express-zod-api 9.2.0 → 10.0.0-beta1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (182) hide show
  1. package/CHANGELOG.md +26 -0
  2. package/README.md +28 -20
  3. package/dist/esm/index.js +58 -0
  4. package/dist/esm/index.js.map +1 -0
  5. package/dist/esm/package.json +1 -0
  6. package/dist/index.d.ts +776 -21
  7. package/dist/index.js +55 -69
  8. package/dist/index.js.map +1 -1
  9. package/package.json +31 -25
  10. package/dist/api-response.d.ts +0 -16
  11. package/dist/api-response.js +0 -3
  12. package/dist/api-response.js.map +0 -1
  13. package/dist/client-helpers.d.ts +0 -23
  14. package/dist/client-helpers.js +0 -71
  15. package/dist/client-helpers.js.map +0 -1
  16. package/dist/client.d.ts +0 -15
  17. package/dist/client.js +0 -120
  18. package/dist/client.js.map +0 -1
  19. package/dist/common-helpers.d.ts +0 -46
  20. package/dist/common-helpers.js +0 -207
  21. package/dist/common-helpers.js.map +0 -1
  22. package/dist/config-type.d.ts +0 -59
  23. package/dist/config-type.js +0 -11
  24. package/dist/config-type.js.map +0 -1
  25. package/dist/date-in-schema.d.ts +0 -11
  26. package/dist/date-in-schema.js +0 -46
  27. package/dist/date-in-schema.js.map +0 -1
  28. package/dist/date-out-schema.d.ts +0 -10
  29. package/dist/date-out-schema.js +0 -31
  30. package/dist/date-out-schema.js.map +0 -1
  31. package/dist/depends-on-method.d.ts +0 -10
  32. package/dist/depends-on-method.js +0 -32
  33. package/dist/depends-on-method.js.map +0 -1
  34. package/dist/endpoint.d.ts +0 -98
  35. package/dist/endpoint.js +0 -261
  36. package/dist/endpoint.js.map +0 -1
  37. package/dist/endpoints-factory.d.ts +0 -161
  38. package/dist/endpoints-factory.js +0 -68
  39. package/dist/endpoints-factory.js.map +0 -1
  40. package/dist/errors.d.ts +0 -35
  41. package/dist/errors.js +0 -64
  42. package/dist/errors.js.map +0 -1
  43. package/dist/extend-zod.d.ts +0 -22
  44. package/dist/extend-zod.js +0 -33
  45. package/dist/extend-zod.js.map +0 -1
  46. package/dist/file-schema.d.ts +0 -23
  47. package/dist/file-schema.js +0 -55
  48. package/dist/file-schema.js.map +0 -1
  49. package/dist/io-schema.d.ts +0 -16
  50. package/dist/io-schema.js +0 -21
  51. package/dist/io-schema.js.map +0 -1
  52. package/dist/logger.d.ts +0 -3
  53. package/dist/logger.js +0 -54
  54. package/dist/logger.js.map +0 -1
  55. package/dist/logical-container.d.ts +0 -16
  56. package/dist/logical-container.js +0 -85
  57. package/dist/logical-container.js.map +0 -1
  58. package/dist/metadata.d.ts +0 -27
  59. package/dist/metadata.js +0 -58
  60. package/dist/metadata.js.map +0 -1
  61. package/dist/method.d.ts +0 -8
  62. package/dist/method.js +0 -5
  63. package/dist/method.js.map +0 -1
  64. package/dist/middleware.d.ts +0 -32
  65. package/dist/middleware.js +0 -16
  66. package/dist/middleware.js.map +0 -1
  67. package/dist/mime.d.ts +0 -2
  68. package/dist/mime.js +0 -10
  69. package/dist/mime.js.map +0 -1
  70. package/dist/mock.d.ts +0 -38
  71. package/dist/mock.js +0 -66
  72. package/dist/mock.js.map +0 -1
  73. package/dist/open-api-helpers.d.ts +0 -83
  74. package/dist/open-api-helpers.js +0 -621
  75. package/dist/open-api-helpers.js.map +0 -1
  76. package/dist/open-api.d.ts +0 -25
  77. package/dist/open-api.js +0 -98
  78. package/dist/open-api.js.map +0 -1
  79. package/dist/result-handler.d.ts +0 -151
  80. package/dist/result-handler.js +0 -71
  81. package/dist/result-handler.js.map +0 -1
  82. package/dist/routing-walker.d.ts +0 -12
  83. package/dist/routing-walker.js +0 -55
  84. package/dist/routing-walker.js.map +0 -1
  85. package/dist/routing.d.ts +0 -15
  86. package/dist/routing.js +0 -25
  87. package/dist/routing.js.map +0 -1
  88. package/dist/schema-walker.d.ts +0 -23
  89. package/dist/schema-walker.js +0 -26
  90. package/dist/schema-walker.js.map +0 -1
  91. package/dist/security.d.ts +0 -72
  92. package/dist/security.js +0 -3
  93. package/dist/security.js.map +0 -1
  94. package/dist/serve-static.d.ts +0 -9
  95. package/dist/serve-static.js +0 -17
  96. package/dist/serve-static.js.map +0 -1
  97. package/dist/server.d.ts +0 -20
  98. package/dist/server.js +0 -131
  99. package/dist/server.js.map +0 -1
  100. package/dist/startup-logo.d.ts +0 -1
  101. package/dist/startup-logo.js +0 -27
  102. package/dist/startup-logo.js.map +0 -1
  103. package/dist/upload-schema.d.ts +0 -11
  104. package/dist/upload-schema.js +0 -42
  105. package/dist/upload-schema.js.map +0 -1
  106. package/dist/zts-helpers.d.ts +0 -37
  107. package/dist/zts-helpers.js +0 -60
  108. package/dist/zts-helpers.js.map +0 -1
  109. package/dist/zts.d.ts +0 -31
  110. package/dist/zts.js +0 -147
  111. package/dist/zts.js.map +0 -1
  112. package/dist-esm/api-response.js +0 -2
  113. package/dist-esm/api-response.js.map +0 -1
  114. package/dist-esm/client-helpers.js +0 -48
  115. package/dist-esm/client-helpers.js.map +0 -1
  116. package/dist-esm/client.js +0 -113
  117. package/dist-esm/client.js.map +0 -1
  118. package/dist-esm/common-helpers.js +0 -188
  119. package/dist-esm/common-helpers.js.map +0 -1
  120. package/dist-esm/config-type.js +0 -7
  121. package/dist-esm/config-type.js.map +0 -1
  122. package/dist-esm/date-in-schema.js +0 -42
  123. package/dist-esm/date-in-schema.js.map +0 -1
  124. package/dist-esm/date-out-schema.js +0 -27
  125. package/dist-esm/date-out-schema.js.map +0 -1
  126. package/dist-esm/depends-on-method.js +0 -28
  127. package/dist-esm/depends-on-method.js.map +0 -1
  128. package/dist-esm/endpoint.js +0 -256
  129. package/dist-esm/endpoint.js.map +0 -1
  130. package/dist-esm/endpoints-factory.js +0 -64
  131. package/dist-esm/endpoints-factory.js.map +0 -1
  132. package/dist-esm/errors.js +0 -54
  133. package/dist-esm/errors.js.map +0 -1
  134. package/dist-esm/extend-zod.js +0 -16
  135. package/dist-esm/extend-zod.js.map +0 -1
  136. package/dist-esm/file-schema.js +0 -51
  137. package/dist-esm/file-schema.js.map +0 -1
  138. package/dist-esm/index.js +0 -19
  139. package/dist-esm/index.js.map +0 -1
  140. package/dist-esm/io-schema.js +0 -17
  141. package/dist-esm/io-schema.js.map +0 -1
  142. package/dist-esm/logger.js +0 -47
  143. package/dist-esm/logger.js.map +0 -1
  144. package/dist-esm/logical-container.js +0 -78
  145. package/dist-esm/logical-container.js.map +0 -1
  146. package/dist-esm/metadata.js +0 -51
  147. package/dist-esm/metadata.js.map +0 -1
  148. package/dist-esm/method.js +0 -2
  149. package/dist-esm/method.js.map +0 -1
  150. package/dist-esm/middleware.js +0 -12
  151. package/dist-esm/middleware.js.map +0 -1
  152. package/dist-esm/mime.js +0 -4
  153. package/dist-esm/mime.js.map +0 -1
  154. package/dist-esm/mock.js +0 -57
  155. package/dist-esm/mock.js.map +0 -1
  156. package/dist-esm/open-api-helpers.js +0 -575
  157. package/dist-esm/open-api-helpers.js.map +0 -1
  158. package/dist-esm/open-api.js +0 -94
  159. package/dist-esm/open-api.js.map +0 -1
  160. package/dist-esm/package.json +0 -1
  161. package/dist-esm/result-handler.js +0 -66
  162. package/dist-esm/result-handler.js.map +0 -1
  163. package/dist-esm/routing-walker.js +0 -51
  164. package/dist-esm/routing-walker.js.map +0 -1
  165. package/dist-esm/routing.js +0 -21
  166. package/dist-esm/routing.js.map +0 -1
  167. package/dist-esm/schema-walker.js +0 -22
  168. package/dist-esm/schema-walker.js.map +0 -1
  169. package/dist-esm/security.js +0 -2
  170. package/dist-esm/security.js.map +0 -1
  171. package/dist-esm/serve-static.js +0 -10
  172. package/dist-esm/serve-static.js.map +0 -1
  173. package/dist-esm/server.js +0 -98
  174. package/dist-esm/server.js.map +0 -1
  175. package/dist-esm/startup-logo.js +0 -23
  176. package/dist-esm/startup-logo.js.map +0 -1
  177. package/dist-esm/upload-schema.js +0 -38
  178. package/dist-esm/upload-schema.js.map +0 -1
  179. package/dist-esm/zts-helpers.js +0 -50
  180. package/dist-esm/zts-helpers.js.map +0 -1
  181. package/dist-esm/zts.js +0 -140
  182. package/dist-esm/zts.js.map +0 -1
