pixiv.py 1.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172
  1. # SPDX-License-Identifier: AGPL-3.0-or-later
  2. """Pixiv (images)"""
  3. from urllib.parse import urlencode
  4. import random
  5. # Engine metadata
  6. about = {
  7. "website": 'https://www.pixiv.net/',
  8. "wikidata_id": 'Q306956',
  9. "official_api_documentation": None,
  10. "use_official_api": False,
  11. "require_api_key": False,
  12. "results": 'JSON',
  13. }
  14. # Engine configuration
  15. paging = True
  16. categories = ['images']
  17. # Search URL
  18. base_url = "https://www.pixiv.net/ajax/search/illustrations"
  19. pixiv_image_proxies: list = []
  20. def request(query, params):
  21. query_params = {
  22. "word": query,
  23. "order": "date_d",
  24. "mode": "all",
  25. "p": params["pageno"],
  26. "s_mode": "s_tag_full",
  27. "type": "illust_and_ugoira",
  28. "lang": "en",
  29. }
  30. params["url"] = f"{base_url}/{query}?{urlencode(query_params)}"
  31. return params
  32. def response(resp):
  33. results = []
  34. data = resp.json()
  35. for item in data["body"]["illust"]["data"]:
  36. image_url = item["url"]
  37. pixiv_proxy = random.choice(pixiv_image_proxies)
  38. proxy_image_url = image_url.replace("https://i.pximg.net", pixiv_proxy)
  39. proxy_full_image_url = (
  40. proxy_image_url.replace("/c/250x250_80_a2/", "/")
  41. .replace("_square1200.jpg", "_master1200.jpg")
  42. .replace("custom-thumb", "img-master")
  43. .replace("_custom1200.jpg", "_master1200.jpg")
  44. )
  45. results.append(
  46. {
  47. "title": item.get("title"),
  48. "url": proxy_full_image_url,
  49. 'content': item.get('alt'),
  50. "author": f"{item.get('userName')} (ID: {item.get('userId')})",
  51. "img_src": proxy_full_image_url,
  52. "thumbnail_src": proxy_image_url,
  53. "source": 'pixiv.net',
  54. "template": "images.html",
  55. }
  56. )
  57. return results