mirror of
https://github.com/searxng/searxng.git
synced 2026-05-27 13:20:11 +02:00
[fix] iqiyi: Add support for multiple videos per album
Add support for albums containing multiple videos in iqiyi engine. When albumInfo contains a "videos" list, process each video individually to create separate search results for each episode/video instead of a single result for the entire album. Also get video length from `duration` instead of `subscriptContent`. Signed-off-by: Hu Butui <hot123tea123@gmail.com>
This commit is contained in:
+31
-23
@@ -1,11 +1,12 @@
|
|||||||
# SPDX-License-Identifier: AGPL-3.0-or-later
|
# SPDX-License-Identifier: AGPL-3.0-or-later
|
||||||
"""iQiyi: A search engine for retrieving videos from iQiyi."""
|
"""iQiyi: A search engine for retrieving videos from iQiyi."""
|
||||||
|
|
||||||
|
import typing
|
||||||
|
|
||||||
from urllib.parse import urlencode
|
from urllib.parse import urlencode
|
||||||
from datetime import datetime
|
from datetime import datetime, timedelta
|
||||||
|
|
||||||
from searx.exceptions import SearxEngineAPIException
|
from searx.exceptions import SearxEngineAPIException
|
||||||
from searx.utils import parse_duration_string
|
|
||||||
|
|
||||||
about = {
|
about = {
|
||||||
"website": "https://www.iqiyi.com/",
|
"website": "https://www.iqiyi.com/",
|
||||||
@@ -35,6 +36,28 @@ def request(query, params):
|
|||||||
return params
|
return params
|
||||||
|
|
||||||
|
|
||||||
|
def _result(video: dict[str, typing.Any], album_info: dict[str, typing.Any]):
|
||||||
|
length = timedelta(milliseconds=video.get("duration", 0))
|
||||||
|
|
||||||
|
published_date = None
|
||||||
|
release_time = album_info.get("releaseTime", {}).get("value")
|
||||||
|
if release_time:
|
||||||
|
try:
|
||||||
|
published_date = datetime.strptime(release_time, "%Y-%m-%d")
|
||||||
|
except (ValueError, TypeError):
|
||||||
|
pass
|
||||||
|
|
||||||
|
return {
|
||||||
|
'url': video.get("pageUrl", "").replace("http://", "https://"),
|
||||||
|
'title': video.get("title", ""),
|
||||||
|
'content': album_info.get("brief", {}).get("value", ""),
|
||||||
|
'template': 'videos.html',
|
||||||
|
'length': length,
|
||||||
|
'publishedDate': published_date,
|
||||||
|
'thumbnail': album_info.get("img", ""),
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
def response(resp):
|
def response(resp):
|
||||||
try:
|
try:
|
||||||
data = resp.json()
|
data = resp.json()
|
||||||
@@ -47,26 +70,11 @@ def response(resp):
|
|||||||
|
|
||||||
for entry in data["data"]["templates"]:
|
for entry in data["data"]["templates"]:
|
||||||
album_info = entry.get("albumInfo", {})
|
album_info = entry.get("albumInfo", {})
|
||||||
|
if "videos" in album_info:
|
||||||
published_date = None
|
for video in album_info["videos"]:
|
||||||
release_time = album_info.get("releaseTime", {}).get("value")
|
results.append(_result(video, album_info))
|
||||||
if release_time:
|
else:
|
||||||
try:
|
# album only contains a single video
|
||||||
published_date = datetime.strptime(release_time, "%Y-%m-%d")
|
results.append(_result(album_info, album_info))
|
||||||
except (ValueError, TypeError):
|
|
||||||
pass
|
|
||||||
|
|
||||||
length = parse_duration_string(album_info.get("subscriptContent"))
|
|
||||||
results.append(
|
|
||||||
{
|
|
||||||
'url': album_info.get("pageUrl", "").replace("http://", "https://"),
|
|
||||||
'title': album_info.get("title", ""),
|
|
||||||
'content': album_info.get("brief", {}).get("value", ""),
|
|
||||||
'template': 'videos.html',
|
|
||||||
'length': length,
|
|
||||||
'publishedDate': published_date,
|
|
||||||
'thumbnail': album_info.get("img", ""),
|
|
||||||
}
|
|
||||||
)
|
|
||||||
|
|
||||||
return results
|
return results
|
||||||
|
|||||||
Reference in New Issue
Block a user