forked from Ponysearch/Ponysearch
55 lines
1.4 KiB
Python
55 lines
1.4 KiB
Python
|
# 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
|