1
0
Fork 0
mirror of https://github.com/av1155/houndarr.git synced 2026-06-02 09:33:19 -07:00
Self-hosted *arr companion for controlled missing, cutoff, and upgrade searches. https://av1155.github.io/houndarr/
  • Python 82.1%
  • HTML 7.3%
  • CSS 4.4%
  • JavaScript 4.4%
  • Shell 0.8%
  • Other 1%
Find a file
Andrea Arturo Venti Fuentes 2979fb3f4a
fix(settings): copy api key on http installs (#648)
The Copy key button silently failed in non-secure contexts because the
fallback textarea was appended to document.body while a modal <dialog>
was open. Per HTML spec, content outside an open modal is inert, so
focus()/select() were no-ops, the selection stayed empty, and
execCommand('copy') returned true while copying nothing. Host the
fallback textarea inside the open dialog and guard the call site with a
selection-length sanity check.

Closes #647
2026-05-23 00:21:48 -04:00
.agents/skills chore(skills): refresh for widget feature 2026-05-22 17:57:02 -04:00
.claude refactor(agents): align skill/rule wiring with cross-harness canonical (#615) 2026-05-07 23:09:12 -04:00
.github chore(deps): may 2026 sweep + pnpm 11 migration (#639) 2026-05-21 20:01:06 -04:00
charts/houndarr fix(perf): cure dashboard hang on large search_log (#587) 2026-04-29 17:13:18 -04:00
docs docs: add homepage integration guide (#641) 2026-05-22 16:42:54 -04:00
scripts docs: add homepage integration guide (#641) 2026-05-22 16:42:54 -04:00
src/houndarr fix(settings): copy api key on http installs (#648) 2026-05-23 00:21:48 -04:00
tests fix(settings): copy api key on http installs (#648) 2026-05-23 00:21:48 -04:00
website [#630] feat: hot retry window after post-release grace (#643) 2026-05-22 22:59:44 -04:00
.dockerignore build(css): compile Tailwind locally + daisyUI v5 Station theme (#481) 2026-04-26 20:42:28 -04:00
.editorconfig chore: initialize repository with project scaffolding 2026-03-12 00:06:47 -04:00
.gitignore chore: modernize Python toolchain (PEP 735, hatchling, py3.13, deps) (#596) 2026-05-03 17:45:36 -04:00
.workmux.yaml chore: modernize Python toolchain (PEP 735, hatchling, py3.13, deps) (#596) 2026-05-03 17:45:36 -04:00
AGENTS.md refactor(agents): align skill/rule wiring with cross-harness canonical (#615) 2026-05-07 23:09:12 -04:00
CHANGELOG.md fix(settings): copy api key on http installs (#648) 2026-05-23 00:21:48 -04:00
CLAUDE.md chore: add Claude Code dev infrastructure (#323) 2026-04-01 15:34:31 -04:00
CODE_OF_CONDUCT.md docs: add Contributor Covenant Code of Conduct v2.1 (#145) 2026-03-15 15:58:59 -04:00
CODEOWNERS ci: add all GitHub Actions workflows and project configuration 2026-03-12 00:17:28 -04:00
CONTEXT.md chore: ground /api/v1/widget design (CONTEXT, ADR-0001) (#614) 2026-05-04 16:41:07 -04:00
CONTRIBUTING.md chore: modernize Python toolchain (PEP 735, hatchling, py3.13, deps) (#596) 2026-05-03 17:45:36 -04:00
docker-compose.dev.yml feat: add production Dockerfile, entrypoint, and docker-compose 2026-03-12 00:30:18 -04:00
docker-compose.yml fix(auth): default SameSite cookie policy to lax (#318) 2026-04-01 13:48:52 -04:00
Dockerfile chore(deps): may 2026 sweep + pnpm 11 migration (#639) 2026-05-21 20:01:06 -04:00
entrypoint.sh security: add Huntarr vulnerability audit tests and smoke test (#277) 2026-03-21 17:41:55 -04:00
hatch_build.py chore: modernize Python toolchain (PEP 735, hatchling, py3.13, deps) (#596) 2026-05-03 17:45:36 -04:00
justfile feat(justfile): add sync and serve recipes 2026-05-14 23:38:35 -04:00
LICENSE chore(license): switch to AGPLv3 (#275) 2026-03-21 15:38:33 -04:00
lychee.toml docs: site followups (review fixes, link check, typecheck) (#403) 2026-04-18 13:06:08 -04:00
package.json chore(deps): may 2026 sweep + pnpm 11 migration (#639) 2026-05-21 20:01:06 -04:00
pnpm-lock.yaml build(css): compile Tailwind locally + daisyUI v5 Station theme (#481) 2026-04-26 20:42:28 -04:00
pnpm-workspace.yaml chore(deps): may 2026 sweep + pnpm 11 migration (#639) 2026-05-21 20:01:06 -04:00
pyproject.toml chore: clean up static-analysis surface and editor LSP (#600) 2026-05-03 20:51:04 -04:00
README.md docs: add homepage integration guide (#641) 2026-05-22 16:42:54 -04:00
SECURITY.md docs: AGENTS.md, commenting standard, refactor track notes, screenshots refresh, website, em dash sweep (#511) 2026-04-27 09:09:02 -04:00
uv.lock chore(deps): may 2026 sweep + pnpm 11 migration (#639) 2026-05-21 20:01:06 -04:00
VERSION chore: bump version to 1.12.0 (#646) 2026-05-22 23:32:56 -04:00

Houndarr logo

Houndarr

Automated missing-media search for your *arr stack.
Small batches. Polite intervals. Zero indexer abuse.

GitHub stars License: AGPL-3.0 Last commit GitHub release GHCR pulls Contributors Discord

Documentation  •  Quick Start  •  Docker  •  Helm Chart  •  Discord  •  Report Bug


Houndarr dashboard



Houndarr log viewer    Houndarr settings

What is Houndarr?

Radarr, Sonarr, Lidarr, Readarr, and Whisparr monitor RSS feeds for new releases, but they do not go back and actively search for content already in your library that is missing or below your quality cutoff. Their built-in "Search All Missing" button fires every item at once, which can overwhelm indexer API limits and get you temporarily banned.

Houndarr fixes this by searching slowly, politely, and automatically. It works through your backlog in small, configurable batches with sleep intervals between cycles, per-item cooldowns, and hourly API caps. It runs as a single Docker container alongside your existing *arr stack and stays out of the way.

What Houndarr does and doesn't do

Does. Trigger searches on your Radarr / Sonarr / Lidarr / Readarr / Whisparr instances for items they already report as missing or below quality cutoff. Read-only REST calls to your configured *arrs plus POST /api/v{1,3}/command for each search. That is the entire network surface.

Doesn't. Phone home, report telemetry, ship obfuscated code, manage download clients, integrate Prowlarr, bundle Usenet or torrent clients, scrape indexers directly, or contact any service outside the *arr instances you configure.

Polite by default. Small batches and long intervals out of the box. Configured caps are the ceiling, not the floor, and Houndarr never ignores an indexer's retry-after. Designed so you never have to think about your indexer's daily budget.

See SECURITY.md for the full security posture.

Key Features

Supported Apps

  • Radarr, Sonarr, Lidarr, Readarr, and Whisparr
  • Connect multiple instances of each

Search Modes

  • Missing media (episodes, movies, albums, books)
  • Cutoff-unmet items below your quality profile
  • Library upgrades for items that already meet cutoff
  • Configurable search context (episode vs. season, album vs. artist, book vs. author)

Rate Limiting and Safety

  • Small, configurable batch sizes with sleep intervals between cycles
  • Per-item cooldown prevents re-searching the same item too soon
  • Per-instance hourly API cap keeps indexer usage in check
  • Download-queue backpressure gate skips cycles when the queue is full
  • Bounded multi-page scanning so deep backlog items are not starved
  • Optional per-instance time windows so scheduled searches only run during configured hours
  • Per-instance search order: random (default) spreads picks across the whole backlog each cycle, chronological walks oldest-first

Web UI

  • Live dashboard with instance status cards and run-now buttons
  • Filterable, searchable log viewer with multi-format copy and export
  • Dark-themed interface (FastAPI + HTMX + Tailwind CSS)

Quick Start

Create a docker-compose.yml:

services:
  houndarr:
    image: ghcr.io/av1155/houndarr:latest
    container_name: houndarr
    restart: unless-stopped
    ports:
      - "8877:8877"
    volumes:
      - ./data:/data
    environment:
      - TZ=America/New_York
      - PUID=1000
      - PGID=1000
docker compose up -d

Open http://<your-host>:8877 and create your admin account on the setup screen.

Prefer docker run?
docker run -d \
  --name houndarr \
  --restart unless-stopped \
  -p 8877:8877 \
  -v /path/to/data:/data \
  -e TZ=America/New_York \
  -e PUID=1000 \
  -e PGID=1000 \
  ghcr.io/av1155/houndarr:latest

Replace /path/to/data with an absolute path on your host where Houndarr should store its database and master key.

For environment variables, reverse proxy setup, Kubernetes, Helm, and building from source, see the full documentation. For Homepage dashboard setup, see the Homepage integration guide.

What Houndarr Does NOT Do
  • No download-client integration: it triggers searches in your *arr instances, which handle downloads
  • No Prowlarr/indexer management: your *arr instances manage their own indexers
  • No request workflows: no Overseerr/Ombi-style request handling
  • No multi-user support: single admin username and password
  • No media file manipulation: it never touches your library files

Security and Trust

  • No telemetry, analytics, or call-home. The only outbound connections go to your configured *arr instances.
  • Instance API keys are encrypted at rest with Fernet (AES-128-CBC + HMAC-SHA256) and never sent back to the browser.
  • Authentication uses bcrypt password hashing, signed session tokens, CSRF protection, and login rate limiting.
  • The container runs as a non-root user after PUID/PGID remapping.
  • 63 integration tests validate immunity to every finding from the Huntarr.io security review; a live smoke test runs in CI on every PR.

For details on how Houndarr handles credentials, network behavior, and trust boundaries, see Security Overview. To report a vulnerability, see SECURITY.md.

Contributing and Community

For questions, troubleshooting, or casual discussion, join the Houndarr Discord. For bug reports and feature requests, open a GitHub issue.

See CONTRIBUTING.md for development workflow, coding standards, and quality gates.

Star History Chart



Contributors



If Houndarr is useful to you, consider giving it a star on GitHub.

License

GNU AGPLv3