@zenstackhq/runtime 3.0.0-alpha.29 → 3.0.0-alpha.30

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1,5 +1,5 @@
1
1
  import Decimal, { Decimal as Decimal$1 } from 'decimal.js';
2
- import { SchemaDef, GetModels, ScalarFields, ForeignKeyFields, GetModelFields, FieldHasDefault, GetModelFieldType, ModelFieldIsOptional, GetModelField, NonRelationFields, RelationFields, FieldIsArray, RelationFieldType, FieldIsRelation, GetModel, FieldDef, GetEnums, GetEnum, GetTypeDefs, GetTypeDefFields, GetTypeDefField, TypeDefFieldIsOptional, BuiltinType, IsDelegateModel, GetModelDiscriminator, GetSubModels, FieldIsRelationArray, FieldIsDelegateDiscriminator, FieldType, RelationInfo, FieldIsDelegateRelation, DataSourceProviderType, ProcedureDef } from '@zenstackhq/sdk/schema';
2
+ import { SchemaDef, GetModels, ScalarFields, ForeignKeyFields, GetModelFields, FieldHasDefault, GetModelFieldType, ModelFieldIsOptional, GetModelField, NonRelationFields, RelationFields, FieldIsArray, RelationFieldType, FieldIsRelation, GetModel, FieldDef, GetEnums, GetEnum, GetTypeDefs, GetTypeDefFields, GetTypeDefField, TypeDefFieldIsOptional, BuiltinType, IsDelegateModel, GetModelDiscriminator, GetSubModels, FieldIsDelegateDiscriminator, FieldType, RelationInfo, FieldIsDelegateRelation, DataSourceProviderType, ProcedureDef } from '@zenstackhq/sdk/schema';
3
3
  import { Generated, Kysely, ExpressionBuilder, OperandExpression, SqlBool, SelectQueryBuilder, Expression, ExpressionWrapper, OperationNode, RootOperationNode, QueryResult, UnknownRow, Dialect, KyselyConfig } from 'kysely';
4
4
 
5
5
  type Optional<T extends object, K extends keyof T = keyof T> = Omit<T, K> & Partial<Pick<T, K>>;
@@ -96,7 +96,7 @@ type BatchResult = {
96
96
  count: number;
97
97
  };
98
98
  type WhereInput<Schema extends SchemaDef, Model extends GetModels<Schema>, ScalarOnly extends boolean = false, WithAggregations extends boolean = false> = {
99
- [Key in GetModelFields<Schema, Model> as ScalarOnly extends true ? Key extends RelationFields<Schema, Model> ? never : Key : Key]?: Key extends RelationFields<Schema, Model> ? RelationFilter<Schema, Model, Key> : GetModelFieldType<Schema, Model, Key> extends GetEnums<Schema> ? EnumFilter<Schema, GetModelFieldType<Schema, Model, Key>, ModelFieldIsOptional<Schema, Model, Key>> : FieldIsArray<Schema, Model, Key> extends true ? ArrayFilter<GetModelFieldType<Schema, Model, Key>> : PrimitiveFilter<Schema, GetModelFieldType<Schema, Model, Key>, ModelFieldIsOptional<Schema, Model, Key>, WithAggregations>;
99
+ [Key in GetModelFields<Schema, Model> as ScalarOnly extends true ? Key extends RelationFields<Schema, Model> ? never : Key : Key]?: Key extends RelationFields<Schema, Model> ? RelationFilter<Schema, Model, Key> : FieldIsArray<Schema, Model, Key> extends true ? ArrayFilter<Schema, GetModelFieldType<Schema, Model, Key>> : GetModelFieldType<Schema, Model, Key> extends GetEnums<Schema> ? EnumFilter<Schema, GetModelFieldType<Schema, Model, Key>, ModelFieldIsOptional<Schema, Model, Key>> : PrimitiveFilter<Schema, GetModelFieldType<Schema, Model, Key>, ModelFieldIsOptional<Schema, Model, Key>, WithAggregations>;
100
100
  } & {
101
101
  $expr?: (eb: ExpressionBuilder<ToKyselySchema<Schema>, Model>) => OperandExpression<SqlBool>;
102
102
  } & {
@@ -110,13 +110,14 @@ type EnumFilter<Schema extends SchemaDef, T extends GetEnums<Schema>, Nullable e
110
110
  notIn?: (keyof GetEnum<Schema, T>)[];
111
111
  not?: EnumFilter<Schema, T, Nullable>;
112
112
  };
