mirror of
https://github.com/Cp0204/quark-auto-save.git
synced 2026-01-11 22:50:45 +08:00
77 lines
2.9 KiB
Python
77 lines
2.9 KiB
Python
import requests
|
||
|
||
|
||
class Emby:
|
||
def __init__(self, **kwargs):
|
||
self.is_active = False
|
||
if kwargs.get("url") and kwargs.get("apikey"):
|
||
self.emby_url = kwargs.get("url")
|
||
self.emby_apikey = kwargs.get("apikey")
|
||
if self.get_info():
|
||
self.is_active = True
|
||
|
||
def get_info(self):
|
||
url = f"{self.emby_url}/emby/System/Info"
|
||
headers = {"X-Emby-Token": self.emby_apikey}
|
||
querystring = {}
|
||
response = requests.request("GET", url, headers=headers, params=querystring)
|
||
if "application/json" in response.headers["Content-Type"]:
|
||
response = response.json()
|
||
print(
|
||
f"Emby媒体库: {response.get('ServerName','')} v{response.get('Version','')}"
|
||
)
|
||
return True
|
||
else:
|
||
print(f"Emby媒体库: 连接失败❌ {response.text}")
|
||
return False
|
||
|
||
def refresh(self, emby_id):
|
||
if emby_id:
|
||
url = f"{self.emby_url}/emby/Items/{emby_id}/Refresh"
|
||
headers = {"X-Emby-Token": self.emby_apikey}
|
||
querystring = {
|
||
"Recursive": "true",
|
||
"MetadataRefreshMode": "FullRefresh",
|
||
"ImageRefreshMode": "FullRefresh",
|
||
"ReplaceAllMetadata": "false",
|
||
"ReplaceAllImages": "false",
|
||
}
|
||
response = requests.request(
|
||
"POST", url, headers=headers, params=querystring
|
||
)
|
||
if response.text == "":
|
||
print(f"🎞 刷新Emby媒体库:成功✅")
|
||
return True
|
||
else:
|
||
print(f"🎞 刷新Emby媒体库:{response.text}❌")
|
||
return False
|
||
|
||
def search(self, media_name):
|
||
if media_name:
|
||
url = f"{self.emby_url}/emby/Items"
|
||
headers = {"X-Emby-Token": self.emby_apikey}
|
||
querystring = {
|
||
"IncludeItemTypes": "Series",
|
||
"StartIndex": 0,
|
||
"SortBy": "SortName",
|
||
"SortOrder": "Ascending",
|
||
"ImageTypeLimit": 0,
|
||
"Recursive": "true",
|
||
"SearchTerm": media_name,
|
||
"Limit": 10,
|
||
"IncludeSearchTypes": "false",
|
||
}
|
||
response = requests.request("GET", url, headers=headers, params=querystring)
|
||
if "application/json" in response.headers["Content-Type"]:
|
||
response = response.json()
|
||
if response.get("Items"):
|
||
for item in response["Items"]:
|
||
if item["IsFolder"]:
|
||
print(
|
||
f"🎞 《{item['Name']}》匹配到Emby媒体库ID:{item['Id']}"
|
||
)
|
||
return item["Id"]
|
||
else:
|
||
print(f"🎞 搜索Emby媒体库:{response.text}❌")
|
||
return False
|