@visulima/api-platform 1.2.3 → 1.2.5

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (73) hide show
  1. package/CHANGELOG.md +26 -0
  2. package/dist/chunk-2ZMPKWQQ.mjs +5 -0
  3. package/dist/chunk-4GBB2H25.mjs +13 -0
  4. package/dist/chunk-4GBB2H25.mjs.map +1 -0
  5. package/dist/chunk-4ZTB2SHJ.mjs +9 -0
  6. package/dist/chunk-4ZTB2SHJ.mjs.map +1 -0
  7. package/dist/chunk-A2BQLJ5W.mjs +7 -0
  8. package/dist/chunk-A2BQLJ5W.mjs.map +1 -0
  9. package/dist/chunk-BIZOICFF.js +13 -0
  10. package/dist/chunk-BIZOICFF.js.map +1 -0
  11. package/dist/chunk-DELU3TYG.js +8 -0
  12. package/dist/chunk-NH4B62H7.js +25 -0
  13. package/dist/chunk-NH4B62H7.js.map +1 -0
  14. package/dist/chunk-QJNODCPR.js +13 -0
  15. package/dist/chunk-QJNODCPR.js.map +1 -0
  16. package/dist/chunk-S26T4TPK.mjs +17 -0
  17. package/dist/chunk-S26T4TPK.mjs.map +1 -0
  18. package/dist/chunk-SNOJMSHW.js +24 -0
  19. package/dist/chunk-SNOJMSHW.js.map +1 -0
  20. package/dist/framework/cli/commander/index.js +3 -3
  21. package/dist/framework/cli/commander/index.mjs +2 -2
  22. package/dist/framework/cli/index.js +3 -3
  23. package/dist/framework/cli/index.mjs +2 -2
  24. package/dist/framework/next/index-browser.d.ts +1 -3
  25. package/dist/framework/next/index-browser.js +3 -11
  26. package/dist/framework/next/index-browser.mjs +2 -2
  27. package/dist/framework/next/index-server.d.ts +3 -5
  28. package/dist/framework/next/index-server.js +13 -16
  29. package/dist/framework/next/index-server.js.map +1 -1
  30. package/dist/framework/next/index-server.mjs +7 -7
  31. package/dist/framework/next/index-server.mjs.map +1 -1
  32. package/dist/framework/next/routes/pages/redoc/index.d.ts +7 -0
  33. package/dist/framework/next/routes/pages/redoc/index.js +20 -0
  34. package/dist/framework/next/routes/pages/redoc/index.js.map +1 -0
  35. package/dist/framework/next/routes/pages/redoc/index.mjs +14 -0
  36. package/dist/framework/next/routes/pages/redoc/index.mjs.map +1 -0
  37. package/dist/framework/next/routes/pages/swagger/index.d.ts +7 -0
  38. package/dist/framework/next/routes/pages/swagger/index.js +21 -0
  39. package/dist/framework/next/routes/pages/swagger/index.js.map +1 -0
  40. package/dist/framework/next/routes/pages/swagger/index.mjs +14 -0
  41. package/dist/framework/next/routes/pages/swagger/index.mjs.map +1 -0
  42. package/dist/get-static-properties-swagger-546ee3ba.d.ts +5 -0
  43. package/dist/index-browser.js +3 -3
  44. package/dist/index-browser.mjs +2 -2
  45. package/dist/index-server.d.ts +3 -3
  46. package/dist/index-server.js +22 -10
  47. package/dist/index-server.js.map +1 -1
  48. package/dist/index-server.mjs +4 -4
  49. package/dist/index-server.mjs.map +1 -1
  50. package/next/pages/redoc/package.json +19 -0
  51. package/next/pages/swagger/package.json +19 -0
  52. package/package.json +77 -63
  53. package/dist/chunk-EP2A5R2C.js +0 -13
  54. package/dist/chunk-EP2A5R2C.js.map +0 -1
  55. package/dist/chunk-ESKLEDNF.mjs +0 -13
  56. package/dist/chunk-ESKLEDNF.mjs.map +0 -1
  57. package/dist/chunk-IMU5ULVF.js +0 -18
  58. package/dist/chunk-IMU5ULVF.js.map +0 -1
  59. package/dist/chunk-OC7L637G.js +0 -23
  60. package/dist/chunk-OC7L637G.js.map +0 -1
  61. package/dist/chunk-OUWZ2PU5.js +0 -7
  62. package/dist/chunk-PXVY7JQL.js +0 -19
  63. package/dist/chunk-PXVY7JQL.js.map +0 -1
  64. package/dist/chunk-R22PP2JL.mjs +0 -17
  65. package/dist/chunk-R22PP2JL.mjs.map +0 -1
  66. package/dist/chunk-SCOIFGN7.mjs +0 -19
  67. package/dist/chunk-SCOIFGN7.mjs.map +0 -1
  68. package/dist/chunk-WJDS32PO.mjs +0 -9
  69. package/dist/chunk-WJDS32PO.mjs.map +0 -1
  70. package/dist/chunk-YOXCJZNX.mjs +0 -5
  71. package/dist/swagger-b2ff43e0.d.ts +0 -11
  72. /package/dist/{chunk-OUWZ2PU5.js.map → chunk-2ZMPKWQQ.mjs.map} +0 -0
  73. /package/dist/{chunk-YOXCJZNX.mjs.map → chunk-DELU3TYG.js.map} +0 -0
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@visulima/api-platform",
3
- "version": "1.2.3",
3
+ "version": "1.2.5",
4
4
  "description": "Visulima API platform is a set of tools to build and consume web APIs",
5
5
  "keywords": [
6
6
  "anolilab",
@@ -65,6 +65,18 @@
65
65
  "require": "./dist/framework/next/index-server.js",
66
66
  "import": "./dist/framework/next/index-server.mjs"
67
67
  },
68
+ "./next/pages/swagger": {
69
+ "types": "./dist/framework/next/routes/pages/swagger/index.d.ts",
70
+ "browser": "./dist/framework/next/routes/pages/swagger/index.js",
71
+ "require": "./dist/framework/next/routes/pages/swagger/index.js",
72
+ "import": "./dist/framework/next/routes/pages/swagger/index.js"
73
+ },
74
+ "./next/pages/redoc": {
75
+ "types": "./dist/framework/next/routes/pages/redoc/index.d.ts",
76
+ "browser": "./dist/framework/next/routes/pages/redoc/index.js",
77
+ "require": "./dist/framework/next/routes/pages/redoc/index.js",
78
+ "import": "./dist/framework/next/routes/pages/redoc/index.js"
79
+ },
68
80
  "./cli": {
69
81
  "types": "./dist/framework/cli/index-server.d.ts",
70
82
  "require": "./dist/framework/cli/index-server.js",
@@ -100,55 +112,56 @@
100
112
  "test:watch": "vitest"
101
113
  },
102
114
  "dependencies": {
103
- "@visulima/connect": "1.3.3",
104
- "@visulima/jsdoc-open-api": "1.3.2",
115
+ "@visulima/connect": "1.3.4",
116
+ "@visulima/jsdoc-open-api": "1.3.4",
105
117
  "accepts": "^1.3.8",
106
118
  "debug": "^4.3.4",
107
119
  "http-errors": "^2.0.0",
108
120
  "http-status-codes": "^2.2.0",
109
- "jstoxml": "^3.2.6",
121
+ "jstoxml": "^3.2.7",
110
122
  "lodash.merge": "^4.6.2",
111
- "schema-dts": "^1.1.0",
123
+ "schema-dts": "^1.1.2",
112
124
  "ts-japi": "^1.8.0",
113
- "yaml": "^2.2.1",
114
- "zod-to-ts": "^1.1.2"
125
+ "yaml": "^2.3.0",
126
+ "zod-to-ts": "^1.1.4"
115
127
  },
116
128
  "devDependencies": {
117
- "@anolilab/eslint-config": "^5.0.2",
118
- "@anolilab/semantic-release-preset": "^2.2.0",
119
- "@hapi/hapi": "^21.2.0",
129
+ "@anolilab/eslint-config": "^5.0.5",
130
+ "@anolilab/semantic-release-preset": "^2.2.1",
131
+ "@hapi/hapi": "^21.3.2",
120
132
  "@koa/router": "^12.0.0",
121
- "@rushstack/eslint-plugin-security": "^0.5.0",
122
- "@testing-library/react": "^13.4.0",
133
+ "@rushstack/eslint-plugin-security": "^0.6.0",
134
+ "@testing-library/react": "^14.0.0",
123
135
  "@testing-library/react-hooks": "^8.0.1",
124
136
  "@types/accepts": "^1.3.5",
125
137
  "@types/cors": "^2.8.13",
126
- "@types/debug": "^4.1.7",
127
- "@types/express": "^4.17.16",
128
- "@types/express-serve-static-core": "^4.17.33",
138
+ "@types/debug": "^4.1.8",
139
+ "@types/express": "^4.17.17",
140
+ "@types/express-serve-static-core": "^4.17.35",
129
141
  "@types/http-errors": "^2.0.1",
130
142
  "@types/jstoxml": "^2.0.2",
131
- "@types/koa": "^2.13.5",
143
+ "@types/koa": "^2.13.6",
132
144
  "@types/koa__router": "^12.0.0",
133
145
  "@types/lodash.merge": "^4.6.7",
134
146
  "@types/lodash.set": "^4.3.7",
135
- "@types/node": "^18.11.18",
147
+ "@types/node": "18.16.14",
136
148
  "@types/qs": "^6.9.7",
137
- "@types/react": "^18.0.27",
138
- "@types/react-dom": "^18.0.10",
139
- "@types/swagger-ui-react": "^4.11.0",
140
- "@types/webpack": "^5.28.0",
141
- "@typescript-eslint/eslint-plugin": "^5.49.0",
142
- "@typescript-eslint/parser": "^5.49.0",
143
- "@visulima/crud": "1.0.10",
144
- "@visulima/readdir": "1.3.4",
145
- "chalk": "4.1.2",
146
- "commander": "^10.0.0",
147
- "core-js": "^3.27.2",
149
+ "@types/react": "^18.2.7",
150
+ "@types/react-dom": "^18.2.4",
151
+ "@types/swagger-ui-react": "^4.18.0",
152
+ "@types/webpack": "^5.28.1",
153
+ "@typescript-eslint/eslint-plugin": "^5.59.7",
154
+ "@typescript-eslint/parser": "^5.59.7",
155
+ "@visulima/crud": "1.0.11",
156
+ "@visulima/readdir": "1.3.5",
157
+ "@vitest/coverage-c8": "^0.31.1",
158
+ "chalk": "5.2.0",
159
+ "commander": "^10.0.1",
160
+ "core-js": "^3.30.2",
148
161
  "cors": "^2.8.5",
149
162
  "cross-env": "^7.0.3",
150
- "eslint": "^8.32.0",
151
- "eslint-plugin-compat": "^4.0.2",
163
+ "eslint": "^8.41.0",
164
+ "eslint-plugin-compat": "^4.1.4",
152
165
  "eslint-plugin-eslint-comments": "^3.2.0",
153
166
  "eslint-plugin-import": "^2.27.5",
154
167
  "eslint-plugin-json": "^3.1.0",
@@ -159,39 +172,38 @@
159
172
  "eslint-plugin-node": "^11.1.0",
160
173
  "eslint-plugin-optimize-regex": "^1.2.1",
161
174
  "eslint-plugin-promise": "^6.1.1",
162
- "eslint-plugin-radar": "^0.2.1",
163
- "eslint-plugin-react": "7.32.1",
175
+ "eslint-plugin-react": "7.32.2",
164
176
  "eslint-plugin-react-hooks": "4.6.0",
165
- "eslint-plugin-simple-import-sort": "^9.0.0",
177
+ "eslint-plugin-simple-import-sort": "^10.0.0",
166
178
  "eslint-plugin-sort-keys-fix": "^1.1.2",
167
- "eslint-plugin-testing-library": "^5.10.0",
168
- "eslint-plugin-unicorn": "^45.0.2",
179
+ "eslint-plugin-testing-library": "^5.11.0",
180
+ "eslint-plugin-unicorn": "^47.0.0",
169
181
  "eslint-plugin-you-dont-need-lodash-underscore": "^6.12.0",
170
182
  "eslint-plugin-you-dont-need-momentjs": "^1.6.0",
171
183
  "express": "^4.18.2",
172
- "fastify": "^4.12.0",
173
- "koa": "^2.14.1",
174
- "mobx": "^6.7.0",
184
+ "fastify": "^4.17.0",
185
+ "koa": "^2.14.2",
186
+ "mobx": "^6.9.0",
175
187
  "next": "^13.1.4",
176
188
  "next-test-api-route-handler": "^4.0.0-canary.1",
177
- "node-mocks-http": "^1.12.1",
178
- "openapi-types": "^12.1.0",
179
- "prettier": "^2.8.3",
189
+ "node-mocks-http": "^1.12.2",
190
+ "openapi-types": "^12.1.3",
191
+ "prettier": "^2.8.8",
180
192
  "rate-limiter-flexible": "^2.4.1",
181
193
  "react": "^18.2.0",
182
194
  "react-dom": "^18.2.0",
183
- "read-pkg": "^7.1.0",
195
+ "read-pkg": "^8.0.0",
184
196
  "redoc": "^2.0.0",
185
- "rimraf": "^4.1.2",
186
- "semantic-release": "^20.1.0",
187
- "styled-components": "^5.3.6",
188
- "swagger-ui-dist": "^4.15.5",
189
- "swagger-ui-react": "^4.15.5",
190
- "tsup": "^6.5.0",
191
- "typescript": "^4.9.4",
192
- "vitest": "^0.28.2",
193
- "webpack": "^5.75.0",
194
- "zod": "^3.20.2"
197
+ "rimraf": "^5.0.1",
198
+ "semantic-release": "^21.0.2",
199
+ "styled-components": "^5.3.10",
200
+ "swagger-ui-dist": "^4.19.0",
201
+ "swagger-ui-react": "^4.19.0",
202
+ "tsup": "^6.7.0",
203
+ "typescript": "^5.0.4",
204
+ "vitest": "^0.31.1",
205
+ "webpack": "^5.84.1",
206
+ "zod": "^3.21.4"
195
207
  },
