@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.
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../src/blob/filesystem/index.ts","../src/blob/provider.ts"],"names":[],"mappings":"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","file":"chunk-VFZDLQDB.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 type { FilesystemProvider } from '@mastra/core/editor';\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"]}