Add Gitea CI workflow and enhance AnilistAPI with new queries and data handling

- Introduced a Gitea CI workflow for building and publishing the package.
- Updated AnilistAPI to support additional queries for genres and tags.
- Improved request handling and response parsing in the API.
- Enhanced Manga schema to ensure proper type annotations and data structure.
This commit is contained in:
2025-05-23 16:20:56 +02:00
parent 88cc93fd50
commit 049f985c2d
4 changed files with 226 additions and 10 deletions

View File

@@ -1,12 +1,19 @@
import requests
from .schemas.manga import Manga
from .queries.manga import MANGA_QUERY, MANGA_ID_QUERY
from .schemas.manga import Manga, Tag
from .queries.manga import (
MANGA_QUERY,
MANGA_ID_QUERY,
REQUESTS_QUERY,
GENRES_QUERY,
TAGS_QUERY,
)
from limit import limit
from anilistapi import __version__, __contact__
import os
import time
REQUEST_LIMIT = 1
REQUEST_PERIOD = 2
REQUEST_LIMIT = 90
REQUEST_PERIOD = 60
class AnilistAPI:
@@ -19,14 +26,15 @@ class AnilistAPI:
def request(self, query: str, variables: dict) -> dict:
url = "https://graphql.anilist.co"
response = requests.post(url, json={"query": query, "variables": variables})
time.sleep(1)
if response.status_code != 200:
return {}
# raise Exception(f"Error: {response}, response: {response.json()}, query: {query}, variables: {variables}")
return response.json()
def search_manga(self, search: str) -> list[Manga]:
variables = {"search": search}
response = self.request(MANGA_QUERY, variables)
variables = {"search": search, "format": "MANGA"}
response = self.request(REQUESTS_QUERY, variables)
# check if reponse has data Page and media
if not response.get("data", {}).get("Page", {}).get("media"):
return []
@@ -42,3 +50,35 @@ class AnilistAPI:
if not response.get("data", {}).get("Media"):
return None
return Manga(**response["data"]["Media"])
def kompage_search(self, search: str) -> list[Manga]:
variables = {"search": search}
response = self.request(REQUESTS_QUERY, variables)
# check if reponse has data Page and media
if not response.get("data", {}).get("Page", {}).get("media"):
return []
res = []
for manga in response["data"]["Page"]["media"]:
res.append(Manga(**manga))
return res
def get_genres(self) -> list[str]:
variables = {}
response = self.request(GENRES_QUERY, variables)
if not response.get("data", {}).get("genres"):
return []
res = []
for genre in response["data"]["genres"]:
res.append(genre)
return res
def get_tags(self):
variables = {}
response = self.request(TAGS_QUERY, variables)
if not response.get("data", {}).get("tags"):
return []
res = []
for tag in response["data"]["tags"]:
ctag = Tag(**tag)
res.append(ctag.name)
return res