Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Storyboards: Various fixes and code cleaning #4153

Merged
merged 8 commits into from
Aug 24, 2024

Conversation

SamantazFox
Copy link
Member

Closes #3441

@ChunkyProgrammer and @iBicha can I have your feedback on this one?

@SamantazFox SamantazFox requested a review from a team as a code owner October 8, 2023 18:38
@SamantazFox SamantazFox requested review from syeopite and removed request for a team October 8, 2023 18:38
@iBicha
Copy link
Contributor

iBicha commented Oct 8, 2023

The refactor LGTM, but I'm not sure it fixes #3441 - when I open the url in the browser after replacing M$M with M0, I get a 404. The other storyboards work though. Am I misunderstanding how it works?

@SamantazFox
Copy link
Member Author

The refactor LGTM, but I'm not sure it fixes #3441 - when I open the url in the browser after replacing M$M with M0, I get a 404. The other storyboards work though. Am I misunderstanding how it works?

That's what bugged me out for a moment! Actually, the first URL should now look like this:
https://i.ytimg.com/sb/{id}/storyboard3_L0/default.jpg?sqp=xxx&sigh=rs%24yyy

Note that it's not M$M.jpg but default.jpg

@iBicha
Copy link
Contributor

iBicha commented Oct 8, 2023

That's what bugged me out for a moment! Actually, the first URL should now look like this: https://i.ytimg.com/sb/{id}/storyboard3_L0/default.jpg?sqp=xxx&sigh=rs%24yyy

Note that it's not M$M.jpg but default.jpg

Oh I totally missed that. That's pretty interesting!
Thank you!

# Parse the JSON structure from Youtube
def self.from_yt_json(container : JSON::Any, length_seconds : Int32) : Array(Storyboard)
# Livestream storyboards are a bit different
# TODO: document exactly how
Copy link
Contributor

@absidue absidue Oct 8, 2023

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Tried messing around with them in shaka for FreeTube (as we can use the live dash manifest with shaka and get 4 hours of seeking) but the code I came up with based on reversing the player.js file and stepping through it with a debugger, ended up requesting loads of future not yet existing thumbnails (something in my assumptions or calculations must have been off), so I gave up and continued doing the rest of the shaka migration.
I'll let you know if I ever get it working in FreeTube.

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Ok, thanks for your research ^^

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Implementing live storyboards is probably something better done on the client side anyway, as it will require information from the streaming URL response headers or the live DASH manifest (at least that's the only way I can think of figuring out the current live segment) and you'll have to update it every 5 seconds, so generating a VTT file on the server side doesn't seem like a viable option for that.

My previous attempt revolved around using shaka's manifest preprocessing function to inject the live storyboards into the DASH manifest based on information in the manifest. Although as shaka already struggles enough with YouTube's 4 hour DVR window (4 hours worth of 5 second segments = 2880, which it has to recalculate every 5 seconds x) ) in the live manifests, so I'm not sure if adding that extra delay is a good idea, even if my solution had worked, which it didn't.

@SamantazFox SamantazFox added the need-testing This feature needs to be deployed and tested to see if it's working, and doesn't break something label Oct 8, 2023
@iBicha iBicha mentioned this pull request Oct 9, 2023
@ChunkyProgrammer
Copy link
Contributor

I tried testing this PR and it seems like the storyboards aren't loading properly in Invidious
Before using this PR:
image

While using this PR:
image

Image urls for the VTT plugin used to have url like
INSTANCE/sb/i/xQqsBIawZTw/storyboard3_L2/M8.jpg...
But are now have a url like this (notice the api/v1):
INSTANCE/api/v1/storyboards/sb/i/sb/xQqsBIawZTw/storyboard3_L0/default.jpg...

@SamantazFox
Copy link
Member Author

SamantazFox commented Oct 10, 2023

@ChunkyProgrammer Yes, we're aware of that problem. Syeopite added a workaround here: #4040

Edit: Though, I realised that his solution doesn't seem to handle URLs starting with /api/v1/storyboards, only /v1/storyboards yet it is still reported as functional?

@ChunkyProgrammer
Copy link
Contributor

