2017-11-29 16:12:23 -08:00
# Invidious
2017-11-22 23:48:55 -08:00
2020-10-23 15:03:08 -07:00
[![Build Status ](https://travis-ci.org/iv-org/invidious.svg?branch=master )](https://travis-ci.org/github/iv-org/invidious) [![Translation Status ](https://hosted.weblate.org/widgets/invidious/-/translations/svg-badge.svg )](https://hosted.weblate.org/engage/invidious/)
2019-08-04 07:10:32 -07:00
2018-09-04 07:22:10 -07:00
## Invidious is an alternative front-end to YouTube
2017-11-22 23:48:55 -08:00
2020-10-10 06:32:54 -07:00
## Invidious instances:
2020-10-10 05:52:41 -07:00
[Public Invidious instances are listed here. ](https://github.com/iv-org/invidious/wiki/Invidious-Instances )
2020-10-10 06:32:54 -07:00
## Invidious features:
2020-10-10 05:52:41 -07:00
2020-07-22 10:04:27 -07:00
- [Copylefted libre software ](https://github.com/iv-org/invidious ) (AGPLv3+ licensed)
2018-11-19 12:44:24 -08:00
- Audio-only mode (and no need to keep window open on mobile)
2020-07-13 01:34:22 -07:00
- Lightweight (the homepage is ~4 KB compressed)
2018-09-03 19:42:49 -07:00
- Tools for managing subscriptions:
- Only show unseen videos
- Only show latest (or latest unseen) video from each channel
- Delivers notifications from all subscribed channels
- Automatically redirect homepage to feed
- Import subscriptions from YouTube
- Dark mode
- Embed support
- Set default player options (speed, quality, autoplay, loop)
2020-07-13 01:34:22 -07:00
- Support for Reddit comments in place of YouTube comments
2018-10-31 07:42:29 -07:00
- Import/Export subscriptions, watch history, preferences
2020-07-22 10:04:27 -07:00
- [Developer API ](https://github.com/iv-org/invidious/wiki/API )
2020-07-13 01:34:22 -07:00
- Does not use any of the official YouTube APIs
- Does not require JavaScript to play videos
- No need to create a Google account to save subscriptions
- No ads
- No CoC
- No CLA
2020-10-23 15:03:08 -07:00
- [Multilingual ](https://hosted.weblate.org/projects/invidious/#languages ) (translated into many languages)
2018-09-03 19:42:49 -07:00
2020-10-10 06:32:54 -07:00
## Screenshots:
2019-02-16 07:51:09 -08:00
| Player | Preferences | Subscriptions |
| ----------------------------------------------------------------------------------------------------------------------- | ----------------------------------------------------------------------------------------------------------------------- | --------------------------------------------------------------------------------------------------------------------------- |
| [<img src="screenshots/01_player.png?raw=true" height="140" width="280"> ](screenshots/01_player.png?raw=true ) | [<img src="screenshots/02_preferences.png?raw=true" height="140" width="280"> ](screenshots/02_preferences.png?raw=true ) | [<img src="screenshots/03_subscriptions.png?raw=true" height="140" width="280"> ](screenshots/03_subscriptions.png?raw=true ) |
| [<img src="screenshots/04_description.png?raw=true" height="140" width="280"> ](screenshots/04_description.png?raw=true ) | [<img src="screenshots/05_preferences.png?raw=true" height="140" width="280"> ](screenshots/05_preferences.png?raw=true ) | [<img src="screenshots/06_subscriptions.png?raw=true" height="140" width="280"> ](screenshots/06_subscriptions.png?raw=true ) |
2020-10-10 06:32:54 -07:00
## Installation:
2017-11-22 23:48:55 -08:00
2020-10-10 05:52:41 -07:00
To manually compile invidious you need at least 2GB of RAM. If you have less you can setup SWAP to have a combined amount of 2 GB or use Docker instead.
2020-10-10 06:32:54 -07:00
After installation take a look at the [Post-install steps ](#post-install-configuration ).
2020-10-10 05:52:41 -07:00
2020-10-10 06:32:54 -07:00
### Automated installation:
2020-10-10 05:52:41 -07:00
2020-07-13 01:34:22 -07:00
[Invidious-Updater ](https://github.com/tmiland/Invidious-Updater ) is a self-contained script that can automatically install and update Invidious.
2019-02-11 08:20:55 -08:00
2018-09-29 08:10:41 -07:00
### Docker:
#### Build and start cluster:
```bash
$ docker-compose up
```
2020-07-13 01:34:22 -07:00
Then visit `localhost:3000` in your browser.
2018-09-29 08:10:41 -07:00
#### Rebuild cluster:
```bash
$ docker-compose build
```
#### Delete data and rebuild:
```bash
$ docker volume rm invidious_postgresdata
$ docker-compose build
```
2020-10-10 06:32:54 -07:00
### Manual installation:
2020-06-05 19:12:43 -07:00
2020-10-10 05:52:41 -07:00
### Linux:
2019-01-23 12:12:02 -08:00
2020-07-13 01:34:22 -07:00
#### Install the dependencies
2018-03-09 08:48:01 -08:00
2018-01-28 18:31:35 -08:00
```bash
2019-01-23 12:12:02 -08:00
# Arch Linux
2020-01-08 18:00:08 -08:00
$ sudo pacman -S base-devel shards crystal librsvg postgresql
2018-10-31 07:42:29 -07:00
2019-01-23 12:12:02 -08:00
# Ubuntu or Debian
2020-07-13 04:22:01 -07:00
# First you have to add the repository to your APT configuration. For easy setup just run in your command line:
2019-01-23 12:12:02 -08:00
$ curl -sSL https://dist.crystal-lang.org/apt/setup.sh | sudo bash
2019-02-03 03:57:01 -08:00
# That will add the signing key and the repository configuration. If you prefer to do it manually, execute the following commands:
$ curl -sL "https://keybase.io/crystal/pgp_keys.asc" | sudo apt-key add -
$ echo "deb https://dist.crystal-lang.org/apt crystal main" | sudo tee /etc/apt/sources.list.d/crystal.list
$ sudo apt-get update
2020-09-27 12:17:52 -07:00
$ sudo apt install crystal libssl-dev libxml2-dev libyaml-dev libgmp-dev libreadline-dev postgresql librsvg2-bin libsqlite3-dev zlib1g-dev
2019-01-23 12:12:02 -08:00
```
2018-10-31 07:42:29 -07:00
2020-07-13 01:34:22 -07:00
#### Add an Invidious user and clone the repository
2019-01-23 12:12:02 -08:00
```bash
$ useradd -m invidious
$ sudo -i -u invidious
2020-07-22 10:04:27 -07:00
$ git clone https://github.com/iv-org/invidious
2019-01-23 12:12:02 -08:00
$ exit
2018-01-28 18:31:35 -08:00
```
2020-07-13 01:34:22 -07:00
#### Set up PostgresSQL
2018-03-09 08:48:01 -08:00
2018-01-28 18:31:35 -08:00
```bash
2018-10-31 07:42:29 -07:00
$ sudo systemctl enable postgresql
$ sudo systemctl start postgresql
$ sudo -i -u postgres
2019-04-06 05:38:33 -07:00
$ psql -c "CREATE USER kemal WITH PASSWORD 'kemal';" # Change 'kemal' here to a stronger password, and update `password` in config/config.yml
2019-01-23 12:12:02 -08:00
$ createdb -O kemal invidious
2019-04-15 09:13:09 -07:00
$ psql invidious kemal < /home/invidious/invidious/config/sql/channels.sql
$ psql invidious kemal < /home/invidious/invidious/config/sql/videos.sql
$ psql invidious kemal < /home/invidious/invidious/config/sql/channel_videos.sql
$ psql invidious kemal < /home/invidious/invidious/config/sql/users.sql
$ psql invidious kemal < /home/invidious/invidious/config/sql/session_ids.sql
$ psql invidious kemal < /home/invidious/invidious/config/sql/nonces.sql
$ psql invidious kemal < /home/invidious/invidious/config/sql/annotations.sql
2020-02-15 11:57:50 -08:00
$ psql invidious kemal < /home/invidious/invidious/config/sql/playlists.sql
$ psql invidious kemal < /home/invidious/invidious/config/sql/playlist_videos.sql
2018-10-31 07:42:29 -07:00
$ exit
2019-01-23 12:12:02 -08:00
```
2018-10-31 07:42:29 -07:00
2020-07-13 01:34:22 -07:00
#### Set up Invidious
2019-01-23 12:12:02 -08:00
```bash
$ sudo -i -u invidious
2018-10-31 07:42:29 -07:00
$ cd invidious
2019-02-28 11:28:02 -08:00
$ shards update & & shards install
2018-10-31 07:42:29 -07:00
$ crystal build src/invidious.cr --release
2019-01-23 12:12:02 -08:00
# test compiled binary
$ ./invidious # stop with ctrl c
$ exit
```
2020-10-10 06:32:54 -07:00
#### Systemd service:
2019-02-16 07:51:09 -08:00
2019-01-23 12:12:02 -08:00
```bash
2019-01-26 08:12:13 -08:00
$ sudo cp /home/invidious/invidious/invidious.service /etc/systemd/system/invidious.service
2019-01-23 12:12:02 -08:00
$ sudo systemctl enable invidious.service
$ sudo systemctl start invidious.service
2018-01-28 18:31:35 -08:00
```
2020-10-10 06:32:54 -07:00
#### Logrotate:
2020-03-02 07:19:07 -08:00
```bash
$ sudo echo "/home/invidious/invidious/invidious.log {
rotate 4
weekly
notifempty
missingok
compress
minsize 1048576
}" | tee /etc/logrotate.d/invidious.logrotate
$ sudo chmod 0644 /etc/logrotate.d/invidious.logrotate
```
2020-10-10 05:52:41 -07:00
### MacOS:
2018-03-09 08:48:01 -08:00
2018-01-28 18:31:35 -08:00
```bash
2018-10-31 07:42:29 -07:00
# Install dependencies
$ brew update
2019-10-28 07:46:59 -07:00
$ brew install shards crystal postgres imagemagick librsvg
2018-03-09 08:48:01 -08:00
2020-07-13 01:34:22 -07:00
# Clone the repository and set up a PostgreSQL database
2020-07-22 10:04:27 -07:00
$ git clone https://github.com/iv-org/invidious
2018-10-31 07:42:29 -07:00
$ cd invidious
2019-01-23 12:12:02 -08:00
$ brew services start postgresql
2019-04-06 05:38:33 -07:00
$ psql -c "CREATE ROLE kemal WITH PASSWORD 'kemal';" # Change 'kemal' here to a stronger password, and update `password` in config/config.yml
$ createdb -O kemal invidious
2019-04-15 09:13:09 -07:00
$ psql invidious kemal < config / sql / channels . sql
$ psql invidious kemal < config / sql / videos . sql
$ psql invidious kemal < config / sql / channel_videos . sql
$ psql invidious kemal < config / sql / users . sql
$ psql invidious kemal < config / sql / session_ids . sql
$ psql invidious kemal < config / sql / nonces . sql
$ psql invidious kemal < config / sql / annotations . sql
2020-03-01 07:30:55 -08:00
$ psql invidious kemal < config / sql / privacy . sql
$ psql invidious kemal < config / sql / playlists . sql
$ psql invidious kemal < config / sql / playlist_videos . sql
2019-01-23 12:12:02 -08:00
2020-07-13 01:34:22 -07:00
# Set up Invidious
2019-02-28 11:28:02 -08:00
$ shards update & & shards install
2018-10-31 07:42:29 -07:00
$ crystal build src/invidious.cr --release
2018-07-18 18:25:11 -07:00
```
2020-10-10 06:32:54 -07:00
## Post-install configuration:
2020-10-10 05:52:41 -07:00
2020-10-10 06:32:54 -07:00
Detailed configuration available in the [configuration guide ](https://github.com/iv-org/invidious/wiki/Configuration ).
2020-10-10 05:52:41 -07:00
2020-10-10 06:32:54 -07:00
If you use a reverse proxy, you **must** configure invidious to properly serve request through it:
2020-10-10 05:52:41 -07:00
`https_only: true` : if your are serving your instance via https, set it to true
2020-10-10 06:32:54 -07:00
`domain: domain.ext` : if you are serving your instance via a domain name, set it here
2020-10-10 05:52:41 -07:00
`external_port: 443` : if your are serving your instance via https, set it to 443
2019-01-24 10:31:56 -08:00
## Update Invidious
2019-02-16 07:51:09 -08:00
2020-07-22 10:04:27 -07:00
Instructions are available in the [updating guide ](https://github.com/iv-org/invidious/wiki/Updating ).
2019-01-24 10:31:56 -08:00
2018-01-28 18:31:35 -08:00
## Usage:
2017-11-22 23:52:37 -08:00
```bash
2018-09-29 08:10:41 -07:00
$ ./invidious -h
Usage: invidious [arguments]
-b HOST, --bind HOST Host to bind (defaults to 0.0.0.0)
-p PORT, --port PORT Port to listen for connections (defaults to 3000)
-s, --ssl Enables SSL
--ssl-key-file FILE SSL key file
--ssl-cert-file FILE SSL certificate file
-h, --help Shows this help
-c THREADS, --channel-threads=THREADS
Number of threads for refreshing channels (default: 1)
2018-10-31 07:42:29 -07:00
-f THREADS, --feed-threads=THREADS
Number of threads for refreshing feeds (default: 1)
2019-01-23 12:40:05 -08:00
-o OUTPUT, --output=OUTPUT Redirect output (default: STDOUT)
2019-04-06 06:28:53 -07:00
-v, --version Print version
2017-11-22 23:52:37 -08:00
```
2017-11-22 23:48:55 -08:00
2018-01-28 18:31:35 -08:00
Or for development:
2018-03-09 08:48:01 -08:00
2017-11-22 23:52:37 -08:00
```bash
2018-01-28 18:31:35 -08:00
$ curl -fsSLo- https://raw.githubusercontent.com/samueleaton/sentry/master/install.cr | crystal eval
$ ./sentry
2019-04-06 06:28:53 -07:00
🤖 Your SentryBot is vigilant. beep-boop...
2017-11-22 23:52:37 -08:00
```
2017-11-22 23:48:55 -08:00
2019-01-24 10:31:56 -08:00
## Documentation
2019-02-16 07:51:09 -08:00
2020-07-22 10:04:27 -07:00
[Documentation ](https://github.com/iv-org/invidious/wiki ) can be found in the wiki.
2019-01-24 10:31:56 -08:00
2018-08-02 13:18:33 -07:00
## Extensions
2019-02-16 07:51:09 -08:00
2020-07-22 10:04:27 -07:00
[Extensions ](https://github.com/iv-org/invidious/wiki/Extensions ) can be found in the wiki, as well as documentation for integrating it into other projects.
2018-08-02 13:18:33 -07:00
2018-12-04 17:22:54 -08:00
## Made with Invidious
2020-07-13 01:34:22 -07:00
- [FreeTube ](https://github.com/FreeTubeApp/FreeTube ): A libre software YouTube app for privacy.
- [CloudTube ](https://cadence.moe/cloudtube/subscriptions ): A JavaScript-rich alternate YouTube player
2020-06-16 16:05:17 -07:00
- [PeerTubeify ](https://gitlab.com/Cha_deL/peertubeify ): On YouTube, displays a link to the same video on PeerTube, if it exists.
2020-07-13 01:34:22 -07:00
- [MusicPiped ](https://github.com/deep-gaurav/MusicPiped ): A material design music player that streams music from YouTube.
- [LapisTube ](https://github.com/blubbll/lapis-tube ): A fancy and advanced (experimental) YouTube front-end. Combined streams & custom YT features.
2020-08-15 07:27:47 -07:00
- [HoloPlay ](https://github.com/stephane-r/HoloPlay ): Funny Android application connecting on Invidious API's with search, playlists and favoris.
2018-12-04 17:22:54 -08:00
2017-11-22 23:48:55 -08:00
## Contributing
2020-07-22 10:04:27 -07:00
1. Fork it ( https://github.com/iv-org/invidious/fork )
2018-03-09 08:48:01 -08:00
2. Create your feature branch (git checkout -b my-new-feature)
3. Commit your changes (git commit -am 'Add some feature')
4. Push to the branch (git push origin my-new-feature)
2020-07-13 01:34:22 -07:00
5. Create a new pull request
2019-01-21 09:35:10 -08:00
2020-07-13 01:34:22 -07:00
#### Translation
2019-01-21 09:35:10 -08:00
2020-10-23 15:03:08 -07:00
- Log in with an account you have elsewhere, or register an account and start translating at [Hosted Weblate ](https://hosted.weblate.org/engage/invidious/ ).
2019-01-21 09:35:10 -08:00
2020-10-10 06:32:54 -07:00
## Donate:
Liberapay: https://liberapay.com/iv-org/
2019-01-21 09:35:10 -08:00
2020-10-10 06:32:54 -07:00
## Contact
2017-11-22 23:48:55 -08:00
2020-10-10 09:00:33 -07:00
Feel free to join our [Matrix room ](https://matrix.to/#/#invidious:matrix.org ), or #invidious on freenode. Both platforms are bridged together.
2020-10-23 15:02:34 -07:00
## Liability
We take no responsibility for the use of our tool, or external instances provided by third parties. We strongly recommend you abide by the valid official regulations in your country. Furthermore, we refuse liability for any inappropriate use of Invidious, such as illegal downloading. This tool is provided to you in the spirit of free, open software.
You may view the LICENSE in which this software is provided to you [here ](./LICENSE ).
> 16. Limitation of Liability.
>
> IN NO EVENT UNLESS REQUIRED BY APPLICABLE LAW OR AGREED TO IN WRITING
WILL ANY COPYRIGHT HOLDER, OR ANY OTHER PARTY WHO MODIFIES AND/OR CONVEYS
THE PROGRAM AS PERMITTED ABOVE, BE LIABLE TO YOU FOR DAMAGES, INCLUDING ANY
GENERAL, SPECIAL, INCIDENTAL OR CONSEQUENTIAL DAMAGES ARISING OUT OF THE
USE OR INABILITY TO USE THE PROGRAM (INCLUDING BUT NOT LIMITED TO LOSS OF
DATA OR DATA BEING RENDERED INACCURATE OR LOSSES SUSTAINED BY YOU OR THIRD
PARTIES OR A FAILURE OF THE PROGRAM TO OPERATE WITH ANY OTHER PROGRAMS),
EVEN IF SUCH HOLDER OR OTHER PARTY HAS BEEN ADVISED OF THE POSSIBILITY OF
SUCH DAMAGES.