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 MPV.
  • Choose playback quality and speed, including speeds up to 4x.
  • Choose streaming or fetch playback per quality/speed option; fetch 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 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 and temporary fetch 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.9.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.9.3-py3-none-any.whl (2.4 MB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: gtktube-1.9.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.9.3.tar.gz
Algorithm Hash digest
SHA256 d6d9f4002f9277b52d8602c890eec76ec52b68d5c817616ef358e3d0bfd69a6e
MD5 2ff560e30802a3fd4ef43a99a051f958
BLAKE2b-256 fa7f8679e740cc09297e5a304f4689b40bd04d7df74a4c7fb3d1160d33c8b2a7

See more details on using hashes here.

Provenance

The following attestation bundles were made for gtktube-1.9.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.9.3-py3-none-any.whl.

File metadata

  • Download URL: gtktube-1.9.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.9.3-py3-none-any.whl
Algorithm Hash digest
SHA256 7352af123f2fcbec90b662bb81009aba759e425ca0aaaa8e1c030359e469fd77
MD5 a129e92508912163bed0681a026a5099
BLAKE2b-256 8bab07d8ec789b154e900a26461108d108392a325e2292d5f3c5f926d87c62d8

See more details on using hashes here.

Provenance

The following attestation bundles were made for gtktube-1.9.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