express-zod-api 22.4.0 → 22.4.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/CHANGELOG.md CHANGED
@@ -2,6 +2,33 @@
2
2
 
3
3
  ## Version 22
4
4
 
5
+ ### v22.4.1
6
+
7
+ - Fixed a bug that could lead to duplicate properties in generated client types:
8
+ - If the middleware and/or endpoint schemas had the same property, it was duplicated by Integration.
9
+ - The issue was introduced in [v20.15.3](#v20153) and reported by [@bobgubko](https://github.com/bobgubko).
10
+
11
+ ```ts
12
+ // reproduction
13
+ factory
14
+ .addMiddleware({
15
+ input: z.object({ query: z.string() }), // ...
16
+ })
17
+ .build({
18
+ input: z.object({ query: z.string() }), // ...
19
+ });
20
+ ```
21
+
22
+ ```ts
23
+ type Before = {
24
+ query: string;
25
+ query: string; // <— bug #2352
26
+ };
27
+ type After = {
28
+ query: string;
29
+ };
30
+ ```
31
+
5
32
  ### v22.4.0
6
33
 
7
34
  - Feat: ability to supply extra data to a custom implementation of the generated client:
package/README.md CHANGED
@@ -86,8 +86,8 @@ Therefore, many basic tasks can be accomplished faster and easier, in particular
86
86
 
87
87
  These people contributed to the improvement of the framework by reporting bugs, making changes and suggesting ideas:
88
88
 
89
- [<img src="https://github.com/LucWag.png" alt="@LucWag" width="50px" />](https://github.com/LucWag)
90
89
  [<img src="https://github.com/bobgubko.png" alt="@bobgubko" width="50px" />](https://github.com/bobgubko)
90
+ [<img src="https://github.com/LucWag.png" alt="@LucWag" width="50px" />](https://github.com/LucWag)
91
91
  [<img src="https://github.com/HenriJ.png" alt="@HenriJ" width="50px" />](https://github.com/HenriJ)
92
92
  [<img src="https://github.com/JonParton.png" alt="@JonParton" width="50px" />](https://github.com/JonParton)
93
93
  [<img src="https://github.com/williamgcampbell.png" alt="@williamgcampbell" width="50px" />](https://github.com/williamgcampbell)
package/dist/index.cjs CHANGED
@@ -1,6 +1,6 @@
1
- "use strict";var Bo=Object.create;var Xe=Object.defineProperty;var $o=Object.getOwnPropertyDescriptor;var Vo=Object.getOwnPropertyNames;var _o=Object.getPrototypeOf,Go=Object.prototype.hasOwnProperty;var Jo=(e,t)=>{for(var r in t)Xe(e,r,{get:t[r],enumerable:!0})},yr=(e,t,r,o)=>{if(t&&typeof t=="object"||typeof t=="function")for(let n of Vo(t))!Go.call(e,n)&&n!==r&&Xe(e,n,{get:()=>t[n],enumerable:!(o=$o(t,n))||o.enumerable});return e};var U=(e,t,r)=>(r=e!=null?Bo(_o(e)):{},yr(t||!e||!e.__esModule?Xe(r,"default",{value:e,enumerable:!0}):r,e)),Yo=e=>yr(Xe({},"__esModule",{value:!0}),e);var Ls={};Jo(Ls,{BuiltinLogger:()=>Le,DependsOnMethod:()=>je,Documentation:()=>xt,DocumentationError:()=>D,EndpointsFactory:()=>ie,EventStreamFactory:()=>Ct,InputValidationError:()=>V,Integration:()=>Zt,Middleware:()=>q,MissingPeerError:()=>Pe,OutputValidationError:()=>X,ResultHandler:()=>se,RoutingError:()=>de,ServeStatic:()=>Me,arrayEndpointsFactory:()=>Cr,arrayResultHandler:()=>ut,attachRouting:()=>ao,createConfig:()=>hr,createServer:()=>po,defaultEndpointsFactory:()=>Zr,defaultResultHandler:()=>ke,ensureHttpError:()=>ge,ez:()=>qo,getExamples:()=>Y,getMessageFromError:()=>te,testEndpoint:()=>ko,testMiddleware:()=>No});module.exports=Yo(Ls);var K=require("ramda"),ue=require("zod");var me=require("ramda"),fr=require("zod");var I={json:"application/json",upload:"multipart/form-data",raw:"application/octet-stream",sse:"text/event-stream"};var de=class extends Error{name="RoutingError"},D=class extends Error{name="DocumentationError";cause;constructor(t,{method:r,path:o,isResponse:n}){super(t),this.cause=`${n?"Response":"Input"} schema of an Endpoint assigned to ${r.toUpperCase()} method of ${o} path.`}},et=class extends Error{name="IOSchemaError"},X=class extends et{constructor(r){super(te(r),{cause:r});this.cause=r}name="OutputValidationError"},V=class extends et{constructor(r){super(te(r),{cause:r});this.cause=r}name="InputValidationError"},ee=class extends Error{constructor(r,o){super(te(r),{cause:r});this.cause=r;this.handled=o}name="ResultHandlerError"},Pe=class extends Error{name="MissingPeerError";constructor(t){super(`Missing peer dependency: ${t}. Please install it to use the feature.`)}};var Wo=e=>{let r=(e.header("content-type")||"").toLowerCase().startsWith(I.upload);return"files"in e&&r},jt={get:["query","params"],post:["body","params","files"],put:["body","params"],patch:["body","params"],delete:["query","params"]},Qo=["body","query","params"],Ut=e=>e.method.toLowerCase(),tt=(e,t={})=>{let r=Ut(e);return r==="options"?{}:(t[r]||jt[r]||Qo).filter(o=>o==="files"?Wo(e):!0).reduce((o,n)=>Object.assign(o,e[n]),{})},re=e=>e instanceof Error?e:new Error(String(e)),te=e=>e instanceof fr.z.ZodError?e.issues.map(({path:t,message:r})=>(t.length?[t.join("/")]:[]).concat(r).join(": ")).join("; "):e instanceof X?`output${e.cause.issues[0]?.path.length>0?"/":": "}${e.message}`:e.message,Y=({schema:e,variant:t="original",validate:r=t==="parsed"})=>{let o=e._def[b]?.examples||[];if(!r&&t==="original")return o;let n=[];for(let i of o){let a=e.safeParse(i);a.success&&n.push(t==="parsed"?a.data:i)}return n},Ae=(e,t,r)=>e.length&&t.length?(0,me.xprod)(e,t).map(r):e.concat(t),Fe=e=>"coerce"in e._def&&typeof e._def.coerce=="boolean"?e._def.coerce:!1,Mt=e=>e.charAt(0).toUpperCase()+e.slice(1).toLowerCase(),oe=(...e)=>{let t=(0,me.chain)(o=>o.split(/[^A-Z0-9]/gi),e);return(0,me.chain)(o=>o.replaceAll(/[A-Z]+/g,n=>`/${n}`).split("/"),t).map(Mt).join("")},rt=(e,t)=>{try{return typeof e.parse(t)}catch{return}},le=e=>typeof e=="object"&&e!==null,we=(0,me.memoizeWith)(()=>"static",()=>process.env.NODE_ENV==="production"),ot=e=>e.length?e:void 0;var nt=require("ramda"),b=Symbol.for("express-zod-api"),st=e=>{let t=e.describe(e.description);return t._def[b]=(0,nt.clone)(t._def[b])||{examples:[]},t},gr=(e,t)=>{if(!(b in e._def))return t;let r=st(t);return r._def[b].examples=Ae(r._def[b].examples,e._def[b].examples,([o,n])=>typeof o=="object"&&typeof n=="object"?(0,nt.mergeDeepRight)({...o},{...n}):n),r};var Xo=function(e){let t=st(this);return t._def[b].examples.push(e),t},en=function(e){let t=st(this);return t._def[b].defaultLabel=e,t},tn=function(e){return new ue.z.ZodBranded({typeName:ue.z.ZodFirstPartyTypeKind.ZodBranded,type:this,description:this._def.description,errorMap:this._def.errorMap,[b]:{examples:[],...(0,K.clone)(this._def[b]),brand:e}})},rn=function(e){let t=typeof e=="function"?e:(0,K.pipe)(K.toPairs,(0,K.map)(([n,i])=>(0,K.pair)(e[String(n)]||n,i)),K.fromPairs),r=t((0,K.clone)(this.shape)),o=ue.z.object(r)[this._def.unknownKeys]();return this.transform(t).pipe(o)};b in globalThis||(globalThis[b]=!0,Object.defineProperties(ue.z.ZodType.prototype,{example:{get(){return Xo.bind(this)}},brand:{set(){},get(){return tn.bind(this)}}}),Object.defineProperty(ue.z.ZodDefault.prototype,"label",{get(){return en.bind(this)}}),Object.defineProperty(ue.z.ZodObject.prototype,"remap",{get(){return rn.bind(this)}}));function hr(e){return e}var Vt=require("zod");var Bt=require("zod");var C=require("node:assert/strict");var Ee=require("zod");var it=e=>!isNaN(e.getTime());var ye=Symbol("DateIn"),xr=()=>Ee.z.union([Ee.z.string().date(),Ee.z.string().datetime(),Ee.z.string().datetime({local:!0})]).transform(t=>new Date(t)).pipe(Ee.z.date().refine(it)).brand(ye);var br=require("zod");var fe=Symbol("DateOut"),Sr=()=>br.z.date().refine(it).transform(e=>e.toISOString()).brand(fe);var qe=require("zod"),_=Symbol("File"),Tr=qe.z.custom(e=>Buffer.isBuffer(e),{message:"Expected Buffer"}),on={buffer:()=>Tr.brand(_),string:()=>qe.z.string().brand(_),binary:()=>Tr.or(qe.z.string()).brand(_),base64:()=>qe.z.string().base64().brand(_)};function at(e){return on[e||"string"]()}var Or=require("zod");var ne=Symbol("Raw"),Rr=(e={})=>Or.z.object({raw:at("buffer")}).extend(e).brand(ne);var Pr=require("zod"),Ie=Symbol("Upload"),Ar=()=>Pr.z.custom(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.encoding=="string"&&typeof e.mimetype=="string"&&Buffer.isBuffer(e.data)&&typeof e.tempFilePath=="string"&&typeof e.truncated=="boolean"&&typeof e.size=="number"&&typeof e.md5=="string"&&typeof e.mv=="function",e=>({message:`Expected file upload, received ${typeof e}`})).brand(Ie);var wr=(e,{next:t})=>e.options.some(t),nn=({_def:e},{next:t})=>[e.left,e.right].some(t),pt=(e,{next:t})=>t(e.unwrap()),Kt={ZodObject:({shape:e},{next:t})=>Object.values(e).some(t),ZodUnion:wr,ZodDiscriminatedUnion:wr,ZodIntersection:nn,ZodEffects:(e,{next:t})=>t(e.innerType()),ZodOptional:pt,ZodNullable:pt,ZodRecord:({valueSchema:e},{next:t})=>t(e),ZodArray:({element:e},{next:t})=>t(e),ZodDefault:({_def:e},{next:t})=>t(e.innerType)},ct=(e,{condition:t,rules:r=Kt,depth:o=1,maxDepth:n=Number.POSITIVE_INFINITY})=>{if(t?.(e))return!0;let i=o<n?r[e._def[b]?.brand]||r[e._def.typeName]:void 0;return i?i(e,{next:a=>ct(a,{condition:t,rules:r,maxDepth:n,depth:o+1})}):!1},Er=e=>ct(e,{condition:t=>t._def[b]?.brand===Ie}),Ir=e=>ct(e,{condition:t=>t._def[b]?.brand===ne,maxDepth:3}),Ht=(e,t)=>{let r=new WeakSet;return ct(e,{maxDepth:300,rules:{...Kt,ZodBranded:pt,ZodReadonly:pt,ZodCatch:({_def:{innerType:o}},{next:n})=>n(o),ZodPipeline:({_def:o},{next:n})=>n(o[t]),ZodLazy:(o,{next:n})=>r.has(o)?!1:r.add(o)&&n(o.schema),ZodTuple:({items:o,_def:{rest:n}},{next:i})=>[...o].concat(n??[]).some(i),ZodEffects:{out:void 0,in:Kt.ZodEffects}[t],ZodNaN:()=>(0,C.fail)("z.nan()"),ZodSymbol:()=>(0,C.fail)("z.symbol()"),ZodFunction:()=>(0,C.fail)("z.function()"),ZodMap:()=>(0,C.fail)("z.map()"),ZodSet:()=>(0,C.fail)("z.set()"),ZodBigInt:()=>(0,C.fail)("z.bigint()"),ZodVoid:()=>(0,C.fail)("z.void()"),ZodPromise:()=>(0,C.fail)("z.promise()"),ZodNever:()=>(0,C.fail)("z.never()"),ZodDate:()=>t==="in"&&(0,C.fail)("z.date()"),[fe]:()=>t==="in"&&(0,C.fail)("ez.dateOut()"),[ye]:()=>t==="out"&&(0,C.fail)("ez.dateIn()"),[ne]:()=>t==="out"&&(0,C.fail)("ez.raw()"),[Ie]:()=>t==="out"&&(0,C.fail)("ez.upload()"),[_]:()=>!1}})};var dt=U(require("http-errors"),1);var Be=U(require("http-errors"),1),zr=require("zod");var Dt=(e,{variant:t,args:r,...o})=>{if(typeof e=="function"&&(e=e(...r)),e instanceof zr.z.ZodType)return[{schema:e,...o}];if(Array.isArray(e)&&!e.length){let n=new Error(`At least one ${t} response schema required.`);throw new ee(n)}return(Array.isArray(e)?e:[e]).map(({schema:n,statusCode:i,mimeType:a})=>({schema:n,statusCodes:typeof i=="number"?[i]:i||o.statusCodes,mimeTypes:typeof a=="string"?[a]:a===void 0?o.mimeTypes:a}))},$e=(e,t,{url:r},o)=>!e.expose&&t.error("Server side error",{error:e,url:r,payload:o}),ge=e=>(0,Be.isHttpError)(e)?e:(0,Be.default)(e instanceof V?400:500,te(e),{cause:e.cause||e}),he=e=>we()&&!e.expose?(0,Be.default)(e.statusCode).message:e.message;var mt=({error:e,logger:t,response:r})=>{t.error("Result handler failure",e);let o=he((0,dt.default)(500,`An error occurred while serving the result: ${e.message}.`+(e.handled?`
2
- Original error: ${e.handled.message}.`:""),{expose:(0,dt.isHttpError)(e.cause)?e.cause.expose:!1}));r.status(500).type("text/plain").end(o)};var Ft=require("zod");var qt=class{},q=class extends qt{#e;#t;#r;constructor({input:t=Ft.z.object({}),security:r,handler:o}){super(),this.#e=t,this.#t=r,this.#r=o}getSecurity(){return this.#t}getSchema(){return this.#e}async execute({input:t,...r}){try{let o=await this.#e.parseAsync(t);return this.#r({...r,input:o})}catch(o){throw o instanceof Ft.z.ZodError?new V(o):o}}},ze=class extends q{constructor(t,{provider:r=()=>({}),transformer:o=n=>n}={}){super({handler:async({request:n,response:i})=>new Promise((a,c)=>{let d=p=>{if(p&&p instanceof Error)return c(o(p));a(r(n,i))};t(n,i,d)?.catch(d)})})}};var ve=class{nest(t){return Object.assign(t,{"":this})}};var Ve=class extends ve{},lt=class extends Ve{#e;#t;#r;#n;#s;#i;#o;#a;#p;#c;#d;constructor({methods:t,inputSchema:r,outputSchema:o,handler:n,resultHandler:i,getOperationId:a=()=>{},scopes:c=[],middlewares:d=[],tags:p=[],description:l,shortDescription:h}){super(),this.#s=n,this.#i=i,this.#r=d,this.#c=a,this.#t=Object.freeze(t),this.#a=Object.freeze(c),this.#p=Object.freeze(p),this.#e={long:l,short:h},this.#o={input:r,output:o},this.#n={positive:Object.freeze(i.getPositiveResponse(o)),negative:Object.freeze(i.getNegativeResponse())},this.#d=Er(r)?"upload":Ir(r)?"raw":"json"}getDescription(t){return this.#e[t]}getMethods(){return this.#t}getSchema(t){return this.#o[t]}getRequestType(){return this.#d}getResponses(t){return this.#n[t]}getSecurity(){return this.#r.map(t=>t.getSecurity()).filter(t=>t!==void 0)}getScopes(){return this.#a}getTags(){return this.#p}getOperationId(t){return this.#c(t)}async#m(t){try{return await this.#o.output.parseAsync(t)}catch(r){throw r instanceof Bt.z.ZodError?new X(r):r}}async#l({method:t,logger:r,options:o,response:n,...i}){for(let a of this.#r)if(!(t==="options"&&!(a instanceof ze))&&(Object.assign(o,await a.execute({...i,options:o,response:n,logger:r})),n.writableEnded)){r.warn("A middleware has closed the stream. Accumulated options:",o);break}}async#u({input:t,...r}){let o;try{o=await this.#o.input.parseAsync(t)}catch(n){throw n instanceof Bt.z.ZodError?new V(n):n}return this.#s({...r,input:o})}async#y({error:t,...r}){try{await this.#i.execute({...r,error:t})}catch(o){mt({...r,error:new ee(re(o),t||void 0)})}}async execute({request:t,response:r,logger:o,config:n}){let i=Ut(t),a={},c=null,d=null,p=tt(t,n.inputSources);try{if(await this.#l({method:i,input:p,request:t,response:r,logger:o,options:a}),r.writableEnded)return;if(i==="options")return void r.status(200).end();c=await this.#m(await this.#u({input:p,logger:o,options:a}))}catch(l){d=re(l)}await this.#y({input:p,output:c,request:t,response:r,error:d,logger:o,options:a})}};var vr=(e,t)=>{let r=e.map(n=>n.getSchema()).concat(t),o=r.reduce((n,i)=>n.and(i));return r.reduce((n,i)=>gr(i,n),o)};var B=require("zod");var Ze={positive:200,negative:400},Ce=Object.keys(Ze);var $t=class{#e;constructor(t){this.#e=t}execute(...t){return this.#e(...t)}},se=class extends $t{#e;#t;constructor(t){super(t.handler),this.#e=t.positive,this.#t=t.negative}getPositiveResponse(t){return Dt(this.#e,{variant:"positive",args:[t],statusCodes:[Ze.positive],mimeTypes:[I.json]})}getNegativeResponse(){return Dt(this.#t,{variant:"negative",args:[],statusCodes:[Ze.negative],mimeTypes:[I.json]})}},ke=new se({positive:e=>{let t=Y({schema:e}),r=B.z.object({status:B.z.literal("success"),data:e});return t.reduce((o,n)=>o.example({status:"success",data:n}),r)},negative:B.z.object({status:B.z.literal("error"),error:B.z.object({message:B.z.string()})}).example({status:"error",error:{message:"Sample error message"}}),handler:({error:e,input:t,output:r,request:o,response:n,logger:i})=>{if(e){let a=ge(e);return $e(a,i,o,t),void n.status(a.statusCode).json({status:"error",error:{message:he(a)}})}n.status(Ze.positive).json({status:"success",data:r})}}),ut=new se({positive:e=>{let t=Y({schema:e}),r="shape"in e&&"items"in e.shape&&e.shape.items instanceof B.z.ZodArray?e.shape.items:B.z.array(B.z.any());return t.reduce((o,n)=>le(n)&&"items"in n&&Array.isArray(n.items)?o.example(n.items):o,r)},negative:B.z.string().example("Sample error message"),handler:({response:e,output:t,error:r,logger:o,request:n,input:i})=>{if(r){let a=ge(r);return $e(a,o,n,i),void e.status(a.statusCode).type("text/plain").send(he(a))}if(t&&"items"in t&&Array.isArray(t.items))return void e.status(Ze.positive).json(t.items);throw new Error("Property 'items' is missing in the endpoint output")}});var ie=class e{constructor(t){this.resultHandler=t}middlewares=[];static#e(t,r){let o=new e(r);return o.middlewares=t,o}addMiddleware(t){return e.#e(this.middlewares.concat(t instanceof q?t:new q(t)),this.resultHandler)}use=this.addExpressMiddleware;addExpressMiddleware(...t){return e.#e(this.middlewares.concat(new ze(...t)),this.resultHandler)}addOptions(t){return e.#e(this.middlewares.concat(new q({handler:t})),this.resultHandler)}build({input:t=Vt.z.object({}),handler:r,output:o,description:n,shortDescription:i,operationId:a,scope:c,tag:d,method:p}){let{middlewares:l,resultHandler:h}=this,S=typeof p=="string"?[p]:p,g=typeof a=="function"?a:()=>a,A=typeof c=="string"?[c]:c||[],R=typeof d=="string"?[d]:d||[];return new lt({handler:r,middlewares:l,outputSchema:o,resultHandler:h,scopes:A,tags:R,methods:S,getOperationId:g,description:n,shortDescription:i,inputSchema:vr(l,t)})}buildVoid({handler:t,...r}){return this.build({...r,output:Vt.z.object({}),handler:async o=>(await t(o),{})})}},Zr=new ie(ke),Cr=new ie(ut);var Mr=U(require("ansis"),1),Kr=require("node:util"),Gt=require("node:perf_hooks");var G=require("ansis"),kr=require("ramda");var _t={debug:G.blue,info:G.green,warn:(0,G.hex)("#FFA500"),error:G.red,ctx:G.cyanBright},yt={debug:10,info:20,warn:30,error:40},Nr=e=>le(e)&&Object.keys(yt).some(t=>t in e),Lr=e=>e in yt,jr=(e,t)=>yt[e]<yt[t],sn=(e,t=0)=>Intl.NumberFormat(void 0,{useGrouping:!1,minimumFractionDigits:0,maximumFractionDigits:t,style:"unit",unitDisplay:"long",unit:e}),Ne=(0,kr.memoizeWith)((e,t)=>`${e}${t}`,sn),Ur=e=>e<1e-6?Ne("nanosecond",3).format(e/1e-6):e<.001?Ne("nanosecond").format(e/1e-6):e<1?Ne("microsecond").format(e/.001):e<1e3?Ne("millisecond").format(e):e<6e4?Ne("second",2).format(e/1e3):Ne("minute",2).format(e/6e4);var Le=class e{config;constructor({color:t=Mr.default.isSupported(),level:r=we()?"warn":"debug",depth:o=2,ctx:n={}}={}){this.config={color:t,level:r,depth:o,ctx:n}}prettyPrint(t){let{depth:r,color:o,level:n}=this.config;return(0,Kr.inspect)(t,{depth:r,colors:o,breakLength:n==="debug"?80:1/0,compact:n==="debug"?3:!0})}print(t,r,o){let{level:n,ctx:{requestId:i,...a},color:c}=this.config;if(n==="silent"||jr(t,n))return;let d=[new Date().toISOString()];i&&d.push(c?_t.ctx(i):i),d.push(c?`${_t[t](t)}:`:`${t}:`,r),o!==void 0&&d.push(this.prettyPrint(o)),Object.keys(a).length>0&&d.push(this.prettyPrint(a)),console.log(d.join(" "))}debug(t,r){this.print("debug",t,r)}info(t,r){this.print("info",t,r)}warn(t,r){this.print("warn",t,r)}error(t,r){this.print("error",t,r)}child(t){return new e({...this.config,ctx:t})}get ctx(){return this.config.ctx}profile(t){let r=Gt.performance.now();return()=>{let o=Gt.performance.now()-r,{message:n,severity:i="debug",formatter:a=Ur}=typeof t=="object"?t:{message:t};this.print(typeof i=="function"?i(o):i,n,a(o))}}};var Ue=require("ramda");var je=class extends ve{entries;constructor(t){super();let r=[],o=(0,Ue.keys)(t);for(let n of o){let i=t[n];i&&r.push([n,i,(0,Ue.reject)((0,Ue.equals)(n),o)])}this.entries=Object.freeze(r)}};var Hr=U(require("express"),1),Me=class{params;constructor(...t){this.params=t}apply(t,r){return r(t,Hr.default.static(...this.params))}};var gt=U(require("express"),1),no=U(require("node:http"),1),so=U(require("node:https"),1);var Ke=async(e,t="default")=>{try{return(await Promise.resolve().then(()=>U(require(e))))[t]}catch{}throw new Pe(e)};var ft=class{constructor(t){this.logger=t}#e=new WeakSet;check(t,r){if(!this.#e.has(t)){if(t.getRequestType()==="json")try{Ht(t.getSchema("input"),"in")}catch(o){this.logger.warn("The final input schema of the endpoint contains an unsupported JSON payload type.",Object.assign(r,{reason:o}))}for(let o of Ce)for(let{mimeTypes:n,schema:i}of t.getResponses(o))if(n?.includes(I.json))try{Ht(i,"out")}catch(a){this.logger.warn(`The final ${o} response schema of the endpoint contains an unsupported JSON payload type.`,Object.assign(r,{reason:a}))}this.#e.add(t)}}};var Dr=(e,t)=>Object.entries(e).map(([r,o])=>{if(r.includes("/"))throw new de(`The entry '${r}' must avoid having slashes \u2014 use nesting instead.`);let n=r.trim();return[`${t||""}${n?`/${n}`:""}`,o]}),He=({routing:e,onEndpoint:t,onStatic:r})=>{let o=Dr(e);for(;o.length;){let[n,i]=o.shift();if(i instanceof Ve){let a=i.getMethods()||["get"];for(let c of a)t(i,n,c)}else if(i instanceof Me)r&&i.apply(n,r);else if(i instanceof je)for(let[a,c,d]of i.entries){let p=c.getMethods();if(p&&!p.includes(a))throw new de(`Endpoint assigned to ${a} method of ${n} must support ${a} method.`);t(c,n,a,d)}else o.unshift(...Dr(i,n))}};var Jt=({app:e,getLogger:t,config:r,routing:o,parsers:n})=>{let i=new ft(t()),a=new Set;He({routing:o,onEndpoint:(d,p,l,h)=>{we()||i.check(d,{path:p,method:l});let S=n?.[d.getRequestType()]||[],g=async(A,R)=>{let N=t(A);if(r.cors){let P={"Access-Control-Allow-Origin":"*","Access-Control-Allow-Methods":[l,...h||[],"options"].join(", ").toUpperCase(),"Access-Control-Allow-Headers":"content-type"},j=typeof r.cors=="function"?await r.cors({request:A,endpoint:d,logger:N,defaultHeaders:P}):P;for(let z in j)R.set(z,j[z])}return d.execute({request:A,response:R,logger:N,config:r})};r.cors&&!a.has(p)&&(e.options(p,...S,g),a.add(p)),e[l](p,...S,g)},onStatic:e.use.bind(e)})};var _e=U(require("http-errors"),1);var _r=require("node:timers/promises");var Fr=e=>"_httpMessage"in e&&typeof e._httpMessage=="object"&&e._httpMessage!==null&&"headersSent"in e._httpMessage&&typeof e._httpMessage.headersSent=="boolean"&&"setHeader"in e._httpMessage&&typeof e._httpMessage.setHeader=="function",qr=e=>"server"in e&&typeof e.server=="object"&&e.server!==null&&"close"in e.server&&typeof e.server.close=="function",Br=e=>"encrypted"in e&&typeof e.encrypted=="boolean"&&e.encrypted,$r=({},e)=>void(!e.headersSent&&e.setHeader("connection","close")),Vr=e=>new Promise((t,r)=>void e.close(o=>o?r(o):t()));var Gr=(e,{timeout:t=1e3,logger:r}={})=>{let o,n=new Set,i=p=>void n.delete(p.destroy()),a=p=>void(Fr(p)?!p._httpMessage.headersSent&&p._httpMessage.setHeader("connection","close"):i(p)),c=p=>void(o?p.destroy():n.add(p.once("close",()=>void n.delete(p))));for(let p of e)for(let l of["connection","secureConnection"])p.on(l,c);let d=async()=>{for(let p of e)p.on("request",$r);r?.info("Graceful shutdown",{sockets:n.size,timeout:t});for(let p of n)(Br(p)||qr(p))&&a(p);for await(let p of(0,_r.setInterval)(10,Date.now()))if(n.size===0||Date.now()-p>=t)break;for(let p of n)i(p);return Promise.allSettled(e.map(Vr))};return{sockets:n,shutdown:()=>o??=d()}};var Jr=({errorHandler:e,getLogger:t})=>async(r,o,n,i)=>r?e.execute({error:(0,_e.isHttpError)(r)?r:(0,_e.default)(400,re(r).message),request:o,response:n,input:null,output:null,options:{},logger:t(o)}):i(),Yr=({errorHandler:e,getLogger:t})=>async(r,o)=>{let n=(0,_e.default)(404,`Can not ${r.method} ${r.path}`),i=t(r);try{e.execute({request:r,response:o,logger:i,error:n,input:null,output:null,options:{}})}catch(a){mt({response:o,logger:i,error:new ee(re(a),n)})}},an=e=>(t,{},r)=>{if(Object.values(t?.files||[]).flat().find(({truncated:n})=>n))return r(e);r()},pn=e=>({log:e.debug.bind(e)}),Wr=async({getLogger:e,config:t})=>{let r=await Ke("express-fileupload"),{limitError:o,beforeUpload:n,...i}={...typeof t.upload=="object"&&t.upload},a=[];return a.push(async(c,d,p)=>{let l=e(c);try{await n?.({request:c,logger:l})}catch(h){return p(h)}return r({debug:!0,...i,abortOnLimit:!1,parseNested:!0,logger:pn(l)})(c,d,p)}),o&&a.push(an(o)),a},Qr=(e,{},t)=>{Buffer.isBuffer(e.body)&&(e.body={raw:e.body}),t()},Xr=({logger:e,config:t})=>async(r,o,n)=>{let i=await t.childLoggerProvider?.({request:r,parent:e})||e;i.debug(`${r.method}: ${r.path}`),r.res&&(r.res.locals[b]={logger:i}),n()},eo=e=>t=>t?.res?.locals[b]?.logger||e,to=e=>process.on("deprecation",({message:t,namespace:r,name:o,stack:n})=>e.warn(`${o} (${r}): ${t}`,n.split(`
3
- `).slice(1))),ro=({servers:e,logger:t,options:{timeout:r,events:o=["SIGINT","SIGTERM"]}})=>{let n=Gr(e,{logger:t,timeout:r}),i=()=>n.shutdown().then(()=>process.exit());for(let a of o)process.on(a,i)};var F=require("ansis"),oo=e=>{if(e.columns<132)return;let t=(0,F.italic)("Proudly supports transgender community.".padStart(109)),r=(0,F.italic)("Start your API server with I/O schema validation and custom middlewares in minutes.".padStart(109)),o=(0,F.italic)("Thank you for choosing Express Zod API for your project.".padStart(132)),n=(0,F.italic)("for Tai".padEnd(20)),i=(0,F.hex)("#F5A9B8"),a=(0,F.hex)("#5BCEFA"),c=new Array(14).fill(a,1,3).fill(i,3,5).fill(F.whiteBright,5,7).fill(i,7,9).fill(a,9,12).fill(F.gray,12,13),d=`
1
+ "use strict";var Wo=Object.create;var nt=Object.defineProperty;var Xo=Object.getOwnPropertyDescriptor;var en=Object.getOwnPropertyNames;var tn=Object.getPrototypeOf,rn=Object.prototype.hasOwnProperty;var on=(e,t)=>{for(var r in t)nt(e,r,{get:t[r],enumerable:!0})},Sr=(e,t,r,o)=>{if(t&&typeof t=="object"||typeof t=="function")for(let n of en(t))!rn.call(e,n)&&n!==r&&nt(e,n,{get:()=>t[n],enumerable:!(o=Xo(t,n))||o.enumerable});return e};var U=(e,t,r)=>(r=e!=null?Wo(tn(e)):{},Sr(t||!e||!e.__esModule?nt(r,"default",{value:e,enumerable:!0}):r,e)),nn=e=>Sr(nt({},"__esModule",{value:!0}),e);var Bs={};on(Bs,{BuiltinLogger:()=>Ue,DependsOnMethod:()=>He,Documentation:()=>Rt,DocumentationError:()=>q,EndpointsFactory:()=>de,EventStreamFactory:()=>Nt,InputValidationError:()=>J,Integration:()=>Ct,Middleware:()=>V,MissingPeerError:()=>Ee,OutputValidationError:()=>oe,ResultHandler:()=>ce,RoutingError:()=>ye,ServeStatic:()=>De,arrayEndpointsFactory:()=>Ur,arrayResultHandler:()=>xt,attachRouting:()=>yo,createConfig:()=>Rr,createServer:()=>fo,defaultEndpointsFactory:()=>Mr,defaultResultHandler:()=>Le,ensureHttpError:()=>Se,ez:()=>Qo,getExamples:()=>ee,getMessageFromError:()=>se,testEndpoint:()=>Ho,testMiddleware:()=>Ko});module.exports=nn(Bs);var D=require("ramda"),he=require("zod");var fe=require("ramda"),Tr=require("zod");var I={json:"application/json",upload:"multipart/form-data",raw:"application/octet-stream",sse:"text/event-stream"};var ye=class extends Error{name="RoutingError"},q=class extends Error{name="DocumentationError";cause;constructor(t,{method:r,path:o,isResponse:n}){super(t),this.cause=`${n?"Response":"Input"} schema of an Endpoint assigned to ${r.toUpperCase()} method of ${o} path.`}},st=class extends Error{name="IOSchemaError"},oe=class extends st{constructor(r){super(se(r),{cause:r});this.cause=r}name="OutputValidationError"},J=class extends st{constructor(r){super(se(r),{cause:r});this.cause=r}name="InputValidationError"},ne=class extends Error{constructor(r,o){super(se(r),{cause:r});this.cause=r;this.handled=o}name="ResultHandlerError"},Ee=class extends Error{name="MissingPeerError";constructor(t){super(`Missing peer dependency: ${t}. Please install it to use the feature.`)}};var sn=e=>{let r=(e.header("content-type")||"").toLowerCase().startsWith(I.upload);return"files"in e&&r},Ut={get:["query","params"],post:["body","params","files"],put:["body","params"],patch:["body","params"],delete:["query","params"]},an=["body","query","params"],Ht=e=>e.method.toLowerCase(),it=(e,t={})=>{let r=Ht(e);return r==="options"?{}:(t[r]||Ut[r]||an).filter(o=>o==="files"?sn(e):!0).reduce((o,n)=>Object.assign(o,e[n]),{})},ie=e=>e instanceof Error?e:new Error(String(e)),se=e=>e instanceof Tr.z.ZodError?e.issues.map(({path:t,message:r})=>(t.length?[t.join("/")]:[]).concat(r).join(": ")).join("; "):e instanceof oe?`output${e.cause.issues[0]?.path.length>0?"/":": "}${e.message}`:e.message,ee=({schema:e,variant:t="original",validate:r=t==="parsed"})=>{let o=e._def[x]?.examples||[];if(!r&&t==="original")return o;let n=[];for(let s of o){let a=e.safeParse(s);a.success&&n.push(t==="parsed"?a.data:s)}return n},ze=(e,t,r)=>e.length&&t.length?(0,fe.xprod)(e,t).map(r):e.concat(t),_e=e=>"coerce"in e._def&&typeof e._def.coerce=="boolean"?e._def.coerce:!1,Kt=e=>e.charAt(0).toUpperCase()+e.slice(1).toLowerCase(),ae=(...e)=>{let t=(0,fe.chain)(o=>o.split(/[^A-Z0-9]/gi),e);return(0,fe.chain)(o=>o.replaceAll(/[A-Z]+/g,n=>`/${n}`).split("/"),t).map(Kt).join("")},at=(e,t)=>{try{return typeof e.parse(t)}catch{return}},ge=e=>typeof e=="object"&&e!==null,Ie=(0,fe.memoizeWith)(()=>"static",()=>process.env.NODE_ENV==="production"),pt=e=>e.length?e:void 0;var ct=require("ramda"),x=Symbol.for("express-zod-api"),dt=e=>{let t=e.describe(e.description);return t._def[x]=(0,ct.clone)(t._def[x])||{examples:[]},t},Or=(e,t)=>{if(!(x in e._def))return t;let r=dt(t);return r._def[x].examples=ze(r._def[x].examples,e._def[x].examples,([o,n])=>typeof o=="object"&&typeof n=="object"?(0,ct.mergeDeepRight)({...o},{...n}):n),r};var pn=function(e){let t=dt(this);return t._def[x].examples.push(e),t},cn=function(e){let t=dt(this);return t._def[x].defaultLabel=e,t},dn=function(e){return new he.z.ZodBranded({typeName:he.z.ZodFirstPartyTypeKind.ZodBranded,type:this,description:this._def.description,errorMap:this._def.errorMap,[x]:{examples:[],...(0,D.clone)(this._def[x]),brand:e}})},mn=function(e){let t=typeof e=="function"?e:(0,D.pipe)(D.toPairs,(0,D.map)(([n,s])=>(0,D.pair)(e[String(n)]||n,s)),D.fromPairs),r=t((0,D.clone)(this.shape)),o=he.z.object(r)[this._def.unknownKeys]();return this.transform(t).pipe(o)};x in globalThis||(globalThis[x]=!0,Object.defineProperties(he.z.ZodType.prototype,{example:{get(){return pn.bind(this)}},brand:{set(){},get(){return dn.bind(this)}}}),Object.defineProperty(he.z.ZodDefault.prototype,"label",{get(){return cn.bind(this)}}),Object.defineProperty(he.z.ZodObject.prototype,"remap",{get(){return mn.bind(this)}}));function Rr(e){return e}var Gt=require("zod");var Vt=require("zod");var C=require("node:assert/strict");var ve=require("zod");var mt=e=>!isNaN(e.getTime());var xe=Symbol("DateIn"),Pr=()=>ve.z.union([ve.z.string().date(),ve.z.string().datetime(),ve.z.string().datetime({local:!0})]).transform(t=>new Date(t)).pipe(ve.z.date().refine(mt)).brand(xe);var Ar=require("zod");var be=Symbol("DateOut"),wr=()=>Ar.z.date().refine(mt).transform(e=>e.toISOString()).brand(be);var Ge=require("zod"),Q=Symbol("File"),Er=Ge.z.custom(e=>Buffer.isBuffer(e),{message:"Expected Buffer"}),ln={buffer:()=>Er.brand(Q),string:()=>Ge.z.string().brand(Q),binary:()=>Er.or(Ge.z.string()).brand(Q),base64:()=>Ge.z.string().base64().brand(Q)};function lt(e){return ln[e||"string"]()}var zr=require("zod");var pe=Symbol("Raw"),Ir=(e={})=>zr.z.object({raw:lt("buffer")}).extend(e).brand(pe);var vr=require("zod"),ke=Symbol("Upload"),kr=()=>vr.z.custom(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.encoding=="string"&&typeof e.mimetype=="string"&&Buffer.isBuffer(e.data)&&typeof e.tempFilePath=="string"&&typeof e.truncated=="boolean"&&typeof e.size=="number"&&typeof e.md5=="string"&&typeof e.mv=="function",e=>({message:`Expected file upload, received ${typeof e}`})).brand(ke);var Zr=(e,{next:t})=>e.options.some(t),un=({_def:e},{next:t})=>[e.left,e.right].some(t),ut=(e,{next:t})=>t(e.unwrap()),Dt={ZodObject:({shape:e},{next:t})=>Object.values(e).some(t),ZodUnion:Zr,ZodDiscriminatedUnion:Zr,ZodIntersection:un,ZodEffects:(e,{next:t})=>t(e.innerType()),ZodOptional:ut,ZodNullable:ut,ZodRecord:({valueSchema:e},{next:t})=>t(e),ZodArray:({element:e},{next:t})=>t(e),ZodDefault:({_def:e},{next:t})=>t(e.innerType)},yt=(e,{condition:t,rules:r=Dt,depth:o=1,maxDepth:n=Number.POSITIVE_INFINITY})=>{if(t?.(e))return!0;let s=o<n?r[e._def[x]?.brand]||r[e._def.typeName]:void 0;return s?s(e,{next:a=>yt(a,{condition:t,rules:r,maxDepth:n,depth:o+1})}):!1},Cr=e=>yt(e,{condition:t=>t._def[x]?.brand===ke}),Nr=e=>yt(e,{condition:t=>t._def[x]?.brand===pe,maxDepth:3}),Ft=(e,t)=>{let r=new WeakSet;return yt(e,{maxDepth:300,rules:{...Dt,ZodBranded:ut,ZodReadonly:ut,ZodCatch:({_def:{innerType:o}},{next:n})=>n(o),ZodPipeline:({_def:o},{next:n})=>n(o[t]),ZodLazy:(o,{next:n})=>r.has(o)?!1:r.add(o)&&n(o.schema),ZodTuple:({items:o,_def:{rest:n}},{next:s})=>[...o].concat(n??[]).some(s),ZodEffects:{out:void 0,in:Dt.ZodEffects}[t],ZodNaN:()=>(0,C.fail)("z.nan()"),ZodSymbol:()=>(0,C.fail)("z.symbol()"),ZodFunction:()=>(0,C.fail)("z.function()"),ZodMap:()=>(0,C.fail)("z.map()"),ZodSet:()=>(0,C.fail)("z.set()"),ZodBigInt:()=>(0,C.fail)("z.bigint()"),ZodVoid:()=>(0,C.fail)("z.void()"),ZodPromise:()=>(0,C.fail)("z.promise()"),ZodNever:()=>(0,C.fail)("z.never()"),ZodDate:()=>t==="in"&&(0,C.fail)("z.date()"),[be]:()=>t==="in"&&(0,C.fail)("ez.dateOut()"),[xe]:()=>t==="out"&&(0,C.fail)("ez.dateIn()"),[pe]:()=>t==="out"&&(0,C.fail)("ez.raw()"),[ke]:()=>t==="out"&&(0,C.fail)("ez.upload()"),[Q]:()=>!1}})};var ft=U(require("http-errors"),1);var Ye=U(require("http-errors"),1),jr=require("zod");var qt=(e,{variant:t,args:r,...o})=>{if(typeof e=="function"&&(e=e(...r)),e instanceof jr.z.ZodType)return[{schema:e,...o}];if(Array.isArray(e)&&!e.length){let n=new Error(`At least one ${t} response schema required.`);throw new ne(n)}return(Array.isArray(e)?e:[e]).map(({schema:n,statusCode:s,mimeType:a})=>({schema:n,statusCodes:typeof s=="number"?[s]:s||o.statusCodes,mimeTypes:typeof a=="string"?[a]:a===void 0?o.mimeTypes:a}))},Je=(e,t,{url:r},o)=>!e.expose&&t.error("Server side error",{error:e,url:r,payload:o}),Se=e=>(0,Ye.isHttpError)(e)?e:(0,Ye.default)(e instanceof J?400:500,se(e),{cause:e.cause||e}),Te=e=>Ie()&&!e.expose?(0,Ye.default)(e.statusCode).message:e.message;var gt=({error:e,logger:t,response:r})=>{t.error("Result handler failure",e);let o=Te((0,ft.default)(500,`An error occurred while serving the result: ${e.message}.`+(e.handled?`
2
+ Original error: ${e.handled.message}.`:""),{expose:(0,ft.isHttpError)(e.cause)?e.cause.expose:!1}));r.status(500).type("text/plain").end(o)};var Bt=require("zod");var $t=class{},V=class extends $t{#e;#t;#r;constructor({input:t=Bt.z.object({}),security:r,handler:o}){super(),this.#e=t,this.#t=r,this.#r=o}getSecurity(){return this.#t}getSchema(){return this.#e}async execute({input:t,...r}){try{let o=await this.#e.parseAsync(t);return this.#r({...r,input:o})}catch(o){throw o instanceof Bt.z.ZodError?new J(o):o}}},Ze=class extends V{constructor(t,{provider:r=()=>({}),transformer:o=n=>n}={}){super({handler:async({request:n,response:s})=>new Promise((a,c)=>{let d=p=>{if(p&&p instanceof Error)return c(o(p));a(r(n,s))};t(n,s,d)?.catch(d)})})}};var Ce=class{nest(t){return Object.assign(t,{"":this})}};var Qe=class extends Ce{},ht=class extends Qe{#e;#t;#r;#n;#s;#i;#o;#a;#p;#c;#d;constructor({methods:t,inputSchema:r,outputSchema:o,handler:n,resultHandler:s,getOperationId:a=()=>{},scopes:c=[],middlewares:d=[],tags:p=[],description:l,shortDescription:g}){super(),this.#s=n,this.#i=s,this.#r=d,this.#c=a,this.#t=Object.freeze(t),this.#a=Object.freeze(c),this.#p=Object.freeze(p),this.#e={long:l,short:g},this.#o={input:r,output:o},this.#n={positive:Object.freeze(s.getPositiveResponse(o)),negative:Object.freeze(s.getNegativeResponse())},this.#d=Cr(r)?"upload":Nr(r)?"raw":"json"}getDescription(t){return this.#e[t]}getMethods(){return this.#t}getSchema(t){return this.#o[t]}getRequestType(){return this.#d}getResponses(t){return this.#n[t]}getSecurity(){return this.#r.map(t=>t.getSecurity()).filter(t=>t!==void 0)}getScopes(){return this.#a}getTags(){return this.#p}getOperationId(t){return this.#c(t)}async#m(t){try{return await this.#o.output.parseAsync(t)}catch(r){throw r instanceof Vt.z.ZodError?new oe(r):r}}async#l({method:t,logger:r,options:o,response:n,...s}){for(let a of this.#r)if(!(t==="options"&&!(a instanceof Ze))&&(Object.assign(o,await a.execute({...s,options:o,response:n,logger:r})),n.writableEnded)){r.warn("A middleware has closed the stream. Accumulated options:",o);break}}async#u({input:t,...r}){let o;try{o=await this.#o.input.parseAsync(t)}catch(n){throw n instanceof Vt.z.ZodError?new J(n):n}return this.#s({...r,input:o})}async#y({error:t,...r}){try{await this.#i.execute({...r,error:t})}catch(o){gt({...r,error:new ne(ie(o),t||void 0)})}}async execute({request:t,response:r,logger:o,config:n}){let s=Ht(t),a={},c=null,d=null,p=it(t,n.inputSources);try{if(await this.#l({method:s,input:p,request:t,response:r,logger:o,options:a}),r.writableEnded)return;if(s==="options")return void r.status(200).end();c=await this.#m(await this.#u({input:p,logger:o,options:a}))}catch(l){d=ie(l)}await this.#y({input:p,output:c,request:t,response:r,error:d,logger:o,options:a})}};var Lr=(e,t)=>{let r=e.map(n=>n.getSchema()).concat(t),o=r.reduce((n,s)=>n.and(s));return r.reduce((n,s)=>Or(s,n),o)};var _=require("zod");var Ne={positive:200,negative:400},je=Object.keys(Ne);var _t=class{#e;constructor(t){this.#e=t}execute(...t){return this.#e(...t)}},ce=class extends _t{#e;#t;constructor(t){super(t.handler),this.#e=t.positive,this.#t=t.negative}getPositiveResponse(t){return qt(this.#e,{variant:"positive",args:[t],statusCodes:[Ne.positive],mimeTypes:[I.json]})}getNegativeResponse(){return qt(this.#t,{variant:"negative",args:[],statusCodes:[Ne.negative],mimeTypes:[I.json]})}},Le=new ce({positive:e=>{let t=ee({schema:e}),r=_.z.object({status:_.z.literal("success"),data:e});return t.reduce((o,n)=>o.example({status:"success",data:n}),r)},negative:_.z.object({status:_.z.literal("error"),error:_.z.object({message:_.z.string()})}).example({status:"error",error:{message:"Sample error message"}}),handler:({error:e,input:t,output:r,request:o,response:n,logger:s})=>{if(e){let a=Se(e);return Je(a,s,o,t),void n.status(a.statusCode).json({status:"error",error:{message:Te(a)}})}n.status(Ne.positive).json({status:"success",data:r})}}),xt=new ce({positive:e=>{let t=ee({schema:e}),r="shape"in e&&"items"in e.shape&&e.shape.items instanceof _.z.ZodArray?e.shape.items:_.z.array(_.z.any());return t.reduce((o,n)=>ge(n)&&"items"in n&&Array.isArray(n.items)?o.example(n.items):o,r)},negative:_.z.string().example("Sample error message"),handler:({response:e,output:t,error:r,logger:o,request:n,input:s})=>{if(r){let a=Se(r);return Je(a,o,n,s),void e.status(a.statusCode).type("text/plain").send(Te(a))}if(t&&"items"in t&&Array.isArray(t.items))return void e.status(Ne.positive).json(t.items);throw new Error("Property 'items' is missing in the endpoint output")}});var de=class e{constructor(t){this.resultHandler=t}middlewares=[];static#e(t,r){let o=new e(r);return o.middlewares=t,o}addMiddleware(t){return e.#e(this.middlewares.concat(t instanceof V?t:new V(t)),this.resultHandler)}use=this.addExpressMiddleware;addExpressMiddleware(...t){return e.#e(this.middlewares.concat(new Ze(...t)),this.resultHandler)}addOptions(t){return e.#e(this.middlewares.concat(new V({handler:t})),this.resultHandler)}build({input:t=Gt.z.object({}),handler:r,output:o,description:n,shortDescription:s,operationId:a,scope:c,tag:d,method:p}){let{middlewares:l,resultHandler:g}=this,b=typeof p=="string"?[p]:p,f=typeof a=="function"?a:()=>a,P=typeof c=="string"?[c]:c||[],O=typeof d=="string"?[d]:d||[];return new ht({handler:r,middlewares:l,outputSchema:o,resultHandler:g,scopes:P,tags:O,methods:b,getOperationId:f,description:n,shortDescription:s,inputSchema:Lr(l,t)})}buildVoid({handler:t,...r}){return this.build({...r,output:Gt.z.object({}),handler:async o=>(await t(o),{})})}},Mr=new de(Le),Ur=new de(xt);var Br=U(require("ansis"),1),$r=require("node:util"),Jt=require("node:perf_hooks");var W=require("ansis"),Hr=require("ramda");var Yt={debug:W.blue,info:W.green,warn:(0,W.hex)("#FFA500"),error:W.red,ctx:W.cyanBright},bt={debug:10,info:20,warn:30,error:40},Kr=e=>ge(e)&&Object.keys(bt).some(t=>t in e),Dr=e=>e in bt,Fr=(e,t)=>bt[e]<bt[t],yn=(e,t=0)=>Intl.NumberFormat(void 0,{useGrouping:!1,minimumFractionDigits:0,maximumFractionDigits:t,style:"unit",unitDisplay:"long",unit:e}),Me=(0,Hr.memoizeWith)((e,t)=>`${e}${t}`,yn),qr=e=>e<1e-6?Me("nanosecond",3).format(e/1e-6):e<.001?Me("nanosecond").format(e/1e-6):e<1?Me("microsecond").format(e/.001):e<1e3?Me("millisecond").format(e):e<6e4?Me("second",2).format(e/1e3):Me("minute",2).format(e/6e4);var Ue=class e{config;constructor({color:t=Br.default.isSupported(),level:r=Ie()?"warn":"debug",depth:o=2,ctx:n={}}={}){this.config={color:t,level:r,depth:o,ctx:n}}prettyPrint(t){let{depth:r,color:o,level:n}=this.config;return(0,$r.inspect)(t,{depth:r,colors:o,breakLength:n==="debug"?80:1/0,compact:n==="debug"?3:!0})}print(t,r,o){let{level:n,ctx:{requestId:s,...a},color:c}=this.config;if(n==="silent"||Fr(t,n))return;let d=[new Date().toISOString()];s&&d.push(c?Yt.ctx(s):s),d.push(c?`${Yt[t](t)}:`:`${t}:`,r),o!==void 0&&d.push(this.prettyPrint(o)),Object.keys(a).length>0&&d.push(this.prettyPrint(a)),console.log(d.join(" "))}debug(t,r){this.print("debug",t,r)}info(t,r){this.print("info",t,r)}warn(t,r){this.print("warn",t,r)}error(t,r){this.print("error",t,r)}child(t){return new e({...this.config,ctx:t})}get ctx(){return this.config.ctx}profile(t){let r=Jt.performance.now();return()=>{let o=Jt.performance.now()-r,{message:n,severity:s="debug",formatter:a=qr}=typeof t=="object"?t:{message:t};this.print(typeof s=="function"?s(o):s,n,a(o))}}};var Ke=require("ramda");var He=class extends Ce{entries;constructor(t){super();let r=[],o=(0,Ke.keys)(t);for(let n of o){let s=t[n];s&&r.push([n,s,(0,Ke.reject)((0,Ke.equals)(n),o)])}this.entries=Object.freeze(r)}};var Vr=U(require("express"),1),De=class{params;constructor(...t){this.params=t}apply(t,r){return r(t,Vr.default.static(...this.params))}};var Tt=U(require("express"),1),mo=U(require("node:http"),1),lo=U(require("node:https"),1);var Fe=async(e,t="default")=>{try{return(await Promise.resolve().then(()=>U(require(e))))[t]}catch{}throw new Ee(e)};var St=class{constructor(t){this.logger=t}#e=new WeakSet;check(t,r){if(!this.#e.has(t)){if(t.getRequestType()==="json")try{Ft(t.getSchema("input"),"in")}catch(o){this.logger.warn("The final input schema of the endpoint contains an unsupported JSON payload type.",Object.assign(r,{reason:o}))}for(let o of je)for(let{mimeTypes:n,schema:s}of t.getResponses(o))if(n?.includes(I.json))try{Ft(s,"out")}catch(a){this.logger.warn(`The final ${o} response schema of the endpoint contains an unsupported JSON payload type.`,Object.assign(r,{reason:a}))}this.#e.add(t)}}};var _r=(e,t)=>Object.entries(e).map(([r,o])=>{if(r.includes("/"))throw new ye(`The entry '${r}' must avoid having slashes \u2014 use nesting instead.`);let n=r.trim();return[`${t||""}${n?`/${n}`:""}`,o]}),qe=({routing:e,onEndpoint:t,onStatic:r})=>{let o=_r(e);for(;o.length;){let[n,s]=o.shift();if(s instanceof Qe){let a=s.getMethods()||["get"];for(let c of a)t(s,n,c)}else if(s instanceof De)r&&s.apply(n,r);else if(s instanceof He)for(let[a,c,d]of s.entries){let p=c.getMethods();if(p&&!p.includes(a))throw new ye(`Endpoint assigned to ${a} method of ${n} must support ${a} method.`);t(c,n,a,d)}else o.unshift(..._r(s,n))}};var Qt=({app:e,getLogger:t,config:r,routing:o,parsers:n})=>{let s=new St(t()),a=new Set;qe({routing:o,onEndpoint:(d,p,l,g)=>{Ie()||s.check(d,{path:p,method:l});let b=n?.[d.getRequestType()]||[],f=async(P,O)=>{let j=t(P);if(r.cors){let R={"Access-Control-Allow-Origin":"*","Access-Control-Allow-Methods":[l,...g||[],"options"].join(", ").toUpperCase(),"Access-Control-Allow-Headers":"content-type"},M=typeof r.cors=="function"?await r.cors({request:P,endpoint:d,logger:j,defaultHeaders:R}):R;for(let v in M)O.set(v,M[v])}return d.execute({request:P,response:O,logger:j,config:r})};r.cors&&!a.has(p)&&(e.options(p,...b,f),a.add(p)),e[l](p,...b,f)},onStatic:e.use.bind(e)})};var We=U(require("http-errors"),1);var Xr=require("node:timers/promises");var Gr=e=>"_httpMessage"in e&&typeof e._httpMessage=="object"&&e._httpMessage!==null&&"headersSent"in e._httpMessage&&typeof e._httpMessage.headersSent=="boolean"&&"setHeader"in e._httpMessage&&typeof e._httpMessage.setHeader=="function",Yr=e=>"server"in e&&typeof e.server=="object"&&e.server!==null&&"close"in e.server&&typeof e.server.close=="function",Jr=e=>"encrypted"in e&&typeof e.encrypted=="boolean"&&e.encrypted,Qr=({},e)=>void(!e.headersSent&&e.setHeader("connection","close")),Wr=e=>new Promise((t,r)=>void e.close(o=>o?r(o):t()));var eo=(e,{timeout:t=1e3,logger:r}={})=>{let o,n=new Set,s=p=>void n.delete(p.destroy()),a=p=>void(Gr(p)?!p._httpMessage.headersSent&&p._httpMessage.setHeader("connection","close"):s(p)),c=p=>void(o?p.destroy():n.add(p.once("close",()=>void n.delete(p))));for(let p of e)for(let l of["connection","secureConnection"])p.on(l,c);let d=async()=>{for(let p of e)p.on("request",Qr);r?.info("Graceful shutdown",{sockets:n.size,timeout:t});for(let p of n)(Jr(p)||Yr(p))&&a(p);for await(let p of(0,Xr.setInterval)(10,Date.now()))if(n.size===0||Date.now()-p>=t)break;for(let p of n)s(p);return Promise.allSettled(e.map(Wr))};return{sockets:n,shutdown:()=>o??=d()}};var to=({errorHandler:e,getLogger:t})=>async(r,o,n,s)=>r?e.execute({error:(0,We.isHttpError)(r)?r:(0,We.default)(400,ie(r).message),request:o,response:n,input:null,output:null,options:{},logger:t(o)}):s(),ro=({errorHandler:e,getLogger:t})=>async(r,o)=>{let n=(0,We.default)(404,`Can not ${r.method} ${r.path}`),s=t(r);try{e.execute({request:r,response:o,logger:s,error:n,input:null,output:null,options:{}})}catch(a){gt({response:o,logger:s,error:new ne(ie(a),n)})}},fn=e=>(t,{},r)=>{if(Object.values(t?.files||[]).flat().find(({truncated:n})=>n))return r(e);r()},gn=e=>({log:e.debug.bind(e)}),oo=async({getLogger:e,config:t})=>{let r=await Fe("express-fileupload"),{limitError:o,beforeUpload:n,...s}={...typeof t.upload=="object"&&t.upload},a=[];return a.push(async(c,d,p)=>{let l=e(c);try{await n?.({request:c,logger:l})}catch(g){return p(g)}return r({debug:!0,...s,abortOnLimit:!1,parseNested:!0,logger:gn(l)})(c,d,p)}),o&&a.push(fn(o)),a},no=(e,{},t)=>{Buffer.isBuffer(e.body)&&(e.body={raw:e.body}),t()},so=({logger:e,config:t})=>async(r,o,n)=>{let s=await t.childLoggerProvider?.({request:r,parent:e})||e;s.debug(`${r.method}: ${r.path}`),r.res&&(r.res.locals[x]={logger:s}),n()},io=e=>t=>t?.res?.locals[x]?.logger||e,ao=e=>process.on("deprecation",({message:t,namespace:r,name:o,stack:n})=>e.warn(`${o} (${r}): ${t}`,n.split(`
3
+ `).slice(1))),po=({servers:e,logger:t,options:{timeout:r,events:o=["SIGINT","SIGTERM"]}})=>{let n=eo(e,{logger:t,timeout:r}),s=()=>n.shutdown().then(()=>process.exit());for(let a of o)process.on(a,s)};var B=require("ansis"),co=e=>{if(e.columns<132)return;let t=(0,B.italic)("Proudly supports transgender community.".padStart(109)),r=(0,B.italic)("Start your API server with I/O schema validation and custom middlewares in minutes.".padStart(109)),o=(0,B.italic)("Thank you for choosing Express Zod API for your project.".padStart(132)),n=(0,B.italic)("for Tai".padEnd(20)),s=(0,B.hex)("#F5A9B8"),a=(0,B.hex)("#5BCEFA"),c=new Array(14).fill(a,1,3).fill(s,3,5).fill(B.whiteBright,5,7).fill(s,7,9).fill(a,9,12).fill(B.gray,12,13),d=`
4
4
  8888888888 8888888888P 888 d8888 8888888b. 8888888
5
5
  888 d88P 888 d88888 888 Y88b 888
6
6
  888 d88P 888 d88P888 888 888 888
@@ -15,9 +15,9 @@ ${n}888${r}
15
15
  ${o}
16
16
  `;e.write(d.split(`
17
17
  `).map((p,l)=>c[l]?c[l](p):p).join(`
18
- `))};var io=e=>{e.startupLogo!==!1&&oo(process.stdout);let t=e.errorHandler||ke,r=Nr(e.logger)?e.logger:new Le(e.logger);r.debug("Running",{build:"v22.4.0 (CJS)",env:process.env.NODE_ENV||"development"}),to(r);let o=Xr({logger:r,config:e}),i={getLogger:eo(r),errorHandler:t},a=Yr(i),c=Jr(i);return{...i,logger:r,notFoundHandler:a,parserFailureHandler:c,loggingMiddleware:o}},ao=(e,t)=>{let{logger:r,getLogger:o,notFoundHandler:n,loggingMiddleware:i}=io(e);return Jt({app:e.app.use(i),routing:t,getLogger:o,config:e}),{notFoundHandler:n,logger:r}},po=async(e,t)=>{let{logger:r,getLogger:o,notFoundHandler:n,parserFailureHandler:i,loggingMiddleware:a}=io(e),c=(0,gt.default)().disable("x-powered-by").use(a);if(e.compression){let S=await Ke("compression");c.use(S(typeof e.compression=="object"?e.compression:void 0))}let d={json:[e.jsonParser||gt.default.json()],raw:[e.rawParser||gt.default.raw(),Qr],upload:e.upload?await Wr({config:e,getLogger:o}):[]};await e.beforeRouting?.({app:c,getLogger:o}),Jt({app:c,routing:t,getLogger:o,config:e,parsers:d}),c.use(i,n);let p=[],l=(S,g)=>()=>S.listen(g,()=>r.info("Listening",g)),h=[];if(e.http){let S=no.default.createServer(c);p.push(S),h.push(l(S,e.http.listen))}if(e.https){let S=so.default.createServer(e.https.options,c);p.push(S),h.push(l(S,e.https.listen))}return e.gracefulShutdown&&ro({logger:r,servers:p,options:e.gracefulShutdown===!0?{}:e.gracefulShutdown}),{app:c,logger:r,servers:h.map(S=>S())}};var vo=require("openapi3-ts/oas31"),Zo=require("ramda");var O=require("ramda");var co=e=>le(e)&&"or"in e,mo=e=>le(e)&&"and"in e,Yt=e=>!mo(e)&&!co(e),lo=e=>{let t=(0,O.filter)(Yt,e),r=(0,O.chain)((0,O.prop)("and"),(0,O.filter)(mo,e)),[o,n]=(0,O.partition)(Yt,r),i=(0,O.concat)(t,o),a=(0,O.filter)(co,e);return(0,O.map)((0,O.prop)("or"),(0,O.concat)(a,n)).reduce((d,p)=>Ae(d,(0,O.map)(l=>Yt(l)?[l]:l.and,p),([l,h])=>(0,O.concat)(l,h)),(0,O.reject)(O.isEmpty,[i]))};var W=require("openapi3-ts/oas31"),m=require("ramda"),w=require("zod");var xe=(e,{onEach:t,rules:r,onMissing:o,ctx:n={}})=>{let i=r[e._def[b]?.brand]||r[e._def.typeName],c=i?i(e,{...n,next:p=>xe(p,{ctx:n,onEach:t,rules:r,onMissing:o})}):o(e,n),d=t&&t(e,{prev:c,...n});return d?{...c,...d}:c};var uo=["a-im","accept","accept-additions","accept-ch","accept-charset","accept-datetime","accept-encoding","accept-features","accept-language","accept-patch","accept-post","accept-ranges","accept-signature","access-control","access-control-allow-credentials","access-control-allow-headers","access-control-allow-methods","access-control-allow-origin","access-control-expose-headers","access-control-max-age","access-control-request-headers","access-control-request-method","age","allow","alpn","alt-svc","alt-used","alternates","amp-cache-transform","apply-to-redirect-ref","authentication-control","authentication-info","authorization","available-dictionary","c-ext","c-man","c-opt","c-pep","c-pep-info","cache-control","cache-status","cal-managed-id","caldav-timezones","capsule-protocol","cdn-cache-control","cdn-loop","cert-not-after","cert-not-before","clear-site-data","client-cert","client-cert-chain","close","cmcd-object","cmcd-request","cmcd-session","cmcd-status","cmsd-dynamic","cmsd-static","concealed-auth-export","configuration-context","connection","content-base","content-digest","content-disposition","content-encoding","content-id","content-language","content-length","content-location","content-md5","content-range","content-script-type","content-security-policy","content-security-policy-report-only","content-style-type","content-type","content-version","cookie","cookie2","cross-origin-embedder-policy","cross-origin-embedder-policy-report-only","cross-origin-opener-policy","cross-origin-opener-policy-report-only","cross-origin-resource-policy","cta-common-access-token","dasl","date","dav","default-style","delta-base","deprecation","depth","derived-from","destination","differential-id","dictionary-id","digest","dpop","dpop-nonce","early-data","ediint-features","etag","expect","expect-ct","expires","ext","forwarded","from","getprofile","hobareg","host","http2-settings","if","if-match","if-modified-since","if-none-match","if-range","if-schedule-tag-match","if-unmodified-since","im","include-referred-token-binding-id","isolation","keep-alive","label","last-event-id","last-modified","link","link-template","location","lock-token","man","max-forwards","memento-datetime","meter","method-check","method-check-expires","mime-version","negotiate","nel","odata-entityid","odata-isolation","odata-maxversion","odata-version","opt","optional-www-authenticate","ordering-type","origin","origin-agent-cluster","oscore","oslc-core-version","overwrite","p3p","pep","pep-info","permissions-policy","pics-label","ping-from","ping-to","position","pragma","prefer","preference-applied","priority","profileobject","protocol","protocol-info","protocol-query","protocol-request","proxy-authenticate","proxy-authentication-info","proxy-authorization","proxy-features","proxy-instruction","proxy-status","public","public-key-pins","public-key-pins-report-only","range","redirect-ref","referer","referer-root","referrer-policy","refresh","repeatability-client-id","repeatability-first-sent","repeatability-request-id","repeatability-result","replay-nonce","reporting-endpoints","repr-digest","retry-after","safe","schedule-reply","schedule-tag","sec-gpc","sec-purpose","sec-token-binding","sec-websocket-accept","sec-websocket-extensions","sec-websocket-key","sec-websocket-protocol","sec-websocket-version","security-scheme","server","server-timing","set-cookie","set-cookie2","setprofile","signature","signature-input","slug","soapaction","status-uri","strict-transport-security","sunset","surrogate-capability","surrogate-control","tcn","te","timeout","timing-allow-origin","topic","traceparent","tracestate","trailer","transfer-encoding","ttl","upgrade","urgency","uri","use-as-dictionary","user-agent","variant-vary","vary","via","want-content-digest","want-digest","want-repr-digest","warning","www-authenticate","x-content-type-options","x-frame-options"];var yo=50,go="https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Date/toISOString",dn={integer:0,number:0,string:"",boolean:!1,object:{},null:null,array:[]},ho=/:([A-Za-z0-9_]+)/g,mn=/^\d{4}-\d{2}-\d{2}$/,ln=/^\d{2}:\d{2}:\d{2}(\.\d+)?$/,un=e=>e?/^\d{4}-\d{2}-\d{2}T\d{2}:\d{2}:\d{2}(\.\d+)?(([+-]\d{2}:\d{2})|Z)$/:/^\d{4}-\d{2}-\d{2}T\d{2}:\d{2}:\d{2}(\.\d+)?Z$/,yn=e=>e.match(ho)?.map(t=>t.slice(1))||[],xo=e=>e.replace(ho,t=>`{${t.slice(1)}}`),fn=({_def:e},{next:t})=>({...t(e.innerType),default:e[b]?.defaultLabel||e.defaultValue()}),gn=({_def:{innerType:e}},{next:t})=>t(e),hn=()=>({format:"any"}),xn=({},e)=>{if(e.isResponse)throw new D("Please use ez.upload() only for input.",e);return{type:"string",format:"binary"}},bn=e=>{let t=e.unwrap();return{type:"string",format:t instanceof w.z.ZodString?t._def.checks.find(r=>r.kind==="base64")?"byte":"file":"binary"}},Sn=({options:e},{next:t})=>({oneOf:e.map(t)}),Tn=({options:e,discriminator:t},{next:r})=>({discriminator:{propertyName:t},oneOf:e.map(r)}),On=(e,t)=>{if(Array.isArray(e)&&Array.isArray(t))return(0,m.concat)(e,t);if(e===t)return t;throw new Error("Can not flatten properties")},Rn=e=>{let[t,r]=e.filter(W.isSchemaObject).filter(n=>n.type==="object"&&Object.keys(n).every(i=>["type","properties","required","examples"].includes(i)));if(!t||!r)throw new Error("Can not flatten objects");let o={type:"object"};return(t.properties||r.properties)&&(o.properties=(0,m.mergeDeepWith)(On,t.properties||{},r.properties||{})),(t.required||r.required)&&(o.required=(0,m.union)(t.required||[],r.required||[])),(t.examples||r.examples)&&(o.examples=Ae(t.examples||[],r.examples||[],([n,i])=>(0,m.mergeDeepRight)(n,i))),o},Pn=({_def:{left:e,right:t}},{next:r})=>{let o=[e,t].map(r);try{return Rn(o)}catch{}return{allOf:o}},An=(e,{next:t})=>t(e.unwrap()),wn=(e,{next:t})=>t(e.unwrap()),En=(e,{next:t})=>{let r=t(e.unwrap());return(0,W.isSchemaObject)(r)&&(r.type=So(r)),r},bo=e=>{let t=(0,m.toLower)((0,m.type)(e));return typeof e=="bigint"?"integer":t==="number"||t==="string"||t==="boolean"||t==="object"||t==="null"||t==="array"?t:void 0},fo=e=>({type:bo(Object.values(e.enum)[0]),enum:Object.values(e.enum)}),In=({value:e})=>({type:bo(e),const:e}),zn=(e,{isResponse:t,next:r})=>{let o=Object.keys(e.shape),n=c=>t&&Fe(c)?c instanceof w.z.ZodOptional:c.isOptional(),i=o.filter(c=>!n(e.shape[c])),a={type:"object"};return o.length&&(a.properties=ht(e,r)),i.length&&(a.required=i),a},vn=()=>({type:"null"}),Zn=({},e)=>{if(e.isResponse)throw new D("Please use ez.dateOut() for output.",e);return{description:"YYYY-MM-DDTHH:mm:ss.sssZ",type:"string",format:"date-time",pattern:/^\d{4}-\d{2}-\d{2}(T\d{2}:\d{2}:\d{2}(\.\d+)?)?Z?$/.source,externalDocs:{url:go}}},Cn=({},e)=>{if(!e.isResponse)throw new D("Please use ez.dateIn() for input.",e);return{description:"YYYY-MM-DDTHH:mm:ss.sssZ",type:"string",format:"date-time",externalDocs:{url:go}}},kn=({},e)=>{throw new D(`Using z.date() within ${e.isResponse?"output":"input"} schema is forbidden. Please use ez.date${e.isResponse?"Out":"In"}() instead. Check out the documentation for details.`,e)},Nn=()=>({type:"boolean"}),Ln=()=>({type:"integer",format:"bigint"}),jn=e=>e.every(t=>t instanceof w.z.ZodLiteral),Un=({keySchema:e,valueSchema:t},{next:r})=>{if(e instanceof w.z.ZodEnum||e instanceof w.z.ZodNativeEnum){let o=Object.values(e.enum),n={type:"object"};return o.length&&(n.properties=ht(w.z.object((0,m.fromPairs)((0,m.xprod)(o,[t]))),r),n.required=o),n}if(e instanceof w.z.ZodLiteral)return{type:"object",properties:ht(w.z.object({[e.value]:t}),r),required:[e.value]};if(e instanceof w.z.ZodUnion&&jn(e.options)){let o=(0,m.map)(i=>`${i.value}`,e.options),n=(0,m.fromPairs)((0,m.xprod)(o,[t]));return{type:"object",properties:ht(w.z.object(n),r),required:o}}return{type:"object",additionalProperties:r(t)}},Mn=({_def:{minLength:e,maxLength:t},element:r},{next:o})=>{let n={type:"array",items:o(r)};return e&&(n.minItems=e.value),t&&(n.maxItems=t.value),n},Kn=({items:e,_def:{rest:t}},{next:r})=>({type:"array",prefixItems:e.map(r),items:t===null?{not:{}}:r(t)}),Hn=({isEmail:e,isURL:t,minLength:r,maxLength:o,isUUID:n,isCUID:i,isCUID2:a,isULID:c,isIP:d,isEmoji:p,isDatetime:l,isCIDR:h,isDate:S,isTime:g,isBase64:A,isNANOID:R,isBase64url:N,isDuration:L,_def:{checks:T}})=>{let P=T.find(Z=>Z.kind==="regex"),j=T.find(Z=>Z.kind==="datetime"),z=T.some(Z=>Z.kind==="jwt"),M=T.find(Z=>Z.kind==="length"),v={type:"string"},pe={"date-time":l,byte:A,base64url:N,date:S,time:g,duration:L,email:e,url:t,uuid:n,cuid:i,cuid2:a,ulid:c,nanoid:R,jwt:z,ip:d,cidr:h,emoji:p};for(let Z in pe)if(pe[Z]){v.format=Z;break}return M&&([v.minLength,v.maxLength]=[M.value,M.value]),r!==null&&(v.minLength=r),o!==null&&(v.maxLength=o),S&&(v.pattern=mn.source),g&&(v.pattern=ln.source),l&&(v.pattern=un(j?.offset).source),P&&(v.pattern=P.regex.source),v},Dn=({isInt:e,maxValue:t,minValue:r,_def:{checks:o}})=>{let n=o.find(h=>h.kind==="min"),i=r===null?e?Number.MIN_SAFE_INTEGER:-Number.MAX_VALUE:r,a=n?n.inclusive:!0,c=o.find(h=>h.kind==="max"),d=t===null?e?Number.MAX_SAFE_INTEGER:Number.MAX_VALUE:t,p=c?c.inclusive:!0,l={type:e?"integer":"number",format:e?"int64":"double"};return a?l.minimum=i:l.exclusiveMinimum=i,p?l.maximum=d:l.exclusiveMaximum=d,l},ht=({shape:e},t)=>(0,m.map)(t,e),Fn=e=>{let t=Array.isArray(e.type)?e.type[0]:e.type;return dn?.[t]},So=({type:e})=>e==="null"?e:typeof e=="string"?[e,"null"]:e?[...new Set(e).add("null")]:"null",qn=(e,{isResponse:t,next:r})=>{let o=r(e.innerType()),{effect:n}=e._def;if(t&&n.type==="transform"&&(0,W.isSchemaObject)(o)){let i=rt(e,Fn(o));return i&&["number","string","boolean"].includes(i)?{type:i}:r(w.z.any())}if(!t&&n.type==="preprocess"&&(0,W.isSchemaObject)(o)){let{type:i,...a}=o;return{...a,format:`${a.format||i} (preprocessed)`}}return o},Bn=({_def:e},{isResponse:t,next:r})=>r(e[t?"out":"in"]),$n=(e,{next:t})=>t(e.unwrap()),Vn=(e,{next:t,makeRef:r})=>r(e,()=>t(e.schema)),_n=(e,{next:t})=>t(e.unwrap().shape.raw),To=e=>e.length?(0,m.fromPairs)((0,m.zip)((0,m.times)(t=>`example${t+1}`,e.length),(0,m.map)((0,m.objOf)("value"),e))):void 0,Oo=(e,t,r=[])=>(0,m.pipe)(Y,(0,m.map)((0,m.when)(o=>(0,m.type)(o)==="Object",(0,m.omit)(r))),To)({schema:e,variant:t?"parsed":"original",validate:!0}),Gn=(e,t)=>(0,m.pipe)(Y,(0,m.filter)((0,m.has)(t)),(0,m.pluck)(t),To)({schema:e,variant:"original",validate:!0}),be=e=>e instanceof w.z.ZodObject?e:e instanceof w.z.ZodBranded?be(e.unwrap()):e instanceof w.z.ZodUnion||e instanceof w.z.ZodDiscriminatedUnion?e.options.map(t=>be(t)).reduce((t,r)=>t.merge(r.partial()),w.z.object({})):e instanceof w.z.ZodEffects?be(e._def.schema):e instanceof w.z.ZodPipeline?be(e._def.in):be(e._def.left).merge(be(e._def.right)),Jn=(e,t)=>t?.includes(e)||e.startsWith("x-")||uo.includes(e),Ro=({path:e,method:t,schema:r,inputSources:o,makeRef:n,composition:i,brandHandling:a,isHeader:c,security:d,description:p=`${t.toUpperCase()} ${e} Parameter`})=>{let{shape:l}=be(r),h=yn(e),S=o.includes("query"),g=o.includes("params"),A=o.includes("headers"),R=T=>g&&h.includes(T),N=(0,m.chain)((0,m.filter)(T=>T.type==="header"),d??[]).map(({name:T})=>T),L=T=>A&&(c?.(T,t,e)??Jn(T,N));return Object.keys(l).reduce((T,P)=>{let j=R(P)?"path":L(P)?"header":S?"query":void 0;if(!j)return T;let z=xe(l[P],{rules:{...a,...Qt},onEach:Xt,onMissing:er,ctx:{isResponse:!1,makeRef:n,path:e,method:t}}),M=i==="components"?n(l[P],z,oe(p,P)):z;return T.concat({name:P,in:j,required:!l[P].isOptional(),description:z.description||p,schema:M,examples:Gn(r,P)})},[])},Qt={ZodString:Hn,ZodNumber:Dn,ZodBigInt:Ln,ZodBoolean:Nn,ZodNull:vn,ZodArray:Mn,ZodTuple:Kn,ZodRecord:Un,ZodObject:zn,ZodLiteral:In,ZodIntersection:Pn,ZodUnion:Sn,ZodAny:hn,ZodDefault:fn,ZodEnum:fo,ZodNativeEnum:fo,ZodEffects:qn,ZodOptional:An,ZodNullable:En,ZodDiscriminatedUnion:Tn,ZodBranded:$n,ZodDate:kn,ZodCatch:gn,ZodPipeline:Bn,ZodLazy:Vn,ZodReadonly:wn,[_]:bn,[Ie]:xn,[fe]:Cn,[ye]:Zn,[ne]:_n},Xt=(e,{isResponse:t,prev:r})=>{if((0,W.isReferenceObject)(r))return{};let{description:o}=e,n=e instanceof w.z.ZodLazy,i=r.type!==void 0,a=t&&Fe(e),c=!n&&i&&!a&&e.isNullable(),d={};if(o&&(d.description=o),c&&(d.type=So(r)),!n){let p=Y({schema:e,variant:t?"parsed":"original",validate:!0});p.length&&(d.examples=p.slice())}return d},er=(e,t)=>{throw new D(`Zod type ${e.constructor.name} is unsupported.`,t)},Wt=(e,t)=>{if((0,W.isReferenceObject)(e))return e;let r={...e};return r.properties&&(r.properties=(0,m.omit)(t,r.properties)),r.examples&&(r.examples=r.examples.map(o=>(0,m.omit)(t,o))),r.required&&(r.required=r.required.filter(o=>!t.includes(o))),r.allOf&&(r.allOf=r.allOf.map(o=>Wt(o,t))),r.oneOf&&(r.oneOf=r.oneOf.map(o=>Wt(o,t))),r},Po=e=>(0,W.isReferenceObject)(e)?e:(0,m.omit)(["examples"],e),Ao=({method:e,path:t,schema:r,mimeTypes:o,variant:n,makeRef:i,composition:a,hasMultipleStatusCodes:c,statusCode:d,brandHandling:p,description:l=`${e.toUpperCase()} ${t} ${Mt(n)} response ${c?d:""}`.trim()})=>{if(!o)return{description:l};let h=Po(xe(r,{rules:{...p,...Qt},onEach:Xt,onMissing:er,ctx:{isResponse:!0,makeRef:i,path:t,method:e}})),S={schema:a==="components"?i(r,h,oe(l)):h,examples:Oo(r,!0)};return{description:l,content:(0,m.fromPairs)((0,m.xprod)(o,[S]))}},Yn=({format:e})=>{let t={type:"http",scheme:"bearer"};return e&&(t.bearerFormat=e),t},Wn=({name:e},t)=>{let r={type:"apiKey",in:"query",name:e};return t?.includes("body")&&(t?.includes("query")?(r["x-in-alternative"]="body",r.description=`${e} CAN also be supplied within the request body`):(r["x-in-actual"]="body",r.description=`${e} MUST be supplied within the request body instead of query`)),r},Qn=({name:e})=>({type:"apiKey",in:"header",name:e}),Xn=({name:e})=>({type:"apiKey",in:"cookie",name:e}),es=({url:e})=>({type:"openIdConnect",openIdConnectUrl:e}),ts=({flows:e={}})=>({type:"oauth2",flows:(0,m.map)(t=>({...t,scopes:t.scopes||{}}),(0,m.reject)(m.isNil,e))}),wo=(e,t=[])=>{let r=o=>o.type==="basic"?{type:"http",scheme:"basic"}:o.type==="bearer"?Yn(o):o.type==="input"?Wn(o,t):o.type==="header"?Qn(o):o.type==="cookie"?Xn(o):o.type==="openid"?es(o):ts(o);return e.map(o=>o.map(r))},Eo=(e,t,r)=>e.map(o=>o.reduce((n,i)=>{let a=r(i),c=["oauth2","openIdConnect"].includes(i.type);return Object.assign(n,{[a]:c?t:[]})},{})),Io=({method:e,path:t,schema:r,mimeType:o,makeRef:n,composition:i,brandHandling:a,paramNames:c,description:d=`${e.toUpperCase()} ${t} Request body`})=>{let p=Po(Wt(xe(r,{rules:{...a,...Qt},onEach:Xt,onMissing:er,ctx:{isResponse:!1,makeRef:n,path:t,method:e}}),c)),l={schema:i==="components"?n(r,p,oe(d)):p,examples:Oo(r,!1,c)};return{description:d,content:{[o]:l}}},zo=e=>Object.entries(e).reduce((t,[r,o])=>{if(!o)return t;let n={name:r,description:typeof o=="string"?o:o.description};return typeof o=="object"&&o.url&&(n.externalDocs={url:o.url}),t.concat(n)},[]),tr=e=>e.length<=yo?e:e.slice(0,yo-1)+"\u2026";var xt=class extends vo.OpenApiBuilder{lastSecuritySchemaIds=new Map;lastOperationIdSuffixes=new Map;references=new Map;makeRef(t,r,o=this.references.get(t)){return o||(o=`Schema${this.references.size+1}`,this.references.set(t,o),typeof r=="function"&&(r=r())),typeof r=="object"&&this.addSchema(o,r),{$ref:`#/components/schemas/${o}`}}ensureUniqOperationId(t,r,o){let n=o||oe(r,t),i=this.lastOperationIdSuffixes.get(n);if(i===void 0)return this.lastOperationIdSuffixes.set(n,1),n;if(o)throw new D(`Duplicated operationId: "${o}"`,{method:r,isResponse:!1,path:t});return i++,this.lastOperationIdSuffixes.set(n,i),`${n}${i}`}ensureUniqSecuritySchemaName(t){let r=JSON.stringify(t);for(let n in this.rootDoc.components?.securitySchemes||{})if(r===JSON.stringify(this.rootDoc.components?.securitySchemes?.[n]))return n;let o=(this.lastSecuritySchemaIds.get(t.type)||0)+1;return this.lastSecuritySchemaIds.set(t.type,o),`${t.type.toUpperCase()}_${o}`}constructor({routing:t,config:r,title:o,version:n,serverUrl:i,descriptions:a,brandHandling:c,tags:d,isHeader:p,hasSummaryFromDescription:l=!0,composition:h="inline"}){super(),this.addInfo({title:o,version:n});for(let g of typeof i=="string"?[i]:i)this.addServer({url:g});He({routing:t,onEndpoint:(g,A,R)=>{let N={path:A,method:R,endpoint:g,composition:h,brandHandling:c,makeRef:this.makeRef.bind(this)},[L,T]=["short","long"].map(g.getDescription.bind(g)),P=L?tr(L):l&&T?tr(T):void 0,j=r.inputSources?.[R]||jt[R],z=this.ensureUniqOperationId(A,R,g.getOperationId(R)),M=lo(g.getSecurity()),v=Ro({...N,inputSources:j,isHeader:p,security:M,schema:g.getSchema("input"),description:a?.requestParameter?.call(null,{method:R,path:A,operationId:z})}),pe={};for(let Q of Ce){let ce=g.getResponses(Q);for(let{mimeTypes:Nt,schema:We,statusCodes:Qe}of ce)for(let Lt of Qe)pe[Lt]=Ao({...N,variant:Q,schema:We,mimeTypes:Nt,statusCode:Lt,hasMultipleStatusCodes:ce.length>1||Qe.length>1,description:a?.[`${Q}Response`]?.call(null,{method:R,path:A,operationId:z,statusCode:Lt})})}let Z=j.includes("body")?Io({...N,paramNames:(0,Zo.pluck)("name",v),schema:g.getSchema("input"),mimeType:I[g.getRequestType()],description:a?.requestBody?.call(null,{method:R,path:A,operationId:z})}):void 0,kt=Eo(wo(M,j),g.getScopes(),Q=>{let ce=this.ensureUniqSecuritySchemaName(Q);return this.addSecurityScheme(ce,Q),ce});this.addPath(xo(A),{[R]:{operationId:z,summary:P,description:T,tags:ot(g.getTags()),parameters:ot(v),requestBody:Z,security:ot(kt),responses:pe}})}}),d&&(this.rootDoc.tags=zo(d))}};var bt=require("node-mocks-http"),rs=e=>(0,bt.createRequest)({...e,headers:{"content-type":I.json,...e?.headers}}),os=e=>(0,bt.createResponse)(e),ns=e=>{let t={warn:[],error:[],info:[],debug:[]};return new Proxy(e||{},{get(r,o,n){return o==="_getLogs"?()=>t:Lr(o)?(...i)=>t[o].push(i):Reflect.get(r,o,n)}})},Co=({requestProps:e,responseOptions:t,configProps:r,loggerProps:o})=>{let n=rs(e),i=os({req:n,...t});i.req=t?.req||n,n.res=i;let a=ns(o),c={cors:!1,logger:a,...r};return{requestMock:n,responseMock:i,loggerMock:a,configMock:c}},ko=async({endpoint:e,...t})=>{let{requestMock:r,responseMock:o,loggerMock:n,configMock:i}=Co(t);return await e.execute({request:r,response:o,config:i,logger:n}),{requestMock:r,responseMock:o,loggerMock:n}},No=async({middleware:e,options:t={},errorHandler:r,...o})=>{let{requestMock:n,responseMock:i,loggerMock:a,configMock:c}=Co(o),d=tt(n,c.inputSources);try{let p=await e.execute({request:n,response:i,logger:a,input:d,options:t});return{requestMock:n,responseMock:i,loggerMock:a,output:p}}catch(p){if(!r)throw p;return r(re(p),i),{requestMock:n,responseMock:i,loggerMock:a,output:{}}}};var Ko=require("ramda"),Ye=U(require("typescript"),1),Ho=require("zod");var $=U(require("typescript"),1);var Lo=["get","post","put","delete","patch"];var u=U(require("typescript"),1),s=u.default.factory,St=[s.createModifier(u.default.SyntaxKind.ExportKeyword)],ss=[s.createModifier(u.default.SyntaxKind.AsyncKeyword)],Ge={public:[s.createModifier(u.default.SyntaxKind.PublicKeyword)],protectedReadonly:[s.createModifier(u.default.SyntaxKind.ProtectedKeyword),s.createModifier(u.default.SyntaxKind.ReadonlyKeyword)]},Tt=(e,t)=>u.default.addSyntheticLeadingComment(e,u.default.SyntaxKind.MultiLineCommentTrivia,`* ${t} `,!0),rr=(e,t)=>{let r=u.default.createSourceFile("print.ts","",u.default.ScriptTarget.Latest,!1,u.default.ScriptKind.TS);return u.default.createPrinter(t).printNode(u.default.EmitHint.Unspecified,e,r)},is=/^[A-Za-z_$][A-Za-z0-9_$]*$/,or=e=>typeof e=="number"?s.createNumericLiteral(e):is.test(e)?s.createIdentifier(e):s.createStringLiteral(e),Ot=(e,...t)=>s.createTemplateExpression(s.createTemplateHead(e),t.map(([r,o=""],n)=>s.createTemplateSpan(r,n===t.length-1?s.createTemplateTail(o):s.createTemplateMiddle(o)))),nr=s.createExpressionWithTypeArguments(s.createIdentifier("Record"),[s.createKeywordTypeNode(u.default.SyntaxKind.StringKeyword),s.createKeywordTypeNode(u.default.SyntaxKind.AnyKeyword)]),Rt=(e,{type:t,mod:r,init:o,optional:n}={})=>s.createParameterDeclaration(r,void 0,e,n?s.createToken(u.default.SyntaxKind.QuestionToken):void 0,t,o),Se=e=>Object.entries(e).map(([t,r])=>Rt(s.createIdentifier(t),r&&"kind"in r?{type:r}:r)),sr=(e,t=[])=>s.createConstructorDeclaration(Ge.public,e,s.createBlock(t)),y=e=>typeof e=="string"||u.default.isIdentifier(e)?s.createTypeReferenceNode(e):e,Te=(e,t,{isOptional:r}={})=>s.createPropertySignature(void 0,or(e),r?s.createToken(u.default.SyntaxKind.QuestionToken):void 0,y(t)),ir=e=>u.default.setEmitFlags(e,u.default.EmitFlags.SingleLine),ar=(...e)=>s.createArrayBindingPattern(e.map(t=>s.createBindingElement(void 0,void 0,t))),k=(e,t,{type:r,expose:o}={})=>s.createVariableStatement(o&&St,s.createVariableDeclarationList([s.createVariableDeclaration(e,void 0,r,t)],u.default.NodeFlags.Const)),pr=(e,t)=>J(e,s.createUnionTypeNode(t.map(r=>s.createLiteralTypeNode(s.createStringLiteral(r)))),{expose:!0}),J=(e,t,{expose:r,comment:o,params:n}={})=>{let i=s.createTypeAliasDeclaration(r?St:void 0,e,n&&wt(n),t);return o?Tt(i,o):i},jo=(e,t)=>s.createPropertyDeclaration(Ge.public,e,void 0,t,void 0),cr=(e,t,r,{typeParams:o,returns:n}={})=>s.createMethodDeclaration(Ge.public,void 0,e,void 0,o&&wt(o),t,n,r),dr=(e,t,{typeParams:r}={})=>s.createClassDeclaration(St,e,r&&wt(r),void 0,t),mr=e=>s.createTypeOperatorNode(u.default.SyntaxKind.KeyOfKeyword,y(e)),Pt=e=>s.createTypeReferenceNode(Promise.name,[e==="any"?s.createKeywordTypeNode(u.default.SyntaxKind.AnyKeyword):e]),At=(e,t,{expose:r,comment:o}={})=>{let n=s.createInterfaceDeclaration(r?St:void 0,e,void 0,void 0,t);return o?Tt(n,o):n},wt=e=>Object.entries(e).map(([t,r])=>{let{type:o,init:n}=r&&"init"in r?r:{type:r};return s.createTypeParameterDeclaration([],t,o&&y(o),typeof n=="number"?s.createKeywordTypeNode(n):n)}),Oe=(e,t,{isAsync:r,typeParams:o}={})=>s.createArrowFunction(r?ss:void 0,o&&wt(o),Array.isArray(e)?e.map(n=>Rt(n)):Se(e),void 0,void 0,t),E=e=>e,Je=(e,t,r)=>s.createConditionalExpression(e,s.createToken(u.default.SyntaxKind.QuestionToken),t,s.createToken(u.default.SyntaxKind.ColonToken),r),H=(e,t,r)=>s.createCallExpression(s.createPropertyAccessExpression(Array.isArray(e)?s.createPropertyAccessExpression(...e):e,t),void 0,r),De=(e,...t)=>s.createNewExpression(e,void 0,t),Et=(e,t)=>s.createTypeReferenceNode("Extract",[y(e),t]),lr=(e,t)=>s.createExpressionStatement(s.createBinaryExpression(e,s.createToken(u.default.SyntaxKind.EqualsToken),t)),as=[u.default.SyntaxKind.AnyKeyword,u.default.SyntaxKind.BigIntKeyword,u.default.SyntaxKind.BooleanKeyword,u.default.SyntaxKind.NeverKeyword,u.default.SyntaxKind.NumberKeyword,u.default.SyntaxKind.ObjectKeyword,u.default.SyntaxKind.StringKeyword,u.default.SyntaxKind.SymbolKeyword,u.default.SyntaxKind.UndefinedKeyword,u.default.SyntaxKind.UnknownKeyword,u.default.SyntaxKind.VoidKeyword],Uo=e=>as.includes(e.kind);var It=class{constructor(t){this.serverUrl=t}paths=new Set;tags=new Map;registry=new Map;ids={pathType:s.createIdentifier("Path"),implementationType:s.createIdentifier("Implementation"),keyParameter:s.createIdentifier("key"),pathParameter:s.createIdentifier("path"),paramsArgument:s.createIdentifier("params"),ctxArgument:s.createIdentifier("ctx"),methodParameter:s.createIdentifier("method"),requestParameter:s.createIdentifier("request"),eventParameter:s.createIdentifier("event"),dataParameter:s.createIdentifier("data"),handlerParameter:s.createIdentifier("handler"),msgParameter:s.createIdentifier("msg"),parseRequestFn:s.createIdentifier("parseRequest"),substituteFn:s.createIdentifier("substitute"),provideMethod:s.createIdentifier("provide"),onMethod:s.createIdentifier("on"),implementationArgument:s.createIdentifier("implementation"),hasBodyConst:s.createIdentifier("hasBody"),undefinedValue:s.createIdentifier("undefined"),responseConst:s.createIdentifier("response"),restConst:s.createIdentifier("rest"),searchParamsConst:s.createIdentifier("searchParams"),defaultImplementationConst:s.createIdentifier("defaultImplementation"),clientConst:s.createIdentifier("client"),contentTypeConst:s.createIdentifier("contentType"),isJsonConst:s.createIdentifier("isJSON"),sourceProp:s.createIdentifier("source")};interfaces={input:s.createIdentifier("Input"),positive:s.createIdentifier("PositiveResponse"),negative:s.createIdentifier("NegativeResponse"),encoded:s.createIdentifier("EncodedResponse"),response:s.createIdentifier("Response")};methodType=pr("Method",Lo);someOfType=J("SomeOf",s.createIndexedAccessTypeNode(y("T"),mr("T")),{params:{T:void 0}});requestType=J("Request",mr(this.interfaces.input),{expose:!0});someOf=({name:t})=>s.createTypeReferenceNode(this.someOfType.name,[y(t)]);makePathType=()=>pr(this.ids.pathType,Array.from(this.paths));makePublicInterfaces=()=>Object.keys(this.interfaces).map(t=>At(this.interfaces[t],Array.from(this.registry).map(([r,o])=>Te(r,o[t])),{expose:!0}));makeEndpointTags=()=>k("endpointTags",s.createObjectLiteralExpression(Array.from(this.tags).map(([t,r])=>s.createPropertyAssignment(or(t),s.createArrayLiteralExpression(r.map(o=>s.createStringLiteral(o)))))),{expose:!0});makeImplementationType=()=>J(this.ids.implementationType,s.createFunctionTypeNode(void 0,Se({[this.ids.methodParameter.text]:y(this.methodType.name),[this.ids.pathParameter.text]:s.createKeywordTypeNode($.default.SyntaxKind.StringKeyword),[this.ids.paramsArgument.text]:nr,[this.ids.ctxArgument.text]:{optional:!0,type:y("T")}}),Pt("any")),{expose:!0,params:{T:{init:$.default.SyntaxKind.UnknownKeyword}}});makeParseRequestFn=()=>k(this.ids.parseRequestFn,Oe({[this.ids.requestParameter.text]:s.createKeywordTypeNode($.default.SyntaxKind.StringKeyword)},s.createAsExpression(H(this.ids.requestParameter,E("split"),[s.createRegularExpressionLiteral("/ (.+)/"),s.createNumericLiteral(2)]),s.createTupleTypeNode([y(this.methodType.name),y(this.ids.pathType)]))));makeSubstituteFn=()=>k(this.ids.substituteFn,Oe({[this.ids.pathParameter.text]:s.createKeywordTypeNode($.default.SyntaxKind.StringKeyword),[this.ids.paramsArgument.text]:nr},s.createBlock([k(this.ids.restConst,s.createObjectLiteralExpression([s.createSpreadAssignment(this.ids.paramsArgument)])),s.createForInStatement(s.createVariableDeclarationList([s.createVariableDeclaration(this.ids.keyParameter)],$.default.NodeFlags.Const),this.ids.paramsArgument,s.createBlock([lr(this.ids.pathParameter,H(this.ids.pathParameter,E("replace"),[Ot(":",[this.ids.keyParameter]),Oe([],s.createBlock([s.createExpressionStatement(s.createDeleteExpression(s.createElementAccessExpression(this.ids.restConst,this.ids.keyParameter))),s.createReturnStatement(s.createElementAccessExpression(this.ids.paramsArgument,this.ids.keyParameter))]))]))])),s.createReturnStatement(s.createAsExpression(s.createArrayLiteralExpression([this.ids.pathParameter,this.ids.restConst]),y("const")))])));makeProvider=()=>cr(this.ids.provideMethod,Se({[this.ids.requestParameter.text]:y("K"),[this.ids.paramsArgument.text]:s.createIndexedAccessTypeNode(y(this.interfaces.input),y("K")),[this.ids.ctxArgument.text]:{optional:!0,type:y("T")}}),s.createBlock([k(ar(this.ids.methodParameter,this.ids.pathParameter),s.createCallExpression(this.ids.parseRequestFn,void 0,[this.ids.requestParameter])),s.createReturnStatement(H(s.createThis(),this.ids.implementationArgument,[this.ids.methodParameter,s.createSpreadElement(s.createCallExpression(this.ids.substituteFn,void 0,[this.ids.pathParameter,this.ids.paramsArgument])),this.ids.ctxArgument]))]),{typeParams:{K:this.requestType.name},returns:Pt(s.createIndexedAccessTypeNode(y(this.interfaces.response),y("K")))});makeClientClass=t=>dr(t,[sr([Rt(this.ids.implementationArgument,{type:s.createTypeReferenceNode(this.ids.implementationType,[y("T")]),mod:Ge.protectedReadonly,init:this.ids.defaultImplementationConst})]),this.makeProvider()],{typeParams:{T:void 0}});makeSearchParams=t=>Ot("?",[De(s.createIdentifier(URLSearchParams.name),t)]);makeFetchURL=()=>De(s.createIdentifier(URL.name),Ot("",[this.ids.pathParameter],[this.ids.searchParamsConst]),s.createStringLiteral(this.serverUrl));makeDefaultImplementation=()=>{let t=s.createPropertyAssignment(E("method"),H(this.ids.methodParameter,E("toUpperCase"))),r=s.createPropertyAssignment(E("headers"),Je(this.ids.hasBodyConst,s.createObjectLiteralExpression([s.createPropertyAssignment(s.createStringLiteral("Content-Type"),s.createStringLiteral(I.json))]),this.ids.undefinedValue)),o=s.createPropertyAssignment(E("body"),Je(this.ids.hasBodyConst,H(s.createIdentifier(JSON[Symbol.toStringTag]),E("stringify"),[this.ids.paramsArgument]),this.ids.undefinedValue)),n=k(this.ids.responseConst,s.createAwaitExpression(s.createCallExpression(s.createIdentifier(fetch.name),void 0,[this.makeFetchURL(),s.createObjectLiteralExpression([t,r,o])]))),i=k(this.ids.hasBodyConst,s.createLogicalNot(H(s.createArrayLiteralExpression([s.createStringLiteral("get"),s.createStringLiteral("delete")]),E("includes"),[this.ids.methodParameter]))),a=k(this.ids.searchParamsConst,Je(this.ids.hasBodyConst,s.createStringLiteral(""),this.makeSearchParams(this.ids.paramsArgument))),c=k(this.ids.contentTypeConst,H([this.ids.responseConst,E("headers")],E("get"),[s.createStringLiteral("content-type")])),d=s.createIfStatement(s.createPrefixUnaryExpression($.default.SyntaxKind.ExclamationToken,this.ids.contentTypeConst),s.createReturnStatement()),p=k(this.ids.isJsonConst,H(this.ids.contentTypeConst,E("startsWith"),[s.createStringLiteral(I.json)])),l=s.createReturnStatement(s.createCallExpression(s.createElementAccessExpression(this.ids.responseConst,Je(this.ids.isJsonConst,s.createStringLiteral(E("json")),s.createStringLiteral(E("text")))),void 0,[]));return k(this.ids.defaultImplementationConst,Oe([this.ids.methodParameter,this.ids.pathParameter,this.ids.paramsArgument],s.createBlock([i,a,n,c,d,p,l]),{isAsync:!0}),{type:y(this.ids.implementationType)})};makeSubscriptionConstructor=()=>sr(Se({request:y("K"),params:s.createIndexedAccessTypeNode(y(this.interfaces.input),y("K"))}),[k(ar(this.ids.pathParameter,this.ids.restConst),s.createCallExpression(this.ids.substituteFn,void 0,[s.createElementAccessExpression(s.createCallExpression(this.ids.parseRequestFn,void 0,[this.ids.requestParameter]),s.createNumericLiteral(1)),this.ids.paramsArgument])),k(this.ids.searchParamsConst,this.makeSearchParams(this.ids.restConst)),lr(s.createPropertyAccessExpression(s.createThis(),this.ids.sourceProp),De(s.createIdentifier("EventSource"),this.makeFetchURL()))]);makeEventNarrow=t=>s.createTypeLiteralNode([Te(E("event"),t)]);makeOnMethod=()=>cr(this.ids.onMethod,Se({[this.ids.eventParameter.text]:y("E"),[this.ids.handlerParameter.text]:s.createFunctionTypeNode(void 0,Se({[this.ids.dataParameter.text]:s.createIndexedAccessTypeNode(Et("R",ir(this.makeEventNarrow("E"))),s.createLiteralTypeNode(s.createStringLiteral(E("data"))))}),s.createUnionTypeNode([s.createKeywordTypeNode($.default.SyntaxKind.VoidKeyword),Pt(s.createKeywordTypeNode($.default.SyntaxKind.VoidKeyword))]))}),s.createBlock([s.createExpressionStatement(H([s.createThis(),this.ids.sourceProp],E("addEventListener"),[this.ids.eventParameter,Oe([this.ids.msgParameter],s.createCallExpression(this.ids.handlerParameter,void 0,[H(s.createIdentifier(JSON[Symbol.toStringTag]),E("parse"),[s.createPropertyAccessExpression(s.createParenthesizedExpression(s.createAsExpression(this.ids.msgParameter,y(MessageEvent.name))),E("data"))])]))])),s.createReturnStatement(s.createThis())]),{typeParams:{E:s.createIndexedAccessTypeNode(y("R"),s.createLiteralTypeNode(s.createStringLiteral(E("event"))))}});makeSubscriptionClass=t=>dr(t,[jo(this.ids.sourceProp,y("EventSource")),this.makeSubscriptionConstructor(),this.makeOnMethod()],{typeParams:{K:Et(this.requestType.name,s.createTemplateLiteralType(s.createTemplateHead("get "),[s.createTemplateLiteralTypeSpan(s.createKeywordTypeNode($.default.SyntaxKind.StringKeyword),s.createTemplateTail(""))])),R:Et(s.createIndexedAccessTypeNode(y(this.interfaces.positive),y("K")),ir(this.makeEventNarrow(s.createKeywordTypeNode($.default.SyntaxKind.StringKeyword))))}});makeUsageStatements=(t,r)=>[k(this.ids.clientConst,De(s.createIdentifier(t))),H(this.ids.clientConst,this.ids.provideMethod,[s.createStringLiteral("get /v1/user/retrieve"),s.createObjectLiteralExpression([s.createPropertyAssignment("id",s.createStringLiteral("10"))])]),H(De(s.createIdentifier(r),s.createStringLiteral("get /v1/events/stream"),s.createObjectLiteralExpression()),this.ids.onMethod,[s.createStringLiteral("time"),Oe({time:void 0},s.createBlock([]))])]};var vt=require("ramda"),x=U(require("typescript"),1),zt=require("zod");var{factory:f}=x.default,ps={[x.default.SyntaxKind.AnyKeyword]:"",[x.default.SyntaxKind.BigIntKeyword]:BigInt(0),[x.default.SyntaxKind.BooleanKeyword]:!1,[x.default.SyntaxKind.NumberKeyword]:0,[x.default.SyntaxKind.ObjectKeyword]:{},[x.default.SyntaxKind.StringKeyword]:"",[x.default.SyntaxKind.UndefinedKeyword]:void 0},cs=({value:e})=>f.createLiteralTypeNode(typeof e=="number"?f.createNumericLiteral(e):typeof e=="boolean"?e?f.createTrue():f.createFalse():f.createStringLiteral(e)),ds=({shape:e},{isResponse:t,next:r,optionalPropStyle:{withQuestionMark:o}})=>{let n=Object.entries(e).map(([i,a])=>{let c=t&&Fe(a)?a instanceof zt.z.ZodOptional:a.isOptional(),d=Te(i,r(a),{isOptional:c&&o});return a.description?Tt(d,a.description):d});return f.createTypeLiteralNode(n)},ms=({element:e},{next:t})=>f.createArrayTypeNode(t(e)),ls=({options:e})=>f.createUnionTypeNode(e.map(t=>f.createLiteralTypeNode(f.createStringLiteral(t)))),Mo=({options:e},{next:t})=>{let r=new Map;for(let o of e){let n=t(o);r.set(Uo(n)?n.kind:n,n)}return f.createUnionTypeNode(Array.from(r.values()))},us=e=>ps?.[e.kind],ys=(e,{next:t,isResponse:r})=>{let o=t(e.innerType());if(r&&e._def.effect.type==="transform"){let n=rt(e,us(o)),i={number:x.default.SyntaxKind.NumberKeyword,bigint:x.default.SyntaxKind.BigIntKeyword,boolean:x.default.SyntaxKind.BooleanKeyword,string:x.default.SyntaxKind.StringKeyword,undefined:x.default.SyntaxKind.UndefinedKeyword,object:x.default.SyntaxKind.ObjectKeyword};return f.createKeywordTypeNode(n&&i[n]||x.default.SyntaxKind.AnyKeyword)}return o},fs=e=>f.createUnionTypeNode(Object.values(e.enum).map(t=>f.createLiteralTypeNode(typeof t=="number"?f.createNumericLiteral(t):f.createStringLiteral(t)))),gs=(e,{next:t,optionalPropStyle:{withUndefined:r}})=>{let o=t(e.unwrap());return r?f.createUnionTypeNode([o,f.createKeywordTypeNode(x.default.SyntaxKind.UndefinedKeyword)]):o},hs=(e,{next:t})=>f.createUnionTypeNode([t(e.unwrap()),f.createLiteralTypeNode(f.createNull())]),xs=({items:e,_def:{rest:t}},{next:r})=>f.createTupleTypeNode(e.map(r).concat(t===null?[]:f.createRestTypeNode(r(t)))),bs=({keySchema:e,valueSchema:t},{next:r})=>f.createExpressionWithTypeArguments(f.createIdentifier("Record"),[e,t].map(r)),Ss=({_def:{left:e,right:t}},{next:r})=>{let o=[e,t].map(r);return o.every(x.default.isTypeLiteralNode)?f.createTypeLiteralNode((0,vt.chain)((0,vt.prop)("members"),o)):f.createIntersectionTypeNode(o)},Ts=({_def:e},{next:t})=>t(e.innerType),ae=e=>()=>f.createKeywordTypeNode(e),Os=(e,{next:t})=>t(e.unwrap()),Rs=(e,{next:t})=>t(e.unwrap()),Ps=({_def:e},{next:t})=>t(e.innerType),As=({_def:e},{next:t,isResponse:r})=>t(e[r?"out":"in"]),ws=()=>f.createLiteralTypeNode(f.createNull()),Es=(e,{makeAlias:t,next:r})=>t(e,()=>r(e.schema)),Is=e=>{let t=e.unwrap(),r=f.createKeywordTypeNode(x.default.SyntaxKind.StringKeyword),o=y("Buffer"),n=f.createUnionTypeNode([r,o]);return t instanceof zt.z.ZodString?r:t instanceof zt.z.ZodUnion?n:o},zs=(e,{next:t})=>t(e.unwrap().shape.raw),vs={ZodString:ae(x.default.SyntaxKind.StringKeyword),ZodNumber:ae(x.default.SyntaxKind.NumberKeyword),ZodBigInt:ae(x.default.SyntaxKind.BigIntKeyword),ZodBoolean:ae(x.default.SyntaxKind.BooleanKeyword),ZodAny:ae(x.default.SyntaxKind.AnyKeyword),ZodUndefined:ae(x.default.SyntaxKind.UndefinedKeyword),[ye]:ae(x.default.SyntaxKind.StringKeyword),[fe]:ae(x.default.SyntaxKind.StringKeyword),ZodNull:ws,ZodArray:ms,ZodTuple:xs,ZodRecord:bs,ZodObject:ds,ZodLiteral:cs,ZodIntersection:Ss,ZodUnion:Mo,ZodDefault:Ts,ZodEnum:ls,ZodNativeEnum:fs,ZodEffects:ys,ZodOptional:gs,ZodNullable:hs,ZodDiscriminatedUnion:Mo,ZodBranded:Os,ZodCatch:Ps,ZodPipeline:As,ZodLazy:Es,ZodReadonly:Rs,[_]:Is,[ne]:zs},ur=(e,{brandHandling:t,ctx:r})=>xe(e,{rules:{...t,...vs},onMissing:()=>f.createKeywordTypeNode(x.default.SyntaxKind.AnyKeyword),ctx:r});var Zt=class extends It{program=[this.someOfType];usage=[];aliases=new Map;makeAlias(t,r){let o=this.aliases.get(t)?.name?.text;if(!o){o=`Type${this.aliases.size+1}`;let n=s.createLiteralTypeNode(s.createNull());this.aliases.set(t,J(o,n)),this.aliases.set(t,J(o,r()))}return y(o)}constructor({routing:t,brandHandling:r,variant:o="client",clientClassName:n="Client",subscriptionClassName:i="Subscription",serverUrl:a="https://example.com",optionalPropStyle:c={withQuestionMark:!0,withUndefined:!0},noContent:d=Ho.z.undefined()}){super(a);let p={makeAlias:this.makeAlias.bind(this),optionalPropStyle:c},l={brandHandling:r,ctx:{...p,isResponse:!1}},h={brandHandling:r,ctx:{...p,isResponse:!0}};He({routing:t,onEndpoint:(g,A,R)=>{let N=oe.bind(null,R,A),L=`${R} ${A}`,T=J(N("input"),ur(g.getSchema("input"),l),{comment:L});this.program.push(T);let P=Ce.reduce((z,M)=>{let v=g.getResponses(M),pe=(0,Ko.chain)(([kt,{schema:Q,mimeTypes:ce,statusCodes:Nt}])=>{let We=J(N(M,"variant",`${kt+1}`),ur(ce?Q:d,h),{comment:L});return this.program.push(We),Nt.map(Qe=>Te(Qe,We.name))},Array.from(v.entries())),Z=At(N(M,"response","variants"),pe,{comment:L});return this.program.push(Z),Object.assign(z,{[M]:Z})},{});this.paths.add(A);let j=s.createLiteralTypeNode(s.createStringLiteral(L));this.registry.set(L,{input:y(T.name),positive:this.someOf(P.positive),negative:this.someOf(P.negative),response:s.createUnionTypeNode([s.createIndexedAccessTypeNode(y(this.interfaces.positive),j),s.createIndexedAccessTypeNode(y(this.interfaces.negative),j)]),encoded:s.createIntersectionTypeNode([y(P.positive.name),y(P.negative.name)])}),this.tags.set(L,g.getTags())}}),this.program.unshift(...this.aliases.values()),this.program.push(this.makePathType(),this.methodType,...this.makePublicInterfaces(),this.requestType),o!=="types"&&(this.program.push(this.makeEndpointTags(),this.makeParseRequestFn(),this.makeSubstituteFn(),this.makeImplementationType(),this.makeDefaultImplementation(),this.makeClientClass(n),this.makeSubscriptionClass(i)),this.usage.push(...this.makeUsageStatements(n,i)))}printUsage(t){return this.usage.length?this.usage.map(r=>typeof r=="string"?r:rr(r,t)).join(`
19
- `):void 0}print(t){let r=this.printUsage(t),o=r&&Ye.default.addSyntheticLeadingComment(Ye.default.addSyntheticLeadingComment(s.createEmptyStatement(),Ye.default.SyntaxKind.SingleLineCommentTrivia," Usage example:"),Ye.default.SyntaxKind.MultiLineCommentTrivia,`
20
- ${r}`);return this.program.concat(o||[]).map((n,i)=>rr(n,i<this.program.length?t:{...t,omitTrailingSemicolon:!0})).join(`
18
+ `))};var uo=e=>{e.startupLogo!==!1&&co(process.stdout);let t=e.errorHandler||Le,r=Kr(e.logger)?e.logger:new Ue(e.logger);r.debug("Running",{build:"v22.4.1 (CJS)",env:process.env.NODE_ENV||"development"}),ao(r);let o=so({logger:r,config:e}),s={getLogger:io(r),errorHandler:t},a=ro(s),c=to(s);return{...s,logger:r,notFoundHandler:a,parserFailureHandler:c,loggingMiddleware:o}},yo=(e,t)=>{let{logger:r,getLogger:o,notFoundHandler:n,loggingMiddleware:s}=uo(e);return Qt({app:e.app.use(s),routing:t,getLogger:o,config:e}),{notFoundHandler:n,logger:r}},fo=async(e,t)=>{let{logger:r,getLogger:o,notFoundHandler:n,parserFailureHandler:s,loggingMiddleware:a}=uo(e),c=(0,Tt.default)().disable("x-powered-by").use(a);if(e.compression){let b=await Fe("compression");c.use(b(typeof e.compression=="object"?e.compression:void 0))}let d={json:[e.jsonParser||Tt.default.json()],raw:[e.rawParser||Tt.default.raw(),no],upload:e.upload?await oo({config:e,getLogger:o}):[]};await e.beforeRouting?.({app:c,getLogger:o}),Qt({app:c,routing:t,getLogger:o,config:e,parsers:d}),c.use(s,n);let p=[],l=(b,f)=>()=>b.listen(f,()=>r.info("Listening",f)),g=[];if(e.http){let b=mo.default.createServer(c);p.push(b),g.push(l(b,e.http.listen))}if(e.https){let b=lo.default.createServer(e.https.options,c);p.push(b),g.push(l(b,e.https.listen))}return e.gracefulShutdown&&po({logger:r,servers:p,options:e.gracefulShutdown===!0?{}:e.gracefulShutdown}),{app:c,logger:r,servers:g.map(b=>b())}};var Lo=require("openapi3-ts/oas31"),Mo=require("ramda");var T=require("ramda");var go=e=>ge(e)&&"or"in e,ho=e=>ge(e)&&"and"in e,Wt=e=>!ho(e)&&!go(e),xo=e=>{let t=(0,T.filter)(Wt,e),r=(0,T.chain)((0,T.prop)("and"),(0,T.filter)(ho,e)),[o,n]=(0,T.partition)(Wt,r),s=(0,T.concat)(t,o),a=(0,T.filter)(go,e);return(0,T.map)((0,T.prop)("or"),(0,T.concat)(a,n)).reduce((d,p)=>ze(d,(0,T.map)(l=>Wt(l)?[l]:l.and,p),([l,g])=>(0,T.concat)(l,g)),(0,T.reject)(T.isEmpty,[s]))};var te=require("openapi3-ts/oas31"),m=require("ramda"),A=require("zod");var Oe=(e,{onEach:t,rules:r,onMissing:o,ctx:n={}})=>{let s=r[e._def[x]?.brand]||r[e._def.typeName],c=s?s(e,{...n,next:p=>Oe(p,{ctx:n,onEach:t,rules:r,onMissing:o})}):o(e,n),d=t&&t(e,{prev:c,...n});return d?{...c,...d}:c};var bo=["a-im","accept","accept-additions","accept-ch","accept-charset","accept-datetime","accept-encoding","accept-features","accept-language","accept-patch","accept-post","accept-ranges","accept-signature","access-control","access-control-allow-credentials","access-control-allow-headers","access-control-allow-methods","access-control-allow-origin","access-control-expose-headers","access-control-max-age","access-control-request-headers","access-control-request-method","age","allow","alpn","alt-svc","alt-used","alternates","amp-cache-transform","apply-to-redirect-ref","authentication-control","authentication-info","authorization","available-dictionary","c-ext","c-man","c-opt","c-pep","c-pep-info","cache-control","cache-status","cal-managed-id","caldav-timezones","capsule-protocol","cdn-cache-control","cdn-loop","cert-not-after","cert-not-before","clear-site-data","client-cert","client-cert-chain","close","cmcd-object","cmcd-request","cmcd-session","cmcd-status","cmsd-dynamic","cmsd-static","concealed-auth-export","configuration-context","connection","content-base","content-digest","content-disposition","content-encoding","content-id","content-language","content-length","content-location","content-md5","content-range","content-script-type","content-security-policy","content-security-policy-report-only","content-style-type","content-type","content-version","cookie","cookie2","cross-origin-embedder-policy","cross-origin-embedder-policy-report-only","cross-origin-opener-policy","cross-origin-opener-policy-report-only","cross-origin-resource-policy","cta-common-access-token","dasl","date","dav","default-style","delta-base","deprecation","depth","derived-from","destination","differential-id","dictionary-id","digest","dpop","dpop-nonce","early-data","ediint-features","etag","expect","expect-ct","expires","ext","forwarded","from","getprofile","hobareg","host","http2-settings","if","if-match","if-modified-since","if-none-match","if-range","if-schedule-tag-match","if-unmodified-since","im","include-referred-token-binding-id","isolation","keep-alive","label","last-event-id","last-modified","link","link-template","location","lock-token","man","max-forwards","memento-datetime","meter","method-check","method-check-expires","mime-version","negotiate","nel","odata-entityid","odata-isolation","odata-maxversion","odata-version","opt","optional-www-authenticate","ordering-type","origin","origin-agent-cluster","oscore","oslc-core-version","overwrite","p3p","pep","pep-info","permissions-policy","pics-label","ping-from","ping-to","position","pragma","prefer","preference-applied","priority","profileobject","protocol","protocol-info","protocol-query","protocol-request","proxy-authenticate","proxy-authentication-info","proxy-authorization","proxy-features","proxy-instruction","proxy-status","public","public-key-pins","public-key-pins-report-only","range","redirect-ref","referer","referer-root","referrer-policy","refresh","repeatability-client-id","repeatability-first-sent","repeatability-request-id","repeatability-result","replay-nonce","reporting-endpoints","repr-digest","retry-after","safe","schedule-reply","schedule-tag","sec-gpc","sec-purpose","sec-token-binding","sec-websocket-accept","sec-websocket-extensions","sec-websocket-key","sec-websocket-protocol","sec-websocket-version","security-scheme","server","server-timing","set-cookie","set-cookie2","setprofile","signature","signature-input","slug","soapaction","status-uri","strict-transport-security","sunset","surrogate-capability","surrogate-control","tcn","te","timeout","timing-allow-origin","topic","traceparent","tracestate","trailer","transfer-encoding","ttl","upgrade","urgency","uri","use-as-dictionary","user-agent","variant-vary","vary","via","want-content-digest","want-digest","want-repr-digest","warning","www-authenticate","x-content-type-options","x-frame-options"];var So=50,Oo="https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Date/toISOString",xn={integer:0,number:0,string:"",boolean:!1,object:{},null:null,array:[]},Ro=/:([A-Za-z0-9_]+)/g,bn=/^\d{4}-\d{2}-\d{2}$/,Sn=/^\d{2}:\d{2}:\d{2}(\.\d+)?$/,Tn=e=>e?/^\d{4}-\d{2}-\d{2}T\d{2}:\d{2}:\d{2}(\.\d+)?(([+-]\d{2}:\d{2})|Z)$/:/^\d{4}-\d{2}-\d{2}T\d{2}:\d{2}:\d{2}(\.\d+)?Z$/,On=e=>e.match(Ro)?.map(t=>t.slice(1))||[],Po=e=>e.replace(Ro,t=>`{${t.slice(1)}}`),Rn=({_def:e},{next:t})=>({...t(e.innerType),default:e[x]?.defaultLabel||e.defaultValue()}),Pn=({_def:{innerType:e}},{next:t})=>t(e),An=()=>({format:"any"}),wn=({},e)=>{if(e.isResponse)throw new q("Please use ez.upload() only for input.",e);return{type:"string",format:"binary"}},En=e=>{let t=e.unwrap();return{type:"string",format:t instanceof A.z.ZodString?t._def.checks.find(r=>r.kind==="base64")?"byte":"file":"binary"}},zn=({options:e},{next:t})=>({oneOf:e.map(t)}),In=({options:e,discriminator:t},{next:r})=>({discriminator:{propertyName:t},oneOf:e.map(r)}),vn=(e,t)=>{if(Array.isArray(e)&&Array.isArray(t))return(0,m.concat)(e,t);if(e===t)return t;throw new Error("Can not flatten properties")},kn=e=>{let[t,r]=e.filter(te.isSchemaObject).filter(n=>n.type==="object"&&Object.keys(n).every(s=>["type","properties","required","examples"].includes(s)));if(!t||!r)throw new Error("Can not flatten objects");let o={type:"object"};return(t.properties||r.properties)&&(o.properties=(0,m.mergeDeepWith)(vn,t.properties||{},r.properties||{})),(t.required||r.required)&&(o.required=(0,m.union)(t.required||[],r.required||[])),(t.examples||r.examples)&&(o.examples=ze(t.examples||[],r.examples||[],([n,s])=>(0,m.mergeDeepRight)(n,s))),o},Zn=({_def:{left:e,right:t}},{next:r})=>{let o=[e,t].map(r);try{return kn(o)}catch{}return{allOf:o}},Cn=(e,{next:t})=>t(e.unwrap()),Nn=(e,{next:t})=>t(e.unwrap()),jn=(e,{next:t})=>{let r=t(e.unwrap());return(0,te.isSchemaObject)(r)&&(r.type=wo(r)),r},Ao=e=>{let t=(0,m.toLower)((0,m.type)(e));return typeof e=="bigint"?"integer":t==="number"||t==="string"||t==="boolean"||t==="object"||t==="null"||t==="array"?t:void 0},To=e=>({type:Ao(Object.values(e.enum)[0]),enum:Object.values(e.enum)}),Ln=({value:e})=>({type:Ao(e),const:e}),Mn=(e,{isResponse:t,next:r})=>{let o=Object.keys(e.shape),n=c=>t&&_e(c)?c instanceof A.z.ZodOptional:c.isOptional(),s=o.filter(c=>!n(e.shape[c])),a={type:"object"};return o.length&&(a.properties=Ot(e,r)),s.length&&(a.required=s),a},Un=()=>({type:"null"}),Hn=({},e)=>{if(e.isResponse)throw new q("Please use ez.dateOut() for output.",e);return{description:"YYYY-MM-DDTHH:mm:ss.sssZ",type:"string",format:"date-time",pattern:/^\d{4}-\d{2}-\d{2}(T\d{2}:\d{2}:\d{2}(\.\d+)?)?Z?$/.source,externalDocs:{url:Oo}}},Kn=({},e)=>{if(!e.isResponse)throw new q("Please use ez.dateIn() for input.",e);return{description:"YYYY-MM-DDTHH:mm:ss.sssZ",type:"string",format:"date-time",externalDocs:{url:Oo}}},Dn=({},e)=>{throw new q(`Using z.date() within ${e.isResponse?"output":"input"} schema is forbidden. Please use ez.date${e.isResponse?"Out":"In"}() instead. Check out the documentation for details.`,e)},Fn=()=>({type:"boolean"}),qn=()=>({type:"integer",format:"bigint"}),Bn=e=>e.every(t=>t instanceof A.z.ZodLiteral),$n=({keySchema:e,valueSchema:t},{next:r})=>{if(e instanceof A.z.ZodEnum||e instanceof A.z.ZodNativeEnum){let o=Object.values(e.enum),n={type:"object"};return o.length&&(n.properties=Ot(A.z.object((0,m.fromPairs)((0,m.xprod)(o,[t]))),r),n.required=o),n}if(e instanceof A.z.ZodLiteral)return{type:"object",properties:Ot(A.z.object({[e.value]:t}),r),required:[e.value]};if(e instanceof A.z.ZodUnion&&Bn(e.options)){let o=(0,m.map)(s=>`${s.value}`,e.options),n=(0,m.fromPairs)((0,m.xprod)(o,[t]));return{type:"object",properties:Ot(A.z.object(n),r),required:o}}return{type:"object",additionalProperties:r(t)}},Vn=({_def:{minLength:e,maxLength:t},element:r},{next:o})=>{let n={type:"array",items:o(r)};return e&&(n.minItems=e.value),t&&(n.maxItems=t.value),n},_n=({items:e,_def:{rest:t}},{next:r})=>({type:"array",prefixItems:e.map(r),items:t===null?{not:{}}:r(t)}),Gn=({isEmail:e,isURL:t,minLength:r,maxLength:o,isUUID:n,isCUID:s,isCUID2:a,isULID:c,isIP:d,isEmoji:p,isDatetime:l,isCIDR:g,isDate:b,isTime:f,isBase64:P,isNANOID:O,isBase64url:j,isDuration:L,_def:{checks:S}})=>{let R=S.find(Z=>Z.kind==="regex"),M=S.find(Z=>Z.kind==="datetime"),v=S.some(Z=>Z.kind==="jwt"),K=S.find(Z=>Z.kind==="length"),k={type:"string"},le={"date-time":l,byte:P,base64url:j,date:b,time:f,duration:L,email:e,url:t,uuid:n,cuid:s,cuid2:a,ulid:c,nanoid:O,jwt:v,ip:d,cidr:g,emoji:p};for(let Z in le)if(le[Z]){k.format=Z;break}return K&&([k.minLength,k.maxLength]=[K.value,K.value]),r!==null&&(k.minLength=r),o!==null&&(k.maxLength=o),b&&(k.pattern=bn.source),f&&(k.pattern=Sn.source),l&&(k.pattern=Tn(M?.offset).source),R&&(k.pattern=R.regex.source),k},Yn=({isInt:e,maxValue:t,minValue:r,_def:{checks:o}})=>{let n=o.find(g=>g.kind==="min"),s=r===null?e?Number.MIN_SAFE_INTEGER:-Number.MAX_VALUE:r,a=n?n.inclusive:!0,c=o.find(g=>g.kind==="max"),d=t===null?e?Number.MAX_SAFE_INTEGER:Number.MAX_VALUE:t,p=c?c.inclusive:!0,l={type:e?"integer":"number",format:e?"int64":"double"};return a?l.minimum=s:l.exclusiveMinimum=s,p?l.maximum=d:l.exclusiveMaximum=d,l},Ot=({shape:e},t)=>(0,m.map)(t,e),Jn=e=>{let t=Array.isArray(e.type)?e.type[0]:e.type;return xn?.[t]},wo=({type:e})=>e==="null"?e:typeof e=="string"?[e,"null"]:e?[...new Set(e).add("null")]:"null",Qn=(e,{isResponse:t,next:r})=>{let o=r(e.innerType()),{effect:n}=e._def;if(t&&n.type==="transform"&&(0,te.isSchemaObject)(o)){let s=at(e,Jn(o));return s&&["number","string","boolean"].includes(s)?{type:s}:r(A.z.any())}if(!t&&n.type==="preprocess"&&(0,te.isSchemaObject)(o)){let{type:s,...a}=o;return{...a,format:`${a.format||s} (preprocessed)`}}return o},Wn=({_def:e},{isResponse:t,next:r})=>r(e[t?"out":"in"]),Xn=(e,{next:t})=>t(e.unwrap()),es=(e,{next:t,makeRef:r})=>r(e,()=>t(e.schema)),ts=(e,{next:t})=>t(e.unwrap().shape.raw),Eo=e=>e.length?(0,m.fromPairs)((0,m.zip)((0,m.times)(t=>`example${t+1}`,e.length),(0,m.map)((0,m.objOf)("value"),e))):void 0,zo=(e,t,r=[])=>(0,m.pipe)(ee,(0,m.map)((0,m.when)(o=>(0,m.type)(o)==="Object",(0,m.omit)(r))),Eo)({schema:e,variant:t?"parsed":"original",validate:!0}),rs=(e,t)=>(0,m.pipe)(ee,(0,m.filter)((0,m.has)(t)),(0,m.pluck)(t),Eo)({schema:e,variant:"original",validate:!0}),Re=e=>e instanceof A.z.ZodObject?e:e instanceof A.z.ZodBranded?Re(e.unwrap()):e instanceof A.z.ZodUnion||e instanceof A.z.ZodDiscriminatedUnion?e.options.map(t=>Re(t)).reduce((t,r)=>t.merge(r.partial()),A.z.object({})):e instanceof A.z.ZodEffects?Re(e._def.schema):e instanceof A.z.ZodPipeline?Re(e._def.in):Re(e._def.left).merge(Re(e._def.right)),os=(e,t)=>t?.includes(e)||e.startsWith("x-")||bo.includes(e),Io=({path:e,method:t,schema:r,inputSources:o,makeRef:n,composition:s,brandHandling:a,isHeader:c,security:d,description:p=`${t.toUpperCase()} ${e} Parameter`})=>{let{shape:l}=Re(r),g=On(e),b=o.includes("query"),f=o.includes("params"),P=o.includes("headers"),O=S=>f&&g.includes(S),j=(0,m.chain)((0,m.filter)(S=>S.type==="header"),d??[]).map(({name:S})=>S),L=S=>P&&(c?.(S,t,e)??os(S,j));return Object.keys(l).reduce((S,R)=>{let M=O(R)?"path":L(R)?"header":b?"query":void 0;if(!M)return S;let v=Oe(l[R],{rules:{...a,...er},onEach:tr,onMissing:rr,ctx:{isResponse:!1,makeRef:n,path:e,method:t}}),K=s==="components"?n(l[R],v,ae(p,R)):v;return S.concat({name:R,in:M,required:!l[R].isOptional(),description:v.description||p,schema:K,examples:rs(r,R)})},[])},er={ZodString:Gn,ZodNumber:Yn,ZodBigInt:qn,ZodBoolean:Fn,ZodNull:Un,ZodArray:Vn,ZodTuple:_n,ZodRecord:$n,ZodObject:Mn,ZodLiteral:Ln,ZodIntersection:Zn,ZodUnion:zn,ZodAny:An,ZodDefault:Rn,ZodEnum:To,ZodNativeEnum:To,ZodEffects:Qn,ZodOptional:Cn,ZodNullable:jn,ZodDiscriminatedUnion:In,ZodBranded:Xn,ZodDate:Dn,ZodCatch:Pn,ZodPipeline:Wn,ZodLazy:es,ZodReadonly:Nn,[Q]:En,[ke]:wn,[be]:Kn,[xe]:Hn,[pe]:ts},tr=(e,{isResponse:t,prev:r})=>{if((0,te.isReferenceObject)(r))return{};let{description:o}=e,n=e instanceof A.z.ZodLazy,s=r.type!==void 0,a=t&&_e(e),c=!n&&s&&!a&&e.isNullable(),d={};if(o&&(d.description=o),c&&(d.type=wo(r)),!n){let p=ee({schema:e,variant:t?"parsed":"original",validate:!0});p.length&&(d.examples=p.slice())}return d},rr=(e,t)=>{throw new q(`Zod type ${e.constructor.name} is unsupported.`,t)},Xt=(e,t)=>{if((0,te.isReferenceObject)(e))return e;let r={...e};return r.properties&&(r.properties=(0,m.omit)(t,r.properties)),r.examples&&(r.examples=r.examples.map(o=>(0,m.omit)(t,o))),r.required&&(r.required=r.required.filter(o=>!t.includes(o))),r.allOf&&(r.allOf=r.allOf.map(o=>Xt(o,t))),r.oneOf&&(r.oneOf=r.oneOf.map(o=>Xt(o,t))),r},vo=e=>(0,te.isReferenceObject)(e)?e:(0,m.omit)(["examples"],e),ko=({method:e,path:t,schema:r,mimeTypes:o,variant:n,makeRef:s,composition:a,hasMultipleStatusCodes:c,statusCode:d,brandHandling:p,description:l=`${e.toUpperCase()} ${t} ${Kt(n)} response ${c?d:""}`.trim()})=>{if(!o)return{description:l};let g=vo(Oe(r,{rules:{...p,...er},onEach:tr,onMissing:rr,ctx:{isResponse:!0,makeRef:s,path:t,method:e}})),b={schema:a==="components"?s(r,g,ae(l)):g,examples:zo(r,!0)};return{description:l,content:(0,m.fromPairs)((0,m.xprod)(o,[b]))}},ns=({format:e})=>{let t={type:"http",scheme:"bearer"};return e&&(t.bearerFormat=e),t},ss=({name:e},t)=>{let r={type:"apiKey",in:"query",name:e};return t?.includes("body")&&(t?.includes("query")?(r["x-in-alternative"]="body",r.description=`${e} CAN also be supplied within the request body`):(r["x-in-actual"]="body",r.description=`${e} MUST be supplied within the request body instead of query`)),r},is=({name:e})=>({type:"apiKey",in:"header",name:e}),as=({name:e})=>({type:"apiKey",in:"cookie",name:e}),ps=({url:e})=>({type:"openIdConnect",openIdConnectUrl:e}),cs=({flows:e={}})=>({type:"oauth2",flows:(0,m.map)(t=>({...t,scopes:t.scopes||{}}),(0,m.reject)(m.isNil,e))}),Zo=(e,t=[])=>{let r=o=>o.type==="basic"?{type:"http",scheme:"basic"}:o.type==="bearer"?ns(o):o.type==="input"?ss(o,t):o.type==="header"?is(o):o.type==="cookie"?as(o):o.type==="openid"?ps(o):cs(o);return e.map(o=>o.map(r))},Co=(e,t,r)=>e.map(o=>o.reduce((n,s)=>{let a=r(s),c=["oauth2","openIdConnect"].includes(s.type);return Object.assign(n,{[a]:c?t:[]})},{})),No=({method:e,path:t,schema:r,mimeType:o,makeRef:n,composition:s,brandHandling:a,paramNames:c,description:d=`${e.toUpperCase()} ${t} Request body`})=>{let p=vo(Xt(Oe(r,{rules:{...a,...er},onEach:tr,onMissing:rr,ctx:{isResponse:!1,makeRef:n,path:t,method:e}}),c)),l={schema:s==="components"?n(r,p,ae(d)):p,examples:zo(r,!1,c)};return{description:d,content:{[o]:l}}},jo=e=>Object.entries(e).reduce((t,[r,o])=>{if(!o)return t;let n={name:r,description:typeof o=="string"?o:o.description};return typeof o=="object"&&o.url&&(n.externalDocs={url:o.url}),t.concat(n)},[]),or=e=>e.length<=So?e:e.slice(0,So-1)+"\u2026";var Rt=class extends Lo.OpenApiBuilder{lastSecuritySchemaIds=new Map;lastOperationIdSuffixes=new Map;references=new Map;makeRef(t,r,o=this.references.get(t)){return o||(o=`Schema${this.references.size+1}`,this.references.set(t,o),typeof r=="function"&&(r=r())),typeof r=="object"&&this.addSchema(o,r),{$ref:`#/components/schemas/${o}`}}ensureUniqOperationId(t,r,o){let n=o||ae(r,t),s=this.lastOperationIdSuffixes.get(n);if(s===void 0)return this.lastOperationIdSuffixes.set(n,1),n;if(o)throw new q(`Duplicated operationId: "${o}"`,{method:r,isResponse:!1,path:t});return s++,this.lastOperationIdSuffixes.set(n,s),`${n}${s}`}ensureUniqSecuritySchemaName(t){let r=JSON.stringify(t);for(let n in this.rootDoc.components?.securitySchemes||{})if(r===JSON.stringify(this.rootDoc.components?.securitySchemes?.[n]))return n;let o=(this.lastSecuritySchemaIds.get(t.type)||0)+1;return this.lastSecuritySchemaIds.set(t.type,o),`${t.type.toUpperCase()}_${o}`}constructor({routing:t,config:r,title:o,version:n,serverUrl:s,descriptions:a,brandHandling:c,tags:d,isHeader:p,hasSummaryFromDescription:l=!0,composition:g="inline"}){super(),this.addInfo({title:o,version:n});for(let f of typeof s=="string"?[s]:s)this.addServer({url:f});qe({routing:t,onEndpoint:(f,P,O)=>{let j={path:P,method:O,endpoint:f,composition:g,brandHandling:c,makeRef:this.makeRef.bind(this)},[L,S]=["short","long"].map(f.getDescription.bind(f)),R=L?or(L):l&&S?or(S):void 0,M=r.inputSources?.[O]||Ut[O],v=this.ensureUniqOperationId(P,O,f.getOperationId(O)),K=xo(f.getSecurity()),k=Io({...j,inputSources:M,isHeader:p,security:K,schema:f.getSchema("input"),description:a?.requestParameter?.call(null,{method:O,path:P,operationId:v})}),le={};for(let re of je){let ue=f.getResponses(re);for(let{mimeTypes:Lt,schema:rt,statusCodes:ot}of ue)for(let Mt of ot)le[Mt]=ko({...j,variant:re,schema:rt,mimeTypes:Lt,statusCode:Mt,hasMultipleStatusCodes:ue.length>1||ot.length>1,description:a?.[`${re}Response`]?.call(null,{method:O,path:P,operationId:v,statusCode:Mt})})}let Z=M.includes("body")?No({...j,paramNames:(0,Mo.pluck)("name",k),schema:f.getSchema("input"),mimeType:I[f.getRequestType()],description:a?.requestBody?.call(null,{method:O,path:P,operationId:v})}):void 0,jt=Co(Zo(K,M),f.getScopes(),re=>{let ue=this.ensureUniqSecuritySchemaName(re);return this.addSecurityScheme(ue,re),ue});this.addPath(Po(P),{[O]:{operationId:v,summary:R,description:S,tags:pt(f.getTags()),parameters:pt(k),requestBody:Z,security:pt(jt),responses:le}})}}),d&&(this.rootDoc.tags=jo(d))}};var Pt=require("node-mocks-http"),ds=e=>(0,Pt.createRequest)({...e,headers:{"content-type":I.json,...e?.headers}}),ms=e=>(0,Pt.createResponse)(e),ls=e=>{let t={warn:[],error:[],info:[],debug:[]};return new Proxy(e||{},{get(r,o,n){return o==="_getLogs"?()=>t:Dr(o)?(...s)=>t[o].push(s):Reflect.get(r,o,n)}})},Uo=({requestProps:e,responseOptions:t,configProps:r,loggerProps:o})=>{let n=ds(e),s=ms({req:n,...t});s.req=t?.req||n,n.res=s;let a=ls(o),c={cors:!1,logger:a,...r};return{requestMock:n,responseMock:s,loggerMock:a,configMock:c}},Ho=async({endpoint:e,...t})=>{let{requestMock:r,responseMock:o,loggerMock:n,configMock:s}=Uo(t);return await e.execute({request:r,response:o,config:s,logger:n}),{requestMock:r,responseMock:o,loggerMock:n}},Ko=async({middleware:e,options:t={},errorHandler:r,...o})=>{let{requestMock:n,responseMock:s,loggerMock:a,configMock:c}=Uo(o),d=it(n,c.inputSources);try{let p=await e.execute({request:n,response:s,logger:a,input:d,options:t});return{requestMock:n,responseMock:s,loggerMock:a,output:p}}catch(p){if(!r)throw p;return r(ie(p),s),{requestMock:n,responseMock:s,loggerMock:a,output:{}}}};var _o=require("ramda"),tt=U(require("typescript"),1),Go=require("zod");var $o=require("ramda"),Y=U(require("typescript"),1);var Do=["get","post","put","delete","patch"];var Be=require("ramda"),u=U(require("typescript"),1),i=u.default.factory,At=[i.createModifier(u.default.SyntaxKind.ExportKeyword)],us=[i.createModifier(u.default.SyntaxKind.AsyncKeyword)],Xe={public:[i.createModifier(u.default.SyntaxKind.PublicKeyword)],protectedReadonly:[i.createModifier(u.default.SyntaxKind.ProtectedKeyword),i.createModifier(u.default.SyntaxKind.ReadonlyKeyword)]},nr=(e,t)=>u.default.addSyntheticLeadingComment(e,u.default.SyntaxKind.MultiLineCommentTrivia,`* ${t} `,!0),sr=(e,t)=>{let r=u.default.createSourceFile("print.ts","",u.default.ScriptTarget.Latest,!1,u.default.ScriptKind.TS);return u.default.createPrinter(t).printNode(u.default.EmitHint.Unspecified,e,r)},ys=/^[A-Za-z_$][A-Za-z0-9_$]*$/,ir=e=>typeof e=="string"&&ys.test(e)?i.createIdentifier(e):z(e),wt=(e,...t)=>i.createTemplateExpression(i.createTemplateHead(e),t.map(([r,o=""],n)=>i.createTemplateSpan(r,n===t.length-1?i.createTemplateTail(o):i.createTemplateMiddle(o)))),Et=(e,{type:t,mod:r,init:o,optional:n}={})=>i.createParameterDeclaration(r,void 0,e,n?i.createToken(u.default.SyntaxKind.QuestionToken):void 0,t?y(t):void 0,o),$e=e=>Object.entries(e).map(([t,r])=>Et(t,typeof r=="string"||typeof r=="number"||typeof r=="object"&&"kind"in r?{type:r}:r)),ar=(e,t=[])=>i.createConstructorDeclaration(Xe.public,e,i.createBlock(t)),y=(e,t)=>typeof e=="number"?i.createKeywordTypeNode(e):typeof e=="string"||u.default.isIdentifier(e)?i.createTypeReferenceNode(e,t&&(0,Be.map)(y,t)):e,pr=y("Record",[u.default.SyntaxKind.StringKeyword,u.default.SyntaxKind.AnyKeyword]),Pe=(e,t,{isOptional:r,comment:o}={})=>{let n=i.createPropertySignature(void 0,ir(e),r?i.createToken(u.default.SyntaxKind.QuestionToken):void 0,y(t));return o?nr(n,o):n},cr=e=>u.default.setEmitFlags(e,u.default.EmitFlags.SingleLine),dr=(...e)=>i.createArrayBindingPattern(e.map(t=>i.createBindingElement(void 0,void 0,t))),N=(e,t,{type:r,expose:o}={})=>i.createVariableStatement(o&&At,i.createVariableDeclarationList([i.createVariableDeclaration(e,void 0,r?y(r):void 0,t)],u.default.NodeFlags.Const)),mr=(e,t)=>X(e,i.createUnionTypeNode((0,Be.map)(F,t)),{expose:!0}),X=(e,t,{expose:r,comment:o,params:n}={})=>{let s=i.createTypeAliasDeclaration(r?At:void 0,e,n&&fr(n),t);return o?nr(s,o):s},Fo=(e,t)=>i.createPropertyDeclaration(Xe.public,e,void 0,y(t),void 0),lr=(e,t,r,{typeParams:o,returns:n}={})=>i.createMethodDeclaration(Xe.public,void 0,e,void 0,o&&fr(o),t,n,i.createBlock(r)),ur=(e,t,{typeParams:r}={})=>i.createClassDeclaration(At,e,r&&fr(r),void 0,t),yr=e=>i.createTypeOperatorNode(u.default.SyntaxKind.KeyOfKeyword,y(e)),zt=e=>y(Promise.name,[e]),It=(e,t,{expose:r,comment:o}={})=>{let n=i.createInterfaceDeclaration(r?At:void 0,e,void 0,void 0,t);return o?nr(n,o):n},fr=e=>(Array.isArray(e)?e.map(t=>(0,Be.pair)(t,void 0)):Object.entries(e)).map(([t,r])=>{let{type:o,init:n}=typeof r=="object"&&"init"in r?r:{type:r};return i.createTypeParameterDeclaration([],t,o?y(o):void 0,n?y(n):void 0)}),Ae=(e,t,{isAsync:r}={})=>i.createArrowFunction(r?us:void 0,void 0,Array.isArray(e)?(0,Be.map)(Et,e):$e(e),void 0,void 0,t),w=e=>e,et=(e,t,r)=>i.createConditionalExpression(e,i.createToken(u.default.SyntaxKind.QuestionToken),t,i.createToken(u.default.SyntaxKind.ColonToken),r),E=(e,...t)=>(...r)=>i.createCallExpression(t.reduce((o,n)=>typeof n=="string"||u.default.isIdentifier(n)?i.createPropertyAccessExpression(o,n):i.createElementAccessExpression(o,n),typeof e=="string"?i.createIdentifier(e):e),void 0,r),Ve=(e,...t)=>i.createNewExpression(i.createIdentifier(e),void 0,t),vt=(e,t)=>y("Extract",[e,t]),gr=(e,t)=>i.createExpressionStatement(i.createBinaryExpression(e,i.createToken(u.default.SyntaxKind.EqualsToken),t)),G=(e,t)=>i.createIndexedAccessTypeNode(y(e),y(t)),qo=e=>i.createUnionTypeNode([y(e),zt(e)]),hr=(e,t)=>i.createFunctionTypeNode(void 0,$e(e),y(t)),z=e=>typeof e=="number"?i.createNumericLiteral(e):typeof e=="boolean"?e?i.createTrue():i.createFalse():e===null?i.createNull():i.createStringLiteral(e),F=e=>i.createLiteralTypeNode(z(e)),fs=[u.default.SyntaxKind.AnyKeyword,u.default.SyntaxKind.BigIntKeyword,u.default.SyntaxKind.BooleanKeyword,u.default.SyntaxKind.NeverKeyword,u.default.SyntaxKind.NumberKeyword,u.default.SyntaxKind.ObjectKeyword,u.default.SyntaxKind.StringKeyword,u.default.SyntaxKind.SymbolKeyword,u.default.SyntaxKind.UndefinedKeyword,u.default.SyntaxKind.UnknownKeyword,u.default.SyntaxKind.VoidKeyword],Bo=e=>fs.includes(e.kind);var kt=class{constructor(t){this.serverUrl=t}paths=new Set;tags=new Map;registry=new Map;ids={pathType:i.createIdentifier("Path"),implementationType:i.createIdentifier("Implementation"),keyParameter:i.createIdentifier("key"),pathParameter:i.createIdentifier("path"),paramsArgument:i.createIdentifier("params"),ctxArgument:i.createIdentifier("ctx"),methodParameter:i.createIdentifier("method"),requestParameter:i.createIdentifier("request"),eventParameter:i.createIdentifier("event"),dataParameter:i.createIdentifier("data"),handlerParameter:i.createIdentifier("handler"),msgParameter:i.createIdentifier("msg"),parseRequestFn:i.createIdentifier("parseRequest"),substituteFn:i.createIdentifier("substitute"),provideMethod:i.createIdentifier("provide"),onMethod:i.createIdentifier("on"),implementationArgument:i.createIdentifier("implementation"),hasBodyConst:i.createIdentifier("hasBody"),undefinedValue:i.createIdentifier("undefined"),responseConst:i.createIdentifier("response"),restConst:i.createIdentifier("rest"),searchParamsConst:i.createIdentifier("searchParams"),defaultImplementationConst:i.createIdentifier("defaultImplementation"),clientConst:i.createIdentifier("client"),contentTypeConst:i.createIdentifier("contentType"),isJsonConst:i.createIdentifier("isJSON"),sourceProp:i.createIdentifier("source")};interfaces={input:i.createIdentifier("Input"),positive:i.createIdentifier("PositiveResponse"),negative:i.createIdentifier("NegativeResponse"),encoded:i.createIdentifier("EncodedResponse"),response:i.createIdentifier("Response")};methodType=mr("Method",Do);someOfType=X("SomeOf",G("T",yr("T")),{params:["T"]});requestType=X("Request",yr(this.interfaces.input),{expose:!0});someOf=({name:t})=>y(this.someOfType.name,[t]);makePathType=()=>mr(this.ids.pathType,Array.from(this.paths));makePublicInterfaces=()=>Object.keys(this.interfaces).map(t=>It(this.interfaces[t],Array.from(this.registry).map(([r,o])=>Pe(r,o[t])),{expose:!0}));makeEndpointTags=()=>N("endpointTags",i.createObjectLiteralExpression(Array.from(this.tags).map(([t,r])=>i.createPropertyAssignment(ir(t),i.createArrayLiteralExpression((0,$o.map)(z,r))))),{expose:!0});makeImplementationType=()=>X(this.ids.implementationType,hr({[this.ids.methodParameter.text]:this.methodType.name,[this.ids.pathParameter.text]:Y.default.SyntaxKind.StringKeyword,[this.ids.paramsArgument.text]:pr,[this.ids.ctxArgument.text]:{optional:!0,type:"T"}},zt(Y.default.SyntaxKind.AnyKeyword)),{expose:!0,params:{T:{init:Y.default.SyntaxKind.UnknownKeyword}}});makeParseRequestFn=()=>N(this.ids.parseRequestFn,Ae({[this.ids.requestParameter.text]:Y.default.SyntaxKind.StringKeyword},i.createAsExpression(E(this.ids.requestParameter,w("split"))(i.createRegularExpressionLiteral("/ (.+)/"),z(2)),i.createTupleTypeNode([y(this.methodType.name),y(this.ids.pathType)]))));makeSubstituteFn=()=>N(this.ids.substituteFn,Ae({[this.ids.pathParameter.text]:Y.default.SyntaxKind.StringKeyword,[this.ids.paramsArgument.text]:pr},i.createBlock([N(this.ids.restConst,i.createObjectLiteralExpression([i.createSpreadAssignment(this.ids.paramsArgument)])),i.createForInStatement(i.createVariableDeclarationList([i.createVariableDeclaration(this.ids.keyParameter)],Y.default.NodeFlags.Const),this.ids.paramsArgument,i.createBlock([gr(this.ids.pathParameter,E(this.ids.pathParameter,w("replace"))(wt(":",[this.ids.keyParameter]),Ae([],i.createBlock([i.createExpressionStatement(i.createDeleteExpression(i.createElementAccessExpression(this.ids.restConst,this.ids.keyParameter))),i.createReturnStatement(i.createElementAccessExpression(this.ids.paramsArgument,this.ids.keyParameter))]))))])),i.createReturnStatement(i.createAsExpression(i.createArrayLiteralExpression([this.ids.pathParameter,this.ids.restConst]),y("const")))])));makeProvider=()=>lr(this.ids.provideMethod,$e({[this.ids.requestParameter.text]:"K",[this.ids.paramsArgument.text]:G(this.interfaces.input,"K"),[this.ids.ctxArgument.text]:{optional:!0,type:"T"}}),[N(dr(this.ids.methodParameter,this.ids.pathParameter),E(this.ids.parseRequestFn)(this.ids.requestParameter)),i.createReturnStatement(E(i.createThis(),this.ids.implementationArgument)(this.ids.methodParameter,i.createSpreadElement(E(this.ids.substituteFn)(this.ids.pathParameter,this.ids.paramsArgument)),this.ids.ctxArgument))],{typeParams:{K:this.requestType.name},returns:zt(G(this.interfaces.response,"K"))});makeClientClass=t=>ur(t,[ar([Et(this.ids.implementationArgument,{type:y(this.ids.implementationType,["T"]),mod:Xe.protectedReadonly,init:this.ids.defaultImplementationConst})]),this.makeProvider()],{typeParams:["T"]});makeSearchParams=t=>wt("?",[Ve(URLSearchParams.name,t)]);makeFetchURL=()=>Ve(URL.name,wt("",[this.ids.pathParameter],[this.ids.searchParamsConst]),z(this.serverUrl));makeDefaultImplementation=()=>{let t=i.createPropertyAssignment(w("method"),E(this.ids.methodParameter,w("toUpperCase"))()),r=i.createPropertyAssignment(w("headers"),et(this.ids.hasBodyConst,i.createObjectLiteralExpression([i.createPropertyAssignment(z("Content-Type"),z(I.json))]),this.ids.undefinedValue)),o=i.createPropertyAssignment(w("body"),et(this.ids.hasBodyConst,E(JSON[Symbol.toStringTag],w("stringify"))(this.ids.paramsArgument),this.ids.undefinedValue)),n=N(this.ids.responseConst,i.createAwaitExpression(E(fetch.name)(this.makeFetchURL(),i.createObjectLiteralExpression([t,r,o])))),s=N(this.ids.hasBodyConst,i.createLogicalNot(E(i.createArrayLiteralExpression([z("get"),z("delete")]),w("includes"))(this.ids.methodParameter))),a=N(this.ids.searchParamsConst,et(this.ids.hasBodyConst,z(""),this.makeSearchParams(this.ids.paramsArgument))),c=N(this.ids.contentTypeConst,E(this.ids.responseConst,w("headers"),w("get"))(z("content-type"))),d=i.createIfStatement(i.createPrefixUnaryExpression(Y.default.SyntaxKind.ExclamationToken,this.ids.contentTypeConst),i.createReturnStatement()),p=N(this.ids.isJsonConst,E(this.ids.contentTypeConst,w("startsWith"))(z(I.json))),l=i.createReturnStatement(E(this.ids.responseConst,et(this.ids.isJsonConst,z(w("json")),z(w("text"))))());return N(this.ids.defaultImplementationConst,Ae([this.ids.methodParameter,this.ids.pathParameter,this.ids.paramsArgument],i.createBlock([s,a,n,c,d,p,l]),{isAsync:!0}),{type:this.ids.implementationType})};makeSubscriptionConstructor=()=>ar($e({request:"K",params:G(this.interfaces.input,"K")}),[N(dr(this.ids.pathParameter,this.ids.restConst),E(this.ids.substituteFn)(i.createElementAccessExpression(E(this.ids.parseRequestFn)(this.ids.requestParameter),z(1)),this.ids.paramsArgument)),N(this.ids.searchParamsConst,this.makeSearchParams(this.ids.restConst)),gr(i.createPropertyAccessExpression(i.createThis(),this.ids.sourceProp),Ve("EventSource",this.makeFetchURL()))]);makeEventNarrow=t=>i.createTypeLiteralNode([Pe(w("event"),t)]);makeOnMethod=()=>lr(this.ids.onMethod,$e({[this.ids.eventParameter.text]:"E",[this.ids.handlerParameter.text]:hr({[this.ids.dataParameter.text]:G(vt("R",cr(this.makeEventNarrow("E"))),F(w("data")))},qo(Y.default.SyntaxKind.VoidKeyword))}),[i.createExpressionStatement(E(i.createThis(),this.ids.sourceProp,w("addEventListener"))(this.ids.eventParameter,Ae([this.ids.msgParameter],E(this.ids.handlerParameter)(E(JSON[Symbol.toStringTag],w("parse"))(i.createPropertyAccessExpression(i.createParenthesizedExpression(i.createAsExpression(this.ids.msgParameter,y(MessageEvent.name))),w("data"))))))),i.createReturnStatement(i.createThis())],{typeParams:{E:G("R",F(w("event")))}});makeSubscriptionClass=t=>ur(t,[Fo(this.ids.sourceProp,"EventSource"),this.makeSubscriptionConstructor(),this.makeOnMethod()],{typeParams:{K:vt(this.requestType.name,i.createTemplateLiteralType(i.createTemplateHead("get "),[i.createTemplateLiteralTypeSpan(y(Y.default.SyntaxKind.StringKeyword),i.createTemplateTail(""))])),R:vt(G(this.interfaces.positive,"K"),cr(this.makeEventNarrow(Y.default.SyntaxKind.StringKeyword)))}});makeUsageStatements=(t,r)=>[N(this.ids.clientConst,Ve(t)),E(this.ids.clientConst,this.ids.provideMethod)(z("get /v1/user/retrieve"),i.createObjectLiteralExpression([i.createPropertyAssignment("id",z("10"))])),E(Ve(r,z("get /v1/events/stream"),i.createObjectLiteralExpression()),this.ids.onMethod)(z("time"),Ae(["time"],i.createBlock([])))]};var H=require("ramda"),h=U(require("typescript"),1),Zt=require("zod");var{factory:$}=h.default,gs={[h.default.SyntaxKind.AnyKeyword]:"",[h.default.SyntaxKind.BigIntKeyword]:BigInt(0),[h.default.SyntaxKind.BooleanKeyword]:!1,[h.default.SyntaxKind.NumberKeyword]:0,[h.default.SyntaxKind.ObjectKeyword]:{},[h.default.SyntaxKind.StringKeyword]:"",[h.default.SyntaxKind.UndefinedKeyword]:void 0},xr={name:(0,H.path)(["name","text"]),type:(0,H.path)(["type"]),optional:(0,H.path)(["questionToken"])},hs=({value:e})=>F(e),xs=({shape:e},{isResponse:t,next:r,optionalPropStyle:{withQuestionMark:o}})=>{let n=Object.entries(e).map(([s,a])=>{let c=t&&_e(a)?a instanceof Zt.z.ZodOptional:a.isOptional();return Pe(s,r(a),{isOptional:c&&o,comment:a.description})});return $.createTypeLiteralNode(n)},bs=({element:e},{next:t})=>$.createArrayTypeNode(t(e)),Ss=({options:e})=>$.createUnionTypeNode(e.map(F)),Vo=({options:e},{next:t})=>{let r=new Map;for(let o of e){let n=t(o);r.set(Bo(n)?n.kind:n,n)}return $.createUnionTypeNode(Array.from(r.values()))},Ts=e=>gs?.[e.kind],Os=(e,{next:t,isResponse:r})=>{let o=t(e.innerType());if(r&&e._def.effect.type==="transform"){let n=at(e,Ts(o)),s={number:h.default.SyntaxKind.NumberKeyword,bigint:h.default.SyntaxKind.BigIntKeyword,boolean:h.default.SyntaxKind.BooleanKeyword,string:h.default.SyntaxKind.StringKeyword,undefined:h.default.SyntaxKind.UndefinedKeyword,object:h.default.SyntaxKind.ObjectKeyword};return y(n&&s[n]||h.default.SyntaxKind.AnyKeyword)}return o},Rs=e=>$.createUnionTypeNode(Object.values(e.enum).map(F)),Ps=(e,{next:t,optionalPropStyle:{withUndefined:r}})=>{let o=t(e.unwrap());return r?$.createUnionTypeNode([o,y(h.default.SyntaxKind.UndefinedKeyword)]):o},As=(e,{next:t})=>$.createUnionTypeNode([t(e.unwrap()),F(null)]),ws=({items:e,_def:{rest:t}},{next:r})=>$.createTupleTypeNode(e.map(r).concat(t===null?[]:$.createRestTypeNode(r(t)))),Es=({keySchema:e,valueSchema:t},{next:r})=>y("Record",[e,t].map(r)),zs=e=>{if(!e.every(h.default.isTypeLiteralNode))throw new Error("Not objects");let r=(0,H.chain)((0,H.prop)("members"),e),o=(0,H.uniqWith)((...n)=>{if(!(0,H.eqBy)(xr.name,...n))return!1;if((0,H.eqBy)(xr.type,...n)&&(0,H.eqBy)(xr.optional,...n))return!0;throw new Error("Has conflicting prop")},r);return $.createTypeLiteralNode(o)},Is=({_def:{left:e,right:t}},{next:r})=>{let o=[e,t].map(r);try{return zs(o)}catch{}return $.createIntersectionTypeNode(o)},vs=({_def:e},{next:t})=>t(e.innerType),me=e=>()=>y(e),ks=(e,{next:t})=>t(e.unwrap()),Zs=(e,{next:t})=>t(e.unwrap()),Cs=({_def:e},{next:t})=>t(e.innerType),Ns=({_def:e},{next:t,isResponse:r})=>t(e[r?"out":"in"]),js=()=>F(null),Ls=(e,{makeAlias:t,next:r})=>t(e,()=>r(e.schema)),Ms=e=>{let t=e.unwrap(),r=y(h.default.SyntaxKind.StringKeyword),o=y("Buffer"),n=$.createUnionTypeNode([r,o]);return t instanceof Zt.z.ZodString?r:t instanceof Zt.z.ZodUnion?n:o},Us=(e,{next:t})=>t(e.unwrap().shape.raw),Hs={ZodString:me(h.default.SyntaxKind.StringKeyword),ZodNumber:me(h.default.SyntaxKind.NumberKeyword),ZodBigInt:me(h.default.SyntaxKind.BigIntKeyword),ZodBoolean:me(h.default.SyntaxKind.BooleanKeyword),ZodAny:me(h.default.SyntaxKind.AnyKeyword),ZodUndefined:me(h.default.SyntaxKind.UndefinedKeyword),[xe]:me(h.default.SyntaxKind.StringKeyword),[be]:me(h.default.SyntaxKind.StringKeyword),ZodNull:js,ZodArray:bs,ZodTuple:ws,ZodRecord:Es,ZodObject:xs,ZodLiteral:hs,ZodIntersection:Is,ZodUnion:Vo,ZodDefault:vs,ZodEnum:Ss,ZodNativeEnum:Rs,ZodEffects:Os,ZodOptional:Ps,ZodNullable:As,ZodDiscriminatedUnion:Vo,ZodBranded:ks,ZodCatch:Cs,ZodPipeline:Ns,ZodLazy:Ls,ZodReadonly:Zs,[Q]:Ms,[pe]:Us},br=(e,{brandHandling:t,ctx:r})=>Oe(e,{rules:{...t,...Hs},onMissing:()=>y(h.default.SyntaxKind.AnyKeyword),ctx:r});var Ct=class extends kt{program=[this.someOfType];usage=[];aliases=new Map;makeAlias(t,r){let o=this.aliases.get(t)?.name?.text;if(!o){o=`Type${this.aliases.size+1}`;let n=F(null);this.aliases.set(t,X(o,n)),this.aliases.set(t,X(o,r()))}return y(o)}constructor({routing:t,brandHandling:r,variant:o="client",clientClassName:n="Client",subscriptionClassName:s="Subscription",serverUrl:a="https://example.com",optionalPropStyle:c={withQuestionMark:!0,withUndefined:!0},noContent:d=Go.z.undefined()}){super(a);let p={makeAlias:this.makeAlias.bind(this),optionalPropStyle:c},l={brandHandling:r,ctx:{...p,isResponse:!1}},g={brandHandling:r,ctx:{...p,isResponse:!0}};qe({routing:t,onEndpoint:(f,P,O)=>{let j=ae.bind(null,O,P),L=`${O} ${P}`,S=X(j("input"),br(f.getSchema("input"),l),{comment:L});this.program.push(S);let R=je.reduce((v,K)=>{let k=f.getResponses(K),le=(0,_o.chain)(([jt,{schema:re,mimeTypes:ue,statusCodes:Lt}])=>{let rt=X(j(K,"variant",`${jt+1}`),br(ue?re:d,g),{comment:L});return this.program.push(rt),Lt.map(ot=>Pe(ot,rt.name))},Array.from(k.entries())),Z=It(j(K,"response","variants"),le,{comment:L});return this.program.push(Z),Object.assign(v,{[K]:Z})},{});this.paths.add(P);let M=F(L);this.registry.set(L,{input:y(S.name),positive:this.someOf(R.positive),negative:this.someOf(R.negative),response:i.createUnionTypeNode([G(this.interfaces.positive,M),G(this.interfaces.negative,M)]),encoded:i.createIntersectionTypeNode([y(R.positive.name),y(R.negative.name)])}),this.tags.set(L,f.getTags())}}),this.program.unshift(...this.aliases.values()),this.program.push(this.makePathType(),this.methodType,...this.makePublicInterfaces(),this.requestType),o!=="types"&&(this.program.push(this.makeEndpointTags(),this.makeParseRequestFn(),this.makeSubstituteFn(),this.makeImplementationType(),this.makeDefaultImplementation(),this.makeClientClass(n),this.makeSubscriptionClass(s)),this.usage.push(...this.makeUsageStatements(n,s)))}printUsage(t){return this.usage.length?this.usage.map(r=>typeof r=="string"?r:sr(r,t)).join(`
19
+ `):void 0}print(t){let r=this.printUsage(t),o=r&&tt.default.addSyntheticLeadingComment(tt.default.addSyntheticLeadingComment(i.createEmptyStatement(),tt.default.SyntaxKind.SingleLineCommentTrivia," Usage example:"),tt.default.SyntaxKind.MultiLineCommentTrivia,`
20
+ ${r}`);return this.program.concat(o||[]).map((n,s)=>sr(n,s<this.program.length?t:{...t,omitTrailingSemicolon:!0})).join(`
21
21
 
22
- `)}async printFormatted({printerOptions:t,format:r}={}){let o=r;if(!o)try{let a=(await Ke("prettier")).format;o=c=>a(c,{filepath:"client.ts"})}catch{}let n=this.printUsage(t);this.usage=n&&o?[await o(n)]:this.usage;let i=this.print(t);return o?o(i):i}};var Re=require("zod");var Fo=(e,t)=>Re.z.object({data:t,event:Re.z.literal(e),id:Re.z.string().optional(),retry:Re.z.number().int().positive().optional()}),Zs=(e,t,r)=>Fo(String(t),e[t]).transform(o=>[`event: ${o.event}`,`data: ${JSON.stringify(o.data)}`,"",""].join(`
23
- `)).parse({event:t,data:r}),Cs=1e4,Do=e=>e.headersSent||e.writeHead(200,{connection:"keep-alive","content-type":I.sse,"cache-control":"no-cache"}),ks=e=>new q({handler:async({response:t})=>setTimeout(()=>Do(t),Cs)&&{isClosed:()=>t.writableEnded||t.closed,emit:(r,o)=>{Do(t),t.write(Zs(e,r,o),"utf-8"),t.flush?.()}}}),Ns=e=>new se({positive:()=>{let[t,...r]=Object.entries(e).map(([o,n])=>Fo(o,n));return{mimeType:I.sse,schema:r.length?Re.z.discriminatedUnion("event",[t,...r]):t}},negative:{mimeType:"text/plain",schema:Re.z.string()},handler:async({response:t,error:r,logger:o,request:n,input:i})=>{if(r){let a=ge(r);$e(a,o,n,i),t.headersSent||t.status(a.statusCode).type("text/plain").write(he(a),"utf-8")}t.end()}}),Ct=class extends ie{constructor(t){super(Ns(t)),this.middlewares=[ks(t)]}};var qo={dateIn:xr,dateOut:Sr,file:at,upload:Ar,raw:Rr};0&&(module.exports={BuiltinLogger,DependsOnMethod,Documentation,DocumentationError,EndpointsFactory,EventStreamFactory,InputValidationError,Integration,Middleware,MissingPeerError,OutputValidationError,ResultHandler,RoutingError,ServeStatic,arrayEndpointsFactory,arrayResultHandler,attachRouting,createConfig,createServer,defaultEndpointsFactory,defaultResultHandler,ensureHttpError,ez,getExamples,getMessageFromError,testEndpoint,testMiddleware});
22
+ `)}async printFormatted({printerOptions:t,format:r}={}){let o=r;if(!o)try{let a=(await Fe("prettier")).format;o=c=>a(c,{filepath:"client.ts"})}catch{}let n=this.printUsage(t);this.usage=n&&o?[await o(n)]:this.usage;let s=this.print(t);return o?o(s):s}};var we=require("zod");var Jo=(e,t)=>we.z.object({data:t,event:we.z.literal(e),id:we.z.string().optional(),retry:we.z.number().int().positive().optional()}),Ks=(e,t,r)=>Jo(String(t),e[t]).transform(o=>[`event: ${o.event}`,`data: ${JSON.stringify(o.data)}`,"",""].join(`
23
+ `)).parse({event:t,data:r}),Ds=1e4,Yo=e=>e.headersSent||e.writeHead(200,{connection:"keep-alive","content-type":I.sse,"cache-control":"no-cache"}),Fs=e=>new V({handler:async({response:t})=>setTimeout(()=>Yo(t),Ds)&&{isClosed:()=>t.writableEnded||t.closed,emit:(r,o)=>{Yo(t),t.write(Ks(e,r,o),"utf-8"),t.flush?.()}}}),qs=e=>new ce({positive:()=>{let[t,...r]=Object.entries(e).map(([o,n])=>Jo(o,n));return{mimeType:I.sse,schema:r.length?we.z.discriminatedUnion("event",[t,...r]):t}},negative:{mimeType:"text/plain",schema:we.z.string()},handler:async({response:t,error:r,logger:o,request:n,input:s})=>{if(r){let a=Se(r);Je(a,o,n,s),t.headersSent||t.status(a.statusCode).type("text/plain").write(Te(a),"utf-8")}t.end()}}),Nt=class extends de{constructor(t){super(qs(t)),this.middlewares=[Fs(t)]}};var Qo={dateIn:Pr,dateOut:wr,file:lt,upload:kr,raw:Ir};0&&(module.exports={BuiltinLogger,DependsOnMethod,Documentation,DocumentationError,EndpointsFactory,EventStreamFactory,InputValidationError,Integration,Middleware,MissingPeerError,OutputValidationError,ResultHandler,RoutingError,ServeStatic,arrayEndpointsFactory,arrayResultHandler,attachRouting,createConfig,createServer,defaultEndpointsFactory,defaultResultHandler,ensureHttpError,ez,getExamples,getMessageFromError,testEndpoint,testMiddleware});
package/dist/index.d.cts CHANGED
@@ -917,7 +917,7 @@ declare const testMiddleware: <LOG extends FlatObject, REQ extends RequestOption
917
917
  output: FlatObject;
918
918
  }>;
919
919
 
920
- declare const ensureTypeNode: (subject: ts.TypeNode | ts.Identifier | string) => ts.TypeNode;
920
+ type Typeable = ts.TypeNode | ts.Identifier | string | ts.KeywordTypeSyntaxKind;
921
921
 
922
922
  type IOKind = "input" | "response" | ResponseVariant | "encoded";
923
923
  declare abstract class IntegrationBase {
@@ -960,7 +960,7 @@ declare abstract class IntegrationBase {
960
960
  protected requestType: ts.TypeAliasDeclaration;
961
961
  protected constructor(serverUrl: string);
962
962
  /** @example SomeOf<_> */
963
- protected someOf: ({ name }: ts.TypeAliasDeclaration) => ts.TypeReferenceNode;
963
+ protected someOf: ({ name }: ts.TypeAliasDeclaration) => ts.TypeNode;
964
964
  protected makePathType: () => ts.TypeAliasDeclaration;
965
965
  protected makePublicInterfaces: () => ts.InterfaceDeclaration[];
966
966
  protected makeEndpointTags: () => ts.VariableStatement;
@@ -973,7 +973,7 @@ declare abstract class IntegrationBase {
973
973
  protected makeFetchURL: () => ts.NewExpression;
974
974
  protected makeDefaultImplementation: () => ts.VariableStatement;
975
975
  protected makeSubscriptionConstructor: () => ts.ConstructorDeclaration;
976
- protected makeEventNarrow: (value: Parameters<typeof ensureTypeNode>[0]) => ts.TypeLiteralNode;
976
+ protected makeEventNarrow: (value: Typeable) => ts.TypeLiteralNode;
977
977
  protected makeOnMethod: () => ts.MethodDeclaration;
978
978
  protected makeSubscriptionClass: (name: string) => ts.ClassDeclaration;
979
979
  protected makeUsageStatements: (clientClassName: string, subscriptionClassName: string) => ts.Node[];
package/dist/index.d.ts CHANGED
@@ -917,7 +917,7 @@ declare const testMiddleware: <LOG extends FlatObject, REQ extends RequestOption
917
917
  output: FlatObject;
918
918
  }>;
919
919
 
920
- declare const ensureTypeNode: (subject: ts.TypeNode | ts.Identifier | string) => ts.TypeNode;
920
+ type Typeable = ts.TypeNode | ts.Identifier | string | ts.KeywordTypeSyntaxKind;
921
921
 
922
922
  type IOKind = "input" | "response" | ResponseVariant | "encoded";
923
923
  declare abstract class IntegrationBase {
@@ -960,7 +960,7 @@ declare abstract class IntegrationBase {
960
960
  protected requestType: ts.TypeAliasDeclaration;
961
961
  protected constructor(serverUrl: string);
962
962
  /** @example SomeOf<_> */
963
- protected someOf: ({ name }: ts.TypeAliasDeclaration) => ts.TypeReferenceNode;
963
+ protected someOf: ({ name }: ts.TypeAliasDeclaration) => ts.TypeNode;
964
964
  protected makePathType: () => ts.TypeAliasDeclaration;
965
965
  protected makePublicInterfaces: () => ts.InterfaceDeclaration[];
966
966
  protected makeEndpointTags: () => ts.VariableStatement;
@@ -973,7 +973,7 @@ declare abstract class IntegrationBase {
973
973
  protected makeFetchURL: () => ts.NewExpression;
974
974
  protected makeDefaultImplementation: () => ts.VariableStatement;
975
975
  protected makeSubscriptionConstructor: () => ts.ConstructorDeclaration;
976
- protected makeEventNarrow: (value: Parameters<typeof ensureTypeNode>[0]) => ts.TypeLiteralNode;
976
+ protected makeEventNarrow: (value: Typeable) => ts.TypeLiteralNode;
977
977
  protected makeOnMethod: () => ts.MethodDeclaration;
978
978
  protected makeSubscriptionClass: (name: string) => ts.ClassDeclaration;
979
979
  protected makeUsageStatements: (clientClassName: string, subscriptionClassName: string) => ts.Node[];
package/dist/index.js CHANGED
@@ -1,6 +1,6 @@
1
- import{clone as sr,fromPairs as zo,map as vo,pipe as Zo,toPairs as Co,pair as ko}from"ramda";import{z as fe}from"zod";import{chain as or,memoizeWith as Oo,xprod as Ro}from"ramda";import{z as Po}from"zod";var w={json:"application/json",upload:"multipart/form-data",raw:"application/octet-stream",sse:"text/event-stream"};var le=class extends Error{name="RoutingError"},U=class extends Error{name="DocumentationError";cause;constructor(t,{method:r,path:o,isResponse:n}){super(t),this.cause=`${n?"Response":"Input"} schema of an Endpoint assigned to ${r.toUpperCase()} method of ${o} path.`}},De=class extends Error{name="IOSchemaError"},X=class extends De{constructor(r){super(ee(r),{cause:r});this.cause=r}name="OutputValidationError"},q=class extends De{constructor(r){super(ee(r),{cause:r});this.cause=r}name="InputValidationError"},$=class extends Error{constructor(r,o){super(ee(r),{cause:r});this.cause=r;this.handled=o}name="ResultHandlerError"},Ee=class extends Error{name="MissingPeerError";constructor(t){super(`Missing peer dependency: ${t}. Please install it to use the feature.`)}};var Ao=e=>{let r=(e.header("content-type")||"").toLowerCase().startsWith(w.upload);return"files"in e&&r},bt={get:["query","params"],post:["body","params","files"],put:["body","params"],patch:["body","params"],delete:["query","params"]},wo=["body","query","params"],St=e=>e.method.toLowerCase(),Fe=(e,t={})=>{let r=St(e);return r==="options"?{}:(t[r]||bt[r]||wo).filter(o=>o==="files"?Ao(e):!0).reduce((o,n)=>Object.assign(o,e[n]),{})},V=e=>e instanceof Error?e:new Error(String(e)),ee=e=>e instanceof Po.ZodError?e.issues.map(({path:t,message:r})=>(t.length?[t.join("/")]:[]).concat(r).join(": ")).join("; "):e instanceof X?`output${e.cause.issues[0]?.path.length>0?"/":": "}${e.message}`:e.message,_=({schema:e,variant:t="original",validate:r=t==="parsed"})=>{let o=e._def[x]?.examples||[];if(!r&&t==="original")return o;let n=[];for(let i of o){let a=e.safeParse(i);a.success&&n.push(t==="parsed"?a.data:i)}return n},ue=(e,t,r)=>e.length&&t.length?Ro(e,t).map(r):e.concat(t),Ie=e=>"coerce"in e._def&&typeof e._def.coerce=="boolean"?e._def.coerce:!1,Tt=e=>e.charAt(0).toUpperCase()+e.slice(1).toLowerCase(),G=(...e)=>{let t=or(o=>o.split(/[^A-Z0-9]/gi),e);return or(o=>o.replaceAll(/[A-Z]+/g,n=>`/${n}`).split("/"),t).map(Tt).join("")},qe=(e,t)=>{try{return typeof e.parse(t)}catch{return}},te=e=>typeof e=="object"&&e!==null,ye=Oo(()=>"static",()=>process.env.NODE_ENV==="production"),Be=e=>e.length?e:void 0;import{clone as Eo,mergeDeepRight as Io}from"ramda";var x=Symbol.for("express-zod-api"),$e=e=>{let t=e.describe(e.description);return t._def[x]=Eo(t._def[x])||{examples:[]},t},nr=(e,t)=>{if(!(x in e._def))return t;let r=$e(t);return r._def[x].examples=ue(r._def[x].examples,e._def[x].examples,([o,n])=>typeof o=="object"&&typeof n=="object"?Io({...o},{...n}):n),r};var No=function(e){let t=$e(this);return t._def[x].examples.push(e),t},Lo=function(e){let t=$e(this);return t._def[x].defaultLabel=e,t},jo=function(e){return new fe.ZodBranded({typeName:fe.ZodFirstPartyTypeKind.ZodBranded,type:this,description:this._def.description,errorMap:this._def.errorMap,[x]:{examples:[],...sr(this._def[x]),brand:e}})},Uo=function(e){let t=typeof e=="function"?e:Zo(Co,vo(([n,i])=>ko(e[String(n)]||n,i)),zo),r=t(sr(this.shape)),o=fe.object(r)[this._def.unknownKeys]();return this.transform(t).pipe(o)};x in globalThis||(globalThis[x]=!0,Object.defineProperties(fe.ZodType.prototype,{example:{get(){return No.bind(this)}},brand:{set(){},get(){return jo.bind(this)}}}),Object.defineProperty(fe.ZodDefault.prototype,"label",{get(){return Lo.bind(this)}}),Object.defineProperty(fe.ZodObject.prototype,"remap",{get(){return Uo.bind(this)}}));function Mo(e){return e}import{z as xr}from"zod";import{z as gr}from"zod";import{fail as N}from"node:assert/strict";import{z as ze}from"zod";var Ve=e=>!isNaN(e.getTime());var re=Symbol("DateIn"),ir=()=>ze.union([ze.string().date(),ze.string().datetime(),ze.string().datetime({local:!0})]).transform(t=>new Date(t)).pipe(ze.date().refine(Ve)).brand(re);import{z as Ko}from"zod";var oe=Symbol("DateOut"),ar=()=>Ko.date().refine(Ve).transform(e=>e.toISOString()).brand(oe);import{z as _e}from"zod";var M=Symbol("File"),pr=_e.custom(e=>Buffer.isBuffer(e),{message:"Expected Buffer"}),Ho={buffer:()=>pr.brand(M),string:()=>_e.string().brand(M),binary:()=>pr.or(_e.string()).brand(M),base64:()=>_e.string().base64().brand(M)};function Ge(e){return Ho[e||"string"]()}import{z as Do}from"zod";var J=Symbol("Raw"),cr=(e={})=>Do.object({raw:Ge("buffer")}).extend(e).brand(J);import{z as Fo}from"zod";var ge=Symbol("Upload"),dr=()=>Fo.custom(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.encoding=="string"&&typeof e.mimetype=="string"&&Buffer.isBuffer(e.data)&&typeof e.tempFilePath=="string"&&typeof e.truncated=="boolean"&&typeof e.size=="number"&&typeof e.md5=="string"&&typeof e.mv=="function",e=>({message:`Expected file upload, received ${typeof e}`})).brand(ge);var mr=(e,{next:t})=>e.options.some(t),qo=({_def:e},{next:t})=>[e.left,e.right].some(t),Je=(e,{next:t})=>t(e.unwrap()),Ot={ZodObject:({shape:e},{next:t})=>Object.values(e).some(t),ZodUnion:mr,ZodDiscriminatedUnion:mr,ZodIntersection:qo,ZodEffects:(e,{next:t})=>t(e.innerType()),ZodOptional:Je,ZodNullable:Je,ZodRecord:({valueSchema:e},{next:t})=>t(e),ZodArray:({element:e},{next:t})=>t(e),ZodDefault:({_def:e},{next:t})=>t(e.innerType)},Ye=(e,{condition:t,rules:r=Ot,depth:o=1,maxDepth:n=Number.POSITIVE_INFINITY})=>{if(t?.(e))return!0;let i=o<n?r[e._def[x]?.brand]||r[e._def.typeName]:void 0;return i?i(e,{next:a=>Ye(a,{condition:t,rules:r,maxDepth:n,depth:o+1})}):!1},lr=e=>Ye(e,{condition:t=>t._def[x]?.brand===ge}),ur=e=>Ye(e,{condition:t=>t._def[x]?.brand===J,maxDepth:3}),Rt=(e,t)=>{let r=new WeakSet;return Ye(e,{maxDepth:300,rules:{...Ot,ZodBranded:Je,ZodReadonly:Je,ZodCatch:({_def:{innerType:o}},{next:n})=>n(o),ZodPipeline:({_def:o},{next:n})=>n(o[t]),ZodLazy:(o,{next:n})=>r.has(o)?!1:r.add(o)&&n(o.schema),ZodTuple:({items:o,_def:{rest:n}},{next:i})=>[...o].concat(n??[]).some(i),ZodEffects:{out:void 0,in:Ot.ZodEffects}[t],ZodNaN:()=>N("z.nan()"),ZodSymbol:()=>N("z.symbol()"),ZodFunction:()=>N("z.function()"),ZodMap:()=>N("z.map()"),ZodSet:()=>N("z.set()"),ZodBigInt:()=>N("z.bigint()"),ZodVoid:()=>N("z.void()"),ZodPromise:()=>N("z.promise()"),ZodNever:()=>N("z.never()"),ZodDate:()=>t==="in"&&N("z.date()"),[oe]:()=>t==="in"&&N("ez.dateOut()"),[re]:()=>t==="out"&&N("ez.dateIn()"),[J]:()=>t==="out"&&N("ez.raw()"),[ge]:()=>t==="out"&&N("ez.upload()"),[M]:()=>!1}})};import Vo,{isHttpError as _o}from"http-errors";import yr,{isHttpError as Bo}from"http-errors";import{z as $o}from"zod";var Pt=(e,{variant:t,args:r,...o})=>{if(typeof e=="function"&&(e=e(...r)),e instanceof $o.ZodType)return[{schema:e,...o}];if(Array.isArray(e)&&!e.length){let n=new Error(`At least one ${t} response schema required.`);throw new $(n)}return(Array.isArray(e)?e:[e]).map(({schema:n,statusCode:i,mimeType:a})=>({schema:n,statusCodes:typeof i=="number"?[i]:i||o.statusCodes,mimeTypes:typeof a=="string"?[a]:a===void 0?o.mimeTypes:a}))},ve=(e,t,{url:r},o)=>!e.expose&&t.error("Server side error",{error:e,url:r,payload:o}),he=e=>Bo(e)?e:yr(e instanceof q?400:500,ee(e),{cause:e.cause||e}),ne=e=>ye()&&!e.expose?yr(e.statusCode).message:e.message;var We=({error:e,logger:t,response:r})=>{t.error("Result handler failure",e);let o=ne(Vo(500,`An error occurred while serving the result: ${e.message}.`+(e.handled?`
2
- Original error: ${e.handled.message}.`:""),{expose:_o(e.cause)?e.cause.expose:!1}));r.status(500).type("text/plain").end(o)};import{z as fr}from"zod";var At=class{},K=class extends At{#e;#t;#r;constructor({input:t=fr.object({}),security:r,handler:o}){super(),this.#e=t,this.#t=r,this.#r=o}getSecurity(){return this.#t}getSchema(){return this.#e}async execute({input:t,...r}){try{let o=await this.#e.parseAsync(t);return this.#r({...r,input:o})}catch(o){throw o instanceof fr.ZodError?new q(o):o}}},xe=class extends K{constructor(t,{provider:r=()=>({}),transformer:o=n=>n}={}){super({handler:async({request:n,response:i})=>new Promise((a,c)=>{let d=p=>{if(p&&p instanceof Error)return c(o(p));a(r(n,i))};t(n,i,d)?.catch(d)})})}};var be=class{nest(t){return Object.assign(t,{"":this})}};var Ze=class extends be{},Qe=class extends Ze{#e;#t;#r;#n;#s;#i;#o;#a;#p;#c;#d;constructor({methods:t,inputSchema:r,outputSchema:o,handler:n,resultHandler:i,getOperationId:a=()=>{},scopes:c=[],middlewares:d=[],tags:p=[],description:m,shortDescription:g}){super(),this.#s=n,this.#i=i,this.#r=d,this.#c=a,this.#t=Object.freeze(t),this.#a=Object.freeze(c),this.#p=Object.freeze(p),this.#e={long:m,short:g},this.#o={input:r,output:o},this.#n={positive:Object.freeze(i.getPositiveResponse(o)),negative:Object.freeze(i.getNegativeResponse())},this.#d=lr(r)?"upload":ur(r)?"raw":"json"}getDescription(t){return this.#e[t]}getMethods(){return this.#t}getSchema(t){return this.#o[t]}getRequestType(){return this.#d}getResponses(t){return this.#n[t]}getSecurity(){return this.#r.map(t=>t.getSecurity()).filter(t=>t!==void 0)}getScopes(){return this.#a}getTags(){return this.#p}getOperationId(t){return this.#c(t)}async#m(t){try{return await this.#o.output.parseAsync(t)}catch(r){throw r instanceof gr.ZodError?new X(r):r}}async#l({method:t,logger:r,options:o,response:n,...i}){for(let a of this.#r)if(!(t==="options"&&!(a instanceof xe))&&(Object.assign(o,await a.execute({...i,options:o,response:n,logger:r})),n.writableEnded)){r.warn("A middleware has closed the stream. Accumulated options:",o);break}}async#u({input:t,...r}){let o;try{o=await this.#o.input.parseAsync(t)}catch(n){throw n instanceof gr.ZodError?new q(n):n}return this.#s({...r,input:o})}async#y({error:t,...r}){try{await this.#i.execute({...r,error:t})}catch(o){We({...r,error:new $(V(o),t||void 0)})}}async execute({request:t,response:r,logger:o,config:n}){let i=St(t),a={},c=null,d=null,p=Fe(t,n.inputSources);try{if(await this.#l({method:i,input:p,request:t,response:r,logger:o,options:a}),r.writableEnded)return;if(i==="options")return void r.status(200).end();c=await this.#m(await this.#u({input:p,logger:o,options:a}))}catch(m){d=V(m)}await this.#y({input:p,output:c,request:t,response:r,error:d,logger:o,options:a})}};var hr=(e,t)=>{let r=e.map(n=>n.getSchema()).concat(t),o=r.reduce((n,i)=>n.and(i));return r.reduce((n,i)=>nr(i,n),o)};import{z as H}from"zod";var Se={positive:200,negative:400},Te=Object.keys(Se);var wt=class{#e;constructor(t){this.#e=t}execute(...t){return this.#e(...t)}},se=class extends wt{#e;#t;constructor(t){super(t.handler),this.#e=t.positive,this.#t=t.negative}getPositiveResponse(t){return Pt(this.#e,{variant:"positive",args:[t],statusCodes:[Se.positive],mimeTypes:[w.json]})}getNegativeResponse(){return Pt(this.#t,{variant:"negative",args:[],statusCodes:[Se.negative],mimeTypes:[w.json]})}},Ce=new se({positive:e=>{let t=_({schema:e}),r=H.object({status:H.literal("success"),data:e});return t.reduce((o,n)=>o.example({status:"success",data:n}),r)},negative:H.object({status:H.literal("error"),error:H.object({message:H.string()})}).example({status:"error",error:{message:"Sample error message"}}),handler:({error:e,input:t,output:r,request:o,response:n,logger:i})=>{if(e){let a=he(e);return ve(a,i,o,t),void n.status(a.statusCode).json({status:"error",error:{message:ne(a)}})}n.status(Se.positive).json({status:"success",data:r})}}),Et=new se({positive:e=>{let t=_({schema:e}),r="shape"in e&&"items"in e.shape&&e.shape.items instanceof H.ZodArray?e.shape.items:H.array(H.any());return t.reduce((o,n)=>te(n)&&"items"in n&&Array.isArray(n.items)?o.example(n.items):o,r)},negative:H.string().example("Sample error message"),handler:({response:e,output:t,error:r,logger:o,request:n,input:i})=>{if(r){let a=he(r);return ve(a,o,n,i),void e.status(a.statusCode).type("text/plain").send(ne(a))}if(t&&"items"in t&&Array.isArray(t.items))return void e.status(Se.positive).json(t.items);throw new Error("Property 'items' is missing in the endpoint output")}});var ie=class e{constructor(t){this.resultHandler=t}middlewares=[];static#e(t,r){let o=new e(r);return o.middlewares=t,o}addMiddleware(t){return e.#e(this.middlewares.concat(t instanceof K?t:new K(t)),this.resultHandler)}use=this.addExpressMiddleware;addExpressMiddleware(...t){return e.#e(this.middlewares.concat(new xe(...t)),this.resultHandler)}addOptions(t){return e.#e(this.middlewares.concat(new K({handler:t})),this.resultHandler)}build({input:t=xr.object({}),handler:r,output:o,description:n,shortDescription:i,operationId:a,scope:c,tag:d,method:p}){let{middlewares:m,resultHandler:g}=this,b=typeof p=="string"?[p]:p,f=typeof a=="function"?a:()=>a,R=typeof c=="string"?[c]:c||[],T=typeof d=="string"?[d]:d||[];return new Qe({handler:r,middlewares:m,outputSchema:o,resultHandler:g,scopes:R,tags:T,methods:b,getOperationId:f,description:n,shortDescription:i,inputSchema:hr(m,t)})}buildVoid({handler:t,...r}){return this.build({...r,output:xr.object({}),handler:async o=>(await t(o),{})})}},Go=new ie(Ce),Jo=new ie(Et);import on from"ansis";import{inspect as nn}from"node:util";import{performance as Rr}from"node:perf_hooks";import{blue as Yo,green as Wo,hex as Qo,red as Xo,cyanBright as en}from"ansis";import{memoizeWith as tn}from"ramda";var It={debug:Yo,info:Wo,warn:Qo("#FFA500"),error:Xo,ctx:en},Xe={debug:10,info:20,warn:30,error:40},br=e=>te(e)&&Object.keys(Xe).some(t=>t in e),Sr=e=>e in Xe,Tr=(e,t)=>Xe[e]<Xe[t],rn=(e,t=0)=>Intl.NumberFormat(void 0,{useGrouping:!1,minimumFractionDigits:0,maximumFractionDigits:t,style:"unit",unitDisplay:"long",unit:e}),Oe=tn((e,t)=>`${e}${t}`,rn),Or=e=>e<1e-6?Oe("nanosecond",3).format(e/1e-6):e<.001?Oe("nanosecond").format(e/1e-6):e<1?Oe("microsecond").format(e/.001):e<1e3?Oe("millisecond").format(e):e<6e4?Oe("second",2).format(e/1e3):Oe("minute",2).format(e/6e4);var ke=class e{config;constructor({color:t=on.isSupported(),level:r=ye()?"warn":"debug",depth:o=2,ctx:n={}}={}){this.config={color:t,level:r,depth:o,ctx:n}}prettyPrint(t){let{depth:r,color:o,level:n}=this.config;return nn(t,{depth:r,colors:o,breakLength:n==="debug"?80:1/0,compact:n==="debug"?3:!0})}print(t,r,o){let{level:n,ctx:{requestId:i,...a},color:c}=this.config;if(n==="silent"||Tr(t,n))return;let d=[new Date().toISOString()];i&&d.push(c?It.ctx(i):i),d.push(c?`${It[t](t)}:`:`${t}:`,r),o!==void 0&&d.push(this.prettyPrint(o)),Object.keys(a).length>0&&d.push(this.prettyPrint(a)),console.log(d.join(" "))}debug(t,r){this.print("debug",t,r)}info(t,r){this.print("info",t,r)}warn(t,r){this.print("warn",t,r)}error(t,r){this.print("error",t,r)}child(t){return new e({...this.config,ctx:t})}get ctx(){return this.config.ctx}profile(t){let r=Rr.now();return()=>{let o=Rr.now()-r,{message:n,severity:i="debug",formatter:a=Or}=typeof t=="object"?t:{message:t};this.print(typeof i=="function"?i(o):i,n,a(o))}}};import{keys as sn,reject as an,equals as pn}from"ramda";var Ne=class extends be{entries;constructor(t){super();let r=[],o=sn(t);for(let n of o){let i=t[n];i&&r.push([n,i,an(pn(n),o)])}this.entries=Object.freeze(r)}};import cn from"express";var Le=class{params;constructor(...t){this.params=t}apply(t,r){return r(t,cn.static(...this.params))}};import vt from"express";import gn from"node:http";import hn from"node:https";var Re=async(e,t="default")=>{try{return(await import(e))[t]}catch{}throw new Ee(e)};var et=class{constructor(t){this.logger=t}#e=new WeakSet;check(t,r){if(!this.#e.has(t)){if(t.getRequestType()==="json")try{Rt(t.getSchema("input"),"in")}catch(o){this.logger.warn("The final input schema of the endpoint contains an unsupported JSON payload type.",Object.assign(r,{reason:o}))}for(let o of Te)for(let{mimeTypes:n,schema:i}of t.getResponses(o))if(n?.includes(w.json))try{Rt(i,"out")}catch(a){this.logger.warn(`The final ${o} response schema of the endpoint contains an unsupported JSON payload type.`,Object.assign(r,{reason:a}))}this.#e.add(t)}}};var Pr=(e,t)=>Object.entries(e).map(([r,o])=>{if(r.includes("/"))throw new le(`The entry '${r}' must avoid having slashes \u2014 use nesting instead.`);let n=r.trim();return[`${t||""}${n?`/${n}`:""}`,o]}),Pe=({routing:e,onEndpoint:t,onStatic:r})=>{let o=Pr(e);for(;o.length;){let[n,i]=o.shift();if(i instanceof Ze){let a=i.getMethods()||["get"];for(let c of a)t(i,n,c)}else if(i instanceof Le)r&&i.apply(n,r);else if(i instanceof Ne)for(let[a,c,d]of i.entries){let p=c.getMethods();if(p&&!p.includes(a))throw new le(`Endpoint assigned to ${a} method of ${n} must support ${a} method.`);t(c,n,a,d)}else o.unshift(...Pr(i,n))}};var zt=({app:e,getLogger:t,config:r,routing:o,parsers:n})=>{let i=new et(t()),a=new Set;Pe({routing:o,onEndpoint:(d,p,m,g)=>{ye()||i.check(d,{path:p,method:m});let b=n?.[d.getRequestType()]||[],f=async(R,T)=>{let Z=t(R);if(r.cors){let O={"Access-Control-Allow-Origin":"*","Access-Control-Allow-Methods":[m,...g||[],"options"].join(", ").toUpperCase(),"Access-Control-Allow-Headers":"content-type"},k=typeof r.cors=="function"?await r.cors({request:R,endpoint:d,logger:Z,defaultHeaders:O}):O;for(let E in k)T.set(E,k[E])}return d.execute({request:R,response:T,logger:Z,config:r})};r.cors&&!a.has(p)&&(e.options(p,...b,f),a.add(p)),e[m](p,...b,f)},onStatic:e.use.bind(e)})};import Zr,{isHttpError as mn}from"http-errors";import{setInterval as dn}from"node:timers/promises";var Ar=e=>"_httpMessage"in e&&typeof e._httpMessage=="object"&&e._httpMessage!==null&&"headersSent"in e._httpMessage&&typeof e._httpMessage.headersSent=="boolean"&&"setHeader"in e._httpMessage&&typeof e._httpMessage.setHeader=="function",wr=e=>"server"in e&&typeof e.server=="object"&&e.server!==null&&"close"in e.server&&typeof e.server.close=="function",Er=e=>"encrypted"in e&&typeof e.encrypted=="boolean"&&e.encrypted,Ir=({},e)=>void(!e.headersSent&&e.setHeader("connection","close")),zr=e=>new Promise((t,r)=>void e.close(o=>o?r(o):t()));var vr=(e,{timeout:t=1e3,logger:r}={})=>{let o,n=new Set,i=p=>void n.delete(p.destroy()),a=p=>void(Ar(p)?!p._httpMessage.headersSent&&p._httpMessage.setHeader("connection","close"):i(p)),c=p=>void(o?p.destroy():n.add(p.once("close",()=>void n.delete(p))));for(let p of e)for(let m of["connection","secureConnection"])p.on(m,c);let d=async()=>{for(let p of e)p.on("request",Ir);r?.info("Graceful shutdown",{sockets:n.size,timeout:t});for(let p of n)(Er(p)||wr(p))&&a(p);for await(let p of dn(10,Date.now()))if(n.size===0||Date.now()-p>=t)break;for(let p of n)i(p);return Promise.allSettled(e.map(zr))};return{sockets:n,shutdown:()=>o??=d()}};var Cr=({errorHandler:e,getLogger:t})=>async(r,o,n,i)=>r?e.execute({error:mn(r)?r:Zr(400,V(r).message),request:o,response:n,input:null,output:null,options:{},logger:t(o)}):i(),kr=({errorHandler:e,getLogger:t})=>async(r,o)=>{let n=Zr(404,`Can not ${r.method} ${r.path}`),i=t(r);try{e.execute({request:r,response:o,logger:i,error:n,input:null,output:null,options:{}})}catch(a){We({response:o,logger:i,error:new $(V(a),n)})}},ln=e=>(t,{},r)=>{if(Object.values(t?.files||[]).flat().find(({truncated:n})=>n))return r(e);r()},un=e=>({log:e.debug.bind(e)}),Nr=async({getLogger:e,config:t})=>{let r=await Re("express-fileupload"),{limitError:o,beforeUpload:n,...i}={...typeof t.upload=="object"&&t.upload},a=[];return a.push(async(c,d,p)=>{let m=e(c);try{await n?.({request:c,logger:m})}catch(g){return p(g)}return r({debug:!0,...i,abortOnLimit:!1,parseNested:!0,logger:un(m)})(c,d,p)}),o&&a.push(ln(o)),a},Lr=(e,{},t)=>{Buffer.isBuffer(e.body)&&(e.body={raw:e.body}),t()},jr=({logger:e,config:t})=>async(r,o,n)=>{let i=await t.childLoggerProvider?.({request:r,parent:e})||e;i.debug(`${r.method}: ${r.path}`),r.res&&(r.res.locals[x]={logger:i}),n()},Ur=e=>t=>t?.res?.locals[x]?.logger||e,Mr=e=>process.on("deprecation",({message:t,namespace:r,name:o,stack:n})=>e.warn(`${o} (${r}): ${t}`,n.split(`
3
- `).slice(1))),Kr=({servers:e,logger:t,options:{timeout:r,events:o=["SIGINT","SIGTERM"]}})=>{let n=vr(e,{logger:t,timeout:r}),i=()=>n.shutdown().then(()=>process.exit());for(let a of o)process.on(a,i)};import{gray as yn,hex as Hr,italic as tt,whiteBright as fn}from"ansis";var Dr=e=>{if(e.columns<132)return;let t=tt("Proudly supports transgender community.".padStart(109)),r=tt("Start your API server with I/O schema validation and custom middlewares in minutes.".padStart(109)),o=tt("Thank you for choosing Express Zod API for your project.".padStart(132)),n=tt("for Tai".padEnd(20)),i=Hr("#F5A9B8"),a=Hr("#5BCEFA"),c=new Array(14).fill(a,1,3).fill(i,3,5).fill(fn,5,7).fill(i,7,9).fill(a,9,12).fill(yn,12,13),d=`
1
+ import{clone as ur,fromPairs as Uo,map as Ho,pipe as Ko,toPairs as Do,pair as Fo}from"ramda";import{z as he}from"zod";import{chain as mr,memoizeWith as ko,xprod as Zo}from"ramda";import{z as Co}from"zod";var E={json:"application/json",upload:"multipart/form-data",raw:"application/octet-stream",sse:"text/event-stream"};var ye=class extends Error{name="RoutingError"},H=class extends Error{name="DocumentationError";cause;constructor(t,{method:r,path:o,isResponse:n}){super(t),this.cause=`${n?"Response":"Input"} schema of an Endpoint assigned to ${r.toUpperCase()} method of ${o} path.`}},Be=class extends Error{name="IOSchemaError"},re=class extends Be{constructor(r){super(oe(r),{cause:r});this.cause=r}name="OutputValidationError"},V=class extends Be{constructor(r){super(oe(r),{cause:r});this.cause=r}name="InputValidationError"},G=class extends Error{constructor(r,o){super(oe(r),{cause:r});this.cause=r;this.handled=o}name="ResultHandlerError"},ve=class extends Error{name="MissingPeerError";constructor(t){super(`Missing peer dependency: ${t}. Please install it to use the feature.`)}};var No=e=>{let r=(e.header("content-type")||"").toLowerCase().startsWith(E.upload);return"files"in e&&r},St={get:["query","params"],post:["body","params","files"],put:["body","params"],patch:["body","params"],delete:["query","params"]},jo=["body","query","params"],Tt=e=>e.method.toLowerCase(),$e=(e,t={})=>{let r=Tt(e);return r==="options"?{}:(t[r]||St[r]||jo).filter(o=>o==="files"?No(e):!0).reduce((o,n)=>Object.assign(o,e[n]),{})},Y=e=>e instanceof Error?e:new Error(String(e)),oe=e=>e instanceof Co.ZodError?e.issues.map(({path:t,message:r})=>(t.length?[t.join("/")]:[]).concat(r).join(": ")).join("; "):e instanceof re?`output${e.cause.issues[0]?.path.length>0?"/":": "}${e.message}`:e.message,J=({schema:e,variant:t="original",validate:r=t==="parsed"})=>{let o=e._def[h]?.examples||[];if(!r&&t==="original")return o;let n=[];for(let s of o){let a=e.safeParse(s);a.success&&n.push(t==="parsed"?a.data:s)}return n},fe=(e,t,r)=>e.length&&t.length?Zo(e,t).map(r):e.concat(t),ke=e=>"coerce"in e._def&&typeof e._def.coerce=="boolean"?e._def.coerce:!1,Ot=e=>e.charAt(0).toUpperCase()+e.slice(1).toLowerCase(),Q=(...e)=>{let t=mr(o=>o.split(/[^A-Z0-9]/gi),e);return mr(o=>o.replaceAll(/[A-Z]+/g,n=>`/${n}`).split("/"),t).map(Ot).join("")},Ve=(e,t)=>{try{return typeof e.parse(t)}catch{return}},ne=e=>typeof e=="object"&&e!==null,ge=ko(()=>"static",()=>process.env.NODE_ENV==="production"),_e=e=>e.length?e:void 0;import{clone as Lo,mergeDeepRight as Mo}from"ramda";var h=Symbol.for("express-zod-api"),Ge=e=>{let t=e.describe(e.description);return t._def[h]=Lo(t._def[h])||{examples:[]},t},lr=(e,t)=>{if(!(h in e._def))return t;let r=Ge(t);return r._def[h].examples=fe(r._def[h].examples,e._def[h].examples,([o,n])=>typeof o=="object"&&typeof n=="object"?Mo({...o},{...n}):n),r};var qo=function(e){let t=Ge(this);return t._def[h].examples.push(e),t},Bo=function(e){let t=Ge(this);return t._def[h].defaultLabel=e,t},$o=function(e){return new he.ZodBranded({typeName:he.ZodFirstPartyTypeKind.ZodBranded,type:this,description:this._def.description,errorMap:this._def.errorMap,[h]:{examples:[],...ur(this._def[h]),brand:e}})},Vo=function(e){let t=typeof e=="function"?e:Ko(Do,Ho(([n,s])=>Fo(e[String(n)]||n,s)),Uo),r=t(ur(this.shape)),o=he.object(r)[this._def.unknownKeys]();return this.transform(t).pipe(o)};h in globalThis||(globalThis[h]=!0,Object.defineProperties(he.ZodType.prototype,{example:{get(){return qo.bind(this)}},brand:{set(){},get(){return $o.bind(this)}}}),Object.defineProperty(he.ZodDefault.prototype,"label",{get(){return Bo.bind(this)}}),Object.defineProperty(he.ZodObject.prototype,"remap",{get(){return Vo.bind(this)}}));function _o(e){return e}import{z as wr}from"zod";import{z as Pr}from"zod";import{fail as j}from"node:assert/strict";import{z as Ze}from"zod";var Ye=e=>!isNaN(e.getTime());var se=Symbol("DateIn"),yr=()=>Ze.union([Ze.string().date(),Ze.string().datetime(),Ze.string().datetime({local:!0})]).transform(t=>new Date(t)).pipe(Ze.date().refine(Ye)).brand(se);import{z as Go}from"zod";var ie=Symbol("DateOut"),fr=()=>Go.date().refine(Ye).transform(e=>e.toISOString()).brand(ie);import{z as Je}from"zod";var D=Symbol("File"),gr=Je.custom(e=>Buffer.isBuffer(e),{message:"Expected Buffer"}),Yo={buffer:()=>gr.brand(D),string:()=>Je.string().brand(D),binary:()=>gr.or(Je.string()).brand(D),base64:()=>Je.string().base64().brand(D)};function Qe(e){return Yo[e||"string"]()}import{z as Jo}from"zod";var W=Symbol("Raw"),hr=(e={})=>Jo.object({raw:Qe("buffer")}).extend(e).brand(W);import{z as Qo}from"zod";var xe=Symbol("Upload"),xr=()=>Qo.custom(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.encoding=="string"&&typeof e.mimetype=="string"&&Buffer.isBuffer(e.data)&&typeof e.tempFilePath=="string"&&typeof e.truncated=="boolean"&&typeof e.size=="number"&&typeof e.md5=="string"&&typeof e.mv=="function",e=>({message:`Expected file upload, received ${typeof e}`})).brand(xe);var br=(e,{next:t})=>e.options.some(t),Wo=({_def:e},{next:t})=>[e.left,e.right].some(t),We=(e,{next:t})=>t(e.unwrap()),Rt={ZodObject:({shape:e},{next:t})=>Object.values(e).some(t),ZodUnion:br,ZodDiscriminatedUnion:br,ZodIntersection:Wo,ZodEffects:(e,{next:t})=>t(e.innerType()),ZodOptional:We,ZodNullable:We,ZodRecord:({valueSchema:e},{next:t})=>t(e),ZodArray:({element:e},{next:t})=>t(e),ZodDefault:({_def:e},{next:t})=>t(e.innerType)},Xe=(e,{condition:t,rules:r=Rt,depth:o=1,maxDepth:n=Number.POSITIVE_INFINITY})=>{if(t?.(e))return!0;let s=o<n?r[e._def[h]?.brand]||r[e._def.typeName]:void 0;return s?s(e,{next:a=>Xe(a,{condition:t,rules:r,maxDepth:n,depth:o+1})}):!1},Sr=e=>Xe(e,{condition:t=>t._def[h]?.brand===xe}),Tr=e=>Xe(e,{condition:t=>t._def[h]?.brand===W,maxDepth:3}),Pt=(e,t)=>{let r=new WeakSet;return Xe(e,{maxDepth:300,rules:{...Rt,ZodBranded:We,ZodReadonly:We,ZodCatch:({_def:{innerType:o}},{next:n})=>n(o),ZodPipeline:({_def:o},{next:n})=>n(o[t]),ZodLazy:(o,{next:n})=>r.has(o)?!1:r.add(o)&&n(o.schema),ZodTuple:({items:o,_def:{rest:n}},{next:s})=>[...o].concat(n??[]).some(s),ZodEffects:{out:void 0,in:Rt.ZodEffects}[t],ZodNaN:()=>j("z.nan()"),ZodSymbol:()=>j("z.symbol()"),ZodFunction:()=>j("z.function()"),ZodMap:()=>j("z.map()"),ZodSet:()=>j("z.set()"),ZodBigInt:()=>j("z.bigint()"),ZodVoid:()=>j("z.void()"),ZodPromise:()=>j("z.promise()"),ZodNever:()=>j("z.never()"),ZodDate:()=>t==="in"&&j("z.date()"),[ie]:()=>t==="in"&&j("ez.dateOut()"),[se]:()=>t==="out"&&j("ez.dateIn()"),[W]:()=>t==="out"&&j("ez.raw()"),[xe]:()=>t==="out"&&j("ez.upload()"),[D]:()=>!1}})};import tn,{isHttpError as rn}from"http-errors";import Or,{isHttpError as Xo}from"http-errors";import{z as en}from"zod";var At=(e,{variant:t,args:r,...o})=>{if(typeof e=="function"&&(e=e(...r)),e instanceof en.ZodType)return[{schema:e,...o}];if(Array.isArray(e)&&!e.length){let n=new Error(`At least one ${t} response schema required.`);throw new G(n)}return(Array.isArray(e)?e:[e]).map(({schema:n,statusCode:s,mimeType:a})=>({schema:n,statusCodes:typeof s=="number"?[s]:s||o.statusCodes,mimeTypes:typeof a=="string"?[a]:a===void 0?o.mimeTypes:a}))},Ce=(e,t,{url:r},o)=>!e.expose&&t.error("Server side error",{error:e,url:r,payload:o}),be=e=>Xo(e)?e:Or(e instanceof V?400:500,oe(e),{cause:e.cause||e}),ae=e=>ge()&&!e.expose?Or(e.statusCode).message:e.message;var et=({error:e,logger:t,response:r})=>{t.error("Result handler failure",e);let o=ae(tn(500,`An error occurred while serving the result: ${e.message}.`+(e.handled?`
2
+ Original error: ${e.handled.message}.`:""),{expose:rn(e.cause)?e.cause.expose:!1}));r.status(500).type("text/plain").end(o)};import{z as Rr}from"zod";var wt=class{},F=class extends wt{#e;#t;#r;constructor({input:t=Rr.object({}),security:r,handler:o}){super(),this.#e=t,this.#t=r,this.#r=o}getSecurity(){return this.#t}getSchema(){return this.#e}async execute({input:t,...r}){try{let o=await this.#e.parseAsync(t);return this.#r({...r,input:o})}catch(o){throw o instanceof Rr.ZodError?new V(o):o}}},Se=class extends F{constructor(t,{provider:r=()=>({}),transformer:o=n=>n}={}){super({handler:async({request:n,response:s})=>new Promise((a,c)=>{let d=p=>{if(p&&p instanceof Error)return c(o(p));a(r(n,s))};t(n,s,d)?.catch(d)})})}};var Te=class{nest(t){return Object.assign(t,{"":this})}};var Ne=class extends Te{},tt=class extends Ne{#e;#t;#r;#n;#s;#i;#o;#a;#p;#c;#d;constructor({methods:t,inputSchema:r,outputSchema:o,handler:n,resultHandler:s,getOperationId:a=()=>{},scopes:c=[],middlewares:d=[],tags:p=[],description:m,shortDescription:f}){super(),this.#s=n,this.#i=s,this.#r=d,this.#c=a,this.#t=Object.freeze(t),this.#a=Object.freeze(c),this.#p=Object.freeze(p),this.#e={long:m,short:f},this.#o={input:r,output:o},this.#n={positive:Object.freeze(s.getPositiveResponse(o)),negative:Object.freeze(s.getNegativeResponse())},this.#d=Sr(r)?"upload":Tr(r)?"raw":"json"}getDescription(t){return this.#e[t]}getMethods(){return this.#t}getSchema(t){return this.#o[t]}getRequestType(){return this.#d}getResponses(t){return this.#n[t]}getSecurity(){return this.#r.map(t=>t.getSecurity()).filter(t=>t!==void 0)}getScopes(){return this.#a}getTags(){return this.#p}getOperationId(t){return this.#c(t)}async#m(t){try{return await this.#o.output.parseAsync(t)}catch(r){throw r instanceof Pr.ZodError?new re(r):r}}async#l({method:t,logger:r,options:o,response:n,...s}){for(let a of this.#r)if(!(t==="options"&&!(a instanceof Se))&&(Object.assign(o,await a.execute({...s,options:o,response:n,logger:r})),n.writableEnded)){r.warn("A middleware has closed the stream. Accumulated options:",o);break}}async#u({input:t,...r}){let o;try{o=await this.#o.input.parseAsync(t)}catch(n){throw n instanceof Pr.ZodError?new V(n):n}return this.#s({...r,input:o})}async#y({error:t,...r}){try{await this.#i.execute({...r,error:t})}catch(o){et({...r,error:new G(Y(o),t||void 0)})}}async execute({request:t,response:r,logger:o,config:n}){let s=Tt(t),a={},c=null,d=null,p=$e(t,n.inputSources);try{if(await this.#l({method:s,input:p,request:t,response:r,logger:o,options:a}),r.writableEnded)return;if(s==="options")return void r.status(200).end();c=await this.#m(await this.#u({input:p,logger:o,options:a}))}catch(m){d=Y(m)}await this.#y({input:p,output:c,request:t,response:r,error:d,logger:o,options:a})}};var Ar=(e,t)=>{let r=e.map(n=>n.getSchema()).concat(t),o=r.reduce((n,s)=>n.and(s));return r.reduce((n,s)=>lr(s,n),o)};import{z as q}from"zod";var Oe={positive:200,negative:400},Re=Object.keys(Oe);var Et=class{#e;constructor(t){this.#e=t}execute(...t){return this.#e(...t)}},pe=class extends Et{#e;#t;constructor(t){super(t.handler),this.#e=t.positive,this.#t=t.negative}getPositiveResponse(t){return At(this.#e,{variant:"positive",args:[t],statusCodes:[Oe.positive],mimeTypes:[E.json]})}getNegativeResponse(){return At(this.#t,{variant:"negative",args:[],statusCodes:[Oe.negative],mimeTypes:[E.json]})}},je=new pe({positive:e=>{let t=J({schema:e}),r=q.object({status:q.literal("success"),data:e});return t.reduce((o,n)=>o.example({status:"success",data:n}),r)},negative:q.object({status:q.literal("error"),error:q.object({message:q.string()})}).example({status:"error",error:{message:"Sample error message"}}),handler:({error:e,input:t,output:r,request:o,response:n,logger:s})=>{if(e){let a=be(e);return Ce(a,s,o,t),void n.status(a.statusCode).json({status:"error",error:{message:ae(a)}})}n.status(Oe.positive).json({status:"success",data:r})}}),zt=new pe({positive:e=>{let t=J({schema:e}),r="shape"in e&&"items"in e.shape&&e.shape.items instanceof q.ZodArray?e.shape.items:q.array(q.any());return t.reduce((o,n)=>ne(n)&&"items"in n&&Array.isArray(n.items)?o.example(n.items):o,r)},negative:q.string().example("Sample error message"),handler:({response:e,output:t,error:r,logger:o,request:n,input:s})=>{if(r){let a=be(r);return Ce(a,o,n,s),void e.status(a.statusCode).type("text/plain").send(ae(a))}if(t&&"items"in t&&Array.isArray(t.items))return void e.status(Oe.positive).json(t.items);throw new Error("Property 'items' is missing in the endpoint output")}});var ce=class e{constructor(t){this.resultHandler=t}middlewares=[];static#e(t,r){let o=new e(r);return o.middlewares=t,o}addMiddleware(t){return e.#e(this.middlewares.concat(t instanceof F?t:new F(t)),this.resultHandler)}use=this.addExpressMiddleware;addExpressMiddleware(...t){return e.#e(this.middlewares.concat(new Se(...t)),this.resultHandler)}addOptions(t){return e.#e(this.middlewares.concat(new F({handler:t})),this.resultHandler)}build({input:t=wr.object({}),handler:r,output:o,description:n,shortDescription:s,operationId:a,scope:c,tag:d,method:p}){let{middlewares:m,resultHandler:f}=this,x=typeof p=="string"?[p]:p,y=typeof a=="function"?a:()=>a,O=typeof c=="string"?[c]:c||[],S=typeof d=="string"?[d]:d||[];return new tt({handler:r,middlewares:m,outputSchema:o,resultHandler:f,scopes:O,tags:S,methods:x,getOperationId:y,description:n,shortDescription:s,inputSchema:Ar(m,t)})}buildVoid({handler:t,...r}){return this.build({...r,output:wr.object({}),handler:async o=>(await t(o),{})})}},on=new ce(je),nn=new ce(zt);import un from"ansis";import{inspect as yn}from"node:util";import{performance as kr}from"node:perf_hooks";import{blue as sn,green as an,hex as pn,red as cn,cyanBright as dn}from"ansis";import{memoizeWith as mn}from"ramda";var It={debug:sn,info:an,warn:pn("#FFA500"),error:cn,ctx:dn},rt={debug:10,info:20,warn:30,error:40},Er=e=>ne(e)&&Object.keys(rt).some(t=>t in e),zr=e=>e in rt,Ir=(e,t)=>rt[e]<rt[t],ln=(e,t=0)=>Intl.NumberFormat(void 0,{useGrouping:!1,minimumFractionDigits:0,maximumFractionDigits:t,style:"unit",unitDisplay:"long",unit:e}),Pe=mn((e,t)=>`${e}${t}`,ln),vr=e=>e<1e-6?Pe("nanosecond",3).format(e/1e-6):e<.001?Pe("nanosecond").format(e/1e-6):e<1?Pe("microsecond").format(e/.001):e<1e3?Pe("millisecond").format(e):e<6e4?Pe("second",2).format(e/1e3):Pe("minute",2).format(e/6e4);var Le=class e{config;constructor({color:t=un.isSupported(),level:r=ge()?"warn":"debug",depth:o=2,ctx:n={}}={}){this.config={color:t,level:r,depth:o,ctx:n}}prettyPrint(t){let{depth:r,color:o,level:n}=this.config;return yn(t,{depth:r,colors:o,breakLength:n==="debug"?80:1/0,compact:n==="debug"?3:!0})}print(t,r,o){let{level:n,ctx:{requestId:s,...a},color:c}=this.config;if(n==="silent"||Ir(t,n))return;let d=[new Date().toISOString()];s&&d.push(c?It.ctx(s):s),d.push(c?`${It[t](t)}:`:`${t}:`,r),o!==void 0&&d.push(this.prettyPrint(o)),Object.keys(a).length>0&&d.push(this.prettyPrint(a)),console.log(d.join(" "))}debug(t,r){this.print("debug",t,r)}info(t,r){this.print("info",t,r)}warn(t,r){this.print("warn",t,r)}error(t,r){this.print("error",t,r)}child(t){return new e({...this.config,ctx:t})}get ctx(){return this.config.ctx}profile(t){let r=kr.now();return()=>{let o=kr.now()-r,{message:n,severity:s="debug",formatter:a=vr}=typeof t=="object"?t:{message:t};this.print(typeof s=="function"?s(o):s,n,a(o))}}};import{keys as fn,reject as gn,equals as hn}from"ramda";var Me=class extends Te{entries;constructor(t){super();let r=[],o=fn(t);for(let n of o){let s=t[n];s&&r.push([n,s,gn(hn(n),o)])}this.entries=Object.freeze(r)}};import xn from"express";var Ue=class{params;constructor(...t){this.params=t}apply(t,r){return r(t,xn.static(...this.params))}};import kt from"express";import An from"node:http";import wn from"node:https";var Ae=async(e,t="default")=>{try{return(await import(e))[t]}catch{}throw new ve(e)};var ot=class{constructor(t){this.logger=t}#e=new WeakSet;check(t,r){if(!this.#e.has(t)){if(t.getRequestType()==="json")try{Pt(t.getSchema("input"),"in")}catch(o){this.logger.warn("The final input schema of the endpoint contains an unsupported JSON payload type.",Object.assign(r,{reason:o}))}for(let o of Re)for(let{mimeTypes:n,schema:s}of t.getResponses(o))if(n?.includes(E.json))try{Pt(s,"out")}catch(a){this.logger.warn(`The final ${o} response schema of the endpoint contains an unsupported JSON payload type.`,Object.assign(r,{reason:a}))}this.#e.add(t)}}};var Zr=(e,t)=>Object.entries(e).map(([r,o])=>{if(r.includes("/"))throw new ye(`The entry '${r}' must avoid having slashes \u2014 use nesting instead.`);let n=r.trim();return[`${t||""}${n?`/${n}`:""}`,o]}),we=({routing:e,onEndpoint:t,onStatic:r})=>{let o=Zr(e);for(;o.length;){let[n,s]=o.shift();if(s instanceof Ne){let a=s.getMethods()||["get"];for(let c of a)t(s,n,c)}else if(s instanceof Ue)r&&s.apply(n,r);else if(s instanceof Me)for(let[a,c,d]of s.entries){let p=c.getMethods();if(p&&!p.includes(a))throw new ye(`Endpoint assigned to ${a} method of ${n} must support ${a} method.`);t(c,n,a,d)}else o.unshift(...Zr(s,n))}};var vt=({app:e,getLogger:t,config:r,routing:o,parsers:n})=>{let s=new ot(t()),a=new Set;we({routing:o,onEndpoint:(d,p,m,f)=>{ge()||s.check(d,{path:p,method:m});let x=n?.[d.getRequestType()]||[],y=async(O,S)=>{let Z=t(O);if(r.cors){let T={"Access-Control-Allow-Origin":"*","Access-Control-Allow-Methods":[m,...f||[],"options"].join(", ").toUpperCase(),"Access-Control-Allow-Headers":"content-type"},N=typeof r.cors=="function"?await r.cors({request:O,endpoint:d,logger:Z,defaultHeaders:T}):T;for(let z in N)S.set(z,N[z])}return d.execute({request:O,response:S,logger:Z,config:r})};r.cors&&!a.has(p)&&(e.options(p,...x,y),a.add(p)),e[m](p,...x,y)},onStatic:e.use.bind(e)})};import Hr,{isHttpError as Sn}from"http-errors";import{setInterval as bn}from"node:timers/promises";var Cr=e=>"_httpMessage"in e&&typeof e._httpMessage=="object"&&e._httpMessage!==null&&"headersSent"in e._httpMessage&&typeof e._httpMessage.headersSent=="boolean"&&"setHeader"in e._httpMessage&&typeof e._httpMessage.setHeader=="function",Nr=e=>"server"in e&&typeof e.server=="object"&&e.server!==null&&"close"in e.server&&typeof e.server.close=="function",jr=e=>"encrypted"in e&&typeof e.encrypted=="boolean"&&e.encrypted,Lr=({},e)=>void(!e.headersSent&&e.setHeader("connection","close")),Mr=e=>new Promise((t,r)=>void e.close(o=>o?r(o):t()));var Ur=(e,{timeout:t=1e3,logger:r}={})=>{let o,n=new Set,s=p=>void n.delete(p.destroy()),a=p=>void(Cr(p)?!p._httpMessage.headersSent&&p._httpMessage.setHeader("connection","close"):s(p)),c=p=>void(o?p.destroy():n.add(p.once("close",()=>void n.delete(p))));for(let p of e)for(let m of["connection","secureConnection"])p.on(m,c);let d=async()=>{for(let p of e)p.on("request",Lr);r?.info("Graceful shutdown",{sockets:n.size,timeout:t});for(let p of n)(jr(p)||Nr(p))&&a(p);for await(let p of bn(10,Date.now()))if(n.size===0||Date.now()-p>=t)break;for(let p of n)s(p);return Promise.allSettled(e.map(Mr))};return{sockets:n,shutdown:()=>o??=d()}};var Kr=({errorHandler:e,getLogger:t})=>async(r,o,n,s)=>r?e.execute({error:Sn(r)?r:Hr(400,Y(r).message),request:o,response:n,input:null,output:null,options:{},logger:t(o)}):s(),Dr=({errorHandler:e,getLogger:t})=>async(r,o)=>{let n=Hr(404,`Can not ${r.method} ${r.path}`),s=t(r);try{e.execute({request:r,response:o,logger:s,error:n,input:null,output:null,options:{}})}catch(a){et({response:o,logger:s,error:new G(Y(a),n)})}},Tn=e=>(t,{},r)=>{if(Object.values(t?.files||[]).flat().find(({truncated:n})=>n))return r(e);r()},On=e=>({log:e.debug.bind(e)}),Fr=async({getLogger:e,config:t})=>{let r=await Ae("express-fileupload"),{limitError:o,beforeUpload:n,...s}={...typeof t.upload=="object"&&t.upload},a=[];return a.push(async(c,d,p)=>{let m=e(c);try{await n?.({request:c,logger:m})}catch(f){return p(f)}return r({debug:!0,...s,abortOnLimit:!1,parseNested:!0,logger:On(m)})(c,d,p)}),o&&a.push(Tn(o)),a},qr=(e,{},t)=>{Buffer.isBuffer(e.body)&&(e.body={raw:e.body}),t()},Br=({logger:e,config:t})=>async(r,o,n)=>{let s=await t.childLoggerProvider?.({request:r,parent:e})||e;s.debug(`${r.method}: ${r.path}`),r.res&&(r.res.locals[h]={logger:s}),n()},$r=e=>t=>t?.res?.locals[h]?.logger||e,Vr=e=>process.on("deprecation",({message:t,namespace:r,name:o,stack:n})=>e.warn(`${o} (${r}): ${t}`,n.split(`
3
+ `).slice(1))),_r=({servers:e,logger:t,options:{timeout:r,events:o=["SIGINT","SIGTERM"]}})=>{let n=Ur(e,{logger:t,timeout:r}),s=()=>n.shutdown().then(()=>process.exit());for(let a of o)process.on(a,s)};import{gray as Rn,hex as Gr,italic as nt,whiteBright as Pn}from"ansis";var Yr=e=>{if(e.columns<132)return;let t=nt("Proudly supports transgender community.".padStart(109)),r=nt("Start your API server with I/O schema validation and custom middlewares in minutes.".padStart(109)),o=nt("Thank you for choosing Express Zod API for your project.".padStart(132)),n=nt("for Tai".padEnd(20)),s=Gr("#F5A9B8"),a=Gr("#5BCEFA"),c=new Array(14).fill(a,1,3).fill(s,3,5).fill(Pn,5,7).fill(s,7,9).fill(a,9,12).fill(Rn,12,13),d=`
4
4
  8888888888 8888888888P 888 d8888 8888888b. 8888888
5
5
  888 d88P 888 d88888 888 Y88b 888
6
6
  888 d88P 888 d88P888 888 888 888
@@ -15,9 +15,9 @@ ${n}888${r}
15
15
  ${o}
16
16
  `;e.write(d.split(`
17
17
  `).map((p,m)=>c[m]?c[m](p):p).join(`
18
- `))};var Fr=e=>{e.startupLogo!==!1&&Dr(process.stdout);let t=e.errorHandler||Ce,r=br(e.logger)?e.logger:new ke(e.logger);r.debug("Running",{build:"v22.4.0 (ESM)",env:process.env.NODE_ENV||"development"}),Mr(r);let o=jr({logger:r,config:e}),i={getLogger:Ur(r),errorHandler:t},a=kr(i),c=Cr(i);return{...i,logger:r,notFoundHandler:a,parserFailureHandler:c,loggingMiddleware:o}},xn=(e,t)=>{let{logger:r,getLogger:o,notFoundHandler:n,loggingMiddleware:i}=Fr(e);return zt({app:e.app.use(i),routing:t,getLogger:o,config:e}),{notFoundHandler:n,logger:r}},bn=async(e,t)=>{let{logger:r,getLogger:o,notFoundHandler:n,parserFailureHandler:i,loggingMiddleware:a}=Fr(e),c=vt().disable("x-powered-by").use(a);if(e.compression){let b=await Re("compression");c.use(b(typeof e.compression=="object"?e.compression:void 0))}let d={json:[e.jsonParser||vt.json()],raw:[e.rawParser||vt.raw(),Lr],upload:e.upload?await Nr({config:e,getLogger:o}):[]};await e.beforeRouting?.({app:c,getLogger:o}),zt({app:c,routing:t,getLogger:o,config:e,parsers:d}),c.use(i,n);let p=[],m=(b,f)=>()=>b.listen(f,()=>r.info("Listening",f)),g=[];if(e.http){let b=gn.createServer(c);p.push(b),g.push(m(b,e.http.listen))}if(e.https){let b=hn.createServer(e.https.options,c);p.push(b),g.push(m(b,e.https.listen))}return e.gracefulShutdown&&Kr({logger:r,servers:p,options:e.gracefulShutdown===!0?{}:e.gracefulShutdown}),{app:c,logger:r,servers:g.map(b=>b())}};import{OpenApiBuilder as Zs}from"openapi3-ts/oas31";import{pluck as Cs}from"ramda";import{chain as Sn,isEmpty as Tn,map as qr,partition as On,prop as Br,reject as Rn,filter as Zt,concat as Ct}from"ramda";var $r=e=>te(e)&&"or"in e,Vr=e=>te(e)&&"and"in e,kt=e=>!Vr(e)&&!$r(e),_r=e=>{let t=Zt(kt,e),r=Sn(Br("and"),Zt(Vr,e)),[o,n]=On(kt,r),i=Ct(t,o),a=Zt($r,e);return qr(Br("or"),Ct(a,n)).reduce((d,p)=>ue(d,qr(m=>kt(m)?[m]:m.and,p),([m,g])=>Ct(m,g)),Rn(Tn,[i]))};import{isReferenceObject as jt,isSchemaObject as ot}from"openapi3-ts/oas31";import{concat as An,chain as wn,type as Wr,filter as Qr,fromPairs as nt,has as En,isNil as In,map as je,mergeDeepRight as zn,mergeDeepWith as vn,objOf as Zn,omit as st,pipe as Xr,pluck as Cn,reject as kn,times as Nn,toLower as Ln,union as jn,when as Un,xprod as Nt,zip as Mn}from"ramda";import{z as A}from"zod";var ae=(e,{onEach:t,rules:r,onMissing:o,ctx:n={}})=>{let i=r[e._def[x]?.brand]||r[e._def.typeName],c=i?i(e,{...n,next:p=>ae(p,{ctx:n,onEach:t,rules:r,onMissing:o})}):o(e,n),d=t&&t(e,{prev:c,...n});return d?{...c,...d}:c};var Gr=["a-im","accept","accept-additions","accept-ch","accept-charset","accept-datetime","accept-encoding","accept-features","accept-language","accept-patch","accept-post","accept-ranges","accept-signature","access-control","access-control-allow-credentials","access-control-allow-headers","access-control-allow-methods","access-control-allow-origin","access-control-expose-headers","access-control-max-age","access-control-request-headers","access-control-request-method","age","allow","alpn","alt-svc","alt-used","alternates","amp-cache-transform","apply-to-redirect-ref","authentication-control","authentication-info","authorization","available-dictionary","c-ext","c-man","c-opt","c-pep","c-pep-info","cache-control","cache-status","cal-managed-id","caldav-timezones","capsule-protocol","cdn-cache-control","cdn-loop","cert-not-after","cert-not-before","clear-site-data","client-cert","client-cert-chain","close","cmcd-object","cmcd-request","cmcd-session","cmcd-status","cmsd-dynamic","cmsd-static","concealed-auth-export","configuration-context","connection","content-base","content-digest","content-disposition","content-encoding","content-id","content-language","content-length","content-location","content-md5","content-range","content-script-type","content-security-policy","content-security-policy-report-only","content-style-type","content-type","content-version","cookie","cookie2","cross-origin-embedder-policy","cross-origin-embedder-policy-report-only","cross-origin-opener-policy","cross-origin-opener-policy-report-only","cross-origin-resource-policy","cta-common-access-token","dasl","date","dav","default-style","delta-base","deprecation","depth","derived-from","destination","differential-id","dictionary-id","digest","dpop","dpop-nonce","early-data","ediint-features","etag","expect","expect-ct","expires","ext","forwarded","from","getprofile","hobareg","host","http2-settings","if","if-match","if-modified-since","if-none-match","if-range","if-schedule-tag-match","if-unmodified-since","im","include-referred-token-binding-id","isolation","keep-alive","label","last-event-id","last-modified","link","link-template","location","lock-token","man","max-forwards","memento-datetime","meter","method-check","method-check-expires","mime-version","negotiate","nel","odata-entityid","odata-isolation","odata-maxversion","odata-version","opt","optional-www-authenticate","ordering-type","origin","origin-agent-cluster","oscore","oslc-core-version","overwrite","p3p","pep","pep-info","permissions-policy","pics-label","ping-from","ping-to","position","pragma","prefer","preference-applied","priority","profileobject","protocol","protocol-info","protocol-query","protocol-request","proxy-authenticate","proxy-authentication-info","proxy-authorization","proxy-features","proxy-instruction","proxy-status","public","public-key-pins","public-key-pins-report-only","range","redirect-ref","referer","referer-root","referrer-policy","refresh","repeatability-client-id","repeatability-first-sent","repeatability-request-id","repeatability-result","replay-nonce","reporting-endpoints","repr-digest","retry-after","safe","schedule-reply","schedule-tag","sec-gpc","sec-purpose","sec-token-binding","sec-websocket-accept","sec-websocket-extensions","sec-websocket-key","sec-websocket-protocol","sec-websocket-version","security-scheme","server","server-timing","set-cookie","set-cookie2","setprofile","signature","signature-input","slug","soapaction","status-uri","strict-transport-security","sunset","surrogate-capability","surrogate-control","tcn","te","timeout","timing-allow-origin","topic","traceparent","tracestate","trailer","transfer-encoding","ttl","upgrade","urgency","uri","use-as-dictionary","user-agent","variant-vary","vary","via","want-content-digest","want-digest","want-repr-digest","warning","www-authenticate","x-content-type-options","x-frame-options"];var Jr=50,eo="https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Date/toISOString",Kn={integer:0,number:0,string:"",boolean:!1,object:{},null:null,array:[]},to=/:([A-Za-z0-9_]+)/g,Hn=/^\d{4}-\d{2}-\d{2}$/,Dn=/^\d{2}:\d{2}:\d{2}(\.\d+)?$/,Fn=e=>e?/^\d{4}-\d{2}-\d{2}T\d{2}:\d{2}:\d{2}(\.\d+)?(([+-]\d{2}:\d{2})|Z)$/:/^\d{4}-\d{2}-\d{2}T\d{2}:\d{2}:\d{2}(\.\d+)?Z$/,qn=e=>e.match(to)?.map(t=>t.slice(1))||[],ro=e=>e.replace(to,t=>`{${t.slice(1)}}`),Bn=({_def:e},{next:t})=>({...t(e.innerType),default:e[x]?.defaultLabel||e.defaultValue()}),$n=({_def:{innerType:e}},{next:t})=>t(e),Vn=()=>({format:"any"}),_n=({},e)=>{if(e.isResponse)throw new U("Please use ez.upload() only for input.",e);return{type:"string",format:"binary"}},Gn=e=>{let t=e.unwrap();return{type:"string",format:t instanceof A.ZodString?t._def.checks.find(r=>r.kind==="base64")?"byte":"file":"binary"}},Jn=({options:e},{next:t})=>({oneOf:e.map(t)}),Yn=({options:e,discriminator:t},{next:r})=>({discriminator:{propertyName:t},oneOf:e.map(r)}),Wn=(e,t)=>{if(Array.isArray(e)&&Array.isArray(t))return An(e,t);if(e===t)return t;throw new Error("Can not flatten properties")},Qn=e=>{let[t,r]=e.filter(ot).filter(n=>n.type==="object"&&Object.keys(n).every(i=>["type","properties","required","examples"].includes(i)));if(!t||!r)throw new Error("Can not flatten objects");let o={type:"object"};return(t.properties||r.properties)&&(o.properties=vn(Wn,t.properties||{},r.properties||{})),(t.required||r.required)&&(o.required=jn(t.required||[],r.required||[])),(t.examples||r.examples)&&(o.examples=ue(t.examples||[],r.examples||[],([n,i])=>zn(n,i))),o},Xn=({_def:{left:e,right:t}},{next:r})=>{let o=[e,t].map(r);try{return Qn(o)}catch{}return{allOf:o}},es=(e,{next:t})=>t(e.unwrap()),ts=(e,{next:t})=>t(e.unwrap()),rs=(e,{next:t})=>{let r=t(e.unwrap());return ot(r)&&(r.type=no(r)),r},oo=e=>{let t=Ln(Wr(e));return typeof e=="bigint"?"integer":t==="number"||t==="string"||t==="boolean"||t==="object"||t==="null"||t==="array"?t:void 0},Yr=e=>({type:oo(Object.values(e.enum)[0]),enum:Object.values(e.enum)}),os=({value:e})=>({type:oo(e),const:e}),ns=(e,{isResponse:t,next:r})=>{let o=Object.keys(e.shape),n=c=>t&&Ie(c)?c instanceof A.ZodOptional:c.isOptional(),i=o.filter(c=>!n(e.shape[c])),a={type:"object"};return o.length&&(a.properties=rt(e,r)),i.length&&(a.required=i),a},ss=()=>({type:"null"}),is=({},e)=>{if(e.isResponse)throw new U("Please use ez.dateOut() for output.",e);return{description:"YYYY-MM-DDTHH:mm:ss.sssZ",type:"string",format:"date-time",pattern:/^\d{4}-\d{2}-\d{2}(T\d{2}:\d{2}:\d{2}(\.\d+)?)?Z?$/.source,externalDocs:{url:eo}}},as=({},e)=>{if(!e.isResponse)throw new U("Please use ez.dateIn() for input.",e);return{description:"YYYY-MM-DDTHH:mm:ss.sssZ",type:"string",format:"date-time",externalDocs:{url:eo}}},ps=({},e)=>{throw new U(`Using z.date() within ${e.isResponse?"output":"input"} schema is forbidden. Please use ez.date${e.isResponse?"Out":"In"}() instead. Check out the documentation for details.`,e)},cs=()=>({type:"boolean"}),ds=()=>({type:"integer",format:"bigint"}),ms=e=>e.every(t=>t instanceof A.ZodLiteral),ls=({keySchema:e,valueSchema:t},{next:r})=>{if(e instanceof A.ZodEnum||e instanceof A.ZodNativeEnum){let o=Object.values(e.enum),n={type:"object"};return o.length&&(n.properties=rt(A.object(nt(Nt(o,[t]))),r),n.required=o),n}if(e instanceof A.ZodLiteral)return{type:"object",properties:rt(A.object({[e.value]:t}),r),required:[e.value]};if(e instanceof A.ZodUnion&&ms(e.options)){let o=je(i=>`${i.value}`,e.options),n=nt(Nt(o,[t]));return{type:"object",properties:rt(A.object(n),r),required:o}}return{type:"object",additionalProperties:r(t)}},us=({_def:{minLength:e,maxLength:t},element:r},{next:o})=>{let n={type:"array",items:o(r)};return e&&(n.minItems=e.value),t&&(n.maxItems=t.value),n},ys=({items:e,_def:{rest:t}},{next:r})=>({type:"array",prefixItems:e.map(r),items:t===null?{not:{}}:r(t)}),fs=({isEmail:e,isURL:t,minLength:r,maxLength:o,isUUID:n,isCUID:i,isCUID2:a,isULID:c,isIP:d,isEmoji:p,isDatetime:m,isCIDR:g,isDate:b,isTime:f,isBase64:R,isNANOID:T,isBase64url:Z,isDuration:C,_def:{checks:S}})=>{let O=S.find(z=>z.kind==="regex"),k=S.find(z=>z.kind==="datetime"),E=S.some(z=>z.kind==="jwt"),L=S.find(z=>z.kind==="length"),I={type:"string"},W={"date-time":m,byte:R,base64url:Z,date:b,time:f,duration:C,email:e,url:t,uuid:n,cuid:i,cuid2:a,ulid:c,nanoid:T,jwt:E,ip:d,cidr:g,emoji:p};for(let z in W)if(W[z]){I.format=z;break}return L&&([I.minLength,I.maxLength]=[L.value,L.value]),r!==null&&(I.minLength=r),o!==null&&(I.maxLength=o),b&&(I.pattern=Hn.source),f&&(I.pattern=Dn.source),m&&(I.pattern=Fn(k?.offset).source),O&&(I.pattern=O.regex.source),I},gs=({isInt:e,maxValue:t,minValue:r,_def:{checks:o}})=>{let n=o.find(g=>g.kind==="min"),i=r===null?e?Number.MIN_SAFE_INTEGER:-Number.MAX_VALUE:r,a=n?n.inclusive:!0,c=o.find(g=>g.kind==="max"),d=t===null?e?Number.MAX_SAFE_INTEGER:Number.MAX_VALUE:t,p=c?c.inclusive:!0,m={type:e?"integer":"number",format:e?"int64":"double"};return a?m.minimum=i:m.exclusiveMinimum=i,p?m.maximum=d:m.exclusiveMaximum=d,m},rt=({shape:e},t)=>je(t,e),hs=e=>{let t=Array.isArray(e.type)?e.type[0]:e.type;return Kn?.[t]},no=({type:e})=>e==="null"?e:typeof e=="string"?[e,"null"]:e?[...new Set(e).add("null")]:"null",xs=(e,{isResponse:t,next:r})=>{let o=r(e.innerType()),{effect:n}=e._def;if(t&&n.type==="transform"&&ot(o)){let i=qe(e,hs(o));return i&&["number","string","boolean"].includes(i)?{type:i}:r(A.any())}if(!t&&n.type==="preprocess"&&ot(o)){let{type:i,...a}=o;return{...a,format:`${a.format||i} (preprocessed)`}}return o},bs=({_def:e},{isResponse:t,next:r})=>r(e[t?"out":"in"]),Ss=(e,{next:t})=>t(e.unwrap()),Ts=(e,{next:t,makeRef:r})=>r(e,()=>t(e.schema)),Os=(e,{next:t})=>t(e.unwrap().shape.raw),so=e=>e.length?nt(Mn(Nn(t=>`example${t+1}`,e.length),je(Zn("value"),e))):void 0,io=(e,t,r=[])=>Xr(_,je(Un(o=>Wr(o)==="Object",st(r))),so)({schema:e,variant:t?"parsed":"original",validate:!0}),Rs=(e,t)=>Xr(_,Qr(En(t)),Cn(t),so)({schema:e,variant:"original",validate:!0}),pe=e=>e instanceof A.ZodObject?e:e instanceof A.ZodBranded?pe(e.unwrap()):e instanceof A.ZodUnion||e instanceof A.ZodDiscriminatedUnion?e.options.map(t=>pe(t)).reduce((t,r)=>t.merge(r.partial()),A.object({})):e instanceof A.ZodEffects?pe(e._def.schema):e instanceof A.ZodPipeline?pe(e._def.in):pe(e._def.left).merge(pe(e._def.right)),Ps=(e,t)=>t?.includes(e)||e.startsWith("x-")||Gr.includes(e),ao=({path:e,method:t,schema:r,inputSources:o,makeRef:n,composition:i,brandHandling:a,isHeader:c,security:d,description:p=`${t.toUpperCase()} ${e} Parameter`})=>{let{shape:m}=pe(r),g=qn(e),b=o.includes("query"),f=o.includes("params"),R=o.includes("headers"),T=S=>f&&g.includes(S),Z=wn(Qr(S=>S.type==="header"),d??[]).map(({name:S})=>S),C=S=>R&&(c?.(S,t,e)??Ps(S,Z));return Object.keys(m).reduce((S,O)=>{let k=T(O)?"path":C(O)?"header":b?"query":void 0;if(!k)return S;let E=ae(m[O],{rules:{...a,...Ut},onEach:Mt,onMissing:Kt,ctx:{isResponse:!1,makeRef:n,path:e,method:t}}),L=i==="components"?n(m[O],E,G(p,O)):E;return S.concat({name:O,in:k,required:!m[O].isOptional(),description:E.description||p,schema:L,examples:Rs(r,O)})},[])},Ut={ZodString:fs,ZodNumber:gs,ZodBigInt:ds,ZodBoolean:cs,ZodNull:ss,ZodArray:us,ZodTuple:ys,ZodRecord:ls,ZodObject:ns,ZodLiteral:os,ZodIntersection:Xn,ZodUnion:Jn,ZodAny:Vn,ZodDefault:Bn,ZodEnum:Yr,ZodNativeEnum:Yr,ZodEffects:xs,ZodOptional:es,ZodNullable:rs,ZodDiscriminatedUnion:Yn,ZodBranded:Ss,ZodDate:ps,ZodCatch:$n,ZodPipeline:bs,ZodLazy:Ts,ZodReadonly:ts,[M]:Gn,[ge]:_n,[oe]:as,[re]:is,[J]:Os},Mt=(e,{isResponse:t,prev:r})=>{if(jt(r))return{};let{description:o}=e,n=e instanceof A.ZodLazy,i=r.type!==void 0,a=t&&Ie(e),c=!n&&i&&!a&&e.isNullable(),d={};if(o&&(d.description=o),c&&(d.type=no(r)),!n){let p=_({schema:e,variant:t?"parsed":"original",validate:!0});p.length&&(d.examples=p.slice())}return d},Kt=(e,t)=>{throw new U(`Zod type ${e.constructor.name} is unsupported.`,t)},Lt=(e,t)=>{if(jt(e))return e;let r={...e};return r.properties&&(r.properties=st(t,r.properties)),r.examples&&(r.examples=r.examples.map(o=>st(t,o))),r.required&&(r.required=r.required.filter(o=>!t.includes(o))),r.allOf&&(r.allOf=r.allOf.map(o=>Lt(o,t))),r.oneOf&&(r.oneOf=r.oneOf.map(o=>Lt(o,t))),r},po=e=>jt(e)?e:st(["examples"],e),co=({method:e,path:t,schema:r,mimeTypes:o,variant:n,makeRef:i,composition:a,hasMultipleStatusCodes:c,statusCode:d,brandHandling:p,description:m=`${e.toUpperCase()} ${t} ${Tt(n)} response ${c?d:""}`.trim()})=>{if(!o)return{description:m};let g=po(ae(r,{rules:{...p,...Ut},onEach:Mt,onMissing:Kt,ctx:{isResponse:!0,makeRef:i,path:t,method:e}})),b={schema:a==="components"?i(r,g,G(m)):g,examples:io(r,!0)};return{description:m,content:nt(Nt(o,[b]))}},As=({format:e})=>{let t={type:"http",scheme:"bearer"};return e&&(t.bearerFormat=e),t},ws=({name:e},t)=>{let r={type:"apiKey",in:"query",name:e};return t?.includes("body")&&(t?.includes("query")?(r["x-in-alternative"]="body",r.description=`${e} CAN also be supplied within the request body`):(r["x-in-actual"]="body",r.description=`${e} MUST be supplied within the request body instead of query`)),r},Es=({name:e})=>({type:"apiKey",in:"header",name:e}),Is=({name:e})=>({type:"apiKey",in:"cookie",name:e}),zs=({url:e})=>({type:"openIdConnect",openIdConnectUrl:e}),vs=({flows:e={}})=>({type:"oauth2",flows:je(t=>({...t,scopes:t.scopes||{}}),kn(In,e))}),mo=(e,t=[])=>{let r=o=>o.type==="basic"?{type:"http",scheme:"basic"}:o.type==="bearer"?As(o):o.type==="input"?ws(o,t):o.type==="header"?Es(o):o.type==="cookie"?Is(o):o.type==="openid"?zs(o):vs(o);return e.map(o=>o.map(r))},lo=(e,t,r)=>e.map(o=>o.reduce((n,i)=>{let a=r(i),c=["oauth2","openIdConnect"].includes(i.type);return Object.assign(n,{[a]:c?t:[]})},{})),uo=({method:e,path:t,schema:r,mimeType:o,makeRef:n,composition:i,brandHandling:a,paramNames:c,description:d=`${e.toUpperCase()} ${t} Request body`})=>{let p=po(Lt(ae(r,{rules:{...a,...Ut},onEach:Mt,onMissing:Kt,ctx:{isResponse:!1,makeRef:n,path:t,method:e}}),c)),m={schema:i==="components"?n(r,p,G(d)):p,examples:io(r,!1,c)};return{description:d,content:{[o]:m}}},yo=e=>Object.entries(e).reduce((t,[r,o])=>{if(!o)return t;let n={name:r,description:typeof o=="string"?o:o.description};return typeof o=="object"&&o.url&&(n.externalDocs={url:o.url}),t.concat(n)},[]),Ht=e=>e.length<=Jr?e:e.slice(0,Jr-1)+"\u2026";var Dt=class extends Zs{lastSecuritySchemaIds=new Map;lastOperationIdSuffixes=new Map;references=new Map;makeRef(t,r,o=this.references.get(t)){return o||(o=`Schema${this.references.size+1}`,this.references.set(t,o),typeof r=="function"&&(r=r())),typeof r=="object"&&this.addSchema(o,r),{$ref:`#/components/schemas/${o}`}}ensureUniqOperationId(t,r,o){let n=o||G(r,t),i=this.lastOperationIdSuffixes.get(n);if(i===void 0)return this.lastOperationIdSuffixes.set(n,1),n;if(o)throw new U(`Duplicated operationId: "${o}"`,{method:r,isResponse:!1,path:t});return i++,this.lastOperationIdSuffixes.set(n,i),`${n}${i}`}ensureUniqSecuritySchemaName(t){let r=JSON.stringify(t);for(let n in this.rootDoc.components?.securitySchemes||{})if(r===JSON.stringify(this.rootDoc.components?.securitySchemes?.[n]))return n;let o=(this.lastSecuritySchemaIds.get(t.type)||0)+1;return this.lastSecuritySchemaIds.set(t.type,o),`${t.type.toUpperCase()}_${o}`}constructor({routing:t,config:r,title:o,version:n,serverUrl:i,descriptions:a,brandHandling:c,tags:d,isHeader:p,hasSummaryFromDescription:m=!0,composition:g="inline"}){super(),this.addInfo({title:o,version:n});for(let f of typeof i=="string"?[i]:i)this.addServer({url:f});Pe({routing:t,onEndpoint:(f,R,T)=>{let Z={path:R,method:T,endpoint:f,composition:g,brandHandling:c,makeRef:this.makeRef.bind(this)},[C,S]=["short","long"].map(f.getDescription.bind(f)),O=C?Ht(C):m&&S?Ht(S):void 0,k=r.inputSources?.[T]||bt[T],E=this.ensureUniqOperationId(R,T,f.getOperationId(T)),L=_r(f.getSecurity()),I=ao({...Z,inputSources:k,isHeader:p,security:L,schema:f.getSchema("input"),description:a?.requestParameter?.call(null,{method:T,path:R,operationId:E})}),W={};for(let B of Te){let Q=f.getResponses(B);for(let{mimeTypes:ht,schema:Ke,statusCodes:He}of Q)for(let xt of He)W[xt]=co({...Z,variant:B,schema:Ke,mimeTypes:ht,statusCode:xt,hasMultipleStatusCodes:Q.length>1||He.length>1,description:a?.[`${B}Response`]?.call(null,{method:T,path:R,operationId:E,statusCode:xt})})}let z=k.includes("body")?uo({...Z,paramNames:Cs("name",I),schema:f.getSchema("input"),mimeType:w[f.getRequestType()],description:a?.requestBody?.call(null,{method:T,path:R,operationId:E})}):void 0,gt=lo(mo(L,k),f.getScopes(),B=>{let Q=this.ensureUniqSecuritySchemaName(B);return this.addSecurityScheme(Q,B),Q});this.addPath(ro(R),{[T]:{operationId:E,summary:O,description:S,tags:Be(f.getTags()),parameters:Be(I),requestBody:z,security:Be(gt),responses:W}})}}),d&&(this.rootDoc.tags=yo(d))}};import{createRequest as ks,createResponse as Ns}from"node-mocks-http";var Ls=e=>ks({...e,headers:{"content-type":w.json,...e?.headers}}),js=e=>Ns(e),Us=e=>{let t={warn:[],error:[],info:[],debug:[]};return new Proxy(e||{},{get(r,o,n){return o==="_getLogs"?()=>t:Sr(o)?(...i)=>t[o].push(i):Reflect.get(r,o,n)}})},fo=({requestProps:e,responseOptions:t,configProps:r,loggerProps:o})=>{let n=Ls(e),i=js({req:n,...t});i.req=t?.req||n,n.res=i;let a=Us(o),c={cors:!1,logger:a,...r};return{requestMock:n,responseMock:i,loggerMock:a,configMock:c}},Ms=async({endpoint:e,...t})=>{let{requestMock:r,responseMock:o,loggerMock:n,configMock:i}=fo(t);return await e.execute({request:r,response:o,config:i,logger:n}),{requestMock:r,responseMock:o,loggerMock:n}},Ks=async({middleware:e,options:t={},errorHandler:r,...o})=>{let{requestMock:n,responseMock:i,loggerMock:a,configMock:c}=fo(o),d=Fe(n,c.inputSources);try{let p=await e.execute({request:n,response:i,logger:a,input:d,options:t});return{requestMock:n,responseMock:i,loggerMock:a,output:p}}catch(p){if(!r)throw p;return r(V(p),i),{requestMock:n,responseMock:i,loggerMock:a,output:{}}}};import{chain as yi}from"ramda";import ft from"typescript";import{z as fi}from"zod";import F from"typescript";var go=["get","post","put","delete","patch"];import u from"typescript";var s=u.factory,it=[s.createModifier(u.SyntaxKind.ExportKeyword)],Hs=[s.createModifier(u.SyntaxKind.AsyncKeyword)],Ue={public:[s.createModifier(u.SyntaxKind.PublicKeyword)],protectedReadonly:[s.createModifier(u.SyntaxKind.ProtectedKeyword),s.createModifier(u.SyntaxKind.ReadonlyKeyword)]},at=(e,t)=>u.addSyntheticLeadingComment(e,u.SyntaxKind.MultiLineCommentTrivia,`* ${t} `,!0),Ft=(e,t)=>{let r=u.createSourceFile("print.ts","",u.ScriptTarget.Latest,!1,u.ScriptKind.TS);return u.createPrinter(t).printNode(u.EmitHint.Unspecified,e,r)},Ds=/^[A-Za-z_$][A-Za-z0-9_$]*$/,qt=e=>typeof e=="number"?s.createNumericLiteral(e):Ds.test(e)?s.createIdentifier(e):s.createStringLiteral(e),pt=(e,...t)=>s.createTemplateExpression(s.createTemplateHead(e),t.map(([r,o=""],n)=>s.createTemplateSpan(r,n===t.length-1?s.createTemplateTail(o):s.createTemplateMiddle(o)))),Bt=s.createExpressionWithTypeArguments(s.createIdentifier("Record"),[s.createKeywordTypeNode(u.SyntaxKind.StringKeyword),s.createKeywordTypeNode(u.SyntaxKind.AnyKeyword)]),ct=(e,{type:t,mod:r,init:o,optional:n}={})=>s.createParameterDeclaration(r,void 0,e,n?s.createToken(u.SyntaxKind.QuestionToken):void 0,t,o),ce=e=>Object.entries(e).map(([t,r])=>ct(s.createIdentifier(t),r&&"kind"in r?{type:r}:r)),$t=(e,t=[])=>s.createConstructorDeclaration(Ue.public,e,s.createBlock(t)),l=e=>typeof e=="string"||u.isIdentifier(e)?s.createTypeReferenceNode(e):e,de=(e,t,{isOptional:r}={})=>s.createPropertySignature(void 0,qt(e),r?s.createToken(u.SyntaxKind.QuestionToken):void 0,l(t)),Vt=e=>u.setEmitFlags(e,u.EmitFlags.SingleLine),_t=(...e)=>s.createArrayBindingPattern(e.map(t=>s.createBindingElement(void 0,void 0,t))),v=(e,t,{type:r,expose:o}={})=>s.createVariableStatement(o&&it,s.createVariableDeclarationList([s.createVariableDeclaration(e,void 0,r,t)],u.NodeFlags.Const)),Gt=(e,t)=>D(e,s.createUnionTypeNode(t.map(r=>s.createLiteralTypeNode(s.createStringLiteral(r)))),{expose:!0}),D=(e,t,{expose:r,comment:o,params:n}={})=>{let i=s.createTypeAliasDeclaration(r?it:void 0,e,n&&lt(n),t);return o?at(i,o):i},ho=(e,t)=>s.createPropertyDeclaration(Ue.public,e,void 0,t,void 0),Jt=(e,t,r,{typeParams:o,returns:n}={})=>s.createMethodDeclaration(Ue.public,void 0,e,void 0,o&&lt(o),t,n,r),Yt=(e,t,{typeParams:r}={})=>s.createClassDeclaration(it,e,r&&lt(r),void 0,t),Wt=e=>s.createTypeOperatorNode(u.SyntaxKind.KeyOfKeyword,l(e)),dt=e=>s.createTypeReferenceNode(Promise.name,[e==="any"?s.createKeywordTypeNode(u.SyntaxKind.AnyKeyword):e]),mt=(e,t,{expose:r,comment:o}={})=>{let n=s.createInterfaceDeclaration(r?it:void 0,e,void 0,void 0,t);return o?at(n,o):n},lt=e=>Object.entries(e).map(([t,r])=>{let{type:o,init:n}=r&&"init"in r?r:{type:r};return s.createTypeParameterDeclaration([],t,o&&l(o),typeof n=="number"?s.createKeywordTypeNode(n):n)}),me=(e,t,{isAsync:r,typeParams:o}={})=>s.createArrowFunction(r?Hs:void 0,o&&lt(o),Array.isArray(e)?e.map(n=>ct(n)):ce(e),void 0,void 0,t),P=e=>e,Me=(e,t,r)=>s.createConditionalExpression(e,s.createToken(u.SyntaxKind.QuestionToken),t,s.createToken(u.SyntaxKind.ColonToken),r),j=(e,t,r)=>s.createCallExpression(s.createPropertyAccessExpression(Array.isArray(e)?s.createPropertyAccessExpression(...e):e,t),void 0,r),Ae=(e,...t)=>s.createNewExpression(e,void 0,t),ut=(e,t)=>s.createTypeReferenceNode("Extract",[l(e),t]),Qt=(e,t)=>s.createExpressionStatement(s.createBinaryExpression(e,s.createToken(u.SyntaxKind.EqualsToken),t)),Fs=[u.SyntaxKind.AnyKeyword,u.SyntaxKind.BigIntKeyword,u.SyntaxKind.BooleanKeyword,u.SyntaxKind.NeverKeyword,u.SyntaxKind.NumberKeyword,u.SyntaxKind.ObjectKeyword,u.SyntaxKind.StringKeyword,u.SyntaxKind.SymbolKeyword,u.SyntaxKind.UndefinedKeyword,u.SyntaxKind.UnknownKeyword,u.SyntaxKind.VoidKeyword],xo=e=>Fs.includes(e.kind);var yt=class{constructor(t){this.serverUrl=t}paths=new Set;tags=new Map;registry=new Map;ids={pathType:s.createIdentifier("Path"),implementationType:s.createIdentifier("Implementation"),keyParameter:s.createIdentifier("key"),pathParameter:s.createIdentifier("path"),paramsArgument:s.createIdentifier("params"),ctxArgument:s.createIdentifier("ctx"),methodParameter:s.createIdentifier("method"),requestParameter:s.createIdentifier("request"),eventParameter:s.createIdentifier("event"),dataParameter:s.createIdentifier("data"),handlerParameter:s.createIdentifier("handler"),msgParameter:s.createIdentifier("msg"),parseRequestFn:s.createIdentifier("parseRequest"),substituteFn:s.createIdentifier("substitute"),provideMethod:s.createIdentifier("provide"),onMethod:s.createIdentifier("on"),implementationArgument:s.createIdentifier("implementation"),hasBodyConst:s.createIdentifier("hasBody"),undefinedValue:s.createIdentifier("undefined"),responseConst:s.createIdentifier("response"),restConst:s.createIdentifier("rest"),searchParamsConst:s.createIdentifier("searchParams"),defaultImplementationConst:s.createIdentifier("defaultImplementation"),clientConst:s.createIdentifier("client"),contentTypeConst:s.createIdentifier("contentType"),isJsonConst:s.createIdentifier("isJSON"),sourceProp:s.createIdentifier("source")};interfaces={input:s.createIdentifier("Input"),positive:s.createIdentifier("PositiveResponse"),negative:s.createIdentifier("NegativeResponse"),encoded:s.createIdentifier("EncodedResponse"),response:s.createIdentifier("Response")};methodType=Gt("Method",go);someOfType=D("SomeOf",s.createIndexedAccessTypeNode(l("T"),Wt("T")),{params:{T:void 0}});requestType=D("Request",Wt(this.interfaces.input),{expose:!0});someOf=({name:t})=>s.createTypeReferenceNode(this.someOfType.name,[l(t)]);makePathType=()=>Gt(this.ids.pathType,Array.from(this.paths));makePublicInterfaces=()=>Object.keys(this.interfaces).map(t=>mt(this.interfaces[t],Array.from(this.registry).map(([r,o])=>de(r,o[t])),{expose:!0}));makeEndpointTags=()=>v("endpointTags",s.createObjectLiteralExpression(Array.from(this.tags).map(([t,r])=>s.createPropertyAssignment(qt(t),s.createArrayLiteralExpression(r.map(o=>s.createStringLiteral(o)))))),{expose:!0});makeImplementationType=()=>D(this.ids.implementationType,s.createFunctionTypeNode(void 0,ce({[this.ids.methodParameter.text]:l(this.methodType.name),[this.ids.pathParameter.text]:s.createKeywordTypeNode(F.SyntaxKind.StringKeyword),[this.ids.paramsArgument.text]:Bt,[this.ids.ctxArgument.text]:{optional:!0,type:l("T")}}),dt("any")),{expose:!0,params:{T:{init:F.SyntaxKind.UnknownKeyword}}});makeParseRequestFn=()=>v(this.ids.parseRequestFn,me({[this.ids.requestParameter.text]:s.createKeywordTypeNode(F.SyntaxKind.StringKeyword)},s.createAsExpression(j(this.ids.requestParameter,P("split"),[s.createRegularExpressionLiteral("/ (.+)/"),s.createNumericLiteral(2)]),s.createTupleTypeNode([l(this.methodType.name),l(this.ids.pathType)]))));makeSubstituteFn=()=>v(this.ids.substituteFn,me({[this.ids.pathParameter.text]:s.createKeywordTypeNode(F.SyntaxKind.StringKeyword),[this.ids.paramsArgument.text]:Bt},s.createBlock([v(this.ids.restConst,s.createObjectLiteralExpression([s.createSpreadAssignment(this.ids.paramsArgument)])),s.createForInStatement(s.createVariableDeclarationList([s.createVariableDeclaration(this.ids.keyParameter)],F.NodeFlags.Const),this.ids.paramsArgument,s.createBlock([Qt(this.ids.pathParameter,j(this.ids.pathParameter,P("replace"),[pt(":",[this.ids.keyParameter]),me([],s.createBlock([s.createExpressionStatement(s.createDeleteExpression(s.createElementAccessExpression(this.ids.restConst,this.ids.keyParameter))),s.createReturnStatement(s.createElementAccessExpression(this.ids.paramsArgument,this.ids.keyParameter))]))]))])),s.createReturnStatement(s.createAsExpression(s.createArrayLiteralExpression([this.ids.pathParameter,this.ids.restConst]),l("const")))])));makeProvider=()=>Jt(this.ids.provideMethod,ce({[this.ids.requestParameter.text]:l("K"),[this.ids.paramsArgument.text]:s.createIndexedAccessTypeNode(l(this.interfaces.input),l("K")),[this.ids.ctxArgument.text]:{optional:!0,type:l("T")}}),s.createBlock([v(_t(this.ids.methodParameter,this.ids.pathParameter),s.createCallExpression(this.ids.parseRequestFn,void 0,[this.ids.requestParameter])),s.createReturnStatement(j(s.createThis(),this.ids.implementationArgument,[this.ids.methodParameter,s.createSpreadElement(s.createCallExpression(this.ids.substituteFn,void 0,[this.ids.pathParameter,this.ids.paramsArgument])),this.ids.ctxArgument]))]),{typeParams:{K:this.requestType.name},returns:dt(s.createIndexedAccessTypeNode(l(this.interfaces.response),l("K")))});makeClientClass=t=>Yt(t,[$t([ct(this.ids.implementationArgument,{type:s.createTypeReferenceNode(this.ids.implementationType,[l("T")]),mod:Ue.protectedReadonly,init:this.ids.defaultImplementationConst})]),this.makeProvider()],{typeParams:{T:void 0}});makeSearchParams=t=>pt("?",[Ae(s.createIdentifier(URLSearchParams.name),t)]);makeFetchURL=()=>Ae(s.createIdentifier(URL.name),pt("",[this.ids.pathParameter],[this.ids.searchParamsConst]),s.createStringLiteral(this.serverUrl));makeDefaultImplementation=()=>{let t=s.createPropertyAssignment(P("method"),j(this.ids.methodParameter,P("toUpperCase"))),r=s.createPropertyAssignment(P("headers"),Me(this.ids.hasBodyConst,s.createObjectLiteralExpression([s.createPropertyAssignment(s.createStringLiteral("Content-Type"),s.createStringLiteral(w.json))]),this.ids.undefinedValue)),o=s.createPropertyAssignment(P("body"),Me(this.ids.hasBodyConst,j(s.createIdentifier(JSON[Symbol.toStringTag]),P("stringify"),[this.ids.paramsArgument]),this.ids.undefinedValue)),n=v(this.ids.responseConst,s.createAwaitExpression(s.createCallExpression(s.createIdentifier(fetch.name),void 0,[this.makeFetchURL(),s.createObjectLiteralExpression([t,r,o])]))),i=v(this.ids.hasBodyConst,s.createLogicalNot(j(s.createArrayLiteralExpression([s.createStringLiteral("get"),s.createStringLiteral("delete")]),P("includes"),[this.ids.methodParameter]))),a=v(this.ids.searchParamsConst,Me(this.ids.hasBodyConst,s.createStringLiteral(""),this.makeSearchParams(this.ids.paramsArgument))),c=v(this.ids.contentTypeConst,j([this.ids.responseConst,P("headers")],P("get"),[s.createStringLiteral("content-type")])),d=s.createIfStatement(s.createPrefixUnaryExpression(F.SyntaxKind.ExclamationToken,this.ids.contentTypeConst),s.createReturnStatement()),p=v(this.ids.isJsonConst,j(this.ids.contentTypeConst,P("startsWith"),[s.createStringLiteral(w.json)])),m=s.createReturnStatement(s.createCallExpression(s.createElementAccessExpression(this.ids.responseConst,Me(this.ids.isJsonConst,s.createStringLiteral(P("json")),s.createStringLiteral(P("text")))),void 0,[]));return v(this.ids.defaultImplementationConst,me([this.ids.methodParameter,this.ids.pathParameter,this.ids.paramsArgument],s.createBlock([i,a,n,c,d,p,m]),{isAsync:!0}),{type:l(this.ids.implementationType)})};makeSubscriptionConstructor=()=>$t(ce({request:l("K"),params:s.createIndexedAccessTypeNode(l(this.interfaces.input),l("K"))}),[v(_t(this.ids.pathParameter,this.ids.restConst),s.createCallExpression(this.ids.substituteFn,void 0,[s.createElementAccessExpression(s.createCallExpression(this.ids.parseRequestFn,void 0,[this.ids.requestParameter]),s.createNumericLiteral(1)),this.ids.paramsArgument])),v(this.ids.searchParamsConst,this.makeSearchParams(this.ids.restConst)),Qt(s.createPropertyAccessExpression(s.createThis(),this.ids.sourceProp),Ae(s.createIdentifier("EventSource"),this.makeFetchURL()))]);makeEventNarrow=t=>s.createTypeLiteralNode([de(P("event"),t)]);makeOnMethod=()=>Jt(this.ids.onMethod,ce({[this.ids.eventParameter.text]:l("E"),[this.ids.handlerParameter.text]:s.createFunctionTypeNode(void 0,ce({[this.ids.dataParameter.text]:s.createIndexedAccessTypeNode(ut("R",Vt(this.makeEventNarrow("E"))),s.createLiteralTypeNode(s.createStringLiteral(P("data"))))}),s.createUnionTypeNode([s.createKeywordTypeNode(F.SyntaxKind.VoidKeyword),dt(s.createKeywordTypeNode(F.SyntaxKind.VoidKeyword))]))}),s.createBlock([s.createExpressionStatement(j([s.createThis(),this.ids.sourceProp],P("addEventListener"),[this.ids.eventParameter,me([this.ids.msgParameter],s.createCallExpression(this.ids.handlerParameter,void 0,[j(s.createIdentifier(JSON[Symbol.toStringTag]),P("parse"),[s.createPropertyAccessExpression(s.createParenthesizedExpression(s.createAsExpression(this.ids.msgParameter,l(MessageEvent.name))),P("data"))])]))])),s.createReturnStatement(s.createThis())]),{typeParams:{E:s.createIndexedAccessTypeNode(l("R"),s.createLiteralTypeNode(s.createStringLiteral(P("event"))))}});makeSubscriptionClass=t=>Yt(t,[ho(this.ids.sourceProp,l("EventSource")),this.makeSubscriptionConstructor(),this.makeOnMethod()],{typeParams:{K:ut(this.requestType.name,s.createTemplateLiteralType(s.createTemplateHead("get "),[s.createTemplateLiteralTypeSpan(s.createKeywordTypeNode(F.SyntaxKind.StringKeyword),s.createTemplateTail(""))])),R:ut(s.createIndexedAccessTypeNode(l(this.interfaces.positive),l("K")),Vt(this.makeEventNarrow(s.createKeywordTypeNode(F.SyntaxKind.StringKeyword))))}});makeUsageStatements=(t,r)=>[v(this.ids.clientConst,Ae(s.createIdentifier(t))),j(this.ids.clientConst,this.ids.provideMethod,[s.createStringLiteral("get /v1/user/retrieve"),s.createObjectLiteralExpression([s.createPropertyAssignment("id",s.createStringLiteral("10"))])]),j(Ae(s.createIdentifier(r),s.createStringLiteral("get /v1/events/stream"),s.createObjectLiteralExpression()),this.ids.onMethod,[s.createStringLiteral("time"),me({time:void 0},s.createBlock([]))])]};import{chain as qs,prop as Bs}from"ramda";import h from"typescript";import{z as Xt}from"zod";var{factory:y}=h,$s={[h.SyntaxKind.AnyKeyword]:"",[h.SyntaxKind.BigIntKeyword]:BigInt(0),[h.SyntaxKind.BooleanKeyword]:!1,[h.SyntaxKind.NumberKeyword]:0,[h.SyntaxKind.ObjectKeyword]:{},[h.SyntaxKind.StringKeyword]:"",[h.SyntaxKind.UndefinedKeyword]:void 0},Vs=({value:e})=>y.createLiteralTypeNode(typeof e=="number"?y.createNumericLiteral(e):typeof e=="boolean"?e?y.createTrue():y.createFalse():y.createStringLiteral(e)),_s=({shape:e},{isResponse:t,next:r,optionalPropStyle:{withQuestionMark:o}})=>{let n=Object.entries(e).map(([i,a])=>{let c=t&&Ie(a)?a instanceof Xt.ZodOptional:a.isOptional(),d=de(i,r(a),{isOptional:c&&o});return a.description?at(d,a.description):d});return y.createTypeLiteralNode(n)},Gs=({element:e},{next:t})=>y.createArrayTypeNode(t(e)),Js=({options:e})=>y.createUnionTypeNode(e.map(t=>y.createLiteralTypeNode(y.createStringLiteral(t)))),bo=({options:e},{next:t})=>{let r=new Map;for(let o of e){let n=t(o);r.set(xo(n)?n.kind:n,n)}return y.createUnionTypeNode(Array.from(r.values()))},Ys=e=>$s?.[e.kind],Ws=(e,{next:t,isResponse:r})=>{let o=t(e.innerType());if(r&&e._def.effect.type==="transform"){let n=qe(e,Ys(o)),i={number:h.SyntaxKind.NumberKeyword,bigint:h.SyntaxKind.BigIntKeyword,boolean:h.SyntaxKind.BooleanKeyword,string:h.SyntaxKind.StringKeyword,undefined:h.SyntaxKind.UndefinedKeyword,object:h.SyntaxKind.ObjectKeyword};return y.createKeywordTypeNode(n&&i[n]||h.SyntaxKind.AnyKeyword)}return o},Qs=e=>y.createUnionTypeNode(Object.values(e.enum).map(t=>y.createLiteralTypeNode(typeof t=="number"?y.createNumericLiteral(t):y.createStringLiteral(t)))),Xs=(e,{next:t,optionalPropStyle:{withUndefined:r}})=>{let o=t(e.unwrap());return r?y.createUnionTypeNode([o,y.createKeywordTypeNode(h.SyntaxKind.UndefinedKeyword)]):o},ei=(e,{next:t})=>y.createUnionTypeNode([t(e.unwrap()),y.createLiteralTypeNode(y.createNull())]),ti=({items:e,_def:{rest:t}},{next:r})=>y.createTupleTypeNode(e.map(r).concat(t===null?[]:y.createRestTypeNode(r(t)))),ri=({keySchema:e,valueSchema:t},{next:r})=>y.createExpressionWithTypeArguments(y.createIdentifier("Record"),[e,t].map(r)),oi=({_def:{left:e,right:t}},{next:r})=>{let o=[e,t].map(r);return o.every(h.isTypeLiteralNode)?y.createTypeLiteralNode(qs(Bs("members"),o)):y.createIntersectionTypeNode(o)},ni=({_def:e},{next:t})=>t(e.innerType),Y=e=>()=>y.createKeywordTypeNode(e),si=(e,{next:t})=>t(e.unwrap()),ii=(e,{next:t})=>t(e.unwrap()),ai=({_def:e},{next:t})=>t(e.innerType),pi=({_def:e},{next:t,isResponse:r})=>t(e[r?"out":"in"]),ci=()=>y.createLiteralTypeNode(y.createNull()),di=(e,{makeAlias:t,next:r})=>t(e,()=>r(e.schema)),mi=e=>{let t=e.unwrap(),r=y.createKeywordTypeNode(h.SyntaxKind.StringKeyword),o=l("Buffer"),n=y.createUnionTypeNode([r,o]);return t instanceof Xt.ZodString?r:t instanceof Xt.ZodUnion?n:o},li=(e,{next:t})=>t(e.unwrap().shape.raw),ui={ZodString:Y(h.SyntaxKind.StringKeyword),ZodNumber:Y(h.SyntaxKind.NumberKeyword),ZodBigInt:Y(h.SyntaxKind.BigIntKeyword),ZodBoolean:Y(h.SyntaxKind.BooleanKeyword),ZodAny:Y(h.SyntaxKind.AnyKeyword),ZodUndefined:Y(h.SyntaxKind.UndefinedKeyword),[re]:Y(h.SyntaxKind.StringKeyword),[oe]:Y(h.SyntaxKind.StringKeyword),ZodNull:ci,ZodArray:Gs,ZodTuple:ti,ZodRecord:ri,ZodObject:_s,ZodLiteral:Vs,ZodIntersection:oi,ZodUnion:bo,ZodDefault:ni,ZodEnum:Js,ZodNativeEnum:Qs,ZodEffects:Ws,ZodOptional:Xs,ZodNullable:ei,ZodDiscriminatedUnion:bo,ZodBranded:si,ZodCatch:ai,ZodPipeline:pi,ZodLazy:di,ZodReadonly:ii,[M]:mi,[J]:li},er=(e,{brandHandling:t,ctx:r})=>ae(e,{rules:{...t,...ui},onMissing:()=>y.createKeywordTypeNode(h.SyntaxKind.AnyKeyword),ctx:r});var tr=class extends yt{program=[this.someOfType];usage=[];aliases=new Map;makeAlias(t,r){let o=this.aliases.get(t)?.name?.text;if(!o){o=`Type${this.aliases.size+1}`;let n=s.createLiteralTypeNode(s.createNull());this.aliases.set(t,D(o,n)),this.aliases.set(t,D(o,r()))}return l(o)}constructor({routing:t,brandHandling:r,variant:o="client",clientClassName:n="Client",subscriptionClassName:i="Subscription",serverUrl:a="https://example.com",optionalPropStyle:c={withQuestionMark:!0,withUndefined:!0},noContent:d=fi.undefined()}){super(a);let p={makeAlias:this.makeAlias.bind(this),optionalPropStyle:c},m={brandHandling:r,ctx:{...p,isResponse:!1}},g={brandHandling:r,ctx:{...p,isResponse:!0}};Pe({routing:t,onEndpoint:(f,R,T)=>{let Z=G.bind(null,T,R),C=`${T} ${R}`,S=D(Z("input"),er(f.getSchema("input"),m),{comment:C});this.program.push(S);let O=Te.reduce((E,L)=>{let I=f.getResponses(L),W=yi(([gt,{schema:B,mimeTypes:Q,statusCodes:ht}])=>{let Ke=D(Z(L,"variant",`${gt+1}`),er(Q?B:d,g),{comment:C});return this.program.push(Ke),ht.map(He=>de(He,Ke.name))},Array.from(I.entries())),z=mt(Z(L,"response","variants"),W,{comment:C});return this.program.push(z),Object.assign(E,{[L]:z})},{});this.paths.add(R);let k=s.createLiteralTypeNode(s.createStringLiteral(C));this.registry.set(C,{input:l(S.name),positive:this.someOf(O.positive),negative:this.someOf(O.negative),response:s.createUnionTypeNode([s.createIndexedAccessTypeNode(l(this.interfaces.positive),k),s.createIndexedAccessTypeNode(l(this.interfaces.negative),k)]),encoded:s.createIntersectionTypeNode([l(O.positive.name),l(O.negative.name)])}),this.tags.set(C,f.getTags())}}),this.program.unshift(...this.aliases.values()),this.program.push(this.makePathType(),this.methodType,...this.makePublicInterfaces(),this.requestType),o!=="types"&&(this.program.push(this.makeEndpointTags(),this.makeParseRequestFn(),this.makeSubstituteFn(),this.makeImplementationType(),this.makeDefaultImplementation(),this.makeClientClass(n),this.makeSubscriptionClass(i)),this.usage.push(...this.makeUsageStatements(n,i)))}printUsage(t){return this.usage.length?this.usage.map(r=>typeof r=="string"?r:Ft(r,t)).join(`
19
- `):void 0}print(t){let r=this.printUsage(t),o=r&&ft.addSyntheticLeadingComment(ft.addSyntheticLeadingComment(s.createEmptyStatement(),ft.SyntaxKind.SingleLineCommentTrivia," Usage example:"),ft.SyntaxKind.MultiLineCommentTrivia,`
20
- ${r}`);return this.program.concat(o||[]).map((n,i)=>Ft(n,i<this.program.length?t:{...t,omitTrailingSemicolon:!0})).join(`
18
+ `))};var Jr=e=>{e.startupLogo!==!1&&Yr(process.stdout);let t=e.errorHandler||je,r=Er(e.logger)?e.logger:new Le(e.logger);r.debug("Running",{build:"v22.4.1 (ESM)",env:process.env.NODE_ENV||"development"}),Vr(r);let o=Br({logger:r,config:e}),s={getLogger:$r(r),errorHandler:t},a=Dr(s),c=Kr(s);return{...s,logger:r,notFoundHandler:a,parserFailureHandler:c,loggingMiddleware:o}},En=(e,t)=>{let{logger:r,getLogger:o,notFoundHandler:n,loggingMiddleware:s}=Jr(e);return vt({app:e.app.use(s),routing:t,getLogger:o,config:e}),{notFoundHandler:n,logger:r}},zn=async(e,t)=>{let{logger:r,getLogger:o,notFoundHandler:n,parserFailureHandler:s,loggingMiddleware:a}=Jr(e),c=kt().disable("x-powered-by").use(a);if(e.compression){let x=await Ae("compression");c.use(x(typeof e.compression=="object"?e.compression:void 0))}let d={json:[e.jsonParser||kt.json()],raw:[e.rawParser||kt.raw(),qr],upload:e.upload?await Fr({config:e,getLogger:o}):[]};await e.beforeRouting?.({app:c,getLogger:o}),vt({app:c,routing:t,getLogger:o,config:e,parsers:d}),c.use(s,n);let p=[],m=(x,y)=>()=>x.listen(y,()=>r.info("Listening",y)),f=[];if(e.http){let x=An.createServer(c);p.push(x),f.push(m(x,e.http.listen))}if(e.https){let x=wn.createServer(e.https.options,c);p.push(x),f.push(m(x,e.https.listen))}return e.gracefulShutdown&&_r({logger:r,servers:p,options:e.gracefulShutdown===!0?{}:e.gracefulShutdown}),{app:c,logger:r,servers:f.map(x=>x())}};import{OpenApiBuilder as Ks}from"openapi3-ts/oas31";import{pluck as Ds}from"ramda";import{chain as In,isEmpty as vn,map as Qr,partition as kn,prop as Wr,reject as Zn,filter as Zt,concat as Ct}from"ramda";var Xr=e=>ne(e)&&"or"in e,eo=e=>ne(e)&&"and"in e,Nt=e=>!eo(e)&&!Xr(e),to=e=>{let t=Zt(Nt,e),r=In(Wr("and"),Zt(eo,e)),[o,n]=kn(Nt,r),s=Ct(t,o),a=Zt(Xr,e);return Qr(Wr("or"),Ct(a,n)).reduce((d,p)=>fe(d,Qr(m=>Nt(m)?[m]:m.and,p),([m,f])=>Ct(m,f)),Zn(vn,[s]))};import{isReferenceObject as Mt,isSchemaObject as it}from"openapi3-ts/oas31";import{concat as Nn,chain as jn,type as so,filter as io,fromPairs as at,has as Ln,isNil as Mn,map as He,mergeDeepRight as Un,mergeDeepWith as Hn,objOf as Kn,omit as pt,pipe as ao,pluck as Dn,reject as Fn,times as qn,toLower as Bn,union as $n,when as Vn,xprod as jt,zip as _n}from"ramda";import{z as w}from"zod";var de=(e,{onEach:t,rules:r,onMissing:o,ctx:n={}})=>{let s=r[e._def[h]?.brand]||r[e._def.typeName],c=s?s(e,{...n,next:p=>de(p,{ctx:n,onEach:t,rules:r,onMissing:o})}):o(e,n),d=t&&t(e,{prev:c,...n});return d?{...c,...d}:c};var ro=["a-im","accept","accept-additions","accept-ch","accept-charset","accept-datetime","accept-encoding","accept-features","accept-language","accept-patch","accept-post","accept-ranges","accept-signature","access-control","access-control-allow-credentials","access-control-allow-headers","access-control-allow-methods","access-control-allow-origin","access-control-expose-headers","access-control-max-age","access-control-request-headers","access-control-request-method","age","allow","alpn","alt-svc","alt-used","alternates","amp-cache-transform","apply-to-redirect-ref","authentication-control","authentication-info","authorization","available-dictionary","c-ext","c-man","c-opt","c-pep","c-pep-info","cache-control","cache-status","cal-managed-id","caldav-timezones","capsule-protocol","cdn-cache-control","cdn-loop","cert-not-after","cert-not-before","clear-site-data","client-cert","client-cert-chain","close","cmcd-object","cmcd-request","cmcd-session","cmcd-status","cmsd-dynamic","cmsd-static","concealed-auth-export","configuration-context","connection","content-base","content-digest","content-disposition","content-encoding","content-id","content-language","content-length","content-location","content-md5","content-range","content-script-type","content-security-policy","content-security-policy-report-only","content-style-type","content-type","content-version","cookie","cookie2","cross-origin-embedder-policy","cross-origin-embedder-policy-report-only","cross-origin-opener-policy","cross-origin-opener-policy-report-only","cross-origin-resource-policy","cta-common-access-token","dasl","date","dav","default-style","delta-base","deprecation","depth","derived-from","destination","differential-id","dictionary-id","digest","dpop","dpop-nonce","early-data","ediint-features","etag","expect","expect-ct","expires","ext","forwarded","from","getprofile","hobareg","host","http2-settings","if","if-match","if-modified-since","if-none-match","if-range","if-schedule-tag-match","if-unmodified-since","im","include-referred-token-binding-id","isolation","keep-alive","label","last-event-id","last-modified","link","link-template","location","lock-token","man","max-forwards","memento-datetime","meter","method-check","method-check-expires","mime-version","negotiate","nel","odata-entityid","odata-isolation","odata-maxversion","odata-version","opt","optional-www-authenticate","ordering-type","origin","origin-agent-cluster","oscore","oslc-core-version","overwrite","p3p","pep","pep-info","permissions-policy","pics-label","ping-from","ping-to","position","pragma","prefer","preference-applied","priority","profileobject","protocol","protocol-info","protocol-query","protocol-request","proxy-authenticate","proxy-authentication-info","proxy-authorization","proxy-features","proxy-instruction","proxy-status","public","public-key-pins","public-key-pins-report-only","range","redirect-ref","referer","referer-root","referrer-policy","refresh","repeatability-client-id","repeatability-first-sent","repeatability-request-id","repeatability-result","replay-nonce","reporting-endpoints","repr-digest","retry-after","safe","schedule-reply","schedule-tag","sec-gpc","sec-purpose","sec-token-binding","sec-websocket-accept","sec-websocket-extensions","sec-websocket-key","sec-websocket-protocol","sec-websocket-version","security-scheme","server","server-timing","set-cookie","set-cookie2","setprofile","signature","signature-input","slug","soapaction","status-uri","strict-transport-security","sunset","surrogate-capability","surrogate-control","tcn","te","timeout","timing-allow-origin","topic","traceparent","tracestate","trailer","transfer-encoding","ttl","upgrade","urgency","uri","use-as-dictionary","user-agent","variant-vary","vary","via","want-content-digest","want-digest","want-repr-digest","warning","www-authenticate","x-content-type-options","x-frame-options"];var oo=50,po="https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Date/toISOString",Gn={integer:0,number:0,string:"",boolean:!1,object:{},null:null,array:[]},co=/:([A-Za-z0-9_]+)/g,Yn=/^\d{4}-\d{2}-\d{2}$/,Jn=/^\d{2}:\d{2}:\d{2}(\.\d+)?$/,Qn=e=>e?/^\d{4}-\d{2}-\d{2}T\d{2}:\d{2}:\d{2}(\.\d+)?(([+-]\d{2}:\d{2})|Z)$/:/^\d{4}-\d{2}-\d{2}T\d{2}:\d{2}:\d{2}(\.\d+)?Z$/,Wn=e=>e.match(co)?.map(t=>t.slice(1))||[],mo=e=>e.replace(co,t=>`{${t.slice(1)}}`),Xn=({_def:e},{next:t})=>({...t(e.innerType),default:e[h]?.defaultLabel||e.defaultValue()}),es=({_def:{innerType:e}},{next:t})=>t(e),ts=()=>({format:"any"}),rs=({},e)=>{if(e.isResponse)throw new H("Please use ez.upload() only for input.",e);return{type:"string",format:"binary"}},os=e=>{let t=e.unwrap();return{type:"string",format:t instanceof w.ZodString?t._def.checks.find(r=>r.kind==="base64")?"byte":"file":"binary"}},ns=({options:e},{next:t})=>({oneOf:e.map(t)}),ss=({options:e,discriminator:t},{next:r})=>({discriminator:{propertyName:t},oneOf:e.map(r)}),is=(e,t)=>{if(Array.isArray(e)&&Array.isArray(t))return Nn(e,t);if(e===t)return t;throw new Error("Can not flatten properties")},as=e=>{let[t,r]=e.filter(it).filter(n=>n.type==="object"&&Object.keys(n).every(s=>["type","properties","required","examples"].includes(s)));if(!t||!r)throw new Error("Can not flatten objects");let o={type:"object"};return(t.properties||r.properties)&&(o.properties=Hn(is,t.properties||{},r.properties||{})),(t.required||r.required)&&(o.required=$n(t.required||[],r.required||[])),(t.examples||r.examples)&&(o.examples=fe(t.examples||[],r.examples||[],([n,s])=>Un(n,s))),o},ps=({_def:{left:e,right:t}},{next:r})=>{let o=[e,t].map(r);try{return as(o)}catch{}return{allOf:o}},cs=(e,{next:t})=>t(e.unwrap()),ds=(e,{next:t})=>t(e.unwrap()),ms=(e,{next:t})=>{let r=t(e.unwrap());return it(r)&&(r.type=uo(r)),r},lo=e=>{let t=Bn(so(e));return typeof e=="bigint"?"integer":t==="number"||t==="string"||t==="boolean"||t==="object"||t==="null"||t==="array"?t:void 0},no=e=>({type:lo(Object.values(e.enum)[0]),enum:Object.values(e.enum)}),ls=({value:e})=>({type:lo(e),const:e}),us=(e,{isResponse:t,next:r})=>{let o=Object.keys(e.shape),n=c=>t&&ke(c)?c instanceof w.ZodOptional:c.isOptional(),s=o.filter(c=>!n(e.shape[c])),a={type:"object"};return o.length&&(a.properties=st(e,r)),s.length&&(a.required=s),a},ys=()=>({type:"null"}),fs=({},e)=>{if(e.isResponse)throw new H("Please use ez.dateOut() for output.",e);return{description:"YYYY-MM-DDTHH:mm:ss.sssZ",type:"string",format:"date-time",pattern:/^\d{4}-\d{2}-\d{2}(T\d{2}:\d{2}:\d{2}(\.\d+)?)?Z?$/.source,externalDocs:{url:po}}},gs=({},e)=>{if(!e.isResponse)throw new H("Please use ez.dateIn() for input.",e);return{description:"YYYY-MM-DDTHH:mm:ss.sssZ",type:"string",format:"date-time",externalDocs:{url:po}}},hs=({},e)=>{throw new H(`Using z.date() within ${e.isResponse?"output":"input"} schema is forbidden. Please use ez.date${e.isResponse?"Out":"In"}() instead. Check out the documentation for details.`,e)},xs=()=>({type:"boolean"}),bs=()=>({type:"integer",format:"bigint"}),Ss=e=>e.every(t=>t instanceof w.ZodLiteral),Ts=({keySchema:e,valueSchema:t},{next:r})=>{if(e instanceof w.ZodEnum||e instanceof w.ZodNativeEnum){let o=Object.values(e.enum),n={type:"object"};return o.length&&(n.properties=st(w.object(at(jt(o,[t]))),r),n.required=o),n}if(e instanceof w.ZodLiteral)return{type:"object",properties:st(w.object({[e.value]:t}),r),required:[e.value]};if(e instanceof w.ZodUnion&&Ss(e.options)){let o=He(s=>`${s.value}`,e.options),n=at(jt(o,[t]));return{type:"object",properties:st(w.object(n),r),required:o}}return{type:"object",additionalProperties:r(t)}},Os=({_def:{minLength:e,maxLength:t},element:r},{next:o})=>{let n={type:"array",items:o(r)};return e&&(n.minItems=e.value),t&&(n.maxItems=t.value),n},Rs=({items:e,_def:{rest:t}},{next:r})=>({type:"array",prefixItems:e.map(r),items:t===null?{not:{}}:r(t)}),Ps=({isEmail:e,isURL:t,minLength:r,maxLength:o,isUUID:n,isCUID:s,isCUID2:a,isULID:c,isIP:d,isEmoji:p,isDatetime:m,isCIDR:f,isDate:x,isTime:y,isBase64:O,isNANOID:S,isBase64url:Z,isDuration:C,_def:{checks:b}})=>{let T=b.find(v=>v.kind==="regex"),N=b.find(v=>v.kind==="datetime"),z=b.some(v=>v.kind==="jwt"),L=b.find(v=>v.kind==="length"),I={type:"string"},ee={"date-time":m,byte:O,base64url:Z,date:x,time:y,duration:C,email:e,url:t,uuid:n,cuid:s,cuid2:a,ulid:c,nanoid:S,jwt:z,ip:d,cidr:f,emoji:p};for(let v in ee)if(ee[v]){I.format=v;break}return L&&([I.minLength,I.maxLength]=[L.value,L.value]),r!==null&&(I.minLength=r),o!==null&&(I.maxLength=o),x&&(I.pattern=Yn.source),y&&(I.pattern=Jn.source),m&&(I.pattern=Qn(N?.offset).source),T&&(I.pattern=T.regex.source),I},As=({isInt:e,maxValue:t,minValue:r,_def:{checks:o}})=>{let n=o.find(f=>f.kind==="min"),s=r===null?e?Number.MIN_SAFE_INTEGER:-Number.MAX_VALUE:r,a=n?n.inclusive:!0,c=o.find(f=>f.kind==="max"),d=t===null?e?Number.MAX_SAFE_INTEGER:Number.MAX_VALUE:t,p=c?c.inclusive:!0,m={type:e?"integer":"number",format:e?"int64":"double"};return a?m.minimum=s:m.exclusiveMinimum=s,p?m.maximum=d:m.exclusiveMaximum=d,m},st=({shape:e},t)=>He(t,e),ws=e=>{let t=Array.isArray(e.type)?e.type[0]:e.type;return Gn?.[t]},uo=({type:e})=>e==="null"?e:typeof e=="string"?[e,"null"]:e?[...new Set(e).add("null")]:"null",Es=(e,{isResponse:t,next:r})=>{let o=r(e.innerType()),{effect:n}=e._def;if(t&&n.type==="transform"&&it(o)){let s=Ve(e,ws(o));return s&&["number","string","boolean"].includes(s)?{type:s}:r(w.any())}if(!t&&n.type==="preprocess"&&it(o)){let{type:s,...a}=o;return{...a,format:`${a.format||s} (preprocessed)`}}return o},zs=({_def:e},{isResponse:t,next:r})=>r(e[t?"out":"in"]),Is=(e,{next:t})=>t(e.unwrap()),vs=(e,{next:t,makeRef:r})=>r(e,()=>t(e.schema)),ks=(e,{next:t})=>t(e.unwrap().shape.raw),yo=e=>e.length?at(_n(qn(t=>`example${t+1}`,e.length),He(Kn("value"),e))):void 0,fo=(e,t,r=[])=>ao(J,He(Vn(o=>so(o)==="Object",pt(r))),yo)({schema:e,variant:t?"parsed":"original",validate:!0}),Zs=(e,t)=>ao(J,io(Ln(t)),Dn(t),yo)({schema:e,variant:"original",validate:!0}),me=e=>e instanceof w.ZodObject?e:e instanceof w.ZodBranded?me(e.unwrap()):e instanceof w.ZodUnion||e instanceof w.ZodDiscriminatedUnion?e.options.map(t=>me(t)).reduce((t,r)=>t.merge(r.partial()),w.object({})):e instanceof w.ZodEffects?me(e._def.schema):e instanceof w.ZodPipeline?me(e._def.in):me(e._def.left).merge(me(e._def.right)),Cs=(e,t)=>t?.includes(e)||e.startsWith("x-")||ro.includes(e),go=({path:e,method:t,schema:r,inputSources:o,makeRef:n,composition:s,brandHandling:a,isHeader:c,security:d,description:p=`${t.toUpperCase()} ${e} Parameter`})=>{let{shape:m}=me(r),f=Wn(e),x=o.includes("query"),y=o.includes("params"),O=o.includes("headers"),S=b=>y&&f.includes(b),Z=jn(io(b=>b.type==="header"),d??[]).map(({name:b})=>b),C=b=>O&&(c?.(b,t,e)??Cs(b,Z));return Object.keys(m).reduce((b,T)=>{let N=S(T)?"path":C(T)?"header":x?"query":void 0;if(!N)return b;let z=de(m[T],{rules:{...a,...Ut},onEach:Ht,onMissing:Kt,ctx:{isResponse:!1,makeRef:n,path:e,method:t}}),L=s==="components"?n(m[T],z,Q(p,T)):z;return b.concat({name:T,in:N,required:!m[T].isOptional(),description:z.description||p,schema:L,examples:Zs(r,T)})},[])},Ut={ZodString:Ps,ZodNumber:As,ZodBigInt:bs,ZodBoolean:xs,ZodNull:ys,ZodArray:Os,ZodTuple:Rs,ZodRecord:Ts,ZodObject:us,ZodLiteral:ls,ZodIntersection:ps,ZodUnion:ns,ZodAny:ts,ZodDefault:Xn,ZodEnum:no,ZodNativeEnum:no,ZodEffects:Es,ZodOptional:cs,ZodNullable:ms,ZodDiscriminatedUnion:ss,ZodBranded:Is,ZodDate:hs,ZodCatch:es,ZodPipeline:zs,ZodLazy:vs,ZodReadonly:ds,[D]:os,[xe]:rs,[ie]:gs,[se]:fs,[W]:ks},Ht=(e,{isResponse:t,prev:r})=>{if(Mt(r))return{};let{description:o}=e,n=e instanceof w.ZodLazy,s=r.type!==void 0,a=t&&ke(e),c=!n&&s&&!a&&e.isNullable(),d={};if(o&&(d.description=o),c&&(d.type=uo(r)),!n){let p=J({schema:e,variant:t?"parsed":"original",validate:!0});p.length&&(d.examples=p.slice())}return d},Kt=(e,t)=>{throw new H(`Zod type ${e.constructor.name} is unsupported.`,t)},Lt=(e,t)=>{if(Mt(e))return e;let r={...e};return r.properties&&(r.properties=pt(t,r.properties)),r.examples&&(r.examples=r.examples.map(o=>pt(t,o))),r.required&&(r.required=r.required.filter(o=>!t.includes(o))),r.allOf&&(r.allOf=r.allOf.map(o=>Lt(o,t))),r.oneOf&&(r.oneOf=r.oneOf.map(o=>Lt(o,t))),r},ho=e=>Mt(e)?e:pt(["examples"],e),xo=({method:e,path:t,schema:r,mimeTypes:o,variant:n,makeRef:s,composition:a,hasMultipleStatusCodes:c,statusCode:d,brandHandling:p,description:m=`${e.toUpperCase()} ${t} ${Ot(n)} response ${c?d:""}`.trim()})=>{if(!o)return{description:m};let f=ho(de(r,{rules:{...p,...Ut},onEach:Ht,onMissing:Kt,ctx:{isResponse:!0,makeRef:s,path:t,method:e}})),x={schema:a==="components"?s(r,f,Q(m)):f,examples:fo(r,!0)};return{description:m,content:at(jt(o,[x]))}},Ns=({format:e})=>{let t={type:"http",scheme:"bearer"};return e&&(t.bearerFormat=e),t},js=({name:e},t)=>{let r={type:"apiKey",in:"query",name:e};return t?.includes("body")&&(t?.includes("query")?(r["x-in-alternative"]="body",r.description=`${e} CAN also be supplied within the request body`):(r["x-in-actual"]="body",r.description=`${e} MUST be supplied within the request body instead of query`)),r},Ls=({name:e})=>({type:"apiKey",in:"header",name:e}),Ms=({name:e})=>({type:"apiKey",in:"cookie",name:e}),Us=({url:e})=>({type:"openIdConnect",openIdConnectUrl:e}),Hs=({flows:e={}})=>({type:"oauth2",flows:He(t=>({...t,scopes:t.scopes||{}}),Fn(Mn,e))}),bo=(e,t=[])=>{let r=o=>o.type==="basic"?{type:"http",scheme:"basic"}:o.type==="bearer"?Ns(o):o.type==="input"?js(o,t):o.type==="header"?Ls(o):o.type==="cookie"?Ms(o):o.type==="openid"?Us(o):Hs(o);return e.map(o=>o.map(r))},So=(e,t,r)=>e.map(o=>o.reduce((n,s)=>{let a=r(s),c=["oauth2","openIdConnect"].includes(s.type);return Object.assign(n,{[a]:c?t:[]})},{})),To=({method:e,path:t,schema:r,mimeType:o,makeRef:n,composition:s,brandHandling:a,paramNames:c,description:d=`${e.toUpperCase()} ${t} Request body`})=>{let p=ho(Lt(de(r,{rules:{...a,...Ut},onEach:Ht,onMissing:Kt,ctx:{isResponse:!1,makeRef:n,path:t,method:e}}),c)),m={schema:s==="components"?n(r,p,Q(d)):p,examples:fo(r,!1,c)};return{description:d,content:{[o]:m}}},Oo=e=>Object.entries(e).reduce((t,[r,o])=>{if(!o)return t;let n={name:r,description:typeof o=="string"?o:o.description};return typeof o=="object"&&o.url&&(n.externalDocs={url:o.url}),t.concat(n)},[]),Dt=e=>e.length<=oo?e:e.slice(0,oo-1)+"\u2026";var Ft=class extends Ks{lastSecuritySchemaIds=new Map;lastOperationIdSuffixes=new Map;references=new Map;makeRef(t,r,o=this.references.get(t)){return o||(o=`Schema${this.references.size+1}`,this.references.set(t,o),typeof r=="function"&&(r=r())),typeof r=="object"&&this.addSchema(o,r),{$ref:`#/components/schemas/${o}`}}ensureUniqOperationId(t,r,o){let n=o||Q(r,t),s=this.lastOperationIdSuffixes.get(n);if(s===void 0)return this.lastOperationIdSuffixes.set(n,1),n;if(o)throw new H(`Duplicated operationId: "${o}"`,{method:r,isResponse:!1,path:t});return s++,this.lastOperationIdSuffixes.set(n,s),`${n}${s}`}ensureUniqSecuritySchemaName(t){let r=JSON.stringify(t);for(let n in this.rootDoc.components?.securitySchemes||{})if(r===JSON.stringify(this.rootDoc.components?.securitySchemes?.[n]))return n;let o=(this.lastSecuritySchemaIds.get(t.type)||0)+1;return this.lastSecuritySchemaIds.set(t.type,o),`${t.type.toUpperCase()}_${o}`}constructor({routing:t,config:r,title:o,version:n,serverUrl:s,descriptions:a,brandHandling:c,tags:d,isHeader:p,hasSummaryFromDescription:m=!0,composition:f="inline"}){super(),this.addInfo({title:o,version:n});for(let y of typeof s=="string"?[s]:s)this.addServer({url:y});we({routing:t,onEndpoint:(y,O,S)=>{let Z={path:O,method:S,endpoint:y,composition:f,brandHandling:c,makeRef:this.makeRef.bind(this)},[C,b]=["short","long"].map(y.getDescription.bind(y)),T=C?Dt(C):m&&b?Dt(b):void 0,N=r.inputSources?.[S]||St[S],z=this.ensureUniqOperationId(O,S,y.getOperationId(S)),L=to(y.getSecurity()),I=go({...Z,inputSources:N,isHeader:p,security:L,schema:y.getSchema("input"),description:a?.requestParameter?.call(null,{method:S,path:O,operationId:z})}),ee={};for(let _ of Re){let te=y.getResponses(_);for(let{mimeTypes:xt,schema:Fe,statusCodes:qe}of te)for(let bt of qe)ee[bt]=xo({...Z,variant:_,schema:Fe,mimeTypes:xt,statusCode:bt,hasMultipleStatusCodes:te.length>1||qe.length>1,description:a?.[`${_}Response`]?.call(null,{method:S,path:O,operationId:z,statusCode:bt})})}let v=N.includes("body")?To({...Z,paramNames:Ds("name",I),schema:y.getSchema("input"),mimeType:E[y.getRequestType()],description:a?.requestBody?.call(null,{method:S,path:O,operationId:z})}):void 0,ht=So(bo(L,N),y.getScopes(),_=>{let te=this.ensureUniqSecuritySchemaName(_);return this.addSecurityScheme(te,_),te});this.addPath(mo(O),{[S]:{operationId:z,summary:T,description:b,tags:_e(y.getTags()),parameters:_e(I),requestBody:v,security:_e(ht),responses:ee}})}}),d&&(this.rootDoc.tags=Oo(d))}};import{createRequest as Fs,createResponse as qs}from"node-mocks-http";var Bs=e=>Fs({...e,headers:{"content-type":E.json,...e?.headers}}),$s=e=>qs(e),Vs=e=>{let t={warn:[],error:[],info:[],debug:[]};return new Proxy(e||{},{get(r,o,n){return o==="_getLogs"?()=>t:zr(o)?(...s)=>t[o].push(s):Reflect.get(r,o,n)}})},Ro=({requestProps:e,responseOptions:t,configProps:r,loggerProps:o})=>{let n=Bs(e),s=$s({req:n,...t});s.req=t?.req||n,n.res=s;let a=Vs(o),c={cors:!1,logger:a,...r};return{requestMock:n,responseMock:s,loggerMock:a,configMock:c}},_s=async({endpoint:e,...t})=>{let{requestMock:r,responseMock:o,loggerMock:n,configMock:s}=Ro(t);return await e.execute({request:r,response:o,config:s,logger:n}),{requestMock:r,responseMock:o,loggerMock:n}},Gs=async({middleware:e,options:t={},errorHandler:r,...o})=>{let{requestMock:n,responseMock:s,loggerMock:a,configMock:c}=Ro(o),d=$e(n,c.inputSources);try{let p=await e.execute({request:n,response:s,logger:a,input:d,options:t});return{requestMock:n,responseMock:s,loggerMock:a,output:p}}catch(p){if(!r)throw p;return r(Y(p),s),{requestMock:n,responseMock:s,loggerMock:a,output:{}}}};import{chain as Ei}from"ramda";import gt from"typescript";import{z as zi}from"zod";import{map as Xs}from"ramda";import $ from"typescript";var Po=["get","post","put","delete","patch"];import{map as qt,pair as Ys}from"ramda";import l from"typescript";var i=l.factory,ct=[i.createModifier(l.SyntaxKind.ExportKeyword)],Js=[i.createModifier(l.SyntaxKind.AsyncKeyword)],Ke={public:[i.createModifier(l.SyntaxKind.PublicKeyword)],protectedReadonly:[i.createModifier(l.SyntaxKind.ProtectedKeyword),i.createModifier(l.SyntaxKind.ReadonlyKeyword)]},Bt=(e,t)=>l.addSyntheticLeadingComment(e,l.SyntaxKind.MultiLineCommentTrivia,`* ${t} `,!0),$t=(e,t)=>{let r=l.createSourceFile("print.ts","",l.ScriptTarget.Latest,!1,l.ScriptKind.TS);return l.createPrinter(t).printNode(l.EmitHint.Unspecified,e,r)},Qs=/^[A-Za-z_$][A-Za-z0-9_$]*$/,Vt=e=>typeof e=="string"&&Qs.test(e)?i.createIdentifier(e):A(e),dt=(e,...t)=>i.createTemplateExpression(i.createTemplateHead(e),t.map(([r,o=""],n)=>i.createTemplateSpan(r,n===t.length-1?i.createTemplateTail(o):i.createTemplateMiddle(o)))),mt=(e,{type:t,mod:r,init:o,optional:n}={})=>i.createParameterDeclaration(r,void 0,e,n?i.createToken(l.SyntaxKind.QuestionToken):void 0,t?u(t):void 0,o),Ee=e=>Object.entries(e).map(([t,r])=>mt(t,typeof r=="string"||typeof r=="number"||typeof r=="object"&&"kind"in r?{type:r}:r)),_t=(e,t=[])=>i.createConstructorDeclaration(Ke.public,e,i.createBlock(t)),u=(e,t)=>typeof e=="number"?i.createKeywordTypeNode(e):typeof e=="string"||l.isIdentifier(e)?i.createTypeReferenceNode(e,t&&qt(u,t)):e,Gt=u("Record",[l.SyntaxKind.StringKeyword,l.SyntaxKind.AnyKeyword]),le=(e,t,{isOptional:r,comment:o}={})=>{let n=i.createPropertySignature(void 0,Vt(e),r?i.createToken(l.SyntaxKind.QuestionToken):void 0,u(t));return o?Bt(n,o):n},Yt=e=>l.setEmitFlags(e,l.EmitFlags.SingleLine),Jt=(...e)=>i.createArrayBindingPattern(e.map(t=>i.createBindingElement(void 0,void 0,t))),k=(e,t,{type:r,expose:o}={})=>i.createVariableStatement(o&&ct,i.createVariableDeclarationList([i.createVariableDeclaration(e,void 0,r?u(r):void 0,t)],l.NodeFlags.Const)),Qt=(e,t)=>B(e,i.createUnionTypeNode(qt(M,t)),{expose:!0}),B=(e,t,{expose:r,comment:o,params:n}={})=>{let s=i.createTypeAliasDeclaration(r?ct:void 0,e,n&&tr(n),t);return o?Bt(s,o):s},Ao=(e,t)=>i.createPropertyDeclaration(Ke.public,e,void 0,u(t),void 0),Wt=(e,t,r,{typeParams:o,returns:n}={})=>i.createMethodDeclaration(Ke.public,void 0,e,void 0,o&&tr(o),t,n,i.createBlock(r)),Xt=(e,t,{typeParams:r}={})=>i.createClassDeclaration(ct,e,r&&tr(r),void 0,t),er=e=>i.createTypeOperatorNode(l.SyntaxKind.KeyOfKeyword,u(e)),lt=e=>u(Promise.name,[e]),ut=(e,t,{expose:r,comment:o}={})=>{let n=i.createInterfaceDeclaration(r?ct:void 0,e,void 0,void 0,t);return o?Bt(n,o):n},tr=e=>(Array.isArray(e)?e.map(t=>Ys(t,void 0)):Object.entries(e)).map(([t,r])=>{let{type:o,init:n}=typeof r=="object"&&"init"in r?r:{type:r};return i.createTypeParameterDeclaration([],t,o?u(o):void 0,n?u(n):void 0)}),ue=(e,t,{isAsync:r}={})=>i.createArrowFunction(r?Js:void 0,void 0,Array.isArray(e)?qt(mt,e):Ee(e),void 0,void 0,t),R=e=>e,De=(e,t,r)=>i.createConditionalExpression(e,i.createToken(l.SyntaxKind.QuestionToken),t,i.createToken(l.SyntaxKind.ColonToken),r),P=(e,...t)=>(...r)=>i.createCallExpression(t.reduce((o,n)=>typeof n=="string"||l.isIdentifier(n)?i.createPropertyAccessExpression(o,n):i.createElementAccessExpression(o,n),typeof e=="string"?i.createIdentifier(e):e),void 0,r),ze=(e,...t)=>i.createNewExpression(i.createIdentifier(e),void 0,t),yt=(e,t)=>u("Extract",[e,t]),rr=(e,t)=>i.createExpressionStatement(i.createBinaryExpression(e,i.createToken(l.SyntaxKind.EqualsToken),t)),K=(e,t)=>i.createIndexedAccessTypeNode(u(e),u(t)),wo=e=>i.createUnionTypeNode([u(e),lt(e)]),or=(e,t)=>i.createFunctionTypeNode(void 0,Ee(e),u(t)),A=e=>typeof e=="number"?i.createNumericLiteral(e):typeof e=="boolean"?e?i.createTrue():i.createFalse():e===null?i.createNull():i.createStringLiteral(e),M=e=>i.createLiteralTypeNode(A(e)),Ws=[l.SyntaxKind.AnyKeyword,l.SyntaxKind.BigIntKeyword,l.SyntaxKind.BooleanKeyword,l.SyntaxKind.NeverKeyword,l.SyntaxKind.NumberKeyword,l.SyntaxKind.ObjectKeyword,l.SyntaxKind.StringKeyword,l.SyntaxKind.SymbolKeyword,l.SyntaxKind.UndefinedKeyword,l.SyntaxKind.UnknownKeyword,l.SyntaxKind.VoidKeyword],Eo=e=>Ws.includes(e.kind);var ft=class{constructor(t){this.serverUrl=t}paths=new Set;tags=new Map;registry=new Map;ids={pathType:i.createIdentifier("Path"),implementationType:i.createIdentifier("Implementation"),keyParameter:i.createIdentifier("key"),pathParameter:i.createIdentifier("path"),paramsArgument:i.createIdentifier("params"),ctxArgument:i.createIdentifier("ctx"),methodParameter:i.createIdentifier("method"),requestParameter:i.createIdentifier("request"),eventParameter:i.createIdentifier("event"),dataParameter:i.createIdentifier("data"),handlerParameter:i.createIdentifier("handler"),msgParameter:i.createIdentifier("msg"),parseRequestFn:i.createIdentifier("parseRequest"),substituteFn:i.createIdentifier("substitute"),provideMethod:i.createIdentifier("provide"),onMethod:i.createIdentifier("on"),implementationArgument:i.createIdentifier("implementation"),hasBodyConst:i.createIdentifier("hasBody"),undefinedValue:i.createIdentifier("undefined"),responseConst:i.createIdentifier("response"),restConst:i.createIdentifier("rest"),searchParamsConst:i.createIdentifier("searchParams"),defaultImplementationConst:i.createIdentifier("defaultImplementation"),clientConst:i.createIdentifier("client"),contentTypeConst:i.createIdentifier("contentType"),isJsonConst:i.createIdentifier("isJSON"),sourceProp:i.createIdentifier("source")};interfaces={input:i.createIdentifier("Input"),positive:i.createIdentifier("PositiveResponse"),negative:i.createIdentifier("NegativeResponse"),encoded:i.createIdentifier("EncodedResponse"),response:i.createIdentifier("Response")};methodType=Qt("Method",Po);someOfType=B("SomeOf",K("T",er("T")),{params:["T"]});requestType=B("Request",er(this.interfaces.input),{expose:!0});someOf=({name:t})=>u(this.someOfType.name,[t]);makePathType=()=>Qt(this.ids.pathType,Array.from(this.paths));makePublicInterfaces=()=>Object.keys(this.interfaces).map(t=>ut(this.interfaces[t],Array.from(this.registry).map(([r,o])=>le(r,o[t])),{expose:!0}));makeEndpointTags=()=>k("endpointTags",i.createObjectLiteralExpression(Array.from(this.tags).map(([t,r])=>i.createPropertyAssignment(Vt(t),i.createArrayLiteralExpression(Xs(A,r))))),{expose:!0});makeImplementationType=()=>B(this.ids.implementationType,or({[this.ids.methodParameter.text]:this.methodType.name,[this.ids.pathParameter.text]:$.SyntaxKind.StringKeyword,[this.ids.paramsArgument.text]:Gt,[this.ids.ctxArgument.text]:{optional:!0,type:"T"}},lt($.SyntaxKind.AnyKeyword)),{expose:!0,params:{T:{init:$.SyntaxKind.UnknownKeyword}}});makeParseRequestFn=()=>k(this.ids.parseRequestFn,ue({[this.ids.requestParameter.text]:$.SyntaxKind.StringKeyword},i.createAsExpression(P(this.ids.requestParameter,R("split"))(i.createRegularExpressionLiteral("/ (.+)/"),A(2)),i.createTupleTypeNode([u(this.methodType.name),u(this.ids.pathType)]))));makeSubstituteFn=()=>k(this.ids.substituteFn,ue({[this.ids.pathParameter.text]:$.SyntaxKind.StringKeyword,[this.ids.paramsArgument.text]:Gt},i.createBlock([k(this.ids.restConst,i.createObjectLiteralExpression([i.createSpreadAssignment(this.ids.paramsArgument)])),i.createForInStatement(i.createVariableDeclarationList([i.createVariableDeclaration(this.ids.keyParameter)],$.NodeFlags.Const),this.ids.paramsArgument,i.createBlock([rr(this.ids.pathParameter,P(this.ids.pathParameter,R("replace"))(dt(":",[this.ids.keyParameter]),ue([],i.createBlock([i.createExpressionStatement(i.createDeleteExpression(i.createElementAccessExpression(this.ids.restConst,this.ids.keyParameter))),i.createReturnStatement(i.createElementAccessExpression(this.ids.paramsArgument,this.ids.keyParameter))]))))])),i.createReturnStatement(i.createAsExpression(i.createArrayLiteralExpression([this.ids.pathParameter,this.ids.restConst]),u("const")))])));makeProvider=()=>Wt(this.ids.provideMethod,Ee({[this.ids.requestParameter.text]:"K",[this.ids.paramsArgument.text]:K(this.interfaces.input,"K"),[this.ids.ctxArgument.text]:{optional:!0,type:"T"}}),[k(Jt(this.ids.methodParameter,this.ids.pathParameter),P(this.ids.parseRequestFn)(this.ids.requestParameter)),i.createReturnStatement(P(i.createThis(),this.ids.implementationArgument)(this.ids.methodParameter,i.createSpreadElement(P(this.ids.substituteFn)(this.ids.pathParameter,this.ids.paramsArgument)),this.ids.ctxArgument))],{typeParams:{K:this.requestType.name},returns:lt(K(this.interfaces.response,"K"))});makeClientClass=t=>Xt(t,[_t([mt(this.ids.implementationArgument,{type:u(this.ids.implementationType,["T"]),mod:Ke.protectedReadonly,init:this.ids.defaultImplementationConst})]),this.makeProvider()],{typeParams:["T"]});makeSearchParams=t=>dt("?",[ze(URLSearchParams.name,t)]);makeFetchURL=()=>ze(URL.name,dt("",[this.ids.pathParameter],[this.ids.searchParamsConst]),A(this.serverUrl));makeDefaultImplementation=()=>{let t=i.createPropertyAssignment(R("method"),P(this.ids.methodParameter,R("toUpperCase"))()),r=i.createPropertyAssignment(R("headers"),De(this.ids.hasBodyConst,i.createObjectLiteralExpression([i.createPropertyAssignment(A("Content-Type"),A(E.json))]),this.ids.undefinedValue)),o=i.createPropertyAssignment(R("body"),De(this.ids.hasBodyConst,P(JSON[Symbol.toStringTag],R("stringify"))(this.ids.paramsArgument),this.ids.undefinedValue)),n=k(this.ids.responseConst,i.createAwaitExpression(P(fetch.name)(this.makeFetchURL(),i.createObjectLiteralExpression([t,r,o])))),s=k(this.ids.hasBodyConst,i.createLogicalNot(P(i.createArrayLiteralExpression([A("get"),A("delete")]),R("includes"))(this.ids.methodParameter))),a=k(this.ids.searchParamsConst,De(this.ids.hasBodyConst,A(""),this.makeSearchParams(this.ids.paramsArgument))),c=k(this.ids.contentTypeConst,P(this.ids.responseConst,R("headers"),R("get"))(A("content-type"))),d=i.createIfStatement(i.createPrefixUnaryExpression($.SyntaxKind.ExclamationToken,this.ids.contentTypeConst),i.createReturnStatement()),p=k(this.ids.isJsonConst,P(this.ids.contentTypeConst,R("startsWith"))(A(E.json))),m=i.createReturnStatement(P(this.ids.responseConst,De(this.ids.isJsonConst,A(R("json")),A(R("text"))))());return k(this.ids.defaultImplementationConst,ue([this.ids.methodParameter,this.ids.pathParameter,this.ids.paramsArgument],i.createBlock([s,a,n,c,d,p,m]),{isAsync:!0}),{type:this.ids.implementationType})};makeSubscriptionConstructor=()=>_t(Ee({request:"K",params:K(this.interfaces.input,"K")}),[k(Jt(this.ids.pathParameter,this.ids.restConst),P(this.ids.substituteFn)(i.createElementAccessExpression(P(this.ids.parseRequestFn)(this.ids.requestParameter),A(1)),this.ids.paramsArgument)),k(this.ids.searchParamsConst,this.makeSearchParams(this.ids.restConst)),rr(i.createPropertyAccessExpression(i.createThis(),this.ids.sourceProp),ze("EventSource",this.makeFetchURL()))]);makeEventNarrow=t=>i.createTypeLiteralNode([le(R("event"),t)]);makeOnMethod=()=>Wt(this.ids.onMethod,Ee({[this.ids.eventParameter.text]:"E",[this.ids.handlerParameter.text]:or({[this.ids.dataParameter.text]:K(yt("R",Yt(this.makeEventNarrow("E"))),M(R("data")))},wo($.SyntaxKind.VoidKeyword))}),[i.createExpressionStatement(P(i.createThis(),this.ids.sourceProp,R("addEventListener"))(this.ids.eventParameter,ue([this.ids.msgParameter],P(this.ids.handlerParameter)(P(JSON[Symbol.toStringTag],R("parse"))(i.createPropertyAccessExpression(i.createParenthesizedExpression(i.createAsExpression(this.ids.msgParameter,u(MessageEvent.name))),R("data"))))))),i.createReturnStatement(i.createThis())],{typeParams:{E:K("R",M(R("event")))}});makeSubscriptionClass=t=>Xt(t,[Ao(this.ids.sourceProp,"EventSource"),this.makeSubscriptionConstructor(),this.makeOnMethod()],{typeParams:{K:yt(this.requestType.name,i.createTemplateLiteralType(i.createTemplateHead("get "),[i.createTemplateLiteralTypeSpan(u($.SyntaxKind.StringKeyword),i.createTemplateTail(""))])),R:yt(K(this.interfaces.positive,"K"),Yt(this.makeEventNarrow($.SyntaxKind.StringKeyword)))}});makeUsageStatements=(t,r)=>[k(this.ids.clientConst,ze(t)),P(this.ids.clientConst,this.ids.provideMethod)(A("get /v1/user/retrieve"),i.createObjectLiteralExpression([i.createPropertyAssignment("id",A("10"))])),P(ze(r,A("get /v1/events/stream"),i.createObjectLiteralExpression()),this.ids.onMethod)(A("time"),ue(["time"],i.createBlock([])))]};import{chain as ei,eqBy as nr,path as sr,prop as ti,uniqWith as ri}from"ramda";import g from"typescript";import{z as ar}from"zod";var{factory:U}=g,oi={[g.SyntaxKind.AnyKeyword]:"",[g.SyntaxKind.BigIntKeyword]:BigInt(0),[g.SyntaxKind.BooleanKeyword]:!1,[g.SyntaxKind.NumberKeyword]:0,[g.SyntaxKind.ObjectKeyword]:{},[g.SyntaxKind.StringKeyword]:"",[g.SyntaxKind.UndefinedKeyword]:void 0},ir={name:sr(["name","text"]),type:sr(["type"]),optional:sr(["questionToken"])},ni=({value:e})=>M(e),si=({shape:e},{isResponse:t,next:r,optionalPropStyle:{withQuestionMark:o}})=>{let n=Object.entries(e).map(([s,a])=>{let c=t&&ke(a)?a instanceof ar.ZodOptional:a.isOptional();return le(s,r(a),{isOptional:c&&o,comment:a.description})});return U.createTypeLiteralNode(n)},ii=({element:e},{next:t})=>U.createArrayTypeNode(t(e)),ai=({options:e})=>U.createUnionTypeNode(e.map(M)),zo=({options:e},{next:t})=>{let r=new Map;for(let o of e){let n=t(o);r.set(Eo(n)?n.kind:n,n)}return U.createUnionTypeNode(Array.from(r.values()))},pi=e=>oi?.[e.kind],ci=(e,{next:t,isResponse:r})=>{let o=t(e.innerType());if(r&&e._def.effect.type==="transform"){let n=Ve(e,pi(o)),s={number:g.SyntaxKind.NumberKeyword,bigint:g.SyntaxKind.BigIntKeyword,boolean:g.SyntaxKind.BooleanKeyword,string:g.SyntaxKind.StringKeyword,undefined:g.SyntaxKind.UndefinedKeyword,object:g.SyntaxKind.ObjectKeyword};return u(n&&s[n]||g.SyntaxKind.AnyKeyword)}return o},di=e=>U.createUnionTypeNode(Object.values(e.enum).map(M)),mi=(e,{next:t,optionalPropStyle:{withUndefined:r}})=>{let o=t(e.unwrap());return r?U.createUnionTypeNode([o,u(g.SyntaxKind.UndefinedKeyword)]):o},li=(e,{next:t})=>U.createUnionTypeNode([t(e.unwrap()),M(null)]),ui=({items:e,_def:{rest:t}},{next:r})=>U.createTupleTypeNode(e.map(r).concat(t===null?[]:U.createRestTypeNode(r(t)))),yi=({keySchema:e,valueSchema:t},{next:r})=>u("Record",[e,t].map(r)),fi=e=>{if(!e.every(g.isTypeLiteralNode))throw new Error("Not objects");let r=ei(ti("members"),e),o=ri((...n)=>{if(!nr(ir.name,...n))return!1;if(nr(ir.type,...n)&&nr(ir.optional,...n))return!0;throw new Error("Has conflicting prop")},r);return U.createTypeLiteralNode(o)},gi=({_def:{left:e,right:t}},{next:r})=>{let o=[e,t].map(r);try{return fi(o)}catch{}return U.createIntersectionTypeNode(o)},hi=({_def:e},{next:t})=>t(e.innerType),X=e=>()=>u(e),xi=(e,{next:t})=>t(e.unwrap()),bi=(e,{next:t})=>t(e.unwrap()),Si=({_def:e},{next:t})=>t(e.innerType),Ti=({_def:e},{next:t,isResponse:r})=>t(e[r?"out":"in"]),Oi=()=>M(null),Ri=(e,{makeAlias:t,next:r})=>t(e,()=>r(e.schema)),Pi=e=>{let t=e.unwrap(),r=u(g.SyntaxKind.StringKeyword),o=u("Buffer"),n=U.createUnionTypeNode([r,o]);return t instanceof ar.ZodString?r:t instanceof ar.ZodUnion?n:o},Ai=(e,{next:t})=>t(e.unwrap().shape.raw),wi={ZodString:X(g.SyntaxKind.StringKeyword),ZodNumber:X(g.SyntaxKind.NumberKeyword),ZodBigInt:X(g.SyntaxKind.BigIntKeyword),ZodBoolean:X(g.SyntaxKind.BooleanKeyword),ZodAny:X(g.SyntaxKind.AnyKeyword),ZodUndefined:X(g.SyntaxKind.UndefinedKeyword),[se]:X(g.SyntaxKind.StringKeyword),[ie]:X(g.SyntaxKind.StringKeyword),ZodNull:Oi,ZodArray:ii,ZodTuple:ui,ZodRecord:yi,ZodObject:si,ZodLiteral:ni,ZodIntersection:gi,ZodUnion:zo,ZodDefault:hi,ZodEnum:ai,ZodNativeEnum:di,ZodEffects:ci,ZodOptional:mi,ZodNullable:li,ZodDiscriminatedUnion:zo,ZodBranded:xi,ZodCatch:Si,ZodPipeline:Ti,ZodLazy:Ri,ZodReadonly:bi,[D]:Pi,[W]:Ai},pr=(e,{brandHandling:t,ctx:r})=>de(e,{rules:{...t,...wi},onMissing:()=>u(g.SyntaxKind.AnyKeyword),ctx:r});var cr=class extends ft{program=[this.someOfType];usage=[];aliases=new Map;makeAlias(t,r){let o=this.aliases.get(t)?.name?.text;if(!o){o=`Type${this.aliases.size+1}`;let n=M(null);this.aliases.set(t,B(o,n)),this.aliases.set(t,B(o,r()))}return u(o)}constructor({routing:t,brandHandling:r,variant:o="client",clientClassName:n="Client",subscriptionClassName:s="Subscription",serverUrl:a="https://example.com",optionalPropStyle:c={withQuestionMark:!0,withUndefined:!0},noContent:d=zi.undefined()}){super(a);let p={makeAlias:this.makeAlias.bind(this),optionalPropStyle:c},m={brandHandling:r,ctx:{...p,isResponse:!1}},f={brandHandling:r,ctx:{...p,isResponse:!0}};we({routing:t,onEndpoint:(y,O,S)=>{let Z=Q.bind(null,S,O),C=`${S} ${O}`,b=B(Z("input"),pr(y.getSchema("input"),m),{comment:C});this.program.push(b);let T=Re.reduce((z,L)=>{let I=y.getResponses(L),ee=Ei(([ht,{schema:_,mimeTypes:te,statusCodes:xt}])=>{let Fe=B(Z(L,"variant",`${ht+1}`),pr(te?_:d,f),{comment:C});return this.program.push(Fe),xt.map(qe=>le(qe,Fe.name))},Array.from(I.entries())),v=ut(Z(L,"response","variants"),ee,{comment:C});return this.program.push(v),Object.assign(z,{[L]:v})},{});this.paths.add(O);let N=M(C);this.registry.set(C,{input:u(b.name),positive:this.someOf(T.positive),negative:this.someOf(T.negative),response:i.createUnionTypeNode([K(this.interfaces.positive,N),K(this.interfaces.negative,N)]),encoded:i.createIntersectionTypeNode([u(T.positive.name),u(T.negative.name)])}),this.tags.set(C,y.getTags())}}),this.program.unshift(...this.aliases.values()),this.program.push(this.makePathType(),this.methodType,...this.makePublicInterfaces(),this.requestType),o!=="types"&&(this.program.push(this.makeEndpointTags(),this.makeParseRequestFn(),this.makeSubstituteFn(),this.makeImplementationType(),this.makeDefaultImplementation(),this.makeClientClass(n),this.makeSubscriptionClass(s)),this.usage.push(...this.makeUsageStatements(n,s)))}printUsage(t){return this.usage.length?this.usage.map(r=>typeof r=="string"?r:$t(r,t)).join(`
19
+ `):void 0}print(t){let r=this.printUsage(t),o=r&&gt.addSyntheticLeadingComment(gt.addSyntheticLeadingComment(i.createEmptyStatement(),gt.SyntaxKind.SingleLineCommentTrivia," Usage example:"),gt.SyntaxKind.MultiLineCommentTrivia,`
20
+ ${r}`);return this.program.concat(o||[]).map((n,s)=>$t(n,s<this.program.length?t:{...t,omitTrailingSemicolon:!0})).join(`
21
21
 
22
- `)}async printFormatted({printerOptions:t,format:r}={}){let o=r;if(!o)try{let a=(await Re("prettier")).format;o=c=>a(c,{filepath:"client.ts"})}catch{}let n=this.printUsage(t);this.usage=n&&o?[await o(n)]:this.usage;let i=this.print(t);return o?o(i):i}};import{z as we}from"zod";var To=(e,t)=>we.object({data:t,event:we.literal(e),id:we.string().optional(),retry:we.number().int().positive().optional()}),gi=(e,t,r)=>To(String(t),e[t]).transform(o=>[`event: ${o.event}`,`data: ${JSON.stringify(o.data)}`,"",""].join(`
23
- `)).parse({event:t,data:r}),hi=1e4,So=e=>e.headersSent||e.writeHead(200,{connection:"keep-alive","content-type":w.sse,"cache-control":"no-cache"}),xi=e=>new K({handler:async({response:t})=>setTimeout(()=>So(t),hi)&&{isClosed:()=>t.writableEnded||t.closed,emit:(r,o)=>{So(t),t.write(gi(e,r,o),"utf-8"),t.flush?.()}}}),bi=e=>new se({positive:()=>{let[t,...r]=Object.entries(e).map(([o,n])=>To(o,n));return{mimeType:w.sse,schema:r.length?we.discriminatedUnion("event",[t,...r]):t}},negative:{mimeType:"text/plain",schema:we.string()},handler:async({response:t,error:r,logger:o,request:n,input:i})=>{if(r){let a=he(r);ve(a,o,n,i),t.headersSent||t.status(a.statusCode).type("text/plain").write(ne(a),"utf-8")}t.end()}}),rr=class extends ie{constructor(t){super(bi(t)),this.middlewares=[xi(t)]}};var Si={dateIn:ir,dateOut:ar,file:Ge,upload:dr,raw:cr};export{ke as BuiltinLogger,Ne as DependsOnMethod,Dt as Documentation,U as DocumentationError,ie as EndpointsFactory,rr as EventStreamFactory,q as InputValidationError,tr as Integration,K as Middleware,Ee as MissingPeerError,X as OutputValidationError,se as ResultHandler,le as RoutingError,Le as ServeStatic,Jo as arrayEndpointsFactory,Et as arrayResultHandler,xn as attachRouting,Mo as createConfig,bn as createServer,Go as defaultEndpointsFactory,Ce as defaultResultHandler,he as ensureHttpError,Si as ez,_ as getExamples,ee as getMessageFromError,Ms as testEndpoint,Ks as testMiddleware};
22
+ `)}async printFormatted({printerOptions:t,format:r}={}){let o=r;if(!o)try{let a=(await Ae("prettier")).format;o=c=>a(c,{filepath:"client.ts"})}catch{}let n=this.printUsage(t);this.usage=n&&o?[await o(n)]:this.usage;let s=this.print(t);return o?o(s):s}};import{z as Ie}from"zod";var vo=(e,t)=>Ie.object({data:t,event:Ie.literal(e),id:Ie.string().optional(),retry:Ie.number().int().positive().optional()}),Ii=(e,t,r)=>vo(String(t),e[t]).transform(o=>[`event: ${o.event}`,`data: ${JSON.stringify(o.data)}`,"",""].join(`
23
+ `)).parse({event:t,data:r}),vi=1e4,Io=e=>e.headersSent||e.writeHead(200,{connection:"keep-alive","content-type":E.sse,"cache-control":"no-cache"}),ki=e=>new F({handler:async({response:t})=>setTimeout(()=>Io(t),vi)&&{isClosed:()=>t.writableEnded||t.closed,emit:(r,o)=>{Io(t),t.write(Ii(e,r,o),"utf-8"),t.flush?.()}}}),Zi=e=>new pe({positive:()=>{let[t,...r]=Object.entries(e).map(([o,n])=>vo(o,n));return{mimeType:E.sse,schema:r.length?Ie.discriminatedUnion("event",[t,...r]):t}},negative:{mimeType:"text/plain",schema:Ie.string()},handler:async({response:t,error:r,logger:o,request:n,input:s})=>{if(r){let a=be(r);Ce(a,o,n,s),t.headersSent||t.status(a.statusCode).type("text/plain").write(ae(a),"utf-8")}t.end()}}),dr=class extends ce{constructor(t){super(Zi(t)),this.middlewares=[ki(t)]}};var Ci={dateIn:yr,dateOut:fr,file:Qe,upload:xr,raw:hr};export{Le as BuiltinLogger,Me as DependsOnMethod,Ft as Documentation,H as DocumentationError,ce as EndpointsFactory,dr as EventStreamFactory,V as InputValidationError,cr as Integration,F as Middleware,ve as MissingPeerError,re as OutputValidationError,pe as ResultHandler,ye as RoutingError,Ue as ServeStatic,nn as arrayEndpointsFactory,zt as arrayResultHandler,En as attachRouting,_o as createConfig,zn as createServer,on as defaultEndpointsFactory,je as defaultResultHandler,be as ensureHttpError,Ci as ez,J as getExamples,oe as getMessageFromError,_s as testEndpoint,Gs as testMiddleware};
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "express-zod-api",
3
- "version": "22.4.0",
3
+ "version": "22.4.1",
4
4
  "description": "A Typescript framework to help you get an API server up and running with I/O schema validation and custom middlewares in minutes.",
5
5
  "license": "MIT",
6
6
  "repository": {