refactor: 修改emby、jellyfin API url请求传参方式

This commit is contained in:
owen
2024-09-16 20:23:24 +08:00
parent 4efc80e35a
commit 8306aa92db
2 changed files with 220 additions and 102 deletions

View File

@@ -59,9 +59,12 @@ class Emby:
"""
if not self._host or not self._apikey:
return []
req_url = "%semby/Library/SelectableMediaFolders?api_key=%s" % (self._host, self._apikey)
url = f"{self._host}emby/Library/SelectableMediaFolders"
params = {
'api_key': self._apikey
}
try:
res = RequestUtils().get_res(req_url)
res = RequestUtils().get_res(url, params)
if res:
return res.json()
else:
@@ -77,9 +80,12 @@ class Emby:
"""
if not self._host or not self._apikey:
return []
req_url = "%semby/Library/VirtualFolders/Query?api_key=%s" % (self._host, self._apikey)
url = f"{self._host}emby/Library/VirtualFolders/Query"
params = {
'api_key': self._apikey
}
try:
res = RequestUtils().get_res(req_url)
res = RequestUtils().get_res(url, params)
if res:
library_items = res.json().get("Items")
librarys = []
@@ -116,9 +122,10 @@ class Emby:
user = self.get_user(username)
else:
user = self.user
req_url = f"{self._host}emby/Users/{user}/Views?api_key={self._apikey}"
url = f"{self._host}emby/Users/{user}/Views"
params = {"api_key": self._apikey}
try:
res = RequestUtils().get_res(req_url)
res = RequestUtils().get_res(url, params)
if res:
return res.json().get("Items")
else:
@@ -166,9 +173,12 @@ class Emby:
"""
if not self._host or not self._apikey:
return None
req_url = "%sUsers?api_key=%s" % (self._host, self._apikey)
url = f"{self._host}Users"
params = {
"api_key": self._apikey
}
try:
res = RequestUtils().get_res(req_url)
res = RequestUtils().get_res(url, params)
if res:
users = res.json()
# 先查询是否有与当前用户名称匹配的
@@ -195,7 +205,7 @@ class Emby:
"""
if not self._host or not self._apikey:
return None
req_url = "%semby/Users/AuthenticateByName" % self._host
url = f"{self._host}emby/Users/AuthenticateByName"
try:
res = RequestUtils(headers={
'X-Emby-Authorization': f'MediaBrowser Client="MoviePilot", '
@@ -206,7 +216,7 @@ class Emby:
'Content-Type': 'application/json',
"Accept": "application/json"
}).post_res(
url=req_url,
url=url,
data=json.dumps({
"Username": username,
"Pw": password
@@ -229,9 +239,12 @@ class Emby:
"""
if not self._host or not self._apikey:
return None
req_url = "%sSystem/Info?api_key=%s" % (self._host, self._apikey)
url = f"{self._host}System/Info"
params = {
'api_key': self._apikey
}
try:
res = RequestUtils().get_res(req_url)
res = RequestUtils().get_res(url, params)
if res:
return res.json().get("Id")
else:
@@ -247,9 +260,12 @@ class Emby:
"""
if not self._host or not self._apikey:
return 0
req_url = "%semby/Users/Query?api_key=%s" % (self._host, self._apikey)
url = f"{self._host}emby/Users/Query"
params = {
'api_key': self._apikey
}
try:
res = RequestUtils().get_res(req_url)
res = RequestUtils().get_res(url, params)
if res:
return res.json().get("TotalRecordCount")
else:
@@ -266,9 +282,12 @@ class Emby:
"""
if not self._host or not self._apikey:
return schemas.Statistic()
req_url = "%semby/Items/Counts?api_key=%s" % (self._host, self._apikey)
url = f"{self._host}emby/Items/Counts"
params = {
'api_key': self._apikey
}
try:
res = RequestUtils().get_res(req_url)
res = RequestUtils().get_res(url, params)
if res:
result = res.json()
return schemas.Statistic(
@@ -292,18 +311,19 @@ class Emby:
"""
if not self._host or not self._apikey:
return None
req_url = ("%semby/Items?"
"IncludeItemTypes=Series"
"&Fields=ProductionYear"
"&StartIndex=0"
"&Recursive=true"
"&SearchTerm=%s"
"&Limit=10"
"&IncludeSearchTypes=false"
"&api_key=%s") % (
self._host, name, self._apikey)
url = f"{self._host}emby/Items"
params={
"IncludeItemTypes": "Series",
"Fields": "ProductionYear",
"StartIndex": 0,
"Recursive": "true",
"SearchTerm": name,
"Limit": 10,
"IncludeSearchTypes": "false",
"api_key": self._apikey
}
try:
res = RequestUtils().get_res(req_url)
res = RequestUtils().get_res(url, params)
if res:
res_items = res.json().get("Items")
if res_items:
@@ -329,11 +349,19 @@ class Emby:
"""
if not self._host or not self._apikey:
return None
req_url = "%semby/Items?IncludeItemTypes=Movie&Fields=ProductionYear&StartIndex=0" \
"&Recursive=true&SearchTerm=%s&Limit=10&IncludeSearchTypes=false&api_key=%s" % (
self._host, title, self._apikey)
url = f"{self._host}emby/Items"
params = {
"IncludeItemTypes": "Movie",
"Fields": "ProductionYear",
"StartIndex": 0,
"Recursive": "true",
"SearchTerm": title,
"Limit": 10,
"IncludeSearchTypes": "false",
"api_key": self._apikey
}
try:
res = RequestUtils().get_res(req_url)
res = RequestUtils().get_res(url, params)
if res:
res_items = res.json().get("Items")
if res_items:
@@ -403,9 +431,13 @@ class Emby:
if not season:
season = ""
try:
req_url = "%semby/Shows/%s/Episodes?Season=%s&IsMissing=false&api_key=%s" % (
self._host, item_id, season, self._apikey)
res_json = RequestUtils().get_res(req_url)
url = f"{self._host}emby/Shows/{item_id}/Episodes"
params = {
"Season": season,
"IsMissing": "false",
"api_key": self._apikey
}
res_json = RequestUtils().get_res(url, params)
if res_json:
tv_item = res_json.json()
res_items = tv_item.get("Items")
@@ -438,9 +470,12 @@ class Emby:
"""
if not self._host or not self._apikey:
return None
req_url = "%semby/Items/%s/RemoteImages?api_key=%s" % (self._host, item_id, self._apikey)
url = f"{self._host}emby/Items/{item_id}/RemoteImages"
params = {
"api_key": self._apikey
}
try:
res = RequestUtils(timeout=10).get_res(req_url)
res = RequestUtils(timeout=10).get_res(url, params)
if res:
images = res.json().get("Images")
if images:
@@ -465,9 +500,9 @@ class Emby:
logger.error("Emby外网播放地址未能获取或为空")
return None
req_url = "%sItems/%s/Images/%s" % (self._playhost, item_id, image_type)
url = f"{self._playhost}Items/{item_id}/Images/{image_type}"
try:
res = RequestUtils().get_res(req_url)
res = RequestUtils().get_res(url)
if res and res.status_code != 404:
logger.info(f"影片图片链接:{res.url}")
return res.url
@@ -484,9 +519,13 @@ class Emby:
"""
if not self._host or not self._apikey:
return False
req_url = "%semby/Items/%s/Refresh?Recursive=true&api_key=%s" % (self._host, item_id, self._apikey)
url = f"{self._host}emby/Items/{item_id}/Refresh"
params = {
"Recursive": "true",
"api_key": self._apikey
}
try:
res = RequestUtils().post_res(req_url)
res = RequestUtils().post_res(url, params)
if res:
return True
else:
@@ -502,9 +541,12 @@ class Emby:
"""
if not self._host or not self._apikey:
return False
req_url = "%semby/Library/Refresh?api_key=%s" % (self._host, self._apikey)
url = f"{self._host}emby/Library/Refresh"
params = {
"api_key": self._apikey
}
try:
res = RequestUtils().post_res(req_url)
res = RequestUtils().post_res(url, params)
if res:
return True
else:
@@ -581,9 +623,12 @@ class Emby:
return None
if not self._host or not self._apikey:
return None
req_url = "%semby/Users/%s/Items/%s?api_key=%s" % (self._host, self.user, itemid, self._apikey)
url = f"{self._host}emby/Users/{self.user}/Items/{itemid}"
params = {
"api_key": self._apikey
}
try:
res = RequestUtils().get_res(req_url)
res = RequestUtils().get_res(url, params)
if res and res.status_code == 200:
item = res.json()
tmdbid = item.get("ProviderIds", {}).get("Tmdb")
@@ -612,9 +657,13 @@ class Emby:
yield None
if not self._host or not self._apikey:
yield None
req_url = "%semby/Users/%s/Items?ParentId=%s&api_key=%s" % (self._host, self.user, parent, self._apikey)
url = f"{self._host}emby/Users/{self.user}/Items"
params = {
"ParentId": parent,
"api_key": self._apikey
}
try:
res = RequestUtils().get_res(req_url)
res = RequestUtils().get_res(url, params)
if res and res.status_code == 200:
results = res.json().get("Items") or []
for result in results:
@@ -1033,10 +1082,15 @@ class Emby:
user = self.get_user(username)
else:
user = self.user
req_url = (f"{self._host}Users/{user}/Items/Resume?"
f"Limit=100&MediaTypes=Video&api_key={self._apikey}&Fields=ProductionYear,Path")
url = f"{self._host}Users/{user}/Items/Resume"
params = {
"Limit": 100,
"MediaTypes": "Video",
"Fields": "ProductionYear,Path",
"api_key": self._apikey,
}
try:
res = RequestUtils().get_res(req_url)
res = RequestUtils().get_res(url, params)
if res:
result = res.json().get("Items") or []
ret_resume = []
@@ -1096,10 +1150,15 @@ class Emby:
user = self.get_user(username)
else:
user = self.user
req_url = (f"{self._host}Users/{user}/Items/Latest?"
f"Limit=100&MediaTypes=Video&api_key={self._apikey}&Fields=ProductionYear,Path")
url = f"{self._host}Users/{user}/Items/Latest"
params = {
"Limit": 100,
"MediaTypes": "Video",
"Fields": "ProductionYear,Path",
"api_key": self._apikey
}
try:
res = RequestUtils().get_res(req_url)
res = RequestUtils().get_res(url, params)
if res:
result = res.json() or []
ret_latest = []

View File

@@ -55,9 +55,12 @@ class Jellyfin:
"""
if not self._host or not self._apikey:
return []
req_url = "%sLibrary/SelectableMediaFolders?api_key=%s" % (self._host, self._apikey)
url = f"{self._host}Library/SelectableMediaFolders"
params = {
'api_key': self._apikey
}
try:
res = RequestUtils().get_res(req_url)
res = RequestUtils().get_res(url, params)
if res:
return res.json()
else:
@@ -73,9 +76,13 @@ class Jellyfin:
"""
if not self._host or not self._apikey:
return []
req_url = "%sLibrary/VirtualFolders?api_key=%s" % (self._host, self._apikey)
url = f"{self._host}Library/VirtualFolders"
params = {
'api_key': self._apikey
}
try:
res = RequestUtils().get_res(req_url)
res = RequestUtils().get_res(url, params)
if res:
library_items = res.json()
librarys = []
@@ -112,9 +119,10 @@ class Jellyfin:
user = self.get_user(username)
else:
user = self.user
req_url = f"{self._host}Users/{user}/Views?api_key={self._apikey}"
url = f"{self._host}Users/{user}/Views"
params = {"api_key": self._apikey}
try:
res = RequestUtils().get_res(req_url)
res = RequestUtils().get_res(url, params)
if res:
return res.json().get("Items")
else:
@@ -165,9 +173,12 @@ class Jellyfin:
"""
if not self._host or not self._apikey:
return 0
req_url = "%sUsers?api_key=%s" % (self._host, self._apikey)
url = f"{self._host}Users"
params = {
"api_key": self._apikey
}
try:
res = RequestUtils().get_res(req_url)
res = RequestUtils().get_res(url, params)
if res:
return len(res.json())
else:
@@ -183,9 +194,12 @@ class Jellyfin:
"""
if not self._host or not self._apikey:
return None
req_url = "%sUsers?api_key=%s" % (self._host, self._apikey)
url = f"{self._host}Users"
params = {
"api_key": self._apikey
}
try:
res = RequestUtils().get_res(req_url)
res = RequestUtils().get_res(url, params)
if res:
users = res.json()
# 先查询是否有与当前用户名称匹配的
@@ -212,7 +226,7 @@ class Jellyfin:
"""
if not self._host or not self._apikey:
return None
req_url = "%sUsers/authenticatebyname" % self._host
url = f"{self._host}Users/authenticatebyname"
try:
res = RequestUtils(headers={
'X-Emby-Authorization': f'MediaBrowser Client="MoviePilot", '
@@ -223,7 +237,7 @@ class Jellyfin:
'Content-Type': 'application/json',
"Accept": "application/json"
}).post_res(
url=req_url,
url=url,
data=json.dumps({
"Username": username,
"Pw": password
@@ -246,9 +260,12 @@ class Jellyfin:
"""
if not self._host or not self._apikey:
return None
req_url = "%sSystem/Info?api_key=%s" % (self._host, self._apikey)
url = f"{self._host}System/Info"
params = {
'api_key': self._apikey
}
try:
res = RequestUtils().get_res(req_url)
res = RequestUtils().get_res(url, params)
if res:
return res.json().get("Id")
else:
@@ -264,9 +281,12 @@ class Jellyfin:
"""
if not self._host or not self._apikey:
return schemas.Statistic()
req_url = "%sItems/Counts?api_key=%s" % (self._host, self._apikey)
url = f"{self._host}Items/Counts"
params = {
'api_key': self._apikey
}
try:
res = RequestUtils().get_res(req_url)
res = RequestUtils().get_res(url, params)
if res:
result = res.json()
return schemas.Statistic(
@@ -287,11 +307,16 @@ class Jellyfin:
"""
if not self._host or not self._apikey or not self.user:
return None
req_url = ("%sUsers/%s/Items?"
"api_key=%s&searchTerm=%s&IncludeItemTypes=Series&Limit=10&Recursive=true") % (
self._host, self.user, self._apikey, name)
url = f"{self._host}Users/{self.user}/Items"
params = {
"IncludeItemTypes": "Series",
"Recursive": "true",
"searchTerm": name,
"Limit": 10,
"api_key": self._apikey
}
try:
res = RequestUtils().get_res(req_url)
res = RequestUtils().get_res(url, params)
if res:
res_items = res.json().get("Items")
if res_items:
@@ -317,11 +342,16 @@ class Jellyfin:
"""
if not self._host or not self._apikey or not self.user:
return None
req_url = ("%sUsers/%s/Items?"
"api_key=%s&searchTerm=%s&IncludeItemTypes=Movie&Limit=10&Recursive=true") % (
self._host, self.user, self._apikey, title)
url = f"{self._host}Users/{self.user}/Items"
params = {
"IncludeItemTypes": "Movie",
"Recursive": "true",
"searchTerm": title,
"Limit": 10,
"api_key": self._apikey
}
try:
res = RequestUtils().get_res(req_url)
res = RequestUtils().get_res(url, params)
if res:
res_items = res.json().get("Items")
if res_items:
@@ -388,10 +418,15 @@ class Jellyfin:
return None, {}
if not season:
season = ""
url = f"{self._host}Shows/{item_id}/Episodes"
params = {
"season": season,
"userId": self.user,
"isMissing": "false",
"api_key": self._apikey
}
try:
req_url = "%sShows/%s/Episodes?season=%s&&userId=%s&isMissing=false&api_key=%s" % (
self._host, item_id, season, self.user, self._apikey)
res_json = RequestUtils().get_res(req_url)
res_json = RequestUtils().get_res(url, params)
if res_json:
tv_info = res_json.json()
res_items = tv_info.get("Items")
@@ -418,15 +453,16 @@ class Jellyfin:
def get_remote_image_by_id(self, item_id: str, image_type: str) -> Optional[str]:
"""
根据ItemId从Jellyfin查询TMDB图片地址
:param item_id: 在Emby中的ID
:param item_id: 在Jellyfin中的ID
:param image_type: 图片的类弄地poster或者backdrop等
:return: 图片对应在TMDB中的URL
"""
if not self._host or not self._apikey:
return None
req_url = "%sItems/%s/RemoteImages?api_key=%s" % (self._host, item_id, self._apikey)
url = f"{self._host}Items/{item_id}/RemoteImages"
params = {"api_key": self._apikey}
try:
res = RequestUtils(timeout=10).get_res(req_url)
res = RequestUtils(timeout=10).get_res(url, params)
if res:
images = res.json().get("Images")
for image in images:
@@ -460,9 +496,9 @@ class Jellyfin:
_host = self._host
if host_type:
_host = self._playhost
req_url = "%sItems/%s/Images/%s" % (_host, item_id, image_type)
url = f"{_host}Items/{item_id}/Images/{image_type}"
try:
res = RequestUtils().get_res(req_url)
res = RequestUtils().get_res(url)
if res and res.status_code != 404:
logger.info(f"影片图片链接:{res.url}")
return res.url
@@ -481,9 +517,12 @@ class Jellyfin:
:param key: 需要得到父item中的键值对
:return key对应类型的值
"""
req_url = "%sItems/%s/Ancestors?api_key=%s" % (self._host, item_id, self._apikey)
url = f"{self._host}Items/{item_id}/Ancestors"
params = {
"api_key": self._apikey
}
try:
res = RequestUtils().get_res(req_url)
res = RequestUtils().get_res(url, params)
if res:
return res.json()[index].get(key)
else:
@@ -499,9 +538,12 @@ class Jellyfin:
"""
if not self._host or not self._apikey:
return False
req_url = "%sLibrary/Refresh?api_key=%s" % (self._host, self._apikey)
url = f"{self._host}Library/Refresh"
params = {
"api_key": self._apikey
}
try:
res = RequestUtils().post_res(req_url)
res = RequestUtils().post_res(url, params)
if res:
return True
else:
@@ -640,10 +682,12 @@ class Jellyfin:
return None
if not self._host or not self._apikey:
return None
req_url = "%sUsers/%s/Items/%s?api_key=%s" % (
self._host, self.user, itemid, self._apikey)
url = f"{self._host}Users/{self.user}/Items/{itemid}"
params = {
"api_key": self._apikey
}
try:
res = RequestUtils().get_res(req_url)
res = RequestUtils().get_res(url, params)
if res and res.status_code == 200:
item = res.json()
tmdbid = item.get("ProviderIds", {}).get("Tmdb")
@@ -672,9 +716,13 @@ class Jellyfin:
yield None
if not self._host or not self._apikey:
yield None
req_url = "%sUsers/%s/Items?parentId=%s&api_key=%s" % (self._host, self.user, parent, self._apikey)
url = f"{self._host}Users/{self.user}/Items"
params = {
"parentId": parent,
"api_key": self._apikey
}
try:
res = RequestUtils().get_res(req_url)
res = RequestUtils().get_res(url, params)
if res and res.status_code == 200:
results = res.json().get("Items") or []
for result in results:
@@ -736,7 +784,7 @@ class Jellyfin:
def __get_local_image_by_id(self, item_id: str) -> str:
"""
根据ItemId从媒体服务器查询有声书图片地址
:param: item_id: 在Emby中的ID
:param: item_id: 在Jellyfin中的ID
:param: remote 是否远程使用TG微信等客户端调用应为True
:param: inner 是否NT内部调用为True是会使用NT中转
"""
@@ -747,7 +795,7 @@ class Jellyfin:
def __get_backdrop_url(self, item_id: str, image_tag: str) -> str:
"""
获取Backdrop图片地址
:param: item_id: 在Emby中的ID
:param: item_id: 在Jellyfin中的ID
:param: image_tag: 图片的tag
:param: remote 是否远程使用TG微信等客户端调用应为True
:param: inner 是否NT内部调用为True是会使用NT中转
@@ -769,10 +817,16 @@ class Jellyfin:
user = self.get_user(username)
else:
user = self.user
req_url = (f"{self._host}Users/{user}/Items/Resume?"
f"Limit=100&MediaTypes=Video&api_key={self._apikey}&Fields=ProductionYear,Path")
url = f"{self._host}Users/{user}/Items/Resume"
params = {
"Limit": 100,
"MediaTypes": "Video",
"Fields": "ProductionYear,Path",
"api_key": self._apikey,
}
try:
res = RequestUtils().get_res(req_url)
res = RequestUtils().get_res(url, params)
if res:
result = res.json().get("Items") or []
ret_resume = []
@@ -830,10 +884,15 @@ class Jellyfin:
user = self.get_user(username)
else:
user = self.user
req_url = (f"{self._host}Users/{user}/Items/Latest?"
f"Limit=100&MediaTypes=Video&api_key={self._apikey}&Fields=ProductionYear,Path")
url = f"{self._host}Users/{user}/Items/Latest"
params = {
"Limit": 100,
"MediaTypes": "Video",
"Fields": "ProductionYear,Path",
"api_key": self._apikey,
}
try:
res = RequestUtils().get_res(req_url)
res = RequestUtils().get_res(url, params)
if res:
result = res.json() or []
ret_latest = []
@@ -868,7 +927,7 @@ class Jellyfin:
def get_user_library_folders(self):
"""
获取Emby媒体库文件夹列表(排除黑名单)
获取Jellyfin媒体库文件夹列表(排除黑名单)
"""
if not self._host or not self._apikey:
return []