@visulima/api-platform 3.0.32 → 3.0.34

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/serializers/transformer/yaml.ts","../src/utils.ts","../src/swagger/extend-swagger-spec.ts","../src/swagger/api/swagger-handler.ts"],"names":["yamlTransformer","data","stringify","yaml_default","toHeaderCase","string_","c","jsonMediaType","prepareStatusContent","methodSpec","status","mediaType","extendComponentSchemas","spec","schemaName","schema","extendResponseSchema","schemaIsArray","extendSwaggerWithMediaTypeSchema","responseSpec","allowedMediaTypes","pathKey","example","examples","mediaName","contentSpec","allowed","extendSwaggerWithMediaTypeExample","transformers","transformed","regex","transformer","extendComponentExamples","exampleName","prepareResponseExamples","transformedExamples","extendSwaggerWithMediaTypeExamples","examplesName","extendSwaggerSpec","value","toXML","pathSpec","swaggerCrudDebug","debug","swaggerHandler","options","crud","specs","swaggerFilePath","request","response","swaggerPath","join","existsSync","fileContents","readFileSync","crudSwagger","modelsOpenApi","modelsToOpenApi","merge","error","swagger_handler_default"],"mappings":"uOAIMA,IAAAA,CAAAA,CAA+BC,CAASC,EAAAA,SAAAA,CAAUD,CAAM,CAAA,CAAE,MAAQ,CAAA,CAAE,CAAC,CAAA,CAEpEE,CAAQH,CAAAA,ECwCFI,IAAAA,CAAAA,CAAgBC,CACzBA,EAAAA,CAAAA,CACK,WAAY,EAAA,CACZ,UAAW,CAAA,WAAA,CAAa,GAAG,CAAA,CAC3B,OAAQ,EAAA,CACR,UAAW,CAAA,SAAA,CAAW,GAAG,CAAA,CACzB,UAAW,CAAA,QAAA,CAAWC,CAAMA,EAAAA,CAAAA,CAAE,WAAY,EAAC,EC3CpD,IAAMC,CAAgB,CAAA,kBAAA,CAEhBC,CAAuB,CAAA,CAACC,CAAuCC,CAAAA,CAAAA,CAAgBC,CAAsB,GAAA,CACjGF,CAAW,CAAA,SAAA,CAAmDC,CAAM,CAAA,CAA+B,OAAY,GAAA,KAAA,CAAA,GAE/GD,CAAW,CAAA,SAAA,CAAmDC,CAAM,CAAA,CAA+B,OAAU,CAAA,EAG7GD,CAAAA,CAAAA,CAAAA,CAAW,SAAmDC,CAAAA,CAAM,CAA+B,CAAA,OAAA,GAAUC,CAAS,CAAA,GAAM,KAG3HF,CAAAA,GAAAA,CAAAA,CAAW,SAAmDC,CAAAA,CAAM,CAA+B,CAAA,OAAA,CAIlGC,CACJ,CAAA,CAAI,EAAC,EAEb,CAEMC,CAAAA,CAAAA,CAAyB,CAACC,CAAAA,CAAmCC,CAAoBC,CAAAA,CAAAA,GAAmC,CAClH,OAAOF,CAAK,CAAA,UAAA,EAAe,QAE3BA,GAAAA,CAAAA,CAAK,UAAa,CAAA,EAGlB,CAAA,CAAA,OAAOA,CAAK,CAAA,UAAA,CAAW,OAAY,EAAA,QAAA,GAEnCA,CAAK,CAAA,UAAA,CAAW,OAAU,CAAA,EAG1BA,CAAAA,CAAAA,CAAAA,CAAK,UAAW,CAAA,OAAA,CAAQC,CAAU,CAAA,GAAM,KAExCD,CAAAA,GAAAA,CAAAA,CAAK,UAAW,CAAA,OAAA,CAAQC,CAAU,CAAA,CAAIC,CAE9C,EAAA,CAAA,CAEMC,CAAuB,CAAA,CAACP,CAAuCC,CAAAA,CAAAA,CAAgBC,CAAmBG,CAAAA,CAAAA,CAAoBG,CAA2B,GAAA,CACnJT,CAAqBC,CAAAA,CAAAA,CAAYC,CAAQC,CAAAA,CAAS,CAE5CF,CAAAA,CAAAA,CAAW,SAAmDC,CAAAA,CAAM,CAA+B,CAAA,OAAA,GAAUC,CAAS,CAAA,EAAG,MAAW,GAAA,KAAA,CAAA,GAGlIF,CAAW,CAAA,SAAA,CAAmDC,CAAM,CAAA,CAA+B,OAI/FC,CAAAA,CACJ,CAAgC,CAAA,MAAA,CAChC,EAAC,CAAA,CAKLF,CAAW,CAAA,SAAA,CAAmDC,CAAM,CAAA,CAA+B,OAI/FC,CAAAA,CACJ,CAAgC,CAAA,MAAA,CAChCM,CACM,CAAA,CACI,KAAO,CAAA,CACH,IAAM,CAAA,CAAA,qBAAA,EAAwBH,CAAU,CAAA,CAC5C,CACA,CAAA,IAAA,CAAM,OACV,CAAA,CACA,CACI,IAAA,CAAM,CAAwBA,qBAAAA,EAAAA,CAAU,CAC5C,CAAA,EACd,CAEMI,CAAAA,CAAAA,CAAmC,CACrCT,CAAAA,CACAU,CACAC,CAAAA,CAAAA,CACAC,CACAR,CAAAA,CAAAA,CACAH,CAIC,GAAA,CACD,IAAIY,CAAAA,CACAC,CAGJ,CAAA,OAAA,MAAA,CAAO,OAAQJ,CAAAA,CAAAA,CAAa,OAAiB,CAAA,CAAE,OAAQ,CAAA,CAAC,CAACK,CAAAA,CAAWC,CAAW,CAAA,GAAM,CACjF,GAAI,OAAOA,CAAAA,CAAY,MAAW,EAAA,QAAA,CAAU,CACxC,GAAM,CAAE,MAAA,CAAAV,CAAO,CAAA,CAAIU,CAEfD,CAAAA,CAAAA,GAAcjB,CAAiBkB,EAAAA,CAAAA,CAAY,QAAa,GAAA,KAAA,CAAA,CACxDF,CAAWE,CAAAA,CAAAA,CAAY,QAChBD,CAAAA,CAAAA,GAAcjB,CAAiBkB,EAAAA,CAAAA,CAAY,OAAY,GAAA,KAAA,CAAA,GAC9DH,CAAUG,CAAAA,CAAAA,CAAY,SAG1B,IAAMR,CAAAA,CAAiBF,CAAkC,CAAA,IAAA,GAAS,OAElE,CAAA,MAAA,CAAO,OAAQK,CAAAA,CAAAA,EAAqB,EAAE,CAAE,CAAA,OAAA,CAAQ,CAAC,CAACT,CAAWe,CAAAA,CAAO,CAAM,GAAA,CACtE,GAAI,CAACA,CACD,CAAA,OAGJ,IAAIZ,CAAAA,CAEAC,CAAQ,EAAA,IAAA,GAAS,KACjBD,CAAAA,EAAAA,CAAAA,CAAa,CAAGV,EAAAA,CAAAA,CAAaiB,CAAQ,CAAA,IAAA,EAAO,CAAA,OAAA,CAAQ,GAAK,CAAA,EAAE,CAAC,CAAC,CAAGV,EAAAA,CAAAA,GAAc,qBAAwB,CAAA,SAAA,CAAY,EAAE,CAAA,CAAA,CAEpHC,CAAuBC,CAAAA,CAAAA,CAA4BC,CAAYC,CAAAA,CAAgC,CAE/FD,EAAAA,CAAAA,CAAcC,CAAqC,CAAA,IAAA,CAAK,OAAQ,CAAA,uBAAA,CAAyB,EAAE,CAAA,CAG/FC,CAAqBP,CAAAA,CAAAA,CAAYC,CAAQC,CAAAA,CAAAA,CAAWG,CAAYG,CAAAA,CAAa,EACjF,CAAC,EACL,CACJ,CAAC,CAAA,CAEM,CAAE,OAAA,CAAAK,CAAS,CAAA,QAAA,CAAAC,CAAS,CAC/B,CAEMI,CAAAA,CAAAA,CAAoC,CACtClB,CAAAA,CACAU,CACAT,CAAAA,CAAAA,CACAU,CACAQ,CAAAA,CAAAA,CACAN,CACC,GAAA,CACD,MAAO,CAAA,IAAA,CAAKH,CAAa,CAAA,OAAiB,CAAE,CAAA,OAAA,CAASK,CAAc,EAAA,CAC3DA,CAAcjB,GAAAA,CAAAA,EAIlB,MAAO,CAAA,OAAA,CAAQa,CAAqB,EAAA,EAAE,CAAA,CAAE,OAAQ,CAAA,CAAC,CAACT,CAAAA,CAAWe,CAAO,CAAA,GAAM,CACtE,GAAI,CAACA,CAAAA,CACD,OAGJlB,CAAAA,CAAqBC,CAAYC,CAAAA,CAAAA,CAAQC,CAAS,CAAA,CAG5CF,CAAW,CAAA,SAAA,CAAmDC,CAAM,CAAA,CAA+B,OAAUC,GAAAA,CAAS,CAAG,EAAA,OAAA,GAAY,KAInIF,CAAAA,GAAAA,CAAAA,CAAW,SAAmDC,CAAAA,CAAM,CAA+B,CAAA,OAAA,CAI/FC,CACJ,CAAA,CAAgC,OAChC,CAAA,EAGR,CAAA,CAAA,IAAIkB,CAAc,CAAA,CAAA,CAAA,CAElBD,CAAa,CAAA,OAAA,CAAQ,CAAC,CAAE,KAAAE,CAAAA,CAAAA,CAAO,WAAAC,CAAAA,CAAY,CAAM,GAAA,CACzC,CAACF,CAAAA,EAAeC,CAAM,CAAA,IAAA,CAAKnB,CAAS,CAAA,GAGhCF,CAAW,CAAA,SAAA,CAAmDC,CAAM,CAAA,CAA+B,OAI/FC,CAAAA,CACJ,CAAgC,CAAA,OAAA,CAChCoB,CAAYT,CAAAA,CAAO,CAEvBO,CAAAA,CAAAA,CAAc,CAEtB,CAAA,EAAA,CAAC,CAEIA,CAAAA,CAAAA,GAGGpB,CAAW,CAAA,SAAA,CAAmDC,CAAM,CAAA,CAA+B,OAI/FC,CAAAA,CACJ,CAAgC,CAAA,OAAA,CAChCW,CAEZ,EAAA,CAAC,EACL,CAAC,EACL,CAAA,CAEMU,CAA0B,CAAA,CAC5BnB,CACAoB,CAAAA,CAAAA,CACAV,CACC,GAAA,CACG,OAAOV,CAAAA,CAAK,UAAe,EAAA,QAAA,GAE3BA,CAAK,CAAA,UAAA,CAAa,EAAC,CAAA,CAGnB,OAAOA,CAAAA,CAAK,UAAW,CAAA,QAAA,EAAa,QAEpCA,GAAAA,CAAAA,CAAK,UAAW,CAAA,QAAA,CAAW,EAAC,CAAA,CAG5BA,CAAK,CAAA,UAAA,CAAW,QAASoB,CAAAA,CAAW,CAAM,GAAA,KAAA,CAAA,EAAaV,CAASU,CAAAA,CAAW,CAAM,GAAA,KAAA,CAAA,GAEjFpB,CAAK,CAAA,UAAA,CAAW,QAASoB,CAAAA,CAAW,CAAIV,CAAAA,CAAAA,CAASU,CAAW,CAAA,EAEpE,CAEMC,CAAAA,CAAAA,CAA0B,CAC5BrB,CAAAA,CACAJ,CACAC,CAAAA,CAAAA,CACAC,CACAiB,CAAAA,CAAAA,CACAL,CAEC,GAAA,CACDf,CAAqBC,CAAAA,CAAAA,CAAYC,CAAQC,CAAAA,CAAS,CAE5CF,CAAAA,CAAAA,CAAW,SAAmDC,CAAAA,CAAM,CAA+B,CAAA,OAAA,GAAUC,CAAS,CAAA,EAAG,QAAa,GAAA,KAAA,CAAA,GAGpIF,CAAW,CAAA,SAAA,CAAmDC,CAAM,CAAA,CAA+B,QAI/FC,CACJ,CAAA,CAAgC,QAChC,CAAA,EAGR,CAAA,CAAA,IAAMwB,CAA2F,CAAA,EAEjG,CAAA,MAAA,CAAO,OAAQZ,CAAAA,CAAQ,CAAE,CAAA,OAAA,CAAQ,CAAC,CAACU,CAAaX,CAAAA,CAAO,CAAM,GAAA,CACzD,IAAIO,CAAAA,CAAc,CAElBD,CAAAA,CAAAA,CAAAA,CAAa,OAAQ,CAAA,CAAC,CAAE,KAAA,CAAAE,CAAO,CAAA,WAAA,CAAAC,CAAY,CAAA,GAAM,CAC7C,GAAI,CAACF,CAAAA,EAAeC,CAAM,CAAA,IAAA,CAAKnB,CAAS,CAAA,CAAG,CACvC,IAAIV,CAAY,CAAA,EAAA,CAEZY,CAAK,CAAA,UAAA,EAAY,QAAWoB,GAAAA,CAAW,CACvChC,CAAAA,CAAAA,CAAQY,CAAK,CAAA,UAAA,CAAW,QAASoB,CAAAA,CAAW,CAA8B,CAAA,KAAA,CAClEX,CAAsC,CAAA,IAAA,CAC9CrB,CACIY,CAAAA,CAAAA,CAAAA,CAAK,UAAY,EAAA,QAAA,GACZS,CAAsC,CAAA,IAAA,CAAK,OAAQ,CAAA,wBAAA,CAA0B,EAAE,CACpF,CACF,EAAA,KAAA,CACK,OAAQA,CAAAA,CAAoC,KAAU,EAAA,QAAA,GAC7DrB,CAAQqB,CAAAA,CAAAA,CAAoC,KAGhDa,CAAAA,CAAAA,CAAAA,CAAoBF,CAAW,CAAA,CAAI,CAC/B,KAAA,CAAOF,CAAY9B,CAAAA,CAAI,CAC3B,CAAA,CAEA4B,CAAc,CAAA,CAAA,EAClB,CACJ,CAAC,CAEIA,CAAAA,CAAAA,GACDM,CAAoBF,CAAAA,CAAW,CAC3BpB,CAAAA,CAAAA,CAAK,UAAY,EAAA,QAAA,GAAWoB,CAAW,CAAA,GAAM,KACvCX,CAAAA,CAAAA,CAAAA,CACA,CACI,IAAA,CAAM,CAAyBW,sBAAAA,EAAAA,CAAW,CAC9C,CAAA,CAAA,EAElB,CAAC,CAAA,CAIGxB,CAAW,CAAA,SAAA,CAAmDC,CAAM,CAAA,CAA+B,OAI/FC,CAAAA,CACJ,CAAgC,CAAA,QAAA,CAChCwB,EACR,CAAA,CAEMC,CAAqC,CAAA,CACvCvB,CACAJ,CAAAA,CAAAA,CACAC,CACAS,CAAAA,CAAAA,CACAC,CACAC,CAAAA,CAAAA,CACAO,CACAL,CAAAA,CAAAA,GACC,CACD,IAAMc,CAAejC,CAAAA,CAAAA,CAAaiB,CAAQ,CAAA,IAAA,EAAO,CAAA,OAAA,CAAQ,GAAK,CAAA,EAAE,CAAC,CAAA,CAEjE,MAAO,CAAA,IAAA,CAAKF,CAAa,CAAA,OAAiB,CAAE,CAAA,OAAA,CAASK,CAAc,EAAA,CAC3DA,CAAcjB,GAAAA,CAAAA,EAIlB,MAAO,CAAA,OAAA,CAAQa,CAAqB,EAAA,EAAE,CAAA,CAAE,OAAQ,CAAA,CAAC,CAACT,CAAAA,CAAWe,CAAO,CAAA,GAAM,CACjEA,CAAAA,GAILM,CAAwBnB,CAAAA,CAAAA,CAAMwB,CAAcd,CAAAA,CAAQ,CAEpDW,CAAAA,CAAAA,CAAwBrB,CAAMJ,CAAAA,CAAAA,CAAYC,CAAQC,CAAAA,CAAAA,CAAWiB,CAAcL,CAAAA,CAAQ,CACvF,EAAA,CAAC,EACL,CAAC,EACL,CAAA,CAGe,SAARe,CAAAA,CACHzB,CACAO,CAAAA,CAAAA,CACAQ,CAA6B,CAAA,CACzB,CACI,KAAA,CAAO,MACP,CAAA,WAAA,CAAcW,CACVC,EAAAA,KAAAA,CAAMD,CAAO,CAAA,CACT,MAAQ,CAAA,CAAA,CAAA,CACR,MAAQ,CAAA,IACZ,CAAC,CACT,CACA,CAAA,CACI,KAAO,CAAA,UAAA,CACP,WAAcA,CAAAA,CAAAA,EAAUrC,SAAUqC,CAAAA,CAAAA,CAAO,CAAE,MAAA,CAAQ,CAAE,CAAC,CAC1D,CACJ,CAC2B,CAAA,CAC3B,OAAI,OAAO1B,CAAS,EAAA,QAAA,EAAY,OAAOA,CAAAA,CAAK,KAAU,EAAA,QAAA,EAClD,MAAO,CAAA,OAAA,CAAQA,CAAK,CAAA,KAAK,CAAE,CAAA,OAAA,CAAQ,CAAC,CAACQ,CAASoB,CAAAA,CAAQ,CAAM,GAAA,CACxD,MAAO,CAAA,MAAA,CAAOA,CAA6D,CAAA,CAAE,OAAShC,CAAAA,CAAAA,EAAe,CAC7F,OAAQA,CAAyC,CAAA,SAAA,EAAc,QAC/D,EAAA,MAAA,CAAO,OAASA,CAAAA,CAAAA,CAAyC,SAAS,CAAE,CAAA,OAAA,CAAQ,CAAC,CAACC,CAAQS,CAAAA,CAAY,CAAM,GAAA,CACpG,GAAI,OAAQA,CAA0C,CAAA,OAAA,EAAY,QAAU,CAAA,CACxE,GAAM,CAAE,OAAAG,CAAAA,CAAAA,CAAS,QAAAC,CAAAA,CAAS,CAAIL,CAAAA,CAAAA,CAC1BT,CACAU,CAAAA,CAAAA,CACAC,CACAC,CAAAA,CAAAA,CACAR,CACAH,CAAAA,CACJ,CAEIY,CAAAA,CAAAA,GAAY,KACZK,CAAAA,CAAAA,CAAAA,CACIlB,CACAU,CAAAA,CAAAA,CACAT,CACAU,CAAAA,CAAAA,CACAQ,CACAN,CAAAA,CACJ,CACOC,CAAAA,CAAAA,GAAa,KACpBa,CAAAA,EAAAA,CAAAA,CACIvB,CACAJ,CAAAA,CAAAA,CACAC,CACAS,CAAAA,CAAAA,CACAC,CACAC,CAAAA,CAAAA,CACAO,CACAL,CAAAA,CACJ,EAER,CACJ,CAAC,EAET,CAAC,EACL,CAAC,CAAA,CAGEV,CACX,CClXM6B,IAAAA,CAAAA,CAAmBC,CAAM,CAAA,kEAAkE,CAE3FC,CAAAA,CAAAA,CAAiB,CACnBC,CAAAA,CAA2D,EAAC,GACc,CAC1E,GAAM,CACF,iBAAA,CAAAzB,CAAoB,CAAA,CAChB,kBAAoB,CAAA,CAAA,CACxB,CACA,CAAA,IAAA,CAAA0B,CACA,CAAA,KAAA,CAAAC,CACA,CAAA,eAAA,CAAAC,CACJ,CAAA,CAAIH,CAEJ,CAAA,OAAgFI,MAAAA,CAAAA,CAAkBC,CAAuB,GAAA,CACrH,IAAMC,CAAAA,CAAcC,IAAK,CAAA,OAAA,CAAQ,GAAI,EAAA,CAAGJ,CAAmB,EAAA,sBAAsB,CAEjF,CAAA,GAAI,CAACK,UAAAA,CAAWF,CAAW,CAAA,CACvB,MAAM,IAAI,KAAM,CAAA,CAAA,2BAAA,EAA8BA,CAAW,CAAA,EAAA,CAAI,CAGjE,CAAA,IAAMG,CAAeC,CAAAA,YAAAA,CAAaJ,CAAa,CAAA,MAAM,CAEjDtC,CAAAA,CAAAA,CAAOyB,CAAkB,CAAA,IAAA,CAAK,KAAMgB,CAAAA,CAAY,CAAyBlC,CAAAA,CAAiB,CAC1FoC,CAAAA,CAAAA,CAA2C,EAAC,CAEhD,GAAIV,CAAAA,GAAS,KACT,CAAA,CAAA,GAAI,CACA,IAAMW,CAAgB,CAAA,MAAMC,eAAgBZ,CAAAA,CAAI,CAEhDU,CAAAA,CAAAA,CAAc,CACV,UAAA,CAAY,CAAE,QAAA,CAAUC,CAAc,CAAA,QAAA,CAAU,OAASA,CAAAA,CAAAA,CAAc,OAAQ,CAAA,CAC/E,KAAOA,CAAAA,CAAAA,CAAc,KACrB,CAAA,IAAA,CAAMA,CAAc,CAAA,IACxB,CAEAD,CAAAA,CAAAA,CAAclB,CAAkBkB,CAAAA,CAAAA,CAAapC,CAAiB,CAAA,CAE9DsB,CAAiB,CAAA,IAAA,CAAK,SAAUc,CAAAA,CAAAA,CAAa,IAAM,CAAA,CAAC,CAAC,CAAA,CAErD3C,CAAO8C,CAAAA,CAAAA,CAAM9C,CAAM2C,CAAAA,CAAW,EAClC,CAAA,MAASI,CAAO,CAAA,CAEZ,MAAQ,OAAA,CAAA,GAAA,CAAIA,CAAK,CAAA,CAEX,IAAI,KAAA,CAAM,kEAAkE,CACtF,CAGA,KAAA,CAAM,OAAQb,CAAAA,CAAK,CACnBA,EAAAA,CAAAA,CAAM,OAASR,CAAAA,CAAAA,EAAU,CACrB1B,CAAAA,CAAO8C,CAAM9C,CAAAA,CAAAA,CAAMyB,CAAkBC,CAAAA,CAAAA,CAAOnB,CAAiB,CAAC,EAClE,CAAC,CAGL,CAAA,IAAInB,CAEA,CAAA,OAAOgD,CAAQ,CAAA,OAAA,CAAQ,MAAW,EAAA,QAAA,EAAY,UAAW,CAAA,IAAA,CAAKA,CAAQ,CAAA,OAAA,CAAQ,MAAM,CAAA,EACpFC,CAAS,CAAA,SAAA,CAAU,cAAgBD,CAAAA,CAAAA,CAAQ,OAAQ,CAAA,MAAM,CAEzDhD,CAAAA,CAAAA,CAAOE,CAAgBU,CAAAA,CAAI,CAE3BqC,GAAAA,CAAAA,CAAS,SAAU,CAAA,cAAA,CAAgB,kBAAkB,CAAA,CAErDjD,CAAO,CAAA,IAAA,CAAK,SAAUY,CAAAA,CAAAA,CAAM,IAAM,CAAA,CAAC,CAGvCqC,CAAAA,CAAAA,CAAAA,CAAS,UAAa,CAAA,GAAA,CACtBA,CAAS,CAAA,GAAA,CAAIjD,CAAI,EACrB,CACJ,CAAA,CAaO4D,EAAQjB,CAAAA","file":"chunk-T4ABIWHW.mjs","sourcesContent":["import { stringify } from \"yaml\";\n\nimport type { Serializer } from \"../types\";\n\nconst yamlTransformer: Serializer = (data) => stringify(data, { indent: 2 });\n\nexport default yamlTransformer;\n","import type { IncomingMessage, ServerResponse } from \"node:http\";\nimport { URL } from \"node:url\";\n\ntype IncomingApiRequest<TApiRequest = IncomingMessage> = TApiRequest & {\n body?: any;\n query?: any;\n};\n\nexport const jsonResponse = (response: ServerResponse, status: number, data?: unknown): void => {\n response.statusCode = status;\n response.setHeader(\"Content-Type\", \"application/json\");\n response.end(data ? JSON.stringify(data) : \"\");\n};\n\nexport const parseBody = async (request: IncomingApiRequest): Promise<any> => {\n if (request.body) {\n return request.body;\n }\n\n const buffers = [];\n\n // eslint-disable-next-line no-restricted-syntax,no-loops/no-loops\n for await (const chunk of request) {\n buffers.push(chunk);\n }\n\n const data = Buffer.concat(buffers).toString();\n\n return data ? JSON.parse(data) : null;\n};\n\nexport const parseQuery = (request: IncomingApiRequest): Record<string, unknown> => {\n if (request.query) {\n return request.query;\n }\n\n if (!request.url) {\n return {};\n }\n\n // Note: Fake protocol is required to parse query string\n const url = new URL(`https://${request.headers.host?.replace(/\\/$/u, \"\")}/${request.url}`);\n\n return Object.fromEntries(url.searchParams.entries());\n};\n\nexport const toHeaderCase = (string_: string): string =>\n string_\n .toLowerCase()\n .replaceAll(/[^\\s\\w]/gu, \" \") // Remove all non-word characters\n .trimEnd() // Remove trailing spaces\n .replaceAll(/\\s+|_/gu, \"-\") // Replace multiple spaces or underline with a single hyphen\n .replaceAll(/\\b\\w/gu, (c) => c.toUpperCase());\n","import type { XmlElement } from \"jstoxml\";\nimport { toXML } from \"jstoxml\";\nimport type { OpenAPIV3 } from \"openapi-types\";\nimport { stringify } from \"yaml\";\n\nimport { toHeaderCase } from \"../utils\";\n\ntype Transformers = { regex: RegExp; transformer: (data: any) => string }[];\n\nconst jsonMediaType = \"application/json\";\n\nconst prepareStatusContent = (methodSpec: OpenAPIV3.OperationObject, status: string, mediaType: string) => {\n if (((methodSpec.responses as unknown as OpenAPIV3.ResponsesObject)[status] as OpenAPIV3.ResponseObject).content === undefined) {\n // eslint-disable-next-line no-param-reassign\n ((methodSpec.responses as unknown as OpenAPIV3.ResponsesObject)[status] as OpenAPIV3.ResponseObject).content = {};\n }\n\n if (((methodSpec.responses as unknown as OpenAPIV3.ResponsesObject)[status] as OpenAPIV3.ResponseObject).content?.[mediaType] === undefined) {\n // prettier-ignore\n // eslint-disable-next-line no-param-reassign\n (((methodSpec.responses as unknown as OpenAPIV3.ResponsesObject)[status] as OpenAPIV3.ResponseObject).content as Record<\n string,\n OpenAPIV3.MediaTypeObject\n >)[\n mediaType\n ] = {} as OpenAPIV3.MediaTypeObject;\n }\n};\n\nconst extendComponentSchemas = (spec: Partial<OpenAPIV3.Document>, schemaName: string, schema: OpenAPIV3.SchemaObject) => {\n if (typeof spec.components !== \"object\") {\n // eslint-disable-next-line no-param-reassign\n spec.components = {};\n }\n\n if (typeof spec.components.schemas !== \"object\") {\n // eslint-disable-next-line no-param-reassign\n spec.components.schemas = {};\n }\n\n if (spec.components.schemas[schemaName] === undefined) {\n // eslint-disable-next-line no-param-reassign\n spec.components.schemas[schemaName] = schema;\n }\n};\n\nconst extendResponseSchema = (methodSpec: OpenAPIV3.OperationObject, status: string, mediaType: string, schemaName: string, schemaIsArray: boolean) => {\n prepareStatusContent(methodSpec, status, mediaType);\n\n if (((methodSpec.responses as unknown as OpenAPIV3.ResponsesObject)[status] as OpenAPIV3.ResponseObject).content?.[mediaType]?.schema === undefined) {\n // prettier-ignore\n // eslint-disable-next-line no-param-reassign\n ((((methodSpec.responses as unknown as OpenAPIV3.ResponsesObject)[status] as OpenAPIV3.ResponseObject).content as Record<\n string,\n OpenAPIV3.MediaTypeObject\n >)[\n mediaType\n ] as OpenAPIV3.MediaTypeObject).schema =\n {} as OpenAPIV3.SchemaObject;\n }\n\n // prettier-ignore\n // eslint-disable-next-line no-param-reassign\n ((((methodSpec.responses as unknown as OpenAPIV3.ResponsesObject)[status] as OpenAPIV3.ResponseObject).content as Record<\n string,\n OpenAPIV3.MediaTypeObject\n >)[\n mediaType\n ] as OpenAPIV3.MediaTypeObject).schema =\n schemaIsArray\n ? {\n items: {\n $ref: `#/components/schemas/${schemaName}`,\n },\n type: \"array\",\n }\n : {\n $ref: `#/components/schemas/${schemaName}`,\n };\n};\n\nconst extendSwaggerWithMediaTypeSchema = (\n methodSpec: OpenAPIV3.OperationObject,\n responseSpec: OpenAPIV3.ResponseObject,\n allowedMediaTypes: Record<string, boolean> | undefined,\n pathKey: string,\n spec: Partial<OpenAPIV3.Document>,\n status: string,\n): {\n example?: any;\n examples?: Record<string, OpenAPIV3.ExampleObject | OpenAPIV3.ReferenceObject>;\n} => {\n let example: any | undefined;\n let examples: Record<string, OpenAPIV3.ExampleObject | OpenAPIV3.ReferenceObject> | undefined;\n\n // eslint-disable-next-line sonarjs/cognitive-complexity\n Object.entries(responseSpec.content as object).forEach(([mediaName, contentSpec]) => {\n if (typeof contentSpec.schema === \"object\") {\n const { schema } = contentSpec;\n\n if (mediaName === jsonMediaType && contentSpec.examples !== undefined) {\n examples = contentSpec.examples;\n } else if (mediaName === jsonMediaType && contentSpec.example !== undefined) {\n example = contentSpec.example;\n }\n\n const schemaIsArray = (schema as OpenAPIV3.SchemaObject).type === \"array\";\n\n Object.entries(allowedMediaTypes ?? {}).forEach(([mediaType, allowed]) => {\n if (!allowed) {\n return;\n }\n\n let schemaName: string;\n\n if (schema?.$ref === undefined) {\n schemaName = `${toHeaderCase(pathKey.trim().replace(\"/\", \"\"))}${mediaType === \"application/ld+json\" ? \".jsonld\" : \"\"}`;\n\n extendComponentSchemas(spec as OpenAPIV3.Document, schemaName, schema as OpenAPIV3.SchemaObject);\n } else {\n schemaName = (schema as OpenAPIV3.ReferenceObject).$ref.replace(\"#/components/schemas/\", \"\");\n }\n\n extendResponseSchema(methodSpec, status, mediaType, schemaName, schemaIsArray);\n });\n }\n });\n\n return { example, examples };\n};\n\nconst extendSwaggerWithMediaTypeExample = (\n methodSpec: OpenAPIV3.OperationObject,\n responseSpec: OpenAPIV3.ResponseObject,\n status: string,\n allowedMediaTypes: Record<string, boolean> | undefined,\n transformers: Transformers,\n example: any,\n) => {\n Object.keys(responseSpec.content as object).forEach((mediaName) => {\n if (mediaName === jsonMediaType) {\n return;\n }\n\n Object.entries(allowedMediaTypes ?? {}).forEach(([mediaType, allowed]) => {\n if (!allowed) {\n return;\n }\n\n prepareStatusContent(methodSpec, status, mediaType);\n\n if (\n ((methodSpec.responses as unknown as OpenAPIV3.ResponsesObject)[status] as OpenAPIV3.ResponseObject).content?.[mediaType]?.example === undefined\n ) {\n // prettier-ignore\n // eslint-disable-next-line no-param-reassign\n ((((methodSpec.responses as unknown as OpenAPIV3.ResponsesObject)[status] as OpenAPIV3.ResponseObject).content as Record<\n string,\n OpenAPIV3.MediaTypeObject\n >)[\n mediaType\n ] as OpenAPIV3.MediaTypeObject).example =\n {};\n }\n\n let transformed = false;\n\n transformers.forEach(({ regex, transformer }) => {\n if (!transformed && regex.test(mediaType)) {\n // prettier-ignore\n // eslint-disable-next-line no-param-reassign\n ((((methodSpec.responses as unknown as OpenAPIV3.ResponsesObject)[status] as OpenAPIV3.ResponseObject).content as Record<\n string,\n OpenAPIV3.MediaTypeObject\n >)[\n mediaType\n ] as OpenAPIV3.MediaTypeObject).example =\n transformer(example);\n\n transformed = true;\n }\n });\n\n if (!transformed) {\n // prettier-ignore\n // eslint-disable-next-line no-param-reassign\n ((((methodSpec.responses as unknown as OpenAPIV3.ResponsesObject)[status] as OpenAPIV3.ResponseObject).content as Record<\n string,\n OpenAPIV3.MediaTypeObject\n >)[\n mediaType\n ] as OpenAPIV3.MediaTypeObject).example =\n example;\n }\n });\n });\n};\n\nconst extendComponentExamples = (\n spec: Partial<OpenAPIV3.Document>,\n exampleName: string,\n examples: Record<string, OpenAPIV3.ExampleObject | OpenAPIV3.ReferenceObject>,\n) => {\n if (typeof spec.components !== \"object\") {\n // eslint-disable-next-line no-param-reassign\n spec.components = {};\n }\n\n if (typeof spec.components.examples !== \"object\") {\n // eslint-disable-next-line no-param-reassign\n spec.components.examples = {};\n }\n\n if (spec.components.examples[exampleName] === undefined && examples[exampleName] !== undefined) {\n // eslint-disable-next-line no-param-reassign\n spec.components.examples[exampleName] = examples[exampleName] as OpenAPIV3.ExampleObject;\n }\n};\n\nconst prepareResponseExamples = (\n spec: Partial<OpenAPIV3.Document>,\n methodSpec: OpenAPIV3.OperationObject,\n status: string,\n mediaType: string,\n transformers: Transformers,\n examples: Record<string, OpenAPIV3.ExampleObject | OpenAPIV3.ReferenceObject>,\n // eslint-disable-next-line sonarjs/cognitive-complexity\n) => {\n prepareStatusContent(methodSpec, status, mediaType);\n\n if (((methodSpec.responses as unknown as OpenAPIV3.ResponsesObject)[status] as OpenAPIV3.ResponseObject).content?.[mediaType]?.examples === undefined) {\n // prettier-ignore\n // eslint-disable-next-line no-param-reassign\n ((((methodSpec.responses as unknown as OpenAPIV3.ResponsesObject)[status] as OpenAPIV3.ResponseObject).content as Record<\n string,\n OpenAPIV3.MediaTypeObject\n >)[\n mediaType\n ] as OpenAPIV3.MediaTypeObject).examples =\n {};\n }\n\n const transformedExamples: Record<string, OpenAPIV3.ExampleObject | OpenAPIV3.ReferenceObject> = {};\n\n Object.entries(examples).forEach(([exampleName, example]) => {\n let transformed = false;\n\n transformers.forEach(({ regex, transformer }) => {\n if (!transformed && regex.test(mediaType)) {\n let data: any = \"\";\n\n if (spec.components?.examples?.[exampleName]) {\n data = (spec.components.examples[exampleName] as OpenAPIV3.ExampleObject).value;\n } else if ((example as OpenAPIV3.ReferenceObject).$ref) {\n data = (\n spec.components?.examples?.[\n (example as OpenAPIV3.ReferenceObject).$ref.replace(\"#/components/examples/\", \"\")\n ] as OpenAPIV3.ExampleObject\n ).value;\n } else if (typeof (example as OpenAPIV3.ExampleObject).value === \"string\") {\n data = (example as OpenAPIV3.ExampleObject).value;\n }\n\n transformedExamples[exampleName] = {\n value: transformer(data),\n };\n\n transformed = true;\n }\n });\n\n if (!transformed) {\n transformedExamples[exampleName] =\n spec.components?.examples?.[exampleName] === undefined\n ? example\n : {\n $ref: `#/components/examples/${exampleName}`,\n };\n }\n });\n\n // prettier-ignore\n // eslint-disable-next-line no-param-reassign\n ((((methodSpec.responses as unknown as OpenAPIV3.ResponsesObject)[status] as OpenAPIV3.ResponseObject).content as Record<\n string,\n OpenAPIV3.MediaTypeObject\n >)[\n mediaType\n ] as OpenAPIV3.MediaTypeObject).examples =\n transformedExamples;\n};\n\nconst extendSwaggerWithMediaTypeExamples = (\n spec: Partial<OpenAPIV3.Document>,\n methodSpec: OpenAPIV3.OperationObject,\n status: string,\n responseSpec: OpenAPIV3.ResponseObject,\n allowedMediaTypes: Record<string, boolean> | undefined,\n pathKey: string,\n transformers: Transformers,\n examples: Record<string, OpenAPIV3.ExampleObject | OpenAPIV3.ReferenceObject>,\n) => {\n const examplesName = toHeaderCase(pathKey.trim().replace(\"/\", \"\"));\n\n Object.keys(responseSpec.content as object).forEach((mediaName) => {\n if (mediaName === jsonMediaType) {\n return;\n }\n\n Object.entries(allowedMediaTypes ?? {}).forEach(([mediaType, allowed]) => {\n if (!allowed) {\n return;\n }\n\n extendComponentExamples(spec, examplesName, examples);\n\n prepareResponseExamples(spec, methodSpec, status, mediaType, transformers, examples);\n });\n });\n};\n\n// eslint-disable-next-line sonarjs/cognitive-complexity\nexport default function extendSwaggerSpec(\n spec: Partial<OpenAPIV3.Document>,\n allowedMediaTypes?: Record<string, boolean>,\n transformers: Transformers = [\n {\n regex: /xml/u,\n transformer: (value: XmlElement | XmlElement[] | undefined) =>\n toXML(value, {\n header: true,\n indent: \" \",\n }),\n },\n {\n regex: /yaml|yml/,\n transformer: (value) => stringify(value, { indent: 2 }),\n },\n ],\n): Partial<OpenAPIV3.Document> {\n if (typeof spec === \"object\" && typeof spec.paths === \"object\") {\n Object.entries(spec.paths).forEach(([pathKey, pathSpec]) => {\n Object.values(pathSpec as OpenAPIV3.OperationObject & OpenAPIV3.PathsObject).forEach((methodSpec) => {\n if (typeof (methodSpec as OpenAPIV3.OperationObject).responses === \"object\") {\n Object.entries((methodSpec as OpenAPIV3.OperationObject).responses).forEach(([status, responseSpec]) => {\n if (typeof (responseSpec as OpenAPIV3.ResponseObject).content === \"object\") {\n const { example, examples } = extendSwaggerWithMediaTypeSchema(\n methodSpec as OpenAPIV3.OperationObject,\n responseSpec as OpenAPIV3.ResponseObject,\n allowedMediaTypes,\n pathKey,\n spec,\n status,\n );\n\n if (example !== undefined) {\n extendSwaggerWithMediaTypeExample(\n methodSpec as OpenAPIV3.OperationObject,\n responseSpec as OpenAPIV3.ResponseObject,\n status,\n allowedMediaTypes,\n transformers,\n example,\n );\n } else if (examples !== undefined) {\n extendSwaggerWithMediaTypeExamples(\n spec,\n methodSpec as OpenAPIV3.OperationObject,\n status,\n responseSpec as OpenAPIV3.ResponseObject,\n allowedMediaTypes,\n pathKey,\n transformers,\n examples,\n );\n }\n }\n });\n }\n });\n });\n }\n\n return spec;\n}\n","import { existsSync, readFileSync } from \"node:fs\";\nimport type { IncomingMessage, ServerResponse } from \"node:http\";\n\nimport type { ModelsToOpenApiParameters, SwaggerModelsConfig } from \"@visulima/crud\";\nimport { modelsToOpenApi } from \"@visulima/crud\";\nimport { join } from \"@visulima/path\";\nimport debug from \"debug\";\n// eslint-disable-next-line no-restricted-imports\nimport merge from \"lodash.merge\";\nimport type { OpenAPIV3 } from \"openapi-types\";\n\nimport yamlTransformer from \"../../serializers/transformer/yaml\";\nimport extendSwaggerSpec from \"../extend-swagger-spec\";\n\nconst swaggerCrudDebug = debug(\"visulima:api-platform:swagger:crud:get-static-properties-swagger\");\n\nconst swaggerHandler = <M extends string, PrismaClient>(\n options: Partial<SwaggerHandlerOptions<M, PrismaClient>> = {},\n): ((request: IncomingMessage, response: ServerResponse) => Promise<void>) => {\n const {\n allowedMediaTypes = {\n \"application/json\": true,\n },\n crud,\n specs,\n swaggerFilePath,\n } = options;\n\n return async <Request extends IncomingMessage, Response extends ServerResponse>(request: Request, response: Response) => {\n const swaggerPath = join(process.cwd(), swaggerFilePath ?? \"swagger/swagger.json\");\n\n if (!existsSync(swaggerPath)) {\n throw new Error(`Swagger file not found at \"${swaggerPath}\".`);\n }\n\n const fileContents = readFileSync(swaggerPath, \"utf8\");\n\n let spec = extendSwaggerSpec(JSON.parse(fileContents) as OpenAPIV3.Document, allowedMediaTypes) as OpenAPIV3.Document;\n let crudSwagger: Partial<OpenAPIV3.Document> = {};\n\n if (crud !== undefined) {\n try {\n const modelsOpenApi = await modelsToOpenApi(crud);\n\n crudSwagger = {\n components: { examples: modelsOpenApi.examples, schemas: modelsOpenApi.schemas },\n paths: modelsOpenApi.paths,\n tags: modelsOpenApi.tags,\n };\n\n crudSwagger = extendSwaggerSpec(crudSwagger, allowedMediaTypes);\n\n swaggerCrudDebug(JSON.stringify(crudSwagger, null, 2));\n\n spec = merge(spec, crudSwagger);\n } catch (error) {\n // eslint-disable-next-line no-console\n console.log(error);\n\n throw new Error(\"Please install @visulima/crud to use the crud swagger generator.\");\n }\n }\n\n if (Array.isArray(specs)) {\n specs.forEach((value) => {\n spec = merge(spec, extendSwaggerSpec(value, allowedMediaTypes));\n });\n }\n\n let data: Buffer | Uint8Array | string;\n\n if (typeof request.headers.accept === \"string\" && /yaml|yml/.test(request.headers.accept)) {\n response.setHeader(\"Content-Type\", request.headers.accept);\n\n data = yamlTransformer(spec);\n } else {\n response.setHeader(\"Content-Type\", \"application/json\");\n\n data = JSON.stringify(spec, null, 2);\n }\n\n response.statusCode = 200;\n response.end(data);\n };\n};\n\nexport interface SwaggerHandlerOptions<M extends string, PrismaClient> {\n allowedMediaTypes: Record<string, boolean>;\n crud: Exclude<ModelsToOpenApiParameters<M, PrismaClient>, \"swagger\"> & {\n swagger?: {\n models?: SwaggerModelsConfig<M>;\n };\n };\n specs?: Partial<OpenAPIV3.Document>[];\n swaggerFilePath: string;\n}\n\nexport default swaggerHandler;\n"]}
1
+ {"version":3,"sources":["../src/serializers/transformer/yaml.ts","../src/utils.ts","../src/swagger/extend-swagger-spec.ts","../src/swagger/api/swagger-handler.ts"],"names":["yamlTransformer","data","stringify","yaml_default","toHeaderCase","string_","c","jsonMediaType","prepareStatusContent","methodSpec","status","mediaType","extendComponentSchemas","spec","schemaName","schema","extendResponseSchema","schemaIsArray","extendSwaggerWithMediaTypeSchema","responseSpec","allowedMediaTypes","pathKey","example","examples","mediaName","contentSpec","allowed","extendSwaggerWithMediaTypeExample","transformers","transformed","regex","transformer","extendComponentExamples","exampleName","prepareResponseExamples","transformedExamples","extendSwaggerWithMediaTypeExamples","examplesName","extendSwaggerSpec","value","toXML","pathSpec","swaggerCrudDebug","debug","swaggerHandler","options","crud","specs","swaggerFilePath","request","response","swaggerPath","join","existsSync","fileContents","readFileSync","crudSwagger","modelsOpenApi","modelsToOpenApi","merge","error","swagger_handler_default"],"mappings":"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","file":"chunk-T4ABIWHW.mjs","sourcesContent":["import { stringify } from \"yaml\";\n\nimport type { Serializer } from \"../types\";\n\nconst yamlTransformer: Serializer = (data) => stringify(data, { indent: 2 });\n\nexport default yamlTransformer;\n","import type { IncomingMessage, ServerResponse } from \"node:http\";\nimport { URL } from \"node:url\";\n\ntype IncomingApiRequest<TApiRequest = IncomingMessage> = TApiRequest & {\n body?: any;\n query?: any;\n};\n\nexport const jsonResponse = (response: ServerResponse, status: number, data?: unknown): void => {\n response.statusCode = status;\n response.setHeader(\"Content-Type\", \"application/json\");\n response.end(data ? JSON.stringify(data) : \"\");\n};\n\nexport const parseBody = async (request: IncomingApiRequest): Promise<any> => {\n if (request.body) {\n return request.body;\n }\n\n const buffers = [];\n\n // eslint-disable-next-line no-restricted-syntax,no-loops/no-loops\n for await (const chunk of request) {\n buffers.push(chunk);\n }\n\n const data = Buffer.concat(buffers).toString();\n\n return data ? JSON.parse(data) : null;\n};\n\nexport const parseQuery = (request: IncomingApiRequest): Record<string, unknown> => {\n if (request.query) {\n return request.query;\n }\n\n if (!request.url) {\n return {};\n }\n\n // Note: Fake protocol is required to parse query string\n const url = new URL(`https://${request.headers.host?.replace(/\\/$/u, \"\")}/${request.url}`);\n\n return Object.fromEntries(url.searchParams.entries());\n};\n\nexport const toHeaderCase = (string_: string): string =>\n string_\n .toLowerCase()\n .replaceAll(/[^\\s\\w]/gu, \" \") // Remove all non-word characters\n .trimEnd() // Remove trailing spaces\n .replaceAll(/\\s+|_/gu, \"-\") // Replace multiple spaces or underline with a single hyphen\n .replaceAll(/\\b\\w/gu, (c) => c.toUpperCase());\n","import type { XmlElement } from \"jstoxml\";\nimport { toXML } from \"jstoxml\";\nimport type { OpenAPIV3 } from \"openapi-types\";\nimport { stringify } from \"yaml\";\n\nimport { toHeaderCase } from \"../utils\";\n\ntype Transformers = { regex: RegExp; transformer: (data: any) => string }[];\n\nconst jsonMediaType = \"application/json\";\n\nconst prepareStatusContent = (methodSpec: OpenAPIV3.OperationObject, status: string, mediaType: string) => {\n if (((methodSpec.responses as unknown as OpenAPIV3.ResponsesObject)[status] as OpenAPIV3.ResponseObject).content === undefined) {\n // eslint-disable-next-line no-param-reassign\n ((methodSpec.responses as unknown as OpenAPIV3.ResponsesObject)[status] as OpenAPIV3.ResponseObject).content = {};\n }\n\n if (((methodSpec.responses as unknown as OpenAPIV3.ResponsesObject)[status] as OpenAPIV3.ResponseObject).content?.[mediaType] === undefined) {\n // prettier-ignore\n // eslint-disable-next-line no-param-reassign\n (((methodSpec.responses as unknown as OpenAPIV3.ResponsesObject)[status] as OpenAPIV3.ResponseObject).content as Record<\n string,\n OpenAPIV3.MediaTypeObject\n >)[\n mediaType\n ] = {} as OpenAPIV3.MediaTypeObject;\n }\n};\n\nconst extendComponentSchemas = (spec: Partial<OpenAPIV3.Document>, schemaName: string, schema: OpenAPIV3.SchemaObject) => {\n if (typeof spec.components !== \"object\") {\n // eslint-disable-next-line no-param-reassign\n spec.components = {};\n }\n\n if (typeof spec.components.schemas !== \"object\") {\n // eslint-disable-next-line no-param-reassign\n spec.components.schemas = {};\n }\n\n if (spec.components.schemas[schemaName] === undefined) {\n // eslint-disable-next-line no-param-reassign\n spec.components.schemas[schemaName] = schema;\n }\n};\n\nconst extendResponseSchema = (methodSpec: OpenAPIV3.OperationObject, status: string, mediaType: string, schemaName: string, schemaIsArray: boolean) => {\n prepareStatusContent(methodSpec, status, mediaType);\n\n if (((methodSpec.responses as unknown as OpenAPIV3.ResponsesObject)[status] as OpenAPIV3.ResponseObject).content?.[mediaType]?.schema === undefined) {\n // prettier-ignore\n // eslint-disable-next-line no-param-reassign\n ((((methodSpec.responses as unknown as OpenAPIV3.ResponsesObject)[status] as OpenAPIV3.ResponseObject).content as Record<\n string,\n OpenAPIV3.MediaTypeObject\n >)[\n mediaType\n ] as OpenAPIV3.MediaTypeObject).schema =\n {} as OpenAPIV3.SchemaObject;\n }\n\n // prettier-ignore\n // eslint-disable-next-line no-param-reassign\n ((((methodSpec.responses as unknown as OpenAPIV3.ResponsesObject)[status] as OpenAPIV3.ResponseObject).content as Record<\n string,\n OpenAPIV3.MediaTypeObject\n >)[\n mediaType\n ] as OpenAPIV3.MediaTypeObject).schema =\n schemaIsArray\n ? {\n items: {\n $ref: `#/components/schemas/${schemaName}`,\n },\n type: \"array\",\n }\n : {\n $ref: `#/components/schemas/${schemaName}`,\n };\n};\n\nconst extendSwaggerWithMediaTypeSchema = (\n methodSpec: OpenAPIV3.OperationObject,\n responseSpec: OpenAPIV3.ResponseObject,\n allowedMediaTypes: Record<string, boolean> | undefined,\n pathKey: string,\n spec: Partial<OpenAPIV3.Document>,\n status: string,\n): {\n example?: any;\n examples?: Record<string, OpenAPIV3.ExampleObject | OpenAPIV3.ReferenceObject>;\n} => {\n let example: any | undefined;\n let examples: Record<string, OpenAPIV3.ExampleObject | OpenAPIV3.ReferenceObject> | undefined;\n\n // eslint-disable-next-line sonarjs/cognitive-complexity\n Object.entries(responseSpec.content as object).forEach(([mediaName, contentSpec]) => {\n if (typeof contentSpec.schema === \"object\") {\n const { schema } = contentSpec;\n\n if (mediaName === jsonMediaType && contentSpec.examples !== undefined) {\n examples = contentSpec.examples;\n } else if (mediaName === jsonMediaType && contentSpec.example !== undefined) {\n example = contentSpec.example;\n }\n\n const schemaIsArray = (schema as OpenAPIV3.SchemaObject).type === \"array\";\n\n Object.entries(allowedMediaTypes ?? {}).forEach(([mediaType, allowed]) => {\n if (!allowed) {\n return;\n }\n\n let schemaName: string;\n\n if (schema?.$ref === undefined) {\n schemaName = `${toHeaderCase(pathKey.trim().replace(\"/\", \"\"))}${mediaType === \"application/ld+json\" ? \".jsonld\" : \"\"}`;\n\n extendComponentSchemas(spec as OpenAPIV3.Document, schemaName, schema as OpenAPIV3.SchemaObject);\n } else {\n schemaName = (schema as OpenAPIV3.ReferenceObject).$ref.replace(\"#/components/schemas/\", \"\");\n }\n\n extendResponseSchema(methodSpec, status, mediaType, schemaName, schemaIsArray);\n });\n }\n });\n\n return { example, examples };\n};\n\nconst extendSwaggerWithMediaTypeExample = (\n methodSpec: OpenAPIV3.OperationObject,\n responseSpec: OpenAPIV3.ResponseObject,\n status: string,\n allowedMediaTypes: Record<string, boolean> | undefined,\n transformers: Transformers,\n example: any,\n) => {\n Object.keys(responseSpec.content as object).forEach((mediaName) => {\n if (mediaName === jsonMediaType) {\n return;\n }\n\n Object.entries(allowedMediaTypes ?? {}).forEach(([mediaType, allowed]) => {\n if (!allowed) {\n return;\n }\n\n prepareStatusContent(methodSpec, status, mediaType);\n\n if (\n ((methodSpec.responses as unknown as OpenAPIV3.ResponsesObject)[status] as OpenAPIV3.ResponseObject).content?.[mediaType]?.example === undefined\n ) {\n // prettier-ignore\n // eslint-disable-next-line no-param-reassign\n ((((methodSpec.responses as unknown as OpenAPIV3.ResponsesObject)[status] as OpenAPIV3.ResponseObject).content as Record<\n string,\n OpenAPIV3.MediaTypeObject\n >)[\n mediaType\n ] as OpenAPIV3.MediaTypeObject).example =\n {};\n }\n\n let transformed = false;\n\n transformers.forEach(({ regex, transformer }) => {\n if (!transformed && regex.test(mediaType)) {\n // prettier-ignore\n // eslint-disable-next-line no-param-reassign\n ((((methodSpec.responses as unknown as OpenAPIV3.ResponsesObject)[status] as OpenAPIV3.ResponseObject).content as Record<\n string,\n OpenAPIV3.MediaTypeObject\n >)[\n mediaType\n ] as OpenAPIV3.MediaTypeObject).example =\n transformer(example);\n\n transformed = true;\n }\n });\n\n if (!transformed) {\n // prettier-ignore\n // eslint-disable-next-line no-param-reassign\n ((((methodSpec.responses as unknown as OpenAPIV3.ResponsesObject)[status] as OpenAPIV3.ResponseObject).content as Record<\n string,\n OpenAPIV3.MediaTypeObject\n >)[\n mediaType\n ] as OpenAPIV3.MediaTypeObject).example =\n example;\n }\n });\n });\n};\n\nconst extendComponentExamples = (\n spec: Partial<OpenAPIV3.Document>,\n exampleName: string,\n examples: Record<string, OpenAPIV3.ExampleObject | OpenAPIV3.ReferenceObject>,\n) => {\n if (typeof spec.components !== \"object\") {\n // eslint-disable-next-line no-param-reassign\n spec.components = {};\n }\n\n if (typeof spec.components.examples !== \"object\") {\n // eslint-disable-next-line no-param-reassign\n spec.components.examples = {};\n }\n\n if (spec.components.examples[exampleName] === undefined && examples[exampleName] !== undefined) {\n // eslint-disable-next-line no-param-reassign\n spec.components.examples[exampleName] = examples[exampleName] as OpenAPIV3.ExampleObject;\n }\n};\n\nconst prepareResponseExamples = (\n spec: Partial<OpenAPIV3.Document>,\n methodSpec: OpenAPIV3.OperationObject,\n status: string,\n mediaType: string,\n transformers: Transformers,\n examples: Record<string, OpenAPIV3.ExampleObject | OpenAPIV3.ReferenceObject>,\n // eslint-disable-next-line sonarjs/cognitive-complexity\n) => {\n prepareStatusContent(methodSpec, status, mediaType);\n\n if (((methodSpec.responses as unknown as OpenAPIV3.ResponsesObject)[status] as OpenAPIV3.ResponseObject).content?.[mediaType]?.examples === undefined) {\n // prettier-ignore\n // eslint-disable-next-line no-param-reassign\n ((((methodSpec.responses as unknown as OpenAPIV3.ResponsesObject)[status] as OpenAPIV3.ResponseObject).content as Record<\n string,\n OpenAPIV3.MediaTypeObject\n >)[\n mediaType\n ] as OpenAPIV3.MediaTypeObject).examples =\n {};\n }\n\n const transformedExamples: Record<string, OpenAPIV3.ExampleObject | OpenAPIV3.ReferenceObject> = {};\n\n Object.entries(examples).forEach(([exampleName, example]) => {\n let transformed = false;\n\n transformers.forEach(({ regex, transformer }) => {\n if (!transformed && regex.test(mediaType)) {\n let data: any = \"\";\n\n if (spec.components?.examples?.[exampleName]) {\n data = (spec.components.examples[exampleName] as OpenAPIV3.ExampleObject).value;\n } else if ((example as OpenAPIV3.ReferenceObject).$ref) {\n data = (\n spec.components?.examples?.[\n (example as OpenAPIV3.ReferenceObject).$ref.replace(\"#/components/examples/\", \"\")\n ] as OpenAPIV3.ExampleObject\n ).value;\n } else if (typeof (example as OpenAPIV3.ExampleObject).value === \"string\") {\n data = (example as OpenAPIV3.ExampleObject).value;\n }\n\n transformedExamples[exampleName] = {\n value: transformer(data),\n };\n\n transformed = true;\n }\n });\n\n if (!transformed) {\n transformedExamples[exampleName] =\n spec.components?.examples?.[exampleName] === undefined\n ? example\n : {\n $ref: `#/components/examples/${exampleName}`,\n };\n }\n });\n\n // prettier-ignore\n // eslint-disable-next-line no-param-reassign\n ((((methodSpec.responses as unknown as OpenAPIV3.ResponsesObject)[status] as OpenAPIV3.ResponseObject).content as Record<\n string,\n OpenAPIV3.MediaTypeObject\n >)[\n mediaType\n ] as OpenAPIV3.MediaTypeObject).examples =\n transformedExamples;\n};\n\nconst extendSwaggerWithMediaTypeExamples = (\n spec: Partial<OpenAPIV3.Document>,\n methodSpec: OpenAPIV3.OperationObject,\n status: string,\n responseSpec: OpenAPIV3.ResponseObject,\n allowedMediaTypes: Record<string, boolean> | undefined,\n pathKey: string,\n transformers: Transformers,\n examples: Record<string, OpenAPIV3.ExampleObject | OpenAPIV3.ReferenceObject>,\n) => {\n const examplesName = toHeaderCase(pathKey.trim().replace(\"/\", \"\"));\n\n Object.keys(responseSpec.content as object).forEach((mediaName) => {\n if (mediaName === jsonMediaType) {\n return;\n }\n\n Object.entries(allowedMediaTypes ?? {}).forEach(([mediaType, allowed]) => {\n if (!allowed) {\n return;\n }\n\n extendComponentExamples(spec, examplesName, examples);\n\n prepareResponseExamples(spec, methodSpec, status, mediaType, transformers, examples);\n });\n });\n};\n\n// eslint-disable-next-line sonarjs/cognitive-complexity\nexport default function extendSwaggerSpec(\n spec: Partial<OpenAPIV3.Document>,\n allowedMediaTypes?: Record<string, boolean>,\n transformers: Transformers = [\n {\n regex: /xml/u,\n transformer: (value: XmlElement | XmlElement[] | undefined) =>\n toXML(value, {\n header: true,\n indent: \" \",\n }),\n },\n {\n regex: /yaml|yml/,\n transformer: (value) => stringify(value, { indent: 2 }),\n },\n ],\n): Partial<OpenAPIV3.Document> {\n if (typeof spec === \"object\" && typeof spec.paths === \"object\") {\n Object.entries(spec.paths).forEach(([pathKey, pathSpec]) => {\n Object.values(pathSpec as OpenAPIV3.OperationObject & OpenAPIV3.PathsObject).forEach((methodSpec) => {\n if (typeof (methodSpec as OpenAPIV3.OperationObject).responses === \"object\") {\n Object.entries((methodSpec as OpenAPIV3.OperationObject).responses).forEach(([status, responseSpec]) => {\n if (typeof (responseSpec as OpenAPIV3.ResponseObject).content === \"object\") {\n const { example, examples } = extendSwaggerWithMediaTypeSchema(\n methodSpec as OpenAPIV3.OperationObject,\n responseSpec as OpenAPIV3.ResponseObject,\n allowedMediaTypes,\n pathKey,\n spec,\n status,\n );\n\n if (example !== undefined) {\n extendSwaggerWithMediaTypeExample(\n methodSpec as OpenAPIV3.OperationObject,\n responseSpec as OpenAPIV3.ResponseObject,\n status,\n allowedMediaTypes,\n transformers,\n example,\n );\n } else if (examples !== undefined) {\n extendSwaggerWithMediaTypeExamples(\n spec,\n methodSpec as OpenAPIV3.OperationObject,\n status,\n responseSpec as OpenAPIV3.ResponseObject,\n allowedMediaTypes,\n pathKey,\n transformers,\n examples,\n );\n }\n }\n });\n }\n });\n });\n }\n\n return spec;\n}\n","import { existsSync, readFileSync } from \"node:fs\";\nimport type { IncomingMessage, ServerResponse } from \"node:http\";\n\nimport type { ModelsToOpenApiParameters, SwaggerModelsConfig } from \"@visulima/crud\";\nimport { modelsToOpenApi } from \"@visulima/crud\";\nimport { join } from \"@visulima/path\";\nimport debug from \"debug\";\n// eslint-disable-next-line no-restricted-imports\nimport merge from \"lodash.merge\";\nimport type { OpenAPIV3 } from \"openapi-types\";\n\nimport yamlTransformer from \"../../serializers/transformer/yaml\";\nimport extendSwaggerSpec from \"../extend-swagger-spec\";\n\nconst swaggerCrudDebug = debug(\"visulima:api-platform:swagger:crud:get-static-properties-swagger\");\n\nconst swaggerHandler = <M extends string, PrismaClient>(\n options: Partial<SwaggerHandlerOptions<M, PrismaClient>> = {},\n): ((request: IncomingMessage, response: ServerResponse) => Promise<void>) => {\n const {\n allowedMediaTypes = {\n \"application/json\": true,\n },\n crud,\n specs,\n swaggerFilePath,\n } = options;\n\n return async <Request extends IncomingMessage, Response extends ServerResponse>(request: Request, response: Response) => {\n const swaggerPath = join(process.cwd(), swaggerFilePath ?? \"swagger/swagger.json\");\n\n if (!existsSync(swaggerPath)) {\n throw new Error(`Swagger file not found at \"${swaggerPath}\".`);\n }\n\n const fileContents = readFileSync(swaggerPath, \"utf8\");\n\n let spec = extendSwaggerSpec(JSON.parse(fileContents) as OpenAPIV3.Document, allowedMediaTypes) as OpenAPIV3.Document;\n let crudSwagger: Partial<OpenAPIV3.Document> = {};\n\n if (crud !== undefined) {\n try {\n const modelsOpenApi = await modelsToOpenApi(crud);\n\n crudSwagger = {\n components: { examples: modelsOpenApi.examples, schemas: modelsOpenApi.schemas },\n paths: modelsOpenApi.paths,\n tags: modelsOpenApi.tags,\n };\n\n crudSwagger = extendSwaggerSpec(crudSwagger, allowedMediaTypes);\n\n swaggerCrudDebug(JSON.stringify(crudSwagger, null, 2));\n\n spec = merge(spec, crudSwagger);\n } catch (error) {\n // eslint-disable-next-line no-console\n console.log(error);\n\n throw new Error(\"Please install @visulima/crud to use the crud swagger generator.\");\n }\n }\n\n if (Array.isArray(specs)) {\n specs.forEach((value) => {\n spec = merge(spec, extendSwaggerSpec(value, allowedMediaTypes));\n });\n }\n\n let data: Buffer | Uint8Array | string;\n\n if (typeof request.headers.accept === \"string\" && /yaml|yml/.test(request.headers.accept)) {\n response.setHeader(\"Content-Type\", request.headers.accept);\n\n data = yamlTransformer(spec);\n } else {\n response.setHeader(\"Content-Type\", \"application/json\");\n\n data = JSON.stringify(spec, null, 2);\n }\n\n response.statusCode = 200;\n response.end(data);\n };\n};\n\nexport interface SwaggerHandlerOptions<M extends string, PrismaClient> {\n allowedMediaTypes: Record<string, boolean>;\n crud: Exclude<ModelsToOpenApiParameters<M, PrismaClient>, \"swagger\"> & {\n swagger?: {\n models?: SwaggerModelsConfig<M>;\n };\n };\n specs?: Partial<OpenAPIV3.Document>[];\n swaggerFilePath: string;\n}\n\nexport default swaggerHandler;\n"]}
@@ -1,2 +1,2 @@
1
- 'use strict';var yaml=require('yaml'),fs=require('fs'),crud=require('@visulima/crud'),path=require('@visulima/path'),H=require('debug'),I=require('lodash.merge'),jstoxml=require('jstoxml');require('url');function _interopDefault(e){return e&&e.__esModule?e:{default:e}}var H__default=/*#__PURE__*/_interopDefault(H);var I__default=/*#__PURE__*/_interopDefault(I);var R=e=>yaml.stringify(e,{indent:2}),A=R;var d=e=>e.toLowerCase().replaceAll(/[^\s\w]/gu," ").trimEnd().replaceAll(/\s+|_/gu,"-").replaceAll(/\b\w/gu,n=>n.toUpperCase());var P="application/json",j=(e,n,s)=>{e.responses[n].content===void 0&&(e.responses[n].content={}),e.responses[n].content?.[s]===void 0&&(e.responses[n].content[s]={});},w=(e,n,s)=>{typeof e.components!="object"&&(e.components={}),typeof e.components.schemas!="object"&&(e.components.schemas={}),e.components.schemas[n]===void 0&&(e.components.schemas[n]=s);},h=(e,n,s,o,f)=>{j(e,n,s),e.responses[n].content?.[s]?.schema===void 0&&(e.responses[n].content[s].schema={}),e.responses[n].content[s].schema=f?{items:{$ref:`#/components/schemas/${o}`},type:"array"}:{$ref:`#/components/schemas/${o}`};},E=(e,n,s,o,f,p)=>{let a,t;return Object.entries(n.content).forEach(([c,r])=>{if(typeof r.schema=="object"){let{schema:i}=r;c===P&&r.examples!==void 0?t=r.examples:c===P&&r.example!==void 0&&(a=r.example);let l=i.type==="array";Object.entries(s??{}).forEach(([O,u])=>{if(!u)return;let g;i?.$ref===void 0?(g=`${d(o.trim().replace("/",""))}${O==="application/ld+json"?".jsonld":""}`,w(f,g,i)):g=i.$ref.replace("#/components/schemas/",""),h(e,p,O,g,l);});}}),{example:a,examples:t}},M=(e,n,s,o,f,p)=>{Object.keys(n.content).forEach(a=>{a!==P&&Object.entries(o??{}).forEach(([t,c])=>{if(!c)return;j(e,s,t),e.responses[s].content?.[t]?.example===void 0&&(e.responses[s].content[t].example={});let r=!1;f.forEach(({regex:i,transformer:l})=>{!r&&i.test(t)&&(e.responses[s].content[t].example=l(p),r=!0);}),r||(e.responses[s].content[t].example=p);});});},T=(e,n,s)=>{typeof e.components!="object"&&(e.components={}),typeof e.components.examples!="object"&&(e.components.examples={}),e.components.examples[n]===void 0&&s[n]!==void 0&&(e.components.examples[n]=s[n]);},C=(e,n,s,o,f,p)=>{j(n,s,o),n.responses[s].content?.[o]?.examples===void 0&&(n.responses[s].content[o].examples={});let a={};Object.entries(p).forEach(([t,c])=>{let r=!1;f.forEach(({regex:i,transformer:l})=>{if(!r&&i.test(o)){let O="";e.components?.examples?.[t]?O=e.components.examples[t].value:c.$ref?O=(e.components?.examples?.[c.$ref.replace("#/components/examples/","")]).value:typeof c.value=="string"&&(O=c.value),a[t]={value:l(O)},r=!0;}}),r||(a[t]=e.components?.examples?.[t]===void 0?c:{$ref:`#/components/examples/${t}`});}),n.responses[s].content[o].examples=a;},k=(e,n,s,o,f,p,a,t)=>{let c=d(p.trim().replace("/",""));Object.keys(o.content).forEach(r=>{r!==P&&Object.entries(f??{}).forEach(([i,l])=>{l&&(T(e,c,t),C(e,n,s,i,a,t));});});};function m(e,n,s=[{regex:/xml/u,transformer:o=>jstoxml.toXML(o,{header:!0,indent:" "})},{regex:/yaml|yml/,transformer:o=>yaml.stringify(o,{indent:2})}]){return typeof e=="object"&&typeof e.paths=="object"&&Object.entries(e.paths).forEach(([o,f])=>{Object.values(f).forEach(p=>{typeof p.responses=="object"&&Object.entries(p.responses).forEach(([a,t])=>{if(typeof t.content=="object"){let{example:c,examples:r}=E(p,t,n,o,e,a);c!==void 0?M(p,t,a,n,s,c):r!==void 0&&k(e,p,a,t,n,o,s,r);}});});}),e}var J=H__default.default("visulima:api-platform:swagger:crud:get-static-properties-swagger"),X=(e={})=>{let{allowedMediaTypes:n={"application/json":!0},crud:s,specs:o,swaggerFilePath:f}=e;return async(p,a)=>{let t=path.join(process.cwd(),f??"swagger/swagger.json");if(!fs.existsSync(t))throw new Error(`Swagger file not found at "${t}".`);let c=fs.readFileSync(t,"utf8"),r=m(JSON.parse(c),n),i={};if(s!==void 0)try{let O=await crud.modelsToOpenApi(s);i={components:{examples:O.examples,schemas:O.schemas},paths:O.paths,tags:O.tags},i=m(i,n),J(JSON.stringify(i,null,2)),r=I__default.default(r,i);}catch(O){throw console.log(O),new Error("Please install @visulima/crud to use the crud swagger generator.")}Array.isArray(o)&&o.forEach(O=>{r=I__default.default(r,m(O,n));});let l;typeof p.headers.accept=="string"&&/yaml|yml/.test(p.headers.accept)?(a.setHeader("Content-Type",p.headers.accept),l=A(r)):(a.setHeader("Content-Type","application/json"),l=JSON.stringify(r,null,2)),a.statusCode=200,a.end(l);}},oe=X;exports.a=d;exports.b=A;exports.c=oe;//# sourceMappingURL=chunk-YG667K32.js.map
1
+ 'use strict';var yaml=require('yaml'),fs=require('fs'),crud=require('@visulima/crud'),path=require('@visulima/path'),H=require('debug'),I=require('lodash.merge'),jstoxml=require('jstoxml');require('url');function _interopDefault(e){return e&&e.__esModule?e:{default:e}}var H__default=/*#__PURE__*/_interopDefault(H);var I__default=/*#__PURE__*/_interopDefault(I);var R=e=>yaml.stringify(e,{indent:2}),A=R;var d=e=>e.toLowerCase().replaceAll(/[^\s\w]/gu," ").trimEnd().replaceAll(/\s+|_/gu,"-").replaceAll(/\b\w/gu,n=>n.toUpperCase());var P="application/json",j=(e,n,s)=>{e.responses[n].content===undefined&&(e.responses[n].content={}),e.responses[n].content?.[s]===undefined&&(e.responses[n].content[s]={});},w=(e,n,s)=>{typeof e.components!="object"&&(e.components={}),typeof e.components.schemas!="object"&&(e.components.schemas={}),e.components.schemas[n]===undefined&&(e.components.schemas[n]=s);},h=(e,n,s,o,f)=>{j(e,n,s),e.responses[n].content?.[s]?.schema===undefined&&(e.responses[n].content[s].schema={}),e.responses[n].content[s].schema=f?{items:{$ref:`#/components/schemas/${o}`},type:"array"}:{$ref:`#/components/schemas/${o}`};},E=(e,n,s,o,f,p)=>{let a,t;return Object.entries(n.content).forEach(([c,r])=>{if(typeof r.schema=="object"){let{schema:i}=r;c===P&&r.examples!==undefined?t=r.examples:c===P&&r.example!==undefined&&(a=r.example);let l=i.type==="array";Object.entries(s??{}).forEach(([O,u])=>{if(!u)return;let g;i?.$ref===undefined?(g=`${d(o.trim().replace("/",""))}${O==="application/ld+json"?".jsonld":""}`,w(f,g,i)):g=i.$ref.replace("#/components/schemas/",""),h(e,p,O,g,l);});}}),{example:a,examples:t}},M=(e,n,s,o,f,p)=>{Object.keys(n.content).forEach(a=>{a!==P&&Object.entries(o??{}).forEach(([t,c])=>{if(!c)return;j(e,s,t),e.responses[s].content?.[t]?.example===undefined&&(e.responses[s].content[t].example={});let r=false;f.forEach(({regex:i,transformer:l})=>{!r&&i.test(t)&&(e.responses[s].content[t].example=l(p),r=true);}),r||(e.responses[s].content[t].example=p);});});},T=(e,n,s)=>{typeof e.components!="object"&&(e.components={}),typeof e.components.examples!="object"&&(e.components.examples={}),e.components.examples[n]===undefined&&s[n]!==undefined&&(e.components.examples[n]=s[n]);},C=(e,n,s,o,f,p)=>{j(n,s,o),n.responses[s].content?.[o]?.examples===undefined&&(n.responses[s].content[o].examples={});let a={};Object.entries(p).forEach(([t,c])=>{let r=false;f.forEach(({regex:i,transformer:l})=>{if(!r&&i.test(o)){let O="";e.components?.examples?.[t]?O=e.components.examples[t].value:c.$ref?O=(e.components?.examples?.[c.$ref.replace("#/components/examples/","")]).value:typeof c.value=="string"&&(O=c.value),a[t]={value:l(O)},r=true;}}),r||(a[t]=e.components?.examples?.[t]===undefined?c:{$ref:`#/components/examples/${t}`});}),n.responses[s].content[o].examples=a;},k=(e,n,s,o,f,p,a,t)=>{let c=d(p.trim().replace("/",""));Object.keys(o.content).forEach(r=>{r!==P&&Object.entries(f??{}).forEach(([i,l])=>{l&&(T(e,c,t),C(e,n,s,i,a,t));});});};function m(e,n,s=[{regex:/xml/u,transformer:o=>jstoxml.toXML(o,{header:true,indent:" "})},{regex:/yaml|yml/,transformer:o=>yaml.stringify(o,{indent:2})}]){return typeof e=="object"&&typeof e.paths=="object"&&Object.entries(e.paths).forEach(([o,f])=>{Object.values(f).forEach(p=>{typeof p.responses=="object"&&Object.entries(p.responses).forEach(([a,t])=>{if(typeof t.content=="object"){let{example:c,examples:r}=E(p,t,n,o,e,a);c!==undefined?M(p,t,a,n,s,c):r!==undefined&&k(e,p,a,t,n,o,s,r);}});});}),e}var J=H__default.default("visulima:api-platform:swagger:crud:get-static-properties-swagger"),X=(e={})=>{let{allowedMediaTypes:n={"application/json":true},crud:s,specs:o,swaggerFilePath:f}=e;return async(p,a)=>{let t=path.join(process.cwd(),f??"swagger/swagger.json");if(!fs.existsSync(t))throw new Error(`Swagger file not found at "${t}".`);let c=fs.readFileSync(t,"utf8"),r=m(JSON.parse(c),n),i={};if(s!==undefined)try{let O=await crud.modelsToOpenApi(s);i={components:{examples:O.examples,schemas:O.schemas},paths:O.paths,tags:O.tags},i=m(i,n),J(JSON.stringify(i,null,2)),r=I__default.default(r,i);}catch(O){throw console.log(O),new Error("Please install @visulima/crud to use the crud swagger generator.")}Array.isArray(o)&&o.forEach(O=>{r=I__default.default(r,m(O,n));});let l;typeof p.headers.accept=="string"&&/yaml|yml/.test(p.headers.accept)?(a.setHeader("Content-Type",p.headers.accept),l=A(r)):(a.setHeader("Content-Type","application/json"),l=JSON.stringify(r,null,2)),a.statusCode=200,a.end(l);}},oe=X;exports.a=d;exports.b=A;exports.c=oe;//# sourceMappingURL=chunk-YG667K32.js.map
2
2
  //# sourceMappingURL=chunk-YG667K32.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/serializers/transformer/yaml.ts","../src/utils.ts","../src/swagger/extend-swagger-spec.ts","../src/swagger/api/swagger-handler.ts"],"names":["yamlTransformer","data","stringify","yaml_default","toHeaderCase","string_","c","jsonMediaType","prepareStatusContent","methodSpec","status","mediaType","extendComponentSchemas","spec","schemaName","schema","extendResponseSchema","schemaIsArray","extendSwaggerWithMediaTypeSchema","responseSpec","allowedMediaTypes","pathKey","example","examples","mediaName","contentSpec","allowed","extendSwaggerWithMediaTypeExample","transformers","transformed","regex","transformer","extendComponentExamples","exampleName","prepareResponseExamples","transformedExamples","extendSwaggerWithMediaTypeExamples","examplesName","extendSwaggerSpec","value","toXML","pathSpec","swaggerCrudDebug","debug","swaggerHandler","options","crud","specs","swaggerFilePath","request","response","swaggerPath","join","existsSync","fileContents","readFileSync","crudSwagger","modelsOpenApi","modelsToOpenApi","merge","error","swagger_handler_default"],"mappings":"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","file":"chunk-YG667K32.js","sourcesContent":["import { stringify } from \"yaml\";\n\nimport type { Serializer } from \"../types\";\n\nconst yamlTransformer: Serializer = (data) => stringify(data, { indent: 2 });\n\nexport default yamlTransformer;\n","import type { IncomingMessage, ServerResponse } from \"node:http\";\nimport { URL } from \"node:url\";\n\ntype IncomingApiRequest<TApiRequest = IncomingMessage> = TApiRequest & {\n body?: any;\n query?: any;\n};\n\nexport const jsonResponse = (response: ServerResponse, status: number, data?: unknown): void => {\n response.statusCode = status;\n response.setHeader(\"Content-Type\", \"application/json\");\n response.end(data ? JSON.stringify(data) : \"\");\n};\n\nexport const parseBody = async (request: IncomingApiRequest): Promise<any> => {\n if (request.body) {\n return request.body;\n }\n\n const buffers = [];\n\n // eslint-disable-next-line no-restricted-syntax,no-loops/no-loops\n for await (const chunk of request) {\n buffers.push(chunk);\n }\n\n const data = Buffer.concat(buffers).toString();\n\n return data ? JSON.parse(data) : null;\n};\n\nexport const parseQuery = (request: IncomingApiRequest): Record<string, unknown> => {\n if (request.query) {\n return request.query;\n }\n\n if (!request.url) {\n return {};\n }\n\n // Note: Fake protocol is required to parse query string\n const url = new URL(`https://${request.headers.host?.replace(/\\/$/u, \"\")}/${request.url}`);\n\n return Object.fromEntries(url.searchParams.entries());\n};\n\nexport const toHeaderCase = (string_: string): string =>\n string_\n .toLowerCase()\n .replaceAll(/[^\\s\\w]/gu, \" \") // Remove all non-word characters\n .trimEnd() // Remove trailing spaces\n .replaceAll(/\\s+|_/gu, \"-\") // Replace multiple spaces or underline with a single hyphen\n .replaceAll(/\\b\\w/gu, (c) => c.toUpperCase());\n","import type { XmlElement } from \"jstoxml\";\nimport { toXML } from \"jstoxml\";\nimport type { OpenAPIV3 } from \"openapi-types\";\nimport { stringify } from \"yaml\";\n\nimport { toHeaderCase } from \"../utils\";\n\ntype Transformers = { regex: RegExp; transformer: (data: any) => string }[];\n\nconst jsonMediaType = \"application/json\";\n\nconst prepareStatusContent = (methodSpec: OpenAPIV3.OperationObject, status: string, mediaType: string) => {\n if (((methodSpec.responses as unknown as OpenAPIV3.ResponsesObject)[status] as OpenAPIV3.ResponseObject).content === undefined) {\n // eslint-disable-next-line no-param-reassign\n ((methodSpec.responses as unknown as OpenAPIV3.ResponsesObject)[status] as OpenAPIV3.ResponseObject).content = {};\n }\n\n if (((methodSpec.responses as unknown as OpenAPIV3.ResponsesObject)[status] as OpenAPIV3.ResponseObject).content?.[mediaType] === undefined) {\n // prettier-ignore\n // eslint-disable-next-line no-param-reassign\n (((methodSpec.responses as unknown as OpenAPIV3.ResponsesObject)[status] as OpenAPIV3.ResponseObject).content as Record<\n string,\n OpenAPIV3.MediaTypeObject\n >)[\n mediaType\n ] = {} as OpenAPIV3.MediaTypeObject;\n }\n};\n\nconst extendComponentSchemas = (spec: Partial<OpenAPIV3.Document>, schemaName: string, schema: OpenAPIV3.SchemaObject) => {\n if (typeof spec.components !== \"object\") {\n // eslint-disable-next-line no-param-reassign\n spec.components = {};\n }\n\n if (typeof spec.components.schemas !== \"object\") {\n // eslint-disable-next-line no-param-reassign\n spec.components.schemas = {};\n }\n\n if (spec.components.schemas[schemaName] === undefined) {\n // eslint-disable-next-line no-param-reassign\n spec.components.schemas[schemaName] = schema;\n }\n};\n\nconst extendResponseSchema = (methodSpec: OpenAPIV3.OperationObject, status: string, mediaType: string, schemaName: string, schemaIsArray: boolean) => {\n prepareStatusContent(methodSpec, status, mediaType);\n\n if (((methodSpec.responses as unknown as OpenAPIV3.ResponsesObject)[status] as OpenAPIV3.ResponseObject).content?.[mediaType]?.schema === undefined) {\n // prettier-ignore\n // eslint-disable-next-line no-param-reassign\n ((((methodSpec.responses as unknown as OpenAPIV3.ResponsesObject)[status] as OpenAPIV3.ResponseObject).content as Record<\n string,\n OpenAPIV3.MediaTypeObject\n >)[\n mediaType\n ] as OpenAPIV3.MediaTypeObject).schema =\n {} as OpenAPIV3.SchemaObject;\n }\n\n // prettier-ignore\n // eslint-disable-next-line no-param-reassign\n ((((methodSpec.responses as unknown as OpenAPIV3.ResponsesObject)[status] as OpenAPIV3.ResponseObject).content as Record<\n string,\n OpenAPIV3.MediaTypeObject\n >)[\n mediaType\n ] as OpenAPIV3.MediaTypeObject).schema =\n schemaIsArray\n ? {\n items: {\n $ref: `#/components/schemas/${schemaName}`,\n },\n type: \"array\",\n }\n : {\n $ref: `#/components/schemas/${schemaName}`,\n };\n};\n\nconst extendSwaggerWithMediaTypeSchema = (\n methodSpec: OpenAPIV3.OperationObject,\n responseSpec: OpenAPIV3.ResponseObject,\n allowedMediaTypes: Record<string, boolean> | undefined,\n pathKey: string,\n spec: Partial<OpenAPIV3.Document>,\n status: string,\n): {\n example?: any;\n examples?: Record<string, OpenAPIV3.ExampleObject | OpenAPIV3.ReferenceObject>;\n} => {\n let example: any | undefined;\n let examples: Record<string, OpenAPIV3.ExampleObject | OpenAPIV3.ReferenceObject> | undefined;\n\n // eslint-disable-next-line sonarjs/cognitive-complexity\n Object.entries(responseSpec.content as object).forEach(([mediaName, contentSpec]) => {\n if (typeof contentSpec.schema === \"object\") {\n const { schema } = contentSpec;\n\n if (mediaName === jsonMediaType && contentSpec.examples !== undefined) {\n examples = contentSpec.examples;\n } else if (mediaName === jsonMediaType && contentSpec.example !== undefined) {\n example = contentSpec.example;\n }\n\n const schemaIsArray = (schema as OpenAPIV3.SchemaObject).type === \"array\";\n\n Object.entries(allowedMediaTypes ?? {}).forEach(([mediaType, allowed]) => {\n if (!allowed) {\n return;\n }\n\n let schemaName: string;\n\n if (schema?.$ref === undefined) {\n schemaName = `${toHeaderCase(pathKey.trim().replace(\"/\", \"\"))}${mediaType === \"application/ld+json\" ? \".jsonld\" : \"\"}`;\n\n extendComponentSchemas(spec as OpenAPIV3.Document, schemaName, schema as OpenAPIV3.SchemaObject);\n } else {\n schemaName = (schema as OpenAPIV3.ReferenceObject).$ref.replace(\"#/components/schemas/\", \"\");\n }\n\n extendResponseSchema(methodSpec, status, mediaType, schemaName, schemaIsArray);\n });\n }\n });\n\n return { example, examples };\n};\n\nconst extendSwaggerWithMediaTypeExample = (\n methodSpec: OpenAPIV3.OperationObject,\n responseSpec: OpenAPIV3.ResponseObject,\n status: string,\n allowedMediaTypes: Record<string, boolean> | undefined,\n transformers: Transformers,\n example: any,\n) => {\n Object.keys(responseSpec.content as object).forEach((mediaName) => {\n if (mediaName === jsonMediaType) {\n return;\n }\n\n Object.entries(allowedMediaTypes ?? {}).forEach(([mediaType, allowed]) => {\n if (!allowed) {\n return;\n }\n\n prepareStatusContent(methodSpec, status, mediaType);\n\n if (\n ((methodSpec.responses as unknown as OpenAPIV3.ResponsesObject)[status] as OpenAPIV3.ResponseObject).content?.[mediaType]?.example === undefined\n ) {\n // prettier-ignore\n // eslint-disable-next-line no-param-reassign\n ((((methodSpec.responses as unknown as OpenAPIV3.ResponsesObject)[status] as OpenAPIV3.ResponseObject).content as Record<\n string,\n OpenAPIV3.MediaTypeObject\n >)[\n mediaType\n ] as OpenAPIV3.MediaTypeObject).example =\n {};\n }\n\n let transformed = false;\n\n transformers.forEach(({ regex, transformer }) => {\n if (!transformed && regex.test(mediaType)) {\n // prettier-ignore\n // eslint-disable-next-line no-param-reassign\n ((((methodSpec.responses as unknown as OpenAPIV3.ResponsesObject)[status] as OpenAPIV3.ResponseObject).content as Record<\n string,\n OpenAPIV3.MediaTypeObject\n >)[\n mediaType\n ] as OpenAPIV3.MediaTypeObject).example =\n transformer(example);\n\n transformed = true;\n }\n });\n\n if (!transformed) {\n // prettier-ignore\n // eslint-disable-next-line no-param-reassign\n ((((methodSpec.responses as unknown as OpenAPIV3.ResponsesObject)[status] as OpenAPIV3.ResponseObject).content as Record<\n string,\n OpenAPIV3.MediaTypeObject\n >)[\n mediaType\n ] as OpenAPIV3.MediaTypeObject).example =\n example;\n }\n });\n });\n};\n\nconst extendComponentExamples = (\n spec: Partial<OpenAPIV3.Document>,\n exampleName: string,\n examples: Record<string, OpenAPIV3.ExampleObject | OpenAPIV3.ReferenceObject>,\n) => {\n if (typeof spec.components !== \"object\") {\n // eslint-disable-next-line no-param-reassign\n spec.components = {};\n }\n\n if (typeof spec.components.examples !== \"object\") {\n // eslint-disable-next-line no-param-reassign\n spec.components.examples = {};\n }\n\n if (spec.components.examples[exampleName] === undefined && examples[exampleName] !== undefined) {\n // eslint-disable-next-line no-param-reassign\n spec.components.examples[exampleName] = examples[exampleName] as OpenAPIV3.ExampleObject;\n }\n};\n\nconst prepareResponseExamples = (\n spec: Partial<OpenAPIV3.Document>,\n methodSpec: OpenAPIV3.OperationObject,\n status: string,\n mediaType: string,\n transformers: Transformers,\n examples: Record<string, OpenAPIV3.ExampleObject | OpenAPIV3.ReferenceObject>,\n // eslint-disable-next-line sonarjs/cognitive-complexity\n) => {\n prepareStatusContent(methodSpec, status, mediaType);\n\n if (((methodSpec.responses as unknown as OpenAPIV3.ResponsesObject)[status] as OpenAPIV3.ResponseObject).content?.[mediaType]?.examples === undefined) {\n // prettier-ignore\n // eslint-disable-next-line no-param-reassign\n ((((methodSpec.responses as unknown as OpenAPIV3.ResponsesObject)[status] as OpenAPIV3.ResponseObject).content as Record<\n string,\n OpenAPIV3.MediaTypeObject\n >)[\n mediaType\n ] as OpenAPIV3.MediaTypeObject).examples =\n {};\n }\n\n const transformedExamples: Record<string, OpenAPIV3.ExampleObject | OpenAPIV3.ReferenceObject> = {};\n\n Object.entries(examples).forEach(([exampleName, example]) => {\n let transformed = false;\n\n transformers.forEach(({ regex, transformer }) => {\n if (!transformed && regex.test(mediaType)) {\n let data: any = \"\";\n\n if (spec.components?.examples?.[exampleName]) {\n data = (spec.components.examples[exampleName] as OpenAPIV3.ExampleObject).value;\n } else if ((example as OpenAPIV3.ReferenceObject).$ref) {\n data = (\n spec.components?.examples?.[\n (example as OpenAPIV3.ReferenceObject).$ref.replace(\"#/components/examples/\", \"\")\n ] as OpenAPIV3.ExampleObject\n ).value;\n } else if (typeof (example as OpenAPIV3.ExampleObject).value === \"string\") {\n data = (example as OpenAPIV3.ExampleObject).value;\n }\n\n transformedExamples[exampleName] = {\n value: transformer(data),\n };\n\n transformed = true;\n }\n });\n\n if (!transformed) {\n transformedExamples[exampleName] =\n spec.components?.examples?.[exampleName] === undefined\n ? example\n : {\n $ref: `#/components/examples/${exampleName}`,\n };\n }\n });\n\n // prettier-ignore\n // eslint-disable-next-line no-param-reassign\n ((((methodSpec.responses as unknown as OpenAPIV3.ResponsesObject)[status] as OpenAPIV3.ResponseObject).content as Record<\n string,\n OpenAPIV3.MediaTypeObject\n >)[\n mediaType\n ] as OpenAPIV3.MediaTypeObject).examples =\n transformedExamples;\n};\n\nconst extendSwaggerWithMediaTypeExamples = (\n spec: Partial<OpenAPIV3.Document>,\n methodSpec: OpenAPIV3.OperationObject,\n status: string,\n responseSpec: OpenAPIV3.ResponseObject,\n allowedMediaTypes: Record<string, boolean> | undefined,\n pathKey: string,\n transformers: Transformers,\n examples: Record<string, OpenAPIV3.ExampleObject | OpenAPIV3.ReferenceObject>,\n) => {\n const examplesName = toHeaderCase(pathKey.trim().replace(\"/\", \"\"));\n\n Object.keys(responseSpec.content as object).forEach((mediaName) => {\n if (mediaName === jsonMediaType) {\n return;\n }\n\n Object.entries(allowedMediaTypes ?? {}).forEach(([mediaType, allowed]) => {\n if (!allowed) {\n return;\n }\n\n extendComponentExamples(spec, examplesName, examples);\n\n prepareResponseExamples(spec, methodSpec, status, mediaType, transformers, examples);\n });\n });\n};\n\n// eslint-disable-next-line sonarjs/cognitive-complexity\nexport default function extendSwaggerSpec(\n spec: Partial<OpenAPIV3.Document>,\n allowedMediaTypes?: Record<string, boolean>,\n transformers: Transformers = [\n {\n regex: /xml/u,\n transformer: (value: XmlElement | XmlElement[] | undefined) =>\n toXML(value, {\n header: true,\n indent: \" \",\n }),\n },\n {\n regex: /yaml|yml/,\n transformer: (value) => stringify(value, { indent: 2 }),\n },\n ],\n): Partial<OpenAPIV3.Document> {\n if (typeof spec === \"object\" && typeof spec.paths === \"object\") {\n Object.entries(spec.paths).forEach(([pathKey, pathSpec]) => {\n Object.values(pathSpec as OpenAPIV3.OperationObject & OpenAPIV3.PathsObject).forEach((methodSpec) => {\n if (typeof (methodSpec as OpenAPIV3.OperationObject).responses === \"object\") {\n Object.entries((methodSpec as OpenAPIV3.OperationObject).responses).forEach(([status, responseSpec]) => {\n if (typeof (responseSpec as OpenAPIV3.ResponseObject).content === \"object\") {\n const { example, examples } = extendSwaggerWithMediaTypeSchema(\n methodSpec as OpenAPIV3.OperationObject,\n responseSpec as OpenAPIV3.ResponseObject,\n allowedMediaTypes,\n pathKey,\n spec,\n status,\n );\n\n if (example !== undefined) {\n extendSwaggerWithMediaTypeExample(\n methodSpec as OpenAPIV3.OperationObject,\n responseSpec as OpenAPIV3.ResponseObject,\n status,\n allowedMediaTypes,\n transformers,\n example,\n );\n } else if (examples !== undefined) {\n extendSwaggerWithMediaTypeExamples(\n spec,\n methodSpec as OpenAPIV3.OperationObject,\n status,\n responseSpec as OpenAPIV3.ResponseObject,\n allowedMediaTypes,\n pathKey,\n transformers,\n examples,\n );\n }\n }\n });\n }\n });\n });\n }\n\n return spec;\n}\n","import { existsSync, readFileSync } from \"node:fs\";\nimport type { IncomingMessage, ServerResponse } from \"node:http\";\n\nimport type { ModelsToOpenApiParameters, SwaggerModelsConfig } from \"@visulima/crud\";\nimport { modelsToOpenApi } from \"@visulima/crud\";\nimport { join } from \"@visulima/path\";\nimport debug from \"debug\";\n// eslint-disable-next-line no-restricted-imports\nimport merge from \"lodash.merge\";\nimport type { OpenAPIV3 } from \"openapi-types\";\n\nimport yamlTransformer from \"../../serializers/transformer/yaml\";\nimport extendSwaggerSpec from \"../extend-swagger-spec\";\n\nconst swaggerCrudDebug = debug(\"visulima:api-platform:swagger:crud:get-static-properties-swagger\");\n\nconst swaggerHandler = <M extends string, PrismaClient>(\n options: Partial<SwaggerHandlerOptions<M, PrismaClient>> = {},\n): ((request: IncomingMessage, response: ServerResponse) => Promise<void>) => {\n const {\n allowedMediaTypes = {\n \"application/json\": true,\n },\n crud,\n specs,\n swaggerFilePath,\n } = options;\n\n return async <Request extends IncomingMessage, Response extends ServerResponse>(request: Request, response: Response) => {\n const swaggerPath = join(process.cwd(), swaggerFilePath ?? \"swagger/swagger.json\");\n\n if (!existsSync(swaggerPath)) {\n throw new Error(`Swagger file not found at \"${swaggerPath}\".`);\n }\n\n const fileContents = readFileSync(swaggerPath, \"utf8\");\n\n let spec = extendSwaggerSpec(JSON.parse(fileContents) as OpenAPIV3.Document, allowedMediaTypes) as OpenAPIV3.Document;\n let crudSwagger: Partial<OpenAPIV3.Document> = {};\n\n if (crud !== undefined) {\n try {\n const modelsOpenApi = await modelsToOpenApi(crud);\n\n crudSwagger = {\n components: { examples: modelsOpenApi.examples, schemas: modelsOpenApi.schemas },\n paths: modelsOpenApi.paths,\n tags: modelsOpenApi.tags,\n };\n\n crudSwagger = extendSwaggerSpec(crudSwagger, allowedMediaTypes);\n\n swaggerCrudDebug(JSON.stringify(crudSwagger, null, 2));\n\n spec = merge(spec, crudSwagger);\n } catch (error) {\n // eslint-disable-next-line no-console\n console.log(error);\n\n throw new Error(\"Please install @visulima/crud to use the crud swagger generator.\");\n }\n }\n\n if (Array.isArray(specs)) {\n specs.forEach((value) => {\n spec = merge(spec, extendSwaggerSpec(value, allowedMediaTypes));\n });\n }\n\n let data: Buffer | Uint8Array | string;\n\n if (typeof request.headers.accept === \"string\" && /yaml|yml/.test(request.headers.accept)) {\n response.setHeader(\"Content-Type\", request.headers.accept);\n\n data = yamlTransformer(spec);\n } else {\n response.setHeader(\"Content-Type\", \"application/json\");\n\n data = JSON.stringify(spec, null, 2);\n }\n\n response.statusCode = 200;\n response.end(data);\n };\n};\n\nexport interface SwaggerHandlerOptions<M extends string, PrismaClient> {\n allowedMediaTypes: Record<string, boolean>;\n crud: Exclude<ModelsToOpenApiParameters<M, PrismaClient>, \"swagger\"> & {\n swagger?: {\n models?: SwaggerModelsConfig<M>;\n };\n };\n specs?: Partial<OpenAPIV3.Document>[];\n swaggerFilePath: string;\n}\n\nexport default swaggerHandler;\n"]}
