mirror of
https://github.com/Benexl/FastAnime.git
synced 2025-12-12 15:50:01 -08:00
116 lines
3.4 KiB
Python
116 lines
3.4 KiB
Python
"""An abstraction over all providers offering added features with a simple and well typed api
|
|
|
|
[TODO:description]
|
|
"""
|
|
|
|
import importlib
|
|
import logging
|
|
from typing import TYPE_CHECKING
|
|
|
|
from .libs.anime_provider import anime_sources
|
|
|
|
if TYPE_CHECKING:
|
|
from typing import Iterator
|
|
|
|
from .libs.anime_provider.types import Anime, SearchResults, Server
|
|
|
|
logger = logging.getLogger(__name__)
|
|
|
|
|
|
# TODO: improve performance of this class and add cool features like auto retry
|
|
class AnimeProvider:
|
|
"""Class that manages all anime sources adding some extra functionality to them.
|
|
Attributes:
|
|
PROVIDERS: [TODO:attribute]
|
|
provider: [TODO:attribute]
|
|
provider: [TODO:attribute]
|
|
dynamic: [TODO:attribute]
|
|
retries: [TODO:attribute]
|
|
anime_provider: [TODO:attribute]
|
|
"""
|
|
|
|
PROVIDERS = list(anime_sources.keys())
|
|
provider = PROVIDERS[0]
|
|
|
|
def __init__(self, provider, dynamic=False, retries=0) -> None:
|
|
self.provider = provider
|
|
self.dynamic = dynamic
|
|
self.retries = retries
|
|
self.lazyload_provider(self.provider)
|
|
|
|
def lazyload_provider(self, provider):
|
|
"""updates the current provider being used"""
|
|
_, anime_provider_cls_name = anime_sources[provider].split(".", 1)
|
|
package = f"fastanime.libs.anime_provider.{provider}"
|
|
provider_api = importlib.import_module(".api", package)
|
|
anime_provider = getattr(provider_api, anime_provider_cls_name)
|
|
self.anime_provider = anime_provider()
|
|
|
|
def search_for_anime(
|
|
self,
|
|
user_query,
|
|
translation_type,
|
|
nsfw=True,
|
|
unknown=True,
|
|
) -> "SearchResults | None":
|
|
"""core abstraction over all providers search functionality
|
|
|
|
Args:
|
|
user_query ([TODO:parameter]): [TODO:description]
|
|
translation_type ([TODO:parameter]): [TODO:description]
|
|
nsfw ([TODO:parameter]): [TODO:description]
|
|
unknown ([TODO:parameter]): [TODO:description]
|
|
anilist_obj: [TODO:description]
|
|
|
|
Returns:
|
|
[TODO:return]
|
|
"""
|
|
anime_provider = self.anime_provider
|
|
results = anime_provider.search_for_anime(
|
|
user_query, translation_type, nsfw, unknown
|
|
)
|
|
|
|
return results
|
|
|
|
def get_anime(
|
|
self,
|
|
anime_id: str,
|
|
) -> "Anime | None":
|
|
"""core abstraction over getting info of an anime from all providers
|
|
|
|
Args:
|
|
anime_id: [TODO:description]
|
|
anilist_obj: [TODO:description]
|
|
|
|
Returns:
|
|
[TODO:return]
|
|
"""
|
|
anime_provider = self.anime_provider
|
|
results = anime_provider.get_anime(anime_id)
|
|
|
|
return results
|
|
|
|
def get_episode_streams(
|
|
self,
|
|
anime_id,
|
|
anime_title,
|
|
episode: str,
|
|
translation_type: str,
|
|
) -> "Iterator[Server] | None":
|
|
"""core abstractions for getting juicy streams from all providers
|
|
|
|
Args:
|
|
anime ([TODO:parameter]): [TODO:description]
|
|
episode: [TODO:description]
|
|
translation_type: [TODO:description]
|
|
anilist_obj: [TODO:description]
|
|
|
|
Returns:
|
|
[TODO:return]
|
|
"""
|
|
anime_provider = self.anime_provider
|
|
results = anime_provider.get_episode_streams(
|
|
anime_id, anime_title, episode, translation_type
|
|
)
|
|
return results
|