name: superplane-cli description: Use when working with the SuperPlane CLI to discover integrations, actions, and triggers, build or troubleshoot apps and canvases, manage secrets, and monitor executions. Covers authentication, list/get commands, interpreting configuration schemas, wiring channels between nodes, resolving integration binding issues, and inspecting runs. Triggers on "superplane", "app", "canvas", "workflow", "CLI", "connect", "integration is required", "execution".
SuperPlane CLI
Operate a SuperPlane instance through the superplane CLI.
Quick Reference
| Task | Command |
|---|---|
| Connect to org | superplane connect <URL> <TOKEN> |
| Who am I | superplane whoami |
| Set active app | superplane apps active [app-id] |
| List/switch contexts | superplane contexts |
| List apps | superplane apps list |
| Generate starter YAML | superplane apps canvas init |
| Generate from template | superplane apps canvas init --template <name> |
| List canvas templates | superplane apps canvas init --list-templates |
| Create app | superplane apps create <name> then resolve a draft id and superplane apps canvas update --draft-id <draft-id> -f canvas.yaml |
| Create app from canvas YAML | superplane apps create --canvas-file canvas.yaml |
| Create app with layout flags | superplane apps create --canvas-file canvas.yaml --canvas-auto-layout horizontal |
| List drafts | superplane apps drafts list <name-or-id> |
| Create draft | superplane apps drafts create <name-or-id> [--name "..."] |
| Delete draft | superplane apps drafts delete <draft-id> [name-or-id] |
| Export canvas (live) | superplane apps canvas get <name-or-id> |
| Export canvas (draft) | superplane apps canvas get <name-or-id> --draft-id <draft-id> -o yaml |
| Update canvas | superplane apps canvas update --draft-id <draft-id> -f canvas.yaml |
| Auto layout full canvas | superplane apps canvas update --draft-id <draft-id> --auto-layout horizontal -f canvas.yaml |
| Auto layout connected subgraph | superplane apps canvas update --draft-id <draft-id> --auto-layout horizontal --auto-layout-scope connected-component --auto-layout-node <node-id> -f canvas.yaml |
| Export live console | superplane apps console get <name-or-id> -o yaml > console.yaml |
| Export draft console | superplane apps console get <name-or-id> --draft-id <draft-id> -o yaml > console.yaml |
| Update console from file | superplane apps console set --draft-id <draft-id> -f console.yaml |
| List app files | superplane apps files tree <name-or-id> |
| Show app file | superplane apps files show <path> <name-or-id> |
| List change requests | superplane apps change-requests list <name-or-id> |
| Create change request | superplane apps change-requests create <name-or-id> [--draft-id <draft-id>] |
| List available providers | superplane index integrations |
| Describe a provider | superplane index integrations --name github |
| List connected integrations | superplane integrations list |
| Inspect connected integration | superplane integrations get <id> |
| List integration resources | superplane integrations list-resources --id <id> --type <type> |
| List actions | superplane index actions |
| Actions from provider | superplane index actions --from github |
| Describe an action | superplane index actions --name semaphore.runWorkflow |
| List triggers | superplane index triggers |
| Triggers from provider | superplane index triggers --from github |
| Describe a trigger | superplane index triggers --name github.onPush |
| List secrets | superplane secrets list |
| Create secret | superplane secrets create --file secret.yaml |
| List runs | superplane runs list --app-id <id> |
| Describe a run | superplane runs describe <run-id> --app-id <id> |
| List node executions | superplane executions list --app-id <id> --node-id <nid> |
| Cancel execution | superplane executions cancel --app-id <id> --execution-id <eid> |
Verify CLI Is Installed
Before any CLI operation, confirm the CLI binary is available without requiring network access:
command -v superplane
If this does not print a path, the CLI is not installed. Stop and tell the user:
The SuperPlane CLI is not installed. Install it from https://docs.superplane.com/installation/cli and then re-run this task.
Do not attempt to install the CLI on behalf of the user. Do not continue with doc-based guesswork — the CLI provides exact trigger names, action names, integration IDs, and config schemas that documentation cannot reliably substitute.
Only after confirming the binary exists should you verify the session:
superplane whoami
Interpret failures carefully:
command not foundfromwhoamistill means the CLI is missing.- Authentication, DNS, timeout, or connection errors mean the CLI exists but the current session cannot reach SuperPlane yet. In that case, tell the user the CLI is installed but the session/network/auth is not working, and ask them to connect or allow network access as needed.
Core Workflow
1. Authenticate
Create a service account in the SuperPlane UI, then:
superplane connect https://superplane.example.com <API_TOKEN>
superplane whoami
1b. Draft Management
Versioning is always on in this environment. Every canvas or console read/write against a draft must include --draft-id <uuid>.
Resolve the draft id before editing:
# List drafts for the app (yours by default; --all for every owner)
superplane apps drafts list <name-or-id>
# Create a draft when none exists yet
superplane apps drafts create <name-or-id> [--name "wip"]
# Read, update, and verify using the id
superplane apps canvas get <name-or-id> --draft-id <draft-id> -o yaml
superplane apps canvas update --draft-id <draft-id> -f canvas.yaml
superplane apps console get <name-or-id> --draft-id <draft-id> -o yaml
superplane apps console set --draft-id <draft-id> -f console.yaml
Rules:
- Users can own multiple drafts per app. Always pass
--draft-id; do not rely on implicit draft selection. - Reuse the id from a prior update response,
apps drafts list, or agent[Draft Status]context when continuing work. --version-idis an alias for--draft-idon canvas, console, and change-request commands.superplane apps drafts delete <draft-id> [name-or-id]discards a draft (no confirmation prompt).
superplane apps canvas update --draft-id <draft-id> -f canvas.yaml
2. Discover What Exists
Run these first to understand what's available:
superplane index integrations # available providers
superplane integrations list # connected instances in this org
superplane index triggers # all trigger types
superplane index actions # all action types
Narrow to one provider:
superplane index triggers --from github
superplane index actions --from github
Inspect required config fields and payload shapes:
superplane index triggers --name github.onPush
superplane index actions --name semaphore.runWorkflow
List runtime options for integration-resource fields (e.g., repos, projects):
superplane integrations list-resources --id <integration-id> --type <type> --parameters key1=value1,key2=value2
Use superplane integrations list first to find valid integration IDs.
3. Build a Canvas Incrementally
Generate a starter YAML, then create and iterate:
superplane apps canvas init --output-file canvas.yaml
# or start from a template:
superplane apps canvas init --template health-check-monitor --output-file canvas.yaml
# edit canvas.yaml, then create:
superplane apps create --canvas-file canvas.yaml
# or create a blank canvas and iterate:
superplane apps create my-canvas
DRAFT_ID=$(superplane apps drafts create my-canvas -o json | jq -r '.metadata.id')
superplane apps canvas get my-canvas --draft-id "$DRAFT_ID" -o yaml > canvas.yaml
# edit canvas.yaml (ensure metadata.id is set)
superplane apps canvas update --draft-id "$DRAFT_ID" -f canvas.yaml
If you create an app from canvas YAML, apps create --canvas-file already sends the full canvas payload. Do not assume a second update is required just to apply the graph:
superplane apps create --canvas-file canvas.yaml
Workflow rules:
superplane apps create --canvas-file canvas.yamlaccepts the same resource-style Canvas YAML described in the spec (apiVersion,kind,metadata,spec).- On
superplane apps create, canvas layout flags are prefixed withcanvas-:--canvas-auto-layout,--canvas-auto-layout-scope, and repeated--canvas-auto-layout-node. - Run a follow-up
superplane apps canvas update ...only when you are intentionally changing the canvas after create, for example to apply additional edits from a file that includesmetadata.id, or to run auto-layout with different flags than the defaults used on create. - Resolve a draft id with
apps drafts listorapps drafts create, then include--draft-idon every canvas/console draft command.
See Canvas YAML Spec for the full format.
Console YAML via CLI
Use superplane apps console to read and replace the app console: panels plus grid layout.
Commands:
# With an explicit app name or id (replace <draft-id> from apps drafts list/create)
superplane apps console get <name-or-id>
superplane apps console get <name-or-id> --draft-id <draft-id>
superplane apps console get <name-or-id> -o yaml > console.yaml
superplane apps console get <name-or-id> --draft-id <draft-id> -o yaml > console.yaml
superplane apps console set --draft-id <draft-id> -f console.yaml
superplane apps console set <name-or-id> --draft-id <draft-id> -f console.yaml
superplane apps console set <name-or-id> --draft-id <draft-id> -f - < console.yaml
# With the active app from `superplane apps active`
superplane apps console get
superplane apps drafts list
superplane apps console set --draft-id <draft-id> -f console.yaml
Behavior:
getwithout--draft-idreads the live console.get --draft-idreads that draft's console YAML.set --draft-idwrites panels and layout to the specified draft version.- Console import is replace-all: the YAML replaces every panel and layout entry.
- Use
-o yamlwhen exporting a file intended for editing/import.
See Console YAML Spec for the stable YAML envelope, layout fields, and where to find current widget details.
Auto Layout via CLI
Use apps canvas update with auto-layout flags:
Default agent behavior:
- Auto layout is applied by default on
superplane apps canvas updatewhen no auto-layout flags are provided. - Use
--auto-layoutflags when you need explicit scope/seed-node control. - Include
--draft-idon every draft update command in this environment.
# connected component around one seed node (recommended default for existing canvases)
superplane apps canvas update --draft-id <draft-id> \
-f canvas.yaml \
--auto-layout horizontal \
--auto-layout-scope connected-component \
--auto-layout-node <node-id>
# full canvas (use sparingly; see policy below)
superplane apps canvas update --draft-id <draft-id> -f canvas.yaml --auto-layout horizontal
Rules and behavior:
--auto-layoutis required when using--auto-layout-scopeor--auto-layout-node.--draft-idis required on draft update commands in this environment.- Supported algorithm:
horizontal. - Supported scopes:
full-canvas,connected-component. - Default scope behavior:
- If no seed nodes are provided: behaves like
full-canvas. - If seed nodes are provided and scope omitted: behaves like
connected-component.
- If no seed nodes are provided: behaves like
- Recommended policy for agents:
- Prefer
connected-componentfor existing/disconnected canvases. - Use
full-canvasonly when creating from scratch, when the graph is one connected component, or when the user explicitly asks for full-canvas layout.
- Prefer
- Scope selection default:
- If a changed/selected node ID is known, use
connected-component+--auto-layout-node. - If a set of changed node IDs is known, use
connected-component+ repeated--auto-layout-node. - If no node IDs are available, use
full-canvas.
- If a changed/selected node ID is known, use
- Positioning is anchor-preserving: the laid-out region keeps its top-left anchor relative to current canvas coordinates to avoid large jumps.
4. Manage Secrets
superplane secrets create --file secret.yaml
superplane secrets list
superplane secrets update --file secret.yaml
superplane secrets delete <name_or_id>
5. Monitor Runs
superplane runs list --app-id <id>
superplane runs describe <run-id> --app-id <id>
6. Troubleshooting Checklist
Run after every canvas update:
superplane apps canvas get <name>
Check:
- All required
configurationfields are present - Edges use the correct output channels
- No node
errorMessageremains (especially "integration is required") - No
warningMessageabout duplicate names - Expressions reference existing node names (case-sensitive)
Resolving "integration is required"
When a field type is integration-resource (like repository or project), the node needs a connected integration instance.
superplane integrations list— confirm the provider is connectedsuperplane integrations get <id>— inspect the connection- Add
integration.idto the node in the canvas YAML superplane integrations list-resources --id <id> --type <type>— find valid resource valuessuperplane apps canvas update --draft-id <draft-id> -f canvas.yaml— apply the fixsuperplane apps canvas get <name-or-id> --draft-id <draft-id>— verify errors are cleared
When to Use Other Skills
| Need | Use Skill |
|---|---|
| Design a canvas from requirements | superplane-app-builder |
| Debug a failed execution | superplane-monitor |
Documentation
For agents that can fetch URLs, the full SuperPlane docs are available in LLM-friendly format:
- Compact index: https://docs.superplane.com/llms.txt
- Full content: https://docs.superplane.com/llms-full.txt
References
- Canvas YAML Spec — Full YAML format with examples
- Console YAML Spec — Stable console YAML envelope and layout format