1
+ {"version":3,"sources":["../src/serializers/transformer/yaml.ts","../src/utils.ts","../src/swagger/extend-swagger-spec.ts","../src/swagger/api/swagger-handler.ts"],"names":["yamlTransformer","data","stringify","yaml_default","toHeaderCase","string_","c","jsonMediaType","prepareStatusContent","methodSpec","status","mediaType","extendComponentSchemas","spec","schemaName","schema","extendResponseSchema","schemaIsArray","extendSwaggerWithMediaTypeSchema","responseSpec","allowedMediaTypes","pathKey","example","examples","mediaName","contentSpec","allowed","extendSwaggerWithMediaTypeExample","transformers","transformed","regex","transformer","extendComponentExamples","exampleName","prepareResponseExamples","transformedExamples","extendSwaggerWithMediaTypeExamples","examplesName","extendSwaggerSpec","value","toXML","pathSpec","swaggerCrudDebug","debug","swaggerHandler","options","crud","specs","swaggerFilePath","request","response","swaggerPath","join","existsSync","fileContents","readFileSync","crudSwagger","modelsOpenApi","modelsToOpenApi","merge","error","swagger_handler_default"],"mappings":"2WAIA,IAAMA,CAA+BC,CAAAA,CAAAA,EAASC,cAAUD,CAAAA,CAAAA,CAAM,CAAE,MAAA,CAAQ,CAAE,CAAC,CAEpEE,CAAAA,CAAAA,CAAQH,ECwCR,IAAMI,CAAgBC,CAAAA,CAAAA,EACzBA,CACK,CAAA,WAAA,EACA,CAAA,UAAA,CAAW,WAAa,CAAA,GAAG,CAC3B,CAAA,OAAA,EACA,CAAA,UAAA,CAAW,SAAW,CAAA,GAAG,CACzB,CAAA,UAAA,CAAW,QAAWC,CAAAA,CAAAA,EAAMA,CAAE,CAAA,WAAA,EAAa,EC3CpD,IAAMC,CAAAA,CAAgB,kBAEhBC,CAAAA,CAAAA,CAAuB,CAACC,CAAAA,CAAuCC,CAAgBC,CAAAA,CAAAA,GAAsB,CACjGF,CAAAA,CAAW,SAAmDC,CAAAA,CAAM,CAA+B,CAAA,OAAA,GAAY,SAE/GD,GAAAA,CAAAA,CAAW,SAAmDC,CAAAA,CAAM,CAA+B,CAAA,OAAA,CAAU,EAAC,CAAA,CAG9GD,CAAW,CAAA,SAAA,CAAmDC,CAAM,CAAA,CAA+B,OAAUC,GAAAA,CAAS,CAAM,GAAA,SAAA,GAG3HF,CAAW,CAAA,SAAA,CAAmDC,CAAM,CAAA,CAA+B,OAIlGC,CAAAA,CACJ,CAAI,CAAA,EAEZ,EAAA,CAAA,CAEMC,CAAyB,CAAA,CAACC,CAAmCC,CAAAA,CAAAA,CAAoBC,CAAmC,GAAA,CAClH,OAAOF,CAAAA,CAAK,UAAe,EAAA,QAAA,GAE3BA,CAAK,CAAA,UAAA,CAAa,EAAC,CAAA,CAGnB,OAAOA,CAAAA,CAAK,UAAW,CAAA,OAAA,EAAY,QAEnCA,GAAAA,CAAAA,CAAK,UAAW,CAAA,OAAA,CAAU,EAAC,CAAA,CAG3BA,CAAK,CAAA,UAAA,CAAW,OAAQC,CAAAA,CAAU,CAAM,GAAA,SAAA,GAExCD,CAAK,CAAA,UAAA,CAAW,OAAQC,CAAAA,CAAU,CAAIC,CAAAA,CAAAA,EAE9C,CAEMC,CAAAA,CAAAA,CAAuB,CAACP,CAAAA,CAAuCC,CAAgBC,CAAAA,CAAAA,CAAmBG,CAAoBG,CAAAA,CAAAA,GAA2B,CACnJT,CAAAA,CAAqBC,CAAYC,CAAAA,CAAAA,CAAQC,CAAS,CAAA,CAE5CF,CAAW,CAAA,SAAA,CAAmDC,CAAM,CAAA,CAA+B,OAAUC,GAAAA,CAAS,CAAG,EAAA,MAAA,GAAW,SAGlIF,GAAAA,CAAAA,CAAW,SAAmDC,CAAAA,CAAM,CAA+B,CAAA,OAAA,CAI/FC,CACJ,CAAA,CAAgC,MAChC,CAAA,EAKJF,CAAAA,CAAAA,CAAAA,CAAW,SAAmDC,CAAAA,CAAM,CAA+B,CAAA,OAAA,CAI/FC,CACJ,CAAA,CAAgC,MAChCM,CAAAA,CAAAA,CACM,CACI,KAAA,CAAO,CACH,IAAA,CAAM,CAAwBH,qBAAAA,EAAAA,CAAU,CAC5C,CAAA,CAAA,CACA,IAAM,CAAA,OACV,CACA,CAAA,CACI,IAAM,CAAA,CAAA,qBAAA,EAAwBA,CAAU,CAAA,CAC5C,EACd,CAAA,CAEMI,CAAmC,CAAA,CACrCT,CACAU,CAAAA,CAAAA,CACAC,CACAC,CAAAA,CAAAA,CACAR,CACAH,CAAAA,CAAAA,GAIC,CACD,IAAIY,CACAC,CAAAA,CAAAA,CAGJ,OAAO,MAAA,CAAA,OAAA,CAAQJ,CAAa,CAAA,OAAiB,CAAE,CAAA,OAAA,CAAQ,CAAC,CAACK,CAAWC,CAAAA,CAAW,CAAM,GAAA,CACjF,GAAI,OAAOA,CAAY,CAAA,MAAA,EAAW,QAAU,CAAA,CACxC,GAAM,CAAE,MAAAV,CAAAA,CAAO,CAAIU,CAAAA,CAAAA,CAEfD,CAAcjB,GAAAA,CAAAA,EAAiBkB,CAAY,CAAA,QAAA,GAAa,SACxDF,CAAAA,CAAAA,CAAWE,CAAY,CAAA,QAAA,CAChBD,CAAcjB,GAAAA,CAAAA,EAAiBkB,CAAY,CAAA,OAAA,GAAY,SAC9DH,GAAAA,CAAAA,CAAUG,CAAY,CAAA,OAAA,CAAA,CAG1B,IAAMR,CAAAA,CAAiBF,CAAkC,CAAA,IAAA,GAAS,OAElE,CAAA,MAAA,CAAO,OAAQK,CAAAA,CAAAA,EAAqB,EAAE,CAAE,CAAA,OAAA,CAAQ,CAAC,CAACT,CAAWe,CAAAA,CAAO,CAAM,GAAA,CACtE,GAAI,CAACA,CACD,CAAA,OAGJ,IAAIZ,CAAAA,CAEAC,CAAQ,EAAA,IAAA,GAAS,SACjBD,EAAAA,CAAAA,CAAa,CAAGV,EAAAA,CAAAA,CAAaiB,CAAQ,CAAA,IAAA,EAAO,CAAA,OAAA,CAAQ,GAAK,CAAA,EAAE,CAAC,CAAC,CAAGV,EAAAA,CAAAA,GAAc,qBAAwB,CAAA,SAAA,CAAY,EAAE,CAAA,CAAA,CAEpHC,CAAuBC,CAAAA,CAAAA,CAA4BC,CAAYC,CAAAA,CAAgC,CAE/FD,EAAAA,CAAAA,CAAcC,CAAqC,CAAA,IAAA,CAAK,OAAQ,CAAA,uBAAA,CAAyB,EAAE,CAAA,CAG/FC,CAAqBP,CAAAA,CAAAA,CAAYC,CAAQC,CAAAA,CAAAA,CAAWG,CAAYG,CAAAA,CAAa,EACjF,CAAC,EACL,CACJ,CAAC,CAAA,CAEM,CAAE,OAAA,CAAAK,CAAS,CAAA,QAAA,CAAAC,CAAS,CAC/B,CAEMI,CAAAA,CAAAA,CAAoC,CACtClB,CAAAA,CACAU,CACAT,CAAAA,CAAAA,CACAU,CACAQ,CAAAA,CAAAA,CACAN,CACC,GAAA,CACD,MAAO,CAAA,IAAA,CAAKH,CAAa,CAAA,OAAiB,CAAE,CAAA,OAAA,CAASK,CAAc,EAAA,CAC3DA,CAAcjB,GAAAA,CAAAA,EAIlB,MAAO,CAAA,OAAA,CAAQa,CAAqB,EAAA,EAAE,CAAA,CAAE,OAAQ,CAAA,CAAC,CAACT,CAAAA,CAAWe,CAAO,CAAA,GAAM,CACtE,GAAI,CAACA,CAAAA,CACD,OAGJlB,CAAAA,CAAqBC,CAAYC,CAAAA,CAAAA,CAAQC,CAAS,CAAA,CAG5CF,CAAW,CAAA,SAAA,CAAmDC,CAAM,CAAA,CAA+B,OAAUC,GAAAA,CAAS,CAAG,EAAA,OAAA,GAAY,SAInIF,GAAAA,CAAAA,CAAW,SAAmDC,CAAAA,CAAM,CAA+B,CAAA,OAAA,CAI/FC,CACJ,CAAA,CAAgC,OAChC,CAAA,EAGR,CAAA,CAAA,IAAIkB,CAAc,CAAA,KAAA,CAElBD,CAAa,CAAA,OAAA,CAAQ,CAAC,CAAE,KAAAE,CAAAA,CAAAA,CAAO,WAAAC,CAAAA,CAAY,CAAM,GAAA,CACzC,CAACF,CAAAA,EAAeC,CAAM,CAAA,IAAA,CAAKnB,CAAS,CAAA,GAGhCF,CAAW,CAAA,SAAA,CAAmDC,CAAM,CAAA,CAA+B,OAI/FC,CAAAA,CACJ,CAAgC,CAAA,OAAA,CAChCoB,CAAYT,CAAAA,CAAO,CAEvBO,CAAAA,CAAAA,CAAc,IAEtB,EAAA,CAAC,CAEIA,CAAAA,CAAAA,GAGGpB,CAAW,CAAA,SAAA,CAAmDC,CAAM,CAAA,CAA+B,OAI/FC,CAAAA,CACJ,CAAgC,CAAA,OAAA,CAChCW,CAEZ,EAAA,CAAC,EACL,CAAC,EACL,CAAA,CAEMU,CAA0B,CAAA,CAC5BnB,CACAoB,CAAAA,CAAAA,CACAV,CACC,GAAA,CACG,OAAOV,CAAAA,CAAK,UAAe,EAAA,QAAA,GAE3BA,CAAK,CAAA,UAAA,CAAa,EAAC,CAAA,CAGnB,OAAOA,CAAAA,CAAK,UAAW,CAAA,QAAA,EAAa,QAEpCA,GAAAA,CAAAA,CAAK,UAAW,CAAA,QAAA,CAAW,EAAC,CAAA,CAG5BA,CAAK,CAAA,UAAA,CAAW,QAASoB,CAAAA,CAAW,CAAM,GAAA,SAAA,EAAaV,CAASU,CAAAA,CAAW,CAAM,GAAA,SAAA,GAEjFpB,CAAK,CAAA,UAAA,CAAW,QAASoB,CAAAA,CAAW,CAAIV,CAAAA,CAAAA,CAASU,CAAW,CAAA,EAEpE,CAEMC,CAAAA,CAAAA,CAA0B,CAC5BrB,CAAAA,CACAJ,CACAC,CAAAA,CAAAA,CACAC,CACAiB,CAAAA,CAAAA,CACAL,CAEC,GAAA,CACDf,CAAqBC,CAAAA,CAAAA,CAAYC,CAAQC,CAAAA,CAAS,CAE5CF,CAAAA,CAAAA,CAAW,SAAmDC,CAAAA,CAAM,CAA+B,CAAA,OAAA,GAAUC,CAAS,CAAA,EAAG,QAAa,GAAA,SAAA,GAGpIF,CAAW,CAAA,SAAA,CAAmDC,CAAM,CAAA,CAA+B,OAI/FC,CAAAA,CACJ,CAAgC,CAAA,QAAA,CAChC,EAAC,CAAA,CAGT,IAAMwB,CAAAA,CAA2F,EAAC,CAElG,MAAO,CAAA,OAAA,CAAQZ,CAAQ,CAAA,CAAE,OAAQ,CAAA,CAAC,CAACU,CAAAA,CAAaX,CAAO,CAAA,GAAM,CACzD,IAAIO,CAAc,CAAA,KAAA,CAElBD,CAAa,CAAA,OAAA,CAAQ,CAAC,CAAE,KAAAE,CAAAA,CAAAA,CAAO,WAAAC,CAAAA,CAAY,CAAM,GAAA,CAC7C,GAAI,CAACF,CAAeC,EAAAA,CAAAA,CAAM,IAAKnB,CAAAA,CAAS,CAAG,CAAA,CACvC,IAAIV,CAAAA,CAAY,EAEZY,CAAAA,CAAAA,CAAK,UAAY,EAAA,QAAA,GAAWoB,CAAW,CAAA,CACvChC,CAAQY,CAAAA,CAAAA,CAAK,UAAW,CAAA,QAAA,CAASoB,CAAW,CAAA,CAA8B,KAClEX,CAAAA,CAAAA,CAAsC,IAC9CrB,CAAAA,CAAAA,CAAAA,CACIY,CAAK,CAAA,UAAA,EAAY,QACZS,GAAAA,CAAAA,CAAsC,IAAK,CAAA,OAAA,CAAQ,wBAA0B,CAAA,EAAE,CACpF,CAAA,EACF,KACK,CAAA,OAAQA,CAAoC,CAAA,KAAA,EAAU,QAC7DrB,GAAAA,CAAAA,CAAQqB,CAAoC,CAAA,KAAA,CAAA,CAGhDa,CAAoBF,CAAAA,CAAW,CAAI,CAAA,CAC/B,KAAOF,CAAAA,CAAAA,CAAY9B,CAAI,CAC3B,CAEA4B,CAAAA,CAAAA,CAAc,KAClB,CACJ,CAAC,CAAA,CAEIA,CACDM,GAAAA,CAAAA,CAAoBF,CAAW,CAAA,CAC3BpB,CAAK,CAAA,UAAA,EAAY,QAAWoB,GAAAA,CAAW,CAAM,GAAA,SAAA,CACvCX,CACA,CAAA,CACI,IAAM,CAAA,CAAA,sBAAA,EAAyBW,CAAW,CAAA,CAC9C,CAElB,EAAA,CAAC,CAIGxB,CAAAA,CAAAA,CAAW,SAAmDC,CAAAA,CAAM,CAA+B,CAAA,OAAA,CAI/FC,CACJ,CAAA,CAAgC,QAChCwB,CAAAA,EACR,CAEMC,CAAAA,CAAAA,CAAqC,CACvCvB,CAAAA,CACAJ,CACAC,CAAAA,CAAAA,CACAS,CACAC,CAAAA,CAAAA,CACAC,CACAO,CAAAA,CAAAA,CACAL,CACC,GAAA,CACD,IAAMc,CAAAA,CAAejC,CAAaiB,CAAAA,CAAAA,CAAQ,IAAK,EAAA,CAAE,OAAQ,CAAA,GAAA,CAAK,EAAE,CAAC,CAEjE,CAAA,MAAA,CAAO,IAAKF,CAAAA,CAAAA,CAAa,OAAiB,CAAA,CAAE,OAASK,CAAAA,CAAAA,EAAc,CAC3DA,CAAAA,GAAcjB,CAIlB,EAAA,MAAA,CAAO,OAAQa,CAAAA,CAAAA,EAAqB,EAAE,CAAE,CAAA,OAAA,CAAQ,CAAC,CAACT,CAAWe,CAAAA,CAAO,CAAM,GAAA,CACjEA,CAILM,GAAAA,CAAAA,CAAwBnB,CAAMwB,CAAAA,CAAAA,CAAcd,CAAQ,CAAA,CAEpDW,CAAwBrB,CAAAA,CAAAA,CAAMJ,CAAYC,CAAAA,CAAAA,CAAQC,CAAWiB,CAAAA,CAAAA,CAAcL,CAAQ,CAAA,EACvF,CAAC,EACL,CAAC,EACL,CAGe,CAAA,SAARe,CACHzB,CAAAA,CAAAA,CACAO,CACAQ,CAAAA,CAAAA,CAA6B,CACzB,CACI,KAAO,CAAA,MAAA,CACP,WAAcW,CAAAA,CAAAA,EACVC,aAAMD,CAAAA,CAAAA,CAAO,CACT,MAAA,CAAQ,IACR,CAAA,MAAA,CAAQ,IACZ,CAAC,CACT,CAAA,CACA,CACI,KAAA,CAAO,UACP,CAAA,WAAA,CAAcA,CAAUrC,EAAAA,cAAAA,CAAUqC,CAAO,CAAA,CAAE,MAAQ,CAAA,CAAE,CAAC,CAC1D,CACJ,CAAA,CAC2B,CAC3B,OAAI,OAAO1B,CAAAA,EAAS,QAAY,EAAA,OAAOA,CAAK,CAAA,KAAA,EAAU,QAClD,EAAA,MAAA,CAAO,OAAQA,CAAAA,CAAAA,CAAK,KAAK,CAAA,CAAE,OAAQ,CAAA,CAAC,CAACQ,CAAAA,CAASoB,CAAQ,CAAA,GAAM,CACxD,MAAA,CAAO,MAAOA,CAAAA,CAA6D,CAAE,CAAA,OAAA,CAAShC,CAAe,EAAA,CAC7F,OAAQA,CAAAA,CAAyC,SAAc,EAAA,QAAA,EAC/D,MAAO,CAAA,OAAA,CAASA,CAAyC,CAAA,SAAS,CAAE,CAAA,OAAA,CAAQ,CAAC,CAACC,CAAQS,CAAAA,CAAY,CAAM,GAAA,CACpG,GAAI,OAAQA,CAA0C,CAAA,OAAA,EAAY,QAAU,CAAA,CACxE,GAAM,CAAE,OAAAG,CAAAA,CAAAA,CAAS,QAAAC,CAAAA,CAAS,CAAIL,CAAAA,CAAAA,CAC1BT,CACAU,CAAAA,CAAAA,CACAC,CACAC,CAAAA,CAAAA,CACAR,CACAH,CAAAA,CACJ,CAEIY,CAAAA,CAAAA,GAAY,SACZK,CAAAA,CAAAA,CACIlB,CACAU,CAAAA,CAAAA,CACAT,CACAU,CAAAA,CAAAA,CACAQ,CACAN,CAAAA,CACJ,CACOC,CAAAA,CAAAA,GAAa,SACpBa,EAAAA,CAAAA,CACIvB,CACAJ,CAAAA,CAAAA,CACAC,CACAS,CAAAA,CAAAA,CACAC,CACAC,CAAAA,CAAAA,CACAO,CACAL,CAAAA,CACJ,EAER,CACJ,CAAC,EAET,CAAC,EACL,CAAC,CAAA,CAGEV,CACX,CClXM6B,IAAAA,CAAAA,CAAmBC,kBAAM,CAAA,kEAAkE,CAE3FC,CAAAA,CAAAA,CAAiB,CACnBC,CAAAA,CAA2D,EAAC,GACc,CAC1E,GAAM,CACF,iBAAA,CAAAzB,CAAoB,CAAA,CAChB,kBAAoB,CAAA,IACxB,CACA,CAAA,IAAA,CAAA0B,CACA,CAAA,KAAA,CAAAC,CACA,CAAA,eAAA,CAAAC,CACJ,CAAA,CAAIH,CAEJ,CAAA,OAAgFI,MAAAA,CAAAA,CAAkBC,CAAuB,GAAA,CACrH,IAAMC,CAAAA,CAAcC,SAAK,CAAA,OAAA,CAAQ,GAAI,EAAA,CAAGJ,CAAmB,EAAA,sBAAsB,CAEjF,CAAA,GAAI,CAACK,aAAAA,CAAWF,CAAW,CAAA,CACvB,MAAM,IAAI,KAAM,CAAA,CAAA,2BAAA,EAA8BA,CAAW,CAAA,EAAA,CAAI,CAGjE,CAAA,IAAMG,CAAeC,CAAAA,eAAAA,CAAaJ,CAAa,CAAA,MAAM,CAEjDtC,CAAAA,CAAAA,CAAOyB,CAAkB,CAAA,IAAA,CAAK,KAAMgB,CAAAA,CAAY,CAAyBlC,CAAAA,CAAiB,CAC1FoC,CAAAA,CAAAA,CAA2C,EAAC,CAEhD,GAAIV,CAAAA,GAAS,SACT,CAAA,GAAI,CACA,IAAMW,CAAgB,CAAA,MAAMC,oBAAgBZ,CAAAA,CAAI,CAEhDU,CAAAA,CAAAA,CAAc,CACV,UAAA,CAAY,CAAE,QAAA,CAAUC,CAAc,CAAA,QAAA,CAAU,OAASA,CAAAA,CAAAA,CAAc,OAAQ,CAAA,CAC/E,KAAOA,CAAAA,CAAAA,CAAc,KACrB,CAAA,IAAA,CAAMA,CAAc,CAAA,IACxB,CAEAD,CAAAA,CAAAA,CAAclB,CAAkBkB,CAAAA,CAAAA,CAAapC,CAAiB,CAAA,CAE9DsB,CAAiB,CAAA,IAAA,CAAK,SAAUc,CAAAA,CAAAA,CAAa,IAAM,CAAA,CAAC,CAAC,CAAA,CAErD3C,CAAO8C,CAAAA,kBAAAA,CAAM9C,CAAM2C,CAAAA,CAAW,EAClC,CAAA,MAASI,CAAO,CAAA,CAEZ,MAAQ,OAAA,CAAA,GAAA,CAAIA,CAAK,CAAA,CAEX,IAAI,KAAA,CAAM,kEAAkE,CACtF,CAGA,KAAA,CAAM,OAAQb,CAAAA,CAAK,CACnBA,EAAAA,CAAAA,CAAM,OAASR,CAAAA,CAAAA,EAAU,CACrB1B,CAAAA,CAAO8C,kBAAM9C,CAAAA,CAAAA,CAAMyB,CAAkBC,CAAAA,CAAAA,CAAOnB,CAAiB,CAAC,EAClE,CAAC,CAGL,CAAA,IAAInB,CAEA,CAAA,OAAOgD,CAAQ,CAAA,OAAA,CAAQ,MAAW,EAAA,QAAA,EAAY,UAAW,CAAA,IAAA,CAAKA,CAAQ,CAAA,OAAA,CAAQ,MAAM,CAAA,EACpFC,CAAS,CAAA,SAAA,CAAU,cAAgBD,CAAAA,CAAAA,CAAQ,OAAQ,CAAA,MAAM,CAEzDhD,CAAAA,CAAAA,CAAOE,CAAgBU,CAAAA,CAAI,CAE3BqC,GAAAA,CAAAA,CAAS,SAAU,CAAA,cAAA,CAAgB,kBAAkB,CAAA,CAErDjD,CAAO,CAAA,IAAA,CAAK,SAAUY,CAAAA,CAAAA,CAAM,IAAM,CAAA,CAAC,CAGvCqC,CAAAA,CAAAA,CAAAA,CAAS,UAAa,CAAA,GAAA,CACtBA,CAAS,CAAA,GAAA,CAAIjD,CAAI,EACrB,CACJ,CAAA,CAaO4D,EAAQjB,CAAAA","file":"chunk-YG667K32.js","sourcesContent":["import { stringify } from \"yaml\";\n\nimport type { Serializer } from \"../types\";\n\nconst yamlTransformer: Serializer = (data) => stringify(data, { indent: 2 });\n\nexport default yamlTransformer;\n","import type { IncomingMessage, ServerResponse } from \"node:http\";\nimport { URL } from \"node:url\";\n\ntype IncomingApiRequest<TApiRequest = IncomingMessage> = TApiRequest & {\n body?: any;\n query?: any;\n};\n\nexport const jsonResponse = (response: ServerResponse, status: number, data?: unknown): void => {\n response.statusCode = status;\n response.setHeader(\"Content-Type\", \"application/json\");\n response.end(data ? JSON.stringify(data) : \"\");\n};\n\nexport const parseBody = async (request: IncomingApiRequest): Promise<any> => {\n if (request.body) {\n return request.body;\n }\n\n const buffers = [];\n\n // eslint-disable-next-line no-restricted-syntax,no-loops/no-loops\n for await (const chunk of request) {\n buffers.push(chunk);\n }\n\n const data = Buffer.concat(buffers).toString();\n\n return data ? JSON.parse(data) : null;\n};\n\nexport const parseQuery = (request: IncomingApiRequest): Record<string, unknown> => {\n if (request.query) {\n return request.query;\n }\n\n if (!request.url) {\n return {};\n }\n\n // Note: Fake protocol is required to parse query string\n const url = new URL(`https://${request.headers.host?.replace(/\\/$/u, \"\")}/${request.url}`);\n\n return Object.fromEntries(url.searchParams.entries());\n};\n\nexport const toHeaderCase = (string_: string): string =>\n string_\n .toLowerCase()\n .replaceAll(/[^\\s\\w]/gu, \" \") // Remove all non-word characters\n .trimEnd() // Remove trailing spaces\n .replaceAll(/\\s+|_/gu, \"-\") // Replace multiple spaces or underline with a single hyphen\n .replaceAll(/\\b\\w/gu, (c) => c.toUpperCase());\n","import type { XmlElement } from \"jstoxml\";\nimport { toXML } from \"jstoxml\";\nimport type { OpenAPIV3 } from \"openapi-types\";\nimport { stringify } from \"yaml\";\n\nimport { toHeaderCase } from \"../utils\";\n\ntype Transformers = { regex: RegExp; transformer: (data: any) => string }[];\n\nconst jsonMediaType = \"application/json\";\n\nconst prepareStatusContent = (methodSpec: OpenAPIV3.OperationObject, status: string, mediaType: string) => {\n if (((methodSpec.responses as unknown as OpenAPIV3.ResponsesObject)[status] as OpenAPIV3.ResponseObject).content === undefined) {\n // eslint-disable-next-line no-param-reassign\n ((methodSpec.responses as unknown as OpenAPIV3.ResponsesObject)[status] as OpenAPIV3.ResponseObject).content = {};\n }\n\n if (((methodSpec.responses as unknown as OpenAPIV3.ResponsesObject)[status] as OpenAPIV3.ResponseObject).content?.[mediaType] === undefined) {\n // prettier-ignore\n // eslint-disable-next-line no-param-reassign\n (((methodSpec.responses as unknown as OpenAPIV3.ResponsesObject)[status] as OpenAPIV3.ResponseObject).content as Record<\n string,\n OpenAPIV3.MediaTypeObject\n >)[\n mediaType\n ] = {} as OpenAPIV3.MediaTypeObject;\n }\n};\n\nconst extendComponentSchemas = (spec: Partial<OpenAPIV3.Document>, schemaName: string, schema: OpenAPIV3.SchemaObject) => {\n if (typeof spec.components !== \"object\") {\n // eslint-disable-next-line no-param-reassign\n spec.components = {};\n }\n\n if (typeof spec.components.schemas !== \"object\") {\n // eslint-disable-next-line no-param-reassign\n spec.components.schemas = {};\n }\n\n if (spec.components.schemas[schemaName] === undefined) {\n // eslint-disable-next-line no-param-reassign\n spec.components.schemas[schemaName] = schema;\n }\n};\n\nconst extendResponseSchema = (methodSpec: OpenAPIV3.OperationObject, status: string, mediaType: string, schemaName: string, schemaIsArray: boolean) => {\n prepareStatusContent(methodSpec, status, mediaType);\n\n if (((methodSpec.responses as unknown as OpenAPIV3.ResponsesObject)[status] as OpenAPIV3.ResponseObject).content?.[mediaType]?.schema === undefined) {\n // prettier-ignore\n // eslint-disable-next-line no-param-reassign\n ((((methodSpec.responses as unknown as OpenAPIV3.ResponsesObject)[status] as OpenAPIV3.ResponseObject).content as Record<\n string,\n OpenAPIV3.MediaTypeObject\n >)[\n mediaType\n ] as OpenAPIV3.MediaTypeObject).schema =\n {} as OpenAPIV3.SchemaObject;\n }\n\n // prettier-ignore\n // eslint-disable-next-line no-param-reassign\n ((((methodSpec.responses as unknown as OpenAPIV3.ResponsesObject)[status] as OpenAPIV3.ResponseObject).content as Record<\n string,\n OpenAPIV3.MediaTypeObject\n >)[\n mediaType\n ] as OpenAPIV3.MediaTypeObject).schema =\n schemaIsArray\n ? {\n items: {\n $ref: `#/components/schemas/${schemaName}`,\n },\n type: \"array\",\n }\n : {\n $ref: `#/components/schemas/${schemaName}`,\n };\n};\n\nconst extendSwaggerWithMediaTypeSchema = (\n methodSpec: OpenAPIV3.OperationObject,\n responseSpec: OpenAPIV3.ResponseObject,\n allowedMediaTypes: Record<string, boolean> | undefined,\n pathKey: string,\n spec: Partial<OpenAPIV3.Document>,\n status: string,\n): {\n example?: any;\n examples?: Record<string, OpenAPIV3.ExampleObject | OpenAPIV3.ReferenceObject>;\n} => {\n let example: any | undefined;\n let examples: Record<string, OpenAPIV3.ExampleObject | OpenAPIV3.ReferenceObject> | undefined;\n\n // eslint-disable-next-line sonarjs/cognitive-complexity\n Object.entries(responseSpec.content as object).forEach(([mediaName, contentSpec]) => {\n if (typeof contentSpec.schema === \"object\") {\n const { schema } = contentSpec;\n\n if (mediaName === jsonMediaType && contentSpec.examples !== undefined) {\n examples = contentSpec.examples;\n } else if (mediaName === jsonMediaType && contentSpec.example !== undefined) {\n example = contentSpec.example;\n }\n\n const schemaIsArray = (schema as OpenAPIV3.SchemaObject).type === \"array\";\n\n Object.entries(allowedMediaTypes ?? {}).forEach(([mediaType, allowed]) => {\n if (!allowed) {\n return;\n }\n\n let schemaName: string;\n\n if (schema?.$ref === undefined) {\n schemaName = `${toHeaderCase(pathKey.trim().replace(\"/\", \"\"))}${mediaType === \"application/ld+json\" ? \".jsonld\" : \"\"}`;\n\n extendComponentSchemas(spec as OpenAPIV3.Document, schemaName, schema as OpenAPIV3.SchemaObject);\n } else {\n schemaName = (schema as OpenAPIV3.ReferenceObject).$ref.replace(\"#/components/schemas/\", \"\");\n }\n\n extendResponseSchema(methodSpec, status, mediaType, schemaName, schemaIsArray);\n });\n }\n });\n\n return { example, examples };\n};\n\nconst extendSwaggerWithMediaTypeExample = (\n methodSpec: OpenAPIV3.OperationObject,\n responseSpec: OpenAPIV3.ResponseObject,\n status: string,\n allowedMediaTypes: Record<string, boolean> | undefined,\n transformers: Transformers,\n example: any,\n) => {\n Object.keys(responseSpec.content as object).forEach((mediaName) => {\n if (mediaName === jsonMediaType) {\n return;\n }\n\n Object.entries(allowedMediaTypes ?? {}).forEach(([mediaType, allowed]) => {\n if (!allowed) {\n return;\n }\n\n prepareStatusContent(methodSpec, status, mediaType);\n\n if (\n ((methodSpec.responses as unknown as OpenAPIV3.ResponsesObject)[status] as OpenAPIV3.ResponseObject).content?.[mediaType]?.example === undefined\n ) {\n // prettier-ignore\n // eslint-disable-next-line no-param-reassign\n ((((methodSpec.responses as unknown as OpenAPIV3.ResponsesObject)[status] as OpenAPIV3.ResponseObject).content as Record<\n string,\n OpenAPIV3.MediaTypeObject\n >)[\n mediaType\n ] as OpenAPIV3.MediaTypeObject).example =\n {};\n }\n\n let transformed = false;\n\n transformers.forEach(({ regex, transformer }) => {\n if (!transformed && regex.test(mediaType)) {\n // prettier-ignore\n // eslint-disable-next-line no-param-reassign\n ((((methodSpec.responses as unknown as OpenAPIV3.ResponsesObject)[status] as OpenAPIV3.ResponseObject).content as Record<\n string,\n OpenAPIV3.MediaTypeObject\n >)[\n mediaType\n ] as OpenAPIV3.MediaTypeObject).example =\n transformer(example);\n\n transformed = true;\n }\n });\n\n if (!transformed) {\n // prettier-ignore\n // eslint-disable-next-line no-param-reassign\n ((((methodSpec.responses as unknown as OpenAPIV3.ResponsesObject)[status] as OpenAPIV3.ResponseObject).content as Record<\n string,\n OpenAPIV3.MediaTypeObject\n >)[\n mediaType\n ] as OpenAPIV3.MediaTypeObject).example =\n example;\n }\n });\n });\n};\n\nconst extendComponentExamples = (\n spec: Partial<OpenAPIV3.Document>,\n exampleName: string,\n examples: Record<string, OpenAPIV3.ExampleObject | OpenAPIV3.ReferenceObject>,\n) => {\n if (typeof spec.components !== \"object\") {\n // eslint-disable-next-line no-param-reassign\n spec.components = {};\n }\n\n if (typeof spec.components.examples !== \"object\") {\n // eslint-disable-next-line no-param-reassign\n spec.components.examples = {};\n }\n\n if (spec.components.examples[exampleName] === undefined && examples[exampleName] !== undefined) {\n // eslint-disable-next-line no-param-reassign\n spec.components.examples[exampleName] = examples[exampleName] as OpenAPIV3.ExampleObject;\n }\n};\n\nconst prepareResponseExamples = (\n spec: Partial<OpenAPIV3.Document>,\n methodSpec: OpenAPIV3.OperationObject,\n status: string,\n mediaType: string,\n transformers: Transformers,\n examples: Record<string, OpenAPIV3.ExampleObject | OpenAPIV3.ReferenceObject>,\n // eslint-disable-next-line sonarjs/cognitive-complexity\n) => {\n prepareStatusContent(methodSpec, status, mediaType);\n\n if (((methodSpec.responses as unknown as OpenAPIV3.ResponsesObject)[status] as OpenAPIV3.ResponseObject).content?.[mediaType]?.examples === undefined) {\n // prettier-ignore\n // eslint-disable-next-line no-param-reassign\n ((((methodSpec.responses as unknown as OpenAPIV3.ResponsesObject)[status] as OpenAPIV3.ResponseObject).content as Record<\n string,\n OpenAPIV3.MediaTypeObject\n >)[\n mediaType\n ] as OpenAPIV3.MediaTypeObject).examples =\n {};\n }\n\n const transformedExamples: Record<string, OpenAPIV3.ExampleObject | OpenAPIV3.ReferenceObject> = {};\n\n Object.entries(examples).forEach(([exampleName, example]) => {\n let transformed = false;\n\n transformers.forEach(({ regex, transformer }) => {\n if (!transformed && regex.test(mediaType)) {\n let data: any = \"\";\n\n if (spec.components?.examples?.[exampleName]) {\n data = (spec.components.examples[exampleName] as OpenAPIV3.ExampleObject).value;\n } else if ((example as OpenAPIV3.ReferenceObject).$ref) {\n data = (\n spec.components?.examples?.[\n (example as OpenAPIV3.ReferenceObject).$ref.replace(\"#/components/examples/\", \"\")\n ] as OpenAPIV3.ExampleObject\n ).value;\n } else if (typeof (example as OpenAPIV3.ExampleObject).value === \"string\") {\n data = (example as OpenAPIV3.ExampleObject).value;\n }\n\n transformedExamples[exampleName] = {\n value: transformer(data),\n };\n\n transformed = true;\n }\n });\n\n if (!transformed) {\n transformedExamples[exampleName] =\n spec.components?.examples?.[exampleName] === undefined\n ? example\n : {\n $ref: `#/components/examples/${exampleName}`,\n };\n }\n });\n\n // prettier-ignore\n // eslint-disable-next-line no-param-reassign\n ((((methodSpec.responses as unknown as OpenAPIV3.ResponsesObject)[status] as OpenAPIV3.ResponseObject).content as Record<\n string,\n OpenAPIV3.MediaTypeObject\n >)[\n mediaType\n ] as OpenAPIV3.MediaTypeObject).examples =\n transformedExamples;\n};\n\nconst extendSwaggerWithMediaTypeExamples = (\n spec: Partial<OpenAPIV3.Document>,\n methodSpec: OpenAPIV3.OperationObject,\n status: string,\n responseSpec: OpenAPIV3.ResponseObject,\n allowedMediaTypes: Record<string, boolean> | undefined,\n pathKey: string,\n transformers: Transformers,\n examples: Record<string, OpenAPIV3.ExampleObject | OpenAPIV3.ReferenceObject>,\n) => {\n const examplesName = toHeaderCase(pathKey.trim().replace(\"/\", \"\"));\n\n Object.keys(responseSpec.content as object).forEach((mediaName) => {\n if (mediaName === jsonMediaType) {\n return;\n }\n\n Object.entries(allowedMediaTypes ?? {}).forEach(([mediaType, allowed]) => {\n if (!allowed) {\n return;\n }\n\n extendComponentExamples(spec, examplesName, examples);\n\n prepareResponseExamples(spec, methodSpec, status, mediaType, transformers, examples);\n });\n });\n};\n\n// eslint-disable-next-line sonarjs/cognitive-complexity\nexport default function extendSwaggerSpec(\n spec: Partial<OpenAPIV3.Document>,\n allowedMediaTypes?: Record<string, boolean>,\n transformers: Transformers = [\n {\n regex: /xml/u,\n transformer: (value: XmlElement | XmlElement[] | undefined) =>\n toXML(value, {\n header: true,\n indent: \" \",\n }),\n },\n {\n regex: /yaml|yml/,\n transformer: (value) => stringify(value, { indent: 2 }),\n },\n ],\n): Partial<OpenAPIV3.Document> {\n if (typeof spec === \"object\" && typeof spec.paths === \"object\") {\n Object.entries(spec.paths).forEach(([pathKey, pathSpec]) => {\n Object.values(pathSpec as OpenAPIV3.OperationObject & OpenAPIV3.PathsObject).forEach((methodSpec) => {\n if (typeof (methodSpec as OpenAPIV3.OperationObject).responses === \"object\") {\n Object.entries((methodSpec as OpenAPIV3.OperationObject).responses).forEach(([status, responseSpec]) => {\n if (typeof (responseSpec as OpenAPIV3.ResponseObject).content === \"object\") {\n const { example, examples } = extendSwaggerWithMediaTypeSchema(\n methodSpec as OpenAPIV3.OperationObject,\n responseSpec as OpenAPIV3.ResponseObject,\n allowedMediaTypes,\n pathKey,\n spec,\n status,\n );\n\n if (example !== undefined) {\n extendSwaggerWithMediaTypeExample(\n methodSpec as OpenAPIV3.OperationObject,\n responseSpec as OpenAPIV3.ResponseObject,\n status,\n allowedMediaTypes,\n transformers,\n example,\n );\n } else if (examples !== undefined) {\n extendSwaggerWithMediaTypeExamples(\n spec,\n methodSpec as OpenAPIV3.OperationObject,\n status,\n responseSpec as OpenAPIV3.ResponseObject,\n allowedMediaTypes,\n pathKey,\n transformers,\n examples,\n );\n }\n }\n });\n }\n });\n });\n }\n\n return spec;\n}\n","import { existsSync, readFileSync } from \"node:fs\";\nimport type { IncomingMessage, ServerResponse } from \"node:http\";\n\nimport type { ModelsToOpenApiParameters, SwaggerModelsConfig } from \"@visulima/crud\";\nimport { modelsToOpenApi } from \"@visulima/crud\";\nimport { join } from \"@visulima/path\";\nimport debug from \"debug\";\n// eslint-disable-next-line no-restricted-imports\nimport merge from \"lodash.merge\";\nimport type { OpenAPIV3 } from \"openapi-types\";\n\nimport yamlTransformer from \"../../serializers/transformer/yaml\";\nimport extendSwaggerSpec from \"../extend-swagger-spec\";\n\nconst swaggerCrudDebug = debug(\"visulima:api-platform:swagger:crud:get-static-properties-swagger\");\n\nconst swaggerHandler = <M extends string, PrismaClient>(\n options: Partial<SwaggerHandlerOptions<M, PrismaClient>> = {},\n): ((request: IncomingMessage, response: ServerResponse) => Promise<void>) => {\n const {\n allowedMediaTypes = {\n \"application/json\": true,\n },\n crud,\n specs,\n swaggerFilePath,\n } = options;\n\n return async <Request extends IncomingMessage, Response extends ServerResponse>(request: Request, response: Response) => {\n const swaggerPath = join(process.cwd(), swaggerFilePath ?? \"swagger/swagger.json\");\n\n if (!existsSync(swaggerPath)) {\n throw new Error(`Swagger file not found at \"${swaggerPath}\".`);\n }\n\n const fileContents = readFileSync(swaggerPath, \"utf8\");\n\n let spec = extendSwaggerSpec(JSON.parse(fileContents) as OpenAPIV3.Document, allowedMediaTypes) as OpenAPIV3.Document;\n let crudSwagger: Partial<OpenAPIV3.Document> = {};\n\n if (crud !== undefined) {\n try {\n const modelsOpenApi = await modelsToOpenApi(crud);\n\n crudSwagger = {\n components: { examples: modelsOpenApi.examples, schemas: modelsOpenApi.schemas },\n paths: modelsOpenApi.paths,\n tags: modelsOpenApi.tags,\n };\n\n crudSwagger = extendSwaggerSpec(crudSwagger, allowedMediaTypes);\n\n swaggerCrudDebug(JSON.stringify(crudSwagger, null, 2));\n\n spec = merge(spec, crudSwagger);\n } catch (error) {\n // eslint-disable-next-line no-console\n console.log(error);\n\n throw new Error(\"Please install @visulima/crud to use the crud swagger generator.\");\n }\n }\n\n if (Array.isArray(specs)) {\n specs.forEach((value) => {\n spec = merge(spec, extendSwaggerSpec(value, allowedMediaTypes));\n });\n }\n\n let data: Buffer | Uint8Array | string;\n\n if (typeof request.headers.accept === \"string\" && /yaml|yml/.test(request.headers.accept)) {\n response.setHeader(\"Content-Type\", request.headers.accept);\n\n data = yamlTransformer(spec);\n } else {\n response.setHeader(\"Content-Type\", \"application/json\");\n\n data = JSON.stringify(spec, null, 2);\n }\n\n response.statusCode = 200;\n response.end(data);\n };\n};\n\nexport interface SwaggerHandlerOptions<M extends string, PrismaClient> {\n allowedMediaTypes: Record<string, boolean>;\n crud: Exclude<ModelsToOpenApiParameters<M, PrismaClient>, \"swagger\"> & {\n swagger?: {\n models?: SwaggerModelsConfig<M>;\n };\n };\n specs?: Partial<OpenAPIV3.Document>[];\n swaggerFilePath: string;\n}\n\nexport default swaggerHandler;\n"]}
@@ -1,2 +1,2 @@
1
- 'use strict';var chunkT3UDBLMA_js=require('../../../chunk-T3UDBLMA.js');require('../../../chunk-4C666HHU.js');var process=require('process');var i=(o,t="list",r="List all available API routes; Supported frameworks are next, express, koa, hapi and fastify")=>{o.command(t).description(r).option("--framework <framework>","Framework to use, choose from next, express, koa, hapi and fastify").option("-p, --path [path]","...").option("--group [type]","Groups routes. Supported: path, tag").option("--include-path [path]","Includes only routes which contain a given path element. (comma-separated values)",[]).option("--exclude-path [path]","Excludes routes which contain a given path element. (comma-separated values)",[]).option("-v, --verbose","Verbose output.",!1).action(async e=>{try{await chunkT3UDBLMA_js.a(e.framework,e.path,{excludePaths:e.excludePaths??[],group:e.group,includePaths:e.includePath??[],verbose:e.verbose});}catch(s){console.log(),console.error(s),process.exit(1);}});},m=i;exports.listCommand=m;//# sourceMappingURL=index.js.map
1
+ 'use strict';var chunkQUSG4GKL_js=require('../../../chunk-QUSG4GKL.js');require('../../../chunk-4C666HHU.js');var process=require('process');var i=(o,t="list",r="List all available API routes; Supported frameworks are next, express, koa, hapi and fastify")=>{o.command(t).description(r).option("--framework <framework>","Framework to use, choose from next, express, koa, hapi and fastify").option("-p, --path [path]","...").option("--group [type]","Groups routes. Supported: path, tag").option("--include-path [path]","Includes only routes which contain a given path element. (comma-separated values)",[]).option("--exclude-path [path]","Excludes routes which contain a given path element. (comma-separated values)",[]).option("-v, --verbose","Verbose output.",false).action(async e=>{try{await chunkQUSG4GKL_js.a(e.framework,e.path,{excludePaths:e.excludePaths??[],group:e.group,includePaths:e.includePath??[],verbose:e.verbose});}catch(s){console.log(),console.error(s),process.exit(1);}});},m=i;exports.listCommand=m;//# sourceMappingURL=index.js.map
2
2
  //# sourceMappingURL=index.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../../src/framework/cli/commander/command/list-command.ts"],"names":["listCommand","program","commandName","description","options","list_command_default","error","exit"],"mappings":"6IAMA,IAAMA,EAAc,CAChBC,CAAAA,CACAC,EAAc,MACdC,CAAAA,CAAAA,CAAc,iGACP,CACPF,CAAAA,CACK,QAAQC,CAAW,CAAA,CACnB,YAAYC,CAAW,CAAA,CACvB,MAAO,CAAA,yBAAA,CAA2B,oEAAoE,CAAA,CACtG,OAAO,mBAAqB,CAAA,KAAK,EACjC,MAAO,CAAA,gBAAA,CAAkB,qCAAqC,CAC9D,CAAA,MAAA,CAAO,wBAAyB,mFAAqF,CAAA,EAAE,CACvH,CAAA,MAAA,CAAO,wBAAyB,8EAAgF,CAAA,EAAE,CAClH,CAAA,MAAA,CAAO,eAAiB,CAAA,iBAAA,CAAmB,CAAK,CAAA,CAAA,CAChD,OACG,MAAOC,CAAAA,EAOD,CACF,GAAI,CACA,MAAMC,kBAAQD,CAAAA,CAAAA,CAAQ,UAAWA,CAAQ,CAAA,IAAA,CAAM,CAC3C,YAAcA,CAAAA,CAAAA,CAAQ,cAAgB,EAAC,CACvC,MAAOA,CAAQ,CAAA,KAAA,CACf,YAAcA,CAAAA,CAAAA,CAAQ,WAAe,EAAA,GACrC,OAASA,CAAAA,CAAAA,CAAQ,OACrB,CAAC,EACL,OAASE,CAAY,CAAA,CAEjB,QAAQ,GAAI,EAAA,CAEZ,QAAQ,KAAMA,CAAAA,CAAK,EACnBC,YAAK,CAAA,CAAC,EACV,CACJ,CACJ,EACR,CAAA,CAEOF,CAAQL,CAAAA","file":"index.js","sourcesContent":["import { exit } from \"node:process\";\n\nimport type { Command } from \"commander\";\n\nimport command from \"../../command/list/list-command\";\n\nconst listCommand = (\n program: Command,\n commandName = \"list\",\n description = \"List all available API routes; Supported frameworks are next, express, koa, hapi and fastify\",\n): void => {\n program\n .command(commandName)\n .description(description)\n .option(\"--framework <framework>\", \"Framework to use, choose from next, express, koa, hapi and fastify\")\n .option(\"-p, --path [path]\", \"...\")\n .option(\"--group [type]\", \"Groups routes. Supported: path, tag\")\n .option(\"--include-path [path]\", \"Includes only routes which contain a given path element. (comma-separated values)\", [])\n .option(\"--exclude-path [path]\", \"Excludes routes which contain a given path element. (comma-separated values)\", [])\n .option(\"-v, --verbose\", \"Verbose output.\", false)\n .action(\n async (options: {\n excludePaths?: string[];\n framework: \"express\" | \"fastify\" | \"hapi\" | \"koa\" | \"next\";\n group?: string;\n includePath?: string[];\n path: string;\n verbose?: boolean;\n }) => {\n try {\n await command(options.framework, options.path, {\n excludePaths: options.excludePaths ?? [],\n group: options.group,\n includePaths: options.includePath ?? [],\n verbose: options.verbose as boolean | undefined,\n });\n } catch (error: any) {\n // eslint-disable-next-line no-console\n console.log();\n // eslint-disable-next-line no-console\n console.error(error);\n exit(1);\n }\n },\n );\n};\n\nexport default listCommand;\n"]}
