@elizaos/plugin-goals 2.0.0-alpha.8 → 2.0.3-beta.2

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.
Files changed (44) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +89 -0
  3. package/assets/hero.svg +69 -0
  4. package/package.json +72 -110
  5. package/dist/__tests__/e2e/goals-plugin.d.ts +0 -3
  6. package/dist/__tests__/e2e/goals-plugin.d.ts.map +0 -1
  7. package/dist/actions/cancelGoal.d.ts +0 -4
  8. package/dist/actions/cancelGoal.d.ts.map +0 -1
  9. package/dist/actions/completeGoal.d.ts +0 -4
  10. package/dist/actions/completeGoal.d.ts.map +0 -1
  11. package/dist/actions/confirmGoal.d.ts +0 -4
  12. package/dist/actions/confirmGoal.d.ts.map +0 -1
  13. package/dist/actions/createGoal.d.ts +0 -4
  14. package/dist/actions/createGoal.d.ts.map +0 -1
  15. package/dist/actions/updateGoal.d.ts +0 -4
  16. package/dist/actions/updateGoal.d.ts.map +0 -1
  17. package/dist/apis.d.ts +0 -4
  18. package/dist/apis.d.ts.map +0 -1
  19. package/dist/build.d.ts +0 -3
  20. package/dist/build.d.ts.map +0 -1
  21. package/dist/frontend/utils.d.ts +0 -3
  22. package/dist/frontend/utils.d.ts.map +0 -1
  23. package/dist/generated/prompts/typescript/prompts.d.ts +0 -22
  24. package/dist/generated/prompts/typescript/prompts.d.ts.map +0 -1
  25. package/dist/generated/specs/spec-helpers.d.ts +0 -49
  26. package/dist/generated/specs/spec-helpers.d.ts.map +0 -1
  27. package/dist/generated/specs/specs.d.ts +0 -113
  28. package/dist/generated/specs/specs.d.ts.map +0 -1
  29. package/dist/index.browser.d.ts +0 -4
  30. package/dist/index.browser.d.ts.map +0 -1
  31. package/dist/index.d.ts +0 -7
  32. package/dist/index.d.ts.map +0 -1
  33. package/dist/node/index.node.js +0 -5876
  34. package/dist/node/index.node.js.map +0 -103
  35. package/dist/providers/goals.d.ts +0 -4
  36. package/dist/providers/goals.d.ts.map +0 -1
  37. package/dist/schema.d.ts +0 -825
  38. package/dist/schema.d.ts.map +0 -1
  39. package/dist/services/goalDataService.d.ts +0 -68
  40. package/dist/services/goalDataService.d.ts.map +0 -1
  41. package/dist/tests.d.ts +0 -6
  42. package/dist/tests.d.ts.map +0 -1
  43. package/dist/vitest.config.d.ts +0 -3
  44. package/dist/vitest.config.d.ts.map +0 -1
