www500px.py 1.8 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374
  1. """
  2. 500px (Images)
  3. @website https://500px.com
  4. @provide-api yes (https://developers.500px.com/)
  5. @using-api no
  6. @results HTML
  7. @stable no (HTML can change)
  8. @parse url, title, thumbnail, img_src, content
  9. @todo rewrite to api
  10. """
  11. from json import loads
  12. from searx.url_utils import urlencode, urljoin
  13. # engine dependent config
  14. categories = ['images']
  15. paging = True
  16. # search-url
  17. base_url = 'https://500px.com'
  18. search_url = 'https://api.500px.com/v1/photos/search?type=photos'\
  19. '&{query}'\
  20. '&image_size%5B%5D=4'\
  21. '&image_size%5B%5D=20'\
  22. '&image_size%5B%5D=21'\
  23. '&image_size%5B%5D=1080'\
  24. '&image_size%5B%5D=1600'\
  25. '&image_size%5B%5D=2048'\
  26. '&include_states=true'\
  27. '&formats=jpeg%2Clytro'\
  28. '&include_tags=true'\
  29. '&exclude_nude=true'\
  30. '&page={pageno}'\
  31. '&rpp=50'\
  32. '&sdk_key=b68e60cff4c929bedea36ca978830c5caca790c3'
  33. # do search-request
  34. def request(query, params):
  35. params['url'] = search_url.format(pageno=params['pageno'],
  36. query=urlencode({'term': query}))
  37. return params
  38. # get response from search-request
  39. def response(resp):
  40. results = []
  41. response_json = loads(resp.text)
  42. # parse results
  43. for result in response_json['photos']:
  44. url = urljoin(base_url, result['url'])
  45. title = result['name']
  46. # last index is the biggest resolution
  47. img_src = result['image_url'][-1]
  48. thumbnail_src = result['image_url'][0]
  49. content = result['description'] or ''
  50. # append result
  51. results.append({'url': url,
  52. 'title': title,
  53. 'img_src': img_src,
  54. 'content': content,
  55. 'thumbnail_src': thumbnail_src,
  56. 'template': 'images.html'})
  57. # return results
  58. return results