| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071 | # SPDX-License-Identifier: AGPL-3.0-or-later"""Pixiv (images)"""from urllib.parse import urlencodeimport random# Engine metadataabout = {    "website": 'https://www.pixiv.net/',    "wikidata_id": 'Q306956',    "official_api_documentation": None,    "use_official_api": False,    "require_api_key": False,    "results": 'JSON',}# Engine configurationpaging = Truecategories = ['images']# Search URLbase_url = "https://www.pixiv.net/ajax/search/illustrations"pixiv_image_proxies: list = []def request(query, params):    query_params = {        "word": query,        "order": "date_d",        "mode": "all",        "p": params["pageno"],        "s_mode": "s_tag_full",        "type": "illust_and_ugoira",        "lang": "en",    }    params["url"] = f"{base_url}/{query}?{urlencode(query_params)}"    return paramsdef response(resp):    results = []    data = resp.json()    for item in data["body"]["illust"]["data"]:        image_url = item["url"]        pixiv_proxy = random.choice(pixiv_image_proxies)        proxy_image_url = image_url.replace("https://i.pximg.net", pixiv_proxy)        proxy_full_image_url = (            proxy_image_url.replace("/c/250x250_80_a2/", "/")            .replace("_square1200.jpg", "_master1200.jpg")            .replace("custom-thumb", "img-master")            .replace("_custom1200.jpg", "_master1200.jpg")        )        results.append(            {                "title": item.get("title"),                "url": proxy_full_image_url,                'content': item.get('alt'),                "author": f"{item.get('userName')} (ID: {item.get('userId')})",                "img_src": proxy_full_image_url,                "thumbnail_src": proxy_image_url,                "source": 'pixiv.net',                "template": "images.html",            }        )    return results
 |