ChunkyProgrammer commented Oct 10, 2023

Just to clarify, storyboards were working for me when running master locally at this commit 60fae01 (which was the latest at the time of my testing) but not working when using this PR locally

@SamantazFox
Copy link
Member Author

Okay, I found the issue!

@SamantazFox SamantazFox added in-testing This feature has been deployed and is being tested and removed need-testing This feature needs to be deployed and tested to see if it's working, and doesn't break something labels Oct 21, 2023
@SamantazFox SamantazFox requested a review from absidue October 21, 2023 14:57
@SamantazFox SamantazFox force-pushed the fix-storyboard branch 2 times, most recently from 139dc6c to b18c6a8 Compare December 16, 2023 18:08
@SamantazFox
Copy link
Member Author

It's so weird. Before that PR, all webVTT timestamps were null (see below), but videojs-vtt-thumbnails seems to handle that perfectly. However, as soon as I fix the timestamps, videojs-vtt-thumbnails goes completely nuts...

Before

WEBVTT

00:00:00.000 --> 00:00:00.000
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/M0.jpg?sqp=...&sigh=...#xywh=0,0,46,27

00:00:00.000 --> 00:00:00.000
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/M0.jpg?sqp=...&sigh=...#xywh=48,0,46,27

00:00:00.000 --> 00:00:00.000
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/M0.jpg?sqp=...&sigh=...#xywh=96,0,46,27

00:00:00.000 --> 00:00:00.000
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/M0.jpg?sqp=...&sigh=...#xywh=144,0,46,27

00:00:00.000 --> 00:00:00.000
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/M0.jpg?sqp=...&sigh=...#xywh=192,0,46,27

00:00:00.000 --> 00:00:00.000
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/M0.jpg?sqp=...&sigh=...#xywh=240,0,46,27

00:00:00.000 --> 00:00:00.000
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/M0.jpg?sqp=...&sigh=...#xywh=288,0,46,27

00:00:00.000 --> 00:00:00.000
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/M0.jpg?sqp=...&sigh=...#xywh=336,0,46,27

00:00:00.000 --> 00:00:00.000
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/M0.jpg?sqp=...&sigh=...#xywh=384,0,46,27

00:00:00.000 --> 00:00:00.000
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/M0.jpg?sqp=...&sigh=...#xywh=432,0,46,27

00:00:00.000 --> 00:00:00.000
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/M0.jpg?sqp=...&sigh=...#xywh=0,27,46,27

00:00:00.000 --> 00:00:00.000
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/M0.jpg?sqp=...&sigh=...#xywh=48,27,46,27

00:00:00.000 --> 00:00:00.000
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/M0.jpg?sqp=...&sigh=...#xywh=96,27,46,27

00:00:00.000 --> 00:00:00.000
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/M0.jpg?sqp=...&sigh=...#xywh=144,27,46,27

00:00:00.000 --> 00:00:00.000
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/M0.jpg?sqp=...&sigh=...#xywh=192,27,46,27

00:00:00.000 --> 00:00:00.000
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/M0.jpg?sqp=...&sigh=...#xywh=240,27,46,27

00:00:00.000 --> 00:00:00.000
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/M0.jpg?sqp=...&sigh=...#xywh=288,27,46,27

00:00:00.000 --> 00:00:00.000
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/M0.jpg?sqp=...&sigh=...#xywh=336,27,46,27

00:00:00.000 --> 00:00:00.000
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/M0.jpg?sqp=...&sigh=...#xywh=384,27,46,27

00:00:00.000 --> 00:00:00.000
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/M0.jpg?sqp=...&sigh=...#xywh=432,27,46,27

00:00:00.000 --> 00:00:00.000
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/M0.jpg?sqp=...&sigh=...#xywh=0,54,46,27

00:00:00.000 --> 00:00:00.000
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/M0.jpg?sqp=...&sigh=...#xywh=48,54,46,27

00:00:00.000 --> 00:00:00.000
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/M0.jpg?sqp=...&sigh=...#xywh=96,54,46,27

00:00:00.000 --> 00:00:00.000
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/M0.jpg?sqp=...&sigh=...#xywh=144,54,46,27