package/dist/index.js CHANGED
@@ -1,72 +1,58 @@
1
- "use strict";
2
- var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
- if (k2 === undefined) k2 = k;
4
- var desc = Object.getOwnPropertyDescriptor(m, k);
5
- if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
- desc = { enumerable: true, get: function() { return m[k]; } };
7
- }
8
- Object.defineProperty(o, k2, desc);
9
- }) : (function(o, m, k, k2) {
10
- if (k2 === undefined) k2 = k;
11
- o[k2] = m[k];
12
- }));
13
- var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
- Object.defineProperty(o, "default", { enumerable: true, value: v });
15
- }) : function(o, v) {
16
- o["default"] = v;
1
+ "use strict";var jr=Object.create;var Ce=Object.defineProperty;var Lr=Object.getOwnPropertyDescriptor;var kr=Object.getOwnPropertyNames;var Ur=Object.getPrototypeOf,Hr=Object.prototype.hasOwnProperty;var Kr=(e,r)=>{for(var t in r)Ce(e,t,{get:r[t],enumerable:!0})},jt=(e,r,t,o)=>{if(r&&typeof r=="object"||typeof r=="function")for(let n of kr(r))!Hr.call(e,n)&&n!==t&&Ce(e,n,{get:()=>r[n],enumerable:!(o=Lr(r,n))||o.enumerable});return e};var b=(e,r,t)=>(t=e!=null?jr(Ur(e)):{},jt(r||!e||!e.__esModule?Ce(t,"default",{value:e,enumerable:!0}):t,e)),Fr=e=>jt(Ce({},"__esModule",{value:!0}),e);var _r=(e,r,t)=>{if(!r.has(e))throw TypeError("Cannot "+t)};var L=(e,r,t)=>{if(r.has(e))throw TypeError("Cannot add the same private member more than once");r instanceof WeakSet?r.add(e):r.set(e,t)};var C=(e,r,t)=>(_r(e,r,"access private method"),t);var un={};Kr(un,{AbstractEndpoint:()=>B,Client:()=>tt,DependsOnMethod:()=>pe,DependsOnMethodError:()=>ee,EndpointsFactory:()=>ie,InputValidationError:()=>N,OpenAPI:()=>Je,OpenAPIError:()=>A,OutputValidationError:()=>H,RoutingError:()=>G,ServeStatic:()=>de,attachRouting:()=>sr,createConfig:()=>kt,createHttpError:()=>Dr.default,createLogger:()=>Se,createMiddleware:()=>Ge,createResultHandler:()=>mt,createServer:()=>ar,defaultEndpointsFactory:()=>Wt,defaultResultHandler:()=>V,ez:()=>rt,getMessageFromError:()=>U,getStatusCodeFromError:()=>De,testEndpoint:()=>Tr,withMeta:()=>X});module.exports=Fr(un);var Lt={silent:!0,warn:!0,debug:!0},kt=e=>e;var D=require("zod");var Kt=require("http-errors"),S=require("zod");var nt=require("ramda"),T="expressZodApiMeta",X=e=>{let r=e._def;return r[T]=r[T]||{examples:[]},"example"in e||Object.defineProperties(e,{example:{get:()=>t=>(r[T].examples.push(t),e)}}),e},Ut=e=>T in e._def?typeof e._def[T]=="object"&&e._def[T]!==null:!1;function Me(e,r){if(!Ut(e))return;let t=e._def;return r in t[T]?t[T][r]:void 0}var me=(e,r)=>{if(!Ut(e))return r;r=X(r);let t=r._def,o=ue(t[T].examples,e._def[T].examples);if(t[T]=(0,nt.mergeDeepRight)({...t[T],examples:[]},{...e._def[T],examples:[]}),o.type==="single")t[T].examples=o.value;else for(let[n,i]of o.value)t[T].examples.push((0,nt.mergeDeepRight)({...n},{...i}));return r};var Ht=b(require("mime")),_=Ht.default.getType("json")||"application/json",fe="multipart/form-data";var R=require("zod"),$r="ZodUpload",Gr=e=>typeof e=="object"&&e!==null&&"name"in e&&"encoding"in e&&"mimetype"in e&&"data"in e&&"tempFilePath"in e&&"truncated"in e&&"size"in e&&"md5"in e&&"mv"in e&&typeof e.name=="string"&&typeof e.mimetype=="string"&&typeof e.data=="object"&&typeof e.tempFilePath=="string"&&typeof e.truncated=="boolean"&&typeof e.size=="number"&&typeof e.md5=="string"&&typeof e.mv=="function",it=class extends R.ZodType{_parse(r){let{ctx:t}=this._processInputParams(r);return t.parsedType!==R.ZodParsedType.object||!Gr(t.data)?((0,R.addIssueToContext)(t,{code:R.ZodIssueCode.custom,message:`Expected file upload, received ${t.parsedType}`}),R.INVALID):(0,R.OK)(t.data)}},$=it;$.create=()=>new it({typeName:$r});var st=/:([A-Za-z0-9_]+)/g;function qr(e){let t=(e.header("content-type")||"").slice(0,fe.length).toLowerCase()===fe;return"files"in e&&t}var Ne={get:["query","params"],post:["body","params","files"],put:["body","params"],patch:["body","params"],delete:["query","params"]},Vr=["body","query","params"],at=e=>e.method.toLowerCase();function Ft(e,r){let t=at(e);if(t==="options")return{};let o=Vr;return t in Ne&&(o=Ne[t]),r&&t in r&&(o=r[t]||o),o.filter(n=>n==="files"?qr(e):!0).reduce((n,i)=>({...n,...e[i]}),{})}function pt(e){return typeof e=="object"&&"level"in e&&"color"in e&&Object.keys(Lt).includes(e.level)&&typeof e.color=="boolean"}function we(e){return!isNaN(e.getTime())}function ge(e){return e instanceof Error?e:new Error(typeof e=="symbol"?e.toString():`${e}`)}function U(e){return e instanceof S.z.ZodError?e.issues.map(({path:r,message:t})=>(r.length?[r.join("/")]:[]).concat(t).join(": ")).join("; "):e instanceof H?`output${e.originalError.issues[0]?.path.length>0?"/":": "}${e.message}`:e.message}function De(e){return e instanceof Kt.HttpError?e.statusCode:e instanceof N?400:500}var ve=(e,r)=>{let t=Me(e,"examples");return t===void 0?[]:t.reduce((o,n)=>{let i=e.safeParse(n);return o.concat(i.success?r?i.data:n:[])},[])},ue=(e,r)=>{if(e.length===0)return{type:"single",value:r};if(r.length===0)return{type:"single",value:e};let t=[];for(let o of e)for(let n of r)t.push([o,n]);return{type:"tuple",value:t}};function dt(e){let r=e.match(st);return r?r.map(t=>t.slice(1)):[]}var ye=e=>e.reduce((r,t)=>r||t,!1);function k(e){return e instanceof S.z.ZodEffects&&e._def.effect.type!=="refinement"?!0:e instanceof S.z.ZodUnion?ye(e.options.map(k)):e instanceof S.z.ZodIntersection?ye([e._def.left,e._def.right].map(k)):!1}function M(e){return e instanceof $?!0:e instanceof S.z.ZodObject?ye(Object.values(e.shape).map(M)):e instanceof S.z.ZodUnion?ye(e.options.map(M)):e instanceof S.z.ZodIntersection?ye([e._def.left,e._def.right].map(M)):e instanceof S.z.ZodOptional||e instanceof S.z.ZodNullable?M(e.unwrap()):e instanceof S.z.ZodEffects||e instanceof S.z.ZodTransformer?M(e._def.schema):e instanceof S.z.ZodRecord?M(e._def.valueType):e instanceof S.z.ZodArray?M(e._def.type):e instanceof S.z.ZodDefault?M(e._def.innerType):!1}var xe=e=>"coerce"in e._def&&typeof e._def.coerce=="boolean"?e._def.coerce:!1,he=(e,r,t)=>[r].concat(e.split("/")).concat(t||[]).flatMap(o=>o.split(/[^A-Z0-9]/gi)).map(o=>o.slice(0,1).toUpperCase()+o.slice(1).toLowerCase()).join(""),ze=({effect:e,sample:r})=>{try{return typeof e.transform(r,{addIssue:()=>{},path:[]})}catch{return}},ct=e=>typeof e=="string"?{message:e}:e||{};var G=class extends Error{constructor(){super(...arguments);this.name="RoutingError"}},ee=class extends G{constructor(){super(...arguments);this.name="DependsOnMethodError"}},A=class extends Error{constructor(){super(...arguments);this.name="OpenAPIError"}},K=class extends Error{constructor(){super(...arguments);this.name="IOSchemaError"}},H=class extends K{constructor(t){super(U(t));this.name="OutputValidationError";this.originalError=t}},N=class extends K{constructor(t){super(U(t));this.name="InputValidationError";this.originalError=t}},te=class extends Error{constructor(t,o){super(t);this.name="ResultHandlerError";this.originalError=o||void 0}};var w=e=>typeof e=="object"&&e!==null,je=e=>({and:e.reduce((r,t)=>r.concat(w(t)&&"and"in t?t.and:t),[])}),Le=(e,r)=>{if(w(e)){if("and"in e)return{and:e.and.map(t=>w(t)&&"or"in t?{or:t.or.map(r)}:r(t))};if("or"in e)return{or:e.or.map(t=>w(t)&&"and"in t?{and:t.and.map(r)}:r(t))}}return r(e)},lt=e=>e.and.reduce((r,t)=>{let o=ue(r.or,w(t)&&"or"in t?t.or:[t]);return o.type==="single"?r.or.push(...o.value):r.or=o.value.map(je),r},{or:[]}),re=(e,r)=>{if(w(e)){if("and"in e){if(w(r)){if("and"in r)return je([e,r]);if("or"in r)return re(lt(e),r)}return je([e,r])}if("or"in e){if(w(r)){if("and"in r)return re(r,e);if("or"in r){let t=ue(e.or,r.or);return{or:t.type==="single"?t.value:t.value.map(je)}}}return re(e,{and:[r]})}}return w(r)&&("and"in r||"or"in r)?re(r,e):{and:[e,r]}};var q=require("zod");var oe={positive:200,negative:400},mt=e=>e,V=mt({getPositiveResponse:e=>{let r=Me(e,"examples")||[],t=X(q.z.object({status:q.z.literal("success"),data:e}));for(let o of r)t.example({status:"success",data:o});return t},getNegativeResponse:()=>X(q.z.object({status:q.z.literal("error"),error:q.z.object({message:q.z.string()})})).example({status:"error",error:{message:U(new Error("Sample error message"))}}),handler:({error:e,input:r,output:t,request:o,response:n,logger:i})=>{if(!e){n.status(oe.positive).json({status:"success",data:t});return}let a=De(e);a===500&&i.error(`Internal server error
2
+ ${e.stack}
3
+ `,{url:o.url,payload:r}),n.status(a).json({status:"error",error:{message:U(e)}})}}),ke=({error:e,logger:r,response:t})=>{r.error(`Result handler failure: ${e.message}.`),t.status(500).end(`An error occurred while serving the result: ${e.message}.`+(e.originalError?`
4
+ Original error: ${e.originalError.message}.`:""))};var _t=(e,r=[_])=>{if(e instanceof D.z.ZodType)return r;let{mimeTypes:t,mimeType:o}=e;return o?[o]:t||r},B=class{},He,$t,Ke,Gt,Fe,qt,_e,Vt,$e,Bt,Ue=class extends B{constructor({middlewares:t,inputSchema:o,outputSchema:n,handler:i,resultHandler:a,description:p,shortDescription:l,...c}){super();L(this,He);L(this,Ke);L(this,Fe);L(this,_e);L(this,$e);this.methods=[];this.siblingMethods=[];this.middlewares=[];this.scopes=[];this.tags=[];[{name:"input schema",schema:o},{name:"output schema",schema:n}].forEach(({name:u,schema:h})=>{if(k(h))throw new K(`Using transformations on the top level of endpoint ${u} is not allowed.`)}),this.middlewares=t;let d={positive:a.getPositiveResponse(n),negative:a.getNegativeResponse()};this.mimeTypes={input:M(o)?[fe]:[_],positive:_t(d.positive),negative:_t(d.negative)},this.schemas={input:o,output:n,positive:d.positive instanceof D.z.ZodType?d.positive:d.positive.schema,negative:d.negative instanceof D.z.ZodType?d.negative:d.negative.schema},this.statusCodes={positive:d.positive instanceof D.z.ZodType?oe.positive:d.positive.statusCode||oe.positive,negative:d.negative instanceof D.z.ZodType?oe.negative:d.negative.statusCode||oe.negative},this.handler=i,this.resultHandler=a,this.descriptions={long:p,short:l},"scopes"in c&&c.scopes&&this.scopes.push(...c.scopes),"scope"in c&&c.scope&&this.scopes.push(c.scope),"tags"in c&&c.tags&&this.tags.push(...c.tags),"tag"in c&&c.tag&&this.tags.push(c.tag),"methods"in c?this.methods=c.methods:this.methods=[c.method]}_setSiblingMethods(t){this.siblingMethods=t}getDescription(t){return this.descriptions[t]}getMethods(){return this.methods}getSchema(t){return this.schemas[t]}getMimeTypes(t){return this.mimeTypes[t]}getStatusCode(t){return this.statusCodes[t]}getSecurity(){return this.middlewares.reduce((t,o)=>o.security?re(t,o.security):t,{and:[]})}getScopes(){return this.scopes}getTags(){return this.tags}async execute({request:t,response:o,logger:n,config:i}){let a=at(t),p,l=null;if(i.cors){let d=C(this,He,$t).call(this);typeof i.cors=="function"&&(d=await i.cors({request:t,logger:n,endpoint:this,defaultHeaders:d}));for(let u in d)o.set(u,d[u])}let c=Ft(t,i.inputSources);try{let{options:d,isStreamClosed:u}=await C(this,Fe,qt).call(this,{method:a,input:c,request:t,response:o,logger:n});if(u)return;if(a==="options"){o.status(200).end();return}p=await C(this,Ke,Gt).call(this,await C(this,_e,Vt).call(this,{input:c,options:d,logger:n}))}catch(d){l=ge(d)}await C(this,$e,Bt).call(this,{input:c,output:p,request:t,response:o,error:l,logger:n})}};He=new WeakSet,$t=function(){return{"Access-Control-Allow-Origin":"*","Access-Control-Allow-Methods":this.methods.concat(this.siblingMethods).concat("options").join(", ").toUpperCase(),"Access-Control-Allow-Headers":"content-type"}},Ke=new WeakSet,Gt=async function(t){try{return await this.schemas.output.parseAsync(t)}catch(o){throw o instanceof D.z.ZodError?new H(o):o}},Fe=new WeakSet,qt=async function({method:t,input:o,request:n,response:i,logger:a}){let p={},l=!1;for(let c of this.middlewares){if(t==="options"&&c.type==="proprietary")continue;let d;try{d=await c.input.parseAsync(o)}catch(u){throw u instanceof D.z.ZodError?new N(u):u}if(Object.assign(p,await c.middleware({input:d,options:p,request:n,response:i,logger:a})),l="writableEnded"in i&&i.writableEnded,l){a.warn(`The middleware ${c.middleware.name} has closed the stream. Accumulated options:`,p);break}}return{options:p,isStreamClosed:l}},_e=new WeakSet,Vt=async function({input:t,options:o,logger:n}){let i;try{i=await this.schemas.input.parseAsync(t)}catch(a){throw a instanceof D.z.ZodError?new N(a):a}return this.handler({input:i,options:o,logger:n})},$e=new WeakSet,Bt=async function({error:t,request:o,response:n,logger:i,input:a,output:p}){try{await this.resultHandler.handler({error:t,output:p,request:o,response:n,logger:i,input:a})}catch(l){ke({logger:i,response:n,error:new te(ge(l).message,t)})}};var Yt=["get","post","put","delete","patch"];var ut=require("zod");var Jt=(e,r)=>{let t=e.map(({input:o})=>o).concat(r).reduce((o,n)=>o.and(n));for(let o of e)me(o.input,t);return me(r,t),t};var Ge=e=>{if(k(e.input))throw new K("Using transformations on the top level of middleware input schema is not allowed.");return{...e,type:"proprietary"}};var se,qe,ne=class{constructor(r){this.middlewares=[];this.use=this.addExpressMiddleware;this.resultHandler="resultHandler"in r?r.resultHandler:r}addMiddleware(r){var t;return C(t=ne,se,qe).call(t,this.middlewares.concat(r),this.resultHandler)}addExpressMiddleware(r,t){var a;let o=t?.transformer||(p=>p),n=t?.provider||(()=>({})),i={type:"express",input:ut.z.object({}),middleware:async({request:p,response:l})=>new Promise((c,d)=>{r(p,l,h=>{if(h&&h instanceof Error)return d(o(h));c(n(p,l))})})};return C(a=ne,se,qe).call(a,this.middlewares.concat(i),this.resultHandler)}addOptions(r){var t;return C(t=ne,se,qe).call(t,this.middlewares.concat(Ge({input:ut.z.object({}),middleware:async()=>r})),this.resultHandler)}build({input:r,handler:t,output:o,...n}){let{middlewares:i,resultHandler:a}=this;return new Ue({handler:t,middlewares:i,outputSchema:o,resultHandler:a,inputSchema:Jt(i,r),...n})}},ie=ne;se=new WeakSet,qe=function(r,t){let o=new ne(t);return o.middlewares=r,o},L(ie,se);var Wt=new ie(V);var Qt=require("util"),ae=require("triple-beam"),Te=b(require("winston")),{combine:Br,colorize:Yr,timestamp:Jr,printf:Wr}=Te.default.format;function Se(e){let r=i=>{let{[ae.LEVEL]:a,[ae.MESSAGE]:p,[ae.SPLAT]:l,...c}=i;return(0,Qt.inspect)(c,!1,1,e.color)},t=i=>Wr(({timestamp:a,message:p,level:l,durationMs:c,...d})=>(typeof p=="object"&&(d={...d,...p},p="[No message]"),`${a} ${l}: ${p}`+(c===void 0?"":` duration: ${c}ms`)+(Object.keys(d).length===0?"":" "+(i?r(d):JSON.stringify(d))))),o=[Jr()],n={handleExceptions:!0};switch(e.color&&o.push(Yr()),e.level){case"debug":n.level="debug",o.push(t(!0));break;case"silent":case"warn":default:n.level="warn",o.push(t())}return n.format=Br(...o),Te.default.createLogger({silent:e.level==="silent",levels:Te.default.config.npm.levels,transports:[new Te.default.transports.Console(n)],exitOnError:!1})}var pe=class{constructor(r){this.methods=r;Object.keys(r).forEach(t=>{if(t in r&&!(r[t]?.getMethods()||[]).includes(t))throw new ee(`The endpoint assigned to the '${t}' parameter must have at least this method in its specification.
5
+ This error should prevent mistakes during the development process.
6
+ Example:
7
+
8
+ new ${this.constructor.name}({
9
+ ${t}: endpointsFactory.build({
10
+ methods: ['${t}', `+((r[t]?.getMethods()||[]).map(n=>`'${n}'`).join(", ")||"...")+`]
11
+ // or method: '${t}'
12
+ ...
13
+ })
17
14
  });
18
- var __importStar = (this && this.__importStar) || function (mod) {
19
- if (mod && mod.__esModule) return mod;
20
- var result = {};
21
- if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
22
- __setModuleDefault(result, mod);
23
- return result;
15
+ `)})}};var Xt=b(require("express")),de=class{constructor(...r){this.params=r}apply(r,t){return t(r,Xt.default.static(...this.params))}};var Y=({routing:e,onEndpoint:r,onStatic:t,parentPath:o,hasCors:n})=>{Object.entries(e).forEach(([i,a])=>{if(i=i.trim(),i.match(/\//))throw new G(`Routing elements should not contain '/' character.
16
+ The error caused by ${o?`'${o}' route that has a '${i}'`:`'${i}'`} entry.`);let p=`${o||""}${i?`/${i}`:""}`;if(a instanceof B){let l=a.getMethods().slice();n&&l.push("options"),l.forEach(c=>{r(a,p,c)})}else if(a instanceof de)t&&a.apply(p,t);else if(a instanceof pe){if(Object.entries(a.methods).forEach(([l,c])=>{r(c,p,l)}),n&&Object.keys(a.methods).length>0){let[l,...c]=Object.keys(a.methods),d=a.methods[l];d._setSiblingMethods(c),r(d,p,"options")}}else Y({onEndpoint:r,onStatic:t,hasCors:n,routing:a,parentPath:p})})};var er=()=>`
17
+ \x1B[94m\x1B[39m
18
+ \x1B[94m\x1B[39m
19
+ \x1B[94m8888888888 8888888888P 888 d8888 8888888b. 8888888 \x1B[39m
20
+ \x1B[94m888 d88P 888 d88888 888 Y88b 888\x1B[39m\x1B[95m\x1B[39m
21
+ \x1B[95m888 d88P 888 d88P888 888 888 888\x1B[39m
22
+ \x1B[95m8888888 888 888 88888b. 888d888 .d88b. .d8888b .d8888b d88P .d88b. .d88888 d88P 888 888 d88P 888\x1B[39m\x1B[97m\x1B[39m
23
+ \x1B[97m888 \`Y8bd8P' 888 "88b 888P" d8P Y8b 88K 88K d88P d88""88b d88" 888 d88P 888 8888888P" 888 \x1B[39m
24
+ \x1B[97m888 X88K 888 888 888 88888888 "Y8888b. "Y8888b. d88P 888 888 888 888 d88P 888 888 888\x1B[39m\x1B[95m\x1B[39m
25
+ \x1B[95m888 .d8""8b. 888 d88P 888 Y8b. X88 X88 d88P Y88..88P Y88b 888 d8888888888 888 888 \x1B[39m
26
+ \x1B[95m8888888888 888 888 88888P" 888 "Y8888 88888P' 88888P' d8888888888 "Y88P" "Y88888 d88P 888 888 8888888\x1B[39m\x1B[94m\x1B[39m
27
+ \x1B[94m 888\x1B[39m
28
+ \x1B[94m 888\x1B[3m Proudly supports transgender community.\x1B[23m\x1B[39m
29
+ \x1B[94m\x1B[3mfor Brianna \x1B[23m 888\x1B[3m Start your API server with I/O schema validation and custom middlewares in minutes.\x1B[23m\x1B[39m\x1B[90m\x1B[39m
30
+ \x1B[90m\x1B[3m Thank you for choosing Express Zod API for your project.\x1B[23m\x1B[39m\x1B[0m\x1B[0m
31
+ \x1B[0m\x1B[0m
32
+ \x1B[0m\x1B[0m
33
+ `.trim();var ft=({app:e,logger:r,config:t,routing:o})=>{t.startupLogo!==!1&&console.log(er()),Y({routing:o,hasCors:!!t.cors,onEndpoint:(n,i,a)=>{e[a](i,async(p,l)=>{r.info(`${p.method}: ${i}`),await n.execute({request:p,response:l,logger:r,config:t})})},onStatic:(n,i)=>{e.use(n,i)}})};var Ve=b(require("express")),tr=b(require("compression")),rr=b(require("express-fileupload")),or=b(require("https"));var nr=b(require("http-errors")),Qr=(e,r)=>(t,o,n,i)=>{if(!t)return i();e.handler({error:t,request:o,response:n,logger:r,input:o.body,output:null})},ir=(e,r)=>(t,o)=>{let n=(0,nr.default)(404,`Can not ${t.method} ${t.path}`);try{e.handler({request:t,response:o,logger:r,error:n,input:null,output:null})}catch(i){ke({response:o,logger:r,error:new te(ge(i).message,n)})}};function sr(e,r){let t=pt(e.logger)?Se(e.logger):e.logger;ft({app:e.app,routing:r,logger:t,config:e});let o=e.errorHandler||V;return{notFoundHandler:ir(o,t),logger:t}}function ar(e,r){let t=pt(e.logger)?Se(e.logger):e.logger,o=(0,Ve.default)();o.disable("x-powered-by");let n=e.errorHandler||V,i=e.server.compression?(0,tr.default)({...typeof e.server.compression=="object"?e.server.compression:{}}):void 0,a=e.server.jsonParser||(0,Ve.json)(),p=e.server.upload?(0,rr.default)({...typeof e.server.upload=="object"?e.server.upload:{},abortOnLimit:!1,parseNested:!0}):void 0,l=[].concat(i||[]).concat(a).concat(p||[]);o.use(l),o.use(Qr(n,t)),ft({app:o,routing:r,logger:t,config:e}),o.use(ir(n,t));let c=o.listen(e.server.listen,()=>{t.info(`Listening ${e.server.listen}`)}),d;return e.https&&(d=or.default.createServer(e.https.options,o).listen(e.https.listen,()=>{t.info(`Listening ${e.https.listen}`)})),{app:o,httpServer:c,httpsServer:d,logger:t}}var hr=require("openapi3-ts");var ce=require("ramda"),x=require("zod");var g=require("zod");var yt=/^\d{4}-\d{2}-\d{2}(T\d{2}:\d{2}:\d{2}(\.\d+)?)?Z?$/,Xr="ZodDateIn",gt=class extends g.ZodType{_parse(r){let{status:t,ctx:o}=this._processInputParams(r);if(o.parsedType!==g.ZodParsedType.string)return(0,g.addIssueToContext)(o,{code:g.ZodIssueCode.invalid_type,expected:g.ZodParsedType.string,received:o.parsedType}),g.INVALID;yt.test(o.data)||((0,g.addIssueToContext)(o,{code:g.ZodIssueCode.invalid_string,validation:"regex"}),t.dirty());let n=new Date(o.data);return we(n)?{status:t.value,value:n}:((0,g.addIssueToContext)(o,{code:g.ZodIssueCode.invalid_date}),g.INVALID)}},Oe=gt;Oe.create=()=>new gt({typeName:Xr});var J=({schema:e,onEach:r,rules:t,onMissing:o,...n})=>{let i=r&&r({schema:e,...n}),a="typeName"in e._def?t[e._def.typeName]:void 0,l=a?a({schema:e,...n,next:c=>J({...c,...n,onEach:r,rules:t,onMissing:o})}):o(e);return i?{...l,...i}:l};var pr=50,cr="https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Date/toISOString",eo={integer:0,number:0,string:"",boolean:!1,object:{},null:null,array:[]},lr=e=>e.replace(st,r=>`{${r.slice(1)}}`),to=({schema:{_def:{innerType:e,defaultValue:r}},next:t})=>({...t({schema:e}),default:r()}),ro=({schema:{_def:{innerType:e}},next:r})=>r({schema:e}),oo=()=>({format:"any"}),no=({isResponse:e})=>{if(e)throw new A("Please use z.upload() only for input.");return{type:"string",format:"binary"}},io=({schema:{isBinary:e,isBase64:r},isResponse:t})=>{if(!t)throw new A("Please use z.file() only within ResultHandler.");return{type:"string",format:e?"binary":r?"byte":"file"}},so=({schema:{options:e},next:r})=>({oneOf:e.map(t=>r({schema:t}))}),ao=({schema:{options:e,discriminator:r},next:t})=>({discriminator:{propertyName:r},oneOf:Array.from(e.values()).map(o=>t({schema:o}))}),po=({schema:{_def:{left:e,right:r}},next:t})=>({allOf:[e,r].map(o=>t({schema:o}))}),co=({schema:e,next:r})=>r({schema:e.unwrap()}),lo=({schema:e,next:r})=>({nullable:!0,...r({schema:e.unwrap()})}),dr=({schema:e})=>({type:typeof Object.values(e.enum)[0],enum:Object.values(e.enum)}),mo=({schema:{value:e}})=>({type:typeof e,enum:[e]}),uo=({schema:e,isResponse:r,next:t})=>{let o=Object.keys(e.shape).filter(n=>{let i=e.shape[n];return!(r&&xe(i)?i instanceof x.z.ZodOptional:i.isOptional())});return{type:"object",properties:Be({schema:e,isResponse:r,next:t}),...o.length?{required:o}:{}}},fo=()=>({type:"string",nullable:!0,format:"null"}),yo=({isResponse:e})=>{if(e)throw new A("Please use z.dateOut() for output.");return{description:"YYYY-MM-DDTHH:mm:ss.sssZ",type:"string",format:"date-time",pattern:yt.source,externalDocs:{url:cr}}},go=({isResponse:e})=>{if(!e)throw new A("Please use z.dateIn() for input.");return{description:"YYYY-MM-DDTHH:mm:ss.sssZ",type:"string",format:"date-time",externalDocs:{url:cr}}},xo=({isResponse:e})=>{throw new A(`Using z.date() within ${e?"output":"input"} schema is forbidden. Please use z.date${e?"Out":"In"}() instead. Check out the documentation for details.`)},ho=()=>({type:"boolean"}),To=()=>({type:"integer",format:"bigint"}),So=({schema:{keySchema:e,valueSchema:r},isResponse:t,next:o})=>{if(e instanceof x.z.ZodEnum||e instanceof x.z.ZodNativeEnum){let n=Object.values(e.enum),i=n.reduce((a,p)=>({...a,[p]:r}),{});return{type:"object",properties:Be({schema:x.z.object(i),isResponse:t,next:o}),...n.length?{required:n}:{}}}if(e instanceof x.z.ZodLiteral)return{type:"object",properties:Be({schema:x.z.object({[e.value]:r}),isResponse:t,next:o}),required:[e.value]};if(e instanceof x.z.ZodUnion&&e.options.reduce((i,a)=>i&&a instanceof x.z.ZodLiteral,!0)){let i=e.options.reduce((a,p)=>({...a,[p.value]:r}),{});return{type:"object",properties:Be({schema:x.z.object(i),isResponse:t,next:o}),required:e.options.map(a=>a.value)}}return{type:"object",additionalProperties:o({schema:r})}},Oo=({schema:{_def:e,element:r},next:t})=>({type:"array",items:t({schema:r}),...e.minLength!==null&&{minItems:e.minLength.value},...e.maxLength!==null&&{maxItems:e.maxLength.value}}),bo=({schema:{items:e},next:r})=>{let t=e.map(o=>r({schema:o}));return{type:"array",minItems:t.length,maxItems:t.length,items:{oneOf:t,format:"tuple",...t.length>0&&{description:t.map((o,n)=>`${n}: ${o.type}`).join(", ")}}}},Po=({schema:{isEmail:e,isURL:r,minLength:t,maxLength:o,isUUID:n,isCUID:i,isCUID2:a,isULID:p,isIP:l,isEmoji:c,isDatetime:d,_def:{checks:u}}})=>{let h=u.find(E=>E.kind==="regex"),y=u.find(E=>E.kind==="datetime"),O=h?h.regex:y?y.offset?new RegExp("^\\d{4}-\\d{2}-\\d{2}T\\d{2}:\\d{2}:\\d{2}(\\.\\d+)?(([+-]\\d{2}:\\d{2})|Z)$"):new RegExp("^\\d{4}-\\d{2}-\\d{2}T\\d{2}:\\d{2}:\\d{2}(\\.\\d+)?Z$"):void 0;return{type:"string",...d&&{format:"date-time"},...e&&{format:"email"},...r&&{format:"url"},...n&&{format:"uuid"},...i&&{format:"cuid"},...a&&{format:"cuid2"},...p&&{format:"ulid"},...l&&{format:"ip"},...c&&{format:"emoji"},...t!==null&&{minLength:t},...o!==null&&{maxLength:o},...O&&{pattern:`/${O.source}/${O.flags}`}}},Eo=({schema:e})=>{let r=e._def.checks.find(({kind:i})=>i==="min"),t=r?r.inclusive:!0,o=e._def.checks.find(({kind:i})=>i==="max"),n=o?o.inclusive:!0;return{type:e.isInt?"integer":"number",format:e.isInt?"int64":"double",minimum:e.minValue===null?e.isInt?Number.MIN_SAFE_INTEGER:Number.MIN_VALUE:e.minValue,exclusiveMinimum:!t,maximum:e.maxValue===null?e.isInt?Number.MAX_SAFE_INTEGER:Number.MAX_VALUE:e.maxValue,exclusiveMaximum:!n}},Be=({schema:{shape:e},next:r})=>Object.keys(e).reduce((t,o)=>({...t,[o]:r({schema:e[o]})}),{}),Zo=e=>{let r=Array.isArray(e.type)?e.type[0]:e.type;return eo?.[r]},Ro=({schema:e,isResponse:r,next:t})=>{let o=t({schema:e.innerType()}),{effect:n}=e._def;if(r&&n.type==="transform"){let i=ze({effect:n,sample:Zo(o)});return i&&["number","string","boolean"].includes(i)?{type:i}:t({schema:x.z.any()})}if(!r&&n.type==="preprocess"){let{type:i,...a}=o;return{...a,format:`${a.format||i} (preprocessed)`}}return o},Ao=({schema:e,isResponse:r,next:t})=>t({schema:e._def[r?"out":"in"]}),Io=({schema:e,next:r})=>r({schema:e.unwrap()}),mr=(e,r,t=[])=>{let o=ve(e,r);return o.length===0?{}:{examples:o.reduce((n,i,a)=>({...n,[`example${a+1}`]:{value:(0,ce.omit)(t,i)}}),{})}},Co=(e,r,t)=>{let o=ve(e,r);return o.length===0?{}:{examples:o.reduce((n,i,a)=>t in i?{...n,[`example${a+1}`]:{value:i[t]}}:n,{})}};function be(e){if(e instanceof x.z.ZodObject)return e;let r;if(e instanceof x.z.ZodUnion||e instanceof x.z.ZodDiscriminatedUnion)r=Array.from(e.options.values()).map(t=>be(t)).reduce((t,o)=>t.merge(o.partial()),x.z.object({}));else if(e instanceof x.z.ZodEffects){if(k(e))throw new A("Using transformations on the top level of input schema is not allowed.");r=be(e._def.schema)}else r=be(e._def.left).merge(be(e._def.right));return me(e,r)}var ur=({path:e,method:r,endpoint:t,inputSources:o})=>{let n=t.getSchema("input"),i=be(n).shape,a=dt(e),p=o.includes("query"),l=o.includes("params"),c=d=>l&&a.includes(d);return Object.keys(i).filter(d=>p||c(d)).map(d=>({name:d,in:c(d)?"path":"query",required:!i[d].isOptional(),schema:{description:`${r.toUpperCase()} ${e} parameter`,...J({schema:i[d],isResponse:!1,rules:ht,onEach:Tt,onMissing:St})},...Co(n,!1,d)}))},ht={ZodString:Po,ZodNumber:Eo,ZodBigInt:To,ZodBoolean:ho,ZodDateIn:yo,ZodDateOut:go,ZodNull:fo,ZodArray:Oo,ZodTuple:bo,ZodRecord:So,ZodObject:uo,ZodLiteral:mo,ZodIntersection:po,ZodUnion:so,ZodFile:io,ZodUpload:no,ZodAny:oo,ZodDefault:to,ZodEnum:dr,ZodNativeEnum:dr,ZodEffects:Ro,ZodOptional:co,ZodNullable:lo,ZodDiscriminatedUnion:ao,ZodBranded:Io,ZodDate:xo,ZodCatch:ro,ZodPipeline:Ao},Tt=({schema:e,isResponse:r})=>{let{description:t}=e,o=ve(e,r);return{...t&&{description:t},...e.isNullable()&&!(r&&xe(e))&&{nullable:!0},...o.length>0&&{example:o[0]}}},St=e=>{throw new A(`Zod type ${e.constructor.name} is unsupported`)},xt=(e,r)=>{let t=e.properties?(0,ce.omit)(r,e.properties):void 0,o=e.example?(0,ce.omit)(r,e.example):void 0,n=e.required?e.required.filter(p=>!r.includes(p)):void 0,i=e.allOf?e.allOf.map(p=>xt(p,r)):void 0,a=e.oneOf?e.oneOf.map(p=>xt(p,r)):void 0;return(0,ce.omit)(Object.entries({properties:t,required:n,example:o,allOf:i,oneOf:a}).filter(([{},p])=>p===void 0).map(([p])=>p),{...e,properties:t,required:n,example:o,allOf:i,oneOf:a})},fr=e=>(0,ce.omit)(["example"],e),Ot=({method:e,path:r,description:t,endpoint:o,isPositive:n})=>{let i=n?o.getSchema("positive"):o.getSchema("negative"),a=n?o.getMimeTypes("positive"):o.getMimeTypes("negative"),p=fr(J({schema:i,isResponse:!0,rules:ht,onEach:Tt,onMissing:St})),l=mr(i,!0);return{description:`${e.toUpperCase()} ${r} ${t}`,content:a.reduce((c,d)=>({...c,[d]:{schema:p,...l}}),{})}},Mo=()=>({type:"http",scheme:"basic"}),No=({format:e})=>({type:"http",scheme:"bearer",...e&&{bearerFormat:e}}),wo=({name:e})=>({type:"apiKey",in:"query",name:e}),Do=({name:e})=>({type:"apiKey",in:"header",name:e}),vo=({name:e})=>({type:"apiKey",in:"cookie",name:e}),zo=({url:e})=>({type:"openIdConnect",openIdConnectUrl:e}),jo=({flows:e={}})=>({type:"oauth2",flows:Object.keys(e).reduce((r,t)=>{let o=e[t];if(!o)return r;let{scopes:n={},...i}=o;return{...r,[t]:{...i,scopes:n}}},{})}),yr=e=>{let r={basic:Mo,bearer:No,input:wo,header:Do,cookie:vo,openid:zo,oauth2:jo};return Le(e,t=>r[t.type](t))},Ye=e=>{if(typeof e=="object"){if("or"in e)return e.or.map(r=>("and"in r?r.and:[r]).reduce((t,{name:o,scopes:n})=>({...t,[o]:n}),{}));if("and"in e)return Ye(lt(e))}return Ye({or:[e]})},gr=({method:e,path:r,endpoint:t})=>{let o=dt(r),n=fr(xt(J({schema:t.getSchema("input"),isResponse:!1,rules:ht,onEach:Tt,onMissing:St}),o)),i=mr(t.getSchema("input"),!1,o);return{content:t.getMimeTypes("input").reduce((a,p)=>({...a,[p]:{schema:{description:`${e.toUpperCase()} ${r} request body`,...n},...i}}),{})}},xr=e=>Object.keys(e).map(r=>{let t=e[r];return{name:r,description:typeof t=="string"?t:t.description,...typeof t=="object"&&t.url&&{externalDocs:{url:t.url}}}}),bt=e=>e.length<=pr?e:e.slice(0,pr-1)+"\u2026";var Je=class extends hr.OpenApiBuilder{constructor({routing:t,config:o,title:n,version:i,serverUrl:a,successfulResponseDescription:p="Successful response",errorResponseDescription:l="Error response",hasSummaryFromDescription:c=!0}){super();this.lastSecuritySchemaIds={};this.lastOperationIdSuffixes={};this.addInfo({title:n,version:i}).addServer({url:a}),Y({routing:t,onEndpoint:(u,h,y)=>{let O=y,E={path:h,method:O,endpoint:u},[W,Q]=["short","long"].map(u.getDescription.bind(u)),Re=o.inputSources?.[O]||Ne[O],Ae=ur({...E,inputSources:Re}),I={operationId:this.ensureUniqOperationId(h,O),responses:{[u.getStatusCode("positive")]:Ot({...E,description:p,isPositive:!0}),[u.getStatusCode("negative")]:Ot({...E,description:l,isPositive:!1})}};Q&&(I.description=Q,c&&W===void 0&&(I.summary=bt(Q))),W&&(I.summary=bt(W)),u.getTags().length>0&&(I.tags=u.getTags()),Ae.length>0&&(I.parameters=Ae),Re.includes("body")&&(I.requestBody=gr(E));let Ie=Ye(Le(yr(u.getSecurity()),ot=>{let zt=this.ensureUniqSecuritySchemaName(ot),zr=["oauth2","openIdConnect"].includes(ot.type)?u.getScopes():[];return this.addSecurityScheme(zt,ot),{name:zt,scopes:zr}}));Ie.length>0&&(I.security=Ie);let vr=lr(h);this.addPath(vr,{[O]:I})}}),this.rootDoc.tags=o.tags?xr(o.tags):[]}ensureUniqOperationId(t,o){let n=he(t,o);return n in this.lastOperationIdSuffixes?(this.lastOperationIdSuffixes[n]++,`${n}${this.lastOperationIdSuffixes[n]}`):(this.lastOperationIdSuffixes[n]=1,n)}ensureUniqSecuritySchemaName(t){for(let o in this.rootDoc.components?.securitySchemes||{})if(JSON.stringify(t)===JSON.stringify(this.rootDoc.components?.securitySchemes?.[o]))return o;return this.lastSecuritySchemaIds[t.type]=(this.lastSecuritySchemaIds?.[t.type]||0)+1,`${t.type.toUpperCase()}_${this.lastSecuritySchemaIds[t.type]}`}};var Pt=b(require("http"));var Lo=e=>({method:"GET",header:jest.fn(()=>_),...e}),ko=e=>{let r={writableEnded:!1,statusCode:200,statusMessage:Pt.default.STATUS_CODES[200],set:jest.fn(()=>r),status:jest.fn(t=>(r.statusCode=t,r.statusMessage=Pt.default.STATUS_CODES[t],r)),json:jest.fn(()=>r),end:jest.fn(()=>(r.writableEnded=!0,r)),...e};return r},Tr=async({endpoint:e,requestProps:r,responseProps:t,configProps:o,loggerProps:n,__noJest:i})=>{if(!jest||i)throw new Error("You need to install Jest in order to use testEndpoint().");let a=Lo(r),p=ko(t),l={info:jest.fn(),warn:jest.fn(),error:jest.fn(),debug:jest.fn(),...n},c={cors:!1,logger:l,...o};return await e.execute({request:a,response:p,config:c,logger:l}),{requestMock:a,responseMock:p,loggerMock:l}};var j=b(require("typescript"));var v=b(require("typescript")),s=v.default.factory,le=[s.createModifier(v.default.SyntaxKind.ExportKeyword)],Uo=[s.createModifier(v.default.SyntaxKind.PublicKeyword),s.createModifier(v.default.SyntaxKind.ReadonlyKeyword)],Sr=[s.createModifier(v.default.SyntaxKind.ProtectedKeyword),s.createModifier(v.default.SyntaxKind.ReadonlyKeyword)],Ho=s.createTemplateHead(""),Ko=s.createTemplateTail(""),Fo=s.createTemplateMiddle(" "),Et=e=>s.createTemplateLiteralType(Ho,e.map((r,t)=>s.createTemplateLiteralTypeSpan(s.createTypeReferenceNode(r),t===e.length-1?Ko:Fo))),Zt=Et(["M","P"]),We=(e,r,t)=>s.createParameterDeclaration(t,void 0,e,void 0,r),Qe=(e,r)=>Object.keys(e).reduce((t,o)=>t.concat(We(o,e[o],r)),[]),Rt=(e,r)=>s.createExpressionWithTypeArguments(s.createIdentifier("Record"),[typeof e=="number"?s.createKeywordTypeNode(e):s.createTypeReferenceNode(e),s.createKeywordTypeNode(r)]),Or=e=>s.createConstructorDeclaration(void 0,e,s.createBlock([])),At=(e,r)=>s.createPropertySignature(void 0,`"${e}"`,void 0,s.createTypeReferenceNode(r)),br=(e,r)=>s.createVariableDeclarationList([s.createVariableDeclaration(e,void 0,void 0,r)],v.default.NodeFlags.Const),It=(e,r)=>s.createTypeAliasDeclaration(le,e,void 0,s.createUnionTypeNode(r.map(t=>s.createLiteralTypeNode(s.createStringLiteral(t))))),Xe=(e,r)=>s.createTypeAliasDeclaration(le,e,void 0,r),Pr=(e,r,t)=>s.createPropertyDeclaration(Uo,e,void 0,r,t),Er=(e,r,t=[])=>s.createClassDeclaration(le,e,void 0,void 0,[r,...t]),Zr=(e,r)=>s.createTypeReferenceNode("Promise",[s.createIndexedAccessTypeNode(s.createTypeReferenceNode(e),r)]),Rr=()=>s.createTypeReferenceNode("Promise",[s.createKeywordTypeNode(v.default.SyntaxKind.AnyKeyword)]),Ct=(e,r,t)=>s.createInterfaceDeclaration(le,e,void 0,r,t),Ar=e=>Object.keys(e).reduce((r,t)=>r.concat(s.createTypeParameterDeclaration([],t,s.createTypeReferenceNode(e[t]))),[]),Ir=(e,r)=>s.createArrowFunction(void 0,void 0,e.map(t=>We(t)),void 0,void 0,s.createCallExpression(s.createPropertyAccessExpression(s.createThis(),"implementation"),void 0,r)),Mt=(e,r,t)=>s.createCallExpression(s.createPropertyAccessExpression(s.createCallExpression(s.createPropertyAccessExpression(s.createIdentifier("Object"),"keys"),void 0,[s.createIdentifier(e)]),"reduce"),void 0,[s.createArrowFunction(void 0,void 0,Qe({acc:void 0,key:void 0}),void 0,void 0,r),t]);var f=b(require("typescript")),wr=require("zod");var z=b(require("typescript")),{factory:et}=z.default,Nt=(e,r)=>{z.default.addSyntheticLeadingComment(e,z.default.SyntaxKind.MultiLineCommentTrivia,`* ${r} `,!0)},wt=(e,r,t)=>{let o=et.createTypeAliasDeclaration(void 0,et.createIdentifier(r),void 0,e);return t&&Nt(o,t),o},Cr=(e,r)=>{let t=z.default.createSourceFile("print.ts","",z.default.ScriptTarget.Latest,!1,z.default.ScriptKind.TS);return z.default.createPrinter(r).printNode(z.default.EmitHint.Unspecified,e,t)},_o=/^[A-Za-z_$][A-Za-z0-9_$]*$/,Mr=e=>_o.test(e)?et.createIdentifier(e):et.createStringLiteral(e);var{factory:m}=f.default,$o={[f.default.SyntaxKind.AnyKeyword]:"",[f.default.SyntaxKind.BigIntKeyword]:BigInt(0),[f.default.SyntaxKind.BooleanKeyword]:!1,[f.default.SyntaxKind.NumberKeyword]:0,[f.default.SyntaxKind.ObjectKeyword]:{},[f.default.SyntaxKind.StringKeyword]:"",[f.default.SyntaxKind.UndefinedKeyword]:void 0},Go=({schema:{value:e}})=>m.createLiteralTypeNode(typeof e=="number"?m.createNumericLiteral(e):typeof e=="boolean"?e?m.createTrue():m.createFalse():m.createStringLiteral(e)),qo=({schema:{shape:e},isResponse:r,next:t})=>{let o=Object.entries(e).map(([n,i])=>{let a=r&&xe(i)?i instanceof wr.z.ZodOptional:i.isOptional(),p=m.createPropertySignature(void 0,Mr(n),a?m.createToken(f.default.SyntaxKind.QuestionToken):void 0,t({schema:i}));return i.description&&Nt(p,i.description),p});return m.createTypeLiteralNode(o)},Vo=({schema:{element:e},next:r})=>m.createArrayTypeNode(r({schema:e})),Bo=({schema:{options:e}})=>m.createUnionTypeNode(e.map(r=>m.createLiteralTypeNode(m.createStringLiteral(r)))),Nr=({schema:{options:e},next:r})=>m.createUnionTypeNode(e.map(t=>r({schema:t}))),Yo=e=>$o?.[e.kind],Jo=({schema:e,next:r,isResponse:t})=>{let o=r({schema:e.innerType()}),n=e._def.effect;if(t&&n.type==="transform"){let i=ze({effect:n,sample:Yo(o)}),a={number:f.default.SyntaxKind.NumberKeyword,bigint:f.default.SyntaxKind.BigIntKeyword,boolean:f.default.SyntaxKind.BooleanKeyword,string:f.default.SyntaxKind.StringKeyword,undefined:f.default.SyntaxKind.UndefinedKeyword,object:f.default.SyntaxKind.ObjectKeyword};return m.createKeywordTypeNode(i&&a[i]||f.default.SyntaxKind.AnyKeyword)}return o},Wo=({schema:e})=>m.createUnionTypeNode(Object.values(e.enum).map(r=>m.createLiteralTypeNode(typeof r=="number"?m.createNumericLiteral(r):m.createStringLiteral(r)))),Qo=({next:e,schema:r})=>m.createUnionTypeNode([e({schema:r.unwrap()}),m.createKeywordTypeNode(f.default.SyntaxKind.UndefinedKeyword)]),Xo=({next:e,schema:r})=>m.createUnionTypeNode([e({schema:r.unwrap()}),m.createLiteralTypeNode(m.createNull())]),en=({next:e,schema:{items:r}})=>m.createTupleTypeNode(r.map(t=>e({schema:t}))),tn=({next:e,schema:{keySchema:r,valueSchema:t}})=>m.createExpressionWithTypeArguments(m.createIdentifier("Record"),[e({schema:r}),e({schema:t})]),rn=({next:e,schema:r})=>m.createIntersectionTypeNode([r._def.left,r._def.right].map(t=>e({schema:t}))),on=({next:e,schema:r})=>e({schema:r._def.innerType}),F=e=>()=>m.createKeywordTypeNode(e),nn=({next:e,schema:r})=>e({schema:r.unwrap()}),sn=({next:e,schema:r})=>e({schema:r._def.innerType}),an=({schema:e,next:r,isResponse:t})=>r({schema:e._def[t?"out":"in"]}),pn=()=>m.createLiteralTypeNode(m.createNull()),dn={ZodString:F(f.default.SyntaxKind.StringKeyword),ZodNumber:F(f.default.SyntaxKind.NumberKeyword),ZodBigInt:F(f.default.SyntaxKind.BigIntKeyword),ZodBoolean:F(f.default.SyntaxKind.BooleanKeyword),ZodDateIn:F(f.default.SyntaxKind.StringKeyword),ZodDateOut:F(f.default.SyntaxKind.StringKeyword),ZodNull:pn,ZodArray:Vo,ZodTuple:en,ZodRecord:tn,ZodObject:qo,ZodLiteral:Go,ZodIntersection:rn,ZodUnion:Nr,ZodFile:F(f.default.SyntaxKind.StringKeyword),ZodAny:F(f.default.SyntaxKind.AnyKeyword),ZodDefault:on,ZodEnum:Bo,ZodNativeEnum:Wo,ZodEffects:Jo,ZodOptional:Qo,ZodNullable:Xo,ZodDiscriminatedUnion:Nr,ZodBranded:nn,ZodCatch:sn,ZodPipeline:an},Dt=({schema:e,...r})=>J({schema:e,rules:dn,onMissing:()=>m.createKeywordTypeNode(f.default.SyntaxKind.AnyKeyword),...r});var tt=class{constructor(r){this.agg=[];this.registry={};this.paths=[];Y({routing:r,onEndpoint:(y,O,E)=>{let W=he(O,E,"input"),Q=he(O,E,"response"),Re=Dt({schema:y.getSchema("input"),isResponse:!1}),Ae=Dt({isResponse:!0,schema:y.getSchema("positive").or(y.getSchema("negative"))}),I=wt(Re,W),Ie=wt(Ae,Q);this.agg.push(I),this.agg.push(Ie),E!=="options"&&(this.paths.push(O),this.registry[`${E} ${O}`]={in:W,out:Q,isJson:y.getMimeTypes("positive").includes(_)})}});let t=It("Path",this.paths),o=It("Method",Yt),n=Xe("MethodPath",Et([o.name,t.name])),i=[s.createHeritageClause(j.default.SyntaxKind.ExtendsKeyword,[Rt(n.name,j.default.SyntaxKind.AnyKeyword)])],a=Ct("Input",i,Object.keys(this.registry).map(y=>At(y,this.registry[y].in))),p=Ct("Response",i,Object.keys(this.registry).map(y=>At(y,this.registry[y].out))),l=s.createVariableStatement(le,br("jsonEndpoints",s.createObjectLiteralExpression(Object.keys(this.registry).filter(y=>this.registry[y].isJson).map(y=>s.createPropertyAssignment(`"${y}"`,s.createTrue()))))),c=Xe("Provider",s.createFunctionTypeNode(Ar({M:o.name,P:t.name}),Qe({method:s.createTypeReferenceNode("M"),path:s.createTypeReferenceNode("P"),params:s.createIndexedAccessTypeNode(s.createTypeReferenceNode(a.name),Zt)}),Zr(p.name,Zt))),d=Xe("Implementation",s.createFunctionTypeNode(void 0,Qe({method:s.createTypeReferenceNode(o.name),path:s.createKeywordTypeNode(j.default.SyntaxKind.StringKeyword),params:Rt(j.default.SyntaxKind.StringKeyword,j.default.SyntaxKind.AnyKeyword)}),Rr())),u=s.createTemplateExpression(s.createTemplateHead(":"),[s.createTemplateSpan(s.createIdentifier("key"),s.createTemplateTail(""))]),h=Er("ExpressZodAPIClient",Or([We("implementation",s.createTypeReferenceNode(d.name),Sr)]),[Pr("provide",s.createTypeReferenceNode(c.name),Ir(["method","path","params"],[s.createIdentifier("method"),Mt("params",s.createCallExpression(s.createPropertyAccessExpression(s.createIdentifier("acc"),"replace"),void 0,[u,s.createElementAccessExpression(s.createIdentifier("params"),s.createIdentifier("key"))]),s.createIdentifier("path")),Mt("params",s.createConditionalExpression(s.createBinaryExpression(s.createCallExpression(s.createPropertyAccessExpression(s.createIdentifier("path"),"indexOf"),void 0,[u]),j.default.SyntaxKind.GreaterThanEqualsToken,s.createNumericLiteral(0)),void 0,s.createIdentifier("acc"),void 0,s.createObjectLiteralExpression([s.createSpreadAssignment(s.createIdentifier("acc")),s.createPropertyAssignment("[key]",s.createElementAccessExpression(s.createIdentifier("params"),s.createIdentifier("key")))])),s.createObjectLiteralExpression())]))]);j.default.addSyntheticLeadingComment(h,j.default.SyntaxKind.MultiLineCommentTrivia,`
34
+ export const exampleImplementation: Implementation = async (
35
+ method,
36
+ path,
37
+ params
38
+ ) => {
39
+ const searchParams =
40
+ method === "get" ? \`?\${new URLSearchParams(params)}\` : "";
41
+ const response = await fetch(\`https://example.com\${path}\${searchParams}\`, {
42
+ method: method.toUpperCase(),
43
+ headers:
44
+ method === "get" ? undefined : { "Content-Type": "application/json" },
45
+ body: method === "get" ? undefined : JSON.stringify(params),
46
+ });
47
+ if (\`\${method} \${path}\` in jsonEndpoints) {
48
+ return response.json();
49
+ }
50
+ return response.text();
24
51
  };
25
- var __importDefault = (this && this.__importDefault) || function (mod) {
26
- return (mod && mod.__esModule) ? mod : { "default": mod };
27
- };
28
- Object.defineProperty(exports, "__esModule", { value: true });
29
- exports.z = exports.createHttpError = exports.Client = exports.testEndpoint = exports.withMeta = exports.InputValidationError = exports.OutputValidationError = exports.RoutingError = exports.DependsOnMethodError = exports.OpenAPIError = exports.OpenAPI = exports.attachRouting = exports.createServer = exports.ServeStatic = exports.DependsOnMethod = exports.defaultResultHandler = exports.createResultHandler = exports.createMiddleware = exports.createLogger = exports.getStatusCodeFromError = exports.getMessageFromError = exports.defaultEndpointsFactory = exports.EndpointsFactory = exports.AbstractEndpoint = exports.createConfig = void 0;
30
- var config_type_1 = require("./config-type");
31
- Object.defineProperty(exports, "createConfig", { enumerable: true, get: function () { return config_type_1.createConfig; } });
32
- var endpoint_1 = require("./endpoint");
33
- Object.defineProperty(exports, "AbstractEndpoint", { enumerable: true, get: function () { return endpoint_1.AbstractEndpoint; } });
34
- var endpoints_factory_1 = require("./endpoints-factory");
35
- Object.defineProperty(exports, "EndpointsFactory", { enumerable: true, get: function () { return endpoints_factory_1.EndpointsFactory; } });
36
- Object.defineProperty(exports, "defaultEndpointsFactory", { enumerable: true, get: function () { return endpoints_factory_1.defaultEndpointsFactory; } });
37
- var common_helpers_1 = require("./common-helpers");
38
- Object.defineProperty(exports, "getMessageFromError", { enumerable: true, get: function () { return common_helpers_1.getMessageFromError; } });
39
- Object.defineProperty(exports, "getStatusCodeFromError", { enumerable: true, get: function () { return common_helpers_1.getStatusCodeFromError; } });
40
- var logger_1 = require("./logger");
41
- Object.defineProperty(exports, "createLogger", { enumerable: true, get: function () { return logger_1.createLogger; } });
42
- var middleware_1 = require("./middleware");
43
- Object.defineProperty(exports, "createMiddleware", { enumerable: true, get: function () { return middleware_1.createMiddleware; } });
44
- var result_handler_1 = require("./result-handler");
45
- Object.defineProperty(exports, "createResultHandler", { enumerable: true, get: function () { return result_handler_1.createResultHandler; } });
46
- Object.defineProperty(exports, "defaultResultHandler", { enumerable: true, get: function () { return result_handler_1.defaultResultHandler; } });
47
- var depends_on_method_1 = require("./depends-on-method");
48
- Object.defineProperty(exports, "DependsOnMethod", { enumerable: true, get: function () { return depends_on_method_1.DependsOnMethod; } });
49
- var serve_static_1 = require("./serve-static");
50
- Object.defineProperty(exports, "ServeStatic", { enumerable: true, get: function () { return serve_static_1.ServeStatic; } });
51
- var server_1 = require("./server");
52
- Object.defineProperty(exports, "createServer", { enumerable: true, get: function () { return server_1.createServer; } });
53
- Object.defineProperty(exports, "attachRouting", { enumerable: true, get: function () { return server_1.attachRouting; } });
54
- var open_api_1 = require("./open-api");
55
- Object.defineProperty(exports, "OpenAPI", { enumerable: true, get: function () { return open_api_1.OpenAPI; } });
56
- var errors_1 = require("./errors");
57
- Object.defineProperty(exports, "OpenAPIError", { enumerable: true, get: function () { return errors_1.OpenAPIError; } });
58
- Object.defineProperty(exports, "DependsOnMethodError", { enumerable: true, get: function () { return errors_1.DependsOnMethodError; } });
59
- Object.defineProperty(exports, "RoutingError", { enumerable: true, get: function () { return errors_1.RoutingError; } });
60
- Object.defineProperty(exports, "OutputValidationError", { enumerable: true, get: function () { return errors_1.OutputValidationError; } });
61
- Object.defineProperty(exports, "InputValidationError", { enumerable: true, get: function () { return errors_1.InputValidationError; } });
62
- var metadata_1 = require("./metadata");
63
- Object.defineProperty(exports, "withMeta", { enumerable: true, get: function () { return metadata_1.withMeta; } });
64
- var mock_1 = require("./mock");
65
- Object.defineProperty(exports, "testEndpoint", { enumerable: true, get: function () { return mock_1.testEndpoint; } });
66
- var client_1 = require("./client");
67
- Object.defineProperty(exports, "Client", { enumerable: true, get: function () { return client_1.Client; } });
68
- const z = __importStar(require("./extend-zod"));
69
- exports.z = z;
70
- const http_errors_1 = __importDefault(require("http-errors"));
71
- exports.createHttpError = http_errors_1.default;
52
+
53
+ const client = new ExpressZodAPIClient(exampleImplementation);
54
+ client.provide("get", "/v1/user/retrieve", { id: "10" });
55
+ `,!0),this.agg.push(t,o,n,a,p,l,c,d,h)}print(r){return this.agg.map(t=>Cr(t,r)).join(`
56
+
57
+ `)}};var P=require("zod");var cn="ZodDateOut",vt=class extends P.ZodType{_parse(r){let{status:t,ctx:o}=this._processInputParams(r);return o.parsedType!==P.ZodParsedType.date?((0,P.addIssueToContext)(o,{code:P.ZodIssueCode.invalid_type,expected:P.ZodParsedType.date,received:o.parsedType}),P.INVALID):we(o.data)?{status:t.value,value:o.data.toISOString()}:((0,P.addIssueToContext)(o,{code:P.ZodIssueCode.invalid_date}),P.INVALID)}},Pe=vt;Pe.create=()=>new vt({typeName:cn});var Z=require("zod");var ln="ZodFile",mn=/^(?:[A-Za-z0-9+/]{4})*(?:[A-Za-z0-9+/]{2}==|[A-Za-z0-9+/]{3}=)?$/,Ze=class extends Z.ZodType{constructor(){super(...arguments);this.binary=t=>new Ze({...this._def,checks:[...this._def.checks,{kind:"binary",...ct(t)}]});this.base64=t=>new Ze({...this._def,checks:[...this._def.checks,{kind:"base64",...ct(t)}]})}_parse(t){let{status:o,ctx:n}=this._processInputParams(t);if(n.parsedType!==Z.ZodParsedType.string)return(0,Z.addIssueToContext)(n,{code:Z.ZodIssueCode.invalid_type,expected:Z.ZodParsedType.string,received:n.parsedType}),Z.INVALID;for(let i of this._def.checks)i.kind==="base64"&&(mn.test(n.data)||((0,Z.addIssueToContext)(n,{code:Z.ZodIssueCode.custom,message:i.message}),o.dirty()));return{status:o.value,value:n.data}}get isBinary(){return!!this._def.checks.find(t=>t.kind==="binary")}get isBase64(){return!!this._def.checks.find(t=>t.kind==="base64")}},Ee=Ze;Ee.create=()=>new Ze({checks:[],typeName:ln});var rt;(n=>(n.file=Ee.create,n.upload=$.create,n.dateIn=Oe.create,n.dateOut=Pe.create))(rt||(rt={}));var Dr=b(require("http-errors"));0&&(module.exports={AbstractEndpoint,Client,DependsOnMethod,DependsOnMethodError,EndpointsFactory,InputValidationError,OpenAPI,OpenAPIError,OutputValidationError,RoutingError,ServeStatic,attachRouting,createConfig,createHttpError,createLogger,createMiddleware,createResultHandler,createServer,defaultEndpointsFactory,defaultResultHandler,ez,getMessageFromError,getStatusCodeFromError,testEndpoint,withMeta});
72
58
  //# sourceMappingURL=index.js.map