Ganymede logo

Ganymede

  •  0 ratings
In category: Archiving and Digital Preservation (DP)

About Ganymede

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

  •   414  
  •   0  
  •   0  
  •   0  
Github stats:
  •  Commits: N/A  
  •   N/A  
  •   N/A  
  •  Latest commit: N/A  

Deploy this app to Linode with a free $100 credit!

Languages/Platforms/Technologies:
Lincenses:

  Depends on a proprietary service outside the user's control

More about Ganymede


Logo

Ganymede

Twitch VOD and Stream archiving platform with a rendered chat. Files are saved in a friendly format allowing for use without Ganymede.


Demo

ganymede-readme_landing

https://user-images.githubusercontent.com/21207065/203620893-41a6a3a0-339a-4c62-8df8-0f66ec68327d.mp4

About

Ganymede allows archiving of past streams (VODs) and livestreams both with a 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.
  • Watch channels for new videos and streams.
  • Twitch VOD/Livestream support.
  • Queue holds.
  • Queue task restarts.
  • Full VOD, Channel, and User management.
  • Custom post-download video FFmpeg parameters.
  • Custom chat render parameters.
  • Webhook notifications.

Documentation

For in-depth documentation on features visit the wiki.

API

Visit the docs folder for the API docs.

Installation

Requirements

Installation

Ganymede consists of four docker containers:

  1. API
  2. Frontend
  3. Postgres Database
  4. Nginx

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

  1. Download a copy of the docker-compose.yml file and nginx.conf.
  2. Edit the docker-compose.yml file modifying the environment variables, see environment variables.
  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.

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 /data, /logs, and /tmp. It will not recursively chown the /vods directory. Ensure the mounted vods directory is readable by the set user.

Environment Variables

API
ENV Name Description
TZ Timezone.
DB_HOST Host of the database.
DB_PORT Port of the database.
DB_USER Username for the database.
DB_PASS Password for the database.
DB_NAME Name of the database.
DB_SSL Whether to use SSL. Default: disable. See DB SSL for more information.
DB_SSL_ROOT_CERT Optional Path to DB SSL root certificate. See DB SSL for more information.
JWT_SECRET Secret for JWT tokens. This should be a long random string.
JWT_REFRESH_SECRET Secret for JWT refresh tokens. This should be a long random string.
TWITCH_CLIENT_ID Twitch application client ID.
TWITCH_CLIENT_SECRET Twitch application client secret.
FRONTEND_HOST Host of the frontend, used for CORS. Example: http://192.168.1.2:4801
COOKIE_DOMAIN Optional Base domain for cookies. Used when reverse proxying. See reverse proxy for more information.
OAUTH_PROVIDER_URL Optional OAuth provider URL. See https://github.com/Zibbp/ganymede/wiki/SSO---OpenID-Connect
OAUTH_CLIENT_ID Optional OAuth client ID.
OAUTH_CLIENT_SECRET Optional OAuth client secret.
OAUTH_REDIRECT_URL Optional OAuth redirect URL, points to the API. Example: http://localhost:4000/api/v1/auth/oauth/callback.
Frontend
ENV Name Description
API_URL Host for the API. Example: http://192.168.1.2:4800.
CDN_URL Host for the Nginx serivce. Example: http://197.148.1.2:4802.
SHOW_SSO_LOGIN_BUTTON true/false Show a "login via sso" button on the login page.
FORCE_SSO_AUTH true/false Force users to login via SSO by bypassing the login page.
REQUIRE_LOGIN true/false Require users to be logged in to view videos.
DB

Ensure these are the same in the API environment variables.

ENV Name Description
POSTGRES_PASSWORD Database password
POSTGRES_USER Database username.
POSTGRES_DB Name of the database.

Volumes

API
Volume Description Example
/vods Mount for VOD storage. This example I have my NAS mounted to /mnt/vault/vods. /mnt/vault/vods:/vods
/logs Queue log folder. ./logs:/logs
/data Config folder. ./data:/data

Optional

./tmp:/tmp Binding the tmp folder prevents lost data if the container crashes as temporary downloads are stored in tmp which gets flushed when the container stops.

Nginx
Volume Description Example
/mnt/vods VOD storage, same as the API container volume. /mnt/vault/vods:/mnt/vods
/etc/nginx/nginx.conf:ro Path to the Nginx conf file. /path/to/nginx.conf:/etc/nginx/nginx.conf:ro

Acknowledgements

License

GNU General Public License v3.0

Authors

Comments (0)

Please login to join the discussion on this project.

Ganymede Reviews (0)

Overall Rating

None

based on 0 ratings

Please login to review this project.

No reviews for this project yet.

↑ back to top

pCloud Lifetime

Popular Projects

FluxBB

in Social Networks and Forums
 33k    0    0    0  

Nextcloud

in File Transfer & Synchronization
 20k    1    1    0  

Libreddit

in Social Networks and Forums
 7k    0    1    0  

Dashboard

in Personal Dashboards
 6k    0    0    0  

Audiobookshelf

in Audio Streaming
 6k    0    1    0  

CasaOS

in Self-hosting Solutions
 5k    0    0    0  

Mediagoblin

in Photo and Video Galleries
 4k    0    0    0  

Most Discussed

Nextcloud

in File Transfer & Synchronization
 20k    1    1    0  

Tube Archivist

in Automation
 3k    0    1    0  

OneDev

in Project Management
 2k    0    0    0  

iodine

in Proxy
 2k    0    0    0  

Alf.io

in Booking and Scheduling
 2k    0    0    0  

sysPass

in Password Managers
 1k    0    0    0  

Misskey

in Social Networks and Forums
 2k    0    0    0  
Linux VPS from $11/yr.
RackNerd VPS for $11.38/mo

Top Rated Projects

Gitea

 1 rating
in Project Management

Bagisto

 1 rating
in E-commerce

LinkAce

 1 rating
in Bookmarks and Link Sharing

Pydio

 1 rating
in File Transfer & Synchronization

Audiobookshelf

 1 rating
in Audio Streaming

Nextcloud

 1 rating
in File Transfer & Synchronization

Seafile

 1 rating
in File Transfer & Synchronization

Categories

You May Also Be Interested In

Collective Access logo
Collective Access cover

Collective Access

Providence - Highly configurable Web-based framework for ma…

Archivematica logo
Archivematica cover

Archivematica

Mature digital preservation system designed to maintain sta…

Access to Memory (AtoM) logo
Access to Memory (AtoM) cover

Access to Memory (AtoM)

Web-based, open source application for standards-based arch…