@visulima/crud 2.0.2 → 2.0.4

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/CHANGELOG.md CHANGED
@@ -1,3 +1,32 @@
1
+ ## @visulima/crud [2.0.4](https://github.com/visulima/visulima/compare/@visulima/crud@2.0.3...@visulima/crud@2.0.4) (2023-10-15)
2
+
3
+
4
+ ### Bug Fixes
5
+
6
+ * removed types from exports key ([80bd356](https://github.com/visulima/visulima/commit/80bd356659a45bd351a60870b0f380569c75e0c1))
7
+
8
+
9
+
10
+ ### Dependencies
11
+
12
+ * **@visulima/pagination:** upgraded to 3.0.4
13
+ * **@visulima/prisma-dmmf-transformer:** upgraded to 2.0.4
14
+
15
+ ## @visulima/crud [2.0.3](https://github.com/visulima/visulima/compare/@visulima/crud@2.0.2...@visulima/crud@2.0.3) (2023-10-11)
16
+
17
+
18
+ ### Bug Fixes
19
+
20
+ * update all deps ([#215](https://github.com/visulima/visulima/issues/215)) ([c077ad8](https://github.com/visulima/visulima/commit/c077ad88a8a9427831b077bb729edd5b7e590ee8))
21
+ * updated deps ([b5a74f6](https://github.com/visulima/visulima/commit/b5a74f6bb8d7bf133e1df39cc67a80f93b287d1e))
22
+
23
+
24
+
25
+ ### Dependencies
26
+
27
+ * **@visulima/pagination:** upgraded to 3.0.3
28
+ * **@visulima/prisma-dmmf-transformer:** upgraded to 2.0.3
29
+
1
30
  ## @visulima/crud [2.0.2](https://github.com/visulima/visulima/compare/@visulima/crud@2.0.1...@visulima/crud@2.0.2) (2023-09-05)
2
31
 
3
32
 
@@ -2,4 +2,4 @@ var d=(e=>(e.CREATE="CREATE",e.DELETE="DELETE",e.READ_ALL="READ_ALL",e.READ_ONE=
2
2
 
3
3
  export { d as a, m as b };
4
4
  //# sourceMappingURL=out.js.map
5
- //# sourceMappingURL=chunk-YQZIXENG.mjs.map
5
+ //# sourceMappingURL=chunk-6BMWZ6H3.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/types.d.ts","../src/utils/get-accessible-routes.ts"],"names":["RouteType","getAccessibleRoutes","only","exclude","defaultExposeStrategy","accessibleRoutes","element","get_accessible_routes_default"],"mappings":"AAMO,IAAKA,OACRA,EAAA,OAAS,SACTA,EAAA,OAAS,SACTA,EAAA,SAAW,WACXA,EAAA,SAAW,WACXA,EAAA,OAAS,SALDA,OAAA,ICJZ,IAAMC,EAAsB,CAACC,EAAoBC,EAAuBC,EAAwC,QAAuB,CACnI,IAAIC,EACAD,IAA0B,OAAS,CAAC,EAAI,iDAA6F,EAEzI,OAAI,MAAM,QAAQF,CAAI,IAClBG,EAAmBH,GAGnBC,GAAS,SACTE,EAAmBA,EAAiB,OAAQC,GAAY,CAACH,EAAQ,SAASG,CAAO,CAAC,GAG/ED,CACX,EAEOE,EAAQN","sourcesContent":["import type { Handler as CreateHandler } from \"./handler/create\";\nimport type { Handler as DeleteHandler } from \"./handler/delete\";\nimport type { Handler as ListHandler } from \"./handler/list\";\nimport type { Handler as GetHandler } from \"./handler/read\";\nimport type { Handler as UpdateHandler } from \"./handler/update\";\n\nexport enum RouteType {\n CREATE = \"CREATE\",\n DELETE = \"DELETE\",\n READ_ALL = \"READ_ALL\",\n READ_ONE = \"READ_ONE\",\n UPDATE = \"UPDATE\",\n}\n\nexport interface ModelOption {\n exclude?: RouteType[];\n formatResourceId?: (resourceId: string) => number | string;\n name?: string;\n only?: RouteType[];\n}\n\nexport type ModelsOptions<M extends string = string> = {\n [key in M]?: ModelOption;\n};\n\nexport interface HandlerOptions<M extends string = string> {\n exposeStrategy?: \"all\" | \"none\";\n formatResourceId?: (resourceId: string) => number | string;\n handlers?: {\n create?: CreateHandler;\n delete?: DeleteHandler;\n get?: GetHandler;\n list?: ListHandler;\n update?: UpdateHandler;\n };\n models?: ModelsOptions<M>;\n pagination?: PaginationConfig;\n}\n\nexport interface PaginationConfig {\n perPage: number;\n}\n\nexport interface HandlerParameters<T, Q> {\n adapter: Adapter<T, Q>;\n query: Q;\n resourceName: string;\n}\n\nexport interface UniqueResourceHandlerParameters<T, Q> {\n adapter: Adapter<T, Q>;\n query: Q;\n resourceId: number | string;\n resourceName: string;\n}\n\nexport interface Adapter<T, Q, M extends string = string> {\n connect?: () => Promise<void>;\n create: (resourceName: M, data: any, query: Q) => Promise<T>;\n delete: (resourceName: M, resourceId: number | string, query: Q) => Promise<T>;\n disconnect?: () => Promise<void>;\n getAll: (resourceName: M, query: Q) => Promise<T[]>;\n getModels: () => M[];\n getOne: (resourceName: M, resourceId: number | string, query: Q) => Promise<T>;\n getPaginationData: (resourceName: M, query: Q) => Promise<PaginationData>;\n handleError?: (error: Error) => void;\n init?: () => Promise<void>;\n mapModelsToRouteNames?: () => Promise<{ [key in M]?: string }>;\n models?: M[];\n parseQuery: (resourceName: M, query: ParsedQueryParameters) => Q;\n update: (resourceName: M, resourceId: number | string, data: any, query: Q) => Promise<T>;\n}\n\nexport interface PaginationData {\n page: number;\n pageCount: number;\n total: number;\n}\n\nexport type RecursiveField = Record<string, Record<string, boolean> | boolean>;\n\nexport type WhereOperator = \"$cont\" | \"$ends\" | \"$eq\" | \"$gt\" | \"$gte\" | \"$in\" | \"$isnull\" | \"$lt\" | \"$lte\" | \"$neq\" | \"$notin\" | \"$starts\";\n\nexport type SearchCondition = Date | boolean | number | string | null;\n\nexport type WhereCondition = {\n [key in WhereOperator]?: SearchCondition;\n};\n\n// TODO: find the correct way to type this\n// eslint-disable-next-line @typescript-eslint/no-redundant-type-constituents\nexport type Condition = Record<string, Condition | SearchCondition | WhereCondition>;\n\n// eslint-disable-next-line @typescript-eslint/no-redundant-type-constituents\nexport type WhereField = Condition & {\n // eslint-disable-next-line @typescript-eslint/no-redundant-type-constituents\n $and?: Condition | Condition[];\n // eslint-disable-next-line @typescript-eslint/no-redundant-type-constituents\n $not?: Condition | Condition[];\n // eslint-disable-next-line @typescript-eslint/no-redundant-type-constituents\n $or?: Condition | Condition[];\n};\n\nexport type OrderByOperator = \"$asc\" | \"$desc\";\n\nexport type OrderByField = Record<string, OrderByOperator>;\n\nexport interface ParsedQueryParameters {\n distinct?: string;\n include?: RecursiveField;\n limit?: number;\n orderBy?: OrderByField;\n originalQuery?: Record<string, any>;\n page?: number;\n select?: RecursiveField;\n skip?: number;\n where?: WhereField;\n}\n\nexport type ExecuteHandler<Request, Response> = (request: Request, response: Response) => Promise<void>;\n\nexport interface FakePrismaClient {\n $connect: () => void;\n $disconnect: () => Promise<void>;\n [key: string]: any;\n _dmmf?: any;\n\n _getDmmf?: () => any;\n}\n","import { RouteType } from \"../types.d\";\n\nconst getAccessibleRoutes = (only?: RouteType[], exclude?: RouteType[], defaultExposeStrategy: \"all\" | \"none\" = \"all\"): RouteType[] => {\n let accessibleRoutes: RouteType[] =\n defaultExposeStrategy === \"none\" ? [] : [RouteType.READ_ALL, RouteType.READ_ONE, RouteType.UPDATE, RouteType.DELETE, RouteType.CREATE];\n\n if (Array.isArray(only)) {\n accessibleRoutes = only;\n }\n\n if (exclude?.length) {\n accessibleRoutes = accessibleRoutes.filter((element) => !exclude.includes(element));\n }\n\n return accessibleRoutes;\n};\n\nexport default getAccessibleRoutes;\n"]}
@@ -5,4 +5,4 @@ var s=(e=>(e.CREATE="CREATE",e.DELETE="DELETE",e.READ_ALL="READ_ALL",e.READ_ONE=
5
5
  exports.a = s;
6
6
  exports.b = u;
7
7
  //# sourceMappingURL=out.js.map
8
- //# sourceMappingURL=chunk-LP5RFO3W.js.map
8
+ //# sourceMappingURL=chunk-MU7W66PZ.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/types.d.ts","../src/utils/get-accessible-routes.ts"],"names":["RouteType","getAccessibleRoutes","only","exclude","defaultExposeStrategy","accessibleRoutes","element","get_accessible_routes_default"],"mappings":"AAMO,IAAKA,OACRA,EAAA,OAAS,SACTA,EAAA,OAAS,SACTA,EAAA,SAAW,WACXA,EAAA,SAAW,WACXA,EAAA,OAAS,SALDA,OAAA,ICJZ,IAAMC,EAAsB,CAACC,EAAoBC,EAAuBC,EAAwC,QAAuB,CACnI,IAAIC,EACAD,IAA0B,OAAS,CAAC,EAAI,iDAA6F,EAEzI,OAAI,MAAM,QAAQF,CAAI,IAClBG,EAAmBH,GAGnBC,GAAS,SACTE,EAAmBA,EAAiB,OAAQC,GAAY,CAACH,EAAQ,SAASG,CAAO,CAAC,GAG/ED,CACX,EAEOE,EAAQN","sourcesContent":["import type { Handler as CreateHandler } from \"./handler/create\";\nimport type { Handler as DeleteHandler } from \"./handler/delete\";\nimport type { Handler as ListHandler } from \"./handler/list\";\nimport type { Handler as GetHandler } from \"./handler/read\";\nimport type { Handler as UpdateHandler } from \"./handler/update\";\n\nexport enum RouteType {\n CREATE = \"CREATE\",\n DELETE = \"DELETE\",\n READ_ALL = \"READ_ALL\",\n READ_ONE = \"READ_ONE\",\n UPDATE = \"UPDATE\",\n}\n\nexport interface ModelOption {\n exclude?: RouteType[];\n formatResourceId?: (resourceId: string) => number | string;\n name?: string;\n only?: RouteType[];\n}\n\nexport type ModelsOptions<M extends string = string> = {\n [key in M]?: ModelOption;\n};\n\nexport interface HandlerOptions<M extends string = string> {\n exposeStrategy?: \"all\" | \"none\";\n formatResourceId?: (resourceId: string) => number | string;\n handlers?: {\n create?: CreateHandler;\n delete?: DeleteHandler;\n get?: GetHandler;\n list?: ListHandler;\n update?: UpdateHandler;\n };\n models?: ModelsOptions<M>;\n pagination?: PaginationConfig;\n}\n\nexport interface PaginationConfig {\n perPage: number;\n}\n\nexport interface HandlerParameters<T, Q> {\n adapter: Adapter<T, Q>;\n query: Q;\n resourceName: string;\n}\n\nexport interface UniqueResourceHandlerParameters<T, Q> {\n adapter: Adapter<T, Q>;\n query: Q;\n resourceId: number | string;\n resourceName: string;\n}\n\nexport interface Adapter<T, Q, M extends string = string> {\n connect?: () => Promise<void>;\n create: (resourceName: M, data: any, query: Q) => Promise<T>;\n delete: (resourceName: M, resourceId: number | string, query: Q) => Promise<T>;\n disconnect?: () => Promise<void>;\n getAll: (resourceName: M, query: Q) => Promise<T[]>;\n getModels: () => M[];\n getOne: (resourceName: M, resourceId: number | string, query: Q) => Promise<T>;\n getPaginationData: (resourceName: M, query: Q) => Promise<PaginationData>;\n handleError?: (error: Error) => void;\n init?: () => Promise<void>;\n mapModelsToRouteNames?: () => Promise<{ [key in M]?: string }>;\n models?: M[];\n parseQuery: (resourceName: M, query: ParsedQueryParameters) => Q;\n update: (resourceName: M, resourceId: number | string, data: any, query: Q) => Promise<T>;\n}\n\nexport interface PaginationData {\n page: number;\n pageCount: number;\n total: number;\n}\n\nexport type RecursiveField = Record<string, Record<string, boolean> | boolean>;\n\nexport type WhereOperator = \"$cont\" | \"$ends\" | \"$eq\" | \"$gt\" | \"$gte\" | \"$in\" | \"$isnull\" | \"$lt\" | \"$lte\" | \"$neq\" | \"$notin\" | \"$starts\";\n\nexport type SearchCondition = Date | boolean | number | string | null;\n\nexport type WhereCondition = {\n [key in WhereOperator]?: SearchCondition;\n};\n\n// TODO: find the correct way to type this\n// eslint-disable-next-line @typescript-eslint/no-redundant-type-constituents\nexport type Condition = Record<string, Condition | SearchCondition | WhereCondition>;\n\n// eslint-disable-next-line @typescript-eslint/no-redundant-type-constituents\nexport type WhereField = Condition & {\n // eslint-disable-next-line @typescript-eslint/no-redundant-type-constituents\n $and?: Condition | Condition[];\n // eslint-disable-next-line @typescript-eslint/no-redundant-type-constituents\n $not?: Condition | Condition[];\n // eslint-disable-next-line @typescript-eslint/no-redundant-type-constituents\n $or?: Condition | Condition[];\n};\n\nexport type OrderByOperator = \"$asc\" | \"$desc\";\n\nexport type OrderByField = Record<string, OrderByOperator>;\n\nexport interface ParsedQueryParameters {\n distinct?: string;\n include?: RecursiveField;\n limit?: number;\n orderBy?: OrderByField;\n originalQuery?: Record<string, any>;\n page?: number;\n select?: RecursiveField;\n skip?: number;\n where?: WhereField;\n}\n\nexport type ExecuteHandler<Request, Response> = (request: Request, response: Response) => Promise<void>;\n\nexport interface FakePrismaClient {\n $connect: () => void;\n $disconnect: () => Promise<void>;\n [key: string]: any;\n _dmmf?: any;\n\n _getDmmf?: () => any;\n}\n","import { RouteType } from \"../types.d\";\n\nconst getAccessibleRoutes = (only?: RouteType[], exclude?: RouteType[], defaultExposeStrategy: \"all\" | \"none\" = \"all\"): RouteType[] => {\n let accessibleRoutes: RouteType[] =\n defaultExposeStrategy === \"none\" ? [] : [RouteType.READ_ALL, RouteType.READ_ONE, RouteType.UPDATE, RouteType.DELETE, RouteType.CREATE];\n\n if (Array.isArray(only)) {\n accessibleRoutes = only;\n }\n\n if (exclude?.length) {\n accessibleRoutes = accessibleRoutes.filter((element) => !exclude.includes(element));\n }\n\n return accessibleRoutes;\n};\n\nexport default getAccessibleRoutes;\n"]}
package/dist/index.d.mts CHANGED
@@ -1,6 +1,6 @@
1
1
  import { HttpError } from 'http-errors';
2
- import { C as Condition, S as SearchCondition, A as Adapter, F as FakePrismaClient, P as PaginationData, a as ParsedQueryParameters, R as RouteType, M as ModelsOptions } from './types.d-6e8ef982.js';
3
- export { H as CrudHandlerOptions, b as HandlerParameters, c as ModelOption, O as OrderByField, d as OrderByOperator, e as PaginationConfig, f as RecursiveField, U as UniqueResourceHandlerParameters, W as WhereCondition, g as WhereField, h as WhereOperator } from './types.d-6e8ef982.js';
2
+ import { C as Condition, S as SearchCondition, A as Adapter, F as FakePrismaClient, P as PaginationData, a as ParsedQueryParameters, R as RouteType, M as ModelsOptions } from './types.d-824d05f2.js';
3
+ export { H as CrudHandlerOptions, b as HandlerParameters, c as ModelOption, O as OrderByField, d as OrderByOperator, e as PaginationConfig, f as RecursiveField, U as UniqueResourceHandlerParameters, W as WhereCondition, g as WhereField, h as WhereOperator } from './types.d-824d05f2.js';
4
4
  import { OpenAPIV3 } from 'openapi-types';
5
5
 
6
6
  type PrismaRecursiveField = "include" | "select";
@@ -52,16 +52,13 @@ interface AdapterCtorArguments<M extends string, PrismaClient> {
52
52
  prismaClient: PrismaClient;
53
53
  }
54
54
  declare class PrismaAdapter<T, M extends string, PrismaClient> implements Adapter<T, PrismaParsedQueryParameters, M> {
55
+ models?: M[];
55
56
  private readonly ctorModels?;
56
57
  private dmmf;
57
- private readonly getPrismaClientModels;
58
58
  private readonly manyRelations;
59
59
  private readonly primaryKey;
60
60
  private readonly prismaClient;
61
- models?: M[];
62
61
  constructor({ manyRelations, models, primaryKey, prismaClient }: AdapterCtorArguments<M, FakePrismaClient & PrismaClient>);
63
- private getPrismaDelegate;
64
- get client(): PrismaClient;
65
62
  connect(): Promise<void>;
66
63
  create(resourceName: M, data: unknown, query: PrismaParsedQueryParameters): Promise<T>;
67
64
  delete(resourceName: M, resourceId: number | string, query: PrismaParsedQueryParameters): Promise<T>;
@@ -77,6 +74,9 @@ declare class PrismaAdapter<T, M extends string, PrismaClient> implements Adapte
77
74
  }>;
78
75
  parseQuery(resourceName: M, query: ParsedQueryParameters): PrismaParsedQueryParameters;
79
76
  update(resourceName: M, resourceId: number | string, data: unknown, query: PrismaParsedQueryParameters): Promise<T>;
77
+ get client(): PrismaClient;
78
+ private readonly getPrismaClientModels;
79
+ private getPrismaDelegate;
80
80
  }
81
81
 
82
82
  interface SwaggerType {
package/dist/index.d.ts CHANGED
@@ -1,6 +1,6 @@
1
1
  import { HttpError } from 'http-errors';
2
- import { C as Condition, S as SearchCondition, A as Adapter, F as FakePrismaClient, P as PaginationData, a as ParsedQueryParameters, R as RouteType, M as ModelsOptions } from './types.d-6e8ef982.js';
3
- export { H as CrudHandlerOptions, b as HandlerParameters, c as ModelOption, O as OrderByField, d as OrderByOperator, e as PaginationConfig, f as RecursiveField, U as UniqueResourceHandlerParameters, W as WhereCondition, g as WhereField, h as WhereOperator } from './types.d-6e8ef982.js';
2
+ import { C as Condition, S as SearchCondition, A as Adapter, F as FakePrismaClient, P as PaginationData, a as ParsedQueryParameters, R as RouteType, M as ModelsOptions } from './types.d-824d05f2.js';
3
+ export { H as CrudHandlerOptions, b as HandlerParameters, c as ModelOption, O as OrderByField, d as OrderByOperator, e as PaginationConfig, f as RecursiveField, U as UniqueResourceHandlerParameters, W as WhereCondition, g as WhereField, h as WhereOperator } from './types.d-824d05f2.js';
4
4
  import { OpenAPIV3 } from 'openapi-types';
5
5
 
6
6
  type PrismaRecursiveField = "include" | "select";
@@ -52,16 +52,13 @@ interface AdapterCtorArguments<M extends string, PrismaClient> {
52
52
  prismaClient: PrismaClient;
53
53
  }
54
54
  declare class PrismaAdapter<T, M extends string, PrismaClient> implements Adapter<T, PrismaParsedQueryParameters, M> {
55
+ models?: M[];
55
56
  private readonly ctorModels?;
56
57
  private dmmf;
57
- private readonly getPrismaClientModels;
58
58
  private readonly manyRelations;
59
59
  private readonly primaryKey;
60
60
  private readonly prismaClient;
61
- models?: M[];
62
61
  constructor({ manyRelations, models, primaryKey, prismaClient }: AdapterCtorArguments<M, FakePrismaClient & PrismaClient>);
63
- private getPrismaDelegate;
64
- get client(): PrismaClient;
65
62
  connect(): Promise<void>;
66
63
  create(resourceName: M, data: unknown, query: PrismaParsedQueryParameters): Promise<T>;
67
64
  delete(resourceName: M, resourceId: number | string, query: PrismaParsedQueryParameters): Promise<T>;
@@ -77,6 +74,9 @@ declare class PrismaAdapter<T, M extends string, PrismaClient> implements Adapte
77
74
  }>;
78
75
  parseQuery(resourceName: M, query: ParsedQueryParameters): PrismaParsedQueryParameters;
79
76
  update(resourceName: M, resourceId: number | string, data: unknown, query: PrismaParsedQueryParameters): Promise<T>;
77
+ get client(): PrismaClient;
78
+ private readonly getPrismaClientModels;
79
+ private getPrismaDelegate;
80
80
  }
81
81
 
82
82
  interface SwaggerType {
package/dist/index.js CHANGED
@@ -1,6 +1,6 @@
1
1
  'use strict';
2
2
 
3
- var chunkLP5RFO3W_js = require('./chunk-LP5RFO3W.js');
3
+ var chunkMU7W66PZ_js = require('./chunk-MU7W66PZ.js');
4
4
  var Q = require('http-errors');
5
5
  var pagination = require('@visulima/pagination');
6
6
  var prismaDmmfTransformer = require('@visulima/prisma-dmmf-transformer');
@@ -9,11 +9,11 @@ function _interopDefault (e) { return e && e.__esModule ? e : { default: e }; }
9
9
 
10
10
  var Q__default = /*#__PURE__*/_interopDefault(Q);
11
11
 
12
- var Y=(s,e)=>{let t={};return e.forEach(r=>{t[r]=s[r].plural;}),t},R=Y;var N=new Set(["string","boolean","number"]),q=s=>N.has(typeof s),b=q;var ee=s=>{let e={};if(Object.keys(s).forEach(t=>{let r=s[t];b(r)&&(e[t]=r);}),Object.keys(e).length!==1)throw new Error("cursor needs to be an object with exactly 1 property with a primitive value");return e},I=ee;var te={$asc:"asc",$desc:"desc"},re=s=>{let e={};return Object.keys(s).forEach(t=>{let r=s[t];e[t]=te[r];}),e},D=re;var F=(s,e)=>{let t={};return Object.keys(s).forEach(r=>{t[r]=s[r]===!0?!0:{[e]:F(s[r],e)};}),t},A=F;var j=s=>s instanceof Object,se={$cont:"contains",$ends:"endsWith",$eq:"equals",$gt:"gt",$gte:"gte",$in:"in",$lt:"lt",$lte:"lte",$neq:"not",$notin:"notIn",$starts:"startsWith"},ne=s=>/^\d{4}-[01]\d-[0-3]\d(?:T[0-2](?:\d:[0-5]){2}\d(?:\.\d+)?(?:Z|[+-][0-2]\d(?::?[0-5]\d)?)?)?$/g.test(s),ie=s=>ne(s)?new Date(s):typeof s=="string"&&s==="$isnull"?null:s,k=(s,e)=>{let t=s.split(".");return t.splice(-1,1),e.includes(t.join("."))},V=s=>{let e=Object.keys(s)[0],t=se[e];if(t)return {[t]:s[e]}},v=(s,e,t,r)=>{let n=e.split(".").reverse(),a={};n.forEach((p,c)=>{c===0?B(s,p,a,r):a={[p]:{some:a}};});let i=n.reverse()[0],o=t[i];t[i]={some:{...o?.some,...a[i]?.some}};},C=(s,e)=>{let t={};return Object.keys(s).forEach(r=>{let n=s[r];if(k(r,e))v(n,r,t,e);else if(b(n))t[r]=n;else if(j(n)){let a=V(n);a&&(t[r]=a);}}),t},B=(s,e,t,r)=>{if(b(s))t[e]=ie(s);else switch(e){case"$or":{j(s)&&(t.OR=C(s,r));break}case"$and":{j(s)&&(t.AND=C(s,r));break}case"$not":{j(s)&&(t.NOT=C(s,r));break}default:{t[e]=V(s);break}}},ae=(s,e)=>{let t={};return Object.keys(s).forEach(r=>{let n=s[r];k(r,e)?v(n,r,t,e):B(n,r,t,e);}),t},W=ae;var w=class{constructor({manyRelations:e={},models:t,primaryKey:r="id",prismaClient:n}){this.getPrismaClientModels=async()=>{if(this.prismaClient._dmmf!==void 0)return this.dmmf=this.prismaClient._dmmf,this.dmmf?.mappingsMap;if(this.prismaClient._getDmmf!==void 0)return this.dmmf=await this.prismaClient._getDmmf(),this.dmmf.mappingsMap;throw new Error("Couldn't get prisma client models")};this.prismaClient=n,this.primaryKey=r,this.manyRelations=e,this.ctorModels=t;}getPrismaDelegate(e){return this.prismaClient[`${e.charAt(0).toLowerCase()}${e.slice(1)}`]}get client(){return this.prismaClient}async connect(){this.prismaClient.$connect();}async create(e,t,r){return await this.getPrismaDelegate(e).create({data:t,include:r.include,select:r.select})}async delete(e,t,r){return await this.getPrismaDelegate(e).delete({include:r.include,select:r.select,where:{[this.primaryKey]:t}})}async disconnect(){await this.prismaClient.$disconnect();}async getAll(e,t){return await this.getPrismaDelegate(e).findMany({cursor:t.cursor,distinct:t.distinct,include:t.include,orderBy:t.orderBy,select:t.select,skip:t.skip,take:t.take,where:t.where})}getModels(){return this.models??[]}async getOne(e,t,r){let n=this.getPrismaDelegate(e);return await(n.findUnique??n.findOne)({include:r.include,select:r.select,where:{[this.primaryKey]:t}})}async getPaginationData(e,t){let r=await this.getPrismaDelegate(e).count({distinct:t.distinct,where:t.where});return {page:Math.ceil((t.skip??0)/(t.take??0))+1,pageCount:Math.ceil(r/(t.take??0)),total:r}}handleError(e){throw console.error(e),e instanceof Error&&e.stack&&console.error(e.stack),e.constructor.name==="PrismaClientKnownRequestError"||e.constructor.name==="PrismaClientValidationError"?Q__default.default(400,"invalid request, check your server logs for more info"):Q__default.default(500,"an unknown error occured, check your server logs for more info")}async init(){let e=this.ctorModels,t=await this.getPrismaClientModels();e!==void 0&&e.forEach(r=>{if(!Object.keys(t).includes(r))throw new Error(`Model name ${r} is invalid.`)}),this.models=e??Object.keys(t);}async mapModelsToRouteNames(){return R(await this.getPrismaClientModels(),this.getModels())}parseQuery(e,t){let r={};return t.select&&(r.select=A(t.select,"select")),t.include&&(r.include=A(t.include,"include")),t.originalQuery?.where&&(r.where=W(JSON.parse(t.originalQuery.where),this.manyRelations[e]??[])),t.orderBy&&(r.orderBy=D(t.orderBy)),t.limit!==void 0&&(r.take=t.limit),t.skip!==void 0&&(r.skip=t.skip),t.originalQuery?.cursor&&(r.cursor=I(JSON.parse(t.originalQuery.cursor))),t.distinct&&(r.distinct=t.distinct),r}async update(e,t,r,n){return await this.getPrismaDelegate(e).update({data:r,include:n.include,select:n.select,where:{[this.primaryKey]:t}})}};var oe=s=>`#/components/schemas/${s}`,h=oe;var _=s=>{switch(s){case"Int":case"BigInt":return "integer";case"DateTime":case"Bytes":case"String":return "string";case"Float":case"Decimal":return "number";case"Json":return "object";case"Boolean":return "boolean";case"Null":return "null";default:return ""}},S="PaginationData",de=[{methodStart:"createOne",schemaNameStart:"Create"},{methodStart:"updateOne",schemaNameStart:"Update"}],T=class{constructor(e){this.dmmf=e;this.schemaInputTypes=new Map;}formatInputTypeData(e){if(e.kind==="object"){let r=h(e.type.name);return e.isList?{items:{$ref:r},type:"array",xml:{name:e.type.name,wrapped:!0}}:{$ref:r}}let t=_(e.type);return e.isList?{items:{type:t},type:"array",xml:{name:e.type.name,wrapped:!0}}:{type:t}}getExampleModelsSchemas(e,t){let r=i=>{let o=i.replace("#/components/schemas/",""),p=t[o],c={};return Object.entries(p.properties??{}).forEach(([g,d])=>{let m=d.type;c[g]=m==="array"?[a(d.items)]:m;}),c},n=i=>{let o={};return Object.entries(i).forEach(([p,c])=>{o[p]=c.$ref===void 0?c.type:r(c.$ref);}),o},a=i=>{let o={};return Object.entries(i).forEach(([p,c])=>{c.items.$ref!==void 0?o[p]=[r(c.items.$ref)]:c.type==="array"?o[p]=[a(c.items)]:c.type==="object"?o[p]=n(c.properties):o[p]=c.type;}),o};return e.reduce((i,o)=>{let p={},c=t[o];Object.entries(c.properties).forEach(([m,u])=>{let f=u.type;f==="array"?p[m]=[r(u.items.$ref)]:f==="object"?p[m]=n(u.properties):p[m]=f;});let g=this.getPaginationDataSchema()[S],d={};return Object.entries(g.properties).forEach(([m,u])=>{d[m]=u.type;}),{...i,[`${o}`]:{value:p},[`${o}Page`]:{value:{data:[p],meta:d}},[`${o}s`]:{value:[p]}}},{})}getPaginatedModelsSchemas(e){return e.reduce((t,r)=>({...t,[`${r}Page`]:{properties:{data:{items:{$ref:h(r)},type:"array",xml:{name:"data",wrapped:!0}},meta:{$ref:h(S)}},type:"object",xml:{name:`${r}Page`}}}),{})}getPaginationDataSchema(){return pagination.createPaginationMetaSchemaObject(S)}parseInputTypes(e){let t=e.reduce((r,n)=>(de.map(i=>({name:`${i.methodStart}${n}`,schemaName:`${i.schemaNameStart}${n}`})).forEach(({name:i,schemaName:o})=>{let p=this.dmmf.mutationType.fieldMap[i].args[0].inputTypes[0].type.fields,c=[],g=p.reduce((d,m)=>{if(m.inputTypes[0].kind==="scalar"){let u=prismaDmmfTransformer.getJSONSchemaProperty(this.dmmf.datamodel,{})({name:m.name,...m.inputTypes[0]}),{type:f}=u[1];f&&Array.isArray(f)?f.includes("null")&&(d[m.name]={...f,nullable:!0,type:f.filter(M=>M!=="null")},d[m.name].type.length===1&&(d[m.name]={...d[m.name],type:d[m.name].type[0]})):d[m.name]=u[1];}else {let u=this.parseObjectInputType(m.inputTypes[0]);d[m.name]={...u,nullable:m.isNullable};}return m.isRequired&&c.push(m.name),d},{});r[o]={properties:g,type:"object",xml:{name:o}},c.length>0&&(r[o].required=c);}),r),{});return this.schemaInputTypes.forEach((r,n)=>{t[n]={properties:r,type:"object",xml:{name:n}};}),t}parseModels(){let e=prismaDmmfTransformer.transformDMMF(this.dmmf).definitions;return Object.keys(e).forEach(t=>{let{properties:r}=e[t];Object.keys(r).forEach(n=>{Array.isArray(r[n].type)&&r[n].type.includes("null")&&(r[n].type=r[n].type.filter(a=>a!=="null"),r[n].type.length===1&&(r[n].type=r[n].type[0]),r[n].nullable=!0);});}),e}parseObjectInputType(e){return e.kind==="object"?(this.schemaInputTypes.has(e.type.name)||(this.schemaInputTypes.set(e.type.name,{}),e.type.fields.forEach(t=>{let r={};if(t.inputTypes.length>1){let n=!1,a=t.inputTypes.map(i=>{let o=this.formatInputTypeData(i);if(o.type==="null"){n=!0;return}return o}).filter(Boolean);a.length===1?r=a[0]:r.anyOf=a,n&&(r.nullable=!0);}else {let n=t.inputTypes[0];r=this.formatInputTypeData(n);}this.schemaInputTypes.set(e.type.name,{...this.schemaInputTypes.get(e.type.name),[t.name]:r}),t.inputTypes.forEach(n=>{n.kind==="object"&&this.parseObjectInputType(n);});})),{$ref:h(e.type.name)}):{type:_(e.type)}}},L=T;var le=(s,e,t="all")=>s.reduce((r,n)=>e?.[n]?{...r,[n]:chunkLP5RFO3W_js.b(e[n].only,e[n].exclude,t)}:{...r,[n]:chunkLP5RFO3W_js.b(void 0,void 0,t)},{}),U=le;var y={distinct:{description:"Fields to distinctively retrieve",name:"distinct",schema:{type:"string"}},include:{description:"Include relations, same as select",name:"include",schema:{type:"string"}},limit:{description:"Maximum number of elements to retrieve",name:"limit",schema:{minimum:0,type:"integer"}},orderBy:{description:'Field on which to order by a direction. See <a href="https://next-crud.js.org/query-params#orderBy">the docs</a>',name:"orderBy",schema:{type:"string"}},page:{description:"Page number. Use only for pagination.",name:"page",schema:{minimum:1,type:"integer"}},select:{description:"Fields to select. For nested fields, chain them separated with a dot, eg: user.posts",name:"select",schema:{type:"string"}},skip:{description:"Number of rows to skip",name:"skip",schema:{minimum:0,type:"integer"}},where:{description:'Fields to filter. See <a href="https://next-crud.js.org/query-params#where">the docs</a>',name:"where",schema:{type:"string"}}},H=[y.select,y.include],ge=[...H,y.limit,y.skip,y.where,y.orderBy,y.page,y.distinct],J=(s,e=[])=>s==="READ_ALL"?[...ge,...e].filter(Boolean):[...H,...e].filter(Boolean);var ue=s=>`#/components/examples/${s}`,P=ue;var O=(s,e)=>e?{items:{$ref:h(s)},type:"array"}:{$ref:h(s)},fe=(s,e)=>{if(s==="CREATE")return {content:{content:{"application/json":{example:P(e),schema:O(e)}},description:`${e} created`},statusCode:201};if(s==="DELETE")return {content:{content:{"application/json":{example:P(e),schema:O(e)}},description:`${e} item deleted`},statusCode:200};if(s==="READ_ALL")return {content:{content:{"application/json":{examples:{Default:{$ref:P(`${e}s`)},Pagination:{$ref:P(`${e}Page`)}},schema:{oneOf:[O(e,!0),O(`${e}Page`,!1)]}}},description:`${e} list retrieved`},statusCode:200};if(s==="READ_ONE")return {content:{content:{"application/json":{example:P(e),schema:O(e)}},description:`${e} item retrieved`},statusCode:200};if(s==="UPDATE")return {content:{content:{"application/json":{example:P(e),schema:O(e)}},description:`${e} item updated`},statusCode:200}},K=(s,e)=>({content:{"application/json":{schema:{$ref:h(`${s}${e}`)}}}}),he=s=>{switch(s){case"CREATE":return "post";case"READ_ALL":case"READ_ONE":return "get";case"UPDATE":return "put";case"DELETE":return "delete";default:throw new TypeError(`Method for route type ${s} was not found.`)}},G=({hasId:s,modelName:e,modelsConfig:t,routeTypes:r,tag:n})=>{let a={};return r.forEach(i=>{if(r.includes(i)){let o=t?.[e]?.routeTypes?.[i]?.response.name??t?.[e]?.type?.name??e,p=he(i),c=fe(i,o);if(c===void 0)throw new TypeError(`Route type ${i}; response config was not found.`);a[p]={parameters:J(i).map(g=>({...g,in:"query"})),responses:{[c.statusCode]:c.content,...t?.[e]?.routeTypes?.[i]?.responses},summary:t?.[e]?.routeTypes?.[i]?.summary,tags:[n]},s&&a[p].parameters.push({description:`ID of the ${e}`,in:"path",name:"id",required:!0,schema:{type:"string"}}),i==="UPDATE"?a[p].requestBody=K("Update",o):i==="CREATE"&&(a[p].requestBody=K("Create",o));}}),a},ye=({models:s,modelsConfig:e,routes:t,routesMap:r})=>Object.keys(t).reduce((n,a)=>{let i=t[a],o=s?.[a]?.name?s[a].name:r?.[a]??a,p=e?.[a]?.tag.name??a;if(i.includes("CREATE")||i.includes("READ_ALL")){let c=`/${o}`,g=["READ_ALL","CREATE"].filter(d=>i.includes(d));n[c]=G({modelName:a,modelsConfig:e,routeTypes:g,tag:p});}if(i.includes("READ_ONE")||i.includes("UPDATE")||i.includes("DELETE")){let c=`/${o}/{id}`,g=["READ_ONE","UPDATE","DELETE"].filter(d=>i.includes(d));n[c]=G({hasId:!0,modelName:a,modelsConfig:e,routeTypes:g,tag:p});}return n},{}),Z=ye;var Pe=(s,e)=>s.map(t=>e?.[t]?.tag?e[t].tag:{name:t}),z=Pe;var Oe=(s,e)=>(Object.values(s).forEach(t=>{Object.values(t).forEach(r=>{typeof r.responses=="object"&&Object.values(r.responses).forEach(n=>{typeof n.content=="object"&&Object.values(n.content).forEach(a=>{if(typeof a.example=="string"){let i=a.example.replace("#/components/examples/","");e[i]?.value!==void 0&&(a.example=e[i].value);}});});});}),s),be=async({crud:s={models:{}},defaultExposeStrategy:e="all",models:t,prismaClient:r,swagger:n={allowedMediaTypes:{"application/json":!0},models:{}}})=>{let a,i;if(r._dmmf!==void 0?(a=r._dmmf,i=a?.mappingsMap):r._getDmmf!==void 0&&(a=await r._getDmmf(),i=a.mappingsMap),a===void 0)throw new TypeError("Couldn't get prisma client models");let o=new L(a),p=o.parseModels(),c=Object.keys(p),g=JSON.stringify({...p,...o.parseInputTypes(c),...o.getPaginationDataSchema(),...o.getPaginatedModelsSchemas(c)});t!==void 0&&t.forEach($=>{if(!Object.keys(i).includes($))throw new Error(`Model name ${$} is invalid.`)});let d=t??Object.keys(i),m=U(d,s.models,e),u=z(d,n.models),f=Z({models:s.models,modelsConfig:n.models,routes:m,routesMap:R(i,d)}),M=JSON.parse(g.replaceAll("#/definitions","#/components/schemas")),x=o.getExampleModelsSchemas(c,M);return {examples:x,paths:Oe(f,x),schemas:M,tags:u}},Me=be;
12
+ var Y=(s,e)=>{let t={};return e.forEach(r=>{t[r]=s[r].plural;}),t},R=Y;var N=new Set(["string","boolean","number"]),q=s=>N.has(typeof s),b=q;var ee=s=>{let e={};if(Object.keys(s).forEach(t=>{let r=s[t];b(r)&&(e[t]=r);}),Object.keys(e).length!==1)throw new Error("cursor needs to be an object with exactly 1 property with a primitive value");return e},I=ee;var te={$asc:"asc",$desc:"desc"},re=s=>{let e={};return Object.keys(s).forEach(t=>{let r=s[t];e[t]=te[r];}),e},D=re;var F=(s,e)=>{let t={};return Object.keys(s).forEach(r=>{t[r]=s[r]===!0?!0:{[e]:F(s[r],e)};}),t},A=F;var j=s=>s instanceof Object,se={$cont:"contains",$ends:"endsWith",$eq:"equals",$gt:"gt",$gte:"gte",$in:"in",$lt:"lt",$lte:"lte",$neq:"not",$notin:"notIn",$starts:"startsWith"},ne=s=>/^\d{4}-[01]\d-[0-3]\d(?:T[0-2](?:\d:[0-5]){2}\d(?:\.\d+)?(?:Z|[+-][0-2]\d(?::?[0-5]\d)?)?)?$/g.test(s),ie=s=>ne(s)?new Date(s):typeof s=="string"&&s==="$isnull"?null:s,k=(s,e)=>{let t=s.split(".");return t.splice(-1,1),e.includes(t.join("."))},V=s=>{let e=Object.keys(s)[0],t=se[e];if(t)return {[t]:s[e]}},v=(s,e,t,r)=>{let n=e.split(".").reverse(),a={};n.forEach((p,c)=>{c===0?B(s,p,a,r):a={[p]:{some:a}};});let i=n.reverse()[0],o=t[i];t[i]={some:{...o?.some,...a[i]?.some}};},C=(s,e)=>{let t={};return Object.keys(s).forEach(r=>{let n=s[r];if(k(r,e))v(n,r,t,e);else if(b(n))t[r]=n;else if(j(n)){let a=V(n);a&&(t[r]=a);}}),t},B=(s,e,t,r)=>{if(b(s))t[e]=ie(s);else switch(e){case"$or":{j(s)&&(t.OR=C(s,r));break}case"$and":{j(s)&&(t.AND=C(s,r));break}case"$not":{j(s)&&(t.NOT=C(s,r));break}default:{t[e]=V(s);break}}},ae=(s,e)=>{let t={};return Object.keys(s).forEach(r=>{let n=s[r];k(r,e)?v(n,r,t,e):B(n,r,t,e);}),t},W=ae;var w=class{constructor({manyRelations:e={},models:t,primaryKey:r="id",prismaClient:n}){this.getPrismaClientModels=async()=>{if(this.prismaClient._dmmf!==void 0)return this.dmmf=this.prismaClient._dmmf,this.dmmf?.mappingsMap;if(this.prismaClient._getDmmf!==void 0)return this.dmmf=await this.prismaClient._getDmmf(),this.dmmf.mappingsMap;throw new Error("Couldn't get prisma client models")};this.prismaClient=n,this.primaryKey=r,this.manyRelations=e,this.ctorModels=t;}async connect(){this.prismaClient.$connect();}async create(e,t,r){return await this.getPrismaDelegate(e).create({data:t,include:r.include,select:r.select})}async delete(e,t,r){return await this.getPrismaDelegate(e).delete({include:r.include,select:r.select,where:{[this.primaryKey]:t}})}async disconnect(){await this.prismaClient.$disconnect();}async getAll(e,t){return await this.getPrismaDelegate(e).findMany({cursor:t.cursor,distinct:t.distinct,include:t.include,orderBy:t.orderBy,select:t.select,skip:t.skip,take:t.take,where:t.where})}getModels(){return this.models??[]}async getOne(e,t,r){let n=this.getPrismaDelegate(e);return await(n.findUnique??n.findOne)({include:r.include,select:r.select,where:{[this.primaryKey]:t}})}async getPaginationData(e,t){let r=await this.getPrismaDelegate(e).count({distinct:t.distinct,where:t.where});return {page:Math.ceil((t.skip??0)/(t.take??0))+1,pageCount:Math.ceil(r/(t.take??0)),total:r}}handleError(e){throw console.error(e),e instanceof Error&&e.stack&&console.error(e.stack),e.constructor.name==="PrismaClientKnownRequestError"||e.constructor.name==="PrismaClientValidationError"?Q__default.default(400,"invalid request, check your server logs for more info"):Q__default.default(500,"an unknown error occured, check your server logs for more info")}async init(){let e=this.ctorModels,t=await this.getPrismaClientModels();e!==void 0&&e.forEach(r=>{if(!Object.keys(t).includes(r))throw new Error(`Model name ${r} is invalid.`)}),this.models=e??Object.keys(t);}async mapModelsToRouteNames(){return R(await this.getPrismaClientModels(),this.getModels())}parseQuery(e,t){let r={};return t.select&&(r.select=A(t.select,"select")),t.include&&(r.include=A(t.include,"include")),t.originalQuery?.where&&(r.where=W(JSON.parse(t.originalQuery.where),this.manyRelations[e]??[])),t.orderBy&&(r.orderBy=D(t.orderBy)),t.limit!==void 0&&(r.take=t.limit),t.skip!==void 0&&(r.skip=t.skip),t.originalQuery?.cursor&&(r.cursor=I(JSON.parse(t.originalQuery.cursor))),t.distinct&&(r.distinct=t.distinct),r}async update(e,t,r,n){return await this.getPrismaDelegate(e).update({data:r,include:n.include,select:n.select,where:{[this.primaryKey]:t}})}get client(){return this.prismaClient}getPrismaDelegate(e){return this.prismaClient[`${e.charAt(0).toLowerCase()}${e.slice(1)}`]}};var oe=s=>`#/components/schemas/${s}`,h=oe;var _=s=>{switch(s){case"Int":case"BigInt":return "integer";case"DateTime":case"Bytes":case"String":return "string";case"Float":case"Decimal":return "number";case"Json":return "object";case"Boolean":return "boolean";case"Null":return "null";default:return ""}},S="PaginationData",de=[{methodStart:"createOne",schemaNameStart:"Create"},{methodStart:"updateOne",schemaNameStart:"Update"}],T=class{constructor(e){this.dmmf=e;this.schemaInputTypes=new Map;}formatInputTypeData(e){if(e.kind==="object"){let r=h(e.type.name);return e.isList?{items:{$ref:r},type:"array",xml:{name:e.type.name,wrapped:!0}}:{$ref:r}}let t=_(e.type);return e.isList?{items:{type:t},type:"array",xml:{name:e.type.name,wrapped:!0}}:{type:t}}getExampleModelsSchemas(e,t){let r=i=>{let o=i.replace("#/components/schemas/",""),p=t[o],c={};return Object.entries(p.properties??{}).forEach(([g,d])=>{let m=d.type;c[g]=m==="array"?[a(d.items)]:m;}),c},n=i=>{let o={};return Object.entries(i).forEach(([p,c])=>{o[p]=c.$ref===void 0?c.type:r(c.$ref);}),o},a=i=>{let o={};return Object.entries(i).forEach(([p,c])=>{c.items.$ref!==void 0?o[p]=[r(c.items.$ref)]:c.type==="array"?o[p]=[a(c.items)]:c.type==="object"?o[p]=n(c.properties):o[p]=c.type;}),o};return e.reduce((i,o)=>{let p={},c=t[o];Object.entries(c.properties).forEach(([m,u])=>{let f=u.type;f==="array"?p[m]=[r(u.items.$ref)]:f==="object"?p[m]=n(u.properties):p[m]=f;});let g=this.getPaginationDataSchema()[S],d={};return Object.entries(g.properties).forEach(([m,u])=>{d[m]=u.type;}),{...i,[`${o}`]:{value:p},[`${o}Page`]:{value:{data:[p],meta:d}},[`${o}s`]:{value:[p]}}},{})}getPaginatedModelsSchemas(e){return e.reduce((t,r)=>({...t,[`${r}Page`]:{properties:{data:{items:{$ref:h(r)},type:"array",xml:{name:"data",wrapped:!0}},meta:{$ref:h(S)}},type:"object",xml:{name:`${r}Page`}}}),{})}getPaginationDataSchema(){return pagination.createPaginationMetaSchemaObject(S)}parseInputTypes(e){let t=e.reduce((r,n)=>(de.map(i=>({name:`${i.methodStart}${n}`,schemaName:`${i.schemaNameStart}${n}`})).forEach(({name:i,schemaName:o})=>{let p=this.dmmf.mutationType.fieldMap[i].args[0].inputTypes[0].type.fields,c=[],g=p.reduce((d,m)=>{if(m.inputTypes[0].kind==="scalar"){let u=prismaDmmfTransformer.getJSONSchemaProperty(this.dmmf.datamodel,{})({name:m.name,...m.inputTypes[0]}),{type:f}=u[1];f&&Array.isArray(f)?f.includes("null")&&(d[m.name]={...f,nullable:!0,type:f.filter(M=>M!=="null")},d[m.name].type.length===1&&(d[m.name]={...d[m.name],type:d[m.name].type[0]})):d[m.name]=u[1];}else {let u=this.parseObjectInputType(m.inputTypes[0]);d[m.name]={...u,nullable:m.isNullable};}return m.isRequired&&c.push(m.name),d},{});r[o]={properties:g,type:"object",xml:{name:o}},c.length>0&&(r[o].required=c);}),r),{});return this.schemaInputTypes.forEach((r,n)=>{t[n]={properties:r,type:"object",xml:{name:n}};}),t}parseModels(){let e=prismaDmmfTransformer.transformDMMF(this.dmmf).definitions;return Object.keys(e).forEach(t=>{let{properties:r}=e[t];Object.keys(r).forEach(n=>{Array.isArray(r[n].type)&&r[n].type.includes("null")&&(r[n].type=r[n].type.filter(a=>a!=="null"),r[n].type.length===1&&(r[n].type=r[n].type[0]),r[n].nullable=!0);});}),e}parseObjectInputType(e){return e.kind==="object"?(this.schemaInputTypes.has(e.type.name)||(this.schemaInputTypes.set(e.type.name,{}),e.type.fields.forEach(t=>{let r={};if(t.inputTypes.length>1){let n=!1,a=t.inputTypes.map(i=>{let o=this.formatInputTypeData(i);if(o.type==="null"){n=!0;return}return o}).filter(Boolean);a.length===1?r=a[0]:r.anyOf=a,n&&(r.nullable=!0);}else {let n=t.inputTypes[0];r=this.formatInputTypeData(n);}this.schemaInputTypes.set(e.type.name,{...this.schemaInputTypes.get(e.type.name),[t.name]:r}),t.inputTypes.forEach(n=>{n.kind==="object"&&this.parseObjectInputType(n);});})),{$ref:h(e.type.name)}):{type:_(e.type)}}},L=T;var le=(s,e,t="all")=>s.reduce((r,n)=>e?.[n]?{...r,[n]:chunkMU7W66PZ_js.b(e[n].only,e[n].exclude,t)}:{...r,[n]:chunkMU7W66PZ_js.b(void 0,void 0,t)},{}),U=le;var y={distinct:{description:"Fields to distinctively retrieve",name:"distinct",schema:{type:"string"}},include:{description:"Include relations, same as select",name:"include",schema:{type:"string"}},limit:{description:"Maximum number of elements to retrieve",name:"limit",schema:{minimum:0,type:"integer"}},orderBy:{description:'Field on which to order by a direction. See <a href="https://next-crud.js.org/query-params#orderBy">the docs</a>',name:"orderBy",schema:{type:"string"}},page:{description:"Page number. Use only for pagination.",name:"page",schema:{minimum:1,type:"integer"}},select:{description:"Fields to select. For nested fields, chain them separated with a dot, eg: user.posts",name:"select",schema:{type:"string"}},skip:{description:"Number of rows to skip",name:"skip",schema:{minimum:0,type:"integer"}},where:{description:'Fields to filter. See <a href="https://next-crud.js.org/query-params#where">the docs</a>',name:"where",schema:{type:"string"}}},H=[y.select,y.include],ge=[...H,y.limit,y.skip,y.where,y.orderBy,y.page,y.distinct],J=(s,e=[])=>s==="READ_ALL"?[...ge,...e].filter(Boolean):[...H,...e].filter(Boolean);var ue=s=>`#/components/examples/${s}`,P=ue;var O=(s,e)=>e?{items:{$ref:h(s)},type:"array"}:{$ref:h(s)},fe=(s,e)=>{if(s==="CREATE")return {content:{content:{"application/json":{example:P(e),schema:O(e)}},description:`${e} created`},statusCode:201};if(s==="DELETE")return {content:{content:{"application/json":{example:P(e),schema:O(e)}},description:`${e} item deleted`},statusCode:200};if(s==="READ_ALL")return {content:{content:{"application/json":{examples:{Default:{$ref:P(`${e}s`)},Pagination:{$ref:P(`${e}Page`)}},schema:{oneOf:[O(e,!0),O(`${e}Page`,!1)]}}},description:`${e} list retrieved`},statusCode:200};if(s==="READ_ONE")return {content:{content:{"application/json":{example:P(e),schema:O(e)}},description:`${e} item retrieved`},statusCode:200};if(s==="UPDATE")return {content:{content:{"application/json":{example:P(e),schema:O(e)}},description:`${e} item updated`},statusCode:200}},K=(s,e)=>({content:{"application/json":{schema:{$ref:h(`${s}${e}`)}}}}),he=s=>{switch(s){case"CREATE":return "post";case"READ_ALL":case"READ_ONE":return "get";case"UPDATE":return "put";case"DELETE":return "delete";default:throw new TypeError(`Method for route type ${s} was not found.`)}},G=({hasId:s,modelName:e,modelsConfig:t,routeTypes:r,tag:n})=>{let a={};return r.forEach(i=>{if(r.includes(i)){let o=t?.[e]?.routeTypes?.[i]?.response.name??t?.[e]?.type?.name??e,p=he(i),c=fe(i,o);if(c===void 0)throw new TypeError(`Route type ${i}; response config was not found.`);a[p]={parameters:J(i).map(g=>({...g,in:"query"})),responses:{[c.statusCode]:c.content,...t?.[e]?.routeTypes?.[i]?.responses},summary:t?.[e]?.routeTypes?.[i]?.summary,tags:[n]},s&&a[p].parameters.push({description:`ID of the ${e}`,in:"path",name:"id",required:!0,schema:{type:"string"}}),i==="UPDATE"?a[p].requestBody=K("Update",o):i==="CREATE"&&(a[p].requestBody=K("Create",o));}}),a},ye=({models:s,modelsConfig:e,routes:t,routesMap:r})=>Object.keys(t).reduce((n,a)=>{let i=t[a],o=s?.[a]?.name?s[a].name:r?.[a]??a,p=e?.[a]?.tag.name??a;if(i.includes("CREATE")||i.includes("READ_ALL")){let c=`/${o}`,g=["READ_ALL","CREATE"].filter(d=>i.includes(d));n[c]=G({modelName:a,modelsConfig:e,routeTypes:g,tag:p});}if(i.includes("READ_ONE")||i.includes("UPDATE")||i.includes("DELETE")){let c=`/${o}/{id}`,g=["READ_ONE","UPDATE","DELETE"].filter(d=>i.includes(d));n[c]=G({hasId:!0,modelName:a,modelsConfig:e,routeTypes:g,tag:p});}return n},{}),Z=ye;var Pe=(s,e)=>s.map(t=>e?.[t]?.tag?e[t].tag:{name:t}),z=Pe;var Oe=(s,e)=>(Object.values(s).forEach(t=>{Object.values(t).forEach(r=>{typeof r.responses=="object"&&Object.values(r.responses).forEach(n=>{typeof n.content=="object"&&Object.values(n.content).forEach(a=>{if(typeof a.example=="string"){let i=a.example.replace("#/components/examples/","");e[i]?.value!==void 0&&(a.example=e[i].value);}});});});}),s),be=async({crud:s={models:{}},defaultExposeStrategy:e="all",models:t,prismaClient:r,swagger:n={allowedMediaTypes:{"application/json":!0},models:{}}})=>{let a,i;if(r._dmmf!==void 0?(a=r._dmmf,i=a?.mappingsMap):r._getDmmf!==void 0&&(a=await r._getDmmf(),i=a.mappingsMap),a===void 0)throw new TypeError("Couldn't get prisma client models");let o=new L(a),p=o.parseModels(),c=Object.keys(p),g=JSON.stringify({...p,...o.parseInputTypes(c),...o.getPaginationDataSchema(),...o.getPaginatedModelsSchemas(c)});t!==void 0&&t.forEach($=>{if(!Object.keys(i).includes($))throw new Error(`Model name ${$} is invalid.`)});let d=t??Object.keys(i),m=U(d,s.models,e),u=z(d,n.models),f=Z({models:s.models,modelsConfig:n.models,routes:m,routesMap:R(i,d)}),M=JSON.parse(g.replaceAll("#/definitions","#/components/schemas")),x=o.getExampleModelsSchemas(c,M);return {examples:x,paths:Oe(f,x),schemas:M,tags:u}},Me=be;
13
13
 
14
14
  Object.defineProperty(exports, 'RouteType', {
15
15
  enumerable: true,
16
- get: function () { return chunkLP5RFO3W_js.a; }
16
+ get: function () { return chunkMU7W66PZ_js.a; }
17
17
  });
18
18
  exports.PrismaAdapter = w;
19
19
  exports.modelsToOpenApi = Me;