@mastra/libsql 1.4.0-alpha.0 → 1.5.0-alpha.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/CHANGELOG.md CHANGED
@@ -1,5 +1,209 @@
1
1
  # @mastra/libsql
2
2
 
3
+ ## 1.5.0-alpha.0
4
+
5
+ ### Minor Changes
6
+
7
+ - Added workspace and skill storage domains with full CRUD, versioning, and implementations across LibSQL, Postgres, and MongoDB. Added `editor.workspace` and `editor.skill` namespaces for managing workspace configurations and skill definitions through the editor. Agents stored in the editor can now reference workspaces (by ID or inline config) and skills, with full hydration to runtime `Workspace` instances during agent resolution. ([#13156](https://github.com/mastra-ai/mastra/pull/13156))
8
+
9
+ **Filesystem-native skill versioning (draft → publish model):**
10
+
11
+ Skills are versioned as filesystem trees with content-addressable blob storage. The editing surface (live filesystem) is separated from the serving surface (versioned blob store), enabling a `draft → publish` workflow:
12
+ - `editor.skill.publish(skillId, source, skillPath)` — Snapshots a skill directory from the filesystem into blob storage, creates a new version with a tree manifest, and sets `activeVersionId`
13
+ - Version switching via `editor.skill.update({ id, activeVersionId })` — Points the skill to a previous version without re-publishing
14
+ - Publishing a skill automatically invalidates cached agents that reference it, so they re-hydrate with the updated version on next access
15
+
16
+ **Agent skill resolution strategies:**
17
+
18
+ Agents can reference skills with different resolution strategies:
19
+ - `strategy: 'latest'` — Resolves the skill's active version (honors `activeVersionId` for rollback)
20
+ - `pin: '<versionId>'` — Pins to a specific version, immune to publishes
21
+ - `strategy: 'live'` — Reads directly from the live filesystem (no blob store)
22
+
23
+ **Blob storage infrastructure:**
24
+ - `BlobStore` abstract class for content-addressable storage keyed by SHA-256 hash
25
+ - `InMemoryBlobStore` for testing
26
+ - LibSQL, Postgres, and MongoDB implementations
27
+ - `S3BlobStore` for storing blobs in S3 or S3-compatible storage (AWS, R2, MinIO, DO Spaces)
28
+ - `BlobStoreProvider` interface and `MastraEditorConfig.blobStores` registry for pluggable blob storage
29
+ - `VersionedSkillSource` and `CompositeVersionedSkillSource` for reading skill files from the blob store at runtime
30
+
31
+ **New storage types:**
32
+ - `StorageWorkspaceSnapshotType` and `StorageSkillSnapshotType` with corresponding input/output types
33
+ - `StorageWorkspaceRef` for ID-based or inline workspace references on agents
34
+ - `StorageSkillConfig` for per-agent skill overrides (`pin`, `strategy`, description, instructions)
35
+ - `SkillVersionTree` and `SkillVersionTreeEntry` for tree manifests
36
+ - `StorageBlobEntry` for content-addressable blob entries
37
+ - `SKILL_BLOBS_SCHEMA` for the `mastra_skill_blobs` table
38
+
39
+ **New editor namespaces:**
40
+ - `editor.workspace` — CRUD for workspace configs, plus `hydrateSnapshotToWorkspace()` for resolving to runtime `Workspace` instances
41
+ - `editor.skill` — CRUD for skill definitions, plus `publish()` for filesystem-to-blob snapshots
42
+
43
+ **Provider registries:**
44
+ - `MastraEditorConfig` accepts `filesystems`, `sandboxes`, and `blobStores` provider registries (keyed by provider ID)
45
+ - Built-in `local` filesystem and sandbox providers are auto-registered
46
+ - `editor.resolveBlobStore()` resolves from provider registry or falls back to the storage backend's blobs domain
47
+ - Providers expose `id`, `name`, `description`, `configSchema` (JSON Schema for UI form rendering), and a factory method
48
+
49
+ **Storage adapter support:**
50
+ - LibSQL: Full `workspaces`, `skills`, and `blobs` domain implementations
51
+ - Postgres: Full `workspaces`, `skills`, and `blobs` domain implementations
52
+ - MongoDB: Full `workspaces`, `skills`, and `blobs` domain implementations
53
+ - All three include `workspace`, `skills`, and `skillsFormat` fields on agent versions
54
+
55
+ **Server endpoints:**
56
+ - `GET/POST/PATCH/DELETE /stored/workspaces` — CRUD for stored workspaces
57
+ - `GET/POST/PATCH/DELETE /stored/skills` — CRUD for stored skills
58
+ - `POST /stored/skills/:id/publish` — Publish a skill from a filesystem source
59
+
60
+ ```ts
61
+ import { MastraEditor } from '@mastra/editor';
62
+ import { s3FilesystemProvider, s3BlobStoreProvider } from '@mastra/s3';
63
+ import { e2bSandboxProvider } from '@mastra/e2b';
64
+
65
+ const editor = new MastraEditor({
66
+ filesystems: { s3: s3FilesystemProvider },
67
+ sandboxes: { e2b: e2bSandboxProvider },
68
+ blobStores: { s3: s3BlobStoreProvider },
69
+ });
70
+
71
+ // Create a skill and publish it
72
+ const skill = await editor.skill.create({
73
+ name: 'Code Review',
74
+ description: 'Reviews code for best practices',
75
+ instructions: 'Analyze the code and provide feedback...',
76
+ });
77
+ await editor.skill.publish(skill.id, source, 'skills/code-review');
78
+
79
+ // Agents resolve skills by strategy
80
+ await editor.agent.create({
81
+ name: 'Dev Assistant',
82
+ model: { provider: 'openai', name: 'gpt-4' },
83
+ workspace: { type: 'id', workspaceId: workspace.id },
84
+ skills: { [skill.id]: { strategy: 'latest' } },
85
+ skillsFormat: 'xml',
86
+ });
87
+ ```
88
+
89
+ - Added draft/publish version management for all editor primitives (agents, scorers, MCP clients, prompt blocks). ([#13061](https://github.com/mastra-ai/mastra/pull/13061))
90
+
91
+ **Status filtering on list endpoints** — All list endpoints now accept a `?status=draft|published|archived` query parameter to filter by entity status. Defaults to `published` to preserve backward compatibility.
92
+
93
+ **Draft vs published resolution on get-by-id endpoints** — All get-by-id endpoints now accept `?status=draft` to resolve the entity with its latest (unpublished) version, or `?status=published` (default) to resolve with the active published version.
94
+
95
+ **Edits no longer auto-publish** — When updating any primitive, a new version is created but `activeVersionId` is no longer automatically updated. Edits stay as drafts until explicitly published via the activate endpoint.
96
+
97
+ **Full version management for all primitives** — Scorers, MCP clients, and prompt blocks now have the same version management API that agents have: list versions, create version snapshots, get specific versions, activate/publish, restore from a previous version, delete versions, and compare versions.
98
+
99
+ **New prompt block CRUD routes** — Prompt blocks now have full server routes (`GET /stored/prompt-blocks`, `GET /stored/prompt-blocks/:id`, `POST`, `PATCH`, `DELETE`).
100
+
101
+ **New version endpoints** — Each primitive now exposes 7 version management endpoints under `/stored/{type}/:id/versions` (list, create, get, activate, restore, delete, compare).
102
+
103
+ ```ts
104
+ // Fetch the published version (default behavior, backward compatible)
105
+ const published = await fetch('/api/stored/scorers/my-scorer');
106
+
107
+ // Fetch the draft version for editing in the UI
108
+ const draft = await fetch('/api/stored/scorers/my-scorer?status=draft');
109
+
110
+ // Publish a specific version
111
+ await fetch('/api/stored/scorers/my-scorer/versions/abc123/activate', { method: 'POST' });
112
+
113
+ // Compare two versions
114
+ const diff = await fetch('/api/stored/scorers/my-scorer/versions/compare?from=v1&to=v2');
115
+ ```
116
+
117
+ ### Patch Changes
118
+
119
+ - Dataset schemas now appear in the Edit Dataset dialog. Previously the `inputSchema` and `groundTruthSchema` fields were not passed to the dialog, so editing a dataset always showed empty schemas. ([#13175](https://github.com/mastra-ai/mastra/pull/13175))
120
+
121
+ Schema edits in the JSON editor no longer cause the cursor to jump to the top of the field. Typing `{"type": "object"}` in the schema editor now behaves like a normal text input instead of resetting on every keystroke.
122
+
123
+ Validation errors are now surfaced when updating a dataset schema that conflicts with existing items. For example, adding a `required: ["name"]` constraint when existing items lack a `name` field now shows "2 existing item(s) fail validation" in the dialog instead of silently dropping the error.
124
+
125
+ Disabling a dataset schema from the Studio UI now correctly clears it. Previously the server converted `null` (disable) to `undefined` (no change), so the old schema persisted and validation continued.
126
+
127
+ Workflow schemas fetched via `client.getWorkflow().getSchema()` are now correctly parsed. The server serializes schemas with `superjson`, but the client was using plain `JSON.parse`, yielding a `{json: {...}}` wrapper instead of the actual JSON Schema object.
128
+
129
+ - CMS draft support with status badges for agents. ([#13194](https://github.com/mastra-ai/mastra/pull/13194))
130
+ - Agent list now resolves the latest (draft) version for each stored agent, showing current edits rather than the last published state.
131
+ - Added `hasDraft` and `activeVersionId` fields to the agent list API response.
132
+ - Agent list badges: "Published" (green) when a published version exists, "Draft" (colored when unpublished changes exist, grayed out otherwise).
133
+ - Added `resolvedVersionId` to all `StorageResolved*Type` types so the server can detect whether the latest version differs from the active version.
134
+ - Added `status` option to `GetByIdOptions` to allow resolving draft vs published versions through the editor layer.
135
+ - Fixed editor cache not being cleared on version activate, restore, and delete — all four versioned domains (agents, scorers, prompt-blocks, mcp-clients) now clear the cache after version mutations.
136
+ - Added `ALTER TABLE` migration for `mastra_agent_versions` in libsql and pg to add newer columns (`mcpClients`, `requestContextSchema`, `workspace`, `skills`, `skillsFormat`).
137
+
138
+ - Added scorer version management and CMS draft/publish flow for scorers. ([#13194](https://github.com/mastra-ai/mastra/pull/13194))
139
+ - Added scorer version methods to the client SDK: `listVersions`, `createVersion`, `getVersion`, `activateVersion`, `restoreVersion`, `deleteVersion`, `compareVersions`.
140
+ - Added `ScorerVersionCombobox` for navigating scorer versions with Published/Draft labels.
141
+ - Scorer edit page now supports Save (draft) and Publish workflows with an "Unpublished changes" indicator.
142
+ - Storage list methods for agents and scorers no longer default to filtering only published entities, allowing drafts to appear in the playground.
143
+
144
+ - Updated dependencies [[`252580a`](https://github.com/mastra-ai/mastra/commit/252580a71feb0e46d0ccab04a70a79ff6a2ee0ab), [`f8e819f`](https://github.com/mastra-ai/mastra/commit/f8e819fabdfdc43d2da546a3ad81ba23685f603d), [`5c75261`](https://github.com/mastra-ai/mastra/commit/5c7526120d936757d4ffb7b82232e1641ebd45cb), [`e27d832`](https://github.com/mastra-ai/mastra/commit/e27d83281b5e166fd63a13969689e928d8605944), [`e37ef84`](https://github.com/mastra-ai/mastra/commit/e37ef8404043c94ca0c8e35ecdedb093b8087878), [`6fdd3d4`](https://github.com/mastra-ai/mastra/commit/6fdd3d451a07a8e7e216c62ac364f8dd8e36c2af), [`10cf521`](https://github.com/mastra-ai/mastra/commit/10cf52183344743a0d7babe24cd24fd78870c354), [`efdb682`](https://github.com/mastra-ai/mastra/commit/efdb682887f6522149769383908f9790c188ab88), [`0dee7a0`](https://github.com/mastra-ai/mastra/commit/0dee7a0ff4c2507e6eb6e6ee5f9738877ebd4ad1), [`04c2c8e`](https://github.com/mastra-ai/mastra/commit/04c2c8e888984364194131aecb490a3d6e920e61), [`02dc07a`](https://github.com/mastra-ai/mastra/commit/02dc07acc4ad42d93335825e3308f5b42266eba2), [`bb7262b`](https://github.com/mastra-ai/mastra/commit/bb7262b7c0ca76320d985b40510b6ffbbb936582), [`cf1c6e7`](https://github.com/mastra-ai/mastra/commit/cf1c6e789b131f55638fed52183a89d5078b4876), [`5ffadfe`](https://github.com/mastra-ai/mastra/commit/5ffadfefb1468ac2612b20bb84d24c39de6961c0), [`1e1339c`](https://github.com/mastra-ai/mastra/commit/1e1339cc276e571a48cfff5014487877086bfe68), [`d03df73`](https://github.com/mastra-ai/mastra/commit/d03df73f8fe9496064a33e1c3b74ba0479bf9ee6), [`79b8f45`](https://github.com/mastra-ai/mastra/commit/79b8f45a6767e1a5c3d56cd3c5b1214326b81661), [`9bbf08e`](https://github.com/mastra-ai/mastra/commit/9bbf08e3c20731c79dea13a765895b9fcf29cbf1), [`0a25952`](https://github.com/mastra-ai/mastra/commit/0a259526b5e1ac11e6efa53db1f140272962af2d), [`ffa5468`](https://github.com/mastra-ai/mastra/commit/ffa546857fc4821753979b3a34e13b4d76fbbcd4), [`3264a04`](https://github.com/mastra-ai/mastra/commit/3264a04e30340c3c5447433300a035ea0878df85), [`6fdd3d4`](https://github.com/mastra-ai/mastra/commit/6fdd3d451a07a8e7e216c62ac364f8dd8e36c2af), [`088d9ba`](https://github.com/mastra-ai/mastra/commit/088d9ba2577518703c52b0dccd617178d9ee6b0d), [`74fbebd`](https://github.com/mastra-ai/mastra/commit/74fbebd918a03832a2864965a8bea59bf617d3a2), [`aea6217`](https://github.com/mastra-ai/mastra/commit/aea621790bfb2291431b08da0cc5e6e150303ae7), [`b6a855e`](https://github.com/mastra-ai/mastra/commit/b6a855edc056e088279075506442ba1d6fa6def9), [`ae408ea`](https://github.com/mastra-ai/mastra/commit/ae408ea7128f0d2710b78d8623185198e7cb19c1), [`17e942e`](https://github.com/mastra-ai/mastra/commit/17e942eee2ba44985b1f807e6208cdde672f82f9), [`2015cf9`](https://github.com/mastra-ai/mastra/commit/2015cf921649f44c3f5bcd32a2c052335f8e49b4), [`7ef454e`](https://github.com/mastra-ai/mastra/commit/7ef454eaf9dcec6de60021c8f42192052dd490d6), [`2be1d99`](https://github.com/mastra-ai/mastra/commit/2be1d99564ce79acc4846071082bff353035a87a), [`2708fa1`](https://github.com/mastra-ai/mastra/commit/2708fa1055ac91c03e08b598869f6b8fb51fa37f), [`ba74aef`](https://github.com/mastra-ai/mastra/commit/ba74aef5716142dbbe931351f5243c9c6e4128a9), [`ba74aef`](https://github.com/mastra-ai/mastra/commit/ba74aef5716142dbbe931351f5243c9c6e4128a9), [`ec53e89`](https://github.com/mastra-ai/mastra/commit/ec53e8939c76c638991e21af762e51378eff7543), [`9b5a8cb`](https://github.com/mastra-ai/mastra/commit/9b5a8cb13e120811b0bf14140ada314f1c067894), [`607e66b`](https://github.com/mastra-ai/mastra/commit/607e66b02dc7f531ee37799f3456aa2dc0ca7ac5), [`a215d06`](https://github.com/mastra-ai/mastra/commit/a215d06758dcf590eabfe0b7afd4ae39bdbf082c), [`6909c74`](https://github.com/mastra-ai/mastra/commit/6909c74a7781e0447d475e9dbc1dc871b700f426), [`192438f`](https://github.com/mastra-ai/mastra/commit/192438f8a90c4f375e955f8ff179bf8dc6821a83)]:
145
+ - @mastra/core@1.5.0-alpha.0
146
+
147
+ ## 1.4.0
148
+
149
+ ### Minor Changes
150
+
151
+ - Added datasets and experiments storage implementations. Includes dataset CRUD, item versioning with SCD-2, experiment runs with scorer results, and table/type configurations for dataset and experiment tables. ([#12747](https://github.com/mastra-ai/mastra/pull/12747))
152
+
153
+ **Requires `@mastra/core` >= 1.4.0**
154
+
155
+ ### Patch Changes
156
+
157
+ - Fixed agent version storage to persist the requestContextSchema field. Previously, requestContextSchema was defined on the agent snapshot type but was not included in the database schema, INSERT statements, or row parsing logic, causing it to be silently dropped when saving and loading agent versions. ([#13003](https://github.com/mastra-ai/mastra/pull/13003))
158
+
159
+ - Added MCP client storage domain and ToolProvider interface for integrating external tool catalogs with stored agents. ([#12974](https://github.com/mastra-ai/mastra/pull/12974))
160
+
161
+ **MCP Client Storage**
162
+
163
+ New storage domain for persisting MCP client configurations with CRUD operations. Each MCP client can contain multiple servers with independent tool selection:
164
+
165
+ ```ts
166
+ // Store an MCP client with multiple servers
167
+ await storage.mcpClients.create({
168
+ id: 'my-mcp',
169
+ name: 'My MCP Client',
170
+ servers: {
171
+ 'github-server': { url: 'https://mcp.github.com/sse' },
172
+ 'slack-server': { url: 'https://mcp.slack.com/sse' },
173
+ },
174
+ });
175
+ ```
176
+
177
+ LibSQL, PostgreSQL, and MongoDB storage adapters all implement the new MCP client domain.
178
+
179
+ **ToolProvider Interface**
180
+
181
+ New `ToolProvider` interface at `@mastra/core/tool-provider` enables third-party tool catalog integration (e.g., Composio, Arcade AI):
182
+
183
+ ```ts
184
+ import type { ToolProvider } from '@mastra/core/tool-provider';
185
+
186
+ # Providers implement: listToolkits(), listTools(), getToolSchema(), resolveTools()
187
+ ```
188
+
189
+ `resolveTools()` receives `requestContext` from the current request, enabling per-user API keys and credentials in multi-tenant setups:
190
+
191
+ ```ts
192
+ const tools = await provider.resolveTools(slugs, configs, {
193
+ requestContext: { apiKey: 'user-specific-key', userId: 'tenant-123' },
194
+ });
195
+ ```
196
+
197
+ **Tool Selection Semantics**
198
+
199
+ Both `mcpClients` and `integrationTools` on stored agents follow consistent three-state selection:
200
+ - `{ tools: undefined }` — provider registered, no tools selected
201
+ - `{ tools: {} }` — all tools from provider included
202
+ - `{ tools: { 'TOOL_SLUG': { description: '...' } } }` — specific tools with optional overrides
203
+
204
+ - Updated dependencies [[`7ef618f`](https://github.com/mastra-ai/mastra/commit/7ef618f3c49c27e2f6b27d7f564c557c0734325b), [`b373564`](https://github.com/mastra-ai/mastra/commit/b37356491d43b4d53067f10cb669abaf2502f218), [`927c2af`](https://github.com/mastra-ai/mastra/commit/927c2af9792286c122e04409efce0f3c804f777f), [`b896b41`](https://github.com/mastra-ai/mastra/commit/b896b41343de7fcc14442fb40fe82d189e65bbe2), [`6415277`](https://github.com/mastra-ai/mastra/commit/6415277a438faa00db2af850ead5dee25f40c428), [`0831bbb`](https://github.com/mastra-ai/mastra/commit/0831bbb5bc750c18e9b22b45f18687c964b70828), [`63f7eda`](https://github.com/mastra-ai/mastra/commit/63f7eda605eb3e0c8c35ee3912ffe7c999c69f69), [`a5b67a3`](https://github.com/mastra-ai/mastra/commit/a5b67a3589a74415feb663a55d1858324a2afde9), [`877b02c`](https://github.com/mastra-ai/mastra/commit/877b02cdbb15e199184c7f2b8f217be8d3ebada7), [`7567222`](https://github.com/mastra-ai/mastra/commit/7567222b1366f0d39980594792dd9d5060bfe2ab), [`af71458`](https://github.com/mastra-ai/mastra/commit/af71458e3b566f09c11d0e5a0a836dc818e7a24a), [`eb36bd8`](https://github.com/mastra-ai/mastra/commit/eb36bd8c52fcd6ec9674ac3b7a6412405b5983e1), [`3cbf121`](https://github.com/mastra-ai/mastra/commit/3cbf121f55418141924754a83102aade89835947)]:
205
+ - @mastra/core@1.4.0
206
+
3
207
  ## 1.4.0-alpha.0
4
208
 
5
209
  ### Minor Changes
@@ -3,7 +3,7 @@ name: mastra-libsql
3
3
  description: Documentation for @mastra/libsql. Use when working with @mastra/libsql APIs, configuration, or implementation.
4
4
  metadata:
5
5
  package: "@mastra/libsql"
6
- version: "1.4.0-alpha.0"
6
+ version: "1.5.0-alpha.0"
7
7
  ---
8
8
 
9
9
  ## When to use
@@ -1,5 +1,5 @@
1
1
  {
2
- "version": "1.4.0-alpha.0",
2
+ "version": "1.5.0-alpha.0",
3
3
  "package": "@mastra/libsql",
4
4
  "exports": {},
5
5
  "modules": {}