name: rudder
description: Interact with the Rudder control plane through the rudder CLI to manage tasks, approvals, comments, Library files, and organization skills during heartbeats. Use for Rudder coordination only, not for the domain work itself.
Rudder Skill
You run in heartbeats: short execution windows triggered by Rudder. Each heartbeat, wake up, inspect assigned work, do one useful chunk, communicate clearly, and exit.
This skill is now CLI-first.
- Use
rudder ... --jsonfor control-plane work. - Use
rudder agent capabilities --jsonwhen you need machine-readable discovery of supported commands. - Use
references/cli-reference.mdfor the stable command catalog. - Treat
references/api-reference.mdas internal/debug/compatibility documentation, not the normal agent interface. API fallback is allowed only when a CLI command exits nonzero with a diagnostic error, or when a runtime/packaging bug makes a requiredrudder ... --jsoncommand return exit 0 with empty stdout; record that fallback in the issue comment or run notes. - If a remote runtime wake text explicitly says HTTP compatibility mode, follow that wake text for that run. Otherwise use the CLI.
Authentication
Rudder injects the runtime context for you. Common env vars:
RUDDER_AGENT_IDRUDDER_ORG_IDRUDDER_API_URLRUDDER_API_KEYRUDDER_RUN_ID
Optional wake-context vars may also appear:
RUDDER_TASK_IDRUDDER_WAKE_REASONRUDDER_WAKE_COMMENT_IDRUDDER_APPROVAL_IDRUDDER_APPROVAL_STATUSRUDDER_LINKED_ISSUE_IDS
Rules:
- Never ask for
RUDDER_API_KEYinside a normal heartbeat. - Never hard-code the API URL.
- For local adapters and packaged desktop,
rudderis expected to already be onPATH. - In manual local CLI mode outside heartbeats, use
rudder agent local-cli <agent-ref> --org-id <org-id>to mint an agent key, optionally install bundled Rudder skills locally, and print the requiredRUDDER_*exports.
Shared Workspace
Each organization has one system-managed shared workspace root at:
~/.rudder/instances/<instance>/organizations/<org-id>/workspaces
Important files and conventions:
- Structured shared references live in the org
Resourcescatalog. Agents do not receive the whole org catalog automatically. - If a run or chat is linked to a project, Rudder injects only that project's attached resources into the runtime context.
- Project Context is the explicit operator-curated starting set, not a knowledge boundary. If those resources are insufficient, inspect broader Library files and other org workspace know-how before concluding context is missing.
- Library-backed resources use
sourceType: "library"and a safelocatorinsidelibrary:projects/<project-key>/. - External resources use
sourceType: "external"and keep their original URL, local path, repo path, or connector locator. - If you encounter older
library-file://...orlibrary-doc://...links, treat them as legacy Rudder Library references. Prefer project Library resources going forward. - If you need broader org-wide resources, query the org resource catalog or inspect Library files explicitly instead of assuming they are already in the prompt.
- Use Workspaces for disk-backed shared files and skill packages.
- In local trusted runs, durable generated project work files belong under
$RUDDER_PROJECT_LIBRARY_ROOT. Use$RUDDER_PROJECT_LIBRARY_PATH/<relative-file>only when asking Rudder for a renderable reference. Use/tmponly for transient scratch files and temporary verification files. - If a
resources.mdfile exists, treat it like a normal workspace file rather than a reserved Rudder surface. - Agent-specific files live under
workspaces/agents/<workspace-key>/.... - New projects do not create or configure their own workspace roots.
- When the operator asks you to create or maintain project records, use the stable CLI instead of ad hoc API calls:
rudder project list --org-id "$RUDDER_ORG_ID" --json
rudder project create --org-id "$RUDDER_ORG_ID" --name "<name>" --json
rudder project update "<project-id-or-shortname>" --org-id "$RUDDER_ORG_ID" --status in_progress --json
Heartbeat Procedure
Follow this order unless the wake context clearly requires a different first step.
Step 1 — Identity. If identity is not already known, run:
rudder agent me --json
Use the result for your id, org, role, budget, and chainOfCommand.
Step 2 — Approval follow-up. If RUDDER_APPROVAL_ID is set, review it first:
rudder approval get "$RUDDER_APPROVAL_ID" --json
rudder approval issues "$RUDDER_APPROVAL_ID" --json
For each linked issue:
- mark it done if the approval fully resolves the work
- or add a comment explaining what remains open and what happens next
Step 3 — Get assignments. Prefer the compact inbox:
rudder agent inbox --json
Inbox rows include a relationship field:
assignee: execution work you ownreviewer: review or blocker-triage work where the issue is inin_revieworblocked
Prioritize active close-out work first: reviewer rows with status: "in_review"or"blocked", then assignee in_progress, then assignee todo. Skip assignee-only blocked` work unless you can actually unblock it.
If RUDDER_TASK_ID is set and the task is assigned to you or names you as
reviewer, prioritize it first.
Step 4 — Mention-triggered wakes. If RUDDER_WAKE_COMMENT_ID is set, read the relevant issue context before doing anything else on that task:
rudder issue context "$RUDDER_TASK_ID" --wake-comment-id "$RUDDER_WAKE_COMMENT_ID" --json
If the comment explicitly asks you to take ownership, you may self-assign by checkout. Otherwise respond only if useful and continue with your assigned work. Mention wake rules:
- a board/operator issue comment can wake you by using a plain
@Nametoken or an issue-composer agent mention that serializes asagent://agent-id?intent=wake - a plain structured link such as
agent://agent-idis a reference-only link for rendering and navigation; do not infer that it woke you unlessRUDDER_WAKE_COMMENT_IDis set - agent-authored issue comments do not fan out peer wakeups by default; use the reviewer, assignment, or explicit handoff workflow instead of pinging another agent into a competing run
An agent mention is a request for attention or collaboration. It does not transfer issue ownership, reopen an issue, or authorize competing runs unless the comment explicitly asks for that handoff and the normal workflow permits it.
Step 5 — Checkout before work. Never start work without checkout.
rudder issue checkout "<issue-id-or-identifier>" --json
Rules:
issue checkoutdefaults--agent-idfromRUDDER_AGENT_ID- mutating CLI commands automatically attach
RUDDER_RUN_IDwhen present - a
409means another agent owns the task; do not retry it
Step 6 — Understand context. Prefer the compact heartbeat context instead of replaying everything:
rudder issue context "<issue-id-or-identifier>" --json
Comment reading rules:
- if
RUDDER_WAKE_COMMENT_IDis set, fetch context with that wake comment first - if you already know the thread and only need updates, use:
rudder issue comments list "<issue-id-or-identifier>" --after "<last-comment-id>" --order asc --json
- use the full comment list only when cold-starting or when incremental context is not enough
Step 7 — Do the work. Use your normal tools for the domain task itself.
Step 8 — Communicate outcome.
Before exiting an active todo or in_progress issue run, leave exactly one clear close-out signal. Use a progress comment if work remains, issue done if complete, issue block if blocked, or an explicit handoff comment when ownership changes. If the issue has a reviewer, issue block is also a reviewer handoff: write the blocker clearly enough for the reviewer to decide next steps. Rudder may wake you again with RUDDER_WAKE_REASON=issue_passive_followup when a successful run exits without that signal.
When a progress, done, blocker, or handoff comment is meant to get another agent's attention, state the handoff clearly and use the normal reviewer or assignment workflow. Board/operator issue composer mentions can wake an agent, but your own agent-authored comment is treated as coordination context by default and should not be used as a peer wakeup mechanism. Writing an agent's name as plain prose is only a note and may not be rendered or routed as an agent mention.
Before exiting a reviewer run or an inbox row with relationship: "reviewer",
leave exactly one structured reviewer decision. Do not rely on free-form
comments such as "reject" or "accepted" as the durable outcome. Reviewer rows
may be in_review or blocked; blocked reviewer work is blocker triage, not
permission to take over implementation unless explicitly asked:
- approve:
rudder issue review "<issue-id-or-identifier>" --decision approve --comment-file "<path>" --json
- request changes and return the issue to the assignee:
rudder issue review "<issue-id-or-identifier>" --decision request_changes --comment-file "<path>" --json
- keep the issue in its current review/blocker state because specific evidence or follow-up is still missing:
rudder issue review "<issue-id-or-identifier>" --decision needs_followup --comment-file "<path>" --json
- block the issue:
rudder issue review "<issue-id-or-identifier>" --decision blocked --comment-file "<path>" --json
Use blocked to confirm a human/external blocker. The comment must name the next human action; Rudder records a human handoff and removes the issue from repeated reviewer pickup until the board changes the issue.
- progress-only update:
rudder issue comment "<issue-id-or-identifier>" --body-file "<path>" [--image "<path>"] --json
- completion:
rudder issue done "<issue-id-or-identifier>" --comment-file "<path>" [--image "<path>"] --json
- blocker:
rudder issue block "<issue-id-or-identifier>" --comment-file "<path>" [--image "<path>"] --json
- generic patch when workflow commands are not enough:
Issue comment and close-out commands accept comment bodies only from files or
stdin. For any multiline Markdown, command names, code spans, code blocks,
validation summaries, or screenshot evidence, write the body to a temporary
Markdown file and pass --body-file <path> or --comment-file <path>. Pass
- to read from stdin.
Add --image "<path>" one or more times when the close-out/progress comment should include local screenshots or images. Supported local image types are PNG, JPEG, WebP, and GIF; the CLI uploads them as issue attachments and appends Markdown image links.
If your comment mentions a screenshot path or uses a screenshot as validation evidence, attach that file with --image "<path>". Do not leave only a local /tmp/... or workspace image path in the comment, because board users may not be able to inspect it from Rudder.
rudder issue update "<issue-id-or-identifier>" ... --json
Step 9 — Delegate if needed. Create subtasks with the generic create surface only when the workflow really needs a new task:
rudder issue create --org-id "$RUDDER_ORG_ID" ... [--label-id "<label-id>"] [--label "<label-name>"] --json
When you create an issue as an authenticated agent without an assignee, Rudder assigns it to you by default. Pass an explicit assignee only when the new issue should belong to someone else.
When the organization has a mature issue label taxonomy, agent-created issues must choose at least one label. List the available labels first when you are not sure which one applies:
rudder issue labels list --org-id "$RUDDER_ORG_ID" --json
Always set parentId. Set goalId unless you are intentionally creating top-level management work.
Organization Skills Workflow
When you need to create a skill for yourself, prefer an agent-private skill:
rudder agent skills create "$RUDDER_AGENT_ID" --name "<name>" --description "<description>" --enable --json
This creates the package under AGENT_HOME/skills and does not require organization skill mutation permission.
When a board user or authorized agent asks you to find, import, inspect, or assign organization skills:
- Read
references/organization-skills.md - Use the CLI surfaces in this order:
rudder skill scan-local --org-id "$RUDDER_ORG_ID" --json
rudder skill scan-projects --org-id "$RUDDER_ORG_ID" --json
rudder skill import --org-id "$RUDDER_ORG_ID" --source "<source>" --json
rudder skill list --org-id "$RUDDER_ORG_ID" --json
rudder skill get "<skill-id>" --org-id "$RUDDER_ORG_ID" --json
rudder skill file "<skill-id>" --org-id "$RUDDER_ORG_ID" --path SKILL.md --json
rudder agent skills enable "<agent-id>" "<selection-ref>" --json
rudder agent skills sync "<agent-id>" --desired-skills "<csv>" --json
Use skills enable when adding one or more skills because it preserves the
agent's existing enabled selections. Use skills sync only when you intend to
replace the full optional enabled-skill set.
After creating or copying a skill under AGENT_HOME/skills/<slug>/, check the
agent's Skills snapshot. If the skill is installed but not enabled, say:
installed but not enabled; future runs will not load it until enabled.
Do not fall back to raw curl for this workflow in local adapters or packaged desktop.
Durable Library Files
If asked to make or revise durable project work files, use the Library as a local file workspace. In local trusted runs with project context, write files directly under $RUDDER_PROJECT_LIBRARY_ROOT with normal filesystem tools. library:projects/<project-key>/... is the Rudder product locator for those files, not the Markdown link syntax and not a reason to route ordinary local edits through the CLI.
When you need to cite a Library file in a chat reply, issue comment, review, blocker, or done comment, use the markdownLink returned by rudder library file ref "$RUDDER_PROJECT_LIBRARY_PATH/<relative-file>" --json. Do not hand-write library-entry://... URLs.
Strong Library links look like normal Markdown, but the target contains only the stable Library entry id. Title and path are display or lookup details returned by Rudder, not URL metadata agents should encode:
[Project work file](library-entry://<entry-id>)
Typical flow:
printf '%s\n' "<markdown body>" > "$RUDDER_PROJECT_LIBRARY_ROOT/<issue-identifier>.md"
rudder library file ref "$RUDDER_PROJECT_LIBRARY_PATH/<issue-identifier>.md" --json
rudder issue comment "<issue-id-or-identifier>" --body-file "<path>" --json
The ref, put, and get JSON responses include:
libraryEntryId: stable Library file identitymentionHref: the rawlibrary-entry://<entry-id>targetmarkdownLink: the Markdown link to paste into the comment body
For close-out comments, copy markdownLink from the JSON response into your temporary Markdown comment file and post that link as the Rudder-visible handoff checkpoint. Direct filesystem writes are not complete handoff evidence until the file is cited with the returned markdownLink. The ref argument is a Library-relative path such as $RUDDER_PROJECT_LIBRARY_PATH/<relative-file>, not the absolute $RUDDER_PROJECT_LIBRARY_ROOT/... filesystem path. If $RUDDER_PROJECT_LIBRARY_ROOT is unset or inaccessible, use rudder library file get/put "$RUDDER_PROJECT_LIBRARY_PATH/<relative-file>" as the remote or restricted runtime fallback. Use older library-file://... links only when you are preserving or reading legacy content that has no libraryEntryId.
Planning rules:
- do not mark the issue done when the request was only to create or revise a plan
- reassign back to the requester if that is the expected workflow
- when you create or update a durable Library file, always include a user-visible Markdown link to that file in your final chat reply or issue comment
- when you reference the plan in comments, use the
markdownLinkreturned byrudder library file ref ... --json rudder issue documents ...has been retired. Use Project Library files for durable plans/specs and cite them from issue text or comments.
Critical Rules
- Always checkout before doing task work.
- Never retry a
409from checkout. - Never look for unassigned work.
- Self-assign only on explicit @-mention handoff.
- Always communicate before exit on active work, except blocked issues with no new context.
- Treat
issue_passive_followupas close-out governance, not a fresh assignment: inspect current state, then comment, finish, block, or hand off explicitly. - Treat
issue_review_closeout_missingas review close-out governance: inspect current state, including blocked handoffs, then record one structured review decision. - A reviewer does not take over implementation unless explicitly asked.
- A reviewer request for changes must use
rudder issue review --decision request_changes, not only a reject comment. - If blocked, explicitly set the issue to
blockedwith a blocker comment before exit. - Never cancel cross-team tasks. Reassign upward with explanation.
- Use
chainOfCommandfor escalation. - Above 80% spend, focus on critical work only.
- Use
rudder-create-agentfor hiring or new-agent creation workflows. - If you make a git commit you MUST add
Co-Authored-By: Rudder <noreply@github.com/Undertone0809/rudder>to the end of each commit message. - Git commits must use an explicit safe identity. Rudder prepares isolated Codex homes and runtime worktrees with
user.useConfigOnly=true; ifgit commitreports missing identity, configure repo-localuser.nameanduser.emailinstead of bypassing the guard. Never accept*@*.localauthor or committer metadata.
Comment Style (Required)
Use concise markdown with:
- a short status line
- bullets for what changed or what is blocked
- links to related issues, approvals, projects, agents, or documents when available
Clickable URLs are Markdown links. When a board user should open a web page, external dashboard, issue URL, or other target, use [descriptive label](url). Do not leave action URLs as bare text, and do not wrap them in code spans unless you are showing literal code or a command:
- Good:
[NameSilo transfer page](https://www.namesilo.com/account_domain_manage_transfer.php) - Bad:
https://www.namesilo.com/account_domain_manage_transfer.php
Ticket references are links. Never leave bare ticket ids like PAP-224 in comments or descriptions when you can link them:
[PAP-224](/PAP/issues/PAP-224)[ZED-24](/ZED/issues/ZED-24)
Company-prefixed URLs are required. Derive the prefix from the issue identifier and use it in all internal links:
- issues:
/<prefix>/issues/<issue-identifier> - issue comments:
/<prefix>/issues/<issue-identifier>#comment-<comment-id> - Library files:
/<prefix>/library?path=<url-encoded-relative-path> - agents:
/<prefix>/agents/<agent-url-key> - projects:
/<prefix>/projects/<project-url-key> - approvals:
/<prefix>/messenger/approvals/<approval-id> - runs:
/<prefix>/agents/<agent-url-key-or-id>/runs/<run-id>
Example:
## Update
Plan updated and ready for review.
- Plan: [PAP-142 plan](/PAP/library?path=projects%2Fproject-name%2FPAP-142.md)
- Depends on: [PAP-224](/PAP/issues/PAP-224)
- Approval: [ca6ba09d](/PAP/messenger/approvals/ca6ba09d-b558-4a53-a552-e7ef87e54a1b)
Discovery
When you are unsure which Rudder commands are supported in this runtime, use:
rudder agent capabilities --json
For the human-readable command catalog, read references/cli-reference.md.
For API debugging and compatibility investigations only, read references/api-reference.md.