|Jesús 9564ee30fe update gevent and update greenlet||4 months ago|
|docs||1 year ago|
|tests||2 years ago|
|youtube||5 months ago|
|.build.yml||2 years ago|
|.drone.yml||1 year ago|
|.editorconfig||1 year ago|
|.gitattributes||4 years ago|
|.gitignore||1 year ago|
|LICENSE||4 years ago|
|README.md||5 months ago|
|generate_release.py||1 year ago|
|pytest.ini||2 years ago|
|requirements-dev.txt||4 months ago|
|requirements.txt||4 months ago|
|run.bat||3 years ago|
|server.py||1 year ago|
|settings.py||5 months ago|
Fork of youtube-local
yt-local is a browser-based client written in Python for watching YouTube anonymously and without the lag of the slow page used by YouTube. One of the primary features is that all requests are routed through Tor, except for the video file at googlevideo.com. This is analogous to what HookTube (defunct) and Invidious do, except that you do not have to trust a third-party to respect your privacy. The assumption here is that Google won't put the effort in to incorporate the video file requests into their tracking, as it's not worth pursuing the incredibly small number of users who care about privacy (Tor video routing is also provided as an option). Tor has high latency, so this will not be as fast network-wise as regular YouTube. However, using Tor is optional; when not routing through Tor, video pages may load faster than they do with YouTube's page depending on your browser.
The YouTube API is not used, so no keys or anything are needed. It uses the same requests as the YouTube webpage.
Download the zip file under the Releases page. Unzip it anywhere you choose.
Download the tarball under the Releases page and extract it.
cd into the directory and run
virtualenv -p python3 venv
pip install -r requirements.txt
Note: If pip isn't installed, first try installing it from your package manager. Make sure you install pip for python 3. For example, the package you need on debian is python3-pip rather than python-pip. If your package manager doesn't provide it, try to install it according to this answer, but make sure you run
python3 get-pip.py instead of
Firstly, if you wish to run this in portable mode, create the empty file "settings.txt" in the program's main directory. If the file is there, settings and data will be stored in the same directory as the program. Otherwise, settings and data will be stored in
C:\Users\[your username]\.yt-local on Windows and
~/.yt-local on GNU+Linux/MacOS.
To run the program on windows, open
run.bat. On GNU+Linux/MacOS, run
Access youtube URLs by prefixing them with
You can use an addon such as Redirector (Firefox|Chrome) to automatically redirect YouTube URLs to yt-local. I use the include pattern
^(https?://(?:[a-zA-Z0-9_-]*\.)?(?:youtube\.com|youtu\.be|youtube-nocookie\.com)/.*) and redirect pattern
http://localhost:9010/$1 (Make sure you're using regular expression mode).
If you want embeds on web to also redirect to yt-local, make sure "Iframes" is checked under advanced options in your redirector rule. Check test
yt-local can be added as a search engine in firefox to make searching more convenient. See here for information on firefox search plugins.
In the settings page, set "Route Tor" to "On, except video" (the second option). Be sure to save the settings.
Ensure Tor is listening for Socks5 connections on port 9150. A simple way to accomplish this is by opening the Tor Browser Bundle and leaving it open. However, you will not be accessing the program (at https://localhost:8080) through the Tor Browser. You will use your regular browser for that. Rather, this is just a quick way to give the program access to Tor routing.
If you don't want to waste system resources leaving the Tor Browser open in addition to your regular browser, you can configure standalone Tor to run instead using the following instructions.
For Windows, to make standalone Tor run at startup, press Windows Key + R and type
shell:startup to open the Startup folder. Create a new shortcut there. For the command of the shortcut, enter
"C:\[path-to-Tor-Browser-directory]\Tor\tor.exe" SOCKSPort 9150 ControlPort 9151. You can then launch this shortcut to start it. Alternatively, if something isn't working, to see what's wrong, open
cmd.exe and go to the directory
C:\[path-to-Tor-Browser-directory]\Tor. Then run
tor SOCKSPort 9150 ControlPort 9151 | more. The
more part at the end is just to make sure any errors are displayed, to fix a bug in Windows cmd where tor doesn't display any output. You can stop tor in the task manager.
For Debian/Ubuntu, you can
sudo apt install tor to install the command line version of Tor, and then run
sudo systemctl start tor to run it as a background service that will get started during boot as well. However, Tor on the command line uses the port
9050 by default (rather than the 9150 used by the Tor Browser). So you will need to change
Tor port to 9050 and
Tor control port to
9051 in yt-local settings page. Additionally, you will need to enable the Tor control port by uncommenting the line
ControlPort 9051, and setting
CookieAuthentication to 0 in
/etc/tor/torrc. If no Tor package is available for your distro, you can configure the
tor binary located at
./Browser/TorBrowser/Tor/tor inside the Tor Browser installation location to run at start time, or create a service to do it.
If you wish to route the video through Tor, set "Route Tor" to "On, including video". Because this is bandwidth-intensive, you are strongly encouraged to donate to the consortium of Tor node operators. For instance, donations to NoiseTor go straight towards funding nodes. Using their numbers for bandwidth costs, together with an average of 485 kbit/sec for a diverse sample of videos, and assuming n hours of video watched per day, gives $0.03n/month. A $1/month donation will be a very generous amount to not only offset losses, but help keep the network healthy.
YouTube and YouTube Music/subscriptions/subscriptions.csv
Supported subscriptions import formats:
Pull requests and issues are welcome
For coding guidelines and an overview of the software architecture, see the HACKING.md file.
yt-local is not made to work in public mode, however there is an instance of yt-local in public mode but with less features
This project is licensed under the GNU Affero General Public License v3 (GNU AGPLv3) or any later version.
Permission is hereby granted to the youtube-dl project at https://github.com/ytdl-org/youtube-dl to relicense any portion of this software under the Unlicense, public domain, or whichever license is in use by youtube-dl at the time of relicensing, for the purpose of inclusion of said portion into youtube-dl. Relicensing permission is not granted for any purpose outside of direct inclusion into the official repository of youtube-dl. If inclusion happens during the process of a pull-request, relicensing happens at the moment the pull request is merged into youtube-dl; until that moment, any cloned repositories of youtube-dl which make use of this software are subject to the terms of the GNU AGPLv3.
This project is completely free/Libre and will always be.