Invidious fork with features exclusive to inv.nadeko.net https://inv.nadeko.net
Find a file
Fijxu fd8c40e0da
fix: fix wrong invidious companion logic on backends
do not change to another companion if request fails
2025-04-03 03:12:36 -03:00
.forgejo/workflows ci: update CI file 2025-02-18 02:40:30 -03:00
.github CI: Drop support for versions prior to 1.12 and add 1.15.0 (#5148) 2025-01-22 11:28:38 -08:00
assets Merge remote-tracking branch 'upstream/master' 2025-02-27 02:02:47 -03:00
config Add invidious companion support (#4985) 2025-03-13 16:44:00 +01:00
docker ci: update crystal compiler to 1.15.1 2025-02-18 02:43:34 -03:00
kubernetes limit feeds and delete materialized views 2024-07-21 13:00:26 -04:00
locales feat: add option to change username 2025-03-08 02:47:42 -03:00
mocks@b55d58dea9 update submodule 2024-10-13 23:57:29 +02:00
screenshots Rework the README (#2135) 2021-07-24 20:48:30 +02:00
scripts Deps: Use the right source path when copying .min.css files 2023-01-21 19:52:14 +01:00
spec update the mocks with the latest updated data 2024-10-13 21:18:21 +02:00
src fix: fix wrong invidious companion logic on backends 2025-04-03 03:12:36 -03:00
.ameba.yml Ameba: Disable Style/RedundantNext rule 2024-08-28 23:49:10 -07:00
.editorconfig Initial commit 2017-11-23 01:48:55 -06:00
.gitattributes Only ignore the videojs libraries 2021-05-23 17:59:02 +00:00
.gitignore Add the docs/ folder to gitignore (#3694) 2023-03-19 20:03:15 +01:00
.gitmodules Add mocks as a submodule 2022-06-08 23:56:40 +02:00
CHANGELOG.md Add changelog for v2.20250314.0 (#5197) 2025-03-12 03:31:15 -07:00
CHANGELOG_legacy.md Rename legacy changelog file 2024-04-27 00:14:46 +02:00
crystal_formatters.py Tokens: Server side generated tokens. 2024-10-17 23:44:30 -03:00
docker-compose.yml Use Docker Valkey instead of passing a socket 2024-07-21 13:00:27 -04:00
invidious.service Add logfile to systemd service and fix path 2019-01-23 21:31:52 +01:00
LICENSE Change license 2018-01-28 11:32:40 -06:00
Makefile Merge remote-tracking branch 'upstream/master' into master 2024-10-31 20:25:33 -03:00
nginx.conf docker-compose.yml for my instances 2024-07-21 13:00:26 -04:00
README.md update readme 2025-03-01 03:11:11 -03:00
shard.lock Update Kemal to 1.6.0 and remove Kilt 2025-02-28 20:04:42 -03:00
shard.yml Merge remote-tracking branch 'upstream/master' 2025-03-28 21:46:32 -03:00
TRANSLATION TRANSLATION file for l10n 2020-05-26 18:02:21 +00:00
videojs-dependencies.yml Bump videojs to 7.12.1 (#3011) 2022-04-22 22:37:45 +02:00

nadeko.net Invidious fork

This is a fork of Invidious with features that I have done for my own instance. If you want to maintain an instance, feel free to use this fork and it's container images (they are also compatible with Podman, not just docker!)

https://git.nadeko.net/Fijxu/-/packages/container/invidious/latest

Caution

If you already have an Invidious instance running the upstream code, moving it to this fork will not work for you! This is due to the "Removal of materialized views on PostgreSQL" pull request that requires a migration of the database using it.

If you don't have an instance already, you can use this fork safely, but you will not be able to switch to upstream Invidious.

Features and changes of this fork:

  • Use a Redis compatible DB for video cache instead of just PostgreSQL: Invidious by default caches the video information for some hours in PostgreSQL. Since the data is accessed a lot, it is better off using an in memory database instead, it's faster and it will not wear out your SSD (due to constant writes to the database).

    It can be set using this on config.yml:

    redis_url: tcp://127.0.0.1:6379
    
  • Ability to use different video caching backends: If you want, you can the PostgreSQL video cache the Redis one or the built-in in memory one that uses the LRU algorithm. Redis and LRU are recommended for public instances, but since Invidious has memory leaks, the LRU cache is lost if Invidious crashes or it's restarted, so because of this, redis is the default option.

    video_cache:
    enabled: true
    backend: 1 # 0 is PSQL, 1 Redis, 2 Built-in LRU
    lru_max_size: 18000 # ~500MB (ignored if backend is 0 or 1)
    

    If you choose to use Redis, make sure to set the redis_url config property:

    redis_url: tcp://127.0.0.1:6379
    
  • Removal of materialized views on PostgreSQL: If you don't have this on your Invidious public instance, your SSD will suffer and it will catch on fire https://github.com/iv-org/invidious/pull/2469#issuecomment-2012623454

  • External video playback proxy: Let's you use an external video playback proxy like https://git.nadeko.net/Fijxu/http3-ytproxy or https://github.com/TeamPiped/piped-proxy instead of the one that is bundled with Invidious. It's useful if you are proxying video and your throughput is not low. I did this to distribute the traffic across different servers. If you are selfhosting only for a few amount of people, this is not really useful for you.

    It can be set using this on config.yml:

    external_videoplayback_proxy: "https://inv-proxy.example.com"
    

    Note

    If you setup this, Invidious will check if the proxy is alive doing a request to https://inv-proxy.example.com/health, and if it doesn't get a response code of 200, Invidious will fallback to the local videoplayback proxy! This is only currently supported by https://git.nadeko.net/Fijxu/http3-ytproxy

  • Limit the DASH resolution sent to the clients: It can be set using max_dash_resolution on the config. Example: max_dash_resolution: 1080

  • Limit requests made to Youtube API when pulling subscriptions (feeds): Due to the recent changes of Youtube ("This helps protect out community", "Sign in to confirm you are not a bot"), subscriptions now have limited information, this is because Invidious by default, makes a video request to youtube to be able to get more information about the video, like length_seconds, live_now, premiere_timestamp, and views. If you have a lot of users with a ton of subscriptions, Invidious will basically spam youtube API all the time, resulting in a block from youtube.

    It can be set using this on config.yml:

    use_innertube_for_feeds: false
    
  • Autoreload configuration: If you are hosting Invidious on Linux without docker, this may be useful for you if you want to change the banner without restarting Invidious.

    reload_config_automatically: true
    

Development features

  • Option to disable CSP: Useful for local development, set csp: false on the config and done

There is more things that I added to this fork, but those are the most important ones. I also regularly merge unmerged pull requests from https://github.com/iv-org/invidious and random fixes as well. Is not the most stable codebase, but you can't really make something stable when youtube is trying to destroy every third party client out there.