@prisma-next/core-execution-plane 0.3.0-dev.4 → 0.3.0-dev.41

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/README.md CHANGED
@@ -4,12 +4,14 @@ Execution/runtime plane descriptor and instance types for Prisma Next.
4
4
 
5
5
  ## Overview
6
6
 
7
- This package provides TypeScript type definitions for execution/runtime-plane descriptors and instances. These types define the structure for runtime components (families, targets, adapters, drivers, extensions) that are used during query execution.
7
+ This package provides TypeScript type definitions for execution/runtime-plane descriptors and instances. These types define the structure for runtime components (families, targets, adapters, drivers, extensions) and the descriptors-only execution stack that is instantiated by applications.
8
8
 
9
9
  ## Responsibilities
10
10
 
11
11
  - **Runtime Instance Types**: Base interfaces for runtime plane instances (`RuntimeFamilyInstance`, `RuntimeTargetInstance`, `RuntimeAdapterInstance`, `RuntimeDriverInstance`, `RuntimeExtensionInstance`)
12
12
  - **Runtime Descriptor Types**: Type definitions for runtime plane descriptors (`RuntimeFamilyDescriptor`, `RuntimeTargetDescriptor`, `RuntimeAdapterDescriptor`, `RuntimeDriverDescriptor`, `RuntimeExtensionDescriptor`)
13
+ - **Execution Stack Types**: Descriptors-only execution stack (`ExecutionStack`) and instantiated stack (`ExecutionStackInstance`)
14
+ - **Stack Instantiation**: Helper to instantiate a stack (`instantiateExecutionStack`). When stack has a driver descriptor, instance includes unbound `driver`; caller connects at boundary then passes driver to runtime.
13
15
 
14
16
  ## Dependencies
15
17
 
@@ -77,6 +79,26 @@ import type { RuntimeAdapterInstance } from '@prisma-next/core-execution-plane/t
77
79
  const adapter: RuntimeAdapterInstance<'sql', 'postgres'> = adapterDescriptor.create();
