@mastra/azure 0.2.0-alpha.0 → 0.2.0-alpha.1
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 +22 -0
- package/README.md +79 -0
- package/dist/blob/blob-store/index.d.ts +84 -0
- package/dist/blob/blob-store/index.d.ts.map +1 -0
- package/dist/blob/index.cjs +11 -3
- package/dist/blob/index.d.ts +4 -3
- package/dist/blob/index.d.ts.map +1 -1
- package/dist/blob/index.js +1 -1
- package/dist/blob/provider.d.ts +3 -1
- package/dist/blob/provider.d.ts.map +1 -1
- package/dist/{chunk-VFZDLQDB.js → chunk-DBBJ2YM7.js} +189 -3
- package/dist/chunk-DBBJ2YM7.js.map +1 -0
- package/dist/{chunk-LLH5EI3J.cjs → chunk-JLBSGA65.cjs} +190 -2
- package/dist/chunk-JLBSGA65.cjs.map +1 -0
- package/dist/index.cjs +11 -3
- package/dist/index.d.ts +1 -1
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +1 -1
- package/package.json +3 -3
- package/dist/chunk-LLH5EI3J.cjs.map +0 -1
- package/dist/chunk-VFZDLQDB.js.map +0 -1
package/CHANGELOG.md
CHANGED
|
@@ -1,5 +1,27 @@
|
|
|
1
1
|
# @mastra/azure
|
|
2
2
|
|
|
3
|
+
## 0.2.0-alpha.1
|
|
4
|
+
|
|
5
|
+
### Minor Changes
|
|
6
|
+
|
|
7
|
+
- Added `AzureBlobStore`, a content-addressable blob store backed by Azure Blob Storage for skill versioning. Available alongside the existing `AzureBlobFilesystem` from `@mastra/azure/blob`. ([#15853](https://github.com/mastra-ai/mastra/pull/15853))
|
|
8
|
+
|
|
9
|
+
```typescript
|
|
10
|
+
import { AzureBlobStore } from '@mastra/azure/blob';
|
|
11
|
+
|
|
12
|
+
const blobs = new AzureBlobStore({
|
|
13
|
+
container: 'my-skill-blobs',
|
|
14
|
+
connectionString: process.env.AZURE_STORAGE_CONNECTION_STRING,
|
|
15
|
+
});
|
|
16
|
+
```
|
|
17
|
+
|
|
18
|
+
Supports the same authentication methods as `AzureBlobFilesystem`: connection string, account key, SAS token, `DefaultAzureCredential`, and anonymous access. A matching `azureBlobStoreProvider` descriptor is also exported for MastraEditor.
|
|
19
|
+
|
|
20
|
+
### Patch Changes
|
|
21
|
+
|
|
22
|
+
- Updated dependencies [[`28caa5b`](https://github.com/mastra-ai/mastra/commit/28caa5b032358545af2589ed90636eccb4dd9d2f), [`7d056b6`](https://github.com/mastra-ai/mastra/commit/7d056b6ecf603cacaa0f663ff1df025ed885b6c1), [`26f1f94`](https://github.com/mastra-ai/mastra/commit/26f1f9490574b864ba1ecedf2c9632e0767a23bd)]:
|
|
23
|
+
- @mastra/core@1.29.0-alpha.5
|
|
24
|
+
|
|
3
25
|
## 0.2.0-alpha.0
|
|
4
26
|
|
|
5
27
|
### Minor Changes
|
package/README.md
ADDED
|
@@ -0,0 +1,79 @@
|
|
|
1
|
+
# @mastra/azure
|
|
2
|
+
|
|
3
|
+
Azure Blob Storage filesystem and content-addressable blob store provider for Mastra workspaces.
|
|
4
|
+
|
|
5
|
+
## Installation
|
|
6
|
+
|
|
7
|
+
```bash
|
|
8
|
+
npm install @mastra/azure
|
|
9
|
+
```
|
|
10
|
+
|
|
11
|
+
## Usage
|
|
12
|
+
|
|
13
|
+
```typescript
|
|
14
|
+
import { Agent } from '@mastra/core/agent';
|
|
15
|
+
import { Workspace } from '@mastra/core/workspace';
|
|
16
|
+
import { AzureBlobFilesystem } from '@mastra/azure/blob';
|
|
17
|
+
|
|
18
|
+
const workspace = new Workspace({
|
|
19
|
+
filesystem: new AzureBlobFilesystem({
|
|
20
|
+
container: 'my-container',
|
|
21
|
+
connectionString: process.env.AZURE_STORAGE_CONNECTION_STRING,
|
|
22
|
+
}),
|
|
23
|
+
});
|
|
24
|
+
|
|
25
|
+
const agent = new Agent({
|
|
26
|
+
name: 'my-agent',
|
|
27
|
+
model: 'anthropic/claude-opus-4-5',
|
|
28
|
+
workspace,
|
|
29
|
+
});
|
|
30
|
+
```
|
|
31
|
+
|
|
32
|
+
### Account key
|
|
33
|
+
|
|
34
|
+
```typescript
|
|
35
|
+
const filesystem = new AzureBlobFilesystem({
|
|
36
|
+
container: 'my-container',
|
|
37
|
+
accountName: process.env.AZURE_STORAGE_ACCOUNT_NAME,
|
|
38
|
+
accountKey: process.env.AZURE_STORAGE_ACCOUNT_KEY,
|
|
39
|
+
});
|
|
40
|
+
```
|
|
41
|
+
|
|
42
|
+
### Shared access signature
|
|
43
|
+
|
|
44
|
+
```typescript
|
|
45
|
+
const filesystem = new AzureBlobFilesystem({
|
|
46
|
+
container: 'my-container',
|
|
47
|
+
accountName: process.env.AZURE_STORAGE_ACCOUNT_NAME,
|
|
48
|
+
sasToken: process.env.AZURE_STORAGE_SAS_TOKEN,
|
|
49
|
+
});
|
|
50
|
+
```
|
|
51
|
+
|
|
52
|
+
### DefaultAzureCredential
|
|
53
|
+
|
|
54
|
+
Requires `@azure/identity` to be installed.
|
|
55
|
+
|
|
56
|
+
```typescript
|
|
57
|
+
const filesystem = new AzureBlobFilesystem({
|
|
58
|
+
container: 'my-container',
|
|
59
|
+
accountName: process.env.AZURE_STORAGE_ACCOUNT_NAME,
|
|
60
|
+
useDefaultCredential: true,
|
|
61
|
+
});
|
|
62
|
+
```
|
|
63
|
+
|
|
64
|
+
## Blob Store
|
|
65
|
+
|
|
66
|
+
`AzureBlobStore` is a content-addressable blob store backed by Azure Blob Storage, used for skill versioning.
|
|
67
|
+
|
|
68
|
+
```typescript
|
|
69
|
+
import { AzureBlobStore } from '@mastra/azure/blob';
|
|
70
|
+
|
|
71
|
+
const blobs = new AzureBlobStore({
|
|
72
|
+
container: 'my-skill-blobs',
|
|
73
|
+
connectionString: process.env.AZURE_STORAGE_CONNECTION_STRING,
|
|
74
|
+
});
|
|
75
|
+
```
|
|
76
|
+
|
|
77
|
+
## Documentation
|
|
78
|
+
|
|
79
|
+
For more information, see the [Mastra Workspaces documentation](https://mastra.ai/docs/workspace/overview).
|
|
@@ -0,0 +1,84 @@
|
|
|
1
|
+
import { BlobStore } from '@mastra/core/storage';
|
|
2
|
+
import type { StorageBlobEntry } from '@mastra/core/storage';
|
|
3
|
+
/**
|
|
4
|
+
* Configuration for AzureBlobStore.
|
|
5
|
+
*/
|
|
6
|
+
export interface AzureBlobStoreOptions {
|
|
7
|
+
/** Azure Blob container name */
|
|
8
|
+
container: string;
|
|
9
|
+
/** Storage account name (required unless using connectionString) */
|
|
10
|
+
accountName?: string;
|
|
11
|
+
/** Storage account key */
|
|
12
|
+
accountKey?: string;
|
|
13
|
+
/** SAS token for authentication */
|
|
14
|
+
sasToken?: string;
|
|
15
|
+
/** Full connection string (takes priority over accountName/accountKey) */
|
|
16
|
+
connectionString?: string;
|
|
17
|
+
/**
|
|
18
|
+
* Use DefaultAzureCredential from @azure/identity for authentication.
|
|
19
|
+
* Requires @azure/identity to be installed as a peer dependency.
|
|
20
|
+
*/
|
|
21
|
+
useDefaultCredential?: boolean;
|
|
22
|
+
/** Custom endpoint URL (e.g. for the Azurite emulator) */
|
|
23
|
+
endpoint?: string;
|
|
24
|
+
/**
|
|
25
|
+
* Key prefix for all blob objects.
|
|
26
|
+
* Defaults to 'mastra_skill_blobs/'.
|
|
27
|
+
*/
|
|
28
|
+
prefix?: string;
|
|
29
|
+
}
|
|
30
|
+
/**
|
|
31
|
+
* Azure Blob Storage-backed content-addressable blob store for skill versioning.
|
|
32
|
+
*
|
|
33
|
+
* Each blob is stored as a block blob keyed by its SHA-256 hash. Metadata
|
|
34
|
+
* (size, mimeType, createdAt) is stored as Azure blob metadata.
|
|
35
|
+
*
|
|
36
|
+
* Since blobs are content-addressable, writes are idempotent — the same hash
|
|
37
|
+
* always maps to the same content, so overwrites are safe and equivalent to
|
|
38
|
+
* a no-op.
|
|
39
|
+
*
|
|
40
|
+
* @example Connection string
|
|
41
|
+
* ```typescript
|
|
42
|
+
* import { AzureBlobStore } from '@mastra/azure/blob';
|
|
43
|
+
*
|
|
44
|
+
* const blobs = new AzureBlobStore({
|
|
45
|
+
* container: 'my-skill-blobs',
|
|
46
|
+
* connectionString: process.env.AZURE_STORAGE_CONNECTION_STRING!,
|
|
47
|
+
* });
|
|
48
|
+
* ```
|
|
49
|
+
*
|
|
50
|
+
* @example Account key
|
|
51
|
+
* ```typescript
|
|
52
|
+
* import { AzureBlobStore } from '@mastra/azure/blob';
|
|
53
|
+
*
|
|
54
|
+
* const blobs = new AzureBlobStore({
|
|
55
|
+
* container: 'my-skill-blobs',
|
|
56
|
+
* accountName: process.env.AZURE_STORAGE_ACCOUNT_NAME!,
|
|
57
|
+
* accountKey: process.env.AZURE_STORAGE_ACCOUNT_KEY!,
|
|
58
|
+
* });
|
|
59
|
+
* ```
|
|
60
|
+
*/
|
|
61
|
+
export declare class AzureBlobStore extends BlobStore {
|
|
62
|
+
private readonly containerName;
|
|
63
|
+
private readonly accountName?;
|
|
64
|
+
private readonly accountKey?;
|
|
65
|
+
private readonly sasToken?;
|
|
66
|
+
private readonly connectionString?;
|
|
67
|
+
private readonly useDefaultCredential;
|
|
68
|
+
private readonly endpoint?;
|
|
69
|
+
private readonly prefix;
|
|
70
|
+
private _containerClient;
|
|
71
|
+
constructor(options: AzureBlobStoreOptions);
|
|
72
|
+
private getContainerClient;
|
|
73
|
+
private toKey;
|
|
74
|
+
init(): Promise<void>;
|
|
75
|
+
put(entry: StorageBlobEntry): Promise<void>;
|
|
76
|
+
get(hash: string): Promise<StorageBlobEntry | null>;
|
|
77
|
+
has(hash: string): Promise<boolean>;
|
|
78
|
+
delete(hash: string): Promise<boolean>;
|
|
79
|
+
putMany(entries: StorageBlobEntry[]): Promise<void>;
|
|
80
|
+
getMany(hashes: string[]): Promise<Map<string, StorageBlobEntry>>;
|
|
81
|
+
dangerouslyClearAll(): Promise<void>;
|
|
82
|
+
private deleteBlobBatch;
|
|
83
|
+
}
|
|
84
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/blob/blob-store/index.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,SAAS,EAAE,MAAM,sBAAsB,CAAC;AACjD,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,sBAAsB,CAAC;AAE7D;;GAEG;AACH,MAAM,WAAW,qBAAqB;IACpC,gCAAgC;IAChC,SAAS,EAAE,MAAM,CAAC;IAClB,oEAAoE;IACpE,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,0BAA0B;IAC1B,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,mCAAmC;IACnC,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,0EAA0E;IAC1E,gBAAgB,CAAC,EAAE,MAAM,CAAC;IAC1B;;;OAGG;IACH,oBAAoB,CAAC,EAAE,OAAO,CAAC;IAC/B,0DAA0D;IAC1D,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB;;;OAGG;IACH,MAAM,CAAC,EAAE,MAAM,CAAC;CACjB;AAmBD;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA8BG;AACH,qBAAa,cAAe,SAAQ,SAAS;IAC3C,OAAO,CAAC,QAAQ,CAAC,aAAa,CAAS;IACvC,OAAO,CAAC,QAAQ,CAAC,WAAW,CAAC,CAAS;IACtC,OAAO,CAAC,QAAQ,CAAC,UAAU,CAAC,CAAS;IACrC,OAAO,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAS;IACnC,OAAO,CAAC,QAAQ,CAAC,gBAAgB,CAAC,CAAS;IAC3C,OAAO,CAAC,QAAQ,CAAC,oBAAoB,CAAU;IAC/C,OAAO,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAS;IACnC,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAS;IAEhC,OAAO,CAAC,gBAAgB,CAAgC;gBAE5C,OAAO,EAAE,qBAAqB;YAY5B,kBAAkB;IA8ChC,OAAO,CAAC,KAAK;IAIP,IAAI,IAAI,OAAO,CAAC,IAAI,CAAC;IAIrB,GAAG,CAAC,KAAK,EAAE,gBAAgB,GAAG,OAAO,CAAC,IAAI,CAAC;IAkB3C,GAAG,CAAC,IAAI,EAAE,MAAM,GAAG,OAAO,CAAC,gBAAgB,GAAG,IAAI,CAAC;IAuBnD,GAAG,CAAC,IAAI,EAAE,MAAM,GAAG,OAAO,CAAC,OAAO,CAAC;IAanC,MAAM,CAAC,IAAI,EAAE,MAAM,GAAG,OAAO,CAAC,OAAO,CAAC;IAOtC,OAAO,CAAC,OAAO,EAAE,gBAAgB,EAAE,GAAG,OAAO,CAAC,IAAI,CAAC;IAOnD,OAAO,CAAC,MAAM,EAAE,MAAM,EAAE,GAAG,OAAO,CAAC,GAAG,CAAC,MAAM,EAAE,gBAAgB,CAAC,CAAC;IAajE,mBAAmB,IAAI,OAAO,CAAC,IAAI,CAAC;YAiB5B,eAAe;CAI9B"}
|
package/dist/blob/index.cjs
CHANGED
|
@@ -1,16 +1,24 @@
|
|
|
1
1
|
'use strict';
|
|
2
2
|
|
|
3
|
-
var
|
|
3
|
+
var chunkJLBSGA65_cjs = require('../chunk-JLBSGA65.cjs');
|
|
4
4
|
|
|
5
5
|
|
|
6
6
|
|
|
7
7
|
Object.defineProperty(exports, "AzureBlobFilesystem", {
|
|
8
8
|
enumerable: true,
|
|
9
|
-
get: function () { return
|
|
9
|
+
get: function () { return chunkJLBSGA65_cjs.AzureBlobFilesystem; }
|
|
10
|
+
});
|
|
11
|
+
Object.defineProperty(exports, "AzureBlobStore", {
|
|
12
|
+
enumerable: true,
|
|
13
|
+
get: function () { return chunkJLBSGA65_cjs.AzureBlobStore; }
|
|
10
14
|
});
|
|
11
15
|
Object.defineProperty(exports, "azureBlobFilesystemProvider", {
|
|
12
16
|
enumerable: true,
|
|
13
|
-
get: function () { return
|
|
17
|
+
get: function () { return chunkJLBSGA65_cjs.azureBlobFilesystemProvider; }
|
|
18
|
+
});
|
|
19
|
+
Object.defineProperty(exports, "azureBlobStoreProvider", {
|
|
20
|
+
enumerable: true,
|
|
21
|
+
get: function () { return chunkJLBSGA65_cjs.azureBlobStoreProvider; }
|
|
14
22
|
});
|
|
15
23
|
//# sourceMappingURL=index.cjs.map
|
|
16
24
|
//# sourceMappingURL=index.cjs.map
|
package/dist/blob/index.d.ts
CHANGED
|
@@ -1,8 +1,9 @@
|
|
|
1
1
|
/**
|
|
2
|
-
* @mastra/azure/blob - Azure Blob Storage Filesystem Provider
|
|
2
|
+
* @mastra/azure/blob - Azure Blob Storage Filesystem & Blob Store Provider
|
|
3
3
|
*
|
|
4
|
-
* A filesystem
|
|
4
|
+
* A filesystem and content-addressable blob store backed by Azure Blob Storage.
|
|
5
5
|
*/
|
|
6
6
|
export { AzureBlobFilesystem, type AzureBlobFilesystemOptions, type AzureBlobMountConfig } from './filesystem/index.js';
|
|
7
|
-
export {
|
|
7
|
+
export { AzureBlobStore, type AzureBlobStoreOptions } from './blob-store/index.js';
|
|
8
|
+
export { azureBlobFilesystemProvider, azureBlobStoreProvider } from './provider.js';
|
|
8
9
|
//# sourceMappingURL=index.d.ts.map
|
package/dist/blob/index.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/blob/index.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH,OAAO,EAAE,mBAAmB,EAAE,KAAK,0BAA0B,EAAE,KAAK,oBAAoB,EAAE,MAAM,cAAc,CAAC;AAC/G,OAAO,EAAE,2BAA2B,EAAE,MAAM,YAAY,CAAC"}
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/blob/index.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH,OAAO,EAAE,mBAAmB,EAAE,KAAK,0BAA0B,EAAE,KAAK,oBAAoB,EAAE,MAAM,cAAc,CAAC;AAC/G,OAAO,EAAE,cAAc,EAAE,KAAK,qBAAqB,EAAE,MAAM,cAAc,CAAC;AAC1E,OAAO,EAAE,2BAA2B,EAAE,sBAAsB,EAAE,MAAM,YAAY,CAAC"}
|
package/dist/blob/index.js
CHANGED
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
export { AzureBlobFilesystem, azureBlobFilesystemProvider } from '../chunk-
|
|
1
|
+
export { AzureBlobFilesystem, AzureBlobStore, azureBlobFilesystemProvider, azureBlobStoreProvider } from '../chunk-DBBJ2YM7.js';
|
|
2
2
|
//# sourceMappingURL=index.js.map
|
|
3
3
|
//# sourceMappingURL=index.js.map
|
package/dist/blob/provider.d.ts
CHANGED
|
@@ -1,4 +1,6 @@
|
|
|
1
|
-
import type { FilesystemProvider } from '@mastra/core/editor';
|
|
1
|
+
import type { BlobStoreProvider, FilesystemProvider } from '@mastra/core/editor';
|
|
2
|
+
import type { AzureBlobStoreOptions } from './blob-store/index.js';
|
|
2
3
|
import type { AzureBlobFilesystemOptions } from './filesystem/index.js';
|
|
3
4
|
export declare const azureBlobFilesystemProvider: FilesystemProvider<AzureBlobFilesystemOptions>;
|
|
5
|
+
export declare const azureBlobStoreProvider: BlobStoreProvider<AzureBlobStoreOptions>;
|
|
4
6
|
//# sourceMappingURL=provider.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"provider.d.ts","sourceRoot":"","sources":["../../src/blob/provider.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,qBAAqB,CAAC;
|
|
1
|
+
{"version":3,"file":"provider.d.ts","sourceRoot":"","sources":["../../src/blob/provider.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,iBAAiB,EAAE,kBAAkB,EAAE,MAAM,qBAAqB,CAAC;AAEjF,OAAO,KAAK,EAAE,qBAAqB,EAAE,MAAM,cAAc,CAAC;AAE1D,OAAO,KAAK,EAAE,0BAA0B,EAAE,MAAM,cAAc,CAAC;AAE/D,eAAO,MAAM,2BAA2B,EAAE,kBAAkB,CAAC,0BAA0B,CAwBtF,CAAC;AAEF,eAAO,MAAM,sBAAsB,EAAE,iBAAiB,CAAC,qBAAqB,CAuB3E,CAAC"}
|
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
import { BlobServiceClient, StorageSharedKeyCredential, BlobSASPermissions } from '@azure/storage-blob';
|
|
2
2
|
import { MastraFilesystem, PermissionError, FileNotFoundError, FileExistsError } from '@mastra/core/workspace';
|
|
3
|
+
import { BlobStore } from '@mastra/core/storage';
|
|
3
4
|
|
|
4
5
|
// src/blob/filesystem/index.ts
|
|
5
6
|
var MIME_TYPES = {
|
|
@@ -537,6 +538,167 @@ var AzureBlobFilesystem = class extends MastraFilesystem {
|
|
|
537
538
|
this._containerClient = null;
|
|
538
539
|
}
|
|
539
540
|
};
|
|
541
|
+
function trimSlashes2(s) {
|
|
542
|
+
let start = 0;
|
|
543
|
+
let end = s.length;
|
|
544
|
+
while (start < end && s[start] === "/") start++;
|
|
545
|
+
while (end > start && s[end - 1] === "/") end--;
|
|
546
|
+
return s.slice(start, end);
|
|
547
|
+
}
|
|
548
|
+
function isNotFoundError2(error) {
|
|
549
|
+
if (!error || typeof error !== "object") return false;
|
|
550
|
+
return error.statusCode === 404;
|
|
551
|
+
}
|
|
552
|
+
var BATCH_DELETE_SIZE = 256;
|
|
553
|
+
var AzureBlobStore = class extends BlobStore {
|
|
554
|
+
containerName;
|
|
555
|
+
accountName;
|
|
556
|
+
accountKey;
|
|
557
|
+
sasToken;
|
|
558
|
+
connectionString;
|
|
559
|
+
useDefaultCredential;
|
|
560
|
+
endpoint;
|
|
561
|
+
prefix;
|
|
562
|
+
_containerClient = null;
|
|
563
|
+
constructor(options) {
|
|
564
|
+
super();
|
|
565
|
+
this.containerName = options.container;
|
|
566
|
+
this.accountName = options.accountName;
|
|
567
|
+
this.accountKey = options.accountKey;
|
|
568
|
+
this.sasToken = options.sasToken;
|
|
569
|
+
this.connectionString = options.connectionString;
|
|
570
|
+
this.useDefaultCredential = options.useDefaultCredential ?? false;
|
|
571
|
+
this.endpoint = options.endpoint;
|
|
572
|
+
this.prefix = options.prefix ? trimSlashes2(options.prefix) + "/" : "mastra_skill_blobs/";
|
|
573
|
+
}
|
|
574
|
+
async getContainerClient() {
|
|
575
|
+
if (this._containerClient) return this._containerClient;
|
|
576
|
+
let serviceClient;
|
|
577
|
+
if (this.connectionString) {
|
|
578
|
+
serviceClient = BlobServiceClient.fromConnectionString(this.connectionString);
|
|
579
|
+
} else {
|
|
580
|
+
if (!this.endpoint && !this.accountName) {
|
|
581
|
+
throw new Error(
|
|
582
|
+
"Azure Blob Storage requires either a connectionString, or an accountName/endpoint. Provide at least one of: connectionString, accountName, or endpoint."
|
|
583
|
+
);
|
|
584
|
+
}
|
|
585
|
+
const baseUrl = this.endpoint ?? `https://${this.accountName}.blob.core.windows.net`;
|
|
586
|
+
if (this.accountName && this.accountKey) {
|
|
587
|
+
const credential = new StorageSharedKeyCredential(this.accountName, this.accountKey);
|
|
588
|
+
serviceClient = new BlobServiceClient(baseUrl, credential);
|
|
589
|
+
} else if (this.sasToken) {
|
|
590
|
+
const sas = this.sasToken.replace(/^\?+/, "");
|
|
591
|
+
const separator = baseUrl.includes("?") ? "&" : "?";
|
|
592
|
+
serviceClient = new BlobServiceClient(`${baseUrl}${separator}${sas}`);
|
|
593
|
+
} else if (this.useDefaultCredential) {
|
|
594
|
+
try {
|
|
595
|
+
const identity = await import('@azure/identity');
|
|
596
|
+
const credential = new identity.DefaultAzureCredential();
|
|
597
|
+
serviceClient = new BlobServiceClient(baseUrl, credential);
|
|
598
|
+
} catch {
|
|
599
|
+
throw new Error(
|
|
600
|
+
"DefaultAzureCredential requires @azure/identity to be installed. Install it with: npm install @azure/identity"
|
|
601
|
+
);
|
|
602
|
+
}
|
|
603
|
+
} else {
|
|
604
|
+
serviceClient = new BlobServiceClient(baseUrl);
|
|
605
|
+
}
|
|
606
|
+
}
|
|
607
|
+
this._containerClient = serviceClient.getContainerClient(this.containerName);
|
|
608
|
+
return this._containerClient;
|
|
609
|
+
}
|
|
610
|
+
toKey(hash) {
|
|
611
|
+
return this.prefix + hash;
|
|
612
|
+
}
|
|
613
|
+
async init() {
|
|
614
|
+
}
|
|
615
|
+
async put(entry) {
|
|
616
|
+
const containerClient = await this.getContainerClient();
|
|
617
|
+
const blobClient = containerClient.getBlockBlobClient(this.toKey(entry.hash));
|
|
618
|
+
const now = entry.createdAt ?? /* @__PURE__ */ new Date();
|
|
619
|
+
const buffer = Buffer.from(entry.content, "utf-8");
|
|
620
|
+
await blobClient.uploadData(buffer, {
|
|
621
|
+
blobHTTPHeaders: {
|
|
622
|
+
blobContentType: entry.mimeType ?? "application/octet-stream"
|
|
623
|
+
},
|
|
624
|
+
metadata: {
|
|
625
|
+
size: String(entry.size),
|
|
626
|
+
createdat: now.toISOString(),
|
|
627
|
+
...entry.mimeType ? { mimetype: entry.mimeType } : {}
|
|
628
|
+
}
|
|
629
|
+
});
|
|
630
|
+
}
|
|
631
|
+
async get(hash) {
|
|
632
|
+
const containerClient = await this.getContainerClient();
|
|
633
|
+
const blobClient = containerClient.getBlockBlobClient(this.toKey(hash));
|
|
634
|
+
try {
|
|
635
|
+
const buffer = await blobClient.downloadToBuffer();
|
|
636
|
+
const properties = await blobClient.getProperties();
|
|
637
|
+
const metadata = properties.metadata ?? {};
|
|
638
|
+
const content = buffer.toString("utf-8");
|
|
639
|
+
return {
|
|
640
|
+
hash,
|
|
641
|
+
content,
|
|
642
|
+
size: metadata.size != null ? Number(metadata.size) : Buffer.byteLength(content, "utf-8"),
|
|
643
|
+
mimeType: metadata.mimetype || properties.contentType || void 0,
|
|
644
|
+
createdAt: metadata.createdat ? new Date(metadata.createdat) : /* @__PURE__ */ new Date()
|
|
645
|
+
};
|
|
646
|
+
} catch (error) {
|
|
647
|
+
if (isNotFoundError2(error)) return null;
|
|
648
|
+
throw error;
|
|
649
|
+
}
|
|
650
|
+
}
|
|
651
|
+
async has(hash) {
|
|
652
|
+
const containerClient = await this.getContainerClient();
|
|
653
|
+
const blobClient = containerClient.getBlockBlobClient(this.toKey(hash));
|
|
654
|
+
try {
|
|
655
|
+
await blobClient.getProperties();
|
|
656
|
+
return true;
|
|
657
|
+
} catch (error) {
|
|
658
|
+
if (isNotFoundError2(error)) return false;
|
|
659
|
+
throw error;
|
|
660
|
+
}
|
|
661
|
+
}
|
|
662
|
+
async delete(hash) {
|
|
663
|
+
const containerClient = await this.getContainerClient();
|
|
664
|
+
const blobClient = containerClient.getBlockBlobClient(this.toKey(hash));
|
|
665
|
+
const response = await blobClient.deleteIfExists();
|
|
666
|
+
return response.succeeded;
|
|
667
|
+
}
|
|
668
|
+
async putMany(entries) {
|
|
669
|
+
if (entries.length === 0) return;
|
|
670
|
+
await Promise.all(entries.map((entry) => this.put(entry)));
|
|
671
|
+
}
|
|
672
|
+
async getMany(hashes) {
|
|
673
|
+
const result = /* @__PURE__ */ new Map();
|
|
674
|
+
if (hashes.length === 0) return result;
|
|
675
|
+
const entries = await Promise.all(hashes.map((hash) => this.get(hash)));
|
|
676
|
+
for (const entry of entries) {
|
|
677
|
+
if (entry) {
|
|
678
|
+
result.set(entry.hash, entry);
|
|
679
|
+
}
|
|
680
|
+
}
|
|
681
|
+
return result;
|
|
682
|
+
}
|
|
683
|
+
async dangerouslyClearAll() {
|
|
684
|
+
const containerClient = await this.getContainerClient();
|
|
685
|
+
let batch = [];
|
|
686
|
+
for await (const blob of containerClient.listBlobsFlat({ prefix: this.prefix })) {
|
|
687
|
+
batch.push(blob.name);
|
|
688
|
+
if (batch.length >= BATCH_DELETE_SIZE) {
|
|
689
|
+
await this.deleteBlobBatch(containerClient, batch);
|
|
690
|
+
batch = [];
|
|
691
|
+
}
|
|
692
|
+
}
|
|
693
|
+
if (batch.length > 0) {
|
|
694
|
+
await this.deleteBlobBatch(containerClient, batch);
|
|
695
|
+
}
|
|
696
|
+
}
|
|
697
|
+
async deleteBlobBatch(containerClient, blobNames) {
|
|
698
|
+
const blobClients = blobNames.map((name) => containerClient.getBlobClient(name));
|
|
699
|
+
await containerClient.getBlobBatchClient().deleteBlobs(blobClients);
|
|
700
|
+
}
|
|
701
|
+
};
|
|
540
702
|
|
|
541
703
|
// src/blob/provider.ts
|
|
542
704
|
var azureBlobFilesystemProvider = {
|
|
@@ -564,7 +726,31 @@ var azureBlobFilesystemProvider = {
|
|
|
564
726
|
},
|
|
565
727
|
createFilesystem: (config) => new AzureBlobFilesystem(config)
|
|
566
728
|
};
|
|
729
|
+
var azureBlobStoreProvider = {
|
|
730
|
+
id: "azure-blob",
|
|
731
|
+
name: "Azure Blob Store",
|
|
732
|
+
description: "Content-addressable blob storage backed by Azure Blob Storage",
|
|
733
|
+
configSchema: {
|
|
734
|
+
type: "object",
|
|
735
|
+
required: ["container"],
|
|
736
|
+
properties: {
|
|
737
|
+
container: { type: "string", description: "Azure Blob container name" },
|
|
738
|
+
accountName: { type: "string", description: "Storage account name" },
|
|
739
|
+
accountKey: { type: "string", description: "Storage account key" },
|
|
740
|
+
sasToken: { type: "string", description: "Shared Access Signature token" },
|
|
741
|
+
connectionString: { type: "string", description: "Full connection string (overrides other auth options)" },
|
|
742
|
+
useDefaultCredential: {
|
|
743
|
+
type: "boolean",
|
|
744
|
+
description: "Use DefaultAzureCredential (requires @azure/identity)",
|
|
745
|
+
default: false
|
|
746
|
+
},
|
|
747
|
+
prefix: { type: "string", description: "Key prefix for blob objects (default: mastra_skill_blobs/)" },
|
|
748
|
+
endpoint: { type: "string", description: "Custom endpoint URL (for Azurite emulator)" }
|
|
749
|
+
}
|
|
750
|
+
},
|
|
751
|
+
createBlobStore: (config) => new AzureBlobStore(config)
|
|
752
|
+
};
|
|
567
753
|
|
|
568
|
-
export { AzureBlobFilesystem, azureBlobFilesystemProvider };
|
|
569
|
-
//# sourceMappingURL=chunk-
|
|
570
|
-
//# sourceMappingURL=chunk-
|
|
754
|
+
export { AzureBlobFilesystem, AzureBlobStore, azureBlobFilesystemProvider, azureBlobStoreProvider };
|
|
755
|
+
//# sourceMappingURL=chunk-DBBJ2YM7.js.map
|
|
756
|
+
//# sourceMappingURL=chunk-DBBJ2YM7.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/blob/filesystem/index.ts","../src/blob/blob-store/index.ts","../src/blob/provider.ts"],"names":["trimSlashes","isNotFoundError","BlobServiceClient","StorageSharedKeyCredential"],"mappings":"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","file":"chunk-DBBJ2YM7.js","sourcesContent":["/**\n * Azure Blob Storage Filesystem Provider\n *\n * A filesystem implementation backed by Azure Blob Storage.\n */\n\nimport { BlobSASPermissions, BlobServiceClient, StorageSharedKeyCredential } from '@azure/storage-blob';\nimport type { ContainerClient, RestError } from '@azure/storage-blob';\n\nimport type {\n FileContent,\n FileStat,\n FileEntry,\n ReadOptions,\n WriteOptions,\n ListOptions,\n RemoveOptions,\n CopyOptions,\n FilesystemInfo,\n FilesystemMountConfig,\n FilesystemIcon,\n ProviderStatus,\n MastraFilesystemOptions,\n} from '@mastra/core/workspace';\nimport { MastraFilesystem, FileNotFoundError, FileExistsError, PermissionError } from '@mastra/core/workspace';\n\n/**\n * Azure Blob mount configuration.\n * Returned by AzureBlobFilesystem.getMountConfig() for FUSE mounting in sandboxes.\n */\nexport interface AzureBlobMountConfig extends FilesystemMountConfig {\n type: 'azure-blob';\n container: string;\n accountName?: string;\n accountKey?: string;\n sasToken?: string;\n connectionString?: string;\n useDefaultCredential?: boolean;\n endpoint?: string;\n readOnly?: boolean;\n}\n\nconst MIME_TYPES: Record<string, string> = {\n '.txt': 'text/plain',\n '.md': 'text/markdown',\n '.markdown': 'text/markdown',\n '.html': 'text/html',\n '.htm': 'text/html',\n '.css': 'text/css',\n '.csv': 'text/csv',\n '.xml': 'text/xml',\n '.js': 'text/javascript',\n '.mjs': 'text/javascript',\n '.ts': 'text/typescript',\n '.tsx': 'text/typescript',\n '.jsx': 'text/javascript',\n '.json': 'application/json',\n '.yaml': 'text/yaml',\n '.yml': 'text/yaml',\n '.py': 'text/x-python',\n '.rb': 'text/x-ruby',\n '.sh': 'text/x-shellscript',\n '.bash': 'text/x-shellscript',\n '.png': 'image/png',\n '.jpg': 'image/jpeg',\n '.jpeg': 'image/jpeg',\n '.gif': 'image/gif',\n '.svg': 'image/svg+xml',\n '.webp': 'image/webp',\n '.ico': 'image/x-icon',\n '.pdf': 'application/pdf',\n '.zip': 'application/zip',\n '.gz': 'application/gzip',\n '.tar': 'application/x-tar',\n};\n\nfunction getMimeType(path: string): string {\n const ext = path.toLowerCase().match(/\\.[^.]+$/)?.[0];\n return ext ? (MIME_TYPES[ext] ?? 'application/octet-stream') : 'application/octet-stream';\n}\n\nfunction isNotFoundError(error: unknown): boolean {\n if (!error || typeof error !== 'object') return false;\n const restErr = error as { statusCode?: number };\n return restErr.statusCode === 404;\n}\n\nfunction isAccessDeniedError(error: unknown): boolean {\n if (!error || typeof error !== 'object') return false;\n const restErr = error as { statusCode?: number };\n return restErr.statusCode === 403;\n}\n\n/** Trim leading and trailing slashes without regex (avoids polynomial regex on user input). */\nfunction trimSlashes(s: string): string {\n let start = 0;\n let end = s.length;\n while (start < end && s[start] === '/') start++;\n while (end > start && s[end - 1] === '/') end--;\n return s.slice(start, end);\n}\n\nasync function streamToBuffer(stream: NodeJS.ReadableStream | undefined): Promise<Buffer> {\n if (!stream) return Buffer.alloc(0);\n const chunks: Buffer[] = [];\n for await (const chunk of stream) {\n chunks.push(typeof chunk === 'string' ? Buffer.from(chunk) : Buffer.isBuffer(chunk) ? chunk : Buffer.from(chunk));\n }\n return Buffer.concat(chunks);\n}\n\nfunction toBuffer(content: FileContent): Buffer {\n if (Buffer.isBuffer(content)) return content;\n return typeof content === 'string' ? Buffer.from(content, 'utf-8') : Buffer.from(content);\n}\n\nexport interface AzureBlobFilesystemOptions extends MastraFilesystemOptions {\n /** Unique identifier for this filesystem instance */\n id?: string;\n /** Azure Blob container name */\n container: string;\n /** Human-friendly display name for the UI */\n displayName?: string;\n /** Icon identifier for the UI (defaults to 'azure-blob') */\n icon?: FilesystemIcon;\n /** Description shown in tooltips */\n description?: string;\n /** Storage account name (required unless using connectionString) */\n accountName?: string;\n /** Storage account key */\n accountKey?: string;\n /** SAS token for authentication */\n sasToken?: string;\n /** Full connection string (takes priority over accountName/accountKey) */\n connectionString?: string;\n /**\n * Use DefaultAzureCredential from @azure/identity for authentication.\n * Supports Managed Identity, Azure CLI, environment variables, etc.\n * Requires @azure/identity to be installed as a peer dependency.\n */\n useDefaultCredential?: boolean;\n /** Optional prefix for all keys (acts like a subdirectory) */\n prefix?: string;\n /** Mount as read-only (blocks write operations, mounts read-only in sandboxes) */\n readOnly?: boolean;\n /**\n * Custom endpoint URL.\n * Used for local development with Azurite emulator.\n */\n endpoint?: string;\n}\n\nexport class AzureBlobFilesystem extends MastraFilesystem {\n readonly id: string;\n readonly name = 'AzureBlobFilesystem';\n readonly provider = 'azure-blob';\n readonly readOnly?: boolean;\n\n status: ProviderStatus = 'pending';\n\n readonly displayName?: string;\n readonly icon: FilesystemIcon = 'azure-blob';\n readonly description?: string;\n\n private readonly containerName: string;\n private readonly accountName?: string;\n private readonly accountKey?: string;\n private readonly sasToken?: string;\n private readonly connectionString?: string;\n private readonly useDefaultCredential: boolean;\n private readonly prefix: string;\n private readonly endpoint?: string;\n\n private _containerClient: ContainerClient | null = null;\n\n constructor(options: AzureBlobFilesystemOptions) {\n super({ ...options, name: 'AzureBlobFilesystem' });\n this.id = options.id ?? `azure-fs-${Date.now().toString(36)}-${Math.random().toString(36).slice(2, 8)}`;\n this.containerName = options.container;\n this.accountName = options.accountName;\n this.accountKey = options.accountKey;\n this.sasToken = options.sasToken;\n this.connectionString = options.connectionString;\n this.useDefaultCredential = options.useDefaultCredential ?? false;\n this.prefix = options.prefix ? trimSlashes(options.prefix) + '/' : '';\n this.endpoint = options.endpoint;\n\n this.displayName = options.displayName ?? 'Azure Blob Storage';\n this.icon = options.icon ?? 'azure-blob';\n this.description = options.description;\n this.readOnly = options.readOnly;\n }\n\n /**\n * Get the underlying ContainerClient for direct access to Azure Blob APIs.\n *\n * Use this when you need features not exposed through the WorkspaceFilesystem\n * interface (e.g., SAS URL generation, lease management, etc.).\n *\n * This is async because DefaultAzureCredential requires a dynamic import.\n * For non-DefaultAzureCredential auth methods, the promise resolves immediately.\n */\n getContainer(): Promise<ContainerClient> {\n return this.getContainerClient();\n }\n\n getMountConfig(): AzureBlobMountConfig {\n const config: AzureBlobMountConfig = {\n type: 'azure-blob',\n container: this.containerName,\n };\n\n if (this.connectionString) {\n config.connectionString = this.connectionString;\n } else {\n if (this.accountName) {\n config.accountName = this.accountName;\n }\n if (this.accountKey) {\n config.accountKey = this.accountKey;\n }\n if (this.sasToken) {\n config.sasToken = this.sasToken;\n }\n }\n\n if (this.useDefaultCredential) {\n config.useDefaultCredential = true;\n }\n\n if (this.endpoint) {\n config.endpoint = this.endpoint;\n }\n\n if (this.readOnly) {\n config.readOnly = true;\n }\n\n return config;\n }\n\n getInfo(): FilesystemInfo<{\n container: string;\n endpoint?: string;\n prefix?: string;\n }> {\n return {\n id: this.id,\n name: this.name,\n provider: this.provider,\n status: this.status,\n error: this.error,\n readOnly: this.readOnly,\n icon: this.icon,\n metadata: {\n container: this.containerName,\n ...(this.endpoint && { endpoint: this.endpoint }),\n ...(this.prefix && { prefix: this.prefix }),\n },\n };\n }\n\n getInstructions(): string {\n const access = this.readOnly ? 'Read-only' : 'Persistent';\n return `Azure Blob Storage in container \"${this.containerName}\". ${access} storage - files are retained across sessions.`;\n }\n\n private async getContainerClient(): Promise<ContainerClient> {\n if (this._containerClient) return this._containerClient;\n\n let serviceClient: BlobServiceClient;\n\n if (this.connectionString) {\n serviceClient = BlobServiceClient.fromConnectionString(this.connectionString);\n } else {\n if (!this.endpoint && !this.accountName) {\n throw new Error(\n 'Azure Blob Storage requires either a connectionString, or an accountName/endpoint. ' +\n 'Provide at least one of: connectionString, accountName, or endpoint.',\n );\n }\n const baseUrl = this.endpoint ?? `https://${this.accountName}.blob.core.windows.net`;\n\n if (this.accountName && this.accountKey) {\n const credential = new StorageSharedKeyCredential(this.accountName, this.accountKey);\n serviceClient = new BlobServiceClient(baseUrl, credential);\n } else if (this.sasToken) {\n const sas = this.sasToken.replace(/^\\?+/, '');\n const separator = baseUrl.includes('?') ? '&' : '?';\n serviceClient = new BlobServiceClient(`${baseUrl}${separator}${sas}`);\n } else if (this.useDefaultCredential) {\n // Dynamically import @azure/identity to avoid requiring it when not used.\n // Must use import() (not require()) because this package is ESM-first.\n try {\n const identity = await import('@azure/identity');\n const credential = new identity.DefaultAzureCredential();\n serviceClient = new BlobServiceClient(baseUrl, credential);\n } catch {\n throw new Error(\n 'DefaultAzureCredential requires @azure/identity to be installed. ' +\n 'Install it with: npm install @azure/identity',\n );\n }\n } else {\n // Anonymous access\n serviceClient = new BlobServiceClient(baseUrl);\n }\n }\n\n this._containerClient = serviceClient.getContainerClient(this.containerName);\n return this._containerClient;\n }\n\n private async getReadyContainer(): Promise<ContainerClient> {\n await this.ensureReady();\n return this.getContainerClient();\n }\n\n private toKey(path: string): string {\n const cleanPath = path.replace(/^\\/+/, '');\n return this.prefix + cleanPath;\n }\n\n private handleError(error: unknown): unknown {\n if (isAccessDeniedError(error)) {\n this.status = 'error';\n this.error = 'Access denied - check credentials and container permissions';\n }\n return error;\n }\n\n private assertWritable(path: string, operation: string): void {\n if (this.readOnly) {\n throw new PermissionError(path, `${operation} (filesystem is read-only)`);\n }\n }\n\n // ---------------------------------------------------------------------------\n // File Operations\n // ---------------------------------------------------------------------------\n\n async readFile(path: string, options?: ReadOptions): Promise<string | Buffer> {\n const containerClient = await this.getReadyContainer();\n const blobClient = containerClient.getBlockBlobClient(this.toKey(path));\n\n try {\n const response = await blobClient.download(0);\n const buffer = await streamToBuffer(response.readableStreamBody);\n\n if (options?.encoding) {\n return buffer.toString(options.encoding);\n }\n return buffer;\n } catch (error: unknown) {\n if (isNotFoundError(error)) {\n throw new FileNotFoundError(path);\n }\n throw this.handleError(error);\n }\n }\n\n async writeFile(path: string, content: FileContent, options?: WriteOptions): Promise<void> {\n this.assertWritable(path, 'write');\n const containerClient = await this.getReadyContainer();\n\n if (options?.overwrite === false && (await this.exists(path))) {\n throw new FileExistsError(path);\n }\n\n const body = toBuffer(content);\n const contentType = getMimeType(path);\n const blobClient = containerClient.getBlockBlobClient(this.toKey(path));\n\n await blobClient.upload(body, body.length, {\n blobHTTPHeaders: { blobContentType: contentType },\n });\n }\n\n async appendFile(path: string, content: FileContent): Promise<void> {\n this.assertWritable(path, 'append');\n let existing: Buffer = Buffer.alloc(0);\n try {\n const read = await this.readFile(path);\n existing = Buffer.isBuffer(read) ? read : Buffer.from(read);\n } catch (error) {\n if (error instanceof FileNotFoundError) {\n // File doesn't exist, start fresh with empty buffer\n } else {\n throw error;\n }\n }\n\n const appendBuffer = toBuffer(content);\n await this.writeFile(path, Buffer.concat([existing, appendBuffer]));\n }\n\n async deleteFile(path: string, options?: RemoveOptions): Promise<void> {\n this.assertWritable(path, 'delete');\n const isDir = await this.isDirectory(path);\n if (isDir) {\n await this.rmdir(path, { recursive: true, force: options?.force });\n return;\n }\n\n const containerClient = await this.getReadyContainer();\n const blobClient = containerClient.getBlobClient(this.toKey(path));\n\n try {\n await blobClient.delete();\n } catch (error: unknown) {\n if (isNotFoundError(error)) {\n if (options?.force) return;\n throw new FileNotFoundError(path);\n }\n throw this.handleError(error);\n }\n }\n\n async copyFile(src: string, dest: string, options?: CopyOptions): Promise<void> {\n this.assertWritable(dest, 'copy');\n if (options?.overwrite === false && (await this.exists(dest))) {\n throw new FileExistsError(dest);\n }\n\n const containerClient = await this.getReadyContainer();\n const srcBlob = containerClient.getBlobClient(this.toKey(src));\n const destBlob = containerClient.getBlobClient(this.toKey(dest));\n\n try {\n const sasUrl = await srcBlob.generateSasUrl({\n permissions: BlobSASPermissions.parse('r'),\n expiresOn: new Date(Date.now() + 5 * 60 * 1000),\n });\n\n const properties = await srcBlob.getProperties();\n\n if (properties.contentLength === 0) {\n // Azure bug: syncCopyFromURL fails on zero-length blobs with CannotVerifyCopySource\n await destBlob.getBlockBlobClient().upload(Buffer.alloc(0), 0);\n return;\n }\n\n const MAX_SYNC_COPY_SIZE = 256 * 1024 * 1024;\n if ((properties.contentLength ?? 0) <= MAX_SYNC_COPY_SIZE) {\n await destBlob.syncCopyFromURL(sasUrl);\n } else {\n const poller = await destBlob.beginCopyFromURL(sasUrl);\n await poller.pollUntilDone();\n }\n } catch (error: unknown) {\n if (isNotFoundError(error)) {\n throw new FileNotFoundError(src);\n }\n\n // SAS generation fails without StorageSharedKeyCredential (e.g. DefaultAzureCredential).\n // Fall back to download+reupload.\n if (\n error instanceof Error &&\n (error.message.includes('generateSasUrl') ||\n (error.message.includes('SAS') && error.message.includes('shared key credential')))\n ) {\n const content = await this.readFile(src);\n await this.writeFile(dest, content);\n return;\n }\n\n throw this.handleError(error);\n }\n }\n\n async moveFile(src: string, dest: string, options?: CopyOptions): Promise<void> {\n this.assertWritable(dest, 'move');\n await this.copyFile(src, dest, options);\n await this.deleteFile(src, { force: true });\n }\n\n // ---------------------------------------------------------------------------\n // Directory Operations\n // ---------------------------------------------------------------------------\n\n async mkdir(_path: string, _options?: { recursive?: boolean }): Promise<void> {\n // Azure Blob Storage doesn't have real directories - they're just key prefixes.\n // No-op, directories are created implicitly when files are written.\n }\n\n async rmdir(path: string, options?: RemoveOptions): Promise<void> {\n this.assertWritable(path, 'rmdir');\n const containerClient = await this.getReadyContainer();\n const prefix = this.toKey(path).replace(/\\/$/, '') + '/';\n\n if (!options?.recursive) {\n const iter = containerClient.listBlobsFlat({ prefix });\n const first = await iter.next();\n if (!first.done) {\n throw new Error(`Directory not empty: ${path}`);\n }\n return;\n }\n\n // Delete all blobs with this prefix in batches\n let blobNames: string[] = [];\n for await (const blob of containerClient.listBlobsFlat({ prefix })) {\n blobNames.push(blob.name);\n\n if (blobNames.length >= 256) {\n await this.deleteBlobBatch(containerClient, blobNames);\n blobNames = [];\n }\n }\n\n if (blobNames.length > 0) {\n await this.deleteBlobBatch(containerClient, blobNames);\n }\n }\n\n private async deleteBlobBatch(containerClient: ContainerClient, blobNames: string[]): Promise<void> {\n const blobClients = blobNames.map(name => containerClient.getBlobClient(name));\n await containerClient.getBlobBatchClient().deleteBlobs(blobClients);\n }\n\n async readdir(path: string, options?: ListOptions): Promise<FileEntry[]> {\n const containerClient = await this.getReadyContainer();\n\n const prefix = this.toKey(path).replace(/\\/$/, '');\n const searchPrefix = prefix ? prefix + '/' : '';\n\n const entries: FileEntry[] = [];\n const seenDirs = new Set<string>();\n\n if (options?.recursive) {\n for await (const blob of containerClient.listBlobsFlat({ prefix: searchPrefix })) {\n const key = blob.name;\n if (!key || key === searchPrefix) continue;\n\n const relativePath = key.slice(searchPrefix.length);\n if (!relativePath) continue;\n\n if (relativePath.endsWith('/')) {\n const dirName = relativePath.slice(0, -1);\n if (!seenDirs.has(dirName)) {\n seenDirs.add(dirName);\n entries.push({ name: dirName, type: 'directory' });\n }\n continue;\n }\n\n if (options?.extension) {\n const extensions = Array.isArray(options.extension) ? options.extension : [options.extension];\n if (!extensions.some(ext => relativePath.endsWith(ext))) {\n continue;\n }\n }\n\n entries.push({\n name: relativePath,\n type: 'file',\n size: blob.properties.contentLength,\n });\n }\n } else {\n for await (const item of containerClient.listBlobsByHierarchy('/', { prefix: searchPrefix })) {\n if (item.kind === 'prefix') {\n const dirName = item.name.slice(searchPrefix.length).replace(/\\/$/, '');\n if (dirName && !seenDirs.has(dirName)) {\n seenDirs.add(dirName);\n entries.push({ name: dirName, type: 'directory' });\n }\n } else {\n const key = item.name;\n if (!key || key === searchPrefix) continue;\n\n const relativePath = key.slice(searchPrefix.length);\n if (!relativePath) continue;\n\n if (relativePath.endsWith('/')) {\n const dirName = relativePath.slice(0, -1);\n if (!seenDirs.has(dirName)) {\n seenDirs.add(dirName);\n entries.push({ name: dirName, type: 'directory' });\n }\n continue;\n }\n\n if (options?.extension) {\n const extensions = Array.isArray(options.extension) ? options.extension : [options.extension];\n if (!extensions.some(ext => relativePath.endsWith(ext))) {\n continue;\n }\n }\n\n entries.push({\n name: relativePath,\n type: 'file',\n size: item.properties.contentLength,\n });\n }\n }\n }\n\n return entries;\n }\n\n // ---------------------------------------------------------------------------\n // Path Operations\n // ---------------------------------------------------------------------------\n\n async exists(path: string): Promise<boolean> {\n const key = this.toKey(path);\n if (!key) return true;\n\n const containerClient = await this.getReadyContainer();\n const blobClient = containerClient.getBlobClient(key);\n\n const exists = await blobClient.exists();\n if (exists) return true;\n\n // Check if it's a \"directory\" (has blobs with this prefix)\n const prefix = key.replace(/\\/$/, '') + '/';\n const iter = containerClient.listBlobsFlat({ prefix });\n const first = await iter.next();\n return !first.done;\n }\n\n async stat(path: string): Promise<FileStat> {\n const key = this.toKey(path);\n\n if (!key) {\n return {\n name: '',\n path,\n type: 'directory',\n size: 0,\n createdAt: new Date(),\n modifiedAt: new Date(),\n };\n }\n\n const containerClient = await this.getReadyContainer();\n const blobClient = containerClient.getBlobClient(key);\n\n try {\n const properties = await blobClient.getProperties();\n const name = path.split('/').pop() ?? '';\n\n return {\n name,\n path,\n type: 'file',\n size: properties.contentLength ?? 0,\n createdAt: properties.createdOn ?? new Date(),\n modifiedAt: properties.lastModified ?? new Date(),\n };\n } catch (error: unknown) {\n if (!isNotFoundError(error)) throw this.handleError(error);\n\n const isDir = await this.isDirectory(path);\n if (isDir) {\n const name = path.split('/').filter(Boolean).pop() ?? '';\n return {\n name,\n path,\n type: 'directory',\n size: 0,\n createdAt: new Date(),\n modifiedAt: new Date(),\n };\n }\n\n throw new FileNotFoundError(path);\n }\n }\n\n async isFile(path: string): Promise<boolean> {\n const key = this.toKey(path);\n if (!key) return false;\n\n const containerClient = await this.getReadyContainer();\n const blobClient = containerClient.getBlobClient(key);\n return blobClient.exists();\n }\n\n async isDirectory(path: string): Promise<boolean> {\n const key = this.toKey(path);\n if (!key) return true;\n\n const containerClient = await this.getReadyContainer();\n const prefix = key.replace(/\\/$/, '') + '/';\n const iter = containerClient.listBlobsFlat({ prefix });\n const first = await iter.next();\n return !first.done;\n }\n\n // ---------------------------------------------------------------------------\n // Lifecycle\n // ---------------------------------------------------------------------------\n\n async init(): Promise<void> {\n const containerClient = await this.getContainerClient();\n try {\n if (this.sasToken) {\n const iter = containerClient.listBlobsFlat({ prefix: this.prefix });\n await iter.next();\n return;\n }\n\n const exists = await containerClient.exists();\n if (!exists) {\n const err = new Error(`Container \"${this.containerName}\" does not exist`) as Error & { status?: number };\n err.status = 404;\n throw err;\n }\n } catch (error) {\n if ((error as { status?: number }).status) {\n throw error;\n }\n\n const statusCode = (error as RestError).statusCode;\n if (typeof statusCode === 'number') {\n const message = error instanceof Error ? error.message : String(error);\n const err = new Error(message) as Error & { status?: number };\n err.status = statusCode;\n throw err;\n }\n throw error;\n }\n }\n\n async destroy(): Promise<void> {\n this._containerClient = null;\n }\n}\n","import { BlobServiceClient, StorageSharedKeyCredential } from '@azure/storage-blob';\nimport type { ContainerClient } from '@azure/storage-blob';\n\nimport { BlobStore } from '@mastra/core/storage';\nimport type { StorageBlobEntry } from '@mastra/core/storage';\n\n/**\n * Configuration for AzureBlobStore.\n */\nexport interface AzureBlobStoreOptions {\n /** Azure Blob container name */\n container: string;\n /** Storage account name (required unless using connectionString) */\n accountName?: string;\n /** Storage account key */\n accountKey?: string;\n /** SAS token for authentication */\n sasToken?: string;\n /** Full connection string (takes priority over accountName/accountKey) */\n connectionString?: string;\n /**\n * Use DefaultAzureCredential from @azure/identity for authentication.\n * Requires @azure/identity to be installed as a peer dependency.\n */\n useDefaultCredential?: boolean;\n /** Custom endpoint URL (e.g. for the Azurite emulator) */\n endpoint?: string;\n /**\n * Key prefix for all blob objects.\n * Defaults to 'mastra_skill_blobs/'.\n */\n prefix?: string;\n}\n\n/** Trim leading and trailing slashes. */\nfunction trimSlashes(s: string): string {\n let start = 0;\n let end = s.length;\n while (start < end && s[start] === '/') start++;\n while (end > start && s[end - 1] === '/') end--;\n return s.slice(start, end);\n}\n\nfunction isNotFoundError(error: unknown): boolean {\n if (!error || typeof error !== 'object') return false;\n return (error as { statusCode?: number }).statusCode === 404;\n}\n\n/** Azure metadata batch limit per request. */\nconst BATCH_DELETE_SIZE = 256;\n\n/**\n * Azure Blob Storage-backed content-addressable blob store for skill versioning.\n *\n * Each blob is stored as a block blob keyed by its SHA-256 hash. Metadata\n * (size, mimeType, createdAt) is stored as Azure blob metadata.\n *\n * Since blobs are content-addressable, writes are idempotent — the same hash\n * always maps to the same content, so overwrites are safe and equivalent to\n * a no-op.\n *\n * @example Connection string\n * ```typescript\n * import { AzureBlobStore } from '@mastra/azure/blob';\n *\n * const blobs = new AzureBlobStore({\n * container: 'my-skill-blobs',\n * connectionString: process.env.AZURE_STORAGE_CONNECTION_STRING!,\n * });\n * ```\n *\n * @example Account key\n * ```typescript\n * import { AzureBlobStore } from '@mastra/azure/blob';\n *\n * const blobs = new AzureBlobStore({\n * container: 'my-skill-blobs',\n * accountName: process.env.AZURE_STORAGE_ACCOUNT_NAME!,\n * accountKey: process.env.AZURE_STORAGE_ACCOUNT_KEY!,\n * });\n * ```\n */\nexport class AzureBlobStore extends BlobStore {\n private readonly containerName: string;\n private readonly accountName?: string;\n private readonly accountKey?: string;\n private readonly sasToken?: string;\n private readonly connectionString?: string;\n private readonly useDefaultCredential: boolean;\n private readonly endpoint?: string;\n private readonly prefix: string;\n\n private _containerClient: ContainerClient | null = null;\n\n constructor(options: AzureBlobStoreOptions) {\n super();\n this.containerName = options.container;\n this.accountName = options.accountName;\n this.accountKey = options.accountKey;\n this.sasToken = options.sasToken;\n this.connectionString = options.connectionString;\n this.useDefaultCredential = options.useDefaultCredential ?? false;\n this.endpoint = options.endpoint;\n this.prefix = options.prefix ? trimSlashes(options.prefix) + '/' : 'mastra_skill_blobs/';\n }\n\n private async getContainerClient(): Promise<ContainerClient> {\n if (this._containerClient) return this._containerClient;\n\n let serviceClient: BlobServiceClient;\n\n if (this.connectionString) {\n serviceClient = BlobServiceClient.fromConnectionString(this.connectionString);\n } else {\n if (!this.endpoint && !this.accountName) {\n throw new Error(\n 'Azure Blob Storage requires either a connectionString, or an accountName/endpoint. ' +\n 'Provide at least one of: connectionString, accountName, or endpoint.',\n );\n }\n const baseUrl = this.endpoint ?? `https://${this.accountName}.blob.core.windows.net`;\n\n if (this.accountName && this.accountKey) {\n const credential = new StorageSharedKeyCredential(this.accountName, this.accountKey);\n serviceClient = new BlobServiceClient(baseUrl, credential);\n } else if (this.sasToken) {\n const sas = this.sasToken.replace(/^\\?+/, '');\n const separator = baseUrl.includes('?') ? '&' : '?';\n serviceClient = new BlobServiceClient(`${baseUrl}${separator}${sas}`);\n } else if (this.useDefaultCredential) {\n // Dynamically import @azure/identity to avoid requiring it when not used.\n // Must use import() (not require()) because this package is ESM-first.\n try {\n const identity = await import('@azure/identity');\n const credential = new identity.DefaultAzureCredential();\n serviceClient = new BlobServiceClient(baseUrl, credential);\n } catch {\n throw new Error(\n 'DefaultAzureCredential requires @azure/identity to be installed. ' +\n 'Install it with: npm install @azure/identity',\n );\n }\n } else {\n // Anonymous access\n serviceClient = new BlobServiceClient(baseUrl);\n }\n }\n\n this._containerClient = serviceClient.getContainerClient(this.containerName);\n return this._containerClient;\n }\n\n private toKey(hash: string): string {\n return this.prefix + hash;\n }\n\n async init(): Promise<void> {\n // Azure does not require table creation — the container is expected to exist.\n }\n\n async put(entry: StorageBlobEntry): Promise<void> {\n const containerClient = await this.getContainerClient();\n const blobClient = containerClient.getBlockBlobClient(this.toKey(entry.hash));\n const now = entry.createdAt ?? new Date();\n const buffer = Buffer.from(entry.content, 'utf-8');\n\n await blobClient.uploadData(buffer, {\n blobHTTPHeaders: {\n blobContentType: entry.mimeType ?? 'application/octet-stream',\n },\n metadata: {\n size: String(entry.size),\n createdat: now.toISOString(),\n ...(entry.mimeType ? { mimetype: entry.mimeType } : {}),\n },\n });\n }\n\n async get(hash: string): Promise<StorageBlobEntry | null> {\n const containerClient = await this.getContainerClient();\n const blobClient = containerClient.getBlockBlobClient(this.toKey(hash));\n\n try {\n const buffer = await blobClient.downloadToBuffer();\n const properties = await blobClient.getProperties();\n const metadata = properties.metadata ?? {};\n const content = buffer.toString('utf-8');\n\n return {\n hash,\n content,\n size: metadata.size != null ? Number(metadata.size) : Buffer.byteLength(content, 'utf-8'),\n mimeType: metadata.mimetype || properties.contentType || undefined,\n createdAt: metadata.createdat ? new Date(metadata.createdat) : new Date(),\n };\n } catch (error: unknown) {\n if (isNotFoundError(error)) return null;\n throw error;\n }\n }\n\n async has(hash: string): Promise<boolean> {\n const containerClient = await this.getContainerClient();\n const blobClient = containerClient.getBlockBlobClient(this.toKey(hash));\n\n try {\n await blobClient.getProperties();\n return true;\n } catch (error: unknown) {\n if (isNotFoundError(error)) return false;\n throw error;\n }\n }\n\n async delete(hash: string): Promise<boolean> {\n const containerClient = await this.getContainerClient();\n const blobClient = containerClient.getBlockBlobClient(this.toKey(hash));\n const response = await blobClient.deleteIfExists();\n return response.succeeded;\n }\n\n async putMany(entries: StorageBlobEntry[]): Promise<void> {\n if (entries.length === 0) return;\n // Azure does not have a batch PUT, so we parallelize individual puts.\n // Content-addressable means duplicate writes are idempotent.\n await Promise.all(entries.map(entry => this.put(entry)));\n }\n\n async getMany(hashes: string[]): Promise<Map<string, StorageBlobEntry>> {\n const result = new Map<string, StorageBlobEntry>();\n if (hashes.length === 0) return result;\n\n const entries = await Promise.all(hashes.map(hash => this.get(hash)));\n for (const entry of entries) {\n if (entry) {\n result.set(entry.hash, entry);\n }\n }\n return result;\n }\n\n async dangerouslyClearAll(): Promise<void> {\n const containerClient = await this.getContainerClient();\n let batch: string[] = [];\n\n for await (const blob of containerClient.listBlobsFlat({ prefix: this.prefix })) {\n batch.push(blob.name);\n if (batch.length >= BATCH_DELETE_SIZE) {\n await this.deleteBlobBatch(containerClient, batch);\n batch = [];\n }\n }\n\n if (batch.length > 0) {\n await this.deleteBlobBatch(containerClient, batch);\n }\n }\n\n private async deleteBlobBatch(containerClient: ContainerClient, blobNames: string[]): Promise<void> {\n const blobClients = blobNames.map(name => containerClient.getBlobClient(name));\n await containerClient.getBlobBatchClient().deleteBlobs(blobClients);\n }\n}\n","import type { BlobStoreProvider, FilesystemProvider } from '@mastra/core/editor';\nimport { AzureBlobStore } from './blob-store';\nimport type { AzureBlobStoreOptions } from './blob-store';\nimport { AzureBlobFilesystem } from './filesystem';\nimport type { AzureBlobFilesystemOptions } from './filesystem';\n\nexport const azureBlobFilesystemProvider: FilesystemProvider<AzureBlobFilesystemOptions> = {\n id: 'azure-blob',\n name: 'Azure Blob Storage',\n description: 'Azure Blob Storage container',\n configSchema: {\n type: 'object',\n required: ['container'],\n properties: {\n container: { type: 'string', description: 'Azure Blob container name' },\n accountName: { type: 'string', description: 'Storage account name' },\n accountKey: { type: 'string', description: 'Storage account key' },\n sasToken: { type: 'string', description: 'Shared Access Signature token' },\n connectionString: { type: 'string', description: 'Full connection string (overrides other auth options)' },\n useDefaultCredential: {\n type: 'boolean',\n description: 'Use DefaultAzureCredential (requires @azure/identity)',\n default: false,\n },\n prefix: { type: 'string', description: 'Key prefix (acts like a subdirectory)' },\n readOnly: { type: 'boolean', description: 'Mount as read-only', default: false },\n endpoint: { type: 'string', description: 'Custom endpoint URL (for Azurite emulator)' },\n },\n },\n createFilesystem: config => new AzureBlobFilesystem(config),\n};\n\nexport const azureBlobStoreProvider: BlobStoreProvider<AzureBlobStoreOptions> = {\n id: 'azure-blob',\n name: 'Azure Blob Store',\n description: 'Content-addressable blob storage backed by Azure Blob Storage',\n configSchema: {\n type: 'object',\n required: ['container'],\n properties: {\n container: { type: 'string', description: 'Azure Blob container name' },\n accountName: { type: 'string', description: 'Storage account name' },\n accountKey: { type: 'string', description: 'Storage account key' },\n sasToken: { type: 'string', description: 'Shared Access Signature token' },\n connectionString: { type: 'string', description: 'Full connection string (overrides other auth options)' },\n useDefaultCredential: {\n type: 'boolean',\n description: 'Use DefaultAzureCredential (requires @azure/identity)',\n default: false,\n },\n prefix: { type: 'string', description: 'Key prefix for blob objects (default: mastra_skill_blobs/)' },\n endpoint: { type: 'string', description: 'Custom endpoint URL (for Azurite emulator)' },\n },\n },\n createBlobStore: config => new AzureBlobStore(config),\n};\n"]}
|