Metadata-Version: 2.1
Name: shiki4py
Version: 2.2.0
Summary: Asynchronous client for api Shikimori written in Python 3.7 with asyncio and aiohttp.
Home-page: https://github.com/ren3104/Shiki4py
License: MIT
Keywords: api-client,aiohttp,asyncio,shikimori,anime
Author: ren3104
Author-email: 2ren3104@gmail.com
Requires-Python: >=3.7,<4.0
Classifier: License :: OSI Approved :: MIT License
Classifier: Programming Language :: Python :: 3
Classifier: Programming Language :: Python :: 3.10
Classifier: Programming Language :: Python :: 3.7
Classifier: Programming Language :: Python :: 3.8
Classifier: Programming Language :: Python :: 3.9
Requires-Dist: aiohttp (>=3.8.1,<4.0.0)
Requires-Dist: attrs (>=22.1.0,<23.0.0)
Requires-Dist: cattrs (>=22.1.0,<23.0.0)
Requires-Dist: pyrate-limiter (>=2.8.1,<3.0.0)
Requires-Dist: python-dotenv (>=0.20.0,<0.21.0)
Project-URL: Bug Tracker, https://github.com/ren3104/shikibaio/issues
Project-URL: Repository, https://github.com/ren3104/Shiki4py
Description-Content-Type: text/markdown

<p align="center">
  <img src="https://raw.githubusercontent.com/ren3104/Shiki4py/main/assets/shiki4py_logo_v2.jpg" alt="Shiki4py" width="480">
</p>

<p align="center">
  <a href="https://github.com/ren3104/Shiki4py/blob/main/LICENSE"><img src="https://img.shields.io/github/license/ren3104/Shiki4py" alt="GitHub license"></a>
  <a href="https://pypi.org/project/shiki4py"><img src="https://img.shields.io/pypi/v/shiki4py?color=blue" alt="PyPi package version"></a>
  <a href="https://pypi.org/project/shiki4py"><img src="https://img.shields.io/pypi/pyversions/shiki4py.svg" alt="Supported python versions"></a>
  <img src="https://img.shields.io/github/repo-size/ren3104/shiki4py" alt="GitHub repo size">
  <a href="https://github.com/psf/black"><img src="https://img.shields.io/badge/code%20style-black-000000.svg" alt="Code style: black"></a>
</p>

Асинхронный клиент для взаимодействия с [api Shikimori](https://shikimori.one/api/doc/1.0), написанный на Python 3.7 c использованием [asyncio](https://docs.python.org/3/library/asyncio.html) и [aiohttp](https://github.com/aio-libs/aiohttp).

- [Особенности](#особенности)
- [Установка](#установка)
- [Использование](#использование)
  - [Быстрый старт](#быстрый-старт)
  - [Сохранение токенов авторизации](#сохранение-токенов-авторизации)
- [Зависимости](#зависимости)

## Особенности
* Асинхронность
* Поддержка api v1 и v2
* Ограничения 5rps и 90rpm
* Повторная отправка запроса с экспоненциальной отсрочкой при ошибке 429
* OAuth2 авторизация
* Контроль срока действия токена
* Хранение токенов в `.env` файле
* Свой класс с методами для каждого ресурса api (пока только для `animes`, `comments`, `users`)
* Представление json данных как python классы

## Установка
```bash
pip install shiki4py
```

## Использование
### Быстрый старт
```python
from shiki4py import Shikimori
import asyncio
import logging


logging.basicConfig(level=logging.INFO)


async def main():
    # Клиент без авторизации
    async with Shikimori("APP_NAME") as api:
        clubs = await api.users.clubs(555400)
        print(clubs)

    # Клиент с авторизацией
    api = Shikimori("APP_NAME",
                    "CLIENT_ID",
                    "CLIENT_SECRET")
    await api.open()
    # Отправляем запросы
    # await api.client.request(...)
    # await api.users.favourites(...)
    # await api.comments.show_one(...)
    # ...
    await api.close()


asyncio.run(main())
```
### Сохранение токенов авторизации
По умолчанию клиент сохраняет токены авторизации в файле .env, но при инициализации можно выбрать другой вариант хранения токенов, либо создать свой вариант унаследовав базовый класс и переопределив его методы.
```python
from shiki4py import Shikimori
from shiki4py.store import BaseTokenStore
from shiki4py.store.memory import MemoryTokenStore


class MyTokenStore(BaseTokenStore):
    ...


api = Shikimori("APP_NAME",
                "CLIENT_ID",
                "CLIENT_SECRET",
                # store=MyTokenStore()
                store=MemoryTokenStore())
```

## Зависимости
* [aiohttp](https://github.com/aio-libs/aiohttp) - для асинхронных http запросов
* [PyrateLimiter](https://github.com/vutran1710/PyrateLimiter) - для ограничения частоты запросов
* [attrs](https://github.com/python-attrs/attrs) - для преобразования данных json в python классы
* [cattrs](https://github.com/python-attrs/cattrs) - дополнение к attrs для структурирования и деструктурирования данных
* [python-dotenv](https://github.com/theskumar/python-dotenv) - для сохранения токенов авторизации в `.env` файл