113
- type ArrayFilter<T extends string> = {
114
- equals?: MapBaseType$1<T>[];
115
- has?: MapBaseType$1<T>;
116
- hasEvery?: MapBaseType$1<T>[];
117
- hasSome?: MapBaseType$1<T>[];
113
+ type ArrayFilter<Schema extends SchemaDef, T extends string> = {
114
+ equals?: MapScalarType<Schema, T>[] | null;
115
+ has?: MapScalarType<Schema, T> | null;
116
+ hasEvery?: MapScalarType<Schema, T>[];
117
+ hasSome?: MapScalarType<Schema, T>[];
118
118
  isEmpty?: boolean;
119
119
  };
120
+ type MapScalarType<Schema extends SchemaDef, T extends string> = T extends GetEnums<Schema> ? keyof GetEnum<Schema, T> : MapBaseType$1<T>;
120
121
  type PrimitiveFilter<Schema extends SchemaDef, T extends string, Nullable extends boolean, WithAggregations extends boolean> = T extends 'String' ? StringFilter<Schema, Nullable, WithAggregations> : T extends 'Int' | 'Float' | 'Decimal' | 'BigInt' ? NumberFilter<Schema, T, Nullable, WithAggregations> : T extends 'Boolean' ? BooleanFilter<Schema, Nullable, WithAggregations> : T extends 'DateTime' ? DateTimeFilter<Schema, Nullable, WithAggregations> : T extends 'Bytes' ? BytesFilter<Schema, Nullable, WithAggregations> : T extends 'Json' ? 'Not implemented yet' : never;
121
122
  type CommonPrimitiveFilter<Schema extends SchemaDef, DataType, T extends BuiltinType, Nullable extends boolean, WithAggregations extends boolean> = {
122
123
  equals?: NullableIf<DataType, Nullable>;
@@ -194,7 +195,7 @@ type WhereUniqueInput<Schema extends SchemaDef, Model extends GetModels<Schema>>
194
195
  };
195
196
  } & WhereInput<Schema, Model>, Extract<keyof GetModel<Schema, Model>['uniqueFields'], string>>;
196
197
  type OmitInput<Schema extends SchemaDef, Model extends GetModels<Schema>> = {
197
- [Key in NonRelationFields<Schema, Model>]?: true;
198
+ [Key in NonRelationFields<Schema, Model>]?: boolean;
198
199
  };
199
200
  type SelectIncludeOmit<Schema extends SchemaDef, Model extends GetModels<Schema>, AllowCount extends boolean> = {
200
201
  select?: SelectInput<Schema, Model, AllowCount, boolean>;
@@ -202,14 +203,14 @@ type SelectIncludeOmit<Schema extends SchemaDef, Model extends GetModels<Schema>
202
203
  omit?: OmitInput<Schema, Model>;
203
204
  };
204
205
  type SelectInput<Schema extends SchemaDef, Model extends GetModels<Schema>, AllowCount extends boolean = true, AllowRelation extends boolean = true> = {
205
- [Key in NonRelationFields<Schema, Model>]?: true;
206
+ [Key in NonRelationFields<Schema, Model>]?: boolean;
206
207
  } & (AllowRelation extends true ? IncludeInput<Schema, Model> : {}) & // relation fields
207
208
  (AllowCount extends true ? HasToManyRelations<Schema, Model> extends true ? {
208
209
  _count?: SelectCount<Schema, Model>;
209
210
  } : {} : {});