1
+ {"version":3,"sources":["../../../../src/framework/cli/commander/command/list-command.ts"],"names":["listCommand","program","commandName","description","options","list_command_default","error","exit"],"mappings":"6IAMA,IAAMA,EAAc,CAChBC,CAAAA,CACAC,EAAc,MACdC,CAAAA,CAAAA,CAAc,iGACP,CACPF,CAAAA,CACK,QAAQC,CAAW,CAAA,CACnB,YAAYC,CAAW,CAAA,CACvB,MAAO,CAAA,yBAAA,CAA2B,oEAAoE,CAAA,CACtG,OAAO,mBAAqB,CAAA,KAAK,EACjC,MAAO,CAAA,gBAAA,CAAkB,qCAAqC,CAC9D,CAAA,MAAA,CAAO,wBAAyB,mFAAqF,CAAA,EAAE,CACvH,CAAA,MAAA,CAAO,wBAAyB,8EAAgF,CAAA,EAAE,CAClH,CAAA,MAAA,CAAO,eAAiB,CAAA,iBAAA,CAAmB,KAAK,CAAA,CAChD,OACG,MAAOC,CAAAA,EAOD,CACF,GAAI,CACA,MAAMC,kBAAQD,CAAAA,CAAAA,CAAQ,UAAWA,CAAQ,CAAA,IAAA,CAAM,CAC3C,YAAcA,CAAAA,CAAAA,CAAQ,cAAgB,EAAC,CACvC,MAAOA,CAAQ,CAAA,KAAA,CACf,YAAcA,CAAAA,CAAAA,CAAQ,WAAe,EAAA,GACrC,OAASA,CAAAA,CAAAA,CAAQ,OACrB,CAAC,EACL,OAASE,CAAY,CAAA,CAEjB,QAAQ,GAAI,EAAA,CAEZ,QAAQ,KAAMA,CAAAA,CAAK,EACnBC,YAAK,CAAA,CAAC,EACV,CACJ,CACJ,EACR,CAAA,CAEOF,CAAQL,CAAAA","file":"index.js","sourcesContent":["import { exit } from \"node:process\";\n\nimport type { Command } from \"commander\";\n\nimport command from \"../../command/list/list-command\";\n\nconst listCommand = (\n program: Command,\n commandName = \"list\",\n description = \"List all available API routes; Supported frameworks are next, express, koa, hapi and fastify\",\n): void => {\n program\n .command(commandName)\n .description(description)\n .option(\"--framework <framework>\", \"Framework to use, choose from next, express, koa, hapi and fastify\")\n .option(\"-p, --path [path]\", \"...\")\n .option(\"--group [type]\", \"Groups routes. Supported: path, tag\")\n .option(\"--include-path [path]\", \"Includes only routes which contain a given path element. (comma-separated values)\", [])\n .option(\"--exclude-path [path]\", \"Excludes routes which contain a given path element. (comma-separated values)\", [])\n .option(\"-v, --verbose\", \"Verbose output.\", false)\n .action(\n async (options: {\n excludePaths?: string[];\n framework: \"express\" | \"fastify\" | \"hapi\" | \"koa\" | \"next\";\n group?: string;\n includePath?: string[];\n path: string;\n verbose?: boolean;\n }) => {\n try {\n await command(options.framework, options.path, {\n excludePaths: options.excludePaths ?? [],\n group: options.group,\n includePaths: options.includePath ?? [],\n verbose: options.verbose as boolean | undefined,\n });\n } catch (error: any) {\n // eslint-disable-next-line no-console\n console.log();\n // eslint-disable-next-line no-console\n console.error(error);\n exit(1);\n }\n },\n );\n};\n\nexport default listCommand;\n"]}
@@ -1,2 +1,2 @@
1
- import {a}from'../../../chunk-TL2JADQK.mjs';import'../../../chunk-HZWWJL43.mjs';import {exit}from'node:process';var m=(o,t="list",r="List all available API routes; Supported frameworks are next, express, koa, hapi and fastify")=>{o.command(t).description(r).option("--framework <framework>","Framework to use, choose from next, express, koa, hapi and fastify").option("-p, --path [path]","...").option("--group [type]","Groups routes. Supported: path, tag").option("--include-path [path]","Includes only routes which contain a given path element. (comma-separated values)",[]).option("--exclude-path [path]","Excludes routes which contain a given path element. (comma-separated values)",[]).option("-v, --verbose","Verbose output.",!1).action(async e=>{try{await a(e.framework,e.path,{excludePaths:e.excludePaths??[],group:e.group,includePaths:e.includePath??[],verbose:e.verbose});}catch(s){console.log(),console.error(s),exit(1);}});},l=m;export{l as listCommand};//# sourceMappingURL=index.mjs.map
1
+ import {a}from'../../../chunk-LMAVL3HF.mjs';import'../../../chunk-HZWWJL43.mjs';import {exit}from'node:process';var m=(o,t="list",r="List all available API routes; Supported frameworks are next, express, koa, hapi and fastify")=>{o.command(t).description(r).option("--framework <framework>","Framework to use, choose from next, express, koa, hapi and fastify").option("-p, --path [path]","...").option("--group [type]","Groups routes. Supported: path, tag").option("--include-path [path]","Includes only routes which contain a given path element. (comma-separated values)",[]).option("--exclude-path [path]","Excludes routes which contain a given path element. (comma-separated values)",[]).option("-v, --verbose","Verbose output.",false).action(async e=>{try{await a(e.framework,e.path,{excludePaths:e.excludePaths??[],group:e.group,includePaths:e.includePath??[],verbose:e.verbose});}catch(s){console.log(),console.error(s),exit(1);}});},l=m;export{l as listCommand};//# sourceMappingURL=index.mjs.map
2
2
  //# sourceMappingURL=index.mjs.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../../src/framework/cli/commander/command/list-command.ts"],"names":["listCommand","program","commandName","description","options","list_command_default","error","exit"],"mappings":"gHAMA,IAAMA,EAAc,CAChBC,CAAAA,CACAC,EAAc,MACdC,CAAAA,CAAAA,CAAc,iGACP,CACPF,CAAAA,CACK,QAAQC,CAAW,CAAA,CACnB,YAAYC,CAAW,CAAA,CACvB,MAAO,CAAA,yBAAA,CAA2B,oEAAoE,CAAA,CACtG,OAAO,mBAAqB,CAAA,KAAK,EACjC,MAAO,CAAA,gBAAA,CAAkB,qCAAqC,CAC9D,CAAA,MAAA,CAAO,wBAAyB,mFAAqF,CAAA,EAAE,CACvH,CAAA,MAAA,CAAO,wBAAyB,8EAAgF,CAAA,EAAE,CAClH,CAAA,MAAA,CAAO,eAAiB,CAAA,iBAAA,CAAmB,CAAK,CAAA,CAAA,CAChD,OACG,MAAOC,CAAAA,EAOD,CACF,GAAI,CACA,MAAMC,CAAQD,CAAAA,CAAAA,CAAQ,UAAWA,CAAQ,CAAA,IAAA,CAAM,CAC3C,YAAcA,CAAAA,CAAAA,CAAQ,cAAgB,EAAC,CACvC,MAAOA,CAAQ,CAAA,KAAA,CACf,YAAcA,CAAAA,CAAAA,CAAQ,WAAe,EAAA,GACrC,OAASA,CAAAA,CAAAA,CAAQ,OACrB,CAAC,EACL,OAASE,CAAY,CAAA,CAEjB,QAAQ,GAAI,EAAA,CAEZ,QAAQ,KAAMA,CAAAA,CAAK,EACnBC,IAAK,CAAA,CAAC,EACV,CACJ,CACJ,EACR,CAAA,CAEOF,CAAQL,CAAAA","file":"index.mjs","sourcesContent":["import { exit } from \"node:process\";\n\nimport type { Command } from \"commander\";\n\nimport command from \"../../command/list/list-command\";\n\nconst listCommand = (\n program: Command,\n commandName = \"list\",\n description = \"List all available API routes; Supported frameworks are next, express, koa, hapi and fastify\",\n): void => {\n program\n .command(commandName)\n .description(description)\n .option(\"--framework <framework>\", \"Framework to use, choose from next, express, koa, hapi and fastify\")\n .option(\"-p, --path [path]\", \"...\")\n .option(\"--group [type]\", \"Groups routes. Supported: path, tag\")\n .option(\"--include-path [path]\", \"Includes only routes which contain a given path element. (comma-separated values)\", [])\n .option(\"--exclude-path [path]\", \"Excludes routes which contain a given path element. (comma-separated values)\", [])\n .option(\"-v, --verbose\", \"Verbose output.\", false)\n .action(\n async (options: {\n excludePaths?: string[];\n framework: \"express\" | \"fastify\" | \"hapi\" | \"koa\" | \"next\";\n group?: string;\n includePath?: string[];\n path: string;\n verbose?: boolean;\n }) => {\n try {\n await command(options.framework, options.path, {\n excludePaths: options.excludePaths ?? [],\n group: options.group,\n includePaths: options.includePath ?? [],\n verbose: options.verbose as boolean | undefined,\n });\n } catch (error: any) {\n // eslint-disable-next-line no-console\n console.log();\n // eslint-disable-next-line no-console\n console.error(error);\n exit(1);\n }\n },\n );\n};\n\nexport default listCommand;\n"]}
