{"id":50578116,"url":"https://github.com/Shoshuo/Prismarr","last_synced_at":"2026-06-21T19:00:39.073Z","repository":{"id":354056668,"uuid":"1221264555","full_name":"Shoshuo/Prismarr","owner":"Shoshuo","description":"A self-hosted media dashboard unifying Radarr, Sonarr, Prowlarr, Jellyseerr, qBittorrent and TMDb in a single Symfony 8 interface. One search bar across the local library and TMDb, one calendar merging movie and episode releases, one dashboard, one settings page. Single Docker container, embedded SQLite, multi-arch. AGPL-3.0.","archived":false,"fork":false,"pushed_at":"2026-06-08T16:01:58.000Z","size":14333,"stargazers_count":205,"open_issues_count":10,"forks_count":3,"subscribers_count":2,"default_branch":"main","last_synced_at":"2026-06-08T18:05:54.502Z","etag":null,"topics":["dashboard","docker-compose","frankenphp","homelab","jellyseerr","media-station","php","prowlarr","qbittorent","radarr","self-hosted","sonarr","sqlite","symfony","tabler","tmdb"],"latest_commit_sha":null,"homepage":"https://hub.docker.com/r/shoshuo/prismarr","language":"Twig","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":"agpl-3.0","status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/Shoshuo.png","metadata":{"files":{"readme":"README.md","changelog":"CHANGELOG.md","contributing":"CONTRIBUTING.md","funding":null,"license":"LICENSE","code_of_conduct":"CODE_OF_CONDUCT.md","threat_model":null,"audit":null,"citation":null,"codeowners":null,"security":"SECURITY.md","support":null,"governance":null,"roadmap":null,"authors":null,"dei":null,"publiccode":null,"codemeta":null,"zenodo":null,"notice":null,"maintainers":null,"copyright":null,"agents":null,"dco":null,"cla":null}},"created_at":"2026-04-26T01:03:16.000Z","updated_at":"2026-06-08T16:02:28.000Z","dependencies_parsed_at":null,"dependency_job_id":"d49b13d0-05f3-4559-8b4d-89bebebc2c74","html_url":"https://github.com/Shoshuo/Prismarr","commit_stats":null,"previous_names":["shoshuo/prismarr"],"tags_count":7,"template":false,"template_full_name":null,"purl":"pkg:github/Shoshuo/Prismarr","repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/Shoshuo%2FPrismarr","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/Shoshuo%2FPrismarr/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/Shoshuo%2FPrismarr/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/Shoshuo%2FPrismarr/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/Shoshuo","download_url":"https://codeload.github.com/Shoshuo/Prismarr/tar.gz/refs/heads/main","sbom_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/Shoshuo%2FPrismarr/sbom","scorecard":null,"host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":286080680,"owners_count":34622271,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2026-05-26T15:22:16.424Z","status":"online","status_checked_at":"2026-06-21T02:00:05.568Z","response_time":54,"last_error":null,"robots_txt_status":"success","robots_txt_updated_at":"2025-07-24T06:49:26.215Z","robots_txt_url":"https://github.com/robots.txt","online":true,"can_crawl_api":true,"host_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub","repositories_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories","repository_names_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repository_names","owners_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners"}},"keywords":["dashboard","docker-compose","frankenphp","homelab","jellyseerr","media-station","php","prowlarr","qbittorent","radarr","self-hosted","sonarr","sqlite","symfony","tabler","tmdb"],"created_at":"2026-06-05T00:00:33.536Z","updated_at":"2026-06-21T19:00:39.067Z","avatar_url":"https://github.com/Shoshuo.png","language":"Twig","funding_links":["https://buymeacoffee.com/shoshuo"],"categories":["Twig"],"sub_categories":[],"readme":"\u003cp align=\"center\"\u003e\n  \u003cimg src=\"symfony/public/img/prismarr/prismarr-logo-horizontal.png\" alt=\"Prismarr\" width=\"420\"\u003e\n\u003c/p\u003e\n\n\u003cp align=\"center\"\u003e\n  \u003cstrong\u003eOne dashboard for your self-hosted media stack.\u003c/strong\u003e\n\u003c/p\u003e\n\n\u003cp align=\"center\"\u003e\n  \u003ca href=\"https://github.com/Shoshuo/Prismarr/releases\"\u003e\u003cimg src=\"https://img.shields.io/github/v/release/Shoshuo/Prismarr?label=release\u0026color=6366f1\" alt=\"Latest release\"\u003e\u003c/a\u003e\n  \u003ca href=\"https://github.com/Shoshuo/Prismarr/actions/workflows/ci.yml\"\u003e\u003cimg src=\"https://img.shields.io/github/actions/workflow/status/Shoshuo/Prismarr/ci.yml?branch=main\u0026label=CI\" alt=\"CI\"\u003e\u003c/a\u003e\n  \u003ca href=\"https://hub.docker.com/r/shoshuo/prismarr\"\u003e\u003cimg src=\"https://img.shields.io/docker/pulls/shoshuo/prismarr?color=2496ED\u0026logo=docker\u0026logoColor=white\" alt=\"Docker pulls\"\u003e\u003c/a\u003e\n  \u003ca href=\"https://hub.docker.com/r/shoshuo/prismarr\"\u003e\u003cimg src=\"https://img.shields.io/docker/image-size/shoshuo/prismarr/latest?color=2496ED\u0026logo=docker\u0026logoColor=white\" alt=\"Image size\"\u003e\u003c/a\u003e\n  \u003ca href=\"https://github.com/Shoshuo/Prismarr\"\u003e\u003cimg src=\"https://img.shields.io/github/stars/Shoshuo/Prismarr?style=flat\u0026color=f59e0b\" alt=\"Stars\"\u003e\u003c/a\u003e\n  \u003ca href=\"https://github.com/Shoshuo/Prismarr/commits/main\"\u003e\u003cimg src=\"https://img.shields.io/github/last-commit/Shoshuo/Prismarr?color=6366f1\" alt=\"Last commit\"\u003e\u003c/a\u003e\n  \u003ca href=\"https://discord.gg/wd4hwU3jTF\"\u003e\u003cimg src=\"https://img.shields.io/badge/Discord-join-5865F2?logo=discord\u0026logoColor=white\" alt=\"Discord\"\u003e\u003c/a\u003e\n  \u003ca href=\"https://buymeacoffee.com/shoshuo\"\u003e\u003cimg src=\"https://img.shields.io/badge/Buy%20Me%20a%20Coffee-support-FFDD00?logo=buymeacoffee\u0026logoColor=black\" alt=\"Buy Me a Coffee\"\u003e\u003c/a\u003e\n\u003c/p\u003e\n\n\u003cp align=\"center\"\u003e\n  \u003ca href=\"https://github.com/Shoshuo/Prismarr/blob/main/LICENSE\"\u003e\u003cimg src=\"https://img.shields.io/badge/license-AGPL--3.0-blue\" alt=\"AGPL-3.0\"\u003e\u003c/a\u003e\n  \u003cimg src=\"https://img.shields.io/badge/PHP-8.4-777BB4?logo=php\u0026logoColor=white\" alt=\"PHP 8.4\"\u003e\n  \u003cimg src=\"https://img.shields.io/badge/Symfony-8-000000?logo=symfony\u0026logoColor=white\" alt=\"Symfony 8\"\u003e\n  \u003cimg src=\"https://img.shields.io/badge/FrankenPHP-1.3-orange\" alt=\"FrankenPHP 1.3\"\u003e\n  \u003cimg src=\"https://img.shields.io/badge/SQLite-zero--config-003B57?logo=sqlite\u0026logoColor=white\" alt=\"SQLite\"\u003e\n\u003c/p\u003e\n\n\u003cp align=\"center\"\u003e\n  \u003ca href=\"#features\"\u003eFeatures\u003c/a\u003e ·\n  \u003ca href=\"#quick-start\"\u003eQuick start\u003c/a\u003e ·\n  \u003ca href=\"#configuration\"\u003eConfiguration\u003c/a\u003e ·\n  \u003ca href=\"#upgrade\"\u003eUpgrade\u003c/a\u003e ·\n  \u003ca href=\"#troubleshooting\"\u003eTroubleshooting\u003c/a\u003e ·\n  \u003ca href=\"#whats-next\"\u003eWhat's next\u003c/a\u003e ·\n  \u003ca href=\"#support-and-community\"\u003eSupport\u003c/a\u003e ·\n  \u003ca href=\"#license\"\u003eLicense\u003c/a\u003e ·\n  \u003ca href=\"#note-on-ai-usage\"\u003eAI\u003c/a\u003e\n\u003c/p\u003e\n\n---\n\n\u003cp align=\"center\"\u003e\n  \u003cimg src=\"docs/screenshots/showcase.gif\" alt=\"Prismarr showcase\" width=\"100%\"\u003e\n\u003c/p\u003e\n\n\u003cdetails\u003e\n\u003csummary\u003e\u003cstrong\u003eStatic screenshots\u003c/strong\u003e (click to expand)\u003c/summary\u003e\n\u003cbr\u003e\n\n\u003cp align=\"center\"\u003e\n  \u003cimg src=\"docs/screenshots/dashboard.png\" width=\"49%\" alt=\"Dashboard\"\u003e\n  \u003cimg src=\"docs/screenshots/discover.png\" width=\"49%\" alt=\"Discover\"\u003e\n\u003c/p\u003e\n\u003cp align=\"center\"\u003e\n  \u003cimg src=\"docs/screenshots/calendar.png\" width=\"49%\" alt=\"Calendar\"\u003e\n  \u003cimg src=\"docs/screenshots/radarr.png\" width=\"49%\" alt=\"Movies (Radarr)\"\u003e\n\u003c/p\u003e\n\u003cp align=\"center\"\u003e\n  \u003cimg src=\"docs/screenshots/series-detail.png\" width=\"49%\" alt=\"Series detail (Sonarr)\"\u003e\n  \u003cimg src=\"docs/screenshots/downloads.png\" width=\"49%\" alt=\"Downloads (qBittorrent)\"\u003e\n\u003c/p\u003e\n\u003cp align=\"center\"\u003e\n  \u003cimg src=\"docs/screenshots/settings.png\" width=\"49%\" alt=\"Settings (custom theme)\"\u003e\n\u003c/p\u003e\n\n\u003c/details\u003e\n\n---\n\n## About\n\n**Prismarr** brings qBittorrent, Radarr, Sonarr, Prowlarr, Seerr and\nTMDb together in a single modern Symfony interface. No more juggling six\ntabs to manage your library.\n\nIt's not a replacement for Radarr or Sonarr - those run side by side and\nkeep doing what they do best. Prismarr is the unified control surface:\none search bar that hits the local library and TMDb, one calendar that\nmerges movie releases and episode airs, one dashboard that surfaces what\nmatters today (a recent download, a pending request, a trending pick),\nand one settings page where every API key lives - never on disk in plain\ntext and never in environment variables.\n\nThe whole thing ships as a single Docker container with SQLite inside.\nFirst boot opens a 7-step wizard: create the admin, plug your services in,\ndone. No external database, no Redis, no per-service `.env` files. Pull\nthe image, mount one volume, you're up.\n\n---\n\n## Project status\n\nPrismarr is maintained by a single developer (for now) in spare time.\nThe codebase is production-ready - I run it on my own homelab daily - but\nsupport, bug fixes and new features land when I have the bandwidth. There\nis no SLA, no commercial backing and no team behind this.\n\nThat said, I actively welcome and encourage feedback. **Feature requests,\nbug reports, code reviews, UI critiques, design ideas, translations** - if\nyou take the time to write something, I'll take the time to read it\ncarefully and reply. Open an issue, drop a PR, or just tell me what's\nmissing or what could be better. Outside contributors are exactly how a\nsolo project becomes a real one, and I'd love that to happen.\n\nThe [CHANGELOG](CHANGELOG.md) is kept up to date, and the [public Kanban](https://github.com/users/Shoshuo/projects/4)\nshows what's in progress, what's planned for the next release and what's\nqueued for later.\n\n---\n\n## Why Prismarr?\n\nThe selfhosted dashboard space is crowded. Here's where Prismarr fits and\nwhere the others might suit you better:\n\n- **[Organizr](https://organizr.app/)** - HTPC-focused, iframes the\n  underlying services into tabs. Excellent if you want each service's\n  full UI inside one page; less so if you want a unified library view\n  rather than six side-by-side dashboards.\n- **[Heimdall](https://heimdall.site/)**, **[Homer](https://github.com/bastienwirtz/homer)**,\n  **[Homepage](https://gethomepage.dev/)** - bookmark-style launchers\n  with widgets. Lightweight and fast; they don't *understand* your\n  library, they just link to other apps.\n- **[Homarr](https://homarr.dev/)** - drag-and-drop launcher with rich\n  widgets. Closer to Prismarr in spirit but still a launcher: Radarr is\n  a tile, not a page.\n- **[Seerr](https://docs.seerr.dev/)** (the unified successor of the\n  archived Overseerr / Seerr) - request frontend. Prismarr embeds\n  Seerr as one component among others; if requests are *all* you need,\n  Seerr alone is enough.\n- **Servarr web UIs themselves** - the most powerful option. Prismarr\n  doesn't replace them; it sits on top and gives you a unified search,\n  calendar, dashboard and download view.\n\n**Pick Prismarr if** you want a single Symfony app that *consumes* the\nAPIs of your existing stack, gives you one search box across the local\nlibrary and TMDb, one calendar that merges movie and episode releases,\none dashboard that surfaces what matters today, and one settings page\nwhere every API key lives - all in one Docker container with SQLite, no\nexternal dependencies.\n\n**Pick something else if** you want iframes (Organizr), pure bookmarks\n(Heimdall / Homer / Homepage), drag-and-drop dashboards (Homarr) or just\na request UI (Seerr).\n\n---\n\n## Features\n\n### Unified media management\n- Movies (Radarr) and Series (Sonarr) with five view modes\n- **Multiple Radarr / Sonarr instances side by side** (e.g. Radarr 1080p\n  + Radarr 4K + Radarr Anime). Each instance is first-class in the UI:\n  per-instance pages, per-instance health badge, per-instance Ctrl+K\n  search results. Add, rename, reorder and toggle instances from\n  `/admin/settings` without leaving Prismarr\n- Global `Ctrl+K` search across every enabled instance + TMDb / TheTVDB\n- Quick-add modal with a per-instance target picker — when a film is\n  already on Radarr 1080p you can still push it to Radarr 4K from one click\n- Unified calendar (movie + episode releases) merged across every\n  instance and deduped by `tmdbId` / `tvdbId`, with month / week / day\n  views and an iCal export\n\n### Dashboard\n- Hero spotlight with a random pick from your library\n- Upcoming releases (seven-day mini-calendar)\n- Pending Seerr requests enriched with TMDb metadata\n- Live health of all six services\n- Personal watchlist, weekly TMDb trending, latest library additions\n- Near-instant load: the page paints first, then each widget hydrates on its own\n\n### Downloads\n- Full qBittorrent dashboard: server-side pagination, sorting and filters\n- Drag-and-drop `.torrent` upload (multi-file)\n- Pipeline badges: clicking a torrent jumps to its movie / series\n- Cross-tab toasts when a download finishes\n- Optional Gluetun integration: public IP, country, port forwarding sync\n\n### Discovery\n- TMDb landing page with hero, personalised recommendations, trending\n- Personal watchlist, Explorer with filters (genre / decade / cast)\n- Countdown for upcoming releases\n- Deep-links into your existing library\n\n### Profile and preferences\n- `/profil` page: edit display name, password and avatar (JPG / PNG / WebP / GIF, 2 MB max)\n- Display preferences: theme colour, UI density, toasts, timezone,\n  date / time format, qBit auto-refresh, default home page\n- English / French UI (EN-first, FR fully translated, ICU plural support)\n- Settings export / import (credentials are always stripped)\n\n### Security\n- Symfony authentication with login rate-limiter (5 attempts per IP+username / 15 min)\n- Container runs as non-root, dynamic Content-Security-Policy\n- SSRF protection on user-provided URLs (protocol allowlist, cloud-metadata blocklist)\n- CSRF tokens on every mutation, branded error pages that never leak exception data\n- Profiler routes return 403 for non-RFC1918 clients in dev\n\n---\n\n## Quick start\n\n### Requirements\n\n- Docker and Docker Compose\n- At least one of: qBittorrent, Radarr, Sonarr, Prowlarr, Seerr\n- Optional: Gluetun if qBittorrent runs behind a VPN\n- Optional: a TMDb API key (free) to enable the Discovery page\n\n### Install\n\n**Step 1.** Get a `docker-compose.yml` file. Pick one of the two options below.\n\n#### Option A — Copy-paste\n\nCreate a file named `docker-compose.yml` with the following content:\n\n```yaml\nservices:\n  prismarr:\n    image: shoshuo/prismarr:latest\n    container_name: prismarr\n    restart: unless-stopped\n    stop_grace_period: 30s\n    ports:\n      - \"7070:7070\"\n    volumes:\n      - prismarr_data:/var/www/html/var/data\n\nvolumes:\n  prismarr_data:\n```\n\n#### Option B — Download\n\n```bash\nwget -O docker-compose.yml https://raw.githubusercontent.com/Shoshuo/Prismarr/main/docker-compose.example.yml\n```\n\n(or `curl -O https://raw.githubusercontent.com/Shoshuo/Prismarr/main/docker-compose.example.yml \u0026\u0026 mv docker-compose.example.yml docker-compose.yml`)\n\n#### Option C: Bind-mount (Servarr-style layout)\n\nIf you prefer host folders next to your other Servarr containers (Radarr, Sonarr, etc.) for easy browsing, replace the named volume with a bind-mount. The container target must stay at `/var/www/html/var/data`:\n\n```yaml\n    volumes:\n      - ./prismarr-config:/var/www/html/var/data\n```\n\nDrop the top-level `volumes:` block from Option A, and create the host folder before first start: `mkdir -p ./prismarr-config`.\n\n\u003e [!warning]\n\u003e If you write your own compose instead of using a template above, the container target for the data volume must be `/var/www/html/var/data`. Prismarr does not use the Servarr `/config` or `/app/config` convention. A bind-mount on the wrong path silently creates an anonymous volume that resets on every redeploy, with no error in the logs.\n\n---\n\n**Step 2.** Start the container:\n\n```bash\ndocker compose up -d\n```\n\n**Step 3.** Open `http://localhost:7070` in your browser. The setup wizard\nwill guide you through:\n\n- admin account creation\n- TMDb API key (optional)\n- Radarr / Sonarr / Prowlarr / Seerr URLs and keys\n- qBittorrent + Gluetun (optional)\n\n`APP_SECRET` and `MERCURE_JWT_SECRET` are auto-generated on first boot and\npersisted in the `prismarr_data` volume. No `.env` editing required.\n\n### Default port\n\nPrismarr listens on `7070`. To use a different port, change the left side of\nthe mapping in `docker-compose.yml`:\n\n```yaml\nports:\n  - \"8080:7070\"  # access on http://localhost:8080\n```\n\n---\n\n## Configuration\n\nEverything is configured from the UI:\n\n- **First boot**: the 7-step setup wizard at `/setup`\n- **Later**: the Settings page at `/admin/settings` (admin only)\n\nExternal service credentials (TMDb / Radarr / Sonarr / Prowlarr / Seerr\nAPI keys, qBittorrent password, service URLs), display preferences and\nlanguage are stored in the SQLite database (`setting` table). They never\nappear in environment variables or in any committable file.\n\nTwo framework-level secrets - `APP_SECRET` and `MERCURE_JWT_SECRET` - are\nauto-generated on first boot and persisted inside the volume at\n`var/data/.env.local`. They never leave the volume; you don't have to set,\nrotate or back them up manually.\n\n### Environment variables (optional)\n\n| Variable | Default | Purpose |\n|---|---|---|\n| `APP_ENV` | `prod` | Switch to `dev` for local development only |\n| `PRISMARR_PORT` | `7070` | Internal listening port |\n| `TRUSTED_PROXIES` | `127.0.0.1,REMOTE_ADDR` | Adjust if running behind Traefik / nginx / Caddy / Cloudflare Tunnel |\n| `TZ` | `UTC` | Container time zone (e.g. `Europe/Paris`, `Pacific/Honolulu`). Drives both the OS clock and the PHP date helpers — see issue [#12](https://github.com/Shoshuo/Prismarr/issues/12) |\n| `PHP_MEMORY_LIMIT` | `1024M` | PHP memory ceiling per request. Bump (e.g. `2048M`, `-1` for unlimited) if you have a very large Radarr / Sonarr library — see issue [#13](https://github.com/Shoshuo/Prismarr/issues/13) |\n| `PHP_MAX_EXECUTION_TIME` | `120` | PHP wall-time ceiling per request, in seconds. Bump alongside `PHP_MEMORY_LIMIT` if the films / series page times out |\n\n### Persistent data\n\nEverything lives in the `prismarr_data` Docker volume:\n\n- `prismarr.db` (SQLite database)\n- `.env.local` (auto-generated secrets)\n- `sessions/` (login sessions)\n- `cache/` (TMDb / cover thumbnails)\n- `avatars/` (uploaded user avatars)\n\nA standard backup is `docker run --rm -v prismarr_data:/data -v $(pwd):/backup alpine tar czf /backup/prismarr-data.tgz -C /data .`.\n\n### Reverse proxy\n\nPrismarr handles HSTS and Permissions-Policy headers itself. When sitting\nbehind a reverse proxy that terminates TLS (Traefik, nginx, Caddy,\nCloudflare Tunnel), set `TRUSTED_PROXIES` to your proxy network so that\nSymfony reads the right `X-Forwarded-*` headers.\n\n---\n\n## Upgrade\n\n```bash\ndocker compose pull\ndocker compose up -d\n```\n\nSQLite migrations run automatically on container start. The `prismarr_data`\nvolume is preserved.\n\nTo pin a specific version instead of `latest`:\n\n```yaml\nservices:\n  prismarr:\n    image: shoshuo/prismarr:1.0.0\n```\n\n### Testing pre-release builds\n\n`shoshuo/prismarr:beta` is the unreleased work-in-progress build of `main`.\n\n\u003e ### /!\\ No stability guarantee /!\\\n\u003e\n\u003e **`:beta` can be broken, regress features, or lose data.** It is not held to\n\u003e the quality bar of `:latest`, and there is no promise it works as well, or at\n\u003e all. **Do not run it on an instance you care about.**\n\nYou only ever get `:beta` if you explicitly set `image: shoshuo/prismarr:beta`\nin your compose file. The `:beta` tag is built separately and never touches\n`:latest`, so users on `:latest` (including with Watchtower or other auto-pull\nsetups) stay on stable. If you *do* opt into `:beta`, auto-pull will keep\nfetching fresh pre-release builds, which is usually what a tester wants.\n\nIf you still want to help test it:\n\n- Back up your `prismarr_data` volume before switching, and again before each\n  `:beta` pull. A pre-release database migration may not be safely reversible,\n  so going back to `:latest` can require restoring that backup.\n- Report problems on the issue tracker with a `[beta]` prefix in the title,\n  including the version shown on **Settings → Updates** and `docker logs prismarr`.\n\n---\n\n## Troubleshooting\n\n### Forgot the admin password\n\n```bash\ndocker exec -it prismarr php bin/console app:user:reset-password \u003cemail\u003e\n```\n\n### Setup wizard loops forever\n\nThe wizard finishes when the `setup_completed` flag is set. To force it\nback to step 1:\n\n```bash\ndocker exec -it prismarr php bin/console doctrine:query:sql \\\n  \"DELETE FROM setting WHERE key = 'setup_completed'\"\n```\n\n### Health check returns 503\n\n`GET /api/health` returns 503 when SQLite is unreachable. Inspect the\ncontainer logs:\n\n```bash\ndocker logs prismarr --tail 200\n```\n\nThe most common cause is a corrupted volume after a host-level disk full\nevent. Restoring the latest backup is the fastest path.\n\n### Container won't start\n\n```bash\ndocker logs prismarr\n```\n\nIf the error mentions `permission denied` on the volume, your host\nfilesystem is preventing the container's `www-data` user (UID 33 by\ndefault) from writing. Make sure the volume is a Docker-managed volume\nand not a bind mount onto a directory owned by root.\n\n---\n\n## What's next\n\nEverything lives on the [public Kanban](https://github.com/users/Shoshuo/projects/4): what's in progress, what's planned for the next release, and what's parked for later.\n\n---\n\n## Support and community\n\nPrismarr is built by one person in spare time. Two ways to be part of it:\n\n- **Join the [Discord](https://discord.gg/wd4hwU3jTF)** to ask for help, report\n  issues, share setups, or follow what's coming next.\n- **[Buy me a coffee](https://buymeacoffee.com/shoshuo)** if Prismarr is useful\n  to you and you'd like to support the time that goes into it. Entirely\n  optional, and every bit is appreciated.\n\nFor anything that needs tracking (bugs, feature requests), GitHub issues and\npull requests stay the right place. See [Contributing](#contributing).\n\n---\n\n## Tech stack\n\n- **Backend**: PHP 8.4 / Symfony 8 / Doctrine ORM\n- **Server**: FrankenPHP (Caddy + PHP embed, worker mode) supervised by s6-overlay\n- **Frontend**: Tabler UI + Alpine.js + Turbo (Hotwire) via Symfony AssetMapper\n- **Database**: SQLite (zero-config, automatic Doctrine migrations)\n- **Cache + sessions**: filesystem (no Redis required)\n- **Queue**: Symfony Messenger (Doctrine transport)\n- **Real-time**: Mercure SSE built into Caddy\n\nA single Docker container ships everything. The image is `~282 MB` and runs\non `amd64` and `arm64`.\n\n---\n\n## FAQ\n\n**Why PHP / Symfony?**\nBecause the developer (me) is comfortable with it and Symfony 8 lets a\nsolo dev ship a polished, testable, batteries-included web app fast.\nThe runtime is FrankenPHP in worker mode, so the per-request overhead\nis small. Performance is a non-issue at homelab scale.\n\n**ARM / Raspberry Pi support?**\nYes. The image is built for `linux/amd64` and `linux/arm64`. It runs\non a Raspberry Pi 4/5, an Apple Silicon Mac, or any arm64 NAS.\n\n**Does Prismarr need internet access?**\nOnly for TMDb (cover art, metadata, discovery) and the Servarr\nservices you point it at. The app itself works fully on a LAN; if\nyou don't configure TMDb, the Discovery page is the only feature\nthat goes dark.\n\n**Can I run it behind a reverse proxy?**\nYes. Set `TRUSTED_PROXIES` to your proxy network (see Configuration).\nHSTS and Permissions-Policy headers are emitted by the embedded\nCaddy.\n\n**Where are my API keys stored? Is it safe?**\nIn the SQLite database (table `setting`). The database lives in the\n`prismarr_data` Docker volume, never in environment variables, never\nin any file under version control. The export feature strips every\nkey matching `api_key`, `password` or `secret` so accidentally\nsharing your config is safe.\n\n**How do I back up my install?**\nSnapshot the `prismarr_data` Docker volume (one-liner in the\nConfiguration section). It contains the SQLite DB, the auto-generated\nsecrets, sessions, cache and avatars - everything needed to restore.\n\n**Can I contribute a translation in another language?**\nYes - duplicate `symfony/translations/messages+intl-icu.en.yaml` to\nyour locale (e.g. `messages+intl-icu.de.yaml`), translate, and open\na PR. The setup wizard will pick up the new locale automatically.\n\n---\n\n## Contributing\n\nContributions are welcome - please open an issue first to discuss the scope\nbefore submitting a PR.\n\n- **Contributor guide**: [CONTRIBUTING.md](CONTRIBUTING.md) (Definition of Done + golden rules)\n- **Code of conduct**: [CODE_OF_CONDUCT.md](CODE_OF_CONDUCT.md) (Contributor Covenant 2.1)\n- **Security vulnerability**: [SECURITY.md](SECURITY.md) - please **do not** open a public issue, contact by email\n- **Changelog**: [CHANGELOG.md](CHANGELOG.md)\n\nBefore any commit: `make check` (PHP lint + Twig lint + full PHPUnit suite).\n\n---\n\n## License\n\n[AGPL-3.0](LICENSE) - you may use, modify and redistribute Prismarr freely,\nincluding in self-hosted production. Derivatives must remain open source\nunder the same license.\n\n---\n\n## Acknowledgements\n\nInspired by the remarkable work of:\n\n- [Overseerr / Seerr](https://github.com/Fallenbagel/jellyseerr)\n- The [Servarr](https://wiki.servarr.com/) family (Radarr, Sonarr, Prowlarr, Bazarr…)\n- [Tabler](https://tabler.io/) for the UI kit\n\nAnd, on a more personal note: thank you to my friends and family for the\npatience, the encouragement, and for asking \"so when does it ship?\" often\nenough to keep me going. This release is for you.\n\n---\n\n## Star history\n\n[![Star history](https://api.star-history.com/svg?repos=Shoshuo/Prismarr\u0026type=Date)](https://star-history.com/#Shoshuo/Prismarr\u0026Date)\n\n---\n\n\u003e ## Note on AI usage\n\u003e\n\u003e Prismarr is a solo project. I make the calls on what to ship, what to drop, how things plug together. The bugs are on me too. [Claude Code](https://claude.com/claude-code) (Anthropic) helped me move faster on the chunks listed below; the rest is mine.\n\u003e\n\u003e To stay transparent, here are the concrete areas where it was actively helpful:\n\u003e\n\u003e **Primary uses**\n\u003e\n\u003e - **i18n translation and key wiring** - English isn't my native language; Claude handled the bulk of the EN/FR YAML files (4 188 keys on each side, kept in exact parity) and the `trans()` call sites in PHP and Twig.\n\u003e - **Log and JavaScript debugging** - faster triage of stack traces, Turbo/Alpine quirks, and front-end edge cases I couldn't reproduce locally.\n\u003e - **API endpoint cataloguing** - mapping the ~600 endpoints across Radarr v3, Sonarr v3, Prowlarr v1, Seerr, qBittorrent v2 and TMDb v3 from their OpenAPI specs.\n\u003e - **Code audits** - flagging missed translations, forgotten edge cases and bugs in my own code.\n\u003e - **SVG icons and illustrations** - generating and tweaking inline SVGs (logo variants, empty-state illustrations, status icons) when no off-the-shelf asset matched.\n\u003e\n\u003e **Secondary uses**\n\u003e\n\u003e - **PHPUnit test debugging** - turning failing assertions into readable diffs.\n\u003e - **Mobile responsive design** - tightening the calendar week/day views, sidebar collapse and dashboard widget grids on phones.\n\u003e - **Security review and hardening** - second-opinion checks on SSRF guards, CSP, CSRF tokens, XSS, SQL/XML injection patterns, profiler exposure.\n\u003e - **Documentation translation and polish** - README, CHANGELOG, CONTRIBUTING, SECURITY, CODE_OF_CONDUCT in both English and French.\n\u003e - **Local commit messages and the private PROGRESSION.md log** - keeping the per-session journal readable. That file lives only on my machine and is never pushed to GitHub.\n\u003e - **Single-container Docker design** - the FrankenPHP + s6-overlay layout that supervises the web server and the messenger worker.\n\u003e\n\u003e Nothing landed without me reading it, running it, and watching `make check` go green (PHP lint + Twig lint + full PHPUnit). Claude is a tool I leaned on, not a co-author.\n","project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2FShoshuo%2FPrismarr","html_url":"https://awesome.ecosyste.ms/projects/github.com%2FShoshuo%2FPrismarr","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2FShoshuo%2FPrismarr/lists"}