ganymede

Twitch VOD and Live Stream archiving platform. Includes a rendered and real-time chat for each archive.

GoGPL-3.0916542145 open issues
Created Jun 22, 2022Last commit Feb 20, 2026Last human commit Feb 20, 2026
archivearchivedchatoauth2selfhostedstreamstreamingtwitchvideovod
ganymede preview
Embed Badge
Play on Codakey
Markdown
[![Play on Codakey](https://codakey.io/badge.svg)](https://codakey.io/projects/ganymede)
HTML
<a href="https://codakey.io/projects/ganymede"><img src="https://codakey.io/badge.svg" alt="Play on Codakey" height="28" /></a>

Daily Activity

Monthly Activity

Star History

README


Logo

Ganymede

Ganymede is a Twitch VOD and Live Stream archiving platform with a real-time chat experience. Every archive includes a rendered chat for viewing outside of Ganymede. Files are saved in a friendly format allowing for use without Ganymede.


Screenshot

ganymede-readme_landing

https://github.com/user-attachments/assets/184451f1-e3ce-4329-8516-a9842648c01b

About

Ganymede allows archiving of past streams (VODs) and live streams with a real-time chat playback along with a archival-friendly rendered chat. All files are saved in a friendly way that doesn't require Ganymede to view them (see file structure). Ganymede is the successor of Ceres.

Features

  • Realtime Chat Playback
  • SSO / OAuth authentication (wiki)
  • Light/dark mode toggle.
  • 'Watched channels'
    • Allows watching channels for archiving past broadcasts and live streams. Includes advanced filtering options.
  • Twitch VOD/Livestream support.
  • Full VOD, Channel, and User management.
  • Custom post-download video FFmpeg parameters.
  • Custom chat render parameters.
  • Webhook notifications.
  • Simple file structure for long-term archival that will outlast Ganymede.
  • Recoverable queue system.
  • Playback / progress saving.
  • Playlists.

Documentation

For in-depth documentation on features visit the wiki.

API

Visit the docs folder for the API docs.

Translations

See the messages directory for available translations. If you would like to add a new translation, please create a pull request with the new translation file. The file should be named <language>.json where <language> is the language code (e.g. de.json for German). Additionally the language needs to be added to the navbar in the frontend/app/layout/Navbar.tsx file in the languages array. Use the frontend/translation-coverage.js script to see what has been translated or with the -u option to populate missing keys in translation files.

Installation

Requirements

Installation

Ganymede consists of two docker containers:

  1. Server
  2. Postgres Database

Feel free to use an existing Postgres database container if you don't want to spin new ones up.

  1. Download a copy of the docker-compose.yml file.
  2. Edit the docker-compose.yml file modifying the environment variables, see environment variables for more information.
  3. Run docker compose up -d.
  4. Visit the address and port you specified for the frontend and login with username: admin password: ganymede.
  5. Change the admin password or create a new user, grant admin permissions on that user, and delete the admin user.

Images

Images are published to ghcr.io. There are four types of tags available.

TagDescription
latestPoints to the latest release.
semver - e.g. 4.10.0The latest release in semver format.
devBuild of the 'main' branch. Use for testing new features before release.
pr-* - e.g. pr-123Build of a pull request. Gets deleted when the PR is closed.

Rootless

The API container can be run as a non root user. To do so add PUID and PGID environment variables, setting the value to your user. Read linuxserver's docs about this for more information.

Note: On startup the container will chown the config, temp, and logs directory. It will not recursively chown the /data/videos directory. Ensure the mounted /data/videos directory is readable by the set user.

Config

A configuration file is generate on initial start of Ganymede. By default the configuration is at /data/config/config.json. See the config.go file for a full list of configuration settings. Most of the settings can be configured in the Web UI by navigating to Admin > Settings.

Environment Variables

The docker-compose.yml file has comments for each environment variable. Below is a list of all environment variables and their descriptions. See the env.go file for a full list of all environment variables and their default values.

Server
ENV NameDescription
DEBUGEnable debug logging true or false.
VIDEOS_DIRPath inside the container to the videos directory. Default: /data/videos.
TEMP_DIRPath inside the container where temporary files are stored during archiving. Default: /data/temp.
LOGS_DIRPath inside the container where log files are stored. Default: /data/logs.
CONFIG_DIRPath inside the container where the config is stored. Default: /data/config.
PATH_MIGRATION_ENABLEDEnable path migration at startup. Default: true.
TZTimezone.
DB_HOSTHost of the database.
DB_PORTPort of the database.
DB_USERUsername for the database.
DB_PASSPassword for the database.
DB_NAMEName of the database.
DB_SSLWhether to use SSL. Default: disable. See DB SSL for more information.
DB_SSL_ROOT_CERTOptional Path to DB SSL root certificate. See DB SSL for more information.
TWITCH_CLIENT_IDTwitch application client ID.
TWITCH_CLIENT_SECRETTwitch application client secret.
OAUTH_ENABLEDOptional Wether OAuth is enabled true or false. Must have the other OAuth variables set if this is enabled.
OAUTH_PROVIDER_URLOptional OAuth provider URL. See https://github.com/Zibbp/ganymede/wiki/SSO---OpenID-Connect
OAUTH_CLIENT_IDOptional OAuth client ID.
OAUTH_CLIENT_SECRETOptional OAuth client secret.
OAUTH_REDIRECT_URLOptional OAuth redirect URL, points to the API. Example: http://localhost:4000/api/v1/auth/oauth/callback.
MAX_CHAT_DOWNLOAD_EXECUTIONSMaximum number of chat downloads that can be running at once. Live streams bypass this limit.
MAX_CHAT_RENDER_EXECUTIONSMaximum number of chat renders that can be running at once.
MAX_VIDEO_DOWNLOAD_EXECUTIONSMaximum number of video downloads that can be running at once. Live streams bypass this limit.
MAX_VIDEO_CONVERT_EXECUTIONSMaximum number of video conversions that can be running at once.
MAX_VIDEO_SPRITE_THUMBNAIL_EXECUTIONSMaximum number of video sprite thumbnail generation jobs that can be running at once. This is not very CPU intensive.
SHOW_SSO_LOGIN_BUTTONFrontend: true/false Show a "login via sso" button on the login page (defaults to false).
FORCE_SSO_AUTHFrontend: true/false Force users to login via SSO by bypassing the login page (defaults to false).
REQUIRE_LOGINFrontend: true/false Require users to be logged in to view videos (defaults to false).
SHOW_LOCALE_BUTTONFrontend: true/false Show the locale/language button on the navbar (defaults to true).
DEFAULT_LOCALEFrontend: Sets the default locale/language. Must be the short code of the language. Example: en for English, de for German.
FORCE_LOGINFrontend: true/false Force require users to login to view any page (defaults to false).
DB

Ensure these are the same in the API environment variables.

ENV NameDescription
POSTGRES_PASSWORDDatabase password
POSTGRES_USERDatabase username.
POSTGRES_DBName of the database.

Volumes

API
VolumeDescriptionExample
/data/videosMount for video storage. This must match the VIDEOS_DIR environment variable./mnt/nas/vods:/data/videos
/data/logsMount to store task logs. This must match the LOGS_DIR environment variable../logs:/data/logs
/data/tempMount to store temporary files during the archive process. This is mounted to the host so files are recoverable in the event of a crash. This must match the TEMP_DIR environment variable../temp:/data/temp
/data/configMount to store the config. This must match the CONFIG_DIR environment variable../config:/data/config

Development

A devcontainer is included for development. This container includes all the necessary tools to develop Ganymede. Once setup, the Makefile can be used to run the development environment.

  • make dev_server - Starts the server.
  • make dev_worker - Starts the worker.
  • make dev_web - Starts the web server.

View the Makefile for more commands.

Acknowledgements

License

GNU General Public License v3.0

Related Projects