Install
openclaw skills install codebase-guideUse for every task involving this project. Covers running Ganglion, its CLI commands, HTTP bridge API, pipeline execution, knowledge queries, configuration, and operational workflows. Trigger phrases: 'run the pipeline', 'start the server', 'check status', 'query knowledge', 'configure', 'call the API', 'scaffold a project', 'check metrics', 'rollback', 'swap policy'.
openclaw skills install codebase-guideGanglion is a domain-specific execution engine for Bittensor subnet mining. It provides a pipeline framework for orchestrating autonomous mining agents that search for optimal model configurations. It exposes a CLI, an HTTP bridge API, and a Python library. Ganglion is search infrastructure — it doesn't know what a good model looks like, it knows how to search for one.
# Scaffold a new project
ganglion init ./my-subnet --subnet sn9 --netuid 9
# Check state (local mode)
ganglion status ./my-subnet
ganglion tools ./my-subnet
ganglion agents ./my-subnet
ganglion knowledge ./my-subnet --capability training --max-entries 10
ganglion pipeline ./my-subnet
# Run (local mode)
ganglion run ./my-subnet
ganglion run ./my-subnet --stage plan
ganglion run ./my-subnet --overrides '{"target_metric":"accuracy"}'
# Start HTTP bridge (remote mode)
ganglion serve ./my-subnet --bot-id alpha --port 8899
# Check state (remote mode)
curl -s "$GANGLION_URL/v1/status" | jq .data
Ganglion supports two modes. Always check which mode applies before running commands.
GANGLION_URL set, or GANGLION_PROJECT is set. Use ganglion <command> <project_dir> directly.GANGLION_URL is set. Use curl against the HTTP bridge.if [ -n "$GANGLION_PROJECT" ] || [ -z "$GANGLION_URL" ]; then
echo "local"
else
echo "remote"
fi
All HTTP bridge endpoints (except health probes) return responses in a standard envelope:
{"data": <payload>} — use jq .data to extract{"detail": {"error": {"code": "ERROR_CODE", "message": "..."}}}Health probes (/healthz, /readyz) return raw JSON without the envelope.
Interactive API docs: $GANGLION_URL/v1/docs (Swagger UI).
Note: Unversioned routes (e.g.
/status) still work but are deprecated. Always use/v1/.
Prerequisites: Python >= 3.11, OPENAI_API_KEY set (used by the LLM runtime).
Install: pip install ganglion
Scaffold a project:
ganglion init ./my-subnet --subnet sn9 --netuid 9
This creates config.py, tools/, agents/, and skill/ in the target directory.
Start in local mode:
export GANGLION_PROJECT=./my-subnet
ganglion status $GANGLION_PROJECT
Start in remote mode:
ganglion serve ./my-subnet --bot-id alpha --port 8899
export GANGLION_URL=http://127.0.0.1:8899
The project directory must contain a config.py that defines subnet_config (SubnetConfig) and pipeline (PipelineDef). See {baseDir}/references/configuration.md for full config details.
Query the current framework state — registered tools, agents, pipeline definition, knowledge, metrics, and run history. Local mode uses CLI commands; remote mode uses GET endpoints.
Full reference: {baseDir}/references/commands.md
Run the full pipeline or a single stage. The orchestrator executes stages in dependency order, applies retry policies, injects accumulated knowledge into agent prompts, and records outcomes.
# Local
ganglion run ./my-subnet
ganglion run ./my-subnet --stage plan
# Remote
curl -s -X POST "$GANGLION_URL/v1/run/pipeline" -H "Content-Type: application/json" -d '{}' | jq .data
curl -s -X POST "$GANGLION_URL/v1/run/stage/plan" -H "Content-Type: application/json" -d '{}' | jq .data
Register new tools, agents, and components; patch the pipeline; swap retry policies; update prompts. All mutations are validated, audited, and reversible.
# Register a tool
curl -s -X POST "$GANGLION_URL/v1/tools" -H "Content-Type: application/json" \
-d '{"name":"my_tool","code":"<code>","category":"training"}' | jq .data
# Patch pipeline
curl -s -X PATCH "$GANGLION_URL/v1/pipeline" -H "Content-Type: application/json" \
-d '{"operations":[{"op":"add_stage","stage":{"name":"validate","agent":"Validator","depends_on":["train"]}}]}' | jq .data
Pipeline operations: add_stage, remove_stage, update_stage. See {baseDir}/references/commands.md for all mutation endpoints.
Cross-run strategic memory that compounds over time. Records patterns (what worked) and antipatterns (what failed), then automatically injects relevant history into agent prompts. Knowledge is queried by capability and filtered by bot_id for multi-bot setups.
# Local
ganglion knowledge ./my-subnet --bot-id alpha --capability training
# Remote
curl -s "$GANGLION_URL/v1/knowledge?capability=training&max_entries=10" | jq
Undo any mutation. Every mutation is recorded in an audit log with rollback data.
curl -s -X POST "$GANGLION_URL/v1/rollback/last" | jq
curl -s -X POST "$GANGLION_URL/v1/rollback/0" | jq # undo ALL mutations
Multiple OpenClaw sessions share a knowledge pool via --bot-id. Each bot's discoveries flow into the shared pool. Cooperation emerges from shared knowledge, not explicit coordination.
# Two local sessions
ganglion run ./my-subnet --bot-id alpha
ganglion run ./my-subnet --bot-id beta
# Two remote servers
ganglion serve ./my-subnet --bot-id alpha --port 8899
ganglion serve ./my-subnet --bot-id beta --port 8900
Connect to external MCP servers to add tools to the agent's repertoire at runtime. Tools from MCP servers appear as regular Ganglion tools with a prefix.
# Static: add to config.py
# from ganglion.mcp.config import MCPClientConfig
# mcp_clients = [MCPClientConfig(name="weather", transport="stdio", command=["python", "-m", "weather_server"])]
# Dynamic: add at runtime via API
curl -s -X POST "$GANGLION_URL/v1/mcp/servers" -H "Content-Type: application/json" \
-d '{"name":"weather","transport":"stdio","command":["python","-m","weather_server"]}' | jq .data
# Check connected MCP servers
curl -s "$GANGLION_URL/v1/mcp" | jq .data
# Disconnect
curl -s -X DELETE "$GANGLION_URL/v1/mcp/servers/weather" | jq .data
# Expose Ganglion tools as MCP server (for Claude Desktop etc.)
ganglion mcp-serve ./my-subnet --transport stdio
See {baseDir}/examples/common-workflows.md for full step-by-step guides.
ganglion init → edit config.py → ganglion run--bot-id values on the same project| Symptom | Likely Cause | Fix |
|---|---|---|
FileNotFoundError: No config.py | Wrong project path | Verify path contains config.py |
OPENAI_API_KEY errors | Missing or invalid API key | export OPENAI_API_KEY=sk-... |
ConcurrentMutationError | Mutating during a pipeline run | Wait for the run to finish |
PipelineValidationError | Invalid pipeline DAG (cycles, missing deps) | Check ganglion pipeline output |
| Agent stuck / max turns reached | Agent cannot make progress | Review knowledge, swap retry policy, adjust prompts |
Full troubleshooting: {baseDir}/references/troubleshooting.md
Four built-in policies control how stages retry on failure:
Three presets: SN50_PRESET (escalating + stall detection), SIMPLE_PRESET (fixed), AGGRESSIVE_PRESET (model escalation).
{baseDir}/references/commands.md{baseDir}/references/configuration.md{baseDir}/references/operations.md{baseDir}/references/troubleshooting.md{baseDir}/examples/common-workflows.md{baseDir}/examples/sample-requests.md{baseDir}/scripts/healthcheck.sh