@@ -1,103 +0,0 @@
1
- {
2
- "version": 3,
3
- "sources": ["../../../../../node_modules/.bun/drizzle-orm@0.45.1+d25e0730597d4111/node_modules/drizzle-orm/entity.js", "../../../../../node_modules/.bun/drizzle-orm@0.45.1+d25e0730597d4111/node_modules/drizzle-orm/column.js", "../../../../../node_modules/.bun/drizzle-orm@0.45.1+d25e0730597d4111/node_modules/drizzle-orm/column-builder.js", "../../../../../node_modules/.bun/drizzle-orm@0.45.1+d25e0730597d4111/node_modules/drizzle-orm/table.utils.js", "../../../../../node_modules/.bun/drizzle-orm@0.45.1+d25e0730597d4111/node_modules/drizzle-orm/pg-core/foreign-keys.js", "../../../../../node_modules/.bun/drizzle-orm@0.45.1+d25e0730597d4111/node_modules/drizzle-orm/tracing-utils.js", "../../../../../node_modules/.bun/drizzle-orm@0.45.1+d25e0730597d4111/node_modules/drizzle-orm/pg-core/unique-constraint.js", "../../../../../node_modules/.bun/drizzle-orm@0.45.1+d25e0730597d4111/node_modules/drizzle-orm/pg-core/utils/array.js", "../../../../../node_modules/.bun/drizzle-orm@0.45.1+d25e0730597d4111/node_modules/drizzle-orm/pg-core/columns/common.js", "../../../../../node_modules/.bun/drizzle-orm@0.45.1+d25e0730597d4111/node_modules/drizzle-orm/pg-core/columns/enum.js", "../../../../../node_modules/.bun/drizzle-orm@0.45.1+d25e0730597d4111/node_modules/drizzle-orm/subquery.js", "../../../../../node_modules/.bun/drizzle-orm@0.45.1+d25e0730597d4111/node_modules/drizzle-orm/version.js", "../../../../../node_modules/.bun/drizzle-orm@0.45.1+d25e0730597d4111/node_modules/drizzle-orm/tracing.js", "../../../../../node_modules/.bun/drizzle-orm@0.45.1+d25e0730597d4111/node_modules/drizzle-orm/view-common.js", "../../../../../node_modules/.bun/drizzle-orm@0.45.1+d25e0730597d4111/node_modules/drizzle-orm/table.js", "../../../../../node_modules/.bun/drizzle-orm@0.45.1+d25e0730597d4111/node_modules/drizzle-orm/sql/sql.js", "../../../../../node_modules/.bun/drizzle-orm@0.45.1+d25e0730597d4111/node_modules/drizzle-orm/alias.js", "../../../../../node_modules/.bun/drizzle-orm@0.45.1+d25e0730597d4111/node_modules/drizzle-orm/query-promise.js", "../../../../../node_modules/.bun/drizzle-orm@0.45.1+d25e0730597d4111/node_modules/drizzle-orm/utils.js", "../../../../../node_modules/.bun/drizzle-orm@0.45.1+d25e0730597d4111/node_modules/drizzle-orm/pg-core/columns/int.common.js", "../../../../../node_modules/.bun/drizzle-orm@0.45.1+d25e0730597d4111/node_modules/drizzle-orm/pg-core/columns/bigint.js", "../../../../../node_modules/.bun/drizzle-orm@0.45.1+d25e0730597d4111/node_modules/drizzle-orm/pg-core/columns/bigserial.js", "../../../../../node_modules/.bun/drizzle-orm@0.45.1+d25e0730597d4111/node_modules/drizzle-orm/pg-core/columns/boolean.js", "../../../../../node_modules/.bun/drizzle-orm@0.45.1+d25e0730597d4111/node_modules/drizzle-orm/pg-core/columns/char.js", "../../../../../node_modules/.bun/drizzle-orm@0.45.1+d25e0730597d4111/node_modules/drizzle-orm/pg-core/columns/cidr.js", "../../../../../node_modules/.bun/drizzle-orm@0.45.1+d25e0730597d4111/node_modules/drizzle-orm/pg-core/columns/custom.js", "../../../../../node_modules/.bun/drizzle-orm@0.45.1+d25e0730597d4111/node_modules/drizzle-orm/pg-core/columns/date.common.js", "../../../../../node_modules/.bun/drizzle-orm@0.45.1+d25e0730597d4111/node_modules/drizzle-orm/pg-core/columns/date.js", "../../../../../node_modules/.bun/drizzle-orm@0.45.1+d25e0730597d4111/node_modules/drizzle-orm/pg-core/columns/double-precision.js", "../../../../../node_modules/.bun/drizzle-orm@0.45.1+d25e0730597d4111/node_modules/drizzle-orm/pg-core/columns/inet.js", "../../../../../node_modules/.bun/drizzle-orm@0.45.1+d25e0730597d4111/node_modules/drizzle-orm/pg-core/columns/integer.js", "../../../../../node_modules/.bun/drizzle-orm@0.45.1+d25e0730597d4111/node_modules/drizzle-orm/pg-core/columns/interval.js", "../../../../../node_modules/.bun/drizzle-orm@0.45.1+d25e0730597d4111/node_modules/drizzle-orm/pg-core/columns/json.js", "../../../../../node_modules/.bun/drizzle-orm@0.45.1+d25e0730597d4111/node_modules/drizzle-orm/pg-core/columns/jsonb.js", "../../../../../node_modules/.bun/drizzle-orm@0.45.1+d25e0730597d4111/node_modules/drizzle-orm/pg-core/columns/line.js", "../../../../../node_modules/.bun/drizzle-orm@0.45.1+d25e0730597d4111/node_modules/drizzle-orm/pg-core/columns/macaddr.js", "../../../../../node_modules/.bun/drizzle-orm@0.45.1+d25e0730597d4111/node_modules/drizzle-orm/pg-core/columns/macaddr8.js", "../../../../../node_modules/.bun/drizzle-orm@0.45.1+d25e0730597d4111/node_modules/drizzle-orm/pg-core/columns/numeric.js", "../../../../../node_modules/.bun/drizzle-orm@0.45.1+d25e0730597d4111/node_modules/drizzle-orm/pg-core/columns/point.js", "../../../../../node_modules/.bun/drizzle-orm@0.45.1+d25e0730597d4111/node_modules/drizzle-orm/pg-core/columns/postgis_extension/utils.js", "../../../../../node_modules/.bun/drizzle-orm@0.45.1+d25e0730597d4111/node_modules/drizzle-orm/pg-core/columns/postgis_extension/geometry.js", "../../../../../node_modules/.bun/drizzle-orm@0.45.1+d25e0730597d4111/node_modules/drizzle-orm/pg-core/columns/real.js", "../../../../../node_modules/.bun/drizzle-orm@0.45.1+d25e0730597d4111/node_modules/drizzle-orm/pg-core/columns/serial.js", "../../../../../node_modules/.bun/drizzle-orm@0.45.1+d25e0730597d4111/node_modules/drizzle-orm/pg-core/columns/smallint.js", "../../../../../node_modules/.bun/drizzle-orm@0.45.1+d25e0730597d4111/node_modules/drizzle-orm/pg-core/columns/smallserial.js", "../../../../../node_modules/.bun/drizzle-orm@0.45.1+d25e0730597d4111/node_modules/drizzle-orm/pg-core/columns/text.js", "../../../../../node_modules/.bun/drizzle-orm@0.45.1+d25e0730597d4111/node_modules/drizzle-orm/pg-core/columns/time.js", "../../../../../node_modules/.bun/drizzle-orm@0.45.1+d25e0730597d4111/node_modules/drizzle-orm/pg-core/columns/timestamp.js", "../../../../../node_modules/.bun/drizzle-orm@0.45.1+d25e0730597d4111/node_modules/drizzle-orm/pg-core/columns/uuid.js", "../../../../../node_modules/.bun/drizzle-orm@0.45.1+d25e0730597d4111/node_modules/drizzle-orm/pg-core/columns/varchar.js", "../../../../../node_modules/.bun/drizzle-orm@0.45.1+d25e0730597d4111/node_modules/drizzle-orm/pg-core/columns/vector_extension/bit.js", "../../../../../node_modules/.bun/drizzle-orm@0.45.1+d25e0730597d4111/node_modules/drizzle-orm/pg-core/columns/vector_extension/halfvec.js", "../../../../../node_modules/.bun/drizzle-orm@0.45.1+d25e0730597d4111/node_modules/drizzle-orm/pg-core/columns/vector_extension/sparsevec.js", "../../../../../node_modules/.bun/drizzle-orm@0.45.1+d25e0730597d4111/node_modules/drizzle-orm/pg-core/columns/vector_extension/vector.js", "../../../../../node_modules/.bun/drizzle-orm@0.45.1+d25e0730597d4111/node_modules/drizzle-orm/pg-core/columns/all.js", "../../../../../node_modules/.bun/drizzle-orm@0.45.1+d25e0730597d4111/node_modules/drizzle-orm/pg-core/table.js", "../../../../../node_modules/.bun/drizzle-orm@0.45.1+d25e0730597d4111/node_modules/drizzle-orm/sql/expressions/conditions.js", "../../../../../node_modules/.bun/drizzle-orm@0.45.1+d25e0730597d4111/node_modules/drizzle-orm/sql/expressions/select.js", "../../../../../node_modules/.bun/drizzle-orm@0.45.1+d25e0730597d4111/node_modules/drizzle-orm/sql/expressions/index.js", "../../../../../node_modules/.bun/drizzle-orm@0.45.1+d25e0730597d4111/node_modules/drizzle-orm/relations.js", "../../../../../node_modules/.bun/drizzle-orm@0.45.1+d25e0730597d4111/node_modules/drizzle-orm/sql/functions/index.js", "../../../../../node_modules/.bun/drizzle-orm@0.45.1+d25e0730597d4111/node_modules/drizzle-orm/sql/index.js", "../../../../../node_modules/.bun/drizzle-orm@0.45.1+d25e0730597d4111/node_modules/drizzle-orm/index.js", "../../node_modules/uuid/dist-node/stringify.js", "../../node_modules/uuid/dist-node/rng.js", "../../node_modules/uuid/dist-node/native.js", "../../node_modules/uuid/dist-node/v4.js", "../../node_modules/uuid/dist-node/index.js", "../../../../../node_modules/.bun/drizzle-orm@0.45.1+d25e0730597d4111/node_modules/drizzle-orm/pg-core/columns/index.js", "../../../../../node_modules/.bun/drizzle-orm@0.45.1+d25e0730597d4111/node_modules/drizzle-orm/selection-proxy.js", "../../../../../node_modules/.bun/drizzle-orm@0.45.1+d25e0730597d4111/node_modules/drizzle-orm/pg-core/indexes.js", "../../../../../node_modules/.bun/drizzle-orm@0.45.1+d25e0730597d4111/node_modules/drizzle-orm/pg-core/view-common.js", "../../../../../node_modules/.bun/drizzle-orm@0.45.1+d25e0730597d4111/node_modules/drizzle-orm/query-builders/query-builder.js", "../../../../../node_modules/.bun/drizzle-orm@0.45.1+d25e0730597d4111/node_modules/drizzle-orm/pg-core/query-builders/select.js", "../../../../../node_modules/.bun/drizzle-orm@0.45.1+d25e0730597d4111/node_modules/drizzle-orm/pg-core/view.js", "../../../../../node_modules/.bun/drizzle-orm@0.45.1+d25e0730597d4111/node_modules/drizzle-orm/pg-core/utils.js", "../../../../../node_modules/.bun/drizzle-orm@0.45.1+d25e0730597d4111/node_modules/drizzle-orm/pg-core/query-builders/update.js", "../../../../../node_modules/.bun/drizzle-orm@0.45.1+d25e0730597d4111/node_modules/drizzle-orm/pg-core/query-builders/index.js", "../../../../../node_modules/.bun/drizzle-orm@0.45.1+d25e0730597d4111/node_modules/drizzle-orm/pg-core/utils/index.js", "../../../../../node_modules/.bun/drizzle-orm@0.45.1+d25e0730597d4111/node_modules/drizzle-orm/pg-core/index.js", "../../schema.ts", "../../services/goalDataService.ts", "../../index.ts", "../../actions/cancelGoal.ts", "../../generated/prompts/typescript/prompts.ts", "../../generated/specs/specs.ts", "../../generated/specs/spec-helpers.ts", "../../actions/completeGoal.ts", "../../actions/confirmGoal.ts", "../../actions/createGoal.ts", "../../actions/updateGoal.ts", "../../apis.ts", "../../providers/goals.ts", "../../__tests__/e2e/goals-plugin.ts"],
4
- "sourcesContent": [
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
- "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",
7
- "import { entityKind } from \"./entity.js\";\nclass ColumnBuilder {\n static [entityKind] = \"ColumnBuilder\";\n config;\n constructor(name, dataType, columnType) {\n this.config = {\n name,\n keyAsName: name === \"\",\n notNull: false,\n default: void 0,\n hasDefault: false,\n primaryKey: false,\n isUnique: false,\n uniqueName: void 0,\n uniqueType: void 0,\n dataType,\n columnType,\n generated: void 0\n };\n }\n /**\n * Changes the data type of the column. Commonly used with `json` columns. Also, useful for branded types.\n *\n * @example\n * ```ts\n * const users = pgTable('users', {\n * \tid: integer('id').$type<UserId>().primaryKey(),\n * \tdetails: json('details').$type<UserDetails>().notNull(),\n * });\n * ```\n */\n $type() {\n return this;\n }\n /**\n * Adds a `not null` clause to the column definition.\n *\n * Affects the `select` model of the table - columns *without* `not null` will be nullable on select.\n */\n notNull() {\n this.config.notNull = true;\n return this;\n }\n /**\n * Adds a `default <value>` clause to the column definition.\n *\n * Affects the `insert` model of the table - columns *with* `default` are optional on insert.\n *\n * If you need to set a dynamic default value, use {@link $defaultFn} instead.\n */\n default(value) {\n this.config.default = value;\n this.config.hasDefault = true;\n return this;\n }\n /**\n * Adds a dynamic default value to the column.\n * The function will be called when the row is inserted, and the returned value will be used as the column value.\n *\n * **Note:** This value does not affect the `drizzle-kit` behavior, it is only used at runtime in `drizzle-orm`.\n */\n $defaultFn(fn) {\n this.config.defaultFn = fn;\n this.config.hasDefault = true;\n return this;\n }\n /**\n * Alias for {@link $defaultFn}.\n */\n $default = this.$defaultFn;\n /**\n * Adds a dynamic update value to the column.\n * The function will be called when the row is updated, and the returned value will be used as the column value if none is provided.\n * If no `default` (or `$defaultFn`) value is provided, the function will be called when the row is inserted as well, and the returned value will be used as the column value.\n *\n * **Note:** This value does not affect the `drizzle-kit` behavior, it is only used at runtime in `drizzle-orm`.\n */\n $onUpdateFn(fn) {\n this.config.onUpdateFn = fn;\n this.config.hasDefault = true;\n return this;\n }\n /**\n * Alias for {@link $onUpdateFn}.\n */\n $onUpdate = this.$onUpdateFn;\n /**\n * Adds a `primary key` clause to the column definition. This implicitly makes the column `not null`.\n *\n * In SQLite, `integer primary key` implicitly makes the column auto-incrementing.\n */\n primaryKey() {\n this.config.primaryKey = true;\n this.config.notNull = true;\n return this;\n }\n /** @internal Sets the name of the column to the key within the table definition if a name was not given. */\n setName(name) {\n if (this.config.name !== \"\") return;\n this.config.name = name;\n }\n}\nexport {\n ColumnBuilder\n};\n//# sourceMappingURL=column-builder.js.map",
8
- "const TableName = Symbol.for(\"drizzle:Name\");\nexport {\n TableName\n};\n//# sourceMappingURL=table.utils.js.map",
9
- "import { entityKind } from \"../entity.js\";\nimport { TableName } from \"../table.utils.js\";\nclass ForeignKeyBuilder {\n static [entityKind] = \"PgForeignKeyBuilder\";\n /** @internal */\n reference;\n /** @internal */\n _onUpdate = \"no action\";\n /** @internal */\n _onDelete = \"no action\";\n constructor(config, actions) {\n this.reference = () => {\n const { name, columns, foreignColumns } = config();\n return { name, columns, foreignTable: foreignColumns[0].table, foreignColumns };\n };\n if (actions) {\n this._onUpdate = actions.onUpdate;\n this._onDelete = actions.onDelete;\n }\n }\n onUpdate(action) {\n this._onUpdate = action === void 0 ? \"no action\" : action;\n return this;\n }\n onDelete(action) {\n this._onDelete = action === void 0 ? \"no action\" : action;\n return this;\n }\n /** @internal */\n build(table) {\n return new ForeignKey(table, this);\n }\n}\nclass ForeignKey {\n constructor(table, builder) {\n this.table = table;\n this.reference = builder.reference;\n this.onUpdate = builder._onUpdate;\n this.onDelete = builder._onDelete;\n }\n static [entityKind] = \"PgForeignKey\";\n reference;\n onUpdate;\n onDelete;\n getName() {\n const { name, columns, foreignColumns } = this.reference();\n const columnNames = columns.map((column) => column.name);\n const foreignColumnNames = foreignColumns.map((column) => column.name);\n const chunks = [\n this.table[TableName],\n ...columnNames,\n foreignColumns[0].table[TableName],\n ...foreignColumnNames\n ];\n return name ?? `${chunks.join(\"_\")}_fk`;\n }\n}\nfunction foreignKey(config) {\n function mappedConfig() {\n const { name, columns, foreignColumns } = config;\n return {\n name,\n columns,\n foreignColumns\n };\n }\n return new ForeignKeyBuilder(mappedConfig);\n}\nexport {\n ForeignKey,\n ForeignKeyBuilder,\n foreignKey\n};\n//# sourceMappingURL=foreign-keys.js.map",
10
- "function iife(fn, ...args) {\n return fn(...args);\n}\nexport {\n iife\n};\n//# sourceMappingURL=tracing-utils.js.map",
11
- "import { entityKind } from \"../entity.js\";\nimport { TableName } from \"../table.utils.js\";\nfunction unique(name) {\n return new UniqueOnConstraintBuilder(name);\n}\nfunction uniqueKeyName(table, columns) {\n return `${table[TableName]}_${columns.join(\"_\")}_unique`;\n}\nclass UniqueConstraintBuilder {\n constructor(columns, name) {\n this.name = name;\n this.columns = columns;\n }\n static [entityKind] = \"PgUniqueConstraintBuilder\";\n /** @internal */\n columns;\n /** @internal */\n nullsNotDistinctConfig = false;\n nullsNotDistinct() {\n this.nullsNotDistinctConfig = true;\n return this;\n }\n /** @internal */\n build(table) {\n return new UniqueConstraint(table, this.columns, this.nullsNotDistinctConfig, this.name);\n }\n}\nclass UniqueOnConstraintBuilder {\n static [entityKind] = \"PgUniqueOnConstraintBuilder\";\n /** @internal */\n name;\n constructor(name) {\n this.name = name;\n }\n on(...columns) {\n return new UniqueConstraintBuilder(columns, this.name);\n }\n}\nclass UniqueConstraint {\n constructor(table, columns, nullsNotDistinct, name) {\n this.table = table;\n this.columns = columns;\n this.name = name ?? uniqueKeyName(this.table, this.columns.map((column) => column.name));\n this.nullsNotDistinct = nullsNotDistinct;\n }\n static [entityKind] = \"PgUniqueConstraint\";\n columns;\n name;\n nullsNotDistinct = false;\n getName() {\n return this.name;\n }\n}\nexport {\n UniqueConstraint,\n UniqueConstraintBuilder,\n UniqueOnConstraintBuilder,\n unique,\n uniqueKeyName\n};\n//# sourceMappingURL=unique-constraint.js.map",
12
- "function parsePgArrayValue(arrayString, startFrom, inQuotes) {\n for (let i = startFrom; i < arrayString.length; i++) {\n const char = arrayString[i];\n if (char === \"\\\\\") {\n i++;\n continue;\n }\n if (char === '\"') {\n return [arrayString.slice(startFrom, i).replace(/\\\\/g, \"\"), i + 1];\n }\n if (inQuotes) {\n continue;\n }\n if (char === \",\" || char === \"}\") {\n return [arrayString.slice(startFrom, i).replace(/\\\\/g, \"\"), i];\n }\n }\n return [arrayString.slice(startFrom).replace(/\\\\/g, \"\"), arrayString.length];\n}\nfunction parsePgNestedArray(arrayString, startFrom = 0) {\n const result = [];\n let i = startFrom;\n let lastCharIsComma = false;\n while (i < arrayString.length) {\n const char = arrayString[i];\n if (char === \",\") {\n if (lastCharIsComma || i === startFrom) {\n result.push(\"\");\n }\n lastCharIsComma = true;\n i++;\n continue;\n }\n lastCharIsComma = false;\n if (char === \"\\\\\") {\n i += 2;\n continue;\n }\n if (char === '\"') {\n const [value2, startFrom2] = parsePgArrayValue(arrayString, i + 1, true);\n result.push(value2);\n i = startFrom2;\n continue;\n }\n if (char === \"}\") {\n return [result, i + 1];\n }\n if (char === \"{\") {\n const [value2, startFrom2] = parsePgNestedArray(arrayString, i + 1);\n result.push(value2);\n i = startFrom2;\n continue;\n }\n const [value, newStartFrom] = parsePgArrayValue(arrayString, i, false);\n result.push(value);\n i = newStartFrom;\n }\n return [result, i];\n}\nfunction parsePgArray(arrayString) {\n const [result] = parsePgNestedArray(arrayString, 1);\n return result;\n}\nfunction makePgArray(array) {\n return `{${array.map((item) => {\n if (Array.isArray(item)) {\n return makePgArray(item);\n }\n if (typeof item === \"string\") {\n return `\"${item.replace(/\\\\/g, \"\\\\\\\\\").replace(/\"/g, '\\\\\"')}\"`;\n }\n return `${item}`;\n }).join(\",\")}}`;\n}\nexport {\n makePgArray,\n parsePgArray,\n parsePgNestedArray\n};\n//# sourceMappingURL=array.js.map",
13
- "import { ColumnBuilder } from \"../../column-builder.js\";\nimport { Column } from \"../../column.js\";\nimport { entityKind, is } from \"../../entity.js\";\nimport { ForeignKeyBuilder } from \"../foreign-keys.js\";\nimport { iife } from \"../../tracing-utils.js\";\nimport { uniqueKeyName } from \"../unique-constraint.js\";\nimport { makePgArray, parsePgArray } from \"../utils/array.js\";\nclass PgColumnBuilder extends ColumnBuilder {\n foreignKeyConfigs = [];\n static [entityKind] = \"PgColumnBuilder\";\n array(size) {\n return new PgArrayBuilder(this.config.name, this, size);\n }\n references(ref, actions = {}) {\n this.foreignKeyConfigs.push({ ref, actions });\n return this;\n }\n unique(name, config) {\n this.config.isUnique = true;\n this.config.uniqueName = name;\n this.config.uniqueType = config?.nulls;\n return this;\n }\n generatedAlwaysAs(as) {\n this.config.generated = {\n as,\n type: \"always\",\n mode: \"stored\"\n };\n return this;\n }\n /** @internal */\n buildForeignKeys(column, table) {\n return this.foreignKeyConfigs.map(({ ref, actions }) => {\n return iife(\n (ref2, actions2) => {\n const builder = new ForeignKeyBuilder(() => {\n const foreignColumn = ref2();\n return { columns: [column], foreignColumns: [foreignColumn] };\n });\n if (actions2.onUpdate) {\n builder.onUpdate(actions2.onUpdate);\n }\n if (actions2.onDelete) {\n builder.onDelete(actions2.onDelete);\n }\n return builder.build(table);\n },\n ref,\n actions\n );\n });\n }\n /** @internal */\n buildExtraConfigColumn(table) {\n return new ExtraConfigColumn(table, this.config);\n }\n}\nclass PgColumn extends Column {\n constructor(table, config) {\n if (!config.uniqueName) {\n config.uniqueName = uniqueKeyName(table, [config.name]);\n }\n super(table, config);\n this.table = table;\n }\n static [entityKind] = \"PgColumn\";\n}\nclass ExtraConfigColumn extends PgColumn {\n static [entityKind] = \"ExtraConfigColumn\";\n getSQLType() {\n return this.getSQLType();\n }\n indexConfig = {\n order: this.config.order ?? \"asc\",\n nulls: this.config.nulls ?? \"last\",\n opClass: this.config.opClass\n };\n defaultConfig = {\n order: \"asc\",\n nulls: \"last\",\n opClass: void 0\n };\n asc() {\n this.indexConfig.order = \"asc\";\n return this;\n }\n desc() {\n this.indexConfig.order = \"desc\";\n return this;\n }\n nullsFirst() {\n this.indexConfig.nulls = \"first\";\n return this;\n }\n nullsLast() {\n this.indexConfig.nulls = \"last\";\n return this;\n }\n /**\n * ### PostgreSQL documentation quote\n *\n * > An operator class with optional parameters can be specified for each column of an index.\n * The operator class identifies the operators to be used by the index for that column.\n * For example, a B-tree index on four-byte integers would use the int4_ops class;\n * this operator class includes comparison functions for four-byte integers.\n * In practice the default operator class for the column's data type is usually sufficient.\n * The main point of having operator classes is that for some data types, there could be more than one meaningful ordering.\n * For example, we might want to sort a complex-number data type either by absolute value or by real part.\n * We could do this by defining two operator classes for the data type and then selecting the proper class when creating an index.\n * More information about operator classes check:\n *\n * ### Useful links\n * https://www.postgresql.org/docs/current/sql-createindex.html\n *\n * https://www.postgresql.org/docs/current/indexes-opclass.html\n *\n * https://www.postgresql.org/docs/current/xindex.html\n *\n * ### Additional types\n * If you have the `pg_vector` extension installed in your database, you can use the\n * `vector_l2_ops`, `vector_ip_ops`, `vector_cosine_ops`, `vector_l1_ops`, `bit_hamming_ops`, `bit_jaccard_ops`, `halfvec_l2_ops`, `sparsevec_l2_ops` options, which are predefined types.\n *\n * **You can always specify any string you want in the operator class, in case Drizzle doesn't have it natively in its types**\n *\n * @param opClass\n * @returns\n */\n op(opClass) {\n this.indexConfig.opClass = opClass;\n return this;\n }\n}\nclass IndexedColumn {\n static [entityKind] = \"IndexedColumn\";\n constructor(name, keyAsName, type, indexConfig) {\n this.name = name;\n this.keyAsName = keyAsName;\n this.type = type;\n this.indexConfig = indexConfig;\n }\n name;\n keyAsName;\n type;\n indexConfig;\n}\nclass PgArrayBuilder extends PgColumnBuilder {\n static [entityKind] = \"PgArrayBuilder\";\n constructor(name, baseBuilder, size) {\n super(name, \"array\", \"PgArray\");\n this.config.baseBuilder = baseBuilder;\n this.config.size = size;\n }\n /** @internal */\n build(table) {\n const baseColumn = this.config.baseBuilder.build(table);\n return new PgArray(\n table,\n this.config,\n baseColumn\n );\n }\n}\nclass PgArray extends PgColumn {\n constructor(table, config, baseColumn, range) {\n super(table, config);\n this.baseColumn = baseColumn;\n this.range = range;\n this.size = config.size;\n }\n size;\n static [entityKind] = \"PgArray\";\n getSQLType() {\n return `${this.baseColumn.getSQLType()}[${typeof this.size === \"number\" ? this.size : \"\"}]`;\n }\n mapFromDriverValue(value) {\n if (typeof value === \"string\") {\n value = parsePgArray(value);\n }\n return value.map((v) => this.baseColumn.mapFromDriverValue(v));\n }\n mapToDriverValue(value, isNestedArray = false) {\n const a = value.map(\n (v) => v === null ? null : is(this.baseColumn, PgArray) ? this.baseColumn.mapToDriverValue(v, true) : this.baseColumn.mapToDriverValue(v)\n );\n if (isNestedArray) return a;\n return makePgArray(a);\n }\n}\nexport {\n ExtraConfigColumn,\n IndexedColumn,\n PgArray,\n PgArrayBuilder,\n PgColumn,\n PgColumnBuilder\n};\n//# sourceMappingURL=common.js.map",
14
- "import { entityKind } from \"../../entity.js\";\nimport { PgColumn, PgColumnBuilder } from \"./common.js\";\nclass PgEnumObjectColumnBuilder extends PgColumnBuilder {\n static [entityKind] = \"PgEnumObjectColumnBuilder\";\n constructor(name, enumInstance) {\n super(name, \"string\", \"PgEnumObjectColumn\");\n this.config.enum = enumInstance;\n }\n /** @internal */\n build(table) {\n return new PgEnumObjectColumn(\n table,\n this.config\n );\n }\n}\nclass PgEnumObjectColumn extends PgColumn {\n static [entityKind] = \"PgEnumObjectColumn\";\n enum;\n enumValues = this.config.enum.enumValues;\n constructor(table, config) {\n super(table, config);\n this.enum = config.enum;\n }\n getSQLType() {\n return this.enum.enumName;\n }\n}\nconst isPgEnumSym = Symbol.for(\"drizzle:isPgEnum\");\nfunction isPgEnum(obj) {\n return !!obj && typeof obj === \"function\" && isPgEnumSym in obj && obj[isPgEnumSym] === true;\n}\nclass PgEnumColumnBuilder extends PgColumnBuilder {\n static [entityKind] = \"PgEnumColumnBuilder\";\n constructor(name, enumInstance) {\n super(name, \"string\", \"PgEnumColumn\");\n this.config.enum = enumInstance;\n }\n /** @internal */\n build(table) {\n return new PgEnumColumn(\n table,\n this.config\n );\n }\n}\nclass PgEnumColumn extends PgColumn {\n static [entityKind] = \"PgEnumColumn\";\n enum = this.config.enum;\n enumValues = this.config.enum.enumValues;\n constructor(table, config) {\n super(table, config);\n this.enum = config.enum;\n }\n getSQLType() {\n return this.enum.enumName;\n }\n}\nfunction pgEnum(enumName, input) {\n return Array.isArray(input) ? pgEnumWithSchema(enumName, [...input], void 0) : pgEnumObjectWithSchema(enumName, input, void 0);\n}\nfunction pgEnumWithSchema(enumName, values, schema) {\n const enumInstance = Object.assign(\n (name) => new PgEnumColumnBuilder(name ?? \"\", enumInstance),\n {\n enumName,\n enumValues: values,\n schema,\n [isPgEnumSym]: true\n }\n );\n return enumInstance;\n}\nfunction pgEnumObjectWithSchema(enumName, values, schema) {\n const enumInstance = Object.assign(\n (name) => new PgEnumObjectColumnBuilder(name ?? \"\", enumInstance),\n {\n enumName,\n enumValues: Object.values(values),\n schema,\n [isPgEnumSym]: true\n }\n );\n return enumInstance;\n}\nexport {\n PgEnumColumn,\n PgEnumColumnBuilder,\n PgEnumObjectColumn,\n PgEnumObjectColumnBuilder,\n isPgEnum,\n pgEnum,\n pgEnumObjectWithSchema,\n pgEnumWithSchema\n};\n//# sourceMappingURL=enum.js.map",
15
- "import { entityKind } from \"./entity.js\";\nclass Subquery {\n static [entityKind] = \"Subquery\";\n constructor(sql, fields, alias, isWith = false, usedTables = []) {\n this._ = {\n brand: \"Subquery\",\n sql,\n selectedFields: fields,\n alias,\n isWith,\n usedTables\n };\n }\n // getSQL(): SQL<unknown> {\n // \treturn new SQL([this]);\n // }\n}\nclass WithSubquery extends Subquery {\n static [entityKind] = \"WithSubquery\";\n}\nexport {\n Subquery,\n WithSubquery\n};\n//# sourceMappingURL=subquery.js.map",
16
- "// package.json\nvar version = \"0.45.1\";\n\n// src/version.ts\nvar compatibilityVersion = 10;\nexport {\n compatibilityVersion,\n version as npmVersion\n};\n",
17
- "import { iife } from \"./tracing-utils.js\";\nimport { npmVersion } from \"./version.js\";\nlet otel;\nlet rawTracer;\nconst tracer = {\n startActiveSpan(name, fn) {\n if (!otel) {\n return fn();\n }\n if (!rawTracer) {\n rawTracer = otel.trace.getTracer(\"drizzle-orm\", npmVersion);\n }\n return iife(\n (otel2, rawTracer2) => rawTracer2.startActiveSpan(\n name,\n (span) => {\n try {\n return fn(span);\n } catch (e) {\n span.setStatus({\n code: otel2.SpanStatusCode.ERROR,\n message: e instanceof Error ? e.message : \"Unknown error\"\n // eslint-disable-line no-instanceof/no-instanceof\n });\n throw e;\n } finally {\n span.end();\n }\n }\n ),\n otel,\n rawTracer\n );\n }\n};\nexport {\n tracer\n};\n//# sourceMappingURL=tracing.js.map",
18
- "const ViewBaseConfig = Symbol.for(\"drizzle:ViewBaseConfig\");\nexport {\n ViewBaseConfig\n};\n//# sourceMappingURL=view-common.js.map",
19
- "import { entityKind } from \"./entity.js\";\nimport { TableName } from \"./table.utils.js\";\nconst Schema = Symbol.for(\"drizzle:Schema\");\nconst Columns = Symbol.for(\"drizzle:Columns\");\nconst ExtraConfigColumns = Symbol.for(\"drizzle:ExtraConfigColumns\");\nconst OriginalName = Symbol.for(\"drizzle:OriginalName\");\nconst BaseName = Symbol.for(\"drizzle:BaseName\");\nconst IsAlias = Symbol.for(\"drizzle:IsAlias\");\nconst ExtraConfigBuilder = Symbol.for(\"drizzle:ExtraConfigBuilder\");\nconst IsDrizzleTable = Symbol.for(\"drizzle:IsDrizzleTable\");\nclass Table {\n static [entityKind] = \"Table\";\n /** @internal */\n static Symbol = {\n Name: TableName,\n Schema,\n OriginalName,\n Columns,\n ExtraConfigColumns,\n BaseName,\n IsAlias,\n ExtraConfigBuilder\n };\n /**\n * @internal\n * Can be changed if the table is aliased.\n */\n [TableName];\n /**\n * @internal\n * Used to store the original name of the table, before any aliasing.\n */\n [OriginalName];\n /** @internal */\n [Schema];\n /** @internal */\n [Columns];\n /** @internal */\n [ExtraConfigColumns];\n /**\n * @internal\n * Used to store the table name before the transformation via the `tableCreator` functions.\n */\n [BaseName];\n /** @internal */\n [IsAlias] = false;\n /** @internal */\n [IsDrizzleTable] = true;\n /** @internal */\n [ExtraConfigBuilder] = void 0;\n constructor(name, schema, baseName) {\n this[TableName] = this[OriginalName] = name;\n this[Schema] = schema;\n this[BaseName] = baseName;\n }\n}\nfunction isTable(table) {\n return typeof table === \"object\" && table !== null && IsDrizzleTable in table;\n}\nfunction getTableName(table) {\n return table[TableName];\n}\nfunction getTableUniqueName(table) {\n return `${table[Schema] ?? \"public\"}.${table[TableName]}`;\n}\nexport {\n BaseName,\n Columns,\n ExtraConfigBuilder,\n ExtraConfigColumns,\n IsAlias,\n OriginalName,\n Schema,\n Table,\n getTableName,\n getTableUniqueName,\n isTable\n};\n//# sourceMappingURL=table.js.map",
20
- "import { entityKind, is } from \"../entity.js\";\nimport { isPgEnum } from \"../pg-core/columns/enum.js\";\nimport { Subquery } from \"../subquery.js\";\nimport { tracer } from \"../tracing.js\";\nimport { ViewBaseConfig } from \"../view-common.js\";\nimport { Column } from \"../column.js\";\nimport { IsAlias, Table } from \"../table.js\";\nclass FakePrimitiveParam {\n static [entityKind] = \"FakePrimitiveParam\";\n}\nfunction isSQLWrapper(value) {\n return value !== null && value !== void 0 && typeof value.getSQL === \"function\";\n}\nfunction mergeQueries(queries) {\n const result = { sql: \"\", params: [] };\n for (const query of queries) {\n result.sql += query.sql;\n result.params.push(...query.params);\n if (query.typings?.length) {\n if (!result.typings) {\n result.typings = [];\n }\n result.typings.push(...query.typings);\n }\n }\n return result;\n}\nclass StringChunk {\n static [entityKind] = \"StringChunk\";\n value;\n constructor(value) {\n this.value = Array.isArray(value) ? value : [value];\n }\n getSQL() {\n return new SQL([this]);\n }\n}\nclass SQL {\n constructor(queryChunks) {\n this.queryChunks = queryChunks;\n for (const chunk of queryChunks) {\n if (is(chunk, Table)) {\n const schemaName = chunk[Table.Symbol.Schema];\n this.usedTables.push(\n schemaName === void 0 ? chunk[Table.Symbol.Name] : schemaName + \".\" + chunk[Table.Symbol.Name]\n );\n }\n }\n }\n static [entityKind] = \"SQL\";\n /** @internal */\n decoder = noopDecoder;\n shouldInlineParams = false;\n /** @internal */\n usedTables = [];\n append(query) {\n this.queryChunks.push(...query.queryChunks);\n return this;\n }\n toQuery(config) {\n return tracer.startActiveSpan(\"drizzle.buildSQL\", (span) => {\n const query = this.buildQueryFromSourceParams(this.queryChunks, config);\n span?.setAttributes({\n \"drizzle.query.text\": query.sql,\n \"drizzle.query.params\": JSON.stringify(query.params)\n });\n return query;\n });\n }\n buildQueryFromSourceParams(chunks, _config) {\n const config = Object.assign({}, _config, {\n inlineParams: _config.inlineParams || this.shouldInlineParams,\n paramStartIndex: _config.paramStartIndex || { value: 0 }\n });\n const {\n casing,\n escapeName,\n escapeParam,\n prepareTyping,\n inlineParams,\n paramStartIndex\n } = config;\n return mergeQueries(chunks.map((chunk) => {\n if (is(chunk, StringChunk)) {\n return { sql: chunk.value.join(\"\"), params: [] };\n }\n if (is(chunk, Name)) {\n return { sql: escapeName(chunk.value), params: [] };\n }\n if (chunk === void 0) {\n return { sql: \"\", params: [] };\n }\n if (Array.isArray(chunk)) {\n const result = [new StringChunk(\"(\")];\n for (const [i, p] of chunk.entries()) {\n result.push(p);\n if (i < chunk.length - 1) {\n result.push(new StringChunk(\", \"));\n }\n }\n result.push(new StringChunk(\")\"));\n return this.buildQueryFromSourceParams(result, config);\n }\n if (is(chunk, SQL)) {\n return this.buildQueryFromSourceParams(chunk.queryChunks, {\n ...config,\n inlineParams: inlineParams || chunk.shouldInlineParams\n });\n }\n if (is(chunk, Table)) {\n const schemaName = chunk[Table.Symbol.Schema];\n const tableName = chunk[Table.Symbol.Name];\n return {\n sql: schemaName === void 0 || chunk[IsAlias] ? escapeName(tableName) : escapeName(schemaName) + \".\" + escapeName(tableName),\n params: []\n };\n }\n if (is(chunk, Column)) {\n const columnName = casing.getColumnCasing(chunk);\n if (_config.invokeSource === \"indexes\") {\n return { sql: escapeName(columnName), params: [] };\n }\n const schemaName = chunk.table[Table.Symbol.Schema];\n return {\n sql: chunk.table[IsAlias] || schemaName === void 0 ? escapeName(chunk.table[Table.Symbol.Name]) + \".\" + escapeName(columnName) : escapeName(schemaName) + \".\" + escapeName(chunk.table[Table.Symbol.Name]) + \".\" + escapeName(columnName),\n params: []\n };\n }\n if (is(chunk, View)) {\n const schemaName = chunk[ViewBaseConfig].schema;\n const viewName = chunk[ViewBaseConfig].name;\n return {\n sql: schemaName === void 0 || chunk[ViewBaseConfig].isAlias ? escapeName(viewName) : escapeName(schemaName) + \".\" + escapeName(viewName),\n params: []\n };\n }\n if (is(chunk, Param)) {\n if (is(chunk.value, Placeholder)) {\n return { sql: escapeParam(paramStartIndex.value++, chunk), params: [chunk], typings: [\"none\"] };\n }\n const mappedValue = chunk.value === null ? null : chunk.encoder.mapToDriverValue(chunk.value);\n if (is(mappedValue, SQL)) {\n return this.buildQueryFromSourceParams([mappedValue], config);\n }\n if (inlineParams) {\n return { sql: this.mapInlineParam(mappedValue, config), params: [] };\n }\n let typings = [\"none\"];\n if (prepareTyping) {\n typings = [prepareTyping(chunk.encoder)];\n }\n return { sql: escapeParam(paramStartIndex.value++, mappedValue), params: [mappedValue], typings };\n }\n if (is(chunk, Placeholder)) {\n return { sql: escapeParam(paramStartIndex.value++, chunk), params: [chunk], typings: [\"none\"] };\n }\n if (is(chunk, SQL.Aliased) && chunk.fieldAlias !== void 0) {\n return { sql: escapeName(chunk.fieldAlias), params: [] };\n }\n if (is(chunk, Subquery)) {\n if (chunk._.isWith) {\n return { sql: escapeName(chunk._.alias), params: [] };\n }\n return this.buildQueryFromSourceParams([\n new StringChunk(\"(\"),\n chunk._.sql,\n new StringChunk(\") \"),\n new Name(chunk._.alias)\n ], config);\n }\n if (isPgEnum(chunk)) {\n if (chunk.schema) {\n return { sql: escapeName(chunk.schema) + \".\" + escapeName(chunk.enumName), params: [] };\n }\n return { sql: escapeName(chunk.enumName), params: [] };\n }\n if (isSQLWrapper(chunk)) {\n if (chunk.shouldOmitSQLParens?.()) {\n return this.buildQueryFromSourceParams([chunk.getSQL()], config);\n }\n return this.buildQueryFromSourceParams([\n new StringChunk(\"(\"),\n chunk.getSQL(),\n new StringChunk(\")\")\n ], config);\n }\n if (inlineParams) {\n return { sql: this.mapInlineParam(chunk, config), params: [] };\n }\n return { sql: escapeParam(paramStartIndex.value++, chunk), params: [chunk], typings: [\"none\"] };\n }));\n }\n mapInlineParam(chunk, { escapeString }) {\n if (chunk === null) {\n return \"null\";\n }\n if (typeof chunk === \"number\" || typeof chunk === \"boolean\") {\n return chunk.toString();\n }\n if (typeof chunk === \"string\") {\n return escapeString(chunk);\n }\n if (typeof chunk === \"object\") {\n const mappedValueAsString = chunk.toString();\n if (mappedValueAsString === \"[object Object]\") {\n return escapeString(JSON.stringify(chunk));\n }\n return escapeString(mappedValueAsString);\n }\n throw new Error(\"Unexpected param value: \" + chunk);\n }\n getSQL() {\n return this;\n }\n as(alias) {\n if (alias === void 0) {\n return this;\n }\n return new SQL.Aliased(this, alias);\n }\n mapWith(decoder) {\n this.decoder = typeof decoder === \"function\" ? { mapFromDriverValue: decoder } : decoder;\n return this;\n }\n inlineParams() {\n this.shouldInlineParams = true;\n return this;\n }\n /**\n * This method is used to conditionally include a part of the query.\n *\n * @param condition - Condition to check\n * @returns itself if the condition is `true`, otherwise `undefined`\n */\n if(condition) {\n return condition ? this : void 0;\n }\n}\nclass Name {\n constructor(value) {\n this.value = value;\n }\n static [entityKind] = \"Name\";\n brand;\n getSQL() {\n return new SQL([this]);\n }\n}\nfunction name(value) {\n return new Name(value);\n}\nfunction isDriverValueEncoder(value) {\n return typeof value === \"object\" && value !== null && \"mapToDriverValue\" in value && typeof value.mapToDriverValue === \"function\";\n}\nconst noopDecoder = {\n mapFromDriverValue: (value) => value\n};\nconst noopEncoder = {\n mapToDriverValue: (value) => value\n};\nconst noopMapper = {\n ...noopDecoder,\n ...noopEncoder\n};\nclass Param {\n /**\n * @param value - Parameter value\n * @param encoder - Encoder to convert the value to a driver parameter\n */\n constructor(value, encoder = noopEncoder) {\n this.value = value;\n this.encoder = encoder;\n }\n static [entityKind] = \"Param\";\n brand;\n getSQL() {\n return new SQL([this]);\n }\n}\nfunction param(value, encoder) {\n return new Param(value, encoder);\n}\nfunction sql(strings, ...params) {\n const queryChunks = [];\n if (params.length > 0 || strings.length > 0 && strings[0] !== \"\") {\n queryChunks.push(new StringChunk(strings[0]));\n }\n for (const [paramIndex, param2] of params.entries()) {\n queryChunks.push(param2, new StringChunk(strings[paramIndex + 1]));\n }\n return new SQL(queryChunks);\n}\n((sql2) => {\n function empty() {\n return new SQL([]);\n }\n sql2.empty = empty;\n function fromList(list) {\n return new SQL(list);\n }\n sql2.fromList = fromList;\n function raw(str) {\n return new SQL([new StringChunk(str)]);\n }\n sql2.raw = raw;\n function join(chunks, separator) {\n const result = [];\n for (const [i, chunk] of chunks.entries()) {\n if (i > 0 && separator !== void 0) {\n result.push(separator);\n }\n result.push(chunk);\n }\n return new SQL(result);\n }\n sql2.join = join;\n function identifier(value) {\n return new Name(value);\n }\n sql2.identifier = identifier;\n function placeholder2(name2) {\n return new Placeholder(name2);\n }\n sql2.placeholder = placeholder2;\n function param2(value, encoder) {\n return new Param(value, encoder);\n }\n sql2.param = param2;\n})(sql || (sql = {}));\n((SQL2) => {\n class Aliased {\n constructor(sql2, fieldAlias) {\n this.sql = sql2;\n this.fieldAlias = fieldAlias;\n }\n static [entityKind] = \"SQL.Aliased\";\n /** @internal */\n isSelectionField = false;\n getSQL() {\n return this.sql;\n }\n /** @internal */\n clone() {\n return new Aliased(this.sql, this.fieldAlias);\n }\n }\n SQL2.Aliased = Aliased;\n})(SQL || (SQL = {}));\nclass Placeholder {\n constructor(name2) {\n this.name = name2;\n }\n static [entityKind] = \"Placeholder\";\n getSQL() {\n return new SQL([this]);\n }\n}\nfunction placeholder(name2) {\n return new Placeholder(name2);\n}\nfunction fillPlaceholders(params, values) {\n return params.map((p) => {\n if (is(p, Placeholder)) {\n if (!(p.name in values)) {\n throw new Error(`No value for placeholder \"${p.name}\" was provided`);\n }\n return values[p.name];\n }\n if (is(p, Param) && is(p.value, Placeholder)) {\n if (!(p.value.name in values)) {\n throw new Error(`No value for placeholder \"${p.value.name}\" was provided`);\n }\n return p.encoder.mapToDriverValue(values[p.value.name]);\n }\n return p;\n });\n}\nconst IsDrizzleView = Symbol.for(\"drizzle:IsDrizzleView\");\nclass View {\n static [entityKind] = \"View\";\n /** @internal */\n [ViewBaseConfig];\n /** @internal */\n [IsDrizzleView] = true;\n constructor({ name: name2, schema, selectedFields, query }) {\n this[ViewBaseConfig] = {\n name: name2,\n originalName: name2,\n schema,\n selectedFields,\n query,\n isExisting: !query,\n isAlias: false\n };\n }\n getSQL() {\n return new SQL([this]);\n }\n}\nfunction isView(view) {\n return typeof view === \"object\" && view !== null && IsDrizzleView in view;\n}\nfunction getViewName(view) {\n return view[ViewBaseConfig].name;\n}\nColumn.prototype.getSQL = function() {\n return new SQL([this]);\n};\nTable.prototype.getSQL = function() {\n return new SQL([this]);\n};\nSubquery.prototype.getSQL = function() {\n return new SQL([this]);\n};\nexport {\n FakePrimitiveParam,\n Name,\n Param,\n Placeholder,\n SQL,\n StringChunk,\n View,\n fillPlaceholders,\n getViewName,\n isDriverValueEncoder,\n isSQLWrapper,\n isView,\n name,\n noopDecoder,\n noopEncoder,\n noopMapper,\n param,\n placeholder,\n sql\n};\n//# sourceMappingURL=sql.js.map",
21
- "import { Column } from \"./column.js\";\nimport { entityKind, is } from \"./entity.js\";\nimport { SQL, sql } from \"./sql/sql.js\";\nimport { Table } from \"./table.js\";\nimport { ViewBaseConfig } from \"./view-common.js\";\nclass ColumnAliasProxyHandler {\n constructor(table) {\n this.table = table;\n }\n static [entityKind] = \"ColumnAliasProxyHandler\";\n get(columnObj, prop) {\n if (prop === \"table\") {\n return this.table;\n }\n return columnObj[prop];\n }\n}\nclass TableAliasProxyHandler {\n constructor(alias, replaceOriginalName) {\n this.alias = alias;\n this.replaceOriginalName = replaceOriginalName;\n }\n static [entityKind] = \"TableAliasProxyHandler\";\n get(target, prop) {\n if (prop === Table.Symbol.IsAlias) {\n return true;\n }\n if (prop === Table.Symbol.Name) {\n return this.alias;\n }\n if (this.replaceOriginalName && prop === Table.Symbol.OriginalName) {\n return this.alias;\n }\n if (prop === ViewBaseConfig) {\n return {\n ...target[ViewBaseConfig],\n name: this.alias,\n isAlias: true\n };\n }\n if (prop === Table.Symbol.Columns) {\n const columns = target[Table.Symbol.Columns];\n if (!columns) {\n return columns;\n }\n const proxiedColumns = {};\n Object.keys(columns).map((key) => {\n proxiedColumns[key] = new Proxy(\n columns[key],\n new ColumnAliasProxyHandler(new Proxy(target, this))\n );\n });\n return proxiedColumns;\n }\n const value = target[prop];\n if (is(value, Column)) {\n return new Proxy(value, new ColumnAliasProxyHandler(new Proxy(target, this)));\n }\n return value;\n }\n}\nclass RelationTableAliasProxyHandler {\n constructor(alias) {\n this.alias = alias;\n }\n static [entityKind] = \"RelationTableAliasProxyHandler\";\n get(target, prop) {\n if (prop === \"sourceTable\") {\n return aliasedTable(target.sourceTable, this.alias);\n }\n return target[prop];\n }\n}\nfunction aliasedTable(table, tableAlias) {\n return new Proxy(table, new TableAliasProxyHandler(tableAlias, false));\n}\nfunction aliasedRelation(relation, tableAlias) {\n return new Proxy(relation, new RelationTableAliasProxyHandler(tableAlias));\n}\nfunction aliasedTableColumn(column, tableAlias) {\n return new Proxy(\n column,\n new ColumnAliasProxyHandler(new Proxy(column.table, new TableAliasProxyHandler(tableAlias, false)))\n );\n}\nfunction mapColumnsInAliasedSQLToAlias(query, alias) {\n return new SQL.Aliased(mapColumnsInSQLToAlias(query.sql, alias), query.fieldAlias);\n}\nfunction mapColumnsInSQLToAlias(query, alias) {\n return sql.join(query.queryChunks.map((c) => {\n if (is(c, Column)) {\n return aliasedTableColumn(c, alias);\n }\n if (is(c, SQL)) {\n return mapColumnsInSQLToAlias(c, alias);\n }\n if (is(c, SQL.Aliased)) {\n return mapColumnsInAliasedSQLToAlias(c, alias);\n }\n return c;\n }));\n}\nexport {\n ColumnAliasProxyHandler,\n RelationTableAliasProxyHandler,\n TableAliasProxyHandler,\n aliasedRelation,\n aliasedTable,\n aliasedTableColumn,\n mapColumnsInAliasedSQLToAlias,\n mapColumnsInSQLToAlias\n};\n//# sourceMappingURL=alias.js.map",
22
- "import { entityKind } from \"./entity.js\";\nclass QueryPromise {\n static [entityKind] = \"QueryPromise\";\n [Symbol.toStringTag] = \"QueryPromise\";\n catch(onRejected) {\n return this.then(void 0, onRejected);\n }\n finally(onFinally) {\n return this.then(\n (value) => {\n onFinally?.();\n return value;\n },\n (reason) => {\n onFinally?.();\n throw reason;\n }\n );\n }\n then(onFulfilled, onRejected) {\n return this.execute().then(onFulfilled, onRejected);\n }\n}\nexport {\n QueryPromise\n};\n//# sourceMappingURL=query-promise.js.map",
23
- "import { Column } from \"./column.js\";\nimport { is } from \"./entity.js\";\nimport { Param, SQL, View } from \"./sql/sql.js\";\nimport { Subquery } from \"./subquery.js\";\nimport { getTableName, Table } from \"./table.js\";\nimport { ViewBaseConfig } from \"./view-common.js\";\nfunction mapResultRow(columns, row, joinsNotNullableMap) {\n const nullifyMap = {};\n const result = columns.reduce(\n (result2, { path, field }, columnIndex) => {\n let decoder;\n if (is(field, Column)) {\n decoder = field;\n } else if (is(field, SQL)) {\n decoder = field.decoder;\n } else if (is(field, Subquery)) {\n decoder = field._.sql.decoder;\n } else {\n decoder = field.sql.decoder;\n }\n let node = result2;\n for (const [pathChunkIndex, pathChunk] of path.entries()) {\n if (pathChunkIndex < path.length - 1) {\n if (!(pathChunk in node)) {\n node[pathChunk] = {};\n }\n node = node[pathChunk];\n } else {\n const rawValue = row[columnIndex];\n const value = node[pathChunk] = rawValue === null ? null : decoder.mapFromDriverValue(rawValue);\n if (joinsNotNullableMap && is(field, Column) && path.length === 2) {\n const objectName = path[0];\n if (!(objectName in nullifyMap)) {\n nullifyMap[objectName] = value === null ? getTableName(field.table) : false;\n } else if (typeof nullifyMap[objectName] === \"string\" && nullifyMap[objectName] !== getTableName(field.table)) {\n nullifyMap[objectName] = false;\n }\n }\n }\n }\n return result2;\n },\n {}\n );\n if (joinsNotNullableMap && Object.keys(nullifyMap).length > 0) {\n for (const [objectName, tableName] of Object.entries(nullifyMap)) {\n if (typeof tableName === \"string\" && !joinsNotNullableMap[tableName]) {\n result[objectName] = null;\n }\n }\n }\n return result;\n}\nfunction orderSelectedFields(fields, pathPrefix) {\n return Object.entries(fields).reduce((result, [name, field]) => {\n if (typeof name !== \"string\") {\n return result;\n }\n const newPath = pathPrefix ? [...pathPrefix, name] : [name];\n if (is(field, Column) || is(field, SQL) || is(field, SQL.Aliased) || is(field, Subquery)) {\n result.push({ path: newPath, field });\n } else if (is(field, Table)) {\n result.push(...orderSelectedFields(field[Table.Symbol.Columns], newPath));\n } else {\n result.push(...orderSelectedFields(field, newPath));\n }\n return result;\n }, []);\n}\nfunction haveSameKeys(left, right) {\n const leftKeys = Object.keys(left);\n const rightKeys = Object.keys(right);\n if (leftKeys.length !== rightKeys.length) {\n return false;\n }\n for (const [index, key] of leftKeys.entries()) {\n if (key !== rightKeys[index]) {\n return false;\n }\n }\n return true;\n}\nfunction mapUpdateSet(table, values) {\n const entries = Object.entries(values).filter(([, value]) => value !== void 0).map(([key, value]) => {\n if (is(value, SQL) || is(value, Column)) {\n return [key, value];\n } else {\n return [key, new Param(value, table[Table.Symbol.Columns][key])];\n }\n });\n if (entries.length === 0) {\n throw new Error(\"No values to set\");\n }\n return Object.fromEntries(entries);\n}\nfunction applyMixins(baseClass, extendedClasses) {\n for (const extendedClass of extendedClasses) {\n for (const name of Object.getOwnPropertyNames(extendedClass.prototype)) {\n if (name === \"constructor\") continue;\n Object.defineProperty(\n baseClass.prototype,\n name,\n Object.getOwnPropertyDescriptor(extendedClass.prototype, name) || /* @__PURE__ */ Object.create(null)\n );\n }\n }\n}\nfunction getTableColumns(table) {\n return table[Table.Symbol.Columns];\n}\nfunction getViewSelectedFields(view) {\n return view[ViewBaseConfig].selectedFields;\n}\nfunction getTableLikeName(table) {\n return is(table, Subquery) ? table._.alias : is(table, View) ? table[ViewBaseConfig].name : is(table, SQL) ? void 0 : table[Table.Symbol.IsAlias] ? table[Table.Symbol.Name] : table[Table.Symbol.BaseName];\n}\nfunction getColumnNameAndConfig(a, b) {\n return {\n name: typeof a === \"string\" && a.length > 0 ? a : \"\",\n config: typeof a === \"object\" ? a : b\n };\n}\nconst _ = {};\nconst __ = {};\nfunction isConfig(data) {\n if (typeof data !== \"object\" || data === null) return false;\n if (data.constructor.name !== \"Object\") return false;\n if (\"logger\" in data) {\n const type = typeof data[\"logger\"];\n if (type !== \"boolean\" && (type !== \"object\" || typeof data[\"logger\"][\"logQuery\"] !== \"function\") && type !== \"undefined\") return false;\n return true;\n }\n if (\"schema\" in data) {\n const type = typeof data[\"schema\"];\n if (type !== \"object\" && type !== \"undefined\") return false;\n return true;\n }\n if (\"casing\" in data) {\n const type = typeof data[\"casing\"];\n if (type !== \"string\" && type !== \"undefined\") return false;\n return true;\n }\n if (\"mode\" in data) {\n if (data[\"mode\"] !== \"default\" || data[\"mode\"] !== \"planetscale\" || data[\"mode\"] !== void 0) return false;\n return true;\n }\n if (\"connection\" in data) {\n const type = typeof data[\"connection\"];\n if (type !== \"string\" && type !== \"object\" && type !== \"undefined\") return false;\n return true;\n }\n if (\"client\" in data) {\n const type = typeof data[\"client\"];\n if (type !== \"object\" && type !== \"function\" && type !== \"undefined\") return false;\n return true;\n }\n if (Object.keys(data).length === 0) return true;\n return false;\n}\nconst textDecoder = typeof TextDecoder === \"undefined\" ? null : new TextDecoder();\nexport {\n applyMixins,\n getColumnNameAndConfig,\n getTableColumns,\n getTableLikeName,\n getViewSelectedFields,\n haveSameKeys,\n isConfig,\n mapResultRow,\n mapUpdateSet,\n orderSelectedFields,\n textDecoder\n};\n//# sourceMappingURL=utils.js.map",
24
- "import { entityKind } from \"../../entity.js\";\nimport { PgColumnBuilder } from \"./common.js\";\nclass PgIntColumnBaseBuilder extends PgColumnBuilder {\n static [entityKind] = \"PgIntColumnBaseBuilder\";\n generatedAlwaysAsIdentity(sequence) {\n if (sequence) {\n const { name, ...options } = sequence;\n this.config.generatedIdentity = {\n type: \"always\",\n sequenceName: name,\n sequenceOptions: options\n };\n } else {\n this.config.generatedIdentity = {\n type: \"always\"\n };\n }\n this.config.hasDefault = true;\n this.config.notNull = true;\n return this;\n }\n generatedByDefaultAsIdentity(sequence) {\n if (sequence) {\n const { name, ...options } = sequence;\n this.config.generatedIdentity = {\n type: \"byDefault\",\n sequenceName: name,\n sequenceOptions: options\n };\n } else {\n this.config.generatedIdentity = {\n type: \"byDefault\"\n };\n }\n this.config.hasDefault = true;\n this.config.notNull = true;\n return this;\n }\n}\nexport {\n PgIntColumnBaseBuilder\n};\n//# sourceMappingURL=int.common.js.map",
25
- "import { entityKind } from \"../../entity.js\";\nimport { getColumnNameAndConfig } from \"../../utils.js\";\nimport { PgColumn } from \"./common.js\";\nimport { PgIntColumnBaseBuilder } from \"./int.common.js\";\nclass PgBigInt53Builder extends PgIntColumnBaseBuilder {\n static [entityKind] = \"PgBigInt53Builder\";\n constructor(name) {\n super(name, \"number\", \"PgBigInt53\");\n }\n /** @internal */\n build(table) {\n return new PgBigInt53(table, this.config);\n }\n}\nclass PgBigInt53 extends PgColumn {\n static [entityKind] = \"PgBigInt53\";\n getSQLType() {\n return \"bigint\";\n }\n mapFromDriverValue(value) {\n if (typeof value === \"number\") {\n return value;\n }\n return Number(value);\n }\n}\nclass PgBigInt64Builder extends PgIntColumnBaseBuilder {\n static [entityKind] = \"PgBigInt64Builder\";\n constructor(name) {\n super(name, \"bigint\", \"PgBigInt64\");\n }\n /** @internal */\n build(table) {\n return new PgBigInt64(\n table,\n this.config\n );\n }\n}\nclass PgBigInt64 extends PgColumn {\n static [entityKind] = \"PgBigInt64\";\n getSQLType() {\n return \"bigint\";\n }\n // eslint-disable-next-line unicorn/prefer-native-coercion-functions\n mapFromDriverValue(value) {\n return BigInt(value);\n }\n}\nfunction bigint(a, b) {\n const { name, config } = getColumnNameAndConfig(a, b);\n if (config.mode === \"number\") {\n return new PgBigInt53Builder(name);\n }\n return new PgBigInt64Builder(name);\n}\nexport {\n PgBigInt53,\n PgBigInt53Builder,\n PgBigInt64,\n PgBigInt64Builder,\n bigint\n};\n//# sourceMappingURL=bigint.js.map",
26
- "import { entityKind } from \"../../entity.js\";\nimport { getColumnNameAndConfig } from \"../../utils.js\";\nimport { PgColumn, PgColumnBuilder } from \"./common.js\";\nclass PgBigSerial53Builder extends PgColumnBuilder {\n static [entityKind] = \"PgBigSerial53Builder\";\n constructor(name) {\n super(name, \"number\", \"PgBigSerial53\");\n this.config.hasDefault = true;\n this.config.notNull = true;\n }\n /** @internal */\n build(table) {\n return new PgBigSerial53(\n table,\n this.config\n );\n }\n}\nclass PgBigSerial53 extends PgColumn {\n static [entityKind] = \"PgBigSerial53\";\n getSQLType() {\n return \"bigserial\";\n }\n mapFromDriverValue(value) {\n if (typeof value === \"number\") {\n return value;\n }\n return Number(value);\n }\n}\nclass PgBigSerial64Builder extends PgColumnBuilder {\n static [entityKind] = \"PgBigSerial64Builder\";\n constructor(name) {\n super(name, \"bigint\", \"PgBigSerial64\");\n this.config.hasDefault = true;\n }\n /** @internal */\n build(table) {\n return new PgBigSerial64(\n table,\n this.config\n );\n }\n}\nclass PgBigSerial64 extends PgColumn {\n static [entityKind] = \"PgBigSerial64\";\n getSQLType() {\n return \"bigserial\";\n }\n // eslint-disable-next-line unicorn/prefer-native-coercion-functions\n mapFromDriverValue(value) {\n return BigInt(value);\n }\n}\nfunction bigserial(a, b) {\n const { name, config } = getColumnNameAndConfig(a, b);\n if (config.mode === \"number\") {\n return new PgBigSerial53Builder(name);\n }\n return new PgBigSerial64Builder(name);\n}\nexport {\n PgBigSerial53,\n PgBigSerial53Builder,\n PgBigSerial64,\n PgBigSerial64Builder,\n bigserial\n};\n//# sourceMappingURL=bigserial.js.map",
27
- "import { entityKind } from \"../../entity.js\";\nimport { PgColumn, PgColumnBuilder } from \"./common.js\";\nclass PgBooleanBuilder extends PgColumnBuilder {\n static [entityKind] = \"PgBooleanBuilder\";\n constructor(name) {\n super(name, \"boolean\", \"PgBoolean\");\n }\n /** @internal */\n build(table) {\n return new PgBoolean(table, this.config);\n }\n}\nclass PgBoolean extends PgColumn {\n static [entityKind] = \"PgBoolean\";\n getSQLType() {\n return \"boolean\";\n }\n}\nfunction boolean(name) {\n return new PgBooleanBuilder(name ?? \"\");\n}\nexport {\n PgBoolean,\n PgBooleanBuilder,\n boolean\n};\n//# sourceMappingURL=boolean.js.map",
28
- "import { entityKind } from \"../../entity.js\";\nimport { getColumnNameAndConfig } from \"../../utils.js\";\nimport { PgColumn, PgColumnBuilder } from \"./common.js\";\nclass PgCharBuilder extends PgColumnBuilder {\n static [entityKind] = \"PgCharBuilder\";\n constructor(name, config) {\n super(name, \"string\", \"PgChar\");\n this.config.length = config.length;\n this.config.enumValues = config.enum;\n }\n /** @internal */\n build(table) {\n return new PgChar(\n table,\n this.config\n );\n }\n}\nclass PgChar extends PgColumn {\n static [entityKind] = \"PgChar\";\n length = this.config.length;\n enumValues = this.config.enumValues;\n getSQLType() {\n return this.length === void 0 ? `char` : `char(${this.length})`;\n }\n}\nfunction char(a, b = {}) {\n const { name, config } = getColumnNameAndConfig(a, b);\n return new PgCharBuilder(name, config);\n}\nexport {\n PgChar,\n PgCharBuilder,\n char\n};\n//# sourceMappingURL=char.js.map",
29
- "import { entityKind } from \"../../entity.js\";\nimport { PgColumn, PgColumnBuilder } from \"./common.js\";\nclass PgCidrBuilder extends PgColumnBuilder {\n static [entityKind] = \"PgCidrBuilder\";\n constructor(name) {\n super(name, \"string\", \"PgCidr\");\n }\n /** @internal */\n build(table) {\n return new PgCidr(table, this.config);\n }\n}\nclass PgCidr extends PgColumn {\n static [entityKind] = \"PgCidr\";\n getSQLType() {\n return \"cidr\";\n }\n}\nfunction cidr(name) {\n return new PgCidrBuilder(name ?? \"\");\n}\nexport {\n PgCidr,\n PgCidrBuilder,\n cidr\n};\n//# sourceMappingURL=cidr.js.map",
30
- "import { entityKind } from \"../../entity.js\";\nimport { getColumnNameAndConfig } from \"../../utils.js\";\nimport { PgColumn, PgColumnBuilder } from \"./common.js\";\nclass PgCustomColumnBuilder extends PgColumnBuilder {\n static [entityKind] = \"PgCustomColumnBuilder\";\n constructor(name, fieldConfig, customTypeParams) {\n super(name, \"custom\", \"PgCustomColumn\");\n this.config.fieldConfig = fieldConfig;\n this.config.customTypeParams = customTypeParams;\n }\n /** @internal */\n build(table) {\n return new PgCustomColumn(\n table,\n this.config\n );\n }\n}\nclass PgCustomColumn extends PgColumn {\n static [entityKind] = \"PgCustomColumn\";\n sqlName;\n mapTo;\n mapFrom;\n constructor(table, config) {\n super(table, config);\n this.sqlName = config.customTypeParams.dataType(config.fieldConfig);\n this.mapTo = config.customTypeParams.toDriver;\n this.mapFrom = config.customTypeParams.fromDriver;\n }\n getSQLType() {\n return this.sqlName;\n }\n mapFromDriverValue(value) {\n return typeof this.mapFrom === \"function\" ? this.mapFrom(value) : value;\n }\n mapToDriverValue(value) {\n return typeof this.mapTo === \"function\" ? this.mapTo(value) : value;\n }\n}\nfunction customType(customTypeParams) {\n return (a, b) => {\n const { name, config } = getColumnNameAndConfig(a, b);\n return new PgCustomColumnBuilder(name, config, customTypeParams);\n };\n}\nexport {\n PgCustomColumn,\n PgCustomColumnBuilder,\n customType\n};\n//# sourceMappingURL=custom.js.map",
31
- "import { entityKind } from \"../../entity.js\";\nimport { sql } from \"../../sql/sql.js\";\nimport { PgColumnBuilder } from \"./common.js\";\nclass PgDateColumnBaseBuilder extends PgColumnBuilder {\n static [entityKind] = \"PgDateColumnBaseBuilder\";\n defaultNow() {\n return this.default(sql`now()`);\n }\n}\nexport {\n PgDateColumnBaseBuilder\n};\n//# sourceMappingURL=date.common.js.map",
32
- "import { entityKind } from \"../../entity.js\";\nimport { getColumnNameAndConfig } from \"../../utils.js\";\nimport { PgColumn } from \"./common.js\";\nimport { PgDateColumnBaseBuilder } from \"./date.common.js\";\nclass PgDateBuilder extends PgDateColumnBaseBuilder {\n static [entityKind] = \"PgDateBuilder\";\n constructor(name) {\n super(name, \"date\", \"PgDate\");\n }\n /** @internal */\n build(table) {\n return new PgDate(table, this.config);\n }\n}\nclass PgDate extends PgColumn {\n static [entityKind] = \"PgDate\";\n getSQLType() {\n return \"date\";\n }\n mapFromDriverValue(value) {\n if (typeof value === \"string\") return new Date(value);\n return value;\n }\n mapToDriverValue(value) {\n return value.toISOString();\n }\n}\nclass PgDateStringBuilder extends PgDateColumnBaseBuilder {\n static [entityKind] = \"PgDateStringBuilder\";\n constructor(name) {\n super(name, \"string\", \"PgDateString\");\n }\n /** @internal */\n build(table) {\n return new PgDateString(\n table,\n this.config\n );\n }\n}\nclass PgDateString extends PgColumn {\n static [entityKind] = \"PgDateString\";\n getSQLType() {\n return \"date\";\n }\n mapFromDriverValue(value) {\n if (typeof value === \"string\") return value;\n return value.toISOString().slice(0, -14);\n }\n}\nfunction date(a, b) {\n const { name, config } = getColumnNameAndConfig(a, b);\n if (config?.mode === \"date\") {\n return new PgDateBuilder(name);\n }\n return new PgDateStringBuilder(name);\n}\nexport {\n PgDate,\n PgDateBuilder,\n PgDateString,\n PgDateStringBuilder,\n date\n};\n//# sourceMappingURL=date.js.map",
33
- "import { entityKind } from \"../../entity.js\";\nimport { PgColumn, PgColumnBuilder } from \"./common.js\";\nclass PgDoublePrecisionBuilder extends PgColumnBuilder {\n static [entityKind] = \"PgDoublePrecisionBuilder\";\n constructor(name) {\n super(name, \"number\", \"PgDoublePrecision\");\n }\n /** @internal */\n build(table) {\n return new PgDoublePrecision(\n table,\n this.config\n );\n }\n}\nclass PgDoublePrecision extends PgColumn {\n static [entityKind] = \"PgDoublePrecision\";\n getSQLType() {\n return \"double precision\";\n }\n mapFromDriverValue(value) {\n if (typeof value === \"string\") {\n return Number.parseFloat(value);\n }\n return value;\n }\n}\nfunction doublePrecision(name) {\n return new PgDoublePrecisionBuilder(name ?? \"\");\n}\nexport {\n PgDoublePrecision,\n PgDoublePrecisionBuilder,\n doublePrecision\n};\n//# sourceMappingURL=double-precision.js.map",
34
- "import { entityKind } from \"../../entity.js\";\nimport { PgColumn, PgColumnBuilder } from \"./common.js\";\nclass PgInetBuilder extends PgColumnBuilder {\n static [entityKind] = \"PgInetBuilder\";\n constructor(name) {\n super(name, \"string\", \"PgInet\");\n }\n /** @internal */\n build(table) {\n return new PgInet(table, this.config);\n }\n}\nclass PgInet extends PgColumn {\n static [entityKind] = \"PgInet\";\n getSQLType() {\n return \"inet\";\n }\n}\nfunction inet(name) {\n return new PgInetBuilder(name ?? \"\");\n}\nexport {\n PgInet,\n PgInetBuilder,\n inet\n};\n//# sourceMappingURL=inet.js.map",
35
- "import { entityKind } from \"../../entity.js\";\nimport { PgColumn } from \"./common.js\";\nimport { PgIntColumnBaseBuilder } from \"./int.common.js\";\nclass PgIntegerBuilder extends PgIntColumnBaseBuilder {\n static [entityKind] = \"PgIntegerBuilder\";\n constructor(name) {\n super(name, \"number\", \"PgInteger\");\n }\n /** @internal */\n build(table) {\n return new PgInteger(table, this.config);\n }\n}\nclass PgInteger extends PgColumn {\n static [entityKind] = \"PgInteger\";\n getSQLType() {\n return \"integer\";\n }\n mapFromDriverValue(value) {\n if (typeof value === \"string\") {\n return Number.parseInt(value);\n }\n return value;\n }\n}\nfunction integer(name) {\n return new PgIntegerBuilder(name ?? \"\");\n}\nexport {\n PgInteger,\n PgIntegerBuilder,\n integer\n};\n//# sourceMappingURL=integer.js.map",
36
- "import { entityKind } from \"../../entity.js\";\nimport { getColumnNameAndConfig } from \"../../utils.js\";\nimport { PgColumn, PgColumnBuilder } from \"./common.js\";\nclass PgIntervalBuilder extends PgColumnBuilder {\n static [entityKind] = \"PgIntervalBuilder\";\n constructor(name, intervalConfig) {\n super(name, \"string\", \"PgInterval\");\n this.config.intervalConfig = intervalConfig;\n }\n /** @internal */\n build(table) {\n return new PgInterval(table, this.config);\n }\n}\nclass PgInterval extends PgColumn {\n static [entityKind] = \"PgInterval\";\n fields = this.config.intervalConfig.fields;\n precision = this.config.intervalConfig.precision;\n getSQLType() {\n const fields = this.fields ? ` ${this.fields}` : \"\";\n const precision = this.precision ? `(${this.precision})` : \"\";\n return `interval${fields}${precision}`;\n }\n}\nfunction interval(a, b = {}) {\n const { name, config } = getColumnNameAndConfig(a, b);\n return new PgIntervalBuilder(name, config);\n}\nexport {\n PgInterval,\n PgIntervalBuilder,\n interval\n};\n//# sourceMappingURL=interval.js.map",
37
- "import { entityKind } from \"../../entity.js\";\nimport { PgColumn, PgColumnBuilder } from \"./common.js\";\nclass PgJsonBuilder extends PgColumnBuilder {\n static [entityKind] = \"PgJsonBuilder\";\n constructor(name) {\n super(name, \"json\", \"PgJson\");\n }\n /** @internal */\n build(table) {\n return new PgJson(table, this.config);\n }\n}\nclass PgJson extends PgColumn {\n static [entityKind] = \"PgJson\";\n constructor(table, config) {\n super(table, config);\n }\n getSQLType() {\n return \"json\";\n }\n mapToDriverValue(value) {\n return JSON.stringify(value);\n }\n mapFromDriverValue(value) {\n if (typeof value === \"string\") {\n try {\n return JSON.parse(value);\n } catch {\n return value;\n }\n }\n return value;\n }\n}\nfunction json(name) {\n return new PgJsonBuilder(name ?? \"\");\n}\nexport {\n PgJson,\n PgJsonBuilder,\n json\n};\n//# sourceMappingURL=json.js.map",
38
- "import { entityKind } from \"../../entity.js\";\nimport { PgColumn, PgColumnBuilder } from \"./common.js\";\nclass PgJsonbBuilder extends PgColumnBuilder {\n static [entityKind] = \"PgJsonbBuilder\";\n constructor(name) {\n super(name, \"json\", \"PgJsonb\");\n }\n /** @internal */\n build(table) {\n return new PgJsonb(table, this.config);\n }\n}\nclass PgJsonb extends PgColumn {\n static [entityKind] = \"PgJsonb\";\n constructor(table, config) {\n super(table, config);\n }\n getSQLType() {\n return \"jsonb\";\n }\n mapToDriverValue(value) {\n return JSON.stringify(value);\n }\n mapFromDriverValue(value) {\n if (typeof value === \"string\") {\n try {\n return JSON.parse(value);\n } catch {\n return value;\n }\n }\n return value;\n }\n}\nfunction jsonb(name) {\n return new PgJsonbBuilder(name ?? \"\");\n}\nexport {\n PgJsonb,\n PgJsonbBuilder,\n jsonb\n};\n//# sourceMappingURL=jsonb.js.map",
39
- "import { entityKind } from \"../../entity.js\";\nimport { getColumnNameAndConfig } from \"../../utils.js\";\nimport { PgColumn, PgColumnBuilder } from \"./common.js\";\nclass PgLineBuilder extends PgColumnBuilder {\n static [entityKind] = \"PgLineBuilder\";\n constructor(name) {\n super(name, \"array\", \"PgLine\");\n }\n /** @internal */\n build(table) {\n return new PgLineTuple(\n table,\n this.config\n );\n }\n}\nclass PgLineTuple extends PgColumn {\n static [entityKind] = \"PgLine\";\n getSQLType() {\n return \"line\";\n }\n mapFromDriverValue(value) {\n const [a, b, c] = value.slice(1, -1).split(\",\");\n return [Number.parseFloat(a), Number.parseFloat(b), Number.parseFloat(c)];\n }\n mapToDriverValue(value) {\n return `{${value[0]},${value[1]},${value[2]}}`;\n }\n}\nclass PgLineABCBuilder extends PgColumnBuilder {\n static [entityKind] = \"PgLineABCBuilder\";\n constructor(name) {\n super(name, \"json\", \"PgLineABC\");\n }\n /** @internal */\n build(table) {\n return new PgLineABC(\n table,\n this.config\n );\n }\n}\nclass PgLineABC extends PgColumn {\n static [entityKind] = \"PgLineABC\";\n getSQLType() {\n return \"line\";\n }\n mapFromDriverValue(value) {\n const [a, b, c] = value.slice(1, -1).split(\",\");\n return { a: Number.parseFloat(a), b: Number.parseFloat(b), c: Number.parseFloat(c) };\n }\n mapToDriverValue(value) {\n return `{${value.a},${value.b},${value.c}}`;\n }\n}\nfunction line(a, b) {\n const { name, config } = getColumnNameAndConfig(a, b);\n if (!config?.mode || config.mode === \"tuple\") {\n return new PgLineBuilder(name);\n }\n return new PgLineABCBuilder(name);\n}\nexport {\n PgLineABC,\n PgLineABCBuilder,\n PgLineBuilder,\n PgLineTuple,\n line\n};\n//# sourceMappingURL=line.js.map",
40
- "import { entityKind } from \"../../entity.js\";\nimport { PgColumn, PgColumnBuilder } from \"./common.js\";\nclass PgMacaddrBuilder extends PgColumnBuilder {\n static [entityKind] = \"PgMacaddrBuilder\";\n constructor(name) {\n super(name, \"string\", \"PgMacaddr\");\n }\n /** @internal */\n build(table) {\n return new PgMacaddr(table, this.config);\n }\n}\nclass PgMacaddr extends PgColumn {\n static [entityKind] = \"PgMacaddr\";\n getSQLType() {\n return \"macaddr\";\n }\n}\nfunction macaddr(name) {\n return new PgMacaddrBuilder(name ?? \"\");\n}\nexport {\n PgMacaddr,\n PgMacaddrBuilder,\n macaddr\n};\n//# sourceMappingURL=macaddr.js.map",
41
- "import { entityKind } from \"../../entity.js\";\nimport { PgColumn, PgColumnBuilder } from \"./common.js\";\nclass PgMacaddr8Builder extends PgColumnBuilder {\n static [entityKind] = \"PgMacaddr8Builder\";\n constructor(name) {\n super(name, \"string\", \"PgMacaddr8\");\n }\n /** @internal */\n build(table) {\n return new PgMacaddr8(table, this.config);\n }\n}\nclass PgMacaddr8 extends PgColumn {\n static [entityKind] = \"PgMacaddr8\";\n getSQLType() {\n return \"macaddr8\";\n }\n}\nfunction macaddr8(name) {\n return new PgMacaddr8Builder(name ?? \"\");\n}\nexport {\n PgMacaddr8,\n PgMacaddr8Builder,\n macaddr8\n};\n//# sourceMappingURL=macaddr8.js.map",
42
- "import { entityKind } from \"../../entity.js\";\nimport { getColumnNameAndConfig } from \"../../utils.js\";\nimport { PgColumn, PgColumnBuilder } from \"./common.js\";\nclass PgNumericBuilder extends PgColumnBuilder {\n static [entityKind] = \"PgNumericBuilder\";\n constructor(name, precision, scale) {\n super(name, \"string\", \"PgNumeric\");\n this.config.precision = precision;\n this.config.scale = scale;\n }\n /** @internal */\n build(table) {\n return new PgNumeric(table, this.config);\n }\n}\nclass PgNumeric extends PgColumn {\n static [entityKind] = \"PgNumeric\";\n precision;\n scale;\n constructor(table, config) {\n super(table, config);\n this.precision = config.precision;\n this.scale = config.scale;\n }\n mapFromDriverValue(value) {\n if (typeof value === \"string\") return value;\n return String(value);\n }\n getSQLType() {\n if (this.precision !== void 0 && this.scale !== void 0) {\n return `numeric(${this.precision}, ${this.scale})`;\n } else if (this.precision === void 0) {\n return \"numeric\";\n } else {\n return `numeric(${this.precision})`;\n }\n }\n}\nclass PgNumericNumberBuilder extends PgColumnBuilder {\n static [entityKind] = \"PgNumericNumberBuilder\";\n constructor(name, precision, scale) {\n super(name, \"number\", \"PgNumericNumber\");\n this.config.precision = precision;\n this.config.scale = scale;\n }\n /** @internal */\n build(table) {\n return new PgNumericNumber(\n table,\n this.config\n );\n }\n}\nclass PgNumericNumber extends PgColumn {\n static [entityKind] = \"PgNumericNumber\";\n precision;\n scale;\n constructor(table, config) {\n super(table, config);\n this.precision = config.precision;\n this.scale = config.scale;\n }\n mapFromDriverValue(value) {\n if (typeof value === \"number\") return value;\n return Number(value);\n }\n mapToDriverValue = String;\n getSQLType() {\n if (this.precision !== void 0 && this.scale !== void 0) {\n return `numeric(${this.precision}, ${this.scale})`;\n } else if (this.precision === void 0) {\n return \"numeric\";\n } else {\n return `numeric(${this.precision})`;\n }\n }\n}\nclass PgNumericBigIntBuilder extends PgColumnBuilder {\n static [entityKind] = \"PgNumericBigIntBuilder\";\n constructor(name, precision, scale) {\n super(name, \"bigint\", \"PgNumericBigInt\");\n this.config.precision = precision;\n this.config.scale = scale;\n }\n /** @internal */\n build(table) {\n return new PgNumericBigInt(\n table,\n this.config\n );\n }\n}\nclass PgNumericBigInt extends PgColumn {\n static [entityKind] = \"PgNumericBigInt\";\n precision;\n scale;\n constructor(table, config) {\n super(table, config);\n this.precision = config.precision;\n this.scale = config.scale;\n }\n mapFromDriverValue = BigInt;\n mapToDriverValue = String;\n getSQLType() {\n if (this.precision !== void 0 && this.scale !== void 0) {\n return `numeric(${this.precision}, ${this.scale})`;\n } else if (this.precision === void 0) {\n return \"numeric\";\n } else {\n return `numeric(${this.precision})`;\n }\n }\n}\nfunction numeric(a, b) {\n const { name, config } = getColumnNameAndConfig(a, b);\n const mode = config?.mode;\n return mode === \"number\" ? new PgNumericNumberBuilder(name, config?.precision, config?.scale) : mode === \"bigint\" ? new PgNumericBigIntBuilder(name, config?.precision, config?.scale) : new PgNumericBuilder(name, config?.precision, config?.scale);\n}\nconst decimal = numeric;\nexport {\n PgNumeric,\n PgNumericBigInt,\n PgNumericBigIntBuilder,\n PgNumericBuilder,\n PgNumericNumber,\n PgNumericNumberBuilder,\n decimal,\n numeric\n};\n//# sourceMappingURL=numeric.js.map",
43
- "import { entityKind } from \"../../entity.js\";\nimport { getColumnNameAndConfig } from \"../../utils.js\";\nimport { PgColumn, PgColumnBuilder } from \"./common.js\";\nclass PgPointTupleBuilder extends PgColumnBuilder {\n static [entityKind] = \"PgPointTupleBuilder\";\n constructor(name) {\n super(name, \"array\", \"PgPointTuple\");\n }\n /** @internal */\n build(table) {\n return new PgPointTuple(\n table,\n this.config\n );\n }\n}\nclass PgPointTuple extends PgColumn {\n static [entityKind] = \"PgPointTuple\";\n getSQLType() {\n return \"point\";\n }\n mapFromDriverValue(value) {\n if (typeof value === \"string\") {\n const [x, y] = value.slice(1, -1).split(\",\");\n return [Number.parseFloat(x), Number.parseFloat(y)];\n }\n return [value.x, value.y];\n }\n mapToDriverValue(value) {\n return `(${value[0]},${value[1]})`;\n }\n}\nclass PgPointObjectBuilder extends PgColumnBuilder {\n static [entityKind] = \"PgPointObjectBuilder\";\n constructor(name) {\n super(name, \"json\", \"PgPointObject\");\n }\n /** @internal */\n build(table) {\n return new PgPointObject(\n table,\n this.config\n );\n }\n}\nclass PgPointObject extends PgColumn {\n static [entityKind] = \"PgPointObject\";\n getSQLType() {\n return \"point\";\n }\n mapFromDriverValue(value) {\n if (typeof value === \"string\") {\n const [x, y] = value.slice(1, -1).split(\",\");\n return { x: Number.parseFloat(x), y: Number.parseFloat(y) };\n }\n return value;\n }\n mapToDriverValue(value) {\n return `(${value.x},${value.y})`;\n }\n}\nfunction point(a, b) {\n const { name, config } = getColumnNameAndConfig(a, b);\n if (!config?.mode || config.mode === \"tuple\") {\n return new PgPointTupleBuilder(name);\n }\n return new PgPointObjectBuilder(name);\n}\nexport {\n PgPointObject,\n PgPointObjectBuilder,\n PgPointTuple,\n PgPointTupleBuilder,\n point\n};\n//# sourceMappingURL=point.js.map",
44
- "function hexToBytes(hex) {\n const bytes = [];\n for (let c = 0; c < hex.length; c += 2) {\n bytes.push(Number.parseInt(hex.slice(c, c + 2), 16));\n }\n return new Uint8Array(bytes);\n}\nfunction bytesToFloat64(bytes, offset) {\n const buffer = new ArrayBuffer(8);\n const view = new DataView(buffer);\n for (let i = 0; i < 8; i++) {\n view.setUint8(i, bytes[offset + i]);\n }\n return view.getFloat64(0, true);\n}\nfunction parseEWKB(hex) {\n const bytes = hexToBytes(hex);\n let offset = 0;\n const byteOrder = bytes[offset];\n offset += 1;\n const view = new DataView(bytes.buffer);\n const geomType = view.getUint32(offset, byteOrder === 1);\n offset += 4;\n let _srid;\n if (geomType & 536870912) {\n _srid = view.getUint32(offset, byteOrder === 1);\n offset += 4;\n }\n if ((geomType & 65535) === 1) {\n const x = bytesToFloat64(bytes, offset);\n offset += 8;\n const y = bytesToFloat64(bytes, offset);\n offset += 8;\n return [x, y];\n }\n throw new Error(\"Unsupported geometry type\");\n}\nexport {\n parseEWKB\n};\n//# sourceMappingURL=utils.js.map",
45
- "import { entityKind } from \"../../../entity.js\";\nimport { getColumnNameAndConfig } from \"../../../utils.js\";\nimport { PgColumn, PgColumnBuilder } from \"../common.js\";\nimport { parseEWKB } from \"./utils.js\";\nclass PgGeometryBuilder extends PgColumnBuilder {\n static [entityKind] = \"PgGeometryBuilder\";\n constructor(name) {\n super(name, \"array\", \"PgGeometry\");\n }\n /** @internal */\n build(table) {\n return new PgGeometry(\n table,\n this.config\n );\n }\n}\nclass PgGeometry extends PgColumn {\n static [entityKind] = \"PgGeometry\";\n getSQLType() {\n return \"geometry(point)\";\n }\n mapFromDriverValue(value) {\n return parseEWKB(value);\n }\n mapToDriverValue(value) {\n return `point(${value[0]} ${value[1]})`;\n }\n}\nclass PgGeometryObjectBuilder extends PgColumnBuilder {\n static [entityKind] = \"PgGeometryObjectBuilder\";\n constructor(name) {\n super(name, \"json\", \"PgGeometryObject\");\n }\n /** @internal */\n build(table) {\n return new PgGeometryObject(\n table,\n this.config\n );\n }\n}\nclass PgGeometryObject extends PgColumn {\n static [entityKind] = \"PgGeometryObject\";\n getSQLType() {\n return \"geometry(point)\";\n }\n mapFromDriverValue(value) {\n const parsed = parseEWKB(value);\n return { x: parsed[0], y: parsed[1] };\n }\n mapToDriverValue(value) {\n return `point(${value.x} ${value.y})`;\n }\n}\nfunction geometry(a, b) {\n const { name, config } = getColumnNameAndConfig(a, b);\n if (!config?.mode || config.mode === \"tuple\") {\n return new PgGeometryBuilder(name);\n }\n return new PgGeometryObjectBuilder(name);\n}\nexport {\n PgGeometry,\n PgGeometryBuilder,\n PgGeometryObject,\n PgGeometryObjectBuilder,\n geometry\n};\n//# sourceMappingURL=geometry.js.map",
46
- "import { entityKind } from \"../../entity.js\";\nimport { PgColumn, PgColumnBuilder } from \"./common.js\";\nclass PgRealBuilder extends PgColumnBuilder {\n static [entityKind] = \"PgRealBuilder\";\n constructor(name, length) {\n super(name, \"number\", \"PgReal\");\n this.config.length = length;\n }\n /** @internal */\n build(table) {\n return new PgReal(table, this.config);\n }\n}\nclass PgReal extends PgColumn {\n static [entityKind] = \"PgReal\";\n constructor(table, config) {\n super(table, config);\n }\n getSQLType() {\n return \"real\";\n }\n mapFromDriverValue = (value) => {\n if (typeof value === \"string\") {\n return Number.parseFloat(value);\n }\n return value;\n };\n}\nfunction real(name) {\n return new PgRealBuilder(name ?? \"\");\n}\nexport {\n PgReal,\n PgRealBuilder,\n real\n};\n//# sourceMappingURL=real.js.map",
47
- "import { entityKind } from \"../../entity.js\";\nimport { PgColumn, PgColumnBuilder } from \"./common.js\";\nclass PgSerialBuilder extends PgColumnBuilder {\n static [entityKind] = \"PgSerialBuilder\";\n constructor(name) {\n super(name, \"number\", \"PgSerial\");\n this.config.hasDefault = true;\n this.config.notNull = true;\n }\n /** @internal */\n build(table) {\n return new PgSerial(table, this.config);\n }\n}\nclass PgSerial extends PgColumn {\n static [entityKind] = \"PgSerial\";\n getSQLType() {\n return \"serial\";\n }\n}\nfunction serial(name) {\n return new PgSerialBuilder(name ?? \"\");\n}\nexport {\n PgSerial,\n PgSerialBuilder,\n serial\n};\n//# sourceMappingURL=serial.js.map",
48
- "import { entityKind } from \"../../entity.js\";\nimport { PgColumn } from \"./common.js\";\nimport { PgIntColumnBaseBuilder } from \"./int.common.js\";\nclass PgSmallIntBuilder extends PgIntColumnBaseBuilder {\n static [entityKind] = \"PgSmallIntBuilder\";\n constructor(name) {\n super(name, \"number\", \"PgSmallInt\");\n }\n /** @internal */\n build(table) {\n return new PgSmallInt(table, this.config);\n }\n}\nclass PgSmallInt extends PgColumn {\n static [entityKind] = \"PgSmallInt\";\n getSQLType() {\n return \"smallint\";\n }\n mapFromDriverValue = (value) => {\n if (typeof value === \"string\") {\n return Number(value);\n }\n return value;\n };\n}\nfunction smallint(name) {\n return new PgSmallIntBuilder(name ?? \"\");\n}\nexport {\n PgSmallInt,\n PgSmallIntBuilder,\n smallint\n};\n//# sourceMappingURL=smallint.js.map",
49
- "import { entityKind } from \"../../entity.js\";\nimport { PgColumn, PgColumnBuilder } from \"./common.js\";\nclass PgSmallSerialBuilder extends PgColumnBuilder {\n static [entityKind] = \"PgSmallSerialBuilder\";\n constructor(name) {\n super(name, \"number\", \"PgSmallSerial\");\n this.config.hasDefault = true;\n this.config.notNull = true;\n }\n /** @internal */\n build(table) {\n return new PgSmallSerial(\n table,\n this.config\n );\n }\n}\nclass PgSmallSerial extends PgColumn {\n static [entityKind] = \"PgSmallSerial\";\n getSQLType() {\n return \"smallserial\";\n }\n}\nfunction smallserial(name) {\n return new PgSmallSerialBuilder(name ?? \"\");\n}\nexport {\n PgSmallSerial,\n PgSmallSerialBuilder,\n smallserial\n};\n//# sourceMappingURL=smallserial.js.map",
50
- "import { entityKind } from \"../../entity.js\";\nimport { getColumnNameAndConfig } from \"../../utils.js\";\nimport { PgColumn, PgColumnBuilder } from \"./common.js\";\nclass PgTextBuilder extends PgColumnBuilder {\n static [entityKind] = \"PgTextBuilder\";\n constructor(name, config) {\n super(name, \"string\", \"PgText\");\n this.config.enumValues = config.enum;\n }\n /** @internal */\n build(table) {\n return new PgText(table, this.config);\n }\n}\nclass PgText extends PgColumn {\n static [entityKind] = \"PgText\";\n enumValues = this.config.enumValues;\n getSQLType() {\n return \"text\";\n }\n}\nfunction text(a, b = {}) {\n const { name, config } = getColumnNameAndConfig(a, b);\n return new PgTextBuilder(name, config);\n}\nexport {\n PgText,\n PgTextBuilder,\n text\n};\n//# sourceMappingURL=text.js.map",
51
- "import { entityKind } from \"../../entity.js\";\nimport { getColumnNameAndConfig } from \"../../utils.js\";\nimport { PgColumn } from \"./common.js\";\nimport { PgDateColumnBaseBuilder } from \"./date.common.js\";\nclass PgTimeBuilder extends PgDateColumnBaseBuilder {\n constructor(name, withTimezone, precision) {\n super(name, \"string\", \"PgTime\");\n this.withTimezone = withTimezone;\n this.precision = precision;\n this.config.withTimezone = withTimezone;\n this.config.precision = precision;\n }\n static [entityKind] = \"PgTimeBuilder\";\n /** @internal */\n build(table) {\n return new PgTime(table, this.config);\n }\n}\nclass PgTime extends PgColumn {\n static [entityKind] = \"PgTime\";\n withTimezone;\n precision;\n constructor(table, config) {\n super(table, config);\n this.withTimezone = config.withTimezone;\n this.precision = config.precision;\n }\n getSQLType() {\n const precision = this.precision === void 0 ? \"\" : `(${this.precision})`;\n return `time${precision}${this.withTimezone ? \" with time zone\" : \"\"}`;\n }\n}\nfunction time(a, b = {}) {\n const { name, config } = getColumnNameAndConfig(a, b);\n return new PgTimeBuilder(name, config.withTimezone ?? false, config.precision);\n}\nexport {\n PgTime,\n PgTimeBuilder,\n time\n};\n//# sourceMappingURL=time.js.map",
52
- "import { entityKind } from \"../../entity.js\";\nimport { getColumnNameAndConfig } from \"../../utils.js\";\nimport { PgColumn } from \"./common.js\";\nimport { PgDateColumnBaseBuilder } from \"./date.common.js\";\nclass PgTimestampBuilder extends PgDateColumnBaseBuilder {\n static [entityKind] = \"PgTimestampBuilder\";\n constructor(name, withTimezone, precision) {\n super(name, \"date\", \"PgTimestamp\");\n this.config.withTimezone = withTimezone;\n this.config.precision = precision;\n }\n /** @internal */\n build(table) {\n return new PgTimestamp(table, this.config);\n }\n}\nclass PgTimestamp extends PgColumn {\n static [entityKind] = \"PgTimestamp\";\n withTimezone;\n precision;\n constructor(table, config) {\n super(table, config);\n this.withTimezone = config.withTimezone;\n this.precision = config.precision;\n }\n getSQLType() {\n const precision = this.precision === void 0 ? \"\" : ` (${this.precision})`;\n return `timestamp${precision}${this.withTimezone ? \" with time zone\" : \"\"}`;\n }\n mapFromDriverValue(value) {\n if (typeof value === \"string\") return new Date(this.withTimezone ? value : value + \"+0000\");\n return value;\n }\n mapToDriverValue = (value) => {\n return value.toISOString();\n };\n}\nclass PgTimestampStringBuilder extends PgDateColumnBaseBuilder {\n static [entityKind] = \"PgTimestampStringBuilder\";\n constructor(name, withTimezone, precision) {\n super(name, \"string\", \"PgTimestampString\");\n this.config.withTimezone = withTimezone;\n this.config.precision = precision;\n }\n /** @internal */\n build(table) {\n return new PgTimestampString(\n table,\n this.config\n );\n }\n}\nclass PgTimestampString extends PgColumn {\n static [entityKind] = \"PgTimestampString\";\n withTimezone;\n precision;\n constructor(table, config) {\n super(table, config);\n this.withTimezone = config.withTimezone;\n this.precision = config.precision;\n }\n getSQLType() {\n const precision = this.precision === void 0 ? \"\" : `(${this.precision})`;\n return `timestamp${precision}${this.withTimezone ? \" with time zone\" : \"\"}`;\n }\n mapFromDriverValue(value) {\n if (typeof value === \"string\") return value;\n const shortened = value.toISOString().slice(0, -1).replace(\"T\", \" \");\n if (this.withTimezone) {\n const offset = value.getTimezoneOffset();\n const sign = offset <= 0 ? \"+\" : \"-\";\n return `${shortened}${sign}${Math.floor(Math.abs(offset) / 60).toString().padStart(2, \"0\")}`;\n }\n return shortened;\n }\n}\nfunction timestamp(a, b = {}) {\n const { name, config } = getColumnNameAndConfig(a, b);\n if (config?.mode === \"string\") {\n return new PgTimestampStringBuilder(name, config.withTimezone ?? false, config.precision);\n }\n return new PgTimestampBuilder(name, config?.withTimezone ?? false, config?.precision);\n}\nexport {\n PgTimestamp,\n PgTimestampBuilder,\n PgTimestampString,\n PgTimestampStringBuilder,\n timestamp\n};\n//# sourceMappingURL=timestamp.js.map",
53
- "import { entityKind } from \"../../entity.js\";\nimport { sql } from \"../../sql/sql.js\";\nimport { PgColumn, PgColumnBuilder } from \"./common.js\";\nclass PgUUIDBuilder extends PgColumnBuilder {\n static [entityKind] = \"PgUUIDBuilder\";\n constructor(name) {\n super(name, \"string\", \"PgUUID\");\n }\n /**\n * Adds `default gen_random_uuid()` to the column definition.\n */\n defaultRandom() {\n return this.default(sql`gen_random_uuid()`);\n }\n /** @internal */\n build(table) {\n return new PgUUID(table, this.config);\n }\n}\nclass PgUUID extends PgColumn {\n static [entityKind] = \"PgUUID\";\n getSQLType() {\n return \"uuid\";\n }\n}\nfunction uuid(name) {\n return new PgUUIDBuilder(name ?? \"\");\n}\nexport {\n PgUUID,\n PgUUIDBuilder,\n uuid\n};\n//# sourceMappingURL=uuid.js.map",
54
- "import { entityKind } from \"../../entity.js\";\nimport { getColumnNameAndConfig } from \"../../utils.js\";\nimport { PgColumn, PgColumnBuilder } from \"./common.js\";\nclass PgVarcharBuilder extends PgColumnBuilder {\n static [entityKind] = \"PgVarcharBuilder\";\n constructor(name, config) {\n super(name, \"string\", \"PgVarchar\");\n this.config.length = config.length;\n this.config.enumValues = config.enum;\n }\n /** @internal */\n build(table) {\n return new PgVarchar(\n table,\n this.config\n );\n }\n}\nclass PgVarchar extends PgColumn {\n static [entityKind] = \"PgVarchar\";\n length = this.config.length;\n enumValues = this.config.enumValues;\n getSQLType() {\n return this.length === void 0 ? `varchar` : `varchar(${this.length})`;\n }\n}\nfunction varchar(a, b = {}) {\n const { name, config } = getColumnNameAndConfig(a, b);\n return new PgVarcharBuilder(name, config);\n}\nexport {\n PgVarchar,\n PgVarcharBuilder,\n varchar\n};\n//# sourceMappingURL=varchar.js.map",
55
- "import { entityKind } from \"../../../entity.js\";\nimport { getColumnNameAndConfig } from \"../../../utils.js\";\nimport { PgColumn, PgColumnBuilder } from \"../common.js\";\nclass PgBinaryVectorBuilder extends PgColumnBuilder {\n static [entityKind] = \"PgBinaryVectorBuilder\";\n constructor(name, config) {\n super(name, \"string\", \"PgBinaryVector\");\n this.config.dimensions = config.dimensions;\n }\n /** @internal */\n build(table) {\n return new PgBinaryVector(\n table,\n this.config\n );\n }\n}\nclass PgBinaryVector extends PgColumn {\n static [entityKind] = \"PgBinaryVector\";\n dimensions = this.config.dimensions;\n getSQLType() {\n return `bit(${this.dimensions})`;\n }\n}\nfunction bit(a, b) {\n const { name, config } = getColumnNameAndConfig(a, b);\n return new PgBinaryVectorBuilder(name, config);\n}\nexport {\n PgBinaryVector,\n PgBinaryVectorBuilder,\n bit\n};\n//# sourceMappingURL=bit.js.map",
56
- "import { entityKind } from \"../../../entity.js\";\nimport { getColumnNameAndConfig } from \"../../../utils.js\";\nimport { PgColumn, PgColumnBuilder } from \"../common.js\";\nclass PgHalfVectorBuilder extends PgColumnBuilder {\n static [entityKind] = \"PgHalfVectorBuilder\";\n constructor(name, config) {\n super(name, \"array\", \"PgHalfVector\");\n this.config.dimensions = config.dimensions;\n }\n /** @internal */\n build(table) {\n return new PgHalfVector(\n table,\n this.config\n );\n }\n}\nclass PgHalfVector extends PgColumn {\n static [entityKind] = \"PgHalfVector\";\n dimensions = this.config.dimensions;\n getSQLType() {\n return `halfvec(${this.dimensions})`;\n }\n mapToDriverValue(value) {\n return JSON.stringify(value);\n }\n mapFromDriverValue(value) {\n return value.slice(1, -1).split(\",\").map((v) => Number.parseFloat(v));\n }\n}\nfunction halfvec(a, b) {\n const { name, config } = getColumnNameAndConfig(a, b);\n return new PgHalfVectorBuilder(name, config);\n}\nexport {\n PgHalfVector,\n PgHalfVectorBuilder,\n halfvec\n};\n//# sourceMappingURL=halfvec.js.map",
57
- "import { entityKind } from \"../../../entity.js\";\nimport { getColumnNameAndConfig } from \"../../../utils.js\";\nimport { PgColumn, PgColumnBuilder } from \"../common.js\";\nclass PgSparseVectorBuilder extends PgColumnBuilder {\n static [entityKind] = \"PgSparseVectorBuilder\";\n constructor(name, config) {\n super(name, \"string\", \"PgSparseVector\");\n this.config.dimensions = config.dimensions;\n }\n /** @internal */\n build(table) {\n return new PgSparseVector(\n table,\n this.config\n );\n }\n}\nclass PgSparseVector extends PgColumn {\n static [entityKind] = \"PgSparseVector\";\n dimensions = this.config.dimensions;\n getSQLType() {\n return `sparsevec(${this.dimensions})`;\n }\n}\nfunction sparsevec(a, b) {\n const { name, config } = getColumnNameAndConfig(a, b);\n return new PgSparseVectorBuilder(name, config);\n}\nexport {\n PgSparseVector,\n PgSparseVectorBuilder,\n sparsevec\n};\n//# sourceMappingURL=sparsevec.js.map",
58
- "import { entityKind } from \"../../../entity.js\";\nimport { getColumnNameAndConfig } from \"../../../utils.js\";\nimport { PgColumn, PgColumnBuilder } from \"../common.js\";\nclass PgVectorBuilder extends PgColumnBuilder {\n static [entityKind] = \"PgVectorBuilder\";\n constructor(name, config) {\n super(name, \"array\", \"PgVector\");\n this.config.dimensions = config.dimensions;\n }\n /** @internal */\n build(table) {\n return new PgVector(\n table,\n this.config\n );\n }\n}\nclass PgVector extends PgColumn {\n static [entityKind] = \"PgVector\";\n dimensions = this.config.dimensions;\n getSQLType() {\n return `vector(${this.dimensions})`;\n }\n mapToDriverValue(value) {\n return JSON.stringify(value);\n }\n mapFromDriverValue(value) {\n return value.slice(1, -1).split(\",\").map((v) => Number.parseFloat(v));\n }\n}\nfunction vector(a, b) {\n const { name, config } = getColumnNameAndConfig(a, b);\n return new PgVectorBuilder(name, config);\n}\nexport {\n PgVector,\n PgVectorBuilder,\n vector\n};\n//# sourceMappingURL=vector.js.map",
59
- "import { bigint } from \"./bigint.js\";\nimport { bigserial } from \"./bigserial.js\";\nimport { boolean } from \"./boolean.js\";\nimport { char } from \"./char.js\";\nimport { cidr } from \"./cidr.js\";\nimport { customType } from \"./custom.js\";\nimport { date } from \"./date.js\";\nimport { doublePrecision } from \"./double-precision.js\";\nimport { inet } from \"./inet.js\";\nimport { integer } from \"./integer.js\";\nimport { interval } from \"./interval.js\";\nimport { json } from \"./json.js\";\nimport { jsonb } from \"./jsonb.js\";\nimport { line } from \"./line.js\";\nimport { macaddr } from \"./macaddr.js\";\nimport { macaddr8 } from \"./macaddr8.js\";\nimport { numeric } from \"./numeric.js\";\nimport { point } from \"./point.js\";\nimport { geometry } from \"./postgis_extension/geometry.js\";\nimport { real } from \"./real.js\";\nimport { serial } from \"./serial.js\";\nimport { smallint } from \"./smallint.js\";\nimport { smallserial } from \"./smallserial.js\";\nimport { text } from \"./text.js\";\nimport { time } from \"./time.js\";\nimport { timestamp } from \"./timestamp.js\";\nimport { uuid } from \"./uuid.js\";\nimport { varchar } from \"./varchar.js\";\nimport { bit } from \"./vector_extension/bit.js\";\nimport { halfvec } from \"./vector_extension/halfvec.js\";\nimport { sparsevec } from \"./vector_extension/sparsevec.js\";\nimport { vector } from \"./vector_extension/vector.js\";\nfunction getPgColumnBuilders() {\n return {\n bigint,\n bigserial,\n boolean,\n char,\n cidr,\n customType,\n date,\n doublePrecision,\n inet,\n integer,\n interval,\n json,\n jsonb,\n line,\n macaddr,\n macaddr8,\n numeric,\n point,\n geometry,\n real,\n serial,\n smallint,\n smallserial,\n text,\n time,\n timestamp,\n uuid,\n varchar,\n bit,\n halfvec,\n sparsevec,\n vector\n };\n}\nexport {\n getPgColumnBuilders\n};\n//# sourceMappingURL=all.js.map",
60
- "import { entityKind } from \"../entity.js\";\nimport { Table } from \"../table.js\";\nimport { getPgColumnBuilders } from \"./columns/all.js\";\nconst InlineForeignKeys = Symbol.for(\"drizzle:PgInlineForeignKeys\");\nconst EnableRLS = Symbol.for(\"drizzle:EnableRLS\");\nclass PgTable extends Table {\n static [entityKind] = \"PgTable\";\n /** @internal */\n static Symbol = Object.assign({}, Table.Symbol, {\n InlineForeignKeys,\n EnableRLS\n });\n /**@internal */\n [InlineForeignKeys] = [];\n /** @internal */\n [EnableRLS] = false;\n /** @internal */\n [Table.Symbol.ExtraConfigBuilder] = void 0;\n /** @internal */\n [Table.Symbol.ExtraConfigColumns] = {};\n}\nfunction pgTableWithSchema(name, columns, extraConfig, schema, baseName = name) {\n const rawTable = new PgTable(name, schema, baseName);\n const parsedColumns = typeof columns === \"function\" ? columns(getPgColumnBuilders()) : columns;\n const builtColumns = Object.fromEntries(\n Object.entries(parsedColumns).map(([name2, colBuilderBase]) => {\n const colBuilder = colBuilderBase;\n colBuilder.setName(name2);\n const column = colBuilder.build(rawTable);\n rawTable[InlineForeignKeys].push(...colBuilder.buildForeignKeys(column, rawTable));\n return [name2, column];\n })\n );\n const builtColumnsForExtraConfig = Object.fromEntries(\n Object.entries(parsedColumns).map(([name2, colBuilderBase]) => {\n const colBuilder = colBuilderBase;\n colBuilder.setName(name2);\n const column = colBuilder.buildExtraConfigColumn(rawTable);\n return [name2, column];\n })\n );\n const table = Object.assign(rawTable, builtColumns);\n table[Table.Symbol.Columns] = builtColumns;\n table[Table.Symbol.ExtraConfigColumns] = builtColumnsForExtraConfig;\n if (extraConfig) {\n table[PgTable.Symbol.ExtraConfigBuilder] = extraConfig;\n }\n return Object.assign(table, {\n enableRLS: () => {\n table[PgTable.Symbol.EnableRLS] = true;\n return table;\n }\n });\n}\nconst pgTable = (name, columns, extraConfig) => {\n return pgTableWithSchema(name, columns, extraConfig, void 0);\n};\nfunction pgTableCreator(customizeTableName) {\n return (name, columns, extraConfig) => {\n return pgTableWithSchema(customizeTableName(name), columns, extraConfig, void 0, name);\n };\n}\nexport {\n EnableRLS,\n InlineForeignKeys,\n PgTable,\n pgTable,\n pgTableCreator,\n pgTableWithSchema\n};\n//# sourceMappingURL=table.js.map",
61
- "import { Column } from \"../../column.js\";\nimport { is } from \"../../entity.js\";\nimport { Table } from \"../../table.js\";\nimport {\n isDriverValueEncoder,\n isSQLWrapper,\n Param,\n Placeholder,\n SQL,\n sql,\n StringChunk,\n View\n} from \"../sql.js\";\nfunction bindIfParam(value, column) {\n if (isDriverValueEncoder(column) && !isSQLWrapper(value) && !is(value, Param) && !is(value, Placeholder) && !is(value, Column) && !is(value, Table) && !is(value, View)) {\n return new Param(value, column);\n }\n return value;\n}\nconst eq = (left, right) => {\n return sql`${left} = ${bindIfParam(right, left)}`;\n};\nconst ne = (left, right) => {\n return sql`${left} <> ${bindIfParam(right, left)}`;\n};\nfunction and(...unfilteredConditions) {\n const conditions = unfilteredConditions.filter(\n (c) => c !== void 0\n );\n if (conditions.length === 0) {\n return void 0;\n }\n if (conditions.length === 1) {\n return new SQL(conditions);\n }\n return new SQL([\n new StringChunk(\"(\"),\n sql.join(conditions, new StringChunk(\" and \")),\n new StringChunk(\")\")\n ]);\n}\nfunction or(...unfilteredConditions) {\n const conditions = unfilteredConditions.filter(\n (c) => c !== void 0\n );\n if (conditions.length === 0) {\n return void 0;\n }\n if (conditions.length === 1) {\n return new SQL(conditions);\n }\n return new SQL([\n new StringChunk(\"(\"),\n sql.join(conditions, new StringChunk(\" or \")),\n new StringChunk(\")\")\n ]);\n}\nfunction not(condition) {\n return sql`not ${condition}`;\n}\nconst gt = (left, right) => {\n return sql`${left} > ${bindIfParam(right, left)}`;\n};\nconst gte = (left, right) => {\n return sql`${left} >= ${bindIfParam(right, left)}`;\n};\nconst lt = (left, right) => {\n return sql`${left} < ${bindIfParam(right, left)}`;\n};\nconst lte = (left, right) => {\n return sql`${left} <= ${bindIfParam(right, left)}`;\n};\nfunction inArray(column, values) {\n if (Array.isArray(values)) {\n if (values.length === 0) {\n return sql`false`;\n }\n return sql`${column} in ${values.map((v) => bindIfParam(v, column))}`;\n }\n return sql`${column} in ${bindIfParam(values, column)}`;\n}\nfunction notInArray(column, values) {\n if (Array.isArray(values)) {\n if (values.length === 0) {\n return sql`true`;\n }\n return sql`${column} not in ${values.map((v) => bindIfParam(v, column))}`;\n }\n return sql`${column} not in ${bindIfParam(values, column)}`;\n}\nfunction isNull(value) {\n return sql`${value} is null`;\n}\nfunction isNotNull(value) {\n return sql`${value} is not null`;\n}\nfunction exists(subquery) {\n return sql`exists ${subquery}`;\n}\nfunction notExists(subquery) {\n return sql`not exists ${subquery}`;\n}\nfunction between(column, min, max) {\n return sql`${column} between ${bindIfParam(min, column)} and ${bindIfParam(\n max,\n column\n )}`;\n}\nfunction notBetween(column, min, max) {\n return sql`${column} not between ${bindIfParam(\n min,\n column\n )} and ${bindIfParam(max, column)}`;\n}\nfunction like(column, value) {\n return sql`${column} like ${value}`;\n}\nfunction notLike(column, value) {\n return sql`${column} not like ${value}`;\n}\nfunction ilike(column, value) {\n return sql`${column} ilike ${value}`;\n}\nfunction notIlike(column, value) {\n return sql`${column} not ilike ${value}`;\n}\nfunction arrayContains(column, values) {\n if (Array.isArray(values)) {\n if (values.length === 0) {\n throw new Error(\"arrayContains requires at least one value\");\n }\n const array = sql`${bindIfParam(values, column)}`;\n return sql`${column} @> ${array}`;\n }\n return sql`${column} @> ${bindIfParam(values, column)}`;\n}\nfunction arrayContained(column, values) {\n if (Array.isArray(values)) {\n if (values.length === 0) {\n throw new Error(\"arrayContained requires at least one value\");\n }\n const array = sql`${bindIfParam(values, column)}`;\n return sql`${column} <@ ${array}`;\n }\n return sql`${column} <@ ${bindIfParam(values, column)}`;\n}\nfunction arrayOverlaps(column, values) {\n if (Array.isArray(values)) {\n if (values.length === 0) {\n throw new Error(\"arrayOverlaps requires at least one value\");\n }\n const array = sql`${bindIfParam(values, column)}`;\n return sql`${column} && ${array}`;\n }\n return sql`${column} && ${bindIfParam(values, column)}`;\n}\nexport {\n and,\n arrayContained,\n arrayContains,\n arrayOverlaps,\n between,\n bindIfParam,\n eq,\n exists,\n gt,\n gte,\n ilike,\n inArray,\n isNotNull,\n isNull,\n like,\n lt,\n lte,\n ne,\n not,\n notBetween,\n notExists,\n notIlike,\n notInArray,\n notLike,\n or\n};\n//# sourceMappingURL=conditions.js.map",
62
- "import { sql } from \"../sql.js\";\nfunction asc(column) {\n return sql`${column} asc`;\n}\nfunction desc(column) {\n return sql`${column} desc`;\n}\nexport {\n asc,\n desc\n};\n//# sourceMappingURL=select.js.map",
63
- "export * from \"./conditions.js\";\nexport * from \"./select.js\";\n//# sourceMappingURL=index.js.map",
64
- "import { getTableUniqueName, Table } from \"./table.js\";\nimport { Column } from \"./column.js\";\nimport { entityKind, is } from \"./entity.js\";\nimport { PrimaryKeyBuilder } from \"./pg-core/primary-keys.js\";\nimport {\n and,\n asc,\n between,\n desc,\n eq,\n exists,\n gt,\n gte,\n ilike,\n inArray,\n isNotNull,\n isNull,\n like,\n lt,\n lte,\n ne,\n not,\n notBetween,\n notExists,\n notIlike,\n notInArray,\n notLike,\n or\n} from \"./sql/expressions/index.js\";\nimport { SQL, sql } from \"./sql/sql.js\";\nclass Relation {\n constructor(sourceTable, referencedTable, relationName) {\n this.sourceTable = sourceTable;\n this.referencedTable = referencedTable;\n this.relationName = relationName;\n this.referencedTableName = referencedTable[Table.Symbol.Name];\n }\n static [entityKind] = \"Relation\";\n referencedTableName;\n fieldName;\n}\nclass Relations {\n constructor(table, config) {\n this.table = table;\n this.config = config;\n }\n static [entityKind] = \"Relations\";\n}\nclass One extends Relation {\n constructor(sourceTable, referencedTable, config, isNullable) {\n super(sourceTable, referencedTable, config?.relationName);\n this.config = config;\n this.isNullable = isNullable;\n }\n static [entityKind] = \"One\";\n withFieldName(fieldName) {\n const relation = new One(\n this.sourceTable,\n this.referencedTable,\n this.config,\n this.isNullable\n );\n relation.fieldName = fieldName;\n return relation;\n }\n}\nclass Many extends Relation {\n constructor(sourceTable, referencedTable, config) {\n super(sourceTable, referencedTable, config?.relationName);\n this.config = config;\n }\n static [entityKind] = \"Many\";\n withFieldName(fieldName) {\n const relation = new Many(\n this.sourceTable,\n this.referencedTable,\n this.config\n );\n relation.fieldName = fieldName;\n return relation;\n }\n}\nfunction getOperators() {\n return {\n and,\n between,\n eq,\n exists,\n gt,\n gte,\n ilike,\n inArray,\n isNull,\n isNotNull,\n like,\n lt,\n lte,\n ne,\n not,\n notBetween,\n notExists,\n notLike,\n notIlike,\n notInArray,\n or,\n sql\n };\n}\nfunction getOrderByOperators() {\n return {\n sql,\n asc,\n desc\n };\n}\nfunction extractTablesRelationalConfig(schema, configHelpers) {\n if (Object.keys(schema).length === 1 && \"default\" in schema && !is(schema[\"default\"], Table)) {\n schema = schema[\"default\"];\n }\n const tableNamesMap = {};\n const relationsBuffer = {};\n const tablesConfig = {};\n for (const [key, value] of Object.entries(schema)) {\n if (is(value, Table)) {\n const dbName = getTableUniqueName(value);\n const bufferedRelations = relationsBuffer[dbName];\n tableNamesMap[dbName] = key;\n tablesConfig[key] = {\n tsName: key,\n dbName: value[Table.Symbol.Name],\n schema: value[Table.Symbol.Schema],\n columns: value[Table.Symbol.Columns],\n relations: bufferedRelations?.relations ?? {},\n primaryKey: bufferedRelations?.primaryKey ?? []\n };\n for (const column of Object.values(\n value[Table.Symbol.Columns]\n )) {\n if (column.primary) {\n tablesConfig[key].primaryKey.push(column);\n }\n }\n const extraConfig = value[Table.Symbol.ExtraConfigBuilder]?.(value[Table.Symbol.ExtraConfigColumns]);\n if (extraConfig) {\n for (const configEntry of Object.values(extraConfig)) {\n if (is(configEntry, PrimaryKeyBuilder)) {\n tablesConfig[key].primaryKey.push(...configEntry.columns);\n }\n }\n }\n } else if (is(value, Relations)) {\n const dbName = getTableUniqueName(value.table);\n const tableName = tableNamesMap[dbName];\n const relations2 = value.config(\n configHelpers(value.table)\n );\n let primaryKey;\n for (const [relationName, relation] of Object.entries(relations2)) {\n if (tableName) {\n const tableConfig = tablesConfig[tableName];\n tableConfig.relations[relationName] = relation;\n if (primaryKey) {\n tableConfig.primaryKey.push(...primaryKey);\n }\n } else {\n if (!(dbName in relationsBuffer)) {\n relationsBuffer[dbName] = {\n relations: {},\n primaryKey\n };\n }\n relationsBuffer[dbName].relations[relationName] = relation;\n }\n }\n }\n }\n return { tables: tablesConfig, tableNamesMap };\n}\nfunction relations(table, relations2) {\n return new Relations(\n table,\n (helpers) => Object.fromEntries(\n Object.entries(relations2(helpers)).map(([key, value]) => [\n key,\n value.withFieldName(key)\n ])\n )\n );\n}\nfunction createOne(sourceTable) {\n return function one(table, config) {\n return new One(\n sourceTable,\n table,\n config,\n config?.fields.reduce((res, f) => res && f.notNull, true) ?? false\n );\n };\n}\nfunction createMany(sourceTable) {\n return function many(referencedTable, config) {\n return new Many(sourceTable, referencedTable, config);\n };\n}\nfunction normalizeRelation(schema, tableNamesMap, relation) {\n if (is(relation, One) && relation.config) {\n return {\n fields: relation.config.fields,\n references: relation.config.references\n };\n }\n const referencedTableTsName = tableNamesMap[getTableUniqueName(relation.referencedTable)];\n if (!referencedTableTsName) {\n throw new Error(\n `Table \"${relation.referencedTable[Table.Symbol.Name]}\" not found in schema`\n );\n }\n const referencedTableConfig = schema[referencedTableTsName];\n if (!referencedTableConfig) {\n throw new Error(`Table \"${referencedTableTsName}\" not found in schema`);\n }\n const sourceTable = relation.sourceTable;\n const sourceTableTsName = tableNamesMap[getTableUniqueName(sourceTable)];\n if (!sourceTableTsName) {\n throw new Error(\n `Table \"${sourceTable[Table.Symbol.Name]}\" not found in schema`\n );\n }\n const reverseRelations = [];\n for (const referencedTableRelation of Object.values(\n referencedTableConfig.relations\n )) {\n if (relation.relationName && relation !== referencedTableRelation && referencedTableRelation.relationName === relation.relationName || !relation.relationName && referencedTableRelation.referencedTable === relation.sourceTable) {\n reverseRelations.push(referencedTableRelation);\n }\n }\n if (reverseRelations.length > 1) {\n throw relation.relationName ? new Error(\n `There are multiple relations with name \"${relation.relationName}\" in table \"${referencedTableTsName}\"`\n ) : new Error(\n `There are multiple relations between \"${referencedTableTsName}\" and \"${relation.sourceTable[Table.Symbol.Name]}\". Please specify relation name`\n );\n }\n if (reverseRelations[0] && is(reverseRelations[0], One) && reverseRelations[0].config) {\n return {\n fields: reverseRelations[0].config.references,\n references: reverseRelations[0].config.fields\n };\n }\n throw new Error(\n `There is not enough information to infer relation \"${sourceTableTsName}.${relation.fieldName}\"`\n );\n}\nfunction createTableRelationsHelpers(sourceTable) {\n return {\n one: createOne(sourceTable),\n many: createMany(sourceTable)\n };\n}\nfunction mapRelationalRow(tablesConfig, tableConfig, row, buildQueryResultSelection, mapColumnValue = (value) => value) {\n const result = {};\n for (const [\n selectionItemIndex,\n selectionItem\n ] of buildQueryResultSelection.entries()) {\n if (selectionItem.isJson) {\n const relation = tableConfig.relations[selectionItem.tsKey];\n const rawSubRows = row[selectionItemIndex];\n const subRows = typeof rawSubRows === \"string\" ? JSON.parse(rawSubRows) : rawSubRows;\n result[selectionItem.tsKey] = is(relation, One) ? subRows && mapRelationalRow(\n tablesConfig,\n tablesConfig[selectionItem.relationTableTsKey],\n subRows,\n selectionItem.selection,\n mapColumnValue\n ) : subRows.map(\n (subRow) => mapRelationalRow(\n tablesConfig,\n tablesConfig[selectionItem.relationTableTsKey],\n subRow,\n selectionItem.selection,\n mapColumnValue\n )\n );\n } else {\n const value = mapColumnValue(row[selectionItemIndex]);\n const field = selectionItem.field;\n let decoder;\n if (is(field, Column)) {\n decoder = field;\n } else if (is(field, SQL)) {\n decoder = field.decoder;\n } else {\n decoder = field.sql.decoder;\n }\n result[selectionItem.tsKey] = value === null ? null : decoder.mapFromDriverValue(value);\n }\n }\n return result;\n}\nexport {\n Many,\n One,\n Relation,\n Relations,\n createMany,\n createOne,\n createTableRelationsHelpers,\n extractTablesRelationalConfig,\n getOperators,\n getOrderByOperators,\n mapRelationalRow,\n normalizeRelation,\n relations\n};\n//# sourceMappingURL=relations.js.map",
65
- "export * from \"./aggregate.js\";\nexport * from \"./vector.js\";\n//# sourceMappingURL=index.js.map",
66
- "export * from \"./expressions/index.js\";\nexport * from \"./functions/index.js\";\nexport * from \"./sql.js\";\n//# sourceMappingURL=index.js.map",
67
- "export * from \"./alias.js\";\nexport * from \"./column-builder.js\";\nexport * from \"./column.js\";\nexport * from \"./entity.js\";\nexport * from \"./errors.js\";\nexport * from \"./logger.js\";\nexport * from \"./operations.js\";\nexport * from \"./query-promise.js\";\nexport * from \"./relations.js\";\nexport * from \"./sql/index.js\";\nexport * from \"./subquery.js\";\nexport * from \"./table.js\";\nexport * from \"./utils.js\";\nexport * from \"./view-common.js\";\n//# sourceMappingURL=index.js.map",
68
- "import validate from './validate.js';\nconst byteToHex = [];\nfor (let i = 0; i < 256; ++i) {\n byteToHex.push((i + 0x100).toString(16).slice(1));\n}\nexport function unsafeStringify(arr, offset = 0) {\n return (byteToHex[arr[offset + 0]] +\n byteToHex[arr[offset + 1]] +\n byteToHex[arr[offset + 2]] +\n byteToHex[arr[offset + 3]] +\n '-' +\n byteToHex[arr[offset + 4]] +\n byteToHex[arr[offset + 5]] +\n '-' +\n byteToHex[arr[offset + 6]] +\n byteToHex[arr[offset + 7]] +\n '-' +\n byteToHex[arr[offset + 8]] +\n byteToHex[arr[offset + 9]] +\n '-' +\n byteToHex[arr[offset + 10]] +\n byteToHex[arr[offset + 11]] +\n byteToHex[arr[offset + 12]] +\n byteToHex[arr[offset + 13]] +\n byteToHex[arr[offset + 14]] +\n byteToHex[arr[offset + 15]]).toLowerCase();\n}\nfunction stringify(arr, offset = 0) {\n const uuid = unsafeStringify(arr, offset);\n if (!validate(uuid)) {\n throw TypeError('Stringified UUID is invalid');\n }\n return uuid;\n}\nexport default stringify;\n",
69
- "import { randomFillSync } from 'node:crypto';\nconst rnds8Pool = new Uint8Array(256);\nlet poolPtr = rnds8Pool.length;\nexport default function rng() {\n if (poolPtr > rnds8Pool.length - 16) {\n randomFillSync(rnds8Pool);\n poolPtr = 0;\n }\n return rnds8Pool.slice(poolPtr, (poolPtr += 16));\n}\n",
70
- "import { randomUUID } from 'node:crypto';\nexport default { randomUUID };\n",
71
- "import native from './native.js';\nimport rng from './rng.js';\nimport { unsafeStringify } from './stringify.js';\nfunction _v4(options, buf, offset) {\n options = options || {};\n const rnds = options.random ?? options.rng?.() ?? rng();\n if (rnds.length < 16) {\n throw new Error('Random bytes length must be >= 16');\n }\n rnds[6] = (rnds[6] & 0x0f) | 0x40;\n rnds[8] = (rnds[8] & 0x3f) | 0x80;\n if (buf) {\n offset = offset || 0;\n if (offset < 0 || offset + 16 > buf.length) {\n throw new RangeError(`UUID byte range ${offset}:${offset + 15} is out of buffer bounds`);\n }\n for (let i = 0; i < 16; ++i) {\n buf[offset + i] = rnds[i];\n }\n return buf;\n }\n return unsafeStringify(rnds);\n}\nfunction v4(options, buf, offset) {\n if (native.randomUUID && !buf && !options) {\n return native.randomUUID();\n }\n return _v4(options, buf, offset);\n}\nexport default v4;\n",
72
- "export { default as MAX } from './max.js';\nexport { default as NIL } from './nil.js';\nexport { default as parse } from './parse.js';\nexport { default as stringify } from './stringify.js';\nexport { default as v1 } from './v1.js';\nexport { default as v1ToV6 } from './v1ToV6.js';\nexport { default as v3 } from './v3.js';\nexport { default as v4 } from './v4.js';\nexport { default as v5 } from './v5.js';\nexport { default as v6 } from './v6.js';\nexport { default as v6ToV1 } from './v6ToV1.js';\nexport { default as v7 } from './v7.js';\nexport { default as validate } from './validate.js';\nexport { default as version } from './version.js';\n",
73
- "export * from \"./bigint.js\";\nexport * from \"./bigserial.js\";\nexport * from \"./boolean.js\";\nexport * from \"./char.js\";\nexport * from \"./cidr.js\";\nexport * from \"./common.js\";\nexport * from \"./custom.js\";\nexport * from \"./date.js\";\nexport * from \"./double-precision.js\";\nexport * from \"./enum.js\";\nexport * from \"./inet.js\";\nexport * from \"./int.common.js\";\nexport * from \"./integer.js\";\nexport * from \"./interval.js\";\nexport * from \"./json.js\";\nexport * from \"./jsonb.js\";\nexport * from \"./line.js\";\nexport * from \"./macaddr.js\";\nexport * from \"./macaddr8.js\";\nexport * from \"./numeric.js\";\nexport * from \"./point.js\";\nexport * from \"./postgis_extension/geometry.js\";\nexport * from \"./real.js\";\nexport * from \"./serial.js\";\nexport * from \"./smallint.js\";\nexport * from \"./smallserial.js\";\nexport * from \"./text.js\";\nexport * from \"./time.js\";\nexport * from \"./timestamp.js\";\nexport * from \"./uuid.js\";\nexport * from \"./varchar.js\";\nexport * from \"./vector_extension/bit.js\";\nexport * from \"./vector_extension/halfvec.js\";\nexport * from \"./vector_extension/sparsevec.js\";\nexport * from \"./vector_extension/vector.js\";\n//# sourceMappingURL=index.js.map",
74
- "import { ColumnAliasProxyHandler, TableAliasProxyHandler } from \"./alias.js\";\nimport { Column } from \"./column.js\";\nimport { entityKind, is } from \"./entity.js\";\nimport { SQL, View } from \"./sql/sql.js\";\nimport { Subquery } from \"./subquery.js\";\nimport { ViewBaseConfig } from \"./view-common.js\";\nclass SelectionProxyHandler {\n static [entityKind] = \"SelectionProxyHandler\";\n config;\n constructor(config) {\n this.config = { ...config };\n }\n get(subquery, prop) {\n if (prop === \"_\") {\n return {\n ...subquery[\"_\"],\n selectedFields: new Proxy(\n subquery._.selectedFields,\n this\n )\n };\n }\n if (prop === ViewBaseConfig) {\n return {\n ...subquery[ViewBaseConfig],\n selectedFields: new Proxy(\n subquery[ViewBaseConfig].selectedFields,\n this\n )\n };\n }\n if (typeof prop === \"symbol\") {\n return subquery[prop];\n }\n const columns = is(subquery, Subquery) ? subquery._.selectedFields : is(subquery, View) ? subquery[ViewBaseConfig].selectedFields : subquery;\n const value = columns[prop];\n if (is(value, SQL.Aliased)) {\n if (this.config.sqlAliasedBehavior === \"sql\" && !value.isSelectionField) {\n return value.sql;\n }\n const newValue = value.clone();\n newValue.isSelectionField = true;\n return newValue;\n }\n if (is(value, SQL)) {\n if (this.config.sqlBehavior === \"sql\") {\n return value;\n }\n throw new Error(\n `You tried to reference \"${prop}\" field from a subquery, which is a raw SQL field, but it doesn't have an alias declared. Please add an alias to the field using \".as('alias')\" method.`\n );\n }\n if (is(value, Column)) {\n if (this.config.alias) {\n return new Proxy(\n value,\n new ColumnAliasProxyHandler(\n new Proxy(\n value.table,\n new TableAliasProxyHandler(this.config.alias, this.config.replaceOriginalName ?? false)\n )\n )\n );\n }\n return value;\n }\n if (typeof value !== \"object\" || value === null) {\n return value;\n }\n return new Proxy(value, new SelectionProxyHandler(this.config));\n }\n}\nexport {\n SelectionProxyHandler\n};\n//# sourceMappingURL=selection-proxy.js.map",
75
- "import { SQL } from \"../sql/sql.js\";\nimport { entityKind, is } from \"../entity.js\";\nimport { IndexedColumn } from \"./columns/index.js\";\nclass IndexBuilderOn {\n constructor(unique, name) {\n this.unique = unique;\n this.name = name;\n }\n static [entityKind] = \"PgIndexBuilderOn\";\n on(...columns) {\n return new IndexBuilder(\n columns.map((it) => {\n if (is(it, SQL)) {\n return it;\n }\n it = it;\n const clonedIndexedColumn = new IndexedColumn(it.name, !!it.keyAsName, it.columnType, it.indexConfig);\n it.indexConfig = JSON.parse(JSON.stringify(it.defaultConfig));\n return clonedIndexedColumn;\n }),\n this.unique,\n false,\n this.name\n );\n }\n onOnly(...columns) {\n return new IndexBuilder(\n columns.map((it) => {\n if (is(it, SQL)) {\n return it;\n }\n it = it;\n const clonedIndexedColumn = new IndexedColumn(it.name, !!it.keyAsName, it.columnType, it.indexConfig);\n it.indexConfig = it.defaultConfig;\n return clonedIndexedColumn;\n }),\n this.unique,\n true,\n this.name\n );\n }\n /**\n * Specify what index method to use. Choices are `btree`, `hash`, `gist`, `spgist`, `gin`, `brin`, or user-installed access methods like `bloom`. The default method is `btree.\n *\n * If you have the `pg_vector` extension installed in your database, you can use the `hnsw` and `ivfflat` options, which are predefined types.\n *\n * **You can always specify any string you want in the method, in case Drizzle doesn't have it natively in its types**\n *\n * @param method The name of the index method to be used\n * @param columns\n * @returns\n */\n using(method, ...columns) {\n return new IndexBuilder(\n columns.map((it) => {\n if (is(it, SQL)) {\n return it;\n }\n it = it;\n const clonedIndexedColumn = new IndexedColumn(it.name, !!it.keyAsName, it.columnType, it.indexConfig);\n it.indexConfig = JSON.parse(JSON.stringify(it.defaultConfig));\n return clonedIndexedColumn;\n }),\n this.unique,\n true,\n this.name,\n method\n );\n }\n}\nclass IndexBuilder {\n static [entityKind] = \"PgIndexBuilder\";\n /** @internal */\n config;\n constructor(columns, unique, only, name, method = \"btree\") {\n this.config = {\n name,\n columns,\n unique,\n only,\n method\n };\n }\n concurrently() {\n this.config.concurrently = true;\n return this;\n }\n with(obj) {\n this.config.with = obj;\n return this;\n }\n where(condition) {\n this.config.where = condition;\n return this;\n }\n /** @internal */\n build(table) {\n return new Index(this.config, table);\n }\n}\nclass Index {\n static [entityKind] = \"PgIndex\";\n config;\n constructor(config, table) {\n this.config = { ...config, table };\n }\n}\nfunction index(name) {\n return new IndexBuilderOn(false, name);\n}\nfunction uniqueIndex(name) {\n return new IndexBuilderOn(true, name);\n}\nexport {\n Index,\n IndexBuilder,\n IndexBuilderOn,\n index,\n uniqueIndex\n};\n//# sourceMappingURL=indexes.js.map",
76
- "const PgViewConfig = Symbol.for(\"drizzle:PgViewConfig\");\nexport {\n PgViewConfig\n};\n//# sourceMappingURL=view-common.js.map",
77
- "import { entityKind } from \"../entity.js\";\nclass TypedQueryBuilder {\n static [entityKind] = \"TypedQueryBuilder\";\n /** @internal */\n getSelectedFields() {\n return this._.selectedFields;\n }\n}\nexport {\n TypedQueryBuilder\n};\n//# sourceMappingURL=query-builder.js.map",
78
- "import { entityKind, is } from \"../../entity.js\";\nimport { PgViewBase } from \"../view-base.js\";\nimport { TypedQueryBuilder } from \"../../query-builders/query-builder.js\";\nimport { QueryPromise } from \"../../query-promise.js\";\nimport { SelectionProxyHandler } from \"../../selection-proxy.js\";\nimport { SQL, View } from \"../../sql/sql.js\";\nimport { Subquery } from \"../../subquery.js\";\nimport { Table } from \"../../table.js\";\nimport { tracer } from \"../../tracing.js\";\nimport {\n applyMixins,\n getTableColumns,\n getTableLikeName,\n haveSameKeys\n} from \"../../utils.js\";\nimport { orderSelectedFields } from \"../../utils.js\";\nimport { ViewBaseConfig } from \"../../view-common.js\";\nimport { extractUsedTable } from \"../utils.js\";\nclass PgSelectBuilder {\n static [entityKind] = \"PgSelectBuilder\";\n fields;\n session;\n dialect;\n withList = [];\n distinct;\n constructor(config) {\n this.fields = config.fields;\n this.session = config.session;\n this.dialect = config.dialect;\n if (config.withList) {\n this.withList = config.withList;\n }\n this.distinct = config.distinct;\n }\n authToken;\n /** @internal */\n setToken(token) {\n this.authToken = token;\n return this;\n }\n /**\n * Specify the table, subquery, or other target that you're\n * building a select query against.\n *\n * {@link https://www.postgresql.org/docs/current/sql-select.html#SQL-FROM | Postgres from documentation}\n */\n from(source) {\n const isPartialSelect = !!this.fields;\n const src = source;\n let fields;\n if (this.fields) {\n fields = this.fields;\n } else if (is(src, Subquery)) {\n fields = Object.fromEntries(\n Object.keys(src._.selectedFields).map((key) => [key, src[key]])\n );\n } else if (is(src, PgViewBase)) {\n fields = src[ViewBaseConfig].selectedFields;\n } else if (is(src, SQL)) {\n fields = {};\n } else {\n fields = getTableColumns(src);\n }\n return new PgSelectBase({\n table: src,\n fields,\n isPartialSelect,\n session: this.session,\n dialect: this.dialect,\n withList: this.withList,\n distinct: this.distinct\n }).setToken(this.authToken);\n }\n}\nclass PgSelectQueryBuilderBase extends TypedQueryBuilder {\n static [entityKind] = \"PgSelectQueryBuilder\";\n _;\n config;\n joinsNotNullableMap;\n tableName;\n isPartialSelect;\n session;\n dialect;\n cacheConfig = void 0;\n usedTables = /* @__PURE__ */ new Set();\n constructor({ table, fields, isPartialSelect, session, dialect, withList, distinct }) {\n super();\n this.config = {\n withList,\n table,\n fields: { ...fields },\n distinct,\n setOperators: []\n };\n this.isPartialSelect = isPartialSelect;\n this.session = session;\n this.dialect = dialect;\n this._ = {\n selectedFields: fields,\n config: this.config\n };\n this.tableName = getTableLikeName(table);\n this.joinsNotNullableMap = typeof this.tableName === \"string\" ? { [this.tableName]: true } : {};\n for (const item of extractUsedTable(table)) this.usedTables.add(item);\n }\n /** @internal */\n getUsedTables() {\n return [...this.usedTables];\n }\n createJoin(joinType, lateral) {\n return (table, on) => {\n const baseTableName = this.tableName;\n const tableName = getTableLikeName(table);\n for (const item of extractUsedTable(table)) this.usedTables.add(item);\n if (typeof tableName === \"string\" && this.config.joins?.some((join) => join.alias === tableName)) {\n throw new Error(`Alias \"${tableName}\" is already used in this query`);\n }\n if (!this.isPartialSelect) {\n if (Object.keys(this.joinsNotNullableMap).length === 1 && typeof baseTableName === \"string\") {\n this.config.fields = {\n [baseTableName]: this.config.fields\n };\n }\n if (typeof tableName === \"string\" && !is(table, SQL)) {\n const selection = is(table, Subquery) ? table._.selectedFields : is(table, View) ? table[ViewBaseConfig].selectedFields : table[Table.Symbol.Columns];\n this.config.fields[tableName] = selection;\n }\n }\n if (typeof on === \"function\") {\n on = on(\n new Proxy(\n this.config.fields,\n new SelectionProxyHandler({ sqlAliasedBehavior: \"sql\", sqlBehavior: \"sql\" })\n )\n );\n }\n if (!this.config.joins) {\n this.config.joins = [];\n }\n this.config.joins.push({ on, table, joinType, alias: tableName, lateral });\n if (typeof tableName === \"string\") {\n switch (joinType) {\n case \"left\": {\n this.joinsNotNullableMap[tableName] = false;\n break;\n }\n case \"right\": {\n this.joinsNotNullableMap = Object.fromEntries(\n Object.entries(this.joinsNotNullableMap).map(([key]) => [key, false])\n );\n this.joinsNotNullableMap[tableName] = true;\n break;\n }\n case \"cross\":\n case \"inner\": {\n this.joinsNotNullableMap[tableName] = true;\n break;\n }\n case \"full\": {\n this.joinsNotNullableMap = Object.fromEntries(\n Object.entries(this.joinsNotNullableMap).map(([key]) => [key, false])\n );\n this.joinsNotNullableMap[tableName] = false;\n break;\n }\n }\n }\n return this;\n };\n }\n /**\n * Executes a `left join` operation by adding another table to the current query.\n *\n * Calling this method associates each row of the table with the corresponding row from the joined table, if a match is found. If no matching row exists, it sets all columns of the joined table to null.\n *\n * See docs: {@link https://orm.drizzle.team/docs/joins#left-join}\n *\n * @param table the table to join.\n * @param on the `on` clause.\n *\n * @example\n *\n * ```ts\n * // Select all users and their pets\n * const usersWithPets: { user: User; pets: Pet | null; }[] = await db.select()\n * .from(users)\n * .leftJoin(pets, eq(users.id, pets.ownerId))\n *\n * // Select userId and petId\n * const usersIdsAndPetIds: { userId: number; petId: number | null; }[] = await db.select({\n * userId: users.id,\n * petId: pets.id,\n * })\n * .from(users)\n * .leftJoin(pets, eq(users.id, pets.ownerId))\n * ```\n */\n leftJoin = this.createJoin(\"left\", false);\n /**\n * Executes a `left join lateral` operation by adding subquery to the current query.\n *\n * A `lateral` join allows the right-hand expression to refer to columns from the left-hand side.\n *\n * Calling this method associates each row of the table with the corresponding row from the joined table, if a match is found. If no matching row exists, it sets all columns of the joined table to null.\n *\n * See docs: {@link https://orm.drizzle.team/docs/joins#left-join-lateral}\n *\n * @param table the subquery to join.\n * @param on the `on` clause.\n */\n leftJoinLateral = this.createJoin(\"left\", true);\n /**\n * Executes a `right join` operation by adding another table to the current query.\n *\n * Calling this method associates each row of the joined table with the corresponding row from the main table, if a match is found. If no matching row exists, it sets all columns of the main table to null.\n *\n * See docs: {@link https://orm.drizzle.team/docs/joins#right-join}\n *\n * @param table the table to join.\n * @param on the `on` clause.\n *\n * @example\n *\n * ```ts\n * // Select all users and their pets\n * const usersWithPets: { user: User | null; pets: Pet; }[] = await db.select()\n * .from(users)\n * .rightJoin(pets, eq(users.id, pets.ownerId))\n *\n * // Select userId and petId\n * const usersIdsAndPetIds: { userId: number | null; petId: number; }[] = await db.select({\n * userId: users.id,\n * petId: pets.id,\n * })\n * .from(users)\n * .rightJoin(pets, eq(users.id, pets.ownerId))\n * ```\n */\n rightJoin = this.createJoin(\"right\", false);\n /**\n * Executes an `inner join` operation, creating a new table by combining rows from two tables that have matching values.\n *\n * Calling this method retrieves rows that have corresponding entries in both joined tables. Rows without matching entries in either table are excluded, resulting in a table that includes only matching pairs.\n *\n * See docs: {@link https://orm.drizzle.team/docs/joins#inner-join}\n *\n * @param table the table to join.\n * @param on the `on` clause.\n *\n * @example\n *\n * ```ts\n * // Select all users and their pets\n * const usersWithPets: { user: User; pets: Pet; }[] = await db.select()\n * .from(users)\n * .innerJoin(pets, eq(users.id, pets.ownerId))\n *\n * // Select userId and petId\n * const usersIdsAndPetIds: { userId: number; petId: number; }[] = await db.select({\n * userId: users.id,\n * petId: pets.id,\n * })\n * .from(users)\n * .innerJoin(pets, eq(users.id, pets.ownerId))\n * ```\n */\n innerJoin = this.createJoin(\"inner\", false);\n /**\n * Executes an `inner join lateral` operation, creating a new table by combining rows from two queries that have matching values.\n *\n * A `lateral` join allows the right-hand expression to refer to columns from the left-hand side.\n *\n * Calling this method retrieves rows that have corresponding entries in both joined tables. Rows without matching entries in either table are excluded, resulting in a table that includes only matching pairs.\n *\n * See docs: {@link https://orm.drizzle.team/docs/joins#inner-join-lateral}\n *\n * @param table the subquery to join.\n * @param on the `on` clause.\n */\n innerJoinLateral = this.createJoin(\"inner\", true);\n /**\n * Executes a `full join` operation by combining rows from two tables into a new table.\n *\n * Calling this method retrieves all rows from both main and joined tables, merging rows with matching values and filling in `null` for non-matching columns.\n *\n * See docs: {@link https://orm.drizzle.team/docs/joins#full-join}\n *\n * @param table the table to join.\n * @param on the `on` clause.\n *\n * @example\n *\n * ```ts\n * // Select all users and their pets\n * const usersWithPets: { user: User | null; pets: Pet | null; }[] = await db.select()\n * .from(users)\n * .fullJoin(pets, eq(users.id, pets.ownerId))\n *\n * // Select userId and petId\n * const usersIdsAndPetIds: { userId: number | null; petId: number | null; }[] = await db.select({\n * userId: users.id,\n * petId: pets.id,\n * })\n * .from(users)\n * .fullJoin(pets, eq(users.id, pets.ownerId))\n * ```\n */\n fullJoin = this.createJoin(\"full\", false);\n /**\n * Executes a `cross join` operation by combining rows from two tables into a new table.\n *\n * Calling this method retrieves all rows from both main and joined tables, merging all rows from each table.\n *\n * See docs: {@link https://orm.drizzle.team/docs/joins#cross-join}\n *\n * @param table the table to join.\n *\n * @example\n *\n * ```ts\n * // Select all users, each user with every pet\n * const usersWithPets: { user: User; pets: Pet; }[] = await db.select()\n * .from(users)\n * .crossJoin(pets)\n *\n * // Select userId and petId\n * const usersIdsAndPetIds: { userId: number; petId: number; }[] = await db.select({\n * userId: users.id,\n * petId: pets.id,\n * })\n * .from(users)\n * .crossJoin(pets)\n * ```\n */\n crossJoin = this.createJoin(\"cross\", false);\n /**\n * Executes a `cross join lateral` operation by combining rows from two queries into a new table.\n *\n * A `lateral` join allows the right-hand expression to refer to columns from the left-hand side.\n *\n * Calling this method retrieves all rows from both main and joined queries, merging all rows from each query.\n *\n * See docs: {@link https://orm.drizzle.team/docs/joins#cross-join-lateral}\n *\n * @param table the query to join.\n */\n crossJoinLateral = this.createJoin(\"cross\", true);\n createSetOperator(type, isAll) {\n return (rightSelection) => {\n const rightSelect = typeof rightSelection === \"function\" ? rightSelection(getPgSetOperators()) : rightSelection;\n if (!haveSameKeys(this.getSelectedFields(), rightSelect.getSelectedFields())) {\n throw new Error(\n \"Set operator error (union / intersect / except): selected fields are not the same or are in a different order\"\n );\n }\n this.config.setOperators.push({ type, isAll, rightSelect });\n return this;\n };\n }\n /**\n * Adds `union` set operator to the query.\n *\n * Calling this method will combine the result sets of the `select` statements and remove any duplicate rows that appear across them.\n *\n * See docs: {@link https://orm.drizzle.team/docs/set-operations#union}\n *\n * @example\n *\n * ```ts\n * // Select all unique names from customers and users tables\n * await db.select({ name: users.name })\n * .from(users)\n * .union(\n * db.select({ name: customers.name }).from(customers)\n * );\n * // or\n * import { union } from 'drizzle-orm/pg-core'\n *\n * await union(\n * db.select({ name: users.name }).from(users),\n * db.select({ name: customers.name }).from(customers)\n * );\n * ```\n */\n union = this.createSetOperator(\"union\", false);\n /**\n * Adds `union all` set operator to the query.\n *\n * Calling this method will combine the result-set of the `select` statements and keep all duplicate rows that appear across them.\n *\n * See docs: {@link https://orm.drizzle.team/docs/set-operations#union-all}\n *\n * @example\n *\n * ```ts\n * // Select all transaction ids from both online and in-store sales\n * await db.select({ transaction: onlineSales.transactionId })\n * .from(onlineSales)\n * .unionAll(\n * db.select({ transaction: inStoreSales.transactionId }).from(inStoreSales)\n * );\n * // or\n * import { unionAll } from 'drizzle-orm/pg-core'\n *\n * await unionAll(\n * db.select({ transaction: onlineSales.transactionId }).from(onlineSales),\n * db.select({ transaction: inStoreSales.transactionId }).from(inStoreSales)\n * );\n * ```\n */\n unionAll = this.createSetOperator(\"union\", true);\n /**\n * Adds `intersect` set operator to the query.\n *\n * Calling this method will retain only the rows that are present in both result sets and eliminate duplicates.\n *\n * See docs: {@link https://orm.drizzle.team/docs/set-operations#intersect}\n *\n * @example\n *\n * ```ts\n * // Select course names that are offered in both departments A and B\n * await db.select({ courseName: depA.courseName })\n * .from(depA)\n * .intersect(\n * db.select({ courseName: depB.courseName }).from(depB)\n * );\n * // or\n * import { intersect } from 'drizzle-orm/pg-core'\n *\n * await intersect(\n * db.select({ courseName: depA.courseName }).from(depA),\n * db.select({ courseName: depB.courseName }).from(depB)\n * );\n * ```\n */\n intersect = this.createSetOperator(\"intersect\", false);\n /**\n * Adds `intersect all` set operator to the query.\n *\n * Calling this method will retain only the rows that are present in both result sets including all duplicates.\n *\n * See docs: {@link https://orm.drizzle.team/docs/set-operations#intersect-all}\n *\n * @example\n *\n * ```ts\n * // Select all products and quantities that are ordered by both regular and VIP customers\n * await db.select({\n * productId: regularCustomerOrders.productId,\n * quantityOrdered: regularCustomerOrders.quantityOrdered\n * })\n * .from(regularCustomerOrders)\n * .intersectAll(\n * db.select({\n * productId: vipCustomerOrders.productId,\n * quantityOrdered: vipCustomerOrders.quantityOrdered\n * })\n * .from(vipCustomerOrders)\n * );\n * // or\n * import { intersectAll } from 'drizzle-orm/pg-core'\n *\n * await intersectAll(\n * db.select({\n * productId: regularCustomerOrders.productId,\n * quantityOrdered: regularCustomerOrders.quantityOrdered\n * })\n * .from(regularCustomerOrders),\n * db.select({\n * productId: vipCustomerOrders.productId,\n * quantityOrdered: vipCustomerOrders.quantityOrdered\n * })\n * .from(vipCustomerOrders)\n * );\n * ```\n */\n intersectAll = this.createSetOperator(\"intersect\", true);\n /**\n * Adds `except` set operator to the query.\n *\n * Calling this method will retrieve all unique rows from the left query, except for the rows that are present in the result set of the right query.\n *\n * See docs: {@link https://orm.drizzle.team/docs/set-operations#except}\n *\n * @example\n *\n * ```ts\n * // Select all courses offered in department A but not in department B\n * await db.select({ courseName: depA.courseName })\n * .from(depA)\n * .except(\n * db.select({ courseName: depB.courseName }).from(depB)\n * );\n * // or\n * import { except } from 'drizzle-orm/pg-core'\n *\n * await except(\n * db.select({ courseName: depA.courseName }).from(depA),\n * db.select({ courseName: depB.courseName }).from(depB)\n * );\n * ```\n */\n except = this.createSetOperator(\"except\", false);\n /**\n * Adds `except all` set operator to the query.\n *\n * Calling this method will retrieve all rows from the left query, except for the rows that are present in the result set of the right query.\n *\n * See docs: {@link https://orm.drizzle.team/docs/set-operations#except-all}\n *\n * @example\n *\n * ```ts\n * // Select all products that are ordered by regular customers but not by VIP customers\n * await db.select({\n * productId: regularCustomerOrders.productId,\n * quantityOrdered: regularCustomerOrders.quantityOrdered,\n * })\n * .from(regularCustomerOrders)\n * .exceptAll(\n * db.select({\n * productId: vipCustomerOrders.productId,\n * quantityOrdered: vipCustomerOrders.quantityOrdered,\n * })\n * .from(vipCustomerOrders)\n * );\n * // or\n * import { exceptAll } from 'drizzle-orm/pg-core'\n *\n * await exceptAll(\n * db.select({\n * productId: regularCustomerOrders.productId,\n * quantityOrdered: regularCustomerOrders.quantityOrdered\n * })\n * .from(regularCustomerOrders),\n * db.select({\n * productId: vipCustomerOrders.productId,\n * quantityOrdered: vipCustomerOrders.quantityOrdered\n * })\n * .from(vipCustomerOrders)\n * );\n * ```\n */\n exceptAll = this.createSetOperator(\"except\", true);\n /** @internal */\n addSetOperators(setOperators) {\n this.config.setOperators.push(...setOperators);\n return this;\n }\n /**\n * Adds a `where` clause to the query.\n *\n * Calling this method will select only those rows that fulfill a specified condition.\n *\n * See docs: {@link https://orm.drizzle.team/docs/select#filtering}\n *\n * @param where the `where` clause.\n *\n * @example\n * You can use conditional operators and `sql function` to filter the rows to be selected.\n *\n * ```ts\n * // Select all cars with green color\n * await db.select().from(cars).where(eq(cars.color, 'green'));\n * // or\n * await db.select().from(cars).where(sql`${cars.color} = 'green'`)\n * ```\n *\n * You can logically combine conditional operators with `and()` and `or()` operators:\n *\n * ```ts\n * // Select all BMW cars with a green color\n * await db.select().from(cars).where(and(eq(cars.color, 'green'), eq(cars.brand, 'BMW')));\n *\n * // Select all cars with the green or blue color\n * await db.select().from(cars).where(or(eq(cars.color, 'green'), eq(cars.color, 'blue')));\n * ```\n */\n where(where) {\n if (typeof where === \"function\") {\n where = where(\n new Proxy(\n this.config.fields,\n new SelectionProxyHandler({ sqlAliasedBehavior: \"sql\", sqlBehavior: \"sql\" })\n )\n );\n }\n this.config.where = where;\n return this;\n }\n /**\n * Adds a `having` clause to the query.\n *\n * Calling this method will select only those rows that fulfill a specified condition. It is typically used with aggregate functions to filter the aggregated data based on a specified condition.\n *\n * See docs: {@link https://orm.drizzle.team/docs/select#aggregations}\n *\n * @param having the `having` clause.\n *\n * @example\n *\n * ```ts\n * // Select all brands with more than one car\n * await db.select({\n * \tbrand: cars.brand,\n * \tcount: sql<number>`cast(count(${cars.id}) as int)`,\n * })\n * .from(cars)\n * .groupBy(cars.brand)\n * .having(({ count }) => gt(count, 1));\n * ```\n */\n having(having) {\n if (typeof having === \"function\") {\n having = having(\n new Proxy(\n this.config.fields,\n new SelectionProxyHandler({ sqlAliasedBehavior: \"sql\", sqlBehavior: \"sql\" })\n )\n );\n }\n this.config.having = having;\n return this;\n }\n groupBy(...columns) {\n if (typeof columns[0] === \"function\") {\n const groupBy = columns[0](\n new Proxy(\n this.config.fields,\n new SelectionProxyHandler({ sqlAliasedBehavior: \"alias\", sqlBehavior: \"sql\" })\n )\n );\n this.config.groupBy = Array.isArray(groupBy) ? groupBy : [groupBy];\n } else {\n this.config.groupBy = columns;\n }\n return this;\n }\n orderBy(...columns) {\n if (typeof columns[0] === \"function\") {\n const orderBy = columns[0](\n new Proxy(\n this.config.fields,\n new SelectionProxyHandler({ sqlAliasedBehavior: \"alias\", sqlBehavior: \"sql\" })\n )\n );\n const orderByArray = Array.isArray(orderBy) ? orderBy : [orderBy];\n if (this.config.setOperators.length > 0) {\n this.config.setOperators.at(-1).orderBy = orderByArray;\n } else {\n this.config.orderBy = orderByArray;\n }\n } else {\n const orderByArray = columns;\n if (this.config.setOperators.length > 0) {\n this.config.setOperators.at(-1).orderBy = orderByArray;\n } else {\n this.config.orderBy = orderByArray;\n }\n }\n return this;\n }\n /**\n * Adds a `limit` clause to the query.\n *\n * Calling this method will set the maximum number of rows that will be returned by this query.\n *\n * See docs: {@link https://orm.drizzle.team/docs/select#limit--offset}\n *\n * @param limit the `limit` clause.\n *\n * @example\n *\n * ```ts\n * // Get the first 10 people from this query.\n * await db.select().from(people).limit(10);\n * ```\n */\n limit(limit) {\n if (this.config.setOperators.length > 0) {\n this.config.setOperators.at(-1).limit = limit;\n } else {\n this.config.limit = limit;\n }\n return this;\n }\n /**\n * Adds an `offset` clause to the query.\n *\n * Calling this method will skip a number of rows when returning results from this query.\n *\n * See docs: {@link https://orm.drizzle.team/docs/select#limit--offset}\n *\n * @param offset the `offset` clause.\n *\n * @example\n *\n * ```ts\n * // Get the 10th-20th people from this query.\n * await db.select().from(people).offset(10).limit(10);\n * ```\n */\n offset(offset) {\n if (this.config.setOperators.length > 0) {\n this.config.setOperators.at(-1).offset = offset;\n } else {\n this.config.offset = offset;\n }\n return this;\n }\n /**\n * Adds a `for` clause to the query.\n *\n * Calling this method will specify a lock strength for this query that controls how strictly it acquires exclusive access to the rows being queried.\n *\n * See docs: {@link https://www.postgresql.org/docs/current/sql-select.html#SQL-FOR-UPDATE-SHARE}\n *\n * @param strength the lock strength.\n * @param config the lock configuration.\n */\n for(strength, config = {}) {\n this.config.lockingClause = { strength, config };\n return this;\n }\n /** @internal */\n getSQL() {\n return this.dialect.buildSelectQuery(this.config);\n }\n toSQL() {\n const { typings: _typings, ...rest } = this.dialect.sqlToQuery(this.getSQL());\n return rest;\n }\n as(alias) {\n const usedTables = [];\n usedTables.push(...extractUsedTable(this.config.table));\n if (this.config.joins) {\n for (const it of this.config.joins) usedTables.push(...extractUsedTable(it.table));\n }\n return new Proxy(\n new Subquery(this.getSQL(), this.config.fields, alias, false, [...new Set(usedTables)]),\n new SelectionProxyHandler({ alias, sqlAliasedBehavior: \"alias\", sqlBehavior: \"error\" })\n );\n }\n /** @internal */\n getSelectedFields() {\n return new Proxy(\n this.config.fields,\n new SelectionProxyHandler({ alias: this.tableName, sqlAliasedBehavior: \"alias\", sqlBehavior: \"error\" })\n );\n }\n $dynamic() {\n return this;\n }\n $withCache(config) {\n this.cacheConfig = config === void 0 ? { config: {}, enable: true, autoInvalidate: true } : config === false ? { enable: false } : { enable: true, autoInvalidate: true, ...config };\n return this;\n }\n}\nclass PgSelectBase extends PgSelectQueryBuilderBase {\n static [entityKind] = \"PgSelect\";\n /** @internal */\n _prepare(name) {\n const { session, config, dialect, joinsNotNullableMap, authToken, cacheConfig, usedTables } = this;\n if (!session) {\n throw new Error(\"Cannot execute a query on a query builder. Please use a database instance instead.\");\n }\n const { fields } = config;\n return tracer.startActiveSpan(\"drizzle.prepareQuery\", () => {\n const fieldsList = orderSelectedFields(fields);\n const query = session.prepareQuery(dialect.sqlToQuery(this.getSQL()), fieldsList, name, true, void 0, {\n type: \"select\",\n tables: [...usedTables]\n }, cacheConfig);\n query.joinsNotNullableMap = joinsNotNullableMap;\n return query.setToken(authToken);\n });\n }\n /**\n * Create a prepared statement for this query. This allows\n * the database to remember this query for the given session\n * and call it by name, rather than specifying the full query.\n *\n * {@link https://www.postgresql.org/docs/current/sql-prepare.html | Postgres prepare documentation}\n */\n prepare(name) {\n return this._prepare(name);\n }\n authToken;\n /** @internal */\n setToken(token) {\n this.authToken = token;\n return this;\n }\n execute = (placeholderValues) => {\n return tracer.startActiveSpan(\"drizzle.operation\", () => {\n return this._prepare().execute(placeholderValues, this.authToken);\n });\n };\n}\napplyMixins(PgSelectBase, [QueryPromise]);\nfunction createSetOperator(type, isAll) {\n return (leftSelect, rightSelect, ...restSelects) => {\n const setOperators = [rightSelect, ...restSelects].map((select) => ({\n type,\n isAll,\n rightSelect: select\n }));\n for (const setOperator of setOperators) {\n if (!haveSameKeys(leftSelect.getSelectedFields(), setOperator.rightSelect.getSelectedFields())) {\n throw new Error(\n \"Set operator error (union / intersect / except): selected fields are not the same or are in a different order\"\n );\n }\n }\n return leftSelect.addSetOperators(setOperators);\n };\n}\nconst getPgSetOperators = () => ({\n union,\n unionAll,\n intersect,\n intersectAll,\n except,\n exceptAll\n});\nconst union = createSetOperator(\"union\", false);\nconst unionAll = createSetOperator(\"union\", true);\nconst intersect = createSetOperator(\"intersect\", false);\nconst intersectAll = createSetOperator(\"intersect\", true);\nconst except = createSetOperator(\"except\", false);\nconst exceptAll = createSetOperator(\"except\", true);\nexport {\n PgSelectBase,\n PgSelectBuilder,\n PgSelectQueryBuilderBase,\n except,\n exceptAll,\n intersect,\n intersectAll,\n union,\n unionAll\n};\n//# sourceMappingURL=select.js.map",
79
- "import { entityKind, is } from \"../entity.js\";\nimport { SelectionProxyHandler } from \"../selection-proxy.js\";\nimport { getTableColumns } from \"../utils.js\";\nimport { QueryBuilder } from \"./query-builders/query-builder.js\";\nimport { pgTable } from \"./table.js\";\nimport { PgViewBase } from \"./view-base.js\";\nimport { PgViewConfig } from \"./view-common.js\";\nclass DefaultViewBuilderCore {\n constructor(name, schema) {\n this.name = name;\n this.schema = schema;\n }\n static [entityKind] = \"PgDefaultViewBuilderCore\";\n config = {};\n with(config) {\n this.config.with = config;\n return this;\n }\n}\nclass ViewBuilder extends DefaultViewBuilderCore {\n static [entityKind] = \"PgViewBuilder\";\n as(qb) {\n if (typeof qb === \"function\") {\n qb = qb(new QueryBuilder());\n }\n const selectionProxy = new SelectionProxyHandler({\n alias: this.name,\n sqlBehavior: \"error\",\n sqlAliasedBehavior: \"alias\",\n replaceOriginalName: true\n });\n const aliasedSelection = new Proxy(qb.getSelectedFields(), selectionProxy);\n return new Proxy(\n new PgView({\n pgConfig: this.config,\n config: {\n name: this.name,\n schema: this.schema,\n selectedFields: aliasedSelection,\n query: qb.getSQL().inlineParams()\n }\n }),\n selectionProxy\n );\n }\n}\nclass ManualViewBuilder extends DefaultViewBuilderCore {\n static [entityKind] = \"PgManualViewBuilder\";\n columns;\n constructor(name, columns, schema) {\n super(name, schema);\n this.columns = getTableColumns(pgTable(name, columns));\n }\n existing() {\n return new Proxy(\n new PgView({\n pgConfig: void 0,\n config: {\n name: this.name,\n schema: this.schema,\n selectedFields: this.columns,\n query: void 0\n }\n }),\n new SelectionProxyHandler({\n alias: this.name,\n sqlBehavior: \"error\",\n sqlAliasedBehavior: \"alias\",\n replaceOriginalName: true\n })\n );\n }\n as(query) {\n return new Proxy(\n new PgView({\n pgConfig: this.config,\n config: {\n name: this.name,\n schema: this.schema,\n selectedFields: this.columns,\n query: query.inlineParams()\n }\n }),\n new SelectionProxyHandler({\n alias: this.name,\n sqlBehavior: \"error\",\n sqlAliasedBehavior: \"alias\",\n replaceOriginalName: true\n })\n );\n }\n}\nclass MaterializedViewBuilderCore {\n constructor(name, schema) {\n this.name = name;\n this.schema = schema;\n }\n static [entityKind] = \"PgMaterializedViewBuilderCore\";\n config = {};\n using(using) {\n this.config.using = using;\n return this;\n }\n with(config) {\n this.config.with = config;\n return this;\n }\n tablespace(tablespace) {\n this.config.tablespace = tablespace;\n return this;\n }\n withNoData() {\n this.config.withNoData = true;\n return this;\n }\n}\nclass MaterializedViewBuilder extends MaterializedViewBuilderCore {\n static [entityKind] = \"PgMaterializedViewBuilder\";\n as(qb) {\n if (typeof qb === \"function\") {\n qb = qb(new QueryBuilder());\n }\n const selectionProxy = new SelectionProxyHandler({\n alias: this.name,\n sqlBehavior: \"error\",\n sqlAliasedBehavior: \"alias\",\n replaceOriginalName: true\n });\n const aliasedSelection = new Proxy(qb.getSelectedFields(), selectionProxy);\n return new Proxy(\n new PgMaterializedView({\n pgConfig: {\n with: this.config.with,\n using: this.config.using,\n tablespace: this.config.tablespace,\n withNoData: this.config.withNoData\n },\n config: {\n name: this.name,\n schema: this.schema,\n selectedFields: aliasedSelection,\n query: qb.getSQL().inlineParams()\n }\n }),\n selectionProxy\n );\n }\n}\nclass ManualMaterializedViewBuilder extends MaterializedViewBuilderCore {\n static [entityKind] = \"PgManualMaterializedViewBuilder\";\n columns;\n constructor(name, columns, schema) {\n super(name, schema);\n this.columns = getTableColumns(pgTable(name, columns));\n }\n existing() {\n return new Proxy(\n new PgMaterializedView({\n pgConfig: {\n tablespace: this.config.tablespace,\n using: this.config.using,\n with: this.config.with,\n withNoData: this.config.withNoData\n },\n config: {\n name: this.name,\n schema: this.schema,\n selectedFields: this.columns,\n query: void 0\n }\n }),\n new SelectionProxyHandler({\n alias: this.name,\n sqlBehavior: \"error\",\n sqlAliasedBehavior: \"alias\",\n replaceOriginalName: true\n })\n );\n }\n as(query) {\n return new Proxy(\n new PgMaterializedView({\n pgConfig: {\n tablespace: this.config.tablespace,\n using: this.config.using,\n with: this.config.with,\n withNoData: this.config.withNoData\n },\n config: {\n name: this.name,\n schema: this.schema,\n selectedFields: this.columns,\n query: query.inlineParams()\n }\n }),\n new SelectionProxyHandler({\n alias: this.name,\n sqlBehavior: \"error\",\n sqlAliasedBehavior: \"alias\",\n replaceOriginalName: true\n })\n );\n }\n}\nclass PgView extends PgViewBase {\n static [entityKind] = \"PgView\";\n [PgViewConfig];\n constructor({ pgConfig, config }) {\n super(config);\n if (pgConfig) {\n this[PgViewConfig] = {\n with: pgConfig.with\n };\n }\n }\n}\nconst PgMaterializedViewConfig = Symbol.for(\"drizzle:PgMaterializedViewConfig\");\nclass PgMaterializedView extends PgViewBase {\n static [entityKind] = \"PgMaterializedView\";\n [PgMaterializedViewConfig];\n constructor({ pgConfig, config }) {\n super(config);\n this[PgMaterializedViewConfig] = {\n with: pgConfig?.with,\n using: pgConfig?.using,\n tablespace: pgConfig?.tablespace,\n withNoData: pgConfig?.withNoData\n };\n }\n}\nfunction pgViewWithSchema(name, selection, schema) {\n if (selection) {\n return new ManualViewBuilder(name, selection, schema);\n }\n return new ViewBuilder(name, schema);\n}\nfunction pgMaterializedViewWithSchema(name, selection, schema) {\n if (selection) {\n return new ManualMaterializedViewBuilder(name, selection, schema);\n }\n return new MaterializedViewBuilder(name, schema);\n}\nfunction pgView(name, columns) {\n return pgViewWithSchema(name, columns, void 0);\n}\nfunction pgMaterializedView(name, columns) {\n return pgMaterializedViewWithSchema(name, columns, void 0);\n}\nfunction isPgView(obj) {\n return is(obj, PgView);\n}\nfunction isPgMaterializedView(obj) {\n return is(obj, PgMaterializedView);\n}\nexport {\n DefaultViewBuilderCore,\n ManualMaterializedViewBuilder,\n ManualViewBuilder,\n MaterializedViewBuilder,\n MaterializedViewBuilderCore,\n PgMaterializedView,\n PgMaterializedViewConfig,\n PgView,\n ViewBuilder,\n isPgMaterializedView,\n isPgView,\n pgMaterializedView,\n pgMaterializedViewWithSchema,\n pgView,\n pgViewWithSchema\n};\n//# sourceMappingURL=view.js.map",
80
- "import { is } from \"../entity.js\";\nimport { PgTable } from \"./table.js\";\nimport { SQL } from \"../sql/sql.js\";\nimport { Subquery } from \"../subquery.js\";\nimport { Schema, Table } from \"../table.js\";\nimport { ViewBaseConfig } from \"../view-common.js\";\nimport { CheckBuilder } from \"./checks.js\";\nimport { ForeignKeyBuilder } from \"./foreign-keys.js\";\nimport { IndexBuilder } from \"./indexes.js\";\nimport { PgPolicy } from \"./policies.js\";\nimport { PrimaryKeyBuilder } from \"./primary-keys.js\";\nimport { UniqueConstraintBuilder } from \"./unique-constraint.js\";\nimport { PgViewConfig } from \"./view-common.js\";\nimport { PgMaterializedViewConfig } from \"./view.js\";\nfunction getTableConfig(table) {\n const columns = Object.values(table[Table.Symbol.Columns]);\n const indexes = [];\n const checks = [];\n const primaryKeys = [];\n const foreignKeys = Object.values(table[PgTable.Symbol.InlineForeignKeys]);\n const uniqueConstraints = [];\n const name = table[Table.Symbol.Name];\n const schema = table[Table.Symbol.Schema];\n const policies = [];\n const enableRLS = table[PgTable.Symbol.EnableRLS];\n const extraConfigBuilder = table[PgTable.Symbol.ExtraConfigBuilder];\n if (extraConfigBuilder !== void 0) {\n const extraConfig = extraConfigBuilder(table[Table.Symbol.ExtraConfigColumns]);\n const extraValues = Array.isArray(extraConfig) ? extraConfig.flat(1) : Object.values(extraConfig);\n for (const builder of extraValues) {\n if (is(builder, IndexBuilder)) {\n indexes.push(builder.build(table));\n } else if (is(builder, CheckBuilder)) {\n checks.push(builder.build(table));\n } else if (is(builder, UniqueConstraintBuilder)) {\n uniqueConstraints.push(builder.build(table));\n } else if (is(builder, PrimaryKeyBuilder)) {\n primaryKeys.push(builder.build(table));\n } else if (is(builder, ForeignKeyBuilder)) {\n foreignKeys.push(builder.build(table));\n } else if (is(builder, PgPolicy)) {\n policies.push(builder);\n }\n }\n }\n return {\n columns,\n indexes,\n foreignKeys,\n checks,\n primaryKeys,\n uniqueConstraints,\n name,\n schema,\n policies,\n enableRLS\n };\n}\nfunction extractUsedTable(table) {\n if (is(table, PgTable)) {\n return [table[Schema] ? `${table[Schema]}.${table[Table.Symbol.BaseName]}` : table[Table.Symbol.BaseName]];\n }\n if (is(table, Subquery)) {\n return table._.usedTables ?? [];\n }\n if (is(table, SQL)) {\n return table.usedTables ?? [];\n }\n return [];\n}\nfunction getViewConfig(view) {\n return {\n ...view[ViewBaseConfig],\n ...view[PgViewConfig]\n };\n}\nfunction getMaterializedViewConfig(view) {\n return {\n ...view[ViewBaseConfig],\n ...view[PgMaterializedViewConfig]\n };\n}\nexport {\n extractUsedTable,\n getMaterializedViewConfig,\n getTableConfig,\n getViewConfig\n};\n//# sourceMappingURL=utils.js.map",
81
- "import { entityKind, is } from \"../../entity.js\";\nimport { PgTable } from \"../table.js\";\nimport { QueryPromise } from \"../../query-promise.js\";\nimport { SelectionProxyHandler } from \"../../selection-proxy.js\";\nimport { SQL } from \"../../sql/sql.js\";\nimport { Subquery } from \"../../subquery.js\";\nimport { getTableName, Table } from \"../../table.js\";\nimport {\n getTableLikeName,\n mapUpdateSet,\n orderSelectedFields\n} from \"../../utils.js\";\nimport { ViewBaseConfig } from \"../../view-common.js\";\nimport { extractUsedTable } from \"../utils.js\";\nclass PgUpdateBuilder {\n constructor(table, session, dialect, withList) {\n this.table = table;\n this.session = session;\n this.dialect = dialect;\n this.withList = withList;\n }\n static [entityKind] = \"PgUpdateBuilder\";\n authToken;\n setToken(token) {\n this.authToken = token;\n return this;\n }\n set(values) {\n return new PgUpdateBase(\n this.table,\n mapUpdateSet(this.table, values),\n this.session,\n this.dialect,\n this.withList\n ).setToken(this.authToken);\n }\n}\nclass PgUpdateBase extends QueryPromise {\n constructor(table, set, session, dialect, withList) {\n super();\n this.session = session;\n this.dialect = dialect;\n this.config = { set, table, withList, joins: [] };\n this.tableName = getTableLikeName(table);\n this.joinsNotNullableMap = typeof this.tableName === \"string\" ? { [this.tableName]: true } : {};\n }\n static [entityKind] = \"PgUpdate\";\n config;\n tableName;\n joinsNotNullableMap;\n cacheConfig;\n from(source) {\n const src = source;\n const tableName = getTableLikeName(src);\n if (typeof tableName === \"string\") {\n this.joinsNotNullableMap[tableName] = true;\n }\n this.config.from = src;\n return this;\n }\n getTableLikeFields(table) {\n if (is(table, PgTable)) {\n return table[Table.Symbol.Columns];\n } else if (is(table, Subquery)) {\n return table._.selectedFields;\n }\n return table[ViewBaseConfig].selectedFields;\n }\n createJoin(joinType) {\n return (table, on) => {\n const tableName = getTableLikeName(table);\n if (typeof tableName === \"string\" && this.config.joins.some((join) => join.alias === tableName)) {\n throw new Error(`Alias \"${tableName}\" is already used in this query`);\n }\n if (typeof on === \"function\") {\n const from = this.config.from && !is(this.config.from, SQL) ? this.getTableLikeFields(this.config.from) : void 0;\n on = on(\n new Proxy(\n this.config.table[Table.Symbol.Columns],\n new SelectionProxyHandler({ sqlAliasedBehavior: \"sql\", sqlBehavior: \"sql\" })\n ),\n from && new Proxy(\n from,\n new SelectionProxyHandler({ sqlAliasedBehavior: \"sql\", sqlBehavior: \"sql\" })\n )\n );\n }\n this.config.joins.push({ on, table, joinType, alias: tableName });\n if (typeof tableName === \"string\") {\n switch (joinType) {\n case \"left\": {\n this.joinsNotNullableMap[tableName] = false;\n break;\n }\n case \"right\": {\n this.joinsNotNullableMap = Object.fromEntries(\n Object.entries(this.joinsNotNullableMap).map(([key]) => [key, false])\n );\n this.joinsNotNullableMap[tableName] = true;\n break;\n }\n case \"inner\": {\n this.joinsNotNullableMap[tableName] = true;\n break;\n }\n case \"full\": {\n this.joinsNotNullableMap = Object.fromEntries(\n Object.entries(this.joinsNotNullableMap).map(([key]) => [key, false])\n );\n this.joinsNotNullableMap[tableName] = false;\n break;\n }\n }\n }\n return this;\n };\n }\n leftJoin = this.createJoin(\"left\");\n rightJoin = this.createJoin(\"right\");\n innerJoin = this.createJoin(\"inner\");\n fullJoin = this.createJoin(\"full\");\n /**\n * Adds a 'where' clause to the query.\n *\n * Calling this method will update only those rows that fulfill a specified condition.\n *\n * See docs: {@link https://orm.drizzle.team/docs/update}\n *\n * @param where the 'where' clause.\n *\n * @example\n * You can use conditional operators and `sql function` to filter the rows to be updated.\n *\n * ```ts\n * // Update all cars with green color\n * await db.update(cars).set({ color: 'red' })\n * .where(eq(cars.color, 'green'));\n * // or\n * await db.update(cars).set({ color: 'red' })\n * .where(sql`${cars.color} = 'green'`)\n * ```\n *\n * You can logically combine conditional operators with `and()` and `or()` operators:\n *\n * ```ts\n * // Update all BMW cars with a green color\n * await db.update(cars).set({ color: 'red' })\n * .where(and(eq(cars.color, 'green'), eq(cars.brand, 'BMW')));\n *\n * // Update all cars with the green or blue color\n * await db.update(cars).set({ color: 'red' })\n * .where(or(eq(cars.color, 'green'), eq(cars.color, 'blue')));\n * ```\n */\n where(where) {\n this.config.where = where;\n return this;\n }\n returning(fields) {\n if (!fields) {\n fields = Object.assign({}, this.config.table[Table.Symbol.Columns]);\n if (this.config.from) {\n const tableName = getTableLikeName(this.config.from);\n if (typeof tableName === \"string\" && this.config.from && !is(this.config.from, SQL)) {\n const fromFields = this.getTableLikeFields(this.config.from);\n fields[tableName] = fromFields;\n }\n for (const join of this.config.joins) {\n const tableName2 = getTableLikeName(join.table);\n if (typeof tableName2 === \"string\" && !is(join.table, SQL)) {\n const fromFields = this.getTableLikeFields(join.table);\n fields[tableName2] = fromFields;\n }\n }\n }\n }\n this.config.returningFields = fields;\n this.config.returning = orderSelectedFields(fields);\n return this;\n }\n /** @internal */\n getSQL() {\n return this.dialect.buildUpdateQuery(this.config);\n }\n toSQL() {\n const { typings: _typings, ...rest } = this.dialect.sqlToQuery(this.getSQL());\n return rest;\n }\n /** @internal */\n _prepare(name) {\n const query = this.session.prepareQuery(this.dialect.sqlToQuery(this.getSQL()), this.config.returning, name, true, void 0, {\n type: \"insert\",\n tables: extractUsedTable(this.config.table)\n }, this.cacheConfig);\n query.joinsNotNullableMap = this.joinsNotNullableMap;\n return query;\n }\n prepare(name) {\n return this._prepare(name);\n }\n authToken;\n /** @internal */\n setToken(token) {\n this.authToken = token;\n return this;\n }\n execute = (placeholderValues) => {\n return this._prepare().execute(placeholderValues, this.authToken);\n };\n /** @internal */\n getSelectedFields() {\n return this.config.returningFields ? new Proxy(\n this.config.returningFields,\n new SelectionProxyHandler({\n alias: getTableName(this.config.table),\n sqlAliasedBehavior: \"alias\",\n sqlBehavior: \"error\"\n })\n ) : void 0;\n }\n $dynamic() {\n return this;\n }\n}\nexport {\n PgUpdateBase,\n PgUpdateBuilder\n};\n//# sourceMappingURL=update.js.map",
82
- "export * from \"./delete.js\";\nexport * from \"./insert.js\";\nexport * from \"./query-builder.js\";\nexport * from \"./refresh-materialized-view.js\";\nexport * from \"./select.js\";\nexport * from \"./select.types.js\";\nexport * from \"./update.js\";\n//# sourceMappingURL=index.js.map",
83
- "export * from \"./array.js\";\n//# sourceMappingURL=index.js.map",
84
- "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",
85
- "import { relations } from \"drizzle-orm\";\nimport {\n boolean,\n index,\n jsonb,\n pgTable,\n text,\n timestamp,\n uniqueIndex,\n uuid,\n} from \"drizzle-orm/pg-core\";\n\nexport const goalsTable = pgTable(\n \"goals\",\n {\n id: uuid(\"id\").notNull().primaryKey(),\n agentId: uuid(\"agent_id\").notNull(), // The agent managing this goal\n ownerType: text(\"owner_type\").notNull(), // 'agent' or 'entity'\n ownerId: uuid(\"owner_id\").notNull(), // Either agentId or entityId\n name: text(\"name\").notNull(),\n description: text(\"description\"),\n isCompleted: boolean(\"is_completed\").default(false),\n completedAt: timestamp(\"completed_at\"),\n createdAt: timestamp(\"created_at\").defaultNow().notNull(),\n updatedAt: timestamp(\"updated_at\").defaultNow().notNull(),\n metadata: jsonb(\"metadata\").$type<Record<string, unknown>>().default({}).notNull(),\n },\n (table) => ({\n agentIdIndex: index(\"idx_goals_agent\").on(table.agentId),\n ownerTypeIndex: index(\"idx_goals_owner_type\").on(table.ownerType),\n ownerIdIndex: index(\"idx_goals_owner_id\").on(table.ownerId),\n completedIndex: index(\"idx_goals_completed\").on(table.isCompleted),\n createdAtIndex: index(\"idx_goals_created_at\").on(table.createdAt),\n })\n);\n\nexport const goalTagsTable = pgTable(\n \"goal_tags\",\n {\n id: uuid(\"id\").notNull().primaryKey(),\n goalId: uuid(\"goal_id\")\n .references(() => goalsTable.id, {\n onDelete: \"cascade\",\n })\n .notNull(),\n tag: text(\"tag\").notNull(),\n createdAt: timestamp(\"created_at\").defaultNow().notNull(),\n },\n (table) => ({\n goalIdIndex: index(\"idx_goal_tags_goal\").on(table.goalId),\n tagIndex: index(\"idx_goal_tags_tag\").on(table.tag),\n uniqueGoalTag: uniqueIndex(\"unique_goal_tag\").on(table.goalId, table.tag),\n })\n);\n\nexport const goalsRelations = relations(goalsTable, ({ many }) => ({\n tags: many(goalTagsTable),\n}));\n\nexport const goalTagsRelations = relations(goalTagsTable, ({ one }) => ({\n goal: one(goalsTable, {\n fields: [goalTagsTable.goalId],\n references: [goalsTable.id],\n }),\n}));\n\nexport const goalSchema = {\n goalsTable,\n goalTagsTable,\n tables: {\n goals: goalsTable,\n goalTags: goalTagsTable,\n },\n};\n\nexport default goalSchema;\n",
86
- "import { asUUID, type IAgentRuntime, logger, Service, type UUID } from \"@elizaos/core\";\nimport { and, asc, eq, inArray, type SQL } from \"drizzle-orm\";\nimport { v4 as uuidv4 } from \"uuid\";\nimport { goalsTable, goalTagsTable } from \"../schema.js\";\n\ntype DrizzleTable = unknown;\ntype DrizzleCondition = unknown;\ntype DrizzleValues = Record<string, unknown>;\ntype DrizzleFields = Record<string, unknown>;\ntype DrizzleResult = Record<string, unknown>;\ntype OrderByArg = unknown;\n\ntype DrizzleDB = {\n insert: (table: DrizzleTable) => {\n values: (values: DrizzleValues | DrizzleValues[]) => {\n returning: () => Promise<DrizzleResult[]>;\n onConflictDoNothing: () => { execute: () => Promise<void> };\n };\n };\n select: (fields?: DrizzleFields) => {\n from: (table: DrizzleTable) => {\n where: (condition?: DrizzleCondition) => {\n orderBy: (...args: OrderByArg[]) => Promise<DrizzleResult[]>;\n } & Promise<DrizzleResult[]>;\n };\n };\n update: (table: DrizzleTable) => {\n set: (values: DrizzleValues) => {\n where: (condition: DrizzleCondition) => Promise<DrizzleResult>;\n };\n };\n delete: (table: DrizzleTable) => {\n where: (condition: DrizzleCondition) => Promise<DrizzleResult>;\n };\n};\n\n/**\n * Goal data structure from database\n */\nexport interface GoalData {\n id: UUID;\n agentId: UUID;\n ownerType: \"agent\" | \"entity\";\n ownerId: UUID;\n name: string;\n description?: string | null;\n isCompleted: boolean;\n completedAt?: Date | null;\n createdAt: Date;\n updatedAt: Date;\n metadata: Record<string, unknown>;\n tags?: string[];\n}\n\nexport class GoalDataService {\n private runtime: IAgentRuntime;\n\n constructor(runtime: IAgentRuntime) {\n this.runtime = runtime;\n }\n\n /**\n * Create a new goal\n */\n async createGoal(params: {\n agentId: UUID;\n ownerType: \"agent\" | \"entity\";\n ownerId: UUID;\n name: string;\n description?: string;\n metadata?: Record<string, unknown>;\n tags?: string[];\n }): Promise<UUID | null> {\n try {\n const db = this.runtime.db as DrizzleDB | undefined;\n if (!db) throw new Error(\"Database not available\");\n\n const goalId = asUUID(uuidv4());\n const values: DrizzleValues = {\n id: goalId,\n agentId: params.agentId,\n ownerType: params.ownerType,\n ownerId: params.ownerId,\n name: params.name,\n metadata: params.metadata || {},\n };\n\n if (params.description !== undefined) {\n values.description = params.description;\n }\n\n const [goal] = await db.insert(goalsTable).values(values).returning();\n\n if (!goal) return null;\n\n if (params.tags && params.tags.length > 0) {\n const tagInserts = params.tags.map((tag) => ({\n id: asUUID(uuidv4()),\n goalId,\n tag,\n }));\n\n await db.insert(goalTagsTable).values(tagInserts);\n }\n\n return goalId;\n } catch (error) {\n logger.error(\"Error creating goal:\", error instanceof Error ? error.message : String(error));\n throw error;\n }\n }\n\n async getGoals(filters?: {\n ownerType?: \"agent\" | \"entity\";\n ownerId?: UUID;\n isCompleted?: boolean;\n tags?: string[];\n }): Promise<GoalData[]> {\n try {\n const db = this.runtime.db as DrizzleDB | undefined;\n if (!db) throw new Error(\"Database not available\");\n\n const conditions: SQL[] = [];\n if (filters?.ownerType) {\n conditions.push(eq(goalsTable.ownerType, filters.ownerType));\n }\n if (filters?.ownerId) {\n conditions.push(eq(goalsTable.ownerId, filters.ownerId));\n }\n if (filters?.isCompleted !== undefined) {\n conditions.push(eq(goalsTable.isCompleted, filters.isCompleted));\n }\n\n const goals = await db\n .select()\n .from(goalsTable)\n .where(conditions.length > 0 ? and(...conditions) : undefined)\n .orderBy(asc(goalsTable.createdAt));\n\n // Get tags for all goals\n const goalIds = goals.map((goal) => asUUID(goal.id as string));\n if (goalIds.length === 0) return [];\n\n const tags = await db\n .select()\n .from(goalTagsTable)\n .where(\n goalIds.length === 1\n ? eq(goalTagsTable.goalId, goalIds[0])\n : inArray(goalTagsTable.goalId, goalIds)\n );\n\n const tagsByGoal = tags.reduce(\n (acc, tag) => {\n const tagGoalId = asUUID(tag.goalId as string);\n if (!acc[tagGoalId]) acc[tagGoalId] = [];\n const goalTags = acc[tagGoalId] as string[];\n goalTags.push(tag.tag as string);\n return acc;\n },\n {} as Record<UUID, string[]>\n );\n\n // Filter by tags if specified\n let filteredGoals = goals;\n if (filters?.tags && filters.tags.length > 0) {\n filteredGoals = goals.filter((goal) => {\n const goalId = asUUID(goal.id as string);\n const goalTags = (tagsByGoal[goalId] || []) as string[];\n return filters.tags?.some((tag) => goalTags.includes(tag));\n });\n }\n\n return filteredGoals.map((goal) => {\n const goalId = asUUID(goal.id as string);\n return {\n ...goal,\n id: goalId,\n agentId: asUUID(goal.agentId as string),\n ownerId: asUUID(goal.ownerId as string),\n tags: tagsByGoal[goalId] || [],\n createdAt: new Date(goal.createdAt as string | number | Date),\n updatedAt: new Date(goal.updatedAt as string | number | Date),\n completedAt: goal.completedAt\n ? new Date(goal.completedAt as string | number | Date)\n : null,\n } as GoalData;\n });\n } catch (error) {\n logger.error(\"Error getting goals:\", error instanceof Error ? error.message : String(error));\n throw error;\n }\n }\n\n async getGoal(goalId: UUID): Promise<GoalData | null> {\n try {\n const db = this.runtime.db as DrizzleDB | undefined;\n if (!db) throw new Error(\"Database not available\");\n\n const [goal] = await db.select().from(goalsTable).where(eq(goalsTable.id, goalId));\n\n if (!goal) return null;\n\n const tags = await db.select().from(goalTagsTable).where(eq(goalTagsTable.goalId, goalId));\n\n return {\n ...goal,\n id: asUUID(goal.id as string),\n agentId: asUUID(goal.agentId as string),\n ownerId: asUUID(goal.ownerId as string),\n tags: tags.map((t) => t.tag as string),\n createdAt: new Date(goal.createdAt as string | number | Date),\n updatedAt: new Date(goal.updatedAt as string | number | Date),\n completedAt: goal.completedAt ? new Date(goal.completedAt as string | number | Date) : null,\n } as GoalData;\n } catch (error) {\n logger.error(\"Error getting goal:\", error instanceof Error ? error.message : String(error));\n throw error;\n }\n }\n\n async updateGoal(\n goalId: UUID,\n updates: {\n name?: string;\n description?: string;\n isCompleted?: boolean;\n completedAt?: Date;\n metadata?: Record<string, unknown>;\n tags?: string[];\n }\n ): Promise<boolean> {\n try {\n const db = this.runtime.db as DrizzleDB | undefined;\n if (!db) throw new Error(\"Database not available\");\n\n const fieldsToUpdate: DrizzleValues = {\n updatedAt: new Date(),\n };\n\n if (updates.name !== undefined) fieldsToUpdate.name = updates.name;\n if (updates.description !== undefined) fieldsToUpdate.description = updates.description;\n if (updates.isCompleted !== undefined) fieldsToUpdate.isCompleted = updates.isCompleted;\n if (updates.completedAt !== undefined) fieldsToUpdate.completedAt = updates.completedAt;\n if (updates.metadata !== undefined) fieldsToUpdate.metadata = updates.metadata;\n\n await db.update(goalsTable).set(fieldsToUpdate).where(eq(goalsTable.id, goalId));\n\n if (updates.tags !== undefined) {\n await db.delete(goalTagsTable).where(eq(goalTagsTable.goalId, goalId));\n\n if (updates.tags.length > 0) {\n const tagInserts = updates.tags.map((tag) => ({\n id: asUUID(uuidv4()),\n goalId,\n tag,\n }));\n\n await db.insert(goalTagsTable).values(tagInserts);\n }\n }\n\n return true;\n } catch (error) {\n logger.error(\"Error updating goal:\", error instanceof Error ? error.message : String(error));\n throw error;\n }\n }\n\n async deleteGoal(goalId: UUID): Promise<boolean> {\n try {\n const db = this.runtime.db as DrizzleDB | undefined;\n if (!db) throw new Error(\"Database not available\");\n\n await db.delete(goalsTable).where(eq(goalsTable.id, goalId));\n return true;\n } catch (error) {\n logger.error(\"Error deleting goal:\", error instanceof Error ? error.message : String(error));\n throw error;\n }\n }\n\n async getUncompletedGoals(ownerType?: \"agent\" | \"entity\", ownerId?: UUID): Promise<GoalData[]> {\n try {\n const conditions = [eq(goalsTable.isCompleted, false)];\n\n if (ownerType) {\n conditions.push(eq(goalsTable.ownerType, ownerType));\n }\n if (ownerId) {\n conditions.push(eq(goalsTable.ownerId, ownerId));\n }\n\n return this.getGoals({\n isCompleted: false,\n ownerType,\n ownerId,\n });\n } catch (error) {\n logger.error(\n \"Error getting uncompleted goals:\",\n error instanceof Error ? error.message : String(error)\n );\n throw error;\n }\n }\n\n async getCompletedGoals(ownerType?: \"agent\" | \"entity\", ownerId?: UUID): Promise<GoalData[]> {\n try {\n return this.getGoals({\n isCompleted: true,\n ownerType,\n ownerId,\n });\n } catch (error) {\n logger.error(\n \"Error getting completed goals:\",\n error instanceof Error ? error.message : String(error)\n );\n throw error;\n }\n }\n\n async countGoals(\n ownerType: \"agent\" | \"entity\",\n ownerId: UUID,\n isCompleted?: boolean\n ): Promise<number> {\n try {\n const goals = await this.getGoals({\n ownerType,\n ownerId,\n isCompleted,\n });\n return goals.length;\n } catch (error) {\n logger.error(\"Error counting goals:\", error instanceof Error ? error.message : String(error));\n throw error;\n }\n }\n\n async getAllGoalsForOwner(ownerType: \"agent\" | \"entity\", ownerId: UUID): Promise<GoalData[]> {\n try {\n return this.getGoals({\n ownerType,\n ownerId,\n });\n } catch (error) {\n logger.error(\n \"Error getting all goals for owner:\",\n error instanceof Error ? error.message : String(error)\n );\n throw error;\n }\n }\n}\n\n/**\n * Factory function to create a GoalDataService\n */\nexport function createGoalDataService(runtime: IAgentRuntime): GoalDataService {\n if (!runtime.db) {\n throw new Error(\"Database instance not available on runtime\");\n }\n return new GoalDataService(runtime);\n}\n\nexport class GoalDataServiceWrapper extends Service {\n static serviceName = \"goalDataService\";\n static serviceType = \"GOAL_DATA\" as const;\n\n private goalDataService: GoalDataService | null = null;\n\n capabilityDescription = \"Manages goal data storage and retrieval\";\n\n async stop(): Promise<void> {\n this.goalDataService = null;\n }\n\n static async start(runtime: IAgentRuntime): Promise<GoalDataServiceWrapper> {\n const service = new GoalDataServiceWrapper();\n\n if (!runtime.db) {\n logger.warn(\"Database not available, GoalDataService will be limited\");\n } else {\n service.goalDataService = new GoalDataService(runtime);\n }\n\n return service;\n }\n\n getDataService(): GoalDataService | null {\n return this.goalDataService;\n }\n}\n",
87
- "import type { Plugin } from \"@elizaos/core\";\nimport { type IAgentRuntime, logger } from \"@elizaos/core\";\nimport { cancelGoalAction } from \"./actions/cancelGoal.js\";\nimport { completeGoalAction } from \"./actions/completeGoal.js\";\nimport { confirmGoalAction } from \"./actions/confirmGoal.js\";\nimport { createGoalAction } from \"./actions/createGoal.js\";\nimport { updateGoalAction } from \"./actions/updateGoal.js\";\nimport { routes } from \"./apis.js\";\nimport { goalsProvider } from \"./providers/goals.js\";\nimport { goalSchema } from \"./schema.js\";\nimport { GoalDataServiceWrapper } from \"./services/goalDataService.js\";\nimport { GoalsPluginE2ETestSuite } from \"./tests.js\";\n\nexport const GoalsPlugin: Plugin = {\n name: \"goals\",\n description: \"Provides goal management functionality for tracking and achieving objectives.\",\n providers: [goalsProvider],\n testDependencies: [\"@elizaos/plugin-sql\"],\n actions: [\n createGoalAction,\n completeGoalAction,\n confirmGoalAction,\n updateGoalAction,\n cancelGoalAction,\n ],\n services: [GoalDataServiceWrapper],\n routes,\n schema: goalSchema,\n tests: [GoalsPluginE2ETestSuite],\n\n async init(_config: Record<string, string>, runtime: IAgentRuntime): Promise<void> {\n if (runtime.db) {\n logger.info(\"Database available, GoalsPlugin ready for operation\");\n } else {\n logger.warn(\"No database instance available, operations will be limited\");\n }\n logger.info(\"GoalsPlugin initialized successfully\");\n },\n};\n\nexport default GoalsPlugin;\n\nexport { goalSchema } from \"./schema.js\";\nexport type { GoalData } from \"./services/goalDataService.js\";\nexport {\n createGoalDataService,\n GoalDataServiceWrapper,\n} from \"./services/goalDataService.js\";\n",
88
- "import {\n type Action,\n type ActionExample,\n type ActionResult,\n composePrompt,\n type Entity,\n formatMessages,\n type HandlerCallback,\n type HandlerOptions,\n type IAgentRuntime,\n logger,\n type Memory,\n ModelType,\n parseKeyValueXml,\n type State,\n} from \"@elizaos/core\";\nimport { extractCancellationTemplate } from \"../generated/prompts/typescript/prompts.js\";\nimport { requireActionSpec } from \"../generated/specs/spec-helpers\";\nimport { createGoalDataService, type GoalData } from \"../services/goalDataService.js\";\n\ninterface TaskCancellation {\n taskId: string;\n taskName: string;\n isFound: boolean;\n}\n\nasync function extractTaskCancellation(\n runtime: IAgentRuntime,\n message: Memory,\n availableGoals: GoalData[],\n state: State\n): Promise<TaskCancellation> {\n try {\n const tasksText = availableGoals\n .map((task) => {\n return `ID: ${task.id}\\nName: ${task.name}\\nDescription: ${task.description || task.name}\\nTags: ${task.tags?.join(\", \") || \"none\"}\\n`;\n })\n .join(\"\\n---\\n\");\n\n const messageHistory = formatMessages({\n messages: (state.data?.messages as Memory[]) || [],\n entities: (state.data?.entities as Entity[]) || [],\n });\n\n const prompt = composePrompt({\n state: {\n text: message.content.text || \"\",\n availableTasks: tasksText,\n messageHistory: messageHistory,\n },\n template: extractCancellationTemplate,\n });\n\n const result = await runtime.useModel(ModelType.TEXT_SMALL, {\n prompt,\n stopSequences: [],\n });\n\n const parsedResult = parseKeyValueXml(result) as TaskCancellation | null;\n\n logger.debug({ parsedResult }, \"Parsed XML Result\");\n\n if (!parsedResult || typeof parsedResult.isFound === \"undefined\") {\n logger.error(\"Failed to parse valid task cancellation information from XML\");\n return { taskId: \"\", taskName: \"\", isFound: false };\n }\n\n const finalResult: TaskCancellation = {\n taskId: parsedResult.taskId === \"null\" ? \"\" : String(parsedResult.taskId || \"\"),\n taskName: parsedResult.taskName === \"null\" ? \"\" : String(parsedResult.taskName || \"\"),\n isFound: String(parsedResult.isFound) === \"true\",\n };\n\n return finalResult;\n } catch (error) {\n logger.error(\"Error extracting task cancellation information:\", error);\n return { taskId: \"\", taskName: \"\", isFound: false };\n }\n}\n\nconst spec = requireActionSpec(\"CANCEL_GOAL\");\n\nexport const cancelGoalAction: Action = {\n name: spec.name,\n similes: spec.similes ? [...spec.similes] : [],\n description: spec.description,\n\n validate: async (runtime: any, message: any, state?: any, options?: any): Promise<boolean> => {\n const __avTextRaw = typeof message?.content?.text === \"string\" ? message.content.text : \"\";\n const __avText = __avTextRaw.toLowerCase();\n const __avKeywords = [\"cancel\", \"goal\"];\n const __avKeywordOk =\n __avKeywords.length > 0 && __avKeywords.some((kw) => kw.length > 0 && __avText.includes(kw));\n const __avRegex = /\\b(?:cancel|goal)\\b/i;\n const __avRegexOk = __avRegex.test(__avText);\n const __avSource = String(message?.content?.source ?? message?.source ?? \"\");\n const __avExpectedSource = \"\";\n const __avSourceOk = __avExpectedSource\n ? __avSource === __avExpectedSource\n : Boolean(__avSource || state || runtime?.agentId || runtime?.getService);\n const __avOptions = options && typeof options === \"object\" ? options : {};\n const __avInputOk =\n __avText.trim().length > 0 ||\n Object.keys(__avOptions as Record<string, unknown>).length > 0 ||\n Boolean(message?.content && typeof message.content === \"object\");\n\n if (!(__avKeywordOk && __avRegexOk && __avSourceOk && __avInputOk)) {\n return false;\n }\n\n const __avLegacyValidate = async (\n runtime: IAgentRuntime,\n message: Memory\n ): Promise<boolean> => {\n try {\n if (!message.roomId) {\n return false;\n }\n const dataService = createGoalDataService(runtime);\n const goals = await dataService.getGoals({\n ownerType: \"entity\",\n ownerId: message.entityId,\n isCompleted: false,\n });\n return goals.length > 0;\n } catch (error) {\n logger.error(\"Error validating CANCEL_GOAL action:\", error);\n return false;\n }\n };\n try {\n return Boolean(await (__avLegacyValidate as any)(runtime, message, state, options));\n } catch {\n return false;\n }\n },\n\n handler: async (\n runtime: IAgentRuntime,\n message: Memory,\n state: State | undefined,\n _options?: HandlerOptions,\n callback?: HandlerCallback\n ): Promise<ActionResult> => {\n try {\n if (!state) {\n if (callback) {\n await callback({\n text: \"Unable to process request without state context.\",\n actions: [\"CANCEL_GOAL_ERROR\"],\n source: message.content.source,\n });\n }\n return;\n }\n if (!message.roomId) {\n if (callback) {\n await callback({\n text: \"I cannot manage goals without a room context.\",\n actions: [\"CANCEL_GOAL_ERROR\"],\n source: message.content.source,\n });\n }\n return;\n }\n const dataService = createGoalDataService(runtime);\n const activeGoals = await dataService.getGoals({\n ownerType: \"entity\",\n ownerId: message.entityId,\n isCompleted: false,\n });\n\n if (activeGoals.length === 0) {\n if (callback) {\n await callback({\n text: \"You don't have any active goals to cancel.\",\n actions: [\"CANCEL_GOAL_NONE\"],\n source: message.content.source,\n });\n }\n return;\n }\n\n const cancelInfo = await extractTaskCancellation(runtime, message, activeGoals, state);\n\n if (!cancelInfo.isFound || !cancelInfo.taskId) {\n const goalsList = activeGoals.map((goal, index) => `${index + 1}. ${goal.name}`).join(\"\\n\");\n\n if (callback) {\n await callback({\n text: `I couldn't determine which goal you want to cancel. Here are your active goals:\\n\\n${goalsList}\\n\\nPlease specify which one you'd like to cancel.`,\n actions: [\"CANCEL_GOAL_NOT_FOUND\"],\n source: message.content.source,\n });\n }\n return;\n }\n\n const goalToCancel = activeGoals.find((g) => g.id === cancelInfo.taskId);\n\n if (!goalToCancel) {\n if (callback) {\n await callback({\n text: `I couldn't find a goal matching \"${cancelInfo.taskName}\". Please try again.`,\n actions: [\"CANCEL_GOAL_NOT_FOUND\"],\n source: message.content.source,\n });\n }\n return;\n }\n\n const success = await dataService.deleteGoal(goalToCancel.id);\n\n if (success) {\n if (callback) {\n await callback({\n text: `✅ Cancelled goal: \"${goalToCancel.name}\"`,\n actions: [\"CANCEL_GOAL_SUCCESS\"],\n source: message.content.source,\n });\n }\n } else {\n throw new Error(\"Failed to delete goal\");\n }\n return { success: true, text: \"Goal cancelled\" };\n } catch (error) {\n logger.error(\"Error in cancelGoal handler:\", error);\n if (callback) {\n await callback({\n text: \"I encountered an error while trying to cancel your task. Please try again.\",\n actions: [\"CANCEL_GOAL_ERROR\"],\n source: message.content.source,\n });\n }\n return {\n success: false,\n error: error instanceof Error ? error.message : \"Unknown error\",\n };\n }\n },\n\n examples: (spec.examples ?? []) as ActionExample[][],\n};\n\nexport default cancelGoalAction;\n",
89
- "/**\n * Auto-generated prompt templates\n * DO NOT EDIT - Generated from ../../../../prompts/*.txt\n *\n * These prompts use Handlebars-style template syntax:\n * - {{variableName}} for simple substitution\n * - {{#each items}}...{{/each}} for iteration\n * - {{#if condition}}...{{/if}} for conditionals\n */\n\nexport const checkSimilarityTemplate = `# Task: Check Goal Similarity\n\n## New Goal\nName: {{newGoalName}}\nDescription: {{newGoalDescription}}\n\n## Existing Goals\n{{existingGoals}}\n\n## Instructions\nDetermine if the new goal is similar to any existing goals.\nConsider goals similar if they have the same objective, even if worded differently.\n\nReturn an XML object:\n<response>\n <hasSimilar>true or false</hasSimilar>\n <similarGoalName>Name of the similar goal if found</similarGoalName>\n <confidence>0-100 indicating confidence in similarity</confidence>\n</response>\n\n## Example\nNew Goal: \"Get better at public speaking\"\nExisting Goal: \"Improve presentation skills\"\nThese are similar (confidence: 85)`;\n\nexport const CHECK_SIMILARITY_TEMPLATE = checkSimilarityTemplate;\n\nexport const extractCancellationTemplate = `# Task: Extract Task Cancellation Information\n\n## User Message\n{{text}}\n\n## Message History\n{{messageHistory}}\n\n## Available Tasks\n{{availableTasks}}\n\n## Instructions\nParse the user's message to identify which task they want to cancel or delete.\nMatch against the list of available tasks by name or description.\nIf multiple tasks have similar names, choose the closest match.\n\nReturn an XML object with:\n<response>\n <taskId>ID of the task being cancelled, or 'null' if not found</taskId>\n <taskName>Name of the task being cancelled, or 'null' if not found</taskName>\n <isFound>'true' or 'false' indicating if a matching task was found</isFound>\n</response>\n\n## Example Output Format\n<response>\n <taskId>123e4567-e89b-12d3-a456-426614174000</taskId>\n <taskName>Finish report</taskName>\n <isFound>true</isFound>\n</response>\n\nIf no matching task was found:\n<response>\n <taskId>null</taskId>\n <taskName>null</taskName>\n <isFound>false</isFound>\n</response>`;\n\nexport const EXTRACT_CANCELLATION_TEMPLATE = extractCancellationTemplate;\n\nexport const extractConfirmationTemplate = `# Task: Extract Confirmation Intent\n\n## User Message\n{{text}}\n\n## Message History\n{{messageHistory}}\n\n## Pending Task Details\n{{pendingTask}}\n\n## Instructions\nDetermine if the user is confirming, rejecting, or modifying the pending task creation.\nLook for:\n- Affirmative responses (yes, confirm, ok, do it, go ahead, etc.)\n- Negative responses (no, cancel, nevermind, stop, etc.)\n- Modification requests (change X to Y, make it priority 1, etc.)\n\nReturn an XML object with:\n<response>\n <isConfirmation>true/false - whether this is a response to the pending task</isConfirmation>\n <shouldProceed>true/false - whether to create the task</shouldProceed>\n <modifications>Any requested changes to the task, or 'none'</modifications>\n</response>\n\n## Example Output\n<response>\n <isConfirmation>true</isConfirmation>\n <shouldProceed>true</shouldProceed>\n <modifications>none</modifications>\n</response>`;\n\nexport const EXTRACT_CONFIRMATION_TEMPLATE = extractConfirmationTemplate;\n\nexport const extractGoalSelectionTemplate = `# Task: Extract Goal Selection Information\n\n## User Message\n{{text}}\n\n## Available Goals\n{{availableGoals}}\n\n## Instructions\nParse the user's message to identify which goal they want to update or modify.\nMatch against the list of available goals by name or description.\nIf multiple goals have similar names, choose the closest match.\n\nReturn an XML object with:\n<response>\n <goalId>ID of the goal being updated, or 'null' if not found</goalId>\n <goalName>Name of the goal being updated, or 'null' if not found</goalName>\n <isFound>'true' or 'false' indicating if a matching goal was found</isFound>\n</response>\n\n## Example Output Format\n<response>\n <goalId>123e4567-e89b-12d3-a456-426614174000</goalId>\n <goalName>Learn French fluently</goalName>\n <isFound>true</isFound>\n</response>\n\nIf no matching goal was found:\n<response>\n <goalId>null</goalId>\n <goalName>null</goalName>\n <isFound>false</isFound>\n</response>`;\n\nexport const EXTRACT_GOAL_SELECTION_TEMPLATE = extractGoalSelectionTemplate;\n\nexport const extractGoalTemplate = `# Task: Extract Goal Information\n\n## User Message\n{{text}}\n\n## Message History\n{{messageHistory}}\n\n## Instructions\nParse the user's message to extract information for creating a new goal.\nDetermine if this goal is for the agent itself or for tracking a user's goal.\n\nGoals should be long-term achievable objectives, not short-term tasks.\n\nReturn an XML object with these fields:\n<response>\n <name>A clear, concise name for the goal</name>\n <description>Optional detailed description</description>\n <ownerType>Either \"agent\" (for agent's own goals) or \"entity\" (for user's goals)</ownerType>\n</response>\n\nIf the message doesn't clearly indicate a goal to create, return empty response.\n\n## Example Output Format\n<response>\n <name>Learn Spanish fluently</name>\n <description>Achieve conversational fluency in Spanish within 6 months</description>\n <ownerType>entity</ownerType>\n</response>`;\n\nexport const EXTRACT_GOAL_TEMPLATE = extractGoalTemplate;\n\nexport const extractGoalUpdateTemplate = `# Task: Extract Goal Update Information\n\n## User Message\n{{text}}\n\n## Current Goal Details\n{{goalDetails}}\n\n## Instructions\nParse the user's message to determine what changes they want to make to the goal.\nOnly name and description can be updated.\n\nReturn an XML object with these potential fields (only include fields that should be changed):\n<response>\n <name>New name for the goal</name>\n <description>New description for the goal</description>\n</response>\n\n## Example Output Format\n<response>\n <name>Learn Spanish fluently</name>\n <description>Achieve conversational fluency in Spanish within 12 months</description>\n</response>`;\n\nexport const EXTRACT_GOAL_UPDATE_TEMPLATE = extractGoalUpdateTemplate;\n",
90
- "/**\n * Auto-generated canonical action/provider/evaluator docs for plugin-goals.\n * DO NOT EDIT - Generated from prompts/specs/**.\n */\n\nexport type ActionDoc = {\n name: string;\n description: string;\n similes?: readonly string[];\n parameters?: readonly unknown[];\n examples?: readonly (readonly unknown[])[];\n};\n\nexport type ProviderDoc = {\n name: string;\n description: string;\n position?: number;\n dynamic?: boolean;\n};\n\nexport type EvaluatorDoc = {\n name: string;\n description: string;\n similes?: readonly string[];\n alwaysRun?: boolean;\n examples?: readonly unknown[];\n};\n\nexport const coreActionsSpec = {\n version: \"1.0.0\",\n actions: [\n {\n name: \"CREATE_GOAL\",\n description: \"Create a new goal or task for the user to track progress on\",\n similes: [\"ADD_GOAL\", \"NEW_GOAL\", \"SET_GOAL\", \"ADD_TASK\", \"CREATE_TASK\"],\n parameters: [],\n },\n {\n name: \"UPDATE_GOAL\",\n description: \"Update an existing goal's name, description, or progress\",\n similes: [\"EDIT_GOAL\", \"MODIFY_GOAL\", \"CHANGE_GOAL\", \"UPDATE_TASK\"],\n parameters: [],\n },\n {\n name: \"CANCEL_GOAL\",\n description: \"Cancel or remove an existing goal that is no longer needed\",\n similes: [\"DELETE_GOAL\", \"REMOVE_GOAL\", \"ABANDON_GOAL\", \"CANCEL_TASK\"],\n parameters: [],\n },\n {\n name: \"COMPLETE_GOAL\",\n description: \"Mark a goal as completed when it has been achieved\",\n similes: [\"FINISH_GOAL\", \"DONE_GOAL\", \"ACHIEVE_GOAL\", \"COMPLETE_TASK\"],\n parameters: [],\n },\n {\n name: \"CONFIRM_GOAL\",\n description: \"Confirm and finalize a pending goal that was proposed\",\n similes: [\"APPROVE_GOAL\", \"ACCEPT_GOAL\", \"VERIFY_GOAL\", \"CONFIRM_TASK\"],\n parameters: [],\n },\n ],\n} as const;\nexport const allActionsSpec = {\n version: \"1.0.0\",\n actions: [\n {\n name: \"CREATE_GOAL\",\n description: \"Create a new goal or task for the user to track progress on\",\n similes: [\"ADD_GOAL\", \"NEW_GOAL\", \"SET_GOAL\", \"ADD_TASK\", \"CREATE_TASK\"],\n parameters: [],\n },\n {\n name: \"UPDATE_GOAL\",\n description: \"Update an existing goal's name, description, or progress\",\n similes: [\"EDIT_GOAL\", \"MODIFY_GOAL\", \"CHANGE_GOAL\", \"UPDATE_TASK\"],\n parameters: [],\n },\n {\n name: \"CANCEL_GOAL\",\n description: \"Cancel or remove an existing goal that is no longer needed\",\n similes: [\"DELETE_GOAL\", \"REMOVE_GOAL\", \"ABANDON_GOAL\", \"CANCEL_TASK\"],\n parameters: [],\n },\n {\n name: \"COMPLETE_GOAL\",\n description: \"Mark a goal as completed when it has been achieved\",\n similes: [\"FINISH_GOAL\", \"DONE_GOAL\", \"ACHIEVE_GOAL\", \"COMPLETE_TASK\"],\n parameters: [],\n },\n {\n name: \"CONFIRM_GOAL\",\n description: \"Confirm and finalize a pending goal that was proposed\",\n similes: [\"APPROVE_GOAL\", \"ACCEPT_GOAL\", \"VERIFY_GOAL\", \"CONFIRM_TASK\"],\n parameters: [],\n },\n ],\n} as const;\nexport const coreProvidersSpec = {\n version: \"1.0.0\",\n providers: [\n {\n name: \"GOALS\",\n description: \"Provides information about active goals and recent achievements\",\n dynamic: true,\n },\n ],\n} as const;\nexport const allProvidersSpec = {\n version: \"1.0.0\",\n providers: [\n {\n name: \"GOALS\",\n description: \"Provides information about active goals and recent achievements\",\n dynamic: true,\n },\n ],\n} as const;\nexport const coreEvaluatorsSpec = {\n version: \"1.0.0\",\n evaluators: [],\n} as const;\nexport const allEvaluatorsSpec = {\n version: \"1.0.0\",\n evaluators: [],\n} as const;\n\nexport const coreActionDocs: readonly ActionDoc[] = coreActionsSpec.actions;\nexport const allActionDocs: readonly ActionDoc[] = allActionsSpec.actions;\nexport const coreProviderDocs: readonly ProviderDoc[] = coreProvidersSpec.providers;\nexport const allProviderDocs: readonly ProviderDoc[] = allProvidersSpec.providers;\nexport const coreEvaluatorDocs: readonly EvaluatorDoc[] = coreEvaluatorsSpec.evaluators;\nexport const allEvaluatorDocs: readonly EvaluatorDoc[] = allEvaluatorsSpec.evaluators;\n",
91
- "/**\n * Helper functions to lookup action/provider/evaluator specs by name.\n * These allow language-specific implementations to import their text content\n * (description, similes, examples) from the centralized specs.\n *\n * DO NOT EDIT the spec data - update prompts/actions.json, prompts/providers.json, prompts/evaluators.json and regenerate.\n */\n\nimport {\n type ActionDoc,\n allActionDocs,\n allEvaluatorDocs,\n allProviderDocs,\n coreActionDocs,\n coreEvaluatorDocs,\n coreProviderDocs,\n type EvaluatorDoc,\n type ProviderDoc,\n} from \"./specs\";\n\n// Build lookup maps for O(1) access\nconst coreActionMap = new Map<string, ActionDoc>(coreActionDocs.map((doc) => [doc.name, doc]));\nconst allActionMap = new Map<string, ActionDoc>(allActionDocs.map((doc) => [doc.name, doc]));\nconst coreProviderMap = new Map<string, ProviderDoc>(\n coreProviderDocs.map((doc) => [doc.name, doc])\n);\nconst allProviderMap = new Map<string, ProviderDoc>(allProviderDocs.map((doc) => [doc.name, doc]));\nconst coreEvaluatorMap = new Map<string, EvaluatorDoc>(\n coreEvaluatorDocs.map((doc) => [doc.name, doc])\n);\nconst allEvaluatorMap = new Map<string, EvaluatorDoc>(\n allEvaluatorDocs.map((doc) => [doc.name, doc])\n);\n\n/**\n * Get an action spec by name from the core specs.\n * @param name - The action name\n * @returns The action spec or undefined if not found\n */\nexport function getActionSpec(name: string): ActionDoc | undefined {\n return coreActionMap.get(name) ?? allActionMap.get(name);\n}\n\n/**\n * Get an action spec by name, throwing if not found.\n * @param name - The action name\n * @returns The action spec\n * @throws Error if the action is not found\n */\nexport function requireActionSpec(name: string): ActionDoc {\n const spec = getActionSpec(name);\n if (!spec) {\n throw new Error(`Action spec not found: ${name}`);\n }\n return spec;\n}\n\n/**\n * Get a provider spec by name from the core specs.\n * @param name - The provider name\n * @returns The provider spec or undefined if not found\n */\nexport function getProviderSpec(name: string): ProviderDoc | undefined {\n return coreProviderMap.get(name) ?? allProviderMap.get(name);\n}\n\n/**\n * Get a provider spec by name, throwing if not found.\n * @param name - The provider name\n * @returns The provider spec\n * @throws Error if the provider is not found\n */\nexport function requireProviderSpec(name: string): ProviderDoc {\n const spec = getProviderSpec(name);\n if (!spec) {\n throw new Error(`Provider spec not found: ${name}`);\n }\n return spec;\n}\n\n/**\n * Get an evaluator spec by name from the core specs.\n * @param name - The evaluator name\n * @returns The evaluator spec or undefined if not found\n */\nexport function getEvaluatorSpec(name: string): EvaluatorDoc | undefined {\n return coreEvaluatorMap.get(name) ?? allEvaluatorMap.get(name);\n}\n\n/**\n * Get an evaluator spec by name, throwing if not found.\n * @param name - The evaluator name\n * @returns The evaluator spec\n * @throws Error if the evaluator is not found\n */\nexport function requireEvaluatorSpec(name: string): EvaluatorDoc {\n const spec = getEvaluatorSpec(name);\n if (!spec) {\n throw new Error(`Evaluator spec not found: ${name}`);\n }\n return spec;\n}\n\n// Re-export types for convenience\nexport type { ActionDoc, ProviderDoc, EvaluatorDoc };\n",
92
- "import {\n type Action,\n type ActionResult,\n asUUID,\n type HandlerCallback,\n type IAgentRuntime,\n logger,\n type Memory,\n ModelType,\n type State,\n} from \"@elizaos/core\";\nimport { requireActionSpec } from \"../generated/specs/spec-helpers\";\nimport { createGoalDataService } from \"../services/goalDataService.js\";\n\nconst spec = requireActionSpec(\"COMPLETE_GOAL\");\n\nexport const completeGoalAction: Action = {\n name: spec.name,\n similes: spec.similes ? [...spec.similes] : [],\n description: spec.description,\n validate: async (runtime: any, message: any, state?: any, options?: any): Promise<boolean> => {\n const __avTextRaw = typeof message?.content?.text === \"string\" ? message.content.text : \"\";\n const __avText = __avTextRaw.toLowerCase();\n const __avKeywords = [\"complete\", \"goal\"];\n const __avKeywordOk =\n __avKeywords.length > 0 && __avKeywords.some((kw) => kw.length > 0 && __avText.includes(kw));\n const __avRegex = /\\b(?:complete|goal)\\b/i;\n const __avRegexOk = __avRegex.test(__avText);\n const __avSource = String(message?.content?.source ?? message?.source ?? \"\");\n const __avExpectedSource = \"\";\n const __avSourceOk = __avExpectedSource\n ? __avSource === __avExpectedSource\n : Boolean(__avSource || state || runtime?.agentId || runtime?.getService);\n const __avOptions = options && typeof options === \"object\" ? options : {};\n const __avInputOk =\n __avText.trim().length > 0 ||\n Object.keys(__avOptions as Record<string, unknown>).length > 0 ||\n Boolean(message?.content && typeof message.content === \"object\");\n\n if (!(__avKeywordOk && __avRegexOk && __avSourceOk && __avInputOk)) {\n return false;\n }\n\n const __avLegacyValidate = async (\n _runtime: IAgentRuntime,\n message: Memory,\n _state?: State\n ): Promise<boolean> => {\n if (!message.roomId) {\n logger.warn(\"No roomId provided for complete goal validation\");\n return false;\n }\n\n const messageText = message.content?.text?.toLowerCase() || \"\";\n const hasCompleteIntent =\n messageText.includes(\"complete\") ||\n messageText.includes(\"achieve\") ||\n messageText.includes(\"finish\") ||\n messageText.includes(\"done\") ||\n messageText.includes(\"accomplished\");\n\n logger.info(\n { hasCompleteIntent, messageText: messageText.substring(0, 100) },\n \"Complete goal validation\"\n );\n\n return hasCompleteIntent;\n };\n try {\n return Boolean(await (__avLegacyValidate as any)(runtime, message, state, options));\n } catch {\n return false;\n }\n },\n handler: async (\n runtime: IAgentRuntime,\n message: Memory,\n _state?: State,\n _options?: { [key: string]: unknown },\n callback?: HandlerCallback\n ): Promise<ActionResult> => {\n try {\n if (!message.roomId) {\n const errorMessage = \"No room context available\";\n if (callback) {\n await callback({\n text: errorMessage,\n error: true,\n });\n }\n return { success: false, text: errorMessage };\n }\n\n const dataService = createGoalDataService(runtime);\n const isEntityMessage = message.entityId && message.entityId !== runtime.agentId;\n const ownerType = isEntityMessage ? \"entity\" : \"agent\";\n const ownerId = asUUID(isEntityMessage ? message.entityId : runtime.agentId);\n const ownerText = isEntityMessage ? \"User\" : \"Agent\";\n const messageText = message.content?.text || \"\";\n\n const activeGoals = await dataService.getGoals({\n ownerType,\n ownerId,\n isCompleted: false,\n });\n\n if (activeGoals.length === 0) {\n const responseText = `${ownerText} don't have any active goals to complete.`;\n if (callback) {\n await callback({\n text: responseText,\n actions: [\"COMPLETE_GOAL\"],\n });\n }\n return { success: true, text: responseText };\n }\n\n const matchPrompt = `Given this completion request: \"${messageText}\"\n \nWhich of these active goals best matches the request? Return only the number.\n\n${activeGoals.map((goal, idx) => `${idx + 1}. ${goal.name}`).join(\"\\n\")}\n\nIf none match well, return 0.`;\n\n const matchResult = await runtime.useModel(ModelType.TEXT_REASONING_SMALL, {\n prompt: matchPrompt,\n temperature: 0.1,\n });\n\n const matchIndex = parseInt(matchResult.trim(), 10) - 1;\n\n if (matchIndex < 0 || matchIndex >= activeGoals.length) {\n const responseText = `I couldn't determine which goal you want to complete. ${ownerText} have these active goals:\\n\\n${activeGoals\n .map((g) => `- ${g.name}`)\n .join(\"\\n\")}\\n\\nPlease be more specific.`;\n\n if (callback) {\n await callback({\n text: responseText,\n actions: [\"COMPLETE_GOAL\"],\n });\n }\n return { success: true, text: responseText };\n }\n\n const goal = activeGoals[matchIndex];\n await dataService.updateGoal(goal.id, {\n isCompleted: true,\n completedAt: new Date(),\n metadata: {\n ...goal.metadata,\n completedBy: message.entityId,\n },\n });\n\n const responseText = `🎉 Congratulations! ${ownerText} goal achieved: \"${goal.name}\"!`;\n\n if (callback) {\n await callback({\n text: responseText,\n actions: [\"COMPLETE_GOAL\"],\n });\n }\n\n return {\n success: true,\n text: responseText,\n data: {\n goalId: goal.id,\n goalName: goal.name,\n },\n };\n } catch (error) {\n logger.error(\"Error completing goal:\", error);\n const errorMessage = error instanceof Error ? error.message : \"Failed to complete goal\";\n\n if (callback) {\n await callback({\n text: `Error: ${errorMessage}`,\n error: true,\n });\n }\n\n return { success: false, error: errorMessage };\n }\n },\n examples: [\n [\n {\n name: \"Alice\",\n content: {\n text: \"I've completed my goal of learning French fluently!\",\n source: \"user\",\n },\n },\n {\n name: \"Agent\",\n content: {\n text: '🎉 Congratulations! User goal achieved: \"Learn French fluently\"!',\n actions: [\"COMPLETE_GOAL\"],\n },\n },\n ],\n [\n {\n name: \"Bob\",\n content: {\n text: \"I finally achieved my marathon goal!\",\n source: \"user\",\n },\n },\n {\n name: \"Agent\",\n content: {\n text: '🎉 Congratulations! User goal achieved: \"Run a marathon\"!',\n actions: [\"COMPLETE_GOAL\"],\n },\n },\n ],\n [\n {\n name: \"Carol\",\n content: {\n text: \"Mark my cooking goal as done\",\n source: \"user\",\n },\n },\n {\n name: \"Agent\",\n content: {\n text: '🎉 Congratulations! User goal achieved: \"Get better at cooking\"!',\n actions: [\"COMPLETE_GOAL\"],\n },\n },\n ],\n ],\n};\n\nexport default completeGoalAction;\n",
93
- "import {\n type Action,\n type ActionExample,\n type ActionResult,\n composePrompt,\n type Entity,\n formatMessages,\n type HandlerCallback,\n type HandlerOptions,\n type IAgentRuntime,\n logger,\n type Memory,\n ModelType,\n parseKeyValueXml,\n type State,\n} from \"@elizaos/core\";\nimport { extractConfirmationTemplate } from \"../generated/prompts/typescript/prompts.js\";\nimport { requireActionSpec } from \"../generated/specs/spec-helpers\";\nimport { createGoalDataService } from \"../services/goalDataService.js\";\n\ninterface PendingGoalData {\n name: string;\n description?: string;\n taskType: \"daily\" | \"one-off\" | \"aspirational\";\n priority?: 1 | 2 | 3 | 4;\n urgent?: boolean;\n dueDate?: string;\n recurring?: \"daily\" | \"weekly\" | \"monthly\";\n tags?: string[];\n metadata?: Record<string, unknown>;\n}\n\ninterface ConfirmationResponse {\n isConfirmation: boolean;\n shouldProceed: boolean;\n modifications?: string;\n}\n\nasync function extractConfirmationIntent(\n runtime: IAgentRuntime,\n message: Memory,\n pendingTask: PendingGoalData | null,\n state: State\n): Promise<ConfirmationResponse> {\n try {\n if (!pendingTask) {\n return { isConfirmation: false, shouldProceed: false };\n }\n\n const messageHistory = formatMessages({\n messages: (state.data?.messages as Memory[]) || [],\n entities: (state.data?.entities as Entity[]) || [],\n });\n\n const pendingTaskText = `\nName: ${pendingTask.name}\nType: ${pendingTask.taskType}\n${pendingTask.priority ? `Priority: ${pendingTask.priority}` : \"\"}\n${pendingTask.urgent ? \"Urgent: Yes\" : \"\"}\n${pendingTask.dueDate ? `Due Date: ${pendingTask.dueDate}` : \"\"}\n${pendingTask.recurring ? `Recurring: ${pendingTask.recurring}` : \"\"}\n`;\n\n const prompt = composePrompt({\n state: {\n text: message.content.text || \"\",\n messageHistory,\n pendingTask: pendingTaskText,\n },\n template: extractConfirmationTemplate,\n });\n\n const result = await runtime.useModel(ModelType.TEXT_SMALL, {\n prompt,\n stopSequences: [],\n });\n\n const parsedResult = parseKeyValueXml(result) as ConfirmationResponse | null;\n\n if (!parsedResult) {\n logger.error(\"Failed to parse confirmation response\");\n return { isConfirmation: false, shouldProceed: false };\n }\n\n return {\n isConfirmation: String(parsedResult.isConfirmation) === \"true\",\n shouldProceed: String(parsedResult.shouldProceed) === \"true\",\n modifications: parsedResult.modifications === \"none\" ? undefined : parsedResult.modifications,\n };\n } catch (error) {\n logger.error(\"Error extracting confirmation intent:\", error);\n return { isConfirmation: false, shouldProceed: false };\n }\n}\n\nconst spec = requireActionSpec(\"CONFIRM_GOAL\");\n\nexport const confirmGoalAction: Action = {\n name: spec.name,\n similes: spec.similes ? [...spec.similes] : [],\n description: spec.description,\n\n validate: async (runtime: any, message: any, state?: any, options?: any): Promise<boolean> => {\n const __avTextRaw = typeof message?.content?.text === \"string\" ? message.content.text : \"\";\n const __avText = __avTextRaw.toLowerCase();\n const __avKeywords = [\"confirm\", \"goal\"];\n const __avKeywordOk =\n __avKeywords.length > 0 && __avKeywords.some((kw) => kw.length > 0 && __avText.includes(kw));\n const __avRegex = /\\b(?:confirm|goal)\\b/i;\n const __avRegexOk = __avRegex.test(__avText);\n const __avSource = String(message?.content?.source ?? message?.source ?? \"\");\n const __avExpectedSource = \"\";\n const __avSourceOk = __avExpectedSource\n ? __avSource === __avExpectedSource\n : Boolean(__avSource || state || runtime?.agentId || runtime?.getService);\n const __avOptions = options && typeof options === \"object\" ? options : {};\n const __avInputOk =\n __avText.trim().length > 0 ||\n Object.keys(__avOptions as Record<string, unknown>).length > 0 ||\n Boolean(message?.content && typeof message.content === \"object\");\n\n if (!(__avKeywordOk && __avRegexOk && __avSourceOk && __avInputOk)) {\n return false;\n }\n\n const __avLegacyValidate = async (\n _runtime: IAgentRuntime,\n _message: Memory,\n state?: State\n ): Promise<boolean> => {\n const pendingGoal = state?.data?.pendingGoal as PendingGoalData | undefined;\n return !!pendingGoal;\n };\n try {\n return Boolean(await (__avLegacyValidate as any)(runtime, message, state, options));\n } catch {\n return false;\n }\n },\n\n handler: async (\n runtime: IAgentRuntime,\n message: Memory,\n state: State | undefined,\n _options?: HandlerOptions,\n callback?: HandlerCallback\n ): Promise<ActionResult> => {\n try {\n if (!state) {\n if (callback) {\n await callback({\n text: \"Unable to process confirmation without state context.\",\n actions: [\"CONFIRM_GOAL_ERROR\"],\n source: message.content.source,\n });\n }\n return { success: false, error: \"No state context\" };\n }\n\n const pendingGoal = state.data?.pendingGoal as PendingGoalData | undefined;\n if (!pendingGoal) {\n if (callback) {\n await callback({\n text: \"I don't have a pending task to confirm. Would you like to create a new task?\",\n actions: [\"CONFIRM_GOAL_NO_PENDING\"],\n source: message.content.source,\n });\n }\n return { success: false, error: \"No pending task\" };\n }\n\n if (!message.roomId || !message.entityId) {\n if (callback) {\n await callback({\n text: \"I cannot confirm a goal without a room and entity context.\",\n actions: [\"CONFIRM_GOAL_ERROR\"],\n source: message.content.source,\n });\n }\n return { success: false, error: \"No room or entity context\" };\n }\n\n const confirmation = await extractConfirmationIntent(runtime, message, pendingGoal, state);\n\n if (!confirmation.isConfirmation) {\n if (callback) {\n await callback({\n text: `I'm still waiting for your confirmation on the task \"${pendingGoal.name}\". Would you like me to create it?`,\n actions: [\"CONFIRM_GOAL_WAITING\"],\n source: message.content.source,\n });\n }\n return;\n }\n\n if (!confirmation.shouldProceed) {\n delete state.data.pendingGoal;\n\n if (callback) {\n await callback({\n text: \"Okay, I've cancelled the task creation. Let me know if you'd like to create a different task.\",\n actions: [\"CONFIRM_GOAL_CANCELLED\"],\n source: message.content.source,\n });\n }\n return;\n }\n\n const dataService = createGoalDataService(runtime);\n const existingGoals = await dataService.getGoals({\n ownerId: message.entityId,\n ownerType: \"entity\",\n isCompleted: false,\n });\n\n const duplicateGoal = existingGoals.find((g) => g.name.trim() === pendingGoal.name.trim());\n\n if (duplicateGoal) {\n delete state.data.pendingGoal;\n if (callback) {\n await callback({\n text: `It looks like you already have an active goal named \"${pendingGoal.name}\". I haven't added a duplicate.`,\n actions: [\"CONFIRM_GOAL_DUPLICATE\"],\n source: message.content.source,\n });\n }\n return;\n }\n\n const createdGoalId = await dataService.createGoal({\n agentId: runtime.agentId,\n ownerType: \"entity\",\n ownerId: message.entityId,\n name: pendingGoal.name,\n description: pendingGoal.description || pendingGoal.name,\n metadata: {\n ...pendingGoal.metadata,\n taskType: pendingGoal.taskType,\n priority: pendingGoal.priority,\n urgent: pendingGoal.urgent,\n dueDate: pendingGoal.dueDate,\n recurring: pendingGoal.recurring,\n },\n tags: pendingGoal.tags || [],\n });\n\n if (!createdGoalId) {\n throw new Error(\"Failed to create goal\");\n }\n\n delete state.data.pendingGoal;\n\n let successMessage = \"\";\n if (pendingGoal.taskType === \"daily\") {\n successMessage = `✅ Created daily task: \"${pendingGoal.name}\".`;\n } else if (pendingGoal.taskType === \"one-off\") {\n const priorityText = `Priority ${pendingGoal.priority || 3}`;\n const urgentText = pendingGoal.urgent ? \", Urgent\" : \"\";\n const dueDateText = pendingGoal.dueDate\n ? `, Due: ${new Date(pendingGoal.dueDate).toLocaleDateString()}`\n : \"\";\n successMessage = `✅ Created task: \"${pendingGoal.name}\" (${priorityText}${urgentText}${dueDateText})`;\n } else {\n successMessage = `✅ Created aspirational goal: \"${pendingGoal.name}\"`;\n }\n\n if (confirmation.modifications) {\n successMessage += `\\n\\nI created the task as originally described. The modifications you mentioned (\"${confirmation.modifications}\") weren't applied. You can use UPDATE_GOAL to make changes.`;\n }\n\n if (callback) {\n await callback({\n text: successMessage,\n actions: [\"CONFIRM_GOAL_SUCCESS\"],\n source: message.content.source,\n });\n }\n return { success: true, text: successMessage };\n } catch (error) {\n logger.error(\"Error in confirmGoal handler:\", error);\n if (callback) {\n await callback({\n text: \"I encountered an error while confirming your goal. Please try again.\",\n actions: [\"CONFIRM_GOAL_ERROR\"],\n source: message.content.source,\n });\n }\n return {\n success: false,\n error: error instanceof Error ? error.message : \"Unknown error\",\n };\n }\n },\n\n examples: (spec.examples ?? []) as ActionExample[][],\n};\n\nexport default confirmGoalAction;\n",
94
- "import {\n type Action,\n type ActionExample,\n type ActionResult,\n composePrompt,\n type Entity,\n formatMessages,\n type HandlerCallback,\n type HandlerOptions,\n type IAgentRuntime,\n logger,\n type Memory,\n ModelType,\n parseKeyValueXml,\n type State,\n type UUID,\n} from \"@elizaos/core\";\nimport {\n checkSimilarityTemplate,\n extractGoalTemplate,\n} from \"../generated/prompts/typescript/prompts.js\";\nimport { requireActionSpec } from \"../generated/specs/spec-helpers\";\nimport { createGoalDataService } from \"../services/goalDataService\";\n\ninterface GoalInput {\n name: string;\n description?: string;\n ownerType: \"agent\" | \"entity\";\n}\n\ninterface SimilarityCheckResult {\n hasSimilar: boolean;\n similarGoalName?: string;\n confidence: number;\n}\n\nasync function extractGoalInfo(\n runtime: IAgentRuntime,\n message: Memory,\n state: State\n): Promise<GoalInput | null> {\n try {\n const messageHistory = formatMessages({\n messages: (state.data?.messages as Memory[]) || [],\n entities: (state.data?.entities as Entity[]) || [],\n });\n\n const prompt = composePrompt({\n state: {\n text: message.content.text || \"\",\n messageHistory,\n },\n template: extractGoalTemplate,\n });\n\n const result = await runtime.useModel(ModelType.TEXT_LARGE, {\n prompt,\n stopSequences: [],\n });\n\n logger.debug(\"Extract goal result:\", result);\n\n // Parse XML from the text results\n const parsedResult = parseKeyValueXml(result);\n\n if (!parsedResult || !parsedResult.name) {\n logger.error(\"Failed to extract valid goal information from XML\");\n return null;\n }\n\n return {\n name: String(parsedResult.name),\n description: parsedResult.description ? String(parsedResult.description) : undefined,\n ownerType: (parsedResult.ownerType === \"agent\" ? \"agent\" : \"entity\") as \"agent\" | \"entity\",\n };\n } catch (error) {\n logger.error(\"Error extracting goal information:\", error);\n return null;\n }\n}\n\ninterface ExistingGoal {\n name: string;\n description?: string;\n}\n\nasync function checkForSimilarGoal(\n runtime: IAgentRuntime,\n newGoal: GoalInput,\n existingGoals: ExistingGoal[]\n): Promise<SimilarityCheckResult> {\n try {\n if (existingGoals.length === 0) {\n return { hasSimilar: false, confidence: 0 };\n }\n\n const existingGoalsText = existingGoals\n .map((goal) => `- ${goal.name}: ${goal.description || \"No description\"}`)\n .join(\"\\n\");\n\n const prompt = composePrompt({\n state: {\n newGoalName: newGoal.name,\n newGoalDescription: newGoal.description || \"No description\",\n existingGoals: existingGoalsText,\n },\n template: checkSimilarityTemplate,\n });\n\n const result = await runtime.useModel(ModelType.TEXT_SMALL, {\n prompt,\n stopSequences: [],\n });\n\n const parsedResult = parseKeyValueXml(result) as SimilarityCheckResult | null;\n\n if (!parsedResult) {\n return { hasSimilar: false, confidence: 0 };\n }\n\n return {\n hasSimilar: String(parsedResult.hasSimilar) === \"true\",\n similarGoalName: parsedResult.similarGoalName,\n confidence: parseInt(String(parsedResult.confidence || 0), 10),\n };\n } catch (error) {\n logger.error(\"Error checking for similar goals:\", error);\n return { hasSimilar: false, confidence: 0 };\n }\n}\n\nconst spec = requireActionSpec(\"CREATE_GOAL\");\n\nexport const createGoalAction: Action = {\n name: spec.name,\n similes: spec.similes ? [...spec.similes] : [],\n description: spec.description,\n\n validate: async (runtime: any, message: any, state?: any, options?: any): Promise<boolean> => {\n const __avTextRaw = typeof message?.content?.text === \"string\" ? message.content.text : \"\";\n const __avText = __avTextRaw.toLowerCase();\n const __avKeywords = [\"create\", \"goal\"];\n const __avKeywordOk =\n __avKeywords.length > 0 && __avKeywords.some((kw) => kw.length > 0 && __avText.includes(kw));\n const __avRegex = /\\b(?:create|goal)\\b/i;\n const __avRegexOk = __avRegex.test(__avText);\n const __avSource = String(message?.content?.source ?? message?.source ?? \"\");\n const __avExpectedSource = \"\";\n const __avSourceOk = __avExpectedSource\n ? __avSource === __avExpectedSource\n : Boolean(__avSource || state || runtime?.agentId || runtime?.getService);\n const __avOptions = options && typeof options === \"object\" ? options : {};\n const __avInputOk =\n __avText.trim().length > 0 ||\n Object.keys(__avOptions as Record<string, unknown>).length > 0 ||\n Boolean(message?.content && typeof message.content === \"object\");\n\n if (!(__avKeywordOk && __avRegexOk && __avSourceOk && __avInputOk)) {\n return false;\n }\n\n const __avLegacyValidate = async (\n _runtime: IAgentRuntime,\n _message: Memory\n ): Promise<boolean> => {\n return true;\n };\n try {\n return Boolean(await (__avLegacyValidate as any)(runtime, message, state, options));\n } catch {\n return false;\n }\n },\n\n handler: async (\n runtime: IAgentRuntime,\n message: Memory,\n state: State | undefined,\n _options?: HandlerOptions,\n callback?: HandlerCallback\n ): Promise<ActionResult> => {\n try {\n const currentState = state || (await runtime.composeState(message, [\"GOALS\"]));\n const goalInfo = await extractGoalInfo(runtime, message, currentState);\n\n if (!goalInfo) {\n if (callback) {\n await callback({\n text: \"I couldn't understand what goal you want to create. Could you please provide a clear goal description?\",\n actions: [\"CREATE_GOAL_FAILED\"],\n source: message.content.source,\n });\n }\n return {\n success: false,\n error: \"Could not understand goal description\",\n };\n }\n\n const dataService = createGoalDataService(runtime);\n const ownerId = goalInfo.ownerType === \"agent\" ? runtime.agentId : (message.entityId as UUID);\n const activeGoalCount = await dataService.countGoals(goalInfo.ownerType, ownerId, false);\n\n if (activeGoalCount >= 10) {\n if (callback) {\n await callback({\n text: `Cannot add new goal: The ${goalInfo.ownerType === \"agent\" ? \"agent\" : \"user\"} already has 10 active goals, which is the maximum allowed. Please complete or remove some existing goals first.`,\n actions: [\"CREATE_GOAL_LIMIT_REACHED\"],\n source: message.content.source,\n });\n }\n return { success: false, error: \"Goal limit reached\" };\n }\n\n const existingGoals = await dataService.getAllGoalsForOwner(goalInfo.ownerType, ownerId);\n const similarityCheck = await checkForSimilarGoal(runtime, goalInfo, existingGoals);\n\n if (similarityCheck.hasSimilar && similarityCheck.confidence > 70) {\n if (callback) {\n await callback({\n text: `It looks like there's already a similar goal: \"${similarityCheck.similarGoalName}\". Are you sure you want to add this as a separate goal?`,\n actions: [\"CREATE_GOAL_SIMILAR_EXISTS\"],\n source: message.content.source,\n });\n }\n return { success: false, error: \"Similar goal exists\" };\n }\n\n const tags = [\"GOAL\"];\n if (goalInfo.ownerType === \"agent\") {\n tags.push(\"agent-goal\");\n } else {\n tags.push(\"entity-goal\");\n }\n\n const metadata: Record<string, unknown> = {\n createdAt: new Date().toISOString(),\n };\n\n const createdGoalId = await dataService.createGoal({\n agentId: runtime.agentId,\n ownerType: goalInfo.ownerType,\n ownerId,\n name: goalInfo.name,\n description: goalInfo.description || goalInfo.name,\n metadata,\n tags,\n });\n\n if (!createdGoalId) {\n throw new Error(\"Failed to create goal\");\n }\n\n let successMessage = `✅ New goal created: \"${goalInfo.name}\"`;\n\n if (activeGoalCount >= 4) {\n successMessage += `\\n\\n⚠️ You now have ${activeGoalCount + 1} active goals. Consider focusing on completing some of these before adding more.`;\n }\n\n if (callback) {\n await callback({\n text: successMessage,\n actions: [\"CREATE_GOAL_SUCCESS\"],\n source: message.content.source,\n });\n }\n return { success: true, text: successMessage };\n } catch (error) {\n logger.error(\"Error in createGoal handler:\", error);\n if (callback) {\n await callback({\n text: \"I encountered an error while creating your goal. Please try again.\",\n actions: [\"CREATE_GOAL_FAILED\"],\n source: message.content.source,\n });\n }\n return {\n success: false,\n error: error instanceof Error ? error.message : \"Unknown error\",\n };\n }\n },\n\n examples: (spec.examples ?? []) as ActionExample[][],\n};\n\nexport default createGoalAction;\n",
95
- "import {\n type Action,\n type ActionExample,\n type ActionResult,\n composePrompt,\n type HandlerCallback,\n type HandlerOptions,\n type IAgentRuntime,\n logger,\n type Memory,\n ModelType,\n parseKeyValueXml,\n type State,\n type UUID,\n} from \"@elizaos/core\";\nimport {\n extractGoalSelectionTemplate,\n extractGoalUpdateTemplate,\n} from \"../generated/prompts/typescript/prompts.js\";\nimport { requireActionSpec } from \"../generated/specs/spec-helpers\";\nimport { createGoalDataService, type GoalData } from \"../services/goalDataService\";\n\ninterface GoalSelection {\n goalId: string;\n goalName: string;\n isFound: boolean;\n}\n\ninterface GoalUpdate {\n name?: string;\n description?: string;\n}\n\nasync function extractGoalSelection(\n runtime: IAgentRuntime,\n message: Memory,\n availableGoals: GoalData[]\n): Promise<GoalSelection> {\n try {\n const goalsText = availableGoals\n .map((goal) => {\n return `ID: ${goal.id}\\nName: ${goal.name}\\nDescription: ${goal.description || goal.name}\\nOwner Type: ${goal.ownerType}\\nTags: ${goal.tags?.join(\", \") || \"none\"}\\n`;\n })\n .join(\"\\n---\\n\");\n\n const prompt = composePrompt({\n state: {\n text: message.content.text || \"\",\n availableGoals: goalsText,\n },\n template: extractGoalSelectionTemplate,\n });\n\n const result = await runtime.useModel(ModelType.TEXT_SMALL, {\n prompt,\n stopSequences: [],\n });\n\n const parsedResult = parseKeyValueXml(result) as GoalSelection | null;\n\n if (!parsedResult || typeof parsedResult.isFound === \"undefined\") {\n logger.error(\"Failed to parse valid goal selection information from XML\");\n return { goalId: \"\", goalName: \"\", isFound: false };\n }\n\n const finalResult: GoalSelection = {\n goalId: parsedResult.goalId === \"null\" ? \"\" : String(parsedResult.goalId || \"\"),\n goalName: parsedResult.goalName === \"null\" ? \"\" : String(parsedResult.goalName || \"\"),\n isFound: String(parsedResult.isFound) === \"true\",\n };\n\n return finalResult;\n } catch (error) {\n logger.error(\"Error extracting goal selection information:\", error);\n return { goalId: \"\", goalName: \"\", isFound: false };\n }\n}\n\n/**\n * Extracts what updates the user wants to make to the goal\n */\nasync function extractGoalUpdate(\n runtime: IAgentRuntime,\n message: Memory,\n goal: GoalData\n): Promise<GoalUpdate | null> {\n try {\n let goalDetails = `Name: ${goal.name}\\n`;\n if (goal.description) goalDetails += `Description: ${goal.description}\\n`;\n goalDetails += `Owner Type: ${goal.ownerType}\\n`;\n goalDetails += `Created: ${goal.createdAt?.toLocaleDateString() || \"Unknown\"}\\n`;\n\n const prompt = composePrompt({\n state: {\n text: message.content.text || \"\",\n goalDetails,\n },\n template: extractGoalUpdateTemplate,\n });\n\n const result = await runtime.useModel(ModelType.TEXT_SMALL, {\n prompt,\n stopSequences: [],\n });\n\n const parsedUpdate = parseKeyValueXml(result) as GoalUpdate | null;\n\n if (!parsedUpdate || Object.keys(parsedUpdate).length === 0) {\n logger.error(\"Failed to extract valid goal update information from XML\");\n return null;\n }\n\n // Return only valid fields\n const finalUpdate: GoalUpdate = {};\n if (parsedUpdate.name) finalUpdate.name = String(parsedUpdate.name);\n if (parsedUpdate.description) finalUpdate.description = String(parsedUpdate.description);\n\n // Return null if no valid fields remain\n if (Object.keys(finalUpdate).length === 0) {\n logger.warn(\"No valid update fields found after parsing XML.\");\n return null;\n }\n\n return finalUpdate;\n } catch (error) {\n logger.error(\"Error extracting goal update information:\", error);\n return null;\n }\n}\n\nconst spec = requireActionSpec(\"UPDATE_GOAL\");\n\nexport const updateGoalAction: Action = {\n name: spec.name,\n similes: spec.similes ? [...spec.similes] : [],\n description: `${spec.description} Update a goal name or description.`,\n\n validate: async (runtime: any, message: any, state?: any, options?: any): Promise<boolean> => {\n const __avTextRaw = typeof message?.content?.text === \"string\" ? message.content.text : \"\";\n const __avText = __avTextRaw.toLowerCase();\n const __avKeywords = [\"update\", \"goal\"];\n const __avKeywordOk =\n __avKeywords.length > 0 && __avKeywords.some((kw) => kw.length > 0 && __avText.includes(kw));\n const __avRegex = /\\b(?:update|goal)\\b/i;\n const __avRegexOk = __avRegex.test(__avText);\n const __avSource = String(message?.content?.source ?? message?.source ?? \"\");\n const __avExpectedSource = \"\";\n const __avSourceOk = __avExpectedSource\n ? __avSource === __avExpectedSource\n : Boolean(__avSource || state || runtime?.agentId || runtime?.getService);\n const __avOptions = options && typeof options === \"object\" ? options : {};\n const __avInputOk =\n __avText.trim().length > 0 ||\n Object.keys(__avOptions as Record<string, unknown>).length > 0 ||\n Boolean(message?.content && typeof message.content === \"object\");\n\n if (!(__avKeywordOk && __avRegexOk && __avSourceOk && __avInputOk)) {\n return false;\n }\n\n const __avLegacyValidate = async (\n runtime: IAgentRuntime,\n message: Memory\n ): Promise<boolean> => {\n try {\n const dataService = createGoalDataService(runtime);\n\n // Check both agent and entity goals\n const agentGoalCount = await dataService.countGoals(\"agent\", runtime.agentId, false);\n const entityGoalCount = message.entityId\n ? await dataService.countGoals(\"entity\", message.entityId as UUID, false)\n : 0;\n\n return agentGoalCount + entityGoalCount > 0;\n } catch (error) {\n logger.error(\"Error validating UPDATE_GOAL action:\", error);\n return false;\n }\n };\n try {\n return Boolean(await (__avLegacyValidate as any)(runtime, message, state, options));\n } catch {\n return false;\n }\n },\n\n handler: async (\n runtime: IAgentRuntime,\n message: Memory,\n state: State | undefined,\n _options?: HandlerOptions,\n callback?: HandlerCallback\n ): Promise<ActionResult> => {\n try {\n if (!state) {\n if (callback) {\n await callback({\n text: \"Unable to process request without state context.\",\n actions: [\"UPDATE_GOAL_ERROR\"],\n source: message.content.source,\n });\n }\n return { success: false, error: \"No state context\" };\n }\n\n const dataService = createGoalDataService(runtime);\n\n // Get all active goals (both agent and entity)\n const agentGoals = await dataService.getGoals({\n ownerType: \"agent\",\n ownerId: runtime.agentId,\n isCompleted: false,\n });\n\n const entityGoals = message.entityId\n ? await dataService.getGoals({\n ownerType: \"entity\",\n ownerId: message.entityId as UUID,\n isCompleted: false,\n })\n : [];\n\n const availableGoals = [...agentGoals, ...entityGoals];\n\n if (availableGoals.length === 0) {\n if (callback) {\n await callback({\n text: \"There are no active goals to update. Would you like to create a new goal?\",\n actions: [\"UPDATE_GOAL_NO_GOALS\"],\n source: message.content.source,\n });\n }\n return { success: false, error: \"No active goals\" };\n }\n\n const goalSelection = await extractGoalSelection(runtime, message, availableGoals);\n if (!goalSelection.isFound) {\n if (callback) {\n await callback({\n text:\n \"I couldn't determine which goal you want to update. Could you be more specific? Here are the current goals:\\n\\n\" +\n availableGoals.map((goal) => `- ${goal.name} (${goal.ownerType} goal)`).join(\"\\n\"),\n actions: [\"UPDATE_GOAL_NOT_FOUND\"],\n source: message.content.source,\n });\n }\n return { success: false, error: \"Goal not found\" };\n }\n\n const goal = availableGoals.find((g) => g.id === goalSelection.goalId);\n if (!goal) {\n if (callback) {\n await callback({\n text: `I couldn't find a goal matching \"${goalSelection.goalName}\". Please try again with the exact goal name.`,\n actions: [\"UPDATE_GOAL_NOT_FOUND\"],\n source: message.content.source,\n });\n }\n return { success: false, error: \"Goal not found\" };\n }\n\n const update = await extractGoalUpdate(runtime, message, goal);\n if (!update) {\n if (callback) {\n await callback({\n text: `I couldn't determine what changes you want to make to \"${goal.name}\". You can update the goal's name or description.`,\n actions: [\"UPDATE_GOAL_INVALID_UPDATE\"],\n source: message.content.source,\n });\n }\n return { success: false, error: \"Invalid update\" };\n }\n\n await dataService.updateGoal(goal.id, update);\n\n const ownerText = goal.ownerType === \"agent\" ? \"Agent\" : \"User\";\n const updateText: string[] = [];\n if (update.name) updateText.push(`name to \"${update.name}\"`);\n if (update.description) updateText.push(`description to \"${update.description}\"`);\n\n if (callback) {\n await callback({\n text: `✓ ${ownerText} goal updated: Changed ${updateText.join(\" and \")}.`,\n actions: [\"UPDATE_GOAL_SUCCESS\"],\n source: message.content.source,\n });\n }\n return {\n success: true,\n text: `Updated goal: ${updateText.join(\" and \")}`,\n };\n } catch (error) {\n logger.error(\"Error in updateGoal handler:\", error);\n if (callback) {\n await callback({\n text: \"I encountered an error while trying to update your goal. Please try again.\",\n actions: [\"UPDATE_GOAL_ERROR\"],\n source: message.content.source,\n });\n }\n return {\n success: false,\n error: error instanceof Error ? error.message : \"Unknown error\",\n };\n }\n },\n\n examples: (spec.examples ?? []) as ActionExample[][],\n};\n\nexport default updateGoalAction;\n",
96
- "import fs from \"node:fs\";\nimport path from \"node:path\";\nimport { fileURLToPath } from \"node:url\";\nimport {\n type IAgentRuntime,\n logger,\n type Route,\n type RouteRequest,\n type RouteResponse,\n stringToUuid,\n type UUID,\n} from \"@elizaos/core\";\nimport { sql } from \"drizzle-orm\";\nimport { createGoalDataService } from \"./services/goalDataService.js\";\n\ninterface TagRow {\n tag: string;\n}\n\ninterface DbQueryResult {\n rows?: TagRow[];\n}\n\n// Define the equivalent of __dirname for ES modules\nconst __filename = fileURLToPath(import.meta.url);\nconst __dirname = path.dirname(__filename);\n\n// Resolve the path to the frontend distribution directory, assuming it's in 'dist'\n// relative to the package root (which is two levels up from src/plugin-todo)\nconst frontendDist = path.resolve(__dirname, \"../dist\");\n\nconst _frontPagePath = path.resolve(frontendDist, \"index.html\");\nconst assetsPath = path.resolve(frontendDist, \"assets\");\n\nexport const routes: Route[] = [\n {\n type: \"GET\",\n path: \"/\",\n handler: async (_req: RouteRequest, res: RouteResponse, _runtime: IAgentRuntime) => {\n const indexPath = path.resolve(frontendDist, \"index.html\");\n if (fs.existsSync(indexPath)) {\n const htmlContent = fs.readFileSync(indexPath, \"utf-8\");\n res.setHeader(\"Content-Type\", \"text/html\");\n res.send(htmlContent);\n } else {\n res.status(404).send(\"HTML file not found\");\n }\n },\n },\n {\n type: \"GET\",\n path: \"/goals\",\n handler: async (_req: RouteRequest, res: RouteResponse, _runtime: IAgentRuntime) => {\n const goalsHtmlPath = path.resolve(frontendDist, \"index.html\");\n if (fs.existsSync(goalsHtmlPath)) {\n const htmlContent = fs.readFileSync(goalsHtmlPath, \"utf-8\");\n res.setHeader(\"Content-Type\", \"text/html\");\n res.send(htmlContent);\n } else {\n res.status(404).send(\"Goals HTML file not found\");\n }\n },\n },\n {\n type: \"GET\",\n path: \"/assets/*\",\n handler: async (\n req: RouteRequest,\n res: RouteResponse,\n _runtime: IAgentRuntime\n ): Promise<void> => {\n const assetRelativePath = req.params?.[\"0\"];\n if (!assetRelativePath) {\n res.status(400).send(\"Invalid asset path\");\n return;\n }\n const filePath = path.resolve(assetsPath, assetRelativePath);\n\n if (!filePath.startsWith(assetsPath)) {\n res.status(403).send(\"Forbidden\");\n return;\n }\n\n if (fs.existsSync(filePath)) {\n const sendFile = res.sendFile;\n if (sendFile) {\n sendFile.call(res, filePath);\n } else {\n const content = fs.readFileSync(filePath);\n (res as unknown as { send: (data: Buffer) => void }).send(content);\n }\n } else {\n res.status(404).send(\"Asset not found\");\n }\n },\n },\n {\n type: \"GET\",\n path: \"/api/tags\",\n handler: async (_req: RouteRequest, res: RouteResponse, runtime: IAgentRuntime) => {\n try {\n logger.debug(\"[API /api/tags] Fetching all distinct tags\");\n const db = runtime.db as { execute?: (query: unknown) => Promise<unknown> } | undefined;\n if (!db || typeof db.execute !== \"function\") {\n logger.error(\"[API /api/tags] runtime.db is not available or not a Drizzle instance.\");\n res.status(500).json({ error: \"Database not available\" });\n return;\n }\n\n let dbType: \"sqlite\" | \"postgres\" | \"unknown\" = \"unknown\";\n try {\n const connection = await runtime.getConnection();\n if (connection && connection.constructor.name === \"Pool\") {\n dbType = \"postgres\";\n } else {\n try {\n await db.execute(sql`SELECT sqlite_version()`);\n dbType = \"sqlite\";\n } catch {\n // Not SQLite\n }\n }\n } catch (error) {\n logger.warn(\"Could not determine database type:\", error);\n }\n\n let result: TagRow[] | DbQueryResult;\n\n if (dbType === \"postgres\") {\n const query = sql`SELECT DISTINCT unnest(tags) as tag FROM goal_tags WHERE tag IS NOT NULL;`;\n result = (await db.execute(query)) as TagRow[] | DbQueryResult;\n } else {\n const query = sql`\n SELECT DISTINCT tag \n FROM goal_tags \n WHERE tag IS NOT NULL\n `;\n result = (await db.execute(query)) as TagRow[] | DbQueryResult;\n }\n\n const tags = Array.isArray(result)\n ? result.map((row: TagRow) => row.tag)\n : (result as DbQueryResult).rows\n ? (result as DbQueryResult).rows?.map((row: TagRow) => row.tag)\n : [];\n\n logger.debug(`[API /api/tags] Found ${tags.length} distinct tags`);\n res.json(tags);\n } catch (error) {\n logger.error(\"[API /api/tags] Error fetching tags:\", error);\n res.status(500).json({ error: \"Failed to fetch tags\" });\n }\n },\n },\n {\n type: \"GET\",\n path: \"/api/goals\",\n handler: async (\n _req: RouteRequest,\n _res: RouteResponse,\n _runtime: IAgentRuntime\n ): Promise<void> => {\n // ... existing code ...\n },\n },\n // API route to create a new goal\n {\n type: \"POST\",\n path: \"/api/goals\",\n handler: async (req: RouteRequest, res: RouteResponse, runtime: IAgentRuntime) => {\n try {\n const body = req.body ?? {};\n const name = body.name as string | undefined;\n const description = body.description as string | undefined;\n const tags = body.tags as string[] | undefined;\n\n if (!name || typeof name !== \"string\") {\n res.status(400).send(\"Missing or invalid name\");\n return;\n }\n\n const dataService = createGoalDataService(runtime);\n\n const newGoalId = await dataService.createGoal({\n agentId: runtime.agentId,\n ownerType: \"agent\",\n ownerId: runtime.agentId,\n name: String(name),\n description: description ? String(description) : name,\n metadata: {},\n tags: Array.isArray(tags) ? tags.map((t) => String(t)) : [\"GOAL\"],\n });\n\n const newGoal = newGoalId ? await dataService.getGoal(newGoalId) : null;\n (res.status(201) as { json: (data: unknown) => void }).json(newGoal);\n } catch (error) {\n console.error(\"Error creating goal:\", error);\n res.status(500).send(\"Error creating goal\");\n }\n },\n },\n {\n type: \"PUT\",\n path: \"/api/goals/:id/complete\",\n handler: async (req: RouteRequest, res: RouteResponse, runtime: IAgentRuntime) => {\n try {\n const goalIdStr = req.params.id;\n\n if (!goalIdStr) {\n res.status(400).send(\"Missing goalId\");\n return;\n }\n\n const goalId = stringToUuid(goalIdStr) as UUID;\n const dataService = createGoalDataService(runtime);\n const goal = await dataService.getGoal(goalId);\n\n if (!goal) {\n res.status(404).send(\"Goal not found\");\n return;\n }\n\n // Check if already completed\n if (goal.isCompleted) {\n res.status(400).send(\"Goal already completed\");\n return;\n }\n\n const now = new Date();\n await dataService.updateGoal(goalId, {\n isCompleted: true,\n completedAt: now,\n metadata: {\n ...goal.metadata,\n completedAt: now.toISOString(),\n },\n });\n\n // Return the final goal state\n const updatedGoal = await dataService.getGoal(goalId);\n (res as { json: (data: unknown) => void }).json({\n message: `Goal ${goalId} completed.`,\n goal: updatedGoal,\n });\n } catch (error) {\n const errorMessage = error instanceof Error ? error.message : \"Unknown error\";\n console.error(`Error completing goal ${req.params.id}:`, error);\n logger.error(`Error completing goal ${req.params.id}:`, error);\n res.status(500).send(`Error completing goal: ${errorMessage}`);\n }\n },\n },\n {\n type: \"PUT\",\n path: \"/api/goals/:id/uncomplete\",\n handler: async (req: RouteRequest, res: RouteResponse, runtime: IAgentRuntime) => {\n try {\n const goalIdStr = req.params.id;\n if (!goalIdStr) {\n res.status(400).send(\"Missing goalId\");\n return;\n }\n\n const goalId = stringToUuid(goalIdStr) as UUID;\n const dataService = createGoalDataService(runtime);\n const goal = await dataService.getGoal(goalId);\n\n if (!goal) {\n res.status(404).send(\"Goal not found\");\n return;\n }\n\n // Check if already incomplete\n if (!goal.isCompleted) {\n res.status(400).send(\"Goal is already not completed\");\n return;\n }\n\n const metadataUpdate = { ...goal.metadata } as Record<string, unknown>;\n delete metadataUpdate.completedAt;\n\n await dataService.updateGoal(goalId, {\n isCompleted: false,\n completedAt: undefined,\n metadata: metadataUpdate,\n });\n\n const updatedGoal = await dataService.getGoal(goalId);\n (res as { json: (data: unknown) => void }).json({\n message: `Goal ${goalId} marked as not completed.`,\n goal: updatedGoal,\n });\n } catch (error) {\n const errorMessage = error instanceof Error ? error.message : \"Unknown error\";\n console.error(`Error uncompleting goal ${req.params.id}:`, error);\n logger.error(`Error uncompleting goal ${req.params.id}:`, error);\n res.status(500).send(`Error uncompleting goal: ${errorMessage}`);\n }\n },\n },\n // API route to update an existing goal\n {\n type: \"PUT\",\n path: \"/api/goals/:id\",\n handler: async (req: RouteRequest, res: RouteResponse, runtime: IAgentRuntime) => {\n try {\n const goalIdStr = req.params.id;\n const updateData = req.body as Record<string, unknown>;\n\n if (!goalIdStr) {\n res.status(400).send(\"Missing goal ID\");\n return;\n }\n if (!updateData || Object.keys(updateData).length === 0) {\n res.status(400).send(\"Missing update data\");\n return undefined;\n }\n\n const goalId = stringToUuid(goalIdStr) as UUID;\n const dataService = createGoalDataService(runtime);\n const goal = await dataService.getGoal(goalId);\n\n if (!goal) {\n res.status(404).send(\"Goal not found\");\n return;\n }\n\n const updates: Record<string, unknown> = {};\n if (updateData.name) updates.name = updateData.name;\n if (updateData.description !== undefined) updates.description = updateData.description;\n if (updateData.tags) updates.tags = updateData.tags;\n if (updateData.metadata)\n updates.metadata = {\n ...goal.metadata,\n ...(updateData.metadata as Record<string, unknown>),\n };\n\n await dataService.updateGoal(goalId, updates);\n\n const updatedGoal = await dataService.getGoal(goalId);\n (res as { json: (data: unknown) => void }).json({\n message: `Goal ${goalId} updated successfully.`,\n goal: updatedGoal,\n });\n } catch (error) {\n const errorMessage = error instanceof Error ? error.message : \"Unknown error\";\n console.error(`Error updating goal ${req.params.id}:`, error);\n logger.error(`Error updating goal ${req.params.id}:`, error);\n res.status(500).send(`Error updating goal: ${errorMessage}`);\n }\n },\n },\n {\n type: \"DELETE\",\n path: \"/api/goals/:id\",\n handler: async (req: RouteRequest, res: RouteResponse, runtime: IAgentRuntime) => {\n try {\n const goalIdStr = req.params.id;\n if (!goalIdStr) {\n res.status(400).send(\"Missing goal ID\");\n return;\n }\n\n const goalId = stringToUuid(goalIdStr) as UUID;\n const dataService = createGoalDataService(runtime);\n const goal = await dataService.getGoal(goalId);\n\n if (!goal) {\n res.status(404).send(\"Goal not found\");\n return;\n }\n\n await dataService.deleteGoal(goalId);\n\n res.json({\n message: `Goal ${goalId} deleted successfully.`,\n });\n } catch (error) {\n console.error(`Error deleting goal ${req.params.id}:`, error);\n logger.error(`Error deleting goal ${req.params.id}:`, error);\n res.status(500).send(\"Error deleting goal\");\n }\n },\n },\n];\n\nexport default routes;\n",
97
- "import {\n type IAgentRuntime,\n logger,\n type Memory,\n type Provider,\n type ProviderResult,\n type State,\n type UUID,\n} from \"@elizaos/core\";\nimport { requireProviderSpec } from \"../generated/specs/spec-helpers\";\nimport { createGoalDataService } from \"../services/goalDataService.js\";\n\nconst spec = requireProviderSpec(\"GOALS\");\n\nexport const goalsProvider: Provider = {\n name: spec.name,\n description: \"Provides information about active goals and recent achievements\",\n\n dynamic: true,\n get: async (runtime: IAgentRuntime, message: Memory, _state: State): Promise<ProviderResult> => {\n try {\n const dataService = createGoalDataService(runtime);\n let ownerType: \"agent\" | \"entity\" = \"agent\";\n let ownerId: UUID = runtime.agentId;\n\n if (message?.entityId && message.entityId !== runtime.agentId) {\n ownerType = \"entity\";\n ownerId = message.entityId;\n }\n\n const activeGoals = await dataService.getGoals({\n ownerType,\n ownerId,\n isCompleted: false,\n });\n\n const completedGoals = await dataService.getGoals({\n ownerType,\n ownerId,\n isCompleted: true,\n });\n\n const recentCompleted = completedGoals\n .sort((a, b) => (b.completedAt?.getTime() || 0) - (a.completedAt?.getTime() || 0))\n .slice(0, 5);\n\n let output = \"\";\n\n if (activeGoals.length > 0) {\n output += \"## Active Goals\\n\";\n activeGoals.forEach((goal) => {\n const tags = goal.tags && goal.tags.length > 0 ? ` [${goal.tags.join(\", \")}]` : \"\";\n output += `- ${goal.name}${tags}`;\n if (goal.description) {\n output += ` - ${goal.description}`;\n }\n output += \"\\n\";\n });\n output += \"\\n\";\n }\n\n if (recentCompleted.length > 0) {\n output += \"## Recently Completed Goals\\n\";\n recentCompleted.forEach((goal) => {\n const completedDate = goal.completedAt\n ? new Date(goal.completedAt).toLocaleDateString()\n : \"Unknown date\";\n output += `- ${goal.name} (completed ${completedDate})\\n`;\n });\n output += \"\\n\";\n }\n\n const totalActive = activeGoals.length;\n const totalCompleted = completedGoals.length;\n\n output += `## Summary\\n`;\n output += `- Active goals: ${totalActive}\\n`;\n output += `- Completed goals: ${totalCompleted}\\n`;\n\n if (activeGoals.length === 0 && completedGoals.length === 0) {\n output = \"No goals have been set yet. Consider creating some goals to track progress!\";\n }\n\n return {\n text: output.trim(),\n data: {\n activeGoalCount: totalActive,\n completedGoalCount: totalCompleted,\n },\n values: {\n activeGoalCount: totalActive.toString(),\n completedGoalCount: totalCompleted.toString(),\n },\n };\n } catch (error) {\n logger.error(\"Error in goals provider:\", error);\n return {\n text: \"Unable to retrieve goals information at this time.\",\n data: {},\n values: {},\n };\n }\n },\n};\n\nexport default goalsProvider;\n",
98
- "import type { IAgentRuntime } from \"@elizaos/core\";\nimport {\n createMessageMemory,\n logger,\n type TestCase,\n type TestSuite,\n type UUID,\n} from \"@elizaos/core\";\n\nexport const GoalsPluginE2ETestSuite: TestSuite = {\n name: \"Goals Plugin E2E Tests\",\n tests: [\n {\n name: \"should create and complete a goal successfully\",\n fn: async (runtime: IAgentRuntime) => {\n logger.info(\"Testing goal creation and completion flow...\");\n\n const { createGoalDataService } = await import(\"../../services/goalDataService\");\n const dataService = createGoalDataService(runtime);\n\n // Create test data\n const testEntityId = `test-entity-${Date.now()}` as UUID;\n\n // Create a goal\n const goalName = `Test Goal ${Date.now()}`;\n const createdGoalId = await dataService.createGoal({\n agentId: runtime.agentId,\n ownerType: \"entity\",\n ownerId: testEntityId,\n name: goalName,\n description: \"Test goal description\",\n metadata: {},\n tags: [\"test\"],\n });\n\n if (!createdGoalId) {\n throw new Error(\"Failed to create goal\");\n }\n logger.info(`✓ Goal created with ID: ${createdGoalId}`);\n\n // Verify goal was created\n const goal = await dataService.getGoal(createdGoalId);\n if (!goal) {\n throw new Error(\"Created goal not found\");\n }\n if (goal.name !== goalName) {\n throw new Error(`Goal name mismatch. Expected: ${goalName}, Got: ${goal.name}`);\n }\n if (goal.isCompleted) {\n throw new Error(\"New goal should not be completed\");\n }\n logger.info(\"✓ Goal retrieved and verified\");\n\n // Complete the goal\n await dataService.updateGoal(createdGoalId, {\n isCompleted: true,\n completedAt: new Date(),\n });\n\n // Verify completion\n const completedGoal = await dataService.getGoal(createdGoalId);\n if (!completedGoal?.isCompleted) {\n throw new Error(\"Goal should be marked as completed\");\n }\n logger.info(\"✓ Goal marked as completed\");\n\n // Clean up\n await dataService.deleteGoal(createdGoalId);\n logger.info(\"✅ Goal creation and completion flow successful\");\n },\n },\n {\n name: \"should get uncompleted goals correctly\",\n fn: async (runtime: IAgentRuntime) => {\n logger.info(\"Testing uncompleted goals retrieval...\");\n\n const { createGoalDataService } = await import(\"../../services/goalDataService\");\n const dataService = createGoalDataService(runtime);\n\n // Create test data\n const testEntityId = `test-entity-${Date.now()}` as UUID;\n\n // Create multiple goals\n const goal1Id = await dataService.createGoal({\n agentId: runtime.agentId,\n ownerType: \"entity\",\n ownerId: testEntityId,\n name: \"Active Goal 1\",\n metadata: {},\n tags: [\"test\"],\n });\n\n const goal2Id = await dataService.createGoal({\n agentId: runtime.agentId,\n ownerType: \"entity\",\n ownerId: testEntityId,\n name: \"Active Goal 2\",\n metadata: {},\n tags: [\"test\"],\n });\n\n logger.info(\"✓ Created two active goals\");\n\n // Get uncompleted goals\n const uncompletedGoals = await dataService.getUncompletedGoals(\"entity\", testEntityId);\n\n if (uncompletedGoals.length !== 2) {\n throw new Error(`Expected 2 uncompleted goals, got ${uncompletedGoals.length}`);\n }\n logger.info(\"✓ Retrieved correct number of uncompleted goals\");\n\n // Complete one goal\n if (!goal1Id) {\n throw new Error(\"goal1Id is null or undefined\");\n }\n await dataService.updateGoal(goal1Id, {\n isCompleted: true,\n completedAt: new Date(),\n });\n\n // Check uncompleted goals again\n const remainingGoals = await dataService.getUncompletedGoals(\"entity\", testEntityId);\n if (remainingGoals.length !== 1) {\n throw new Error(`Expected 1 uncompleted goal, got ${remainingGoals.length}`);\n }\n logger.info(\"✓ Uncompleted goals updated correctly after completion\");\n\n // Clean up\n if (goal1Id) await dataService.deleteGoal(goal1Id);\n if (goal2Id) await dataService.deleteGoal(goal2Id);\n logger.info(\"✅ Uncompleted goals retrieval successful\");\n },\n },\n {\n name: \"should filter goals by tags correctly\",\n fn: async (runtime: IAgentRuntime) => {\n logger.info(\"Testing goal tag filtering...\");\n\n const { createGoalDataService } = await import(\"../../services/goalDataService\");\n const dataService = createGoalDataService(runtime);\n\n // Create test data\n const testEntityId = `test-entity-${Date.now()}` as UUID;\n\n // Create goals with different tags\n const workGoalId = await dataService.createGoal({\n agentId: runtime.agentId,\n ownerType: \"entity\",\n ownerId: testEntityId,\n name: \"Work Goal\",\n metadata: {},\n tags: [\"work\", \"important\"],\n });\n\n const personalGoalId = await dataService.createGoal({\n agentId: runtime.agentId,\n ownerType: \"entity\",\n ownerId: testEntityId,\n name: \"Personal Goal\",\n metadata: {},\n tags: [\"personal\", \"health\"],\n });\n\n logger.info(\"✓ Created goals with different tags\");\n\n // Filter by 'work' tag\n const workGoals = await dataService.getGoals({\n ownerType: \"entity\",\n ownerId: testEntityId,\n tags: [\"work\"],\n });\n\n if (workGoals.length !== 1) {\n throw new Error(`Expected 1 work goal, got ${workGoals.length}`);\n }\n if (workGoals[0].name !== \"Work Goal\") {\n throw new Error(\"Wrong goal returned for work tag filter\");\n }\n logger.info(\"✓ Tag filtering working correctly\");\n\n // Clean up\n if (workGoalId) await dataService.deleteGoal(workGoalId);\n if (personalGoalId) await dataService.deleteGoal(personalGoalId);\n logger.info(\"✅ Goal tag filtering successful\");\n },\n },\n {\n name: \"should process CREATE_GOAL action correctly\",\n fn: async (runtime: IAgentRuntime) => {\n logger.info(\"Testing CREATE_GOAL action...\");\n\n // Find the action\n const createAction = runtime.actions.find((a) => a.name === \"CREATE_GOAL\");\n if (!createAction) {\n throw new Error(\"CREATE_GOAL action not found\");\n }\n logger.info(\"✓ CREATE_GOAL action found\");\n\n // Create test message\n const testRoomId = `test-room-${Date.now()}` as UUID;\n const testEntityId = `test-entity-${Date.now()}` as UUID;\n const testMessage = createMessageMemory({\n entityId: testEntityId,\n agentId: runtime.agentId,\n roomId: testRoomId,\n content: {\n text: \"I want to set a goal to learn Spanish\",\n source: \"test\",\n },\n });\n\n // Validate the action\n const isValid = await createAction.validate(runtime, testMessage);\n if (!isValid) {\n throw new Error(\"CREATE_GOAL action validation failed\");\n }\n logger.info(\"✓ CREATE_GOAL action validated\");\n\n logger.info(\"✅ CREATE_GOAL action test completed\");\n },\n },\n ] as TestCase[],\n};\n"
99
- ],
100
- "mappings": "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",
101
- "debugId": "040C0DE543D9A4C864756E2164756E21",
102
- "names": []
103
- }