@prisma-next/extension-pgvector 0.3.0-dev.33 → 0.3.0-dev.36

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 (68) hide show
  1. package/README.md +11 -8
  2. package/dist/codec-types.d.mts +41 -0
  3. package/dist/codec-types.d.mts.map +1 -0
  4. package/dist/codec-types.mjs +1 -0
  5. package/dist/{exports/column-types.d.ts → column-types.d.mts} +14 -15
  6. package/dist/column-types.d.mts.map +1 -0
  7. package/dist/column-types.mjs +36 -0
  8. package/dist/column-types.mjs.map +1 -0
  9. package/dist/constants-BmZpaev5.mjs +13 -0
  10. package/dist/constants-BmZpaev5.mjs.map +1 -0
  11. package/dist/control.d.mts +7 -0
  12. package/dist/control.d.mts.map +1 -0
  13. package/dist/control.mjs +49 -0
  14. package/dist/control.mjs.map +1 -0
  15. package/dist/descriptor-meta-BADTQp0u.mjs +57 -0
  16. package/dist/descriptor-meta-BADTQp0u.mjs.map +1 -0
  17. package/dist/operation-types.d.mts +32 -0
  18. package/dist/operation-types.d.mts.map +1 -0
  19. package/dist/operation-types.mjs +1 -0
  20. package/dist/pack.d.mts +46 -0
  21. package/dist/pack.d.mts.map +1 -0
  22. package/dist/pack.mjs +9 -0
  23. package/dist/pack.mjs.map +1 -0
  24. package/dist/runtime.d.mts +7 -0
  25. package/dist/runtime.d.mts.map +1 -0
  26. package/dist/runtime.mjs +74 -0
  27. package/dist/runtime.mjs.map +1 -0
  28. package/package.json +32 -44
  29. package/src/core/descriptor-meta.ts +6 -20
  30. package/src/exports/control.ts +2 -13
  31. package/src/exports/runtime.ts +14 -38
  32. package/dist/chunk-DSJTFXJR.js +0 -73
  33. package/dist/chunk-DSJTFXJR.js.map +0 -1
  34. package/dist/chunk-MUHUVAQX.js +0 -9
  35. package/dist/chunk-MUHUVAQX.js.map +0 -1
  36. package/dist/core/codecs.d.ts +0 -23
  37. package/dist/core/codecs.d.ts.map +0 -1
  38. package/dist/core/constants.d.ts +0 -9
  39. package/dist/core/constants.d.ts.map +0 -1
  40. package/dist/core/descriptor-meta.d.ts +0 -61
  41. package/dist/core/descriptor-meta.d.ts.map +0 -1
  42. package/dist/exports/codec-types.d.ts +0 -7
  43. package/dist/exports/codec-types.d.ts.map +0 -1
  44. package/dist/exports/codec-types.js +0 -1
  45. package/dist/exports/codec-types.js.map +0 -1
  46. package/dist/exports/column-types.d.ts.map +0 -1
  47. package/dist/exports/column-types.js +0 -27
  48. package/dist/exports/column-types.js.map +0 -1
  49. package/dist/exports/control.d.ts +0 -9
  50. package/dist/exports/control.d.ts.map +0 -1
  51. package/dist/exports/control.js +0 -67
  52. package/dist/exports/control.js.map +0 -1
  53. package/dist/exports/operation-types.d.ts +0 -7
  54. package/dist/exports/operation-types.d.ts.map +0 -1
  55. package/dist/exports/operation-types.js +0 -1
  56. package/dist/exports/operation-types.js.map +0 -1
  57. package/dist/exports/pack.d.ts +0 -60
  58. package/dist/exports/pack.d.ts.map +0 -1
  59. package/dist/exports/pack.js +0 -11
  60. package/dist/exports/pack.js.map +0 -1
  61. package/dist/exports/runtime.d.ts +0 -8
  62. package/dist/exports/runtime.d.ts.map +0 -1
  63. package/dist/exports/runtime.js +0 -112
  64. package/dist/exports/runtime.js.map +0 -1
  65. package/dist/types/codec-types.d.ts +0 -34
  66. package/dist/types/codec-types.d.ts.map +0 -1
  67. package/dist/types/operation-types.d.ts +0 -31
  68. package/dist/types/operation-types.d.ts.map +0 -1
@@ -1,4 +1,3 @@
1
- import type { ExtensionPackRef } from '@prisma-next/contract/framework-components';
2
1
  import type { SqlOperationSignature } from '@prisma-next/sql-operations';
3
2
 
4
3
  const pgvectorTypeId = 'pg/vector@1' as const;
@@ -9,10 +8,6 @@ const cosineLowering = {
9
8
  template: '1 - ({{self}} <=> {{arg0}})',
10
9
  } as const;
11
10
 
