# SPDX-License-Identifier: AGPL-3.0-or-later """Google (Images) For detailed description of the *REST-full* API see: `Query Parameter Definitions`_. .. _admonition:: Content-Security-Policy (CSP) This engine needs to allow images from the `data URLs`_ (prefixed with the ``data:` scheme).:: Header set Content-Security-Policy "img-src 'self' data: ;" .. _Query Parameter Definitions: https://developers.google.com/custom-search/docs/xml_results#WebSearch_Query_Parameter_Definitions .. _data URLs: https://developer.mozilla.org/en-US/docs/Web/HTTP/Basics_of_HTTP/Data_URIs """ from urllib.parse import urlencode, unquote from lxml import html from searx import logger from searx.utils import ( eval_xpath, eval_xpath_list, eval_xpath_getindex, extract_text, ) from searx.engines.google import ( get_lang_info, time_range_dict, detect_google_sorry, ) # pylint: disable=unused-import from searx.engines.google import ( supported_languages_url , _fetch_supported_languages ) # pylint: enable=unused-import logger = logger.getChild('google images') # about about = { "website": 'https://images.google.com', "wikidata_id": 'Q521550', "official_api_documentation": 'https://developers.google.com/custom-search', "use_official_api": False, "require_api_key": False, "results": 'HTML', } # engine dependent config categories = ['images'] paging = False use_locale_domain = True time_range_support = True safesearch = True filter_mapping = { 0: 'images', 1: 'active', 2: 'active' } def scrap_out_thumbs(dom): """Scrap out thumbnail data from