mirror of
				https://github.com/searxng/searxng
				synced 2024-01-01 19:24:07 +01:00 
			
		
		
		
	Flake8 and Twitter corrections
Lots of Flake8 corrections Maybe we should change the rule to allow lines of 120 chars. It seems more usable. Big twitter correction : now it outputs the words in right order...
This commit is contained in:
		
							parent
							
								
									576fdef440
								
							
						
					
					
						commit
						5d977056f7
					
				
					 13 changed files with 80 additions and 47 deletions
				
			
		|  | @ -81,7 +81,7 @@ def load_engine(engine_data): | ||||||
|         if engine_attr.startswith('_'): |         if engine_attr.startswith('_'): | ||||||
|             continue |             continue | ||||||
|         if getattr(engine, engine_attr) is None: |         if getattr(engine, engine_attr) is None: | ||||||
|             print('[E] Engine config error: Missing attribute "{0}.{1}"'\ |             print('[E] Engine config error: Missing attribute "{0}.{1}"' | ||||||
|                   .format(engine.name, engine_attr)) |                   .format(engine.name, engine_attr)) | ||||||
|             sys.exit(1) |             sys.exit(1) | ||||||
| 
 | 
 | ||||||
|  | @ -102,7 +102,7 @@ def load_engine(engine_data): | ||||||
|     if engine.shortcut: |     if engine.shortcut: | ||||||
|         # TODO check duplications |         # TODO check duplications | ||||||
|         if engine.shortcut in engine_shortcuts: |         if engine.shortcut in engine_shortcuts: | ||||||
|             print('[E] Engine config error: ambigious shortcut: {0}'\ |             print('[E] Engine config error: ambigious shortcut: {0}' | ||||||
|                   .format(engine.shortcut)) |                   .format(engine.shortcut)) | ||||||
|             sys.exit(1) |             sys.exit(1) | ||||||
|         engine_shortcuts[engine.shortcut] = engine.name |         engine_shortcuts[engine.shortcut] = engine.name | ||||||
|  |  | ||||||
|  | @ -52,7 +52,8 @@ def response(resp): | ||||||
|         thumbnail = result.xpath('.//img')[0].attrib.get('src') |         thumbnail = result.xpath('.//img')[0].attrib.get('src') | ||||||
|         title = ''.join(result.xpath(title_xpath)) |         title = ''.join(result.xpath(title_xpath)) | ||||||
|         content = escape(''.join(result.xpath(content_xpath))) |         content = escape(''.join(result.xpath(content_xpath))) | ||||||
|         publishedDate = parser.parse(result.xpath(pubdate_xpath)[0].attrib.get('datetime')) |         pubdate = result.xpath(pubdate_xpath)[0].attrib.get('datetime') | ||||||
|  |         publishedDate = parser.parse(pubdate) | ||||||
| 
 | 
 | ||||||
