@mastra/cloudflare 1.2.3 → 1.3.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 +26 -0
- package/dist/chunk-E4MARS3A.cjs +2135 -0
- package/dist/chunk-E4MARS3A.cjs.map +1 -0
- package/dist/chunk-NSFHQATX.js +2128 -0
- package/dist/chunk-NSFHQATX.js.map +1 -0
- package/dist/chunk-O57GFJSB.js +2265 -0
- package/dist/chunk-O57GFJSB.js.map +1 -0
- package/dist/chunk-ZBYNKKG6.cjs +2275 -0
- package/dist/chunk-ZBYNKKG6.cjs.map +1 -0
- package/dist/do/index.cjs +32 -0
- package/dist/do/index.cjs.map +1 -0
- package/dist/do/index.d.ts +91 -0
- package/dist/do/index.d.ts.map +1 -0
- package/dist/do/index.js +3 -0
- package/dist/do/index.js.map +1 -0
- package/dist/do/storage/db/index.d.ts +76 -0
- package/dist/do/storage/db/index.d.ts.map +1 -0
- package/dist/do/storage/domains/memory/index.d.ts +60 -0
- package/dist/do/storage/domains/memory/index.d.ts.map +1 -0
- package/dist/do/storage/domains/scores/index.d.ts +38 -0
- package/dist/do/storage/domains/scores/index.d.ts.map +1 -0
- package/dist/do/storage/domains/utils.d.ts +3 -0
- package/dist/do/storage/domains/utils.d.ts.map +1 -0
- package/dist/do/storage/domains/workflows/index.d.ts +46 -0
- package/dist/do/storage/domains/workflows/index.d.ts.map +1 -0
- package/dist/do/storage/sql-builder.d.ts +128 -0
- package/dist/do/storage/sql-builder.d.ts.map +1 -0
- package/dist/docs/SKILL.md +2 -2
- package/dist/docs/assets/SOURCE_MAP.json +56 -2
- package/dist/docs/references/reference-storage-cloudflare.md +79 -8
- package/dist/index.cjs +49 -2269
- package/dist/index.cjs.map +1 -1
- package/dist/index.d.ts +4 -1
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +2 -2262
- package/dist/index.js.map +1 -1
- package/dist/kv/index.cjs +28 -0
- package/dist/kv/index.cjs.map +1 -0
- package/dist/{storage → kv}/index.d.ts +11 -7
- package/dist/kv/index.d.ts.map +1 -0
- package/dist/kv/index.js +3 -0
- package/dist/kv/index.js.map +1 -0
- package/dist/kv/storage/db/index.d.ts.map +1 -0
- package/dist/kv/storage/domains/memory/index.d.ts.map +1 -0
- package/dist/kv/storage/domains/scores/index.d.ts.map +1 -0
- package/dist/kv/storage/domains/workflows/index.d.ts.map +1 -0
- package/dist/kv/storage/test-utils.d.ts.map +1 -0
- package/dist/kv/storage/types.d.ts.map +1 -0
- package/package.json +26 -5
- package/dist/storage/db/index.d.ts.map +0 -1
- package/dist/storage/domains/memory/index.d.ts.map +0 -1
- package/dist/storage/domains/scores/index.d.ts.map +0 -1
- package/dist/storage/domains/workflows/index.d.ts.map +0 -1
- package/dist/storage/index.d.ts.map +0 -1
- package/dist/storage/test-utils.d.ts.map +0 -1
- package/dist/storage/types.d.ts.map +0 -1
- /package/dist/{storage → kv/storage}/db/index.d.ts +0 -0
- /package/dist/{storage → kv/storage}/domains/memory/index.d.ts +0 -0
- /package/dist/{storage → kv/storage}/domains/scores/index.d.ts +0 -0
- /package/dist/{storage → kv/storage}/domains/workflows/index.d.ts +0 -0
- /package/dist/{storage → kv/storage}/test-utils.d.ts +0 -0
- /package/dist/{storage → kv/storage}/types.d.ts +0 -0
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/do/storage/domains/utils.ts","../src/do/storage/sql-builder.ts","../src/do/storage/db/index.ts","../src/do/storage/domains/memory/index.ts","../src/do/storage/domains/scores/index.ts","../src/do/storage/domains/workflows/index.ts","../src/do/index.ts"],"names":["parseSqlIdentifier","MastraBase","error","MastraError","createStorageErrorId","ErrorDomain","ErrorCategory","getSqlType","getDefaultValue","TABLE_WORKFLOW_SNAPSHOT","MemoryStorage","TABLE_THREADS","TABLE_SCHEMAS","TABLE_MESSAGES","TABLE_RESOURCES","ensureDate","normalizePerPage","calculatePagination","MessageList","serializeDate","coreTransformScoreRow","ScoresStorage","TABLE_SCORERS","saveScorePayloadSchema","WorkflowsStorage","MastraCompositeStore"],"mappings":"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","file":"chunk-E4MARS3A.cjs","sourcesContent":["export function isArrayOfRecords(value: unknown): value is Record<string, unknown>[] {\n return value !== null && value !== undefined && Array.isArray(value);\n}\n\nexport function deserializeValue(value: unknown, type?: string): unknown {\n if (value === null || value === undefined) return null;\n\n if (type === 'date' && typeof value === 'string') {\n return new Date(value);\n }\n\n if (type === 'jsonb' && typeof value === 'string') {\n try {\n return JSON.parse(value);\n } catch {\n return value;\n }\n }\n\n if (typeof value === 'string' && (value.startsWith('{') || value.startsWith('['))) {\n try {\n return JSON.parse(value);\n } catch {\n return value;\n }\n }\n\n return value;\n}\n","import { parseSqlIdentifier } from '@mastra/core/utils';\n\n/**\n * Type definition for SQL query parameters\n */\nexport type SqlParam = string | number | boolean | null | undefined;\n\n/**\n * Interface for SQL query options with generic type support\n */\nexport interface SqlQueryOptions {\n /** SQL query to execute */\n sql: string;\n /** Parameters to bind to the query */\n params?: SqlParam[];\n /** Whether to return only the first result */\n first?: boolean;\n}\n\n/**\n * SQL Builder class for constructing type-safe SQL queries\n * This helps create maintainable and secure SQL queries with proper parameter handling\n */\nexport class SqlBuilder {\n private sql: string = '';\n private params: SqlParam[] = [];\n private whereAdded: boolean = false;\n\n // Basic query building\n select(columns?: string | string[]): SqlBuilder {\n if (!columns || (Array.isArray(columns) && columns.length === 0)) {\n this.sql = 'SELECT *';\n } else {\n const cols = Array.isArray(columns) ? columns : [columns];\n const parsedCols = cols.map(col => parseSelectIdentifier(col));\n this.sql = `SELECT ${parsedCols.join(', ')}`;\n }\n return this;\n }\n\n from(table: string): SqlBuilder {\n const parsedTableName = parseSqlIdentifier(table, 'table name');\n this.sql += ` FROM ${parsedTableName}`;\n return this;\n }\n\n /**\n * Add a WHERE clause to the query\n * @param condition The condition to add\n * @param params Parameters to bind to the condition\n */\n where(condition: string, ...params: SqlParam[]): SqlBuilder {\n this.sql += ` WHERE ${condition}`;\n this.params.push(...params);\n this.whereAdded = true;\n return this;\n }\n\n /**\n * Add a WHERE clause if it hasn't been added yet, otherwise add an AND clause\n * @param condition The condition to add\n * @param params Parameters to bind to the condition\n */\n whereAnd(condition: string, ...params: SqlParam[]): SqlBuilder {\n if (this.whereAdded) {\n return this.andWhere(condition, ...params);\n } else {\n return this.where(condition, ...params);\n }\n }\n\n andWhere(condition: string, ...params: SqlParam[]): SqlBuilder {\n this.sql += ` AND ${condition}`;\n this.params.push(...params);\n return this;\n }\n\n orWhere(condition: string, ...params: SqlParam[]): SqlBuilder {\n this.sql += ` OR ${condition}`;\n this.params.push(...params);\n return this;\n }\n\n orderBy(column: string, direction: 'ASC' | 'DESC' = 'ASC'): SqlBuilder {\n const parsedColumn = parseSqlIdentifier(column, 'column name');\n if (!['ASC', 'DESC'].includes(direction)) {\n throw new Error(`Invalid sort direction: ${direction}`);\n }\n this.sql += ` ORDER BY ${parsedColumn} ${direction}`;\n return this;\n }\n\n limit(count: number): SqlBuilder {\n this.sql += ` LIMIT ?`;\n this.params.push(count);\n return this;\n }\n\n offset(count: number): SqlBuilder {\n this.sql += ` OFFSET ?`;\n this.params.push(count);\n return this;\n }\n\n count(): SqlBuilder {\n this.sql += 'SELECT COUNT(*) AS count';\n return this;\n }\n\n /**\n * Insert a row, or update specific columns on conflict (upsert).\n * @param table Table name\n * @param columns Columns to insert\n * @param values Values to insert\n * @param conflictColumns Columns to check for conflict (usually PK or UNIQUE)\n * @param updateMap Object mapping columns to update to their new value (e.g. { name: 'excluded.name' })\n */\n insert(\n table: string,\n columns: string[],\n values: SqlParam[],\n conflictColumns?: string[],\n updateMap?: Record<string, string>,\n ): SqlBuilder {\n const parsedTableName = parseSqlIdentifier(table, 'table name');\n const parsedColumns = columns.map(col => parseSqlIdentifier(col, 'column name'));\n const placeholders = parsedColumns.map(() => '?').join(', ');\n\n if (conflictColumns && updateMap) {\n const parsedConflictColumns = conflictColumns.map(col => parseSqlIdentifier(col, 'column name'));\n // Validate updateMap: keys must be valid identifiers, values must be safe patterns\n // Allowed: 'excluded.<column>' or 'COALESCE(excluded.<column>, <table>.<column>)'\n const excludedPattern = /^excluded\\.[a-zA-Z_][a-zA-Z0-9_]*$/;\n const coalescePattern =\n /^COALESCE\\(excluded\\.[a-zA-Z_][a-zA-Z0-9_]*,\\s*[a-zA-Z_][a-zA-Z0-9_]*\\.[a-zA-Z_][a-zA-Z0-9_]*\\)$/;\n const updateClause = Object.entries(updateMap)\n .map(([col, expr]) => {\n const parsedCol = parseSqlIdentifier(col, 'update column name');\n if (!excludedPattern.test(expr) && !coalescePattern.test(expr)) {\n throw new Error(\n `Invalid update expression for column ${col}: must be 'excluded.<column>' or 'COALESCE(excluded.<column>, <table>.<column>)' pattern`,\n );\n }\n return `${parsedCol} = ${expr}`;\n })\n .join(', ');\n this.sql = `INSERT INTO ${parsedTableName} (${parsedColumns.join(', ')}) VALUES (${placeholders}) ON CONFLICT(${parsedConflictColumns.join(', ')}) DO UPDATE SET ${updateClause}`;\n this.params.push(...values);\n return this;\n }\n\n this.sql = `INSERT INTO ${parsedTableName} (${parsedColumns.join(', ')}) VALUES (${placeholders})`;\n this.params.push(...values);\n\n return this;\n }\n\n // Update operations\n update(table: string, columns: string[], values: SqlParam[]): SqlBuilder {\n const parsedTableName = parseSqlIdentifier(table, 'table name');\n const parsedColumns = columns.map(col => parseSqlIdentifier(col, 'column name'));\n const setClause = parsedColumns.map(col => `${col} = ?`).join(', ');\n this.sql = `UPDATE ${parsedTableName} SET ${setClause}`;\n this.params.push(...values);\n return this;\n }\n\n // Delete operations\n delete(table: string): SqlBuilder {\n const parsedTableName = parseSqlIdentifier(table, 'table name');\n this.sql = `DELETE FROM ${parsedTableName}`;\n return this;\n }\n\n /**\n * Create a table if it doesn't exist\n * @param table The table name\n * @param columnDefinitions The column definitions as an array of strings\n * @param tableConstraints Optional constraints for the table\n * @returns The builder instance\n */\n createTable(table: string, columnDefinitions: string[], tableConstraints?: string[]): SqlBuilder {\n const parsedTableName = parseSqlIdentifier(table, 'table name');\n // Naive validation: check the first word of each column definition\n const parsedColumnDefinitions = columnDefinitions.map(def => {\n const colName = def.split(/\\s+/)[0];\n if (!colName) throw new Error('Empty column name in definition');\n parseSqlIdentifier(colName, 'column name');\n return def;\n });\n const columns = parsedColumnDefinitions.join(', ');\n\n // Validate table constraints against allowed patterns\n let constraints = '';\n if (tableConstraints && tableConstraints.length > 0) {\n // Allowed patterns: PRIMARY KEY (...), UNIQUE (...), FOREIGN KEY (...), CHECK (...)\n const constraintPattern = /^(PRIMARY\\s+KEY|UNIQUE|FOREIGN\\s+KEY|CHECK)\\s*\\([a-zA-Z0-9_,\\s]+\\)$/i;\n for (const constraint of tableConstraints) {\n if (!constraintPattern.test(constraint.trim())) {\n throw new Error(`Invalid table constraint: ${constraint}`);\n }\n }\n constraints = ', ' + tableConstraints.join(', ');\n }\n\n this.sql = `CREATE TABLE IF NOT EXISTS ${parsedTableName} (${columns}${constraints})`;\n return this;\n }\n\n /**\n * Check if an index exists in the database\n * @param indexName The name of the index to check\n * @param tableName The table the index is on\n * @returns The builder instance\n */\n checkIndexExists(indexName: string, tableName: string): SqlBuilder {\n this.sql = `SELECT name FROM sqlite_master WHERE type='index' AND name=? AND tbl_name=?`;\n this.params.push(indexName, tableName);\n return this;\n }\n\n /**\n * Create an index if it doesn't exist\n * @param indexName The name of the index to create\n * @param tableName The table to create the index on\n * @param columnName The column to index\n * @param indexType Optional index type (e.g., 'UNIQUE')\n * @returns The builder instance\n */\n createIndex(indexName: string, tableName: string, columnName: string, indexType: string = ''): SqlBuilder {\n const parsedIndexName = parseSqlIdentifier(indexName, 'index name');\n const parsedTableName = parseSqlIdentifier(tableName, 'table name');\n const parsedColumnName = parseSqlIdentifier(columnName, 'column name');\n\n // Validate indexType against allowed values\n const allowedIndexTypes = ['', 'UNIQUE'];\n const normalizedIndexType = indexType.toUpperCase().trim();\n if (!allowedIndexTypes.includes(normalizedIndexType)) {\n throw new Error(\n `Invalid index type: ${indexType}. Allowed values: ${allowedIndexTypes.filter(t => t).join(', ')}`,\n );\n }\n\n this.sql = `CREATE ${normalizedIndexType ? normalizedIndexType + ' ' : ''}INDEX IF NOT EXISTS ${parsedIndexName} ON ${parsedTableName}(${parsedColumnName})`;\n return this;\n }\n\n /**\n * Add a LIKE condition to the query\n * @param column The column to check\n * @param value The value to match (will be wrapped with % for LIKE)\n * @param exact If true, will not add % wildcards\n */\n like(column: string, value: string, exact: boolean = false): SqlBuilder {\n const parsedColumnName = parseSqlIdentifier(column, 'column name');\n const likeValue = exact ? value : `%${value}%`;\n if (this.whereAdded) {\n this.sql += ` AND ${parsedColumnName} LIKE ?`;\n } else {\n this.sql += ` WHERE ${parsedColumnName} LIKE ?`;\n this.whereAdded = true;\n }\n this.params.push(likeValue);\n return this;\n }\n\n /**\n * Add a JSON LIKE condition for searching in JSON fields\n * @param column The JSON column to search in\n * @param key The JSON key to match\n * @param value The value to match\n */\n jsonLike(column: string, key: string, value: string): SqlBuilder {\n const parsedColumnName = parseSqlIdentifier(column, 'column name');\n const parsedKey = parseSqlIdentifier(key, 'key name');\n const jsonPattern = `%\"${parsedKey}\":\"${value}\"%`;\n if (this.whereAdded) {\n this.sql += ` AND ${parsedColumnName} LIKE ?`;\n } else {\n this.sql += ` WHERE ${parsedColumnName} LIKE ?`;\n this.whereAdded = true;\n }\n this.params.push(jsonPattern);\n return this;\n }\n\n /**\n * Get the built query\n * @returns Object containing the SQL string and parameters array\n */\n build(): { sql: string; params: SqlParam[] } {\n return {\n sql: this.sql,\n params: this.params,\n };\n }\n\n /**\n * Reset the builder for reuse\n * @returns The reset builder instance\n */\n reset(): SqlBuilder {\n this.sql = '';\n this.params = [];\n this.whereAdded = false;\n return this;\n }\n}\n\n// Factory function for easier creation\nexport function createSqlBuilder(): SqlBuilder {\n return new SqlBuilder();\n}\n\n/** Represents a validated SQL SELECT column identifier (or '*', optionally with 'AS alias'). */\ntype SelectIdentifier = string & { __brand: 'SelectIdentifier' };\n\nconst SQL_IDENTIFIER_PATTERN = /^[a-zA-Z0-9_]+(\\s+AS\\s+[a-zA-Z0-9_]+)?$/;\n\n/**\n * Parses and returns a valid SQL SELECT column identifier.\n * Allows a single identifier (letters, numbers, underscores), or '*', optionally with 'AS alias'.\n *\n * @param column - The column identifier string to parse.\n * @returns The validated column identifier as a branded type.\n * @throws {Error} If invalid.\n *\n * @example\n * const col = parseSelectIdentifier('user_id'); // Ok\n * parseSelectIdentifier('user_id AS uid'); // Ok\n * parseSelectIdentifier('*'); // Ok\n * parseSelectIdentifier('user id'); // Throws error\n */\nexport function parseSelectIdentifier(column: string): SelectIdentifier {\n if (column !== '*' && !SQL_IDENTIFIER_PATTERN.test(column)) {\n throw new Error(\n `Invalid column name: \"${column}\". Must be \"*\" or a valid identifier (letters, numbers, underscores), optionally with \"AS alias\".`,\n );\n }\n return column as SelectIdentifier;\n}\n","import type { SqlStorage } from '@cloudflare/workers-types';\nimport { MastraBase } from '@mastra/core/base';\nimport { MastraError, ErrorDomain, ErrorCategory } from '@mastra/core/error';\nimport { createStorageErrorId, getDefaultValue, getSqlType, TABLE_WORKFLOW_SNAPSHOT } from '@mastra/core/storage';\nimport type { TABLE_NAMES, StorageColumn } from '@mastra/core/storage';\n\nimport { deserializeValue } from '../domains/utils';\nimport { createSqlBuilder } from '../sql-builder';\nimport type { SqlParam, SqlQueryOptions } from '../sql-builder';\n\nexport interface DODBConfig {\n sql: SqlStorage;\n tablePrefix?: string;\n}\n\n/**\n * Configuration for standalone domain usage with Durable Objects.\n */\nexport interface DODomainConfig {\n sql: SqlStorage;\n tablePrefix?: string;\n}\n\nexport class DODB extends MastraBase {\n private sql: SqlStorage;\n private tablePrefix: string;\n\n constructor(config: DODBConfig) {\n super({\n component: 'STORAGE',\n name: 'DO_DB',\n });\n this.sql = config.sql;\n this.tablePrefix = config.tablePrefix || '';\n }\n\n async hasColumn(table: string, column: string): Promise<boolean> {\n // Validate table and column names against SQL injection\n const identifierPattern = /^[A-Za-z_][A-Za-z0-9_]*$/;\n if (!identifierPattern.test(table)) {\n throw new Error(`Invalid table name: ${table}`);\n }\n if (!identifierPattern.test(column)) {\n throw new Error(`Invalid column name: ${column}`);\n }\n if (this.tablePrefix && !identifierPattern.test(this.tablePrefix)) {\n throw new Error(`Invalid table prefix: ${this.tablePrefix}`);\n }\n\n // Handle both prefixed and non-prefixed table names\n const fullTableName = table.startsWith(this.tablePrefix) ? table : `${this.tablePrefix}${table}`;\n const sql = `PRAGMA table_info(${fullTableName});`;\n const result = await this.executeQuery({ sql, params: [] });\n if (!result || !Array.isArray(result)) return false;\n return result.some((col: Record<string, unknown>) => col.name === column || col.name === column.toLowerCase());\n }\n\n getTableName(tableName: TABLE_NAMES): string {\n return `${this.tablePrefix}${tableName}`;\n }\n\n private formatSqlParams(params: SqlParam[]): (string | number | null)[] {\n return params.map(p => (p === undefined || p === null ? null : p) as string | number | null);\n }\n\n /**\n * Execute a SQL query using Durable Objects SqlStorage.\n * SqlStorage.exec() is synchronous but we wrap in Promise for interface compatibility.\n */\n async executeQuery(options: SqlQueryOptions): Promise<Record<string, unknown>[] | Record<string, unknown> | null> {\n const { sql, params = [], first = false } = options;\n\n try {\n const formattedParams = this.formatSqlParams(params);\n // SqlStorage.exec() is synchronous and returns a SqlStorageCursor\n const cursor = this.sql.exec(sql, ...formattedParams);\n\n if (first) {\n const rows = cursor.toArray();\n return rows[0] || null;\n }\n\n return cursor.toArray();\n } catch (error) {\n throw new MastraError(\n {\n id: createStorageErrorId('CLOUDFLARE_DO', 'QUERY', 'FAILED'),\n domain: ErrorDomain.STORAGE,\n category: ErrorCategory.THIRD_PARTY,\n details: { sql },\n },\n error,\n );\n }\n }\n\n private async getTableColumns(tableName: string): Promise<{ name: string; type: string }[]> {\n // Validate table name to prevent SQL injection\n const identifierPattern = /^[A-Za-z_][A-Za-z0-9_]*$/;\n if (!identifierPattern.test(tableName)) {\n this.logger.warn(`Invalid table name in getTableColumns: ${tableName}`);\n return [];\n }\n\n try {\n const sql = `PRAGMA table_info(${tableName})`;\n const result = await this.executeQuery({ sql });\n\n if (!result || !Array.isArray(result)) {\n return [];\n }\n\n return result.map(row => ({\n name: row.name as string,\n type: row.type as string,\n }));\n } catch (error) {\n this.logger.warn(`Failed to get table columns for ${tableName}:`, error);\n return [];\n }\n }\n\n private serializeValue(value: unknown): unknown {\n if (value === null || value === undefined) {\n return null;\n }\n if (value instanceof Date) {\n return value.toISOString();\n }\n if (typeof value === 'object') {\n return JSON.stringify(value);\n }\n return value;\n }\n\n protected getSqlType(type: StorageColumn['type']): string {\n switch (type) {\n case 'bigint':\n return 'INTEGER'; // SQLite uses INTEGER for all integer sizes\n case 'jsonb':\n return 'TEXT'; // Store JSON as TEXT in SQLite\n case 'boolean':\n return 'INTEGER'; // SQLite uses 0/1 for booleans\n default:\n return getSqlType(type);\n }\n }\n\n protected getDefaultValue(type: StorageColumn['type']): string {\n return getDefaultValue(type);\n }\n\n async createTable({\n tableName,\n schema,\n }: {\n tableName: TABLE_NAMES;\n schema: Record<string, StorageColumn>;\n }): Promise<void> {\n try {\n const fullTableName = this.getTableName(tableName);\n\n // Build SQL columns from schema\n const columnDefinitions = Object.entries(schema).map(([colName, colDef]) => {\n const type = this.getSqlType(colDef.type);\n const nullable = colDef.nullable === false ? 'NOT NULL' : '';\n const primaryKey = colDef.primaryKey ? 'PRIMARY KEY' : '';\n return `${colName} ${type} ${nullable} ${primaryKey}`.trim();\n });\n\n // Add table-level constraints if needed\n const tableConstraints: string[] = [];\n if (tableName === TABLE_WORKFLOW_SNAPSHOT) {\n tableConstraints.push('UNIQUE (workflow_name, run_id)');\n }\n\n const query = createSqlBuilder().createTable(fullTableName, columnDefinitions, tableConstraints);\n const { sql, params } = query.build();\n await this.executeQuery({ sql, params });\n this.logger.debug(`Created table ${fullTableName}`);\n } catch (error) {\n throw new MastraError(\n {\n id: createStorageErrorId('CLOUDFLARE_DO', 'CREATE_TABLE', 'FAILED'),\n domain: ErrorDomain.STORAGE,\n category: ErrorCategory.THIRD_PARTY,\n details: { tableName },\n },\n error,\n );\n }\n }\n\n async clearTable({ tableName }: { tableName: TABLE_NAMES }): Promise<void> {\n try {\n const fullTableName = this.getTableName(tableName);\n const query = createSqlBuilder().delete(fullTableName);\n const { sql, params } = query.build();\n await this.executeQuery({ sql, params });\n this.logger.debug(`Cleared table ${fullTableName}`);\n } catch (error) {\n throw new MastraError(\n {\n id: createStorageErrorId('CLOUDFLARE_DO', 'CLEAR_TABLE', 'FAILED'),\n domain: ErrorDomain.STORAGE,\n category: ErrorCategory.THIRD_PARTY,\n details: { tableName },\n },\n error,\n );\n }\n }\n\n async dropTable({ tableName }: { tableName: TABLE_NAMES }): Promise<void> {\n try {\n const fullTableName = this.getTableName(tableName);\n const sql = `DROP TABLE IF EXISTS ${fullTableName}`;\n await this.executeQuery({ sql });\n this.logger.debug(`Dropped table ${fullTableName}`);\n } catch (error) {\n throw new MastraError(\n {\n id: createStorageErrorId('CLOUDFLARE_DO', 'DROP_TABLE', 'FAILED'),\n domain: ErrorDomain.STORAGE,\n category: ErrorCategory.THIRD_PARTY,\n details: { tableName },\n },\n error,\n );\n }\n }\n\n async alterTable(args: {\n tableName: TABLE_NAMES;\n schema: Record<string, StorageColumn>;\n ifNotExists: string[];\n }): Promise<void> {\n // Validate identifier pattern\n const identifierPattern = /^[A-Za-z_][A-Za-z0-9_]*$/;\n\n try {\n const fullTableName = this.getTableName(args.tableName);\n\n // Validate full table name (may include prefix)\n if (!identifierPattern.test(fullTableName)) {\n throw new Error(`Invalid table name: ${fullTableName}`);\n }\n\n const existingColumns = await this.getTableColumns(fullTableName);\n const existingColumnNames = new Set(existingColumns.map(col => col.name));\n\n for (const [columnName, column] of Object.entries(args.schema)) {\n // Validate column name before using in SQL\n if (!identifierPattern.test(columnName)) {\n throw new Error(`Invalid column name: ${columnName}`);\n }\n\n if (!existingColumnNames.has(columnName) && args.ifNotExists.includes(columnName)) {\n const sqlType = this.getSqlType(column.type);\n const defaultValue = this.getDefaultValue(column.type);\n const sql = `ALTER TABLE ${fullTableName} ADD COLUMN ${columnName} ${sqlType} ${defaultValue}`;\n await this.executeQuery({ sql });\n this.logger.debug(`Added column ${columnName} to table ${fullTableName}`);\n }\n }\n } catch (error) {\n throw new MastraError(\n {\n id: createStorageErrorId('CLOUDFLARE_DO', 'ALTER_TABLE', 'FAILED'),\n domain: ErrorDomain.STORAGE,\n category: ErrorCategory.THIRD_PARTY,\n details: { tableName: args.tableName },\n },\n error,\n );\n }\n }\n\n async insert({ tableName, record }: { tableName: TABLE_NAMES; record: Record<string, unknown> }): Promise<void> {\n try {\n const fullTableName = this.getTableName(tableName);\n const processedRecord = await this.processRecord(record);\n const columns = Object.keys(processedRecord);\n const values = Object.values(processedRecord);\n\n const query = createSqlBuilder().insert(fullTableName, columns, values as SqlParam[]);\n const { sql, params } = query.build();\n\n await this.executeQuery({ sql, params });\n } catch (error) {\n throw new MastraError(\n {\n id: createStorageErrorId('CLOUDFLARE_DO', 'INSERT', 'FAILED'),\n domain: ErrorDomain.STORAGE,\n category: ErrorCategory.THIRD_PARTY,\n details: { tableName },\n },\n error,\n );\n }\n }\n\n async batchInsert({\n tableName,\n records,\n }: {\n tableName: TABLE_NAMES;\n records: Record<string, unknown>[];\n }): Promise<void> {\n try {\n if (records.length === 0) return;\n\n const fullTableName = this.getTableName(tableName);\n const processedRecords = await Promise.all(records.map(record => this.processRecord(record)));\n const columns = Object.keys(processedRecords[0] || {});\n\n // For batch insert, we need to create multiple INSERT statements\n for (const record of processedRecords) {\n const values = Object.values(record);\n const query = createSqlBuilder().insert(fullTableName, columns, values as SqlParam[]);\n const { sql, params } = query.build();\n await this.executeQuery({ sql, params });\n }\n } catch (error) {\n throw new MastraError(\n {\n id: createStorageErrorId('CLOUDFLARE_DO', 'BATCH_INSERT', 'FAILED'),\n domain: ErrorDomain.STORAGE,\n category: ErrorCategory.THIRD_PARTY,\n details: { tableName },\n },\n error,\n );\n }\n }\n\n async load<R>({\n tableName,\n keys,\n orderBy,\n }: {\n tableName: TABLE_NAMES;\n keys: Record<string, string>;\n orderBy?: { column: string; direction: 'ASC' | 'DESC' };\n }): Promise<R | null> {\n try {\n const fullTableName = this.getTableName(tableName);\n const query = createSqlBuilder().select('*').from(fullTableName);\n\n // Add WHERE conditions for each key\n let firstKey = true;\n for (const [key, value] of Object.entries(keys)) {\n if (firstKey) {\n query.where(`${key} = ?`, value);\n firstKey = false;\n } else {\n query.andWhere(`${key} = ?`, value);\n }\n }\n\n // Only apply orderBy if explicitly provided\n if (orderBy) {\n query.orderBy(orderBy.column, orderBy.direction);\n }\n\n query.limit(1);\n const { sql, params } = query.build();\n\n const result = await this.executeQuery({ sql, params, first: true });\n\n if (!result) {\n return null;\n }\n\n // Deserialize JSON fields\n const deserializedResult: Record<string, unknown> = {};\n for (const [key, value] of Object.entries(result)) {\n deserializedResult[key] = deserializeValue(value);\n }\n\n return deserializedResult as R;\n } catch (error) {\n throw new MastraError(\n {\n id: createStorageErrorId('CLOUDFLARE_DO', 'LOAD', 'FAILED'),\n domain: ErrorDomain.STORAGE,\n category: ErrorCategory.THIRD_PARTY,\n details: { tableName },\n },\n error,\n );\n }\n }\n\n async processRecord(record: Record<string, unknown>): Promise<Record<string, unknown>> {\n const processed: Record<string, unknown> = {};\n for (const [key, value] of Object.entries(record)) {\n processed[key] = this.serializeValue(value);\n }\n return processed;\n }\n\n /**\n * Upsert multiple records in a batch operation\n * @param tableName The table to insert into\n * @param records The records to insert\n * @param conflictKeys The columns to use for conflict detection (defaults to ['id'])\n */\n async batchUpsert({\n tableName,\n records,\n conflictKeys = ['id'],\n }: {\n tableName: TABLE_NAMES;\n records: Record<string, unknown>[];\n conflictKeys?: string[];\n }): Promise<void> {\n if (records.length === 0) return;\n\n const fullTableName = this.getTableName(tableName);\n\n try {\n // Process records in batches for better performance\n const batchSize = 50; // Adjust based on performance testing\n\n for (let i = 0; i < records.length; i += batchSize) {\n const batch = records.slice(i, i + batchSize);\n\n const recordsToInsert = batch;\n\n // For bulk insert, we need to determine the columns from the first record\n if (recordsToInsert.length > 0) {\n const firstRecord = recordsToInsert[0];\n // Ensure firstRecord is not undefined before calling Object.keys\n const columns = Object.keys(firstRecord || {});\n\n // Create a bulk insert statement\n for (const record of recordsToInsert) {\n // Use type-safe approach to extract values\n const values = columns.map(col => {\n if (!record) return null;\n // Safely access the record properties\n const value = typeof col === 'string' ? record[col as keyof typeof record] : null;\n return this.serializeValue(value);\n });\n\n const recordToUpsert = columns.reduce(\n (acc, col) => {\n // Don't update conflict keys or createdAt on conflict\n if (col !== 'createdAt' && !conflictKeys.includes(col)) {\n acc[col] = `excluded.${col}`;\n }\n return acc;\n },\n {} as Record<string, string>,\n );\n\n const query = createSqlBuilder().insert(\n fullTableName,\n columns,\n values as SqlParam[],\n conflictKeys,\n recordToUpsert,\n );\n\n const { sql, params } = query.build();\n await this.executeQuery({ sql, params });\n }\n }\n\n this.logger.debug(\n `Processed batch ${Math.floor(i / batchSize) + 1} of ${Math.ceil(records.length / batchSize)}`,\n );\n }\n\n this.logger.debug(`Successfully batch upserted ${records.length} records into ${tableName}`);\n } catch (error) {\n throw new MastraError(\n {\n id: createStorageErrorId('CLOUDFLARE_DO', 'BATCH_UPSERT', 'FAILED'),\n domain: ErrorDomain.STORAGE,\n category: ErrorCategory.THIRD_PARTY,\n text: `Failed to batch upsert into ${tableName}: ${error instanceof Error ? error.message : String(error)}`,\n details: { tableName },\n },\n error,\n );\n }\n }\n}\n","import { MessageList } from '@mastra/core/agent';\nimport type { MastraMessageContentV2 } from '@mastra/core/agent';\nimport { ErrorCategory, ErrorDomain, MastraError } from '@mastra/core/error';\nimport type { MastraMessageV1, MastraDBMessage, StorageThreadType } from '@mastra/core/memory';\nimport {\n createStorageErrorId,\n ensureDate,\n MemoryStorage,\n serializeDate,\n TABLE_MESSAGES,\n TABLE_THREADS,\n TABLE_RESOURCES,\n TABLE_SCHEMAS,\n normalizePerPage,\n calculatePagination,\n} from '@mastra/core/storage';\nimport type {\n StorageResourceType,\n StorageListMessagesInput,\n StorageListMessagesOutput,\n StorageListThreadsInput,\n StorageListThreadsOutput,\n} from '@mastra/core/storage';\n\nimport { DODB } from '../../db';\nimport type { DODomainConfig } from '../../db';\nimport { createSqlBuilder } from '../../sql-builder';\nimport { deserializeValue, isArrayOfRecords } from '../utils';\n\nexport class MemoryStorageDO extends MemoryStorage {\n #db: DODB;\n\n constructor(config: DODomainConfig) {\n super();\n this.#db = new DODB(config);\n }\n\n async init(): Promise<void> {\n await this.#db.createTable({ tableName: TABLE_THREADS, schema: TABLE_SCHEMAS[TABLE_THREADS] });\n await this.#db.createTable({ tableName: TABLE_MESSAGES, schema: TABLE_SCHEMAS[TABLE_MESSAGES] });\n await this.#db.createTable({ tableName: TABLE_RESOURCES, schema: TABLE_SCHEMAS[TABLE_RESOURCES] });\n // Add resourceId column for backwards compatibility\n await this.#db.alterTable({\n tableName: TABLE_MESSAGES,\n schema: TABLE_SCHEMAS[TABLE_MESSAGES],\n ifNotExists: ['resourceId'],\n });\n }\n\n async dangerouslyClearAll(): Promise<void> {\n await this.#db.clearTable({ tableName: TABLE_MESSAGES });\n await this.#db.clearTable({ tableName: TABLE_THREADS });\n await this.#db.clearTable({ tableName: TABLE_RESOURCES });\n }\n\n async getResourceById({ resourceId }: { resourceId: string }): Promise<StorageResourceType | null> {\n const resource = await this.#db.load<StorageResourceType>({\n tableName: TABLE_RESOURCES,\n keys: { id: resourceId },\n });\n\n if (!resource) return null;\n\n try {\n return {\n ...resource,\n createdAt: ensureDate(resource.createdAt) as Date,\n updatedAt: ensureDate(resource.updatedAt) as Date,\n metadata:\n typeof resource.metadata === 'string'\n ? (JSON.parse(resource.metadata || '{}') as Record<string, unknown>)\n : resource.metadata,\n };\n } catch (error) {\n const mastraError = new MastraError(\n {\n id: createStorageErrorId('CLOUDFLARE_DO', 'GET_RESOURCE_BY_ID', 'FAILED'),\n domain: ErrorDomain.STORAGE,\n category: ErrorCategory.THIRD_PARTY,\n text: `Error processing resource ${resourceId}: ${error instanceof Error ? error.message : String(error)}`,\n details: { resourceId },\n },\n error,\n );\n this.logger?.error(mastraError.toString());\n this.logger?.trackException(mastraError);\n return null;\n }\n }\n\n async saveResource({ resource }: { resource: StorageResourceType }): Promise<StorageResourceType> {\n const fullTableName = this.#db.getTableName(TABLE_RESOURCES);\n\n // Prepare the record for SQL insertion\n const resourceToSave = {\n id: resource.id,\n workingMemory: resource.workingMemory,\n metadata: resource.metadata ? JSON.stringify(resource.metadata) : null,\n createdAt: resource.createdAt,\n updatedAt: resource.updatedAt,\n };\n\n // Process record for SQL insertion\n const processedRecord = await this.#db.processRecord(resourceToSave);\n\n const columns = Object.keys(processedRecord);\n const values = Object.values(processedRecord);\n\n // Specify which columns to update on conflict (all except id)\n const updateMap: Record<string, string> = {\n workingMemory: 'excluded.workingMemory',\n metadata: 'excluded.metadata',\n createdAt: 'excluded.createdAt',\n updatedAt: 'excluded.updatedAt',\n };\n\n // Use the new insert method with ON CONFLICT\n const query = createSqlBuilder().insert(\n fullTableName,\n columns,\n values as (string | number | boolean | null | undefined)[],\n ['id'],\n updateMap,\n );\n\n const { sql, params } = query.build();\n\n try {\n await this.#db.executeQuery({ sql, params });\n return resource;\n } catch (error) {\n throw new MastraError(\n {\n id: createStorageErrorId('CLOUDFLARE_DO', 'SAVE_RESOURCE', 'FAILED'),\n domain: ErrorDomain.STORAGE,\n category: ErrorCategory.THIRD_PARTY,\n text: `Failed to save resource to ${fullTableName}: ${error instanceof Error ? error.message : String(error)}`,\n details: { resourceId: resource.id },\n },\n error,\n );\n }\n }\n\n async updateResource({\n resourceId,\n workingMemory,\n metadata,\n }: {\n resourceId: string;\n workingMemory?: string;\n metadata?: Record<string, unknown>;\n }): Promise<StorageResourceType> {\n const existingResource = await this.getResourceById({ resourceId });\n\n if (!existingResource) {\n // Create new resource if it doesn't exist\n const newResource: StorageResourceType = {\n id: resourceId,\n workingMemory,\n metadata: metadata || {},\n createdAt: new Date(),\n updatedAt: new Date(),\n };\n return this.saveResource({ resource: newResource });\n }\n\n const updatedAt = new Date();\n const updatedResource = {\n ...existingResource,\n workingMemory: workingMemory !== undefined ? workingMemory : existingResource.workingMemory,\n metadata: {\n ...existingResource.metadata,\n ...metadata,\n },\n updatedAt,\n };\n\n const fullTableName = this.#db.getTableName(TABLE_RESOURCES);\n\n const columns = ['workingMemory', 'metadata', 'updatedAt'];\n const values = [updatedResource.workingMemory, JSON.stringify(updatedResource.metadata), updatedAt.toISOString()];\n\n const query = createSqlBuilder().update(fullTableName, columns, values).where('id = ?', resourceId);\n\n const { sql, params } = query.build();\n\n try {\n await this.#db.executeQuery({ sql, params });\n return updatedResource;\n } catch (error) {\n throw new MastraError(\n {\n id: createStorageErrorId('CLOUDFLARE_DO', 'UPDATE_RESOURCE', 'FAILED'),\n domain: ErrorDomain.STORAGE,\n category: ErrorCategory.THIRD_PARTY,\n text: `Failed to update resource ${resourceId}: ${error instanceof Error ? error.message : String(error)}`,\n details: { resourceId },\n },\n error,\n );\n }\n }\n\n async getThreadById({ threadId }: { threadId: string }): Promise<StorageThreadType | null> {\n const thread = await this.#db.load<StorageThreadType>({\n tableName: TABLE_THREADS,\n keys: { id: threadId },\n });\n\n if (!thread) return null;\n\n try {\n return {\n ...thread,\n createdAt: ensureDate(thread.createdAt) as Date,\n updatedAt: ensureDate(thread.updatedAt) as Date,\n metadata:\n typeof thread.metadata === 'string'\n ? (JSON.parse(thread.metadata || '{}') as Record<string, unknown>)\n : thread.metadata || {},\n };\n } catch (error) {\n const mastraError = new MastraError(\n {\n id: createStorageErrorId('CLOUDFLARE_DO', 'GET_THREAD_BY_ID', 'FAILED'),\n domain: ErrorDomain.STORAGE,\n category: ErrorCategory.THIRD_PARTY,\n text: `Error processing thread ${threadId}: ${error instanceof Error ? error.message : String(error)}`,\n details: { threadId },\n },\n error,\n );\n this.logger?.error(mastraError.toString());\n this.logger?.trackException(mastraError);\n return null;\n }\n }\n\n public async listThreads(args: StorageListThreadsInput): Promise<StorageListThreadsOutput> {\n const { page = 0, perPage: perPageInput, orderBy, filter } = args;\n\n try {\n this.validatePaginationInput(page, perPageInput ?? 100);\n } catch (error) {\n throw new MastraError(\n {\n id: createStorageErrorId('CLOUDFLARE_DO', 'LIST_THREADS', 'INVALID_PAGE'),\n domain: ErrorDomain.STORAGE,\n category: ErrorCategory.USER,\n details: { page, ...(perPageInput !== undefined && { perPage: perPageInput }) },\n },\n error instanceof Error ? error : new Error('Invalid pagination parameters'),\n );\n }\n\n const perPage = normalizePerPage(perPageInput, 100);\n\n try {\n this.validateMetadataKeys(filter?.metadata);\n } catch (error) {\n throw new MastraError(\n {\n id: createStorageErrorId('CLOUDFLARE_DO', 'LIST_THREADS', 'INVALID_METADATA_KEY'),\n domain: ErrorDomain.STORAGE,\n category: ErrorCategory.USER,\n details: { metadataKeys: filter?.metadata ? Object.keys(filter.metadata).join(', ') : '' },\n },\n error instanceof Error ? error : new Error('Invalid metadata key'),\n );\n }\n\n const { offset, perPage: perPageForResponse } = calculatePagination(page, perPageInput, perPage);\n const { field, direction } = this.parseOrderBy(orderBy);\n const fullTableName = this.#db.getTableName(TABLE_THREADS);\n\n const mapRowToStorageThreadType = (row: any): StorageThreadType => ({\n ...row,\n createdAt: ensureDate(row.createdAt) as Date,\n updatedAt: ensureDate(row.updatedAt) as Date,\n metadata:\n typeof row.metadata === 'string'\n ? (JSON.parse(row.metadata || '{}') as Record<string, unknown>)\n : row.metadata || {},\n });\n\n try {\n let countQuery = createSqlBuilder().count().from(fullTableName);\n let selectQuery = createSqlBuilder().select('*').from(fullTableName);\n\n if (filter?.resourceId) {\n countQuery = countQuery.whereAnd('resourceId = ?', filter.resourceId);\n selectQuery = selectQuery.whereAnd('resourceId = ?', filter.resourceId);\n }\n\n if (filter?.metadata && Object.keys(filter.metadata).length > 0) {\n for (const [key, value] of Object.entries(filter.metadata)) {\n if (value !== null && typeof value === 'object') {\n throw new MastraError(\n {\n id: createStorageErrorId('CLOUDFLARE_DO', 'LIST_THREADS', 'INVALID_METADATA_VALUE'),\n domain: ErrorDomain.STORAGE,\n category: ErrorCategory.USER,\n text: `Metadata filter value for key \"${key}\" must be a scalar type (string, number, boolean, or null), got ${Array.isArray(value) ? 'array' : 'object'}`,\n details: { key, valueType: Array.isArray(value) ? 'array' : 'object' },\n },\n new Error('Invalid metadata filter value type'),\n );\n }\n\n if (value === null) {\n const condition = `json_extract(metadata, '$.${key}') IS NULL`;\n countQuery = countQuery.whereAnd(condition);\n selectQuery = selectQuery.whereAnd(condition);\n } else {\n const condition = `json_extract(metadata, '$.${key}') = ?`;\n const filterValue = value as string | number | boolean;\n countQuery = countQuery.whereAnd(condition, filterValue);\n selectQuery = selectQuery.whereAnd(condition, filterValue);\n }\n }\n }\n\n const countResult = (await this.#db.executeQuery(countQuery.build())) as {\n count: number;\n }[];\n const total = Number(countResult?.[0]?.count ?? 0);\n\n if (total === 0) {\n return {\n threads: [],\n total: 0,\n page,\n perPage: perPageForResponse,\n hasMore: false,\n };\n }\n\n const limitValue = perPageInput === false ? total : perPage;\n selectQuery = selectQuery.orderBy(field, direction).limit(limitValue).offset(offset);\n\n const results = (await this.#db.executeQuery(selectQuery.build())) as Record<string, unknown>[];\n const threads = results.map(mapRowToStorageThreadType);\n\n return {\n threads,\n total,\n page,\n perPage: perPageForResponse,\n hasMore: perPageInput === false ? false : offset + perPage < total,\n };\n } catch (error) {\n if (error instanceof MastraError && error.category === ErrorCategory.USER) {\n throw error;\n }\n const mastraError = new MastraError(\n {\n id: createStorageErrorId('CLOUDFLARE_DO', 'LIST_THREADS', 'FAILED'),\n domain: ErrorDomain.STORAGE,\n category: ErrorCategory.THIRD_PARTY,\n text: `Error listing threads: ${error instanceof Error ? error.message : String(error)}`,\n details: {\n ...(filter?.resourceId && { resourceId: filter.resourceId }),\n hasMetadataFilter: !!filter?.metadata,\n },\n },\n error,\n );\n this.logger?.error(mastraError.toString());\n this.logger?.trackException(mastraError);\n return {\n threads: [],\n total: 0,\n page,\n perPage: perPageForResponse,\n hasMore: false,\n };\n }\n }\n\n async saveThread({ thread }: { thread: StorageThreadType }): Promise<StorageThreadType> {\n const fullTableName = this.#db.getTableName(TABLE_THREADS);\n\n // Prepare the record for SQL insertion\n const threadToSave = {\n id: thread.id,\n resourceId: thread.resourceId,\n title: thread.title,\n metadata: thread.metadata ? JSON.stringify(thread.metadata) : null,\n createdAt: thread.createdAt.toISOString(),\n updatedAt: thread.updatedAt.toISOString(),\n };\n\n // Process record for SQL insertion\n const processedRecord = await this.#db.processRecord(threadToSave);\n\n const columns = Object.keys(processedRecord);\n const values = Object.values(processedRecord);\n\n // Specify which columns to update on conflict (all except id)\n const updateMap: Record<string, string> = {\n resourceId: 'excluded.resourceId',\n title: 'excluded.title',\n metadata: 'excluded.metadata',\n createdAt: 'excluded.createdAt',\n updatedAt: 'excluded.updatedAt',\n };\n\n // Use the new insert method with ON CONFLICT\n const query = createSqlBuilder().insert(\n fullTableName,\n columns,\n values as (string | number | boolean | null | undefined)[],\n ['id'],\n updateMap,\n );\n\n const { sql, params } = query.build();\n\n try {\n await this.#db.executeQuery({ sql, params });\n return thread;\n } catch (error) {\n throw new MastraError(\n {\n id: createStorageErrorId('CLOUDFLARE_DO', 'SAVE_THREAD', 'FAILED'),\n domain: ErrorDomain.STORAGE,\n category: ErrorCategory.THIRD_PARTY,\n text: `Failed to save thread to ${fullTableName}: ${error instanceof Error ? error.message : String(error)}`,\n details: { threadId: thread.id },\n },\n error,\n );\n }\n }\n\n async updateThread({\n id,\n title,\n metadata,\n }: {\n id: string;\n title: string;\n metadata: Record<string, unknown>;\n }): Promise<StorageThreadType> {\n const thread = await this.getThreadById({ threadId: id });\n try {\n if (!thread) {\n throw new Error(`Thread ${id} not found`);\n }\n const fullTableName = this.#db.getTableName(TABLE_THREADS);\n\n const mergedMetadata = {\n ...thread.metadata,\n ...metadata,\n };\n\n const updatedAt = new Date();\n const columns = ['title', 'metadata', 'updatedAt'];\n const values = [title, JSON.stringify(mergedMetadata), updatedAt.toISOString()];\n\n const query = createSqlBuilder().update(fullTableName, columns, values).where('id = ?', id);\n\n const { sql, params } = query.build();\n\n await this.#db.executeQuery({ sql, params });\n\n return {\n ...thread,\n title,\n metadata: mergedMetadata,\n updatedAt,\n };\n } catch (error) {\n throw new MastraError(\n {\n id: createStorageErrorId('CLOUDFLARE_DO', 'UPDATE_THREAD', 'FAILED'),\n domain: ErrorDomain.STORAGE,\n category: ErrorCategory.THIRD_PARTY,\n text: `Failed to update thread ${id}: ${error instanceof Error ? error.message : String(error)}`,\n details: { threadId: id },\n },\n error,\n );\n }\n }\n\n async deleteThread({ threadId }: { threadId: string }): Promise<void> {\n const fullTableName = this.#db.getTableName(TABLE_THREADS);\n\n try {\n // Delete associated messages first to avoid orphaned data\n const messagesTableName = this.#db.getTableName(TABLE_MESSAGES);\n const deleteMessagesQuery = createSqlBuilder().delete(messagesTableName).where('thread_id = ?', threadId);\n\n const { sql: messagesSql, params: messagesParams } = deleteMessagesQuery.build();\n await this.#db.executeQuery({ sql: messagesSql, params: messagesParams });\n\n // Then delete the thread\n const deleteThreadQuery = createSqlBuilder().delete(fullTableName).where('id = ?', threadId);\n\n const { sql: threadSql, params: threadParams } = deleteThreadQuery.build();\n await this.#db.executeQuery({ sql: threadSql, params: threadParams });\n } catch (error) {\n throw new MastraError(\n {\n id: createStorageErrorId('CLOUDFLARE_DO', 'DELETE_THREAD', 'FAILED'),\n domain: ErrorDomain.STORAGE,\n category: ErrorCategory.THIRD_PARTY,\n text: `Failed to delete thread ${threadId}: ${error instanceof Error ? error.message : String(error)}`,\n details: { threadId },\n },\n error,\n );\n }\n }\n\n async saveMessages(args: { messages: MastraDBMessage[] }): Promise<{ messages: MastraDBMessage[] }> {\n const { messages } = args;\n if (messages.length === 0) return { messages: [] };\n\n try {\n const now = new Date();\n\n // Validate all messages before insert\n for (const [i, message] of messages.entries()) {\n if (!message.id) throw new Error(`Message at index ${i} missing id`);\n if (!message.threadId) {\n throw new Error(`Message at index ${i} missing threadId`);\n }\n if (!message.content) {\n throw new Error(`Message at index ${i} missing content`);\n }\n if (!message.role) {\n throw new Error(`Message at index ${i} missing role`);\n }\n if (!message.resourceId) {\n throw new Error(`Message at index ${i} missing resourceId`);\n }\n }\n\n // Batch validate thread existence to avoid N+1 queries\n const uniqueThreadIds = [...new Set(messages.map(m => m.threadId!))];\n const threads = await Promise.all(uniqueThreadIds.map(id => this.getThreadById({ threadId: id })));\n const missingThreadId = uniqueThreadIds.find((id, i) => !threads[i]);\n if (missingThreadId) {\n throw new Error(`Thread ${missingThreadId} not found`);\n }\n\n // Prepare all messages for insertion (set timestamps, thread_id, etc.)\n const messagesToInsert = messages.map(message => {\n const createdAt = message.createdAt ? new Date(message.createdAt) : now;\n return {\n id: message.id,\n thread_id: message.threadId!,\n content: typeof message.content === 'string' ? message.content : JSON.stringify(message.content),\n createdAt: createdAt.toISOString(),\n role: message.role,\n type: message.type || 'v2',\n resourceId: message.resourceId,\n };\n });\n\n // Insert messages and update all affected threads' updatedAt in parallel\n await Promise.all([\n this.#db.batchUpsert({\n tableName: TABLE_MESSAGES,\n records: messagesToInsert,\n }),\n // Update updatedAt timestamp for all affected threads\n ...uniqueThreadIds.map(tid =>\n this.#db.executeQuery({\n sql: `UPDATE ${this.#db.getTableName(TABLE_THREADS)} SET updatedAt = ? WHERE id = ?`,\n params: [now.toISOString(), tid],\n }),\n ),\n ]);\n\n this.logger.debug(`Saved ${messages.length} messages`);\n const list = new MessageList().add(messages, 'memory');\n return { messages: list.get.all.db() };\n } catch (error) {\n throw new MastraError(\n {\n id: createStorageErrorId('CLOUDFLARE_DO', 'SAVE_MESSAGES', 'FAILED'),\n domain: ErrorDomain.STORAGE,\n category: ErrorCategory.THIRD_PARTY,\n text: `Failed to save messages: ${error instanceof Error ? error.message : String(error)}`,\n },\n error,\n );\n }\n }\n\n private async _getIncludedMessages(include: StorageListMessagesInput['include']) {\n if (!include || include.length === 0) return null;\n\n const unionQueries: string[] = [];\n const params: unknown[] = [];\n let paramIdx = 1;\n const tableName = this.#db.getTableName(TABLE_MESSAGES);\n\n for (const inc of include) {\n const { id, withPreviousMessages = 0, withNextMessages = 0 } = inc;\n // Query by message ID directly - get the threadId from the message itself via subquery\n\n unionQueries.push(`\n SELECT * FROM (\n WITH target_thread AS (\n SELECT thread_id FROM ${tableName} WHERE id = ?\n ),\n ordered_messages AS (\n SELECT\n *,\n ROW_NUMBER() OVER (ORDER BY createdAt ASC) AS row_num\n FROM ${tableName}\n WHERE thread_id = (SELECT thread_id FROM target_thread)\n )\n SELECT\n m.id,\n m.content,\n m.role,\n m.type,\n m.createdAt,\n m.thread_id AS threadId,\n m.resourceId\n FROM ordered_messages m\n WHERE m.id = ?\n OR EXISTS (\n SELECT 1 FROM ordered_messages target\n WHERE target.id = ?\n AND (\n (m.row_num <= target.row_num + ? AND m.row_num > target.row_num)\n OR\n (m.row_num >= target.row_num - ? AND m.row_num < target.row_num)\n )\n )\n ) AS query_${paramIdx}\n `);\n\n params.push(id, id, id, withNextMessages, withPreviousMessages);\n paramIdx++;\n }\n\n const finalQuery = unionQueries.join(' UNION ALL ') + ' ORDER BY createdAt ASC';\n const messages = await this.#db.executeQuery({\n sql: finalQuery,\n params: params as (string | number | boolean | null | undefined)[],\n });\n\n if (!Array.isArray(messages)) {\n return [];\n }\n\n // Parse message content\n const processedMessages = messages.map((message: Record<string, unknown>) => {\n const processedMsg: Record<string, unknown> = {};\n\n for (const [key, value] of Object.entries(message)) {\n if (key === `type` && value === `v2`) continue;\n processedMsg[key] = deserializeValue(value);\n }\n\n return processedMsg;\n });\n\n return processedMessages;\n }\n\n public async listMessagesById({ messageIds }: { messageIds: string[] }): Promise<{ messages: MastraDBMessage[] }> {\n if (messageIds.length === 0) return { messages: [] };\n const fullTableName = this.#db.getTableName(TABLE_MESSAGES);\n const messages: unknown[] = [];\n\n try {\n const query = createSqlBuilder()\n .select(['id', 'content', 'role', 'type', 'createdAt', 'thread_id AS threadId', 'resourceId'])\n .from(fullTableName)\n .where(`id in (${messageIds.map(() => '?').join(',')})`, ...messageIds);\n\n query.orderBy('createdAt', 'DESC');\n\n const { sql, params } = query.build();\n\n const result = await this.#db.executeQuery({ sql, params });\n\n if (Array.isArray(result)) messages.push(...result);\n\n // Parse message content\n const processedMessages = messages.map(message => {\n const processedMsg: Record<string, unknown> = {};\n\n for (const [key, value] of Object.entries(message as Record<string, unknown>)) {\n if (key === `type` && value === `v2`) continue;\n processedMsg[key] = deserializeValue(value);\n }\n\n return processedMsg;\n });\n this.logger.debug(`Retrieved ${messages.length} messages`);\n const list = new MessageList().add(processedMessages as MastraMessageV1[] | MastraDBMessage[], 'memory');\n return { messages: list.get.all.db() };\n } catch (error) {\n const mastraError = new MastraError(\n {\n id: createStorageErrorId('CLOUDFLARE_DO', 'LIST_MESSAGES_BY_ID', 'FAILED'),\n domain: ErrorDomain.STORAGE,\n category: ErrorCategory.THIRD_PARTY,\n text: `Failed to retrieve messages by ID: ${error instanceof Error ? error.message : String(error)}`,\n details: { messageIds: JSON.stringify(messageIds) },\n },\n error,\n );\n this.logger?.error?.(mastraError.toString());\n this.logger?.trackException?.(mastraError);\n throw mastraError;\n }\n }\n\n public async listMessages(args: StorageListMessagesInput): Promise<StorageListMessagesOutput> {\n const { threadId, resourceId, include, filter, perPage: perPageInput, page = 0, orderBy } = args;\n\n // Normalize threadId to array\n const threadIds = Array.isArray(threadId) ? threadId : [threadId];\n\n if (threadIds.length === 0 || threadIds.some(id => !id.trim())) {\n throw new MastraError(\n {\n id: createStorageErrorId('CLOUDFLARE_DO', 'LIST_MESSAGES', 'INVALID_THREAD_ID'),\n domain: ErrorDomain.STORAGE,\n category: ErrorCategory.THIRD_PARTY,\n details: { threadId: Array.isArray(threadId) ? threadId.join(',') : threadId },\n },\n new Error('threadId must be a non-empty string or array of non-empty strings'),\n );\n }\n\n if (page < 0) {\n throw new MastraError(\n {\n id: createStorageErrorId('CLOUDFLARE_DO', 'LIST_MESSAGES', 'INVALID_PAGE'),\n domain: ErrorDomain.STORAGE,\n category: ErrorCategory.USER,\n details: { page },\n },\n new Error('page must be >= 0'),\n );\n }\n\n const perPage = normalizePerPage(perPageInput, 40);\n const { offset, perPage: perPageForResponse } = calculatePagination(page, perPageInput, perPage);\n\n try {\n const fullTableName = this.#db.getTableName(TABLE_MESSAGES);\n\n // Step 1: Get paginated messages from the thread(s) first (without excluding included ones)\n const placeholders = threadIds.map(() => '?').join(', ');\n let query = `\n SELECT id, content, role, type, createdAt, thread_id AS threadId, resourceId\n FROM ${fullTableName}\n WHERE thread_id IN (${placeholders})\n `;\n const queryParams: unknown[] = [...threadIds];\n\n if (resourceId) {\n query += ` AND resourceId = ?`;\n queryParams.push(resourceId);\n }\n\n const dateRange = filter?.dateRange;\n if (dateRange?.start) {\n const startDate =\n dateRange.start instanceof Date ? serializeDate(dateRange.start) : serializeDate(new Date(dateRange.start));\n const startOp = dateRange.startExclusive ? '>' : '>=';\n query += ` AND createdAt ${startOp} ?`;\n queryParams.push(startDate);\n }\n\n if (dateRange?.end) {\n const endDate =\n dateRange.end instanceof Date ? serializeDate(dateRange.end) : serializeDate(new Date(dateRange.end));\n const endOp = dateRange.endExclusive ? '<' : '<=';\n query += ` AND createdAt ${endOp} ?`;\n queryParams.push(endDate);\n }\n\n // Build ORDER BY clause\n const { field, direction } = this.parseOrderBy(orderBy, 'ASC');\n query += ` ORDER BY \"${field}\" ${direction}`;\n\n // Apply pagination\n if (perPage !== Number.MAX_SAFE_INTEGER) {\n query += ` LIMIT ? OFFSET ?`;\n queryParams.push(perPage, offset);\n }\n\n const results = await this.#db.executeQuery({\n sql: query,\n params: queryParams as (string | number | boolean | null | undefined)[],\n });\n\n // Parse message content\n const paginatedMessages = (isArrayOfRecords(results) ? results : []).map((message: Record<string, unknown>) => {\n const processedMsg: Record<string, unknown> = {};\n for (const [key, value] of Object.entries(message)) {\n if (key === `type` && value === `v2`) continue;\n processedMsg[key] = deserializeValue(value);\n }\n return processedMsg;\n });\n\n const paginatedCount = paginatedMessages.length;\n\n // Get total count\n let countQuery = `SELECT count() as count FROM ${fullTableName} WHERE thread_id = ?`;\n const countParams: unknown[] = [threadId];\n\n if (resourceId) {\n countQuery += ` AND resourceId = ?`;\n countParams.push(resourceId);\n }\n\n if (dateRange?.start) {\n const startDate =\n dateRange.start instanceof Date ? serializeDate(dateRange.start) : serializeDate(new Date(dateRange.start));\n const startOp = dateRange.startExclusive ? '>' : '>=';\n countQuery += ` AND createdAt ${startOp} ?`;\n countParams.push(startDate);\n }\n\n if (dateRange?.end) {\n const endDate =\n dateRange.end instanceof Date ? serializeDate(dateRange.end) : serializeDate(new Date(dateRange.end));\n const endOp = dateRange.endExclusive ? '<' : '<=';\n countQuery += ` AND createdAt ${endOp} ?`;\n countParams.push(endDate);\n }\n\n const countResult = (await this.#db.executeQuery({\n sql: countQuery,\n params: countParams as (string | number | boolean | null | undefined)[],\n })) as {\n count: number;\n }[];\n const total = Number(countResult[0]?.count ?? 0);\n\n // Only return early if there are no messages AND no includes to process\n if (total === 0 && paginatedCount === 0 && (!include || include.length === 0)) {\n return {\n messages: [],\n total: 0,\n page,\n perPage: perPageForResponse,\n hasMore: false,\n };\n }\n\n // Step 2: Add included messages with context (if any), excluding duplicates\n const messageIds = new Set(paginatedMessages.map((m: Record<string, unknown>) => m.id as string));\n let includeMessages: MastraDBMessage[] = [];\n\n if (include && include.length > 0) {\n // Use the existing _getIncludedMessages helper, but adapt it for listMessages format\n const includeResult = (await this._getIncludedMessages(include)) as MastraDBMessage[];\n if (Array.isArray(includeResult)) {\n includeMessages = includeResult;\n\n // Deduplicate: only add messages that aren't already in the paginated results\n for (const includeMsg of includeMessages) {\n if (!messageIds.has(includeMsg.id)) {\n paginatedMessages.push(includeMsg as unknown as Record<string, unknown>);\n messageIds.add(includeMsg.id);\n }\n }\n }\n }\n\n // Use MessageList for proper deduplication and format conversion to V2\n const list = new MessageList().add(paginatedMessages as MastraMessageV1[] | MastraDBMessage[], 'memory');\n let finalMessages = list.get.all.db();\n\n // Sort all messages (paginated + included) for final output\n finalMessages = finalMessages.sort((a, b) => {\n const isDateField = field === 'createdAt' || field === 'updatedAt';\n const aValue = isDateField\n ? new Date((a as Record<string, unknown>)[field] as string | Date).getTime()\n : (a as Record<string, unknown>)[field];\n const bValue = isDateField\n ? new Date((b as Record<string, unknown>)[field] as string | Date).getTime()\n : (b as Record<string, unknown>)[field];\n\n // Handle tiebreaker for stable sorting\n if (aValue === bValue) {\n return a.id.localeCompare(b.id);\n }\n\n if (typeof aValue === 'number' && typeof bValue === 'number') {\n return direction === 'ASC' ? aValue - bValue : bValue - aValue;\n }\n // Fallback to string comparison for non-numeric fields\n return direction === 'ASC'\n ? String(aValue).localeCompare(String(bValue))\n : String(bValue).localeCompare(String(aValue));\n });\n\n // Calculate hasMore based on pagination window\n // If all thread messages have been returned (through pagination or include), hasMore = false\n // Otherwise, check if there are more pages in the pagination window\n const returnedThreadMessageIds = new Set(finalMessages.filter(m => m.threadId === threadId).map(m => m.id));\n const allThreadMessagesReturned = returnedThreadMessageIds.size >= total;\n const hasMore =\n perPageInput === false ? false : allThreadMessagesReturned ? false : offset + paginatedCount < total;\n\n return {\n messages: finalMessages,\n total,\n page,\n perPage: perPageForResponse,\n hasMore,\n };\n } catch (error: unknown) {\n const mastraError = new MastraError(\n {\n id: createStorageErrorId('CLOUDFLARE_DO', 'LIST_MESSAGES', 'FAILED'),\n domain: ErrorDomain.STORAGE,\n category: ErrorCategory.THIRD_PARTY,\n text: `Failed to list messages for thread ${Array.isArray(threadId) ? threadId.join(',') : threadId}: ${\n error instanceof Error ? error.message : String(error)\n }`,\n details: {\n threadId: Array.isArray(threadId) ? threadId.join(',') : threadId,\n resourceId: resourceId ?? '',\n },\n },\n error,\n );\n this.logger?.error?.(mastraError.toString());\n this.logger?.trackException?.(mastraError);\n return {\n messages: [],\n total: 0,\n page,\n perPage: perPageForResponse,\n hasMore: false,\n };\n }\n }\n\n async updateMessages(args: {\n messages: (Partial<Omit<MastraDBMessage, 'createdAt'>> & {\n id: string;\n content?: {\n metadata?: MastraMessageContentV2['metadata'];\n content?: MastraMessageContentV2['content'];\n };\n })[];\n }): Promise<MastraDBMessage[]> {\n const { messages } = args;\n this.logger.debug('Updating messages', { count: messages.length });\n\n if (!messages.length) {\n return [];\n }\n\n const messageIds = messages.map(m => m.id);\n const fullTableName = this.#db.getTableName(TABLE_MESSAGES);\n const threadsTableName = this.#db.getTableName(TABLE_THREADS);\n\n try {\n // Get existing messages\n const placeholders = messageIds.map(() => '?').join(',');\n const selectQuery = `SELECT id, content, role, type, createdAt, thread_id AS threadId, resourceId FROM ${fullTableName} WHERE id IN (${placeholders})`;\n const existingMessages = (await this.#db.executeQuery({ sql: selectQuery, params: messageIds })) as any[];\n\n if (existingMessages.length === 0) {\n return [];\n }\n\n // Parse content from string to object for merging\n const parsedExistingMessages = existingMessages.map(msg => {\n let parsedContent = msg.content;\n if (typeof msg.content === 'string') {\n try {\n parsedContent = JSON.parse(msg.content);\n } catch {\n // Keep as string if parsing fails\n }\n }\n return { ...msg, content: parsedContent };\n });\n\n // Create a map of existing messages by ID for quick lookup\n const existingMessagesMap = new Map(parsedExistingMessages.map(msg => [msg.id, msg]));\n\n // Merge updates with existing messages\n const updatedMessages: any[] = [];\n const now = new Date().toISOString();\n\n for (const update of messages) {\n const existing = existingMessagesMap.get(update.id);\n if (!existing) continue;\n\n // Deep merge the content\n let mergedContent = existing.content;\n if (update.content) {\n if (typeof mergedContent === 'object' && mergedContent !== null) {\n mergedContent = {\n ...mergedContent,\n ...update.content,\n metadata: {\n ...mergedContent.metadata,\n ...update.content.metadata,\n },\n };\n } else {\n mergedContent = update.content;\n }\n }\n\n updatedMessages.push({\n ...existing,\n ...update,\n content: mergedContent,\n });\n }\n\n // Update each message\n for (const msg of updatedMessages) {\n const contentStr = typeof msg.content === 'string' ? msg.content : JSON.stringify(msg.content);\n const updateQuery = createSqlBuilder()\n .update(fullTableName, ['content', 'role', 'type'], [contentStr, msg.role as string, msg.type as string])\n .where('id = ?', msg.id);\n\n const { sql, params } = updateQuery.build();\n await this.#db.executeQuery({ sql, params });\n }\n\n // Update thread's updatedAt timestamp\n const threadIds = [...new Set(updatedMessages.map(m => m.threadId))];\n for (const tid of threadIds) {\n await this.#db.executeQuery({\n sql: `UPDATE ${threadsTableName} SET updatedAt = ? WHERE id = ?`,\n params: [now, tid],\n });\n }\n\n // Return updated messages in the expected format\n const list = new MessageList().add(updatedMessages, 'memory');\n return list.get.all.db();\n } catch (error) {\n throw new MastraError(\n {\n id: createStorageErrorId('CLOUDFLARE_DO', 'UPDATE_MESSAGES', 'FAILED'),\n domain: ErrorDomain.STORAGE,\n category: ErrorCategory.THIRD_PARTY,\n text: `Failed to update messages: ${error instanceof Error ? error.message : String(error)}`,\n details: { messageIds: JSON.stringify(messageIds) },\n },\n error,\n );\n }\n }\n\n async deleteMessages(messageIds: string[]): Promise<void> {\n if (messageIds.length === 0) return;\n\n const fullTableName = this.#db.getTableName(TABLE_MESSAGES);\n\n try {\n const placeholders = messageIds.map(() => '?').join(',');\n const sql = `DELETE FROM ${fullTableName} WHERE id IN (${placeholders})`;\n await this.#db.executeQuery({ sql, params: messageIds });\n this.logger.debug(`Deleted ${messageIds.length} messages`);\n } catch (error) {\n throw new MastraError(\n {\n id: createStorageErrorId('CLOUDFLARE_DO', 'DELETE_MESSAGES', 'FAILED'),\n domain: ErrorDomain.STORAGE,\n category: ErrorCategory.THIRD_PARTY,\n text: `Failed to delete messages: ${error instanceof Error ? error.message : String(error)}`,\n details: { messageIds: JSON.stringify(messageIds) },\n },\n error,\n );\n }\n }\n}\n","import { ErrorDomain, ErrorCategory, MastraError } from '@mastra/core/error';\nimport type { ListScoresResponse, SaveScorePayload, ScoreRowData, ScoringSource } from '@mastra/core/evals';\nimport { saveScorePayloadSchema } from '@mastra/core/evals';\nimport {\n createStorageErrorId,\n ScoresStorage,\n TABLE_SCORERS,\n TABLE_SCHEMAS,\n calculatePagination,\n normalizePerPage,\n transformScoreRow as coreTransformScoreRow,\n} from '@mastra/core/storage';\nimport type { StoragePagination } from '@mastra/core/storage';\n\nimport { DODB } from '../../db';\nimport type { DODomainConfig } from '../../db';\nimport { createSqlBuilder } from '../../sql-builder';\n\n/**\n * Durable Objects-specific score row transformation.\n * Uses Z-suffix timestamps (createdAtZ, updatedAtZ) when available.\n */\nfunction transformScoreRow(row: Record<string, unknown>): ScoreRowData {\n return coreTransformScoreRow(row, {\n preferredTimestampFields: {\n createdAt: 'createdAtZ',\n updatedAt: 'updatedAtZ',\n },\n });\n}\n\nexport class ScoresStorageDO extends ScoresStorage {\n #db: DODB;\n\n constructor(config: DODomainConfig) {\n super();\n this.#db = new DODB(config);\n }\n\n async init(): Promise<void> {\n await this.#db.createTable({ tableName: TABLE_SCORERS, schema: TABLE_SCHEMAS[TABLE_SCORERS] });\n }\n\n async dangerouslyClearAll(): Promise<void> {\n await this.#db.clearTable({ tableName: TABLE_SCORERS });\n }\n\n async getScoreById({ id }: { id: string }): Promise<ScoreRowData | null> {\n try {\n const fullTableName = this.#db.getTableName(TABLE_SCORERS);\n const query = createSqlBuilder().select('*').from(fullTableName).where('id = ?', id);\n const { sql, params } = query.build();\n\n const result = await this.#db.executeQuery({ sql, params, first: true });\n\n if (!result) {\n return null;\n }\n\n return transformScoreRow(result as Record<string, unknown>);\n } catch (error) {\n throw new MastraError(\n {\n id: createStorageErrorId('CLOUDFLARE_DO', 'GET_SCORE_BY_ID', 'FAILED'),\n domain: ErrorDomain.STORAGE,\n category: ErrorCategory.THIRD_PARTY,\n },\n error,\n );\n }\n }\n\n async saveScore(score: SaveScorePayload): Promise<{ score: ScoreRowData }> {\n let parsedScore: SaveScorePayload;\n try {\n parsedScore = saveScorePayloadSchema.parse(score);\n } catch (error) {\n // Guard against null/primitives when accessing score properties\n const safeScore = score && typeof score === 'object' ? (score as Record<string, unknown>) : {};\n const safeScorer =\n safeScore.scorer && typeof safeScore.scorer === 'object' ? (safeScore.scorer as Record<string, unknown>) : {};\n throw new MastraError(\n {\n id: createStorageErrorId('CLOUDFLARE_DO', 'SAVE_SCORE', 'VALIDATION_FAILED'),\n domain: ErrorDomain.STORAGE,\n category: ErrorCategory.USER,\n details: {\n scorer: typeof safeScorer.id === 'string' ? safeScorer.id : String(safeScorer.id ?? 'unknown'),\n entityId: (safeScore.entityId as string) ?? 'unknown',\n entityType: (safeScore.entityType as string) ?? 'unknown',\n traceId: (safeScore.traceId as string) ?? '',\n spanId: (safeScore.spanId as string) ?? '',\n },\n },\n error,\n );\n }\n\n const id = crypto.randomUUID();\n\n try {\n const fullTableName = this.#db.getTableName(TABLE_SCORERS);\n\n // Serialize all object values to JSON strings\n const serializedRecord: Record<string, unknown> = {};\n for (const [key, value] of Object.entries(parsedScore)) {\n if (value !== null && value !== undefined) {\n if (typeof value === 'object') {\n serializedRecord[key] = JSON.stringify(value);\n } else {\n serializedRecord[key] = value;\n }\n } else {\n serializedRecord[key] = null;\n }\n }\n\n const now = new Date();\n serializedRecord.id = id;\n serializedRecord.createdAt = now.toISOString();\n serializedRecord.updatedAt = now.toISOString();\n\n const columns = Object.keys(serializedRecord);\n const values = Object.values(serializedRecord);\n\n const query = createSqlBuilder().insert(\n fullTableName,\n columns,\n values as (string | number | boolean | null | undefined)[],\n );\n const { sql, params } = query.build();\n\n await this.#db.executeQuery({ sql, params });\n\n return { score: { ...parsedScore, id, createdAt: now, updatedAt: now } as ScoreRowData };\n } catch (error) {\n throw new MastraError(\n {\n id: createStorageErrorId('CLOUDFLARE_DO', 'SAVE_SCORE', 'FAILED'),\n domain: ErrorDomain.STORAGE,\n category: ErrorCategory.THIRD_PARTY,\n details: { id },\n },\n error,\n );\n }\n }\n\n async listScoresByScorerId({\n scorerId,\n entityId,\n entityType,\n source,\n pagination,\n }: {\n scorerId: string;\n entityId?: string;\n entityType?: string;\n source?: ScoringSource;\n pagination: StoragePagination;\n }): Promise<ListScoresResponse> {\n try {\n const { page, perPage: perPageInput } = pagination;\n const perPage = normalizePerPage(perPageInput, 100);\n const { offset: start, perPage: perPageForResponse } = calculatePagination(page, perPageInput, perPage);\n\n const fullTableName = this.#db.getTableName(TABLE_SCORERS);\n\n // Get total count\n const countQuery = createSqlBuilder().count().from(fullTableName).where('scorerId = ?', scorerId);\n if (entityId) {\n countQuery.andWhere('entityId = ?', entityId);\n }\n if (entityType) {\n countQuery.andWhere('entityType = ?', entityType);\n }\n if (source) {\n countQuery.andWhere('source = ?', source as string);\n }\n const countResult = await this.#db.executeQuery(countQuery.build());\n const total = Array.isArray(countResult)\n ? Number(countResult?.[0]?.count ?? 0)\n : Number((countResult as Record<string, unknown>)?.count ?? 0);\n\n if (total === 0) {\n return {\n pagination: {\n total: 0,\n page,\n perPage: perPageForResponse,\n hasMore: false,\n },\n scores: [],\n };\n }\n\n const end = perPageInput === false ? total : start + perPage;\n const limitValue = perPageInput === false ? total : perPage;\n\n // Get paginated results\n const selectQuery = createSqlBuilder().select('*').from(fullTableName).where('scorerId = ?', scorerId);\n\n if (entityId) {\n selectQuery.andWhere('entityId = ?', entityId);\n }\n if (entityType) {\n selectQuery.andWhere('entityType = ?', entityType);\n }\n if (source) {\n selectQuery.andWhere('source = ?', source as string);\n }\n selectQuery.limit(limitValue).offset(start);\n\n const { sql, params } = selectQuery.build();\n const results = await this.#db.executeQuery({ sql, params });\n\n const scores = Array.isArray(results) ? results.map(r => transformScoreRow(r as Record<string, unknown>)) : [];\n\n return {\n pagination: {\n total,\n page,\n perPage: perPageForResponse,\n hasMore: end < total,\n },\n scores,\n };\n } catch (error) {\n throw new MastraError(\n {\n id: createStorageErrorId('CLOUDFLARE_DO', 'GET_SCORES_BY_SCORER_ID', 'FAILED'),\n domain: ErrorDomain.STORAGE,\n category: ErrorCategory.THIRD_PARTY,\n },\n error,\n );\n }\n }\n\n async listScoresByRunId({\n runId,\n pagination,\n }: {\n runId: string;\n pagination: StoragePagination;\n }): Promise<ListScoresResponse> {\n try {\n const { page, perPage: perPageInput } = pagination;\n const perPage = normalizePerPage(perPageInput, 100);\n const { offset: start, perPage: perPageForResponse } = calculatePagination(page, perPageInput, perPage);\n\n const fullTableName = this.#db.getTableName(TABLE_SCORERS);\n\n // Get total count\n const countQuery = createSqlBuilder().count().from(fullTableName).where('runId = ?', runId);\n const countResult = await this.#db.executeQuery(countQuery.build());\n const total = Array.isArray(countResult)\n ? Number(countResult?.[0]?.count ?? 0)\n : Number((countResult as Record<string, unknown>)?.count ?? 0);\n\n if (total === 0) {\n return {\n pagination: {\n total: 0,\n page,\n perPage: perPageForResponse,\n hasMore: false,\n },\n scores: [],\n };\n }\n\n const end = perPageInput === false ? total : start + perPage;\n const limitValue = perPageInput === false ? total : perPage;\n\n // Get paginated results\n const selectQuery = createSqlBuilder()\n .select('*')\n .from(fullTableName)\n .where('runId = ?', runId)\n .limit(limitValue)\n .offset(start);\n\n const { sql, params } = selectQuery.build();\n const results = await this.#db.executeQuery({ sql, params });\n\n const scores = Array.isArray(results) ? results.map(r => transformScoreRow(r as Record<string, unknown>)) : [];\n\n return {\n pagination: {\n total,\n page,\n perPage: perPageForResponse,\n hasMore: end < total,\n },\n scores,\n };\n } catch (error) {\n throw new MastraError(\n {\n id: createStorageErrorId('CLOUDFLARE_DO', 'GET_SCORES_BY_RUN_ID', 'FAILED'),\n domain: ErrorDomain.STORAGE,\n category: ErrorCategory.THIRD_PARTY,\n },\n error,\n );\n }\n }\n\n async listScoresByEntityId({\n entityId,\n entityType,\n pagination,\n }: {\n pagination: StoragePagination;\n entityId: string;\n entityType: string;\n }): Promise<ListScoresResponse> {\n try {\n const { page, perPage: perPageInput } = pagination;\n const perPage = normalizePerPage(perPageInput, 100);\n const { offset: start, perPage: perPageForResponse } = calculatePagination(page, perPageInput, perPage);\n\n const fullTableName = this.#db.getTableName(TABLE_SCORERS);\n\n // Get total count\n const countQuery = createSqlBuilder()\n .count()\n .from(fullTableName)\n .where('entityId = ?', entityId)\n .andWhere('entityType = ?', entityType);\n const countResult = await this.#db.executeQuery(countQuery.build());\n const total = Array.isArray(countResult)\n ? Number(countResult?.[0]?.count ?? 0)\n : Number((countResult as Record<string, unknown>)?.count ?? 0);\n\n if (total === 0) {\n return {\n pagination: {\n total: 0,\n page,\n perPage: perPageForResponse,\n hasMore: false,\n },\n scores: [],\n };\n }\n\n const end = perPageInput === false ? total : start + perPage;\n const limitValue = perPageInput === false ? total : perPage;\n\n // Get paginated results\n const selectQuery = createSqlBuilder()\n .select('*')\n .from(fullTableName)\n .where('entityId = ?', entityId)\n .andWhere('entityType = ?', entityType)\n .limit(limitValue)\n .offset(start);\n\n const { sql, params } = selectQuery.build();\n const results = await this.#db.executeQuery({ sql, params });\n\n const scores = Array.isArray(results) ? results.map(r => transformScoreRow(r as Record<string, unknown>)) : [];\n\n return {\n pagination: {\n total,\n page,\n perPage: perPageForResponse,\n hasMore: end < total,\n },\n scores,\n };\n } catch (error) {\n throw new MastraError(\n {\n id: createStorageErrorId('CLOUDFLARE_DO', 'GET_SCORES_BY_ENTITY_ID', 'FAILED'),\n domain: ErrorDomain.STORAGE,\n category: ErrorCategory.THIRD_PARTY,\n },\n error,\n );\n }\n }\n\n async listScoresBySpan({\n traceId,\n spanId,\n pagination,\n }: {\n traceId: string;\n spanId: string;\n pagination: StoragePagination;\n }): Promise<ListScoresResponse> {\n try {\n const { page, perPage: perPageInput } = pagination;\n const perPage = normalizePerPage(perPageInput, 100);\n const { offset: start, perPage: perPageForResponse } = calculatePagination(page, perPageInput, perPage);\n\n const fullTableName = this.#db.getTableName(TABLE_SCORERS);\n\n // Get total count\n const countQuery = createSqlBuilder()\n .count()\n .from(fullTableName)\n .where('traceId = ?', traceId)\n .andWhere('spanId = ?', spanId);\n const countResult = await this.#db.executeQuery(countQuery.build());\n const total = Array.isArray(countResult)\n ? Number(countResult?.[0]?.count ?? 0)\n : Number((countResult as Record<string, unknown>)?.count ?? 0);\n\n if (total === 0) {\n return {\n pagination: {\n total: 0,\n page,\n perPage: perPageForResponse,\n hasMore: false,\n },\n scores: [],\n };\n }\n\n const end = perPageInput === false ? total : start + perPage;\n const limitValue = perPageInput === false ? total : perPage;\n\n // Get paginated results\n const selectQuery = createSqlBuilder()\n .select('*')\n .from(fullTableName)\n .where('traceId = ?', traceId)\n .andWhere('spanId = ?', spanId)\n .orderBy('createdAt', 'DESC')\n .limit(limitValue)\n .offset(start);\n\n const { sql, params } = selectQuery.build();\n const results = await this.#db.executeQuery({ sql, params });\n const scores = Array.isArray(results) ? results.map(r => transformScoreRow(r as Record<string, unknown>)) : [];\n\n return {\n pagination: {\n total,\n page,\n perPage: perPageForResponse,\n hasMore: end < total,\n },\n scores,\n };\n } catch (error) {\n throw new MastraError(\n {\n id: createStorageErrorId('CLOUDFLARE_DO', 'GET_SCORES_BY_SPAN', 'FAILED'),\n domain: ErrorDomain.STORAGE,\n category: ErrorCategory.THIRD_PARTY,\n },\n error,\n );\n }\n }\n}\n","import { ErrorCategory, ErrorDomain, MastraError } from '@mastra/core/error';\nimport type {\n WorkflowRun,\n WorkflowRuns,\n StorageListWorkflowRunsInput,\n UpdateWorkflowStateOptions,\n} from '@mastra/core/storage';\nimport {\n createStorageErrorId,\n ensureDate,\n TABLE_WORKFLOW_SNAPSHOT,\n TABLE_SCHEMAS,\n WorkflowsStorage,\n} from '@mastra/core/storage';\nimport type { StepResult, WorkflowRunState } from '@mastra/core/workflows';\n\nimport { DODB } from '../../db';\nimport type { DODomainConfig } from '../../db';\nimport { createSqlBuilder } from '../../sql-builder';\nimport type { SqlParam } from '../../sql-builder';\nimport { isArrayOfRecords } from '../utils';\n\nexport class WorkflowsStorageDO extends WorkflowsStorage {\n #db: DODB;\n\n constructor(config: DODomainConfig) {\n super();\n this.#db = new DODB(config);\n }\n\n supportsConcurrentUpdates(): boolean {\n // updateWorkflowResults and updateWorkflowState are not yet implemented\n return false;\n }\n\n async init(): Promise<void> {\n await this.#db.createTable({ tableName: TABLE_WORKFLOW_SNAPSHOT, schema: TABLE_SCHEMAS[TABLE_WORKFLOW_SNAPSHOT] });\n }\n\n async dangerouslyClearAll(): Promise<void> {\n await this.#db.clearTable({ tableName: TABLE_WORKFLOW_SNAPSHOT });\n }\n\n updateWorkflowResults(\n {\n // workflowName,\n // runId,\n // stepId,\n // result,\n // requestContext,\n }: {\n workflowName: string;\n runId: string;\n stepId: string;\n result: StepResult<unknown, unknown, unknown, unknown>;\n requestContext: Record<string, unknown>;\n },\n ): Promise<Record<string, StepResult<unknown, unknown, unknown, unknown>>> {\n throw new Error('Method not implemented.');\n }\n updateWorkflowState(\n {\n // workflowName,\n // runId,\n // opts,\n }: {\n workflowName: string;\n runId: string;\n opts: UpdateWorkflowStateOptions;\n },\n ): Promise<WorkflowRunState | undefined> {\n throw new Error('Method not implemented.');\n }\n\n async persistWorkflowSnapshot({\n workflowName,\n runId,\n resourceId,\n snapshot,\n createdAt,\n updatedAt,\n }: {\n workflowName: string;\n runId: string;\n resourceId?: string;\n snapshot: WorkflowRunState;\n createdAt?: Date;\n updatedAt?: Date;\n }): Promise<void> {\n const fullTableName = this.#db.getTableName(TABLE_WORKFLOW_SNAPSHOT);\n const now = new Date().toISOString();\n\n const currentSnapshot = await this.#db.load({\n tableName: TABLE_WORKFLOW_SNAPSHOT,\n keys: { workflow_name: workflowName, run_id: runId },\n });\n\n const persisting = currentSnapshot\n ? {\n ...currentSnapshot,\n resourceId,\n snapshot: JSON.stringify(snapshot),\n updatedAt: updatedAt ? updatedAt.toISOString() : now,\n }\n : {\n workflow_name: workflowName,\n run_id: runId,\n resourceId,\n snapshot: JSON.stringify(snapshot),\n createdAt: createdAt ? createdAt.toISOString() : now,\n updatedAt: updatedAt ? updatedAt.toISOString() : now,\n };\n\n // Process record for SQL insertion\n const processedRecord = await this.#db.processRecord(persisting);\n\n const columns = Object.keys(processedRecord);\n const values = Object.values(processedRecord);\n\n // Specify which columns to update on conflict (all except PKs)\n // Use COALESCE for resourceId to preserve existing value when new value is null\n const updateMap: Record<string, string> = {\n snapshot: 'excluded.snapshot',\n updatedAt: 'excluded.updatedAt',\n resourceId: `COALESCE(excluded.resourceId, ${fullTableName}.resourceId)`,\n };\n\n this.logger.debug('Persisting workflow snapshot', { workflowName, runId });\n\n // Use the new insert method with ON CONFLICT\n const query = createSqlBuilder().insert(\n fullTableName,\n columns,\n values as SqlParam[],\n ['workflow_name', 'run_id'],\n updateMap,\n );\n\n const { sql, params } = query.build();\n\n try {\n await this.#db.executeQuery({ sql, params });\n } catch (error) {\n throw new MastraError(\n {\n id: createStorageErrorId('CLOUDFLARE_DO', 'PERSIST_WORKFLOW_SNAPSHOT', 'FAILED'),\n domain: ErrorDomain.STORAGE,\n category: ErrorCategory.THIRD_PARTY,\n text: `Failed to persist workflow snapshot: ${error instanceof Error ? error.message : String(error)}`,\n details: { workflowName, runId },\n },\n error,\n );\n }\n }\n\n async loadWorkflowSnapshot(params: { workflowName: string; runId: string }): Promise<WorkflowRunState | null> {\n const { workflowName, runId } = params;\n\n this.logger.debug('Loading workflow snapshot', { workflowName, runId });\n\n try {\n const d = await this.#db.load<{ snapshot: unknown }>({\n tableName: TABLE_WORKFLOW_SNAPSHOT,\n keys: {\n workflow_name: workflowName,\n run_id: runId,\n },\n });\n\n return d ? (d.snapshot as WorkflowRunState) : null;\n } catch (error) {\n throw new MastraError(\n {\n id: createStorageErrorId('CLOUDFLARE_DO', 'LOAD_WORKFLOW_SNAPSHOT', 'FAILED'),\n domain: ErrorDomain.STORAGE,\n category: ErrorCategory.THIRD_PARTY,\n text: `Failed to load workflow snapshot: ${error instanceof Error ? error.message : String(error)}`,\n details: { workflowName, runId },\n },\n error,\n );\n }\n }\n\n private parseWorkflowRun(row: any): WorkflowRun {\n let parsedSnapshot: WorkflowRunState | string = row.snapshot;\n if (typeof parsedSnapshot === 'string') {\n try {\n parsedSnapshot = JSON.parse(row.snapshot) as WorkflowRunState;\n } catch (e) {\n // If parsing fails, return the raw snapshot string\n this.logger.warn(`Failed to parse snapshot for workflow ${row.workflow_name}: ${e}`);\n }\n }\n\n return {\n workflowName: row.workflow_name,\n runId: row.run_id,\n snapshot: parsedSnapshot,\n createdAt: ensureDate(row.createdAt)!,\n updatedAt: ensureDate(row.updatedAt)!,\n resourceId: row.resourceId,\n };\n }\n\n async listWorkflowRuns({\n workflowName,\n fromDate,\n toDate,\n page,\n perPage,\n resourceId,\n status,\n }: StorageListWorkflowRunsInput = {}): Promise<WorkflowRuns> {\n const fullTableName = this.#db.getTableName(TABLE_WORKFLOW_SNAPSHOT);\n try {\n const builder = createSqlBuilder().select().from(fullTableName);\n const countBuilder = createSqlBuilder().count().from(fullTableName);\n\n if (workflowName) {\n builder.whereAnd('workflow_name = ?', workflowName);\n countBuilder.whereAnd('workflow_name = ?', workflowName);\n }\n if (status) {\n builder.whereAnd(\"json_extract(snapshot, '$.status') = ?\", status);\n countBuilder.whereAnd(\"json_extract(snapshot, '$.status') = ?\", status);\n }\n if (resourceId) {\n const hasResourceId = await this.#db.hasColumn(fullTableName, 'resourceId');\n if (hasResourceId) {\n builder.whereAnd('resourceId = ?', resourceId);\n countBuilder.whereAnd('resourceId = ?', resourceId);\n } else {\n this.logger.warn(`[${fullTableName}] resourceId column not found. Skipping resourceId filter.`);\n }\n }\n if (fromDate) {\n builder.whereAnd('createdAt >= ?', fromDate instanceof Date ? fromDate.toISOString() : fromDate);\n countBuilder.whereAnd('createdAt >= ?', fromDate instanceof Date ? fromDate.toISOString() : fromDate);\n }\n if (toDate) {\n builder.whereAnd('createdAt <= ?', toDate instanceof Date ? toDate.toISOString() : toDate);\n countBuilder.whereAnd('createdAt <= ?', toDate instanceof Date ? toDate.toISOString() : toDate);\n }\n\n builder.orderBy('createdAt', 'DESC');\n if (typeof perPage === 'number' && typeof page === 'number') {\n const offset = page * perPage;\n builder.limit(perPage);\n builder.offset(offset);\n }\n\n const { sql, params } = builder.build();\n\n let total = 0;\n\n if (perPage !== undefined && page !== undefined) {\n const { sql: countSql, params: countParams } = countBuilder.build();\n const countResult = await this.#db.executeQuery({\n sql: countSql,\n params: countParams,\n first: true,\n });\n total = Number((countResult as Record<string, unknown>)?.count ?? 0);\n }\n\n const results = await this.#db.executeQuery({ sql, params });\n const runs = (isArrayOfRecords(results) ? results : []).map((row: Record<string, unknown>) =>\n this.parseWorkflowRun(row),\n );\n return { runs, total: total || runs.length };\n } catch (error) {\n throw new MastraError(\n {\n id: createStorageErrorId('CLOUDFLARE_DO', 'LIST_WORKFLOW_RUNS', 'FAILED'),\n domain: ErrorDomain.STORAGE,\n category: ErrorCategory.THIRD_PARTY,\n text: `Failed to retrieve workflow runs: ${error instanceof Error ? error.message : String(error)}`,\n details: {\n workflowName: workflowName ?? '',\n resourceId: resourceId ?? '',\n },\n },\n error,\n );\n }\n }\n\n async getWorkflowRunById({\n runId,\n workflowName,\n }: {\n runId: string;\n workflowName?: string;\n }): Promise<WorkflowRun | null> {\n const fullTableName = this.#db.getTableName(TABLE_WORKFLOW_SNAPSHOT);\n try {\n const conditions: string[] = [];\n const params: SqlParam[] = [];\n if (runId) {\n conditions.push('run_id = ?');\n params.push(runId);\n }\n if (workflowName) {\n conditions.push('workflow_name = ?');\n params.push(workflowName);\n }\n const whereClause = conditions.length > 0 ? 'WHERE ' + conditions.join(' AND ') : '';\n const sql = `SELECT * FROM ${fullTableName} ${whereClause} ORDER BY createdAt DESC LIMIT 1`;\n const result = await this.#db.executeQuery({ sql, params, first: true });\n if (!result) return null;\n return this.parseWorkflowRun(result as Record<string, unknown>);\n } catch (error) {\n throw new MastraError(\n {\n id: createStorageErrorId('CLOUDFLARE_DO', 'GET_WORKFLOW_RUN_BY_ID', 'FAILED'),\n domain: ErrorDomain.STORAGE,\n category: ErrorCategory.THIRD_PARTY,\n text: `Failed to retrieve workflow run by ID: ${error instanceof Error ? error.message : String(error)}`,\n details: { runId, workflowName: workflowName ?? '' },\n },\n error,\n );\n }\n }\n\n async deleteWorkflowRunById({ runId, workflowName }: { runId: string; workflowName: string }): Promise<void> {\n const fullTableName = this.#db.getTableName(TABLE_WORKFLOW_SNAPSHOT);\n try {\n const sql = `DELETE FROM ${fullTableName} WHERE workflow_name = ? AND run_id = ?`;\n const params: SqlParam[] = [workflowName, runId];\n await this.#db.executeQuery({ sql, params });\n } catch (error) {\n throw new MastraError(\n {\n id: createStorageErrorId('CLOUDFLARE_DO', 'DELETE_WORKFLOW_RUN_BY_ID', 'FAILED'),\n domain: ErrorDomain.STORAGE,\n category: ErrorCategory.THIRD_PARTY,\n text: `Failed to delete workflow run by ID: ${error instanceof Error ? error.message : String(error)}`,\n details: { runId, workflowName },\n },\n error,\n );\n }\n }\n}\n","import type { SqlStorage } from '@cloudflare/workers-types';\nimport { MastraError, ErrorDomain, ErrorCategory } from '@mastra/core/error';\nimport { createStorageErrorId, MastraCompositeStore } from '@mastra/core/storage';\nimport type { StorageDomains } from '@mastra/core/storage';\n\nimport { MemoryStorageDO } from './storage/domains/memory';\nimport { ScoresStorageDO } from './storage/domains/scores';\nimport { WorkflowsStorageDO } from './storage/domains/workflows';\n\n// Export domain classes for direct use with MastraStorage composition\nexport { MemoryStorageDO, ScoresStorageDO, WorkflowsStorageDO };\nexport type { DODomainConfig } from './storage/db';\nexport { DODB } from './storage/db';\n\n/**\n * Configuration for CloudflareDOStorage using Durable Objects SqlStorage\n */\nexport interface CloudflareDOStorageConfig {\n /** SqlStorage instance from Durable Objects ctx.storage.sql */\n sql: SqlStorage;\n /** Optional prefix for table names */\n tablePrefix?: string;\n /**\n * When true, automatic initialization (table creation/migrations) is disabled.\n * This is useful for CI/CD pipelines where you want to:\n * 1. Run migrations explicitly during deployment (not at runtime)\n * 2. Use different credentials for schema changes vs runtime operations\n *\n * When disableInit is true:\n * - The storage will not automatically create/alter tables on first use\n * - You must call `storage.init()` explicitly in your CI/CD scripts\n *\n * @example\n * // In CI/CD script:\n * const storage = new CloudflareDOStorage({ ...config, disableInit: false });\n * await storage.init(); // Explicitly run migrations\n *\n * // In runtime application:\n * const storage = new CloudflareDOStorage({ ...config, disableInit: true });\n * // No auto-init, tables must already exist\n */\n disableInit?: boolean;\n}\n\n/**\n * Cloudflare Durable Objects storage adapter for Mastra.\n *\n * Uses the synchronous SqlStorage API available in Durable Objects\n * to provide thread-based memory storage, workflow persistence, and scoring.\n *\n * Access domain-specific storage via `getStore()`:\n *\n * @example\n * ```typescript\n * import { DurableObject } from \"cloudflare:workers\";\n * import { CloudflareDOStorage } from \"@mastra/cloudflare/do\";\n *\n * class AgentDurableObject extends DurableObject<Env> {\n * private storage: CloudflareDOStorage;\n *\n * constructor(ctx: DurableObjectState, env: Env) {\n * super(ctx, env);\n * this.storage = new CloudflareDOStorage({\n * sql: ctx.storage.sql,\n * tablePrefix: 'mastra_'\n * });\n * }\n *\n * async run() {\n * const memory = await this.storage.getStore('memory');\n * await memory?.saveThread({ thread: { id: 'thread-1', ... } });\n * }\n * }\n * ```\n */\nexport class CloudflareDOStorage extends MastraCompositeStore {\n stores: StorageDomains;\n\n /**\n * Creates a new CloudflareDOStorage instance\n * @param config Configuration for Durable Objects SqlStorage access\n */\n constructor(config: CloudflareDOStorageConfig) {\n try {\n super({ id: 'do-store', name: 'DO', disableInit: config.disableInit });\n\n if (config.tablePrefix && !/^[A-Za-z_][A-Za-z0-9_]*$/.test(config.tablePrefix)) {\n throw new Error(\n 'Invalid tablePrefix: must start with a letter or underscore and contain only letters, numbers, and underscores.',\n );\n }\n\n const domainConfig = { sql: config.sql, tablePrefix: config.tablePrefix };\n\n this.stores = {\n memory: new MemoryStorageDO(domainConfig),\n workflows: new WorkflowsStorageDO(domainConfig),\n scores: new ScoresStorageDO(domainConfig),\n };\n\n this.logger.info('Using Durable Objects SqlStorage');\n } catch (error) {\n throw new MastraError(\n {\n id: createStorageErrorId('CLOUDFLARE_DO', 'INITIALIZATION', 'FAILED'),\n domain: ErrorDomain.STORAGE,\n category: ErrorCategory.SYSTEM,\n text: 'Error initializing CloudflareDOStorage',\n },\n error,\n );\n }\n }\n\n /**\n * Close the database connection\n * No explicit cleanup needed for DO storage\n */\n async close(): Promise<void> {\n this.logger.debug('Closing DO connection');\n // No explicit cleanup needed for DO storage\n }\n}\n\n/**\n * @deprecated Use CloudflareDOStorage instead\n */\nexport const DOStore = CloudflareDOStorage;\n\n/**\n * @deprecated Use CloudflareDOStorageConfig instead\n */\nexport type DOStoreConfig = CloudflareDOStorageConfig;\n"]}
|