Skip to content

OpenCode Data Source (Beta)

OpenCode support is experimental. Expect breaking changes while both ccusage and OpenCode continue to evolve.

ccusage can read OpenCode session logs as one of its supported local data sources. OpenCode is a terminal-based AI coding assistant that supports multiple AI providers.

Focused Views

bash
bunx ccusage opencode --help
bash
npx ccusage@latest opencode --help
bash
pnpm dlx ccusage opencode --help
bash
BUN_BE_BUN=1 opencode x ccusage@latest opencode --help

opencode x option

The opencode x option requires the native version of OpenCode. If you installed OpenCode via npm, use the bunx or npx options instead.

Data Source

The CLI reads OpenCode message and session JSON files located under OPENCODE_DATA_DIR (defaults to ~/.local/share/opencode). OPENCODE_DATA_DIR can be one directory or a comma-separated list of directories.

bash
OPENCODE_DATA_DIR="$HOME/.local/share/opencode,/backup/opencode" ccusage opencode daily
~/.local/share/opencode/
└── storage/
    ├── message/{sessionID}/msg_{messageID}.json
    └── session/{projectHash}/{sessionID}.json

Report Views

Focused viewDescriptionSee also
ccusage opencode dailyAggregate usage by date (YYYY-MM-DD)Daily Usage
ccusage opencode weeklyAggregate usage by ISO week (YYYY-Www)Weekly Usage
ccusage opencode monthlyAggregate usage by month (YYYY-MM)Monthly Usage
ccusage opencode sessionPer-session breakdown with parent/subagent hierarchySession Usage

These views support --json for structured output and --compact for narrow terminals. See the linked ccusage documentation for detailed flag descriptions.

Session Hierarchy

OpenCode supports subagent sessions. The session report displays:

  • Bold titles for parent sessions with subagents
  • Indented rows () for subagent sessions
  • Subtotal rows combining parent + subagents

Environment Variables

VariableDescription
OPENCODE_DATA_DIROverride the root directory, or comma-separated root directories, containing OpenCode data
LOG_LEVELAdjust verbosity (0 silent ... 5 trace)

Cost Calculation

OpenCode stores cost: 0 in message files. Costs are calculated from token counts using LiteLLM pricing. Model aliases (e.g., gemini-3-pro-highgemini-3-pro-preview) are handled automatically.

Troubleshooting

No OpenCode usage data found

Ensure the data directory exists at ~/.local/share/opencode/storage/message/. Set OPENCODE_DATA_DIR for custom paths or comma-separated archive roots.

Costs showing as $0.00

If a model is not in LiteLLM's database, the cost will be $0.00. Open an issue to request alias support.

Released under the MIT License.