00:00:00.000 --> 00:00:00.000
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/M0.jpg?sqp=...&sigh=...#xywh=192,54,46,27

00:00:00.000 --> 00:00:00.000
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/M0.jpg?sqp=...&sigh=...#xywh=240,54,46,27

00:00:00.000 --> 00:00:00.000
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/M0.jpg?sqp=...&sigh=...#xywh=288,54,46,27

00:00:00.000 --> 00:00:00.000
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/M0.jpg?sqp=...&sigh=...#xywh=336,54,46,27

00:00:00.000 --> 00:00:00.000
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/M0.jpg?sqp=...&sigh=...#xywh=384,54,46,27

00:00:00.000 --> 00:00:00.000
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/M0.jpg?sqp=...&sigh=...#xywh=432,54,46,27

00:00:00.000 --> 00:00:00.000
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/M0.jpg?sqp=...&sigh=...#xywh=0,81,46,27

00:00:00.000 --> 00:00:00.000
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/M0.jpg?sqp=...&sigh=...#xywh=48,81,46,27

00:00:00.000 --> 00:00:00.000
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/M0.jpg?sqp=...&sigh=...#xywh=96,81,46,27

00:00:00.000 --> 00:00:00.000
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/M0.jpg?sqp=...&sigh=...#xywh=144,81,46,27

00:00:00.000 --> 00:00:00.000
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/M0.jpg?sqp=...&sigh=...#xywh=192,81,46,27

00:00:00.000 --> 00:00:00.000
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/M0.jpg?sqp=...&sigh=...#xywh=240,81,46,27

00:00:00.000 --> 00:00:00.000
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/M0.jpg?sqp=...&sigh=...#xywh=288,81,46,27

00:00:00.000 --> 00:00:00.000
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/M0.jpg?sqp=...&sigh=...#xywh=336,81,46,27

00:00:00.000 --> 00:00:00.000
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/M0.jpg?sqp=...&sigh=...#xywh=384,81,46,27

00:00:00.000 --> 00:00:00.000
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/M0.jpg?sqp=...&sigh=...#xywh=432,81,46,27

00:00:00.000 --> 00:00:00.000
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/M0.jpg?sqp=...&sigh=...#xywh=0,108,46,27

00:00:00.000 --> 00:00:00.000
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/M0.jpg?sqp=...&sigh=...#xywh=48,108,46,27

00:00:00.000 --> 00:00:00.000
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/M0.jpg?sqp=...&sigh=...#xywh=96,108,46,27

00:00:00.000 --> 00:00:00.000
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/M0.jpg?sqp=...&sigh=...#xywh=144,108,46,27

00:00:00.000 --> 00:00:00.000
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/M0.jpg?sqp=...&sigh=...#xywh=192,108,46,27

00:00:00.000 --> 00:00:00.000
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/M0.jpg?sqp=...&sigh=...#xywh=240,108,46,27

00:00:00.000 --> 00:00:00.000
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/M0.jpg?sqp=...&sigh=...#xywh=288,108,46,27

00:00:00.000 --> 00:00:00.000
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/M0.jpg?sqp=...&sigh=...#xywh=336,108,46,27

00:00:00.000 --> 00:00:00.000
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/M0.jpg?sqp=...&sigh=...#xywh=384,108,46,27

00:00:00.000 --> 00:00:00.000
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/M0.jpg?sqp=...&sigh=...#xywh=432,108,46,27

00:00:00.000 --> 00:00:00.000
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/M0.jpg?sqp=...&sigh=...#xywh=0,135,46,27

00:00:00.000 --> 00:00:00.000
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/M0.jpg?sqp=...&sigh=...#xywh=48,135,46,27

00:00:00.000 --> 00:00:00.000
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/M0.jpg?sqp=...&sigh=...#xywh=96,135,46,27

00:00:00.000 --> 00:00:00.000
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/M0.jpg?sqp=...&sigh=...#xywh=144,135,46,27

00:00:00.000 --> 00:00:00.000
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/M0.jpg?sqp=...&sigh=...#xywh=192,135,46,27

00:00:00.000 --> 00:00:00.000
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/M0.jpg?sqp=...&sigh=...#xywh=240,135,46,27

