|  | # SPDX-License-Identifier: AGPL-3.0-or-later
 | 
						
						
						
							|  | """Petalsearch Images
 | 
						
						
						
							|  | 
 | 
						
						
						
							|  | """
 | 
						
						
						
							|  | 
 | 
						
						
						
							|  | from json import loads
 | 
						
						
						
							|  | from urllib.parse import urlencode
 | 
						
						
						
							|  | from datetime import datetime
 | 
						
						
						
							|  | 
 | 
						
						
						
							|  | from lxml import html
 | 
						
						
						
							|  | 
 | 
						
						
						
							|  | from searx.utils import extract_text
 | 
						
						
						
							|  | 
 | 
						
						
						
							|  | about = {
 | 
						
						
						
							|  |     "website": 'https://petalsearch.com/',
 | 
						
						
						
							|  |     "wikidata_id": 'Q104399280',
 | 
						
						
						
							|  |     "official_api_documentation": False,
 | 
						
						
						
							|  |     "use_official_api": False,
 | 
						
						
						
							|  |     "require_api_key": False,
 | 
						
						
						
							|  |     "results": 'JSON',
 | 
						
						
						
							|  | }
 | 
						
						
						
							|  | 
 | 
						
						
						
							|  | categories = ['images']
 | 
						
						
						
							|  | paging = True
 | 
						
						
						
							|  | time_range_support = False
 | 
						
						
						
							|  | 
 | 
						
						
						
							|  | safesearch = True
 | 
						
						
						
							|  | safesearch_table = {0: 'off', 1: 'moderate', 2: 'on'}
 | 
						
						
						
							|  | 
 | 
						
						
						
							|  | base_url = 'https://petalsearch.com/'
 | 
						
						
						
							|  | search_string = 'search?{query}&channel=image&ps=50&pn={page}®ion={lang}&ss_mode={safesearch}&ss_type=normal'
 | 
						
						
						
							|  | 
 | 
						
						
						
							|  | 
 | 
						
						
						
							|  | def request(query, params):
 | 
						
						
						
							|  | 
 | 
						
						
						
							|  |     search_path = search_string.format(
 | 
						
						
						
							|  |         query=urlencode({'query': query}),
 | 
						
						
						
							|  |         page=params['pageno'],
 | 
						
						
						
							|  |         lang=params['language'].lower(),
 | 
						
						
						
							|  |         safesearch=safesearch_table[params['safesearch']],
 | 
						
						
						
							|  |     )
 | 
						
						
						
							|  | 
 | 
						
						
						
							|  |     params['url'] = base_url + search_path
 | 
						
						
						
							|  | 
 | 
						
						
						
							|  |     return params
 | 
						
						
						
							|  | 
 | 
						
						
						
							|  | 
 | 
						
						
						
							|  | def response(resp):
 | 
						
						
						
							|  |     results = []
 | 
						
						
						
							|  | 
 | 
						
						
						
							|  |     tree = html.fromstring(resp.text)
 | 
						
						
						
							|  |     root = tree.findall('.//script[3]')
 | 
						
						
						
							|  | 
 | 
						
						
						
							|  |     # Convert list to JSON
 | 
						
						
						
							|  |     json_content = extract_text(root)
 | 
						
						
						
							|  | 
 | 
						
						
						
							|  |     # Manipulate with JSON
 | 
						
						
						
							|  |     data = loads(json_content)
 | 
						
						
						
							|  | 
 | 
						
						
						
							|  |     for result in data['newImages']:
 | 
						
						
						
							|  |         url = result['url']
 | 
						
						
						
							|  |         title = result['title']
 | 
						
						
						
							|  |         thumbnail_src = result['image']
 | 
						
						
						
							|  | 
 | 
						
						
						
							|  |         pic_dict = result.get('extrainfo')
 | 
						
						
						
							|  | 
 | 
						
						
						
							|  |         date_from_api = pic_dict.get('publish_time')
 | 
						
						
						
							|  |         width = pic_dict.get('width')
 | 
						
						
						
							|  |         height = pic_dict.get('height')
 | 
						
						
						
							|  |         img_src = pic_dict.get('real_url')
 | 
						
						
						
							|  | 
 | 
						
						
						
							|  |         # Continue if img_src is missing
 | 
						
						
						
							|  |         if img_src is None or '':
 | 
						
						
						
							|  |             continue
 | 
						
						
						
							|  | 
 | 
						
						
						
							|  |         # Get and convert published date
 | 
						
						
						
							|  |         if date_from_api is not None:
 | 
						
						
						
							|  |             publishedDate = datetime.fromtimestamp(int(date_from_api))
 | 
						
						
						
							|  | 
 | 
						
						
						
							|  |         # Append results
 | 
						
						
						
							|  |         results.append(
 | 
						
						
						
							|  |             {
 | 
						
						
						
							|  |                 'template': 'images.html',
 | 
						
						
						
							|  |                 'url': url,
 | 
						
						
						
							|  |                 'title': title,
 | 
						
						
						
							|  |                 'img_src': img_src,
 | 
						
						
						
							|  |                 'thumbnail_src': thumbnail_src,
 | 
						
						
						
							|  |                 'width': width,
 | 
						
						
						
							|  |                 'height': height,
 | 
						
						
						
							|  |                 'publishedDate': publishedDate,
 | 
						
						
						
							|  |             }
 | 
						
						
						
							|  |         )
 | 
						
						
						
							|  | 
 | 
						
						
						
							|  |     return results
 |