|  | @@ -11,9 +11,11 @@
 | 
	
		
			
			| 11 | 11 |   More info on api: https://www.ncbi.nlm.nih.gov/books/NBK25501/
 | 
	
		
			
			| 12 | 12 |  """
 | 
	
		
			
			| 13 | 13 |  
 | 
	
		
			
			|  | 14 | +from flask_babel import gettext
 | 
	
		
			
			| 14 | 15 |  from lxml import etree
 | 
	
		
			
			| 15 | 16 |  from datetime import datetime
 | 
	
		
			
			| 16 |  | -from searx.url_utils import urlencode, urlopen
 | 
	
		
			
			|  | 17 | +from searx.url_utils import urlencode
 | 
	
		
			
			|  | 18 | +from searx.poolrequests import get
 | 
	
		
			
			| 17 | 19 |  
 | 
	
		
			
			| 18 | 20 |  
 | 
	
		
			
			| 19 | 21 |  categories = ['science']
 | 
	
	
		
			
			|  | @@ -46,12 +48,7 @@ def response(resp):
 | 
	
		
			
			| 46 | 48 |      pubmed_retrieve_api_url = 'https://eutils.ncbi.nlm.nih.gov/entrez/eutils/efetch.fcgi?'\
 | 
	
		
			
			| 47 | 49 |                                + 'db=pubmed&retmode=xml&id={pmids_string}'
 | 
	
		
			
			| 48 | 50 |  
 | 
	
		
			
			| 49 |  | -    # handle Python2 vs Python3 management of bytes and strings
 | 
	
		
			
			| 50 |  | -    try:
 | 
	
		
			
			| 51 |  | -        pmids_results = etree.XML(resp.text.encode('utf-8'))
 | 
	
		
			
			| 52 |  | -    except AttributeError:
 | 
	
		
			
			| 53 |  | -        pmids_results = etree.XML(resp.text)
 | 
	
		
			
			| 54 |  | -
 | 
	
		
			
			|  | 51 | +    pmids_results = etree.XML(resp.content)
 | 
	
		
			
			| 55 | 52 |      pmids = pmids_results.xpath('//eSearchResult/IdList/Id')
 | 
	
		
			
			| 56 | 53 |      pmids_string = ''
 | 
	
		
			
			| 57 | 54 |  
 | 
	
	
		
			
			|  | @@ -62,7 +59,7 @@ def response(resp):
 | 
	
		
			
			| 62 | 59 |  
 | 
	
		
			
			| 63 | 60 |      retrieve_url_encoded = pubmed_retrieve_api_url.format(**retrieve_notice_args)
 | 
	
		
			
			| 64 | 61 |  
 | 
	
		
			
			| 65 |  | -    search_results_xml = urlopen(retrieve_url_encoded).read()
 | 
	
		
			
			|  | 62 | +    search_results_xml = get(retrieve_url_encoded).content
 | 
	
		
			
			| 66 | 63 |      search_results = etree.XML(search_results_xml).xpath('//PubmedArticleSet/PubmedArticle/MedlineCitation')
 | 
	
		
			
			| 67 | 64 |  
 | 
	
		
			
			| 68 | 65 |      for entry in search_results:
 | 
	
	
		
			
			|  | @@ -74,12 +71,12 @@ def response(resp):
 | 
	
		
			
			| 74 | 71 |          try:
 | 
	
		
			
			| 75 | 72 |              content = entry.xpath('.//Abstract/AbstractText')[0].text
 | 
	
		
			
			| 76 | 73 |          except:
 | 
	
		
			
			| 77 |  | -            content = 'No abstract is available for this publication.'
 | 
	
		
			
			|  | 74 | +            content = gettext('No abstract is available for this publication.')
 | 
	
		
			
			| 78 | 75 |  
 | 
	
		
			
			| 79 | 76 |          #  If a doi is available, add it to the snipppet
 | 
	
		
			
			| 80 | 77 |          try:
 | 
	
		
			
			| 81 | 78 |              doi = entry.xpath('.//ELocationID[@EIdType="doi"]')[0].text
 | 
	
		
			
			| 82 |  | -            content = 'DOI: ' + doi + ' Abstract: ' + content
 | 
	
		
			
			|  | 79 | +            content = 'DOI: {doi} Abstract: {content}'.format(doi=doi, content=content)
 | 
	
		
			
			| 83 | 80 |          except:
 | 
	
		
			
			| 84 | 81 |              pass
 | 
	
		
			
			| 85 | 82 |  
 |