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