dailymotion.py 2.7KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697
  1. """
  2. Dailymotion (Videos)
  3. @website https://www.dailymotion.com
  4. @provide-api yes (http://www.dailymotion.com/developer)
  5. @using-api yes
  6. @results JSON
  7. @stable yes
  8. @parse url, title, thumbnail, publishedDate, embedded
  9. @todo set content-parameter with correct data
  10. """
  11. from json import loads
  12. from datetime import datetime
  13. from searx.url_utils import urlencode
  14. # engine dependent config
  15. categories = ['videos']
  16. paging = True
  17. language_support = True
  18. # search-url
  19. # see http://www.dailymotion.com/doc/api/obj-video.html
  20. search_url = 'https://api.dailymotion.com/videos?fields=created_time,title,description,duration,url,thumbnail_360_url,id&sort=relevance&limit=5&page={pageno}&{query}' # noqa
  21. embedded_url = '<iframe frameborder="0" width="540" height="304" ' +\
  22. 'data-src="//www.dailymotion.com/embed/video/{videoid}" allowfullscreen></iframe>'
  23. supported_languages_url = 'https://api.dailymotion.com/languages'
  24. # do search-request
  25. def request(query, params):
  26. if params['language'] == 'all':
  27. locale = 'en-US'
  28. else:
  29. locale = params['language']
  30. params['url'] = search_url.format(
  31. query=urlencode({'search': query, 'localization': locale}),
  32. pageno=params['pageno'])
  33. return params
  34. # get response from search-request
  35. def response(resp):
  36. results = []
  37. search_res = loads(resp.text)
  38. # return empty array if there are no results
  39. if 'list' not in search_res:
  40. return []
  41. # parse results
  42. for res in search_res['list']:
  43. title = res['title']
  44. url = res['url']
  45. content = res['description']
  46. thumbnail = res['thumbnail_360_url']
  47. publishedDate = datetime.fromtimestamp(res['created_time'], None)
  48. embedded = embedded_url.format(videoid=res['id'])
  49. # http to https
  50. thumbnail = thumbnail.replace("http://", "https://")
  51. results.append({'template': 'videos.html',
  52. 'url': url,
  53. 'title': title,
  54. 'content': content,
  55. 'publishedDate': publishedDate,
  56. 'embedded': embedded,
  57. 'thumbnail': thumbnail})
  58. # return results
  59. return results
  60. # get supported languages from their site
  61. def _fetch_supported_languages(resp):
  62. supported_languages = {}
  63. response_json = loads(resp.text)
  64. for language in response_json['list']:
  65. supported_languages[language['code']] = {}
  66. name = language['native_name']
  67. if name:
  68. supported_languages[language['code']]['name'] = name
  69. english_name = language['name']
  70. if english_name:
  71. supported_languages[language['code']]['english_name'] = english_name
  72. return supported_languages