|
@@ -0,0 +1,54 @@
|
|
|
+# SPDX-License-Identifier: AGPL-3.0-or-later
|
|
|
+"""media.ccc.de"""
|
|
|
+
|
|
|
+import datetime
|
|
|
+from urllib.parse import urlencode
|
|
|
+
|
|
|
+from dateutil import parser
|
|
|
+
|
|
|
+about = {
|
|
|
+ 'website': 'https://media.ccc.de',
|
|
|
+ 'official_api_documentation': 'https://github.com/voc/voctoweb',
|
|
|
+ 'use_official_api': True,
|
|
|
+ 'require_api_key': False,
|
|
|
+ 'results': 'JSON',
|
|
|
+}
|
|
|
+categories = ['videos']
|
|
|
+paging = True
|
|
|
+
|
|
|
+api_url = "https://api.media.ccc.de"
|
|
|
+
|
|
|
+
|
|
|
+def request(query, params):
|
|
|
+ args = {'q': query, 'page': params['pageno']}
|
|
|
+ params['url'] = f"{api_url}/public/events/search?{urlencode(args)}"
|
|
|
+
|
|
|
+ return params
|
|
|
+
|
|
|
+
|
|
|
+def response(resp):
|
|
|
+ results = []
|
|
|
+
|
|
|
+ for item in resp.json()['events']:
|
|
|
+ publishedDate = None
|
|
|
+ if item.get('date'):
|
|
|
+ publishedDate = parser.parse(item['date'])
|
|
|
+
|
|
|
+ iframe_src = None
|
|
|
+ if len(item['recordings']) > 0:
|
|
|
+ iframe_src = item['recordings'][0]['recording_url']
|
|
|
+
|
|
|
+ results.append(
|
|
|
+ {
|
|
|
+ 'template': 'videos.html',
|
|
|
+ 'url': item['frontend_link'],
|
|
|
+ 'title': item['title'],
|
|
|
+ 'content': item['description'],
|
|
|
+ 'thumbnail': item['thumb_url'],
|
|
|
+ 'publishedDate': publishedDate,
|
|
|
+ 'length': datetime.timedelta(seconds=item['length']),
|
|
|
+ 'iframe_src': iframe_src,
|
|
|
+ }
|
|
|
+ )
|
|
|
+
|
|
|
+ return results
|