qbit_manage/modules/bhd.py

42 lines
1.4 KiB
Python
Raw Normal View History

"""Module for BeyondHD (BHD) tracker."""
2022-10-29 23:19:09 +08:00
from json import JSONDecodeError
from modules import util
from modules.util import Failed
logger = util.logger
BASE_URL = "https://beyond-hd.me/api/"
2021-12-29 01:19:58 +08:00
class BeyondHD:
"""BeyondHD (BHD) tracker class."""
def __init__(self, config, params):
self.config = config
self.apikey = params["apikey"]
logger.secret(self.apikey)
2021-12-29 01:19:58 +08:00
json = {"search": "test"}
self.search(json)
def search(self, json, path="torrents/"):
"""Search BHD."""
url = f"{BASE_URL}{path}{self.apikey}"
json["action"] = "search"
2022-11-19 22:46:38 +08:00
logger.trace(url)
logger.trace(f"JSON: {json}")
try:
2022-11-19 22:46:38 +08:00
response = self.config.post(url, json=json, headers={"User-Agent": "Chrome"})
logger.trace(response)
response_json = response.json()
except JSONDecodeError as err:
if response.status_code >= 400:
raise Failed(err) from err
elif "Expecting value" in err:
logger.debug(err)
if response.status_code >= 400:
logger.debug(f"Response: {response_json}")
raise Failed(f"({response.status_code} [{response.reason}]) {response_json}")
if not response_json["success"]:
raise Failed(f"BHD Error: {response_json['status_message']}")
2021-12-29 01:19:58 +08:00
return response.json()