summaryrefslogtreecommitdiff
path: root/searx/engines/ccc_media.py
blob: 34fe811df7faa5989e07b8a166001d2dfc22cd6c (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
# 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
        for rec in item['recordings']:
            if rec['mime_type'].startswith('video'):
                if not iframe_src:
                    iframe_src = rec['recording_url']
                elif rec['mime_type'] == 'video/mp4':
                    # prefer mp4 (minimal data rates)
                    iframe_src = rec['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