1
+ {"version":3,"sources":["../../../../src/framework/cli/commander/command/list-command.ts"],"names":["listCommand","program","commandName","description","options","list_command_default","error","exit"],"mappings":"gHAMA,IAAMA,EAAc,CAChBC,CAAAA,CACAC,EAAc,MACdC,CAAAA,CAAAA,CAAc,iGACP,CACPF,CAAAA,CACK,QAAQC,CAAW,CAAA,CACnB,YAAYC,CAAW,CAAA,CACvB,MAAO,CAAA,yBAAA,CAA2B,oEAAoE,CAAA,CACtG,OAAO,mBAAqB,CAAA,KAAK,EACjC,MAAO,CAAA,gBAAA,CAAkB,qCAAqC,CAC9D,CAAA,MAAA,CAAO,wBAAyB,mFAAqF,CAAA,EAAE,CACvH,CAAA,MAAA,CAAO,wBAAyB,8EAAgF,CAAA,EAAE,CAClH,CAAA,MAAA,CAAO,eAAiB,CAAA,iBAAA,CAAmB,KAAK,CAAA,CAChD,OACG,MAAOC,CAAAA,EAOD,CACF,GAAI,CACA,MAAMC,CAAQD,CAAAA,CAAAA,CAAQ,UAAWA,CAAQ,CAAA,IAAA,CAAM,CAC3C,YAAcA,CAAAA,CAAAA,CAAQ,cAAgB,EAAC,CACvC,MAAOA,CAAQ,CAAA,KAAA,CACf,YAAcA,CAAAA,CAAAA,CAAQ,WAAe,EAAA,GACrC,OAASA,CAAAA,CAAAA,CAAQ,OACrB,CAAC,EACL,OAASE,CAAY,CAAA,CAEjB,QAAQ,GAAI,EAAA,CAEZ,QAAQ,KAAMA,CAAAA,CAAK,EACnBC,IAAK,CAAA,CAAC,EACV,CACJ,CACJ,EACR,CAAA,CAEOF,CAAQL,CAAAA","file":"index.mjs","sourcesContent":["import { exit } from \"node:process\";\n\nimport type { Command } from \"commander\";\n\nimport command from \"../../command/list/list-command\";\n\nconst listCommand = (\n program: Command,\n commandName = \"list\",\n description = \"List all available API routes; Supported frameworks are next, express, koa, hapi and fastify\",\n): void => {\n program\n .command(commandName)\n .description(description)\n .option(\"--framework <framework>\", \"Framework to use, choose from next, express, koa, hapi and fastify\")\n .option(\"-p, --path [path]\", \"...\")\n .option(\"--group [type]\", \"Groups routes. Supported: path, tag\")\n .option(\"--include-path [path]\", \"Includes only routes which contain a given path element. (comma-separated values)\", [])\n .option(\"--exclude-path [path]\", \"Excludes routes which contain a given path element. (comma-separated values)\", [])\n .option(\"-v, --verbose\", \"Verbose output.\", false)\n .action(\n async (options: {\n excludePaths?: string[];\n framework: \"express\" | \"fastify\" | \"hapi\" | \"koa\" | \"next\";\n group?: string;\n includePath?: string[];\n path: string;\n verbose?: boolean;\n }) => {\n try {\n await command(options.framework, options.path, {\n excludePaths: options.excludePaths ?? [],\n group: options.group,\n includePaths: options.includePath ?? [],\n verbose: options.verbose as boolean | undefined,\n });\n } catch (error: any) {\n // eslint-disable-next-line no-console\n console.log();\n // eslint-disable-next-line no-console\n console.error(error);\n exit(1);\n }\n },\n );\n};\n\nexport default listCommand;\n"]}
@@ -1,2 +1,2 @@
1
- 'use strict';var chunkT3UDBLMA_js=require('../../chunk-T3UDBLMA.js');require('../../chunk-4C666HHU.js');Object.defineProperty(exports,"listCommand",{enumerable:true,get:function(){return chunkT3UDBLMA_js.a}});//# sourceMappingURL=index.js.map
1
+ 'use strict';var chunkQUSG4GKL_js=require('../../chunk-QUSG4GKL.js');require('../../chunk-4C666HHU.js');Object.defineProperty(exports,"listCommand",{enumerable:true,get:function(){return chunkQUSG4GKL_js.a}});//# sourceMappingURL=index.js.map
2
2
  //# sourceMappingURL=index.js.map
