Install
openclaw skills install fluxPublish events and query shared world state via Flux state engine. Use when agents need to share observations, coordinate on shared data, or track entity state across systems.
openclaw skills install fluxFlux is a persistent, shared, event-sourced world state engine. Agents publish immutable events, and Flux derives canonical state that all agents can observe.
Public instance: https://api.flux-universe.com (namespace purchased at flux-universe.com — name auto-assigned at purchase, e.g. dawn-coral)
Local instance: http://localhost:3000 (default, override with FLUX_URL env var)
Authentication: Set FLUX_TOKEN to your bearer token. Required for the public instance. Optional for local instances with auth disabled.
All entity IDs must be prefixed with your namespace:
yournamespace/entity-name
Example with namespace dawn-coral:
./scripts/flux.sh publish sensors agent-01 dawn-coral/sensor-01 \
'{"temperature":22.5}'
./scripts/flux.sh get dawn-coral/sensor-01
Entity IDs without a namespace prefix will be rejected on auth-enabled instances.
First, verify your connection:
./scripts/flux.sh health
Then check the directory to see what's available on the Flux Universe:
./scripts/flux.sh get flux-core/directory
The directory lists all active namespaces, entity counts, and total entities — a good way to discover what data is flowing through the system.
Use the provided bash script in the scripts/ directory:
flux.sh - Main CLI tool./scripts/flux.sh publish <stream> <source> <entity_id> <properties_json>
# Replace dawn-coral with your namespace
# Example: Publish sensor reading
./scripts/flux.sh publish sensors agent-01 dawn-coral/temp-sensor-01 '{"temperature":22.5,"unit":"celsius"}'
./scripts/flux.sh get <entity_id>
# Replace dawn-coral with your namespace
# Example: Get current sensor state
./scripts/flux.sh get dawn-coral/temp-sensor-01
./scripts/flux.sh list
# Filter by prefix
./scripts/flux.sh list --prefix scada/
./scripts/flux.sh delete <entity_id>
# Example: Remove old test entity
./scripts/flux.sh delete test/old-entity
# Replace dawn-coral with your namespace
./scripts/flux.sh batch '[
{"stream":"sensors","source":"agent-01","payload":{"entity_id":"dawn-coral/sensor-01","properties":{"temp":22}}},
{"stream":"sensors","source":"agent-01","payload":{"entity_id":"dawn-coral/sensor-02","properties":{"temp":23}}}
]'
./scripts/flux.sh connectors
# Read runtime config
./scripts/flux.sh admin-config
# Update (requires FLUX_ADMIN_TOKEN)
./scripts/flux.sh admin-config '{"rate_limit_per_namespace_per_minute": 5000}'
Agents publish observations to shared entities:
# Replace dawn-coral with your namespace
# Agent A observes temperature
flux.sh publish sensors agent-a dawn-coral/room-101 '{"temperature":22.5}'
# Agent B queries current state
flux.sh get dawn-coral/room-101
# Returns: {"temperature":22.5,...}
Track service/system state:
# Replace dawn-coral with your namespace
# Publish status change
flux.sh publish system monitor dawn-coral/api-gateway '{"status":"healthy","uptime":3600}'
# Query current status
flux.sh get dawn-coral/api-gateway
Event Ingestion:
POST /api/events — Publish single event (1 MB limit)POST /api/events/batch — Publish multiple events (10 MB limit)State Query:
GET /api/state/entities — List all entities (supports ?prefix= and ?namespace= filters)GET /api/state/entities/:id — Get specific entityEntity Management:
DELETE /api/state/entities/:id — Delete single entityPOST /api/state/entities/delete — Batch delete (by namespace/prefix/IDs)Real-time Updates:
GET /api/ws — WebSocket subscriptionConnectors:
GET /api/connectors — List connectors and statusPOST /api/connectors/:name/token — Store PAT credentialDELETE /api/connectors/:name/token — Remove credentialAdmin:
GET /api/admin/config — Read runtime configPUT /api/admin/config — Update runtime config (requires FLUX_ADMIN_TOKEN)Namespaces (auth mode only):
POST /api/namespaces — Register namespace (returns auth token)/ for namespacing (e.g., scada/pump-01)