Version History
Every saved console and dashboard has a full, immutable version history. Each explicit save creates a new version record capturing the complete state at that point in time. Versions are never rewritten or deleted.
How It Works
Section titled “How It Works”- Each console or dashboard carries a monotonically increasing
versionnumber on the main document. (Console drafts bump a separatedraftRevisionand do not create a version — only an explicit save does.) - Every versioned save writes an
EntityVersionrecord in MongoDB scoped to(entityId, entityType, version), enforced by a unique index. dbt files are versioned through the same collection. - Snapshots capture the full entity state (for consoles: code, language, chart spec, connection; for dashboards: widgets, data sources, layout).
- Restoring a past version writes the old snapshot back into the main document and appends a new version record (with
restoredFromset), so the timeline is never lost.
Retry logic handles the rare case of concurrent writers picking the same version number.
REST API
Section titled “REST API”All endpoints live under the workspace path and require workspace membership.
Consoles
Section titled “Consoles”| Method | Endpoint | Description |
|---|---|---|
GET | /api/workspaces/:wid/consoles/:id/versions | List versions (paginated, newest first) |
GET | /api/workspaces/:wid/consoles/:id/versions/:version | Get a specific version snapshot |
POST | /api/workspaces/:wid/consoles/:id/versions/:version/restore | Restore the console to that version |
Dashboards
Section titled “Dashboards”| Method | Endpoint | Description |
|---|---|---|
GET | /api/workspaces/:wid/dashboards/:did/versions | List versions (paginated, newest first) |
GET | /api/workspaces/:wid/dashboards/:did/versions/:version | Get a specific version snapshot |
POST | /api/workspaces/:wid/dashboards/:did/versions/:version/restore | Restore the dashboard to that version |
Query Parameters (list endpoints)
Section titled “Query Parameters (list endpoints)”| Param | Default | Max | Description |
|---|---|---|---|
limit | 50 | 100 | Number of versions to return |
offset | 0 | — | Pagination offset |
List Response
Section titled “List Response”{ "success": true, "versions": [ { "version": 7, "savedBy": "user_abc123", "savedByName": "Alice Doe", "comment": "Added filter on status", "restoredFrom": null, "createdAt": "2026-04-22T14:10:32.000Z" } ], "total": 7}Snapshot Response
Section titled “Snapshot Response”version is the full version record, including the snapshot:
{ "success": true, "version": { "version": 7, "savedBy": "user_abc123", "savedByName": "Alice Doe", "comment": "Added filter on status", "restoredFrom": null, "createdAt": "2026-04-22T14:10:32.000Z", "snapshot": { "code": "SELECT ...", "language": "sql" } }}Restore Response
Section titled “Restore Response”Restoring bumps the entity to a new version (N + 1) whose record has restoredFrom set to the version you restored. The restored content is written to the main document alongside the new version record.
{ "success": true, "message": "Restored to version 8", "console": { "id": "6620...", "name": "Active users", "version": 8 }}(The dashboard restore endpoint returns the restored dashboard under data instead of console.)
Optional body on restore: { "comment": "Reverting because X" }. If omitted, the comment defaults to "Restored from version N".
Open the version history panel from any saved console or dashboard. It shows the full list of versions with author, timestamp, and commit comment. From there you can:
- Click a version to preview its snapshot
- Restore any past version with one click
- Optionally add a commit comment when saving via the save dialog
Unsaved drafts have no version history yet; the history button is disabled until the first save.
AI Agent Tools
Section titled “AI Agent Tools”The assistant can inspect version history through two dedicated tools, which are part of the always-on core toolset. See AI Agent for the full tool surface.
browse_version_history
Section titled “browse_version_history”Lists past versions of a console or dashboard. Returns authors, timestamps, and comments.
Inputs: entityType ("console" | "dashboard"), entityId, optional limit (default 10).
get_version_snapshot
Section titled “get_version_snapshot”Fetches the full snapshot of a specific version — including code (consoles) or widgets/data sources/layout (dashboards).
Inputs: entityType, entityId, version.
Both tools are workspace-scoped: the assistant can only browse entities inside the current workspace.
- Version history is enabled by default for every workspace; no configuration needed.
- The
EntityVersioncollection was introduced in migration2026-04-05-075746_add_entity_versions_collection. - History is append-only — there is no hard delete, even on restore.