|         # append result |         # append result | ||||||
|         results.append({'url': url, |         results.append({'url': url, | ||||||
|  |  | ||||||
|  | @ -53,7 +53,8 @@ def response(resp): | ||||||
| 
 | 
 | ||||||
|     for photo in photos: |     for photo in photos: | ||||||
| 
 | 
 | ||||||
|         # In paged configuration, the first pages' photos are represented by a None object |         # In paged configuration, the first pages' photos | ||||||
|  |         # are represented by a None object | ||||||
|         if photo is None: |         if photo is None: | ||||||
|             continue |             continue | ||||||
| 
 | 
 | ||||||
|  | @ -74,10 +75,15 @@ def response(resp): | ||||||
| 
 | 
 | ||||||
|         title = photo['title'] |         title = photo['title'] | ||||||
| 
 | 
 | ||||||
|         content = '<span class="photo-author">' + photo['owner']['username'] + '</span><br />' |         content = '<span class="photo-author">' +\ | ||||||
|  |                   photo['owner']['username'] +\ | ||||||
|  |                   '</span><br />' | ||||||
| 
 | 
 | ||||||
|         if 'description' in photo: |         if 'description' in photo: | ||||||
|             content = content + '<span class="description">' + photo['description'] + '</span>' |             content = content +\ | ||||||
|  |                       '<span class="description">' +\ | ||||||
|  |                       photo['description'] +\ | ||||||
|  |                       '</span>' | ||||||
| 
 | 
 | ||||||
|         # append result |         # append result | ||||||
|         results.append({'url': url, |         results.append({'url': url, | ||||||
|  |  | ||||||
|  | @ -21,11 +21,15 @@ paging = True | ||||||
| api_key = None | api_key = None | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| url = 'https://api.flickr.com/services/rest/?method=flickr.photos.search&api_key={api_key}&{text}&sort=relevance&extras=description%2C+owner_name%2C+url_o%2C+url_z&per_page={nb_per_page}&format=json&nojsoncallback=1&page={page}' | url = 'https://api.flickr.com/services/rest/?method=flickr.photos.search' +\ | ||||||
|  |       '&api_key={api_key}&{text}&sort=relevance' +\ | ||||||
|  |       '&extras=description%2C+owner_name%2C+url_o%2C+url_z' +\ | ||||||
|  |       '&per_page={nb_per_page}&format=json&nojsoncallback=1&page={page}' | ||||||
| photo_url = 'https://www.flickr.com/photos/{userid}/{photoid}' | photo_url = 'https://www.flickr.com/photos/{userid}/{photoid}' | ||||||
| 
 | 
 | ||||||
| paging = True | paging = True | ||||||
| 
 | 
 | ||||||
|  | 
 | ||||||
| def build_flickr_url(user_id, photo_id): | def build_flickr_url(user_id, photo_id): | ||||||
|     return photo_url.format(userid=user_id, photoid=photo_id) |     return photo_url.format(userid=user_id, photoid=photo_id) | ||||||
| 
 | 
 | ||||||
|  | @ -65,9 +69,12 @@ def response(resp): | ||||||
| 
 | 
 | ||||||
|         title = photo['title'] |         title = photo['title'] | ||||||
| 
 | 
 | ||||||
|         content = '<span class="photo-author">'+ photo['ownername'] +'</span><br />' |         content = '<span class="photo-author">' +\ | ||||||
|          |                   photo['ownername'] +\ | ||||||
|         content = content + '<span class="description">' + photo['description']['_content'] + '</span>' |                   '</span><br />' +\ | ||||||
|  |                   '<span class="description">' +\ | ||||||
|  |                   photo['description']['_content'] +\ | ||||||
|  |                   '</span>' | ||||||
| 
 | 
 | ||||||
|         # append result |         # append result | ||||||
|         results.append({'url': url, |         results.append({'url': url, | ||||||
|  |  | ||||||
|  | @ -24,7 +24,7 @@ search_url = url + 'search/{search_term}/{pageno}/' | ||||||
| 
 | 
 | ||||||
| # specific xpath variables | # specific xpath variables | ||||||
| magnet_xpath = './/a[@title="Torrent magnet link"]' | magnet_xpath = './/a[@title="Torrent magnet link"]' | ||||||
| #content_xpath = './/font[@class="detDesc"]//text()' | content_xpath = './/span[@class="font11px lightgrey block"]' | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| # do search-request | # do search-request | ||||||
|  | @ -56,7 +56,8 @@ def response(resp): | ||||||
|         link = result.xpath('.//a[@class="cellMainLink"]')[0] |         link = result.xpath('.//a[@class="cellMainLink"]')[0] | ||||||
|         href = urljoin(url, link.attrib['href']) |         href = urljoin(url, link.attrib['href']) | ||||||
|         title = ' '.join(link.xpath('.//text()')) |         title = ' '.join(link.xpath('.//text()')) | ||||||
|         content = escape(html.tostring(result.xpath('.//span[@class="font11px lightgrey block"]')[0], method="text")) |         content = escape(html.tostring(result.xpath(content_xpath)[0], | ||||||
|  |                                        method="text")) | ||||||
|         seed = result.xpath('.//td[contains(@class, "green")]/text()')[0] |         seed = result.xpath('.//td[contains(@class, "green")]/text()')[0] | ||||||
|         leech = result.xpath('.//td[contains(@class, "red")]/text()')[0] |         leech = result.xpath('.//td[contains(@class, "red")]/text()')[0] | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -11,7 +11,6 @@ | ||||||
| from urllib import urlencode | from urllib import urlencode | ||||||
| from json import loads | from json import loads | ||||||
| import cgi | import cgi | ||||||
| import re |  | ||||||
| 
 | 
 | ||||||
| # engine dependent config | # engine dependent config | ||||||
| categories = ['it'] | categories = ['it'] | ||||||
|  | @ -50,7 +49,8 @@ def response(resp): | ||||||
|         for line, code in sorted(lines.items()): |         for line, code in sorted(lines.items()): | ||||||
|             content = content + '<tr><td class="line-number" style="padding-right:5px;">' |             content = content + '<tr><td class="line-number" style="padding-right:5px;">' | ||||||
|             content = content + str(line) + '</td><td class="code-snippet">' |             content = content + str(line) + '</td><td class="code-snippet">' | ||||||
|             # Replace every two spaces with ' &nbps;' to keep formatting while allowing the browser to break the line if necessary |             # Replace every two spaces with ' &nbps;' to keep formatting | ||||||
|  |             # while allowing the browser to break the line if necessary | ||||||
|             content = content + cgi.escape(code).replace('\t', '    ').replace('  ', '  ').replace('  ', '  ') |             content = content + cgi.escape(code).replace('\t', '    ').replace('  ', '  ').replace('  ', '  ') | ||||||
|             content = content + "</td></tr>" |             content = content + "</td></tr>" | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -37,8 +37,15 @@ def response(resp): | ||||||
|     # parse results |     # parse results | ||||||
|     for result in search_results['results']: |     for result in search_results['results']: | ||||||
|         href = result['url'] |         href = result['url'] | ||||||
|         title = "[" + result['type'] + "] " + result['namespace'] + " " + result['name'] |         title = "[" + result['type'] + "] " +\ | ||||||
|         content = '<span class="highlight">[' + result['type'] + "] " + result['name'] + " " + result['synopsis'] + "</span><br />" + result['description'] |                 result['namespace'] +\ | ||||||
|  |                 " " + result['name'] | ||||||
|  |         content = '<span class="highlight">[' +\ | ||||||
|  |                   result['type'] + "] " +\ | ||||||
|  |                   result['name'] + " " +\ | ||||||
|  |                   result['synopsis'] +\ | ||||||
|  |                   "</span><br />" +\ | ||||||
|  |                   result['description'] | ||||||
| 
 | 
 | ||||||
|         # append result |         # append result | ||||||
|         results.append({'url': href, |         results.append({'url': href, | ||||||
|  |  | ||||||
|  | @ -60,10 +60,14 @@ def response(resp): | ||||||
| 
 | 
 | ||||||
|         content = result.xpath('.//div[contains(@class,"red")]//text()')[0] |         content = result.xpath('.//div[contains(@class,"red")]//text()')[0] | ||||||
|         content = content + " - " |         content = content + " - " | ||||||
|         content = content + html.tostring(result.xpath('.//div[contains(@class,"grey-web")]')[0], method='text') |         text = result.xpath('.//div[contains(@class,"grey-web")]')[0] | ||||||
|  |         content = content + html.tostring(text, method='text') | ||||||
| 
 | 
 | ||||||
|         if result.xpath(".//span") != []: |         if result.xpath(".//span") != []: | ||||||
|             content = content + " - (" + result.xpath(".//span//text()")[0].strip() + ")" |             content = content +\ | ||||||
|  |                       " - (" +\ | ||||||
|  |                       result.xpath(".//span//text()")[0].strip() +\ | ||||||
|  |                       ")" | ||||||
| 
 | 
 | ||||||
|         # append result |         # append result | ||||||
|         results.append({'url': href, |         results.append({'url': href, | ||||||
|  |  | ||||||
|  | @ -28,7 +28,7 @@ search_url = base_url+'search?' | ||||||
| results_xpath = '//li[@data-item-type="tweet"]' | results_xpath = '//li[@data-item-type="tweet"]' | ||||||
| link_xpath = './/small[@class="time"]//a' | link_xpath = './/small[@class="time"]//a' | ||||||
| title_xpath = './/span[@class="username js-action-profile-name"]//text()' | title_xpath = './/span[@class="username js-action-profile-name"]//text()' | ||||||
| content_xpath = './/p[@class="js-tweet-text tweet-text"]//text()' | content_xpath = './/p[@class="js-tweet-text tweet-text"]' | ||||||
| timestamp_xpath = './/span[contains(@class,"_timestamp")]' | timestamp_xpath = './/span[contains(@class,"_timestamp")]' | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
|  | @ -54,10 +54,11 @@ def response(resp): | ||||||
|         link = tweet.xpath(link_xpath)[0] |         link = tweet.xpath(link_xpath)[0] | ||||||
|         url = urljoin(base_url, link.attrib.get('href')) |         url = urljoin(base_url, link.attrib.get('href')) | ||||||
|         title = ''.join(tweet.xpath(title_xpath)) |         title = ''.join(tweet.xpath(title_xpath)) | ||||||
|         content = escape(''.join(tweet.xpath(content_xpath))) |         content = escape(html.tostring(tweet.xpath(content_xpath)[0], method='text', encoding='UTF-8').decode("utf-8")) | ||||||
|         pubdate = tweet.xpath(timestamp_xpath) |         pubdate = tweet.xpath(timestamp_xpath) | ||||||
|         if len(pubdate) > 0: |         if len(pubdate) > 0: | ||||||
|             publishedDate = datetime.fromtimestamp(float(pubdate[0].attrib.get('data-time')), None) |             timestamp = float(pubdate[0].attrib.get('data-time')) | ||||||
|  |             publishedDate = datetime.fromtimestamp(timestamp, None) | ||||||
|             # append result |             # append result | ||||||
|             results.append({'url': url, |             results.append({'url': url, | ||||||
|                             'title': title, |                             'title': title, | ||||||
|  |  | ||||||
|  | @ -154,7 +154,6 @@ def load_https_rules(rules_path): | ||||||
|     print(' * {n} https-rules loaded'.format(n=len(https_rules))) |     print(' * {n} https-rules loaded'.format(n=len(https_rules))) | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| 
 |  | ||||||
| def https_url_rewrite(result): | def https_url_rewrite(result): | ||||||
|     skip_https_rewrite = False |     skip_https_rewrite = False | ||||||
|     # check if HTTPS rewrite is possible |     # check if HTTPS rewrite is possible | ||||||
|  |  | ||||||
|  | @ -69,11 +69,16 @@ def threaded_requests(requests): | ||||||
|                 print('engine timeout: {0}'.format(th._engine_name)) |                 print('engine timeout: {0}'.format(th._engine_name)) | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| 
 |  | ||||||
| # get default reqest parameter | # get default reqest parameter | ||||||
| def default_request_params(): | def default_request_params(): | ||||||
|     return { |     return { | ||||||
|         'method': 'GET', 'headers': {}, 'data': {}, 'url': '', 'cookies': {}, 'verify': True} |         'method': 'GET', | ||||||
|  |         'headers': {}, | ||||||
|  |         'data': {}, | ||||||
|  |         'url': '', | ||||||
|  |         'cookies': {}, | ||||||
|  |         'verify': True | ||||||
|  |     } | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| # create a callback wrapper for the search engine results | # create a callback wrapper for the search engine results | ||||||
|  | @ -487,14 +492,15 @@ class Search(object): | ||||||
|                 continue |                 continue | ||||||
| 
 | 
 | ||||||
|             # append request to list |             # append request to list | ||||||
|             requests.append((req, request_params['url'], request_args, selected_engine['name'])) |             requests.append((req, request_params['url'], | ||||||
|  |                              request_args, | ||||||
|  |                              selected_engine['name'])) | ||||||
| 
 | 
 | ||||||
|         if not requests: |         if not requests: | ||||||
|             return results, suggestions, answers, infoboxes |             return results, suggestions, answers, infoboxes | ||||||
|         # send all search-request |         # send all search-request | ||||||
|         threaded_requests(requests) |         threaded_requests(requests) | ||||||
| 
 | 
 | ||||||
| 
 |  | ||||||
|         while not results_queue.empty(): |         while not results_queue.empty(): | ||||||
|             engine_name, engine_results = results_queue.get_nowait() |             engine_name, engine_results = results_queue.get_nowait() | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -30,7 +30,8 @@ def gen_useragent(): | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| def searx_useragent(): | def searx_useragent(): | ||||||
|     return 'searx/{searx_version} {suffix}'.format(searx_version=VERSION_STRING, |     return 'searx/{searx_version} {suffix}'.format( | ||||||
|  |            searx_version=VERSION_STRING, | ||||||
|            suffix=settings['server'].get('useragent_suffix', '')) |            suffix=settings['server'].get('useragent_suffix', '')) | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		
		Reference in a new issue
	
	 Cqoicebordel
						Cqoicebordel