Workflows
Workflows define triggers, manual inputs, and lifecycle stages, then run inside a published workspace.
How workflows work
A workflow watches an external system or accepts a manual trigger, creates an agent with scoped access from its workspace, injects event context, and tracks the work through issue, code, PR, review, and completion states.
Author workflow YAML under .elasticclaw/workflows/, then publish it to a workspace with elasticclaw workflow push.
Workflow file
schema_version: v1
name: triage
enabled: true
trigger:
github_issues:
event: issue_labeled
repositories:
- my-org/my-app
states:
- open
labels:
- agent-ready
labelers:
- "*"
provider: daytona
tags: ["triage"]
color: teal
secret_refs:
GITHUB_TOKEN: github_app
enable_manual_trigger: true
inputs:
- name: issue
type: string
required: true
stages:
- id: working
label: Working
entry: true
on_enter:
remove_labels: [agent-ready]
add_labels: [agent-working]
inject: |
Issue: {{.Issue.Identifier}} — {{.Issue.Title}}
URL: {{.Issue.URL}}
Read CONTEXT.md and start working.
- id: pr_opened
label: PR Opened
triggers:
- message_contains: "[DONE]"
on_enter:
add_labels: [needs-review]
remove_labels: [agent-working]
- id: merged
label: Merged
triggers:
- pr_merged: {}
terminal: trueWorkflow fields
name — Workflow identifier inside the workspace.
enabled — Set false to pause the workflow.
trigger.github_issues — GitHub Issues source. Supports issue events, repositories, states, labels, labelers, and assignee filters.
trigger.linear — Linear source. Supports status-change events, states, team, labels, and assignee filters.
provider — Sandbox provider override for agents created by this workflow.
tags and color — Dashboard metadata for created agents.
secret_refs — Environment variable to workspace secret name map.
inputs — Manual trigger inputs.
concurrency_group — Limit parallel agents by group.
enable_manual_trigger — Allow dashboard and CLI manual triggers.
stages — Lifecycle stages used by the workflow.
CLI commands
elasticclaw workspace create --name my-app
elasticclaw workspace push my-app
elasticclaw workflow push --workspace my-app .elasticclaw/workflows/triage.yaml
elasticclaw workflow list --workspace my-app
elasticclaw workflow show triage --workspace my-app
elasticclaw workflow trigger triage --workspace my-app --input issue=ENG-123