Skip to content

ad-on-is/odin-server

Repository files navigation

Enjoy movies and TV shows.

To be used with Odin TV

release Version GitHub stars

screenshot screenshot2

🚀 Key features

  • Discover movies and shows
  • Scrobble
  • See your watchlists
  • Setup custom sections from Trakt lists
  • Scrape Jackett for Torrents
  • Multi-User support
  • Unrestrict links with RealDebrid/AllDebrid

💡 Prerequisites

Warning

In order to make sure Odin works as expected, please setup these things before starting the app.

  • Trakt API credentials
  • TMDB API key
  • A working Jackett server
    • Make sure you have some good indexers set up
  • At least one of:
    • RealDebrid Account
    • AllDebrid API_KEY

🐋 Setup with Docker (docker-compose)

services:
  odin:
    image: ghcr.io/ad-on-is/odin:latest
    # image: ghcr.io/ad-on-is/odin:latest-arm64
    container_name: odin
    restart: always
    ports:
      - 6060:6060
    environment:
      - LOG_LEVEL=info
      - JACKETT_URL=http://jackett:9117
      - JACKETT_KEY=xxxxx
      - TMDB_KEY=<tmdbkey>
      - TRAKT_CLIENTID=<trakt_clientid>
      - TRAKT_SECRET=<trakt_secret>
      - ADMIN_EMAIL=<[email protected]> #optional
      - ADMIN_PASSWORD=<password> #optional
      - ALLDEBRID_KEY=<alldebrid_key> # if you have an AllDebrid account
    volumes:
      - ./pb_data:/pb_data

  jackett:
    image: lscr.io/linuxserver/jackett:latest
    container_name: jackett
    ports:
      - 9117:9117
    environment:
      - TZ=Etc/UTC
      - AUTO_UPDATE=true
    volumes:
      - ./jackett:/config
    restart: always
  flaresolverr:
    container_name: flaresolverr
    image: ghcr.io/flaresolverr/flaresolverr:latest
    restart: always
    environment:
      - LOG_LEVEL=info

  # use a reverse proxy to serve the app
  # nginx:
  # caddy:

1️⃣ First steps

Trakt

TMDB

Jackett and flaresolverr

  • Configured Jackett as needed
    • Add flaresolverr
    • Add as many good quality indexers as possible
  • Make sure the Jackett search returns some results

Prepare the server

  • Log in as admin
    • E-Mail: [email protected], Password: odinAdmin1
    • If you've set them via the environment variables, use these instead
  • Configure RealDebrid
  • Create a new user

Configuration

RealDebrid

  • Connect to RealDebrid by following the steps in the frontend

AllDebrid

  • Go to Apikey manager
  • Create a new API key
  • Use the key as environment variable

Trakt

  • Log in as a User
  • Go to Profile
  • In the Trakt section click on "Login" and follow the steps

Trakt Lists

  • Go to settings
  • Add lists, with title and url in the desired section

[!INFO]

Trakt API for info about possible endpoints

Example: /movies/trending

Placeholders

  • ::(year|month|day):: current year|month|day
  • ::(year|month|day):-1: current year|month|day +1 (or -1)
  • ::monthdays:: days of the current month

Examples: /movies/popular?years=::year::,::year:-1: -> /movies/popular?years=2024,2023

📺 Connecting to Odin TV

Note

This only works with a regular user, not an admin account.

  • Install the Odin TV app on your Android TV box
  • Open Odin TV on your Android TV box. A screen with a code should show up.
  • Login as your user in the Odin frontend, and go to devices
  • Click on Link device, enter the code shown on your TV and click Connect

connect

Note

This process uses ntfy.sh to propagate the public URL from the server to the App. The public URL only needs to be accessible within your network where the Android TV is running on.

💻 Running local dev environment

# install Bun
curl -fsSL https://bun.sh/install | bash

# lone the repo
git clone https://github.com/ad-on-is/odin-movieshow
cd odin-movieshow

# install dependencies
bun install

# copy .env.example to apps/backend/.env and apps/frontend/.env and fill in the blanks

# run dev
bun --bun run dev

Donations

License

GPLv3


GitHub @ad-on-is  ·  Built using pocketbase and Nuxt