pixiv.py 1.9 KB

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