00:00:00.000 --> 00:00:00.000
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/M0.jpg?sqp=...&sigh=...#xywh=288,135,46,27

00:00:00.000 --> 00:00:00.000
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/M0.jpg?sqp=...&sigh=...#xywh=336,135,46,27

00:00:00.000 --> 00:00:00.000
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/M0.jpg?sqp=...&sigh=...#xywh=384,135,46,27

00:00:00.000 --> 00:00:00.000
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/M0.jpg?sqp=...&sigh=...#xywh=432,135,46,27

00:00:00.000 --> 00:00:00.000
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/M0.jpg?sqp=...&sigh=...#xywh=0,162,46,27

00:00:00.000 --> 00:00:00.000
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/M0.jpg?sqp=...&sigh=...#xywh=48,162,46,27

00:00:00.000 --> 00:00:00.000
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/M0.jpg?sqp=...&sigh=...#xywh=96,162,46,27

00:00:00.000 --> 00:00:00.000
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/M0.jpg?sqp=...&sigh=...#xywh=144,162,46,27

00:00:00.000 --> 00:00:00.000
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/M0.jpg?sqp=...&sigh=...#xywh=192,162,46,27

00:00:00.000 --> 00:00:00.000
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/M0.jpg?sqp=...&sigh=...#xywh=240,162,46,27

00:00:00.000 --> 00:00:00.000
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/M0.jpg?sqp=...&sigh=...#xywh=288,162,46,27

00:00:00.000 --> 00:00:00.000
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/M0.jpg?sqp=...&sigh=...#xywh=336,162,46,27

00:00:00.000 --> 00:00:00.000
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/M0.jpg?sqp=...&sigh=...#xywh=384,162,46,27

00:00:00.000 --> 00:00:00.000
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/M0.jpg?sqp=...&sigh=...#xywh=432,162,46,27

00:00:00.000 --> 00:00:00.000
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/M0.jpg?sqp=...&sigh=...#xywh=0,189,46,27

00:00:00.000 --> 00:00:00.000
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/M0.jpg?sqp=...&sigh=...#xywh=48,189,46,27

00:00:00.000 --> 00:00:00.000
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/M0.jpg?sqp=...&sigh=...#xywh=96,189,46,27

00:00:00.000 --> 00:00:00.000
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/M0.jpg?sqp=...&sigh=...#xywh=144,189,46,27

00:00:00.000 --> 00:00:00.000
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/M0.jpg?sqp=...&sigh=...#xywh=192,189,46,27

00:00:00.000 --> 00:00:00.000
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/M0.jpg?sqp=...&sigh=...#xywh=240,189,46,27

00:00:00.000 --> 00:00:00.000
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/M0.jpg?sqp=...&sigh=...#xywh=288,189,46,27

00:00:00.000 --> 00:00:00.000
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/M0.jpg?sqp=...&sigh=...#xywh=336,189,46,27

00:00:00.000 --> 00:00:00.000
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/M0.jpg?sqp=...&sigh=...#xywh=384,189,46,27

00:00:00.000 --> 00:00:00.000
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/M0.jpg?sqp=...&sigh=...#xywh=432,189,46,27

00:00:00.000 --> 00:00:00.000
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/M0.jpg?sqp=...&sigh=...#xywh=0,216,46,27

00:00:00.000 --> 00:00:00.000
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/M0.jpg?sqp=...&sigh=...#xywh=48,216,46,27

00:00:00.000 --> 00:00:00.000
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/M0.jpg?sqp=...&sigh=...#xywh=96,216,46,27

00:00:00.000 --> 00:00:00.000
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/M0.jpg?sqp=...&sigh=...#xywh=144,216,46,27

00:00:00.000 --> 00:00:00.000
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/M0.jpg?sqp=...&sigh=...#xywh=192,216,46,27

00:00:00.000 --> 00:00:00.000
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/M0.jpg?sqp=...&sigh=...#xywh=240,216,46,27

00:00:00.000 --> 00:00:00.000
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/M0.jpg?sqp=...&sigh=...#xywh=288,216,46,27

