Track your AI coding subscriptions from the macOS menu bar — native Swift edition.
OpenUsage shows how much of your AI coding plans you've used: session and weekly limits, credits, and spend, all in one popover. Pin your most important metrics straight into the menu bar.
Homebrew:
brew install --cask openusageDirect download: grab the latest universal DMG from the releases page, open it, and drag OpenUsage to your Applications folder.
Either way, the app updates itself in place via signed, notarized Sparkle updates. Requires macOS 15 (Sequoia) or later.
- Antigravity — Gemini Pro/Flash and Claude model quotas
- Claude — session, weekly, Sonnet, extra usage, local daily spend (ccusage)
- Codex — session, weekly, credits, local daily spend (ccusage)
- Cursor — credits, total/auto/API usage, requests, on-demand, per-day spend
- Devin — weekly and daily quota, extra usage balance
- Grok — credits used, pay-as-you-go
- OpenRouter — credit balance, daily/weekly/monthly spend (API key)
Most providers read the credentials already on your machine (keychain, auth files, app state) — no extra login. OpenRouter is the exception: it has no local credential to reuse, so you supply an API key (see its setup). Either way, nothing leaves your Mac except the same API calls the vendor's own tools make.
- Menu bar pins. Pin metrics to the menu bar (up to 2 per provider); render as compact text or mini bars. The strip hides metrics with no data instead of showing placeholders.
- Dashboard popover. Provider-grouped meters with live reset countdowns, pace indicators, and context menus (pin, hide, used⟷left, countdown⟷exact resets, refresh).
- Global shortcut. Toggle the popover from anywhere — record any combo in Settings.
- Customize. Add/remove widgets, drag-reorder providers and metrics.
- Stale-while-revalidate. Cached values display instantly at launch; refresh runs every 5 minutes.
- Local HTTP API. Other apps can read your usage as JSON from
127.0.0.1:6736(/v1/usage), same format as the original app. It is loopback-only and serves usage numbers, never credentials; note that browser pages can read it too — see the privacy note. - Proxy support. Route provider requests through SOCKS5 or HTTP(S) via
~/.openusage/config.json. - Native settings. Launch at login, global shortcut, menu style, theme, density, 12/24-hour time — see Settings.
- Automatic updates. Signed, notarized in-app updates via Sparkle, with an optional early access channel.
Behavior docs live in docs/: the dashboard, menu bar pins, settings, refresh & caching, the local HTTP API, the proxy, and one page per provider.
For working on the code, see the developer docs: architecture, adding a provider, and debugging & capturing logs.
- macOS 15 (Sequoia) or later
- Universal binary — runs natively on both Apple Silicon and Intel Macs
- A JavaScript package runner — optional, only for the local Today / Yesterday / Last 30 Days spend tiles (which run
ccusage). Bun is preferred (bunx), butpnpm dlx,yarn dlx,npm exec, ornpxwork too — so an existing Node.js install is enough.
swift build # debug build
swift test # run the test suite
./script/build_and_run.sh # build and launch the dev app from dist/ (no install)SwiftPM executable, SwiftUI content hosted in an AppKit-owned NSStatusItem + NSPopover, Swift 6 strict concurrency. Providers implement a small ProviderRuntime protocol (auth store → usage client → mapper → ProviderSnapshot), and the UI renders normalized MetricLine values — see the architecture overview for how the pieces fit together and AGENTS.md for engineering conventions.
Releases are automated: pushing a v* tag on main builds, signs, notarizes, and publishes a new version. A plain tag (v0.7.1) ships to everyone; a pre-release suffix (v0.7.1-beta.1) ships to the Early Access channel. The pipeline lives in .github/workflows/release.yml, and the step-by-step is in the release-swift skill.
The release workflow needs these repository secrets (Settings → Secrets and variables → Actions):
| Secret | What it is |
|---|---|
APPLE_CERTIFICATE |
base64 of your Developer ID Application .p12 |
APPLE_CERTIFICATE_PASSWORD |
the password set when exporting that .p12 |
APPLE_ID |
the Apple ID email used for notarization |
APPLE_PASSWORD |
an app-specific password for that Apple ID |
APPLE_TEAM_ID |
your Apple Developer team ID |
SPARKLE_PUBLIC_KEY |
base64 EdDSA public key, baked into the build as SUPublicEDKey |
SPARKLE_PRIVATE_KEY |
base64 EdDSA private key used to sign the DMG |
POSTHOG_CLI_API_KEY |
PostHog personal API key used to upload dSYMs for crash symbolication |
POSTHOG_CLI_PROJECT_ID |
numeric PostHog project ID the dSYMs upload to |
Export the Developer ID Application cert (with its private key) from Keychain Access as a .p12, then base64 -i DeveloperID.p12 | pbcopy. App-specific passwords come from appleid.apple.com → Sign-In and Security → App-Specific Passwords. Generate the Sparkle EdDSA key pair once with Sparkle's generate_keys tool; the public and private values must be a matching pair or signing is silently skipped.
The two POSTHOG_CLI_* secrets are only used to upload debug symbols (dSYMs) so PostHog can symbolicate crash reports: POSTHOG_CLI_API_KEY is a PostHog personal API key (PostHog → Settings → Personal API keys) and POSTHOG_CLI_PROJECT_ID is the numeric ID from your project URL. The upload host is hardcoded in the workflow (https://us.i.posthog.com), so there is no POSTHOG_CLI_HOST secret. Unlike the secrets above these don't block a release — if POSTHOG_CLI_API_KEY is unset the workflow skips the upload with a warning and the release still ships, but crash reports for that version show raw addresses instead of symbolicated stack traces.
The repository must be public (Sparkle fetches the DMG and appcast anonymously), and the appcast is served from GitHub Pages — confirm Settings → Pages points at the gh-pages branch after the first release.
Issues and PRs are welcome — read CONTRIBUTING.md first; the quality bar is deliberately high. Report security issues privately per SECURITY.md. The OpenUsage name and logo are covered by the trademark policy.
