dailymotion.py 2.7 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394
  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. locale = params['language']
  27. params['url'] = search_url.format(
  28. query=urlencode({'search': query, 'localization': locale}),
  29. pageno=params['pageno'])
  30. return params
  31. # get response from search-request
  32. def response(resp):
  33. results = []
  34. search_res = loads(resp.text)
  35. # return empty array if there are no results
  36. if 'list' not in search_res:
  37. return []
  38. # parse results
  39. for res in search_res['list']:
  40. title = res['title']
  41. url = res['url']
  42. content = res['description']
  43. thumbnail = res['thumbnail_360_url']
  44. publishedDate = datetime.fromtimestamp(res['created_time'], None)
  45. embedded = embedded_url.format(videoid=res['id'])
  46. # http to https
  47. thumbnail = thumbnail.replace("http://", "https://")
  48. results.append({'template': 'videos.html',
  49. 'url': url,
  50. 'title': title,
  51. 'content': content,
  52. 'publishedDate': publishedDate,
  53. 'embedded': embedded,
  54. 'thumbnail': thumbnail})
  55. # return results
  56. return results
  57. # get supported languages from their site
  58. def _fetch_supported_languages(resp):
  59. supported_languages = {}
  60. response_json = loads(resp.text)
  61. for language in response_json['list']:
  62. supported_languages[language['code']] = {}
  63. name = language['native_name']
  64. if name:
  65. supported_languages[language['code']]['name'] = name
  66. english_name = language['name']
  67. if english_name:
  68. supported_languages[language['code']]['english_name'] = english_name
  69. return supported_languages