CLI Reference¶
Orcheo ships with a LangGraph-friendly CLI for node discovery, workflow inspection, credential management, and reference code generation.
Getting Started¶
After installing the SDK, the CLI is available immediately:
Check which version you have installed:
Global Options¶
| Flag | Environment Variable | Description |
|---|---|---|
--version |
— | Show the installed CLI version and exit. |
--human |
ORCHEO_HUMAN=1 |
Use human-friendly Rich output (colored tables, panels). Without this flag, the CLI defaults to machine-readable output (JSON, Markdown tables) suitable for scripting and piping. |
--profile <name> |
ORCHEO_PROFILE |
Select a named profile from cli.toml. |
--api-url <url> |
ORCHEO_API_URL |
Override the backend API URL. |
--service-token <token> |
ORCHEO_SERVICE_TOKEN |
Override the service token. |
--offline |
— | Fall back to cached data when network calls fail. |
--cache-ttl <hours> |
— | Cache TTL in hours for offline data (default: 24). |
--no-update-check |
ORCHEO_DISABLE_UPDATE_CHECK=1 |
Skip startup update reminders for the current invocation. |
Output Modes¶
By default the CLI produces machine-readable output: lists render as Markdown tables, detail views render as JSON, and errors are returned as JSON objects. This makes the CLI suitable for use in scripts, CI pipelines, and tool integrations.
To get human-friendly output with Rich formatting (colored tables, syntax highlighting, status panels), pass --human or set the ORCHEO_HUMAN environment variable to a truthy value (1, true, yes, on):
# Machine-readable (default)
orcheo workflow list
# Human-friendly
orcheo --human workflow list
# Or via environment variable
export ORCHEO_HUMAN=1
orcheo workflow list
Shell Auto-Completion¶
Enable fast shell auto-completion for commands and options:
This installs completion for your current shell (bash, zsh, fish, or PowerShell). After installation, restart your shell or source your shell configuration file.
Available Commands¶
| Command | Description |
|---|---|
orcheo node list [--tag <tag>] |
List registered nodes with metadata (name, category, description). Filter by tag. |
orcheo node show <node> |
Display detailed node schema, inputs/outputs, and credential requirements. |
orcheo edge list [--category <category>] |
List registered edges with metadata (name, category, description). Filter by category. |
orcheo edge show <edge> |
Display detailed edge schema and conditional routing configuration. Canonical built-ins use the *Edge suffix. |
orcheo plugin list [--runtime auto\|local\|stack] |
List installed plugins with enabled state, status, version, exports, and source ref. |
orcheo plugin show <plugin> [--runtime auto\|local\|stack] |
Show plugin manifest, compatibility, entry points, and resolved install state. |
orcheo plugin install <ref> [--runtime auto\|local\|stack] |
Install a plugin from a package name, pinned package, local path, wheel, or Git URL. |
orcheo plugin update <plugin> [--runtime auto\|local\|stack] |
Rebuild and update one plugin from its stored source ref. |
orcheo plugin update --all [--runtime auto\|local\|stack] |
Rebuild and update all configured plugins. |
orcheo plugin uninstall <plugin> [--runtime auto\|local\|stack] |
Remove a plugin and rebuild the shared plugin environment. |
orcheo plugin enable <plugin> [--runtime auto\|local\|stack] |
Mark an installed plugin enabled so the runtime may load it. |
orcheo plugin disable <plugin> [--runtime auto\|local\|stack] |
Mark an installed plugin disabled without forgetting its install source. |
orcheo plugin doctor [--runtime auto\|local\|stack] |
Run non-destructive diagnostics against plugin state, compatibility, and importability. |
orcheo agent-tool list [--category <category>] |
List available agent tools with metadata. Filter by category. |
orcheo agent-tool show <tool> |
Display detailed tool schema and parameter information. |
orcheo workflow list [--include-archived] |
List workflows with owner, last run, and status. |
orcheo workflow show <workflow> [--version <num>] |
Print workflow summary, publish status/details, Mermaid graph, and runs. Use --version to show a specific version instead of the latest. |
orcheo workflow run <workflow> [--inputs <json> \| --inputs-file <path>] [--config <json> \| --config-file <path>] [--verbose] [--stream/--no-stream] |
Trigger a workflow execution. Streaming is enabled by default. |
orcheo workflow evaluate <workflow> [--inputs <json> \| --inputs-file <path>] [--config <json> \| --config-file <path>] [--evaluation <json> \| --evaluation-file <path>] [--verbose] [--stream/--no-stream] |
Trigger a workflow evaluation run (requires streaming mode). |
orcheo workflow update <workflow> [--name <name>] [--description <text>] [--handle <handle>] [--chatkit-prompts <json> \| --chatkit-prompts-file <path> \| --clear-chatkit-prompts] |
Update workflow metadata, including per-workflow public ChatKit starter prompts. |
orcheo workflow upload <file> [--id <ref>] [--name <name>] [--entrypoint <name>] [--config <json> \| --config-file <path>] |
Upload a workflow from a Python LangGraph script (.py). The script may declare an optional # /// orcheo ... # /// frontmatter block whose values are used as defaults (CLI flags override). |
orcheo workflow save-config <workflow> [--version <num>] (--config <json> \| --config-file <path> \| --clear) |
Save version runnable_config without creating a new version. |
orcheo workflow download <workflow> [-o <file>] [--config-out <file>] [--version <num>] |
Download workflow source as Python only. Use --config-out to write stored runnable config JSON when present, and --version to download a specific version. |
orcheo workflow delete <workflow> [--force] |
Delete a workflow with confirmation safeguards. |
orcheo workflow schedule <workflow> |
Activate cron scheduling based on the workflow's cron trigger (no-op if none). |
orcheo workflow unschedule <workflow> |
Remove cron scheduling for the workflow. |
orcheo workflow publish <workflow> [--require-login] [--chatkit-public-base-url <url>] |
Publish a workflow for public ChatKit access, optionally requiring OAuth login and overriding the share-link origin for that run. |
orcheo workflow unpublish <workflow> |
Revoke public access and invalidate existing share links. |
orcheo credential list [--workflow-id <id>] |
List credentials with scopes, expiry, and health status. |
orcheo credential create <name> --provider <provider> --secret <secret> |
Create a new credential with guided prompts. --secret is required. |
orcheo credential delete <credential> [--force] |
Revoke a credential with confirmation safeguards. |
orcheo auth login [--no-browser] [--port <port>] |
Authenticate via browser-based OAuth flow. |
orcheo auth logout |
Clear stored OAuth tokens for the current profile. |
orcheo auth status |
Show current authentication status (OAuth or service token). |
orcheo token create [--id <id>] [--scope <scope>] |
Create a service token for CLI/API authentication. |
orcheo token list |
List all service tokens with their scopes and status. |
orcheo token show <token-id> |
Show detailed information for a specific service token. |
orcheo token rotate <token-id> [--overlap <seconds>] |
Rotate a service token with grace period overlap. |
orcheo token revoke <token-id> [--reason <reason>] |
Immediately invalidate a service token. |
orcheo config [--profile <name>] [--api-url <url>] [--service-token <token>] [--env-file <path>] |
Write CLI profile settings to cli.toml. Supports OAuth options (see below). |
orcheo code template [-o <file>] [--name <name>] |
Generate a minimal Python LangGraph workflow template file. |
orcheo code scaffold <workflow> |
Generate Python SDK code snippets to invoke an existing workflow. |
orcheo install [--yes] [--mode install\|upgrade] [--stack-version <version>] [--auth-mode api-key\|oauth] [--chatkit-domain-key <key>] |
Guided Docker-stack setup/upgrade (asset sync, .env updates, optional compose startup). |
orcheo install upgrade [--yes] [--stack-version <version>] [--auth-mode api-key\|oauth] [--chatkit-domain-key <key>] |
Guided upgrade shortcut command. |
orcheo install syncs stack assets into ~/.orcheo/stack (or
ORCHEO_STACK_DIR). Files are refreshed when upstream content differs.
Use --stack-version (or ORCHEO_STACK_VERSION) to pin stack assets to a
specific stack-v* tag and set ORCHEO_STACK_IMAGE accordingly.
When startup is enabled (--start-stack), setup then runs Docker Compose
(Docker must be installed). Setup also prompts for
VITE_ORCHEO_CHATKIT_DOMAIN_KEY; you can skip and continue, but ChatKit UI
features stay disabled until the key is set.
Edge Naming¶
Built-in branching edges use canonical names with an Edge suffix:
IfElseEdgeSwitchEdgeWhileEdge
orcheo edge list emits these canonical names. New examples and custom
registrations should use the canonical *Edge names.
Plugin Management¶
The plugin subsystem uses a shared managed virtual environment plus desired and
lock state files under ~/.orcheo/plugins/ by default:
Cached plugin downloads and metadata live under ~/.cache/orcheo/plugins/.
Set ORCHEO_PLUGIN_DIR to relocate the runtime-managed plugin tree. The cache
root continues to follow ORCHEO_CACHE_DIR.
Supported plugin refs:
- package:
orcheo-plugin-acme - pinned package:
orcheo-plugin-acme==0.1.0 - local path:
./plugins/orcheo-plugin-acme - wheel:
dist/orcheo_plugin_acme-0.1.0-py3-none-any.whl - git:
git+https://github.com/acme/orcheo-plugin-acme.git
orcheo plugin install, update, disable, and uninstall classify changes
as silent hot reload, confirmation-required hot reload, or restart-required.
Listener and trigger plugins always surface restart guidance because they are
not hot-reloadable in v1.
orcheo plugin doctor checks the managed plugin venv, Python version,
importability of enabled plugins, manifest hash integrity, plugin API
compatibility, Orcheo version compatibility, disabled-plugin references, and
lock consistency. It exits 1 when any error-level diagnostic is present.
Validation listener plugins¶
Two reference plugins exercise the listener-plugin contract end to end:
orcheo plugin install "git+https://github.com/AI-Colleagues/orcheo-plugin-wecom-listener.git"
orcheo plugin install "git+https://github.com/AI-Colleagues/orcheo-plugin-lark-listener.git"
They register:
WeComListenerPluginNode+ listener platformwecomLarkListenerPluginNode+ listener platformlark
Both plugins are intended to be operated through the plugin CLI. Because they export listeners, install, update, disable, and uninstall operations should be treated as restart or reconcile events for affected runtime processes.
Plugin troubleshooting¶
Common operator flows:
- Broken import on startup: run
orcheo plugin doctor, thenorcheo plugin disable <name>if you need to restore service health quickly. - Compatibility failure:
orcheo plugin show <name>andorcheo plugin doctorwill surface plugin API or Orcheo version mismatches. Reinstall a compatible plugin version or upgrade the plugin package. - Integrity drift: if
plugin doctorreports manifest or lock inconsistencies, reinstall or update the affected plugin so the managed venv and lock state are rebuilt together.
Workflow Commands¶
Running Workflows¶
Pass workflow inputs inline with --inputs or from disk via --inputs-file. Use --config or --config-file to provide LangChain runnable configuration for execution (each pair is mutually exclusive).
# Run with inline inputs
orcheo workflow run my-workflow --inputs '{"query": "hello"}'
# Run with inputs from file
orcheo workflow run my-workflow --inputs-file inputs.json
Streaming options:
--stream(default): stream node and trace updates in real time.--no-stream: disable streaming forworkflow runand create the run via API response payload.--verbose: include full payload output for stream updates.
In machine-readable mode (default, without --human), --verbose emits JSON event lines, including a start event (workflow.execution.start) and raw WebSocket updates until terminal status.
Evaluating Workflows¶
Use workflow evaluate to run Agentensor evaluation mode:
# Evaluate with inline payload
orcheo workflow evaluate my-workflow \
--inputs '{"query": "hello"}' \
--evaluation '{"dataset": {"name": "golden"}}'
# Evaluate with files
orcheo workflow evaluate my-workflow \
--inputs-file inputs.json \
--evaluation-file evaluation.json \
--verbose
workflow evaluate uses streaming mode and surfaces start events as workflow.evaluation.start in machine-readable verbose output.
Publishing Workflows¶
Published workflows remain accessible until you run orcheo workflow unpublish <workflow> or toggle the --require-login flag to gate public chats behind OAuth.
# Publish a workflow for public access
orcheo workflow publish my-workflow
# Publish with login required
orcheo workflow publish my-workflow --require-login
# Revoke public access
orcheo workflow unpublish my-workflow
Workflow Configuration¶
Upload-time defaults can be stored on a workflow version with orcheo workflow upload ... --config or --config-file. You can update config later without creating a version via orcheo workflow save-config .... Stored config is merged with per-run overrides (run config wins). orcheo workflow download --config-out <file> writes that stored runnable config as companion JSON when present. Avoid putting secrets in runnable config; use environment variables or credential vaults instead.
Workflow Frontmatter¶
Workflow .py files may include an optional PEP 723-style metadata block. When present, the orcheo workflow upload command reads it as the source of truth for the workflow's name, target id/handle, companion config file, and entrypoint. Any explicit CLI flag overrides the matching frontmatter field.
# /// orcheo
# name = "My Workflow"
# id = "wf-abc123"
# config = "./my-workflow.config.json"
# entrypoint = "build_graph"
# emoji = "🤖"
# subtitle = "AI Assistant"
# ///
from langgraph.graph import StateGraph
def build_graph():
return StateGraph(dict)
Supported fields (all optional):
name– display name used when creating or renaming the workflow.id(orhandle) – workflow reference; when set, the upload updates this existing workflow instead of creating a new one.config– path to a companion JSON runnable config file. Relative paths resolve against the workflow file's directory.entrypoint– LangGraph entrypoint function/variable name.emoji– emoji shown on the colleague's Candidates badge in Canvas.subtitle– short role line shown on the Candidates badge.notes– free-form notes describing the workflow template.metadata– a[metadata]table of template compatibility info (e.g.required_plugins,validated_provider_api).
The block is parsed as TOML; only the fields above are accepted. CLI flags (--name, --id, --config-file, --entrypoint) always win over the frontmatter values.
Offline Mode¶
Pass --offline to reuse cached metadata when disconnected:
Configuration¶
The CLI reads configuration from (highest precedence first):
- Command flags:
--api-url,--service-token,--profile - Environment variables:
ORCHEO_API_URL,ORCHEO_SERVICE_TOKEN - Config file:
~/.config/orcheo/cli.toml(profiles for multiple environments)
Writing Profiles with orcheo config¶
The config command writes profile settings to cli.toml, pulling values from flags, an .env file, or the current environment:
# Write a profile from flags
orcheo config --api-url https://api.example.com --service-token sk-...
# Write a named profile
orcheo config --profile staging --api-url https://staging.example.com
# Import settings from a .env file
orcheo config --env-file .env
# Write multiple profiles at once
orcheo config --profile dev --profile staging --env-file .env
The config command also accepts OAuth settings for browser-based authentication:
| Flag | Environment Variable | Config Key |
|---|---|---|
--auth-issuer |
ORCHEO_AUTH_ISSUER |
auth_issuer |
--auth-client-id |
ORCHEO_AUTH_CLIENT_ID |
auth_client_id |
--auth-scopes |
ORCHEO_AUTH_SCOPES |
auth_scopes |
--auth-audience |
ORCHEO_AUTH_AUDIENCE |
auth_audience |
--auth-organization |
ORCHEO_AUTH_ORGANIZATION |
auth_organization |
--chatkit-public-base-url |
ORCHEO_CHATKIT_PUBLIC_BASE_URL |
chatkit_public_base_url |
Once written to a profile, these values are used by orcheo auth login and other commands without needing environment variables.
See Environment Variables for the complete configuration reference.