Authentication
All API requests require a Bearer token in theAuthorization header. API keys use the brz_ prefix.
read (GET requests only) or write (GET, POST, and PATCH). The API exposes no DELETE operations; use the Breezing dashboard for destructive actions. Calls to write endpoints with a read-only key return 403 FORBIDDEN.
Creating an API Key
API keys are managed at the user level. A single key can span multiple companies with specificread or write access per company.
To create one, open the profile menu in the top-right corner and select Account Settings:


brz_ prefixed key as a Bearer token in all API requests.
Base URL
All endpoints are served from:Finding orgId and companyId
Every endpoint exceptGET /companies requires orgId and companyId as query parameters. Start by calling GET /companies to list every company your API key can access. Each entry returns its id, orgId, and accessLevel.
orgId or companyId, or using IDs your API key isn’t assigned to, return 400 BAD_REQUEST or 403 FORBIDDEN.
Rate Limits
The Breezing API currently allows up to600 requests per minute. If you hit the limit, back off briefly and retry your request.
Pagination
GET /transactions, GET /assets, GET /contacts, GET /reports, and GET /rules use cursor-based pagination:
cursor: the ID of the last item from the previous page (omit for the first page)limit: number of items to return per page (1 to 100)
pagination object:
pagination.limit: number of records requestedpagination.cursor: the cursor value for the current page, ornullpagination.hasMore: whether another page of results is available
Long-Running Operations
Some endpoints start a background job instead of returning the result immediately:POST /transactions, POST /transactions/update-price-auto, POST /wallets, POST /wallets/{id}/sync, POST /balances/calculate, POST /ngl/calculate, POST /active-issues/refresh, and POST /rules/apply. They return a taskId you can poll with GET /tasks.
While one of these is already running for the same company or wallet, a duplicate call returns 409 with a TASK_IN_PROGRESS code. Check GET /tasks before starting a new run, and again before reading derived data such as balances or reports, since overlapping runs can corrupt computed state.
Error Responses
Errors returnsuccess: false and an error object with code and message:
| Status Code | Meaning |
|---|---|
| 400 | Bad request: invalid parameters or request body |
| 401 | Unauthorized: invalid or missing API key |
| 403 | Forbidden: insufficient access level or no access to company |
| 404 | Not found: resource does not exist |
| 409 | Conflict: a long-running task is already in progress, or the resource is locked or already exists |
| 429 | Too Many Requests: rate limit exceeded |
| 500 | Internal server error |
Resources
Companies
List the companies your API key can access. Start here to find org and company IDs.
Company
Retrieve a company’s accounting configuration and chart of accounts, or update its accounting settings.
Transactions
Create, list, filter, update, group, consolidate, and reprice crypto transactions with full accounting details.
Wallets
View, create, and sync connected wallets, exchange accounts, and blockchain addresses.
Assets
Browse token assets and manage their GL account mappings.
Balances
Get aggregated token balances across wallets with fiat valuations.
Contacts
Label counterparty addresses with names to clarify transaction parties.
Active Issues
Surface uncategorized transactions, missing prices, and broken syncs blocking the close.
Reports
Run and inspect Breezing reports for token, account, and explorer balance reconciliation.
Rules
Manage automation rules that auto-categorize transactions based on conditions.
Tasks
Track active background tasks like wallet syncs, report generation, and rule application.
Gain/Loss
Recompute realized and unrealized net gain or loss across crypto transactions.
Xero
Refresh Xero accounts and tracking categories, then sync crypto transactions as journal entries.
QuickBooks
Refresh QuickBooks accounts, classes, and entities, then sync crypto transactions as journal entries.
Bexio
Refresh Bexio accounts and sync crypto transactions as journal entries.