@@ -1,2 +1,2 @@
1
- export{a as listCommand}from'../../chunk-TL2JADQK.mjs';import'../../chunk-HZWWJL43.mjs';//# sourceMappingURL=index.mjs.map
1
+ export{a as listCommand}from'../../chunk-LMAVL3HF.mjs';import'../../chunk-HZWWJL43.mjs';//# sourceMappingURL=index.mjs.map
2
2
  //# sourceMappingURL=index.mjs.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../../../../src/framework/next/routes/pages/redoc/index.tsx"],"names":["RedocApiDocument","name","swagger","swaggerData","jsxs","Fragment","Head","jsx","RedocStandalone","redoc_default"],"mappings":"uQAMMA,CASF,CAAA,CAACC,EAAMC,CAAU,CAAA,EACjB,GAAA,CAAC,CAAE,WAAAC,CAAAA,CAAY,IACXC,eAAAC,CAAAA,mBAAAA,CAAA,CACI,QAAAD,CAAAA,CAAAA,eAAAA,CAACE,kBAAA,CAAA,CACG,UAAAC,cAAC,CAAA,OAAA,CAAA,CAAO,SAAAN,CAAK,CAAA,CAAA,CACbM,eAAC,OACI,CAAA,CAAA,QAAA,CAAA,CAAA;AAAA;AAAA;AAAA;AAAA,CAKL,CAAA,CAAA,CAAA,CACJ,CAEAA,CAAAA,cAAAA,CAACC,qBAAA,CAAA,CAAiB,GAAGN,CAAAA,CAAS,IAAMC,CAAAA,CAAAA,CAAa,CACrD,CAAA,CAAA,CAAA,CAGDM,CAAQT,CAAAA","file":"index.js","sourcesContent":["import Head from \"next/head\";\nimport type { InferGetStaticPropsType, NextPage } from \"next/types\";\nimport { RedocStandalone } from \"redoc\";\n\nimport type getStaticProps from \"../get-static-properties-swagger\";\n\nconst RedocApiDocument: (\n name: string,\n swagger?: Exclude<\n {\n specUrl?: string;\n },\n \"spec\"\n >,\n) => NextPage<InferGetStaticPropsType<typeof getStaticProps>> =\n (name, swagger = {}) =>\n ({ swaggerData }: InferGetStaticPropsType<typeof getStaticProps>) => (\n <>\n <Head>\n <title>{name}</title>\n <style>\n {`\nbody {\n background: #fafafa !important;\n}\n`}\n </style>\n </Head>\n {/* eslint-disable-next-line react/jsx-props-no-spreading */}\n <RedocStandalone {...swagger} spec={swaggerData} />\n </>\n );\n\nexport default RedocApiDocument;\n"]}
