From 768aae730dde3c54db29185134c28d91371357b6 Mon Sep 17 00:00:00 2001 From: saltyaom Date: Sat, 12 Nov 2022 10:09:01 +0700 Subject: [PATCH] :tada: feat: init --- .cjs.swcrc | 24 + .es.swcrc | 24 + .eslintrc.js | 23 + .gitignore | 5 + .npmignore | 15 + CHANGELOG.md | 0 LICENSE | 7 + README.md | 70 +++ bun.lockb | Bin 0 -> 46439 bytes example/index.ts | 58 +++ nodemon.json | 6 + package.json | 53 ++ pnpm-lock.yaml | 1165 ++++++++++++++++++++++++++++++++++++++++++++ src/index.ts | 160 ++++++ test/index.test.ts | 25 + tsconfig.json | 103 ++++ 16 files changed, 1738 insertions(+) create mode 100644 .cjs.swcrc create mode 100644 .es.swcrc create mode 100644 .eslintrc.js create mode 100644 .gitignore create mode 100644 .npmignore create mode 100644 CHANGELOG.md create mode 100644 LICENSE create mode 100644 README.md create mode 100755 bun.lockb create mode 100644 example/index.ts create mode 100644 nodemon.json create mode 100644 package.json create mode 100644 pnpm-lock.yaml create mode 100644 src/index.ts create mode 100644 test/index.test.ts create mode 100644 tsconfig.json diff --git a/.cjs.swcrc b/.cjs.swcrc new file mode 100644 index 0000000..549a7ad --- /dev/null +++ b/.cjs.swcrc @@ -0,0 +1,24 @@ +{ + "module": { + "type": "commonjs" + }, + "exclude": ["(.*).(spec|test).(j|t)s$"], + "jsc": { + "target": "es2020", + "parser": { + "syntax": "typescript" + }, + "minify": { + "mangle": true, + "compress": true + } + }, + "minify": false, + "sourceMaps": true, + "inlineSourcesContent": true, + "env": { + "targets": { + "node": 16 + } + } +} diff --git a/.es.swcrc b/.es.swcrc new file mode 100644 index 0000000..7b88b46 --- /dev/null +++ b/.es.swcrc @@ -0,0 +1,24 @@ +{ + "module": { + "type": "nodenext" + }, + "exclude": ["(.*).(spec|test).(j|t)s$"], + "jsc": { + "target": "es2020", + "parser": { + "syntax": "typescript" + }, + "minify": { + "mangle": true, + "compress": true + } + }, + "minify": false, + "sourceMaps": true, + "inlineSourcesContent": true, + "env": { + "targets": { + "node": 16 + } + } +} diff --git a/.eslintrc.js b/.eslintrc.js new file mode 100644 index 0000000..5aa8146 --- /dev/null +++ b/.eslintrc.js @@ -0,0 +1,23 @@ +module.exports = { + "env": { + "es2021": true, + "node": true + }, + "extends": [ + "eslint:recommended", + "plugin:@typescript-eslint/recommended" + ], + "parser": "@typescript-eslint/parser", + "parserOptions": { + "ecmaVersion": "latest", + "sourceType": "module" + }, + "plugins": [ + "@typescript-eslint" + ], + "rules": { + "@typescript-eslint/ban-types": 'off', + '@typescript-eslint/no-explicit-any': 'off' + }, + "ignorePatterns": ["example/*", "tests/**/*"] +} diff --git a/.gitignore b/.gitignore new file mode 100644 index 0000000..5f7b824 --- /dev/null +++ b/.gitignore @@ -0,0 +1,5 @@ +.DS_Store + +node_modules +.pnpm-debug.log +build \ No newline at end of file diff --git a/.npmignore b/.npmignore new file mode 100644 index 0000000..4cb7478 --- /dev/null +++ b/.npmignore @@ -0,0 +1,15 @@ +.git +.gitignore +.prettierrc +.cjs.swcrc +.es.swcrc +bun.lockb + +node_modules +tsconfig.json +pnpm-lock.yaml +jest.config.js +nodemon.json + +example +tests diff --git a/CHANGELOG.md b/CHANGELOG.md new file mode 100644 index 0000000..e69de29 diff --git a/LICENSE b/LICENSE new file mode 100644 index 0000000..7419435 --- /dev/null +++ b/LICENSE @@ -0,0 +1,7 @@ +Copyright 2022 saltyAom + +Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. diff --git a/README.md b/README.md new file mode 100644 index 0000000..e4add1c --- /dev/null +++ b/README.md @@ -0,0 +1,70 @@ +# @kingworldjs/swagger +A plugin for [kingworld](https://github.com/saltyaom/kingworld) that auto-generate Swagger page. + +## Installation +```bash +bun add @kingworldjs/swagger +``` + +## Example +```typescript +import KingWorld from 'kingworld' +import swagger from '@kingworldjs/swagger' + +const app = new KingWorld() + .use(swagger) + .get('/', () => 'hi') + .get('/unpath/:id', ({ params: { id } }) => id) + .get('/unpath/:id/:name', ({ params: { id, name } }) => `${id} ${name}`) + .post( + '/json/:id', + ({ body, params: { id }, query: { name } }) => ({ + ...body, + id, + name + }), + { + schema: { + params: t.Object({ + id: t.String() + }), + query: t.Object({ + name: t.String() + }), + body: t.Object({ + username: t.String(), + password: t.String() + }), + response: t.Object({ + username: t.String(), + password: t.String(), + id: t.String(), + name: t.String() + }) + } + } + ) + .listen(8080) +``` + +Then go to `http://localhost:8080/swagger`. + +# config + +## swagger +Customize Swagger config, refers to [Swagger 2.0 config](https://swagger.io/specification/v2/) + +## path +@default '/swagger' + +The endpoint to expose Swagger + +## excludeStaticFile +@default true + +Determine if Swagger should exclude static files. + +## exclude +@default [] + +Paths to exclude from Swagger endpoint diff --git a/bun.lockb b/bun.lockb new file mode 100755 index 0000000000000000000000000000000000000000..0e255c587331ca94bd3e33a1e52f8c4b7234d307 GIT binary patch literal 46439 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 Q6{w>$8+Rzy{D1%d4{TDOe*gdg literal 0 HcmV?d00001 diff --git a/example/index.ts b/example/index.ts new file mode 100644 index 0000000..b8299fa --- /dev/null +++ b/example/index.ts @@ -0,0 +1,58 @@ +import { KingWorld, t } from 'kingworld' + +import swagger from '../src/index' + +const app = new KingWorld() + .use(swagger, { + // path: '/v2/swagger', + // swagger: { + // info: { + // title: 'Hello World', + // version: '0.0.0' + // } + // } + }) + .get('/', () => 'hi') + .get('/unpath/:id', ({ params: { id } }) => id) + .get('/unpath/:id/:name', ({ params: { id } }) => id) + .post( + '/json/:id', + ({ body, params: { id }, query: { name } }) => ({ + ...body, + id, + name + }), + { + schema: { + params: t.Object({ + id: t.String() + }), + query: t.Object({ + name: t.String() + }), + body: t.Object({ + username: t.String(), + password: t.String() + }), + response: t.Object({ + username: t.String(), + password: t.String(), + id: t.String(), + name: t.String() + }) + } + } + ) + .post('/json', ({ body }) => body, { + schema: { + body: t.Object({ + username: t.String(), + password: t.String() + }), + response: t.Object({ + username: t.String(), + password: t.String() + }) + } + }) + .listen(8080) diff --git a/nodemon.json b/nodemon.json new file mode 100644 index 0000000..b619375 --- /dev/null +++ b/nodemon.json @@ -0,0 +1,6 @@ +{ + "restartable": "rs", + "ignore": [".git", "node_modules/", "build/"], + "exec": "bun example/index.ts", + "ext": "js, json, ts" +} diff --git a/package.json b/package.json new file mode 100644 index 0000000..21f5a3e --- /dev/null +++ b/package.json @@ -0,0 +1,53 @@ +{ + "name": "@kingworldjs/swagger", + "version": "0.0.0-experimental.0", + "description": "A plugin for kingworld that auto-generate Swagger page", + "author": { + "name": "saltyAom", + "url": "https://github.com/SaltyAom", + "email": "saltyaom@gmail.com" + }, + "main": "build/index.js", + "module": "build/es/index.js", + "esnext": "build/es/index.js", + "types": "src/index.ts", + "typings": "src/index.ts", + "keywords": [ + "kingworld", + "swagger" + ], + "homepage": "https://github.com/saltyaom/kingworld-swagger", + "repository": { + "type": "git", + "url": "https://github.com/saltyaom/kingworld-swagger" + }, + "bugs": "https://github.com/SaltyAom/kingworld-swagger/issues", + "license": "MIT", + "scripts": { + "dev": "nodemon --config nodemon.json", + "test": "bun wiptest", + "build": "npm run build:main && npm run build:es", + "build:main": "swc src --config-file .cjs.swcrc -d build", + "build:es": "swc src --config-file .es.swcrc -d build/es", + "release": "npm run build && npm run test && npm publish --access public" + }, + "peerDependencies": { + "kingworld": ">= 0.0.0-experimental.41" + }, + "devDependencies": { + "@swc/cli": "^0.1.57", + "@swc/core": "^1.3.11", + "@types/node": "^18.11.7", + "@types/swagger-ui-dist": "^3.30.1", + "bun-types": "^0.2.2", + "eslint": "^8.26.0", + "kingworld": "^0.0.0-experimental.41", + "nodemon": "^2.0.20", + "openapi-types": "^12.0.2", + "typescript": "^4.8.4" + }, + "dependencies": { + "@kingworldjs/static": "0.0.0-experimental.1", + "swagger-ui-dist": "^4.15.5" + } +} diff --git a/pnpm-lock.yaml b/pnpm-lock.yaml new file mode 100644 index 0000000..016e5b2 --- /dev/null +++ b/pnpm-lock.yaml @@ -0,0 +1,1165 @@ +lockfileVersion: 5.4 + +specifiers: + '@swc/cli': ^0.1.57 + '@swc/core': ^1.3.11 + '@types/cookie': ^0.5.1 + '@types/cookie-signature': ^1.0.4 + '@types/node': ^18.11.7 + bun-types: ^0.2.2 + cookie: ^0.5.0 + eslint: ^8.26.0 + kingworld: 0.0.0-experimental.28 + nodemon: ^2.0.20 + typescript: ^4.8.4 + +dependencies: + cookie: 0.5.0 + +devDependencies: + '@swc/cli': 0.1.57_@swc+core@1.3.11 + '@swc/core': 1.3.11 + '@types/cookie': 0.5.1 + '@types/cookie-signature': 1.0.4 + '@types/node': 18.11.7 + bun-types: 0.2.2 + eslint: 8.26.0 + kingworld: 0.0.0-experimental.28 + nodemon: 2.0.20 + typescript: 4.8.4 + +packages: + + /@eslint/eslintrc/1.3.3: + resolution: {integrity: sha512-uj3pT6Mg+3t39fvLrj8iuCIJ38zKO9FpGtJ4BBJebJhEwjoT+KLVNCcHT5QC9NGRIEi7fZ0ZR8YRb884auB4Lg==} + engines: {node: ^12.22.0 || ^14.17.0 || >=16.0.0} + dependencies: + ajv: 6.12.6 + debug: 4.3.4 + espree: 9.4.0 + globals: 13.17.0 + ignore: 5.2.0 + import-fresh: 3.3.0 + js-yaml: 4.1.0 + minimatch: 3.1.2 + strip-json-comments: 3.1.1 + transitivePeerDependencies: + - supports-color + dev: true + + /@humanwhocodes/config-array/0.11.7: + resolution: {integrity: sha512-kBbPWzN8oVMLb0hOUYXhmxggL/1cJE6ydvjDIGi9EnAGUyA7cLVKQg+d/Dsm+KZwx2czGHrCmMVLiyg8s5JPKw==} + engines: {node: '>=10.10.0'} + dependencies: + '@humanwhocodes/object-schema': 1.2.1 + debug: 4.3.4 + minimatch: 3.1.2 + transitivePeerDependencies: + - supports-color + dev: true + + /@humanwhocodes/module-importer/1.0.1: + resolution: {integrity: sha512-bxveV4V8v5Yb4ncFTT3rPSgZBOpCkjfK0y4oVVVJwIuDVBRMDXrPyXRL988i5ap9m9bnyEEjWfm5WkBmtffLfA==} + engines: {node: '>=12.22'} + dev: true + + /@humanwhocodes/object-schema/1.2.1: + resolution: {integrity: sha512-ZnQMnLV4e7hDlUvw8H+U8ASL02SS2Gn6+9Ac3wGGLIe7+je2AeAOxPY+izIPJDfFDb7eDjev0Us8MO1iFRN8hA==} + dev: true + + /@medley/router/0.2.1: + resolution: {integrity: sha512-mdvS1spIxmZoUbTdYmWknHtwm72WwrGNoQCDd4RTvcXJ9G6XThxeC3g+cpOf6Fw6vIERHt50pYiJpsk5XTJQ5w==} + engines: {node: '>=8'} + dependencies: + object-treeify: 1.1.33 + dev: true + + /@nodelib/fs.scandir/2.1.5: + resolution: {integrity: sha512-vq24Bq3ym5HEQm2NKCr3yXDwjc7vTsEThRDnkp2DK9p1uqLR+DHurm/NOTo0KG7HYHU7eppKZj3MyqYuMBf62g==} + engines: {node: '>= 8'} + dependencies: + '@nodelib/fs.stat': 2.0.5 + run-parallel: 1.2.0 + dev: true + + /@nodelib/fs.stat/2.0.5: + resolution: {integrity: sha512-RkhPPp2zrqDAQA/2jNhnztcPAlv64XdhIp7a7454A5ovI7Bukxgt7MX7udwAu3zg1DcpPU0rz3VV1SeaqvY4+A==} + engines: {node: '>= 8'} + dev: true + + /@nodelib/fs.walk/1.2.8: + resolution: {integrity: sha512-oGB+UxlgWcgQkgwo8GcEGwemoTFt3FIO9ababBmaGwXIoBKZ+GTy0pP185beGg7Llih/NSHSV2XAs1lnznocSg==} + engines: {node: '>= 8'} + dependencies: + '@nodelib/fs.scandir': 2.1.5 + fastq: 1.13.0 + dev: true + + /@saltyaom/trek-router/0.0.7: + resolution: {integrity: sha512-59391o76kGiMT5uYkA3B5wMoseLrpICiWem5pt8vg2RfxfSXwdLLSijp9xRUBhY6oHSYKwWr+If5bsLIQ/cbUw==} + dev: true + + /@swc/cli/0.1.57_@swc+core@1.3.11: + resolution: {integrity: sha512-HxM8TqYHhAg+zp7+RdTU69bnkl4MWdt1ygyp6BDIPjTiaJVH6Dizn2ezbgDS8mnFZI1FyhKvxU/bbaUs8XhzQg==} + engines: {node: '>= 12.13'} + hasBin: true + peerDependencies: + '@swc/core': ^1.2.66 + chokidar: ^3.5.1 + peerDependenciesMeta: + chokidar: + optional: true + dependencies: + '@swc/core': 1.3.11 + commander: 7.2.0 + fast-glob: 3.2.12 + slash: 3.0.0 + source-map: 0.7.4 + dev: true + + /@swc/core-android-arm-eabi/1.3.11: + resolution: {integrity: sha512-LC9JlMcdFmTU94KKmQkJKaPSeVmYTfVm2rKGESMiFrgIjopXL/Zeg+XHA97ucnh5iUMkWIpXAMzSOaVRs33K5g==} + engines: {node: '>=10'} + cpu: [arm] + os: [android] + requiresBuild: true + dependencies: + '@swc/wasm': 1.2.122 + dev: true + optional: true + + /@swc/core-android-arm64/1.3.11: + resolution: {integrity: sha512-M7FamR3kFpVTyTw73FzKcOZmS7/TWHX75eqtwBTaU9fW4shf0KTLr/h9DnMxNKAnwUMeub/lqlINUe5EKFIKwQ==} + engines: {node: '>=10'} + cpu: [arm64] + os: [android] + requiresBuild: true + dependencies: + '@swc/wasm': 1.2.130 + dev: true + optional: true + + /@swc/core-darwin-arm64/1.3.11: + resolution: {integrity: sha512-LOoiw3uQDuoKBLW3Mn8p6wIccpYjAoDI3ROdto4MksLQSraHMufXY8bqqncfVuy1750XZmC1qnU39RC3yihPfA==} + engines: {node: '>=10'} + cpu: [arm64] + os: [darwin] + requiresBuild: true + dev: true + optional: true + + /@swc/core-darwin-x64/1.3.11: + resolution: {integrity: sha512-ycjrEbWmpU8MTDdVLdf76ClxQCSTfNqSoP59hieLzhmXpXUa7Oy4sN/v6WSQgp4I1euGs1Wp5kPU5hH5f7XBJQ==} + engines: {node: '>=10'} + cpu: [x64] + os: [darwin] + requiresBuild: true + dev: true + optional: true + + /@swc/core-freebsd-x64/1.3.11: + resolution: {integrity: sha512-02uqYktPp6WmZfZ2Crc/yIVOcgANtjo8ciHcT7yLHvz7v+S7gx1I2tyNGUFtTX5hcR2IFNGrL8Yj4DvpTABFHg==} + engines: {node: '>=10'} + cpu: [x64] + os: [freebsd] + requiresBuild: true + dependencies: + '@swc/wasm': 1.2.130 + dev: true + optional: true + + /@swc/core-linux-arm-gnueabihf/1.3.11: + resolution: {integrity: sha512-nZ2T/gPFncsIiFGhVeVY9vRCTX0hTdqso8OEvFhSwRfRvcEYOpb/rhMG09are7YoB44GMiku5tSzEiNmvT3GuQ==} + engines: {node: '>=10'} + cpu: [arm] + os: [linux] + requiresBuild: true + dependencies: + '@swc/wasm': 1.2.130 + dev: true + optional: true + + /@swc/core-linux-arm64-gnu/1.3.11: + resolution: {integrity: sha512-EWEd8NnGwhykEDFIet/r4Fcfr6805ecnBniHZWmG8UVYUp5tz7LYEMZesxCxa0+aGVpCmxHL5/Cdk1uEIrVIzg==} + engines: {node: '>=10'} + cpu: [arm64] + os: [linux] + requiresBuild: true + dev: true + optional: true + + /@swc/core-linux-arm64-musl/1.3.11: + resolution: {integrity: sha512-ms7CLj2+8sfTM2QnnwqDheYRky9rgPpX2hXmc0KltX+AiSAs7WURjn2JwXWkaICDzXL+djennfswxSspJ53knw==} + engines: {node: '>=10'} + cpu: [arm64] + os: [linux] + requiresBuild: true + dev: true + optional: true + + /@swc/core-linux-x64-gnu/1.3.11: + resolution: {integrity: sha512-Fq5/QEY0IbzpIrqlvQT59aMf+nLk//esL3Aj4nvZdsvF4iZaD2oHtXW+/MBi0i1HV9OBWApGZMygYNVS0uVZkQ==} + engines: {node: '>=10'} + cpu: [x64] + os: [linux] + requiresBuild: true + dev: true + optional: true + + /@swc/core-linux-x64-musl/1.3.11: + resolution: {integrity: sha512-S/KoEgRHwGhs7VunHiz4jLrnFOJvqZe391j2MiYN1p2EThoGI3rvwcUoHkoxLCXVuDbi4E91qodOheaMGetWNA==} + engines: {node: '>=10'} + cpu: [x64] + os: [linux] + requiresBuild: true + dev: true + optional: true + + /@swc/core-win32-arm64-msvc/1.3.11: + resolution: {integrity: sha512-fFby7KOQIxolR6w4Gie8MSkgQ3ee6j3r7A6PX4ekzu+509QsZogLPZnWFTJ8WFo7ui0tx/ocA5X8BV4ZNBVlKQ==} + engines: {node: '>=10'} + cpu: [arm64] + os: [win32] + requiresBuild: true + dependencies: + '@swc/wasm': 1.2.130 + dev: true + optional: true + + /@swc/core-win32-ia32-msvc/1.3.11: + resolution: {integrity: sha512-fii7Y33S9Z5oZ/BTsXa8Ou/RZ4T/ZsAOFpG7mMvifpdAP6LVWdhLoNy7SeeEHTEAWGcWNA/FslA6p2WETvEEfA==} + engines: {node: '>=10'} + cpu: [ia32] + os: [win32] + requiresBuild: true + dependencies: + '@swc/wasm': 1.2.130 + dev: true + optional: true + + /@swc/core-win32-x64-msvc/1.3.11: + resolution: {integrity: sha512-cDF4qBQLf3U0KypnLn3T1HtE12QmEplPGjWs2Xd/hzVkjsPixVR8XIgLlczsj7Pk7Of7VDnUDLIl52aIdgTm8w==} + engines: {node: '>=10'} + cpu: [x64] + os: [win32] + requiresBuild: true + dev: true + optional: true + + /@swc/core/1.3.11: + resolution: {integrity: sha512-lnCnnnNCsnbrhW/gwkoN0sAeIqOyoHLS4ZB20xmPJjKVfvTnJrAcNnLSiwlYdcoUSFqT2GYZjUAG6usEzRQASA==} + engines: {node: '>=10'} + hasBin: true + requiresBuild: true + optionalDependencies: + '@swc/core-android-arm-eabi': 1.3.11 + '@swc/core-android-arm64': 1.3.11 + '@swc/core-darwin-arm64': 1.3.11 + '@swc/core-darwin-x64': 1.3.11 + '@swc/core-freebsd-x64': 1.3.11 + '@swc/core-linux-arm-gnueabihf': 1.3.11 + '@swc/core-linux-arm64-gnu': 1.3.11 + '@swc/core-linux-arm64-musl': 1.3.11 + '@swc/core-linux-x64-gnu': 1.3.11 + '@swc/core-linux-x64-musl': 1.3.11 + '@swc/core-win32-arm64-msvc': 1.3.11 + '@swc/core-win32-ia32-msvc': 1.3.11 + '@swc/core-win32-x64-msvc': 1.3.11 + dev: true + + /@swc/wasm/1.2.122: + resolution: {integrity: sha512-sM1VCWQxmNhFtdxME+8UXNyPNhxNu7zdb6ikWpz0YKAQQFRGT5ThZgJrubEpah335SUToNg8pkdDF7ibVCjxbQ==} + requiresBuild: true + dev: true + optional: true + + /@swc/wasm/1.2.130: + resolution: {integrity: sha512-rNcJsBxS70+pv8YUWwf5fRlWX6JoY/HJc25HD/F8m6Kv7XhJdqPPMhyX6TKkUBPAG7TWlZYoxa+rHAjPy4Cj3Q==} + requiresBuild: true + dev: true + optional: true + + /@types/cookie-signature/1.0.4: + resolution: {integrity: sha512-B9LOCjVnLniz5NHq8pPFQdDjRGtLZKYG7tQHveMeUalWvZgOuLQ5OeWgx3y4/WLJFt0N+tYyk8HMEOsvCjf7Yw==} + dev: true + + /@types/cookie/0.5.1: + resolution: {integrity: sha512-COUnqfB2+ckwXXSFInsFdOAWQzCCx+a5hq2ruyj+Vjund94RJQd4LG2u9hnvJrTgunKAaax7ancBYlDrNYxA0g==} + dev: true + + /@types/json-schema/7.0.11: + resolution: {integrity: sha512-wOuvG1SN4Us4rez+tylwwwCV1psiNVOkJeM3AUWUNWg/jDQY2+HE/444y5gc+jBmRqASOm2Oeh5c1axHobwRKQ==} + dev: true + + /@types/node/18.11.7: + resolution: {integrity: sha512-LhFTglglr63mNXUSRYD8A+ZAIu5sFqNJ4Y2fPuY7UlrySJH87rRRlhtVmMHplmfk5WkoJGmDjE9oiTfyX94CpQ==} + dev: true + + /abbrev/1.1.1: + resolution: {integrity: sha512-nne9/IiQ/hzIhY6pdDnbBtz7DjPTKrY00P/zvPSm5pOFkl6xuGrGnXn/VtTNNfNtAfZ9/1RtehkszU9qcTii0Q==} + dev: true + + /acorn-jsx/5.3.2_acorn@8.8.1: + resolution: {integrity: sha512-rq9s+JNhf0IChjtDXxllJ7g41oZk5SlXtp0LHwyA5cejwn7vKmKp4pPri6YEePv2PU65sAsegbXtIinmDFDXgQ==} + peerDependencies: + acorn: ^6.0.0 || ^7.0.0 || ^8.0.0 + dependencies: + acorn: 8.8.1 + dev: true + + /acorn/8.8.1: + resolution: {integrity: sha512-7zFpHzhnqYKrkYdUjF1HI1bzd0VygEGX8lFk4k5zVMqHEoES+P+7TKI+EvLO9WVMJ8eekdO0aDEK044xTXwPPA==} + engines: {node: '>=0.4.0'} + hasBin: true + dev: true + + /ajv/6.12.6: + resolution: {integrity: sha512-j3fVLgvTo527anyYyJOGTYJbG+vnnQYvE0m5mmkc1TK+nxAppkCLMIL0aZ4dblVCNoGShhm+kzE4ZUykBoMg4g==} + dependencies: + fast-deep-equal: 3.1.3 + fast-json-stable-stringify: 2.1.0 + json-schema-traverse: 0.4.1 + uri-js: 4.4.1 + dev: true + + /ajv/8.11.0: + resolution: {integrity: sha512-wGgprdCvMalC0BztXvitD2hC04YffAvtsUn93JbGXYLAtCUO4xd17mCCZQxUOItiBwZvJScWo8NIvQMQ71rdpg==} + dependencies: + fast-deep-equal: 3.1.3 + json-schema-traverse: 1.0.0 + require-from-string: 2.0.2 + uri-js: 4.4.1 + dev: true + + /ansi-regex/5.0.1: + resolution: {integrity: sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==} + engines: {node: '>=8'} + dev: true + + /ansi-styles/4.3.0: + resolution: {integrity: sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==} + engines: {node: '>=8'} + dependencies: + color-convert: 2.0.1 + dev: true + + /anymatch/3.1.2: + resolution: {integrity: sha512-P43ePfOAIupkguHUycrc4qJ9kz8ZiuOUijaETwX7THt0Y/GNK7v0aa8rY816xWjZ7rJdA5XdMcpVFTKMq+RvWg==} + engines: {node: '>= 8'} + dependencies: + normalize-path: 3.0.0 + picomatch: 2.3.1 + dev: true + + /argparse/2.0.1: + resolution: {integrity: sha512-8+9WqebbFzpX9OR+Wa6O29asIogeRMzcGtAINdpMHHyAg10f05aSFVBbcEqGf/PXw1EjAZ+q2/bEBg3DvurK3Q==} + dev: true + + /balanced-match/1.0.2: + resolution: {integrity: sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==} + dev: true + + /binary-extensions/2.2.0: + resolution: {integrity: sha512-jDctJ/IVQbZoJykoeHbhXpOlNBqGNcwXJKJog42E5HDPUwQTSdjCHdihjj0DlnheQ7blbT6dHOafNAiS8ooQKA==} + engines: {node: '>=8'} + dev: true + + /brace-expansion/1.1.11: + resolution: {integrity: sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==} + dependencies: + balanced-match: 1.0.2 + concat-map: 0.0.1 + dev: true + + /braces/3.0.2: + resolution: {integrity: sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A==} + engines: {node: '>=8'} + dependencies: + fill-range: 7.0.1 + dev: true + + /bun-types/0.2.2: + resolution: {integrity: sha512-/1IPC/PPWvV39I7uulBcWHL0Xpi1BqvwF34R/2gRwt0/l5MJB1gt15GLwLP33d59EnkOdRYibImuCg0l/9BRng==} + dev: true + + /callsites/3.1.0: + resolution: {integrity: sha512-P8BjAsXvZS+VIDUI11hHCQEv74YT67YUi5JJFNWIqL235sBmjX4+qx9Muvls5ivyNENctx46xQLQ3aTuE7ssaQ==} + engines: {node: '>=6'} + dev: true + + /chalk/4.1.2: + resolution: {integrity: sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==} + engines: {node: '>=10'} + dependencies: + ansi-styles: 4.3.0 + supports-color: 7.2.0 + dev: true + + /chokidar/3.5.3: + resolution: {integrity: sha512-Dr3sfKRP6oTcjf2JmUmFJfeVMvXBdegxB0iVQ5eb2V10uFJUCAS8OByZdVAyVb8xXNz3GjjTgj9kLWsZTqE6kw==} + engines: {node: '>= 8.10.0'} + dependencies: + anymatch: 3.1.2 + braces: 3.0.2 + glob-parent: 5.1.2 + is-binary-path: 2.1.0 + is-glob: 4.0.3 + normalize-path: 3.0.0 + readdirp: 3.6.0 + optionalDependencies: + fsevents: 2.3.2 + dev: true + + /color-convert/2.0.1: + resolution: {integrity: sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==} + engines: {node: '>=7.0.0'} + dependencies: + color-name: 1.1.4 + dev: true + + /color-name/1.1.4: + resolution: {integrity: sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==} + dev: true + + /commander/7.2.0: + resolution: {integrity: sha512-QrWXB+ZQSVPmIWIhtEO9H+gwHaMGYiF5ChvoJ+K9ZGHG/sVsa6yiesAD1GC/x46sET00Xlwo1u49RVVVzvcSkw==} + engines: {node: '>= 10'} + dev: true + + /concat-map/0.0.1: + resolution: {integrity: sha1-2Klr13/Wjfd5OnMDajug1UBdR3s=} + dev: true + + /cookie/0.5.0: + resolution: {integrity: sha512-YZ3GUyn/o8gfKJlnlX7g7xq4gyO6OSuhGPKaaGssGB2qgDUS0gPgtTvoyZLTt9Ab6dC4hfc9dV5arkvc/OCmrw==} + engines: {node: '>= 0.6'} + dev: false + + /cross-spawn/7.0.3: + resolution: {integrity: sha512-iRDPJKUPVEND7dHPO8rkbOnPpyDygcDFtWjpeWNCgy8WP2rXcxXL8TskReQl6OrB2G7+UJrags1q15Fudc7G6w==} + engines: {node: '>= 8'} + dependencies: + path-key: 3.1.1 + shebang-command: 2.0.0 + which: 2.0.2 + dev: true + + /debug/3.2.7_supports-color@5.5.0: + resolution: {integrity: sha512-CFjzYYAi4ThfiQvizrFQevTTXHtnCqWfe7x1AhgEscTz6ZbLbfoLRLPugTQyBth6f8ZERVUSyWHFD/7Wu4t1XQ==} + peerDependencies: + supports-color: '*' + peerDependenciesMeta: + supports-color: + optional: true + dependencies: + ms: 2.1.3 + supports-color: 5.5.0 + dev: true + + /debug/4.3.4: + resolution: {integrity: sha512-PRWFHuSU3eDtQJPvnNY7Jcket1j0t5OuOsFzPPzsekD52Zl8qUfFIPEiswXqIvHWGVHOgX+7G/vCNNhehwxfkQ==} + engines: {node: '>=6.0'} + peerDependencies: + supports-color: '*' + peerDependenciesMeta: + supports-color: + optional: true + dependencies: + ms: 2.1.2 + dev: true + + /deep-is/0.1.4: + resolution: {integrity: sha512-oIPzksmTg4/MriiaYGO+okXDT7ztn/w3Eptv/+gSIdMdKsJo0u4CfYNFJPy+4SKMuCqGw2wxnA+URMg3t8a/bQ==} + dev: true + + /doctrine/3.0.0: + resolution: {integrity: sha512-yS+Q5i3hBf7GBkd4KG8a7eBNNWNGLTaEwwYWUijIYM7zrlYDM0BFXHjjPWlWZ1Rg7UaddZeIDmi9jF3HmqiQ2w==} + engines: {node: '>=6.0.0'} + dependencies: + esutils: 2.0.3 + dev: true + + /escape-string-regexp/4.0.0: + resolution: {integrity: sha512-TtpcNJ3XAzx3Gq8sWRzJaVajRs0uVxA2YAkdb1jm2YkPz4G6egUFAyA3n5vtEIZefPk5Wa4UXbKuS5fKkJWdgA==} + engines: {node: '>=10'} + dev: true + + /eslint-scope/7.1.1: + resolution: {integrity: sha512-QKQM/UXpIiHcLqJ5AOyIW7XZmzjkzQXYE54n1++wb0u9V/abW3l9uQnxX8Z5Xd18xyKIMTUAyQ0k1e8pz6LUrw==} + engines: {node: ^12.22.0 || ^14.17.0 || >=16.0.0} + dependencies: + esrecurse: 4.3.0 + estraverse: 5.3.0 + dev: true + + /eslint-utils/3.0.0_eslint@8.26.0: + resolution: {integrity: sha512-uuQC43IGctw68pJA1RgbQS8/NP7rch6Cwd4j3ZBtgo4/8Flj4eGE7ZYSZRN3iq5pVUv6GPdW5Z1RFleo84uLDA==} + engines: {node: ^10.0.0 || ^12.0.0 || >= 14.0.0} + peerDependencies: + eslint: '>=5' + dependencies: + eslint: 8.26.0 + eslint-visitor-keys: 2.1.0 + dev: true + + /eslint-visitor-keys/2.1.0: + resolution: {integrity: sha512-0rSmRBzXgDzIsD6mGdJgevzgezI534Cer5L/vyMX0kHzT/jiB43jRhd9YUlMGYLQy2zprNmoT8qasCGtY+QaKw==} + engines: {node: '>=10'} + dev: true + + /eslint-visitor-keys/3.3.0: + resolution: {integrity: sha512-mQ+suqKJVyeuwGYHAdjMFqjCyfl8+Ldnxuyp3ldiMBFKkvytrXUZWaiPCEav8qDHKty44bD+qV1IP4T+w+xXRA==} + engines: {node: ^12.22.0 || ^14.17.0 || >=16.0.0} + dev: true + + /eslint/8.26.0: + resolution: {integrity: sha512-kzJkpaw1Bfwheq4VXUezFriD1GxszX6dUekM7Z3aC2o4hju+tsR/XyTC3RcoSD7jmy9VkPU3+N6YjVU2e96Oyg==} + engines: {node: ^12.22.0 || ^14.17.0 || >=16.0.0} + hasBin: true + dependencies: + '@eslint/eslintrc': 1.3.3 + '@humanwhocodes/config-array': 0.11.7 + '@humanwhocodes/module-importer': 1.0.1 + '@nodelib/fs.walk': 1.2.8 + ajv: 6.12.6 + chalk: 4.1.2 + cross-spawn: 7.0.3 + debug: 4.3.4 + doctrine: 3.0.0 + escape-string-regexp: 4.0.0 + eslint-scope: 7.1.1 + eslint-utils: 3.0.0_eslint@8.26.0 + eslint-visitor-keys: 3.3.0 + espree: 9.4.0 + esquery: 1.4.0 + esutils: 2.0.3 + fast-deep-equal: 3.1.3 + file-entry-cache: 6.0.1 + find-up: 5.0.0 + glob-parent: 6.0.2 + globals: 13.17.0 + grapheme-splitter: 1.0.4 + ignore: 5.2.0 + import-fresh: 3.3.0 + imurmurhash: 0.1.4 + is-glob: 4.0.3 + is-path-inside: 3.0.3 + js-sdsl: 4.1.5 + js-yaml: 4.1.0 + json-stable-stringify-without-jsonify: 1.0.1 + levn: 0.4.1 + lodash.merge: 4.6.2 + minimatch: 3.1.2 + natural-compare: 1.4.0 + optionator: 0.9.1 + regexpp: 3.2.0 + strip-ansi: 6.0.1 + strip-json-comments: 3.1.1 + text-table: 0.2.0 + transitivePeerDependencies: + - supports-color + dev: true + + /espree/9.4.0: + resolution: {integrity: sha512-DQmnRpLj7f6TgN/NYb0MTzJXL+vJF9h3pHy4JhCIs3zwcgez8xmGg3sXHcEO97BrmO2OSvCwMdfdlyl+E9KjOw==} + engines: {node: ^12.22.0 || ^14.17.0 || >=16.0.0} + dependencies: + acorn: 8.8.1 + acorn-jsx: 5.3.2_acorn@8.8.1 + eslint-visitor-keys: 3.3.0 + dev: true + + /esquery/1.4.0: + resolution: {integrity: sha512-cCDispWt5vHHtwMY2YrAQ4ibFkAL8RbH5YGBnZBc90MolvvfkkQcJro/aZiAQUlQ3qgrYS6D6v8Gc5G5CQsc9w==} + engines: {node: '>=0.10'} + dependencies: + estraverse: 5.3.0 + dev: true + + /esrecurse/4.3.0: + resolution: {integrity: sha512-KmfKL3b6G+RXvP8N1vr3Tq1kL/oCFgn2NYXEtqP8/L3pKapUA4G8cFVaoF3SU323CD4XypR/ffioHmkti6/Tag==} + engines: {node: '>=4.0'} + dependencies: + estraverse: 5.3.0 + dev: true + + /estraverse/5.3.0: + resolution: {integrity: sha512-MMdARuVEQziNTeJD8DgMqmhwR11BRQ/cBP+pLtYdSTnf3MIO8fFeiINEbX36ZdNlfU/7A9f3gUw49B3oQsvwBA==} + engines: {node: '>=4.0'} + dev: true + + /esutils/2.0.3: + resolution: {integrity: sha512-kVscqXk4OCp68SZ0dkgEKVi6/8ij300KBWTJq32P/dYeWTSwK41WyTxalN1eRmA5Z9UU/LX9D7FWSmV9SAYx6g==} + engines: {node: '>=0.10.0'} + dev: true + + /fast-deep-equal/3.1.3: + resolution: {integrity: sha512-f3qQ9oQy9j2AhBe/H9VC91wLmKBCCU/gDOnKNAYG5hswO7BLKj09Hc5HYNz9cGI++xlpDCIgDaitVs03ATR84Q==} + dev: true + + /fast-glob/3.2.12: + resolution: {integrity: sha512-DVj4CQIYYow0BlaelwK1pHl5n5cRSJfM60UA0zK891sVInoPri2Ekj7+e1CT3/3qxXenpI+nBBmQAcJPJgaj4w==} + engines: {node: '>=8.6.0'} + dependencies: + '@nodelib/fs.stat': 2.0.5 + '@nodelib/fs.walk': 1.2.8 + glob-parent: 5.1.2 + merge2: 1.4.1 + micromatch: 4.0.5 + dev: true + + /fast-json-stable-stringify/2.1.0: + resolution: {integrity: sha512-lhd/wF+Lk98HZoTCtlVraHtfh5XYijIjalXck7saUtuanSDyLMxnHhSXEDJqHxD7msR8D0uCmqlkwjCV8xvwHw==} + dev: true + + /fast-levenshtein/2.0.6: + resolution: {integrity: sha512-DCXu6Ifhqcks7TZKY3Hxp3y6qphY5SJZmrWMDrKcERSOXWQdMhU9Ig/PYrzyw/ul9jOIyh0N4M0tbC5hodg8dw==} + dev: true + + /fastq/1.13.0: + resolution: {integrity: sha512-YpkpUnK8od0o1hmeSc7UUs/eB/vIPWJYjKck2QKIzAf71Vm1AAQ3EbuZB3g2JIy+pg+ERD0vqI79KyZiB2e2Nw==} + dependencies: + reusify: 1.0.4 + dev: true + + /file-entry-cache/6.0.1: + resolution: {integrity: sha512-7Gps/XWymbLk2QLYK4NzpMOrYjMhdIxXuIvy2QBsLE6ljuodKvdkWs/cpyJJ3CVIVpH0Oi1Hvg1ovbMzLdFBBg==} + engines: {node: ^10.12.0 || >=12.0.0} + dependencies: + flat-cache: 3.0.4 + dev: true + + /fill-range/7.0.1: + resolution: {integrity: sha512-qOo9F+dMUmC2Lcb4BbVvnKJxTPjCm+RRpe4gDuGrzkL7mEVl/djYSu2OdQ2Pa302N4oqkSg9ir6jaLWJ2USVpQ==} + engines: {node: '>=8'} + dependencies: + to-regex-range: 5.0.1 + dev: true + + /find-up/5.0.0: + resolution: {integrity: sha512-78/PXT1wlLLDgTzDs7sjq9hzz0vXD+zn+7wypEe4fXQxCmdmqfGsEPQxmiCSQI3ajFV91bVSsvNtrJRiW6nGng==} + engines: {node: '>=10'} + dependencies: + locate-path: 6.0.0 + path-exists: 4.0.0 + dev: true + + /flat-cache/3.0.4: + resolution: {integrity: sha512-dm9s5Pw7Jc0GvMYbshN6zchCA9RgQlzzEZX3vylR9IqFfS8XciblUXOKfW6SiuJ0e13eDYZoZV5wdrev7P3Nwg==} + engines: {node: ^10.12.0 || >=12.0.0} + dependencies: + flatted: 3.2.7 + rimraf: 3.0.2 + dev: true + + /flatted/3.2.7: + resolution: {integrity: sha512-5nqDSxl8nn5BSNxyR3n4I6eDmbolI6WT+QqR547RwxQapgjQBmtktdP+HTBb/a/zLsbzERTONyUB5pefh5TtjQ==} + dev: true + + /fs.realpath/1.0.0: + resolution: {integrity: sha512-OO0pH2lK6a0hZnAdau5ItzHPI6pUlvI7jMVnxUQRtw4owF2wk8lOSabtGDCTP4Ggrg2MbGnWO9X8K1t4+fGMDw==} + dev: true + + /fsevents/2.3.2: + resolution: {integrity: sha512-xiqMQR4xAeHTuB9uWm+fFRcIOgKBMiOBP+eXiyT7jsgVCq1bkVygt00oASowB7EdtpOHaaPgKt812P9ab+DDKA==} + engines: {node: ^8.16.0 || ^10.6.0 || >=11.0.0} + os: [darwin] + requiresBuild: true + dev: true + optional: true + + /glob-parent/5.1.2: + resolution: {integrity: sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow==} + engines: {node: '>= 6'} + dependencies: + is-glob: 4.0.3 + dev: true + + /glob-parent/6.0.2: + resolution: {integrity: sha512-XxwI8EOhVQgWp6iDL+3b0r86f4d6AX6zSU55HfB4ydCEuXLXc5FcYeOu+nnGftS4TEju/11rt4KJPTMgbfmv4A==} + engines: {node: '>=10.13.0'} + dependencies: + is-glob: 4.0.3 + dev: true + + /glob/7.2.3: + resolution: {integrity: sha512-nFR0zLpU2YCaRxwoCJvL6UvCH2JFyFVIvwTLsIf21AuHlMskA1hhTdk+LlYJtOlYt9v6dvszD2BGRqBL+iQK9Q==} + dependencies: + fs.realpath: 1.0.0 + inflight: 1.0.6 + inherits: 2.0.4 + minimatch: 3.1.2 + once: 1.4.0 + path-is-absolute: 1.0.1 + dev: true + + /globals/13.17.0: + resolution: {integrity: sha512-1C+6nQRb1GwGMKm2dH/E7enFAMxGTmGI7/dEdhy/DNelv85w9B72t3uc5frtMNXIbzrarJJ/lTCjcaZwbLJmyw==} + engines: {node: '>=8'} + dependencies: + type-fest: 0.20.2 + dev: true + + /grapheme-splitter/1.0.4: + resolution: {integrity: sha512-bzh50DW9kTPM00T8y4o8vQg89Di9oLJVLW/KaOGIXJWP/iqCN6WKYkbNOF04vFLJhwcpYUh9ydh/+5vpOqV4YQ==} + dev: true + + /has-flag/3.0.0: + resolution: {integrity: sha512-sKJf1+ceQBr4SMkvQnBDNDtf4TXpVhVGateu0t918bl30FnbE2m4vNLX+VWe/dpjlb+HugGYzW7uQXH98HPEYw==} + engines: {node: '>=4'} + dev: true + + /has-flag/4.0.0: + resolution: {integrity: sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==} + engines: {node: '>=8'} + dev: true + + /ignore-by-default/1.0.1: + resolution: {integrity: sha512-Ius2VYcGNk7T90CppJqcIkS5ooHUZyIQK+ClZfMfMNFEF9VSE73Fq+906u/CWu92x4gzZMWOwfFYckPObzdEbA==} + dev: true + + /ignore/5.2.0: + resolution: {integrity: sha512-CmxgYGiEPCLhfLnpPp1MoRmifwEIOgjcHXxOBjv7mY96c+eWScsOP9c112ZyLdWHi0FxHjI+4uVhKYp/gcdRmQ==} + engines: {node: '>= 4'} + dev: true + + /import-fresh/3.3.0: + resolution: {integrity: sha512-veYYhQa+D1QBKznvhUHxb8faxlrwUnxseDAbAp457E0wLNio2bOSKnjYDhMj+YiAq61xrMGhQk9iXVk5FzgQMw==} + engines: {node: '>=6'} + dependencies: + parent-module: 1.0.1 + resolve-from: 4.0.0 + dev: true + + /imurmurhash/0.1.4: + resolution: {integrity: sha512-JmXMZ6wuvDmLiHEml9ykzqO6lwFbof0GG4IkcGaENdCRDDmMVnny7s5HsIgHCbaq0w2MyPhDqkhTUgS2LU2PHA==} + engines: {node: '>=0.8.19'} + dev: true + + /inflight/1.0.6: + resolution: {integrity: sha512-k92I/b08q4wvFscXCLvqfsHCrjrF7yiXsQuIVvVE7N82W3+aqpzuUdBbfhWcy/FZR3/4IgflMgKLOsvPDrGCJA==} + dependencies: + once: 1.4.0 + wrappy: 1.0.2 + dev: true + + /inherits/2.0.4: + resolution: {integrity: sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==} + dev: true + + /is-binary-path/2.1.0: + resolution: {integrity: sha512-ZMERYes6pDydyuGidse7OsHxtbI7WVeUEozgR/g7rd0xUimYNlvZRE/K2MgZTjWy725IfelLeVcEM97mmtRGXw==} + engines: {node: '>=8'} + dependencies: + binary-extensions: 2.2.0 + dev: true + + /is-extglob/2.1.1: + resolution: {integrity: sha512-SbKbANkN603Vi4jEZv49LeVJMn4yGwsbzZworEoyEiutsN3nJYdbO36zfhGJ6QEDpOZIFkDtnq5JRxmvl3jsoQ==} + engines: {node: '>=0.10.0'} + dev: true + + /is-glob/4.0.3: + resolution: {integrity: sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg==} + engines: {node: '>=0.10.0'} + dependencies: + is-extglob: 2.1.1 + dev: true + + /is-number/7.0.0: + resolution: {integrity: sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==} + engines: {node: '>=0.12.0'} + dev: true + + /is-path-inside/3.0.3: + resolution: {integrity: sha512-Fd4gABb+ycGAmKou8eMftCupSir5lRxqf4aD/vd0cD2qc4HL07OjCeuHMr8Ro4CoMaeCKDB0/ECBOVWjTwUvPQ==} + engines: {node: '>=8'} + dev: true + + /isexe/2.0.0: + resolution: {integrity: sha512-RHxMLp9lnKHGHRng9QFhRCMbYAcVpn69smSGcq3f36xjgVVWThj4qqLbTLlq7Ssj8B+fIQ1EuCEGI2lKsyQeIw==} + dev: true + + /js-sdsl/4.1.5: + resolution: {integrity: sha512-08bOAKweV2NUC1wqTtf3qZlnpOX/R2DU9ikpjOHs0H+ibQv3zpncVQg6um4uYtRtrwIX8M4Nh3ytK4HGlYAq7Q==} + dev: true + + /js-yaml/4.1.0: + resolution: {integrity: sha512-wpxZs9NoxZaJESJGIZTyDEaYpl0FKSA+FB9aJiyemKhMwkxQg63h4T1KJgUGHpTqPDNRcmmYLugrRjJlBtWvRA==} + hasBin: true + dependencies: + argparse: 2.0.1 + dev: true + + /json-schema-to-ts/2.5.5: + resolution: {integrity: sha512-GFD5t0fUnX/B0gE9xbHjxv2BwFXRJND2+OKoLoMElJ3XRJ7dOBlLT7KXpg96aETeZ0RJbAZOfqHALBf5k4aIIA==} + dependencies: + '@types/json-schema': 7.0.11 + ts-algebra: 1.1.1 + ts-toolbelt: 9.6.0 + dev: true + + /json-schema-traverse/0.4.1: + resolution: {integrity: sha512-xbbCH5dCYU5T8LcEhhuh7HJ88HXuW3qsI3Y0zOZFKfZEHcpWiHU/Jxzk629Brsab/mMiHQti9wMP+845RPe3Vg==} + dev: true + + /json-schema-traverse/1.0.0: + resolution: {integrity: sha512-NM8/P9n3XjXhIZn1lLhkFaACTOURQXjWhV4BA/RnOv8xvgqtqpAX9IO4mRQxSx1Rlo4tqzeqb0sOlruaOy3dug==} + dev: true + + /json-stable-stringify-without-jsonify/1.0.1: + resolution: {integrity: sha512-Bdboy+l7tA3OGW6FjyFHWkP5LuByj1Tk33Ljyq0axyzdk9//JSi2u3fP1QSmd1KNwq6VOKYGlAu87CisVir6Pw==} + dev: true + + /kingworld/0.0.0-experimental.28: + resolution: {integrity: sha512-oZ4vhYdpC5igL4QfFsM6pw0ahLMkAAlg9QBvVyFEMR7c8I+6BTRJPb/MpC75hLgS8zzfjBaUFebyYdFvp9OKBw==} + dependencies: + '@medley/router': 0.2.1 + '@saltyaom/trek-router': 0.0.7 + ajv: 8.11.0 + json-schema-to-ts: 2.5.5 + dev: true + + /levn/0.4.1: + resolution: {integrity: sha512-+bT2uH4E5LGE7h/n3evcS/sQlJXCpIp6ym8OWJ5eV6+67Dsql/LaaT7qJBAt2rzfoa/5QBGBhxDix1dMt2kQKQ==} + engines: {node: '>= 0.8.0'} + dependencies: + prelude-ls: 1.2.1 + type-check: 0.4.0 + dev: true + + /locate-path/6.0.0: + resolution: {integrity: sha512-iPZK6eYjbxRu3uB4/WZ3EsEIMJFMqAoopl3R+zuq0UjcAm/MO6KCweDgPfP3elTztoKP3KtnVHxTn2NHBSDVUw==} + engines: {node: '>=10'} + dependencies: + p-locate: 5.0.0 + dev: true + + /lodash.merge/4.6.2: + resolution: {integrity: sha512-0KpjqXRVvrYyCsX1swR/XTK0va6VQkQM6MNo7PqW77ByjAhoARA8EfrP1N4+KlKj8YS0ZUCtRT/YUuhyYDujIQ==} + dev: true + + /merge2/1.4.1: + resolution: {integrity: sha512-8q7VEgMJW4J8tcfVPy8g09NcQwZdbwFEqhe/WZkoIzjn/3TGDwtOCYtXGxA3O8tPzpczCCDgv+P2P5y00ZJOOg==} + engines: {node: '>= 8'} + dev: true + + /micromatch/4.0.5: + resolution: {integrity: sha512-DMy+ERcEW2q8Z2Po+WNXuw3c5YaUSFjAO5GsJqfEl7UjvtIuFKO6ZrKvcItdy98dwFI2N1tg3zNIdKaQT+aNdA==} + engines: {node: '>=8.6'} + dependencies: + braces: 3.0.2 + picomatch: 2.3.1 + dev: true + + /minimatch/3.1.2: + resolution: {integrity: sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==} + dependencies: + brace-expansion: 1.1.11 + dev: true + + /ms/2.1.2: + resolution: {integrity: sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==} + dev: true + + /ms/2.1.3: + resolution: {integrity: sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==} + dev: true + + /natural-compare/1.4.0: + resolution: {integrity: sha512-OWND8ei3VtNC9h7V60qff3SVobHr996CTwgxubgyQYEpg290h9J0buyECNNJexkFm5sOajh5G116RYA1c8ZMSw==} + dev: true + + /nodemon/2.0.20: + resolution: {integrity: sha512-Km2mWHKKY5GzRg6i1j5OxOHQtuvVsgskLfigG25yTtbyfRGn/GNvIbRyOf1PSCKJ2aT/58TiuUsuOU5UToVViw==} + engines: {node: '>=8.10.0'} + hasBin: true + dependencies: + chokidar: 3.5.3 + debug: 3.2.7_supports-color@5.5.0 + ignore-by-default: 1.0.1 + minimatch: 3.1.2 + pstree.remy: 1.1.8 + semver: 5.7.1 + simple-update-notifier: 1.0.7 + supports-color: 5.5.0 + touch: 3.1.0 + undefsafe: 2.0.5 + dev: true + + /nopt/1.0.10: + resolution: {integrity: sha512-NWmpvLSqUrgrAC9HCuxEvb+PSloHpqVu+FqcO4eeF2h5qYRhA7ev6KvelyQAKtegUbC6RypJnlEOhd8vloNKYg==} + hasBin: true + dependencies: + abbrev: 1.1.1 + dev: true + + /normalize-path/3.0.0: + resolution: {integrity: sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA==} + engines: {node: '>=0.10.0'} + dev: true + + /object-treeify/1.1.33: + resolution: {integrity: sha512-EFVjAYfzWqWsBMRHPMAXLCDIJnpMhdWAqR7xG6M6a2cs6PMFpl/+Z20w9zDW4vkxOFfddegBKq9Rehd0bxWE7A==} + engines: {node: '>= 10'} + dev: true + + /once/1.4.0: + resolution: {integrity: sha512-lNaJgI+2Q5URQBkccEKHTQOPaXdUxnZZElQTZY0MFUAuaEqe1E+Nyvgdz/aIyNi6Z9MzO5dv1H8n58/GELp3+w==} + dependencies: + wrappy: 1.0.2 + dev: true + + /optionator/0.9.1: + resolution: {integrity: sha512-74RlY5FCnhq4jRxVUPKDaRwrVNXMqsGsiW6AJw4XK8hmtm10wC0ypZBLw5IIp85NZMr91+qd1RvvENwg7jjRFw==} + engines: {node: '>= 0.8.0'} + dependencies: + deep-is: 0.1.4 + fast-levenshtein: 2.0.6 + levn: 0.4.1 + prelude-ls: 1.2.1 + type-check: 0.4.0 + word-wrap: 1.2.3 + dev: true + + /p-limit/3.1.0: + resolution: {integrity: sha512-TYOanM3wGwNGsZN2cVTYPArw454xnXj5qmWF1bEoAc4+cU/ol7GVh7odevjp1FNHduHc3KZMcFduxU5Xc6uJRQ==} + engines: {node: '>=10'} + dependencies: + yocto-queue: 0.1.0 + dev: true + + /p-locate/5.0.0: + resolution: {integrity: sha512-LaNjtRWUBY++zB5nE/NwcaoMylSPk+S+ZHNB1TzdbMJMny6dynpAGt7X/tl/QYq3TIeE6nxHppbo2LGymrG5Pw==} + engines: {node: '>=10'} + dependencies: + p-limit: 3.1.0 + dev: true + + /parent-module/1.0.1: + resolution: {integrity: sha512-GQ2EWRpQV8/o+Aw8YqtfZZPfNRWZYkbidE9k5rpl/hC3vtHHBfGm2Ifi6qWV+coDGkrUKZAxE3Lot5kcsRlh+g==} + engines: {node: '>=6'} + dependencies: + callsites: 3.1.0 + dev: true + + /path-exists/4.0.0: + resolution: {integrity: sha512-ak9Qy5Q7jYb2Wwcey5Fpvg2KoAc/ZIhLSLOSBmRmygPsGwkVVt0fZa0qrtMz+m6tJTAHfZQ8FnmB4MG4LWy7/w==} + engines: {node: '>=8'} + dev: true + + /path-is-absolute/1.0.1: + resolution: {integrity: sha512-AVbw3UJ2e9bq64vSaS9Am0fje1Pa8pbGqTTsmXfaIiMpnr5DlDhfJOuLj9Sf95ZPVDAUerDfEk88MPmPe7UCQg==} + engines: {node: '>=0.10.0'} + dev: true + + /path-key/3.1.1: + resolution: {integrity: sha512-ojmeN0qd+y0jszEtoY48r0Peq5dwMEkIlCOu6Q5f41lfkswXuKtYrhgoTpLnyIcHm24Uhqx+5Tqm2InSwLhE6Q==} + engines: {node: '>=8'} + dev: true + + /picomatch/2.3.1: + resolution: {integrity: sha512-JU3teHTNjmE2VCGFzuY8EXzCDVwEqB2a8fsIvwaStHhAWJEeVd1o1QD80CU6+ZdEXXSLbSsuLwJjkCBWqRQUVA==} + engines: {node: '>=8.6'} + dev: true + + /prelude-ls/1.2.1: + resolution: {integrity: sha512-vkcDPrRZo1QZLbn5RLGPpg/WmIQ65qoWWhcGKf/b5eplkkarX0m9z8ppCat4mlOqUsWpyNuYgO3VRyrYHSzX5g==} + engines: {node: '>= 0.8.0'} + dev: true + + /pstree.remy/1.1.8: + resolution: {integrity: sha512-77DZwxQmxKnu3aR542U+X8FypNzbfJ+C5XQDk3uWjWxn6151aIMGthWYRXTqT1E5oJvg+ljaa2OJi+VfvCOQ8w==} + dev: true + + /punycode/2.1.1: + resolution: {integrity: sha512-XRsRjdf+j5ml+y/6GKHPZbrF/8p2Yga0JPtdqTIY2Xe5ohJPD9saDJJLPvp9+NSBprVvevdXZybnj2cv8OEd0A==} + engines: {node: '>=6'} + dev: true + + /queue-microtask/1.2.3: + resolution: {integrity: sha512-NuaNSa6flKT5JaSYQzJok04JzTL1CA6aGhv5rfLW3PgqA+M2ChpZQnAC8h8i4ZFkBS8X5RqkDBHA7r4hej3K9A==} + dev: true + + /readdirp/3.6.0: + resolution: {integrity: sha512-hOS089on8RduqdbhvQ5Z37A0ESjsqz6qnRcffsMU3495FuTdqSm+7bhJ29JvIOsBDEEnan5DPu9t3To9VRlMzA==} + engines: {node: '>=8.10.0'} + dependencies: + picomatch: 2.3.1 + dev: true + + /regexpp/3.2.0: + resolution: {integrity: sha512-pq2bWo9mVD43nbts2wGv17XLiNLya+GklZ8kaDLV2Z08gDCsGpnKn9BFMepvWuHCbyVvY7J5o5+BVvoQbmlJLg==} + engines: {node: '>=8'} + dev: true + + /require-from-string/2.0.2: + resolution: {integrity: sha512-Xf0nWe6RseziFMu+Ap9biiUbmplq6S9/p+7w7YXP/JBHhrUDDUhwa+vANyubuqfZWTveU//DYVGsDG7RKL/vEw==} + engines: {node: '>=0.10.0'} + dev: true + + /resolve-from/4.0.0: + resolution: {integrity: sha512-pb/MYmXstAkysRFx8piNI1tGFNQIFA3vkE3Gq4EuA1dF6gHp/+vgZqsCGJapvy8N3Q+4o7FwvquPJcnZ7RYy4g==} + engines: {node: '>=4'} + dev: true + + /reusify/1.0.4: + resolution: {integrity: sha512-U9nH88a3fc/ekCF1l0/UP1IosiuIjyTh7hBvXVMHYgVcfGvt897Xguj2UOLDeI5BG2m7/uwyaLVT6fbtCwTyzw==} + engines: {iojs: '>=1.0.0', node: '>=0.10.0'} + dev: true + + /rimraf/3.0.2: + resolution: {integrity: sha512-JZkJMZkAGFFPP2YqXZXPbMlMBgsxzE8ILs4lMIX/2o0L9UBw9O/Y3o6wFw/i9YLapcUJWwqbi3kdxIPdC62TIA==} + hasBin: true + dependencies: + glob: 7.2.3 + dev: true + + /run-parallel/1.2.0: + resolution: {integrity: sha512-5l4VyZR86LZ/lDxZTR6jqL8AFE2S0IFLMP26AbjsLVADxHdhB/c0GUsH+y39UfCi3dzz8OlQuPmnaJOMoDHQBA==} + dependencies: + queue-microtask: 1.2.3 + dev: true + + /semver/5.7.1: + resolution: {integrity: sha512-sauaDf/PZdVgrLTNYHRtpXa1iRiKcaebiKQ1BJdpQlWH2lCvexQdX55snPFyK7QzpudqbCI0qXFfOasHdyNDGQ==} + hasBin: true + dev: true + + /semver/7.0.0: + resolution: {integrity: sha512-+GB6zVA9LWh6zovYQLALHwv5rb2PHGlJi3lfiqIHxR0uuwCgefcOJc59v9fv1w8GbStwxuuqqAjI9NMAOOgq1A==} + hasBin: true + dev: true + + /shebang-command/2.0.0: + resolution: {integrity: sha512-kHxr2zZpYtdmrN1qDjrrX/Z1rR1kG8Dx+gkpK1G4eXmvXswmcE1hTWBWYUzlraYw1/yZp6YuDY77YtvbN0dmDA==} + engines: {node: '>=8'} + dependencies: + shebang-regex: 3.0.0 + dev: true + + /shebang-regex/3.0.0: + resolution: {integrity: sha512-7++dFhtcx3353uBaq8DDR4NuxBetBzC7ZQOhmTQInHEd6bSrXdiEyzCvG07Z44UYdLShWUyXt5M/yhz8ekcb1A==} + engines: {node: '>=8'} + dev: true + + /simple-update-notifier/1.0.7: + resolution: {integrity: sha512-BBKgR84BJQJm6WjWFMHgLVuo61FBDSj1z/xSFUIozqO6wO7ii0JxCqlIud7Enr/+LhlbNI0whErq96P2qHNWew==} + engines: {node: '>=8.10.0'} + dependencies: + semver: 7.0.0 + dev: true + + /slash/3.0.0: + resolution: {integrity: sha512-g9Q1haeby36OSStwb4ntCGGGaKsaVSjQ68fBxoQcutl5fS1vuY18H3wSt3jFyFtrkx+Kz0V1G85A4MyAdDMi2Q==} + engines: {node: '>=8'} + dev: true + + /source-map/0.7.4: + resolution: {integrity: sha512-l3BikUxvPOcn5E74dZiq5BGsTb5yEwhaTSzccU6t4sDOH8NWJCstKO5QT2CvtFoK6F0saL7p9xHAqHOlCPJygA==} + engines: {node: '>= 8'} + dev: true + + /strip-ansi/6.0.1: + resolution: {integrity: sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==} + engines: {node: '>=8'} + dependencies: + ansi-regex: 5.0.1 + dev: true + + /strip-json-comments/3.1.1: + resolution: {integrity: sha512-6fPc+R4ihwqP6N/aIv2f1gMH8lOVtWQHoqC4yK6oSDVVocumAsfCqjkXnqiYMhmMwS/mEHLp7Vehlt3ql6lEig==} + engines: {node: '>=8'} + dev: true + + /supports-color/5.5.0: + resolution: {integrity: sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==} + engines: {node: '>=4'} + dependencies: + has-flag: 3.0.0 + dev: true + + /supports-color/7.2.0: + resolution: {integrity: sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==} + engines: {node: '>=8'} + dependencies: + has-flag: 4.0.0 + dev: true + + /text-table/0.2.0: + resolution: {integrity: sha512-N+8UisAXDGk8PFXP4HAzVR9nbfmVJ3zYLAWiTIoqC5v5isinhr+r5uaO8+7r3BMfuNIufIsA7RdpVgacC2cSpw==} + dev: true + + /to-regex-range/5.0.1: + resolution: {integrity: sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==} + engines: {node: '>=8.0'} + dependencies: + is-number: 7.0.0 + dev: true + + /touch/3.1.0: + resolution: {integrity: sha512-WBx8Uy5TLtOSRtIq+M03/sKDrXCLHxwDcquSP2c43Le03/9serjQBIztjRz6FkJez9D/hleyAXTBGLwwZUw9lA==} + hasBin: true + dependencies: + nopt: 1.0.10 + dev: true + + /ts-algebra/1.1.1: + resolution: {integrity: sha512-W43a3/BN0Tp4SgRNERQF/QPVuY1rnHkgCr/fISLY0Ycu05P0NWPYRuViU8JFn+pFZuY6/zp9TgET1fxMzppR/Q==} + dependencies: + ts-toolbelt: 9.6.0 + dev: true + + /ts-toolbelt/9.6.0: + resolution: {integrity: sha512-nsZd8ZeNUzukXPlJmTBwUAuABDe/9qtVDelJeT/qW0ow3ZS3BsQJtNkan1802aM9Uf68/Y8ljw86Hu0h5IUW3w==} + dev: true + + /type-check/0.4.0: + resolution: {integrity: sha512-XleUoc9uwGXqjWwXaUTZAmzMcFZ5858QA2vvx1Ur5xIcixXIP+8LnFDgRplU30us6teqdlskFfu+ae4K79Ooew==} + engines: {node: '>= 0.8.0'} + dependencies: + prelude-ls: 1.2.1 + dev: true + + /type-fest/0.20.2: + resolution: {integrity: sha512-Ne+eE4r0/iWnpAxD852z3A+N0Bt5RN//NjJwRd2VFHEmrywxf5vsZlh4R6lixl6B+wz/8d+maTSAkN1FIkI3LQ==} + engines: {node: '>=10'} + dev: true + + /typescript/4.8.4: + resolution: {integrity: sha512-QCh+85mCy+h0IGff8r5XWzOVSbBO+KfeYrMQh7NJ58QujwcE22u+NUSmUxqF+un70P9GXKxa2HCNiTTMJknyjQ==} + engines: {node: '>=4.2.0'} + hasBin: true + dev: true + + /undefsafe/2.0.5: + resolution: {integrity: sha512-WxONCrssBM8TSPRqN5EmsjVrsv4A8X12J4ArBiiayv3DyyG3ZlIg6yysuuSYdZsVz3TKcTg2fd//Ujd4CHV1iA==} + dev: true + + /uri-js/4.4.1: + resolution: {integrity: sha512-7rKUyy33Q1yc98pQ1DAmLtwX109F7TIfWlW1Ydo8Wl1ii1SeHieeh0HHfPeL2fMXK6z0s8ecKs9frCuLJvndBg==} + dependencies: + punycode: 2.1.1 + dev: true + + /which/2.0.2: + resolution: {integrity: sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA==} + engines: {node: '>= 8'} + hasBin: true + dependencies: + isexe: 2.0.0 + dev: true + + /word-wrap/1.2.3: + resolution: {integrity: sha512-Hz/mrNwitNRh/HUAtM/VT/5VH+ygD6DV7mYKZAtHOrbs8U7lvPS6xf7EJKMF0uW1KJCl0H701g3ZGus+muE5vQ==} + engines: {node: '>=0.10.0'} + dev: true + + /wrappy/1.0.2: + resolution: {integrity: sha512-l4Sp/DRseor9wL6EvV2+TuQn63dMkPjZ/sp9XkghTEbV9KlPS1xUsZ3u7/IQO4wxtcFB4bgpQPRcR3QCvezPcQ==} + dev: true + + /yocto-queue/0.1.0: + resolution: {integrity: sha512-rVksvsnNCdJ/ohGc6xgPwyN8eheCxsiLM8mxuE/t/mOVqJewPuO1miLpTHQiRgTKCLexL4MeAFVagts7HmNZ2Q==} + engines: {node: '>=10'} + dev: true diff --git a/src/index.ts b/src/index.ts new file mode 100644 index 0000000..760e8e9 --- /dev/null +++ b/src/index.ts @@ -0,0 +1,160 @@ +import { type KingWorld, SCHEMA } from 'kingworld' +import { getAbsoluteFSPath } from 'swagger-ui-dist' + +import staticPlugin from '@kingworldjs/static' + +import type { OpenAPIV2 } from 'openapi-types' + +const defaultConfig: Partial = { + swagger: '2.0', + schemes: ['http', 'https'], + consumes: ['application/json', 'text/plain'], + produces: ['application/json', 'text/plain'] +} + +const filterPaths = ( + paths: Record, + { + excludeStaticFile = true, + exclude = [] + }: { + excludeStaticFile: boolean + exclude: (string | RegExp)[] + } +) => { + const newPaths: Record = {} + + for (const [key, value] of Object.entries(paths)) + if ( + !exclude.some((x) => { + if (typeof x === 'string') return key === x + + return x.test(key) + }) && + !key.includes('/swagger') && + !key.includes('*') && + (excludeStaticFile ? !key.includes('.') : true) + ) { + Object.keys(value).forEach((method) => { + const schema = value[method] + + if (key.includes('{') && !schema.parameters) + schema.parameters = key + .split('/') + .filter((x) => x.startsWith('{')) + .map((x) => ({ + in: 'path', + name: x.slice(1, x.length - 1), + type: 'string', + required: true + })) + + if (!schema.responses) + schema.responses = { + 200: {} + } + }) + + newPaths[key] = value + } + + return newPaths +} + +/** + * A plugin for [kingworld](https://github.com/saltyaom/kingworld) that auto-generate Swagger page. + * + * @see https://github.com/saltyaom/kingworld-swagger + */ +export const swagger = ( + app: KingWorld, + { + swagger = {}, + excludeStaticFile = true, + path = '/swagger', + exclude = [] + }: { + /** + * Customize Swagger config, refers to Swagger 2.0 config + * + * @see https://swagger.io/specification/v2/ + */ + swagger?: Partial + /** + * Determine if Swagger should exclude static files. + * + * @default true + */ + excludeStaticFile?: boolean + /** + * The endpoint to expose Swagger + * + * @default '/swagger' + */ + path?: string + /** + * Paths to exclude from Swagger endpoint + * + * @default [] + */ + exclude?: string | RegExp | (string | RegExp)[] + } = { + swagger: {}, + excludeStaticFile: true, + path: '/swagger', + exclude: [] + } +) => + app + .get(path, (context) => { + context.set.redirect = `${path}/static/index.html` + }) + .get( + `${path}/static/swagger-initializer.js`, + ({ store }) => + new Response( + `window.onload = function() { + window.ui = SwaggerUIBundle({ + url: "${path}/json", + dom_id: '#swagger-ui', + deepLinking: true, + presets: [ + SwaggerUIBundle.presets.apis, + SwaggerUIStandalonePreset + ], + plugins: [ + SwaggerUIBundle.plugins.DownloadUrl + ], + layout: "StandaloneLayout" + }); +};`, + { + headers: { + 'content-type': 'text/javascript;charset=utf-8' + } + } + ) + ) + .get(`${path}/json`, (context) => ({ + ...{ + ...defaultConfig, + ...swagger, + info: { + title: 'KingWorld Documentation', + description: 'Developement documentation', + version: '0.0.0', + ...swagger.info + } + }, + // @ts-ignore + paths: filterPaths(context.store[SCHEMA], { + excludeStaticFile, + exclude: Array.isArray(exclude) ? exclude : [exclude] + }) + })) + .use(staticPlugin, { + prefix: `${path}/static`, + path: getAbsoluteFSPath() + }) + +export default swagger diff --git a/test/index.test.ts b/test/index.test.ts new file mode 100644 index 0000000..ca10729 --- /dev/null +++ b/test/index.test.ts @@ -0,0 +1,25 @@ +import KingWorld from 'kingworld' + +import swagger from '../src' + +import { describe, expect, it } from 'bun:test' + +const req = (path: string) => new Request(path) + +describe('Swagger', () => { + it('redirect to Swagger page', async () => { + const app = new KingWorld().use(swagger) + + const res = await app.handle(req('/swagger')) + expect(res.status).toBe(302) + }) + + it('use custom path', async () => { + const app = new KingWorld().use(swagger, { + path: '/v2/swagger' + }) + + const res = await app.handle(req('/v2/swagger')) + expect(res.status).toBe(302) + }) +}) diff --git a/tsconfig.json b/tsconfig.json new file mode 100644 index 0000000..813dbe7 --- /dev/null +++ b/tsconfig.json @@ -0,0 +1,103 @@ +{ + "compilerOptions": { + /* Visit https://aka.ms/tsconfig to read more about this file */ + + /* Projects */ + // "incremental": true, /* Save .tsbuildinfo files to allow for incremental compilation of projects. */ + // "composite": true, /* Enable constraints that allow a TypeScript project to be used with project references. */ + // "tsBuildInfoFile": "./.tsbuildinfo", /* Specify the path to .tsbuildinfo incremental compilation file. */ + // "disableSourceOfProjectReferenceRedirect": true, /* Disable preferring source files instead of declaration files when referencing composite projects. */ + // "disableSolutionSearching": true, /* Opt a project out of multi-project reference checking when editing. */ + // "disableReferencedProjectLoad": true, /* Reduce the number of projects loaded automatically by TypeScript. */ + + /* Language and Environment */ + "target": "es2016", /* Set the JavaScript language version for emitted JavaScript and include compatible library declarations. */ + // "lib": [], /* Specify a set of bundled library declaration files that describe the target runtime environment. */ + // "jsx": "preserve", /* Specify what JSX code is generated. */ + // "experimentalDecorators": true, /* Enable experimental support for TC39 stage 2 draft decorators. */ + // "emitDecoratorMetadata": true, /* Emit design-type metadata for decorated declarations in source files. */ + // "jsxFactory": "", /* Specify the JSX factory function used when targeting React JSX emit, e.g. 'React.createElement' or 'h'. */ + // "jsxFragmentFactory": "", /* Specify the JSX Fragment reference used for fragments when targeting React JSX emit e.g. 'React.Fragment' or 'Fragment'. */ + // "jsxImportSource": "", /* Specify module specifier used to import the JSX factory functions when using 'jsx: react-jsx*'. */ + // "reactNamespace": "", /* Specify the object invoked for 'createElement'. This only applies when targeting 'react' JSX emit. */ + // "noLib": true, /* Disable including any library files, including the default lib.d.ts. */ + // "useDefineForClassFields": true, /* Emit ECMAScript-standard-compliant class fields. */ + // "moduleDetection": "auto", /* Control what method is used to detect module-format JS files. */ + + /* Modules */ + "module": "commonjs", /* Specify what module code is generated. */ + // "rootDir": "./", /* Specify the root folder within your source files. */ + // "moduleResolution": "node", /* Specify how TypeScript looks up a file from a given module specifier. */ + // "baseUrl": "./", /* Specify the base directory to resolve non-relative module names. */ + // "paths": {}, /* Specify a set of entries that re-map imports to additional lookup locations. */ + // "rootDirs": [], /* Allow multiple folders to be treated as one when resolving modules. */ + // "typeRoots": [], /* Specify multiple folders that act like './node_modules/@types'. */ + "types": ["bun-types"], /* Specify type package names to be included without being referenced in a source file. */ + // "allowUmdGlobalAccess": true, /* Allow accessing UMD globals from modules. */ + // "moduleSuffixes": [], /* List of file name suffixes to search when resolving a module. */ + // "resolveJsonModule": true, /* Enable importing .json files. */ + // "noResolve": true, /* Disallow 'import's, 'require's or ''s from expanding the number of files TypeScript should add to a project. */ + + /* JavaScript Support */ + // "allowJs": true, /* Allow JavaScript files to be a part of your program. Use the 'checkJS' option to get errors from these files. */ + // "checkJs": true, /* Enable error reporting in type-checked JavaScript files. */ + // "maxNodeModuleJsDepth": 1, /* Specify the maximum folder depth used for checking JavaScript files from 'node_modules'. Only applicable with 'allowJs'. */ + + /* Emit */ + // "declaration": true, /* Generate .d.ts files from TypeScript and JavaScript files in your project. */ + // "declarationMap": true, /* Create sourcemaps for d.ts files. */ + // "emitDeclarationOnly": true, /* Only output d.ts files and not JavaScript files. */ + // "sourceMap": true, /* Create source map files for emitted JavaScript files. */ + // "outFile": "./", /* Specify a file that bundles all outputs into one JavaScript file. If 'declaration' is true, also designates a file that bundles all .d.ts output. */ + // "outDir": "./", /* Specify an output folder for all emitted files. */ + // "removeComments": true, /* Disable emitting comments. */ + // "noEmit": true, /* Disable emitting files from a compilation. */ + // "importHelpers": true, /* Allow importing helper functions from tslib once per project, instead of including them per-file. */ + // "importsNotUsedAsValues": "remove", /* Specify emit/checking behavior for imports that are only used for types. */ + // "downlevelIteration": true, /* Emit more compliant, but verbose and less performant JavaScript for iteration. */ + // "sourceRoot": "", /* Specify the root path for debuggers to find the reference source code. */ + // "mapRoot": "", /* Specify the location where debugger should locate map files instead of generated locations. */ + // "inlineSourceMap": true, /* Include sourcemap files inside the emitted JavaScript. */ + // "inlineSources": true, /* Include source code in the sourcemaps inside the emitted JavaScript. */ + // "emitBOM": true, /* Emit a UTF-8 Byte Order Mark (BOM) in the beginning of output files. */ + // "newLine": "crlf", /* Set the newline character for emitting files. */ + // "stripInternal": true, /* Disable emitting declarations that have '@internal' in their JSDoc comments. */ + // "noEmitHelpers": true, /* Disable generating custom helper functions like '__extends' in compiled output. */ + // "noEmitOnError": true, /* Disable emitting files if any type checking errors are reported. */ + // "preserveConstEnums": true, /* Disable erasing 'const enum' declarations in generated code. */ + // "declarationDir": "./", /* Specify the output directory for generated declaration files. */ + // "preserveValueImports": true, /* Preserve unused imported values in the JavaScript output that would otherwise be removed. */ + + /* Interop Constraints */ + // "isolatedModules": true, /* Ensure that each file can be safely transpiled without relying on other imports. */ + // "allowSyntheticDefaultImports": true, /* Allow 'import x from y' when a module doesn't have a default export. */ + "esModuleInterop": true, /* Emit additional JavaScript to ease support for importing CommonJS modules. This enables 'allowSyntheticDefaultImports' for type compatibility. */ + // "preserveSymlinks": true, /* Disable resolving symlinks to their realpath. This correlates to the same flag in node. */ + "forceConsistentCasingInFileNames": true, /* Ensure that casing is correct in imports. */ + + /* Type Checking */ + "strict": true, /* Enable all strict type-checking options. */ + // "noImplicitAny": true, /* Enable error reporting for expressions and declarations with an implied 'any' type. */ + // "strictNullChecks": true, /* When type checking, take into account 'null' and 'undefined'. */ + // "strictFunctionTypes": true, /* When assigning functions, check to ensure parameters and the return values are subtype-compatible. */ + // "strictBindCallApply": true, /* Check that the arguments for 'bind', 'call', and 'apply' methods match the original function. */ + // "strictPropertyInitialization": true, /* Check for class properties that are declared but not set in the constructor. */ + // "noImplicitThis": true, /* Enable error reporting when 'this' is given the type 'any'. */ + // "useUnknownInCatchVariables": true, /* Default catch clause variables as 'unknown' instead of 'any'. */ + // "alwaysStrict": true, /* Ensure 'use strict' is always emitted. */ + // "noUnusedLocals": true, /* Enable error reporting when local variables aren't read. */ + // "noUnusedParameters": true, /* Raise an error when a function parameter isn't read. */ + // "exactOptionalPropertyTypes": true, /* Interpret optional property types as written, rather than adding 'undefined'. */ + // "noImplicitReturns": true, /* Enable error reporting for codepaths that do not explicitly return in a function. */ + // "noFallthroughCasesInSwitch": true, /* Enable error reporting for fallthrough cases in switch statements. */ + // "noUncheckedIndexedAccess": true, /* Add 'undefined' to a type when accessed using an index. */ + // "noImplicitOverride": true, /* Ensure overriding members in derived classes are marked with an override modifier. */ + // "noPropertyAccessFromIndexSignature": true, /* Enforces using indexed accessors for keys declared using an indexed type. */ + // "allowUnusedLabels": true, /* Disable error reporting for unused labels. */ + // "allowUnreachableCode": true, /* Disable error reporting for unreachable code. */ + + /* Completeness */ + // "skipDefaultLibCheck": true, /* Skip type checking .d.ts files that are included with TypeScript. */ + "skipLibCheck": true /* Skip type checking all .d.ts files. */ + } +}