| name | task-management |
| description | Use before any Leader taskflow call or task-level workflow involving delegating a ready DAG or Loop node, writing task meta/spec, checking a Worker task result, handling result statuses, task directory ownership, or Worker result contracts. Always use this skill when the request mentions delegate_task, check_task, task result.md, task spec.md, BLOCKED, REVISION_NEEDED, INTERRUPTED, SUCCESS, or assigning/delegating a Worker task. |
Task Management
You manage individual Worker task delegation and result checks. Use this skill as the task execution layer. Use team-coordination for work organization strategy and project-management for Project state, DAG, Loop, lifecycle, and ready-node operations.
Scope
Use this skill for:
taskflow calls
- creating Leader-owned task files
- delegating one ready DAG or Loop node
- checking one submitted Worker result
- enforcing task file ownership
- enforcing Worker result contracts
Do not use this skill to choose DAG vs Loop, design the project graph, pause/resume/complete a Project, or aggregate the final Project result.
Ownership
You own:
shared/tasks/{task-id}/meta.json
shared/tasks/{task-id}/spec.md
The Worker owns:
shared/tasks/{task-id}/workspace/
shared/tasks/{task-id}/<deliverables>
shared/tasks/{task-id}/result.md
Do not ask Workers to edit Project-level files:
shared/projects/{project-id}/meta.json
shared/projects/{project-id}/plan.md
shared/projects/{project-id}/result.md
Tool Boundary
Use taskflow for Leader task actions:
Worker runtimes use their own task actions:
Use project-management for:
create_project
plan_dag
ready_nodes
plan_loop
ready_loop_nodes
record_loop_iteration
pause_project
resume_project
complete_project
Do not call check_active_tasks from heartbeat or routine recovery checks for now; Kubernetes Team Workers do not expose per-Worker /api/chats Services, so runtime probes can misreport healthy Workers as unreachable.
taskflow handles file sync internally: delegate_task auto-pushes the task directory, check_task auto-pulls the task directory. Use filesync separately only for project-level files or non-task shared files.
Task Spec Language
Write task specs in the language selected by AGENTS.md Response Language.
Localize:
- prose
- headings
- task titles
- context
- deliverable descriptions
- constraints
- next-step wording
Keep machine-facing identifiers and protocol tokens unchanged:
- task IDs
- paths
result.md
STATUS
SUMMARY
DELIVERABLES
SUCCESS
SUCCESS_WITH_NOTES
REVISION_NEEDED
BLOCKED
INTERRUPTED
Worker Name Canonicality
assigned_to, Matrix @mention, and all task tracking fields must use the Worker's Matrix localpart (the part between @ and : in matrixUserID). Extract it mechanically — never guess, strip, or transform.
Lookup (mandatory before assigning any task)
TEAM_CR="$(hiclaw get workers "${HICLAW_WORKER_CR_NAME:-$HICLAW_WORKER_NAME}" -o json | jq -r '.team')"
hiclaw get workers --team "$TEAM_CR" -o json
Use the extracted localpart verbatim everywhere:
manage-team-state.sh --assigned-to <localpart>
- Matrix @mention:
@<localpart>:<domain>
meta.json assigned_to field
Common mistake
CLI .name may include a deployment prefix (e.g. magic-cn-x0a4t4pr201-worker-issue-resolver). Do NOT use .name directly and do NOT manually strip prefixes. Always extract the localpart from .matrixUserID instead.
CLI .name | matrixUserID | ✅ assigned_to | ❌ Wrong |
|---|
magic-cn-...-worker-issue-resolver | @worker-issue-resolver:domain | worker-issue-resolver | issue-resolver |
magic-cn-...-dev-worker | @dev-worker:domain | dev-worker | worker |
Delegate A Ready Node
Delegate only nodes returned by:
projectflow(action="ready_nodes") for DAG plans
projectflow(action="ready_loop_nodes") for Loop plans
Do not create bare tasks directly from external requests. Start from the Project plan.
Before delegation:
- Pull
shared/projects/{project-id}/.
- Read Project
meta.json and plan.md.
- Confirm the Project is active.
- Resolve ready nodes with
project-management.
- Select one ready node.
Create the task with taskflow(action="delegate_task"):
{
"action": "delegate_task",
"payload": {
"projectId": "{project-id}",
"taskId": "{task-id}",
"roomId": "room:!team-room:domain",
"spec": "# <localized task heading>: <title>\n\n## <localized context heading>\n...\n\n## <localized expected result heading>\n<localized instructions. Keep deliverables under shared/tasks/{task-id}/ and publish result.md with STATUS, SUMMARY, and DELIVERABLES.>"
}
}
roomId is required. Set it to the Matrix room where this task was assigned and where the Worker must report completion. For Team work, use the Team Room. For external delegation, use that external assignment room.
delegate_task writes:
shared/tasks/{task-id}/meta.json
shared/tasks/{task-id}/spec.md
It also updates the plan marker from [ ] to [~]. Treat [~] as delegated/assigned from your perspective, not proof that the Worker is actively executing.
After delegation:
delegate_task auto-pushes shared/tasks/{task-id}/. Do not call filesync push for the task directory.
- Publish
shared/projects/{project-id}/, because the plan marker changed.
- @mention the assigned Worker in the assignment room.
- Include only the task ID, title, and instruction to start.
Do not prescribe Worker-internal acknowledgement, push, submit, or planning steps.
Check A Submitted Task
When a Worker reports completion:
-
In the current room, directly say that you received the message.
-
Check the submitted task:
{
"action": "check_task",
"payload": {
"taskId": "{task-id}"
}
}
check_task auto-pulls shared/tasks/{task-id}/ and returns the task meta (task field with project_id, room_id, assigned Worker) and the validated result (result field with status, summary, deliverables). Do not call filesync pull or read_file for task files separately.
-
Pull shared/projects/{project-id}/.
-
Read Project meta.json and plan.md.
-
If the Project is paused, stop. Do not check or accept the result, mark [x], resolve ready nodes, call plan_dag, call plan_loop, or delegate follow-up work. Tell the requester that a Worker result arrived while the Project is paused and wait for explicit direction.
-
Return to team-coordination and decide whether the result satisfies the Project delivery criteria.
-
Return to project-management and apply the Project-level decision:
- If accepted, update the plan node to
[x], publish Project files, and resolve ready nodes.
- If revision, repair, verification, replanning, or blocker handling is needed, do not mark
[x]; create or replace plan nodes as needed.
-
Delegate any ready downstream nodes through the normal ready-node delegation flow.
-
Close the completion loop with requester visibility:
- Read
project-management and use the Project Status Reports template for the report content.
- Read
communication.
- Use the Requester Reports routing rules.
- Report to the requester recorded on the Project.
- If the requester is Team Admin, notify the Team Admin in Leader DM.
- If the Worker completion arrived in the Team Room, do not treat the Team Room reply or downstream task assignment as the requester update.
-
You may batch multiple Worker completions and downstream delegations into one requester report, but do not omit Step 9 when Project state changed. Task handling is not complete until the requester or DM admin has been notified.
Project directory pulls in these flows are blocking. If shared/projects/{project-id}/ cannot be pulled as a directory, stop and report the sync failure. Do not switch to pulling only meta.json or plan.md and then modify the plan.
Result Contract
Worker result.md is parsed with this contract:
STATUS: SUCCESS
SUMMARY: Short summary of the result
DELIVERABLES:
- shared/tasks/{task-id}/path/to/output
NOTES:
- Optional note
Valid statuses:
| Status | Meaning |
|---|
SUCCESS | Candidate dependency input; you must accept it before it can unblock downstream work |
SUCCESS_WITH_NOTES | Candidate dependency input with notes; you must accept it before it can unblock downstream work |
REVISION_NEEDED | Worker task ended; you must decide the next graph shape |
BLOCKED | Worker task ended; you must escalate, ask, or replan |
INTERRUPTED | Runtime/control-plane interruption ended the task; do not accept it by default |
Deliverable paths must be under:
shared/tasks/{task-id}/
SUCCESS and SUCCESS_WITH_NOTES are effective only as candidate results. Dependencies advance only after you accept the result and mark the plan node [x].
Submitting a result ends the Worker task. Do not resume, rewrite, or mutate the old task. Use project-management to plan a new DAG or Loop node if more work is needed.
Plan Markers
Project plans use these task markers:
| Marker | Meaning |
|---|
[ ] | pending |
[~] | delegated |
[x] | completed / accepted by you |
[!] | blocked |
[→] | revision |
Use the Unicode arrow marker for revision in plan.md; the parser expects that single marker character.
Only [x] satisfies dependencies for ready_nodes and ready_loop_nodes.
References
Read only when needed:
references/dag-tasks.md - detailed task creation and completion workflow for DAG or Loop plan nodes.
Patch Rules
Do not:
- put organization strategy into
task-management
- create tasks that were not returned by ready-node resolution
- mark completion before checking the task result with
check_task
- mark
[x] just because the Worker wrote SUCCESS
- ask Workers to edit Project-level files