immich/skills/immich-ml-layer/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-ml-layerInstall 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 | task: |
| 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.# charly.yml -- adds ML to an immich image
immich-ml:
candy:
- immich-ml
/charly-immich:immich-ml/charly-immich:immich -- required base (provides server + database)/charly-distros:cuda -- GPU acceleration (when used in cuda boxes)Use when the user asks about:
/charly-image:layer — candy authoring reference (charly.yml schema, task verbs, service declarations)/charly-eval:eval — declarative testing (eval: block, charly eval box, charly eval live)tools
OpenCharly CLI (charly) binary installed into container/VM images for in-container use. Use when working with charly binary deployment inside containers, native D-Bus support, or the full charly toolchain (charly binary + virtualization + gocryptfs + socat).
development
Operator CachyOS workstation profile — a kind:local template + target:local deploy that installs the full dev stack (30 candies) onto a CachyOS host via ShellExecutor. Lives in the overthinkos/cachyos submodule. MUST be invoked before editing or applying the charly-cachyos workstation profile.
tools
Fedora box with the full charly toolchain using shared candies. Rootless-first — runs as uid=1000 with passwordless sudo (no root, no cap_add: ALL). Same candy list as charly-arch. Includes NVIDIA GPU runtime. MUST be invoked before building, deploying, configuring, or troubleshooting the charly-fedora box.
tools
Arch Linux box with the full charly toolchain. Rootless-first — runs as uid=1000 with passwordless sudo (no root, no cap_add: ALL). Composes /charly-coder:charly-mcp so the box is reachable as an MCP gateway on port 18765. NVIDIA GPU runtime composed in. MUST be invoked before building, deploying, configuring, or troubleshooting the charly-arch box.