12
- /**
13
- * Shared operation definition used by both pack metadata and runtime descriptor.
14
- * Frozen to prevent accidental mutation.
15
- */
16
11
  const cosineDistanceOperation = Object.freeze({
17
12
  method: 'cosineDistance',
18
13
  args: [{ kind: 'param' }],
@@ -20,6 +15,11 @@ const cosineDistanceOperation = Object.freeze({
20
15
  lowering: cosineLowering,
21
16
  } as const);
22
17
 
18
+ export const pgvectorOperationSignature: SqlOperationSignature = {
19
+ forTypeId: pgvectorTypeId,
20
+ ...cosineDistanceOperation,
21
+ };
22
+
23
23
  export const pgvectorPackMeta = {
24
24
  kind: 'extension',
25
25
  id: 'pgvector',
@@ -45,9 +45,6 @@ export const pgvectorPackMeta = {
45
45
  alias: 'Vector',
46
46
  },
47
47
  ],
48
- // Parameterized codec renderers for type emission.
49
- // The renderer template produces precise TypeScript types like Vector<1536>
50
- // when columns have typeParams with a `length` property.
51
48
  parameterized: {
52
49
  [pgvectorTypeId]: 'Vector<{{length}}>',
53
50
  },
@@ -63,15 +60,4 @@ export const pgvectorPackMeta = {
63
60
  { typeId: pgvectorTypeId, familyId: 'sql', targetId: 'postgres', nativeType: 'vector' },
64
61
  ],
65
62
  },
66
- operations: [
67
- {
68
- for: pgvectorTypeId,
69
- ...cosineDistanceOperation,
70
- },
71
- ],
72
- } as const satisfies ExtensionPackRef<'sql', 'postgres'>;
73
-
74
- export const pgvectorRuntimeOperation: SqlOperationSignature = {
75
- forTypeId: pgvectorTypeId,
76
- ...cosineDistanceOperation,
77
- };
63
+ } as const;
@@ -4,12 +4,8 @@ import type {
4
4
  SqlControlExtensionDescriptor,
5
5
  } from '@prisma-next/family-sql/control';
6
6
  import type { SqlSchemaIR } from '@prisma-next/sql-schema-ir/types';
7
- import { pgvectorPackMeta } from '../core/descriptor-meta';
7
+ import { pgvectorOperationSignature, pgvectorPackMeta } from '../core/descriptor-meta';
8
8
 