196
208
  "peerDependencies": {
197
209
  "react": "^18.2.0",
@@ -199,25 +211,25 @@
199
211
  "zod": "^3.19.1"
200
212
  },
201
213
  "optionalDependencies": {
202
- "@hapi/hapi": "^21.2.0",
214
+ "@hapi/hapi": "^21.3.2",
203
215
  "@koa/router": "^12.0.0",
204
- "@visulima/crud": "1.0.10",
205
- "@visulima/readdir": "1.3.4",
216
+ "@visulima/crud": "1.0.11",
217
+ "@visulima/readdir": "1.3.5",
206
218
  "chalk": "5.2.0",
207
- "commander": "^10.0.0",
219
+ "commander": "^10.0.1",
208
220
  "cors": "^2.8.5",
209
221
  "express": "^4.18.2",
210
- "fastify": "^4.12.0",
211
- "koa": "^2.14.1",
222
+ "fastify": "^4.17.0",
223
+ "koa": "^2.14.2",
212
224
  "next": "^13.1.5",
213
225
  "rate-limiter-flexible": "^2.4.1",
214
226
  "redoc": "^2.0.0",
215
- "swagger-ui-dist": "^4.15.5",
216
- "swagger-ui-react": "^4.15.5",
217
- "webpack": "^5.75.0"
227
+ "swagger-ui-dist": "^4.19.0",
228
+ "swagger-ui-react": "^4.19.0",
229
+ "webpack": "^5.84.1"
218
230
  },
219
231
  "engines": {
220
- "node": ">=16.18.0 <=19.*"
232
+ "node": ">=16.18.0 <=20.*"
221
233
  },
222
234
  "publishConfig": {
223
235
  "access": "public"
@@ -228,6 +240,8 @@
228
240
  "src/framework/cli/index.ts",
229
241
  "src/framework/cli/commander/index.ts",
230
242
  "src/framework/next/index-browser.tsx",
231
- "src/framework/next/index-server.ts"
243
+ "src/framework/next/index-server.ts",
244
+ "src/framework/next/routes/pages/swagger/index.tsx",
245
+ "src/framework/next/routes/pages/redoc/index.tsx"
232
246
  ]
233
247
  }
