Commit Graph

1696 Commits (1996e6afaad350e5205135919461b96fe04e12ac)

Author SHA1 Message Date
saltycrys 4184fb3ae7
Increase YouTube request timeout (#1540)
Increase YouTube request timeout
4 years ago
TheFrenchGhosty 20d2d141e4
Merge pull request #1539 from saltycrys/fix-comments
Fix comments
4 years ago
saltycrys 2de206cb81 Fix comments
The YouTube headers are now always added for requests to YouTube.
Previously they were only added for requests going through QUIC.

The session token is now JSON decoded to unescape escaped Unicode characters.

The comment continuation protobuf has been updated and the request now goes
through the YouTube `pbj` JSON API.
4 years ago
Sonic-Y3k 03d0b296e1
Fix invidious version for docker image
As Alpine-Linux per default uses the busybox date command, the -f option is not available and the build will fail.
4 years ago
TheFrenchGhosty 527f408f6a
Merge pull request #1529 from saltycrys/fix-version
Fix invidious version for old git versions
4 years ago
saltycrys adccca366e Fix invidious version for old git versions
The `%cs` format was only added to git in version 2.25 while `%ci` has been
around forever.
4 years ago
TheFrenchGhosty 76cad41382
Merge pull request #1525 from saltycrys/fix-video-descriptions
Fix `extract_polymer_config`
4 years ago
saltycrys cc684ff0b1 Fix redirect channels
Redirect channels may use JS to redirect now, instead of only a response header
as it used to be. This fix reads the channel to redirect to from `ytInitialData`.
4 years ago
saltycrys 7823c07f1a Fix `extract_polymer_config`
The `ytInitialPlayerResponse` regex can now handle `var` and `window`
assignments.

The video streams can now be extracted from `player_response` and
`initial_data`.

This fixes the descriptions on videos and videos themselves. Videos are
technically broken right now, but work becasue of a fallback that goes through
embeds.
4 years ago
Matthew McGarvey d7377015a2 Extracting search endpoints 4 years ago
saltycrys b409cdece5 Improve error message 2
Electric Boogaloo

The long backtrace has been moved into a `<details>` HTML element, as suggested
by @B0pol. To make the error still visible it has been added to the top under
`Title:`. This also encourages informative issue titles.
4 years ago
saltycrys 2478e67d16 Switch to date based versioning scheme
Since no new tags are created for releases the version has been frozen for some
time, with only the commit hash changing.

Versions based on the latest commit date make it much easier to identify them.
4 years ago
Théo Gaillard df3f9a2ae8
fix: channel info parsing 4 years ago
TheFrenchGhosty ca781651cb Fix formatting of #1504 4 years ago
saltycrys 92bb477f68 Improve error message
The error message has been reworded and the issue template now includes the
date, route, version and backtrace.
4 years ago
saltycrys 0f08cc5aa9 Remove backtrace on YouTube error
YouTube returning an error is not a bug in Invidious, so it should not print
a backtrace.
4 years ago
saltycrys 3dac33ffba
Add backtraces to errors (#1498)
Error handling has been reworked to always go through the new `error_template`,
`error_json` and `error_atom` macros.
They all accept a status code followed by a string message or an exception
object. `error_json` accepts a hash with additional fields as third argument.

If the second argument is an exception a backtrace will be printed, if it is a
string only the string is printed. Since up till now only the exception message
was printed a new `InfoException` class was added for situations where no
backtrace is intended but a string cannot be used.

`error_template` with a string message automatically localizes the message.
Missing error translations have been collected in https://github.com/iv-org/invidious/issues/1497
`error_json` with a string message does not localize the message. This is the
same as previous behavior. If translations are desired for `error_json` they
can be added easily but those error messages have not been collected yet.

Uncaught exceptions previously only printed a generic message ("Looks like
you've found a bug in Invidious. [...]"). They still print that message
but now also include a backtrace.
4 years ago
TheFrenchGhosty fe73eccb90
Merge pull request #1479 from saltycrys/theme-flash
Apply dark theme immediately
4 years ago
Théo Gaillard b41ca72d2b
revert: remove 'JSON.parse("' 4 years ago
Théo Gaillard 1ba17a0e14
feat: centralize ytInitialData parsing 4 years ago
Théo Gaillard 480d31eb5e
fix: ytInitialData parsing with regex 4 years ago
TheFrenchGhosty 1973f93d4a
Merge pull request #1482 from matthewmcgarvey/extract-playlist-routes
Extract playlist routes from global file
4 years ago
Émilien Devos 3a2f4d4def
allow to set a custom anti-captcha api url (#1473) 4 years ago
Matthew McGarvey 192d2b86b6 Extract playlist routes from global file 4 years ago
TheFrenchGhosty 6ca948ac3c
Merge pull request #1477 from saltycrys/empty-preference-values
Fill empty preference values
4 years ago
saltycrys ff46c18164 Move themes into default.css
Now that themes are controlled with a class instead of setting
media="none" on the stylesheet link and both themes already being
duplicated in default.css for the automatic themeing it makes sense
to have all theme related CSS in the same place.

This commit also fixes the missing dark theme on embeds.
4 years ago
saltycrys de777907f2 Apply dark theme immediately
Themes are now controlled with a class on the body element.

If a preference is set the body element will have either "dark-theme"
or "light-theme" class. If no preference is set or the preference is
empty the class will be "no-theme".

"dark-theme" and "light-theme" are handled by darktheme.css and
lighttheme.css respectively.

"no-theme" is handled by default.css where depending on the value of
"prefers-color-scheme" the styles corresponding to "dark-theme" or
"light-theme" are applied.

Unfortunately this means that both themes are duplicated, once in the
theme .css and once in default.css.
4 years ago
saltycrys 72c4fd868a Fill empty preference values 4 years ago
Émilien Devos c9c6c1f769
Remove duplicate Referrer-Policy 4 years ago
Perflyst bb7d8735cb
Merge branch 'master' into patch-1 4 years ago
Perflyst 557b0d76ab
Merge pull request #919 from edumoreira1506/feature/add-buttons-top-page
Add Previous/Next page buttons at the top of the page
4 years ago
Perflyst 13073411cc
Merge pull request #1465 from saltycrys/storyboards
Update videojs-vtt-thumbnails to latest upstream version and improve storyboard display
4 years ago
Johnquai 6d29e9c1b7
Fix missing videos tab on some channels (#1462)
* Fix missing videos tab on some channels

* Fixed formatting

Co-authored-by: Linux User <user@localhost.local>
4 years ago
saltycrys d3e4739745 Improve storyboard display 4 years ago
Matthew McGarvey 38b617d848 Formatting 4 years ago
Matthew McGarvey dda02f783f Extract embed routes into separate classes 4 years ago
Perflyst cda322e311
Merge pull request #1449 from raycheung/master
Fix stale playlist video counting on add/drop (#1448)
4 years ago
Matthew McGarvey 2cded8dcac Extract /watch route from main file 4 years ago
Ray Cheung babe0c31ad Fix stale playlist video counting on add/drop (https://github.com/iv-org/invidious/issues/1448)
The return of `cardinality()` is not affected by the `array_append()`
and `array_remove()` of the same statement.
4 years ago
saltycrys 9a8b81fcbe Fix storyboards 4 years ago
TheFrenchGhosty 138f38aade
more polish (#1437) 4 years ago
Triplesalt ec4a22687f
Update get_about_info for polymer (iv-org/invidious#1423) (#1429)
Update get_about_info for polymer (iv-org/invidious#1423)
4 years ago
Ben Heller 22d9d16a7a
Update parsing of ytInitialData (#1427)
Update parsing of ytInitialData
4 years ago
Matthew McGarvey 0520e67303
[refactor] Finish converting jobs to new job setup (#1420)
[refactor] Finish converting jobs to new job setup
4 years ago
Matthew McGarvey d571573e52
Set preferences before conditional breaks in before_all (#1412) 4 years ago
Matthew McGarvey 989317e5d3
Extract RefreshChannelsJob (#1403) 4 years ago
Perflyst 812a21bce6
Merge pull request #1372 from tleydxdy/patch-1
Add exponential backoff to refresh_channels
4 years ago
Perflyst e02608edf8
Use channel API v3 4 years ago
TheFrenchGhosty 1a7e160956
Merge pull request #1402 from matthewmcgarvey/feed-menu-overlap
Fix feed menu overlap at iPad screen widths
4 years ago
Matthew McGarvey 5937e0289e Fix feed menu overlap at ipad screen widths 4 years ago
Matthew McGarvey 85c212aee3 Provide rough draft of better project organization 4 years ago
TheFrenchGhosty 1978c3d3bd
Merge pull request #1379 from Rjevski/patch-1
Remove on-hover tooltip from player
4 years ago
Perflyst f65e57ee82
Fix formatting 4 years ago
Gauthier POGAM--LE MONTAGNER 1595eaeb74 Fix #1382 : Playlists missing first video
The index was set to index - 1, causing the first video to be shifted in fetch_playlist_videos
(because of its index being -1 lower than it should) and thus not displayed on playlist page.
4 years ago
Andre Borie a54cbe896d
Remove on-hover tooltip from player
Using the player on latest Safari, the tooltip appears and stays stuck for long even when switching to fullscreen which is annoying. You need to explicitly click anywhere to dismiss that stuck tooltip.

This doesn't seem to happen in Firefox so I am not sure whether this is a browser bug, but in any case I don't see any value in keeping this tooltip so maybe we can just remove it?
4 years ago
Omar Roth 9995a8d53f
Allow cookies from anti-captcha to be optional (#1371) 4 years ago
Omar Roth b88872d54b
Fix sub refresh (#1370) 4 years ago
tleydxdy f02ac01f7e
Add exponential backoff to refresh_channels
In practice with the patch I usually see backoff to 2 hours when blocked, so it should improve recovery time. The lim_thread is to work with multi-threading, not sure if it's the best way to do it.
4 years ago
Ben Heller 4a6e920d0e
Use new youtube API to fetch channel videos (#1355)
* Use new API to fetch videos from channels

This mirrors the process used by subscriptions.gir.st. The old API is
tried first, and if it fails then the new one is used.

* Use the new API whenever getting videos from a channel

I created the get_channel_videos_response function because now instead
of just getting a single url, there are extra steps involved in getting
the API response for channel videos, and these steps don't need to be
repeated throughout the code.

The only remaining exception is the bypass_captcha function, which still
only makes a request to the old API. I don't know whether this code
needs to be updated to use the new API for captcha bypassing to work
correctly.

* Correctly determine video length with new api

* Remove unnecessary line
4 years ago
stranger195 13f58d602f
Replace omarroth with iv-org where applicable (#1353)
Fixes #1353
4 years ago
Omar Roth 62f015fc34
Fix playlist export for playlists with more than 100 videos 4 years ago
Omar Roth 176ef19cca
Update mixes link 4 years ago
Omar Roth db83ede73c
Add missing default for ConfigPreferences 4 years ago
Omar Roth 452d1e8307
Fix warnings with latest version of Crystal 4 years ago
Omar Roth 92f337c67e
Add playlist import/export 4 years ago
Omar Roth 1e4022680a
Fix playlists with one video 4 years ago
Omar Roth b5f79444f9
Fix optional value in data extractor 4 years ago
Omar Roth 8ed1c77e47
Skip DASH streams segmented by URL 4 years ago
Omar Roth 8c65b8c16f
Update playlists to support polymer redesign 4 years ago
Omar Roth 1f435522b4
Fix cast from nil in short_description 4 years ago
Omar Roth 83b1d80a5b
Fix signature URL regex 4 years ago
Omar Roth 38c7dda00f
Fix genreUrl 4 years ago
Omar Roth 056e7432bd
Update channel playlists to use polymer 4 years ago
Omar Roth 1eca969cf6
Add support for polymer redesign 4 years ago
Omar Roth c1cbdae5ee
Make HOST_URL constant 4 years ago
Omar Roth 4d4b6a2fa0
Remove top page 4 years ago
Omar Roth d30a972a90
Support Crystal 0.35.0 4 years ago
Dmitry Sandalov 338dc3223c
Merge pull request #1182 from DmitrySandalov/master
Allow user to subscribe to playlist (#17)
4 years ago
Omar Roth 6435c7b921
Fix reCaptcha 5 years ago
mendel5 80941eacbd
More consistent HTML IDs for info section (#1156)
* More consistent IDs for info section

More consistent IDs for info section: watch-on-youtube, annotations and download

* Consistent IDs: channel-name

* Consistent IDs: published-date

The term "published" can also be found in the answer for the following YouTube API request: https://developers.google.com/youtube/v3/docs/videos/list
5 years ago
Omar Roth ceb252986e
Update captcha job 5 years ago
Dmitry Sandalov 5d8de5fde2
Allow user to subscribe to playlist (#17) 5 years ago
Omar Roth 750ef296c6
Update captcha handler 5 years ago
Omar Roth 454ae8656a
Cleanup request headers 5 years ago
Omar Roth 75450dcdbc
Update signature param 5 years ago
mendel5 9d23cf33fd
Consistent IDs for info section (#1133) 5 years ago
Omar Roth 97eb01a28d
Merge weblate 5 years ago
Omar Roth 408f3852ec
Hide playlist widget when user has no playlists 5 years ago
Omar Roth 7bb7003c9d
Fix authorThumbnails in /api/v1/channels 5 years ago
Omar Roth 920463f2ff
Fix playlist_ajax 5 years ago
Omar Roth ca1185d0be
Fix warnings in latest version of Crystal 5 years ago
Omar Roth 02d4186b11
Fix player matching 5 years ago
Omar Roth 3f97bebd69
Support adding video to playlist from watch page 5 years ago
Omar Roth 2e378da922
Add support for Swedish locale 5 years ago
Omar Roth b37f51bd7f
Fix /c/ redirect 5 years ago
Omar Roth c97cdf551e
Refactor extract_plid 5 years ago
Omar Roth 3b2e142542
Fix JSON serialization 5 years ago
Omar Roth 92798abb5d Add manifest-src to CSP 5 years ago
Omar Roth 59a15ceef6
Remove VarInt class 5 years ago
Omar Roth 4011a113cc
Strip invalid characters from referer URLs 5 years ago