@axiom-lattice/pg-stores 1.0.4 → 1.0.5

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/dist/index.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/index.ts","../src/stores/PostgreSQLThreadStore.ts","../src/migrations/migration.ts","../src/migrations/thread_migrations.ts","../src/stores/PostgreSQLAssistantStore.ts","../src/migrations/assistant_migrations.ts","../src/stores/PostgreSQLScheduleStorage.ts","../src/migrations/schedule_migrations.ts"],"sourcesContent":["/**\n * PostgreSQL Stores Package\n *\n * Provides PostgreSQL implementations for various stores\n */\n\nexport * from \"./stores/PostgreSQLThreadStore\";\nexport * from \"./stores/PostgreSQLAssistantStore\";\nexport * from \"./stores/PostgreSQLScheduleStorage\";\nexport * from \"./migrations/migration\";\nexport * from \"./migrations/thread_migrations\";\nexport * from \"./migrations/assistant_migrations\";\nexport * from \"./migrations/schedule_migrations\";\n\n// Re-export for convenience\nexport { PostgreSQLThreadStore } from \"./stores/PostgreSQLThreadStore\";\nexport { PostgreSQLAssistantStore } from \"./stores/PostgreSQLAssistantStore\";\nexport { PostgreSQLScheduleStorage } from \"./stores/PostgreSQLScheduleStorage\";\n\n// Re-export types from protocols\nexport type {\n ThreadStore,\n Thread,\n CreateThreadRequest,\n AssistantStore,\n Assistant,\n CreateAssistantRequest,\n ScheduleStorage,\n ScheduledTaskDefinition,\n ScheduledTaskStatus,\n ScheduleExecutionType,\n} from \"@axiom-lattice/protocols\";\n","/**\n * PostgreSQL implementation of ThreadStore\n */\n\nimport { Pool, PoolClient, PoolConfig } from \"pg\";\nimport {\n ThreadStore,\n Thread,\n CreateThreadRequest,\n} from \"@axiom-lattice/protocols\";\nimport { MigrationManager } from \"../migrations/migration\";\nimport { createThreadsTable } from \"../migrations/thread_migrations\";\n\n/**\n * PostgreSQL ThreadStore options\n */\nexport interface PostgreSQLThreadStoreOptions {\n /**\n * PostgreSQL connection pool configuration\n * Can be a connection string or PoolConfig object\n */\n poolConfig: string | PoolConfig;\n\n /**\n * Whether to run migrations automatically on initialization\n * @default true\n */\n autoMigrate?: boolean;\n}\n\n/**\n * PostgreSQL implementation of ThreadStore\n */\nexport class PostgreSQLThreadStore implements ThreadStore {\n private pool: Pool;\n private migrationManager: MigrationManager;\n private initialized: boolean = false;\n private ownsPool: boolean = true;\n\n constructor(options: PostgreSQLThreadStoreOptions) {\n // Create Pool from config\n if (typeof options.poolConfig === \"string\") {\n this.pool = new Pool({ connectionString: options.poolConfig });\n } else {\n this.pool = new Pool(options.poolConfig);\n }\n\n this.migrationManager = new MigrationManager(this.pool);\n this.migrationManager.register(createThreadsTable);\n\n // Auto-migrate by default\n if (options.autoMigrate !== false) {\n this.initialize().catch((error) => {\n console.error(\"Failed to initialize PostgreSQLThreadStore:\", error);\n throw error;\n });\n }\n }\n\n /**\n * Dispose resources and close the connection pool\n * Should be called when the store is no longer needed\n */\n async dispose(): Promise<void> {\n if (this.ownsPool && this.pool) {\n await this.pool.end();\n }\n }\n\n /**\n * Initialize the store and run migrations\n */\n async initialize(): Promise<void> {\n if (this.initialized) {\n return;\n }\n\n await this.migrationManager.migrate();\n this.initialized = true;\n }\n\n /**\n * Get all threads for a specific assistant\n */\n async getThreadsByAssistantId(assistantId: string): Promise<Thread[]> {\n await this.ensureInitialized();\n\n const result = await this.pool.query<{\n id: string;\n assistant_id: string;\n metadata: any;\n created_at: Date;\n updated_at: Date;\n }>(\n `\n SELECT id, assistant_id, metadata, created_at, updated_at\n FROM lattice_threads\n WHERE assistant_id = $1\n ORDER BY created_at DESC\n `,\n [assistantId]\n );\n\n return result.rows.map(this.mapRowToThread);\n }\n\n /**\n * Get a thread by ID for a specific assistant\n */\n async getThreadById(\n assistantId: string,\n threadId: string\n ): Promise<Thread | undefined> {\n await this.ensureInitialized();\n\n const result = await this.pool.query<{\n id: string;\n assistant_id: string;\n metadata: any;\n created_at: Date;\n updated_at: Date;\n }>(\n `\n SELECT id, assistant_id, metadata, created_at, updated_at\n FROM lattice_threads\n WHERE id = $1 AND assistant_id = $2\n `,\n [threadId, assistantId]\n );\n\n if (result.rows.length === 0) {\n return undefined;\n }\n\n return this.mapRowToThread(result.rows[0]);\n }\n\n /**\n * Create a new thread for an assistant\n */\n async createThread(\n assistantId: string,\n threadId: string,\n data: CreateThreadRequest\n ): Promise<Thread> {\n await this.ensureInitialized();\n\n const now = new Date();\n const metadata = data.metadata || {};\n\n await this.pool.query(\n `\n INSERT INTO lattice_threads (id, assistant_id, metadata, created_at, updated_at)\n VALUES ($1, $2, $3, $4, $5)\n ON CONFLICT (id, assistant_id) DO UPDATE SET\n metadata = EXCLUDED.metadata,\n updated_at = EXCLUDED.updated_at\n `,\n [threadId, assistantId, JSON.stringify(metadata), now, now]\n );\n\n return {\n id: threadId,\n assistantId,\n metadata,\n createdAt: now,\n updatedAt: now,\n };\n }\n\n /**\n * Update an existing thread\n */\n async updateThread(\n assistantId: string,\n threadId: string,\n updates: Partial<CreateThreadRequest>\n ): Promise<Thread | null> {\n await this.ensureInitialized();\n\n // Get existing thread\n const existing = await this.getThreadById(assistantId, threadId);\n if (!existing) {\n return null;\n }\n\n // Merge metadata\n const updatedMetadata = {\n ...existing.metadata,\n ...(updates.metadata || {}),\n };\n\n const now = new Date();\n\n await this.pool.query(\n `\n UPDATE lattice_threads\n SET metadata = $1, updated_at = $2\n WHERE id = $3 AND assistant_id = $4\n `,\n [JSON.stringify(updatedMetadata), now, threadId, assistantId]\n );\n\n return {\n ...existing,\n metadata: updatedMetadata,\n updatedAt: now,\n };\n }\n\n /**\n * Delete a thread by ID\n */\n async deleteThread(assistantId: string, threadId: string): Promise<boolean> {\n await this.ensureInitialized();\n\n const result = await this.pool.query(\n `\n DELETE FROM lattice_threads\n WHERE id = $1 AND assistant_id = $2\n `,\n [threadId, assistantId]\n );\n\n return result.rowCount !== null && result.rowCount > 0;\n }\n\n /**\n * Check if thread exists\n */\n async hasThread(assistantId: string, threadId: string): Promise<boolean> {\n await this.ensureInitialized();\n\n const result = await this.pool.query(\n `\n SELECT 1 FROM lattice_threads\n WHERE id = $1 AND assistant_id = $2\n LIMIT 1\n `,\n [threadId, assistantId]\n );\n\n return result.rows.length > 0;\n }\n\n /**\n * Ensure store is initialized\n */\n private async ensureInitialized(): Promise<void> {\n if (!this.initialized) {\n await this.initialize();\n }\n }\n\n /**\n * Map database row to Thread object\n */\n private mapRowToThread(row: {\n id: string;\n assistant_id: string;\n metadata: any;\n created_at: Date;\n updated_at: Date;\n }): Thread {\n return {\n id: row.id,\n assistantId: row.assistant_id,\n metadata:\n typeof row.metadata === \"string\"\n ? JSON.parse(row.metadata)\n : row.metadata || {},\n createdAt: row.created_at,\n updatedAt: row.updated_at,\n };\n }\n}\n","/**\n * Migration system for database schema management\n */\n\nimport { Pool, PoolClient } from \"pg\";\n\n/**\n * Migration record stored in database\n */\ninterface MigrationRecord {\n version: number;\n name: string;\n applied_at: Date;\n}\n\n/**\n * Migration definition\n */\nexport interface Migration {\n version: number;\n name: string;\n up: (client: PoolClient) => Promise<void>;\n down?: (client: PoolClient) => Promise<void>;\n}\n\n/**\n * Migration manager\n */\nexport class MigrationManager {\n private pool: Pool;\n private migrations: Migration[] = [];\n\n constructor(pool: Pool) {\n this.pool = pool;\n }\n\n /**\n * Register a migration\n */\n register(migration: Migration): void {\n this.migrations.push(migration);\n // Sort migrations by version\n this.migrations.sort((a, b) => a.version - b.version);\n }\n\n /**\n * Initialize migrations table if it doesn't exist\n */\n private async ensureMigrationsTable(client: PoolClient): Promise<void> {\n await client.query(`\n CREATE TABLE IF NOT EXISTS lattice_schema_migrations (\n version INTEGER PRIMARY KEY,\n name VARCHAR(255) NOT NULL,\n applied_at TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP\n )\n `);\n }\n\n /**\n * Get applied migrations from database\n */\n private async getAppliedMigrations(\n client: PoolClient\n ): Promise<MigrationRecord[]> {\n await client.query(`\n CREATE TABLE IF NOT EXISTS lattice_schema_migrations (\n version INTEGER PRIMARY KEY,\n name VARCHAR(255) NOT NULL,\n applied_at TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP\n )\n `);\n\n const result = await client.query<MigrationRecord>(\n \"SELECT version, name, applied_at FROM lattice_schema_migrations ORDER BY version\"\n );\n return result.rows;\n }\n\n /**\n * Apply pending migrations\n */\n async migrate(): Promise<void> {\n const client = await this.pool.connect();\n try {\n await client.query(\"BEGIN\");\n\n await this.ensureMigrationsTable(client);\n const appliedMigrations = await this.getAppliedMigrations(client);\n const appliedVersions = new Set(appliedMigrations.map((m) => m.version));\n\n // Find pending migrations\n const pendingMigrations = this.migrations.filter(\n (m) => !appliedVersions.has(m.version)\n );\n\n if (pendingMigrations.length === 0) {\n console.log(\"No pending migrations\");\n await client.query(\"COMMIT\");\n return;\n }\n\n // Apply pending migrations\n for (const migration of pendingMigrations) {\n console.log(\n `Applying migration ${migration.version}: ${migration.name}`\n );\n await migration.up(client);\n await client.query(\n \"INSERT INTO lattice_schema_migrations (version, name) VALUES ($1, $2)\",\n [migration.version, migration.name]\n );\n }\n\n await client.query(\"COMMIT\");\n console.log(`Applied ${pendingMigrations.length} migration(s)`);\n } catch (error) {\n await client.query(\"ROLLBACK\");\n throw error;\n } finally {\n client.release();\n }\n }\n\n /**\n * Rollback last migration\n */\n async rollback(): Promise<void> {\n const client = await this.pool.connect();\n try {\n await client.query(\"BEGIN\");\n\n const appliedMigrations = await this.getAppliedMigrations(client);\n if (appliedMigrations.length === 0) {\n console.log(\"No migrations to rollback\");\n await client.query(\"COMMIT\");\n return;\n }\n\n const lastMigration = appliedMigrations[appliedMigrations.length - 1];\n const migration = this.migrations.find(\n (m) => m.version === lastMigration.version\n );\n\n if (!migration || !migration.down) {\n throw new Error(\n `Migration ${lastMigration.version} does not have a down migration`\n );\n }\n\n console.log(\n `Rolling back migration ${lastMigration.version}: ${lastMigration.name}`\n );\n await migration.down(client);\n await client.query(\n \"DELETE FROM lattice_schema_migrations WHERE version = $1\",\n [lastMigration.version]\n );\n\n await client.query(\"COMMIT\");\n console.log(\"Rollback completed\");\n } catch (error) {\n await client.query(\"ROLLBACK\");\n throw error;\n } finally {\n client.release();\n }\n }\n\n /**\n * Get current migration version\n */\n async getCurrentVersion(): Promise<number> {\n const client = await this.pool.connect();\n try {\n const appliedMigrations = await this.getAppliedMigrations(client);\n if (appliedMigrations.length === 0) {\n return 0;\n }\n return Math.max(...appliedMigrations.map((m) => m.version));\n } finally {\n client.release();\n }\n }\n}\n","/**\n * Thread table migrations\n */\n\nimport { PoolClient } from \"pg\";\nimport { Migration } from \"./migration\";\n\n/**\n * Initial migration: Create threads table\n */\nexport const createThreadsTable: Migration = {\n version: 1,\n name: \"create_threads_table\",\n up: async (client: PoolClient) => {\n await client.query(`\n CREATE TABLE IF NOT EXISTS lattice_threads (\n id VARCHAR(255) NOT NULL,\n assistant_id VARCHAR(255) NOT NULL,\n metadata JSONB DEFAULT '{}',\n created_at TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,\n updated_at TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,\n PRIMARY KEY (id, assistant_id)\n )\n `);\n\n // Create indexes for better query performance\n await client.query(`\n CREATE INDEX IF NOT EXISTS idx_lattice_threads_assistant_id \n ON lattice_threads(assistant_id)\n `);\n\n await client.query(`\n CREATE INDEX IF NOT EXISTS idx_lattice_threads_created_at \n ON lattice_threads(created_at DESC)\n `);\n },\n down: async (client: PoolClient) => {\n await client.query(\"DROP INDEX IF EXISTS idx_lattice_threads_created_at\");\n await client.query(\"DROP INDEX IF EXISTS idx_lattice_threads_assistant_id\");\n await client.query(\"DROP TABLE IF EXISTS lattice_threads\");\n },\n};\n","/**\n * PostgreSQL implementation of AssistantStore\n */\n\nimport { Pool, PoolClient, PoolConfig } from \"pg\";\nimport {\n AssistantStore,\n Assistant,\n CreateAssistantRequest,\n} from \"@axiom-lattice/protocols\";\nimport { MigrationManager } from \"../migrations/migration\";\nimport { createAssistantsTable } from \"../migrations/assistant_migrations\";\n\n/**\n * PostgreSQL AssistantStore options\n */\nexport interface PostgreSQLAssistantStoreOptions {\n /**\n * PostgreSQL connection pool configuration\n * Can be a connection string or PoolConfig object\n */\n poolConfig: string | PoolConfig;\n\n /**\n * Whether to run migrations automatically on initialization\n * @default true\n */\n autoMigrate?: boolean;\n}\n\n/**\n * PostgreSQL implementation of AssistantStore\n */\nexport class PostgreSQLAssistantStore implements AssistantStore {\n private pool: Pool;\n private migrationManager: MigrationManager;\n private initialized: boolean = false;\n private ownsPool: boolean = true;\n\n constructor(options: PostgreSQLAssistantStoreOptions) {\n // Create Pool from config\n if (typeof options.poolConfig === \"string\") {\n this.pool = new Pool({ connectionString: options.poolConfig });\n } else {\n this.pool = new Pool(options.poolConfig);\n }\n\n this.migrationManager = new MigrationManager(this.pool);\n this.migrationManager.register(createAssistantsTable);\n\n // Auto-migrate by default\n if (options.autoMigrate !== false) {\n this.initialize().catch((error) => {\n console.error(\"Failed to initialize PostgreSQLAssistantStore:\", error);\n throw error;\n });\n }\n }\n\n /**\n * Initialize the store and run migrations\n */\n async initialize(): Promise<void> {\n if (this.initialized) {\n return;\n }\n\n await this.migrationManager.migrate();\n this.initialized = true;\n }\n\n /**\n * Get all assistants\n */\n async getAllAssistants(): Promise<Assistant[]> {\n await this.ensureInitialized();\n\n const result = await this.pool.query<{\n id: string;\n name: string;\n description: string | null;\n graph_definition: any;\n created_at: Date;\n updated_at: Date;\n }>(\n `\n SELECT id, name, description, graph_definition, created_at, updated_at\n FROM lattice_assistants\n ORDER BY created_at DESC\n `\n );\n\n return result.rows.map(this.mapRowToAssistant);\n }\n\n /**\n * Get assistant by ID\n */\n async getAssistantById(id: string): Promise<Assistant | null> {\n await this.ensureInitialized();\n\n const result = await this.pool.query<{\n id: string;\n name: string;\n description: string | null;\n graph_definition: any;\n created_at: Date;\n updated_at: Date;\n }>(\n `\n SELECT id, name, description, graph_definition, created_at, updated_at\n FROM lattice_assistants\n WHERE id = $1\n `,\n [id]\n );\n\n if (result.rows.length === 0) {\n return null;\n }\n\n return this.mapRowToAssistant(result.rows[0]);\n }\n\n /**\n * Create a new assistant\n */\n async createAssistant(\n id: string,\n data: CreateAssistantRequest\n ): Promise<Assistant> {\n await this.ensureInitialized();\n\n const now = new Date();\n\n await this.pool.query(\n `\n INSERT INTO lattice_assistants (id, name, description, graph_definition, created_at, updated_at)\n VALUES ($1, $2, $3, $4, $5, $6)\n ON CONFLICT (id) DO UPDATE SET\n name = EXCLUDED.name,\n description = EXCLUDED.description,\n graph_definition = EXCLUDED.graph_definition,\n updated_at = EXCLUDED.updated_at\n `,\n [\n id,\n data.name,\n data.description || null,\n JSON.stringify(data.graphDefinition),\n now,\n now,\n ]\n );\n\n return {\n id,\n name: data.name,\n description: data.description,\n graphDefinition: data.graphDefinition,\n createdAt: now,\n updatedAt: now,\n };\n }\n\n /**\n * Update an existing assistant\n */\n async updateAssistant(\n id: string,\n updates: Partial<CreateAssistantRequest>\n ): Promise<Assistant | null> {\n await this.ensureInitialized();\n\n // Get existing assistant\n const existing = await this.getAssistantById(id);\n if (!existing) {\n return null;\n }\n\n // Build update query dynamically based on provided fields\n const updateFields: string[] = [];\n const updateValues: any[] = [];\n let paramIndex = 1;\n\n if (updates.name !== undefined) {\n updateFields.push(`name = $${paramIndex++}`);\n updateValues.push(updates.name);\n }\n\n if (updates.description !== undefined) {\n updateFields.push(`description = $${paramIndex++}`);\n updateValues.push(updates.description || null);\n }\n\n if (updates.graphDefinition !== undefined) {\n updateFields.push(`graph_definition = $${paramIndex++}`);\n updateValues.push(JSON.stringify(updates.graphDefinition));\n }\n\n if (updateFields.length === 0) {\n // No fields to update\n return existing;\n }\n\n // Always update updated_at\n updateFields.push(`updated_at = $${paramIndex++}`);\n updateValues.push(new Date());\n\n // Add id for WHERE clause\n updateValues.push(id);\n\n await this.pool.query(\n `\n UPDATE lattice_assistants\n SET ${updateFields.join(\", \")}\n WHERE id = $${paramIndex}\n `,\n updateValues\n );\n\n // Return updated assistant\n return await this.getAssistantById(id);\n }\n\n /**\n * Delete an assistant by ID\n */\n async deleteAssistant(id: string): Promise<boolean> {\n await this.ensureInitialized();\n\n const result = await this.pool.query(\n `\n DELETE FROM lattice_assistants\n WHERE id = $1\n `,\n [id]\n );\n\n return result.rowCount !== null && result.rowCount > 0;\n }\n\n /**\n * Check if assistant exists\n */\n async hasAssistant(id: string): Promise<boolean> {\n await this.ensureInitialized();\n\n const result = await this.pool.query(\n `\n SELECT 1 FROM lattice_assistants\n WHERE id = $1\n LIMIT 1\n `,\n [id]\n );\n\n return result.rows.length > 0;\n }\n\n /**\n * Dispose resources and close the connection pool\n * Should be called when the store is no longer needed\n */\n async dispose(): Promise<void> {\n if (this.ownsPool && this.pool) {\n await this.pool.end();\n }\n }\n\n /**\n * Ensure store is initialized\n */\n private async ensureInitialized(): Promise<void> {\n if (!this.initialized) {\n await this.initialize();\n }\n }\n\n /**\n * Map database row to Assistant object\n */\n private mapRowToAssistant(row: {\n id: string;\n name: string;\n description: string | null;\n graph_definition: any;\n created_at: Date;\n updated_at: Date;\n }): Assistant {\n return {\n id: row.id,\n name: row.name,\n description: row.description || undefined,\n graphDefinition:\n typeof row.graph_definition === \"string\"\n ? JSON.parse(row.graph_definition)\n : row.graph_definition,\n createdAt: row.created_at,\n updatedAt: row.updated_at,\n };\n }\n}\n","/**\n * Assistant table migrations\n */\n\nimport { PoolClient } from \"pg\";\nimport { Migration } from \"./migration\";\n\n/**\n * Initial migration: Create assistants table\n */\nexport const createAssistantsTable: Migration = {\n version: 1,\n name: \"create_assistants_table\",\n up: async (client: PoolClient) => {\n await client.query(`\n CREATE TABLE IF NOT EXISTS lattice_assistants (\n id VARCHAR(255) PRIMARY KEY,\n name VARCHAR(255) NOT NULL,\n description TEXT,\n graph_definition JSONB NOT NULL,\n created_at TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,\n updated_at TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP\n )\n `);\n\n // Create indexes for better query performance\n await client.query(`\n CREATE INDEX IF NOT EXISTS idx_lattice_assistants_name \n ON lattice_assistants(name)\n `);\n\n await client.query(`\n CREATE INDEX IF NOT EXISTS idx_lattice_assistants_created_at \n ON lattice_assistants(created_at DESC)\n `);\n },\n down: async (client: PoolClient) => {\n await client.query(\n \"DROP INDEX IF EXISTS idx_lattice_assistants_created_at\"\n );\n await client.query(\"DROP INDEX IF EXISTS idx_lattice_assistants_name\");\n await client.query(\"DROP TABLE IF EXISTS lattice_assistants\");\n },\n};\n","/**\n * PostgreSQL implementation of ScheduleStorage\n *\n * Provides persistent storage for scheduled tasks\n * Data survives service restarts\n */\n\nimport { Pool, PoolConfig } from \"pg\";\nimport {\n ScheduleStorage,\n ScheduledTaskDefinition,\n ScheduledTaskStatus,\n ScheduleExecutionType,\n} from \"@axiom-lattice/protocols\";\nimport { MigrationManager } from \"../migrations/migration\";\nimport { createScheduledTasksTable } from \"../migrations/schedule_migrations\";\n\n/**\n * PostgreSQL ScheduleStorage options\n */\nexport interface PostgreSQLScheduleStorageOptions {\n /**\n * PostgreSQL connection pool configuration\n * Can be a connection string or PoolConfig object\n */\n poolConfig: string | PoolConfig;\n\n /**\n * Whether to run migrations automatically on initialization\n * @default true\n */\n autoMigrate?: boolean;\n}\n\n/**\n * Database row type for scheduled tasks\n */\ninterface ScheduledTaskRow {\n task_id: string;\n task_type: string;\n payload: string | Record<string, any>;\n assistant_id: string | null;\n thread_id: string | null;\n execution_type: string;\n execute_at: Date | null;\n delay_ms: number | null;\n cron_expression: string | null;\n timezone: string | null;\n next_run_at: Date | null;\n last_run_at: Date | null;\n status: string;\n run_count: number;\n max_runs: number | null;\n retry_count: number;\n max_retries: number;\n last_error: string | null;\n created_at: Date;\n updated_at: Date;\n expires_at: Date | null;\n metadata: string | Record<string, any> | null;\n}\n\n/**\n * PostgreSQL implementation of ScheduleStorage\n */\nexport class PostgreSQLScheduleStorage implements ScheduleStorage {\n private pool: Pool;\n private migrationManager: MigrationManager;\n private initialized: boolean = false;\n\n constructor(options: PostgreSQLScheduleStorageOptions) {\n // Create Pool from config\n if (typeof options.poolConfig === \"string\") {\n this.pool = new Pool({ connectionString: options.poolConfig });\n } else {\n this.pool = new Pool(options.poolConfig);\n }\n\n this.migrationManager = new MigrationManager(this.pool);\n this.migrationManager.register(createScheduledTasksTable);\n\n // Auto-migrate by default\n if (options.autoMigrate !== false) {\n this.initialize().catch((error) => {\n console.error(\"Failed to initialize PostgreSQLScheduleStorage:\", error);\n throw error;\n });\n }\n }\n\n /**\n * Dispose resources and close the connection pool\n */\n async dispose(): Promise<void> {\n if (this.pool) {\n await this.pool.end();\n }\n }\n\n /**\n * Initialize the store and run migrations\n */\n async initialize(): Promise<void> {\n if (this.initialized) {\n return;\n }\n\n await this.migrationManager.migrate();\n this.initialized = true;\n }\n\n /**\n * Ensure store is initialized\n */\n private async ensureInitialized(): Promise<void> {\n if (!this.initialized) {\n await this.initialize();\n }\n }\n\n /**\n * Save a new task\n */\n async save(task: ScheduledTaskDefinition): Promise<void> {\n await this.ensureInitialized();\n\n await this.pool.query(\n `\n INSERT INTO lattice_scheduled_tasks (\n task_id, task_type, payload, assistant_id, thread_id, execution_type,\n execute_at, delay_ms, cron_expression, timezone,\n next_run_at, last_run_at, status, run_count, max_runs,\n retry_count, max_retries, last_error,\n created_at, updated_at, expires_at, metadata\n ) VALUES (\n $1, $2, $3, $4, $5, $6,\n $7, $8, $9, $10,\n $11, $12, $13, $14, $15,\n $16, $17, $18,\n $19, $20, $21, $22\n )\n ON CONFLICT (task_id) DO UPDATE SET\n task_type = EXCLUDED.task_type,\n payload = EXCLUDED.payload,\n assistant_id = EXCLUDED.assistant_id,\n thread_id = EXCLUDED.thread_id,\n execution_type = EXCLUDED.execution_type,\n execute_at = EXCLUDED.execute_at,\n delay_ms = EXCLUDED.delay_ms,\n cron_expression = EXCLUDED.cron_expression,\n timezone = EXCLUDED.timezone,\n next_run_at = EXCLUDED.next_run_at,\n last_run_at = EXCLUDED.last_run_at,\n status = EXCLUDED.status,\n run_count = EXCLUDED.run_count,\n max_runs = EXCLUDED.max_runs,\n retry_count = EXCLUDED.retry_count,\n max_retries = EXCLUDED.max_retries,\n last_error = EXCLUDED.last_error,\n updated_at = EXCLUDED.updated_at,\n expires_at = EXCLUDED.expires_at,\n metadata = EXCLUDED.metadata\n `,\n [\n task.taskId,\n task.taskType,\n JSON.stringify(task.payload),\n task.assistantId ?? null,\n task.threadId ?? null,\n task.executionType,\n task.executeAt ? new Date(task.executeAt) : null,\n task.delayMs ?? null,\n task.cronExpression ?? null,\n task.timezone ?? null,\n task.nextRunAt ? new Date(task.nextRunAt) : null,\n task.lastRunAt ? new Date(task.lastRunAt) : null,\n task.status,\n task.runCount,\n task.maxRuns ?? null,\n task.retryCount,\n task.maxRetries,\n task.lastError ?? null,\n new Date(task.createdAt),\n new Date(task.updatedAt),\n task.expiresAt ? new Date(task.expiresAt) : null,\n task.metadata ? JSON.stringify(task.metadata) : null,\n ]\n );\n }\n\n /**\n * Get task by ID\n */\n async get(taskId: string): Promise<ScheduledTaskDefinition | null> {\n await this.ensureInitialized();\n\n const result = await this.pool.query<ScheduledTaskRow>(\n `SELECT * FROM lattice_scheduled_tasks WHERE task_id = $1`,\n [taskId]\n );\n\n if (result.rows.length === 0) {\n return null;\n }\n\n return this.mapRowToTask(result.rows[0]);\n }\n\n /**\n * Update task\n */\n async update(\n taskId: string,\n updates: Partial<ScheduledTaskDefinition>\n ): Promise<void> {\n await this.ensureInitialized();\n\n const setClauses: string[] = [];\n const values: any[] = [];\n let paramIndex = 1;\n\n // Build dynamic UPDATE query\n if (updates.taskType !== undefined) {\n setClauses.push(`task_type = $${paramIndex++}`);\n values.push(updates.taskType);\n }\n if (updates.payload !== undefined) {\n setClauses.push(`payload = $${paramIndex++}`);\n values.push(JSON.stringify(updates.payload));\n }\n if (updates.assistantId !== undefined) {\n setClauses.push(`assistant_id = $${paramIndex++}`);\n values.push(updates.assistantId);\n }\n if (updates.threadId !== undefined) {\n setClauses.push(`thread_id = $${paramIndex++}`);\n values.push(updates.threadId);\n }\n if (updates.executionType !== undefined) {\n setClauses.push(`execution_type = $${paramIndex++}`);\n values.push(updates.executionType);\n }\n if (updates.executeAt !== undefined) {\n setClauses.push(`execute_at = $${paramIndex++}`);\n values.push(updates.executeAt ? new Date(updates.executeAt) : null);\n }\n if (updates.delayMs !== undefined) {\n setClauses.push(`delay_ms = $${paramIndex++}`);\n values.push(updates.delayMs);\n }\n if (updates.cronExpression !== undefined) {\n setClauses.push(`cron_expression = $${paramIndex++}`);\n values.push(updates.cronExpression);\n }\n if (updates.timezone !== undefined) {\n setClauses.push(`timezone = $${paramIndex++}`);\n values.push(updates.timezone);\n }\n if (updates.nextRunAt !== undefined) {\n setClauses.push(`next_run_at = $${paramIndex++}`);\n values.push(updates.nextRunAt ? new Date(updates.nextRunAt) : null);\n }\n if (updates.lastRunAt !== undefined) {\n setClauses.push(`last_run_at = $${paramIndex++}`);\n values.push(updates.lastRunAt ? new Date(updates.lastRunAt) : null);\n }\n if (updates.status !== undefined) {\n setClauses.push(`status = $${paramIndex++}`);\n values.push(updates.status);\n }\n if (updates.runCount !== undefined) {\n setClauses.push(`run_count = $${paramIndex++}`);\n values.push(updates.runCount);\n }\n if (updates.maxRuns !== undefined) {\n setClauses.push(`max_runs = $${paramIndex++}`);\n values.push(updates.maxRuns);\n }\n if (updates.retryCount !== undefined) {\n setClauses.push(`retry_count = $${paramIndex++}`);\n values.push(updates.retryCount);\n }\n if (updates.maxRetries !== undefined) {\n setClauses.push(`max_retries = $${paramIndex++}`);\n values.push(updates.maxRetries);\n }\n if (updates.lastError !== undefined) {\n setClauses.push(`last_error = $${paramIndex++}`);\n values.push(updates.lastError);\n }\n if (updates.expiresAt !== undefined) {\n setClauses.push(`expires_at = $${paramIndex++}`);\n values.push(updates.expiresAt ? new Date(updates.expiresAt) : null);\n }\n if (updates.metadata !== undefined) {\n setClauses.push(`metadata = $${paramIndex++}`);\n values.push(updates.metadata ? JSON.stringify(updates.metadata) : null);\n }\n\n // Always update updated_at\n setClauses.push(`updated_at = $${paramIndex++}`);\n values.push(new Date());\n\n // Add taskId as the last parameter\n values.push(taskId);\n\n if (setClauses.length === 0) {\n return;\n }\n\n await this.pool.query(\n `UPDATE lattice_scheduled_tasks SET ${setClauses.join(\n \", \"\n )} WHERE task_id = $${paramIndex}`,\n values\n );\n }\n\n /**\n * Delete task\n */\n async delete(taskId: string): Promise<void> {\n await this.ensureInitialized();\n\n await this.pool.query(\n `DELETE FROM lattice_scheduled_tasks WHERE task_id = $1`,\n [taskId]\n );\n }\n\n /**\n * Get all active tasks (pending or paused)\n */\n async getActiveTasks(): Promise<ScheduledTaskDefinition[]> {\n await this.ensureInitialized();\n\n const result = await this.pool.query<ScheduledTaskRow>(\n `SELECT * FROM lattice_scheduled_tasks WHERE status IN ($1, $2) ORDER BY created_at ASC`,\n [ScheduledTaskStatus.PENDING, ScheduledTaskStatus.PAUSED]\n );\n\n return result.rows.map((row) => this.mapRowToTask(row));\n }\n\n /**\n * Get tasks by type\n */\n async getTasksByType(taskType: string): Promise<ScheduledTaskDefinition[]> {\n await this.ensureInitialized();\n\n const result = await this.pool.query<ScheduledTaskRow>(\n `SELECT * FROM lattice_scheduled_tasks WHERE task_type = $1 ORDER BY created_at DESC`,\n [taskType]\n );\n\n return result.rows.map((row) => this.mapRowToTask(row));\n }\n\n /**\n * Get tasks by status\n */\n async getTasksByStatus(\n status: ScheduledTaskStatus\n ): Promise<ScheduledTaskDefinition[]> {\n await this.ensureInitialized();\n\n const result = await this.pool.query<ScheduledTaskRow>(\n `SELECT * FROM lattice_scheduled_tasks WHERE status = $1 ORDER BY created_at DESC`,\n [status]\n );\n\n return result.rows.map((row) => this.mapRowToTask(row));\n }\n\n /**\n * Get tasks by execution type\n */\n async getTasksByExecutionType(\n executionType: ScheduleExecutionType\n ): Promise<ScheduledTaskDefinition[]> {\n await this.ensureInitialized();\n\n const result = await this.pool.query<ScheduledTaskRow>(\n `SELECT * FROM lattice_scheduled_tasks WHERE execution_type = $1 ORDER BY created_at DESC`,\n [executionType]\n );\n\n return result.rows.map((row) => this.mapRowToTask(row));\n }\n\n /**\n * Get tasks by assistant ID\n */\n async getTasksByAssistantId(\n assistantId: string\n ): Promise<ScheduledTaskDefinition[]> {\n await this.ensureInitialized();\n\n const result = await this.pool.query<ScheduledTaskRow>(\n `SELECT * FROM lattice_scheduled_tasks WHERE assistant_id = $1 ORDER BY created_at DESC`,\n [assistantId]\n );\n\n return result.rows.map((row) => this.mapRowToTask(row));\n }\n\n /**\n * Get tasks by thread ID\n */\n async getTasksByThreadId(\n threadId: string\n ): Promise<ScheduledTaskDefinition[]> {\n await this.ensureInitialized();\n\n const result = await this.pool.query<ScheduledTaskRow>(\n `SELECT * FROM lattice_scheduled_tasks WHERE thread_id = $1 ORDER BY created_at DESC`,\n [threadId]\n );\n\n return result.rows.map((row) => this.mapRowToTask(row));\n }\n\n /**\n * Get all tasks with optional filters\n */\n async getAllTasks(filters?: {\n status?: ScheduledTaskStatus;\n executionType?: ScheduleExecutionType;\n taskType?: string;\n assistantId?: string;\n threadId?: string;\n limit?: number;\n offset?: number;\n }): Promise<ScheduledTaskDefinition[]> {\n await this.ensureInitialized();\n\n const whereClauses: string[] = [];\n const values: any[] = [];\n let paramIndex = 1;\n\n if (filters?.status !== undefined) {\n whereClauses.push(`status = $${paramIndex++}`);\n values.push(filters.status);\n }\n if (filters?.executionType !== undefined) {\n whereClauses.push(`execution_type = $${paramIndex++}`);\n values.push(filters.executionType);\n }\n if (filters?.taskType !== undefined) {\n whereClauses.push(`task_type = $${paramIndex++}`);\n values.push(filters.taskType);\n }\n if (filters?.assistantId !== undefined) {\n whereClauses.push(`assistant_id = $${paramIndex++}`);\n values.push(filters.assistantId);\n }\n if (filters?.threadId !== undefined) {\n whereClauses.push(`thread_id = $${paramIndex++}`);\n values.push(filters.threadId);\n }\n\n let query = `SELECT * FROM lattice_scheduled_tasks`;\n if (whereClauses.length > 0) {\n query += ` WHERE ${whereClauses.join(\" AND \")}`;\n }\n query += ` ORDER BY created_at DESC`;\n\n if (filters?.limit !== undefined) {\n query += ` LIMIT $${paramIndex++}`;\n values.push(filters.limit);\n }\n if (filters?.offset !== undefined) {\n query += ` OFFSET $${paramIndex++}`;\n values.push(filters.offset);\n }\n\n const result = await this.pool.query<ScheduledTaskRow>(query, values);\n\n return result.rows.map((row) => this.mapRowToTask(row));\n }\n\n /**\n * Count tasks with optional filters\n */\n async countTasks(filters?: {\n status?: ScheduledTaskStatus;\n executionType?: ScheduleExecutionType;\n taskType?: string;\n assistantId?: string;\n threadId?: string;\n }): Promise<number> {\n await this.ensureInitialized();\n\n const whereClauses: string[] = [];\n const values: any[] = [];\n let paramIndex = 1;\n\n if (filters?.status !== undefined) {\n whereClauses.push(`status = $${paramIndex++}`);\n values.push(filters.status);\n }\n if (filters?.executionType !== undefined) {\n whereClauses.push(`execution_type = $${paramIndex++}`);\n values.push(filters.executionType);\n }\n if (filters?.taskType !== undefined) {\n whereClauses.push(`task_type = $${paramIndex++}`);\n values.push(filters.taskType);\n }\n if (filters?.assistantId !== undefined) {\n whereClauses.push(`assistant_id = $${paramIndex++}`);\n values.push(filters.assistantId);\n }\n if (filters?.threadId !== undefined) {\n whereClauses.push(`thread_id = $${paramIndex++}`);\n values.push(filters.threadId);\n }\n\n let query = `SELECT COUNT(*) as count FROM lattice_scheduled_tasks`;\n if (whereClauses.length > 0) {\n query += ` WHERE ${whereClauses.join(\" AND \")}`;\n }\n\n const result = await this.pool.query<{ count: string }>(query, values);\n\n return parseInt(result.rows[0].count, 10);\n }\n\n /**\n * Delete completed/cancelled/failed tasks older than specified time\n */\n async deleteOldTasks(olderThanMs: number): Promise<number> {\n await this.ensureInitialized();\n\n const cutoff = new Date(Date.now() - olderThanMs);\n\n const result = await this.pool.query(\n `\n DELETE FROM lattice_scheduled_tasks \n WHERE status IN ($1, $2, $3) \n AND updated_at < $4\n `,\n [\n ScheduledTaskStatus.COMPLETED,\n ScheduledTaskStatus.CANCELLED,\n ScheduledTaskStatus.FAILED,\n cutoff,\n ]\n );\n\n return result.rowCount ?? 0;\n }\n\n /**\n * Map database row to ScheduledTaskDefinition\n */\n private mapRowToTask(row: ScheduledTaskRow): ScheduledTaskDefinition {\n return {\n taskId: row.task_id,\n taskType: row.task_type,\n payload:\n typeof row.payload === \"string\"\n ? JSON.parse(row.payload)\n : row.payload || {},\n assistantId: row.assistant_id ?? undefined,\n threadId: row.thread_id ?? undefined,\n executionType: row.execution_type as ScheduleExecutionType,\n executeAt: row.execute_at ? row.execute_at.getTime() : undefined,\n delayMs: row.delay_ms ?? undefined,\n cronExpression: row.cron_expression ?? undefined,\n timezone: row.timezone ?? undefined,\n nextRunAt: row.next_run_at ? row.next_run_at.getTime() : undefined,\n lastRunAt: row.last_run_at ? row.last_run_at.getTime() : undefined,\n status: row.status as ScheduledTaskStatus,\n runCount: row.run_count,\n maxRuns: row.max_runs ?? undefined,\n retryCount: row.retry_count,\n maxRetries: row.max_retries,\n lastError: row.last_error ?? undefined,\n createdAt: row.created_at.getTime(),\n updatedAt: row.updated_at.getTime(),\n expiresAt: row.expires_at ? row.expires_at.getTime() : undefined,\n metadata:\n row.metadata === null\n ? undefined\n : typeof row.metadata === \"string\"\n ? JSON.parse(row.metadata)\n : row.metadata,\n };\n }\n}\n","/**\n * PostgreSQL migrations for scheduled tasks table\n */\n\nimport { Migration } from \"./migration\";\n\n/**\n * Create the scheduled_tasks table\n */\nexport const createScheduledTasksTable: Migration = {\n name: \"create_scheduled_tasks_table\",\n version: 2,\n\n up: async (client) => {\n await client.query(`\n CREATE TABLE IF NOT EXISTS lattice_scheduled_tasks (\n -- Primary key\n task_id VARCHAR(255) PRIMARY KEY,\n \n -- Task type (maps to handler)\n task_type VARCHAR(255) NOT NULL,\n \n -- Payload (JSON-serializable data)\n payload JSONB NOT NULL DEFAULT '{}',\n \n -- Context fields for querying\n assistant_id VARCHAR(255),\n thread_id VARCHAR(255),\n \n -- Execution type: 'once' or 'cron'\n execution_type VARCHAR(50) NOT NULL,\n \n -- For ONCE type\n execute_at TIMESTAMPTZ,\n delay_ms BIGINT,\n \n -- For CRON type\n cron_expression VARCHAR(255),\n timezone VARCHAR(100),\n next_run_at TIMESTAMPTZ,\n last_run_at TIMESTAMPTZ,\n \n -- Status\n status VARCHAR(50) NOT NULL DEFAULT 'pending',\n \n -- Execution tracking\n run_count INTEGER NOT NULL DEFAULT 0,\n max_runs INTEGER,\n \n -- Error handling\n retry_count INTEGER NOT NULL DEFAULT 0,\n max_retries INTEGER NOT NULL DEFAULT 0,\n last_error TEXT,\n \n -- Timestamps\n created_at TIMESTAMPTZ NOT NULL DEFAULT NOW(),\n updated_at TIMESTAMPTZ NOT NULL DEFAULT NOW(),\n expires_at TIMESTAMPTZ,\n \n -- Metadata\n metadata JSONB\n );\n\n -- Index for querying active tasks\n CREATE INDEX IF NOT EXISTS idx_scheduled_tasks_status \n ON lattice_scheduled_tasks (status);\n \n -- Index for querying by task type\n CREATE INDEX IF NOT EXISTS idx_scheduled_tasks_task_type \n ON lattice_scheduled_tasks (task_type);\n \n -- Index for querying by execution type\n CREATE INDEX IF NOT EXISTS idx_scheduled_tasks_execution_type \n ON lattice_scheduled_tasks (execution_type);\n \n -- Index for querying by assistant ID\n CREATE INDEX IF NOT EXISTS idx_scheduled_tasks_assistant_id \n ON lattice_scheduled_tasks (assistant_id)\n WHERE assistant_id IS NOT NULL;\n \n -- Index for querying by thread ID\n CREATE INDEX IF NOT EXISTS idx_scheduled_tasks_thread_id \n ON lattice_scheduled_tasks (thread_id)\n WHERE thread_id IS NOT NULL;\n \n -- Index for querying pending tasks by next run time\n CREATE INDEX IF NOT EXISTS idx_scheduled_tasks_next_run \n ON lattice_scheduled_tasks (next_run_at) \n WHERE status = 'pending';\n \n -- Index for querying pending one-time tasks by execute time\n CREATE INDEX IF NOT EXISTS idx_scheduled_tasks_execute_at \n ON lattice_scheduled_tasks (execute_at) \n WHERE status = 'pending' AND execution_type = 'once';\n \n -- Index for cleanup queries (old completed/cancelled tasks)\n CREATE INDEX IF NOT EXISTS idx_scheduled_tasks_cleanup \n ON lattice_scheduled_tasks (updated_at) \n WHERE status IN ('completed', 'cancelled', 'failed');\n `);\n },\n\n down: async (client) => {\n await client.query(`\n DROP INDEX IF EXISTS idx_scheduled_tasks_cleanup;\n DROP INDEX IF EXISTS idx_scheduled_tasks_execute_at;\n DROP INDEX IF EXISTS idx_scheduled_tasks_next_run;\n DROP INDEX IF EXISTS idx_scheduled_tasks_thread_id;\n DROP INDEX IF EXISTS idx_scheduled_tasks_assistant_id;\n DROP INDEX IF EXISTS idx_scheduled_tasks_execution_type;\n DROP INDEX IF EXISTS idx_scheduled_tasks_task_type;\n DROP INDEX IF EXISTS idx_scheduled_tasks_status;\n DROP TABLE IF EXISTS lattice_scheduled_tasks;\n `);\n },\n};\n"],"mappings":"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","names":["import_pg","import_pg"]}
1
+ {"version":3,"sources":["../src/index.ts","../src/stores/PostgreSQLThreadStore.ts","../src/migrations/migration.ts","../src/migrations/thread_migrations.ts","../src/stores/PostgreSQLAssistantStore.ts","../src/migrations/assistant_migrations.ts","../src/stores/PostgreSQLScheduleStorage.ts","../src/migrations/schedule_migrations.ts","../src/stores/PostgreSQLSkillStore.ts","../src/migrations/skill_migrations.ts"],"sourcesContent":["/**\n * PostgreSQL Stores Package\n *\n * Provides PostgreSQL implementations for various stores\n */\n\nexport * from \"./stores/PostgreSQLThreadStore\";\nexport * from \"./stores/PostgreSQLAssistantStore\";\nexport * from \"./stores/PostgreSQLScheduleStorage\";\nexport * from \"./stores/PostgreSQLSkillStore\";\nexport * from \"./migrations/migration\";\nexport * from \"./migrations/thread_migrations\";\nexport * from \"./migrations/assistant_migrations\";\nexport * from \"./migrations/schedule_migrations\";\nexport * from \"./migrations/skill_migrations\";\n\n// Re-export for convenience\nexport { PostgreSQLThreadStore } from \"./stores/PostgreSQLThreadStore\";\nexport { PostgreSQLAssistantStore } from \"./stores/PostgreSQLAssistantStore\";\nexport { PostgreSQLScheduleStorage } from \"./stores/PostgreSQLScheduleStorage\";\nexport { PostgreSQLSkillStore } from \"./stores/PostgreSQLSkillStore\";\n\n// Re-export types from protocols\nexport type {\n ThreadStore,\n Thread,\n CreateThreadRequest,\n AssistantStore,\n Assistant,\n CreateAssistantRequest,\n ScheduleStorage,\n ScheduledTaskDefinition,\n ScheduledTaskStatus,\n ScheduleExecutionType,\n SkillStore,\n Skill,\n CreateSkillRequest,\n} from \"@axiom-lattice/protocols\";\n","/**\n * PostgreSQL implementation of ThreadStore\n */\n\nimport { Pool, PoolClient, PoolConfig } from \"pg\";\nimport {\n ThreadStore,\n Thread,\n CreateThreadRequest,\n} from \"@axiom-lattice/protocols\";\nimport { MigrationManager } from \"../migrations/migration\";\nimport { createThreadsTable } from \"../migrations/thread_migrations\";\n\n/**\n * PostgreSQL ThreadStore options\n */\nexport interface PostgreSQLThreadStoreOptions {\n /**\n * PostgreSQL connection pool configuration\n * Can be a connection string or PoolConfig object\n */\n poolConfig: string | PoolConfig;\n\n /**\n * Whether to run migrations automatically on initialization\n * @default true\n */\n autoMigrate?: boolean;\n}\n\n/**\n * PostgreSQL implementation of ThreadStore\n */\nexport class PostgreSQLThreadStore implements ThreadStore {\n private pool: Pool;\n private migrationManager: MigrationManager;\n private initialized: boolean = false;\n private ownsPool: boolean = true;\n\n constructor(options: PostgreSQLThreadStoreOptions) {\n // Create Pool from config\n if (typeof options.poolConfig === \"string\") {\n this.pool = new Pool({ connectionString: options.poolConfig });\n } else {\n this.pool = new Pool(options.poolConfig);\n }\n\n this.migrationManager = new MigrationManager(this.pool);\n this.migrationManager.register(createThreadsTable);\n\n // Auto-migrate by default\n if (options.autoMigrate !== false) {\n this.initialize().catch((error) => {\n console.error(\"Failed to initialize PostgreSQLThreadStore:\", error);\n throw error;\n });\n }\n }\n\n /**\n * Dispose resources and close the connection pool\n * Should be called when the store is no longer needed\n */\n async dispose(): Promise<void> {\n if (this.ownsPool && this.pool) {\n await this.pool.end();\n }\n }\n\n /**\n * Initialize the store and run migrations\n */\n async initialize(): Promise<void> {\n if (this.initialized) {\n return;\n }\n\n await this.migrationManager.migrate();\n this.initialized = true;\n }\n\n /**\n * Get all threads for a specific assistant\n */\n async getThreadsByAssistantId(assistantId: string): Promise<Thread[]> {\n await this.ensureInitialized();\n\n const result = await this.pool.query<{\n id: string;\n assistant_id: string;\n metadata: any;\n created_at: Date;\n updated_at: Date;\n }>(\n `\n SELECT id, assistant_id, metadata, created_at, updated_at\n FROM lattice_threads\n WHERE assistant_id = $1\n ORDER BY created_at DESC\n `,\n [assistantId]\n );\n\n return result.rows.map(this.mapRowToThread);\n }\n\n /**\n * Get a thread by ID for a specific assistant\n */\n async getThreadById(\n assistantId: string,\n threadId: string\n ): Promise<Thread | undefined> {\n await this.ensureInitialized();\n\n const result = await this.pool.query<{\n id: string;\n assistant_id: string;\n metadata: any;\n created_at: Date;\n updated_at: Date;\n }>(\n `\n SELECT id, assistant_id, metadata, created_at, updated_at\n FROM lattice_threads\n WHERE id = $1 AND assistant_id = $2\n `,\n [threadId, assistantId]\n );\n\n if (result.rows.length === 0) {\n return undefined;\n }\n\n return this.mapRowToThread(result.rows[0]);\n }\n\n /**\n * Create a new thread for an assistant\n */\n async createThread(\n assistantId: string,\n threadId: string,\n data: CreateThreadRequest\n ): Promise<Thread> {\n await this.ensureInitialized();\n\n const now = new Date();\n const metadata = data.metadata || {};\n\n await this.pool.query(\n `\n INSERT INTO lattice_threads (id, assistant_id, metadata, created_at, updated_at)\n VALUES ($1, $2, $3, $4, $5)\n ON CONFLICT (id, assistant_id) DO UPDATE SET\n metadata = EXCLUDED.metadata,\n updated_at = EXCLUDED.updated_at\n `,\n [threadId, assistantId, JSON.stringify(metadata), now, now]\n );\n\n return {\n id: threadId,\n assistantId,\n metadata,\n createdAt: now,\n updatedAt: now,\n };\n }\n\n /**\n * Update an existing thread\n */\n async updateThread(\n assistantId: string,\n threadId: string,\n updates: Partial<CreateThreadRequest>\n ): Promise<Thread | null> {\n await this.ensureInitialized();\n\n // Get existing thread\n const existing = await this.getThreadById(assistantId, threadId);\n if (!existing) {\n return null;\n }\n\n // Merge metadata\n const updatedMetadata = {\n ...existing.metadata,\n ...(updates.metadata || {}),\n };\n\n const now = new Date();\n\n await this.pool.query(\n `\n UPDATE lattice_threads\n SET metadata = $1, updated_at = $2\n WHERE id = $3 AND assistant_id = $4\n `,\n [JSON.stringify(updatedMetadata), now, threadId, assistantId]\n );\n\n return {\n ...existing,\n metadata: updatedMetadata,\n updatedAt: now,\n };\n }\n\n /**\n * Delete a thread by ID\n */\n async deleteThread(assistantId: string, threadId: string): Promise<boolean> {\n await this.ensureInitialized();\n\n const result = await this.pool.query(\n `\n DELETE FROM lattice_threads\n WHERE id = $1 AND assistant_id = $2\n `,\n [threadId, assistantId]\n );\n\n return result.rowCount !== null && result.rowCount > 0;\n }\n\n /**\n * Check if thread exists\n */\n async hasThread(assistantId: string, threadId: string): Promise<boolean> {\n await this.ensureInitialized();\n\n const result = await this.pool.query(\n `\n SELECT 1 FROM lattice_threads\n WHERE id = $1 AND assistant_id = $2\n LIMIT 1\n `,\n [threadId, assistantId]\n );\n\n return result.rows.length > 0;\n }\n\n /**\n * Ensure store is initialized\n */\n private async ensureInitialized(): Promise<void> {\n if (!this.initialized) {\n await this.initialize();\n }\n }\n\n /**\n * Map database row to Thread object\n */\n private mapRowToThread(row: {\n id: string;\n assistant_id: string;\n metadata: any;\n created_at: Date;\n updated_at: Date;\n }): Thread {\n return {\n id: row.id,\n assistantId: row.assistant_id,\n metadata:\n typeof row.metadata === \"string\"\n ? JSON.parse(row.metadata)\n : row.metadata || {},\n createdAt: row.created_at,\n updatedAt: row.updated_at,\n };\n }\n}\n","/**\n * Migration system for database schema management\n */\n\nimport { Pool, PoolClient } from \"pg\";\n\n/**\n * Migration record stored in database\n */\ninterface MigrationRecord {\n version: number;\n name: string;\n applied_at: Date;\n}\n\n/**\n * Migration definition\n */\nexport interface Migration {\n version: number;\n name: string;\n up: (client: PoolClient) => Promise<void>;\n down?: (client: PoolClient) => Promise<void>;\n}\n\n/**\n * Migration manager\n */\nexport class MigrationManager {\n private pool: Pool;\n private migrations: Migration[] = [];\n\n constructor(pool: Pool) {\n this.pool = pool;\n }\n\n /**\n * Register a migration\n */\n register(migration: Migration): void {\n this.migrations.push(migration);\n // Sort migrations by version\n this.migrations.sort((a, b) => a.version - b.version);\n }\n\n /**\n * Initialize migrations table if it doesn't exist\n */\n private async ensureMigrationsTable(client: PoolClient): Promise<void> {\n await client.query(`\n CREATE TABLE IF NOT EXISTS lattice_schema_migrations (\n version INTEGER PRIMARY KEY,\n name VARCHAR(255) NOT NULL,\n applied_at TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP\n )\n `);\n }\n\n /**\n * Get applied migrations from database\n */\n private async getAppliedMigrations(\n client: PoolClient\n ): Promise<MigrationRecord[]> {\n await client.query(`\n CREATE TABLE IF NOT EXISTS lattice_schema_migrations (\n version INTEGER PRIMARY KEY,\n name VARCHAR(255) NOT NULL,\n applied_at TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP\n )\n `);\n\n const result = await client.query<MigrationRecord>(\n \"SELECT version, name, applied_at FROM lattice_schema_migrations ORDER BY version\"\n );\n return result.rows;\n }\n\n /**\n * Apply pending migrations\n */\n async migrate(): Promise<void> {\n const client = await this.pool.connect();\n try {\n await client.query(\"BEGIN\");\n\n await this.ensureMigrationsTable(client);\n const appliedMigrations = await this.getAppliedMigrations(client);\n const appliedVersions = new Set(appliedMigrations.map((m) => m.version));\n\n // Find pending migrations\n const pendingMigrations = this.migrations.filter(\n (m) => !appliedVersions.has(m.version)\n );\n\n if (pendingMigrations.length === 0) {\n console.log(\"No pending migrations\");\n await client.query(\"COMMIT\");\n return;\n }\n\n // Apply pending migrations\n for (const migration of pendingMigrations) {\n console.log(\n `Applying migration ${migration.version}: ${migration.name}`\n );\n await migration.up(client);\n await client.query(\n \"INSERT INTO lattice_schema_migrations (version, name) VALUES ($1, $2)\",\n [migration.version, migration.name]\n );\n }\n\n await client.query(\"COMMIT\");\n console.log(`Applied ${pendingMigrations.length} migration(s)`);\n } catch (error) {\n await client.query(\"ROLLBACK\");\n throw error;\n } finally {\n client.release();\n }\n }\n\n /**\n * Rollback last migration\n */\n async rollback(): Promise<void> {\n const client = await this.pool.connect();\n try {\n await client.query(\"BEGIN\");\n\n const appliedMigrations = await this.getAppliedMigrations(client);\n if (appliedMigrations.length === 0) {\n console.log(\"No migrations to rollback\");\n await client.query(\"COMMIT\");\n return;\n }\n\n const lastMigration = appliedMigrations[appliedMigrations.length - 1];\n const migration = this.migrations.find(\n (m) => m.version === lastMigration.version\n );\n\n if (!migration || !migration.down) {\n throw new Error(\n `Migration ${lastMigration.version} does not have a down migration`\n );\n }\n\n console.log(\n `Rolling back migration ${lastMigration.version}: ${lastMigration.name}`\n );\n await migration.down(client);\n await client.query(\n \"DELETE FROM lattice_schema_migrations WHERE version = $1\",\n [lastMigration.version]\n );\n\n await client.query(\"COMMIT\");\n console.log(\"Rollback completed\");\n } catch (error) {\n await client.query(\"ROLLBACK\");\n throw error;\n } finally {\n client.release();\n }\n }\n\n /**\n * Get current migration version\n */\n async getCurrentVersion(): Promise<number> {\n const client = await this.pool.connect();\n try {\n const appliedMigrations = await this.getAppliedMigrations(client);\n if (appliedMigrations.length === 0) {\n return 0;\n }\n return Math.max(...appliedMigrations.map((m) => m.version));\n } finally {\n client.release();\n }\n }\n}\n","/**\n * Thread table migrations\n */\n\nimport { PoolClient } from \"pg\";\nimport { Migration } from \"./migration\";\n\n/**\n * Initial migration: Create threads table\n */\nexport const createThreadsTable: Migration = {\n version: 1,\n name: \"create_threads_table\",\n up: async (client: PoolClient) => {\n await client.query(`\n CREATE TABLE IF NOT EXISTS lattice_threads (\n id VARCHAR(255) NOT NULL,\n assistant_id VARCHAR(255) NOT NULL,\n metadata JSONB DEFAULT '{}',\n created_at TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,\n updated_at TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,\n PRIMARY KEY (id, assistant_id)\n )\n `);\n\n // Create indexes for better query performance\n await client.query(`\n CREATE INDEX IF NOT EXISTS idx_lattice_threads_assistant_id \n ON lattice_threads(assistant_id)\n `);\n\n await client.query(`\n CREATE INDEX IF NOT EXISTS idx_lattice_threads_created_at \n ON lattice_threads(created_at DESC)\n `);\n },\n down: async (client: PoolClient) => {\n await client.query(\"DROP INDEX IF EXISTS idx_lattice_threads_created_at\");\n await client.query(\"DROP INDEX IF EXISTS idx_lattice_threads_assistant_id\");\n await client.query(\"DROP TABLE IF EXISTS lattice_threads\");\n },\n};\n","/**\n * PostgreSQL implementation of AssistantStore\n */\n\nimport { Pool, PoolClient, PoolConfig } from \"pg\";\nimport {\n AssistantStore,\n Assistant,\n CreateAssistantRequest,\n} from \"@axiom-lattice/protocols\";\nimport { MigrationManager } from \"../migrations/migration\";\nimport { createAssistantsTable } from \"../migrations/assistant_migrations\";\n\n/**\n * PostgreSQL AssistantStore options\n */\nexport interface PostgreSQLAssistantStoreOptions {\n /**\n * PostgreSQL connection pool configuration\n * Can be a connection string or PoolConfig object\n */\n poolConfig: string | PoolConfig;\n\n /**\n * Whether to run migrations automatically on initialization\n * @default true\n */\n autoMigrate?: boolean;\n}\n\n/**\n * PostgreSQL implementation of AssistantStore\n */\nexport class PostgreSQLAssistantStore implements AssistantStore {\n private pool: Pool;\n private migrationManager: MigrationManager;\n private initialized: boolean = false;\n private ownsPool: boolean = true;\n\n constructor(options: PostgreSQLAssistantStoreOptions) {\n // Create Pool from config\n if (typeof options.poolConfig === \"string\") {\n this.pool = new Pool({ connectionString: options.poolConfig });\n } else {\n this.pool = new Pool(options.poolConfig);\n }\n\n this.migrationManager = new MigrationManager(this.pool);\n this.migrationManager.register(createAssistantsTable);\n\n // Auto-migrate by default\n if (options.autoMigrate !== false) {\n this.initialize().catch((error) => {\n console.error(\"Failed to initialize PostgreSQLAssistantStore:\", error);\n throw error;\n });\n }\n }\n\n /**\n * Initialize the store and run migrations\n */\n async initialize(): Promise<void> {\n if (this.initialized) {\n return;\n }\n\n await this.migrationManager.migrate();\n this.initialized = true;\n }\n\n /**\n * Get all assistants\n */\n async getAllAssistants(): Promise<Assistant[]> {\n await this.ensureInitialized();\n\n const result = await this.pool.query<{\n id: string;\n name: string;\n description: string | null;\n graph_definition: any;\n created_at: Date;\n updated_at: Date;\n }>(\n `\n SELECT id, name, description, graph_definition, created_at, updated_at\n FROM lattice_assistants\n ORDER BY created_at DESC\n `\n );\n\n return result.rows.map(this.mapRowToAssistant);\n }\n\n /**\n * Get assistant by ID\n */\n async getAssistantById(id: string): Promise<Assistant | null> {\n await this.ensureInitialized();\n\n const result = await this.pool.query<{\n id: string;\n name: string;\n description: string | null;\n graph_definition: any;\n created_at: Date;\n updated_at: Date;\n }>(\n `\n SELECT id, name, description, graph_definition, created_at, updated_at\n FROM lattice_assistants\n WHERE id = $1\n `,\n [id]\n );\n\n if (result.rows.length === 0) {\n return null;\n }\n\n return this.mapRowToAssistant(result.rows[0]);\n }\n\n /**\n * Create a new assistant\n */\n async createAssistant(\n id: string,\n data: CreateAssistantRequest\n ): Promise<Assistant> {\n await this.ensureInitialized();\n\n const now = new Date();\n\n await this.pool.query(\n `\n INSERT INTO lattice_assistants (id, name, description, graph_definition, created_at, updated_at)\n VALUES ($1, $2, $3, $4, $5, $6)\n ON CONFLICT (id) DO UPDATE SET\n name = EXCLUDED.name,\n description = EXCLUDED.description,\n graph_definition = EXCLUDED.graph_definition,\n updated_at = EXCLUDED.updated_at\n `,\n [\n id,\n data.name,\n data.description || null,\n JSON.stringify(data.graphDefinition),\n now,\n now,\n ]\n );\n\n return {\n id,\n name: data.name,\n description: data.description,\n graphDefinition: data.graphDefinition,\n createdAt: now,\n updatedAt: now,\n };\n }\n\n /**\n * Update an existing assistant\n */\n async updateAssistant(\n id: string,\n updates: Partial<CreateAssistantRequest>\n ): Promise<Assistant | null> {\n await this.ensureInitialized();\n\n // Get existing assistant\n const existing = await this.getAssistantById(id);\n if (!existing) {\n return null;\n }\n\n // Build update query dynamically based on provided fields\n const updateFields: string[] = [];\n const updateValues: any[] = [];\n let paramIndex = 1;\n\n if (updates.name !== undefined) {\n updateFields.push(`name = $${paramIndex++}`);\n updateValues.push(updates.name);\n }\n\n if (updates.description !== undefined) {\n updateFields.push(`description = $${paramIndex++}`);\n updateValues.push(updates.description || null);\n }\n\n if (updates.graphDefinition !== undefined) {\n updateFields.push(`graph_definition = $${paramIndex++}`);\n updateValues.push(JSON.stringify(updates.graphDefinition));\n }\n\n if (updateFields.length === 0) {\n // No fields to update\n return existing;\n }\n\n // Always update updated_at\n updateFields.push(`updated_at = $${paramIndex++}`);\n updateValues.push(new Date());\n\n // Add id for WHERE clause\n updateValues.push(id);\n\n await this.pool.query(\n `\n UPDATE lattice_assistants\n SET ${updateFields.join(\", \")}\n WHERE id = $${paramIndex}\n `,\n updateValues\n );\n\n // Return updated assistant\n return await this.getAssistantById(id);\n }\n\n /**\n * Delete an assistant by ID\n */\n async deleteAssistant(id: string): Promise<boolean> {\n await this.ensureInitialized();\n\n const result = await this.pool.query(\n `\n DELETE FROM lattice_assistants\n WHERE id = $1\n `,\n [id]\n );\n\n return result.rowCount !== null && result.rowCount > 0;\n }\n\n /**\n * Check if assistant exists\n */\n async hasAssistant(id: string): Promise<boolean> {\n await this.ensureInitialized();\n\n const result = await this.pool.query(\n `\n SELECT 1 FROM lattice_assistants\n WHERE id = $1\n LIMIT 1\n `,\n [id]\n );\n\n return result.rows.length > 0;\n }\n\n /**\n * Dispose resources and close the connection pool\n * Should be called when the store is no longer needed\n */\n async dispose(): Promise<void> {\n if (this.ownsPool && this.pool) {\n await this.pool.end();\n }\n }\n\n /**\n * Ensure store is initialized\n */\n private async ensureInitialized(): Promise<void> {\n if (!this.initialized) {\n await this.initialize();\n }\n }\n\n /**\n * Map database row to Assistant object\n */\n private mapRowToAssistant(row: {\n id: string;\n name: string;\n description: string | null;\n graph_definition: any;\n created_at: Date;\n updated_at: Date;\n }): Assistant {\n return {\n id: row.id,\n name: row.name,\n description: row.description || undefined,\n graphDefinition:\n typeof row.graph_definition === \"string\"\n ? JSON.parse(row.graph_definition)\n : row.graph_definition,\n createdAt: row.created_at,\n updatedAt: row.updated_at,\n };\n }\n}\n","/**\n * Assistant table migrations\n */\n\nimport { PoolClient } from \"pg\";\nimport { Migration } from \"./migration\";\n\n/**\n * Initial migration: Create assistants table\n */\nexport const createAssistantsTable: Migration = {\n version: 1,\n name: \"create_assistants_table\",\n up: async (client: PoolClient) => {\n await client.query(`\n CREATE TABLE IF NOT EXISTS lattice_assistants (\n id VARCHAR(255) PRIMARY KEY,\n name VARCHAR(255) NOT NULL,\n description TEXT,\n graph_definition JSONB NOT NULL,\n created_at TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,\n updated_at TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP\n )\n `);\n\n // Create indexes for better query performance\n await client.query(`\n CREATE INDEX IF NOT EXISTS idx_lattice_assistants_name \n ON lattice_assistants(name)\n `);\n\n await client.query(`\n CREATE INDEX IF NOT EXISTS idx_lattice_assistants_created_at \n ON lattice_assistants(created_at DESC)\n `);\n },\n down: async (client: PoolClient) => {\n await client.query(\n \"DROP INDEX IF EXISTS idx_lattice_assistants_created_at\"\n );\n await client.query(\"DROP INDEX IF EXISTS idx_lattice_assistants_name\");\n await client.query(\"DROP TABLE IF EXISTS lattice_assistants\");\n },\n};\n","/**\n * PostgreSQL implementation of ScheduleStorage\n *\n * Provides persistent storage for scheduled tasks\n * Data survives service restarts\n */\n\nimport { Pool, PoolConfig } from \"pg\";\nimport {\n ScheduleStorage,\n ScheduledTaskDefinition,\n ScheduledTaskStatus,\n ScheduleExecutionType,\n} from \"@axiom-lattice/protocols\";\nimport { MigrationManager } from \"../migrations/migration\";\nimport { createScheduledTasksTable } from \"../migrations/schedule_migrations\";\n\n/**\n * PostgreSQL ScheduleStorage options\n */\nexport interface PostgreSQLScheduleStorageOptions {\n /**\n * PostgreSQL connection pool configuration\n * Can be a connection string or PoolConfig object\n */\n poolConfig: string | PoolConfig;\n\n /**\n * Whether to run migrations automatically on initialization\n * @default true\n */\n autoMigrate?: boolean;\n}\n\n/**\n * Database row type for scheduled tasks\n */\ninterface ScheduledTaskRow {\n task_id: string;\n task_type: string;\n payload: string | Record<string, any>;\n assistant_id: string | null;\n thread_id: string | null;\n execution_type: string;\n execute_at: Date | null;\n delay_ms: number | null;\n cron_expression: string | null;\n timezone: string | null;\n next_run_at: Date | null;\n last_run_at: Date | null;\n status: string;\n run_count: number;\n max_runs: number | null;\n retry_count: number;\n max_retries: number;\n last_error: string | null;\n created_at: Date;\n updated_at: Date;\n expires_at: Date | null;\n metadata: string | Record<string, any> | null;\n}\n\n/**\n * PostgreSQL implementation of ScheduleStorage\n */\nexport class PostgreSQLScheduleStorage implements ScheduleStorage {\n private pool: Pool;\n private migrationManager: MigrationManager;\n private initialized: boolean = false;\n\n constructor(options: PostgreSQLScheduleStorageOptions) {\n // Create Pool from config\n if (typeof options.poolConfig === \"string\") {\n this.pool = new Pool({ connectionString: options.poolConfig });\n } else {\n this.pool = new Pool(options.poolConfig);\n }\n\n this.migrationManager = new MigrationManager(this.pool);\n this.migrationManager.register(createScheduledTasksTable);\n\n // Auto-migrate by default\n if (options.autoMigrate !== false) {\n this.initialize().catch((error) => {\n console.error(\"Failed to initialize PostgreSQLScheduleStorage:\", error);\n throw error;\n });\n }\n }\n\n /**\n * Dispose resources and close the connection pool\n */\n async dispose(): Promise<void> {\n if (this.pool) {\n await this.pool.end();\n }\n }\n\n /**\n * Initialize the store and run migrations\n */\n async initialize(): Promise<void> {\n if (this.initialized) {\n return;\n }\n\n await this.migrationManager.migrate();\n this.initialized = true;\n }\n\n /**\n * Ensure store is initialized\n */\n private async ensureInitialized(): Promise<void> {\n if (!this.initialized) {\n await this.initialize();\n }\n }\n\n /**\n * Save a new task\n */\n async save(task: ScheduledTaskDefinition): Promise<void> {\n await this.ensureInitialized();\n\n await this.pool.query(\n `\n INSERT INTO lattice_scheduled_tasks (\n task_id, task_type, payload, assistant_id, thread_id, execution_type,\n execute_at, delay_ms, cron_expression, timezone,\n next_run_at, last_run_at, status, run_count, max_runs,\n retry_count, max_retries, last_error,\n created_at, updated_at, expires_at, metadata\n ) VALUES (\n $1, $2, $3, $4, $5, $6,\n $7, $8, $9, $10,\n $11, $12, $13, $14, $15,\n $16, $17, $18,\n $19, $20, $21, $22\n )\n ON CONFLICT (task_id) DO UPDATE SET\n task_type = EXCLUDED.task_type,\n payload = EXCLUDED.payload,\n assistant_id = EXCLUDED.assistant_id,\n thread_id = EXCLUDED.thread_id,\n execution_type = EXCLUDED.execution_type,\n execute_at = EXCLUDED.execute_at,\n delay_ms = EXCLUDED.delay_ms,\n cron_expression = EXCLUDED.cron_expression,\n timezone = EXCLUDED.timezone,\n next_run_at = EXCLUDED.next_run_at,\n last_run_at = EXCLUDED.last_run_at,\n status = EXCLUDED.status,\n run_count = EXCLUDED.run_count,\n max_runs = EXCLUDED.max_runs,\n retry_count = EXCLUDED.retry_count,\n max_retries = EXCLUDED.max_retries,\n last_error = EXCLUDED.last_error,\n updated_at = EXCLUDED.updated_at,\n expires_at = EXCLUDED.expires_at,\n metadata = EXCLUDED.metadata\n `,\n [\n task.taskId,\n task.taskType,\n JSON.stringify(task.payload),\n task.assistantId ?? null,\n task.threadId ?? null,\n task.executionType,\n task.executeAt ? new Date(task.executeAt) : null,\n task.delayMs ?? null,\n task.cronExpression ?? null,\n task.timezone ?? null,\n task.nextRunAt ? new Date(task.nextRunAt) : null,\n task.lastRunAt ? new Date(task.lastRunAt) : null,\n task.status,\n task.runCount,\n task.maxRuns ?? null,\n task.retryCount,\n task.maxRetries,\n task.lastError ?? null,\n new Date(task.createdAt),\n new Date(task.updatedAt),\n task.expiresAt ? new Date(task.expiresAt) : null,\n task.metadata ? JSON.stringify(task.metadata) : null,\n ]\n );\n }\n\n /**\n * Get task by ID\n */\n async get(taskId: string): Promise<ScheduledTaskDefinition | null> {\n await this.ensureInitialized();\n\n const result = await this.pool.query<ScheduledTaskRow>(\n `SELECT * FROM lattice_scheduled_tasks WHERE task_id = $1`,\n [taskId]\n );\n\n if (result.rows.length === 0) {\n return null;\n }\n\n return this.mapRowToTask(result.rows[0]);\n }\n\n /**\n * Update task\n */\n async update(\n taskId: string,\n updates: Partial<ScheduledTaskDefinition>\n ): Promise<void> {\n await this.ensureInitialized();\n\n const setClauses: string[] = [];\n const values: any[] = [];\n let paramIndex = 1;\n\n // Build dynamic UPDATE query\n if (updates.taskType !== undefined) {\n setClauses.push(`task_type = $${paramIndex++}`);\n values.push(updates.taskType);\n }\n if (updates.payload !== undefined) {\n setClauses.push(`payload = $${paramIndex++}`);\n values.push(JSON.stringify(updates.payload));\n }\n if (updates.assistantId !== undefined) {\n setClauses.push(`assistant_id = $${paramIndex++}`);\n values.push(updates.assistantId);\n }\n if (updates.threadId !== undefined) {\n setClauses.push(`thread_id = $${paramIndex++}`);\n values.push(updates.threadId);\n }\n if (updates.executionType !== undefined) {\n setClauses.push(`execution_type = $${paramIndex++}`);\n values.push(updates.executionType);\n }\n if (updates.executeAt !== undefined) {\n setClauses.push(`execute_at = $${paramIndex++}`);\n values.push(updates.executeAt ? new Date(updates.executeAt) : null);\n }\n if (updates.delayMs !== undefined) {\n setClauses.push(`delay_ms = $${paramIndex++}`);\n values.push(updates.delayMs);\n }\n if (updates.cronExpression !== undefined) {\n setClauses.push(`cron_expression = $${paramIndex++}`);\n values.push(updates.cronExpression);\n }\n if (updates.timezone !== undefined) {\n setClauses.push(`timezone = $${paramIndex++}`);\n values.push(updates.timezone);\n }\n if (updates.nextRunAt !== undefined) {\n setClauses.push(`next_run_at = $${paramIndex++}`);\n values.push(updates.nextRunAt ? new Date(updates.nextRunAt) : null);\n }\n if (updates.lastRunAt !== undefined) {\n setClauses.push(`last_run_at = $${paramIndex++}`);\n values.push(updates.lastRunAt ? new Date(updates.lastRunAt) : null);\n }\n if (updates.status !== undefined) {\n setClauses.push(`status = $${paramIndex++}`);\n values.push(updates.status);\n }\n if (updates.runCount !== undefined) {\n setClauses.push(`run_count = $${paramIndex++}`);\n values.push(updates.runCount);\n }\n if (updates.maxRuns !== undefined) {\n setClauses.push(`max_runs = $${paramIndex++}`);\n values.push(updates.maxRuns);\n }\n if (updates.retryCount !== undefined) {\n setClauses.push(`retry_count = $${paramIndex++}`);\n values.push(updates.retryCount);\n }\n if (updates.maxRetries !== undefined) {\n setClauses.push(`max_retries = $${paramIndex++}`);\n values.push(updates.maxRetries);\n }\n if (updates.lastError !== undefined) {\n setClauses.push(`last_error = $${paramIndex++}`);\n values.push(updates.lastError);\n }\n if (updates.expiresAt !== undefined) {\n setClauses.push(`expires_at = $${paramIndex++}`);\n values.push(updates.expiresAt ? new Date(updates.expiresAt) : null);\n }\n if (updates.metadata !== undefined) {\n setClauses.push(`metadata = $${paramIndex++}`);\n values.push(updates.metadata ? JSON.stringify(updates.metadata) : null);\n }\n\n // Always update updated_at\n setClauses.push(`updated_at = $${paramIndex++}`);\n values.push(new Date());\n\n // Add taskId as the last parameter\n values.push(taskId);\n\n if (setClauses.length === 0) {\n return;\n }\n\n await this.pool.query(\n `UPDATE lattice_scheduled_tasks SET ${setClauses.join(\n \", \"\n )} WHERE task_id = $${paramIndex}`,\n values\n );\n }\n\n /**\n * Delete task\n */\n async delete(taskId: string): Promise<void> {\n await this.ensureInitialized();\n\n await this.pool.query(\n `DELETE FROM lattice_scheduled_tasks WHERE task_id = $1`,\n [taskId]\n );\n }\n\n /**\n * Get all active tasks (pending or paused)\n */\n async getActiveTasks(): Promise<ScheduledTaskDefinition[]> {\n await this.ensureInitialized();\n\n const result = await this.pool.query<ScheduledTaskRow>(\n `SELECT * FROM lattice_scheduled_tasks WHERE status IN ($1, $2) ORDER BY created_at ASC`,\n [ScheduledTaskStatus.PENDING, ScheduledTaskStatus.PAUSED]\n );\n\n return result.rows.map((row) => this.mapRowToTask(row));\n }\n\n /**\n * Get tasks by type\n */\n async getTasksByType(taskType: string): Promise<ScheduledTaskDefinition[]> {\n await this.ensureInitialized();\n\n const result = await this.pool.query<ScheduledTaskRow>(\n `SELECT * FROM lattice_scheduled_tasks WHERE task_type = $1 ORDER BY created_at DESC`,\n [taskType]\n );\n\n return result.rows.map((row) => this.mapRowToTask(row));\n }\n\n /**\n * Get tasks by status\n */\n async getTasksByStatus(\n status: ScheduledTaskStatus\n ): Promise<ScheduledTaskDefinition[]> {\n await this.ensureInitialized();\n\n const result = await this.pool.query<ScheduledTaskRow>(\n `SELECT * FROM lattice_scheduled_tasks WHERE status = $1 ORDER BY created_at DESC`,\n [status]\n );\n\n return result.rows.map((row) => this.mapRowToTask(row));\n }\n\n /**\n * Get tasks by execution type\n */\n async getTasksByExecutionType(\n executionType: ScheduleExecutionType\n ): Promise<ScheduledTaskDefinition[]> {\n await this.ensureInitialized();\n\n const result = await this.pool.query<ScheduledTaskRow>(\n `SELECT * FROM lattice_scheduled_tasks WHERE execution_type = $1 ORDER BY created_at DESC`,\n [executionType]\n );\n\n return result.rows.map((row) => this.mapRowToTask(row));\n }\n\n /**\n * Get tasks by assistant ID\n */\n async getTasksByAssistantId(\n assistantId: string\n ): Promise<ScheduledTaskDefinition[]> {\n await this.ensureInitialized();\n\n const result = await this.pool.query<ScheduledTaskRow>(\n `SELECT * FROM lattice_scheduled_tasks WHERE assistant_id = $1 ORDER BY created_at DESC`,\n [assistantId]\n );\n\n return result.rows.map((row) => this.mapRowToTask(row));\n }\n\n /**\n * Get tasks by thread ID\n */\n async getTasksByThreadId(\n threadId: string\n ): Promise<ScheduledTaskDefinition[]> {\n await this.ensureInitialized();\n\n const result = await this.pool.query<ScheduledTaskRow>(\n `SELECT * FROM lattice_scheduled_tasks WHERE thread_id = $1 ORDER BY created_at DESC`,\n [threadId]\n );\n\n return result.rows.map((row) => this.mapRowToTask(row));\n }\n\n /**\n * Get all tasks with optional filters\n */\n async getAllTasks(filters?: {\n status?: ScheduledTaskStatus;\n executionType?: ScheduleExecutionType;\n taskType?: string;\n assistantId?: string;\n threadId?: string;\n limit?: number;\n offset?: number;\n }): Promise<ScheduledTaskDefinition[]> {\n await this.ensureInitialized();\n\n const whereClauses: string[] = [];\n const values: any[] = [];\n let paramIndex = 1;\n\n if (filters?.status !== undefined) {\n whereClauses.push(`status = $${paramIndex++}`);\n values.push(filters.status);\n }\n if (filters?.executionType !== undefined) {\n whereClauses.push(`execution_type = $${paramIndex++}`);\n values.push(filters.executionType);\n }\n if (filters?.taskType !== undefined) {\n whereClauses.push(`task_type = $${paramIndex++}`);\n values.push(filters.taskType);\n }\n if (filters?.assistantId !== undefined) {\n whereClauses.push(`assistant_id = $${paramIndex++}`);\n values.push(filters.assistantId);\n }\n if (filters?.threadId !== undefined) {\n whereClauses.push(`thread_id = $${paramIndex++}`);\n values.push(filters.threadId);\n }\n\n let query = `SELECT * FROM lattice_scheduled_tasks`;\n if (whereClauses.length > 0) {\n query += ` WHERE ${whereClauses.join(\" AND \")}`;\n }\n query += ` ORDER BY created_at DESC`;\n\n if (filters?.limit !== undefined) {\n query += ` LIMIT $${paramIndex++}`;\n values.push(filters.limit);\n }\n if (filters?.offset !== undefined) {\n query += ` OFFSET $${paramIndex++}`;\n values.push(filters.offset);\n }\n\n const result = await this.pool.query<ScheduledTaskRow>(query, values);\n\n return result.rows.map((row) => this.mapRowToTask(row));\n }\n\n /**\n * Count tasks with optional filters\n */\n async countTasks(filters?: {\n status?: ScheduledTaskStatus;\n executionType?: ScheduleExecutionType;\n taskType?: string;\n assistantId?: string;\n threadId?: string;\n }): Promise<number> {\n await this.ensureInitialized();\n\n const whereClauses: string[] = [];\n const values: any[] = [];\n let paramIndex = 1;\n\n if (filters?.status !== undefined) {\n whereClauses.push(`status = $${paramIndex++}`);\n values.push(filters.status);\n }\n if (filters?.executionType !== undefined) {\n whereClauses.push(`execution_type = $${paramIndex++}`);\n values.push(filters.executionType);\n }\n if (filters?.taskType !== undefined) {\n whereClauses.push(`task_type = $${paramIndex++}`);\n values.push(filters.taskType);\n }\n if (filters?.assistantId !== undefined) {\n whereClauses.push(`assistant_id = $${paramIndex++}`);\n values.push(filters.assistantId);\n }\n if (filters?.threadId !== undefined) {\n whereClauses.push(`thread_id = $${paramIndex++}`);\n values.push(filters.threadId);\n }\n\n let query = `SELECT COUNT(*) as count FROM lattice_scheduled_tasks`;\n if (whereClauses.length > 0) {\n query += ` WHERE ${whereClauses.join(\" AND \")}`;\n }\n\n const result = await this.pool.query<{ count: string }>(query, values);\n\n return parseInt(result.rows[0].count, 10);\n }\n\n /**\n * Delete completed/cancelled/failed tasks older than specified time\n */\n async deleteOldTasks(olderThanMs: number): Promise<number> {\n await this.ensureInitialized();\n\n const cutoff = new Date(Date.now() - olderThanMs);\n\n const result = await this.pool.query(\n `\n DELETE FROM lattice_scheduled_tasks \n WHERE status IN ($1, $2, $3) \n AND updated_at < $4\n `,\n [\n ScheduledTaskStatus.COMPLETED,\n ScheduledTaskStatus.CANCELLED,\n ScheduledTaskStatus.FAILED,\n cutoff,\n ]\n );\n\n return result.rowCount ?? 0;\n }\n\n /**\n * Map database row to ScheduledTaskDefinition\n */\n private mapRowToTask(row: ScheduledTaskRow): ScheduledTaskDefinition {\n return {\n taskId: row.task_id,\n taskType: row.task_type,\n payload:\n typeof row.payload === \"string\"\n ? JSON.parse(row.payload)\n : row.payload || {},\n assistantId: row.assistant_id ?? undefined,\n threadId: row.thread_id ?? undefined,\n executionType: row.execution_type as ScheduleExecutionType,\n executeAt: row.execute_at ? row.execute_at.getTime() : undefined,\n delayMs: row.delay_ms ?? undefined,\n cronExpression: row.cron_expression ?? undefined,\n timezone: row.timezone ?? undefined,\n nextRunAt: row.next_run_at ? row.next_run_at.getTime() : undefined,\n lastRunAt: row.last_run_at ? row.last_run_at.getTime() : undefined,\n status: row.status as ScheduledTaskStatus,\n runCount: row.run_count,\n maxRuns: row.max_runs ?? undefined,\n retryCount: row.retry_count,\n maxRetries: row.max_retries,\n lastError: row.last_error ?? undefined,\n createdAt: row.created_at.getTime(),\n updatedAt: row.updated_at.getTime(),\n expiresAt: row.expires_at ? row.expires_at.getTime() : undefined,\n metadata:\n row.metadata === null\n ? undefined\n : typeof row.metadata === \"string\"\n ? JSON.parse(row.metadata)\n : row.metadata,\n };\n }\n}\n","/**\n * PostgreSQL migrations for scheduled tasks table\n */\n\nimport { Migration } from \"./migration\";\n\n/**\n * Create the scheduled_tasks table\n */\nexport const createScheduledTasksTable: Migration = {\n name: \"create_scheduled_tasks_table\",\n version: 2,\n\n up: async (client) => {\n await client.query(`\n CREATE TABLE IF NOT EXISTS lattice_scheduled_tasks (\n -- Primary key\n task_id VARCHAR(255) PRIMARY KEY,\n \n -- Task type (maps to handler)\n task_type VARCHAR(255) NOT NULL,\n \n -- Payload (JSON-serializable data)\n payload JSONB NOT NULL DEFAULT '{}',\n \n -- Context fields for querying\n assistant_id VARCHAR(255),\n thread_id VARCHAR(255),\n \n -- Execution type: 'once' or 'cron'\n execution_type VARCHAR(50) NOT NULL,\n \n -- For ONCE type\n execute_at TIMESTAMPTZ,\n delay_ms BIGINT,\n \n -- For CRON type\n cron_expression VARCHAR(255),\n timezone VARCHAR(100),\n next_run_at TIMESTAMPTZ,\n last_run_at TIMESTAMPTZ,\n \n -- Status\n status VARCHAR(50) NOT NULL DEFAULT 'pending',\n \n -- Execution tracking\n run_count INTEGER NOT NULL DEFAULT 0,\n max_runs INTEGER,\n \n -- Error handling\n retry_count INTEGER NOT NULL DEFAULT 0,\n max_retries INTEGER NOT NULL DEFAULT 0,\n last_error TEXT,\n \n -- Timestamps\n created_at TIMESTAMPTZ NOT NULL DEFAULT NOW(),\n updated_at TIMESTAMPTZ NOT NULL DEFAULT NOW(),\n expires_at TIMESTAMPTZ,\n \n -- Metadata\n metadata JSONB\n );\n\n -- Index for querying active tasks\n CREATE INDEX IF NOT EXISTS idx_scheduled_tasks_status \n ON lattice_scheduled_tasks (status);\n \n -- Index for querying by task type\n CREATE INDEX IF NOT EXISTS idx_scheduled_tasks_task_type \n ON lattice_scheduled_tasks (task_type);\n \n -- Index for querying by execution type\n CREATE INDEX IF NOT EXISTS idx_scheduled_tasks_execution_type \n ON lattice_scheduled_tasks (execution_type);\n \n -- Index for querying by assistant ID\n CREATE INDEX IF NOT EXISTS idx_scheduled_tasks_assistant_id \n ON lattice_scheduled_tasks (assistant_id)\n WHERE assistant_id IS NOT NULL;\n \n -- Index for querying by thread ID\n CREATE INDEX IF NOT EXISTS idx_scheduled_tasks_thread_id \n ON lattice_scheduled_tasks (thread_id)\n WHERE thread_id IS NOT NULL;\n \n -- Index for querying pending tasks by next run time\n CREATE INDEX IF NOT EXISTS idx_scheduled_tasks_next_run \n ON lattice_scheduled_tasks (next_run_at) \n WHERE status = 'pending';\n \n -- Index for querying pending one-time tasks by execute time\n CREATE INDEX IF NOT EXISTS idx_scheduled_tasks_execute_at \n ON lattice_scheduled_tasks (execute_at) \n WHERE status = 'pending' AND execution_type = 'once';\n \n -- Index for cleanup queries (old completed/cancelled tasks)\n CREATE INDEX IF NOT EXISTS idx_scheduled_tasks_cleanup \n ON lattice_scheduled_tasks (updated_at) \n WHERE status IN ('completed', 'cancelled', 'failed');\n `);\n },\n\n down: async (client) => {\n await client.query(`\n DROP INDEX IF EXISTS idx_scheduled_tasks_cleanup;\n DROP INDEX IF EXISTS idx_scheduled_tasks_execute_at;\n DROP INDEX IF EXISTS idx_scheduled_tasks_next_run;\n DROP INDEX IF EXISTS idx_scheduled_tasks_thread_id;\n DROP INDEX IF EXISTS idx_scheduled_tasks_assistant_id;\n DROP INDEX IF EXISTS idx_scheduled_tasks_execution_type;\n DROP INDEX IF EXISTS idx_scheduled_tasks_task_type;\n DROP INDEX IF EXISTS idx_scheduled_tasks_status;\n DROP TABLE IF EXISTS lattice_scheduled_tasks;\n `);\n },\n};\n","/**\n * PostgreSQL implementation of SkillStore\n */\n\nimport { Pool, PoolConfig } from \"pg\";\nimport {\n SkillStore,\n Skill,\n CreateSkillRequest,\n} from \"@axiom-lattice/protocols\";\nimport { MigrationManager } from \"../migrations/migration\";\nimport { createSkillsTable } from \"../migrations/skill_migrations\";\n\n/**\n * PostgreSQL SkillStore options\n */\nexport interface PostgreSQLSkillStoreOptions {\n /**\n * PostgreSQL connection pool configuration\n * Can be a connection string or PoolConfig object\n */\n poolConfig: string | PoolConfig;\n\n /**\n * Whether to run migrations automatically on initialization\n * @default true\n */\n autoMigrate?: boolean;\n}\n\n/**\n * PostgreSQL implementation of SkillStore\n */\nexport class PostgreSQLSkillStore implements SkillStore {\n private pool: Pool;\n private migrationManager: MigrationManager;\n private initialized: boolean = false;\n private ownsPool: boolean = true;\n\n constructor(options: PostgreSQLSkillStoreOptions) {\n // Create Pool from config\n if (typeof options.poolConfig === \"string\") {\n this.pool = new Pool({ connectionString: options.poolConfig });\n } else {\n this.pool = new Pool(options.poolConfig);\n }\n\n this.migrationManager = new MigrationManager(this.pool);\n this.migrationManager.register(createSkillsTable);\n\n // Auto-migrate by default\n if (options.autoMigrate !== false) {\n this.initialize().catch((error) => {\n console.error(\"Failed to initialize PostgreSQLSkillStore:\", error);\n throw error;\n });\n }\n }\n\n /**\n * Dispose resources and close the connection pool\n * Should be called when the store is no longer needed\n */\n async dispose(): Promise<void> {\n if (this.ownsPool && this.pool) {\n await this.pool.end();\n }\n }\n\n /**\n * Initialize the store and run migrations\n */\n async initialize(): Promise<void> {\n if (this.initialized) {\n return;\n }\n\n await this.migrationManager.migrate();\n this.initialized = true;\n }\n\n /**\n * Ensure store is initialized\n */\n private async ensureInitialized(): Promise<void> {\n if (!this.initialized) {\n await this.initialize();\n }\n }\n\n /**\n * Map database row to Skill object\n */\n private mapRowToSkill(row: {\n id: string;\n name: string;\n description: string;\n license: string | null;\n compatibility: string | null;\n metadata: any;\n content: string | null;\n sub_skills: any;\n created_at: Date;\n updated_at: Date;\n }): Skill {\n return {\n id: row.id,\n name: row.name,\n description: row.description,\n license: row.license || undefined,\n compatibility: row.compatibility || undefined,\n metadata: row.metadata || {},\n content: row.content || undefined,\n subSkills: Array.isArray(row.sub_skills) && row.sub_skills.length > 0 \n ? row.sub_skills \n : undefined,\n createdAt: row.created_at,\n updatedAt: row.updated_at,\n };\n }\n\n /**\n * Get all skills\n */\n async getAllSkills(): Promise<Skill[]> {\n await this.ensureInitialized();\n\n const result = await this.pool.query<{\n id: string;\n name: string;\n description: string;\n license: string | null;\n compatibility: string | null;\n metadata: any;\n content: string | null;\n sub_skills: any;\n created_at: Date;\n updated_at: Date;\n }>(\n `\n SELECT id, name, description, license, compatibility, metadata, content, sub_skills, created_at, updated_at\n FROM lattice_skills\n ORDER BY created_at DESC\n `\n );\n\n return result.rows.map(this.mapRowToSkill);\n }\n\n /**\n * Get skill by ID\n */\n async getSkillById(id: string): Promise<Skill | null> {\n await this.ensureInitialized();\n\n const result = await this.pool.query<{\n id: string;\n name: string;\n description: string;\n license: string | null;\n compatibility: string | null;\n metadata: any;\n content: string | null;\n sub_skills: any;\n created_at: Date;\n updated_at: Date;\n }>(\n `\n SELECT id, name, description, license, compatibility, metadata, content, sub_skills, created_at, updated_at\n FROM lattice_skills\n WHERE id = $1\n `,\n [id]\n );\n\n if (result.rows.length === 0) {\n return null;\n }\n\n return this.mapRowToSkill(result.rows[0]);\n }\n\n /**\n * Create a new skill\n */\n async createSkill(id: string, data: CreateSkillRequest): Promise<Skill> {\n await this.ensureInitialized();\n\n const now = new Date();\n const metadata = data.metadata || {};\n\n await this.pool.query(\n `\n INSERT INTO lattice_skills (id, name, description, license, compatibility, metadata, content, sub_skills, created_at, updated_at)\n VALUES ($1, $2, $3, $4, $5, $6, $7, $8, $9, $10)\n ON CONFLICT (id) DO UPDATE SET\n name = EXCLUDED.name,\n description = EXCLUDED.description,\n license = EXCLUDED.license,\n compatibility = EXCLUDED.compatibility,\n metadata = EXCLUDED.metadata,\n content = EXCLUDED.content,\n sub_skills = EXCLUDED.sub_skills,\n updated_at = EXCLUDED.updated_at\n `,\n [\n id,\n data.name,\n data.description,\n data.license || null,\n data.compatibility || null,\n JSON.stringify(metadata),\n data.content || null,\n JSON.stringify(data.subSkills || []),\n now,\n now,\n ]\n );\n\n return this.getSkillById(id) as Promise<Skill>;\n }\n\n /**\n * Update an existing skill\n */\n async updateSkill(\n id: string,\n updates: Partial<CreateSkillRequest>\n ): Promise<Skill | null> {\n await this.ensureInitialized();\n\n const updateFields: string[] = [];\n const values: any[] = [];\n let paramIndex = 1;\n\n if (updates.name !== undefined) {\n updateFields.push(`name = $${paramIndex++}`);\n values.push(updates.name);\n }\n\n if (updates.description !== undefined) {\n updateFields.push(`description = $${paramIndex++}`);\n values.push(updates.description);\n }\n\n if (updates.license !== undefined) {\n updateFields.push(`license = $${paramIndex++}`);\n values.push(updates.license || null);\n }\n\n if (updates.compatibility !== undefined) {\n updateFields.push(`compatibility = $${paramIndex++}`);\n values.push(updates.compatibility || null);\n }\n\n if (updates.metadata !== undefined) {\n updateFields.push(`metadata = $${paramIndex++}`);\n values.push(JSON.stringify(updates.metadata || {}));\n }\n\n if (updates.content !== undefined) {\n updateFields.push(`content = $${paramIndex++}`);\n values.push(updates.content || null);\n }\n\n if (updates.subSkills !== undefined) {\n updateFields.push(`sub_skills = $${paramIndex++}`);\n values.push(JSON.stringify(updates.subSkills || []));\n }\n\n if (updateFields.length === 0) {\n return this.getSkillById(id);\n }\n\n updateFields.push(`updated_at = $${paramIndex++}`);\n values.push(new Date());\n values.push(id);\n\n await this.pool.query(\n `\n UPDATE lattice_skills\n SET ${updateFields.join(\", \")}\n WHERE id = $${paramIndex}\n `,\n values\n );\n\n return this.getSkillById(id);\n }\n\n /**\n * Delete a skill by ID\n */\n async deleteSkill(id: string): Promise<boolean> {\n await this.ensureInitialized();\n\n const result = await this.pool.query(\n `\n DELETE FROM lattice_skills\n WHERE id = $1\n `,\n [id]\n );\n\n return result.rowCount !== null && result.rowCount > 0;\n }\n\n /**\n * Check if skill exists\n */\n async hasSkill(id: string): Promise<boolean> {\n await this.ensureInitialized();\n\n const result = await this.pool.query<{ count: string }>(\n `\n SELECT COUNT(*) as count\n FROM lattice_skills\n WHERE id = $1\n `,\n [id]\n );\n\n return parseInt(result.rows[0].count, 10) > 0;\n }\n\n /**\n * Search skills by metadata\n */\n async searchByMetadata(\n metadataKey: string,\n metadataValue: string\n ): Promise<Skill[]> {\n await this.ensureInitialized();\n\n const result = await this.pool.query<{\n id: string;\n name: string;\n description: string;\n license: string | null;\n compatibility: string | null;\n metadata: any;\n content: string | null;\n sub_skills: any;\n created_at: Date;\n updated_at: Date;\n }>(\n `\n SELECT id, name, description, license, compatibility, metadata, content, sub_skills, created_at, updated_at\n FROM lattice_skills\n WHERE metadata->>$1 = $2\n ORDER BY created_at DESC\n `,\n [metadataKey, metadataValue]\n );\n\n return result.rows.map(this.mapRowToSkill);\n }\n\n /**\n * Filter skills by compatibility\n */\n async filterByCompatibility(compatibility: string): Promise<Skill[]> {\n await this.ensureInitialized();\n\n const result = await this.pool.query<{\n id: string;\n name: string;\n description: string;\n license: string | null;\n compatibility: string | null;\n metadata: any;\n content: string | null;\n sub_skills: any;\n created_at: Date;\n updated_at: Date;\n }>(\n `\n SELECT id, name, description, license, compatibility, metadata, content, sub_skills, created_at, updated_at\n FROM lattice_skills\n WHERE compatibility = $1\n ORDER BY created_at DESC\n `,\n [compatibility]\n );\n\n return result.rows.map(this.mapRowToSkill);\n }\n\n /**\n * Filter skills by license\n */\n async filterByLicense(license: string): Promise<Skill[]> {\n await this.ensureInitialized();\n\n const result = await this.pool.query<{\n id: string;\n name: string;\n description: string;\n license: string | null;\n compatibility: string | null;\n metadata: any;\n content: string | null;\n sub_skills: any;\n created_at: Date;\n updated_at: Date;\n }>(\n `\n SELECT id, name, description, license, compatibility, metadata, content, sub_skills, created_at, updated_at\n FROM lattice_skills\n WHERE license = $1\n ORDER BY created_at DESC\n `,\n [license]\n );\n\n return result.rows.map(this.mapRowToSkill);\n }\n\n /**\n * Get sub-skills of a parent skill\n */\n async getSubSkills(parentSkillName: string): Promise<Skill[]> {\n await this.ensureInitialized();\n\n const parentSkill = await this.getSkillById(parentSkillName);\n if (!parentSkill || !parentSkill.subSkills || parentSkill.subSkills.length === 0) {\n return [];\n }\n\n // Query all sub-skills in one query\n const placeholders = parentSkill.subSkills.map((_, index) => `$${index + 1}`).join(\", \");\n const result = await this.pool.query<{\n id: string;\n name: string;\n description: string;\n license: string | null;\n compatibility: string | null;\n metadata: any;\n content: string | null;\n sub_skills: any;\n created_at: Date;\n updated_at: Date;\n }>(\n `\n SELECT id, name, description, license, compatibility, metadata, content, sub_skills, created_at, updated_at\n FROM lattice_skills\n WHERE name IN (${placeholders})\n ORDER BY created_at DESC\n `,\n parentSkill.subSkills\n );\n\n return result.rows.map(this.mapRowToSkill);\n }\n}\n","/**\n * Skill table migrations\n */\n\nimport { PoolClient } from \"pg\";\nimport { Migration } from \"./migration\";\n\n/**\n * Initial migration: Create skills table\n */\nexport const createSkillsTable: Migration = {\n version: 1,\n name: \"create_skills_table\",\n up: async (client: PoolClient) => {\n await client.query(`\n CREATE TABLE IF NOT EXISTS lattice_skills (\n id VARCHAR(255) PRIMARY KEY,\n name VARCHAR(255) NOT NULL,\n description TEXT NOT NULL,\n license VARCHAR(255),\n compatibility VARCHAR(255),\n metadata JSONB DEFAULT '{}',\n content TEXT,\n sub_skills JSONB DEFAULT '[]',\n created_at TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,\n updated_at TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP\n )\n `);\n\n // Create indexes for better query performance\n await client.query(`\n CREATE INDEX IF NOT EXISTS idx_lattice_skills_name \n ON lattice_skills(name)\n `);\n\n await client.query(`\n CREATE INDEX IF NOT EXISTS idx_lattice_skills_license \n ON lattice_skills(license)\n `);\n\n await client.query(`\n CREATE INDEX IF NOT EXISTS idx_lattice_skills_compatibility \n ON lattice_skills(compatibility)\n `);\n\n await client.query(`\n CREATE INDEX IF NOT EXISTS idx_lattice_skills_created_at \n ON lattice_skills(created_at DESC)\n `);\n\n // Create GIN index for metadata JSONB queries\n await client.query(`\n CREATE INDEX IF NOT EXISTS idx_lattice_skills_metadata \n ON lattice_skills USING GIN (metadata)\n `);\n },\n down: async (client: PoolClient) => {\n await client.query(\"DROP INDEX IF EXISTS idx_lattice_skills_metadata\");\n await client.query(\"DROP INDEX IF EXISTS idx_lattice_skills_created_at\");\n await client.query(\"DROP INDEX IF EXISTS idx_lattice_skills_compatibility\");\n await client.query(\"DROP INDEX IF EXISTS idx_lattice_skills_license\");\n await client.query(\"DROP INDEX IF EXISTS idx_lattice_skills_name\");\n await client.query(\"DROP TABLE IF EXISTS lattice_skills\");\n },\n};\n"],"mappings":"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","names":["import_pg","import_pg","import_pg"]}