00:00:00.000 --> 00:00:00.000
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/M0.jpg?sqp=...&sigh=...#xywh=336,216,46,27

00:00:00.000 --> 00:00:00.000
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/M0.jpg?sqp=...&sigh=...#xywh=384,216,46,27

00:00:00.000 --> 00:00:00.000
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/M0.jpg?sqp=...&sigh=...#xywh=432,216,46,27

00:00:00.000 --> 00:00:00.000
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/M0.jpg?sqp=...&sigh=...#xywh=0,243,46,27

00:00:00.000 --> 00:00:00.000
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/M0.jpg?sqp=...&sigh=...#xywh=48,243,46,27

00:00:00.000 --> 00:00:00.000
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/M0.jpg?sqp=...&sigh=...#xywh=96,243,46,27

00:00:00.000 --> 00:00:00.000
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/M0.jpg?sqp=...&sigh=...#xywh=144,243,46,27

00:00:00.000 --> 00:00:00.000
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/M0.jpg?sqp=...&sigh=...#xywh=192,243,46,27

00:00:00.000 --> 00:00:00.000
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/M0.jpg?sqp=...&sigh=...#xywh=240,243,46,27

00:00:00.000 --> 00:00:00.000
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/M0.jpg?sqp=...&sigh=...#xywh=288,243,46,27

00:00:00.000 --> 00:00:00.000
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/M0.jpg?sqp=...&sigh=...#xywh=336,243,46,27

00:00:00.000 --> 00:00:00.000
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/M0.jpg?sqp=...&sigh=...#xywh=384,243,46,27

00:00:00.000 --> 00:00:00.000
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/M0.jpg?sqp=...&sigh=...#xywh=432,243,46,27

After

WEBVTT

00:00:00.000 --> 00:00:13.229
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/default.jpg?sqp=...&sigh=...#xywh=0,0,46,27

00:00:13.230 --> 00:00:26.459
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/default.jpg?sqp=...&sigh=...#xywh=48,0,46,27

00:00:26.460 --> 00:00:39.689
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/default.jpg?sqp=...&sigh=...#xywh=96,0,46,27

00:00:39.690 --> 00:00:52.919
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/default.jpg?sqp=...&sigh=...#xywh=144,0,46,27

00:00:52.920 --> 00:01:06.149
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/default.jpg?sqp=...&sigh=...#xywh=192,0,46,27

00:01:06.150 --> 00:01:19.379
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/default.jpg?sqp=...&sigh=...#xywh=240,0,46,27

00:01:19.380 --> 00:01:32.609
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/default.jpg?sqp=...&sigh=...#xywh=288,0,46,27

00:01:32.610 --> 00:01:45.839
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/default.jpg?sqp=...&sigh=...#xywh=336,0,46,27

00:01:45.840 --> 00:01:59.069
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/default.jpg?sqp=...&sigh=...#xywh=384,0,46,27

00:01:59.070 --> 00:02:12.299
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/default.jpg?sqp=...&sigh=...#xywh=432,0,46,27

00:02:12.300 --> 00:02:25.529
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/default.jpg?sqp=...&sigh=...#xywh=0,27,46,27

00:02:25.530 --> 00:02:38.759
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/default.jpg?sqp=...&sigh=...#xywh=48,27,46,27

00:02:38.760 --> 00:02:51.989
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/default.jpg?sqp=...&sigh=...#xywh=96,27,46,27

00:02:51.990 --> 00:03:05.219
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/default.jpg?sqp=...&sigh=...#xywh=144,27,46,27

00:03:05.220 --> 00:03:18.449
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/default.jpg?sqp=...&sigh=...#xywh=192,27,46,27

00:03:18.450 --> 00:03:31.679
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/default.jpg?sqp=...&sigh=...#xywh=240,27,46,27

00:03:31.680 --> 00:03:44.909
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/default.jpg?sqp=...&sigh=...#xywh=288,27,46,27

00:03:44.910 --> 00:03:58.139
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/default.jpg?sqp=...&sigh=...#xywh=336,27,46,27

00:03:58.140 --> 00:04:11.369
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/default.jpg?sqp=...&sigh=...#xywh=384,27,46,27

