|  | Commit message (Collapse) | Author | Age | Files | Lines | 
|---|
| ... |  | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | those urls give a bio and pic of the person, and recently they've
started giving a list of all the programmes that person's appeared in as
well.
the API is a bit annoying, you have to specify a start and end time to
search between, so i had to work out the logic for "everything currently
on timefree"
also, the site doesn't use the "end_at_lt" parameter, only start_at_lt
i tried it in the url on the offchance it would work and save a bit of
logic
it did so i will keep it, but it probably stands out a quite a bit, idk
if the mobile apps use this, or with the end_at_lt parameter
the only playlist details I can provide are the ID. There is an API for
the actual details, but that's an extra request, and it's protobuf. | 
| | 
| 
| 
| 
| | so just the one --extractor-args incantation can be used for both live
and timefree (--extractor-args "rajiko:device=pc_html5") | 
| | 
| 
| 
| | generally we should work in datetimes, the strings should be the "special" ones | 
| | |  | 
| | |  | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | all tests passed as of Sat, 03 Aug 2024 06:44:00 +0100
updated to present day where necessary
rearranged the dicts to make them easier to read + modify
'single quotes' -> "double quotes" (including some other bits i saw along the way)
got rid of most of the timefree tests, since the time handling is tested externally now
the station websites stopped using the stationbutton (or started rendering it with javascript) so now cocolo is the only webpage test | 
| | |  | 
| | 
| 
| 
| | the link wasnt dead after all | 
| | |  | 
| | |  | 
| | |  | 
| | |  | 
| | |  | 
| | |  | 
| | |  | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | wanted to do this before, but per comment:
the official docs led me to believe that importlib_resources was the only
way to do it, and that the thing i was trying to do wasn't supported in
some python versions
so i put it off to one side for later
later came (now), and i tried to implement it with importlib.resources
didn't work, i looked it up and found this stackoverflow post
https://stackoverflow.com/a/58941536
and the second answer, using pkgutil (not importlib.resources), just worked
and the syntax/api seems much nicer as well
have tested with pip yt-dlp + raw directory plugin,
and binary yt-dlp + .whl plugin
also on windows, with binary+whl
both worked, amazing success! so pkgutil seems like the way to go
i also updated the build thing to include .bin files in the extractor dir | 
| | |  | 
| | 
| 
| 
| | so i don't have to figure it out from scratch every time | 
| | 
| 
| 
| | parity with yt-dlp proper | 
| | |  | 
| | |  | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | per discussion in the discord https://discord.com/channels/807245652072857610/1112613156934668338/1235992574687445044
one can do stuff like installing yt-dlp with the zip, and plugins with pip
so it's better for it to possibly not work, than to possibly fuck everything up
also it stops things needlessly hitting my pip index | 
| | |  | 
| | 
| 
| 
| 
| | information remains available on the website, which has been saved on 
the internet archive wayback machine | 
| | 
| 
| 
| 
| 
| | added usage instructions/advice
added a bit of japanese translation
updated required yt-dlp version to reflect reality | 
| | 
| 
| 
| | increment the version number more often | 
| | 
| 
| 
| | now links to the actual issue page and prints info useful for debugging | 
| | 
| 
| 
| 
| | it does not need to be cryptographically strong
only using token_hex for convenience | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | also fixed a rather embarrassing bug
the generated user agent was, for example:
Dalvik/2.1.0 (Linux; U; Android {'sdk': '27', 'builds': ['5794017', '6107733', '6037697']};SOV36/6107733)
because i put the wrong variable name in the fstring
thats alright its only been sending botched identification for
its entire existence(!) | 
| | 
| 
| 
| 
| 
| 
| 
| | one day i will find out what the proper thing to do is
i don't really want set "releases", i just want people to pull off the
master branch
since i try not to push broken code so fingers crossed it should be fine
(famous last words) | 
| | 
| 
| 
| 
| | makes it a bit easier to use in the cli since you don't need to 'quote'
for the #! | 
| | |  | 
| | 
| 
| 
| | there is a live format that also doesn't work | 
| | 
| 
| 
| | closes #18 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | so now it's just datetime.datetime with custom input and a few new funcs
instead of actually having a datetime.datetime internally and jankily
kind-of-exposing it
doesn't really affect things currently, but it makes something i want to
do possible (and it's generally just the better way of doing it)
Co-Authored-By: 9382 <omnomaidan@gmail.com> | 
| | |  | 
| | 
| 
| 
| 
| 
| | i think copyright can be a good thing actually
bsd 0-clause is basically the same but without the anti-copyright stuff afaict
also corrected spelling | 
| | |  | 
| | 
| 
| 
| 
| | housou daigaku is going away soon, so switching to radio nikkei
https://www.ouj.ac.jp/news/2023/information/5-32-2.html | 
| | 
| 
| 
| | mostly whitespace changes | 
| | |  | 
| | 
| 
| 
| 
| 
| | deduped code for working it out
also fixed bug in broadcast_day_end where it shifted forward by a day,
but didn't also set the time to 5am | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | the site will accept this so we have to as well
i should probably try and handle this in SiteTime
but cant be fucked right now
iirc the site just blanks out if the day is out of range
so the datetime exception matches the site's behaviour 👍 | 
| | 
| 
| 
| 
| | extractor shouldnt be executable
time thing should so i can test it easier | 
| | |  | 
| | 
| 
| 
| | closes #17 | 
| | |  | 
| | |  | 
| | |  | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | Station metadata changes extremely rarely, if ever, so it seems awfully
silly to keep downloading the exact same metadata every time we extract.
Wastes requests, wastes time (300ms round trip for me)
This commit makes it so station metadata is cached for a day, and cached
data is used in place of downloaded metadata when available.
Closes #16 |