1
+ {"version":3,"sources":["../../../../../../src/framework/next/routes/pages/redoc/index.tsx"],"names":["RedocApiDocument","name","swagger","swaggerData","jsxs","Fragment","Head","jsx","RedocStandalone","redoc_default"],"mappings":"uQAMMA,CASF,CAAA,CAACC,EAAMC,CAAU,CAAA,EACjB,GAAA,CAAC,CAAE,WAAAC,CAAAA,CAAY,IACXC,eAAAC,CAAAA,mBAAAA,CAAA,CACI,QAAAD,CAAAA,CAAAA,eAAAA,CAACE,kBAAA,CAAA,CACG,UAAAC,cAAC,CAAA,OAAA,CAAA,CAAO,SAAAN,CAAK,CAAA,CAAA,CACbM,eAAC,OACI,CAAA,CAAA,QAAA,CAAA;AAAA;AAAA;AAAA;AAAA,CAKL,CAAA,CAAA,CAAA,CACJ,CAEAA,CAAAA,cAAAA,CAACC,qBAAA,CAAA,CAAiB,GAAGN,CAAAA,CAAS,IAAMC,CAAAA,CAAAA,CAAa,CACrD,CAAA,CAAA,CAAA,CAGDM,CAAQT,CAAAA","file":"index.js","sourcesContent":["import Head from \"next/head\";\nimport type { InferGetStaticPropsType, NextPage } from \"next/types\";\nimport { RedocStandalone } from \"redoc\";\n\nimport type getStaticProps from \"../get-static-properties-swagger\";\n\nconst RedocApiDocument: (\n name: string,\n swagger?: Exclude<\n {\n specUrl?: string;\n },\n \"spec\"\n >,\n) => NextPage<InferGetStaticPropsType<typeof getStaticProps>> =\n (name, swagger = {}) =>\n ({ swaggerData }: InferGetStaticPropsType<typeof getStaticProps>) => (\n <>\n <Head>\n <title>{name}</title>\n <style>\n {`\nbody {\n background: #fafafa !important;\n}\n`}\n </style>\n </Head>\n {/* eslint-disable-next-line react/jsx-props-no-spreading */}\n <RedocStandalone {...swagger} spec={swaggerData} />\n </>\n );\n\nexport default RedocApiDocument;\n"]}
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../../../../src/framework/next/routes/pages/redoc/index.tsx"],"names":["RedocApiDocument","name","swagger","swaggerData","jsxs","Fragment","Head","jsx","RedocStandalone","redoc_default"],"mappings":"6JAMMA,CASF,CAAA,CAACC,EAAMC,CAAU,CAAA,EACjB,GAAA,CAAC,CAAE,WAAAC,CAAAA,CAAY,IACXC,IAAAC,CAAAA,QAAAA,CAAA,CACI,QAAAD,CAAAA,CAAAA,IAAAA,CAACE,CAAA,CAAA,CACG,UAAAC,GAAC,CAAA,OAAA,CAAA,CAAO,SAAAN,CAAK,CAAA,CAAA,CACbM,IAAC,OACI,CAAA,CAAA,QAAA,CAAA,CAAA;AAAA;AAAA;AAAA;AAAA,CAKL,CAAA,CAAA,CAAA,CACJ,CAEAA,CAAAA,GAAAA,CAACC,eAAA,CAAA,CAAiB,GAAGN,CAAAA,CAAS,IAAMC,CAAAA,CAAAA,CAAa,CACrD,CAAA,CAAA,CAAA,CAGDM,CAAQT,CAAAA","file":"index.mjs","sourcesContent":["import Head from \"next/head\";\nimport type { InferGetStaticPropsType, NextPage } from \"next/types\";\nimport { RedocStandalone } from \"redoc\";\n\nimport type getStaticProps from \"../get-static-properties-swagger\";\n\nconst RedocApiDocument: (\n name: string,\n swagger?: Exclude<\n {\n specUrl?: string;\n },\n \"spec\"\n >,\n) => NextPage<InferGetStaticPropsType<typeof getStaticProps>> =\n (name, swagger = {}) =>\n ({ swaggerData }: InferGetStaticPropsType<typeof getStaticProps>) => (\n <>\n <Head>\n <title>{name}</title>\n <style>\n {`\nbody {\n background: #fafafa !important;\n}\n`}\n </style>\n </Head>\n {/* eslint-disable-next-line react/jsx-props-no-spreading */}\n <RedocStandalone {...swagger} spec={swaggerData} />\n </>\n );\n\nexport default RedocApiDocument;\n"]}
1
+ {"version":3,"sources":["../../../../../../src/framework/next/routes/pages/redoc/index.tsx"],"names":["RedocApiDocument","name","swagger","swaggerData","jsxs","Fragment","Head","jsx","RedocStandalone","redoc_default"],"mappings":"6JAMMA,CASF,CAAA,CAACC,EAAMC,CAAU,CAAA,EACjB,GAAA,CAAC,CAAE,WAAAC,CAAAA,CAAY,IACXC,IAAAC,CAAAA,QAAAA,CAAA,CACI,QAAAD,CAAAA,CAAAA,IAAAA,CAACE,CAAA,CAAA,CACG,UAAAC,GAAC,CAAA,OAAA,CAAA,CAAO,SAAAN,CAAK,CAAA,CAAA,CACbM,IAAC,OACI,CAAA,CAAA,QAAA,CAAA;AAAA;AAAA;AAAA;AAAA,CAKL,CAAA,CAAA,CAAA,CACJ,CAEAA,CAAAA,GAAAA,CAACC,eAAA,CAAA,CAAiB,GAAGN,CAAAA,CAAS,IAAMC,CAAAA,CAAAA,CAAa,CACrD,CAAA,CAAA,CAAA,CAGDM,CAAQT,CAAAA","file":"index.mjs","sourcesContent":["import Head from \"next/head\";\nimport type { InferGetStaticPropsType, NextPage } from \"next/types\";\nimport { RedocStandalone } from \"redoc\";\n\nimport type getStaticProps from \"../get-static-properties-swagger\";\n\nconst RedocApiDocument: (\n name: string,\n swagger?: Exclude<\n {\n specUrl?: string;\n },\n \"spec\"\n >,\n) => NextPage<InferGetStaticPropsType<typeof getStaticProps>> =\n (name, swagger = {}) =>\n ({ swaggerData }: InferGetStaticPropsType<typeof getStaticProps>) => (\n <>\n <Head>\n <title>{name}</title>\n <style>\n {`\nbody {\n background: #fafafa !important;\n}\n`}\n </style>\n </Head>\n {/* eslint-disable-next-line react/jsx-props-no-spreading */}\n <RedocStandalone {...swagger} spec={swaggerData} />\n </>\n );\n\nexport default RedocApiDocument;\n"]}
@@ -1,4 +1,4 @@
1
- 'use strict';require('../../../../../chunk-4C666HHU.js');var o=require('next/dynamic'),s=require('next/head'),jsxRuntime=require('react/jsx-runtime');function _interopDefault(e){return e&&e.__esModule?e:{default:e}}var o__default=/*#__PURE__*/_interopDefault(o);var s__default=/*#__PURE__*/_interopDefault(s);var g=o__default.default(async()=>await import('swagger-ui-react'),{ssr:!1}),i=(r,a={})=>({swaggerData:p})=>jsxRuntime.jsxs(jsxRuntime.Fragment,{children:[jsxRuntime.jsxs(s__default.default,{children:[jsxRuntime.jsx("title",{children:r}),jsxRuntime.jsx("style",{children:`
1
+ 'use strict';require('../../../../../chunk-4C666HHU.js');var o=require('next/dynamic'),s=require('next/head'),jsxRuntime=require('react/jsx-runtime');function _interopDefault(e){return e&&e.__esModule?e:{default:e}}var o__default=/*#__PURE__*/_interopDefault(o);var s__default=/*#__PURE__*/_interopDefault(s);var g=o__default.default(async()=>await import('swagger-ui-react'),{ssr:false}),i=(r,a={})=>({swaggerData:p})=>jsxRuntime.jsxs(jsxRuntime.Fragment,{children:[jsxRuntime.jsxs(s__default.default,{children:[jsxRuntime.jsx("title",{children:r}),jsxRuntime.jsx("style",{children:`
2
2
  body {
3
3
  background: #fafafa !important;
4
4
  }
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../../../../src/framework/next/routes/pages/swagger/index.tsx"],"names":["SwaggerUi","dynamic","SwaggerApiDocument","name","swagger","swaggerData","jsxs","Fragment","Head","jsx","swagger_default"],"mappings":"qTAOMA,IAAAA,CAAAA,CAAYC,kBAAQ,CAAA,SAAY,MAAM,OAAO,kBAAkB,CAAG,CAAA,CAAE,GAAK,CAAA,CAAA,CAAM,CAAC,CAAA,CAEhFC,EACF,CAACC,CAAAA,CAAMC,EAAU,EAAC,GAClB,CAAC,CAAE,WAAA,CAAAC,CAAY,CAAA,GACXC,eAAAC,CAAAA,mBAAAA,CAAA,CACI,QAAAD,CAAAA,CAAAA,eAAAA,CAACE,kBAAA,CAAA,CACG,QAAAC,CAAAA,CAAAA,cAAAA,CAAC,SAAO,QAAAN,CAAAA,CAAAA,CAAK,CACbM,CAAAA,cAAAA,CAAC,OACI,CAAA,CAAA,QAAA,CAAA,CAAA;AAAA;AAAA;AAAA;AAAA,CAKL,CAAA,CAAA,CAAA,CACJ,CAGAA,CAAAA,cAAAA,CAACT,CAAA,CAAA,CAAW,GAAGI,CAAAA,CAAS,IAAMC,CAAAA,CAAAA,CAAa,CAC/C,CAAA,CAAA,CAAA,CAGDK,CAAQR,CAAAA","file":"index.js","sourcesContent":["import dynamic from \"next/dynamic\";\nimport Head from \"next/head\";\nimport type { InferGetStaticPropsType, NextPage } from \"next/types\";\nimport type { SwaggerUIProps } from \"swagger-ui-react\";\n\nimport type getStaticProps from \"../get-static-properties-swagger\";\n\nconst SwaggerUi = dynamic(async () => await import(\"swagger-ui-react\"), { ssr: false });\n\nconst SwaggerApiDocument: (name: string, swagger?: Exclude<SwaggerUIProps, \"spec\">) => NextPage<InferGetStaticPropsType<typeof getStaticProps>> =\n (name, swagger = {}) =>\n ({ swaggerData }: InferGetStaticPropsType<typeof getStaticProps>) => (\n <>\n <Head>\n <title>{name}</title>\n <style>\n {`\nbody {\n background: #fafafa !important;\n}\n`}\n </style>\n </Head>\n\n {/* eslint-disable-next-line react/jsx-props-no-spreading */}\n <SwaggerUi {...swagger} spec={swaggerData} />\n </>\n );\n\nexport default SwaggerApiDocument;\n"]}
1
+ {"version":3,"sources":["../../../../../../src/framework/next/routes/pages/swagger/index.tsx"],"names":["SwaggerUi","dynamic","SwaggerApiDocument","name","swagger","swaggerData","jsxs","Fragment","Head","jsx","swagger_default"],"mappings":"qTAOMA,IAAAA,CAAAA,CAAYC,kBAAQ,CAAA,SAAY,MAAM,OAAO,kBAAkB,CAAG,CAAA,CAAE,GAAK,CAAA,KAAM,CAAC,CAAA,CAEhFC,EACF,CAACC,CAAAA,CAAMC,EAAU,EAAC,GAClB,CAAC,CAAE,WAAA,CAAAC,CAAY,CAAA,GACXC,eAAAC,CAAAA,mBAAAA,CAAA,CACI,QAAAD,CAAAA,CAAAA,eAAAA,CAACE,kBAAA,CAAA,CACG,QAAAC,CAAAA,CAAAA,cAAAA,CAAC,SAAO,QAAAN,CAAAA,CAAAA,CAAK,CACbM,CAAAA,cAAAA,CAAC,OACI,CAAA,CAAA,QAAA,CAAA;AAAA;AAAA;AAAA;AAAA,CAKL,CAAA,CAAA,CAAA,CACJ,CAGAA,CAAAA,cAAAA,CAACT,CAAA,CAAA,CAAW,GAAGI,CAAAA,CAAS,IAAMC,CAAAA,CAAAA,CAAa,CAC/C,CAAA,CAAA,CAAA,CAGDK,CAAQR,CAAAA","file":"index.js","sourcesContent":["import dynamic from \"next/dynamic\";\nimport Head from \"next/head\";\nimport type { InferGetStaticPropsType, NextPage } from \"next/types\";\nimport type { SwaggerUIProps } from \"swagger-ui-react\";\n\nimport type getStaticProps from \"../get-static-properties-swagger\";\n\nconst SwaggerUi = dynamic(async () => await import(\"swagger-ui-react\"), { ssr: false });\n\nconst SwaggerApiDocument: (name: string, swagger?: Exclude<SwaggerUIProps, \"spec\">) => NextPage<InferGetStaticPropsType<typeof getStaticProps>> =\n (name, swagger = {}) =>\n ({ swaggerData }: InferGetStaticPropsType<typeof getStaticProps>) => (\n <>\n <Head>\n <title>{name}</title>\n <style>\n {`\nbody {\n background: #fafafa !important;\n}\n`}\n </style>\n </Head>\n\n {/* eslint-disable-next-line react/jsx-props-no-spreading */}\n <SwaggerUi {...swagger} spec={swaggerData} />\n </>\n );\n\nexport default SwaggerApiDocument;\n"]}
@@ -1,4 +1,4 @@
1
- import'../../../../../chunk-HZWWJL43.mjs';import o from'next/dynamic';import s from'next/head';import {jsxs,Fragment,jsx}from'react/jsx-runtime';var g=o(async()=>await import('swagger-ui-react'),{ssr:!1}),i=(r,a={})=>({swaggerData:p})=>jsxs(Fragment,{children:[jsxs(s,{children:[jsx("title",{children:r}),jsx("style",{children:`
1
+ import'../../../../../chunk-HZWWJL43.mjs';import o from'next/dynamic';import s from'next/head';import {jsxs,Fragment,jsx}from'react/jsx-runtime';var g=o(async()=>await import('swagger-ui-react'),{ssr:false}),i=(r,a={})=>({swaggerData:p})=>jsxs(Fragment,{children:[jsxs(s,{children:[jsx("title",{children:r}),jsx("style",{children:`
2
2
  body {
3
3
  background: #fafafa !important;
4
4
  }
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../../../../src/framework/next/routes/pages/swagger/index.tsx"],"names":["SwaggerUi","dynamic","SwaggerApiDocument","name","swagger","swaggerData","jsxs","Fragment","Head","jsx","swagger_default"],"mappings":"iJAOMA,IAAAA,CAAAA,CAAYC,CAAQ,CAAA,SAAY,MAAM,OAAO,kBAAkB,CAAG,CAAA,CAAE,GAAK,CAAA,CAAA,CAAM,CAAC,CAAA,CAEhFC,EACF,CAACC,CAAAA,CAAMC,EAAU,EAAC,GAClB,CAAC,CAAE,WAAA,CAAAC,CAAY,CAAA,GACXC,IAAAC,CAAAA,QAAAA,CAAA,CACI,QAAAD,CAAAA,CAAAA,IAAAA,CAACE,CAAA,CAAA,CACG,QAAAC,CAAAA,CAAAA,GAAAA,CAAC,SAAO,QAAAN,CAAAA,CAAAA,CAAK,CACbM,CAAAA,GAAAA,CAAC,OACI,CAAA,CAAA,QAAA,CAAA,CAAA;AAAA;AAAA;AAAA;AAAA,CAKL,CAAA,CAAA,CAAA,CACJ,CAGAA,CAAAA,GAAAA,CAACT,CAAA,CAAA,CAAW,GAAGI,CAAAA,CAAS,IAAMC,CAAAA,CAAAA,CAAa,CAC/C,CAAA,CAAA,CAAA,CAGDK,CAAQR,CAAAA","file":"index.mjs","sourcesContent":["import dynamic from \"next/dynamic\";\nimport Head from \"next/head\";\nimport type { InferGetStaticPropsType, NextPage } from \"next/types\";\nimport type { SwaggerUIProps } from \"swagger-ui-react\";\n\nimport type getStaticProps from \"../get-static-properties-swagger\";\n\nconst SwaggerUi = dynamic(async () => await import(\"swagger-ui-react\"), { ssr: false });\n\nconst SwaggerApiDocument: (name: string, swagger?: Exclude<SwaggerUIProps, \"spec\">) => NextPage<InferGetStaticPropsType<typeof getStaticProps>> =\n (name, swagger = {}) =>\n ({ swaggerData }: InferGetStaticPropsType<typeof getStaticProps>) => (\n <>\n <Head>\n <title>{name}</title>\n <style>\n {`\nbody {\n background: #fafafa !important;\n}\n`}\n </style>\n </Head>\n\n {/* eslint-disable-next-line react/jsx-props-no-spreading */}\n <SwaggerUi {...swagger} spec={swaggerData} />\n </>\n );\n\nexport default SwaggerApiDocument;\n"]}
1
+ {"version":3,"sources":["../../../../../../src/framework/next/routes/pages/swagger/index.tsx"],"names":["SwaggerUi","dynamic","SwaggerApiDocument","name","swagger","swaggerData","jsxs","Fragment","Head","jsx","swagger_default"],"mappings":"iJAOMA,IAAAA,CAAAA,CAAYC,CAAQ,CAAA,SAAY,MAAM,OAAO,kBAAkB,CAAG,CAAA,CAAE,GAAK,CAAA,KAAM,CAAC,CAAA,CAEhFC,EACF,CAACC,CAAAA,CAAMC,EAAU,EAAC,GAClB,CAAC,CAAE,WAAA,CAAAC,CAAY,CAAA,GACXC,IAAAC,CAAAA,QAAAA,CAAA,CACI,QAAAD,CAAAA,CAAAA,IAAAA,CAACE,CAAA,CAAA,CACG,QAAAC,CAAAA,CAAAA,GAAAA,CAAC,SAAO,QAAAN,CAAAA,CAAAA,CAAK,CACbM,CAAAA,GAAAA,CAAC,OACI,CAAA,CAAA,QAAA,CAAA;AAAA;AAAA;AAAA;AAAA,CAKL,CAAA,CAAA,CAAA,CACJ,CAGAA,CAAAA,GAAAA,CAACT,CAAA,CAAA,CAAW,GAAGI,CAAAA,CAAS,IAAMC,CAAAA,CAAAA,CAAa,CAC/C,CAAA,CAAA,CAAA,CAGDK,CAAQR,CAAAA","file":"index.mjs","sourcesContent":["import dynamic from \"next/dynamic\";\nimport Head from \"next/head\";\nimport type { InferGetStaticPropsType, NextPage } from \"next/types\";\nimport type { SwaggerUIProps } from \"swagger-ui-react\";\n\nimport type getStaticProps from \"../get-static-properties-swagger\";\n\nconst SwaggerUi = dynamic(async () => await import(\"swagger-ui-react\"), { ssr: false });\n\nconst SwaggerApiDocument: (name: string, swagger?: Exclude<SwaggerUIProps, \"spec\">) => NextPage<InferGetStaticPropsType<typeof getStaticProps>> =\n (name, swagger = {}) =>\n ({ swaggerData }: InferGetStaticPropsType<typeof getStaticProps>) => (\n <>\n <Head>\n <title>{name}</title>\n <style>\n {`\nbody {\n background: #fafafa !important;\n}\n`}\n </style>\n </Head>\n\n {/* eslint-disable-next-line react/jsx-props-no-spreading */}\n <SwaggerUi {...swagger} spec={swaggerData} />\n </>\n );\n\nexport default SwaggerApiDocument;\n"]}
@@ -1,3 +1,3 @@
1
- 'use strict';var chunkUPRO35MO_js=require('./chunk-UPRO35MO.js'),chunkYG667K32_js=require('./chunk-YG667K32.js');require('./chunk-4C666HHU.js');var connect=require('@visulima/connect'),q=require('http-errors'),httpStatusCodes=require('http-status-codes'),x=require('ts-japi'),ee=require('debug'),Q=require('accepts'),jstoxml=require('jstoxml'),ie=require('cors');function _interopDefault(e){return e&&e.__esModule?e:{default:e}}var q__default=/*#__PURE__*/_interopDefault(q);var x__default=/*#__PURE__*/_interopDefault(x);var ee__default=/*#__PURE__*/_interopDefault(ee);var Q__default=/*#__PURE__*/_interopDefault(Q);var ie__default=/*#__PURE__*/_interopDefault(ie);var u=(e,o)=>{let t=o.headers??{};Object.keys(t).forEach(r=>{e.setHeader(r,t[r]);});},l=(e,o)=>{e.setHeader("content-type","application/json; charset=utf-8"),e.end(JSON.stringify(o));},R=(e,o)=>{o.statusCode!==void 0&&(e.statusCode=o.statusCode),o.status!==void 0&&(e.statusCode=o.status),e.statusCode<400&&(e.statusCode=httpStatusCodes.StatusCodes.INTERNAL_SERVER_ERROR);};var z="An error occurred",U=(e,o,t)=>{if(R(t,e),u(t,e),e instanceof x__default.default.JapiError||x__default.default.JapiError.isLikeJapiError(e)){let r=new x__default.default.ErrorSerializer;l(t,r.serialize(e));}else if(e instanceof q.HttpError){let{message:r,statusCode:n,title:a}=e;l(t,{errors:[{code:n,title:a||httpStatusCodes.getReasonPhrase(n)||z,detail:r}]});}else {let{message:r}=e;l(t,{errors:[{code:"500",title:httpStatusCodes.getReasonPhrase(t.statusCode)||z,detail:r}]});}},T=U;var M="https://tools.ietf.org/html/rfc2616#section-10",C="An error occurred",F=(e,o,t)=>{let{message:r,stack:n}=e;if(e instanceof q.HttpError){let{expose:a,statusCode:s,title:i,type:d}=e;t.statusCode=s,u(t,e),l(t,{type:d||M,title:i||httpStatusCodes.getReasonPhrase(s)||C,details:r,...a?{trace:n}:{}});}else R(t,e),l(t,{type:M,title:httpStatusCodes.getReasonPhrase(t.statusCode)||C,details:r,...e.expose?{trace:n}:{}});},I=F;var h=(e,o)=>async(t,r,n)=>{let a=r.headers.accept,s=I;a==="application/vnd.api+json"&&(s=T);for(let{handler:i,regex:d}of e)if(d.test(a)){s=i;break}t.expose=o,s(t,r,n);},H=async(e,o,t)=>{let r=[...new Set(t.map(n=>n.method))].join(", ");throw o.setHeader("Allow",r),o.statusCode=405,q__default.default(405,`No route with [${e.method}] method found.`)};var O={alpn:"ALPN","c-pep":"C-PEP","c-pep-info":"C-PEP-Info","caldav-timezones":"CalDAV-Timezones","content-id":"Content-ID","content-md5":"Content-MD5",dasl:"DASL",dav:"DAV",dnt:"DNT",etag:"ETag",getprofile:"GetProfile","http2-settings":"HTTP2-Settings","last-event-id":"Last-Event-ID","mime-version":"MIME-Version","optional-www-authenticate":"Optional-WWW-Authenticate","sec-webSocket-key":"Sec-WebSocket-Key","sec-webSocket-protocol":"Sec-WebSocket-Protocol","sec-webSocket-version":"Sec-WebSocket-Version","sec-websocket-accept":"Sec-WebSocket-Accept","sec-websocket-extensions":"Sec-WebSocket-Extensions",slug:"SLUG",tcn:"TCN",te:"TE",ttl:"TTL","www-authenticate":"WWW-Authenticate","x-att-deviceid":"X-ATT-DeviceId","x-dnsprefetch-control":"X-DNSPrefetch-Control","x-uidh":"X-UIDH"},K=(e,o)=>{let t=e.toLowerCase();return o?O[t]?O[t]:t.split("-").map(r=>r[0]?.toUpperCase()+r.slice(1)).join("-"):t},Z={canonical:!1,normalizeHeaderKey:K},B=e=>{let o={...Z,...e};return async(t,r,n)=>{let a={},s={};return Object.keys(t.headers).forEach(i=>{a[i]=t.headers[i];let d=o.normalizeHeaderKey(i,o.canonical);d&&(s[d]=t.headers[i]);}),t.headers=s,t.rawHeaders=a,n()}},S=B;var G=e=>{if(typeof e!="string")return !1;try{let o=JSON.parse(e),t=Object.prototype.toString.call(o);return t==="[object Object]"||t==="[object Array]"}catch{return !1}},E=G;var $=e=>jstoxml.toXML(e,{header:!0,indent:" "}),y=$;var g="Content-Type",Y=(e,o,t,r,n)=>{if(typeof t.getHeader(g)=="string")return r;let i=[...Q__default.default(o).types(),n.defaultContentType],d=r,N=!1;return i.forEach(c=>{e.forEach(({regex:P,serializer:k})=>{P.test(c)&&(t.setHeader(g,c),d=k(d),N=!0);}),N||(/yaml|yml/.test(c)?(t.setHeader(g,c),d=chunkYG667K32_js.b(E(r)?JSON.parse(r):r)):c.includes("xml")&&(t.setHeader(g,c),d=y({[chunkYG667K32_js.a(`${o.url?.replace("/api/","")}`.trim())]:E(r)?JSON.parse(r):r})));}),d},m=Y;var te=ee__default.default("api-platform:connect:serializers-middleware"),re=(e=[],o="application/json; charset=utf-8")=>async(t,r,n)=>{if(typeof r.send=="function"){let a=r.send;r.send=s=>{r.send=a,s=m(e,t,r,s,{defaultContentType:o}),r.send(s);};}else if(typeof r.json=="function")te("response.json() is not supported by @visulima/api-platform serializer. Use response.send() or response.end() instead.");else {let a=r.end;r.end=(s,...i)=>(r.end=a,s=m(e,t,r,s,{defaultContentType:o}),r.end(s,...i));}return n()},w=re;var se=(e={})=>new connect.NodeRouter({onError:h(e.errorHandlers??[],e.showTrace??!1),onNoMatch:H}).use(S(e.middlewares?.["http-header-normalizer"]??{})).use(w(e.middlewares?.serializers?.serializers??[],e.middlewares?.serializers?.defaultContentType??"application/json; charset=utf-8")),ne=se;var de=e=>connect.expressWrapper(ie__default.default(e)),pe=de;var le=e=>e.ip??e.headers["x-forwarded-for"]??e.headers["x-real-ip"]??e.socket.remoteAddress,ce=(e,o)=>async(t,r,n)=>{let a=le(t);if(a===void 0)throw q__default.default(400,"Missing IP");try{let s=await e.consume(a),i={"Retry-After":Math.round(s.msBeforeNext/1e3)||1,"X-RateLimit-Remaining":s.remainingPoints,"X-RateLimit-Reset":new Date(Date.now()+s.msBeforeNext).toISOString(),...o};Object.keys(i).forEach(d=>{r.setHeader(d,i[d]);}),await n();}catch{throw q__default.default(429,"Too Many Requests")}},me=ce;
1
+ 'use strict';var chunkUPRO35MO_js=require('./chunk-UPRO35MO.js'),chunkYG667K32_js=require('./chunk-YG667K32.js');require('./chunk-4C666HHU.js');var connect=require('@visulima/connect'),q=require('http-errors'),httpStatusCodes=require('http-status-codes'),x=require('ts-japi'),ee=require('debug'),Q=require('accepts'),jstoxml=require('jstoxml'),ie=require('cors');function _interopDefault(e){return e&&e.__esModule?e:{default:e}}var q__default=/*#__PURE__*/_interopDefault(q);var x__default=/*#__PURE__*/_interopDefault(x);var ee__default=/*#__PURE__*/_interopDefault(ee);var Q__default=/*#__PURE__*/_interopDefault(Q);var ie__default=/*#__PURE__*/_interopDefault(ie);var u=(e,o)=>{let t=o.headers??{};Object.keys(t).forEach(r=>{e.setHeader(r,t[r]);});},l=(e,o)=>{e.setHeader("content-type","application/json; charset=utf-8"),e.end(JSON.stringify(o));},R=(e,o)=>{o.statusCode!==undefined&&(e.statusCode=o.statusCode),o.status!==undefined&&(e.statusCode=o.status),e.statusCode<400&&(e.statusCode=httpStatusCodes.StatusCodes.INTERNAL_SERVER_ERROR);};var z="An error occurred",U=(e,o,t)=>{if(R(t,e),u(t,e),e instanceof x__default.default.JapiError||x__default.default.JapiError.isLikeJapiError(e)){let r=new x__default.default.ErrorSerializer;l(t,r.serialize(e));}else if(e instanceof q.HttpError){let{message:r,statusCode:n,title:a}=e;l(t,{errors:[{code:n,title:a||httpStatusCodes.getReasonPhrase(n)||z,detail:r}]});}else {let{message:r}=e;l(t,{errors:[{code:"500",title:httpStatusCodes.getReasonPhrase(t.statusCode)||z,detail:r}]});}},T=U;var M="https://tools.ietf.org/html/rfc2616#section-10",C="An error occurred",F=(e,o,t)=>{let{message:r,stack:n}=e;if(e instanceof q.HttpError){let{expose:a,statusCode:s,title:i,type:d}=e;t.statusCode=s,u(t,e),l(t,{type:d||M,title:i||httpStatusCodes.getReasonPhrase(s)||C,details:r,...a?{trace:n}:{}});}else R(t,e),l(t,{type:M,title:httpStatusCodes.getReasonPhrase(t.statusCode)||C,details:r,...e.expose?{trace:n}:{}});},I=F;var h=(e,o)=>async(t,r,n)=>{let a=r.headers.accept,s=I;a==="application/vnd.api+json"&&(s=T);for(let{handler:i,regex:d}of e)if(d.test(a)){s=i;break}t.expose=o,s(t,r,n);},H=async(e,o,t)=>{let r=[...new Set(t.map(n=>n.method))].join(", ");throw o.setHeader("Allow",r),o.statusCode=405,q__default.default(405,`No route with [${e.method}] method found.`)};var O={alpn:"ALPN","c-pep":"C-PEP","c-pep-info":"C-PEP-Info","caldav-timezones":"CalDAV-Timezones","content-id":"Content-ID","content-md5":"Content-MD5",dasl:"DASL",dav:"DAV",dnt:"DNT",etag:"ETag",getprofile:"GetProfile","http2-settings":"HTTP2-Settings","last-event-id":"Last-Event-ID","mime-version":"MIME-Version","optional-www-authenticate":"Optional-WWW-Authenticate","sec-webSocket-key":"Sec-WebSocket-Key","sec-webSocket-protocol":"Sec-WebSocket-Protocol","sec-webSocket-version":"Sec-WebSocket-Version","sec-websocket-accept":"Sec-WebSocket-Accept","sec-websocket-extensions":"Sec-WebSocket-Extensions",slug:"SLUG",tcn:"TCN",te:"TE",ttl:"TTL","www-authenticate":"WWW-Authenticate","x-att-deviceid":"X-ATT-DeviceId","x-dnsprefetch-control":"X-DNSPrefetch-Control","x-uidh":"X-UIDH"},K=(e,o)=>{let t=e.toLowerCase();return o?O[t]?O[t]:t.split("-").map(r=>r[0]?.toUpperCase()+r.slice(1)).join("-"):t},Z={canonical:false,normalizeHeaderKey:K},B=e=>{let o={...Z,...e};return async(t,r,n)=>{let a={},s={};return Object.keys(t.headers).forEach(i=>{a[i]=t.headers[i];let d=o.normalizeHeaderKey(i,o.canonical);d&&(s[d]=t.headers[i]);}),t.headers=s,t.rawHeaders=a,n()}},S=B;var G=e=>{if(typeof e!="string")return false;try{let o=JSON.parse(e),t=Object.prototype.toString.call(o);return t==="[object Object]"||t==="[object Array]"}catch{return false}},E=G;var $=e=>jstoxml.toXML(e,{header:true,indent:" "}),y=$;var g="Content-Type",Y=(e,o,t,r,n)=>{if(typeof t.getHeader(g)=="string")return r;let i=[...Q__default.default(o).types(),n.defaultContentType],d=r,N=false;return i.forEach(c=>{e.forEach(({regex:P,serializer:k})=>{P.test(c)&&(t.setHeader(g,c),d=k(d),N=true);}),N||(/yaml|yml/.test(c)?(t.setHeader(g,c),d=chunkYG667K32_js.b(E(r)?JSON.parse(r):r)):c.includes("xml")&&(t.setHeader(g,c),d=y({[chunkYG667K32_js.a(`${o.url?.replace("/api/","")}`.trim())]:E(r)?JSON.parse(r):r})));}),d},m=Y;var te=ee__default.default("api-platform:connect:serializers-middleware"),re=(e=[],o="application/json; charset=utf-8")=>async(t,r,n)=>{if(typeof r.send=="function"){let a=r.send;r.send=s=>{r.send=a,s=m(e,t,r,s,{defaultContentType:o}),r.send(s);};}else if(typeof r.json=="function")te("response.json() is not supported by @visulima/api-platform serializer. Use response.send() or response.end() instead.");else {let a=r.end;r.end=(s,...i)=>(r.end=a,s=m(e,t,r,s,{defaultContentType:o}),r.end(s,...i));}return n()},w=re;var se=(e={})=>new connect.NodeRouter({onError:h(e.errorHandlers??[],e.showTrace??false),onNoMatch:H}).use(S(e.middlewares?.["http-header-normalizer"]??{})).use(w(e.middlewares?.serializers?.serializers??[],e.middlewares?.serializers?.defaultContentType??"application/json; charset=utf-8")),ne=se;var de=e=>connect.expressWrapper(ie__default.default(e)),pe=de;var le=e=>e.ip??e.headers["x-forwarded-for"]??e.headers["x-real-ip"]??e.socket.remoteAddress,ce=(e,o)=>async(t,r,n)=>{let a=le(t);if(a===undefined)throw q__default.default(400,"Missing IP");try{let s=await e.consume(a),i={"Retry-After":Math.round(s.msBeforeNext/1e3)||1,"X-RateLimit-Remaining":s.remainingPoints,"X-RateLimit-Reset":new Date(Date.now()+s.msBeforeNext).toISOString(),...o};Object.keys(i).forEach(d=>{r.setHeader(d,i[d]);}),await n();}catch{throw q__default.default(429,"Too Many Requests")}},me=ce;
2
2
  Object.defineProperty(exports,"dateIn",{enumerable:true,get:function(){return chunkUPRO35MO_js.a}});Object.defineProperty(exports,"dateOut",{enumerable:true,get:function(){return chunkUPRO35MO_js.b}});Object.defineProperty(exports,"zod",{enumerable:true,get:function(){return chunkUPRO35MO_js.c}});Object.defineProperty(exports,"swaggerHandler",{enumerable:true,get:function(){return chunkYG667K32_js.c}});Object.defineProperty(exports,"yamlTransformer",{enumerable:true,get:function(){return chunkYG667K32_js.b}});Object.defineProperty(exports,"EdgeRouter",{enumerable:true,get:function(){return connect.EdgeRouter}});Object.defineProperty(exports,"NodeRouter",{enumerable:true,get:function(){return connect.NodeRouter}});Object.defineProperty(exports,"Router",{enumerable:true,get:function(){return connect.Router}});Object.defineProperty(exports,"createEdgeRouter",{enumerable:true,get:function(){return connect.createEdgeRouter}});Object.defineProperty(exports,"expressWrapper",{enumerable:true,get:function(){return connect.expressWrapper}});Object.defineProperty(exports,"sendJson",{enumerable:true,get:function(){return connect.sendJson}});Object.defineProperty(exports,"withZod",{enumerable:true,get:function(){return connect.withZod}});Object.defineProperty(exports,"BadGateway",{enumerable:true,get:function(){return q.BadGateway}});Object.defineProperty(exports,"BadRequest",{enumerable:true,get:function(){return q.BadRequest}});Object.defineProperty(exports,"BandwidthLimitExceeded",{enumerable:true,get:function(){return q.BandwidthLimitExceeded}});Object.defineProperty(exports,"Conflict",{enumerable:true,get:function(){return q.Conflict}});Object.defineProperty(exports,"ExpectationFailed",{enumerable:true,get:function(){return q.ExpectationFailed}});Object.defineProperty(exports,"FailedDependency",{enumerable:true,get:function(){return q.FailedDependency}});Object.defineProperty(exports,"Forbidden",{enumerable:true,get:function(){return q.Forbidden}});Object.defineProperty(exports,"GatewayTimeout",{enumerable:true,get:function(){return q.GatewayTimeout}});Object.defineProperty(exports,"Gone",{enumerable:true,get:function(){return q.Gone}});Object.defineProperty(exports,"HTTPVersionNotSupported",{enumerable:true,get:function(){return q.HTTPVersionNotSupported}});Object.defineProperty(exports,"ImATeapot",{enumerable:true,get:function(){return q.ImATeapot}});Object.defineProperty(exports,"InsufficientStorage",{enumerable:true,get:function(){return q.InsufficientStorage}});Object.defineProperty(exports,"InternalServerError",{enumerable:true,get:function(){return q.InternalServerError}});Object.defineProperty(exports,"LengthRequired",{enumerable:true,get:function(){return q.LengthRequired}});Object.defineProperty(exports,"Locked",{enumerable:true,get:function(){return q.Locked}});Object.defineProperty(exports,"LoopDetected",{enumerable:true,get:function(){return q.LoopDetected}});Object.defineProperty(exports,"MethodNotAllowed",{enumerable:true,get:function(){return q.MethodNotAllowed}});Object.defineProperty(exports,"MisdirectedRequest",{enumerable:true,get:function(){return q.MisdirectedRequest}});Object.defineProperty(exports,"NetworkAuthenticationRequire",{enumerable:true,get:function(){return q.NetworkAuthenticationRequire}});Object.defineProperty(exports,"NotAcceptable",{enumerable:true,get:function(){return q.NotAcceptable}});Object.defineProperty(exports,"NotExtended",{enumerable:true,get:function(){return q.NotExtended}});Object.defineProperty(exports,"NotFound",{enumerable:true,get:function(){return q.NotFound}});Object.defineProperty(exports,"NotImplemented",{enumerable:true,get:function(){return q.NotImplemented}});Object.defineProperty(exports,"PayloadTooLarge",{enumerable:true,get:function(){return q.PayloadTooLarge}});Object.defineProperty(exports,"PaymentRequired",{enumerable:true,get:function(){return q.PaymentRequired}});Object.defineProperty(exports,"PreconditionFailed",{enumerable:true,get:function(){return q.PreconditionFailed}});Object.defineProperty(exports,"PreconditionRequired",{enumerable:true,get:function(){return q.PreconditionRequired}});Object.defineProperty(exports,"ProxyAuthenticationRequired",{enumerable:true,get:function(){return q.ProxyAuthenticationRequired}});Object.defineProperty(exports,"RangeNotSatisfiable",{enumerable:true,get:function(){return q.RangeNotSatisfiable}});Object.defineProperty(exports,"RequestHeaderFieldsTooLarge",{enumerable:true,get:function(){return q.RequestHeaderFieldsTooLarge}});Object.defineProperty(exports,"RequestTimeout",{enumerable:true,get:function(){return q.RequestTimeout}});Object.defineProperty(exports,"ServiceUnavailable",{enumerable:true,get:function(){return q.ServiceUnavailable}});Object.defineProperty(exports,"TooManyRequests",{enumerable:true,get:function(){return q.TooManyRequests}});Object.defineProperty(exports,"URITooLong",{enumerable:true,get:function(){return q.URITooLong}});Object.defineProperty(exports,"Unauthorized",{enumerable:true,get:function(){return q.Unauthorized}});Object.defineProperty(exports,"UnavailableForLegalReasons",{enumerable:true,get:function(){return q.UnavailableForLegalReasons}});Object.defineProperty(exports,"UnprocessableEntity",{enumerable:true,get:function(){return q.UnprocessableEntity}});Object.defineProperty(exports,"UnsupportedMediaType",{enumerable:true,get:function(){return q.UnsupportedMediaType}});Object.defineProperty(exports,"UpgradeRequired",{enumerable:true,get:function(){return q.UpgradeRequired}});Object.defineProperty(exports,"VariantAlsoNegotiates",{enumerable:true,get:function(){return q.VariantAlsoNegotiates}});Object.defineProperty(exports,"createHttpError",{enumerable:true,get:function(){return q__default.default}});exports.corsMiddleware=pe;exports.createNodeRouter=ne;exports.httpHeaderNormalizerMiddleware=S;exports.onError=h;exports.onNoMatch=H;exports.rateLimiterMiddleware=me;exports.serialize=m;exports.serializersMiddleware=w;exports.xmlTransformer=y;//# sourceMappingURL=index-server.js.map
3
3
  //# sourceMappingURL=index-server.js.map