ov-layers/skills/immich-ml/SKILL.md
Immich machine learning backend on port 3003 for photo classification and search. Use when working with Immich ML features, face detection, or CLIP search.
npx skillsauth add overthinkos/overthink-plugins immich-mlInstall this skill globally with one command. Works with Claude Code, Cursor, and Windsurf.
3 of 9 scanners reported clean
Some scanners were skipped, did not run, or reported a non-clean status. Review each row below.
| Property | Value |
|----------|-------|
| Dependencies | immich |
| Ports | 3003 |
| Volumes | models -> ~/.immich/models |
| Service | immich-ml (supervisord, priority 40) |
| Install files | tasks: |
| Variable | Value |
|----------|-------|
| IMMICH_MACHINE_LEARNING_ENABLED | true (overrides immich default) |
| IMMICH_MACHINE_LEARNING_URL | http://127.0.0.1:3003 |
| MACHINE_LEARNING_HOST | 0.0.0.0 |
| MACHINE_LEARNING_PORT | 3003 |
| MACHINE_LEARNING_WORKERS | 1 |
| MACHINE_LEARNING_WORKER_TIMEOUT | 120 |
| TRANSFORMERS_CACHE | ~/.immich/models |
/opt/immich/machine-learning/.venv~/.immich/models (TRANSFORMERS_CACHE) and ~/.cache/immich_ml (immich ML model cache). The ~/.cache/immich_ml directory must be created at build time because ~/.cache may be root-owned from earlier layer builds (npm/pixi). Creating it in tasks: ensures correct UID 1000 ownership.# image.yml -- adds ML to an immich image
immich-ml:
layers:
- immich-ml
/ov-images:immich-ml/ov-layers:immich -- required base (provides server + database)/ov-layers:cuda -- GPU acceleration (when used in cuda images)Use when the user asks about:
/ov:layer — layer authoring reference (layer.yml schema, task verbs, service declarations)/ov:test — declarative testing (tests: block, ov image test, ov test)development
Claude Code multi-agent support in Overthink — sub-agents, dynamic workflows, and agent teams, and how each drives the existing `ov eval` disposable beds to test and verify. MUST be invoked before authoring or invoking an ov sub-agent / dynamic workflow / agent team, wiring agent-lifecycle hooks, or asking "which primitive should drive the R10 beds?".
tools
Mounts a virtiofs share tagged `workspace` at /workspace inside a VM guest via a systemd .mount unit. Use when a kind:vm entity shares a host directory into the guest and you need it auto-mounted (and re-mounted at every boot).
development
MUST be invoked before any work involving: the `kind: android` schema kind, a `target: android` deploy, the `apk:` layer package format (installing Android apps declaratively), AndroidDeployTarget, an in-pod emulator OR a remote/physical adb-endpoint device, or nested `pod → android` deployment. The first-class Android device + app surface that sits above `ov eval adb`/`appium`.
tools
Use when committing, branching, pushing, merging, tagging, creating PRs, or approving/merging PRs with gh — the feat/-branch, R10-gated, never-force-push landing workflow across the main repo + the plugins submodule + image/<distro> submodules. Covers sync-to-upstream, branch/worktree pruning, the fork+PR path for contributors without write access, and cross-repo @github landing order.