@prisma-next/sql-orm-lane 0.1.0-pr.37.5 → 0.1.0-pr.38.1

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.
@@ -93,10 +93,10 @@ function errorMissingAlias(index) {
93
93
  throw planInvalid(`Missing alias at index ${index}`);
94
94
  }
95
95
  function errorMissingColumn(alias, index) {
96
- throw planInvalid(`Missing column for alias "${alias}" at index ${index}`);
96
+ throw planInvalid(`Missing column for alias ${alias} at index ${index}`);
97
97
  }
98
98
  function errorInvalidColumn(alias, index) {
99
- throw planInvalid(`Invalid column for alias "${alias}" at index ${index}`);
99
+ throw planInvalid(`Invalid column for alias ${alias} at index ${index}`);
100
100
  }
101
101
  function errorFailedToBuildWhereClause() {
102
102
  throw planInvalid("Failed to build WHERE clause");
@@ -113,115 +113,37 @@ function assertParameterExists(paramsMap, paramName) {
113
113
  return paramsMap[paramName];
114
114
  }
115
115
 
116
- // src/utils/guards.ts
117
- function extractBaseColumnRef(expr) {
118
- if (expr.kind === "col") {
119
- return expr;
120
- }
121
- return extractBaseColumnRef(expr.self);
122
- }
123
- function collectColumnRefs(expr) {
124
- if (expr.kind === "col") {
125
- return [expr];
126
- }
127
- if (expr.kind === "operation") {
128
- const refs = collectColumnRefs(expr.self);
129
- for (const arg of expr.args) {
130
- refs.push(...collectColumnRefs(arg));
131
- }
132
- return refs;
133
- }
134
- return [];
135
- }
136
- function isOperationExpr(expr) {
137
- return typeof expr === "object" && expr !== null && "kind" in expr && expr.kind === "operation";
138
- }
139
- function getOperationExpr(builder) {
140
- if (isOperationExpr(builder)) {
141
- return builder;
142
- }
143
- const builderWithExpr = builder;
144
- return builderWithExpr._operationExpr;
145
- }
146
- function getColumnInfo(expr) {
147
- if (isOperationExpr(expr)) {
148
- const baseCol = extractBaseColumnRef(expr);
149
- return { table: baseCol.table, column: baseCol.column };
150
- }
151
- const colBuilder = expr;
152
- return { table: colBuilder.table, column: colBuilder.column };
153
- }
154
- function getColumnMeta(expr) {
155
- if ("columnMeta" in expr) {
156
- return expr.columnMeta;
157
- }
158
- return void 0;
159
- }
160
- function isColumnBuilder(value) {
161
- return typeof value === "object" && value !== null && "kind" in value && value.kind === "column";
162
- }
163
- function isParamPlaceholder(value) {
164
- return typeof value === "object" && value !== null && "kind" in value && value.kind === "param-placeholder" && "name" in value && typeof value.name === "string";
165
- }
166
-
167
116
  // src/selection/predicates.ts
168
117
  function buildWhereExpr(where, contract, paramsMap, descriptors, values) {
118
+ const placeholder = where.right;
119
+ const paramName = placeholder.name;
120
+ if (!Object.hasOwn(paramsMap, paramName)) {
121
+ errorMissingParameter(paramName);
122
+ }
123
+ const value = paramsMap[paramName];
124
+ const index = values.push(value);
169
125
  let leftExpr;
170
126
  let codecId;
171
- let rightExpr;
172
- let paramName;
173
- const operationExpr = getOperationExpr(where.left);
127
+ const operationExpr = where.left._operationExpr;
174
128
  if (operationExpr) {
175
129
  leftExpr = operationExpr;
176
- } else if (isColumnBuilder(where.left)) {
177
- const { table, column } = getColumnInfo(where.left);
178
- const contractTable = contract.storage.tables[table];
179
- if (!contractTable) {
180
- errorUnknownTable(table);
181
- }
182
- const columnMeta = contractTable.columns[column];
183
- if (columnMeta) {
184
- codecId = columnMeta.codecId;
185
- }
186
- leftExpr = createColumnRef(table, column);
187
130
  } else {
188
- errorFailedToBuildWhereClause();
189
- }
190
- if (isParamPlaceholder(where.right)) {
191
- const placeholder = where.right;
192
- paramName = placeholder.name;
193
- if (!Object.hasOwn(paramsMap, paramName)) {
194
- errorMissingParameter(paramName);
195
- }
196
- const value = paramsMap[paramName];
197
- const index = values.push(value);
198
- if (isColumnBuilder(where.left)) {
199
- const { table, column } = getColumnInfo(where.left);
200
- const contractTable = contract.storage.tables[table];
201
- const columnMeta = contractTable?.columns[column];
202
- const builderColumnMeta = getColumnMeta(where.left);
203
- descriptors.push({
204
- name: paramName,
205
- source: "dsl",
206
- refs: { table, column },
207
- ...typeof builderColumnMeta?.nullable === "boolean" ? { nullable: builderColumnMeta.nullable } : {}
208
- });
209
- augmentDescriptorWithColumnMeta(descriptors, columnMeta);
210
- }
211
- rightExpr = createParamRef(index, paramName);
212
- } else if (isColumnBuilder(where.right)) {
213
- const { table, column } = getColumnInfo(where.right);
214
- const contractTable = contract.storage.tables[table];
215
- if (!contractTable) {
216
- errorUnknownTable(table);
217
- }
218
- rightExpr = createColumnRef(table, column);
219
- paramName = "";
220
- } else {
221
- errorFailedToBuildWhereClause();
131
+ const colBuilder = where.left;
132
+ const meta = colBuilder.columnMeta ?? {};
133
+ descriptors.push({
134
+ name: paramName,
135
+ source: "dsl",
136
+ refs: { table: colBuilder.table, column: colBuilder.column },
137
+ ...typeof meta.nullable === "boolean" ? { nullable: meta.nullable } : {}
138
+ });
139
+ const contractTable = contract.storage.tables[colBuilder.table];
140
+ const columnMeta = contractTable?.columns[colBuilder.column];
141
+ codecId = columnMeta?.codecId;
142
+ augmentDescriptorWithColumnMeta(descriptors, columnMeta);
143
+ leftExpr = createColumnRef(colBuilder.table, colBuilder.column);
222
144
  }
223
145
  return {
224
- expr: createBinaryExpr(where.op, leftExpr, rightExpr),
146
+ expr: createBinaryExpr(where.op, leftExpr, createParamRef(index, paramName)),
225
147
  ...codecId ? { codecId } : {},
226
148
  paramName
227
149
  };
@@ -668,6 +590,43 @@ var OrmRelationFilterBuilderImpl = class _OrmRelationFilterBuilderImpl {
668
590
  // src/plan/plan-assembly.ts
669
591
  import { planInvalid as planInvalid4 } from "@prisma-next/plan";
670
592
  import { compact } from "@prisma-next/sql-relational-core/ast";
593
+
594
+ // src/utils/guards.ts
595
+ function extractBaseColumnRef(expr) {
596
+ if (expr.kind === "col") {
597
+ return expr;
598
+ }
599
+ return extractBaseColumnRef(expr.self);
600
+ }
601
+ function collectColumnRefs(expr) {
602
+ if (expr.kind === "col") {
603
+ return [expr];
604
+ }
605
+ if (expr.kind === "operation") {
606
+ const refs = collectColumnRefs(expr.self);
607
+ for (const arg of expr.args) {
608
+ refs.push(...collectColumnRefs(arg));
609
+ }
610
+ return refs;
611
+ }
612
+ return [];
613
+ }
614
+ function isOperationExpr(expr) {
615
+ return typeof expr === "object" && expr !== null && "kind" in expr && expr.kind === "operation";
616
+ }
617
+ function getColumnInfo(expr) {
618
+ if (isOperationExpr(expr)) {
619
+ const baseCol = extractBaseColumnRef(expr);
620
+ return { table: baseCol.table, column: baseCol.column };
621
+ }
622
+ const colBuilder = expr;
623
+ return { table: colBuilder.table, column: colBuilder.column };
624
+ }
625
+ function isColumnBuilder(value) {
626
+ return typeof value === "object" && value !== null && "kind" in value && value.kind === "column";
627
+ }
628
+
629
+ // src/plan/plan-assembly.ts
671
630
  function buildMeta(args) {
672
631
  const refsColumns = /* @__PURE__ */ new Map();
673
632
  const refsTables = /* @__PURE__ */ new Set([args.table.name]);
@@ -817,7 +776,8 @@ function buildMeta(args) {
817
776
  projectionTypes[alias] = operationExpr.returns.type;
818
777
  }
819
778
  } else {
820
- const columnMeta = getColumnMeta(col);
779
+ const colMeta = col;
780
+ const columnMeta = colMeta.columnMeta;
821
781
  const codecId = columnMeta?.codecId;
822
782
  if (codecId) {
823
783
  projectionTypes[alias] = codecId;
@@ -840,7 +800,8 @@ function buildMeta(args) {
840
800
  projectionCodecs[alias] = operationExpr.returns.type;
841
801
  }
842
802
  } else {
843
- const columnMeta = getColumnMeta(column);
803
+ const col = column;
804
+ const columnMeta = col.columnMeta;
844
805
  const codecId = columnMeta?.codecId;
845
806
  if (codecId) {
846
807
  projectionCodecs[alias] = codecId;
@@ -1755,4 +1716,4 @@ export {
1755
1716
  OrmModelBuilderImpl,
1756
1717
  orm
1757
1718
  };
1758
- //# sourceMappingURL=chunk-K7DL6OZX.js.map
1719
+ //# sourceMappingURL=chunk-KQPLODPT.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/orm/builder.ts","../src/selection/predicates.ts","../src/utils/ast.ts","../src/utils/errors.ts","../src/mutations/delete-builder.ts","../src/mutations/insert-builder.ts","../src/utils/param-descriptor.ts","../src/mutations/update-builder.ts","../src/orm-include-child.ts","../src/orm-relation-filter.ts","../src/plan/plan-assembly.ts","../src/utils/guards.ts","../src/relations/include-plan.ts","../src/orm/capabilities.ts","../src/selection/join.ts","../src/selection/ordering.ts","../src/selection/projection.ts","../src/selection/select-builder.ts","../src/orm/context.ts","../src/orm.ts"],"sourcesContent":["import type { ParamDescriptor } from '@prisma-next/contract/types';\nimport { planInvalid } from '@prisma-next/plan';\nimport type { SqlContract, SqlStorage } from '@prisma-next/sql-contract/types';\nimport type { SelectAst, TableRef } from '@prisma-next/sql-relational-core/ast';\nimport type { SqlQueryPlan } from '@prisma-next/sql-relational-core/plan';\nimport type { QueryLaneContext } from '@prisma-next/sql-relational-core/query-lane-context';\nimport { schema } from '@prisma-next/sql-relational-core/schema';\nimport type {\n AnyBinaryBuilder,\n AnyColumnBuilder,\n AnyOrderBuilder,\n BinaryBuilder,\n BuildOptions,\n InferNestedProjectionRow,\n NestedProjection,\n OrderBuilder,\n} from '@prisma-next/sql-relational-core/types';\nimport { buildDeletePlan } from '../mutations/delete-builder';\nimport { buildInsertPlan } from '../mutations/insert-builder';\nimport { buildUpdatePlan } from '../mutations/update-builder';\nimport type { OrmIncludeChildBuilder } from '../orm-include-child';\nimport { OrmIncludeChildBuilderImpl } from '../orm-include-child';\nimport { OrmRelationFilterBuilderImpl } from '../orm-relation-filter';\nimport type {\n IncludeAccumulator,\n ModelColumnAccessor,\n OrmBuilderOptions,\n OrmIncludeAccessor,\n OrmModelBuilder,\n OrmRelationFilterBuilder,\n OrmWhereProperty,\n} from '../orm-types';\nimport { buildMeta, type MetaBuildArgs } from '../plan/plan-assembly';\nimport {\n buildExistsSubqueries,\n buildIncludeAsts,\n combineWhereClauses,\n} from '../relations/include-plan';\nimport { buildOrderByClause } from '../selection/ordering';\nimport { buildWhereExpr } from '../selection/predicates';\nimport { buildProjectionState, type ProjectionInput } from '../selection/projection';\nimport { buildProjectionItems, buildSelectAst } from '../selection/select-builder';\nimport { createTableRef } from '../utils/ast';\nimport { errorModelNotFound, errorTableNotFound, errorUnknownTable } from '../utils/errors';\nimport { createOrmContext } from './context';\nimport type { OrmIncludeState, RelationFilter } from './state';\n\nexport class OrmModelBuilderImpl<\n TContract extends SqlContract<SqlStorage>,\n CodecTypes extends Record<string, { output: unknown }> = Record<string, never>,\n ModelName extends string = string,\n Includes extends Record<string, unknown> = Record<string, never>,\n Row = unknown,\n> implements OrmModelBuilder<TContract, CodecTypes, ModelName, Includes, Row>\n{\n private readonly context: QueryLaneContext<TContract>;\n private readonly contract: TContract;\n private readonly modelName: ModelName;\n private table: TableRef;\n private wherePredicate: AnyBinaryBuilder | undefined = undefined;\n private relationFilters: RelationFilter[] = [];\n private includes: OrmIncludeState[] = [];\n private orderByExpr: AnyOrderBuilder | undefined = undefined;\n private limitValue: number | undefined = undefined;\n private offsetValue: number | undefined = undefined;\n private projection: Record<string, AnyColumnBuilder | boolean | NestedProjection> | undefined =\n undefined;\n\n constructor(options: OrmBuilderOptions<TContract>, modelName: ModelName) {\n this.context = options.context;\n this.contract = options.context.contract;\n this.modelName = modelName;\n\n const tableName = this.contract.mappings.modelToTable?.[modelName];\n if (!tableName) {\n errorModelNotFound(modelName);\n }\n\n const schemaHandle = schema(options.context);\n const table = schemaHandle.tables[tableName];\n if (!table) {\n errorTableNotFound(tableName);\n }\n this.table = table;\n }\n\n get where(): OrmWhereProperty<TContract, CodecTypes, ModelName, Includes, Row> {\n const whereFn = (\n fn: (model: ModelColumnAccessor<TContract, CodecTypes, ModelName>) => AnyBinaryBuilder,\n ): OrmModelBuilder<TContract, CodecTypes, ModelName, Includes, Row> => {\n const builder = new OrmModelBuilderImpl<TContract, CodecTypes, ModelName, Includes, Row>(\n { context: this.context },\n this.modelName,\n );\n builder['table'] = this.table;\n builder.wherePredicate = fn(this._getModelAccessor());\n builder.relationFilters = this.relationFilters;\n builder.includes = this.includes;\n builder.orderByExpr = this.orderByExpr;\n builder.limitValue = this.limitValue;\n builder.offsetValue = this.offsetValue;\n builder.projection = this.projection;\n return builder;\n };\n\n // Add related property using Proxy\n const related = this._createRelatedProxy();\n\n return Object.assign(whereFn, { related }) as OrmWhereProperty<\n TContract,\n CodecTypes,\n ModelName,\n Includes,\n Row\n >;\n }\n\n get include(): OrmIncludeAccessor<TContract, CodecTypes, ModelName, Includes, Row> {\n return this._createIncludeProxy();\n }\n\n private _createIncludeProxy(): OrmIncludeAccessor<\n TContract,\n CodecTypes,\n ModelName,\n Includes,\n Row\n > {\n const self = this;\n // Relations are keyed by table name, not model name\n const tableName = this.contract.mappings.modelToTable?.[this.modelName];\n if (!tableName) {\n return {} as OrmIncludeAccessor<TContract, CodecTypes, ModelName, Includes, Row>;\n }\n const modelRelations = this.contract.relations?.[tableName];\n if (!modelRelations || typeof modelRelations !== 'object') {\n return {} as OrmIncludeAccessor<TContract, CodecTypes, ModelName, Includes, Row>;\n }\n\n return new Proxy({} as OrmIncludeAccessor<TContract, CodecTypes, ModelName, Includes, Row>, {\n get(_target, prop) {\n if (typeof prop !== 'string') {\n return undefined;\n }\n\n const relation = (modelRelations as Record<string, { to?: string }>)[prop];\n if (!relation || typeof relation !== 'object' || !('to' in relation)) {\n throw planInvalid(`Relation ${prop} not found on model ${self.modelName}`);\n }\n\n const childModelName = relation.to as string;\n const relationDef = relation as {\n to: string;\n cardinality: string;\n on: { parentCols: readonly string[]; childCols: readonly string[] };\n };\n\n const relationName = prop as keyof typeof modelRelations & string;\n\n const includeFn = (<ChildRow>(\n child: (\n child: OrmIncludeChildBuilder<TContract, CodecTypes, typeof childModelName>,\n ) => OrmIncludeChildBuilder<TContract, CodecTypes, typeof childModelName, ChildRow>,\n ) => {\n return self._applyInclude<typeof relationName, ChildRow>(\n relationName,\n childModelName,\n child,\n relationDef,\n );\n }) as OrmIncludeAccessor<\n TContract,\n CodecTypes,\n ModelName,\n Includes,\n Row\n >[typeof relationName];\n\n return includeFn;\n },\n });\n }\n\n private _applyInclude<RelationName extends string, ChildRow>(\n relationName: RelationName,\n childModelName: string,\n childBuilderFn: (\n child: OrmIncludeChildBuilder<TContract, CodecTypes, string>,\n ) => OrmIncludeChildBuilder<TContract, CodecTypes, string, ChildRow>,\n relationDef: {\n to: string;\n cardinality: string;\n on: { parentCols: readonly string[]; childCols: readonly string[] };\n },\n ): OrmModelBuilder<\n TContract,\n CodecTypes,\n ModelName,\n IncludeAccumulator<Includes, RelationName, ChildRow>,\n Row\n > {\n // Get child table\n const childTableName = this.contract.mappings.modelToTable?.[childModelName];\n if (!childTableName) {\n errorModelNotFound(childModelName);\n }\n const childTable: TableRef = { kind: 'table', name: childTableName };\n\n // Create child builder and apply callback\n const childBuilder = new OrmIncludeChildBuilderImpl<TContract, CodecTypes, string>(\n { context: this.context },\n childModelName,\n );\n const builtChild = childBuilderFn(\n childBuilder as OrmIncludeChildBuilder<TContract, CodecTypes, string>,\n );\n const childState = (\n builtChild as OrmIncludeChildBuilderImpl<TContract, CodecTypes, string, ChildRow>\n ).getState();\n\n // Store the include\n // Note: Child projection validation happens in findMany() when compiling to includeMany\n const includeState: OrmIncludeState = {\n relationName,\n childModelName,\n childTable,\n childWhere: childState.childWhere,\n childOrderBy: childState.childOrderBy,\n childLimit: childState.childLimit,\n childProjection: childState.childProjection,\n alias: relationName,\n relation: relationDef,\n };\n\n const builder = new OrmModelBuilderImpl<\n TContract,\n CodecTypes,\n ModelName,\n IncludeAccumulator<Includes, RelationName, ChildRow>,\n Row\n >({ context: this.context }, this.modelName);\n builder['table'] = this.table;\n builder.wherePredicate = this.wherePredicate;\n builder.relationFilters = this.relationFilters;\n builder.includes = [...this.includes, includeState];\n builder.orderByExpr = this.orderByExpr;\n builder.limitValue = this.limitValue;\n builder.offsetValue = this.offsetValue;\n builder.projection = this.projection;\n return builder;\n }\n\n private _createRelatedProxy(): OrmWhereProperty<\n TContract,\n CodecTypes,\n ModelName,\n Includes,\n Row\n >['related'] {\n const self = this;\n // Relations are keyed by table name, not model name\n const tableName = this.contract.mappings.modelToTable?.[this.modelName];\n if (!tableName) {\n return {} as OrmWhereProperty<TContract, CodecTypes, ModelName, Includes, Row>['related'];\n }\n const modelRelations = this.contract.relations?.[tableName];\n if (!modelRelations || typeof modelRelations !== 'object') {\n return {} as OrmWhereProperty<TContract, CodecTypes, ModelName, Includes, Row>['related'];\n }\n\n return new Proxy(\n {} as OrmWhereProperty<TContract, CodecTypes, ModelName, Includes, Row>['related'],\n {\n get(_target, prop) {\n if (typeof prop !== 'string') {\n return undefined;\n }\n\n const relation = (modelRelations as Record<string, { to?: string }>)[prop];\n if (!relation || typeof relation !== 'object' || !('to' in relation)) {\n throw planInvalid(`Relation ${prop} not found on model ${self.modelName}`);\n }\n\n const childModelName = relation.to as string;\n const relationDef = relation as {\n to: string;\n cardinality: string;\n on: { parentCols: readonly string[]; childCols: readonly string[] };\n };\n const filterBuilder = new OrmRelationFilterBuilderImpl<\n TContract,\n CodecTypes,\n typeof childModelName\n >({ context: self.context }, childModelName);\n // Expose model accessor directly on the builder for convenience\n const modelAccessor = filterBuilder.getModelAccessor();\n const builderWithAccessor = Object.assign(\n filterBuilder,\n modelAccessor,\n ) as OrmRelationFilterBuilder<TContract, CodecTypes, typeof childModelName> &\n ModelColumnAccessor<TContract, CodecTypes, typeof childModelName>;\n\n return {\n some: (\n fn: (\n child:\n | OrmRelationFilterBuilder<TContract, CodecTypes, typeof childModelName>\n | ModelColumnAccessor<TContract, CodecTypes, typeof childModelName>,\n ) =>\n | OrmRelationFilterBuilder<TContract, CodecTypes, typeof childModelName>\n | AnyBinaryBuilder,\n ) => {\n const result = fn(builderWithAccessor);\n // If result is a AnyBinaryBuilder, wrap it in a builder\n if (result && 'kind' in result && result.kind === 'binary') {\n const wrappedBuilder = new OrmRelationFilterBuilderImpl<\n TContract,\n CodecTypes,\n typeof childModelName\n >({ context: self.context }, childModelName);\n wrappedBuilder['wherePredicate'] = result as AnyBinaryBuilder;\n return self._applyRelationFilter(\n prop,\n childModelName,\n 'some',\n () => wrappedBuilder,\n relationDef,\n );\n }\n return self._applyRelationFilter(\n prop,\n childModelName,\n 'some',\n () =>\n result as OrmRelationFilterBuilder<TContract, CodecTypes, typeof childModelName>,\n relationDef,\n );\n },\n none: (\n fn: (\n child:\n | OrmRelationFilterBuilder<TContract, CodecTypes, typeof childModelName>\n | ModelColumnAccessor<TContract, CodecTypes, typeof childModelName>,\n ) =>\n | OrmRelationFilterBuilder<TContract, CodecTypes, typeof childModelName>\n | AnyBinaryBuilder,\n ) => {\n const result = fn(builderWithAccessor);\n if (result && 'kind' in result && result.kind === 'binary') {\n const wrappedBuilder = new OrmRelationFilterBuilderImpl<\n TContract,\n CodecTypes,\n typeof childModelName\n >({ context: self.context }, childModelName);\n wrappedBuilder['wherePredicate'] = result as AnyBinaryBuilder;\n return self._applyRelationFilter(\n prop,\n childModelName,\n 'none',\n () => wrappedBuilder,\n relationDef,\n );\n }\n return self._applyRelationFilter(\n prop,\n childModelName,\n 'none',\n () =>\n result as OrmRelationFilterBuilder<TContract, CodecTypes, typeof childModelName>,\n relationDef,\n );\n },\n every: (\n fn: (\n child:\n | OrmRelationFilterBuilder<TContract, CodecTypes, typeof childModelName>\n | ModelColumnAccessor<TContract, CodecTypes, typeof childModelName>,\n ) =>\n | OrmRelationFilterBuilder<TContract, CodecTypes, typeof childModelName>\n | AnyBinaryBuilder,\n ) => {\n const result = fn(builderWithAccessor);\n if (result && 'kind' in result && result.kind === 'binary') {\n const wrappedBuilder = new OrmRelationFilterBuilderImpl<\n TContract,\n CodecTypes,\n typeof childModelName\n >({ context: self.context }, childModelName);\n wrappedBuilder['wherePredicate'] = result as AnyBinaryBuilder;\n return self._applyRelationFilter(\n prop,\n childModelName,\n 'every',\n () => wrappedBuilder,\n relationDef,\n );\n }\n return self._applyRelationFilter(\n prop,\n childModelName,\n 'every',\n () =>\n result as OrmRelationFilterBuilder<TContract, CodecTypes, typeof childModelName>,\n relationDef,\n );\n },\n };\n },\n },\n );\n }\n\n private _applyRelationFilter(\n relationName: string,\n childModelName: string,\n filterType: 'some' | 'none' | 'every',\n fn: (\n child: OrmRelationFilterBuilder<TContract, CodecTypes, string>,\n ) => OrmRelationFilterBuilder<TContract, CodecTypes, string>,\n relationDef: {\n to: string;\n cardinality: string;\n on: { parentCols: readonly string[]; childCols: readonly string[] };\n },\n ): OrmModelBuilder<TContract, CodecTypes, ModelName, Includes, Row> {\n // Create a relation filter builder and apply the callback\n const filterBuilder = new OrmRelationFilterBuilderImpl<TContract, CodecTypes, string>(\n { context: this.context },\n childModelName,\n );\n const appliedFilter = fn(\n filterBuilder as OrmRelationFilterBuilder<TContract, CodecTypes, string>,\n );\n const childWhere = (\n appliedFilter as OrmRelationFilterBuilderImpl<TContract, CodecTypes, string>\n ).getWherePredicate();\n\n // Store the relation filter\n const relationFilter: RelationFilter = {\n relationName,\n childModelName,\n filterType,\n childWhere,\n relation: relationDef,\n };\n\n const builder = new OrmModelBuilderImpl<TContract, CodecTypes, ModelName, Includes, Row>(\n { context: this.context },\n this.modelName,\n );\n builder['table'] = this.table;\n builder.wherePredicate = this.wherePredicate;\n builder.relationFilters = [...this.relationFilters, relationFilter];\n builder.includes = this.includes;\n builder.orderByExpr = this.orderByExpr;\n builder.limitValue = this.limitValue;\n builder.offsetValue = this.offsetValue;\n builder.projection = this.projection;\n return builder;\n }\n\n orderBy(\n fn: (model: ModelColumnAccessor<TContract, CodecTypes, ModelName>) => OrderBuilder,\n ): OrmModelBuilder<TContract, CodecTypes, ModelName, Includes, Row> {\n const builder = new OrmModelBuilderImpl<TContract, CodecTypes, ModelName, Includes, Row>(\n { context: this.context },\n this.modelName,\n );\n builder['table'] = this.table;\n builder.wherePredicate = this.wherePredicate;\n builder.relationFilters = this.relationFilters;\n builder.includes = this.includes;\n builder.orderByExpr = fn(this._getModelAccessor());\n builder.limitValue = this.limitValue;\n builder.offsetValue = this.offsetValue;\n builder.projection = this.projection;\n return builder;\n }\n\n take(n: number): OrmModelBuilder<TContract, CodecTypes, ModelName, Includes, Row> {\n const builder = new OrmModelBuilderImpl<TContract, CodecTypes, ModelName, Includes, Row>(\n { context: this.context },\n this.modelName,\n );\n builder['table'] = this.table;\n builder.wherePredicate = this.wherePredicate;\n builder.relationFilters = this.relationFilters;\n builder.includes = this.includes;\n builder.orderByExpr = this.orderByExpr;\n builder.limitValue = n;\n builder.offsetValue = this.offsetValue;\n builder.projection = this.projection;\n return builder;\n }\n\n skip(n: number): OrmModelBuilder<TContract, CodecTypes, ModelName, Includes, Row> {\n // TODO: SQL lane doesn't support offset yet - this is a placeholder\n // When offset is added to SelectAst, implement it here\n const builder = new OrmModelBuilderImpl<TContract, CodecTypes, ModelName, Includes, Row>(\n { context: this.context },\n this.modelName,\n );\n builder['table'] = this.table;\n builder.wherePredicate = this.wherePredicate;\n builder.relationFilters = this.relationFilters;\n builder.includes = this.includes;\n builder.orderByExpr = this.orderByExpr;\n builder.limitValue = this.limitValue;\n builder.offsetValue = n;\n builder.projection = this.projection;\n return builder;\n }\n\n select<Projection extends Record<string, AnyColumnBuilder | boolean | NestedProjection>>(\n fn: (model: ModelColumnAccessor<TContract, CodecTypes, ModelName>) => Projection,\n ): OrmModelBuilder<\n TContract,\n CodecTypes,\n ModelName,\n Includes,\n InferNestedProjectionRow<Projection, CodecTypes, Includes>\n > {\n const builder = new OrmModelBuilderImpl<\n TContract,\n CodecTypes,\n ModelName,\n Includes,\n InferNestedProjectionRow<Projection, CodecTypes, Includes>\n >({ context: this.context }, this.modelName);\n builder['table'] = this.table;\n builder.wherePredicate = this.wherePredicate;\n builder.relationFilters = this.relationFilters;\n builder.includes = this.includes;\n builder.orderByExpr = this.orderByExpr;\n builder.limitValue = this.limitValue;\n builder.offsetValue = this.offsetValue;\n builder.projection = fn(this._getModelAccessor());\n return builder as OrmModelBuilder<\n TContract,\n CodecTypes,\n ModelName,\n Includes,\n InferNestedProjectionRow<Projection, CodecTypes, Includes>\n >;\n }\n\n findMany(options?: BuildOptions): SqlQueryPlan<Row> {\n const paramsMap = (options?.params ?? {}) as Record<string, unknown>;\n const contractTable = this.contract.storage.tables[this.table.name];\n\n if (!contractTable) {\n errorUnknownTable(this.table.name);\n }\n\n const paramDescriptors: ParamDescriptor[] = [];\n const paramValues: unknown[] = [];\n const paramCodecs: Record<string, string> = {};\n\n // Build projection state\n const projectionInput: ProjectionInput =\n this.projection ??\n (() => {\n const modelAccessor = this._getModelAccessor();\n const defaultProjection: Record<string, AnyColumnBuilder> = {};\n for (const fieldName in modelAccessor) {\n defaultProjection[fieldName] = modelAccessor[fieldName];\n }\n return defaultProjection;\n })();\n\n // Build includes AST\n const { includesAst, includesForMeta } = buildIncludeAsts(\n this.includes,\n this.contract,\n this.context,\n this.modelName,\n paramsMap,\n paramDescriptors,\n paramValues,\n paramCodecs,\n );\n\n // Build projection state\n const projectionState = buildProjectionState(\n this.table,\n projectionInput,\n includesForMeta.length > 0\n ? (includesForMeta as unknown as Parameters<typeof buildProjectionState>[2])\n : undefined,\n );\n\n // Build where clause\n const whereResult = this.wherePredicate\n ? buildWhereExpr(this.wherePredicate, this.contract, paramsMap, paramDescriptors, paramValues)\n : undefined;\n const whereExpr = whereResult?.expr;\n if (whereResult?.codecId && whereResult.paramName) {\n paramCodecs[whereResult.paramName] = whereResult.codecId;\n }\n\n // Build orderBy clause\n const orderByClause = buildOrderByClause(this.orderByExpr);\n\n // Build main projection items\n const projectEntries = buildProjectionItems(projectionState, includesForMeta);\n\n // Build SELECT AST\n const ast = buildSelectAst(\n this.table,\n projectEntries,\n includesAst.length > 0 ? includesAst : undefined,\n whereExpr,\n orderByClause,\n this.limitValue,\n );\n\n // Build plan metadata\n const planMeta = buildMeta({\n contract: this.contract,\n table: createTableRef(this.table.name),\n projection: projectionState,\n includes: includesForMeta.length > 0 ? includesForMeta : undefined,\n paramDescriptors,\n paramCodecs: Object.keys(paramCodecs).length > 0 ? paramCodecs : undefined,\n where: this.wherePredicate as BinaryBuilder | undefined,\n orderBy: this.orderByExpr,\n } as MetaBuildArgs);\n\n // Compile relation filters to EXISTS subqueries and combine with main where clause\n if (this.relationFilters.length > 0) {\n const existsExprs = buildExistsSubqueries(\n this.relationFilters,\n this.contract,\n this.modelName,\n options,\n );\n if (existsExprs.length > 0) {\n const combinedWhere = combineWhereClauses(ast.where, existsExprs);\n const modifiedAst: SelectAst = {\n ...ast,\n ...(combinedWhere !== undefined ? { where: combinedWhere } : {}),\n };\n return Object.freeze({\n ast: modifiedAst,\n params: paramValues,\n meta: {\n ...planMeta,\n lane: 'orm',\n },\n });\n }\n }\n\n return Object.freeze({\n ast,\n params: paramValues,\n meta: {\n ...planMeta,\n lane: 'orm',\n },\n });\n }\n\n findFirst(options?: BuildOptions): SqlQueryPlan<Row> {\n const queryPlan = this.take(1).findMany(options);\n return queryPlan;\n }\n\n findUnique(\n where: (model: ModelColumnAccessor<TContract, CodecTypes, ModelName>) => AnyBinaryBuilder,\n options?: BuildOptions,\n ): SqlQueryPlan<Row> {\n return this.where(where).take(1).findMany(options);\n }\n\n create(data: Record<string, unknown>, options?: BuildOptions): SqlQueryPlan<number> {\n const context = createOrmContext(this.context);\n return buildInsertPlan(context, this.modelName, data, options);\n }\n\n update(\n where: (model: ModelColumnAccessor<TContract, CodecTypes, ModelName>) => AnyBinaryBuilder,\n data: Record<string, unknown>,\n options?: BuildOptions,\n ): SqlQueryPlan<number> {\n const context = createOrmContext(this.context);\n return buildUpdatePlan<TContract, CodecTypes, ModelName>(\n context,\n this.modelName,\n where,\n () => this._getModelAccessor(),\n data,\n options,\n );\n }\n\n delete(\n where: (model: ModelColumnAccessor<TContract, CodecTypes, ModelName>) => AnyBinaryBuilder,\n options?: BuildOptions,\n ): SqlQueryPlan<number> {\n const context = createOrmContext(this.context);\n return buildDeletePlan<TContract, CodecTypes, ModelName>(\n context,\n this.modelName,\n where,\n () => this._getModelAccessor(),\n options,\n );\n }\n\n private _getModelAccessor(): ModelColumnAccessor<TContract, CodecTypes, ModelName> {\n const tableName = this.contract.mappings.modelToTable?.[this.modelName];\n if (!tableName) {\n errorModelNotFound(this.modelName);\n }\n const schemaHandle = schema(this.context);\n const table = schemaHandle.tables[tableName];\n if (!table) {\n errorTableNotFound(tableName);\n }\n\n const accessor: Record<string, AnyColumnBuilder> = {};\n const model = this.contract.models[this.modelName];\n if (!model || typeof model !== 'object' || !('fields' in model)) {\n throw planInvalid(`Model ${this.modelName} does not have fields`);\n }\n const modelFields = model.fields as Record<string, { column?: string }>;\n\n for (const fieldName in modelFields) {\n const field = modelFields[fieldName];\n if (!field) continue;\n const columnName =\n this.contract.mappings.fieldToColumn?.[this.modelName]?.[fieldName] ??\n field.column ??\n fieldName;\n const column = table.columns[columnName];\n if (column) {\n accessor[fieldName] = column as AnyColumnBuilder;\n }\n }\n\n return accessor as ModelColumnAccessor<TContract, CodecTypes, ModelName>;\n }\n}\n","import type { ParamDescriptor } from '@prisma-next/contract/types';\nimport type { SqlContract, SqlStorage } from '@prisma-next/sql-contract/types';\nimport type { BinaryExpr, ColumnRef, OperationExpr } from '@prisma-next/sql-relational-core/ast';\nimport { augmentDescriptorWithColumnMeta } from '@prisma-next/sql-relational-core/plan';\nimport type { BinaryBuilder } from '@prisma-next/sql-relational-core/types';\nimport { createBinaryExpr, createColumnRef, createParamRef } from '../utils/ast';\nimport { errorMissingParameter } from '../utils/errors';\n\nexport function buildWhereExpr(\n where: BinaryBuilder,\n contract: SqlContract<SqlStorage>,\n paramsMap: Record<string, unknown>,\n descriptors: ParamDescriptor[],\n values: unknown[],\n): {\n expr: BinaryExpr;\n codecId?: string;\n paramName: string;\n} {\n const placeholder = where.right;\n const paramName = placeholder.name;\n\n if (!Object.hasOwn(paramsMap, paramName)) {\n errorMissingParameter(paramName);\n }\n\n const value = paramsMap[paramName];\n const index = values.push(value);\n\n let leftExpr: ColumnRef | OperationExpr;\n let codecId: string | undefined;\n\n const operationExpr = (where.left as { _operationExpr?: OperationExpr })._operationExpr;\n if (operationExpr) {\n leftExpr = operationExpr;\n } else {\n const colBuilder = where.left as unknown as {\n table: string;\n column: string;\n columnMeta?: { codecId?: string; nullable?: boolean };\n };\n const meta = colBuilder.columnMeta ?? {};\n\n descriptors.push({\n name: paramName,\n source: 'dsl',\n refs: { table: colBuilder.table, column: colBuilder.column },\n ...(typeof meta.nullable === 'boolean' ? { nullable: meta.nullable } : {}),\n });\n\n const contractTable = contract.storage.tables[colBuilder.table];\n const columnMeta = contractTable?.columns[colBuilder.column];\n codecId = columnMeta?.codecId;\n\n augmentDescriptorWithColumnMeta(descriptors, columnMeta);\n\n leftExpr = createColumnRef(colBuilder.table, colBuilder.column);\n }\n\n return {\n expr: createBinaryExpr(where.op, leftExpr, createParamRef(index, paramName)),\n ...(codecId ? { codecId } : {}),\n paramName,\n };\n}\n","export {\n createBinaryExpr,\n createColumnRef,\n createDeleteAst,\n createInsertAst,\n createJoinOnExpr,\n createOrderByItem,\n createParamRef,\n createSelectAst,\n createTableRef,\n createUpdateAst,\n} from '@prisma-next/sql-relational-core/ast';\n","import { planInvalid } from '@prisma-next/plan';\nimport type { StorageColumn } from '@prisma-next/sql-contract/types';\n\nexport function errorModelNotFound(modelName: string): never {\n throw planInvalid(`Model ${modelName} not found in mappings`);\n}\n\nexport function errorTableNotFound(tableName: string): never {\n throw planInvalid(`Table ${tableName} not found in schema`);\n}\n\nexport function errorUnknownTable(tableName: string): never {\n throw planInvalid(`Unknown table ${tableName}`);\n}\n\nexport function errorUnknownColumn(columnName: string, tableName: string): never {\n throw planInvalid(`Unknown column ${columnName} in table ${tableName}`);\n}\n\nexport function errorMissingParameter(paramName: string): never {\n throw planInvalid(`Missing value for parameter ${paramName}`);\n}\n\nexport function errorAliasPathEmpty(): never {\n throw planInvalid('Alias path cannot be empty');\n}\n\nexport function errorAliasCollision(path: string[], alias: string, existingPath?: string[]): never {\n throw planInvalid(\n `Alias collision: path ${path.join('.')} would generate alias \"${alias}\" which conflicts with path ${existingPath?.join('.') ?? 'unknown'}`,\n );\n}\n\nexport function errorInvalidProjectionValue(path: string[]): never {\n throw planInvalid(\n `Invalid projection value at path ${path.join('.')}: expected ColumnBuilder or nested object`,\n );\n}\n\nexport function errorIncludeAliasNotFound(alias: string): never {\n throw planInvalid(\n `Include alias \"${alias}\" not found. Did you call includeMany() with alias \"${alias}\"?`,\n );\n}\n\nexport function errorInvalidProjectionKey(key: string): never {\n throw planInvalid(\n `Invalid projection value at key \"${key}\": expected ColumnBuilder, boolean true (for includes), or nested object`,\n );\n}\n\nexport function errorProjectionEmpty(): never {\n throw planInvalid('select() requires at least one column or include');\n}\n\nexport function errorCreateRequiresFields(): never {\n throw planInvalid('create() requires at least one field');\n}\n\nexport function errorUpdateRequiresFields(): never {\n throw planInvalid('update() requires at least one field');\n}\n\nexport function errorIncludeRequiresCapabilities(): never {\n throw planInvalid('includeMany requires lateral and jsonAgg capabilities');\n}\n\nexport function errorIncludeCapabilitiesNotTrue(): never {\n throw planInvalid('includeMany requires lateral and jsonAgg capabilities to be true');\n}\n\nexport function errorMultiColumnJoinsNotSupported(): never {\n throw planInvalid('Multi-column joins in includes are not yet supported');\n}\n\nexport function errorJoinColumnsMustBeDefined(): never {\n throw planInvalid('Join columns must be defined');\n}\n\nexport function errorColumnNotFound(columnName: string, tableName: string): never {\n throw planInvalid(`Column ${columnName} not found in table ${tableName}`);\n}\n\nexport function errorChildProjectionMustBeSpecified(): never {\n throw planInvalid('Child projection must be specified');\n}\n\nexport function errorChildProjectionEmpty(): never {\n throw planInvalid('Child projection must not be empty after filtering boolean values');\n}\n\nexport function errorMissingAlias(index: number): never {\n throw planInvalid(`Missing alias at index ${index}`);\n}\n\nexport function errorMissingColumn(alias: string, index: number): never {\n throw planInvalid(`Missing column for alias ${alias} at index ${index}`);\n}\n\nexport function errorInvalidColumn(alias: string, index: number): never {\n throw planInvalid(`Invalid column for alias ${alias} at index ${index}`);\n}\n\nexport function errorRelationNotFound(relationName: string, modelName: string): never {\n throw planInvalid(`Relation ${relationName} not found on model ${modelName}`);\n}\n\nexport function errorFailedToBuildWhereClause(): never {\n throw planInvalid('Failed to build WHERE clause');\n}\n\nexport function assertColumnExists(\n columnMeta: StorageColumn | undefined,\n columnName: string,\n tableName: string,\n): asserts columnMeta is StorageColumn {\n if (!columnMeta) {\n errorUnknownColumn(columnName, tableName);\n }\n}\n\nexport function assertParameterExists(\n paramsMap: Record<string, unknown>,\n paramName: string,\n): unknown {\n if (!Object.hasOwn(paramsMap, paramName)) {\n errorMissingParameter(paramName);\n }\n return paramsMap[paramName];\n}\n","import type { ParamDescriptor } from '@prisma-next/contract/types';\nimport type { SqlContract, SqlStorage } from '@prisma-next/sql-contract/types';\nimport type { SqlQueryPlan } from '@prisma-next/sql-relational-core/plan';\nimport type { AnyBinaryBuilder, BuildOptions } from '@prisma-next/sql-relational-core/types';\nimport type { OrmContext } from '../orm/context';\nimport type { ModelColumnAccessor } from '../orm-types';\nimport { buildWhereExpr } from '../selection/predicates';\nimport { createDeleteAst, createTableRef } from '../utils/ast';\nimport { errorFailedToBuildWhereClause, errorModelNotFound } from '../utils/errors';\n\nexport function buildDeletePlan<\n TContract extends SqlContract<SqlStorage>,\n CodecTypes extends Record<string, { output: unknown }>,\n ModelName extends string,\n>(\n context: OrmContext<TContract>,\n modelName: ModelName,\n where: (model: ModelColumnAccessor<TContract, CodecTypes, ModelName>) => AnyBinaryBuilder,\n getModelAccessor: () => ModelColumnAccessor<TContract, CodecTypes, ModelName>,\n options?: BuildOptions,\n): SqlQueryPlan<number> {\n const modelAccessor = getModelAccessor();\n const wherePredicate = where(modelAccessor);\n\n const tableName = context.contract.mappings.modelToTable?.[modelName];\n if (!tableName) {\n errorModelNotFound(modelName);\n }\n const table = createTableRef(tableName);\n\n const paramsMap = (options?.params ?? {}) as Record<string, unknown>;\n const paramDescriptors: ParamDescriptor[] = [];\n const paramValues: unknown[] = [];\n const paramCodecs: Record<string, string> = {};\n\n const whereResult = buildWhereExpr(\n wherePredicate,\n context.contract,\n paramsMap,\n paramDescriptors,\n paramValues,\n );\n const whereExpr = whereResult.expr;\n if (!whereExpr) {\n errorFailedToBuildWhereClause();\n }\n\n if (whereResult?.codecId && whereResult.paramName) {\n paramCodecs[whereResult.paramName] = whereResult.codecId;\n }\n\n const ast = createDeleteAst({\n table,\n where: whereExpr,\n });\n\n return Object.freeze({\n ast,\n params: paramValues,\n meta: {\n target: context.contract.target,\n targetFamily: context.contract.targetFamily,\n coreHash: context.contract.coreHash,\n lane: 'orm',\n refs: {\n tables: [tableName],\n columns: [],\n },\n projection: {},\n paramDescriptors,\n ...(Object.keys(paramCodecs).length > 0\n ? {\n annotations: {\n codecs: paramCodecs,\n intent: 'write',\n isMutation: true,\n },\n }\n : {\n annotations: {\n intent: 'write',\n isMutation: true,\n },\n }),\n },\n });\n}\n","import type { ParamDescriptor } from '@prisma-next/contract/types';\nimport type { SqlContract, SqlStorage } from '@prisma-next/sql-contract/types';\nimport type { ColumnRef, ParamRef } from '@prisma-next/sql-relational-core/ast';\nimport { param } from '@prisma-next/sql-relational-core/param';\nimport type { SqlQueryPlan } from '@prisma-next/sql-relational-core/plan';\nimport type { BuildOptions, ParamPlaceholder } from '@prisma-next/sql-relational-core/types';\nimport type { OrmContext } from '../orm/context';\nimport { createInsertAst, createParamRef, createTableRef } from '../utils/ast';\nimport {\n assertColumnExists,\n assertParameterExists,\n errorCreateRequiresFields,\n errorModelNotFound,\n errorUnknownTable,\n} from '../utils/errors';\nimport { createParamDescriptor } from '../utils/param-descriptor';\n\nexport function convertModelFieldsToColumns<TContract extends SqlContract<SqlStorage>>(\n contract: TContract,\n modelName: string,\n fields: Record<string, unknown>,\n): Record<string, ParamPlaceholder> {\n const model = contract.models[modelName];\n if (!model || typeof model !== 'object' || !('fields' in model)) {\n throw new Error(`Model ${modelName} does not have fields`);\n }\n const modelFields = model.fields as Record<string, { column?: string }>;\n\n const result: Record<string, ParamPlaceholder> = {};\n\n for (const fieldName in fields) {\n if (!Object.hasOwn(fields, fieldName)) {\n continue;\n }\n\n if (!Object.hasOwn(modelFields, fieldName)) {\n throw new Error(`Field ${fieldName} does not exist on model ${modelName}`);\n }\n\n const field = modelFields[fieldName];\n if (!field) {\n continue;\n }\n\n const columnName =\n contract.mappings.fieldToColumn?.[modelName]?.[fieldName] ?? field.column ?? fieldName;\n\n result[columnName] = param(fieldName);\n }\n\n return result;\n}\n\nexport function buildInsertPlan<TContract extends SqlContract<SqlStorage>>(\n context: OrmContext<TContract>,\n modelName: string,\n data: Record<string, unknown>,\n options?: BuildOptions,\n): SqlQueryPlan<number> {\n if (!data || Object.keys(data).length === 0) {\n errorCreateRequiresFields();\n }\n\n const values = convertModelFieldsToColumns(context.contract, modelName, data);\n\n const tableName = context.contract.mappings.modelToTable?.[modelName];\n if (!tableName) {\n errorModelNotFound(modelName);\n }\n const table = createTableRef(tableName);\n\n const paramsMap = {\n ...(options?.params ?? {}),\n ...data,\n } as Record<string, unknown>;\n const paramDescriptors: ParamDescriptor[] = [];\n const paramValues: unknown[] = [];\n const paramCodecs: Record<string, string> = {};\n\n const contractTable = context.contract.storage.tables[tableName];\n if (!contractTable) {\n errorUnknownTable(tableName);\n }\n\n const insertValues: Record<string, ColumnRef | ParamRef> = {};\n for (const [columnName, placeholder] of Object.entries(values)) {\n const columnMeta = contractTable.columns[columnName];\n assertColumnExists(columnMeta, columnName, tableName);\n\n const paramName = placeholder.name;\n const value = assertParameterExists(paramsMap, paramName);\n const index = paramValues.push(value);\n\n const codecId = columnMeta.codecId;\n if (paramName) {\n paramCodecs[paramName] = codecId;\n }\n\n paramDescriptors.push(\n createParamDescriptor({\n name: paramName,\n table: tableName,\n column: columnName,\n codecId: codecId,\n nativeType: columnMeta.nativeType,\n nullable: columnMeta.nullable,\n }),\n );\n\n insertValues[columnName] = createParamRef(index, paramName);\n }\n\n const ast = createInsertAst({\n table,\n values: insertValues,\n });\n\n return Object.freeze({\n ast,\n params: paramValues,\n meta: {\n target: context.contract.target,\n targetFamily: context.contract.targetFamily,\n coreHash: context.contract.coreHash,\n lane: 'orm',\n refs: {\n tables: [tableName],\n columns: [],\n },\n projection: {},\n paramDescriptors,\n ...(Object.keys(paramCodecs).length > 0\n ? {\n annotations: {\n codecs: paramCodecs,\n intent: 'write',\n isMutation: true,\n },\n }\n : {\n annotations: {\n intent: 'write',\n isMutation: true,\n },\n }),\n },\n });\n}\n","import type { ParamDescriptor } from '@prisma-next/contract/types';\n\nexport function createParamDescriptor(args: {\n name: string;\n table: string;\n column: string;\n codecId?: string;\n nativeType?: string;\n nullable: boolean;\n}): ParamDescriptor {\n return {\n name: args.name,\n source: 'dsl',\n refs: { table: args.table, column: args.column },\n ...(args.codecId ? { codecId: args.codecId } : {}),\n ...(args.nativeType ? { nativeType: args.nativeType } : {}),\n nullable: args.nullable,\n };\n}\n","import type { ParamDescriptor } from '@prisma-next/contract/types';\nimport type { SqlContract, SqlStorage } from '@prisma-next/sql-contract/types';\nimport type { ColumnRef, ParamRef } from '@prisma-next/sql-relational-core/ast';\nimport type { SqlQueryPlan } from '@prisma-next/sql-relational-core/plan';\nimport type { AnyBinaryBuilder, BuildOptions } from '@prisma-next/sql-relational-core/types';\nimport type { OrmContext } from '../orm/context';\nimport type { ModelColumnAccessor } from '../orm-types';\nimport { buildWhereExpr } from '../selection/predicates';\nimport { createParamRef, createTableRef, createUpdateAst } from '../utils/ast';\nimport {\n assertColumnExists,\n assertParameterExists,\n errorFailedToBuildWhereClause,\n errorModelNotFound,\n errorUnknownTable,\n errorUpdateRequiresFields,\n} from '../utils/errors';\nimport { createParamDescriptor } from '../utils/param-descriptor';\nimport { convertModelFieldsToColumns } from './insert-builder';\n\nexport function buildUpdatePlan<\n TContract extends SqlContract<SqlStorage>,\n CodecTypes extends Record<string, { output: unknown }>,\n ModelName extends string,\n>(\n context: OrmContext<TContract>,\n modelName: ModelName,\n where: (model: ModelColumnAccessor<TContract, CodecTypes, ModelName>) => AnyBinaryBuilder,\n getModelAccessor: () => ModelColumnAccessor<TContract, CodecTypes, ModelName>,\n data: Record<string, unknown>,\n options?: BuildOptions,\n): SqlQueryPlan<number> {\n if (!data || Object.keys(data).length === 0) {\n errorUpdateRequiresFields();\n }\n\n const set = convertModelFieldsToColumns(context.contract, modelName, data);\n\n const modelAccessor = getModelAccessor();\n const wherePredicate = where(modelAccessor);\n\n const tableName = context.contract.mappings.modelToTable?.[modelName];\n if (!tableName) {\n errorModelNotFound(modelName);\n }\n const table = createTableRef(tableName);\n\n const paramsMap = {\n ...(options?.params ?? {}),\n ...data,\n } as Record<string, unknown>;\n const paramDescriptors: ParamDescriptor[] = [];\n const paramValues: unknown[] = [];\n const paramCodecs: Record<string, string> = {};\n\n const contractTable = context.contract.storage.tables[tableName];\n if (!contractTable) {\n errorUnknownTable(tableName);\n }\n\n const updateSet: Record<string, ColumnRef | ParamRef> = {};\n for (const [columnName, placeholder] of Object.entries(set)) {\n const columnMeta = contractTable.columns[columnName];\n assertColumnExists(columnMeta, columnName, tableName);\n\n const paramName = placeholder.name;\n const value = assertParameterExists(paramsMap, paramName);\n const index = paramValues.push(value);\n\n const codecId = columnMeta.codecId;\n if (paramName) {\n paramCodecs[paramName] = codecId;\n }\n\n paramDescriptors.push(\n createParamDescriptor({\n name: paramName,\n table: tableName,\n column: columnName,\n codecId: codecId,\n nativeType: columnMeta.nativeType,\n nullable: columnMeta.nullable,\n }),\n );\n\n updateSet[columnName] = createParamRef(index, paramName);\n }\n\n const whereResult = buildWhereExpr(\n wherePredicate,\n context.contract,\n paramsMap,\n paramDescriptors,\n paramValues,\n );\n const whereExpr = whereResult.expr;\n if (!whereExpr) {\n errorFailedToBuildWhereClause();\n }\n\n if (whereResult?.codecId && whereResult.paramName) {\n paramCodecs[whereResult.paramName] = whereResult.codecId;\n }\n\n const ast = createUpdateAst({\n table,\n set: updateSet,\n where: whereExpr,\n });\n\n return Object.freeze({\n ast,\n params: paramValues,\n meta: {\n target: context.contract.target,\n targetFamily: context.contract.targetFamily,\n coreHash: context.contract.coreHash,\n lane: 'orm',\n refs: {\n tables: [tableName],\n columns: [],\n },\n projection: {},\n paramDescriptors,\n ...(Object.keys(paramCodecs).length > 0\n ? {\n annotations: {\n codecs: paramCodecs,\n intent: 'write',\n isMutation: true,\n },\n }\n : {\n annotations: {\n intent: 'write',\n isMutation: true,\n },\n }),\n },\n });\n}\n","import { planInvalid } from '@prisma-next/plan';\nimport type { SqlContract, SqlStorage } from '@prisma-next/sql-contract/types';\nimport type { QueryLaneContext } from '@prisma-next/sql-relational-core/query-lane-context';\nimport { schema } from '@prisma-next/sql-relational-core/schema';\nimport type {\n AnyBinaryBuilder,\n AnyColumnBuilder,\n AnyOrderBuilder,\n InferNestedProjectionRow,\n NestedProjection,\n} from '@prisma-next/sql-relational-core/types';\nimport type { ModelColumnAccessor, OrmBuilderOptions } from './orm-types';\n\nexport interface OrmIncludeChildBuilder<\n TContract extends SqlContract<SqlStorage>,\n CodecTypes extends Record<string, { output: unknown }>,\n ChildModelName extends string,\n ChildRow = unknown,\n> {\n where(\n fn: (model: ModelColumnAccessor<TContract, CodecTypes, ChildModelName>) => AnyBinaryBuilder,\n ): OrmIncludeChildBuilder<TContract, CodecTypes, ChildModelName, ChildRow>;\n orderBy(\n fn: (model: ModelColumnAccessor<TContract, CodecTypes, ChildModelName>) => AnyOrderBuilder,\n ): OrmIncludeChildBuilder<TContract, CodecTypes, ChildModelName, ChildRow>;\n take(n: number): OrmIncludeChildBuilder<TContract, CodecTypes, ChildModelName, ChildRow>;\n select<Projection extends Record<string, AnyColumnBuilder | boolean | NestedProjection>>(\n fn: (model: ModelColumnAccessor<TContract, CodecTypes, ChildModelName>) => Projection,\n ): OrmIncludeChildBuilder<\n TContract,\n CodecTypes,\n ChildModelName,\n InferNestedProjectionRow<Projection, CodecTypes>\n >;\n}\n\nexport class OrmIncludeChildBuilderImpl<\n TContract extends SqlContract<SqlStorage>,\n CodecTypes extends Record<string, { output: unknown }>,\n ChildModelName extends string,\n ChildRow = unknown,\n> implements OrmIncludeChildBuilder<TContract, CodecTypes, ChildModelName, ChildRow>\n{\n private readonly context: QueryLaneContext<TContract>;\n private readonly contract: TContract;\n private readonly childModelName: ChildModelName;\n private childWhere: AnyBinaryBuilder | undefined;\n private childOrderBy: AnyOrderBuilder | undefined;\n private childLimit: number | undefined;\n private childProjection:\n | Record<string, AnyColumnBuilder | boolean | NestedProjection>\n | undefined = undefined;\n\n constructor(options: OrmBuilderOptions<TContract>, childModelName: ChildModelName) {\n this.context = options.context;\n this.contract = options.context.contract;\n this.childModelName = childModelName;\n }\n\n where(\n fn: (model: ModelColumnAccessor<TContract, CodecTypes, ChildModelName>) => AnyBinaryBuilder,\n ): OrmIncludeChildBuilder<TContract, CodecTypes, ChildModelName, ChildRow> {\n const builder = new OrmIncludeChildBuilderImpl<TContract, CodecTypes, ChildModelName, ChildRow>(\n { context: this.context },\n this.childModelName,\n );\n builder.childWhere = fn(this._getModelAccessor());\n builder.childOrderBy = this.childOrderBy;\n builder.childLimit = this.childLimit;\n builder.childProjection = this.childProjection;\n return builder;\n }\n\n orderBy(\n fn: (model: ModelColumnAccessor<TContract, CodecTypes, ChildModelName>) => AnyOrderBuilder,\n ): OrmIncludeChildBuilder<TContract, CodecTypes, ChildModelName, ChildRow> {\n const builder = new OrmIncludeChildBuilderImpl<TContract, CodecTypes, ChildModelName, ChildRow>(\n { context: this.context },\n this.childModelName,\n );\n builder.childWhere = this.childWhere;\n builder.childOrderBy = fn(this._getModelAccessor());\n builder.childLimit = this.childLimit;\n builder.childProjection = this.childProjection;\n return builder;\n }\n\n take(n: number): OrmIncludeChildBuilder<TContract, CodecTypes, ChildModelName, ChildRow> {\n const builder = new OrmIncludeChildBuilderImpl<TContract, CodecTypes, ChildModelName, ChildRow>(\n { context: this.context },\n this.childModelName,\n );\n builder.childWhere = this.childWhere;\n builder.childOrderBy = this.childOrderBy;\n builder.childLimit = n;\n builder.childProjection = this.childProjection;\n return builder;\n }\n\n select<Projection extends Record<string, AnyColumnBuilder | boolean | NestedProjection>>(\n fn: (model: ModelColumnAccessor<TContract, CodecTypes, ChildModelName>) => Projection,\n ): OrmIncludeChildBuilder<\n TContract,\n CodecTypes,\n ChildModelName,\n InferNestedProjectionRow<Projection, CodecTypes>\n > {\n const builder = new OrmIncludeChildBuilderImpl<\n TContract,\n CodecTypes,\n ChildModelName,\n InferNestedProjectionRow<Projection, CodecTypes>\n >({ context: this.context }, this.childModelName);\n builder.childWhere = this.childWhere;\n builder.childOrderBy = this.childOrderBy;\n builder.childLimit = this.childLimit;\n builder.childProjection = fn(this._getModelAccessor());\n return builder;\n }\n\n getState(): {\n childWhere?: AnyBinaryBuilder;\n childOrderBy?: AnyOrderBuilder;\n childLimit?: number;\n childProjection?: Record<string, AnyColumnBuilder | boolean | NestedProjection>;\n } {\n return {\n ...(this.childWhere !== undefined ? { childWhere: this.childWhere } : {}),\n ...(this.childOrderBy !== undefined ? { childOrderBy: this.childOrderBy } : {}),\n ...(this.childLimit !== undefined ? { childLimit: this.childLimit } : {}),\n ...(this.childProjection !== undefined ? { childProjection: this.childProjection } : {}),\n };\n }\n\n private _getModelAccessor(): ModelColumnAccessor<TContract, CodecTypes, ChildModelName> {\n const tableName = this.contract.mappings.modelToTable?.[this.childModelName];\n if (!tableName) {\n throw planInvalid(`Model ${this.childModelName} not found in mappings`);\n }\n const schemaHandle = schema(this.context);\n const table = schemaHandle.tables[tableName];\n if (!table) {\n throw planInvalid(`Table ${tableName} not found in schema`);\n }\n\n const accessor = {} as ModelColumnAccessor<TContract, CodecTypes, ChildModelName>;\n const model = this.contract.models[this.childModelName];\n if (!model || typeof model !== 'object' || !('fields' in model)) {\n throw planInvalid(`Model ${this.childModelName} does not have fields`);\n }\n const modelFields = model.fields as Record<string, { column?: string }>;\n\n for (const fieldName in modelFields) {\n const field = modelFields[fieldName];\n if (!field) continue;\n const columnName =\n this.contract.mappings.fieldToColumn?.[this.childModelName]?.[fieldName] ??\n field.column ??\n fieldName;\n const column = table.columns[columnName];\n if (column) {\n // ModelColumnAccessor alignment is ensured by contract validation; cast for compatibility\n (accessor as Record<string, AnyColumnBuilder>)[fieldName] = column;\n }\n }\n\n return accessor;\n }\n}\n","import { planInvalid } from '@prisma-next/plan';\nimport type { SqlContract, SqlStorage } from '@prisma-next/sql-contract/types';\nimport type { QueryLaneContext } from '@prisma-next/sql-relational-core/query-lane-context';\nimport { schema } from '@prisma-next/sql-relational-core/schema';\nimport type { AnyBinaryBuilder, AnyColumnBuilder } from '@prisma-next/sql-relational-core/types';\nimport type { ModelColumnAccessor, OrmBuilderOptions, OrmRelationFilterBuilder } from './orm-types';\n\nexport class OrmRelationFilterBuilderImpl<\n TContract extends SqlContract<SqlStorage>,\n CodecTypes extends Record<string, { output: unknown }>,\n ChildModelName extends string,\n> implements OrmRelationFilterBuilder<TContract, CodecTypes, ChildModelName>\n{\n private readonly context: QueryLaneContext<TContract>;\n private readonly contract: TContract;\n private readonly childModelName: ChildModelName;\n private wherePredicate: AnyBinaryBuilder | undefined = undefined;\n private modelAccessor: ModelColumnAccessor<TContract, CodecTypes, ChildModelName> | undefined =\n undefined;\n\n constructor(options: OrmBuilderOptions<TContract>, childModelName: ChildModelName) {\n this.context = options.context;\n this.contract = options.context.contract;\n this.childModelName = childModelName;\n this.modelAccessor = this._getModelAccessor();\n }\n\n where(\n fn: (model: ModelColumnAccessor<TContract, CodecTypes, ChildModelName>) => AnyBinaryBuilder,\n ): OrmRelationFilterBuilder<TContract, CodecTypes, ChildModelName> {\n const builder = new OrmRelationFilterBuilderImpl<TContract, CodecTypes, ChildModelName>(\n { context: this.context },\n this.childModelName,\n );\n builder.modelAccessor = this.modelAccessor;\n if (this.modelAccessor) {\n builder.wherePredicate = fn(this.modelAccessor);\n }\n return builder;\n }\n\n getWherePredicate(): AnyBinaryBuilder | undefined {\n return this.wherePredicate;\n }\n\n getChildModelName(): ChildModelName {\n return this.childModelName;\n }\n\n getModelAccessor(): ModelColumnAccessor<TContract, CodecTypes, ChildModelName> {\n if (!this.modelAccessor) {\n this.modelAccessor = this._getModelAccessor();\n }\n if (!this.modelAccessor) {\n throw planInvalid(`Failed to get model accessor for ${this.childModelName}`);\n }\n return this.modelAccessor;\n }\n\n private _getModelAccessor(): ModelColumnAccessor<TContract, CodecTypes, ChildModelName> {\n const tableName = this.contract.mappings.modelToTable?.[this.childModelName];\n if (!tableName) {\n throw planInvalid(`Model ${this.childModelName} not found in mappings`);\n }\n const schemaHandle = schema(this.context);\n const table = schemaHandle.tables[tableName];\n if (!table) {\n throw planInvalid(`Table ${tableName} not found in schema`);\n }\n\n const accessor: Record<string, AnyColumnBuilder> = {};\n const model = this.contract.models[this.childModelName];\n if (!model || typeof model !== 'object' || !('fields' in model)) {\n throw planInvalid(`Model ${this.childModelName} does not have fields`);\n }\n const modelFields = model.fields as Record<string, { column?: string }>;\n\n for (const fieldName in modelFields) {\n const field = modelFields[fieldName];\n if (!field) continue;\n const columnName =\n this.contract.mappings.fieldToColumn?.[this.childModelName]?.[fieldName] ??\n field.column ??\n fieldName;\n const column = table.columns[columnName];\n if (column) {\n accessor[fieldName] = column as AnyColumnBuilder;\n }\n }\n\n return accessor as ModelColumnAccessor<TContract, CodecTypes, ChildModelName>;\n }\n}\n","import type { ExecutionPlan, ParamDescriptor, PlanMeta } from '@prisma-next/contract/types';\nimport { planInvalid } from '@prisma-next/plan';\nimport type { SqlContract, SqlStorage } from '@prisma-next/sql-contract/types';\nimport type {\n BinaryExpr,\n ExistsExpr,\n LoweredStatement,\n OperationExpr,\n SelectAst,\n TableRef,\n} from '@prisma-next/sql-relational-core/ast';\nimport { compact } from '@prisma-next/sql-relational-core/ast';\nimport type {\n AnyColumnBuilder,\n AnyOrderBuilder,\n BinaryBuilder,\n} from '@prisma-next/sql-relational-core/types';\nimport type { IncludeState } from '../relations/include-plan';\nimport type { ProjectionState } from '../selection/projection';\nimport { collectColumnRefs, getColumnInfo, isOperationExpr } from '../utils/guards';\n\nexport interface MetaBuildArgs {\n readonly contract: SqlContract<SqlStorage>;\n readonly table: TableRef;\n readonly projection: ProjectionState;\n readonly includes?: ReadonlyArray<IncludeState>;\n readonly where?: BinaryBuilder;\n readonly orderBy?: AnyOrderBuilder;\n readonly paramDescriptors: ParamDescriptor[];\n readonly paramCodecs?: Record<string, string>;\n}\n\nexport function buildMeta(args: MetaBuildArgs): PlanMeta {\n const refsColumns = new Map<string, { table: string; column: string }>();\n const refsTables = new Set<string>([args.table.name]);\n\n for (const column of args.projection.columns) {\n const operationExpr = (column as { _operationExpr?: OperationExpr })._operationExpr;\n if (operationExpr) {\n const allRefs = collectColumnRefs(operationExpr);\n for (const ref of allRefs) {\n refsColumns.set(`${ref.table}.${ref.column}`, {\n table: ref.table,\n column: ref.column,\n });\n }\n } else {\n const col = column as unknown as { table?: string; column?: string };\n if (col.table && col.column) {\n refsColumns.set(`${col.table}.${col.column}`, {\n table: col.table,\n column: col.column,\n });\n }\n }\n }\n\n if (args.includes) {\n for (const include of args.includes) {\n refsTables.add(include.table.name);\n const onLeft = include.on.left as unknown as { table: string; column: string };\n const onRight = include.on.right as unknown as { table: string; column: string };\n if (onLeft.table && onLeft.column && onRight.table && onRight.column) {\n refsColumns.set(`${onLeft.table}.${onLeft.column}`, {\n table: onLeft.table,\n column: onLeft.column,\n });\n refsColumns.set(`${onRight.table}.${onRight.column}`, {\n table: onRight.table,\n column: onRight.column,\n });\n }\n for (const column of include.childProjection.columns) {\n const col = column as unknown as { table?: string; column?: string };\n if (col.table && col.column) {\n refsColumns.set(`${col.table}.${col.column}`, {\n table: col.table,\n column: col.column,\n });\n }\n }\n if (include.childWhere) {\n const colInfo = getColumnInfo(include.childWhere.left);\n refsColumns.set(`${colInfo.table}.${colInfo.column}`, {\n table: colInfo.table,\n column: colInfo.column,\n });\n }\n if (include.childOrderBy) {\n const orderBy = include.childOrderBy as unknown as {\n expr?: AnyColumnBuilder | OperationExpr;\n };\n if (orderBy.expr) {\n const colInfo = getColumnInfo(orderBy.expr);\n refsColumns.set(`${colInfo.table}.${colInfo.column}`, {\n table: colInfo.table,\n column: colInfo.column,\n });\n }\n }\n }\n }\n\n if (args.where) {\n const whereLeft = args.where.left;\n const operationExpr = (whereLeft as { _operationExpr?: OperationExpr })._operationExpr;\n if (operationExpr) {\n const allRefs = collectColumnRefs(operationExpr);\n for (const ref of allRefs) {\n refsColumns.set(`${ref.table}.${ref.column}`, {\n table: ref.table,\n column: ref.column,\n });\n }\n } else {\n const colBuilder = whereLeft as unknown as { table?: string; column?: string };\n if (colBuilder.table && colBuilder.column) {\n refsColumns.set(`${colBuilder.table}.${colBuilder.column}`, {\n table: colBuilder.table,\n column: colBuilder.column,\n });\n }\n }\n }\n\n if (args.orderBy) {\n const orderBy = args.orderBy as unknown as {\n expr?: AnyColumnBuilder | OperationExpr;\n };\n const orderByExpr = orderBy.expr;\n if (orderByExpr) {\n if (isOperationExpr(orderByExpr)) {\n const allRefs = collectColumnRefs(orderByExpr);\n for (const ref of allRefs) {\n refsColumns.set(`${ref.table}.${ref.column}`, {\n table: ref.table,\n column: ref.column,\n });\n }\n } else {\n const colBuilder = orderByExpr as unknown as { table?: string; column?: string };\n if (colBuilder.table && colBuilder.column) {\n refsColumns.set(`${colBuilder.table}.${colBuilder.column}`, {\n table: colBuilder.table,\n column: colBuilder.column,\n });\n }\n }\n }\n }\n\n const includeAliases = new Set(args.includes?.map((inc) => inc.alias) ?? []);\n const projectionMap = Object.fromEntries(\n args.projection.aliases.map((alias, index) => {\n if (includeAliases.has(alias)) {\n return [alias, `include:${alias}`];\n }\n const column = args.projection.columns[index];\n if (!column) {\n throw planInvalid(`Missing column for alias ${alias} at index ${index}`);\n }\n const col = column as unknown as {\n table?: string;\n column?: string;\n _operationExpr?: OperationExpr;\n };\n if (!col.table || !col.column) {\n return [alias, `include:${alias}`];\n }\n const operationExpr = col._operationExpr;\n if (operationExpr) {\n return [alias, `operation:${operationExpr.method}`];\n }\n return [alias, `${col.table}.${col.column}`];\n }),\n );\n\n const projectionTypes: Record<string, string> = {};\n for (let i = 0; i < args.projection.aliases.length; i++) {\n const alias = args.projection.aliases[i];\n if (!alias || includeAliases.has(alias)) {\n continue;\n }\n const col = args.projection.columns[i];\n if (!col) {\n continue;\n }\n const operationExpr = (col as { _operationExpr?: OperationExpr })._operationExpr;\n if (operationExpr) {\n if (operationExpr.returns.kind === 'typeId') {\n projectionTypes[alias] = operationExpr.returns.type;\n } else if (operationExpr.returns.kind === 'builtin') {\n projectionTypes[alias] = operationExpr.returns.type;\n }\n } else {\n const colMeta = col as unknown as { columnMeta?: { codecId: string } };\n const columnMeta = colMeta.columnMeta;\n const codecId = columnMeta?.codecId;\n if (codecId) {\n projectionTypes[alias] = codecId;\n }\n }\n }\n\n const projectionCodecs: Record<string, string> = {};\n for (let i = 0; i < args.projection.aliases.length; i++) {\n const alias = args.projection.aliases[i];\n if (!alias || includeAliases.has(alias)) {\n continue;\n }\n const column = args.projection.columns[i];\n if (!column) {\n continue;\n }\n const operationExpr = (column as { _operationExpr?: OperationExpr })._operationExpr;\n if (operationExpr) {\n if (operationExpr.returns.kind === 'typeId') {\n projectionCodecs[alias] = operationExpr.returns.type;\n }\n } else {\n const col = column as unknown as { columnMeta?: { codecId: string } };\n const columnMeta = col.columnMeta;\n const codecId = columnMeta?.codecId;\n if (codecId) {\n projectionCodecs[alias] = codecId;\n }\n }\n }\n\n const allCodecs: Record<string, string> = {\n ...projectionCodecs,\n ...(args.paramCodecs ? args.paramCodecs : {}),\n };\n\n return Object.freeze(\n compact({\n target: args.contract.target,\n targetFamily: args.contract.targetFamily,\n coreHash: args.contract.coreHash,\n lane: 'dsl',\n refs: {\n tables: Array.from(refsTables),\n columns: Array.from(refsColumns.values()),\n },\n projection: projectionMap,\n projectionTypes: Object.keys(projectionTypes).length > 0 ? projectionTypes : undefined,\n annotations:\n Object.keys(allCodecs).length > 0\n ? Object.freeze({ codecs: Object.freeze(allCodecs) })\n : undefined,\n paramDescriptors: args.paramDescriptors,\n profileHash: args.contract.profileHash,\n }) as PlanMeta,\n );\n}\n\nexport function createPlan<Row>(\n ast: SelectAst,\n lowered: { body: LoweredStatement },\n paramValues: unknown[],\n planMeta: PlanMeta,\n): ExecutionPlan<Row> {\n return Object.freeze({\n ast,\n sql: lowered.body.sql,\n params: lowered.body.params ?? paramValues,\n meta: {\n ...planMeta,\n lane: 'orm',\n },\n });\n}\n\nexport function createPlanWithExists<Row>(\n ast: SelectAst,\n combinedWhere: BinaryExpr | ExistsExpr | undefined,\n lowered: { body: LoweredStatement },\n paramValues: unknown[],\n planMeta: PlanMeta,\n): ExecutionPlan<Row> {\n const modifiedAst: SelectAst = {\n ...ast,\n ...(combinedWhere !== undefined ? { where: combinedWhere } : {}),\n };\n return Object.freeze({\n ast: modifiedAst,\n sql: lowered.body.sql,\n params: lowered.body.params ?? paramValues,\n meta: {\n ...planMeta,\n lane: 'orm',\n },\n });\n}\n","import type {\n ColumnRef,\n LiteralExpr,\n OperationExpr,\n ParamRef,\n} from '@prisma-next/sql-relational-core/ast';\nimport type { AnyColumnBuilder } from '@prisma-next/sql-relational-core/types';\n\nexport function extractBaseColumnRef(expr: ColumnRef | OperationExpr): ColumnRef {\n if (expr.kind === 'col') {\n return expr;\n }\n return extractBaseColumnRef(expr.self);\n}\n\nexport function collectColumnRefs(\n expr: ColumnRef | ParamRef | LiteralExpr | OperationExpr,\n): ColumnRef[] {\n if (expr.kind === 'col') {\n return [expr];\n }\n if (expr.kind === 'operation') {\n const refs: ColumnRef[] = collectColumnRefs(expr.self);\n for (const arg of expr.args) {\n refs.push(...collectColumnRefs(arg));\n }\n return refs;\n }\n return [];\n}\n\nexport function isOperationExpr(expr: AnyColumnBuilder | OperationExpr): expr is OperationExpr {\n return typeof expr === 'object' && expr !== null && 'kind' in expr && expr.kind === 'operation';\n}\n\nexport function getColumnInfo(expr: AnyColumnBuilder | OperationExpr): {\n table: string;\n column: string;\n} {\n if (isOperationExpr(expr)) {\n const baseCol = extractBaseColumnRef(expr);\n return { table: baseCol.table, column: baseCol.column };\n }\n const colBuilder = expr as unknown as { table: string; column: string };\n return { table: colBuilder.table, column: colBuilder.column };\n}\n\nexport function isColumnBuilder(value: unknown): value is AnyColumnBuilder {\n return (\n typeof value === 'object' &&\n value !== null &&\n 'kind' in value &&\n (value as { kind: unknown }).kind === 'column'\n );\n}\n","import type { ParamDescriptor } from '@prisma-next/contract/types';\nimport type { SqlContract, SqlStorage, StorageColumn } from '@prisma-next/sql-contract/types';\nimport type {\n BinaryExpr,\n ColumnRef,\n ExistsExpr,\n IncludeAst,\n OperationExpr,\n ParamRef,\n TableRef,\n} from '@prisma-next/sql-relational-core/ast';\nimport { compact } from '@prisma-next/sql-relational-core/ast';\nimport type { QueryLaneContext } from '@prisma-next/sql-relational-core/query-lane-context';\nimport { schema } from '@prisma-next/sql-relational-core/schema';\nimport type {\n AnyBinaryBuilder,\n AnyColumnBuilder,\n AnyOrderBuilder,\n BuildOptions,\n NestedProjection,\n} from '@prisma-next/sql-relational-core/types';\nimport { checkIncludeCapabilities } from '../orm/capabilities';\nimport type { OrmIncludeState, RelationFilter } from '../orm/state';\nimport { buildJoinOnExpr } from '../selection/join';\nimport { buildChildOrderByClause } from '../selection/ordering';\nimport { buildWhereExpr } from '../selection/predicates';\nimport {\n buildProjectionState,\n type ProjectionInput,\n type ProjectionState,\n} from '../selection/projection';\nimport { createColumnRef, createSelectAst } from '../utils/ast';\nimport {\n errorChildProjectionEmpty,\n errorChildProjectionMustBeSpecified,\n errorColumnNotFound,\n errorJoinColumnsMustBeDefined,\n errorMissingAlias,\n errorMissingColumn,\n errorModelNotFound,\n errorMultiColumnJoinsNotSupported,\n errorTableNotFound,\n} from '../utils/errors';\n\nexport interface IncludeState {\n readonly alias: string;\n readonly table: TableRef;\n readonly on: {\n kind: 'join-on';\n left: StorageColumn;\n right: StorageColumn;\n };\n readonly childProjection: ProjectionState;\n readonly childWhere?: AnyBinaryBuilder;\n readonly childOrderBy?: AnyOrderBuilder;\n readonly childLimit?: number;\n}\n\nexport function buildIncludeAsts(\n includes: OrmIncludeState[],\n contract: SqlContract<SqlStorage>,\n context: QueryLaneContext<SqlContract<SqlStorage>>,\n modelName: string,\n paramsMap: Record<string, unknown>,\n paramDescriptors: ParamDescriptor[],\n paramValues: unknown[],\n paramCodecs: Record<string, string>,\n): {\n includesAst: IncludeAst[];\n includesForMeta: IncludeState[];\n} {\n const includesAst: IncludeAst[] = [];\n const includesForMeta: IncludeState[] = [];\n\n for (const includeState of includes) {\n checkIncludeCapabilities(contract);\n\n const parentTableName = contract.mappings.modelToTable?.[modelName];\n if (!parentTableName) {\n errorModelNotFound(modelName);\n }\n\n const parentSchemaHandle = schema(context);\n const parentSchemaTable = parentSchemaHandle.tables[parentTableName];\n if (!parentSchemaTable) {\n errorTableNotFound(parentTableName);\n }\n const childSchemaHandle = schema(context);\n const childSchemaTable = childSchemaHandle.tables[includeState.childTable.name];\n if (!childSchemaTable) {\n errorTableNotFound(includeState.childTable.name);\n }\n\n if (\n includeState.relation.on.parentCols.length !== 1 ||\n includeState.relation.on.childCols.length !== 1\n ) {\n errorMultiColumnJoinsNotSupported();\n }\n const parentColName = includeState.relation.on.parentCols[0];\n const childColName = includeState.relation.on.childCols[0];\n if (!parentColName || !childColName) {\n errorJoinColumnsMustBeDefined();\n }\n const parentCol = parentSchemaTable.columns[parentColName];\n const childCol = childSchemaTable.columns[childColName];\n if (!parentCol) {\n errorColumnNotFound(parentColName, parentTableName);\n }\n if (!childCol) {\n errorColumnNotFound(childColName, includeState.childTable.name);\n }\n\n const onExpr = buildJoinOnExpr(\n parentTableName,\n parentColName,\n includeState.childTable.name,\n childColName,\n );\n\n if (!includeState.childProjection) {\n errorChildProjectionMustBeSpecified();\n }\n const filteredProjection: Record<string, AnyColumnBuilder | NestedProjection> = {};\n for (const [key, value] of Object.entries(includeState.childProjection)) {\n if (value !== true && value !== false) {\n filteredProjection[key] = value as AnyColumnBuilder | NestedProjection;\n }\n }\n if (Object.keys(filteredProjection).length === 0) {\n errorChildProjectionEmpty();\n }\n const childProjectionState = buildProjectionState(\n includeState.childTable,\n filteredProjection as ProjectionInput,\n );\n\n let childWhere: BinaryExpr | undefined;\n if (includeState.childWhere) {\n const whereResult = buildWhereExpr(\n includeState.childWhere,\n contract,\n paramsMap,\n paramDescriptors,\n paramValues,\n );\n childWhere = whereResult.expr;\n if (whereResult.codecId && whereResult.paramName) {\n paramCodecs[whereResult.paramName] = whereResult.codecId;\n }\n }\n\n const childOrderBy = buildChildOrderByClause(includeState.childOrderBy);\n\n const childProjectionItems: Array<{ alias: string; expr: ColumnRef | OperationExpr }> = [];\n for (let i = 0; i < childProjectionState.aliases.length; i++) {\n const alias = childProjectionState.aliases[i];\n if (!alias) {\n errorMissingAlias(i);\n }\n const column = childProjectionState.columns[i];\n if (!column) {\n errorMissingColumn(alias, i);\n }\n const operationExpr = (column as { _operationExpr?: OperationExpr })._operationExpr;\n if (operationExpr) {\n childProjectionItems.push({ alias, expr: operationExpr });\n } else {\n const col = column as { table: string; column: string };\n childProjectionItems.push({ alias, expr: createColumnRef(col.table, col.column) });\n }\n }\n\n const includeAst: IncludeAst = compact({\n kind: 'includeMany',\n alias: includeState.alias,\n child: compact({\n table: includeState.childTable,\n on: onExpr,\n project: childProjectionItems,\n where: childWhere,\n orderBy: childOrderBy,\n limit: includeState.childLimit,\n }),\n }) as IncludeAst;\n includesAst.push(includeAst);\n\n const includeForMeta: IncludeState = compact({\n alias: includeState.alias,\n table: includeState.childTable,\n on: {\n kind: 'join-on',\n left: parentCol as unknown as StorageColumn,\n right: childCol as unknown as StorageColumn,\n },\n childProjection: childProjectionState,\n childWhere: includeState.childWhere,\n childOrderBy: includeState.childOrderBy,\n childLimit: includeState.childLimit,\n }) as IncludeState;\n includesForMeta.push(includeForMeta);\n }\n\n return { includesAst, includesForMeta };\n}\n\nexport function buildExistsSubqueries(\n relationFilters: RelationFilter[],\n contract: SqlContract<SqlStorage>,\n modelName: string,\n options?: BuildOptions,\n): ExistsExpr[] {\n const existsExprs: ExistsExpr[] = [];\n\n for (const filter of relationFilters) {\n const childTableName = contract.mappings.modelToTable?.[filter.childModelName];\n if (!childTableName) {\n errorModelNotFound(filter.childModelName);\n }\n\n const childTable: TableRef = { kind: 'table', name: childTableName };\n const parentTableName = contract.mappings.modelToTable?.[modelName];\n if (!parentTableName) {\n errorModelNotFound(modelName);\n }\n\n const joinConditions: Array<{ left: ColumnRef; right: ColumnRef }> = [];\n for (let i = 0; i < filter.relation.on.parentCols.length; i++) {\n const parentCol = filter.relation.on.parentCols[i];\n const childCol = filter.relation.on.childCols[i];\n if (!parentCol || !childCol) {\n continue;\n }\n joinConditions.push({\n left: { kind: 'col', table: parentTableName, column: parentCol },\n right: { kind: 'col', table: childTableName, column: childCol },\n });\n }\n\n let childWhere: BinaryExpr | undefined;\n if (filter.childWhere) {\n const paramsMap = (options?.params ?? {}) as Record<string, unknown>;\n const paramDescriptors: ParamDescriptor[] = [];\n const paramValues: unknown[] = [];\n const whereResult = buildWhereExpr(\n filter.childWhere,\n contract,\n paramsMap,\n paramDescriptors,\n paramValues,\n );\n childWhere = whereResult.expr;\n }\n\n let subqueryWhere: BinaryExpr | undefined = childWhere;\n if (joinConditions.length > 0) {\n const firstJoinCondition = joinConditions[0];\n if (firstJoinCondition) {\n const joinWhere: BinaryExpr = {\n kind: 'bin',\n op: 'eq',\n left: firstJoinCondition.left,\n right: firstJoinCondition.right as unknown as ParamRef,\n };\n if (childWhere) {\n subqueryWhere = joinWhere;\n } else {\n subqueryWhere = joinWhere;\n }\n }\n }\n const projectionColumn = joinConditions[0]?.right ?? createColumnRef(childTableName, 'id');\n const subquery = createSelectAst({\n from: childTable,\n project: [{ alias: '_exists', expr: projectionColumn }],\n where: subqueryWhere,\n } as {\n from: TableRef;\n project: ReadonlyArray<{ alias: string; expr: ColumnRef }>;\n where?: BinaryExpr | ExistsExpr;\n });\n\n const notExists = filter.filterType === 'none' || filter.filterType === 'every';\n\n const existsExpr: ExistsExpr = {\n kind: 'exists',\n subquery,\n not: notExists,\n };\n\n existsExprs.push(existsExpr);\n }\n\n return existsExprs;\n}\n\nexport function combineWhereClauses(\n mainWhere: BinaryExpr | ExistsExpr | undefined,\n existsExprs: ExistsExpr[],\n): BinaryExpr | ExistsExpr | undefined {\n if (existsExprs.length === 1) {\n return existsExprs[0];\n }\n if (mainWhere) {\n return mainWhere;\n }\n if (existsExprs.length > 0) {\n return existsExprs[0];\n }\n return undefined;\n}\n","import type { SqlContract, SqlStorage } from '@prisma-next/sql-contract/types';\nimport { errorIncludeCapabilitiesNotTrue, errorIncludeRequiresCapabilities } from '../utils/errors';\n\nexport function checkIncludeCapabilities(contract: SqlContract<SqlStorage>): void {\n const target = contract.target;\n const capabilities = contract.capabilities;\n if (!capabilities || !capabilities[target]) {\n errorIncludeRequiresCapabilities();\n }\n const targetCapabilities = capabilities[target];\n if (capabilities[target]['lateral'] !== true || targetCapabilities['jsonAgg'] !== true) {\n errorIncludeCapabilitiesNotTrue();\n }\n}\n","import type { JoinOnExpr } from '@prisma-next/sql-relational-core/ast';\nimport { createColumnRef, createJoinOnExpr } from '../utils/ast';\n\nexport function buildJoinOnExpr(\n parentTableName: string,\n parentColName: string,\n childTableName: string,\n childColName: string,\n): JoinOnExpr {\n const leftCol = createColumnRef(parentTableName, parentColName);\n const rightCol = createColumnRef(childTableName, childColName);\n return createJoinOnExpr(leftCol, rightCol);\n}\n","import type { StorageColumn } from '@prisma-next/sql-contract/types';\nimport type { ColumnRef, Direction, OperationExpr } from '@prisma-next/sql-relational-core/ast';\nimport type { AnyOrderBuilder, OrderBuilder } from '@prisma-next/sql-relational-core/types';\nimport { createColumnRef, createOrderByItem } from '../utils/ast';\nimport { extractBaseColumnRef, isOperationExpr } from '../utils/guards';\n\nexport function buildOrderByClause(orderBy: AnyOrderBuilder | undefined):\n | ReadonlyArray<{\n expr: ColumnRef | OperationExpr;\n dir: Direction;\n }>\n | undefined {\n if (!orderBy) {\n return undefined;\n }\n\n const orderByBuilder = orderBy as OrderBuilder<string, StorageColumn, unknown>;\n const orderExpr = orderByBuilder.expr;\n const expr: ColumnRef | OperationExpr = isOperationExpr(orderExpr)\n ? orderExpr\n : (() => {\n const colBuilder = orderExpr as { table: string; column: string };\n return createColumnRef(colBuilder.table, colBuilder.column);\n })();\n return [createOrderByItem(expr, orderByBuilder.dir)];\n}\n\nexport function buildChildOrderByClause(orderBy: AnyOrderBuilder | undefined):\n | ReadonlyArray<{\n expr: ColumnRef | OperationExpr;\n dir: Direction;\n }>\n | undefined {\n if (!orderBy) {\n return undefined;\n }\n\n const orderByBuilder = orderBy as OrderBuilder<string, StorageColumn, unknown>;\n const orderExpr = orderByBuilder.expr;\n const expr: ColumnRef | OperationExpr = (() => {\n if (isOperationExpr(orderExpr)) {\n const baseCol = extractBaseColumnRef(orderExpr);\n return createColumnRef(baseCol.table, baseCol.column);\n }\n const colBuilder = orderExpr as { table: string; column: string };\n return createColumnRef(colBuilder.table, colBuilder.column);\n })();\n return [createOrderByItem(expr, orderByBuilder.dir)];\n}\n","import type { TableRef } from '@prisma-next/sql-relational-core/ast';\nimport type {\n AnyBinaryBuilder,\n AnyColumnBuilder,\n AnyOrderBuilder,\n JoinOnPredicate,\n NestedProjection,\n} from '@prisma-next/sql-relational-core/types';\nimport {\n errorAliasCollision,\n errorAliasPathEmpty,\n errorIncludeAliasNotFound,\n errorInvalidProjectionKey,\n errorInvalidProjectionValue,\n errorProjectionEmpty,\n} from '../utils/errors';\nimport { isColumnBuilder } from '../utils/guards';\n\nexport interface ProjectionState {\n readonly aliases: string[];\n readonly columns: AnyColumnBuilder[];\n}\n\nexport type ProjectionInput = Record<string, AnyColumnBuilder | boolean | NestedProjection>;\n\nfunction generateAlias(path: string[]): string {\n if (path.length === 0) {\n errorAliasPathEmpty();\n }\n return path.join('_');\n}\n\nexport class AliasTracker {\n private readonly aliases = new Set<string>();\n private readonly aliasToPath = new Map<string, string[]>();\n\n register(path: string[]): string {\n const alias = generateAlias(path);\n if (this.aliases.has(alias)) {\n const existingPath = this.aliasToPath.get(alias);\n errorAliasCollision(path, alias, existingPath);\n }\n this.aliases.add(alias);\n this.aliasToPath.set(alias, path);\n return alias;\n }\n\n getPath(alias: string): string[] | undefined {\n return this.aliasToPath.get(alias);\n }\n\n has(alias: string): boolean {\n return this.aliases.has(alias);\n }\n}\n\nexport function flattenProjection(\n projection: NestedProjection,\n tracker: AliasTracker,\n currentPath: string[] = [],\n): { aliases: string[]; columns: AnyColumnBuilder[] } {\n const aliases: string[] = [];\n const columns: AnyColumnBuilder[] = [];\n\n for (const [key, value] of Object.entries(projection)) {\n const path = [...currentPath, key];\n\n if (isColumnBuilder(value)) {\n const alias = tracker.register(path);\n aliases.push(alias);\n columns.push(value);\n } else if (typeof value === 'object' && value !== null) {\n const nested = flattenProjection(value, tracker, path);\n aliases.push(...nested.aliases);\n columns.push(...nested.columns);\n } else {\n errorInvalidProjectionValue(path);\n }\n }\n\n return { aliases, columns };\n}\n\nexport function buildProjectionState(\n _table: TableRef,\n projection: ProjectionInput,\n includes?: ReadonlyArray<{\n readonly alias: string;\n readonly table: TableRef;\n readonly on: JoinOnPredicate;\n readonly childProjection: ProjectionState;\n readonly childWhere?: AnyBinaryBuilder;\n readonly childOrderBy?: AnyOrderBuilder;\n readonly childLimit?: number;\n }>,\n): ProjectionState {\n const tracker = new AliasTracker();\n const aliases: string[] = [];\n const columns: AnyColumnBuilder[] = [];\n\n for (const [key, value] of Object.entries(projection)) {\n if (value === true) {\n const matchingInclude = includes?.find((inc) => inc.alias === key);\n if (!matchingInclude) {\n errorIncludeAliasNotFound(key);\n }\n aliases.push(key);\n columns.push({\n kind: 'column',\n table: matchingInclude.table.name,\n column: '',\n columnMeta: {\n nativeType: 'jsonb',\n codecId: 'core/json@1',\n nullable: true,\n },\n } as AnyColumnBuilder);\n } else if (isColumnBuilder(value)) {\n const alias = tracker.register([key]);\n aliases.push(alias);\n columns.push(value);\n } else if (typeof value === 'object' && value !== null) {\n const nested = flattenProjection(value as NestedProjection, tracker, [key]);\n aliases.push(...nested.aliases);\n columns.push(...nested.columns);\n } else {\n errorInvalidProjectionKey(key);\n }\n }\n\n if (aliases.length === 0) {\n errorProjectionEmpty();\n }\n\n return { aliases, columns };\n}\n","import type {\n BinaryExpr,\n ColumnRef,\n Direction,\n ExistsExpr,\n IncludeAst,\n IncludeRef,\n OperationExpr,\n SelectAst,\n TableRef,\n} from '@prisma-next/sql-relational-core/ast';\nimport type { IncludeState } from '../relations/include-plan';\nimport { createColumnRef, createSelectAst, createTableRef } from '../utils/ast';\nimport { errorInvalidColumn, errorMissingAlias, errorMissingColumn } from '../utils/errors';\nimport type { ProjectionState } from './projection';\n\nexport function buildProjectionItems(\n projectionState: ProjectionState,\n includesForMeta: ReadonlyArray<IncludeState>,\n): Array<{ alias: string; expr: ColumnRef | IncludeRef | OperationExpr }> {\n const projectEntries: Array<{ alias: string; expr: ColumnRef | IncludeRef | OperationExpr }> = [];\n for (let i = 0; i < projectionState.aliases.length; i++) {\n const alias = projectionState.aliases[i];\n if (!alias) {\n errorMissingAlias(i);\n }\n const column = projectionState.columns[i];\n if (!column) {\n errorMissingColumn(alias, i);\n }\n\n const matchingInclude = includesForMeta.find((inc) => inc.alias === alias);\n if (matchingInclude) {\n projectEntries.push({\n alias,\n expr: { kind: 'includeRef', alias },\n });\n } else {\n const operationExpr = (column as { _operationExpr?: OperationExpr })._operationExpr;\n if (operationExpr) {\n projectEntries.push({\n alias,\n expr: operationExpr,\n });\n } else {\n const col = column as { table: string; column: string };\n const tableName = col.table;\n const columnName = col.column;\n if (!tableName || !columnName) {\n errorInvalidColumn(alias, i);\n }\n projectEntries.push({\n alias,\n expr: createColumnRef(tableName, columnName),\n });\n }\n }\n }\n return projectEntries;\n}\n\nexport function buildSelectAst(\n table: TableRef,\n projectEntries: Array<{ alias: string; expr: ColumnRef | IncludeRef | OperationExpr }>,\n includesAst: ReadonlyArray<IncludeAst> | undefined,\n whereExpr: BinaryExpr | ExistsExpr | undefined,\n orderByClause:\n | ReadonlyArray<{\n expr: ColumnRef | OperationExpr;\n dir: Direction;\n }>\n | undefined,\n limit: number | undefined,\n): SelectAst {\n return createSelectAst({\n from: createTableRef(table.name),\n project: projectEntries,\n includes: includesAst,\n where: whereExpr,\n orderBy: orderByClause,\n limit,\n } as {\n from: TableRef;\n project: ReadonlyArray<{ alias: string; expr: ColumnRef | IncludeRef | OperationExpr }>;\n includes?: ReadonlyArray<IncludeAst>;\n where?: BinaryExpr | ExistsExpr;\n orderBy?: ReadonlyArray<{\n expr: ColumnRef | OperationExpr;\n dir: Direction;\n }>;\n limit?: number;\n });\n}\n","import type { SqlContract, SqlStorage } from '@prisma-next/sql-contract/types';\nimport type { QueryLaneContext } from '@prisma-next/sql-relational-core/query-lane-context';\n\nexport type OrmContext<TContract extends SqlContract<SqlStorage>> = QueryLaneContext<TContract>;\n\nexport function createOrmContext<TContract extends SqlContract<SqlStorage>>(\n context: QueryLaneContext<TContract>,\n): OrmContext<TContract> {\n return context;\n}\n","import { planInvalid } from '@prisma-next/plan';\nimport type { ExtractCodecTypes, SqlContract, SqlStorage } from '@prisma-next/sql-contract/types';\nimport { OrmModelBuilderImpl } from './orm/builder';\nimport type { OrmBuilderOptions, OrmRegistry } from './orm-types';\n\ntype ModelName<TContract extends SqlContract<SqlStorage>> = keyof TContract['models'] & string;\n\nexport function orm<TContract extends SqlContract<SqlStorage>>(\n options: OrmBuilderOptions<TContract>,\n): OrmRegistry<TContract, ExtractCodecTypes<TContract>> {\n const contract = options.context.contract;\n type CodecTypes = ExtractCodecTypes<TContract>;\n\n return new Proxy({} as OrmRegistry<TContract, CodecTypes>, {\n get(_target, prop) {\n if (typeof prop !== 'string') {\n return undefined;\n }\n\n const modelName = (prop.charAt(0).toUpperCase() + prop.slice(1)) as ModelName<TContract>;\n if (\n !contract.models ||\n typeof contract.models !== 'object' ||\n !(modelName in contract.models)\n ) {\n throw planInvalid(`Model ${prop} (resolved to ${modelName}) not found in contract`);\n }\n\n return () =>\n new OrmModelBuilderImpl<TContract, CodecTypes, typeof modelName>(options, modelName);\n },\n has(_target, prop) {\n if (typeof prop !== 'string') {\n return false;\n }\n const modelName = (prop.charAt(0).toUpperCase() + prop.slice(1)) as ModelName<TContract>;\n return contract.models && typeof contract.models === 'object' && modelName in contract.models;\n },\n });\n}\n\n// Re-export types for convenience\nexport type {\n ModelColumnAccessor,\n OrmBuilderOptions,\n OrmModelBuilder,\n OrmRegistry,\n OrmRelationAccessor,\n OrmRelationFilterBuilder,\n OrmWhereProperty,\n} from './orm-types';\n"],"mappings":"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","names":["planInvalid","schema","planInvalid","planInvalid","schema","planInvalid","planInvalid","compact","schema","schema","compact","schema","planInvalid","planInvalid","planInvalid"]}
@@ -1,6 +1,6 @@
1
1
  import {
2
2
  orm
3
- } from "../chunk-K7DL6OZX.js";
3
+ } from "../chunk-KQPLODPT.js";
4
4
  export {
5
5
  orm
6
6
  };
package/dist/index.js CHANGED
@@ -1,7 +1,7 @@
1
1
  import {
2
2
  OrmModelBuilderImpl,
3
3
  orm
4
- } from "./chunk-K7DL6OZX.js";
4
+ } from "./chunk-KQPLODPT.js";
5
5
  export {
6
6
  OrmModelBuilderImpl,
7
7
  orm
package/package.json CHANGED
@@ -1,24 +1,24 @@
1
1
  {
2
2
  "name": "@prisma-next/sql-orm-lane",
3
- "version": "0.1.0-pr.37.5",
3
+ "version": "0.1.0-pr.38.1",
4
4
  "type": "module",
5
5
  "sideEffects": false,
6
6
  "description": "ORM builder, include lowering, and relation filters for Prisma Next",
7
7
  "dependencies": {
8
- "@prisma-next/contract": "0.1.0-pr.37.5",
9
- "@prisma-next/plan": "0.1.0-pr.37.5",
10
- "@prisma-next/sql-contract": "0.1.0-pr.37.5",
11
- "@prisma-next/sql-lane": "0.1.0-pr.37.5",
12
- "@prisma-next/sql-relational-core": "0.1.0-pr.37.5"
8
+ "@prisma-next/contract": "0.1.0-pr.38.1",
9
+ "@prisma-next/plan": "0.1.0-pr.38.1",
10
+ "@prisma-next/sql-contract": "0.1.0-pr.38.1",
11
+ "@prisma-next/sql-lane": "0.1.0-pr.38.1",
12
+ "@prisma-next/sql-relational-core": "0.1.0-pr.38.1"
13
13
  },
14
14
  "devDependencies": {
15
15
  "tsup": "^8.3.0",
16
16
  "typescript": "^5.9.3",
17
17
  "vite-tsconfig-paths": "^5.1.4",
18
18
  "vitest": "^2.1.1",
19
- "@prisma-next/operations": "0.1.0-pr.37.5",
20
- "@prisma-next/sql-contract-ts": "0.1.0-pr.37.5",
21
- "@prisma-next/sql-runtime": "0.1.0-pr.37.5",
19
+ "@prisma-next/operations": "0.1.0-pr.38.1",
20
+ "@prisma-next/sql-contract-ts": "0.1.0-pr.38.1",
21
+ "@prisma-next/sql-runtime": "0.1.0-pr.38.1",
22
22
  "@prisma-next/test-utils": "0.0.1"
23
23
  },
24
24
  "files": [
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../src/orm/builder.ts","../src/selection/predicates.ts","../src/utils/ast.ts","../src/utils/errors.ts","../src/utils/guards.ts","../src/mutations/delete-builder.ts","../src/mutations/insert-builder.ts","../src/utils/param-descriptor.ts","../src/mutations/update-builder.ts","../src/orm-include-child.ts","../src/orm-relation-filter.ts","../src/plan/plan-assembly.ts","../src/relations/include-plan.ts","../src/orm/capabilities.ts","../src/selection/join.ts","../src/selection/ordering.ts","../src/selection/projection.ts","../src/selection/select-builder.ts","../src/orm/context.ts","../src/orm.ts"],"sourcesContent":["import type { ParamDescriptor } from '@prisma-next/contract/types';\nimport { planInvalid } from '@prisma-next/plan';\nimport type { SqlContract, SqlStorage } from '@prisma-next/sql-contract/types';\nimport type { SelectAst, TableRef } from '@prisma-next/sql-relational-core/ast';\nimport type { SqlQueryPlan } from '@prisma-next/sql-relational-core/plan';\nimport type { QueryLaneContext } from '@prisma-next/sql-relational-core/query-lane-context';\nimport { schema } from '@prisma-next/sql-relational-core/schema';\nimport type {\n AnyBinaryBuilder,\n AnyColumnBuilder,\n AnyOrderBuilder,\n BinaryBuilder,\n BuildOptions,\n InferNestedProjectionRow,\n NestedProjection,\n OrderBuilder,\n} from '@prisma-next/sql-relational-core/types';\nimport { buildDeletePlan } from '../mutations/delete-builder';\nimport { buildInsertPlan } from '../mutations/insert-builder';\nimport { buildUpdatePlan } from '../mutations/update-builder';\nimport type { OrmIncludeChildBuilder } from '../orm-include-child';\nimport { OrmIncludeChildBuilderImpl } from '../orm-include-child';\nimport { OrmRelationFilterBuilderImpl } from '../orm-relation-filter';\nimport type {\n IncludeAccumulator,\n ModelColumnAccessor,\n OrmBuilderOptions,\n OrmIncludeAccessor,\n OrmModelBuilder,\n OrmRelationFilterBuilder,\n OrmWhereProperty,\n} from '../orm-types';\nimport { buildMeta, type MetaBuildArgs } from '../plan/plan-assembly';\nimport {\n buildExistsSubqueries,\n buildIncludeAsts,\n combineWhereClauses,\n} from '../relations/include-plan';\nimport { buildOrderByClause } from '../selection/ordering';\nimport { buildWhereExpr } from '../selection/predicates';\nimport { buildProjectionState, type ProjectionInput } from '../selection/projection';\nimport { buildProjectionItems, buildSelectAst } from '../selection/select-builder';\nimport { createTableRef } from '../utils/ast';\nimport { errorModelNotFound, errorTableNotFound, errorUnknownTable } from '../utils/errors';\nimport { createOrmContext } from './context';\nimport type { OrmIncludeState, RelationFilter } from './state';\n\nexport class OrmModelBuilderImpl<\n TContract extends SqlContract<SqlStorage>,\n CodecTypes extends Record<string, { output: unknown }> = Record<string, never>,\n ModelName extends string = string,\n Includes extends Record<string, unknown> = Record<string, never>,\n Row = unknown,\n> implements OrmModelBuilder<TContract, CodecTypes, ModelName, Includes, Row>\n{\n private readonly context: QueryLaneContext<TContract>;\n private readonly contract: TContract;\n private readonly modelName: ModelName;\n private table: TableRef;\n private wherePredicate: AnyBinaryBuilder | undefined = undefined;\n private relationFilters: RelationFilter[] = [];\n private includes: OrmIncludeState[] = [];\n private orderByExpr: AnyOrderBuilder | undefined = undefined;\n private limitValue: number | undefined = undefined;\n private offsetValue: number | undefined = undefined;\n private projection: Record<string, AnyColumnBuilder | boolean | NestedProjection> | undefined =\n undefined;\n\n constructor(options: OrmBuilderOptions<TContract>, modelName: ModelName) {\n this.context = options.context;\n this.contract = options.context.contract;\n this.modelName = modelName;\n\n const tableName = this.contract.mappings.modelToTable?.[modelName];\n if (!tableName) {\n errorModelNotFound(modelName);\n }\n\n const schemaHandle = schema(options.context);\n const table = schemaHandle.tables[tableName];\n if (!table) {\n errorTableNotFound(tableName);\n }\n this.table = table;\n }\n\n get where(): OrmWhereProperty<TContract, CodecTypes, ModelName, Includes, Row> {\n const whereFn = (\n fn: (model: ModelColumnAccessor<TContract, CodecTypes, ModelName>) => AnyBinaryBuilder,\n ): OrmModelBuilder<TContract, CodecTypes, ModelName, Includes, Row> => {\n const builder = new OrmModelBuilderImpl<TContract, CodecTypes, ModelName, Includes, Row>(\n { context: this.context },\n this.modelName,\n );\n builder['table'] = this.table;\n builder.wherePredicate = fn(this._getModelAccessor());\n builder.relationFilters = this.relationFilters;\n builder.includes = this.includes;\n builder.orderByExpr = this.orderByExpr;\n builder.limitValue = this.limitValue;\n builder.offsetValue = this.offsetValue;\n builder.projection = this.projection;\n return builder;\n };\n\n // Add related property using Proxy\n const related = this._createRelatedProxy();\n\n return Object.assign(whereFn, { related }) as OrmWhereProperty<\n TContract,\n CodecTypes,\n ModelName,\n Includes,\n Row\n >;\n }\n\n get include(): OrmIncludeAccessor<TContract, CodecTypes, ModelName, Includes, Row> {\n return this._createIncludeProxy();\n }\n\n private _createIncludeProxy(): OrmIncludeAccessor<\n TContract,\n CodecTypes,\n ModelName,\n Includes,\n Row\n > {\n const self = this;\n // Relations are keyed by table name, not model name\n const tableName = this.contract.mappings.modelToTable?.[this.modelName];\n if (!tableName) {\n return {} as OrmIncludeAccessor<TContract, CodecTypes, ModelName, Includes, Row>;\n }\n const modelRelations = this.contract.relations?.[tableName];\n if (!modelRelations || typeof modelRelations !== 'object') {\n return {} as OrmIncludeAccessor<TContract, CodecTypes, ModelName, Includes, Row>;\n }\n\n return new Proxy({} as OrmIncludeAccessor<TContract, CodecTypes, ModelName, Includes, Row>, {\n get(_target, prop) {\n if (typeof prop !== 'string') {\n return undefined;\n }\n\n const relation = (modelRelations as Record<string, { to?: string }>)[prop];\n if (!relation || typeof relation !== 'object' || !('to' in relation)) {\n throw planInvalid(`Relation ${prop} not found on model ${self.modelName}`);\n }\n\n const childModelName = relation.to as string;\n const relationDef = relation as {\n to: string;\n cardinality: string;\n on: { parentCols: readonly string[]; childCols: readonly string[] };\n };\n\n const relationName = prop as keyof typeof modelRelations & string;\n\n const includeFn = (<ChildRow>(\n child: (\n child: OrmIncludeChildBuilder<TContract, CodecTypes, typeof childModelName>,\n ) => OrmIncludeChildBuilder<TContract, CodecTypes, typeof childModelName, ChildRow>,\n ) => {\n return self._applyInclude<typeof relationName, ChildRow>(\n relationName,\n childModelName,\n child,\n relationDef,\n );\n }) as OrmIncludeAccessor<\n TContract,\n CodecTypes,\n ModelName,\n Includes,\n Row\n >[typeof relationName];\n\n return includeFn;\n },\n });\n }\n\n private _applyInclude<RelationName extends string, ChildRow>(\n relationName: RelationName,\n childModelName: string,\n childBuilderFn: (\n child: OrmIncludeChildBuilder<TContract, CodecTypes, string>,\n ) => OrmIncludeChildBuilder<TContract, CodecTypes, string, ChildRow>,\n relationDef: {\n to: string;\n cardinality: string;\n on: { parentCols: readonly string[]; childCols: readonly string[] };\n },\n ): OrmModelBuilder<\n TContract,\n CodecTypes,\n ModelName,\n IncludeAccumulator<Includes, RelationName, ChildRow>,\n Row\n > {\n // Get child table\n const childTableName = this.contract.mappings.modelToTable?.[childModelName];\n if (!childTableName) {\n errorModelNotFound(childModelName);\n }\n const childTable: TableRef = { kind: 'table', name: childTableName };\n\n // Create child builder and apply callback\n const childBuilder = new OrmIncludeChildBuilderImpl<TContract, CodecTypes, string>(\n { context: this.context },\n childModelName,\n );\n const builtChild = childBuilderFn(\n childBuilder as OrmIncludeChildBuilder<TContract, CodecTypes, string>,\n );\n const childState = (\n builtChild as OrmIncludeChildBuilderImpl<TContract, CodecTypes, string, ChildRow>\n ).getState();\n\n // Store the include\n // Note: Child projection validation happens in findMany() when compiling to includeMany\n const includeState: OrmIncludeState = {\n relationName,\n childModelName,\n childTable,\n childWhere: childState.childWhere,\n childOrderBy: childState.childOrderBy,\n childLimit: childState.childLimit,\n childProjection: childState.childProjection,\n alias: relationName,\n relation: relationDef,\n };\n\n const builder = new OrmModelBuilderImpl<\n TContract,\n CodecTypes,\n ModelName,\n IncludeAccumulator<Includes, RelationName, ChildRow>,\n Row\n >({ context: this.context }, this.modelName);\n builder['table'] = this.table;\n builder.wherePredicate = this.wherePredicate;\n builder.relationFilters = this.relationFilters;\n builder.includes = [...this.includes, includeState];\n builder.orderByExpr = this.orderByExpr;\n builder.limitValue = this.limitValue;\n builder.offsetValue = this.offsetValue;\n builder.projection = this.projection;\n return builder;\n }\n\n private _createRelatedProxy(): OrmWhereProperty<\n TContract,\n CodecTypes,\n ModelName,\n Includes,\n Row\n >['related'] {\n const self = this;\n // Relations are keyed by table name, not model name\n const tableName = this.contract.mappings.modelToTable?.[this.modelName];\n if (!tableName) {\n return {} as OrmWhereProperty<TContract, CodecTypes, ModelName, Includes, Row>['related'];\n }\n const modelRelations = this.contract.relations?.[tableName];\n if (!modelRelations || typeof modelRelations !== 'object') {\n return {} as OrmWhereProperty<TContract, CodecTypes, ModelName, Includes, Row>['related'];\n }\n\n return new Proxy(\n {} as OrmWhereProperty<TContract, CodecTypes, ModelName, Includes, Row>['related'],\n {\n get(_target, prop) {\n if (typeof prop !== 'string') {\n return undefined;\n }\n\n const relation = (modelRelations as Record<string, { to?: string }>)[prop];\n if (!relation || typeof relation !== 'object' || !('to' in relation)) {\n throw planInvalid(`Relation ${prop} not found on model ${self.modelName}`);\n }\n\n const childModelName = relation.to as string;\n const relationDef = relation as {\n to: string;\n cardinality: string;\n on: { parentCols: readonly string[]; childCols: readonly string[] };\n };\n const filterBuilder = new OrmRelationFilterBuilderImpl<\n TContract,\n CodecTypes,\n typeof childModelName\n >({ context: self.context }, childModelName);\n // Expose model accessor directly on the builder for convenience\n const modelAccessor = filterBuilder.getModelAccessor();\n const builderWithAccessor = Object.assign(\n filterBuilder,\n modelAccessor,\n ) as OrmRelationFilterBuilder<TContract, CodecTypes, typeof childModelName> &\n ModelColumnAccessor<TContract, CodecTypes, typeof childModelName>;\n\n return {\n some: (\n fn: (\n child:\n | OrmRelationFilterBuilder<TContract, CodecTypes, typeof childModelName>\n | ModelColumnAccessor<TContract, CodecTypes, typeof childModelName>,\n ) =>\n | OrmRelationFilterBuilder<TContract, CodecTypes, typeof childModelName>\n | AnyBinaryBuilder,\n ) => {\n const result = fn(builderWithAccessor);\n // If result is a AnyBinaryBuilder, wrap it in a builder\n if (result && 'kind' in result && result.kind === 'binary') {\n const wrappedBuilder = new OrmRelationFilterBuilderImpl<\n TContract,\n CodecTypes,\n typeof childModelName\n >({ context: self.context }, childModelName);\n wrappedBuilder['wherePredicate'] = result as AnyBinaryBuilder;\n return self._applyRelationFilter(\n prop,\n childModelName,\n 'some',\n () => wrappedBuilder,\n relationDef,\n );\n }\n return self._applyRelationFilter(\n prop,\n childModelName,\n 'some',\n () =>\n result as OrmRelationFilterBuilder<TContract, CodecTypes, typeof childModelName>,\n relationDef,\n );\n },\n none: (\n fn: (\n child:\n | OrmRelationFilterBuilder<TContract, CodecTypes, typeof childModelName>\n | ModelColumnAccessor<TContract, CodecTypes, typeof childModelName>,\n ) =>\n | OrmRelationFilterBuilder<TContract, CodecTypes, typeof childModelName>\n | AnyBinaryBuilder,\n ) => {\n const result = fn(builderWithAccessor);\n if (result && 'kind' in result && result.kind === 'binary') {\n const wrappedBuilder = new OrmRelationFilterBuilderImpl<\n TContract,\n CodecTypes,\n typeof childModelName\n >({ context: self.context }, childModelName);\n wrappedBuilder['wherePredicate'] = result as AnyBinaryBuilder;\n return self._applyRelationFilter(\n prop,\n childModelName,\n 'none',\n () => wrappedBuilder,\n relationDef,\n );\n }\n return self._applyRelationFilter(\n prop,\n childModelName,\n 'none',\n () =>\n result as OrmRelationFilterBuilder<TContract, CodecTypes, typeof childModelName>,\n relationDef,\n );\n },\n every: (\n fn: (\n child:\n | OrmRelationFilterBuilder<TContract, CodecTypes, typeof childModelName>\n | ModelColumnAccessor<TContract, CodecTypes, typeof childModelName>,\n ) =>\n | OrmRelationFilterBuilder<TContract, CodecTypes, typeof childModelName>\n | AnyBinaryBuilder,\n ) => {\n const result = fn(builderWithAccessor);\n if (result && 'kind' in result && result.kind === 'binary') {\n const wrappedBuilder = new OrmRelationFilterBuilderImpl<\n TContract,\n CodecTypes,\n typeof childModelName\n >({ context: self.context }, childModelName);\n wrappedBuilder['wherePredicate'] = result as AnyBinaryBuilder;\n return self._applyRelationFilter(\n prop,\n childModelName,\n 'every',\n () => wrappedBuilder,\n relationDef,\n );\n }\n return self._applyRelationFilter(\n prop,\n childModelName,\n 'every',\n () =>\n result as OrmRelationFilterBuilder<TContract, CodecTypes, typeof childModelName>,\n relationDef,\n );\n },\n };\n },\n },\n );\n }\n\n private _applyRelationFilter(\n relationName: string,\n childModelName: string,\n filterType: 'some' | 'none' | 'every',\n fn: (\n child: OrmRelationFilterBuilder<TContract, CodecTypes, string>,\n ) => OrmRelationFilterBuilder<TContract, CodecTypes, string>,\n relationDef: {\n to: string;\n cardinality: string;\n on: { parentCols: readonly string[]; childCols: readonly string[] };\n },\n ): OrmModelBuilder<TContract, CodecTypes, ModelName, Includes, Row> {\n // Create a relation filter builder and apply the callback\n const filterBuilder = new OrmRelationFilterBuilderImpl<TContract, CodecTypes, string>(\n { context: this.context },\n childModelName,\n );\n const appliedFilter = fn(\n filterBuilder as OrmRelationFilterBuilder<TContract, CodecTypes, string>,\n );\n const childWhere = (\n appliedFilter as OrmRelationFilterBuilderImpl<TContract, CodecTypes, string>\n ).getWherePredicate();\n\n // Store the relation filter\n const relationFilter: RelationFilter = {\n relationName,\n childModelName,\n filterType,\n childWhere,\n relation: relationDef,\n };\n\n const builder = new OrmModelBuilderImpl<TContract, CodecTypes, ModelName, Includes, Row>(\n { context: this.context },\n this.modelName,\n );\n builder['table'] = this.table;\n builder.wherePredicate = this.wherePredicate;\n builder.relationFilters = [...this.relationFilters, relationFilter];\n builder.includes = this.includes;\n builder.orderByExpr = this.orderByExpr;\n builder.limitValue = this.limitValue;\n builder.offsetValue = this.offsetValue;\n builder.projection = this.projection;\n return builder;\n }\n\n orderBy(\n fn: (model: ModelColumnAccessor<TContract, CodecTypes, ModelName>) => OrderBuilder,\n ): OrmModelBuilder<TContract, CodecTypes, ModelName, Includes, Row> {\n const builder = new OrmModelBuilderImpl<TContract, CodecTypes, ModelName, Includes, Row>(\n { context: this.context },\n this.modelName,\n );\n builder['table'] = this.table;\n builder.wherePredicate = this.wherePredicate;\n builder.relationFilters = this.relationFilters;\n builder.includes = this.includes;\n builder.orderByExpr = fn(this._getModelAccessor());\n builder.limitValue = this.limitValue;\n builder.offsetValue = this.offsetValue;\n builder.projection = this.projection;\n return builder;\n }\n\n take(n: number): OrmModelBuilder<TContract, CodecTypes, ModelName, Includes, Row> {\n const builder = new OrmModelBuilderImpl<TContract, CodecTypes, ModelName, Includes, Row>(\n { context: this.context },\n this.modelName,\n );\n builder['table'] = this.table;\n builder.wherePredicate = this.wherePredicate;\n builder.relationFilters = this.relationFilters;\n builder.includes = this.includes;\n builder.orderByExpr = this.orderByExpr;\n builder.limitValue = n;\n builder.offsetValue = this.offsetValue;\n builder.projection = this.projection;\n return builder;\n }\n\n skip(n: number): OrmModelBuilder<TContract, CodecTypes, ModelName, Includes, Row> {\n // TODO: SQL lane doesn't support offset yet - this is a placeholder\n // When offset is added to SelectAst, implement it here\n const builder = new OrmModelBuilderImpl<TContract, CodecTypes, ModelName, Includes, Row>(\n { context: this.context },\n this.modelName,\n );\n builder['table'] = this.table;\n builder.wherePredicate = this.wherePredicate;\n builder.relationFilters = this.relationFilters;\n builder.includes = this.includes;\n builder.orderByExpr = this.orderByExpr;\n builder.limitValue = this.limitValue;\n builder.offsetValue = n;\n builder.projection = this.projection;\n return builder;\n }\n\n select<Projection extends Record<string, AnyColumnBuilder | boolean | NestedProjection>>(\n fn: (model: ModelColumnAccessor<TContract, CodecTypes, ModelName>) => Projection,\n ): OrmModelBuilder<\n TContract,\n CodecTypes,\n ModelName,\n Includes,\n InferNestedProjectionRow<Projection, CodecTypes, Includes>\n > {\n const builder = new OrmModelBuilderImpl<\n TContract,\n CodecTypes,\n ModelName,\n Includes,\n InferNestedProjectionRow<Projection, CodecTypes, Includes>\n >({ context: this.context }, this.modelName);\n builder['table'] = this.table;\n builder.wherePredicate = this.wherePredicate;\n builder.relationFilters = this.relationFilters;\n builder.includes = this.includes;\n builder.orderByExpr = this.orderByExpr;\n builder.limitValue = this.limitValue;\n builder.offsetValue = this.offsetValue;\n builder.projection = fn(this._getModelAccessor());\n return builder as OrmModelBuilder<\n TContract,\n CodecTypes,\n ModelName,\n Includes,\n InferNestedProjectionRow<Projection, CodecTypes, Includes>\n >;\n }\n\n findMany(options?: BuildOptions): SqlQueryPlan<Row> {\n const paramsMap = (options?.params ?? {}) as Record<string, unknown>;\n const contractTable = this.contract.storage.tables[this.table.name];\n\n if (!contractTable) {\n errorUnknownTable(this.table.name);\n }\n\n const paramDescriptors: ParamDescriptor[] = [];\n const paramValues: unknown[] = [];\n const paramCodecs: Record<string, string> = {};\n\n // Build projection state\n const projectionInput: ProjectionInput =\n this.projection ??\n (() => {\n const modelAccessor = this._getModelAccessor();\n const defaultProjection: Record<string, AnyColumnBuilder> = {};\n for (const fieldName in modelAccessor) {\n defaultProjection[fieldName] = modelAccessor[fieldName];\n }\n return defaultProjection;\n })();\n\n // Build includes AST\n const { includesAst, includesForMeta } = buildIncludeAsts(\n this.includes,\n this.contract,\n this.context,\n this.modelName,\n paramsMap,\n paramDescriptors,\n paramValues,\n paramCodecs,\n );\n\n // Build projection state\n const projectionState = buildProjectionState(\n this.table,\n projectionInput,\n includesForMeta.length > 0\n ? (includesForMeta as unknown as Parameters<typeof buildProjectionState>[2])\n : undefined,\n );\n\n // Build where clause\n const whereResult = this.wherePredicate\n ? buildWhereExpr(this.wherePredicate, this.contract, paramsMap, paramDescriptors, paramValues)\n : undefined;\n const whereExpr = whereResult?.expr;\n if (whereResult?.codecId && whereResult.paramName) {\n paramCodecs[whereResult.paramName] = whereResult.codecId;\n }\n\n // Build orderBy clause\n const orderByClause = buildOrderByClause(this.orderByExpr);\n\n // Build main projection items\n const projectEntries = buildProjectionItems(projectionState, includesForMeta);\n\n // Build SELECT AST\n const ast = buildSelectAst(\n this.table,\n projectEntries,\n includesAst.length > 0 ? includesAst : undefined,\n whereExpr,\n orderByClause,\n this.limitValue,\n );\n\n // Build plan metadata\n const planMeta = buildMeta({\n contract: this.contract,\n table: createTableRef(this.table.name),\n projection: projectionState,\n includes: includesForMeta.length > 0 ? includesForMeta : undefined,\n paramDescriptors,\n paramCodecs: Object.keys(paramCodecs).length > 0 ? paramCodecs : undefined,\n where: this.wherePredicate as BinaryBuilder | undefined,\n orderBy: this.orderByExpr,\n } as MetaBuildArgs);\n\n // Compile relation filters to EXISTS subqueries and combine with main where clause\n if (this.relationFilters.length > 0) {\n const existsExprs = buildExistsSubqueries(\n this.relationFilters,\n this.contract,\n this.modelName,\n options,\n );\n if (existsExprs.length > 0) {\n const combinedWhere = combineWhereClauses(ast.where, existsExprs);\n const modifiedAst: SelectAst = {\n ...ast,\n ...(combinedWhere !== undefined ? { where: combinedWhere } : {}),\n };\n return Object.freeze({\n ast: modifiedAst,\n params: paramValues,\n meta: {\n ...planMeta,\n lane: 'orm',\n },\n });\n }\n }\n\n return Object.freeze({\n ast,\n params: paramValues,\n meta: {\n ...planMeta,\n lane: 'orm',\n },\n });\n }\n\n findFirst(options?: BuildOptions): SqlQueryPlan<Row> {\n const queryPlan = this.take(1).findMany(options);\n return queryPlan;\n }\n\n findUnique(\n where: (model: ModelColumnAccessor<TContract, CodecTypes, ModelName>) => AnyBinaryBuilder,\n options?: BuildOptions,\n ): SqlQueryPlan<Row> {\n return this.where(where).take(1).findMany(options);\n }\n\n create(data: Record<string, unknown>, options?: BuildOptions): SqlQueryPlan<number> {\n const context = createOrmContext(this.context);\n return buildInsertPlan(context, this.modelName, data, options);\n }\n\n update(\n where: (model: ModelColumnAccessor<TContract, CodecTypes, ModelName>) => AnyBinaryBuilder,\n data: Record<string, unknown>,\n options?: BuildOptions,\n ): SqlQueryPlan<number> {\n const context = createOrmContext(this.context);\n return buildUpdatePlan<TContract, CodecTypes, ModelName>(\n context,\n this.modelName,\n where,\n () => this._getModelAccessor(),\n data,\n options,\n );\n }\n\n delete(\n where: (model: ModelColumnAccessor<TContract, CodecTypes, ModelName>) => AnyBinaryBuilder,\n options?: BuildOptions,\n ): SqlQueryPlan<number> {\n const context = createOrmContext(this.context);\n return buildDeletePlan<TContract, CodecTypes, ModelName>(\n context,\n this.modelName,\n where,\n () => this._getModelAccessor(),\n options,\n );\n }\n\n private _getModelAccessor(): ModelColumnAccessor<TContract, CodecTypes, ModelName> {\n const tableName = this.contract.mappings.modelToTable?.[this.modelName];\n if (!tableName) {\n errorModelNotFound(this.modelName);\n }\n const schemaHandle = schema(this.context);\n const table = schemaHandle.tables[tableName];\n if (!table) {\n errorTableNotFound(tableName);\n }\n\n const accessor: Record<string, AnyColumnBuilder> = {};\n const model = this.contract.models[this.modelName];\n if (!model || typeof model !== 'object' || !('fields' in model)) {\n throw planInvalid(`Model ${this.modelName} does not have fields`);\n }\n const modelFields = model.fields as Record<string, { column?: string }>;\n\n for (const fieldName in modelFields) {\n const field = modelFields[fieldName];\n if (!field) continue;\n const columnName =\n this.contract.mappings.fieldToColumn?.[this.modelName]?.[fieldName] ??\n field.column ??\n fieldName;\n const column = table.columns[columnName];\n if (column) {\n accessor[fieldName] = column as AnyColumnBuilder;\n }\n }\n\n return accessor as ModelColumnAccessor<TContract, CodecTypes, ModelName>;\n }\n}\n","import type { ParamDescriptor } from '@prisma-next/contract/types';\nimport type { SqlContract, SqlStorage, StorageColumn } from '@prisma-next/sql-contract/types';\nimport type {\n BinaryExpr,\n ColumnRef,\n OperationExpr,\n ParamRef,\n} from '@prisma-next/sql-relational-core/ast';\nimport { augmentDescriptorWithColumnMeta } from '@prisma-next/sql-relational-core/plan';\nimport type { BinaryBuilder } from '@prisma-next/sql-relational-core/types';\nimport { createBinaryExpr, createColumnRef, createParamRef } from '../utils/ast';\nimport {\n errorFailedToBuildWhereClause,\n errorMissingParameter,\n errorUnknownTable,\n} from '../utils/errors';\nimport {\n getColumnInfo,\n getColumnMeta,\n getOperationExpr,\n isColumnBuilder,\n isParamPlaceholder,\n} from '../utils/guards';\n\nexport function buildWhereExpr(\n where: BinaryBuilder,\n contract: SqlContract<SqlStorage>,\n paramsMap: Record<string, unknown>,\n descriptors: ParamDescriptor[],\n values: unknown[],\n): {\n expr: BinaryExpr;\n codecId?: string;\n paramName: string;\n} {\n let leftExpr: ColumnRef | OperationExpr;\n let codecId: string | undefined;\n let rightExpr: ColumnRef | ParamRef;\n let paramName: string;\n\n const operationExpr = getOperationExpr(where.left);\n if (operationExpr) {\n leftExpr = operationExpr;\n } else if (isColumnBuilder(where.left)) {\n const { table, column } = getColumnInfo(where.left);\n\n const contractTable = contract.storage.tables[table];\n if (!contractTable) {\n errorUnknownTable(table);\n }\n\n const columnMeta: StorageColumn | undefined = contractTable.columns[column];\n // If column not found in contract, still build expression but without codecId\n // This allows flexibility when columnMeta is available on the column builder\n if (columnMeta) {\n codecId = columnMeta.codecId;\n }\n leftExpr = createColumnRef(table, column);\n } else {\n errorFailedToBuildWhereClause();\n }\n\n // Handle where.right - can be ParamPlaceholder or AnyColumnBuilder\n if (isParamPlaceholder(where.right)) {\n // Handle param placeholder (existing logic)\n const placeholder = where.right;\n paramName = placeholder.name;\n\n if (!Object.hasOwn(paramsMap, paramName)) {\n errorMissingParameter(paramName);\n }\n\n const value = paramsMap[paramName];\n const index = values.push(value);\n\n // Construct descriptor if where.left is a ColumnBuilder\n if (isColumnBuilder(where.left)) {\n const { table, column } = getColumnInfo(where.left);\n const contractTable = contract.storage.tables[table];\n const columnMeta = contractTable?.columns[column];\n const builderColumnMeta = getColumnMeta(where.left);\n\n descriptors.push({\n name: paramName,\n source: 'dsl',\n refs: { table, column },\n ...(typeof builderColumnMeta?.nullable === 'boolean'\n ? { nullable: builderColumnMeta.nullable }\n : {}),\n });\n\n augmentDescriptorWithColumnMeta(descriptors, columnMeta);\n }\n\n rightExpr = createParamRef(index, paramName);\n } else if (isColumnBuilder(where.right)) {\n // Handle column builder on the right\n const { table, column } = getColumnInfo(where.right);\n\n const contractTable = contract.storage.tables[table];\n if (!contractTable) {\n errorUnknownTable(table);\n }\n\n // If column not found in contract, still build expression\n // This allows flexibility when columnMeta is available on the column builder\n rightExpr = createColumnRef(table, column);\n // Use a placeholder paramName for column references (not used for params)\n paramName = '';\n } else {\n // where.right is neither ParamPlaceholder nor ColumnBuilder - invalid state\n errorFailedToBuildWhereClause();\n }\n\n return {\n expr: createBinaryExpr(where.op, leftExpr, rightExpr),\n ...(codecId ? { codecId } : {}),\n paramName,\n };\n}\n","export {\n createBinaryExpr,\n createColumnRef,\n createDeleteAst,\n createInsertAst,\n createJoinOnExpr,\n createOrderByItem,\n createParamRef,\n createSelectAst,\n createTableRef,\n createUpdateAst,\n} from '@prisma-next/sql-relational-core/ast';\n","import { planInvalid } from '@prisma-next/plan';\nimport type { StorageColumn } from '@prisma-next/sql-contract/types';\n\nexport function errorModelNotFound(modelName: string): never {\n throw planInvalid(`Model ${modelName} not found in mappings`);\n}\n\nexport function errorTableNotFound(tableName: string): never {\n throw planInvalid(`Table ${tableName} not found in schema`);\n}\n\nexport function errorUnknownTable(tableName: string): never {\n throw planInvalid(`Unknown table ${tableName}`);\n}\n\nexport function errorUnknownColumn(columnName: string, tableName: string): never {\n throw planInvalid(`Unknown column ${columnName} in table ${tableName}`);\n}\n\nexport function errorMissingParameter(paramName: string): never {\n throw planInvalid(`Missing value for parameter ${paramName}`);\n}\n\nexport function errorAliasPathEmpty(): never {\n throw planInvalid('Alias path cannot be empty');\n}\n\nexport function errorAliasCollision(path: string[], alias: string, existingPath?: string[]): never {\n throw planInvalid(\n `Alias collision: path ${path.join('.')} would generate alias \"${alias}\" which conflicts with path ${existingPath?.join('.') ?? 'unknown'}`,\n );\n}\n\nexport function errorInvalidProjectionValue(path: string[]): never {\n throw planInvalid(\n `Invalid projection value at path ${path.join('.')}: expected ColumnBuilder or nested object`,\n );\n}\n\nexport function errorIncludeAliasNotFound(alias: string): never {\n throw planInvalid(\n `Include alias \"${alias}\" not found. Did you call includeMany() with alias \"${alias}\"?`,\n );\n}\n\nexport function errorInvalidProjectionKey(key: string): never {\n throw planInvalid(\n `Invalid projection value at key \"${key}\": expected ColumnBuilder, boolean true (for includes), or nested object`,\n );\n}\n\nexport function errorProjectionEmpty(): never {\n throw planInvalid('select() requires at least one column or include');\n}\n\nexport function errorCreateRequiresFields(): never {\n throw planInvalid('create() requires at least one field');\n}\n\nexport function errorUpdateRequiresFields(): never {\n throw planInvalid('update() requires at least one field');\n}\n\nexport function errorIncludeRequiresCapabilities(): never {\n throw planInvalid('includeMany requires lateral and jsonAgg capabilities');\n}\n\nexport function errorIncludeCapabilitiesNotTrue(): never {\n throw planInvalid('includeMany requires lateral and jsonAgg capabilities to be true');\n}\n\nexport function errorMultiColumnJoinsNotSupported(): never {\n throw planInvalid('Multi-column joins in includes are not yet supported');\n}\n\nexport function errorJoinColumnsMustBeDefined(): never {\n throw planInvalid('Join columns must be defined');\n}\n\nexport function errorColumnNotFound(columnName: string, tableName: string): never {\n throw planInvalid(`Column ${columnName} not found in table ${tableName}`);\n}\n\nexport function errorChildProjectionMustBeSpecified(): never {\n throw planInvalid('Child projection must be specified');\n}\n\nexport function errorChildProjectionEmpty(): never {\n throw planInvalid('Child projection must not be empty after filtering boolean values');\n}\n\nexport function errorMissingAlias(index: number): never {\n throw planInvalid(`Missing alias at index ${index}`);\n}\n\nexport function errorMissingColumn(alias: string, index: number): never {\n throw planInvalid(`Missing column for alias \"${alias}\" at index ${index}`);\n}\n\nexport function errorInvalidColumn(alias: string, index: number): never {\n throw planInvalid(`Invalid column for alias \"${alias}\" at index ${index}`);\n}\n\nexport function errorRelationNotFound(relationName: string, modelName: string): never {\n throw planInvalid(`Relation ${relationName} not found on model ${modelName}`);\n}\n\nexport function errorFailedToBuildWhereClause(): never {\n throw planInvalid('Failed to build WHERE clause');\n}\n\nexport function assertColumnExists(\n columnMeta: StorageColumn | undefined,\n columnName: string,\n tableName: string,\n): asserts columnMeta is StorageColumn {\n if (!columnMeta) {\n errorUnknownColumn(columnName, tableName);\n }\n}\n\nexport function assertParameterExists(\n paramsMap: Record<string, unknown>,\n paramName: string,\n): unknown {\n if (!Object.hasOwn(paramsMap, paramName)) {\n errorMissingParameter(paramName);\n }\n return paramsMap[paramName];\n}\n","import type { StorageColumn } from '@prisma-next/sql-contract/types';\nimport type {\n ColumnRef,\n LiteralExpr,\n OperationExpr,\n ParamRef,\n} from '@prisma-next/sql-relational-core/ast';\nimport type { AnyColumnBuilder, ParamPlaceholder } from '@prisma-next/sql-relational-core/types';\n\nexport function extractBaseColumnRef(expr: ColumnRef | OperationExpr): ColumnRef {\n if (expr.kind === 'col') {\n return expr;\n }\n return extractBaseColumnRef(expr.self);\n}\n\nexport function collectColumnRefs(\n expr: ColumnRef | ParamRef | LiteralExpr | OperationExpr,\n): ColumnRef[] {\n if (expr.kind === 'col') {\n return [expr];\n }\n if (expr.kind === 'operation') {\n const refs: ColumnRef[] = collectColumnRefs(expr.self);\n for (const arg of expr.args) {\n refs.push(...collectColumnRefs(arg));\n }\n return refs;\n }\n return [];\n}\n\nexport function isOperationExpr(expr: AnyColumnBuilder | OperationExpr): expr is OperationExpr {\n return typeof expr === 'object' && expr !== null && 'kind' in expr && expr.kind === 'operation';\n}\n\n/**\n * Helper to extract operation expression from builder.\n * Returns OperationExpr if present, undefined otherwise.\n */\nexport function getOperationExpr(\n builder: AnyColumnBuilder | OperationExpr,\n): OperationExpr | undefined {\n if (isOperationExpr(builder)) {\n return builder;\n }\n const builderWithExpr = builder as unknown as { _operationExpr?: OperationExpr };\n return builderWithExpr._operationExpr;\n}\n\nexport function getColumnInfo(expr: AnyColumnBuilder | OperationExpr): {\n table: string;\n column: string;\n} {\n if (isOperationExpr(expr)) {\n const baseCol = extractBaseColumnRef(expr);\n return { table: baseCol.table, column: baseCol.column };\n }\n const colBuilder = expr as unknown as { table: string; column: string };\n return { table: colBuilder.table, column: colBuilder.column };\n}\n\n/**\n * Helper to extract columnMeta from a ColumnBuilder.\n * Returns StorageColumn if present, undefined otherwise.\n * AnyColumnBuilder is a union that includes types with columnMeta property,\n * so we can safely access it after checking for existence.\n */\nexport function getColumnMeta(expr: AnyColumnBuilder): StorageColumn | undefined {\n // AnyColumnBuilder includes AnyColumnBuilderBase which has columnMeta: StorageColumn\n // and ColumnBuilder which has columnMeta: ColumnMeta extends StorageColumn\n // TypeScript should narrow the type after the 'in' check\n if ('columnMeta' in expr) {\n return expr.columnMeta;\n }\n return undefined;\n}\n\nexport function isColumnBuilder(value: unknown): value is AnyColumnBuilder {\n return (\n typeof value === 'object' &&\n value !== null &&\n 'kind' in value &&\n (value as { kind: unknown }).kind === 'column'\n );\n}\n\n/**\n * Type predicate to check if a value is a ParamPlaceholder.\n */\nexport function isParamPlaceholder(value: unknown): value is ParamPlaceholder {\n return (\n typeof value === 'object' &&\n value !== null &&\n 'kind' in value &&\n (value as { kind: unknown }).kind === 'param-placeholder' &&\n 'name' in value &&\n typeof (value as { name: unknown }).name === 'string'\n );\n}\n","import type { ParamDescriptor } from '@prisma-next/contract/types';\nimport type { SqlContract, SqlStorage } from '@prisma-next/sql-contract/types';\nimport type { SqlQueryPlan } from '@prisma-next/sql-relational-core/plan';\nimport type { AnyBinaryBuilder, BuildOptions } from '@prisma-next/sql-relational-core/types';\nimport type { OrmContext } from '../orm/context';\nimport type { ModelColumnAccessor } from '../orm-types';\nimport { buildWhereExpr } from '../selection/predicates';\nimport { createDeleteAst, createTableRef } from '../utils/ast';\nimport { errorFailedToBuildWhereClause, errorModelNotFound } from '../utils/errors';\n\nexport function buildDeletePlan<\n TContract extends SqlContract<SqlStorage>,\n CodecTypes extends Record<string, { output: unknown }>,\n ModelName extends string,\n>(\n context: OrmContext<TContract>,\n modelName: ModelName,\n where: (model: ModelColumnAccessor<TContract, CodecTypes, ModelName>) => AnyBinaryBuilder,\n getModelAccessor: () => ModelColumnAccessor<TContract, CodecTypes, ModelName>,\n options?: BuildOptions,\n): SqlQueryPlan<number> {\n const modelAccessor = getModelAccessor();\n const wherePredicate = where(modelAccessor);\n\n const tableName = context.contract.mappings.modelToTable?.[modelName];\n if (!tableName) {\n errorModelNotFound(modelName);\n }\n const table = createTableRef(tableName);\n\n const paramsMap = (options?.params ?? {}) as Record<string, unknown>;\n const paramDescriptors: ParamDescriptor[] = [];\n const paramValues: unknown[] = [];\n const paramCodecs: Record<string, string> = {};\n\n const whereResult = buildWhereExpr(\n wherePredicate,\n context.contract,\n paramsMap,\n paramDescriptors,\n paramValues,\n );\n const whereExpr = whereResult.expr;\n if (!whereExpr) {\n errorFailedToBuildWhereClause();\n }\n\n if (whereResult?.codecId && whereResult.paramName) {\n paramCodecs[whereResult.paramName] = whereResult.codecId;\n }\n\n const ast = createDeleteAst({\n table,\n where: whereExpr,\n });\n\n return Object.freeze({\n ast,\n params: paramValues,\n meta: {\n target: context.contract.target,\n targetFamily: context.contract.targetFamily,\n coreHash: context.contract.coreHash,\n lane: 'orm',\n refs: {\n tables: [tableName],\n columns: [],\n },\n projection: {},\n paramDescriptors,\n ...(Object.keys(paramCodecs).length > 0\n ? {\n annotations: {\n codecs: paramCodecs,\n intent: 'write',\n isMutation: true,\n },\n }\n : {\n annotations: {\n intent: 'write',\n isMutation: true,\n },\n }),\n },\n });\n}\n","import type { ParamDescriptor } from '@prisma-next/contract/types';\nimport type { SqlContract, SqlStorage } from '@prisma-next/sql-contract/types';\nimport type { ColumnRef, ParamRef } from '@prisma-next/sql-relational-core/ast';\nimport { param } from '@prisma-next/sql-relational-core/param';\nimport type { SqlQueryPlan } from '@prisma-next/sql-relational-core/plan';\nimport type { BuildOptions, ParamPlaceholder } from '@prisma-next/sql-relational-core/types';\nimport type { OrmContext } from '../orm/context';\nimport { createInsertAst, createParamRef, createTableRef } from '../utils/ast';\nimport {\n assertColumnExists,\n assertParameterExists,\n errorCreateRequiresFields,\n errorModelNotFound,\n errorUnknownTable,\n} from '../utils/errors';\nimport { createParamDescriptor } from '../utils/param-descriptor';\n\nexport function convertModelFieldsToColumns<TContract extends SqlContract<SqlStorage>>(\n contract: TContract,\n modelName: string,\n fields: Record<string, unknown>,\n): Record<string, ParamPlaceholder> {\n const model = contract.models[modelName];\n if (!model || typeof model !== 'object' || !('fields' in model)) {\n throw new Error(`Model ${modelName} does not have fields`);\n }\n const modelFields = model.fields as Record<string, { column?: string }>;\n\n const result: Record<string, ParamPlaceholder> = {};\n\n for (const fieldName in fields) {\n if (!Object.hasOwn(fields, fieldName)) {\n continue;\n }\n\n if (!Object.hasOwn(modelFields, fieldName)) {\n throw new Error(`Field ${fieldName} does not exist on model ${modelName}`);\n }\n\n const field = modelFields[fieldName];\n if (!field) {\n continue;\n }\n\n const columnName =\n contract.mappings.fieldToColumn?.[modelName]?.[fieldName] ?? field.column ?? fieldName;\n\n result[columnName] = param(fieldName);\n }\n\n return result;\n}\n\nexport function buildInsertPlan<TContract extends SqlContract<SqlStorage>>(\n context: OrmContext<TContract>,\n modelName: string,\n data: Record<string, unknown>,\n options?: BuildOptions,\n): SqlQueryPlan<number> {\n if (!data || Object.keys(data).length === 0) {\n errorCreateRequiresFields();\n }\n\n const values = convertModelFieldsToColumns(context.contract, modelName, data);\n\n const tableName = context.contract.mappings.modelToTable?.[modelName];\n if (!tableName) {\n errorModelNotFound(modelName);\n }\n const table = createTableRef(tableName);\n\n const paramsMap = {\n ...(options?.params ?? {}),\n ...data,\n } as Record<string, unknown>;\n const paramDescriptors: ParamDescriptor[] = [];\n const paramValues: unknown[] = [];\n const paramCodecs: Record<string, string> = {};\n\n const contractTable = context.contract.storage.tables[tableName];\n if (!contractTable) {\n errorUnknownTable(tableName);\n }\n\n const insertValues: Record<string, ColumnRef | ParamRef> = {};\n for (const [columnName, placeholder] of Object.entries(values)) {\n const columnMeta = contractTable.columns[columnName];\n assertColumnExists(columnMeta, columnName, tableName);\n\n const paramName = placeholder.name;\n const value = assertParameterExists(paramsMap, paramName);\n const index = paramValues.push(value);\n\n const codecId = columnMeta.codecId;\n if (paramName) {\n paramCodecs[paramName] = codecId;\n }\n\n paramDescriptors.push(\n createParamDescriptor({\n name: paramName,\n table: tableName,\n column: columnName,\n codecId: codecId,\n nativeType: columnMeta.nativeType,\n nullable: columnMeta.nullable,\n }),\n );\n\n insertValues[columnName] = createParamRef(index, paramName);\n }\n\n const ast = createInsertAst({\n table,\n values: insertValues,\n });\n\n return Object.freeze({\n ast,\n params: paramValues,\n meta: {\n target: context.contract.target,\n targetFamily: context.contract.targetFamily,\n coreHash: context.contract.coreHash,\n lane: 'orm',\n refs: {\n tables: [tableName],\n columns: [],\n },\n projection: {},\n paramDescriptors,\n ...(Object.keys(paramCodecs).length > 0\n ? {\n annotations: {\n codecs: paramCodecs,\n intent: 'write',\n isMutation: true,\n },\n }\n : {\n annotations: {\n intent: 'write',\n isMutation: true,\n },\n }),\n },\n });\n}\n","import type { ParamDescriptor } from '@prisma-next/contract/types';\n\nexport function createParamDescriptor(args: {\n name: string;\n table: string;\n column: string;\n codecId?: string;\n nativeType?: string;\n nullable: boolean;\n}): ParamDescriptor {\n return {\n name: args.name,\n source: 'dsl',\n refs: { table: args.table, column: args.column },\n ...(args.codecId ? { codecId: args.codecId } : {}),\n ...(args.nativeType ? { nativeType: args.nativeType } : {}),\n nullable: args.nullable,\n };\n}\n","import type { ParamDescriptor } from '@prisma-next/contract/types';\nimport type { SqlContract, SqlStorage } from '@prisma-next/sql-contract/types';\nimport type { ColumnRef, ParamRef } from '@prisma-next/sql-relational-core/ast';\nimport type { SqlQueryPlan } from '@prisma-next/sql-relational-core/plan';\nimport type { AnyBinaryBuilder, BuildOptions } from '@prisma-next/sql-relational-core/types';\nimport type { OrmContext } from '../orm/context';\nimport type { ModelColumnAccessor } from '../orm-types';\nimport { buildWhereExpr } from '../selection/predicates';\nimport { createParamRef, createTableRef, createUpdateAst } from '../utils/ast';\nimport {\n assertColumnExists,\n assertParameterExists,\n errorFailedToBuildWhereClause,\n errorModelNotFound,\n errorUnknownTable,\n errorUpdateRequiresFields,\n} from '../utils/errors';\nimport { createParamDescriptor } from '../utils/param-descriptor';\nimport { convertModelFieldsToColumns } from './insert-builder';\n\nexport function buildUpdatePlan<\n TContract extends SqlContract<SqlStorage>,\n CodecTypes extends Record<string, { output: unknown }>,\n ModelName extends string,\n>(\n context: OrmContext<TContract>,\n modelName: ModelName,\n where: (model: ModelColumnAccessor<TContract, CodecTypes, ModelName>) => AnyBinaryBuilder,\n getModelAccessor: () => ModelColumnAccessor<TContract, CodecTypes, ModelName>,\n data: Record<string, unknown>,\n options?: BuildOptions,\n): SqlQueryPlan<number> {\n if (!data || Object.keys(data).length === 0) {\n errorUpdateRequiresFields();\n }\n\n const set = convertModelFieldsToColumns(context.contract, modelName, data);\n\n const modelAccessor = getModelAccessor();\n const wherePredicate = where(modelAccessor);\n\n const tableName = context.contract.mappings.modelToTable?.[modelName];\n if (!tableName) {\n errorModelNotFound(modelName);\n }\n const table = createTableRef(tableName);\n\n const paramsMap = {\n ...(options?.params ?? {}),\n ...data,\n } as Record<string, unknown>;\n const paramDescriptors: ParamDescriptor[] = [];\n const paramValues: unknown[] = [];\n const paramCodecs: Record<string, string> = {};\n\n const contractTable = context.contract.storage.tables[tableName];\n if (!contractTable) {\n errorUnknownTable(tableName);\n }\n\n const updateSet: Record<string, ColumnRef | ParamRef> = {};\n for (const [columnName, placeholder] of Object.entries(set)) {\n const columnMeta = contractTable.columns[columnName];\n assertColumnExists(columnMeta, columnName, tableName);\n\n const paramName = placeholder.name;\n const value = assertParameterExists(paramsMap, paramName);\n const index = paramValues.push(value);\n\n const codecId = columnMeta.codecId;\n if (paramName) {\n paramCodecs[paramName] = codecId;\n }\n\n paramDescriptors.push(\n createParamDescriptor({\n name: paramName,\n table: tableName,\n column: columnName,\n codecId: codecId,\n nativeType: columnMeta.nativeType,\n nullable: columnMeta.nullable,\n }),\n );\n\n updateSet[columnName] = createParamRef(index, paramName);\n }\n\n const whereResult = buildWhereExpr(\n wherePredicate,\n context.contract,\n paramsMap,\n paramDescriptors,\n paramValues,\n );\n const whereExpr = whereResult.expr;\n if (!whereExpr) {\n errorFailedToBuildWhereClause();\n }\n\n if (whereResult?.codecId && whereResult.paramName) {\n paramCodecs[whereResult.paramName] = whereResult.codecId;\n }\n\n const ast = createUpdateAst({\n table,\n set: updateSet,\n where: whereExpr,\n });\n\n return Object.freeze({\n ast,\n params: paramValues,\n meta: {\n target: context.contract.target,\n targetFamily: context.contract.targetFamily,\n coreHash: context.contract.coreHash,\n lane: 'orm',\n refs: {\n tables: [tableName],\n columns: [],\n },\n projection: {},\n paramDescriptors,\n ...(Object.keys(paramCodecs).length > 0\n ? {\n annotations: {\n codecs: paramCodecs,\n intent: 'write',\n isMutation: true,\n },\n }\n : {\n annotations: {\n intent: 'write',\n isMutation: true,\n },\n }),\n },\n });\n}\n","import { planInvalid } from '@prisma-next/plan';\nimport type { SqlContract, SqlStorage } from '@prisma-next/sql-contract/types';\nimport type { QueryLaneContext } from '@prisma-next/sql-relational-core/query-lane-context';\nimport { schema } from '@prisma-next/sql-relational-core/schema';\nimport type {\n AnyBinaryBuilder,\n AnyColumnBuilder,\n AnyOrderBuilder,\n InferNestedProjectionRow,\n NestedProjection,\n} from '@prisma-next/sql-relational-core/types';\nimport type { ModelColumnAccessor, OrmBuilderOptions } from './orm-types';\n\nexport interface OrmIncludeChildBuilder<\n TContract extends SqlContract<SqlStorage>,\n CodecTypes extends Record<string, { output: unknown }>,\n ChildModelName extends string,\n ChildRow = unknown,\n> {\n where(\n fn: (model: ModelColumnAccessor<TContract, CodecTypes, ChildModelName>) => AnyBinaryBuilder,\n ): OrmIncludeChildBuilder<TContract, CodecTypes, ChildModelName, ChildRow>;\n orderBy(\n fn: (model: ModelColumnAccessor<TContract, CodecTypes, ChildModelName>) => AnyOrderBuilder,\n ): OrmIncludeChildBuilder<TContract, CodecTypes, ChildModelName, ChildRow>;\n take(n: number): OrmIncludeChildBuilder<TContract, CodecTypes, ChildModelName, ChildRow>;\n select<Projection extends Record<string, AnyColumnBuilder | boolean | NestedProjection>>(\n fn: (model: ModelColumnAccessor<TContract, CodecTypes, ChildModelName>) => Projection,\n ): OrmIncludeChildBuilder<\n TContract,\n CodecTypes,\n ChildModelName,\n InferNestedProjectionRow<Projection, CodecTypes>\n >;\n}\n\nexport class OrmIncludeChildBuilderImpl<\n TContract extends SqlContract<SqlStorage>,\n CodecTypes extends Record<string, { output: unknown }>,\n ChildModelName extends string,\n ChildRow = unknown,\n> implements OrmIncludeChildBuilder<TContract, CodecTypes, ChildModelName, ChildRow>\n{\n private readonly context: QueryLaneContext<TContract>;\n private readonly contract: TContract;\n private readonly childModelName: ChildModelName;\n private childWhere: AnyBinaryBuilder | undefined;\n private childOrderBy: AnyOrderBuilder | undefined;\n private childLimit: number | undefined;\n private childProjection:\n | Record<string, AnyColumnBuilder | boolean | NestedProjection>\n | undefined = undefined;\n\n constructor(options: OrmBuilderOptions<TContract>, childModelName: ChildModelName) {\n this.context = options.context;\n this.contract = options.context.contract;\n this.childModelName = childModelName;\n }\n\n where(\n fn: (model: ModelColumnAccessor<TContract, CodecTypes, ChildModelName>) => AnyBinaryBuilder,\n ): OrmIncludeChildBuilder<TContract, CodecTypes, ChildModelName, ChildRow> {\n const builder = new OrmIncludeChildBuilderImpl<TContract, CodecTypes, ChildModelName, ChildRow>(\n { context: this.context },\n this.childModelName,\n );\n builder.childWhere = fn(this._getModelAccessor());\n builder.childOrderBy = this.childOrderBy;\n builder.childLimit = this.childLimit;\n builder.childProjection = this.childProjection;\n return builder;\n }\n\n orderBy(\n fn: (model: ModelColumnAccessor<TContract, CodecTypes, ChildModelName>) => AnyOrderBuilder,\n ): OrmIncludeChildBuilder<TContract, CodecTypes, ChildModelName, ChildRow> {\n const builder = new OrmIncludeChildBuilderImpl<TContract, CodecTypes, ChildModelName, ChildRow>(\n { context: this.context },\n this.childModelName,\n );\n builder.childWhere = this.childWhere;\n builder.childOrderBy = fn(this._getModelAccessor());\n builder.childLimit = this.childLimit;\n builder.childProjection = this.childProjection;\n return builder;\n }\n\n take(n: number): OrmIncludeChildBuilder<TContract, CodecTypes, ChildModelName, ChildRow> {\n const builder = new OrmIncludeChildBuilderImpl<TContract, CodecTypes, ChildModelName, ChildRow>(\n { context: this.context },\n this.childModelName,\n );\n builder.childWhere = this.childWhere;\n builder.childOrderBy = this.childOrderBy;\n builder.childLimit = n;\n builder.childProjection = this.childProjection;\n return builder;\n }\n\n select<Projection extends Record<string, AnyColumnBuilder | boolean | NestedProjection>>(\n fn: (model: ModelColumnAccessor<TContract, CodecTypes, ChildModelName>) => Projection,\n ): OrmIncludeChildBuilder<\n TContract,\n CodecTypes,\n ChildModelName,\n InferNestedProjectionRow<Projection, CodecTypes>\n > {\n const builder = new OrmIncludeChildBuilderImpl<\n TContract,\n CodecTypes,\n ChildModelName,\n InferNestedProjectionRow<Projection, CodecTypes>\n >({ context: this.context }, this.childModelName);\n builder.childWhere = this.childWhere;\n builder.childOrderBy = this.childOrderBy;\n builder.childLimit = this.childLimit;\n builder.childProjection = fn(this._getModelAccessor());\n return builder;\n }\n\n getState(): {\n childWhere?: AnyBinaryBuilder;\n childOrderBy?: AnyOrderBuilder;\n childLimit?: number;\n childProjection?: Record<string, AnyColumnBuilder | boolean | NestedProjection>;\n } {\n return {\n ...(this.childWhere !== undefined ? { childWhere: this.childWhere } : {}),\n ...(this.childOrderBy !== undefined ? { childOrderBy: this.childOrderBy } : {}),\n ...(this.childLimit !== undefined ? { childLimit: this.childLimit } : {}),\n ...(this.childProjection !== undefined ? { childProjection: this.childProjection } : {}),\n };\n }\n\n private _getModelAccessor(): ModelColumnAccessor<TContract, CodecTypes, ChildModelName> {\n const tableName = this.contract.mappings.modelToTable?.[this.childModelName];\n if (!tableName) {\n throw planInvalid(`Model ${this.childModelName} not found in mappings`);\n }\n const schemaHandle = schema(this.context);\n const table = schemaHandle.tables[tableName];\n if (!table) {\n throw planInvalid(`Table ${tableName} not found in schema`);\n }\n\n const accessor = {} as ModelColumnAccessor<TContract, CodecTypes, ChildModelName>;\n const model = this.contract.models[this.childModelName];\n if (!model || typeof model !== 'object' || !('fields' in model)) {\n throw planInvalid(`Model ${this.childModelName} does not have fields`);\n }\n const modelFields = model.fields as Record<string, { column?: string }>;\n\n for (const fieldName in modelFields) {\n const field = modelFields[fieldName];\n if (!field) continue;\n const columnName =\n this.contract.mappings.fieldToColumn?.[this.childModelName]?.[fieldName] ??\n field.column ??\n fieldName;\n const column = table.columns[columnName];\n if (column) {\n // ModelColumnAccessor alignment is ensured by contract validation; cast for compatibility\n (accessor as Record<string, AnyColumnBuilder>)[fieldName] = column;\n }\n }\n\n return accessor;\n }\n}\n","import { planInvalid } from '@prisma-next/plan';\nimport type { SqlContract, SqlStorage } from '@prisma-next/sql-contract/types';\nimport type { QueryLaneContext } from '@prisma-next/sql-relational-core/query-lane-context';\nimport { schema } from '@prisma-next/sql-relational-core/schema';\nimport type { AnyBinaryBuilder, AnyColumnBuilder } from '@prisma-next/sql-relational-core/types';\nimport type { ModelColumnAccessor, OrmBuilderOptions, OrmRelationFilterBuilder } from './orm-types';\n\nexport class OrmRelationFilterBuilderImpl<\n TContract extends SqlContract<SqlStorage>,\n CodecTypes extends Record<string, { output: unknown }>,\n ChildModelName extends string,\n> implements OrmRelationFilterBuilder<TContract, CodecTypes, ChildModelName>\n{\n private readonly context: QueryLaneContext<TContract>;\n private readonly contract: TContract;\n private readonly childModelName: ChildModelName;\n private wherePredicate: AnyBinaryBuilder | undefined = undefined;\n private modelAccessor: ModelColumnAccessor<TContract, CodecTypes, ChildModelName> | undefined =\n undefined;\n\n constructor(options: OrmBuilderOptions<TContract>, childModelName: ChildModelName) {\n this.context = options.context;\n this.contract = options.context.contract;\n this.childModelName = childModelName;\n this.modelAccessor = this._getModelAccessor();\n }\n\n where(\n fn: (model: ModelColumnAccessor<TContract, CodecTypes, ChildModelName>) => AnyBinaryBuilder,\n ): OrmRelationFilterBuilder<TContract, CodecTypes, ChildModelName> {\n const builder = new OrmRelationFilterBuilderImpl<TContract, CodecTypes, ChildModelName>(\n { context: this.context },\n this.childModelName,\n );\n builder.modelAccessor = this.modelAccessor;\n if (this.modelAccessor) {\n builder.wherePredicate = fn(this.modelAccessor);\n }\n return builder;\n }\n\n getWherePredicate(): AnyBinaryBuilder | undefined {\n return this.wherePredicate;\n }\n\n getChildModelName(): ChildModelName {\n return this.childModelName;\n }\n\n getModelAccessor(): ModelColumnAccessor<TContract, CodecTypes, ChildModelName> {\n if (!this.modelAccessor) {\n this.modelAccessor = this._getModelAccessor();\n }\n if (!this.modelAccessor) {\n throw planInvalid(`Failed to get model accessor for ${this.childModelName}`);\n }\n return this.modelAccessor;\n }\n\n private _getModelAccessor(): ModelColumnAccessor<TContract, CodecTypes, ChildModelName> {\n const tableName = this.contract.mappings.modelToTable?.[this.childModelName];\n if (!tableName) {\n throw planInvalid(`Model ${this.childModelName} not found in mappings`);\n }\n const schemaHandle = schema(this.context);\n const table = schemaHandle.tables[tableName];\n if (!table) {\n throw planInvalid(`Table ${tableName} not found in schema`);\n }\n\n const accessor: Record<string, AnyColumnBuilder> = {};\n const model = this.contract.models[this.childModelName];\n if (!model || typeof model !== 'object' || !('fields' in model)) {\n throw planInvalid(`Model ${this.childModelName} does not have fields`);\n }\n const modelFields = model.fields as Record<string, { column?: string }>;\n\n for (const fieldName in modelFields) {\n const field = modelFields[fieldName];\n if (!field) continue;\n const columnName =\n this.contract.mappings.fieldToColumn?.[this.childModelName]?.[fieldName] ??\n field.column ??\n fieldName;\n const column = table.columns[columnName];\n if (column) {\n accessor[fieldName] = column as AnyColumnBuilder;\n }\n }\n\n return accessor as ModelColumnAccessor<TContract, CodecTypes, ChildModelName>;\n }\n}\n","import type { ExecutionPlan, ParamDescriptor, PlanMeta } from '@prisma-next/contract/types';\nimport { planInvalid } from '@prisma-next/plan';\nimport type { SqlContract, SqlStorage } from '@prisma-next/sql-contract/types';\nimport type {\n BinaryExpr,\n ExistsExpr,\n LoweredStatement,\n OperationExpr,\n SelectAst,\n TableRef,\n} from '@prisma-next/sql-relational-core/ast';\nimport { compact } from '@prisma-next/sql-relational-core/ast';\nimport type {\n AnyColumnBuilder,\n AnyOrderBuilder,\n BinaryBuilder,\n} from '@prisma-next/sql-relational-core/types';\nimport type { IncludeState } from '../relations/include-plan';\nimport type { ProjectionState } from '../selection/projection';\nimport { collectColumnRefs, getColumnInfo, getColumnMeta, isOperationExpr } from '../utils/guards';\n\nexport interface MetaBuildArgs {\n readonly contract: SqlContract<SqlStorage>;\n readonly table: TableRef;\n readonly projection: ProjectionState;\n readonly includes?: ReadonlyArray<IncludeState>;\n readonly where?: BinaryBuilder;\n readonly orderBy?: AnyOrderBuilder;\n readonly paramDescriptors: ParamDescriptor[];\n readonly paramCodecs?: Record<string, string>;\n}\n\nexport function buildMeta(args: MetaBuildArgs): PlanMeta {\n const refsColumns = new Map<string, { table: string; column: string }>();\n const refsTables = new Set<string>([args.table.name]);\n\n for (const column of args.projection.columns) {\n const operationExpr = (column as { _operationExpr?: OperationExpr })._operationExpr;\n if (operationExpr) {\n const allRefs = collectColumnRefs(operationExpr);\n for (const ref of allRefs) {\n refsColumns.set(`${ref.table}.${ref.column}`, {\n table: ref.table,\n column: ref.column,\n });\n }\n } else {\n const col = column as unknown as { table?: string; column?: string };\n if (col.table && col.column) {\n refsColumns.set(`${col.table}.${col.column}`, {\n table: col.table,\n column: col.column,\n });\n }\n }\n }\n\n if (args.includes) {\n for (const include of args.includes) {\n refsTables.add(include.table.name);\n const onLeft = include.on.left as unknown as { table: string; column: string };\n const onRight = include.on.right as unknown as { table: string; column: string };\n if (onLeft.table && onLeft.column && onRight.table && onRight.column) {\n refsColumns.set(`${onLeft.table}.${onLeft.column}`, {\n table: onLeft.table,\n column: onLeft.column,\n });\n refsColumns.set(`${onRight.table}.${onRight.column}`, {\n table: onRight.table,\n column: onRight.column,\n });\n }\n for (const column of include.childProjection.columns) {\n const col = column as unknown as { table?: string; column?: string };\n if (col.table && col.column) {\n refsColumns.set(`${col.table}.${col.column}`, {\n table: col.table,\n column: col.column,\n });\n }\n }\n if (include.childWhere) {\n const colInfo = getColumnInfo(include.childWhere.left);\n refsColumns.set(`${colInfo.table}.${colInfo.column}`, {\n table: colInfo.table,\n column: colInfo.column,\n });\n }\n if (include.childOrderBy) {\n const orderBy = include.childOrderBy as unknown as {\n expr?: AnyColumnBuilder | OperationExpr;\n };\n if (orderBy.expr) {\n const colInfo = getColumnInfo(orderBy.expr);\n refsColumns.set(`${colInfo.table}.${colInfo.column}`, {\n table: colInfo.table,\n column: colInfo.column,\n });\n }\n }\n }\n }\n\n if (args.where) {\n const whereLeft = args.where.left;\n const operationExpr = (whereLeft as { _operationExpr?: OperationExpr })._operationExpr;\n if (operationExpr) {\n const allRefs = collectColumnRefs(operationExpr);\n for (const ref of allRefs) {\n refsColumns.set(`${ref.table}.${ref.column}`, {\n table: ref.table,\n column: ref.column,\n });\n }\n } else {\n const colBuilder = whereLeft as unknown as { table?: string; column?: string };\n if (colBuilder.table && colBuilder.column) {\n refsColumns.set(`${colBuilder.table}.${colBuilder.column}`, {\n table: colBuilder.table,\n column: colBuilder.column,\n });\n }\n }\n }\n\n if (args.orderBy) {\n const orderBy = args.orderBy as unknown as {\n expr?: AnyColumnBuilder | OperationExpr;\n };\n const orderByExpr = orderBy.expr;\n if (orderByExpr) {\n if (isOperationExpr(orderByExpr)) {\n const allRefs = collectColumnRefs(orderByExpr);\n for (const ref of allRefs) {\n refsColumns.set(`${ref.table}.${ref.column}`, {\n table: ref.table,\n column: ref.column,\n });\n }\n } else {\n const colBuilder = orderByExpr as unknown as { table?: string; column?: string };\n if (colBuilder.table && colBuilder.column) {\n refsColumns.set(`${colBuilder.table}.${colBuilder.column}`, {\n table: colBuilder.table,\n column: colBuilder.column,\n });\n }\n }\n }\n }\n\n const includeAliases = new Set(args.includes?.map((inc) => inc.alias) ?? []);\n const projectionMap = Object.fromEntries(\n args.projection.aliases.map((alias, index) => {\n if (includeAliases.has(alias)) {\n return [alias, `include:${alias}`];\n }\n const column = args.projection.columns[index];\n if (!column) {\n throw planInvalid(`Missing column for alias ${alias} at index ${index}`);\n }\n const col = column as unknown as {\n table?: string;\n column?: string;\n _operationExpr?: OperationExpr;\n };\n if (!col.table || !col.column) {\n return [alias, `include:${alias}`];\n }\n const operationExpr = col._operationExpr;\n if (operationExpr) {\n return [alias, `operation:${operationExpr.method}`];\n }\n return [alias, `${col.table}.${col.column}`];\n }),\n );\n\n const projectionTypes: Record<string, string> = {};\n for (let i = 0; i < args.projection.aliases.length; i++) {\n const alias = args.projection.aliases[i];\n if (!alias || includeAliases.has(alias)) {\n continue;\n }\n const col = args.projection.columns[i];\n if (!col) {\n continue;\n }\n const operationExpr = (col as { _operationExpr?: OperationExpr })._operationExpr;\n if (operationExpr) {\n if (operationExpr.returns.kind === 'typeId') {\n projectionTypes[alias] = operationExpr.returns.type;\n } else if (operationExpr.returns.kind === 'builtin') {\n projectionTypes[alias] = operationExpr.returns.type;\n }\n } else {\n const columnMeta = getColumnMeta(col);\n const codecId = columnMeta?.codecId;\n if (codecId) {\n projectionTypes[alias] = codecId;\n }\n }\n }\n\n const projectionCodecs: Record<string, string> = {};\n for (let i = 0; i < args.projection.aliases.length; i++) {\n const alias = args.projection.aliases[i];\n if (!alias || includeAliases.has(alias)) {\n continue;\n }\n const column = args.projection.columns[i];\n if (!column) {\n continue;\n }\n const operationExpr = (column as { _operationExpr?: OperationExpr })._operationExpr;\n if (operationExpr) {\n if (operationExpr.returns.kind === 'typeId') {\n projectionCodecs[alias] = operationExpr.returns.type;\n }\n } else {\n const columnMeta = getColumnMeta(column);\n const codecId = columnMeta?.codecId;\n if (codecId) {\n projectionCodecs[alias] = codecId;\n }\n }\n }\n\n const allCodecs: Record<string, string> = {\n ...projectionCodecs,\n ...(args.paramCodecs ? args.paramCodecs : {}),\n };\n\n return Object.freeze(\n compact({\n target: args.contract.target,\n targetFamily: args.contract.targetFamily,\n coreHash: args.contract.coreHash,\n lane: 'dsl',\n refs: {\n tables: Array.from(refsTables),\n columns: Array.from(refsColumns.values()),\n },\n projection: projectionMap,\n projectionTypes: Object.keys(projectionTypes).length > 0 ? projectionTypes : undefined,\n annotations:\n Object.keys(allCodecs).length > 0\n ? Object.freeze({ codecs: Object.freeze(allCodecs) })\n : undefined,\n paramDescriptors: args.paramDescriptors,\n profileHash: args.contract.profileHash,\n }) as PlanMeta,\n );\n}\n\nexport function createPlan<Row>(\n ast: SelectAst,\n lowered: { body: LoweredStatement },\n paramValues: unknown[],\n planMeta: PlanMeta,\n): ExecutionPlan<Row> {\n return Object.freeze({\n ast,\n sql: lowered.body.sql,\n params: lowered.body.params ?? paramValues,\n meta: {\n ...planMeta,\n lane: 'orm',\n },\n });\n}\n\nexport function createPlanWithExists<Row>(\n ast: SelectAst,\n combinedWhere: BinaryExpr | ExistsExpr | undefined,\n lowered: { body: LoweredStatement },\n paramValues: unknown[],\n planMeta: PlanMeta,\n): ExecutionPlan<Row> {\n const modifiedAst: SelectAst = {\n ...ast,\n ...(combinedWhere !== undefined ? { where: combinedWhere } : {}),\n };\n return Object.freeze({\n ast: modifiedAst,\n sql: lowered.body.sql,\n params: lowered.body.params ?? paramValues,\n meta: {\n ...planMeta,\n lane: 'orm',\n },\n });\n}\n","import type { ParamDescriptor } from '@prisma-next/contract/types';\nimport type { SqlContract, SqlStorage, StorageColumn } from '@prisma-next/sql-contract/types';\nimport type {\n BinaryExpr,\n ColumnRef,\n ExistsExpr,\n IncludeAst,\n OperationExpr,\n ParamRef,\n TableRef,\n} from '@prisma-next/sql-relational-core/ast';\nimport { compact } from '@prisma-next/sql-relational-core/ast';\nimport type { QueryLaneContext } from '@prisma-next/sql-relational-core/query-lane-context';\nimport { schema } from '@prisma-next/sql-relational-core/schema';\nimport type {\n AnyBinaryBuilder,\n AnyColumnBuilder,\n AnyOrderBuilder,\n BuildOptions,\n NestedProjection,\n} from '@prisma-next/sql-relational-core/types';\nimport { checkIncludeCapabilities } from '../orm/capabilities';\nimport type { OrmIncludeState, RelationFilter } from '../orm/state';\nimport { buildJoinOnExpr } from '../selection/join';\nimport { buildChildOrderByClause } from '../selection/ordering';\nimport { buildWhereExpr } from '../selection/predicates';\nimport {\n buildProjectionState,\n type ProjectionInput,\n type ProjectionState,\n} from '../selection/projection';\nimport { createColumnRef, createSelectAst } from '../utils/ast';\nimport {\n errorChildProjectionEmpty,\n errorChildProjectionMustBeSpecified,\n errorColumnNotFound,\n errorJoinColumnsMustBeDefined,\n errorMissingAlias,\n errorMissingColumn,\n errorModelNotFound,\n errorMultiColumnJoinsNotSupported,\n errorTableNotFound,\n} from '../utils/errors';\n\nexport interface IncludeState {\n readonly alias: string;\n readonly table: TableRef;\n readonly on: {\n kind: 'join-on';\n left: StorageColumn;\n right: StorageColumn;\n };\n readonly childProjection: ProjectionState;\n readonly childWhere?: AnyBinaryBuilder;\n readonly childOrderBy?: AnyOrderBuilder;\n readonly childLimit?: number;\n}\n\nexport function buildIncludeAsts(\n includes: OrmIncludeState[],\n contract: SqlContract<SqlStorage>,\n context: QueryLaneContext<SqlContract<SqlStorage>>,\n modelName: string,\n paramsMap: Record<string, unknown>,\n paramDescriptors: ParamDescriptor[],\n paramValues: unknown[],\n paramCodecs: Record<string, string>,\n): {\n includesAst: IncludeAst[];\n includesForMeta: IncludeState[];\n} {\n const includesAst: IncludeAst[] = [];\n const includesForMeta: IncludeState[] = [];\n\n for (const includeState of includes) {\n checkIncludeCapabilities(contract);\n\n const parentTableName = contract.mappings.modelToTable?.[modelName];\n if (!parentTableName) {\n errorModelNotFound(modelName);\n }\n\n const parentSchemaHandle = schema(context);\n const parentSchemaTable = parentSchemaHandle.tables[parentTableName];\n if (!parentSchemaTable) {\n errorTableNotFound(parentTableName);\n }\n const childSchemaHandle = schema(context);\n const childSchemaTable = childSchemaHandle.tables[includeState.childTable.name];\n if (!childSchemaTable) {\n errorTableNotFound(includeState.childTable.name);\n }\n\n if (\n includeState.relation.on.parentCols.length !== 1 ||\n includeState.relation.on.childCols.length !== 1\n ) {\n errorMultiColumnJoinsNotSupported();\n }\n const parentColName = includeState.relation.on.parentCols[0];\n const childColName = includeState.relation.on.childCols[0];\n if (!parentColName || !childColName) {\n errorJoinColumnsMustBeDefined();\n }\n const parentCol = parentSchemaTable.columns[parentColName];\n const childCol = childSchemaTable.columns[childColName];\n if (!parentCol) {\n errorColumnNotFound(parentColName, parentTableName);\n }\n if (!childCol) {\n errorColumnNotFound(childColName, includeState.childTable.name);\n }\n\n const onExpr = buildJoinOnExpr(\n parentTableName,\n parentColName,\n includeState.childTable.name,\n childColName,\n );\n\n if (!includeState.childProjection) {\n errorChildProjectionMustBeSpecified();\n }\n const filteredProjection: Record<string, AnyColumnBuilder | NestedProjection> = {};\n for (const [key, value] of Object.entries(includeState.childProjection)) {\n if (value !== true && value !== false) {\n filteredProjection[key] = value as AnyColumnBuilder | NestedProjection;\n }\n }\n if (Object.keys(filteredProjection).length === 0) {\n errorChildProjectionEmpty();\n }\n const childProjectionState = buildProjectionState(\n includeState.childTable,\n filteredProjection as ProjectionInput,\n );\n\n let childWhere: BinaryExpr | undefined;\n if (includeState.childWhere) {\n const whereResult = buildWhereExpr(\n includeState.childWhere,\n contract,\n paramsMap,\n paramDescriptors,\n paramValues,\n );\n childWhere = whereResult.expr;\n if (whereResult.codecId && whereResult.paramName) {\n paramCodecs[whereResult.paramName] = whereResult.codecId;\n }\n }\n\n const childOrderBy = buildChildOrderByClause(includeState.childOrderBy);\n\n const childProjectionItems: Array<{ alias: string; expr: ColumnRef | OperationExpr }> = [];\n for (let i = 0; i < childProjectionState.aliases.length; i++) {\n const alias = childProjectionState.aliases[i];\n if (!alias) {\n errorMissingAlias(i);\n }\n const column = childProjectionState.columns[i];\n if (!column) {\n errorMissingColumn(alias, i);\n }\n const operationExpr = (column as { _operationExpr?: OperationExpr })._operationExpr;\n if (operationExpr) {\n childProjectionItems.push({ alias, expr: operationExpr });\n } else {\n const col = column as { table: string; column: string };\n childProjectionItems.push({ alias, expr: createColumnRef(col.table, col.column) });\n }\n }\n\n const includeAst: IncludeAst = compact({\n kind: 'includeMany',\n alias: includeState.alias,\n child: compact({\n table: includeState.childTable,\n on: onExpr,\n project: childProjectionItems,\n where: childWhere,\n orderBy: childOrderBy,\n limit: includeState.childLimit,\n }),\n }) as IncludeAst;\n includesAst.push(includeAst);\n\n const includeForMeta: IncludeState = compact({\n alias: includeState.alias,\n table: includeState.childTable,\n on: {\n kind: 'join-on',\n left: parentCol as unknown as StorageColumn,\n right: childCol as unknown as StorageColumn,\n },\n childProjection: childProjectionState,\n childWhere: includeState.childWhere,\n childOrderBy: includeState.childOrderBy,\n childLimit: includeState.childLimit,\n }) as IncludeState;\n includesForMeta.push(includeForMeta);\n }\n\n return { includesAst, includesForMeta };\n}\n\nexport function buildExistsSubqueries(\n relationFilters: RelationFilter[],\n contract: SqlContract<SqlStorage>,\n modelName: string,\n options?: BuildOptions,\n): ExistsExpr[] {\n const existsExprs: ExistsExpr[] = [];\n\n for (const filter of relationFilters) {\n const childTableName = contract.mappings.modelToTable?.[filter.childModelName];\n if (!childTableName) {\n errorModelNotFound(filter.childModelName);\n }\n\n const childTable: TableRef = { kind: 'table', name: childTableName };\n const parentTableName = contract.mappings.modelToTable?.[modelName];\n if (!parentTableName) {\n errorModelNotFound(modelName);\n }\n\n const joinConditions: Array<{ left: ColumnRef; right: ColumnRef }> = [];\n for (let i = 0; i < filter.relation.on.parentCols.length; i++) {\n const parentCol = filter.relation.on.parentCols[i];\n const childCol = filter.relation.on.childCols[i];\n if (!parentCol || !childCol) {\n continue;\n }\n joinConditions.push({\n left: { kind: 'col', table: parentTableName, column: parentCol },\n right: { kind: 'col', table: childTableName, column: childCol },\n });\n }\n\n let childWhere: BinaryExpr | undefined;\n if (filter.childWhere) {\n const paramsMap = (options?.params ?? {}) as Record<string, unknown>;\n const paramDescriptors: ParamDescriptor[] = [];\n const paramValues: unknown[] = [];\n const whereResult = buildWhereExpr(\n filter.childWhere,\n contract,\n paramsMap,\n paramDescriptors,\n paramValues,\n );\n childWhere = whereResult.expr;\n }\n\n let subqueryWhere: BinaryExpr | undefined = childWhere;\n if (joinConditions.length > 0) {\n const firstJoinCondition = joinConditions[0];\n if (firstJoinCondition) {\n const joinWhere: BinaryExpr = {\n kind: 'bin',\n op: 'eq',\n left: firstJoinCondition.left,\n right: firstJoinCondition.right as unknown as ParamRef,\n };\n if (childWhere) {\n subqueryWhere = joinWhere;\n } else {\n subqueryWhere = joinWhere;\n }\n }\n }\n const projectionColumn = joinConditions[0]?.right ?? createColumnRef(childTableName, 'id');\n const subquery = createSelectAst({\n from: childTable,\n project: [{ alias: '_exists', expr: projectionColumn }],\n where: subqueryWhere,\n } as {\n from: TableRef;\n project: ReadonlyArray<{ alias: string; expr: ColumnRef }>;\n where?: BinaryExpr | ExistsExpr;\n });\n\n const notExists = filter.filterType === 'none' || filter.filterType === 'every';\n\n const existsExpr: ExistsExpr = {\n kind: 'exists',\n subquery,\n not: notExists,\n };\n\n existsExprs.push(existsExpr);\n }\n\n return existsExprs;\n}\n\nexport function combineWhereClauses(\n mainWhere: BinaryExpr | ExistsExpr | undefined,\n existsExprs: ExistsExpr[],\n): BinaryExpr | ExistsExpr | undefined {\n if (existsExprs.length === 1) {\n return existsExprs[0];\n }\n if (mainWhere) {\n return mainWhere;\n }\n if (existsExprs.length > 0) {\n return existsExprs[0];\n }\n return undefined;\n}\n","import type { SqlContract, SqlStorage } from '@prisma-next/sql-contract/types';\nimport { errorIncludeCapabilitiesNotTrue, errorIncludeRequiresCapabilities } from '../utils/errors';\n\nexport function checkIncludeCapabilities(contract: SqlContract<SqlStorage>): void {\n const target = contract.target;\n const capabilities = contract.capabilities;\n if (!capabilities || !capabilities[target]) {\n errorIncludeRequiresCapabilities();\n }\n const targetCapabilities = capabilities[target];\n if (capabilities[target]['lateral'] !== true || targetCapabilities['jsonAgg'] !== true) {\n errorIncludeCapabilitiesNotTrue();\n }\n}\n","import type { JoinOnExpr } from '@prisma-next/sql-relational-core/ast';\nimport { createColumnRef, createJoinOnExpr } from '../utils/ast';\n\nexport function buildJoinOnExpr(\n parentTableName: string,\n parentColName: string,\n childTableName: string,\n childColName: string,\n): JoinOnExpr {\n const leftCol = createColumnRef(parentTableName, parentColName);\n const rightCol = createColumnRef(childTableName, childColName);\n return createJoinOnExpr(leftCol, rightCol);\n}\n","import type { StorageColumn } from '@prisma-next/sql-contract/types';\nimport type { ColumnRef, Direction, OperationExpr } from '@prisma-next/sql-relational-core/ast';\nimport type { AnyOrderBuilder, OrderBuilder } from '@prisma-next/sql-relational-core/types';\nimport { createColumnRef, createOrderByItem } from '../utils/ast';\nimport { extractBaseColumnRef, isOperationExpr } from '../utils/guards';\n\nexport function buildOrderByClause(orderBy: AnyOrderBuilder | undefined):\n | ReadonlyArray<{\n expr: ColumnRef | OperationExpr;\n dir: Direction;\n }>\n | undefined {\n if (!orderBy) {\n return undefined;\n }\n\n const orderByBuilder = orderBy as OrderBuilder<string, StorageColumn, unknown>;\n const orderExpr = orderByBuilder.expr;\n const expr: ColumnRef | OperationExpr = isOperationExpr(orderExpr)\n ? orderExpr\n : (() => {\n const colBuilder = orderExpr as { table: string; column: string };\n return createColumnRef(colBuilder.table, colBuilder.column);\n })();\n return [createOrderByItem(expr, orderByBuilder.dir)];\n}\n\nexport function buildChildOrderByClause(orderBy: AnyOrderBuilder | undefined):\n | ReadonlyArray<{\n expr: ColumnRef | OperationExpr;\n dir: Direction;\n }>\n | undefined {\n if (!orderBy) {\n return undefined;\n }\n\n const orderByBuilder = orderBy as OrderBuilder<string, StorageColumn, unknown>;\n const orderExpr = orderByBuilder.expr;\n const expr: ColumnRef | OperationExpr = (() => {\n if (isOperationExpr(orderExpr)) {\n const baseCol = extractBaseColumnRef(orderExpr);\n return createColumnRef(baseCol.table, baseCol.column);\n }\n const colBuilder = orderExpr as { table: string; column: string };\n return createColumnRef(colBuilder.table, colBuilder.column);\n })();\n return [createOrderByItem(expr, orderByBuilder.dir)];\n}\n","import type { TableRef } from '@prisma-next/sql-relational-core/ast';\nimport type {\n AnyBinaryBuilder,\n AnyColumnBuilder,\n AnyOrderBuilder,\n JoinOnPredicate,\n NestedProjection,\n} from '@prisma-next/sql-relational-core/types';\nimport {\n errorAliasCollision,\n errorAliasPathEmpty,\n errorIncludeAliasNotFound,\n errorInvalidProjectionKey,\n errorInvalidProjectionValue,\n errorProjectionEmpty,\n} from '../utils/errors';\nimport { isColumnBuilder } from '../utils/guards';\n\nexport interface ProjectionState {\n readonly aliases: string[];\n readonly columns: AnyColumnBuilder[];\n}\n\nexport type ProjectionInput = Record<string, AnyColumnBuilder | boolean | NestedProjection>;\n\nfunction generateAlias(path: string[]): string {\n if (path.length === 0) {\n errorAliasPathEmpty();\n }\n return path.join('_');\n}\n\nexport class AliasTracker {\n private readonly aliases = new Set<string>();\n private readonly aliasToPath = new Map<string, string[]>();\n\n register(path: string[]): string {\n const alias = generateAlias(path);\n if (this.aliases.has(alias)) {\n const existingPath = this.aliasToPath.get(alias);\n errorAliasCollision(path, alias, existingPath);\n }\n this.aliases.add(alias);\n this.aliasToPath.set(alias, path);\n return alias;\n }\n\n getPath(alias: string): string[] | undefined {\n return this.aliasToPath.get(alias);\n }\n\n has(alias: string): boolean {\n return this.aliases.has(alias);\n }\n}\n\nexport function flattenProjection(\n projection: NestedProjection,\n tracker: AliasTracker,\n currentPath: string[] = [],\n): { aliases: string[]; columns: AnyColumnBuilder[] } {\n const aliases: string[] = [];\n const columns: AnyColumnBuilder[] = [];\n\n for (const [key, value] of Object.entries(projection)) {\n const path = [...currentPath, key];\n\n if (isColumnBuilder(value)) {\n const alias = tracker.register(path);\n aliases.push(alias);\n columns.push(value);\n } else if (typeof value === 'object' && value !== null) {\n const nested = flattenProjection(value, tracker, path);\n aliases.push(...nested.aliases);\n columns.push(...nested.columns);\n } else {\n errorInvalidProjectionValue(path);\n }\n }\n\n return { aliases, columns };\n}\n\nexport function buildProjectionState(\n _table: TableRef,\n projection: ProjectionInput,\n includes?: ReadonlyArray<{\n readonly alias: string;\n readonly table: TableRef;\n readonly on: JoinOnPredicate;\n readonly childProjection: ProjectionState;\n readonly childWhere?: AnyBinaryBuilder;\n readonly childOrderBy?: AnyOrderBuilder;\n readonly childLimit?: number;\n }>,\n): ProjectionState {\n const tracker = new AliasTracker();\n const aliases: string[] = [];\n const columns: AnyColumnBuilder[] = [];\n\n for (const [key, value] of Object.entries(projection)) {\n if (value === true) {\n const matchingInclude = includes?.find((inc) => inc.alias === key);\n if (!matchingInclude) {\n errorIncludeAliasNotFound(key);\n }\n aliases.push(key);\n columns.push({\n kind: 'column',\n table: matchingInclude.table.name,\n column: '',\n columnMeta: {\n nativeType: 'jsonb',\n codecId: 'core/json@1',\n nullable: true,\n },\n } as AnyColumnBuilder);\n } else if (isColumnBuilder(value)) {\n const alias = tracker.register([key]);\n aliases.push(alias);\n columns.push(value);\n } else if (typeof value === 'object' && value !== null) {\n const nested = flattenProjection(value as NestedProjection, tracker, [key]);\n aliases.push(...nested.aliases);\n columns.push(...nested.columns);\n } else {\n errorInvalidProjectionKey(key);\n }\n }\n\n if (aliases.length === 0) {\n errorProjectionEmpty();\n }\n\n return { aliases, columns };\n}\n","import type {\n BinaryExpr,\n ColumnRef,\n Direction,\n ExistsExpr,\n IncludeAst,\n IncludeRef,\n OperationExpr,\n SelectAst,\n TableRef,\n} from '@prisma-next/sql-relational-core/ast';\nimport type { IncludeState } from '../relations/include-plan';\nimport { createColumnRef, createSelectAst, createTableRef } from '../utils/ast';\nimport { errorInvalidColumn, errorMissingAlias, errorMissingColumn } from '../utils/errors';\nimport type { ProjectionState } from './projection';\n\nexport function buildProjectionItems(\n projectionState: ProjectionState,\n includesForMeta: ReadonlyArray<IncludeState>,\n): Array<{ alias: string; expr: ColumnRef | IncludeRef | OperationExpr }> {\n const projectEntries: Array<{ alias: string; expr: ColumnRef | IncludeRef | OperationExpr }> = [];\n for (let i = 0; i < projectionState.aliases.length; i++) {\n const alias = projectionState.aliases[i];\n if (!alias) {\n errorMissingAlias(i);\n }\n const column = projectionState.columns[i];\n if (!column) {\n errorMissingColumn(alias, i);\n }\n\n const matchingInclude = includesForMeta.find((inc) => inc.alias === alias);\n if (matchingInclude) {\n projectEntries.push({\n alias,\n expr: { kind: 'includeRef', alias },\n });\n } else {\n const operationExpr = (column as { _operationExpr?: OperationExpr })._operationExpr;\n if (operationExpr) {\n projectEntries.push({\n alias,\n expr: operationExpr,\n });\n } else {\n const col = column as { table: string; column: string };\n const tableName = col.table;\n const columnName = col.column;\n if (!tableName || !columnName) {\n errorInvalidColumn(alias, i);\n }\n projectEntries.push({\n alias,\n expr: createColumnRef(tableName, columnName),\n });\n }\n }\n }\n return projectEntries;\n}\n\nexport function buildSelectAst(\n table: TableRef,\n projectEntries: Array<{ alias: string; expr: ColumnRef | IncludeRef | OperationExpr }>,\n includesAst: ReadonlyArray<IncludeAst> | undefined,\n whereExpr: BinaryExpr | ExistsExpr | undefined,\n orderByClause:\n | ReadonlyArray<{\n expr: ColumnRef | OperationExpr;\n dir: Direction;\n }>\n | undefined,\n limit: number | undefined,\n): SelectAst {\n return createSelectAst({\n from: createTableRef(table.name),\n project: projectEntries,\n includes: includesAst,\n where: whereExpr,\n orderBy: orderByClause,\n limit,\n } as {\n from: TableRef;\n project: ReadonlyArray<{ alias: string; expr: ColumnRef | IncludeRef | OperationExpr }>;\n includes?: ReadonlyArray<IncludeAst>;\n where?: BinaryExpr | ExistsExpr;\n orderBy?: ReadonlyArray<{\n expr: ColumnRef | OperationExpr;\n dir: Direction;\n }>;\n limit?: number;\n });\n}\n","import type { SqlContract, SqlStorage } from '@prisma-next/sql-contract/types';\nimport type { QueryLaneContext } from '@prisma-next/sql-relational-core/query-lane-context';\n\nexport type OrmContext<TContract extends SqlContract<SqlStorage>> = QueryLaneContext<TContract>;\n\nexport function createOrmContext<TContract extends SqlContract<SqlStorage>>(\n context: QueryLaneContext<TContract>,\n): OrmContext<TContract> {\n return context;\n}\n","import { planInvalid } from '@prisma-next/plan';\nimport type { ExtractCodecTypes, SqlContract, SqlStorage } from '@prisma-next/sql-contract/types';\nimport { OrmModelBuilderImpl } from './orm/builder';\nimport type { OrmBuilderOptions, OrmRegistry } from './orm-types';\n\ntype ModelName<TContract extends SqlContract<SqlStorage>> = keyof TContract['models'] & string;\n\nexport function orm<TContract extends SqlContract<SqlStorage>>(\n options: OrmBuilderOptions<TContract>,\n): OrmRegistry<TContract, ExtractCodecTypes<TContract>> {\n const contract = options.context.contract;\n type CodecTypes = ExtractCodecTypes<TContract>;\n\n return new Proxy({} as OrmRegistry<TContract, CodecTypes>, {\n get(_target, prop) {\n if (typeof prop !== 'string') {\n return undefined;\n }\n\n const modelName = (prop.charAt(0).toUpperCase() + prop.slice(1)) as ModelName<TContract>;\n if (\n !contract.models ||\n typeof contract.models !== 'object' ||\n !(modelName in contract.models)\n ) {\n throw planInvalid(`Model ${prop} (resolved to ${modelName}) not found in contract`);\n }\n\n return () =>\n new OrmModelBuilderImpl<TContract, CodecTypes, typeof modelName>(options, modelName);\n },\n has(_target, prop) {\n if (typeof prop !== 'string') {\n return false;\n }\n const modelName = (prop.charAt(0).toUpperCase() + prop.slice(1)) as ModelName<TContract>;\n return contract.models && typeof contract.models === 'object' && modelName in contract.models;\n },\n });\n}\n\n// Re-export types for convenience\nexport type {\n ModelColumnAccessor,\n OrmBuilderOptions,\n OrmModelBuilder,\n OrmRegistry,\n OrmRelationAccessor,\n OrmRelationFilterBuilder,\n OrmWhereProperty,\n} from './orm-types';\n"],"mappings":"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","names":["planInvalid","schema","planInvalid","planInvalid","schema","planInvalid","planInvalid","compact","schema","schema","compact","schema","planInvalid","planInvalid","planInvalid"]}