78
80
  ```
79
81
 
82
+ ### Execution Stack
83
+
84
+ Execution stacks group runtime descriptors and are instantiated explicitly. When the stack has a driver descriptor, `instantiateExecutionStack` includes an unbound driver; connect at the boundary then create runtime:
85
+
86
+ ```typescript
87
+ import { createExecutionStack, instantiateExecutionStack } from '@prisma-next/core-execution-plane/stack';
88
+
89
+ const stack = createExecutionStack({
90
+ target: postgresTarget,
91
+ adapter: postgresAdapter,
92
+ driver: postgresDriver,
93
+ extensionPacks: [],
94
+ });
95
+
96
+ const stackInstance = instantiateExecutionStack(stack);
97
+ // stackInstance.driver is unbound; caller connects at boundary:
98
+ await stackInstance.driver!.connect(binding);
99
+ // then createRuntime({ stackInstance, context, driver: stackInstance.driver, ... })
100
+ ```
101
+
80
102
  ## Package Location
81
103
 
82
104
  This package is part of the **framework domain**, **core layer**, **runtime plane**:
@@ -87,7 +109,8 @@ This package is part of the **framework domain**, **core layer**, **runtime plan
87
109
 
88
110
  ## Related Documentation
89
111
 
90
- - `docs/architecture docs/adrs/ADR 152 - Runtime Plane Descriptors and Instances.md`: Complete ADR specification
112
+ - [ADR 152 Execution Plane Descriptors and Instances](../../../../docs/architecture%20docs/adrs/ADR%20152%20-%20Execution%20Plane%20Descriptors%20and%20Instances.md)
113
+ - [ADR 159 — Driver Terminology and Lifecycle](../../../../docs/architecture%20docs/adrs/ADR%20159%20-%20Driver%20Terminology%20and%20Lifecycle.md): Driver instantiation vs connection binding
91
114
  - `.cursor/rules/multi-plane-packages.mdc`: Multi-plane package structure
92
115
  - `packages/1-framework/1-core/migration/control-plane/README.md`: Control plane counterpart
93
116
 
@@ -0,0 +1,32 @@
1
+ import { a as RuntimeExtensionDescriptor, l as RuntimeTargetDescriptor, s as RuntimeFamilyDescriptor, t as RuntimeAdapterDescriptor } from "./types-DELFO9yp.mjs";
2
+
3
+ //#region src/framework-components.d.ts
4
+
5
+ /**
6
+ * Asserts that runtime component descriptors satisfy contract requirements.
7
+ *
8
+ * Routes the same framework composition through validation as control-plane:
9
+ * family, target, adapter, extensionPacks (all as descriptors with IDs).
10
+ *
11
+ * @throws Error if contract target doesn't match the provided target descriptor
12
+ * @throws Error if contract requires extension packs not provided in descriptors
13
+ */
14
+ declare function assertRuntimeContractRequirementsSatisfied<TFamilyId extends string, TTargetId extends string>({
15
+ contract,
16
+ family,
17
+ target,
18
+ adapter,
19
+ extensionPacks
20
+ }: {
21
+ readonly contract: {
22
+ readonly target: string;
23
+ readonly extensionPacks?: Record<string, unknown>;
24
+ };
25
+ readonly family: RuntimeFamilyDescriptor<TFamilyId>;
26
+ readonly target: RuntimeTargetDescriptor<TFamilyId, TTargetId>;
27
+ readonly adapter: RuntimeAdapterDescriptor<TFamilyId, TTargetId>;
28
+ readonly extensionPacks: readonly RuntimeExtensionDescriptor<TFamilyId, TTargetId>[];
29
+ }): void;
30
+ //#endregion
31
+ export { assertRuntimeContractRequirementsSatisfied };
32
+ //# sourceMappingURL=framework-components.d.mts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"framework-components.d.mts","names":[],"sources":["../src/framework-components.ts"],"sourcesContent":[],"mappings":";;;;;;AAkBA;;;;;;;AAW2C,iBAX3B,0CAW2B,CAAA,kBAAA,MAAA,EAAA,kBAAA,MAAA,CAAA,CAAA;EAAA,QAAA;EAAA,MAAA;EAAA,MAAA;EAAA,OAAA;EAAA;CAAA,EAAA;EAAxB,SAAA,QAAA,EAAA;IACwB,SAAA,MAAA,EAAA,MAAA;IAAW,SAAA,cAAA,CAAA,EAFoB,MAEpB,CAAA,MAAA,EAAA,OAAA,CAAA;EAAnC,CAAA;EAC0B,SAAA,MAAA,EAF1B,uBAE0B,CAFF,SAEE,CAAA;EAAW,SAAA,MAAA,EADrC,uBACqC,CADb,SACa,EADF,SACE,CAAA;EAApC,SAAA,OAAA,EAAA,wBAAA,CAAyB,SAAzB,EAAoC,SAApC,CAAA;EAC2C,SAAA,cAAA,EAAA,SAA3B,0BAA2B,CAAA,SAAA,EAAW,SAAX,CAAA,EAAA;CAAW,CAAA,EAAA,IAAA"}
@@ -0,0 +1,31 @@
1
+ import { checkContractComponentRequirements } from "@prisma-next/contract/framework-components";
2
+
3
+ //#region src/framework-components.ts
4
+ /**
5
+ * Asserts that runtime component descriptors satisfy contract requirements.
6
+ *
7
+ * Routes the same framework composition through validation as control-plane:
8
+ * family, target, adapter, extensionPacks (all as descriptors with IDs).
9
+ *
10
+ * @throws Error if contract target doesn't match the provided target descriptor
11
+ * @throws Error if contract requires extension packs not provided in descriptors
12
+ */
13
+ function assertRuntimeContractRequirementsSatisfied({ contract, family, target, adapter, extensionPacks }) {
14
+ const providedComponentIds = new Set([
15
+ family.id,
16
+ target.id,
17
+ adapter.id
18
+ ]);
19
+ for (const extension of extensionPacks) providedComponentIds.add(extension.id);
20
+ const result = checkContractComponentRequirements({
21
+ contract,
22
+ expectedTargetId: target.targetId,
23
+ providedComponentIds
24
+ });
25
+ if (result.targetMismatch) throw new Error(`Contract target '${result.targetMismatch.actual}' does not match runtime target descriptor '${result.targetMismatch.expected}'.`);
26
+ for (const packId of result.missingExtensionPackIds) throw new Error(`Contract requires extension pack '${packId}', but runtime descriptors do not provide a matching component.`);
27
+ }
28
+
29
+ //#endregion
30
+ export { assertRuntimeContractRequirementsSatisfied };
31
+ //# sourceMappingURL=framework-components.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"framework-components.mjs","names":[],"sources":["../src/framework-components.ts"],"sourcesContent":["import { checkContractComponentRequirements } from '@prisma-next/contract/framework-components';\n\nimport type {\n RuntimeAdapterDescriptor,\n RuntimeExtensionDescriptor,\n RuntimeFamilyDescriptor,\n RuntimeTargetDescriptor,\n} from './types';\n\n/**\n * Asserts that runtime component descriptors satisfy contract requirements.\n *\n * Routes the same framework composition through validation as control-plane:\n * family, target, adapter, extensionPacks (all as descriptors with IDs).\n *\n * @throws Error if contract target doesn't match the provided target descriptor\n * @throws Error if contract requires extension packs not provided in descriptors\n */\nexport function assertRuntimeContractRequirementsSatisfied<\n TFamilyId extends string,\n TTargetId extends string,\n>({\n contract,\n family,\n target,\n adapter,\n extensionPacks,\n}: {\n readonly contract: { readonly target: string; readonly extensionPacks?: Record<string, unknown> };\n readonly family: RuntimeFamilyDescriptor<TFamilyId>;\n readonly target: RuntimeTargetDescriptor<TFamilyId, TTargetId>;\n readonly adapter: RuntimeAdapterDescriptor<TFamilyId, TTargetId>;\n readonly extensionPacks: readonly RuntimeExtensionDescriptor<TFamilyId, TTargetId>[];\n}): void {\n // Build set of provided component IDs from descriptors\n const providedComponentIds = new Set<string>([family.id, target.id, adapter.id]);\n for (const extension of extensionPacks) {\n providedComponentIds.add(extension.id);\n }\n\n const result = checkContractComponentRequirements({\n contract,\n expectedTargetId: target.targetId,\n providedComponentIds,\n });\n\n if (result.targetMismatch) {\n throw new Error(\n `Contract target '${result.targetMismatch.actual}' does not match runtime target descriptor '${result.targetMismatch.expected}'.`,\n );\n }\n\n // Strict enforcement: all extension packs required by contract must be provided as descriptors\n for (const packId of result.missingExtensionPackIds) {\n throw new Error(\n `Contract requires extension pack '${packId}', but runtime descriptors do not provide a matching component.`,\n );\n }\n}\n"],"mappings":";;;;;;;;;;;;AAkBA,SAAgB,2CAGd,EACA,UACA,QACA,QACA,SACA,kBAOO;CAEP,MAAM,uBAAuB,IAAI,IAAY;EAAC,OAAO;EAAI,OAAO;EAAI,QAAQ;EAAG,CAAC;AAChF,MAAK,MAAM,aAAa,eACtB,sBAAqB,IAAI,UAAU,GAAG;CAGxC,MAAM,SAAS,mCAAmC;EAChD;EACA,kBAAkB,OAAO;EACzB;EACD,CAAC;AAEF,KAAI,OAAO,eACT,OAAM,IAAI,MACR,oBAAoB,OAAO,eAAe,OAAO,8CAA8C,OAAO,eAAe,SAAS,IAC/H;AAIH,MAAK,MAAM,UAAU,OAAO,wBAC1B,OAAM,IAAI,MACR,qCAAqC,OAAO,iEAC7C"}
@@ -0,0 +1,31 @@
1
+ import { a as RuntimeExtensionDescriptor, i as RuntimeDriverInstance, l as RuntimeTargetDescriptor, n as RuntimeAdapterInstance, o as RuntimeExtensionInstance, r as RuntimeDriverDescriptor, t as RuntimeAdapterDescriptor, u as RuntimeTargetInstance } from "./types-DELFO9yp.mjs";
2
+
3
+ //#region src/stack.d.ts
4
+ interface ExecutionStack<TFamilyId extends string, TTargetId extends string, TAdapterInstance extends RuntimeAdapterInstance<TFamilyId, TTargetId> = RuntimeAdapterInstance<TFamilyId, TTargetId>, TDriverInstance extends RuntimeDriverInstance<TFamilyId, TTargetId> = RuntimeDriverInstance<TFamilyId, TTargetId>, TExtensionInstance extends RuntimeExtensionInstance<TFamilyId, TTargetId> = RuntimeExtensionInstance<TFamilyId, TTargetId>> {
5
+ readonly target: RuntimeTargetDescriptor<TFamilyId, TTargetId>;
6
+ readonly adapter: RuntimeAdapterDescriptor<TFamilyId, TTargetId, TAdapterInstance>;
7
+ readonly driver: RuntimeDriverDescriptor<TFamilyId, TTargetId, unknown, TDriverInstance> | undefined;
8
+ readonly extensionPacks: readonly RuntimeExtensionDescriptor<TFamilyId, TTargetId, TExtensionInstance>[];
9
+ }
10
+ interface ExecutionStackInstance<TFamilyId extends string, TTargetId extends string, TAdapterInstance extends RuntimeAdapterInstance<TFamilyId, TTargetId> = RuntimeAdapterInstance<TFamilyId, TTargetId>, TDriverInstance extends RuntimeDriverInstance<TFamilyId, TTargetId> = RuntimeDriverInstance<TFamilyId, TTargetId>, TExtensionInstance extends RuntimeExtensionInstance<TFamilyId, TTargetId> = RuntimeExtensionInstance<TFamilyId, TTargetId>> {
11
+ readonly stack: ExecutionStack<TFamilyId, TTargetId, TAdapterInstance, TDriverInstance, TExtensionInstance>;
12
+ readonly target: RuntimeTargetInstance<TFamilyId, TTargetId>;
13
+ readonly adapter: TAdapterInstance;
14
+ readonly driver: TDriverInstance | undefined;
15
+ readonly extensionPacks: readonly TExtensionInstance[];
16
+ }
17
+ declare function createExecutionStack<TFamilyId extends string, TTargetId extends string, TTargetInstance extends RuntimeTargetInstance<TFamilyId, TTargetId>, TTargetDescriptor extends RuntimeTargetDescriptor<TFamilyId, TTargetId, TTargetInstance>, TAdapterInstance extends RuntimeAdapterInstance<TFamilyId, TTargetId>, TAdapterDescriptor extends RuntimeAdapterDescriptor<TFamilyId, TTargetId, TAdapterInstance>, TDriverInstance extends RuntimeDriverInstance<TFamilyId, TTargetId> = RuntimeDriverInstance<TFamilyId, TTargetId>, TDriverDescriptor extends RuntimeDriverDescriptor<TFamilyId, TTargetId, unknown, TDriverInstance> | undefined = undefined, TExtensionInstance extends RuntimeExtensionInstance<TFamilyId, TTargetId> = RuntimeExtensionInstance<TFamilyId, TTargetId>, TExtensionDescriptor extends RuntimeExtensionDescriptor<TFamilyId, TTargetId, TExtensionInstance> = never>(input: {
18
+ readonly target: TTargetDescriptor;
19
+ readonly adapter: TAdapterDescriptor;
20
+ readonly driver?: TDriverDescriptor | undefined;
21
+ readonly extensionPacks?: readonly TExtensionDescriptor[] | undefined;
22
+ }): ExecutionStack<TFamilyId, TTargetId, TAdapterInstance, TDriverInstance, TExtensionInstance> & {
23
+ readonly target: TTargetDescriptor;
24
+ readonly adapter: TAdapterDescriptor;
25
+ readonly driver: TDriverDescriptor | undefined;
26
+ readonly extensionPacks: readonly TExtensionDescriptor[];
27
+ };
28
+ declare function instantiateExecutionStack<TFamilyId extends string, TTargetId extends string, TAdapterInstance extends RuntimeAdapterInstance<TFamilyId, TTargetId>, TDriverInstance extends RuntimeDriverInstance<TFamilyId, TTargetId>, TExtensionInstance extends RuntimeExtensionInstance<TFamilyId, TTargetId>>(stack: ExecutionStack<TFamilyId, TTargetId, TAdapterInstance, TDriverInstance, TExtensionInstance>): ExecutionStackInstance<TFamilyId, TTargetId, TAdapterInstance, TDriverInstance, TExtensionInstance>;
29
+ //#endregion
30
+ export { type ExecutionStack, type ExecutionStackInstance, createExecutionStack, instantiateExecutionStack };
31
+ //# sourceMappingURL=stack.d.mts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"stack.d.mts","names":[],"sources":["../src/stack.ts"],"sourcesContent":[],"mappings":"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"}
package/dist/stack.mjs ADDED
@@ -0,0 +1,23 @@
1
+ //#region src/stack.ts
2
+ function createExecutionStack(input) {
3
+ return {
4
+ target: input.target,
5
+ adapter: input.adapter,
6
+ driver: input.driver,
7
+ extensionPacks: input.extensionPacks ?? []
8
+ };
9
+ }
10
+ function instantiateExecutionStack(stack) {
11
+ const driver = stack.driver ? stack.driver.create() : void 0;
12
+ return {
13
+ stack,
14
+ target: stack.target.create(),
15
+ adapter: stack.adapter.create(),
16
+ driver,
17
+ extensionPacks: stack.extensionPacks.map((descriptor) => descriptor.create())
18
+ };
19
+ }
20
+
21
+ //#endregion
22
+ export { createExecutionStack, instantiateExecutionStack };
23
+ //# sourceMappingURL=stack.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"stack.mjs","names":[],"sources":["../src/stack.ts"],"sourcesContent":["import type {\n RuntimeAdapterDescriptor,\n RuntimeAdapterInstance,\n RuntimeDriverDescriptor,\n RuntimeDriverInstance,\n RuntimeExtensionDescriptor,\n RuntimeExtensionInstance,\n RuntimeTargetDescriptor,\n RuntimeTargetInstance,\n} from './types';\n\nexport interface ExecutionStack<\n TFamilyId extends string,\n TTargetId extends string,\n TAdapterInstance extends RuntimeAdapterInstance<TFamilyId, TTargetId> = RuntimeAdapterInstance<\n TFamilyId,\n TTargetId\n >,\n TDriverInstance extends RuntimeDriverInstance<TFamilyId, TTargetId> = RuntimeDriverInstance<\n TFamilyId,\n TTargetId\n >,\n TExtensionInstance extends RuntimeExtensionInstance<\n TFamilyId,\n TTargetId\n > = RuntimeExtensionInstance<TFamilyId, TTargetId>,\n> {\n readonly target: RuntimeTargetDescriptor<TFamilyId, TTargetId>;\n readonly adapter: RuntimeAdapterDescriptor<TFamilyId, TTargetId, TAdapterInstance>;\n readonly driver:\n | RuntimeDriverDescriptor<TFamilyId, TTargetId, unknown, TDriverInstance>\n | undefined;\n readonly extensionPacks: readonly RuntimeExtensionDescriptor<\n TFamilyId,\n TTargetId,\n TExtensionInstance\n >[];\n}\n\nexport interface ExecutionStackInstance<\n TFamilyId extends string,\n TTargetId extends string,\n TAdapterInstance extends RuntimeAdapterInstance<TFamilyId, TTargetId> = RuntimeAdapterInstance<\n TFamilyId,\n TTargetId\n >,\n TDriverInstance extends RuntimeDriverInstance<TFamilyId, TTargetId> = RuntimeDriverInstance<\n TFamilyId,\n TTargetId\n >,\n TExtensionInstance extends RuntimeExtensionInstance<\n TFamilyId,\n TTargetId\n > = RuntimeExtensionInstance<TFamilyId, TTargetId>,\n> {\n readonly stack: ExecutionStack<\n TFamilyId,\n TTargetId,\n TAdapterInstance,\n TDriverInstance,\n TExtensionInstance\n >;\n readonly target: RuntimeTargetInstance<TFamilyId, TTargetId>;\n readonly adapter: TAdapterInstance;\n readonly driver: TDriverInstance | undefined;\n readonly extensionPacks: readonly TExtensionInstance[];\n}\n\nexport function createExecutionStack<\n TFamilyId extends string,\n TTargetId extends string,\n TTargetInstance extends RuntimeTargetInstance<TFamilyId, TTargetId>,\n TTargetDescriptor extends RuntimeTargetDescriptor<TFamilyId, TTargetId, TTargetInstance>,\n TAdapterInstance extends RuntimeAdapterInstance<TFamilyId, TTargetId>,\n TAdapterDescriptor extends RuntimeAdapterDescriptor<TFamilyId, TTargetId, TAdapterInstance>,\n TDriverInstance extends RuntimeDriverInstance<TFamilyId, TTargetId> = RuntimeDriverInstance<\n TFamilyId,\n TTargetId\n >,\n TDriverDescriptor extends\n | RuntimeDriverDescriptor<TFamilyId, TTargetId, unknown, TDriverInstance>\n | undefined = undefined,\n TExtensionInstance extends RuntimeExtensionInstance<\n TFamilyId,\n TTargetId\n > = RuntimeExtensionInstance<TFamilyId, TTargetId>,\n TExtensionDescriptor extends RuntimeExtensionDescriptor<\n TFamilyId,\n TTargetId,\n TExtensionInstance\n > = never,\n>(input: {\n readonly target: TTargetDescriptor;\n readonly adapter: TAdapterDescriptor;\n readonly driver?: TDriverDescriptor | undefined;\n readonly extensionPacks?: readonly TExtensionDescriptor[] | undefined;\n}): ExecutionStack<TFamilyId, TTargetId, TAdapterInstance, TDriverInstance, TExtensionInstance> & {\n readonly target: TTargetDescriptor;\n readonly adapter: TAdapterDescriptor;\n readonly driver: TDriverDescriptor | undefined;\n readonly extensionPacks: readonly TExtensionDescriptor[];\n} {\n return {\n target: input.target,\n adapter: input.adapter,\n driver: input.driver,\n extensionPacks: input.extensionPacks ?? [],\n };\n}\n\nexport function instantiateExecutionStack<\n TFamilyId extends string,\n TTargetId extends string,\n TAdapterInstance extends RuntimeAdapterInstance<TFamilyId, TTargetId>,\n TDriverInstance extends RuntimeDriverInstance<TFamilyId, TTargetId>,\n TExtensionInstance extends RuntimeExtensionInstance<TFamilyId, TTargetId>,\n>(\n stack: ExecutionStack<\n TFamilyId,\n TTargetId,\n TAdapterInstance,\n TDriverInstance,\n TExtensionInstance\n >,\n): ExecutionStackInstance<\n TFamilyId,\n TTargetId,\n TAdapterInstance,\n TDriverInstance,\n TExtensionInstance\n> {\n const driver = stack.driver ? stack.driver.create() : undefined;\n\n return {\n stack,\n target: stack.target.create(),\n adapter: stack.adapter.create(),\n driver,\n extensionPacks: stack.extensionPacks.map((descriptor) => descriptor.create()),\n };\n}\n"],"mappings":";AAoEA,SAAgB,qBAuBd,OAUA;AACA,QAAO;EACL,QAAQ,MAAM;EACd,SAAS,MAAM;EACf,QAAQ,MAAM;EACd,gBAAgB,MAAM,kBAAkB,EAAE;EAC3C;;AAGH,SAAgB,0BAOd,OAaA;CACA,MAAM,SAAS,MAAM,SAAS,MAAM,OAAO,QAAQ,GAAG;AAEtD,QAAO;EACL;EACA,QAAQ,MAAM,OAAO,QAAQ;EAC7B,SAAS,MAAM,QAAQ,QAAQ;EAC/B;EACA,gBAAgB,MAAM,eAAe,KAAK,eAAe,WAAW,QAAQ,CAAC;EAC9E"}
@@ -1,4 +1,6 @@
1
- import { AdapterInstance, AdapterDescriptor, DriverInstance, DriverDescriptor, ExtensionInstance, ExtensionDescriptor, FamilyInstance, FamilyDescriptor, TargetInstance, TargetDescriptor } from '@prisma-next/contract/framework-components';
1
+ import { AdapterDescriptor, AdapterInstance, DriverDescriptor, DriverInstance, ExtensionDescriptor, ExtensionInstance, FamilyDescriptor, FamilyInstance, TargetDescriptor, TargetInstance } from "@prisma-next/contract/framework-components";
2
+
3
+ //#region src/types.d.ts
2
4
 
3
5
  /**
4
6
  * Runtime-plane family instance interface.
@@ -6,8 +8,7 @@ import { AdapterInstance, AdapterDescriptor, DriverInstance, DriverDescriptor, E
6
8
  *
7
9
  * @template TFamilyId - The family ID (e.g., 'sql', 'document')
8
10
  */
9
- interface RuntimeFamilyInstance<TFamilyId extends string> extends FamilyInstance<TFamilyId> {
10
- }
11
+ interface RuntimeFamilyInstance<TFamilyId extends string> extends FamilyInstance<TFamilyId> {}
11
12
  /**
12
13
  * Runtime-plane target instance interface.
13
14
  * Extends the base TargetInstance with runtime-plane specific behavior.
@@ -15,8 +16,7 @@ interface RuntimeFamilyInstance<TFamilyId extends string> extends FamilyInstance
15
16
  * @template TFamilyId - The family ID (e.g., 'sql', 'document')
16
17
  * @template TTargetId - The target ID (e.g., 'postgres', 'mysql')
17
18
  */
18
- interface RuntimeTargetInstance<TFamilyId extends string, TTargetId extends string> extends TargetInstance<TFamilyId, TTargetId> {
19
- }
19
+ interface RuntimeTargetInstance<TFamilyId extends string, TTargetId extends string> extends TargetInstance<TFamilyId, TTargetId> {}
20
20
  /**
21
21
  * Runtime-plane adapter instance interface.
22
22
  * Extends the base AdapterInstance with runtime-plane specific behavior.
@@ -25,8 +25,7 @@ interface RuntimeTargetInstance<TFamilyId extends string, TTargetId extends stri
25
25
  * @template TFamilyId - The family ID (e.g., 'sql', 'document')
26
26
  * @template TTargetId - The target ID (e.g., 'postgres', 'mysql')
27
27
  */
28
- interface RuntimeAdapterInstance<TFamilyId extends string, TTargetId extends string> extends AdapterInstance<TFamilyId, TTargetId> {
29
- }
28
+ interface RuntimeAdapterInstance<TFamilyId extends string, TTargetId extends string> extends AdapterInstance<TFamilyId, TTargetId> {}
30
29
  /**
31
30
  * Runtime-plane driver instance interface.
32
31
  * Extends the base DriverInstance with runtime-plane specific behavior.
@@ -34,8 +33,7 @@ interface RuntimeAdapterInstance<TFamilyId extends string, TTargetId extends str
34
33
  * @template TFamilyId - The family ID (e.g., 'sql', 'document')
35
34
  * @template TTargetId - The target ID (e.g., 'postgres', 'mysql')
36
35
  */
37
- interface RuntimeDriverInstance<TFamilyId extends string, TTargetId extends string> extends DriverInstance<TFamilyId, TTargetId> {
38
- }
36
+ interface RuntimeDriverInstance<TFamilyId extends string, TTargetId extends string> extends DriverInstance<TFamilyId, TTargetId> {}
39
37
  /**
40
38
  * Runtime-plane extension instance interface.
41
39
  * Extends the base ExtensionInstance with runtime-plane specific behavior.
@@ -43,8 +41,7 @@ interface RuntimeDriverInstance<TFamilyId extends string, TTargetId extends stri
43
41
  * @template TFamilyId - The family ID (e.g., 'sql', 'document')
44
42
  * @template TTargetId - The target ID (e.g., 'postgres', 'mysql')
45
43
  */
46
- interface RuntimeExtensionInstance<TFamilyId extends string, TTargetId extends string> extends ExtensionInstance<TFamilyId, TTargetId> {
47
- }
44
+ interface RuntimeExtensionInstance<TFamilyId extends string, TTargetId extends string> extends ExtensionInstance<TFamilyId, TTargetId> {}
48
45
  /**
49
46
  * Descriptor for an execution/runtime-plane family (e.g., SQL).
50
47
  * Provides factory method to create runtime family instance.
@@ -53,12 +50,12 @@ interface RuntimeExtensionInstance<TFamilyId extends string, TTargetId extends s
53
50
  * @template TFamilyInstance - The family instance type
54
51
  */
55
52
  interface RuntimeFamilyDescriptor<TFamilyId extends string, TFamilyInstance extends RuntimeFamilyInstance<TFamilyId> = RuntimeFamilyInstance<TFamilyId>> extends FamilyDescriptor<TFamilyId> {
56
- create<TTargetId extends string>(options: {
57
- readonly target: RuntimeTargetDescriptor<TFamilyId, TTargetId>;
58
- readonly adapter: RuntimeAdapterDescriptor<TFamilyId, TTargetId>;
59
- readonly driver: RuntimeDriverDescriptor<TFamilyId, TTargetId>;
60
- readonly extensionPacks: readonly RuntimeExtensionDescriptor<TFamilyId, TTargetId>[];
61
- }): TFamilyInstance;
53
+ create<TTargetId extends string>(options: {
54
+ readonly target: RuntimeTargetDescriptor<TFamilyId, TTargetId>;
55
+ readonly adapter: RuntimeAdapterDescriptor<TFamilyId, TTargetId>;
56
+ readonly driver: RuntimeDriverDescriptor<TFamilyId, TTargetId>;
57
+ readonly extensionPacks: readonly RuntimeExtensionDescriptor<TFamilyId, TTargetId>[];
58
+ }): TFamilyInstance;
62
59
  }
63
60
  /**
64
61
  * Descriptor for an execution/runtime-plane target component (e.g., Postgres target).
@@ -68,7 +65,7 @@ interface RuntimeFamilyDescriptor<TFamilyId extends string, TFamilyInstance exte
68
65
  * @template TTargetInstance - The target instance type
69
66
  */
70
67
  interface RuntimeTargetDescriptor<TFamilyId extends string, TTargetId extends string, TTargetInstance extends RuntimeTargetInstance<TFamilyId, TTargetId> = RuntimeTargetInstance<TFamilyId, TTargetId>> extends TargetDescriptor<TFamilyId, TTargetId> {
71
- create(): TTargetInstance;
68
+ create(): TTargetInstance;
72
69
  }
73
70
  /**
74
71
  * Descriptor for an execution/runtime-plane adapter component (e.g., Postgres adapter).
@@ -78,17 +75,19 @@ interface RuntimeTargetDescriptor<TFamilyId extends string, TTargetId extends st
78
75
  * @template TAdapterInstance - The adapter instance type
79
76
  */
80
77
  interface RuntimeAdapterDescriptor<TFamilyId extends string, TTargetId extends string, TAdapterInstance extends RuntimeAdapterInstance<TFamilyId, TTargetId> = RuntimeAdapterInstance<TFamilyId, TTargetId>> extends AdapterDescriptor<TFamilyId, TTargetId> {
81
- create(): TAdapterInstance;
78
+ create(): TAdapterInstance;
82
79
  }
83
80
  /**
84
81
  * Descriptor for an execution/runtime-plane driver component (e.g., Postgres driver).
82
+ * create() accepts optional driver-specific options; connection binding happens at connect time.
85
83
  *
86
84
  * @template TFamilyId - The family ID (e.g., 'sql', 'document')
87
85
  * @template TTargetId - The target ID (e.g., 'postgres', 'mysql')
86
+ * @template TCreateOptions - Optional options for create (no connection); default void
88
87
  * @template TDriverInstance - The driver instance type
89
88
  */
90
- interface RuntimeDriverDescriptor<TFamilyId extends string, TTargetId extends string, TDriverInstance extends RuntimeDriverInstance<TFamilyId, TTargetId> = RuntimeDriverInstance<TFamilyId, TTargetId>> extends DriverDescriptor<TFamilyId, TTargetId> {
91
- create(options: unknown): TDriverInstance;
89
+ interface RuntimeDriverDescriptor<TFamilyId extends string, TTargetId extends string, TCreateOptions = void, TDriverInstance extends RuntimeDriverInstance<TFamilyId, TTargetId> = RuntimeDriverInstance<TFamilyId, TTargetId>> extends DriverDescriptor<TFamilyId, TTargetId> {
90
+ create(options?: TCreateOptions): TDriverInstance;
92
91
  }
93
92
  /**
94
93
  * Descriptor for an execution/runtime-plane extension component (e.g., pgvector).
@@ -98,7 +97,8 @@ interface RuntimeDriverDescriptor<TFamilyId extends string, TTargetId extends st
98
97
  * @template TExtensionInstance - The extension instance type
99
98
  */
100
99
  interface RuntimeExtensionDescriptor<TFamilyId extends string, TTargetId extends string, TExtensionInstance extends RuntimeExtensionInstance<TFamilyId, TTargetId> = RuntimeExtensionInstance<TFamilyId, TTargetId>> extends ExtensionDescriptor<TFamilyId, TTargetId> {
101
- create(): TExtensionInstance;
100
+ create(): TExtensionInstance;
102
101
  }
103
-
104
- export type { RuntimeAdapterDescriptor, RuntimeAdapterInstance, RuntimeDriverDescriptor, RuntimeDriverInstance, RuntimeExtensionDescriptor, RuntimeExtensionInstance, RuntimeFamilyDescriptor, RuntimeFamilyInstance, RuntimeTargetDescriptor, RuntimeTargetInstance };
102
+ //#endregion
103
+ export { RuntimeExtensionDescriptor as a, RuntimeFamilyInstance as c, RuntimeDriverInstance as i, RuntimeTargetDescriptor as l, RuntimeAdapterInstance as n, RuntimeExtensionInstance as o, RuntimeDriverDescriptor as r, RuntimeFamilyDescriptor as s, RuntimeAdapterDescriptor as t, RuntimeTargetInstance as u };
104
+ //# sourceMappingURL=types-DELFO9yp.d.mts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types-DELFO9yp.d.mts","names":[],"sources":["../src/types.ts"],"sourcesContent":[],"mappings":";;;;;;AAuBA;AAWA;;;AACU,UAZO,qBAYP,CAAA,kBAAA,MAAA,CAAA,SAZ+D,cAY/D,CAZ8E,SAY9E,CAAA,CAAA;AAUV;;;;;AAUA;;AACoC,UAtBnB,qBAsBmB,CAAA,kBAAA,MAAA,EAAA,kBAAA,MAAA,CAAA,SArB1B,cAqB0B,CArBX,SAqBW,EArBA,SAqBA,CAAA,CAAA;;AASpC;;;;;AAcA;;AAE0B,UApCT,sBAoCS,CAAA,kBAAA,MAAA,EAAA,kBAAA,MAAA,CAAA,SAnChB,eAmCgB,CAnCA,SAmCA,EAnCW,SAmCX,CAAA,CAAA;;;;;;;;AAIJ,UA9BL,qBA8BK,CAAA,kBAAA,MAAA,EAAA,kBAAA,MAAA,CAAA,SA7BZ,cA6BY,CA7BG,SA6BH,EA7Bc,SA6Bd,CAAA,CAAA;;;;;;;;AAHI,UAjBT,wBAiBS,CAAA,kBAAA,MAAA,EAAA,kBAAA,MAAA,CAAA,SAhBhB,iBAgBgB,CAhBE,SAgBF,EAhBa,SAgBb,CAAA,CAAA,CAgB1B;;;;;;;;AAOsC,UA1BrB,uBA0BqB,CAAA,kBAAA,MAAA,EAAA,wBAxBZ,qBAwBY,CAxBU,SAwBV,CAAA,GAxBuB,qBAwBvB,CAxB6C,SAwB7C,CAAA,CAAA,SAvB5B,gBAuB4B,CAvBX,SAuBW,CAAA,CAAA;EAC1B,MAAA,CAAA,kBAAA,MAAA,CAAA,CAAA,OAAA,EAAA;IADF,SAAA,MAAA,EArBW,uBAqBX,CArBmC,SAqBnC,EArB8C,SAqB9C,CAAA;IAAgB,SAAA,OAAA,EApBJ,wBAoBI,CApBqB,SAoBrB,EApBgC,SAoBhC,CAAA;IAWT,SAAA,MAAA,EA9BI,uBA8BoB,CA9BI,SA8BJ,EA9Be,SA8Bf,CAAA;IAGS,SAAA,cAAA,EAAA,SAhCZ,0BAgCY,CAhCe,SAgCf,EAhC0B,SAgC1B,CAAA,EAAA;EAAW,CAAA,CAAA,EA/BvD,eA+BuD;;;;;;;;;AAIlC,UAzBV,uBAyBU,CAAA,kBAAA,MAAA,EAAA,kBAAA,MAAA,EAAA,wBAtBD,qBAsBC,CAtBqB,SAsBrB,EAtBgC,SAsBhC,CAAA,GAtB6C,qBAsB7C,CArBvB,SAqBuB,EApBvB,SAoBuB,CAAA,CAAA,SAlBjB,gBAkBiB,CAlBA,SAkBA,EAlBW,SAkBX,CAAA,CAAA;EAaV,MAAA,EAAA,EA9BL,eA8BK;;;;;;;;;AASE,UA7BF,wBA6BE,CAAA,kBAAA,MAAA,EAAA,kBAAA,MAAA,EAAA,yBA1BQ,sBA0BR,CA1B+B,SA0B/B,EA1B0C,SA0B1C,CAAA,GA1BuD,sBA0BvD,CAzBf,SAyBe,EAxBf,SAwBe,CAAA,CAAA,SAtBT,iBAsBS,CAtBS,SAsBT,EAtBoB,SAsBpB,CAAA,CAAA;EAAiB,MAAA,EAAA,EArBxB,gBAqBwB;;;AAUpC;;;;;;;;AAOyC,UA1BxB,uBA0BwB,CAAA,kBAAA,MAAA,EAAA,kBAAA,MAAA,EAAA,iBAAA,IAAA,EAAA,wBAtBf,qBAsBe,CAtBO,SAsBP,EAtBkB,SAsBlB,CAAA,GAtB+B,qBAsB/B,CArBrC,SAqBqC,EApBrC,SAoBqC,CAAA,CAAA,SAlB/B,gBAkB+B,CAlBd,SAkBc,EAlBH,SAkBG,CAAA,CAAA;EAC7B,MAAA,CAAA,OAAA,CAAA,EAlBO,cAkBP,CAAA,EAlBwB,eAkBxB;;;;;;;;;UARK,0GAGY,yBACzB,WACA,aACE,yBAAyB,WAAW,oBAChC,oBAAoB,WAAW;YAC7B"}
@@ -0,0 +1,2 @@
1
+ import { a as RuntimeExtensionDescriptor, c as RuntimeFamilyInstance, i as RuntimeDriverInstance, l as RuntimeTargetDescriptor, n as RuntimeAdapterInstance, o as RuntimeExtensionInstance, r as RuntimeDriverDescriptor, s as RuntimeFamilyDescriptor, t as RuntimeAdapterDescriptor, u as RuntimeTargetInstance } from "./types-DELFO9yp.mjs";
2
+ export { type RuntimeAdapterDescriptor, type RuntimeAdapterInstance, type RuntimeDriverDescriptor, type RuntimeDriverInstance, type RuntimeExtensionDescriptor, type RuntimeExtensionInstance, type RuntimeFamilyDescriptor, type RuntimeFamilyInstance, type RuntimeTargetDescriptor, type RuntimeTargetInstance };
package/dist/types.mjs ADDED
@@ -0,0 +1 @@
1
+ export { };
package/package.json CHANGED
@@ -1,41 +1,47 @@
1
1
  {
2
2
  "name": "@prisma-next/core-execution-plane",
3
- "version": "0.3.0-dev.4",
3
+ "version": "0.3.0-dev.41",
4
4
  "type": "module",
5
5
  "sideEffects": false,
6
6
  "description": "Execution/runtime plane descriptor and instance types for Prisma Next",
7
7
  "dependencies": {
8
- "@prisma-next/core-control-plane": "0.3.0-dev.4",
9
- "@prisma-next/contract": "0.3.0-dev.4"
8
+ "@prisma-next/core-control-plane": "0.3.0-dev.41",
9
+ "@prisma-next/contract": "0.3.0-dev.41"
10
10
  },
11
11
  "devDependencies": {
12
- "@vitest/coverage-v8": "4.0.16",
13
- "tsup": "8.5.1",
12
+ "tsdown": "0.18.4",
14
13
  "typescript": "5.9.3",
15
- "vitest": "4.0.16",
16
- "@prisma-next/test-utils": "0.0.1"
14
+ "vitest": "4.0.17",
15
+ "@prisma-next/test-utils": "0.0.1",
16
+ "@prisma-next/tsconfig": "0.0.0",
17
+ "@prisma-next/tsdown": "0.0.0"
17
18
  },
18
19
  "files": [
19
- "dist"
20
+ "dist",
21
+ "src"
20
22
  ],
23
+ "engines": {
24
+ "node": ">=20"
25
+ },
21
26
  "exports": {
22
- "./types": {
23
- "types": "./dist/exports/types.d.ts",
24
- "import": "./dist/exports/types.js"
25
- },
26
- "./framework-components": {
27
- "types": "./dist/exports/framework-components.d.ts",
28
- "import": "./dist/exports/framework-components.js"
29
- }
27
+ "./framework-components": "./dist/framework-components.mjs",
28
+ "./stack": "./dist/stack.mjs",
29
+ "./types": "./dist/types.mjs",
30
+ "./package.json": "./package.json"
31
+ },
32
+ "repository": {
33
+ "type": "git",
34
+ "url": "https://github.com/prisma/prisma-next.git",
35
+ "directory": "packages/1-framework/1-core/runtime/execution-plane"
30
36
  },
31
37
  "scripts": {
32
- "build": "tsup --config tsup.config.ts",
38
+ "build": "tsdown",
33
39
  "test": "vitest run --passWithNoTests",
34
40
  "test:coverage": "vitest run --coverage --passWithNoTests",
35
- "typecheck": "tsc --project tsconfig.json --noEmit",
36
- "lint": "biome check . --config-path ../../../../../biome.json --error-on-warnings",
37
- "lint:fix": "biome check --write . --config-path ../../../biome.json",
38
- "lint:fix:unsafe": "biome check --write --unsafe . --config-path ../../../biome.json",
39
- "clean": "node ../../../../../scripts/clean.mjs"
41
+ "typecheck": "tsc --noEmit",
42
+ "lint": "biome check . --error-on-warnings",
43
+ "lint:fix": "biome check --write .",
44
+ "lint:fix:unsafe": "biome check --write --unsafe .",
45
+ "clean": "rm -rf dist dist-tsc dist-tsc-prod coverage .tmp-output"
40
46
  }
41
47
  }
@@ -0,0 +1 @@
1
+ export { assertRuntimeContractRequirementsSatisfied } from '../framework-components';
@@ -0,0 +1,2 @@
1
+ export type { ExecutionStack, ExecutionStackInstance } from '../stack';
2
+ export { createExecutionStack, instantiateExecutionStack } from '../stack';
@@ -0,0 +1,12 @@
1
+ export type {
2
+ RuntimeAdapterDescriptor,
3
+ RuntimeAdapterInstance,
4
+ RuntimeDriverDescriptor,
5
+ RuntimeDriverInstance,
6
+ RuntimeExtensionDescriptor,
7
+ RuntimeExtensionInstance,
8
+ RuntimeFamilyDescriptor,
9
+ RuntimeFamilyInstance,
10
+ RuntimeTargetDescriptor,
11
+ RuntimeTargetInstance,
12
+ } from '../types';
@@ -0,0 +1,59 @@
1
+ import { checkContractComponentRequirements } from '@prisma-next/contract/framework-components';
2
+
3
+ import type {
4
+ RuntimeAdapterDescriptor,
5
+ RuntimeExtensionDescriptor,
6
+ RuntimeFamilyDescriptor,
7
+ RuntimeTargetDescriptor,
8
+ } from './types';
9
+
10
+ /**
11
+ * Asserts that runtime component descriptors satisfy contract requirements.
12
+ *
13
+ * Routes the same framework composition through validation as control-plane:
14
+ * family, target, adapter, extensionPacks (all as descriptors with IDs).
15
+ *
16
+ * @throws Error if contract target doesn't match the provided target descriptor
17
+ * @throws Error if contract requires extension packs not provided in descriptors
18
+ */
19
+ export function assertRuntimeContractRequirementsSatisfied<
20
+ TFamilyId extends string,
21
+ TTargetId extends string,
22
+ >({
23
+ contract,
24
+ family,
25
+ target,
26
+ adapter,
27
+ extensionPacks,
28
+ }: {
29
+ readonly contract: { readonly target: string; readonly extensionPacks?: Record<string, unknown> };
30
+ readonly family: RuntimeFamilyDescriptor<TFamilyId>;
31
+ readonly target: RuntimeTargetDescriptor<TFamilyId, TTargetId>;
32
+ readonly adapter: RuntimeAdapterDescriptor<TFamilyId, TTargetId>;
33
+ readonly extensionPacks: readonly RuntimeExtensionDescriptor<TFamilyId, TTargetId>[];
34
+ }): void {
35
+ // Build set of provided component IDs from descriptors
36
+ const providedComponentIds = new Set<string>([family.id, target.id, adapter.id]);
37
+ for (const extension of extensionPacks) {
38
+ providedComponentIds.add(extension.id);
39
+ }
40
+
41
+ const result = checkContractComponentRequirements({
42
+ contract,
43
+ expectedTargetId: target.targetId,
44
+ providedComponentIds,
45
+ });
46
+
47
+ if (result.targetMismatch) {
48
+ throw new Error(
49
+ `Contract target '${result.targetMismatch.actual}' does not match runtime target descriptor '${result.targetMismatch.expected}'.`,
50
+ );
51
+ }
52
+
53
+ // Strict enforcement: all extension packs required by contract must be provided as descriptors
54
+ for (const packId of result.missingExtensionPackIds) {
55
+ throw new Error(
56
+ `Contract requires extension pack '${packId}', but runtime descriptors do not provide a matching component.`,
57
+ );
58
+ }
59
+ }
package/src/stack.ts ADDED
@@ -0,0 +1,141 @@
1
+ import type {
2
+ RuntimeAdapterDescriptor,
3
+ RuntimeAdapterInstance,
4
+ RuntimeDriverDescriptor,
5
+ RuntimeDriverInstance,
6
+ RuntimeExtensionDescriptor,
7
+ RuntimeExtensionInstance,
8
+ RuntimeTargetDescriptor,
9
+ RuntimeTargetInstance,
10
+ } from './types';
11
+
12
+ export interface ExecutionStack<
13
+ TFamilyId extends string,
14
+ TTargetId extends string,
15
+ TAdapterInstance extends RuntimeAdapterInstance<TFamilyId, TTargetId> = RuntimeAdapterInstance<
16
+ TFamilyId,
17
+ TTargetId
18
+ >,
19
+ TDriverInstance extends RuntimeDriverInstance<TFamilyId, TTargetId> = RuntimeDriverInstance<
20
+ TFamilyId,
21
+ TTargetId
22
+ >,
23
+ TExtensionInstance extends RuntimeExtensionInstance<
24
+ TFamilyId,
25
+ TTargetId
26
+ > = RuntimeExtensionInstance<TFamilyId, TTargetId>,
27
+ > {
28
+ readonly target: RuntimeTargetDescriptor<TFamilyId, TTargetId>;
29
+ readonly adapter: RuntimeAdapterDescriptor<TFamilyId, TTargetId, TAdapterInstance>;
30
+ readonly driver:
31
+ | RuntimeDriverDescriptor<TFamilyId, TTargetId, unknown, TDriverInstance>
32
+ | undefined;
33
+ readonly extensionPacks: readonly RuntimeExtensionDescriptor<
34
+ TFamilyId,
35
+ TTargetId,
36
+ TExtensionInstance
37
+ >[];
38
+ }
39
+
40
+ export interface ExecutionStackInstance<
41
+ TFamilyId extends string,
42
+ TTargetId extends string,
43
+ TAdapterInstance extends RuntimeAdapterInstance<TFamilyId, TTargetId> = RuntimeAdapterInstance<
44
+ TFamilyId,
45
+ TTargetId
46
+ >,
47
+ TDriverInstance extends RuntimeDriverInstance<TFamilyId, TTargetId> = RuntimeDriverInstance<
48
+ TFamilyId,
49
+ TTargetId
50
+ >,
51
+ TExtensionInstance extends RuntimeExtensionInstance<
52
+ TFamilyId,
53
+ TTargetId
54
+ > = RuntimeExtensionInstance<TFamilyId, TTargetId>,
55
+ > {
56
+ readonly stack: ExecutionStack<
57
+ TFamilyId,
58
+ TTargetId,
59
+ TAdapterInstance,
60
+ TDriverInstance,
61
+ TExtensionInstance
62
+ >;
63
+ readonly target: RuntimeTargetInstance<TFamilyId, TTargetId>;
64
+ readonly adapter: TAdapterInstance;
65
+ readonly driver: TDriverInstance | undefined;
66
+ readonly extensionPacks: readonly TExtensionInstance[];
67
+ }
68
+
69
+ export function createExecutionStack<
70
+ TFamilyId extends string,
71
+ TTargetId extends string,
72
+ TTargetInstance extends RuntimeTargetInstance<TFamilyId, TTargetId>,
73
+ TTargetDescriptor extends RuntimeTargetDescriptor<TFamilyId, TTargetId, TTargetInstance>,
74
+ TAdapterInstance extends RuntimeAdapterInstance<TFamilyId, TTargetId>,
75
+ TAdapterDescriptor extends RuntimeAdapterDescriptor<TFamilyId, TTargetId, TAdapterInstance>,
76
+ TDriverInstance extends RuntimeDriverInstance<TFamilyId, TTargetId> = RuntimeDriverInstance<
77
+ TFamilyId,
78
+ TTargetId
79
+ >,
80
+ TDriverDescriptor extends
81
+ | RuntimeDriverDescriptor<TFamilyId, TTargetId, unknown, TDriverInstance>
82
+ | undefined = undefined,
83
+ TExtensionInstance extends RuntimeExtensionInstance<
84
+ TFamilyId,
85
+ TTargetId
86
+ > = RuntimeExtensionInstance<TFamilyId, TTargetId>,
87
+ TExtensionDescriptor extends RuntimeExtensionDescriptor<
88
+ TFamilyId,
89
+ TTargetId,
90
+ TExtensionInstance
91
+ > = never,
92
+ >(input: {
93
+ readonly target: TTargetDescriptor;
94
+ readonly adapter: TAdapterDescriptor;
95
+ readonly driver?: TDriverDescriptor | undefined;
96
+ readonly extensionPacks?: readonly TExtensionDescriptor[] | undefined;
97
+ }): ExecutionStack<TFamilyId, TTargetId, TAdapterInstance, TDriverInstance, TExtensionInstance> & {
98
+ readonly target: TTargetDescriptor;
99
+ readonly adapter: TAdapterDescriptor;
100
+ readonly driver: TDriverDescriptor | undefined;
101
+ readonly extensionPacks: readonly TExtensionDescriptor[];
102
+ } {
103
+ return {
104
+ target: input.target,
105
+ adapter: input.adapter,
106
+ driver: input.driver,
107
+ extensionPacks: input.extensionPacks ?? [],
108
+ };
109
+ }
110
+
111
+ export function instantiateExecutionStack<
112
+ TFamilyId extends string,
113
+ TTargetId extends string,
114
+ TAdapterInstance extends RuntimeAdapterInstance<TFamilyId, TTargetId>,
115
+ TDriverInstance extends RuntimeDriverInstance<TFamilyId, TTargetId>,
116
+ TExtensionInstance extends RuntimeExtensionInstance<TFamilyId, TTargetId>,
117
+ >(
118
+ stack: ExecutionStack<
119
+ TFamilyId,
120
+ TTargetId,
121
+ TAdapterInstance,
122
+ TDriverInstance,
123
+ TExtensionInstance
124
+ >,
125
+ ): ExecutionStackInstance<
126
+ TFamilyId,
127
+ TTargetId,
128
+ TAdapterInstance,
129
+ TDriverInstance,
130
+ TExtensionInstance
131
+ > {
132
+ const driver = stack.driver ? stack.driver.create() : undefined;
133
+
134
+ return {
135
+ stack,
136
+ target: stack.target.create(),
137
+ adapter: stack.adapter.create(),
138
+ driver,
139
+ extensionPacks: stack.extensionPacks.map((descriptor) => descriptor.create()),
140
+ };
141
+ }
package/src/types.ts ADDED
@@ -0,0 +1,165 @@
1
+ import type {
2
+ AdapterDescriptor,
3
+ AdapterInstance,
4
+ DriverDescriptor,
5
+ DriverInstance,
6
+ ExtensionDescriptor,
7
+ ExtensionInstance,
8
+ FamilyDescriptor,
9
+ FamilyInstance,
10
+ TargetDescriptor,
11
+ TargetInstance,
12
+ } from '@prisma-next/contract/framework-components';
13
+
14
+ // ============================================================================
15
+ // Runtime*Instance Base Interfaces
16
+ // ============================================================================
17
+
18
+ /**
19
+ * Runtime-plane family instance interface.
20
+ * Extends the base FamilyInstance for runtime-plane specific methods.
21
+ *
22
+ * @template TFamilyId - The family ID (e.g., 'sql', 'document')
23
+ */
24
+ export interface RuntimeFamilyInstance<TFamilyId extends string> extends FamilyInstance<TFamilyId> {
25
+ // Placeholder for future runtime-plane-specific methods
26
+ }
27
+
28
+ /**
29
+ * Runtime-plane target instance interface.
30
+ * Extends the base TargetInstance with runtime-plane specific behavior.
31
+ *
32
+ * @template TFamilyId - The family ID (e.g., 'sql', 'document')
33
+ * @template TTargetId - The target ID (e.g., 'postgres', 'mysql')
34
+ */
35
+ export interface RuntimeTargetInstance<TFamilyId extends string, TTargetId extends string>
36
+ extends TargetInstance<TFamilyId, TTargetId> {}
37
+
38
+ /**
39
+ * Runtime-plane adapter instance interface.
40
+ * Extends the base AdapterInstance with runtime-plane specific behavior.
41
+ * Families extend this with family-specific adapter interfaces.
42
+ *
43
+ * @template TFamilyId - The family ID (e.g., 'sql', 'document')
44
+ * @template TTargetId - The target ID (e.g., 'postgres', 'mysql')
45
+ */
46
+ export interface RuntimeAdapterInstance<TFamilyId extends string, TTargetId extends string>
47
+ extends AdapterInstance<TFamilyId, TTargetId> {}
48
+
49
+ /**
50
+ * Runtime-plane driver instance interface.
51
+ * Extends the base DriverInstance with runtime-plane specific behavior.
52
+ *
53
+ * @template TFamilyId - The family ID (e.g., 'sql', 'document')
54
+ * @template TTargetId - The target ID (e.g., 'postgres', 'mysql')
55
+ */
56
+ export interface RuntimeDriverInstance<TFamilyId extends string, TTargetId extends string>
57
+ extends DriverInstance<TFamilyId, TTargetId> {}
58
+
59
+ /**
60
+ * Runtime-plane extension instance interface.
61
+ * Extends the base ExtensionInstance with runtime-plane specific behavior.
62
+ *
63
+ * @template TFamilyId - The family ID (e.g., 'sql', 'document')
64
+ * @template TTargetId - The target ID (e.g., 'postgres', 'mysql')
65
+ */
66
+ export interface RuntimeExtensionInstance<TFamilyId extends string, TTargetId extends string>
67
+ extends ExtensionInstance<TFamilyId, TTargetId> {}
68
+
69
+ // ============================================================================
70
+ // Runtime*Descriptor Interfaces (ADR 152)
71
+ // ============================================================================
72
+
73
+ /**
74
+ * Descriptor for an execution/runtime-plane family (e.g., SQL).
75
+ * Provides factory method to create runtime family instance.
76
+ *
77
+ * @template TFamilyId - The family ID (e.g., 'sql', 'document')
78
+ * @template TFamilyInstance - The family instance type
79
+ */
80
+ export interface RuntimeFamilyDescriptor<
81
+ TFamilyId extends string,
82
+ TFamilyInstance extends RuntimeFamilyInstance<TFamilyId> = RuntimeFamilyInstance<TFamilyId>,
83
+ > extends FamilyDescriptor<TFamilyId> {
84
+ create<TTargetId extends string>(options: {
85
+ readonly target: RuntimeTargetDescriptor<TFamilyId, TTargetId>;
86
+ readonly adapter: RuntimeAdapterDescriptor<TFamilyId, TTargetId>;
87
+ readonly driver: RuntimeDriverDescriptor<TFamilyId, TTargetId>;
88
+ readonly extensionPacks: readonly RuntimeExtensionDescriptor<TFamilyId, TTargetId>[];
89
+ }): TFamilyInstance;
90
+ }
91
+
92
+ /**
93
+ * Descriptor for an execution/runtime-plane target component (e.g., Postgres target).
94
+ *
95
+ * @template TFamilyId - The family ID (e.g., 'sql', 'document')
96
+ * @template TTargetId - The target ID (e.g., 'postgres', 'mysql')
97
+ * @template TTargetInstance - The target instance type
98
+ */
99
+ export interface RuntimeTargetDescriptor<
100
+ TFamilyId extends string,
101
+ TTargetId extends string,
102
+ TTargetInstance extends RuntimeTargetInstance<TFamilyId, TTargetId> = RuntimeTargetInstance<
103
+ TFamilyId,
104
+ TTargetId
105
+ >,
106
+ > extends TargetDescriptor<TFamilyId, TTargetId> {
107
+ create(): TTargetInstance;
108
+ }
109
+
110
+ /**
111
+ * Descriptor for an execution/runtime-plane adapter component (e.g., Postgres adapter).
112
+ *
113
+ * @template TFamilyId - The family ID (e.g., 'sql', 'document')
114
+ * @template TTargetId - The target ID (e.g., 'postgres', 'mysql')
115
+ * @template TAdapterInstance - The adapter instance type
116
+ */
117
+ export interface RuntimeAdapterDescriptor<
118
+ TFamilyId extends string,
119
+ TTargetId extends string,
120
+ TAdapterInstance extends RuntimeAdapterInstance<TFamilyId, TTargetId> = RuntimeAdapterInstance<
121
+ TFamilyId,
122
+ TTargetId
123
+ >,
124
+ > extends AdapterDescriptor<TFamilyId, TTargetId> {
125
+ create(): TAdapterInstance;
126
+ }
127
+
128
+ /**
129
+ * Descriptor for an execution/runtime-plane driver component (e.g., Postgres driver).
130
+ * create() accepts optional driver-specific options; connection binding happens at connect time.
131
+ *
132
+ * @template TFamilyId - The family ID (e.g., 'sql', 'document')
133
+ * @template TTargetId - The target ID (e.g., 'postgres', 'mysql')
134
+ * @template TCreateOptions - Optional options for create (no connection); default void
135
+ * @template TDriverInstance - The driver instance type
136
+ */
137
+ export interface RuntimeDriverDescriptor<
138
+ TFamilyId extends string,
139
+ TTargetId extends string,
140
+ TCreateOptions = void,
141
+ TDriverInstance extends RuntimeDriverInstance<TFamilyId, TTargetId> = RuntimeDriverInstance<
142
+ TFamilyId,
143
+ TTargetId
144
+ >,
145
+ > extends DriverDescriptor<TFamilyId, TTargetId> {
146
+ create(options?: TCreateOptions): TDriverInstance;
147
+ }
148
+
149
+ /**
150
+ * Descriptor for an execution/runtime-plane extension component (e.g., pgvector).
151
+ *
152
+ * @template TFamilyId - The family ID (e.g., 'sql', 'document')
153
+ * @template TTargetId - The target ID (e.g., 'postgres', 'mysql')
154
+ * @template TExtensionInstance - The extension instance type
155
+ */
156
+ export interface RuntimeExtensionDescriptor<
157
+ TFamilyId extends string,
158
+ TTargetId extends string,
159
+ TExtensionInstance extends RuntimeExtensionInstance<
160
+ TFamilyId,
161
+ TTargetId
162
+ > = RuntimeExtensionInstance<TFamilyId, TTargetId>,
163
+ > extends ExtensionDescriptor<TFamilyId, TTargetId> {
164
+ create(): TExtensionInstance;
165
+ }
@@ -1,24 +0,0 @@
1
- import { RuntimeFamilyDescriptor, RuntimeTargetDescriptor, RuntimeAdapterDescriptor, RuntimeExtensionDescriptor } from './types.js';
2
- import '@prisma-next/contract/framework-components';
3
-
4
- /**
5
- * Asserts that runtime component descriptors satisfy contract requirements.
6
- *
7
- * Routes the same framework composition through validation as control-plane:
8
- * family, target, adapter, extensionPacks (all as descriptors with IDs).
9
- *
10
- * @throws Error if contract target doesn't match the provided target descriptor
11
- * @throws Error if contract requires extension packs not provided in descriptors
12
- */
13
- declare function assertRuntimeContractRequirementsSatisfied<TFamilyId extends string, TTargetId extends string>({ contract, family, target, adapter, extensionPacks, }: {
14
- readonly contract: {
15
- readonly target: string;
16
- readonly extensionPacks?: Record<string, unknown>;
17
- };
18
- readonly family: RuntimeFamilyDescriptor<TFamilyId>;
19
- readonly target: RuntimeTargetDescriptor<TFamilyId, TTargetId>;
20
- readonly adapter: RuntimeAdapterDescriptor<TFamilyId, TTargetId>;
21
- readonly extensionPacks: readonly RuntimeExtensionDescriptor<TFamilyId, TTargetId>[];
22
- }): void;
23
-
24
- export { assertRuntimeContractRequirementsSatisfied };
@@ -1,33 +0,0 @@
1
- // src/framework-components.ts
2
- import { checkContractComponentRequirements } from "@prisma-next/contract/framework-components";
3
- function assertRuntimeContractRequirementsSatisfied({
4
- contract,
5
- family,
6
- target,
7
- adapter,
8
- extensionPacks
9
- }) {
10
- const providedComponentIds = /* @__PURE__ */ new Set([family.id, target.id, adapter.id]);
11
- for (const extension of extensionPacks) {
12
- providedComponentIds.add(extension.id);
13
- }
14
- const result = checkContractComponentRequirements({
15
- contract,
16
- expectedTargetId: target.targetId,
17
- providedComponentIds
18
- });
19
- if (result.targetMismatch) {
20
- throw new Error(
21
- `Contract target '${result.targetMismatch.actual}' does not match runtime target descriptor '${result.targetMismatch.expected}'.`
22
- );
23
- }
24
- for (const packId of result.missingExtensionPackIds) {
25
- throw new Error(
26
- `Contract requires extension pack '${packId}', but runtime descriptors do not provide a matching component.`
27
- );
28
- }
29
- }
30
- export {
31
- assertRuntimeContractRequirementsSatisfied
32
- };
33
- //# sourceMappingURL=framework-components.js.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../../src/framework-components.ts"],"sourcesContent":["import { checkContractComponentRequirements } from '@prisma-next/contract/framework-components';\n\nimport type {\n RuntimeAdapterDescriptor,\n RuntimeExtensionDescriptor,\n RuntimeFamilyDescriptor,\n RuntimeTargetDescriptor,\n} from './types';\n\n/**\n * Asserts that runtime component descriptors satisfy contract requirements.\n *\n * Routes the same framework composition through validation as control-plane:\n * family, target, adapter, extensionPacks (all as descriptors with IDs).\n *\n * @throws Error if contract target doesn't match the provided target descriptor\n * @throws Error if contract requires extension packs not provided in descriptors\n */\nexport function assertRuntimeContractRequirementsSatisfied<\n TFamilyId extends string,\n TTargetId extends string,\n>({\n contract,\n family,\n target,\n adapter,\n extensionPacks,\n}: {\n readonly contract: { readonly target: string; readonly extensionPacks?: Record<string, unknown> };\n readonly family: RuntimeFamilyDescriptor<TFamilyId>;\n readonly target: RuntimeTargetDescriptor<TFamilyId, TTargetId>;\n readonly adapter: RuntimeAdapterDescriptor<TFamilyId, TTargetId>;\n readonly extensionPacks: readonly RuntimeExtensionDescriptor<TFamilyId, TTargetId>[];\n}): void {\n // Build set of provided component IDs from descriptors\n const providedComponentIds = new Set<string>([family.id, target.id, adapter.id]);\n for (const extension of extensionPacks) {\n providedComponentIds.add(extension.id);\n }\n\n const result = checkContractComponentRequirements({\n contract,\n expectedTargetId: target.targetId,\n providedComponentIds,\n });\n\n if (result.targetMismatch) {\n throw new Error(\n `Contract target '${result.targetMismatch.actual}' does not match runtime target descriptor '${result.targetMismatch.expected}'.`,\n );\n }\n\n // Strict enforcement: all extension packs required by contract must be provided as descriptors\n for (const packId of result.missingExtensionPackIds) {\n throw new Error(\n `Contract requires extension pack '${packId}', but runtime descriptors do not provide a matching component.`,\n );\n }\n}\n"],"mappings":";AAAA,SAAS,0CAA0C;AAkB5C,SAAS,2CAGd;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AACF,GAMS;AAEP,QAAM,uBAAuB,oBAAI,IAAY,CAAC,OAAO,IAAI,OAAO,IAAI,QAAQ,EAAE,CAAC;AAC/E,aAAW,aAAa,gBAAgB;AACtC,yBAAqB,IAAI,UAAU,EAAE;AAAA,EACvC;AAEA,QAAM,SAAS,mCAAmC;AAAA,IAChD;AAAA,IACA,kBAAkB,OAAO;AAAA,IACzB;AAAA,EACF,CAAC;AAED,MAAI,OAAO,gBAAgB;AACzB,UAAM,IAAI;AAAA,MACR,oBAAoB,OAAO,eAAe,MAAM,+CAA+C,OAAO,eAAe,QAAQ;AAAA,IAC/H;AAAA,EACF;AAGA,aAAW,UAAU,OAAO,yBAAyB;AACnD,UAAM,IAAI;AAAA,MACR,qCAAqC,MAAM;AAAA,IAC7C;AAAA,EACF;AACF;","names":[]}
@@ -1 +0,0 @@
1
- //# sourceMappingURL=types.js.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":[],"sourcesContent":[],"mappings":"","names":[]}