00:04:11.370 --> 00:04:24.599
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/default.jpg?sqp=...&sigh=...#xywh=432,27,46,27

00:04:24.600 --> 00:04:37.829
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/default.jpg?sqp=...&sigh=...#xywh=0,54,46,27

00:04:37.830 --> 00:04:51.059
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/default.jpg?sqp=...&sigh=...#xywh=48,54,46,27

00:04:51.060 --> 00:05:04.289
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/default.jpg?sqp=...&sigh=...#xywh=96,54,46,27

00:05:04.290 --> 00:05:17.519
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/default.jpg?sqp=...&sigh=...#xywh=144,54,46,27

00:05:17.520 --> 00:05:30.749
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/default.jpg?sqp=...&sigh=...#xywh=192,54,46,27

00:05:30.750 --> 00:05:43.979
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/default.jpg?sqp=...&sigh=...#xywh=240,54,46,27

00:05:43.980 --> 00:05:57.209
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/default.jpg?sqp=...&sigh=...#xywh=288,54,46,27

00:05:57.210 --> 00:06:10.439
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/default.jpg?sqp=...&sigh=...#xywh=336,54,46,27

00:06:10.440 --> 00:06:23.669
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/default.jpg?sqp=...&sigh=...#xywh=384,54,46,27

00:06:23.670 --> 00:06:36.899
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/default.jpg?sqp=...&sigh=...#xywh=432,54,46,27

00:06:36.900 --> 00:06:50.129
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/default.jpg?sqp=...&sigh=...#xywh=0,81,46,27

00:06:50.130 --> 00:07:03.359
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/default.jpg?sqp=...&sigh=...#xywh=48,81,46,27

00:07:03.360 --> 00:07:16.589
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/default.jpg?sqp=...&sigh=...#xywh=96,81,46,27

00:07:16.590 --> 00:07:29.819
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/default.jpg?sqp=...&sigh=...#xywh=144,81,46,27

00:07:29.820 --> 00:07:43.049
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/default.jpg?sqp=...&sigh=...#xywh=192,81,46,27

00:07:43.050 --> 00:07:56.279
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/default.jpg?sqp=...&sigh=...#xywh=240,81,46,27

00:07:56.280 --> 00:08:09.509
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/default.jpg?sqp=...&sigh=...#xywh=288,81,46,27

00:08:09.510 --> 00:08:22.739
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/default.jpg?sqp=...&sigh=...#xywh=336,81,46,27

00:08:22.740 --> 00:08:35.969
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/default.jpg?sqp=...&sigh=...#xywh=384,81,46,27

00:08:35.970 --> 00:08:49.199
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/default.jpg?sqp=...&sigh=...#xywh=432,81,46,27

00:08:49.200 --> 00:09:02.429
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/default.jpg?sqp=...&sigh=...#xywh=0,108,46,27

00:09:02.430 --> 00:09:15.659
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/default.jpg?sqp=...&sigh=...#xywh=48,108,46,27

00:09:15.660 --> 00:09:28.889
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/default.jpg?sqp=...&sigh=...#xywh=96,108,46,27

00:09:28.890 --> 00:09:42.119
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/default.jpg?sqp=...&sigh=...#xywh=144,108,46,27

00:09:42.120 --> 00:09:55.349
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/default.jpg?sqp=...&sigh=...#xywh=192,108,46,27

00:09:55.350 --> 00:10:08.579
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/default.jpg?sqp=...&sigh=...#xywh=240,108,46,27

00:10:08.580 --> 00:10:21.809
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/default.jpg?sqp=...&sigh=...#xywh=288,108,46,27

00:10:21.810 --> 00:10:35.039
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/default.jpg?sqp=...&sigh=...#xywh=336,108,46,27

00:10:35.040 --> 00:10:48.269
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/default.jpg?sqp=...&sigh=...#xywh=384,108,46,27

00:10:48.270 --> 00:11:01.499
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/default.jpg?sqp=...&sigh=...#xywh=432,108,46,27

00:11:01.500 --> 00:11:14.729
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/default.jpg?sqp=...&sigh=...#xywh=0,135,46,27

