mirror of
				https://github.com/searxng/searxng
				synced 2024-01-01 19:24:07 +01:00 
			
		
		
		
	 cfdcbdd9b5
			
		
	
	
		cfdcbdd9b5
		
	
	
	
	
		
			
			Everything was redone to use the API. It needs an API key, but it's worth it. Everything works. Title, Image, Content, URL The API allow lots of things. Thumbnails and date will be easy to add when it will be implemented in Searx. Fix asciimoo/searx#126
		
			
				
	
	
		
			83 lines
		
	
	
	
		
			2.3 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			83 lines
		
	
	
	
		
			2.3 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
| #!/usr/bin/env python
 | |
| 
 | |
| ## Flickr (Images)
 | |
| # 
 | |
| # @website     https://www.flickr.com
 | |
| # @provide-api yes (https://secure.flickr.com/services/api/flickr.photos.search.html) 
 | |
| # 
 | |
| # @using-api   yes
 | |
| # @results     JSON
 | |
| # @stable      yes
 | |
| # @parse       url, title, thumbnail, img_src
 | |
| #More info on api-key : https://www.flickr.com/services/apps/create/
 | |
| 
 | |
| from urllib import urlencode
 | |
| from json import loads
 | |
| from urlparse import urljoin
 | |
| from lxml import html
 | |
| from time import time
 | |
| 
 | |
| categories = ['images']
 | |
| 
 | |
| nb_per_page = 15
 | |
| paging = True
 | |
| 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}'
 | |
| photo_url = 'https://www.flickr.com/photos/{userid}/{photoid}'
 | |
| 
 | |
| paging = True
 | |
| 
 | |
| def build_flickr_url(user_id, photo_id):
 | |
|     return photo_url.format(userid=user_id,photoid=photo_id)
 | |
| 
 | |
| 
 | |
| def request(query, params):
 | |
|     params['url'] = url.format(text=urlencode({'text': query}),
 | |
|                                api_key=api_key,
 | |
|                                nb_per_page=nb_per_page,
 | |
|                                page=params['pageno'])
 | |
|     return params
 | |
| 
 | |
| 
 | |
| def response(resp):
 | |
|     results = []
 | |
|     
 | |
|     search_results = loads(resp.text)
 | |
| 
 | |
|     # return empty array if there are no results
 | |
|     if not 'photos' in search_results:
 | |
|         return []
 | |
| 
 | |
|     if not 'photo' in search_results['photos']:
 | |
|         return []
 | |
| 
 | |
|     photos = search_results['photos']['photo']
 | |
| 
 | |
|     # parse results
 | |
|     for photo in photos:
 | |
|         if 'url_o' in photo:
 | |
|             img_src = photo['url_o']
 | |
|         elif 'url_z' in photo:
 | |
|             img_src = photo['url_z']
 | |
|         else:
 | |
|             continue
 | |
| 
 | |
|         url = build_flickr_url(photo['owner'], photo['id'])
 | |
| 
 | |
|         title = photo['title']
 | |
|         
 | |
|         content = '<span class="photo-author">'+ photo['ownername'] +'</span><br />'
 | |
|         
 | |
|         content = content + ' <span class="description">' + photo['description']['_content'] + '</span>'
 | |
|         
 | |
|         # append result
 | |
|         results.append({'url': url,
 | |
|                         'title': title,
 | |
|                         'img_src': img_src,
 | |
|                         'content': content,
 | |
|                         'template': 'images.html'})
 | |
| 
 | |
|     # return results
 | |
|     return results
 |