Xerg
Use xerg if it is already installed. If not, use npx @xerg/cli with the same arguments.
Xerg audits OpenClaw and Hermes workflows in dollars, not tokens. It reads gateway logs and session transcripts, surfaces confirmed waste plus savings opportunities, and helps you measure fixes with --compare.
Local audits need no account. Hosted sync and hosted MCP are optional paid workspace features. No data leaves your machine unless you explicitly push results to Xerg Cloud.
Quick Start
xerg init
xerg audit --compare
Use direct commands when you need explicit control, non-interactive behavior, JSON output, or CI gates:
xerg doctor
xerg audit
xerg audit --json
xerg audit --fail-above-waste-rate 0.30
Inputs
Xerg needs one of these source inputs:
- Local OpenClaw data at the default paths:
/tmp/openclaw/openclaw-*.log~/.openclaw/agents/*/sessions/*.jsonl
- Local Hermes data at the default paths:
~/.hermes/logs/agent.log*withgateway.log*fallback~/.hermes/sessions/
- Explicit paths via
--log-fileand/or--sessions-dir - An SSH target via
--remote - A Railway target via
--railway - A multi-source config via
--remote-config
Additional requirements:
--compareneeds at least one previously stored compatible local snapshot- Pushing needs auth via
XERG_API_KEY,~/.xerg/config.json, or browser credentials fromxerg login - SSH audits require
sshandrsyncon your localPATHand are OpenClaw-only in this phase - Railway audits require the
railwayCLI on your localPATHand are OpenClaw-only in this phase
Default Flow
- Start with the default first-run path when you want the fastest local result:
xerg init
initdetects local OpenClaw or Hermes data- it runs a first audit with local snapshot persistence enabled
- it offers optional hosted follow-up after the audit completes
- if no local data is found, it prints explicit local-path commands plus remote OpenClaw-only guidance
- Detect sources directly when paths or connectivity are uncertain:
xerg doctor
xerg doctor --verbose
xerg doctor --remote user@host
xerg doctor --railway
xerg doctor --verboseshows progress on stderr while Xerg checks local paths or remote transports- If local defaults are empty, prefer
xerg doctor --remote ...orxerg doctor --railwayinstead of guessing paths
- Run a baseline audit explicitly when you want direct control:
xerg audit
xerg audit --runtime openclaw
xerg audit --runtime hermes
- Choose the right output mode for the task:
xerg audit
xerg audit --json
xerg audit --markdown
- Plain
xerg auditis best for a human-readable summary xerg audit --jsonis best for automation and agentsxerg audit --markdownis best for a shareable report
- After a workflow or model change, measure the delta:
xerg audit --compare
xerg audit --compare --json
- Export, push, or hosted-setup only when needed:
xerg audit --markdown > xerg-audit.md
xerg connect
xerg mcp-setup
xerg audit --push
xerg push
connectis the guided hosted path: it reuses existing auth, prompts before browser login when needed, and offers to push the latest auditmcp-setupprints or writes hosted MCP config for Cursor, Claude Code, or another client- local audits and compare remain available if you skip hosted setup
Source Selection
Local defaults:
xerg audit
If both OpenClaw and Hermes are present locally, pass --runtime openclaw or --runtime hermes explicitly.
Explicit local paths:
xerg audit --runtime openclaw --log-file /path/to/openclaw.log
xerg audit --runtime openclaw --sessions-dir /path/to/sessions
xerg audit --runtime hermes --log-file ~/.hermes/logs/agent.log
xerg audit --runtime hermes --sessions-dir ~/.hermes/sessions
SSH remote:
xerg audit --remote user@vps.example.com
xerg audit --remote user@vps.example.com \
--remote-log-file /opt/openclaw/logs/openclaw.log \
--remote-sessions-dir /opt/openclaw/sessions
Railway:
xerg audit --railway
xerg audit --railway --project <id> --environment <id> --service <id>
Multiple remote sources:
xerg audit --remote-config ~/.xerg/remotes.json
Remote config files use this shape:
{
"remotes": [
{
"name": "prod",
"transport": "ssh",
"host": "deploy@prod.example.com"
},
{
"name": "railway-prod",
"transport": "railway",
"railway": {
"projectId": "...",
"environmentId": "...",
"serviceId": "..."
}
}
]
}
CI And Automation
For CI gates, prefer a single command so the audit can still be pushed before threshold failure:
xerg audit --push --fail-above-waste-rate 0.25 --fail-above-waste-usd 100
Common variants:
xerg audit --fail-above-waste-rate 0.30
xerg audit --fail-above-waste-usd 50
xerg audit --since 24h --fail-above-waste-rate 0.30
Documented exit codes:
0success1runtime error2no supported local runtime data found3threshold exceeded
Automation can branch on those codes instead of scraping terminal output.
Recommendations
When using --json, expect a recommendations array alongside the audit summary. Each recommendation item includes:
id,findingId,kind,title,summarypriorityBucket,recommendedOrder,implementationSurface,categoryseverity,confidence,effortestimatedSavingsUsd,estimatedSavingsPctscope,scopeId,scopeLabelwhereToChange,validationPlan,actions
Current recommendation kinds map into the Action queue buckets:
fix_now:retry-waste,loop-wastetest_next:context-outlier,idle-spend,candidate-downgrade,cache-carryover,max-mode-concentrationwatch: unknown or uncategorized findings
Prefer high-confidence or reversible fixes first. Treat model downgrades, context changes, and Cursor behavior changes as compare-friendly experiments, not guaranteed savings.
Checks
Before finalizing work that used Xerg:
- Say whether the audit was local, SSH, Railway, or multi-source
- Say whether the output was plain terminal text, JSON, or Markdown
- If
--comparewas used, confirm that it compared against a compatible stored snapshot - If no data was found, run
xerg doctoror use explicit source flags rather than guessing - Say whether results were pushed to the Xerg API
- Distinguish confirmed waste (
retry-waste,loop-waste) from directional opportunities (context-outlier,idle-spend,candidate-downgrade)
Notes
--compareand--no-dbcannot be used together- Xerg is local-first: it stores economic metadata and audit snapshots locally, not prompt or response content
XERG_API_KEYis recommended for CI and non-interactive automation- If browser auth is needed without the hosted setup flow, use
xerg login; remove stored credentials withxerg logout - Pilot: xerg.ai/pilot
- Support:
query@xerg.ai