livespace.py 2.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101
  1. # SPDX-License-Identifier: AGPL-3.0-or-later
  2. # lint: pylint
  3. """LiveSpace (Videos)
  4. .. hint::
  5. This engine only search for **live streams**!
  6. """
  7. from urllib.parse import urlencode
  8. from datetime import datetime
  9. from babel import dates
  10. about = {
  11. "website": 'https://live.space',
  12. "wikidata_id": None,
  13. "official_api_documentation": None,
  14. "use_official_api": True,
  15. "require_api_key": False,
  16. "results": 'JSON',
  17. }
  18. categories = ['videos']
  19. base_url = 'https://backend.live.space'
  20. # engine dependent config
  21. paging = True
  22. results_per_page = 10
  23. def request(query, params):
  24. args = {'page': params['pageno'] - 1, 'searchKey': query, 'size': results_per_page}
  25. params['url'] = f"{base_url}/search/public/stream?{urlencode(args)}"
  26. params['headers'] = {'Accept': 'application/json', 'Content-Type': 'application/json'}
  27. return params
  28. def response(resp):
  29. results = []
  30. json = resp.json()
  31. now = datetime.now()
  32. # for live videos
  33. for result in json.get('result', []):
  34. title = result.get("title")
  35. thumbnailUrl = result.get("thumbnailUrl")
  36. category = result.get("category/name")
  37. username = result.get("user", {}).get("userName", "")
  38. url = f'https://live.space/watch/{username}'
  39. # stream tags
  40. # currently the api seems to always return null before the first tag,
  41. # so strip that unless it's not already there
  42. tags = ''
  43. if result.get("tags"):
  44. tags = [x for x in result.get("tags").split(';') if x and x != 'null']
  45. tags = ', '.join(tags)
  46. content = []
  47. if category:
  48. content.append(f'category - {category}')
  49. if tags and len(tags) > 0:
  50. content.append(f'tags - {tags}')
  51. # time & duration
  52. start_time = None
  53. if result.get("startTimeStamp"):
  54. start_time = datetime.fromtimestamp(result.get("startTimeStamp") / 1000)
  55. # for VODs (videos on demand)
  56. end_time = None
  57. if result.get("endTimeStamp"):
  58. end_time = datetime.fromtimestamp(result.get("endTimeStamp") / 1000)
  59. timestring = ""
  60. if start_time:
  61. delta = (now if end_time is None else end_time) - start_time
  62. timestring = dates.format_timedelta(delta, granularity='second')
  63. results.append(
  64. {
  65. 'url': url,
  66. 'title': title,
  67. 'content': "No category or tags." if len(content) == 0 else ' '.join(content),
  68. 'author': username,
  69. 'length': (">= " if end_time is None else "") + timestring,
  70. 'publishedDate': start_time,
  71. 'thumbnail': thumbnailUrl,
  72. 'template': 'videos.html',
  73. }
  74. )
  75. return results