← Back to Skills Marketplace
wegow

ARCHIV

by WegoW · GitHub ↗ · v1.0.0 · MIT-0
cross-platform ⚠ suspicious
101
Downloads
0
Stars
0
Active Installs
1
Versions
Install in OpenClaw
/install archiv
Description
Controls Roon music system via API to search, play tracks or albums, manage queues, adjust volume, shuffle, and control playback on specified zones.
README (SKILL.md)

Roon Music Controller

Your Roon system is controlled via a REST API running in LCX container on Proxmox server.

API Base

http://roonext2.home:3001/api

CRITICAL: How to make API calls

GET:

curl -s 'http://roonext2.home:3001/api/status'

POST:

curl -X POST http://roonext2.home:3001/api/find-and-play \
  -H "Content-Type: application/json" \
  -d '{
    "zone_id": "YOUR_ZONE_ID",
    "query": "stool pigeon",
    "type": "Tracks",
    "action": "Play Now"
  }'

Zones

Replace this table with your own zones. Get them by calling /api/zones.

Zone ID
Schlafzimmer 1601dcef8115529daf4cd6807753971fae3e
Wohnzimmer 160124b4c2dcc52aa8478e05110f7ed25120

How to find your zone IDs:

curl -s 'http://roonext2.home:3001/api/zones'

Endpoints

Method Path Purpose
GET /api/status All zones, playback state, now playing
GET /api/zones Zone list with IDs
GET /api/search?q=\x3Cquery>[&type=Tracks|Albums|Artists] Search library + TIDAL
POST /api/find-and-play Main play endpoint — search + play in one session
POST /api/transport Playback control (play/pause/skip etc.)
POST /api/volume Volume control
GET /api/queue/\x3Czone_id> View current queue
POST /api/playlist Queue multiple tracks in order (save as playlist in Roon app)
GET /api/inspect?q=\x3Cquery> Debug: show Roon's exact action names for a track
POST /api/shuffle Enable or disable shuffle for a zone
POST /api/play-album Play an entire album — natively queues all tracks in order

play-album (album playback)

Use this endpoint when the user asks to play an album. Do NOT use find-and-play for albums — it only plays the first track.

{ "zone_id": "...", "query": "Artist Album", "action": "Play Now" }

Searches for the album, navigates Roon's full browse hierarchy (Search → Albums → Album page → Play Album → action), and triggers album-level playback. All tracks are queued natively in the correct album order.

Supports the same action strings: Play Now, Queue, Add Next, Start Radio.

curl -X POST http://roonext2.home:3001/api/play-album \
  -H "Content-Type: application/json" \
  -d '{
    "zone_id": "YOUR_ZONE_ID",
    "query": "white city a novel",
    "action": "Play Now"
  }'

find-and-play (single track playback)

{ "zone_id": "...", "query": "...", "type": "Tracks", "action": "Play Now" }

CRITICAL — Roon's exact action labels

These are the real strings Roon uses internally. Wrong names silently fall back to Play Now.

Want to... Use this string
Play immediately (clears queue) Play Now
Add to end of queue QueueNOT "Add to Queue"
Play after current track Add NextNOT "Play Next"
Start Roon Radio Start Radio

transport

{ "zone_id": "...", "action": "next" }

Valid actions: play, pause, stop, next, previous, toggle_play_pause



shuffle

{ "zone_id": "...", "shuffle": true }

Set shuffle to true to enable, false to disable.

curl -s -X POST http://roonext2.home3001/api/shuffle \
  -H 'Content-Type: application/json' \
  -d '{"zone_id": "1601dcef8115529daf4cd6807753971fae3e", "shuffle": true}'

volume

{ "zone_id": "...", "how": "absolute", "value": 40 }

Range 0–100. how: absolute, relative, relative_step


Playlist pattern

Option A — /api/playlist (recommended for multi-track lists)

Queues all tracks in one API call. First track plays immediately, rest are queued. To save as a permanent Roon playlist: Queue → ⋮ → Save Queue as Playlist.

Note: Roon's Extension API does not expose "Add to Playlist" to third-party extensions — only playback actions are available. The queue-then-save workflow is the supported path.

POST /api/playlist
{
  "name": "My 1988 Mix",
  "zone_id": "YOUR_ZONE_ID",
  "tracks": [
    { "query": "Song One Artist One" },
    { "query": "Song Two Artist Two" },
    { "query": "Song Three Artist Three" }
  ]
}
curl -s -X POST http://roonext2.home:3001/api/playlist \
  -H 'Content-Type: application/json' \
  -d '{"name":"My Playlist","zone_id":"YOUR_ZONE_ID","tracks":[{"query":"Song One Artist"},{"query":"Song Two Artist"}]}'

Option B — individual find-and-play calls (for short lists or fine control)

First track → Play Now (starts playback, clears existing queue). All subsequent tracks → Queue. Use delay 2 between calls.

ZONE="YOUR_ZONE_ID"
API="http://roonext2.home:3001/api/find-and-play"

tracks=(
  "Song One Artist One|Play Now"
  "Song Two Artist Two|Queue"
  "Song Three Artist Three|Queue"
)

for track in "${tracks[@]}"; do
  query="${track%%|*}"
  action="${track##*|}"
  curl -s -X POST "$API" \
    -H 'Content-Type: application/json' \
    -d "{\"zone_id\":\"$ZONE\",\"query\":\"$query\",\"type\":\"Tracks\",\"action\":\"$action\"}"
  sleep 2
