vimeo.py 1.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566
  1. # SPDX-License-Identifier: AGPL-3.0-or-later
  2. """
  3. Wikipedia (Web
  4. """
  5. from urllib.parse import urlencode
  6. from json import loads
  7. from dateutil import parser
  8. # about
  9. about = {
  10. "website": 'https://vimeo.com/',
  11. "wikidata_id": 'Q156376',
  12. "official_api_documentation": 'http://developer.vimeo.com/api',
  13. "use_official_api": False,
  14. "require_api_key": False,
  15. "results": 'HTML',
  16. }
  17. # engine dependent config
  18. categories = ['videos']
  19. paging = True
  20. # search-url
  21. base_url = 'https://vimeo.com/'
  22. search_url = base_url + '/search/page:{pageno}?{query}'
  23. # do search-request
  24. def request(query, params):
  25. params['url'] = search_url.format(pageno=params['pageno'], query=urlencode({'q': query}))
  26. return params
  27. # get response from search-request
  28. def response(resp):
  29. results = []
  30. data_start_pos = resp.text.find('{"filtered"')
  31. data_end_pos = resp.text.find(';\n', data_start_pos + 1)
  32. data = loads(resp.text[data_start_pos:data_end_pos])
  33. # parse results
  34. for result in data['filtered']['data']:
  35. result = result[result['type']]
  36. videoid = result['uri'].split('/')[-1]
  37. url = base_url + videoid
  38. title = result['name']
  39. thumbnail = result['pictures']['sizes'][-1]['link']
  40. publishedDate = parser.parse(result['created_time'])
  41. # append result
  42. results.append(
  43. {
  44. 'url': url,
  45. 'title': title,
  46. 'content': '',
  47. 'template': 'videos.html',
  48. 'publishedDate': publishedDate,
  49. 'iframe_src': "https://player.vimeo.com/video/" + videoid,
  50. 'thumbnail': thumbnail,
  51. }
  52. )
  53. # return results
  54. return results