ov-foundation/skills/cloud-init/SKILL.md
Cloud-init for instance initialization in cloud/VM environments with NoCloud datasource. Use when working with cloud-init, VM provisioning, or cloud instance bootstrapping.
npx skillsauth add overthinkos/overthink-plugins cloud-initInstall 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 | sshd |
| Install files | tasks:, layer.yml |
cloud-init (RPM) -- cloud instance initializationcloud-utils-growpart (RPM) -- partition growing utility# overthink.yml or image.yml
image:
my-cloud-image:
base: "quay.io/fedora/fedora-bootc:43"
bootc: true
layers:
- cloud-init
Used in bootc images for VM/cloud deployments. Depends on sshd.
kind: vm entitiesThis layer installs the guest-side cloud-init package — the daemon that reads a NoCloud seed ISO at first boot. The host-side companion is the RenderCloudInit path in the ov binary itself (/ov-dev:cloud-init-renderer), which produces that seed ISO from the structured VmSpec.CloudInit block on a kind: vm entity.
The two sides cooperate across the host/guest boundary:
/ov-dev:cloud-init-renderer emits user-data + meta-data + network-config + seeds ISO via xorriso./dev/sr0 (the seed ISO) at boot.composeUsers adopt-merge pattern (renderer-side) deposits the SSH pubkey in ~<base_user>/.ssh/authorized_keys without useradd.For cloud_image VMs (source.kind: cloud_image), cloud-init typically comes pre-installed in the upstream qcow2 — this layer isn't needed; author the VM entity directly in vms.yml. For bootc VMs that want cloud-init provisioning, add this layer explicitly. See /ov-vms:vms for the authoring guide and /ov-vms:arch for a worked example.
/ov-coder:sshd -- SSH server dependency/ov-foundation:bootc-base — composition that includes this layer/ov-foundation:qemu-guest-agent — host-guest communication (paired with cloud-init in VMs)/ov-advanced:vm — VM lifecycle (create, start, stop, ssh) for kind:vm entities/ov-vms:vms — kind:vm authoring reference/ov-dev:cloud-init-renderer — host-side renderer producing the NoCloud seed ISO this layer reads/ov-build:layer — layer authoring referenceUse when the user asks about:
/ov-build:eval — declarative testing (eval: block, ov eval image, ov 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.