done

Your library and taste profile

Edit this section to describe your own library and musical taste. Cowork uses this to make smart recommendations and playlist choices on your behalf.

YOUR_STREAMING_SERVICE is connected — any track can be played.

Local library includes:
- Artist — albums

Taste profile: describe your taste here so Cowork can recommend music you'll enjoy.

Roon authorisation

If the API returns "Not connected to Roon Core", you need to re-authorise:

Roon → Settings → Extensions → Enable "Cowork Controller"

Learnings

  • verify.artist_match – check that the artist of a track or album matches the requested artist before adding to the queue. This prevents mismatches like Bobbi Humphrey for a Commodores request.
  • Embedding future learnings here ensures they are only loaded when the roon‑controller skill is used.
Usage Guidance
This skill appears to be a straightforward Roon controller and is coherent with its description, but exercise caution before installing. The included MEMORY.md exposes local file paths, references to API keys and backup scripts, and mentions other internal services — none of which the Roon skill needs. Before installing: (1) remove or sanitize MEMORY.md (don’t include paths or key names), (2) verify the Roon API hostname/port in a safe test (and fix the malformed example URL), (3) ensure the agent runtime does not have broad filesystem read/write or network access you don't intend (the skill uses local network endpoints), and (4) only proceed if you trust the skill source and the local API endpoint. If you want, provide a sanitized version of the SKILL.md (only the Roon curl examples and your zone IDs) and I can re-evaluate.
Capability Analysis
Type: OpenClaw Skill Name: archiv Version: 1.0.0 The bundle contains a highly irregular MEMORY.md file that acts as a persistent instruction set, directing the agent to perform hourly backups of its memory and files to a specific external GitHub repository (https://github.com/WegoW/Openclaw.git), which constitutes a data exfiltration risk. It also includes hardcoded local network addresses (e.g., 192.168.1.247) and references to sensitive configuration paths like ~/.trakt.yaml and /root/.openclaw/openclaw.json. While the content appears to be a personal environment dump for a user named 'Walter Wego,' the inclusion of automated exfiltration logic and environment-specific overrides in a skill bundle is a significant security risk.
Capability Assessment
Purpose & Capability
The SKILL.md describes exactly a Roon controller and all declared endpoints and curl examples map to that purpose. No unrelated binaries or external cloud credentials are required by the skill itself.
Instruction Scope
The runtime instructions focus on calling a local REST API (http://roonext2.home:3001/api) using curl — this is consistent with a local Roon extension controller. The doc asks the agent to trigger the skill widely (for many casual phrases), which is broad but logically aligned with a playback controller. Minor issues: at least one example has a malformed URL typo (http://roonext2.home3001/...), and the SKILL.md invites the user to paste personal library/taste info (which is fine but user-provided). The SKILL.md does not instruct the agent to read unrelated system files or exfiltrate data.
Install Mechanism
No install spec or code files — instruction-only skill — so nothing is written to disk or fetched during install. This is the lowest-risk install posture.
Credentials
The skill itself declares no environment variables or credentials, which is appropriate. However, the included MEMORY.md contains many references to local credential files, API keys paths (/root/.openclaw/openclaw.json, ~/.trakt.yaml), cron/backups, internal services (SearXNG at 192.168.1.247), and exec-based tooling. Those entries are unrelated to the Roon controller's purpose and reveal where sensitive keys and data live — bundling them with the skill increases privacy risk and could enable accidental access if the agent is given file-read capabilities.
Persistence & Privilege
The skill does not request always:true and is user-invocable; it does not ask to modify other skills or system-wide configs. Autonomous invocation remains allowed by platform default but is not otherwise escalated by this skill.
How to Use
  1. Make sure OpenClaw is installed (local or Docker)
  2. Run the install command in chat: /install archiv
  3. After installation, invoke the skill by name or use /archiv
  4. Provide required inputs per the skill's parameter spec and get structured output
Version History
v1.0.0
Initial release of the Roon music controller skill: - Enables control of your Roon music system (playback, queue, search, volume, skipping). - Supports full REST API integration for searching your library/TIDAL and controlling all playback features. - Clearly documents each available API endpoint, request method, and correct parameter usage. - Provides examples for common music requests, including track/album play, volume adjustment, shuffle, and playlist creation. - Includes best practices and critical notes for reliable automation and future improvements.
Metadata
Slug archiv
Version 1.0.0
License MIT-0
All-time Installs 0
Active Installs 0
Total Versions 1
Frequently Asked Questions

What is ARCHIV?

Controls Roon music system via API to search, play tracks or albums, manage queues, adjust volume, shuffle, and control playback on specified zones. It is an AI Agent Skill for Claude Code / OpenClaw, with 101 downloads so far.

How do I install ARCHIV?

Run "/install archiv" in the OpenClaw or Claude Code chat to install it in one step — no extra setup required.

Is ARCHIV free?

Yes, ARCHIV is completely free, licensed under MIT-0. You can download, install and use it at no cost.

Which platforms does ARCHIV support?

ARCHIV is cross-platform and runs anywhere OpenClaw / Claude Code is available (cross-platform).

Who created ARCHIV?

It is built and maintained by WegoW (@wegow); the current version is v1.0.0.

💬 Comments