9
- /**
10
- * Pure verification hook: checks whether the 'vector' extension is installed
11
- * based on the in-memory schema IR (no DB I/O).
12
- */
13
9
  function verifyVectorExtensionInstalled(schema: SqlSchemaIR): readonly SchemaIssue[] {
14
10
  if (!schema.extensions.includes('vector')) {
15
11
  return [
@@ -23,10 +19,6 @@ function verifyVectorExtensionInstalled(schema: SqlSchemaIR): readonly SchemaIss
23
19
  return [];
24
20
  }
25
21
 
26
- /**
27
- * Database dependencies for the pgvector extension.
28
- * Declares the 'vector' Postgres extension as a required dependency.
29
- */
30
22
  const pgvectorDatabaseDependencies: ComponentDatabaseDependencies<unknown> = {
31
23
  init: [
32
24
  {
@@ -64,12 +56,9 @@ const pgvectorDatabaseDependencies: ComponentDatabaseDependencies<unknown> = {
64
56
  ],
65
57
  };
66
58
 
67
- /**
68
- * pgvector extension descriptor for CLI config.
69
- * Declares database dependencies for the 'vector' Postgres extension.
70
- */
71
59
  const pgvectorExtensionDescriptor: SqlControlExtensionDescriptor<'postgres'> = {
72
60
  ...pgvectorPackMeta,
61
+ operationSignatures: () => [pgvectorOperationSignature],
73
62
  databaseDependencies: pgvectorDatabaseDependencies,
74
63
  create: () => ({
75
64
  familyId: 'sql' as const,
@@ -1,15 +1,12 @@
1
- import type { SqlOperationSignature } from '@prisma-next/sql-operations';
2
- import type { CodecRegistry } from '@prisma-next/sql-relational-core/ast';
3
1
  import { createCodecRegistry } from '@prisma-next/sql-relational-core/ast';
4
2
  import type {
5
3
  RuntimeParameterizedCodecDescriptor,
6
4
  SqlRuntimeExtensionDescriptor,
7
- SqlRuntimeExtensionInstance,
8
5
  } from '@prisma-next/sql-runtime';
9
6
  import { type as arktype } from 'arktype';
10
7
  import { codecDefinitions } from '../core/codecs';
11
8
  import { VECTOR_CODEC_ID, VECTOR_MAX_DIM } from '../core/constants';
12
- import { pgvectorPackMeta, pgvectorRuntimeOperation } from '../core/descriptor-meta';
9
+ import { pgvectorOperationSignature, pgvectorPackMeta } from '../core/descriptor-meta';
13
10
 
14
11
  const vectorParamsSchema = arktype({
15
12
  length: 'number',
@@ -24,9 +21,6 @@ const vectorParamsSchema = arktype({
24
21
  return true;
25
22
  });
26
23
 
27
- /**
28
- * Pre-allocated parameterized codec descriptors to avoid per-call allocations.
29
- */
30
24
  const parameterizedCodecDescriptors = [
31
25
  {
32
26
  codecId: VECTOR_CODEC_ID,
@@ -36,46 +30,28 @@ const parameterizedCodecDescriptors = [
36
30
  RuntimeParameterizedCodecDescriptor<{ readonly length: number }>
37
31
  >;
38
32
 
39
- /**
40
- * pgvector SQL runtime extension instance.
41
- * Provides codecs and operations for vector data type and similarity operations.
42
- */
43
- class PgVectorRuntimeExtensionInstance implements SqlRuntimeExtensionInstance<'postgres'> {
44
- readonly familyId = 'sql' as const;
45
- readonly targetId = 'postgres' as const;
46
-
47
- codecs(): CodecRegistry {
48
- const registry = createCodecRegistry();
49
- // Register all codecs from codecDefinitions
50
- for (const def of Object.values(codecDefinitions)) {
51
- registry.register(def.codec);
52
- }
53
- return registry;
54
- }
55
-
56
- operations(): ReadonlyArray<SqlOperationSignature> {
57
- return [pgvectorRuntimeOperation];
58
- }
59
-
60
- parameterizedCodecs(): ReadonlyArray<
61
- RuntimeParameterizedCodecDescriptor<{ readonly length: number }>
62
- > {
63
- return parameterizedCodecDescriptors;
33
+ function createPgvectorCodecRegistry() {
34
+ const registry = createCodecRegistry();
35
+ for (const def of Object.values(codecDefinitions)) {
36
+ registry.register(def.codec);
64
37
  }
38
+ return registry;
65
39
  }
66
40
 
67
- /**
68
- * pgvector SQL runtime extension descriptor.
69
- * Provides metadata and factory for creating runtime extension instances.
70
- */
71
41
  const pgvectorRuntimeDescriptor: SqlRuntimeExtensionDescriptor<'postgres'> = {
72
42
  kind: 'extension' as const,
73
43
  id: pgvectorPackMeta.id,
74
44
  version: pgvectorPackMeta.version,
75
45
  familyId: 'sql' as const,
76
46
  targetId: 'postgres' as const,
77
- create(): SqlRuntimeExtensionInstance<'postgres'> {
78
- return new PgVectorRuntimeExtensionInstance();
47
+ codecs: createPgvectorCodecRegistry,
48
+ operationSignatures: () => [pgvectorOperationSignature],
49
+ parameterizedCodecs: () => parameterizedCodecDescriptors,
50
+ create() {
51
+ return {
52
+ familyId: 'sql' as const,
53
+ targetId: 'postgres' as const,
54
+ };
79
55
  },
80
56
  };
81
57
 
@@ -1,73 +0,0 @@
1
- // src/core/descriptor-meta.ts
2
- var pgvectorTypeId = "pg/vector@1";
3
- var cosineLowering = {
4
- targetFamily: "sql",
5
- strategy: "function",
6
- template: "1 - ({{self}} <=> {{arg0}})"
7
- };
8
- var cosineDistanceOperation = Object.freeze({
9
- method: "cosineDistance",
10
- args: [{ kind: "param" }],
11
- returns: { kind: "builtin", type: "number" },
12
- lowering: cosineLowering
13
- });
14
- var pgvectorPackMeta = {
15
- kind: "extension",
16
- id: "pgvector",
17
- familyId: "sql",
18
- targetId: "postgres",
19
- version: "0.0.1",
20
- capabilities: {
21
- postgres: {
22
- "pgvector/cosine": true
23
- }
24
- },
25
- types: {
26
- codecTypes: {
27
- import: {
28
- package: "@prisma-next/extension-pgvector/codec-types",
29
- named: "CodecTypes",
30
- alias: "PgVectorTypes"
31
- },
32
- typeImports: [
33
- {
34
- package: "@prisma-next/extension-pgvector/codec-types",
35
- named: "Vector",
36
- alias: "Vector"
37
- }
38
- ],
39
- // Parameterized codec renderers for type emission.
40
- // The renderer template produces precise TypeScript types like Vector<1536>
41
- // when columns have typeParams with a `length` property.
42
- parameterized: {
43
- [pgvectorTypeId]: "Vector<{{length}}>"
44
- }
45
- },
46
- operationTypes: {
47
- import: {
48
- package: "@prisma-next/extension-pgvector/operation-types",
49
- named: "OperationTypes",
50
- alias: "PgVectorOperationTypes"
51
- }
52
- },
53
- storage: [
54
- { typeId: pgvectorTypeId, familyId: "sql", targetId: "postgres", nativeType: "vector" }
55
- ]
56
- },
57
- operations: [
58
- {
59
- for: pgvectorTypeId,
60
- ...cosineDistanceOperation
61
- }
62
- ]
63
- };
64
- var pgvectorRuntimeOperation = {
65
- forTypeId: pgvectorTypeId,
66
- ...cosineDistanceOperation
67
- };
68
-
69
- export {
70
- pgvectorPackMeta,
71
- pgvectorRuntimeOperation
72
- };
73
- //# sourceMappingURL=chunk-DSJTFXJR.js.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../src/core/descriptor-meta.ts"],"sourcesContent":["import type { ExtensionPackRef } from '@prisma-next/contract/framework-components';\nimport type { SqlOperationSignature } from '@prisma-next/sql-operations';\n\nconst pgvectorTypeId = 'pg/vector@1' as const;\n\nconst cosineLowering = {\n targetFamily: 'sql',\n strategy: 'function',\n template: '1 - ({{self}} <=> {{arg0}})',\n} as const;\n\n/**\n * Shared operation definition used by both pack metadata and runtime descriptor.\n * Frozen to prevent accidental mutation.\n */\nconst cosineDistanceOperation = Object.freeze({\n method: 'cosineDistance',\n args: [{ kind: 'param' }],\n returns: { kind: 'builtin', type: 'number' },\n lowering: cosineLowering,\n} as const);\n\nexport const pgvectorPackMeta = {\n kind: 'extension',\n id: 'pgvector',\n familyId: 'sql',\n targetId: 'postgres',\n version: '0.0.1',\n capabilities: {\n postgres: {\n 'pgvector/cosine': true,\n },\n },\n types: {\n codecTypes: {\n import: {\n package: '@prisma-next/extension-pgvector/codec-types',\n named: 'CodecTypes',\n alias: 'PgVectorTypes',\n },\n typeImports: [\n {\n package: '@prisma-next/extension-pgvector/codec-types',\n named: 'Vector',\n alias: 'Vector',\n },\n ],\n // Parameterized codec renderers for type emission.\n // The renderer template produces precise TypeScript types like Vector<1536>\n // when columns have typeParams with a `length` property.\n parameterized: {\n [pgvectorTypeId]: 'Vector<{{length}}>',\n },\n },\n operationTypes: {\n import: {\n package: '@prisma-next/extension-pgvector/operation-types',\n named: 'OperationTypes',\n alias: 'PgVectorOperationTypes',\n },\n },\n storage: [\n { typeId: pgvectorTypeId, familyId: 'sql', targetId: 'postgres', nativeType: 'vector' },\n ],\n },\n operations: [\n {\n for: pgvectorTypeId,\n ...cosineDistanceOperation,\n },\n ],\n} as const satisfies ExtensionPackRef<'sql', 'postgres'>;\n\nexport const pgvectorRuntimeOperation: SqlOperationSignature = {\n forTypeId: pgvectorTypeId,\n ...cosineDistanceOperation,\n};\n"],"mappings":";AAGA,IAAM,iBAAiB;AAEvB,IAAM,iBAAiB;AAAA,EACrB,cAAc;AAAA,EACd,UAAU;AAAA,EACV,UAAU;AACZ;AAMA,IAAM,0BAA0B,OAAO,OAAO;AAAA,EAC5C,QAAQ;AAAA,EACR,MAAM,CAAC,EAAE,MAAM,QAAQ,CAAC;AAAA,EACxB,SAAS,EAAE,MAAM,WAAW,MAAM,SAAS;AAAA,EAC3C,UAAU;AACZ,CAAU;AAEH,IAAM,mBAAmB;AAAA,EAC9B,MAAM;AAAA,EACN,IAAI;AAAA,EACJ,UAAU;AAAA,EACV,UAAU;AAAA,EACV,SAAS;AAAA,EACT,cAAc;AAAA,IACZ,UAAU;AAAA,MACR,mBAAmB;AAAA,IACrB;AAAA,EACF;AAAA,EACA,OAAO;AAAA,IACL,YAAY;AAAA,MACV,QAAQ;AAAA,QACN,SAAS;AAAA,QACT,OAAO;AAAA,QACP,OAAO;AAAA,MACT;AAAA,MACA,aAAa;AAAA,QACX;AAAA,UACE,SAAS;AAAA,UACT,OAAO;AAAA,UACP,OAAO;AAAA,QACT;AAAA,MACF;AAAA;AAAA;AAAA;AAAA,MAIA,eAAe;AAAA,QACb,CAAC,cAAc,GAAG;AAAA,MACpB;AAAA,IACF;AAAA,IACA,gBAAgB;AAAA,MACd,QAAQ;AAAA,QACN,SAAS;AAAA,QACT,OAAO;AAAA,QACP,OAAO;AAAA,MACT;AAAA,IACF;AAAA,IACA,SAAS;AAAA,MACP,EAAE,QAAQ,gBAAgB,UAAU,OAAO,UAAU,YAAY,YAAY,SAAS;AAAA,IACxF;AAAA,EACF;AAAA,EACA,YAAY;AAAA,IACV;AAAA,MACE,KAAK;AAAA,MACL,GAAG;AAAA,IACL;AAAA,EACF;AACF;AAEO,IAAM,2BAAkD;AAAA,EAC7D,WAAW;AAAA,EACX,GAAG;AACL;","names":[]}
@@ -1,9 +0,0 @@
1
- // src/core/constants.ts
2
- var VECTOR_CODEC_ID = "pg/vector@1";
3
- var VECTOR_MAX_DIM = 16e3;
4
-
5
- export {
6
- VECTOR_CODEC_ID,
7
- VECTOR_MAX_DIM
8
- };
9
- //# sourceMappingURL=chunk-MUHUVAQX.js.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../src/core/constants.ts"],"sourcesContent":["/**\n * Codec ID for pgvector's vector type.\n */\nexport const VECTOR_CODEC_ID = 'pg/vector@1' as const;\n\n/**\n * Maximum dimension for pgvector vectors (VECTOR_MAX_DIM from pgvector).\n */\nexport const VECTOR_MAX_DIM = 16000;\n"],"mappings":";AAGO,IAAM,kBAAkB;AAKxB,IAAM,iBAAiB;","names":[]}
@@ -1,23 +0,0 @@
1
- /**
2
- * Vector codec implementation for pgvector extension.
3
- *
4
- * Provides encoding/decoding for the `vector` PostgreSQL type.
5
- * Wire format is a string like `[1,2,3]` (PostgreSQL vector text format).
6
- */
7
- declare const codecs: import("@prisma-next/sql-relational-core/ast").CodecDefBuilder<{} & Record<"vector", import("@prisma-next/sql-relational-core/ast").Codec<"pg/vector@1", string, number[]>>>;
8
- export declare const codecDefinitions: {
9
- readonly vector: {
10
- readonly typeId: "pg/vector@1";
11
- readonly scalar: "vector";
12
- readonly codec: import("@prisma-next/sql-relational-core/ast").Codec<"pg/vector@1", string, number[]>;
13
- readonly input: number[];
14
- readonly output: number[];
15
- readonly jsType: number[];
16
- };
17
- };
18
- export declare const dataTypes: {
19
- readonly vector: "pg/vector@1";
20
- };
21
- export type CodecTypes = typeof codecs.CodecTypes;
22
- export {};
23
- //# sourceMappingURL=codecs.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"codecs.d.ts","sourceRoot":"","sources":["../../src/core/codecs.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAqDH,QAAA,MAAM,MAAM,8KAA8C,CAAC;AAG3D,eAAO,MAAM,gBAAgB;;;;;;;;;CAA0B,CAAC;AACxD,eAAO,MAAM,SAAS;;CAAmB,CAAC;AAG1C,MAAM,MAAM,UAAU,GAAG,OAAO,MAAM,CAAC,UAAU,CAAC"}
@@ -1,9 +0,0 @@
1
- /**
2
- * Codec ID for pgvector's vector type.
3
- */
4
- export declare const VECTOR_CODEC_ID: "pg/vector@1";
5
- /**
6
- * Maximum dimension for pgvector vectors (VECTOR_MAX_DIM from pgvector).
7
- */
8
- export declare const VECTOR_MAX_DIM = 16000;
9
- //# sourceMappingURL=constants.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"constants.d.ts","sourceRoot":"","sources":["../../src/core/constants.ts"],"names":[],"mappings":"AAAA;;GAEG;AACH,eAAO,MAAM,eAAe,EAAG,aAAsB,CAAC;AAEtD;;GAEG;AACH,eAAO,MAAM,cAAc,QAAQ,CAAC"}
@@ -1,61 +0,0 @@
1
- import type { SqlOperationSignature } from '@prisma-next/sql-operations';
2
- export declare const pgvectorPackMeta: {
3
- readonly kind: "extension";
4
- readonly id: "pgvector";
5
- readonly familyId: "sql";
6
- readonly targetId: "postgres";
7
- readonly version: "0.0.1";
8
- readonly capabilities: {
9
- readonly postgres: {
10
- readonly 'pgvector/cosine': true;
11
- };
12
- };
13
- readonly types: {
14
- readonly codecTypes: {
15
- readonly import: {
16
- readonly package: "@prisma-next/extension-pgvector/codec-types";
17
- readonly named: "CodecTypes";
18
- readonly alias: "PgVectorTypes";
19
- };
20
- readonly typeImports: readonly [{
21
- readonly package: "@prisma-next/extension-pgvector/codec-types";
22
- readonly named: "Vector";
23
- readonly alias: "Vector";
24
- }];
25
- readonly parameterized: {
26
- readonly "pg/vector@1": "Vector<{{length}}>";
27
- };
28
- };
29
- readonly operationTypes: {
30
- readonly import: {
31
- readonly package: "@prisma-next/extension-pgvector/operation-types";
32
- readonly named: "OperationTypes";
33
- readonly alias: "PgVectorOperationTypes";
34
- };
35
- };
36
- readonly storage: readonly [{
37
- readonly typeId: "pg/vector@1";
38
- readonly familyId: "sql";
39
- readonly targetId: "postgres";
40
- readonly nativeType: "vector";
41
- }];
42
- };
43
- readonly operations: readonly [{
44
- readonly method: "cosineDistance";
45
- readonly args: readonly [{
46
- readonly kind: "param";
47
- }];
48
- readonly returns: {
49
- readonly kind: "builtin";
50
- readonly type: "number";
51
- };
52
- readonly lowering: {
53
- readonly targetFamily: "sql";
54
- readonly strategy: "function";
55
- readonly template: "1 - ({{self}} <=> {{arg0}})";
56
- };
57
- readonly for: "pg/vector@1";
58
- }];
59
- };
60
- export declare const pgvectorRuntimeOperation: SqlOperationSignature;
61
- //# sourceMappingURL=descriptor-meta.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"descriptor-meta.d.ts","sourceRoot":"","sources":["../../src/core/descriptor-meta.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,qBAAqB,EAAE,MAAM,6BAA6B,CAAC;AAqBzE,eAAO,MAAM,gBAAgB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CAiD2B,CAAC;AAEzD,eAAO,MAAM,wBAAwB,EAAE,qBAGtC,CAAC"}
@@ -1,7 +0,0 @@
1
- /**
2
- * Codec type definitions for pgvector extension.
3
- *
4
- * Re-export from types module for public API.
5
- */
6
- export type { CodecTypes, Vector } from '../types/codec-types';
7
- //# sourceMappingURL=codec-types.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"codec-types.d.ts","sourceRoot":"","sources":["../../src/exports/codec-types.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH,YAAY,EAAE,UAAU,EAAE,MAAM,EAAE,MAAM,sBAAsB,CAAC"}
@@ -1 +0,0 @@
1
- //# sourceMappingURL=codec-types.js.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":[],"sourcesContent":[],"mappings":"","names":[]}
@@ -1 +0,0 @@
1
- {"version":3,"file":"column-types.d.ts","sourceRoot":"","sources":["../../src/exports/column-types.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAEH,OAAO,KAAK,EAAE,oBAAoB,EAAE,MAAM,iCAAiC,CAAC;AAG5E;;;GAGG;AACH,eAAO,MAAM,YAAY;;;CAGgB,CAAC;AAE1C;;;;;;;;;;;;GAYG;AACH,wBAAgB,MAAM,CAAC,CAAC,SAAS,MAAM,EACrC,MAAM,EAAE,CAAC,GACR,oBAAoB,GAAG;IAAE,QAAQ,CAAC,UAAU,EAAE;QAAE,QAAQ,CAAC,MAAM,EAAE,CAAC,CAAA;KAAE,CAAA;CAAE,CAWxE"}
@@ -1,27 +0,0 @@
1
- import {
2
- VECTOR_CODEC_ID,
3
- VECTOR_MAX_DIM
4
- } from "../chunk-MUHUVAQX.js";
5
-
6
- // src/exports/column-types.ts
7
- var vectorColumn = {
8
- codecId: VECTOR_CODEC_ID,
9
- nativeType: "vector"
10
- };
11
- function vector(length) {
12
- if (!Number.isInteger(length) || length < 1 || length > VECTOR_MAX_DIM) {
13
- throw new RangeError(
14
- `pgvector: dimension must be an integer in [1, ${VECTOR_MAX_DIM}], got ${length}`
15
- );
16
- }
17
- return {
18
- codecId: VECTOR_CODEC_ID,
19
- nativeType: `vector(${length})`,
20
- typeParams: { length }
21
- };
22
- }
23
- export {
24
- vector,
25
- vectorColumn
26
- };
27
- //# sourceMappingURL=column-types.js.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../../src/exports/column-types.ts"],"sourcesContent":["/**\n * Column type descriptors for pgvector extension.\n *\n * These descriptors provide both codecId and nativeType for use in contract authoring.\n * They are derived from the same source of truth as codec definitions and manifests.\n */\n\nimport type { ColumnTypeDescriptor } from '@prisma-next/contract-authoring';\nimport { VECTOR_CODEC_ID, VECTOR_MAX_DIM } from '../core/constants';\n\n/**\n * Static vector column descriptor without dimension.\n * Use `vector(N)` for dimensioned vectors that produce `vector(N)` DDL.\n */\nexport const vectorColumn = {\n codecId: VECTOR_CODEC_ID,\n nativeType: 'vector',\n} as const satisfies ColumnTypeDescriptor;\n\n/**\n * Factory for creating dimensioned vector column descriptors.\n *\n * @example\n * ```typescript\n * .column('embedding', { type: vector(1536), nullable: false })\n * // Produces: nativeType: 'vector(1536)', typeParams: { length: 1536 }\n * ```\n *\n * @param length - The dimension of the vector (e.g., 1536 for OpenAI embeddings)\n * @returns A column type descriptor with `typeParams.length` set\n * @throws {RangeError} If length is not an integer in the range [1, VECTOR_MAX_DIM]\n */\nexport function vector<N extends number>(\n length: N,\n): ColumnTypeDescriptor & { readonly typeParams: { readonly length: N } } {\n if (!Number.isInteger(length) || length < 1 || length > VECTOR_MAX_DIM) {\n throw new RangeError(\n `pgvector: dimension must be an integer in [1, ${VECTOR_MAX_DIM}], got ${length}`,\n );\n }\n return {\n codecId: VECTOR_CODEC_ID,\n nativeType: `vector(${length})`,\n typeParams: { length },\n } as const;\n}\n"],"mappings":";;;;;;AAcO,IAAM,eAAe;AAAA,EAC1B,SAAS;AAAA,EACT,YAAY;AACd;AAeO,SAAS,OACd,QACwE;AACxE,MAAI,CAAC,OAAO,UAAU,MAAM,KAAK,SAAS,KAAK,SAAS,gBAAgB;AACtE,UAAM,IAAI;AAAA,MACR,iDAAiD,cAAc,UAAU,MAAM;AAAA,IACjF;AAAA,EACF;AACA,SAAO;AAAA,IACL,SAAS;AAAA,IACT,YAAY,UAAU,MAAM;AAAA,IAC5B,YAAY,EAAE,OAAO;AAAA,EACvB;AACF;","names":[]}
@@ -1,9 +0,0 @@
1
- import type { SqlControlExtensionDescriptor } from '@prisma-next/family-sql/control';
2
- /**
3
- * pgvector extension descriptor for CLI config.
4
- * Declares database dependencies for the 'vector' Postgres extension.
5
- */
6
- declare const pgvectorExtensionDescriptor: SqlControlExtensionDescriptor<'postgres'>;
7
- export { pgvectorExtensionDescriptor };
8
- export default pgvectorExtensionDescriptor;
9
- //# sourceMappingURL=control.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"control.d.ts","sourceRoot":"","sources":["../../src/exports/control.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAEV,6BAA6B,EAC9B,MAAM,iCAAiC,CAAC;AA8DzC;;;GAGG;AACH,QAAA,MAAM,2BAA2B,EAAE,6BAA6B,CAAC,UAAU,CAO1E,CAAC;AAEF,OAAO,EAAE,2BAA2B,EAAE,CAAC;AACvC,eAAe,2BAA2B,CAAC"}
@@ -1,67 +0,0 @@
1
- import {
2
- pgvectorPackMeta
3
- } from "../chunk-DSJTFXJR.js";
4
-
5
- // src/exports/control.ts
6
- function verifyVectorExtensionInstalled(schema) {
7
- if (!schema.extensions.includes("vector")) {
8
- return [
9
- {
10
- kind: "extension_missing",
11
- table: "",
12
- message: 'Extension "vector" is missing from database (required by pgvector)'
13
- }
14
- ];
15
- }
16
- return [];
17
- }
18
- var pgvectorDatabaseDependencies = {
19
- init: [
20
- {
21
- id: "postgres.extension.vector",
22
- label: "Enable vector extension",
23
- install: [
24
- {
25
- id: "extension.vector",
26
- label: 'Enable extension "vector"',
27
- summary: "Ensures the vector extension is available for pgvector operations",
28
- operationClass: "additive",
29
- target: { id: "postgres" },
30
- precheck: [
31
- {
32
- description: 'verify extension "vector" is not already enabled',
33
- sql: "SELECT NOT EXISTS (SELECT 1 FROM pg_extension WHERE extname = 'vector')"
34
- }
35
- ],
36
- execute: [
37
- {
38
- description: 'create extension "vector"',
39
- sql: "CREATE EXTENSION IF NOT EXISTS vector"
40
- }
41
- ],
42
- postcheck: [
43
- {
44
- description: 'confirm extension "vector" is enabled',
45
- sql: "SELECT EXISTS (SELECT 1 FROM pg_extension WHERE extname = 'vector')"
46
- }
47
- ]
48
- }
49
- ],
50
- verifyDatabaseDependencyInstalled: verifyVectorExtensionInstalled
51
- }
52
- ]
53
- };
54
- var pgvectorExtensionDescriptor = {
55
- ...pgvectorPackMeta,
56
- databaseDependencies: pgvectorDatabaseDependencies,
57
- create: () => ({
58
- familyId: "sql",
59
- targetId: "postgres"
60
- })
61
- };
62
- var control_default = pgvectorExtensionDescriptor;
63
- export {
64
- control_default as default,
65
- pgvectorExtensionDescriptor
66
- };
67
- //# sourceMappingURL=control.js.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../../src/exports/control.ts"],"sourcesContent":["import type { SchemaIssue } from '@prisma-next/core-control-plane/types';\nimport type {\n ComponentDatabaseDependencies,\n SqlControlExtensionDescriptor,\n} from '@prisma-next/family-sql/control';\nimport type { SqlSchemaIR } from '@prisma-next/sql-schema-ir/types';\nimport { pgvectorPackMeta } from '../core/descriptor-meta';\n\n/**\n * Pure verification hook: checks whether the 'vector' extension is installed\n * based on the in-memory schema IR (no DB I/O).\n */\nfunction verifyVectorExtensionInstalled(schema: SqlSchemaIR): readonly SchemaIssue[] {\n if (!schema.extensions.includes('vector')) {\n return [\n {\n kind: 'extension_missing',\n table: '',\n message: 'Extension \"vector\" is missing from database (required by pgvector)',\n },\n ];\n }\n return [];\n}\n\n/**\n * Database dependencies for the pgvector extension.\n * Declares the 'vector' Postgres extension as a required dependency.\n */\nconst pgvectorDatabaseDependencies: ComponentDatabaseDependencies<unknown> = {\n init: [\n {\n id: 'postgres.extension.vector',\n label: 'Enable vector extension',\n install: [\n {\n id: 'extension.vector',\n label: 'Enable extension \"vector\"',\n summary: 'Ensures the vector extension is available for pgvector operations',\n operationClass: 'additive',\n target: { id: 'postgres' },\n precheck: [\n {\n description: 'verify extension \"vector\" is not already enabled',\n sql: \"SELECT NOT EXISTS (SELECT 1 FROM pg_extension WHERE extname = 'vector')\",\n },\n ],\n execute: [\n {\n description: 'create extension \"vector\"',\n sql: 'CREATE EXTENSION IF NOT EXISTS vector',\n },\n ],\n postcheck: [\n {\n description: 'confirm extension \"vector\" is enabled',\n sql: \"SELECT EXISTS (SELECT 1 FROM pg_extension WHERE extname = 'vector')\",\n },\n ],\n },\n ],\n verifyDatabaseDependencyInstalled: verifyVectorExtensionInstalled,\n },\n ],\n};\n\n/**\n * pgvector extension descriptor for CLI config.\n * Declares database dependencies for the 'vector' Postgres extension.\n */\nconst pgvectorExtensionDescriptor: SqlControlExtensionDescriptor<'postgres'> = {\n ...pgvectorPackMeta,\n databaseDependencies: pgvectorDatabaseDependencies,\n create: () => ({\n familyId: 'sql' as const,\n targetId: 'postgres' as const,\n }),\n};\n\nexport { pgvectorExtensionDescriptor };\nexport default pgvectorExtensionDescriptor;\n"],"mappings":";;;;;AAYA,SAAS,+BAA+B,QAA6C;AACnF,MAAI,CAAC,OAAO,WAAW,SAAS,QAAQ,GAAG;AACzC,WAAO;AAAA,MACL;AAAA,QACE,MAAM;AAAA,QACN,OAAO;AAAA,QACP,SAAS;AAAA,MACX;AAAA,IACF;AAAA,EACF;AACA,SAAO,CAAC;AACV;AAMA,IAAM,+BAAuE;AAAA,EAC3E,MAAM;AAAA,IACJ;AAAA,MACE,IAAI;AAAA,MACJ,OAAO;AAAA,MACP,SAAS;AAAA,QACP;AAAA,UACE,IAAI;AAAA,UACJ,OAAO;AAAA,UACP,SAAS;AAAA,UACT,gBAAgB;AAAA,UAChB,QAAQ,EAAE,IAAI,WAAW;AAAA,UACzB,UAAU;AAAA,YACR;AAAA,cACE,aAAa;AAAA,cACb,KAAK;AAAA,YACP;AAAA,UACF;AAAA,UACA,SAAS;AAAA,YACP;AAAA,cACE,aAAa;AAAA,cACb,KAAK;AAAA,YACP;AAAA,UACF;AAAA,UACA,WAAW;AAAA,YACT;AAAA,cACE,aAAa;AAAA,cACb,KAAK;AAAA,YACP;AAAA,UACF;AAAA,QACF;AAAA,MACF;AAAA,MACA,mCAAmC;AAAA,IACrC;AAAA,EACF;AACF;AAMA,IAAM,8BAAyE;AAAA,EAC7E,GAAG;AAAA,EACH,sBAAsB;AAAA,EACtB,QAAQ,OAAO;AAAA,IACb,UAAU;AAAA,IACV,UAAU;AAAA,EACZ;AACF;AAGA,IAAO,kBAAQ;","names":[]}
@@ -1,7 +0,0 @@
1
- /**
2
- * Operation type definitions for pgvector extension.
3
- *
4
- * Re-export from types module for public API.
5
- */
6
- export type { OperationTypes } from '../types/operation-types';
7
- //# sourceMappingURL=operation-types.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"operation-types.d.ts","sourceRoot":"","sources":["../../src/exports/operation-types.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH,YAAY,EAAE,cAAc,EAAE,MAAM,0BAA0B,CAAC"}
@@ -1 +0,0 @@
1
- //# sourceMappingURL=operation-types.js.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":[],"sourcesContent":[],"mappings":"","names":[]}
@@ -1,60 +0,0 @@
1
- declare const pgvectorPack: {
2
- readonly kind: "extension";
3
- readonly id: "pgvector";
4
- readonly familyId: "sql";
5
- readonly targetId: "postgres";
6
- readonly version: "0.0.1";
7
- readonly capabilities: {
8
- readonly postgres: {
9
- readonly 'pgvector/cosine': true;
10
- };
11
- };
12
- readonly types: {
13
- readonly codecTypes: {
14
- readonly import: {
15
- readonly package: "@prisma-next/extension-pgvector/codec-types";
16
- readonly named: "CodecTypes";
17
- readonly alias: "PgVectorTypes";
18
- };
19
- readonly typeImports: readonly [{
20
- readonly package: "@prisma-next/extension-pgvector/codec-types";
21
- readonly named: "Vector";
22
- readonly alias: "Vector";
23
- }];
24
- readonly parameterized: {
25
- readonly "pg/vector@1": "Vector<{{length}}>";
26
- };
27
- };
28
- readonly operationTypes: {
29
- readonly import: {
30
- readonly package: "@prisma-next/extension-pgvector/operation-types";
31
- readonly named: "OperationTypes";
32
- readonly alias: "PgVectorOperationTypes";
33
- };
34
- };
35
- readonly storage: readonly [{
36
- readonly typeId: "pg/vector@1";
37
- readonly familyId: "sql";
38
- readonly targetId: "postgres";
39
- readonly nativeType: "vector";
40
- }];
41
- };
42
- readonly operations: readonly [{
43
- readonly method: "cosineDistance";
44
- readonly args: readonly [{
45
- readonly kind: "param";
46
- }];
47
- readonly returns: {
48
- readonly kind: "builtin";
49
- readonly type: "number";
50
- };
51
- readonly lowering: {
52
- readonly targetFamily: "sql";
53
- readonly strategy: "function";
54
- readonly template: "1 - ({{self}} <=> {{arg0}})";
55
- };
56
- readonly for: "pg/vector@1";
57
- }];
58
- };
59
- export default pgvectorPack;
60
- //# sourceMappingURL=pack.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"pack.d.ts","sourceRoot":"","sources":["../../src/exports/pack.ts"],"names":[],"mappings":"AAEA,QAAA,MAAM,YAAY;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CAAmB,CAAC;AAEtC,eAAe,YAAY,CAAC"}
@@ -1,11 +0,0 @@
1
- import {
2
- pgvectorPackMeta
3
- } from "../chunk-DSJTFXJR.js";
4
-
5
- // src/exports/pack.ts
6
- var pgvectorPack = pgvectorPackMeta;
7
- var pack_default = pgvectorPack;
8
- export {
9
- pack_default as default
10
- };
11
- //# sourceMappingURL=pack.js.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../../src/exports/pack.ts"],"sourcesContent":["import { pgvectorPackMeta } from '../core/descriptor-meta';\n\nconst pgvectorPack = pgvectorPackMeta;\n\nexport default pgvectorPack;\n"],"mappings":";;;;;AAEA,IAAM,eAAe;AAErB,IAAO,eAAQ;","names":[]}
@@ -1,8 +0,0 @@
1
- import type { SqlRuntimeExtensionDescriptor } from '@prisma-next/sql-runtime';
2
- /**
3
- * pgvector SQL runtime extension descriptor.
4
- * Provides metadata and factory for creating runtime extension instances.
5
- */
6
- declare const pgvectorRuntimeDescriptor: SqlRuntimeExtensionDescriptor<'postgres'>;
7
- export default pgvectorRuntimeDescriptor;
8
- //# sourceMappingURL=runtime.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"runtime.d.ts","sourceRoot":"","sources":["../../src/exports/runtime.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAEV,6BAA6B,EAE9B,MAAM,0BAA0B,CAAC;AA2DlC;;;GAGG;AACH,QAAA,MAAM,yBAAyB,EAAE,6BAA6B,CAAC,UAAU,CASxE,CAAC;AAEF,eAAe,yBAAyB,CAAC"}