ov-layers/skills/wayvnc/SKILL.md
WayVNC server on port tcp:5900 for remote access to Wayland desktops. Use when working with VNC access, remote desktop, or wayvnc configuration.
npx skillsauth add overthinkos/overthink-plugins wayvncInstall 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 | supervisord |
| Ports | tcp:5900 (non-HTTP protocol) |
| Service | wayvnc (supervisord, priority 20) |
| Install files | tasks:, wayvnc-wrapper |
wayvnc (RPM)# image.yml -- typically included via sway-desktop composition
my-desktop:
layers:
- wayvnc
ov test vnc screenshot my-image # capture desktop
ov test vnc passwd my-image --generate # set up VeNCrypt/TLS auth
VNC screenshots work correctly on NVIDIA headless when used via sway-desktop-vnc (the standard VNC composition). Two fixes make this work:
Pixman renderer — sway-desktop-vnc sets WLR_RENDERER=pixman in its layer env, forcing software rendering. The sway-wrapper skips GPU auto-detection when WLR_RENDERER is pre-set.
DPMS workaround — wayvnc 0.9.1 gates screen capture on zwlr_output_power_v1 mode events, but sway's headless backend never emits them. The wayvnc-wrapper performs a minimal VNC handshake to trigger wayvnc to bind the power manager, then swaymsg "output HEADLESS-1 power on" forces the missing event. Fixed in wayvnc git main (post-0.9.1) — remove workaround when Fedora ships the fix.
For images NOT using sway-desktop-vnc (custom sway + wayvnc setups), ov test wl screenshot (grim) remains a reliable fallback.
The wayvnc-wrapper uses a two-phase wait:
wayland-0)sway-ipc.*.sock) + 2s delayThis ensures sway has set the output resolution (default 1920x1080) before wayvnc connects.
Part of /ov-layers:sway-desktop composition.
/ov-layers:supervisord -- process manager dependency/ov-layers:sway -- Wayland compositor (provides display)/ov-layers:sway-desktop -- composition that includes wayvnc/ov-layers:pipewire -- sibling in desktop stack/ov:vnc — VNC screenshot, click, type, key, mouse commandsUse 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.