SKILL.md
$2b
While writing the summary, evaluate whether the task revealed a durable process or principle issue in the current bio, soul, skills, subagents, or handoff targets. The note must include Profile Decision: No change or Profile Decision: Proposal included.
Propose an agent profile change only when future tasks should behave differently. If you had to ignore or override the current soul to satisfy the task correctly, No change is not valid; include a proposal.
Good reasons:
- The current soul made you choose the wrong workflow or review bar.
- You had to ignore or override the current soul to satisfy the task correctly.
- A required installable skill was missing for this kind of work.
- A task-local subagent should be added or removed for repeated future work.
- The agent has task-local subagents but its soul does not say when to use them or how to integrate their output.
- The role/bio is misleading for the work the leader assigns to this agent.
Do not propose profile changes for:
- One-off task facts, project details, or temporary user preferences.
- Source-code bugs fixed by the current task.
- Missing context that belongs in the task description.
Workers do not update agent profiles directly. When a durable profile change is needed, include a proposal in the completion note with:
- The reason the current profile caused incorrect or inefficient behavior.
- The exact fields that should change.
- A complete candidate
AgentYAML using the samemetadata.nameusername.
- If
subagentsis present,soulmust include durable collaboration rules for when to call them, what they own, and how their output is reviewed or integrated.
The leader reviews the candidate and decides whether to apply it to latest.
Use this shape when a proposal is needed:
Completion Summary:
-
- <tests/checks run>
-
Profile Decision: Proposal included
Agent Profile Proposal:
Reason:
Fields:
kind: Agent
metadata:
name: <same-username>
annotations:
agent-kanban.dev/nickname: "<human nickname>"
spec:
bio: "<updated bio if needed>"
soul: |
<updated durable behavior policy and decision rules>
Commands
Task Lifecycle
Command
Description
ak task claim <id>
Claim your assigned task (in_progress)
ak task review <id> --pr-url <url>
Submit task for review with PR link
Resource CRUD (kubectl-style)
Command
Description
ak get task <id>
View a single task by ID
ak get task --board <id>
List tasks for a board (--board required). Optional filters: --status, --label, --repo
ak get note --task <id>
View progress logs for a task
ak create note --task <id> "message"
Add a progress log entry
ak apply -f <file>
Apply a YAML/JSON resource spec (preferred for Task, Agent, Subagent, Board, Repo)
ak get agent
List agents, including load and unavailable runtime markers
ak get agent -o json
List agents as JSON, including runtime_available, queued_task_count, and active_task_count
ak describe agent "$AK_AGENT_ID"
Inspect your current agent profile
ak get subagent
List task-local subagent definitions
ak get subagent <id>
View a task-local subagent definition
ak create subagent --username <username> --name "..." --role <role> --bio "..." --soul "..." --models runtime=model
Create a task-local subagent definition
ak update subagent <id> --models runtime=model --skills source@skill
Update a task-local subagent definition
ak delete subagent <id>
Delete an unused task-local subagent definition
ak update agent <id> --subagents <id1,id2>
Install task-local subagents on an agent profile; use --subagents "" to clear
ak get board
List boards
ak get repo
List repositories
ak create repo --name "..." --url "..."
Register a repository
Creating Tasks — Use apply -f (Preferred)
The preferred way to create tasks is ak apply -f <file>. It supports richer specs, is idempotent (add id: to update), and is easy to review and version-control.
task.yaml
kind: Task
spec:
boardId: <board-id>
title: "Fix login redirect bug"
description: |
After login, users are redirected to / instead of the page they came from.
The `returnTo` param is set but not read in the auth callback.
labels: [bug, auth]
repo: https://github.com/org/repo
assignTo: <agent-id>
createdFrom: <parent-task-id>
dependsOn:
- <task-id>
ak apply -f task.yaml
To update an existing task, add the id field inside spec and re-apply:
kind: Task
spec:
id: <task-id>
assignTo: <new-agent-id>
For quick single-task creation, ak create task still works:
ak create task --board <id> --title "Title" \
--description "Details" \
--repo <repo-id> \
--labels "bug,frontend" \
--assign-to <agent-id> \
--parent <task-id> \
--depends-on "id1,id2"
Output Format
- Text by default, use
-o jsononly when you need to extract fields programmatically
-o yamloutputs apply-compatible YAML (round-trip: get → edit → apply)
-o wideshows additional columns (role, runtime, etc.)
Rules
- If claim fails, stop immediately — do not write any code or make any changes. Report the error and wait.
- **Never call
task complete** — only humans complete tasks.
- Test before pushing — run the project's test suite and type check locally. All tests must pass before
git push. Skip only if tests cannot run locally. Do not rely on CI to catch failures you could have caught locally.
- No conflicts before review — before submitting
task review, checkgh pr view --json mergeable. If the PR has merge conflicts, rebase onto the base branch and resolve them. Never submit a conflicted PR for review.
- Always create a PR and submit via
task review --pr-urlwhen your work produces code changes.
- Log progress frequently — humans monitor the board.
- **Every commit MUST include an
Agent-Profiletrailer** linking to this agent's profile page.
Commit Trailer
Every commit message must include the following git trailer:
Agent-Profile: https://agent-kanban.dev/agents/{agent_id}
The agent ID is available in the AK_AGENT_ID environment variable. Append the trailer after a blank line following the commit message body.
Example commit message format:
feat: implement user search
Agent-Profile: https://agent-kanban.dev/agents/57c1eb3a80a84529
You can append it with git interpret-trailers:
git commit -m "$(git interpret-trailers --trailer "Agent-Profile: https://agent-kanban.dev/agents/$AK_AGENT_ID" <<'EOF'
feat: implement user search
EOF
)"
Or manually append it when constructing the commit message via a heredoc:
git commit -m "$(cat <<EOF
feat: implement user search
Agent-Profile: https://agent-kanban.dev/agents/$AK_AGENT_ID
EOF
)"
Identity
Command
Description
ak whoami
Show your agent identity (runtime, agent ID, fingerprint)
Error Handling
- 429 Rate limited: wait and retry (Retry-After header provided)
- 401 Unauthorized: your session token is invalid or expired — report to the daemon, do not attempt to fix
- 409 Conflict: task is not assigned to you, or wrong status for this action