00:11:14.730 --> 00:11:27.959
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/default.jpg?sqp=...&sigh=...#xywh=48,135,46,27

00:11:27.960 --> 00:11:41.189
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/default.jpg?sqp=...&sigh=...#xywh=96,135,46,27

00:11:41.190 --> 00:11:54.419
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/default.jpg?sqp=...&sigh=...#xywh=144,135,46,27

00:11:54.420 --> 00:12:07.649
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/default.jpg?sqp=...&sigh=...#xywh=192,135,46,27

00:12:07.650 --> 00:12:20.879
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/default.jpg?sqp=...&sigh=...#xywh=240,135,46,27

00:12:20.880 --> 00:12:34.109
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/default.jpg?sqp=...&sigh=...#xywh=288,135,46,27

00:12:34.110 --> 00:12:47.339
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/default.jpg?sqp=...&sigh=...#xywh=336,135,46,27

00:12:47.340 --> 00:13:00.569
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/default.jpg?sqp=...&sigh=...#xywh=384,135,46,27

00:13:00.570 --> 00:13:13.799
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/default.jpg?sqp=...&sigh=...#xywh=432,135,46,27

00:13:13.800 --> 00:13:27.029
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/default.jpg?sqp=...&sigh=...#xywh=0,162,46,27

00:13:27.030 --> 00:13:40.259
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/default.jpg?sqp=...&sigh=...#xywh=48,162,46,27

00:13:40.260 --> 00:13:53.489
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/default.jpg?sqp=...&sigh=...#xywh=96,162,46,27

00:13:53.490 --> 00:14:06.719
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/default.jpg?sqp=...&sigh=...#xywh=144,162,46,27

00:14:06.720 --> 00:14:19.949
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/default.jpg?sqp=...&sigh=...#xywh=192,162,46,27

00:14:19.950 --> 00:14:33.179
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/default.jpg?sqp=...&sigh=...#xywh=240,162,46,27

00:14:33.180 --> 00:14:46.409
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/default.jpg?sqp=...&sigh=...#xywh=288,162,46,27

00:14:46.410 --> 00:14:59.639
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/default.jpg?sqp=...&sigh=...#xywh=336,162,46,27

00:14:59.640 --> 00:15:12.869
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/default.jpg?sqp=...&sigh=...#xywh=384,162,46,27

00:15:12.870 --> 00:15:26.099
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/default.jpg?sqp=...&sigh=...#xywh=432,162,46,27

00:15:26.100 --> 00:15:39.329
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/default.jpg?sqp=...&sigh=...#xywh=0,189,46,27

00:15:39.330 --> 00:15:52.559
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/default.jpg?sqp=...&sigh=...#xywh=48,189,46,27

00:15:52.560 --> 00:16:05.789
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/default.jpg?sqp=...&sigh=...#xywh=96,189,46,27

00:16:05.790 --> 00:16:19.019
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/default.jpg?sqp=...&sigh=...#xywh=144,189,46,27

00:16:19.020 --> 00:16:32.249
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/default.jpg?sqp=...&sigh=...#xywh=192,189,46,27

00:16:32.250 --> 00:16:45.479
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/default.jpg?sqp=...&sigh=...#xywh=240,189,46,27

00:16:45.480 --> 00:16:58.709
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/default.jpg?sqp=...&sigh=...#xywh=288,189,46,27

00:16:58.710 --> 00:17:11.939
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/default.jpg?sqp=...&sigh=...#xywh=336,189,46,27

00:17:11.940 --> 00:17:25.169
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/default.jpg?sqp=...&sigh=...#xywh=384,189,46,27

00:17:25.170 --> 00:17:38.399
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/default.jpg?sqp=...&sigh=...#xywh=432,189,46,27

00:17:38.400 --> 00:17:51.629
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/default.jpg?sqp=...&sigh=...#xywh=0,216,46,27

00:17:51.630 --> 00:18:04.859
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/default.jpg?sqp=...&sigh=...#xywh=48,216,46,27

00:18:04.860 --> 00:18:18.089
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/default.jpg?sqp=...&sigh=...#xywh=96,216,46,27