@@ -1,13 +0,0 @@
1
- 'use strict';
2
-
3
- var chunkOUWZ2PU5_js = require('./chunk-OUWZ2PU5.js');
4
- var zodToTs = require('zod-to-ts');
5
- var zod = require('zod');
6
-
7
- var I={};chunkOUWZ2PU5_js.a(I,{dateIn:()=>K,dateOut:()=>w});var g="ZodDateIn",N=/^\d{4}-\d{2}-\d{2}(T\d{2}:\d{2}:\d{2}(\.\d{3})?)?Z?$/,p=class extends zod.ZodType{_parse(t){let{status:d,ctx:e}=this._processInputParams(t);if(e.parsedType!==zod.ZodParsedType.string)return zod.addIssueToContext(e,{code:zod.ZodIssueCode.invalid_type,expected:zod.ZodParsedType.string,received:e.parsedType}),zod.INVALID;N.test(e.data)||(zod.addIssueToContext(e,{code:zod.ZodIssueCode.invalid_string,validation:"regex"}),d.dirty());let c=new Date(e.data);return Number.isNaN(c.getTime())?(zod.addIssueToContext(e,{code:zod.ZodIssueCode.invalid_date}),zod.INVALID):{status:d.value,value:c}}},a=p;a.create=()=>new p({typeName:g});var v="ZodDateOut",i=class extends zod.ZodType{_parse(t){let{status:d,ctx:e}=this._processInputParams(t);return e.parsedType!==zod.ZodParsedType.date?(zod.addIssueToContext(e,{code:zod.ZodIssueCode.invalid_type,expected:zod.ZodParsedType.date,received:e.parsedType}),zod.INVALID):Number.isNaN(e.data.getTime())?(zod.addIssueToContext(e,{code:zod.ZodIssueCode.invalid_date}),zod.INVALID):{status:d.value,value:e.data.toISOString()}}},r=i;r.create=()=>new i({typeName:v});var K=(...o)=>zodToTs.withGetType(a.create(...o),t=>t.factory.createKeywordTypeNode(t.SyntaxKind.StringKeyword)),w=(...o)=>zodToTs.withGetType(r.create(...o),t=>t.factory.createKeywordTypeNode(t.SyntaxKind.StringKeyword));
8
-
9
- exports.a = K;
10
- exports.b = w;
11
- exports.c = I;
12
- //# sourceMappingURL=out.js.map
13
- //# sourceMappingURL=chunk-EP2A5R2C.js.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../src/zod/index.ts","../src/zod/date-in-schema.ts","../src/zod/date-out-schema.ts"],"names":["zod_exports","__export","dateIn","dateOut","withGetType","addIssueToContext","INVALID","ZodIssueCode","ZodParsedType","ZodType","zodDateInKind","isoDateRegex","_ZodDateIn","input","status","ctx","date","ZodDateIn","zodDateOutKind","_ZodDateOut","ZodDateOut","parameters","ts"],"mappings":"wCAAA,IAAAA,EAAA,GAAAC,EAAAD,EAAA,YAAAE,EAAA,YAAAC,IAAA,OAAS,eAAAC,MAAmB,YCC5B,OACI,qBAAAC,EAAmB,WAAAC,EAAS,gBAAAC,EAAc,iBAAAC,EAAe,WAAAC,MACtD,MAEP,IAAMC,EAAgB,YAOTC,EAAe,uDAOfC,EAAN,cAAwBH,CAAoC,CAExD,OAAOI,EAA0C,CAEpD,GAAM,CAAE,OAAAC,EAAQ,IAAAC,CAAI,EAAI,KAAK,oBAAoBF,CAAK,EACtD,GAAIE,EAAI,aAAeP,EAAc,OACjC,OAAAH,EAAkBU,EAAK,CACnB,KAAMR,EAAa,aACnB,SAAUC,EAAc,OACxB,SAAUO,EAAI,UAClB,CAAC,EACMT,EAGNK,EAAa,KAAKI,EAAI,IAAc,IACrCV,EAAkBU,EAAK,CACnB,KAAMR,EAAa,eACnB,WAAY,OAChB,CAAC,EACDO,EAAO,MAAM,GAGjB,IAAME,EAAO,IAAI,KAAKD,EAAI,IAAc,EAExC,OAAI,OAAO,MAAMC,EAAK,QAAQ,CAAC,GAC3BX,EAAkBU,EAAK,CACnB,KAAMR,EAAa,YACvB,CAAC,EACMD,GAGJ,CAAE,OAAQQ,EAAO,MAAO,MAAOE,CAAK,CAC/C,CAKJ,EArCaC,EAANL,EAAMK,EAkCK,OAAS,IAAiB,IAAIL,EAAU,CAClD,SAAUF,CACd,CAAC,ECtDL,OACI,qBAAAL,EAAmB,WAAAC,EAAS,gBAAAC,EAAc,iBAAAC,EAAe,WAAAC,MACtD,MAEP,IAAMS,EAAiB,aAOVC,EAAN,cAAyBV,CAAqC,CAE1D,OAAOI,EAA4C,CAEtD,GAAM,CAAE,OAAAC,EAAQ,IAAAC,CAAI,EAAI,KAAK,oBAAoBF,CAAK,EAEtD,OAAIE,EAAI,aAAeP,EAAc,MACjCH,EAAkBU,EAAK,CACnB,KAAMR,EAAa,aACnB,SAAUC,EAAc,KACxB,SAAUO,EAAI,UAClB,CAAC,EACMT,GAGP,OAAO,MAAMS,EAAI,KAAK,QAAQ,CAAC,GAC/BV,EAAkBU,EAAK,CACnB,KAAMR,EAAa,YACvB,CAAC,EACMD,GAGJ,CAAE,OAAQQ,EAAO,MAAO,MAAQC,EAAI,KAAc,YAAY,CAAE,CAC3E,CAKJ,EA5BaK,EAAND,EAAMC,EAyBK,OAAS,IAAkB,IAAID,EAAW,CACpD,SAAUD,CACd,CAAC,EFjCE,IAAMhB,EAAS,IAAImB,IAAoDjB,EAAYa,EAAU,OAAO,GAAGI,CAAU,EAAIC,GAAOA,EAAG,QAAQ,sBAAsBA,EAAG,WAAW,aAAa,CAAC,EAEnLnB,EAAU,IAAIkB,IAAqDjB,EAAYgB,EAAW,OAAO,GAAGC,CAAU,EAAIC,GAAOA,EAAG,QAAQ,sBAAsBA,EAAG,WAAW,aAAa,CAAC","sourcesContent":["import { withGetType } from \"zod-to-ts\";\n\nimport { ZodDateIn } from \"./date-in-schema\";\nimport { ZodDateOut } from \"./date-out-schema\";\n\n// eslint-disable-next-line max-len,@typescript-eslint/explicit-module-boundary-types\nexport const dateIn = (...parameters: Parameters<typeof ZodDateIn.create>) => withGetType(ZodDateIn.create(...parameters), (ts) => ts.factory.createKeywordTypeNode(ts.SyntaxKind.StringKeyword));\n// eslint-disable-next-line max-len,@typescript-eslint/explicit-module-boundary-types\nexport const dateOut = (...parameters: Parameters<typeof ZodDateOut.create>) => withGetType(ZodDateOut.create(...parameters), (ts) => ts.factory.createKeywordTypeNode(ts.SyntaxKind.StringKeyword));\n","import type { ParseInput, ParseReturnType, ZodTypeDef } from \"zod\";\nimport {\n addIssueToContext, INVALID, ZodIssueCode, ZodParsedType, ZodType,\n} from \"zod\";\n\nconst zodDateInKind = \"ZodDateIn\";\n\n// simple regex for ISO date, supports the following formats:\n// 2021-01-01T00:00:00.000Z\n// 2021-01-01T00:00:00Z\n// 2021-01-01T00:00:00\n// 2021-01-01\nexport const isoDateRegex = /^\\d{4}-\\d{2}-\\d{2}(T\\d{2}:\\d{2}:\\d{2}(\\.\\d{3})?)?Z?$/;\n\n// eslint-disable-next-line unicorn/prevent-abbreviations\nexport interface ZodDateInDef extends ZodTypeDef {\n typeName: typeof zodDateInKind;\n}\n\nexport class ZodDateIn extends ZodType<Date, ZodDateInDef, string> {\n // eslint-disable-next-line no-underscore-dangle\n public _parse(input: ParseInput): ParseReturnType<Date> {\n // eslint-disable-next-line no-underscore-dangle\n const { status, ctx } = this._processInputParams(input);\n if (ctx.parsedType !== ZodParsedType.string) {\n addIssueToContext(ctx, {\n code: ZodIssueCode.invalid_type,\n expected: ZodParsedType.string,\n received: ctx.parsedType,\n });\n return INVALID;\n }\n\n if (!isoDateRegex.test(ctx.data as string)) {\n addIssueToContext(ctx, {\n code: ZodIssueCode.invalid_string,\n validation: \"regex\",\n });\n status.dirty();\n }\n\n const date = new Date(ctx.data as string);\n\n if (Number.isNaN(date.getTime())) {\n addIssueToContext(ctx, {\n code: ZodIssueCode.invalid_date,\n });\n return INVALID;\n }\n\n return { status: status.value, value: date };\n }\n\n public static create = (): ZodDateIn => new ZodDateIn({\n typeName: zodDateInKind,\n });\n}\n","import type { ParseInput, ParseReturnType, ZodTypeDef } from \"zod\";\nimport {\n addIssueToContext, INVALID, ZodIssueCode, ZodParsedType, ZodType,\n} from \"zod\";\n\nconst zodDateOutKind = \"ZodDateOut\";\n\n// eslint-disable-next-line unicorn/prevent-abbreviations\nexport interface ZodDateOutDef extends ZodTypeDef {\n typeName: typeof zodDateOutKind;\n}\n\nexport class ZodDateOut extends ZodType<string, ZodDateOutDef, Date> {\n // eslint-disable-next-line no-underscore-dangle\n public _parse(input: ParseInput): ParseReturnType<string> {\n // eslint-disable-next-line no-underscore-dangle\n const { status, ctx } = this._processInputParams(input);\n\n if (ctx.parsedType !== ZodParsedType.date) {\n addIssueToContext(ctx, {\n code: ZodIssueCode.invalid_type,\n expected: ZodParsedType.date,\n received: ctx.parsedType,\n });\n return INVALID;\n }\n\n if (Number.isNaN(ctx.data.getTime())) {\n addIssueToContext(ctx, {\n code: ZodIssueCode.invalid_date,\n });\n return INVALID;\n }\n\n return { status: status.value, value: (ctx.data as Date).toISOString() };\n }\n\n public static create = (): ZodDateOut => new ZodDateOut({\n typeName: zodDateOutKind,\n });\n}\n"]}
@@ -1,13 +0,0 @@
1
- import { stringify } from 'yaml';
2
- import { modelsToOpenApi } from '@visulima/crud';
3
- import v from 'debug';
4
- import I from 'lodash.merge';
5
- import { existsSync, readFileSync } from 'fs';
6
- import S from 'path';
7
- import y from 'jstoxml';
8
-
9
- var u=e=>stringify(e,{indent:2}),A=u;var g=e=>e.toLowerCase().replace(/[^\s\w]/g," ").trimEnd().replace(/\s+|_/g,"-").replace(/\b\w/g,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]={});},x=(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);},w=(e,n,s,r,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?{type:"array",items:{$ref:`#/components/schemas/${r}`}}:{$ref:`#/components/schemas/${r}`};},h=(e,n,s,r,f,p)=>{let a,t;return Object.entries(n.content).forEach(([i,o])=>{if(typeof o.schema=="object"){let{schema:c}=o;i===P&&o.examples!==void 0?t=o.examples:i===P&&o.example!==void 0&&(a=o.example);let m=c.type==="array";Object.entries(s??{}).forEach(([O,d])=>{if(!d)return;let b;c?.$ref===void 0?(b=`${g(r.trim().replace("/",""))}${O==="application/ld+json"?".jsonld":""}`,x(f,b,c)):b=c.$ref.replace("#/components/schemas/",""),w(e,p,O,b,m);});}}),{examples:t,example:a}},E=(e,n,s,r,f,p)=>{Object.keys(n.content).forEach(a=>{a!==P&&Object.entries(r??{}).forEach(([t,i])=>{if(!i)return;j(e,s,t),e.responses[s].content?.[t]?.example===void 0&&(e.responses[s].content[t].example={});let o=!1;f.forEach(({regex:c,transformer:m})=>{!o&&c.test(t)&&(e.responses[s].content[t].example=m(p),o=!0);}),o||(e.responses[s].content[t].example=p);});});},M=(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]);},k=(e,n,s,r,f,p)=>{j(n,s,r),n.responses[s].content?.[r]?.examples===void 0&&(n.responses[s].content[r].examples={});let a={};Object.entries(p).forEach(([t,i])=>{let o=!1;f.forEach(({regex:c,transformer:m})=>{if(!o&&c.test(r)){let O="";e.components?.examples?.[t]?O=e.components.examples[t].value:i.$ref?O=(e.components?.examples?.[i.$ref.replace("#/components/examples/","")]).value:typeof i.value=="string"&&(O=i.value),a[t]={value:m(O)},o=!0;}}),o||(a[t]=e.components?.examples?.[t]===void 0?i:{$ref:`#/components/examples/${t}`});}),n.responses[s].content[r].examples=a;},T=(e,n,s,r,f,p,a,t)=>{let i=`${g(p.trim().replace("/",""))}`;Object.keys(r.content).forEach(o=>{o!==P&&Object.entries(f??{}).forEach(([c,m])=>{!m||(M(e,i,t),k(e,n,s,c,a,t));});});};function l(e,n,s=[{regex:/xml/,transformer:r=>y.toXML(r,{header:!0,indent:" "})},{regex:/yaml|yml/,transformer:r=>stringify(r,{indent:2})}]){return typeof e=="object"&&typeof e.paths=="object"&&Object.entries(e.paths).forEach(([r,f])=>{Object.values(f).forEach(p=>{typeof p.responses=="object"&&Object.entries(p.responses).forEach(([a,t])=>{if(typeof t.content=="object"){let{examples:i,example:o}=h(p,t,n,r,e,a);o!==void 0?E(p,t,a,n,s,o):i!==void 0&&T(e,p,a,t,n,r,s,i);}});});}),e}var H=v("visulima:api-platform:swagger:crud:get-static-properties-swagger"),q=(e={})=>{let{allowedMediaTypes:n={"application/json":!0},swaggerFilePath:s,crud:r,specs:f}=e;return async(p,a)=>{let t=S.join(process.cwd(),s??"swagger/swagger.json");if(!existsSync(t))throw new Error(`Swagger file not found at "${t}".`);let i=readFileSync(t,"utf8"),o=l(JSON.parse(i),n),c={};if(r!==void 0)try{let O=await modelsToOpenApi(r);c={components:{schemas:O.schemas,examples:O.examples},tags:O.tags,paths:O.paths},c=l(c,n),H(JSON.stringify(c,null,2)),o=I(o,c);}catch(O){throw console.log(O),new Error("Please install @visulima/crud to use the crud swagger generator.")}Array.isArray(f)&&f.forEach(O=>{o=I(o,l(O,n));});let m;typeof p.headers.accept=="string"&&/yaml|yml/.test(p.headers.accept)?(a.setHeader("Content-Type",p.headers.accept),m=A(o)):(a.setHeader("Content-Type","application/json"),m=JSON.stringify(o,null,2)),a.statusCode=200,a.end(m);}},N=q;
10
-
11
- export { g as a, A as b, N as c };
12
- //# sourceMappingURL=out.js.map
13
- //# sourceMappingURL=chunk-ESKLEDNF.mjs.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../src/serializers/transformer/yaml.ts","../src/swagger/api/swagger-handler.ts","../src/swagger/extend-swagger-spec.ts","../src/utils.ts"],"names":["stringify","yamlTransformer","data","yaml_default","modelsToOpenApi","debug","merge","existsSync","readFileSync","path","xml","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","pathSpec","swaggerCrudDebug","swaggerHandler","options","swaggerFilePath","crud","specs","request","response","swaggerPath","fileContents","crudSwagger","modelsOpenApi","error","swagger_handler_default"],"mappings":"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","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","// eslint-disable-next-line unicorn/prevent-abbreviations,import/no-extraneous-dependencies\nimport type { ModelsToOpenApiParameters, SwaggerModelsConfig } from \"@visulima/crud\";\n// eslint-disable-next-line unicorn/prevent-abbreviations,import/no-extraneous-dependencies\nimport { modelsToOpenApi } from \"@visulima/crud\";\nimport debug from \"debug\";\nimport merge from \"lodash.merge\";\nimport { existsSync, readFileSync } from \"node:fs\";\nimport type { IncomingMessage, ServerResponse } from \"node:http\";\nimport path from \"node:path\";\nimport type { OpenAPIV3 } from \"openapi-types\";\n\nimport yamlTransformer from \"../../serializers/transformer/yaml\";\nimport extendSwaggerSpec from \"../extend-swagger-spec\";\n\n// eslint-disable-next-line testing-library/no-debugging-utils\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 swaggerFilePath,\n crud,\n specs,\n } = options;\n\n return async <Request extends IncomingMessage, Response extends ServerResponse>(request: Request, response: Response) => {\n const swaggerPath = path.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: { schemas: modelsOpenApi.schemas, examples: modelsOpenApi.examples },\n tags: modelsOpenApi.tags,\n paths: modelsOpenApi.paths,\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 type SwaggerHandlerOptions<M extends string, PrismaClient> = {\n allowedMediaTypes: { [key: string]: boolean };\n swaggerFilePath: string;\n crud: Exclude<ModelsToOpenApiParameters<M, PrismaClient>, \"swagger\"> & {\n swagger?: {\n models?: SwaggerModelsConfig<M>;\n };\n };\n specs?: Partial<OpenAPIV3.Document>[];\n};\n\nexport default swaggerHandler;\n","import type { XmlElement } from \"jstoxml\";\nimport xml 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 (\n // eslint-disable-next-line no-param-reassign\n ((methodSpec.responses as unknown as OpenAPIV3.ResponsesObject)[status] as OpenAPIV3.ResponseObject).content as {\n [key: string]: OpenAPIV3.MediaTypeObject;\n }\n )[mediaType] = {} 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 (\n (\n // eslint-disable-next-line no-param-reassign\n ((methodSpec.responses as unknown as OpenAPIV3.ResponsesObject)[status] as OpenAPIV3.ResponseObject).content as {\n [key: string]: OpenAPIV3.MediaTypeObject;\n }\n )[mediaType] as OpenAPIV3.MediaTypeObject\n ).schema = {} as OpenAPIV3.SchemaObject;\n }\n\n (\n (\n // eslint-disable-next-line no-param-reassign\n ((methodSpec.responses as unknown as OpenAPIV3.ResponsesObject)[status] as OpenAPIV3.ResponseObject).content as {\n [key: string]: OpenAPIV3.MediaTypeObject;\n }\n )[mediaType] as OpenAPIV3.MediaTypeObject\n ).schema = schemaIsArray\n ? {\n type: \"array\",\n items: {\n $ref: `#/components/schemas/${schemaName}`,\n },\n }\n : {\n $ref: `#/components/schemas/${schemaName}`,\n };\n};\n\nconst extendSwaggerWithMediaTypeSchema = (\n methodSpec: OpenAPIV3.OperationObject,\n responseSpec: OpenAPIV3.ResponseObject,\n allowedMediaTypes: { [p: string]: boolean } | undefined,\n pathKey: string,\n spec: Partial<OpenAPIV3.Document>,\n status: string,\n): {\n example?: any;\n examples?: {\n [media: string]: OpenAPIV3.ExampleObject | OpenAPIV3.ReferenceObject;\n };\n} => {\n let example: any | undefined;\n let examples:\n | {\n [media: string]: OpenAPIV3.ExampleObject | OpenAPIV3.ReferenceObject;\n }\n | undefined;\n\n // eslint-disable-next-line radar/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 // eslint-disable-next-line max-len\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 // eslint-disable-next-line max-len\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 { examples, example };\n};\n\nconst extendSwaggerWithMediaTypeExample = (\n methodSpec: OpenAPIV3.OperationObject,\n responseSpec: OpenAPIV3.ResponseObject,\n status: string,\n allowedMediaTypes: { [p: 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\n === undefined\n ) {\n (\n (\n // eslint-disable-next-line no-param-reassign\n ((methodSpec.responses as unknown as OpenAPIV3.ResponsesObject)[status] as OpenAPIV3.ResponseObject).content as {\n [key: string]: OpenAPIV3.MediaTypeObject;\n }\n )[mediaType] as OpenAPIV3.MediaTypeObject\n ).example = {};\n }\n\n let transformed: boolean = false;\n\n transformers.forEach(({ regex, transformer }) => {\n if (!transformed && regex.test(mediaType)) {\n (\n (\n // eslint-disable-next-line no-param-reassign\n ((methodSpec.responses as unknown as OpenAPIV3.ResponsesObject)[status] as OpenAPIV3.ResponseObject).content as {\n [key: string]: OpenAPIV3.MediaTypeObject;\n }\n )[mediaType] as OpenAPIV3.MediaTypeObject\n ).example = transformer(example);\n\n transformed = true;\n }\n });\n\n // eslint-disable-next-line @typescript-eslint/no-unnecessary-condition\n if (!transformed) {\n (\n (\n // eslint-disable-next-line no-param-reassign\n ((methodSpec.responses as unknown as OpenAPIV3.ResponsesObject)[status] as OpenAPIV3.ResponseObject).content as {\n [key: string]: OpenAPIV3.MediaTypeObject;\n }\n )[mediaType] as OpenAPIV3.MediaTypeObject\n ).example = example;\n }\n });\n });\n};\n\nconst extendComponentExamples = (\n spec: Partial<OpenAPIV3.Document>,\n exampleName: string,\n examples: {\n [media: string]: OpenAPIV3.ExampleObject | OpenAPIV3.ReferenceObject;\n },\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: {\n [media: string]: OpenAPIV3.ExampleObject | OpenAPIV3.ReferenceObject;\n },\n // eslint-disable-next-line radar/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 (\n (\n // eslint-disable-next-line no-param-reassign\n ((methodSpec.responses as unknown as OpenAPIV3.ResponsesObject)[status] as OpenAPIV3.ResponseObject).content as {\n [key: string]: OpenAPIV3.MediaTypeObject;\n }\n )[mediaType] as OpenAPIV3.MediaTypeObject\n ).examples = {};\n }\n\n const transformedExamples: {\n [media: string]: OpenAPIV3.ExampleObject | OpenAPIV3.ReferenceObject;\n } = {};\n\n Object.entries(examples).forEach(([exampleName, example]) => {\n let transformed: boolean = 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 // eslint-disable-next-line @typescript-eslint/no-unnecessary-condition\n if (!transformed) {\n transformedExamples[exampleName] = spec.components?.examples?.[exampleName] === undefined\n ? example\n : {\n $ref: `#/components/examples/${exampleName}`,\n };\n }\n });\n\n (\n (\n // eslint-disable-next-line no-param-reassign\n ((methodSpec.responses as unknown as OpenAPIV3.ResponsesObject)[status] as OpenAPIV3.ResponseObject).content as {\n [key: string]: OpenAPIV3.MediaTypeObject;\n }\n )[mediaType] as OpenAPIV3.MediaTypeObject\n ).examples = transformedExamples;\n};\n\nconst extendSwaggerWithMediaTypeExamples = (\n spec: Partial<OpenAPIV3.Document>,\n methodSpec: OpenAPIV3.OperationObject,\n status: string,\n responseSpec: OpenAPIV3.ResponseObject,\n allowedMediaTypes: { [p: string]: boolean } | undefined,\n pathKey: string,\n transformers: Transformers,\n examples: {\n [media: string]: OpenAPIV3.ExampleObject | OpenAPIV3.ReferenceObject;\n },\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 radar/cognitive-complexity\nexport default function extendSwaggerSpec(\n spec: Partial<OpenAPIV3.Document>,\n allowedMediaTypes?: { [key: string]: boolean },\n transformers: Transformers = [\n {\n regex: /xml/,\n transformer: (value: XmlElement | XmlElement[] | undefined) => xml.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 { examples, example } = 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 type { IncomingMessage, ServerResponse } from \"node:http\";\nimport { parse as urlParse } 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\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): unknown => {\n if (request.query) {\n return request.query;\n }\n\n return urlParse(request.url ?? \"\", true).query;\n};\n\nexport const toHeaderCase = (string_: string): string => string_\n .toLowerCase()\n .replace(/[^\\s\\w]/g, \" \") // Remove all non-word characters\n .trimEnd() // Remove trailing spaces\n .replace(/\\s+|_/g, \"-\") // Replace multiple spaces or underline with a single hyphen\n .replace(/\\b\\w/g, (c) => c.toUpperCase());\n"]}
@@ -1,18 +0,0 @@
1
- 'use strict';
2
-
3
- var yaml = require('yaml');
4
- var crud = require('@visulima/crud');
5
- var v = require('debug');
6
- var I = require('lodash.merge');
7
- var fs = require('fs');
8
- var S = require('path');
9
- var y = require('jstoxml');
10
- require('url');
11
-
12
- var u=e=>yaml.stringify(e,{indent:2}),A=u;var g=e=>e.toLowerCase().replace(/[^\s\w]/g," ").trimEnd().replace(/\s+|_/g,"-").replace(/\b\w/g,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]={});},x=(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);},w=(e,n,s,r,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?{type:"array",items:{$ref:`#/components/schemas/${r}`}}:{$ref:`#/components/schemas/${r}`};},h=(e,n,s,r,f,p)=>{let a,t;return Object.entries(n.content).forEach(([i,o])=>{if(typeof o.schema=="object"){let{schema:c}=o;i===P&&o.examples!==void 0?t=o.examples:i===P&&o.example!==void 0&&(a=o.example);let m=c.type==="array";Object.entries(s??{}).forEach(([O,d])=>{if(!d)return;let b;c?.$ref===void 0?(b=`${g(r.trim().replace("/",""))}${O==="application/ld+json"?".jsonld":""}`,x(f,b,c)):b=c.$ref.replace("#/components/schemas/",""),w(e,p,O,b,m);});}}),{examples:t,example:a}},E=(e,n,s,r,f,p)=>{Object.keys(n.content).forEach(a=>{a!==P&&Object.entries(r??{}).forEach(([t,i])=>{if(!i)return;j(e,s,t),e.responses[s].content?.[t]?.example===void 0&&(e.responses[s].content[t].example={});let o=!1;f.forEach(({regex:c,transformer:m})=>{!o&&c.test(t)&&(e.responses[s].content[t].example=m(p),o=!0);}),o||(e.responses[s].content[t].example=p);});});},M=(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]);},k=(e,n,s,r,f,p)=>{j(n,s,r),n.responses[s].content?.[r]?.examples===void 0&&(n.responses[s].content[r].examples={});let a={};Object.entries(p).forEach(([t,i])=>{let o=!1;f.forEach(({regex:c,transformer:m})=>{if(!o&&c.test(r)){let O="";e.components?.examples?.[t]?O=e.components.examples[t].value:i.$ref?O=(e.components?.examples?.[i.$ref.replace("#/components/examples/","")]).value:typeof i.value=="string"&&(O=i.value),a[t]={value:m(O)},o=!0;}}),o||(a[t]=e.components?.examples?.[t]===void 0?i:{$ref:`#/components/examples/${t}`});}),n.responses[s].content[r].examples=a;},T=(e,n,s,r,f,p,a,t)=>{let i=`${g(p.trim().replace("/",""))}`;Object.keys(r.content).forEach(o=>{o!==P&&Object.entries(f??{}).forEach(([c,m])=>{!m||(M(e,i,t),k(e,n,s,c,a,t));});});};function l(e,n,s=[{regex:/xml/,transformer:r=>y.toXML(r,{header:!0,indent:" "})},{regex:/yaml|yml/,transformer:r=>yaml.stringify(r,{indent:2})}]){return typeof e=="object"&&typeof e.paths=="object"&&Object.entries(e.paths).forEach(([r,f])=>{Object.values(f).forEach(p=>{typeof p.responses=="object"&&Object.entries(p.responses).forEach(([a,t])=>{if(typeof t.content=="object"){let{examples:i,example:o}=h(p,t,n,r,e,a);o!==void 0?E(p,t,a,n,s,o):i!==void 0&&T(e,p,a,t,n,r,s,i);}});});}),e}var H=v("visulima:api-platform:swagger:crud:get-static-properties-swagger"),q=(e={})=>{let{allowedMediaTypes:n={"application/json":!0},swaggerFilePath:s,crud:r,specs:f}=e;return async(p,a)=>{let t=S.join(process.cwd(),s??"swagger/swagger.json");if(!fs.existsSync(t))throw new Error(`Swagger file not found at "${t}".`);let i=fs.readFileSync(t,"utf8"),o=l(JSON.parse(i),n),c={};if(r!==void 0)try{let O=await crud.modelsToOpenApi(r);c={components:{schemas:O.schemas,examples:O.examples},tags:O.tags,paths:O.paths},c=l(c,n),H(JSON.stringify(c,null,2)),o=I(o,c);}catch(O){throw console.log(O),new Error("Please install @visulima/crud to use the crud swagger generator.")}Array.isArray(f)&&f.forEach(O=>{o=I(o,l(O,n));});let m;typeof p.headers.accept=="string"&&/yaml|yml/.test(p.headers.accept)?(a.setHeader("Content-Type",p.headers.accept),m=A(o)):(a.setHeader("Content-Type","application/json"),m=JSON.stringify(o,null,2)),a.statusCode=200,a.end(m);}},ne=q;
13
-
14
- exports.a = g;
15
- exports.b = A;
16
- exports.c = ne;
17
- //# sourceMappingURL=out.js.map
18
- //# sourceMappingURL=chunk-IMU5ULVF.js.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../src/serializers/transformer/yaml.ts","../src/swagger/api/swagger-handler.ts","../src/swagger/extend-swagger-spec.ts","../src/utils.ts"],"names":["stringify","yamlTransformer","data","yaml_default","modelsToOpenApi","debug","merge","existsSync","readFileSync","path","xml","urlParse","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","pathSpec","swaggerCrudDebug","swaggerHandler","options","swaggerFilePath","crud","specs","request","response","swaggerPath","fileContents","crudSwagger","modelsOpenApi","error","swagger_handler_default"],"mappings":"AAAA,OAAS,aAAAA,MAAiB,OAI1B,IAAMC,EAA+BC,GAASF,EAAUE,EAAM,CAAE,OAAQ,CAAE,CAAC,EAEpEC,EAAQF,ECHf,OAAS,mBAAAG,MAAuB,iBAChC,OAAOC,MAAW,QAClB,OAAOC,MAAW,eAClB,OAAS,cAAAC,EAAY,gBAAAC,MAAoB,KAEzC,OAAOC,MAAU,OCPjB,OAAOC,MAAS,UAEhB,OAAS,aAAAV,MAAiB,OCF1B,OAAS,SAASW,MAAgB,MAsC3B,IAAMC,EAAgBC,GAA4BA,EACpD,YAAY,EACZ,QAAQ,WAAY,GAAG,EACvB,QAAQ,EACR,QAAQ,SAAU,GAAG,EACrB,QAAQ,QAAUC,GAAMA,EAAE,YAAY,CAAC,EDnC5C,IAAMC,EAAgB,mBAEhBC,EAAuB,CAACC,EAAuCC,EAAgBC,IAAsB,CACjGF,EAAW,UAAmDC,GAAqC,UAAY,SAE/GD,EAAW,UAAmDC,GAAqC,QAAU,CAAC,GAG9GD,EAAW,UAAmDC,GAAqC,UAAUC,KAAe,SAGxHF,EAAW,UAAmDC,GAAqC,QAGvGC,GAAa,CAAC,EAExB,EAEMC,EAAyB,CAACC,EAAmCC,EAAoBC,IAAmC,CAClH,OAAOF,EAAK,YAAe,WAE3BA,EAAK,WAAa,CAAC,GAGnB,OAAOA,EAAK,WAAW,SAAY,WAEnCA,EAAK,WAAW,QAAU,CAAC,GAG3BA,EAAK,WAAW,QAAQC,KAAgB,SAExCD,EAAK,WAAW,QAAQC,GAAcC,EAE9C,EAEMC,EAAuB,CAACP,EAAuCC,EAAgBC,EAAmBG,EAAoBG,IAA2B,CACnJT,EAAqBC,EAAYC,EAAQC,CAAS,EAE5CF,EAAW,UAAmDC,GAAqC,UAAUC,IAAY,SAAW,SAI5HF,EAAW,UAAmDC,GAAqC,QAGvGC,GACJ,OAAS,CAAC,GAMNF,EAAW,UAAmDC,GAAqC,QAGvGC,GACJ,OAASM,EACL,CACE,KAAM,QACN,MAAO,CACH,KAAM,wBAAwBH,GAClC,CACJ,EACE,CACE,KAAM,wBAAwBA,GAClC,CACR,EAEMI,EAAmC,CACrCT,EACAU,EACAC,EACAC,EACAR,EACAH,IAMC,CACD,IAAIY,EACAC,EAOJ,cAAO,QAAQJ,EAAa,OAAiB,EAAE,QAAQ,CAAC,CAACK,EAAWC,CAAW,IAAM,CACjF,GAAI,OAAOA,EAAY,QAAW,SAAU,CACxC,GAAM,CAAE,OAAAV,CAAO,EAAIU,EAEfD,IAAcjB,GAAiBkB,EAAY,WAAa,OACxDF,EAAWE,EAAY,SAChBD,IAAcjB,GAAiBkB,EAAY,UAAY,SAC9DH,EAAUG,EAAY,SAG1B,IAAMR,EAAiBF,EAAkC,OAAS,QAElE,OAAO,QAAQK,GAAqB,CAAC,CAAC,EAAE,QAAQ,CAAC,CAACT,EAAWe,CAAO,IAAM,CACtE,GAAI,CAACA,EACD,OAGJ,IAAIZ,EAEAC,GAAQ,OAAS,QAEjBD,EAAa,GAAGV,EAAaiB,EAAQ,KAAK,EAAE,QAAQ,IAAK,EAAE,CAAC,IAAIV,IAAc,sBAAwB,UAAY,KAElHC,EAAuBC,EAA4BC,EAAYC,CAAgC,GAG/FD,EAAcC,EAAqC,KAAK,QAAQ,wBAAyB,EAAE,EAG/FC,EAAqBP,EAAYC,EAAQC,EAAWG,EAAYG,CAAa,CACjF,CAAC,CACL,CACJ,CAAC,EAEM,CAAE,SAAAM,EAAU,QAAAD,CAAQ,CAC/B,EAEMK,EAAoC,CACtClB,EACAU,EACAT,EACAU,EACAQ,EACAN,IACC,CACD,OAAO,KAAKH,EAAa,OAAiB,EAAE,QAASK,GAAc,CAC3DA,IAAcjB,GAIlB,OAAO,QAAQa,GAAqB,CAAC,CAAC,EAAE,QAAQ,CAAC,CAACT,EAAWe,CAAO,IAAM,CACtE,GAAI,CAACA,EACD,OAGJlB,EAAqBC,EAAYC,EAAQC,CAAS,EAG5CF,EAAW,UAAmDC,GAAqC,UAAUC,IAAY,UACvH,SAKMF,EAAW,UAAmDC,GAAqC,QAGvGC,GACJ,QAAU,CAAC,GAGjB,IAAIkB,EAAuB,GAE3BD,EAAa,QAAQ,CAAC,CAAE,MAAAE,EAAO,YAAAC,CAAY,IAAM,CACzC,CAACF,GAAeC,EAAM,KAAKnB,CAAS,IAI1BF,EAAW,UAAmDC,GAAqC,QAGvGC,GACJ,QAAUoB,EAAYT,CAAO,EAE/BO,EAAc,GAEtB,CAAC,EAGIA,IAISpB,EAAW,UAAmDC,GAAqC,QAGvGC,GACJ,QAAUW,EAEpB,CAAC,CACL,CAAC,CACL,EAEMU,EAA0B,CAC5BnB,EACAoB,EACAV,IAGC,CACG,OAAOV,EAAK,YAAe,WAE3BA,EAAK,WAAa,CAAC,GAGnB,OAAOA,EAAK,WAAW,UAAa,WAEpCA,EAAK,WAAW,SAAW,CAAC,GAG5BA,EAAK,WAAW,SAASoB,KAAiB,QAAaV,EAASU,KAAiB,SAEjFpB,EAAK,WAAW,SAASoB,GAAeV,EAASU,GAEzD,EAEMC,EAA0B,CAC5BrB,EACAJ,EACAC,EACAC,EACAiB,EACAL,IAIC,CACDf,EAAqBC,EAAYC,EAAQC,CAAS,EAE5CF,EAAW,UAAmDC,GAAqC,UAAUC,IAAY,WAAa,SAI9HF,EAAW,UAAmDC,GAAqC,QAGvGC,GACJ,SAAW,CAAC,GAGlB,IAAMwB,EAEF,CAAC,EAEL,OAAO,QAAQZ,CAAQ,EAAE,QAAQ,CAAC,CAACU,EAAaX,CAAO,IAAM,CACzD,IAAIO,EAAuB,GAE3BD,EAAa,QAAQ,CAAC,CAAE,MAAAE,EAAO,YAAAC,CAAY,IAAM,CAC7C,GAAI,CAACF,GAAeC,EAAM,KAAKnB,CAAS,EAAG,CACvC,IAAIjB,EAAY,GAEZmB,EAAK,YAAY,WAAWoB,GAC5BvC,EAAQmB,EAAK,WAAW,SAASoB,GAAyC,MAClEX,EAAsC,KAC9C5B,GACImB,EAAK,YAAY,WACZS,EAAsC,KAAK,QAAQ,yBAA0B,EAAE,IAEtF,MACK,OAAQA,EAAoC,OAAU,WAC7D5B,EAAQ4B,EAAoC,OAGhDa,EAAoBF,GAAe,CAC/B,MAAOF,EAAYrC,CAAI,CAC3B,EAEAmC,EAAc,EAClB,CACJ,CAAC,EAGIA,IACDM,EAAoBF,GAAepB,EAAK,YAAY,WAAWoB,KAAiB,OAC1EX,EACA,CACE,KAAM,yBAAyBW,GACnC,EAEZ,CAAC,EAKSxB,EAAW,UAAmDC,GAAqC,QAGvGC,GACJ,SAAWwB,CACjB,EAEMC,EAAqC,CACvCvB,EACAJ,EACAC,EACAS,EACAC,EACAC,EACAO,EACAL,IAGC,CACD,IAAMc,EAAe,GAAGjC,EAAaiB,EAAQ,KAAK,EAAE,QAAQ,IAAK,EAAE,CAAC,IAEpE,OAAO,KAAKF,EAAa,OAAiB,EAAE,QAASK,GAAc,CAC3DA,IAAcjB,GAIlB,OAAO,QAAQa,GAAqB,CAAC,CAAC,EAAE,QAAQ,CAAC,CAACT,EAAWe,CAAO,IAAM,CAClE,CAACA,IAILM,EAAwBnB,EAAMwB,EAAcd,CAAQ,EAEpDW,EAAwBrB,EAAMJ,EAAYC,EAAQC,EAAWiB,EAAcL,CAAQ,EACvF,CAAC,CACL,CAAC,CACL,EAGe,SAARe,EACHzB,EACAO,EACAQ,EAA6B,CACzB,CACI,MAAO,MACP,YAAcW,GAAiDrC,EAAI,MAAMqC,EAAO,CAC5E,OAAQ,GACR,OAAQ,IACZ,CAAC,CACL,EACA,CACI,MAAO,WACP,YAAcA,GAAU/C,EAAU+C,EAAO,CAAE,OAAQ,CAAE,CAAC,CAC1D,CACJ,EAC2B,CAC3B,OAAI,OAAO1B,GAAS,UAAY,OAAOA,EAAK,OAAU,UAClD,OAAO,QAAQA,EAAK,KAAK,EAAE,QAAQ,CAAC,CAACQ,EAASmB,CAAQ,IAAM,CACxD,OAAO,OAAOA,CAA6D,EAAE,QAAS/B,GAAe,CAC7F,OAAQA,EAAyC,WAAc,UAC/D,OAAO,QAASA,EAAyC,SAAS,EAAE,QAAQ,CAAC,CAACC,EAAQS,CAAY,IAAM,CACpG,GAAI,OAAQA,EAA0C,SAAY,SAAU,CACxE,GAAM,CAAE,SAAAI,EAAU,QAAAD,CAAQ,EAAIJ,EAC1BT,EACAU,EACAC,EACAC,EACAR,EACAH,CACJ,EAEIY,IAAY,OACZK,EACIlB,EACAU,EACAT,EACAU,EACAQ,EACAN,CACJ,EACOC,IAAa,QACpBa,EACIvB,EACAJ,EACAC,EACAS,EACAC,EACAC,EACAO,EACAL,CACJ,CAER,CACJ,CAAC,CAET,CAAC,CACL,CAAC,EAGEV,CACX,CDzXA,IAAM4B,EAAmB5C,EAAM,kEAAkE,EAE3F6C,EAAiB,CACnBC,EAA2D,CAAC,IACc,CAC1E,GAAM,CACF,kBAAAvB,EAAoB,CAChB,mBAAoB,EACxB,EACA,gBAAAwB,EACA,KAAAC,EACA,MAAAC,CACJ,EAAIH,EAEJ,MAAO,OAAyEI,EAAkBC,IAAuB,CACrH,IAAMC,EAAchD,EAAK,KAAK,QAAQ,IAAI,EAAG2C,GAAmB,sBAAsB,EAEtF,GAAI,CAAC7C,EAAWkD,CAAW,EACvB,MAAM,IAAI,MAAM,8BAA8BA,KAAe,EAGjE,IAAMC,EAAelD,EAAaiD,EAAa,MAAM,EAEjDpC,EAAOyB,EAAkB,KAAK,MAAMY,CAAY,EAAyB9B,CAAiB,EAC1F+B,EAA2C,CAAC,EAEhD,GAAIN,IAAS,OACT,GAAI,CACA,IAAMO,EAAgB,MAAMxD,EAAgBiD,CAAI,EAEhDM,EAAc,CACV,WAAY,CAAE,QAASC,EAAc,QAAS,SAAUA,EAAc,QAAS,EAC/E,KAAMA,EAAc,KACpB,MAAOA,EAAc,KACzB,EAEAD,EAAcb,EAAkBa,EAAa/B,CAAiB,EAE9DqB,EAAiB,KAAK,UAAUU,EAAa,KAAM,CAAC,CAAC,EAErDtC,EAAOf,EAAMe,EAAMsC,CAAW,CAClC,OAASE,EAAP,CAEE,cAAQ,IAAIA,CAAK,EAEX,IAAI,MAAM,kEAAkE,CACtF,CAGA,MAAM,QAAQP,CAAK,GACnBA,EAAM,QAASP,GAAU,CACrB1B,EAAOf,EAAMe,EAAMyB,EAAkBC,EAAOnB,CAAiB,CAAC,CAClE,CAAC,EAGL,IAAI1B,EAEA,OAAOqD,EAAQ,QAAQ,QAAW,UAAY,WAAW,KAAKA,EAAQ,QAAQ,MAAM,GACpFC,EAAS,UAAU,eAAgBD,EAAQ,QAAQ,MAAM,EAEzDrD,EAAOC,EAAgBkB,CAAI,IAE3BmC,EAAS,UAAU,eAAgB,kBAAkB,EAErDtD,EAAO,KAAK,UAAUmB,EAAM,KAAM,CAAC,GAGvCmC,EAAS,WAAa,IACtBA,EAAS,IAAItD,CAAI,CACrB,CACJ,EAaO4D,GAAQZ","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","// eslint-disable-next-line unicorn/prevent-abbreviations,import/no-extraneous-dependencies\nimport type { ModelsToOpenApiParameters, SwaggerModelsConfig } from \"@visulima/crud\";\n// eslint-disable-next-line unicorn/prevent-abbreviations,import/no-extraneous-dependencies\nimport { modelsToOpenApi } from \"@visulima/crud\";\nimport debug from \"debug\";\nimport merge from \"lodash.merge\";\nimport { existsSync, readFileSync } from \"node:fs\";\nimport type { IncomingMessage, ServerResponse } from \"node:http\";\nimport path from \"node:path\";\nimport type { OpenAPIV3 } from \"openapi-types\";\n\nimport yamlTransformer from \"../../serializers/transformer/yaml\";\nimport extendSwaggerSpec from \"../extend-swagger-spec\";\n\n// eslint-disable-next-line testing-library/no-debugging-utils\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 swaggerFilePath,\n crud,\n specs,\n } = options;\n\n return async <Request extends IncomingMessage, Response extends ServerResponse>(request: Request, response: Response) => {\n const swaggerPath = path.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: { schemas: modelsOpenApi.schemas, examples: modelsOpenApi.examples },\n tags: modelsOpenApi.tags,\n paths: modelsOpenApi.paths,\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 type SwaggerHandlerOptions<M extends string, PrismaClient> = {\n allowedMediaTypes: { [key: string]: boolean };\n swaggerFilePath: string;\n crud: Exclude<ModelsToOpenApiParameters<M, PrismaClient>, \"swagger\"> & {\n swagger?: {\n models?: SwaggerModelsConfig<M>;\n };\n };\n specs?: Partial<OpenAPIV3.Document>[];\n};\n\nexport default swaggerHandler;\n","import type { XmlElement } from \"jstoxml\";\nimport xml 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 (\n // eslint-disable-next-line no-param-reassign\n ((methodSpec.responses as unknown as OpenAPIV3.ResponsesObject)[status] as OpenAPIV3.ResponseObject).content as {\n [key: string]: OpenAPIV3.MediaTypeObject;\n }\n )[mediaType] = {} 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 (\n (\n // eslint-disable-next-line no-param-reassign\n ((methodSpec.responses as unknown as OpenAPIV3.ResponsesObject)[status] as OpenAPIV3.ResponseObject).content as {\n [key: string]: OpenAPIV3.MediaTypeObject;\n }\n )[mediaType] as OpenAPIV3.MediaTypeObject\n ).schema = {} as OpenAPIV3.SchemaObject;\n }\n\n (\n (\n // eslint-disable-next-line no-param-reassign\n ((methodSpec.responses as unknown as OpenAPIV3.ResponsesObject)[status] as OpenAPIV3.ResponseObject).content as {\n [key: string]: OpenAPIV3.MediaTypeObject;\n }\n )[mediaType] as OpenAPIV3.MediaTypeObject\n ).schema = schemaIsArray\n ? {\n type: \"array\",\n items: {\n $ref: `#/components/schemas/${schemaName}`,\n },\n }\n : {\n $ref: `#/components/schemas/${schemaName}`,\n };\n};\n\nconst extendSwaggerWithMediaTypeSchema = (\n methodSpec: OpenAPIV3.OperationObject,\n responseSpec: OpenAPIV3.ResponseObject,\n allowedMediaTypes: { [p: string]: boolean } | undefined,\n pathKey: string,\n spec: Partial<OpenAPIV3.Document>,\n status: string,\n): {\n example?: any;\n examples?: {\n [media: string]: OpenAPIV3.ExampleObject | OpenAPIV3.ReferenceObject;\n };\n} => {\n let example: any | undefined;\n let examples:\n | {\n [media: string]: OpenAPIV3.ExampleObject | OpenAPIV3.ReferenceObject;\n }\n | undefined;\n\n // eslint-disable-next-line radar/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 // eslint-disable-next-line max-len\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 // eslint-disable-next-line max-len\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 { examples, example };\n};\n\nconst extendSwaggerWithMediaTypeExample = (\n methodSpec: OpenAPIV3.OperationObject,\n responseSpec: OpenAPIV3.ResponseObject,\n status: string,\n allowedMediaTypes: { [p: 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\n === undefined\n ) {\n (\n (\n // eslint-disable-next-line no-param-reassign\n ((methodSpec.responses as unknown as OpenAPIV3.ResponsesObject)[status] as OpenAPIV3.ResponseObject).content as {\n [key: string]: OpenAPIV3.MediaTypeObject;\n }\n )[mediaType] as OpenAPIV3.MediaTypeObject\n ).example = {};\n }\n\n let transformed: boolean = false;\n\n transformers.forEach(({ regex, transformer }) => {\n if (!transformed && regex.test(mediaType)) {\n (\n (\n // eslint-disable-next-line no-param-reassign\n ((methodSpec.responses as unknown as OpenAPIV3.ResponsesObject)[status] as OpenAPIV3.ResponseObject).content as {\n [key: string]: OpenAPIV3.MediaTypeObject;\n }\n )[mediaType] as OpenAPIV3.MediaTypeObject\n ).example = transformer(example);\n\n transformed = true;\n }\n });\n\n // eslint-disable-next-line @typescript-eslint/no-unnecessary-condition\n if (!transformed) {\n (\n (\n // eslint-disable-next-line no-param-reassign\n ((methodSpec.responses as unknown as OpenAPIV3.ResponsesObject)[status] as OpenAPIV3.ResponseObject).content as {\n [key: string]: OpenAPIV3.MediaTypeObject;\n }\n )[mediaType] as OpenAPIV3.MediaTypeObject\n ).example = example;\n }\n });\n });\n};\n\nconst extendComponentExamples = (\n spec: Partial<OpenAPIV3.Document>,\n exampleName: string,\n examples: {\n [media: string]: OpenAPIV3.ExampleObject | OpenAPIV3.ReferenceObject;\n },\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: {\n [media: string]: OpenAPIV3.ExampleObject | OpenAPIV3.ReferenceObject;\n },\n // eslint-disable-next-line radar/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 (\n (\n // eslint-disable-next-line no-param-reassign\n ((methodSpec.responses as unknown as OpenAPIV3.ResponsesObject)[status] as OpenAPIV3.ResponseObject).content as {\n [key: string]: OpenAPIV3.MediaTypeObject;\n }\n )[mediaType] as OpenAPIV3.MediaTypeObject\n ).examples = {};\n }\n\n const transformedExamples: {\n [media: string]: OpenAPIV3.ExampleObject | OpenAPIV3.ReferenceObject;\n } = {};\n\n Object.entries(examples).forEach(([exampleName, example]) => {\n let transformed: boolean = 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 // eslint-disable-next-line @typescript-eslint/no-unnecessary-condition\n if (!transformed) {\n transformedExamples[exampleName] = spec.components?.examples?.[exampleName] === undefined\n ? example\n : {\n $ref: `#/components/examples/${exampleName}`,\n };\n }\n });\n\n (\n (\n // eslint-disable-next-line no-param-reassign\n ((methodSpec.responses as unknown as OpenAPIV3.ResponsesObject)[status] as OpenAPIV3.ResponseObject).content as {\n [key: string]: OpenAPIV3.MediaTypeObject;\n }\n )[mediaType] as OpenAPIV3.MediaTypeObject\n ).examples = transformedExamples;\n};\n\nconst extendSwaggerWithMediaTypeExamples = (\n spec: Partial<OpenAPIV3.Document>,\n methodSpec: OpenAPIV3.OperationObject,\n status: string,\n responseSpec: OpenAPIV3.ResponseObject,\n allowedMediaTypes: { [p: string]: boolean } | undefined,\n pathKey: string,\n transformers: Transformers,\n examples: {\n [media: string]: OpenAPIV3.ExampleObject | OpenAPIV3.ReferenceObject;\n },\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 radar/cognitive-complexity\nexport default function extendSwaggerSpec(\n spec: Partial<OpenAPIV3.Document>,\n allowedMediaTypes?: { [key: string]: boolean },\n transformers: Transformers = [\n {\n regex: /xml/,\n transformer: (value: XmlElement | XmlElement[] | undefined) => xml.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 { examples, example } = 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 type { IncomingMessage, ServerResponse } from \"node:http\";\nimport { parse as urlParse } 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\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): unknown => {\n if (request.query) {\n return request.query;\n }\n\n return urlParse(request.url ?? \"\", true).query;\n};\n\nexport const toHeaderCase = (string_: string): string => string_\n .toLowerCase()\n .replace(/[^\\s\\w]/g, \" \") // Remove all non-word characters\n .trimEnd() // Remove trailing spaces\n .replace(/\\s+|_/g, \"-\") // Replace multiple spaces or underline with a single hyphen\n .replace(/\\b\\w/g, (c) => c.toUpperCase());\n"]}
@@ -1,23 +0,0 @@
1
- 'use strict';
2
-
3
- var g = require('next/head');
4
- var redoc = require('redoc');
5
- var jsxRuntime = require('react/jsx-runtime');
6
- var m = require('next/dynamic');
7
- var w = require('debug');
8
-
9
- var c=(t,r={})=>({swaggerData:e})=>jsxRuntime.jsxs(jsxRuntime.Fragment,{children:[jsxRuntime.jsxs(g,{children:[jsxRuntime.jsx("title",{children:t}),jsxRuntime.jsx("style",{children:`
10
- body {
11
- background: #fafafa !important;
12
- }
13
- `})]}),jsxRuntime.jsx(redoc.RedocStandalone,{...r,spec:e})]}),n=c;var y=m(()=>import('swagger-ui-react'),{ssr:!1}),d=(t,r={})=>({swaggerData:e})=>jsxRuntime.jsxs(jsxRuntime.Fragment,{children:[jsxRuntime.jsxs(g,{children:[jsxRuntime.jsx("title",{children:t}),jsxRuntime.jsx("style",{children:`
14
- body {
15
- background: #fafafa !important;
16
- }
17
- `})]}),jsxRuntime.jsx(y,{...r,spec:e})]}),S=d;var u=w("visulima:api-platform:swagger:get-static-properties-swagger"),x=t=>async()=>{let e=await(await fetch(t)).json();return u(e),{props:{swaggerUrl:t,swaggerData:JSON.parse(JSON.stringify(e))}}},I=x;
18
-
19
- exports.a = n;
20
- exports.b = S;
21
- exports.c = I;
22
- //# sourceMappingURL=out.js.map
23
- //# sourceMappingURL=chunk-OC7L637G.js.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../src/framework/next/routes/pages/swagger/redoc.tsx","../src/framework/next/routes/pages/swagger/swagger.tsx","../src/framework/next/routes/pages/swagger/get-static-properties-swagger.ts"],"names":["Head","RedocStandalone","Fragment","jsx","jsxs","RedocApiDocument","name","swagger","swaggerData","redoc_default","dynamic","SwaggerUI","SwaggerApiDocument","swagger_default","debug","swaggerDebug","getStaticProps","swaggerUrl","get_static_properties_swagger_default"],"mappings":"AAGA,OAAOA,MAAU,YAIjB,OAAS,mBAAAC,MAAuB,QAUpB,mBAAAC,EAEQ,OAAAC,EADJ,QAAAC,MADJ,oBALZ,IAAMC,EAI0D,CAACC,EAAMC,EAAU,CAAC,IAAM,CAAC,CAAE,YAAAC,CAAY,IAC3FJ,EAAAF,EAAA,CACI,UAAAE,EAACJ,EAAA,CACG,UAAAG,EAAC,SAAO,SAAAG,EAAK,EACbH,EAAC,SACI;AAAA;AAAA;AAAA;AAAA,EAKL,GACJ,EAEAA,EAACF,EAAA,CAAiB,GAAGM,EAAS,KAAMC,EAAa,GACrD,EAGLC,EAAQJ,EC/Bf,OAAOK,MAAa,eAEpB,OAAOV,MAAU,YAaL,mBAAAE,EAEQ,OAAAC,EADJ,QAAAC,MADJ,oBARZ,IAAMO,EAAYD,EAAQ,IAAM,OAAO,oBAAqB,CAAE,IAAK,EAAM,CAAC,EAGpEE,EAI0D,CAACN,EAAMC,EAAU,CAAC,IAAM,CAAC,CAAE,YAAAC,CAAY,IAC3FJ,EAAAF,EAAA,CACI,UAAAE,EAACJ,EAAA,CACG,UAAAG,EAAC,SAAO,SAAAG,EAAK,EACbH,EAAC,SACI;AAAA;AAAA;AAAA;AAAA,EAKL,GACJ,EAEAA,EAACQ,EAAA,CAAW,GAAGJ,EAAS,KAAMC,EAAa,GAC/C,EAGLK,EAAQD,EChCf,OAAOE,MAAW,QAKlB,IAAMC,EAAeD,EAAM,6DAA6D,EAGlFE,EAEiBC,GAAe,SAKhC,CAGF,IAAMT,EAAc,MADH,MAAM,MAAMS,CAAU,GACJ,KAAK,EAExC,OAAAF,EAAaP,CAAW,EAEjB,CACH,MAAO,CACH,WAAAS,EACA,YAAa,KAAK,MAAM,KAAK,UAAUT,CAAW,CAAC,CACvD,CACJ,CACJ,EAEOU,EAAQF","sourcesContent":["// eslint-disable-next-line import/no-extraneous-dependencies\nimport type { InferGetStaticPropsType, NextPage } from \"next\";\n// eslint-disable-next-line import/no-extraneous-dependencies\nimport Head from \"next/head\";\n// eslint-disable-next-line import/no-extraneous-dependencies\nimport type { RedocStandaloneProps } from \"redoc\";\n// eslint-disable-next-line import/no-extraneous-dependencies\nimport { RedocStandalone } from \"redoc\";\n\nimport type getStaticProps from \"./get-static-properties-swagger\";\n\n// eslint-disable-next-line max-len\nconst RedocApiDocument: (\n name: string,\n swagger?: Exclude<RedocStandaloneProps, \"spec\">,\n // eslint-disable-next-line max-len,unicorn/no-useless-undefined\n) => NextPage<InferGetStaticPropsType<typeof getStaticProps>> = (name, swagger = {}) => ({ 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","import type { InferGetStaticPropsType, NextPage } from \"next\";\n// eslint-disable-next-line import/no-extraneous-dependencies\nimport dynamic from \"next/dynamic\";\n// eslint-disable-next-line import/no-extraneous-dependencies\nimport Head from \"next/head\";\nimport type { SwaggerUIProps } from \"swagger-ui-react\";\n\nimport type getStaticProps from \"./get-static-properties-swagger\";\n// eslint-disable-next-line import/no-extraneous-dependencies\nconst SwaggerUI = dynamic(() => import(\"swagger-ui-react\"), { ssr: false });\n\n// eslint-disable-next-line max-len\nconst SwaggerApiDocument: (\n name: string,\n swagger?: Exclude<SwaggerUIProps, \"spec\">,\n // eslint-disable-next-line max-len,unicorn/no-useless-undefined\n) => NextPage<InferGetStaticPropsType<typeof getStaticProps>> = (name, swagger = {}) => ({ 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 <SwaggerUI {...swagger} spec={swaggerData} />\n </>\n);\n\nexport default SwaggerApiDocument;\n","// eslint-disable-next-line unicorn/prevent-abbreviations\nimport debug from \"debug\";\nimport type { GetStaticProps } from \"next\";\nimport type { OpenAPIV3 } from \"openapi-types\";\n\n// eslint-disable-next-line testing-library/no-debugging-utils\nconst swaggerDebug = debug(\"visulima:api-platform:swagger:get-static-properties-swagger\");\n\n// eslint-disable-next-line unicorn/consistent-function-scoping\nconst getStaticProps: (\n swaggerUrl: string,\n) => GetStaticProps = (swaggerUrl) => async (): Promise<{\n props: {\n swaggerUrl: string;\n swaggerData: OpenAPIV3.Document;\n };\n}> => {\n // eslint-disable-next-line compat/compat\n const response = await fetch(swaggerUrl);\n const swaggerData = await response.json();\n\n swaggerDebug(swaggerData);\n\n return {\n props: {\n swaggerUrl,\n swaggerData: JSON.parse(JSON.stringify(swaggerData)),\n },\n };\n};\n\nexport default getStaticProps;\n"]}
@@ -1,7 +0,0 @@
1
- 'use strict';
2
-
3
- var d=Object.defineProperty;var e=(c,a)=>{for(var b in a)d(c,b,{get:a[b],enumerable:!0});};
4
-
5
- exports.a = e;
6
- //# sourceMappingURL=out.js.map
7
- //# sourceMappingURL=chunk-OUWZ2PU5.js.map
@@ -1,19 +0,0 @@
1
- 'use strict';
2
-
3
- var l = require('chalk');
4
- var child_process = require('child_process');
5
- var fs = require('fs');
6
- var path = require('path');
7
- var y = require('process');
8
- var jsdocOpenApi = require('@visulima/jsdoc-open-api');
9
- var readdir = require('@visulima/readdir');
10
-
11
- var Y=(e,o)=>{if(o.length===0)throw new Error("must include atleast one key to map");let t=e.toString();return o.forEach(r=>{t=r.optional?t.replace("(?:\\/([^\\/]+?))?\\",`/:${r.name}?`):t.replace("(?:([^\\/]+?))",`:${r.name}`);}),t.replace("/?(?=\\/|$)/i","").replace("/^","").replace(/\\/gi,"").replace(/\/{2,}/gi,"/")},A=Y;var z=(e,o)=>{if(typeof e=="string")return e;if(e.fast_slash)return "";if(e.fast_star)return "*";let t="";o.length>0&&(t=A(e,o));let r=/^\/\^((?:\\[$()*+./?[\\\]^{|}]|[^$()*+./?[\\\]^{|}])*)\$\//.exec(e.toString().replace("\\/?","").replace("(?=\\/|$)","$"));return Array.isArray(r)&&r.length>1?r[1].replace(/\\(.)/g,"$1").slice(1):t?t.slice(1):e.toString()},T=z;var Q=(e,o,t)=>{let r=e.route.stack[e.route.stack.length-1],a=o.map(i=>({name:i.name,in:"path",required:!i.optional})),s=e.route.stack.filter(i=>i?.handle?.metadata);if(s.length>1)throw new Error("Only one metadata middleware is allowed per route");let n=(t+e.route.path).replace(/\/{2,}/gi,"/");return s.length===0?{path:n,pathParams:a,method:r.method}:{path:n,pathParams:a,method:r.method,metadata:s[0].handle.metadata}},k=(e,o,t,r)=>{r=[...r,...t.keys],t.name==="router"&&t.handle&&t.handle.stack.forEach(a=>{o=o||"",k(e,`${o}/${T(t.regexp,t.keys)}`,a,r);}),!(!t.route||t.route.stack.length===0)&&e.push(Q(t,r,o));},V=e=>{let o=e._router||e.router,t=[];return o.stack.forEach(r=>{k(t,"",r,[]);}),t},D=V;var Z=e=>{let o=[];return D(e).forEach(t=>{o.push({path:t.path,method:t.method.toUpperCase(),tags:[],file:"unknown"});}),o},$=Z;var j=e=>e.replace(/ \(.*\)/g,"").trim(),O=e=>e.trim().split(" ")[1].slice(1,-1),ee=e=>{let t=e.printRoutes().replace(/[─│└├]/g," ").trimEnd().split(`
12
- `),r=t.reduce((s,n,i)=>{let p=j(n);if(j(t[i-1]??"")===p){let w=s.filter(S=>S.index<i&&S.segment===p),{methods:P}=w[w.length-1];return P!==null&&P.push(O(n)),s}let u=n.replace(/ \(.*\)/g,"").match(/ /g);if(u===null)throw new Error("Invalid spaces");let f=u.length/4,m=n.includes("("),g=m?[O(n)]:null;return s.push({segment:p,index:i,depth:f,isRoute:m,methods:g}),s},[]),a=[];return r.filter(s=>s.isRoute).forEach(s=>{let i=[...r.filter(p=>p.index<s.index&&p.depth<s.depth).filter((p,c,u)=>!u.find(f=>f.depth===p.depth&&f.index>p.index)).map(p=>p.segment),s.segment].join("");if(s.methods===null)throw new Error("Invalid methods");s.methods.forEach(p=>{a.push({path:i,method:p.toUpperCase(),tags:[],file:"unknown"});});}),a},v=ee;var te=e=>{let t=e._core.router.routes,r=[];return [...t.keys()].forEach(a=>{t.get(a).routes.forEach(s=>{r.push({path:s.path,method:s.route.method.toUpperCase(),tags:[],file:"unknown"});});}),r},b=te;var re=e=>{let o=[];return e.middleware.filter(t=>t.router).flatMap(t=>t.router.stack).forEach(t=>{o.push({path:t.path,method:t.methods.join("|").toUpperCase(),tags:[],file:"unknown"});}),o},F=re;var L=/\.(js|ts|mjs|cjs)$/,ae=(e,o,t=!1)=>{let r=[],a=jsdocOpenApi.parseFile(e,jsdocOpenApi.jsDocumentCommentsToOpenApi,t);r=[...r,...a.map(i=>i.spec)];let s=jsdocOpenApi.parseFile(e,jsdocOpenApi.swaggerJsDocumentCommentsToOpenApi,t);r=[...r,...s.map(i=>i.spec)];let n=[];return r.length===0?(fs.readFileSync(e,"utf8").split(/\r?\n/).forEach(p=>{let c=/[=aces|]+\s["'|](GET|POST|PUT|PATCH|HEAD|DELETE|OPTIONS)["'|]/.exec(p);if(c){let[,u]=c;u==="GET"&&(u="GET|HEAD"),n.push({method:u,path:e.replace(o,"").replace(L,""),tags:[],file:e.replace(`${y.cwd()}/`,"")});}}),n.length===0&&n.push({method:"GET|POST|PUT|PATCH|DELETE|HEAD|OPTIONS",path:e.replace(o,"").replace(L,""),tags:[],file:e.replace(`${y.cwd()}/`,"")}),n):(r.forEach(i=>{Object.entries(i.paths).forEach(([c,u])=>{Object.entries(u).forEach(([m,g])=>{n.push({path:c,method:m.toUpperCase(),tags:g.tags,file:e.replace(`${y.cwd()}/`,"")});});});}),n)},N=ae;var h=[".js",".ts",".mjs",".cjs"],I=e=>{let o=path.parse(e);for(;o.base&&o.root!==o.dir;){if(fs.readdirSync(o.dir).find(a=>a==="package.json"))return o.dir;o=path.parse(o.dir);}return null},H=e=>{let o=`${e}/package.json`,t=JSON.parse(fs.readFileSync(o).toString()),{dependencies:r}=t;return r.express?"express":r.koa&&(r["@koa/router"]||r["koa-router"])?"koa":r.next?"next":r["@hapi/hapi"]?"hapi":r.fastify?"fastify":null},K=(e,o)=>Object.keys(e).length===0?null:o==="hapi"?typeof e.app?.app=="string"?e.app:e:e.app??e;var _=e=>{try{return fs.statSync(e).isDirectory()}catch{return !1}},le=async(e="",o=!1)=>{let t=path.join(e,"pages/api");return !_(t)&&(t=path.join(e,"src/pages/api"),!_(t))?[]:readdir.collect(t,{extensions:h,includeDirs:!1,minimatchOptions:{match:{debug:o,matchBase:!0},skip:{debug:o,matchBase:!0}}})},B=le;async function E(e,o,t){if(o==="express")return $(e);if(o==="koa")return F(e);if(o==="hapi")return b(e);if(o==="fastify")return v(e);if(o==="next"){let r=await B(e,t);if(r.length===0)throw new Error(`No API routes found, in "${e}".`);return r.flatMap(a=>N(a,e,t))}return null}var fe=(e,o)=>{let t=new Map;return e.forEach(r=>{let a=o(r),s=t.get(a);s?s.push(r):t.set(a,[r]);}),t},J=fe;var me=(e,o)=>{let t={GET:l.blue,POST:l.yellow,PATCH:l.yellow,PUT:l.yellow,DELETE:l.redBright,OPTIONS:l.hex("#6C7280"),ANY:l.redBright,HEAD:l.hex("#6C7280")},r;if(e==="GET|HEAD")r=`${l.blue("GET")}${l.grey("|HEAD")}`;else {let c=t[e](e);r=e==="GET"?`${c}${l.grey("|HEAD")}`:c;}let a=e==="GET"?6:14-e.length,s=Array.from({length:a}).fill(" ").join(""),n=process.stdout.columns-16-o.length-4,i=n>0?Array.from({length:n}).fill(".").join(""):"",p=o.split("/").map(c=>["[",":"].includes(c[0]??"")?l.yellowBright(c):c).join("/");return ` ${r}${s}${p}${l.grey(i)}`},de=(e,o={})=>e.map(t=>{if(!(Array.isArray(o.methods)&&o.methods.includes(t.method)))return t.method==="GET|POST|PUT|PATCH|DELETE|HEAD|OPTIONS"&&(t.method="ANY"),me(t.method,t.path.replace("/pages",""))}).filter(Boolean),x=de;var ye=async(e,o,t={})=>{let r=path.join(y.cwd(),o);if(!fs.existsSync(r))throw new Error("No such file, invalid path provided.");let a=I(r);if(!a)throw new Error("Please initialize local package.json.");if(e===void 0){let n=H(a);if(!n)throw new Error("Couldn't detect supported back-end framework.");e=n;}let s=null;if(e==="next")s=await E(r,"next",t.verbose??!1);else {if(!fs.statSync(r).isFile())throw new Error(`${r} is directory, but file expected.`);if(!h.includes(path.extname(r)))throw new Error("Please specify application .ts/.js/.mjs/.cjs file.");let n=`${a}/.env`;fs.existsSync(n)&&(await import(`${a}/node_modules/dotenv/lib/main.js`)).config({path:n});let i=path.extname(r)===".ts",p=path.join(a,"node_modules/.bin/tsc");if(i&&!fs.existsSync(p))throw new Error(`Please install typescript in ${a}`);try{if(i)try{child_process.execSync(`${p} --outDir framework-list >&2`,{cwd:a});}catch(f){console.log(`TSC compilation failed. Please resolve issues in your project.
13
- `),console.log(f),fs.rmSync(path.join(a,"framework-list"),{recursive:!0});}let c=i?path.join(a,"framework-list",r.replace(a,"").replace(".ts",".js")):r,{default:u}=await import(c);s=await E(["AsyncFunction","Function"].includes(u.constructor.name)?await u():K(u,e),e,t.verbose??!1);}finally{i&&fs.rmSync(path.join(a,"framework-list"),{recursive:!0});}}if(s===null)throw new Error(`Framework "${e}" is not supported.`);if(Array.isArray(t.includePaths)&&t.includePaths.length>0&&(s=t.includePaths.flatMap(n=>s.filter(i=>i.path.startsWith(n)))),Array.isArray(t.excludePaths)&&t.excludePaths.length>0&&(s=t.excludePaths.flatMap(n=>s.filter(i=>!i.path.startsWith(n)))),typeof t.group=="string"&&t.group!==""){console.log();let n=J(s,p=>t.group==="path"?p.path.replace("/pages","").split("/")[1]:p.tags[0]??"unsorted"),i=0;n.forEach((p,c)=>{i>0&&console.log();let u=(y.stdout.columns-16-c.length)/2,f=u>0?Array.from({length:u}).fill(" ").join(""):"";console.log(f+l.bold.underline(c)),x(p,t).forEach(m=>{console.log(m);}),i+=1;});}else console.log(),x(s,t).forEach(n=>{console.log(n);});console.log(`
14
- Listed ${l.greenBright(String(s.length))} HTTP ${s.length===1?"route":"routes"}.
15
- `);},nt=ye;
16
-
17
- exports.a = nt;
18
- //# sourceMappingURL=out.js.map
19
- //# sourceMappingURL=chunk-PXVY7JQL.js.map