gnubok

gnubok API

Swedish double-entry bookkeeping as a public REST API for agents and integrations. API version 2026-05-12.

The gnubok API lets you do anything the dashboard can do — create invoices, ingest bank transactions, file VAT declarations, run payroll, and subscribe to webhooks for state changes. Every endpoint is designed for autonomous agents first: machine-readable schemas, dry-run previews, idempotent retries, and inline audit blocks on every write.

If you've used Stripe's API, the shape will feel familiar — bearer-token auth, dated API versions, webhook signature verification, idempotency keys. The accounting concepts are Swedish (BAS chart, BFL retention, K2/K3, momsdeklaration) but the surface is built for the same kind of integrator.

Authentication

All requests authenticate with a bearer token in the Authorization header:

curl https://gnubok.app/api/v1/companies \
  -H "Authorization: Bearer gnubok_sk_live_..."

Create keys in the gnubok dashboard at /settings/api. Two key prefixes are available:

  • gnubok_sk_live_* — hits real customer data. Use in production.
  • gnubok_sk_test_* — bound to deterministic sandbox companies. Safe for evals, demos, and agent learning. Same surface, different blast radius.

Each key carries one or more scopes (invoices:read, invoices:write, payroll:write, webhooks:manage, ...) that gate which endpoints it can call. Scopes are listed on every endpoint reference page.

Rate limit: 100 requests per minute per key, returned in X-RateLimit-* headers.

Base URL

https://gnubok.app/api/v1

URLs include the company id explicitly:

GET  /api/v1/companies/{companyId}/invoices
POST /api/v1/companies/{companyId}/invoices

A multi-company key can act on any company the underlying user is a member of — the URL is the source of truth, not a default. List the companies a key can access with:

curl https://gnubok.app/api/v1/companies \
  -H "Authorization: Bearer gnubok_sk_live_..."

Core principles

These four invariants hold across the entire surface — once you've internalised them you can predict the shape of any endpoint without reading the reference.

Dry-run on every write. Append ?dry_run=true (or send X-Dry-Run: true) to any POST/PATCH/DELETE to preview the effect — the response shows the journal lines, voucher number, account deltas, and any validation errors that would surface, but commits nothing. Use this in agent test-loops to validate inputs before paying the side-effect cost.

Idempotency-Key on every write. Pass a UUID in the Idempotency-Key header. Replays of the same key+body return the original response with Idempotent-Replayed: true (24h cache). Replays with a different body return 409 IDEMPOTENCY_KEY_REUSE.

Strict-mode write semantics. A v1 mutation either commits fully or returns a structured error code with no side effects. The dashboard soft-fails on partial writes (a human is there to retry); the v1 surface aborts. This means you never see "the invoice was sent but the email failed" — either both happened or neither did.

Inline audit on every write. Every successful write response includes an audit block in meta with the voucher number, audit-trail URL, and immutability timestamp. No second round-trip needed to confirm what happened.

Response envelope

Every response has the same shape:

{
  "data": { ... },
  "meta": {
    "request_id": "req_...",
    "api_version": "2026-05-12",
    "next_cursor": "...",
    "audit": { "voucher_number": "A-2026-042", "voucher_url": "..." }
  }
}

Errors swap data for error:

{
  "error": {
    "code": "PERIOD_LOCKED",
    "message": "Den valda perioden är låst.",
    "message_en": "The selected period is locked.",
    "remediation": { "description": "Unlock via /fiscal-periods/{id}/unlock or pick an open period.", "tool": "fiscal_periods.unlock" },
    "details": { "fiscal_period_id": "..." },
    "docs_url": "https://gnubok.app/docs/api/errors#period_locked"
  },
  "meta": { "request_id": "req_...", "api_version": "2026-05-12" }
}

Every error code is documented in the error reference.

Where to go next

For LLM-based agents:

Cookbooks

End-to-end recipes for the most common integrations. Copy-paste ready, tested against the sandbox.

API reference

Every endpoint, grouped by resource. Auto-generated from the same Zod registry that powers the OpenAPI spec, MCP tools, and runtime validators.