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 urllib import urlencode
  13. from urlparse import urljoin
  14. # engine dependent config
  15. categories = ['images']
  16. paging = True
  17. # search-url
  18. base_url = 'https://500px.com'
  19. search_url = 'https://api.500px.com/v1/photos/search?type=photos'\
  20. '&{query}'\
  21. '&image_size%5B%5D=4'\
  22. '&image_size%5B%5D=20'\
  23. '&image_size%5B%5D=21'\
  24. '&image_size%5B%5D=1080'\
  25. '&image_size%5B%5D=1600'\
  26. '&image_size%5B%5D=2048'\
  27. '&include_states=true'\
  28. '&formats=jpeg%2Clytro'\
  29. '&include_tags=true'\
  30. '&exclude_nude=true'\
  31. '&page={pageno}'\
  32. '&rpp=50'\
  33. '&sdk_key=b68e60cff4c929bedea36ca978830c5caca790c3'
  34. # do search-request
  35. def request(query, params):
  36. params['url'] = search_url.format(pageno=params['pageno'],
  37. query=urlencode({'term': query}))
  38. return params
  39. # get response from search-request
  40. def response(resp):
  41. results = []
  42. response_json = loads(resp.text)
  43. # parse results
  44. for result in response_json['photos']:
  45. url = urljoin(base_url, result['url'])
  46. title = result['name']
  47. # last index is the biggest resolution
  48. img_src = result['image_url'][-1]
  49. thumbnail_src = result['image_url'][0]
  50. content = result['description'] or ''
  51. # append result
  52. results.append({'url': url,
  53. 'title': title,
  54. 'img_src': img_src,
  55. 'content': content,
  56. 'thumbnail_src': thumbnail_src,
  57. 'template': 'images.html'})
  58. # return results
  59. return results