210
- type SelectCount<Schema extends SchemaDef, Model extends GetModels<Schema>> = true | {
211
+ type SelectCount<Schema extends SchemaDef, Model extends GetModels<Schema>> = boolean | {
211
212
  select: {
212
- [Key in RelationFields<Schema, Model> as FieldIsArray<Schema, Model, Key> extends true ? Key : never]: true | {
213
+ [Key in RelationFields<Schema, Model> as FieldIsArray<Schema, Model, Key> extends true ? Key : never]?: boolean | {
213
214
  where: WhereInput<Schema, RelationFieldType<Schema, Model, Key>, false>;
214
215
  };
215
216
  };
@@ -243,7 +244,7 @@ type MapModelFieldType<Schema extends SchemaDef, Model extends GetModels<Schema>
243
244
  type MapTypeDefFieldType<Schema extends SchemaDef, TypeDef extends GetTypeDefs<Schema>, Field extends GetTypeDefFields<Schema, TypeDef>> = MapFieldDefType<Schema, GetTypeDefField<Schema, TypeDef, Field>>;
244
245
  type MapFieldDefType<Schema extends SchemaDef, T extends Pick<FieldDef, 'type' | 'optional' | 'array'>> = WrapType<T['type'] extends GetEnums<Schema> ? keyof GetEnum<Schema, T['type']> : T['type'] extends GetTypeDefs<Schema> ? TypeDefResult<Schema, T['type']> & Record<string, unknown> : MapBaseType$1<T['type']>, T['optional'], T['array']>;
245
246
  type OptionalFieldsForCreate<Schema extends SchemaDef, Model extends GetModels<Schema>> = keyof {
246
- [Key in GetModelFields<Schema, Model> as ModelFieldIsOptional<Schema, Model, Key> extends true ? Key : FieldHasDefault<Schema, Model, Key> extends true ? Key : GetModelField<Schema, Model, Key>['updatedAt'] extends true ? Key : FieldIsRelationArray<Schema, Model, Key> extends true ? Key : never]: GetModelField<Schema, Model, Key>;
247
+ [Key in GetModelFields<Schema, Model> as ModelFieldIsOptional<Schema, Model, Key> extends true ? Key : FieldHasDefault<Schema, Model, Key> extends true ? Key : FieldIsArray<Schema, Model, Key> extends true ? Key : GetModelField<Schema, Model, Key>['updatedAt'] extends true ? Key : never]: GetModelField<Schema, Model, Key>;
247
248
  };
248
249
  type GetRelation<Schema extends SchemaDef, Model extends GetModels<Schema>, Field extends GetModelFields<Schema, Model>> = GetModelField<Schema, Model, Field>['relation'];
249
250
  type OppositeRelation<Schema extends SchemaDef, Model extends GetModels<Schema>, Field extends GetModelFields<Schema, Model>, FT = FieldType<Schema, Model, Field>> = FT extends GetModels<Schema> ? GetRelation<Schema, Model, Field> extends RelationInfo ? GetRelation<Schema, Model, Field>['opposite'] extends GetModelFields<Schema, FT> ? Schema['models'][FT]['fields'][GetRelation<Schema, Model, Field>['opposite']]['relation'] : never : never : never;
@@ -282,7 +283,7 @@ type CreateScalarPayload<Schema extends SchemaDef, Model extends GetModels<Schem
282
283
  [Key in ScalarFields<Schema, Model, false> as FieldIsDelegateDiscriminator<Schema, Model, Key> extends true ? never : Key]: ScalarCreatePayload<Schema, Model, Key>;
283
284
  }>;
284
285
  type ScalarCreatePayload<Schema extends SchemaDef, Model extends GetModels<Schema>, Field extends ScalarFields<Schema, Model, false>> = MapModelFieldType<Schema, Model, Field> | (FieldIsArray<Schema, Model, Field> extends true ? {
285
- set?: MapModelFieldType<Schema, Model, Field>[];
286
+ set?: MapModelFieldType<Schema, Model, Field>;
286
287
  } : never);
287
288
  type CreateFKPayload<Schema extends SchemaDef, Model extends GetModels<Schema>> = OptionalWrap<Schema, Model, {
288
289
  [Key in ForeignKeyFields<Schema, Model>]: MapModelFieldType<Schema, Model, Key>;
@@ -497,7 +498,7 @@ type NestedUpdateInput<Schema extends SchemaDef, Model extends GetModels<Schema>
497
498
  data: UpdateInput<Schema, RelationFieldType<Schema, Model, Field>, OppositeRelationAndFK<Schema, Model, Field>>;
498
499
  }, UpdateInput<Schema, RelationFieldType<Schema, Model, Field>, OppositeRelationAndFK<Schema, Model, Field>>>;
499
500
  type NestedUpsertInput<Schema extends SchemaDef, Model extends GetModels<Schema>, Field extends RelationFields<Schema, Model>> = OrArray<{
500
- where: WhereUniqueInput<Schema, Model>;
501
+ where: WhereUniqueInput<Schema, RelationFieldType<Schema, Model, Field>>;
501
502
  create: CreateInput<Schema, RelationFieldType<Schema, Model, Field>, OppositeRelationAndFK<Schema, Model, Field>>;
502
503
  update: UpdateInput<Schema, RelationFieldType<Schema, Model, Field>, OppositeRelationAndFK<Schema, Model, Field>>;
503
504
  }, FieldIsArray<Schema, Model, Field>>;
@@ -1459,4 +1460,4 @@ type AllModelOperations<Schema extends SchemaDef, Model extends GetModels<Schema
1459
1460
  };
1460
1461
  type ModelOperations<Schema extends SchemaDef, Model extends GetModels<Schema>> = Omit<AllModelOperations<Schema, Model>, IsDelegateModel<Schema, Model> extends true ? 'create' | 'createMany' | 'createManyAndReturn' | 'upsert' : never>;
1461
1462
 
1462
- export { type DeleteArgs as A, type BatchResult as B, type ClientConstructor as C, type DateTimeFilter as D, type DeleteManyArgs as E, type FindArgs as F, type CountArgs as G, type CountResult as H, type IncludeInput as I, type JsonArray as J, type AggregateArgs as K, type AggregateResult as L, type ModelResult as M, type NumberFilter as N, type OrderBy as O, type GroupByArgs as P, type GroupByResult as Q, type RuntimePlugin as R, type SimplifiedModelResult as S, type ToKysely as T, type UpdateArgs as U, type OnKyselyQueryArgs as V, type WhereInput as W, type JsonObject as a, type JsonValue as b, type ClientContract as c, type ClientOptions as d, definePlugin as e, type TypeDefResult as f, type StringFilter as g, type BytesFilter as h, type BooleanFilter as i, type SortOrder as j, type NullsOrder as k, type WhereUniqueInput as l, type OmitInput as m, type SelectIncludeOmit as n, type SelectInput as o, type Subset as p, type SelectSubset as q, type FindManyArgs as r, type FindFirstArgs as s, type FindUniqueArgs as t, type CreateArgs as u, type CreateManyArgs as v, type CreateManyAndReturnArgs as w, type UpdateManyArgs as x, type UpdateManyAndReturnArgs as y, type UpsertArgs as z };
1463
+ export { type DeleteArgs as A, type BatchResult as B, type ClientConstructor as C, type DateTimeFilter as D, type DeleteManyArgs as E, type FindArgs as F, type CountArgs as G, type CountResult as H, type IncludeInput as I, type JsonArray as J, type AggregateArgs as K, type AggregateResult as L, type ModelResult as M, type NumberFilter as N, type OrderBy as O, type GroupByArgs as P, type GroupByResult as Q, type RuntimePlugin as R, type SimplifiedModelResult as S, type ToKysely as T, type UpdateArgs as U, type OnKyselyQueryArgs as V, type WhereInput as W, type ZenStackPromise as Z, type JsonObject as a, type JsonValue as b, type ClientContract as c, type ClientOptions as d, definePlugin as e, type TypeDefResult as f, type StringFilter as g, type BytesFilter as h, type BooleanFilter as i, type SortOrder as j, type NullsOrder as k, type WhereUniqueInput as l, type OmitInput as m, type SelectIncludeOmit as n, type SelectInput as o, type Subset as p, type SelectSubset as q, type FindManyArgs as r, type FindFirstArgs as s, type FindUniqueArgs as t, type CreateArgs as u, type CreateManyArgs as v, type CreateManyAndReturnArgs as w, type UpdateManyArgs as x, type UpdateManyAndReturnArgs as y, type UpsertArgs as z };
@@ -1,5 +1,5 @@
1
1
  import Decimal, { Decimal as Decimal$1 } from 'decimal.js';
2
- import { SchemaDef, GetModels, ScalarFields, ForeignKeyFields, GetModelFields, FieldHasDefault, GetModelFieldType, ModelFieldIsOptional, GetModelField, NonRelationFields, RelationFields, FieldIsArray, RelationFieldType, FieldIsRelation, GetModel, FieldDef, GetEnums, GetEnum, GetTypeDefs, GetTypeDefFields, GetTypeDefField, TypeDefFieldIsOptional, BuiltinType, IsDelegateModel, GetModelDiscriminator, GetSubModels, FieldIsRelationArray, FieldIsDelegateDiscriminator, FieldType, RelationInfo, FieldIsDelegateRelation, DataSourceProviderType, ProcedureDef } from '@zenstackhq/sdk/schema';
2
+ import { SchemaDef, GetModels, ScalarFields, ForeignKeyFields, GetModelFields, FieldHasDefault, GetModelFieldType, ModelFieldIsOptional, GetModelField, NonRelationFields, RelationFields, FieldIsArray, RelationFieldType, FieldIsRelation, GetModel, FieldDef, GetEnums, GetEnum, GetTypeDefs, GetTypeDefFields, GetTypeDefField, TypeDefFieldIsOptional, BuiltinType, IsDelegateModel, GetModelDiscriminator, GetSubModels, FieldIsDelegateDiscriminator, FieldType, RelationInfo, FieldIsDelegateRelation, DataSourceProviderType, ProcedureDef } from '@zenstackhq/sdk/schema';
3
3
  import { Generated, Kysely, ExpressionBuilder, OperandExpression, SqlBool, SelectQueryBuilder, Expression, ExpressionWrapper, OperationNode, RootOperationNode, QueryResult, UnknownRow, Dialect, KyselyConfig } from 'kysely';
4
4
 
5
5
  type Optional<T extends object, K extends keyof T = keyof T> = Omit<T, K> & Partial<Pick<T, K>>;
@@ -96,7 +96,7 @@ type BatchResult = {
96
96
  count: number;
97
97
  };
98
98
  type WhereInput<Schema extends SchemaDef, Model extends GetModels<Schema>, ScalarOnly extends boolean = false, WithAggregations extends boolean = false> = {
99
- [Key in GetModelFields<Schema, Model> as ScalarOnly extends true ? Key extends RelationFields<Schema, Model> ? never : Key : Key]?: Key extends RelationFields<Schema, Model> ? RelationFilter<Schema, Model, Key> : GetModelFieldType<Schema, Model, Key> extends GetEnums<Schema> ? EnumFilter<Schema, GetModelFieldType<Schema, Model, Key>, ModelFieldIsOptional<Schema, Model, Key>> : FieldIsArray<Schema, Model, Key> extends true ? ArrayFilter<GetModelFieldType<Schema, Model, Key>> : PrimitiveFilter<Schema, GetModelFieldType<Schema, Model, Key>, ModelFieldIsOptional<Schema, Model, Key>, WithAggregations>;
99
+ [Key in GetModelFields<Schema, Model> as ScalarOnly extends true ? Key extends RelationFields<Schema, Model> ? never : Key : Key]?: Key extends RelationFields<Schema, Model> ? RelationFilter<Schema, Model, Key> : FieldIsArray<Schema, Model, Key> extends true ? ArrayFilter<Schema, GetModelFieldType<Schema, Model, Key>> : GetModelFieldType<Schema, Model, Key> extends GetEnums<Schema> ? EnumFilter<Schema, GetModelFieldType<Schema, Model, Key>, ModelFieldIsOptional<Schema, Model, Key>> : PrimitiveFilter<Schema, GetModelFieldType<Schema, Model, Key>, ModelFieldIsOptional<Schema, Model, Key>, WithAggregations>;
100
100
  } & {
101
101
  $expr?: (eb: ExpressionBuilder<ToKyselySchema<Schema>, Model>) => OperandExpression<SqlBool>;
102
102
  } & {
@@ -110,13 +110,14 @@ type EnumFilter<Schema extends SchemaDef, T extends GetEnums<Schema>, Nullable e
110
110
  notIn?: (keyof GetEnum<Schema, T>)[];
111
111
  not?: EnumFilter<Schema, T, Nullable>;
112
112
  };
113
- type ArrayFilter<T extends string> = {
114
- equals?: MapBaseType$1<T>[];
115
- has?: MapBaseType$1<T>;
116
- hasEvery?: MapBaseType$1<T>[];
117
- hasSome?: MapBaseType$1<T>[];
113
+ type ArrayFilter<Schema extends SchemaDef, T extends string> = {
114
+ equals?: MapScalarType<Schema, T>[] | null;
115
+ has?: MapScalarType<Schema, T> | null;
116
+ hasEvery?: MapScalarType<Schema, T>[];
117
+ hasSome?: MapScalarType<Schema, T>[];
118
118
  isEmpty?: boolean;
119
119
  };
120
+ type MapScalarType<Schema extends SchemaDef, T extends string> = T extends GetEnums<Schema> ? keyof GetEnum<Schema, T> : MapBaseType$1<T>;
120
121
  type PrimitiveFilter<Schema extends SchemaDef, T extends string, Nullable extends boolean, WithAggregations extends boolean> = T extends 'String' ? StringFilter<Schema, Nullable, WithAggregations> : T extends 'Int' | 'Float' | 'Decimal' | 'BigInt' ? NumberFilter<Schema, T, Nullable, WithAggregations> : T extends 'Boolean' ? BooleanFilter<Schema, Nullable, WithAggregations> : T extends 'DateTime' ? DateTimeFilter<Schema, Nullable, WithAggregations> : T extends 'Bytes' ? BytesFilter<Schema, Nullable, WithAggregations> : T extends 'Json' ? 'Not implemented yet' : never;
121
122
  type CommonPrimitiveFilter<Schema extends SchemaDef, DataType, T extends BuiltinType, Nullable extends boolean, WithAggregations extends boolean> = {
122
123
  equals?: NullableIf<DataType, Nullable>;
@@ -194,7 +195,7 @@ type WhereUniqueInput<Schema extends SchemaDef, Model extends GetModels<Schema>>
194
195
  };
195
196
  } & WhereInput<Schema, Model>, Extract<keyof GetModel<Schema, Model>['uniqueFields'], string>>;
196
197
  type OmitInput<Schema extends SchemaDef, Model extends GetModels<Schema>> = {
197
- [Key in NonRelationFields<Schema, Model>]?: true;
198
+ [Key in NonRelationFields<Schema, Model>]?: boolean;
198
199
  };
199
200
  type SelectIncludeOmit<Schema extends SchemaDef, Model extends GetModels<Schema>, AllowCount extends boolean> = {
200
201
  select?: SelectInput<Schema, Model, AllowCount, boolean>;
@@ -202,14 +203,14 @@ type SelectIncludeOmit<Schema extends SchemaDef, Model extends GetModels<Schema>
202
203
  omit?: OmitInput<Schema, Model>;
203
204
  };
204
205
  type SelectInput<Schema extends SchemaDef, Model extends GetModels<Schema>, AllowCount extends boolean = true, AllowRelation extends boolean = true> = {
205
- [Key in NonRelationFields<Schema, Model>]?: true;
206
+ [Key in NonRelationFields<Schema, Model>]?: boolean;
206
207
  } & (AllowRelation extends true ? IncludeInput<Schema, Model> : {}) & // relation fields
207
208
  (AllowCount extends true ? HasToManyRelations<Schema, Model> extends true ? {
208
209
  _count?: SelectCount<Schema, Model>;
209
210
  } : {} : {});
210
- type SelectCount<Schema extends SchemaDef, Model extends GetModels<Schema>> = true | {
211
+ type SelectCount<Schema extends SchemaDef, Model extends GetModels<Schema>> = boolean | {
211
212
  select: {
212
- [Key in RelationFields<Schema, Model> as FieldIsArray<Schema, Model, Key> extends true ? Key : never]: true | {
213
+ [Key in RelationFields<Schema, Model> as FieldIsArray<Schema, Model, Key> extends true ? Key : never]?: boolean | {
213
214
  where: WhereInput<Schema, RelationFieldType<Schema, Model, Key>, false>;
214
215
  };
215
216
  };
@@ -243,7 +244,7 @@ type MapModelFieldType<Schema extends SchemaDef, Model extends GetModels<Schema>
243
244
  type MapTypeDefFieldType<Schema extends SchemaDef, TypeDef extends GetTypeDefs<Schema>, Field extends GetTypeDefFields<Schema, TypeDef>> = MapFieldDefType<Schema, GetTypeDefField<Schema, TypeDef, Field>>;
244
245
  type MapFieldDefType<Schema extends SchemaDef, T extends Pick<FieldDef, 'type' | 'optional' | 'array'>> = WrapType<T['type'] extends GetEnums<Schema> ? keyof GetEnum<Schema, T['type']> : T['type'] extends GetTypeDefs<Schema> ? TypeDefResult<Schema, T['type']> & Record<string, unknown> : MapBaseType$1<T['type']>, T['optional'], T['array']>;
245
246
  type OptionalFieldsForCreate<Schema extends SchemaDef, Model extends GetModels<Schema>> = keyof {
246
- [Key in GetModelFields<Schema, Model> as ModelFieldIsOptional<Schema, Model, Key> extends true ? Key : FieldHasDefault<Schema, Model, Key> extends true ? Key : GetModelField<Schema, Model, Key>['updatedAt'] extends true ? Key : FieldIsRelationArray<Schema, Model, Key> extends true ? Key : never]: GetModelField<Schema, Model, Key>;
247
+ [Key in GetModelFields<Schema, Model> as ModelFieldIsOptional<Schema, Model, Key> extends true ? Key : FieldHasDefault<Schema, Model, Key> extends true ? Key : FieldIsArray<Schema, Model, Key> extends true ? Key : GetModelField<Schema, Model, Key>['updatedAt'] extends true ? Key : never]: GetModelField<Schema, Model, Key>;
247
248
  };
248
249
  type GetRelation<Schema extends SchemaDef, Model extends GetModels<Schema>, Field extends GetModelFields<Schema, Model>> = GetModelField<Schema, Model, Field>['relation'];
249
250
  type OppositeRelation<Schema extends SchemaDef, Model extends GetModels<Schema>, Field extends GetModelFields<Schema, Model>, FT = FieldType<Schema, Model, Field>> = FT extends GetModels<Schema> ? GetRelation<Schema, Model, Field> extends RelationInfo ? GetRelation<Schema, Model, Field>['opposite'] extends GetModelFields<Schema, FT> ? Schema['models'][FT]['fields'][GetRelation<Schema, Model, Field>['opposite']]['relation'] : never : never : never;
@@ -282,7 +283,7 @@ type CreateScalarPayload<Schema extends SchemaDef, Model extends GetModels<Schem
282
283
  [Key in ScalarFields<Schema, Model, false> as FieldIsDelegateDiscriminator<Schema, Model, Key> extends true ? never : Key]: ScalarCreatePayload<Schema, Model, Key>;
283
284
  }>;
284
285
  type ScalarCreatePayload<Schema extends SchemaDef, Model extends GetModels<Schema>, Field extends ScalarFields<Schema, Model, false>> = MapModelFieldType<Schema, Model, Field> | (FieldIsArray<Schema, Model, Field> extends true ? {
285
- set?: MapModelFieldType<Schema, Model, Field>[];
286
+ set?: MapModelFieldType<Schema, Model, Field>;
286
287
  } : never);
287
288
  type CreateFKPayload<Schema extends SchemaDef, Model extends GetModels<Schema>> = OptionalWrap<Schema, Model, {
288
289
  [Key in ForeignKeyFields<Schema, Model>]: MapModelFieldType<Schema, Model, Key>;
@@ -497,7 +498,7 @@ type NestedUpdateInput<Schema extends SchemaDef, Model extends GetModels<Schema>
497
498
  data: UpdateInput<Schema, RelationFieldType<Schema, Model, Field>, OppositeRelationAndFK<Schema, Model, Field>>;
498
499
  }, UpdateInput<Schema, RelationFieldType<Schema, Model, Field>, OppositeRelationAndFK<Schema, Model, Field>>>;
499
500
  type NestedUpsertInput<Schema extends SchemaDef, Model extends GetModels<Schema>, Field extends RelationFields<Schema, Model>> = OrArray<{
500
- where: WhereUniqueInput<Schema, Model>;
501
+ where: WhereUniqueInput<Schema, RelationFieldType<Schema, Model, Field>>;
501
502
  create: CreateInput<Schema, RelationFieldType<Schema, Model, Field>, OppositeRelationAndFK<Schema, Model, Field>>;
502
503
  update: UpdateInput<Schema, RelationFieldType<Schema, Model, Field>, OppositeRelationAndFK<Schema, Model, Field>>;
503
504
  }, FieldIsArray<Schema, Model, Field>>;
@@ -1459,4 +1460,4 @@ type AllModelOperations<Schema extends SchemaDef, Model extends GetModels<Schema
1459
1460
  };
1460
1461
  type ModelOperations<Schema extends SchemaDef, Model extends GetModels<Schema>> = Omit<AllModelOperations<Schema, Model>, IsDelegateModel<Schema, Model> extends true ? 'create' | 'createMany' | 'createManyAndReturn' | 'upsert' : never>;
1461
1462
 
1462
- export { type DeleteArgs as A, type BatchResult as B, type ClientConstructor as C, type DateTimeFilter as D, type DeleteManyArgs as E, type FindArgs as F, type CountArgs as G, type CountResult as H, type IncludeInput as I, type JsonArray as J, type AggregateArgs as K, type AggregateResult as L, type ModelResult as M, type NumberFilter as N, type OrderBy as O, type GroupByArgs as P, type GroupByResult as Q, type RuntimePlugin as R, type SimplifiedModelResult as S, type ToKysely as T, type UpdateArgs as U, type OnKyselyQueryArgs as V, type WhereInput as W, type JsonObject as a, type JsonValue as b, type ClientContract as c, type ClientOptions as d, definePlugin as e, type TypeDefResult as f, type StringFilter as g, type BytesFilter as h, type BooleanFilter as i, type SortOrder as j, type NullsOrder as k, type WhereUniqueInput as l, type OmitInput as m, type SelectIncludeOmit as n, type SelectInput as o, type Subset as p, type SelectSubset as q, type FindManyArgs as r, type FindFirstArgs as s, type FindUniqueArgs as t, type CreateArgs as u, type CreateManyArgs as v, type CreateManyAndReturnArgs as w, type UpdateManyArgs as x, type UpdateManyAndReturnArgs as y, type UpsertArgs as z };
1463
+ export { type DeleteArgs as A, type BatchResult as B, type ClientConstructor as C, type DateTimeFilter as D, type DeleteManyArgs as E, type FindArgs as F, type CountArgs as G, type CountResult as H, type IncludeInput as I, type JsonArray as J, type AggregateArgs as K, type AggregateResult as L, type ModelResult as M, type NumberFilter as N, type OrderBy as O, type GroupByArgs as P, type GroupByResult as Q, type RuntimePlugin as R, type SimplifiedModelResult as S, type ToKysely as T, type UpdateArgs as U, type OnKyselyQueryArgs as V, type WhereInput as W, type ZenStackPromise as Z, type JsonObject as a, type JsonValue as b, type ClientContract as c, type ClientOptions as d, definePlugin as e, type TypeDefResult as f, type StringFilter as g, type BytesFilter as h, type BooleanFilter as i, type SortOrder as j, type NullsOrder as k, type WhereUniqueInput as l, type OmitInput as m, type SelectIncludeOmit as n, type SelectInput as o, type Subset as p, type SelectSubset as q, type FindManyArgs as r, type FindFirstArgs as s, type FindUniqueArgs as t, type CreateArgs as u, type CreateManyArgs as v, type CreateManyAndReturnArgs as w, type UpdateManyArgs as x, type UpdateManyAndReturnArgs as y, type UpsertArgs as z };
package/dist/index.cjs CHANGED
@@ -36,7 +36,8 @@ __export(src_exports, {
36
36
  NotFoundError: () => NotFoundError,
37
37
  QueryError: () => QueryError,
38
38
  ZenStackClient: () => ZenStackClient,
39
- definePlugin: () => definePlugin
39
+ definePlugin: () => definePlugin,
40
+ sql: () => import_kysely17.sql
40
41
  });
41
42
  module.exports = __toCommonJS(src_exports);
42
43
 
@@ -4578,8 +4579,8 @@ var InputValidator = class {
4578
4579
  if (this.schema.typeDefs && type in this.schema.typeDefs) {
4579
4580
  return this.makeTypeDefSchema(type);
4580
4581
  } else {
4581
- return (0, import_ts_pattern15.match)(type).with("String", () => import_zod.z.string()).with("Int", () => import_zod.z.int()).with("Float", () => import_zod.z.number()).with("Boolean", () => import_zod.z.boolean()).with("BigInt", () => import_zod.z.union([
4582
- import_zod.z.int(),
4582
+ return (0, import_ts_pattern15.match)(type).with("String", () => import_zod.z.string()).with("Int", () => import_zod.z.number().int()).with("Float", () => import_zod.z.number()).with("Boolean", () => import_zod.z.boolean()).with("BigInt", () => import_zod.z.union([
4583
+ import_zod.z.number().int(),
4583
4584
  import_zod.z.bigint()
4584
4585
  ])).with("Decimal", () => import_zod.z.union([
4585
4586
  import_zod.z.number(),
@@ -4599,7 +4600,7 @@ var InputValidator = class {
4599
4600
  }
4600
4601
  const typeDef = this.schema.typeDefs?.[type];
4601
4602
  (0, import_common_helpers9.invariant)(typeDef, `Type definition "${type}" not found in schema`);
4602
- schema = import_zod.z.looseObject(Object.fromEntries(Object.entries(typeDef.fields).map(([field, def]) => {
4603
+ schema = import_zod.z.object(Object.fromEntries(Object.entries(typeDef.fields).map(([field, def]) => {
4603
4604
  let fieldSchema = this.makePrimitiveSchema(def.type);
4604
4605
  if (def.array) {
4605
4606
  fieldSchema = fieldSchema.array();
@@ -4611,7 +4612,7 @@ var InputValidator = class {
4611
4612
  field,
4612
4613
  fieldSchema
4613
4614
  ];
4614
- })));
4615
+ }))).passthrough();
4615
4616
  this.schemaCache.set(key, schema);
4616
4617
  return schema;
4617
4618
  }
@@ -4749,7 +4750,7 @@ var InputValidator = class {
4749
4750
  }
4750
4751
  makeDateTimeFilterSchema(optional, withAggregations) {
4751
4752
  return this.makeCommonPrimitiveFilterSchema(import_zod.z.union([
4752
- import_zod.z.iso.datetime(),
4753
+ import_zod.z.string().datetime(),
4753
4754
  import_zod.z.date()
4754
4755
  ]), optional, () => import_zod.z.lazy(() => this.makeDateTimeFilterSchema(optional, withAggregations)), withAggregations ? [
4755
4756
  "_count",
@@ -4801,7 +4802,7 @@ var InputValidator = class {
4801
4802
  gte: baseSchema.optional(),
4802
4803
  not: makeThis().optional(),
4803
4804
  ...withAggregations?.includes("_count") ? {
4804
- _count: this.makeNumberFilterSchema(import_zod.z.int(), false, false).optional()
4805
+ _count: this.makeNumberFilterSchema(import_zod.z.number().int(), false, false).optional()
4805
4806
  } : {},
4806
4807
  ...withAggregations?.includes("_avg") ? {
4807
4808
  _avg: commonAggSchema()
@@ -5213,7 +5214,7 @@ var InputValidator = class {
5213
5214
  return import_zod.z.strictObject({
5214
5215
  where: this.makeWhereSchema(model, false).optional(),
5215
5216
  data: this.makeUpdateDataSchema(model, [], true),
5216
- limit: import_zod.z.int().nonnegative().optional()
5217
+ limit: import_zod.z.number().int().nonnegative().optional()
5217
5218
  });
5218
5219
  }
5219
5220
  makeUpdateManyAndReturnSchema(model) {
@@ -5320,7 +5321,7 @@ var InputValidator = class {
5320
5321
  makeDeleteManySchema(model) {
5321
5322
  return import_zod.z.object({
5322
5323
  where: this.makeWhereSchema(model, false).optional(),
5323
- limit: import_zod.z.int().nonnegative().optional()
5324
+ limit: import_zod.z.number().int().nonnegative().optional()
5324
5325
  }).optional();
5325
5326
  }
5326
5327
  // #endregion
@@ -5452,10 +5453,10 @@ var InputValidator = class {
5452
5453
  // #endregion
5453
5454
  // #region Helpers
5454
5455
  makeSkipSchema() {
5455
- return import_zod.z.int().nonnegative();
5456
+ return import_zod.z.number().int().nonnegative();
5456
5457
  }
5457
5458
  makeTakeSchema() {
5458
- return import_zod.z.int();
5459
+ return import_zod.z.number().int();
5459
5460
  }
5460
5461
  refineForSelectIncludeMutuallyExclusive(schema) {
5461
5462
  return schema.refine((value) => !(value["select"] && value["include"]), '"select" and "include" cannot be used together');
@@ -6990,6 +6991,9 @@ function definePlugin(plugin) {
6990
6991
  return plugin;
6991
6992
  }
6992
6993
  __name(definePlugin, "definePlugin");
6994
+
6995
+ // src/client/index.ts
6996
+ var import_kysely17 = require("kysely");
6993
6997
  // Annotate the CommonJS export names for ESM import in node:
6994
6998
  0 && (module.exports = {
6995
6999
  InputValidationError,
@@ -6997,6 +7001,7 @@ __name(definePlugin, "definePlugin");
6997
7001
  NotFoundError,
6998
7002
  QueryError,
6999
7003
  ZenStackClient,
7000
- definePlugin
7004
+ definePlugin,
7005
+ sql
7001
7006
  });
7002
7007
  //# sourceMappingURL=index.cjs.map