@elizaos/plugin-sql 2.0.0-alpha.1 → 2.0.0-alpha.11

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "version": 3,
3
- "sources": ["../../../../../node_modules/drizzle-orm/entity.js", "../../../../../node_modules/drizzle-orm/column.js", "../../../../../node_modules/drizzle-orm/column-builder.js", "../../../../../node_modules/drizzle-orm/table.utils.js", "../../../../../node_modules/drizzle-orm/pg-core/foreign-keys.js", "../../../../../node_modules/drizzle-orm/tracing-utils.js", "../../../../../node_modules/drizzle-orm/pg-core/unique-constraint.js", "../../../../../node_modules/drizzle-orm/pg-core/utils/array.js", "../../../../../node_modules/drizzle-orm/pg-core/columns/common.js", "../../../../../node_modules/drizzle-orm/pg-core/columns/enum.js", "../../../../../node_modules/drizzle-orm/subquery.js", "../../../../../node_modules/drizzle-orm/version.js", "../../../../../node_modules/drizzle-orm/tracing.js", "../../../../../node_modules/drizzle-orm/view-common.js", "../../../../../node_modules/drizzle-orm/table.js", "../../../../../node_modules/drizzle-orm/sql/sql.js", "../../../../../node_modules/drizzle-orm/alias.js", "../../../../../node_modules/drizzle-orm/errors.js", "../../../../../node_modules/drizzle-orm/logger.js", "../../../../../node_modules/drizzle-orm/query-promise.js", "../../../../../node_modules/drizzle-orm/utils.js", "../../../../../node_modules/drizzle-orm/pg-core/columns/int.common.js", "../../../../../node_modules/drizzle-orm/pg-core/columns/bigint.js", "../../../../../node_modules/drizzle-orm/pg-core/columns/bigserial.js", "../../../../../node_modules/drizzle-orm/pg-core/columns/boolean.js", "../../../../../node_modules/drizzle-orm/pg-core/columns/char.js", "../../../../../node_modules/drizzle-orm/pg-core/columns/cidr.js", "../../../../../node_modules/drizzle-orm/pg-core/columns/custom.js", "../../../../../node_modules/drizzle-orm/pg-core/columns/date.common.js", "../../../../../node_modules/drizzle-orm/pg-core/columns/date.js", "../../../../../node_modules/drizzle-orm/pg-core/columns/double-precision.js", "../../../../../node_modules/drizzle-orm/pg-core/columns/inet.js", "../../../../../node_modules/drizzle-orm/pg-core/columns/integer.js", "../../../../../node_modules/drizzle-orm/pg-core/columns/interval.js", "../../../../../node_modules/drizzle-orm/pg-core/columns/json.js", "../../../../../node_modules/drizzle-orm/pg-core/columns/jsonb.js", "../../../../../node_modules/drizzle-orm/pg-core/columns/line.js", "../../../../../node_modules/drizzle-orm/pg-core/columns/macaddr.js", "../../../../../node_modules/drizzle-orm/pg-core/columns/macaddr8.js", "../../../../../node_modules/drizzle-orm/pg-core/columns/numeric.js", "../../../../../node_modules/drizzle-orm/pg-core/columns/point.js", "../../../../../node_modules/drizzle-orm/pg-core/columns/postgis_extension/utils.js", "../../../../../node_modules/drizzle-orm/pg-core/columns/postgis_extension/geometry.js", "../../../../../node_modules/drizzle-orm/pg-core/columns/real.js", "../../../../../node_modules/drizzle-orm/pg-core/columns/serial.js", "../../../../../node_modules/drizzle-orm/pg-core/columns/smallint.js", "../../../../../node_modules/drizzle-orm/pg-core/columns/smallserial.js", "../../../../../node_modules/drizzle-orm/pg-core/columns/text.js", "../../../../../node_modules/drizzle-orm/pg-core/columns/time.js", "../../../../../node_modules/drizzle-orm/pg-core/columns/timestamp.js", "../../../../../node_modules/drizzle-orm/pg-core/columns/uuid.js", "../../../../../node_modules/drizzle-orm/pg-core/columns/varchar.js", "../../../../../node_modules/drizzle-orm/pg-core/columns/vector_extension/bit.js", "../../../../../node_modules/drizzle-orm/pg-core/columns/vector_extension/halfvec.js", "../../../../../node_modules/drizzle-orm/pg-core/columns/vector_extension/sparsevec.js", "../../../../../node_modules/drizzle-orm/pg-core/columns/vector_extension/vector.js", "../../../../../node_modules/drizzle-orm/pg-core/columns/all.js", "../../../../../node_modules/drizzle-orm/pg-core/table.js", "../../../../../node_modules/drizzle-orm/pg-core/primary-keys.js", "../../../../../node_modules/drizzle-orm/sql/expressions/conditions.js", "../../../../../node_modules/drizzle-orm/sql/expressions/select.js", "../../../../../node_modules/drizzle-orm/sql/expressions/index.js", "../../../../../node_modules/drizzle-orm/relations.js", "../../../../../node_modules/drizzle-orm/sql/functions/aggregate.js", "../../../../../node_modules/drizzle-orm/sql/functions/vector.js", "../../../../../node_modules/drizzle-orm/sql/functions/index.js", "../../../../../node_modules/drizzle-orm/sql/index.js", "../../../../../node_modules/drizzle-orm/index.js", "../../../../../node_modules/drizzle-orm/pg-core/checks.js", "../../../../../node_modules/drizzle-orm/pg-core/columns/index.js", "../../../../../node_modules/drizzle-orm/selection-proxy.js", "../../../../../node_modules/drizzle-orm/pg-core/indexes.js", "../../../../../node_modules/drizzle-orm/pg-core/policies.js", "../../../../../node_modules/drizzle-orm/pg-core/view-common.js", "../../../../../node_modules/drizzle-orm/casing.js", "../../../../../node_modules/drizzle-orm/pg-core/view-base.js", "../../../../../node_modules/drizzle-orm/pg-core/dialect.js", "../../../../../node_modules/drizzle-orm/query-builders/query-builder.js", "../../../../../node_modules/drizzle-orm/pg-core/query-builders/select.js", "../../../../../node_modules/drizzle-orm/pg-core/query-builders/query-builder.js", "../../../../../node_modules/drizzle-orm/pg-core/view.js", "../../../../../node_modules/drizzle-orm/pg-core/utils.js", "../../../../../node_modules/drizzle-orm/pg-core/query-builders/delete.js", "../../../../../node_modules/drizzle-orm/pg-core/query-builders/insert.js", "../../../../../node_modules/drizzle-orm/pg-core/query-builders/refresh-materialized-view.js", "../../../../../node_modules/drizzle-orm/pg-core/query-builders/update.js", "../../../../../node_modules/drizzle-orm/pg-core/query-builders/index.js", "../../../../../node_modules/drizzle-orm/pg-core/query-builders/count.js", "../../../../../node_modules/drizzle-orm/pg-core/query-builders/query.js", "../../../../../node_modules/drizzle-orm/pg-core/query-builders/raw.js", "../../../../../node_modules/drizzle-orm/pg-core/db.js", "../../../../../node_modules/drizzle-orm/cache/core/cache.js", "../../../../../node_modules/drizzle-orm/pg-core/session.js", "../../../../../node_modules/drizzle-orm/pg-core/utils/index.js", "../../../../../node_modules/drizzle-orm/pg-core/index.js", "../../schema/agent.ts", "../../schema/server.ts", "../../types.ts", "../../migrations.ts", "../../rls.ts", "../../runtime-migrator/drizzle-adapters/diff-calculator.ts", "../../runtime-migrator/crypto-utils.ts", "../../runtime-migrator/drizzle-adapters/snapshot-generator.ts", "../../runtime-migrator/drizzle-adapters/sql-generator.ts", "../../runtime-migrator/drizzle-adapters/database-introspector.ts", "../../runtime-migrator/extension-manager.ts", "../../runtime-migrator/schema-transformer.ts", "../../runtime-migrator/storage/journal-storage.ts", "../../runtime-migrator/storage/migration-tracker.ts", "../../runtime-migrator/storage/snapshot-storage.ts", "../../runtime-migrator/runtime-migrator.ts", "../../runtime-migrator/index.ts", "../../migration-service.ts", "../../index.node.ts", "../../pg/adapter.ts", "../../base.ts", "../../schema/embedding.ts", "../../schema/memory.ts", "../../schema/entity.ts", "../../schema/room.ts", "../../schema/index.ts", "../../schema/cache.ts", "../../schema/channel.ts", "../../schema/messageServer.ts", "../../schema/channelParticipant.ts", "../../schema/component.ts", "../../schema/world.ts", "../../schema/log.ts", "../../schema/message.ts", "../../schema/messageServerAgent.ts", "../../schema/participant.ts", "../../schema/relationship.ts", "../../schema/tasks.ts", "../../pg/manager.ts", "../../../../../node_modules/drizzle-orm/node-postgres/driver.js", "../../../../../node_modules/drizzle-orm/node-postgres/session.js", "../../pglite/adapter.ts", "../../../../../node_modules/drizzle-orm/pglite/driver.js", "../../../../../node_modules/drizzle-orm/pglite/session.js", "../../pglite/manager.ts", "../../utils.node.ts"],
3
+ "sources": ["../../node_modules/drizzle-orm/entity.js", "../../node_modules/drizzle-orm/column.js", "../../node_modules/drizzle-orm/column-builder.js", "../../node_modules/drizzle-orm/table.utils.js", "../../node_modules/drizzle-orm/pg-core/foreign-keys.js", "../../node_modules/drizzle-orm/tracing-utils.js", "../../node_modules/drizzle-orm/pg-core/unique-constraint.js", "../../node_modules/drizzle-orm/pg-core/utils/array.js", "../../node_modules/drizzle-orm/pg-core/columns/common.js", "../../node_modules/drizzle-orm/pg-core/columns/enum.js", "../../node_modules/drizzle-orm/subquery.js", "../../node_modules/drizzle-orm/version.js", "../../node_modules/drizzle-orm/tracing.js", "../../node_modules/drizzle-orm/view-common.js", "../../node_modules/drizzle-orm/table.js", "../../node_modules/drizzle-orm/sql/sql.js", "../../node_modules/drizzle-orm/alias.js", "../../node_modules/drizzle-orm/errors.js", "../../node_modules/drizzle-orm/logger.js", "../../node_modules/drizzle-orm/query-promise.js", "../../node_modules/drizzle-orm/utils.js", "../../node_modules/drizzle-orm/pg-core/columns/int.common.js", "../../node_modules/drizzle-orm/pg-core/columns/bigint.js", "../../node_modules/drizzle-orm/pg-core/columns/bigserial.js", "../../node_modules/drizzle-orm/pg-core/columns/boolean.js", "../../node_modules/drizzle-orm/pg-core/columns/char.js", "../../node_modules/drizzle-orm/pg-core/columns/cidr.js", "../../node_modules/drizzle-orm/pg-core/columns/custom.js", "../../node_modules/drizzle-orm/pg-core/columns/date.common.js", "../../node_modules/drizzle-orm/pg-core/columns/date.js", "../../node_modules/drizzle-orm/pg-core/columns/double-precision.js", "../../node_modules/drizzle-orm/pg-core/columns/inet.js", "../../node_modules/drizzle-orm/pg-core/columns/integer.js", "../../node_modules/drizzle-orm/pg-core/columns/interval.js", "../../node_modules/drizzle-orm/pg-core/columns/json.js", "../../node_modules/drizzle-orm/pg-core/columns/jsonb.js", "../../node_modules/drizzle-orm/pg-core/columns/line.js", "../../node_modules/drizzle-orm/pg-core/columns/macaddr.js", "../../node_modules/drizzle-orm/pg-core/columns/macaddr8.js", "../../node_modules/drizzle-orm/pg-core/columns/numeric.js", "../../node_modules/drizzle-orm/pg-core/columns/point.js", "../../node_modules/drizzle-orm/pg-core/columns/postgis_extension/utils.js", "../../node_modules/drizzle-orm/pg-core/columns/postgis_extension/geometry.js", "../../node_modules/drizzle-orm/pg-core/columns/real.js", "../../node_modules/drizzle-orm/pg-core/columns/serial.js", "../../node_modules/drizzle-orm/pg-core/columns/smallint.js", "../../node_modules/drizzle-orm/pg-core/columns/smallserial.js", "../../node_modules/drizzle-orm/pg-core/columns/text.js", "../../node_modules/drizzle-orm/pg-core/columns/time.js", "../../node_modules/drizzle-orm/pg-core/columns/timestamp.js", "../../node_modules/drizzle-orm/pg-core/columns/uuid.js", "../../node_modules/drizzle-orm/pg-core/columns/varchar.js", "../../node_modules/drizzle-orm/pg-core/columns/vector_extension/bit.js", "../../node_modules/drizzle-orm/pg-core/columns/vector_extension/halfvec.js", "../../node_modules/drizzle-orm/pg-core/columns/vector_extension/sparsevec.js", "../../node_modules/drizzle-orm/pg-core/columns/vector_extension/vector.js", "../../node_modules/drizzle-orm/pg-core/columns/all.js", "../../node_modules/drizzle-orm/pg-core/table.js", "../../node_modules/drizzle-orm/pg-core/primary-keys.js", "../../node_modules/drizzle-orm/sql/expressions/conditions.js", "../../node_modules/drizzle-orm/sql/expressions/select.js", "../../node_modules/drizzle-orm/sql/expressions/index.js", "../../node_modules/drizzle-orm/relations.js", "../../node_modules/drizzle-orm/sql/functions/aggregate.js", "../../node_modules/drizzle-orm/sql/functions/vector.js", "../../node_modules/drizzle-orm/sql/functions/index.js", "../../node_modules/drizzle-orm/sql/index.js", "../../node_modules/drizzle-orm/index.js", "../../node_modules/drizzle-orm/pg-core/checks.js", "../../node_modules/drizzle-orm/pg-core/columns/index.js", "../../node_modules/drizzle-orm/selection-proxy.js", "../../node_modules/drizzle-orm/pg-core/indexes.js", "../../node_modules/drizzle-orm/pg-core/policies.js", "../../node_modules/drizzle-orm/pg-core/view-common.js", "../../node_modules/drizzle-orm/casing.js", "../../node_modules/drizzle-orm/pg-core/view-base.js", "../../node_modules/drizzle-orm/pg-core/dialect.js", "../../node_modules/drizzle-orm/query-builders/query-builder.js", "../../node_modules/drizzle-orm/pg-core/query-builders/select.js", "../../node_modules/drizzle-orm/pg-core/query-builders/query-builder.js", "../../node_modules/drizzle-orm/pg-core/view.js", "../../node_modules/drizzle-orm/pg-core/utils.js", "../../node_modules/drizzle-orm/pg-core/query-builders/delete.js", "../../node_modules/drizzle-orm/pg-core/query-builders/insert.js", "../../node_modules/drizzle-orm/pg-core/query-builders/refresh-materialized-view.js", "../../node_modules/drizzle-orm/pg-core/query-builders/update.js", "../../node_modules/drizzle-orm/pg-core/query-builders/index.js", "../../node_modules/drizzle-orm/pg-core/query-builders/count.js", "../../node_modules/drizzle-orm/pg-core/query-builders/query.js", "../../node_modules/drizzle-orm/pg-core/query-builders/raw.js", "../../node_modules/drizzle-orm/pg-core/db.js", "../../node_modules/drizzle-orm/cache/core/cache.js", "../../node_modules/drizzle-orm/pg-core/session.js", "../../node_modules/drizzle-orm/pg-core/utils/index.js", "../../node_modules/drizzle-orm/pg-core/index.js", "../../schema/agent.ts", "../../schema/server.ts", "../../types.ts", "../../migrations.ts", "../../rls.ts", "../../runtime-migrator/drizzle-adapters/diff-calculator.ts", "../../runtime-migrator/crypto-utils.ts", "../../runtime-migrator/drizzle-adapters/snapshot-generator.ts", "../../runtime-migrator/drizzle-adapters/sql-generator.ts", "../../runtime-migrator/drizzle-adapters/database-introspector.ts", "../../runtime-migrator/extension-manager.ts", "../../runtime-migrator/schema-transformer.ts", "../../runtime-migrator/storage/journal-storage.ts", "../../runtime-migrator/storage/migration-tracker.ts", "../../runtime-migrator/storage/snapshot-storage.ts", "../../runtime-migrator/runtime-migrator.ts", "../../runtime-migrator/index.ts", "../../migration-service.ts", "../../index.node.ts", "../../pg/adapter.ts", "../../base.ts", "../../schema/embedding.ts", "../../schema/memory.ts", "../../schema/entity.ts", "../../schema/room.ts", "../../schema/index.ts", "../../schema/cache.ts", "../../schema/channel.ts", "../../schema/messageServer.ts", "../../schema/channelParticipant.ts", "../../schema/component.ts", "../../schema/world.ts", "../../schema/log.ts", "../../schema/message.ts", "../../schema/messageServerAgent.ts", "../../schema/pairingAllowlist.ts", "../../schema/pairingRequest.ts", "../../schema/participant.ts", "../../schema/relationship.ts", "../../schema/tasks.ts", "../../pg/manager.ts", "../../node_modules/drizzle-orm/node-postgres/driver.js", "../../node_modules/drizzle-orm/node-postgres/session.js", "../../pglite/adapter.ts", "../../node_modules/drizzle-orm/pglite/driver.js", "../../node_modules/drizzle-orm/pglite/session.js", "../../pglite/manager.ts", "../../utils.node.ts"],
4
4
  "sourcesContent": [
5
5
  "const entityKind = Symbol.for(\"drizzle:entityKind\");\nconst hasOwnEntityKind = Symbol.for(\"drizzle:hasOwnEntityKind\");\nfunction is(value, type) {\n if (!value || typeof value !== \"object\") {\n return false;\n }\n if (value instanceof type) {\n return true;\n }\n if (!Object.prototype.hasOwnProperty.call(type, entityKind)) {\n throw new Error(\n `Class \"${type.name ?? \"<unknown>\"}\" doesn't look like a Drizzle entity. If this is incorrect and the class is provided by Drizzle, please report this as a bug.`\n );\n }\n let cls = Object.getPrototypeOf(value).constructor;\n if (cls) {\n while (cls) {\n if (entityKind in cls && cls[entityKind] === type[entityKind]) {\n return true;\n }\n cls = Object.getPrototypeOf(cls);\n }\n }\n return false;\n}\nexport {\n entityKind,\n hasOwnEntityKind,\n is\n};\n//# sourceMappingURL=entity.js.map",
6
6
  "import { entityKind } from \"./entity.js\";\nclass Column {\n constructor(table, config) {\n this.table = table;\n this.config = config;\n this.name = config.name;\n this.keyAsName = config.keyAsName;\n this.notNull = config.notNull;\n this.default = config.default;\n this.defaultFn = config.defaultFn;\n this.onUpdateFn = config.onUpdateFn;\n this.hasDefault = config.hasDefault;\n this.primary = config.primaryKey;\n this.isUnique = config.isUnique;\n this.uniqueName = config.uniqueName;\n this.uniqueType = config.uniqueType;\n this.dataType = config.dataType;\n this.columnType = config.columnType;\n this.generated = config.generated;\n this.generatedIdentity = config.generatedIdentity;\n }\n static [entityKind] = \"Column\";\n name;\n keyAsName;\n primary;\n notNull;\n default;\n defaultFn;\n onUpdateFn;\n hasDefault;\n isUnique;\n uniqueName;\n uniqueType;\n dataType;\n columnType;\n enumValues = void 0;\n generated = void 0;\n generatedIdentity = void 0;\n config;\n mapFromDriverValue(value) {\n return value;\n }\n mapToDriverValue(value) {\n return value;\n }\n // ** @internal */\n shouldDisableInsert() {\n return this.config.generated !== void 0 && this.config.generated.type !== \"byDefault\";\n }\n}\nexport {\n Column\n};\n//# sourceMappingURL=column.js.map",
@@ -97,54 +97,56 @@
97
97
  "import { hashQuery, NoopCache } from \"../cache/core/cache.js\";\nimport { entityKind, is } from \"../entity.js\";\nimport { DrizzleQueryError, TransactionRollbackError } from \"../errors.js\";\nimport { sql } from \"../sql/index.js\";\nimport { tracer } from \"../tracing.js\";\nimport { PgDatabase } from \"./db.js\";\nclass PgPreparedQuery {\n constructor(query, cache, queryMetadata, cacheConfig) {\n this.query = query;\n this.cache = cache;\n this.queryMetadata = queryMetadata;\n this.cacheConfig = cacheConfig;\n if (cache && cache.strategy() === \"all\" && cacheConfig === void 0) {\n this.cacheConfig = { enable: true, autoInvalidate: true };\n }\n if (!this.cacheConfig?.enable) {\n this.cacheConfig = void 0;\n }\n }\n authToken;\n getQuery() {\n return this.query;\n }\n mapResult(response, _isFromBatch) {\n return response;\n }\n /** @internal */\n setToken(token) {\n this.authToken = token;\n return this;\n }\n static [entityKind] = \"PgPreparedQuery\";\n /** @internal */\n joinsNotNullableMap;\n /** @internal */\n async queryWithCache(queryString, params, query) {\n if (this.cache === void 0 || is(this.cache, NoopCache) || this.queryMetadata === void 0) {\n try {\n return await query();\n } catch (e) {\n throw new DrizzleQueryError(queryString, params, e);\n }\n }\n if (this.cacheConfig && !this.cacheConfig.enable) {\n try {\n return await query();\n } catch (e) {\n throw new DrizzleQueryError(queryString, params, e);\n }\n }\n if ((this.queryMetadata.type === \"insert\" || this.queryMetadata.type === \"update\" || this.queryMetadata.type === \"delete\") && this.queryMetadata.tables.length > 0) {\n try {\n const [res] = await Promise.all([\n query(),\n this.cache.onMutate({ tables: this.queryMetadata.tables })\n ]);\n return res;\n } catch (e) {\n throw new DrizzleQueryError(queryString, params, e);\n }\n }\n if (!this.cacheConfig) {\n try {\n return await query();\n } catch (e) {\n throw new DrizzleQueryError(queryString, params, e);\n }\n }\n if (this.queryMetadata.type === \"select\") {\n const fromCache = await this.cache.get(\n this.cacheConfig.tag ?? (await hashQuery(queryString, params)),\n this.queryMetadata.tables,\n this.cacheConfig.tag !== void 0,\n this.cacheConfig.autoInvalidate\n );\n if (fromCache === void 0) {\n let result;\n try {\n result = await query();\n } catch (e) {\n throw new DrizzleQueryError(queryString, params, e);\n }\n await this.cache.put(\n this.cacheConfig.tag ?? (await hashQuery(queryString, params)),\n result,\n // make sure we send tables that were used in a query only if user wants to invalidate it on each write\n this.cacheConfig.autoInvalidate ? this.queryMetadata.tables : [],\n this.cacheConfig.tag !== void 0,\n this.cacheConfig.config\n );\n return result;\n }\n return fromCache;\n }\n try {\n return await query();\n } catch (e) {\n throw new DrizzleQueryError(queryString, params, e);\n }\n }\n}\nclass PgSession {\n constructor(dialect) {\n this.dialect = dialect;\n }\n static [entityKind] = \"PgSession\";\n /** @internal */\n execute(query, token) {\n return tracer.startActiveSpan(\"drizzle.operation\", () => {\n const prepared = tracer.startActiveSpan(\"drizzle.prepareQuery\", () => {\n return this.prepareQuery(\n this.dialect.sqlToQuery(query),\n void 0,\n void 0,\n false\n );\n });\n return prepared.setToken(token).execute(void 0, token);\n });\n }\n all(query) {\n return this.prepareQuery(\n this.dialect.sqlToQuery(query),\n void 0,\n void 0,\n false\n ).all();\n }\n /** @internal */\n async count(sql2, token) {\n const res = await this.execute(sql2, token);\n return Number(\n res[0][\"count\"]\n );\n }\n}\nclass PgTransaction extends PgDatabase {\n constructor(dialect, session, schema, nestedIndex = 0) {\n super(dialect, session, schema);\n this.schema = schema;\n this.nestedIndex = nestedIndex;\n }\n static [entityKind] = \"PgTransaction\";\n rollback() {\n throw new TransactionRollbackError();\n }\n /** @internal */\n getTransactionConfigSQL(config) {\n const chunks = [];\n if (config.isolationLevel) {\n chunks.push(`isolation level ${config.isolationLevel}`);\n }\n if (config.accessMode) {\n chunks.push(config.accessMode);\n }\n if (typeof config.deferrable === \"boolean\") {\n chunks.push(config.deferrable ? \"deferrable\" : \"not deferrable\");\n }\n return sql.raw(chunks.join(\" \"));\n }\n setTransaction(config) {\n return this.session.execute(sql`set transaction ${this.getTransactionConfigSQL(config)}`);\n }\n}\nexport {\n PgPreparedQuery,\n PgSession,\n PgTransaction\n};\n//# sourceMappingURL=session.js.map",
98
98
  "export * from \"./array.js\";\n//# sourceMappingURL=index.js.map",
99
99
  "export * from \"./alias.js\";\nexport * from \"./checks.js\";\nexport * from \"./columns/index.js\";\nexport * from \"./db.js\";\nexport * from \"./dialect.js\";\nexport * from \"./foreign-keys.js\";\nexport * from \"./indexes.js\";\nexport * from \"./policies.js\";\nexport * from \"./primary-keys.js\";\nexport * from \"./query-builders/index.js\";\nexport * from \"./roles.js\";\nexport * from \"./schema.js\";\nexport * from \"./sequence.js\";\nexport * from \"./session.js\";\nexport * from \"./subquery.js\";\nexport * from \"./table.js\";\nexport * from \"./unique-constraint.js\";\nexport * from \"./utils.js\";\nexport * from \"./utils/index.js\";\nexport * from \"./view-common.js\";\nexport * from \"./view.js\";\n//# sourceMappingURL=index.js.map",
100
- "import type { MessageExample } from \"@elizaos/core\";\nimport { sql } from \"drizzle-orm\";\nimport { boolean, jsonb, pgTable, text, timestamp, uuid } from \"drizzle-orm/pg-core\";\n\n/**\n * Represents a table for storing agent data.\n *\n * @type {Table}\n */\nexport const agentTable = pgTable(\"agents\", {\n id: uuid(\"id\").primaryKey().defaultRandom(),\n enabled: boolean(\"enabled\").default(true).notNull(),\n server_id: uuid(\"server_id\"),\n createdAt: timestamp(\"created_at\", { withTimezone: true }).default(sql`now()`).notNull(),\n\n updatedAt: timestamp(\"updated_at\", { withTimezone: true }).default(sql`now()`).notNull(),\n\n // Character\n name: text(\"name\").notNull(),\n username: text(\"username\"),\n system: text(\"system\").default(\"\"),\n bio: jsonb(\"bio\").$type<string | string[]>().default(sql`'[]'::jsonb`),\n messageExamples: jsonb(\"message_examples\")\n .$type<MessageExample[][]>()\n .default(sql`'[]'::jsonb`)\n .notNull(),\n postExamples: jsonb(\"post_examples\").$type<string[]>().default(sql`'[]'::jsonb`).notNull(),\n topics: jsonb(\"topics\").$type<string[]>().default(sql`'[]'::jsonb`).notNull(),\n adjectives: jsonb(\"adjectives\").$type<string[]>().default(sql`'[]'::jsonb`).notNull(),\n knowledge: jsonb(\"knowledge\")\n .$type<(string | { path: string; shared?: boolean })[]>()\n .default(sql`'[]'::jsonb`)\n .notNull(),\n plugins: jsonb(\"plugins\").$type<string[]>().default(sql`'[]'::jsonb`).notNull(),\n settings: jsonb(\"settings\")\n .$type<{\n secrets?: { [key: string]: string | boolean | number };\n [key: string]: string | boolean | number | Record<string, unknown> | undefined;\n }>()\n .default(sql`'{}'::jsonb`)\n .notNull(),\n style: jsonb(\"style\")\n .$type<{\n all?: string[];\n chat?: string[];\n post?: string[];\n }>()\n .default(sql`'{}'::jsonb`)\n .notNull(),\n});\n",
101
- "import { sql } from \"drizzle-orm\";\nimport { pgTable, timestamp, uuid } from \"drizzle-orm/pg-core\";\n\n/**\n * Represents a table for storing server data for RLS multi-tenant isolation.\n * Each server represents one elizaOS instance in a multi-tenant deployment.\n *\n * @type {Table}\n */\nexport const serverTable = pgTable(\"servers\", {\n id: uuid(\"id\").primaryKey(),\n createdAt: timestamp(\"created_at\", { withTimezone: true }).default(sql`now()`).notNull(),\n updatedAt: timestamp(\"updated_at\", { withTimezone: true }).default(sql`now()`).notNull(),\n});\n",
102
- "import type { IDatabaseAdapter } from \"@elizaos/core\";\nimport type { NodePgDatabase } from \"drizzle-orm/node-postgres\";\nimport type { PgliteDatabase } from \"drizzle-orm/pglite\";\n\nexport type DrizzleDatabase = NodePgDatabase | PgliteDatabase;\n\nexport interface IDatabaseClientManager<T> {\n initialize(): Promise<void>;\n getConnection(): T;\n close(): Promise<void>;\n}\n\nexport function getDb(adapter: IDatabaseAdapter): DrizzleDatabase {\n return adapter.db as DrizzleDatabase;\n}\n\nexport function getRow<T>(result: { rows: unknown[] }, index = 0): T | undefined {\n return result.rows[index] as T | undefined;\n}\n",
103
- "import { type IDatabaseAdapter, logger } from \"@elizaos/core\";\nimport { sql } from \"drizzle-orm\";\nimport { getDb } from \"./types\";\n\n// Column info row for schema introspection queries\ninterface ColumnInfoRow {\n column_name: string;\n data_type: string;\n}\n\n// Table info row for schema introspection queries\ninterface TableInfoRow {\n table_name: string;\n}\n\n/**\n * Type-safe extraction of rows from SQL query results.\n */\nfunction getRows<T>(result: { rows: unknown[] }): T[] {\n return result.rows as T[];\n}\n\n/**\n * TEMPORARY MIGRATION: pre-1.6.5 → 1.6.5+ schema migration\n *\n * This migration runs automatically on startup and is idempotent.\n * It handles the migration from Owner RLS to Server RLS + Entity RLS, including:\n * - Disabling old RLS policies temporarily\n * - Renaming server_id → message_server_id in channels, worlds, rooms\n * - Converting TEXT → UUID where needed\n * - Dropping old server_id columns for RLS\n * - Cleaning up indexes\n *\n * @param adapter - Database adapter\n */\nexport async function migrateToEntityRLS(adapter: IDatabaseAdapter): Promise<void> {\n const db = getDb(adapter);\n\n // Detect database type - skip PostgreSQL-specific migrations for SQLite\n try {\n await db.execute(sql`SELECT 1 FROM pg_tables LIMIT 1`);\n } catch {\n // Not PostgreSQL (likely SQLite)\n logger.debug(\"[Migration] ⊘ Not PostgreSQL, skipping PostgreSQL-specific migrations\");\n return;\n }\n\n // Check if schema migration has already been completed\n // We use the presence of snake_case columns as a marker\n let schemaAlreadyMigrated = false;\n try {\n const migrationCheck = await db.execute(sql`\n SELECT column_name FROM information_schema.columns\n WHERE table_schema = 'public'\n AND table_name = 'rooms'\n AND column_name = 'agent_id'\n `);\n\n if (migrationCheck.rows && migrationCheck.rows.length > 0) {\n // Migration already completed - rooms.agent_id exists (snake_case)\n schemaAlreadyMigrated = true;\n logger.debug(\"[Migration] ⊘ Schema already migrated (snake_case columns exist)\");\n }\n } catch {\n // Table might not exist yet, continue with migration\n logger.debug(\"[Migration] → rooms table not found, will be created by RuntimeMigrator\");\n return; // Let RuntimeMigrator create fresh tables\n }\n\n // If schema is already migrated, check if we need to clean up RLS\n // Only disable RLS if ENABLE_DATA_ISOLATION is NOT true (user disabled isolation)\n // If ENABLE_DATA_ISOLATION=true, keep RLS as-is - migration-service.ts will ensure proper config\n if (schemaAlreadyMigrated) {\n const dataIsolationEnabled = process.env.ENABLE_DATA_ISOLATION === \"true\";\n\n if (dataIsolationEnabled) {\n // RLS should stay enabled - no need to disable/re-enable cycle\n // migration-service.ts ensures RLS is properly configured via idempotent calls\n logger.debug(\"[Migration] ⊘ Schema already migrated, RLS enabled - nothing to do\");\n return;\n }\n\n // User disabled data isolation - clean up RLS if it was previously enabled\n logger.debug(\"[Migration] → Schema migrated but RLS disabled, cleaning up...\");\n\n try {\n const tablesWithRls = await db.execute(sql`\n SELECT c.relname as tablename\n FROM pg_class c\n JOIN pg_namespace n ON n.oid = c.relnamespace\n WHERE n.nspname = 'public'\n AND c.relkind = 'r'\n AND c.relrowsecurity = true\n ORDER BY c.relname\n `);\n\n if (tablesWithRls.rows && tablesWithRls.rows.length > 0) {\n for (const row of tablesWithRls.rows) {\n const tableName = row.tablename as string;\n try {\n await db.execute(sql.raw(`ALTER TABLE \"${tableName}\" DISABLE ROW LEVEL SECURITY`));\n } catch {\n // Ignore errors\n }\n }\n logger.debug(`[Migration] ✓ RLS cleanup completed (${tablesWithRls.rows.length} tables)`);\n } else {\n logger.debug(\"[Migration] ⊘ No tables with RLS to clean up\");\n }\n } catch {\n logger.debug(\"[Migration] ⊘ Could not perform RLS cleanup\");\n }\n\n return;\n }\n\n logger.info(\"[Migration] Starting pre-1.6.5 → 1.6.5+ schema migration...\");\n\n try {\n // Clear RuntimeMigrator snapshot cache to force fresh introspection\n // This ensures the snapshot matches the current database state after our migrations\n logger.debug(\"[Migration] → Clearing RuntimeMigrator snapshot cache...\");\n try {\n await db.execute(\n sql`DELETE FROM migrations._snapshots WHERE plugin_name = '@elizaos/plugin-sql'`\n );\n logger.debug(\"[Migration] ✓ Snapshot cache cleared\");\n } catch (_error) {\n // If migrations schema doesn't exist yet, that's fine - no cache to clear\n logger.debug(\"[Migration] ⊘ No snapshot cache to clear (migrations schema not yet created)\");\n }\n\n // Disable RLS only on tables that have it enabled\n // RLS will be re-implemented properly later\n logger.debug(\"[Migration] → Checking for Row Level Security to disable...\");\n try {\n const tablesWithRls = await db.execute(sql`\n SELECT c.relname as tablename\n FROM pg_class c\n JOIN pg_namespace n ON n.oid = c.relnamespace\n WHERE n.nspname = 'public'\n AND c.relkind = 'r'\n AND c.relrowsecurity = true\n ORDER BY c.relname\n `);\n\n if (tablesWithRls.rows && tablesWithRls.rows.length > 0) {\n for (const row of tablesWithRls.rows) {\n const tableName = row.tablename as string;\n try {\n await db.execute(sql.raw(`ALTER TABLE \"${tableName}\" DISABLE ROW LEVEL SECURITY`));\n logger.debug(`[Migration] ✓ Disabled RLS on ${tableName}`);\n } catch (_error) {\n logger.debug(`[Migration] ⊘ Could not disable RLS on ${tableName}`);\n }\n }\n } else {\n logger.debug(\"[Migration] ⊘ No tables with RLS enabled\");\n }\n } catch (_error) {\n logger.debug(\"[Migration] ⊘ Could not check RLS (may not have permissions)\");\n }\n\n // Special handling for tables where serverId/server_id needs to become message_server_id\n // v1.6.4 had: rooms.serverId (TEXT camelCase), worlds.serverId (TEXT camelCase), channels.server_id (UUID)\n // Current: message_server_id (UUID) in all tables\n //\n // STRATEGY: Rename serverId/server_id to message_server_id preserving data\n logger.debug(\"[Migration] → Handling serverId/server_id → message_server_id migrations...\");\n\n const tablesToMigrate = [\"channels\", \"worlds\", \"rooms\"];\n\n for (const tableName of tablesToMigrate) {\n try {\n // Check for both camelCase (serverId) and snake_case (server_id) columns\n const columnsResult = await db.execute(sql`\n SELECT column_name, data_type, is_nullable\n FROM information_schema.columns\n WHERE table_schema = 'public'\n AND table_name = ${tableName}\n AND column_name IN ('server_id', 'serverId', 'message_server_id')\n ORDER BY column_name\n `);\n\n const columns = getRows<ColumnInfoRow>(columnsResult);\n const serverIdSnake = columns.find((c) => c.column_name === \"server_id\");\n const serverIdCamel = columns.find((c) => c.column_name === \"serverId\");\n const messageServerId = columns.find((c) => c.column_name === \"message_server_id\");\n\n // Use whichever old column exists (prefer snake_case for channels)\n const serverId = serverIdSnake || serverIdCamel;\n const oldColumnName = serverIdSnake ? \"server_id\" : \"serverId\";\n\n if (serverId && !messageServerId) {\n // Old column exists → rename it to message_server_id\n logger.debug(\n `[Migration] → Renaming ${tableName}.${oldColumnName} to message_server_id...`\n );\n await db.execute(\n sql.raw(\n `ALTER TABLE \"${tableName}\" RENAME COLUMN \"${oldColumnName}\" TO \"message_server_id\"`\n )\n );\n logger.debug(`[Migration] ✓ Renamed ${tableName}.${oldColumnName} → message_server_id`);\n\n // If the column was text, try to convert to UUID (if data is UUID-compatible)\n if (serverId.data_type === \"text\") {\n // CRITICAL: Drop DEFAULT constraint before type conversion\n // This prevents \"default for column cannot be cast automatically\" errors\n // Wrap in separate try-catch to ensure we continue even if no default exists\n try {\n logger.debug(\n `[Migration] → Dropping DEFAULT constraint on ${tableName}.message_server_id...`\n );\n await db.execute(\n sql.raw(`ALTER TABLE \"${tableName}\" ALTER COLUMN \"message_server_id\" DROP DEFAULT`)\n );\n logger.debug(`[Migration] ✓ Dropped DEFAULT constraint`);\n } catch {\n logger.debug(\n `[Migration] ⊘ No DEFAULT constraint to drop on ${tableName}.message_server_id`\n );\n }\n\n try {\n logger.debug(\n `[Migration] → Converting ${tableName}.message_server_id from text to uuid...`\n );\n // Use robust conversion: valid UUIDs are cast directly, others get md5 hash\n // This handles: empty strings, non-UUID text, uppercase UUIDs, NULL values\n await db.execute(\n sql.raw(`\n ALTER TABLE \"${tableName}\"\n ALTER COLUMN \"message_server_id\" TYPE uuid\n USING CASE\n WHEN \"message_server_id\" IS NULL THEN NULL\n WHEN \"message_server_id\" = '' THEN NULL\n WHEN \"message_server_id\" ~ '^[0-9a-fA-F]{8}-[0-9a-fA-F]{4}-[0-9a-fA-F]{4}-[0-9a-fA-F]{4}-[0-9a-fA-F]{12}$'\n THEN \"message_server_id\"::uuid\n ELSE md5(\"message_server_id\")::uuid\n END\n `)\n );\n logger.debug(`[Migration] ✓ Converted ${tableName}.message_server_id to uuid`);\n } catch (convertError) {\n logger.warn(\n `[Migration] ⚠️ Could not convert ${tableName}.message_server_id to uuid: ${convertError}`\n );\n }\n }\n\n // If the column should be NOT NULL but has NULLs, we need to handle that\n // For channels, it's NOT NULL in the new schema\n if (tableName === \"channels\") {\n const nullCountResult = await db.execute(\n sql.raw(\n `SELECT COUNT(*) as count FROM \"${tableName}\" WHERE \"message_server_id\" IS NULL`\n )\n );\n const nullCount = nullCountResult.rows?.[0]?.count as string | undefined;\n if (nullCount && parseInt(nullCount, 10) > 0) {\n logger.warn(\n `[Migration] ⚠️ ${tableName} has ${nullCount} rows with NULL message_server_id - these will be deleted`\n );\n await db.execute(\n sql.raw(`DELETE FROM \"${tableName}\" WHERE \"message_server_id\" IS NULL`)\n );\n logger.debug(\n `[Migration] ✓ Deleted ${nullCount} rows with NULL message_server_id from ${tableName}`\n );\n }\n\n // Make it NOT NULL\n logger.debug(`[Migration] → Making ${tableName}.message_server_id NOT NULL...`);\n await db.execute(\n sql.raw(`ALTER TABLE \"${tableName}\" ALTER COLUMN \"message_server_id\" SET NOT NULL`)\n );\n logger.debug(`[Migration] ✓ Set ${tableName}.message_server_id NOT NULL`);\n }\n } else if (serverId && messageServerId) {\n // Both exist → just drop the old column\n logger.debug(`[Migration] → ${tableName} has both columns, dropping ${oldColumnName}...`);\n await db.execute(\n sql.raw(`ALTER TABLE \"${tableName}\" DROP COLUMN \"${oldColumnName}\" CASCADE`)\n );\n logger.debug(`[Migration] ✓ Dropped ${tableName}.${oldColumnName}`);\n } else if (!serverId && messageServerId) {\n // Only message_server_id exists - check if it needs type conversion from TEXT to UUID\n // This handles idempotency when migration partially ran before rollback\n if (messageServerId.data_type === \"text\") {\n logger.debug(\n `[Migration] → ${tableName}.message_server_id exists but is TEXT, needs UUID conversion...`\n );\n\n // CRITICAL: Drop DEFAULT constraint before type conversion\n // This prevents \"default for column cannot be cast automatically\" errors\n logger.debug(\n `[Migration] → Dropping DEFAULT constraint on ${tableName}.message_server_id...`\n );\n await db.execute(\n sql.raw(`ALTER TABLE \"${tableName}\" ALTER COLUMN \"message_server_id\" DROP DEFAULT`)\n );\n logger.debug(`[Migration] ✓ Dropped DEFAULT constraint`);\n\n // Convert TEXT to UUID using MD5 hash for non-UUID text values\n // This creates deterministic UUIDs from text values, preserving data\n logger.debug(\n `[Migration] → Converting ${tableName}.message_server_id from text to uuid (generating UUIDs from text)...`\n );\n await db.execute(\n sql.raw(`\n ALTER TABLE \"${tableName}\"\n ALTER COLUMN \"message_server_id\" TYPE uuid\n USING CASE\n WHEN \"message_server_id\" ~ '^[0-9a-fA-F]{8}-[0-9a-fA-F]{4}-[0-9a-fA-F]{4}-[0-9a-fA-F]{4}-[0-9a-fA-F]{12}$'\n THEN \"message_server_id\"::uuid\n ELSE md5(\"message_server_id\")::uuid\n END\n `)\n );\n logger.debug(`[Migration] ✓ Converted ${tableName}.message_server_id to uuid`);\n } else {\n logger.debug(`[Migration] ⊘ ${tableName}.message_server_id already UUID, skipping`);\n }\n } else {\n logger.debug(`[Migration] ⊘ ${tableName} already migrated, skipping`);\n }\n } catch (error) {\n logger.warn(`[Migration] ⚠️ Error migrating ${tableName}.server_id: ${error}`);\n }\n }\n\n // Drop ALL remaining server_id columns (will be re-added by RLS after migrations)\n // This prevents RuntimeMigrator from seeing them and trying to drop them\n // EXCEPT for tables where server_id is part of the schema (like agents, server_agents)\n logger.debug(\"[Migration] → Dropping all remaining RLS-managed server_id columns...\");\n try {\n const serverIdColumnsResult = await db.execute(sql`\n SELECT table_name\n FROM information_schema.columns\n WHERE table_schema = 'public'\n AND column_name = 'server_id'\n AND table_name NOT IN (\n 'servers', -- server_id is the primary key\n 'agents', -- server_id is in the schema (for RLS)\n 'channels', -- already handled above\n 'worlds', -- already handled above\n 'rooms', -- already handled above\n 'server_agents', -- server_id is part of composite key\n 'drizzle_migrations',\n '__drizzle_migrations'\n )\n ORDER BY table_name\n `);\n\n const tablesToClean = serverIdColumnsResult.rows || [];\n logger.debug(`[Migration] → Found ${tablesToClean.length} tables with server_id columns`);\n\n for (const row of tablesToClean) {\n const tableName = row.table_name as string;\n try {\n await db.execute(\n sql.raw(`ALTER TABLE \"${tableName}\" DROP COLUMN IF EXISTS server_id CASCADE`)\n );\n logger.debug(`[Migration] ✓ Dropped server_id from ${tableName}`);\n } catch (_error) {\n logger.debug(`[Migration] ⊘ Could not drop server_id from ${tableName}`);\n }\n }\n } catch (_error) {\n logger.debug(\"[Migration] ⊘ Could not drop server_id columns (may not have permissions)\");\n }\n\n // Special handling for agents table: rename owner_id → server_id\n // v1.6.4 had owner_id, v1.6.5 changed it to server_id\n logger.debug(\"[Migration] → Checking agents.owner_id → server_id rename...\");\n try {\n const agentsColumnsResult = await db.execute(sql`\n SELECT column_name\n FROM information_schema.columns\n WHERE table_schema = 'public'\n AND table_name = 'agents'\n AND column_name IN ('owner_id', 'server_id')\n ORDER BY column_name\n `);\n\n const agentsColumns = getRows<ColumnInfoRow>(agentsColumnsResult);\n const hasOwnerId = agentsColumns.some((c) => c.column_name === \"owner_id\");\n const hasServerId = agentsColumns.some((c) => c.column_name === \"server_id\");\n\n if (hasOwnerId && !hasServerId) {\n // Rename owner_id → server_id\n logger.debug(\"[Migration] → Renaming agents.owner_id to server_id...\");\n await db.execute(sql.raw(`ALTER TABLE \"agents\" RENAME COLUMN \"owner_id\" TO \"server_id\"`));\n logger.debug(\"[Migration] ✓ Renamed agents.owner_id → server_id\");\n } else if (hasOwnerId && hasServerId) {\n // Both exist - drop owner_id (data should be in server_id)\n logger.debug(\"[Migration] → Both owner_id and server_id exist, dropping owner_id...\");\n await db.execute(sql.raw(`ALTER TABLE \"agents\" DROP COLUMN \"owner_id\" CASCADE`));\n logger.debug(\"[Migration] ✓ Dropped agents.owner_id\");\n } else {\n logger.debug(\"[Migration] ⊘ agents table already has server_id (or no owner_id), skipping\");\n }\n } catch (_error) {\n logger.debug(\"[Migration] ⊘ Could not check/migrate agents.owner_id\");\n }\n\n // Migrate data from obsolete 'owners' table to 'servers' (if owners exists)\n // v1.6.4 used owners table, v1.6.5+ uses servers table\n logger.debug(\"[Migration] → Checking for owners → servers data migration...\");\n try {\n const ownersTableResult = await db.execute(sql`\n SELECT table_name\n FROM information_schema.tables\n WHERE table_schema = 'public'\n AND table_name = 'owners'\n `);\n\n if (ownersTableResult.rows && ownersTableResult.rows.length > 0) {\n // First, ensure servers table exists\n logger.debug(\"[Migration] → Ensuring servers table exists...\");\n await db.execute(\n sql.raw(`\n CREATE TABLE IF NOT EXISTS \"servers\" (\n \"id\" uuid PRIMARY KEY,\n \"created_at\" timestamp with time zone DEFAULT now() NOT NULL,\n \"updated_at\" timestamp with time zone DEFAULT now() NOT NULL\n )\n `)\n );\n\n // Migrate data from owners to servers (if any)\n logger.debug(\"[Migration] → Migrating owners data to servers...\");\n await db.execute(\n sql.raw(`\n INSERT INTO \"servers\" (\"id\", \"created_at\", \"updated_at\")\n SELECT \"id\", COALESCE(\"created_at\", now()), COALESCE(\"updated_at\", now())\n FROM \"owners\"\n ON CONFLICT (\"id\") DO NOTHING\n `)\n );\n logger.debug(\"[Migration] ✓ Migrated owners data to servers\");\n\n // Now safe to drop owners table\n logger.debug(\"[Migration] → Dropping obsolete owners table...\");\n await db.execute(sql.raw(`DROP TABLE IF EXISTS \"owners\" CASCADE`));\n logger.debug(\"[Migration] ✓ Dropped obsolete owners table\");\n } else {\n logger.debug(\"[Migration] ⊘ owners table not found, skipping\");\n }\n } catch (error) {\n logger.warn(`[Migration] ⚠️ Could not migrate owners → servers: ${error}`);\n }\n\n // Special handling for server_agents → message_server_agents rename\n // This aligns with the server_id → message_server_id naming convention\n logger.debug(\"[Migration] → Checking server_agents table rename...\");\n try {\n const tablesResult = await db.execute(sql`\n SELECT table_name\n FROM information_schema.tables\n WHERE table_schema = 'public'\n AND table_name IN ('server_agents', 'message_server_agents')\n ORDER BY table_name\n `);\n\n const tables = getRows<TableInfoRow>(tablesResult);\n const hasServerAgents = tables.some((t) => t.table_name === \"server_agents\");\n const hasMessageServerAgents = tables.some((t) => t.table_name === \"message_server_agents\");\n\n if (hasServerAgents && !hasMessageServerAgents) {\n // Rename server_agents → message_server_agents\n logger.debug(\"[Migration] → Renaming server_agents to message_server_agents...\");\n await db.execute(sql.raw(`ALTER TABLE \"server_agents\" RENAME TO \"message_server_agents\"`));\n logger.debug(\"[Migration] ✓ Renamed server_agents → message_server_agents\");\n\n // Now rename server_id column → message_server_id\n logger.debug(\n \"[Migration] → Renaming message_server_agents.server_id to message_server_id...\"\n );\n await db.execute(\n sql.raw(\n `ALTER TABLE \"message_server_agents\" RENAME COLUMN \"server_id\" TO \"message_server_id\"`\n )\n );\n logger.debug(\"[Migration] ✓ Renamed message_server_agents.server_id → message_server_id\");\n } else if (!hasServerAgents && !hasMessageServerAgents) {\n // Neither table exists - RuntimeMigrator will create message_server_agents\n logger.debug(\"[Migration] ⊘ No server_agents table to migrate\");\n } else if (hasMessageServerAgents) {\n // Check if it has the columns and rename if needed\n logger.debug(\"[Migration] → Checking message_server_agents columns...\");\n const columnsResult = await db.execute(sql`\n SELECT column_name\n FROM information_schema.columns\n WHERE table_schema = 'public'\n AND table_name = 'message_server_agents'\n AND column_name IN ('server_id', 'message_server_id')\n ORDER BY column_name\n `);\n\n const columns = getRows<ColumnInfoRow>(columnsResult);\n const hasServerId = columns.some((c) => c.column_name === \"server_id\");\n const hasMessageServerId = columns.some((c) => c.column_name === \"message_server_id\");\n\n if (hasServerId && !hasMessageServerId) {\n // Rename server_id → message_server_id\n logger.debug(\n \"[Migration] → Renaming message_server_agents.server_id to message_server_id...\"\n );\n await db.execute(\n sql.raw(\n `ALTER TABLE \"message_server_agents\" RENAME COLUMN \"server_id\" TO \"message_server_id\"`\n )\n );\n logger.debug(\"[Migration] ✓ Renamed message_server_agents.server_id → message_server_id\");\n } else if (!hasServerId && !hasMessageServerId) {\n // Table exists but doesn't have either column - truncate it\n logger.debug(\n \"[Migration] → message_server_agents exists without required columns, truncating...\"\n );\n await db.execute(sql`TRUNCATE TABLE message_server_agents CASCADE`);\n logger.debug(\"[Migration] ✓ Truncated message_server_agents\");\n } else {\n logger.debug(\"[Migration] ⊘ message_server_agents already has correct schema\");\n }\n }\n } catch (_error) {\n logger.debug(\"[Migration] ⊘ Could not check/migrate server_agents table\");\n }\n\n // Special handling for channel_participants: rename userId → entityId\n // This handles the migration from the old userId column to the new entityId column\n logger.debug(\"[Migration] → Checking channel_participants table...\");\n try {\n const columnsResult = await db.execute(sql`\n SELECT column_name\n FROM information_schema.columns\n WHERE table_schema = 'public'\n AND table_name = 'channel_participants'\n AND column_name IN ('user_id', 'entity_id')\n ORDER BY column_name\n `);\n\n const columns = getRows<ColumnInfoRow>({ rows: columnsResult.rows || [] });\n const hasUserId = columns.some((c) => c.column_name === \"user_id\");\n const hasEntityId = columns.some((c) => c.column_name === \"entity_id\");\n\n if (hasUserId && !hasEntityId) {\n // Rename user_id → entity_id\n logger.debug(\"[Migration] → Renaming channel_participants.user_id to entity_id...\");\n await db.execute(\n sql.raw(`ALTER TABLE \"channel_participants\" RENAME COLUMN \"user_id\" TO \"entity_id\"`)\n );\n logger.debug(\"[Migration] ✓ Renamed channel_participants.user_id → entity_id\");\n } else if (!hasUserId && !hasEntityId) {\n // Table exists but has neither column - truncate it so RuntimeMigrator can add entity_id\n logger.debug(\n \"[Migration] → channel_participants exists without entity_id or user_id, truncating...\"\n );\n await db.execute(sql`TRUNCATE TABLE channel_participants CASCADE`);\n logger.debug(\"[Migration] ✓ Truncated channel_participants\");\n } else {\n logger.debug(\"[Migration] ⊘ channel_participants already has entity_id column\");\n }\n } catch (_error) {\n logger.debug(\"[Migration] ⊘ Could not check/migrate channel_participants\");\n }\n\n // Drop ALL regular indexes (not PK or unique constraints) to avoid conflicts\n // The RuntimeMigrator will recreate them based on the schema\n logger.debug(\"[Migration] → Discovering and dropping all regular indexes...\");\n try {\n const indexesResult = await db.execute(sql`\n SELECT i.relname AS index_name\n FROM pg_index idx\n JOIN pg_class i ON i.oid = idx.indexrelid\n JOIN pg_class c ON c.oid = idx.indrelid\n JOIN pg_namespace n ON n.oid = c.relnamespace\n LEFT JOIN pg_constraint con ON con.conindid = idx.indexrelid\n WHERE n.nspname = 'public'\n AND NOT idx.indisprimary -- Not a primary key\n AND con.contype IS NULL -- Not a constraint (unique, etc)\n ORDER BY i.relname\n `);\n\n const indexesToDrop = indexesResult.rows || [];\n logger.debug(`[Migration] → Found ${indexesToDrop.length} indexes to drop`);\n\n for (const row of indexesToDrop) {\n const indexName = row.index_name as string;\n try {\n await db.execute(sql.raw(`DROP INDEX IF EXISTS \"${indexName}\"`));\n logger.debug(`[Migration] ✓ Dropped index ${indexName}`);\n } catch (_error) {\n logger.debug(`[Migration] ⊘ Could not drop index ${indexName}`);\n }\n }\n } catch (_error) {\n logger.debug(\"[Migration] ⊘ Could not drop indexes (may not have permissions)\");\n }\n\n // =========================================================================\n // SMOOTH MIGRATION: camelCase → snake_case column renames\n // This ensures a non-destructive transition from v1.6.4 to v1.6.5+\n // All data is preserved through RENAME COLUMN operations\n // This section can be removed once all deployments have been migrated\n // =========================================================================\n logger.debug(\"[Migration] → Starting camelCase → snake_case column renames...\");\n\n const columnRenames = [\n // rooms table\n { table: \"rooms\", from: \"agentId\", to: \"agent_id\" },\n { table: \"rooms\", from: \"worldId\", to: \"world_id\" },\n { table: \"rooms\", from: \"channelId\", to: \"channel_id\" },\n { table: \"rooms\", from: \"createdAt\", to: \"created_at\" },\n\n // worlds table\n { table: \"worlds\", from: \"agentId\", to: \"agent_id\" },\n { table: \"worlds\", from: \"createdAt\", to: \"created_at\" },\n\n // memories table\n { table: \"memories\", from: \"createdAt\", to: \"created_at\" },\n { table: \"memories\", from: \"entityId\", to: \"entity_id\" },\n { table: \"memories\", from: \"agentId\", to: \"agent_id\" },\n { table: \"memories\", from: \"roomId\", to: \"room_id\" },\n { table: \"memories\", from: \"worldId\", to: \"world_id\" },\n\n // components table\n { table: \"components\", from: \"entityId\", to: \"entity_id\" },\n { table: \"components\", from: \"agentId\", to: \"agent_id\" },\n { table: \"components\", from: \"roomId\", to: \"room_id\" },\n { table: \"components\", from: \"worldId\", to: \"world_id\" },\n { table: \"components\", from: \"sourceEntityId\", to: \"source_entity_id\" },\n { table: \"components\", from: \"createdAt\", to: \"created_at\" },\n\n // participants table\n { table: \"participants\", from: \"entityId\", to: \"entity_id\" },\n { table: \"participants\", from: \"roomId\", to: \"room_id\" },\n { table: \"participants\", from: \"agentId\", to: \"agent_id\" },\n { table: \"participants\", from: \"roomState\", to: \"room_state\" },\n { table: \"participants\", from: \"createdAt\", to: \"created_at\" },\n\n // relationships table\n {\n table: \"relationships\",\n from: \"sourceEntityId\",\n to: \"source_entity_id\",\n },\n {\n table: \"relationships\",\n from: \"targetEntityId\",\n to: \"target_entity_id\",\n },\n { table: \"relationships\", from: \"agentId\", to: \"agent_id\" },\n { table: \"relationships\", from: \"createdAt\", to: \"created_at\" },\n\n // logs table\n { table: \"logs\", from: \"entityId\", to: \"entity_id\" },\n { table: \"logs\", from: \"roomId\", to: \"room_id\" },\n { table: \"logs\", from: \"createdAt\", to: \"created_at\" },\n\n // tasks table\n { table: \"tasks\", from: \"roomId\", to: \"room_id\" },\n { table: \"tasks\", from: \"worldId\", to: \"world_id\" },\n { table: \"tasks\", from: \"entityId\", to: \"entity_id\" },\n { table: \"tasks\", from: \"createdAt\", to: \"created_at\" },\n { table: \"tasks\", from: \"updatedAt\", to: \"updated_at\" },\n\n // agents table\n { table: \"agents\", from: \"createdAt\", to: \"created_at\" },\n { table: \"agents\", from: \"updatedAt\", to: \"updated_at\" },\n\n // entities table\n { table: \"entities\", from: \"agentId\", to: \"agent_id\" },\n { table: \"entities\", from: \"createdAt\", to: \"created_at\" },\n\n // embeddings table\n { table: \"embeddings\", from: \"memoryId\", to: \"memory_id\" },\n { table: \"embeddings\", from: \"createdAt\", to: \"created_at\" },\n\n // cache table\n { table: \"cache\", from: \"agentId\", to: \"agent_id\" },\n { table: \"cache\", from: \"createdAt\", to: \"created_at\" },\n { table: \"cache\", from: \"expiresAt\", to: \"expires_at\" },\n ];\n\n for (const rename of columnRenames) {\n try {\n // Check if table exists first\n const tableExistsResult = await db.execute(sql`\n SELECT 1 FROM information_schema.tables\n WHERE table_schema = 'public' AND table_name = ${rename.table}\n `);\n\n if (!tableExistsResult.rows || tableExistsResult.rows.length === 0) {\n // Table doesn't exist yet, skip\n continue;\n }\n\n // Check which columns exist\n const columnsResult = await db.execute(sql`\n SELECT column_name\n FROM information_schema.columns\n WHERE table_schema = 'public'\n AND table_name = ${rename.table}\n AND column_name IN (${rename.from}, ${rename.to})\n ORDER BY column_name\n `);\n\n const columns = getRows<ColumnInfoRow>(columnsResult);\n const hasOldColumn = columns.some((c) => c.column_name === rename.from);\n const hasNewColumn = columns.some((c) => c.column_name === rename.to);\n\n if (hasOldColumn && !hasNewColumn) {\n // Old column exists, new doesn't → RENAME (preserves data!)\n logger.debug(`[Migration] → Renaming ${rename.table}.${rename.from} to ${rename.to}...`);\n await db.execute(\n sql.raw(\n `ALTER TABLE \"${rename.table}\" RENAME COLUMN \"${rename.from}\" TO \"${rename.to}\"`\n )\n );\n logger.debug(`[Migration] ✓ Renamed ${rename.table}.${rename.from} → ${rename.to}`);\n } else if (hasOldColumn && hasNewColumn) {\n // Both exist → drop old (data should be in new already)\n logger.debug(\n `[Migration] → Both columns exist, dropping ${rename.table}.${rename.from}...`\n );\n await db.execute(\n sql.raw(`ALTER TABLE \"${rename.table}\" DROP COLUMN \"${rename.from}\" CASCADE`)\n );\n logger.debug(`[Migration] ✓ Dropped ${rename.table}.${rename.from}`);\n }\n // If only new column exists or neither exists, nothing to do\n } catch (error) {\n // Log but continue - table might not exist yet or column might already be renamed\n logger.debug(`[Migration] ⊘ Could not process ${rename.table}.${rename.from}: ${error}`);\n }\n }\n\n logger.debug(\"[Migration] ✓ Completed camelCase → snake_case column renames\");\n\n logger.info(\"[Migration] ✓ Migration complete - pre-1.6.5 → 1.6.5+ schema migration finished\");\n } catch (error) {\n // Re-throw errors to prevent RuntimeMigrator from running on broken state\n logger.error(\"[Migration] Migration failed:\", String(error));\n throw error;\n }\n}\n",
104
- "import { type IDatabaseAdapter, logger, validateUuid } from \"@elizaos/core\";\nimport { eq, sql } from \"drizzle-orm\";\nimport { agentTable } from \"./schema/agent\";\nimport { serverTable } from \"./schema/server\";\nimport { getDb } from \"./types\";\n\nexport async function installRLSFunctions(adapter: IDatabaseAdapter): Promise<void> {\n const db = getDb(adapter);\n\n await db.execute(sql`\n CREATE TABLE IF NOT EXISTS servers (\n id UUID PRIMARY KEY,\n created_at TIMESTAMPTZ DEFAULT NOW() NOT NULL,\n updated_at TIMESTAMPTZ DEFAULT NOW() NOT NULL\n )\n `);\n\n await db.execute(sql`\n CREATE OR REPLACE FUNCTION current_server_id() RETURNS UUID AS $$\n DECLARE\n app_name TEXT;\n BEGIN\n app_name := NULLIF(current_setting('application_name', TRUE), '');\n\n BEGIN\n RETURN app_name::UUID;\n EXCEPTION WHEN OTHERS THEN\n RETURN NULL;\n END;\n END;\n $$ LANGUAGE plpgsql STABLE;\n `);\n\n await db.execute(sql`\n CREATE OR REPLACE FUNCTION add_server_isolation(\n schema_name text,\n table_name text\n ) RETURNS void AS $$\n DECLARE\n full_table_name text;\n column_exists boolean;\n orphaned_count bigint;\n BEGIN\n full_table_name := schema_name || '.' || table_name;\n\n SELECT EXISTS (\n SELECT 1 FROM information_schema.columns\n WHERE information_schema.columns.table_schema = schema_name\n AND information_schema.columns.table_name = add_server_isolation.table_name\n AND information_schema.columns.column_name = 'server_id'\n ) INTO column_exists;\n\n IF NOT column_exists THEN\n EXECUTE format('ALTER TABLE %I.%I ADD COLUMN server_id UUID DEFAULT current_server_id()', schema_name, table_name);\n EXECUTE format('UPDATE %I.%I SET server_id = current_server_id() WHERE server_id IS NULL', schema_name, table_name);\n ELSE\n EXECUTE format('ALTER TABLE %I.%I ALTER COLUMN server_id SET DEFAULT current_server_id()', schema_name, table_name);\n EXECUTE format('SELECT COUNT(*) FROM %I.%I WHERE server_id IS NULL', schema_name, table_name) INTO orphaned_count;\n\n IF orphaned_count > 0 THEN\n RAISE NOTICE 'Backfilling % rows with NULL server_id in %.%', orphaned_count, schema_name, table_name;\n EXECUTE format('UPDATE %I.%I SET server_id = current_server_id() WHERE server_id IS NULL', schema_name, table_name);\n END IF;\n END IF;\n\n EXECUTE format('CREATE INDEX IF NOT EXISTS idx_%I_server_id ON %I.%I(server_id)', table_name, schema_name, table_name);\n EXECUTE format('ALTER TABLE %I.%I ENABLE ROW LEVEL SECURITY', schema_name, table_name);\n EXECUTE format('ALTER TABLE %I.%I FORCE ROW LEVEL SECURITY', schema_name, table_name);\n EXECUTE format('DROP POLICY IF EXISTS server_isolation_policy ON %I.%I', schema_name, table_name);\n EXECUTE format('\n CREATE POLICY server_isolation_policy ON %I.%I\n USING (server_id = current_server_id())\n WITH CHECK (server_id = current_server_id())\n ', schema_name, table_name);\n END;\n $$ LANGUAGE plpgsql;\n `);\n\n await db.execute(sql`\n CREATE OR REPLACE FUNCTION apply_rls_to_all_tables() RETURNS void AS $$\n DECLARE\n tbl record;\n BEGIN\n FOR tbl IN\n SELECT schemaname, tablename\n FROM pg_tables\n WHERE schemaname = 'public'\n AND tablename NOT IN (\n 'servers',\n 'drizzle_migrations',\n '__drizzle_migrations'\n )\n LOOP\n BEGIN\n PERFORM add_server_isolation(tbl.schemaname, tbl.tablename);\n EXCEPTION WHEN OTHERS THEN\n RAISE WARNING 'Failed to apply RLS to %.%: %', tbl.schemaname, tbl.tablename, SQLERRM;\n END;\n END LOOP;\n END;\n $$ LANGUAGE plpgsql;\n `);\n\n logger.info({ src: \"plugin:sql\" }, \"RLS PostgreSQL functions installed\");\n await installEntityRLS(adapter);\n}\n\nexport async function getOrCreateRlsServer(\n adapter: IDatabaseAdapter,\n serverId: string\n): Promise<string> {\n const db = getDb(adapter);\n\n // Use Drizzle's insert with onConflictDoNothing\n await db\n .insert(serverTable)\n .values({\n id: serverId,\n })\n .onConflictDoNothing();\n\n logger.info({ src: \"plugin:sql\", serverId: serverId.slice(0, 8) }, \"RLS server registered\");\n return serverId;\n}\n\nexport async function setServerContext(adapter: IDatabaseAdapter, serverId: string): Promise<void> {\n if (!validateUuid(serverId)) {\n throw new Error(`Invalid server ID format: ${serverId}. Must be a valid UUID.`);\n }\n\n const db = getDb(adapter);\n const servers = await db.select().from(serverTable).where(eq(serverTable.id, serverId));\n\n if (servers.length === 0) {\n throw new Error(`Server ${serverId} does not exist`);\n }\n\n logger.info({ src: \"plugin:sql\", serverId: serverId.slice(0, 8) }, \"RLS context configured\");\n}\n\nexport async function assignAgentToServer(\n adapter: IDatabaseAdapter,\n agentId: string,\n serverId: string\n): Promise<void> {\n if (!agentId || !serverId) {\n logger.warn(\n `[Data Isolation] Cannot assign agent to server: invalid agentId (${agentId}) or serverId (${serverId})`\n );\n return;\n }\n\n const db = getDb(adapter);\n\n // Check if agent exists using Drizzle\n const agents = await db.select().from(agentTable).where(eq(agentTable.id, agentId));\n\n if (agents.length > 0) {\n const agent = agents[0];\n const currentServerId = agent.server_id;\n\n if (currentServerId === serverId) {\n logger.debug(\n { src: \"plugin:sql\", agentName: agent.name },\n \"Agent already assigned to correct server\"\n );\n } else {\n // Update agent server using Drizzle\n await db.update(agentTable).set({ server_id: serverId }).where(eq(agentTable.id, agentId));\n\n if (currentServerId === null) {\n logger.info({ src: \"plugin:sql\", agentName: agent.name }, \"Agent assigned to server\");\n } else {\n logger.warn({ src: \"plugin:sql\", agentName: agent.name }, \"Agent server changed\");\n }\n }\n } else {\n logger.debug({ src: \"plugin:sql\", agentId }, \"Agent does not exist yet\");\n }\n}\n\n/**\n * Apply RLS to all tables by calling PostgreSQL function\n */\nexport async function applyRLSToNewTables(adapter: IDatabaseAdapter): Promise<void> {\n const db = getDb(adapter);\n\n try {\n await db.execute(sql`SELECT apply_rls_to_all_tables()`);\n logger.info({ src: \"plugin:sql\" }, \"RLS applied to all tables\");\n } catch (error) {\n logger.warn({ src: \"plugin:sql\", error: String(error) }, \"Failed to apply RLS to some tables\");\n }\n}\n\nexport async function uninstallRLS(adapter: IDatabaseAdapter): Promise<void> {\n const db = getDb(adapter);\n\n try {\n const checkResult = await db.execute(sql`\n SELECT EXISTS (\n SELECT FROM pg_tables\n WHERE schemaname = 'public' AND tablename = 'servers'\n ) as rls_enabled\n `);\n\n const rlsEnabled = checkResult.rows?.[0]?.rls_enabled;\n\n if (!rlsEnabled) {\n logger.debug({ src: \"plugin:sql\" }, \"RLS not installed, skipping cleanup\");\n return;\n }\n\n logger.info(\n { src: \"plugin:sql\" },\n \"Disabling RLS globally (keeping server_id columns for schema compatibility)...\"\n );\n\n try {\n await uninstallEntityRLS(adapter);\n } catch (_entityRlsError) {\n logger.debug(\n { src: \"plugin:sql\" },\n \"Entity RLS cleanup skipped (not installed or already cleaned)\"\n );\n }\n\n await db.execute(sql`\n CREATE OR REPLACE FUNCTION _temp_disable_rls_on_table(\n p_schema_name text,\n p_table_name text\n ) RETURNS void AS $$\n DECLARE\n policy_rec record;\n BEGIN\n -- Drop all policies on this table\n FOR policy_rec IN\n SELECT policyname\n FROM pg_policies\n WHERE schemaname = p_schema_name AND tablename = p_table_name\n LOOP\n EXECUTE format('DROP POLICY IF EXISTS %I ON %I.%I',\n policy_rec.policyname, p_schema_name, p_table_name);\n END LOOP;\n\n -- Disable RLS\n EXECUTE format('ALTER TABLE %I.%I NO FORCE ROW LEVEL SECURITY', p_schema_name, p_table_name);\n EXECUTE format('ALTER TABLE %I.%I DISABLE ROW LEVEL SECURITY', p_schema_name, p_table_name);\n END;\n $$ LANGUAGE plpgsql;\n `);\n\n const tablesResult = await db.execute(sql`\n SELECT schemaname, tablename\n FROM pg_tables\n WHERE schemaname = 'public'\n AND tablename NOT IN ('drizzle_migrations', '__drizzle_migrations')\n `);\n\n for (const row of tablesResult.rows || []) {\n const schemaName = row.schemaname;\n const tableName = row.tablename;\n\n try {\n await db.execute(sql`SELECT _temp_disable_rls_on_table(${schemaName}, ${tableName})`);\n logger.debug({ src: \"plugin:sql\", schemaName, tableName }, \"Disabled RLS on table\");\n } catch (error) {\n logger.warn(\n { src: \"plugin:sql\", schemaName, tableName, error: String(error) },\n \"Failed to disable RLS on table\"\n );\n }\n }\n\n await db.execute(sql`DROP FUNCTION IF EXISTS _temp_disable_rls_on_table(text, text)`);\n\n logger.info(\n { src: \"plugin:sql\" },\n \"Keeping server_id values intact (prevents data theft on re-enable)\"\n );\n\n logger.info({ src: \"plugin:sql\" }, \"Clearing servers table...\");\n await db.execute(sql`TRUNCATE TABLE servers`);\n\n await db.execute(sql`DROP FUNCTION IF EXISTS apply_rls_to_all_tables() CASCADE`);\n await db.execute(sql`DROP FUNCTION IF EXISTS add_server_isolation(text, text) CASCADE`);\n await db.execute(sql`DROP FUNCTION IF EXISTS current_server_id() CASCADE`);\n logger.info({ src: \"plugin:sql\" }, \"Dropped all RLS functions\");\n\n logger.info({ src: \"plugin:sql\" }, \"RLS disabled successfully (server_id columns preserved)\");\n } catch (error) {\n logger.error({ src: \"plugin:sql\", error: String(error) }, \"Failed to disable RLS\");\n throw error;\n }\n}\n\nexport async function installEntityRLS(adapter: IDatabaseAdapter): Promise<void> {\n const db = getDb(adapter);\n\n logger.info(\"[Entity RLS] Installing entity RLS functions and policies...\");\n\n await db.execute(sql`\n CREATE OR REPLACE FUNCTION current_entity_id()\n RETURNS UUID AS $$\n DECLARE\n entity_id_text TEXT;\n BEGIN\n -- Read from transaction-local variable\n entity_id_text := NULLIF(current_setting('app.entity_id', TRUE), '');\n\n IF entity_id_text IS NULL OR entity_id_text = '' THEN\n RETURN NULL;\n END IF;\n\n BEGIN\n RETURN entity_id_text::UUID;\n EXCEPTION WHEN OTHERS THEN\n RETURN NULL;\n END;\n END;\n $$ LANGUAGE plpgsql STABLE;\n `);\n\n logger.info(\"[Entity RLS] Created current_entity_id() function\");\n\n // 2. Create add_entity_isolation() function - applies entity RLS to a single table\n await db.execute(sql`\n CREATE OR REPLACE FUNCTION add_entity_isolation(\n schema_name text,\n table_name text,\n require_entity boolean DEFAULT false\n ) RETURNS void AS $$\n DECLARE\n full_table_name text;\n has_entity_id boolean;\n has_author_id boolean;\n has_channel_id boolean;\n has_room_id boolean;\n entity_column_name text;\n room_column_name text;\n BEGIN\n full_table_name := schema_name || '.' || table_name;\n\n SELECT EXISTS (\n SELECT 1 FROM information_schema.columns\n WHERE information_schema.columns.table_schema = schema_name\n AND information_schema.columns.table_name = add_entity_isolation.table_name\n AND information_schema.columns.column_name = 'entity_id'\n ) INTO has_entity_id;\n\n SELECT EXISTS (\n SELECT 1 FROM information_schema.columns\n WHERE information_schema.columns.table_schema = schema_name\n AND information_schema.columns.table_name = add_entity_isolation.table_name\n AND information_schema.columns.column_name = 'author_id'\n ) INTO has_author_id;\n\n SELECT EXISTS (\n SELECT 1 FROM information_schema.columns\n WHERE information_schema.columns.table_schema = schema_name\n AND information_schema.columns.table_name = add_entity_isolation.table_name\n AND information_schema.columns.column_name = 'room_id'\n ) INTO has_room_id;\n\n IF NOT (has_entity_id OR has_author_id OR has_room_id) THEN\n RAISE NOTICE '[Entity RLS] Skipping %.%: no entity columns found', schema_name, table_name;\n RETURN;\n END IF;\n\n IF table_name = 'participants' AND has_entity_id THEN\n entity_column_name := 'entity_id';\n room_column_name := NULL;\n ELSIF has_room_id THEN\n room_column_name := 'room_id';\n entity_column_name := NULL;\n ELSIF has_entity_id THEN\n entity_column_name := 'entity_id';\n room_column_name := NULL;\n ELSIF has_author_id THEN\n entity_column_name := 'author_id';\n room_column_name := NULL;\n ELSE\n entity_column_name := NULL;\n room_column_name := NULL;\n END IF;\n\n EXECUTE format('ALTER TABLE %I.%I ENABLE ROW LEVEL SECURITY', schema_name, table_name);\n EXECUTE format('ALTER TABLE %I.%I FORCE ROW LEVEL SECURITY', schema_name, table_name);\n EXECUTE format('DROP POLICY IF EXISTS entity_isolation_policy ON %I.%I', schema_name, table_name);\n\n IF room_column_name IS NOT NULL THEN\n IF require_entity THEN\n EXECUTE format('\n CREATE POLICY entity_isolation_policy ON %I.%I\n AS RESTRICTIVE\n USING (\n current_entity_id() IS NOT NULL\n AND %I IN (\n SELECT room_id\n FROM participants\n WHERE entity_id = current_entity_id()\n )\n )\n WITH CHECK (\n current_entity_id() IS NOT NULL\n AND %I IN (\n SELECT room_id\n FROM participants\n WHERE entity_id = current_entity_id()\n )\n )\n ', schema_name, table_name, room_column_name, room_column_name);\n RAISE NOTICE '[Entity RLS] Applied STRICT RESTRICTIVE to %.% (via % → participants.room_id, entity REQUIRED)', schema_name, table_name, room_column_name;\n ELSE\n EXECUTE format('\n CREATE POLICY entity_isolation_policy ON %I.%I\n AS RESTRICTIVE\n USING (\n current_entity_id() IS NULL\n OR %I IN (\n SELECT room_id\n FROM participants\n WHERE entity_id = current_entity_id()\n )\n )\n WITH CHECK (\n current_entity_id() IS NULL\n OR %I IN (\n SELECT room_id\n FROM participants\n WHERE entity_id = current_entity_id()\n )\n )\n ', schema_name, table_name, room_column_name, room_column_name);\n RAISE NOTICE '[Entity RLS] Applied PERMISSIVE RESTRICTIVE to %.% (via % → participants.room_id, NULL allowed)', schema_name, table_name, room_column_name;\n END IF;\n\n ELSIF entity_column_name IS NOT NULL THEN\n IF require_entity THEN\n EXECUTE format('\n CREATE POLICY entity_isolation_policy ON %I.%I\n AS RESTRICTIVE\n USING (\n current_entity_id() IS NOT NULL\n AND %I = current_entity_id()\n )\n WITH CHECK (\n current_entity_id() IS NOT NULL\n AND %I = current_entity_id()\n )\n ', schema_name, table_name, entity_column_name, entity_column_name);\n RAISE NOTICE '[Entity RLS] Applied STRICT RESTRICTIVE to %.% (direct column: %, entity REQUIRED)', schema_name, table_name, entity_column_name;\n ELSE\n -- PERMISSIVE MODE: NULL entity_id allows system/admin access\n EXECUTE format('\n CREATE POLICY entity_isolation_policy ON %I.%I\n AS RESTRICTIVE\n USING (\n current_entity_id() IS NULL\n OR %I = current_entity_id()\n )\n WITH CHECK (\n current_entity_id() IS NULL\n OR %I = current_entity_id()\n )\n ', schema_name, table_name, entity_column_name, entity_column_name);\n RAISE NOTICE '[Entity RLS] Applied PERMISSIVE RESTRICTIVE to %.% (direct column: %, NULL allowed)', schema_name, table_name, entity_column_name;\n END IF;\n END IF;\n\n IF room_column_name IS NOT NULL THEN\n EXECUTE format('CREATE INDEX IF NOT EXISTS idx_%I_room ON %I.%I(%I)',\n table_name, schema_name, table_name, room_column_name);\n END IF;\n\n IF entity_column_name IS NOT NULL THEN\n EXECUTE format('CREATE INDEX IF NOT EXISTS idx_%I_entity ON %I.%I(%I)',\n table_name, schema_name, table_name, entity_column_name);\n END IF;\n END;\n $$ LANGUAGE plpgsql;\n `);\n\n logger.info(\"[Entity RLS] Created add_entity_isolation() function\");\n\n await db.execute(sql`\n CREATE OR REPLACE FUNCTION apply_entity_rls_to_all_tables() RETURNS void AS $$\n DECLARE\n tbl record;\n require_entity_for_table boolean;\n BEGIN\n FOR tbl IN\n SELECT schemaname, tablename\n FROM pg_tables\n WHERE schemaname = 'public'\n AND tablename NOT IN (\n 'servers', -- Server RLS table\n 'users', -- Authentication table (no entity isolation needed)\n 'entity_mappings', -- Mapping table (no entity isolation needed)\n 'drizzle_migrations', -- Migration tracking\n '__drizzle_migrations' -- Migration tracking\n )\n LOOP\n BEGIN\n -- Apply STRICT mode (require_entity=true) to sensitive user-facing tables\n -- These tables MUST have entity context set to access data\n -- STRICT tables: memories, logs, components, tasks (user data requiring isolation)\n -- NOTE: Excluded tables:\n -- - 'participants': Adding participants is a privileged operation during initialization\n IF tbl.tablename IN ('memories', 'logs', 'components', 'tasks') THEN\n require_entity_for_table := true;\n ELSE\n require_entity_for_table := false;\n END IF;\n\n PERFORM add_entity_isolation(tbl.schemaname, tbl.tablename, require_entity_for_table);\n EXCEPTION WHEN OTHERS THEN\n RAISE WARNING '[Entity RLS] Failed to apply to %.%: %', tbl.schemaname, tbl.tablename, SQLERRM;\n END;\n END LOOP;\n END;\n $$ LANGUAGE plpgsql;\n `);\n\n logger.info(\"[Entity RLS] Created apply_entity_rls_to_all_tables() function\");\n\n logger.info(\"[Entity RLS] Entity RLS functions installed successfully\");\n}\n\nexport async function applyEntityRLSToAllTables(adapter: IDatabaseAdapter): Promise<void> {\n const db = getDb(adapter);\n\n try {\n await db.execute(sql`SELECT apply_entity_rls_to_all_tables()`);\n logger.info(\"[Entity RLS] Applied entity RLS to all eligible tables\");\n } catch (error) {\n logger.warn(\"[Entity RLS] Failed to apply entity RLS to some tables:\", String(error));\n }\n}\n\nexport async function uninstallEntityRLS(adapter: IDatabaseAdapter): Promise<void> {\n const db = getDb(adapter);\n\n logger.info(\"[Entity RLS] Removing entity RLS policies and functions...\");\n\n try {\n const tablesResult = await db.execute(sql`\n SELECT schemaname, tablename\n FROM pg_tables\n WHERE schemaname = 'public'\n AND tablename NOT IN ('drizzle_migrations', '__drizzle_migrations')\n `);\n\n for (const row of tablesResult.rows || []) {\n const schemaName = row.schemaname;\n const tableName = row.tablename;\n\n try {\n await db.execute(\n sql.raw(`DROP POLICY IF EXISTS entity_isolation_policy ON \"${schemaName}\".\"${tableName}\"`)\n );\n logger.debug(\n `[Entity RLS] Dropped entity_isolation_policy from ${schemaName}.${tableName}`\n );\n } catch (_error) {\n logger.debug(`[Entity RLS] No entity policy on ${schemaName}.${tableName}`);\n }\n }\n\n await db.execute(sql`DROP FUNCTION IF EXISTS apply_entity_rls_to_all_tables() CASCADE`);\n await db.execute(sql`DROP FUNCTION IF EXISTS add_entity_isolation(text, text) CASCADE`);\n await db.execute(sql`DROP FUNCTION IF EXISTS current_entity_id() CASCADE`);\n\n logger.info(\"[Entity RLS] Entity RLS functions and policies removed successfully\");\n } catch (error) {\n logger.error(\"[Entity RLS] Failed to remove entity RLS:\", String(error));\n throw error;\n }\n}\n",
105
- "import type {\n IndexColumn,\n SchemaCheckConstraint,\n SchemaColumn,\n SchemaForeignKey,\n SchemaIndex,\n SchemaSnapshot,\n SchemaUniqueConstraint,\n} from \"../types\";\n\n/**\n * Normalize SQL types for comparison\n * Handles equivalent type variations between introspected DB and schema definitions\n */\nfunction normalizeType(type: string | undefined): string {\n if (!type) return \"\";\n\n const normalized = type.toLowerCase().trim();\n\n // Handle timestamp variations\n if (normalized === \"timestamp without time zone\" || normalized === \"timestamp with time zone\") {\n return \"timestamp\";\n }\n\n // Handle serial vs integer with identity\n // serial is essentially integer with auto-increment\n if (normalized === \"serial\") {\n return \"integer\";\n }\n if (normalized === \"bigserial\") {\n return \"bigint\";\n }\n if (normalized === \"smallserial\") {\n return \"smallint\";\n }\n\n // Handle numeric/decimal equivalence\n if (normalized.startsWith(\"numeric\") || normalized.startsWith(\"decimal\")) {\n // Extract precision and scale if present\n const match = normalized.match(/\\((\\d+)(?:,\\s*(\\d+))?\\)/);\n if (match) {\n return `numeric(${match[1]}${match[2] ? `,${match[2]}` : \"\"})`;\n }\n return \"numeric\";\n }\n\n // Handle varchar/character varying\n if (normalized.startsWith(\"character varying\")) {\n return normalized.replace(\"character varying\", \"varchar\");\n }\n\n // Handle text array variations\n if (normalized === \"text[]\" || normalized === \"_text\") {\n return \"text[]\";\n }\n\n return normalized;\n}\n\n/**\n * Helper function to compare two index definitions\n * Returns true if indexes are different and need to be recreated\n */\nfunction isIndexChanged(prevIndex: SchemaIndex, currIndex: SchemaIndex): boolean {\n // Compare basic properties\n if (prevIndex.isUnique !== currIndex.isUnique) return true;\n if (prevIndex.method !== currIndex.method) return true;\n if (prevIndex.where !== currIndex.where) return true;\n if (prevIndex.concurrently !== currIndex.concurrently) return true;\n\n // Compare columns array - must be same columns in same order\n const prevColumns = prevIndex.columns || [];\n const currColumns = currIndex.columns || [];\n\n if (prevColumns.length !== currColumns.length) return true;\n\n for (let i = 0; i < prevColumns.length; i++) {\n const prevCol = prevColumns[i] as string | IndexColumn;\n const currCol = currColumns[i] as string | IndexColumn;\n\n // Handle both string columns and expression columns\n if (typeof prevCol === \"string\" && typeof currCol === \"string\") {\n if (prevCol !== currCol) return true;\n } else if (typeof prevCol === \"object\" && typeof currCol === \"object\") {\n // Compare expression columns\n if (prevCol.expression !== currCol.expression) return true;\n if (prevCol.isExpression !== currCol.isExpression) return true;\n if (prevCol.asc !== currCol.asc) return true;\n if (prevCol.nulls !== currCol.nulls) return true;\n } else {\n // Type mismatch (one is string, other is object)\n return true;\n }\n }\n\n return false;\n}\n\n// Column changes interface\nexport interface ColumnChanges {\n typeChanged?: boolean;\n prevType?: string;\n newType?: string;\n nullabilityChanged?: boolean;\n wasNullable?: boolean;\n isNullable?: boolean;\n defaultChanged?: boolean;\n prevDefault?: string | number | boolean;\n newDefault?: string | number | boolean;\n from?: SchemaColumn;\n to?: SchemaColumn;\n}\n\n// Table changes interface\nexport interface TableChanges {\n columnsAdded: string[];\n columnsDeleted: string[];\n columnsModified: string[];\n}\n\nexport interface SchemaDiff {\n tables: {\n created: string[];\n deleted: string[];\n modified: Array<{\n name: string;\n changes: TableChanges;\n }>;\n };\n columns: {\n added: Array<{\n table: string;\n column: string;\n definition: SchemaColumn;\n }>;\n deleted: Array<{\n table: string;\n column: string;\n }>;\n modified: Array<{\n table: string;\n column: string;\n changes: ColumnChanges;\n }>;\n };\n indexes: {\n created: SchemaIndex[];\n deleted: SchemaIndex[];\n altered: Array<{\n // Indexes with same name but different definition\n old: SchemaIndex;\n new: SchemaIndex;\n }>;\n };\n foreignKeys: {\n created: SchemaForeignKey[];\n deleted: SchemaForeignKey[];\n altered: Array<{\n // FKs with modified CASCADE behavior\n old: SchemaForeignKey;\n new: SchemaForeignKey;\n }>;\n };\n uniqueConstraints: {\n created: SchemaUniqueConstraint[];\n deleted: SchemaUniqueConstraint[];\n };\n checkConstraints: {\n created: SchemaCheckConstraint[];\n deleted: SchemaCheckConstraint[];\n };\n}\n\n/**\n * Calculate the difference between two snapshots\n */\nexport async function calculateDiff(\n previousSnapshot: SchemaSnapshot | null,\n currentSnapshot: SchemaSnapshot\n): Promise<SchemaDiff> {\n const diff: SchemaDiff = {\n tables: {\n created: [],\n deleted: [],\n modified: [],\n },\n columns: {\n added: [],\n deleted: [],\n modified: [],\n },\n indexes: {\n created: [],\n deleted: [],\n altered: [],\n },\n foreignKeys: {\n created: [],\n deleted: [],\n altered: [],\n },\n uniqueConstraints: {\n created: [],\n deleted: [],\n },\n checkConstraints: {\n created: [],\n deleted: [],\n },\n };\n\n // If no previous snapshot, all tables are new\n if (!previousSnapshot) {\n diff.tables.created = Object.keys(currentSnapshot.tables);\n\n // Also track indexes and foreign keys from new tables\n for (const tableName in currentSnapshot.tables) {\n const table = currentSnapshot.tables[tableName];\n\n // Add indexes\n if (table.indexes) {\n for (const indexName in table.indexes) {\n diff.indexes.created.push({\n ...table.indexes[indexName],\n table: tableName,\n } as SchemaIndex & { table: string });\n }\n }\n\n // Add foreign keys\n if (table.foreignKeys) {\n for (const fkName in table.foreignKeys) {\n diff.foreignKeys.created.push(table.foreignKeys[fkName]);\n }\n }\n }\n\n return diff;\n }\n\n const prevTables = previousSnapshot.tables || {};\n const currTables = currentSnapshot.tables || {};\n\n // Find created tables\n for (const tableName in currTables) {\n if (!(tableName in prevTables)) {\n diff.tables.created.push(tableName);\n\n const table = currTables[tableName];\n\n // Add indexes for new table\n if (table.indexes) {\n for (const indexName in table.indexes) {\n diff.indexes.created.push({\n ...table.indexes[indexName],\n table: tableName,\n } as SchemaIndex & { table: string });\n }\n }\n\n // Add unique constraints for new table\n if (table.uniqueConstraints) {\n for (const uqName in table.uniqueConstraints) {\n diff.uniqueConstraints.created.push({\n ...table.uniqueConstraints[uqName],\n table: tableName,\n } as SchemaUniqueConstraint & { table: string });\n }\n }\n\n // Add check constraints for new table\n if (table.checkConstraints) {\n for (const checkName in table.checkConstraints) {\n diff.checkConstraints.created.push({\n ...table.checkConstraints[checkName],\n table: tableName,\n } as SchemaCheckConstraint & { table: string });\n }\n }\n\n // Add foreign keys for new table\n if (table.foreignKeys) {\n for (const fkName in table.foreignKeys) {\n diff.foreignKeys.created.push(table.foreignKeys[fkName]);\n }\n }\n }\n }\n\n // Find deleted tables\n for (const tableName in prevTables) {\n if (!(tableName in currTables)) {\n diff.tables.deleted.push(tableName);\n }\n }\n\n // Find modified tables (check columns, indexes, foreign keys)\n for (const tableName in currTables) {\n if (tableName in prevTables) {\n const prevTable = prevTables[tableName];\n const currTable = currTables[tableName];\n\n // Early check: if the table schemas are identical, skip it entirely\n // This prevents false positives when other tables are modified\n const prevTableJson = JSON.stringify({\n columns: prevTable.columns || {},\n indexes: prevTable.indexes || {},\n foreignKeys: prevTable.foreignKeys || {},\n uniqueConstraints: prevTable.uniqueConstraints || {},\n checkConstraints: prevTable.checkConstraints || {},\n });\n\n const currTableJson = JSON.stringify({\n columns: currTable.columns || {},\n indexes: currTable.indexes || {},\n foreignKeys: currTable.foreignKeys || {},\n uniqueConstraints: currTable.uniqueConstraints || {},\n checkConstraints: currTable.checkConstraints || {},\n });\n\n // If tables are identical, skip all processing for this table\n if (prevTableJson === currTableJson) {\n continue;\n }\n\n // Compare columns\n const prevColumns = prevTable.columns || {};\n const currColumns = currTable.columns || {};\n\n // Find added columns\n for (const colName in currColumns) {\n if (!(colName in prevColumns)) {\n diff.columns.added.push({\n table: tableName,\n column: colName,\n definition: currColumns[colName],\n });\n }\n }\n\n // Find deleted columns\n for (const colName in prevColumns) {\n if (!(colName in currColumns)) {\n diff.columns.deleted.push({\n table: tableName,\n column: colName,\n });\n }\n }\n\n // Find modified columns\n for (const colName in currColumns) {\n if (colName in prevColumns) {\n const prevCol = prevColumns[colName];\n const currCol = currColumns[colName];\n\n // Check for changes in column properties\n // Use normalized type comparison\n const typeChanged = normalizeType(prevCol.type) !== normalizeType(currCol.type);\n const hasChanges =\n typeChanged ||\n prevCol.notNull !== currCol.notNull ||\n prevCol.default !== currCol.default ||\n prevCol.primaryKey !== currCol.primaryKey;\n\n if (hasChanges) {\n diff.columns.modified.push({\n table: tableName,\n column: colName,\n changes: {\n from: prevCol,\n to: currCol,\n },\n });\n }\n }\n }\n\n // Compare indexes\n const prevIndexes = prevTable.indexes || {};\n const currIndexes = currTable.indexes || {};\n\n // Find new, deleted, and altered indexes\n for (const indexName in currIndexes) {\n if (!(indexName in prevIndexes)) {\n // New index\n diff.indexes.created.push({\n ...currIndexes[indexName],\n table: tableName,\n } as SchemaIndex & { table: string });\n } else {\n // Check if index definition changed\n const prevIndex = prevIndexes[indexName];\n const currIndex = currIndexes[indexName];\n\n // Deep comparison of index properties\n const indexChanged = isIndexChanged(prevIndex, currIndex);\n\n if (indexChanged) {\n // Index definition changed - need to drop and recreate\n diff.indexes.altered.push({\n old: {\n ...prevIndex,\n table: tableName,\n name: indexName,\n } as SchemaIndex & { table: string },\n new: {\n ...currIndex,\n table: tableName,\n name: indexName,\n } as SchemaIndex & { table: string },\n });\n }\n }\n }\n\n // Find deleted indexes (not altered)\n for (const indexName in prevIndexes) {\n if (!(indexName in currIndexes)) {\n diff.indexes.deleted.push({\n ...prevIndexes[indexName],\n table: tableName,\n } as SchemaIndex & { table: string });\n }\n }\n\n // Compare unique constraints\n const prevUniqueConstraints = prevTable.uniqueConstraints || {};\n const currUniqueConstraints = currTable.uniqueConstraints || {};\n\n // Find new unique constraints\n for (const uqName in currUniqueConstraints) {\n if (!(uqName in prevUniqueConstraints)) {\n diff.uniqueConstraints.created.push({\n ...currUniqueConstraints[uqName],\n table: tableName,\n } as SchemaUniqueConstraint & { table: string });\n }\n }\n\n // Find deleted unique constraints\n for (const uqName in prevUniqueConstraints) {\n if (!(uqName in currUniqueConstraints)) {\n diff.uniqueConstraints.deleted.push({\n ...prevUniqueConstraints[uqName],\n table: tableName,\n } as SchemaUniqueConstraint & { table: string });\n }\n }\n\n // Compare check constraints\n const prevCheckConstraints = prevTable.checkConstraints || {};\n const currCheckConstraints = currTable.checkConstraints || {};\n\n // Find new check constraints\n for (const checkName in currCheckConstraints) {\n if (!(checkName in prevCheckConstraints)) {\n diff.checkConstraints.created.push({\n ...currCheckConstraints[checkName],\n table: tableName,\n } as SchemaCheckConstraint & { table: string });\n }\n }\n\n // Find deleted check constraints\n for (const checkName in prevCheckConstraints) {\n if (!(checkName in currCheckConstraints)) {\n diff.checkConstraints.deleted.push({\n ...prevCheckConstraints[checkName],\n table: tableName,\n } as SchemaCheckConstraint & { table: string });\n }\n }\n\n // Compare foreign keys\n const prevFKs = prevTable.foreignKeys || {};\n const currFKs = currTable.foreignKeys || {};\n\n // Find new, deleted, and altered foreign keys\n for (const fkName in currFKs) {\n if (!(fkName in prevFKs)) {\n // New FK\n diff.foreignKeys.created.push(currFKs[fkName]);\n } else {\n // Check if FK definition changed (CASCADE behavior, etc.)\n const prevFK = prevFKs[fkName];\n const currFK = currFKs[fkName];\n\n // Compare FK properties\n const prevOnDelete = prevFK.onDelete || \"no action\";\n const currOnDelete = currFK.onDelete || \"no action\";\n const prevOnUpdate = prevFK.onUpdate || \"no action\";\n const currOnUpdate = currFK.onUpdate || \"no action\";\n\n if (prevOnDelete !== currOnDelete || prevOnUpdate !== currOnUpdate) {\n // FK CASCADE behavior changed - need to drop and recreate\n diff.foreignKeys.altered.push({\n old: prevFK,\n new: currFK,\n });\n }\n }\n }\n\n // Find deleted foreign keys (not altered)\n for (const fkName in prevFKs) {\n if (!(fkName in currFKs)) {\n const prevFK = prevFKs[fkName];\n diff.foreignKeys.deleted.push({\n ...prevFK,\n tableFrom: tableName,\n } as SchemaForeignKey);\n }\n }\n }\n }\n\n return diff;\n}\n\n/**\n * Check if a diff has any changes\n */\nexport function hasDiffChanges(diff: SchemaDiff): boolean {\n return (\n diff.tables.created.length > 0 ||\n diff.tables.deleted.length > 0 ||\n diff.tables.modified.length > 0 ||\n diff.columns.added.length > 0 ||\n diff.columns.deleted.length > 0 ||\n diff.columns.modified.length > 0 ||\n diff.indexes.created.length > 0 ||\n diff.indexes.deleted.length > 0 ||\n diff.indexes.altered.length > 0 ||\n diff.foreignKeys.created.length > 0 ||\n diff.foreignKeys.deleted.length > 0 ||\n diff.foreignKeys.altered.length > 0 ||\n diff.uniqueConstraints.created.length > 0 ||\n diff.uniqueConstraints.deleted.length > 0 ||\n diff.checkConstraints.created.length > 0 ||\n diff.checkConstraints.deleted.length > 0\n );\n}\n",
106
- "/**\n * Browser-compatible crypto utilities\n * Uses the Web Crypto API which is available in both browsers and Node.js\n */\n\n/**\n * Simple synchronous hash function for change detection\n * This is NOT cryptographic - it's just for comparing snapshots\n * Uses djb2 hash algorithm for speed and simplicity\n */\nexport function simpleHash(str: string): string {\n let hash = 5381;\n for (let i = 0; i < str.length; i++) {\n hash = (hash * 33) ^ str.charCodeAt(i);\n }\n // Convert to unsigned 32-bit integer and then to hex\n return (hash >>> 0).toString(16).padStart(8, \"0\");\n}\n\n/**\n * Create a longer hash by combining multiple passes\n * This provides better distribution for larger inputs\n */\nexport function extendedHash(str: string): string {\n // Run multiple passes with different seeds for better distribution\n const h1 = hashWithSeed(str, 5381);\n const h2 = hashWithSeed(str, 7919);\n const h3 = hashWithSeed(str, 104729);\n const h4 = hashWithSeed(str, 224737);\n\n return h1 + h2 + h3 + h4;\n}\n\nfunction hashWithSeed(str: string, seed: number): string {\n let hash = seed;\n for (let i = 0; i < str.length; i++) {\n hash = (hash * 33) ^ str.charCodeAt(i);\n }\n return (hash >>> 0).toString(16).padStart(8, \"0\");\n}\n\n/**\n * Convert string to Uint8Array\n */\nfunction stringToBytes(str: string): Uint8Array {\n const encoder = new TextEncoder();\n return encoder.encode(str);\n}\n\n/**\n * Convert ArrayBuffer to hex string\n */\nfunction bufferToHex(buffer: ArrayBuffer): string {\n const bytes = new Uint8Array(buffer);\n let hex = \"\";\n for (let i = 0; i < bytes.length; i++) {\n hex += bytes[i].toString(16).padStart(2, \"0\");\n }\n return hex;\n}\n\n/**\n * Async SHA-256 hash using Web Crypto API\n * Works in both browsers and Node.js (v15+)\n */\nexport async function sha256Async(data: string): Promise<string> {\n const bytes = stringToBytes(data);\n // Cast to ArrayBuffer to satisfy TypeScript's strict BufferSource typing\n const hashBuffer = await crypto.subtle.digest(\"SHA-256\", bytes.buffer as ArrayBuffer);\n return bufferToHex(hashBuffer);\n}\n\n/**\n * Generate a stable bigint from a string for advisory lock IDs\n * Uses a simple hash that produces consistent results across runs\n */\nexport function stringToBigInt(str: string): bigint {\n // Use extended hash for better uniqueness\n const hash = extendedHash(str);\n\n // Convert first 16 hex chars (64 bits) to bigint\n let lockId = BigInt(`0x${hash.slice(0, 16)}`);\n\n // Ensure the value fits in PostgreSQL's positive bigint range\n // Use a mask to keep only 63 bits (ensures positive in signed 64-bit)\n const mask63Bits = 0x7fffffffffffffffn;\n lockId = lockId & mask63Bits;\n\n // Ensure non-zero\n if (lockId === 0n) {\n lockId = 1n;\n }\n\n return lockId;\n}\n",
107
- "import { is, SQL } from \"drizzle-orm\";\nimport { getTableConfig, type PgColumn, PgDialect, PgTable } from \"drizzle-orm/pg-core\";\nimport { extendedHash } from \"../crypto-utils\";\nimport type {\n IndexColumn,\n SchemaCheckConstraint,\n SchemaColumn,\n SchemaEnum,\n SchemaForeignKey,\n SchemaIndex,\n SchemaPrimaryKey,\n SchemaSnapshot,\n SchemaTable,\n SchemaUniqueConstraint,\n} from \"../types\";\n\n// Drizzle schema type - an object mapping table names to PgTable instances\ntype DrizzleSchema = Record<string, unknown>;\n\n// Array element type for building SQL arrays\ntype ArrayElement = number | bigint | boolean | string | Date | object | ArrayElement[];\n\n/**\n * Internal Drizzle types for working with SQL expressions and indexes.\n * These types aren't exported from drizzle-orm but are needed for snapshot generation.\n *\n * Note: Drizzle's SQL.toQuery() accepts a config object with specific properties.\n * Since these are internal to Drizzle, we define compatible types here.\n */\ninterface SqlToQueryConfig {\n escapeName: () => never;\n escapeParam: () => never;\n escapeString: () => never;\n casing?: undefined; // We don't use casing transformation\n}\n\n/**\n * Internal Drizzle column config interface.\n * PgColumn has internal properties not exposed in the public type definition.\n */\ninterface DrizzleColumnWithConfig {\n name: string;\n notNull: boolean;\n primary: boolean;\n getSQLType: () => string;\n default?: unknown;\n isUnique?: boolean;\n config?: {\n uniqueName?: string;\n uniqueType?: string;\n };\n}\n\n/**\n * Utility functions from Drizzle's code\n */\nfunction escapeSingleQuotes(str: string): string {\n return str.replace(/'/g, \"''\");\n}\n\nfunction isPgArrayType(sqlType: string): boolean {\n return sqlType.match(/.*\\[\\d*\\].*|.*\\[\\].*/g) !== null;\n}\n\nfunction buildArrayString(array: ArrayElement[], sqlType: string): string {\n sqlType = sqlType.split(\"[\")[0];\n const values = array\n .map((value) => {\n if (typeof value === \"number\" || typeof value === \"bigint\") {\n return value.toString();\n } else if (typeof value === \"boolean\") {\n return value ? \"true\" : \"false\";\n } else if (Array.isArray(value)) {\n return buildArrayString(value, sqlType);\n } else if (value instanceof Date) {\n if (sqlType === \"date\") {\n return `\"${value.toISOString().split(\"T\")[0]}\"`;\n } else if (sqlType === \"timestamp\") {\n return `\"${value.toISOString().replace(\"T\", \" \").slice(0, 23)}\"`;\n } else {\n return `\"${value.toISOString()}\"`;\n }\n } else if (typeof value === \"object\") {\n return `\"${JSON.stringify(value).replaceAll('\"', '\\\\\"')}\"`;\n }\n\n return `\"${value}\"`;\n })\n .join(\",\");\n\n return `{${values}}`;\n}\n\n/**\n * Convert a Drizzle SQL expression to a string.\n * This is used for extracting default values from column definitions.\n *\n * Note: We use a type assertion here because SQL.toQuery() expects internal\n * Drizzle types that aren't publicly exported. Our config is compatible\n * at runtime but TypeScript can't verify this.\n */\nconst sqlToStr = (sql: SQL, _casing: string | undefined) => {\n const config: SqlToQueryConfig = {\n escapeName: () => {\n throw new Error(\"we don't support params for `sql` default values\");\n },\n escapeParam: () => {\n throw new Error(\"we don't support params for `sql` default values\");\n },\n escapeString: () => {\n throw new Error(\"we don't support params for `sql` default values\");\n },\n casing: undefined, // We don't use casing transformation in this context\n };\n // Type assertion needed: SQL.toQuery expects internal Drizzle types\n type ToQueryParam = Parameters<SQL[\"toQuery\"]>[0];\n return sql.toQuery(config as ToQueryParam).sql;\n};\n\n/**\n * Extract Drizzle tables from a schema object\n */\nfunction extractTablesFromSchema(schema: DrizzleSchema): PgTable[] {\n const tables: PgTable[] = [];\n\n // Iterate through all exports in the schema\n const exports = Object.values(schema);\n exports.forEach((t: unknown) => {\n // Check if it's a PgTable using Drizzle's is() function\n if (is(t, PgTable)) {\n tables.push(t);\n }\n });\n\n return tables;\n}\n\n/**\n * Generate a snapshot from a Drizzle schema\n * This is a port of Drizzle's pgSerializer.generatePgSnapshot\n */\nexport async function generateSnapshot(schema: DrizzleSchema): Promise<SchemaSnapshot> {\n const dialect = new PgDialect({ casing: undefined });\n const tables: Record<string, SchemaTable> = {};\n const schemas: Record<string, string> = {};\n const enums: Record<string, SchemaEnum> = {};\n\n // Extract tables from schema\n const pgTables = extractTablesFromSchema(schema);\n\n // Process each table\n for (const table of pgTables) {\n const config = getTableConfig(table);\n const {\n name: tableName,\n columns,\n indexes,\n foreignKeys,\n schema: tableSchema,\n primaryKeys,\n uniqueConstraints,\n checks,\n } = config;\n\n const columnsObject: Record<string, SchemaColumn> = {};\n const indexesObject: Record<string, SchemaIndex> = {};\n const foreignKeysObject: Record<string, SchemaForeignKey> = {};\n const primaryKeysObject: Record<string, SchemaPrimaryKey> = {};\n const uniqueConstraintObject: Record<string, SchemaUniqueConstraint> = {};\n const checksObject: Record<string, SchemaCheckConstraint> = {};\n\n // Process columns - EXACT copy of Drizzle's logic\n columns.forEach((column: PgColumn) => {\n const name = column.name;\n const notNull = column.notNull;\n const primaryKey = column.primary;\n const sqlType = column.getSQLType();\n const sqlTypeLowered = sqlType.toLowerCase();\n\n const columnToSet: SchemaColumn = {\n name,\n type: sqlType,\n primaryKey,\n notNull,\n };\n\n // Handle defaults - EXACT copy from Drizzle's pgSerializer.ts lines 247-273\n if (column.default !== undefined) {\n if (is(column.default, SQL)) {\n columnToSet.default = sqlToStr(column.default, undefined);\n } else {\n if (typeof column.default === \"string\") {\n columnToSet.default = `'${escapeSingleQuotes(column.default)}'`;\n } else {\n if (sqlTypeLowered === \"jsonb\" || sqlTypeLowered === \"json\") {\n columnToSet.default = `'${JSON.stringify(column.default)}'::${sqlTypeLowered}`;\n } else if (column.default instanceof Date) {\n if (sqlTypeLowered === \"date\") {\n columnToSet.default = `'${column.default.toISOString().split(\"T\")[0]}'`;\n } else if (sqlTypeLowered === \"timestamp\") {\n columnToSet.default = `'${column.default.toISOString().replace(\"T\", \" \").slice(0, 23)}'`;\n } else {\n columnToSet.default = `'${column.default.toISOString()}'`;\n }\n } else if (isPgArrayType(sqlTypeLowered) && Array.isArray(column.default)) {\n columnToSet.default = `'${buildArrayString(column.default as ArrayElement[], sqlTypeLowered)}'`;\n } else {\n // Should do for all types\n // columnToSet.default = `'${column.default}'::${sqlTypeLowered}`;\n columnToSet.default = column.default as string | number | boolean;\n }\n }\n }\n }\n\n // Handle column-level unique constraints\n // IMPORTANT: Check isUnique, not just uniqueName presence!\n // Drizzle sets uniqueName for all columns but only unique ones should have constraints\n // Type assertion: accessing internal Drizzle column properties not in public types\n const columnWithConfig = column as unknown as DrizzleColumnWithConfig;\n const columnConfig = columnWithConfig.config;\n if (columnWithConfig.isUnique && columnConfig && columnConfig.uniqueName) {\n uniqueConstraintObject[columnConfig.uniqueName] = {\n name: columnConfig.uniqueName,\n columns: [name],\n nullsNotDistinct: columnConfig.uniqueType === \"not distinct\",\n };\n }\n\n columnsObject[name] = columnToSet;\n });\n\n // Drizzle primary key interface\n interface DrizzlePrimaryKey {\n columns: Array<{ name: string }>;\n getName: () => string;\n }\n\n // Process primary keys\n primaryKeys.forEach((pk: DrizzlePrimaryKey) => {\n const columnNames = pk.columns.map((c) => c.name);\n const name = pk.getName();\n\n primaryKeysObject[name] = {\n name,\n columns: columnNames,\n };\n });\n\n // Drizzle unique constraint interface\n interface DrizzleUniqueConstraint {\n columns: Array<{ name: string }>;\n name?: string;\n nullsNotDistinct?: boolean;\n }\n\n // Process unique constraints\n uniqueConstraints?.forEach((unq: DrizzleUniqueConstraint) => {\n const columnNames = unq.columns.map((c) => c.name);\n const name = unq.name || `${tableName}_${columnNames.join(\"_\")}_unique`;\n\n uniqueConstraintObject[name] = {\n name,\n columns: columnNames,\n nullsNotDistinct: unq.nullsNotDistinct,\n };\n });\n\n // Drizzle foreign key interfaces\n interface DrizzleForeignKeyReference {\n columns: Array<{ name: string }>;\n foreignColumns: Array<{ name: string }>;\n foreignTable: PgTable;\n }\n\n interface DrizzleForeignKey {\n reference: () => DrizzleForeignKeyReference;\n getName: () => string;\n onDelete?: string;\n onUpdate?: string;\n }\n\n // Process foreign keys - includes both explicit foreignKeys and inline references\n // Drizzle's getTableConfig automatically collects inline .references() into foreignKeys\n foreignKeys.forEach((fk: DrizzleForeignKey) => {\n const reference = fk.reference();\n const columnsFrom = reference.columns.map((it) => it.name);\n const columnsTo = reference.foreignColumns.map((it) => it.name);\n const tableTo = getTableConfig(reference.foreignTable).name;\n const schemaTo = getTableConfig(reference.foreignTable).schema || \"public\";\n\n const name = fk.getName();\n\n foreignKeysObject[name] = {\n name,\n tableFrom: tableName,\n schemaFrom: tableSchema, // Add source table schema\n tableTo,\n schemaTo,\n columnsFrom,\n columnsTo,\n onDelete: fk.onDelete || \"no action\",\n onUpdate: fk.onUpdate || \"no action\",\n };\n });\n\n // Drizzle index interfaces\n interface DrizzleIndexConfig {\n order?: string;\n nulls?: string;\n }\n\n interface DrizzleIndexColumn {\n name: string;\n indexConfig?: DrizzleIndexConfig;\n }\n\n interface DrizzleIndex {\n config: {\n columns: Array<DrizzleIndexColumn | SQL>;\n name?: string;\n unique?: boolean;\n method?: string;\n };\n }\n\n // Process indexes\n // Drizzle's getTableConfig returns indexes with internal types not exported from the package\n (indexes as DrizzleIndex[]).forEach((idx: DrizzleIndex) => {\n const indexCols = idx.config.columns;\n const indexColumns: IndexColumn[] = indexCols.map((col) => {\n if (is(col, SQL)) {\n return {\n expression: dialect.sqlToQuery(col).sql,\n isExpression: true,\n };\n } else {\n const indexCol: IndexColumn = {\n expression: col.name,\n isExpression: false,\n asc: col.indexConfig && col.indexConfig.order === \"asc\",\n };\n // Only add nulls if explicitly specified in the config\n if (col.indexConfig?.nulls) {\n indexCol.nulls = col.indexConfig.nulls;\n }\n return indexCol;\n }\n });\n\n const name =\n idx.config.name || `${tableName}_${indexColumns.map((c) => c.expression).join(\"_\")}_index`;\n\n indexesObject[name] = {\n name,\n columns: indexColumns,\n isUnique: idx.config.unique || false,\n method: idx.config.method || \"btree\",\n };\n });\n\n // Drizzle check constraint interface\n interface DrizzleCheck {\n name: string;\n value: SQL;\n }\n\n // Process check constraints\n if (checks) {\n checks.forEach((check: DrizzleCheck) => {\n const checkName = check.name;\n checksObject[checkName] = {\n name: checkName,\n value: dialect.sqlToQuery(check.value).sql,\n };\n });\n }\n\n // Build the table object\n tables[`${tableSchema || \"public\"}.${tableName}`] = {\n name: tableName,\n schema: tableSchema || \"public\",\n columns: columnsObject,\n indexes: indexesObject,\n foreignKeys: foreignKeysObject,\n compositePrimaryKeys: primaryKeysObject,\n uniqueConstraints: uniqueConstraintObject,\n checkConstraints: checksObject,\n };\n\n // Track schemas\n if (tableSchema && tableSchema !== \"public\") {\n schemas[tableSchema] = tableSchema;\n }\n }\n\n // Create snapshot in Drizzle's format\n const snapshot: SchemaSnapshot = {\n version: \"7\",\n dialect: \"postgresql\",\n tables,\n schemas,\n enums,\n _meta: {\n schemas: {},\n tables: {},\n columns: {},\n },\n };\n\n return snapshot;\n}\n\n/**\n * Calculate hash of a snapshot for change detection\n * Uses a browser-compatible hash function\n */\nexport function hashSnapshot(snapshot: SchemaSnapshot): string {\n const content = JSON.stringify(snapshot);\n return extendedHash(content);\n}\n\n/**\n * Create an empty snapshot for initial migration\n */\nexport function createEmptySnapshot(): SchemaSnapshot {\n return {\n version: \"7\",\n dialect: \"postgresql\",\n tables: {},\n schemas: {},\n enums: {},\n _meta: {\n schemas: {},\n tables: {},\n columns: {},\n },\n };\n}\n\n/**\n * Compare two snapshots and detect if there are changes\n */\nexport function hasChanges(\n previousSnapshot: SchemaSnapshot | null,\n currentSnapshot: SchemaSnapshot\n): boolean {\n // If no previous snapshot, there are definitely changes\n if (!previousSnapshot) {\n return Object.keys(currentSnapshot.tables).length > 0;\n }\n\n // Simple comparison for now - in production, use deep comparison\n const prevHash = hashSnapshot(previousSnapshot);\n const currHash = hashSnapshot(currentSnapshot);\n\n return prevHash !== currHash;\n}\n",
108
- "import { logger } from \"@elizaos/core\";\nimport type {\n SchemaCheckConstraint,\n SchemaColumn,\n SchemaForeignKey,\n SchemaIndex,\n SchemaPrimaryKey,\n SchemaSnapshot,\n SchemaTable,\n SchemaUniqueConstraint,\n} from \"../types\";\nimport type { SchemaDiff } from \"./diff-calculator\";\n\n/**\n * Data loss detection result\n * Based on Drizzle's pgPushUtils approach\n */\nexport interface DataLossCheck {\n hasDataLoss: boolean;\n tablesToRemove: string[];\n columnsToRemove: string[];\n tablesToTruncate: string[];\n typeChanges: Array<{\n table: string;\n column: string;\n from: string;\n to: string;\n }>;\n warnings: string[];\n requiresConfirmation: boolean;\n}\n\n/**\n * Check for potential data loss in schema changes\n * Based on Drizzle's pgSuggestions function\n */\nexport function checkForDataLoss(diff: SchemaDiff): DataLossCheck {\n const result: DataLossCheck = {\n hasDataLoss: false,\n tablesToRemove: [],\n columnsToRemove: [],\n tablesToTruncate: [],\n typeChanges: [],\n warnings: [],\n requiresConfirmation: false,\n };\n\n // Check for table deletions\n if (diff.tables.deleted.length > 0) {\n result.hasDataLoss = true;\n result.requiresConfirmation = true;\n result.tablesToRemove = [...diff.tables.deleted];\n for (const table of diff.tables.deleted) {\n result.warnings.push(`Table \"${table}\" will be dropped with all its data`);\n }\n }\n\n // Check for column deletions\n if (diff.columns.deleted.length > 0) {\n result.hasDataLoss = true;\n result.requiresConfirmation = true;\n for (const col of diff.columns.deleted) {\n result.columnsToRemove.push(`${col.table}.${col.column}`);\n result.warnings.push(`Column \"${col.column}\" in table \"${col.table}\" will be dropped`);\n }\n }\n\n // Check for column type changes that might cause data loss\n for (const modified of diff.columns.modified) {\n const from = modified.changes.from;\n const to = modified.changes.to;\n\n if (!from || !to) continue;\n\n // Check if type change is destructive\n if (from.type !== to.type) {\n const isDestructive = checkIfTypeChangeIsDestructive(from.type, to.type);\n\n if (isDestructive) {\n result.hasDataLoss = true;\n result.requiresConfirmation = true;\n result.typeChanges.push({\n table: modified.table,\n column: modified.column,\n from: from.type,\n to: to.type,\n });\n result.tablesToTruncate.push(modified.table);\n result.warnings.push(\n `Column \"${modified.column}\" in table \"${modified.table}\" changes type from \"${from.type}\" to \"${to.type}\". ` +\n `This may require truncating the table to avoid data conversion errors.`\n );\n }\n }\n\n // Check for adding NOT NULL without default to existing column\n if (!from.notNull && to.notNull && !to.default) {\n result.hasDataLoss = true;\n result.requiresConfirmation = true;\n result.warnings.push(\n `Column \"${modified.column}\" in table \"${modified.table}\" is becoming NOT NULL without a default value. ` +\n `This will fail if the table contains NULL values.`\n );\n }\n }\n\n // Check for adding NOT NULL columns without defaults\n for (const added of diff.columns.added) {\n if (added.definition.notNull && !added.definition.default) {\n // This is only a problem if the table already has data\n // We'll flag it as a potential issue\n result.warnings.push(\n `Column \"${added.column}\" is being added to table \"${added.table}\" as NOT NULL without a default value. ` +\n `This will fail if the table contains data.`\n );\n // Don't set requiresConfirmation here - it's only a warning\n }\n }\n\n return result;\n}\n\n/**\n * Normalize SQL types for comparison\n * Handles equivalent type variations between introspected DB and schema definitions\n */\nfunction normalizeType(type: string | undefined): string {\n if (!type) return \"\";\n\n const normalized = type.toLowerCase().trim();\n\n // Handle timestamp variations - all are equivalent\n if (\n normalized === \"timestamp without time zone\" ||\n normalized === \"timestamp with time zone\" ||\n normalized === \"timestamptz\"\n ) {\n return \"timestamp\";\n }\n\n // Handle serial vs integer with identity\n // serial is essentially integer with auto-increment\n if (normalized === \"serial\") {\n return \"integer\";\n }\n if (normalized === \"bigserial\") {\n return \"bigint\";\n }\n if (normalized === \"smallserial\") {\n return \"smallint\";\n }\n\n // Handle numeric/decimal equivalence\n if (normalized.startsWith(\"numeric\") || normalized.startsWith(\"decimal\")) {\n // Extract precision and scale if present\n const match = normalized.match(/\\((\\d+)(?:,\\s*(\\d+))?\\)/);\n if (match) {\n return `numeric(${match[1]}${match[2] ? `,${match[2]}` : \"\"})`;\n }\n return \"numeric\";\n }\n\n // Handle varchar/character varying\n if (normalized.startsWith(\"character varying\")) {\n return normalized.replace(\"character varying\", \"varchar\");\n }\n\n // Handle text array variations\n if (normalized === \"text[]\" || normalized === \"_text\") {\n return \"text[]\";\n }\n\n return normalized;\n}\n\n/**\n * Check if a type change is destructive\n * Based on PostgreSQL's type casting rules\n */\nfunction checkIfTypeChangeIsDestructive(fromType: string, toType: string): boolean {\n // First normalize the types to handle equivalent variations\n const normalizedFrom = normalizeType(fromType);\n const normalizedTo = normalizeType(toType);\n\n // If normalized types match, it's not destructive\n if (normalizedFrom === normalizedTo) {\n return false;\n }\n\n // Safe conversions (PostgreSQL) - based on Drizzle's logic\n const safeConversions: Record<string, string[]> = {\n smallint: [\"integer\", \"bigint\", \"numeric\", \"real\", \"double precision\"],\n integer: [\"bigint\", \"numeric\", \"real\", \"double precision\"],\n bigint: [\"numeric\"],\n real: [\"double precision\"],\n varchar: [\"text\"],\n char: [\"varchar\", \"text\"],\n citext: [\"text\"],\n text: [\"citext\"],\n // UUID to text is safe\n uuid: [\"text\", \"varchar\"],\n // Timestamp variations are generally safe (now handled by normalization)\n timestamp: [\"timestamp\"], // Simplified since normalization handles variations\n // Date/time conversions\n date: [\"timestamp\"],\n time: [\"timetz\"],\n };\n\n const fromBase = normalizedFrom.split(\"(\")[0];\n const toBase = normalizedTo.split(\"(\")[0];\n\n // Same type is always safe\n if (fromBase === toBase) {\n return false;\n }\n\n // Check if it's a safe conversion\n const safeTo = safeConversions[fromBase];\n if (safeTo?.includes(toBase)) {\n return false;\n }\n\n // All other conversions are considered potentially destructive\n return true;\n}\n\n/**\n * Generate SQL statements from a schema diff\n * This follows Drizzle's approach: create all tables first, then add foreign keys\n */\nexport async function generateMigrationSQL(\n previousSnapshot: SchemaSnapshot | null,\n currentSnapshot: SchemaSnapshot,\n diff?: SchemaDiff\n): Promise<string[]> {\n const statements: string[] = [];\n\n // If no diff provided, calculate it\n if (!diff) {\n const { calculateDiff } = await import(\"./diff-calculator\");\n diff = await calculateDiff(previousSnapshot, currentSnapshot);\n }\n\n // Check for data loss\n const dataLossCheck = checkForDataLoss(diff);\n\n // Log warnings if any\n if (dataLossCheck.warnings.length > 0) {\n logger.warn(\n { src: \"plugin:sql\", warnings: dataLossCheck.warnings },\n \"Schema changes may cause data loss\"\n );\n }\n\n // Phase 1: Collect unique schemas and create them first\n const schemasToCreate = new Set<string>();\n for (const tableName of diff.tables.created) {\n const table = currentSnapshot.tables[tableName];\n if (table) {\n const schema = table.schema || \"public\";\n if (schema !== \"public\") {\n schemasToCreate.add(schema);\n }\n }\n }\n\n // Create schemas first (following drizzle-kit pattern)\n for (const schema of schemasToCreate) {\n statements.push(`CREATE SCHEMA IF NOT EXISTS \"${schema}\";`);\n }\n\n // Phase 2: Generate CREATE TABLE statements for new tables (WITHOUT foreign keys)\n const createTableStatements: string[] = [];\n const foreignKeyStatements: string[] = [];\n\n for (const tableName of diff.tables.created) {\n const table = currentSnapshot.tables[tableName];\n if (table) {\n const { tableSQL, fkSQLs } = generateCreateTableSQL(tableName, table);\n createTableStatements.push(tableSQL);\n foreignKeyStatements.push(...fkSQLs);\n }\n }\n\n // Add all CREATE TABLE statements\n statements.push(...createTableStatements);\n\n // Phase 3: Add all foreign keys AFTER tables are created\n // Deduplicate foreign key statements to avoid duplicate constraints\n const uniqueFKs = new Set<string>();\n const dedupedFKStatements: string[] = [];\n\n for (const fkSQL of foreignKeyStatements) {\n // Extract constraint name to check for duplicates\n const match = fkSQL.match(/ADD CONSTRAINT \"([^\"]+)\"/);\n if (match) {\n const constraintName = match[1];\n if (!uniqueFKs.has(constraintName)) {\n uniqueFKs.add(constraintName);\n dedupedFKStatements.push(fkSQL);\n }\n } else {\n dedupedFKStatements.push(fkSQL);\n }\n }\n\n statements.push(...dedupedFKStatements);\n\n // Phase 4: Handle table modifications\n\n // Generate DROP TABLE statements for deleted tables\n for (const tableName of diff.tables.deleted) {\n const [schema, name] = tableName.includes(\".\") ? tableName.split(\".\") : [\"public\", tableName];\n statements.push(`DROP TABLE IF EXISTS \"${schema}\".\"${name}\" CASCADE;`);\n }\n\n // Generate ALTER TABLE statements for column changes\n // Handle column additions\n for (const added of diff.columns.added) {\n statements.push(generateAddColumnSQL(added.table, added.column, added.definition));\n }\n\n // Handle column deletions\n for (const deleted of diff.columns.deleted) {\n statements.push(generateDropColumnSQL(deleted.table, deleted.column));\n }\n\n // Handle column modifications\n for (const modified of diff.columns.modified) {\n const alterStatements = generateAlterColumnSQL(\n modified.table,\n modified.column,\n modified.changes\n );\n statements.push(...alterStatements);\n }\n\n // Generate DROP INDEX statements (including altered ones - drop old version)\n for (const index of diff.indexes.deleted) {\n statements.push(generateDropIndexSQL(index));\n }\n\n // Drop old version of altered indexes\n for (const alteredIndex of diff.indexes.altered) {\n statements.push(generateDropIndexSQL(alteredIndex.old));\n }\n\n // Generate CREATE INDEX statements (including altered ones - create new version)\n for (const index of diff.indexes.created) {\n statements.push(generateCreateIndexSQL(index));\n }\n\n // Create new version of altered indexes\n for (const alteredIndex of diff.indexes.altered) {\n statements.push(generateCreateIndexSQL(alteredIndex.new));\n }\n\n // Generate CREATE UNIQUE CONSTRAINT statements\n for (const constraint of diff.uniqueConstraints.created) {\n // Skip if it's part of a new table (already handled)\n const isNewTable = diff.tables.created.some((tableName) => {\n const [schema, table] = tableName.includes(\".\")\n ? tableName.split(\".\")\n : [\"public\", tableName];\n const constraintTable =\n (constraint as SchemaUniqueConstraint & { table?: string }).table || \"\";\n const [constraintSchema, constraintTableName] = constraintTable.includes(\".\")\n ? constraintTable.split(\".\")\n : [\"public\", constraintTable];\n return table === constraintTableName && schema === constraintSchema;\n });\n\n if (!isNewTable) {\n statements.push(generateCreateUniqueConstraintSQL(constraint));\n }\n }\n\n // Generate DROP UNIQUE CONSTRAINT statements\n for (const constraint of diff.uniqueConstraints.deleted) {\n statements.push(generateDropUniqueConstraintSQL(constraint));\n }\n\n // Generate CREATE CHECK CONSTRAINT statements\n for (const constraint of diff.checkConstraints.created) {\n // Skip if it's part of a new table (already handled)\n const isNewTable = diff.tables.created.some((tableName) => {\n const [schema, table] = tableName.includes(\".\")\n ? tableName.split(\".\")\n : [\"public\", tableName];\n const constraintTable =\n (constraint as SchemaCheckConstraint & { table?: string }).table || \"\";\n const [constraintSchema, constraintTableName] = constraintTable.includes(\".\")\n ? constraintTable.split(\".\")\n : [\"public\", constraintTable];\n return table === constraintTableName && schema === constraintSchema;\n });\n\n if (!isNewTable) {\n statements.push(generateCreateCheckConstraintSQL(constraint));\n }\n }\n\n // Generate DROP CHECK CONSTRAINT statements\n for (const constraint of diff.checkConstraints.deleted) {\n statements.push(generateDropCheckConstraintSQL(constraint));\n }\n\n // Handle foreign key deletions first (including altered ones)\n for (const fk of diff.foreignKeys.deleted) {\n statements.push(generateDropForeignKeySQL(fk));\n }\n\n // Drop old version of altered foreign keys\n for (const alteredFK of diff.foreignKeys.altered) {\n statements.push(generateDropForeignKeySQL(alteredFK.old));\n }\n\n // Handle foreign key creations (for existing tables)\n for (const fk of diff.foreignKeys.created) {\n // Only add if it's not part of a new table (those were handled above)\n // Check both with and without schema prefix\n const tableFrom = fk.tableFrom || \"\";\n const schemaFrom = fk.schemaFrom || \"public\";\n\n const isNewTable = diff.tables.created.some((tableName) => {\n // Compare table names, handling schema prefixes\n const [createdSchema, createdTable] = tableName.includes(\".\")\n ? tableName.split(\".\")\n : [\"public\", tableName];\n\n // Compare using the actual schema and table from the FK\n return createdTable === tableFrom && createdSchema === schemaFrom;\n });\n\n if (!isNewTable) {\n statements.push(generateCreateForeignKeySQL(fk));\n }\n }\n\n // Create new version of altered foreign keys\n for (const alteredFK of diff.foreignKeys.altered) {\n statements.push(generateCreateForeignKeySQL(alteredFK.new));\n }\n\n return statements;\n}\n\n/**\n * Generate CREATE TABLE SQL (following Drizzle's pattern)\n * Returns the table creation SQL and separate foreign key SQLs\n */\nfunction generateCreateTableSQL(\n fullTableName: string,\n table: SchemaTable\n): { tableSQL: string; fkSQLs: string[] } {\n const [schema, tableName] = fullTableName.includes(\".\")\n ? fullTableName.split(\".\")\n : [\"public\", fullTableName];\n const columns: string[] = [];\n const fkSQLs: string[] = [];\n\n // Add columns\n for (const [colName, colDef] of Object.entries(table.columns || {})) {\n columns.push(generateColumnDefinition(colName, colDef));\n }\n\n // Add composite primary keys if exists\n const primaryKeys = table.compositePrimaryKeys || {};\n for (const [pkName, pkDef] of Object.entries(primaryKeys)) {\n const pk = pkDef as SchemaPrimaryKey;\n if (pk.columns && pk.columns.length > 0) {\n columns.push(\n `CONSTRAINT \"${pkName}\" PRIMARY KEY (${pk.columns.map((c) => `\"${c}\"`).join(\", \")})`\n );\n }\n }\n\n // Add unique constraints\n const uniqueConstraints = table.uniqueConstraints || {};\n for (const [uqName, uqDef] of Object.entries(uniqueConstraints)) {\n const uq = uqDef as SchemaUniqueConstraint;\n if (uq.columns && uq.columns.length > 0) {\n const uniqueDef = uq.nullsNotDistinct\n ? `CONSTRAINT \"${uqName}\" UNIQUE NULLS NOT DISTINCT (${uq.columns.map((c) => `\"${c}\"`).join(\", \")})`\n : `CONSTRAINT \"${uqName}\" UNIQUE (${uq.columns.map((c) => `\"${c}\"`).join(\", \")})`;\n columns.push(uniqueDef);\n }\n }\n\n // Add check constraints\n const checkConstraints = table.checkConstraints || {};\n for (const [checkName, checkDef] of Object.entries(checkConstraints)) {\n const check = checkDef as SchemaCheckConstraint;\n if (check.value) {\n columns.push(`CONSTRAINT \"${checkName}\" CHECK (${check.value})`);\n }\n }\n\n // Following drizzle-kit pattern: don't create schema here, it's handled separately\n const tableSQL = `CREATE TABLE IF NOT EXISTS \"${schema}\".\"${tableName}\" (\\n ${columns.join(\",\\n \")}\\n);`;\n\n // Collect foreign keys to be added AFTER all tables are created\n const foreignKeys = table.foreignKeys || {};\n for (const [fkName, fkDef] of Object.entries(foreignKeys)) {\n const fk = fkDef as SchemaForeignKey;\n const fkSQL = `ALTER TABLE \"${schema}\".\"${tableName}\" ADD CONSTRAINT \"${fkName}\" FOREIGN KEY (${fk.columnsFrom.map((c) => `\"${c}\"`).join(\", \")}) REFERENCES \"${fk.schemaTo || \"public\"}\".\"${fk.tableTo}\" (${fk.columnsTo.map((c) => `\"${c}\"`).join(\", \")})${fk.onDelete ? ` ON DELETE ${fk.onDelete}` : \"\"}${fk.onUpdate ? ` ON UPDATE ${fk.onUpdate}` : \"\"};`;\n fkSQLs.push(fkSQL);\n }\n\n return { tableSQL, fkSQLs };\n}\n\n/**\n * Generate column definition (following Drizzle's pattern)\n */\nfunction generateColumnDefinition(name: string, def: SchemaColumn): string {\n let sql = `\"${name}\" ${def.type}`;\n\n // Handle primary key that's not part of composite\n if (def.primaryKey && !def.type.includes(\"SERIAL\")) {\n sql += \" PRIMARY KEY\";\n }\n\n // Add NOT NULL constraint\n if (def.notNull) {\n sql += \" NOT NULL\";\n }\n\n // Add DEFAULT value - properly formatted\n if (def.default !== undefined) {\n const defaultValue = formatDefaultValue(def.default, def.type);\n sql += ` DEFAULT ${defaultValue}`;\n }\n\n return sql;\n}\n\n/**\n * Generate ALTER TABLE ADD COLUMN SQL\n * Based on Drizzle's PgAlterTableAddColumnConvertor\n */\nfunction generateAddColumnSQL(table: string, column: string, definition: SchemaColumn): string {\n const [schema, tableName] = table.includes(\".\") ? table.split(\".\") : [\"public\", table];\n const tableNameWithSchema = `\"${schema}\".\"${tableName}\"`;\n\n // Build column definition parts in the correct order (like Drizzle)\n const parts: string[] = [`\"${column}\"`];\n\n // Type\n parts.push(definition.type);\n\n // Primary key\n if (definition.primaryKey) {\n parts.push(\"PRIMARY KEY\");\n }\n\n // Default value - needs proper formatting based on type\n if (definition.default !== undefined) {\n const defaultValue = formatDefaultValue(definition.default, definition.type);\n if (defaultValue) {\n parts.push(`DEFAULT ${defaultValue}`);\n }\n }\n\n // Generated columns\n const definitionWithGenerated = definition as SchemaColumn & { generated?: string };\n if (definitionWithGenerated.generated) {\n parts.push(`GENERATED ALWAYS AS (${definitionWithGenerated.generated}) STORED`);\n }\n\n // NOT NULL constraint - comes after DEFAULT\n if (definition.notNull) {\n parts.push(\"NOT NULL\");\n }\n\n return `ALTER TABLE ${tableNameWithSchema} ADD COLUMN ${parts.join(\" \")};`;\n}\n\n/**\n * Generate ALTER TABLE DROP COLUMN SQL\n * Based on Drizzle's approach with CASCADE\n */\nfunction generateDropColumnSQL(table: string, column: string): string {\n const [schema, tableName] = table.includes(\".\") ? table.split(\".\") : [\"public\", table];\n const tableNameWithSchema = `\"${schema}\".\"${tableName}\"`;\n // Use CASCADE to handle dependent objects\n return `ALTER TABLE ${tableNameWithSchema} DROP COLUMN \"${column}\" CASCADE;`;\n}\n\n// Column change tracking interface\ninterface ColumnChangeInfo {\n from?: SchemaColumn;\n to?: SchemaColumn;\n}\n\n/**\n * Generate ALTER TABLE ALTER COLUMN SQL\n * Based on Drizzle's approach with proper type casting and handling\n */\nfunction generateAlterColumnSQL(\n table: string,\n column: string,\n changes: ColumnChangeInfo\n): string[] {\n const [schema, tableName] = table.includes(\".\") ? table.split(\".\") : [\"public\", table];\n const tableNameWithSchema = `\"${schema}\".\"${tableName}\"`;\n const statements: string[] = [];\n\n // Handle type changes - need to handle enums and complex types\n const changesTo = changes.to;\n const changesFrom = changes.from;\n const changesToType = changesTo?.type;\n const changesFromType = changesFrom?.type;\n if (changesToType !== changesFromType) {\n const newType = changesToType || \"TEXT\";\n\n // Check if we need a USING clause for type conversion\n const needsUsing = checkIfNeedsUsingClause(changesFromType || \"\", newType);\n\n if (needsUsing) {\n // For complex type changes, use USING clause like Drizzle\n statements.push(\n `ALTER TABLE ${tableNameWithSchema} ALTER COLUMN \"${column}\" TYPE ${newType} USING \"${column}\"::text::${newType};`\n );\n } else {\n statements.push(\n `ALTER TABLE ${tableNameWithSchema} ALTER COLUMN \"${column}\" SET DATA TYPE ${newType};`\n );\n }\n }\n\n // Handle NOT NULL changes\n const changesToNotNull = changesTo?.notNull;\n const changesFromNotNull = changesFrom?.notNull;\n if (changesToNotNull !== changesFromNotNull) {\n if (changesToNotNull) {\n // When adding NOT NULL, might need to set defaults for existing NULL values\n statements.push(`ALTER TABLE ${tableNameWithSchema} ALTER COLUMN \"${column}\" SET NOT NULL;`);\n } else {\n statements.push(`ALTER TABLE ${tableNameWithSchema} ALTER COLUMN \"${column}\" DROP NOT NULL;`);\n }\n }\n\n // Handle default value changes\n const changesToDefault = changesTo?.default;\n const changesFromDefault = changesFrom?.default;\n if (changesToDefault !== changesFromDefault) {\n if (changesToDefault !== undefined) {\n const defaultValue = formatDefaultValue(changesToDefault, changesToType || \"\");\n statements.push(\n `ALTER TABLE ${tableNameWithSchema} ALTER COLUMN \"${column}\" SET DEFAULT ${defaultValue};`\n );\n } else {\n statements.push(`ALTER TABLE ${tableNameWithSchema} ALTER COLUMN \"${column}\" DROP DEFAULT;`);\n }\n }\n\n return statements;\n}\n\n/**\n * Check if a type change needs a USING clause\n * Based on Drizzle's type conversion logic\n */\nfunction checkIfNeedsUsingClause(fromType: string, toType: string): boolean {\n if (!fromType || !toType) return false;\n\n // Enum changes always need USING\n if (fromType.includes(\"enum\") || toType.includes(\"enum\")) {\n return true;\n }\n\n const fromBase = fromType.split(\"(\")[0].toLowerCase();\n const toBase = toType.split(\"(\")[0].toLowerCase();\n\n // Text/varchar to JSONB always needs USING\n if (\n (fromBase === \"text\" || fromBase === \"varchar\" || fromBase === \"character varying\") &&\n (toBase === \"jsonb\" || toBase === \"json\")\n ) {\n return true;\n }\n\n // Some specific type conversions need USING\n const needsUsingPairs = [\n [\"integer\", \"boolean\"],\n [\"boolean\", \"integer\"],\n [\"text\", \"integer\"],\n [\"text\", \"numeric\"],\n [\"text\", \"boolean\"],\n [\"text\", \"uuid\"],\n [\"text\", \"jsonb\"],\n [\"text\", \"json\"],\n [\"varchar\", \"integer\"],\n [\"varchar\", \"numeric\"],\n [\"varchar\", \"boolean\"],\n [\"varchar\", \"uuid\"],\n [\"varchar\", \"jsonb\"],\n [\"varchar\", \"json\"],\n [\"character varying\", \"jsonb\"],\n [\"character varying\", \"json\"],\n // Add more as needed based on PostgreSQL casting rules\n ];\n\n for (const [from, to] of needsUsingPairs) {\n if ((fromBase === from && toBase === to) || (fromBase === to && toBase === from)) {\n return true;\n }\n }\n\n return false;\n}\n\n// Default value type - can be string, number, boolean, or null\ntype DefaultValue = string | number | boolean | null | undefined;\n\n/**\n * Format a default value for SQL\n * Based on Drizzle's default value formatting\n */\nfunction formatDefaultValue(value: DefaultValue, type: string): string {\n // Handle NULL\n if (value === null || value === \"NULL\") {\n return \"NULL\";\n }\n\n // Handle boolean\n if (type && (type.toLowerCase().includes(\"boolean\") || type.toLowerCase() === \"bool\")) {\n if (value === true || value === \"true\" || value === \"t\" || value === 1) {\n return \"true\";\n }\n if (value === false || value === \"false\" || value === \"f\" || value === 0) {\n return \"false\";\n }\n }\n\n // Handle numeric types\n if (type?.match(/^(integer|bigint|smallint|numeric|decimal|real|double)/i)) {\n return String(value);\n }\n\n // Handle SQL expressions and pre-formatted defaults\n if (typeof value === \"string\") {\n // Already formatted with type cast (e.g., '[]'::jsonb, '{}'::jsonb)\n // These come from the snapshot and are already properly formatted\n if (value.includes(\"::\")) {\n return value;\n }\n\n // Already quoted string literals (from snapshot)\n // These start and end with single quotes\n if (value.startsWith(\"'\") && value.endsWith(\"'\")) {\n return value;\n }\n\n // SQL functions like now(), gen_random_uuid(), etc.\n if (value.match(/^\\w+\\(\\)/i) || (value.includes(\"(\") && value.includes(\")\"))) {\n return value;\n }\n\n // SQL expressions starting with CURRENT_\n if (value.toUpperCase().startsWith(\"CURRENT_\")) {\n return value;\n }\n\n // Otherwise, it's an unquoted string literal - wrap and escape\n return `'${value.replace(/'/g, \"''\")}'`;\n }\n\n // Default: return as-is\n return String(value);\n}\n\n// Extended index interface with table reference\ninterface SchemaIndexWithTableRef {\n name: string;\n columns: Array<{ expression: string; isExpression: boolean; asc?: boolean; nulls?: string }>;\n isUnique: boolean;\n method?: string;\n where?: string;\n concurrently?: boolean;\n table?: string;\n}\n\n/**\n * Generate CREATE INDEX SQL\n */\nfunction generateCreateIndexSQL(index: SchemaIndexWithTableRef): string {\n const unique = index.isUnique ? \"UNIQUE \" : \"\";\n const method = index.method || \"btree\";\n const columns = index.columns\n .map((c) => {\n if (c.isExpression) {\n return c.expression;\n }\n // Only add DESC if explicitly set to false, no NULLS clause by default\n return `\"${c.expression}\"${c.asc === false ? \" DESC\" : \"\"}`;\n })\n .join(\", \");\n\n // Extract index name and table with proper schema handling\n const indexName = index.name.includes(\".\") ? index.name.split(\".\")[1] : index.name;\n\n // Keep the full table name with schema if present\n let tableRef: string;\n const indexTable = index.table;\n if (indexTable?.includes(\".\")) {\n const [schema, table] = indexTable.split(\".\");\n tableRef = `\"${schema}\".\"${table}\"`;\n } else {\n tableRef = `\"${indexTable || \"\"}\"`;\n }\n\n // Include schema in table reference for correct index creation\n return `CREATE ${unique}INDEX \"${indexName}\" ON ${tableRef} USING ${method} (${columns});`;\n}\n\n/**\n * Generate DROP INDEX SQL\n */\nfunction generateDropIndexSQL(index: SchemaIndex | string): string {\n // Extract just the index name without schema\n const indexNameFull = typeof index === \"string\" ? index : index.name;\n const indexName = indexNameFull.includes(\".\") ? indexNameFull.split(\".\")[1] : indexNameFull;\n // Match Drizzle's format - no schema qualification\n return `DROP INDEX IF EXISTS \"${indexName}\";`;\n}\n\n/**\n * Generate CREATE FOREIGN KEY SQL (for existing tables)\n */\nfunction generateCreateForeignKeySQL(fk: SchemaForeignKey): string {\n const schemaFrom = fk.schemaFrom || \"public\";\n const schemaTo = fk.schemaTo || \"public\";\n const tableFrom = fk.tableFrom;\n const columnsFrom = fk.columnsFrom.map((c: string) => `\"${c}\"`).join(\", \");\n const columnsTo = fk.columnsTo.map((c: string) => `\"${c}\"`).join(\", \");\n\n let sql = `ALTER TABLE \"${schemaFrom}\".\"${tableFrom}\" ADD CONSTRAINT \"${fk.name}\" FOREIGN KEY (${columnsFrom}) REFERENCES \"${schemaTo}\".\"${fk.tableTo}\" (${columnsTo})`;\n\n if (fk.onDelete) {\n sql += ` ON DELETE ${fk.onDelete}`;\n }\n\n if (fk.onUpdate) {\n sql += ` ON UPDATE ${fk.onUpdate}`;\n }\n\n return `${sql};`;\n}\n\n/**\n * Generate DROP FOREIGN KEY SQL\n */\nfunction generateDropForeignKeySQL(fk: SchemaForeignKey): string {\n const [schema, tableName] = fk.tableFrom\n ? fk.tableFrom.includes(\".\")\n ? fk.tableFrom.split(\".\")\n : [\"public\", fk.tableFrom]\n : [\"public\", \"\"];\n return `ALTER TABLE \"${schema}\".\"${tableName}\" DROP CONSTRAINT \"${fk.name}\";`;\n}\n\n/**\n * Generate SQL for renaming a table\n */\nexport function generateRenameTableSQL(oldName: string, newName: string): string {\n const [oldSchema, oldTable] = oldName.includes(\".\") ? oldName.split(\".\") : [\"public\", oldName];\n const [, newTable] = newName.includes(\".\") ? newName.split(\".\") : [\"public\", newName];\n return `ALTER TABLE \"${oldSchema}\".\"${oldTable}\" RENAME TO \"${newTable}\";`;\n}\n\n/**\n * Generate SQL for renaming a column\n */\nexport function generateRenameColumnSQL(table: string, oldName: string, newName: string): string {\n const [schema, tableName] = table.includes(\".\") ? table.split(\".\") : [\"public\", table];\n return `ALTER TABLE \"${schema}\".\"${tableName}\" RENAME COLUMN \"${oldName}\" TO \"${newName}\";`;\n}\n\n// Extended constraint interfaces with table reference\ninterface UniqueConstraintWithTable extends SchemaUniqueConstraint {\n table?: string;\n}\n\ninterface CheckConstraintWithTable extends SchemaCheckConstraint {\n table?: string;\n}\n\n/**\n * Generate CREATE UNIQUE CONSTRAINT SQL\n */\nfunction generateCreateUniqueConstraintSQL(constraint: UniqueConstraintWithTable): string {\n const table = constraint.table || \"\";\n const [schema, tableName] = table.includes(\".\") ? table.split(\".\") : [\"public\", table];\n\n const name = constraint.name;\n const columns = constraint.columns.map((c) => `\"${c}\"`).join(\", \");\n\n let sql = `ALTER TABLE \"${schema}\".\"${tableName}\" ADD CONSTRAINT \"${name}\" UNIQUE`;\n\n // Handle NULLS NOT DISTINCT if specified (PostgreSQL 15+)\n if (constraint.nullsNotDistinct) {\n sql += ` NULLS NOT DISTINCT`;\n }\n\n sql += ` (${columns});`;\n\n return sql;\n}\n\n/**\n * Generate DROP UNIQUE CONSTRAINT SQL\n */\nfunction generateDropUniqueConstraintSQL(constraint: UniqueConstraintWithTable): string {\n const table = constraint.table || \"\";\n const [schema, tableName] = table.includes(\".\") ? table.split(\".\") : [\"public\", table];\n\n return `ALTER TABLE \"${schema}\".\"${tableName}\" DROP CONSTRAINT \"${constraint.name}\";`;\n}\n\n/**\n * Generate CREATE CHECK CONSTRAINT SQL\n */\nfunction generateCreateCheckConstraintSQL(constraint: CheckConstraintWithTable): string {\n const table = constraint.table || \"\";\n const [schema, tableName] = table.includes(\".\") ? table.split(\".\") : [\"public\", table];\n\n const name = constraint.name;\n const value = constraint.value;\n\n return `ALTER TABLE \"${schema}\".\"${tableName}\" ADD CONSTRAINT \"${name}\" CHECK (${value});`;\n}\n\n/**\n * Generate DROP CHECK CONSTRAINT SQL\n */\nfunction generateDropCheckConstraintSQL(constraint: CheckConstraintWithTable): string {\n const table = constraint.table || \"\";\n const [schema, tableName] = table.includes(\".\") ? table.split(\".\") : [\"public\", table];\n\n return `ALTER TABLE \"${schema}\".\"${tableName}\" DROP CONSTRAINT \"${constraint.name}\";`;\n}\n",
109
- "import { logger } from \"@elizaos/core\";\nimport { sql } from \"drizzle-orm\";\nimport type {\n CheckConstraintInfoRow,\n ColumnInfoRow,\n DrizzleDB,\n EnumInfoRow,\n ForeignKeyInfoRow,\n IndexInfoRow,\n PrimaryKeyInfoRow,\n SchemaCheckConstraint,\n SchemaColumn,\n SchemaEnum,\n SchemaForeignKey,\n SchemaIndex,\n SchemaPrimaryKey,\n SchemaSnapshot,\n SchemaTable,\n SchemaUniqueConstraint,\n TableInfoRow,\n UniqueConstraintInfoRow,\n} from \"../types\";\n\n/**\n * Type-safe extraction of rows from SQL query results.\n * Raw SQL queries in Drizzle return untyped rows - this helper provides type safety.\n */\nfunction getRows<T>(result: { rows: unknown[] }): T[] {\n return result.rows as T[];\n}\n\n/**\n * Introspect the current database state and generate a snapshot\n * This is used when no previous snapshot exists for a plugin\n * to capture the existing database state before migrations\n */\nexport class DatabaseIntrospector {\n constructor(private db: DrizzleDB) {}\n\n /**\n * Introspect all tables in the database and generate a snapshot\n * @param schemaName - Schema to introspect (default: 'public')\n * @returns Schema snapshot of current database state\n */\n async introspectSchema(schemaName: string = \"public\"): Promise<SchemaSnapshot> {\n logger.info({ src: \"plugin:sql\", schemaName }, \"Starting database introspection\");\n\n const tables: Record<string, SchemaTable> = {};\n const schemas: Record<string, string> = {};\n const enums: Record<string, SchemaEnum> = {};\n\n // Get all tables in the schema\n const allTables = await this.getTables(schemaName);\n\n for (const tableInfo of allTables) {\n const tableName = tableInfo.table_name;\n const tableSchema = tableInfo.table_schema || \"public\";\n\n logger.debug({ src: \"plugin:sql\", tableSchema, tableName }, \"Introspecting table\");\n\n // Get columns for this table\n const columns = await this.getColumns(tableSchema, tableName);\n const columnsObject: Record<string, SchemaColumn> = {};\n const uniqueConstraintObject: Record<string, SchemaUniqueConstraint> = {};\n\n for (const col of columns) {\n columnsObject[col.column_name] = {\n name: col.column_name,\n type: col.data_type,\n primaryKey: col.is_primary || false,\n notNull: col.is_nullable === \"NO\",\n default: col.column_default\n ? this.parseDefault(col.column_default, col.data_type)\n : undefined,\n };\n }\n\n // Get indexes\n const indexes = await this.getIndexes(tableSchema, tableName);\n const indexesObject: Record<string, SchemaIndex> = {};\n\n for (const idx of indexes) {\n if (!idx.is_primary && !idx.is_unique_constraint) {\n // Skip primary keys and unique constraints\n // Also skip indexes with no columns (partial indexes, expression indexes, etc.)\n if (idx.columns && Array.isArray(idx.columns) && idx.columns.length > 0) {\n indexesObject[idx.name] = {\n name: idx.name,\n columns: idx.columns.map((col) => ({\n expression: col,\n isExpression: false,\n })),\n isUnique: idx.is_unique,\n method: idx.method || \"btree\",\n };\n }\n }\n }\n\n // Get foreign keys\n const foreignKeys = await this.getForeignKeys(tableSchema, tableName);\n const foreignKeysObject: Record<string, SchemaForeignKey> = {};\n\n for (const fk of foreignKeys) {\n foreignKeysObject[fk.name] = {\n name: fk.name,\n tableFrom: tableName,\n schemaFrom: tableSchema,\n tableTo: fk.foreign_table_name,\n schemaTo: fk.foreign_table_schema || \"public\",\n columnsFrom: [fk.column_name],\n columnsTo: [fk.foreign_column_name],\n onDelete: fk.delete_rule?.toLowerCase() || \"no action\",\n onUpdate: fk.update_rule?.toLowerCase() || \"no action\",\n };\n }\n\n // Get primary keys\n const primaryKeys = await this.getPrimaryKeys(tableSchema, tableName);\n const primaryKeysObject: Record<string, SchemaPrimaryKey> = {};\n\n for (const pk of primaryKeys) {\n primaryKeysObject[pk.name] = {\n name: pk.name,\n columns: pk.columns,\n };\n }\n\n // Get unique constraints\n const uniqueConstraints = await this.getUniqueConstraints(tableSchema, tableName);\n\n for (const unq of uniqueConstraints) {\n uniqueConstraintObject[unq.name] = {\n name: unq.name,\n columns: unq.columns,\n nullsNotDistinct: false, // Default value\n };\n }\n\n // Get check constraints\n const checkConstraints = await this.getCheckConstraints(tableSchema, tableName);\n const checksObject: Record<string, SchemaCheckConstraint> = {};\n\n for (const check of checkConstraints) {\n checksObject[check.name] = {\n name: check.name,\n value: check.definition,\n };\n }\n\n // Build the table object\n tables[`${tableSchema}.${tableName}`] = {\n name: tableName,\n schema: tableSchema,\n columns: columnsObject,\n indexes: indexesObject,\n foreignKeys: foreignKeysObject,\n compositePrimaryKeys: primaryKeysObject,\n uniqueConstraints: uniqueConstraintObject,\n checkConstraints: checksObject,\n };\n\n // Track schemas\n if (tableSchema && tableSchema !== \"public\") {\n schemas[tableSchema] = tableSchema;\n }\n }\n\n // Get enums if any\n const enumsResult = await this.getEnums(schemaName);\n for (const enumInfo of enumsResult) {\n const key = `${enumInfo.schema}.${enumInfo.name}`;\n if (!enums[key]) {\n enums[key] = {\n name: enumInfo.name,\n schema: enumInfo.schema,\n values: [],\n };\n }\n enums[key].values.push(enumInfo.value);\n }\n\n logger.info(\n { src: \"plugin:sql\", tableCount: Object.keys(tables).length },\n \"Database introspection complete\"\n );\n\n return {\n version: \"7\",\n dialect: \"postgresql\",\n tables,\n schemas,\n enums,\n _meta: {\n schemas: {},\n tables: {},\n columns: {},\n },\n };\n }\n\n /**\n * Get all tables in a schema\n */\n private async getTables(schemaName: string): Promise<TableInfoRow[]> {\n const result = await this.db.execute(\n sql`SELECT \n table_schema,\n table_name\n FROM information_schema.tables\n WHERE table_schema = ${schemaName}\n AND table_type = 'BASE TABLE'\n ORDER BY table_name`\n );\n return getRows<TableInfoRow>(result);\n }\n\n /**\n * Get columns for a table\n */\n private async getColumns(schemaName: string, tableName: string): Promise<ColumnInfoRow[]> {\n const result = await this.db.execute(\n sql`SELECT \n a.attname AS column_name,\n CASE \n WHEN a.attnotnull THEN 'NO'\n ELSE 'YES'\n END AS is_nullable,\n CASE \n WHEN a.atttypid = ANY ('{int,int8,int2}'::regtype[]) \n AND EXISTS (\n SELECT FROM pg_attrdef ad\n WHERE ad.adrelid = a.attrelid \n AND ad.adnum = a.attnum \n AND pg_get_expr(ad.adbin, ad.adrelid) = 'nextval(''' \n || pg_get_serial_sequence(a.attrelid::regclass::text, a.attname)::regclass || '''::regclass)'\n )\n THEN CASE a.atttypid\n WHEN 'int'::regtype THEN 'serial'\n WHEN 'int8'::regtype THEN 'bigserial'\n WHEN 'int2'::regtype THEN 'smallserial'\n END\n ELSE format_type(a.atttypid, a.atttypmod)\n END AS data_type,\n pg_get_expr(ad.adbin, ad.adrelid) AS column_default,\n CASE \n WHEN con.contype = 'p' THEN true\n ELSE false\n END AS is_primary\n FROM pg_attribute a\n JOIN pg_class cls ON cls.oid = a.attrelid\n JOIN pg_namespace ns ON ns.oid = cls.relnamespace\n LEFT JOIN pg_attrdef ad ON ad.adrelid = a.attrelid AND ad.adnum = a.attnum\n LEFT JOIN pg_constraint con ON con.conrelid = a.attrelid \n AND a.attnum = ANY(con.conkey) \n AND con.contype = 'p'\n WHERE \n a.attnum > 0\n AND NOT a.attisdropped\n AND ns.nspname = ${schemaName}\n AND cls.relname = ${tableName}\n ORDER BY a.attnum`\n );\n return getRows<ColumnInfoRow>(result);\n }\n\n /**\n * Get indexes for a table\n */\n private async getIndexes(schemaName: string, tableName: string): Promise<IndexInfoRow[]> {\n const result = await this.db.execute(\n sql`SELECT \n i.relname AS name,\n idx.indisunique AS is_unique,\n idx.indisprimary AS is_primary,\n con.contype = 'u' AS is_unique_constraint,\n ARRAY(\n SELECT a.attname\n FROM pg_attribute a\n WHERE a.attrelid = idx.indrelid\n AND a.attnum = ANY(idx.indkey::int[])\n ORDER BY a.attnum\n ) AS columns,\n am.amname AS method\n FROM pg_index idx\n JOIN pg_class i ON i.oid = idx.indexrelid\n JOIN pg_class c ON c.oid = idx.indrelid\n JOIN pg_namespace n ON n.oid = c.relnamespace\n JOIN pg_am am ON am.oid = i.relam\n LEFT JOIN pg_constraint con ON con.conindid = idx.indexrelid\n WHERE n.nspname = ${schemaName}\n AND c.relname = ${tableName}`\n );\n return getRows<IndexInfoRow>(result);\n }\n\n /**\n * Get foreign keys for a table\n */\n private async getForeignKeys(\n schemaName: string,\n tableName: string\n ): Promise<ForeignKeyInfoRow[]> {\n const result = await this.db.execute(\n sql`SELECT\n con.conname AS name,\n att.attname AS column_name,\n fnsp.nspname AS foreign_table_schema,\n frel.relname AS foreign_table_name,\n fatt.attname AS foreign_column_name,\n CASE con.confupdtype\n WHEN 'a' THEN 'NO ACTION'\n WHEN 'r' THEN 'RESTRICT'\n WHEN 'n' THEN 'SET NULL'\n WHEN 'c' THEN 'CASCADE'\n WHEN 'd' THEN 'SET DEFAULT'\n END AS update_rule,\n CASE con.confdeltype\n WHEN 'a' THEN 'NO ACTION'\n WHEN 'r' THEN 'RESTRICT'\n WHEN 'n' THEN 'SET NULL'\n WHEN 'c' THEN 'CASCADE'\n WHEN 'd' THEN 'SET DEFAULT'\n END AS delete_rule\n FROM pg_catalog.pg_constraint con\n JOIN pg_catalog.pg_class rel ON rel.oid = con.conrelid\n JOIN pg_catalog.pg_namespace nsp ON nsp.oid = con.connamespace\n LEFT JOIN pg_catalog.pg_attribute att ON att.attnum = ANY (con.conkey)\n AND att.attrelid = con.conrelid\n LEFT JOIN pg_catalog.pg_class frel ON frel.oid = con.confrelid\n LEFT JOIN pg_catalog.pg_namespace fnsp ON fnsp.oid = frel.relnamespace\n LEFT JOIN pg_catalog.pg_attribute fatt ON fatt.attnum = ANY (con.confkey)\n AND fatt.attrelid = con.confrelid\n WHERE con.contype = 'f'\n AND nsp.nspname = ${schemaName}\n AND rel.relname = ${tableName}`\n );\n return getRows<ForeignKeyInfoRow>(result);\n }\n\n /**\n * Get primary keys for a table\n */\n private async getPrimaryKeys(\n schemaName: string,\n tableName: string\n ): Promise<PrimaryKeyInfoRow[]> {\n const result = await this.db.execute(\n sql`SELECT \n con.conname AS name,\n ARRAY(\n SELECT a.attname\n FROM pg_attribute a\n WHERE a.attrelid = con.conrelid\n AND a.attnum = ANY(con.conkey)\n ORDER BY a.attnum\n ) AS columns\n FROM pg_constraint con\n JOIN pg_class rel ON rel.oid = con.conrelid\n JOIN pg_namespace nsp ON nsp.oid = con.connamespace\n WHERE con.contype = 'p'\n AND nsp.nspname = ${schemaName}\n AND rel.relname = ${tableName}`\n );\n return getRows<PrimaryKeyInfoRow>(result);\n }\n\n /**\n * Get unique constraints for a table\n */\n private async getUniqueConstraints(\n schemaName: string,\n tableName: string\n ): Promise<UniqueConstraintInfoRow[]> {\n const result = await this.db.execute(\n sql`SELECT \n con.conname AS name,\n ARRAY(\n SELECT a.attname\n FROM pg_attribute a\n WHERE a.attrelid = con.conrelid\n AND a.attnum = ANY(con.conkey)\n ORDER BY a.attnum\n ) AS columns\n FROM pg_constraint con\n JOIN pg_class rel ON rel.oid = con.conrelid\n JOIN pg_namespace nsp ON nsp.oid = con.connamespace\n WHERE con.contype = 'u'\n AND nsp.nspname = ${schemaName}\n AND rel.relname = ${tableName}`\n );\n return getRows<UniqueConstraintInfoRow>(result);\n }\n\n /**\n * Get check constraints for a table\n */\n private async getCheckConstraints(\n schemaName: string,\n tableName: string\n ): Promise<CheckConstraintInfoRow[]> {\n const result = await this.db.execute(\n sql`SELECT \n con.conname AS name,\n pg_get_constraintdef(con.oid) AS definition\n FROM pg_constraint con\n JOIN pg_class rel ON rel.oid = con.conrelid\n JOIN pg_namespace nsp ON nsp.oid = con.connamespace\n WHERE con.contype = 'c'\n AND nsp.nspname = ${schemaName}\n AND rel.relname = ${tableName}`\n );\n return getRows<CheckConstraintInfoRow>(result);\n }\n\n /**\n * Get enums in a schema\n */\n private async getEnums(schemaName: string): Promise<EnumInfoRow[]> {\n const result = await this.db.execute(\n sql`SELECT \n n.nspname AS schema,\n t.typname AS name,\n e.enumlabel AS value,\n e.enumsortorder AS sort_order\n FROM pg_type t\n JOIN pg_enum e ON t.oid = e.enumtypid\n JOIN pg_catalog.pg_namespace n ON n.oid = t.typnamespace\n WHERE n.nspname = ${schemaName}\n ORDER BY schema, name, sort_order`\n );\n return getRows<EnumInfoRow>(result);\n }\n\n /**\n * Parse default value for a column\n */\n private parseDefault(defaultValue: string, dataType: string): string | undefined {\n if (!defaultValue) return undefined;\n\n // Remove the type cast if present (e.g., \"'value'::text\" -> \"'value'\")\n const match = defaultValue.match(/^'(.*)'::/);\n if (match) {\n return `'${match[1]}'`;\n }\n\n // Handle nextval for sequences\n if (defaultValue.includes(\"nextval(\")) {\n return undefined; // Serial types handle this automatically\n }\n\n // Handle boolean defaults\n if (dataType === \"boolean\") {\n if (defaultValue === \"true\") return \"true\";\n if (defaultValue === \"false\") return \"false\";\n }\n\n // Return as-is for other cases\n return defaultValue;\n }\n\n /**\n * Check if tables exist for a plugin by checking if any tables exist in its schema\n * @param pluginName - Name of the plugin\n * @returns True if tables exist, false otherwise\n */\n async hasExistingTables(pluginName: string): Promise<boolean> {\n const schemaName =\n pluginName === \"@elizaos/plugin-sql\" ? \"public\" : this.deriveSchemaName(pluginName);\n\n const result = await this.db.execute(\n sql`SELECT COUNT(*) AS count\n FROM information_schema.tables\n WHERE table_schema = ${schemaName}\n AND table_type = 'BASE TABLE'`\n );\n\n const firstRow = result.rows?.[0];\n const count = parseInt((firstRow && (firstRow.count as string)) || \"0\", 10);\n return count > 0;\n }\n\n /**\n * Derive schema name from plugin name\n */\n private deriveSchemaName(pluginName: string): string {\n // Same logic as in schema-transformer.ts\n return pluginName.replace(\"@\", \"\").replace(\"/\", \"_\").replace(/-/g, \"_\").toLowerCase();\n }\n}\n",
110
- "import { logger } from \"@elizaos/core\";\nimport { sql } from \"drizzle-orm\";\nimport type { DrizzleDB } from \"./types\";\n\nexport class ExtensionManager {\n constructor(private db: DrizzleDB) {}\n\n async installRequiredExtensions(extensions: string[]): Promise<void> {\n for (const extension of extensions) {\n try {\n // Validate extension name to prevent SQL injection\n // Extension names should only contain alphanumeric characters, underscores, and hyphens\n if (!/^[a-zA-Z0-9_-]+$/.test(extension)) {\n logger.warn(\n { src: \"plugin:sql\", extension },\n \"Invalid extension name - contains invalid characters\"\n );\n continue;\n }\n\n // Use sql.identifier for safe escaping of SQL identifiers\n await this.db.execute(sql`CREATE EXTENSION IF NOT EXISTS ${sql.identifier(extension)}`);\n logger.debug({ src: \"plugin:sql\", extension }, \"Extension installed\");\n } catch (error) {\n const errorMessage = error instanceof Error ? error.message : String(error);\n logger.warn(\n { src: \"plugin:sql\", extension, error: errorMessage },\n \"Could not install extension\"\n );\n // Some extensions might not be available or already installed\n // This shouldn't stop the migration process\n }\n }\n }\n}\n",
111
- "import { logger } from \"@elizaos/core\";\nimport { getTableConfig, type PgTable, pgSchema } from \"drizzle-orm/pg-core\";\n\n// Drizzle schema type - an object mapping names to tables or other schema objects\ntype DrizzleSchema = Record<string, unknown>;\n\n// pgSchema object interface\ninterface PgSchemaObject {\n _schema: string;\n table: (...args: unknown[]) => unknown;\n}\n\n/**\n * Transform a plugin's schema to use the appropriate namespace\n *\n * @elizaos/plugin-sql uses 'public' schema (no transformation)\n * Other plugins get their tables wrapped in a namespaced schema\n */\nexport function transformPluginSchema(pluginName: string, schema: DrizzleSchema): DrizzleSchema {\n // Core plugin uses public schema - no transformation needed\n if (pluginName === \"@elizaos/plugin-sql\") {\n return schema;\n }\n\n // Derive schema name from plugin name\n const schemaName = deriveSchemaName(pluginName);\n\n // If schema is already using pgSchema, return as-is\n if (isAlreadyNamespaced(schema, schemaName)) {\n logger.debug(\n { src: \"plugin:sql\", pluginName, schemaName },\n \"Plugin already uses expected schema\"\n );\n return schema;\n }\n\n logger.info({ src: \"plugin:sql\", pluginName, schemaName }, \"Transforming plugin to use schema\");\n\n // Transform the schema object\n const transformed: DrizzleSchema = {};\n\n for (const [key, value] of Object.entries(schema)) {\n if (isPgTable(value)) {\n // Get the table configuration\n const config = getTableConfig(value as PgTable);\n\n // If the table doesn't have a schema or is in public, warn about it\n if (!config.schema || config.schema === \"public\") {\n // Can't easily transform existing tables to different schema\n // (would require reconstructing all column definitions, constraints, etc.)\n logger.warn(\n {\n src: \"plugin:sql\",\n tableName: config.name,\n pluginName,\n expectedSchema: schemaName,\n },\n \"Table should use pgSchema for proper isolation - manual migration may be required\"\n );\n transformed[key] = value;\n } else {\n // Table already has a schema, keep it as-is\n transformed[key] = value;\n }\n } else if (typeof value === \"object\" && value !== null) {\n // Check if this is a schema object (created with pgSchema)\n const obj = value as PgSchemaObject;\n if (obj._schema && obj.table) {\n // This is already a pgSchema object, keep it\n transformed[key] = value;\n } else {\n // Regular object, keep as-is\n transformed[key] = value;\n }\n } else {\n // Not a table, keep as-is\n transformed[key] = value;\n }\n }\n\n return transformed;\n}\n\n/**\n * Derive a valid PostgreSQL schema name from a plugin name\n */\nexport function deriveSchemaName(pluginName: string): string {\n // Remove common prefixes and convert to lowercase with underscores\n let schemaName = pluginName\n .replace(/^@[^/]+\\//, \"\") // Remove npm scope like @elizaos/\n .replace(/^plugin-/, \"\") // Remove plugin- prefix\n .toLowerCase();\n\n // Replace non-alphanumeric characters with underscores (avoid polynomial regex)\n schemaName = normalizeSchemaName(schemaName);\n\n // Ensure schema name is valid (not empty, not a reserved word)\n const reserved = [\"public\", \"pg_catalog\", \"information_schema\", \"migrations\"];\n if (!schemaName || reserved.includes(schemaName)) {\n // Fallback to using the full plugin name with safe characters\n schemaName = `plugin_${normalizeSchemaName(pluginName.toLowerCase())}`;\n }\n\n // Ensure it starts with a letter (PostgreSQL requirement)\n if (!/^[a-z]/.test(schemaName)) {\n schemaName = `p_${schemaName}`;\n }\n\n // Truncate if too long (PostgreSQL identifier limit is 63 chars)\n if (schemaName.length > 63) {\n schemaName = schemaName.substring(0, 63);\n }\n\n return schemaName;\n}\n\n/**\n * Normalize a string to be a valid PostgreSQL identifier\n * Avoids polynomial regex by using string manipulation instead\n */\nfunction normalizeSchemaName(input: string): string {\n const chars: string[] = [];\n let prevWasUnderscore = false;\n\n for (let i = 0; i < input.length; i++) {\n const char = input[i];\n\n if (/[a-z0-9]/.test(char)) {\n chars.push(char);\n prevWasUnderscore = false;\n } else if (!prevWasUnderscore) {\n // Only add underscore if previous char wasn't already an underscore\n chars.push(\"_\");\n prevWasUnderscore = true;\n }\n // Skip consecutive non-alphanumeric characters\n }\n\n // Remove leading and trailing underscores\n const result = chars.join(\"\");\n\n // Trim underscores from start and end efficiently\n let start = 0;\n let end = result.length;\n\n while (start < end && result[start] === \"_\") {\n start++;\n }\n\n while (end > start && result[end - 1] === \"_\") {\n end--;\n }\n\n return result.slice(start, end);\n}\n\n/**\n * Check if a value is a PgTable\n */\nfunction isPgTable(value: unknown): value is PgTable {\n if (!value || typeof value !== \"object\") {\n return false;\n }\n\n // Check for table-like properties\n // This is a heuristic since we can't use instanceof across module boundaries\n try {\n const config = getTableConfig(value as PgTable);\n return config && typeof config.name === \"string\";\n } catch {\n return false;\n }\n}\n\n/**\n * Check if a schema is already properly namespaced\n */\nfunction isAlreadyNamespaced(schema: DrizzleSchema, expectedSchemaName: string): boolean {\n for (const value of Object.values(schema)) {\n if (isPgTable(value)) {\n try {\n const config = getTableConfig(value);\n if (config.schema === expectedSchemaName) {\n return true;\n }\n } catch {\n // Not a table, continue\n }\n }\n }\n return false;\n}\n\n/**\n * Create a namespaced schema helper for plugins\n * This is what plugins should ideally use to define their tables\n */\nexport function createPluginSchema(pluginName: string) {\n const schemaName = deriveSchemaName(pluginName);\n return pgSchema(schemaName);\n}\n",
112
- "import { sql } from \"drizzle-orm\";\nimport { getRow } from \"../../types\";\nimport type { DrizzleDB, Journal, JournalEntry } from \"../types\";\n\nexport class JournalStorage {\n constructor(private db: DrizzleDB) {}\n\n async loadJournal(pluginName: string): Promise<Journal | null> {\n const result = await this.db.execute(\n sql`SELECT version, dialect, entries \n FROM migrations._journal \n WHERE plugin_name = ${pluginName}`\n );\n\n if (result.rows.length === 0) {\n return null;\n }\n\n interface JournalRow {\n version: string;\n dialect: string;\n entries: JournalEntry[];\n }\n const row = getRow<JournalRow>(result);\n if (!row) {\n throw new Error(`Journal not found for plugin: ${pluginName}`);\n }\n return {\n version: row.version,\n dialect: row.dialect,\n entries: row.entries as JournalEntry[],\n };\n }\n\n async saveJournal(pluginName: string, journal: Journal): Promise<void> {\n await this.db.execute(\n sql`INSERT INTO migrations._journal (plugin_name, version, dialect, entries)\n VALUES (${pluginName}, ${journal.version}, ${journal.dialect}, ${JSON.stringify(journal.entries)}::jsonb)\n ON CONFLICT (plugin_name) \n DO UPDATE SET \n version = EXCLUDED.version,\n dialect = EXCLUDED.dialect,\n entries = EXCLUDED.entries`\n );\n }\n\n async addEntry(pluginName: string, entry: JournalEntry): Promise<void> {\n // First, get the current journal\n let journal = await this.loadJournal(pluginName);\n\n // If no journal exists, create a new one\n if (!journal) {\n journal = {\n version: \"7\", // Latest Drizzle version\n dialect: \"postgresql\",\n entries: [],\n };\n }\n\n // Add the new entry\n journal.entries.push(entry);\n\n // Save the updated journal\n await this.saveJournal(pluginName, journal);\n }\n\n async getNextIdx(pluginName: string): Promise<number> {\n const journal = await this.loadJournal(pluginName);\n\n if (!journal || journal.entries.length === 0) {\n return 0;\n }\n\n const lastEntry = journal.entries[journal.entries.length - 1];\n return lastEntry.idx + 1;\n }\n\n async updateJournal(\n pluginName: string,\n idx: number,\n tag: string,\n breakpoints: boolean = true\n ): Promise<void> {\n const entry: JournalEntry = {\n idx,\n version: \"7\",\n when: Date.now(),\n tag,\n breakpoints,\n };\n\n await this.addEntry(pluginName, entry);\n }\n}\n",
113
- "import { sql } from \"drizzle-orm\";\nimport { getRow } from \"../../types\";\nimport type { DrizzleDB } from \"../types\";\n\nexport class MigrationTracker {\n constructor(private db: DrizzleDB) {}\n\n async ensureSchema(): Promise<void> {\n await this.db.execute(sql`CREATE SCHEMA IF NOT EXISTS migrations`);\n }\n\n async ensureTables(): Promise<void> {\n // Ensure schema exists\n await this.ensureSchema();\n\n // Create migrations table (like Drizzle's __drizzle_migrations)\n await this.db.execute(sql`\n CREATE TABLE IF NOT EXISTS migrations._migrations (\n id SERIAL PRIMARY KEY,\n plugin_name TEXT NOT NULL,\n hash TEXT NOT NULL,\n created_at BIGINT NOT NULL\n )\n `);\n\n // Create journal table (replaces _journal.json)\n await this.db.execute(sql`\n CREATE TABLE IF NOT EXISTS migrations._journal (\n plugin_name TEXT PRIMARY KEY,\n version TEXT NOT NULL,\n dialect TEXT NOT NULL DEFAULT 'postgresql',\n entries JSONB NOT NULL DEFAULT '[]'\n )\n `);\n\n // Create snapshots table (replaces snapshot JSON files)\n await this.db.execute(sql`\n CREATE TABLE IF NOT EXISTS migrations._snapshots (\n id SERIAL PRIMARY KEY,\n plugin_name TEXT NOT NULL,\n idx INTEGER NOT NULL,\n snapshot JSONB NOT NULL,\n created_at TIMESTAMP DEFAULT NOW(),\n UNIQUE(plugin_name, idx)\n )\n `);\n }\n\n async getLastMigration(pluginName: string): Promise<{\n id: number;\n hash: string;\n created_at: string;\n } | null> {\n const result = await this.db.execute(\n sql`SELECT id, hash, created_at\n FROM migrations._migrations\n WHERE plugin_name = ${pluginName}\n ORDER BY created_at DESC\n LIMIT 1`\n );\n interface MigrationRow {\n id: number;\n hash: string;\n created_at: string;\n }\n return getRow<MigrationRow>(result) || null;\n }\n\n async recordMigration(pluginName: string, hash: string, createdAt: number): Promise<void> {\n await this.db.execute(\n sql`INSERT INTO migrations._migrations (plugin_name, hash, created_at) \n VALUES (${pluginName}, ${hash}, ${createdAt})`\n );\n }\n}\n",
114
- "import { sql } from \"drizzle-orm\";\nimport type { DrizzleDB, SchemaSnapshot } from \"../types\";\n\nexport class SnapshotStorage {\n constructor(private db: DrizzleDB) {}\n\n async saveSnapshot(pluginName: string, idx: number, snapshot: SchemaSnapshot): Promise<void> {\n await this.db.execute(\n sql`INSERT INTO migrations._snapshots (plugin_name, idx, snapshot)\n VALUES (${pluginName}, ${idx}, ${JSON.stringify(snapshot)}::jsonb)\n ON CONFLICT (plugin_name, idx) \n DO UPDATE SET \n snapshot = EXCLUDED.snapshot,\n created_at = NOW()`\n );\n }\n\n async loadSnapshot(pluginName: string, idx: number): Promise<SchemaSnapshot | null> {\n const result = await this.db.execute(\n sql`SELECT snapshot \n FROM migrations._snapshots \n WHERE plugin_name = ${pluginName} AND idx = ${idx}`\n );\n\n if (result.rows.length === 0) {\n return null;\n }\n\n return result.rows[0].snapshot as SchemaSnapshot;\n }\n\n async getLatestSnapshot(pluginName: string): Promise<SchemaSnapshot | null> {\n const result = await this.db.execute(\n sql`SELECT snapshot \n FROM migrations._snapshots \n WHERE plugin_name = ${pluginName}\n ORDER BY idx DESC\n LIMIT 1`\n );\n\n if (result.rows.length === 0) {\n return null;\n }\n\n return result.rows[0].snapshot as SchemaSnapshot;\n }\n\n async getAllSnapshots(pluginName: string): Promise<SchemaSnapshot[]> {\n const result = await this.db.execute(\n sql`SELECT snapshot \n FROM migrations._snapshots \n WHERE plugin_name = ${pluginName}\n ORDER BY idx ASC`\n );\n\n return result.rows.map((row) => row.snapshot as SchemaSnapshot);\n }\n}\n",
115
- "import { logger } from \"@elizaos/core\";\nimport { sql } from \"drizzle-orm\";\nimport { getRow } from \"../types\";\nimport { stringToBigInt } from \"./crypto-utils\";\nimport { DatabaseIntrospector } from \"./drizzle-adapters/database-introspector\";\nimport { calculateDiff, hasDiffChanges } from \"./drizzle-adapters/diff-calculator\";\nimport { generateSnapshot, hasChanges, hashSnapshot } from \"./drizzle-adapters/snapshot-generator\";\nimport {\n checkForDataLoss,\n type DataLossCheck,\n generateMigrationSQL,\n} from \"./drizzle-adapters/sql-generator\";\nimport { ExtensionManager } from \"./extension-manager\";\nimport { deriveSchemaName } from \"./schema-transformer\";\nimport { JournalStorage } from \"./storage/journal-storage\";\nimport { MigrationTracker } from \"./storage/migration-tracker\";\nimport { SnapshotStorage } from \"./storage/snapshot-storage\";\nimport type { DrizzleDB, RuntimeMigrationOptions, SchemaSnapshot, SchemaTable } from \"./types\";\n\nexport class RuntimeMigrator {\n private migrationTracker: MigrationTracker;\n private journalStorage: JournalStorage;\n private snapshotStorage: SnapshotStorage;\n private extensionManager: ExtensionManager;\n private introspector: DatabaseIntrospector;\n\n constructor(private db: DrizzleDB) {\n this.migrationTracker = new MigrationTracker(db);\n this.journalStorage = new JournalStorage(db);\n this.snapshotStorage = new SnapshotStorage(db);\n this.extensionManager = new ExtensionManager(db);\n this.introspector = new DatabaseIntrospector(db);\n }\n\n /**\n * Get expected schema name for a plugin\n * @elizaos/plugin-sql uses 'public' schema (core application)\n * All other plugins should use namespaced schemas\n */\n private getExpectedSchemaName(pluginName: string): string {\n // Core plugin uses public schema\n if (pluginName === \"@elizaos/plugin-sql\") {\n return \"public\";\n }\n\n // Use the schema transformer's logic for consistency\n return deriveSchemaName(pluginName);\n }\n\n /**\n * Ensure all schemas used in the snapshot exist\n */\n private async ensureSchemasExist(snapshot: SchemaSnapshot): Promise<void> {\n const schemasToCreate = new Set<string>();\n\n // Collect all schemas from tables\n for (const table of Object.values(snapshot.tables)) {\n const schemaName = table.schema || \"public\";\n if (schemaName !== \"public\") {\n schemasToCreate.add(schemaName);\n }\n }\n\n // Also add schemas from the snapshot's schemas object\n for (const schema of Object.keys(snapshot.schemas || {})) {\n if (schema !== \"public\") {\n schemasToCreate.add(schema);\n }\n }\n\n // Create all non-public schemas\n for (const schemaName of schemasToCreate) {\n logger.debug({ src: \"plugin:sql\", schemaName }, \"Ensuring schema exists\");\n await this.db.execute(sql.raw(`CREATE SCHEMA IF NOT EXISTS \"${schemaName}\"`));\n }\n }\n\n /**\n * Validate schema usage and provide warnings\n */\n private validateSchemaUsage(pluginName: string, snapshot: SchemaSnapshot): void {\n const expectedSchema = this.getExpectedSchemaName(pluginName);\n const isCorePLugin = pluginName === \"@elizaos/plugin-sql\";\n\n for (const table of Object.values(snapshot.tables)) {\n const actualSchema = table.schema || \"public\";\n\n // Warn if non-core plugin is using public schema\n if (!isCorePLugin && actualSchema === \"public\") {\n logger.warn(\n {\n src: \"plugin:sql\",\n pluginName,\n tableName: table.name,\n expectedSchema,\n },\n \"Plugin table is using public schema - consider using pgSchema for better isolation\"\n );\n }\n\n // Warn if core plugin is not using public schema\n if (isCorePLugin && actualSchema !== \"public\") {\n logger.warn(\n {\n src: \"plugin:sql\",\n pluginName: \"@elizaos/plugin-sql\",\n tableName: table.name,\n actualSchema,\n },\n \"Core plugin table should use public schema\"\n );\n }\n }\n }\n\n /**\n * Generate a stable advisory lock ID from plugin name\n * PostgreSQL advisory locks use bigint, so we need to hash the plugin name\n * and convert to a stable bigint value\n * Uses browser-compatible hashing\n */\n private getAdvisoryLockId(pluginName: string): bigint {\n return stringToBigInt(pluginName);\n }\n\n /**\n * Validate that a value is a valid PostgreSQL bigint\n * PostgreSQL bigint range: -9223372036854775808 to 9223372036854775807\n */\n private validateBigInt(value: bigint): boolean {\n const MIN_BIGINT = -9223372036854775808n;\n const MAX_BIGINT = 9223372036854775807n;\n return value >= MIN_BIGINT && value <= MAX_BIGINT;\n }\n\n /**\n * Detect if a connection string represents a real PostgreSQL database\n * (not PGLite, in-memory, or other non-PostgreSQL databases)\n */\n private isRealPostgresDatabase(connectionUrl: string): boolean {\n if (!connectionUrl?.trim()) return false;\n\n const url = connectionUrl.trim().toLowerCase();\n\n // Exclude non-PostgreSQL databases (check schemes first)\n const nonPgSchemes = [\"mysql://\", \"mysqli://\", \"mariadb://\", \"mongodb://\", \"mongodb+srv://\"];\n if (nonPgSchemes.some((s) => url.startsWith(s))) return false;\n\n // Always reject :memory: databases (even with postgres:// scheme, it's not valid)\n if (url.includes(\":memory:\")) return false;\n\n // PostgreSQL URL schemes - check BEFORE other exclude patterns\n // (a postgres:// URL may have \"sqlite\" in the database name, that's OK)\n const pgSchemes = [\n \"postgres://\",\n \"postgresql://\",\n \"postgis://\",\n \"pgbouncer://\",\n \"pgpool://\",\n \"cockroach://\",\n \"cockroachdb://\",\n \"redshift://\",\n \"timescaledb://\",\n \"yugabyte://\",\n ];\n if (pgSchemes.some((s) => url.startsWith(s))) return true;\n\n // Exclude PGLite, SQLite databases (only for non-postgres:// URLs)\n const excludePatterns = [\"pglite\", \"sqlite\"];\n const urlBase = url.split(\"?\")[0];\n if (excludePatterns.some((p) => url.includes(p))) return false;\n if (/\\.(db|sqlite|sqlite3)$/.test(urlBase)) return false;\n\n // Local PostgreSQL (localhost, 127.0.0.1, Docker service names)\n if (url.includes(\"localhost\") || url.includes(\"127.0.0.1\")) return true;\n\n // PostgreSQL connection params (libpq style)\n const connParams = [\n \"host=\",\n \"dbname=\",\n \"sslmode=\",\n \"connect_timeout=\",\n \"application_name=\",\n \"user=\",\n \"password=\",\n \"port=\",\n \"options=\",\n \"sslcert=\",\n \"sslkey=\",\n \"sslrootcert=\",\n \"fallback_application_name=\",\n \"keepalives=\",\n \"target_session_attrs=\",\n ];\n if (connParams.some((p) => url.includes(p))) return true;\n\n // user@host format with postgres keyword or port\n if (url.includes(\"@\") && (url.includes(\"postgres\") || /:\\d{4,5}/.test(url))) return true;\n\n // Common PostgreSQL ports\n if (/:(5432|5433|5434|6432|8432|9999|25060|26257)\\b/.test(url)) return true;\n\n // Cloud providers\n const cloudPatterns = [\n // AWS\n \"amazonaws.com\",\n \".rds.\",\n // Azure\n \"azure.com\",\n \"database.azure.com\",\n // Google Cloud\n \"googleusercontent\",\n \"cloudsql\",\n // Supabase\n \"supabase\",\n // Neon\n \"neon.tech\",\n \"neon.build\",\n // Railway\n \"railway.app\",\n \"railway.internal\",\n // Render\n \"render.com\",\n \"onrender.com\",\n // Heroku\n \"heroku\",\n // TimescaleDB\n \"timescale\",\n \".tsdb.cloud\",\n // CockroachDB\n \"cockroachlabs\",\n \"cockroachdb.cloud\",\n \".crdb.io\",\n // DigitalOcean\n \"digitalocean\",\n \"db.ondigitalocean\",\n \"do-user-\",\n // Aiven\n \"aiven\",\n // Crunchy Data\n \"crunchydata\",\n // ElephantSQL\n \"elephantsql\",\n // YugabyteDB\n \"yugabyte\",\n // Scaleway\n \"scaleway\",\n \".rdb.fr-par.scw.cloud\",\n // Vercel Postgres\n \"vercel-storage\",\n // PlanetScale\n \"psdb.cloud\",\n // Xata\n \"xata.sh\",\n // Fly.io\n \"fly.dev\",\n \"fly.io\",\n ];\n if (cloudPatterns.some((p) => url.includes(p))) return true;\n\n // IP:port patterns (IPv4 and IPv6)\n if (/\\d{1,3}\\.\\d{1,3}\\.\\d{1,3}\\.\\d{1,3}:\\d{1,5}/.test(url)) return true;\n if (/\\[[0-9a-f:]+\\](:\\d{1,5})?/i.test(connectionUrl)) return true;\n\n // host:port/database format (Docker Compose, etc.)\n if (/^[a-z0-9_.-]+:\\d{1,5}\\/[a-z0-9_-]+/i.test(connectionUrl)) return true;\n\n logger.debug(\n { src: \"plugin:sql\", urlPreview: url.substring(0, 50) },\n \"Connection string did not match any PostgreSQL patterns\"\n );\n return false;\n }\n\n /**\n * Initialize migration system - create necessary tables\n * @throws Error if table creation fails\n */\n async initialize(): Promise<void> {\n logger.info({ src: \"plugin:sql\" }, \"Initializing migration system\");\n await this.migrationTracker.ensureTables();\n logger.info({ src: \"plugin:sql\" }, \"Migration system initialized\");\n }\n\n /**\n * Run migrations for a plugin/schema\n * @param pluginName - Plugin identifier\n * @param schema - Drizzle schema object\n * @param options - Migration options (verbose, force, dryRun, allowDataLoss)\n * @throws Error if destructive migrations blocked or migration fails\n */\n async migrate(\n pluginName: string,\n schema: Record<string, unknown>,\n options: RuntimeMigrationOptions = {}\n ): Promise<void> {\n const lockId = this.getAdvisoryLockId(pluginName);\n\n // Validate lockId is within PostgreSQL bigint range\n if (!this.validateBigInt(lockId)) {\n throw new Error(`Invalid advisory lock ID generated for plugin ${pluginName}`);\n }\n\n let lockAcquired = false;\n\n try {\n logger.info({ src: \"plugin:sql\", pluginName }, \"Starting migration for plugin\");\n\n // Ensure migration tables exist\n await this.initialize();\n\n // Only use advisory locks for real PostgreSQL databases\n // Skip for PGLite or development databases\n const postgresUrl = process.env.POSTGRES_URL || process.env.DATABASE_URL || \"\";\n const isRealPostgres = this.isRealPostgresDatabase(postgresUrl);\n\n if (isRealPostgres) {\n try {\n logger.debug({ src: \"plugin:sql\", pluginName }, \"Using PostgreSQL advisory locks\");\n\n // Convert bigint to string for SQL query\n // The sql tagged template will properly parameterize this value\n const lockIdStr = lockId.toString();\n\n const lockResult = await this.db.execute(\n sql`SELECT pg_try_advisory_lock(CAST(${lockIdStr} AS bigint)) as acquired`\n );\n\n interface LockResultRow {\n acquired: boolean;\n }\n lockAcquired = getRow<LockResultRow>(lockResult)?.acquired === true;\n\n if (!lockAcquired) {\n logger.info(\n { src: \"plugin:sql\", pluginName },\n \"Migration already in progress, waiting for lock\"\n );\n\n // Wait for the lock (blocking call)\n await this.db.execute(sql`SELECT pg_advisory_lock(CAST(${lockIdStr} AS bigint))`);\n lockAcquired = true;\n\n logger.info({ src: \"plugin:sql\", pluginName }, \"Lock acquired\");\n } else {\n logger.debug(\n { src: \"plugin:sql\", pluginName, lockId: lockIdStr },\n \"Advisory lock acquired\"\n );\n }\n } catch (lockError) {\n // If advisory locks fail, log but continue\n // This might happen if the PostgreSQL version doesn't support advisory locks\n logger.warn(\n {\n src: \"plugin:sql\",\n pluginName,\n error: lockError instanceof Error ? lockError.message : String(lockError),\n },\n \"Failed to acquire advisory lock, continuing without lock\"\n );\n lockAcquired = false;\n }\n } else {\n // For PGLite or other development databases, skip advisory locks\n logger.debug(\n { src: \"plugin:sql\" },\n \"Development database detected, skipping advisory locks\"\n );\n }\n\n // Install required extensions\n // pgcrypto is only needed for real PostgreSQL (PGLite uses native gen_random_uuid)\n const extensions = isRealPostgres\n ? [\"vector\", \"fuzzystrmatch\", \"pgcrypto\"]\n : [\"vector\", \"fuzzystrmatch\"];\n await this.extensionManager.installRequiredExtensions(extensions);\n\n // Generate current snapshot from schema\n const currentSnapshot = await generateSnapshot(schema);\n\n // Ensure all schemas referenced in the snapshot exist\n await this.ensureSchemasExist(currentSnapshot);\n\n // Validate schema usage and warn about potential issues\n this.validateSchemaUsage(pluginName, currentSnapshot);\n\n const currentHash = hashSnapshot(currentSnapshot);\n\n // Check if we've already run this exact migration\n // This check happens AFTER acquiring the lock to handle concurrent scenarios\n // This is critical: if we had to wait for the lock (lockAcquired was initially false),\n // another process may have completed the migration while we were waiting\n // We MUST check regardless of whether lastMigration existed before\n const lastMigration = await this.migrationTracker.getLastMigration(pluginName);\n if (lastMigration && lastMigration.hash === currentHash) {\n logger.info(\n { src: \"plugin:sql\", pluginName, hash: currentHash },\n \"No changes detected, skipping migration\"\n );\n return;\n }\n\n // Load previous snapshot\n let previousSnapshot = await this.snapshotStorage.getLatestSnapshot(pluginName);\n\n // If no snapshot exists but tables exist in database, introspect them\n if (!previousSnapshot && Object.keys(currentSnapshot.tables).length > 0) {\n const hasExistingTables = await this.introspector.hasExistingTables(pluginName);\n\n if (hasExistingTables) {\n logger.info(\n { src: \"plugin:sql\", pluginName },\n \"No snapshot found but tables exist in database, introspecting\"\n );\n\n // Determine the schema name for introspection\n const schemaName = this.getExpectedSchemaName(pluginName);\n\n // Introspect the current database state\n const introspectedSnapshot = await this.introspector.introspectSchema(schemaName);\n\n // IMPORTANT: Filter the introspected snapshot to only include tables that are\n // defined in the current schema. This prevents tables from other plugins\n // (e.g., gamification tables in 'public' schema) from being marked as \"orphans\"\n // and scheduled for deletion.\n const expectedTableNames = new Set<string>();\n for (const tableKey of Object.keys(currentSnapshot.tables)) {\n const tableData = currentSnapshot.tables[tableKey];\n const tableName = tableData.name || tableKey.split(\".\").pop() || \"\";\n expectedTableNames.add(tableName);\n }\n\n // Filter introspected tables to only those in the current schema\n const filteredTables: Record<string, SchemaTable> = {};\n for (const tableKey of Object.keys(introspectedSnapshot.tables)) {\n const tableData = introspectedSnapshot.tables[tableKey];\n const tableName = tableData.name || tableKey.split(\".\").pop() || \"\";\n if (expectedTableNames.has(tableName)) {\n filteredTables[tableKey] = tableData;\n } else {\n logger.debug(\n { src: \"plugin:sql\", pluginName, tableName },\n \"Ignoring table from introspection (not in current schema)\"\n );\n }\n }\n\n // Use filtered snapshot\n const filteredSnapshot = {\n ...introspectedSnapshot,\n tables: filteredTables,\n };\n\n // Only use the introspected snapshot if it has tables\n if (Object.keys(filteredSnapshot.tables).length > 0) {\n // Save this as the initial snapshot (idx: 0)\n await this.snapshotStorage.saveSnapshot(pluginName, 0, filteredSnapshot);\n\n // Update journal to record this initial state\n await this.journalStorage.updateJournal(\n pluginName,\n 0,\n `introspected_${Date.now()}`,\n true\n );\n\n // Record this as a migration\n const filteredHash = hashSnapshot(filteredSnapshot);\n await this.migrationTracker.recordMigration(pluginName, filteredHash, Date.now());\n\n logger.info(\n { src: \"plugin:sql\", pluginName },\n \"Created initial snapshot from existing database\"\n );\n\n // Set this as the previous snapshot for comparison\n previousSnapshot = filteredSnapshot;\n }\n }\n }\n\n // Check if there are actual changes\n if (!hasChanges(previousSnapshot, currentSnapshot)) {\n logger.info({ src: \"plugin:sql\", pluginName }, \"No schema changes\");\n\n // For empty schemas, we still want to record the migration\n // to ensure idempotency and consistency\n if (!previousSnapshot && Object.keys(currentSnapshot.tables).length === 0) {\n logger.info({ src: \"plugin:sql\", pluginName }, \"Recording empty schema\");\n await this.migrationTracker.recordMigration(pluginName, currentHash, Date.now());\n const idx = await this.journalStorage.getNextIdx(pluginName);\n const tag = this.generateMigrationTag(idx, pluginName);\n await this.journalStorage.updateJournal(pluginName, idx, tag, true);\n await this.snapshotStorage.saveSnapshot(pluginName, idx, currentSnapshot);\n }\n\n return;\n }\n\n // Calculate diff\n const diff = await calculateDiff(previousSnapshot, currentSnapshot);\n\n // Check if diff has changes\n if (!hasDiffChanges(diff)) {\n logger.info({ src: \"plugin:sql\", pluginName }, \"No actionable changes\");\n return;\n }\n\n // Check for potential data loss\n const dataLossCheck = checkForDataLoss(diff);\n\n if (dataLossCheck.hasDataLoss) {\n const isProduction = process.env.NODE_ENV === \"production\";\n\n // Determine if destructive migrations are allowed\n // Priority: explicit options > environment variable\n const allowDestructive =\n options.force ||\n options.allowDataLoss ||\n process.env.ELIZA_ALLOW_DESTRUCTIVE_MIGRATIONS === \"true\";\n\n if (!allowDestructive) {\n // Block the migration and provide clear instructions\n logger.error(\n {\n src: \"plugin:sql\",\n pluginName,\n environment: isProduction ? \"PRODUCTION\" : \"DEVELOPMENT\",\n warnings: dataLossCheck.warnings,\n },\n \"Destructive migration blocked - set ELIZA_ALLOW_DESTRUCTIVE_MIGRATIONS=true or use force option\"\n );\n\n const errorMessage = isProduction\n ? `Destructive migration blocked in production for ${pluginName}. Set ELIZA_ALLOW_DESTRUCTIVE_MIGRATIONS=true or use drizzle-kit.`\n : `Destructive migration blocked for ${pluginName}. Set ELIZA_ALLOW_DESTRUCTIVE_MIGRATIONS=true to proceed.`;\n\n throw new Error(errorMessage);\n }\n\n // Log that we're proceeding with destructive operations\n if (dataLossCheck.requiresConfirmation) {\n logger.warn(\n { src: \"plugin:sql\", pluginName, warnings: dataLossCheck.warnings },\n \"Proceeding with destructive migration\"\n );\n }\n }\n\n // Generate SQL statements\n const sqlStatements = await generateMigrationSQL(previousSnapshot, currentSnapshot, diff);\n\n if (sqlStatements.length === 0) {\n logger.info({ src: \"plugin:sql\", pluginName }, \"No SQL statements to execute\");\n return;\n }\n\n // Log what we're about to do\n logger.info(\n { src: \"plugin:sql\", pluginName, statementCount: sqlStatements.length },\n \"Executing SQL statements\"\n );\n if (options.verbose) {\n sqlStatements.forEach((stmt, i) => {\n logger.debug(\n { src: \"plugin:sql\", statementIndex: i + 1, statement: stmt },\n \"SQL statement\"\n );\n });\n }\n\n // Dry run mode - just log what would happen\n if (options.dryRun) {\n logger.info(\n { src: \"plugin:sql\", pluginName, statements: sqlStatements },\n \"DRY RUN mode - not executing statements\"\n );\n return;\n }\n\n // Execute migration in transaction\n await this.executeMigration(pluginName, currentSnapshot, currentHash, sqlStatements);\n\n logger.info({ src: \"plugin:sql\", pluginName }, \"Migration completed successfully\");\n\n // Return a success result\n return;\n } catch (error) {\n logger.error(\n {\n src: \"plugin:sql\",\n pluginName,\n error: error instanceof Error ? error.message : String(error),\n },\n \"Migration failed\"\n );\n throw error;\n } finally {\n // Always release the advisory lock if we acquired it (only for real PostgreSQL)\n const postgresUrl = process.env.POSTGRES_URL || process.env.DATABASE_URL || \"\";\n const isRealPostgres = this.isRealPostgresDatabase(postgresUrl);\n\n if (lockAcquired && isRealPostgres) {\n try {\n // Convert bigint to string for SQL query (same as when acquiring)\n const lockIdStr = lockId.toString();\n await this.db.execute(sql`SELECT pg_advisory_unlock(CAST(${lockIdStr} AS bigint))`);\n logger.debug({ src: \"plugin:sql\", pluginName }, \"Advisory lock released\");\n } catch (unlockError) {\n logger.warn(\n {\n src: \"plugin:sql\",\n pluginName,\n error: unlockError instanceof Error ? unlockError.message : String(unlockError),\n },\n \"Failed to release advisory lock\"\n );\n }\n }\n }\n }\n\n /**\n * Execute migration in a transaction\n */\n private async executeMigration(\n pluginName: string,\n snapshot: SchemaSnapshot,\n hash: string,\n sqlStatements: string[]\n ): Promise<void> {\n let transactionStarted = false;\n\n try {\n // Start manual transaction\n await this.db.execute(sql`BEGIN`);\n transactionStarted = true;\n\n // Execute all SQL statements\n for (const stmt of sqlStatements) {\n logger.debug({ src: \"plugin:sql\", statement: stmt }, \"Executing SQL statement\");\n await this.db.execute(sql.raw(stmt));\n }\n\n // Get next index for journal\n const idx = await this.journalStorage.getNextIdx(pluginName);\n\n // Record migration\n await this.migrationTracker.recordMigration(pluginName, hash, Date.now());\n\n // Update journal\n const tag = this.generateMigrationTag(idx, pluginName);\n await this.journalStorage.updateJournal(\n pluginName,\n idx,\n tag,\n true // breakpoints\n );\n\n // Store snapshot\n await this.snapshotStorage.saveSnapshot(pluginName, idx, snapshot);\n\n // Commit the transaction\n await this.db.execute(sql`COMMIT`);\n\n logger.info({ src: \"plugin:sql\", pluginName, tag }, \"Recorded migration\");\n } catch (error) {\n // Rollback on error if transaction was started\n if (transactionStarted) {\n try {\n await this.db.execute(sql`ROLLBACK`);\n logger.error(\n {\n src: \"plugin:sql\",\n error: error instanceof Error ? error.message : String(error),\n },\n \"Migration failed, rolled back\"\n );\n } catch (rollbackError) {\n logger.error(\n {\n src: \"plugin:sql\",\n error: rollbackError instanceof Error ? rollbackError.message : String(rollbackError),\n },\n \"Failed to rollback transaction\"\n );\n }\n }\n throw error;\n }\n }\n\n /**\n * Generate migration tag (like 0000_jazzy_shard)\n */\n private generateMigrationTag(idx: number, pluginName: string): string {\n // Generate a simple tag - in production, use Drizzle's word generation\n const prefix = idx.toString().padStart(4, \"0\");\n const timestamp = Date.now().toString(36);\n return `${prefix}_${pluginName}_${timestamp}`;\n }\n\n /**\n * Get migration status for a plugin\n * @param pluginName - Plugin identifier\n * @returns Migration history and current state\n */\n async getStatus(pluginName: string): Promise<{\n hasRun: boolean;\n lastMigration: { id: number; hash: string; created_at: string } | null;\n journal: { version: string; dialect: string; entries: unknown[] } | null;\n snapshots: number;\n }> {\n const lastMigration = await this.migrationTracker.getLastMigration(pluginName);\n const journal = await this.journalStorage.loadJournal(pluginName);\n const snapshots = await this.snapshotStorage.getAllSnapshots(pluginName);\n\n return {\n hasRun: !!lastMigration,\n lastMigration,\n journal,\n snapshots: snapshots.length,\n };\n }\n\n /**\n * Reset migrations for a plugin (dangerous - for development only)\n * @param pluginName - Plugin identifier\n * @warning Deletes all migration history - use only in development\n */\n async reset(pluginName: string): Promise<void> {\n logger.warn({ src: \"plugin:sql\", pluginName }, \"Resetting migrations\");\n\n await this.db.execute(\n sql`DELETE FROM migrations._migrations WHERE plugin_name = ${pluginName}`\n );\n await this.db.execute(sql`DELETE FROM migrations._journal WHERE plugin_name = ${pluginName}`);\n await this.db.execute(sql`DELETE FROM migrations._snapshots WHERE plugin_name = ${pluginName}`);\n\n logger.warn({ src: \"plugin:sql\", pluginName }, \"Reset complete\");\n }\n\n /**\n * Check if a migration would cause data loss without executing it\n * @param pluginName - Plugin identifier\n * @param schema - Drizzle schema to check\n * @returns Data loss analysis or null if no changes\n */\n async checkMigration(\n pluginName: string,\n schema: Record<string, unknown>\n ): Promise<DataLossCheck | null> {\n try {\n logger.info({ src: \"plugin:sql\", pluginName }, \"Checking migration\");\n\n // Generate current snapshot from schema\n const currentSnapshot = await generateSnapshot(schema);\n\n // Load previous snapshot\n const previousSnapshot = await this.snapshotStorage.getLatestSnapshot(pluginName);\n\n // Check if there are changes\n if (!hasChanges(previousSnapshot, currentSnapshot)) {\n logger.info({ src: \"plugin:sql\", pluginName }, \"No changes detected\");\n return null;\n }\n\n // Calculate diff\n const diff = await calculateDiff(previousSnapshot, currentSnapshot);\n\n // Check for data loss\n const dataLossCheck = checkForDataLoss(diff);\n\n if (dataLossCheck.hasDataLoss) {\n logger.warn({ src: \"plugin:sql\", pluginName }, \"Migration would cause data loss\");\n } else {\n logger.info({ src: \"plugin:sql\", pluginName }, \"Migration is safe (no data loss)\");\n }\n\n return dataLossCheck;\n } catch (error) {\n logger.error(\n {\n src: \"plugin:sql\",\n pluginName,\n error: error instanceof Error ? error.message : String(error),\n },\n \"Failed to check migration\"\n );\n throw error;\n }\n }\n}\n",
116
- "export {\n calculateDiff,\n hasDiffChanges,\n type SchemaDiff,\n} from \"./drizzle-adapters/diff-calculator\";\n// Drizzle adapter exports (if needed for extensions)\nexport {\n createEmptySnapshot,\n generateSnapshot,\n hasChanges,\n hashSnapshot,\n} from \"./drizzle-adapters/snapshot-generator\";\nexport {\n generateMigrationSQL,\n generateRenameColumnSQL,\n generateRenameTableSQL,\n} from \"./drizzle-adapters/sql-generator\";\nexport { RuntimeMigrator } from \"./runtime-migrator\";\nexport { JournalStorage } from \"./storage/journal-storage\";\n// Storage exports (if needed for advanced usage)\nexport { MigrationTracker } from \"./storage/migration-tracker\";\nexport { SnapshotStorage } from \"./storage/snapshot-storage\";\nexport * from \"./types\";\n",
117
- "import { type IDatabaseAdapter, logger, type Plugin } from \"@elizaos/core\";\nimport { migrateToEntityRLS } from \"./migrations\";\nimport { applyEntityRLSToAllTables, applyRLSToNewTables, installRLSFunctions } from \"./rls\";\nimport { RuntimeMigrator } from \"./runtime-migrator\";\nimport type { DrizzleDatabase } from \"./types\";\n\nexport class DatabaseMigrationService {\n private db: DrizzleDatabase | null = null;\n private registeredSchemas = new Map<string, Record<string, unknown>>();\n private migrator: RuntimeMigrator | null = null;\n\n async initializeWithDatabase(db: DrizzleDatabase): Promise<void> {\n this.db = db;\n\n interface AdapterWrapper extends IDatabaseAdapter {\n db: DrizzleDatabase;\n }\n const adapterWrapper: AdapterWrapper = { db } as AdapterWrapper;\n await migrateToEntityRLS(adapterWrapper);\n\n this.migrator = new RuntimeMigrator(db);\n await this.migrator.initialize();\n logger.info({ src: \"plugin:sql\" }, \"DatabaseMigrationService initialized\");\n }\n\n discoverAndRegisterPluginSchemas(plugins: Plugin[]): void {\n for (const plugin of plugins) {\n type PluginWithSchema = Plugin & {\n schema?: Record<string, unknown>;\n };\n const pluginWithSchema = plugin as PluginWithSchema;\n if (pluginWithSchema.schema) {\n this.registeredSchemas.set(plugin.name, pluginWithSchema.schema);\n }\n }\n logger.info(\n {\n src: \"plugin:sql\",\n schemasDiscovered: this.registeredSchemas.size,\n totalPlugins: plugins.length,\n },\n \"Plugin schemas discovered\"\n );\n }\n\n registerSchema(pluginName: string, schema: Record<string, unknown>): void {\n this.registeredSchemas.set(pluginName, schema);\n logger.debug({ src: \"plugin:sql\", pluginName }, \"Schema registered\");\n }\n\n async runAllPluginMigrations(options?: {\n verbose?: boolean;\n force?: boolean;\n dryRun?: boolean;\n }): Promise<void> {\n if (!this.db || !this.migrator) {\n throw new Error(\"Database or migrator not initialized in DatabaseMigrationService\");\n }\n\n const isProduction = process.env.NODE_ENV === \"production\";\n\n const migrationOptions = {\n verbose: options?.verbose ?? !isProduction,\n force: options?.force ?? false,\n dryRun: options?.dryRun ?? false,\n };\n\n logger.info(\n {\n src: \"plugin:sql\",\n environment: isProduction ? \"PRODUCTION\" : \"DEVELOPMENT\",\n pluginCount: this.registeredSchemas.size,\n dryRun: migrationOptions.dryRun,\n },\n \"Starting migrations\"\n );\n\n let successCount = 0;\n let failureCount = 0;\n const errors: Array<{ pluginName: string; error: Error }> = [];\n\n for (const [pluginName, schema] of this.registeredSchemas) {\n try {\n await this.migrator.migrate(pluginName, schema, migrationOptions);\n successCount++;\n logger.info({ src: \"plugin:sql\", pluginName }, \"Migration completed\");\n } catch (error) {\n failureCount++;\n const errorMessage = (error as Error).message;\n\n errors.push({ pluginName, error: error as Error });\n\n if (errorMessage.includes(\"Destructive migration blocked\")) {\n logger.error(\n { src: \"plugin:sql\", pluginName },\n \"Migration blocked - destructive changes detected. Set ELIZA_ALLOW_DESTRUCTIVE_MIGRATIONS=true or use force option\"\n );\n } else {\n logger.error({ src: \"plugin:sql\", pluginName, error: errorMessage }, \"Migration failed\");\n }\n }\n }\n\n if (failureCount === 0) {\n logger.info({ src: \"plugin:sql\", successCount }, \"All migrations completed successfully\");\n\n const dataIsolationEnabled = process.env.ENABLE_DATA_ISOLATION === \"true\";\n\n if (dataIsolationEnabled) {\n try {\n logger.info({ src: \"plugin:sql\" }, \"Re-applying Row Level Security...\");\n interface AdapterWrapper extends IDatabaseAdapter {\n db: DrizzleDatabase;\n }\n const adapterWrapper: AdapterWrapper = {\n db: this.db,\n } as AdapterWrapper;\n await installRLSFunctions(adapterWrapper);\n await applyRLSToNewTables(adapterWrapper);\n await applyEntityRLSToAllTables(adapterWrapper);\n logger.info({ src: \"plugin:sql\" }, \"RLS re-applied successfully\");\n } catch (rlsError) {\n const errorMsg = rlsError instanceof Error ? rlsError.message : String(rlsError);\n logger.warn(\n { src: \"plugin:sql\", error: errorMsg },\n \"Failed to re-apply RLS (this is OK if server_id columns are not yet in schemas)\"\n );\n }\n } else {\n logger.info(\n { src: \"plugin:sql\" },\n \"Skipping RLS re-application (ENABLE_DATA_ISOLATION is not true)\"\n );\n }\n } else {\n logger.error({ src: \"plugin:sql\", failureCount, successCount }, \"Some migrations failed\");\n\n const errorSummary = errors.map((e) => `${e.pluginName}: ${e.error.message}`).join(\"\\n \");\n throw new Error(`${failureCount} migration(s) failed:\\n ${errorSummary}`);\n }\n }\n\n getMigrator(): RuntimeMigrator | null {\n return this.migrator;\n }\n}\n",
118
- "import { mkdirSync } from \"node:fs\";\nimport type { IDatabaseAdapter, UUID } from \"@elizaos/core\";\nimport { type IAgentRuntime, logger, type Plugin, stringToUuid } from \"@elizaos/core\";\nimport { PgDatabaseAdapter } from \"./pg/adapter\";\nimport { PostgresConnectionManager } from \"./pg/manager\";\nimport { PgliteDatabaseAdapter } from \"./pglite/adapter\";\nimport { PGliteClientManager } from \"./pglite/manager\";\nimport * as schema from \"./schema\";\nimport { resolvePgliteDir } from \"./utils.node\";\n\nconst GLOBAL_SINGLETONS = Symbol.for(\"@elizaos/plugin-sql/global-singletons\");\n\ninterface GlobalSingletons {\n pgLiteClientManager?: PGliteClientManager;\n postgresConnectionManagers?: Map<string, PostgresConnectionManager>;\n}\n\nconst globalSymbols = globalThis as typeof globalThis & Record<symbol, GlobalSingletons>;\nif (!globalSymbols[GLOBAL_SINGLETONS]) {\n globalSymbols[GLOBAL_SINGLETONS] = {};\n}\nconst globalSingletons = globalSymbols[GLOBAL_SINGLETONS];\n\nexport function createDatabaseAdapter(\n config: {\n dataDir?: string;\n postgresUrl?: string;\n },\n agentId: UUID\n): IDatabaseAdapter {\n if (config.postgresUrl) {\n const dataIsolationEnabled = process.env.ENABLE_DATA_ISOLATION === \"true\";\n let rlsServerId: string | undefined;\n let managerKey = \"default\";\n\n if (dataIsolationEnabled) {\n const rlsServerIdString = process.env.ELIZA_SERVER_ID;\n if (!rlsServerIdString) {\n throw new Error(\n \"[Data Isolation] ENABLE_DATA_ISOLATION=true requires ELIZA_SERVER_ID environment variable\"\n );\n }\n rlsServerId = stringToUuid(rlsServerIdString);\n managerKey = rlsServerId;\n logger.debug(\n {\n src: \"plugin:sql\",\n rlsServerId: rlsServerId.slice(0, 8),\n serverIdString: rlsServerIdString,\n },\n \"Using connection pool for RLS server\"\n );\n }\n\n // Initialize connection managers map if needed\n if (!globalSingletons.postgresConnectionManagers) {\n globalSingletons.postgresConnectionManagers = new Map();\n }\n\n // Get or create connection manager for this server_id\n let manager = globalSingletons.postgresConnectionManagers.get(managerKey);\n if (!manager) {\n logger.debug(\n { src: \"plugin:sql\", managerKey: managerKey.slice(0, 8) },\n \"Creating new connection pool\"\n );\n manager = new PostgresConnectionManager(config.postgresUrl, rlsServerId);\n globalSingletons.postgresConnectionManagers.set(managerKey, manager);\n }\n\n return new PgDatabaseAdapter(agentId, manager);\n }\n\n const dataDir = resolvePgliteDir(config.dataDir);\n\n if (dataDir && !dataDir.includes(\"://\")) {\n mkdirSync(dataDir, { recursive: true });\n }\n\n if (!globalSingletons.pgLiteClientManager) {\n globalSingletons.pgLiteClientManager = new PGliteClientManager({ dataDir });\n }\n return new PgliteDatabaseAdapter(agentId, globalSingletons.pgLiteClientManager);\n}\n\nexport const plugin: Plugin = {\n name: \"@elizaos/plugin-sql\",\n description: \"A plugin for SQL database access with dynamic schema migrations\",\n priority: 0,\n schema: schema,\n init: async (_config, runtime: IAgentRuntime) => {\n runtime.logger.info(\n { src: \"plugin:sql\", agentId: runtime.agentId },\n \"plugin-sql (node) init starting\"\n );\n\n const adapterRegistered = await runtime\n .isReady()\n .then(() => true)\n .catch((error: unknown) => {\n const message = error instanceof Error ? error.message : String(error);\n if (message.includes(\"Database adapter not registered\")) {\n runtime.logger.info(\n { src: \"plugin:sql\", agentId: runtime.agentId },\n \"No pre-registered database adapter detected; registering adapter\"\n );\n } else {\n runtime.logger.warn(\n { src: \"plugin:sql\", agentId: runtime.agentId, error: message },\n \"Database adapter readiness check error; proceeding to register adapter\"\n );\n }\n return false;\n });\n if (adapterRegistered) {\n runtime.logger.info(\n { src: \"plugin:sql\", agentId: runtime.agentId },\n \"Database adapter already registered, skipping creation\"\n );\n return;\n }\n\n const postgresUrl = runtime.getSetting(\"POSTGRES_URL\");\n const dataDir = runtime.getSetting(\"PGLITE_DATA_DIR\");\n\n const dbAdapter = createDatabaseAdapter(\n {\n dataDir: typeof dataDir === \"string\" ? dataDir : undefined,\n postgresUrl: typeof postgresUrl === \"string\" ? postgresUrl : undefined,\n },\n runtime.agentId\n );\n\n runtime.registerDatabaseAdapter(dbAdapter);\n runtime.logger.info(\n { src: \"plugin:sql\", agentId: runtime.agentId },\n \"Database adapter created and registered\"\n );\n },\n};\n\nexport default plugin;\n\nexport { DatabaseMigrationService } from \"./migration-service\";\nexport {\n applyRLSToNewTables,\n assignAgentToServer,\n getOrCreateRlsServer,\n installRLSFunctions,\n setServerContext,\n uninstallRLS,\n} from \"./rls\";\n",
119
- "import {\n type Agent,\n type Component,\n type Entity,\n logger,\n type Memory,\n type UUID,\n} from \"@elizaos/core\";\nimport type { NodePgDatabase } from \"drizzle-orm/node-postgres\";\nimport { BaseDrizzleAdapter } from \"../base\";\nimport { DIMENSION_MAP, type EmbeddingDimensionColumn } from \"../schema/embedding\";\nimport type { PostgresConnectionManager } from \"./manager\";\n\nexport class PgDatabaseAdapter extends BaseDrizzleAdapter {\n protected embeddingDimension: EmbeddingDimensionColumn = DIMENSION_MAP[384];\n private manager: PostgresConnectionManager;\n\n constructor(\n agentId: UUID,\n manager: PostgresConnectionManager,\n _schema?: Record<string, unknown>\n ) {\n super(agentId);\n this.manager = manager;\n this.db = manager.getDatabase();\n }\n\n getManager(): PostgresConnectionManager {\n return this.manager;\n }\n\n public async withEntityContext<T>(\n entityId: UUID | null,\n callback: (tx: NodePgDatabase) => Promise<T>\n ): Promise<T> {\n return await this.manager.withEntityContext(entityId, callback);\n }\n\n async getEntityByIds(entityIds: UUID[]): Promise<Entity[] | null> {\n return this.getEntitiesByIds(entityIds);\n }\n\n async getMemoriesByServerId(_params: { serverId: UUID; count?: number }): Promise<Memory[]> {\n logger.warn({ src: \"plugin:sql\" }, \"getMemoriesByServerId called but not implemented\");\n return [];\n }\n\n async ensureAgentExists(agent: Partial<Agent>): Promise<Agent> {\n const existingAgent = await this.getAgent(this.agentId);\n if (existingAgent) {\n return existingAgent;\n }\n\n const newAgent: Agent = {\n id: this.agentId,\n name: agent.name || \"Unknown Agent\",\n username: agent.username,\n bio: (Array.isArray(agent.bio)\n ? agent.bio\n : agent.bio\n ? [agent.bio]\n : [\"An AI agent\"]) as string[],\n createdAt: agent.createdAt || Date.now(),\n updatedAt: agent.updatedAt || Date.now(),\n };\n\n await this.createAgent(newAgent);\n const createdAgent = await this.getAgent(this.agentId);\n if (!createdAgent) {\n throw new Error(\"Failed to create agent\");\n }\n return createdAgent;\n }\n\n protected async withDatabase<T>(operation: () => Promise<T>): Promise<T> {\n return await this.withRetry(async () => {\n return await operation();\n });\n }\n\n async init(): Promise<void> {\n logger.debug({ src: \"plugin:sql\" }, \"PgDatabaseAdapter initialized\");\n }\n\n async isReady(): Promise<boolean> {\n return this.manager.testConnection();\n }\n\n async close(): Promise<void> {\n await this.manager.close();\n }\n\n async getConnection(): Promise<NodePgDatabase> {\n return this.db as NodePgDatabase;\n }\n\n getRawConnection() {\n return this.manager.getConnection();\n }\n\n async createAgent(agent: Agent): Promise<boolean> {\n return super.createAgent(agent);\n }\n\n getAgent(agentId: UUID): Promise<Agent | null> {\n return super.getAgent(agentId);\n }\n\n updateAgent(agentId: UUID, agent: Partial<Agent>): Promise<boolean> {\n return super.updateAgent(agentId, agent);\n }\n\n deleteAgent(agentId: UUID): Promise<boolean> {\n return super.deleteAgent(agentId);\n }\n\n createEntities(entities: Entity[]): Promise<boolean> {\n return super.createEntities(entities);\n }\n\n getEntitiesByIds(entityIds: UUID[]): Promise<Entity[]> {\n return super.getEntitiesByIds(entityIds).then((result) => result || []);\n }\n\n updateEntity(entity: Entity): Promise<void> {\n return super.updateEntity(entity);\n }\n\n createMemory(memory: Memory, tableName: string): Promise<UUID> {\n return super.createMemory(memory, tableName);\n }\n\n getMemoryById(memoryId: UUID): Promise<Memory | null> {\n return super.getMemoryById(memoryId);\n }\n\n updateMemory(memory: Partial<Memory> & { id: UUID }): Promise<boolean> {\n return super.updateMemory(memory);\n }\n\n deleteMemory(memoryId: UUID): Promise<void> {\n return super.deleteMemory(memoryId);\n }\n\n createComponent(component: Component): Promise<boolean> {\n return super.createComponent(component);\n }\n\n getComponent(\n entityId: UUID,\n type: string,\n worldId?: UUID,\n sourceEntityId?: UUID\n ): Promise<Component | null> {\n return super.getComponent(entityId, type, worldId, sourceEntityId);\n }\n\n updateComponent(component: Component): Promise<void> {\n return super.updateComponent(component);\n }\n\n deleteComponent(componentId: UUID): Promise<void> {\n return super.deleteComponent(componentId);\n }\n}\n",
120
- "import {\n type Agent,\n type AgentRunCounts,\n type AgentRunSummary,\n type AgentRunSummaryResult,\n ChannelType,\n type Component,\n DatabaseAdapter,\n type Entity,\n type Log,\n type LogBody,\n logger,\n type Memory,\n type MemoryMetadata,\n type Metadata,\n type Participant,\n type Relationship,\n type Room,\n type RunStatus,\n type Task,\n type TaskMetadata,\n type UUID,\n type World,\n} from \"@elizaos/core\";\n\n// JSON-serializable value type for metadata\ntype JsonValue = string | number | boolean | null | JsonValue[] | { [key: string]: JsonValue };\n\nimport {\n and,\n cosineDistance,\n count,\n desc,\n eq,\n gte,\n inArray,\n lt,\n lte,\n or,\n type SQL,\n sql,\n} from \"drizzle-orm\";\nimport { v4 } from \"uuid\";\nimport type { DatabaseMigrationService } from \"./migration-service\";\nimport { DIMENSION_MAP, type EmbeddingDimensionColumn } from \"./schema/embedding\";\nimport {\n agentTable,\n cacheTable,\n channelParticipantsTable,\n channelTable,\n componentTable,\n embeddingTable,\n entityTable,\n logTable,\n memoryTable,\n messageServerAgentsTable,\n messageServerTable,\n messageTable,\n participantTable,\n relationshipTable,\n roomTable,\n taskTable,\n worldTable,\n} from \"./schema/index\";\nimport type { DrizzleDatabase } from \"./types\";\n\nexport abstract class BaseDrizzleAdapter extends DatabaseAdapter<DrizzleDatabase> {\n protected readonly maxRetries: number = 3;\n protected readonly baseDelay: number = 1000;\n protected readonly maxDelay: number = 10000;\n protected readonly jitterMax: number = 1000;\n protected embeddingDimension: EmbeddingDimensionColumn = DIMENSION_MAP[384];\n protected migrationService?: DatabaseMigrationService;\n\n protected abstract withDatabase<T>(operation: () => Promise<T>): Promise<T>;\n\n public abstract withEntityContext<T>(\n entityId: UUID | null,\n callback: (tx: DrizzleDatabase) => Promise<T>\n ): Promise<T>;\n\n public abstract init(): Promise<void>;\n public abstract close(): Promise<void>;\n\n public async initialize(): Promise<void> {\n await this.init();\n }\n\n public async runPluginMigrations(\n plugins: Array<{ name: string; schema?: Record<string, unknown> }>,\n options?: {\n verbose?: boolean;\n force?: boolean;\n dryRun?: boolean;\n }\n ): Promise<void> {\n if (!this.migrationService) {\n const { DatabaseMigrationService } = await import(\"./migration-service\");\n this.migrationService = new DatabaseMigrationService();\n await this.migrationService.initializeWithDatabase(this.db as DrizzleDatabase);\n }\n\n for (const plugin of plugins) {\n if (plugin.schema) {\n this.migrationService.registerSchema(plugin.name, plugin.schema);\n }\n }\n\n await this.migrationService.runAllPluginMigrations(options);\n }\n\n public getDatabase(): unknown {\n return this.db;\n }\n\n protected agentId: UUID;\n\n constructor(agentId: UUID) {\n super();\n this.agentId = agentId;\n }\n\n private normalizeEntityNames(names: unknown): string[] {\n if (names == null) {\n return [];\n }\n\n if (typeof names === \"string\") {\n return [names];\n }\n\n if (Array.isArray(names)) {\n return names.map(String);\n }\n\n if (names instanceof Set) {\n return Array.from(names).map(String);\n }\n\n if (typeof names === \"object\" && typeof names[Symbol.iterator] === \"function\") {\n return Array.from(names as Iterable<unknown>).map(String);\n }\n\n return [String(names)];\n }\n\n /**\n * Executes the given operation with retry logic.\n * @template T\n * @param {() => Promise<T>} operation - The operation to be executed.\n * @returns {Promise<T>} A promise that resolves with the result of the operation.\n */\n protected async withRetry<T>(operation: () => Promise<T>): Promise<T> {\n let lastError: Error = new Error(\"Unknown error\");\n\n for (let attempt = 1; attempt <= this.maxRetries; attempt++) {\n try {\n return await operation();\n } catch (error) {\n lastError = error as Error;\n\n if (attempt < this.maxRetries) {\n const backoffDelay = Math.min(this.baseDelay * 2 ** (attempt - 1), this.maxDelay);\n\n const jitter = Math.random() * this.jitterMax;\n const delay = backoffDelay + jitter;\n\n logger.warn(\n {\n src: \"plugin:sql\",\n attempt,\n maxRetries: this.maxRetries,\n error: error instanceof Error ? error.message : String(error),\n },\n \"Database operation failed, retrying\"\n );\n\n await new Promise((resolve) => setTimeout(resolve, delay));\n } else {\n logger.error(\n {\n src: \"plugin:sql\",\n totalAttempts: attempt,\n error: error instanceof Error ? error.message : String(error),\n },\n \"Max retry attempts reached\"\n );\n throw error instanceof Error ? error : new Error(String(error));\n }\n }\n }\n\n throw lastError;\n }\n\n /**\n * Asynchronously ensures that the given embedding dimension is valid for the agent.\n *\n * @param {number} dimension - The dimension to ensure for the embedding.\n * @returns {Promise<void>} - Resolves once the embedding dimension is ensured.\n */\n async ensureEmbeddingDimension(dimension: number) {\n return this.withDatabase(async () => {\n const existingMemory = await this.db\n .select()\n .from(memoryTable)\n .innerJoin(embeddingTable, eq(embeddingTable.memoryId, memoryTable.id))\n .where(eq(memoryTable.agentId, this.agentId))\n .limit(1);\n\n if (existingMemory.length > 0) {\n // The join result includes both memoryTable and embeddingTable columns\n // Access embedding columns directly from the joined result\n interface JoinedMemoryResult {\n memories: typeof memoryTable.$inferSelect;\n embeddings: typeof embeddingTable.$inferSelect;\n }\n const joinedResult = existingMemory[0] as JoinedMemoryResult;\n Object.entries(DIMENSION_MAP).find(([_, colName]) => {\n const embeddingCol = colName as keyof typeof embeddingTable.$inferSelect;\n return joinedResult.embeddings[embeddingCol] !== null;\n });\n // We don't actually need to use usedDimension for now, but it's good to know it's there.\n }\n\n this.embeddingDimension = DIMENSION_MAP[dimension as keyof typeof DIMENSION_MAP];\n });\n }\n\n /**\n * Asynchronously retrieves an agent by their ID from the database.\n * @param {UUID} agentId - The ID of the agent to retrieve.\n * @returns {Promise<Agent | null>} A promise that resolves to the retrieved agent or null if not found.\n */\n async getAgent(agentId: UUID): Promise<Agent | null> {\n return this.withDatabase(async () => {\n const rows = await this.db\n .select()\n .from(agentTable)\n .where(eq(agentTable.id, agentId))\n .limit(1);\n\n if (rows.length === 0) return null;\n\n const row = rows[0];\n const bioValue = !row.bio ? \"\" : Array.isArray(row.bio) ? row.bio : row.bio;\n return {\n ...row,\n username: row.username || \"\",\n id: row.id as UUID,\n system: !row.system ? undefined : row.system,\n bio: bioValue as string | string[],\n createdAt: row.createdAt.getTime(),\n updatedAt: row.updatedAt.getTime(),\n } as unknown as Agent;\n });\n }\n\n /**\n * Asynchronously retrieves a list of agents from the database.\n *\n * @returns {Promise<Partial<Agent>[]>} A Promise that resolves to an array of Agent objects.\n */\n async getAgents(): Promise<Partial<Agent>[]> {\n const result = await this.withDatabase(async () => {\n const rows = await this.db\n .select({\n id: agentTable.id,\n name: agentTable.name,\n bio: agentTable.bio,\n })\n .from(agentTable);\n return rows.map(\n (row) =>\n ({\n ...row,\n id: row.id as UUID,\n bio: (row.bio === null ? \"\" : Array.isArray(row.bio) ? row.bio : row.bio) as\n | string\n | string[],\n }) as Partial<Agent>\n );\n });\n // Guard against null return\n return result || [];\n }\n /**\n * Asynchronously creates a new agent record in the database.\n *\n * @param {Partial<Agent>} agent The agent object to be created.\n * @returns {Promise<boolean>} A promise that resolves to a boolean indicating the success of the operation.\n */\n async createAgent(agent: Agent): Promise<boolean> {\n return this.withDatabase(async () => {\n try {\n // Check for existing agent with the same ID only (names can be duplicated)\n if (agent.id) {\n const existing = await this.db\n .select({ id: agentTable.id })\n .from(agentTable)\n .where(eq(agentTable.id, agent.id))\n .limit(1);\n\n if (existing.length > 0) {\n logger.warn(\n { src: \"plugin:sql\", agentId: agent.id },\n \"Attempted to create agent with duplicate ID\"\n );\n return false;\n }\n }\n\n await this.db.transaction(async (tx) => {\n const agentData = {\n ...agent,\n createdAt: new Date(\n typeof agent.createdAt === \"bigint\"\n ? Number(agent.createdAt)\n : agent.createdAt || Date.now()\n ),\n updatedAt: new Date(\n typeof agent.updatedAt === \"bigint\"\n ? Number(agent.updatedAt)\n : agent.updatedAt || Date.now()\n ),\n };\n await tx\n .insert(agentTable)\n .values(agentData as unknown as typeof agentTable.$inferInsert);\n });\n\n return true;\n } catch (error) {\n logger.error(\n {\n src: \"plugin:sql\",\n agentId: agent.id,\n error: error instanceof Error ? error.message : String(error),\n },\n \"Failed to create agent\"\n );\n return false;\n }\n });\n }\n\n /**\n * Updates an agent in the database with the provided agent ID and data.\n * @param {UUID} agentId - The unique identifier of the agent to update.\n * @param {Partial<Agent>} agent - The partial agent object containing the fields to update.\n * @returns {Promise<boolean>} - A boolean indicating if the agent was successfully updated.\n */\n async updateAgent(agentId: UUID, agent: Partial<Agent>): Promise<boolean> {\n return this.withDatabase(async () => {\n try {\n if (!agentId) {\n throw new Error(\"Agent ID is required for update\");\n }\n\n await this.db.transaction(async (tx) => {\n // Handle settings update if present\n if (agent?.settings) {\n agent.settings = await this.mergeAgentSettings(tx, agentId, agent.settings);\n }\n\n // Convert numeric timestamps to Date objects for database storage\n // The Agent interface uses numbers, but the database schema expects Date objects\n const updateData: Record<string, unknown> = { ...agent };\n\n if (updateData.createdAt) {\n if (typeof updateData.createdAt === \"number\") {\n updateData.createdAt = new Date(updateData.createdAt);\n } else {\n delete updateData.createdAt; // Don't update createdAt if it's not a valid timestamp\n }\n }\n if (updateData.updatedAt) {\n if (typeof updateData.updatedAt === \"number\") {\n updateData.updatedAt = new Date(updateData.updatedAt);\n } else {\n updateData.updatedAt = new Date(); // Use current time if invalid\n }\n } else {\n updateData.updatedAt = new Date(); // Always set updatedAt to current time\n }\n\n await tx.update(agentTable).set(updateData).where(eq(agentTable.id, agentId));\n });\n\n return true;\n } catch (error) {\n logger.error(\n {\n src: \"plugin:sql\",\n agentId,\n error: error instanceof Error ? error.message : String(error),\n },\n \"Failed to update agent\"\n );\n return false;\n }\n });\n }\n\n /**\n * Merges updated agent settings with existing settings in the database,\n * with special handling for nested objects like secrets.\n * @param tx - The database transaction\n * @param agentId - The ID of the agent\n * @param updatedSettings - The settings object with updates\n * @returns The merged settings object\n * @private\n */\n private async mergeAgentSettings<T extends Record<string, unknown>>(\n tx: DrizzleDatabase,\n agentId: UUID,\n updatedSettings: T\n ): Promise<T> {\n // First get the current agent data\n const currentAgent = await tx\n .select({ settings: agentTable.settings })\n .from(agentTable)\n .where(eq(agentTable.id, agentId))\n .limit(1);\n\n const currentSettings =\n currentAgent.length > 0 && currentAgent[0].settings ? currentAgent[0].settings : {};\n\n const deepMerge = (\n target: Record<string, unknown> | unknown,\n source: Record<string, unknown>\n ): Record<string, unknown> | undefined => {\n // If source is explicitly null, it means the intention is to set this entire branch to null (or delete if top-level handled by caller).\n // For recursive calls, if a sub-object in source is null, it effectively means \"remove this sub-object from target\".\n // However, our primary deletion signal is a *property value* being null within an object.\n if (source === null) {\n // If the entire source for a given key is null, we treat it as \"delete this key from target\"\n // by returning undefined, which the caller can use to delete the key.\n return undefined;\n }\n\n // If source is an array or a primitive, it replaces the target value.\n if (Array.isArray(source) || typeof source !== \"object\") {\n return source;\n }\n\n // Initialize output. If target is not an object, start with an empty one to merge source into.\n const output =\n typeof target === \"object\" && target !== null && !Array.isArray(target)\n ? { ...target }\n : {};\n\n for (const key of Object.keys(source)) {\n // Iterate over source keys\n const sourceValue = source[key];\n\n if (sourceValue === null) {\n // If a value in source is null, delete the corresponding key from output.\n delete output[key];\n } else if (typeof sourceValue === \"object\" && !Array.isArray(sourceValue)) {\n // If value is an object, recurse.\n const nestedMergeResult = deepMerge(output[key], sourceValue as Record<string, unknown>);\n if (nestedMergeResult === undefined) {\n // If recursive merge resulted in undefined (meaning the nested object should be deleted)\n delete output[key];\n } else {\n output[key] = nestedMergeResult;\n }\n } else {\n // Primitive or array value from source, assign it.\n output[key] = sourceValue;\n }\n }\n\n // After processing all keys from source, check if output became empty.\n // An object is empty if all its keys were deleted or resulted in undefined.\n // This is a more direct check than iterating 'output' after building it.\n if (Object.keys(output).length === 0) {\n // If the source itself was not an explicitly empty object,\n // and the merge resulted in an empty object, signal deletion.\n if (!(typeof source === \"object\" && source !== null && Object.keys(source).length === 0)) {\n return undefined; // Signal to delete this (parent) key if it became empty.\n }\n }\n\n return output;\n }; // End of deepMerge\n\n const finalSettings = deepMerge(currentSettings, updatedSettings);\n // If the entire settings object becomes undefined (e.g. all keys removed),\n // return an empty object instead of undefined/null to keep the settings field present.\n return (finalSettings ?? {}) as T;\n }\n\n /**\n * Asynchronously deletes an agent with the specified UUID and all related entries.\n *\n * @param {UUID} agentId - The UUID of the agent to be deleted.\n * @returns {Promise<boolean>} - A boolean indicating if the deletion was successful.\n */\n async deleteAgent(agentId: UUID): Promise<boolean> {\n return this.withDatabase(async () => {\n try {\n // Simply delete the agent - all related data will be cascade deleted\n const result = await this.db\n .delete(agentTable)\n .where(eq(agentTable.id, agentId))\n .returning();\n\n if (result.length === 0) {\n logger.warn({ src: \"plugin:sql\", agentId }, \"Agent not found for deletion\");\n return false;\n }\n\n return true;\n } catch (error) {\n logger.error(\n {\n src: \"plugin:sql\",\n agentId,\n error: error instanceof Error ? error.message : String(error),\n },\n \"Failed to delete agent\"\n );\n throw error;\n }\n });\n }\n\n /**\n * Count all agents in the database\n * Used primarily for maintenance and cleanup operations\n */\n /**\n * Asynchronously counts the number of agents in the database.\n * @returns {Promise<number>} A Promise that resolves to the number of agents in the database.\n */\n async countAgents(): Promise<number> {\n return this.withDatabase(async () => {\n try {\n const result = await this.db.select({ count: count() }).from(agentTable);\n\n const result0 = result[0];\n return result0?.count || 0;\n } catch (error) {\n logger.error(\n {\n src: \"plugin:sql\",\n error: error instanceof Error ? error.message : String(error),\n },\n \"Failed to count agents\"\n );\n return 0;\n }\n });\n }\n\n /**\n * Clean up the agents table by removing all agents\n * This is used during server startup to ensure no orphaned agents exist\n * from previous crashes or improper shutdowns\n */\n async cleanupAgents(): Promise<void> {\n return this.withDatabase(async () => {\n try {\n await this.db.delete(agentTable);\n } catch (error) {\n logger.error(\n {\n src: \"plugin:sql\",\n error: error instanceof Error ? error.message : String(error),\n },\n \"Failed to clean up agent table\"\n );\n throw error;\n }\n });\n }\n\n /**\n * Asynchronously retrieves an entity and its components by entity IDs.\n * @param {UUID[]} entityIds - The unique identifiers of the entities to retrieve.\n * @returns {Promise<Entity[] | null>} A Promise that resolves to the entity with its components if found, null otherwise.\n */\n async getEntitiesByIds(entityIds: UUID[]): Promise<Entity[] | null> {\n return this.withDatabase(async () => {\n const result = await this.db\n .select({\n entity: entityTable,\n components: componentTable,\n })\n .from(entityTable)\n .leftJoin(componentTable, eq(componentTable.entityId, entityTable.id))\n .where(inArray(entityTable.id, entityIds));\n\n if (result.length === 0) return [];\n\n // Group components by entity\n const entities: Record<UUID, Entity> = {};\n const entityComponents: Record<UUID, Entity[\"components\"]> = {};\n for (const e of result) {\n const key = e.entity.id;\n entities[key] = e.entity;\n if (entityComponents[key] === undefined) entityComponents[key] = [];\n if (e.components) {\n // Handle both single component and array of components\n const componentsArray = Array.isArray(e.components) ? e.components : [e.components];\n entityComponents[key] = [...entityComponents[key], ...componentsArray];\n }\n }\n for (const k of Object.keys(entityComponents)) {\n entities[k].components = entityComponents[k];\n }\n\n return Object.values(entities);\n });\n }\n\n /**\n * Asynchronously retrieves all entities for a given room, optionally including their components.\n * @param {UUID} roomId - The unique identifier of the room to get entities for\n * @param {boolean} [includeComponents] - Whether to include component data for each entity\n * @returns {Promise<Entity[]>} A Promise that resolves to an array of entities in the room\n */\n async getEntitiesForRoom(roomId: UUID, includeComponents?: boolean): Promise<Entity[]> {\n return this.withDatabase(async () => {\n const query = this.db\n .select({\n entity: entityTable,\n ...(includeComponents && { components: componentTable }),\n })\n .from(participantTable)\n .leftJoin(\n entityTable,\n and(eq(participantTable.entityId, entityTable.id), eq(entityTable.agentId, this.agentId))\n );\n\n if (includeComponents) {\n query.leftJoin(componentTable, eq(componentTable.entityId, entityTable.id));\n }\n\n const result = await query.where(eq(participantTable.roomId, roomId));\n\n // Group components by entity if includeComponents is true\n const entitiesByIdMap = new Map<UUID, Entity>();\n\n for (const row of result) {\n if (!row.entity) continue;\n\n const entityId = row.entity.id as UUID;\n if (!entitiesByIdMap.has(entityId)) {\n const entity: Entity = {\n ...row.entity,\n id: entityId,\n agentId: row.entity.agentId as UUID,\n metadata: (row.entity.metadata || {}) as Metadata,\n components: includeComponents ? [] : undefined,\n };\n entitiesByIdMap.set(entityId, entity);\n }\n\n if (includeComponents && row.components) {\n const entity = entitiesByIdMap.get(entityId);\n if (entity) {\n if (!entity.components) {\n entity.components = [];\n }\n entity.components.push(row.components);\n }\n }\n }\n\n return Array.from(entitiesByIdMap.values());\n });\n }\n\n /**\n * Asynchronously creates new entities in the database.\n * @param {Entity[]} entities - The entity objects to be created.\n * @returns {Promise<boolean>} A Promise that resolves to a boolean indicating the success of the operation.\n */\n async createEntities(entities: Entity[]): Promise<boolean> {\n return this.withDatabase(async () => {\n try {\n return await this.db.transaction(async (tx) => {\n // Normalize entity data to ensure names is a proper array\n const normalizedEntities = entities.map((entity) => ({\n ...entity,\n names: this.normalizeEntityNames(entity.names),\n metadata: entity.metadata || {},\n }));\n\n await tx.insert(entityTable).values(normalizedEntities);\n\n return true;\n });\n } catch (error) {\n logger.error(\n {\n src: \"plugin:sql\",\n entityId: entities[0]?.id,\n error: error instanceof Error ? error.message : String(error),\n },\n \"Failed to create entities\"\n );\n return false;\n }\n });\n }\n\n /**\n * Asynchronously ensures an entity exists, creating it if it doesn't\n * @param entity The entity to ensure exists\n * @returns Promise resolving to boolean indicating success\n */\n protected async ensureEntityExists(entity: Entity): Promise<boolean> {\n if (!entity.id) {\n logger.error({ src: \"plugin:sql\" }, \"Entity ID is required for ensureEntityExists\");\n return false;\n }\n\n try {\n const existingEntities = await this.getEntitiesByIds([entity.id]);\n\n if (!existingEntities || !existingEntities.length) {\n return await this.createEntities([entity]);\n }\n\n return true;\n } catch (error) {\n logger.error(\n {\n src: \"plugin:sql\",\n entityId: entity.id,\n error: error instanceof Error ? error.message : String(error),\n },\n \"Failed to ensure entity exists\"\n );\n return false;\n }\n }\n\n /**\n * Asynchronously updates an entity in the database.\n * @param {Entity} entity - The entity object to be updated.\n * @returns {Promise<void>} A Promise that resolves when the entity is updated.\n */\n async updateEntity(entity: Entity): Promise<void> {\n if (!entity.id) {\n throw new Error(\"Entity ID is required for update\");\n }\n return this.withDatabase(async () => {\n // Normalize entity data to ensure names is a proper array\n const normalizedEntity = {\n ...entity,\n names: this.normalizeEntityNames(entity.names),\n metadata: entity.metadata || {},\n };\n\n await this.db\n .update(entityTable)\n .set(normalizedEntity)\n .where(eq(entityTable.id, entity.id as string));\n });\n }\n\n /**\n * Asynchronously deletes an entity from the database based on the provided ID.\n * @param {UUID} entityId - The ID of the entity to delete.\n * @returns {Promise<void>} A Promise that resolves when the entity is deleted.\n */\n async deleteEntity(entityId: UUID): Promise<void> {\n return this.withDatabase(async () => {\n await this.db.transaction(async (tx) => {\n // Delete related components first\n await tx\n .delete(componentTable)\n .where(\n or(eq(componentTable.entityId, entityId), eq(componentTable.sourceEntityId, entityId))\n );\n\n // Delete the entity\n await tx.delete(entityTable).where(eq(entityTable.id, entityId));\n });\n });\n }\n\n /**\n * Asynchronously retrieves entities by their names and agentId.\n * @param {Object} params - The parameters for retrieving entities.\n * @param {string[]} params.names - The names to search for.\n * @param {UUID} params.agentId - The agent ID to filter by.\n * @returns {Promise<Entity[]>} A Promise that resolves to an array of entities.\n */\n async getEntitiesByNames(params: { names: string[]; agentId: UUID }): Promise<Entity[]> {\n return this.withDatabase(async () => {\n const { names, agentId } = params;\n\n // Build a condition to match any of the names\n const nameConditions = names.map((name) => sql`${name} = ANY(${entityTable.names})`);\n\n const query = sql`\n SELECT * FROM ${entityTable}\n WHERE ${entityTable.agentId} = ${agentId}\n AND (${sql.join(nameConditions, sql` OR `)})\n `;\n\n const result = await this.db.execute(query);\n\n return result.rows.map((row: Record<string, unknown>) => ({\n id: row.id as UUID,\n agentId: row.agentId as UUID,\n names: (row.names || []) as string[],\n metadata: (row.metadata || {}) as Metadata,\n }));\n });\n }\n\n /**\n * Asynchronously searches for entities by name with fuzzy matching.\n * @param {Object} params - The parameters for searching entities.\n * @param {string} params.query - The search query.\n * @param {UUID} params.agentId - The agent ID to filter by.\n * @param {number} params.limit - The maximum number of results to return.\n * @returns {Promise<Entity[]>} A Promise that resolves to an array of entities.\n */\n async searchEntitiesByName(params: {\n query: string;\n agentId: UUID;\n limit?: number;\n }): Promise<Entity[]> {\n return this.withDatabase(async () => {\n const { query, agentId, limit = 10 } = params;\n\n // If query is empty, return all entities up to limit\n if (!query || query.trim() === \"\") {\n const result = await this.db\n .select()\n .from(entityTable)\n .where(eq(entityTable.agentId, agentId))\n .limit(limit);\n\n return result.map((row: Record<string, unknown>) => ({\n id: row.id as UUID,\n agentId: row.agentId as UUID,\n names: (row.names || []) as string[],\n metadata: (row.metadata || {}) as Metadata,\n }));\n }\n\n // Otherwise, search for entities with names containing the query (case-insensitive)\n const searchQuery = sql`\n SELECT * FROM ${entityTable}\n WHERE ${entityTable.agentId} = ${agentId}\n AND EXISTS (\n SELECT 1 FROM unnest(${entityTable.names}) AS name\n WHERE LOWER(name) LIKE LOWER(${`%${query}%`})\n )\n LIMIT ${limit}\n `;\n\n const result = await this.db.execute(searchQuery);\n\n return result.rows.map((row: Record<string, unknown>) => ({\n id: row.id as UUID,\n agentId: row.agentId as UUID,\n names: (row.names || []) as string[],\n metadata: (row.metadata || {}) as Metadata,\n }));\n });\n }\n\n async getComponent(\n entityId: UUID,\n type: string,\n worldId?: UUID,\n sourceEntityId?: UUID\n ): Promise<Component | null> {\n return this.withDatabase(async () => {\n const conditions = [eq(componentTable.entityId, entityId), eq(componentTable.type, type)];\n\n if (worldId) {\n conditions.push(eq(componentTable.worldId, worldId));\n }\n\n if (sourceEntityId) {\n conditions.push(eq(componentTable.sourceEntityId, sourceEntityId));\n }\n\n const result = await this.db\n .select()\n .from(componentTable)\n .where(and(...conditions));\n\n if (result.length === 0) return null;\n\n const component = result[0];\n\n return {\n ...component,\n id: component.id as UUID,\n entityId: component.entityId as UUID,\n agentId: component.agentId as UUID,\n roomId: component.roomId as UUID,\n worldId: (component.worldId ?? \"\") as UUID,\n sourceEntityId: (component.sourceEntityId ?? \"\") as UUID,\n data: component.data as Metadata,\n createdAt: component.createdAt.getTime(),\n };\n });\n }\n\n /**\n * Asynchronously retrieves all components for a given entity, optionally filtered by world and source entity.\n * @param {UUID} entityId - The unique identifier of the entity to retrieve components for\n * @param {UUID} [worldId] - Optional world ID to filter components by\n * @param {UUID} [sourceEntityId] - Optional source entity ID to filter components by\n * @returns {Promise<Component[]>} A Promise that resolves to an array of components\n */\n async getComponents(entityId: UUID, worldId?: UUID, sourceEntityId?: UUID): Promise<Component[]> {\n return this.withDatabase(async () => {\n const conditions = [eq(componentTable.entityId, entityId)];\n\n if (worldId) {\n conditions.push(eq(componentTable.worldId, worldId));\n }\n\n if (sourceEntityId) {\n conditions.push(eq(componentTable.sourceEntityId, sourceEntityId));\n }\n\n const result = await this.db\n .select({\n id: componentTable.id,\n entityId: componentTable.entityId,\n type: componentTable.type,\n data: componentTable.data,\n worldId: componentTable.worldId,\n agentId: componentTable.agentId,\n roomId: componentTable.roomId,\n sourceEntityId: componentTable.sourceEntityId,\n createdAt: componentTable.createdAt,\n })\n .from(componentTable)\n .where(and(...conditions));\n\n if (result.length === 0) return [];\n\n const components = result.map((component) => ({\n ...component,\n id: component.id as UUID,\n entityId: component.entityId as UUID,\n agentId: component.agentId as UUID,\n roomId: component.roomId as UUID,\n worldId: (component.worldId ?? \"\") as UUID,\n sourceEntityId: (component.sourceEntityId ?? \"\") as UUID,\n data: component.data as Metadata,\n createdAt: component.createdAt.getTime(),\n }));\n\n return components;\n });\n }\n\n /**\n * Asynchronously creates a new component in the database.\n * @param {Component} component - The component object to be created.\n * @returns {Promise<boolean>} A Promise that resolves to a boolean indicating the success of the operation.\n */\n async createComponent(component: Component): Promise<boolean> {\n return this.withDatabase(async () => {\n await this.db.insert(componentTable).values({\n ...component,\n createdAt: new Date(),\n });\n return true;\n });\n }\n\n /**\n * Asynchronously updates an existing component in the database.\n * @param {Component} component - The component object to be updated.\n * @returns {Promise<void>} A Promise that resolves when the component is updated.\n */\n async updateComponent(component: Component): Promise<void> {\n return this.withDatabase(async () => {\n try {\n // Convert createdAt from number to Date for database compatibility\n const { createdAt, ...rest } = component;\n await this.db\n .update(componentTable)\n .set({\n ...rest,\n createdAt: new Date(createdAt),\n })\n .where(eq(componentTable.id, component.id));\n } catch (e) {\n console.error(\"updateComponent error\", e);\n }\n });\n }\n\n /**\n * Asynchronously deletes a component from the database.\n * @param {UUID} componentId - The unique identifier of the component to delete.\n * @returns {Promise<void>} A Promise that resolves when the component is deleted.\n */\n async deleteComponent(componentId: UUID): Promise<void> {\n return this.withDatabase(async () => {\n await this.db.delete(componentTable).where(eq(componentTable.id, componentId));\n });\n }\n\n /**\n * Asynchronously retrieves memories from the database based on the provided parameters.\n * @param {Object} params - The parameters for retrieving memories.\n * @param {UUID} params.roomId - The ID of the room to retrieve memories for.\n * @param {number} [params.count] - The maximum number of memories to retrieve.\n * @param {number} [params.offset] - The offset for pagination.\n * @param {boolean} [params.unique] - Whether to retrieve unique memories only.\n * @param {string} [params.tableName] - The name of the table to retrieve memories from.\n * @param {number} [params.start] - The start date to retrieve memories from.\n * @param {number} [params.end] - The end date to retrieve memories from.\n * @returns {Promise<Memory[]>} A Promise that resolves to an array of memories.\n */\n async getMemories(params: {\n entityId?: UUID;\n agentId?: UUID;\n count?: number;\n offset?: number;\n unique?: boolean;\n tableName: string;\n start?: number;\n end?: number;\n roomId?: UUID;\n worldId?: UUID;\n }): Promise<Memory[]> {\n const { entityId, agentId, roomId, worldId, tableName, unique, start, end, offset } = params;\n\n if (!tableName) throw new Error(\"tableName is required\");\n if (offset !== undefined && offset < 0) {\n throw new Error(\"offset must be a non-negative number\");\n }\n\n return this.withEntityContext(entityId ?? null, async (tx) => {\n const conditions = [eq(memoryTable.type, tableName)];\n\n if (start) {\n conditions.push(gte(memoryTable.createdAt, new Date(start)));\n }\n\n // RLS handles access control - no explicit entityId filter needed\n\n if (roomId) {\n conditions.push(eq(memoryTable.roomId, roomId));\n }\n\n // Add worldId condition\n if (worldId) {\n conditions.push(eq(memoryTable.worldId, worldId));\n }\n\n if (end) {\n conditions.push(lte(memoryTable.createdAt, new Date(end)));\n }\n\n if (unique) {\n conditions.push(eq(memoryTable.unique, true));\n }\n\n if (agentId) {\n conditions.push(eq(memoryTable.agentId, agentId));\n }\n\n const baseQuery = tx\n .select({\n memory: {\n id: memoryTable.id,\n type: memoryTable.type,\n createdAt: memoryTable.createdAt,\n content: memoryTable.content,\n entityId: memoryTable.entityId,\n agentId: memoryTable.agentId,\n roomId: memoryTable.roomId,\n unique: memoryTable.unique,\n metadata: memoryTable.metadata,\n },\n embedding: embeddingTable[this.embeddingDimension],\n })\n .from(memoryTable)\n .leftJoin(embeddingTable, eq(embeddingTable.memoryId, memoryTable.id))\n .where(and(...conditions))\n .orderBy(desc(memoryTable.createdAt));\n\n // Apply limit and offset for pagination\n // Build query conditionally to maintain proper types\n const rows = await (async () => {\n if (params.count && offset !== undefined && offset > 0) {\n return baseQuery.limit(params.count).offset(offset);\n } else if (params.count) {\n return baseQuery.limit(params.count);\n } else if (offset !== undefined && offset > 0) {\n return baseQuery.offset(offset);\n } else {\n return baseQuery;\n }\n })();\n\n return rows.map((row) => ({\n id: row.memory.id as UUID,\n type: row.memory.type,\n createdAt: row.memory.createdAt.getTime(),\n content:\n typeof row.memory.content === \"string\"\n ? JSON.parse(row.memory.content)\n : row.memory.content,\n entityId: row.memory.entityId as UUID,\n agentId: row.memory.agentId as UUID,\n roomId: row.memory.roomId as UUID,\n unique: row.memory.unique,\n metadata: row.memory.metadata as MemoryMetadata,\n embedding: row.embedding ? Array.from(row.embedding) : undefined,\n }));\n });\n }\n\n /**\n * Asynchronously retrieves memories from the database based on the provided parameters.\n * @param {Object} params - The parameters for retrieving memories.\n * @param {UUID[]} params.roomIds - The IDs of the rooms to retrieve memories for.\n * @param {string} params.tableName - The name of the table to retrieve memories from.\n * @param {number} [params.limit] - The maximum number of memories to retrieve.\n * @returns {Promise<Memory[]>} A Promise that resolves to an array of memories.\n */\n async getMemoriesByRoomIds(params: {\n roomIds: UUID[];\n tableName: string;\n limit?: number;\n }): Promise<Memory[]> {\n return this.withDatabase(async () => {\n if (params.roomIds.length === 0) return [];\n\n const conditions = [\n eq(memoryTable.type, params.tableName),\n inArray(memoryTable.roomId, params.roomIds),\n ];\n\n conditions.push(eq(memoryTable.agentId, this.agentId));\n\n const query = this.db\n .select({\n id: memoryTable.id,\n type: memoryTable.type,\n createdAt: memoryTable.createdAt,\n content: memoryTable.content,\n entityId: memoryTable.entityId,\n agentId: memoryTable.agentId,\n roomId: memoryTable.roomId,\n unique: memoryTable.unique,\n metadata: memoryTable.metadata,\n })\n .from(memoryTable)\n .where(and(...conditions))\n .orderBy(desc(memoryTable.createdAt));\n\n const rows = params.limit ? await query.limit(params.limit) : await query;\n\n return rows.map((row) => ({\n id: row.id as UUID,\n createdAt: row.createdAt.getTime(),\n content: typeof row.content === \"string\" ? JSON.parse(row.content) : row.content,\n entityId: row.entityId as UUID,\n agentId: row.agentId as UUID,\n roomId: row.roomId as UUID,\n unique: row.unique,\n metadata: row.metadata,\n })) as Memory[];\n });\n }\n\n /**\n * Asynchronously retrieves a memory by its unique identifier.\n * @param {UUID} id - The unique identifier of the memory to retrieve.\n * @returns {Promise<Memory | null>} A Promise that resolves to the memory if found, null otherwise.\n */\n async getMemoryById(id: UUID): Promise<Memory | null> {\n return this.withDatabase(async () => {\n const result = await this.db\n .select({\n memory: memoryTable,\n embedding: embeddingTable[this.embeddingDimension],\n })\n .from(memoryTable)\n .leftJoin(embeddingTable, eq(memoryTable.id, embeddingTable.memoryId))\n .where(eq(memoryTable.id, id))\n .limit(1);\n\n if (result.length === 0) return null;\n\n const row = result[0];\n return {\n id: row.memory.id as UUID,\n createdAt: row.memory.createdAt.getTime(),\n content:\n typeof row.memory.content === \"string\"\n ? JSON.parse(row.memory.content)\n : row.memory.content,\n entityId: row.memory.entityId as UUID,\n agentId: row.memory.agentId as UUID,\n roomId: row.memory.roomId as UUID,\n unique: row.memory.unique,\n metadata: row.memory.metadata as MemoryMetadata,\n embedding: row.embedding ?? undefined,\n };\n });\n }\n\n /**\n * Asynchronously retrieves memories from the database based on the provided parameters.\n * @param {Object} params - The parameters for retrieving memories.\n * @param {UUID[]} params.memoryIds - The IDs of the memories to retrieve.\n * @param {string} [params.tableName] - The name of the table to retrieve memories from.\n * @returns {Promise<Memory[]>} A Promise that resolves to an array of memories.\n */\n async getMemoriesByIds(memoryIds: UUID[], tableName?: string): Promise<Memory[]> {\n return this.withDatabase(async () => {\n if (memoryIds.length === 0) return [];\n\n const conditions = [inArray(memoryTable.id, memoryIds)];\n\n if (tableName) {\n conditions.push(eq(memoryTable.type, tableName));\n }\n\n const rows = await this.db\n .select({\n memory: memoryTable,\n embedding: embeddingTable[this.embeddingDimension],\n })\n .from(memoryTable)\n .leftJoin(embeddingTable, eq(embeddingTable.memoryId, memoryTable.id))\n .where(and(...conditions))\n .orderBy(desc(memoryTable.createdAt));\n\n return rows.map((row) => ({\n id: row.memory.id as UUID,\n createdAt: row.memory.createdAt.getTime(),\n content:\n typeof row.memory.content === \"string\"\n ? JSON.parse(row.memory.content)\n : row.memory.content,\n entityId: row.memory.entityId as UUID,\n agentId: row.memory.agentId as UUID,\n roomId: row.memory.roomId as UUID,\n unique: row.memory.unique,\n metadata: row.memory.metadata as MemoryMetadata,\n embedding: row.embedding ?? undefined,\n }));\n });\n }\n\n /**\n * Asynchronously retrieves cached embeddings from the database based on the provided parameters.\n * @param {Object} opts - The parameters for retrieving cached embeddings.\n * @param {string} opts.query_table_name - The name of the table to retrieve embeddings from.\n * @param {number} opts.query_threshold - The threshold for the levenshtein distance.\n * @param {string} opts.query_input - The input string to search for.\n * @param {string} opts.query_field_name - The name of the field to retrieve embeddings from.\n * @param {string} opts.query_field_sub_name - The name of the sub-field to retrieve embeddings from.\n * @param {number} opts.query_match_count - The maximum number of matches to retrieve.\n * @returns {Promise<{ embedding: number[]; levenshtein_score: number }[]>} A Promise that resolves to an array of cached embeddings.\n */\n async getCachedEmbeddings(opts: {\n query_table_name: string;\n query_threshold: number;\n query_input: string;\n query_field_name: string;\n query_field_sub_name: string;\n query_match_count: number;\n }): Promise<{ embedding: number[]; levenshtein_score: number }[]> {\n return this.withDatabase(async () => {\n try {\n // Drizzle database has execute method for raw SQL\n interface DrizzleDatabaseWithExecute {\n execute: (query: ReturnType<typeof sql>) => Promise<{ rows: Record<string, unknown>[] }>;\n }\n const results = await (this.db as DrizzleDatabaseWithExecute).execute(sql`\n WITH content_text AS (\n SELECT\n m.id,\n COALESCE(\n m.content->>${opts.query_field_sub_name},\n ''\n ) as content_text\n FROM memories m\n WHERE m.type = ${opts.query_table_name}\n AND m.content->>${opts.query_field_sub_name} IS NOT NULL\n ),\n embedded_text AS (\n SELECT\n ct.content_text,\n COALESCE(\n e.dim_384,\n e.dim_512,\n e.dim_768,\n e.dim_1024,\n e.dim_1536,\n e.dim_3072\n ) as embedding\n FROM content_text ct\n LEFT JOIN embeddings e ON e.memory_id = ct.id\n WHERE e.memory_id IS NOT NULL\n )\n SELECT\n embedding,\n levenshtein(${opts.query_input}, content_text) as levenshtein_score\n FROM embedded_text\n WHERE levenshtein(${opts.query_input}, content_text) <= ${opts.query_threshold}\n ORDER BY levenshtein_score\n LIMIT ${opts.query_match_count}\n `);\n\n return results.rows\n .map((row) => ({\n embedding: Array.isArray(row.embedding)\n ? row.embedding\n : typeof row.embedding === \"string\"\n ? JSON.parse(row.embedding)\n : [],\n levenshtein_score: Number(row.levenshtein_score),\n }))\n .filter((row) => Array.isArray(row.embedding));\n } catch (error) {\n logger.error(\n {\n src: \"plugin:sql\",\n tableName: opts.query_table_name,\n fieldName: opts.query_field_name,\n error: error instanceof Error ? error.message : String(error),\n },\n \"Failed to get cached embeddings\"\n );\n if (\n error instanceof Error &&\n error.message === \"levenshtein argument exceeds maximum length of 255 characters\"\n ) {\n return [];\n }\n throw error;\n }\n });\n }\n\n /**\n * Asynchronously logs an event in the database.\n * @param {Object} params - The parameters for logging an event.\n * @param {Object} params.body - The body of the event to log.\n * @param {UUID} params.entityId - The ID of the entity associated with the event.\n * @param {UUID} params.roomId - The ID of the room associated with the event.\n * @param {string} params.type - The type of the event to log.\n * @returns {Promise<void>} A Promise that resolves when the event is logged.\n */\n async log(params: {\n body: { [key: string]: unknown };\n entityId: UUID;\n roomId: UUID;\n type: string;\n }): Promise<void> {\n return this.withDatabase(async () => {\n try {\n // Sanitize JSON body to prevent Unicode escape sequence errors\n const sanitizedBody = this.sanitizeJsonObject(params.body);\n\n // Serialize to JSON string first for an additional layer of protection\n // This ensures any problematic characters are properly escaped during JSON serialization\n const jsonString = JSON.stringify(sanitizedBody);\n\n // Use withEntityContext to set Entity RLS context before inserting\n // This ensures the log entry passes STRICT Entity RLS policy\n await this.withEntityContext(params.entityId, async (tx) => {\n await tx.insert(logTable).values({\n body: sql`${jsonString}::jsonb`,\n entityId: params.entityId,\n roomId: params.roomId,\n type: params.type,\n });\n });\n } catch (error) {\n logger.error(\n {\n src: \"plugin:sql\",\n type: params.type,\n roomId: params.roomId,\n entityId: params.entityId,\n error: error instanceof Error ? error.message : String(error),\n },\n \"Failed to create log entry\"\n );\n throw error;\n }\n });\n }\n\n /**\n * Sanitizes a JSON object by replacing problematic Unicode escape sequences\n * that could cause errors during JSON serialization/storage\n *\n * @param value - The value to sanitize\n * @returns The sanitized value\n */\n private sanitizeJsonObject(value: unknown, seen: WeakSet<object> = new WeakSet()): unknown {\n if (value === null || value === undefined) {\n return value;\n }\n\n if (typeof value === \"string\") {\n // Handle multiple cases that can cause PostgreSQL/PgLite JSON parsing errors:\n // 1. Remove null bytes (U+0000) which are not allowed in PostgreSQL text fields\n // 2. Escape single backslashes that might be interpreted as escape sequences\n // 3. Fix broken Unicode escape sequences (\\u not followed by 4 hex digits)\n const nullChar = String.fromCharCode(0);\n const nullCharRegex = new RegExp(nullChar, \"g\");\n return value\n .replace(nullCharRegex, \"\") // Remove null bytes\n .replace(/\\\\(?![\"\\\\/bfnrtu])/g, \"\\\\\\\\\") // Escape single backslashes not part of valid escape sequences\n .replace(/\\\\u(?![0-9a-fA-F]{4})/g, \"\\\\\\\\u\"); // Fix malformed Unicode escape sequences\n }\n\n if (typeof value === \"object\") {\n if (seen.has(value as object)) {\n return null;\n } else {\n seen.add(value as object);\n }\n\n if (Array.isArray(value)) {\n return value.map((item) => this.sanitizeJsonObject(item, seen));\n } else {\n const result: Record<string, unknown> = {};\n const nullChar = String.fromCharCode(0);\n const nullCharRegex = new RegExp(nullChar, \"g\");\n for (const [key, val] of Object.entries(value)) {\n // Also sanitize object keys\n const sanitizedKey =\n typeof key === \"string\"\n ? key.replace(nullCharRegex, \"\").replace(/\\\\u(?![0-9a-fA-F]{4})/g, \"\\\\\\\\u\")\n : key;\n result[sanitizedKey] = this.sanitizeJsonObject(val, seen);\n }\n return result;\n }\n }\n\n return value;\n }\n\n /**\n * Asynchronously retrieves logs from the database based on the provided parameters.\n * @param {Object} params - The parameters for retrieving logs.\n * @param {UUID} params.entityId - The ID of the entity associated with the logs.\n * @param {UUID} [params.roomId] - The ID of the room associated with the logs.\n * @param {string} [params.type] - The type of the logs to retrieve.\n * @param {number} [params.count] - The maximum number of logs to retrieve.\n * @param {number} [params.offset] - The offset to retrieve logs from.\n * @returns {Promise<Log[]>} A Promise that resolves to an array of logs.\n */\n async getLogs(params: {\n entityId?: UUID;\n roomId?: UUID;\n type?: string;\n count?: number;\n offset?: number;\n }): Promise<Log[]> {\n const { entityId, roomId, type, count, offset } = params;\n\n // Use withEntityContext for RLS only when entityId is provided\n // Without entityId, bypass RLS to see all logs (for non-RLS mode)\n return this.withEntityContext(entityId ?? null, async (tx) => {\n const result = await tx\n .select()\n .from(logTable)\n .where(\n and(\n roomId ? eq(logTable.roomId, roomId) : undefined,\n type ? eq(logTable.type, type) : undefined\n )\n )\n .orderBy(desc(logTable.createdAt))\n .limit(count ?? 10)\n .offset(offset ?? 0);\n\n const logs = result.map((log) => ({\n ...log,\n id: log.id as UUID,\n entityId: log.entityId as UUID,\n roomId: log.roomId as UUID,\n type: log.type as string,\n body: log.body as LogBody,\n createdAt: new Date(log.createdAt as string | number | Date),\n }));\n\n if (logs.length === 0) return [];\n\n return logs;\n });\n }\n\n async getAgentRunSummaries(\n params: {\n limit?: number;\n roomId?: UUID;\n status?: RunStatus | \"all\";\n from?: number;\n to?: number;\n entityId?: UUID;\n } = {}\n ): Promise<AgentRunSummaryResult> {\n const limit = Math.min(Math.max(params.limit ?? 20, 1), 100);\n const fromDate = typeof params.from === \"number\" ? new Date(params.from) : undefined;\n const toDate = typeof params.to === \"number\" ? new Date(params.to) : undefined;\n\n // Use withEntityContext for RLS when entityId is provided\n return this.withEntityContext(params.entityId ?? null, async (tx) => {\n const runMap = new Map<string, AgentRunSummary>();\n\n const conditions: SQL<unknown>[] = [\n eq(logTable.type, \"run_event\"),\n sql`${logTable.body} ? 'runId'`,\n eq(roomTable.agentId, this.agentId),\n ];\n\n if (params.roomId) {\n conditions.push(eq(logTable.roomId, params.roomId));\n }\n if (fromDate) {\n conditions.push(gte(logTable.createdAt, fromDate));\n }\n if (toDate) {\n conditions.push(lte(logTable.createdAt, toDate));\n }\n\n const whereClause = and(...conditions);\n\n const eventLimit = Math.max(limit * 20, 200);\n\n const runEventRows = await tx\n .select({\n runId: sql<string>`(${logTable.body} ->> 'runId')`,\n status: sql<string | null>`(${logTable.body} ->> 'status')`,\n messageId: sql<string | null>`(${logTable.body} ->> 'messageId')`,\n rawBody: logTable.body,\n createdAt: logTable.createdAt,\n roomId: logTable.roomId,\n entityId: logTable.entityId,\n })\n .from(logTable)\n .innerJoin(roomTable, eq(roomTable.id, logTable.roomId))\n .where(whereClause)\n .orderBy(desc(logTable.createdAt))\n .limit(eventLimit);\n\n for (const row of runEventRows) {\n const runId = row.runId;\n if (!runId) continue;\n\n const summary: AgentRunSummary = runMap.get(runId) ?? {\n runId,\n status: \"started\",\n startedAt: null,\n endedAt: null,\n durationMs: null,\n messageId: undefined,\n roomId: undefined,\n entityId: undefined,\n metadata: {},\n };\n\n if (!summary.messageId && row.messageId) {\n summary.messageId = row.messageId as UUID;\n }\n if (!summary.roomId && row.roomId) {\n summary.roomId = row.roomId as UUID;\n }\n if (!summary.entityId && row.entityId) {\n summary.entityId = row.entityId as UUID;\n }\n\n const body = row.rawBody as Record<string, unknown> | undefined;\n if (body && typeof body === \"object\") {\n if (!summary.roomId && typeof body.roomId === \"string\") {\n summary.roomId = body.roomId as UUID;\n }\n if (!summary.entityId && typeof body.entityId === \"string\") {\n summary.entityId = body.entityId as UUID;\n }\n if (!summary.messageId && typeof body.messageId === \"string\") {\n summary.messageId = body.messageId as UUID;\n }\n if (!summary.metadata || Object.keys(summary.metadata).length === 0) {\n const metadata = (body.metadata as Record<string, unknown> | undefined) ?? undefined;\n summary.metadata = metadata ? ({ ...metadata } as Record<string, JsonValue>) : {};\n }\n }\n\n const createdAt = row.createdAt instanceof Date ? row.createdAt : new Date(row.createdAt);\n const timestamp = createdAt.getTime();\n const bodyStatus = body?.status;\n const eventStatus =\n (row.status as RunStatus | undefined) ?? (bodyStatus as RunStatus | undefined);\n\n if (eventStatus === \"started\") {\n const currentStartedAt =\n summary.startedAt === null\n ? null\n : typeof summary.startedAt === \"bigint\"\n ? Number(summary.startedAt)\n : summary.startedAt;\n summary.startedAt =\n currentStartedAt === null ? timestamp : Math.min(currentStartedAt, timestamp);\n } else if (\n eventStatus === \"completed\" ||\n eventStatus === \"timeout\" ||\n eventStatus === \"error\"\n ) {\n summary.status = eventStatus;\n summary.endedAt = timestamp;\n if (summary.startedAt !== null) {\n const startedAtNum =\n typeof summary.startedAt === \"bigint\" ? Number(summary.startedAt) : summary.startedAt;\n summary.durationMs = Math.max(timestamp - startedAtNum, 0);\n }\n }\n\n runMap.set(runId, summary);\n }\n\n let runs = Array.from(runMap.values());\n if (params.status && params.status !== \"all\") {\n runs = runs.filter((run) => run.status === params.status);\n }\n\n runs.sort((a, b) => {\n const aStarted =\n a.startedAt === null\n ? 0\n : typeof a.startedAt === \"bigint\"\n ? Number(a.startedAt)\n : a.startedAt;\n const bStarted =\n b.startedAt === null\n ? 0\n : typeof b.startedAt === \"bigint\"\n ? Number(b.startedAt)\n : b.startedAt;\n return bStarted - aStarted;\n });\n\n const total = runs.length;\n const limitedRuns = runs.slice(0, limit);\n const hasMore = total > limit;\n\n const runCounts = new Map<string, AgentRunCounts>();\n for (const run of limitedRuns) {\n runCounts.set(run.runId, {\n actions: 0,\n modelCalls: 0,\n errors: 0,\n evaluators: 0,\n });\n }\n\n const runIds = limitedRuns.map((run) => run.runId).filter(Boolean);\n\n if (runIds.length > 0) {\n const runIdArray = sql`array[${sql.join(\n runIds.map((id) => sql`${id}`),\n sql`, `\n )}]::text[]`;\n\n const actionSummary = await this.db.execute(sql`\n SELECT\n body->>'runId' as \"runId\",\n COUNT(*)::int as \"actions\",\n SUM(CASE WHEN COALESCE(body->'result'->>'success', 'true') = 'false' THEN 1 ELSE 0 END)::int as \"errors\",\n SUM(COALESCE((body->>'promptCount')::int, 0))::int as \"modelCalls\"\n FROM ${logTable}\n WHERE type = 'action'\n AND body->>'runId' = ANY(${runIdArray})\n GROUP BY body->>'runId'\n `);\n\n const actionRows = (actionSummary.rows ?? []) as Array<{\n runId: string;\n actions: number | string;\n errors: number | string;\n modelCalls: number | string;\n }>;\n\n for (const row of actionRows) {\n const counts = runCounts.get(row.runId);\n if (!counts) continue;\n counts.actions += Number(row.actions ?? 0);\n counts.errors += Number(row.errors ?? 0);\n counts.modelCalls += Number(row.modelCalls ?? 0);\n }\n\n const evaluatorSummary = await this.db.execute(sql`\n SELECT\n body->>'runId' as \"runId\",\n COUNT(*)::int as \"evaluators\"\n FROM ${logTable}\n WHERE type = 'evaluator'\n AND body->>'runId' = ANY(${runIdArray})\n GROUP BY body->>'runId'\n `);\n\n const evaluatorRows = (evaluatorSummary.rows ?? []) as Array<{\n runId: string;\n evaluators: number | string;\n }>;\n\n for (const row of evaluatorRows) {\n const counts = runCounts.get(row.runId);\n if (!counts) continue;\n counts.evaluators += Number(row.evaluators ?? 0);\n }\n\n const genericSummary = await this.db.execute(sql`\n SELECT\n body->>'runId' as \"runId\",\n COUNT(*) FILTER (WHERE type LIKE 'useModel:%')::int as \"modelLogs\",\n COUNT(*) FILTER (WHERE type = 'embedding_event' AND body->>'status' = 'failed')::int as \"embeddingErrors\"\n FROM ${logTable}\n WHERE (type LIKE 'useModel:%' OR type = 'embedding_event')\n AND body->>'runId' = ANY(${runIdArray})\n GROUP BY body->>'runId'\n `);\n\n const genericRows = (genericSummary.rows ?? []) as Array<{\n runId: string;\n modelLogs: number | string;\n embeddingErrors: number | string;\n }>;\n\n for (const row of genericRows) {\n const counts = runCounts.get(row.runId);\n if (!counts) continue;\n counts.modelCalls += Number(row.modelLogs ?? 0);\n counts.errors += Number(row.embeddingErrors ?? 0);\n }\n }\n\n for (const run of limitedRuns) {\n const counts = runCounts.get(run.runId) ?? {\n actions: 0,\n modelCalls: 0,\n errors: 0,\n evaluators: 0,\n };\n // Cast through unknown to bridge the core type (without $typeName) to proto type (with $typeName)\n run.counts = counts as unknown as typeof run.counts;\n }\n\n return {\n runs: limitedRuns as unknown as import(\"@elizaos/core\").AgentRunSummary[],\n total,\n hasMore,\n } as AgentRunSummaryResult;\n });\n }\n\n /**\n * Asynchronously deletes a log from the database based on the provided parameters.\n * @param {UUID} logId - The ID of the log to delete.\n * @returns {Promise<void>} A Promise that resolves when the log is deleted.\n */\n async deleteLog(logId: UUID): Promise<void> {\n return this.withDatabase(async () => {\n await this.db.delete(logTable).where(eq(logTable.id, logId));\n });\n }\n\n /**\n * Asynchronously searches for memories in the database based on the provided parameters.\n * @param {Object} params - The parameters for searching for memories.\n * @param {string} params.tableName - The name of the table to search for memories in.\n * @param {number[]} params.embedding - The embedding to search for.\n * @param {number} [params.match_threshold] - The threshold for the cosine distance.\n * @param {number} [params.count] - The maximum number of memories to retrieve.\n * @param {boolean} [params.unique] - Whether to retrieve unique memories only.\n * @param {string} [params.query] - Optional query string for potential reranking.\n * @param {UUID} [params.roomId] - Optional room ID to filter by.\n * @param {UUID} [params.worldId] - Optional world ID to filter by.\n * @param {UUID} [params.entityId] - Optional entity ID to filter by.\n * @returns {Promise<Memory[]>} A Promise that resolves to an array of memories.\n */\n async searchMemories(params: {\n tableName: string;\n embedding: number[];\n match_threshold?: number;\n count?: number;\n unique?: boolean;\n query?: string;\n roomId?: UUID;\n worldId?: UUID;\n entityId?: UUID;\n }): Promise<Memory[]> {\n return await this.searchMemoriesByEmbedding(params.embedding, {\n match_threshold: params.match_threshold,\n count: params.count,\n // Pass direct scope fields down\n roomId: params.roomId,\n worldId: params.worldId,\n entityId: params.entityId,\n unique: params.unique,\n tableName: params.tableName,\n });\n }\n\n /**\n * Asynchronously searches for memories in the database based on the provided parameters.\n * @param {number[]} embedding - The embedding to search for.\n * @param {Object} params - The parameters for searching for memories.\n * @param {number} [params.match_threshold] - The threshold for the cosine distance.\n * @param {number} [params.count] - The maximum number of memories to retrieve.\n * @param {UUID} [params.roomId] - Optional room ID to filter by.\n * @param {UUID} [params.worldId] - Optional world ID to filter by.\n * @param {UUID} [params.entityId] - Optional entity ID to filter by.\n * @param {boolean} [params.unique] - Whether to retrieve unique memories only.\n * @param {string} [params.tableName] - The name of the table to search for memories in.\n * @returns {Promise<Memory[]>} A Promise that resolves to an array of memories.\n */\n async searchMemoriesByEmbedding(\n embedding: number[],\n params: {\n match_threshold?: number;\n count?: number;\n roomId?: UUID;\n worldId?: UUID;\n entityId?: UUID;\n unique?: boolean;\n tableName: string;\n }\n ): Promise<Memory[]> {\n return this.withDatabase(async () => {\n const cleanVector = embedding.map((n) => (Number.isFinite(n) ? Number(n.toFixed(6)) : 0));\n\n const similarity = sql<number>`1 - (${cosineDistance(\n embeddingTable[this.embeddingDimension],\n cleanVector\n )})`;\n\n const conditions = [eq(memoryTable.type, params.tableName)];\n\n if (params.unique) {\n conditions.push(eq(memoryTable.unique, true));\n }\n\n conditions.push(eq(memoryTable.agentId, this.agentId));\n\n // Add filters based on direct params\n if (params.roomId) {\n conditions.push(eq(memoryTable.roomId, params.roomId));\n }\n if (params.worldId) {\n conditions.push(eq(memoryTable.worldId, params.worldId));\n }\n if (params.entityId) {\n conditions.push(eq(memoryTable.entityId, params.entityId));\n }\n\n if (params.match_threshold) {\n conditions.push(gte(similarity, params.match_threshold));\n }\n\n const results = await this.db\n .select({\n memory: memoryTable,\n similarity,\n embedding: embeddingTable[this.embeddingDimension],\n })\n .from(embeddingTable)\n .innerJoin(memoryTable, eq(memoryTable.id, embeddingTable.memoryId))\n .where(and(...conditions))\n .orderBy(desc(similarity))\n .limit(params.count ?? 10);\n\n return results.map((row) => ({\n id: row.memory.id as UUID,\n type: row.memory.type,\n createdAt: row.memory.createdAt.getTime(),\n content:\n typeof row.memory.content === \"string\"\n ? JSON.parse(row.memory.content)\n : row.memory.content,\n entityId: row.memory.entityId as UUID,\n agentId: row.memory.agentId as UUID,\n roomId: row.memory.roomId as UUID,\n worldId: row.memory.worldId as UUID | undefined, // Include worldId\n unique: row.memory.unique,\n metadata: row.memory.metadata as MemoryMetadata,\n embedding: row.embedding ?? undefined,\n similarity: row.similarity,\n }));\n });\n }\n\n /**\n * Asynchronously creates a new memory in the database.\n * @param {Memory & { metadata?: MemoryMetadata }} memory - The memory object to create.\n * @param {string} tableName - The name of the table to create the memory in.\n * @returns {Promise<UUID>} A Promise that resolves to the ID of the created memory.\n */\n async createMemory(\n memory: Memory & { metadata?: MemoryMetadata },\n tableName: string\n ): Promise<UUID> {\n const memoryId = memory.id ?? (v4() as UUID);\n\n const existing = await this.getMemoryById(memoryId);\n if (existing) {\n return memoryId;\n }\n\n // only do costly check if we need to\n if (memory.unique === undefined) {\n memory.unique = true; // set default\n if (memory.embedding && Array.isArray(memory.embedding)) {\n const similarMemories = await this.searchMemoriesByEmbedding(memory.embedding, {\n tableName,\n // Use the scope fields from the memory object for similarity check\n roomId: memory.roomId,\n worldId: memory.worldId,\n entityId: memory.entityId,\n match_threshold: 0.95,\n count: 1,\n });\n memory.unique = similarMemories.length === 0;\n }\n }\n\n // Ensure we always pass a JSON string to the SQL placeholder – if we pass an\n // object directly PG sees `[object Object]` and fails the `::jsonb` cast.\n const contentToInsert =\n typeof memory.content === \"string\" ? memory.content : JSON.stringify(memory.content ?? {});\n\n const metadataToInsert =\n typeof memory.metadata === \"string\" ? memory.metadata : JSON.stringify(memory.metadata ?? {});\n\n // Use withEntityContext to set Entity RLS context if needed\n // This delegates to the concrete adapter implementation (PostgreSQL or PGLite)\n await this.withEntityContext(memory.entityId, async (tx) => {\n await tx.insert(memoryTable).values([\n {\n id: memoryId,\n type: tableName,\n content: sql`${contentToInsert}::jsonb`,\n metadata: sql`${metadataToInsert}::jsonb`,\n entityId: memory.entityId,\n roomId: memory.roomId,\n worldId: memory.worldId, // Include worldId\n agentId: memory.agentId || this.agentId,\n unique: memory.unique,\n createdAt: memory.createdAt ? new Date(memory.createdAt) : new Date(),\n },\n ]);\n\n if (memory.embedding && Array.isArray(memory.embedding)) {\n const embeddingValues: Record<string, unknown> = {\n id: v4(),\n memoryId: memoryId,\n createdAt: memory.createdAt ? new Date(memory.createdAt) : new Date(),\n };\n\n const cleanVector = memory.embedding.map((n) =>\n Number.isFinite(n) ? Number(n.toFixed(6)) : 0\n );\n\n embeddingValues[this.embeddingDimension] = cleanVector;\n\n await tx.insert(embeddingTable).values([embeddingValues]);\n }\n });\n\n return memoryId;\n }\n\n /**\n * Updates an existing memory in the database.\n * @param memory The memory object with updated content and optional embedding\n * @returns Promise resolving to boolean indicating success\n */\n async updateMemory(\n memory: Partial<Memory> & { id: UUID; metadata?: MemoryMetadata }\n ): Promise<boolean> {\n return this.withDatabase(async () => {\n try {\n await this.db.transaction(async (tx) => {\n // Update memory content if provided\n if (memory.content) {\n const contentToUpdate =\n typeof memory.content === \"string\"\n ? memory.content\n : JSON.stringify(memory.content ?? {});\n\n const metadataToUpdate =\n typeof memory.metadata === \"string\"\n ? memory.metadata\n : JSON.stringify(memory.metadata ?? {});\n\n await tx\n .update(memoryTable)\n .set({\n content: sql`${contentToUpdate}::jsonb`,\n ...(memory.metadata && {\n metadata: sql`${metadataToUpdate}::jsonb`,\n }),\n })\n .where(eq(memoryTable.id, memory.id));\n } else if (memory.metadata) {\n // Update only metadata if content is not provided\n const metadataToUpdate =\n typeof memory.metadata === \"string\"\n ? memory.metadata\n : JSON.stringify(memory.metadata ?? {});\n\n await tx\n .update(memoryTable)\n .set({\n metadata: sql`${metadataToUpdate}::jsonb`,\n })\n .where(eq(memoryTable.id, memory.id));\n }\n\n // Update embedding if provided\n if (memory.embedding && Array.isArray(memory.embedding)) {\n const cleanVector = memory.embedding.map((n) =>\n Number.isFinite(n) ? Number(n.toFixed(6)) : 0\n );\n\n // Check if embedding exists\n const existingEmbedding = await tx\n .select({ id: embeddingTable.id })\n .from(embeddingTable)\n .where(eq(embeddingTable.memoryId, memory.id))\n .limit(1);\n\n if (existingEmbedding.length > 0) {\n // Update existing embedding\n const updateValues: Record<string, unknown> = {};\n updateValues[this.embeddingDimension] = cleanVector;\n\n await tx\n .update(embeddingTable)\n .set(updateValues)\n .where(eq(embeddingTable.memoryId, memory.id));\n } else {\n // Create new embedding\n const embeddingValues: Record<string, unknown> = {\n id: v4(),\n memoryId: memory.id,\n };\n embeddingValues[this.embeddingDimension] = cleanVector;\n\n await tx.insert(embeddingTable).values([embeddingValues]);\n }\n }\n });\n\n return true;\n } catch (error) {\n logger.error(\n {\n src: \"plugin:sql\",\n memoryId: memory.id,\n error: error instanceof Error ? error.message : String(error),\n },\n \"Failed to update memory\"\n );\n return false;\n }\n });\n }\n\n /**\n * Asynchronously deletes a memory from the database based on the provided parameters.\n * @param {UUID} memoryId - The ID of the memory to delete.\n * @returns {Promise<void>} A Promise that resolves when the memory is deleted.\n */\n async deleteMemory(memoryId: UUID): Promise<void> {\n return this.withDatabase(async () => {\n await this.db.transaction(async (tx) => {\n // See if there are any fragments that we need to delete\n await this.deleteMemoryFragments(tx, memoryId);\n\n // Then delete the embedding for the main memory\n await tx.delete(embeddingTable).where(eq(embeddingTable.memoryId, memoryId));\n\n // Finally delete the memory itself\n await tx.delete(memoryTable).where(eq(memoryTable.id, memoryId));\n });\n });\n }\n\n /**\n * Asynchronously deletes multiple memories from the database in a single batch operation.\n * @param {UUID[]} memoryIds - An array of UUIDs of the memories to delete.\n * @returns {Promise<void>} A Promise that resolves when all memories are deleted.\n */\n async deleteManyMemories(memoryIds: UUID[]): Promise<void> {\n if (memoryIds.length === 0) {\n return;\n }\n\n return this.withDatabase(async () => {\n await this.db.transaction(async (tx) => {\n // Process in smaller batches to avoid query size limits\n const BATCH_SIZE = 100;\n for (let i = 0; i < memoryIds.length; i += BATCH_SIZE) {\n const batch = memoryIds.slice(i, i + BATCH_SIZE);\n\n // Delete any fragments for document memories in this batch\n await Promise.all(\n batch.map(async (memoryId) => {\n await this.deleteMemoryFragments(tx, memoryId);\n })\n );\n\n // Delete embeddings for the batch\n await tx.delete(embeddingTable).where(inArray(embeddingTable.memoryId, batch));\n\n // Delete the memories themselves\n await tx.delete(memoryTable).where(inArray(memoryTable.id, batch));\n }\n });\n });\n }\n\n /**\n * Deletes all memory fragments that reference a specific document memory\n * @param tx The database transaction\n * @param documentId The UUID of the document memory whose fragments should be deleted\n * @private\n */\n private async deleteMemoryFragments(tx: DrizzleDatabase, documentId: UUID): Promise<void> {\n const fragmentsToDelete = await this.getMemoryFragments(tx, documentId);\n\n if (fragmentsToDelete.length > 0) {\n const fragmentIds = fragmentsToDelete.map((f) => f.id) as UUID[];\n\n // Delete embeddings for fragments\n await tx.delete(embeddingTable).where(inArray(embeddingTable.memoryId, fragmentIds));\n\n // Delete the fragments\n await tx.delete(memoryTable).where(inArray(memoryTable.id, fragmentIds));\n }\n }\n\n /**\n * Retrieves all memory fragments that reference a specific document memory\n * @param tx The database transaction\n * @param documentId The UUID of the document memory whose fragments should be retrieved\n * @returns An array of memory fragments\n * @private\n */\n private async getMemoryFragments(tx: DrizzleDatabase, documentId: UUID): Promise<{ id: UUID }[]> {\n const fragments = await tx\n .select({ id: memoryTable.id })\n .from(memoryTable)\n .where(\n and(\n eq(memoryTable.agentId, this.agentId),\n sql`${memoryTable.metadata}->>'documentId' = ${documentId}`\n )\n );\n\n return fragments.map((f) => ({ id: f.id as UUID }));\n }\n\n /**\n * Asynchronously deletes all memories from the database based on the provided parameters.\n * @param {UUID} roomId - The ID of the room to delete memories from.\n * @param {string} tableName - The name of the table to delete memories from.\n * @returns {Promise<void>} A Promise that resolves when the memories are deleted.\n */\n async deleteAllMemories(roomId: UUID, tableName: string): Promise<void> {\n return this.withDatabase(async () => {\n await this.db.transaction(async (tx) => {\n // 1) fetch all memory IDs for this room + table\n const rows = await tx\n .select({ id: memoryTable.id })\n .from(memoryTable)\n .where(and(eq(memoryTable.roomId, roomId), eq(memoryTable.type, tableName)));\n\n const ids = rows.map((r) => r.id);\n logger.debug(\n { src: \"plugin:sql\", roomId, tableName, memoryCount: ids.length },\n \"Deleting all memories\"\n );\n\n if (ids.length === 0) {\n return;\n }\n\n // 2) delete any fragments for \"document\" memories & their embeddings\n await Promise.all(\n ids.map(async (memoryId) => {\n await this.deleteMemoryFragments(tx, memoryId);\n await tx.delete(embeddingTable).where(eq(embeddingTable.memoryId, memoryId));\n })\n );\n\n // 3) delete the memories themselves\n await tx\n .delete(memoryTable)\n .where(and(eq(memoryTable.roomId, roomId), eq(memoryTable.type, tableName)));\n });\n });\n }\n\n /**\n * Asynchronously counts the number of memories in the database based on the provided parameters.\n * @param {UUID} roomId - The ID of the room to count memories in.\n * @param {boolean} [unique] - Whether to count unique memories only.\n * @param {string} [tableName] - The name of the table to count memories in.\n * @returns {Promise<number>} A Promise that resolves to the number of memories.\n */\n async countMemories(roomId: UUID, unique = true, tableName = \"\"): Promise<number> {\n if (!tableName) throw new Error(\"tableName is required\");\n\n return this.withDatabase(async () => {\n const conditions = [eq(memoryTable.roomId, roomId), eq(memoryTable.type, tableName)];\n\n if (unique) {\n conditions.push(eq(memoryTable.unique, true));\n }\n\n const result = await this.db\n .select({ count: sql<number>`count(*)` })\n .from(memoryTable)\n .where(and(...conditions));\n\n const result0 = result[0];\n return Number(result0?.count ?? 0);\n });\n }\n\n /**\n * Asynchronously retrieves rooms from the database based on the provided parameters.\n * @param {UUID[]} roomIds - The IDs of the rooms to retrieve.\n * @returns {Promise<Room[] | null>} A Promise that resolves to the rooms if found, null otherwise.\n */\n async getRoomsByIds(roomIds: UUID[]): Promise<Room[] | null> {\n return this.withDatabase(async () => {\n const result = await this.db\n .select({\n id: roomTable.id,\n name: roomTable.name, // Added name\n channelId: roomTable.channelId,\n agentId: roomTable.agentId,\n messageServerId: roomTable.messageServerId,\n worldId: roomTable.worldId,\n type: roomTable.type,\n source: roomTable.source,\n metadata: roomTable.metadata, // Added metadata\n })\n .from(roomTable)\n .where(and(inArray(roomTable.id, roomIds), eq(roomTable.agentId, this.agentId)));\n\n // Map the result to properly typed Room objects\n const rooms = result.map((room) => ({\n ...room,\n id: room.id as UUID,\n name: room.name ?? undefined,\n agentId: room.agentId as UUID,\n messageServerId: room.messageServerId as UUID,\n serverId: room.messageServerId as UUID, // Backward compatibility alias\n worldId: room.worldId as UUID,\n channelId: room.channelId as UUID,\n type: room.type as ChannelType,\n metadata: room.metadata as Metadata,\n }));\n\n return rooms;\n });\n }\n\n /**\n * Asynchronously retrieves all rooms from the database based on the provided parameters.\n * @param {UUID} worldId - The ID of the world to retrieve rooms from.\n * @returns {Promise<Room[]>} A Promise that resolves to an array of rooms.\n */\n async getRoomsByWorld(worldId: UUID): Promise<Room[]> {\n return this.withDatabase(async () => {\n const result = await this.db.select().from(roomTable).where(eq(roomTable.worldId, worldId));\n const rooms = result.map((room) => ({\n ...room,\n id: room.id as UUID,\n name: room.name ?? undefined,\n agentId: room.agentId as UUID,\n messageServerId: room.messageServerId as UUID,\n serverId: room.messageServerId as UUID, // Backward compatibility alias\n worldId: room.worldId as UUID,\n channelId: room.channelId as UUID,\n type: room.type as ChannelType,\n metadata: room.metadata as Metadata,\n }));\n return rooms;\n });\n }\n\n /**\n * Asynchronously updates a room in the database based on the provided parameters.\n * @param {Room} room - The room object to update.\n * @returns {Promise<void>} A Promise that resolves when the room is updated.\n */\n async updateRoom(room: Room): Promise<void> {\n return this.withDatabase(async () => {\n await this.db\n .update(roomTable)\n .set({ ...room, agentId: this.agentId })\n .where(eq(roomTable.id, room.id));\n });\n }\n\n /**\n * Asynchronously creates a new room in the database based on the provided parameters.\n * @param {Room} room - The room object to create.\n * @returns {Promise<UUID>} A Promise that resolves to the ID of the created room.\n */\n async createRooms(rooms: Room[]): Promise<UUID[]> {\n return this.withDatabase(async () => {\n const roomsWithIds = rooms.map((room) => ({\n ...room,\n agentId: this.agentId,\n id: room.id || v4(), // ensure each room has a unique ID\n }));\n\n const insertedRooms = await this.db\n .insert(roomTable)\n .values(roomsWithIds)\n .onConflictDoNothing()\n .returning();\n const insertedIds = insertedRooms.map((r) => r.id as UUID);\n return insertedIds;\n });\n }\n\n /**\n * Asynchronously deletes a room from the database based on the provided parameters.\n * @param {UUID} roomId - The ID of the room to delete.\n * @returns {Promise<void>} A Promise that resolves when the room is deleted.\n */\n async deleteRoom(roomId: UUID): Promise<void> {\n if (!roomId) throw new Error(\"Room ID is required\");\n return this.withDatabase(async () => {\n await this.db.transaction(async (tx) => {\n await tx.delete(roomTable).where(eq(roomTable.id, roomId));\n });\n });\n }\n\n /**\n * Asynchronously retrieves all rooms for a participant from the database based on the provided parameters.\n * @param {UUID} entityId - The ID of the entity to retrieve rooms for.\n * @returns {Promise<UUID[]>} A Promise that resolves to an array of room IDs.\n */\n async getRoomsForParticipant(entityId: UUID): Promise<UUID[]> {\n return this.withDatabase(async () => {\n const result = await this.db\n .select({ roomId: participantTable.roomId })\n .from(participantTable)\n .innerJoin(roomTable, eq(participantTable.roomId, roomTable.id))\n .where(and(eq(participantTable.entityId, entityId), eq(roomTable.agentId, this.agentId)));\n\n return result.map((row) => row.roomId as UUID);\n });\n }\n\n /**\n * Asynchronously retrieves all rooms for a list of participants from the database based on the provided parameters.\n * @param {UUID[]} entityIds - The IDs of the entities to retrieve rooms for.\n * @returns {Promise<UUID[]>} A Promise that resolves to an array of room IDs.\n */\n async getRoomsForParticipants(entityIds: UUID[]): Promise<UUID[]> {\n return this.withDatabase(async () => {\n const result = await this.db\n .selectDistinct({ roomId: participantTable.roomId })\n .from(participantTable)\n .innerJoin(roomTable, eq(participantTable.roomId, roomTable.id))\n .where(\n and(inArray(participantTable.entityId, entityIds), eq(roomTable.agentId, this.agentId))\n );\n\n return result.map((row) => row.roomId as UUID);\n });\n }\n\n /**\n * Asynchronously adds a participant to a room in the database based on the provided parameters.\n * @param {UUID} entityId - The ID of the entity to add to the room.\n * @param {UUID} roomId - The ID of the room to add the entity to.\n * @returns {Promise<boolean>} A Promise that resolves to a boolean indicating whether the participant was added successfully.\n */\n async addParticipant(entityId: UUID, roomId: UUID): Promise<boolean> {\n return this.withDatabase(async () => {\n try {\n await this.db\n .insert(participantTable)\n .values({\n entityId,\n roomId,\n agentId: this.agentId,\n })\n .onConflictDoNothing();\n return true;\n } catch (error) {\n logger.error(\n {\n src: \"plugin:sql\",\n entityId,\n roomId,\n agentId: this.agentId,\n error: error instanceof Error ? error.message : String(error),\n },\n \"Failed to add participant to room\"\n );\n return false;\n }\n });\n }\n\n async addParticipantsRoom(entityIds: UUID[], roomId: UUID): Promise<boolean> {\n return this.withDatabase(async () => {\n try {\n const values = entityIds.map((id) => ({\n entityId: id,\n roomId,\n agentId: this.agentId,\n }));\n await this.db.insert(participantTable).values(values).onConflictDoNothing().execute();\n return true;\n } catch (error) {\n logger.error(\n {\n src: \"plugin:sql\",\n roomId,\n agentId: this.agentId,\n error: error instanceof Error ? error.message : String(error),\n },\n \"Failed to add participants to room\"\n );\n return false;\n }\n });\n }\n\n /**\n * Asynchronously removes a participant from a room in the database based on the provided parameters.\n * @param {UUID} entityId - The ID of the entity to remove from the room.\n * @param {UUID} roomId - The ID of the room to remove the entity from.\n * @returns {Promise<boolean>} A Promise that resolves to a boolean indicating whether the participant was removed successfully.\n */\n async removeParticipant(entityId: UUID, roomId: UUID): Promise<boolean> {\n return this.withDatabase(async () => {\n try {\n const result = await this.db.transaction(async (tx) => {\n return await tx\n .delete(participantTable)\n .where(\n and(eq(participantTable.entityId, entityId), eq(participantTable.roomId, roomId))\n )\n .returning();\n });\n\n const removed = result.length > 0;\n return removed;\n } catch (error) {\n logger.error(\n {\n src: \"plugin:sql\",\n entityId,\n roomId,\n error: error instanceof Error ? error.message : String(error),\n },\n \"Failed to remove participant from room\"\n );\n return false;\n }\n });\n }\n\n /**\n * Asynchronously retrieves all participants for an entity from the database based on the provided parameters.\n * @param {UUID} entityId - The ID of the entity to retrieve participants for.\n * @returns {Promise<Participant[]>} A Promise that resolves to an array of participants.\n */\n async getParticipantsForEntity(entityId: UUID): Promise<Participant[]> {\n return this.withDatabase(async () => {\n const result = await this.db\n .select({\n id: participantTable.id,\n entityId: participantTable.entityId,\n roomId: participantTable.roomId,\n })\n .from(participantTable)\n .where(eq(participantTable.entityId, entityId));\n\n const entities = await this.getEntitiesByIds([entityId]);\n\n if (!entities || !entities.length) {\n return [];\n }\n\n return result.map((row) => ({\n id: row.id as UUID,\n entity: entities[0],\n }));\n });\n }\n\n /**\n * Asynchronously retrieves all participants for a room from the database based on the provided parameters.\n * @param {UUID} roomId - The ID of the room to retrieve participants for.\n * @returns {Promise<UUID[]>} A Promise that resolves to an array of entity IDs.\n */\n async getParticipantsForRoom(roomId: UUID): Promise<UUID[]> {\n return this.withDatabase(async () => {\n const result = await this.db\n .select({ entityId: participantTable.entityId })\n .from(participantTable)\n .where(eq(participantTable.roomId, roomId));\n\n return result.map((row) => row.entityId as UUID);\n });\n }\n\n /**\n * Check if an entity is a participant in a specific room/channel.\n * More efficient than getParticipantsForRoom when only checking membership.\n * @param {UUID} roomId - The ID of the room to check.\n * @param {UUID} entityId - The ID of the entity to check.\n * @returns {Promise<boolean>} A Promise that resolves to true if entity is a participant.\n */\n async isRoomParticipant(roomId: UUID, entityId: UUID): Promise<boolean> {\n return this.withDatabase(async () => {\n const result = await this.db\n .select()\n .from(participantTable)\n .where(and(eq(participantTable.roomId, roomId), eq(participantTable.entityId, entityId)))\n .limit(1);\n\n return result.length > 0;\n });\n }\n\n /**\n * Asynchronously retrieves the user state for a participant in a room from the database based on the provided parameters.\n * @param {UUID} roomId - The ID of the room to retrieve the participant's user state for.\n * @param {UUID} entityId - The ID of the entity to retrieve the user state for.\n * @returns {Promise<\"FOLLOWED\" | \"MUTED\" | null>} A Promise that resolves to the participant's user state.\n */\n async getParticipantUserState(\n roomId: UUID,\n entityId: UUID\n ): Promise<\"FOLLOWED\" | \"MUTED\" | null> {\n return this.withDatabase(async () => {\n const result = await this.db\n .select({ roomState: participantTable.roomState })\n .from(participantTable)\n .where(\n and(\n eq(participantTable.roomId, roomId),\n eq(participantTable.entityId, entityId),\n eq(participantTable.agentId, this.agentId)\n )\n )\n .limit(1);\n\n const result0 = result[0];\n return (result0?.roomState as \"FOLLOWED\" | \"MUTED\" | null) ?? null;\n });\n }\n\n /**\n * Asynchronously sets the user state for a participant in a room in the database based on the provided parameters.\n * @param {UUID} roomId - The ID of the room to set the participant's user state for.\n * @param {UUID} entityId - The ID of the entity to set the user state for.\n * @param {string} state - The state to set the participant's user state to.\n * @returns {Promise<void>} A Promise that resolves when the participant's user state is set.\n */\n async setParticipantUserState(\n roomId: UUID,\n entityId: UUID,\n state: \"FOLLOWED\" | \"MUTED\" | null\n ): Promise<void> {\n return this.withDatabase(async () => {\n try {\n await this.db.transaction(async (tx) => {\n await tx\n .update(participantTable)\n .set({ roomState: state })\n .where(\n and(\n eq(participantTable.roomId, roomId),\n eq(participantTable.entityId, entityId),\n eq(participantTable.agentId, this.agentId)\n )\n );\n });\n } catch (error) {\n logger.error(\n {\n src: \"plugin:sql\",\n roomId,\n entityId,\n state,\n error: error instanceof Error ? error.message : String(error),\n },\n \"Failed to set participant follow state\"\n );\n throw error;\n }\n });\n }\n\n /**\n * Asynchronously creates a new relationship in the database based on the provided parameters.\n * @param {Object} params - The parameters for creating a new relationship.\n * @param {UUID} params.sourceEntityId - The ID of the source entity.\n * @param {UUID} params.targetEntityId - The ID of the target entity.\n * @param {string[]} [params.tags] - The tags for the relationship.\n * @param {Object} [params.metadata] - The metadata for the relationship.\n * @returns {Promise<boolean>} A Promise that resolves to a boolean indicating whether the relationship was created successfully.\n */\n async createRelationship(params: {\n sourceEntityId: UUID;\n targetEntityId: UUID;\n tags?: string[];\n metadata?: { [key: string]: unknown };\n }): Promise<boolean> {\n return this.withDatabase(async () => {\n const id = v4();\n const saveParams = {\n id,\n sourceEntityId: params.sourceEntityId,\n targetEntityId: params.targetEntityId,\n agentId: this.agentId,\n tags: params.tags || [],\n metadata: params.metadata || {},\n };\n try {\n await this.db.insert(relationshipTable).values(saveParams);\n return true;\n } catch (error) {\n logger.error(\n {\n src: \"plugin:sql\",\n agentId: this.agentId,\n error: error instanceof Error ? error.message : String(error),\n saveParams,\n },\n \"Error creating relationship\"\n );\n return false;\n }\n });\n }\n\n /**\n * Asynchronously updates an existing relationship in the database based on the provided parameters.\n * @param {Relationship} relationship - The relationship object to update.\n * @returns {Promise<void>} A Promise that resolves when the relationship is updated.\n */\n async updateRelationship(relationship: Relationship): Promise<void> {\n return this.withDatabase(async () => {\n try {\n await this.db\n .update(relationshipTable)\n .set({\n tags: relationship.tags || [],\n metadata: relationship.metadata || {},\n })\n .where(eq(relationshipTable.id, relationship.id));\n } catch (error) {\n logger.error(\n {\n src: \"plugin:sql\",\n agentId: this.agentId,\n error: error instanceof Error ? error.message : String(error),\n relationshipId: relationship.id,\n },\n \"Error updating relationship\"\n );\n throw error;\n }\n });\n }\n\n /**\n * Asynchronously retrieves a relationship from the database based on the provided parameters.\n * @param {Object} params - The parameters for retrieving a relationship.\n * @param {UUID} params.sourceEntityId - The ID of the source entity.\n * @param {UUID} params.targetEntityId - The ID of the target entity.\n * @returns {Promise<Relationship | null>} A Promise that resolves to the relationship if found, null otherwise.\n */\n async getRelationship(params: {\n sourceEntityId: UUID;\n targetEntityId: UUID;\n }): Promise<Relationship | null> {\n return this.withDatabase(async () => {\n const { sourceEntityId, targetEntityId } = params;\n const result = await this.db\n .select()\n .from(relationshipTable)\n .where(\n and(\n eq(relationshipTable.sourceEntityId, sourceEntityId),\n eq(relationshipTable.targetEntityId, targetEntityId)\n )\n );\n if (result.length === 0) return null;\n const relationship = result[0];\n return {\n ...relationship,\n id: relationship.id as UUID,\n sourceEntityId: relationship.sourceEntityId as UUID,\n targetEntityId: relationship.targetEntityId as UUID,\n agentId: relationship.agentId as UUID,\n tags: (relationship.tags ?? []) as string[],\n metadata: (relationship.metadata ?? {}) as Metadata,\n createdAt: relationship.createdAt.toISOString(),\n };\n });\n }\n\n /**\n * Asynchronously retrieves relationships from the database based on the provided parameters.\n * @param {Object} params - The parameters for retrieving relationships.\n * @param {UUID} params.entityId - The ID of the entity to retrieve relationships for.\n * @param {string[]} [params.tags] - The tags to filter relationships by.\n * @returns {Promise<Relationship[]>} A Promise that resolves to an array of relationships.\n */\n async getRelationships(params: { entityId: UUID; tags?: string[] }): Promise<Relationship[]> {\n return this.withDatabase(async () => {\n const { entityId, tags } = params;\n\n let query: SQL;\n\n if (tags && tags.length > 0) {\n query = sql`\n SELECT * FROM ${relationshipTable}\n WHERE (${relationshipTable.sourceEntityId} = ${entityId} OR ${relationshipTable.targetEntityId} = ${entityId})\n AND ${relationshipTable.tags} && CAST(ARRAY[${sql.join(tags, sql`, `)}] AS text[])\n `;\n } else {\n query = sql`\n SELECT * FROM ${relationshipTable}\n WHERE ${relationshipTable.sourceEntityId} = ${entityId} OR ${relationshipTable.targetEntityId} = ${entityId}\n `;\n }\n\n const result = await this.db.execute(query);\n\n return result.rows.map((relationship: Record<string, unknown>) => ({\n ...relationship,\n id: relationship.id as UUID,\n sourceEntityId: (relationship.source_entity_id || relationship.sourceEntityId) as UUID,\n targetEntityId: (relationship.target_entity_id || relationship.targetEntityId) as UUID,\n agentId: (relationship.agent_id || relationship.agentId) as UUID,\n tags: (relationship.tags ?? []) as string[],\n metadata: (relationship.metadata ?? {}) as Metadata,\n createdAt:\n relationship.created_at || relationship.createdAt\n ? (relationship.created_at || relationship.createdAt) instanceof Date\n ? ((relationship.created_at || relationship.createdAt) as Date).toISOString()\n : new Date(\n (relationship.created_at as string) || (relationship.createdAt as string)\n ).toISOString()\n : new Date().toISOString(),\n }));\n });\n }\n\n /**\n * Asynchronously retrieves a cache value from the database based on the provided key.\n * @param {string} key - The key to retrieve the cache value for.\n * @returns {Promise<T | undefined>} A Promise that resolves to the cache value if found, undefined otherwise.\n */\n async getCache<T>(key: string): Promise<T | undefined> {\n return this.withDatabase(async () => {\n try {\n const result = await this.db\n .select({ value: cacheTable.value })\n .from(cacheTable)\n .where(and(eq(cacheTable.agentId, this.agentId), eq(cacheTable.key, key)))\n .limit(1);\n\n if (result && result.length > 0 && result[0]) {\n return result[0].value as T | undefined;\n }\n\n return undefined;\n } catch (error) {\n logger.error(\n {\n src: \"plugin:sql\",\n agentId: this.agentId,\n error: error instanceof Error ? error.message : String(error),\n key,\n },\n \"Error fetching cache\"\n );\n return undefined;\n }\n });\n }\n\n /**\n * Asynchronously sets a cache value in the database based on the provided key and value.\n * @param {string} key - The key to set the cache value for.\n * @param {T} value - The value to set in the cache.\n * @returns {Promise<boolean>} A Promise that resolves to a boolean indicating whether the cache value was set successfully.\n */\n async setCache<T>(key: string, value: T): Promise<boolean> {\n return this.withDatabase(async () => {\n try {\n await this.db\n .insert(cacheTable)\n .values({\n key: key,\n agentId: this.agentId,\n value: value,\n })\n .onConflictDoUpdate({\n target: [cacheTable.key, cacheTable.agentId],\n set: {\n value: value,\n },\n });\n\n return true;\n } catch (error) {\n logger.error(\n {\n src: \"plugin:sql\",\n agentId: this.agentId,\n error: error instanceof Error ? error.message : String(error),\n key,\n },\n \"Error setting cache\"\n );\n return false;\n }\n });\n }\n\n /**\n * Asynchronously deletes a cache value from the database based on the provided key.\n * @param {string} key - The key to delete the cache value for.\n * @returns {Promise<boolean>} A Promise that resolves to a boolean indicating whether the cache value was deleted successfully.\n */\n async deleteCache(key: string): Promise<boolean> {\n return this.withDatabase(async () => {\n try {\n await this.db.transaction(async (tx) => {\n await tx\n .delete(cacheTable)\n .where(and(eq(cacheTable.agentId, this.agentId), eq(cacheTable.key, key)));\n });\n return true;\n } catch (error) {\n logger.error(\n {\n src: \"plugin:sql\",\n agentId: this.agentId,\n error: error instanceof Error ? error.message : String(error),\n key,\n },\n \"Error deleting cache\"\n );\n return false;\n }\n });\n }\n\n /**\n * Asynchronously creates a new world in the database based on the provided parameters.\n * @param {World} world - The world object to create.\n * @returns {Promise<UUID>} A Promise that resolves to the ID of the created world.\n */\n async createWorld(world: World): Promise<UUID> {\n return this.withDatabase(async () => {\n const newWorldId = world.id || (v4() as UUID);\n await this.db.insert(worldTable).values({\n ...world,\n id: newWorldId,\n name: world.name || \"\",\n });\n return newWorldId;\n });\n }\n\n /**\n * Asynchronously retrieves a world from the database based on the provided parameters.\n * @param {UUID} id - The ID of the world to retrieve.\n * @returns {Promise<World | null>} A Promise that resolves to the world if found, null otherwise.\n */\n async getWorld(id: UUID): Promise<World | null> {\n return this.withDatabase(async () => {\n const result = await this.db.select().from(worldTable).where(eq(worldTable.id, id));\n return result.length > 0 ? (result[0] as World) : null;\n });\n }\n\n /**\n * Asynchronously retrieves all worlds from the database based on the provided parameters.\n * @returns {Promise<World[]>} A Promise that resolves to an array of worlds.\n */\n async getAllWorlds(): Promise<World[]> {\n return this.withDatabase(async () => {\n const result = await this.db\n .select()\n .from(worldTable)\n .where(eq(worldTable.agentId, this.agentId));\n return result as World[];\n });\n }\n\n /**\n * Asynchronously updates an existing world in the database based on the provided parameters.\n * @param {World} world - The world object to update.\n * @returns {Promise<void>} A Promise that resolves when the world is updated.\n */\n async updateWorld(world: World): Promise<void> {\n return this.withDatabase(async () => {\n await this.db.update(worldTable).set(world).where(eq(worldTable.id, world.id));\n });\n }\n\n /**\n * Asynchronously removes a world from the database based on the provided parameters.\n * @param {UUID} id - The ID of the world to remove.\n * @returns {Promise<void>} A Promise that resolves when the world is removed.\n */\n async removeWorld(id: UUID): Promise<void> {\n return this.withDatabase(async () => {\n await this.db.delete(worldTable).where(eq(worldTable.id, id));\n });\n }\n\n /**\n * Asynchronously creates a new task in the database based on the provided parameters.\n * @param {Task} task - The task object to create.\n * @returns {Promise<UUID>} A Promise that resolves to the ID of the created task.\n */\n async createTask(task: Task): Promise<UUID> {\n if (!task.worldId) {\n throw new Error(\"worldId is required\");\n }\n return this.withRetry(async () => {\n return this.withDatabase(async () => {\n const now = new Date();\n const metadata = task.metadata || {};\n\n const values = {\n id: task.id as UUID,\n name: task.name,\n description: task.description,\n roomId: task.roomId as UUID,\n worldId: task.worldId as UUID,\n tags: task.tags,\n metadata: metadata,\n createdAt: now,\n updatedAt: now,\n agentId: this.agentId as UUID,\n };\n\n const result = await this.db.insert(taskTable).values(values).returning();\n\n return result[0].id as UUID;\n });\n });\n }\n\n /**\n * Asynchronously retrieves tasks based on specified parameters.\n * @param params Object containing optional roomId, tags, and entityId to filter tasks\n * @returns Promise resolving to an array of Task objects\n */\n async getTasks(params: {\n roomId?: UUID;\n tags?: string[];\n entityId?: UUID; // Added entityId parameter\n }): Promise<Task[]> {\n return this.withRetry(async () => {\n return this.withDatabase(async () => {\n const result = await this.db\n .select()\n .from(taskTable)\n .where(\n and(\n eq(taskTable.agentId, this.agentId),\n ...(params.roomId ? [eq(taskTable.roomId, params.roomId)] : []),\n ...(params.tags && params.tags.length > 0\n ? [\n sql`${taskTable.tags} @> ARRAY[${sql.join(\n params.tags.map((t) => sql`${t}`),\n sql`, `\n )}]::text[]`,\n ]\n : [])\n )\n );\n\n return result.map((row) => ({\n id: row.id as UUID,\n name: row.name,\n description: row.description ?? \"\",\n roomId: row.roomId as UUID,\n worldId: row.worldId as UUID,\n tags: row.tags || [],\n metadata: row.metadata as TaskMetadata,\n }));\n });\n });\n }\n\n /**\n * Asynchronously retrieves a specific task by its name.\n * @param name The name of the task to retrieve\n * @returns Promise resolving to the Task object if found, null otherwise\n */\n async getTasksByName(name: string): Promise<Task[]> {\n return this.withRetry(async () => {\n return this.withDatabase(async () => {\n const result = await this.db\n .select()\n .from(taskTable)\n .where(and(eq(taskTable.name, name), eq(taskTable.agentId, this.agentId)));\n\n return result.map((row) => ({\n id: row.id as UUID,\n name: row.name,\n description: row.description ?? \"\",\n roomId: row.roomId as UUID,\n worldId: row.worldId as UUID,\n tags: row.tags || [],\n metadata: (row.metadata || {}) as TaskMetadata,\n }));\n });\n });\n }\n\n /**\n * Asynchronously retrieves a specific task by its ID.\n * @param id The UUID of the task to retrieve\n * @returns Promise resolving to the Task object if found, null otherwise\n */\n async getTask(id: UUID): Promise<Task | null> {\n return this.withRetry(async () => {\n return this.withDatabase(async () => {\n const result = await this.db\n .select()\n .from(taskTable)\n .where(and(eq(taskTable.id, id), eq(taskTable.agentId, this.agentId)))\n .limit(1);\n\n if (result.length === 0) {\n return null;\n }\n\n const row = result[0];\n return {\n id: row.id as UUID,\n name: row.name,\n description: row.description ?? \"\",\n roomId: row.roomId as UUID,\n worldId: row.worldId as UUID,\n tags: row.tags || [],\n metadata: (row.metadata || {}) as TaskMetadata,\n };\n });\n });\n }\n\n /**\n * Asynchronously updates an existing task in the database.\n * @param id The UUID of the task to update\n * @param task Partial Task object containing the fields to update\n * @returns Promise resolving when the update is complete\n */\n async updateTask(id: UUID, task: Partial<Task>): Promise<void> {\n await this.withRetry(async () => {\n await this.withDatabase(async () => {\n const updateValues: Partial<typeof taskTable.$inferInsert> = {};\n\n // Add fields to update if they exist in the partial task object\n if (task.name !== undefined) updateValues.name = task.name;\n if (task.description !== undefined) updateValues.description = task.description;\n if (task.roomId !== undefined) updateValues.roomId = task.roomId;\n if (task.worldId !== undefined) updateValues.worldId = task.worldId;\n if (task.tags !== undefined) updateValues.tags = task.tags;\n if (task.metadata !== undefined)\n updateValues.metadata = task.metadata as typeof taskTable.$inferInsert.metadata;\n // Handle createdAt if present in the task object (using type assertion for compatibility)\n const taskWithCreatedAt = task as { createdAt?: number | bigint | null };\n if (taskWithCreatedAt.createdAt !== undefined && taskWithCreatedAt.createdAt !== null) {\n const createdAtValue = taskWithCreatedAt.createdAt;\n updateValues.createdAt = new Date(\n typeof createdAtValue === \"bigint\" ? Number(createdAtValue) : createdAtValue\n );\n }\n\n // Always update the updatedAt timestamp as a Date (schema uses Date, not number)\n const dbUpdateValues: Partial<typeof taskTable.$inferInsert> = {\n ...updateValues,\n updatedAt: new Date(),\n };\n\n // Handle metadata updates - just set it directly without merging\n if (task.metadata !== undefined) {\n dbUpdateValues.metadata = task.metadata;\n }\n\n await this.db\n .update(taskTable)\n // createdAt is hella borked, number / Date\n .set(dbUpdateValues)\n .where(and(eq(taskTable.id, id), eq(taskTable.agentId, this.agentId)));\n });\n });\n }\n\n /**\n * Asynchronously deletes a task from the database.\n * @param id The UUID of the task to delete\n * @returns Promise resolving when the deletion is complete\n */\n async deleteTask(id: UUID): Promise<void> {\n return this.withDatabase(async () => {\n await this.db.delete(taskTable).where(eq(taskTable.id, id));\n });\n }\n\n async getMemoriesByWorldId(params: {\n worldId: UUID;\n count?: number;\n tableName?: string;\n }): Promise<Memory[]> {\n return this.withDatabase(async () => {\n // First, get all rooms for the given worldId\n const rooms = await this.db\n .select({ id: roomTable.id })\n .from(roomTable)\n .where(and(eq(roomTable.worldId, params.worldId), eq(roomTable.agentId, this.agentId)));\n\n if (rooms.length === 0) {\n return [];\n }\n\n const roomIds = rooms.map((room) => room.id as UUID);\n\n const memories = await this.getMemoriesByRoomIds({\n roomIds,\n tableName: params.tableName || \"messages\",\n limit: params.count,\n });\n\n return memories;\n });\n }\n\n async deleteRoomsByWorldId(worldId: UUID): Promise<void> {\n return this.withDatabase(async () => {\n const rooms = await this.db\n .select({ id: roomTable.id })\n .from(roomTable)\n .where(and(eq(roomTable.worldId, worldId), eq(roomTable.agentId, this.agentId)));\n\n if (rooms.length === 0) {\n return;\n }\n\n const roomIds = rooms.map((room) => room.id as UUID);\n\n if (roomIds.length > 0) {\n await this.db.delete(logTable).where(inArray(logTable.roomId, roomIds));\n await this.db.delete(participantTable).where(inArray(participantTable.roomId, roomIds));\n\n const memoriesInRooms = await this.db\n .select({ id: memoryTable.id })\n .from(memoryTable)\n .where(inArray(memoryTable.roomId, roomIds));\n const memoryIdsInRooms = memoriesInRooms.map((m) => m.id as UUID);\n\n if (memoryIdsInRooms.length > 0) {\n await this.db\n .delete(embeddingTable)\n .where(inArray(embeddingTable.memoryId, memoryIdsInRooms));\n await this.db.delete(memoryTable).where(inArray(memoryTable.id, memoryIdsInRooms));\n }\n\n await this.db.delete(roomTable).where(inArray(roomTable.id, roomIds));\n\n logger.debug(\n {\n src: \"plugin:sql\",\n worldId,\n roomsDeleted: roomIds.length,\n memoriesDeleted: memoryIdsInRooms.length,\n },\n \"World cleanup completed\"\n );\n }\n });\n }\n\n // Message Server Database Operations\n\n /**\n * Creates a new message server in the central database\n */\n async createMessageServer(data: {\n id?: UUID; // Allow passing a specific ID\n name: string;\n sourceType: string;\n sourceId?: string;\n metadata?: Metadata;\n }): Promise<{\n id: UUID;\n name: string;\n sourceType: string;\n sourceId?: string;\n metadata?: Metadata;\n createdAt: Date;\n updatedAt: Date;\n }> {\n return this.withDatabase(async () => {\n const newId = data.id || (v4() as UUID);\n const now = new Date();\n const serverToInsert = {\n id: newId,\n name: data.name,\n sourceType: data.sourceType,\n sourceId: data.sourceId,\n metadata: data.metadata,\n createdAt: now,\n updatedAt: now,\n };\n\n await this.db.insert(messageServerTable).values(serverToInsert).onConflictDoNothing(); // In case the ID already exists\n\n // If server already existed, fetch it\n if (data.id) {\n const existing = await this.db\n .select()\n .from(messageServerTable)\n .where(eq(messageServerTable.id, data.id))\n .limit(1);\n if (existing.length > 0) {\n return {\n id: existing[0].id as UUID,\n name: existing[0].name,\n sourceType: existing[0].sourceType,\n sourceId: existing[0].sourceId || undefined,\n metadata: (existing[0].metadata || undefined) as Metadata | undefined,\n createdAt: existing[0].createdAt,\n updatedAt: existing[0].updatedAt,\n };\n }\n }\n\n return serverToInsert;\n });\n }\n\n /**\n * Gets all message servers\n */\n async getMessageServers(): Promise<\n Array<{\n id: UUID;\n name: string;\n sourceType: string;\n sourceId?: string;\n metadata?: Metadata;\n createdAt: Date;\n updatedAt: Date;\n }>\n > {\n const result = await this.withDatabase(async () => {\n const results = await this.db.select().from(messageServerTable);\n return results.map((r) => ({\n id: r.id as UUID,\n name: r.name,\n sourceType: r.sourceType,\n sourceId: r.sourceId || undefined,\n metadata: (r.metadata || undefined) as Metadata | undefined,\n createdAt: r.createdAt,\n updatedAt: r.updatedAt,\n }));\n });\n // Guard against null return\n return result || [];\n }\n\n /**\n * Gets a message server by ID\n */\n async getMessageServerById(serverId: UUID): Promise<{\n id: UUID;\n name: string;\n sourceType: string;\n sourceId?: string;\n metadata?: Metadata;\n createdAt: Date;\n updatedAt: Date;\n } | null> {\n return this.withDatabase(async () => {\n const results = await this.db\n .select()\n .from(messageServerTable)\n .where(eq(messageServerTable.id, serverId))\n .limit(1);\n return results.length > 0\n ? {\n id: results[0].id as UUID,\n name: results[0].name,\n sourceType: results[0].sourceType,\n sourceId: results[0].sourceId || undefined,\n metadata: (results[0].metadata || undefined) as Metadata | undefined,\n createdAt: results[0].createdAt,\n updatedAt: results[0].updatedAt,\n }\n : null;\n });\n }\n\n /**\n * Gets a message server by RLS server_id.\n * The server_id column is added dynamically when RLS is enabled.\n */\n async getMessageServerByRlsServerId(rlsServerId: UUID): Promise<{\n id: UUID;\n name: string;\n sourceType: string;\n sourceId?: string;\n metadata?: Metadata;\n createdAt: Date;\n updatedAt: Date;\n } | null> {\n return this.withDatabase(async () => {\n // Use raw SQL since server_id column is dynamically added by RLS and not in Drizzle schema\n const results = await this.db.execute(sql`\n SELECT id, name, source_type, source_id, metadata, created_at, updated_at\n FROM message_servers\n WHERE server_id = ${rlsServerId}\n LIMIT 1\n `);\n\n const rows = results.rows || results;\n return (rows as Record<string, unknown>[]).length > 0\n ? {\n id: (rows as Record<string, unknown>[])[0].id as UUID,\n name: (rows as Record<string, unknown>[])[0].name as string,\n sourceType: (rows as Record<string, unknown>[])[0].source_type as string,\n sourceId: ((rows as Record<string, unknown>[])[0].source_id || undefined) as\n | string\n | undefined,\n metadata: ((rows as Record<string, unknown>[])[0].metadata || undefined) as\n | Metadata\n | undefined,\n createdAt: new Date((rows as Record<string, unknown>[])[0].created_at as string),\n updatedAt: new Date((rows as Record<string, unknown>[])[0].updated_at as string),\n }\n : null;\n });\n }\n\n /**\n * Creates a new channel\n */\n async createChannel(\n data: {\n id?: UUID; // Allow passing a specific ID\n messageServerId: UUID;\n name: string;\n type: string;\n sourceType?: string;\n sourceId?: string;\n topic?: string;\n metadata?: Metadata;\n },\n participantIds?: UUID[]\n ): Promise<{\n id: UUID;\n messageServerId: UUID;\n name: string;\n type: string;\n sourceType?: string;\n sourceId?: string;\n topic?: string;\n metadata?: Metadata;\n createdAt: Date;\n updatedAt: Date;\n }> {\n return this.withDatabase(async () => {\n const newId = data.id || (v4() as UUID);\n const now = new Date();\n const channelToInsert = {\n id: newId,\n messageServerId: data.messageServerId,\n name: data.name,\n type: data.type,\n sourceType: data.sourceType,\n sourceId: data.sourceId,\n topic: data.topic,\n metadata: data.metadata,\n createdAt: now,\n updatedAt: now,\n };\n\n await this.db.transaction(async (tx) => {\n await tx.insert(channelTable).values(channelToInsert);\n\n if (participantIds && participantIds.length > 0) {\n const participantValues = participantIds.map((entityId) => ({\n channelId: newId,\n entityId: entityId,\n }));\n await tx.insert(channelParticipantsTable).values(participantValues).onConflictDoNothing();\n }\n });\n\n return channelToInsert;\n });\n }\n\n /**\n * Gets channels for a message server\n */\n async getChannelsForMessageServer(messageServerId: UUID): Promise<\n Array<{\n id: UUID;\n messageServerId: UUID;\n name: string;\n type: string;\n sourceType?: string;\n sourceId?: string;\n topic?: string;\n metadata?: Metadata;\n createdAt: Date;\n updatedAt: Date;\n }>\n > {\n return this.withDatabase(async () => {\n const results = await this.db\n .select()\n .from(channelTable)\n .where(eq(channelTable.messageServerId, messageServerId));\n return results.map((r) => ({\n id: r.id as UUID,\n messageServerId: r.messageServerId as UUID,\n name: r.name,\n type: r.type,\n sourceType: r.sourceType || undefined,\n sourceId: r.sourceId || undefined,\n topic: r.topic || undefined,\n metadata: (r.metadata || undefined) as Metadata | undefined,\n createdAt: r.createdAt,\n updatedAt: r.updatedAt,\n }));\n });\n }\n\n /**\n * Gets channel details\n */\n async getChannelDetails(channelId: UUID): Promise<{\n id: UUID;\n messageServerId: UUID;\n name: string;\n type: string;\n sourceType?: string;\n sourceId?: string;\n topic?: string;\n metadata?: Metadata;\n createdAt: Date;\n updatedAt: Date;\n } | null> {\n return this.withDatabase(async () => {\n const results = await this.db\n .select()\n .from(channelTable)\n .where(eq(channelTable.id, channelId))\n .limit(1);\n return results.length > 0\n ? {\n id: results[0].id as UUID,\n messageServerId: results[0].messageServerId as UUID,\n name: results[0].name,\n type: results[0].type,\n sourceType: results[0].sourceType || undefined,\n sourceId: results[0].sourceId || undefined,\n topic: results[0].topic || undefined,\n metadata: (results[0].metadata || undefined) as Metadata | undefined,\n createdAt: results[0].createdAt,\n updatedAt: results[0].updatedAt,\n }\n : null;\n });\n }\n\n /**\n * Creates a message\n */\n async createMessage(data: {\n channelId: UUID;\n authorId: UUID;\n content: string;\n rawMessage?: Record<string, unknown>;\n sourceType?: string;\n sourceId?: string;\n metadata?: Metadata;\n inReplyToRootMessageId?: UUID;\n messageId?: UUID;\n }): Promise<{\n id: UUID;\n channelId: UUID;\n authorId: UUID;\n content: string;\n rawMessage?: Record<string, unknown>;\n sourceType?: string;\n sourceId?: string;\n metadata?: Metadata;\n inReplyToRootMessageId?: UUID;\n createdAt: Date;\n updatedAt: Date;\n }> {\n return this.withDatabase(async () => {\n const newId = data.messageId || (v4() as UUID);\n const now = new Date();\n const messageToInsert = {\n id: newId,\n channelId: data.channelId,\n authorId: data.authorId,\n content: data.content,\n rawMessage: data.rawMessage,\n sourceType: data.sourceType,\n sourceId: data.sourceId,\n metadata: data.metadata,\n inReplyToRootMessageId: data.inReplyToRootMessageId,\n createdAt: now,\n updatedAt: now,\n };\n\n await this.db.insert(messageTable).values(messageToInsert);\n return messageToInsert;\n });\n }\n\n async getMessageById(id: UUID): Promise<{\n id: UUID;\n channelId: UUID;\n authorId: UUID;\n content: string;\n rawMessage?: Record<string, unknown>;\n sourceType?: string;\n sourceId?: string;\n metadata?: Metadata;\n inReplyToRootMessageId?: UUID;\n createdAt: Date;\n updatedAt: Date;\n } | null> {\n return this.withDatabase(async () => {\n const rows = await this.db\n .select()\n .from(messageTable)\n .where(eq(messageTable.id, id))\n .limit(1);\n if (!rows || rows.length === 0) return null;\n const row = rows[0];\n return {\n id: row.id as UUID,\n channelId: row.channelId as UUID,\n authorId: row.authorId as UUID,\n content: row.content,\n rawMessage: row.rawMessage || undefined,\n sourceType: row.sourceType || undefined,\n sourceId: row.sourceId || undefined,\n metadata: (row.metadata || undefined) as Metadata | undefined,\n inReplyToRootMessageId: (row.inReplyToRootMessageId || undefined) as UUID | undefined,\n createdAt: row.createdAt,\n updatedAt: row.updatedAt,\n };\n });\n }\n\n async updateMessage(\n id: UUID,\n patch: {\n content?: string;\n rawMessage?: Record<string, unknown>;\n sourceType?: string;\n sourceId?: string;\n metadata?: Metadata;\n inReplyToRootMessageId?: UUID;\n }\n ): Promise<{\n id: UUID;\n channelId: UUID;\n authorId: UUID;\n content: string;\n rawMessage?: Record<string, unknown>;\n sourceType?: string;\n sourceId?: string;\n metadata?: Metadata;\n inReplyToRootMessageId?: UUID;\n createdAt: Date;\n updatedAt: Date;\n } | null> {\n return this.withDatabase(async () => {\n const existing = await this.getMessageById(id);\n if (!existing) return null;\n\n const updatedAt = new Date();\n const next = {\n content: patch.content ?? existing.content,\n rawMessage: patch.rawMessage ?? existing.rawMessage,\n sourceType: patch.sourceType ?? existing.sourceType,\n sourceId: patch.sourceId ?? existing.sourceId,\n metadata: patch.metadata ?? existing.metadata,\n inReplyToRootMessageId: patch.inReplyToRootMessageId ?? existing.inReplyToRootMessageId,\n updatedAt,\n };\n\n await this.db.update(messageTable).set(next).where(eq(messageTable.id, id));\n\n // Return merged object\n return {\n ...existing,\n ...next,\n };\n });\n }\n\n /**\n * Gets messages for a channel\n */\n async getMessagesForChannel(\n channelId: UUID,\n limit: number = 50,\n beforeTimestamp?: Date\n ): Promise<\n Array<{\n id: UUID;\n channelId: UUID;\n authorId: UUID;\n content: string;\n rawMessage?: Record<string, unknown>;\n sourceType?: string;\n sourceId?: string;\n metadata?: Metadata;\n inReplyToRootMessageId?: UUID;\n createdAt: Date;\n updatedAt: Date;\n }>\n > {\n return this.withDatabase(async () => {\n const conditions = [eq(messageTable.channelId, channelId)];\n if (beforeTimestamp) {\n conditions.push(lt(messageTable.createdAt, beforeTimestamp));\n }\n\n const query = this.db\n .select()\n .from(messageTable)\n .where(and(...conditions))\n .orderBy(desc(messageTable.createdAt))\n .limit(limit);\n\n const results = await query;\n return results.map((r) => ({\n id: r.id as UUID,\n channelId: r.channelId as UUID,\n authorId: r.authorId as UUID,\n content: r.content,\n rawMessage: r.rawMessage || undefined,\n sourceType: r.sourceType || undefined,\n sourceId: r.sourceId || undefined,\n metadata: r.metadata || undefined,\n inReplyToRootMessageId: r.inReplyToRootMessageId as UUID | undefined,\n createdAt: r.createdAt,\n updatedAt: r.updatedAt,\n }));\n });\n }\n\n /**\n * Deletes a message\n */\n async deleteMessage(messageId: UUID): Promise<void> {\n return this.withDatabase(async () => {\n await this.db.delete(messageTable).where(eq(messageTable.id, messageId));\n });\n }\n\n /**\n * Updates a channel\n */\n async updateChannel(\n channelId: UUID,\n updates: {\n name?: string;\n participantCentralUserIds?: UUID[];\n metadata?: Metadata;\n }\n ): Promise<{\n id: UUID;\n messageServerId: UUID;\n name: string;\n type: string;\n sourceType?: string;\n sourceId?: string;\n topic?: string;\n metadata?: Metadata;\n createdAt: Date;\n updatedAt: Date;\n }> {\n return this.withDatabase(async () => {\n const now = new Date();\n\n await this.db.transaction(async (tx) => {\n // Update channel details\n const updateData: Record<string, unknown> = { updatedAt: now };\n if (updates.name !== undefined) updateData.name = updates.name;\n if (updates.metadata !== undefined) updateData.metadata = updates.metadata;\n\n await tx.update(channelTable).set(updateData).where(eq(channelTable.id, channelId));\n\n // Update participants if provided\n if (updates.participantCentralUserIds !== undefined) {\n // Remove existing participants\n await tx\n .delete(channelParticipantsTable)\n .where(eq(channelParticipantsTable.channelId, channelId));\n\n // Add new participants\n if (updates.participantCentralUserIds.length > 0) {\n const participantValues = updates.participantCentralUserIds.map((entityId) => ({\n channelId: channelId,\n entityId: entityId,\n }));\n await tx\n .insert(channelParticipantsTable)\n .values(participantValues)\n .onConflictDoNothing();\n }\n }\n });\n\n // Return updated channel details\n const updatedChannel = await this.getChannelDetails(channelId);\n if (!updatedChannel) {\n throw new Error(`Channel ${channelId} not found after update`);\n }\n return updatedChannel;\n });\n }\n\n /**\n * Deletes a channel and all its associated data\n */\n async deleteChannel(channelId: UUID): Promise<void> {\n return this.withDatabase(async () => {\n await this.db.transaction(async (tx) => {\n // Delete all messages in the channel (cascade delete will handle this, but explicit is better)\n await tx.delete(messageTable).where(eq(messageTable.channelId, channelId));\n\n // Delete all participants (cascade delete will handle this, but explicit is better)\n await tx\n .delete(channelParticipantsTable)\n .where(eq(channelParticipantsTable.channelId, channelId));\n\n // Delete the channel itself\n await tx.delete(channelTable).where(eq(channelTable.id, channelId));\n });\n });\n }\n\n /**\n * Adds participants to a channel\n */\n async addChannelParticipants(channelId: UUID, entityIds: UUID[]): Promise<void> {\n return this.withDatabase(async () => {\n if (!entityIds || entityIds.length === 0) return;\n\n const participantValues = entityIds.map((entityId) => ({\n channelId: channelId,\n entityId: entityId,\n }));\n\n await this.db\n .insert(channelParticipantsTable)\n .values(participantValues)\n .onConflictDoNothing();\n });\n }\n\n /**\n * Gets participants for a channel\n */\n async getChannelParticipants(channelId: UUID): Promise<UUID[]> {\n return this.withDatabase(async () => {\n const results = await this.db\n .select({ entityId: channelParticipantsTable.entityId })\n .from(channelParticipantsTable)\n .where(eq(channelParticipantsTable.channelId, channelId));\n\n return results.map((r) => r.entityId as UUID);\n });\n }\n\n /**\n * Check if an entity is a participant in a specific messaging channel.\n * @param {UUID} channelId - The ID of the channel to check.\n * @param {UUID} entityId - The ID of the entity to check.\n * @returns {Promise<boolean>} A Promise that resolves to true if entity is a participant.\n */\n async isChannelParticipant(channelId: UUID, entityId: UUID): Promise<boolean> {\n return this.withDatabase(async () => {\n const result = await this.db\n .select()\n .from(channelParticipantsTable)\n .where(\n and(\n eq(channelParticipantsTable.channelId, channelId),\n eq(channelParticipantsTable.entityId, entityId)\n )\n )\n .limit(1);\n\n return result.length > 0;\n });\n }\n\n /**\n * Adds an agent to a message server (Discord/Telegram server)\n */\n async addAgentToMessageServer(messageServerId: UUID, agentId: UUID): Promise<void> {\n return this.withDatabase(async () => {\n await this.db\n .insert(messageServerAgentsTable)\n .values({\n messageServerId,\n agentId,\n })\n .onConflictDoNothing();\n });\n }\n\n /**\n * Gets agents for a message server (Discord/Telegram server)\n */\n async getAgentsForMessageServer(messageServerId: UUID): Promise<UUID[]> {\n return this.withDatabase(async () => {\n const results = await this.db\n .select({ agentId: messageServerAgentsTable.agentId })\n .from(messageServerAgentsTable)\n .where(eq(messageServerAgentsTable.messageServerId, messageServerId));\n\n return results.map((r) => r.agentId as UUID);\n });\n }\n\n /**\n * Removes an agent from a message server (Discord/Telegram server)\n */\n async removeAgentFromMessageServer(messageServerId: UUID, agentId: UUID): Promise<void> {\n return this.withDatabase(async () => {\n await this.db\n .delete(messageServerAgentsTable)\n .where(\n and(\n eq(messageServerAgentsTable.messageServerId, messageServerId),\n eq(messageServerAgentsTable.agentId, agentId)\n )\n );\n });\n }\n\n /**\n * Finds or creates a DM channel between two users\n */\n async findOrCreateDmChannel(\n user1Id: UUID,\n user2Id: UUID,\n messageServerId: UUID\n ): Promise<{\n id: UUID;\n messageServerId: UUID;\n name: string;\n type: string;\n sourceType?: string;\n sourceId?: string;\n topic?: string;\n metadata?: Metadata;\n createdAt: Date;\n updatedAt: Date;\n }> {\n return this.withDatabase(async () => {\n const ids = [user1Id, user2Id].sort();\n const dmChannelName = `DM-${ids[0]}-${ids[1]}`;\n\n const existingChannels = await this.db\n .select()\n .from(channelTable)\n .where(\n and(\n eq(channelTable.type, ChannelType.DM),\n eq(channelTable.name, dmChannelName),\n eq(channelTable.messageServerId, messageServerId)\n )\n )\n .limit(1);\n\n if (existingChannels.length > 0) {\n return {\n id: existingChannels[0].id as UUID,\n messageServerId: existingChannels[0].messageServerId as UUID,\n name: existingChannels[0].name,\n type: existingChannels[0].type,\n sourceType: existingChannels[0].sourceType || undefined,\n sourceId: existingChannels[0].sourceId || undefined,\n topic: existingChannels[0].topic || undefined,\n metadata: (existingChannels[0].metadata || undefined) as Metadata | undefined,\n createdAt: existingChannels[0].createdAt,\n updatedAt: existingChannels[0].updatedAt,\n };\n }\n\n // Create new DM channel\n return this.createChannel(\n {\n messageServerId,\n name: dmChannelName,\n type: ChannelType.DM,\n metadata: { user1: ids[0], user2: ids[1] },\n },\n ids\n );\n });\n }\n}\n\n// Import tables at the end to avoid circular dependencies\n",
121
- "import { VECTOR_DIMS } from \"@elizaos/core\";\nimport { relations, sql } from \"drizzle-orm\";\nimport { check, foreignKey, index, pgTable, timestamp, uuid, vector } from \"drizzle-orm/pg-core\";\nimport { memoryTable } from \"./memory\";\n\nexport const DIMENSION_MAP = {\n [VECTOR_DIMS.SMALL]: \"dim384\",\n [VECTOR_DIMS.MEDIUM]: \"dim512\",\n [VECTOR_DIMS.LARGE]: \"dim768\",\n [VECTOR_DIMS.XL]: \"dim1024\",\n [VECTOR_DIMS.XXL]: \"dim1536\",\n [VECTOR_DIMS.XXXL]: \"dim3072\",\n} as const;\n\n/**\n * Definition of the embeddings table in the database.\n * Contains columns for ID, Memory ID, Creation Timestamp, and multiple vector dimensions.\n */\nexport const embeddingTable = pgTable(\n \"embeddings\",\n {\n id: uuid(\"id\").primaryKey().defaultRandom().notNull(),\n memoryId: uuid(\"memory_id\").references(() => memoryTable.id, {\n onDelete: \"cascade\",\n }),\n createdAt: timestamp(\"created_at\").default(sql`now()`).notNull(),\n dim384: vector(\"dim_384\", { dimensions: VECTOR_DIMS.SMALL }),\n dim512: vector(\"dim_512\", { dimensions: VECTOR_DIMS.MEDIUM }),\n dim768: vector(\"dim_768\", { dimensions: VECTOR_DIMS.LARGE }),\n dim1024: vector(\"dim_1024\", { dimensions: VECTOR_DIMS.XL }),\n dim1536: vector(\"dim_1536\", { dimensions: VECTOR_DIMS.XXL }),\n dim3072: vector(\"dim_3072\", { dimensions: VECTOR_DIMS.XXXL }),\n },\n (table) => [\n check(\"embedding_source_check\", sql`\"memory_id\" IS NOT NULL`),\n index(\"idx_embedding_memory\").on(table.memoryId),\n foreignKey({\n name: \"fk_embedding_memory\",\n columns: [table.memoryId],\n foreignColumns: [memoryTable.id],\n }).onDelete(\"cascade\"),\n ]\n);\n\n/**\n * Defines the possible values for the Embedding Dimension Column.\n * It can be \"dim384\", \"dim512\", \"dim768\", \"dim1024\", \"dim1536\", or \"dim3072\".\n */\nexport type EmbeddingDimensionColumn =\n | \"dim384\"\n | \"dim512\"\n | \"dim768\"\n | \"dim1024\"\n | \"dim1536\"\n | \"dim3072\";\n\n/**\n * Retrieve the type of a specific column in the EmbeddingTable based on the EmbeddingDimensionColumn key.\n */\nexport type EmbeddingTableColumn = (typeof embeddingTable._.columns)[EmbeddingDimensionColumn];\n\n// Relations - defined here to avoid circular dependency with memory.ts\nexport const memoryRelations = relations(memoryTable, ({ one }) => ({\n embedding: one(embeddingTable),\n}));\n",
122
- "import { sql } from \"drizzle-orm\";\nimport {\n boolean,\n check,\n foreignKey,\n index,\n jsonb,\n pgTable,\n text,\n timestamp,\n uuid,\n} from \"drizzle-orm/pg-core\";\nimport { agentTable } from \"./agent\";\nimport { entityTable } from \"./entity\";\nimport { roomTable } from \"./room\";\n\n/**\n * Definition of the memory table in the database.\n *\n * @param {string} tableName - The name of the table.\n * @param {object} columns - An object containing the column definitions.\n * @param {function} indexes - A function that defines the indexes for the table.\n * @returns {object} - The memory table object.\n */\nexport const memoryTable = pgTable(\n \"memories\",\n {\n id: uuid(\"id\").primaryKey().notNull(),\n type: text(\"type\").notNull(),\n createdAt: timestamp(\"created_at\").default(sql`now()`).notNull(),\n content: jsonb(\"content\").notNull(),\n entityId: uuid(\"entity_id\").references(() => entityTable.id, {\n onDelete: \"cascade\",\n }),\n agentId: uuid(\"agent_id\")\n .references(() => agentTable.id, {\n onDelete: \"cascade\",\n })\n .notNull(),\n roomId: uuid(\"room_id\").references(() => roomTable.id, {\n onDelete: \"cascade\",\n }),\n worldId: uuid(\"world_id\"),\n // .references(() => worldTable.id, {\n // onDelete: 'set null',\n // }),\n unique: boolean(\"unique\").default(true).notNull(),\n metadata: jsonb(\"metadata\").default({}).notNull(),\n },\n (table) => [\n index(\"idx_memories_type_room\").on(table.type, table.roomId),\n index(\"idx_memories_world_id\").on(table.worldId),\n foreignKey({\n name: \"fk_room\",\n columns: [table.roomId],\n foreignColumns: [roomTable.id],\n }).onDelete(\"cascade\"),\n foreignKey({\n name: \"fk_user\",\n columns: [table.entityId],\n foreignColumns: [entityTable.id],\n }).onDelete(\"cascade\"),\n foreignKey({\n name: \"fk_agent\",\n columns: [table.agentId],\n foreignColumns: [agentTable.id],\n }).onDelete(\"cascade\"),\n // foreignKey({\n // name: 'fk_world',\n // columns: [table.worldId],\n // foreignColumns: [worldTable.id],\n // }).onDelete('set null'),\n index(\"idx_memories_metadata_type\").on(sql`((metadata->>'type'))`),\n index(\"idx_memories_document_id\").on(sql`((metadata->>'documentId'))`),\n index(\"idx_fragments_order\").on(\n sql`((metadata->>'documentId'))`,\n sql`((metadata->>'position'))`\n ),\n check(\n \"fragment_metadata_check\",\n sql`\n CASE \n WHEN metadata->>'type' = 'fragment' THEN\n metadata ? 'documentId' AND \n metadata ? 'position'\n ELSE true\n END\n `\n ),\n check(\n \"document_metadata_check\",\n sql`\n CASE \n WHEN metadata->>'type' = 'document' THEN\n metadata ? 'timestamp'\n ELSE true\n END\n `\n ),\n ]\n);\n\n// Relations are defined in embedding.ts to avoid circular dependency\n",
123
- "import type { Metadata } from \"@elizaos/core\";\nimport { sql } from \"drizzle-orm\";\nimport { jsonb, pgTable, text, timestamp, unique, uuid } from \"drizzle-orm/pg-core\";\nimport { agentTable } from \"./agent\";\n\n/**\n * Represents an entity table in the database.\n * Includes columns for id, agentId, createdAt, names, and metadata.\n */\nexport const entityTable = pgTable(\n \"entities\",\n {\n id: uuid(\"id\").notNull().primaryKey(),\n agentId: uuid(\"agent_id\")\n .notNull()\n .references(() => agentTable.id, {\n onDelete: \"cascade\",\n }),\n createdAt: timestamp(\"created_at\").default(sql`now()`).notNull(),\n names: text(\"names\").array().default(sql`'{}'::text[]`).notNull(),\n metadata: jsonb(\"metadata\").$type<Metadata>().default(sql`'{}'::jsonb`).notNull(),\n },\n (table) => {\n return {\n idAgentIdUnique: unique(\"id_agent_id_unique\").on(table.id, table.agentId),\n };\n }\n);\n",
124
- "import type { Metadata } from \"@elizaos/core\";\nimport { sql } from \"drizzle-orm\";\nimport { jsonb, pgTable, text, timestamp, uuid } from \"drizzle-orm/pg-core\";\nimport { agentTable } from \"./agent\";\n\n/**\n * Defines a table schema for 'rooms' in the database.\n *\n * @typedef {object} RoomTable\n * @property {string} id - The unique identifier for the room.\n * @property {string} agentId - The UUID of the agent associated with the room.\n * @property {string} source - The source of the room.\n * @property {string} type - The type of the room.\n * @property {string} messageServerId - The message server ID of the room.\n * @property {string} worldId - The UUID of the world associated with the room.\n * @property {string} name - The name of the room.\n * @property {object} metadata - Additional metadata for the room in JSON format.\n * @property {string} channelId - The channel ID of the room.\n * @property {number} createdAt - The timestamp of when the room was created.\n */\nexport const roomTable = pgTable(\"rooms\", {\n id: uuid(\"id\").notNull().primaryKey().default(sql`gen_random_uuid()`),\n agentId: uuid(\"agent_id\").references(() => agentTable.id, {\n onDelete: \"cascade\",\n }),\n source: text(\"source\").notNull(),\n type: text(\"type\").notNull(),\n messageServerId: uuid(\"message_server_id\"),\n worldId: uuid(\"world_id\"), // no guarantee that world exists, it is optional for now\n // .references(() => worldTable.id, {\n // onDelete: 'cascade',\n // }),\n name: text(\"name\"),\n metadata: jsonb(\"metadata\").$type<Metadata>(),\n channelId: text(\"channel_id\"),\n createdAt: timestamp(\"created_at\").default(sql`now()`).notNull(),\n});\n",
125
- "export { agentTable } from \"./agent\";\nexport { cacheTable } from \"./cache\";\nexport { channelTable } from \"./channel\";\nexport { channelParticipantsTable } from \"./channelParticipant\";\nexport { componentTable } from \"./component\";\nexport { embeddingTable } from \"./embedding\";\nexport { entityTable } from \"./entity\";\nexport { logTable } from \"./log\";\nexport { memoryTable } from \"./memory\";\nexport { messageTable } from \"./message\";\nexport { messageServerTable } from \"./messageServer\";\nexport { messageServerAgentsTable } from \"./messageServerAgent\";\nexport { participantTable } from \"./participant\";\nexport { relationshipTable } from \"./relationship\";\nexport { roomTable } from \"./room\";\nexport { serverTable } from \"./server\";\nexport { taskTable } from \"./tasks\";\nexport { worldTable } from \"./world\";\n",
126
- "import { sql } from \"drizzle-orm\";\nimport { jsonb, pgTable, primaryKey, text, timestamp, uuid } from \"drizzle-orm/pg-core\";\nimport { agentTable } from \"./agent\";\n\n/**\n * Represents a PostgreSQL table for caching data.\n *\n * @type {pgTable}\n */\nexport const cacheTable = pgTable(\n \"cache\",\n {\n key: text(\"key\").notNull(),\n agentId: uuid(\"agent_id\")\n .notNull()\n .references(() => agentTable.id, { onDelete: \"cascade\" }),\n value: jsonb(\"value\").notNull(),\n createdAt: timestamp(\"created_at\", { withTimezone: true }).default(sql`now()`).notNull(),\n expiresAt: timestamp(\"expires_at\", { withTimezone: true }),\n },\n (table) => [primaryKey({ columns: [table.key, table.agentId] })]\n);\n",
127
- "import { sql } from \"drizzle-orm\";\nimport { jsonb, pgTable, text, timestamp, uuid } from \"drizzle-orm/pg-core\";\nimport { messageServerTable } from \"./messageServer\";\n\nexport const channelTable = pgTable(\"channels\", {\n id: text(\"id\").primaryKey(), // UUID stored as text\n messageServerId: uuid(\"message_server_id\")\n .notNull()\n .references(() => messageServerTable.id, { onDelete: \"cascade\" }),\n name: text(\"name\").notNull(),\n type: text(\"type\").notNull(), // Store ChannelType enum values as text\n sourceType: text(\"source_type\"),\n sourceId: text(\"source_id\"),\n topic: text(\"topic\"),\n metadata: jsonb(\"metadata\"),\n // server_id is added dynamically by RLS setup\n createdAt: timestamp(\"created_at\", { mode: \"date\" }).default(sql`CURRENT_TIMESTAMP`).notNull(),\n updatedAt: timestamp(\"updated_at\", { mode: \"date\" }).default(sql`CURRENT_TIMESTAMP`).notNull(),\n});\n",
128
- "import { sql } from \"drizzle-orm\";\nimport { jsonb, pgTable, text, timestamp, uuid } from \"drizzle-orm/pg-core\";\n\nexport const messageServerTable = pgTable(\"message_servers\", {\n id: uuid(\"id\").primaryKey(),\n name: text(\"name\").notNull(),\n sourceType: text(\"source_type\").notNull(),\n sourceId: text(\"source_id\"),\n metadata: jsonb(\"metadata\"),\n createdAt: timestamp(\"created_at\", { mode: \"date\" }).default(sql`CURRENT_TIMESTAMP`).notNull(),\n updatedAt: timestamp(\"updated_at\", { mode: \"date\" }).default(sql`CURRENT_TIMESTAMP`).notNull(),\n});\n",
129
- "import { pgTable, primaryKey, text } from \"drizzle-orm/pg-core\";\nimport { channelTable } from \"./channel\";\n\nexport const channelParticipantsTable = pgTable(\n \"channel_participants\",\n {\n channelId: text(\"channel_id\")\n .notNull()\n .references(() => channelTable.id, { onDelete: \"cascade\" }),\n entityId: text(\"entity_id\").notNull(), // Entity UUID (can be an agentId or a dedicated central user ID)\n },\n (table) => [primaryKey({ columns: [table.channelId, table.entityId] })]\n);\n",
130
- "import { sql } from \"drizzle-orm\";\nimport { jsonb, pgTable, text, timestamp, uuid } from \"drizzle-orm/pg-core\";\nimport { agentTable } from \"./agent\";\nimport { entityTable } from \"./entity\";\nimport { roomTable } from \"./room\";\nimport { worldTable } from \"./world\";\n\n/**\n * Represents a component table in the database.\n */\nexport const componentTable = pgTable(\"components\", {\n id: uuid(\"id\").primaryKey().default(sql`gen_random_uuid()`).notNull(),\n\n // Foreign keys\n entityId: uuid(\"entity_id\")\n .references(() => entityTable.id, { onDelete: \"cascade\" })\n .notNull(),\n agentId: uuid(\"agent_id\")\n .references(() => agentTable.id, { onDelete: \"cascade\" })\n .notNull(),\n roomId: uuid(\"room_id\")\n .references(() => roomTable.id, { onDelete: \"cascade\" })\n .notNull(),\n worldId: uuid(\"world_id\").references(() => worldTable.id, {\n onDelete: \"cascade\",\n }),\n sourceEntityId: uuid(\"source_entity_id\").references(() => entityTable.id, {\n onDelete: \"cascade\",\n }),\n\n // Data\n type: text(\"type\").notNull(),\n data: jsonb(\"data\").default(sql`'{}'::jsonb`),\n\n // Timestamps\n createdAt: timestamp(\"created_at\").default(sql`now()`).notNull(),\n});\n",
131
- "import { sql } from \"drizzle-orm\";\nimport { jsonb, pgTable, text, timestamp, uuid } from \"drizzle-orm/pg-core\";\nimport { agentTable } from \"./agent\";\n\n/**\n * Represents a table schema for worlds in the database.\n *\n * @type {PgTable}\n */\n\nexport const worldTable = pgTable(\"worlds\", {\n id: uuid(\"id\").notNull().primaryKey().default(sql`gen_random_uuid()`),\n agentId: uuid(\"agent_id\")\n .notNull()\n .references(() => agentTable.id, { onDelete: \"cascade\" }),\n name: text(\"name\").notNull(),\n metadata: jsonb(\"metadata\"),\n messageServerId: uuid(\"message_server_id\"),\n createdAt: timestamp(\"created_at\").default(sql`now()`).notNull(),\n});\n",
132
- "import { sql } from \"drizzle-orm\";\nimport { foreignKey, jsonb, pgTable, text, timestamp, uuid } from \"drizzle-orm/pg-core\";\nimport { entityTable } from \"./entity\";\nimport { roomTable } from \"./room\";\n\n/**\n * Represents a PostgreSQL table for storing logs.\n *\n * @type {Table}\n */\n\nexport const logTable = pgTable(\n \"logs\",\n {\n id: uuid(\"id\").defaultRandom().notNull(),\n createdAt: timestamp(\"created_at\", { withTimezone: true }).default(sql`now()`).notNull(),\n entityId: uuid(\"entity_id\")\n .notNull()\n .references(() => entityTable.id, { onDelete: \"cascade\" }),\n body: jsonb(\"body\").notNull(),\n type: text(\"type\").notNull(),\n roomId: uuid(\"room_id\")\n .notNull()\n .references(() => roomTable.id, { onDelete: \"cascade\" }),\n },\n (table) => [\n foreignKey({\n name: \"fk_room\",\n columns: [table.roomId],\n foreignColumns: [roomTable.id],\n }).onDelete(\"cascade\"),\n foreignKey({\n name: \"fk_user\",\n columns: [table.entityId],\n foreignColumns: [entityTable.id],\n }).onDelete(\"cascade\"),\n ]\n);\n",
133
- "import { sql } from \"drizzle-orm\";\nimport { jsonb, pgTable, text, timestamp } from \"drizzle-orm/pg-core\";\nimport { channelTable } from \"./channel\";\n\nexport const messageTable = pgTable(\"central_messages\", {\n id: text(\"id\").primaryKey(), // UUID stored as text\n channelId: text(\"channel_id\")\n .notNull()\n .references(() => channelTable.id, { onDelete: \"cascade\" }),\n authorId: text(\"author_id\").notNull(),\n content: text(\"content\").notNull(),\n rawMessage: jsonb(\"raw_message\"),\n inReplyToRootMessageId: text(\"in_reply_to_root_message_id\").references(() => messageTable.id, {\n onDelete: \"set null\",\n }),\n sourceType: text(\"source_type\"),\n sourceId: text(\"source_id\"),\n metadata: jsonb(\"metadata\"),\n createdAt: timestamp(\"created_at\", { mode: \"date\" }).default(sql`CURRENT_TIMESTAMP`).notNull(),\n updatedAt: timestamp(\"updated_at\", { mode: \"date\" }).default(sql`CURRENT_TIMESTAMP`).notNull(),\n});\n",
134
- "import { pgTable, primaryKey, uuid } from \"drizzle-orm/pg-core\";\nimport { agentTable } from \"./agent\";\nimport { messageServerTable } from \"./messageServer\";\n\nexport const messageServerAgentsTable = pgTable(\n \"message_server_agents\",\n {\n messageServerId: uuid(\"message_server_id\")\n .notNull()\n .references(() => messageServerTable.id, { onDelete: \"cascade\" }),\n agentId: uuid(\"agent_id\")\n .notNull()\n .references(() => agentTable.id, { onDelete: \"cascade\" }),\n },\n (table) => [primaryKey({ columns: [table.messageServerId, table.agentId] })]\n);\n",
135
- "import { sql } from \"drizzle-orm\";\nimport { foreignKey, index, pgTable, text, timestamp, uuid } from \"drizzle-orm/pg-core\";\nimport { agentTable } from \"./agent\";\nimport { entityTable } from \"./entity\";\nimport { roomTable } from \"./room\";\n\n/**\n * Defines the schema for the \"participants\" table in the database.\n *\n * @type {import('knex').TableBuilder}\n */\nexport const participantTable = pgTable(\n \"participants\",\n {\n id: uuid(\"id\").notNull().primaryKey().default(sql`gen_random_uuid()`),\n createdAt: timestamp(\"created_at\", { withTimezone: true }).default(sql`now()`).notNull(),\n entityId: uuid(\"entity_id\").references(() => entityTable.id, {\n onDelete: \"cascade\",\n }),\n roomId: uuid(\"room_id\").references(() => roomTable.id, {\n onDelete: \"cascade\",\n }),\n agentId: uuid(\"agent_id\").references(() => agentTable.id, {\n onDelete: \"cascade\",\n }),\n roomState: text(\"room_state\"),\n },\n (table) => [\n // unique(\"participants_user_room_agent_unique\").on(table.entityId, table.roomId, table.agentId),\n index(\"idx_participants_user\").on(table.entityId),\n index(\"idx_participants_room\").on(table.roomId),\n foreignKey({\n name: \"fk_room\",\n columns: [table.roomId],\n foreignColumns: [roomTable.id],\n }).onDelete(\"cascade\"),\n foreignKey({\n name: \"fk_user\",\n columns: [table.entityId],\n foreignColumns: [entityTable.id],\n }).onDelete(\"cascade\"),\n ]\n);\n",
136
- "import { sql } from \"drizzle-orm\";\nimport {\n foreignKey,\n index,\n jsonb,\n pgTable,\n text,\n timestamp,\n unique,\n uuid,\n} from \"drizzle-orm/pg-core\";\nimport { agentTable } from \"./agent\";\nimport { entityTable } from \"./entity\";\n\n/**\n * Defines the relationshipTable containing information about relationships between entities and agents.\n * @type {import('knex').TableBuilder}\n */\nexport const relationshipTable = pgTable(\n \"relationships\",\n {\n id: uuid(\"id\").notNull().primaryKey().default(sql`gen_random_uuid()`),\n createdAt: timestamp(\"created_at\", { withTimezone: true }).default(sql`now()`).notNull(),\n sourceEntityId: uuid(\"source_entity_id\")\n .notNull()\n .references(() => entityTable.id, { onDelete: \"cascade\" }),\n targetEntityId: uuid(\"target_entity_id\")\n .notNull()\n .references(() => entityTable.id, { onDelete: \"cascade\" }),\n agentId: uuid(\"agent_id\")\n .notNull()\n .references(() => agentTable.id, { onDelete: \"cascade\" }),\n tags: text(\"tags\").array(),\n metadata: jsonb(\"metadata\"),\n },\n (table) => [\n index(\"idx_relationships_users\").on(table.sourceEntityId, table.targetEntityId),\n unique(\"unique_relationship\").on(table.sourceEntityId, table.targetEntityId, table.agentId),\n foreignKey({\n name: \"fk_user_a\",\n columns: [table.sourceEntityId],\n foreignColumns: [entityTable.id],\n }).onDelete(\"cascade\"),\n foreignKey({\n name: \"fk_user_b\",\n columns: [table.targetEntityId],\n foreignColumns: [entityTable.id],\n }).onDelete(\"cascade\"),\n ]\n);\n",
137
- "import { sql } from \"drizzle-orm\";\nimport { jsonb, pgTable, text, timestamp, uuid } from \"drizzle-orm/pg-core\";\nimport { agentTable } from \"./agent\";\n\n/**\n * Represents a table schema for tasks in the database.\n *\n * @type {PgTable}\n */\nexport const taskTable = pgTable(\"tasks\", {\n id: uuid(\"id\").primaryKey().defaultRandom(),\n name: text(\"name\").notNull(),\n description: text(\"description\"),\n roomId: uuid(\"room_id\"),\n worldId: uuid(\"world_id\"),\n entityId: uuid(\"entity_id\"),\n agentId: uuid(\"agent_id\")\n .notNull()\n .references(() => agentTable.id, { onDelete: \"cascade\" }),\n tags: text(\"tags\").array().default(sql`'{}'::text[]`),\n metadata: jsonb(\"metadata\").default(sql`'{}'::jsonb`),\n createdAt: timestamp(\"created_at\", { withTimezone: true }).defaultNow(),\n updatedAt: timestamp(\"updated_at\", { withTimezone: true }).defaultNow(),\n});\n",
138
- "import { logger, type UUID, validateUuid } from \"@elizaos/core\";\nimport { sql } from \"drizzle-orm\";\nimport { drizzle, type NodePgDatabase } from \"drizzle-orm/node-postgres\";\nimport { Pool, type PoolClient, type PoolConfig } from \"pg\";\n\nexport class PostgresConnectionManager {\n private pool: Pool;\n private db: NodePgDatabase;\n\n constructor(connectionString: string, rlsServerId?: string) {\n const poolConfig: PoolConfig = {\n connectionString,\n max: 20,\n min: 2,\n idleTimeoutMillis: 30000,\n connectionTimeoutMillis: 5000,\n keepAlive: true,\n keepAliveInitialDelayMillis: 10000,\n };\n\n if (rlsServerId) {\n poolConfig.application_name = rlsServerId;\n logger.debug(\n { src: \"plugin:sql\", rlsServerId: rlsServerId.substring(0, 8) },\n \"Pool configured with RLS server\"\n );\n }\n\n this.pool = new Pool(poolConfig);\n\n this.pool.on(\"error\", (err) => {\n logger.warn(\n { src: \"plugin:sql\", error: err?.message || String(err) },\n \"Pool client error (connection will be replaced)\"\n );\n });\n\n this.db = drizzle(this.pool, { casing: \"snake_case\" });\n }\n\n public getDatabase(): NodePgDatabase {\n return this.db;\n }\n\n public getConnection(): Pool {\n return this.pool;\n }\n\n public async getClient(): Promise<PoolClient> {\n return this.pool.connect();\n }\n\n public async testConnection(): Promise<boolean> {\n let client: PoolClient | null = null;\n try {\n client = await this.pool.connect();\n await client.query(\"SELECT 1\");\n return true;\n } catch (error) {\n logger.error(\n {\n src: \"plugin:sql\",\n error: error instanceof Error ? error.message : String(error),\n },\n \"Failed to connect to the database\"\n );\n return false;\n } finally {\n if (client) {\n client.release();\n }\n }\n }\n\n public async withEntityContext<T>(\n entityId: UUID | null,\n callback: (tx: NodePgDatabase) => Promise<T>\n ): Promise<T> {\n const dataIsolationEnabled = process.env.ENABLE_DATA_ISOLATION === \"true\";\n\n return await this.db.transaction(async (tx) => {\n if (dataIsolationEnabled && entityId) {\n if (!validateUuid(entityId)) {\n throw new Error(`Invalid UUID format for entity context: ${entityId}`);\n }\n\n try {\n await tx.execute(sql.raw(`SET LOCAL app.entity_id = '${entityId}'`));\n logger.debug(`[Entity Context] Set app.entity_id = ${entityId}`);\n } catch (error) {\n const errorMessage = error instanceof Error ? error.message : String(error);\n logger.error(\n { error, entityId },\n `[Entity Context] Failed to set entity context: ${errorMessage}`\n );\n throw error;\n }\n } else if (!dataIsolationEnabled) {\n } else {\n logger.debug(\"[Entity Context] No entity context set (server operation)\");\n }\n\n return await callback(tx);\n });\n }\n\n public async close(): Promise<void> {\n await this.pool.end();\n }\n}\n",
100
+ "import type { MessageExample } from \"@elizaos/core\";\nimport { sql } from \"drizzle-orm\";\nimport {\n\tboolean,\n\tjsonb,\n\tpgTable,\n\ttext,\n\ttimestamp,\n\tuuid,\n} from \"drizzle-orm/pg-core\";\n\n/**\n * Represents a table for storing agent data.\n *\n * @type {Table}\n */\nexport const agentTable = pgTable(\"agents\", {\n\tid: uuid(\"id\").primaryKey().defaultRandom(),\n\tenabled: boolean(\"enabled\").default(true).notNull(),\n\tserver_id: uuid(\"server_id\"),\n\tcreatedAt: timestamp(\"created_at\", { withTimezone: true })\n\t\t.default(sql`now()`)\n\t\t.notNull(),\n\n\tupdatedAt: timestamp(\"updated_at\", { withTimezone: true })\n\t\t.default(sql`now()`)\n\t\t.notNull(),\n\n\t// Character\n\tname: text(\"name\").notNull(),\n\tusername: text(\"username\"),\n\tsystem: text(\"system\").default(\"\"),\n\tbio: jsonb(\"bio\").$type<string | string[]>().default(sql`'[]'::jsonb`),\n\tmessageExamples: jsonb(\"message_examples\")\n\t\t.$type<MessageExample[][]>()\n\t\t.default(sql`'[]'::jsonb`)\n\t\t.notNull(),\n\tpostExamples: jsonb(\"post_examples\")\n\t\t.$type<string[]>()\n\t\t.default(sql`'[]'::jsonb`)\n\t\t.notNull(),\n\ttopics: jsonb(\"topics\").$type<string[]>().default(sql`'[]'::jsonb`).notNull(),\n\tadjectives: jsonb(\"adjectives\")\n\t\t.$type<string[]>()\n\t\t.default(sql`'[]'::jsonb`)\n\t\t.notNull(),\n\tknowledge: jsonb(\"knowledge\")\n\t\t.$type<(string | { path: string; shared?: boolean })[]>()\n\t\t.default(sql`'[]'::jsonb`)\n\t\t.notNull(),\n\tplugins: jsonb(\"plugins\")\n\t\t.$type<string[]>()\n\t\t.default(sql`'[]'::jsonb`)\n\t\t.notNull(),\n\tsettings: jsonb(\"settings\")\n\t\t.$type<{\n\t\t\tsecrets?: { [key: string]: string | boolean | number };\n\t\t\t[key: string]:\n\t\t\t\t| string\n\t\t\t\t| boolean\n\t\t\t\t| number\n\t\t\t\t| Record<string, unknown>\n\t\t\t\t| undefined;\n\t\t}>()\n\t\t.default(sql`'{}'::jsonb`)\n\t\t.notNull(),\n\tstyle: jsonb(\"style\")\n\t\t.$type<{\n\t\t\tall?: string[];\n\t\t\tchat?: string[];\n\t\t\tpost?: string[];\n\t\t}>()\n\t\t.default(sql`'{}'::jsonb`)\n\t\t.notNull(),\n});\n",
101
+ "import { sql } from \"drizzle-orm\";\nimport { pgTable, timestamp, uuid } from \"drizzle-orm/pg-core\";\n\n/**\n * Represents a table for storing server data for RLS multi-tenant isolation.\n * Each server represents one elizaOS instance in a multi-tenant deployment.\n *\n * @type {Table}\n */\nexport const serverTable = pgTable(\"servers\", {\n\tid: uuid(\"id\").primaryKey(),\n\tcreatedAt: timestamp(\"created_at\", { withTimezone: true })\n\t\t.default(sql`now()`)\n\t\t.notNull(),\n\tupdatedAt: timestamp(\"updated_at\", { withTimezone: true })\n\t\t.default(sql`now()`)\n\t\t.notNull(),\n});\n",
102
+ "import type { IDatabaseAdapter } from \"@elizaos/core\";\nimport type { NodePgDatabase } from \"drizzle-orm/node-postgres\";\nimport type { PgliteDatabase } from \"drizzle-orm/pglite\";\n\nexport type DrizzleDatabase = NodePgDatabase | PgliteDatabase;\n\nexport interface IDatabaseClientManager<T> {\n\tinitialize(): Promise<void>;\n\tgetConnection(): T;\n\tclose(): Promise<void>;\n}\n\nexport function getDb(adapter: IDatabaseAdapter): DrizzleDatabase {\n\treturn adapter.db as DrizzleDatabase;\n}\n\nexport function getRow<T>(\n\tresult: { rows: unknown[] },\n\tindex = 0,\n): T | undefined {\n\treturn result.rows[index] as T | undefined;\n}\n",
103
+ "import { type IDatabaseAdapter, logger } from \"@elizaos/core\";\nimport { sql } from \"drizzle-orm\";\nimport { getDb } from \"./types\";\n\n// Column info row for schema introspection queries\ninterface ColumnInfoRow {\n\tcolumn_name: string;\n\tdata_type: string;\n}\n\n// Table info row for schema introspection queries\ninterface TableInfoRow {\n\ttable_name: string;\n}\n\n/**\n * Type-safe extraction of rows from SQL query results.\n */\nfunction getRows<T>(result: { rows: unknown[] }): T[] {\n\treturn result.rows as T[];\n}\n\n/**\n * TEMPORARY MIGRATION: pre-1.6.5 → 1.6.5+ schema migration\n *\n * This migration runs automatically on startup and is idempotent.\n * It handles the migration from Owner RLS to Server RLS + Entity RLS, including:\n * - Disabling old RLS policies temporarily\n * - Renaming server_id → message_server_id in channels, worlds, rooms\n * - Converting TEXT → UUID where needed\n * - Dropping old server_id columns for RLS\n * - Cleaning up indexes\n *\n * @param adapter - Database adapter\n */\nexport async function migrateToEntityRLS(\n\tadapter: IDatabaseAdapter,\n): Promise<void> {\n\tconst db = getDb(adapter);\n\n\t// Detect database type - skip PostgreSQL-specific migrations for SQLite\n\ttry {\n\t\tawait db.execute(sql`SELECT 1 FROM pg_tables LIMIT 1`);\n\t} catch {\n\t\t// Not PostgreSQL (likely SQLite)\n\t\tlogger.debug(\n\t\t\t\"[Migration] ⊘ Not PostgreSQL, skipping PostgreSQL-specific migrations\",\n\t\t);\n\t\treturn;\n\t}\n\n\t// Check if schema migration has already been completed\n\t// We use the presence of snake_case columns as a marker\n\tlet schemaAlreadyMigrated = false;\n\ttry {\n\t\tconst migrationCheck = await db.execute(sql`\n SELECT column_name FROM information_schema.columns\n WHERE table_schema = 'public'\n AND table_name = 'rooms'\n AND column_name = 'agent_id'\n `);\n\n\t\tif (migrationCheck.rows && migrationCheck.rows.length > 0) {\n\t\t\t// Migration already completed - rooms.agent_id exists (snake_case)\n\t\t\tschemaAlreadyMigrated = true;\n\t\t\tlogger.debug(\n\t\t\t\t\"[Migration] ⊘ Schema already migrated (snake_case columns exist)\",\n\t\t\t);\n\t\t}\n\t} catch {\n\t\t// Table might not exist yet, continue with migration\n\t\tlogger.debug(\n\t\t\t\"[Migration] → rooms table not found, will be created by RuntimeMigrator\",\n\t\t);\n\t\treturn; // Let RuntimeMigrator create fresh tables\n\t}\n\n\t// If schema is already migrated, check if we need to clean up RLS\n\t// Only disable RLS if ENABLE_DATA_ISOLATION is NOT true (user disabled isolation)\n\t// If ENABLE_DATA_ISOLATION=true, keep RLS as-is - migration-service.ts will ensure proper config\n\tif (schemaAlreadyMigrated) {\n\t\tconst dataIsolationEnabled = process.env.ENABLE_DATA_ISOLATION === \"true\";\n\n\t\tif (dataIsolationEnabled) {\n\t\t\t// RLS should stay enabled - no need to disable/re-enable cycle\n\t\t\t// migration-service.ts ensures RLS is properly configured via idempotent calls\n\t\t\tlogger.debug(\n\t\t\t\t\"[Migration] ⊘ Schema already migrated, RLS enabled - nothing to do\",\n\t\t\t);\n\t\t\treturn;\n\t\t}\n\n\t\t// User disabled data isolation - clean up RLS if it was previously enabled\n\t\tlogger.debug(\n\t\t\t\"[Migration] → Schema migrated but RLS disabled, cleaning up...\",\n\t\t);\n\n\t\ttry {\n\t\t\tconst tablesWithRls = await db.execute(sql`\n SELECT c.relname as tablename\n FROM pg_class c\n JOIN pg_namespace n ON n.oid = c.relnamespace\n WHERE n.nspname = 'public'\n AND c.relkind = 'r'\n AND c.relrowsecurity = true\n ORDER BY c.relname\n `);\n\n\t\t\tif (tablesWithRls.rows && tablesWithRls.rows.length > 0) {\n\t\t\t\tfor (const row of tablesWithRls.rows) {\n\t\t\t\t\tconst tableName = row.tablename as string;\n\t\t\t\t\ttry {\n\t\t\t\t\t\tawait db.execute(\n\t\t\t\t\t\t\tsql.raw(`ALTER TABLE \"${tableName}\" DISABLE ROW LEVEL SECURITY`),\n\t\t\t\t\t\t);\n\t\t\t\t\t} catch {\n\t\t\t\t\t\t// Ignore errors\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t\tlogger.debug(\n\t\t\t\t\t`[Migration] ✓ RLS cleanup completed (${tablesWithRls.rows.length} tables)`,\n\t\t\t\t);\n\t\t\t} else {\n\t\t\t\tlogger.debug(\"[Migration] ⊘ No tables with RLS to clean up\");\n\t\t\t}\n\t\t} catch {\n\t\t\tlogger.debug(\"[Migration] ⊘ Could not perform RLS cleanup\");\n\t\t}\n\n\t\treturn;\n\t}\n\n\tlogger.info(\"[Migration] Starting pre-1.6.5 → 1.6.5+ schema migration...\");\n\n\ttry {\n\t\t// Clear RuntimeMigrator snapshot cache to force fresh introspection\n\t\t// This ensures the snapshot matches the current database state after our migrations\n\t\tlogger.debug(\"[Migration] → Clearing RuntimeMigrator snapshot cache...\");\n\t\ttry {\n\t\t\tawait db.execute(\n\t\t\t\tsql`DELETE FROM migrations._snapshots WHERE plugin_name = '@elizaos/plugin-sql'`,\n\t\t\t);\n\t\t\tlogger.debug(\"[Migration] ✓ Snapshot cache cleared\");\n\t\t} catch (_error) {\n\t\t\t// If migrations schema doesn't exist yet, that's fine - no cache to clear\n\t\t\tlogger.debug(\n\t\t\t\t\"[Migration] ⊘ No snapshot cache to clear (migrations schema not yet created)\",\n\t\t\t);\n\t\t}\n\n\t\t// Disable RLS only on tables that have it enabled\n\t\t// RLS will be re-implemented properly later\n\t\tlogger.debug(\"[Migration] → Checking for Row Level Security to disable...\");\n\t\ttry {\n\t\t\tconst tablesWithRls = await db.execute(sql`\n SELECT c.relname as tablename\n FROM pg_class c\n JOIN pg_namespace n ON n.oid = c.relnamespace\n WHERE n.nspname = 'public'\n AND c.relkind = 'r'\n AND c.relrowsecurity = true\n ORDER BY c.relname\n `);\n\n\t\t\tif (tablesWithRls.rows && tablesWithRls.rows.length > 0) {\n\t\t\t\tfor (const row of tablesWithRls.rows) {\n\t\t\t\t\tconst tableName = row.tablename as string;\n\t\t\t\t\ttry {\n\t\t\t\t\t\tawait db.execute(\n\t\t\t\t\t\t\tsql.raw(`ALTER TABLE \"${tableName}\" DISABLE ROW LEVEL SECURITY`),\n\t\t\t\t\t\t);\n\t\t\t\t\t\tlogger.debug(`[Migration] ✓ Disabled RLS on ${tableName}`);\n\t\t\t\t\t} catch (_error) {\n\t\t\t\t\t\tlogger.debug(`[Migration] ⊘ Could not disable RLS on ${tableName}`);\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t} else {\n\t\t\t\tlogger.debug(\"[Migration] ⊘ No tables with RLS enabled\");\n\t\t\t}\n\t\t} catch (_error) {\n\t\t\tlogger.debug(\n\t\t\t\t\"[Migration] ⊘ Could not check RLS (may not have permissions)\",\n\t\t\t);\n\t\t}\n\n\t\t// Special handling for tables where serverId/server_id needs to become message_server_id\n\t\t// v1.6.4 had: rooms.serverId (TEXT camelCase), worlds.serverId (TEXT camelCase), channels.server_id (UUID)\n\t\t// Current: message_server_id (UUID) in all tables\n\t\t//\n\t\t// STRATEGY: Rename serverId/server_id to message_server_id preserving data\n\t\tlogger.debug(\n\t\t\t\"[Migration] → Handling serverId/server_id → message_server_id migrations...\",\n\t\t);\n\n\t\tconst tablesToMigrate = [\"channels\", \"worlds\", \"rooms\"];\n\n\t\tfor (const tableName of tablesToMigrate) {\n\t\t\ttry {\n\t\t\t\t// Check for both camelCase (serverId) and snake_case (server_id) columns\n\t\t\t\tconst columnsResult = await db.execute(sql`\n SELECT column_name, data_type, is_nullable\n FROM information_schema.columns\n WHERE table_schema = 'public'\n AND table_name = ${tableName}\n AND column_name IN ('server_id', 'serverId', 'message_server_id')\n ORDER BY column_name\n `);\n\n\t\t\t\tconst columns = getRows<ColumnInfoRow>(columnsResult);\n\t\t\t\tconst serverIdSnake = columns.find(\n\t\t\t\t\t(c) => c.column_name === \"server_id\",\n\t\t\t\t);\n\t\t\t\tconst serverIdCamel = columns.find((c) => c.column_name === \"serverId\");\n\t\t\t\tconst messageServerId = columns.find(\n\t\t\t\t\t(c) => c.column_name === \"message_server_id\",\n\t\t\t\t);\n\n\t\t\t\t// Use whichever old column exists (prefer snake_case for channels)\n\t\t\t\tconst serverId = serverIdSnake || serverIdCamel;\n\t\t\t\tconst oldColumnName = serverIdSnake ? \"server_id\" : \"serverId\";\n\n\t\t\t\tif (serverId && !messageServerId) {\n\t\t\t\t\t// Old column exists → rename it to message_server_id\n\t\t\t\t\tlogger.debug(\n\t\t\t\t\t\t`[Migration] → Renaming ${tableName}.${oldColumnName} to message_server_id...`,\n\t\t\t\t\t);\n\t\t\t\t\tawait db.execute(\n\t\t\t\t\t\tsql.raw(\n\t\t\t\t\t\t\t`ALTER TABLE \"${tableName}\" RENAME COLUMN \"${oldColumnName}\" TO \"message_server_id\"`,\n\t\t\t\t\t\t),\n\t\t\t\t\t);\n\t\t\t\t\tlogger.debug(\n\t\t\t\t\t\t`[Migration] ✓ Renamed ${tableName}.${oldColumnName} → message_server_id`,\n\t\t\t\t\t);\n\n\t\t\t\t\t// If the column was text, try to convert to UUID (if data is UUID-compatible)\n\t\t\t\t\tif (serverId.data_type === \"text\") {\n\t\t\t\t\t\t// CRITICAL: Drop DEFAULT constraint before type conversion\n\t\t\t\t\t\t// This prevents \"default for column cannot be cast automatically\" errors\n\t\t\t\t\t\t// Wrap in separate try-catch to ensure we continue even if no default exists\n\t\t\t\t\t\ttry {\n\t\t\t\t\t\t\tlogger.debug(\n\t\t\t\t\t\t\t\t`[Migration] → Dropping DEFAULT constraint on ${tableName}.message_server_id...`,\n\t\t\t\t\t\t\t);\n\t\t\t\t\t\t\tawait db.execute(\n\t\t\t\t\t\t\t\tsql.raw(\n\t\t\t\t\t\t\t\t\t`ALTER TABLE \"${tableName}\" ALTER COLUMN \"message_server_id\" DROP DEFAULT`,\n\t\t\t\t\t\t\t\t),\n\t\t\t\t\t\t\t);\n\t\t\t\t\t\t\tlogger.debug(`[Migration] ✓ Dropped DEFAULT constraint`);\n\t\t\t\t\t\t} catch {\n\t\t\t\t\t\t\tlogger.debug(\n\t\t\t\t\t\t\t\t`[Migration] ⊘ No DEFAULT constraint to drop on ${tableName}.message_server_id`,\n\t\t\t\t\t\t\t);\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\ttry {\n\t\t\t\t\t\t\tlogger.debug(\n\t\t\t\t\t\t\t\t`[Migration] → Converting ${tableName}.message_server_id from text to uuid...`,\n\t\t\t\t\t\t\t);\n\t\t\t\t\t\t\t// Use robust conversion: valid UUIDs are cast directly, others get md5 hash\n\t\t\t\t\t\t\t// This handles: empty strings, non-UUID text, uppercase UUIDs, NULL values\n\t\t\t\t\t\t\tawait db.execute(\n\t\t\t\t\t\t\t\tsql.raw(`\n ALTER TABLE \"${tableName}\"\n ALTER COLUMN \"message_server_id\" TYPE uuid\n USING CASE\n WHEN \"message_server_id\" IS NULL THEN NULL\n WHEN \"message_server_id\" = '' THEN NULL\n WHEN \"message_server_id\" ~ '^[0-9a-fA-F]{8}-[0-9a-fA-F]{4}-[0-9a-fA-F]{4}-[0-9a-fA-F]{4}-[0-9a-fA-F]{12}$'\n THEN \"message_server_id\"::uuid\n ELSE md5(\"message_server_id\")::uuid\n END\n `),\n\t\t\t\t\t\t\t);\n\t\t\t\t\t\t\tlogger.debug(\n\t\t\t\t\t\t\t\t`[Migration] ✓ Converted ${tableName}.message_server_id to uuid`,\n\t\t\t\t\t\t\t);\n\t\t\t\t\t\t} catch (convertError) {\n\t\t\t\t\t\t\tlogger.warn(\n\t\t\t\t\t\t\t\t`[Migration] ⚠️ Could not convert ${tableName}.message_server_id to uuid: ${convertError}`,\n\t\t\t\t\t\t\t);\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\n\t\t\t\t\t// If the column should be NOT NULL but has NULLs, we need to handle that\n\t\t\t\t\t// For channels, it's NOT NULL in the new schema\n\t\t\t\t\tif (tableName === \"channels\") {\n\t\t\t\t\t\tconst nullCountResult = await db.execute(\n\t\t\t\t\t\t\tsql.raw(\n\t\t\t\t\t\t\t\t`SELECT COUNT(*) as count FROM \"${tableName}\" WHERE \"message_server_id\" IS NULL`,\n\t\t\t\t\t\t\t),\n\t\t\t\t\t\t);\n\t\t\t\t\t\tconst nullCount = nullCountResult.rows?.[0]?.count as\n\t\t\t\t\t\t\t| string\n\t\t\t\t\t\t\t| undefined;\n\t\t\t\t\t\tif (nullCount && parseInt(nullCount, 10) > 0) {\n\t\t\t\t\t\t\tlogger.warn(\n\t\t\t\t\t\t\t\t`[Migration] ⚠️ ${tableName} has ${nullCount} rows with NULL message_server_id - these will be deleted`,\n\t\t\t\t\t\t\t);\n\t\t\t\t\t\t\tawait db.execute(\n\t\t\t\t\t\t\t\tsql.raw(\n\t\t\t\t\t\t\t\t\t`DELETE FROM \"${tableName}\" WHERE \"message_server_id\" IS NULL`,\n\t\t\t\t\t\t\t\t),\n\t\t\t\t\t\t\t);\n\t\t\t\t\t\t\tlogger.debug(\n\t\t\t\t\t\t\t\t`[Migration] ✓ Deleted ${nullCount} rows with NULL message_server_id from ${tableName}`,\n\t\t\t\t\t\t\t);\n\t\t\t\t\t\t}\n\n\t\t\t\t\t\t// Make it NOT NULL\n\t\t\t\t\t\tlogger.debug(\n\t\t\t\t\t\t\t`[Migration] → Making ${tableName}.message_server_id NOT NULL...`,\n\t\t\t\t\t\t);\n\t\t\t\t\t\tawait db.execute(\n\t\t\t\t\t\t\tsql.raw(\n\t\t\t\t\t\t\t\t`ALTER TABLE \"${tableName}\" ALTER COLUMN \"message_server_id\" SET NOT NULL`,\n\t\t\t\t\t\t\t),\n\t\t\t\t\t\t);\n\t\t\t\t\t\tlogger.debug(\n\t\t\t\t\t\t\t`[Migration] ✓ Set ${tableName}.message_server_id NOT NULL`,\n\t\t\t\t\t\t);\n\t\t\t\t\t}\n\t\t\t\t} else if (serverId && messageServerId) {\n\t\t\t\t\t// Both exist → just drop the old column\n\t\t\t\t\tlogger.debug(\n\t\t\t\t\t\t`[Migration] → ${tableName} has both columns, dropping ${oldColumnName}...`,\n\t\t\t\t\t);\n\t\t\t\t\tawait db.execute(\n\t\t\t\t\t\tsql.raw(\n\t\t\t\t\t\t\t`ALTER TABLE \"${tableName}\" DROP COLUMN \"${oldColumnName}\" CASCADE`,\n\t\t\t\t\t\t),\n\t\t\t\t\t);\n\t\t\t\t\tlogger.debug(`[Migration] ✓ Dropped ${tableName}.${oldColumnName}`);\n\t\t\t\t} else if (!serverId && messageServerId) {\n\t\t\t\t\t// Only message_server_id exists - check if it needs type conversion from TEXT to UUID\n\t\t\t\t\t// This handles idempotency when migration partially ran before rollback\n\t\t\t\t\tif (messageServerId.data_type === \"text\") {\n\t\t\t\t\t\tlogger.debug(\n\t\t\t\t\t\t\t`[Migration] → ${tableName}.message_server_id exists but is TEXT, needs UUID conversion...`,\n\t\t\t\t\t\t);\n\n\t\t\t\t\t\t// CRITICAL: Drop DEFAULT constraint before type conversion\n\t\t\t\t\t\t// This prevents \"default for column cannot be cast automatically\" errors\n\t\t\t\t\t\tlogger.debug(\n\t\t\t\t\t\t\t`[Migration] → Dropping DEFAULT constraint on ${tableName}.message_server_id...`,\n\t\t\t\t\t\t);\n\t\t\t\t\t\tawait db.execute(\n\t\t\t\t\t\t\tsql.raw(\n\t\t\t\t\t\t\t\t`ALTER TABLE \"${tableName}\" ALTER COLUMN \"message_server_id\" DROP DEFAULT`,\n\t\t\t\t\t\t\t),\n\t\t\t\t\t\t);\n\t\t\t\t\t\tlogger.debug(`[Migration] ✓ Dropped DEFAULT constraint`);\n\n\t\t\t\t\t\t// Convert TEXT to UUID using MD5 hash for non-UUID text values\n\t\t\t\t\t\t// This creates deterministic UUIDs from text values, preserving data\n\t\t\t\t\t\tlogger.debug(\n\t\t\t\t\t\t\t`[Migration] → Converting ${tableName}.message_server_id from text to uuid (generating UUIDs from text)...`,\n\t\t\t\t\t\t);\n\t\t\t\t\t\tawait db.execute(\n\t\t\t\t\t\t\tsql.raw(`\n ALTER TABLE \"${tableName}\"\n ALTER COLUMN \"message_server_id\" TYPE uuid\n USING CASE\n WHEN \"message_server_id\" ~ '^[0-9a-fA-F]{8}-[0-9a-fA-F]{4}-[0-9a-fA-F]{4}-[0-9a-fA-F]{4}-[0-9a-fA-F]{12}$'\n THEN \"message_server_id\"::uuid\n ELSE md5(\"message_server_id\")::uuid\n END\n `),\n\t\t\t\t\t\t);\n\t\t\t\t\t\tlogger.debug(\n\t\t\t\t\t\t\t`[Migration] ✓ Converted ${tableName}.message_server_id to uuid`,\n\t\t\t\t\t\t);\n\t\t\t\t\t} else {\n\t\t\t\t\t\tlogger.debug(\n\t\t\t\t\t\t\t`[Migration] ⊘ ${tableName}.message_server_id already UUID, skipping`,\n\t\t\t\t\t\t);\n\t\t\t\t\t}\n\t\t\t\t} else {\n\t\t\t\t\tlogger.debug(`[Migration] ⊘ ${tableName} already migrated, skipping`);\n\t\t\t\t}\n\t\t\t} catch (error) {\n\t\t\t\tlogger.warn(\n\t\t\t\t\t`[Migration] ⚠️ Error migrating ${tableName}.server_id: ${error}`,\n\t\t\t\t);\n\t\t\t}\n\t\t}\n\n\t\t// Drop ALL remaining server_id columns (will be re-added by RLS after migrations)\n\t\t// This prevents RuntimeMigrator from seeing them and trying to drop them\n\t\t// EXCEPT for tables where server_id is part of the schema (like agents, server_agents)\n\t\tlogger.debug(\n\t\t\t\"[Migration] → Dropping all remaining RLS-managed server_id columns...\",\n\t\t);\n\t\ttry {\n\t\t\tconst serverIdColumnsResult = await db.execute(sql`\n SELECT table_name\n FROM information_schema.columns\n WHERE table_schema = 'public'\n AND column_name = 'server_id'\n AND table_name NOT IN (\n 'servers', -- server_id is the primary key\n 'agents', -- server_id is in the schema (for RLS)\n 'channels', -- already handled above\n 'worlds', -- already handled above\n 'rooms', -- already handled above\n 'server_agents', -- server_id is part of composite key\n 'drizzle_migrations',\n '__drizzle_migrations'\n )\n ORDER BY table_name\n `);\n\n\t\t\tconst tablesToClean = serverIdColumnsResult.rows || [];\n\t\t\tlogger.debug(\n\t\t\t\t`[Migration] → Found ${tablesToClean.length} tables with server_id columns`,\n\t\t\t);\n\n\t\t\tfor (const row of tablesToClean) {\n\t\t\t\tconst tableName = row.table_name as string;\n\t\t\t\ttry {\n\t\t\t\t\tawait db.execute(\n\t\t\t\t\t\tsql.raw(\n\t\t\t\t\t\t\t`ALTER TABLE \"${tableName}\" DROP COLUMN IF EXISTS server_id CASCADE`,\n\t\t\t\t\t\t),\n\t\t\t\t\t);\n\t\t\t\t\tlogger.debug(`[Migration] ✓ Dropped server_id from ${tableName}`);\n\t\t\t\t} catch (_error) {\n\t\t\t\t\tlogger.debug(\n\t\t\t\t\t\t`[Migration] ⊘ Could not drop server_id from ${tableName}`,\n\t\t\t\t\t);\n\t\t\t\t}\n\t\t\t}\n\t\t} catch (_error) {\n\t\t\tlogger.debug(\n\t\t\t\t\"[Migration] ⊘ Could not drop server_id columns (may not have permissions)\",\n\t\t\t);\n\t\t}\n\n\t\t// Special handling for agents table: rename owner_id → server_id\n\t\t// v1.6.4 had owner_id, v1.6.5 changed it to server_id\n\t\tlogger.debug(\n\t\t\t\"[Migration] → Checking agents.owner_id → server_id rename...\",\n\t\t);\n\t\ttry {\n\t\t\tconst agentsColumnsResult = await db.execute(sql`\n SELECT column_name\n FROM information_schema.columns\n WHERE table_schema = 'public'\n AND table_name = 'agents'\n AND column_name IN ('owner_id', 'server_id')\n ORDER BY column_name\n `);\n\n\t\t\tconst agentsColumns = getRows<ColumnInfoRow>(agentsColumnsResult);\n\t\t\tconst hasOwnerId = agentsColumns.some(\n\t\t\t\t(c) => c.column_name === \"owner_id\",\n\t\t\t);\n\t\t\tconst hasServerId = agentsColumns.some(\n\t\t\t\t(c) => c.column_name === \"server_id\",\n\t\t\t);\n\n\t\t\tif (hasOwnerId && !hasServerId) {\n\t\t\t\t// Rename owner_id → server_id\n\t\t\t\tlogger.debug(\"[Migration] → Renaming agents.owner_id to server_id...\");\n\t\t\t\tawait db.execute(\n\t\t\t\t\tsql.raw(\n\t\t\t\t\t\t`ALTER TABLE \"agents\" RENAME COLUMN \"owner_id\" TO \"server_id\"`,\n\t\t\t\t\t),\n\t\t\t\t);\n\t\t\t\tlogger.debug(\"[Migration] ✓ Renamed agents.owner_id → server_id\");\n\t\t\t} else if (hasOwnerId && hasServerId) {\n\t\t\t\t// Both exist - drop owner_id (data should be in server_id)\n\t\t\t\tlogger.debug(\n\t\t\t\t\t\"[Migration] → Both owner_id and server_id exist, dropping owner_id...\",\n\t\t\t\t);\n\t\t\t\tawait db.execute(\n\t\t\t\t\tsql.raw(`ALTER TABLE \"agents\" DROP COLUMN \"owner_id\" CASCADE`),\n\t\t\t\t);\n\t\t\t\tlogger.debug(\"[Migration] ✓ Dropped agents.owner_id\");\n\t\t\t} else {\n\t\t\t\tlogger.debug(\n\t\t\t\t\t\"[Migration] ⊘ agents table already has server_id (or no owner_id), skipping\",\n\t\t\t\t);\n\t\t\t}\n\t\t} catch (_error) {\n\t\t\tlogger.debug(\"[Migration] ⊘ Could not check/migrate agents.owner_id\");\n\t\t}\n\n\t\t// Migrate data from obsolete 'owners' table to 'servers' (if owners exists)\n\t\t// v1.6.4 used owners table, v1.6.5+ uses servers table\n\t\tlogger.debug(\n\t\t\t\"[Migration] → Checking for owners → servers data migration...\",\n\t\t);\n\t\ttry {\n\t\t\tconst ownersTableResult = await db.execute(sql`\n SELECT table_name\n FROM information_schema.tables\n WHERE table_schema = 'public'\n AND table_name = 'owners'\n `);\n\n\t\t\tif (ownersTableResult.rows && ownersTableResult.rows.length > 0) {\n\t\t\t\t// First, ensure servers table exists\n\t\t\t\tlogger.debug(\"[Migration] → Ensuring servers table exists...\");\n\t\t\t\tawait db.execute(\n\t\t\t\t\tsql.raw(`\n CREATE TABLE IF NOT EXISTS \"servers\" (\n \"id\" uuid PRIMARY KEY,\n \"created_at\" timestamp with time zone DEFAULT now() NOT NULL,\n \"updated_at\" timestamp with time zone DEFAULT now() NOT NULL\n )\n `),\n\t\t\t\t);\n\n\t\t\t\t// Migrate data from owners to servers (if any)\n\t\t\t\tlogger.debug(\"[Migration] → Migrating owners data to servers...\");\n\t\t\t\tawait db.execute(\n\t\t\t\t\tsql.raw(`\n INSERT INTO \"servers\" (\"id\", \"created_at\", \"updated_at\")\n SELECT \"id\", COALESCE(\"created_at\", now()), COALESCE(\"updated_at\", now())\n FROM \"owners\"\n ON CONFLICT (\"id\") DO NOTHING\n `),\n\t\t\t\t);\n\t\t\t\tlogger.debug(\"[Migration] ✓ Migrated owners data to servers\");\n\n\t\t\t\t// Now safe to drop owners table\n\t\t\t\tlogger.debug(\"[Migration] → Dropping obsolete owners table...\");\n\t\t\t\tawait db.execute(sql.raw(`DROP TABLE IF EXISTS \"owners\" CASCADE`));\n\t\t\t\tlogger.debug(\"[Migration] ✓ Dropped obsolete owners table\");\n\t\t\t} else {\n\t\t\t\tlogger.debug(\"[Migration] ⊘ owners table not found, skipping\");\n\t\t\t}\n\t\t} catch (error) {\n\t\t\tlogger.warn(`[Migration] ⚠️ Could not migrate owners → servers: ${error}`);\n\t\t}\n\n\t\t// Special handling for server_agents → message_server_agents rename\n\t\t// This aligns with the server_id → message_server_id naming convention\n\t\tlogger.debug(\"[Migration] → Checking server_agents table rename...\");\n\t\ttry {\n\t\t\tconst tablesResult = await db.execute(sql`\n SELECT table_name\n FROM information_schema.tables\n WHERE table_schema = 'public'\n AND table_name IN ('server_agents', 'message_server_agents')\n ORDER BY table_name\n `);\n\n\t\t\tconst tables = getRows<TableInfoRow>(tablesResult);\n\t\t\tconst hasServerAgents = tables.some(\n\t\t\t\t(t) => t.table_name === \"server_agents\",\n\t\t\t);\n\t\t\tconst hasMessageServerAgents = tables.some(\n\t\t\t\t(t) => t.table_name === \"message_server_agents\",\n\t\t\t);\n\n\t\t\tif (hasServerAgents && !hasMessageServerAgents) {\n\t\t\t\t// Rename server_agents → message_server_agents\n\t\t\t\tlogger.debug(\n\t\t\t\t\t\"[Migration] → Renaming server_agents to message_server_agents...\",\n\t\t\t\t);\n\t\t\t\tawait db.execute(\n\t\t\t\t\tsql.raw(\n\t\t\t\t\t\t`ALTER TABLE \"server_agents\" RENAME TO \"message_server_agents\"`,\n\t\t\t\t\t),\n\t\t\t\t);\n\t\t\t\tlogger.debug(\n\t\t\t\t\t\"[Migration] ✓ Renamed server_agents → message_server_agents\",\n\t\t\t\t);\n\n\t\t\t\t// Now rename server_id column → message_server_id\n\t\t\t\tlogger.debug(\n\t\t\t\t\t\"[Migration] → Renaming message_server_agents.server_id to message_server_id...\",\n\t\t\t\t);\n\t\t\t\tawait db.execute(\n\t\t\t\t\tsql.raw(\n\t\t\t\t\t\t`ALTER TABLE \"message_server_agents\" RENAME COLUMN \"server_id\" TO \"message_server_id\"`,\n\t\t\t\t\t),\n\t\t\t\t);\n\t\t\t\tlogger.debug(\n\t\t\t\t\t\"[Migration] ✓ Renamed message_server_agents.server_id → message_server_id\",\n\t\t\t\t);\n\t\t\t} else if (!hasServerAgents && !hasMessageServerAgents) {\n\t\t\t\t// Neither table exists - RuntimeMigrator will create message_server_agents\n\t\t\t\tlogger.debug(\"[Migration] ⊘ No server_agents table to migrate\");\n\t\t\t} else if (hasMessageServerAgents) {\n\t\t\t\t// Check if it has the columns and rename if needed\n\t\t\t\tlogger.debug(\"[Migration] → Checking message_server_agents columns...\");\n\t\t\t\tconst columnsResult = await db.execute(sql`\n SELECT column_name\n FROM information_schema.columns\n WHERE table_schema = 'public'\n AND table_name = 'message_server_agents'\n AND column_name IN ('server_id', 'message_server_id')\n ORDER BY column_name\n `);\n\n\t\t\t\tconst columns = getRows<ColumnInfoRow>(columnsResult);\n\t\t\t\tconst hasServerId = columns.some((c) => c.column_name === \"server_id\");\n\t\t\t\tconst hasMessageServerId = columns.some(\n\t\t\t\t\t(c) => c.column_name === \"message_server_id\",\n\t\t\t\t);\n\n\t\t\t\tif (hasServerId && !hasMessageServerId) {\n\t\t\t\t\t// Rename server_id → message_server_id\n\t\t\t\t\tlogger.debug(\n\t\t\t\t\t\t\"[Migration] → Renaming message_server_agents.server_id to message_server_id...\",\n\t\t\t\t\t);\n\t\t\t\t\tawait db.execute(\n\t\t\t\t\t\tsql.raw(\n\t\t\t\t\t\t\t`ALTER TABLE \"message_server_agents\" RENAME COLUMN \"server_id\" TO \"message_server_id\"`,\n\t\t\t\t\t\t),\n\t\t\t\t\t);\n\t\t\t\t\tlogger.debug(\n\t\t\t\t\t\t\"[Migration] ✓ Renamed message_server_agents.server_id → message_server_id\",\n\t\t\t\t\t);\n\t\t\t\t} else if (!hasServerId && !hasMessageServerId) {\n\t\t\t\t\t// Table exists but doesn't have either column - truncate it\n\t\t\t\t\tlogger.debug(\n\t\t\t\t\t\t\"[Migration] → message_server_agents exists without required columns, truncating...\",\n\t\t\t\t\t);\n\t\t\t\t\tawait db.execute(sql`TRUNCATE TABLE message_server_agents CASCADE`);\n\t\t\t\t\tlogger.debug(\"[Migration] ✓ Truncated message_server_agents\");\n\t\t\t\t} else {\n\t\t\t\t\tlogger.debug(\n\t\t\t\t\t\t\"[Migration] ⊘ message_server_agents already has correct schema\",\n\t\t\t\t\t);\n\t\t\t\t}\n\t\t\t}\n\t\t} catch (_error) {\n\t\t\tlogger.debug(\"[Migration] ⊘ Could not check/migrate server_agents table\");\n\t\t}\n\n\t\t// Special handling for channel_participants: rename userId → entityId\n\t\t// This handles the migration from the old userId column to the new entityId column\n\t\tlogger.debug(\"[Migration] → Checking channel_participants table...\");\n\t\ttry {\n\t\t\tconst columnsResult = await db.execute(sql`\n SELECT column_name\n FROM information_schema.columns\n WHERE table_schema = 'public'\n AND table_name = 'channel_participants'\n AND column_name IN ('user_id', 'entity_id')\n ORDER BY column_name\n `);\n\n\t\t\tconst columns = getRows<ColumnInfoRow>({\n\t\t\t\trows: columnsResult.rows || [],\n\t\t\t});\n\t\t\tconst hasUserId = columns.some((c) => c.column_name === \"user_id\");\n\t\t\tconst hasEntityId = columns.some((c) => c.column_name === \"entity_id\");\n\n\t\t\tif (hasUserId && !hasEntityId) {\n\t\t\t\t// Rename user_id → entity_id\n\t\t\t\tlogger.debug(\n\t\t\t\t\t\"[Migration] → Renaming channel_participants.user_id to entity_id...\",\n\t\t\t\t);\n\t\t\t\tawait db.execute(\n\t\t\t\t\tsql.raw(\n\t\t\t\t\t\t`ALTER TABLE \"channel_participants\" RENAME COLUMN \"user_id\" TO \"entity_id\"`,\n\t\t\t\t\t),\n\t\t\t\t);\n\t\t\t\tlogger.debug(\n\t\t\t\t\t\"[Migration] ✓ Renamed channel_participants.user_id → entity_id\",\n\t\t\t\t);\n\t\t\t} else if (!hasUserId && !hasEntityId) {\n\t\t\t\t// Table exists but has neither column - truncate it so RuntimeMigrator can add entity_id\n\t\t\t\tlogger.debug(\n\t\t\t\t\t\"[Migration] → channel_participants exists without entity_id or user_id, truncating...\",\n\t\t\t\t);\n\t\t\t\tawait db.execute(sql`TRUNCATE TABLE channel_participants CASCADE`);\n\t\t\t\tlogger.debug(\"[Migration] ✓ Truncated channel_participants\");\n\t\t\t} else {\n\t\t\t\tlogger.debug(\n\t\t\t\t\t\"[Migration] ⊘ channel_participants already has entity_id column\",\n\t\t\t\t);\n\t\t\t}\n\t\t} catch (_error) {\n\t\t\tlogger.debug(\n\t\t\t\t\"[Migration] ⊘ Could not check/migrate channel_participants\",\n\t\t\t);\n\t\t}\n\n\t\t// Drop ALL regular indexes (not PK or unique constraints) to avoid conflicts\n\t\t// The RuntimeMigrator will recreate them based on the schema\n\t\tlogger.debug(\n\t\t\t\"[Migration] → Discovering and dropping all regular indexes...\",\n\t\t);\n\t\ttry {\n\t\t\tconst indexesResult = await db.execute(sql`\n SELECT i.relname AS index_name\n FROM pg_index idx\n JOIN pg_class i ON i.oid = idx.indexrelid\n JOIN pg_class c ON c.oid = idx.indrelid\n JOIN pg_namespace n ON n.oid = c.relnamespace\n LEFT JOIN pg_constraint con ON con.conindid = idx.indexrelid\n WHERE n.nspname = 'public'\n AND NOT idx.indisprimary -- Not a primary key\n AND con.contype IS NULL -- Not a constraint (unique, etc)\n ORDER BY i.relname\n `);\n\n\t\t\tconst indexesToDrop = indexesResult.rows || [];\n\t\t\tlogger.debug(\n\t\t\t\t`[Migration] → Found ${indexesToDrop.length} indexes to drop`,\n\t\t\t);\n\n\t\t\tfor (const row of indexesToDrop) {\n\t\t\t\tconst indexName = row.index_name as string;\n\t\t\t\ttry {\n\t\t\t\t\tawait db.execute(sql.raw(`DROP INDEX IF EXISTS \"${indexName}\"`));\n\t\t\t\t\tlogger.debug(`[Migration] ✓ Dropped index ${indexName}`);\n\t\t\t\t} catch (_error) {\n\t\t\t\t\tlogger.debug(`[Migration] ⊘ Could not drop index ${indexName}`);\n\t\t\t\t}\n\t\t\t}\n\t\t} catch (_error) {\n\t\t\tlogger.debug(\n\t\t\t\t\"[Migration] ⊘ Could not drop indexes (may not have permissions)\",\n\t\t\t);\n\t\t}\n\n\t\t// =========================================================================\n\t\t// SMOOTH MIGRATION: camelCase → snake_case column renames\n\t\t// This ensures a non-destructive transition from v1.6.4 to v1.6.5+\n\t\t// All data is preserved through RENAME COLUMN operations\n\t\t// This section can be removed once all deployments have been migrated\n\t\t// =========================================================================\n\t\tlogger.debug(\n\t\t\t\"[Migration] → Starting camelCase → snake_case column renames...\",\n\t\t);\n\n\t\tconst columnRenames = [\n\t\t\t// rooms table\n\t\t\t{ table: \"rooms\", from: \"agentId\", to: \"agent_id\" },\n\t\t\t{ table: \"rooms\", from: \"worldId\", to: \"world_id\" },\n\t\t\t{ table: \"rooms\", from: \"channelId\", to: \"channel_id\" },\n\t\t\t{ table: \"rooms\", from: \"createdAt\", to: \"created_at\" },\n\n\t\t\t// worlds table\n\t\t\t{ table: \"worlds\", from: \"agentId\", to: \"agent_id\" },\n\t\t\t{ table: \"worlds\", from: \"createdAt\", to: \"created_at\" },\n\n\t\t\t// memories table\n\t\t\t{ table: \"memories\", from: \"createdAt\", to: \"created_at\" },\n\t\t\t{ table: \"memories\", from: \"entityId\", to: \"entity_id\" },\n\t\t\t{ table: \"memories\", from: \"agentId\", to: \"agent_id\" },\n\t\t\t{ table: \"memories\", from: \"roomId\", to: \"room_id\" },\n\t\t\t{ table: \"memories\", from: \"worldId\", to: \"world_id\" },\n\n\t\t\t// components table\n\t\t\t{ table: \"components\", from: \"entityId\", to: \"entity_id\" },\n\t\t\t{ table: \"components\", from: \"agentId\", to: \"agent_id\" },\n\t\t\t{ table: \"components\", from: \"roomId\", to: \"room_id\" },\n\t\t\t{ table: \"components\", from: \"worldId\", to: \"world_id\" },\n\t\t\t{ table: \"components\", from: \"sourceEntityId\", to: \"source_entity_id\" },\n\t\t\t{ table: \"components\", from: \"createdAt\", to: \"created_at\" },\n\n\t\t\t// participants table\n\t\t\t{ table: \"participants\", from: \"entityId\", to: \"entity_id\" },\n\t\t\t{ table: \"participants\", from: \"roomId\", to: \"room_id\" },\n\t\t\t{ table: \"participants\", from: \"agentId\", to: \"agent_id\" },\n\t\t\t{ table: \"participants\", from: \"roomState\", to: \"room_state\" },\n\t\t\t{ table: \"participants\", from: \"createdAt\", to: \"created_at\" },\n\n\t\t\t// relationships table\n\t\t\t{\n\t\t\t\ttable: \"relationships\",\n\t\t\t\tfrom: \"sourceEntityId\",\n\t\t\t\tto: \"source_entity_id\",\n\t\t\t},\n\t\t\t{\n\t\t\t\ttable: \"relationships\",\n\t\t\t\tfrom: \"targetEntityId\",\n\t\t\t\tto: \"target_entity_id\",\n\t\t\t},\n\t\t\t{ table: \"relationships\", from: \"agentId\", to: \"agent_id\" },\n\t\t\t{ table: \"relationships\", from: \"createdAt\", to: \"created_at\" },\n\n\t\t\t// logs table\n\t\t\t{ table: \"logs\", from: \"entityId\", to: \"entity_id\" },\n\t\t\t{ table: \"logs\", from: \"roomId\", to: \"room_id\" },\n\t\t\t{ table: \"logs\", from: \"createdAt\", to: \"created_at\" },\n\n\t\t\t// tasks table\n\t\t\t{ table: \"tasks\", from: \"roomId\", to: \"room_id\" },\n\t\t\t{ table: \"tasks\", from: \"worldId\", to: \"world_id\" },\n\t\t\t{ table: \"tasks\", from: \"entityId\", to: \"entity_id\" },\n\t\t\t{ table: \"tasks\", from: \"createdAt\", to: \"created_at\" },\n\t\t\t{ table: \"tasks\", from: \"updatedAt\", to: \"updated_at\" },\n\n\t\t\t// agents table\n\t\t\t{ table: \"agents\", from: \"createdAt\", to: \"created_at\" },\n\t\t\t{ table: \"agents\", from: \"updatedAt\", to: \"updated_at\" },\n\n\t\t\t// entities table\n\t\t\t{ table: \"entities\", from: \"agentId\", to: \"agent_id\" },\n\t\t\t{ table: \"entities\", from: \"createdAt\", to: \"created_at\" },\n\n\t\t\t// embeddings table\n\t\t\t{ table: \"embeddings\", from: \"memoryId\", to: \"memory_id\" },\n\t\t\t{ table: \"embeddings\", from: \"createdAt\", to: \"created_at\" },\n\n\t\t\t// cache table\n\t\t\t{ table: \"cache\", from: \"agentId\", to: \"agent_id\" },\n\t\t\t{ table: \"cache\", from: \"createdAt\", to: \"created_at\" },\n\t\t\t{ table: \"cache\", from: \"expiresAt\", to: \"expires_at\" },\n\t\t];\n\n\t\tfor (const rename of columnRenames) {\n\t\t\ttry {\n\t\t\t\t// Check if table exists first\n\t\t\t\tconst tableExistsResult = await db.execute(sql`\n SELECT 1 FROM information_schema.tables\n WHERE table_schema = 'public' AND table_name = ${rename.table}\n `);\n\n\t\t\t\tif (!tableExistsResult.rows || tableExistsResult.rows.length === 0) {\n\t\t\t\t\t// Table doesn't exist yet, skip\n\t\t\t\t\tcontinue;\n\t\t\t\t}\n\n\t\t\t\t// Check which columns exist\n\t\t\t\tconst columnsResult = await db.execute(sql`\n SELECT column_name\n FROM information_schema.columns\n WHERE table_schema = 'public'\n AND table_name = ${rename.table}\n AND column_name IN (${rename.from}, ${rename.to})\n ORDER BY column_name\n `);\n\n\t\t\t\tconst columns = getRows<ColumnInfoRow>(columnsResult);\n\t\t\t\tconst hasOldColumn = columns.some((c) => c.column_name === rename.from);\n\t\t\t\tconst hasNewColumn = columns.some((c) => c.column_name === rename.to);\n\n\t\t\t\tif (hasOldColumn && !hasNewColumn) {\n\t\t\t\t\t// Old column exists, new doesn't → RENAME (preserves data!)\n\t\t\t\t\tlogger.debug(\n\t\t\t\t\t\t`[Migration] → Renaming ${rename.table}.${rename.from} to ${rename.to}...`,\n\t\t\t\t\t);\n\t\t\t\t\tawait db.execute(\n\t\t\t\t\t\tsql.raw(\n\t\t\t\t\t\t\t`ALTER TABLE \"${rename.table}\" RENAME COLUMN \"${rename.from}\" TO \"${rename.to}\"`,\n\t\t\t\t\t\t),\n\t\t\t\t\t);\n\t\t\t\t\tlogger.debug(\n\t\t\t\t\t\t`[Migration] ✓ Renamed ${rename.table}.${rename.from} → ${rename.to}`,\n\t\t\t\t\t);\n\t\t\t\t} else if (hasOldColumn && hasNewColumn) {\n\t\t\t\t\t// Both exist → drop old (data should be in new already)\n\t\t\t\t\tlogger.debug(\n\t\t\t\t\t\t`[Migration] → Both columns exist, dropping ${rename.table}.${rename.from}...`,\n\t\t\t\t\t);\n\t\t\t\t\tawait db.execute(\n\t\t\t\t\t\tsql.raw(\n\t\t\t\t\t\t\t`ALTER TABLE \"${rename.table}\" DROP COLUMN \"${rename.from}\" CASCADE`,\n\t\t\t\t\t\t),\n\t\t\t\t\t);\n\t\t\t\t\tlogger.debug(`[Migration] ✓ Dropped ${rename.table}.${rename.from}`);\n\t\t\t\t}\n\t\t\t\t// If only new column exists or neither exists, nothing to do\n\t\t\t} catch (error) {\n\t\t\t\t// Log but continue - table might not exist yet or column might already be renamed\n\t\t\t\tlogger.debug(\n\t\t\t\t\t`[Migration] ⊘ Could not process ${rename.table}.${rename.from}: ${error}`,\n\t\t\t\t);\n\t\t\t}\n\t\t}\n\n\t\tlogger.debug(\n\t\t\t\"[Migration] ✓ Completed camelCase → snake_case column renames\",\n\t\t);\n\n\t\tlogger.info(\n\t\t\t\"[Migration] ✓ Migration complete - pre-1.6.5 → 1.6.5+ schema migration finished\",\n\t\t);\n\t} catch (error) {\n\t\t// Re-throw errors to prevent RuntimeMigrator from running on broken state\n\t\tlogger.error(\"[Migration] Migration failed:\", String(error));\n\t\tthrow error;\n\t}\n}\n",
104
+ "import { type IDatabaseAdapter, logger, validateUuid } from \"@elizaos/core\";\nimport { eq, sql } from \"drizzle-orm\";\nimport { agentTable } from \"./schema/agent\";\nimport { serverTable } from \"./schema/server\";\nimport { getDb } from \"./types\";\n\nexport async function installRLSFunctions(\n\tadapter: IDatabaseAdapter,\n): Promise<void> {\n\tconst db = getDb(adapter);\n\n\tawait db.execute(sql`\n CREATE TABLE IF NOT EXISTS servers (\n id UUID PRIMARY KEY,\n created_at TIMESTAMPTZ DEFAULT NOW() NOT NULL,\n updated_at TIMESTAMPTZ DEFAULT NOW() NOT NULL\n )\n `);\n\n\tawait db.execute(sql`\n CREATE OR REPLACE FUNCTION current_server_id() RETURNS UUID AS $$\n DECLARE\n app_name TEXT;\n BEGIN\n app_name := NULLIF(current_setting('application_name', TRUE), '');\n\n BEGIN\n RETURN app_name::UUID;\n EXCEPTION WHEN OTHERS THEN\n RETURN NULL;\n END;\n END;\n $$ LANGUAGE plpgsql STABLE;\n `);\n\n\tawait db.execute(sql`\n CREATE OR REPLACE FUNCTION add_server_isolation(\n schema_name text,\n table_name text\n ) RETURNS void AS $$\n DECLARE\n full_table_name text;\n column_exists boolean;\n orphaned_count bigint;\n BEGIN\n full_table_name := schema_name || '.' || table_name;\n\n SELECT EXISTS (\n SELECT 1 FROM information_schema.columns\n WHERE information_schema.columns.table_schema = schema_name\n AND information_schema.columns.table_name = add_server_isolation.table_name\n AND information_schema.columns.column_name = 'server_id'\n ) INTO column_exists;\n\n IF NOT column_exists THEN\n EXECUTE format('ALTER TABLE %I.%I ADD COLUMN server_id UUID DEFAULT current_server_id()', schema_name, table_name);\n EXECUTE format('UPDATE %I.%I SET server_id = current_server_id() WHERE server_id IS NULL', schema_name, table_name);\n ELSE\n EXECUTE format('ALTER TABLE %I.%I ALTER COLUMN server_id SET DEFAULT current_server_id()', schema_name, table_name);\n EXECUTE format('SELECT COUNT(*) FROM %I.%I WHERE server_id IS NULL', schema_name, table_name) INTO orphaned_count;\n\n IF orphaned_count > 0 THEN\n RAISE NOTICE 'Backfilling % rows with NULL server_id in %.%', orphaned_count, schema_name, table_name;\n EXECUTE format('UPDATE %I.%I SET server_id = current_server_id() WHERE server_id IS NULL', schema_name, table_name);\n END IF;\n END IF;\n\n EXECUTE format('CREATE INDEX IF NOT EXISTS idx_%I_server_id ON %I.%I(server_id)', table_name, schema_name, table_name);\n EXECUTE format('ALTER TABLE %I.%I ENABLE ROW LEVEL SECURITY', schema_name, table_name);\n EXECUTE format('ALTER TABLE %I.%I FORCE ROW LEVEL SECURITY', schema_name, table_name);\n EXECUTE format('DROP POLICY IF EXISTS server_isolation_policy ON %I.%I', schema_name, table_name);\n EXECUTE format('\n CREATE POLICY server_isolation_policy ON %I.%I\n USING (server_id = current_server_id())\n WITH CHECK (server_id = current_server_id())\n ', schema_name, table_name);\n END;\n $$ LANGUAGE plpgsql;\n `);\n\n\tawait db.execute(sql`\n CREATE OR REPLACE FUNCTION apply_rls_to_all_tables() RETURNS void AS $$\n DECLARE\n tbl record;\n BEGIN\n FOR tbl IN\n SELECT schemaname, tablename\n FROM pg_tables\n WHERE schemaname = 'public'\n AND tablename NOT IN (\n 'servers',\n 'drizzle_migrations',\n '__drizzle_migrations'\n )\n LOOP\n BEGIN\n PERFORM add_server_isolation(tbl.schemaname, tbl.tablename);\n EXCEPTION WHEN OTHERS THEN\n RAISE WARNING 'Failed to apply RLS to %.%: %', tbl.schemaname, tbl.tablename, SQLERRM;\n END;\n END LOOP;\n END;\n $$ LANGUAGE plpgsql;\n `);\n\n\tlogger.info({ src: \"plugin:sql\" }, \"RLS PostgreSQL functions installed\");\n\tawait installEntityRLS(adapter);\n}\n\nexport async function getOrCreateRlsServer(\n\tadapter: IDatabaseAdapter,\n\tserverId: string,\n): Promise<string> {\n\tconst db = getDb(adapter);\n\n\t// Use Drizzle's insert with onConflictDoNothing\n\tawait db\n\t\t.insert(serverTable)\n\t\t.values({\n\t\t\tid: serverId,\n\t\t})\n\t\t.onConflictDoNothing();\n\n\tlogger.info(\n\t\t{ src: \"plugin:sql\", serverId: serverId.slice(0, 8) },\n\t\t\"RLS server registered\",\n\t);\n\treturn serverId;\n}\n\nexport async function setServerContext(\n\tadapter: IDatabaseAdapter,\n\tserverId: string,\n): Promise<void> {\n\tif (!validateUuid(serverId)) {\n\t\tthrow new Error(\n\t\t\t`Invalid server ID format: ${serverId}. Must be a valid UUID.`,\n\t\t);\n\t}\n\n\tconst db = getDb(adapter);\n\tconst servers = await db\n\t\t.select()\n\t\t.from(serverTable)\n\t\t.where(eq(serverTable.id, serverId));\n\n\tif (servers.length === 0) {\n\t\tthrow new Error(`Server ${serverId} does not exist`);\n\t}\n\n\tlogger.info(\n\t\t{ src: \"plugin:sql\", serverId: serverId.slice(0, 8) },\n\t\t\"RLS context configured\",\n\t);\n}\n\nexport async function assignAgentToServer(\n\tadapter: IDatabaseAdapter,\n\tagentId: string,\n\tserverId: string,\n): Promise<void> {\n\tif (!agentId || !serverId) {\n\t\tlogger.warn(\n\t\t\t`[Data Isolation] Cannot assign agent to server: invalid agentId (${agentId}) or serverId (${serverId})`,\n\t\t);\n\t\treturn;\n\t}\n\n\tconst db = getDb(adapter);\n\n\t// Check if agent exists using Drizzle\n\tconst agents = await db\n\t\t.select()\n\t\t.from(agentTable)\n\t\t.where(eq(agentTable.id, agentId));\n\n\tif (agents.length > 0) {\n\t\tconst agent = agents[0];\n\t\tconst currentServerId = agent.server_id;\n\n\t\tif (currentServerId === serverId) {\n\t\t\tlogger.debug(\n\t\t\t\t{ src: \"plugin:sql\", agentName: agent.name },\n\t\t\t\t\"Agent already assigned to correct server\",\n\t\t\t);\n\t\t} else {\n\t\t\t// Update agent server using Drizzle\n\t\t\tawait db\n\t\t\t\t.update(agentTable)\n\t\t\t\t.set({ server_id: serverId })\n\t\t\t\t.where(eq(agentTable.id, agentId));\n\n\t\t\tif (currentServerId === null) {\n\t\t\t\tlogger.info(\n\t\t\t\t\t{ src: \"plugin:sql\", agentName: agent.name },\n\t\t\t\t\t\"Agent assigned to server\",\n\t\t\t\t);\n\t\t\t} else {\n\t\t\t\tlogger.warn(\n\t\t\t\t\t{ src: \"plugin:sql\", agentName: agent.name },\n\t\t\t\t\t\"Agent server changed\",\n\t\t\t\t);\n\t\t\t}\n\t\t}\n\t} else {\n\t\tlogger.debug({ src: \"plugin:sql\", agentId }, \"Agent does not exist yet\");\n\t}\n}\n\n/**\n * Apply RLS to all tables by calling PostgreSQL function\n */\nexport async function applyRLSToNewTables(\n\tadapter: IDatabaseAdapter,\n): Promise<void> {\n\tconst db = getDb(adapter);\n\n\ttry {\n\t\tawait db.execute(sql`SELECT apply_rls_to_all_tables()`);\n\t\tlogger.info({ src: \"plugin:sql\" }, \"RLS applied to all tables\");\n\t} catch (error) {\n\t\tlogger.warn(\n\t\t\t{ src: \"plugin:sql\", error: String(error) },\n\t\t\t\"Failed to apply RLS to some tables\",\n\t\t);\n\t}\n}\n\nexport async function uninstallRLS(adapter: IDatabaseAdapter): Promise<void> {\n\tconst db = getDb(adapter);\n\n\ttry {\n\t\tconst checkResult = await db.execute(sql`\n SELECT EXISTS (\n SELECT FROM pg_tables\n WHERE schemaname = 'public' AND tablename = 'servers'\n ) as rls_enabled\n `);\n\n\t\tconst rlsEnabled = checkResult.rows?.[0]?.rls_enabled;\n\n\t\tif (!rlsEnabled) {\n\t\t\tlogger.debug(\n\t\t\t\t{ src: \"plugin:sql\" },\n\t\t\t\t\"RLS not installed, skipping cleanup\",\n\t\t\t);\n\t\t\treturn;\n\t\t}\n\n\t\tlogger.info(\n\t\t\t{ src: \"plugin:sql\" },\n\t\t\t\"Disabling RLS globally (keeping server_id columns for schema compatibility)...\",\n\t\t);\n\n\t\ttry {\n\t\t\tawait uninstallEntityRLS(adapter);\n\t\t} catch (_entityRlsError) {\n\t\t\tlogger.debug(\n\t\t\t\t{ src: \"plugin:sql\" },\n\t\t\t\t\"Entity RLS cleanup skipped (not installed or already cleaned)\",\n\t\t\t);\n\t\t}\n\n\t\tawait db.execute(sql`\n CREATE OR REPLACE FUNCTION _temp_disable_rls_on_table(\n p_schema_name text,\n p_table_name text\n ) RETURNS void AS $$\n DECLARE\n policy_rec record;\n BEGIN\n -- Drop all policies on this table\n FOR policy_rec IN\n SELECT policyname\n FROM pg_policies\n WHERE schemaname = p_schema_name AND tablename = p_table_name\n LOOP\n EXECUTE format('DROP POLICY IF EXISTS %I ON %I.%I',\n policy_rec.policyname, p_schema_name, p_table_name);\n END LOOP;\n\n -- Disable RLS\n EXECUTE format('ALTER TABLE %I.%I NO FORCE ROW LEVEL SECURITY', p_schema_name, p_table_name);\n EXECUTE format('ALTER TABLE %I.%I DISABLE ROW LEVEL SECURITY', p_schema_name, p_table_name);\n END;\n $$ LANGUAGE plpgsql;\n `);\n\n\t\tconst tablesResult = await db.execute(sql`\n SELECT schemaname, tablename\n FROM pg_tables\n WHERE schemaname = 'public'\n AND tablename NOT IN ('drizzle_migrations', '__drizzle_migrations')\n `);\n\n\t\tfor (const row of tablesResult.rows || []) {\n\t\t\tconst schemaName = row.schemaname;\n\t\t\tconst tableName = row.tablename;\n\n\t\t\ttry {\n\t\t\t\tawait db.execute(\n\t\t\t\t\tsql`SELECT _temp_disable_rls_on_table(${schemaName}, ${tableName})`,\n\t\t\t\t);\n\t\t\t\tlogger.debug(\n\t\t\t\t\t{ src: \"plugin:sql\", schemaName, tableName },\n\t\t\t\t\t\"Disabled RLS on table\",\n\t\t\t\t);\n\t\t\t} catch (error) {\n\t\t\t\tlogger.warn(\n\t\t\t\t\t{ src: \"plugin:sql\", schemaName, tableName, error: String(error) },\n\t\t\t\t\t\"Failed to disable RLS on table\",\n\t\t\t\t);\n\t\t\t}\n\t\t}\n\n\t\tawait db.execute(\n\t\t\tsql`DROP FUNCTION IF EXISTS _temp_disable_rls_on_table(text, text)`,\n\t\t);\n\n\t\tlogger.info(\n\t\t\t{ src: \"plugin:sql\" },\n\t\t\t\"Keeping server_id values intact (prevents data theft on re-enable)\",\n\t\t);\n\n\t\tlogger.info({ src: \"plugin:sql\" }, \"Clearing servers table...\");\n\t\tawait db.execute(sql`TRUNCATE TABLE servers`);\n\n\t\tawait db.execute(\n\t\t\tsql`DROP FUNCTION IF EXISTS apply_rls_to_all_tables() CASCADE`,\n\t\t);\n\t\tawait db.execute(\n\t\t\tsql`DROP FUNCTION IF EXISTS add_server_isolation(text, text) CASCADE`,\n\t\t);\n\t\tawait db.execute(sql`DROP FUNCTION IF EXISTS current_server_id() CASCADE`);\n\t\tlogger.info({ src: \"plugin:sql\" }, \"Dropped all RLS functions\");\n\n\t\tlogger.info(\n\t\t\t{ src: \"plugin:sql\" },\n\t\t\t\"RLS disabled successfully (server_id columns preserved)\",\n\t\t);\n\t} catch (error) {\n\t\tlogger.error(\n\t\t\t{ src: \"plugin:sql\", error: String(error) },\n\t\t\t\"Failed to disable RLS\",\n\t\t);\n\t\tthrow error;\n\t}\n}\n\nexport async function installEntityRLS(\n\tadapter: IDatabaseAdapter,\n): Promise<void> {\n\tconst db = getDb(adapter);\n\n\tlogger.info(\"[Entity RLS] Installing entity RLS functions and policies...\");\n\n\tawait db.execute(sql`\n CREATE OR REPLACE FUNCTION current_entity_id()\n RETURNS UUID AS $$\n DECLARE\n entity_id_text TEXT;\n BEGIN\n -- Read from transaction-local variable\n entity_id_text := NULLIF(current_setting('app.entity_id', TRUE), '');\n\n IF entity_id_text IS NULL OR entity_id_text = '' THEN\n RETURN NULL;\n END IF;\n\n BEGIN\n RETURN entity_id_text::UUID;\n EXCEPTION WHEN OTHERS THEN\n RETURN NULL;\n END;\n END;\n $$ LANGUAGE plpgsql STABLE;\n `);\n\n\tlogger.info(\"[Entity RLS] Created current_entity_id() function\");\n\n\t// 2. Create add_entity_isolation() function - applies entity RLS to a single table\n\tawait db.execute(sql`\n CREATE OR REPLACE FUNCTION add_entity_isolation(\n schema_name text,\n table_name text,\n require_entity boolean DEFAULT false\n ) RETURNS void AS $$\n DECLARE\n full_table_name text;\n has_entity_id boolean;\n has_author_id boolean;\n has_channel_id boolean;\n has_room_id boolean;\n entity_column_name text;\n room_column_name text;\n BEGIN\n full_table_name := schema_name || '.' || table_name;\n\n SELECT EXISTS (\n SELECT 1 FROM information_schema.columns\n WHERE information_schema.columns.table_schema = schema_name\n AND information_schema.columns.table_name = add_entity_isolation.table_name\n AND information_schema.columns.column_name = 'entity_id'\n ) INTO has_entity_id;\n\n SELECT EXISTS (\n SELECT 1 FROM information_schema.columns\n WHERE information_schema.columns.table_schema = schema_name\n AND information_schema.columns.table_name = add_entity_isolation.table_name\n AND information_schema.columns.column_name = 'author_id'\n ) INTO has_author_id;\n\n SELECT EXISTS (\n SELECT 1 FROM information_schema.columns\n WHERE information_schema.columns.table_schema = schema_name\n AND information_schema.columns.table_name = add_entity_isolation.table_name\n AND information_schema.columns.column_name = 'room_id'\n ) INTO has_room_id;\n\n IF NOT (has_entity_id OR has_author_id OR has_room_id) THEN\n RAISE NOTICE '[Entity RLS] Skipping %.%: no entity columns found', schema_name, table_name;\n RETURN;\n END IF;\n\n IF table_name = 'participants' AND has_entity_id THEN\n entity_column_name := 'entity_id';\n room_column_name := NULL;\n ELSIF has_room_id THEN\n room_column_name := 'room_id';\n entity_column_name := NULL;\n ELSIF has_entity_id THEN\n entity_column_name := 'entity_id';\n room_column_name := NULL;\n ELSIF has_author_id THEN\n entity_column_name := 'author_id';\n room_column_name := NULL;\n ELSE\n entity_column_name := NULL;\n room_column_name := NULL;\n END IF;\n\n EXECUTE format('ALTER TABLE %I.%I ENABLE ROW LEVEL SECURITY', schema_name, table_name);\n EXECUTE format('ALTER TABLE %I.%I FORCE ROW LEVEL SECURITY', schema_name, table_name);\n EXECUTE format('DROP POLICY IF EXISTS entity_isolation_policy ON %I.%I', schema_name, table_name);\n\n IF room_column_name IS NOT NULL THEN\n IF require_entity THEN\n EXECUTE format('\n CREATE POLICY entity_isolation_policy ON %I.%I\n AS RESTRICTIVE\n USING (\n current_entity_id() IS NOT NULL\n AND %I IN (\n SELECT room_id\n FROM participants\n WHERE entity_id = current_entity_id()\n )\n )\n WITH CHECK (\n current_entity_id() IS NOT NULL\n AND %I IN (\n SELECT room_id\n FROM participants\n WHERE entity_id = current_entity_id()\n )\n )\n ', schema_name, table_name, room_column_name, room_column_name);\n RAISE NOTICE '[Entity RLS] Applied STRICT RESTRICTIVE to %.% (via % → participants.room_id, entity REQUIRED)', schema_name, table_name, room_column_name;\n ELSE\n EXECUTE format('\n CREATE POLICY entity_isolation_policy ON %I.%I\n AS RESTRICTIVE\n USING (\n current_entity_id() IS NULL\n OR %I IN (\n SELECT room_id\n FROM participants\n WHERE entity_id = current_entity_id()\n )\n )\n WITH CHECK (\n current_entity_id() IS NULL\n OR %I IN (\n SELECT room_id\n FROM participants\n WHERE entity_id = current_entity_id()\n )\n )\n ', schema_name, table_name, room_column_name, room_column_name);\n RAISE NOTICE '[Entity RLS] Applied PERMISSIVE RESTRICTIVE to %.% (via % → participants.room_id, NULL allowed)', schema_name, table_name, room_column_name;\n END IF;\n\n ELSIF entity_column_name IS NOT NULL THEN\n IF require_entity THEN\n EXECUTE format('\n CREATE POLICY entity_isolation_policy ON %I.%I\n AS RESTRICTIVE\n USING (\n current_entity_id() IS NOT NULL\n AND %I = current_entity_id()\n )\n WITH CHECK (\n current_entity_id() IS NOT NULL\n AND %I = current_entity_id()\n )\n ', schema_name, table_name, entity_column_name, entity_column_name);\n RAISE NOTICE '[Entity RLS] Applied STRICT RESTRICTIVE to %.% (direct column: %, entity REQUIRED)', schema_name, table_name, entity_column_name;\n ELSE\n -- PERMISSIVE MODE: NULL entity_id allows system/admin access\n EXECUTE format('\n CREATE POLICY entity_isolation_policy ON %I.%I\n AS RESTRICTIVE\n USING (\n current_entity_id() IS NULL\n OR %I = current_entity_id()\n )\n WITH CHECK (\n current_entity_id() IS NULL\n OR %I = current_entity_id()\n )\n ', schema_name, table_name, entity_column_name, entity_column_name);\n RAISE NOTICE '[Entity RLS] Applied PERMISSIVE RESTRICTIVE to %.% (direct column: %, NULL allowed)', schema_name, table_name, entity_column_name;\n END IF;\n END IF;\n\n IF room_column_name IS NOT NULL THEN\n EXECUTE format('CREATE INDEX IF NOT EXISTS idx_%I_room ON %I.%I(%I)',\n table_name, schema_name, table_name, room_column_name);\n END IF;\n\n IF entity_column_name IS NOT NULL THEN\n EXECUTE format('CREATE INDEX IF NOT EXISTS idx_%I_entity ON %I.%I(%I)',\n table_name, schema_name, table_name, entity_column_name);\n END IF;\n END;\n $$ LANGUAGE plpgsql;\n `);\n\n\tlogger.info(\"[Entity RLS] Created add_entity_isolation() function\");\n\n\tawait db.execute(sql`\n CREATE OR REPLACE FUNCTION apply_entity_rls_to_all_tables() RETURNS void AS $$\n DECLARE\n tbl record;\n require_entity_for_table boolean;\n BEGIN\n FOR tbl IN\n SELECT schemaname, tablename\n FROM pg_tables\n WHERE schemaname = 'public'\n AND tablename NOT IN (\n 'servers', -- Server RLS table\n 'users', -- Authentication table (no entity isolation needed)\n 'entity_mappings', -- Mapping table (no entity isolation needed)\n 'drizzle_migrations', -- Migration tracking\n '__drizzle_migrations' -- Migration tracking\n )\n LOOP\n BEGIN\n -- Apply STRICT mode (require_entity=true) to sensitive user-facing tables\n -- These tables MUST have entity context set to access data\n -- STRICT tables: memories, logs, components, tasks (user data requiring isolation)\n -- NOTE: Excluded tables:\n -- - 'participants': Adding participants is a privileged operation during initialization\n IF tbl.tablename IN ('memories', 'logs', 'components', 'tasks') THEN\n require_entity_for_table := true;\n ELSE\n require_entity_for_table := false;\n END IF;\n\n PERFORM add_entity_isolation(tbl.schemaname, tbl.tablename, require_entity_for_table);\n EXCEPTION WHEN OTHERS THEN\n RAISE WARNING '[Entity RLS] Failed to apply to %.%: %', tbl.schemaname, tbl.tablename, SQLERRM;\n END;\n END LOOP;\n END;\n $$ LANGUAGE plpgsql;\n `);\n\n\tlogger.info(\"[Entity RLS] Created apply_entity_rls_to_all_tables() function\");\n\n\tlogger.info(\"[Entity RLS] Entity RLS functions installed successfully\");\n}\n\nexport async function applyEntityRLSToAllTables(\n\tadapter: IDatabaseAdapter,\n): Promise<void> {\n\tconst db = getDb(adapter);\n\n\ttry {\n\t\tawait db.execute(sql`SELECT apply_entity_rls_to_all_tables()`);\n\t\tlogger.info(\"[Entity RLS] Applied entity RLS to all eligible tables\");\n\t} catch (error) {\n\t\tlogger.warn(\n\t\t\t\"[Entity RLS] Failed to apply entity RLS to some tables:\",\n\t\t\tString(error),\n\t\t);\n\t}\n}\n\nexport async function uninstallEntityRLS(\n\tadapter: IDatabaseAdapter,\n): Promise<void> {\n\tconst db = getDb(adapter);\n\n\tlogger.info(\"[Entity RLS] Removing entity RLS policies and functions...\");\n\n\ttry {\n\t\tconst tablesResult = await db.execute(sql`\n SELECT schemaname, tablename\n FROM pg_tables\n WHERE schemaname = 'public'\n AND tablename NOT IN ('drizzle_migrations', '__drizzle_migrations')\n `);\n\n\t\tfor (const row of tablesResult.rows || []) {\n\t\t\tconst schemaName = row.schemaname;\n\t\t\tconst tableName = row.tablename;\n\n\t\t\ttry {\n\t\t\t\tawait db.execute(\n\t\t\t\t\tsql.raw(\n\t\t\t\t\t\t`DROP POLICY IF EXISTS entity_isolation_policy ON \"${schemaName}\".\"${tableName}\"`,\n\t\t\t\t\t),\n\t\t\t\t);\n\t\t\t\tlogger.debug(\n\t\t\t\t\t`[Entity RLS] Dropped entity_isolation_policy from ${schemaName}.${tableName}`,\n\t\t\t\t);\n\t\t\t} catch (_error) {\n\t\t\t\tlogger.debug(\n\t\t\t\t\t`[Entity RLS] No entity policy on ${schemaName}.${tableName}`,\n\t\t\t\t);\n\t\t\t}\n\t\t}\n\n\t\tawait db.execute(\n\t\t\tsql`DROP FUNCTION IF EXISTS apply_entity_rls_to_all_tables() CASCADE`,\n\t\t);\n\t\tawait db.execute(\n\t\t\tsql`DROP FUNCTION IF EXISTS add_entity_isolation(text, text) CASCADE`,\n\t\t);\n\t\tawait db.execute(sql`DROP FUNCTION IF EXISTS current_entity_id() CASCADE`);\n\n\t\tlogger.info(\n\t\t\t\"[Entity RLS] Entity RLS functions and policies removed successfully\",\n\t\t);\n\t} catch (error) {\n\t\tlogger.error(\"[Entity RLS] Failed to remove entity RLS:\", String(error));\n\t\tthrow error;\n\t}\n}\n",
105
+ "import type {\n\tIndexColumn,\n\tSchemaCheckConstraint,\n\tSchemaColumn,\n\tSchemaForeignKey,\n\tSchemaIndex,\n\tSchemaSnapshot,\n\tSchemaUniqueConstraint,\n} from \"../types\";\n\n/**\n * Normalize SQL types for comparison\n * Handles equivalent type variations between introspected DB and schema definitions\n */\nfunction normalizeType(type: string | undefined): string {\n\tif (!type) return \"\";\n\n\tconst normalized = type.toLowerCase().trim();\n\n\t// Handle timestamp variations\n\tif (\n\t\tnormalized === \"timestamp without time zone\" ||\n\t\tnormalized === \"timestamp with time zone\"\n\t) {\n\t\treturn \"timestamp\";\n\t}\n\n\t// Handle serial vs integer with identity\n\t// serial is essentially integer with auto-increment\n\tif (normalized === \"serial\") {\n\t\treturn \"integer\";\n\t}\n\tif (normalized === \"bigserial\") {\n\t\treturn \"bigint\";\n\t}\n\tif (normalized === \"smallserial\") {\n\t\treturn \"smallint\";\n\t}\n\n\t// Handle numeric/decimal equivalence\n\tif (normalized.startsWith(\"numeric\") || normalized.startsWith(\"decimal\")) {\n\t\t// Extract precision and scale if present\n\t\tconst match = normalized.match(/\\((\\d+)(?:,\\s*(\\d+))?\\)/);\n\t\tif (match) {\n\t\t\treturn `numeric(${match[1]}${match[2] ? `,${match[2]}` : \"\"})`;\n\t\t}\n\t\treturn \"numeric\";\n\t}\n\n\t// Handle varchar/character varying\n\tif (normalized.startsWith(\"character varying\")) {\n\t\treturn normalized.replace(\"character varying\", \"varchar\");\n\t}\n\n\t// Handle text array variations\n\tif (normalized === \"text[]\" || normalized === \"_text\") {\n\t\treturn \"text[]\";\n\t}\n\n\treturn normalized;\n}\n\n/**\n * Helper function to compare two index definitions\n * Returns true if indexes are different and need to be recreated\n */\nfunction isIndexChanged(\n\tprevIndex: SchemaIndex,\n\tcurrIndex: SchemaIndex,\n): boolean {\n\t// Compare basic properties\n\tif (prevIndex.isUnique !== currIndex.isUnique) return true;\n\tif (prevIndex.method !== currIndex.method) return true;\n\tif (prevIndex.where !== currIndex.where) return true;\n\tif (prevIndex.concurrently !== currIndex.concurrently) return true;\n\n\t// Compare columns array - must be same columns in same order\n\tconst prevColumns = prevIndex.columns || [];\n\tconst currColumns = currIndex.columns || [];\n\n\tif (prevColumns.length !== currColumns.length) return true;\n\n\tfor (let i = 0; i < prevColumns.length; i++) {\n\t\tconst prevCol = prevColumns[i] as string | IndexColumn;\n\t\tconst currCol = currColumns[i] as string | IndexColumn;\n\n\t\t// Handle both string columns and expression columns\n\t\tif (typeof prevCol === \"string\" && typeof currCol === \"string\") {\n\t\t\tif (prevCol !== currCol) return true;\n\t\t} else if (typeof prevCol === \"object\" && typeof currCol === \"object\") {\n\t\t\t// Compare expression columns\n\t\t\tif (prevCol.expression !== currCol.expression) return true;\n\t\t\tif (prevCol.isExpression !== currCol.isExpression) return true;\n\t\t\tif (prevCol.asc !== currCol.asc) return true;\n\t\t\tif (prevCol.nulls !== currCol.nulls) return true;\n\t\t} else {\n\t\t\t// Type mismatch (one is string, other is object)\n\t\t\treturn true;\n\t\t}\n\t}\n\n\treturn false;\n}\n\n// Column changes interface\nexport interface ColumnChanges {\n\ttypeChanged?: boolean;\n\tprevType?: string;\n\tnewType?: string;\n\tnullabilityChanged?: boolean;\n\twasNullable?: boolean;\n\tisNullable?: boolean;\n\tdefaultChanged?: boolean;\n\tprevDefault?: string | number | boolean;\n\tnewDefault?: string | number | boolean;\n\tfrom?: SchemaColumn;\n\tto?: SchemaColumn;\n}\n\n// Table changes interface\nexport interface TableChanges {\n\tcolumnsAdded: string[];\n\tcolumnsDeleted: string[];\n\tcolumnsModified: string[];\n}\n\nexport interface SchemaDiff {\n\ttables: {\n\t\tcreated: string[];\n\t\tdeleted: string[];\n\t\tmodified: Array<{\n\t\t\tname: string;\n\t\t\tchanges: TableChanges;\n\t\t}>;\n\t};\n\tcolumns: {\n\t\tadded: Array<{\n\t\t\ttable: string;\n\t\t\tcolumn: string;\n\t\t\tdefinition: SchemaColumn;\n\t\t}>;\n\t\tdeleted: Array<{\n\t\t\ttable: string;\n\t\t\tcolumn: string;\n\t\t}>;\n\t\tmodified: Array<{\n\t\t\ttable: string;\n\t\t\tcolumn: string;\n\t\t\tchanges: ColumnChanges;\n\t\t}>;\n\t};\n\tindexes: {\n\t\tcreated: SchemaIndex[];\n\t\tdeleted: SchemaIndex[];\n\t\taltered: Array<{\n\t\t\t// Indexes with same name but different definition\n\t\t\told: SchemaIndex;\n\t\t\tnew: SchemaIndex;\n\t\t}>;\n\t};\n\tforeignKeys: {\n\t\tcreated: SchemaForeignKey[];\n\t\tdeleted: SchemaForeignKey[];\n\t\taltered: Array<{\n\t\t\t// FKs with modified CASCADE behavior\n\t\t\told: SchemaForeignKey;\n\t\t\tnew: SchemaForeignKey;\n\t\t}>;\n\t};\n\tuniqueConstraints: {\n\t\tcreated: SchemaUniqueConstraint[];\n\t\tdeleted: SchemaUniqueConstraint[];\n\t};\n\tcheckConstraints: {\n\t\tcreated: SchemaCheckConstraint[];\n\t\tdeleted: SchemaCheckConstraint[];\n\t};\n}\n\n/**\n * Calculate the difference between two snapshots\n */\nexport async function calculateDiff(\n\tpreviousSnapshot: SchemaSnapshot | null,\n\tcurrentSnapshot: SchemaSnapshot,\n): Promise<SchemaDiff> {\n\tconst diff: SchemaDiff = {\n\t\ttables: {\n\t\t\tcreated: [],\n\t\t\tdeleted: [],\n\t\t\tmodified: [],\n\t\t},\n\t\tcolumns: {\n\t\t\tadded: [],\n\t\t\tdeleted: [],\n\t\t\tmodified: [],\n\t\t},\n\t\tindexes: {\n\t\t\tcreated: [],\n\t\t\tdeleted: [],\n\t\t\taltered: [],\n\t\t},\n\t\tforeignKeys: {\n\t\t\tcreated: [],\n\t\t\tdeleted: [],\n\t\t\taltered: [],\n\t\t},\n\t\tuniqueConstraints: {\n\t\t\tcreated: [],\n\t\t\tdeleted: [],\n\t\t},\n\t\tcheckConstraints: {\n\t\t\tcreated: [],\n\t\t\tdeleted: [],\n\t\t},\n\t};\n\n\t// If no previous snapshot, all tables are new\n\tif (!previousSnapshot) {\n\t\tdiff.tables.created = Object.keys(currentSnapshot.tables);\n\n\t\t// Also track indexes and foreign keys from new tables\n\t\tfor (const tableName in currentSnapshot.tables) {\n\t\t\tconst table = currentSnapshot.tables[tableName];\n\n\t\t\t// Add indexes\n\t\t\tif (table.indexes) {\n\t\t\t\tfor (const indexName in table.indexes) {\n\t\t\t\t\tdiff.indexes.created.push({\n\t\t\t\t\t\t...table.indexes[indexName],\n\t\t\t\t\t\ttable: tableName,\n\t\t\t\t\t} as SchemaIndex & { table: string });\n\t\t\t\t}\n\t\t\t}\n\n\t\t\t// Add foreign keys\n\t\t\tif (table.foreignKeys) {\n\t\t\t\tfor (const fkName in table.foreignKeys) {\n\t\t\t\t\tdiff.foreignKeys.created.push(table.foreignKeys[fkName]);\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\treturn diff;\n\t}\n\n\tconst prevTables = previousSnapshot.tables || {};\n\tconst currTables = currentSnapshot.tables || {};\n\n\t// Find created tables\n\tfor (const tableName in currTables) {\n\t\tif (!(tableName in prevTables)) {\n\t\t\tdiff.tables.created.push(tableName);\n\n\t\t\tconst table = currTables[tableName];\n\n\t\t\t// Add indexes for new table\n\t\t\tif (table.indexes) {\n\t\t\t\tfor (const indexName in table.indexes) {\n\t\t\t\t\tdiff.indexes.created.push({\n\t\t\t\t\t\t...table.indexes[indexName],\n\t\t\t\t\t\ttable: tableName,\n\t\t\t\t\t} as SchemaIndex & { table: string });\n\t\t\t\t}\n\t\t\t}\n\n\t\t\t// Add unique constraints for new table\n\t\t\tif (table.uniqueConstraints) {\n\t\t\t\tfor (const uqName in table.uniqueConstraints) {\n\t\t\t\t\tdiff.uniqueConstraints.created.push({\n\t\t\t\t\t\t...table.uniqueConstraints[uqName],\n\t\t\t\t\t\ttable: tableName,\n\t\t\t\t\t} as SchemaUniqueConstraint & { table: string });\n\t\t\t\t}\n\t\t\t}\n\n\t\t\t// Add check constraints for new table\n\t\t\tif (table.checkConstraints) {\n\t\t\t\tfor (const checkName in table.checkConstraints) {\n\t\t\t\t\tdiff.checkConstraints.created.push({\n\t\t\t\t\t\t...table.checkConstraints[checkName],\n\t\t\t\t\t\ttable: tableName,\n\t\t\t\t\t} as SchemaCheckConstraint & { table: string });\n\t\t\t\t}\n\t\t\t}\n\n\t\t\t// Add foreign keys for new table\n\t\t\tif (table.foreignKeys) {\n\t\t\t\tfor (const fkName in table.foreignKeys) {\n\t\t\t\t\tdiff.foreignKeys.created.push(table.foreignKeys[fkName]);\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n\n\t// Find deleted tables\n\tfor (const tableName in prevTables) {\n\t\tif (!(tableName in currTables)) {\n\t\t\tdiff.tables.deleted.push(tableName);\n\t\t}\n\t}\n\n\t// Find modified tables (check columns, indexes, foreign keys)\n\tfor (const tableName in currTables) {\n\t\tif (tableName in prevTables) {\n\t\t\tconst prevTable = prevTables[tableName];\n\t\t\tconst currTable = currTables[tableName];\n\n\t\t\t// Early check: if the table schemas are identical, skip it entirely\n\t\t\t// This prevents false positives when other tables are modified\n\t\t\tconst prevTableJson = JSON.stringify({\n\t\t\t\tcolumns: prevTable.columns || {},\n\t\t\t\tindexes: prevTable.indexes || {},\n\t\t\t\tforeignKeys: prevTable.foreignKeys || {},\n\t\t\t\tuniqueConstraints: prevTable.uniqueConstraints || {},\n\t\t\t\tcheckConstraints: prevTable.checkConstraints || {},\n\t\t\t});\n\n\t\t\tconst currTableJson = JSON.stringify({\n\t\t\t\tcolumns: currTable.columns || {},\n\t\t\t\tindexes: currTable.indexes || {},\n\t\t\t\tforeignKeys: currTable.foreignKeys || {},\n\t\t\t\tuniqueConstraints: currTable.uniqueConstraints || {},\n\t\t\t\tcheckConstraints: currTable.checkConstraints || {},\n\t\t\t});\n\n\t\t\t// If tables are identical, skip all processing for this table\n\t\t\tif (prevTableJson === currTableJson) {\n\t\t\t\tcontinue;\n\t\t\t}\n\n\t\t\t// Compare columns\n\t\t\tconst prevColumns = prevTable.columns || {};\n\t\t\tconst currColumns = currTable.columns || {};\n\n\t\t\t// Find added columns\n\t\t\tfor (const colName in currColumns) {\n\t\t\t\tif (!(colName in prevColumns)) {\n\t\t\t\t\tdiff.columns.added.push({\n\t\t\t\t\t\ttable: tableName,\n\t\t\t\t\t\tcolumn: colName,\n\t\t\t\t\t\tdefinition: currColumns[colName],\n\t\t\t\t\t});\n\t\t\t\t}\n\t\t\t}\n\n\t\t\t// Find deleted columns\n\t\t\tfor (const colName in prevColumns) {\n\t\t\t\tif (!(colName in currColumns)) {\n\t\t\t\t\tdiff.columns.deleted.push({\n\t\t\t\t\t\ttable: tableName,\n\t\t\t\t\t\tcolumn: colName,\n\t\t\t\t\t});\n\t\t\t\t}\n\t\t\t}\n\n\t\t\t// Find modified columns\n\t\t\tfor (const colName in currColumns) {\n\t\t\t\tif (colName in prevColumns) {\n\t\t\t\t\tconst prevCol = prevColumns[colName];\n\t\t\t\t\tconst currCol = currColumns[colName];\n\n\t\t\t\t\t// Check for changes in column properties\n\t\t\t\t\t// Use normalized type comparison\n\t\t\t\t\tconst typeChanged =\n\t\t\t\t\t\tnormalizeType(prevCol.type) !== normalizeType(currCol.type);\n\t\t\t\t\tconst hasChanges =\n\t\t\t\t\t\ttypeChanged ||\n\t\t\t\t\t\tprevCol.notNull !== currCol.notNull ||\n\t\t\t\t\t\tprevCol.default !== currCol.default ||\n\t\t\t\t\t\tprevCol.primaryKey !== currCol.primaryKey;\n\n\t\t\t\t\tif (hasChanges) {\n\t\t\t\t\t\tdiff.columns.modified.push({\n\t\t\t\t\t\t\ttable: tableName,\n\t\t\t\t\t\t\tcolumn: colName,\n\t\t\t\t\t\t\tchanges: {\n\t\t\t\t\t\t\t\tfrom: prevCol,\n\t\t\t\t\t\t\t\tto: currCol,\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t});\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\n\t\t\t// Compare indexes\n\t\t\tconst prevIndexes = prevTable.indexes || {};\n\t\t\tconst currIndexes = currTable.indexes || {};\n\n\t\t\t// Find new, deleted, and altered indexes\n\t\t\tfor (const indexName in currIndexes) {\n\t\t\t\tif (!(indexName in prevIndexes)) {\n\t\t\t\t\t// New index\n\t\t\t\t\tdiff.indexes.created.push({\n\t\t\t\t\t\t...currIndexes[indexName],\n\t\t\t\t\t\ttable: tableName,\n\t\t\t\t\t} as SchemaIndex & { table: string });\n\t\t\t\t} else {\n\t\t\t\t\t// Check if index definition changed\n\t\t\t\t\tconst prevIndex = prevIndexes[indexName];\n\t\t\t\t\tconst currIndex = currIndexes[indexName];\n\n\t\t\t\t\t// Deep comparison of index properties\n\t\t\t\t\tconst indexChanged = isIndexChanged(prevIndex, currIndex);\n\n\t\t\t\t\tif (indexChanged) {\n\t\t\t\t\t\t// Index definition changed - need to drop and recreate\n\t\t\t\t\t\tdiff.indexes.altered.push({\n\t\t\t\t\t\t\told: {\n\t\t\t\t\t\t\t\t...prevIndex,\n\t\t\t\t\t\t\t\ttable: tableName,\n\t\t\t\t\t\t\t\tname: indexName,\n\t\t\t\t\t\t\t} as SchemaIndex & { table: string },\n\t\t\t\t\t\t\tnew: {\n\t\t\t\t\t\t\t\t...currIndex,\n\t\t\t\t\t\t\t\ttable: tableName,\n\t\t\t\t\t\t\t\tname: indexName,\n\t\t\t\t\t\t\t} as SchemaIndex & { table: string },\n\t\t\t\t\t\t});\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\n\t\t\t// Find deleted indexes (not altered)\n\t\t\tfor (const indexName in prevIndexes) {\n\t\t\t\tif (!(indexName in currIndexes)) {\n\t\t\t\t\tdiff.indexes.deleted.push({\n\t\t\t\t\t\t...prevIndexes[indexName],\n\t\t\t\t\t\ttable: tableName,\n\t\t\t\t\t} as SchemaIndex & { table: string });\n\t\t\t\t}\n\t\t\t}\n\n\t\t\t// Compare unique constraints\n\t\t\tconst prevUniqueConstraints = prevTable.uniqueConstraints || {};\n\t\t\tconst currUniqueConstraints = currTable.uniqueConstraints || {};\n\n\t\t\t// Find new unique constraints\n\t\t\tfor (const uqName in currUniqueConstraints) {\n\t\t\t\tif (!(uqName in prevUniqueConstraints)) {\n\t\t\t\t\tdiff.uniqueConstraints.created.push({\n\t\t\t\t\t\t...currUniqueConstraints[uqName],\n\t\t\t\t\t\ttable: tableName,\n\t\t\t\t\t} as SchemaUniqueConstraint & { table: string });\n\t\t\t\t}\n\t\t\t}\n\n\t\t\t// Find deleted unique constraints\n\t\t\tfor (const uqName in prevUniqueConstraints) {\n\t\t\t\tif (!(uqName in currUniqueConstraints)) {\n\t\t\t\t\tdiff.uniqueConstraints.deleted.push({\n\t\t\t\t\t\t...prevUniqueConstraints[uqName],\n\t\t\t\t\t\ttable: tableName,\n\t\t\t\t\t} as SchemaUniqueConstraint & { table: string });\n\t\t\t\t}\n\t\t\t}\n\n\t\t\t// Compare check constraints\n\t\t\tconst prevCheckConstraints = prevTable.checkConstraints || {};\n\t\t\tconst currCheckConstraints = currTable.checkConstraints || {};\n\n\t\t\t// Find new check constraints\n\t\t\tfor (const checkName in currCheckConstraints) {\n\t\t\t\tif (!(checkName in prevCheckConstraints)) {\n\t\t\t\t\tdiff.checkConstraints.created.push({\n\t\t\t\t\t\t...currCheckConstraints[checkName],\n\t\t\t\t\t\ttable: tableName,\n\t\t\t\t\t} as SchemaCheckConstraint & { table: string });\n\t\t\t\t}\n\t\t\t}\n\n\t\t\t// Find deleted check constraints\n\t\t\tfor (const checkName in prevCheckConstraints) {\n\t\t\t\tif (!(checkName in currCheckConstraints)) {\n\t\t\t\t\tdiff.checkConstraints.deleted.push({\n\t\t\t\t\t\t...prevCheckConstraints[checkName],\n\t\t\t\t\t\ttable: tableName,\n\t\t\t\t\t} as SchemaCheckConstraint & { table: string });\n\t\t\t\t}\n\t\t\t}\n\n\t\t\t// Compare foreign keys\n\t\t\tconst prevFKs = prevTable.foreignKeys || {};\n\t\t\tconst currFKs = currTable.foreignKeys || {};\n\n\t\t\t// Find new, deleted, and altered foreign keys\n\t\t\tfor (const fkName in currFKs) {\n\t\t\t\tif (!(fkName in prevFKs)) {\n\t\t\t\t\t// New FK\n\t\t\t\t\tdiff.foreignKeys.created.push(currFKs[fkName]);\n\t\t\t\t} else {\n\t\t\t\t\t// Check if FK definition changed (CASCADE behavior, etc.)\n\t\t\t\t\tconst prevFK = prevFKs[fkName];\n\t\t\t\t\tconst currFK = currFKs[fkName];\n\n\t\t\t\t\t// Compare FK properties\n\t\t\t\t\tconst prevOnDelete = prevFK.onDelete || \"no action\";\n\t\t\t\t\tconst currOnDelete = currFK.onDelete || \"no action\";\n\t\t\t\t\tconst prevOnUpdate = prevFK.onUpdate || \"no action\";\n\t\t\t\t\tconst currOnUpdate = currFK.onUpdate || \"no action\";\n\n\t\t\t\t\tif (prevOnDelete !== currOnDelete || prevOnUpdate !== currOnUpdate) {\n\t\t\t\t\t\t// FK CASCADE behavior changed - need to drop and recreate\n\t\t\t\t\t\tdiff.foreignKeys.altered.push({\n\t\t\t\t\t\t\told: prevFK,\n\t\t\t\t\t\t\tnew: currFK,\n\t\t\t\t\t\t});\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\n\t\t\t// Find deleted foreign keys (not altered)\n\t\t\tfor (const fkName in prevFKs) {\n\t\t\t\tif (!(fkName in currFKs)) {\n\t\t\t\t\tconst prevFK = prevFKs[fkName];\n\t\t\t\t\tdiff.foreignKeys.deleted.push({\n\t\t\t\t\t\t...prevFK,\n\t\t\t\t\t\ttableFrom: tableName,\n\t\t\t\t\t} as SchemaForeignKey);\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n\n\treturn diff;\n}\n\n/**\n * Check if a diff has any changes\n */\nexport function hasDiffChanges(diff: SchemaDiff): boolean {\n\treturn (\n\t\tdiff.tables.created.length > 0 ||\n\t\tdiff.tables.deleted.length > 0 ||\n\t\tdiff.tables.modified.length > 0 ||\n\t\tdiff.columns.added.length > 0 ||\n\t\tdiff.columns.deleted.length > 0 ||\n\t\tdiff.columns.modified.length > 0 ||\n\t\tdiff.indexes.created.length > 0 ||\n\t\tdiff.indexes.deleted.length > 0 ||\n\t\tdiff.indexes.altered.length > 0 ||\n\t\tdiff.foreignKeys.created.length > 0 ||\n\t\tdiff.foreignKeys.deleted.length > 0 ||\n\t\tdiff.foreignKeys.altered.length > 0 ||\n\t\tdiff.uniqueConstraints.created.length > 0 ||\n\t\tdiff.uniqueConstraints.deleted.length > 0 ||\n\t\tdiff.checkConstraints.created.length > 0 ||\n\t\tdiff.checkConstraints.deleted.length > 0\n\t);\n}\n",
106
+ "/**\n * Browser-compatible crypto utilities\n * Uses the Web Crypto API which is available in both browsers and Node.js\n */\n\n/**\n * Simple synchronous hash function for change detection\n * This is NOT cryptographic - it's just for comparing snapshots\n * Uses djb2 hash algorithm for speed and simplicity\n */\nexport function simpleHash(str: string): string {\n\tlet hash = 5381;\n\tfor (let i = 0; i < str.length; i++) {\n\t\thash = (hash * 33) ^ str.charCodeAt(i);\n\t}\n\t// Convert to unsigned 32-bit integer and then to hex\n\treturn (hash >>> 0).toString(16).padStart(8, \"0\");\n}\n\n/**\n * Create a longer hash by combining multiple passes\n * This provides better distribution for larger inputs\n */\nexport function extendedHash(str: string): string {\n\t// Run multiple passes with different seeds for better distribution\n\tconst h1 = hashWithSeed(str, 5381);\n\tconst h2 = hashWithSeed(str, 7919);\n\tconst h3 = hashWithSeed(str, 104729);\n\tconst h4 = hashWithSeed(str, 224737);\n\n\treturn h1 + h2 + h3 + h4;\n}\n\nfunction hashWithSeed(str: string, seed: number): string {\n\tlet hash = seed;\n\tfor (let i = 0; i < str.length; i++) {\n\t\thash = (hash * 33) ^ str.charCodeAt(i);\n\t}\n\treturn (hash >>> 0).toString(16).padStart(8, \"0\");\n}\n\n/**\n * Convert string to Uint8Array\n */\nfunction stringToBytes(str: string): Uint8Array {\n\tconst encoder = new TextEncoder();\n\treturn encoder.encode(str);\n}\n\n/**\n * Convert ArrayBuffer to hex string\n */\nfunction bufferToHex(buffer: ArrayBuffer): string {\n\tconst bytes = new Uint8Array(buffer);\n\tlet hex = \"\";\n\tfor (let i = 0; i < bytes.length; i++) {\n\t\thex += bytes[i].toString(16).padStart(2, \"0\");\n\t}\n\treturn hex;\n}\n\n/**\n * Async SHA-256 hash using Web Crypto API\n * Works in both browsers and Node.js (v15+)\n */\nexport async function sha256Async(data: string): Promise<string> {\n\tconst bytes = stringToBytes(data);\n\t// Cast to ArrayBuffer to satisfy TypeScript's strict BufferSource typing\n\tconst hashBuffer = await crypto.subtle.digest(\n\t\t\"SHA-256\",\n\t\tbytes.buffer as ArrayBuffer,\n\t);\n\treturn bufferToHex(hashBuffer);\n}\n\n/**\n * Generate a stable bigint from a string for advisory lock IDs\n * Uses a simple hash that produces consistent results across runs\n */\nexport function stringToBigInt(str: string): bigint {\n\t// Use extended hash for better uniqueness\n\tconst hash = extendedHash(str);\n\n\t// Convert first 16 hex chars (64 bits) to bigint\n\tlet lockId = BigInt(`0x${hash.slice(0, 16)}`);\n\n\t// Ensure the value fits in PostgreSQL's positive bigint range\n\t// Use a mask to keep only 63 bits (ensures positive in signed 64-bit)\n\tconst mask63Bits = 0x7fffffffffffffffn;\n\tlockId = lockId & mask63Bits;\n\n\t// Ensure non-zero\n\tif (lockId === 0n) {\n\t\tlockId = 1n;\n\t}\n\n\treturn lockId;\n}\n",
107
+ "import { is, SQL } from \"drizzle-orm\";\nimport {\n\tgetTableConfig,\n\ttype PgColumn,\n\tPgDialect,\n\tPgTable,\n} from \"drizzle-orm/pg-core\";\nimport { extendedHash } from \"../crypto-utils\";\nimport type {\n\tIndexColumn,\n\tSchemaCheckConstraint,\n\tSchemaColumn,\n\tSchemaEnum,\n\tSchemaForeignKey,\n\tSchemaIndex,\n\tSchemaPrimaryKey,\n\tSchemaSnapshot,\n\tSchemaTable,\n\tSchemaUniqueConstraint,\n} from \"../types\";\n\n// Drizzle schema type - an object mapping table names to PgTable instances\ntype DrizzleSchema = Record<string, unknown>;\n\n// Array element type for building SQL arrays\ntype ArrayElement =\n\t| number\n\t| bigint\n\t| boolean\n\t| string\n\t| Date\n\t| object\n\t| ArrayElement[];\n\n/**\n * Internal Drizzle types for working with SQL expressions and indexes.\n * These types aren't exported from drizzle-orm but are needed for snapshot generation.\n *\n * Note: Drizzle's SQL.toQuery() accepts a config object with specific properties.\n * Since these are internal to Drizzle, we define compatible types here.\n */\ninterface SqlToQueryConfig {\n\tescapeName: () => never;\n\tescapeParam: () => never;\n\tescapeString: () => never;\n\tcasing?: undefined; // We don't use casing transformation\n}\n\n/**\n * Internal Drizzle column config interface.\n * PgColumn has internal properties not exposed in the public type definition.\n */\ninterface DrizzleColumnWithConfig {\n\tname: string;\n\tnotNull: boolean;\n\tprimary: boolean;\n\tgetSQLType: () => string;\n\tdefault?: unknown;\n\tisUnique?: boolean;\n\tconfig?: {\n\t\tuniqueName?: string;\n\t\tuniqueType?: string;\n\t};\n}\n\n/**\n * Utility functions from Drizzle's code\n */\nfunction escapeSingleQuotes(str: string): string {\n\treturn str.replace(/'/g, \"''\");\n}\n\nfunction isPgArrayType(sqlType: string): boolean {\n\treturn sqlType.match(/.*\\[\\d*\\].*|.*\\[\\].*/g) !== null;\n}\n\nfunction buildArrayString(array: ArrayElement[], sqlType: string): string {\n\tsqlType = sqlType.split(\"[\")[0];\n\tconst values = array\n\t\t.map((value) => {\n\t\t\tif (typeof value === \"number\" || typeof value === \"bigint\") {\n\t\t\t\treturn value.toString();\n\t\t\t} else if (typeof value === \"boolean\") {\n\t\t\t\treturn value ? \"true\" : \"false\";\n\t\t\t} else if (Array.isArray(value)) {\n\t\t\t\treturn buildArrayString(value, sqlType);\n\t\t\t} else if (value instanceof Date) {\n\t\t\t\tif (sqlType === \"date\") {\n\t\t\t\t\treturn `\"${value.toISOString().split(\"T\")[0]}\"`;\n\t\t\t\t} else if (sqlType === \"timestamp\") {\n\t\t\t\t\treturn `\"${value.toISOString().replace(\"T\", \" \").slice(0, 23)}\"`;\n\t\t\t\t} else {\n\t\t\t\t\treturn `\"${value.toISOString()}\"`;\n\t\t\t\t}\n\t\t\t} else if (typeof value === \"object\") {\n\t\t\t\treturn `\"${JSON.stringify(value).replaceAll('\"', '\\\\\"')}\"`;\n\t\t\t}\n\n\t\t\treturn `\"${value}\"`;\n\t\t})\n\t\t.join(\",\");\n\n\treturn `{${values}}`;\n}\n\n/**\n * Convert a Drizzle SQL expression to a string.\n * This is used for extracting default values from column definitions.\n *\n * Note: We use a type assertion here because SQL.toQuery() expects internal\n * Drizzle types that aren't publicly exported. Our config is compatible\n * at runtime but TypeScript can't verify this.\n */\nconst sqlToStr = (sql: SQL, _casing: string | undefined) => {\n\tconst config: SqlToQueryConfig = {\n\t\tescapeName: () => {\n\t\t\tthrow new Error(\"we don't support params for `sql` default values\");\n\t\t},\n\t\tescapeParam: () => {\n\t\t\tthrow new Error(\"we don't support params for `sql` default values\");\n\t\t},\n\t\tescapeString: () => {\n\t\t\tthrow new Error(\"we don't support params for `sql` default values\");\n\t\t},\n\t\tcasing: undefined, // We don't use casing transformation in this context\n\t};\n\t// Type assertion needed: SQL.toQuery expects internal Drizzle types\n\ttype ToQueryParam = Parameters<SQL[\"toQuery\"]>[0];\n\treturn sql.toQuery(config as ToQueryParam).sql;\n};\n\n/**\n * Extract Drizzle tables from a schema object\n */\nfunction extractTablesFromSchema(schema: DrizzleSchema): PgTable[] {\n\tconst tables: PgTable[] = [];\n\n\t// Iterate through all exports in the schema\n\tconst exports = Object.values(schema);\n\texports.forEach((t: unknown) => {\n\t\t// Check if it's a PgTable using Drizzle's is() function\n\t\tif (is(t, PgTable)) {\n\t\t\ttables.push(t);\n\t\t}\n\t});\n\n\treturn tables;\n}\n\n/**\n * Generate a snapshot from a Drizzle schema\n * This is a port of Drizzle's pgSerializer.generatePgSnapshot\n */\nexport async function generateSnapshot(\n\tschema: DrizzleSchema,\n): Promise<SchemaSnapshot> {\n\tconst dialect = new PgDialect({ casing: undefined });\n\tconst tables: Record<string, SchemaTable> = {};\n\tconst schemas: Record<string, string> = {};\n\tconst enums: Record<string, SchemaEnum> = {};\n\n\t// Extract tables from schema\n\tconst pgTables = extractTablesFromSchema(schema);\n\n\t// Process each table\n\tfor (const table of pgTables) {\n\t\tconst config = getTableConfig(table);\n\t\tconst {\n\t\t\tname: tableName,\n\t\t\tcolumns,\n\t\t\tindexes,\n\t\t\tforeignKeys,\n\t\t\tschema: tableSchema,\n\t\t\tprimaryKeys,\n\t\t\tuniqueConstraints,\n\t\t\tchecks,\n\t\t} = config;\n\n\t\tconst columnsObject: Record<string, SchemaColumn> = {};\n\t\tconst indexesObject: Record<string, SchemaIndex> = {};\n\t\tconst foreignKeysObject: Record<string, SchemaForeignKey> = {};\n\t\tconst primaryKeysObject: Record<string, SchemaPrimaryKey> = {};\n\t\tconst uniqueConstraintObject: Record<string, SchemaUniqueConstraint> = {};\n\t\tconst checksObject: Record<string, SchemaCheckConstraint> = {};\n\n\t\t// Process columns - EXACT copy of Drizzle's logic\n\t\tcolumns.forEach((column: PgColumn) => {\n\t\t\tconst name = column.name;\n\t\t\tconst notNull = column.notNull;\n\t\t\tconst primaryKey = column.primary;\n\t\t\tconst sqlType = column.getSQLType();\n\t\t\tconst sqlTypeLowered = sqlType.toLowerCase();\n\n\t\t\tconst columnToSet: SchemaColumn = {\n\t\t\t\tname,\n\t\t\t\ttype: sqlType,\n\t\t\t\tprimaryKey,\n\t\t\t\tnotNull,\n\t\t\t};\n\n\t\t\t// Handle defaults - EXACT copy from Drizzle's pgSerializer.ts lines 247-273\n\t\t\tif (column.default !== undefined) {\n\t\t\t\tif (is(column.default, SQL)) {\n\t\t\t\t\tcolumnToSet.default = sqlToStr(column.default, undefined);\n\t\t\t\t} else {\n\t\t\t\t\tif (typeof column.default === \"string\") {\n\t\t\t\t\t\tcolumnToSet.default = `'${escapeSingleQuotes(column.default)}'`;\n\t\t\t\t\t} else {\n\t\t\t\t\t\tif (sqlTypeLowered === \"jsonb\" || sqlTypeLowered === \"json\") {\n\t\t\t\t\t\t\tcolumnToSet.default = `'${JSON.stringify(column.default)}'::${sqlTypeLowered}`;\n\t\t\t\t\t\t} else if (column.default instanceof Date) {\n\t\t\t\t\t\t\tif (sqlTypeLowered === \"date\") {\n\t\t\t\t\t\t\t\tcolumnToSet.default = `'${column.default.toISOString().split(\"T\")[0]}'`;\n\t\t\t\t\t\t\t} else if (sqlTypeLowered === \"timestamp\") {\n\t\t\t\t\t\t\t\tcolumnToSet.default = `'${column.default.toISOString().replace(\"T\", \" \").slice(0, 23)}'`;\n\t\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\t\tcolumnToSet.default = `'${column.default.toISOString()}'`;\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t} else if (\n\t\t\t\t\t\t\tisPgArrayType(sqlTypeLowered) &&\n\t\t\t\t\t\t\tArray.isArray(column.default)\n\t\t\t\t\t\t) {\n\t\t\t\t\t\t\tcolumnToSet.default = `'${buildArrayString(column.default as ArrayElement[], sqlTypeLowered)}'`;\n\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\t// Should do for all types\n\t\t\t\t\t\t\t// columnToSet.default = `'${column.default}'::${sqlTypeLowered}`;\n\t\t\t\t\t\t\tcolumnToSet.default = column.default as string | number | boolean;\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\n\t\t\t// Handle column-level unique constraints\n\t\t\t// IMPORTANT: Check isUnique, not just uniqueName presence!\n\t\t\t// Drizzle sets uniqueName for all columns but only unique ones should have constraints\n\t\t\t// Type assertion: accessing internal Drizzle column properties not in public types\n\t\t\tconst columnWithConfig = column as unknown as DrizzleColumnWithConfig;\n\t\t\tconst columnConfig = columnWithConfig.config;\n\t\t\tif (\n\t\t\t\tcolumnWithConfig.isUnique &&\n\t\t\t\tcolumnConfig &&\n\t\t\t\tcolumnConfig.uniqueName\n\t\t\t) {\n\t\t\t\tuniqueConstraintObject[columnConfig.uniqueName] = {\n\t\t\t\t\tname: columnConfig.uniqueName,\n\t\t\t\t\tcolumns: [name],\n\t\t\t\t\tnullsNotDistinct: columnConfig.uniqueType === \"not distinct\",\n\t\t\t\t};\n\t\t\t}\n\n\t\t\tcolumnsObject[name] = columnToSet;\n\t\t});\n\n\t\t// Drizzle primary key interface\n\t\tinterface DrizzlePrimaryKey {\n\t\t\tcolumns: Array<{ name: string }>;\n\t\t\tgetName: () => string;\n\t\t}\n\n\t\t// Process primary keys\n\t\tprimaryKeys.forEach((pk: DrizzlePrimaryKey) => {\n\t\t\tconst columnNames = pk.columns.map((c) => c.name);\n\t\t\tconst name = pk.getName();\n\n\t\t\tprimaryKeysObject[name] = {\n\t\t\t\tname,\n\t\t\t\tcolumns: columnNames,\n\t\t\t};\n\t\t});\n\n\t\t// Drizzle unique constraint interface\n\t\tinterface DrizzleUniqueConstraint {\n\t\t\tcolumns: Array<{ name: string }>;\n\t\t\tname?: string;\n\t\t\tnullsNotDistinct?: boolean;\n\t\t}\n\n\t\t// Process unique constraints\n\t\tuniqueConstraints?.forEach((unq: DrizzleUniqueConstraint) => {\n\t\t\tconst columnNames = unq.columns.map((c) => c.name);\n\t\t\tconst name = unq.name || `${tableName}_${columnNames.join(\"_\")}_unique`;\n\n\t\t\tuniqueConstraintObject[name] = {\n\t\t\t\tname,\n\t\t\t\tcolumns: columnNames,\n\t\t\t\tnullsNotDistinct: unq.nullsNotDistinct,\n\t\t\t};\n\t\t});\n\n\t\t// Drizzle foreign key interfaces\n\t\tinterface DrizzleForeignKeyReference {\n\t\t\tcolumns: Array<{ name: string }>;\n\t\t\tforeignColumns: Array<{ name: string }>;\n\t\t\tforeignTable: PgTable;\n\t\t}\n\n\t\tinterface DrizzleForeignKey {\n\t\t\treference: () => DrizzleForeignKeyReference;\n\t\t\tgetName: () => string;\n\t\t\tonDelete?: string;\n\t\t\tonUpdate?: string;\n\t\t}\n\n\t\t// Process foreign keys - includes both explicit foreignKeys and inline references\n\t\t// Drizzle's getTableConfig automatically collects inline .references() into foreignKeys\n\t\tforeignKeys.forEach((fk: DrizzleForeignKey) => {\n\t\t\tconst reference = fk.reference();\n\t\t\tconst columnsFrom = reference.columns.map((it) => it.name);\n\t\t\tconst columnsTo = reference.foreignColumns.map((it) => it.name);\n\t\t\tconst tableTo = getTableConfig(reference.foreignTable).name;\n\t\t\tconst schemaTo =\n\t\t\t\tgetTableConfig(reference.foreignTable).schema || \"public\";\n\n\t\t\tconst name = fk.getName();\n\n\t\t\tforeignKeysObject[name] = {\n\t\t\t\tname,\n\t\t\t\ttableFrom: tableName,\n\t\t\t\tschemaFrom: tableSchema, // Add source table schema\n\t\t\t\ttableTo,\n\t\t\t\tschemaTo,\n\t\t\t\tcolumnsFrom,\n\t\t\t\tcolumnsTo,\n\t\t\t\tonDelete: fk.onDelete || \"no action\",\n\t\t\t\tonUpdate: fk.onUpdate || \"no action\",\n\t\t\t};\n\t\t});\n\n\t\t// Drizzle index interfaces\n\t\tinterface DrizzleIndexConfig {\n\t\t\torder?: string;\n\t\t\tnulls?: string;\n\t\t}\n\n\t\tinterface DrizzleIndexColumn {\n\t\t\tname: string;\n\t\t\tindexConfig?: DrizzleIndexConfig;\n\t\t}\n\n\t\tinterface DrizzleIndex {\n\t\t\tconfig: {\n\t\t\t\tcolumns: Array<DrizzleIndexColumn | SQL>;\n\t\t\t\tname?: string;\n\t\t\t\tunique?: boolean;\n\t\t\t\tmethod?: string;\n\t\t\t};\n\t\t}\n\n\t\t// Process indexes\n\t\t// Drizzle's getTableConfig returns indexes with internal types not exported from the package\n\t\t(indexes as DrizzleIndex[]).forEach((idx: DrizzleIndex) => {\n\t\t\tconst indexCols = idx.config.columns;\n\t\t\tconst indexColumns: IndexColumn[] = indexCols.map((col) => {\n\t\t\t\tif (is(col, SQL)) {\n\t\t\t\t\treturn {\n\t\t\t\t\t\texpression: dialect.sqlToQuery(col).sql,\n\t\t\t\t\t\tisExpression: true,\n\t\t\t\t\t};\n\t\t\t\t} else {\n\t\t\t\t\tconst indexCol: IndexColumn = {\n\t\t\t\t\t\texpression: col.name,\n\t\t\t\t\t\tisExpression: false,\n\t\t\t\t\t\tasc: col.indexConfig && col.indexConfig.order === \"asc\",\n\t\t\t\t\t};\n\t\t\t\t\t// Only add nulls if explicitly specified in the config\n\t\t\t\t\tif (col.indexConfig?.nulls) {\n\t\t\t\t\t\tindexCol.nulls = col.indexConfig.nulls;\n\t\t\t\t\t}\n\t\t\t\t\treturn indexCol;\n\t\t\t\t}\n\t\t\t});\n\n\t\t\tconst name =\n\t\t\t\tidx.config.name ||\n\t\t\t\t`${tableName}_${indexColumns.map((c) => c.expression).join(\"_\")}_index`;\n\n\t\t\tindexesObject[name] = {\n\t\t\t\tname,\n\t\t\t\tcolumns: indexColumns,\n\t\t\t\tisUnique: idx.config.unique || false,\n\t\t\t\tmethod: idx.config.method || \"btree\",\n\t\t\t};\n\t\t});\n\n\t\t// Drizzle check constraint interface\n\t\tinterface DrizzleCheck {\n\t\t\tname: string;\n\t\t\tvalue: SQL;\n\t\t}\n\n\t\t// Process check constraints\n\t\tif (checks) {\n\t\t\tchecks.forEach((check: DrizzleCheck) => {\n\t\t\t\tconst checkName = check.name;\n\t\t\t\tchecksObject[checkName] = {\n\t\t\t\t\tname: checkName,\n\t\t\t\t\tvalue: dialect.sqlToQuery(check.value).sql,\n\t\t\t\t};\n\t\t\t});\n\t\t}\n\n\t\t// Build the table object\n\t\ttables[`${tableSchema || \"public\"}.${tableName}`] = {\n\t\t\tname: tableName,\n\t\t\tschema: tableSchema || \"public\",\n\t\t\tcolumns: columnsObject,\n\t\t\tindexes: indexesObject,\n\t\t\tforeignKeys: foreignKeysObject,\n\t\t\tcompositePrimaryKeys: primaryKeysObject,\n\t\t\tuniqueConstraints: uniqueConstraintObject,\n\t\t\tcheckConstraints: checksObject,\n\t\t};\n\n\t\t// Track schemas\n\t\tif (tableSchema && tableSchema !== \"public\") {\n\t\t\tschemas[tableSchema] = tableSchema;\n\t\t}\n\t}\n\n\t// Create snapshot in Drizzle's format\n\tconst snapshot: SchemaSnapshot = {\n\t\tversion: \"7\",\n\t\tdialect: \"postgresql\",\n\t\ttables,\n\t\tschemas,\n\t\tenums,\n\t\t_meta: {\n\t\t\tschemas: {},\n\t\t\ttables: {},\n\t\t\tcolumns: {},\n\t\t},\n\t};\n\n\treturn snapshot;\n}\n\n/**\n * Calculate hash of a snapshot for change detection\n * Uses a browser-compatible hash function\n */\nexport function hashSnapshot(snapshot: SchemaSnapshot): string {\n\tconst content = JSON.stringify(snapshot);\n\treturn extendedHash(content);\n}\n\n/**\n * Create an empty snapshot for initial migration\n */\nexport function createEmptySnapshot(): SchemaSnapshot {\n\treturn {\n\t\tversion: \"7\",\n\t\tdialect: \"postgresql\",\n\t\ttables: {},\n\t\tschemas: {},\n\t\tenums: {},\n\t\t_meta: {\n\t\t\tschemas: {},\n\t\t\ttables: {},\n\t\t\tcolumns: {},\n\t\t},\n\t};\n}\n\n/**\n * Compare two snapshots and detect if there are changes\n */\nexport function hasChanges(\n\tpreviousSnapshot: SchemaSnapshot | null,\n\tcurrentSnapshot: SchemaSnapshot,\n): boolean {\n\t// If no previous snapshot, there are definitely changes\n\tif (!previousSnapshot) {\n\t\treturn Object.keys(currentSnapshot.tables).length > 0;\n\t}\n\n\t// Simple comparison for now - in production, use deep comparison\n\tconst prevHash = hashSnapshot(previousSnapshot);\n\tconst currHash = hashSnapshot(currentSnapshot);\n\n\treturn prevHash !== currHash;\n}\n",
108
+ "import { logger } from \"@elizaos/core\";\nimport type {\n\tSchemaCheckConstraint,\n\tSchemaColumn,\n\tSchemaForeignKey,\n\tSchemaIndex,\n\tSchemaPrimaryKey,\n\tSchemaSnapshot,\n\tSchemaTable,\n\tSchemaUniqueConstraint,\n} from \"../types\";\nimport type { SchemaDiff } from \"./diff-calculator\";\n\n/**\n * Data loss detection result\n * Based on Drizzle's pgPushUtils approach\n */\nexport interface DataLossCheck {\n\thasDataLoss: boolean;\n\ttablesToRemove: string[];\n\tcolumnsToRemove: string[];\n\ttablesToTruncate: string[];\n\ttypeChanges: Array<{\n\t\ttable: string;\n\t\tcolumn: string;\n\t\tfrom: string;\n\t\tto: string;\n\t}>;\n\twarnings: string[];\n\trequiresConfirmation: boolean;\n}\n\n/**\n * Check for potential data loss in schema changes\n * Based on Drizzle's pgSuggestions function\n */\nexport function checkForDataLoss(diff: SchemaDiff): DataLossCheck {\n\tconst result: DataLossCheck = {\n\t\thasDataLoss: false,\n\t\ttablesToRemove: [],\n\t\tcolumnsToRemove: [],\n\t\ttablesToTruncate: [],\n\t\ttypeChanges: [],\n\t\twarnings: [],\n\t\trequiresConfirmation: false,\n\t};\n\n\t// Check for table deletions\n\tif (diff.tables.deleted.length > 0) {\n\t\tresult.hasDataLoss = true;\n\t\tresult.requiresConfirmation = true;\n\t\tresult.tablesToRemove = [...diff.tables.deleted];\n\t\tfor (const table of diff.tables.deleted) {\n\t\t\tresult.warnings.push(\n\t\t\t\t`Table \"${table}\" will be dropped with all its data`,\n\t\t\t);\n\t\t}\n\t}\n\n\t// Check for column deletions\n\tif (diff.columns.deleted.length > 0) {\n\t\tresult.hasDataLoss = true;\n\t\tresult.requiresConfirmation = true;\n\t\tfor (const col of diff.columns.deleted) {\n\t\t\tresult.columnsToRemove.push(`${col.table}.${col.column}`);\n\t\t\tresult.warnings.push(\n\t\t\t\t`Column \"${col.column}\" in table \"${col.table}\" will be dropped`,\n\t\t\t);\n\t\t}\n\t}\n\n\t// Check for column type changes that might cause data loss\n\tfor (const modified of diff.columns.modified) {\n\t\tconst from = modified.changes.from;\n\t\tconst to = modified.changes.to;\n\n\t\tif (!from || !to) continue;\n\n\t\t// Check if type change is destructive\n\t\tif (from.type !== to.type) {\n\t\t\tconst isDestructive = checkIfTypeChangeIsDestructive(from.type, to.type);\n\n\t\t\tif (isDestructive) {\n\t\t\t\tresult.hasDataLoss = true;\n\t\t\t\tresult.requiresConfirmation = true;\n\t\t\t\tresult.typeChanges.push({\n\t\t\t\t\ttable: modified.table,\n\t\t\t\t\tcolumn: modified.column,\n\t\t\t\t\tfrom: from.type,\n\t\t\t\t\tto: to.type,\n\t\t\t\t});\n\t\t\t\tresult.tablesToTruncate.push(modified.table);\n\t\t\t\tresult.warnings.push(\n\t\t\t\t\t`Column \"${modified.column}\" in table \"${modified.table}\" changes type from \"${from.type}\" to \"${to.type}\". ` +\n\t\t\t\t\t\t`This may require truncating the table to avoid data conversion errors.`,\n\t\t\t\t);\n\t\t\t}\n\t\t}\n\n\t\t// Check for adding NOT NULL without default to existing column\n\t\tif (!from.notNull && to.notNull && !to.default) {\n\t\t\tresult.hasDataLoss = true;\n\t\t\tresult.requiresConfirmation = true;\n\t\t\tresult.warnings.push(\n\t\t\t\t`Column \"${modified.column}\" in table \"${modified.table}\" is becoming NOT NULL without a default value. ` +\n\t\t\t\t\t`This will fail if the table contains NULL values.`,\n\t\t\t);\n\t\t}\n\t}\n\n\t// Check for adding NOT NULL columns without defaults\n\tfor (const added of diff.columns.added) {\n\t\tif (added.definition.notNull && !added.definition.default) {\n\t\t\t// This is only a problem if the table already has data\n\t\t\t// We'll flag it as a potential issue\n\t\t\tresult.warnings.push(\n\t\t\t\t`Column \"${added.column}\" is being added to table \"${added.table}\" as NOT NULL without a default value. ` +\n\t\t\t\t\t`This will fail if the table contains data.`,\n\t\t\t);\n\t\t\t// Don't set requiresConfirmation here - it's only a warning\n\t\t}\n\t}\n\n\treturn result;\n}\n\n/**\n * Normalize SQL types for comparison\n * Handles equivalent type variations between introspected DB and schema definitions\n */\nfunction normalizeType(type: string | undefined): string {\n\tif (!type) return \"\";\n\n\tconst normalized = type.toLowerCase().trim();\n\n\t// Handle timestamp variations - all are equivalent\n\tif (\n\t\tnormalized === \"timestamp without time zone\" ||\n\t\tnormalized === \"timestamp with time zone\" ||\n\t\tnormalized === \"timestamptz\"\n\t) {\n\t\treturn \"timestamp\";\n\t}\n\n\t// Handle serial vs integer with identity\n\t// serial is essentially integer with auto-increment\n\tif (normalized === \"serial\") {\n\t\treturn \"integer\";\n\t}\n\tif (normalized === \"bigserial\") {\n\t\treturn \"bigint\";\n\t}\n\tif (normalized === \"smallserial\") {\n\t\treturn \"smallint\";\n\t}\n\n\t// Handle numeric/decimal equivalence\n\tif (normalized.startsWith(\"numeric\") || normalized.startsWith(\"decimal\")) {\n\t\t// Extract precision and scale if present\n\t\tconst match = normalized.match(/\\((\\d+)(?:,\\s*(\\d+))?\\)/);\n\t\tif (match) {\n\t\t\treturn `numeric(${match[1]}${match[2] ? `,${match[2]}` : \"\"})`;\n\t\t}\n\t\treturn \"numeric\";\n\t}\n\n\t// Handle varchar/character varying\n\tif (normalized.startsWith(\"character varying\")) {\n\t\treturn normalized.replace(\"character varying\", \"varchar\");\n\t}\n\n\t// Handle text array variations\n\tif (normalized === \"text[]\" || normalized === \"_text\") {\n\t\treturn \"text[]\";\n\t}\n\n\treturn normalized;\n}\n\n/**\n * Check if a type change is destructive\n * Based on PostgreSQL's type casting rules\n */\nfunction checkIfTypeChangeIsDestructive(\n\tfromType: string,\n\ttoType: string,\n): boolean {\n\t// First normalize the types to handle equivalent variations\n\tconst normalizedFrom = normalizeType(fromType);\n\tconst normalizedTo = normalizeType(toType);\n\n\t// If normalized types match, it's not destructive\n\tif (normalizedFrom === normalizedTo) {\n\t\treturn false;\n\t}\n\n\t// Safe conversions (PostgreSQL) - based on Drizzle's logic\n\tconst safeConversions: Record<string, string[]> = {\n\t\tsmallint: [\"integer\", \"bigint\", \"numeric\", \"real\", \"double precision\"],\n\t\tinteger: [\"bigint\", \"numeric\", \"real\", \"double precision\"],\n\t\tbigint: [\"numeric\"],\n\t\treal: [\"double precision\"],\n\t\tvarchar: [\"text\"],\n\t\tchar: [\"varchar\", \"text\"],\n\t\tcitext: [\"text\"],\n\t\ttext: [\"citext\"],\n\t\t// UUID to text is safe\n\t\tuuid: [\"text\", \"varchar\"],\n\t\t// Timestamp variations are generally safe (now handled by normalization)\n\t\ttimestamp: [\"timestamp\"], // Simplified since normalization handles variations\n\t\t// Date/time conversions\n\t\tdate: [\"timestamp\"],\n\t\ttime: [\"timetz\"],\n\t};\n\n\tconst fromBase = normalizedFrom.split(\"(\")[0];\n\tconst toBase = normalizedTo.split(\"(\")[0];\n\n\t// Same type is always safe\n\tif (fromBase === toBase) {\n\t\treturn false;\n\t}\n\n\t// Check if it's a safe conversion\n\tconst safeTo = safeConversions[fromBase];\n\tif (safeTo?.includes(toBase)) {\n\t\treturn false;\n\t}\n\n\t// All other conversions are considered potentially destructive\n\treturn true;\n}\n\n/**\n * Generate SQL statements from a schema diff\n * This follows Drizzle's approach: create all tables first, then add foreign keys\n */\nexport async function generateMigrationSQL(\n\tpreviousSnapshot: SchemaSnapshot | null,\n\tcurrentSnapshot: SchemaSnapshot,\n\tdiff?: SchemaDiff,\n): Promise<string[]> {\n\tconst statements: string[] = [];\n\n\t// If no diff provided, calculate it\n\tif (!diff) {\n\t\tconst { calculateDiff } = await import(\"./diff-calculator\");\n\t\tdiff = await calculateDiff(previousSnapshot, currentSnapshot);\n\t}\n\n\t// Check for data loss\n\tconst dataLossCheck = checkForDataLoss(diff);\n\n\t// Log warnings if any\n\tif (dataLossCheck.warnings.length > 0) {\n\t\tlogger.warn(\n\t\t\t{ src: \"plugin:sql\", warnings: dataLossCheck.warnings },\n\t\t\t\"Schema changes may cause data loss\",\n\t\t);\n\t}\n\n\t// Phase 1: Collect unique schemas and create them first\n\tconst schemasToCreate = new Set<string>();\n\tfor (const tableName of diff.tables.created) {\n\t\tconst table = currentSnapshot.tables[tableName];\n\t\tif (table) {\n\t\t\tconst schema = table.schema || \"public\";\n\t\t\tif (schema !== \"public\") {\n\t\t\t\tschemasToCreate.add(schema);\n\t\t\t}\n\t\t}\n\t}\n\n\t// Create schemas first (following drizzle-kit pattern)\n\tfor (const schema of schemasToCreate) {\n\t\tstatements.push(`CREATE SCHEMA IF NOT EXISTS \"${schema}\";`);\n\t}\n\n\t// Phase 2: Generate CREATE TABLE statements for new tables (WITHOUT foreign keys)\n\tconst createTableStatements: string[] = [];\n\tconst foreignKeyStatements: string[] = [];\n\n\tfor (const tableName of diff.tables.created) {\n\t\tconst table = currentSnapshot.tables[tableName];\n\t\tif (table) {\n\t\t\tconst { tableSQL, fkSQLs } = generateCreateTableSQL(tableName, table);\n\t\t\tcreateTableStatements.push(tableSQL);\n\t\t\tforeignKeyStatements.push(...fkSQLs);\n\t\t}\n\t}\n\n\t// Add all CREATE TABLE statements\n\tstatements.push(...createTableStatements);\n\n\t// Phase 3: Add all foreign keys AFTER tables are created\n\t// Deduplicate foreign key statements to avoid duplicate constraints\n\tconst uniqueFKs = new Set<string>();\n\tconst dedupedFKStatements: string[] = [];\n\n\tfor (const fkSQL of foreignKeyStatements) {\n\t\t// Extract constraint name to check for duplicates\n\t\tconst match = fkSQL.match(/ADD CONSTRAINT \"([^\"]+)\"/);\n\t\tif (match) {\n\t\t\tconst constraintName = match[1];\n\t\t\tif (!uniqueFKs.has(constraintName)) {\n\t\t\t\tuniqueFKs.add(constraintName);\n\t\t\t\tdedupedFKStatements.push(fkSQL);\n\t\t\t}\n\t\t} else {\n\t\t\tdedupedFKStatements.push(fkSQL);\n\t\t}\n\t}\n\n\tstatements.push(...dedupedFKStatements);\n\n\t// Phase 4: Handle table modifications\n\n\t// Generate DROP TABLE statements for deleted tables\n\tfor (const tableName of diff.tables.deleted) {\n\t\tconst [schema, name] = tableName.includes(\".\")\n\t\t\t? tableName.split(\".\")\n\t\t\t: [\"public\", tableName];\n\t\tstatements.push(`DROP TABLE IF EXISTS \"${schema}\".\"${name}\" CASCADE;`);\n\t}\n\n\t// Generate ALTER TABLE statements for column changes\n\t// Handle column additions\n\tfor (const added of diff.columns.added) {\n\t\tstatements.push(\n\t\t\tgenerateAddColumnSQL(added.table, added.column, added.definition),\n\t\t);\n\t}\n\n\t// Handle column deletions\n\tfor (const deleted of diff.columns.deleted) {\n\t\tstatements.push(generateDropColumnSQL(deleted.table, deleted.column));\n\t}\n\n\t// Handle column modifications\n\tfor (const modified of diff.columns.modified) {\n\t\tconst alterStatements = generateAlterColumnSQL(\n\t\t\tmodified.table,\n\t\t\tmodified.column,\n\t\t\tmodified.changes,\n\t\t);\n\t\tstatements.push(...alterStatements);\n\t}\n\n\t// Generate DROP INDEX statements (including altered ones - drop old version)\n\tfor (const index of diff.indexes.deleted) {\n\t\tstatements.push(generateDropIndexSQL(index));\n\t}\n\n\t// Drop old version of altered indexes\n\tfor (const alteredIndex of diff.indexes.altered) {\n\t\tstatements.push(generateDropIndexSQL(alteredIndex.old));\n\t}\n\n\t// Generate CREATE INDEX statements (including altered ones - create new version)\n\tfor (const index of diff.indexes.created) {\n\t\tstatements.push(generateCreateIndexSQL(index));\n\t}\n\n\t// Create new version of altered indexes\n\tfor (const alteredIndex of diff.indexes.altered) {\n\t\tstatements.push(generateCreateIndexSQL(alteredIndex.new));\n\t}\n\n\t// Generate CREATE UNIQUE CONSTRAINT statements\n\tfor (const constraint of diff.uniqueConstraints.created) {\n\t\t// Skip if it's part of a new table (already handled)\n\t\tconst isNewTable = diff.tables.created.some((tableName) => {\n\t\t\tconst [schema, table] = tableName.includes(\".\")\n\t\t\t\t? tableName.split(\".\")\n\t\t\t\t: [\"public\", tableName];\n\t\t\tconst constraintTable =\n\t\t\t\t(constraint as SchemaUniqueConstraint & { table?: string }).table || \"\";\n\t\t\tconst [constraintSchema, constraintTableName] = constraintTable.includes(\n\t\t\t\t\".\",\n\t\t\t)\n\t\t\t\t? constraintTable.split(\".\")\n\t\t\t\t: [\"public\", constraintTable];\n\t\t\treturn table === constraintTableName && schema === constraintSchema;\n\t\t});\n\n\t\tif (!isNewTable) {\n\t\t\tstatements.push(generateCreateUniqueConstraintSQL(constraint));\n\t\t}\n\t}\n\n\t// Generate DROP UNIQUE CONSTRAINT statements\n\tfor (const constraint of diff.uniqueConstraints.deleted) {\n\t\tstatements.push(generateDropUniqueConstraintSQL(constraint));\n\t}\n\n\t// Generate CREATE CHECK CONSTRAINT statements\n\tfor (const constraint of diff.checkConstraints.created) {\n\t\t// Skip if it's part of a new table (already handled)\n\t\tconst isNewTable = diff.tables.created.some((tableName) => {\n\t\t\tconst [schema, table] = tableName.includes(\".\")\n\t\t\t\t? tableName.split(\".\")\n\t\t\t\t: [\"public\", tableName];\n\t\t\tconst constraintTable =\n\t\t\t\t(constraint as SchemaCheckConstraint & { table?: string }).table || \"\";\n\t\t\tconst [constraintSchema, constraintTableName] = constraintTable.includes(\n\t\t\t\t\".\",\n\t\t\t)\n\t\t\t\t? constraintTable.split(\".\")\n\t\t\t\t: [\"public\", constraintTable];\n\t\t\treturn table === constraintTableName && schema === constraintSchema;\n\t\t});\n\n\t\tif (!isNewTable) {\n\t\t\tstatements.push(generateCreateCheckConstraintSQL(constraint));\n\t\t}\n\t}\n\n\t// Generate DROP CHECK CONSTRAINT statements\n\tfor (const constraint of diff.checkConstraints.deleted) {\n\t\tstatements.push(generateDropCheckConstraintSQL(constraint));\n\t}\n\n\t// Handle foreign key deletions first (including altered ones)\n\tfor (const fk of diff.foreignKeys.deleted) {\n\t\tstatements.push(generateDropForeignKeySQL(fk));\n\t}\n\n\t// Drop old version of altered foreign keys\n\tfor (const alteredFK of diff.foreignKeys.altered) {\n\t\tstatements.push(generateDropForeignKeySQL(alteredFK.old));\n\t}\n\n\t// Handle foreign key creations (for existing tables)\n\tfor (const fk of diff.foreignKeys.created) {\n\t\t// Only add if it's not part of a new table (those were handled above)\n\t\t// Check both with and without schema prefix\n\t\tconst tableFrom = fk.tableFrom || \"\";\n\t\tconst schemaFrom = fk.schemaFrom || \"public\";\n\n\t\tconst isNewTable = diff.tables.created.some((tableName) => {\n\t\t\t// Compare table names, handling schema prefixes\n\t\t\tconst [createdSchema, createdTable] = tableName.includes(\".\")\n\t\t\t\t? tableName.split(\".\")\n\t\t\t\t: [\"public\", tableName];\n\n\t\t\t// Compare using the actual schema and table from the FK\n\t\t\treturn createdTable === tableFrom && createdSchema === schemaFrom;\n\t\t});\n\n\t\tif (!isNewTable) {\n\t\t\tstatements.push(generateCreateForeignKeySQL(fk));\n\t\t}\n\t}\n\n\t// Create new version of altered foreign keys\n\tfor (const alteredFK of diff.foreignKeys.altered) {\n\t\tstatements.push(generateCreateForeignKeySQL(alteredFK.new));\n\t}\n\n\treturn statements;\n}\n\n/**\n * Generate CREATE TABLE SQL (following Drizzle's pattern)\n * Returns the table creation SQL and separate foreign key SQLs\n */\nfunction generateCreateTableSQL(\n\tfullTableName: string,\n\ttable: SchemaTable,\n): { tableSQL: string; fkSQLs: string[] } {\n\tconst [schema, tableName] = fullTableName.includes(\".\")\n\t\t? fullTableName.split(\".\")\n\t\t: [\"public\", fullTableName];\n\tconst columns: string[] = [];\n\tconst fkSQLs: string[] = [];\n\n\t// Add columns\n\tfor (const [colName, colDef] of Object.entries(table.columns || {})) {\n\t\tcolumns.push(generateColumnDefinition(colName, colDef));\n\t}\n\n\t// Add composite primary keys if exists\n\tconst primaryKeys = table.compositePrimaryKeys || {};\n\tfor (const [pkName, pkDef] of Object.entries(primaryKeys)) {\n\t\tconst pk = pkDef as SchemaPrimaryKey;\n\t\tif (pk.columns && pk.columns.length > 0) {\n\t\t\tcolumns.push(\n\t\t\t\t`CONSTRAINT \"${pkName}\" PRIMARY KEY (${pk.columns.map((c) => `\"${c}\"`).join(\", \")})`,\n\t\t\t);\n\t\t}\n\t}\n\n\t// Add unique constraints\n\tconst uniqueConstraints = table.uniqueConstraints || {};\n\tfor (const [uqName, uqDef] of Object.entries(uniqueConstraints)) {\n\t\tconst uq = uqDef as SchemaUniqueConstraint;\n\t\tif (uq.columns && uq.columns.length > 0) {\n\t\t\tconst uniqueDef = uq.nullsNotDistinct\n\t\t\t\t? `CONSTRAINT \"${uqName}\" UNIQUE NULLS NOT DISTINCT (${uq.columns.map((c) => `\"${c}\"`).join(\", \")})`\n\t\t\t\t: `CONSTRAINT \"${uqName}\" UNIQUE (${uq.columns.map((c) => `\"${c}\"`).join(\", \")})`;\n\t\t\tcolumns.push(uniqueDef);\n\t\t}\n\t}\n\n\t// Add check constraints\n\tconst checkConstraints = table.checkConstraints || {};\n\tfor (const [checkName, checkDef] of Object.entries(checkConstraints)) {\n\t\tconst check = checkDef as SchemaCheckConstraint;\n\t\tif (check.value) {\n\t\t\tcolumns.push(`CONSTRAINT \"${checkName}\" CHECK (${check.value})`);\n\t\t}\n\t}\n\n\t// Following drizzle-kit pattern: don't create schema here, it's handled separately\n\tconst tableSQL = `CREATE TABLE IF NOT EXISTS \"${schema}\".\"${tableName}\" (\\n ${columns.join(\",\\n \")}\\n);`;\n\n\t// Collect foreign keys to be added AFTER all tables are created\n\tconst foreignKeys = table.foreignKeys || {};\n\tfor (const [fkName, fkDef] of Object.entries(foreignKeys)) {\n\t\tconst fk = fkDef as SchemaForeignKey;\n\t\tconst fkSQL = `ALTER TABLE \"${schema}\".\"${tableName}\" ADD CONSTRAINT \"${fkName}\" FOREIGN KEY (${fk.columnsFrom.map((c) => `\"${c}\"`).join(\", \")}) REFERENCES \"${fk.schemaTo || \"public\"}\".\"${fk.tableTo}\" (${fk.columnsTo.map((c) => `\"${c}\"`).join(\", \")})${fk.onDelete ? ` ON DELETE ${fk.onDelete}` : \"\"}${fk.onUpdate ? ` ON UPDATE ${fk.onUpdate}` : \"\"};`;\n\t\tfkSQLs.push(fkSQL);\n\t}\n\n\treturn { tableSQL, fkSQLs };\n}\n\n/**\n * Generate column definition (following Drizzle's pattern)\n */\nfunction generateColumnDefinition(name: string, def: SchemaColumn): string {\n\tlet sql = `\"${name}\" ${def.type}`;\n\n\t// Handle primary key that's not part of composite\n\tif (def.primaryKey && !def.type.includes(\"SERIAL\")) {\n\t\tsql += \" PRIMARY KEY\";\n\t}\n\n\t// Add NOT NULL constraint\n\tif (def.notNull) {\n\t\tsql += \" NOT NULL\";\n\t}\n\n\t// Add DEFAULT value - properly formatted\n\tif (def.default !== undefined) {\n\t\tconst defaultValue = formatDefaultValue(def.default, def.type);\n\t\tsql += ` DEFAULT ${defaultValue}`;\n\t}\n\n\treturn sql;\n}\n\n/**\n * Generate ALTER TABLE ADD COLUMN SQL\n * Based on Drizzle's PgAlterTableAddColumnConvertor\n */\nfunction generateAddColumnSQL(\n\ttable: string,\n\tcolumn: string,\n\tdefinition: SchemaColumn,\n): string {\n\tconst [schema, tableName] = table.includes(\".\")\n\t\t? table.split(\".\")\n\t\t: [\"public\", table];\n\tconst tableNameWithSchema = `\"${schema}\".\"${tableName}\"`;\n\n\t// Build column definition parts in the correct order (like Drizzle)\n\tconst parts: string[] = [`\"${column}\"`];\n\n\t// Type\n\tparts.push(definition.type);\n\n\t// Primary key\n\tif (definition.primaryKey) {\n\t\tparts.push(\"PRIMARY KEY\");\n\t}\n\n\t// Default value - needs proper formatting based on type\n\tif (definition.default !== undefined) {\n\t\tconst defaultValue = formatDefaultValue(\n\t\t\tdefinition.default,\n\t\t\tdefinition.type,\n\t\t);\n\t\tif (defaultValue) {\n\t\t\tparts.push(`DEFAULT ${defaultValue}`);\n\t\t}\n\t}\n\n\t// Generated columns\n\tconst definitionWithGenerated = definition as SchemaColumn & {\n\t\tgenerated?: string;\n\t};\n\tif (definitionWithGenerated.generated) {\n\t\tparts.push(\n\t\t\t`GENERATED ALWAYS AS (${definitionWithGenerated.generated}) STORED`,\n\t\t);\n\t}\n\n\t// NOT NULL constraint - comes after DEFAULT\n\tif (definition.notNull) {\n\t\tparts.push(\"NOT NULL\");\n\t}\n\n\treturn `ALTER TABLE ${tableNameWithSchema} ADD COLUMN ${parts.join(\" \")};`;\n}\n\n/**\n * Generate ALTER TABLE DROP COLUMN SQL\n * Based on Drizzle's approach with CASCADE\n */\nfunction generateDropColumnSQL(table: string, column: string): string {\n\tconst [schema, tableName] = table.includes(\".\")\n\t\t? table.split(\".\")\n\t\t: [\"public\", table];\n\tconst tableNameWithSchema = `\"${schema}\".\"${tableName}\"`;\n\t// Use CASCADE to handle dependent objects\n\treturn `ALTER TABLE ${tableNameWithSchema} DROP COLUMN \"${column}\" CASCADE;`;\n}\n\n// Column change tracking interface\ninterface ColumnChangeInfo {\n\tfrom?: SchemaColumn;\n\tto?: SchemaColumn;\n}\n\n/**\n * Generate ALTER TABLE ALTER COLUMN SQL\n * Based on Drizzle's approach with proper type casting and handling\n */\nfunction generateAlterColumnSQL(\n\ttable: string,\n\tcolumn: string,\n\tchanges: ColumnChangeInfo,\n): string[] {\n\tconst [schema, tableName] = table.includes(\".\")\n\t\t? table.split(\".\")\n\t\t: [\"public\", table];\n\tconst tableNameWithSchema = `\"${schema}\".\"${tableName}\"`;\n\tconst statements: string[] = [];\n\n\t// Handle type changes - need to handle enums and complex types\n\tconst changesTo = changes.to;\n\tconst changesFrom = changes.from;\n\tconst changesToType = changesTo?.type;\n\tconst changesFromType = changesFrom?.type;\n\tif (changesToType !== changesFromType) {\n\t\tconst newType = changesToType || \"TEXT\";\n\n\t\t// Check if we need a USING clause for type conversion\n\t\tconst needsUsing = checkIfNeedsUsingClause(changesFromType || \"\", newType);\n\n\t\tif (needsUsing) {\n\t\t\t// For complex type changes, use USING clause like Drizzle\n\t\t\tstatements.push(\n\t\t\t\t`ALTER TABLE ${tableNameWithSchema} ALTER COLUMN \"${column}\" TYPE ${newType} USING \"${column}\"::text::${newType};`,\n\t\t\t);\n\t\t} else {\n\t\t\tstatements.push(\n\t\t\t\t`ALTER TABLE ${tableNameWithSchema} ALTER COLUMN \"${column}\" SET DATA TYPE ${newType};`,\n\t\t\t);\n\t\t}\n\t}\n\n\t// Handle NOT NULL changes\n\tconst changesToNotNull = changesTo?.notNull;\n\tconst changesFromNotNull = changesFrom?.notNull;\n\tif (changesToNotNull !== changesFromNotNull) {\n\t\tif (changesToNotNull) {\n\t\t\t// When adding NOT NULL, might need to set defaults for existing NULL values\n\t\t\tstatements.push(\n\t\t\t\t`ALTER TABLE ${tableNameWithSchema} ALTER COLUMN \"${column}\" SET NOT NULL;`,\n\t\t\t);\n\t\t} else {\n\t\t\tstatements.push(\n\t\t\t\t`ALTER TABLE ${tableNameWithSchema} ALTER COLUMN \"${column}\" DROP NOT NULL;`,\n\t\t\t);\n\t\t}\n\t}\n\n\t// Handle default value changes\n\tconst changesToDefault = changesTo?.default;\n\tconst changesFromDefault = changesFrom?.default;\n\tif (changesToDefault !== changesFromDefault) {\n\t\tif (changesToDefault !== undefined) {\n\t\t\tconst defaultValue = formatDefaultValue(\n\t\t\t\tchangesToDefault,\n\t\t\t\tchangesToType || \"\",\n\t\t\t);\n\t\t\tstatements.push(\n\t\t\t\t`ALTER TABLE ${tableNameWithSchema} ALTER COLUMN \"${column}\" SET DEFAULT ${defaultValue};`,\n\t\t\t);\n\t\t} else {\n\t\t\tstatements.push(\n\t\t\t\t`ALTER TABLE ${tableNameWithSchema} ALTER COLUMN \"${column}\" DROP DEFAULT;`,\n\t\t\t);\n\t\t}\n\t}\n\n\treturn statements;\n}\n\n/**\n * Check if a type change needs a USING clause\n * Based on Drizzle's type conversion logic\n */\nfunction checkIfNeedsUsingClause(fromType: string, toType: string): boolean {\n\tif (!fromType || !toType) return false;\n\n\t// Enum changes always need USING\n\tif (fromType.includes(\"enum\") || toType.includes(\"enum\")) {\n\t\treturn true;\n\t}\n\n\tconst fromBase = fromType.split(\"(\")[0].toLowerCase();\n\tconst toBase = toType.split(\"(\")[0].toLowerCase();\n\n\t// Text/varchar to JSONB always needs USING\n\tif (\n\t\t(fromBase === \"text\" ||\n\t\t\tfromBase === \"varchar\" ||\n\t\t\tfromBase === \"character varying\") &&\n\t\t(toBase === \"jsonb\" || toBase === \"json\")\n\t) {\n\t\treturn true;\n\t}\n\n\t// Some specific type conversions need USING\n\tconst needsUsingPairs = [\n\t\t[\"integer\", \"boolean\"],\n\t\t[\"boolean\", \"integer\"],\n\t\t[\"text\", \"integer\"],\n\t\t[\"text\", \"numeric\"],\n\t\t[\"text\", \"boolean\"],\n\t\t[\"text\", \"uuid\"],\n\t\t[\"text\", \"jsonb\"],\n\t\t[\"text\", \"json\"],\n\t\t[\"varchar\", \"integer\"],\n\t\t[\"varchar\", \"numeric\"],\n\t\t[\"varchar\", \"boolean\"],\n\t\t[\"varchar\", \"uuid\"],\n\t\t[\"varchar\", \"jsonb\"],\n\t\t[\"varchar\", \"json\"],\n\t\t[\"character varying\", \"jsonb\"],\n\t\t[\"character varying\", \"json\"],\n\t\t// Add more as needed based on PostgreSQL casting rules\n\t];\n\n\tfor (const [from, to] of needsUsingPairs) {\n\t\tif (\n\t\t\t(fromBase === from && toBase === to) ||\n\t\t\t(fromBase === to && toBase === from)\n\t\t) {\n\t\t\treturn true;\n\t\t}\n\t}\n\n\treturn false;\n}\n\n// Default value type - can be string, number, boolean, or null\ntype DefaultValue = string | number | boolean | null | undefined;\n\n/**\n * Format a default value for SQL\n * Based on Drizzle's default value formatting\n */\nfunction formatDefaultValue(value: DefaultValue, type: string): string {\n\t// Handle NULL\n\tif (value === null || value === \"NULL\") {\n\t\treturn \"NULL\";\n\t}\n\n\t// Handle boolean\n\tif (\n\t\ttype &&\n\t\t(type.toLowerCase().includes(\"boolean\") || type.toLowerCase() === \"bool\")\n\t) {\n\t\tif (value === true || value === \"true\" || value === \"t\" || value === 1) {\n\t\t\treturn \"true\";\n\t\t}\n\t\tif (value === false || value === \"false\" || value === \"f\" || value === 0) {\n\t\t\treturn \"false\";\n\t\t}\n\t}\n\n\t// Handle numeric types\n\tif (type?.match(/^(integer|bigint|smallint|numeric|decimal|real|double)/i)) {\n\t\treturn String(value);\n\t}\n\n\t// Handle SQL expressions and pre-formatted defaults\n\tif (typeof value === \"string\") {\n\t\t// Already formatted with type cast (e.g., '[]'::jsonb, '{}'::jsonb)\n\t\t// These come from the snapshot and are already properly formatted\n\t\tif (value.includes(\"::\")) {\n\t\t\treturn value;\n\t\t}\n\n\t\t// Already quoted string literals (from snapshot)\n\t\t// These start and end with single quotes\n\t\tif (value.startsWith(\"'\") && value.endsWith(\"'\")) {\n\t\t\treturn value;\n\t\t}\n\n\t\t// SQL functions like now(), gen_random_uuid(), etc.\n\t\tif (\n\t\t\tvalue.match(/^\\w+\\(\\)/i) ||\n\t\t\t(value.includes(\"(\") && value.includes(\")\"))\n\t\t) {\n\t\t\treturn value;\n\t\t}\n\n\t\t// SQL expressions starting with CURRENT_\n\t\tif (value.toUpperCase().startsWith(\"CURRENT_\")) {\n\t\t\treturn value;\n\t\t}\n\n\t\t// Otherwise, it's an unquoted string literal - wrap and escape\n\t\treturn `'${value.replace(/'/g, \"''\")}'`;\n\t}\n\n\t// Default: return as-is\n\treturn String(value);\n}\n\n// Extended index interface with table reference\ninterface SchemaIndexWithTableRef {\n\tname: string;\n\tcolumns: Array<{\n\t\texpression: string;\n\t\tisExpression: boolean;\n\t\tasc?: boolean;\n\t\tnulls?: string;\n\t}>;\n\tisUnique: boolean;\n\tmethod?: string;\n\twhere?: string;\n\tconcurrently?: boolean;\n\ttable?: string;\n}\n\n/**\n * Generate CREATE INDEX SQL\n */\nfunction generateCreateIndexSQL(index: SchemaIndexWithTableRef): string {\n\tconst unique = index.isUnique ? \"UNIQUE \" : \"\";\n\tconst method = index.method || \"btree\";\n\tconst columns = index.columns\n\t\t.map((c) => {\n\t\t\tif (c.isExpression) {\n\t\t\t\treturn c.expression;\n\t\t\t}\n\t\t\t// Only add DESC if explicitly set to false, no NULLS clause by default\n\t\t\treturn `\"${c.expression}\"${c.asc === false ? \" DESC\" : \"\"}`;\n\t\t})\n\t\t.join(\", \");\n\n\t// Extract index name and table with proper schema handling\n\tconst indexName = index.name.includes(\".\")\n\t\t? index.name.split(\".\")[1]\n\t\t: index.name;\n\n\t// Keep the full table name with schema if present\n\tlet tableRef: string;\n\tconst indexTable = index.table;\n\tif (indexTable?.includes(\".\")) {\n\t\tconst [schema, table] = indexTable.split(\".\");\n\t\ttableRef = `\"${schema}\".\"${table}\"`;\n\t} else {\n\t\ttableRef = `\"${indexTable || \"\"}\"`;\n\t}\n\n\t// Include schema in table reference for correct index creation\n\treturn `CREATE ${unique}INDEX \"${indexName}\" ON ${tableRef} USING ${method} (${columns});`;\n}\n\n/**\n * Generate DROP INDEX SQL\n */\nfunction generateDropIndexSQL(index: SchemaIndex | string): string {\n\t// Extract just the index name without schema\n\tconst indexNameFull = typeof index === \"string\" ? index : index.name;\n\tconst indexName = indexNameFull.includes(\".\")\n\t\t? indexNameFull.split(\".\")[1]\n\t\t: indexNameFull;\n\t// Match Drizzle's format - no schema qualification\n\treturn `DROP INDEX IF EXISTS \"${indexName}\";`;\n}\n\n/**\n * Generate CREATE FOREIGN KEY SQL (for existing tables)\n */\nfunction generateCreateForeignKeySQL(fk: SchemaForeignKey): string {\n\tconst schemaFrom = fk.schemaFrom || \"public\";\n\tconst schemaTo = fk.schemaTo || \"public\";\n\tconst tableFrom = fk.tableFrom;\n\tconst columnsFrom = fk.columnsFrom.map((c: string) => `\"${c}\"`).join(\", \");\n\tconst columnsTo = fk.columnsTo.map((c: string) => `\"${c}\"`).join(\", \");\n\n\tlet sql = `ALTER TABLE \"${schemaFrom}\".\"${tableFrom}\" ADD CONSTRAINT \"${fk.name}\" FOREIGN KEY (${columnsFrom}) REFERENCES \"${schemaTo}\".\"${fk.tableTo}\" (${columnsTo})`;\n\n\tif (fk.onDelete) {\n\t\tsql += ` ON DELETE ${fk.onDelete}`;\n\t}\n\n\tif (fk.onUpdate) {\n\t\tsql += ` ON UPDATE ${fk.onUpdate}`;\n\t}\n\n\treturn `${sql};`;\n}\n\n/**\n * Generate DROP FOREIGN KEY SQL\n */\nfunction generateDropForeignKeySQL(fk: SchemaForeignKey): string {\n\tconst [schema, tableName] = fk.tableFrom\n\t\t? fk.tableFrom.includes(\".\")\n\t\t\t? fk.tableFrom.split(\".\")\n\t\t\t: [\"public\", fk.tableFrom]\n\t\t: [\"public\", \"\"];\n\treturn `ALTER TABLE \"${schema}\".\"${tableName}\" DROP CONSTRAINT \"${fk.name}\";`;\n}\n\n/**\n * Generate SQL for renaming a table\n */\nexport function generateRenameTableSQL(\n\toldName: string,\n\tnewName: string,\n): string {\n\tconst [oldSchema, oldTable] = oldName.includes(\".\")\n\t\t? oldName.split(\".\")\n\t\t: [\"public\", oldName];\n\tconst [, newTable] = newName.includes(\".\")\n\t\t? newName.split(\".\")\n\t\t: [\"public\", newName];\n\treturn `ALTER TABLE \"${oldSchema}\".\"${oldTable}\" RENAME TO \"${newTable}\";`;\n}\n\n/**\n * Generate SQL for renaming a column\n */\nexport function generateRenameColumnSQL(\n\ttable: string,\n\toldName: string,\n\tnewName: string,\n): string {\n\tconst [schema, tableName] = table.includes(\".\")\n\t\t? table.split(\".\")\n\t\t: [\"public\", table];\n\treturn `ALTER TABLE \"${schema}\".\"${tableName}\" RENAME COLUMN \"${oldName}\" TO \"${newName}\";`;\n}\n\n// Extended constraint interfaces with table reference\ninterface UniqueConstraintWithTable extends SchemaUniqueConstraint {\n\ttable?: string;\n}\n\ninterface CheckConstraintWithTable extends SchemaCheckConstraint {\n\ttable?: string;\n}\n\n/**\n * Generate CREATE UNIQUE CONSTRAINT SQL\n */\nfunction generateCreateUniqueConstraintSQL(\n\tconstraint: UniqueConstraintWithTable,\n): string {\n\tconst table = constraint.table || \"\";\n\tconst [schema, tableName] = table.includes(\".\")\n\t\t? table.split(\".\")\n\t\t: [\"public\", table];\n\n\tconst name = constraint.name;\n\tconst columns = constraint.columns.map((c) => `\"${c}\"`).join(\", \");\n\n\tlet sql = `ALTER TABLE \"${schema}\".\"${tableName}\" ADD CONSTRAINT \"${name}\" UNIQUE`;\n\n\t// Handle NULLS NOT DISTINCT if specified (PostgreSQL 15+)\n\tif (constraint.nullsNotDistinct) {\n\t\tsql += ` NULLS NOT DISTINCT`;\n\t}\n\n\tsql += ` (${columns});`;\n\n\treturn sql;\n}\n\n/**\n * Generate DROP UNIQUE CONSTRAINT SQL\n */\nfunction generateDropUniqueConstraintSQL(\n\tconstraint: UniqueConstraintWithTable,\n): string {\n\tconst table = constraint.table || \"\";\n\tconst [schema, tableName] = table.includes(\".\")\n\t\t? table.split(\".\")\n\t\t: [\"public\", table];\n\n\treturn `ALTER TABLE \"${schema}\".\"${tableName}\" DROP CONSTRAINT \"${constraint.name}\";`;\n}\n\n/**\n * Generate CREATE CHECK CONSTRAINT SQL\n */\nfunction generateCreateCheckConstraintSQL(\n\tconstraint: CheckConstraintWithTable,\n): string {\n\tconst table = constraint.table || \"\";\n\tconst [schema, tableName] = table.includes(\".\")\n\t\t? table.split(\".\")\n\t\t: [\"public\", table];\n\n\tconst name = constraint.name;\n\tconst value = constraint.value;\n\n\treturn `ALTER TABLE \"${schema}\".\"${tableName}\" ADD CONSTRAINT \"${name}\" CHECK (${value});`;\n}\n\n/**\n * Generate DROP CHECK CONSTRAINT SQL\n */\nfunction generateDropCheckConstraintSQL(\n\tconstraint: CheckConstraintWithTable,\n): string {\n\tconst table = constraint.table || \"\";\n\tconst [schema, tableName] = table.includes(\".\")\n\t\t? table.split(\".\")\n\t\t: [\"public\", table];\n\n\treturn `ALTER TABLE \"${schema}\".\"${tableName}\" DROP CONSTRAINT \"${constraint.name}\";`;\n}\n",
109
+ "import { logger } from \"@elizaos/core\";\nimport { sql } from \"drizzle-orm\";\nimport type {\n\tCheckConstraintInfoRow,\n\tColumnInfoRow,\n\tDrizzleDB,\n\tEnumInfoRow,\n\tForeignKeyInfoRow,\n\tIndexInfoRow,\n\tPrimaryKeyInfoRow,\n\tSchemaCheckConstraint,\n\tSchemaColumn,\n\tSchemaEnum,\n\tSchemaForeignKey,\n\tSchemaIndex,\n\tSchemaPrimaryKey,\n\tSchemaSnapshot,\n\tSchemaTable,\n\tSchemaUniqueConstraint,\n\tTableInfoRow,\n\tUniqueConstraintInfoRow,\n} from \"../types\";\n\n/**\n * Type-safe extraction of rows from SQL query results.\n * Raw SQL queries in Drizzle return untyped rows - this helper provides type safety.\n */\nfunction getRows<T>(result: { rows: unknown[] }): T[] {\n\treturn result.rows as T[];\n}\n\n/**\n * Introspect the current database state and generate a snapshot\n * This is used when no previous snapshot exists for a plugin\n * to capture the existing database state before migrations\n */\nexport class DatabaseIntrospector {\n\tconstructor(private db: DrizzleDB) {}\n\n\t/**\n\t * Introspect all tables in the database and generate a snapshot\n\t * @param schemaName - Schema to introspect (default: 'public')\n\t * @returns Schema snapshot of current database state\n\t */\n\tasync introspectSchema(\n\t\tschemaName: string = \"public\",\n\t): Promise<SchemaSnapshot> {\n\t\tlogger.info(\n\t\t\t{ src: \"plugin:sql\", schemaName },\n\t\t\t\"Starting database introspection\",\n\t\t);\n\n\t\tconst tables: Record<string, SchemaTable> = {};\n\t\tconst schemas: Record<string, string> = {};\n\t\tconst enums: Record<string, SchemaEnum> = {};\n\n\t\t// Get all tables in the schema\n\t\tconst allTables = await this.getTables(schemaName);\n\n\t\tfor (const tableInfo of allTables) {\n\t\t\tconst tableName = tableInfo.table_name;\n\t\t\tconst tableSchema = tableInfo.table_schema || \"public\";\n\n\t\t\tlogger.debug(\n\t\t\t\t{ src: \"plugin:sql\", tableSchema, tableName },\n\t\t\t\t\"Introspecting table\",\n\t\t\t);\n\n\t\t\t// Get columns for this table\n\t\t\tconst columns = await this.getColumns(tableSchema, tableName);\n\t\t\tconst columnsObject: Record<string, SchemaColumn> = {};\n\t\t\tconst uniqueConstraintObject: Record<string, SchemaUniqueConstraint> = {};\n\n\t\t\tfor (const col of columns) {\n\t\t\t\tcolumnsObject[col.column_name] = {\n\t\t\t\t\tname: col.column_name,\n\t\t\t\t\ttype: col.data_type,\n\t\t\t\t\tprimaryKey: col.is_primary || false,\n\t\t\t\t\tnotNull: col.is_nullable === \"NO\",\n\t\t\t\t\tdefault: col.column_default\n\t\t\t\t\t\t? this.parseDefault(col.column_default, col.data_type)\n\t\t\t\t\t\t: undefined,\n\t\t\t\t};\n\t\t\t}\n\n\t\t\t// Get indexes\n\t\t\tconst indexes = await this.getIndexes(tableSchema, tableName);\n\t\t\tconst indexesObject: Record<string, SchemaIndex> = {};\n\n\t\t\tfor (const idx of indexes) {\n\t\t\t\tif (!idx.is_primary && !idx.is_unique_constraint) {\n\t\t\t\t\t// Skip primary keys and unique constraints\n\t\t\t\t\t// Also skip indexes with no columns (partial indexes, expression indexes, etc.)\n\t\t\t\t\tif (\n\t\t\t\t\t\tidx.columns &&\n\t\t\t\t\t\tArray.isArray(idx.columns) &&\n\t\t\t\t\t\tidx.columns.length > 0\n\t\t\t\t\t) {\n\t\t\t\t\t\tindexesObject[idx.name] = {\n\t\t\t\t\t\t\tname: idx.name,\n\t\t\t\t\t\t\tcolumns: idx.columns.map((col) => ({\n\t\t\t\t\t\t\t\texpression: col,\n\t\t\t\t\t\t\t\tisExpression: false,\n\t\t\t\t\t\t\t})),\n\t\t\t\t\t\t\tisUnique: idx.is_unique,\n\t\t\t\t\t\t\tmethod: idx.method || \"btree\",\n\t\t\t\t\t\t};\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\n\t\t\t// Get foreign keys\n\t\t\tconst foreignKeys = await this.getForeignKeys(tableSchema, tableName);\n\t\t\tconst foreignKeysObject: Record<string, SchemaForeignKey> = {};\n\n\t\t\tfor (const fk of foreignKeys) {\n\t\t\t\tforeignKeysObject[fk.name] = {\n\t\t\t\t\tname: fk.name,\n\t\t\t\t\ttableFrom: tableName,\n\t\t\t\t\tschemaFrom: tableSchema,\n\t\t\t\t\ttableTo: fk.foreign_table_name,\n\t\t\t\t\tschemaTo: fk.foreign_table_schema || \"public\",\n\t\t\t\t\tcolumnsFrom: [fk.column_name],\n\t\t\t\t\tcolumnsTo: [fk.foreign_column_name],\n\t\t\t\t\tonDelete: fk.delete_rule?.toLowerCase() || \"no action\",\n\t\t\t\t\tonUpdate: fk.update_rule?.toLowerCase() || \"no action\",\n\t\t\t\t};\n\t\t\t}\n\n\t\t\t// Get primary keys\n\t\t\tconst primaryKeys = await this.getPrimaryKeys(tableSchema, tableName);\n\t\t\tconst primaryKeysObject: Record<string, SchemaPrimaryKey> = {};\n\n\t\t\tfor (const pk of primaryKeys) {\n\t\t\t\tprimaryKeysObject[pk.name] = {\n\t\t\t\t\tname: pk.name,\n\t\t\t\t\tcolumns: pk.columns,\n\t\t\t\t};\n\t\t\t}\n\n\t\t\t// Get unique constraints\n\t\t\tconst uniqueConstraints = await this.getUniqueConstraints(\n\t\t\t\ttableSchema,\n\t\t\t\ttableName,\n\t\t\t);\n\n\t\t\tfor (const unq of uniqueConstraints) {\n\t\t\t\tuniqueConstraintObject[unq.name] = {\n\t\t\t\t\tname: unq.name,\n\t\t\t\t\tcolumns: unq.columns,\n\t\t\t\t\tnullsNotDistinct: false, // Default value\n\t\t\t\t};\n\t\t\t}\n\n\t\t\t// Get check constraints\n\t\t\tconst checkConstraints = await this.getCheckConstraints(\n\t\t\t\ttableSchema,\n\t\t\t\ttableName,\n\t\t\t);\n\t\t\tconst checksObject: Record<string, SchemaCheckConstraint> = {};\n\n\t\t\tfor (const check of checkConstraints) {\n\t\t\t\tchecksObject[check.name] = {\n\t\t\t\t\tname: check.name,\n\t\t\t\t\tvalue: check.definition,\n\t\t\t\t};\n\t\t\t}\n\n\t\t\t// Build the table object\n\t\t\ttables[`${tableSchema}.${tableName}`] = {\n\t\t\t\tname: tableName,\n\t\t\t\tschema: tableSchema,\n\t\t\t\tcolumns: columnsObject,\n\t\t\t\tindexes: indexesObject,\n\t\t\t\tforeignKeys: foreignKeysObject,\n\t\t\t\tcompositePrimaryKeys: primaryKeysObject,\n\t\t\t\tuniqueConstraints: uniqueConstraintObject,\n\t\t\t\tcheckConstraints: checksObject,\n\t\t\t};\n\n\t\t\t// Track schemas\n\t\t\tif (tableSchema && tableSchema !== \"public\") {\n\t\t\t\tschemas[tableSchema] = tableSchema;\n\t\t\t}\n\t\t}\n\n\t\t// Get enums if any\n\t\tconst enumsResult = await this.getEnums(schemaName);\n\t\tfor (const enumInfo of enumsResult) {\n\t\t\tconst key = `${enumInfo.schema}.${enumInfo.name}`;\n\t\t\tif (!enums[key]) {\n\t\t\t\tenums[key] = {\n\t\t\t\t\tname: enumInfo.name,\n\t\t\t\t\tschema: enumInfo.schema,\n\t\t\t\t\tvalues: [],\n\t\t\t\t};\n\t\t\t}\n\t\t\tenums[key].values.push(enumInfo.value);\n\t\t}\n\n\t\tlogger.info(\n\t\t\t{ src: \"plugin:sql\", tableCount: Object.keys(tables).length },\n\t\t\t\"Database introspection complete\",\n\t\t);\n\n\t\treturn {\n\t\t\tversion: \"7\",\n\t\t\tdialect: \"postgresql\",\n\t\t\ttables,\n\t\t\tschemas,\n\t\t\tenums,\n\t\t\t_meta: {\n\t\t\t\tschemas: {},\n\t\t\t\ttables: {},\n\t\t\t\tcolumns: {},\n\t\t\t},\n\t\t};\n\t}\n\n\t/**\n\t * Get all tables in a schema\n\t */\n\tprivate async getTables(schemaName: string): Promise<TableInfoRow[]> {\n\t\tconst result = await this.db.execute(\n\t\t\tsql`SELECT \n table_schema,\n table_name\n FROM information_schema.tables\n WHERE table_schema = ${schemaName}\n AND table_type = 'BASE TABLE'\n ORDER BY table_name`,\n\t\t);\n\t\treturn getRows<TableInfoRow>(result);\n\t}\n\n\t/**\n\t * Get columns for a table\n\t */\n\tprivate async getColumns(\n\t\tschemaName: string,\n\t\ttableName: string,\n\t): Promise<ColumnInfoRow[]> {\n\t\tconst result = await this.db.execute(\n\t\t\tsql`SELECT \n a.attname AS column_name,\n CASE \n WHEN a.attnotnull THEN 'NO'\n ELSE 'YES'\n END AS is_nullable,\n CASE \n WHEN a.atttypid = ANY ('{int,int8,int2}'::regtype[]) \n AND EXISTS (\n SELECT FROM pg_attrdef ad\n WHERE ad.adrelid = a.attrelid \n AND ad.adnum = a.attnum \n AND pg_get_expr(ad.adbin, ad.adrelid) = 'nextval(''' \n || pg_get_serial_sequence(a.attrelid::regclass::text, a.attname)::regclass || '''::regclass)'\n )\n THEN CASE a.atttypid\n WHEN 'int'::regtype THEN 'serial'\n WHEN 'int8'::regtype THEN 'bigserial'\n WHEN 'int2'::regtype THEN 'smallserial'\n END\n ELSE format_type(a.atttypid, a.atttypmod)\n END AS data_type,\n pg_get_expr(ad.adbin, ad.adrelid) AS column_default,\n CASE \n WHEN con.contype = 'p' THEN true\n ELSE false\n END AS is_primary\n FROM pg_attribute a\n JOIN pg_class cls ON cls.oid = a.attrelid\n JOIN pg_namespace ns ON ns.oid = cls.relnamespace\n LEFT JOIN pg_attrdef ad ON ad.adrelid = a.attrelid AND ad.adnum = a.attnum\n LEFT JOIN pg_constraint con ON con.conrelid = a.attrelid \n AND a.attnum = ANY(con.conkey) \n AND con.contype = 'p'\n WHERE \n a.attnum > 0\n AND NOT a.attisdropped\n AND ns.nspname = ${schemaName}\n AND cls.relname = ${tableName}\n ORDER BY a.attnum`,\n\t\t);\n\t\treturn getRows<ColumnInfoRow>(result);\n\t}\n\n\t/**\n\t * Get indexes for a table\n\t */\n\tprivate async getIndexes(\n\t\tschemaName: string,\n\t\ttableName: string,\n\t): Promise<IndexInfoRow[]> {\n\t\tconst result = await this.db.execute(\n\t\t\tsql`SELECT \n i.relname AS name,\n idx.indisunique AS is_unique,\n idx.indisprimary AS is_primary,\n con.contype = 'u' AS is_unique_constraint,\n ARRAY(\n SELECT a.attname\n FROM pg_attribute a\n WHERE a.attrelid = idx.indrelid\n AND a.attnum = ANY(idx.indkey::int[])\n ORDER BY a.attnum\n ) AS columns,\n am.amname AS method\n FROM pg_index idx\n JOIN pg_class i ON i.oid = idx.indexrelid\n JOIN pg_class c ON c.oid = idx.indrelid\n JOIN pg_namespace n ON n.oid = c.relnamespace\n JOIN pg_am am ON am.oid = i.relam\n LEFT JOIN pg_constraint con ON con.conindid = idx.indexrelid\n WHERE n.nspname = ${schemaName}\n AND c.relname = ${tableName}`,\n\t\t);\n\t\treturn getRows<IndexInfoRow>(result);\n\t}\n\n\t/**\n\t * Get foreign keys for a table\n\t */\n\tprivate async getForeignKeys(\n\t\tschemaName: string,\n\t\ttableName: string,\n\t): Promise<ForeignKeyInfoRow[]> {\n\t\tconst result = await this.db.execute(\n\t\t\tsql`SELECT\n con.conname AS name,\n att.attname AS column_name,\n fnsp.nspname AS foreign_table_schema,\n frel.relname AS foreign_table_name,\n fatt.attname AS foreign_column_name,\n CASE con.confupdtype\n WHEN 'a' THEN 'NO ACTION'\n WHEN 'r' THEN 'RESTRICT'\n WHEN 'n' THEN 'SET NULL'\n WHEN 'c' THEN 'CASCADE'\n WHEN 'd' THEN 'SET DEFAULT'\n END AS update_rule,\n CASE con.confdeltype\n WHEN 'a' THEN 'NO ACTION'\n WHEN 'r' THEN 'RESTRICT'\n WHEN 'n' THEN 'SET NULL'\n WHEN 'c' THEN 'CASCADE'\n WHEN 'd' THEN 'SET DEFAULT'\n END AS delete_rule\n FROM pg_catalog.pg_constraint con\n JOIN pg_catalog.pg_class rel ON rel.oid = con.conrelid\n JOIN pg_catalog.pg_namespace nsp ON nsp.oid = con.connamespace\n LEFT JOIN pg_catalog.pg_attribute att ON att.attnum = ANY (con.conkey)\n AND att.attrelid = con.conrelid\n LEFT JOIN pg_catalog.pg_class frel ON frel.oid = con.confrelid\n LEFT JOIN pg_catalog.pg_namespace fnsp ON fnsp.oid = frel.relnamespace\n LEFT JOIN pg_catalog.pg_attribute fatt ON fatt.attnum = ANY (con.confkey)\n AND fatt.attrelid = con.confrelid\n WHERE con.contype = 'f'\n AND nsp.nspname = ${schemaName}\n AND rel.relname = ${tableName}`,\n\t\t);\n\t\treturn getRows<ForeignKeyInfoRow>(result);\n\t}\n\n\t/**\n\t * Get primary keys for a table\n\t */\n\tprivate async getPrimaryKeys(\n\t\tschemaName: string,\n\t\ttableName: string,\n\t): Promise<PrimaryKeyInfoRow[]> {\n\t\tconst result = await this.db.execute(\n\t\t\tsql`SELECT \n con.conname AS name,\n ARRAY(\n SELECT a.attname\n FROM pg_attribute a\n WHERE a.attrelid = con.conrelid\n AND a.attnum = ANY(con.conkey)\n ORDER BY a.attnum\n ) AS columns\n FROM pg_constraint con\n JOIN pg_class rel ON rel.oid = con.conrelid\n JOIN pg_namespace nsp ON nsp.oid = con.connamespace\n WHERE con.contype = 'p'\n AND nsp.nspname = ${schemaName}\n AND rel.relname = ${tableName}`,\n\t\t);\n\t\treturn getRows<PrimaryKeyInfoRow>(result);\n\t}\n\n\t/**\n\t * Get unique constraints for a table\n\t */\n\tprivate async getUniqueConstraints(\n\t\tschemaName: string,\n\t\ttableName: string,\n\t): Promise<UniqueConstraintInfoRow[]> {\n\t\tconst result = await this.db.execute(\n\t\t\tsql`SELECT \n con.conname AS name,\n ARRAY(\n SELECT a.attname\n FROM pg_attribute a\n WHERE a.attrelid = con.conrelid\n AND a.attnum = ANY(con.conkey)\n ORDER BY a.attnum\n ) AS columns\n FROM pg_constraint con\n JOIN pg_class rel ON rel.oid = con.conrelid\n JOIN pg_namespace nsp ON nsp.oid = con.connamespace\n WHERE con.contype = 'u'\n AND nsp.nspname = ${schemaName}\n AND rel.relname = ${tableName}`,\n\t\t);\n\t\treturn getRows<UniqueConstraintInfoRow>(result);\n\t}\n\n\t/**\n\t * Get check constraints for a table\n\t */\n\tprivate async getCheckConstraints(\n\t\tschemaName: string,\n\t\ttableName: string,\n\t): Promise<CheckConstraintInfoRow[]> {\n\t\tconst result = await this.db.execute(\n\t\t\tsql`SELECT \n con.conname AS name,\n pg_get_constraintdef(con.oid) AS definition\n FROM pg_constraint con\n JOIN pg_class rel ON rel.oid = con.conrelid\n JOIN pg_namespace nsp ON nsp.oid = con.connamespace\n WHERE con.contype = 'c'\n AND nsp.nspname = ${schemaName}\n AND rel.relname = ${tableName}`,\n\t\t);\n\t\treturn getRows<CheckConstraintInfoRow>(result);\n\t}\n\n\t/**\n\t * Get enums in a schema\n\t */\n\tprivate async getEnums(schemaName: string): Promise<EnumInfoRow[]> {\n\t\tconst result = await this.db.execute(\n\t\t\tsql`SELECT \n n.nspname AS schema,\n t.typname AS name,\n e.enumlabel AS value,\n e.enumsortorder AS sort_order\n FROM pg_type t\n JOIN pg_enum e ON t.oid = e.enumtypid\n JOIN pg_catalog.pg_namespace n ON n.oid = t.typnamespace\n WHERE n.nspname = ${schemaName}\n ORDER BY schema, name, sort_order`,\n\t\t);\n\t\treturn getRows<EnumInfoRow>(result);\n\t}\n\n\t/**\n\t * Parse default value for a column\n\t */\n\tprivate parseDefault(\n\t\tdefaultValue: string,\n\t\tdataType: string,\n\t): string | undefined {\n\t\tif (!defaultValue) return undefined;\n\n\t\t// Remove the type cast if present (e.g., \"'value'::text\" -> \"'value'\")\n\t\tconst match = defaultValue.match(/^'(.*)'::/);\n\t\tif (match) {\n\t\t\treturn `'${match[1]}'`;\n\t\t}\n\n\t\t// Handle nextval for sequences\n\t\tif (defaultValue.includes(\"nextval(\")) {\n\t\t\treturn undefined; // Serial types handle this automatically\n\t\t}\n\n\t\t// Handle boolean defaults\n\t\tif (dataType === \"boolean\") {\n\t\t\tif (defaultValue === \"true\") return \"true\";\n\t\t\tif (defaultValue === \"false\") return \"false\";\n\t\t}\n\n\t\t// Return as-is for other cases\n\t\treturn defaultValue;\n\t}\n\n\t/**\n\t * Check if tables exist for a plugin by checking if any tables exist in its schema\n\t * @param pluginName - Name of the plugin\n\t * @returns True if tables exist, false otherwise\n\t */\n\tasync hasExistingTables(pluginName: string): Promise<boolean> {\n\t\tconst schemaName =\n\t\t\tpluginName === \"@elizaos/plugin-sql\"\n\t\t\t\t? \"public\"\n\t\t\t\t: this.deriveSchemaName(pluginName);\n\n\t\tconst result = await this.db.execute(\n\t\t\tsql`SELECT COUNT(*) AS count\n FROM information_schema.tables\n WHERE table_schema = ${schemaName}\n AND table_type = 'BASE TABLE'`,\n\t\t);\n\n\t\tconst firstRow = result.rows?.[0];\n\t\tconst count = parseInt((firstRow && (firstRow.count as string)) || \"0\", 10);\n\t\treturn count > 0;\n\t}\n\n\t/**\n\t * Derive schema name from plugin name\n\t */\n\tprivate deriveSchemaName(pluginName: string): string {\n\t\t// Same logic as in schema-transformer.ts\n\t\treturn pluginName\n\t\t\t.replace(\"@\", \"\")\n\t\t\t.replace(\"/\", \"_\")\n\t\t\t.replace(/-/g, \"_\")\n\t\t\t.toLowerCase();\n\t}\n}\n",
110
+ "import { logger } from \"@elizaos/core\";\nimport { sql } from \"drizzle-orm\";\nimport type { DrizzleDB } from \"./types\";\n\nexport class ExtensionManager {\n\tconstructor(private db: DrizzleDB) {}\n\n\tasync installRequiredExtensions(extensions: string[]): Promise<void> {\n\t\tfor (const extension of extensions) {\n\t\t\ttry {\n\t\t\t\t// Validate extension name to prevent SQL injection\n\t\t\t\t// Extension names should only contain alphanumeric characters, underscores, and hyphens\n\t\t\t\tif (!/^[a-zA-Z0-9_-]+$/.test(extension)) {\n\t\t\t\t\tlogger.warn(\n\t\t\t\t\t\t{ src: \"plugin:sql\", extension },\n\t\t\t\t\t\t\"Invalid extension name - contains invalid characters\",\n\t\t\t\t\t);\n\t\t\t\t\tcontinue;\n\t\t\t\t}\n\n\t\t\t\t// Use sql.identifier for safe escaping of SQL identifiers\n\t\t\t\tawait this.db.execute(\n\t\t\t\t\tsql`CREATE EXTENSION IF NOT EXISTS ${sql.identifier(extension)}`,\n\t\t\t\t);\n\t\t\t\tlogger.debug({ src: \"plugin:sql\", extension }, \"Extension installed\");\n\t\t\t} catch (error) {\n\t\t\t\tconst errorMessage =\n\t\t\t\t\terror instanceof Error ? error.message : String(error);\n\t\t\t\tlogger.warn(\n\t\t\t\t\t{ src: \"plugin:sql\", extension, error: errorMessage },\n\t\t\t\t\t\"Could not install extension\",\n\t\t\t\t);\n\t\t\t\t// Some extensions might not be available or already installed\n\t\t\t\t// This shouldn't stop the migration process\n\t\t\t}\n\t\t}\n\t}\n}\n",
111
+ "import { logger } from \"@elizaos/core\";\nimport { getTableConfig, type PgTable, pgSchema } from \"drizzle-orm/pg-core\";\n\n// Drizzle schema type - an object mapping names to tables or other schema objects\ntype DrizzleSchema = Record<string, unknown>;\n\n// pgSchema object interface\ninterface PgSchemaObject {\n\t_schema: string;\n\ttable: (...args: unknown[]) => unknown;\n}\n\n/**\n * Transform a plugin's schema to use the appropriate namespace\n *\n * @elizaos/plugin-sql uses 'public' schema (no transformation)\n * Other plugins get their tables wrapped in a namespaced schema\n */\nexport function transformPluginSchema(\n\tpluginName: string,\n\tschema: DrizzleSchema,\n): DrizzleSchema {\n\t// Core plugin uses public schema - no transformation needed\n\tif (pluginName === \"@elizaos/plugin-sql\") {\n\t\treturn schema;\n\t}\n\n\t// Derive schema name from plugin name\n\tconst schemaName = deriveSchemaName(pluginName);\n\n\t// If schema is already using pgSchema, return as-is\n\tif (isAlreadyNamespaced(schema, schemaName)) {\n\t\tlogger.debug(\n\t\t\t{ src: \"plugin:sql\", pluginName, schemaName },\n\t\t\t\"Plugin already uses expected schema\",\n\t\t);\n\t\treturn schema;\n\t}\n\n\tlogger.info(\n\t\t{ src: \"plugin:sql\", pluginName, schemaName },\n\t\t\"Transforming plugin to use schema\",\n\t);\n\n\t// Transform the schema object\n\tconst transformed: DrizzleSchema = {};\n\n\tfor (const [key, value] of Object.entries(schema)) {\n\t\tif (isPgTable(value)) {\n\t\t\t// Get the table configuration\n\t\t\tconst config = getTableConfig(value as PgTable);\n\n\t\t\t// If the table doesn't have a schema or is in public, warn about it\n\t\t\tif (!config.schema || config.schema === \"public\") {\n\t\t\t\t// Can't easily transform existing tables to different schema\n\t\t\t\t// (would require reconstructing all column definitions, constraints, etc.)\n\t\t\t\tlogger.warn(\n\t\t\t\t\t{\n\t\t\t\t\t\tsrc: \"plugin:sql\",\n\t\t\t\t\t\ttableName: config.name,\n\t\t\t\t\t\tpluginName,\n\t\t\t\t\t\texpectedSchema: schemaName,\n\t\t\t\t\t},\n\t\t\t\t\t\"Table should use pgSchema for proper isolation - manual migration may be required\",\n\t\t\t\t);\n\t\t\t\ttransformed[key] = value;\n\t\t\t} else {\n\t\t\t\t// Table already has a schema, keep it as-is\n\t\t\t\ttransformed[key] = value;\n\t\t\t}\n\t\t} else if (typeof value === \"object\" && value !== null) {\n\t\t\t// Check if this is a schema object (created with pgSchema)\n\t\t\tconst obj = value as PgSchemaObject;\n\t\t\tif (obj._schema && obj.table) {\n\t\t\t\t// This is already a pgSchema object, keep it\n\t\t\t\ttransformed[key] = value;\n\t\t\t} else {\n\t\t\t\t// Regular object, keep as-is\n\t\t\t\ttransformed[key] = value;\n\t\t\t}\n\t\t} else {\n\t\t\t// Not a table, keep as-is\n\t\t\ttransformed[key] = value;\n\t\t}\n\t}\n\n\treturn transformed;\n}\n\n/**\n * Derive a valid PostgreSQL schema name from a plugin name\n */\nexport function deriveSchemaName(pluginName: string): string {\n\t// Remove common prefixes and convert to lowercase with underscores\n\tlet schemaName = pluginName\n\t\t.replace(/^@[^/]+\\//, \"\") // Remove npm scope like @elizaos/\n\t\t.replace(/^plugin-/, \"\") // Remove plugin- prefix\n\t\t.toLowerCase();\n\n\t// Replace non-alphanumeric characters with underscores (avoid polynomial regex)\n\tschemaName = normalizeSchemaName(schemaName);\n\n\t// Ensure schema name is valid (not empty, not a reserved word)\n\tconst reserved = [\"public\", \"pg_catalog\", \"information_schema\", \"migrations\"];\n\tif (!schemaName || reserved.includes(schemaName)) {\n\t\t// Fallback to using the full plugin name with safe characters\n\t\tschemaName = `plugin_${normalizeSchemaName(pluginName.toLowerCase())}`;\n\t}\n\n\t// Ensure it starts with a letter (PostgreSQL requirement)\n\tif (!/^[a-z]/.test(schemaName)) {\n\t\tschemaName = `p_${schemaName}`;\n\t}\n\n\t// Truncate if too long (PostgreSQL identifier limit is 63 chars)\n\tif (schemaName.length > 63) {\n\t\tschemaName = schemaName.substring(0, 63);\n\t}\n\n\treturn schemaName;\n}\n\n/**\n * Normalize a string to be a valid PostgreSQL identifier\n * Avoids polynomial regex by using string manipulation instead\n */\nfunction normalizeSchemaName(input: string): string {\n\tconst chars: string[] = [];\n\tlet prevWasUnderscore = false;\n\n\tfor (let i = 0; i < input.length; i++) {\n\t\tconst char = input[i];\n\n\t\tif (/[a-z0-9]/.test(char)) {\n\t\t\tchars.push(char);\n\t\t\tprevWasUnderscore = false;\n\t\t} else if (!prevWasUnderscore) {\n\t\t\t// Only add underscore if previous char wasn't already an underscore\n\t\t\tchars.push(\"_\");\n\t\t\tprevWasUnderscore = true;\n\t\t}\n\t\t// Skip consecutive non-alphanumeric characters\n\t}\n\n\t// Remove leading and trailing underscores\n\tconst result = chars.join(\"\");\n\n\t// Trim underscores from start and end efficiently\n\tlet start = 0;\n\tlet end = result.length;\n\n\twhile (start < end && result[start] === \"_\") {\n\t\tstart++;\n\t}\n\n\twhile (end > start && result[end - 1] === \"_\") {\n\t\tend--;\n\t}\n\n\treturn result.slice(start, end);\n}\n\n/**\n * Check if a value is a PgTable\n */\nfunction isPgTable(value: unknown): value is PgTable {\n\tif (!value || typeof value !== \"object\") {\n\t\treturn false;\n\t}\n\n\t// Check for table-like properties\n\t// This is a heuristic since we can't use instanceof across module boundaries\n\ttry {\n\t\tconst config = getTableConfig(value as PgTable);\n\t\treturn config && typeof config.name === \"string\";\n\t} catch {\n\t\treturn false;\n\t}\n}\n\n/**\n * Check if a schema is already properly namespaced\n */\nfunction isAlreadyNamespaced(\n\tschema: DrizzleSchema,\n\texpectedSchemaName: string,\n): boolean {\n\tfor (const value of Object.values(schema)) {\n\t\tif (isPgTable(value)) {\n\t\t\ttry {\n\t\t\t\tconst config = getTableConfig(value);\n\t\t\t\tif (config.schema === expectedSchemaName) {\n\t\t\t\t\treturn true;\n\t\t\t\t}\n\t\t\t} catch {\n\t\t\t\t// Not a table, continue\n\t\t\t}\n\t\t}\n\t}\n\treturn false;\n}\n\n/**\n * Create a namespaced schema helper for plugins\n * This is what plugins should ideally use to define their tables\n */\nexport function createPluginSchema(pluginName: string) {\n\tconst schemaName = deriveSchemaName(pluginName);\n\treturn pgSchema(schemaName);\n}\n",
112
+ "import { sql } from \"drizzle-orm\";\nimport { getRow } from \"../../types\";\nimport type { DrizzleDB, Journal, JournalEntry } from \"../types\";\n\nexport class JournalStorage {\n\tconstructor(private db: DrizzleDB) {}\n\n\tasync loadJournal(pluginName: string): Promise<Journal | null> {\n\t\tconst result = await this.db.execute(\n\t\t\tsql`SELECT version, dialect, entries \n FROM migrations._journal \n WHERE plugin_name = ${pluginName}`,\n\t\t);\n\n\t\tif (result.rows.length === 0) {\n\t\t\treturn null;\n\t\t}\n\n\t\tinterface JournalRow {\n\t\t\tversion: string;\n\t\t\tdialect: string;\n\t\t\tentries: JournalEntry[];\n\t\t}\n\t\tconst row = getRow<JournalRow>(result);\n\t\tif (!row) {\n\t\t\tthrow new Error(`Journal not found for plugin: ${pluginName}`);\n\t\t}\n\t\treturn {\n\t\t\tversion: row.version,\n\t\t\tdialect: row.dialect,\n\t\t\tentries: row.entries as JournalEntry[],\n\t\t};\n\t}\n\n\tasync saveJournal(pluginName: string, journal: Journal): Promise<void> {\n\t\tawait this.db.execute(\n\t\t\tsql`INSERT INTO migrations._journal (plugin_name, version, dialect, entries)\n VALUES (${pluginName}, ${journal.version}, ${journal.dialect}, ${JSON.stringify(journal.entries)}::jsonb)\n ON CONFLICT (plugin_name) \n DO UPDATE SET \n version = EXCLUDED.version,\n dialect = EXCLUDED.dialect,\n entries = EXCLUDED.entries`,\n\t\t);\n\t}\n\n\tasync addEntry(pluginName: string, entry: JournalEntry): Promise<void> {\n\t\t// First, get the current journal\n\t\tlet journal = await this.loadJournal(pluginName);\n\n\t\t// If no journal exists, create a new one\n\t\tif (!journal) {\n\t\t\tjournal = {\n\t\t\t\tversion: \"7\", // Latest Drizzle version\n\t\t\t\tdialect: \"postgresql\",\n\t\t\t\tentries: [],\n\t\t\t};\n\t\t}\n\n\t\t// Add the new entry\n\t\tjournal.entries.push(entry);\n\n\t\t// Save the updated journal\n\t\tawait this.saveJournal(pluginName, journal);\n\t}\n\n\tasync getNextIdx(pluginName: string): Promise<number> {\n\t\tconst journal = await this.loadJournal(pluginName);\n\n\t\tif (!journal || journal.entries.length === 0) {\n\t\t\treturn 0;\n\t\t}\n\n\t\tconst lastEntry = journal.entries[journal.entries.length - 1];\n\t\treturn lastEntry.idx + 1;\n\t}\n\n\tasync updateJournal(\n\t\tpluginName: string,\n\t\tidx: number,\n\t\ttag: string,\n\t\tbreakpoints: boolean = true,\n\t): Promise<void> {\n\t\tconst entry: JournalEntry = {\n\t\t\tidx,\n\t\t\tversion: \"7\",\n\t\t\twhen: Date.now(),\n\t\t\ttag,\n\t\t\tbreakpoints,\n\t\t};\n\n\t\tawait this.addEntry(pluginName, entry);\n\t}\n}\n",
113
+ "import { sql } from \"drizzle-orm\";\nimport { getRow } from \"../../types\";\nimport type { DrizzleDB } from \"../types\";\n\nexport class MigrationTracker {\n\tconstructor(private db: DrizzleDB) {}\n\n\tasync ensureSchema(): Promise<void> {\n\t\tawait this.db.execute(sql`CREATE SCHEMA IF NOT EXISTS migrations`);\n\t}\n\n\tasync ensureTables(): Promise<void> {\n\t\t// Ensure schema exists\n\t\tawait this.ensureSchema();\n\n\t\t// Create migrations table (like Drizzle's __drizzle_migrations)\n\t\tawait this.db.execute(sql`\n CREATE TABLE IF NOT EXISTS migrations._migrations (\n id SERIAL PRIMARY KEY,\n plugin_name TEXT NOT NULL,\n hash TEXT NOT NULL,\n created_at BIGINT NOT NULL\n )\n `);\n\n\t\t// Create journal table (replaces _journal.json)\n\t\tawait this.db.execute(sql`\n CREATE TABLE IF NOT EXISTS migrations._journal (\n plugin_name TEXT PRIMARY KEY,\n version TEXT NOT NULL,\n dialect TEXT NOT NULL DEFAULT 'postgresql',\n entries JSONB NOT NULL DEFAULT '[]'\n )\n `);\n\n\t\t// Create snapshots table (replaces snapshot JSON files)\n\t\tawait this.db.execute(sql`\n CREATE TABLE IF NOT EXISTS migrations._snapshots (\n id SERIAL PRIMARY KEY,\n plugin_name TEXT NOT NULL,\n idx INTEGER NOT NULL,\n snapshot JSONB NOT NULL,\n created_at TIMESTAMP DEFAULT NOW(),\n UNIQUE(plugin_name, idx)\n )\n `);\n\t}\n\n\tasync getLastMigration(pluginName: string): Promise<{\n\t\tid: number;\n\t\thash: string;\n\t\tcreated_at: string;\n\t} | null> {\n\t\tconst result = await this.db.execute(\n\t\t\tsql`SELECT id, hash, created_at\n FROM migrations._migrations\n WHERE plugin_name = ${pluginName}\n ORDER BY created_at DESC\n LIMIT 1`,\n\t\t);\n\t\tinterface MigrationRow {\n\t\t\tid: number;\n\t\t\thash: string;\n\t\t\tcreated_at: string;\n\t\t}\n\t\treturn getRow<MigrationRow>(result) || null;\n\t}\n\n\tasync recordMigration(\n\t\tpluginName: string,\n\t\thash: string,\n\t\tcreatedAt: number,\n\t): Promise<void> {\n\t\tawait this.db.execute(\n\t\t\tsql`INSERT INTO migrations._migrations (plugin_name, hash, created_at) \n VALUES (${pluginName}, ${hash}, ${createdAt})`,\n\t\t);\n\t}\n}\n",
114
+ "import { sql } from \"drizzle-orm\";\nimport type { DrizzleDB, SchemaSnapshot } from \"../types\";\n\nexport class SnapshotStorage {\n\tconstructor(private db: DrizzleDB) {}\n\n\tasync saveSnapshot(\n\t\tpluginName: string,\n\t\tidx: number,\n\t\tsnapshot: SchemaSnapshot,\n\t): Promise<void> {\n\t\tawait this.db.execute(\n\t\t\tsql`INSERT INTO migrations._snapshots (plugin_name, idx, snapshot)\n VALUES (${pluginName}, ${idx}, ${JSON.stringify(snapshot)}::jsonb)\n ON CONFLICT (plugin_name, idx) \n DO UPDATE SET \n snapshot = EXCLUDED.snapshot,\n created_at = NOW()`,\n\t\t);\n\t}\n\n\tasync loadSnapshot(\n\t\tpluginName: string,\n\t\tidx: number,\n\t): Promise<SchemaSnapshot | null> {\n\t\tconst result = await this.db.execute(\n\t\t\tsql`SELECT snapshot \n FROM migrations._snapshots \n WHERE plugin_name = ${pluginName} AND idx = ${idx}`,\n\t\t);\n\n\t\tif (result.rows.length === 0) {\n\t\t\treturn null;\n\t\t}\n\n\t\treturn result.rows[0].snapshot as SchemaSnapshot;\n\t}\n\n\tasync getLatestSnapshot(pluginName: string): Promise<SchemaSnapshot | null> {\n\t\tconst result = await this.db.execute(\n\t\t\tsql`SELECT snapshot \n FROM migrations._snapshots \n WHERE plugin_name = ${pluginName}\n ORDER BY idx DESC\n LIMIT 1`,\n\t\t);\n\n\t\tif (result.rows.length === 0) {\n\t\t\treturn null;\n\t\t}\n\n\t\treturn result.rows[0].snapshot as SchemaSnapshot;\n\t}\n\n\tasync getAllSnapshots(pluginName: string): Promise<SchemaSnapshot[]> {\n\t\tconst result = await this.db.execute(\n\t\t\tsql`SELECT snapshot \n FROM migrations._snapshots \n WHERE plugin_name = ${pluginName}\n ORDER BY idx ASC`,\n\t\t);\n\n\t\treturn result.rows.map((row) => row.snapshot as SchemaSnapshot);\n\t}\n}\n",
115
+ "import { logger } from \"@elizaos/core\";\nimport { sql } from \"drizzle-orm\";\nimport { getRow } from \"../types\";\nimport { stringToBigInt } from \"./crypto-utils\";\nimport { DatabaseIntrospector } from \"./drizzle-adapters/database-introspector\";\nimport {\n\tcalculateDiff,\n\thasDiffChanges,\n} from \"./drizzle-adapters/diff-calculator\";\nimport {\n\tgenerateSnapshot,\n\thasChanges,\n\thashSnapshot,\n} from \"./drizzle-adapters/snapshot-generator\";\nimport {\n\tcheckForDataLoss,\n\ttype DataLossCheck,\n\tgenerateMigrationSQL,\n} from \"./drizzle-adapters/sql-generator\";\nimport { ExtensionManager } from \"./extension-manager\";\nimport { deriveSchemaName } from \"./schema-transformer\";\nimport { JournalStorage } from \"./storage/journal-storage\";\nimport { MigrationTracker } from \"./storage/migration-tracker\";\nimport { SnapshotStorage } from \"./storage/snapshot-storage\";\nimport type {\n\tDrizzleDB,\n\tRuntimeMigrationOptions,\n\tSchemaSnapshot,\n\tSchemaTable,\n} from \"./types\";\n\nexport class RuntimeMigrator {\n\tprivate migrationTracker: MigrationTracker;\n\tprivate journalStorage: JournalStorage;\n\tprivate snapshotStorage: SnapshotStorage;\n\tprivate extensionManager: ExtensionManager;\n\tprivate introspector: DatabaseIntrospector;\n\n\tconstructor(private db: DrizzleDB) {\n\t\tthis.migrationTracker = new MigrationTracker(db);\n\t\tthis.journalStorage = new JournalStorage(db);\n\t\tthis.snapshotStorage = new SnapshotStorage(db);\n\t\tthis.extensionManager = new ExtensionManager(db);\n\t\tthis.introspector = new DatabaseIntrospector(db);\n\t}\n\n\t/**\n\t * Get expected schema name for a plugin\n\t * @elizaos/plugin-sql uses 'public' schema (core application)\n\t * All other plugins should use namespaced schemas\n\t */\n\tprivate getExpectedSchemaName(pluginName: string): string {\n\t\t// Core plugin uses public schema\n\t\tif (pluginName === \"@elizaos/plugin-sql\") {\n\t\t\treturn \"public\";\n\t\t}\n\n\t\t// Use the schema transformer's logic for consistency\n\t\treturn deriveSchemaName(pluginName);\n\t}\n\n\t/**\n\t * Ensure all schemas used in the snapshot exist\n\t */\n\tprivate async ensureSchemasExist(snapshot: SchemaSnapshot): Promise<void> {\n\t\tconst schemasToCreate = new Set<string>();\n\n\t\t// Collect all schemas from tables\n\t\tfor (const table of Object.values(snapshot.tables)) {\n\t\t\tconst schemaName = table.schema || \"public\";\n\t\t\tif (schemaName !== \"public\") {\n\t\t\t\tschemasToCreate.add(schemaName);\n\t\t\t}\n\t\t}\n\n\t\t// Also add schemas from the snapshot's schemas object\n\t\tfor (const schema of Object.keys(snapshot.schemas || {})) {\n\t\t\tif (schema !== \"public\") {\n\t\t\t\tschemasToCreate.add(schema);\n\t\t\t}\n\t\t}\n\n\t\t// Create all non-public schemas\n\t\tfor (const schemaName of schemasToCreate) {\n\t\t\tlogger.debug({ src: \"plugin:sql\", schemaName }, \"Ensuring schema exists\");\n\t\t\tawait this.db.execute(\n\t\t\t\tsql.raw(`CREATE SCHEMA IF NOT EXISTS \"${schemaName}\"`),\n\t\t\t);\n\t\t}\n\t}\n\n\t/**\n\t * Validate schema usage and provide warnings\n\t */\n\tprivate validateSchemaUsage(\n\t\tpluginName: string,\n\t\tsnapshot: SchemaSnapshot,\n\t): void {\n\t\tconst expectedSchema = this.getExpectedSchemaName(pluginName);\n\t\tconst isCorePLugin = pluginName === \"@elizaos/plugin-sql\";\n\n\t\tfor (const table of Object.values(snapshot.tables)) {\n\t\t\tconst actualSchema = table.schema || \"public\";\n\n\t\t\t// Warn if non-core plugin is using public schema\n\t\t\tif (!isCorePLugin && actualSchema === \"public\") {\n\t\t\t\tlogger.warn(\n\t\t\t\t\t{\n\t\t\t\t\t\tsrc: \"plugin:sql\",\n\t\t\t\t\t\tpluginName,\n\t\t\t\t\t\ttableName: table.name,\n\t\t\t\t\t\texpectedSchema,\n\t\t\t\t\t},\n\t\t\t\t\t\"Plugin table is using public schema - consider using pgSchema for better isolation\",\n\t\t\t\t);\n\t\t\t}\n\n\t\t\t// Warn if core plugin is not using public schema\n\t\t\tif (isCorePLugin && actualSchema !== \"public\") {\n\t\t\t\tlogger.warn(\n\t\t\t\t\t{\n\t\t\t\t\t\tsrc: \"plugin:sql\",\n\t\t\t\t\t\tpluginName: \"@elizaos/plugin-sql\",\n\t\t\t\t\t\ttableName: table.name,\n\t\t\t\t\t\tactualSchema,\n\t\t\t\t\t},\n\t\t\t\t\t\"Core plugin table should use public schema\",\n\t\t\t\t);\n\t\t\t}\n\t\t}\n\t}\n\n\t/**\n\t * Generate a stable advisory lock ID from plugin name\n\t * PostgreSQL advisory locks use bigint, so we need to hash the plugin name\n\t * and convert to a stable bigint value\n\t * Uses browser-compatible hashing\n\t */\n\tprivate getAdvisoryLockId(pluginName: string): bigint {\n\t\treturn stringToBigInt(pluginName);\n\t}\n\n\t/**\n\t * Validate that a value is a valid PostgreSQL bigint\n\t * PostgreSQL bigint range: -9223372036854775808 to 9223372036854775807\n\t */\n\tprivate validateBigInt(value: bigint): boolean {\n\t\tconst MIN_BIGINT = -9223372036854775808n;\n\t\tconst MAX_BIGINT = 9223372036854775807n;\n\t\treturn value >= MIN_BIGINT && value <= MAX_BIGINT;\n\t}\n\n\t/**\n\t * Detect if a connection string represents a real PostgreSQL database\n\t * (not PGLite, in-memory, or other non-PostgreSQL databases)\n\t */\n\tprivate isRealPostgresDatabase(connectionUrl: string): boolean {\n\t\tif (!connectionUrl?.trim()) return false;\n\n\t\tconst url = connectionUrl.trim().toLowerCase();\n\n\t\t// Exclude non-PostgreSQL databases (check schemes first)\n\t\tconst nonPgSchemes = [\n\t\t\t\"mysql://\",\n\t\t\t\"mysqli://\",\n\t\t\t\"mariadb://\",\n\t\t\t\"mongodb://\",\n\t\t\t\"mongodb+srv://\",\n\t\t];\n\t\tif (nonPgSchemes.some((s) => url.startsWith(s))) return false;\n\n\t\t// Always reject :memory: databases (even with postgres:// scheme, it's not valid)\n\t\tif (url.includes(\":memory:\")) return false;\n\n\t\t// PostgreSQL URL schemes - check BEFORE other exclude patterns\n\t\t// (a postgres:// URL may have \"sqlite\" in the database name, that's OK)\n\t\tconst pgSchemes = [\n\t\t\t\"postgres://\",\n\t\t\t\"postgresql://\",\n\t\t\t\"postgis://\",\n\t\t\t\"pgbouncer://\",\n\t\t\t\"pgpool://\",\n\t\t\t\"cockroach://\",\n\t\t\t\"cockroachdb://\",\n\t\t\t\"redshift://\",\n\t\t\t\"timescaledb://\",\n\t\t\t\"yugabyte://\",\n\t\t];\n\t\tif (pgSchemes.some((s) => url.startsWith(s))) return true;\n\n\t\t// Exclude PGLite, SQLite databases (only for non-postgres:// URLs)\n\t\tconst excludePatterns = [\"pglite\", \"sqlite\"];\n\t\tconst urlBase = url.split(\"?\")[0];\n\t\tif (excludePatterns.some((p) => url.includes(p))) return false;\n\t\tif (/\\.(db|sqlite|sqlite3)$/.test(urlBase)) return false;\n\n\t\t// Local PostgreSQL (localhost, 127.0.0.1, Docker service names)\n\t\tif (url.includes(\"localhost\") || url.includes(\"127.0.0.1\")) return true;\n\n\t\t// PostgreSQL connection params (libpq style)\n\t\tconst connParams = [\n\t\t\t\"host=\",\n\t\t\t\"dbname=\",\n\t\t\t\"sslmode=\",\n\t\t\t\"connect_timeout=\",\n\t\t\t\"application_name=\",\n\t\t\t\"user=\",\n\t\t\t\"password=\",\n\t\t\t\"port=\",\n\t\t\t\"options=\",\n\t\t\t\"sslcert=\",\n\t\t\t\"sslkey=\",\n\t\t\t\"sslrootcert=\",\n\t\t\t\"fallback_application_name=\",\n\t\t\t\"keepalives=\",\n\t\t\t\"target_session_attrs=\",\n\t\t];\n\t\tif (connParams.some((p) => url.includes(p))) return true;\n\n\t\t// user@host format with postgres keyword or port\n\t\tif (url.includes(\"@\") && (url.includes(\"postgres\") || /:\\d{4,5}/.test(url)))\n\t\t\treturn true;\n\n\t\t// Common PostgreSQL ports\n\t\tif (/:(5432|5433|5434|6432|8432|9999|25060|26257)\\b/.test(url)) return true;\n\n\t\t// Cloud providers\n\t\tconst cloudPatterns = [\n\t\t\t// AWS\n\t\t\t\"amazonaws.com\",\n\t\t\t\".rds.\",\n\t\t\t// Azure\n\t\t\t\"azure.com\",\n\t\t\t\"database.azure.com\",\n\t\t\t// Google Cloud\n\t\t\t\"googleusercontent\",\n\t\t\t\"cloudsql\",\n\t\t\t// Supabase\n\t\t\t\"supabase\",\n\t\t\t// Neon\n\t\t\t\"neon.tech\",\n\t\t\t\"neon.build\",\n\t\t\t// Railway\n\t\t\t\"railway.app\",\n\t\t\t\"railway.internal\",\n\t\t\t// Render\n\t\t\t\"render.com\",\n\t\t\t\"onrender.com\",\n\t\t\t// Heroku\n\t\t\t\"heroku\",\n\t\t\t// TimescaleDB\n\t\t\t\"timescale\",\n\t\t\t\".tsdb.cloud\",\n\t\t\t// CockroachDB\n\t\t\t\"cockroachlabs\",\n\t\t\t\"cockroachdb.cloud\",\n\t\t\t\".crdb.io\",\n\t\t\t// DigitalOcean\n\t\t\t\"digitalocean\",\n\t\t\t\"db.ondigitalocean\",\n\t\t\t\"do-user-\",\n\t\t\t// Aiven\n\t\t\t\"aiven\",\n\t\t\t// Crunchy Data\n\t\t\t\"crunchydata\",\n\t\t\t// ElephantSQL\n\t\t\t\"elephantsql\",\n\t\t\t// YugabyteDB\n\t\t\t\"yugabyte\",\n\t\t\t// Scaleway\n\t\t\t\"scaleway\",\n\t\t\t\".rdb.fr-par.scw.cloud\",\n\t\t\t// Vercel Postgres\n\t\t\t\"vercel-storage\",\n\t\t\t// PlanetScale\n\t\t\t\"psdb.cloud\",\n\t\t\t// Xata\n\t\t\t\"xata.sh\",\n\t\t\t// Fly.io\n\t\t\t\"fly.dev\",\n\t\t\t\"fly.io\",\n\t\t];\n\t\tif (cloudPatterns.some((p) => url.includes(p))) return true;\n\n\t\t// IP:port patterns (IPv4 and IPv6)\n\t\tif (/\\d{1,3}\\.\\d{1,3}\\.\\d{1,3}\\.\\d{1,3}:\\d{1,5}/.test(url)) return true;\n\t\tif (/\\[[0-9a-f:]+\\](:\\d{1,5})?/i.test(connectionUrl)) return true;\n\n\t\t// host:port/database format (Docker Compose, etc.)\n\t\tif (/^[a-z0-9_.-]+:\\d{1,5}\\/[a-z0-9_-]+/i.test(connectionUrl)) return true;\n\n\t\tlogger.debug(\n\t\t\t{ src: \"plugin:sql\", urlPreview: url.substring(0, 50) },\n\t\t\t\"Connection string did not match any PostgreSQL patterns\",\n\t\t);\n\t\treturn false;\n\t}\n\n\t/**\n\t * Initialize migration system - create necessary tables\n\t * @throws Error if table creation fails\n\t */\n\tasync initialize(): Promise<void> {\n\t\tlogger.info({ src: \"plugin:sql\" }, \"Initializing migration system\");\n\t\tawait this.migrationTracker.ensureTables();\n\t\tlogger.info({ src: \"plugin:sql\" }, \"Migration system initialized\");\n\t}\n\n\t/**\n\t * Run migrations for a plugin/schema\n\t * @param pluginName - Plugin identifier\n\t * @param schema - Drizzle schema object\n\t * @param options - Migration options (verbose, force, dryRun, allowDataLoss)\n\t * @throws Error if destructive migrations blocked or migration fails\n\t */\n\tasync migrate(\n\t\tpluginName: string,\n\t\tschema: Record<string, unknown>,\n\t\toptions: RuntimeMigrationOptions = {},\n\t): Promise<void> {\n\t\tconst lockId = this.getAdvisoryLockId(pluginName);\n\n\t\t// Validate lockId is within PostgreSQL bigint range\n\t\tif (!this.validateBigInt(lockId)) {\n\t\t\tthrow new Error(\n\t\t\t\t`Invalid advisory lock ID generated for plugin ${pluginName}`,\n\t\t\t);\n\t\t}\n\n\t\tlet lockAcquired = false;\n\n\t\ttry {\n\t\t\tlogger.info(\n\t\t\t\t{ src: \"plugin:sql\", pluginName },\n\t\t\t\t\"Starting migration for plugin\",\n\t\t\t);\n\n\t\t\t// Ensure migration tables exist\n\t\t\tawait this.initialize();\n\n\t\t\t// Only use advisory locks for real PostgreSQL databases\n\t\t\t// Skip for PGLite or development databases\n\t\t\tconst postgresUrl =\n\t\t\t\tprocess.env.POSTGRES_URL || process.env.DATABASE_URL || \"\";\n\t\t\tconst isRealPostgres = this.isRealPostgresDatabase(postgresUrl);\n\n\t\t\tif (isRealPostgres) {\n\t\t\t\ttry {\n\t\t\t\t\tlogger.debug(\n\t\t\t\t\t\t{ src: \"plugin:sql\", pluginName },\n\t\t\t\t\t\t\"Using PostgreSQL advisory locks\",\n\t\t\t\t\t);\n\n\t\t\t\t\t// Convert bigint to string for SQL query\n\t\t\t\t\t// The sql tagged template will properly parameterize this value\n\t\t\t\t\tconst lockIdStr = lockId.toString();\n\n\t\t\t\t\tconst lockResult = await this.db.execute(\n\t\t\t\t\t\tsql`SELECT pg_try_advisory_lock(CAST(${lockIdStr} AS bigint)) as acquired`,\n\t\t\t\t\t);\n\n\t\t\t\t\tinterface LockResultRow {\n\t\t\t\t\t\tacquired: boolean;\n\t\t\t\t\t}\n\t\t\t\t\tlockAcquired = getRow<LockResultRow>(lockResult)?.acquired === true;\n\n\t\t\t\t\tif (!lockAcquired) {\n\t\t\t\t\t\tlogger.info(\n\t\t\t\t\t\t\t{ src: \"plugin:sql\", pluginName },\n\t\t\t\t\t\t\t\"Migration already in progress, waiting for lock\",\n\t\t\t\t\t\t);\n\n\t\t\t\t\t\t// Wait for the lock (blocking call)\n\t\t\t\t\t\tawait this.db.execute(\n\t\t\t\t\t\t\tsql`SELECT pg_advisory_lock(CAST(${lockIdStr} AS bigint))`,\n\t\t\t\t\t\t);\n\t\t\t\t\t\tlockAcquired = true;\n\n\t\t\t\t\t\tlogger.info({ src: \"plugin:sql\", pluginName }, \"Lock acquired\");\n\t\t\t\t\t} else {\n\t\t\t\t\t\tlogger.debug(\n\t\t\t\t\t\t\t{ src: \"plugin:sql\", pluginName, lockId: lockIdStr },\n\t\t\t\t\t\t\t\"Advisory lock acquired\",\n\t\t\t\t\t\t);\n\t\t\t\t\t}\n\t\t\t\t} catch (lockError) {\n\t\t\t\t\t// If advisory locks fail, log but continue\n\t\t\t\t\t// This might happen if the PostgreSQL version doesn't support advisory locks\n\t\t\t\t\tlogger.warn(\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tsrc: \"plugin:sql\",\n\t\t\t\t\t\t\tpluginName,\n\t\t\t\t\t\t\terror:\n\t\t\t\t\t\t\t\tlockError instanceof Error\n\t\t\t\t\t\t\t\t\t? lockError.message\n\t\t\t\t\t\t\t\t\t: String(lockError),\n\t\t\t\t\t\t},\n\t\t\t\t\t\t\"Failed to acquire advisory lock, continuing without lock\",\n\t\t\t\t\t);\n\t\t\t\t\tlockAcquired = false;\n\t\t\t\t}\n\t\t\t} else {\n\t\t\t\t// For PGLite or other development databases, skip advisory locks\n\t\t\t\tlogger.debug(\n\t\t\t\t\t{ src: \"plugin:sql\" },\n\t\t\t\t\t\"Development database detected, skipping advisory locks\",\n\t\t\t\t);\n\t\t\t}\n\n\t\t\t// Install required extensions\n\t\t\t// pgcrypto is only needed for real PostgreSQL (PGLite uses native gen_random_uuid)\n\t\t\tconst extensions = isRealPostgres\n\t\t\t\t? [\"vector\", \"fuzzystrmatch\", \"pgcrypto\"]\n\t\t\t\t: [\"vector\", \"fuzzystrmatch\"];\n\t\t\tawait this.extensionManager.installRequiredExtensions(extensions);\n\n\t\t\t// Generate current snapshot from schema\n\t\t\tconst currentSnapshot = await generateSnapshot(schema);\n\n\t\t\t// Ensure all schemas referenced in the snapshot exist\n\t\t\tawait this.ensureSchemasExist(currentSnapshot);\n\n\t\t\t// Validate schema usage and warn about potential issues\n\t\t\tthis.validateSchemaUsage(pluginName, currentSnapshot);\n\n\t\t\tconst currentHash = hashSnapshot(currentSnapshot);\n\n\t\t\t// Check if we've already run this exact migration\n\t\t\t// This check happens AFTER acquiring the lock to handle concurrent scenarios\n\t\t\t// This is critical: if we had to wait for the lock (lockAcquired was initially false),\n\t\t\t// another process may have completed the migration while we were waiting\n\t\t\t// We MUST check regardless of whether lastMigration existed before\n\t\t\tconst lastMigration =\n\t\t\t\tawait this.migrationTracker.getLastMigration(pluginName);\n\t\t\tif (lastMigration && lastMigration.hash === currentHash) {\n\t\t\t\tlogger.info(\n\t\t\t\t\t{ src: \"plugin:sql\", pluginName, hash: currentHash },\n\t\t\t\t\t\"No changes detected, skipping migration\",\n\t\t\t\t);\n\t\t\t\treturn;\n\t\t\t}\n\n\t\t\t// Load previous snapshot\n\t\t\tlet previousSnapshot =\n\t\t\t\tawait this.snapshotStorage.getLatestSnapshot(pluginName);\n\n\t\t\t// If no snapshot exists but tables exist in database, introspect them\n\t\t\tif (!previousSnapshot && Object.keys(currentSnapshot.tables).length > 0) {\n\t\t\t\tconst hasExistingTables =\n\t\t\t\t\tawait this.introspector.hasExistingTables(pluginName);\n\n\t\t\t\tif (hasExistingTables) {\n\t\t\t\t\tlogger.info(\n\t\t\t\t\t\t{ src: \"plugin:sql\", pluginName },\n\t\t\t\t\t\t\"No snapshot found but tables exist in database, introspecting\",\n\t\t\t\t\t);\n\n\t\t\t\t\t// Determine the schema name for introspection\n\t\t\t\t\tconst schemaName = this.getExpectedSchemaName(pluginName);\n\n\t\t\t\t\t// Introspect the current database state\n\t\t\t\t\tconst introspectedSnapshot =\n\t\t\t\t\t\tawait this.introspector.introspectSchema(schemaName);\n\n\t\t\t\t\t// IMPORTANT: Filter the introspected snapshot to only include tables that are\n\t\t\t\t\t// defined in the current schema. This prevents tables from other plugins\n\t\t\t\t\t// (e.g., gamification tables in 'public' schema) from being marked as \"orphans\"\n\t\t\t\t\t// and scheduled for deletion.\n\t\t\t\t\tconst expectedTableNames = new Set<string>();\n\t\t\t\t\tfor (const tableKey of Object.keys(currentSnapshot.tables)) {\n\t\t\t\t\t\tconst tableData = currentSnapshot.tables[tableKey];\n\t\t\t\t\t\tconst tableName = tableData.name || tableKey.split(\".\").pop() || \"\";\n\t\t\t\t\t\texpectedTableNames.add(tableName);\n\t\t\t\t\t}\n\n\t\t\t\t\t// Filter introspected tables to only those in the current schema\n\t\t\t\t\tconst filteredTables: Record<string, SchemaTable> = {};\n\t\t\t\t\tfor (const tableKey of Object.keys(introspectedSnapshot.tables)) {\n\t\t\t\t\t\tconst tableData = introspectedSnapshot.tables[tableKey];\n\t\t\t\t\t\tconst tableName = tableData.name || tableKey.split(\".\").pop() || \"\";\n\t\t\t\t\t\tif (expectedTableNames.has(tableName)) {\n\t\t\t\t\t\t\tfilteredTables[tableKey] = tableData;\n\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\tlogger.debug(\n\t\t\t\t\t\t\t\t{ src: \"plugin:sql\", pluginName, tableName },\n\t\t\t\t\t\t\t\t\"Ignoring table from introspection (not in current schema)\",\n\t\t\t\t\t\t\t);\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\n\t\t\t\t\t// Use filtered snapshot\n\t\t\t\t\tconst filteredSnapshot = {\n\t\t\t\t\t\t...introspectedSnapshot,\n\t\t\t\t\t\ttables: filteredTables,\n\t\t\t\t\t};\n\n\t\t\t\t\t// Only use the introspected snapshot if it has tables\n\t\t\t\t\tif (Object.keys(filteredSnapshot.tables).length > 0) {\n\t\t\t\t\t\t// Save this as the initial snapshot (idx: 0)\n\t\t\t\t\t\tawait this.snapshotStorage.saveSnapshot(\n\t\t\t\t\t\t\tpluginName,\n\t\t\t\t\t\t\t0,\n\t\t\t\t\t\t\tfilteredSnapshot,\n\t\t\t\t\t\t);\n\n\t\t\t\t\t\t// Update journal to record this initial state\n\t\t\t\t\t\tawait this.journalStorage.updateJournal(\n\t\t\t\t\t\t\tpluginName,\n\t\t\t\t\t\t\t0,\n\t\t\t\t\t\t\t`introspected_${Date.now()}`,\n\t\t\t\t\t\t\ttrue,\n\t\t\t\t\t\t);\n\n\t\t\t\t\t\t// Record this as a migration\n\t\t\t\t\t\tconst filteredHash = hashSnapshot(filteredSnapshot);\n\t\t\t\t\t\tawait this.migrationTracker.recordMigration(\n\t\t\t\t\t\t\tpluginName,\n\t\t\t\t\t\t\tfilteredHash,\n\t\t\t\t\t\t\tDate.now(),\n\t\t\t\t\t\t);\n\n\t\t\t\t\t\tlogger.info(\n\t\t\t\t\t\t\t{ src: \"plugin:sql\", pluginName },\n\t\t\t\t\t\t\t\"Created initial snapshot from existing database\",\n\t\t\t\t\t\t);\n\n\t\t\t\t\t\t// Set this as the previous snapshot for comparison\n\t\t\t\t\t\tpreviousSnapshot = filteredSnapshot;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\n\t\t\t// Check if there are actual changes\n\t\t\tif (!hasChanges(previousSnapshot, currentSnapshot)) {\n\t\t\t\tlogger.info({ src: \"plugin:sql\", pluginName }, \"No schema changes\");\n\n\t\t\t\t// For empty schemas, we still want to record the migration\n\t\t\t\t// to ensure idempotency and consistency\n\t\t\t\tif (\n\t\t\t\t\t!previousSnapshot &&\n\t\t\t\t\tObject.keys(currentSnapshot.tables).length === 0\n\t\t\t\t) {\n\t\t\t\t\tlogger.info(\n\t\t\t\t\t\t{ src: \"plugin:sql\", pluginName },\n\t\t\t\t\t\t\"Recording empty schema\",\n\t\t\t\t\t);\n\t\t\t\t\tawait this.migrationTracker.recordMigration(\n\t\t\t\t\t\tpluginName,\n\t\t\t\t\t\tcurrentHash,\n\t\t\t\t\t\tDate.now(),\n\t\t\t\t\t);\n\t\t\t\t\tconst idx = await this.journalStorage.getNextIdx(pluginName);\n\t\t\t\t\tconst tag = this.generateMigrationTag(idx, pluginName);\n\t\t\t\t\tawait this.journalStorage.updateJournal(pluginName, idx, tag, true);\n\t\t\t\t\tawait this.snapshotStorage.saveSnapshot(\n\t\t\t\t\t\tpluginName,\n\t\t\t\t\t\tidx,\n\t\t\t\t\t\tcurrentSnapshot,\n\t\t\t\t\t);\n\t\t\t\t}\n\n\t\t\t\treturn;\n\t\t\t}\n\n\t\t\t// Calculate diff\n\t\t\tconst diff = await calculateDiff(previousSnapshot, currentSnapshot);\n\n\t\t\t// Check if diff has changes\n\t\t\tif (!hasDiffChanges(diff)) {\n\t\t\t\tlogger.info({ src: \"plugin:sql\", pluginName }, \"No actionable changes\");\n\t\t\t\treturn;\n\t\t\t}\n\n\t\t\t// Check for potential data loss\n\t\t\tconst dataLossCheck = checkForDataLoss(diff);\n\n\t\t\tif (dataLossCheck.hasDataLoss) {\n\t\t\t\tconst isProduction = process.env.NODE_ENV === \"production\";\n\n\t\t\t\t// Determine if destructive migrations are allowed\n\t\t\t\t// Priority: explicit options > environment variable\n\t\t\t\tconst allowDestructive =\n\t\t\t\t\toptions.force ||\n\t\t\t\t\toptions.allowDataLoss ||\n\t\t\t\t\tprocess.env.ELIZA_ALLOW_DESTRUCTIVE_MIGRATIONS === \"true\";\n\n\t\t\t\tif (!allowDestructive) {\n\t\t\t\t\t// Block the migration and provide clear instructions\n\t\t\t\t\tlogger.error(\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tsrc: \"plugin:sql\",\n\t\t\t\t\t\t\tpluginName,\n\t\t\t\t\t\t\tenvironment: isProduction ? \"PRODUCTION\" : \"DEVELOPMENT\",\n\t\t\t\t\t\t\twarnings: dataLossCheck.warnings,\n\t\t\t\t\t\t},\n\t\t\t\t\t\t\"Destructive migration blocked - set ELIZA_ALLOW_DESTRUCTIVE_MIGRATIONS=true or use force option\",\n\t\t\t\t\t);\n\n\t\t\t\t\tconst errorMessage = isProduction\n\t\t\t\t\t\t? `Destructive migration blocked in production for ${pluginName}. Set ELIZA_ALLOW_DESTRUCTIVE_MIGRATIONS=true or use drizzle-kit.`\n\t\t\t\t\t\t: `Destructive migration blocked for ${pluginName}. Set ELIZA_ALLOW_DESTRUCTIVE_MIGRATIONS=true to proceed.`;\n\n\t\t\t\t\tthrow new Error(errorMessage);\n\t\t\t\t}\n\n\t\t\t\t// Log that we're proceeding with destructive operations\n\t\t\t\tif (dataLossCheck.requiresConfirmation) {\n\t\t\t\t\tlogger.warn(\n\t\t\t\t\t\t{ src: \"plugin:sql\", pluginName, warnings: dataLossCheck.warnings },\n\t\t\t\t\t\t\"Proceeding with destructive migration\",\n\t\t\t\t\t);\n\t\t\t\t}\n\t\t\t}\n\n\t\t\t// Generate SQL statements\n\t\t\tconst sqlStatements = await generateMigrationSQL(\n\t\t\t\tpreviousSnapshot,\n\t\t\t\tcurrentSnapshot,\n\t\t\t\tdiff,\n\t\t\t);\n\n\t\t\tif (sqlStatements.length === 0) {\n\t\t\t\tlogger.info(\n\t\t\t\t\t{ src: \"plugin:sql\", pluginName },\n\t\t\t\t\t\"No SQL statements to execute\",\n\t\t\t\t);\n\t\t\t\treturn;\n\t\t\t}\n\n\t\t\t// Log what we're about to do\n\t\t\tlogger.info(\n\t\t\t\t{ src: \"plugin:sql\", pluginName, statementCount: sqlStatements.length },\n\t\t\t\t\"Executing SQL statements\",\n\t\t\t);\n\t\t\tif (options.verbose) {\n\t\t\t\tsqlStatements.forEach((stmt, i) => {\n\t\t\t\t\tlogger.debug(\n\t\t\t\t\t\t{ src: \"plugin:sql\", statementIndex: i + 1, statement: stmt },\n\t\t\t\t\t\t\"SQL statement\",\n\t\t\t\t\t);\n\t\t\t\t});\n\t\t\t}\n\n\t\t\t// Dry run mode - just log what would happen\n\t\t\tif (options.dryRun) {\n\t\t\t\tlogger.info(\n\t\t\t\t\t{ src: \"plugin:sql\", pluginName, statements: sqlStatements },\n\t\t\t\t\t\"DRY RUN mode - not executing statements\",\n\t\t\t\t);\n\t\t\t\treturn;\n\t\t\t}\n\n\t\t\t// Execute migration in transaction\n\t\t\tawait this.executeMigration(\n\t\t\t\tpluginName,\n\t\t\t\tcurrentSnapshot,\n\t\t\t\tcurrentHash,\n\t\t\t\tsqlStatements,\n\t\t\t);\n\n\t\t\tlogger.info(\n\t\t\t\t{ src: \"plugin:sql\", pluginName },\n\t\t\t\t\"Migration completed successfully\",\n\t\t\t);\n\n\t\t\t// Return a success result\n\t\t\treturn;\n\t\t} catch (error) {\n\t\t\tlogger.error(\n\t\t\t\t{\n\t\t\t\t\tsrc: \"plugin:sql\",\n\t\t\t\t\tpluginName,\n\t\t\t\t\terror: error instanceof Error ? error.message : String(error),\n\t\t\t\t},\n\t\t\t\t\"Migration failed\",\n\t\t\t);\n\t\t\tthrow error;\n\t\t} finally {\n\t\t\t// Always release the advisory lock if we acquired it (only for real PostgreSQL)\n\t\t\tconst postgresUrl =\n\t\t\t\tprocess.env.POSTGRES_URL || process.env.DATABASE_URL || \"\";\n\t\t\tconst isRealPostgres = this.isRealPostgresDatabase(postgresUrl);\n\n\t\t\tif (lockAcquired && isRealPostgres) {\n\t\t\t\ttry {\n\t\t\t\t\t// Convert bigint to string for SQL query (same as when acquiring)\n\t\t\t\t\tconst lockIdStr = lockId.toString();\n\t\t\t\t\tawait this.db.execute(\n\t\t\t\t\t\tsql`SELECT pg_advisory_unlock(CAST(${lockIdStr} AS bigint))`,\n\t\t\t\t\t);\n\t\t\t\t\tlogger.debug(\n\t\t\t\t\t\t{ src: \"plugin:sql\", pluginName },\n\t\t\t\t\t\t\"Advisory lock released\",\n\t\t\t\t\t);\n\t\t\t\t} catch (unlockError) {\n\t\t\t\t\tlogger.warn(\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tsrc: \"plugin:sql\",\n\t\t\t\t\t\t\tpluginName,\n\t\t\t\t\t\t\terror:\n\t\t\t\t\t\t\t\tunlockError instanceof Error\n\t\t\t\t\t\t\t\t\t? unlockError.message\n\t\t\t\t\t\t\t\t\t: String(unlockError),\n\t\t\t\t\t\t},\n\t\t\t\t\t\t\"Failed to release advisory lock\",\n\t\t\t\t\t);\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n\n\t/**\n\t * Execute migration in a transaction\n\t */\n\tprivate async executeMigration(\n\t\tpluginName: string,\n\t\tsnapshot: SchemaSnapshot,\n\t\thash: string,\n\t\tsqlStatements: string[],\n\t): Promise<void> {\n\t\tlet transactionStarted = false;\n\n\t\ttry {\n\t\t\t// Start manual transaction\n\t\t\tawait this.db.execute(sql`BEGIN`);\n\t\t\ttransactionStarted = true;\n\n\t\t\t// Execute all SQL statements\n\t\t\tfor (const stmt of sqlStatements) {\n\t\t\t\tlogger.debug(\n\t\t\t\t\t{ src: \"plugin:sql\", statement: stmt },\n\t\t\t\t\t\"Executing SQL statement\",\n\t\t\t\t);\n\t\t\t\tawait this.db.execute(sql.raw(stmt));\n\t\t\t}\n\n\t\t\t// Get next index for journal\n\t\t\tconst idx = await this.journalStorage.getNextIdx(pluginName);\n\n\t\t\t// Record migration\n\t\t\tawait this.migrationTracker.recordMigration(pluginName, hash, Date.now());\n\n\t\t\t// Update journal\n\t\t\tconst tag = this.generateMigrationTag(idx, pluginName);\n\t\t\tawait this.journalStorage.updateJournal(\n\t\t\t\tpluginName,\n\t\t\t\tidx,\n\t\t\t\ttag,\n\t\t\t\ttrue, // breakpoints\n\t\t\t);\n\n\t\t\t// Store snapshot\n\t\t\tawait this.snapshotStorage.saveSnapshot(pluginName, idx, snapshot);\n\n\t\t\t// Commit the transaction\n\t\t\tawait this.db.execute(sql`COMMIT`);\n\n\t\t\tlogger.info({ src: \"plugin:sql\", pluginName, tag }, \"Recorded migration\");\n\t\t} catch (error) {\n\t\t\t// Rollback on error if transaction was started\n\t\t\tif (transactionStarted) {\n\t\t\t\ttry {\n\t\t\t\t\tawait this.db.execute(sql`ROLLBACK`);\n\t\t\t\t\tlogger.error(\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tsrc: \"plugin:sql\",\n\t\t\t\t\t\t\terror: error instanceof Error ? error.message : String(error),\n\t\t\t\t\t\t},\n\t\t\t\t\t\t\"Migration failed, rolled back\",\n\t\t\t\t\t);\n\t\t\t\t} catch (rollbackError) {\n\t\t\t\t\tlogger.error(\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tsrc: \"plugin:sql\",\n\t\t\t\t\t\t\terror:\n\t\t\t\t\t\t\t\trollbackError instanceof Error\n\t\t\t\t\t\t\t\t\t? rollbackError.message\n\t\t\t\t\t\t\t\t\t: String(rollbackError),\n\t\t\t\t\t\t},\n\t\t\t\t\t\t\"Failed to rollback transaction\",\n\t\t\t\t\t);\n\t\t\t\t}\n\t\t\t}\n\t\t\tthrow error;\n\t\t}\n\t}\n\n\t/**\n\t * Generate migration tag (like 0000_jazzy_shard)\n\t */\n\tprivate generateMigrationTag(idx: number, pluginName: string): string {\n\t\t// Generate a simple tag - in production, use Drizzle's word generation\n\t\tconst prefix = idx.toString().padStart(4, \"0\");\n\t\tconst timestamp = Date.now().toString(36);\n\t\treturn `${prefix}_${pluginName}_${timestamp}`;\n\t}\n\n\t/**\n\t * Get migration status for a plugin\n\t * @param pluginName - Plugin identifier\n\t * @returns Migration history and current state\n\t */\n\tasync getStatus(pluginName: string): Promise<{\n\t\thasRun: boolean;\n\t\tlastMigration: { id: number; hash: string; created_at: string } | null;\n\t\tjournal: { version: string; dialect: string; entries: unknown[] } | null;\n\t\tsnapshots: number;\n\t}> {\n\t\tconst lastMigration =\n\t\t\tawait this.migrationTracker.getLastMigration(pluginName);\n\t\tconst journal = await this.journalStorage.loadJournal(pluginName);\n\t\tconst snapshots = await this.snapshotStorage.getAllSnapshots(pluginName);\n\n\t\treturn {\n\t\t\thasRun: !!lastMigration,\n\t\t\tlastMigration,\n\t\t\tjournal,\n\t\t\tsnapshots: snapshots.length,\n\t\t};\n\t}\n\n\t/**\n\t * Reset migrations for a plugin (dangerous - for development only)\n\t * @param pluginName - Plugin identifier\n\t * @warning Deletes all migration history - use only in development\n\t */\n\tasync reset(pluginName: string): Promise<void> {\n\t\tlogger.warn({ src: \"plugin:sql\", pluginName }, \"Resetting migrations\");\n\n\t\tawait this.db.execute(\n\t\t\tsql`DELETE FROM migrations._migrations WHERE plugin_name = ${pluginName}`,\n\t\t);\n\t\tawait this.db.execute(\n\t\t\tsql`DELETE FROM migrations._journal WHERE plugin_name = ${pluginName}`,\n\t\t);\n\t\tawait this.db.execute(\n\t\t\tsql`DELETE FROM migrations._snapshots WHERE plugin_name = ${pluginName}`,\n\t\t);\n\n\t\tlogger.warn({ src: \"plugin:sql\", pluginName }, \"Reset complete\");\n\t}\n\n\t/**\n\t * Check if a migration would cause data loss without executing it\n\t * @param pluginName - Plugin identifier\n\t * @param schema - Drizzle schema to check\n\t * @returns Data loss analysis or null if no changes\n\t */\n\tasync checkMigration(\n\t\tpluginName: string,\n\t\tschema: Record<string, unknown>,\n\t): Promise<DataLossCheck | null> {\n\t\ttry {\n\t\t\tlogger.info({ src: \"plugin:sql\", pluginName }, \"Checking migration\");\n\n\t\t\t// Generate current snapshot from schema\n\t\t\tconst currentSnapshot = await generateSnapshot(schema);\n\n\t\t\t// Load previous snapshot\n\t\t\tconst previousSnapshot =\n\t\t\t\tawait this.snapshotStorage.getLatestSnapshot(pluginName);\n\n\t\t\t// Check if there are changes\n\t\t\tif (!hasChanges(previousSnapshot, currentSnapshot)) {\n\t\t\t\tlogger.info({ src: \"plugin:sql\", pluginName }, \"No changes detected\");\n\t\t\t\treturn null;\n\t\t\t}\n\n\t\t\t// Calculate diff\n\t\t\tconst diff = await calculateDiff(previousSnapshot, currentSnapshot);\n\n\t\t\t// Check for data loss\n\t\t\tconst dataLossCheck = checkForDataLoss(diff);\n\n\t\t\tif (dataLossCheck.hasDataLoss) {\n\t\t\t\tlogger.warn(\n\t\t\t\t\t{ src: \"plugin:sql\", pluginName },\n\t\t\t\t\t\"Migration would cause data loss\",\n\t\t\t\t);\n\t\t\t} else {\n\t\t\t\tlogger.info(\n\t\t\t\t\t{ src: \"plugin:sql\", pluginName },\n\t\t\t\t\t\"Migration is safe (no data loss)\",\n\t\t\t\t);\n\t\t\t}\n\n\t\t\treturn dataLossCheck;\n\t\t} catch (error) {\n\t\t\tlogger.error(\n\t\t\t\t{\n\t\t\t\t\tsrc: \"plugin:sql\",\n\t\t\t\t\tpluginName,\n\t\t\t\t\terror: error instanceof Error ? error.message : String(error),\n\t\t\t\t},\n\t\t\t\t\"Failed to check migration\",\n\t\t\t);\n\t\t\tthrow error;\n\t\t}\n\t}\n}\n",
116
+ "export {\n\tcalculateDiff,\n\thasDiffChanges,\n\ttype SchemaDiff,\n} from \"./drizzle-adapters/diff-calculator\";\n// Drizzle adapter exports (if needed for extensions)\nexport {\n\tcreateEmptySnapshot,\n\tgenerateSnapshot,\n\thasChanges,\n\thashSnapshot,\n} from \"./drizzle-adapters/snapshot-generator\";\nexport {\n\tgenerateMigrationSQL,\n\tgenerateRenameColumnSQL,\n\tgenerateRenameTableSQL,\n} from \"./drizzle-adapters/sql-generator\";\nexport { RuntimeMigrator } from \"./runtime-migrator\";\nexport { JournalStorage } from \"./storage/journal-storage\";\n// Storage exports (if needed for advanced usage)\nexport { MigrationTracker } from \"./storage/migration-tracker\";\nexport { SnapshotStorage } from \"./storage/snapshot-storage\";\nexport * from \"./types\";\n",
117
+ "import { type IDatabaseAdapter, logger, type Plugin } from \"@elizaos/core\";\nimport { migrateToEntityRLS } from \"./migrations\";\nimport {\n\tapplyEntityRLSToAllTables,\n\tapplyRLSToNewTables,\n\tinstallRLSFunctions,\n} from \"./rls\";\nimport { RuntimeMigrator } from \"./runtime-migrator\";\nimport type { DrizzleDatabase } from \"./types\";\n\nexport class DatabaseMigrationService {\n\tprivate db: DrizzleDatabase | null = null;\n\tprivate registeredSchemas = new Map<string, Record<string, unknown>>();\n\tprivate migrator: RuntimeMigrator | null = null;\n\n\tasync initializeWithDatabase(db: DrizzleDatabase): Promise<void> {\n\t\tthis.db = db;\n\n\t\tinterface AdapterWrapper extends IDatabaseAdapter {\n\t\t\tdb: DrizzleDatabase;\n\t\t}\n\t\tconst adapterWrapper: AdapterWrapper = { db } as AdapterWrapper;\n\t\tawait migrateToEntityRLS(adapterWrapper);\n\n\t\tthis.migrator = new RuntimeMigrator(db);\n\t\tawait this.migrator.initialize();\n\t\tlogger.info({ src: \"plugin:sql\" }, \"DatabaseMigrationService initialized\");\n\t}\n\n\tdiscoverAndRegisterPluginSchemas(plugins: Plugin[]): void {\n\t\tfor (const plugin of plugins) {\n\t\t\ttype PluginWithSchema = Plugin & {\n\t\t\t\tschema?: Record<string, unknown>;\n\t\t\t};\n\t\t\tconst pluginWithSchema = plugin as PluginWithSchema;\n\t\t\tif (pluginWithSchema.schema) {\n\t\t\t\tthis.registeredSchemas.set(plugin.name, pluginWithSchema.schema);\n\t\t\t}\n\t\t}\n\t\tlogger.info(\n\t\t\t{\n\t\t\t\tsrc: \"plugin:sql\",\n\t\t\t\tschemasDiscovered: this.registeredSchemas.size,\n\t\t\t\ttotalPlugins: plugins.length,\n\t\t\t},\n\t\t\t\"Plugin schemas discovered\",\n\t\t);\n\t}\n\n\tregisterSchema(pluginName: string, schema: Record<string, unknown>): void {\n\t\tthis.registeredSchemas.set(pluginName, schema);\n\t\tlogger.debug({ src: \"plugin:sql\", pluginName }, \"Schema registered\");\n\t}\n\n\tasync runAllPluginMigrations(options?: {\n\t\tverbose?: boolean;\n\t\tforce?: boolean;\n\t\tdryRun?: boolean;\n\t}): Promise<void> {\n\t\tif (!this.db || !this.migrator) {\n\t\t\tthrow new Error(\n\t\t\t\t\"Database or migrator not initialized in DatabaseMigrationService\",\n\t\t\t);\n\t\t}\n\n\t\tconst isProduction = process.env.NODE_ENV === \"production\";\n\n\t\tconst migrationOptions = {\n\t\t\tverbose: options?.verbose ?? !isProduction,\n\t\t\tforce: options?.force ?? false,\n\t\t\tdryRun: options?.dryRun ?? false,\n\t\t};\n\n\t\tlogger.info(\n\t\t\t{\n\t\t\t\tsrc: \"plugin:sql\",\n\t\t\t\tenvironment: isProduction ? \"PRODUCTION\" : \"DEVELOPMENT\",\n\t\t\t\tpluginCount: this.registeredSchemas.size,\n\t\t\t\tdryRun: migrationOptions.dryRun,\n\t\t\t},\n\t\t\t\"Starting migrations\",\n\t\t);\n\n\t\tlet successCount = 0;\n\t\tlet failureCount = 0;\n\t\tconst errors: Array<{ pluginName: string; error: Error }> = [];\n\n\t\tfor (const [pluginName, schema] of this.registeredSchemas) {\n\t\t\ttry {\n\t\t\t\tawait this.migrator.migrate(pluginName, schema, migrationOptions);\n\t\t\t\tsuccessCount++;\n\t\t\t\tlogger.info({ src: \"plugin:sql\", pluginName }, \"Migration completed\");\n\t\t\t} catch (error) {\n\t\t\t\tfailureCount++;\n\t\t\t\tconst errorMessage = (error as Error).message;\n\n\t\t\t\terrors.push({ pluginName, error: error as Error });\n\n\t\t\t\tif (errorMessage.includes(\"Destructive migration blocked\")) {\n\t\t\t\t\tlogger.error(\n\t\t\t\t\t\t{ src: \"plugin:sql\", pluginName },\n\t\t\t\t\t\t\"Migration blocked - destructive changes detected. Set ELIZA_ALLOW_DESTRUCTIVE_MIGRATIONS=true or use force option\",\n\t\t\t\t\t);\n\t\t\t\t} else {\n\t\t\t\t\tlogger.error(\n\t\t\t\t\t\t{ src: \"plugin:sql\", pluginName, error: errorMessage },\n\t\t\t\t\t\t\"Migration failed\",\n\t\t\t\t\t);\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\tif (failureCount === 0) {\n\t\t\tlogger.info(\n\t\t\t\t{ src: \"plugin:sql\", successCount },\n\t\t\t\t\"All migrations completed successfully\",\n\t\t\t);\n\n\t\t\tconst dataIsolationEnabled = process.env.ENABLE_DATA_ISOLATION === \"true\";\n\n\t\t\tif (dataIsolationEnabled) {\n\t\t\t\ttry {\n\t\t\t\t\tlogger.info(\n\t\t\t\t\t\t{ src: \"plugin:sql\" },\n\t\t\t\t\t\t\"Re-applying Row Level Security...\",\n\t\t\t\t\t);\n\t\t\t\t\tinterface AdapterWrapper extends IDatabaseAdapter {\n\t\t\t\t\t\tdb: DrizzleDatabase;\n\t\t\t\t\t}\n\t\t\t\t\tconst adapterWrapper: AdapterWrapper = {\n\t\t\t\t\t\tdb: this.db,\n\t\t\t\t\t} as AdapterWrapper;\n\t\t\t\t\tawait installRLSFunctions(adapterWrapper);\n\t\t\t\t\tawait applyRLSToNewTables(adapterWrapper);\n\t\t\t\t\tawait applyEntityRLSToAllTables(adapterWrapper);\n\t\t\t\t\tlogger.info({ src: \"plugin:sql\" }, \"RLS re-applied successfully\");\n\t\t\t\t} catch (rlsError) {\n\t\t\t\t\tconst errorMsg =\n\t\t\t\t\t\trlsError instanceof Error ? rlsError.message : String(rlsError);\n\t\t\t\t\tlogger.warn(\n\t\t\t\t\t\t{ src: \"plugin:sql\", error: errorMsg },\n\t\t\t\t\t\t\"Failed to re-apply RLS (this is OK if server_id columns are not yet in schemas)\",\n\t\t\t\t\t);\n\t\t\t\t}\n\t\t\t} else {\n\t\t\t\tlogger.info(\n\t\t\t\t\t{ src: \"plugin:sql\" },\n\t\t\t\t\t\"Skipping RLS re-application (ENABLE_DATA_ISOLATION is not true)\",\n\t\t\t\t);\n\t\t\t}\n\t\t} else {\n\t\t\tlogger.error(\n\t\t\t\t{ src: \"plugin:sql\", failureCount, successCount },\n\t\t\t\t\"Some migrations failed\",\n\t\t\t);\n\n\t\t\tconst errorSummary = errors\n\t\t\t\t.map((e) => `${e.pluginName}: ${e.error.message}`)\n\t\t\t\t.join(\"\\n \");\n\t\t\tthrow new Error(\n\t\t\t\t`${failureCount} migration(s) failed:\\n ${errorSummary}`,\n\t\t\t);\n\t\t}\n\t}\n\n\tgetMigrator(): RuntimeMigrator | null {\n\t\treturn this.migrator;\n\t}\n}\n",
118
+ "import { mkdirSync } from \"node:fs\";\nimport type { IDatabaseAdapter, UUID } from \"@elizaos/core\";\nimport {\n\ttype IAgentRuntime,\n\tlogger,\n\ttype Plugin,\n\tstringToUuid,\n} from \"@elizaos/core\";\nimport { PgDatabaseAdapter } from \"./pg/adapter\";\nimport { PostgresConnectionManager } from \"./pg/manager\";\nimport { PgliteDatabaseAdapter } from \"./pglite/adapter\";\nimport { PGliteClientManager } from \"./pglite/manager\";\nimport * as schema from \"./schema\";\nimport { resolvePgliteDir } from \"./utils.node\";\n\nconst GLOBAL_SINGLETONS = Symbol.for(\"@elizaos/plugin-sql/global-singletons\");\n\ninterface GlobalSingletons {\n\tpgLiteClientManager?: PGliteClientManager;\n\tpostgresConnectionManagers?: Map<string, PostgresConnectionManager>;\n}\n\nconst globalSymbols = globalThis as typeof globalThis &\n\tRecord<symbol, GlobalSingletons>;\nif (!globalSymbols[GLOBAL_SINGLETONS]) {\n\tglobalSymbols[GLOBAL_SINGLETONS] = {};\n}\nconst globalSingletons = globalSymbols[GLOBAL_SINGLETONS];\n\nfunction shouldReusePgliteManager(\n\tmanager: PGliteClientManager | undefined,\n): boolean {\n\tif (!manager) {\n\t\treturn false;\n\t}\n\n\treturn !manager.isShuttingDown();\n}\n\nexport function createDatabaseAdapter(\n\tconfig: {\n\t\tdataDir?: string;\n\t\tpostgresUrl?: string;\n\t},\n\tagentId: UUID,\n): IDatabaseAdapter {\n\tif (config.postgresUrl) {\n\t\tconst dataIsolationEnabled = process.env.ENABLE_DATA_ISOLATION === \"true\";\n\t\tlet rlsServerId: string | undefined;\n\t\tlet managerKey = \"default\";\n\n\t\tif (dataIsolationEnabled) {\n\t\t\tconst rlsServerIdString = process.env.ELIZA_SERVER_ID;\n\t\t\tif (!rlsServerIdString) {\n\t\t\t\tthrow new Error(\n\t\t\t\t\t\"[Data Isolation] ENABLE_DATA_ISOLATION=true requires ELIZA_SERVER_ID environment variable\",\n\t\t\t\t);\n\t\t\t}\n\t\t\trlsServerId = stringToUuid(rlsServerIdString);\n\t\t\tmanagerKey = rlsServerId;\n\t\t\tlogger.debug(\n\t\t\t\t{\n\t\t\t\t\tsrc: \"plugin:sql\",\n\t\t\t\t\trlsServerId: rlsServerId.slice(0, 8),\n\t\t\t\t\tserverIdString: rlsServerIdString,\n\t\t\t\t},\n\t\t\t\t\"Using connection pool for RLS server\",\n\t\t\t);\n\t\t}\n\n\t\t// Initialize connection managers map if needed\n\t\tif (!globalSingletons.postgresConnectionManagers) {\n\t\t\tglobalSingletons.postgresConnectionManagers = new Map();\n\t\t}\n\n\t\t// Get or create connection manager for this server_id\n\t\tlet manager = globalSingletons.postgresConnectionManagers.get(managerKey);\n\t\tif (!manager) {\n\t\t\tlogger.debug(\n\t\t\t\t{ src: \"plugin:sql\", managerKey: managerKey.slice(0, 8) },\n\t\t\t\t\"Creating new connection pool\",\n\t\t\t);\n\t\t\tmanager = new PostgresConnectionManager(config.postgresUrl, rlsServerId);\n\t\t\tglobalSingletons.postgresConnectionManagers.set(managerKey, manager);\n\t\t}\n\n\t\treturn new PgDatabaseAdapter(agentId, manager);\n\t}\n\n\tconst dataDir = resolvePgliteDir(config.dataDir);\n\n\tif (dataDir && !dataDir.includes(\"://\")) {\n\t\tmkdirSync(dataDir, { recursive: true });\n\t}\n\n\tif (!shouldReusePgliteManager(globalSingletons.pgLiteClientManager)) {\n\t\tglobalSingletons.pgLiteClientManager = new PGliteClientManager({ dataDir });\n\t}\n\treturn new PgliteDatabaseAdapter(\n\t\tagentId,\n\t\tglobalSingletons.pgLiteClientManager,\n\t);\n}\n\nexport const plugin: Plugin = {\n\tname: \"@elizaos/plugin-sql\",\n\tdescription:\n\t\t\"A plugin for SQL database access with dynamic schema migrations\",\n\tpriority: 0,\n\tschema: schema,\n\tinit: async (_config, runtime: IAgentRuntime) => {\n\t\truntime.logger.info(\n\t\t\t{ src: \"plugin:sql\", agentId: runtime.agentId },\n\t\t\t\"plugin-sql (node) init starting\",\n\t\t);\n\n\t\tconst adapterRegistered = await runtime\n\t\t\t.isReady()\n\t\t\t.then(() => true)\n\t\t\t.catch((error: unknown) => {\n\t\t\t\tconst message = error instanceof Error ? error.message : String(error);\n\t\t\t\tif (message.includes(\"Database adapter not registered\")) {\n\t\t\t\t\truntime.logger.info(\n\t\t\t\t\t\t{ src: \"plugin:sql\", agentId: runtime.agentId },\n\t\t\t\t\t\t\"No pre-registered database adapter detected; registering adapter\",\n\t\t\t\t\t);\n\t\t\t\t} else {\n\t\t\t\t\truntime.logger.warn(\n\t\t\t\t\t\t{ src: \"plugin:sql\", agentId: runtime.agentId, error: message },\n\t\t\t\t\t\t\"Database adapter readiness check error; proceeding to register adapter\",\n\t\t\t\t\t);\n\t\t\t\t}\n\t\t\t\treturn false;\n\t\t\t});\n\t\tif (adapterRegistered) {\n\t\t\truntime.logger.info(\n\t\t\t\t{ src: \"plugin:sql\", agentId: runtime.agentId },\n\t\t\t\t\"Database adapter already registered, skipping creation\",\n\t\t\t);\n\t\t\treturn;\n\t\t}\n\n\t\tconst postgresUrl = runtime.getSetting(\"POSTGRES_URL\");\n\t\tconst dataDir = runtime.getSetting(\"PGLITE_DATA_DIR\");\n\n\t\tconst dbAdapter = createDatabaseAdapter(\n\t\t\t{\n\t\t\t\tdataDir: typeof dataDir === \"string\" ? dataDir : undefined,\n\t\t\t\tpostgresUrl: typeof postgresUrl === \"string\" ? postgresUrl : undefined,\n\t\t\t},\n\t\t\truntime.agentId,\n\t\t);\n\n\t\truntime.registerDatabaseAdapter(dbAdapter);\n\t\truntime.logger.info(\n\t\t\t{ src: \"plugin:sql\", agentId: runtime.agentId },\n\t\t\t\"Database adapter created and registered\",\n\t\t);\n\t},\n};\n\nexport default plugin;\n\nexport { DatabaseMigrationService } from \"./migration-service\";\nexport {\n\tapplyRLSToNewTables,\n\tassignAgentToServer,\n\tgetOrCreateRlsServer,\n\tinstallRLSFunctions,\n\tsetServerContext,\n\tuninstallRLS,\n} from \"./rls\";\n",
119
+ "import {\n\ttype Agent,\n\ttype Component,\n\ttype Entity,\n\tlogger,\n\ttype Memory,\n\ttype UUID,\n} from \"@elizaos/core\";\nimport type { NodePgDatabase } from \"drizzle-orm/node-postgres\";\nimport { BaseDrizzleAdapter } from \"../base\";\nimport {\n\tDIMENSION_MAP,\n\ttype EmbeddingDimensionColumn,\n} from \"../schema/embedding\";\nimport type { PostgresConnectionManager } from \"./manager\";\n\nexport class PgDatabaseAdapter extends BaseDrizzleAdapter {\n\tprotected embeddingDimension: EmbeddingDimensionColumn = DIMENSION_MAP[384];\n\tprivate manager: PostgresConnectionManager;\n\n\tconstructor(\n\t\tagentId: UUID,\n\t\tmanager: PostgresConnectionManager,\n\t\t_schema?: Record<string, unknown>,\n\t) {\n\t\tsuper(agentId);\n\t\tthis.manager = manager;\n\t\tthis.db = manager.getDatabase();\n\t}\n\n\tgetManager(): PostgresConnectionManager {\n\t\treturn this.manager;\n\t}\n\n\tpublic async withEntityContext<T>(\n\t\tentityId: UUID | null,\n\t\tcallback: (tx: NodePgDatabase) => Promise<T>,\n\t): Promise<T> {\n\t\treturn await this.manager.withEntityContext(entityId, callback);\n\t}\n\n\tasync getEntityByIds(entityIds: UUID[]): Promise<Entity[] | null> {\n\t\treturn this.getEntitiesByIds(entityIds);\n\t}\n\n\tasync getMemoriesByServerId(_params: {\n\t\tserverId: UUID;\n\t\tcount?: number;\n\t}): Promise<Memory[]> {\n\t\tlogger.warn(\n\t\t\t{ src: \"plugin:sql\" },\n\t\t\t\"getMemoriesByServerId called but not implemented\",\n\t\t);\n\t\treturn [];\n\t}\n\n\tasync ensureAgentExists(agent: Partial<Agent>): Promise<Agent> {\n\t\tconst existingAgent = await this.getAgent(this.agentId);\n\t\tif (existingAgent) {\n\t\t\treturn existingAgent;\n\t\t}\n\n\t\tconst newAgent: Agent = {\n\t\t\tid: this.agentId,\n\t\t\tname: agent.name || \"Unknown Agent\",\n\t\t\tusername: agent.username,\n\t\t\tbio: (Array.isArray(agent.bio)\n\t\t\t\t? agent.bio\n\t\t\t\t: agent.bio\n\t\t\t\t\t? [agent.bio]\n\t\t\t\t\t: [\"An AI agent\"]) as string[],\n\t\t\tcreatedAt: agent.createdAt || Date.now(),\n\t\t\tupdatedAt: agent.updatedAt || Date.now(),\n\t\t};\n\n\t\tawait this.createAgent(newAgent);\n\t\tconst createdAgent = await this.getAgent(this.agentId);\n\t\tif (!createdAgent) {\n\t\t\tthrow new Error(\"Failed to create agent\");\n\t\t}\n\t\treturn createdAgent;\n\t}\n\n\tprotected async withDatabase<T>(operation: () => Promise<T>): Promise<T> {\n\t\treturn await this.withRetry(async () => {\n\t\t\treturn await operation();\n\t\t});\n\t}\n\n\tasync init(): Promise<void> {\n\t\tlogger.debug({ src: \"plugin:sql\" }, \"PgDatabaseAdapter initialized\");\n\t}\n\n\tasync isReady(): Promise<boolean> {\n\t\treturn this.manager.testConnection();\n\t}\n\n\tasync close(): Promise<void> {\n\t\tawait this.manager.close();\n\t}\n\n\tasync getConnection(): Promise<NodePgDatabase> {\n\t\treturn this.db as NodePgDatabase;\n\t}\n\n\tgetRawConnection() {\n\t\treturn this.manager.getConnection();\n\t}\n\n\tasync createAgent(agent: Agent): Promise<boolean> {\n\t\treturn super.createAgent(agent);\n\t}\n\n\tgetAgent(agentId: UUID): Promise<Agent | null> {\n\t\treturn super.getAgent(agentId);\n\t}\n\n\tupdateAgent(agentId: UUID, agent: Partial<Agent>): Promise<boolean> {\n\t\treturn super.updateAgent(agentId, agent);\n\t}\n\n\tdeleteAgent(agentId: UUID): Promise<boolean> {\n\t\treturn super.deleteAgent(agentId);\n\t}\n\n\tcreateEntities(entities: Entity[]): Promise<boolean> {\n\t\treturn super.createEntities(entities);\n\t}\n\n\tgetEntitiesByIds(entityIds: UUID[]): Promise<Entity[]> {\n\t\treturn super.getEntitiesByIds(entityIds).then((result) => result || []);\n\t}\n\n\tupdateEntity(entity: Entity): Promise<void> {\n\t\treturn super.updateEntity(entity);\n\t}\n\n\tcreateMemory(memory: Memory, tableName: string): Promise<UUID> {\n\t\treturn super.createMemory(memory, tableName);\n\t}\n\n\tgetMemoryById(memoryId: UUID): Promise<Memory | null> {\n\t\treturn super.getMemoryById(memoryId);\n\t}\n\n\tupdateMemory(memory: Partial<Memory> & { id: UUID }): Promise<boolean> {\n\t\treturn super.updateMemory(memory);\n\t}\n\n\tdeleteMemory(memoryId: UUID): Promise<void> {\n\t\treturn super.deleteMemory(memoryId);\n\t}\n\n\tcreateComponent(component: Component): Promise<boolean> {\n\t\treturn super.createComponent(component);\n\t}\n\n\tgetComponent(\n\t\tentityId: UUID,\n\t\ttype: string,\n\t\tworldId?: UUID,\n\t\tsourceEntityId?: UUID,\n\t): Promise<Component | null> {\n\t\treturn super.getComponent(entityId, type, worldId, sourceEntityId);\n\t}\n\n\tupdateComponent(component: Component): Promise<void> {\n\t\treturn super.updateComponent(component);\n\t}\n\n\tdeleteComponent(componentId: UUID): Promise<void> {\n\t\treturn super.deleteComponent(componentId);\n\t}\n}\n",
120
+ "import {\n\ttype Agent,\n\ttype AgentRunCounts,\n\ttype AgentRunSummary,\n\ttype AgentRunSummaryResult,\n\tChannelType,\n\ttype Component,\n\tDatabaseAdapter,\n\ttype Entity,\n\ttype Log,\n\ttype LogBody,\n\tlogger,\n\ttype Memory,\n\ttype MemoryMetadata,\n\ttype Metadata,\n\ttype PairingAllowlistEntry,\n\ttype PairingChannel,\n\ttype PairingRequest,\n\ttype Participant,\n\ttype Relationship,\n\ttype Room,\n\ttype RunStatus,\n\ttype Task,\n\ttype TaskMetadata,\n\ttype UUID,\n\ttype World,\n} from \"@elizaos/core\";\n\n// JSON-serializable value type for metadata\ntype JsonValue =\n\t| string\n\t| number\n\t| boolean\n\t| null\n\t| JsonValue[]\n\t| { [key: string]: JsonValue };\n\nimport {\n\tand,\n\tcosineDistance,\n\tcount,\n\tdesc,\n\teq,\n\tgte,\n\tinArray,\n\tlt,\n\tlte,\n\tor,\n\ttype SQL,\n\tsql,\n} from \"drizzle-orm\";\nimport { v4 } from \"uuid\";\nimport type { DatabaseMigrationService } from \"./migration-service\";\nimport {\n\tDIMENSION_MAP,\n\ttype EmbeddingDimensionColumn,\n} from \"./schema/embedding\";\nimport {\n\tagentTable,\n\tcacheTable,\n\tchannelParticipantsTable,\n\tchannelTable,\n\tcomponentTable,\n\tembeddingTable,\n\tentityTable,\n\tlogTable,\n\tmemoryTable,\n\tmessageServerAgentsTable,\n\tmessageServerTable,\n\tmessageTable,\n\tpairingAllowlistTable,\n\tpairingRequestTable,\n\tparticipantTable,\n\trelationshipTable,\n\troomTable,\n\ttaskTable,\n\tworldTable,\n} from \"./schema/index\";\nimport type { DrizzleDatabase } from \"./types\";\n\nexport abstract class BaseDrizzleAdapter extends DatabaseAdapter<DrizzleDatabase> {\n\tprotected readonly maxRetries: number = 3;\n\tprotected readonly baseDelay: number = 1000;\n\tprotected readonly maxDelay: number = 10000;\n\tprotected readonly jitterMax: number = 1000;\n\tprotected embeddingDimension: EmbeddingDimensionColumn = DIMENSION_MAP[384];\n\tprotected migrationService?: DatabaseMigrationService;\n\n\tprotected abstract withDatabase<T>(operation: () => Promise<T>): Promise<T>;\n\n\tpublic abstract withEntityContext<T>(\n\t\tentityId: UUID | null,\n\t\tcallback: (tx: DrizzleDatabase) => Promise<T>,\n\t): Promise<T>;\n\n\tpublic abstract init(): Promise<void>;\n\tpublic abstract close(): Promise<void>;\n\n\tpublic async initialize(): Promise<void> {\n\t\tawait this.init();\n\t}\n\n\tpublic async runPluginMigrations(\n\t\tplugins: Array<{ name: string; schema?: Record<string, unknown> }>,\n\t\toptions?: {\n\t\t\tverbose?: boolean;\n\t\t\tforce?: boolean;\n\t\t\tdryRun?: boolean;\n\t\t},\n\t): Promise<void> {\n\t\tif (!this.migrationService) {\n\t\t\tconst { DatabaseMigrationService } = await import(\"./migration-service\");\n\t\t\tthis.migrationService = new DatabaseMigrationService();\n\t\t\tawait this.migrationService.initializeWithDatabase(\n\t\t\t\tthis.db as DrizzleDatabase,\n\t\t\t);\n\t\t}\n\n\t\tfor (const plugin of plugins) {\n\t\t\tif (plugin.schema) {\n\t\t\t\tthis.migrationService.registerSchema(plugin.name, plugin.schema);\n\t\t\t}\n\t\t}\n\n\t\tawait this.migrationService.runAllPluginMigrations(options);\n\t}\n\n\tpublic getDatabase(): unknown {\n\t\treturn this.db;\n\t}\n\n\tprotected agentId: UUID;\n\n\tconstructor(agentId: UUID) {\n\t\tsuper();\n\t\tthis.agentId = agentId;\n\t}\n\n\tprivate normalizeEntityNames(names: unknown): string[] {\n\t\tif (names == null) {\n\t\t\treturn [];\n\t\t}\n\n\t\tif (typeof names === \"string\") {\n\t\t\treturn [names];\n\t\t}\n\n\t\tif (Array.isArray(names)) {\n\t\t\treturn names.map(String);\n\t\t}\n\n\t\tif (names instanceof Set) {\n\t\t\treturn Array.from(names).map(String);\n\t\t}\n\n\t\tif (\n\t\t\ttypeof names === \"object\" &&\n\t\t\ttypeof names[Symbol.iterator] === \"function\"\n\t\t) {\n\t\t\treturn Array.from(names as Iterable<unknown>).map(String);\n\t\t}\n\n\t\treturn [String(names)];\n\t}\n\n\t/**\n\t * Executes the given operation with retry logic.\n\t * @template T\n\t * @param {() => Promise<T>} operation - The operation to be executed.\n\t * @returns {Promise<T>} A promise that resolves with the result of the operation.\n\t */\n\tprotected async withRetry<T>(operation: () => Promise<T>): Promise<T> {\n\t\tlet lastError: Error = new Error(\"Unknown error\");\n\n\t\tfor (let attempt = 1; attempt <= this.maxRetries; attempt++) {\n\t\t\ttry {\n\t\t\t\treturn await operation();\n\t\t\t} catch (error) {\n\t\t\t\tlastError = error as Error;\n\n\t\t\t\tif (attempt < this.maxRetries) {\n\t\t\t\t\tconst backoffDelay = Math.min(\n\t\t\t\t\t\tthis.baseDelay * 2 ** (attempt - 1),\n\t\t\t\t\t\tthis.maxDelay,\n\t\t\t\t\t);\n\n\t\t\t\t\tconst jitter = Math.random() * this.jitterMax;\n\t\t\t\t\tconst delay = backoffDelay + jitter;\n\n\t\t\t\t\tlogger.warn(\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tsrc: \"plugin:sql\",\n\t\t\t\t\t\t\tattempt,\n\t\t\t\t\t\t\tmaxRetries: this.maxRetries,\n\t\t\t\t\t\t\terror: error instanceof Error ? error.message : String(error),\n\t\t\t\t\t\t},\n\t\t\t\t\t\t\"Database operation failed, retrying\",\n\t\t\t\t\t);\n\n\t\t\t\t\tawait new Promise((resolve) => setTimeout(resolve, delay));\n\t\t\t\t} else {\n\t\t\t\t\tlogger.error(\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tsrc: \"plugin:sql\",\n\t\t\t\t\t\t\ttotalAttempts: attempt,\n\t\t\t\t\t\t\terror: error instanceof Error ? error.message : String(error),\n\t\t\t\t\t\t},\n\t\t\t\t\t\t\"Max retry attempts reached\",\n\t\t\t\t\t);\n\t\t\t\t\tthrow error instanceof Error ? error : new Error(String(error));\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\tthrow lastError;\n\t}\n\n\t/**\n\t * Asynchronously ensures that the given embedding dimension is valid for the agent.\n\t *\n\t * @param {number} dimension - The dimension to ensure for the embedding.\n\t * @returns {Promise<void>} - Resolves once the embedding dimension is ensured.\n\t */\n\tasync ensureEmbeddingDimension(dimension: number) {\n\t\treturn this.withDatabase(async () => {\n\t\t\tconst existingMemory = await this.db\n\t\t\t\t.select()\n\t\t\t\t.from(memoryTable)\n\t\t\t\t.innerJoin(embeddingTable, eq(embeddingTable.memoryId, memoryTable.id))\n\t\t\t\t.where(eq(memoryTable.agentId, this.agentId))\n\t\t\t\t.limit(1);\n\n\t\t\tif (existingMemory.length > 0) {\n\t\t\t\t// The join result includes both memoryTable and embeddingTable columns\n\t\t\t\t// Access embedding columns directly from the joined result\n\t\t\t\tinterface JoinedMemoryResult {\n\t\t\t\t\tmemories: typeof memoryTable.$inferSelect;\n\t\t\t\t\tembeddings: typeof embeddingTable.$inferSelect;\n\t\t\t\t}\n\t\t\t\tconst joinedResult = existingMemory[0] as JoinedMemoryResult;\n\t\t\t\tObject.entries(DIMENSION_MAP).find(([_, colName]) => {\n\t\t\t\t\tconst embeddingCol =\n\t\t\t\t\t\tcolName as keyof typeof embeddingTable.$inferSelect;\n\t\t\t\t\treturn joinedResult.embeddings[embeddingCol] !== null;\n\t\t\t\t});\n\t\t\t\t// We don't actually need to use usedDimension for now, but it's good to know it's there.\n\t\t\t}\n\n\t\t\tthis.embeddingDimension =\n\t\t\t\tDIMENSION_MAP[dimension as keyof typeof DIMENSION_MAP];\n\t\t});\n\t}\n\n\t/**\n\t * Asynchronously retrieves an agent by their ID from the database.\n\t * @param {UUID} agentId - The ID of the agent to retrieve.\n\t * @returns {Promise<Agent | null>} A promise that resolves to the retrieved agent or null if not found.\n\t */\n\tasync getAgent(agentId: UUID): Promise<Agent | null> {\n\t\treturn this.withDatabase(async () => {\n\t\t\tconst rows = await this.db\n\t\t\t\t.select()\n\t\t\t\t.from(agentTable)\n\t\t\t\t.where(eq(agentTable.id, agentId))\n\t\t\t\t.limit(1);\n\n\t\t\tif (rows.length === 0) return null;\n\n\t\t\tconst row = rows[0];\n\t\t\tconst bioValue = !row.bio\n\t\t\t\t? \"\"\n\t\t\t\t: Array.isArray(row.bio)\n\t\t\t\t\t? row.bio\n\t\t\t\t\t: row.bio;\n\t\t\treturn {\n\t\t\t\t...row,\n\t\t\t\tusername: row.username || \"\",\n\t\t\t\tid: row.id as UUID,\n\t\t\t\tsystem: !row.system ? undefined : row.system,\n\t\t\t\tbio: bioValue as string | string[],\n\t\t\t\tcreatedAt: row.createdAt.getTime(),\n\t\t\t\tupdatedAt: row.updatedAt.getTime(),\n\t\t\t} as unknown as Agent;\n\t\t});\n\t}\n\n\t/**\n\t * Asynchronously retrieves a list of agents from the database.\n\t *\n\t * @returns {Promise<Partial<Agent>[]>} A Promise that resolves to an array of Agent objects.\n\t */\n\tasync getAgents(): Promise<Partial<Agent>[]> {\n\t\tconst result = await this.withDatabase(async () => {\n\t\t\tconst rows = await this.db\n\t\t\t\t.select({\n\t\t\t\t\tid: agentTable.id,\n\t\t\t\t\tname: agentTable.name,\n\t\t\t\t\tbio: agentTable.bio,\n\t\t\t\t})\n\t\t\t\t.from(agentTable);\n\t\t\treturn rows.map(\n\t\t\t\t(row) =>\n\t\t\t\t\t({\n\t\t\t\t\t\t...row,\n\t\t\t\t\t\tid: row.id as UUID,\n\t\t\t\t\t\tbio: (row.bio === null\n\t\t\t\t\t\t\t? \"\"\n\t\t\t\t\t\t\t: Array.isArray(row.bio)\n\t\t\t\t\t\t\t\t? row.bio\n\t\t\t\t\t\t\t\t: row.bio) as string | string[],\n\t\t\t\t\t}) as Partial<Agent>,\n\t\t\t);\n\t\t});\n\t\t// Guard against null return\n\t\treturn result || [];\n\t}\n\t/**\n\t * Asynchronously creates a new agent record in the database.\n\t *\n\t * @param {Partial<Agent>} agent The agent object to be created.\n\t * @returns {Promise<boolean>} A promise that resolves to a boolean indicating the success of the operation.\n\t */\n\tasync createAgent(agent: Agent): Promise<boolean> {\n\t\treturn this.withDatabase(async () => {\n\t\t\ttry {\n\t\t\t\tconst _isDuplicateKeyError = (error: unknown): boolean => {\n\t\t\t\t\tif (!error || typeof error !== \"object\") return false;\n\n\t\t\t\t\tconst maybeError = error as { code?: unknown; message?: unknown };\n\t\t\t\t\tif (maybeError.code === \"23505\") return true;\n\n\t\t\t\t\tif (typeof maybeError.message === \"string\") {\n\t\t\t\t\t\treturn /duplicate key|already exists/i.test(maybeError.message);\n\t\t\t\t\t}\n\n\t\t\t\t\treturn false;\n\t\t\t\t};\n\n\t\t\t\t// Check for existing agent with the same ID only (names can be duplicated)\n\t\t\t\tif (agent.id) {\n\t\t\t\t\tconst existing = await this.db\n\t\t\t\t\t\t.select({ id: agentTable.id })\n\t\t\t\t\t\t.from(agentTable)\n\t\t\t\t\t\t.where(eq(agentTable.id, agent.id))\n\t\t\t\t\t\t.limit(1);\n\n\t\t\t\t\tif (existing.length > 0) {\n\t\t\t\t\t\tlogger.warn(\n\t\t\t\t\t\t\t{ src: \"plugin:sql\", agentId: agent.id },\n\t\t\t\t\t\t\t\"Attempted to create agent with duplicate ID\",\n\t\t\t\t\t\t);\n\t\t\t\t\t\treturn false;\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\tawait this.db.transaction(async (tx) => {\n\t\t\t\t\tconst agentData = {\n\t\t\t\t\t\t...agent,\n\t\t\t\t\t\tcreatedAt: new Date(\n\t\t\t\t\t\t\ttypeof agent.createdAt === \"bigint\"\n\t\t\t\t\t\t\t\t? Number(agent.createdAt)\n\t\t\t\t\t\t\t\t: agent.createdAt || Date.now(),\n\t\t\t\t\t\t),\n\t\t\t\t\t\tupdatedAt: new Date(\n\t\t\t\t\t\t\ttypeof agent.updatedAt === \"bigint\"\n\t\t\t\t\t\t\t\t? Number(agent.updatedAt)\n\t\t\t\t\t\t\t\t: agent.updatedAt || Date.now(),\n\t\t\t\t\t\t),\n\t\t\t\t\t};\n\t\t\t\t\tconst sanitizedAgentData = Object.fromEntries(\n\t\t\t\t\t\tObject.entries(agentData).filter(\n\t\t\t\t\t\t\t([, value]) => value !== undefined,\n\t\t\t\t\t\t),\n\t\t\t\t\t) as typeof agentData;\n\n\t\t\t\t\tawait tx\n\t\t\t\t\t\t.insert(agentTable)\n\t\t\t\t\t\t.values(\n\t\t\t\t\t\t\tsanitizedAgentData as unknown as typeof agentTable.$inferInsert,\n\t\t\t\t\t\t);\n\t\t\t\t});\n\n\t\t\t\treturn true;\n\t\t\t} catch (error) {\n\t\t\t\tif (isDuplicateKeyError(error)) {\n\t\t\t\t\tlogger.warn(\n\t\t\t\t\t\t{ src: \"plugin:sql\", agentId: agent.id },\n\t\t\t\t\t\t\"Attempted to create agent with duplicate ID\",\n\t\t\t\t\t);\n\t\t\t\t\treturn false;\n\t\t\t\t}\n\n\t\t\t\tlogger.error(\n\t\t\t\t\t{\n\t\t\t\t\t\tsrc: \"plugin:sql\",\n\t\t\t\t\t\tagentId: agent.id,\n\t\t\t\t\t\terror: error instanceof Error ? error.message : String(error),\n\t\t\t\t\t},\n\t\t\t\t\t\"Failed to create agent\",\n\t\t\t\t);\n\t\t\t\tthrow error;\n\t\t\t}\n\t\t});\n\t}\n\n\t/**\n\t * Updates an agent in the database with the provided agent ID and data.\n\t * @param {UUID} agentId - The unique identifier of the agent to update.\n\t * @param {Partial<Agent>} agent - The partial agent object containing the fields to update.\n\t * @returns {Promise<boolean>} - A boolean indicating if the agent was successfully updated.\n\t */\n\tasync updateAgent(agentId: UUID, agent: Partial<Agent>): Promise<boolean> {\n\t\treturn this.withDatabase(async () => {\n\t\t\ttry {\n\t\t\t\tif (!agentId) {\n\t\t\t\t\tthrow new Error(\"Agent ID is required for update\");\n\t\t\t\t}\n\n\t\t\t\tawait this.db.transaction(async (tx) => {\n\t\t\t\t\t// Handle settings update if present\n\t\t\t\t\tif (agent?.settings) {\n\t\t\t\t\t\tagent.settings = await this.mergeAgentSettings(\n\t\t\t\t\t\t\ttx,\n\t\t\t\t\t\t\tagentId,\n\t\t\t\t\t\t\tagent.settings,\n\t\t\t\t\t\t);\n\t\t\t\t\t}\n\n\t\t\t\t\t// Convert numeric timestamps to Date objects for database storage\n\t\t\t\t\t// The Agent interface uses numbers, but the database schema expects Date objects\n\t\t\t\t\tconst updateData: Record<string, unknown> = { ...agent };\n\n\t\t\t\t\tif (updateData.createdAt) {\n\t\t\t\t\t\tif (typeof updateData.createdAt === \"number\") {\n\t\t\t\t\t\t\tupdateData.createdAt = new Date(updateData.createdAt);\n\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\tdelete updateData.createdAt; // Don't update createdAt if it's not a valid timestamp\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t\tif (updateData.updatedAt) {\n\t\t\t\t\t\tif (typeof updateData.updatedAt === \"number\") {\n\t\t\t\t\t\t\tupdateData.updatedAt = new Date(updateData.updatedAt);\n\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\tupdateData.updatedAt = new Date(); // Use current time if invalid\n\t\t\t\t\t\t}\n\t\t\t\t\t} else {\n\t\t\t\t\t\tupdateData.updatedAt = new Date(); // Always set updatedAt to current time\n\t\t\t\t\t}\n\n\t\t\t\t\tawait tx\n\t\t\t\t\t\t.update(agentTable)\n\t\t\t\t\t\t.set(updateData)\n\t\t\t\t\t\t.where(eq(agentTable.id, agentId));\n\t\t\t\t});\n\n\t\t\t\treturn true;\n\t\t\t} catch (error) {\n\t\t\t\tlogger.error(\n\t\t\t\t\t{\n\t\t\t\t\t\tsrc: \"plugin:sql\",\n\t\t\t\t\t\tagentId,\n\t\t\t\t\t\terror: error instanceof Error ? error.message : String(error),\n\t\t\t\t\t},\n\t\t\t\t\t\"Failed to update agent\",\n\t\t\t\t);\n\t\t\t\treturn false;\n\t\t\t}\n\t\t});\n\t}\n\n\t/**\n\t * Merges updated agent settings with existing settings in the database,\n\t * with special handling for nested objects like secrets.\n\t * @param tx - The database transaction\n\t * @param agentId - The ID of the agent\n\t * @param updatedSettings - The settings object with updates\n\t * @returns The merged settings object\n\t * @private\n\t */\n\tprivate async mergeAgentSettings<T extends Record<string, unknown>>(\n\t\ttx: DrizzleDatabase,\n\t\tagentId: UUID,\n\t\tupdatedSettings: T,\n\t): Promise<T> {\n\t\t// First get the current agent data\n\t\tconst currentAgent = await tx\n\t\t\t.select({ settings: agentTable.settings })\n\t\t\t.from(agentTable)\n\t\t\t.where(eq(agentTable.id, agentId))\n\t\t\t.limit(1);\n\n\t\tconst currentSettings =\n\t\t\tcurrentAgent.length > 0 && currentAgent[0].settings\n\t\t\t\t? currentAgent[0].settings\n\t\t\t\t: {};\n\n\t\tconst deepMerge = (\n\t\t\ttarget: Record<string, unknown> | unknown,\n\t\t\tsource: Record<string, unknown>,\n\t\t): Record<string, unknown> | undefined => {\n\t\t\t// If source is explicitly null, it means the intention is to set this entire branch to null (or delete if top-level handled by caller).\n\t\t\t// For recursive calls, if a sub-object in source is null, it effectively means \"remove this sub-object from target\".\n\t\t\t// However, our primary deletion signal is a *property value* being null within an object.\n\t\t\tif (source === null) {\n\t\t\t\t// If the entire source for a given key is null, we treat it as \"delete this key from target\"\n\t\t\t\t// by returning undefined, which the caller can use to delete the key.\n\t\t\t\treturn undefined;\n\t\t\t}\n\n\t\t\t// If source is an array or a primitive, it replaces the target value.\n\t\t\tif (Array.isArray(source) || typeof source !== \"object\") {\n\t\t\t\treturn source;\n\t\t\t}\n\n\t\t\t// Initialize output. If target is not an object, start with an empty one to merge source into.\n\t\t\tconst output =\n\t\t\t\ttypeof target === \"object\" && target !== null && !Array.isArray(target)\n\t\t\t\t\t? { ...target }\n\t\t\t\t\t: {};\n\n\t\t\tfor (const key of Object.keys(source)) {\n\t\t\t\t// Iterate over source keys\n\t\t\t\tconst sourceValue = source[key];\n\n\t\t\t\tif (sourceValue === null) {\n\t\t\t\t\t// If a value in source is null, delete the corresponding key from output.\n\t\t\t\t\tdelete output[key];\n\t\t\t\t} else if (\n\t\t\t\t\ttypeof sourceValue === \"object\" &&\n\t\t\t\t\t!Array.isArray(sourceValue)\n\t\t\t\t) {\n\t\t\t\t\t// If value is an object, recurse.\n\t\t\t\t\tconst nestedMergeResult = deepMerge(\n\t\t\t\t\t\toutput[key],\n\t\t\t\t\t\tsourceValue as Record<string, unknown>,\n\t\t\t\t\t);\n\t\t\t\t\tif (nestedMergeResult === undefined) {\n\t\t\t\t\t\t// If recursive merge resulted in undefined (meaning the nested object should be deleted)\n\t\t\t\t\t\tdelete output[key];\n\t\t\t\t\t} else {\n\t\t\t\t\t\toutput[key] = nestedMergeResult;\n\t\t\t\t\t}\n\t\t\t\t} else {\n\t\t\t\t\t// Primitive or array value from source, assign it.\n\t\t\t\t\toutput[key] = sourceValue;\n\t\t\t\t}\n\t\t\t}\n\n\t\t\t// After processing all keys from source, check if output became empty.\n\t\t\t// An object is empty if all its keys were deleted or resulted in undefined.\n\t\t\t// This is a more direct check than iterating 'output' after building it.\n\t\t\tif (Object.keys(output).length === 0) {\n\t\t\t\t// If the source itself was not an explicitly empty object,\n\t\t\t\t// and the merge resulted in an empty object, signal deletion.\n\t\t\t\tif (\n\t\t\t\t\t!(\n\t\t\t\t\t\ttypeof source === \"object\" &&\n\t\t\t\t\t\tsource !== null &&\n\t\t\t\t\t\tObject.keys(source).length === 0\n\t\t\t\t\t)\n\t\t\t\t) {\n\t\t\t\t\treturn undefined; // Signal to delete this (parent) key if it became empty.\n\t\t\t\t}\n\t\t\t}\n\n\t\t\treturn output;\n\t\t}; // End of deepMerge\n\n\t\tconst finalSettings = deepMerge(currentSettings, updatedSettings);\n\t\t// If the entire settings object becomes undefined (e.g. all keys removed),\n\t\t// return an empty object instead of undefined/null to keep the settings field present.\n\t\treturn (finalSettings ?? {}) as T;\n\t}\n\n\t/**\n\t * Asynchronously deletes an agent with the specified UUID and all related entries.\n\t *\n\t * @param {UUID} agentId - The UUID of the agent to be deleted.\n\t * @returns {Promise<boolean>} - A boolean indicating if the deletion was successful.\n\t */\n\tasync deleteAgent(agentId: UUID): Promise<boolean> {\n\t\treturn this.withDatabase(async () => {\n\t\t\ttry {\n\t\t\t\t// Simply delete the agent - all related data will be cascade deleted\n\t\t\t\tconst result = await this.db\n\t\t\t\t\t.delete(agentTable)\n\t\t\t\t\t.where(eq(agentTable.id, agentId))\n\t\t\t\t\t.returning();\n\n\t\t\t\tif (result.length === 0) {\n\t\t\t\t\tlogger.warn(\n\t\t\t\t\t\t{ src: \"plugin:sql\", agentId },\n\t\t\t\t\t\t\"Agent not found for deletion\",\n\t\t\t\t\t);\n\t\t\t\t\treturn false;\n\t\t\t\t}\n\n\t\t\t\treturn true;\n\t\t\t} catch (error) {\n\t\t\t\tlogger.error(\n\t\t\t\t\t{\n\t\t\t\t\t\tsrc: \"plugin:sql\",\n\t\t\t\t\t\tagentId,\n\t\t\t\t\t\terror: error instanceof Error ? error.message : String(error),\n\t\t\t\t\t},\n\t\t\t\t\t\"Failed to delete agent\",\n\t\t\t\t);\n\t\t\t\tthrow error;\n\t\t\t}\n\t\t});\n\t}\n\n\t/**\n\t * Count all agents in the database\n\t * Used primarily for maintenance and cleanup operations\n\t */\n\t/**\n\t * Asynchronously counts the number of agents in the database.\n\t * @returns {Promise<number>} A Promise that resolves to the number of agents in the database.\n\t */\n\tasync countAgents(): Promise<number> {\n\t\treturn this.withDatabase(async () => {\n\t\t\ttry {\n\t\t\t\tconst result = await this.db\n\t\t\t\t\t.select({ count: count() })\n\t\t\t\t\t.from(agentTable);\n\n\t\t\t\tconst result0 = result[0];\n\t\t\t\treturn result0?.count || 0;\n\t\t\t} catch (error) {\n\t\t\t\tlogger.error(\n\t\t\t\t\t{\n\t\t\t\t\t\tsrc: \"plugin:sql\",\n\t\t\t\t\t\terror: error instanceof Error ? error.message : String(error),\n\t\t\t\t\t},\n\t\t\t\t\t\"Failed to count agents\",\n\t\t\t\t);\n\t\t\t\treturn 0;\n\t\t\t}\n\t\t});\n\t}\n\n\t/**\n\t * Clean up the agents table by removing all agents\n\t * This is used during server startup to ensure no orphaned agents exist\n\t * from previous crashes or improper shutdowns\n\t */\n\tasync cleanupAgents(): Promise<void> {\n\t\treturn this.withDatabase(async () => {\n\t\t\ttry {\n\t\t\t\tawait this.db.delete(agentTable);\n\t\t\t} catch (error) {\n\t\t\t\tlogger.error(\n\t\t\t\t\t{\n\t\t\t\t\t\tsrc: \"plugin:sql\",\n\t\t\t\t\t\terror: error instanceof Error ? error.message : String(error),\n\t\t\t\t\t},\n\t\t\t\t\t\"Failed to clean up agent table\",\n\t\t\t\t);\n\t\t\t\tthrow error;\n\t\t\t}\n\t\t});\n\t}\n\n\t/**\n\t * Asynchronously retrieves an entity and its components by entity IDs.\n\t * @param {UUID[]} entityIds - The unique identifiers of the entities to retrieve.\n\t * @returns {Promise<Entity[] | null>} A Promise that resolves to the entity with its components if found, null otherwise.\n\t */\n\tasync getEntitiesByIds(entityIds: UUID[]): Promise<Entity[] | null> {\n\t\treturn this.withDatabase(async () => {\n\t\t\tconst result = await this.db\n\t\t\t\t.select({\n\t\t\t\t\tentity: entityTable,\n\t\t\t\t\tcomponents: componentTable,\n\t\t\t\t})\n\t\t\t\t.from(entityTable)\n\t\t\t\t.leftJoin(componentTable, eq(componentTable.entityId, entityTable.id))\n\t\t\t\t.where(inArray(entityTable.id, entityIds));\n\n\t\t\tif (result.length === 0) return [];\n\n\t\t\t// Group components by entity\n\t\t\tconst entities: Record<UUID, Entity> = {};\n\t\t\tconst entityComponents: Record<UUID, Entity[\"components\"]> = {};\n\t\t\tfor (const e of result) {\n\t\t\t\tconst key = e.entity.id;\n\t\t\t\tentities[key] = e.entity;\n\t\t\t\tif (entityComponents[key] === undefined) entityComponents[key] = [];\n\t\t\t\tif (e.components) {\n\t\t\t\t\t// Handle both single component and array of components\n\t\t\t\t\tconst componentsArray = Array.isArray(e.components)\n\t\t\t\t\t\t? e.components\n\t\t\t\t\t\t: [e.components];\n\t\t\t\t\tentityComponents[key] = [\n\t\t\t\t\t\t...entityComponents[key],\n\t\t\t\t\t\t...componentsArray,\n\t\t\t\t\t];\n\t\t\t\t}\n\t\t\t}\n\t\t\tfor (const k of Object.keys(entityComponents)) {\n\t\t\t\tentities[k].components = entityComponents[k];\n\t\t\t}\n\n\t\t\treturn Object.values(entities);\n\t\t});\n\t}\n\n\t/**\n\t * Asynchronously retrieves all entities for a given room, optionally including their components.\n\t * @param {UUID} roomId - The unique identifier of the room to get entities for\n\t * @param {boolean} [includeComponents] - Whether to include component data for each entity\n\t * @returns {Promise<Entity[]>} A Promise that resolves to an array of entities in the room\n\t */\n\tasync getEntitiesForRoom(\n\t\troomId: UUID,\n\t\tincludeComponents?: boolean,\n\t): Promise<Entity[]> {\n\t\treturn this.withDatabase(async () => {\n\t\t\tconst query = this.db\n\t\t\t\t.select({\n\t\t\t\t\tentity: entityTable,\n\t\t\t\t\t...(includeComponents && { components: componentTable }),\n\t\t\t\t})\n\t\t\t\t.from(participantTable)\n\t\t\t\t.leftJoin(\n\t\t\t\t\tentityTable,\n\t\t\t\t\tand(\n\t\t\t\t\t\teq(participantTable.entityId, entityTable.id),\n\t\t\t\t\t\teq(entityTable.agentId, this.agentId),\n\t\t\t\t\t),\n\t\t\t\t);\n\n\t\t\tif (includeComponents) {\n\t\t\t\tquery.leftJoin(\n\t\t\t\t\tcomponentTable,\n\t\t\t\t\teq(componentTable.entityId, entityTable.id),\n\t\t\t\t);\n\t\t\t}\n\n\t\t\tconst result = await query.where(eq(participantTable.roomId, roomId));\n\n\t\t\t// Group components by entity if includeComponents is true\n\t\t\tconst entitiesByIdMap = new Map<UUID, Entity>();\n\n\t\t\tfor (const row of result) {\n\t\t\t\tif (!row.entity) continue;\n\n\t\t\t\tconst entityId = row.entity.id as UUID;\n\t\t\t\tif (!entitiesByIdMap.has(entityId)) {\n\t\t\t\t\tconst entity: Entity = {\n\t\t\t\t\t\t...row.entity,\n\t\t\t\t\t\tid: entityId,\n\t\t\t\t\t\tagentId: row.entity.agentId as UUID,\n\t\t\t\t\t\tmetadata: (row.entity.metadata || {}) as Metadata,\n\t\t\t\t\t\tcomponents: includeComponents ? [] : undefined,\n\t\t\t\t\t};\n\t\t\t\t\tentitiesByIdMap.set(entityId, entity);\n\t\t\t\t}\n\n\t\t\t\tif (includeComponents && row.components) {\n\t\t\t\t\tconst entity = entitiesByIdMap.get(entityId);\n\t\t\t\t\tif (entity) {\n\t\t\t\t\t\tif (!entity.components) {\n\t\t\t\t\t\t\tentity.components = [];\n\t\t\t\t\t\t}\n\t\t\t\t\t\tentity.components.push(row.components);\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\n\t\t\treturn Array.from(entitiesByIdMap.values());\n\t\t});\n\t}\n\n\t/**\n\t * Asynchronously creates new entities in the database.\n\t * @param {Entity[]} entities - The entity objects to be created.\n\t * @returns {Promise<boolean>} A Promise that resolves to a boolean indicating the success of the operation.\n\t */\n\tasync createEntities(entities: Entity[]): Promise<boolean> {\n\t\treturn this.withDatabase(async () => {\n\t\t\ttry {\n\t\t\t\treturn await this.db.transaction(async (tx) => {\n\t\t\t\t\t// Normalize entity data to ensure names is a proper array\n\t\t\t\t\tconst normalizedEntities = entities.map((entity) => ({\n\t\t\t\t\t\t...entity,\n\t\t\t\t\t\tnames: this.normalizeEntityNames(entity.names),\n\t\t\t\t\t\tmetadata: entity.metadata || {},\n\t\t\t\t\t}));\n\n\t\t\t\t\tawait tx.insert(entityTable).values(normalizedEntities);\n\n\t\t\t\t\treturn true;\n\t\t\t\t});\n\t\t\t} catch (error) {\n\t\t\t\tlogger.error(\n\t\t\t\t\t{\n\t\t\t\t\t\tsrc: \"plugin:sql\",\n\t\t\t\t\t\tentityId: entities[0]?.id,\n\t\t\t\t\t\terror: error instanceof Error ? error.message : String(error),\n\t\t\t\t\t},\n\t\t\t\t\t\"Failed to create entities\",\n\t\t\t\t);\n\t\t\t\treturn false;\n\t\t\t}\n\t\t});\n\t}\n\n\t/**\n\t * Asynchronously ensures an entity exists, creating it if it doesn't\n\t * @param entity The entity to ensure exists\n\t * @returns Promise resolving to boolean indicating success\n\t */\n\tprotected async ensureEntityExists(entity: Entity): Promise<boolean> {\n\t\tif (!entity.id) {\n\t\t\tlogger.error(\n\t\t\t\t{ src: \"plugin:sql\" },\n\t\t\t\t\"Entity ID is required for ensureEntityExists\",\n\t\t\t);\n\t\t\treturn false;\n\t\t}\n\n\t\ttry {\n\t\t\tconst existingEntities = await this.getEntitiesByIds([entity.id]);\n\n\t\t\tif (!existingEntities || !existingEntities.length) {\n\t\t\t\treturn await this.createEntities([entity]);\n\t\t\t}\n\n\t\t\treturn true;\n\t\t} catch (error) {\n\t\t\tlogger.error(\n\t\t\t\t{\n\t\t\t\t\tsrc: \"plugin:sql\",\n\t\t\t\t\tentityId: entity.id,\n\t\t\t\t\terror: error instanceof Error ? error.message : String(error),\n\t\t\t\t},\n\t\t\t\t\"Failed to ensure entity exists\",\n\t\t\t);\n\t\t\treturn false;\n\t\t}\n\t}\n\n\t/**\n\t * Asynchronously updates an entity in the database.\n\t * @param {Entity} entity - The entity object to be updated.\n\t * @returns {Promise<void>} A Promise that resolves when the entity is updated.\n\t */\n\tasync updateEntity(entity: Entity): Promise<void> {\n\t\tif (!entity.id) {\n\t\t\tthrow new Error(\"Entity ID is required for update\");\n\t\t}\n\t\treturn this.withDatabase(async () => {\n\t\t\t// Normalize entity data to ensure names is a proper array\n\t\t\tconst normalizedEntity = {\n\t\t\t\t...entity,\n\t\t\t\tnames: this.normalizeEntityNames(entity.names),\n\t\t\t\tmetadata: entity.metadata || {},\n\t\t\t};\n\n\t\t\tawait this.db\n\t\t\t\t.update(entityTable)\n\t\t\t\t.set(normalizedEntity)\n\t\t\t\t.where(eq(entityTable.id, entity.id as string));\n\t\t});\n\t}\n\n\t/**\n\t * Asynchronously deletes an entity from the database based on the provided ID.\n\t * @param {UUID} entityId - The ID of the entity to delete.\n\t * @returns {Promise<void>} A Promise that resolves when the entity is deleted.\n\t */\n\tasync deleteEntity(entityId: UUID): Promise<void> {\n\t\treturn this.withDatabase(async () => {\n\t\t\tawait this.db.transaction(async (tx) => {\n\t\t\t\t// Delete related components first\n\t\t\t\tawait tx\n\t\t\t\t\t.delete(componentTable)\n\t\t\t\t\t.where(\n\t\t\t\t\t\tor(\n\t\t\t\t\t\t\teq(componentTable.entityId, entityId),\n\t\t\t\t\t\t\teq(componentTable.sourceEntityId, entityId),\n\t\t\t\t\t\t),\n\t\t\t\t\t);\n\n\t\t\t\t// Delete the entity\n\t\t\t\tawait tx.delete(entityTable).where(eq(entityTable.id, entityId));\n\t\t\t});\n\t\t});\n\t}\n\n\t/**\n\t * Asynchronously retrieves entities by their names and agentId.\n\t * @param {Object} params - The parameters for retrieving entities.\n\t * @param {string[]} params.names - The names to search for.\n\t * @param {UUID} params.agentId - The agent ID to filter by.\n\t * @returns {Promise<Entity[]>} A Promise that resolves to an array of entities.\n\t */\n\tasync getEntitiesByNames(params: {\n\t\tnames: string[];\n\t\tagentId: UUID;\n\t}): Promise<Entity[]> {\n\t\treturn this.withDatabase(async () => {\n\t\t\tconst { names, agentId } = params;\n\n\t\t\t// Build a condition to match any of the names\n\t\t\tconst nameConditions = names.map(\n\t\t\t\t(name) => sql`${name} = ANY(${entityTable.names})`,\n\t\t\t);\n\n\t\t\tconst query = sql`\n SELECT * FROM ${entityTable}\n WHERE ${entityTable.agentId} = ${agentId}\n AND (${sql.join(nameConditions, sql` OR `)})\n `;\n\n\t\t\tconst result = await this.db.execute(query);\n\n\t\t\treturn result.rows.map((row: Record<string, unknown>) => ({\n\t\t\t\tid: row.id as UUID,\n\t\t\t\tagentId: row.agentId as UUID,\n\t\t\t\tnames: (row.names || []) as string[],\n\t\t\t\tmetadata: (row.metadata || {}) as Metadata,\n\t\t\t}));\n\t\t});\n\t}\n\n\t/**\n\t * Asynchronously searches for entities by name with fuzzy matching.\n\t * @param {Object} params - The parameters for searching entities.\n\t * @param {string} params.query - The search query.\n\t * @param {UUID} params.agentId - The agent ID to filter by.\n\t * @param {number} params.limit - The maximum number of results to return.\n\t * @returns {Promise<Entity[]>} A Promise that resolves to an array of entities.\n\t */\n\tasync searchEntitiesByName(params: {\n\t\tquery: string;\n\t\tagentId: UUID;\n\t\tlimit?: number;\n\t}): Promise<Entity[]> {\n\t\treturn this.withDatabase(async () => {\n\t\t\tconst { query, agentId, limit = 10 } = params;\n\n\t\t\t// If query is empty, return all entities up to limit\n\t\t\tif (!query || query.trim() === \"\") {\n\t\t\t\tconst result = await this.db\n\t\t\t\t\t.select()\n\t\t\t\t\t.from(entityTable)\n\t\t\t\t\t.where(eq(entityTable.agentId, agentId))\n\t\t\t\t\t.limit(limit);\n\n\t\t\t\treturn result.map((row: Record<string, unknown>) => ({\n\t\t\t\t\tid: row.id as UUID,\n\t\t\t\t\tagentId: row.agentId as UUID,\n\t\t\t\t\tnames: (row.names || []) as string[],\n\t\t\t\t\tmetadata: (row.metadata || {}) as Metadata,\n\t\t\t\t}));\n\t\t\t}\n\n\t\t\t// Otherwise, search for entities with names containing the query (case-insensitive)\n\t\t\tconst searchQuery = sql`\n SELECT * FROM ${entityTable}\n WHERE ${entityTable.agentId} = ${agentId}\n AND EXISTS (\n SELECT 1 FROM unnest(${entityTable.names}) AS name\n WHERE LOWER(name) LIKE LOWER(${`%${query}%`})\n )\n LIMIT ${limit}\n `;\n\n\t\t\tconst result = await this.db.execute(searchQuery);\n\n\t\t\treturn result.rows.map((row: Record<string, unknown>) => ({\n\t\t\t\tid: row.id as UUID,\n\t\t\t\tagentId: row.agentId as UUID,\n\t\t\t\tnames: (row.names || []) as string[],\n\t\t\t\tmetadata: (row.metadata || {}) as Metadata,\n\t\t\t}));\n\t\t});\n\t}\n\n\tasync getComponent(\n\t\tentityId: UUID,\n\t\ttype: string,\n\t\tworldId?: UUID,\n\t\tsourceEntityId?: UUID,\n\t): Promise<Component | null> {\n\t\treturn this.withDatabase(async () => {\n\t\t\tconst conditions = [\n\t\t\t\teq(componentTable.entityId, entityId),\n\t\t\t\teq(componentTable.type, type),\n\t\t\t];\n\n\t\t\tif (worldId) {\n\t\t\t\tconditions.push(eq(componentTable.worldId, worldId));\n\t\t\t}\n\n\t\t\tif (sourceEntityId) {\n\t\t\t\tconditions.push(eq(componentTable.sourceEntityId, sourceEntityId));\n\t\t\t}\n\n\t\t\tconst result = await this.db\n\t\t\t\t.select()\n\t\t\t\t.from(componentTable)\n\t\t\t\t.where(and(...conditions));\n\n\t\t\tif (result.length === 0) return null;\n\n\t\t\tconst component = result[0];\n\n\t\t\treturn {\n\t\t\t\t...component,\n\t\t\t\tid: component.id as UUID,\n\t\t\t\tentityId: component.entityId as UUID,\n\t\t\t\tagentId: component.agentId as UUID,\n\t\t\t\troomId: component.roomId as UUID,\n\t\t\t\tworldId: (component.worldId ?? \"\") as UUID,\n\t\t\t\tsourceEntityId: (component.sourceEntityId ?? \"\") as UUID,\n\t\t\t\tdata: component.data as Metadata,\n\t\t\t\tcreatedAt: component.createdAt.getTime(),\n\t\t\t};\n\t\t});\n\t}\n\n\t/**\n\t * Asynchronously retrieves all components for a given entity, optionally filtered by world and source entity.\n\t * @param {UUID} entityId - The unique identifier of the entity to retrieve components for\n\t * @param {UUID} [worldId] - Optional world ID to filter components by\n\t * @param {UUID} [sourceEntityId] - Optional source entity ID to filter components by\n\t * @returns {Promise<Component[]>} A Promise that resolves to an array of components\n\t */\n\tasync getComponents(\n\t\tentityId: UUID,\n\t\tworldId?: UUID,\n\t\tsourceEntityId?: UUID,\n\t): Promise<Component[]> {\n\t\treturn this.withDatabase(async () => {\n\t\t\tconst conditions = [eq(componentTable.entityId, entityId)];\n\n\t\t\tif (worldId) {\n\t\t\t\tconditions.push(eq(componentTable.worldId, worldId));\n\t\t\t}\n\n\t\t\tif (sourceEntityId) {\n\t\t\t\tconditions.push(eq(componentTable.sourceEntityId, sourceEntityId));\n\t\t\t}\n\n\t\t\tconst result = await this.db\n\t\t\t\t.select({\n\t\t\t\t\tid: componentTable.id,\n\t\t\t\t\tentityId: componentTable.entityId,\n\t\t\t\t\ttype: componentTable.type,\n\t\t\t\t\tdata: componentTable.data,\n\t\t\t\t\tworldId: componentTable.worldId,\n\t\t\t\t\tagentId: componentTable.agentId,\n\t\t\t\t\troomId: componentTable.roomId,\n\t\t\t\t\tsourceEntityId: componentTable.sourceEntityId,\n\t\t\t\t\tcreatedAt: componentTable.createdAt,\n\t\t\t\t})\n\t\t\t\t.from(componentTable)\n\t\t\t\t.where(and(...conditions));\n\n\t\t\tif (result.length === 0) return [];\n\n\t\t\tconst components = result.map((component) => ({\n\t\t\t\t...component,\n\t\t\t\tid: component.id as UUID,\n\t\t\t\tentityId: component.entityId as UUID,\n\t\t\t\tagentId: component.agentId as UUID,\n\t\t\t\troomId: component.roomId as UUID,\n\t\t\t\tworldId: (component.worldId ?? \"\") as UUID,\n\t\t\t\tsourceEntityId: (component.sourceEntityId ?? \"\") as UUID,\n\t\t\t\tdata: component.data as Metadata,\n\t\t\t\tcreatedAt: component.createdAt.getTime(),\n\t\t\t}));\n\n\t\t\treturn components;\n\t\t});\n\t}\n\n\t/**\n\t * Asynchronously creates a new component in the database.\n\t * @param {Component} component - The component object to be created.\n\t * @returns {Promise<boolean>} A Promise that resolves to a boolean indicating the success of the operation.\n\t */\n\tasync createComponent(component: Component): Promise<boolean> {\n\t\treturn this.withDatabase(async () => {\n\t\t\tawait this.db.insert(componentTable).values({\n\t\t\t\t...component,\n\t\t\t\tcreatedAt: new Date(),\n\t\t\t});\n\t\t\treturn true;\n\t\t});\n\t}\n\n\t/**\n\t * Asynchronously updates an existing component in the database.\n\t * @param {Component} component - The component object to be updated.\n\t * @returns {Promise<void>} A Promise that resolves when the component is updated.\n\t */\n\tasync updateComponent(component: Component): Promise<void> {\n\t\treturn this.withDatabase(async () => {\n\t\t\ttry {\n\t\t\t\t// Convert createdAt from number to Date for database compatibility\n\t\t\t\tconst { createdAt, ...rest } = component;\n\t\t\t\tawait this.db\n\t\t\t\t\t.update(componentTable)\n\t\t\t\t\t.set({\n\t\t\t\t\t\t...rest,\n\t\t\t\t\t\tcreatedAt: new Date(createdAt),\n\t\t\t\t\t})\n\t\t\t\t\t.where(eq(componentTable.id, component.id));\n\t\t\t} catch (e) {\n\t\t\t\tconsole.error(\"updateComponent error\", e);\n\t\t\t}\n\t\t});\n\t}\n\n\t/**\n\t * Asynchronously deletes a component from the database.\n\t * @param {UUID} componentId - The unique identifier of the component to delete.\n\t * @returns {Promise<void>} A Promise that resolves when the component is deleted.\n\t */\n\tasync deleteComponent(componentId: UUID): Promise<void> {\n\t\treturn this.withDatabase(async () => {\n\t\t\tawait this.db\n\t\t\t\t.delete(componentTable)\n\t\t\t\t.where(eq(componentTable.id, componentId));\n\t\t});\n\t}\n\n\t/**\n\t * Asynchronously retrieves memories from the database based on the provided parameters.\n\t * @param {Object} params - The parameters for retrieving memories.\n\t * @param {UUID} params.roomId - The ID of the room to retrieve memories for.\n\t * @param {number} [params.count] - The maximum number of memories to retrieve.\n\t * @param {number} [params.offset] - The offset for pagination.\n\t * @param {boolean} [params.unique] - Whether to retrieve unique memories only.\n\t * @param {string} [params.tableName] - The name of the table to retrieve memories from.\n\t * @param {number} [params.start] - The start date to retrieve memories from.\n\t * @param {number} [params.end] - The end date to retrieve memories from.\n\t * @returns {Promise<Memory[]>} A Promise that resolves to an array of memories.\n\t */\n\tasync getMemories(params: {\n\t\tentityId?: UUID;\n\t\tagentId?: UUID;\n\t\tcount?: number;\n\t\toffset?: number;\n\t\tunique?: boolean;\n\t\ttableName: string;\n\t\tstart?: number;\n\t\tend?: number;\n\t\troomId?: UUID;\n\t\tworldId?: UUID;\n\t}): Promise<Memory[]> {\n\t\tconst {\n\t\t\tentityId,\n\t\t\tagentId,\n\t\t\troomId,\n\t\t\tworldId,\n\t\t\ttableName,\n\t\t\tunique,\n\t\t\tstart,\n\t\t\tend,\n\t\t\toffset,\n\t\t} = params;\n\n\t\tif (!tableName) throw new Error(\"tableName is required\");\n\t\tif (offset !== undefined && offset < 0) {\n\t\t\tthrow new Error(\"offset must be a non-negative number\");\n\t\t}\n\n\t\treturn this.withEntityContext(entityId ?? null, async (tx) => {\n\t\t\tconst conditions = [eq(memoryTable.type, tableName)];\n\n\t\t\tif (start) {\n\t\t\t\tconditions.push(gte(memoryTable.createdAt, new Date(start)));\n\t\t\t}\n\n\t\t\t// RLS handles access control - no explicit entityId filter needed\n\n\t\t\tif (roomId) {\n\t\t\t\tconditions.push(eq(memoryTable.roomId, roomId));\n\t\t\t}\n\n\t\t\t// Add worldId condition\n\t\t\tif (worldId) {\n\t\t\t\tconditions.push(eq(memoryTable.worldId, worldId));\n\t\t\t}\n\n\t\t\tif (end) {\n\t\t\t\tconditions.push(lte(memoryTable.createdAt, new Date(end)));\n\t\t\t}\n\n\t\t\tif (unique) {\n\t\t\t\tconditions.push(eq(memoryTable.unique, true));\n\t\t\t}\n\n\t\t\tif (agentId) {\n\t\t\t\tconditions.push(eq(memoryTable.agentId, agentId));\n\t\t\t}\n\n\t\t\tconst baseQuery = tx\n\t\t\t\t.select({\n\t\t\t\t\tmemory: {\n\t\t\t\t\t\tid: memoryTable.id,\n\t\t\t\t\t\ttype: memoryTable.type,\n\t\t\t\t\t\tcreatedAt: memoryTable.createdAt,\n\t\t\t\t\t\tcontent: memoryTable.content,\n\t\t\t\t\t\tentityId: memoryTable.entityId,\n\t\t\t\t\t\tagentId: memoryTable.agentId,\n\t\t\t\t\t\troomId: memoryTable.roomId,\n\t\t\t\t\t\tunique: memoryTable.unique,\n\t\t\t\t\t\tmetadata: memoryTable.metadata,\n\t\t\t\t\t},\n\t\t\t\t\tembedding: embeddingTable[this.embeddingDimension],\n\t\t\t\t})\n\t\t\t\t.from(memoryTable)\n\t\t\t\t.leftJoin(embeddingTable, eq(embeddingTable.memoryId, memoryTable.id))\n\t\t\t\t.where(and(...conditions))\n\t\t\t\t.orderBy(desc(memoryTable.createdAt));\n\n\t\t\t// Apply limit and offset for pagination\n\t\t\t// Build query conditionally to maintain proper types\n\t\t\tconst rows = await (async () => {\n\t\t\t\tif (params.count && offset !== undefined && offset > 0) {\n\t\t\t\t\treturn baseQuery.limit(params.count).offset(offset);\n\t\t\t\t} else if (params.count) {\n\t\t\t\t\treturn baseQuery.limit(params.count);\n\t\t\t\t} else if (offset !== undefined && offset > 0) {\n\t\t\t\t\treturn baseQuery.offset(offset);\n\t\t\t\t} else {\n\t\t\t\t\treturn baseQuery;\n\t\t\t\t}\n\t\t\t})();\n\n\t\t\treturn rows.map((row) => ({\n\t\t\t\tid: row.memory.id as UUID,\n\t\t\t\ttype: row.memory.type,\n\t\t\t\tcreatedAt: row.memory.createdAt.getTime(),\n\t\t\t\tcontent:\n\t\t\t\t\ttypeof row.memory.content === \"string\"\n\t\t\t\t\t\t? JSON.parse(row.memory.content)\n\t\t\t\t\t\t: row.memory.content,\n\t\t\t\tentityId: row.memory.entityId as UUID,\n\t\t\t\tagentId: row.memory.agentId as UUID,\n\t\t\t\troomId: row.memory.roomId as UUID,\n\t\t\t\tunique: row.memory.unique,\n\t\t\t\tmetadata: row.memory.metadata as MemoryMetadata,\n\t\t\t\tembedding: row.embedding ? Array.from(row.embedding) : undefined,\n\t\t\t}));\n\t\t});\n\t}\n\n\t/**\n\t * Asynchronously retrieves memories from the database based on the provided parameters.\n\t * @param {Object} params - The parameters for retrieving memories.\n\t * @param {UUID[]} params.roomIds - The IDs of the rooms to retrieve memories for.\n\t * @param {string} params.tableName - The name of the table to retrieve memories from.\n\t * @param {number} [params.limit] - The maximum number of memories to retrieve.\n\t * @returns {Promise<Memory[]>} A Promise that resolves to an array of memories.\n\t */\n\tasync getMemoriesByRoomIds(params: {\n\t\troomIds: UUID[];\n\t\ttableName: string;\n\t\tlimit?: number;\n\t}): Promise<Memory[]> {\n\t\treturn this.withDatabase(async () => {\n\t\t\tif (params.roomIds.length === 0) return [];\n\n\t\t\tconst conditions = [\n\t\t\t\teq(memoryTable.type, params.tableName),\n\t\t\t\tinArray(memoryTable.roomId, params.roomIds),\n\t\t\t];\n\n\t\t\tconditions.push(eq(memoryTable.agentId, this.agentId));\n\n\t\t\tconst query = this.db\n\t\t\t\t.select({\n\t\t\t\t\tid: memoryTable.id,\n\t\t\t\t\ttype: memoryTable.type,\n\t\t\t\t\tcreatedAt: memoryTable.createdAt,\n\t\t\t\t\tcontent: memoryTable.content,\n\t\t\t\t\tentityId: memoryTable.entityId,\n\t\t\t\t\tagentId: memoryTable.agentId,\n\t\t\t\t\troomId: memoryTable.roomId,\n\t\t\t\t\tunique: memoryTable.unique,\n\t\t\t\t\tmetadata: memoryTable.metadata,\n\t\t\t\t})\n\t\t\t\t.from(memoryTable)\n\t\t\t\t.where(and(...conditions))\n\t\t\t\t.orderBy(desc(memoryTable.createdAt));\n\n\t\t\tconst rows = params.limit ? await query.limit(params.limit) : await query;\n\n\t\t\treturn rows.map((row) => ({\n\t\t\t\tid: row.id as UUID,\n\t\t\t\tcreatedAt: row.createdAt.getTime(),\n\t\t\t\tcontent:\n\t\t\t\t\ttypeof row.content === \"string\"\n\t\t\t\t\t\t? JSON.parse(row.content)\n\t\t\t\t\t\t: row.content,\n\t\t\t\tentityId: row.entityId as UUID,\n\t\t\t\tagentId: row.agentId as UUID,\n\t\t\t\troomId: row.roomId as UUID,\n\t\t\t\tunique: row.unique,\n\t\t\t\tmetadata: row.metadata,\n\t\t\t})) as Memory[];\n\t\t});\n\t}\n\n\t/**\n\t * Asynchronously retrieves a memory by its unique identifier.\n\t * @param {UUID} id - The unique identifier of the memory to retrieve.\n\t * @returns {Promise<Memory | null>} A Promise that resolves to the memory if found, null otherwise.\n\t */\n\tasync getMemoryById(id: UUID): Promise<Memory | null> {\n\t\treturn this.withDatabase(async () => {\n\t\t\tconst result = await this.db\n\t\t\t\t.select({\n\t\t\t\t\tmemory: memoryTable,\n\t\t\t\t\tembedding: embeddingTable[this.embeddingDimension],\n\t\t\t\t})\n\t\t\t\t.from(memoryTable)\n\t\t\t\t.leftJoin(embeddingTable, eq(memoryTable.id, embeddingTable.memoryId))\n\t\t\t\t.where(eq(memoryTable.id, id))\n\t\t\t\t.limit(1);\n\n\t\t\tif (result.length === 0) return null;\n\n\t\t\tconst row = result[0];\n\t\t\treturn {\n\t\t\t\tid: row.memory.id as UUID,\n\t\t\t\tcreatedAt: row.memory.createdAt.getTime(),\n\t\t\t\tcontent:\n\t\t\t\t\ttypeof row.memory.content === \"string\"\n\t\t\t\t\t\t? JSON.parse(row.memory.content)\n\t\t\t\t\t\t: row.memory.content,\n\t\t\t\tentityId: row.memory.entityId as UUID,\n\t\t\t\tagentId: row.memory.agentId as UUID,\n\t\t\t\troomId: row.memory.roomId as UUID,\n\t\t\t\tunique: row.memory.unique,\n\t\t\t\tmetadata: row.memory.metadata as MemoryMetadata,\n\t\t\t\tembedding: row.embedding ?? undefined,\n\t\t\t};\n\t\t});\n\t}\n\n\t/**\n\t * Asynchronously retrieves memories from the database based on the provided parameters.\n\t * @param {Object} params - The parameters for retrieving memories.\n\t * @param {UUID[]} params.memoryIds - The IDs of the memories to retrieve.\n\t * @param {string} [params.tableName] - The name of the table to retrieve memories from.\n\t * @returns {Promise<Memory[]>} A Promise that resolves to an array of memories.\n\t */\n\tasync getMemoriesByIds(\n\t\tmemoryIds: UUID[],\n\t\ttableName?: string,\n\t): Promise<Memory[]> {\n\t\treturn this.withDatabase(async () => {\n\t\t\tif (memoryIds.length === 0) return [];\n\n\t\t\tconst conditions = [inArray(memoryTable.id, memoryIds)];\n\n\t\t\tif (tableName) {\n\t\t\t\tconditions.push(eq(memoryTable.type, tableName));\n\t\t\t}\n\n\t\t\tconst rows = await this.db\n\t\t\t\t.select({\n\t\t\t\t\tmemory: memoryTable,\n\t\t\t\t\tembedding: embeddingTable[this.embeddingDimension],\n\t\t\t\t})\n\t\t\t\t.from(memoryTable)\n\t\t\t\t.leftJoin(embeddingTable, eq(embeddingTable.memoryId, memoryTable.id))\n\t\t\t\t.where(and(...conditions))\n\t\t\t\t.orderBy(desc(memoryTable.createdAt));\n\n\t\t\treturn rows.map((row) => ({\n\t\t\t\tid: row.memory.id as UUID,\n\t\t\t\tcreatedAt: row.memory.createdAt.getTime(),\n\t\t\t\tcontent:\n\t\t\t\t\ttypeof row.memory.content === \"string\"\n\t\t\t\t\t\t? JSON.parse(row.memory.content)\n\t\t\t\t\t\t: row.memory.content,\n\t\t\t\tentityId: row.memory.entityId as UUID,\n\t\t\t\tagentId: row.memory.agentId as UUID,\n\t\t\t\troomId: row.memory.roomId as UUID,\n\t\t\t\tunique: row.memory.unique,\n\t\t\t\tmetadata: row.memory.metadata as MemoryMetadata,\n\t\t\t\tembedding: row.embedding ?? undefined,\n\t\t\t}));\n\t\t});\n\t}\n\n\t/**\n\t * Asynchronously retrieves cached embeddings from the database based on the provided parameters.\n\t * @param {Object} opts - The parameters for retrieving cached embeddings.\n\t * @param {string} opts.query_table_name - The name of the table to retrieve embeddings from.\n\t * @param {number} opts.query_threshold - The threshold for the levenshtein distance.\n\t * @param {string} opts.query_input - The input string to search for.\n\t * @param {string} opts.query_field_name - The name of the field to retrieve embeddings from.\n\t * @param {string} opts.query_field_sub_name - The name of the sub-field to retrieve embeddings from.\n\t * @param {number} opts.query_match_count - The maximum number of matches to retrieve.\n\t * @returns {Promise<{ embedding: number[]; levenshtein_score: number }[]>} A Promise that resolves to an array of cached embeddings.\n\t */\n\tasync getCachedEmbeddings(opts: {\n\t\tquery_table_name: string;\n\t\tquery_threshold: number;\n\t\tquery_input: string;\n\t\tquery_field_name: string;\n\t\tquery_field_sub_name: string;\n\t\tquery_match_count: number;\n\t}): Promise<{ embedding: number[]; levenshtein_score: number }[]> {\n\t\treturn this.withDatabase(async () => {\n\t\t\ttry {\n\t\t\t\t// Drizzle database has execute method for raw SQL\n\t\t\t\tinterface DrizzleDatabaseWithExecute {\n\t\t\t\t\texecute: (\n\t\t\t\t\t\tquery: ReturnType<typeof sql>,\n\t\t\t\t\t) => Promise<{ rows: Record<string, unknown>[] }>;\n\t\t\t\t}\n\t\t\t\tconst results = await (\n\t\t\t\t\tthis.db as DrizzleDatabaseWithExecute\n\t\t\t\t).execute(sql`\n WITH content_text AS (\n SELECT\n m.id,\n COALESCE(\n m.content->>${opts.query_field_sub_name},\n ''\n ) as content_text\n FROM memories m\n WHERE m.type = ${opts.query_table_name}\n AND m.content->>${opts.query_field_sub_name} IS NOT NULL\n ),\n embedded_text AS (\n SELECT\n ct.content_text,\n COALESCE(\n e.dim_384,\n e.dim_512,\n e.dim_768,\n e.dim_1024,\n e.dim_1536,\n e.dim_3072\n ) as embedding\n FROM content_text ct\n LEFT JOIN embeddings e ON e.memory_id = ct.id\n WHERE e.memory_id IS NOT NULL\n )\n SELECT\n embedding,\n levenshtein(${opts.query_input}, content_text) as levenshtein_score\n FROM embedded_text\n WHERE levenshtein(${opts.query_input}, content_text) <= ${opts.query_threshold}\n ORDER BY levenshtein_score\n LIMIT ${opts.query_match_count}\n `);\n\n\t\t\t\treturn results.rows\n\t\t\t\t\t.map((row) => ({\n\t\t\t\t\t\tembedding: Array.isArray(row.embedding)\n\t\t\t\t\t\t\t? row.embedding\n\t\t\t\t\t\t\t: typeof row.embedding === \"string\"\n\t\t\t\t\t\t\t\t? JSON.parse(row.embedding)\n\t\t\t\t\t\t\t\t: [],\n\t\t\t\t\t\tlevenshtein_score: Number(row.levenshtein_score),\n\t\t\t\t\t}))\n\t\t\t\t\t.filter((row) => Array.isArray(row.embedding));\n\t\t\t} catch (error) {\n\t\t\t\tlogger.error(\n\t\t\t\t\t{\n\t\t\t\t\t\tsrc: \"plugin:sql\",\n\t\t\t\t\t\ttableName: opts.query_table_name,\n\t\t\t\t\t\tfieldName: opts.query_field_name,\n\t\t\t\t\t\terror: error instanceof Error ? error.message : String(error),\n\t\t\t\t\t},\n\t\t\t\t\t\"Failed to get cached embeddings\",\n\t\t\t\t);\n\t\t\t\tif (\n\t\t\t\t\terror instanceof Error &&\n\t\t\t\t\terror.message ===\n\t\t\t\t\t\t\"levenshtein argument exceeds maximum length of 255 characters\"\n\t\t\t\t) {\n\t\t\t\t\treturn [];\n\t\t\t\t}\n\t\t\t\tthrow error;\n\t\t\t}\n\t\t});\n\t}\n\n\t/**\n\t * Asynchronously logs an event in the database.\n\t * @param {Object} params - The parameters for logging an event.\n\t * @param {Object} params.body - The body of the event to log.\n\t * @param {UUID} params.entityId - The ID of the entity associated with the event.\n\t * @param {UUID} params.roomId - The ID of the room associated with the event.\n\t * @param {string} params.type - The type of the event to log.\n\t * @returns {Promise<void>} A Promise that resolves when the event is logged.\n\t */\n\tasync log(params: {\n\t\tbody: { [key: string]: unknown };\n\t\tentityId: UUID;\n\t\troomId: UUID;\n\t\ttype: string;\n\t}): Promise<void> {\n\t\treturn this.withDatabase(async () => {\n\t\t\ttry {\n\t\t\t\t// Sanitize JSON body to prevent Unicode escape sequence errors\n\t\t\t\tconst sanitizedBody = this.sanitizeJsonObject(params.body);\n\n\t\t\t\t// Serialize to JSON string first for an additional layer of protection\n\t\t\t\t// This ensures any problematic characters are properly escaped during JSON serialization\n\t\t\t\tconst jsonString = JSON.stringify(sanitizedBody);\n\n\t\t\t\t// Use withEntityContext to set Entity RLS context before inserting\n\t\t\t\t// This ensures the log entry passes STRICT Entity RLS policy\n\t\t\t\tawait this.withEntityContext(params.entityId, async (tx) => {\n\t\t\t\t\tawait tx.insert(logTable).values({\n\t\t\t\t\t\tbody: sql`${jsonString}::jsonb`,\n\t\t\t\t\t\tentityId: params.entityId,\n\t\t\t\t\t\troomId: params.roomId,\n\t\t\t\t\t\ttype: params.type,\n\t\t\t\t\t});\n\t\t\t\t});\n\t\t\t} catch (error) {\n\t\t\t\tlogger.error(\n\t\t\t\t\t{\n\t\t\t\t\t\tsrc: \"plugin:sql\",\n\t\t\t\t\t\ttype: params.type,\n\t\t\t\t\t\troomId: params.roomId,\n\t\t\t\t\t\tentityId: params.entityId,\n\t\t\t\t\t\terror: error instanceof Error ? error.message : String(error),\n\t\t\t\t\t},\n\t\t\t\t\t\"Failed to create log entry\",\n\t\t\t\t);\n\t\t\t\tthrow error;\n\t\t\t}\n\t\t});\n\t}\n\n\t/**\n\t * Sanitizes a JSON object by replacing problematic Unicode escape sequences\n\t * that could cause errors during JSON serialization/storage\n\t *\n\t * @param value - The value to sanitize\n\t * @returns The sanitized value\n\t */\n\tprivate sanitizeJsonObject(\n\t\tvalue: unknown,\n\t\tseen: WeakSet<object> = new WeakSet(),\n\t): unknown {\n\t\tif (value === null || value === undefined) {\n\t\t\treturn value;\n\t\t}\n\n\t\tif (typeof value === \"string\") {\n\t\t\t// Handle multiple cases that can cause PostgreSQL/PgLite JSON parsing errors:\n\t\t\t// 1. Remove null bytes (U+0000) which are not allowed in PostgreSQL text fields\n\t\t\t// 2. Escape single backslashes that might be interpreted as escape sequences\n\t\t\t// 3. Fix broken Unicode escape sequences (\\u not followed by 4 hex digits)\n\t\t\tconst nullChar = String.fromCharCode(0);\n\t\t\tconst nullCharRegex = new RegExp(nullChar, \"g\");\n\t\t\treturn value\n\t\t\t\t.replace(nullCharRegex, \"\") // Remove null bytes\n\t\t\t\t.replace(/\\\\(?![\"\\\\/bfnrtu])/g, \"\\\\\\\\\") // Escape single backslashes not part of valid escape sequences\n\t\t\t\t.replace(/\\\\u(?![0-9a-fA-F]{4})/g, \"\\\\\\\\u\"); // Fix malformed Unicode escape sequences\n\t\t}\n\n\t\tif (typeof value === \"object\") {\n\t\t\tif (seen.has(value as object)) {\n\t\t\t\treturn null;\n\t\t\t} else {\n\t\t\t\tseen.add(value as object);\n\t\t\t}\n\n\t\t\tif (Array.isArray(value)) {\n\t\t\t\treturn value.map((item) => this.sanitizeJsonObject(item, seen));\n\t\t\t} else {\n\t\t\t\tconst result: Record<string, unknown> = {};\n\t\t\t\tconst nullChar = String.fromCharCode(0);\n\t\t\t\tconst nullCharRegex = new RegExp(nullChar, \"g\");\n\t\t\t\tfor (const [key, val] of Object.entries(value)) {\n\t\t\t\t\t// Also sanitize object keys\n\t\t\t\t\tconst sanitizedKey =\n\t\t\t\t\t\ttypeof key === \"string\"\n\t\t\t\t\t\t\t? key\n\t\t\t\t\t\t\t\t\t.replace(nullCharRegex, \"\")\n\t\t\t\t\t\t\t\t\t.replace(/\\\\u(?![0-9a-fA-F]{4})/g, \"\\\\\\\\u\")\n\t\t\t\t\t\t\t: key;\n\t\t\t\t\tresult[sanitizedKey] = this.sanitizeJsonObject(val, seen);\n\t\t\t\t}\n\t\t\t\treturn result;\n\t\t\t}\n\t\t}\n\n\t\treturn value;\n\t}\n\n\t/**\n\t * Asynchronously retrieves logs from the database based on the provided parameters.\n\t * @param {Object} params - The parameters for retrieving logs.\n\t * @param {UUID} params.entityId - The ID of the entity associated with the logs.\n\t * @param {UUID} [params.roomId] - The ID of the room associated with the logs.\n\t * @param {string} [params.type] - The type of the logs to retrieve.\n\t * @param {number} [params.count] - The maximum number of logs to retrieve.\n\t * @param {number} [params.offset] - The offset to retrieve logs from.\n\t * @returns {Promise<Log[]>} A Promise that resolves to an array of logs.\n\t */\n\tasync getLogs(params: {\n\t\tentityId?: UUID;\n\t\troomId?: UUID;\n\t\ttype?: string;\n\t\tcount?: number;\n\t\toffset?: number;\n\t}): Promise<Log[]> {\n\t\tconst { entityId, roomId, type, count, offset } = params;\n\n\t\t// Use withEntityContext for RLS only when entityId is provided\n\t\t// Without entityId, bypass RLS to see all logs (for non-RLS mode)\n\t\treturn this.withEntityContext(entityId ?? null, async (tx) => {\n\t\t\tconst result = await tx\n\t\t\t\t.select()\n\t\t\t\t.from(logTable)\n\t\t\t\t.where(\n\t\t\t\t\tand(\n\t\t\t\t\t\troomId ? eq(logTable.roomId, roomId) : undefined,\n\t\t\t\t\t\ttype ? eq(logTable.type, type) : undefined,\n\t\t\t\t\t),\n\t\t\t\t)\n\t\t\t\t.orderBy(desc(logTable.createdAt))\n\t\t\t\t.limit(count ?? 10)\n\t\t\t\t.offset(offset ?? 0);\n\n\t\t\tconst logs = result.map((log) => ({\n\t\t\t\t...log,\n\t\t\t\tid: log.id as UUID,\n\t\t\t\tentityId: log.entityId as UUID,\n\t\t\t\troomId: log.roomId as UUID,\n\t\t\t\ttype: log.type as string,\n\t\t\t\tbody: log.body as LogBody,\n\t\t\t\tcreatedAt: new Date(log.createdAt as string | number | Date),\n\t\t\t}));\n\n\t\t\tif (logs.length === 0) return [];\n\n\t\t\treturn logs;\n\t\t});\n\t}\n\n\tasync getAgentRunSummaries(\n\t\tparams: {\n\t\t\tlimit?: number;\n\t\t\troomId?: UUID;\n\t\t\tstatus?: RunStatus | \"all\";\n\t\t\tfrom?: number;\n\t\t\tto?: number;\n\t\t\tentityId?: UUID;\n\t\t} = {},\n\t): Promise<AgentRunSummaryResult> {\n\t\tconst limit = Math.min(Math.max(params.limit ?? 20, 1), 100);\n\t\tconst fromDate =\n\t\t\ttypeof params.from === \"number\" ? new Date(params.from) : undefined;\n\t\tconst toDate =\n\t\t\ttypeof params.to === \"number\" ? new Date(params.to) : undefined;\n\n\t\t// Use withEntityContext for RLS when entityId is provided\n\t\treturn this.withEntityContext(params.entityId ?? null, async (tx) => {\n\t\t\tconst runMap = new Map<string, AgentRunSummary>();\n\n\t\t\tconst conditions: SQL<unknown>[] = [\n\t\t\t\teq(logTable.type, \"run_event\"),\n\t\t\t\tsql`${logTable.body} ? 'runId'`,\n\t\t\t\teq(roomTable.agentId, this.agentId),\n\t\t\t];\n\n\t\t\tif (params.roomId) {\n\t\t\t\tconditions.push(eq(logTable.roomId, params.roomId));\n\t\t\t}\n\t\t\tif (fromDate) {\n\t\t\t\tconditions.push(gte(logTable.createdAt, fromDate));\n\t\t\t}\n\t\t\tif (toDate) {\n\t\t\t\tconditions.push(lte(logTable.createdAt, toDate));\n\t\t\t}\n\n\t\t\tconst whereClause = and(...conditions);\n\n\t\t\tconst eventLimit = Math.max(limit * 20, 200);\n\n\t\t\tconst runEventRows = await tx\n\t\t\t\t.select({\n\t\t\t\t\trunId: sql<string>`(${logTable.body} ->> 'runId')`,\n\t\t\t\t\tstatus: sql<string | null>`(${logTable.body} ->> 'status')`,\n\t\t\t\t\tmessageId: sql<string | null>`(${logTable.body} ->> 'messageId')`,\n\t\t\t\t\trawBody: logTable.body,\n\t\t\t\t\tcreatedAt: logTable.createdAt,\n\t\t\t\t\troomId: logTable.roomId,\n\t\t\t\t\tentityId: logTable.entityId,\n\t\t\t\t})\n\t\t\t\t.from(logTable)\n\t\t\t\t.innerJoin(roomTable, eq(roomTable.id, logTable.roomId))\n\t\t\t\t.where(whereClause)\n\t\t\t\t.orderBy(desc(logTable.createdAt))\n\t\t\t\t.limit(eventLimit);\n\n\t\t\tfor (const row of runEventRows) {\n\t\t\t\tconst runId = row.runId;\n\t\t\t\tif (!runId) continue;\n\n\t\t\t\tconst summary: AgentRunSummary = runMap.get(runId) ?? {\n\t\t\t\t\trunId,\n\t\t\t\t\tstatus: \"started\",\n\t\t\t\t\tstartedAt: null,\n\t\t\t\t\tendedAt: null,\n\t\t\t\t\tdurationMs: null,\n\t\t\t\t\tmessageId: undefined,\n\t\t\t\t\troomId: undefined,\n\t\t\t\t\tentityId: undefined,\n\t\t\t\t\tmetadata: {},\n\t\t\t\t};\n\n\t\t\t\tif (!summary.messageId && row.messageId) {\n\t\t\t\t\tsummary.messageId = row.messageId as UUID;\n\t\t\t\t}\n\t\t\t\tif (!summary.roomId && row.roomId) {\n\t\t\t\t\tsummary.roomId = row.roomId as UUID;\n\t\t\t\t}\n\t\t\t\tif (!summary.entityId && row.entityId) {\n\t\t\t\t\tsummary.entityId = row.entityId as UUID;\n\t\t\t\t}\n\n\t\t\t\tconst body = row.rawBody as Record<string, unknown> | undefined;\n\t\t\t\tif (body && typeof body === \"object\") {\n\t\t\t\t\tif (!summary.roomId && typeof body.roomId === \"string\") {\n\t\t\t\t\t\tsummary.roomId = body.roomId as UUID;\n\t\t\t\t\t}\n\t\t\t\t\tif (!summary.entityId && typeof body.entityId === \"string\") {\n\t\t\t\t\t\tsummary.entityId = body.entityId as UUID;\n\t\t\t\t\t}\n\t\t\t\t\tif (!summary.messageId && typeof body.messageId === \"string\") {\n\t\t\t\t\t\tsummary.messageId = body.messageId as UUID;\n\t\t\t\t\t}\n\t\t\t\t\tif (!summary.metadata || Object.keys(summary.metadata).length === 0) {\n\t\t\t\t\t\tconst metadata =\n\t\t\t\t\t\t\t(body.metadata as Record<string, unknown> | undefined) ??\n\t\t\t\t\t\t\tundefined;\n\t\t\t\t\t\tsummary.metadata = metadata\n\t\t\t\t\t\t\t? ({ ...metadata } as Record<string, JsonValue>)\n\t\t\t\t\t\t\t: {};\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\tconst createdAt =\n\t\t\t\t\trow.createdAt instanceof Date\n\t\t\t\t\t\t? row.createdAt\n\t\t\t\t\t\t: new Date(row.createdAt);\n\t\t\t\tconst timestamp = createdAt.getTime();\n\t\t\t\tconst bodyStatus = body?.status;\n\t\t\t\tconst eventStatus =\n\t\t\t\t\t(row.status as RunStatus | undefined) ??\n\t\t\t\t\t(bodyStatus as RunStatus | undefined);\n\n\t\t\t\tif (eventStatus === \"started\") {\n\t\t\t\t\tconst currentStartedAt =\n\t\t\t\t\t\tsummary.startedAt === null\n\t\t\t\t\t\t\t? null\n\t\t\t\t\t\t\t: typeof summary.startedAt === \"bigint\"\n\t\t\t\t\t\t\t\t? Number(summary.startedAt)\n\t\t\t\t\t\t\t\t: summary.startedAt;\n\t\t\t\t\tsummary.startedAt =\n\t\t\t\t\t\tcurrentStartedAt === null\n\t\t\t\t\t\t\t? timestamp\n\t\t\t\t\t\t\t: Math.min(currentStartedAt, timestamp);\n\t\t\t\t} else if (\n\t\t\t\t\teventStatus === \"completed\" ||\n\t\t\t\t\teventStatus === \"timeout\" ||\n\t\t\t\t\teventStatus === \"error\"\n\t\t\t\t) {\n\t\t\t\t\tsummary.status = eventStatus;\n\t\t\t\t\tsummary.endedAt = timestamp;\n\t\t\t\t\tif (summary.startedAt !== null) {\n\t\t\t\t\t\tconst startedAtNum =\n\t\t\t\t\t\t\ttypeof summary.startedAt === \"bigint\"\n\t\t\t\t\t\t\t\t? Number(summary.startedAt)\n\t\t\t\t\t\t\t\t: summary.startedAt;\n\t\t\t\t\t\tsummary.durationMs = Math.max(timestamp - startedAtNum, 0);\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\trunMap.set(runId, summary);\n\t\t\t}\n\n\t\t\tlet runs = Array.from(runMap.values());\n\t\t\tif (params.status && params.status !== \"all\") {\n\t\t\t\truns = runs.filter((run) => run.status === params.status);\n\t\t\t}\n\n\t\t\truns.sort((a, b) => {\n\t\t\t\tconst aStarted =\n\t\t\t\t\ta.startedAt === null\n\t\t\t\t\t\t? 0\n\t\t\t\t\t\t: typeof a.startedAt === \"bigint\"\n\t\t\t\t\t\t\t? Number(a.startedAt)\n\t\t\t\t\t\t\t: a.startedAt;\n\t\t\t\tconst bStarted =\n\t\t\t\t\tb.startedAt === null\n\t\t\t\t\t\t? 0\n\t\t\t\t\t\t: typeof b.startedAt === \"bigint\"\n\t\t\t\t\t\t\t? Number(b.startedAt)\n\t\t\t\t\t\t\t: b.startedAt;\n\t\t\t\treturn bStarted - aStarted;\n\t\t\t});\n\n\t\t\tconst total = runs.length;\n\t\t\tconst limitedRuns = runs.slice(0, limit);\n\t\t\tconst hasMore = total > limit;\n\n\t\t\tconst runCounts = new Map<string, AgentRunCounts>();\n\t\t\tfor (const run of limitedRuns) {\n\t\t\t\trunCounts.set(run.runId, {\n\t\t\t\t\tactions: 0,\n\t\t\t\t\tmodelCalls: 0,\n\t\t\t\t\terrors: 0,\n\t\t\t\t\tevaluators: 0,\n\t\t\t\t});\n\t\t\t}\n\n\t\t\tconst runIds = limitedRuns.map((run) => run.runId).filter(Boolean);\n\n\t\t\tif (runIds.length > 0) {\n\t\t\t\tconst runIdArray = sql`array[${sql.join(\n\t\t\t\t\trunIds.map((id) => sql`${id}`),\n\t\t\t\t\tsql`, `,\n\t\t\t\t)}]::text[]`;\n\n\t\t\t\tconst actionSummary = await this.db.execute(sql`\n SELECT\n body->>'runId' as \"runId\",\n COUNT(*)::int as \"actions\",\n SUM(CASE WHEN COALESCE(body->'result'->>'success', 'true') = 'false' THEN 1 ELSE 0 END)::int as \"errors\",\n SUM(COALESCE((body->>'promptCount')::int, 0))::int as \"modelCalls\"\n FROM ${logTable}\n WHERE type = 'action'\n AND body->>'runId' = ANY(${runIdArray})\n GROUP BY body->>'runId'\n `);\n\n\t\t\t\tconst actionRows = (actionSummary.rows ?? []) as Array<{\n\t\t\t\t\trunId: string;\n\t\t\t\t\tactions: number | string;\n\t\t\t\t\terrors: number | string;\n\t\t\t\t\tmodelCalls: number | string;\n\t\t\t\t}>;\n\n\t\t\t\tfor (const row of actionRows) {\n\t\t\t\t\tconst counts = runCounts.get(row.runId);\n\t\t\t\t\tif (!counts) continue;\n\t\t\t\t\tcounts.actions += Number(row.actions ?? 0);\n\t\t\t\t\tcounts.errors += Number(row.errors ?? 0);\n\t\t\t\t\tcounts.modelCalls += Number(row.modelCalls ?? 0);\n\t\t\t\t}\n\n\t\t\t\tconst evaluatorSummary = await this.db.execute(sql`\n SELECT\n body->>'runId' as \"runId\",\n COUNT(*)::int as \"evaluators\"\n FROM ${logTable}\n WHERE type = 'evaluator'\n AND body->>'runId' = ANY(${runIdArray})\n GROUP BY body->>'runId'\n `);\n\n\t\t\t\tconst evaluatorRows = (evaluatorSummary.rows ?? []) as Array<{\n\t\t\t\t\trunId: string;\n\t\t\t\t\tevaluators: number | string;\n\t\t\t\t}>;\n\n\t\t\t\tfor (const row of evaluatorRows) {\n\t\t\t\t\tconst counts = runCounts.get(row.runId);\n\t\t\t\t\tif (!counts) continue;\n\t\t\t\t\tcounts.evaluators += Number(row.evaluators ?? 0);\n\t\t\t\t}\n\n\t\t\t\tconst genericSummary = await this.db.execute(sql`\n SELECT\n body->>'runId' as \"runId\",\n COUNT(*) FILTER (WHERE type LIKE 'useModel:%')::int as \"modelLogs\",\n COUNT(*) FILTER (WHERE type = 'embedding_event' AND body->>'status' = 'failed')::int as \"embeddingErrors\"\n FROM ${logTable}\n WHERE (type LIKE 'useModel:%' OR type = 'embedding_event')\n AND body->>'runId' = ANY(${runIdArray})\n GROUP BY body->>'runId'\n `);\n\n\t\t\t\tconst genericRows = (genericSummary.rows ?? []) as Array<{\n\t\t\t\t\trunId: string;\n\t\t\t\t\tmodelLogs: number | string;\n\t\t\t\t\tembeddingErrors: number | string;\n\t\t\t\t}>;\n\n\t\t\t\tfor (const row of genericRows) {\n\t\t\t\t\tconst counts = runCounts.get(row.runId);\n\t\t\t\t\tif (!counts) continue;\n\t\t\t\t\tcounts.modelCalls += Number(row.modelLogs ?? 0);\n\t\t\t\t\tcounts.errors += Number(row.embeddingErrors ?? 0);\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tfor (const run of limitedRuns) {\n\t\t\t\tconst counts = runCounts.get(run.runId) ?? {\n\t\t\t\t\tactions: 0,\n\t\t\t\t\tmodelCalls: 0,\n\t\t\t\t\terrors: 0,\n\t\t\t\t\tevaluators: 0,\n\t\t\t\t};\n\t\t\t\t// Cast through unknown to bridge the core type (without $typeName) to proto type (with $typeName)\n\t\t\t\trun.counts = counts as unknown as typeof run.counts;\n\t\t\t}\n\n\t\t\treturn {\n\t\t\t\truns: limitedRuns as unknown as import(\"@elizaos/core\").AgentRunSummary[],\n\t\t\t\ttotal,\n\t\t\t\thasMore,\n\t\t\t} as AgentRunSummaryResult;\n\t\t});\n\t}\n\n\t/**\n\t * Asynchronously deletes a log from the database based on the provided parameters.\n\t * @param {UUID} logId - The ID of the log to delete.\n\t * @returns {Promise<void>} A Promise that resolves when the log is deleted.\n\t */\n\tasync deleteLog(logId: UUID): Promise<void> {\n\t\treturn this.withDatabase(async () => {\n\t\t\tawait this.db.delete(logTable).where(eq(logTable.id, logId));\n\t\t});\n\t}\n\n\t/**\n\t * Asynchronously searches for memories in the database based on the provided parameters.\n\t * @param {Object} params - The parameters for searching for memories.\n\t * @param {string} params.tableName - The name of the table to search for memories in.\n\t * @param {number[]} params.embedding - The embedding to search for.\n\t * @param {number} [params.match_threshold] - The threshold for the cosine distance.\n\t * @param {number} [params.count] - The maximum number of memories to retrieve.\n\t * @param {boolean} [params.unique] - Whether to retrieve unique memories only.\n\t * @param {string} [params.query] - Optional query string for potential reranking.\n\t * @param {UUID} [params.roomId] - Optional room ID to filter by.\n\t * @param {UUID} [params.worldId] - Optional world ID to filter by.\n\t * @param {UUID} [params.entityId] - Optional entity ID to filter by.\n\t * @returns {Promise<Memory[]>} A Promise that resolves to an array of memories.\n\t */\n\tasync searchMemories(params: {\n\t\ttableName: string;\n\t\tembedding: number[];\n\t\tmatch_threshold?: number;\n\t\tcount?: number;\n\t\tunique?: boolean;\n\t\tquery?: string;\n\t\troomId?: UUID;\n\t\tworldId?: UUID;\n\t\tentityId?: UUID;\n\t}): Promise<Memory[]> {\n\t\treturn await this.searchMemoriesByEmbedding(params.embedding, {\n\t\t\tmatch_threshold: params.match_threshold,\n\t\t\tcount: params.count,\n\t\t\t// Pass direct scope fields down\n\t\t\troomId: params.roomId,\n\t\t\tworldId: params.worldId,\n\t\t\tentityId: params.entityId,\n\t\t\tunique: params.unique,\n\t\t\ttableName: params.tableName,\n\t\t});\n\t}\n\n\t/**\n\t * Asynchronously searches for memories in the database based on the provided parameters.\n\t * @param {number[]} embedding - The embedding to search for.\n\t * @param {Object} params - The parameters for searching for memories.\n\t * @param {number} [params.match_threshold] - The threshold for the cosine distance.\n\t * @param {number} [params.count] - The maximum number of memories to retrieve.\n\t * @param {UUID} [params.roomId] - Optional room ID to filter by.\n\t * @param {UUID} [params.worldId] - Optional world ID to filter by.\n\t * @param {UUID} [params.entityId] - Optional entity ID to filter by.\n\t * @param {boolean} [params.unique] - Whether to retrieve unique memories only.\n\t * @param {string} [params.tableName] - The name of the table to search for memories in.\n\t * @returns {Promise<Memory[]>} A Promise that resolves to an array of memories.\n\t */\n\tasync searchMemoriesByEmbedding(\n\t\tembedding: number[],\n\t\tparams: {\n\t\t\tmatch_threshold?: number;\n\t\t\tcount?: number;\n\t\t\troomId?: UUID;\n\t\t\tworldId?: UUID;\n\t\t\tentityId?: UUID;\n\t\t\tunique?: boolean;\n\t\t\ttableName: string;\n\t\t},\n\t): Promise<Memory[]> {\n\t\treturn this.withDatabase(async () => {\n\t\t\tconst cleanVector = embedding.map((n) =>\n\t\t\t\tNumber.isFinite(n) ? Number(n.toFixed(6)) : 0,\n\t\t\t);\n\n\t\t\tconst similarity = sql<number>`1 - (${cosineDistance(\n\t\t\t\tembeddingTable[this.embeddingDimension],\n\t\t\t\tcleanVector,\n\t\t\t)})`;\n\n\t\t\tconst conditions = [eq(memoryTable.type, params.tableName)];\n\n\t\t\tif (params.unique) {\n\t\t\t\tconditions.push(eq(memoryTable.unique, true));\n\t\t\t}\n\n\t\t\tconditions.push(eq(memoryTable.agentId, this.agentId));\n\n\t\t\t// Add filters based on direct params\n\t\t\tif (params.roomId) {\n\t\t\t\tconditions.push(eq(memoryTable.roomId, params.roomId));\n\t\t\t}\n\t\t\tif (params.worldId) {\n\t\t\t\tconditions.push(eq(memoryTable.worldId, params.worldId));\n\t\t\t}\n\t\t\tif (params.entityId) {\n\t\t\t\tconditions.push(eq(memoryTable.entityId, params.entityId));\n\t\t\t}\n\n\t\t\tif (params.match_threshold) {\n\t\t\t\tconditions.push(gte(similarity, params.match_threshold));\n\t\t\t}\n\n\t\t\tconst results = await this.db\n\t\t\t\t.select({\n\t\t\t\t\tmemory: memoryTable,\n\t\t\t\t\tsimilarity,\n\t\t\t\t\tembedding: embeddingTable[this.embeddingDimension],\n\t\t\t\t})\n\t\t\t\t.from(embeddingTable)\n\t\t\t\t.innerJoin(memoryTable, eq(memoryTable.id, embeddingTable.memoryId))\n\t\t\t\t.where(and(...conditions))\n\t\t\t\t.orderBy(desc(similarity))\n\t\t\t\t.limit(params.count ?? 10);\n\n\t\t\treturn results.map((row) => ({\n\t\t\t\tid: row.memory.id as UUID,\n\t\t\t\ttype: row.memory.type,\n\t\t\t\tcreatedAt: row.memory.createdAt.getTime(),\n\t\t\t\tcontent:\n\t\t\t\t\ttypeof row.memory.content === \"string\"\n\t\t\t\t\t\t? JSON.parse(row.memory.content)\n\t\t\t\t\t\t: row.memory.content,\n\t\t\t\tentityId: row.memory.entityId as UUID,\n\t\t\t\tagentId: row.memory.agentId as UUID,\n\t\t\t\troomId: row.memory.roomId as UUID,\n\t\t\t\tworldId: row.memory.worldId as UUID | undefined, // Include worldId\n\t\t\t\tunique: row.memory.unique,\n\t\t\t\tmetadata: row.memory.metadata as MemoryMetadata,\n\t\t\t\tembedding: row.embedding ?? undefined,\n\t\t\t\tsimilarity: row.similarity,\n\t\t\t}));\n\t\t});\n\t}\n\n\t/**\n\t * Asynchronously creates a new memory in the database.\n\t * @param {Memory & { metadata?: MemoryMetadata }} memory - The memory object to create.\n\t * @param {string} tableName - The name of the table to create the memory in.\n\t * @returns {Promise<UUID>} A Promise that resolves to the ID of the created memory.\n\t */\n\tasync createMemory(\n\t\tmemory: Memory & { metadata?: MemoryMetadata },\n\t\ttableName: string,\n\t): Promise<UUID> {\n\t\tconst memoryId = memory.id ?? (v4() as UUID);\n\n\t\tconst existing = await this.getMemoryById(memoryId);\n\t\tif (existing) {\n\t\t\treturn memoryId;\n\t\t}\n\n\t\t// only do costly check if we need to\n\t\tif (memory.unique === undefined) {\n\t\t\tmemory.unique = true; // set default\n\t\t\tif (memory.embedding && Array.isArray(memory.embedding)) {\n\t\t\t\tconst similarMemories = await this.searchMemoriesByEmbedding(\n\t\t\t\t\tmemory.embedding,\n\t\t\t\t\t{\n\t\t\t\t\t\ttableName,\n\t\t\t\t\t\t// Use the scope fields from the memory object for similarity check\n\t\t\t\t\t\troomId: memory.roomId,\n\t\t\t\t\t\tworldId: memory.worldId,\n\t\t\t\t\t\tentityId: memory.entityId,\n\t\t\t\t\t\tmatch_threshold: 0.95,\n\t\t\t\t\t\tcount: 1,\n\t\t\t\t\t},\n\t\t\t\t);\n\t\t\t\tmemory.unique = similarMemories.length === 0;\n\t\t\t}\n\t\t}\n\n\t\t// Ensure we always pass a JSON string to the SQL placeholder – if we pass an\n\t\t// object directly PG sees `[object Object]` and fails the `::jsonb` cast.\n\t\tconst contentToInsert =\n\t\t\ttypeof memory.content === \"string\"\n\t\t\t\t? memory.content\n\t\t\t\t: JSON.stringify(memory.content ?? {});\n\n\t\tconst metadataToInsert =\n\t\t\ttypeof memory.metadata === \"string\"\n\t\t\t\t? memory.metadata\n\t\t\t\t: JSON.stringify(memory.metadata ?? {});\n\n\t\t// Use withEntityContext to set Entity RLS context if needed\n\t\t// This delegates to the concrete adapter implementation (PostgreSQL or PGLite)\n\t\tawait this.withEntityContext(memory.entityId, async (tx) => {\n\t\t\tawait tx.insert(memoryTable).values([\n\t\t\t\t{\n\t\t\t\t\tid: memoryId,\n\t\t\t\t\ttype: tableName,\n\t\t\t\t\tcontent: sql`${contentToInsert}::jsonb`,\n\t\t\t\t\tmetadata: sql`${metadataToInsert}::jsonb`,\n\t\t\t\t\tentityId: memory.entityId,\n\t\t\t\t\troomId: memory.roomId,\n\t\t\t\t\tworldId: memory.worldId, // Include worldId\n\t\t\t\t\tagentId: memory.agentId || this.agentId,\n\t\t\t\t\tunique: memory.unique,\n\t\t\t\t\tcreatedAt: memory.createdAt ? new Date(memory.createdAt) : new Date(),\n\t\t\t\t},\n\t\t\t]);\n\n\t\t\tif (memory.embedding && Array.isArray(memory.embedding)) {\n\t\t\t\tconst embeddingValues: Record<string, unknown> = {\n\t\t\t\t\tid: v4(),\n\t\t\t\t\tmemoryId: memoryId,\n\t\t\t\t\tcreatedAt: memory.createdAt ? new Date(memory.createdAt) : new Date(),\n\t\t\t\t};\n\n\t\t\t\tconst cleanVector = memory.embedding.map((n) =>\n\t\t\t\t\tNumber.isFinite(n) ? Number(n.toFixed(6)) : 0,\n\t\t\t\t);\n\n\t\t\t\tembeddingValues[this.embeddingDimension] = cleanVector;\n\n\t\t\t\tawait tx.insert(embeddingTable).values([embeddingValues]);\n\t\t\t}\n\t\t});\n\n\t\treturn memoryId;\n\t}\n\n\t/**\n\t * Updates an existing memory in the database.\n\t * @param memory The memory object with updated content and optional embedding\n\t * @returns Promise resolving to boolean indicating success\n\t */\n\tasync updateMemory(\n\t\tmemory: Partial<Memory> & { id: UUID; metadata?: MemoryMetadata },\n\t): Promise<boolean> {\n\t\treturn this.withDatabase(async () => {\n\t\t\ttry {\n\t\t\t\tawait this.db.transaction(async (tx) => {\n\t\t\t\t\t// Update memory content if provided\n\t\t\t\t\tif (memory.content) {\n\t\t\t\t\t\tconst contentToUpdate =\n\t\t\t\t\t\t\ttypeof memory.content === \"string\"\n\t\t\t\t\t\t\t\t? memory.content\n\t\t\t\t\t\t\t\t: JSON.stringify(memory.content ?? {});\n\n\t\t\t\t\t\tconst metadataToUpdate =\n\t\t\t\t\t\t\ttypeof memory.metadata === \"string\"\n\t\t\t\t\t\t\t\t? memory.metadata\n\t\t\t\t\t\t\t\t: JSON.stringify(memory.metadata ?? {});\n\n\t\t\t\t\t\tawait tx\n\t\t\t\t\t\t\t.update(memoryTable)\n\t\t\t\t\t\t\t.set({\n\t\t\t\t\t\t\t\tcontent: sql`${contentToUpdate}::jsonb`,\n\t\t\t\t\t\t\t\t...(memory.metadata && {\n\t\t\t\t\t\t\t\t\tmetadata: sql`${metadataToUpdate}::jsonb`,\n\t\t\t\t\t\t\t\t}),\n\t\t\t\t\t\t\t})\n\t\t\t\t\t\t\t.where(eq(memoryTable.id, memory.id));\n\t\t\t\t\t} else if (memory.metadata) {\n\t\t\t\t\t\t// Update only metadata if content is not provided\n\t\t\t\t\t\tconst metadataToUpdate =\n\t\t\t\t\t\t\ttypeof memory.metadata === \"string\"\n\t\t\t\t\t\t\t\t? memory.metadata\n\t\t\t\t\t\t\t\t: JSON.stringify(memory.metadata ?? {});\n\n\t\t\t\t\t\tawait tx\n\t\t\t\t\t\t\t.update(memoryTable)\n\t\t\t\t\t\t\t.set({\n\t\t\t\t\t\t\t\tmetadata: sql`${metadataToUpdate}::jsonb`,\n\t\t\t\t\t\t\t})\n\t\t\t\t\t\t\t.where(eq(memoryTable.id, memory.id));\n\t\t\t\t\t}\n\n\t\t\t\t\t// Update embedding if provided\n\t\t\t\t\tif (memory.embedding && Array.isArray(memory.embedding)) {\n\t\t\t\t\t\tconst cleanVector = memory.embedding.map((n) =>\n\t\t\t\t\t\t\tNumber.isFinite(n) ? Number(n.toFixed(6)) : 0,\n\t\t\t\t\t\t);\n\n\t\t\t\t\t\t// Check if embedding exists\n\t\t\t\t\t\tconst existingEmbedding = await tx\n\t\t\t\t\t\t\t.select({ id: embeddingTable.id })\n\t\t\t\t\t\t\t.from(embeddingTable)\n\t\t\t\t\t\t\t.where(eq(embeddingTable.memoryId, memory.id))\n\t\t\t\t\t\t\t.limit(1);\n\n\t\t\t\t\t\tif (existingEmbedding.length > 0) {\n\t\t\t\t\t\t\t// Update existing embedding\n\t\t\t\t\t\t\tconst updateValues: Record<string, unknown> = {};\n\t\t\t\t\t\t\tupdateValues[this.embeddingDimension] = cleanVector;\n\n\t\t\t\t\t\t\tawait tx\n\t\t\t\t\t\t\t\t.update(embeddingTable)\n\t\t\t\t\t\t\t\t.set(updateValues)\n\t\t\t\t\t\t\t\t.where(eq(embeddingTable.memoryId, memory.id));\n\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\t// Create new embedding\n\t\t\t\t\t\t\tconst embeddingValues: Record<string, unknown> = {\n\t\t\t\t\t\t\t\tid: v4(),\n\t\t\t\t\t\t\t\tmemoryId: memory.id,\n\t\t\t\t\t\t\t};\n\t\t\t\t\t\t\tembeddingValues[this.embeddingDimension] = cleanVector;\n\n\t\t\t\t\t\t\tawait tx.insert(embeddingTable).values([embeddingValues]);\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t});\n\n\t\t\t\treturn true;\n\t\t\t} catch (error) {\n\t\t\t\tlogger.error(\n\t\t\t\t\t{\n\t\t\t\t\t\tsrc: \"plugin:sql\",\n\t\t\t\t\t\tmemoryId: memory.id,\n\t\t\t\t\t\terror: error instanceof Error ? error.message : String(error),\n\t\t\t\t\t},\n\t\t\t\t\t\"Failed to update memory\",\n\t\t\t\t);\n\t\t\t\treturn false;\n\t\t\t}\n\t\t});\n\t}\n\n\t/**\n\t * Asynchronously deletes a memory from the database based on the provided parameters.\n\t * @param {UUID} memoryId - The ID of the memory to delete.\n\t * @returns {Promise<void>} A Promise that resolves when the memory is deleted.\n\t */\n\tasync deleteMemory(memoryId: UUID): Promise<void> {\n\t\treturn this.withDatabase(async () => {\n\t\t\tawait this.db.transaction(async (tx) => {\n\t\t\t\t// See if there are any fragments that we need to delete\n\t\t\t\tawait this.deleteMemoryFragments(tx, memoryId);\n\n\t\t\t\t// Then delete the embedding for the main memory\n\t\t\t\tawait tx\n\t\t\t\t\t.delete(embeddingTable)\n\t\t\t\t\t.where(eq(embeddingTable.memoryId, memoryId));\n\n\t\t\t\t// Finally delete the memory itself\n\t\t\t\tawait tx.delete(memoryTable).where(eq(memoryTable.id, memoryId));\n\t\t\t});\n\t\t});\n\t}\n\n\t/**\n\t * Asynchronously deletes multiple memories from the database in a single batch operation.\n\t * @param {UUID[]} memoryIds - An array of UUIDs of the memories to delete.\n\t * @returns {Promise<void>} A Promise that resolves when all memories are deleted.\n\t */\n\tasync deleteManyMemories(memoryIds: UUID[]): Promise<void> {\n\t\tif (memoryIds.length === 0) {\n\t\t\treturn;\n\t\t}\n\n\t\treturn this.withDatabase(async () => {\n\t\t\tawait this.db.transaction(async (tx) => {\n\t\t\t\t// Process in smaller batches to avoid query size limits\n\t\t\t\tconst BATCH_SIZE = 100;\n\t\t\t\tfor (let i = 0; i < memoryIds.length; i += BATCH_SIZE) {\n\t\t\t\t\tconst batch = memoryIds.slice(i, i + BATCH_SIZE);\n\n\t\t\t\t\t// Delete any fragments for document memories in this batch\n\t\t\t\t\tawait Promise.all(\n\t\t\t\t\t\tbatch.map(async (memoryId) => {\n\t\t\t\t\t\t\tawait this.deleteMemoryFragments(tx, memoryId);\n\t\t\t\t\t\t}),\n\t\t\t\t\t);\n\n\t\t\t\t\t// Delete embeddings for the batch\n\t\t\t\t\tawait tx\n\t\t\t\t\t\t.delete(embeddingTable)\n\t\t\t\t\t\t.where(inArray(embeddingTable.memoryId, batch));\n\n\t\t\t\t\t// Delete the memories themselves\n\t\t\t\t\tawait tx.delete(memoryTable).where(inArray(memoryTable.id, batch));\n\t\t\t\t}\n\t\t\t});\n\t\t});\n\t}\n\n\t/**\n\t * Deletes all memory fragments that reference a specific document memory\n\t * @param tx The database transaction\n\t * @param documentId The UUID of the document memory whose fragments should be deleted\n\t * @private\n\t */\n\tprivate async deleteMemoryFragments(\n\t\ttx: DrizzleDatabase,\n\t\tdocumentId: UUID,\n\t): Promise<void> {\n\t\tconst fragmentsToDelete = await this.getMemoryFragments(tx, documentId);\n\n\t\tif (fragmentsToDelete.length > 0) {\n\t\t\tconst fragmentIds = fragmentsToDelete.map((f) => f.id) as UUID[];\n\n\t\t\t// Delete embeddings for fragments\n\t\t\tawait tx\n\t\t\t\t.delete(embeddingTable)\n\t\t\t\t.where(inArray(embeddingTable.memoryId, fragmentIds));\n\n\t\t\t// Delete the fragments\n\t\t\tawait tx.delete(memoryTable).where(inArray(memoryTable.id, fragmentIds));\n\t\t}\n\t}\n\n\t/**\n\t * Retrieves all memory fragments that reference a specific document memory\n\t * @param tx The database transaction\n\t * @param documentId The UUID of the document memory whose fragments should be retrieved\n\t * @returns An array of memory fragments\n\t * @private\n\t */\n\tprivate async getMemoryFragments(\n\t\ttx: DrizzleDatabase,\n\t\tdocumentId: UUID,\n\t): Promise<{ id: UUID }[]> {\n\t\tconst fragments = await tx\n\t\t\t.select({ id: memoryTable.id })\n\t\t\t.from(memoryTable)\n\t\t\t.where(\n\t\t\t\tand(\n\t\t\t\t\teq(memoryTable.agentId, this.agentId),\n\t\t\t\t\tsql`${memoryTable.metadata}->>'documentId' = ${documentId}`,\n\t\t\t\t),\n\t\t\t);\n\n\t\treturn fragments.map((f) => ({ id: f.id as UUID }));\n\t}\n\n\t/**\n\t * Asynchronously deletes all memories from the database based on the provided parameters.\n\t * @param {UUID} roomId - The ID of the room to delete memories from.\n\t * @param {string} tableName - The name of the table to delete memories from.\n\t * @returns {Promise<void>} A Promise that resolves when the memories are deleted.\n\t */\n\tasync deleteAllMemories(roomId: UUID, tableName: string): Promise<void> {\n\t\treturn this.withDatabase(async () => {\n\t\t\tawait this.db.transaction(async (tx) => {\n\t\t\t\t// 1) fetch all memory IDs for this room + table\n\t\t\t\tconst rows = await tx\n\t\t\t\t\t.select({ id: memoryTable.id })\n\t\t\t\t\t.from(memoryTable)\n\t\t\t\t\t.where(\n\t\t\t\t\t\tand(\n\t\t\t\t\t\t\teq(memoryTable.roomId, roomId),\n\t\t\t\t\t\t\teq(memoryTable.type, tableName),\n\t\t\t\t\t\t),\n\t\t\t\t\t);\n\n\t\t\t\tconst ids = rows.map((r) => r.id);\n\t\t\t\tlogger.debug(\n\t\t\t\t\t{ src: \"plugin:sql\", roomId, tableName, memoryCount: ids.length },\n\t\t\t\t\t\"Deleting all memories\",\n\t\t\t\t);\n\n\t\t\t\tif (ids.length === 0) {\n\t\t\t\t\treturn;\n\t\t\t\t}\n\n\t\t\t\t// 2) delete any fragments for \"document\" memories & their embeddings\n\t\t\t\tawait Promise.all(\n\t\t\t\t\tids.map(async (memoryId) => {\n\t\t\t\t\t\tawait this.deleteMemoryFragments(tx, memoryId);\n\t\t\t\t\t\tawait tx\n\t\t\t\t\t\t\t.delete(embeddingTable)\n\t\t\t\t\t\t\t.where(eq(embeddingTable.memoryId, memoryId));\n\t\t\t\t\t}),\n\t\t\t\t);\n\n\t\t\t\t// 3) delete the memories themselves\n\t\t\t\tawait tx\n\t\t\t\t\t.delete(memoryTable)\n\t\t\t\t\t.where(\n\t\t\t\t\t\tand(\n\t\t\t\t\t\t\teq(memoryTable.roomId, roomId),\n\t\t\t\t\t\t\teq(memoryTable.type, tableName),\n\t\t\t\t\t\t),\n\t\t\t\t\t);\n\t\t\t});\n\t\t});\n\t}\n\n\t/**\n\t * Asynchronously counts the number of memories in the database based on the provided parameters.\n\t * @param {UUID} roomId - The ID of the room to count memories in.\n\t * @param {boolean} [unique] - Whether to count unique memories only.\n\t * @param {string} [tableName] - The name of the table to count memories in.\n\t * @returns {Promise<number>} A Promise that resolves to the number of memories.\n\t */\n\tasync countMemories(\n\t\troomId: UUID,\n\t\tunique = true,\n\t\ttableName = \"\",\n\t): Promise<number> {\n\t\tif (!tableName) throw new Error(\"tableName is required\");\n\n\t\treturn this.withDatabase(async () => {\n\t\t\tconst conditions = [\n\t\t\t\teq(memoryTable.roomId, roomId),\n\t\t\t\teq(memoryTable.type, tableName),\n\t\t\t];\n\n\t\t\tif (unique) {\n\t\t\t\tconditions.push(eq(memoryTable.unique, true));\n\t\t\t}\n\n\t\t\tconst result = await this.db\n\t\t\t\t.select({ count: sql<number>`count(*)` })\n\t\t\t\t.from(memoryTable)\n\t\t\t\t.where(and(...conditions));\n\n\t\t\tconst result0 = result[0];\n\t\t\treturn Number(result0?.count ?? 0);\n\t\t});\n\t}\n\n\t/**\n\t * Asynchronously retrieves rooms from the database based on the provided parameters.\n\t * @param {UUID[]} roomIds - The IDs of the rooms to retrieve.\n\t * @returns {Promise<Room[] | null>} A Promise that resolves to the rooms if found, null otherwise.\n\t */\n\tasync getRoomsByIds(roomIds: UUID[]): Promise<Room[] | null> {\n\t\treturn this.withDatabase(async () => {\n\t\t\tconst result = await this.db\n\t\t\t\t.select({\n\t\t\t\t\tid: roomTable.id,\n\t\t\t\t\tname: roomTable.name, // Added name\n\t\t\t\t\tchannelId: roomTable.channelId,\n\t\t\t\t\tagentId: roomTable.agentId,\n\t\t\t\t\tmessageServerId: roomTable.messageServerId,\n\t\t\t\t\tworldId: roomTable.worldId,\n\t\t\t\t\ttype: roomTable.type,\n\t\t\t\t\tsource: roomTable.source,\n\t\t\t\t\tmetadata: roomTable.metadata, // Added metadata\n\t\t\t\t})\n\t\t\t\t.from(roomTable)\n\t\t\t\t.where(\n\t\t\t\t\tand(\n\t\t\t\t\t\tinArray(roomTable.id, roomIds),\n\t\t\t\t\t\teq(roomTable.agentId, this.agentId),\n\t\t\t\t\t),\n\t\t\t\t);\n\n\t\t\t// Map the result to properly typed Room objects\n\t\t\tconst rooms = result.map((room) => ({\n\t\t\t\t...room,\n\t\t\t\tid: room.id as UUID,\n\t\t\t\tname: room.name ?? undefined,\n\t\t\t\tagentId: room.agentId as UUID,\n\t\t\t\tmessageServerId: room.messageServerId as UUID,\n\t\t\t\tserverId: room.messageServerId as UUID, // Backward compatibility alias\n\t\t\t\tworldId: room.worldId as UUID,\n\t\t\t\tchannelId: room.channelId as UUID,\n\t\t\t\ttype: room.type as ChannelType,\n\t\t\t\tmetadata: room.metadata as Metadata,\n\t\t\t}));\n\n\t\t\treturn rooms;\n\t\t});\n\t}\n\n\t/**\n\t * Asynchronously retrieves all rooms from the database based on the provided parameters.\n\t * @param {UUID} worldId - The ID of the world to retrieve rooms from.\n\t * @returns {Promise<Room[]>} A Promise that resolves to an array of rooms.\n\t */\n\tasync getRoomsByWorld(worldId: UUID): Promise<Room[]> {\n\t\treturn this.withDatabase(async () => {\n\t\t\tconst result = await this.db\n\t\t\t\t.select()\n\t\t\t\t.from(roomTable)\n\t\t\t\t.where(eq(roomTable.worldId, worldId));\n\t\t\tconst rooms = result.map((room) => ({\n\t\t\t\t...room,\n\t\t\t\tid: room.id as UUID,\n\t\t\t\tname: room.name ?? undefined,\n\t\t\t\tagentId: room.agentId as UUID,\n\t\t\t\tmessageServerId: room.messageServerId as UUID,\n\t\t\t\tserverId: room.messageServerId as UUID, // Backward compatibility alias\n\t\t\t\tworldId: room.worldId as UUID,\n\t\t\t\tchannelId: room.channelId as UUID,\n\t\t\t\ttype: room.type as ChannelType,\n\t\t\t\tmetadata: room.metadata as Metadata,\n\t\t\t}));\n\t\t\treturn rooms;\n\t\t});\n\t}\n\n\t/**\n\t * Asynchronously updates a room in the database based on the provided parameters.\n\t * @param {Room} room - The room object to update.\n\t * @returns {Promise<void>} A Promise that resolves when the room is updated.\n\t */\n\tasync updateRoom(room: Room): Promise<void> {\n\t\treturn this.withDatabase(async () => {\n\t\t\tawait this.db\n\t\t\t\t.update(roomTable)\n\t\t\t\t.set({ ...room, agentId: this.agentId })\n\t\t\t\t.where(eq(roomTable.id, room.id));\n\t\t});\n\t}\n\n\t/**\n\t * Asynchronously creates a new room in the database based on the provided parameters.\n\t * @param {Room} room - The room object to create.\n\t * @returns {Promise<UUID>} A Promise that resolves to the ID of the created room.\n\t */\n\tasync createRooms(rooms: Room[]): Promise<UUID[]> {\n\t\treturn this.withDatabase(async () => {\n\t\t\tconst roomsWithIds = rooms.map((room) => ({\n\t\t\t\t...room,\n\t\t\t\tagentId: this.agentId,\n\t\t\t\tid: room.id || v4(), // ensure each room has a unique ID\n\t\t\t}));\n\n\t\t\tconst insertedRooms = await this.db\n\t\t\t\t.insert(roomTable)\n\t\t\t\t.values(roomsWithIds)\n\t\t\t\t.onConflictDoNothing()\n\t\t\t\t.returning();\n\t\t\tconst insertedIds = insertedRooms.map((r) => r.id as UUID);\n\t\t\treturn insertedIds;\n\t\t});\n\t}\n\n\t/**\n\t * Asynchronously deletes a room from the database based on the provided parameters.\n\t * @param {UUID} roomId - The ID of the room to delete.\n\t * @returns {Promise<void>} A Promise that resolves when the room is deleted.\n\t */\n\tasync deleteRoom(roomId: UUID): Promise<void> {\n\t\tif (!roomId) throw new Error(\"Room ID is required\");\n\t\treturn this.withDatabase(async () => {\n\t\t\tawait this.db.transaction(async (tx) => {\n\t\t\t\tawait tx.delete(roomTable).where(eq(roomTable.id, roomId));\n\t\t\t});\n\t\t});\n\t}\n\n\t/**\n\t * Asynchronously retrieves all rooms for a participant from the database based on the provided parameters.\n\t * @param {UUID} entityId - The ID of the entity to retrieve rooms for.\n\t * @returns {Promise<UUID[]>} A Promise that resolves to an array of room IDs.\n\t */\n\tasync getRoomsForParticipant(entityId: UUID): Promise<UUID[]> {\n\t\treturn this.withDatabase(async () => {\n\t\t\tconst result = await this.db\n\t\t\t\t.select({ roomId: participantTable.roomId })\n\t\t\t\t.from(participantTable)\n\t\t\t\t.innerJoin(roomTable, eq(participantTable.roomId, roomTable.id))\n\t\t\t\t.where(\n\t\t\t\t\tand(\n\t\t\t\t\t\teq(participantTable.entityId, entityId),\n\t\t\t\t\t\teq(roomTable.agentId, this.agentId),\n\t\t\t\t\t),\n\t\t\t\t);\n\n\t\t\treturn result.map((row) => row.roomId as UUID);\n\t\t});\n\t}\n\n\t/**\n\t * Asynchronously retrieves all rooms for a list of participants from the database based on the provided parameters.\n\t * @param {UUID[]} entityIds - The IDs of the entities to retrieve rooms for.\n\t * @returns {Promise<UUID[]>} A Promise that resolves to an array of room IDs.\n\t */\n\tasync getRoomsForParticipants(entityIds: UUID[]): Promise<UUID[]> {\n\t\treturn this.withDatabase(async () => {\n\t\t\tconst result = await this.db\n\t\t\t\t.selectDistinct({ roomId: participantTable.roomId })\n\t\t\t\t.from(participantTable)\n\t\t\t\t.innerJoin(roomTable, eq(participantTable.roomId, roomTable.id))\n\t\t\t\t.where(\n\t\t\t\t\tand(\n\t\t\t\t\t\tinArray(participantTable.entityId, entityIds),\n\t\t\t\t\t\teq(roomTable.agentId, this.agentId),\n\t\t\t\t\t),\n\t\t\t\t);\n\n\t\t\treturn result.map((row) => row.roomId as UUID);\n\t\t});\n\t}\n\n\t/**\n\t * Asynchronously adds a participant to a room in the database based on the provided parameters.\n\t * @param {UUID} entityId - The ID of the entity to add to the room.\n\t * @param {UUID} roomId - The ID of the room to add the entity to.\n\t * @returns {Promise<boolean>} A Promise that resolves to a boolean indicating whether the participant was added successfully.\n\t */\n\tasync addParticipant(entityId: UUID, roomId: UUID): Promise<boolean> {\n\t\treturn this.withDatabase(async () => {\n\t\t\ttry {\n\t\t\t\tawait this.db\n\t\t\t\t\t.insert(participantTable)\n\t\t\t\t\t.values({\n\t\t\t\t\t\tentityId,\n\t\t\t\t\t\troomId,\n\t\t\t\t\t\tagentId: this.agentId,\n\t\t\t\t\t})\n\t\t\t\t\t.onConflictDoNothing();\n\t\t\t\treturn true;\n\t\t\t} catch (error) {\n\t\t\t\tlogger.error(\n\t\t\t\t\t{\n\t\t\t\t\t\tsrc: \"plugin:sql\",\n\t\t\t\t\t\tentityId,\n\t\t\t\t\t\troomId,\n\t\t\t\t\t\tagentId: this.agentId,\n\t\t\t\t\t\terror: error instanceof Error ? error.message : String(error),\n\t\t\t\t\t},\n\t\t\t\t\t\"Failed to add participant to room\",\n\t\t\t\t);\n\t\t\t\treturn false;\n\t\t\t}\n\t\t});\n\t}\n\n\tasync addParticipantsRoom(entityIds: UUID[], roomId: UUID): Promise<boolean> {\n\t\treturn this.withDatabase(async () => {\n\t\t\ttry {\n\t\t\t\tconst values = entityIds.map((id) => ({\n\t\t\t\t\tentityId: id,\n\t\t\t\t\troomId,\n\t\t\t\t\tagentId: this.agentId,\n\t\t\t\t}));\n\t\t\t\tawait this.db\n\t\t\t\t\t.insert(participantTable)\n\t\t\t\t\t.values(values)\n\t\t\t\t\t.onConflictDoNothing()\n\t\t\t\t\t.execute();\n\t\t\t\treturn true;\n\t\t\t} catch (error) {\n\t\t\t\tlogger.error(\n\t\t\t\t\t{\n\t\t\t\t\t\tsrc: \"plugin:sql\",\n\t\t\t\t\t\troomId,\n\t\t\t\t\t\tagentId: this.agentId,\n\t\t\t\t\t\terror: error instanceof Error ? error.message : String(error),\n\t\t\t\t\t},\n\t\t\t\t\t\"Failed to add participants to room\",\n\t\t\t\t);\n\t\t\t\treturn false;\n\t\t\t}\n\t\t});\n\t}\n\n\t/**\n\t * Asynchronously removes a participant from a room in the database based on the provided parameters.\n\t * @param {UUID} entityId - The ID of the entity to remove from the room.\n\t * @param {UUID} roomId - The ID of the room to remove the entity from.\n\t * @returns {Promise<boolean>} A Promise that resolves to a boolean indicating whether the participant was removed successfully.\n\t */\n\tasync removeParticipant(entityId: UUID, roomId: UUID): Promise<boolean> {\n\t\treturn this.withDatabase(async () => {\n\t\t\ttry {\n\t\t\t\tconst result = await this.db.transaction(async (tx) => {\n\t\t\t\t\treturn await tx\n\t\t\t\t\t\t.delete(participantTable)\n\t\t\t\t\t\t.where(\n\t\t\t\t\t\t\tand(\n\t\t\t\t\t\t\t\teq(participantTable.entityId, entityId),\n\t\t\t\t\t\t\t\teq(participantTable.roomId, roomId),\n\t\t\t\t\t\t\t),\n\t\t\t\t\t\t)\n\t\t\t\t\t\t.returning();\n\t\t\t\t});\n\n\t\t\t\tconst removed = result.length > 0;\n\t\t\t\treturn removed;\n\t\t\t} catch (error) {\n\t\t\t\tlogger.error(\n\t\t\t\t\t{\n\t\t\t\t\t\tsrc: \"plugin:sql\",\n\t\t\t\t\t\tentityId,\n\t\t\t\t\t\troomId,\n\t\t\t\t\t\terror: error instanceof Error ? error.message : String(error),\n\t\t\t\t\t},\n\t\t\t\t\t\"Failed to remove participant from room\",\n\t\t\t\t);\n\t\t\t\treturn false;\n\t\t\t}\n\t\t});\n\t}\n\n\t/**\n\t * Asynchronously retrieves all participants for an entity from the database based on the provided parameters.\n\t * @param {UUID} entityId - The ID of the entity to retrieve participants for.\n\t * @returns {Promise<Participant[]>} A Promise that resolves to an array of participants.\n\t */\n\tasync getParticipantsForEntity(entityId: UUID): Promise<Participant[]> {\n\t\treturn this.withDatabase(async () => {\n\t\t\tconst result = await this.db\n\t\t\t\t.select({\n\t\t\t\t\tid: participantTable.id,\n\t\t\t\t\tentityId: participantTable.entityId,\n\t\t\t\t\troomId: participantTable.roomId,\n\t\t\t\t})\n\t\t\t\t.from(participantTable)\n\t\t\t\t.where(eq(participantTable.entityId, entityId));\n\n\t\t\tconst entities = await this.getEntitiesByIds([entityId]);\n\n\t\t\tif (!entities || !entities.length) {\n\t\t\t\treturn [];\n\t\t\t}\n\n\t\t\treturn result.map((row) => ({\n\t\t\t\tid: row.id as UUID,\n\t\t\t\tentity: entities[0],\n\t\t\t}));\n\t\t});\n\t}\n\n\t/**\n\t * Asynchronously retrieves all participants for a room from the database based on the provided parameters.\n\t * @param {UUID} roomId - The ID of the room to retrieve participants for.\n\t * @returns {Promise<UUID[]>} A Promise that resolves to an array of entity IDs.\n\t */\n\tasync getParticipantsForRoom(roomId: UUID): Promise<UUID[]> {\n\t\treturn this.withDatabase(async () => {\n\t\t\tconst result = await this.db\n\t\t\t\t.select({ entityId: participantTable.entityId })\n\t\t\t\t.from(participantTable)\n\t\t\t\t.where(eq(participantTable.roomId, roomId));\n\n\t\t\treturn result.map((row) => row.entityId as UUID);\n\t\t});\n\t}\n\n\t/**\n\t * Check if an entity is a participant in a specific room/channel.\n\t * More efficient than getParticipantsForRoom when only checking membership.\n\t * @param {UUID} roomId - The ID of the room to check.\n\t * @param {UUID} entityId - The ID of the entity to check.\n\t * @returns {Promise<boolean>} A Promise that resolves to true if entity is a participant.\n\t */\n\tasync isRoomParticipant(roomId: UUID, entityId: UUID): Promise<boolean> {\n\t\treturn this.withDatabase(async () => {\n\t\t\tconst result = await this.db\n\t\t\t\t.select()\n\t\t\t\t.from(participantTable)\n\t\t\t\t.where(\n\t\t\t\t\tand(\n\t\t\t\t\t\teq(participantTable.roomId, roomId),\n\t\t\t\t\t\teq(participantTable.entityId, entityId),\n\t\t\t\t\t),\n\t\t\t\t)\n\t\t\t\t.limit(1);\n\n\t\t\treturn result.length > 0;\n\t\t});\n\t}\n\n\t/**\n\t * Asynchronously retrieves the user state for a participant in a room from the database based on the provided parameters.\n\t * @param {UUID} roomId - The ID of the room to retrieve the participant's user state for.\n\t * @param {UUID} entityId - The ID of the entity to retrieve the user state for.\n\t * @returns {Promise<\"FOLLOWED\" | \"MUTED\" | null>} A Promise that resolves to the participant's user state.\n\t */\n\tasync getParticipantUserState(\n\t\troomId: UUID,\n\t\tentityId: UUID,\n\t): Promise<\"FOLLOWED\" | \"MUTED\" | null> {\n\t\treturn this.withDatabase(async () => {\n\t\t\tconst result = await this.db\n\t\t\t\t.select({ roomState: participantTable.roomState })\n\t\t\t\t.from(participantTable)\n\t\t\t\t.where(\n\t\t\t\t\tand(\n\t\t\t\t\t\teq(participantTable.roomId, roomId),\n\t\t\t\t\t\teq(participantTable.entityId, entityId),\n\t\t\t\t\t\teq(participantTable.agentId, this.agentId),\n\t\t\t\t\t),\n\t\t\t\t)\n\t\t\t\t.limit(1);\n\n\t\t\tconst result0 = result[0];\n\t\t\treturn (result0?.roomState as \"FOLLOWED\" | \"MUTED\" | null) ?? null;\n\t\t});\n\t}\n\n\t/**\n\t * Asynchronously sets the user state for a participant in a room in the database based on the provided parameters.\n\t * @param {UUID} roomId - The ID of the room to set the participant's user state for.\n\t * @param {UUID} entityId - The ID of the entity to set the user state for.\n\t * @param {string} state - The state to set the participant's user state to.\n\t * @returns {Promise<void>} A Promise that resolves when the participant's user state is set.\n\t */\n\tasync setParticipantUserState(\n\t\troomId: UUID,\n\t\tentityId: UUID,\n\t\tstate: \"FOLLOWED\" | \"MUTED\" | null,\n\t): Promise<void> {\n\t\treturn this.withDatabase(async () => {\n\t\t\ttry {\n\t\t\t\tawait this.db.transaction(async (tx) => {\n\t\t\t\t\tawait tx\n\t\t\t\t\t\t.update(participantTable)\n\t\t\t\t\t\t.set({ roomState: state })\n\t\t\t\t\t\t.where(\n\t\t\t\t\t\t\tand(\n\t\t\t\t\t\t\t\teq(participantTable.roomId, roomId),\n\t\t\t\t\t\t\t\teq(participantTable.entityId, entityId),\n\t\t\t\t\t\t\t\teq(participantTable.agentId, this.agentId),\n\t\t\t\t\t\t\t),\n\t\t\t\t\t\t);\n\t\t\t\t});\n\t\t\t} catch (error) {\n\t\t\t\tlogger.error(\n\t\t\t\t\t{\n\t\t\t\t\t\tsrc: \"plugin:sql\",\n\t\t\t\t\t\troomId,\n\t\t\t\t\t\tentityId,\n\t\t\t\t\t\tstate,\n\t\t\t\t\t\terror: error instanceof Error ? error.message : String(error),\n\t\t\t\t\t},\n\t\t\t\t\t\"Failed to set participant follow state\",\n\t\t\t\t);\n\t\t\t\tthrow error;\n\t\t\t}\n\t\t});\n\t}\n\n\t/**\n\t * Asynchronously creates a new relationship in the database based on the provided parameters.\n\t * @param {Object} params - The parameters for creating a new relationship.\n\t * @param {UUID} params.sourceEntityId - The ID of the source entity.\n\t * @param {UUID} params.targetEntityId - The ID of the target entity.\n\t * @param {string[]} [params.tags] - The tags for the relationship.\n\t * @param {Object} [params.metadata] - The metadata for the relationship.\n\t * @returns {Promise<boolean>} A Promise that resolves to a boolean indicating whether the relationship was created successfully.\n\t */\n\tasync createRelationship(params: {\n\t\tsourceEntityId: UUID;\n\t\ttargetEntityId: UUID;\n\t\ttags?: string[];\n\t\tmetadata?: { [key: string]: unknown };\n\t}): Promise<boolean> {\n\t\treturn this.withDatabase(async () => {\n\t\t\tconst id = v4();\n\t\t\tconst saveParams = {\n\t\t\t\tid,\n\t\t\t\tsourceEntityId: params.sourceEntityId,\n\t\t\t\ttargetEntityId: params.targetEntityId,\n\t\t\t\tagentId: this.agentId,\n\t\t\t\ttags: params.tags || [],\n\t\t\t\tmetadata: params.metadata || {},\n\t\t\t};\n\t\t\ttry {\n\t\t\t\tawait this.db.insert(relationshipTable).values(saveParams);\n\t\t\t\treturn true;\n\t\t\t} catch (error) {\n\t\t\t\tlogger.error(\n\t\t\t\t\t{\n\t\t\t\t\t\tsrc: \"plugin:sql\",\n\t\t\t\t\t\tagentId: this.agentId,\n\t\t\t\t\t\terror: error instanceof Error ? error.message : String(error),\n\t\t\t\t\t\tsaveParams,\n\t\t\t\t\t},\n\t\t\t\t\t\"Error creating relationship\",\n\t\t\t\t);\n\t\t\t\treturn false;\n\t\t\t}\n\t\t});\n\t}\n\n\t/**\n\t * Asynchronously updates an existing relationship in the database based on the provided parameters.\n\t * @param {Relationship} relationship - The relationship object to update.\n\t * @returns {Promise<void>} A Promise that resolves when the relationship is updated.\n\t */\n\tasync updateRelationship(relationship: Relationship): Promise<void> {\n\t\treturn this.withDatabase(async () => {\n\t\t\ttry {\n\t\t\t\tawait this.db\n\t\t\t\t\t.update(relationshipTable)\n\t\t\t\t\t.set({\n\t\t\t\t\t\ttags: relationship.tags || [],\n\t\t\t\t\t\tmetadata: relationship.metadata || {},\n\t\t\t\t\t})\n\t\t\t\t\t.where(eq(relationshipTable.id, relationship.id));\n\t\t\t} catch (error) {\n\t\t\t\tlogger.error(\n\t\t\t\t\t{\n\t\t\t\t\t\tsrc: \"plugin:sql\",\n\t\t\t\t\t\tagentId: this.agentId,\n\t\t\t\t\t\terror: error instanceof Error ? error.message : String(error),\n\t\t\t\t\t\trelationshipId: relationship.id,\n\t\t\t\t\t},\n\t\t\t\t\t\"Error updating relationship\",\n\t\t\t\t);\n\t\t\t\tthrow error;\n\t\t\t}\n\t\t});\n\t}\n\n\t/**\n\t * Asynchronously retrieves a relationship from the database based on the provided parameters.\n\t * @param {Object} params - The parameters for retrieving a relationship.\n\t * @param {UUID} params.sourceEntityId - The ID of the source entity.\n\t * @param {UUID} params.targetEntityId - The ID of the target entity.\n\t * @returns {Promise<Relationship | null>} A Promise that resolves to the relationship if found, null otherwise.\n\t */\n\tasync getRelationship(params: {\n\t\tsourceEntityId: UUID;\n\t\ttargetEntityId: UUID;\n\t}): Promise<Relationship | null> {\n\t\treturn this.withDatabase(async () => {\n\t\t\tconst { sourceEntityId, targetEntityId } = params;\n\t\t\tconst result = await this.db\n\t\t\t\t.select()\n\t\t\t\t.from(relationshipTable)\n\t\t\t\t.where(\n\t\t\t\t\tand(\n\t\t\t\t\t\teq(relationshipTable.sourceEntityId, sourceEntityId),\n\t\t\t\t\t\teq(relationshipTable.targetEntityId, targetEntityId),\n\t\t\t\t\t),\n\t\t\t\t);\n\t\t\tif (result.length === 0) return null;\n\t\t\tconst relationship = result[0];\n\t\t\treturn {\n\t\t\t\t...relationship,\n\t\t\t\tid: relationship.id as UUID,\n\t\t\t\tsourceEntityId: relationship.sourceEntityId as UUID,\n\t\t\t\ttargetEntityId: relationship.targetEntityId as UUID,\n\t\t\t\tagentId: relationship.agentId as UUID,\n\t\t\t\ttags: (relationship.tags ?? []) as string[],\n\t\t\t\tmetadata: (relationship.metadata ?? {}) as Metadata,\n\t\t\t\tcreatedAt: relationship.createdAt.toISOString(),\n\t\t\t};\n\t\t});\n\t}\n\n\t/**\n\t * Asynchronously retrieves relationships from the database based on the provided parameters.\n\t * @param {Object} params - The parameters for retrieving relationships.\n\t * @param {UUID} params.entityId - The ID of the entity to retrieve relationships for.\n\t * @param {string[]} [params.tags] - The tags to filter relationships by.\n\t * @returns {Promise<Relationship[]>} A Promise that resolves to an array of relationships.\n\t */\n\tasync getRelationships(params: {\n\t\tentityId: UUID;\n\t\ttags?: string[];\n\t}): Promise<Relationship[]> {\n\t\treturn this.withDatabase(async () => {\n\t\t\tconst { entityId, tags } = params;\n\n\t\t\tlet query: SQL;\n\n\t\t\tif (tags && tags.length > 0) {\n\t\t\t\tquery = sql`\n SELECT * FROM ${relationshipTable}\n WHERE (${relationshipTable.sourceEntityId} = ${entityId} OR ${relationshipTable.targetEntityId} = ${entityId})\n AND ${relationshipTable.tags} && CAST(ARRAY[${sql.join(tags, sql`, `)}] AS text[])\n `;\n\t\t\t} else {\n\t\t\t\tquery = sql`\n SELECT * FROM ${relationshipTable}\n WHERE ${relationshipTable.sourceEntityId} = ${entityId} OR ${relationshipTable.targetEntityId} = ${entityId}\n `;\n\t\t\t}\n\n\t\t\tconst result = await this.db.execute(query);\n\n\t\t\treturn result.rows.map((relationship: Record<string, unknown>) => ({\n\t\t\t\t...relationship,\n\t\t\t\tid: relationship.id as UUID,\n\t\t\t\tsourceEntityId: (relationship.source_entity_id ||\n\t\t\t\t\trelationship.sourceEntityId) as UUID,\n\t\t\t\ttargetEntityId: (relationship.target_entity_id ||\n\t\t\t\t\trelationship.targetEntityId) as UUID,\n\t\t\t\tagentId: (relationship.agent_id || relationship.agentId) as UUID,\n\t\t\t\ttags: (relationship.tags ?? []) as string[],\n\t\t\t\tmetadata: (relationship.metadata ?? {}) as Metadata,\n\t\t\t\tcreatedAt:\n\t\t\t\t\trelationship.created_at || relationship.createdAt\n\t\t\t\t\t\t? (relationship.created_at || relationship.createdAt) instanceof\n\t\t\t\t\t\t\tDate\n\t\t\t\t\t\t\t? (\n\t\t\t\t\t\t\t\t\t(relationship.created_at || relationship.createdAt) as Date\n\t\t\t\t\t\t\t\t).toISOString()\n\t\t\t\t\t\t\t: new Date(\n\t\t\t\t\t\t\t\t\t(relationship.created_at as string) ||\n\t\t\t\t\t\t\t\t\t\t(relationship.createdAt as string),\n\t\t\t\t\t\t\t\t).toISOString()\n\t\t\t\t\t\t: new Date().toISOString(),\n\t\t\t}));\n\t\t});\n\t}\n\n\t/**\n\t * Asynchronously retrieves a cache value from the database based on the provided key.\n\t * @param {string} key - The key to retrieve the cache value for.\n\t * @returns {Promise<T | undefined>} A Promise that resolves to the cache value if found, undefined otherwise.\n\t */\n\tasync getCache<T>(key: string): Promise<T | undefined> {\n\t\treturn this.withDatabase(async () => {\n\t\t\ttry {\n\t\t\t\tconst result = await this.db\n\t\t\t\t\t.select({ value: cacheTable.value })\n\t\t\t\t\t.from(cacheTable)\n\t\t\t\t\t.where(\n\t\t\t\t\t\tand(eq(cacheTable.agentId, this.agentId), eq(cacheTable.key, key)),\n\t\t\t\t\t)\n\t\t\t\t\t.limit(1);\n\n\t\t\t\tif (result && result.length > 0 && result[0]) {\n\t\t\t\t\treturn result[0].value as T | undefined;\n\t\t\t\t}\n\n\t\t\t\treturn undefined;\n\t\t\t} catch (error) {\n\t\t\t\tlogger.error(\n\t\t\t\t\t{\n\t\t\t\t\t\tsrc: \"plugin:sql\",\n\t\t\t\t\t\tagentId: this.agentId,\n\t\t\t\t\t\terror: error instanceof Error ? error.message : String(error),\n\t\t\t\t\t\tkey,\n\t\t\t\t\t},\n\t\t\t\t\t\"Error fetching cache\",\n\t\t\t\t);\n\t\t\t\treturn undefined;\n\t\t\t}\n\t\t});\n\t}\n\n\t/**\n\t * Asynchronously sets a cache value in the database based on the provided key and value.\n\t * @param {string} key - The key to set the cache value for.\n\t * @param {T} value - The value to set in the cache.\n\t * @returns {Promise<boolean>} A Promise that resolves to a boolean indicating whether the cache value was set successfully.\n\t */\n\tasync setCache<T>(key: string, value: T): Promise<boolean> {\n\t\treturn this.withDatabase(async () => {\n\t\t\ttry {\n\t\t\t\tawait this.db\n\t\t\t\t\t.insert(cacheTable)\n\t\t\t\t\t.values({\n\t\t\t\t\t\tkey: key,\n\t\t\t\t\t\tagentId: this.agentId,\n\t\t\t\t\t\tvalue: value,\n\t\t\t\t\t})\n\t\t\t\t\t.onConflictDoUpdate({\n\t\t\t\t\t\ttarget: [cacheTable.key, cacheTable.agentId],\n\t\t\t\t\t\tset: {\n\t\t\t\t\t\t\tvalue: value,\n\t\t\t\t\t\t},\n\t\t\t\t\t});\n\n\t\t\t\treturn true;\n\t\t\t} catch (error) {\n\t\t\t\tlogger.error(\n\t\t\t\t\t{\n\t\t\t\t\t\tsrc: \"plugin:sql\",\n\t\t\t\t\t\tagentId: this.agentId,\n\t\t\t\t\t\terror: error instanceof Error ? error.message : String(error),\n\t\t\t\t\t\tkey,\n\t\t\t\t\t},\n\t\t\t\t\t\"Error setting cache\",\n\t\t\t\t);\n\t\t\t\treturn false;\n\t\t\t}\n\t\t});\n\t}\n\n\t/**\n\t * Asynchronously deletes a cache value from the database based on the provided key.\n\t * @param {string} key - The key to delete the cache value for.\n\t * @returns {Promise<boolean>} A Promise that resolves to a boolean indicating whether the cache value was deleted successfully.\n\t */\n\tasync deleteCache(key: string): Promise<boolean> {\n\t\treturn this.withDatabase(async () => {\n\t\t\ttry {\n\t\t\t\tawait this.db.transaction(async (tx) => {\n\t\t\t\t\tawait tx\n\t\t\t\t\t\t.delete(cacheTable)\n\t\t\t\t\t\t.where(\n\t\t\t\t\t\t\tand(\n\t\t\t\t\t\t\t\teq(cacheTable.agentId, this.agentId),\n\t\t\t\t\t\t\t\teq(cacheTable.key, key),\n\t\t\t\t\t\t\t),\n\t\t\t\t\t\t);\n\t\t\t\t});\n\t\t\t\treturn true;\n\t\t\t} catch (error) {\n\t\t\t\tlogger.error(\n\t\t\t\t\t{\n\t\t\t\t\t\tsrc: \"plugin:sql\",\n\t\t\t\t\t\tagentId: this.agentId,\n\t\t\t\t\t\terror: error instanceof Error ? error.message : String(error),\n\t\t\t\t\t\tkey,\n\t\t\t\t\t},\n\t\t\t\t\t\"Error deleting cache\",\n\t\t\t\t);\n\t\t\t\treturn false;\n\t\t\t}\n\t\t});\n\t}\n\n\t/**\n\t * Asynchronously creates a new world in the database based on the provided parameters.\n\t * @param {World} world - The world object to create.\n\t * @returns {Promise<UUID>} A Promise that resolves to the ID of the created world.\n\t */\n\tasync createWorld(world: World): Promise<UUID> {\n\t\treturn this.withDatabase(async () => {\n\t\t\tconst newWorldId = world.id || (v4() as UUID);\n\t\t\tawait this.db.insert(worldTable).values({\n\t\t\t\t...world,\n\t\t\t\tid: newWorldId,\n\t\t\t\tname: world.name || \"\",\n\t\t\t});\n\t\t\treturn newWorldId;\n\t\t});\n\t}\n\n\t/**\n\t * Asynchronously retrieves a world from the database based on the provided parameters.\n\t * @param {UUID} id - The ID of the world to retrieve.\n\t * @returns {Promise<World | null>} A Promise that resolves to the world if found, null otherwise.\n\t */\n\tasync getWorld(id: UUID): Promise<World | null> {\n\t\treturn this.withDatabase(async () => {\n\t\t\tconst result = await this.db\n\t\t\t\t.select()\n\t\t\t\t.from(worldTable)\n\t\t\t\t.where(eq(worldTable.id, id));\n\t\t\treturn result.length > 0 ? (result[0] as World) : null;\n\t\t});\n\t}\n\n\t/**\n\t * Asynchronously retrieves all worlds from the database based on the provided parameters.\n\t * @returns {Promise<World[]>} A Promise that resolves to an array of worlds.\n\t */\n\tasync getAllWorlds(): Promise<World[]> {\n\t\treturn this.withDatabase(async () => {\n\t\t\tconst result = await this.db\n\t\t\t\t.select()\n\t\t\t\t.from(worldTable)\n\t\t\t\t.where(eq(worldTable.agentId, this.agentId));\n\t\t\treturn result as World[];\n\t\t});\n\t}\n\n\t/**\n\t * Asynchronously updates an existing world in the database based on the provided parameters.\n\t * @param {World} world - The world object to update.\n\t * @returns {Promise<void>} A Promise that resolves when the world is updated.\n\t */\n\tasync updateWorld(world: World): Promise<void> {\n\t\treturn this.withDatabase(async () => {\n\t\t\tawait this.db\n\t\t\t\t.update(worldTable)\n\t\t\t\t.set(world)\n\t\t\t\t.where(eq(worldTable.id, world.id));\n\t\t});\n\t}\n\n\t/**\n\t * Asynchronously removes a world from the database based on the provided parameters.\n\t * @param {UUID} id - The ID of the world to remove.\n\t * @returns {Promise<void>} A Promise that resolves when the world is removed.\n\t */\n\tasync removeWorld(id: UUID): Promise<void> {\n\t\treturn this.withDatabase(async () => {\n\t\t\tawait this.db.delete(worldTable).where(eq(worldTable.id, id));\n\t\t});\n\t}\n\n\t/**\n\t * Asynchronously creates a new task in the database based on the provided parameters.\n\t * @param {Task} task - The task object to create.\n\t * @returns {Promise<UUID>} A Promise that resolves to the ID of the created task.\n\t */\n\tasync createTask(task: Task): Promise<UUID> {\n\t\t// Default worldId to agentId for agent-internal tasks\n\t\tif (!task.worldId) {\n\t\t\ttask = { ...task, worldId: this.agentId as UUID };\n\t\t}\n\t\treturn this.withRetry(async () => {\n\t\t\treturn this.withDatabase(async () => {\n\t\t\t\tconst now = new Date();\n\t\t\t\tconst metadata = task.metadata || {};\n\n\t\t\t\tconst values = {\n\t\t\t\t\tid: task.id as UUID,\n\t\t\t\t\tname: task.name,\n\t\t\t\t\tdescription: task.description,\n\t\t\t\t\troomId: task.roomId as UUID,\n\t\t\t\t\tworldId: task.worldId as UUID,\n\t\t\t\t\ttags: task.tags,\n\t\t\t\t\tmetadata: metadata,\n\t\t\t\t\tcreatedAt: now,\n\t\t\t\t\tupdatedAt: now,\n\t\t\t\t\tagentId: this.agentId as UUID,\n\t\t\t\t};\n\n\t\t\t\tconst result = await this.db\n\t\t\t\t\t.insert(taskTable)\n\t\t\t\t\t.values(values)\n\t\t\t\t\t.returning();\n\n\t\t\t\treturn result[0].id as UUID;\n\t\t\t});\n\t\t});\n\t}\n\n\t/**\n\t * Asynchronously retrieves tasks based on specified parameters.\n\t * @param params Object containing optional roomId, tags, and entityId to filter tasks\n\t * @returns Promise resolving to an array of Task objects\n\t */\n\tasync getTasks(params: {\n\t\troomId?: UUID;\n\t\ttags?: string[];\n\t\tentityId?: UUID; // Added entityId parameter\n\t}): Promise<Task[]> {\n\t\treturn this.withRetry(async () => {\n\t\t\treturn this.withDatabase(async () => {\n\t\t\t\tconst result = await this.db\n\t\t\t\t\t.select()\n\t\t\t\t\t.from(taskTable)\n\t\t\t\t\t.where(\n\t\t\t\t\t\tand(\n\t\t\t\t\t\t\teq(taskTable.agentId, this.agentId),\n\t\t\t\t\t\t\t...(params.roomId ? [eq(taskTable.roomId, params.roomId)] : []),\n\t\t\t\t\t\t\t...(params.tags && params.tags.length > 0\n\t\t\t\t\t\t\t\t? [\n\t\t\t\t\t\t\t\t\t\tsql`${taskTable.tags} @> ARRAY[${sql.join(\n\t\t\t\t\t\t\t\t\t\t\tparams.tags.map((t) => sql`${t}`),\n\t\t\t\t\t\t\t\t\t\t\tsql`, `,\n\t\t\t\t\t\t\t\t\t\t)}]::text[]`,\n\t\t\t\t\t\t\t\t\t]\n\t\t\t\t\t\t\t\t: []),\n\t\t\t\t\t\t),\n\t\t\t\t\t);\n\n\t\t\t\treturn result.map((row) => ({\n\t\t\t\t\tid: row.id as UUID,\n\t\t\t\t\tname: row.name,\n\t\t\t\t\tdescription: row.description ?? \"\",\n\t\t\t\t\troomId: row.roomId as UUID,\n\t\t\t\t\tworldId: row.worldId as UUID,\n\t\t\t\t\ttags: row.tags || [],\n\t\t\t\t\tmetadata: row.metadata as TaskMetadata,\n\t\t\t\t}));\n\t\t\t});\n\t\t});\n\t}\n\n\t/**\n\t * Asynchronously retrieves a specific task by its name.\n\t * @param name The name of the task to retrieve\n\t * @returns Promise resolving to the Task object if found, null otherwise\n\t */\n\tasync getTasksByName(name: string): Promise<Task[]> {\n\t\treturn this.withRetry(async () => {\n\t\t\treturn this.withDatabase(async () => {\n\t\t\t\tconst result = await this.db\n\t\t\t\t\t.select()\n\t\t\t\t\t.from(taskTable)\n\t\t\t\t\t.where(\n\t\t\t\t\t\tand(eq(taskTable.name, name), eq(taskTable.agentId, this.agentId)),\n\t\t\t\t\t);\n\n\t\t\t\treturn result.map((row) => ({\n\t\t\t\t\tid: row.id as UUID,\n\t\t\t\t\tname: row.name,\n\t\t\t\t\tdescription: row.description ?? \"\",\n\t\t\t\t\troomId: row.roomId as UUID,\n\t\t\t\t\tworldId: row.worldId as UUID,\n\t\t\t\t\ttags: row.tags || [],\n\t\t\t\t\tmetadata: (row.metadata || {}) as TaskMetadata,\n\t\t\t\t}));\n\t\t\t});\n\t\t});\n\t}\n\n\t/**\n\t * Asynchronously retrieves a specific task by its ID.\n\t * @param id The UUID of the task to retrieve\n\t * @returns Promise resolving to the Task object if found, null otherwise\n\t */\n\tasync getTask(id: UUID): Promise<Task | null> {\n\t\treturn this.withRetry(async () => {\n\t\t\treturn this.withDatabase(async () => {\n\t\t\t\tconst result = await this.db\n\t\t\t\t\t.select()\n\t\t\t\t\t.from(taskTable)\n\t\t\t\t\t.where(and(eq(taskTable.id, id), eq(taskTable.agentId, this.agentId)))\n\t\t\t\t\t.limit(1);\n\n\t\t\t\tif (result.length === 0) {\n\t\t\t\t\treturn null;\n\t\t\t\t}\n\n\t\t\t\tconst row = result[0];\n\t\t\t\treturn {\n\t\t\t\t\tid: row.id as UUID,\n\t\t\t\t\tname: row.name,\n\t\t\t\t\tdescription: row.description ?? \"\",\n\t\t\t\t\troomId: row.roomId as UUID,\n\t\t\t\t\tworldId: row.worldId as UUID,\n\t\t\t\t\ttags: row.tags || [],\n\t\t\t\t\tmetadata: (row.metadata || {}) as TaskMetadata,\n\t\t\t\t};\n\t\t\t});\n\t\t});\n\t}\n\n\t/**\n\t * Asynchronously updates an existing task in the database.\n\t * @param id The UUID of the task to update\n\t * @param task Partial Task object containing the fields to update\n\t * @returns Promise resolving when the update is complete\n\t */\n\tasync updateTask(id: UUID, task: Partial<Task>): Promise<void> {\n\t\tawait this.withRetry(async () => {\n\t\t\tawait this.withDatabase(async () => {\n\t\t\t\tconst updateValues: Partial<typeof taskTable.$inferInsert> = {};\n\n\t\t\t\t// Add fields to update if they exist in the partial task object\n\t\t\t\tif (task.name !== undefined) updateValues.name = task.name;\n\t\t\t\tif (task.description !== undefined)\n\t\t\t\t\tupdateValues.description = task.description;\n\t\t\t\tif (task.roomId !== undefined) updateValues.roomId = task.roomId;\n\t\t\t\tif (task.worldId !== undefined) updateValues.worldId = task.worldId;\n\t\t\t\tif (task.tags !== undefined) updateValues.tags = task.tags;\n\t\t\t\tif (task.metadata !== undefined)\n\t\t\t\t\tupdateValues.metadata =\n\t\t\t\t\t\ttask.metadata as typeof taskTable.$inferInsert.metadata;\n\t\t\t\t// Handle createdAt if present in the task object (using type assertion for compatibility)\n\t\t\t\tconst taskWithCreatedAt = task as {\n\t\t\t\t\tcreatedAt?: number | bigint | null;\n\t\t\t\t};\n\t\t\t\tif (\n\t\t\t\t\ttaskWithCreatedAt.createdAt !== undefined &&\n\t\t\t\t\ttaskWithCreatedAt.createdAt !== null\n\t\t\t\t) {\n\t\t\t\t\tconst createdAtValue = taskWithCreatedAt.createdAt;\n\t\t\t\t\tupdateValues.createdAt = new Date(\n\t\t\t\t\t\ttypeof createdAtValue === \"bigint\"\n\t\t\t\t\t\t\t? Number(createdAtValue)\n\t\t\t\t\t\t\t: createdAtValue,\n\t\t\t\t\t);\n\t\t\t\t}\n\n\t\t\t\t// Always update the updatedAt timestamp as a Date (schema uses Date, not number)\n\t\t\t\tconst dbUpdateValues: Partial<typeof taskTable.$inferInsert> = {\n\t\t\t\t\t...updateValues,\n\t\t\t\t\tupdatedAt: new Date(),\n\t\t\t\t};\n\n\t\t\t\t// Handle metadata updates - just set it directly without merging\n\t\t\t\tif (task.metadata !== undefined) {\n\t\t\t\t\tdbUpdateValues.metadata = task.metadata;\n\t\t\t\t}\n\n\t\t\t\tawait this.db\n\t\t\t\t\t.update(taskTable)\n\t\t\t\t\t// createdAt is hella borked, number / Date\n\t\t\t\t\t.set(dbUpdateValues)\n\t\t\t\t\t.where(\n\t\t\t\t\t\tand(eq(taskTable.id, id), eq(taskTable.agentId, this.agentId)),\n\t\t\t\t\t);\n\t\t\t});\n\t\t});\n\t}\n\n\t/**\n\t * Asynchronously deletes a task from the database.\n\t * @param id The UUID of the task to delete\n\t * @returns Promise resolving when the deletion is complete\n\t */\n\tasync deleteTask(id: UUID): Promise<void> {\n\t\treturn this.withDatabase(async () => {\n\t\t\tawait this.db.delete(taskTable).where(eq(taskTable.id, id));\n\t\t});\n\t}\n\n\tasync getMemoriesByWorldId(params: {\n\t\tworldId: UUID;\n\t\tcount?: number;\n\t\ttableName?: string;\n\t}): Promise<Memory[]> {\n\t\treturn this.withDatabase(async () => {\n\t\t\t// First, get all rooms for the given worldId\n\t\t\tconst rooms = await this.db\n\t\t\t\t.select({ id: roomTable.id })\n\t\t\t\t.from(roomTable)\n\t\t\t\t.where(\n\t\t\t\t\tand(\n\t\t\t\t\t\teq(roomTable.worldId, params.worldId),\n\t\t\t\t\t\teq(roomTable.agentId, this.agentId),\n\t\t\t\t\t),\n\t\t\t\t);\n\n\t\t\tif (rooms.length === 0) {\n\t\t\t\treturn [];\n\t\t\t}\n\n\t\t\tconst roomIds = rooms.map((room) => room.id as UUID);\n\n\t\t\tconst memories = await this.getMemoriesByRoomIds({\n\t\t\t\troomIds,\n\t\t\t\ttableName: params.tableName || \"messages\",\n\t\t\t\tlimit: params.count,\n\t\t\t});\n\n\t\t\treturn memories;\n\t\t});\n\t}\n\n\tasync deleteRoomsByWorldId(worldId: UUID): Promise<void> {\n\t\treturn this.withDatabase(async () => {\n\t\t\tconst rooms = await this.db\n\t\t\t\t.select({ id: roomTable.id })\n\t\t\t\t.from(roomTable)\n\t\t\t\t.where(\n\t\t\t\t\tand(\n\t\t\t\t\t\teq(roomTable.worldId, worldId),\n\t\t\t\t\t\teq(roomTable.agentId, this.agentId),\n\t\t\t\t\t),\n\t\t\t\t);\n\n\t\t\tif (rooms.length === 0) {\n\t\t\t\treturn;\n\t\t\t}\n\n\t\t\tconst roomIds = rooms.map((room) => room.id as UUID);\n\n\t\t\tif (roomIds.length > 0) {\n\t\t\t\tawait this.db.delete(logTable).where(inArray(logTable.roomId, roomIds));\n\t\t\t\tawait this.db\n\t\t\t\t\t.delete(participantTable)\n\t\t\t\t\t.where(inArray(participantTable.roomId, roomIds));\n\n\t\t\t\tconst memoriesInRooms = await this.db\n\t\t\t\t\t.select({ id: memoryTable.id })\n\t\t\t\t\t.from(memoryTable)\n\t\t\t\t\t.where(inArray(memoryTable.roomId, roomIds));\n\t\t\t\tconst memoryIdsInRooms = memoriesInRooms.map((m) => m.id as UUID);\n\n\t\t\t\tif (memoryIdsInRooms.length > 0) {\n\t\t\t\t\tawait this.db\n\t\t\t\t\t\t.delete(embeddingTable)\n\t\t\t\t\t\t.where(inArray(embeddingTable.memoryId, memoryIdsInRooms));\n\t\t\t\t\tawait this.db\n\t\t\t\t\t\t.delete(memoryTable)\n\t\t\t\t\t\t.where(inArray(memoryTable.id, memoryIdsInRooms));\n\t\t\t\t}\n\n\t\t\t\tawait this.db.delete(roomTable).where(inArray(roomTable.id, roomIds));\n\n\t\t\t\tlogger.debug(\n\t\t\t\t\t{\n\t\t\t\t\t\tsrc: \"plugin:sql\",\n\t\t\t\t\t\tworldId,\n\t\t\t\t\t\troomsDeleted: roomIds.length,\n\t\t\t\t\t\tmemoriesDeleted: memoryIdsInRooms.length,\n\t\t\t\t\t},\n\t\t\t\t\t\"World cleanup completed\",\n\t\t\t\t);\n\t\t\t}\n\t\t});\n\t}\n\n\t// Message Server Database Operations\n\n\t/**\n\t * Creates a new message server in the central database\n\t */\n\tasync createMessageServer(data: {\n\t\tid?: UUID; // Allow passing a specific ID\n\t\tname: string;\n\t\tsourceType: string;\n\t\tsourceId?: string;\n\t\tmetadata?: Metadata;\n\t}): Promise<{\n\t\tid: UUID;\n\t\tname: string;\n\t\tsourceType: string;\n\t\tsourceId?: string;\n\t\tmetadata?: Metadata;\n\t\tcreatedAt: Date;\n\t\tupdatedAt: Date;\n\t}> {\n\t\treturn this.withDatabase(async () => {\n\t\t\tconst newId = data.id || (v4() as UUID);\n\t\t\tconst now = new Date();\n\t\t\tconst serverToInsert = {\n\t\t\t\tid: newId,\n\t\t\t\tname: data.name,\n\t\t\t\tsourceType: data.sourceType,\n\t\t\t\tsourceId: data.sourceId,\n\t\t\t\tmetadata: data.metadata,\n\t\t\t\tcreatedAt: now,\n\t\t\t\tupdatedAt: now,\n\t\t\t};\n\n\t\t\tawait this.db\n\t\t\t\t.insert(messageServerTable)\n\t\t\t\t.values(serverToInsert)\n\t\t\t\t.onConflictDoNothing(); // In case the ID already exists\n\n\t\t\t// If server already existed, fetch it\n\t\t\tif (data.id) {\n\t\t\t\tconst existing = await this.db\n\t\t\t\t\t.select()\n\t\t\t\t\t.from(messageServerTable)\n\t\t\t\t\t.where(eq(messageServerTable.id, data.id))\n\t\t\t\t\t.limit(1);\n\t\t\t\tif (existing.length > 0) {\n\t\t\t\t\treturn {\n\t\t\t\t\t\tid: existing[0].id as UUID,\n\t\t\t\t\t\tname: existing[0].name,\n\t\t\t\t\t\tsourceType: existing[0].sourceType,\n\t\t\t\t\t\tsourceId: existing[0].sourceId || undefined,\n\t\t\t\t\t\tmetadata: (existing[0].metadata || undefined) as\n\t\t\t\t\t\t\t| Metadata\n\t\t\t\t\t\t\t| undefined,\n\t\t\t\t\t\tcreatedAt: existing[0].createdAt,\n\t\t\t\t\t\tupdatedAt: existing[0].updatedAt,\n\t\t\t\t\t};\n\t\t\t\t}\n\t\t\t}\n\n\t\t\treturn serverToInsert;\n\t\t});\n\t}\n\n\t/**\n\t * Gets all message servers\n\t */\n\tasync getMessageServers(): Promise<\n\t\tArray<{\n\t\t\tid: UUID;\n\t\t\tname: string;\n\t\t\tsourceType: string;\n\t\t\tsourceId?: string;\n\t\t\tmetadata?: Metadata;\n\t\t\tcreatedAt: Date;\n\t\t\tupdatedAt: Date;\n\t\t}>\n\t> {\n\t\tconst result = await this.withDatabase(async () => {\n\t\t\tconst results = await this.db.select().from(messageServerTable);\n\t\t\treturn results.map((r) => ({\n\t\t\t\tid: r.id as UUID,\n\t\t\t\tname: r.name,\n\t\t\t\tsourceType: r.sourceType,\n\t\t\t\tsourceId: r.sourceId || undefined,\n\t\t\t\tmetadata: (r.metadata || undefined) as Metadata | undefined,\n\t\t\t\tcreatedAt: r.createdAt,\n\t\t\t\tupdatedAt: r.updatedAt,\n\t\t\t}));\n\t\t});\n\t\t// Guard against null return\n\t\treturn result || [];\n\t}\n\n\t/**\n\t * Gets a message server by ID\n\t */\n\tasync getMessageServerById(serverId: UUID): Promise<{\n\t\tid: UUID;\n\t\tname: string;\n\t\tsourceType: string;\n\t\tsourceId?: string;\n\t\tmetadata?: Metadata;\n\t\tcreatedAt: Date;\n\t\tupdatedAt: Date;\n\t} | null> {\n\t\treturn this.withDatabase(async () => {\n\t\t\tconst results = await this.db\n\t\t\t\t.select()\n\t\t\t\t.from(messageServerTable)\n\t\t\t\t.where(eq(messageServerTable.id, serverId))\n\t\t\t\t.limit(1);\n\t\t\treturn results.length > 0\n\t\t\t\t? {\n\t\t\t\t\t\tid: results[0].id as UUID,\n\t\t\t\t\t\tname: results[0].name,\n\t\t\t\t\t\tsourceType: results[0].sourceType,\n\t\t\t\t\t\tsourceId: results[0].sourceId || undefined,\n\t\t\t\t\t\tmetadata: (results[0].metadata || undefined) as\n\t\t\t\t\t\t\t| Metadata\n\t\t\t\t\t\t\t| undefined,\n\t\t\t\t\t\tcreatedAt: results[0].createdAt,\n\t\t\t\t\t\tupdatedAt: results[0].updatedAt,\n\t\t\t\t\t}\n\t\t\t\t: null;\n\t\t});\n\t}\n\n\t/**\n\t * Gets a message server by RLS server_id.\n\t * The server_id column is added dynamically when RLS is enabled.\n\t */\n\tasync getMessageServerByRlsServerId(rlsServerId: UUID): Promise<{\n\t\tid: UUID;\n\t\tname: string;\n\t\tsourceType: string;\n\t\tsourceId?: string;\n\t\tmetadata?: Metadata;\n\t\tcreatedAt: Date;\n\t\tupdatedAt: Date;\n\t} | null> {\n\t\treturn this.withDatabase(async () => {\n\t\t\t// Use raw SQL since server_id column is dynamically added by RLS and not in Drizzle schema\n\t\t\tconst results = await this.db.execute(sql`\n SELECT id, name, source_type, source_id, metadata, created_at, updated_at\n FROM message_servers\n WHERE server_id = ${rlsServerId}\n LIMIT 1\n `);\n\n\t\t\tconst rows = results.rows || results;\n\t\t\treturn (rows as Record<string, unknown>[]).length > 0\n\t\t\t\t? {\n\t\t\t\t\t\tid: (rows as Record<string, unknown>[])[0].id as UUID,\n\t\t\t\t\t\tname: (rows as Record<string, unknown>[])[0].name as string,\n\t\t\t\t\t\tsourceType: (rows as Record<string, unknown>[])[0]\n\t\t\t\t\t\t\t.source_type as string,\n\t\t\t\t\t\tsourceId: ((rows as Record<string, unknown>[])[0].source_id ||\n\t\t\t\t\t\t\tundefined) as string | undefined,\n\t\t\t\t\t\tmetadata: ((rows as Record<string, unknown>[])[0].metadata ||\n\t\t\t\t\t\t\tundefined) as Metadata | undefined,\n\t\t\t\t\t\tcreatedAt: new Date(\n\t\t\t\t\t\t\t(rows as Record<string, unknown>[])[0].created_at as string,\n\t\t\t\t\t\t),\n\t\t\t\t\t\tupdatedAt: new Date(\n\t\t\t\t\t\t\t(rows as Record<string, unknown>[])[0].updated_at as string,\n\t\t\t\t\t\t),\n\t\t\t\t\t}\n\t\t\t\t: null;\n\t\t});\n\t}\n\n\t/**\n\t * Creates a new channel\n\t */\n\tasync createChannel(\n\t\tdata: {\n\t\t\tid?: UUID; // Allow passing a specific ID\n\t\t\tmessageServerId: UUID;\n\t\t\tname: string;\n\t\t\ttype: string;\n\t\t\tsourceType?: string;\n\t\t\tsourceId?: string;\n\t\t\ttopic?: string;\n\t\t\tmetadata?: Metadata;\n\t\t},\n\t\tparticipantIds?: UUID[],\n\t): Promise<{\n\t\tid: UUID;\n\t\tmessageServerId: UUID;\n\t\tname: string;\n\t\ttype: string;\n\t\tsourceType?: string;\n\t\tsourceId?: string;\n\t\ttopic?: string;\n\t\tmetadata?: Metadata;\n\t\tcreatedAt: Date;\n\t\tupdatedAt: Date;\n\t}> {\n\t\treturn this.withDatabase(async () => {\n\t\t\tconst newId = data.id || (v4() as UUID);\n\t\t\tconst now = new Date();\n\t\t\tconst channelToInsert = {\n\t\t\t\tid: newId,\n\t\t\t\tmessageServerId: data.messageServerId,\n\t\t\t\tname: data.name,\n\t\t\t\ttype: data.type,\n\t\t\t\tsourceType: data.sourceType,\n\t\t\t\tsourceId: data.sourceId,\n\t\t\t\ttopic: data.topic,\n\t\t\t\tmetadata: data.metadata,\n\t\t\t\tcreatedAt: now,\n\t\t\t\tupdatedAt: now,\n\t\t\t};\n\n\t\t\tawait this.db.transaction(async (tx) => {\n\t\t\t\tawait tx.insert(channelTable).values(channelToInsert);\n\n\t\t\t\tif (participantIds && participantIds.length > 0) {\n\t\t\t\t\tconst participantValues = participantIds.map((entityId) => ({\n\t\t\t\t\t\tchannelId: newId,\n\t\t\t\t\t\tentityId: entityId,\n\t\t\t\t\t}));\n\t\t\t\t\tawait tx\n\t\t\t\t\t\t.insert(channelParticipantsTable)\n\t\t\t\t\t\t.values(participantValues)\n\t\t\t\t\t\t.onConflictDoNothing();\n\t\t\t\t}\n\t\t\t});\n\n\t\t\treturn channelToInsert;\n\t\t});\n\t}\n\n\t/**\n\t * Gets channels for a message server\n\t */\n\tasync getChannelsForMessageServer(messageServerId: UUID): Promise<\n\t\tArray<{\n\t\t\tid: UUID;\n\t\t\tmessageServerId: UUID;\n\t\t\tname: string;\n\t\t\ttype: string;\n\t\t\tsourceType?: string;\n\t\t\tsourceId?: string;\n\t\t\ttopic?: string;\n\t\t\tmetadata?: Metadata;\n\t\t\tcreatedAt: Date;\n\t\t\tupdatedAt: Date;\n\t\t}>\n\t> {\n\t\treturn this.withDatabase(async () => {\n\t\t\tconst results = await this.db\n\t\t\t\t.select()\n\t\t\t\t.from(channelTable)\n\t\t\t\t.where(eq(channelTable.messageServerId, messageServerId));\n\t\t\treturn results.map((r) => ({\n\t\t\t\tid: r.id as UUID,\n\t\t\t\tmessageServerId: r.messageServerId as UUID,\n\t\t\t\tname: r.name,\n\t\t\t\ttype: r.type,\n\t\t\t\tsourceType: r.sourceType || undefined,\n\t\t\t\tsourceId: r.sourceId || undefined,\n\t\t\t\ttopic: r.topic || undefined,\n\t\t\t\tmetadata: (r.metadata || undefined) as Metadata | undefined,\n\t\t\t\tcreatedAt: r.createdAt,\n\t\t\t\tupdatedAt: r.updatedAt,\n\t\t\t}));\n\t\t});\n\t}\n\n\t/**\n\t * Gets channel details\n\t */\n\tasync getChannelDetails(channelId: UUID): Promise<{\n\t\tid: UUID;\n\t\tmessageServerId: UUID;\n\t\tname: string;\n\t\ttype: string;\n\t\tsourceType?: string;\n\t\tsourceId?: string;\n\t\ttopic?: string;\n\t\tmetadata?: Metadata;\n\t\tcreatedAt: Date;\n\t\tupdatedAt: Date;\n\t} | null> {\n\t\treturn this.withDatabase(async () => {\n\t\t\tconst results = await this.db\n\t\t\t\t.select()\n\t\t\t\t.from(channelTable)\n\t\t\t\t.where(eq(channelTable.id, channelId))\n\t\t\t\t.limit(1);\n\t\t\treturn results.length > 0\n\t\t\t\t? {\n\t\t\t\t\t\tid: results[0].id as UUID,\n\t\t\t\t\t\tmessageServerId: results[0].messageServerId as UUID,\n\t\t\t\t\t\tname: results[0].name,\n\t\t\t\t\t\ttype: results[0].type,\n\t\t\t\t\t\tsourceType: results[0].sourceType || undefined,\n\t\t\t\t\t\tsourceId: results[0].sourceId || undefined,\n\t\t\t\t\t\ttopic: results[0].topic || undefined,\n\t\t\t\t\t\tmetadata: (results[0].metadata || undefined) as\n\t\t\t\t\t\t\t| Metadata\n\t\t\t\t\t\t\t| undefined,\n\t\t\t\t\t\tcreatedAt: results[0].createdAt,\n\t\t\t\t\t\tupdatedAt: results[0].updatedAt,\n\t\t\t\t\t}\n\t\t\t\t: null;\n\t\t});\n\t}\n\n\t/**\n\t * Creates a message\n\t */\n\tasync createMessage(data: {\n\t\tchannelId: UUID;\n\t\tauthorId: UUID;\n\t\tcontent: string;\n\t\trawMessage?: Record<string, unknown>;\n\t\tsourceType?: string;\n\t\tsourceId?: string;\n\t\tmetadata?: Metadata;\n\t\tinReplyToRootMessageId?: UUID;\n\t\tmessageId?: UUID;\n\t}): Promise<{\n\t\tid: UUID;\n\t\tchannelId: UUID;\n\t\tauthorId: UUID;\n\t\tcontent: string;\n\t\trawMessage?: Record<string, unknown>;\n\t\tsourceType?: string;\n\t\tsourceId?: string;\n\t\tmetadata?: Metadata;\n\t\tinReplyToRootMessageId?: UUID;\n\t\tcreatedAt: Date;\n\t\tupdatedAt: Date;\n\t}> {\n\t\treturn this.withDatabase(async () => {\n\t\t\tconst newId = data.messageId || (v4() as UUID);\n\t\t\tconst now = new Date();\n\t\t\tconst messageToInsert = {\n\t\t\t\tid: newId,\n\t\t\t\tchannelId: data.channelId,\n\t\t\t\tauthorId: data.authorId,\n\t\t\t\tcontent: data.content,\n\t\t\t\trawMessage: data.rawMessage,\n\t\t\t\tsourceType: data.sourceType,\n\t\t\t\tsourceId: data.sourceId,\n\t\t\t\tmetadata: data.metadata,\n\t\t\t\tinReplyToRootMessageId: data.inReplyToRootMessageId,\n\t\t\t\tcreatedAt: now,\n\t\t\t\tupdatedAt: now,\n\t\t\t};\n\n\t\t\tawait this.db.insert(messageTable).values(messageToInsert);\n\t\t\treturn messageToInsert;\n\t\t});\n\t}\n\n\tasync getMessageById(id: UUID): Promise<{\n\t\tid: UUID;\n\t\tchannelId: UUID;\n\t\tauthorId: UUID;\n\t\tcontent: string;\n\t\trawMessage?: Record<string, unknown>;\n\t\tsourceType?: string;\n\t\tsourceId?: string;\n\t\tmetadata?: Metadata;\n\t\tinReplyToRootMessageId?: UUID;\n\t\tcreatedAt: Date;\n\t\tupdatedAt: Date;\n\t} | null> {\n\t\treturn this.withDatabase(async () => {\n\t\t\tconst rows = await this.db\n\t\t\t\t.select()\n\t\t\t\t.from(messageTable)\n\t\t\t\t.where(eq(messageTable.id, id))\n\t\t\t\t.limit(1);\n\t\t\tif (!rows || rows.length === 0) return null;\n\t\t\tconst row = rows[0];\n\t\t\treturn {\n\t\t\t\tid: row.id as UUID,\n\t\t\t\tchannelId: row.channelId as UUID,\n\t\t\t\tauthorId: row.authorId as UUID,\n\t\t\t\tcontent: row.content,\n\t\t\t\trawMessage: row.rawMessage || undefined,\n\t\t\t\tsourceType: row.sourceType || undefined,\n\t\t\t\tsourceId: row.sourceId || undefined,\n\t\t\t\tmetadata: (row.metadata || undefined) as Metadata | undefined,\n\t\t\t\tinReplyToRootMessageId: (row.inReplyToRootMessageId || undefined) as\n\t\t\t\t\t| UUID\n\t\t\t\t\t| undefined,\n\t\t\t\tcreatedAt: row.createdAt,\n\t\t\t\tupdatedAt: row.updatedAt,\n\t\t\t};\n\t\t});\n\t}\n\n\tasync updateMessage(\n\t\tid: UUID,\n\t\tpatch: {\n\t\t\tcontent?: string;\n\t\t\trawMessage?: Record<string, unknown>;\n\t\t\tsourceType?: string;\n\t\t\tsourceId?: string;\n\t\t\tmetadata?: Metadata;\n\t\t\tinReplyToRootMessageId?: UUID;\n\t\t},\n\t): Promise<{\n\t\tid: UUID;\n\t\tchannelId: UUID;\n\t\tauthorId: UUID;\n\t\tcontent: string;\n\t\trawMessage?: Record<string, unknown>;\n\t\tsourceType?: string;\n\t\tsourceId?: string;\n\t\tmetadata?: Metadata;\n\t\tinReplyToRootMessageId?: UUID;\n\t\tcreatedAt: Date;\n\t\tupdatedAt: Date;\n\t} | null> {\n\t\treturn this.withDatabase(async () => {\n\t\t\tconst existing = await this.getMessageById(id);\n\t\t\tif (!existing) return null;\n\n\t\t\tconst updatedAt = new Date();\n\t\t\tconst next = {\n\t\t\t\tcontent: patch.content ?? existing.content,\n\t\t\t\trawMessage: patch.rawMessage ?? existing.rawMessage,\n\t\t\t\tsourceType: patch.sourceType ?? existing.sourceType,\n\t\t\t\tsourceId: patch.sourceId ?? existing.sourceId,\n\t\t\t\tmetadata: patch.metadata ?? existing.metadata,\n\t\t\t\tinReplyToRootMessageId:\n\t\t\t\t\tpatch.inReplyToRootMessageId ?? existing.inReplyToRootMessageId,\n\t\t\t\tupdatedAt,\n\t\t\t};\n\n\t\t\tawait this.db\n\t\t\t\t.update(messageTable)\n\t\t\t\t.set(next)\n\t\t\t\t.where(eq(messageTable.id, id));\n\n\t\t\t// Return merged object\n\t\t\treturn {\n\t\t\t\t...existing,\n\t\t\t\t...next,\n\t\t\t};\n\t\t});\n\t}\n\n\t/**\n\t * Gets messages for a channel\n\t */\n\tasync getMessagesForChannel(\n\t\tchannelId: UUID,\n\t\tlimit: number = 50,\n\t\tbeforeTimestamp?: Date,\n\t): Promise<\n\t\tArray<{\n\t\t\tid: UUID;\n\t\t\tchannelId: UUID;\n\t\t\tauthorId: UUID;\n\t\t\tcontent: string;\n\t\t\trawMessage?: Record<string, unknown>;\n\t\t\tsourceType?: string;\n\t\t\tsourceId?: string;\n\t\t\tmetadata?: Metadata;\n\t\t\tinReplyToRootMessageId?: UUID;\n\t\t\tcreatedAt: Date;\n\t\t\tupdatedAt: Date;\n\t\t}>\n\t> {\n\t\treturn this.withDatabase(async () => {\n\t\t\tconst conditions = [eq(messageTable.channelId, channelId)];\n\t\t\tif (beforeTimestamp) {\n\t\t\t\tconditions.push(lt(messageTable.createdAt, beforeTimestamp));\n\t\t\t}\n\n\t\t\tconst query = this.db\n\t\t\t\t.select()\n\t\t\t\t.from(messageTable)\n\t\t\t\t.where(and(...conditions))\n\t\t\t\t.orderBy(desc(messageTable.createdAt))\n\t\t\t\t.limit(limit);\n\n\t\t\tconst results = await query;\n\t\t\treturn results.map((r) => ({\n\t\t\t\tid: r.id as UUID,\n\t\t\t\tchannelId: r.channelId as UUID,\n\t\t\t\tauthorId: r.authorId as UUID,\n\t\t\t\tcontent: r.content,\n\t\t\t\trawMessage: r.rawMessage || undefined,\n\t\t\t\tsourceType: r.sourceType || undefined,\n\t\t\t\tsourceId: r.sourceId || undefined,\n\t\t\t\tmetadata: r.metadata || undefined,\n\t\t\t\tinReplyToRootMessageId: r.inReplyToRootMessageId as UUID | undefined,\n\t\t\t\tcreatedAt: r.createdAt,\n\t\t\t\tupdatedAt: r.updatedAt,\n\t\t\t}));\n\t\t});\n\t}\n\n\t/**\n\t * Deletes a message\n\t */\n\tasync deleteMessage(messageId: UUID): Promise<void> {\n\t\treturn this.withDatabase(async () => {\n\t\t\tawait this.db.delete(messageTable).where(eq(messageTable.id, messageId));\n\t\t});\n\t}\n\n\t/**\n\t * Updates a channel\n\t */\n\tasync updateChannel(\n\t\tchannelId: UUID,\n\t\tupdates: {\n\t\t\tname?: string;\n\t\t\tparticipantCentralUserIds?: UUID[];\n\t\t\tmetadata?: Metadata;\n\t\t},\n\t): Promise<{\n\t\tid: UUID;\n\t\tmessageServerId: UUID;\n\t\tname: string;\n\t\ttype: string;\n\t\tsourceType?: string;\n\t\tsourceId?: string;\n\t\ttopic?: string;\n\t\tmetadata?: Metadata;\n\t\tcreatedAt: Date;\n\t\tupdatedAt: Date;\n\t}> {\n\t\treturn this.withDatabase(async () => {\n\t\t\tconst now = new Date();\n\n\t\t\tawait this.db.transaction(async (tx) => {\n\t\t\t\t// Update channel details\n\t\t\t\tconst updateData: Record<string, unknown> = { updatedAt: now };\n\t\t\t\tif (updates.name !== undefined) updateData.name = updates.name;\n\t\t\t\tif (updates.metadata !== undefined)\n\t\t\t\t\tupdateData.metadata = updates.metadata;\n\n\t\t\t\tawait tx\n\t\t\t\t\t.update(channelTable)\n\t\t\t\t\t.set(updateData)\n\t\t\t\t\t.where(eq(channelTable.id, channelId));\n\n\t\t\t\t// Update participants if provided\n\t\t\t\tif (updates.participantCentralUserIds !== undefined) {\n\t\t\t\t\t// Remove existing participants\n\t\t\t\t\tawait tx\n\t\t\t\t\t\t.delete(channelParticipantsTable)\n\t\t\t\t\t\t.where(eq(channelParticipantsTable.channelId, channelId));\n\n\t\t\t\t\t// Add new participants\n\t\t\t\t\tif (updates.participantCentralUserIds.length > 0) {\n\t\t\t\t\t\tconst participantValues = updates.participantCentralUserIds.map(\n\t\t\t\t\t\t\t(entityId) => ({\n\t\t\t\t\t\t\t\tchannelId: channelId,\n\t\t\t\t\t\t\t\tentityId: entityId,\n\t\t\t\t\t\t\t}),\n\t\t\t\t\t\t);\n\t\t\t\t\t\tawait tx\n\t\t\t\t\t\t\t.insert(channelParticipantsTable)\n\t\t\t\t\t\t\t.values(participantValues)\n\t\t\t\t\t\t\t.onConflictDoNothing();\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t});\n\n\t\t\t// Return updated channel details\n\t\t\tconst updatedChannel = await this.getChannelDetails(channelId);\n\t\t\tif (!updatedChannel) {\n\t\t\t\tthrow new Error(`Channel ${channelId} not found after update`);\n\t\t\t}\n\t\t\treturn updatedChannel;\n\t\t});\n\t}\n\n\t/**\n\t * Deletes a channel and all its associated data\n\t */\n\tasync deleteChannel(channelId: UUID): Promise<void> {\n\t\treturn this.withDatabase(async () => {\n\t\t\tawait this.db.transaction(async (tx) => {\n\t\t\t\t// Delete all messages in the channel (cascade delete will handle this, but explicit is better)\n\t\t\t\tawait tx\n\t\t\t\t\t.delete(messageTable)\n\t\t\t\t\t.where(eq(messageTable.channelId, channelId));\n\n\t\t\t\t// Delete all participants (cascade delete will handle this, but explicit is better)\n\t\t\t\tawait tx\n\t\t\t\t\t.delete(channelParticipantsTable)\n\t\t\t\t\t.where(eq(channelParticipantsTable.channelId, channelId));\n\n\t\t\t\t// Delete the channel itself\n\t\t\t\tawait tx.delete(channelTable).where(eq(channelTable.id, channelId));\n\t\t\t});\n\t\t});\n\t}\n\n\t/**\n\t * Adds participants to a channel\n\t */\n\tasync addChannelParticipants(\n\t\tchannelId: UUID,\n\t\tentityIds: UUID[],\n\t): Promise<void> {\n\t\treturn this.withDatabase(async () => {\n\t\t\tif (!entityIds || entityIds.length === 0) return;\n\n\t\t\tconst participantValues = entityIds.map((entityId) => ({\n\t\t\t\tchannelId: channelId,\n\t\t\t\tentityId: entityId,\n\t\t\t}));\n\n\t\t\tawait this.db\n\t\t\t\t.insert(channelParticipantsTable)\n\t\t\t\t.values(participantValues)\n\t\t\t\t.onConflictDoNothing();\n\t\t});\n\t}\n\n\t/**\n\t * Gets participants for a channel\n\t */\n\tasync getChannelParticipants(channelId: UUID): Promise<UUID[]> {\n\t\treturn this.withDatabase(async () => {\n\t\t\tconst results = await this.db\n\t\t\t\t.select({ entityId: channelParticipantsTable.entityId })\n\t\t\t\t.from(channelParticipantsTable)\n\t\t\t\t.where(eq(channelParticipantsTable.channelId, channelId));\n\n\t\t\treturn results.map((r) => r.entityId as UUID);\n\t\t});\n\t}\n\n\t/**\n\t * Check if an entity is a participant in a specific messaging channel.\n\t * @param {UUID} channelId - The ID of the channel to check.\n\t * @param {UUID} entityId - The ID of the entity to check.\n\t * @returns {Promise<boolean>} A Promise that resolves to true if entity is a participant.\n\t */\n\tasync isChannelParticipant(\n\t\tchannelId: UUID,\n\t\tentityId: UUID,\n\t): Promise<boolean> {\n\t\treturn this.withDatabase(async () => {\n\t\t\tconst result = await this.db\n\t\t\t\t.select()\n\t\t\t\t.from(channelParticipantsTable)\n\t\t\t\t.where(\n\t\t\t\t\tand(\n\t\t\t\t\t\teq(channelParticipantsTable.channelId, channelId),\n\t\t\t\t\t\teq(channelParticipantsTable.entityId, entityId),\n\t\t\t\t\t),\n\t\t\t\t)\n\t\t\t\t.limit(1);\n\n\t\t\treturn result.length > 0;\n\t\t});\n\t}\n\n\t/**\n\t * Adds an agent to a message server (Discord/Telegram server)\n\t */\n\tasync addAgentToMessageServer(\n\t\tmessageServerId: UUID,\n\t\tagentId: UUID,\n\t): Promise<void> {\n\t\treturn this.withDatabase(async () => {\n\t\t\tawait this.db\n\t\t\t\t.insert(messageServerAgentsTable)\n\t\t\t\t.values({\n\t\t\t\t\tmessageServerId,\n\t\t\t\t\tagentId,\n\t\t\t\t})\n\t\t\t\t.onConflictDoNothing();\n\t\t});\n\t}\n\n\t/**\n\t * Gets agents for a message server (Discord/Telegram server)\n\t */\n\tasync getAgentsForMessageServer(messageServerId: UUID): Promise<UUID[]> {\n\t\treturn this.withDatabase(async () => {\n\t\t\tconst results = await this.db\n\t\t\t\t.select({ agentId: messageServerAgentsTable.agentId })\n\t\t\t\t.from(messageServerAgentsTable)\n\t\t\t\t.where(eq(messageServerAgentsTable.messageServerId, messageServerId));\n\n\t\t\treturn results.map((r) => r.agentId as UUID);\n\t\t});\n\t}\n\n\t/**\n\t * Removes an agent from a message server (Discord/Telegram server)\n\t */\n\tasync removeAgentFromMessageServer(\n\t\tmessageServerId: UUID,\n\t\tagentId: UUID,\n\t): Promise<void> {\n\t\treturn this.withDatabase(async () => {\n\t\t\tawait this.db\n\t\t\t\t.delete(messageServerAgentsTable)\n\t\t\t\t.where(\n\t\t\t\t\tand(\n\t\t\t\t\t\teq(messageServerAgentsTable.messageServerId, messageServerId),\n\t\t\t\t\t\teq(messageServerAgentsTable.agentId, agentId),\n\t\t\t\t\t),\n\t\t\t\t);\n\t\t});\n\t}\n\n\t/**\n\t * Finds or creates a DM channel between two users\n\t */\n\tasync findOrCreateDmChannel(\n\t\tuser1Id: UUID,\n\t\tuser2Id: UUID,\n\t\tmessageServerId: UUID,\n\t): Promise<{\n\t\tid: UUID;\n\t\tmessageServerId: UUID;\n\t\tname: string;\n\t\ttype: string;\n\t\tsourceType?: string;\n\t\tsourceId?: string;\n\t\ttopic?: string;\n\t\tmetadata?: Metadata;\n\t\tcreatedAt: Date;\n\t\tupdatedAt: Date;\n\t}> {\n\t\treturn this.withDatabase(async () => {\n\t\t\tconst ids = [user1Id, user2Id].sort();\n\t\t\tconst dmChannelName = `DM-${ids[0]}-${ids[1]}`;\n\n\t\t\tconst existingChannels = await this.db\n\t\t\t\t.select()\n\t\t\t\t.from(channelTable)\n\t\t\t\t.where(\n\t\t\t\t\tand(\n\t\t\t\t\t\teq(channelTable.type, ChannelType.DM),\n\t\t\t\t\t\teq(channelTable.name, dmChannelName),\n\t\t\t\t\t\teq(channelTable.messageServerId, messageServerId),\n\t\t\t\t\t),\n\t\t\t\t)\n\t\t\t\t.limit(1);\n\n\t\t\tif (existingChannels.length > 0) {\n\t\t\t\treturn {\n\t\t\t\t\tid: existingChannels[0].id as UUID,\n\t\t\t\t\tmessageServerId: existingChannels[0].messageServerId as UUID,\n\t\t\t\t\tname: existingChannels[0].name,\n\t\t\t\t\ttype: existingChannels[0].type,\n\t\t\t\t\tsourceType: existingChannels[0].sourceType || undefined,\n\t\t\t\t\tsourceId: existingChannels[0].sourceId || undefined,\n\t\t\t\t\ttopic: existingChannels[0].topic || undefined,\n\t\t\t\t\tmetadata: (existingChannels[0].metadata || undefined) as\n\t\t\t\t\t\t| Metadata\n\t\t\t\t\t\t| undefined,\n\t\t\t\t\tcreatedAt: existingChannels[0].createdAt,\n\t\t\t\t\tupdatedAt: existingChannels[0].updatedAt,\n\t\t\t\t};\n\t\t\t}\n\n\t\t\t// Create new DM channel\n\t\t\treturn this.createChannel(\n\t\t\t\t{\n\t\t\t\t\tmessageServerId,\n\t\t\t\t\tname: dmChannelName,\n\t\t\t\t\ttype: ChannelType.DM,\n\t\t\t\t\tmetadata: { user1: ids[0], user2: ids[1] },\n\t\t\t\t},\n\t\t\t\tids,\n\t\t\t);\n\t\t});\n\t}\n\n\t// ===============================\n\t// Pairing Methods\n\t// ===============================\n\n\t/**\n\t * Get all pending pairing requests for a channel and agent.\n\t */\n\tasync getPairingRequests(\n\t\tchannel: PairingChannel,\n\t\tagentId: UUID,\n\t): Promise<PairingRequest[]> {\n\t\treturn this.withDatabase(async () => {\n\t\t\tconst results = await this.db\n\t\t\t\t.select()\n\t\t\t\t.from(pairingRequestTable)\n\t\t\t\t.where(\n\t\t\t\t\tand(\n\t\t\t\t\t\teq(pairingRequestTable.channel, channel),\n\t\t\t\t\t\teq(pairingRequestTable.agentId, agentId),\n\t\t\t\t\t),\n\t\t\t\t)\n\t\t\t\t.orderBy(pairingRequestTable.createdAt);\n\n\t\t\treturn results.map((row) => ({\n\t\t\t\tid: row.id as UUID,\n\t\t\t\tchannel: row.channel as PairingChannel,\n\t\t\t\tsenderId: row.senderId,\n\t\t\t\tcode: row.code,\n\t\t\t\tcreatedAt: row.createdAt,\n\t\t\t\tlastSeenAt: row.lastSeenAt,\n\t\t\t\tmetadata: (row.metadata as Record<string, string>) || undefined,\n\t\t\t\tagentId: row.agentId as UUID,\n\t\t\t}));\n\t\t});\n\t}\n\n\t/**\n\t * Create a new pairing request.\n\t */\n\tasync createPairingRequest(request: PairingRequest): Promise<UUID> {\n\t\treturn this.withDatabase(async () => {\n\t\t\tconst id = request.id || (v4() as UUID);\n\t\t\tawait this.db.insert(pairingRequestTable).values({\n\t\t\t\tid,\n\t\t\t\tchannel: request.channel,\n\t\t\t\tsenderId: request.senderId,\n\t\t\t\tcode: request.code,\n\t\t\t\tcreatedAt: request.createdAt,\n\t\t\t\tlastSeenAt: request.lastSeenAt,\n\t\t\t\tmetadata: request.metadata || {},\n\t\t\t\tagentId: request.agentId,\n\t\t\t});\n\t\t\treturn id;\n\t\t});\n\t}\n\n\t/**\n\t * Update an existing pairing request.\n\t */\n\tasync updatePairingRequest(request: PairingRequest): Promise<void> {\n\t\treturn this.withDatabase(async () => {\n\t\t\tawait this.db\n\t\t\t\t.update(pairingRequestTable)\n\t\t\t\t.set({\n\t\t\t\t\tlastSeenAt: request.lastSeenAt,\n\t\t\t\t\tmetadata: request.metadata || {},\n\t\t\t\t})\n\t\t\t\t.where(eq(pairingRequestTable.id, request.id));\n\t\t});\n\t}\n\n\t/**\n\t * Delete a pairing request by ID.\n\t */\n\tasync deletePairingRequest(id: UUID): Promise<void> {\n\t\treturn this.withDatabase(async () => {\n\t\t\tawait this.db\n\t\t\t\t.delete(pairingRequestTable)\n\t\t\t\t.where(eq(pairingRequestTable.id, id));\n\t\t});\n\t}\n\n\t/**\n\t * Get the allowlist for a channel and agent.\n\t */\n\tasync getPairingAllowlist(\n\t\tchannel: PairingChannel,\n\t\tagentId: UUID,\n\t): Promise<PairingAllowlistEntry[]> {\n\t\treturn this.withDatabase(async () => {\n\t\t\tconst results = await this.db\n\t\t\t\t.select()\n\t\t\t\t.from(pairingAllowlistTable)\n\t\t\t\t.where(\n\t\t\t\t\tand(\n\t\t\t\t\t\teq(pairingAllowlistTable.channel, channel),\n\t\t\t\t\t\teq(pairingAllowlistTable.agentId, agentId),\n\t\t\t\t\t),\n\t\t\t\t)\n\t\t\t\t.orderBy(pairingAllowlistTable.createdAt);\n\n\t\t\treturn results.map((row) => ({\n\t\t\t\tid: row.id as UUID,\n\t\t\t\tchannel: row.channel as PairingChannel,\n\t\t\t\tsenderId: row.senderId,\n\t\t\t\tcreatedAt: row.createdAt,\n\t\t\t\tmetadata: (row.metadata as Record<string, string>) || undefined,\n\t\t\t\tagentId: row.agentId as UUID,\n\t\t\t}));\n\t\t});\n\t}\n\n\t/**\n\t * Create a new allowlist entry.\n\t */\n\tasync createPairingAllowlistEntry(\n\t\tentry: PairingAllowlistEntry,\n\t): Promise<UUID> {\n\t\treturn this.withDatabase(async () => {\n\t\t\tconst id = entry.id || (v4() as UUID);\n\t\t\tawait this.db\n\t\t\t\t.insert(pairingAllowlistTable)\n\t\t\t\t.values({\n\t\t\t\t\tid,\n\t\t\t\t\tchannel: entry.channel,\n\t\t\t\t\tsenderId: entry.senderId,\n\t\t\t\t\tcreatedAt: entry.createdAt,\n\t\t\t\t\tmetadata: entry.metadata || {},\n\t\t\t\t\tagentId: entry.agentId,\n\t\t\t\t})\n\t\t\t\t.onConflictDoNothing();\n\t\t\treturn id;\n\t\t});\n\t}\n\n\t/**\n\t * Delete an allowlist entry by ID.\n\t */\n\tasync deletePairingAllowlistEntry(id: UUID): Promise<void> {\n\t\treturn this.withDatabase(async () => {\n\t\t\tawait this.db\n\t\t\t\t.delete(pairingAllowlistTable)\n\t\t\t\t.where(eq(pairingAllowlistTable.id, id));\n\t\t});\n\t}\n}\n\n// Import tables at the end to avoid circular dependencies\n",
121
+ "import { VECTOR_DIMS } from \"@elizaos/core\";\nimport { relations, sql } from \"drizzle-orm\";\nimport {\n\tcheck,\n\tforeignKey,\n\tindex,\n\tpgTable,\n\ttimestamp,\n\tuuid,\n\tvector,\n} from \"drizzle-orm/pg-core\";\nimport { memoryTable } from \"./memory\";\n\nexport const DIMENSION_MAP = {\n\t[VECTOR_DIMS.SMALL]: \"dim384\",\n\t[VECTOR_DIMS.MEDIUM]: \"dim512\",\n\t[VECTOR_DIMS.LARGE]: \"dim768\",\n\t[VECTOR_DIMS.XL]: \"dim1024\",\n\t[VECTOR_DIMS.XXL]: \"dim1536\",\n\t[VECTOR_DIMS.XXXL]: \"dim3072\",\n} as const;\n\n/**\n * Definition of the embeddings table in the database.\n * Contains columns for ID, Memory ID, Creation Timestamp, and multiple vector dimensions.\n */\nexport const embeddingTable = pgTable(\n\t\"embeddings\",\n\t{\n\t\tid: uuid(\"id\").primaryKey().defaultRandom().notNull(),\n\t\tmemoryId: uuid(\"memory_id\").references(() => memoryTable.id, {\n\t\t\tonDelete: \"cascade\",\n\t\t}),\n\t\tcreatedAt: timestamp(\"created_at\").default(sql`now()`).notNull(),\n\t\tdim384: vector(\"dim_384\", { dimensions: VECTOR_DIMS.SMALL }),\n\t\tdim512: vector(\"dim_512\", { dimensions: VECTOR_DIMS.MEDIUM }),\n\t\tdim768: vector(\"dim_768\", { dimensions: VECTOR_DIMS.LARGE }),\n\t\tdim1024: vector(\"dim_1024\", { dimensions: VECTOR_DIMS.XL }),\n\t\tdim1536: vector(\"dim_1536\", { dimensions: VECTOR_DIMS.XXL }),\n\t\tdim3072: vector(\"dim_3072\", { dimensions: VECTOR_DIMS.XXXL }),\n\t},\n\t(table) => [\n\t\tcheck(\"embedding_source_check\", sql`\"memory_id\" IS NOT NULL`),\n\t\tindex(\"idx_embedding_memory\").on(table.memoryId),\n\t\tforeignKey({\n\t\t\tname: \"fk_embedding_memory\",\n\t\t\tcolumns: [table.memoryId],\n\t\t\tforeignColumns: [memoryTable.id],\n\t\t}).onDelete(\"cascade\"),\n\t],\n);\n\n/**\n * Defines the possible values for the Embedding Dimension Column.\n * It can be \"dim384\", \"dim512\", \"dim768\", \"dim1024\", \"dim1536\", or \"dim3072\".\n */\nexport type EmbeddingDimensionColumn =\n\t| \"dim384\"\n\t| \"dim512\"\n\t| \"dim768\"\n\t| \"dim1024\"\n\t| \"dim1536\"\n\t| \"dim3072\";\n\n/**\n * Retrieve the type of a specific column in the EmbeddingTable based on the EmbeddingDimensionColumn key.\n */\nexport type EmbeddingTableColumn =\n\t(typeof embeddingTable._.columns)[EmbeddingDimensionColumn];\n\n// Relations - defined here to avoid circular dependency with memory.ts\nexport const memoryRelations = relations(memoryTable, ({ one }) => ({\n\tembedding: one(embeddingTable),\n}));\n",
122
+ "import { sql } from \"drizzle-orm\";\nimport {\n\tboolean,\n\tcheck,\n\tforeignKey,\n\tindex,\n\tjsonb,\n\tpgTable,\n\ttext,\n\ttimestamp,\n\tuuid,\n} from \"drizzle-orm/pg-core\";\nimport { agentTable } from \"./agent\";\nimport { entityTable } from \"./entity\";\nimport { roomTable } from \"./room\";\n\n/**\n * Definition of the memory table in the database.\n *\n * @param {string} tableName - The name of the table.\n * @param {object} columns - An object containing the column definitions.\n * @param {function} indexes - A function that defines the indexes for the table.\n * @returns {object} - The memory table object.\n */\nexport const memoryTable = pgTable(\n\t\"memories\",\n\t{\n\t\tid: uuid(\"id\").primaryKey().notNull(),\n\t\ttype: text(\"type\").notNull(),\n\t\tcreatedAt: timestamp(\"created_at\").default(sql`now()`).notNull(),\n\t\tcontent: jsonb(\"content\").notNull(),\n\t\tentityId: uuid(\"entity_id\").references(() => entityTable.id, {\n\t\t\tonDelete: \"cascade\",\n\t\t}),\n\t\tagentId: uuid(\"agent_id\")\n\t\t\t.references(() => agentTable.id, {\n\t\t\t\tonDelete: \"cascade\",\n\t\t\t})\n\t\t\t.notNull(),\n\t\troomId: uuid(\"room_id\").references(() => roomTable.id, {\n\t\t\tonDelete: \"cascade\",\n\t\t}),\n\t\tworldId: uuid(\"world_id\"),\n\t\t// .references(() => worldTable.id, {\n\t\t// onDelete: 'set null',\n\t\t// }),\n\t\tunique: boolean(\"unique\").default(true).notNull(),\n\t\tmetadata: jsonb(\"metadata\").default({}).notNull(),\n\t},\n\t(table) => [\n\t\tindex(\"idx_memories_type_room\").on(table.type, table.roomId),\n\t\tindex(\"idx_memories_world_id\").on(table.worldId),\n\t\tforeignKey({\n\t\t\tname: \"fk_room\",\n\t\t\tcolumns: [table.roomId],\n\t\t\tforeignColumns: [roomTable.id],\n\t\t}).onDelete(\"cascade\"),\n\t\tforeignKey({\n\t\t\tname: \"fk_user\",\n\t\t\tcolumns: [table.entityId],\n\t\t\tforeignColumns: [entityTable.id],\n\t\t}).onDelete(\"cascade\"),\n\t\tforeignKey({\n\t\t\tname: \"fk_agent\",\n\t\t\tcolumns: [table.agentId],\n\t\t\tforeignColumns: [agentTable.id],\n\t\t}).onDelete(\"cascade\"),\n\t\t// foreignKey({\n\t\t// name: 'fk_world',\n\t\t// columns: [table.worldId],\n\t\t// foreignColumns: [worldTable.id],\n\t\t// }).onDelete('set null'),\n\t\tindex(\"idx_memories_metadata_type\").on(sql`((metadata->>'type'))`),\n\t\tindex(\"idx_memories_document_id\").on(sql`((metadata->>'documentId'))`),\n\t\tindex(\"idx_fragments_order\").on(\n\t\t\tsql`((metadata->>'documentId'))`,\n\t\t\tsql`((metadata->>'position'))`,\n\t\t),\n\t\tcheck(\n\t\t\t\"fragment_metadata_check\",\n\t\t\tsql`\n CASE \n WHEN metadata->>'type' = 'fragment' THEN\n metadata ? 'documentId' AND \n metadata ? 'position'\n ELSE true\n END\n `,\n\t\t),\n\t\tcheck(\n\t\t\t\"document_metadata_check\",\n\t\t\tsql`\n CASE \n WHEN metadata->>'type' = 'document' THEN\n metadata ? 'timestamp'\n ELSE true\n END\n `,\n\t\t),\n\t],\n);\n\n// Relations are defined in embedding.ts to avoid circular dependency\n",
123
+ "import type { Metadata } from \"@elizaos/core\";\nimport { sql } from \"drizzle-orm\";\nimport {\n\tjsonb,\n\tpgTable,\n\ttext,\n\ttimestamp,\n\tunique,\n\tuuid,\n} from \"drizzle-orm/pg-core\";\nimport { agentTable } from \"./agent\";\n\n/**\n * Represents an entity table in the database.\n * Includes columns for id, agentId, createdAt, names, and metadata.\n */\nexport const entityTable = pgTable(\n\t\"entities\",\n\t{\n\t\tid: uuid(\"id\").notNull().primaryKey(),\n\t\tagentId: uuid(\"agent_id\")\n\t\t\t.notNull()\n\t\t\t.references(() => agentTable.id, {\n\t\t\t\tonDelete: \"cascade\",\n\t\t\t}),\n\t\tcreatedAt: timestamp(\"created_at\").default(sql`now()`).notNull(),\n\t\tnames: text(\"names\").array().default(sql`'{}'::text[]`).notNull(),\n\t\tmetadata: jsonb(\"metadata\")\n\t\t\t.$type<Metadata>()\n\t\t\t.default(sql`'{}'::jsonb`)\n\t\t\t.notNull(),\n\t},\n\t(table) => {\n\t\treturn {\n\t\t\tidAgentIdUnique: unique(\"id_agent_id_unique\").on(table.id, table.agentId),\n\t\t};\n\t},\n);\n",
124
+ "import type { Metadata } from \"@elizaos/core\";\nimport { sql } from \"drizzle-orm\";\nimport { jsonb, pgTable, text, timestamp, uuid } from \"drizzle-orm/pg-core\";\nimport { agentTable } from \"./agent\";\n\n/**\n * Defines a table schema for 'rooms' in the database.\n *\n * @typedef {object} RoomTable\n * @property {string} id - The unique identifier for the room.\n * @property {string} agentId - The UUID of the agent associated with the room.\n * @property {string} source - The source of the room.\n * @property {string} type - The type of the room.\n * @property {string} messageServerId - The message server ID of the room.\n * @property {string} worldId - The UUID of the world associated with the room.\n * @property {string} name - The name of the room.\n * @property {object} metadata - Additional metadata for the room in JSON format.\n * @property {string} channelId - The channel ID of the room.\n * @property {number} createdAt - The timestamp of when the room was created.\n */\nexport const roomTable = pgTable(\"rooms\", {\n\tid: uuid(\"id\").notNull().primaryKey().default(sql`gen_random_uuid()`),\n\tagentId: uuid(\"agent_id\").references(() => agentTable.id, {\n\t\tonDelete: \"cascade\",\n\t}),\n\tsource: text(\"source\").notNull(),\n\ttype: text(\"type\").notNull(),\n\tmessageServerId: uuid(\"message_server_id\"),\n\tworldId: uuid(\"world_id\"), // no guarantee that world exists, it is optional for now\n\t// .references(() => worldTable.id, {\n\t// onDelete: 'cascade',\n\t// }),\n\tname: text(\"name\"),\n\tmetadata: jsonb(\"metadata\").$type<Metadata>(),\n\tchannelId: text(\"channel_id\"),\n\tcreatedAt: timestamp(\"created_at\").default(sql`now()`).notNull(),\n});\n",
125
+ "export { agentTable } from \"./agent\";\nexport { cacheTable } from \"./cache\";\nexport { channelTable } from \"./channel\";\nexport { channelParticipantsTable } from \"./channelParticipant\";\nexport { componentTable } from \"./component\";\nexport { embeddingTable } from \"./embedding\";\nexport { entityTable } from \"./entity\";\nexport { logTable } from \"./log\";\nexport { memoryTable } from \"./memory\";\nexport { messageTable } from \"./message\";\nexport { messageServerTable } from \"./messageServer\";\nexport { messageServerAgentsTable } from \"./messageServerAgent\";\nexport { pairingAllowlistTable } from \"./pairingAllowlist\";\nexport { pairingRequestTable } from \"./pairingRequest\";\nexport { participantTable } from \"./participant\";\nexport { relationshipTable } from \"./relationship\";\nexport { roomTable } from \"./room\";\nexport { serverTable } from \"./server\";\nexport { taskTable } from \"./tasks\";\nexport { worldTable } from \"./world\";\n",
126
+ "import { sql } from \"drizzle-orm\";\nimport {\n\tjsonb,\n\tpgTable,\n\tprimaryKey,\n\ttext,\n\ttimestamp,\n\tuuid,\n} from \"drizzle-orm/pg-core\";\nimport { agentTable } from \"./agent\";\n\n/**\n * Represents a PostgreSQL table for caching data.\n *\n * @type {pgTable}\n */\nexport const cacheTable = pgTable(\n\t\"cache\",\n\t{\n\t\tkey: text(\"key\").notNull(),\n\t\tagentId: uuid(\"agent_id\")\n\t\t\t.notNull()\n\t\t\t.references(() => agentTable.id, { onDelete: \"cascade\" }),\n\t\tvalue: jsonb(\"value\").notNull(),\n\t\tcreatedAt: timestamp(\"created_at\", { withTimezone: true })\n\t\t\t.default(sql`now()`)\n\t\t\t.notNull(),\n\t\texpiresAt: timestamp(\"expires_at\", { withTimezone: true }),\n\t},\n\t(table) => [primaryKey({ columns: [table.key, table.agentId] })],\n);\n",
127
+ "import { sql } from \"drizzle-orm\";\nimport { jsonb, pgTable, text, timestamp, uuid } from \"drizzle-orm/pg-core\";\nimport { messageServerTable } from \"./messageServer\";\n\nexport const channelTable = pgTable(\"channels\", {\n\tid: text(\"id\").primaryKey(), // UUID stored as text\n\tmessageServerId: uuid(\"message_server_id\")\n\t\t.notNull()\n\t\t.references(() => messageServerTable.id, { onDelete: \"cascade\" }),\n\tname: text(\"name\").notNull(),\n\ttype: text(\"type\").notNull(), // Store ChannelType enum values as text\n\tsourceType: text(\"source_type\"),\n\tsourceId: text(\"source_id\"),\n\ttopic: text(\"topic\"),\n\tmetadata: jsonb(\"metadata\"),\n\t// server_id is added dynamically by RLS setup\n\tcreatedAt: timestamp(\"created_at\", { mode: \"date\" })\n\t\t.default(sql`CURRENT_TIMESTAMP`)\n\t\t.notNull(),\n\tupdatedAt: timestamp(\"updated_at\", { mode: \"date\" })\n\t\t.default(sql`CURRENT_TIMESTAMP`)\n\t\t.notNull(),\n});\n",
128
+ "import { sql } from \"drizzle-orm\";\nimport { jsonb, pgTable, text, timestamp, uuid } from \"drizzle-orm/pg-core\";\n\nexport const messageServerTable = pgTable(\"message_servers\", {\n\tid: uuid(\"id\").primaryKey(),\n\tname: text(\"name\").notNull(),\n\tsourceType: text(\"source_type\").notNull(),\n\tsourceId: text(\"source_id\"),\n\tmetadata: jsonb(\"metadata\"),\n\tcreatedAt: timestamp(\"created_at\", { mode: \"date\" })\n\t\t.default(sql`CURRENT_TIMESTAMP`)\n\t\t.notNull(),\n\tupdatedAt: timestamp(\"updated_at\", { mode: \"date\" })\n\t\t.default(sql`CURRENT_TIMESTAMP`)\n\t\t.notNull(),\n});\n",
129
+ "import { pgTable, primaryKey, text } from \"drizzle-orm/pg-core\";\nimport { channelTable } from \"./channel\";\n\nexport const channelParticipantsTable = pgTable(\n\t\"channel_participants\",\n\t{\n\t\tchannelId: text(\"channel_id\")\n\t\t\t.notNull()\n\t\t\t.references(() => channelTable.id, { onDelete: \"cascade\" }),\n\t\tentityId: text(\"entity_id\").notNull(), // Entity UUID (can be an agentId or a dedicated central user ID)\n\t},\n\t(table) => [primaryKey({ columns: [table.channelId, table.entityId] })],\n);\n",
130
+ "import { sql } from \"drizzle-orm\";\nimport { jsonb, pgTable, text, timestamp, uuid } from \"drizzle-orm/pg-core\";\nimport { agentTable } from \"./agent\";\nimport { entityTable } from \"./entity\";\nimport { roomTable } from \"./room\";\nimport { worldTable } from \"./world\";\n\n/**\n * Represents a component table in the database.\n */\nexport const componentTable = pgTable(\"components\", {\n\tid: uuid(\"id\").primaryKey().default(sql`gen_random_uuid()`).notNull(),\n\n\t// Foreign keys\n\tentityId: uuid(\"entity_id\")\n\t\t.references(() => entityTable.id, { onDelete: \"cascade\" })\n\t\t.notNull(),\n\tagentId: uuid(\"agent_id\")\n\t\t.references(() => agentTable.id, { onDelete: \"cascade\" })\n\t\t.notNull(),\n\troomId: uuid(\"room_id\")\n\t\t.references(() => roomTable.id, { onDelete: \"cascade\" })\n\t\t.notNull(),\n\tworldId: uuid(\"world_id\").references(() => worldTable.id, {\n\t\tonDelete: \"cascade\",\n\t}),\n\tsourceEntityId: uuid(\"source_entity_id\").references(() => entityTable.id, {\n\t\tonDelete: \"cascade\",\n\t}),\n\n\t// Data\n\ttype: text(\"type\").notNull(),\n\tdata: jsonb(\"data\").default(sql`'{}'::jsonb`),\n\n\t// Timestamps\n\tcreatedAt: timestamp(\"created_at\").default(sql`now()`).notNull(),\n});\n",
131
+ "import { sql } from \"drizzle-orm\";\nimport { jsonb, pgTable, text, timestamp, uuid } from \"drizzle-orm/pg-core\";\nimport { agentTable } from \"./agent\";\n\n/**\n * Represents a table schema for worlds in the database.\n *\n * @type {PgTable}\n */\n\nexport const worldTable = pgTable(\"worlds\", {\n\tid: uuid(\"id\").notNull().primaryKey().default(sql`gen_random_uuid()`),\n\tagentId: uuid(\"agent_id\")\n\t\t.notNull()\n\t\t.references(() => agentTable.id, { onDelete: \"cascade\" }),\n\tname: text(\"name\").notNull(),\n\tmetadata: jsonb(\"metadata\"),\n\tmessageServerId: uuid(\"message_server_id\"),\n\tcreatedAt: timestamp(\"created_at\").default(sql`now()`).notNull(),\n});\n",
132
+ "import { sql } from \"drizzle-orm\";\nimport {\n\tforeignKey,\n\tjsonb,\n\tpgTable,\n\ttext,\n\ttimestamp,\n\tuuid,\n} from \"drizzle-orm/pg-core\";\nimport { entityTable } from \"./entity\";\nimport { roomTable } from \"./room\";\n\n/**\n * Represents a PostgreSQL table for storing logs.\n *\n * @type {Table}\n */\n\nexport const logTable = pgTable(\n\t\"logs\",\n\t{\n\t\tid: uuid(\"id\").defaultRandom().notNull(),\n\t\tcreatedAt: timestamp(\"created_at\", { withTimezone: true })\n\t\t\t.default(sql`now()`)\n\t\t\t.notNull(),\n\t\tentityId: uuid(\"entity_id\")\n\t\t\t.notNull()\n\t\t\t.references(() => entityTable.id, { onDelete: \"cascade\" }),\n\t\tbody: jsonb(\"body\").notNull(),\n\t\ttype: text(\"type\").notNull(),\n\t\troomId: uuid(\"room_id\")\n\t\t\t.notNull()\n\t\t\t.references(() => roomTable.id, { onDelete: \"cascade\" }),\n\t},\n\t(table) => [\n\t\tforeignKey({\n\t\t\tname: \"fk_room\",\n\t\t\tcolumns: [table.roomId],\n\t\t\tforeignColumns: [roomTable.id],\n\t\t}).onDelete(\"cascade\"),\n\t\tforeignKey({\n\t\t\tname: \"fk_user\",\n\t\t\tcolumns: [table.entityId],\n\t\t\tforeignColumns: [entityTable.id],\n\t\t}).onDelete(\"cascade\"),\n\t],\n);\n",
133
+ "import { sql } from \"drizzle-orm\";\nimport { jsonb, pgTable, text, timestamp } from \"drizzle-orm/pg-core\";\nimport { channelTable } from \"./channel\";\n\nexport const messageTable = pgTable(\"central_messages\", {\n\tid: text(\"id\").primaryKey(), // UUID stored as text\n\tchannelId: text(\"channel_id\")\n\t\t.notNull()\n\t\t.references(() => channelTable.id, { onDelete: \"cascade\" }),\n\tauthorId: text(\"author_id\").notNull(),\n\tcontent: text(\"content\").notNull(),\n\trawMessage: jsonb(\"raw_message\"),\n\tinReplyToRootMessageId: text(\"in_reply_to_root_message_id\").references(\n\t\t() => messageTable.id,\n\t\t{\n\t\t\tonDelete: \"set null\",\n\t\t},\n\t),\n\tsourceType: text(\"source_type\"),\n\tsourceId: text(\"source_id\"),\n\tmetadata: jsonb(\"metadata\"),\n\tcreatedAt: timestamp(\"created_at\", { mode: \"date\" })\n\t\t.default(sql`CURRENT_TIMESTAMP`)\n\t\t.notNull(),\n\tupdatedAt: timestamp(\"updated_at\", { mode: \"date\" })\n\t\t.default(sql`CURRENT_TIMESTAMP`)\n\t\t.notNull(),\n});\n",
134
+ "import { pgTable, primaryKey, uuid } from \"drizzle-orm/pg-core\";\nimport { agentTable } from \"./agent\";\nimport { messageServerTable } from \"./messageServer\";\n\nexport const messageServerAgentsTable = pgTable(\n\t\"message_server_agents\",\n\t{\n\t\tmessageServerId: uuid(\"message_server_id\")\n\t\t\t.notNull()\n\t\t\t.references(() => messageServerTable.id, { onDelete: \"cascade\" }),\n\t\tagentId: uuid(\"agent_id\")\n\t\t\t.notNull()\n\t\t\t.references(() => agentTable.id, { onDelete: \"cascade\" }),\n\t},\n\t(table) => [primaryKey({ columns: [table.messageServerId, table.agentId] })],\n);\n",
135
+ "import { sql } from \"drizzle-orm\";\nimport {\n\tindex,\n\tjsonb,\n\tpgTable,\n\ttext,\n\ttimestamp,\n\tuniqueIndex,\n\tuuid,\n} from \"drizzle-orm/pg-core\";\nimport { agentTable } from \"./agent\";\n\n/**\n * Represents the allowlist of approved senders for each channel.\n * Senders in this list are permitted to send DMs to the bot.\n */\nexport const pairingAllowlistTable = pgTable(\n\t\"pairing_allowlist\",\n\t{\n\t\tid: uuid(\"id\").primaryKey().defaultRandom(),\n\t\t/** The messaging channel (telegram, discord, whatsapp, etc.) */\n\t\tchannel: text(\"channel\").notNull(),\n\t\t/** Approved sender identifier */\n\t\tsenderId: text(\"sender_id\").notNull(),\n\t\t/** When the entry was added */\n\t\tcreatedAt: timestamp(\"created_at\", { withTimezone: true })\n\t\t\t.default(sql`now()`)\n\t\t\t.notNull(),\n\t\t/** Optional metadata about the approved sender */\n\t\tmetadata: jsonb(\"metadata\").default(sql`'{}'::jsonb`),\n\t\t/** Agent ID this allowlist belongs to */\n\t\tagentId: uuid(\"agent_id\")\n\t\t\t.notNull()\n\t\t\t.references(() => agentTable.id, { onDelete: \"cascade\" }),\n\t},\n\t(table) => [\n\t\t// Index for looking up allowlist by channel and agent\n\t\tindex(\"pairing_allowlist_channel_agent_idx\").on(\n\t\t\ttable.channel,\n\t\t\ttable.agentId,\n\t\t),\n\t\t// Unique constraint to prevent duplicate entries\n\t\tuniqueIndex(\"pairing_allowlist_sender_channel_agent_idx\").on(\n\t\t\ttable.senderId,\n\t\t\ttable.channel,\n\t\t\ttable.agentId,\n\t\t),\n\t],\n);\n",
136
+ "import { sql } from \"drizzle-orm\";\nimport {\n\tindex,\n\tjsonb,\n\tpgTable,\n\ttext,\n\ttimestamp,\n\tuniqueIndex,\n\tuuid,\n} from \"drizzle-orm/pg-core\";\nimport { agentTable } from \"./agent\";\n\n/**\n * Represents pending pairing requests from users trying to access the bot via DM.\n * Requests are stored temporarily until approved or expired.\n */\nexport const pairingRequestTable = pgTable(\n\t\"pairing_requests\",\n\t{\n\t\tid: uuid(\"id\").primaryKey().defaultRandom(),\n\t\t/** The messaging channel (telegram, discord, whatsapp, etc.) */\n\t\tchannel: text(\"channel\").notNull(),\n\t\t/** User identifier on the channel (userId, phoneNumber, etc.) */\n\t\tsenderId: text(\"sender_id\").notNull(),\n\t\t/** Human-friendly pairing code */\n\t\tcode: text(\"code\").notNull(),\n\t\t/** When the request was created */\n\t\tcreatedAt: timestamp(\"created_at\", { withTimezone: true })\n\t\t\t.default(sql`now()`)\n\t\t\t.notNull(),\n\t\t/** When the request was last seen/updated */\n\t\tlastSeenAt: timestamp(\"last_seen_at\", { withTimezone: true })\n\t\t\t.default(sql`now()`)\n\t\t\t.notNull(),\n\t\t/** Optional metadata about the requester */\n\t\tmetadata: jsonb(\"metadata\").default(sql`'{}'::jsonb`),\n\t\t/** Agent ID that received this request */\n\t\tagentId: uuid(\"agent_id\")\n\t\t\t.notNull()\n\t\t\t.references(() => agentTable.id, { onDelete: \"cascade\" }),\n\t},\n\t(table) => [\n\t\t// Index for looking up requests by channel and agent\n\t\tindex(\"pairing_requests_channel_agent_idx\").on(\n\t\t\ttable.channel,\n\t\t\ttable.agentId,\n\t\t),\n\t\t// Unique constraint on code per channel/agent to prevent duplicates\n\t\tuniqueIndex(\"pairing_requests_code_channel_agent_idx\").on(\n\t\t\ttable.code,\n\t\t\ttable.channel,\n\t\t\ttable.agentId,\n\t\t),\n\t\t// Unique constraint on sender per channel/agent (one request per user)\n\t\tuniqueIndex(\"pairing_requests_sender_channel_agent_idx\").on(\n\t\t\ttable.senderId,\n\t\t\ttable.channel,\n\t\t\ttable.agentId,\n\t\t),\n\t],\n);\n",
137
+ "import { sql } from \"drizzle-orm\";\nimport {\n\tforeignKey,\n\tindex,\n\tpgTable,\n\ttext,\n\ttimestamp,\n\tuuid,\n} from \"drizzle-orm/pg-core\";\nimport { agentTable } from \"./agent\";\nimport { entityTable } from \"./entity\";\nimport { roomTable } from \"./room\";\n\n/**\n * Defines the schema for the \"participants\" table in the database.\n *\n * @type {import('knex').TableBuilder}\n */\nexport const participantTable = pgTable(\n\t\"participants\",\n\t{\n\t\tid: uuid(\"id\").notNull().primaryKey().default(sql`gen_random_uuid()`),\n\t\tcreatedAt: timestamp(\"created_at\", { withTimezone: true })\n\t\t\t.default(sql`now()`)\n\t\t\t.notNull(),\n\t\tentityId: uuid(\"entity_id\").references(() => entityTable.id, {\n\t\t\tonDelete: \"cascade\",\n\t\t}),\n\t\troomId: uuid(\"room_id\").references(() => roomTable.id, {\n\t\t\tonDelete: \"cascade\",\n\t\t}),\n\t\tagentId: uuid(\"agent_id\").references(() => agentTable.id, {\n\t\t\tonDelete: \"cascade\",\n\t\t}),\n\t\troomState: text(\"room_state\"),\n\t},\n\t(table) => [\n\t\t// unique(\"participants_user_room_agent_unique\").on(table.entityId, table.roomId, table.agentId),\n\t\tindex(\"idx_participants_user\").on(table.entityId),\n\t\tindex(\"idx_participants_room\").on(table.roomId),\n\t\tforeignKey({\n\t\t\tname: \"fk_room\",\n\t\t\tcolumns: [table.roomId],\n\t\t\tforeignColumns: [roomTable.id],\n\t\t}).onDelete(\"cascade\"),\n\t\tforeignKey({\n\t\t\tname: \"fk_user\",\n\t\t\tcolumns: [table.entityId],\n\t\t\tforeignColumns: [entityTable.id],\n\t\t}).onDelete(\"cascade\"),\n\t],\n);\n",
138
+ "import { sql } from \"drizzle-orm\";\nimport {\n\tforeignKey,\n\tindex,\n\tjsonb,\n\tpgTable,\n\ttext,\n\ttimestamp,\n\tunique,\n\tuuid,\n} from \"drizzle-orm/pg-core\";\nimport { agentTable } from \"./agent\";\nimport { entityTable } from \"./entity\";\n\n/**\n * Defines the relationshipTable containing information about relationships between entities and agents.\n * @type {import('knex').TableBuilder}\n */\nexport const relationshipTable = pgTable(\n\t\"relationships\",\n\t{\n\t\tid: uuid(\"id\").notNull().primaryKey().default(sql`gen_random_uuid()`),\n\t\tcreatedAt: timestamp(\"created_at\", { withTimezone: true })\n\t\t\t.default(sql`now()`)\n\t\t\t.notNull(),\n\t\tsourceEntityId: uuid(\"source_entity_id\")\n\t\t\t.notNull()\n\t\t\t.references(() => entityTable.id, { onDelete: \"cascade\" }),\n\t\ttargetEntityId: uuid(\"target_entity_id\")\n\t\t\t.notNull()\n\t\t\t.references(() => entityTable.id, { onDelete: \"cascade\" }),\n\t\tagentId: uuid(\"agent_id\")\n\t\t\t.notNull()\n\t\t\t.references(() => agentTable.id, { onDelete: \"cascade\" }),\n\t\ttags: text(\"tags\").array(),\n\t\tmetadata: jsonb(\"metadata\"),\n\t},\n\t(table) => [\n\t\tindex(\"idx_relationships_users\").on(\n\t\t\ttable.sourceEntityId,\n\t\t\ttable.targetEntityId,\n\t\t),\n\t\tunique(\"unique_relationship\").on(\n\t\t\ttable.sourceEntityId,\n\t\t\ttable.targetEntityId,\n\t\t\ttable.agentId,\n\t\t),\n\t\tforeignKey({\n\t\t\tname: \"fk_user_a\",\n\t\t\tcolumns: [table.sourceEntityId],\n\t\t\tforeignColumns: [entityTable.id],\n\t\t}).onDelete(\"cascade\"),\n\t\tforeignKey({\n\t\t\tname: \"fk_user_b\",\n\t\t\tcolumns: [table.targetEntityId],\n\t\t\tforeignColumns: [entityTable.id],\n\t\t}).onDelete(\"cascade\"),\n\t],\n);\n",
139
+ "import { sql } from \"drizzle-orm\";\nimport { jsonb, pgTable, text, timestamp, uuid } from \"drizzle-orm/pg-core\";\nimport { agentTable } from \"./agent\";\n\n/**\n * Represents a table schema for tasks in the database.\n *\n * @type {PgTable}\n */\nexport const taskTable = pgTable(\"tasks\", {\n\tid: uuid(\"id\").primaryKey().defaultRandom(),\n\tname: text(\"name\").notNull(),\n\tdescription: text(\"description\"),\n\troomId: uuid(\"room_id\"),\n\tworldId: uuid(\"world_id\"),\n\tentityId: uuid(\"entity_id\"),\n\tagentId: uuid(\"agent_id\")\n\t\t.notNull()\n\t\t.references(() => agentTable.id, { onDelete: \"cascade\" }),\n\ttags: text(\"tags\").array().default(sql`'{}'::text[]`),\n\tmetadata: jsonb(\"metadata\").default(sql`'{}'::jsonb`),\n\tcreatedAt: timestamp(\"created_at\", { withTimezone: true }).defaultNow(),\n\tupdatedAt: timestamp(\"updated_at\", { withTimezone: true }).defaultNow(),\n});\n",
140
+ "import { logger, type UUID, validateUuid } from \"@elizaos/core\";\nimport { sql } from \"drizzle-orm\";\nimport { drizzle, type NodePgDatabase } from \"drizzle-orm/node-postgres\";\nimport { Pool, type PoolClient, type PoolConfig } from \"pg\";\n\nexport class PostgresConnectionManager {\n\tprivate pool: Pool;\n\tprivate db: NodePgDatabase;\n\n\tconstructor(connectionString: string, rlsServerId?: string) {\n\t\tconst poolConfig: PoolConfig = {\n\t\t\tconnectionString,\n\t\t\tmax: 20,\n\t\t\tmin: 2,\n\t\t\tidleTimeoutMillis: 30000,\n\t\t\tconnectionTimeoutMillis: 5000,\n\t\t\tkeepAlive: true,\n\t\t\tkeepAliveInitialDelayMillis: 10000,\n\t\t};\n\n\t\tif (rlsServerId) {\n\t\t\tpoolConfig.application_name = rlsServerId;\n\t\t\tlogger.debug(\n\t\t\t\t{ src: \"plugin:sql\", rlsServerId: rlsServerId.substring(0, 8) },\n\t\t\t\t\"Pool configured with RLS server\",\n\t\t\t);\n\t\t}\n\n\t\tthis.pool = new Pool(poolConfig);\n\n\t\tthis.pool.on(\"error\", (err) => {\n\t\t\tlogger.warn(\n\t\t\t\t{ src: \"plugin:sql\", error: err?.message || String(err) },\n\t\t\t\t\"Pool client error (connection will be replaced)\",\n\t\t\t);\n\t\t});\n\n\t\tthis.db = drizzle(this.pool, { casing: \"snake_case\" });\n\t}\n\n\tpublic getDatabase(): NodePgDatabase {\n\t\treturn this.db;\n\t}\n\n\tpublic getConnection(): Pool {\n\t\treturn this.pool;\n\t}\n\n\tpublic async getClient(): Promise<PoolClient> {\n\t\treturn this.pool.connect();\n\t}\n\n\tpublic async testConnection(): Promise<boolean> {\n\t\tlet client: PoolClient | null = null;\n\t\ttry {\n\t\t\tclient = await this.pool.connect();\n\t\t\tawait client.query(\"SELECT 1\");\n\t\t\treturn true;\n\t\t} catch (error) {\n\t\t\tlogger.error(\n\t\t\t\t{\n\t\t\t\t\tsrc: \"plugin:sql\",\n\t\t\t\t\terror: error instanceof Error ? error.message : String(error),\n\t\t\t\t},\n\t\t\t\t\"Failed to connect to the database\",\n\t\t\t);\n\t\t\treturn false;\n\t\t} finally {\n\t\t\tif (client) {\n\t\t\t\tclient.release();\n\t\t\t}\n\t\t}\n\t}\n\n\tpublic async withEntityContext<T>(\n\t\tentityId: UUID | null,\n\t\tcallback: (tx: NodePgDatabase) => Promise<T>,\n\t): Promise<T> {\n\t\tconst dataIsolationEnabled = process.env.ENABLE_DATA_ISOLATION === \"true\";\n\n\t\treturn await this.db.transaction(async (tx) => {\n\t\t\tif (dataIsolationEnabled && entityId) {\n\t\t\t\tif (!validateUuid(entityId)) {\n\t\t\t\t\tthrow new Error(\n\t\t\t\t\t\t`Invalid UUID format for entity context: ${entityId}`,\n\t\t\t\t\t);\n\t\t\t\t}\n\n\t\t\t\ttry {\n\t\t\t\t\tawait tx.execute(sql.raw(`SET LOCAL app.entity_id = '${entityId}'`));\n\t\t\t\t\tlogger.debug(`[Entity Context] Set app.entity_id = ${entityId}`);\n\t\t\t\t} catch (error) {\n\t\t\t\t\tconst errorMessage =\n\t\t\t\t\t\terror instanceof Error ? error.message : String(error);\n\t\t\t\t\tlogger.error(\n\t\t\t\t\t\t{ error, entityId },\n\t\t\t\t\t\t`[Entity Context] Failed to set entity context: ${errorMessage}`,\n\t\t\t\t\t);\n\t\t\t\t\tthrow error;\n\t\t\t\t}\n\t\t\t} else if (!dataIsolationEnabled) {\n\t\t\t} else {\n\t\t\t\tlogger.debug(\n\t\t\t\t\t\"[Entity Context] No entity context set (server operation)\",\n\t\t\t\t);\n\t\t\t}\n\n\t\t\treturn await callback(tx);\n\t\t});\n\t}\n\n\tpublic async close(): Promise<void> {\n\t\tawait this.pool.end();\n\t}\n}\n",
139
141
  "import pg from \"pg\";\nimport { entityKind } from \"../entity.js\";\nimport { DefaultLogger } from \"../logger.js\";\nimport { PgDatabase } from \"../pg-core/db.js\";\nimport { PgDialect } from \"../pg-core/dialect.js\";\nimport {\n createTableRelationsHelpers,\n extractTablesRelationalConfig\n} from \"../relations.js\";\nimport { isConfig } from \"../utils.js\";\nimport { NodePgSession } from \"./session.js\";\nclass NodePgDriver {\n constructor(client, dialect, options = {}) {\n this.client = client;\n this.dialect = dialect;\n this.options = options;\n }\n static [entityKind] = \"NodePgDriver\";\n createSession(schema) {\n return new NodePgSession(this.client, this.dialect, schema, {\n logger: this.options.logger,\n cache: this.options.cache\n });\n }\n}\nclass NodePgDatabase extends PgDatabase {\n static [entityKind] = \"NodePgDatabase\";\n}\nfunction construct(client, config = {}) {\n const dialect = new PgDialect({ casing: config.casing });\n let logger;\n if (config.logger === true) {\n logger = new DefaultLogger();\n } else if (config.logger !== false) {\n logger = config.logger;\n }\n let schema;\n if (config.schema) {\n const tablesConfig = extractTablesRelationalConfig(\n config.schema,\n createTableRelationsHelpers\n );\n schema = {\n fullSchema: config.schema,\n schema: tablesConfig.tables,\n tableNamesMap: tablesConfig.tableNamesMap\n };\n }\n const driver = new NodePgDriver(client, dialect, { logger, cache: config.cache });\n const session = driver.createSession(schema);\n const db = new NodePgDatabase(dialect, session, schema);\n db.$client = client;\n db.$cache = config.cache;\n if (db.$cache) {\n db.$cache[\"invalidate\"] = config.cache?.onMutate;\n }\n return db;\n}\nfunction drizzle(...params) {\n if (typeof params[0] === \"string\") {\n const instance = new pg.Pool({\n connectionString: params[0]\n });\n return construct(instance, params[1]);\n }\n if (isConfig(params[0])) {\n const { connection, client, ...drizzleConfig } = params[0];\n if (client) return construct(client, drizzleConfig);\n const instance = typeof connection === \"string\" ? new pg.Pool({\n connectionString: connection\n }) : new pg.Pool(connection);\n return construct(instance, drizzleConfig);\n }\n return construct(params[0], params[1]);\n}\n((drizzle2) => {\n function mock(config) {\n return construct({}, config);\n }\n drizzle2.mock = mock;\n})(drizzle || (drizzle = {}));\nexport {\n NodePgDatabase,\n NodePgDriver,\n drizzle\n};\n//# sourceMappingURL=driver.js.map",
140
142
  "import pg from \"pg\";\nimport { NoopCache } from \"../cache/core/index.js\";\nimport { entityKind } from \"../entity.js\";\nimport { NoopLogger } from \"../logger.js\";\nimport { PgTransaction } from \"../pg-core/index.js\";\nimport { PgPreparedQuery, PgSession } from \"../pg-core/session.js\";\nimport { fillPlaceholders, sql } from \"../sql/sql.js\";\nimport { tracer } from \"../tracing.js\";\nimport { mapResultRow } from \"../utils.js\";\nconst { Pool, types } = pg;\nclass NodePgPreparedQuery extends PgPreparedQuery {\n constructor(client, queryString, params, logger, cache, queryMetadata, cacheConfig, fields, name, _isResponseInArrayMode, customResultMapper) {\n super({ sql: queryString, params }, cache, queryMetadata, cacheConfig);\n this.client = client;\n this.queryString = queryString;\n this.params = params;\n this.logger = logger;\n this.fields = fields;\n this._isResponseInArrayMode = _isResponseInArrayMode;\n this.customResultMapper = customResultMapper;\n this.rawQueryConfig = {\n name,\n text: queryString,\n types: {\n // @ts-ignore\n getTypeParser: (typeId, format) => {\n if (typeId === types.builtins.TIMESTAMPTZ) {\n return (val) => val;\n }\n if (typeId === types.builtins.TIMESTAMP) {\n return (val) => val;\n }\n if (typeId === types.builtins.DATE) {\n return (val) => val;\n }\n if (typeId === types.builtins.INTERVAL) {\n return (val) => val;\n }\n if (typeId === 1231) {\n return (val) => val;\n }\n if (typeId === 1115) {\n return (val) => val;\n }\n if (typeId === 1185) {\n return (val) => val;\n }\n if (typeId === 1187) {\n return (val) => val;\n }\n if (typeId === 1182) {\n return (val) => val;\n }\n return types.getTypeParser(typeId, format);\n }\n }\n };\n this.queryConfig = {\n name,\n text: queryString,\n rowMode: \"array\",\n types: {\n // @ts-ignore\n getTypeParser: (typeId, format) => {\n if (typeId === types.builtins.TIMESTAMPTZ) {\n return (val) => val;\n }\n if (typeId === types.builtins.TIMESTAMP) {\n return (val) => val;\n }\n if (typeId === types.builtins.DATE) {\n return (val) => val;\n }\n if (typeId === types.builtins.INTERVAL) {\n return (val) => val;\n }\n if (typeId === 1231) {\n return (val) => val;\n }\n if (typeId === 1115) {\n return (val) => val;\n }\n if (typeId === 1185) {\n return (val) => val;\n }\n if (typeId === 1187) {\n return (val) => val;\n }\n if (typeId === 1182) {\n return (val) => val;\n }\n return types.getTypeParser(typeId, format);\n }\n }\n };\n }\n static [entityKind] = \"NodePgPreparedQuery\";\n rawQueryConfig;\n queryConfig;\n async execute(placeholderValues = {}) {\n return tracer.startActiveSpan(\"drizzle.execute\", async () => {\n const params = fillPlaceholders(this.params, placeholderValues);\n this.logger.logQuery(this.rawQueryConfig.text, params);\n const { fields, rawQueryConfig: rawQuery, client, queryConfig: query, joinsNotNullableMap, customResultMapper } = this;\n if (!fields && !customResultMapper) {\n return tracer.startActiveSpan(\"drizzle.driver.execute\", async (span) => {\n span?.setAttributes({\n \"drizzle.query.name\": rawQuery.name,\n \"drizzle.query.text\": rawQuery.text,\n \"drizzle.query.params\": JSON.stringify(params)\n });\n return this.queryWithCache(rawQuery.text, params, async () => {\n return await client.query(rawQuery, params);\n });\n });\n }\n const result = await tracer.startActiveSpan(\"drizzle.driver.execute\", (span) => {\n span?.setAttributes({\n \"drizzle.query.name\": query.name,\n \"drizzle.query.text\": query.text,\n \"drizzle.query.params\": JSON.stringify(params)\n });\n return this.queryWithCache(query.text, params, async () => {\n return await client.query(query, params);\n });\n });\n return tracer.startActiveSpan(\"drizzle.mapResponse\", () => {\n return customResultMapper ? customResultMapper(result.rows) : result.rows.map((row) => mapResultRow(fields, row, joinsNotNullableMap));\n });\n });\n }\n all(placeholderValues = {}) {\n return tracer.startActiveSpan(\"drizzle.execute\", () => {\n const params = fillPlaceholders(this.params, placeholderValues);\n this.logger.logQuery(this.rawQueryConfig.text, params);\n return tracer.startActiveSpan(\"drizzle.driver.execute\", (span) => {\n span?.setAttributes({\n \"drizzle.query.name\": this.rawQueryConfig.name,\n \"drizzle.query.text\": this.rawQueryConfig.text,\n \"drizzle.query.params\": JSON.stringify(params)\n });\n return this.queryWithCache(this.rawQueryConfig.text, params, async () => {\n return this.client.query(this.rawQueryConfig, params);\n }).then((result) => result.rows);\n });\n });\n }\n /** @internal */\n isResponseInArrayMode() {\n return this._isResponseInArrayMode;\n }\n}\nclass NodePgSession extends PgSession {\n constructor(client, dialect, schema, options = {}) {\n super(dialect);\n this.client = client;\n this.schema = schema;\n this.options = options;\n this.logger = options.logger ?? new NoopLogger();\n this.cache = options.cache ?? new NoopCache();\n }\n static [entityKind] = \"NodePgSession\";\n logger;\n cache;\n prepareQuery(query, fields, name, isResponseInArrayMode, customResultMapper, queryMetadata, cacheConfig) {\n return new NodePgPreparedQuery(\n this.client,\n query.sql,\n query.params,\n this.logger,\n this.cache,\n queryMetadata,\n cacheConfig,\n fields,\n name,\n isResponseInArrayMode,\n customResultMapper\n );\n }\n async transaction(transaction, config) {\n const isPool = this.client instanceof Pool || Object.getPrototypeOf(this.client).constructor.name.includes(\"Pool\");\n const session = isPool ? new NodePgSession(await this.client.connect(), this.dialect, this.schema, this.options) : this;\n const tx = new NodePgTransaction(this.dialect, session, this.schema);\n await tx.execute(sql`begin${config ? sql` ${tx.getTransactionConfigSQL(config)}` : void 0}`);\n try {\n const result = await transaction(tx);\n await tx.execute(sql`commit`);\n return result;\n } catch (error) {\n await tx.execute(sql`rollback`);\n throw error;\n } finally {\n if (isPool) session.client.release();\n }\n }\n async count(sql2) {\n const res = await this.execute(sql2);\n return Number(\n res[\"rows\"][0][\"count\"]\n );\n }\n}\nclass NodePgTransaction extends PgTransaction {\n static [entityKind] = \"NodePgTransaction\";\n async transaction(transaction) {\n const savepointName = `sp${this.nestedIndex + 1}`;\n const tx = new NodePgTransaction(\n this.dialect,\n this.session,\n this.schema,\n this.nestedIndex + 1\n );\n await tx.execute(sql.raw(`savepoint ${savepointName}`));\n try {\n const result = await transaction(tx);\n await tx.execute(sql.raw(`release savepoint ${savepointName}`));\n return result;\n } catch (err) {\n await tx.execute(sql.raw(`rollback to savepoint ${savepointName}`));\n throw err;\n }\n }\n}\nexport {\n NodePgPreparedQuery,\n NodePgSession,\n NodePgTransaction\n};\n//# sourceMappingURL=session.js.map",
141
- "import { type Agent, type Entity, logger, type Memory, type UUID } from \"@elizaos/core\";\nimport { drizzle, type PgliteDatabase } from \"drizzle-orm/pglite\";\nimport { BaseDrizzleAdapter } from \"../base\";\nimport { DIMENSION_MAP, type EmbeddingDimensionColumn } from \"../schema/embedding\";\nimport type { PGliteClientManager } from \"./manager\";\n\nexport class PgliteDatabaseAdapter extends BaseDrizzleAdapter {\n private manager: PGliteClientManager;\n protected embeddingDimension: EmbeddingDimensionColumn = DIMENSION_MAP[384];\n\n constructor(agentId: UUID, manager: PGliteClientManager) {\n super(agentId);\n this.manager = manager;\n this.db = drizzle(this.manager.getConnection());\n }\n\n public async withEntityContext<T>(\n _entityId: UUID | null,\n callback: (tx: PgliteDatabase) => Promise<T>\n ): Promise<T> {\n return this.db.transaction(callback);\n }\n\n async getEntityByIds(entityIds: UUID[]): Promise<Entity[] | null> {\n return this.getEntitiesByIds(entityIds);\n }\n\n async getMemoriesByServerId(_params: { serverId: UUID; count?: number }): Promise<Memory[]> {\n logger.warn({ src: \"plugin:sql\" }, \"getMemoriesByServerId called but not implemented\");\n return [];\n }\n\n async ensureAgentExists(agent: Partial<Agent>): Promise<Agent> {\n const existingAgent = await this.getAgent(this.agentId);\n if (existingAgent) {\n return existingAgent;\n }\n\n const newAgent: Agent = {\n id: this.agentId,\n name: agent.name || \"Unknown Agent\",\n username: agent.username,\n bio: (Array.isArray(agent.bio)\n ? agent.bio\n : agent.bio\n ? [agent.bio]\n : [\"An AI agent\"]) as string[],\n createdAt: agent.createdAt || Date.now(),\n updatedAt: agent.updatedAt || Date.now(),\n };\n\n await this.createAgent(newAgent);\n const createdAgent = await this.getAgent(this.agentId);\n if (!createdAgent) {\n throw new Error(\"Failed to create agent\");\n }\n return createdAgent;\n }\n\n protected async withDatabase<T>(operation: () => Promise<T>): Promise<T> {\n if (this.manager.isShuttingDown()) {\n const error = new Error(\"Database is shutting down - operation rejected\");\n logger.warn(\n { src: \"plugin:sql\", error: error.message },\n \"Database operation rejected during shutdown\"\n );\n throw error;\n }\n return operation();\n }\n\n async init(): Promise<void> {\n logger.debug({ src: \"plugin:sql\" }, \"PGliteDatabaseAdapter initialized\");\n }\n\n async isReady(): Promise<boolean> {\n return !this.manager.isShuttingDown();\n }\n\n async close() {\n await this.manager.close();\n }\n\n async getConnection(): Promise<PgliteDatabase> {\n return this.db as PgliteDatabase;\n }\n\n getRawConnection() {\n return this.manager.getConnection();\n }\n}\n",
143
+ "import {\n\ttype Agent,\n\ttype Entity,\n\tlogger,\n\ttype Memory,\n\ttype UUID,\n} from \"@elizaos/core\";\nimport { drizzle, type PgliteDatabase } from \"drizzle-orm/pglite\";\nimport { BaseDrizzleAdapter } from \"../base\";\nimport {\n\tDIMENSION_MAP,\n\ttype EmbeddingDimensionColumn,\n} from \"../schema/embedding\";\nimport type { PGliteClientManager } from \"./manager\";\n\nexport class PgliteDatabaseAdapter extends BaseDrizzleAdapter {\n\tprivate manager: PGliteClientManager;\n\tprotected embeddingDimension: EmbeddingDimensionColumn = DIMENSION_MAP[384];\n\n\tconstructor(agentId: UUID, manager: PGliteClientManager) {\n\t\tsuper(agentId);\n\t\tthis.manager = manager;\n\t\tthis.db = drizzle(this.manager.getConnection());\n\t}\n\n\tpublic async withEntityContext<T>(\n\t\t_entityId: UUID | null,\n\t\tcallback: (tx: PgliteDatabase) => Promise<T>,\n\t): Promise<T> {\n\t\treturn this.db.transaction(callback);\n\t}\n\n\tasync getEntityByIds(entityIds: UUID[]): Promise<Entity[] | null> {\n\t\treturn this.getEntitiesByIds(entityIds);\n\t}\n\n\tasync getMemoriesByServerId(_params: {\n\t\tserverId: UUID;\n\t\tcount?: number;\n\t}): Promise<Memory[]> {\n\t\tlogger.warn(\n\t\t\t{ src: \"plugin:sql\" },\n\t\t\t\"getMemoriesByServerId called but not implemented\",\n\t\t);\n\t\treturn [];\n\t}\n\n\tasync ensureAgentExists(agent: Partial<Agent>): Promise<Agent> {\n\t\tconst existingAgent = await this.getAgent(this.agentId);\n\t\tif (existingAgent) {\n\t\t\treturn existingAgent;\n\t\t}\n\n\t\tconst newAgent: Agent = {\n\t\t\tid: this.agentId,\n\t\t\tname: agent.name || \"Unknown Agent\",\n\t\t\tusername: agent.username,\n\t\t\tbio: (Array.isArray(agent.bio)\n\t\t\t\t? agent.bio\n\t\t\t\t: agent.bio\n\t\t\t\t\t? [agent.bio]\n\t\t\t\t\t: [\"An AI agent\"]) as string[],\n\t\t\tcreatedAt: agent.createdAt || Date.now(),\n\t\t\tupdatedAt: agent.updatedAt || Date.now(),\n\t\t};\n\n\t\tawait this.createAgent(newAgent);\n\t\tconst createdAgent = await this.getAgent(this.agentId);\n\t\tif (!createdAgent) {\n\t\t\tthrow new Error(\"Failed to create agent\");\n\t\t}\n\t\treturn createdAgent;\n\t}\n\n\tprotected async withDatabase<T>(operation: () => Promise<T>): Promise<T> {\n\t\tif (this.manager.isShuttingDown()) {\n\t\t\tconst error = new Error(\"Database is shutting down - operation rejected\");\n\t\t\tlogger.warn(\n\t\t\t\t{ src: \"plugin:sql\", error: error.message },\n\t\t\t\t\"Database operation rejected during shutdown\",\n\t\t\t);\n\t\t\tthrow error;\n\t\t}\n\t\treturn operation();\n\t}\n\n\tasync init(): Promise<void> {\n\t\tconst managerWithInit = this.manager as PGliteClientManager & {\n\t\t\tinitialize?: () => Promise<void>;\n\t\t};\n\t\tawait managerWithInit.initialize?.();\n\t\tlogger.debug({ src: \"plugin:sql\" }, \"PGliteDatabaseAdapter initialized\");\n\t}\n\n\tasync isReady(): Promise<boolean> {\n\t\treturn !this.manager.isShuttingDown();\n\t}\n\n\tasync close() {\n\t\tawait this.manager.close();\n\t}\n\n\tasync getConnection(): Promise<PgliteDatabase> {\n\t\tconst managerWithInit = this.manager as PGliteClientManager & {\n\t\t\tinitialize?: () => Promise<void>;\n\t\t};\n\t\tawait managerWithInit.initialize?.();\n\t\treturn this.db as PgliteDatabase;\n\t}\n\n\tgetRawConnection() {\n\t\treturn this.manager.getConnection();\n\t}\n}\n",
142
144
  "import { PGlite } from \"@electric-sql/pglite\";\nimport { entityKind } from \"../entity.js\";\nimport { DefaultLogger } from \"../logger.js\";\nimport { PgDatabase } from \"../pg-core/db.js\";\nimport { PgDialect } from \"../pg-core/dialect.js\";\nimport {\n createTableRelationsHelpers,\n extractTablesRelationalConfig\n} from \"../relations.js\";\nimport { isConfig } from \"../utils.js\";\nimport { PgliteSession } from \"./session.js\";\nclass PgliteDriver {\n constructor(client, dialect, options = {}) {\n this.client = client;\n this.dialect = dialect;\n this.options = options;\n }\n static [entityKind] = \"PgliteDriver\";\n createSession(schema) {\n return new PgliteSession(this.client, this.dialect, schema, {\n logger: this.options.logger,\n cache: this.options.cache\n });\n }\n}\nclass PgliteDatabase extends PgDatabase {\n static [entityKind] = \"PgliteDatabase\";\n}\nfunction construct(client, config = {}) {\n const dialect = new PgDialect({ casing: config.casing });\n let logger;\n if (config.logger === true) {\n logger = new DefaultLogger();\n } else if (config.logger !== false) {\n logger = config.logger;\n }\n let schema;\n if (config.schema) {\n const tablesConfig = extractTablesRelationalConfig(\n config.schema,\n createTableRelationsHelpers\n );\n schema = {\n fullSchema: config.schema,\n schema: tablesConfig.tables,\n tableNamesMap: tablesConfig.tableNamesMap\n };\n }\n const driver = new PgliteDriver(client, dialect, { logger, cache: config.cache });\n const session = driver.createSession(schema);\n const db = new PgliteDatabase(dialect, session, schema);\n db.$client = client;\n db.$cache = config.cache;\n if (db.$cache) {\n db.$cache[\"invalidate\"] = config.cache?.onMutate;\n }\n return db;\n}\nfunction drizzle(...params) {\n if (params[0] === void 0 || typeof params[0] === \"string\") {\n const instance = new PGlite(params[0]);\n return construct(instance, params[1]);\n }\n if (isConfig(params[0])) {\n const { connection, client, ...drizzleConfig } = params[0];\n if (client) return construct(client, drizzleConfig);\n if (typeof connection === \"object\") {\n const { dataDir, ...options } = connection;\n const instance2 = new PGlite(dataDir, options);\n return construct(instance2, drizzleConfig);\n }\n const instance = new PGlite(connection);\n return construct(instance, drizzleConfig);\n }\n return construct(params[0], params[1]);\n}\n((drizzle2) => {\n function mock(config) {\n return construct({}, config);\n }\n drizzle2.mock = mock;\n})(drizzle || (drizzle = {}));\nexport {\n PgliteDatabase,\n PgliteDriver,\n drizzle\n};\n//# sourceMappingURL=driver.js.map",
143
145
  "import { entityKind } from \"../entity.js\";\nimport { NoopLogger } from \"../logger.js\";\nimport { PgTransaction } from \"../pg-core/index.js\";\nimport { PgPreparedQuery, PgSession } from \"../pg-core/session.js\";\nimport { fillPlaceholders, sql } from \"../sql/sql.js\";\nimport { mapResultRow } from \"../utils.js\";\nimport { types } from \"@electric-sql/pglite\";\nimport { NoopCache } from \"../cache/core/cache.js\";\nclass PglitePreparedQuery extends PgPreparedQuery {\n constructor(client, queryString, params, logger, cache, queryMetadata, cacheConfig, fields, name, _isResponseInArrayMode, customResultMapper) {\n super({ sql: queryString, params }, cache, queryMetadata, cacheConfig);\n this.client = client;\n this.queryString = queryString;\n this.params = params;\n this.logger = logger;\n this.fields = fields;\n this._isResponseInArrayMode = _isResponseInArrayMode;\n this.customResultMapper = customResultMapper;\n this.rawQueryConfig = {\n rowMode: \"object\",\n parsers: {\n [types.TIMESTAMP]: (value) => value,\n [types.TIMESTAMPTZ]: (value) => value,\n [types.INTERVAL]: (value) => value,\n [types.DATE]: (value) => value,\n // numeric[]\n [1231]: (value) => value,\n // timestamp[]\n [1115]: (value) => value,\n // timestamp with timezone[]\n [1185]: (value) => value,\n // interval[]\n [1187]: (value) => value,\n // date[]\n [1182]: (value) => value\n }\n };\n this.queryConfig = {\n rowMode: \"array\",\n parsers: {\n [types.TIMESTAMP]: (value) => value,\n [types.TIMESTAMPTZ]: (value) => value,\n [types.INTERVAL]: (value) => value,\n [types.DATE]: (value) => value,\n // numeric[]\n [1231]: (value) => value,\n // timestamp[]\n [1115]: (value) => value,\n // timestamp with timezone[]\n [1185]: (value) => value,\n // interval[]\n [1187]: (value) => value,\n // date[]\n [1182]: (value) => value\n }\n };\n }\n static [entityKind] = \"PglitePreparedQuery\";\n rawQueryConfig;\n queryConfig;\n async execute(placeholderValues = {}) {\n const params = fillPlaceholders(this.params, placeholderValues);\n this.logger.logQuery(this.queryString, params);\n const { fields, client, queryConfig, joinsNotNullableMap, customResultMapper, queryString, rawQueryConfig } = this;\n if (!fields && !customResultMapper) {\n return this.queryWithCache(queryString, params, async () => {\n return await client.query(queryString, params, rawQueryConfig);\n });\n }\n const result = await this.queryWithCache(queryString, params, async () => {\n return await client.query(queryString, params, queryConfig);\n });\n return customResultMapper ? customResultMapper(result.rows) : result.rows.map((row) => mapResultRow(fields, row, joinsNotNullableMap));\n }\n all(placeholderValues = {}) {\n const params = fillPlaceholders(this.params, placeholderValues);\n this.logger.logQuery(this.queryString, params);\n return this.queryWithCache(this.queryString, params, async () => {\n return await this.client.query(this.queryString, params, this.rawQueryConfig);\n }).then((result) => result.rows);\n }\n /** @internal */\n isResponseInArrayMode() {\n return this._isResponseInArrayMode;\n }\n}\nclass PgliteSession extends PgSession {\n constructor(client, dialect, schema, options = {}) {\n super(dialect);\n this.client = client;\n this.schema = schema;\n this.options = options;\n this.logger = options.logger ?? new NoopLogger();\n this.cache = options.cache ?? new NoopCache();\n }\n static [entityKind] = \"PgliteSession\";\n logger;\n cache;\n prepareQuery(query, fields, name, isResponseInArrayMode, customResultMapper, queryMetadata, cacheConfig) {\n return new PglitePreparedQuery(\n this.client,\n query.sql,\n query.params,\n this.logger,\n this.cache,\n queryMetadata,\n cacheConfig,\n fields,\n name,\n isResponseInArrayMode,\n customResultMapper\n );\n }\n async transaction(transaction, config) {\n return this.client.transaction(async (client) => {\n const session = new PgliteSession(\n client,\n this.dialect,\n this.schema,\n this.options\n );\n const tx = new PgliteTransaction(this.dialect, session, this.schema);\n if (config) {\n await tx.setTransaction(config);\n }\n return transaction(tx);\n });\n }\n async count(sql2) {\n const res = await this.execute(sql2);\n return Number(\n res[\"rows\"][0][\"count\"]\n );\n }\n}\nclass PgliteTransaction extends PgTransaction {\n static [entityKind] = \"PgliteTransaction\";\n async transaction(transaction) {\n const savepointName = `sp${this.nestedIndex + 1}`;\n const tx = new PgliteTransaction(\n this.dialect,\n this.session,\n this.schema,\n this.nestedIndex + 1\n );\n await tx.execute(sql.raw(`savepoint ${savepointName}`));\n try {\n const result = await transaction(tx);\n await tx.execute(sql.raw(`release savepoint ${savepointName}`));\n return result;\n } catch (err) {\n await tx.execute(sql.raw(`rollback to savepoint ${savepointName}`));\n throw err;\n }\n }\n}\nexport {\n PglitePreparedQuery,\n PgliteSession,\n PgliteTransaction\n};\n//# sourceMappingURL=session.js.map",
144
- "import { PGlite, type PGliteOptions } from \"@electric-sql/pglite\";\nimport { fuzzystrmatch } from \"@electric-sql/pglite/contrib/fuzzystrmatch\";\nimport { vector } from \"@electric-sql/pglite/vector\";\nimport type { IDatabaseClientManager } from \"../types\";\n\nexport class PGliteClientManager implements IDatabaseClientManager<PGlite> {\n private client: PGlite;\n private shuttingDown = false;\n\n constructor(options: PGliteOptions) {\n this.client = new PGlite({\n ...options,\n extensions: {\n vector,\n fuzzystrmatch,\n },\n });\n this.setupShutdownHandlers();\n }\n\n public getConnection(): PGlite {\n return this.client;\n }\n\n public isShuttingDown(): boolean {\n return this.shuttingDown;\n }\n\n public async initialize(): Promise<void> {}\n\n public async close(): Promise<void> {\n this.shuttingDown = true;\n if (this.client) {\n try {\n await this.client.close();\n } catch {}\n }\n }\n\n private setupShutdownHandlers() {}\n}\n",
145
- "import { existsSync } from \"node:fs\";\nimport path from \"node:path\";\nimport dotenv from \"dotenv\";\n\nexport function expandTildePath(filepath: string): string {\n if (filepath?.startsWith(\"~\")) {\n return path.join(process.cwd(), filepath.slice(1));\n }\n return filepath;\n}\n\nexport function resolveEnvFile(startDir: string = process.cwd()): string {\n let currentDir = startDir;\n\n while (true) {\n const candidate = path.join(currentDir, \".env\");\n if (existsSync(candidate)) {\n return candidate;\n }\n\n const parentDir = path.dirname(currentDir);\n if (parentDir === currentDir) {\n break;\n }\n currentDir = parentDir;\n }\n\n return path.join(startDir, \".env\");\n}\n\nexport function resolvePgliteDir(dir?: string, fallbackDir?: string): string {\n const envPath = resolveEnvFile();\n if (existsSync(envPath)) {\n dotenv.config({ path: envPath });\n }\n\n let monoPath: string | undefined;\n if (existsSync(path.join(process.cwd(), \"packages\", \"core\"))) {\n monoPath = process.cwd();\n } else {\n const twoUp = path.resolve(process.cwd(), \"../..\");\n if (existsSync(path.join(twoUp, \"packages\", \"core\"))) {\n monoPath = twoUp;\n }\n }\n\n const base =\n dir ??\n process.env.PGLITE_DATA_DIR ??\n fallbackDir ??\n (monoPath ? path.join(monoPath, \".eliza\", \".elizadb\") : undefined) ??\n path.join(process.cwd(), \".eliza\", \".elizadb\");\n\n return expandTildePath(base);\n}\n"
146
+ "import { existsSync, mkdirSync, renameSync } from \"node:fs\";\nimport { PGlite, type PGliteOptions } from \"@electric-sql/pglite\";\nimport { fuzzystrmatch } from \"@electric-sql/pglite/contrib/fuzzystrmatch\";\nimport { vector } from \"@electric-sql/pglite/vector\";\nimport { logger } from \"@elizaos/core\";\nimport type { IDatabaseClientManager } from \"../types\";\n\nexport class PGliteClientManager implements IDatabaseClientManager<PGlite> {\n\tprivate client: PGlite;\n\tprivate options: PGliteOptions;\n\tprivate shuttingDown = false;\n\tprivate initialized = false;\n\tprivate initializePromise: Promise<void> | null = null;\n\n\tconstructor(options: PGliteOptions) {\n\t\tthis.options = options;\n\t\tthis.client = this.createClient(options);\n\t\tthis.setupShutdownHandlers();\n\t}\n\n\tpublic getConnection(): PGlite {\n\t\treturn this.client;\n\t}\n\n\tpublic isShuttingDown(): boolean {\n\t\treturn this.shuttingDown;\n\t}\n\n\tpublic async initialize(): Promise<void> {\n\t\tif (this.initialized) {\n\t\t\treturn;\n\t\t}\n\n\t\tif (!this.initializePromise) {\n\t\t\tthis.initializePromise = this.initializeInternal().finally(() => {\n\t\t\t\tthis.initializePromise = null;\n\t\t\t});\n\t\t}\n\n\t\tawait this.initializePromise;\n\t}\n\n\tpublic async close(): Promise<void> {\n\t\tthis.shuttingDown = true;\n\t\tif (this.client) {\n\t\t\ttry {\n\t\t\t\tawait this.client.close();\n\t\t\t} catch {}\n\t\t}\n\t}\n\n\tprivate setupShutdownHandlers() {}\n\n\tprivate createClient(options: PGliteOptions): PGlite {\n\t\treturn new PGlite({\n\t\t\t...options,\n\t\t\textensions: {\n\t\t\t\t...(options.extensions ?? {}),\n\t\t\t\tvector,\n\t\t\t\tfuzzystrmatch,\n\t\t\t},\n\t\t});\n\t}\n\n\tprivate getDataDir(): string | null {\n\t\tconst optionsWithDataDir = this.options as PGliteOptions & {\n\t\t\tdataDir?: unknown;\n\t\t\tdataPath?: unknown;\n\t\t};\n\n\t\tconst dataDir = optionsWithDataDir.dataDir ?? optionsWithDataDir.dataPath;\n\t\treturn typeof dataDir === \"string\" ? dataDir : null;\n\t}\n\n\tprivate isFileBackedDataDir(dataDir: string | null): dataDir is string {\n\t\tif (!dataDir) {\n\t\t\treturn false;\n\t\t}\n\n\t\tif (dataDir.includes(\"://\")) {\n\t\t\treturn false;\n\t\t}\n\n\t\tif (dataDir === \":memory:\") {\n\t\t\treturn false;\n\t\t}\n\n\t\treturn true;\n\t}\n\n\tprivate getErrorText(error: unknown): string {\n\t\tif (error instanceof Error) {\n\t\t\treturn error.message;\n\t\t}\n\t\treturn String(error);\n\t}\n\n\tprivate async initializeInternal(): Promise<void> {\n\t\ttry {\n\t\t\tawait this.client.query(\"CREATE SCHEMA IF NOT EXISTS migrations\");\n\t\t\tthis.initialized = true;\n\t\t\treturn;\n\t\t} catch (initialError) {\n\t\t\tconst dataDir = this.getDataDir();\n\t\t\tif (!this.isFileBackedDataDir(dataDir)) {\n\t\t\t\tthrow initialError;\n\t\t\t}\n\n\t\t\tconst errorText = this.getErrorText(initialError);\n\t\t\tconst backupDir = `${dataDir}.corrupt-${Date.now()}`;\n\n\t\t\tlogger.error(\n\t\t\t\t{\n\t\t\t\t\tsrc: \"plugin:sql\",\n\t\t\t\t\tdataDir,\n\t\t\t\t\tbackupDir,\n\t\t\t\t\terror: errorText,\n\t\t\t\t},\n\t\t\t\t\"PGlite initialization failed; attempting recovery with a clean data directory\",\n\t\t\t);\n\n\t\t\ttry {\n\t\t\t\tawait this.client.close();\n\t\t\t} catch {}\n\n\t\t\tif (existsSync(dataDir)) {\n\t\t\t\trenameSync(dataDir, backupDir);\n\t\t\t}\n\t\t\tmkdirSync(dataDir, { recursive: true });\n\n\t\t\tthis.client = this.createClient(this.options);\n\n\t\t\ttry {\n\t\t\t\tawait this.client.query(\"CREATE SCHEMA IF NOT EXISTS migrations\");\n\t\t\t\tthis.initialized = true;\n\t\t\t\tlogger.warn(\n\t\t\t\t\t{\n\t\t\t\t\t\tsrc: \"plugin:sql\",\n\t\t\t\t\t\tdataDir,\n\t\t\t\t\t\tbackupDir,\n\t\t\t\t\t},\n\t\t\t\t\t\"Recovered from corrupted PGlite database directory\",\n\t\t\t\t);\n\t\t\t} catch (recoveryError) {\n\t\t\t\tthrow new Error(\n\t\t\t\t\t`PGlite recovery failed for ${dataDir}: ${this.getErrorText(recoveryError)}`,\n\t\t\t\t);\n\t\t\t}\n\t\t}\n\t}\n}\n",
147
+ "import { existsSync } from \"node:fs\";\nimport path from \"node:path\";\nimport dotenv from \"dotenv\";\n\nexport function expandTildePath(filepath: string): string {\n\tif (filepath?.startsWith(\"~\")) {\n\t\treturn path.join(process.cwd(), filepath.slice(1));\n\t}\n\treturn filepath;\n}\n\nexport function resolveEnvFile(startDir: string = process.cwd()): string {\n\tlet currentDir = startDir;\n\n\twhile (true) {\n\t\tconst candidate = path.join(currentDir, \".env\");\n\t\tif (existsSync(candidate)) {\n\t\t\treturn candidate;\n\t\t}\n\n\t\tconst parentDir = path.dirname(currentDir);\n\t\tif (parentDir === currentDir) {\n\t\t\tbreak;\n\t\t}\n\t\tcurrentDir = parentDir;\n\t}\n\n\treturn path.join(startDir, \".env\");\n}\n\nexport function resolvePgliteDir(dir?: string, fallbackDir?: string): string {\n\tconst envPath = resolveEnvFile();\n\tif (existsSync(envPath)) {\n\t\tdotenv.config({ path: envPath });\n\t}\n\n\tlet monoPath: string | undefined;\n\tif (existsSync(path.join(process.cwd(), \"packages\", \"core\"))) {\n\t\tmonoPath = process.cwd();\n\t} else {\n\t\tconst twoUp = path.resolve(process.cwd(), \"../..\");\n\t\tif (existsSync(path.join(twoUp, \"packages\", \"core\"))) {\n\t\t\tmonoPath = twoUp;\n\t\t}\n\t}\n\n\tconst base =\n\t\tdir ??\n\t\tprocess.env.PGLITE_DATA_DIR ??\n\t\tfallbackDir ??\n\t\t(monoPath ? path.join(monoPath, \".eliza\", \".elizadb\") : undefined) ??\n\t\tpath.join(process.cwd(), \".eliza\", \".elizadb\");\n\n\treturn expandTildePath(base);\n}\n"
146
148
  ],
147
- "mappings": "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",
148
- "debugId": "DC540429542FF71C64756E2164756E21",
149
+ "mappings": "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",
150
+ "debugId": "2E4FBBE6134438E564756E2164756E21",
149
151
  "names": []
150
152
  }