findthatmeme.py 1.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354
  1. # SPDX-License-Identifier: AGPL-3.0-or-later
  2. """FindThatMeme (Images)"""
  3. from json import dumps
  4. from datetime import datetime
  5. from searx.utils import humanize_bytes
  6. about = {
  7. "website": 'https://findthatmeme.com',
  8. "official_api_documentation": None,
  9. "use_official_api": False,
  10. "require_api_key": False,
  11. "results": "JSON",
  12. }
  13. base_url = "https://findthatmeme.com/api/v1/search"
  14. categories = ['images']
  15. paging = True
  16. def request(query, params):
  17. start_index = (params["pageno"] - 1) * 50
  18. data = {"search": query, "offset": start_index}
  19. params["url"] = base_url
  20. params["method"] = 'POST'
  21. params['headers']['content-type'] = "application/json"
  22. params['data'] = dumps(data)
  23. return params
  24. def response(resp):
  25. search_res = resp.json()
  26. results = []
  27. for item in search_res:
  28. img = 'https://s3.thehackerblog.com/findthatmeme/' + item['image_path']
  29. thumb = 'https://s3.thehackerblog.com/findthatmeme/thumb/' + item.get('thumbnail', '')
  30. date = datetime.strptime(item["updated_at"].split("T")[0], "%Y-%m-%d")
  31. formatted_date = datetime.fromtimestamp(date.timestamp())
  32. results.append(
  33. {
  34. 'url': item['source_page_url'],
  35. 'title': item['source_site'],
  36. 'img_src': img if item['type'] == 'IMAGE' else thumb,
  37. 'filesize': humanize_bytes(item['meme_file_size']),
  38. 'publishedDate': formatted_date,
  39. 'template': 'images.html',
  40. }
  41. )
  42. return results