mirror of
https://github.com/yt-dlp/yt-dlp
synced 2025-01-16 03:40:50 +01:00
[ie/radiko] rough patch to make timefree 30 possible
naive approach that assumes things dont do anything unusual
This commit is contained in:
parent
a6783a3b99
commit
6b883e15c8
1 changed files with 13 additions and 4 deletions
|
@ -1,4 +1,5 @@
|
||||||
import base64
|
import base64
|
||||||
|
import datetime
|
||||||
import random
|
import random
|
||||||
import re
|
import re
|
||||||
import urllib.parse
|
import urllib.parse
|
||||||
|
@ -99,17 +100,25 @@ class RadikoBaseIE(InfoExtractor):
|
||||||
self._FULL_KEY = full_key
|
self._FULL_KEY = full_key
|
||||||
return full_key
|
return full_key
|
||||||
|
|
||||||
|
def _get_broadcast_day(self, timestring):
|
||||||
|
dt = datetime.datetime.strptime(timestring, '%Y%m%d%H%M%S')
|
||||||
|
if dt.hour < 5:
|
||||||
|
dt -= datetime.timedelta(days=1)
|
||||||
|
return dt.strftime('%Y%m%d')
|
||||||
|
|
||||||
def _find_program(self, video_id, station, cursor):
|
def _find_program(self, video_id, station, cursor):
|
||||||
|
broadcast_day = self._get_broadcast_day(cursor)
|
||||||
|
|
||||||
station_program = self._download_xml(
|
station_program = self._download_xml(
|
||||||
f'https://radiko.jp/v3/program/station/weekly/{station}.xml', video_id,
|
f'https://api.radiko.jp/program/v3/date/{broadcast_day}/station/{station}.xml', station,
|
||||||
note=f'Downloading radio program for {station} station')
|
note=f'Downloading programme data for {broadcast_day}')
|
||||||
|
|
||||||
prog = None
|
prog = None
|
||||||
for p in station_program.findall('.//prog'):
|
for p in station_program.findall('.//prog'):
|
||||||
ft_str, to_str = p.attrib['ft'], p.attrib['to']
|
ft_str, to_str = p.attrib['ft'], p.attrib['to']
|
||||||
ft = unified_timestamp(ft_str, False)
|
ft = unified_timestamp(ft_str, False)
|
||||||
to = unified_timestamp(to_str, False)
|
to = unified_timestamp(to_str, False)
|
||||||
if ft <= cursor and cursor < to:
|
if ft_str <= cursor and cursor < to_str:
|
||||||
prog = p
|
prog = p
|
||||||
break
|
break
|
||||||
if not prog:
|
if not prog:
|
||||||
|
@ -187,7 +196,7 @@ class RadikoIE(RadikoBaseIE):
|
||||||
station, timestring = self._match_valid_url(url).group('station', 'timestring')
|
station, timestring = self._match_valid_url(url).group('station', 'timestring')
|
||||||
video_id = join_nonempty(station, timestring)
|
video_id = join_nonempty(station, timestring)
|
||||||
vid_int = unified_timestamp(timestring, False)
|
vid_int = unified_timestamp(timestring, False)
|
||||||
prog, station_program, ft, radio_begin, radio_end = self._find_program(video_id, station, vid_int)
|
prog, station_program, ft, radio_begin, radio_end = self._find_program(video_id, station, timestring)
|
||||||
|
|
||||||
auth_token, area_id = self._auth_client()
|
auth_token, area_id = self._auth_client()
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue