Update arrhist script
This commit is contained in:
parent
9b497a5174
commit
4431e54740
@ -6,6 +6,7 @@ from datetime import datetime, date, timedelta
|
|||||||
|
|
||||||
SECRET_DIR = "/home/torjus/.config/sops-nix/secrets"
|
SECRET_DIR = "/home/torjus/.config/sops-nix/secrets"
|
||||||
|
|
||||||
|
|
||||||
def sonarr_url():
|
def sonarr_url():
|
||||||
xdg_dir = os.environ["XDG_RUNTIME_DIR"]
|
xdg_dir = os.environ["XDG_RUNTIME_DIR"]
|
||||||
if not xdg_dir:
|
if not xdg_dir:
|
||||||
@ -13,26 +14,31 @@ def sonarr_url():
|
|||||||
with open(f"{SECRET_DIR}/sonarr_base_url") as f:
|
with open(f"{SECRET_DIR}/sonarr_base_url") as f:
|
||||||
return f.read().strip()
|
return f.read().strip()
|
||||||
|
|
||||||
|
|
||||||
def radarr_url():
|
def radarr_url():
|
||||||
with open(f"{SECRET_DIR}/radarr_base_url") as f:
|
with open(f"{SECRET_DIR}/radarr_base_url") as f:
|
||||||
return f.read().strip()
|
return f.read().strip()
|
||||||
|
|
||||||
|
|
||||||
def make_header(api_key: str):
|
def make_header(api_key: str):
|
||||||
return {"X-Api-Key": api_key, "Accept": "application/json"}
|
return {"X-Api-Key": api_key, "Accept": "application/json"}
|
||||||
|
|
||||||
|
|
||||||
def get_sonarr_key():
|
def get_sonarr_key():
|
||||||
with open(f"{SECRET_DIR}/sonarr_api_key") as f:
|
with open(f"{SECRET_DIR}/sonarr_api_key") as f:
|
||||||
return f.read().strip()
|
return f.read().strip()
|
||||||
|
|
||||||
|
|
||||||
def get_radarr_key():
|
def get_radarr_key():
|
||||||
with open(f"{SECRET_DIR}/radarr_api_key") as f:
|
with open(f"{SECRET_DIR}/radarr_api_key") as f:
|
||||||
return f.read().strip()
|
return f.read().strip()
|
||||||
|
|
||||||
def get_sonarr_history(since: datetime|None=None):
|
|
||||||
|
def get_sonarr_history(since: datetime | None = None):
|
||||||
api_key = get_sonarr_key()
|
api_key = get_sonarr_key()
|
||||||
if not since:
|
if not since:
|
||||||
since = datetime.combine(date.today()-timedelta(days=1),datetime.min.time())
|
since = datetime.combine(date.today() - timedelta(days=1), datetime.min.time())
|
||||||
url = f"{sonarr_url()}/api/history/since"
|
url = f"{sonarr_url()}/api/v3/history/since"
|
||||||
url += f"?date={since.isoformat()}"
|
url += f"?date={since.isoformat()}"
|
||||||
response = requests.get(url, headers=make_header(api_key))
|
response = requests.get(url, headers=make_header(api_key))
|
||||||
response.raise_for_status()
|
response.raise_for_status()
|
||||||
@ -44,10 +50,11 @@ def get_sonarr_history(since: datetime|None=None):
|
|||||||
items.append(item["sourceTitle"])
|
items.append(item["sourceTitle"])
|
||||||
return items
|
return items
|
||||||
|
|
||||||
def get_radarr_history(since: datetime|None=None):
|
|
||||||
|
def get_radarr_history(since: datetime | None = None):
|
||||||
api_key = get_radarr_key()
|
api_key = get_radarr_key()
|
||||||
if not since:
|
if not since:
|
||||||
since = datetime.combine(date.today()-timedelta(days=7),datetime.min.time())
|
since = datetime.combine(date.today() - timedelta(days=7), datetime.min.time())
|
||||||
url = f"{radarr_url()}/api/v3/history/since"
|
url = f"{radarr_url()}/api/v3/history/since"
|
||||||
url += f"?date={since.isoformat()}"
|
url += f"?date={since.isoformat()}"
|
||||||
response = requests.get(url, headers=make_header(api_key))
|
response = requests.get(url, headers=make_header(api_key))
|
||||||
@ -60,12 +67,17 @@ def get_radarr_history(since: datetime|None=None):
|
|||||||
items.append(item["sourceTitle"])
|
items.append(item["sourceTitle"])
|
||||||
return items
|
return items
|
||||||
|
|
||||||
|
|
||||||
if __name__ == "__main__":
|
if __name__ == "__main__":
|
||||||
sonarr_items = get_sonarr_history()
|
sonarr_items = get_sonarr_history()
|
||||||
radarr_items = get_radarr_history()
|
radarr_items = get_radarr_history()
|
||||||
|
|
||||||
output = {
|
output = {
|
||||||
"text": f"Son: {len(sonarr_items)}|Rad: {len(radarr_items)}",
|
"text": f"Son: {len(sonarr_items)}|Rad: {len(radarr_items)}",
|
||||||
"tooltip": "Radarr: \n" + "\n".join(radarr_items) + "\n" + "Sonarr: \n" + "\n".join(sonarr_items)
|
"tooltip": "Radarr: \n"
|
||||||
|
+ "\n".join(radarr_items)
|
||||||
|
+ "\n"
|
||||||
|
+ "Sonarr: \n"
|
||||||
|
+ "\n".join(sonarr_items),
|
||||||
}
|
}
|
||||||
print(json.dumps(output))
|
print(json.dumps(output))
|
||||||
|
Loading…
Reference in New Issue
Block a user