@kubb/oas 3.16.2 → 3.16.3
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/index-C15JQ8q-.d.ts +376 -0
- package/dist/index-CxCy5xxn.d.cts +376 -0
- package/dist/index.cjs +305 -329
- package/dist/index.cjs.map +1 -1
- package/dist/index.d.cts +51 -63
- package/dist/index.d.ts +51 -63
- package/dist/index.js +271 -314
- package/dist/index.js.map +1 -1
- package/dist/infer.cjs +0 -4
- package/dist/infer.d.cts +2 -379
- package/dist/infer.d.ts +2 -379
- package/dist/infer.js +1 -3
- package/package.json +14 -18
- package/src/utils.ts +5 -6
- package/dist/infer.cjs.map +0 -1
- package/dist/infer.js.map +0 -1
package/dist/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/types.ts","../src/Oas.ts","../src/utils.ts"],"names":["schema","OASNormalize"],"mappings":";;;;;;;;;;;AAeO,IAAM,WAAc,GAAA;AAAA,EACzB,GAAK,EAAA,KAAA;AAAA,EACL,IAAM,EAAA,MAAA;AAAA,EACN,GAAK,EAAA,KAAA;AAAA,EACL,KAAO,EAAA,OAAA;AAAA,EACP,MAAQ,EAAA,QAAA;AAAA,EACR,IAAM,EAAA,MAAA;AAAA,EACN,OAAS,EAAA,SAAA;AAAA,EACT,KAAO,EAAA;AACT;ACRa,IAAA,GAAA,GAAN,cAAwC,OAAQ,CAAA;AAAA,EACrD,QAAoB,GAAA;AAAA,IAClB,aAAe,EAAA;AAAA,GACjB;AAAA,EACA,QAAiB,GAAA,MAAA;AAAA,EAEjB,WAAY,CAAA,EAAE,GAAK,EAAA,IAAA,EAA2D,EAAA;AAC5E,IAAI,IAAA,OAAO,QAAQ,QAAU,EAAA;AAC3B,MAAM,GAAA,GAAA,IAAA,CAAK,MAAM,GAAG,CAAA;AAAA;AAGtB,IAAA,KAAA,CAAM,KAAoB,IAAI,CAAA;AAE9B,IAAA,IAAA,CAAK,QAAW,GAAA,GAAA;AAAA;AAClB,EAEA,WAAW,OAAkB,EAAA;AAC3B,IAAA,IAAA,CAAK,QAAW,GAAA,OAAA;AAAA;AAClB,EAEA,IAAI,OAAmB,GAAA;AACrB,IAAA,OAAO,IAAK,CAAA,QAAA;AAAA;AACd,EAEA,IAAI,IAAc,EAAA;AAChB,IAAA,MAAM,OAAU,GAAA,IAAA;AAChB,IAAA,IAAA,GAAO,KAAK,IAAK,EAAA;AACjB,IAAA,IAAI,SAAS,EAAI,EAAA;AACf,MAAO,OAAA,KAAA;AAAA;AAET,IAAI,IAAA,IAAA,CAAK,UAAW,CAAA,GAAG,CAAG,EAAA;AACxB,MAAA,IAAA,GAAO,UAAW,CAAA,kBAAA,CAAmB,IAAK,CAAA,SAAA,CAAU,CAAC,CAAC,CAAA;AAAA,KACjD,MAAA;AACL,MAAO,OAAA,IAAA;AAAA;AAET,IAAA,MAAM,OAAU,GAAA,WAAA,CAAY,GAAI,CAAA,IAAA,CAAK,KAAK,IAAI,CAAA;AAE9C,IAAA,IAAI,CAAC,OAAS,EAAA;AACZ,MAAA,MAAM,IAAI,KAAA,CAAM,CAAmC,gCAAA,EAAA,OAAO,CAAG,CAAA,CAAA,CAAA;AAAA;AAE/D,IAAO,OAAA,OAAA;AAAA;AACT,EAEA,OAAO,IAAc,EAAA;AACnB,IAAA,MAAM,GAAM,GAAA,IAAA,CAAK,KAAM,CAAA,GAAG,EAAE,GAAI,EAAA;AAChC,IAAO,OAAA,GAAA,KAAQ,KAAK,MAAY,GAAA,GAAA;AAAA;AAClC,EACA,GAAA,CAAI,MAAc,KAAgB,EAAA;AAChC,IAAA,IAAA,GAAO,KAAK,IAAK,EAAA;AACjB,IAAA,IAAI,SAAS,EAAI,EAAA;AACf,MAAO,OAAA,KAAA;AAAA;AAET,IAAI,IAAA,IAAA,CAAK,UAAW,CAAA,GAAG,CAAG,EAAA;AACxB,MAAA,IAAA,GAAO,UAAW,CAAA,kBAAA,CAAmB,IAAK,CAAA,SAAA,CAAU,CAAC,CAAC,CAAA;AAEtD,MAAA,WAAA,CAAY,GAAI,CAAA,IAAA,CAAK,GAAK,EAAA,IAAA,EAAM,KAAK,CAAA;AAAA;AACvC;AACF,EAEA,iBAAiB,MAA0E,EAAA;AACzF,IAAI,IAAA,CAAC,eAAgB,CAAA,MAAM,CAAG,EAAA;AAC5B,MAAO,OAAA,MAAA;AAAA;AAGT,IAAA,MAAM,EAAE,OAAU,GAAA,EAAI,EAAA,YAAA,KAAiB,MAAO,CAAA,aAAA;AAE9C,IAAI,IAAA,IAAA,CAAK,QAAS,CAAA,aAAA,KAAkB,SAAW,EAAA;AAC7C,MAAO,MAAA,CAAA,OAAA,CAAQ,OAAO,CAAE,CAAA,OAAA,CAAQ,CAAC,CAAC,UAAA,EAAY,YAAY,CAAM,KAAA;AAC9D,QAAA,IAAI,YAAc,EAAA;AAChB,UAAM,MAAA,WAAA,GAAc,IAAK,CAAA,GAAA,CAAI,YAAY,CAAA;AACzC,UAAI,IAAA,CAAC,YAAY,UAAY,EAAA;AAC3B,YAAA,WAAA,CAAY,aAAa,EAAC;AAAA;AAG5B,UAAM,MAAA,QAAA,GAAW,WAAY,CAAA,UAAA,CAAW,YAAY,CAAA;AAEpD,UAAA,IAAI,YAAY,UAAY,EAAA;AAC1B,YAAY,WAAA,CAAA,UAAA,CAAW,YAAY,CAAI,GAAA;AAAA,cACrC,GAAI,WAAY,CAAA,UAAA,GAAa,YAAY,UAAW,CAAA,YAAY,IAAI,EAAC;AAAA,cACrE,IAAM,EAAA,CAAC,GAAI,QAAA,EAAU,IAAM,EAAA,MAAA,CAAO,CAAC,KAAA,KAAU,KAAU,KAAA,UAAU,CAAK,IAAA,IAAK,UAAU;AAAA,aACvF;AAEA,YAAA,WAAA,CAAY,WAAW,CAAC,GAAI,YAAY,QAAY,IAAA,IAAK,YAAY,CAAA;AAErE,YAAK,IAAA,CAAA,GAAA,CAAI,cAAc,WAAW,CAAA;AAAA;AACpC;AACF,OACD,CAAA;AAAA;AAIH,IAAA,IAAI,OAAO,KAAO,EAAA;AAChB,MAAO,MAAA,CAAA,KAAA,CAAM,OAAQ,CAAA,CAACA,OAAW,KAAA;AAC/B,QAAI,IAAA,WAAA,CAAYA,OAAM,CAAG,EAAA;AACvB,UAAA,MAAM,GAAM,GAAA,IAAA,CAAK,MAAOA,CAAAA,OAAAA,CAAO,IAAI,CAAA;AACnC,UAAA,MAAM,SAAoC,GAAA,IAAA,CAAK,GAAIA,CAAAA,OAAAA,CAAO,IAAI,CAAA;AAE9D,UAAM,MAAA,cAAA,GAAiB,SAAU,CAAA,UAAA,GAAa,YAAY,CAAA;AAC1D,UAAM,MAAA,MAAA,GAAS,OAAO,CAAC,MAAA,CAAO,OAAO,OAAO,CAAA,CAAE,QAASA,CAAAA,OAAAA,CAAO,IAAI,CAAA;AAElE,UAAA,IAAI,MAAU,IAAA,cAAA,EAAgB,IAAM,EAAA,MAAA,KAAW,CAAG,EAAA;AAChD,YAAA,OAAA,CAAQ,cAAe,CAAA,IAAA,CAAK,CAAC,CAAC,IAAIA,OAAO,CAAA,IAAA;AAAA,qBAChC,MAAQ,EAAA;AACjB,YAAQ,OAAA,CAAA,GAAG,IAAIA,OAAO,CAAA,IAAA;AAAA;AACxB;AACF,OACD,CAAA;AAAA;AAGH,IAAA,IAAI,OAAO,KAAO,EAAA;AAChB,MAAO,MAAA,CAAA,KAAA,CAAM,OAAQ,CAAA,CAACA,OAAW,KAAA;AAC/B,QAAI,IAAA,WAAA,CAAYA,OAAM,CAAG,EAAA;AACvB,UAAA,MAAM,GAAM,GAAA,IAAA,CAAK,MAAOA,CAAAA,OAAAA,CAAO,IAAI,CAAA;AACnC,UAAA,MAAM,SAAoC,GAAA,IAAA,CAAK,GAAIA,CAAAA,OAAAA,CAAO,IAAI,CAAA;AAE9D,UAAM,MAAA,cAAA,GAAiB,SAAU,CAAA,UAAA,GAAa,YAAY,CAAA;AAC1D,UAAM,MAAA,MAAA,GAAS,OAAO,CAAC,MAAA,CAAO,OAAO,OAAO,CAAA,CAAE,QAASA,CAAAA,OAAAA,CAAO,IAAI,CAAA;AAElE,UAAA,IAAI,MAAU,IAAA,cAAA,EAAgB,IAAM,EAAA,MAAA,KAAW,CAAG,EAAA;AAChD,YAAA,OAAA,CAAQ,cAAe,CAAA,IAAA,CAAK,CAAC,CAAC,IAAIA,OAAO,CAAA,IAAA;AAAA,qBAChC,MAAQ,EAAA;AACjB,YAAQ,OAAA,CAAA,GAAG,IAAIA,OAAO,CAAA,IAAA;AAAA;AACxB;AACF,OACD,CAAA;AAAA;AAGH,IAAO,OAAA;AAAA,MACL,GAAG,MAAO,CAAA,aAAA;AAAA,MACV;AAAA,KACF;AAAA;AACF;AAAA,EAGA,mBAAmB,MAAkB,EAAA;AACnC,IAAI,IAAA,WAAA,CAAY,MAAM,CAAG,EAAA;AACvB,MAAO,OAAA;AAAA,QACL,GAAG,MAAA;AAAA,QACH,GAAG,IAAA,CAAK,GAAI,CAAA,MAAA,CAAO,IAAI,CAAA;AAAA,QACvB,MAAM,MAAO,CAAA;AAAA,OACf;AAAA;AAGF,IAAO,OAAA,MAAA;AAAA;AACT;AAAA;AAAA;AAAA,EAKA,wBAAwB,YAAoI,EAAA;AAC1J,IAAS,SAAA,eAAA,CAAgB,MAAM,YAAqC,EAAA;AAClE,MAAA,OAAO,CAAC,CAAC,GAAA;AAAA;AAGX,IAAA,OAAO,CAAC,WAAgB,KAAA;AACtB,MAAI,IAAA,CAAC,eAAgB,CAAA,YAAY,CAAG,EAAA;AAClC,QAAO,OAAA,KAAA;AAAA;AAGT,MAAI,IAAA,WAAA,CAAY,YAAY,CAAG,EAAA;AAG7B,QAAO,OAAA,KAAA;AAAA;AAGT,MAAI,IAAA,CAAC,aAAa,OAAS,EAAA;AACzB,QAAO,OAAA,KAAA;AAAA;AAGT,MAAA,IAAI,WAAa,EAAA;AACf,QAAI,IAAA,EAAE,WAAe,IAAA,YAAA,CAAa,OAAU,CAAA,EAAA;AAC1C,UAAO,OAAA,KAAA;AAAA;AAGT,QAAO,OAAA,YAAA,CAAa,QAAQ,WAAW,CAAA;AAAA;AAKzC,MAAI,IAAA,oBAAA;AACJ,MAAA,MAAM,YAAe,GAAA,MAAA,CAAO,IAAK,CAAA,YAAA,CAAa,OAAO,CAAA;AACrD,MAAa,YAAA,CAAA,OAAA,CAAQ,CAAC,EAAe,KAAA;AACnC,QAAA,IAAI,CAAC,oBAAA,IAAwB,eAAgB,CAAA,IAAA,CAAK,EAAE,CAAG,EAAA;AACrD,UAAuB,oBAAA,GAAA,EAAA;AAAA;AACzB,OACD,CAAA;AAED,MAAA,IAAI,CAAC,oBAAsB,EAAA;AACzB,QAAa,YAAA,CAAA,OAAA,CAAQ,CAAC,EAAe,KAAA;AACnC,UAAA,IAAI,CAAC,oBAAsB,EAAA;AACzB,YAAuB,oBAAA,GAAA,EAAA;AAAA;AACzB,SACD,CAAA;AAAA;AAGH,MAAA,IAAI,oBAAsB,EAAA;AACxB,QAAA,OAAO,CAAC,oBAAA,EAAsB,YAAa,CAAA,OAAA,CAAQ,oBAAoB,CAAI,EAAA,GAAI,YAAa,CAAA,WAAA,GAAc,CAAC,YAAA,CAAa,WAAW,CAAA,GAAI,EAAG,CAAA;AAAA;AAG5I,MAAO,OAAA,KAAA;AAAA,KACT;AAAA;AACF,EAEA,iBAAA,CAAkB,WAAsB,UAA2C,EAAA;AACjF,IAAI,IAAA,SAAA,CAAU,OAAO,SAAW,EAAA;AAC9B,MAAA,MAAA,CAAO,KAAK,SAAU,CAAA,MAAA,CAAO,SAAS,CAAE,CAAA,OAAA,CAAQ,CAAC,GAAQ,KAAA;AACvD,QAAA,MAAMA,OAAS,GAAA,SAAA,CAAU,MAAO,CAAA,SAAA,CAAW,GAAG,CAAA;AAC9C,QAAA,MAAM,IAAO,GAAA,WAAA,CAAYA,OAAM,CAAA,GAAIA,QAAO,IAAO,GAAA,MAAA;AAEjD,QAAA,IAAIA,WAAU,IAAM,EAAA;AAClB,UAAA,SAAA,CAAU,OAAO,SAAW,CAAA,GAAG,CAAI,GAAA,IAAA,CAAK,IAAI,IAAI,CAAA;AAAA;AAClD,OACD,CAAA;AAAA;AAGH,IAAA,MAAM,kBAAkB,IAAK,CAAA,uBAAA,CAAwB,SAAU,CAAA,uBAAA,CAAwB,UAAU,CAAC,CAAA;AAElG,IAAM,MAAA,EAAE,WAAY,EAAA,GAAI,IAAK,CAAA,QAAA;AAC7B,IAAM,MAAA,YAAA,GAAe,gBAAgB,WAAW,CAAA;AAEhD,IAAA,IAAI,iBAAiB,KAAO,EAAA;AAE1B,MAAA,OAAO,EAAC;AAAA;AAGV,IAAM,MAAA,MAAA,GAAS,MAAM,OAAQ,CAAA,YAAY,IAAI,YAAa,CAAA,CAAC,CAAE,CAAA,MAAA,GAAS,YAAa,CAAA,MAAA;AAEnF,IAAA,IAAI,CAAC,MAAQ,EAAA;AAGX,MAAA,OAAO,EAAC;AAAA;AAGV,IAAO,OAAA,IAAA,CAAK,mBAAmB,MAAM,CAAA;AAAA;AACvC,EAEA,iBAAiB,SAAgD,EAAA;AAC/D,IAAM,MAAA,EAAE,WAAY,EAAA,GAAI,IAAK,CAAA,QAAA;AAE7B,IAAI,IAAA,SAAA,CAAU,OAAO,WAAa,EAAA;AAChC,MAAA,SAAA,CAAU,OAAO,WAAc,GAAA,IAAA,CAAK,kBAAmB,CAAA,SAAA,CAAU,OAAO,WAAW,CAAA;AAAA;AAGrF,IAAM,MAAA,WAAA,GAAc,SAAU,CAAA,cAAA,CAAe,WAAW,CAAA;AAExD,IAAA,IAAI,gBAAgB,KAAO,EAAA;AACzB,MAAO,OAAA,MAAA;AAAA;AAGT,IAAM,MAAA,MAAA,GAAS,MAAM,OAAQ,CAAA,WAAW,IAAI,WAAY,CAAA,CAAC,CAAE,CAAA,MAAA,GAAS,WAAY,CAAA,MAAA;AAEhF,IAAA,IAAI,CAAC,MAAQ,EAAA;AACX,MAAO,OAAA,MAAA;AAAA;AAGT,IAAO,OAAA,IAAA,CAAK,mBAAmB,MAAM,CAAA;AAAA;AACvC,EAEA,mBAAA,CAAoB,WAAsB,KAAyD,EAAA;AACjG,IAAA,MAAM,EAAE,WAAc,GAAA,SAAA,CAAU,cAAe,EAAA,KAAM,IAAK,CAAA,QAAA;AAC1D,IAAA,MAAM,SAAS,SACZ,CAAA,aAAA,EACA,CAAA,GAAA,CAAI,CAAC,MAAW,KAAA;AACf,MAAO,OAAA,IAAA,CAAK,mBAAmB,MAAM,CAAA;AAAA,KACtC,CACA,CAAA,MAAA,CAAO,CAAC,CAAM,KAAA,CAAA,CAAE,OAAO,KAAK,CAAA;AAE/B,IAAI,IAAA,CAAC,OAAO,MAAQ,EAAA;AAClB,MAAO,OAAA,IAAA;AAAA;AAGT,IAAA,OAAO,MAAO,CAAA,MAAA;AAAA,MACZ,CAAC,QAAQ,cAAmB,KAAA;AAC1B,QAAA,MAAM,WAAW,cAAe,CAAA,OAAA,GAAU,WAAW,CAAA,EAAG,UAAW,cAAe,CAAA,MAAA;AAClF,QAAA,MAAM,QAAW,GAAA,CAAC,GAAI,MAAA,CAAO,YAAa,EAAC,EAAY,cAAe,CAAA,QAAA,GAAW,cAAe,CAAA,IAAA,GAAO,MAAS,CAAA,CAAE,OAAO,OAAO,CAAA;AAEhI,QAAO,OAAA;AAAA,UACL,GAAG,MAAA;AAAA,UACH,aAAa,MAAO,CAAA,WAAA;AAAA,UACpB,YAAY,MAAO,CAAA,UAAA;AAAA,UACnB,SAAS,MAAO,CAAA,OAAA;AAAA,UAChB,QAAA;AAAA,UACA,UAAY,EAAA;AAAA,YACV,GAAG,MAAO,CAAA,UAAA;AAAA,YACV,CAAC,cAAe,CAAA,IAAI,GAAG;AAAA,cACrB,aAAa,cAAe,CAAA,WAAA;AAAA,cAC5B,GAAG;AAAA;AACL;AACF,SACF;AAAA,OACF;AAAA,MACA,EAAE,MAAM,QAAU,EAAA,QAAA,EAAU,EAAI,EAAA,UAAA,EAAY,EAAG;AAAA,KACjD;AAAA;AACF,EAEA,MAAM,QAAW,GAAA;AACf,IAAA,MAAM,YAAe,GAAA,IAAI,YAAa,CAAA,IAAA,CAAK,GAAK,EAAA;AAAA,MAC9C,WAAa,EAAA,IAAA;AAAA,MACb,cAAgB,EAAA;AAAA,KACjB,CAAA;AAED,IAAA,OAAO,aAAa,QAAS,CAAA;AAAA,MAC3B,MAAQ,EAAA;AAAA,QACN,QAAU,EAAA;AAAA,UACR,MAAQ,EAAA;AAAA,YACN,QAAU,EAAA;AAAA;AACZ;AACF;AACF,KACD,CAAA;AAAA;AAEL;;;AC5TO,SAAS,oBAAoB,GAAqC,EAAA;AACvE,EAAA,OAAO,GAAO,IAAA,aAAA,CAAc,GAAG,CAAA,IAAK,EAAE,SAAa,IAAA,GAAA,CAAA;AACrD;AAKO,SAAS,sBAAsB,GAAuC,EAAA;AAC3E,EAAO,OAAA,GAAA,IAAO,cAAoC,GAAG,CAAA,IAAK,aAAa,GAAO,IAAA,GAAA,CAAI,OAAQ,CAAA,UAAA,CAAW,KAAK,CAAA;AAC5G;AAMO,SAAS,kBAAkB,GAA6D,EAAA;AAC7F,EAAA,OAAO,OAAO,IAAQ,IAAA,GAAA;AACxB;AAQO,SAAS,WAAW,MAA6D,EAAA;AACtF,EAAA,OAAO,MAAQ,EAAA,QAAA,IAAY,MAAS,GAAA,YAAY,CAAK,IAAA,KAAA;AACvD;AAOO,SAAS,YAAY,GAA2E,EAAA;AACrG,EAAA,OAAO,CAAC,CAAC,GAAO,IAAA,KAAA,CAAM,GAAG,CAAA;AAC3B;AAOO,SAAS,gBAAgB,GAAmF,EAAA;AACjH,EAAO,OAAA,CAAC,CAAC,GAAO,IAAA,GAAA,GAAM,eAAe,CAAK,IAAA,OAAO,IAAI,aAAkB,KAAA,QAAA;AACzE;AAUO,SAAS,WAAW,MAAgC,EAAA;AACzD,EAAA,IAAI,CAAC,MAAQ,EAAA;AACX,IAAO,OAAA,KAAA;AAAA;AAGT,EAAA,OAAO,KAAM,CAAA,OAAA,CAAQ,MAAO,CAAA,QAAQ,CAAI,GAAA,CAAC,CAAC,MAAA,CAAO,QAAU,EAAA,MAAA,GAAS,CAAC,CAAC,MAAO,CAAA,QAAA;AAC/E;AAEO,SAAS,WAAW,MAAgC,EAAA;AACzD,EAAO,OAAA,CAAC,WAAW,MAAM,CAAA;AAC3B;AAEA,eAAsB,KAAA,CACpB,SACA,EAAA,EAAE,QAAW,GAAA,GAAA,EAAK,SAAY,GAAA,IAAA,EAAM,WAAc,GAAA,IAAA,EAAgF,GAAA,EACpH,EAAA;AACd,EAAI,IAAA,OAAO,SAAc,KAAA,QAAA,IAAY,SAAW,EAAA;AAE9C,IAAM,MAAA,MAAA,GAAS,MAAM,UAAW,EAAA;AAChC,IAAM,MAAA,aAAA,GAAgB,MAAM,MAAO,CAAA,EAAE,KAAK,SAAW,EAAA,MAAA,EAAQ,IAAM,EAAA,SAAA,EAAW,CAAA;AAE9E,IAAO,OAAA,KAAA,CAAM,aAAc,CAAA,MAAA,CAAO,MAAM,CAAA;AAAA;AAG1C,EAAM,MAAA,YAAA,GAAe,IAAIC,YAAAA,CAAa,SAAW,EAAA;AAAA,IAC/C,WAAA;AAAA,IACA,cAAgB,EAAA;AAAA,GACjB,CAAA;AACD,EAAM,MAAA,QAAA,GAAY,MAAM,YAAA,CAAa,IAAK,EAAA;AAE1C,EAAI,IAAA,mBAAA,CAAoB,QAAQ,CAAG,EAAA;AACjC,IAAA,MAAM,EAAE,OAAQ,EAAA,GAAI,MAAM,eAAA,CAAgB,WAAW,QAAU,EAAA;AAAA,MAC7D,OAAS,EAAA;AAAA,KACV,CAAA;AAED,IAAA,OAAO,IAAI,QAAA,CAAS,EAAE,GAAA,EAAK,SAAwB,CAAA;AAAA;AAGrD,EAAA,OAAO,IAAI,QAAA,CAAS,EAAE,GAAA,EAAK,UAAU,CAAA;AACvC;AAEA,eAAsB,MAAM,SAAwC,EAAA,EAAE,WAAW,GAAI,EAAA,GAA+B,EAAkB,EAAA;AACpI,EAAA,MAAM,YAAY,MAAM,OAAA,CAAQ,IAAI,SAAU,CAAA,GAAA,CAAI,CAAC,CAAM,KAAA,KAAA,CAAM,CAAG,EAAA,EAAE,UAAU,WAAa,EAAA,KAAA,EAAO,WAAW,KAAM,EAAC,CAAC,CAAC,CAAA;AAEtH,EAAI,IAAA,SAAA,CAAU,WAAW,CAAG,EAAA;AAC1B,IAAM,MAAA,IAAI,MAAM,wCAAwC,CAAA;AAAA;AAG1D,EAAA,MAAM,SAAS,SAAU,CAAA,MAAA;AAAA,IACvB,CAAC,KAAK,OAAY,KAAA;AAChB,MAAO,OAAA,SAAA,CAAU,GAAK,EAAA,OAAA,CAAQ,QAAuB,CAAA;AAAA,KACvD;AAAA,IACA;AAAA,MACE,OAAS,EAAA,OAAA;AAAA,MACT,IAAM,EAAA;AAAA,QACJ,KAAO,EAAA,YAAA;AAAA,QACP,OAAS,EAAA;AAAA,OACX;AAAA,MACA,OAAO,EAAC;AAAA,MACR,UAAY,EAAA;AAAA,QACV,SAAS;AAAC;AACZ;AACF,GACF;AAEA,EAAA,OAAO,KAAM,CAAA,MAAA,EAAQ,EAAE,QAAA,EAAU,CAAA;AACnC","file":"index.js","sourcesContent":["import type * as OasTypes from 'oas/types'\n\n// external packages\nexport type { Operation } from 'oas/operation'\nexport type { HttpMethods as HttpMethod } from 'oas/types'\nexport type * as OasTypes from 'oas/types'\nexport type { OpenAPIV3, OpenAPIV3_1 } from 'openapi-types'\n\nexport type contentType = 'application/json' | (string & {})\n\nexport type SchemaObject = OasTypes.SchemaObject & {\n 'x-nullable'?: boolean\n $ref?: string\n}\n\nexport const HttpMethods = {\n GET: 'get',\n POST: 'post',\n PUT: 'put',\n PATCH: 'patch',\n DELETE: 'delete',\n HEAD: 'head',\n OPTIONS: 'options',\n TRACE: 'trace',\n} satisfies Record<Uppercase<OasTypes.HttpMethods>, OasTypes.HttpMethods>\n","import jsonpointer from 'jsonpointer'\nimport BaseOas from 'oas'\nimport type { Operation } from 'oas/operation'\nimport type { MediaTypeObject, OASDocument, ResponseObject, SchemaObject, User } from 'oas/types'\nimport { matchesMimeType } from 'oas/utils'\nimport OASNormalize from 'oas-normalize'\nimport type { OpenAPIV3 } from 'openapi-types'\nimport type { OasTypes } from './index.ts'\nimport type { contentType } from './types.ts'\nimport { isDiscriminator, isReference } from './utils.ts'\n\ntype Options = {\n contentType?: contentType\n discriminator?: 'strict' | 'inherit'\n}\n\nexport class Oas<const TOAS = unknown> extends BaseOas {\n #options: Options = {\n discriminator: 'strict',\n }\n document: TOAS = undefined as unknown as TOAS\n\n constructor({ oas, user }: { oas: TOAS | OASDocument | string; user?: User }) {\n if (typeof oas === 'string') {\n oas = JSON.parse(oas)\n }\n\n super(oas as OASDocument, user)\n\n this.document = oas as TOAS\n }\n\n setOptions(options: Options) {\n this.#options = options\n }\n\n get options(): Options {\n return this.#options\n }\n\n get($ref: string) {\n const origRef = $ref\n $ref = $ref.trim()\n if ($ref === '') {\n return false\n }\n if ($ref.startsWith('#')) {\n $ref = globalThis.decodeURIComponent($ref.substring(1))\n } else {\n return null\n }\n const current = jsonpointer.get(this.api, $ref)\n\n if (!current) {\n throw new Error(`Could not find a definition for ${origRef}.`)\n }\n return current\n }\n\n getKey($ref: string) {\n const key = $ref.split('/').pop()\n return key === '' ? undefined : key\n }\n set($ref: string, value: unknown) {\n $ref = $ref.trim()\n if ($ref === '') {\n return false\n }\n if ($ref.startsWith('#')) {\n $ref = globalThis.decodeURIComponent($ref.substring(1))\n\n jsonpointer.set(this.api, $ref, value)\n }\n }\n\n getDiscriminator(schema: OasTypes.SchemaObject): OpenAPIV3.DiscriminatorObject | undefined {\n if (!isDiscriminator(schema)) {\n return undefined\n }\n\n const { mapping = {}, propertyName } = schema.discriminator\n\n if (this.#options.discriminator === 'inherit') {\n Object.entries(mapping).forEach(([mappingKey, mappingValue]) => {\n if (mappingValue) {\n const childSchema = this.get(mappingValue)\n if (!childSchema.properties) {\n childSchema.properties = {}\n }\n\n const property = childSchema.properties[propertyName] as SchemaObject\n\n if (childSchema.properties) {\n childSchema.properties[propertyName] = {\n ...(childSchema.properties ? childSchema.properties[propertyName] : {}),\n enum: [...(property?.enum?.filter((value) => value !== mappingKey) ?? []), mappingKey],\n }\n\n childSchema.required = [...(childSchema.required ?? []), propertyName]\n\n this.set(mappingValue, childSchema)\n }\n }\n })\n }\n\n // loop over oneOf and add default mapping when none is defined\n if (schema.oneOf) {\n schema.oneOf.forEach((schema) => {\n if (isReference(schema)) {\n const key = this.getKey(schema.$ref)\n const refSchema: OpenAPIV3.SchemaObject = this.get(schema.$ref)\n // special case where enum in the schema is set without mapping being defined, see https://github.com/kubb-labs/kubb/issues/1669\n const propertySchema = refSchema.properties?.[propertyName] as OpenAPIV3.SchemaObject\n const canAdd = key && !Object.values(mapping).includes(schema.$ref)\n\n if (canAdd && propertySchema?.enum?.length === 1) {\n mapping[propertySchema.enum[0]] = schema.$ref\n } else if (canAdd) {\n mapping[key] = schema.$ref\n }\n }\n })\n }\n\n if (schema.anyOf) {\n schema.anyOf.forEach((schema) => {\n if (isReference(schema)) {\n const key = this.getKey(schema.$ref)\n const refSchema: OpenAPIV3.SchemaObject = this.get(schema.$ref)\n // special case where enum in the schema is set without mapping being defined, see https://github.com/kubb-labs/kubb/issues/1669\n const propertySchema = refSchema.properties?.[propertyName] as OpenAPIV3.SchemaObject\n const canAdd = key && !Object.values(mapping).includes(schema.$ref)\n\n if (canAdd && propertySchema?.enum?.length === 1) {\n mapping[propertySchema.enum[0]] = schema.$ref\n } else if (canAdd) {\n mapping[key] = schema.$ref\n }\n }\n })\n }\n\n return {\n ...schema.discriminator,\n mapping,\n }\n }\n\n // TODO add better typing\n dereferenceWithRef(schema?: unknown) {\n if (isReference(schema)) {\n return {\n ...schema,\n ...this.get(schema.$ref),\n $ref: schema.$ref,\n }\n }\n\n return schema\n }\n\n /**\n * Oas does not have a getResponseBody(contentType)\n */\n #getResponseBodyFactory(responseBody: boolean | ResponseObject): (contentType?: string) => MediaTypeObject | false | [string, MediaTypeObject, ...string[]] {\n function hasResponseBody(res = responseBody): res is ResponseObject {\n return !!res\n }\n\n return (contentType) => {\n if (!hasResponseBody(responseBody)) {\n return false\n }\n\n if (isReference(responseBody)) {\n // If the request body is still a `$ref` pointer we should return false because this library\n // assumes that you've run dereferencing beforehand.\n return false\n }\n\n if (!responseBody.content) {\n return false\n }\n\n if (contentType) {\n if (!(contentType in responseBody.content)) {\n return false\n }\n\n return responseBody.content[contentType]!\n }\n\n // Since no media type was supplied we need to find either the first JSON-like media type that\n // we've got, or the first available of anything else if no JSON-like media types are present.\n let availablecontentType: string | undefined\n const contentTypes = Object.keys(responseBody.content)\n contentTypes.forEach((mt: string) => {\n if (!availablecontentType && matchesMimeType.json(mt)) {\n availablecontentType = mt\n }\n })\n\n if (!availablecontentType) {\n contentTypes.forEach((mt: string) => {\n if (!availablecontentType) {\n availablecontentType = mt\n }\n })\n }\n\n if (availablecontentType) {\n return [availablecontentType, responseBody.content[availablecontentType]!, ...(responseBody.description ? [responseBody.description] : [])]\n }\n\n return false\n }\n }\n\n getResponseSchema(operation: Operation, statusCode: string | number): SchemaObject {\n if (operation.schema.responses) {\n Object.keys(operation.schema.responses).forEach((key) => {\n const schema = operation.schema.responses![key]\n const $ref = isReference(schema) ? schema.$ref : undefined\n\n if (schema && $ref) {\n operation.schema.responses![key] = this.get($ref)\n }\n })\n }\n\n const getResponseBody = this.#getResponseBodyFactory(operation.getResponseByStatusCode(statusCode))\n\n const { contentType } = this.#options\n const responseBody = getResponseBody(contentType)\n\n if (responseBody === false) {\n // return empty object because response will always be defined(request does not need a body)\n return {}\n }\n\n const schema = Array.isArray(responseBody) ? responseBody[1].schema : responseBody.schema\n\n if (!schema) {\n // return empty object because response will always be defined(request does not need a body)\n\n return {}\n }\n\n return this.dereferenceWithRef(schema)\n }\n\n getRequestSchema(operation: Operation): SchemaObject | undefined {\n const { contentType } = this.#options\n\n if (operation.schema.requestBody) {\n operation.schema.requestBody = this.dereferenceWithRef(operation.schema.requestBody)\n }\n\n const requestBody = operation.getRequestBody(contentType)\n\n if (requestBody === false) {\n return undefined\n }\n\n const schema = Array.isArray(requestBody) ? requestBody[1].schema : requestBody.schema\n\n if (!schema) {\n return undefined\n }\n\n return this.dereferenceWithRef(schema)\n }\n\n getParametersSchema(operation: Operation, inKey: 'path' | 'query' | 'header'): SchemaObject | null {\n const { contentType = operation.getContentType() } = this.#options\n const params = operation\n .getParameters()\n .map((schema) => {\n return this.dereferenceWithRef(schema)\n })\n .filter((v) => v.in === inKey)\n\n if (!params.length) {\n return null\n }\n\n return params.reduce(\n (schema, pathParameters) => {\n const property = pathParameters.content?.[contentType]?.schema ?? (pathParameters.schema as SchemaObject)\n const required = [...(schema.required || ([] as any)), pathParameters.required ? pathParameters.name : undefined].filter(Boolean)\n\n return {\n ...schema,\n description: schema.description,\n deprecated: schema.deprecated,\n example: schema.example,\n required,\n properties: {\n ...schema.properties,\n [pathParameters.name]: {\n description: pathParameters.description,\n ...property,\n },\n },\n }\n },\n { type: 'object', required: [], properties: {} } as SchemaObject,\n )\n }\n\n async valdiate() {\n const oasNormalize = new OASNormalize(this.api, {\n enablePaths: true,\n colorizeErrors: true,\n })\n\n return oasNormalize.validate({\n parser: {\n validate: {\n errors: {\n colorize: true,\n },\n },\n },\n })\n }\n}\n","import { isRef, isSchema } from 'oas/types'\nimport { isPlainObject, mergeDeep } from 'remeda'\n\nimport { bundle, loadConfig } from '@redocly/openapi-core'\nimport OASNormalize from 'oas-normalize'\nimport type { OASDocument } from 'oas/types'\nimport type { ParameterObject, SchemaObject } from 'oas/types'\nimport type { OpenAPI, OpenAPIV2, OpenAPIV3, OpenAPIV3_1 } from 'openapi-types'\nimport swagger2openapi from 'swagger2openapi'\nimport { Oas } from './Oas.ts'\n\nexport function isOpenApiV2Document(doc: any): doc is OpenAPIV2.Document {\n return doc && isPlainObject(doc) && !('openapi' in doc)\n}\nexport function isOpenApiV3Document(doc: any): doc is OpenAPIV3.Document {\n return doc && isPlainObject(doc) && 'openapi' in doc\n}\n\nexport function isOpenApiV3_1Document(doc: any): doc is OpenAPIV3_1.Document {\n return doc && isPlainObject<OpenAPIV3_1.Document>(doc) && 'openapi' in doc && doc.openapi.startsWith('3.1')\n}\n\nexport function isJSONSchema(obj?: unknown): obj is SchemaObject {\n return !!obj && isSchema(obj)\n}\n\nexport function isParameterObject(obj: ParameterObject | SchemaObject): obj is ParameterObject {\n return obj && 'in' in obj\n}\n\n/**\n * Determines if a schema is nullable, considering both the standard `nullable` property and the legacy `x-nullable` extension.\n *\n * @param schema - The schema object to check.\n * @returns `true` if the schema is marked as nullable; otherwise, `false`.\n */\nexport function isNullable(schema?: SchemaObject & { 'x-nullable'?: boolean }): boolean {\n return schema?.nullable ?? schema?.['x-nullable'] ?? false\n}\n\n/**\n * Determines if the given object is an OpenAPI ReferenceObject.\n *\n * @returns True if {@link obj} is a ReferenceObject; otherwise, false.\n */\nexport function isReference(obj?: any): obj is OpenAPIV3.ReferenceObject | OpenAPIV3_1.ReferenceObject {\n return !!obj && isRef(obj)\n}\n\n/**\n * Determines if the given object is a SchemaObject with a discriminator property of type DiscriminatorObject.\n *\n * @returns True if {@link obj} is a SchemaObject containing a non-string {@link discriminator} property.\n */\nexport function isDiscriminator(obj?: any): obj is SchemaObject & { discriminator: OpenAPIV3.DiscriminatorObject } {\n return !!obj && obj?.['discriminator'] && typeof obj.discriminator !== 'string'\n}\n\n/**\n * Determines whether a schema is required.\n *\n * Returns true if the schema has a non-empty {@link SchemaObject.required} array or a truthy {@link SchemaObject.required} property.\n *\n * @param schema - The schema object to check.\n * @returns True if the schema is required; otherwise, false.\n */\nexport function isRequired(schema?: SchemaObject): boolean {\n if (!schema) {\n return false\n }\n\n return Array.isArray(schema.required) ? !!schema.required?.length : !!schema.required\n}\n\nexport function isOptional(schema?: SchemaObject): boolean {\n return !isRequired(schema)\n}\n\nexport async function parse(\n pathOrApi: string | OASDocument,\n { oasClass = Oas, canBundle = true, enablePaths = true }: { oasClass?: typeof Oas; canBundle?: boolean; enablePaths?: boolean } = {},\n): Promise<Oas> {\n if (typeof pathOrApi === 'string' && canBundle) {\n // resolve external refs\n const config = await loadConfig()\n const bundleResults = await bundle({ ref: pathOrApi, config, base: pathOrApi })\n\n return parse(bundleResults.bundle.parsed)\n }\n\n const oasNormalize = new OASNormalize(pathOrApi, {\n enablePaths,\n colorizeErrors: true,\n })\n const document = (await oasNormalize.load()) as OpenAPI.Document\n\n if (isOpenApiV2Document(document)) {\n const { openapi } = await swagger2openapi.convertObj(document, {\n anchors: true,\n })\n\n return new oasClass({ oas: openapi as OASDocument })\n }\n\n return new oasClass({ oas: document })\n}\n\nexport async function merge(pathOrApi: Array<string | OASDocument>, { oasClass = Oas }: { oasClass?: typeof Oas } = {}): Promise<Oas> {\n const instances = await Promise.all(pathOrApi.map((p) => parse(p, { oasClass, enablePaths: false, canBundle: false })))\n\n if (instances.length === 0) {\n throw new Error('No OAS instances provided for merging.')\n }\n\n const merged = instances.reduce(\n (acc, current) => {\n return mergeDeep(acc, current.document as OASDocument)\n },\n {\n openapi: '3.0.0',\n info: {\n title: 'Merged API',\n version: '1.0.0',\n },\n paths: {},\n components: {\n schemas: {},\n },\n } as any,\n )\n\n return parse(merged, { oasClass })\n}\n"]}
|
|
1
|
+
{"version":3,"file":"index.js","names":["options: Options","#options","$ref: string","value: unknown","schema: OasTypes.SchemaObject","schema","refSchema: OpenAPIV3.SchemaObject","schema?: unknown","responseBody: boolean | ResponseObject","availablecontentType: string | undefined","mt: string","matchesMimeType","operation: Operation","statusCode: string | number","#getResponseBodyFactory","inKey: 'path' | 'query' | 'header'","doc: any","obj: ParameterObject | SchemaObject","schema?: SchemaObject & { 'x-nullable'?: boolean }","obj?: any","schema?: SchemaObject","pathOrApi: string | OASDocument","pathOrApi: Array<string | OASDocument>"],"sources":["../src/types.ts","../src/Oas.ts","../src/utils.ts"],"sourcesContent":["import type * as OasTypes from 'oas/types'\n\n// external packages\nexport type { Operation } from 'oas/operation'\nexport type { HttpMethods as HttpMethod } from 'oas/types'\nexport type * as OasTypes from 'oas/types'\nexport type { OpenAPIV3, OpenAPIV3_1 } from 'openapi-types'\n\nexport type contentType = 'application/json' | (string & {})\n\nexport type SchemaObject = OasTypes.SchemaObject & {\n 'x-nullable'?: boolean\n $ref?: string\n}\n\nexport const HttpMethods = {\n GET: 'get',\n POST: 'post',\n PUT: 'put',\n PATCH: 'patch',\n DELETE: 'delete',\n HEAD: 'head',\n OPTIONS: 'options',\n TRACE: 'trace',\n} satisfies Record<Uppercase<OasTypes.HttpMethods>, OasTypes.HttpMethods>\n","import jsonpointer from 'jsonpointer'\nimport BaseOas from 'oas'\nimport type { Operation } from 'oas/operation'\nimport type { MediaTypeObject, OASDocument, ResponseObject, SchemaObject, User } from 'oas/types'\nimport { matchesMimeType } from 'oas/utils'\nimport OASNormalize from 'oas-normalize'\nimport type { OpenAPIV3 } from 'openapi-types'\nimport type { OasTypes } from './index.ts'\nimport type { contentType } from './types.ts'\nimport { isDiscriminator, isReference } from './utils.ts'\n\ntype Options = {\n contentType?: contentType\n discriminator?: 'strict' | 'inherit'\n}\n\nexport class Oas<const TOAS = unknown> extends BaseOas {\n #options: Options = {\n discriminator: 'strict',\n }\n document: TOAS = undefined as unknown as TOAS\n\n constructor({ oas, user }: { oas: TOAS | OASDocument | string; user?: User }) {\n if (typeof oas === 'string') {\n oas = JSON.parse(oas)\n }\n\n super(oas as OASDocument, user)\n\n this.document = oas as TOAS\n }\n\n setOptions(options: Options) {\n this.#options = options\n }\n\n get options(): Options {\n return this.#options\n }\n\n get($ref: string) {\n const origRef = $ref\n $ref = $ref.trim()\n if ($ref === '') {\n return false\n }\n if ($ref.startsWith('#')) {\n $ref = globalThis.decodeURIComponent($ref.substring(1))\n } else {\n return null\n }\n const current = jsonpointer.get(this.api, $ref)\n\n if (!current) {\n throw new Error(`Could not find a definition for ${origRef}.`)\n }\n return current\n }\n\n getKey($ref: string) {\n const key = $ref.split('/').pop()\n return key === '' ? undefined : key\n }\n set($ref: string, value: unknown) {\n $ref = $ref.trim()\n if ($ref === '') {\n return false\n }\n if ($ref.startsWith('#')) {\n $ref = globalThis.decodeURIComponent($ref.substring(1))\n\n jsonpointer.set(this.api, $ref, value)\n }\n }\n\n getDiscriminator(schema: OasTypes.SchemaObject): OpenAPIV3.DiscriminatorObject | undefined {\n if (!isDiscriminator(schema)) {\n return undefined\n }\n\n const { mapping = {}, propertyName } = schema.discriminator\n\n if (this.#options.discriminator === 'inherit') {\n Object.entries(mapping).forEach(([mappingKey, mappingValue]) => {\n if (mappingValue) {\n const childSchema = this.get(mappingValue)\n if (!childSchema.properties) {\n childSchema.properties = {}\n }\n\n const property = childSchema.properties[propertyName] as SchemaObject\n\n if (childSchema.properties) {\n childSchema.properties[propertyName] = {\n ...(childSchema.properties ? childSchema.properties[propertyName] : {}),\n enum: [...(property?.enum?.filter((value) => value !== mappingKey) ?? []), mappingKey],\n }\n\n childSchema.required = [...(childSchema.required ?? []), propertyName]\n\n this.set(mappingValue, childSchema)\n }\n }\n })\n }\n\n // loop over oneOf and add default mapping when none is defined\n if (schema.oneOf) {\n schema.oneOf.forEach((schema) => {\n if (isReference(schema)) {\n const key = this.getKey(schema.$ref)\n const refSchema: OpenAPIV3.SchemaObject = this.get(schema.$ref)\n // special case where enum in the schema is set without mapping being defined, see https://github.com/kubb-labs/kubb/issues/1669\n const propertySchema = refSchema.properties?.[propertyName] as OpenAPIV3.SchemaObject\n const canAdd = key && !Object.values(mapping).includes(schema.$ref)\n\n if (canAdd && propertySchema?.enum?.length === 1) {\n mapping[propertySchema.enum[0]] = schema.$ref\n } else if (canAdd) {\n mapping[key] = schema.$ref\n }\n }\n })\n }\n\n if (schema.anyOf) {\n schema.anyOf.forEach((schema) => {\n if (isReference(schema)) {\n const key = this.getKey(schema.$ref)\n const refSchema: OpenAPIV3.SchemaObject = this.get(schema.$ref)\n // special case where enum in the schema is set without mapping being defined, see https://github.com/kubb-labs/kubb/issues/1669\n const propertySchema = refSchema.properties?.[propertyName] as OpenAPIV3.SchemaObject\n const canAdd = key && !Object.values(mapping).includes(schema.$ref)\n\n if (canAdd && propertySchema?.enum?.length === 1) {\n mapping[propertySchema.enum[0]] = schema.$ref\n } else if (canAdd) {\n mapping[key] = schema.$ref\n }\n }\n })\n }\n\n return {\n ...schema.discriminator,\n mapping,\n }\n }\n\n // TODO add better typing\n dereferenceWithRef(schema?: unknown) {\n if (isReference(schema)) {\n return {\n ...schema,\n ...this.get(schema.$ref),\n $ref: schema.$ref,\n }\n }\n\n return schema\n }\n\n /**\n * Oas does not have a getResponseBody(contentType)\n */\n #getResponseBodyFactory(responseBody: boolean | ResponseObject): (contentType?: string) => MediaTypeObject | false | [string, MediaTypeObject, ...string[]] {\n function hasResponseBody(res = responseBody): res is ResponseObject {\n return !!res\n }\n\n return (contentType) => {\n if (!hasResponseBody(responseBody)) {\n return false\n }\n\n if (isReference(responseBody)) {\n // If the request body is still a `$ref` pointer we should return false because this library\n // assumes that you've run dereferencing beforehand.\n return false\n }\n\n if (!responseBody.content) {\n return false\n }\n\n if (contentType) {\n if (!(contentType in responseBody.content)) {\n return false\n }\n\n return responseBody.content[contentType]!\n }\n\n // Since no media type was supplied we need to find either the first JSON-like media type that\n // we've got, or the first available of anything else if no JSON-like media types are present.\n let availablecontentType: string | undefined\n const contentTypes = Object.keys(responseBody.content)\n contentTypes.forEach((mt: string) => {\n if (!availablecontentType && matchesMimeType.json(mt)) {\n availablecontentType = mt\n }\n })\n\n if (!availablecontentType) {\n contentTypes.forEach((mt: string) => {\n if (!availablecontentType) {\n availablecontentType = mt\n }\n })\n }\n\n if (availablecontentType) {\n return [availablecontentType, responseBody.content[availablecontentType]!, ...(responseBody.description ? [responseBody.description] : [])]\n }\n\n return false\n }\n }\n\n getResponseSchema(operation: Operation, statusCode: string | number): SchemaObject {\n if (operation.schema.responses) {\n Object.keys(operation.schema.responses).forEach((key) => {\n const schema = operation.schema.responses![key]\n const $ref = isReference(schema) ? schema.$ref : undefined\n\n if (schema && $ref) {\n operation.schema.responses![key] = this.get($ref)\n }\n })\n }\n\n const getResponseBody = this.#getResponseBodyFactory(operation.getResponseByStatusCode(statusCode))\n\n const { contentType } = this.#options\n const responseBody = getResponseBody(contentType)\n\n if (responseBody === false) {\n // return empty object because response will always be defined(request does not need a body)\n return {}\n }\n\n const schema = Array.isArray(responseBody) ? responseBody[1].schema : responseBody.schema\n\n if (!schema) {\n // return empty object because response will always be defined(request does not need a body)\n\n return {}\n }\n\n return this.dereferenceWithRef(schema)\n }\n\n getRequestSchema(operation: Operation): SchemaObject | undefined {\n const { contentType } = this.#options\n\n if (operation.schema.requestBody) {\n operation.schema.requestBody = this.dereferenceWithRef(operation.schema.requestBody)\n }\n\n const requestBody = operation.getRequestBody(contentType)\n\n if (requestBody === false) {\n return undefined\n }\n\n const schema = Array.isArray(requestBody) ? requestBody[1].schema : requestBody.schema\n\n if (!schema) {\n return undefined\n }\n\n return this.dereferenceWithRef(schema)\n }\n\n getParametersSchema(operation: Operation, inKey: 'path' | 'query' | 'header'): SchemaObject | null {\n const { contentType = operation.getContentType() } = this.#options\n const params = operation\n .getParameters()\n .map((schema) => {\n return this.dereferenceWithRef(schema)\n })\n .filter((v) => v.in === inKey)\n\n if (!params.length) {\n return null\n }\n\n return params.reduce(\n (schema, pathParameters) => {\n const property = pathParameters.content?.[contentType]?.schema ?? (pathParameters.schema as SchemaObject)\n const required = [...(schema.required || ([] as any)), pathParameters.required ? pathParameters.name : undefined].filter(Boolean)\n\n return {\n ...schema,\n description: schema.description,\n deprecated: schema.deprecated,\n example: schema.example,\n required,\n properties: {\n ...schema.properties,\n [pathParameters.name]: {\n description: pathParameters.description,\n ...property,\n },\n },\n }\n },\n { type: 'object', required: [], properties: {} } as SchemaObject,\n )\n }\n\n async valdiate() {\n const oasNormalize = new OASNormalize(this.api, {\n enablePaths: true,\n colorizeErrors: true,\n })\n\n return oasNormalize.validate({\n parser: {\n validate: {\n errors: {\n colorize: true,\n },\n },\n },\n })\n }\n}\n","import type { OASDocument, ParameterObject, SchemaObject } from 'oas/types'\nimport { isRef, isSchema } from 'oas/types'\nimport OASNormalize from 'oas-normalize'\nimport type { OpenAPI, OpenAPIV2, OpenAPIV3, OpenAPIV3_1 } from 'openapi-types'\nimport { isPlainObject, mergeDeep } from 'remeda'\nimport swagger2openapi from 'swagger2openapi'\nimport { Oas } from './Oas.ts'\n\nexport function isOpenApiV2Document(doc: any): doc is OpenAPIV2.Document {\n return doc && isPlainObject(doc) && !('openapi' in doc)\n}\nexport function isOpenApiV3Document(doc: any): doc is OpenAPIV3.Document {\n return doc && isPlainObject(doc) && 'openapi' in doc\n}\n\nexport function isOpenApiV3_1Document(doc: any): doc is OpenAPIV3_1.Document {\n return doc && isPlainObject<OpenAPIV3_1.Document>(doc) && 'openapi' in doc && doc.openapi.startsWith('3.1')\n}\n\nexport function isJSONSchema(obj?: unknown): obj is SchemaObject {\n return !!obj && isSchema(obj)\n}\n\nexport function isParameterObject(obj: ParameterObject | SchemaObject): obj is ParameterObject {\n return obj && 'in' in obj\n}\n\n/**\n * Determines if a schema is nullable, considering both the standard `nullable` property and the legacy `x-nullable` extension.\n *\n * @param schema - The schema object to check.\n * @returns `true` if the schema is marked as nullable; otherwise, `false`.\n */\nexport function isNullable(schema?: SchemaObject & { 'x-nullable'?: boolean }): boolean {\n return schema?.nullable ?? schema?.['x-nullable'] ?? false\n}\n\n/**\n * Determines if the given object is an OpenAPI ReferenceObject.\n *\n * @returns True if {@link obj} is a ReferenceObject; otherwise, false.\n */\nexport function isReference(obj?: any): obj is OpenAPIV3.ReferenceObject | OpenAPIV3_1.ReferenceObject {\n return !!obj && isRef(obj)\n}\n\n/**\n * Determines if the given object is a SchemaObject with a discriminator property of type DiscriminatorObject.\n *\n * @returns True if {@link obj} is a SchemaObject containing a non-string {@link discriminator} property.\n */\nexport function isDiscriminator(obj?: any): obj is SchemaObject & { discriminator: OpenAPIV3.DiscriminatorObject } {\n return !!obj && obj?.['discriminator'] && typeof obj.discriminator !== 'string'\n}\n\n/**\n * Determines whether a schema is required.\n *\n * Returns true if the schema has a non-empty {@link SchemaObject.required} array or a truthy {@link SchemaObject.required} property.\n *\n * @param schema - The schema object to check.\n * @returns True if the schema is required; otherwise, false.\n */\nexport function isRequired(schema?: SchemaObject): boolean {\n if (!schema) {\n return false\n }\n\n return Array.isArray(schema.required) ? !!schema.required?.length : !!schema.required\n}\n\nexport function isOptional(schema?: SchemaObject): boolean {\n return !isRequired(schema)\n}\n\nexport async function parse(\n pathOrApi: string | OASDocument,\n { oasClass = Oas, canBundle = true, enablePaths = true }: { oasClass?: typeof Oas; canBundle?: boolean; enablePaths?: boolean } = {},\n): Promise<Oas> {\n const { loadConfig, bundle } = await import('@redocly/openapi-core')\n\n if (typeof pathOrApi === 'string' && canBundle) {\n // resolve external refs\n const config = await loadConfig()\n const bundleResults = await bundle({ ref: pathOrApi, config, base: pathOrApi })\n\n return parse(bundleResults.bundle.parsed as string)\n }\n\n const oasNormalize = new OASNormalize(pathOrApi, {\n enablePaths,\n colorizeErrors: true,\n })\n const document = (await oasNormalize.load()) as OpenAPI.Document\n\n if (isOpenApiV2Document(document)) {\n const { openapi } = await swagger2openapi.convertObj(document, {\n anchors: true,\n })\n\n return new oasClass({ oas: openapi as OASDocument })\n }\n\n return new oasClass({ oas: document })\n}\n\nexport async function merge(pathOrApi: Array<string | OASDocument>, { oasClass = Oas }: { oasClass?: typeof Oas } = {}): Promise<Oas> {\n const instances = await Promise.all(pathOrApi.map((p) => parse(p, { oasClass, enablePaths: false, canBundle: false })))\n\n if (instances.length === 0) {\n throw new Error('No OAS instances provided for merging.')\n }\n\n const merged = instances.reduce(\n (acc, current) => {\n return mergeDeep(acc, current.document as OASDocument)\n },\n {\n openapi: '3.0.0',\n info: {\n title: 'Merged API',\n version: '1.0.0',\n },\n paths: {},\n components: {\n schemas: {},\n },\n } as any,\n )\n\n return parse(merged, { oasClass })\n}\n"],"mappings":"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"}
|
package/dist/infer.cjs
CHANGED
package/dist/infer.d.cts
CHANGED
|
@@ -1,379 +1,2 @@
|
|
|
1
|
-
import {
|
|
2
|
-
|
|
3
|
-
import { JSONSchema, FromSchema } from 'json-schema-to-ts';
|
|
4
|
-
import * as OasTypes from 'oas/types';
|
|
5
|
-
|
|
6
|
-
type Checks$5 = {
|
|
7
|
-
AllOFf: {
|
|
8
|
-
allOf: any[];
|
|
9
|
-
};
|
|
10
|
-
Object: {
|
|
11
|
-
type: 'object';
|
|
12
|
-
properties: any;
|
|
13
|
-
};
|
|
14
|
-
Properties: {
|
|
15
|
-
properties: any;
|
|
16
|
-
};
|
|
17
|
-
PropertiesRequired: {
|
|
18
|
-
properties: Record<string, any>;
|
|
19
|
-
required: string[];
|
|
20
|
-
};
|
|
21
|
-
};
|
|
22
|
-
type FixAdditionalPropertiesForAllOf<T> = T extends Checks$5['AllOFf'] ? Omit<T, 'allOf'> & {
|
|
23
|
-
allOf: Call<Tuples.Map<Objects.Omit<'additionalProperties'>>, T['allOf']>;
|
|
24
|
-
} : T;
|
|
25
|
-
type FixMissingAdditionalProperties<T> = T extends Checks$5['Object'] ? Omit<T, 'additionalProperties'> & {
|
|
26
|
-
additionalProperties: false;
|
|
27
|
-
} : T;
|
|
28
|
-
type FixMissingTypeObject<T> = T extends Checks$5['Properties'] ? T & {
|
|
29
|
-
type: 'object';
|
|
30
|
-
} : T;
|
|
31
|
-
type FixExtraRequiredFields<T> = T extends Checks$5['PropertiesRequired'] ? Omit<T, 'required'> & {
|
|
32
|
-
required: Call<Tuples.Filter<Booleans.Extends<keyof T['properties']>>, T['required']>;
|
|
33
|
-
} : T;
|
|
34
|
-
type FixJSONSchema<T> = FixAdditionalPropertiesForAllOf<FixMissingAdditionalProperties<FixMissingTypeObject<FixExtraRequiredFields<T>>>>;
|
|
35
|
-
type Mutable<Type> = FixJSONSchema<{
|
|
36
|
-
-readonly [Key in keyof Type]: Mutable<Type[Key]>;
|
|
37
|
-
}>;
|
|
38
|
-
type RefToPath<T extends string> = T extends `#/${infer Ref}` ? Call<Strings.Split<'/'>, Ref> : never;
|
|
39
|
-
type ResolveRef<TObj, TRef extends string> = {
|
|
40
|
-
$id: TRef;
|
|
41
|
-
} & Object$1.Path<TObj, RefToPath<TRef>>;
|
|
42
|
-
type ResolveRefInObj<T, TBase> = T extends {
|
|
43
|
-
$ref: infer Ref;
|
|
44
|
-
} ? (Ref extends string ? ResolveRef<TBase, Ref> : T) : T;
|
|
45
|
-
type ResolveRefsInObj<T, TBase = T> = {
|
|
46
|
-
[K in keyof T]: ResolveRefsInObj<ResolveRefInObj<T[K], TBase>, TBase>;
|
|
47
|
-
};
|
|
48
|
-
type Infer<TOas> = Mutable<ResolveRefsInObj<TOas>>;
|
|
49
|
-
|
|
50
|
-
type Checks$4<TParamType = never> = {
|
|
51
|
-
Required: {
|
|
52
|
-
required: true;
|
|
53
|
-
};
|
|
54
|
-
Schemas: {
|
|
55
|
-
schema: JSONSchema;
|
|
56
|
-
};
|
|
57
|
-
Enum: {
|
|
58
|
-
type: JSONSchemaTypeName;
|
|
59
|
-
enum?: any[];
|
|
60
|
-
};
|
|
61
|
-
Parameters: {
|
|
62
|
-
in: string;
|
|
63
|
-
required?: boolean;
|
|
64
|
-
}[];
|
|
65
|
-
SingleParameter: [{
|
|
66
|
-
in: TParamType;
|
|
67
|
-
required?: true;
|
|
68
|
-
}];
|
|
69
|
-
Responses: {
|
|
70
|
-
responses: any;
|
|
71
|
-
};
|
|
72
|
-
};
|
|
73
|
-
type PathMap<TOAS extends OasTypes.OASDocument> = TOAS['paths'];
|
|
74
|
-
interface ParamPropMap {
|
|
75
|
-
query: 'query';
|
|
76
|
-
path: 'params';
|
|
77
|
-
header: 'headers';
|
|
78
|
-
}
|
|
79
|
-
type JSONSchemaTypeName = 'string' | 'number' | 'integer' | 'boolean' | 'object' | 'array' | 'null';
|
|
80
|
-
type ParamObj<TParameter extends {
|
|
81
|
-
name: string;
|
|
82
|
-
}> = TParameter extends Checks$4['Required'] ? {
|
|
83
|
-
[TName in TParameter['name']]: TParameter extends Checks$4['Schemas'] ? FromSchema<TParameter['schema']> : TParameter extends Checks$4['Enum'] ? FromSchema<{
|
|
84
|
-
type: TParameter['type'];
|
|
85
|
-
enum: TParameter['enum'];
|
|
86
|
-
}> : unknown;
|
|
87
|
-
} : {
|
|
88
|
-
[TName in TParameter['name']]?: TParameter extends Checks$4['Schemas'] ? FromSchema<TParameter['schema']> : TParameter extends Checks$4['Enum'] ? FromSchema<{
|
|
89
|
-
type: TParameter['type'];
|
|
90
|
-
enum: TParameter['enum'];
|
|
91
|
-
}> : unknown;
|
|
92
|
-
};
|
|
93
|
-
interface ParamToRequestParam<TParameters extends Checks$4['Parameters']> extends Fn {
|
|
94
|
-
return: this['arg0'] extends {
|
|
95
|
-
name: string;
|
|
96
|
-
in: infer TParamType;
|
|
97
|
-
} ? TParameters extends Checks$4<TParamType>['SingleParameter'] ? {
|
|
98
|
-
[TKey in TParamType extends keyof ParamPropMap ? ParamPropMap[TParamType] : never]: ParamObj<this['arg0']>;
|
|
99
|
-
} : {
|
|
100
|
-
[TKey in TParamType extends keyof ParamPropMap ? ParamPropMap[TParamType] : never]?: ParamObj<this['arg0']>;
|
|
101
|
-
} : {};
|
|
102
|
-
}
|
|
103
|
-
type ParamMap<TParameters extends Checks$4['Parameters']> = Pipe<TParameters, [Tuples.Map<ParamToRequestParam<TParameters>>, Tuples.ToIntersection]>;
|
|
104
|
-
type MethodMap<TOAS extends OasTypes.OASDocument, TPath extends keyof PathMap<TOAS>> = PathMap<TOAS>[TPath];
|
|
105
|
-
type StatusMap<TOAS extends OasTypes.OASDocument, TPath extends keyof PathMap<TOAS>, TMethod extends keyof MethodMap<TOAS, TPath>> = MethodMap<TOAS, TPath>[TMethod] extends Checks$4['Responses'] ? MethodMap<TOAS, TPath>[TMethod]['responses'] : never;
|
|
106
|
-
|
|
107
|
-
type Checks$3<TName extends string | number | symbol = never> = {
|
|
108
|
-
ModelWithSchemas: {
|
|
109
|
-
components: {
|
|
110
|
-
schemas: Record<string, JSONSchema>;
|
|
111
|
-
};
|
|
112
|
-
};
|
|
113
|
-
ModelWithSchemasNamed: {
|
|
114
|
-
components: {
|
|
115
|
-
schemas: {
|
|
116
|
-
[TModelName in TName]: JSONSchema;
|
|
117
|
-
};
|
|
118
|
-
};
|
|
119
|
-
};
|
|
120
|
-
ModelWithDefinitions: {
|
|
121
|
-
definitions: Record<string, JSONSchema>;
|
|
122
|
-
};
|
|
123
|
-
ModelWithDefinitionsNamed: {
|
|
124
|
-
definitions: {
|
|
125
|
-
[TModelName in TName]: JSONSchema;
|
|
126
|
-
};
|
|
127
|
-
};
|
|
128
|
-
};
|
|
129
|
-
type Model<TOAS extends OasTypes.OASDocument, TName extends TOAS extends Checks$3['ModelWithSchemas'] ? keyof TOAS['components']['schemas'] : TOAS extends Checks$3['ModelWithDefinitions'] ? keyof TOAS['definitions'] : never> = TOAS extends Checks$3<TName>['ModelWithSchemasNamed'] ? FromSchema<TOAS['components']['schemas'][TName]> : TOAS extends Checks$3<TName>['ModelWithDefinitionsNamed'] ? FromSchema<TOAS['definitions'][TName]> : never;
|
|
130
|
-
|
|
131
|
-
type Checks$2 = {
|
|
132
|
-
Security: {
|
|
133
|
-
security: {
|
|
134
|
-
[key: string]: any;
|
|
135
|
-
}[];
|
|
136
|
-
};
|
|
137
|
-
AuthParams: {
|
|
138
|
-
Basic: {
|
|
139
|
-
type: 'http';
|
|
140
|
-
scheme: 'basic';
|
|
141
|
-
} | {
|
|
142
|
-
type: 'basic';
|
|
143
|
-
};
|
|
144
|
-
Bearer: {
|
|
145
|
-
type: 'http';
|
|
146
|
-
scheme: 'bearer';
|
|
147
|
-
} | {
|
|
148
|
-
type: 'bearer';
|
|
149
|
-
};
|
|
150
|
-
OAuth2: {
|
|
151
|
-
type: 'oauth2';
|
|
152
|
-
};
|
|
153
|
-
ApiKey: {
|
|
154
|
-
type: 'apiKey';
|
|
155
|
-
in: 'header';
|
|
156
|
-
};
|
|
157
|
-
};
|
|
158
|
-
AuthName: {
|
|
159
|
-
Basic: `basic${string}`;
|
|
160
|
-
Bearer: `bearer${string}`;
|
|
161
|
-
OAuth2: `oauth${string}`;
|
|
162
|
-
};
|
|
163
|
-
};
|
|
164
|
-
type SecuritySchemeName<T extends Checks$2['Security']> = Call<Tuples.Map<Objects.Keys>, T['security']>[number];
|
|
165
|
-
declare namespace AuthParams {
|
|
166
|
-
type Basic<TSecurityScheme> = TSecurityScheme extends Checks$2['AuthParams']['Basic'] ? {
|
|
167
|
-
headers: {
|
|
168
|
-
/**
|
|
169
|
-
* `Authorization` header is required for basic authentication
|
|
170
|
-
* @see https://en.wikipedia.org/wiki/Basic_access_authentication
|
|
171
|
-
*
|
|
172
|
-
* It contains the word `Basic` followed by a space and a base64-encoded string `username:password`
|
|
173
|
-
*
|
|
174
|
-
* @example
|
|
175
|
-
* ```
|
|
176
|
-
* Authorization: Basic QWxhZGRpbjpvcGVuIHNlc2FtZQ==
|
|
177
|
-
* ```
|
|
178
|
-
*/
|
|
179
|
-
Authorization: `Basic ${string}`;
|
|
180
|
-
};
|
|
181
|
-
} : {};
|
|
182
|
-
type Bearer<TSecurityScheme> = TSecurityScheme extends Checks$2['AuthParams']['Bearer'] ? {
|
|
183
|
-
/**
|
|
184
|
-
* `Authorization` header is required for bearer authentication
|
|
185
|
-
* @see https://swagger.io/docs/specification/authentication/bearer-authentication/
|
|
186
|
-
*/
|
|
187
|
-
headers: {
|
|
188
|
-
/**
|
|
189
|
-
* It contains the word `Bearer` followed by a space and the token
|
|
190
|
-
*
|
|
191
|
-
* @example
|
|
192
|
-
* ```
|
|
193
|
-
* Authorization: Bearer {token}
|
|
194
|
-
* ```
|
|
195
|
-
*/
|
|
196
|
-
Authorization: `Bearer ${string}`;
|
|
197
|
-
};
|
|
198
|
-
} : {};
|
|
199
|
-
type ApiKey<TSecurityScheme> = TSecurityScheme extends Checks$2['AuthParams']['ApiKey'] & {
|
|
200
|
-
name: infer TApiKeyHeaderName;
|
|
201
|
-
} ? {
|
|
202
|
-
headers: {
|
|
203
|
-
[THeaderName in TApiKeyHeaderName extends string ? TApiKeyHeaderName : never]: string;
|
|
204
|
-
};
|
|
205
|
-
} : TSecurityScheme extends {
|
|
206
|
-
type: 'apiKey';
|
|
207
|
-
in: 'query';
|
|
208
|
-
name: infer TApiKeyQueryName;
|
|
209
|
-
} ? {
|
|
210
|
-
query: {
|
|
211
|
-
[TQueryName in TApiKeyQueryName extends string ? TApiKeyQueryName : never]: string;
|
|
212
|
-
};
|
|
213
|
-
} : {};
|
|
214
|
-
type OAuth2<TSecurityScheme> = TSecurityScheme extends Checks$2['AuthParams']['OAuth2'] ? {
|
|
215
|
-
/**
|
|
216
|
-
* `Authorization` header is required for OAuth2.
|
|
217
|
-
*/
|
|
218
|
-
headers: {
|
|
219
|
-
/**
|
|
220
|
-
* The access token string as issued by the authorization server.
|
|
221
|
-
* @example `Authorization: Bearer <access_token>`
|
|
222
|
-
*/
|
|
223
|
-
Authorization: `Bearer ${string}`;
|
|
224
|
-
};
|
|
225
|
-
} : {};
|
|
226
|
-
}
|
|
227
|
-
type OASSecurityParams<TSecurityScheme> = AuthParams.Basic<TSecurityScheme> & AuthParams.Bearer<TSecurityScheme> & AuthParams.ApiKey<TSecurityScheme> & AuthParams.OAuth2<TSecurityScheme>;
|
|
228
|
-
type SecurityParamsBySecurityRef<TOAS, TSecurityObj> = TSecurityObj extends Checks$2['Security'] ? TOAS extends {
|
|
229
|
-
components: {
|
|
230
|
-
securitySchemes: {
|
|
231
|
-
[TSecuritySchemeNameKey in SecuritySchemeName<TSecurityObj> extends string ? SecuritySchemeName<TSecurityObj> : never]: infer TSecurityScheme;
|
|
232
|
-
};
|
|
233
|
-
};
|
|
234
|
-
} | {
|
|
235
|
-
securityDefinitions: {
|
|
236
|
-
[TSecuritySchemeNameKey in SecuritySchemeName<TSecurityObj> extends string ? SecuritySchemeName<TSecurityObj> : never]: infer TSecurityScheme;
|
|
237
|
-
};
|
|
238
|
-
} ? OASSecurityParams<TSecurityScheme> : SecuritySchemeName<TSecurityObj> extends Checks$2['AuthName']['Basic'] ? AuthParams.Basic<{
|
|
239
|
-
type: 'http';
|
|
240
|
-
scheme: 'basic';
|
|
241
|
-
}> : SecuritySchemeName<TSecurityObj> extends Checks$2['AuthName']['Bearer'] ? AuthParams.Bearer<{
|
|
242
|
-
type: 'http';
|
|
243
|
-
scheme: 'bearer';
|
|
244
|
-
}> : SecuritySchemeName<TSecurityObj> extends Checks$2['AuthName']['OAuth2'] ? AuthParams.OAuth2<{
|
|
245
|
-
type: 'oauth2';
|
|
246
|
-
}> : {} : {};
|
|
247
|
-
|
|
248
|
-
type TupleToUnion<T> = T extends any[] ? T[number] : never;
|
|
249
|
-
type SplitByDelimiter<T extends string, D extends string> = T extends `${infer P}${D}${infer Q}` ? [P, ...SplitByDelimiter<Q, D>] : [T];
|
|
250
|
-
type Checks$1 = {
|
|
251
|
-
RequestBodyJson: {
|
|
252
|
-
requestBody: {
|
|
253
|
-
content: {
|
|
254
|
-
'application/json': {
|
|
255
|
-
schema: JSONSchema;
|
|
256
|
-
};
|
|
257
|
-
};
|
|
258
|
-
};
|
|
259
|
-
};
|
|
260
|
-
RequestBodyFormData: {
|
|
261
|
-
requestBody: {
|
|
262
|
-
content: {
|
|
263
|
-
'multipart/form-data': {
|
|
264
|
-
schema: JSONSchema;
|
|
265
|
-
};
|
|
266
|
-
};
|
|
267
|
-
};
|
|
268
|
-
};
|
|
269
|
-
RequestBodyFormEncoded: {
|
|
270
|
-
requestBody: {
|
|
271
|
-
content: {
|
|
272
|
-
'application/x-www-form-urlencoded': {
|
|
273
|
-
schema: JSONSchema;
|
|
274
|
-
};
|
|
275
|
-
};
|
|
276
|
-
};
|
|
277
|
-
};
|
|
278
|
-
Parameters: {
|
|
279
|
-
parameters: {
|
|
280
|
-
name: string;
|
|
281
|
-
in: string;
|
|
282
|
-
}[];
|
|
283
|
-
};
|
|
284
|
-
PathBrackets: `${string}{${string}}${string}`;
|
|
285
|
-
PathPattern: `${string}:${string}${string}`;
|
|
286
|
-
Required: {
|
|
287
|
-
required: true;
|
|
288
|
-
};
|
|
289
|
-
};
|
|
290
|
-
type ExtractPathParamsWithPattern<TPath extends string> = Pipe<TPath, [
|
|
291
|
-
Strings.Split<'/'>,
|
|
292
|
-
Tuples.Filter<Strings.StartsWith<':'>>,
|
|
293
|
-
Tuples.Map<Strings.Trim<':'>>,
|
|
294
|
-
Tuples.ToUnion
|
|
295
|
-
]>;
|
|
296
|
-
type IsPathParameter<T extends string> = T extends `{${infer U}}` ? U : never;
|
|
297
|
-
type ExtractPathParameters<T extends any[]> = {
|
|
298
|
-
[K in keyof T]: IsPathParameter<T[K]>;
|
|
299
|
-
};
|
|
300
|
-
type ExtractSegments<TPath extends string> = SplitByDelimiter<TPath, '/'>;
|
|
301
|
-
type ExtractSubSegments<T extends any[]> = {
|
|
302
|
-
[K in keyof T]: SplitByDelimiter<T[K], ';'>;
|
|
303
|
-
};
|
|
304
|
-
type ExtractPathParamsWithBrackets<TPath extends string> = TupleToUnion<ExtractPathParameters<ExtractSubSegments<ExtractSegments<TPath>>[number]>>;
|
|
305
|
-
type RequestParams<TOAS extends OasTypes.OASDocument, TPath extends keyof PathMap<TOAS>, TMethod extends keyof MethodMap<TOAS, TPath>> = (MethodMap<TOAS, TPath>[TMethod] extends Checks$1['RequestBodyJson'] ? MethodMap<TOAS, TPath>[TMethod]['requestBody'] extends Checks$1['Required'] ? {
|
|
306
|
-
/**
|
|
307
|
-
* The request body in JSON is required for this request.
|
|
308
|
-
*
|
|
309
|
-
* The value of `json` will be stringified and sent as the request body with `Content-Type: application/json`.
|
|
310
|
-
*/
|
|
311
|
-
json: FromSchema<MethodMap<TOAS, TPath>[TMethod]['requestBody']['content']['application/json']['schema']>;
|
|
312
|
-
} : {
|
|
313
|
-
/**
|
|
314
|
-
* The request body in JSON is optional for this request.
|
|
315
|
-
*
|
|
316
|
-
* The value of `json` will be stringified and sent as the request body with `Content-Type: application/json`.
|
|
317
|
-
*/
|
|
318
|
-
json?: FromSchema<MethodMap<TOAS, TPath>[TMethod]['requestBody']['content']['application/json']['schema']>;
|
|
319
|
-
} : MethodMap<TOAS, TPath>[TMethod] extends Checks$1['RequestBodyFormData'] ? MethodMap<TOAS, TPath>[TMethod]['requestBody'] extends Checks$1['Required'] ? {
|
|
320
|
-
/**
|
|
321
|
-
* The request body in multipart/form-data is required for this request.
|
|
322
|
-
*
|
|
323
|
-
* The value of `formData` will be sent as the request body with `Content-Type: multipart/form-data`.
|
|
324
|
-
*/
|
|
325
|
-
formData: FromSchema<MethodMap<TOAS, TPath>[TMethod]['requestBody']['content']['multipart/form-data']['schema']>;
|
|
326
|
-
} : {
|
|
327
|
-
/**
|
|
328
|
-
* The request body in multipart/form-data is optional for this request.
|
|
329
|
-
*
|
|
330
|
-
* The value of `formData` will be sent as the request body with `Content-Type: multipart/form-data`.
|
|
331
|
-
*/
|
|
332
|
-
formData?: FromSchema<MethodMap<TOAS, TPath>[TMethod]['requestBody']['content']['multipart/form-data']['schema']>;
|
|
333
|
-
} : MethodMap<TOAS, TPath>[TMethod] extends Checks$1['RequestBodyFormEncoded'] ? MethodMap<TOAS, TPath>[TMethod]['requestBody'] extends Checks$1['Required'] ? {
|
|
334
|
-
/**
|
|
335
|
-
* The request body in application/x-www-form-urlencoded is required for this request.
|
|
336
|
-
*
|
|
337
|
-
* The value of `formUrlEncoded` will be sent as the request body with `Content-Type: application/x-www-form-urlencoded`.
|
|
338
|
-
*/
|
|
339
|
-
formUrlEncoded: FromSchema<MethodMap<TOAS, TPath>[TMethod]['requestBody']['content']['application/x-www-form-urlencoded']['schema']>;
|
|
340
|
-
} : {
|
|
341
|
-
/**
|
|
342
|
-
* The request body in application/x-www-form-urlencoded is optional for this request.
|
|
343
|
-
*
|
|
344
|
-
* The value of `formUrlEncoded` will be sent as the request body with `Content-Type: application/x-www-form-urlencoded`.
|
|
345
|
-
*/
|
|
346
|
-
formUrlEncoded?: FromSchema<MethodMap<TOAS, TPath>[TMethod]['requestBody']['content']['application/x-www-form-urlencoded']['schema']>;
|
|
347
|
-
} : {}) & (MethodMap<TOAS, TPath>[TMethod] extends Checks$1['Parameters'] ? ParamMap<MethodMap<TOAS, TPath>[TMethod]['parameters']> : {}) & // If there is any parameters defined in path but not in the parameters array, we should add them to the params
|
|
348
|
-
(TPath extends Checks$1['PathBrackets'] ? {
|
|
349
|
-
/**
|
|
350
|
-
* Parameters defined in the path are required for this request.
|
|
351
|
-
*
|
|
352
|
-
* The value of `params` will be used to replace the path parameters.
|
|
353
|
-
*
|
|
354
|
-
* For example if path is `/todos/{id}` and `params` is `{ id: '1' }`, the path will be `/todos/1`
|
|
355
|
-
*/
|
|
356
|
-
params: Record<ExtractPathParamsWithBrackets<TPath>, string | number | bigint | boolean>;
|
|
357
|
-
} : {}) & (TPath extends Checks$1['PathPattern'] ? {
|
|
358
|
-
/**
|
|
359
|
-
* Parameters defined in the path are required for this request.
|
|
360
|
-
*
|
|
361
|
-
* The value of `params` will be used to replace the path parameters.
|
|
362
|
-
*
|
|
363
|
-
* For example if path is `/todos/:id` and `params` is `{ id: '1' }`, the path will be `/todos/1`.
|
|
364
|
-
*/
|
|
365
|
-
params: Record<ExtractPathParamsWithPattern<TPath>, string | number | bigint | boolean>;
|
|
366
|
-
} : {}) & // Respect security definitions in path object
|
|
367
|
-
SecurityParamsBySecurityRef<TOAS, MethodMap<TOAS, TPath>[TMethod]> & // Respect global security definitions
|
|
368
|
-
SecurityParamsBySecurityRef<TOAS, TOAS>;
|
|
369
|
-
|
|
370
|
-
type Checks = {
|
|
371
|
-
Content: {
|
|
372
|
-
content: any;
|
|
373
|
-
};
|
|
374
|
-
};
|
|
375
|
-
type ResponseSchemas<TOAS extends OasTypes.OASDocument, TPath extends keyof PathMap<TOAS>, TMethod extends keyof MethodMap<TOAS, TPath>, TStatus extends keyof StatusMap<TOAS, TPath, TMethod>> = StatusMap<TOAS, TPath, TMethod>[TStatus]['content'];
|
|
376
|
-
type JSONResponseSchema<TOAS extends OasTypes.OASDocument, TPath extends keyof PathMap<TOAS>, TMethod extends keyof MethodMap<TOAS, TPath>, TStatus extends keyof StatusMap<TOAS, TPath, TMethod>> = StatusMap<TOAS, TPath, TMethod>[TStatus] extends Checks['Content'] ? ResponseSchemas<TOAS, TPath, TMethod, TStatus>[keyof ResponseSchemas<TOAS, TPath, TMethod, TStatus>]['schema'] : StatusMap<TOAS, TPath, TMethod>[TStatus]['schema'];
|
|
377
|
-
type Response<TOAS extends OasTypes.OASDocument, TPath extends keyof PathMap<TOAS>, TMethod extends keyof MethodMap<TOAS, TPath>, TStatusCode extends keyof StatusMap<TOAS, TPath, TMethod> = 200> = FromSchema<JSONResponseSchema<TOAS, TPath, TMethod, TStatusCode>>;
|
|
378
|
-
|
|
379
|
-
export type { Infer, MethodMap, Model, PathMap, RequestParams, Response, StatusMap };
|
|
1
|
+
import { Infer, MethodMap, Model, PathMap, RequestParams, Response, StatusMap } from "./index-CxCy5xxn.cjs";
|
|
2
|
+
export { Infer, MethodMap, Model, PathMap, RequestParams, Response, StatusMap };
|