Skip to main content

Local privacy-first Python/GTK4 YouTube player

Project description

GTKTube

GTKTube icon

GTKTube is a local privacy-first Python/GTK4 YouTube player for Linux. It stores subscriptions and viewing history locally in SQLite, and does not require a Google account. The feed has no algorithm. It just shows recent videos from the channels you subscribe to.

Features

  • Browse recent videos from your subscribed channels without YouTube recommendations.
  • Watch without ads.
  • No tracking by GTKTube.
  • Search YouTube for videos and channels without signing in.
  • Personalized home feed with recommended videos (requires browser cookies).
  • Subscribe and unsubscribe locally; no Google account or OAuth required.
  • Optionally import your YouTube subscriptions one time from browser cookies.
  • Play videos inside the GTK app with libmpv.
  • Choose playback quality and speed, including speeds up to 4x.
  • Choose streaming or prefetch playback per quality/speed option; prefetch downloads the selected stream to a temporary app cache before playback to avoid throttling.
  • Use normal playback shortcuts for play/pause, seeking, fullscreen, and speed changes.
  • Keep watching while browsing with a mini-player.
  • Save videos to Watch Later.
  • Queue videos in Up Next and optionally save remaining queued videos to Watch Later when quitting.
  • Download videos into GTKTube-managed local storage and play downloaded copies automatically when available.
  • Track watch history locally, including watched time ranges rather than only a last position.
  • Search and review local watch history.
  • Optionally configure yt-dlp to extract browser cookies for age-restricted, members-only, recommendations, watch-history import, and subscription import features.
  • Optionally use SponsorBlock to show and skip community-maintained segment ranges.
  • Show video chapters, captions, SponsorBlock segments, and chapter ticks in the player.
  • Limit how many videos a single channel can put in each feed day.
  • Refresh subscriptions in parallel with per-channel progress in the sidebar, including automatic startup refreshes for channels that are due.
  • Check PyPI for updates and upgrade/restart from inside the app.
  • Store thumbnails on disk and app data in SQLite.

Screenshots

Channel Browsing

Channel grid

Player

Video player

Mini-Player

Mini-player while browsing

Install

pipx ensurepath
pipx install --system-site-packages gtktube
gtktube --install-desktop

GTKTube also needs GTK4/PyGObject, libmpv, and a JavaScript runtime for yt-dlp from your Linux distribution. If required system dependencies are missing, the app can launch a small installer helper.

On Debian/Ubuntu, install the system dependencies with:

sudo apt-get update
sudo apt-get install -y \
  python3-gi \
  python3-gi-cairo \
  gir1.2-gtk-4.0 \
  gir1.2-adw-1 \
  libmpv2 \
  python3-mpv \
  nodejs

The same package list is used by scripts/install-apt-deps.sh and the in-app dependency installer. Python dependencies, including yt-dlp, python-mpv, and SecretStorage for browser cookie extraction, are declared in pyproject.toml. requirements.txt installs that same project dependency set for source checkouts.

Run

GTKTube installs a desktop app entry, so you can launch it from your normal Linux app launcher. You can also run it from a terminal:

gtktube

When launched as the installed gtktube command, GTKTube also installs or updates its desktop launcher entry in your user application directory. If your desktop environment does not show it immediately after installation, run gtktube once from a terminal or run gtktube --install-desktop.

Useful startup flags:

  • gtktube --show-upgrade opens the upgrade dialog even when GTKTube has not detected a newer version.
  • gtktube --show-deps-installer opens the system dependency installer even when GTKTube thinks dependencies are present.
  • gtktube --db /path/to/gtktube.sqlite3 uses a specific SQLite database file.
  • gtktube --install-desktop installs the desktop launcher entry and exits.
  • gtktube -v or gtktube --verbose prints detailed playback diagnostics to stderr.

Development runs with python -m gtktube do not auto-install a desktop launcher or check PyPI for upgrades.

Developer-only modal preview flag:

  • python -m gtktube --debug-modal=open-url
  • python -m gtktube --debug-modal=import-subscriptions
  • python -m gtktube --debug-modal=sponsorblock
  • python -m gtktube --debug-modal=up-next-quit
  • python -m gtktube --debug-modal=update

Updates

When launched from an installed gtktube command, GTKTube checks PyPI for newer releases. If an update is available, the app can run the appropriate upgrade command and restart itself. Pipx installs use pipx upgrade gtktube; other installs use python3 -m pip install --upgrade gtktube.

Data Storage

GTKTube keeps its state on your machine:

  • subscriptions and watch history in SQLite
  • thumbnails, mpv cache files, and temporary prefetch playback cache under the user cache directory
  • downloaded videos under the user data directory
  • optional one-time browser-cookie reads for importing YouTube subscriptions and watch history
  • no cloud sync
  • no analytics or tracking by GTKTube

License

GTKTube is licensed under the GNU General Public License v3.0. See LICENSE.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

gtktube-1.7.3.tar.gz (1.3 MB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

gtktube-1.7.3-py3-none-any.whl (2.4 MB view details)

Uploaded Python 3

File details

Details for the file gtktube-1.7.3.tar.gz.

File metadata

  • Download URL: gtktube-1.7.3.tar.gz
  • Upload date:
  • Size: 1.3 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for gtktube-1.7.3.tar.gz
Algorithm Hash digest
SHA256 e34f94bfad0ebb6d5b74d359a8a26558bb2552838d9274f90d579bd1e1fd3430
MD5 ef5a2451ca510da95fdad1e7713d792e
BLAKE2b-256 48275e6fcd06b27674c25ef7c42720db02b78a7573e6515507c823e337a3d180

See more details on using hashes here.

Provenance

The following attestation bundles were made for gtktube-1.7.3.tar.gz:

Publisher: publish.yml on keredson/gtktube

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file gtktube-1.7.3-py3-none-any.whl.

File metadata

  • Download URL: gtktube-1.7.3-py3-none-any.whl
  • Upload date:
  • Size: 2.4 MB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for gtktube-1.7.3-py3-none-any.whl
Algorithm Hash digest
SHA256 74030d0c0c01ee970d2a0748fed04e15d4d1a0eb250dbda10a0a1c9022e9979c
MD5 b2e0d680c56277098918104041247d49
BLAKE2b-256 af0cb6cad6f9c878091a67e06a2cc995d6283027d436c698285372ac7cc02036

See more details on using hashes here.

Provenance

The following attestation bundles were made for gtktube-1.7.3-py3-none-any.whl:

Publisher: publish.yml on keredson/gtktube

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page