Commit Graph

2111 Commits (a905175e8c925447f37c3e3d7d98b78168ba7393)

Author SHA1 Message Date
syeopite 585e4617e8
Lazy load (some) images 3 years ago
syeopite 4d44b2c3a4
Handle YT tabs without any content 3 years ago
syeopite b49b5fbda9
Support empty categories 3 years ago
syeopite 17e6093abb
Merge pull request #2497 from Yetangitu/videorendererparser_parse_missing_title
Handle missing title fields in VideoRendererParser.parse (fixes #2495)
3 years ago
Frank de Lange 3dc980e800
Fix for #2488 - parse contents of search results of type=Category (#2496)
* Fix for #2488 - parse contents of search results of type=Category (returned on first page for universal (type=all) queries instead of returning an error.

* Moved content array walker to Category#to_json

As requested by reviewer this change moves the content array walker from the API endpoint to the Category class.

* Update src/invidious/helpers/serialized_yt_data.cr

Co-authored-by: syeopite <70992037+syeopite@users.noreply.github.com>
3 years ago
Frank de Lange c44c1003af Handle missing title fields in VideoRendererParser.parse 3 years ago
Samantaz Fox 678b10dbcf
Lookback 50 videos 3 years ago
diogo a1d6411f1f
propagate video_id field on getting playlists 3 years ago
diogo c4c8a10507
rename from continuation to video_id on get_playlist_videos 3 years ago
diogo ee94ccdeb0
update to new YoutubeAPI 3 years ago
diogo e3df9f9ead
use dig for getting the video index 3 years ago
diogo 62dc629337
linting 3 years ago
diogo dccdf38ce7
increase the max videos in a playlist 3 years ago
diogo 84124b837d
use v1/next instead of searching for the continuation index 3 years ago
diogo 6176da3cbb
linting 3 years ago
diogo 24bc3e2704
no need to normalize the offset 3 years ago
diogo 0a9e19646a
pass the api/v1/playlists with videos before the offset 3 years ago
diogo 65e45c4079
linting 3 years ago
diogo 440105976f
fix cases when high offset video from playlist has no offset in url 3 years ago
diogo 7eba7fbcc7
add index to playlist item 3 years ago
diogo d9bfb3d305
playlist starts at the offset 3 years ago
syeopite 4246c7a523
Extract image routes 3 years ago
Samantaz Fox 57ed047025
Add mising 'require' statement to 'invidious.cr' 3 years ago
Samantaz Fox bda3a26423
Move server structure to a separate file 3 years ago
Samantaz Fox 080d9a8dc7
move theme converter function to a separate file 3 years ago
Samantaz Fox 984a4acc7b
Move user preferences structure to a separate file 3 years ago
syeopite b10f37bea9
Use kemal in production mode (#2455) 3 years ago
mastihios 0947c26612
Fix URL-encoding in href strings (#2460)
* hrefs: replace HTML.escape w/ URI.encode_www_form

* Fix search_query_encoded
3 years ago
Samantaz Fox c6f088d6ca
Reduce refresh delay, increase backoff start duration 3 years ago
syeopite 21e29411af
Fix extractor bugs (#2454)
* Add debug/trace logging to extract_items
* Handle invalid timestamps for livestreams extraction
* Make use of author_fallback in playlist extractor
* Don't use extract_text for video length extraction

The extract_text function attempts to extract from both the simpleText and
the runs route. This is typically what we'd want for text extraction as
it could appear in both locations. However, while this still holds true,
the thumbnailOverlayTimeStatusRenderer writes a numerical length (when
present on the video) to the simpleText route and uses runs for a
text overlay like "LIVE" or "PREMIERE".

Therefore, when a video has a text overlay instead of a numerical one,
Invidious still passes it onto decode_length_seconds, which obviously
raises since it cannot be converted into integers.

In the future, if more routes requires one text route over the other, we
should go ahead and add an argument to extract_text itself. Though for
now, this is sufficient.

* Handle unsupported "special" categories
3 years ago
Samantaz Fox adc12addfa
Add config option to display source code URL in footer (#2450) 3 years ago
Samantaz Fox d806310665
Revert "Fix typo (#2456)" (#2457)
This reverts commit 4982bff74d.
3 years ago
Jorge Maldonado Ventura 4982bff74d
Fix typo (#2456) 3 years ago
syeopite 81b12b8001
Add support to make invidious API-only via flag (#2363) 3 years ago
syeopite 3e781b7d13
Merge pull request #2443 from iv-org/syeopite-patch-1
Use make_client when querying instance api
3 years ago
syeopite 9c44e41a4c
Merge pull request #2228 from syeopite/extract-items-overhaul
Overhaul extract_item(s) functions and add infrastructure for parsing YouTube categories
3 years ago
syeopite 73eabb6ca2
Actually fix lint 3 years ago
Samantaz Fox 5a52b4fe45
Fix lint 3 years ago
Samantaz Fox caa08a6379
Disable locales with less than 50% of strings translated 3 years ago
Samantaz Fox cd02078e26
Add Portuguese (pt) to locales
follow up to #2437
3 years ago
syeopite 77131cff91
Use make_client when querying instance api 3 years ago
mastihios 7b2aa5f98e
add icon-buttons to playlist items (#2442) 3 years ago
syeopite 26b28cea49
Use break instead of short-circuit return 3 years ago
syeopite 23049e026f
Improve readabltiy of SearchChannel auto-gen detect 3 years ago
syeopite 9ab242ca2e
Optimize routing logic of extract_item(s) funcs 3 years ago
syeopite aa59925374
Rename get_browse_endpoint to get_browse_id 3 years ago
syeopite 43ea8fa706
Convert nil for AuthorFallback to empty strings 3 years ago
syeopite 6df85718e6
Apply suggestions from code review
Co-authored-by: Samantaz Fox <coding@samantaz.fr>
3 years ago
Samantaz Fox 9ba3e1cdb4
Decrease channel refresh frequency (1 min -> 1 h)
This is a temporary fix to reduce load on instances with many channels and avoid IP being flagged by Google.
3 years ago
syeopite b20f72b963
Use default timeout (5 seconds) for YT pool (#2430) 3 years ago
syeopite 092b8a4e52
Add documentation to extractors.cr 3 years ago
syeopite e5f07dedbf
Typos and tiny styling changes 3 years ago
syeopite ca9eb0d539
Bountiful extractor changes
- Add extract_text to simplify extraction of InnerTube texts
- Add helper extractor methods to reduce repetition in parsing InnerTube
- Change [] more than 2 blocks long to use #dig or #dig?
- Remove useless ?.try blocks for items that always exists
- Add (some) documentation to VideoRendererParser
3 years ago
syeopite 142317c2be
Overhaul extractors.cr to use modules 3 years ago
syeopite 3dea670091
Switch to structs in extractors.cr for performance 3 years ago
syeopite 8435e79913
Improve documentation for extract_item(s) funcs 3 years ago
syeopite 30e85b40f9
Fix extract_videos 3 years ago
syeopite be1a43a337
Manually extract category refactor from 1b569bbc99
Also fixes some errors caused by cherry-picking
3 years ago
syeopite abca8f7a7c
Rename invidiousitems.cr 3 years ago
syeopite 7b60dac526
Add description_html field to Category
(cherry picked from commit aa8f15f795)
3 years ago
syeopite ea6434662d
Change typing of Category contents to only Array
(cherry picked from commit d3384e17f1)
3 years ago
syeopite 0b7a108a59
Move continuation_token out of Category struct
(cherry picked from commit 0e96eda28f)
3 years ago
syeopite 57c63f3598
Rename "items_without_cate_items" to reflect usage 3 years ago
syeopite ae30f32c36
Unpack search items that are embedded in categories
This is a squash of a bunch of commits
cherry-picked commits

Fix category parse error on search

(cherry picked from commit cc02fed4e6)

Fix category items not being extracted in search

(cherry picked from commit 2605b9c609)

Make search not include category items for now

(cherry picked from commit ca4afd59f4)

Change behavior of categories in search results

(cherry picked from commit cc10675610)

Fix missing search results in extraction

(cherry picked from commit abda6840d5)

Fix miscount of search results

(cherry picked from commit 491e33450e)
3 years ago
syeopite a50f64f6e9
Add parser for categories (shelfRenderer)
This commit adds a new parser for YT's shelfRenderers which are
typically used to denote different categories.The code for featured
channels parsing has also been moved to use the new parser but some
additional refactoring are needed there.

The ContinuationExtractor has also been improved and is now capable of
extraction continuation data that is packaged under
"appendContinuationItemsAction"

In additional this commit adds some useful helper functions to extract
the current selected tab the continuation token. This is to mainly
reduce code size and repetition.
--
This cherry-picked commit also removes the code for parsing featured
channels present on the original.

(cherry picked from commit 8000d538db)
3 years ago
syeopite 1323b94b7a
Rewrite extract_item and extract_items functions
This commit completely rewrites the extract_item and extract_items
function. Before this commit these two function were an unreadable
mess. The extract_item function was a lengthy if-elsif chain
while the extract_items function contained an incomprehensible
mess of .try, else and ||.

With this commit both of these functions have been pulled into a
separate file with the internal logic being moved to a few classes.

This significantly reduces the size of these two methods, enhances
readability and makes adding new extraction/parse rules much simpler.

See diff for details.

--
This cherry-picked commit also removes the code for parsing featured
channels present on the original.

(cherry picked from commit a027fbf7af)
3 years ago
syeopite 6d68fbc31d
Fix livestream regex regression caused by #2271
Closes #2352

Special thanks to @WaywardHeart for finding this issue!
3 years ago
syeopite 86ca568d6d
Remove login type button from frontend (#2423) 3 years ago
Walkyst 2b0bb69a4f
Fix mixes route (#2421) 3 years ago
syeopite 87f46a7532
Unregister captcha job (#2390) 3 years ago
Samantaz Fox e655af251c
Try not to log search queries (#2362) 3 years ago
syeopite 5054510d15
Prevent VR from being initialized in listen mode (#2396) 3 years ago
Samantaz Fox 947fe4fbb3
HTML escape video mimetype
Video mimetype may contain code information between double quotes.
If not properly escaped, it breaks the browser's parser. E.g:
```
type="video/mp4; codecs=" avc1.64001f,="" mp4a.40.2""=""
```

Thank Robin for catching this!
3 years ago
syeopite 50c8afb525
Handle equirectangular projections for VR (#2379) 3 years ago
syeopite a539de4f97
Bump dependencies (#2378)
* Upgrade to Kemal v1.1.0

* Bump postgres driver
3 years ago
TheFrenchGhosty 8d5a867271
Merge pull request #2380 from syeopite/fix-invidious-showing-yt-redirect-links
Fix invidious showing yt redirect links
3 years ago
syeopite 387bddb51b
Improve detection and handling of yt redirect links 3 years ago
Emilien Devos 41ba19b615 fix comment replies 3 years ago
syeopite a28945273d
Propagate replacing yout.be links to /watch to RSS 3 years ago
syeopite fd6f03655e
Fix typo causing links to be youtube.com/redirect 3 years ago
Émilien Devos 8b62c05fe2
remove 3gp only from the player (#2376)
+ video quality precedence on default player when js is not enabled
3 years ago
syeopite a1001ada47
Properly transform youtu.be links to be /watch routes in comments and descriptions (#2365) 3 years ago
TheFrenchGhosty 8e3ff79f22 Remove the mention of 'Omar Roth' from the footer 3 years ago
syeopite 4fcd0964cd
Extract API routes (#2271)
* Extract API routes from invidious.cr
* Remove deprecated APIs
  - insights
  - top feed
3 years ago
syeopite 5005212bec
Extract feed routes (#2269)
* Extract feed routes from invidious.cr
* Removes the deprecated route for /feed/top
* Deprecate /view_all_playlist & use /feed/playlists
* Move feed views into their own directory

* Add haltf method to halt current route context
* Change status_code + return blocks to use haltf

* Set appropriate response headers for RSS routes
3 years ago
Émilien Devos a279d6f433
Fix livestream parsing URLs (#2356) 3 years ago
syeopite fceb8093f1
Use `athena-negotiation` to detect language through Accept-Language header (#2324)
Detect language through Accept-Language header
3 years ago
syeopite d984a898d4
Remove usage of haltf in /api/v1/channels/:ucid/comments 3 years ago
syeopite 52688106e4
Fix /api/v1/search/suggestions route link 3 years ago
syeopite 66b45a8fe2
Bountiful changes
- Use haltf in more locations
 - Fix wrong URL params
 - Rename API modules
 - Remove API routing file and move everything to general iv routing
   file
3 years ago
Émilien Devos b5d2eb5c70
fetch with innertube api when video is unavailable (#2329)
+ rename some client type to better names
+ fix thirdParty hack
3 years ago
syeopite 25362f16a0
Readd paid attribute for videos (#2330) 3 years ago
syeopite 39b34eece8
Extract API routes from invidious.cr (3/3)
- Auth (excluding notifications*) APIs
- Mixes

*Notifications currently require the "connection_channel" channel
for talking with the notifications job. Unfortunately, we cannot
access that within the route modules yet.
3 years ago
syeopite b3426fdc94
Restructure API routes to use more namespaces 3 years ago
syeopite 6aa65593ef
Extract API routes from invidious.cr (2/?)
- Video playback endpoints
- Search feed api
- Video info api
3 years ago
syeopite 66becbf46f
Restructure API route organisation 3 years ago
syeopite cbf3d75087
Extract API routes from invidious.cr (1/?) 3 years ago
syeopite 0b0036813f
Remove deprecated APIs
- insights
- top feed
3 years ago
Émilien Devos c06a20e085
Switch to innertube API for videos (#2220)
Commit history:
- Switch to innertube API for videos
- fix hardcoded strings + fix bypass geo-restriction
3 years ago
Émilien Devos 12b46bbd41
switch to innertube API for about channels (#2255) 3 years ago
syeopite cea38de4ad
Check for existance of "adaptiveFormats" in videos
Combined from commits:
- Check for existance of "adaptiveFormats" in videos
- Remove usage of ternary conditional
3 years ago
Emilien Devos 6745ca7775 fix comments using dig 3 years ago
Émilien Devos 88c5e3b6fa
Use the new youtube api for comments (#2217)
* use the new youtube api for comments
* remove PG_DB & action parameter + allow force region
* support new comments data with onResponseReceivedEndpoints
3 years ago
syeopite 7afa027b95
Switch routing logic to use modules (#2298)
* Switch routing logic to use modules
* Add more macros for adding routes of different HTTP methods
3 years ago
TheFrenchGhosty 9b74cf3225
Typo 3 years ago
syeopite 1321c90920
Extract channel routes (#2227)
* Extract primary channel routes from invidious.cr

Also removes timedtext_video stub since all it does is redirect to the
homepage. However, Invidious's 404 handler already does this.

--
As the template for the channel about page doesn't exist yet, the
behavior for the /channel/:ucid/about endpoint has been changed to be
the same as what's currently present on Invidious

(cherry picked from commit 8fad19d805)

* Manually extract brand_redirect from 1b569bbc99

This commit manually extracts the brand_redirect function from the
commit mentioned.

However, the redirect to the  `.../about` endpoint is removed due to the
fact that it doesn't exist yet.

This commit is also mainly just a bridge for the next few cherry picks from
\#2215

* Update brand_redirect to use youtubei resolve_url

(cherry picked from commit 53335fe7cf)

* Add additional channel endpoints to brand_redirect

(cherry picked from commit 8fc6f3add6)

* Add separate handler for /profile endpoint

* Add /channel/:ucid/home route

* Document all channel brand_urls
3 years ago
Samantaz Fox 4b46313e19
Fix crystal overrides (#2295)
* Move Crystal stdlib classes overrides to a separate file
* Document known crystal overrides
* Update crystal overrides for HTTP::Client socket
* Update shard.yml to restrict crystal versions
* Fix compilation error in Crystal 1.1.x (See
   https://github.com/crystal-lang/crystal/issues/10965
   for more details about this issue).
3 years ago
syeopite e9add69e26
Fix #resolve_url by adding ClientConfig argument
The private `_post_json` method of the YoutubeAPI requires a ClientConfig
as the third parameter. This was passed in all Youtube API methods except the
`#resolve_url` method.
3 years ago
Samantaz Fox 5b020e81ca
Youtube api improvements (#2277)
* Put youtube API functions under the YoutubeAPI namespace

* Implement the following endpoints:
  - `next`
  - `player`
  - `resolve_url`

* Allow a ClientConfig to be passed to YoutubeAPI endpoint handlers.

* Add constants for many new clients

* Fix documentation of YoutubeAPI.browse(): Comments and search
  result aren't returned by the browse() endpoint but by the next()
  and search() endpoints, respectively.

* Accept gzip compressed data, to help save on bandwidth

* Add debug/trace logging

* Other minor fixes
3 years ago
Samantaz Fox 84594b0e1e
Remove workaround for decompression of proxied files (#2286)
Was used by `proxy_file` before crystal 0.35.0.
Implemented in: f7dbf2bdd4
orphaned since: d30a972a90
3 years ago
syeopite 578bbcd181
Fix raw parameter for videos in listen mode (#2270) 3 years ago
Samantaz Fox bc937a6434
Add Korean (ko.json) to loaded locales
Required because of c83113d49b.
3 years ago
syeopite 095c894548
Merge pull request #2201 from pinchese/patch-1
futureproof comment avatars
4 years ago
Samantaz Fox 56ebef4352
Multiple front-end fixes (#2247)
Fixes:
* Sanitize user-provided content in HTML (Fixes #2193)
* Fix encoding of search query in prev/next pages (Fixes #2229)
* Fix some issues introduced with #2196:
   - Fix alignment of all <h3> elements (Move the inline style from the parent to the <h3> element)
   - Add missing comma on 'dir' HTML attribute (Typo introduced by PR #2196)

Code cleaning:
* Remove unnecessary 'each_sclice' + 'each' double loop in ECR files
* Clean the player's <source> list generation code (in player.ecr)
4 years ago
syeopite 3e5c353298
Merge pull request #2205 from syeopite/fix-age-restricted-videos
Partial (and temporary) fix for age restricted videos
4 years ago
Émilien Devos 0d57a887ea
Mute unbuffered_flush IOError exception (#2235)
Related to #1416, it doesn't really fix the real error, but instead mutes the exception message.

Like explained in #1416, this "exception Error" while flushing the client data doesn't harm the client-server connection. However, this exception message continuously spams the logs and makes debugging and error finding really difficult.
4 years ago
syeopite ae61662f61
Debloat channels.cr into multiple files (#2225)
Cherry picked from ui overhaul branch with a few modifications:
  - channel folder is renamed to channels
  - parsing for channel home and featured channels are removed due to
    lack of infrastructure from other commits

(cherry picked from commit 44d18b8e14)
4 years ago
Samantaz Fox c0e8feb66e
Add new and missing locales to i18n.cr
New locales: lt, vi
Missing: bn_BD, cs, da, eu, hu-HU, si, sk, sr, sr_Cyrl
4 years ago
syeopite 39110ad21c
Use struct for caption object 4 years ago
syeopite 57bb8c610a
Use embed stream pull as fallback for gated videos 4 years ago
Émilien Devos cf619f24a9
Remove workaround for kemalcr/kemal/issues/575 (#2230)
Full URL of the issue: https://github.com/kemalcr/kemal/issues/575
4 years ago
Samantaz Fox 67a18dcff6
Merge pull request #2196 from ahangarha/patch-1
Add bi-directional text support
4 years ago
syeopite 54b19a04bb
Fix caption parsing on age restricted videos 4 years ago
syeopite ca4df29670
Wrap comment 4 years ago
syeopite 7da0b2fd7f
Switch from URI::Params.new to URI::Params.encode 4 years ago
Samantaz Fox cfcb64c516
Fix layout of video 'card' items
Previous changes broke alignment of text and icons
4 years ago
Samantaz Fox 135ae11c20
Merge pull request #2195 from B0pol/trending
Use youtubei API for trending
4 years ago
Émilien Devos ce68d09d26
Pick a random video for bypass captcha
pick a random video from the 1000 first rows of the channel_videos table
in order to bypass the captcha more efficiently
4 years ago
syeopite aa55e67389
Fix extraction of age restricted videos 4 years ago
Penny f7992d2d09
futureproof comment avatars
i was injecting custom css into the site that made the avatars round, and noticed comment avatars looked a little odd

i opened dev tools and siffed through the html, and noticed that the image was being padded,
when it would look nicer if the element used margin instead of padding

with padding:
https://imgur.com/c0pB37e

with proposed changes (margin instead of padding):
https://imgur.com/iKmBzEi
4 years ago
Samantaz Fox eecfc155b8
Right-align the RSS icon in channel playlists 4 years ago
Samantaz Fox 9cef7945c0
Fix RTL text in video titles on Firefox
The behavior was as follow: on Right-To-Left text (e.g Arabic) that is wrapped
(because it's too long to fit on one line), the second row and following rows
may or may not be right aligned (as RTL text should be). Opening the devtools
fixes that alignement, as consistently as closing the devtool breaks it.

This problem seems to arrive only in the following configurations (link nested
in a paragraph, both of which may or may not have the dir= attribute):

* `<p><a href="some_link">RTL_TEXT</a></p>`
* `<p><a href="some_link" dir="auto">RTL_TEXT</a></p>`
* `<p dir="auto"><a href="some_link">RTL_TEXT</a></p>`

with the following CSS:

```
p {
	unicode-bidi: plaintext;
	text-align: start;
}
```

Changing the HTML to the following configuration (a paragraph with the dir=
attribute, nested in a link) seems to fix it:

`<a href="some_link"><p dir="auto">RTL_TEXT</p></a>`
4 years ago
Mostafa Ahangarha 1b1932f787 fix feed alignment on community view 4 years ago
Samantaz Fox 9e4fd193c6 Limit descriptions width to ease mixed LTR/RTL text reading
This will prevent, on large pages, the LTR and RTL text to be
far away, on each side of the page. This could happen on channel
and playlists descriptions, when the page is displayed on a large
screen.
4 years ago
Mostafa Ahangarha d16a748f37 set alignment for feed link 4 years ago
Cadence Ember 7ec93825b6 Change description-box from flex to block
I also make minor changes to the surroundings so that the same layout
and functionality as before is preserved.
4 years ago
bopol 50267a6dd6 Use youtubei API for trending 4 years ago
Samantaz Fox 5a8825d016
Fix quoting of 'none' in CSP header
The keyword 'none' must be surrounded by single quotes.
Regression introduced by #2168.
4 years ago
Émilien Devos 4803285e50
update video URL for recaptcha detection 4 years ago
syeopite 349f073b8e
Remove unnecessary "Welcome, " on username display 4 years ago
Mateusz Makowski 90c907710c
Display username in header 4 years ago
syeopite cb525af0a2
Connect to api.invidious.io with https 4 years ago
syeopite 09f7e38eed
Disable automatic instance redirection by default 4 years ago
syeopite 7c49a0ba7a
Rephrase auto instance redirect preference 4 years ago
syeopite 45e57f1ad3
Refactor fetch_random_instance 4 years ago
syeopite eb911de928
Handle if inst. api is down for rand inst fetch 4 years ago
syeopite b393e31b76
Fix inst. fetching for inst w/ disabled stats/err 4 years ago
syeopite 4a095eb98e
Fix <hr> styling on empty search page 4 years ago
syeopite d793d4ba78
Add switch invidious instance btn to all chan tabs 4 years ago
syeopite 2f54ec4e18
Fix locale consistency for err template redirects 4 years ago