aboutsummaryrefslogtreecommitdiff
path: root/youtube_dl/extractor/fm4.py
blob: 4eb63ffa9e00922f818d20a178f8624a25e0231b (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
# coding: utf-8
from __future__ import unicode_literals

import calendar
import datetime
import re

from .common import InfoExtractor

# audios on fm4.orf.at are only available for 7 days, so we can't
# add tests.


class FM4IE(InfoExtractor):
    IE_DESC = 'fm4.orf.at'
    _VALID_URL = r'http://fm4\.orf\.at/7tage#(?P<date>[0-9]+)/(?P<show>[\w]+)'

    def _extract_entry_dict(self, info, title, subtitle):
        result = {
            'id': info['loopStreamId'].replace('.mp3', ''),
            'url': 'http://loopstream01.apa.at/?channel=fm4&id=%s' % info['loopStreamId'],
            'title': title,
            'description': subtitle,
            'duration': (info['end'] - info['start']) / 1000,
            'timestamp': info['start'] / 1000,
            'ext': 'mp3'
        }

        return result

    def _real_extract(self, url):
        mobj = re.match(self._VALID_URL, url)
        show_date = mobj.group('date')
        show_id = mobj.group('show')

        data = self._download_json(
            'http://audioapi.orf.at/fm4/json/2.0/broadcasts/%s/4%s' % (show_date, show_id),
            show_id
        )

        entries = [ self._extract_entry_dict(t, data['title'], data['subtitle']) for t in data['streams']]

        return {
            '_type': 'playlist',
            'id': show_id,
            'title': data['title'],
            'description': data['subtitle'],
            'entries': entries
        }