cross-posted from: https://aussie.zone/post/19146681
Important Notes
Configurations behind a reverse proxy that did not explicitly configure trusted proxies will not work after this release. This was never a supported configuration, so please ensure you correct your configuration before upgrading. See the updated docs here for more information.
Security
- Fix validation of API parameters to FFmpeg [GHSA-2c3c-r7gp-q32m], by @Shadowghost
- Fix trusting forward headers if none are configured [GHSA-qcmf-gmhm-rfv9], by @JPVenson
Note: GHSAs will be published seven (7) days after this release.
General Changes
- Fix regression where “Search for missing metadata” not handling cast having multiple roles [PR #13720], by @Lampan-git
- Clone fallback audio tags instead of use ATL.Track.set [PR #13694], by @gnattu
- Backport 10.11 API enum changes [PR #13835], by @nielsvanvelzen
- Support more rating formats [PR #13639], by @IDisposable
- Fix stackoverflow in MediaSourceCount [PR #12907], by @JPVenson
- Upgrade LrcParser to 2025.228.1 [PR #13659], by @congerh
- Include Role and SortOrder in MergePeople to fix “Search for missing metadata” [PR #13618], by @Lampan-git
- Delete children from cache on parent delete [PR #13601], by @Bond-009
- Fix overwrite of PremierDate with a year-only value [PR #13598], by @IDisposable
- Wait for ffmpeg to exit on Windows before we try deleting the concat file [PR #13593], by @Bond-009
- Fix 4K filtering when grouping movies into collections [PR #13594], by @theguymadmax
- Remove empty ParentIndexNumber workaround [PR #13611], by @Shadowghost
- Update dependency z440.atl.core to 6.20.0 [PR #13845], by @Shadowghost
General Changes
- Fix parsing minor version of Tizen [PR #6661], by @dmitrylyzo
- Fix re-focusing on pause button when displaying OSD [PR #6510], by @dmitrylyzo
- Fix skip button not displaying correctly with OSD [PR #6583], by @rlauuzo
- Fix catalog plugin page not setting page title [PR #6570], by @nielsvanvelzen


It’s a crappy python script I packaged in a docker container lol. Turns out PBS kids uses an open unauthenticated CDN for serving videos to the website and apps.
I can share if you want, but it’ll take me until tomorrow to make it public
Please also grace me with this python goodness.
https://gitlab.com/mwirth001/elinorr
https://gitlab.com/mwirth001/elinorr/container_registry
Gracias
I’ve got some PBS kids I’d want to download so, sure
https://gitlab.com/mwirth001/elinorr
https://gitlab.com/mwirth001/elinorr/container_registry
I’m also interested 🫡
https://gitlab.com/mwirth001/elinorr
https://gitlab.com/mwirth001/elinorr/container_registry
So i got the container running, logs are showing the same error loop every couple of seconds. I’m wondering if it’s because the video url don’t match what’s in your gitlab readme:
https://pbskids.org/videos/watch/design-squad-full-episodes/1385861/one-giant-leap-part-2-ep-409/35449
https://pbskids.org/videos/watch/cyberchase-full-episodes/1385841/if-you-cant-stand-the-heat/1568637
Hmmm. I just double checked and my episodes are still downloading. But maybe newer shows have a different format… What’s the exact error? I’ll try to reproduce and fix.
Ah. I just walked away from my computer for the day. I can check tomorrow.
So I just spot checked. Both shows work, you just have to not click an episode anymore.
E.g, https://pbskids.org/videos/design-squad -> design-squad
Thank you for telling me, I’ll update the readme
Ah cool. Thanks for checking it out.
So I just got back to this today and I still have the same error:
KeyError: 'collections' '2025-04-08 20:31:17,226 - INFO - Entering elinorr function' '2025-04-08 20:31:17,226 - INFO - Successfully set show_list.' '2025-04-08 20:31:17,226 - INFO - Successfully finished pre-flight checks, beginning main loop of Elinorr.' '2025-04-08 20:31:17,228 - INFO - Successfully connected to elinorr.db.' '2025-04-08 20:31:17,229 - INFO - Processing show "design-squad"' Traceback (most recent call last): File "/elinorr/elinorr.py", line 175, in <module> elinorr(SHOW_LIST, WORK_DIR, SCAN_INTERVAL) File "/elinorr/elinorr.py", line 136, in elinorr for episode in content_json['collections']['episodes']['content']: KeyError: 'collections' '2025-04-08 20:31:19,132 - INFO - Entering elinorr function' '2025-04-08 20:31:19,132 - INFO - Successfully set show_list.' '2025-04-08 20:31:19,133 - INFO - Successfully finished pre-flight checks, beginning main loop of Elinorr.' '2025-04-08 20:31:19,135 - INFO - Successfully connected to elinorr.db.' '2025-04-08 20:31:19,137 - INFO - Processing show "design-squad"' Traceback (most recent call last): File "/elinorr/elinorr.py", line 175, in <module> elinorr(SHOW_LIST, WORK_DIR, SCAN_INTERVAL) File "/elinorr/elinorr.py", line 136, in elinorr for episode in content_json['collections']['episodes']['content']: KeyError: 'collections'Also tried with just
"design-squad", and tried with"cyberchase design-squad"Okay, thanks for giving me that, I’ll investigate further tonight