00:18:18.090 --> 00:18:31.319
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/default.jpg?sqp=...&sigh=...#xywh=144,216,46,27

00:18:31.320 --> 00:18:44.549
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/default.jpg?sqp=...&sigh=...#xywh=192,216,46,27

00:18:44.550 --> 00:18:57.779
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/default.jpg?sqp=...&sigh=...#xywh=240,216,46,27

00:18:57.780 --> 00:19:11.009
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/default.jpg?sqp=...&sigh=...#xywh=288,216,46,27

00:19:11.010 --> 00:19:24.239
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/default.jpg?sqp=...&sigh=...#xywh=336,216,46,27

00:19:24.240 --> 00:19:37.469
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/default.jpg?sqp=...&sigh=...#xywh=384,216,46,27

00:19:37.470 --> 00:19:50.699
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/default.jpg?sqp=...&sigh=...#xywh=432,216,46,27

00:19:50.700 --> 00:20:03.929
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/default.jpg?sqp=...&sigh=...#xywh=0,243,46,27

00:20:03.930 --> 00:20:17.159
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/default.jpg?sqp=...&sigh=...#xywh=48,243,46,27

00:20:17.160 --> 00:20:30.389
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/default.jpg?sqp=...&sigh=...#xywh=96,243,46,27

00:20:30.390 --> 00:20:43.619
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/default.jpg?sqp=...&sigh=...#xywh=144,243,46,27

00:20:43.620 --> 00:20:56.849
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/default.jpg?sqp=...&sigh=...#xywh=192,243,46,27

00:20:56.850 --> 00:21:10.079
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/default.jpg?sqp=...&sigh=...#xywh=240,243,46,27

00:21:10.080 --> 00:21:23.309
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/default.jpg?sqp=...&sigh=...#xywh=288,243,46,27

00:21:23.310 --> 00:21:36.539
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/default.jpg?sqp=...&sigh=...#xywh=336,243,46,27

00:21:36.540 --> 00:21:49.769
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/default.jpg?sqp=...&sigh=...#xywh=384,243,46,27

00:21:49.770 --> 00:22:02.999
https://test.invidious.io/sb/i/KOEfDvr4DcQ/storyboard3_L0/default.jpg?sqp=...&sigh=...#xywh=432,243,46,27

@absidue
Copy link
Contributor

absidue commented Apr 18, 2024

@SamantazFox Looks like videojs-vtt-thumbnails doesn't follow the spec properly and doesn't unescape the escaped characters. So an exception will need to be added to #4414 to not escape characters for thumbnail files.

@SamantazFox SamantazFox added unfinished More work is needed on this PR, or on something this PR uses. and removed in-testing This feature has been deployed and is being tested labels Jul 9, 2024
@SamantazFox SamantazFox added need-testing This feature needs to be deployed and tested to see if it's working, and doesn't break something and removed unfinished More work is needed on this PR, or on something this PR uses. labels Aug 16, 2024
The workarounds are as follow:
  * Unescape HTML entities
  * Always use 0:00:00.000 for cue start/end
@SamantazFox
Copy link
Member Author

SamantazFox commented Aug 16, 2024

It should be good now. 5b05f3b adds the required workarounds for videojs-vtt-thumbnails: unescaped HTML entities and cue start/end always at 0:00:00.000

@SamantazFox
Copy link
Member Author

Well, I was wrong: videojs-vtt-thumbnails still requires proper cue timing, but the start and end times must overlap (see comment in last commit). If they don't, it leaves a 1sec gap and the GUI glitches, resulting in poor user experience.

@SamantazFox SamantazFox added in-testing This feature has been deployed and is being tested ready and removed need-testing This feature needs to be deployed and tested to see if it's working, and doesn't break something in-testing This feature has been deployed and is being tested labels Aug 22, 2024
@SamantazFox SamantazFox merged commit cd2daf4 into iv-org:master Aug 24, 2024
7 of 8 checks passed
@SamantazFox SamantazFox deleted the fix-storyboard branch August 24, 2024 18:54
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Projects
None yet
Development

Successfully merging this pull request may close these issues.

[Bug] First storyboard is always broken
4 participants