feat: added request
This commit is contained in:
parent
58ecad37d5
commit
0f01238365
@ -1,6 +1,8 @@
|
|||||||
import requests
|
import requests
|
||||||
|
import logging
|
||||||
from urllib.parse import urlparse, urlunparse, parse_qs
|
from urllib.parse import urlparse, urlunparse, parse_qs
|
||||||
import re
|
import re
|
||||||
|
from typing import Optional
|
||||||
|
|
||||||
from .exceptions import SponsorBlockError, SponsorBlockIdNotFoundError
|
from .exceptions import SponsorBlockError, SponsorBlockIdNotFoundError
|
||||||
|
|
||||||
@ -25,10 +27,32 @@ def _get_video_id(i: str, silent: bool = False) -> None:
|
|||||||
else:
|
else:
|
||||||
return query_stuff["v"][0]
|
return query_stuff["v"][0]
|
||||||
|
|
||||||
|
|
||||||
class SponsorBlock:
|
class SponsorBlock:
|
||||||
def __init__(self, session: requests.Session = None, base_url: str = "https://sponsor.ajay.app"):
|
def __init__(self, session: requests.Session = None, base_url: str = "https://sponsor.ajay.app", silent: bool = False, _requests_logging_exists: bool = False):
|
||||||
self.base_url: str = base_url
|
self.base_url: str = base_url
|
||||||
self.session: requests.Session = session or requests.Session()
|
self.session: requests.Session = session or requests.Session()
|
||||||
|
|
||||||
|
self.silent: bool = silent
|
||||||
|
self._requests_logging_exists: bool = _requests_logging_exists
|
||||||
|
|
||||||
|
self.logger: logging.Logger = logging.Logger("SponsorBlock")
|
||||||
|
|
||||||
|
def _request(self, method: str, endpoint: str) -> Optional[requests.Response]:
|
||||||
|
error_message = ""
|
||||||
|
url = self.base_url + endpoint
|
||||||
|
|
||||||
|
r: requests.Response = None
|
||||||
|
try:
|
||||||
|
r = self.session.request(method="GET", url=url)
|
||||||
|
except requests.exceptions.Timeout:
|
||||||
|
error_message = f"Request timed out at \"{url}\""
|
||||||
|
except requests.exceptions.ConnectionError:
|
||||||
|
error_message = f"Couldn't connect to \"{url}\""
|
||||||
|
|
||||||
|
if error_message != "":
|
||||||
|
if not self._requests_logging_exists:
|
||||||
|
self.logger.error(error_message)
|
||||||
|
if not self.silent:
|
||||||
|
raise exceptions.SponsorBlockConnectionError(error_message)
|
||||||
|
|
||||||
|
return r
|
@ -4,3 +4,6 @@ class SponsorBlockError(Exception):
|
|||||||
|
|
||||||
class SponsorBlockIdNotFoundError(SponsorBlockError):
|
class SponsorBlockIdNotFoundError(SponsorBlockError):
|
||||||
pass
|
pass
|
||||||
|
|
||||||
|
class SponsorBlockConnectionError(SponsorBlockError):
|
||||||
|
pass
|
||||||
|
Loading…
Reference in New Issue
Block a user