| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354 | 
							- # SPDX-License-Identifier: AGPL-3.0-or-later
 
- """FindThatMeme (Images)"""
 
- from json import dumps
 
- from datetime import datetime
 
- from searx.utils import humanize_bytes
 
- about = {
 
-     "website": 'https://findthatmeme.com',
 
-     "official_api_documentation": None,
 
-     "use_official_api": False,
 
-     "require_api_key": False,
 
-     "results": "JSON",
 
- }
 
- base_url = "https://findthatmeme.com/api/v1/search"
 
- categories = ['images']
 
- paging = True
 
- def request(query, params):
 
-     start_index = (params["pageno"] - 1) * 50
 
-     data = {"search": query, "offset": start_index}
 
-     params["url"] = base_url
 
-     params["method"] = 'POST'
 
-     params['headers']['content-type'] = "application/json"
 
-     params['data'] = dumps(data)
 
-     return params
 
- def response(resp):
 
-     search_res = resp.json()
 
-     results = []
 
-     for item in search_res:
 
-         img = 'https://s3.thehackerblog.com/findthatmeme/' + item['image_path']
 
-         thumb = 'https://s3.thehackerblog.com/findthatmeme/thumb/' + item.get('thumbnail', '')
 
-         date = datetime.strptime(item["updated_at"].split("T")[0], "%Y-%m-%d")
 
-         formatted_date = datetime.fromtimestamp(date.timestamp())
 
-         results.append(
 
-             {
 
-                 'url': item['source_page_url'],
 
-                 'title': item['source_site'],
 
-                 'img_src': img if item['type'] == 'IMAGE' else thumb,
 
-                 'filesize': humanize_bytes(item['meme_file_size']),
 
-                 'publishedDate': formatted_date,
 
-                 'template': 'images.html',
 
-             }
 
-         )
 
-     return results
 
 
  |