ov-images/skills/arch-coder/SKILL.md
Kitchen-sink development image on Arch Linux: coding + AI-coding CLIs + DevOps tooling in one container. Arch base, 30+ direct layers mirroring fedora-coder's stack but with pac:-section packages (plus AUR for a few unique cases). Runs as uid 1000 (`user`) with passwordless sudo. Use when working with the arch-coder image — or when comparing cross-distro parity across the four coder-family images (fedora, debian, ubuntu, arch).
npx skillsauth add overthinkos/overthink-plugins arch-coderInstall 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.
Arch Linux counterpart of /ov-images:fedora-coder. Same daily-development surface (AI CLIs, language runtimes, DevOps stack), same rootless posture (uid 1000 + passwordless sudo), same shape of tests — only the package manager (pac: / aur:) and a handful of Arch-specific package names differ.
arch-coder:
base: archlinux
ports:
- "2222:2222" # sshd-wrapper
- "18765:18765" # ov-mcp (Streamable HTTP)
layers:
# Baseline — identical to fedora-coder
- agent-forwarding
- sshd
- ov-full
- ov-mcp
- container-nesting
- dbus
- tmux
# Language runtimes + managers
- language-runtimes # Go + PHP + .NET 9 + python3-devel
- golang
- nodejs # NOT nodejs24 — Arch's nodejs is already current
- rust
- pixi
- uv
# Build + developer tooling
- build-toolchain
- dev-tools
- pre-commit
- direnv
- gh
- typst
- asciinema
# AI coding CLIs
- claude-code
- codex
- gemini
- forgecode
- oracle
# DevOps / cloud / infra
- devops-tools
- kubernetes
- docker-ce
- github-actions
- google-cloud
- google-cloud-npm
- grafana-tools
No explicit user: / uid: / gid: — inherits the defaults. user_policy: defaults to auto; the archlinux base image declares no base_user: in build.yml, so the policy falls through to create mode — the bootstrap emits an idempotent useradd -m -u 1000 -g 1000 user. See /ov:image "user_policy" and /ov:build "base_user".
| Field | Value | Source |
|---|---|---|
| cap_add | (empty) | — |
| security_opt | [unmask=/proc/*] | /ov-layers:container-nesting |
| devices | [/dev/fuse, /dev/net/tun] | /ov-layers:container-nesting |
| privileged | false | — |
| Network | bridge | defaults |
| UID / user | 1000 / user | create mode |
| sudo | passwordless via /etc/sudoers.d/ov-user | /ov-layers:sshd |
No --privileged, no cap_add: ALL, no seccomp=unconfined. The rootless posture is shared with the three sibling power-user images (fedora-coder, fedora-ov, arch-ov) — dropped the legacy privileged posture in 2026-04 once /ov-layers:container-nesting proved it was unnecessary.
Unlike fedora-coder (which only uses pixi/npm/cargo builders), arch-coder can also pull from the AUR — because the archlinux-builder image ships yay and declares builds: [pixi, npm, cargo, aur]. Layers with aur: sections route through archlinux-builder as their aur builder. Currently no layer in the arch-coder stack uses AUR, but the capability exists for future additions (e.g. niche tools not in [core]/[extra]).
See /ov-images:archlinux-builder and /ov-layers:yay.
arch-coder is one of four cross-distro coder images that share the identical 80-line tests: block and ~30 identical layers, diverging only in each layer's package-format section (rpm: / pac: / deb:):
/ov-images:fedora-coder — RPM-based, Fedora 43 via fedora-nonfree, uid=1000 user./ov-images:arch-coder — this image; pacman + optional AUR, uid=1000 user./ov-images:debian-coder — deb-based, Debian 13 trixie, uid=1000 user./ov-images:ubuntu-coder — deb-based, Ubuntu 24.04 noble, uid=1000 ubuntu (adopted from base image — see /ov:image "user_policy" and /ov-images:ubuntu).All four produce the same developer surface. Pick based on which distro family you (or your team / CI) are already standardized on.
Layers in roughly the same groups as fedora-coder, with these Arch-specific notes:
nodejs (not nodejs24) — Arch's nodejs package is already current enough; no LTS pinning.language-runtimes — Arch ships dotnet-sdk in [extra] (no Microsoft repo needed, unlike Debian/Ubuntu). Also drops python3-ramalama (not packaged on Arch — install via uv tool install ramalama).dev-tools — /usr/bin/bat ships directly from the bat package (no Debian-style batcat rename needed).gh — GitHub CLI from Arch's extra repo (no third-party apt repo needed).container-nesting — Arch equivalents for podman + buildah + skopeo + fuse-overlayfs + crun.The remaining 25+ layers are identical to fedora-coder at the composition level. Each layer's pac: section handles the Arch-specific package names.
ov image build arch-coder
ov shell arch-coder
# or as a service:
ov config arch-coder
ov start arch-coder
ssh -p 2222 user@localhost # passwordless sudo
ov image build arch-coder
ov image test ghcr.io/overthinkos/arch-coder:latest
# disposable-container tests against the baked OCI label
ov config arch-coder
ov start arch-coder
ov image test ghcr.io/overthinkos/arch-coder:latest --include-deploy
# adds deploy-scope checks: sshd reachable, supervisord, dbus, ov-mcp,
# virtqemud, libvirt session list, KVM domcaps, MCP tool-call probes.
| Port | Service | Bound by |
|---|---|---|
| 2222 | sshd-wrapper (SSH access as user with sudo) | /ov-layers:sshd |
| 18765 | ov-mcp (entire ov CLI as MCP tools, Streamable HTTP) | /ov-layers:ov-mcp |
Conflicts with /ov-images:fedora-coder / /ov-images:debian-coder / /ov-images:ubuntu-coder on both ports (all coder-family images use the same canonical ports). Use -i <instance> or -p <remap> to run alongside.
/ov-images:archlinux — base image (pacman bootstrap, user_policy: auto → create)./ov-images:archlinux-builder — pixi/npm/cargo/aur multi-stage builder./ov-images:fedora-coder — canonical RPM-family sibling./ov-images:debian-coder — deb-family sibling on Debian 13./ov-images:ubuntu-coder — deb-family sibling on Ubuntu 24.04 (adopt mode)./ov-images:arch-ov — slimmer Arch alternative with just the ov toolchain (no AI CLIs or DevOps tooling)./ov-images:selkies-desktop-ov — adds a browser-streamed Wayland desktop on the fedora-ov baseline./ov-layers:yay — AUR helper, required for any aur: section/ov-layers:ov-full, /ov-layers:ov-mcp, /ov-layers:container-nesting — shared rootless baseline/ov-layers:sshd — cross-distro sudoers via getent passwd 1000/ov-layers:language-runtimes, /ov-layers:dev-tools, /ov-layers:gh/ov-layers:claude-code, /ov-layers:codex, /ov-layers:gemini, /ov-layers:forgecode, /ov-layers:oracle/ov:shell, /ov:config, /ov:start, /ov:stop, /ov:test/ov:image — user_policy: field reference/ov:build — base_user: declaration (absent for archlinux)/ov:layer — authoring referenceMUST be invoked when the task involves:
arch-coder.aur: sections to layers composed into arch-coder.[extra]) or batcat symlinks (bat is packaged as bat).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.