From bfd9cbbf7beb87ece06e8a23b32ce2bac1e9c085 Mon Sep 17 00:00:00 2001 From: Dlovely <591562538@qq.com> Date: Sat, 26 Oct 2024 23:23:01 +0800 Subject: [PATCH 1/9] =?UTF-8?q?feat:=20=E6=96=B0=E5=A2=9Enest=E6=A8=A1?= =?UTF-8?q?=E6=9D=BF=E3=80=81=E6=96=B0=E5=A2=9Eserver=E7=B1=BB=E5=9E=8B?= =?UTF-8?q?=E7=9A=84vite=E9=85=8D=E7=BD=AE?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- apps/backend-nest/.env | 15 + apps/backend-nest/.env.analyze | 1 + apps/backend-nest/.env.development | 2 + apps/backend-nest/.env.production | 2 + apps/backend-nest/.vscode/settings.json | 7 + apps/backend-nest/package.json | 27 + apps/backend-nest/src/app/index.module.ts | 5 + apps/backend-nest/src/app/index.ts | 29 + apps/backend-nest/src/index.ts | 5 + apps/backend-nest/tsconfig.build.json | 4 + apps/backend-nest/tsconfig.json | 12 + apps/backend-nest/vite.config.mts | 8 + cspell.json | 53 +- internal/vite-config/package.json | 3 +- .../vite-config/src/config/application.ts | 4 +- internal/vite-config/src/config/index.ts | 6 +- internal/vite-config/src/config/server.ts | 63 + internal/vite-config/src/index.ts | 2 +- internal/vite-config/src/plugins/index.ts | 52 +- internal/vite-config/src/typing.ts | 30 +- internal/vite-config/src/utils/env.ts | 34 +- package.json | 2 + pnpm-lock.yaml | 1433 ++++++++++++++++- pnpm-workspace.yaml | 91 +- scripts/vsh/src/check-dep/index.ts | 1 + vben-admin.code-workspace | 4 + 26 files changed, 1770 insertions(+), 125 deletions(-) create mode 100644 apps/backend-nest/.env create mode 100644 apps/backend-nest/.env.analyze create mode 100644 apps/backend-nest/.env.development create mode 100644 apps/backend-nest/.env.production create mode 100644 apps/backend-nest/.vscode/settings.json create mode 100644 apps/backend-nest/package.json create mode 100644 apps/backend-nest/src/app/index.module.ts create mode 100644 apps/backend-nest/src/app/index.ts create mode 100644 apps/backend-nest/src/index.ts create mode 100644 apps/backend-nest/tsconfig.build.json create mode 100644 apps/backend-nest/tsconfig.json create mode 100644 apps/backend-nest/vite.config.mts create mode 100644 internal/vite-config/src/config/server.ts diff --git a/apps/backend-nest/.env b/apps/backend-nest/.env new file mode 100644 index 00000000000..4d805fc5937 --- /dev/null +++ b/apps/backend-nest/.env @@ -0,0 +1,15 @@ +# 适配器 +VITE_ADAPTER=nest + +# 应用名称 +VITE_APP_NAME=Vben Server + +# 应用入口 +VITE_APP_PATH=src + +# 应用入口的导出变量 +VITE_EXPORT_NAME=default + +# 立即启动 +VITE_IMMEDIATE=true + diff --git a/apps/backend-nest/.env.analyze b/apps/backend-nest/.env.analyze new file mode 100644 index 00000000000..bce905f2693 --- /dev/null +++ b/apps/backend-nest/.env.analyze @@ -0,0 +1 @@ +VITE_VISUALIZER=true diff --git a/apps/backend-nest/.env.development b/apps/backend-nest/.env.development new file mode 100644 index 00000000000..d3ee1095d0f --- /dev/null +++ b/apps/backend-nest/.env.development @@ -0,0 +1,2 @@ +# 端口号 +VITE_PORT=5777 diff --git a/apps/backend-nest/.env.production b/apps/backend-nest/.env.production new file mode 100644 index 00000000000..21cc3e759f3 --- /dev/null +++ b/apps/backend-nest/.env.production @@ -0,0 +1,2 @@ +# 端口号 +VITE_PORT=3000 diff --git a/apps/backend-nest/.vscode/settings.json b/apps/backend-nest/.vscode/settings.json new file mode 100644 index 00000000000..a74719c6b62 --- /dev/null +++ b/apps/backend-nest/.vscode/settings.json @@ -0,0 +1,7 @@ +{ + "explorer.fileNesting.patterns": { + "*.ts": "${capture}.module.ts,${capture}.service.ts,${capture}.dto.ts,${capture}.controller.ts", + "*.module.ts": "${capture}.module.ts,${capture}.service.ts,${capture}.dto.ts", + "*.service.ts": "${capture}.dto.ts" + } +} diff --git a/apps/backend-nest/package.json b/apps/backend-nest/package.json new file mode 100644 index 00000000000..5e137807eaf --- /dev/null +++ b/apps/backend-nest/package.json @@ -0,0 +1,27 @@ +{ + "name": "@vben/backend-nest", + "version": "0.0.1", + "description": "", + "private": true, + "license": "MIT", + "author": "", + "scripts": { + "build": "pnpm vite build --mode production", + "build:analyze": "pnpm vite build --mode analyze", + "dev": "pnpm vite --mode development", + "preview": "vite preview", + "typecheck": "vue-tsc --noEmit --skipLibCheck" + }, + "dependencies": { + "@nestjs/common": "^10.0.0", + "@nestjs/core": "^10.0.0", + "@nestjs/platform-express": "^10.0.0", + "reflect-metadata": "^0.2.0", + "rxjs": "^7.8.1" + }, + "devDependencies": { + "@nestjs/cli": "^10.0.0", + "@types/express": "^4.17.17", + "@types/node": "catalog:" + } +} diff --git a/apps/backend-nest/src/app/index.module.ts b/apps/backend-nest/src/app/index.module.ts new file mode 100644 index 00000000000..c972661300f --- /dev/null +++ b/apps/backend-nest/src/app/index.module.ts @@ -0,0 +1,5 @@ +import { Module } from '@nestjs/common'; + +@Module({}) +// eslint-disable-next-line @typescript-eslint/no-extraneous-class +export class AppModule {} diff --git a/apps/backend-nest/src/app/index.ts b/apps/backend-nest/src/app/index.ts new file mode 100644 index 00000000000..e4c58a329e8 --- /dev/null +++ b/apps/backend-nest/src/app/index.ts @@ -0,0 +1,29 @@ +import type { INestApplication } from '@nestjs/common'; + +import { NestFactory } from '@nestjs/core'; + +import { AppModule } from './index.module'; + +let app: INestApplication; + +async function createApp() { + const app = await NestFactory.create(AppModule); + + app.enableCors(); + + return app; +} + +export async function useApp() { + if (!app) { + app = await createApp(); + } + + return app; +} + +export async function bootstrap() { + const app = await useApp(); + + await app.listen(import.meta.env.VITE_PORT); +} diff --git a/apps/backend-nest/src/index.ts b/apps/backend-nest/src/index.ts new file mode 100644 index 00000000000..250145f7066 --- /dev/null +++ b/apps/backend-nest/src/index.ts @@ -0,0 +1,5 @@ +import { bootstrap, useApp } from './app'; + +if (import.meta.env.PROD) bootstrap(); + +export default useApp(); diff --git a/apps/backend-nest/tsconfig.build.json b/apps/backend-nest/tsconfig.build.json new file mode 100644 index 00000000000..64f86c6bd2b --- /dev/null +++ b/apps/backend-nest/tsconfig.build.json @@ -0,0 +1,4 @@ +{ + "extends": "./tsconfig.json", + "exclude": ["node_modules", "test", "dist", "**/*spec.ts"] +} diff --git a/apps/backend-nest/tsconfig.json b/apps/backend-nest/tsconfig.json new file mode 100644 index 00000000000..909ce0b8f2d --- /dev/null +++ b/apps/backend-nest/tsconfig.json @@ -0,0 +1,12 @@ +{ + "$schema": "https://json.schemastore.org/tsconfig", + "extends": "@vben/tsconfig/node.json", + "compilerOptions": { + "baseUrl": ".", + "paths": { + "#/*": ["./src/*"] + }, + "types": ["vite/client"] + }, + "include": ["src/**/*.ts"] +} diff --git a/apps/backend-nest/vite.config.mts b/apps/backend-nest/vite.config.mts new file mode 100644 index 00000000000..e8c9ac73edb --- /dev/null +++ b/apps/backend-nest/vite.config.mts @@ -0,0 +1,8 @@ +import { defineConfig } from '@vben/vite-config'; + +export default defineConfig(async () => { + return { + server: {}, + vite: {}, + }; +}, 'server'); diff --git a/cspell.json b/cspell.json index b4cbb962243..a6ca16013bb 100644 --- a/cspell.json +++ b/cspell.json @@ -4,53 +4,54 @@ "language": "en,en-US", "allowCompoundWords": true, "words": [ - "clsx", - "esno", - "demi", - "unref", - "taze", "acmr", "antd", - "lucide", + "antdv", + "astro", "brotli", + "clsx", "defu", + "demi", + "echarts", + "ependencies", + "esno", + "etag", "execa", "iconify", + "iconoir", "intlify", + "lockb", + "lucide", "mkdist", "mockjs", - "vitejs", + "naiveui", + "nestjs", + "nocheck", "noopener", "noreferrer", "nprogress", + "nuxt", "pinia", + "prefixs", "publint", "qrcode", "shadcn", "sonner", + "sortablejs", + "styl", + "taze", + "ui-kit", + "uicons", "unplugin", + "unref", "vben", "vbenjs", - "vueuse", - "yxxx", - "nuxt", - "lockb", - "astro", - "ui-kit", - "styl", - "vnode", - "nocheck", - "prefixs", - "vitepress", - "antdv", - "ependencies", "vite", - "echarts", - "sortablejs", - "etag", - "naiveui", - "uicons", - "iconoir" + "vitejs", + "vitepress", + "vnode", + "vueuse", + "yxxx" ], "ignorePaths": [ "**/node_modules/**", diff --git a/internal/vite-config/package.json b/internal/vite-config/package.json index 5636d3767c2..72036366802 100644 --- a/internal/vite-config/package.json +++ b/internal/vite-config/package.json @@ -55,6 +55,7 @@ "vite-plugin-compression": "catalog:", "vite-plugin-dts": "catalog:", "vite-plugin-html": "catalog:", - "vite-plugin-lazy-import": "catalog:" + "vite-plugin-lazy-import": "catalog:", + "vite-plugin-node": "catalog:" } } diff --git a/internal/vite-config/src/config/application.ts b/internal/vite-config/src/config/application.ts index 2070192734f..ea20e85433c 100644 --- a/internal/vite-config/src/config/application.ts +++ b/internal/vite-config/src/config/application.ts @@ -10,13 +10,13 @@ import { defineConfig, loadEnv, mergeConfig } from 'vite'; import { defaultImportmapOptions, getDefaultPwaOptions } from '../options'; import { loadApplicationPlugins } from '../plugins'; -import { loadAndConvertEnv } from '../utils/env'; +import { loadApplicationEnv } from '../utils/env'; import { getCommonConfig } from './common'; function defineApplicationConfig(userConfigPromise?: DefineApplicationOptions) { return defineConfig(async (config) => { const options = await userConfigPromise?.(config); - const { appTitle, base, port, ...envConfig } = await loadAndConvertEnv(); + const { appTitle, base, port, ...envConfig } = await loadApplicationEnv(); const { command, mode } = config; const { application = {}, vite = {} } = options || {}; const root = process.cwd(); diff --git a/internal/vite-config/src/config/index.ts b/internal/vite-config/src/config/index.ts index d04a84a869c..30068c0a290 100644 --- a/internal/vite-config/src/config/index.ts +++ b/internal/vite-config/src/config/index.ts @@ -5,13 +5,14 @@ import { join } from 'node:path'; import { defineApplicationConfig } from './application'; import { defineLibraryConfig } from './library'; +import { defineServerConfig } from './server'; export * from './application'; export * from './library'; function defineConfig( userConfigPromise?: DefineConfig, - type: 'application' | 'auto' | 'library' = 'auto', + type: 'application' | 'auto' | 'library' | 'server' = 'auto', ) { let projectType = type; @@ -28,6 +29,9 @@ function defineConfig( case 'library': { return defineLibraryConfig(userConfigPromise); } + case 'server': { + return defineServerConfig(userConfigPromise); + } default: { throw new Error(`Unsupported project type: ${projectType}`); } diff --git a/internal/vite-config/src/config/server.ts b/internal/vite-config/src/config/server.ts new file mode 100644 index 00000000000..69e639d7b7d --- /dev/null +++ b/internal/vite-config/src/config/server.ts @@ -0,0 +1,63 @@ +import type { UserConfig } from 'vite'; + +import type { DefineServerOptions } from '../typing'; + +import { defineConfig, loadEnv, mergeConfig } from 'vite'; + +import { loadServerPlugins } from '../plugins'; +import { loadServerEnv } from '../utils/env'; +import { getCommonConfig } from './common'; + +function defineServerConfig(userConfigPromise?: DefineServerOptions) { + return defineConfig(async (config) => { + const options = await userConfigPromise?.(config); + const { port, ...envConfig } = await loadServerEnv(); + const { command, mode } = config; + const { server = {}, vite = {} } = options || {}; + const root = process.cwd(); + const isBuild = command === 'build'; + const env = loadEnv(mode, root); + + const plugins = await loadServerPlugins({ + env, + injectMetadata: true, + isBuild, + mode, + noElement: true, + ...envConfig, + ...server, + }); + + const serverConfig: UserConfig = { + esbuild: { + drop: isBuild + ? [ + // 'console', + 'debugger', + ] + : [], + legalComments: 'none', + }, + optimizeDeps: { + exclude: [ + '@nestjs/microservices', + '@nestjs/websockets', + 'cache-manager', + 'class-transformer', + 'class-validator', + 'fastify-swagger', + ], + }, + plugins, + server: { host: true, port }, + }; + + const mergedCommonConfig = mergeConfig( + await getCommonConfig(), + serverConfig, + ); + return mergeConfig(mergedCommonConfig, vite); + }); +} + +export { defineServerConfig }; diff --git a/internal/vite-config/src/index.ts b/internal/vite-config/src/index.ts index 352a3235af9..d78c5211aef 100644 --- a/internal/vite-config/src/index.ts +++ b/internal/vite-config/src/index.ts @@ -1,4 +1,4 @@ export * from './config'; export * from './options'; export * from './plugins'; -export { loadAndConvertEnv } from './utils/env'; +export { loadApplicationEnv as loadAndConvertEnv } from './utils/env'; diff --git a/internal/vite-config/src/plugins/index.ts b/internal/vite-config/src/plugins/index.ts index 1a8e7c263ee..29b7530d359 100644 --- a/internal/vite-config/src/plugins/index.ts +++ b/internal/vite-config/src/plugins/index.ts @@ -5,6 +5,7 @@ import type { CommonPluginOptions, ConditionPlugin, LibraryPluginOptions, + ServerPluginOptions, } from '../typing'; import viteVueI18nPlugin from '@intlify/unplugin-vue-i18n/vite'; @@ -15,6 +16,7 @@ import viteCompressPlugin from 'vite-plugin-compression'; import viteDtsPlugin from 'vite-plugin-dts'; import { createHtmlPlugin as viteHtmlPlugin } from 'vite-plugin-html'; import { libInjectCss as viteLibInjectCss } from 'vite-plugin-lib-inject-css'; +import { VitePluginNode as vitePluginNode } from 'vite-plugin-node'; import { VitePWA } from 'vite-plugin-pwa'; import viteVueDevTools from 'vite-plugin-vue-devtools'; @@ -49,10 +51,10 @@ async function loadConditionPlugins(conditionPlugins: ConditionPlugin[]) { async function loadCommonPlugins( options: CommonPluginOptions, ): Promise { - const { devtools, injectMetadata, isBuild, visualizer } = options; + const { devtools, injectMetadata, isBuild, noElement, visualizer } = options; return [ { - condition: true, + condition: !noElement, plugins: () => [ viteVue({ script: { @@ -65,7 +67,7 @@ async function loadCommonPlugins( }, { - condition: !isBuild && devtools, + condition: !noElement && !isBuild && devtools, plugins: () => [viteVueDevTools()], }, { @@ -240,9 +242,53 @@ async function loadLibraryPlugins( ]); } +/** + * 根据条件获取服务类型的vite插件 + */ +async function loadServerPlugins( + options: ServerPluginOptions, +): Promise { + // 单独取,否则commonOptions拿不到 + const isBuild = options.isBuild; + const { appName, dts, exportName, immediate, ...commonOptions } = options; + const { adapter, appPath } = options as Required; + const commonPlugins = await loadCommonPlugins(commonOptions); + return await loadConditionPlugins([ + ...commonPlugins, + { + condition: isBuild && !!dts, + plugins: () => [viteDtsPlugin({ logLevel: 'error' })], + }, + { + condition: true, + plugins: () => [ + vitePluginNode({ + adapter, + appName, + appPath, + exportName, + initAppOnBoot: immediate, + outputFormat: 'esm', + }), + ], + }, + { + condition: !isBuild, + plugins: () => [ + { + config: () => ({ server: { hmr: true } }), + handleHotUpdate: ({ server }) => server.restart(), + name: 'auto-restart-server', + }, + ], + }, + ]); +} + export { loadApplicationPlugins, loadLibraryPlugins, + loadServerPlugins, viteArchiverPlugin, viteCompressPlugin, viteDtsPlugin, diff --git a/internal/vite-config/src/typing.ts b/internal/vite-config/src/typing.ts index 907a723e48b..6827bf9fb56 100644 --- a/internal/vite-config/src/typing.ts +++ b/internal/vite-config/src/typing.ts @@ -1,6 +1,7 @@ import type { PluginVisualizerOptions } from 'rollup-plugin-visualizer'; import type { ConfigEnv, PluginOption, UserConfig } from 'vite'; import type { PluginOptions } from 'vite-plugin-dts'; +import type { RequestAdapterOption } from 'vite-plugin-node'; import type { Options as PwaPluginOptions } from 'vite-plugin-pwa'; interface IImportMap { @@ -82,6 +83,8 @@ interface CommonPluginOptions { isBuild?: boolean; /** 构建模式 */ mode?: string; + /** 是否没有前端元素 */ + noElement?: boolean; /** 开启依赖分析 */ visualizer?: boolean | PluginVisualizerOptions; } @@ -135,6 +138,21 @@ interface LibraryPluginOptions extends CommonPluginOptions { injectLibCss?: boolean; } +interface ServerPluginOptions extends CommonPluginOptions { + /** 适配器 */ + adapter?: RequestAdapterOption; + /** 应用名称 */ + appName?: string; + /** 应用入口 */ + appPath?: string; + /** 开启 dts 输出 */ + dts?: boolean | PluginOptions; + /** 应用入口的导出变量 */ + exportName?: string; + /** 立即启动 */ + immediate?: boolean; +} + type ApplicationOptions = ApplicationPluginOptions; type LibraryOptions = LibraryPluginOptions; @@ -149,7 +167,15 @@ type DefineLibraryOptions = (config?: ConfigEnv) => Promise<{ vite?: UserConfig; }>; -type DefineConfig = DefineApplicationOptions | DefineLibraryOptions; +type DefineServerOptions = (config?: ConfigEnv) => Promise<{ + server?: ServerPluginOptions; + vite?: UserConfig; +}>; + +type DefineConfig = + | DefineApplicationOptions + | DefineLibraryOptions + | DefineServerOptions; export type { ApplicationPluginOptions, @@ -159,9 +185,11 @@ export type { DefineApplicationOptions, DefineConfig, DefineLibraryOptions, + DefineServerOptions, IImportMap, ImportmapPluginOptions, LibraryPluginOptions, NitroMockPluginOptions, PrintPluginOptions, + ServerPluginOptions, }; diff --git a/internal/vite-config/src/utils/env.ts b/internal/vite-config/src/utils/env.ts index 1dfd180869f..b05356b5f82 100644 --- a/internal/vite-config/src/utils/env.ts +++ b/internal/vite-config/src/utils/env.ts @@ -1,4 +1,6 @@ -import type { ApplicationPluginOptions } from '../typing'; +import type { RequestAdapterOption } from 'vite-plugin-node'; + +import type { ApplicationPluginOptions, ServerPluginOptions } from '../typing'; import { join } from 'node:path'; @@ -60,7 +62,7 @@ async function loadEnv>( return envConfig as T; } -async function loadAndConvertEnv( +async function loadApplicationEnv( match = 'VITE_', confFiles = getConfFiles(), ): Promise< @@ -104,4 +106,30 @@ async function loadAndConvertEnv( }; } -export { loadAndConvertEnv, loadEnv }; +async function loadServerEnv(match = 'VITE_', confFiles = getConfFiles()) { + const envConfig = await loadEnv(match, confFiles); + + const { + VITE_ADAPTER, + VITE_APP_NAME, + VITE_APP_PATH, + VITE_EXPORT_NAME, + VITE_IMMEDIATE, + VITE_PORT, + VITE_VISUALIZER, + } = envConfig; + + return { + adapter: getString(VITE_ADAPTER, 'nest') as RequestAdapterOption, + appName: getString(VITE_APP_NAME, 'Vben Server'), + appPath: getString(VITE_APP_PATH, 'src'), + exportName: getString(VITE_EXPORT_NAME, 'default'), + immediate: getBoolean(VITE_IMMEDIATE), + port: getNumber(VITE_PORT, 5173), + visualizer: getBoolean(VITE_VISUALIZER), + } satisfies { + port: number; + } & ServerPluginOptions; +} + +export { loadApplicationEnv, loadEnv, loadServerEnv }; diff --git a/package.json b/package.json index c66dcbc43c1..001039e24e1 100644 --- a/package.json +++ b/package.json @@ -27,6 +27,7 @@ "scripts": { "build": "cross-env NODE_OPTIONS=--max-old-space-size=8192 turbo build", "build:analyze": "turbo build:analyze", + "build:nest": "pnpm run build --filter=@vben/backend-nest", "build:antd": "pnpm run build --filter=@vben/web-antd", "build:docker": "./scripts/deploy/build-local-docker-image.sh", "build:docs": "pnpm run build --filter=@vben/docs", @@ -42,6 +43,7 @@ "clean": "node ./scripts/clean.mjs", "commit": "czg", "dev": "turbo-run dev", + "dev:nest": "pnpm -F @vben/backend-nest run dev", "dev:antd": "pnpm -F @vben/web-antd run dev", "dev:docs": "pnpm -F @vben/docs run dev", "dev:ele": "pnpm -F @vben/web-ele run dev", diff --git a/pnpm-lock.yaml b/pnpm-lock.yaml index a60acfc219f..c6db08a48f2 100644 --- a/pnpm-lock.yaml +++ b/pnpm-lock.yaml @@ -444,6 +444,9 @@ catalogs: vite-plugin-lib-inject-css: specifier: ^2.1.1 version: 2.1.1 + vite-plugin-node: + specifier: ^4.0.0 + version: 4.0.0 vite-plugin-pwa: specifier: ^0.20.5 version: 0.20.5 @@ -607,7 +610,7 @@ importers: version: 9.0.2 nitropack: specifier: 'catalog:' - version: 2.9.7(encoding@0.1.13) + version: 2.9.7(encoding@0.1.13)(webpack-sources@3.2.3) devDependencies: '@types/jsonwebtoken': specifier: 'catalog:' @@ -616,6 +619,34 @@ importers: specifier: 'catalog:' version: 1.13.0 + apps/backend-nest: + dependencies: + '@nestjs/common': + specifier: ^10.0.0 + version: 10.4.6(reflect-metadata@0.2.2)(rxjs@7.8.1) + '@nestjs/core': + specifier: ^10.0.0 + version: 10.4.6(@nestjs/common@10.4.6(reflect-metadata@0.2.2)(rxjs@7.8.1))(@nestjs/platform-express@10.4.6)(encoding@0.1.13)(reflect-metadata@0.2.2)(rxjs@7.8.1) + '@nestjs/platform-express': + specifier: ^10.0.0 + version: 10.4.6(@nestjs/common@10.4.6(reflect-metadata@0.2.2)(rxjs@7.8.1))(@nestjs/core@10.4.6) + reflect-metadata: + specifier: ^0.2.0 + version: 0.2.2 + rxjs: + specifier: ^7.8.1 + version: 7.8.1 + devDependencies: + '@nestjs/cli': + specifier: ^10.0.0 + version: 10.4.5 + '@types/express': + specifier: ^4.17.17 + version: 4.17.21 + '@types/node': + specifier: 'catalog:' + version: 22.7.9 + apps/web-antd: dependencies: '@vben/access': @@ -744,7 +775,7 @@ importers: devDependencies: unplugin-element-plus: specifier: 'catalog:' - version: 0.8.0(rollup@4.24.0) + version: 0.8.0(rollup@4.24.0)(webpack-sources@3.2.3) apps/web-naive: dependencies: @@ -1099,7 +1130,7 @@ importers: dependencies: '@intlify/unplugin-vue-i18n': specifier: 'catalog:' - version: 5.2.0(@vue/compiler-dom@3.5.12)(eslint@9.13.0(jiti@2.3.3))(rollup@4.24.0)(typescript@5.6.3)(vue-i18n@10.0.4(vue@3.5.12(typescript@5.6.3)))(vue@3.5.12(typescript@5.6.3)) + version: 5.2.0(@vue/compiler-dom@3.5.12)(eslint@9.13.0(jiti@2.3.3))(rollup@4.24.0)(typescript@5.6.3)(vue-i18n@10.0.4(vue@3.5.12(typescript@5.6.3)))(vue@3.5.12(typescript@5.6.3))(webpack-sources@3.2.3) '@jspm/generator': specifier: 'catalog:' version: 2.4.1 @@ -1117,7 +1148,7 @@ importers: version: 7.2.0 nitropack: specifier: 'catalog:' - version: 2.9.7(encoding@0.1.13) + version: 2.9.7(encoding@0.1.13)(webpack-sources@3.2.3) resolve.exports: specifier: 'catalog:' version: 2.0.2 @@ -1179,6 +1210,9 @@ importers: vite-plugin-lazy-import: specifier: 'catalog:' version: 1.0.7 + vite-plugin-node: + specifier: 'catalog:' + version: 4.0.0(vite@5.4.10(@types/node@22.7.9)(less@4.2.0)(sass@1.79.5)(terser@5.36.0)) packages/@core/base/design: {} @@ -1691,7 +1725,7 @@ importers: version: 2.2.2(typescript@5.6.3)(vue@3.5.12(typescript@5.6.3)) pinia-plugin-persistedstate: specifier: 'catalog:' - version: 4.1.1(pinia@2.2.2(typescript@5.6.3)(vue@3.5.12(typescript@5.6.3)))(rollup@4.24.0) + version: 4.1.1(pinia@2.2.2(typescript@5.6.3)(vue@3.5.12(typescript@5.6.3)))(rollup@4.24.0)(webpack-sources@3.2.3) vue: specifier: ^3.5.12 version: 3.5.12(typescript@5.6.3) @@ -1900,6 +1934,37 @@ packages: resolution: {integrity: sha512-30iZtAPgz+LTIYoeivqYo853f02jBYSd5uGnGpkFV0M3xOt9aN73erkgYAmZU43x4VfqcnLxW9Kpg3R5LC4YYw==} engines: {node: '>=6.0.0'} + '@angular-devkit/core@17.3.10': + resolution: {integrity: sha512-czdl54yxU5DOAGy/uUPNjJruoBDTgwi/V+eOgLNybYhgrc+TsY0f7uJ11yEk/pz5sCov7xIiS7RdRv96waS7vg==} + engines: {node: ^18.13.0 || >=20.9.0, npm: ^6.11.0 || ^7.5.6 || >=8.0.0, yarn: '>= 1.13.0'} + peerDependencies: + chokidar: ^3.5.2 + peerDependenciesMeta: + chokidar: + optional: true + + '@angular-devkit/core@17.3.8': + resolution: {integrity: sha512-Q8q0voCGudbdCgJ7lXdnyaxKHbNQBARH68zPQV72WT8NWy+Gw/tys870i6L58NWbBaCJEUcIj/kb6KoakSRu+Q==} + engines: {node: ^18.13.0 || >=20.9.0, npm: ^6.11.0 || ^7.5.6 || >=8.0.0, yarn: '>= 1.13.0'} + peerDependencies: + chokidar: ^3.5.2 + peerDependenciesMeta: + chokidar: + optional: true + + '@angular-devkit/schematics-cli@17.3.8': + resolution: {integrity: sha512-TjmiwWJarX7oqvNiRAroQ5/LeKUatxBOCNEuKXO/PV8e7pn/Hr/BqfFm+UcYrQoFdZplmtNAfqmbqgVziKvCpA==} + engines: {node: ^18.13.0 || >=20.9.0, npm: ^6.11.0 || ^7.5.6 || >=8.0.0, yarn: '>= 1.13.0'} + hasBin: true + + '@angular-devkit/schematics@17.3.10': + resolution: {integrity: sha512-FHcNa1ktYRd0SKExCsNJpR75RffsyuPIV8kvBXzXnLHmXMqvl25G2te3yYJ9yYqy9OLy/58HZznZTxWRyUdHOg==} + engines: {node: ^18.13.0 || >=20.9.0, npm: ^6.11.0 || ^7.5.6 || >=8.0.0, yarn: '>= 1.13.0'} + + '@angular-devkit/schematics@17.3.8': + resolution: {integrity: sha512-QRVEYpIfgkprNHc916JlPuNbLzOgrm9DZalHasnLUz4P6g7pR21olb8YCyM2OTJjombNhya9ZpckcADU5Qyvlg==} + engines: {node: ^18.13.0 || >=20.9.0, npm: ^6.11.0 || ^7.5.6 || >=8.0.0, yarn: '>= 1.13.0'} + '@ant-design/colors@6.0.0': resolution: {integrity: sha512-qAZRvPzfdWHtfameEGP2Qvuf838NhergR35o+EuVyB5XvSA98xod5r4utvi4TJ3ywmevm290g9nsCG5MryrdWQ==} @@ -2649,6 +2714,10 @@ packages: resolution: {integrity: sha512-YLPHc8yASwjNkmcDMQMY35yiWjoKAKnhUbPRszBRS0YgH+IXtsMp61j+yTcnCE3oO2DgP0U3iejLC8FTtKDC8Q==} engines: {node: '>=16.13'} + '@colors/colors@1.5.0': + resolution: {integrity: sha512-ooWCrlZP11i8GImSjTHYHLkvFDP48nS4+204nGb1RiX/WXYHmJA2III9/e2DWVabCESdW7hBAEzHRqUn9OUVvQ==} + engines: {node: '>=0.1.90'} + '@commitlint/cli@19.5.0': resolution: {integrity: sha512-gaGqSliGwB86MDmAAKAtV9SV1SHdmN8pnGq4EJU4+hLisQ7IFfx4jvU4s+pk6tl0+9bv6yT+CaZkufOinkSJIQ==} engines: {node: '>=v18'} @@ -4004,6 +4073,14 @@ packages: '@juggle/resize-observer@3.4.0': resolution: {integrity: sha512-dfLbk+PwWvFzSxwk3n5ySL0hfBog779o8h68wK/7/APo/7cgyWp5jcXockbxdk5kFRkbeXWm4Fbi9FrdN381sA==} + '@ljharb/through@2.3.13': + resolution: {integrity: sha512-/gKJun8NNiWGZJkGzI/Ragc53cOdcLNdzjLaIa+GEjguQs0ulsurx8WN0jijdK9yPqDvziX995sMRLyLt1uZMQ==} + engines: {node: '>= 0.4'} + + '@lukeed/csprng@1.1.0': + resolution: {integrity: sha512-Z7C/xXCiGWsg0KuKsHTKJxbWhpI3Vs5GwLfOean7MGyVFGqdRgBbAjOCh6u4bbjPc/8MJ2pZmK/0DLdCbivLDA==} + engines: {node: '>=8'} + '@manypkg/find-root@1.1.0': resolution: {integrity: sha512-mki5uBvhHzO8kYYix/WRy2WX8S3B5wdVSc9D6KcU5lQNglP2yt58/VfLuAK49glRXChosY8ap2oJ1qgma3GUVA==} @@ -4039,6 +4116,60 @@ packages: '@microsoft/tsdoc@0.15.0': resolution: {integrity: sha512-HZpPoABogPvjeJOdzCOSJsXeL/SMCBgBZMVC3X3d7YYp2gf31MfxhUoYUNwf1ERPJOnQc0wkFn9trqI6ZEdZuA==} + '@nestjs/cli@10.4.5': + resolution: {integrity: sha512-FP7Rh13u8aJbHe+zZ7hM0CC4785g9Pw4lz4r2TTgRtf0zTxSWMkJaPEwyjX8SK9oWK2GsYxl+fKpwVZNbmnj9A==} + engines: {node: '>= 16.14'} + hasBin: true + peerDependencies: + '@swc/cli': ^0.1.62 || ^0.3.0 || ^0.4.0 + '@swc/core': ^1.3.62 + peerDependenciesMeta: + '@swc/cli': + optional: true + '@swc/core': + optional: true + + '@nestjs/common@10.4.6': + resolution: {integrity: sha512-KkezkZvU9poWaNq4L+lNvx+386hpOxPJkfXBBeSMrcqBOx8kVr36TGN2uYkF4Ta4zNu1KbCjmZbc0rhHSg296g==} + peerDependencies: + class-transformer: '*' + class-validator: '*' + reflect-metadata: ^0.1.12 || ^0.2.0 + rxjs: ^7.1.0 + peerDependenciesMeta: + class-transformer: + optional: true + class-validator: + optional: true + + '@nestjs/core@10.4.6': + resolution: {integrity: sha512-zXVPxCNRfO6gAy0yvEDjUxE/8gfZICJFpsl2lZAUH31bPb6m+tXuhUq2mVCTEltyMYQ+DYtRe+fEYM2v152N1g==} + peerDependencies: + '@nestjs/common': ^10.0.0 + '@nestjs/microservices': ^10.0.0 + '@nestjs/platform-express': ^10.0.0 + '@nestjs/websockets': ^10.0.0 + reflect-metadata: ^0.1.12 || ^0.2.0 + rxjs: ^7.1.0 + peerDependenciesMeta: + '@nestjs/microservices': + optional: true + '@nestjs/platform-express': + optional: true + '@nestjs/websockets': + optional: true + + '@nestjs/platform-express@10.4.6': + resolution: {integrity: sha512-HcyCpAKccAasrLSGRTGWv5BKRs0rwTIFOSsk6laNyqfqvgvYcJQAedarnm4jmaemtmSJ0PFI9PmtEZADd2ahCg==} + peerDependencies: + '@nestjs/common': ^10.0.0 + '@nestjs/core': ^10.0.0 + + '@nestjs/schematics@10.2.2': + resolution: {integrity: sha512-D4pJ46E8llCA7WPr3cV6sfRqDlvnTjQWnF1fLyKYD3Ldl+KPtlLyIcxaqlLTB0YR9ItKNKIZTJzUehRxR7UUsQ==} + peerDependencies: + typescript: '>=4.8.2' + '@netlify/functions@2.8.2': resolution: {integrity: sha512-DeoAQh8LuNPvBE4qsKlezjKj0PyXDryOFJfJKo3Z1qZLKzQ21sT314KQKPVjfvw6knqijj+IO+0kHXy/TJiqNA==} engines: {node: '>=14.0.0'} @@ -4085,6 +4216,11 @@ packages: resolution: {integrity: sha512-CCZgpm+MkqtOMDEgF9SWgGPBXlQ01hV/6+2reDEpJuqFPGzV8HYKPBcIFvn7/z5ahtgutHLzjP71Na+hYcqSpw==} engines: {node: ^14.18.0 || >=16.10.0} + '@nuxtjs/opencollective@0.3.2': + resolution: {integrity: sha512-um0xL3fO7Mf4fDxcqx9KryrB7zgRM5JSlvGN5AGkP6JLM5XEKyjeAiPbNxdXVXQ16isuAhYpvP88NgL2BGd6aA==} + engines: {node: '>=8.0.0', npm: '>=5.0.0'} + hasBin: true + '@one-ini/wasm@0.1.1': resolution: {integrity: sha512-XuySG1E38YScSJoMlqovLru4KTUNSjgVTIjyh7qMX6aNN5HY5Ct5LhRJdxO79JtTzKfzV/bnWpz+zquYrISsvw==} @@ -4534,6 +4670,12 @@ packages: '@types/bintrees@1.0.6': resolution: {integrity: sha512-pZWT4Bz+tWwxlDspSjdoIza4PE5lbGI4Xvs3FZV/2v5m5SDA8LwNpU8AXxlndmARO7OaQ1Vf3zFenOsNMzaRkQ==} + '@types/body-parser@1.19.5': + resolution: {integrity: sha512-fB3Zu92ucau0iQ0JMCFQE7b/dv8Ot07NI3KaZIkIUNXq82k4eBAqUaneXfleGY9JWskeS9y+u0nXMyspcuQrCg==} + + '@types/connect@3.4.38': + resolution: {integrity: sha512-K6uROf1LD88uDQqJCktA4yzL1YYAK6NgfsI0v/mTgyPKWsX1CnJ0XPSDhViejru1GcRkLWb8RlzFYJRqGUbaug==} + '@types/conventional-commits-parser@5.0.0': resolution: {integrity: sha512-loB369iXNmAZglwWATL+WRe+CRMmmBPtpolYzIebFaX4YA3x+BEfLqhUAV9WanycKI3TG1IMr5bMJDajDKLlUQ==} @@ -4546,6 +4688,12 @@ packages: '@types/estree@1.0.6': resolution: {integrity: sha512-AYnb1nQyY49te+VRAVgmzfcgjYS91mY5P0TKUDCLEM+gNnA+3T6rWITXRLYCpahpqSQbN5cE+gHpnPyXjHWxcw==} + '@types/express-serve-static-core@4.19.6': + resolution: {integrity: sha512-N4LZ2xG7DatVqhCZzOGb1Yi5lMbXSZcmdLDe9EzSndPV2HpWYWzRbaerl2n27irrm94EPpprqa8KpskPT085+A==} + + '@types/express@4.17.21': + resolution: {integrity: sha512-ejlPM315qwLpaQlQDTjPdsUFSc6ZsP4AN6AlWnogPjQ7CVi7PYF3YVz+CY3jE2pwYf7E/7HlDAN0rV2GxTG0HQ==} + '@types/fs-extra@11.0.4': resolution: {integrity: sha512-yTbItCNreRooED33qjunPthRcSjERP1r4MqCZc7wv0u2sUkzTFp45tgUfS5+r7FrZPdmCCNflLhVSP/o+SemsQ==} @@ -4555,6 +4703,9 @@ packages: '@types/html-minifier-terser@7.0.2': resolution: {integrity: sha512-mm2HqV22l8lFQh4r2oSsOEVea+m0qqxEmwpc9kC1p/XzmjLWrReR9D/GRs8Pex2NX/imyEH9c5IU/7tMBQCHOA==} + '@types/http-errors@2.0.4': + resolution: {integrity: sha512-D0CFMMtydbJAegzOyHjtiKPLlvnm3iTZyZRSZoLq2mRhDdmLfIWOCYPfQJ4cu2erKghU++QvjcUjp/5h7hESpA==} + '@types/http-proxy@1.17.15': resolution: {integrity: sha512-25g5atgiVNTIv0LBDTg1H74Hvayx0ajtJPLLcYE3whFv75J0pWNtOBzaXJQgDTmrX1bx5U9YC2w/n65BN1HwRQ==} @@ -4591,6 +4742,9 @@ packages: '@types/mdurl@2.0.0': resolution: {integrity: sha512-RGdgjQUZba5p6QEFAVx2OGb8rQDL/cPRG7GiedRzMcJ1tYnUANBncjbSB1NRGwbvjcPeikRABz2nshyPk1bhWg==} + '@types/mime@1.3.5': + resolution: {integrity: sha512-/pyBZWSLD2n0dcHE3hq8s8ZvcETHtEuF+3E7XVt0Ig2nvsVQXdghHVcEkIWjy9A0wKfTn97a/PSDYohKIlnP/w==} + '@types/minimatch@3.0.5': resolution: {integrity: sha512-Klz949h02Gz2uZCMGwDUSDS1YBlTdDDgbWHi+81l29tQALUtvz4rAYi5uoVhE5Lagoq6DeqAUlbrHvW/mXDgdQ==} @@ -4600,9 +4754,6 @@ packages: '@types/node@22.7.7': resolution: {integrity: sha512-SRxCrrg9CL/y54aiMCG3edPKdprgMVGDXjA3gB8UmmBW5TcXzRUYAh8EWzTnSJFAd1rgImPELza+A3bJ+qxz8Q==} - '@types/node@22.7.8': - resolution: {integrity: sha512-a922jJy31vqR5sk+kAdIENJjHblqcZ4RmERviFsER4WJcEONqxKcjNOlk0q7OUfrF5sddT+vng070cdfMlrPLg==} - '@types/node@22.7.9': resolution: {integrity: sha512-jrTfRC7FM6nChvU7X2KqcrgquofrWLFDeYC1hKfwNWomVvrn7JIksqf344WN2X/y8xrgqBd2dJATZV4GbatBfg==} @@ -4621,12 +4772,24 @@ packages: '@types/qrcode@1.5.5': resolution: {integrity: sha512-CdfBi/e3Qk+3Z/fXYShipBT13OJ2fDO2Q2w5CIP5anLTLIndQG9z6P1cnm+8zCWSpm5dnxMFd/uREtb0EXuQzg==} + '@types/qs@6.9.16': + resolution: {integrity: sha512-7i+zxXdPD0T4cKDuxCUXJ4wHcsJLwENa6Z3dCu8cfCK743OGy5Nu1RmAGqDPsoTDINVEcdXKRvR/zre+P2Ku1A==} + + '@types/range-parser@1.2.7': + resolution: {integrity: sha512-hKormJbkJqzQGhziax5PItDUTMAM9uE2XXQmM37dyd4hVM+5aVl7oVxMVUiVQn2oCQFN/LKCZdvSM0pFRqbSmQ==} + '@types/readdir-glob@1.1.5': resolution: {integrity: sha512-raiuEPUYqXu+nvtY2Pe8s8FEmZ3x5yAH4VkLdihcPdalvsHltomrRC9BzuStrJ9yk06470hS0Crw0f1pXqD+Hg==} '@types/resolve@1.20.2': resolution: {integrity: sha512-60BCwRFOZCQhDncwQdxxeOEEkbc5dIMccYLwbxsS4TUNeVECQ/pBJ0j09mrHOl/JJvpRPGwO9SvE4nR2Nb/a4Q==} + '@types/send@0.17.4': + resolution: {integrity: sha512-x2EM6TJOybec7c52BX0ZspPodMsQUd5L6PRwOunVyVUhXiBSKf3AezDL8Dgvgt5o0UfKNfuA0eMLr2wLT4AiBA==} + + '@types/serve-static@1.15.7': + resolution: {integrity: sha512-W8Ym+h8nhuRwaKPaDw34QUkwsGi6Rc4yYqvKFo5rm2FUEhCFbzVWrxXUxuKK8TASjWsysJY0nsmNCGhCOIsrOw==} + '@types/sortablejs@1.15.8': resolution: {integrity: sha512-b79830lW+RZfwaztgs1aVPgbasJ8e7AXtZYHTELNXZPsERt4ymJdjV4OccDbHQAvHrCcFpbF78jkm0R6h/pZVg==} @@ -4981,6 +5144,57 @@ packages: peerDependencies: vue: ^3.5.12 + '@webassemblyjs/ast@1.12.1': + resolution: {integrity: sha512-EKfMUOPRRUTy5UII4qJDGPpqfwjOmZ5jeGFwid9mnoqIFK+e0vqoi1qH56JpmZSzEL53jKnNzScdmftJyG5xWg==} + + '@webassemblyjs/floating-point-hex-parser@1.11.6': + resolution: {integrity: sha512-ejAj9hfRJ2XMsNHk/v6Fu2dGS+i4UaXBXGemOfQ/JfQ6mdQg/WXtwleQRLLS4OvfDhv8rYnVwH27YJLMyYsxhw==} + + '@webassemblyjs/helper-api-error@1.11.6': + resolution: {integrity: sha512-o0YkoP4pVu4rN8aTJgAyj9hC2Sv5UlkzCHhxqWj8butaLvnpdc2jOwh4ewE6CX0txSfLn/UYaV/pheS2Txg//Q==} + + '@webassemblyjs/helper-buffer@1.12.1': + resolution: {integrity: sha512-nzJwQw99DNDKr9BVCOZcLuJJUlqkJh+kVzVl6Fmq/tI5ZtEyWT1KZMyOXltXLZJmDtvLCDgwsyrkohEtopTXCw==} + + '@webassemblyjs/helper-numbers@1.11.6': + resolution: {integrity: sha512-vUIhZ8LZoIWHBohiEObxVm6hwP034jwmc9kuq5GdHZH0wiLVLIPcMCdpJzG4C11cHoQ25TFIQj9kaVADVX7N3g==} + + '@webassemblyjs/helper-wasm-bytecode@1.11.6': + resolution: {integrity: sha512-sFFHKwcmBprO9e7Icf0+gddyWYDViL8bpPjJJl0WHxCdETktXdmtWLGVzoHbqUcY4Be1LkNfwTmXOJUFZYSJdA==} + + '@webassemblyjs/helper-wasm-section@1.12.1': + resolution: {integrity: sha512-Jif4vfB6FJlUlSbgEMHUyk1j234GTNG9dBJ4XJdOySoj518Xj0oGsNi59cUQF4RRMS9ouBUxDDdyBVfPTypa5g==} + + '@webassemblyjs/ieee754@1.11.6': + resolution: {integrity: sha512-LM4p2csPNvbij6U1f19v6WR56QZ8JcHg3QIJTlSwzFcmx6WSORicYj6I63f9yU1kEUtrpG+kjkiIAkevHpDXrg==} + + '@webassemblyjs/leb128@1.11.6': + resolution: {integrity: sha512-m7a0FhE67DQXgouf1tbN5XQcdWoNgaAuoULHIfGFIEVKA6tu/edls6XnIlkmS6FrXAquJRPni3ZZKjw6FSPjPQ==} + + '@webassemblyjs/utf8@1.11.6': + resolution: {integrity: sha512-vtXf2wTQ3+up9Zsg8sa2yWiQpzSsMyXj0qViVP6xKGCUT8p8YJ6HqI7l5eCnWx1T/FYdsv07HQs2wTFbbof/RA==} + + '@webassemblyjs/wasm-edit@1.12.1': + resolution: {integrity: sha512-1DuwbVvADvS5mGnXbE+c9NfA8QRcZ6iKquqjjmR10k6o+zzsRVesil54DKexiowcFCPdr/Q0qaMgB01+SQ1u6g==} + + '@webassemblyjs/wasm-gen@1.12.1': + resolution: {integrity: sha512-TDq4Ojh9fcohAw6OIMXqiIcTq5KUXTGRkVxbSo1hQnSy6lAM5GSdfwWeSxpAo0YzgsgF182E/U0mDNhuA0tW7w==} + + '@webassemblyjs/wasm-opt@1.12.1': + resolution: {integrity: sha512-Jg99j/2gG2iaz3hijw857AVYekZe2SAskcqlWIZXjji5WStnOpVoat3gQfT/Q5tb2djnCjBtMocY/Su1GfxPBg==} + + '@webassemblyjs/wasm-parser@1.12.1': + resolution: {integrity: sha512-xikIi7c2FHXysxXe3COrVUPSheuBtpcfhbpFj4gmu7KRLYOzANztwUU0IbsqvMqzuNK2+glRGWCEqZo1WCLyAQ==} + + '@webassemblyjs/wast-printer@1.12.1': + resolution: {integrity: sha512-+X4WAlOisVWQMikjbcvY2e0rwPsKQ9F688lksZhBcPycBBuii3O7m8FACbDMWDojpAqvjIncrG8J0XHKyQfVeA==} + + '@xtuc/ieee754@1.2.0': + resolution: {integrity: sha512-DX8nKgqcGwsc0eJSqYt5lwP4DH5FlHnmuWWBRy7X0NcaGR0ZtuyeESgMwTYVEtxmsNGY+qit4QYT/MIYTOTPeA==} + + '@xtuc/long@4.2.2': + resolution: {integrity: sha512-NuHqBY1PB/D8xU6s/thBgOAiAP7HOYDQ32+BFZILJ8ivkUkAHQnWfn6WhL79Owj1qmUnoN/YPhktdIoucipkAQ==} + JSONStream@1.3.5: resolution: {integrity: sha512-E+iruNOY8VV9s4JEbe1aNEm6MiszPRr/UfcHMz0TQh1BXSxHK+ASV1R6W4HpjBhSeS+54PIsAMCBmwD06LLsqQ==} hasBin: true @@ -4996,6 +5210,10 @@ packages: resolution: {integrity: sha512-h8lQ8tacZYnR3vNQTgibj+tODHI5/+l06Au2Pcriv/Gmet0eaj4TwWH41sO9wnHDiQsEj19q0drzdWdeAHtweg==} engines: {node: '>=6.5'} + accepts@1.3.8: + resolution: {integrity: sha512-PYAthTa2m2VKxuvSD3DPC/Gy+U+sOA1LAuT8mkmRuvw+NACSaeXEQ+NHcVF7rONl6qcaxV3Uuemwawk+7+SJLw==} + engines: {node: '>= 0.6'} + acorn-import-attributes@1.9.5: resolution: {integrity: sha512-n02Vykv5uA3eHGM/Z2dQrcD56kL8TyDb2p1+0P83PClMnC/nc+anbQRhIOWnSq4Ke/KvDPrY3C9hDtC/A3eHnQ==} peerDependencies: @@ -5031,6 +5249,14 @@ packages: ajv: optional: true + ajv-formats@2.1.1: + resolution: {integrity: sha512-Wx0Kx52hxE7C18hkMEggYlEifqWZtYaRgouJor+WMdPnQyEK13vgEWyVNup7SoeeoLMsr4kf5h6dOW11I15MUA==} + peerDependencies: + ajv: ^8.0.0 + peerDependenciesMeta: + ajv: + optional: true + ajv-formats@3.0.1: resolution: {integrity: sha512-8iUql50EUR+uUcdRQ3HDqa6EVyo3docL8g5WJ3FNcWmu62IbkGUue/pEyLBW8VGKKucTPgqeks4fIU1DA4yowQ==} peerDependencies: @@ -5039,6 +5265,11 @@ packages: ajv: optional: true + ajv-keywords@3.5.2: + resolution: {integrity: sha512-5p6WTN0DdTGVQk6VjcEju19IgaHudalcfabD7yhDGeA6bcQnmL+CpveLJq/3hvfwd1aof6L386Ougkx6RfyMIQ==} + peerDependencies: + ajv: ^6.9.1 + ajv@6.12.6: resolution: {integrity: sha512-j3fVLgvTo527anyYyJOGTYJbG+vnnQYvE0m5mmkc1TK+nxAppkCLMIL0aZ4dblVCNoGShhm+kzE4ZUykBoMg4g==} @@ -5061,6 +5292,10 @@ packages: resolution: {integrity: sha512-/6w/C21Pm1A7aZitlI5Ni/2J6FFQN8i1Cvz3kHABAAbw93v/NlvKdVOqz7CCWz/3iv/JplRSEEZ83XION15ovw==} engines: {node: '>=6'} + ansi-escapes@4.3.2: + resolution: {integrity: sha512-gKXj5ALrKWQLsYG9jlTRmR/xKluxHV+Z9QEwNIgCfM1/uwPMCuzVVnh5mwTd+OuBZcwSIMbqssNWRm1lE51QaQ==} + engines: {node: '>=8'} + ansi-escapes@7.0.0: resolution: {integrity: sha512-GdYO7a61mR0fOlAsvC9/rIHf7L96sBc6dEWzeOu+KAea5bZyQRPIpojrVoI4AXGJS/ycu/fBTdLrUkA4ODrvjw==} engines: {node: '>=18'} @@ -5098,6 +5333,9 @@ packages: resolution: {integrity: sha512-KMReFUr0B4t+D+OBkjR3KYqvocp2XaSzO55UcB6mgQMd3KbcE+mWTyvVV7D/zsdEbNnV6acZUutkiHQXvTr1Rw==} engines: {node: '>= 8'} + append-field@1.0.0: + resolution: {integrity: sha512-klpgFSWLW1ZEs8svjfb7g4qWY0YS5imI82dTg+QahUvJ8YqAY0P10Uk8tTyh9ZGuYEZEMaeJYCF5BFuX552hsw==} + aproba@2.0.0: resolution: {integrity: sha512-lYe4Gx7QT+MKGbDsA+Z+he/Wtef0BiwDOlK/XkBrdfsh9J/jPPXbX0tE9x9cl27Tmu5gg3QUbUrQYa/y+KOHPQ==} @@ -5139,6 +5377,9 @@ packages: resolution: {integrity: sha512-THtfYS6KtME/yIAhKjZ2ul7XI96lQGHRputJQHO80LAWQnuGP4iCIN8vdMRboGbIEYBwU33q8Tch1os2+X0kMg==} engines: {node: '>=8'} + array-flatten@1.1.1: + resolution: {integrity: sha512-PCVAQswWemu6UdxsDFFX/+gVeYqKAod3D3UVm91jHwynguOwAvYPhx8nNlM++NqRcK6CxxpUafjmhIdKiHibqg==} + array-ify@1.0.0: resolution: {integrity: sha512-c5AMf34bKdvPhQ7tBGhqkgKNUzMr4WUs+WDtC2ZUGOUncbxKMTvqxYctiseW3+L4bA8ec+GcZ6/A/FW4m8ukng==} @@ -5253,6 +5494,13 @@ packages: birpc@0.2.19: resolution: {integrity: sha512-5WeXXAvTmitV1RqJFppT5QtUiz2p1mRSYU000Jkft5ZUCLJIk4uQriYNO50HknxKwM6jd8utNc66K1qGIwwWBQ==} + bl@4.1.0: + resolution: {integrity: sha512-1W07cM9gS6DcLperZfFSj+bWLtaPGSOHWhPiGzXmvVJbRLdG82sH/Kn8EtW1VqWVA54AKf2h5k5BbnIbwF3h6w==} + + body-parser@1.20.3: + resolution: {integrity: sha512-7rAxByjUMqQ3/bHJy7D6OGXvx/MMc4IqBn/X0fcM1QUcAItpZrBEYhWGem+tzXH90c+G01ypMcYJBO9Y30203g==} + engines: {node: '>= 0.8', npm: 1.2.8000 || >= 1.4.16} + boolbase@1.0.0: resolution: {integrity: sha512-JZOSA7Mo9sNGB8+UjSgzdLtokWAky1zbztM3WRLCbZ70/3cTANmQmOdR7y2g+J0e2WXywy1yS468tY+IruqEww==} @@ -5285,6 +5533,9 @@ packages: buffer-from@1.1.2: resolution: {integrity: sha512-E+XQCRwSbaaiChtv6k6Dwgc+bx+Bs6vuKJHHl5kox/BaKbhiXzqQOwK4cO22yElGp2OCmjwVhT3HmxgyPGnJfQ==} + buffer@5.7.1: + resolution: {integrity: sha512-EHcyIPBQ4BSGlvjB16k5KgAJ27CIsHY/2JBmCRReo48y9rQ3MaUzWX3KVlBa4U7MyX02HdVj0K7C3WaB3ju7FQ==} + buffer@6.0.3: resolution: {integrity: sha512-FTiCpNxtwiZZHEZbcbTIcZjERVICn9yq/pDFkTl95/AxzD1naBctN7YO68riM/gLSDY7sdrMby8hofADYuuqOA==} @@ -5296,6 +5547,14 @@ packages: resolution: {integrity: sha512-tjwM5exMg6BGRI+kNmTntNsvdZS1X8BFYS6tnJ2hdH0kVxM6/eVZ2xy+FqStSWvYmtfFMDLIxurorHwDKfDz5Q==} engines: {node: '>=18'} + busboy@1.6.0: + resolution: {integrity: sha512-8SFQbg/0hQ9xy3UNTB0YEnsNBbWfhf7RtnzpL7TkBiTBRfrQ9Fxcnz7VJsleJpyp6rVLvXiuORqjlHi5q+PYuA==} + engines: {node: '>=10.16.0'} + + bytes@3.1.2: + resolution: {integrity: sha512-/Nf7TyzTx6S3yRJObOAV7956r8cr2+Oj8AC5dt8wSP3BQAoeX58NoHyCU8P8zGkNXStjTSi6fzO6F0pBdcYbEg==} + engines: {node: '>= 0.8'} + c12@1.11.2: resolution: {integrity: sha512-oBs8a4uvSDO9dm8b7OCFW7+dgtVrwmwnrVXYzLm43ta7ep2jCn/0MhoUFygIWtxhyy6+/MG7/agvpY0U1Iemew==} peerDependencies: @@ -5403,6 +5662,10 @@ packages: resolution: {integrity: sha512-bIomtDF5KGpdogkLd9VspvFzk9KfpyyGlS8YFVZl7TGPBHL5snIOnxeshwVgPteQ9b4Eydl+pVbIyE1DcvCWgQ==} engines: {node: '>=10'} + chrome-trace-event@1.0.4: + resolution: {integrity: sha512-rNjApaLzuwaOTjCiT8lSDdGN1APCiqkChLMJxJPWLunPAt5fy8xgU9/jNOchV84wfIxrA0lRQB7oCT8jrn/wrQ==} + engines: {node: '>=6.0'} + ci-info@3.9.0: resolution: {integrity: sha512-NIxF55hv4nSqQswkAeiOi1r83xy8JldOFDTWiug55KBu9Jnblncd2U6ViHmYgHf01TPZS77NJBhBMKdWj9HQMQ==} engines: {node: '>=8'} @@ -5441,6 +5704,10 @@ packages: resolution: {integrity: sha512-/lzGpEWL/8PfI0BmBOPRwp0c/wFNX1RdUML3jK/RcSBA9T8mZDdQpqYBKtCFTOfQbwPqWEOpjqW+Fnayc0969g==} engines: {node: '>=10'} + cli-cursor@3.1.0: + resolution: {integrity: sha512-I/zHAwsKf9FqGoXM4WWRACob9+SNukZTd94DWF57E4toouRulbCxcUh6RKUEOQlYTHJnzkPMySvPNaaSLNfLZw==} + engines: {node: '>=8'} + cli-cursor@5.0.0: resolution: {integrity: sha512-aCj4O5wKyszjMmDT4tZj93kxyydN/K5zPWSCe6/0AV/AA1pqe5ZBIw0a2ZfPQV7lL5/yb5HsUreJ6UFAF1tEQw==} engines: {node: '>=18'} @@ -5449,10 +5716,22 @@ packages: resolution: {integrity: sha512-ywqV+5MmyL4E7ybXgKys4DugZbX0FC6LnwrhjuykIjnK9k8OQacQ7axGKnjDXWNhns0xot3bZI5h55H8yo9cJg==} engines: {node: '>=6'} + cli-table3@0.6.5: + resolution: {integrity: sha512-+W/5efTR7y5HRD7gACw9yQjqMVvEMLBHmboM/kPWam+H+Hmyrgjh6YncVKK122YZkXrLudzTuAukUw9FnMf7IQ==} + engines: {node: 10.* || >= 12.*} + cli-truncate@4.0.0: resolution: {integrity: sha512-nPdaFdQ0h/GEigbPClz11D0v/ZJEwxmeVZGeMo3Z5StPtUTkA9o1lD6QwoirYiSDzbcwn2XcjwmCp68W1IS4TA==} engines: {node: '>=18'} + cli-width@3.0.0: + resolution: {integrity: sha512-FxqpkPPwu1HjuN93Omfm4h8uIanXofW0RxVEW3k5RKx+mJJYSthzNhp32Kzxxy3YAEZ/Dc/EWN1vZRY0+kOhbw==} + engines: {node: '>= 10'} + + cli-width@4.1.0: + resolution: {integrity: sha512-ouuZd4/dm2Sw5Gmqy6bGyNNNe1qt9RpmxveLSO7KcgsTnU7RXfsw+/bukWGo1abgBiMAic068rclZsO4IWmmxQ==} + engines: {node: '>= 12'} + clipboardy@4.0.0: resolution: {integrity: sha512-5mOlNS0mhX0707P2I0aZ2V/cmHUEO/fL7VFLqszkhUsxt7RwnmrInf/eEQKlf5GzvYeHIjT+Ov1HRfNmymlG0w==} engines: {node: '>=18'} @@ -5467,6 +5746,10 @@ packages: resolution: {integrity: sha512-BSeNnyus75C4//NQ9gQt1/csTXyo/8Sb+afLAkzAptFuMsod9HFokGNudZpi/oQV73hnVK+sR+5PVRMd+Dr7YQ==} engines: {node: '>=12'} + clone@1.0.4: + resolution: {integrity: sha512-JQHZ2QMW6l3aH/j6xCqQThY/9OH4D/9ls34cgkUBiEeocRTU04tHfKPBsUK1PqZCUQM7GiA0IIXJSuXHI64Kbg==} + engines: {node: '>=0.8'} + clsx@2.1.1: resolution: {integrity: sha512-eYm0QWBtUrBWZWG0d386OGAw16Z995PiOVo2B7bjWSbHedGl5e0ZWaq65kOGgUSNesEIDkB9ISbTg/JK9dhCZA==} engines: {node: '>=6'} @@ -5571,6 +5854,10 @@ packages: concat-map@0.0.1: resolution: {integrity: sha512-/Srv4dswyQNBfohGpz9o6Yb3Gz3SrUDqBH5rTuhGR7ahtlbYKnVxw2bCFMRljaA7EXHaXZ8wsHdodFvbkhKmqg==} + concat-stream@1.6.2: + resolution: {integrity: sha512-27HBghJxjiZtIk3Ycvn/4kbJk/1uZuJFfuPEns6LaEvpvG1f0hTea8lilrouyo9mVc2GWdcEZ8OLoGmSADlrCw==} + engines: {'0': node >= 0.8} + confbox@0.1.8: resolution: {integrity: sha512-RMtmw0iFkeR4YV+fUOSucriAQNb9g8zFR52MWCtl+cCZOFRNL6zeB395vPzFhEjjn4fMxXudmELnl/KF/WrK6w==} @@ -5595,6 +5882,14 @@ packages: console-control-strings@1.1.0: resolution: {integrity: sha512-ty/fTekppD2fIwRvnZAVdeOiGd1c7YXEixbgJTNzqcxJWKQnjJ/V1bNEEE6hygpM3WjwHFUVK6HTjWSzV4a8sQ==} + content-disposition@0.5.4: + resolution: {integrity: sha512-FveZTNuGw04cxlAiWbzi6zTAL/lhehaWbTtgluJh4/E95DqMwTmha3KZN1aAWA8cFIhHzMZUvLevkw5Rqk+tSQ==} + engines: {node: '>= 0.6'} + + content-type@1.0.5: + resolution: {integrity: sha512-nTjqfcBFEipKdXCv4YDQWCfmcLZKm81ldF0pAopTvyrFGVbcR6P/VAAd5G7N+0tTr8QqiU0tFadD6FK4NtJwOA==} + engines: {node: '>= 0.6'} + conventional-changelog-angular@7.0.0: resolution: {integrity: sha512-ROjNchA9LgfNMTTFSIWPzebCwOGFdgkEq45EnvvrmSLvCtAw0HSmrCs7/ty+wAeYUZyNay0YMUNYFTRL72PkBQ==} engines: {node: '>=16'} @@ -5614,6 +5909,13 @@ packages: cookie-es@1.2.2: resolution: {integrity: sha512-+W7VmiVINB+ywl1HGXJXmrqkOhpKrIiVZV6tQuV54ZyQC7MMuBt81Vc336GMLoHBq5hV/F9eXgt5Mnx0Rha5Fg==} + cookie-signature@1.0.6: + resolution: {integrity: sha512-QADzlaHc8icV8I7vbaJXJwod9HWYp8uCqf1xa4OfNu1T7JVxQIrUgOWtHdNDtPiywmFbiS12VjotIXLrKM3orQ==} + + cookie@0.7.1: + resolution: {integrity: sha512-6DnInpx7SJ2AK3+CTUE/ZM0vWTUboZCegxhC2xiIydHR9jNuTAASBrfEpHhiGOZw/nX51bHt6YQl8jsGo4y/0w==} + engines: {node: '>= 0.6'} + copy-anything@2.0.6: resolution: {integrity: sha512-1j20GZTsvKNkc4BY3NpMOM8tt///wY3FpIzozTOFO2ffuZcV61nojHXVKIy3WM+7ADCy5FVhdZYHYDdgTU0yJw==} @@ -5630,6 +5932,10 @@ packages: core-util-is@1.0.3: resolution: {integrity: sha512-ZQBvi1DcpJ4GDqanjucZ2Hj3wEO5pZDS89BWbkcrvdxksJorwUDDZamX9ldFkp9aw2lmBDLgkObEA4DWNJ9FYQ==} + cors@2.8.5: + resolution: {integrity: sha512-KIHbLJqu73RGr/hnbrO9uBeixNGuvSQjul/jdFvS/KFSIH1hWVd1ng7zOHx+YrEfInLG7q4n6GHQ9cDtxv/P6g==} + engines: {node: '>= 0.10'} + cosmiconfig-typescript-loader@5.1.0: resolution: {integrity: sha512-7PtBB+6FdsOvZyJtlF3hEPpACq7RQX6BVGsgC7/lfVXnKMvNCu/XY3ykreqG5w/rBNdu2z8LCIKoF3kpHHdHlA==} engines: {node: '>=v16'} @@ -5642,6 +5948,15 @@ packages: resolution: {integrity: sha512-AdmX6xUzdNASswsFtmwSt7Vj8po9IuqXm0UXz7QKPuEUmPB4XyjGfaAr2PSuELMwkRMVH1EpIkX5bTZGRB3eCA==} engines: {node: '>=10'} + cosmiconfig@8.3.6: + resolution: {integrity: sha512-kcZ6+W5QzcJ3P1Mt+83OUv/oHFqZHIx8DuxG6eZ5RGMERoLqp4BuGjhHLYGK+Kf5XVkQvqBSmAy/nGWN3qDgEA==} + engines: {node: '>=14'} + peerDependencies: + typescript: '>=4.9.5' + peerDependenciesMeta: + typescript: + optional: true + cosmiconfig@9.0.0: resolution: {integrity: sha512-itvL5h8RETACmOTFc4UfIyB2RfEHi71Ax6E/PivVxq9NseKbOWpeyHEOIbmAw1rs8Ak0VursQNww7lf7YtUwzg==} engines: {node: '>=14'} @@ -5933,6 +6248,9 @@ packages: resolution: {integrity: sha512-WY/3TUME0x3KPYdRRxEJJvXRHV4PyPoUsxtZa78lwItwRQRHhd2U9xOscaT/YTf8uCXIAjeJOFBVEh/7FtD8Xg==} engines: {node: '>=18'} + defaults@1.0.4: + resolution: {integrity: sha512-eFuaLoy/Rxalv2kr+lqMlUnrDWV+3j4pljOIJgLIhI058IQfWJ7vXhyEIHu+HtC738klGALYxOKDO0bQP3tg8A==} + define-data-property@1.1.4: resolution: {integrity: sha512-rBMvIzlpA8v6E+SJZoo++HAYqsLrkg7MSfIinMPFhmkorw7X+dOXVJQs+QT69zGkzMyfDnIMN2Wid1+NbL3T+A==} engines: {node: '>= 0.4'} @@ -6397,6 +6715,10 @@ packages: peerDependencies: eslint: ^6.2.0 || ^7.0.0 || ^8.0.0 || ^9.0.0 + eslint-scope@5.1.1: + resolution: {integrity: sha512-2NxwbF/hZ0KpepYN0cNbo+FN6XoK7GaHlQhgx/hIZl6Va0bF45RQOOwhLIy8lQDbuCiadSLCBnH2CFYquit5bw==} + engines: {node: '>=8.0.0'} + eslint-scope@7.2.2: resolution: {integrity: sha512-dOt21O7lTMhDM+X9mB4GX+DZrZtCUJPL/wlcTqxyrx5IvO0IYtILdtrQGQp+8n5S0gwSVmOf9NQrjMOgfQZlIg==} engines: {node: ^12.22.0 || ^14.17.0 || >=16.0.0} @@ -6444,6 +6766,10 @@ packages: resolution: {integrity: sha512-KmfKL3b6G+RXvP8N1vr3Tq1kL/oCFgn2NYXEtqP8/L3pKapUA4G8cFVaoF3SU323CD4XypR/ffioHmkti6/Tag==} engines: {node: '>=4.0'} + estraverse@4.3.0: + resolution: {integrity: sha512-39nnKffWz8xN1BU/2c79n9nB9HDzo0niYUqx6xyqUnyoAnQyyWpOTdZEeiCch8BBu515t4wp9ZmgVfVhn9EBpw==} + engines: {node: '>=4.0'} + estraverse@5.3.0: resolution: {integrity: sha512-MMdARuVEQziNTeJD8DgMqmhwR11BRQ/cBP+pLtYdSTnf3MIO8fFeiINEbX36ZdNlfU/7A9f3gUw49B3oQsvwBA==} engines: {node: '>=4.0'} @@ -6491,6 +6817,10 @@ packages: resolution: {integrity: sha512-A5EmesHW6rfnZ9ysHQjPdJRni0SRar0tjtG5MNtm9n5TUvsYU8oozprtRD4AqHxcZWWlVuAmQo2nWKfN9oyjTw==} engines: {node: '>=0.10.0'} + express@4.21.1: + resolution: {integrity: sha512-YSFlK1Ee0/GC8QaO91tHcDxJiE/X4FbpAyQWkxAvG6AXCuR65YzK8ua6D9hvi/TzUfZMpc+BwuM1IPw8fmQBiQ==} + engines: {node: '>= 0.10.0'} + extend-shallow@2.0.1: resolution: {integrity: sha512-zCnTtlxNoAiDc3gqY2aYAWFx7XWWiasuF2K8Me5WbN8otHKTUKBwjPtNpRs/rbUZm7KxWAaNj7P1a/p52GbVug==} engines: {node: '>=0.10.0'} @@ -6525,6 +6855,9 @@ packages: fast-levenshtein@2.0.6: resolution: {integrity: sha512-DCXu6Ifhqcks7TZKY3Hxp3y6qphY5SJZmrWMDrKcERSOXWQdMhU9Ig/PYrzyw/ul9jOIyh0N4M0tbC5hodg8dw==} + fast-safe-stringify@2.1.1: + resolution: {integrity: sha512-W+KJc2dmILlPplD/H4K9l9LcAHAfPtP6BY84uVLXQ6Evcz9Lcg33Y2z1IVblT6xdY54PXYVHEv+0Wpq8Io6zkA==} + fast-string-compare@3.0.0: resolution: {integrity: sha512-PY66/8HelapGo5nqMN17ZTKqJj1nppuS1OoC9Y0aI2jsUDlZDEYhMODTpb68wVCq+xMbaEbPGXRd7qutHzkRXA==} engines: {node: ^14.13.1 || >=16.0.0} @@ -6547,6 +6880,10 @@ packages: picomatch: optional: true + figures@3.2.0: + resolution: {integrity: sha512-yaduQFRKLXYOGgEn6AZau90j3ggSOyiqXU0F9JZfeXYhNa+Jk4X+s45A2zg5jns87GAFa34BBm2kXw4XpNcbdg==} + engines: {node: '>=8'} + figures@6.1.0: resolution: {integrity: sha512-d+l3qxjSesT4V7v2fh+QnmFnUWv9lSpjarhShNTgBOfA0ttejbQUAlHLitbjkoRiDulW0OPoQPYIGhIC8ohejg==} engines: {node: '>=18'} @@ -6569,6 +6906,10 @@ packages: resolution: {integrity: sha512-YsGpe3WHLK8ZYi4tWDg2Jy3ebRz2rXowDxnld4bkQB00cc/1Zw9AWnC0i9ztDJitivtQvaI9KaLyKrc+hBW0yg==} engines: {node: '>=8'} + finalhandler@1.3.1: + resolution: {integrity: sha512-6BN9trH7bp3qvnrRyzsBz+g3lZxTNZTbVO2EV1CS0WIcDbawYVdYvGflME/9QP0h0pYlCDBCTjYa9nZzMDpyxQ==} + engines: {node: '>= 0.8'} + find-up-simple@1.0.0: resolution: {integrity: sha512-q7Us7kcjj2VMePAa02hDAF6d+MzsdsAWEwYyOpwUtlerRBkOEPBCRZrAV4XfcSN8fHAgaD0hP7miwoay6DCprw==} engines: {node: '>=18'} @@ -6619,10 +6960,21 @@ packages: resolution: {integrity: sha512-Ld2g8rrAyMYFXBhEqMz8ZAHBi4J4uS1i/CxGMDnjyFWddMXLVcDp051DZfu+t7+ab7Wv6SMqpWmyFIj5UbfFvg==} engines: {node: '>=14'} + fork-ts-checker-webpack-plugin@9.0.2: + resolution: {integrity: sha512-Uochze2R8peoN1XqlSi/rGUkDQpRogtLFocP9+PGu68zk1BDAKXfdeCdyVZpgTk8V8WFVQXdEz426VKjXLO1Gg==} + engines: {node: '>=12.13.0', yarn: '>=1.0.0'} + peerDependencies: + typescript: '>3.6.0' + webpack: ^5.11.0 + form-data@4.0.1: resolution: {integrity: sha512-tzN8e4TX8+kkxGPK8D5u0FNmjPUjw3lwC9lSLxxoB/+GtsJG91CO8bSWy73APlgAZzZbXEYZJuxjkHH2w+Ezhw==} engines: {node: '>= 6'} + forwarded@0.2.0: + resolution: {integrity: sha512-buRG0fpBtRHSTCOASe6hD258tEubFoRLb4ZNA6NxMVHNw2gOcwHo9wyablzMzOA5z9xA9L1KNjk/Nt6MT9aYow==} + engines: {node: '>= 0.6'} + fraction.js@4.3.7: resolution: {integrity: sha512-ZsDfxO51wGAXREY55a7la9LScWpwv9RxIrYABrlvOFBlH/ShPnrtsXeuUIfXKKOVicNxQ+o8JTbJvjS4M89yew==} @@ -6654,6 +7006,9 @@ packages: resolution: {integrity: sha512-V/JgOLFCS+R6Vcq0slCuaeWEdNC3ouDlJMNIsacH2VtALiu9mV4LPrHc5cDl8k5aw6J8jwgWWpiTo5RYhmIzvg==} engines: {node: '>= 8'} + fs-monkey@1.0.6: + resolution: {integrity: sha512-b1FMfwetIKymC0eioW7mTywihSQE4oLzQn1dB6rZB5fx/3NpNEdAWeCSMB+60/AeT0TCXsxzAlcYVEFCTAksWg==} + fs.realpath@1.0.0: resolution: {integrity: sha512-OO0pH2lK6a0hZnAdau5ItzHPI6pUlvI7jMVnxUQRtw4owF2wk8lOSabtGDCTP4Ggrg2MbGnWO9X8K1t4+fGMDw==} @@ -6748,6 +7103,14 @@ packages: resolution: {integrity: sha512-XxwI8EOhVQgWp6iDL+3b0r86f4d6AX6zSU55HfB4ydCEuXLXc5FcYeOu+nnGftS4TEju/11rt4KJPTMgbfmv4A==} engines: {node: '>=10.13.0'} + glob-to-regexp@0.4.1: + resolution: {integrity: sha512-lkX1HJXwyMcprw/5YUZc2s7DrpAiHB21/V+E1rHUrVNokkvB6bqMzT0VfV6/86ZNabt1k14YOIaT7nDvOX3Iiw==} + + glob@10.4.2: + resolution: {integrity: sha512-GwMlUF6PkPo3Gk21UxkCohOv0PLcIXVtKyLlpEI28R/cO/4eNOdmLk3CMW1wROV/WR/EsZOWAfBbBOqYvs88/w==} + engines: {node: '>=16 || 14 >=14.18'} + hasBin: true + glob@10.4.5: resolution: {integrity: sha512-7Bv8RF0k6xjo7d4A/PxYLbUCfb6c+Vpd2/mB2yRDlew7Jb5hEXiCD9ibfO7wpk8i4sevK6DFny9h7EYbM3/sHg==} hasBin: true @@ -7050,6 +7413,14 @@ packages: resolution: {integrity: sha512-QQnnxNyfvmHFIsj7gkPcYymR8Jdw/o7mp5ZFihxn6h8Ci6fh3Dx4E1gPjpQEpIuPo9XVNY/ZUwh4BPMjGyL01g==} engines: {node: ^14.17.0 || ^16.13.0 || >=18.0.0} + inquirer@8.2.6: + resolution: {integrity: sha512-M1WuAmb7pn9zdFRtQYk26ZBoY043Sse0wVDdk4Bppr+JOXyQYybdtvK+l9wUibhtjdjvtoiNy8tk+EgsYIUqKg==} + engines: {node: '>=12.0.0'} + + inquirer@9.2.15: + resolution: {integrity: sha512-vI2w4zl/mDluHt9YEQ/543VTCwPKWiHzKtm9dM2V0NdFcqEexDAjUHzO1oA60HRNaVifGXXM1tRRNluLVHa0Kg==} + engines: {node: '>=18'} + internal-slot@1.0.7: resolution: {integrity: sha512-NGnrKwXzSms2qUUih/ILZ5JBqNTSa1+ZmP6flaIp6KmSElgE9qdndzS3cqjrDovwFdmwsGsLdeFgB6suw+1e9g==} engines: {node: '>= 0.4'} @@ -7062,6 +7433,10 @@ packages: resolution: {integrity: sha512-zHtQzGojZXTwZTHQqra+ETKd4Sn3vgi7uBmlPoXVWZqYvuKmtI0l/VZTjqGmJY9x88GGOaZ9+G9ES8hC4T4X8g==} engines: {node: '>= 12'} + ipaddr.js@1.9.1: + resolution: {integrity: sha512-0KI/607xoxSToH7GjN1FfSbLoU0+btTicjsQSWQlh/hZykN8KpmMf7uYwPW3R+akZ6R/w18ZlXSHBYXiYUPO3g==} + engines: {node: '>= 0.10'} + iron-webcrypto@1.2.1: resolution: {integrity: sha512-feOM6FaSr6rEABp/eDfVseKyTMDt+KGpeB35SkVn9Tyn0CqvVsY3EwI0v5i8nMHyJnzCIQf7nsy3p41TPkJZhg==} @@ -7159,6 +7534,10 @@ packages: resolution: {integrity: sha512-K55T22lfpQ63N4KEN57jZUAaAYqYHEe8veb/TycJRk9DdSCLLcovXz/mL6mOnhQaZsQGwPhuFopdQIlqGSEjiQ==} engines: {node: '>=18'} + is-interactive@1.0.0: + resolution: {integrity: sha512-2HvIEKRoqS62guEC+qBjpvRubdX910WCMuJTZ+I9yvqKU2/12eSL549HMwtabb4oupdj2sMP50k+XJfB/8JE6w==} + engines: {node: '>=8'} + is-interactive@2.0.0: resolution: {integrity: sha512-qP1vozQRI+BMOPcjFzrjXuQvdak2pHNUMZoeG2eRbiSqyvbEf/wQtEOTOX1guk6E3t36RkaqiSt8A/6YElNxLQ==} engines: {node: '>=12'} @@ -7256,6 +7635,10 @@ packages: resolution: {integrity: sha512-uZ25/bUAlUY5fR4OKT4rZQEBrzQWYV9ZJYGGsUmEJ6thodVJ1HX64ePQ6Z0qPWP+m+Uq6e9UugrE38jeYsDSMw==} engines: {node: '>= 0.4'} + is-unicode-supported@0.1.0: + resolution: {integrity: sha512-knxG2q4UC3u8stRGyAVJCOdxFmv5DZiRcdlIaAQXAbSfJya+OhopNotLQrstBhququ4ZpuKbDc/8S6mgXgPFPw==} + engines: {node: '>=10'} + is-unicode-supported@1.3.0: resolution: {integrity: sha512-43r2mRvz+8JRIKnWJ+3j8JtjRKZ6GmjzfaE/qiBJnikNnYv/6bagRJ1kUhNk8R5EX/GkobD+r+sfxCPJsiKBLQ==} engines: {node: '>=12'} @@ -7299,6 +7682,10 @@ packages: isexe@2.0.0: resolution: {integrity: sha512-RHxMLp9lnKHGHRng9QFhRCMbYAcVpn69smSGcq3f36xjgVVWThj4qqLbTLlq7Ssj8B+fIQ1EuCEGI2lKsyQeIw==} + iterare@1.2.1: + resolution: {integrity: sha512-RKYVTCjAnRthyJes037NX/IiqeidgN1xc3j1RjFfECFp28A1GVwK9nA+i0rJPaHqSZwygLzRnFlzUuHFoWWy+Q==} + engines: {node: '>=6'} + jackspeak@3.4.3: resolution: {integrity: sha512-OGlZQpz2yfahA/Rd1Y8Cd9SIEsqvXkLVoSw/cgwhnhFMDbsQFeZYoJJ7bIZBS9BcamUW96asq/npPWugM+RQBw==} @@ -7311,6 +7698,10 @@ packages: engines: {node: '>=10'} hasBin: true + jest-worker@27.5.1: + resolution: {integrity: sha512-7vuh85V5cdDofPyxn58nrPjBktZo0u9x1g8WtjQol+jZDaE+fhN+cIvTj11GndBnMnyfrUOG1sZQxCdjKh+DKg==} + engines: {node: '>= 10.13.0'} + jiti@1.21.6: resolution: {integrity: sha512-2yTgeWTWzMWkHu6Jp9NKgePDaYHbntiwvYuuJLbbN9vl7DC9DvXKOB2BC3ZZ92D3cvV/aflH0osDfwpHepQ53w==} hasBin: true @@ -7388,6 +7779,12 @@ packages: resolution: {integrity: sha512-WYDyuc/uFcGp6YtM2H0uKmUwieOuzeE/5YocFJLnLfclZ4inf3mRn8ZVy1s7Hxji7Jxm6Ss8gqpexD/GlKoGgg==} engines: {node: ^12.22.0 || ^14.17.0 || >=16.0.0} + jsonc-parser@3.2.1: + resolution: {integrity: sha512-AilxAyFOAcK5wA1+LeaySVBrHsGQvUFCDWXKpZjzaL0PqW+xfBOttn8GNtWKFWqneyMZj41MWF9Kl6iPWLwgOA==} + + jsonc-parser@3.3.1: + resolution: {integrity: sha512-HUgH65KyejrUFPvHFPbqOY0rsFip3Bo5wb4ngvdi1EpCYWUQDC5V+Y7mZws+DLkr4M//zQJoanu1SP+87Dv1oQ==} + jsonfile@4.0.0: resolution: {integrity: sha512-m6F1R3z8jjlf2imQHS2Qez5sjKWQzbuuhuJ/FKYFRZvPE3PuHcSMVZzfsLhGVOkfd20obL5SWEBew5ShlquNxg==} @@ -7481,6 +7878,10 @@ packages: resolution: {integrity: sha512-iyAZCeyD+c1gPyE9qpFu8af0Y+MRtmKOncdGoA2S5EY8iFq99dmmvkNnHiWo+pj0s7yH7l3KPIgee77tKpXPWQ==} engines: {node: '>=18.0.0'} + loader-runner@4.3.0: + resolution: {integrity: sha512-3R/1M+yS3j5ou80Me59j7F9IMs4PXs3VqRrm0TU3AbKPxlmpoY1TNscJV/oGJXo8qCatFGTfDbY6W6ipGOYXfg==} + engines: {node: '>=6.11.5'} + local-pkg@0.5.0: resolution: {integrity: sha512-ok6z3qlYyCDS4ZEU27HaU6x/xZa9Whf8jD4ptH5UZTQYZVYeb9bnZ3ojVhiJNLiXK1Hfc0GNbLXcmZ5plLDDBg==} engines: {node: '>=14'} @@ -7579,6 +7980,10 @@ packages: lodash@4.17.21: resolution: {integrity: sha512-v2kDEe57lecTulaDIuNTPy3Ry4gLGJ6Z1O3vE1krgXZNrsQ+LFTGHVxVjcXPs17LhbZVGedAJv8XZ1tvj5FvSg==} + log-symbols@4.1.0: + resolution: {integrity: sha512-8XPvpAA8uyhfteu8pIvQxpJZ7SYYdpUivZpGy6sFsBuKRY/7rQGavedeB8aK+Zkyq6upMFVL/9AW6vOYzfRyLg==} + engines: {node: '>=10'} + log-symbols@6.0.0: resolution: {integrity: sha512-i24m8rpwhmPIS4zscNzK6MSEhk0DUWa/8iYQWxhffV8jkI4Phvs3F+quL5xvS0gdQR0FyTCMMH33Y78dDTzzIw==} engines: {node: '>=18'} @@ -7625,6 +8030,10 @@ packages: magic-string@0.30.12: resolution: {integrity: sha512-Ea8I3sQMVXr8JhN4z+H/d8zwo+tYDgHE9+5G4Wnrwhs0gaK9fXTKx0Tw5Xwsd/bCPTTZNRAdpyzvoeORe9LYpw==} + magic-string@0.30.8: + resolution: {integrity: sha512-ISQTe55T2ao7XtlAStud6qwYPZjE4GK1S/BeVPus4jrq6JuOnQ00YKQC581RWhR122W7msZV263KzVeLoqidyQ==} + engines: {node: '>=12'} + make-dir@2.1.0: resolution: {integrity: sha512-LS9X+dc8KLxXCb8dni79fLIIUA5VyZoyjSMCwTluaXA0o27cCK0bhXkpgw+sTXVpPy/lSO57ilRixqk0vDmtRA==} engines: {node: '>=6'} @@ -7658,9 +8067,17 @@ packages: mdn-data@2.11.1: resolution: {integrity: sha512-Hdx3wmyqPFrhd6YHVuSkUK2eIGAcxR0xlndcgZqjA68yMJTbfXrjJwbgsBOsNjI7LnBIVUQnmyMVSdi/ob0GpQ==} + media-typer@0.3.0: + resolution: {integrity: sha512-dq+qelQ9akHpcOl/gUVRTxVIOkAJ1wR3QAvb4RsVjS8oVoFjDGTc679wJYmUmknUF5HwMLOgb5O+a3KxfWapPQ==} + engines: {node: '>= 0.6'} + medium-zoom@1.1.0: resolution: {integrity: sha512-ewyDsp7k4InCUp3jRmwHBRFGyjBimKps/AJLjRSox+2q/2H4p/PNpQf+pwONWlJiOudkBXtbdmVbFjqyybfTmQ==} + memfs@3.5.3: + resolution: {integrity: sha512-UERzLsxzllchadvbPs5aolHh65ISpKpM+ccLbOJ8/vvpBKmAWf+la7dXFy7Mr0ySHbdHrFv5kGFCUHHe6GFEmw==} + engines: {node: '>= 4.0.0'} + memoize-one@6.0.0: resolution: {integrity: sha512-rkpe71W0N0c0Xz6QD0eJETuWAJGnJ9afsl1srmwPrI+yBCkge5EycXXbYRyvL29zZVUWQCY7InPRCv3GDXuZNw==} @@ -7672,6 +8089,9 @@ packages: resolution: {integrity: sha512-pxQJQzB6djGPXh08dacEloMFopsOqGVRKFPYvPOt9XDZ1HasbgDZA74CJGreSU4G3Ak7EFJGoiH2auq+yXISgA==} engines: {node: '>=18'} + merge-descriptors@1.0.3: + resolution: {integrity: sha512-gaNvAS7TZ897/rVaZ0nMtAyxNyi/pdbjbAwUpFQpN70GqnVfOiXpeUUMKRBmzXaSQ8DdTX4/0ms62r2K+hE6mQ==} + merge-stream@2.0.0: resolution: {integrity: sha512-abv/qOcuPfk3URPfDzmZU1LKmuw8kT+0nIHvKrKgFrwifol/doWcdA4ZqsWQ8ENrFKkd67Mfpo/LovbIUsbt3w==} @@ -7679,6 +8099,10 @@ packages: resolution: {integrity: sha512-8q7VEgMJW4J8tcfVPy8g09NcQwZdbwFEqhe/WZkoIzjn/3TGDwtOCYtXGxA3O8tPzpczCCDgv+P2P5y00ZJOOg==} engines: {node: '>= 8'} + methods@1.1.2: + resolution: {integrity: sha512-iclAHeNqNm68zFtnZ0e+1L2yUIdvzNoauKU4WBA3VvH/vPFieF7qfRlwUZU+DA9P9bPXIS90ulxoUoCH23sV2w==} + engines: {node: '>= 0.6'} + micromark-util-character@2.1.0: resolution: {integrity: sha512-KvOVV+X1yLBfs9dCBSopq/+G1PcgT3lAK07mC4BzXi5E7ahzMAF8oIupDDJ6mievI6F+lAATkbQQlQixJfT3aQ==} @@ -7721,6 +8145,10 @@ packages: engines: {node: '>=16'} hasBin: true + mimic-fn@2.1.0: + resolution: {integrity: sha512-OqbOk5oEQeAZ8WXWydlu9HJjz9WVdEIvamMCcXmuqUYjTknH/sqsWvhQ3vgwKFRR1HpjvNBKQ37nbJgYzGqGcg==} + engines: {node: '>=6'} + mimic-fn@4.0.0: resolution: {integrity: sha512-vqiC06CuhBTUdZH+RYl8sFrL096vA45Ok5ISO6sE/Mr1jRbGH4Csnhi8f3wKVl7x8mO4Au7Ir9D3Oyv1VYMFJw==} engines: {node: '>=12'} @@ -7804,6 +8232,10 @@ packages: mitt@3.0.1: resolution: {integrity: sha512-vKivATfr97l2/QBCYAkXYDbrIWPM2IIKEl7YPhjCvKlG3kE2gm+uBo6nEXK3M5/Ffh/FLpKExzOQ3JJoJGFKBw==} + mkdirp@0.5.6: + resolution: {integrity: sha512-FP+p8RB8OWpF3YZBCrP5gtADmtXApB5AMLn+vdyA+PyxCjrCs00mjyUozssO33cwDeT3wNGdLxJ5M//YqtHAJw==} + hasBin: true + mkdirp@1.0.4: resolution: {integrity: sha512-vVqVZQyf3WLx2Shd0qJ9xuvqgAyKPLAiqITEtqW0oIUjzo3PePDd6fW9iFz30ef7Ysp/oiWqbhszeGWW2T6Gzw==} engines: {node: '>=10'} @@ -7844,10 +8276,21 @@ packages: muggle-string@0.4.1: resolution: {integrity: sha512-VNTrAak/KhO2i8dqqnqnAHOa3cYBwXEZe9h+D5h/1ZqFSTEFHdM65lR7RoIqq3tBBYavsOXV84NoHXZ0AkPyqQ==} + multer@1.4.4-lts.1: + resolution: {integrity: sha512-WeSGziVj6+Z2/MwQo3GvqzgR+9Uc+qt8SwHKh3gvNPiISKfsMfG4SvCOFYlxxgkXt7yIV2i1yczehm0EOKIxIg==} + engines: {node: '>= 6.0.0'} + multimatch@5.0.0: resolution: {integrity: sha512-ypMKuglUrZUD99Tk2bUQ+xNQj43lPEfAeX2o9cTteAmShXy2VHDJpuwu1o0xqoKCt9jLVAvwyFKdLTPXKAfJyA==} engines: {node: '>=10'} + mute-stream@0.0.8: + resolution: {integrity: sha512-nnbWWOkoWyUsTjKrhgD0dcz22mdkSnpYqbEjIm2nhwhuxlSkpywJmBo8h0ZqJdkp73mb90SssHkN4rsRaBAfAA==} + + mute-stream@1.0.0: + resolution: {integrity: sha512-avsJQhyd+680gKXyG/sQc0nXaC6rBkPOfyHYcFb9+hdkqQkR9bdnkJ0AMZhke0oesPqIO+mFFJ+IdBc7mst4IA==} + engines: {node: ^14.17.0 || ^16.13.0 || >=18.0.0} + mz@2.7.0: resolution: {integrity: sha512-z81GNO7nnYMEhrGh9LeymoE4+Yr0Wn5McHIZMK5cfQCl+NDX08sCZgUc9/6MHni9IWuFLm1Z3HTCXu2z9fN62Q==} @@ -7880,6 +8323,13 @@ packages: engines: {node: '>= 4.4.x'} hasBin: true + negotiator@0.6.3: + resolution: {integrity: sha512-+EUsqGPLsM+j/zdChZjsnX51g4XrHFOIXwfnCVPGlQk/k5giakcKsuxCObBRu6DSm9opw/O6slWbJdghQM4bBg==} + engines: {node: '>= 0.6'} + + neo-async@2.6.2: + resolution: {integrity: sha512-Yd3UES5mWCSqR+qNT93S3UoYUkqAZ9lLg8a7g9rimsWmYGK8cVToA4/sF3RrshdyV3sAGMXVUmpMYOw+dLpOuw==} + nitropack@2.9.7: resolution: {integrity: sha512-aKXvtNrWkOCMsQbsk4A0qQdBjrJ1ZcvwlTQevI/LAgLWLYc5L7Q/YiYxGLal4ITyNSlzir1Cm1D2ZxnYhmpMEw==} engines: {node: ^16.11.0 || >=17.0.0} @@ -7893,12 +8343,18 @@ packages: no-case@3.0.4: resolution: {integrity: sha512-fgAN3jGAh+RoxUGZHTSOLJIqUc2wmoBwGR4tbpNAKmmovFoWq0OdRkb0VkldReO2a2iBT/OEulG9XSUc10r3zg==} + node-abort-controller@3.1.1: + resolution: {integrity: sha512-AGK2yQKIjRuqnc6VkX2Xj5d+QW8xZ87pa1UK6yA6ouUyuxfHuMP6umE5QK7UmTeOAymo+Zx1Fxiuw9rVx8taHQ==} + node-addon-api@7.1.1: resolution: {integrity: sha512-5m3bsyrjFWE1xf7nz7YXdN4udnVtXK6/Yfgn5qnahL6bCkf2yKt4k3nuTKAtT4r3IG8JNR2ncsIMdZuAzJjHQQ==} node-cleanup@2.1.2: resolution: {integrity: sha512-qN8v/s2PAJwGUtr1/hYTpNKlD6Y9rc4p8KSmJXyGdYGZsDGKXrGThikLFP9OCHFeLeEpQzPwiAtdIvBLqm//Hw==} + node-emoji@1.11.0: + resolution: {integrity: sha512-wo2DpQkQp7Sjm2A0cq+sN7EHKO6Sl0ctXeBdFZrL9T9+UywORbufTcTZxom8YqpLQt/FqNMUkOpkZrJVYSKD3A==} + node-fetch-native@1.6.4: resolution: {integrity: sha512-IhOigYzAKHd244OC0JIMIUrjzctirCmPkaIfhDeGcEETWof5zKYUW7e7MYvChGWh/4CJeXEgsRyGzuF334rOOQ==} @@ -8018,6 +8474,10 @@ packages: once@1.4.0: resolution: {integrity: sha512-lNaJgI+2Q5URQBkccEKHTQOPaXdUxnZZElQTZY0MFUAuaEqe1E+Nyvgdz/aIyNi6Z9MzO5dv1H8n58/GELp3+w==} + onetime@5.1.2: + resolution: {integrity: sha512-kbpaSSGJTWdAY5KPVeMOKXSrPtr8C8C7wodJbcsd51jRnmD+GZu8Y0VoU6Dm5Z4vWr0Ig/1NKuWRKf7j5aaYSg==} + engines: {node: '>=6'} + onetime@6.0.0: resolution: {integrity: sha512-1FlR+gjXK7X+AsAHso35MnyN5KqGwJRi/31ft6x0M194ht7S+rWAvd7PHss9xSKMzE0asv1pyIHaJYq+BbacAQ==} engines: {node: '>=12'} @@ -8045,6 +8505,10 @@ packages: resolution: {integrity: sha512-6IpQ7mKUxRcZNLIObR0hz7lxsapSSIYNZJwXPGeF0mTVqGKFIXj1DQcMoT22S3ROcLyY/rz0PWaWZ9ayWmad9g==} engines: {node: '>= 0.8.0'} + ora@5.4.1: + resolution: {integrity: sha512-5b6Y85tPxZZ7QytO+BQzysW31HJku27cRIlkbAXaNx+BdcVi+LlRFmVXzeF6a7JCwJpyw5c4b+YSVImQIrBpuQ==} + engines: {node: '>=10'} + ora@8.1.0: resolution: {integrity: sha512-GQEkNkH/GHOhPFXcqZs3IDahXEQcQxsSjEkK4KvEEST4t7eNzoMjxTzef+EZ+JluDEV+Raoi3WQ2CflnRdSVnQ==} engines: {node: '>=18'} @@ -8187,6 +8651,12 @@ packages: resolution: {integrity: sha512-ypGJsmGtdXUOeM5u93TyeIEfEhM6s+ljAhrk5vAvSx8uyY/02OvrZnA0YNGUrPXfpJMgI1ODd3nwz8Npx4O4cg==} engines: {node: 20 || >=22} + path-to-regexp@0.1.10: + resolution: {integrity: sha512-7lf7qcQidTku0Gu3YDPc8DJ1q7OOucfa/BSsIwjuh56VU7katFvuM8hULfkwB3Fns/rsVF7PwPKVw1sl5KQS9w==} + + path-to-regexp@3.3.0: + resolution: {integrity: sha512-qyCH421YQPS2WFDxDjftfc1ZR5WKQzVzqsp4n9M2kQhVOo/ByahFoUNJfl58kOcEGfQ//7weFTDhm+ss8Ecxgw==} + path-type@4.0.0: resolution: {integrity: sha512-gDKb8aZMDeD/tZWs9P6+q0J9Mwkdl6xMV8TjnGP3qJVJ06bdMgkbBlLU8IdfOsIsFz2BW1rNVT3XuNEl8zPAvw==} engines: {node: '>=8'} @@ -8215,6 +8685,10 @@ packages: resolution: {integrity: sha512-JU3teHTNjmE2VCGFzuY8EXzCDVwEqB2a8fsIvwaStHhAWJEeVd1o1QD80CU6+ZdEXXSLbSsuLwJjkCBWqRQUVA==} engines: {node: '>=8.6'} + picomatch@4.0.1: + resolution: {integrity: sha512-xUXwsxNjwTQ8K3GnT4pCJm+xq3RUPQbmkYJTP5aFIfNIvbcc/4MUxgBaaRSZJ6yGJZiGSyYlM6MzwTsRk8SYCg==} + engines: {node: '>=12'} + picomatch@4.0.2: resolution: {integrity: sha512-M7BAV6Rlcy5u+m6oPhAPFgJTzAioX/6B0DxyvDlo9l8+T3nLKbrczg2WLUyzd45L8RqfUMyGPzekbMvX2Ldkwg==} engines: {node: '>=12'} @@ -8814,6 +9288,10 @@ packages: proto-list@1.2.4: resolution: {integrity: sha512-vtK/94akxsTMhe0/cbfpR+syPuszcuwhqVjJq26CuNDgFGj682oRBXOP5MJpv2r7JtE8MsiepGIqvvOTBwn2vA==} + proxy-addr@2.0.7: + resolution: {integrity: sha512-llQsMLSUDUPT44jdrU/O37qlnifitDP+ZwrmmZcoSKyLKvtZxpyV0n2/bD/N4tBAAZ/gJEdZU7KMraoK1+XYAg==} + engines: {node: '>= 0.10'} + proxy-from-env@1.1.0: resolution: {integrity: sha512-D+zkORCbA9f1tdWRK0RaCR3GPv50cMxcrz4X8k5LTSUD1Dkw47mKJEZQNunItRTkWwgtaUSo1RVFRIG9ZXiFYg==} @@ -8841,6 +9319,10 @@ packages: engines: {node: '>=10.13.0'} hasBin: true + qs@6.13.0: + resolution: {integrity: sha512-+38qI9SOr8tfZ4QmJNplMUxqjbe7LKvvZgWdExBOmd+egZTtjLB67Gu0HRX3u/XOq7UU2Nx6nsjvS16Z9uwfpg==} + engines: {node: '>=0.6'} + queue-microtask@1.2.3: resolution: {integrity: sha512-NuaNSa6flKT5JaSYQzJok04JzTL1CA6aGhv5rfLW3PgqA+M2ChpZQnAC8h8i4ZFkBS8X5RqkDBHA7r4hej3K9A==} @@ -8862,6 +9344,10 @@ packages: resolution: {integrity: sha512-Hrgsx+orqoygnmhFbKaHE6c296J+HTAQXoxEF6gNupROmmGJRoyzfG3ccAveqCBrwr/2yxQ5BVd/GTl5agOwSg==} engines: {node: '>= 0.6'} + raw-body@2.5.2: + resolution: {integrity: sha512-8zGqypfENjCIqGhgXToC8aB2r7YrBX+AQAfIPs/Mlk+BtPTztOvTS01NRW/3Eh60J+a48lt8qsCzirQ6loCVfA==} + engines: {node: '>= 0.8'} + rc9@2.1.2: resolution: {integrity: sha512-btXCnMmRIBINM2LDZoEmOogIZU7Qe7zn4BpomSKZ/ykbLObuBdvG+mFq11DL6fjH1DRwHhrlgtYWG96bJiC7Cg==} @@ -8922,6 +9408,9 @@ packages: resolution: {integrity: sha512-J8rn6v4DBb2nnFqkqwy6/NnTYMcgLA+sLr0iIO41qpv0n+ngb7ksag2tMRl0inb1bbO/esUwzW1vbJi7K0sI0g==} engines: {node: ^12.0.0 || ^14.0.0 || >=16.0.0} + reflect-metadata@0.2.2: + resolution: {integrity: sha512-urBwgfrvVP/eAyXx4hluJivBKzuEbSQs9rKWCrCkbSxNv8mxPcUZKeuoF3Uy4mJl3Lwprp6yy5/39VWigZ4K6Q==} + regenerate-unicode-properties@10.2.0: resolution: {integrity: sha512-DqHn3DwbmmPVzeKj9woBadqmXxLvQoQIwu7nopMc72ztvxVmVk2SBhSnx67zuye5TP+lJsb/TBQsjLKhnDf3MA==} engines: {node: '>=4'} @@ -9024,6 +9513,10 @@ packages: resolution: {integrity: sha512-oKWePCxqpd6FlLvGV1VU0x7bkPmmCNolxzjMf4NczoDnQcIWrAF+cPtZn5i6n+RfD2d9i0tzpKnG6Yk168yIyw==} hasBin: true + restore-cursor@3.1.0: + resolution: {integrity: sha512-l+sSefzHpj5qimhFSE5a8nufZYAM3sBSVMAPtYkmC+4EH2anSGaEMXSD0izRQbu9nfyQ9y5JrVmp7E8oZrUjvA==} + engines: {node: '>=8'} + restore-cursor@5.1.0: resolution: {integrity: sha512-oMA2dcrw6u0YfxJQXm342bFKX/E4sG9rbTzO9ptUcR/e8A33cHuvStiYOwH7fszkZlZ1z/ta9AAoPk2F4qIOHA==} engines: {node: '>=18'} @@ -9089,9 +9582,20 @@ packages: resolution: {integrity: sha512-9by4Ij99JUr/MCFBUkDKLWK3G9HVXmabKz9U5MlIAIuvuzkiOicRYs8XJLxX+xahD+mLiiCYDqF9dKAgtzKP1A==} engines: {node: '>=18'} + run-async@2.4.1: + resolution: {integrity: sha512-tvVnVv01b8c1RrA6Ep7JkStj85Guv/YrMcwqYQnwjsAS2cTmmPGBBjAjpCW7RrSodNSoE2/qg9O4bceNvUuDgQ==} + engines: {node: '>=0.12.0'} + + run-async@3.0.0: + resolution: {integrity: sha512-540WwVDOMxA6dN6We19EcT9sc3hkXPw5mzRNGM3FkdN/vtE9NFvj5lFAPNwUDmJjXidm3v7TC1cTE7t17Ulm1Q==} + engines: {node: '>=0.12.0'} + run-parallel@1.2.0: resolution: {integrity: sha512-5l4VyZR86LZ/lDxZTR6jqL8AFE2S0IFLMP26AbjsLVADxHdhB/c0GUsH+y39UfCi3dzz8OlQuPmnaJOMoDHQBA==} + rxjs@7.8.1: + resolution: {integrity: sha512-AA3TVj+0A2iuIoQkWEK/tqFjBq2j+6PO6Y0zJcvzLAFhEFIO3HL0vls9hWLncZbAAbK0mar7oZ4V079I/qPMxg==} + sade@1.8.1: resolution: {integrity: sha512-xal3CZX1Xlo/k4ApwCFrHVACi9fBqJ7V+mwhBsuf/1IOKbBy098Fex+Wa/5QMubw09pSZ/u8EY8PWgevJsXp1A==} engines: {node: '>=6'} @@ -9121,6 +9625,10 @@ packages: sax@1.4.1: resolution: {integrity: sha512-+aWOz7yVScEGoKNd4PA10LZ8sk0A/z5+nXQG5giUO5rprX9jgYsTdov9qCchZiPIZezbZH+jRut8nPodFAX4Jg==} + schema-utils@3.3.0: + resolution: {integrity: sha512-pN/yOAvcC+5rQ5nERGuwrjLlYvLTbCibnZ1I7B1LaiAz9BRBlE9GMgE/eqV30P7aJQUf7Ddimy/RsbYO/GrVGg==} + engines: {node: '>= 10.13.0'} + scroll-into-view-if-needed@2.2.31: resolution: {integrity: sha512-dGCXy99wZQivjmjIqihaBQNjryrz5rueJY7eHfTdyWEiR4ttYpsajb14rn9s5d4DY4EcY6+4+U/maARBXJedkA==} @@ -9368,6 +9876,10 @@ packages: resolution: {integrity: sha512-UhDfHmA92YAlNnCfhmq0VeNL5bDbiZGg7sZ2IvPsXubGkiNa9EC+tUTsjBRsYUAz87btI6/1wf4XoVvQ3uRnmQ==} engines: {node: '>=18'} + streamsearch@1.1.0: + resolution: {integrity: sha512-Mcc5wHehp9aXz1ax6bZUyY5afg9u2rv5cqQI3mRrYkGC8rW2hM02jWuwjtL++LS5qinSyhj2QfLyNsuc+VsExg==} + engines: {node: '>=10.0.0'} + streamx@2.20.1: resolution: {integrity: sha512-uTa0mU6WUC65iUvzKH4X9hEdvSW7rbPxPtwfWiLMSj3qTdQbAiUboZTxauKfpFuGIGa1C2BYijZ7wgdUXICJhA==} @@ -9585,6 +10097,10 @@ packages: engines: {node: '>=14.0.0'} hasBin: true + symbol-observable@4.0.0: + resolution: {integrity: sha512-b19dMThMV4HVFynSAM1++gBHAbk2Tc/osgLIBZMKsyqh34jb2e8Os7T6ZW/Bt3pJFdBTd2JwAnAAEQV7rSNvcQ==} + engines: {node: '>=0.10'} + synckit@0.6.2: resolution: {integrity: sha512-Vhf+bUa//YSTYKseDiiEuQmhGCoIF3CVBhunm3r/DQnYiGT4JssmnKQc44BIyOZRK2pKjXXAgbhfmbeoC9CJpA==} engines: {node: '>=12.20'} @@ -9640,6 +10156,22 @@ packages: resolution: {integrity: sha512-wK0Ri4fOGjv/XPy8SBHZChl8CM7uMc5VML7SqiQ0zG7+J5Vr+RMQDoHa2CNT6KHUnTGIXH34UDMkPzAUyapBZg==} engines: {node: '>=8'} + terser-webpack-plugin@5.3.10: + resolution: {integrity: sha512-BKFPWlPDndPs+NGGCr1U59t0XScL5317Y0UReNrHaw9/FwhPENlq6bfgs+4yPfyP51vqC1bQ4rp1EfXW5ZSH9w==} + engines: {node: '>= 10.13.0'} + peerDependencies: + '@swc/core': '*' + esbuild: '*' + uglify-js: '*' + webpack: ^5.1.0 + peerDependenciesMeta: + '@swc/core': + optional: true + esbuild: + optional: true + uglify-js: + optional: true + terser@5.36.0: resolution: {integrity: sha512-IYV9eNMuFAV4THUspIRXkLakHnV6XO7FEdtKjf/mDyrnqUg9LnlOn6/RwRvM9SZjR4GUq8Nk8zj67FzVARr74w==} engines: {node: '>=10'} @@ -9720,6 +10252,10 @@ packages: tr46@1.0.1: resolution: {integrity: sha512-dTpowEjclQ7Kgx5SdBkqRzVhERQXov8/l9Ft9dVM9fmg0W0KQSVaXX9T4i6twCPNtYiZM53lpSSUAwJbFPOHxA==} + tree-kill@1.2.2: + resolution: {integrity: sha512-L0Orpi8qGpRG//Nd+H90vFB+3iHnue1zSSGmNOOCh1GLJ7rUKVwV2HvijphGQS2UmhUZewS9VgvxYIdgr+fG1A==} + hasBin: true + treemate@0.3.11: resolution: {integrity: sha512-M8RGFoKtZ8dF+iwJfAJTOH/SM4KluKOKRJpjCMhI8bG3qB74zrFoArKZ62ll0Fr3mqkMJiQOmWYkdYgDeITYQg==} @@ -9735,9 +10271,20 @@ packages: ts-interface-checker@0.1.13: resolution: {integrity: sha512-Y/arvbn+rrz3JCKl9C4kVNfTfSm2/mEp5FSz5EsZSANGPSlQrpRI5M4PKF+mJnE52jOO90PnPSc3Ur3bTQw0gA==} + tsconfig-paths-webpack-plugin@4.1.0: + resolution: {integrity: sha512-xWFISjviPydmtmgeUAuXp4N1fky+VCtfhOkDUFIv5ea7p4wuTomI4QTrXvFBX2S4jZsmyTSrStQl+E+4w+RzxA==} + engines: {node: '>=10.13.0'} + + tsconfig-paths@4.2.0: + resolution: {integrity: sha512-NoZ4roiN7LnbKn9QqE1amc9DJfzvZXxF4xDavcOWt1BPkdx+m+0gJuPM+S0vCe7zTJMYUP0R8pO2XMr+Y8oLIg==} + engines: {node: '>=6'} + tslib@2.3.0: resolution: {integrity: sha512-N82ooyxVNm6h1riLCoyS9e3fuJ3AMG2zIZs2Gd1ATcSFjSA23Q0fzjjZeh0jbJvWVDZ0cJT8yaNNaaXHzueNjg==} + tslib@2.7.0: + resolution: {integrity: sha512-gLXCKdN1/j47AiHiOkJN69hJmcbGTHI0ImLmbYLHykhgeN0jVGola9yVjFgzCUklsZQMW55o+dW7IXv3RCXDzA==} + tslib@2.8.0: resolution: {integrity: sha512-jWVzBLplnCmoaTr13V9dYbiQ99wvZRd0vNWaDRg+aVYRcjDF3nDksxFDE/+fkXnKhpnUUkmx5pK/v8mCtLVqZA==} @@ -9787,6 +10334,10 @@ packages: resolution: {integrity: sha512-Ne+eE4r0/iWnpAxD852z3A+N0Bt5RN//NjJwRd2VFHEmrywxf5vsZlh4R6lixl6B+wz/8d+maTSAkN1FIkI3LQ==} engines: {node: '>=10'} + type-fest@0.21.3: + resolution: {integrity: sha512-t0rzBq87m3fVcduHDUFhKmyyX+9eo6WQjZvf51Ea/M0Q7+T374Jp1aUiyUl0GKxp8M/OETVHSDvmkyPgvX+X2w==} + engines: {node: '>=10'} + type-fest@0.6.0: resolution: {integrity: sha512-q+MB8nYR1KDLrgr4G5yemftpMC7/QLqVndBmEEdqzmNj5dcFOO4Oo8qlwZE3ULT3+Zim1F8Kq4cBnikNhlCMlg==} engines: {node: '>=8'} @@ -9803,6 +10354,10 @@ packages: resolution: {integrity: sha512-yOGpmOAL7CkKe/91I5O3gPICmJNLJ1G4zFYVAsRHg7M64biSnPtRj0WNQt++bRkjYOqjWXrhnUw1utzmVErAdg==} engines: {node: '>=16'} + type-is@1.6.18: + resolution: {integrity: sha512-TkRKr9sUTxEH8MdfuCSP7VizJyzRNMjj2J2do2Jr3Kym598JVdEksuzPQCnlFPW4ky9Q+iA+ma9BGm06XQBy8g==} + engines: {node: '>= 0.6'} + typed-array-buffer@1.0.2: resolution: {integrity: sha512-gEymJYKZtKXzzBzM4jqa9w6Q1Jjm7x2d+sh19AdsD4wqnMPDYyvwpsIc2Q/835kHuo3BEQ7CjelGhfTsoBb2MQ==} engines: {node: '>= 0.4'} @@ -9819,6 +10374,14 @@ packages: resolution: {integrity: sha512-/OxDN6OtAk5KBpGb28T+HZc2M+ADtvRxXrKKbUwtsLgdoxgX13hyy7ek6bFRl5+aBs2yZzB0c4CnQfAtVypW/g==} engines: {node: '>= 0.4'} + typedarray@0.0.6: + resolution: {integrity: sha512-/aCDEGatGvZ2BIk+HmLf4ifCJFwvKFNb9/JeZPMulfgFracn9QFcAf5GO8B/mweUjSoblS5In0cWhqpfs/5PQA==} + + typescript@5.3.3: + resolution: {integrity: sha512-pXWcraxM0uxAS+tN0AG/BF2TyqmHO014Z070UsJ+pFvYuRSq8KH8DmWpnbXe0pEPDHXZV3FcAbJkijJ5oNEnWw==} + engines: {node: '>=14.17'} + hasBin: true + typescript@5.4.2: resolution: {integrity: sha512-+2/g0Fds1ERlP6JsakQQDXjZdZMM+rqpamFZJEKh4kwTIn3iDkgKtby0CeNd5ATNZ4Ry1ax15TMx0W2V+miizQ==} engines: {node: '>=14.17'} @@ -9832,6 +10395,10 @@ packages: ufo@1.5.4: resolution: {integrity: sha512-UsUk3byDzKd04EyoZ7U4DOlxQaD14JUKQl6/P7wiX4FNvUfm3XL246n9W5AmqwW5RSFJ27NAuM0iLscAOYUiGQ==} + uid@2.0.2: + resolution: {integrity: sha512-u3xV3X7uzvi5b1MncmZo3i2Aw222Zk1keqLA1YkHldREkAhAqi65wuPfe7lHx8H/Wzy+8CE7S7uS3jekIM5s8g==} + engines: {node: '>=8'} + unbox-primitive@1.0.2: resolution: {integrity: sha512-61pPlCD9h51VoreyJ0BReideM3MDKMKnh6+V9L08331ipq6Q8OFXZYiqP6n/tbHx4s5I9uRhcye6BrbkizkBDw==} @@ -9924,6 +10491,10 @@ packages: resolution: {integrity: sha512-gptHNQghINnc/vTGIk0SOFGFNXw7JVrlRUtConJRlvaw6DuX0wO5Jeko9sWrMBhh+PsYAZ7oXAiOnf/UKogyiw==} engines: {node: '>= 10.0.0'} + unpipe@1.0.0: + resolution: {integrity: sha512-pjy2bYhSsufwWlKwPc+l3cN7+wuJlK6uz0YdJEOlQDbl6jo/YlPi4mb8agUkVC8BF7V8NuzeyPNqRksA3hztKQ==} + engines: {node: '>= 0.8'} + unplugin-element-plus@0.8.0: resolution: {integrity: sha512-jByUGY3FG2B8RJKFryqxx4eNtSTj+Hjlo8edcOdJymewndDQjThZ1pRUQHRjQsbKhTV2jEctJV7t7RJ405UL4g==} engines: {node: '>=14.19.0'} @@ -10018,9 +10589,17 @@ packages: util-deprecate@1.0.2: resolution: {integrity: sha512-EPD5q1uXyFxJpCrLnCc1nHnq3gOa6DZBocAIiI2TaSCA7VCJ1UJDMagCzIkXNsUYfD1daK//LTEQ8xiIbrHtcw==} + utils-merge@1.0.1: + resolution: {integrity: sha512-pMZTvIkT1d+TFGvDOqodOclx0QWkkgi6Tdoa8gC8ffGAAqz9pzPTZWAybbsHHoED/ztMtkv/VoYTYyShUn81hA==} + engines: {node: '>= 0.4.0'} + validate-npm-package-license@3.0.4: resolution: {integrity: sha512-DpKm2Ui/xN7/HQKCtpZxoRWBhZ9Z0kqtygG8XCgNQ8ZlDnxuQmWhj566j8fN4Cu3/JmbhsDo7fcAJq4s9h27Ew==} + vary@1.1.2: + resolution: {integrity: sha512-BNGbWLfd0eUPabhkXUVm0j8uuvREyTh5ovRa/dyow/BqAbZJyC+5fU+IzQOzmAKzYqYRAISoRhdQr3eIZ/PXqg==} + engines: {node: '>= 0.8'} + vdirs@0.1.8: resolution: {integrity: sha512-H9V1zGRLQZg9b+GdMk8MXDN2Lva0zx72MPahDKc30v+DtwKjfyOSXWRIX4t2mhDubM1H09gPhWeth/BJWPHGUw==} peerDependencies: @@ -10085,6 +10664,15 @@ packages: peerDependencies: vite: '*' + vite-plugin-node@4.0.0: + resolution: {integrity: sha512-KwINBvYBjNqYml/dSmBWJo2rSr+qrRbqbuuG5oNhu7+R3R5Rh9fibpslvr3LUwOjjkreIb9VId/37Rf7KL96qg==} + peerDependencies: + '@swc/core': ^1.7.26 + vite: ^5.0.0 + peerDependenciesMeta: + '@swc/core': + optional: true + vite-plugin-pwa@0.20.5: resolution: {integrity: sha512-aweuI/6G6n4C5Inn0vwHumElU/UEpNuO+9iZzwPZGTCH87TeZ6YFMrEY6ZUBQdIHHlhTsbMDryFARcSuOdsz9Q==} engines: {node: '>=16.0.0'} @@ -10286,10 +10874,17 @@ packages: warning@4.0.3: resolution: {integrity: sha512-rpJyN222KWIvHJ/F53XSZv0Zl/accqHR8et1kpaMTD/fLCRxtV8iX8czMzY7sVZupTI3zcUTg8eycS2kNF9l6w==} + watchpack@2.4.2: + resolution: {integrity: sha512-TnbFSbcOCcDgjZ4piURLCbJ3nJhznVh9kw6F6iokjiFPl8ONxe9A6nMDVXDiNbrSfLILs6vB07F7wLBrwPYzJw==} + engines: {node: '>=10.13.0'} + watermark-js-plus@1.5.7: resolution: {integrity: sha512-KaQEUnvBX5em2hBeuKcpAASpV+sO1j8NbXY7FL7jb0w1TCKmMSyn8nkj2e+KeleuQ1iwyXHEMFdSWXDIQsACYQ==} engines: {node: '>=20.0.0'} + wcwidth@1.0.1: + resolution: {integrity: sha512-XHPEwS0q6TaxcvG85+8EYkbiCux2XtWG2mkc47Ng2A77BQu9+DqIOJldST4HgPkuea7dvKSj5VgX3P1d4rW8Tg==} + webidl-conversions@3.0.1: resolution: {integrity: sha512-2JAn3z8AR6rjK8Sm8orRC0h/bcl/DqL7tRPdGZ4I1CjdF+EaMLmYxBHyXuKL849eucPFhvBoxMsflfOb8kxaeQ==} @@ -10300,9 +10895,27 @@ packages: resolution: {integrity: sha512-VwddBukDzu71offAQR975unBIGqfKZpM+8ZX6ySk8nYhVoo5CYaZyzt3YBvYtRtO+aoGlqxPg/B87NGVZ/fu6g==} engines: {node: '>=12'} + webpack-node-externals@3.0.0: + resolution: {integrity: sha512-LnL6Z3GGDPht/AigwRh2dvL9PQPFQ8skEpVrWZXLWBYmqcaojHNN0onvHzie6rq7EWKrrBfPYqNEzTJgiwEQDQ==} + engines: {node: '>=6'} + + webpack-sources@3.2.3: + resolution: {integrity: sha512-/DyMEOrDgLKKIG0fmvtz+4dUX/3Ghozwgm6iPp8KRhvn+eQf9+Q7GWxVNMk3+uCPWfdXYC4ExGBckIXdFEfH1w==} + engines: {node: '>=10.13.0'} + webpack-virtual-modules@0.6.2: resolution: {integrity: sha512-66/V2i5hQanC51vBQKPH4aI8NMAcBW59FVBs+rC7eGHupMyfn34q7rZIE+ETlJ+XTevqfUhVVBgSUNSW2flEUQ==} + webpack@5.94.0: + resolution: {integrity: sha512-KcsGn50VT+06JH/iunZJedYGUJS5FGjow8wb9c0v5n1Om8O1g4L6LjtfxwlXIATopoQu+vOXXa7gYisWxCoPyg==} + engines: {node: '>=10.13.0'} + hasBin: true + peerDependencies: + webpack-cli: '*' + peerDependenciesMeta: + webpack-cli: + optional: true + whatwg-encoding@3.1.1: resolution: {integrity: sha512-6qN4hJdMwfYBtE3YBTTHhoeuUrDBPZmbQaxWAqSALV/MeEnR5z1xd8UKud2RAkFoPkmB+hli1TZSnyi84xz1vQ==} engines: {node: '>=18'} @@ -10442,6 +11055,10 @@ packages: resolution: {integrity: sha512-ICP2e+jsHvAj2E2lIHxa5tjXRlKDJo4IdvPvCXbXQGdzSfmSpNVyIKMvoZHjDY9DP0zV17iI85o90vRFXNccRw==} engines: {node: '>=12'} + xtend@4.0.2: + resolution: {integrity: sha512-LKYU1iAXJXUgAXn9URjiu+MWhyUXHsvfp7mcuYm9dSUKK0/CjtrUwFAxD82/mCWbtLsGjFIad0wIsod4zrTAEQ==} + engines: {node: '>=0.4'} + y18n@4.0.3: resolution: {integrity: sha512-JKhqTOwSrqNA1NY5lSztJ1GrBiUodLMmIZuLiDaMRJ+itFd+ABVE8XBjOvIWL+rSqNDC74LCSFmlb/U4UZ4hJQ==} @@ -10648,6 +11265,59 @@ snapshots: '@jridgewell/gen-mapping': 0.3.5 '@jridgewell/trace-mapping': 0.3.25 + '@angular-devkit/core@17.3.10(chokidar@3.6.0)': + dependencies: + ajv: 8.12.0 + ajv-formats: 2.1.1(ajv@8.12.0) + jsonc-parser: 3.2.1 + picomatch: 4.0.1 + rxjs: 7.8.1 + source-map: 0.7.4 + optionalDependencies: + chokidar: 3.6.0 + + '@angular-devkit/core@17.3.8(chokidar@3.6.0)': + dependencies: + ajv: 8.12.0 + ajv-formats: 2.1.1(ajv@8.12.0) + jsonc-parser: 3.2.1 + picomatch: 4.0.1 + rxjs: 7.8.1 + source-map: 0.7.4 + optionalDependencies: + chokidar: 3.6.0 + + '@angular-devkit/schematics-cli@17.3.8(chokidar@3.6.0)': + dependencies: + '@angular-devkit/core': 17.3.8(chokidar@3.6.0) + '@angular-devkit/schematics': 17.3.8(chokidar@3.6.0) + ansi-colors: 4.1.3 + inquirer: 9.2.15 + symbol-observable: 4.0.0 + yargs-parser: 21.1.1 + transitivePeerDependencies: + - chokidar + + '@angular-devkit/schematics@17.3.10(chokidar@3.6.0)': + dependencies: + '@angular-devkit/core': 17.3.10(chokidar@3.6.0) + jsonc-parser: 3.2.1 + magic-string: 0.30.8 + ora: 5.4.1 + rxjs: 7.8.1 + transitivePeerDependencies: + - chokidar + + '@angular-devkit/schematics@17.3.8(chokidar@3.6.0)': + dependencies: + '@angular-devkit/core': 17.3.8(chokidar@3.6.0) + jsonc-parser: 3.2.1 + magic-string: 0.30.8 + ora: 5.4.1 + rxjs: 7.8.1 + transitivePeerDependencies: + - chokidar + '@ant-design/colors@6.0.0': dependencies: '@ctrl/tinycolor': 4.1.0 @@ -11630,6 +12300,9 @@ snapshots: dependencies: mime: 3.0.0 + '@colors/colors@1.5.0': + optional: true + '@commitlint/cli@19.5.0(@types/node@22.7.9)(typescript@5.6.3)': dependencies: '@commitlint/format': 19.5.0 @@ -12675,7 +13348,7 @@ snapshots: '@intlify/shared@10.0.4': {} - '@intlify/unplugin-vue-i18n@5.2.0(@vue/compiler-dom@3.5.12)(eslint@9.13.0(jiti@2.3.3))(rollup@4.24.0)(typescript@5.6.3)(vue-i18n@10.0.4(vue@3.5.12(typescript@5.6.3)))(vue@3.5.12(typescript@5.6.3))': + '@intlify/unplugin-vue-i18n@5.2.0(@vue/compiler-dom@3.5.12)(eslint@9.13.0(jiti@2.3.3))(rollup@4.24.0)(typescript@5.6.3)(vue-i18n@10.0.4(vue@3.5.12(typescript@5.6.3)))(vue@3.5.12(typescript@5.6.3))(webpack-sources@3.2.3)': dependencies: '@eslint-community/eslint-utils': 4.4.0(eslint@9.13.0(jiti@2.3.3)) '@intlify/bundle-utils': 9.0.0-beta.0(vue-i18n@10.0.4(vue@3.5.12(typescript@5.6.3))) @@ -12691,7 +13364,7 @@ snapshots: pathe: 1.1.2 picocolors: 1.1.1 source-map-js: 1.2.1 - unplugin: 1.14.1 + unplugin: 1.14.1(webpack-sources@3.2.3) vue: 3.5.12(typescript@5.6.3) optionalDependencies: vue-i18n: 10.0.4(vue@3.5.12(typescript@5.6.3)) @@ -12762,6 +13435,12 @@ snapshots: '@juggle/resize-observer@3.4.0': {} + '@ljharb/through@2.3.13': + dependencies: + call-bind: 1.0.7 + + '@lukeed/csprng@1.1.0': {} + '@manypkg/find-root@1.1.0': dependencies: '@babel/runtime': 7.25.7 @@ -12843,6 +13522,79 @@ snapshots: '@microsoft/tsdoc@0.15.0': {} + '@nestjs/cli@10.4.5': + dependencies: + '@angular-devkit/core': 17.3.8(chokidar@3.6.0) + '@angular-devkit/schematics': 17.3.8(chokidar@3.6.0) + '@angular-devkit/schematics-cli': 17.3.8(chokidar@3.6.0) + '@nestjs/schematics': 10.2.2(chokidar@3.6.0)(typescript@5.3.3) + chalk: 4.1.2 + chokidar: 3.6.0 + cli-table3: 0.6.5 + commander: 4.1.1 + fork-ts-checker-webpack-plugin: 9.0.2(typescript@5.3.3)(webpack@5.94.0) + glob: 10.4.2 + inquirer: 8.2.6 + node-emoji: 1.11.0 + ora: 5.4.1 + tree-kill: 1.2.2 + tsconfig-paths: 4.2.0 + tsconfig-paths-webpack-plugin: 4.1.0 + typescript: 5.3.3 + webpack: 5.94.0 + webpack-node-externals: 3.0.0 + transitivePeerDependencies: + - esbuild + - uglify-js + - webpack-cli + + '@nestjs/common@10.4.6(reflect-metadata@0.2.2)(rxjs@7.8.1)': + dependencies: + iterare: 1.2.1 + reflect-metadata: 0.2.2 + rxjs: 7.8.1 + tslib: 2.7.0 + uid: 2.0.2 + + '@nestjs/core@10.4.6(@nestjs/common@10.4.6(reflect-metadata@0.2.2)(rxjs@7.8.1))(@nestjs/platform-express@10.4.6)(encoding@0.1.13)(reflect-metadata@0.2.2)(rxjs@7.8.1)': + dependencies: + '@nestjs/common': 10.4.6(reflect-metadata@0.2.2)(rxjs@7.8.1) + '@nuxtjs/opencollective': 0.3.2(encoding@0.1.13) + fast-safe-stringify: 2.1.1 + iterare: 1.2.1 + path-to-regexp: 3.3.0 + reflect-metadata: 0.2.2 + rxjs: 7.8.1 + tslib: 2.7.0 + uid: 2.0.2 + optionalDependencies: + '@nestjs/platform-express': 10.4.6(@nestjs/common@10.4.6(reflect-metadata@0.2.2)(rxjs@7.8.1))(@nestjs/core@10.4.6) + transitivePeerDependencies: + - encoding + + '@nestjs/platform-express@10.4.6(@nestjs/common@10.4.6(reflect-metadata@0.2.2)(rxjs@7.8.1))(@nestjs/core@10.4.6)': + dependencies: + '@nestjs/common': 10.4.6(reflect-metadata@0.2.2)(rxjs@7.8.1) + '@nestjs/core': 10.4.6(@nestjs/common@10.4.6(reflect-metadata@0.2.2)(rxjs@7.8.1))(@nestjs/platform-express@10.4.6)(encoding@0.1.13)(reflect-metadata@0.2.2)(rxjs@7.8.1) + body-parser: 1.20.3 + cors: 2.8.5 + express: 4.21.1 + multer: 1.4.4-lts.1 + tslib: 2.7.0 + transitivePeerDependencies: + - supports-color + + '@nestjs/schematics@10.2.2(chokidar@3.6.0)(typescript@5.3.3)': + dependencies: + '@angular-devkit/core': 17.3.10(chokidar@3.6.0) + '@angular-devkit/schematics': 17.3.10(chokidar@3.6.0) + comment-json: 4.2.5 + jsonc-parser: 3.3.1 + pluralize: 8.0.0 + typescript: 5.3.3 + transitivePeerDependencies: + - chokidar + '@netlify/functions@2.8.2': dependencies: '@netlify/serverless-functions-api': 1.26.1 @@ -12954,9 +13706,9 @@ snapshots: mkdirp: 1.0.4 rimraf: 3.0.2 - '@nuxt/kit@3.13.2(rollup@4.24.0)': + '@nuxt/kit@3.13.2(rollup@4.24.0)(webpack-sources@3.2.3)': dependencies: - '@nuxt/schema': 3.13.2(rollup@4.24.0) + '@nuxt/schema': 3.13.2(rollup@4.24.0)(webpack-sources@3.2.3) c12: 1.11.2 consola: 3.2.3 defu: 6.1.4 @@ -12973,8 +13725,8 @@ snapshots: scule: 1.3.0 semver: 7.6.3 ufo: 1.5.4 - unctx: 2.3.1 - unimport: 3.13.1(rollup@4.24.0) + unctx: 2.3.1(webpack-sources@3.2.3) + unimport: 3.13.1(rollup@4.24.0)(webpack-sources@3.2.3) untyped: 1.5.1 transitivePeerDependencies: - magicast @@ -12982,7 +13734,7 @@ snapshots: - supports-color - webpack-sources - '@nuxt/schema@3.13.2(rollup@4.24.0)': + '@nuxt/schema@3.13.2(rollup@4.24.0)(webpack-sources@3.2.3)': dependencies: compatx: 0.1.8 consola: 3.2.3 @@ -12994,13 +13746,21 @@ snapshots: std-env: 3.7.0 ufo: 1.5.4 uncrypto: 0.1.3 - unimport: 3.13.1(rollup@4.24.0) + unimport: 3.13.1(rollup@4.24.0)(webpack-sources@3.2.3) untyped: 1.5.1 transitivePeerDependencies: - rollup - supports-color - webpack-sources + '@nuxtjs/opencollective@0.3.2(encoding@0.1.13)': + dependencies: + chalk: 4.1.2 + consola: 2.15.3 + node-fetch: 2.7.0(encoding@0.1.13) + transitivePeerDependencies: + - encoding + '@one-ini/wasm@0.1.1': {} '@parcel/watcher-android-arm64@2.4.1': @@ -13462,9 +14222,18 @@ snapshots: '@types/bintrees@1.0.6': {} + '@types/body-parser@1.19.5': + dependencies: + '@types/connect': 3.4.38 + '@types/node': 22.7.9 + + '@types/connect@3.4.38': + dependencies: + '@types/node': 22.7.9 + '@types/conventional-commits-parser@5.0.0': dependencies: - '@types/node': 22.7.8 + '@types/node': 22.7.9 '@types/eslint@9.6.1': dependencies: @@ -13475,10 +14244,24 @@ snapshots: '@types/estree@1.0.6': {} + '@types/express-serve-static-core@4.19.6': + dependencies: + '@types/node': 22.7.9 + '@types/qs': 6.9.16 + '@types/range-parser': 1.2.7 + '@types/send': 0.17.4 + + '@types/express@4.17.21': + dependencies: + '@types/body-parser': 1.19.5 + '@types/express-serve-static-core': 4.19.6 + '@types/qs': 6.9.16 + '@types/serve-static': 1.15.7 + '@types/fs-extra@11.0.4': dependencies: '@types/jsonfile': 6.1.4 - '@types/node': 22.7.8 + '@types/node': 22.7.9 optional: true '@types/hast@3.0.4': @@ -13487,15 +14270,17 @@ snapshots: '@types/html-minifier-terser@7.0.2': {} + '@types/http-errors@2.0.4': {} + '@types/http-proxy@1.17.15': dependencies: - '@types/node': 22.7.8 + '@types/node': 22.7.9 '@types/json-schema@7.0.15': {} '@types/jsonfile@6.1.4': dependencies: - '@types/node': 22.7.8 + '@types/node': 22.7.9 optional: true '@types/jsonwebtoken@9.0.7': @@ -13527,6 +14312,8 @@ snapshots: '@types/mdurl@2.0.0': {} + '@types/mime@1.3.5': {} + '@types/minimatch@3.0.5': {} '@types/node@12.20.55': {} @@ -13535,10 +14322,6 @@ snapshots: dependencies: undici-types: 6.19.8 - '@types/node@22.7.8': - dependencies: - undici-types: 6.19.8 - '@types/node@22.7.9': dependencies: undici-types: 6.19.8 @@ -13555,14 +14338,29 @@ snapshots: '@types/qrcode@1.5.5': dependencies: - '@types/node': 22.7.7 + '@types/node': 22.7.9 + + '@types/qs@6.9.16': {} + + '@types/range-parser@1.2.7': {} '@types/readdir-glob@1.1.5': dependencies: - '@types/node': 22.7.8 + '@types/node': 22.7.9 '@types/resolve@1.20.2': {} + '@types/send@0.17.4': + dependencies: + '@types/mime': 1.3.5 + '@types/node': 22.7.9 + + '@types/serve-static@1.15.7': + dependencies: + '@types/http-errors': 2.0.4 + '@types/node': 22.7.9 + '@types/send': 0.17.4 + '@types/sortablejs@1.15.8': {} '@types/trusted-types@2.0.7': {} @@ -14066,6 +14864,86 @@ snapshots: vue: 3.5.12(typescript@5.6.3) xe-utils: 3.5.31 + '@webassemblyjs/ast@1.12.1': + dependencies: + '@webassemblyjs/helper-numbers': 1.11.6 + '@webassemblyjs/helper-wasm-bytecode': 1.11.6 + + '@webassemblyjs/floating-point-hex-parser@1.11.6': {} + + '@webassemblyjs/helper-api-error@1.11.6': {} + + '@webassemblyjs/helper-buffer@1.12.1': {} + + '@webassemblyjs/helper-numbers@1.11.6': + dependencies: + '@webassemblyjs/floating-point-hex-parser': 1.11.6 + '@webassemblyjs/helper-api-error': 1.11.6 + '@xtuc/long': 4.2.2 + + '@webassemblyjs/helper-wasm-bytecode@1.11.6': {} + + '@webassemblyjs/helper-wasm-section@1.12.1': + dependencies: + '@webassemblyjs/ast': 1.12.1 + '@webassemblyjs/helper-buffer': 1.12.1 + '@webassemblyjs/helper-wasm-bytecode': 1.11.6 + '@webassemblyjs/wasm-gen': 1.12.1 + + '@webassemblyjs/ieee754@1.11.6': + dependencies: + '@xtuc/ieee754': 1.2.0 + + '@webassemblyjs/leb128@1.11.6': + dependencies: + '@xtuc/long': 4.2.2 + + '@webassemblyjs/utf8@1.11.6': {} + + '@webassemblyjs/wasm-edit@1.12.1': + dependencies: + '@webassemblyjs/ast': 1.12.1 + '@webassemblyjs/helper-buffer': 1.12.1 + '@webassemblyjs/helper-wasm-bytecode': 1.11.6 + '@webassemblyjs/helper-wasm-section': 1.12.1 + '@webassemblyjs/wasm-gen': 1.12.1 + '@webassemblyjs/wasm-opt': 1.12.1 + '@webassemblyjs/wasm-parser': 1.12.1 + '@webassemblyjs/wast-printer': 1.12.1 + + '@webassemblyjs/wasm-gen@1.12.1': + dependencies: + '@webassemblyjs/ast': 1.12.1 + '@webassemblyjs/helper-wasm-bytecode': 1.11.6 + '@webassemblyjs/ieee754': 1.11.6 + '@webassemblyjs/leb128': 1.11.6 + '@webassemblyjs/utf8': 1.11.6 + + '@webassemblyjs/wasm-opt@1.12.1': + dependencies: + '@webassemblyjs/ast': 1.12.1 + '@webassemblyjs/helper-buffer': 1.12.1 + '@webassemblyjs/wasm-gen': 1.12.1 + '@webassemblyjs/wasm-parser': 1.12.1 + + '@webassemblyjs/wasm-parser@1.12.1': + dependencies: + '@webassemblyjs/ast': 1.12.1 + '@webassemblyjs/helper-api-error': 1.11.6 + '@webassemblyjs/helper-wasm-bytecode': 1.11.6 + '@webassemblyjs/ieee754': 1.11.6 + '@webassemblyjs/leb128': 1.11.6 + '@webassemblyjs/utf8': 1.11.6 + + '@webassemblyjs/wast-printer@1.12.1': + dependencies: + '@webassemblyjs/ast': 1.12.1 + '@xtuc/long': 4.2.2 + + '@xtuc/ieee754@1.2.0': {} + + '@xtuc/long@4.2.2': {} + JSONStream@1.3.5: dependencies: jsonparse: 1.3.1 @@ -14079,6 +14957,11 @@ snapshots: dependencies: event-target-shim: 5.0.1 + accepts@1.3.8: + dependencies: + mime-types: 2.1.35 + negotiator: 0.6.3 + acorn-import-attributes@1.9.5(acorn@8.13.0): dependencies: acorn: 8.13.0 @@ -14108,10 +14991,18 @@ snapshots: optionalDependencies: ajv: 8.13.0 + ajv-formats@2.1.1(ajv@8.12.0): + optionalDependencies: + ajv: 8.12.0 + ajv-formats@3.0.1(ajv@8.13.0): optionalDependencies: ajv: 8.13.0 + ajv-keywords@3.5.2(ajv@6.12.6): + dependencies: + ajv: 6.12.6 + ajv@6.12.6: dependencies: fast-deep-equal: 3.1.3 @@ -14164,6 +15055,10 @@ snapshots: ansi-colors@4.1.3: {} + ansi-escapes@4.3.2: + dependencies: + type-fest: 0.21.3 + ansi-escapes@7.0.0: dependencies: environment: 1.1.0 @@ -14215,6 +15110,8 @@ snapshots: normalize-path: 3.0.0 picomatch: 2.3.1 + append-field@1.0.0: {} + aproba@2.0.0: {} archiver-utils@5.0.2: @@ -14263,6 +15160,8 @@ snapshots: array-differ@3.0.0: {} + array-flatten@1.1.1: {} + array-ify@1.0.0: {} array-timsort@1.0.3: {} @@ -14380,6 +15279,29 @@ snapshots: birpc@0.2.19: {} + bl@4.1.0: + dependencies: + buffer: 5.7.1 + inherits: 2.0.4 + readable-stream: 3.6.2 + + body-parser@1.20.3: + dependencies: + bytes: 3.1.2 + content-type: 1.0.5 + debug: 2.6.9 + depd: 2.0.0 + destroy: 1.2.0 + http-errors: 2.0.0 + iconv-lite: 0.4.24 + on-finished: 2.4.1 + qs: 6.13.0 + raw-body: 2.5.2 + type-is: 1.6.18 + unpipe: 1.0.0 + transitivePeerDependencies: + - supports-color + boolbase@1.0.0: {} boxen@8.0.1: @@ -14419,6 +15341,11 @@ snapshots: buffer-from@1.1.2: {} + buffer@5.7.1: + dependencies: + base64-js: 1.5.1 + ieee754: 1.2.1 + buffer@6.0.3: dependencies: base64-js: 1.5.1 @@ -14430,6 +15357,12 @@ snapshots: dependencies: run-applescript: 7.0.0 + busboy@1.6.0: + dependencies: + streamsearch: 1.1.0 + + bytes@3.1.2: {} + c12@1.11.2: dependencies: chokidar: 3.6.0 @@ -14580,6 +15513,8 @@ snapshots: chownr@2.0.0: {} + chrome-trace-event@1.0.4: {} + ci-info@3.9.0: {} ci-info@4.0.0: {} @@ -14623,17 +15558,31 @@ snapshots: cli-boxes@3.0.0: {} + cli-cursor@3.1.0: + dependencies: + restore-cursor: 3.1.0 + cli-cursor@5.0.0: dependencies: restore-cursor: 5.1.0 cli-spinners@2.9.2: {} + cli-table3@0.6.5: + dependencies: + string-width: 4.2.3 + optionalDependencies: + '@colors/colors': 1.5.0 + cli-truncate@4.0.0: dependencies: slice-ansi: 5.0.0 string-width: 7.2.0 + cli-width@3.0.0: {} + + cli-width@4.1.0: {} + clipboardy@4.0.0: dependencies: execa: 8.0.1 @@ -14658,6 +15607,8 @@ snapshots: strip-ansi: 6.0.1 wrap-ansi: 7.0.0 + clone@1.0.4: {} + clsx@2.1.1: {} cluster-key-slot@1.1.2: {} @@ -14739,6 +15690,13 @@ snapshots: concat-map@0.0.1: {} + concat-stream@1.6.2: + dependencies: + buffer-from: 1.1.2 + inherits: 2.0.4 + readable-stream: 2.3.8 + typedarray: 0.0.6 + confbox@0.1.8: {} config-chain@1.1.13: @@ -14761,6 +15719,12 @@ snapshots: console-control-strings@1.1.0: {} + content-disposition@0.5.4: + dependencies: + safe-buffer: 5.2.1 + + content-type@1.0.5: {} + conventional-changelog-angular@7.0.0: dependencies: compare-func: 2.0.0 @@ -14780,6 +15744,10 @@ snapshots: cookie-es@1.2.2: {} + cookie-signature@1.0.6: {} + + cookie@0.7.1: {} + copy-anything@2.0.6: dependencies: is-what: 3.14.1 @@ -14796,6 +15764,11 @@ snapshots: core-util-is@1.0.3: {} + cors@2.8.5: + dependencies: + object-assign: 4.1.1 + vary: 1.1.2 + cosmiconfig-typescript-loader@5.1.0(@types/node@22.7.9)(cosmiconfig@9.0.0(typescript@5.6.3))(typescript@5.6.3): dependencies: '@types/node': 22.7.9 @@ -14811,6 +15784,15 @@ snapshots: path-type: 4.0.0 yaml: 1.10.2 + cosmiconfig@8.3.6(typescript@5.3.3): + dependencies: + import-fresh: 3.3.0 + js-yaml: 4.1.0 + parse-json: 5.2.0 + path-type: 4.0.0 + optionalDependencies: + typescript: 5.3.3 + cosmiconfig@9.0.0(typescript@5.6.3): dependencies: env-paths: 2.2.1 @@ -15129,6 +16111,10 @@ snapshots: bundle-name: 4.1.0 default-browser-id: 5.0.0 + defaults@1.0.4: + dependencies: + clone: 1.0.4 + define-data-property@1.1.4: dependencies: es-define-property: 1.0.0 @@ -15768,6 +16754,11 @@ snapshots: transitivePeerDependencies: - supports-color + eslint-scope@5.1.1: + dependencies: + esrecurse: 4.3.0 + estraverse: 4.3.0 + eslint-scope@7.2.2: dependencies: esrecurse: 4.3.0 @@ -15846,6 +16837,8 @@ snapshots: dependencies: estraverse: 5.3.0 + estraverse@4.3.0: {} + estraverse@5.3.0: {} estree-walker@1.0.1: {} @@ -15899,6 +16892,42 @@ snapshots: dependencies: homedir-polyfill: 1.0.3 + express@4.21.1: + dependencies: + accepts: 1.3.8 + array-flatten: 1.1.1 + body-parser: 1.20.3 + content-disposition: 0.5.4 + content-type: 1.0.5 + cookie: 0.7.1 + cookie-signature: 1.0.6 + debug: 2.6.9 + depd: 2.0.0 + encodeurl: 2.0.0 + escape-html: 1.0.3 + etag: 1.8.1 + finalhandler: 1.3.1 + fresh: 0.5.2 + http-errors: 2.0.0 + merge-descriptors: 1.0.3 + methods: 1.1.2 + on-finished: 2.4.1 + parseurl: 1.3.3 + path-to-regexp: 0.1.10 + proxy-addr: 2.0.7 + qs: 6.13.0 + range-parser: 1.2.1 + safe-buffer: 5.2.1 + send: 0.19.0 + serve-static: 1.16.2 + setprototypeof: 1.2.0 + statuses: 2.0.1 + type-is: 1.6.18 + utils-merge: 1.0.1 + vary: 1.1.2 + transitivePeerDependencies: + - supports-color + extend-shallow@2.0.1: dependencies: is-extendable: 0.1.1 @@ -15931,6 +16960,8 @@ snapshots: fast-levenshtein@2.0.6: {} + fast-safe-stringify@2.1.1: {} + fast-string-compare@3.0.0: {} fast-uri@3.0.3: {} @@ -15945,6 +16976,10 @@ snapshots: optionalDependencies: picomatch: 4.0.2 + figures@3.2.0: + dependencies: + escape-string-regexp: 1.0.5 + figures@6.1.0: dependencies: is-unicode-supported: 2.1.0 @@ -15967,6 +17002,18 @@ snapshots: dependencies: to-regex-range: 5.0.1 + finalhandler@1.3.1: + dependencies: + debug: 2.6.9 + encodeurl: 2.0.0 + escape-html: 1.0.3 + on-finished: 2.4.1 + parseurl: 1.3.3 + statuses: 2.0.1 + unpipe: 1.0.0 + transitivePeerDependencies: + - supports-color + find-up-simple@1.0.0: {} find-up@4.1.0: @@ -16019,12 +17066,31 @@ snapshots: cross-spawn: 7.0.3 signal-exit: 4.1.0 + fork-ts-checker-webpack-plugin@9.0.2(typescript@5.3.3)(webpack@5.94.0): + dependencies: + '@babel/code-frame': 7.25.7 + chalk: 4.1.2 + chokidar: 3.6.0 + cosmiconfig: 8.3.6(typescript@5.3.3) + deepmerge: 4.3.1 + fs-extra: 10.1.0 + memfs: 3.5.3 + minimatch: 3.1.2 + node-abort-controller: 3.1.1 + schema-utils: 3.3.0 + semver: 7.6.3 + tapable: 2.2.1 + typescript: 5.3.3 + webpack: 5.94.0 + form-data@4.0.1: dependencies: asynckit: 0.4.0 combined-stream: 1.0.8 mime-types: 2.1.35 + forwarded@0.2.0: {} + fraction.js@4.3.7: {} fresh@0.5.2: {} @@ -16064,6 +17130,8 @@ snapshots: dependencies: minipass: 3.3.6 + fs-monkey@1.0.6: {} + fs.realpath@1.0.0: {} fsevents@2.3.2: @@ -16161,6 +17229,17 @@ snapshots: dependencies: is-glob: 4.0.3 + glob-to-regexp@0.4.1: {} + + glob@10.4.2: + dependencies: + foreground-child: 3.3.0 + jackspeak: 3.4.3 + minimatch: 9.0.5 + minipass: 7.1.2 + package-json-from-dist: 1.0.1 + path-scurry: 1.11.1 + glob@10.4.5: dependencies: foreground-child: 3.3.0 @@ -16501,6 +17580,42 @@ snapshots: ini@4.1.1: {} + inquirer@8.2.6: + dependencies: + ansi-escapes: 4.3.2 + chalk: 4.1.2 + cli-cursor: 3.1.0 + cli-width: 3.0.0 + external-editor: 3.1.0 + figures: 3.2.0 + lodash: 4.17.21 + mute-stream: 0.0.8 + ora: 5.4.1 + run-async: 2.4.1 + rxjs: 7.8.1 + string-width: 4.2.3 + strip-ansi: 6.0.1 + through: 2.3.8 + wrap-ansi: 6.2.0 + + inquirer@9.2.15: + dependencies: + '@ljharb/through': 2.3.13 + ansi-escapes: 4.3.2 + chalk: 5.3.0 + cli-cursor: 3.1.0 + cli-width: 4.1.0 + external-editor: 3.1.0 + figures: 3.2.0 + lodash: 4.17.21 + mute-stream: 1.0.0 + ora: 5.4.1 + run-async: 3.0.0 + rxjs: 7.8.1 + string-width: 4.2.3 + strip-ansi: 6.0.1 + wrap-ansi: 6.2.0 + internal-slot@1.0.7: dependencies: es-errors: 1.3.0 @@ -16526,6 +17641,8 @@ snapshots: jsbn: 1.1.0 sprintf-js: 1.1.3 + ipaddr.js@1.9.1: {} + iron-webcrypto@1.2.1: {} is-array-buffer@3.0.4: @@ -16603,6 +17720,8 @@ snapshots: global-directory: 4.0.1 is-path-inside: 4.0.0 + is-interactive@1.0.0: {} + is-interactive@2.0.0: {} is-lambda@1.0.1: {} @@ -16672,6 +17791,8 @@ snapshots: dependencies: which-typed-array: 1.1.15 + is-unicode-supported@0.1.0: {} + is-unicode-supported@1.3.0: {} is-unicode-supported@2.1.0: {} @@ -16704,6 +17825,8 @@ snapshots: isexe@2.0.0: {} + iterare@1.2.1: {} + jackspeak@3.4.3: dependencies: '@isaacs/cliui': 8.0.2 @@ -16721,6 +17844,12 @@ snapshots: filelist: 1.0.4 minimatch: 3.1.2 + jest-worker@27.5.1: + dependencies: + '@types/node': 22.7.9 + merge-stream: 2.0.0 + supports-color: 8.1.1 + jiti@1.21.6: {} jiti@2.3.3: {} @@ -16779,6 +17908,10 @@ snapshots: espree: 9.6.1 semver: 7.6.3 + jsonc-parser@3.2.1: {} + + jsonc-parser@3.3.1: {} + jsonfile@4.0.0: optionalDependencies: graceful-fs: 4.2.11 @@ -16915,6 +18048,8 @@ snapshots: rfdc: 1.4.1 wrap-ansi: 9.0.0 + loader-runner@4.3.0: {} + local-pkg@0.5.0: dependencies: mlly: 1.7.2 @@ -16988,6 +18123,11 @@ snapshots: lodash@4.17.21: {} + log-symbols@4.1.0: + dependencies: + chalk: 4.1.2 + is-unicode-supported: 0.1.0 + log-symbols@6.0.0: dependencies: chalk: 5.3.0 @@ -17040,6 +18180,10 @@ snapshots: dependencies: '@jridgewell/sourcemap-codec': 1.5.0 + magic-string@0.30.8: + dependencies: + '@jridgewell/sourcemap-codec': 1.5.0 + make-dir@2.1.0: dependencies: pify: 4.0.1 @@ -17095,18 +18239,28 @@ snapshots: mdn-data@2.11.1: {} + media-typer@0.3.0: {} + medium-zoom@1.1.0: {} + memfs@3.5.3: + dependencies: + fs-monkey: 1.0.6 + memoize-one@6.0.0: {} meow@12.1.1: {} meow@13.2.0: {} + merge-descriptors@1.0.3: {} + merge-stream@2.0.0: {} merge2@1.4.1: {} + methods@1.1.2: {} + micromark-util-character@2.1.0: dependencies: micromark-util-symbol: 2.0.0 @@ -17141,6 +18295,8 @@ snapshots: mime@4.0.4: {} + mimic-fn@2.1.0: {} + mimic-fn@4.0.0: {} mimic-function@5.0.1: {} @@ -17218,6 +18374,10 @@ snapshots: mitt@3.0.1: {} + mkdirp@0.5.6: + dependencies: + minimist: 1.2.8 + mkdirp@1.0.4: {} mkdist@1.6.0(sass@1.79.5)(typescript@5.6.3)(vue-tsc@2.1.6(typescript@5.6.3)): @@ -17257,6 +18417,16 @@ snapshots: muggle-string@0.4.1: {} + multer@1.4.4-lts.1: + dependencies: + append-field: 1.0.0 + busboy: 1.6.0 + concat-stream: 1.6.2 + mkdirp: 0.5.6 + object-assign: 4.1.1 + type-is: 1.6.18 + xtend: 4.0.2 + multimatch@5.0.0: dependencies: '@types/minimatch': 3.0.5 @@ -17265,6 +18435,10 @@ snapshots: arrify: 2.0.1 minimatch: 3.1.2 + mute-stream@0.0.8: {} + + mute-stream@1.0.0: {} + mz@2.7.0: dependencies: any-promise: 1.3.0 @@ -17310,7 +18484,11 @@ snapshots: sax: 1.4.1 optional: true - nitropack@2.9.7(encoding@0.1.13): + negotiator@0.6.3: {} + + neo-async@2.6.2: {} + + nitropack@2.9.7(encoding@0.1.13)(webpack-sources@3.2.3): dependencies: '@cloudflare/kv-asset-handler': 0.3.4 '@netlify/functions': 2.8.2 @@ -17373,11 +18551,11 @@ snapshots: std-env: 3.7.0 ufo: 1.5.4 uncrypto: 0.1.3 - unctx: 2.3.1 + unctx: 2.3.1(webpack-sources@3.2.3) unenv: 1.10.0 - unimport: 3.13.1(rollup@4.24.0) + unimport: 3.13.1(rollup@4.24.0)(webpack-sources@3.2.3) unstorage: 1.12.0(ioredis@5.4.1) - unwasm: 0.3.9 + unwasm: 0.3.9(webpack-sources@3.2.3) transitivePeerDependencies: - '@azure/app-configuration' - '@azure/cosmos' @@ -17405,10 +18583,16 @@ snapshots: lower-case: 2.0.2 tslib: 2.8.0 + node-abort-controller@3.1.1: {} + node-addon-api@7.1.1: {} node-cleanup@2.1.2: {} + node-emoji@1.11.0: + dependencies: + lodash: 4.17.21 + node-fetch-native@1.6.4: {} node-fetch@2.7.0(encoding@0.1.13): @@ -17524,6 +18708,10 @@ snapshots: dependencies: wrappy: 1.0.2 + onetime@5.1.2: + dependencies: + mimic-fn: 2.1.0 + onetime@6.0.0: dependencies: mimic-fn: 4.0.0 @@ -17567,6 +18755,18 @@ snapshots: type-check: 0.4.0 word-wrap: 1.2.5 + ora@5.4.1: + dependencies: + bl: 4.1.0 + chalk: 4.1.2 + cli-cursor: 3.1.0 + cli-spinners: 2.9.2 + is-interactive: 1.0.0 + is-unicode-supported: 0.1.0 + log-symbols: 4.1.0 + strip-ansi: 6.0.1 + wcwidth: 1.0.1 + ora@8.1.0: dependencies: chalk: 5.3.0 @@ -17705,6 +18905,10 @@ snapshots: lru-cache: 11.0.1 minipass: 7.1.2 + path-to-regexp@0.1.10: {} + + path-to-regexp@3.3.0: {} + path-type@4.0.0: {} path-type@5.0.0: {} @@ -17721,6 +18925,8 @@ snapshots: picomatch@2.3.1: {} + picomatch@4.0.1: {} + picomatch@4.0.2: {} pidtree@0.6.0: {} @@ -17729,9 +18935,9 @@ snapshots: pify@4.0.1: {} - pinia-plugin-persistedstate@4.1.1(pinia@2.2.2(typescript@5.6.3)(vue@3.5.12(typescript@5.6.3)))(rollup@4.24.0): + pinia-plugin-persistedstate@4.1.1(pinia@2.2.2(typescript@5.6.3)(vue@3.5.12(typescript@5.6.3)))(rollup@4.24.0)(webpack-sources@3.2.3): dependencies: - '@nuxt/kit': 3.13.2(rollup@4.24.0) + '@nuxt/kit': 3.13.2(rollup@4.24.0)(webpack-sources@3.2.3) deep-pick-omit: 1.2.1 defu: 6.1.4 destr: 2.0.3 @@ -18265,6 +19471,11 @@ snapshots: proto-list@1.2.4: {} + proxy-addr@2.0.7: + dependencies: + forwarded: 0.2.0 + ipaddr.js: 1.9.1 + proxy-from-env@1.1.0: {} prr@1.0.1: @@ -18290,6 +19501,10 @@ snapshots: pngjs: 5.0.0 yargs: 15.4.1 + qs@6.13.0: + dependencies: + side-channel: 1.0.6 + queue-microtask@1.2.3: {} queue-tick@1.0.1: {} @@ -18319,6 +19534,13 @@ snapshots: range-parser@1.2.1: {} + raw-body@2.5.2: + dependencies: + bytes: 3.1.2 + http-errors: 2.0.0 + iconv-lite: 0.4.24 + unpipe: 1.0.0 + rc9@2.1.2: dependencies: defu: 6.1.4 @@ -18404,6 +19626,8 @@ snapshots: dependencies: '@eslint-community/regexpp': 4.11.1 + reflect-metadata@0.2.2: {} + regenerate-unicode-properties@10.2.0: dependencies: regenerate: 1.4.2 @@ -18494,6 +19718,11 @@ snapshots: path-parse: 1.0.7 supports-preserve-symlinks-flag: 1.0.0 + restore-cursor@3.1.0: + dependencies: + onetime: 5.1.2 + signal-exit: 3.0.7 + restore-cursor@5.1.0: dependencies: onetime: 7.0.0 @@ -18565,10 +19794,18 @@ snapshots: run-applescript@7.0.0: {} + run-async@2.4.1: {} + + run-async@3.0.0: {} + run-parallel@1.2.0: dependencies: queue-microtask: 1.2.3 + rxjs@7.8.1: + dependencies: + tslib: 2.8.0 + sade@1.8.1: dependencies: mri: 1.2.0 @@ -18602,6 +19839,12 @@ snapshots: sax@1.4.1: optional: true + schema-utils@3.3.0: + dependencies: + '@types/json-schema': 7.0.15 + ajv: 6.12.6 + ajv-keywords: 3.5.2(ajv@6.12.6) + scroll-into-view-if-needed@2.2.31: dependencies: compute-scroll-into-view: 1.0.20 @@ -18855,6 +20098,8 @@ snapshots: stdin-discarder@0.2.2: {} + streamsearch@1.1.0: {} + streamx@2.20.1: dependencies: fast-fifo: 1.3.2 @@ -19135,6 +20380,8 @@ snapshots: csso: 5.0.5 picocolors: 1.1.1 + symbol-observable@4.0.0: {} + synckit@0.6.2: dependencies: tslib: 2.8.0 @@ -19217,6 +20464,15 @@ snapshots: term-size@2.2.1: {} + terser-webpack-plugin@5.3.10(webpack@5.94.0): + dependencies: + '@jridgewell/trace-mapping': 0.3.25 + jest-worker: 27.5.1 + schema-utils: 3.3.0 + serialize-javascript: 6.0.2 + terser: 5.36.0 + webpack: 5.94.0 + terser@5.36.0: dependencies: '@jridgewell/source-map': 0.3.6 @@ -19279,6 +20535,8 @@ snapshots: dependencies: punycode: 2.3.1 + tree-kill@1.2.2: {} + treemate@0.3.11: {} trim-lines@3.0.1: {} @@ -19289,8 +20547,22 @@ snapshots: ts-interface-checker@0.1.13: {} + tsconfig-paths-webpack-plugin@4.1.0: + dependencies: + chalk: 4.1.2 + enhanced-resolve: 5.17.1 + tsconfig-paths: 4.2.0 + + tsconfig-paths@4.2.0: + dependencies: + json5: 2.2.3 + minimist: 1.2.8 + strip-bom: 3.0.0 + tslib@2.3.0: {} + tslib@2.7.0: {} + tslib@2.8.0: {} turbo-darwin-64@2.2.3: @@ -19328,6 +20600,8 @@ snapshots: type-fest@0.20.2: {} + type-fest@0.21.3: {} + type-fest@0.6.0: {} type-fest@0.8.1: {} @@ -19336,6 +20610,11 @@ snapshots: type-fest@4.26.1: {} + type-is@1.6.18: + dependencies: + media-typer: 0.3.0 + mime-types: 2.1.35 + typed-array-buffer@1.0.2: dependencies: call-bind: 1.0.7 @@ -19368,12 +20647,20 @@ snapshots: is-typed-array: 1.1.13 possible-typed-array-names: 1.0.0 + typedarray@0.0.6: {} + + typescript@5.3.3: {} + typescript@5.4.2: {} typescript@5.6.3: {} ufo@1.5.4: {} + uid@2.0.2: + dependencies: + '@lukeed/csprng': 1.1.0 + unbox-primitive@1.0.2: dependencies: call-bind: 1.0.7 @@ -19416,12 +20703,12 @@ snapshots: uncrypto@0.1.3: {} - unctx@2.3.1: + unctx@2.3.1(webpack-sources@3.2.3): dependencies: acorn: 8.13.0 estree-walker: 3.0.3 magic-string: 0.30.12 - unplugin: 1.14.1 + unplugin: 1.14.1(webpack-sources@3.2.3) transitivePeerDependencies: - webpack-sources @@ -19456,7 +20743,7 @@ snapshots: unicorn-magic@0.3.0: {} - unimport@3.13.1(rollup@4.24.0): + unimport@3.13.1(rollup@4.24.0)(webpack-sources@3.2.3): dependencies: '@rollup/pluginutils': 5.1.2(rollup@4.24.0) acorn: 8.13.0 @@ -19470,7 +20757,7 @@ snapshots: pkg-types: 1.2.1 scule: 1.3.0 strip-literal: 2.1.0 - unplugin: 1.14.1 + unplugin: 1.14.1(webpack-sources@3.2.3) transitivePeerDependencies: - rollup - webpack-sources @@ -19514,20 +20801,24 @@ snapshots: universalify@2.0.1: {} - unplugin-element-plus@0.8.0(rollup@4.24.0): + unpipe@1.0.0: {} + + unplugin-element-plus@0.8.0(rollup@4.24.0)(webpack-sources@3.2.3): dependencies: '@rollup/pluginutils': 5.1.2(rollup@4.24.0) es-module-lexer: 1.5.4 magic-string: 0.30.12 - unplugin: 1.14.1 + unplugin: 1.14.1(webpack-sources@3.2.3) transitivePeerDependencies: - rollup - webpack-sources - unplugin@1.14.1: + unplugin@1.14.1(webpack-sources@3.2.3): dependencies: acorn: 8.13.0 webpack-virtual-modules: 0.6.2 + optionalDependencies: + webpack-sources: 3.2.3 unstorage@1.12.0(ioredis@5.4.1): dependencies: @@ -19564,14 +20855,14 @@ snapshots: transitivePeerDependencies: - supports-color - unwasm@0.3.9: + unwasm@0.3.9(webpack-sources@3.2.3): dependencies: knitwork: 1.1.0 magic-string: 0.30.12 mlly: 1.7.2 pathe: 1.1.2 pkg-types: 1.2.1 - unplugin: 1.14.1 + unplugin: 1.14.1(webpack-sources@3.2.3) transitivePeerDependencies: - webpack-sources @@ -19606,11 +20897,15 @@ snapshots: util-deprecate@1.0.2: {} + utils-merge@1.0.1: {} + validate-npm-package-license@3.0.4: dependencies: spdx-correct: 3.2.0 spdx-expression-parse: 3.0.1 + vary@1.1.2: {} + vdirs@0.1.8(vue@3.5.12(typescript@5.6.3)): dependencies: evtd: 0.2.4 @@ -19727,6 +21022,15 @@ snapshots: picocolors: 1.1.1 vite: 5.4.10(@types/node@22.7.9)(less@4.2.0)(sass@1.79.5)(terser@5.36.0) + vite-plugin-node@4.0.0(vite@5.4.10(@types/node@22.7.9)(less@4.2.0)(sass@1.79.5)(terser@5.36.0)): + dependencies: + '@rollup/pluginutils': 4.2.1 + chalk: 4.1.2 + debug: 4.3.7 + vite: 5.4.10(@types/node@22.7.9)(less@4.2.0)(sass@1.79.5)(terser@5.36.0) + transitivePeerDependencies: + - supports-color + vite-plugin-pwa@0.20.5(vite@5.4.10(@types/node@22.7.9)(less@4.2.0)(sass@1.79.5)(terser@5.36.0))(workbox-build@7.1.1)(workbox-window@7.1.0): dependencies: debug: 4.3.7 @@ -19985,16 +21289,59 @@ snapshots: dependencies: loose-envify: 1.4.0 + watchpack@2.4.2: + dependencies: + glob-to-regexp: 0.4.1 + graceful-fs: 4.2.11 + watermark-js-plus@1.5.7: {} + wcwidth@1.0.1: + dependencies: + defaults: 1.0.4 + webidl-conversions@3.0.1: {} webidl-conversions@4.0.2: {} webidl-conversions@7.0.0: {} + webpack-node-externals@3.0.0: {} + + webpack-sources@3.2.3: {} + webpack-virtual-modules@0.6.2: {} + webpack@5.94.0: + dependencies: + '@types/estree': 1.0.6 + '@webassemblyjs/ast': 1.12.1 + '@webassemblyjs/wasm-edit': 1.12.1 + '@webassemblyjs/wasm-parser': 1.12.1 + acorn: 8.13.0 + acorn-import-attributes: 1.9.5(acorn@8.13.0) + browserslist: 4.24.0 + chrome-trace-event: 1.0.4 + enhanced-resolve: 5.17.1 + es-module-lexer: 1.5.4 + eslint-scope: 5.1.1 + events: 3.3.0 + glob-to-regexp: 0.4.1 + graceful-fs: 4.2.11 + json-parse-even-better-errors: 2.3.1 + loader-runner: 4.3.0 + mime-types: 2.1.35 + neo-async: 2.6.2 + schema-utils: 3.3.0 + tapable: 2.2.1 + terser-webpack-plugin: 5.3.10(webpack@5.94.0) + watchpack: 2.4.2 + webpack-sources: 3.2.3 + transitivePeerDependencies: + - '@swc/core' + - esbuild + - uglify-js + whatwg-encoding@3.1.1: dependencies: iconv-lite: 0.6.3 @@ -20207,6 +21554,8 @@ snapshots: xml-name-validator@4.0.0: {} + xtend@4.0.2: {} + y18n@4.0.3: {} y18n@5.0.8: {} @@ -20299,4 +21648,4 @@ snapshots: zx@8.1.9: optionalDependencies: '@types/fs-extra': 11.0.4 - '@types/node': 22.7.8 + '@types/node': 22.7.9 diff --git a/pnpm-workspace.yaml b/pnpm-workspace.yaml index 749652f1c28..d74f7db846f 100644 --- a/pnpm-workspace.yaml +++ b/pnpm-workspace.yaml @@ -13,51 +13,51 @@ packages: - docs - playground catalog: - '@changesets/changelog-github': ^0.5.0 - '@changesets/cli': ^2.27.9 - '@changesets/git': ^3.0.1 - '@clack/prompts': ^0.7.0 - '@commitlint/cli': ^19.5.0 - '@commitlint/config-conventional': ^19.5.0 - '@ctrl/tinycolor': ^4.1.0 - '@eslint/js': ^9.13.0 - '@faker-js/faker': ^9.0.3 - '@iconify/json': ^2.2.263 - '@iconify/tailwind': ^1.1.3 - '@iconify/vue': ^4.1.2 - '@intlify/core-base': ^10.0.4 - '@intlify/unplugin-vue-i18n': ^5.2.0 - '@jspm/generator': ^2.4.1 - '@manypkg/get-packages': ^2.2.2 - '@nolebase/vitepress-plugin-git-changelog': ^2.6.1 - '@playwright/test': ^1.48.1 - '@pnpm/workspace.read-manifest': ^2.2.1 - '@stylistic/stylelint-plugin': ^3.1.1 - '@tailwindcss/nesting': 0.0.0-insiders.565cd3e - '@tailwindcss/typography': ^0.5.15 - '@tanstack/vue-query': ^5.59.16 - '@tanstack/vue-store': ^0.5.6 - '@types/archiver': ^6.0.3 - '@types/eslint': ^9.6.1 - '@types/html-minifier-terser': ^7.0.2 - '@types/jsonwebtoken': ^9.0.7 - '@types/lodash.clonedeep': ^4.5.9 - '@types/node': ^22.7.9 - '@types/nprogress': ^0.2.3 - '@types/postcss-import': ^14.0.3 - '@types/qrcode': ^1.5.5 - '@types/sortablejs': ^1.15.8 - '@typescript-eslint/eslint-plugin': ^8.11.0 - '@typescript-eslint/parser': ^8.11.0 - '@vee-validate/zod': ^4.14.4 - '@vite-pwa/vitepress': ^0.5.3 - '@vitejs/plugin-vue': ^5.1.4 - '@vitejs/plugin-vue-jsx': ^4.0.1 - '@vue/reactivity': ^3.5.12 - '@vue/shared': ^3.5.12 - '@vue/test-utils': ^2.4.6 - '@vueuse/core': ^11.1.0 - '@vueuse/integrations': ^11.1.0 + "@changesets/changelog-github": ^0.5.0 + "@changesets/cli": ^2.27.9 + "@changesets/git": ^3.0.1 + "@clack/prompts": ^0.7.0 + "@commitlint/cli": ^19.5.0 + "@commitlint/config-conventional": ^19.5.0 + "@ctrl/tinycolor": ^4.1.0 + "@eslint/js": ^9.13.0 + "@faker-js/faker": ^9.0.3 + "@iconify/json": ^2.2.263 + "@iconify/tailwind": ^1.1.3 + "@iconify/vue": ^4.1.2 + "@intlify/core-base": ^10.0.4 + "@intlify/unplugin-vue-i18n": ^5.2.0 + "@jspm/generator": ^2.4.1 + "@manypkg/get-packages": ^2.2.2 + "@nolebase/vitepress-plugin-git-changelog": ^2.6.1 + "@playwright/test": ^1.48.1 + "@pnpm/workspace.read-manifest": ^2.2.1 + "@stylistic/stylelint-plugin": ^3.1.1 + "@tailwindcss/nesting": 0.0.0-insiders.565cd3e + "@tailwindcss/typography": ^0.5.15 + "@tanstack/vue-query": ^5.59.16 + "@tanstack/vue-store": ^0.5.6 + "@types/archiver": ^6.0.3 + "@types/eslint": ^9.6.1 + "@types/html-minifier-terser": ^7.0.2 + "@types/jsonwebtoken": ^9.0.7 + "@types/lodash.clonedeep": ^4.5.9 + "@types/node": ^22.7.9 + "@types/nprogress": ^0.2.3 + "@types/postcss-import": ^14.0.3 + "@types/qrcode": ^1.5.5 + "@types/sortablejs": ^1.15.8 + "@typescript-eslint/eslint-plugin": ^8.11.0 + "@typescript-eslint/parser": ^8.11.0 + "@vee-validate/zod": ^4.14.4 + "@vite-pwa/vitepress": ^0.5.3 + "@vitejs/plugin-vue": ^5.1.4 + "@vitejs/plugin-vue-jsx": ^4.0.1 + "@vue/reactivity": ^3.5.12 + "@vue/shared": ^3.5.12 + "@vue/test-utils": ^2.4.6 + "@vueuse/core": ^11.1.0 + "@vueuse/integrations": ^11.1.0 ant-design-vue: ^4.2.5 archiver: ^7.0.1 autoprefixer: ^10.4.20 @@ -163,6 +163,7 @@ catalog: vite-plugin-html: ^3.2.2 vite-plugin-lazy-import: ^1.0.7 vite-plugin-lib-inject-css: ^2.1.1 + vite-plugin-node: ^4.0.0 vite-plugin-pwa: ^0.20.5 vite-plugin-vue-devtools: ^7.5.3 vitepress: ^1.4.1 diff --git a/scripts/vsh/src/check-dep/index.ts b/scripts/vsh/src/check-dep/index.ts index 762622995ec..50c72177433 100644 --- a/scripts/vsh/src/check-dep/index.ts +++ b/scripts/vsh/src/check-dep/index.ts @@ -32,6 +32,7 @@ async function runDepcheck() { 'vite', 'vitest', 'unbuild', + '@nestjs/cli', '@vben/tsconfig', '@vben/vite-config', '@vben/tailwind-config', diff --git a/vben-admin.code-workspace b/vben-admin.code-workspace index aa8205bda73..cf07387100d 100644 --- a/vben-admin.code-workspace +++ b/vben-admin.code-workspace @@ -4,6 +4,10 @@ "name": "@vben/backend-mock", "path": "apps/backend-mock", }, + { + "name": "@vben/backend-nest", + "path": "apps/backend-nest", + }, { "name": "@vben/web-antd", "path": "apps/web-antd", From d13a6257df2d4d0970bb4fc463d330414f00d409 Mon Sep 17 00:00:00 2001 From: Dlovely <591562538@qq.com> Date: Sun, 27 Oct 2024 18:11:29 +0800 Subject: [PATCH 2/9] =?UTF-8?q?feat:=20=E5=85=81=E8=AE=B8=E4=BD=BF?= =?UTF-8?q?=E7=94=A8swc=E7=BC=96=E8=AF=91,=20=E5=B9=B6=E6=8F=90=E4=BE=9B?= =?UTF-8?q?=E6=A8=A1=E6=9D=BF=E9=85=8D=E7=BD=AE?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- apps/backend-nest/.env.development | 3 + apps/backend-nest/.env.production | 3 + internal/vite-config/package.json | 1 + internal/vite-config/src/plugins/index.ts | 12 +- internal/vite-config/src/typing.ts | 5 + internal/vite-config/src/utils/env.ts | 2 + pnpm-lock.yaml | 168 ++++++++++++++++++++-- pnpm-workspace.yaml | 1 + 8 files changed, 182 insertions(+), 13 deletions(-) diff --git a/apps/backend-nest/.env.development b/apps/backend-nest/.env.development index d3ee1095d0f..f462586e469 100644 --- a/apps/backend-nest/.env.development +++ b/apps/backend-nest/.env.development @@ -1,2 +1,5 @@ # 端口号 VITE_PORT=5777 + +# 是否开启 SWC +VITE_SWC=true diff --git a/apps/backend-nest/.env.production b/apps/backend-nest/.env.production index 21cc3e759f3..86969148c8e 100644 --- a/apps/backend-nest/.env.production +++ b/apps/backend-nest/.env.production @@ -1,2 +1,5 @@ # 端口号 VITE_PORT=3000 + +# 是否开启 SWC +VITE_SWC=false diff --git a/internal/vite-config/package.json b/internal/vite-config/package.json index 72036366802..fcb4a21aae2 100644 --- a/internal/vite-config/package.json +++ b/internal/vite-config/package.json @@ -41,6 +41,7 @@ }, "devDependencies": { "@pnpm/workspace.read-manifest": "catalog:", + "@swc/core": "catalog:", "@types/archiver": "catalog:", "@types/html-minifier-terser": "catalog:", "@vben/node-utils": "workspace:*", diff --git a/internal/vite-config/src/plugins/index.ts b/internal/vite-config/src/plugins/index.ts index 29b7530d359..fa52cd6c47f 100644 --- a/internal/vite-config/src/plugins/index.ts +++ b/internal/vite-config/src/plugins/index.ts @@ -250,7 +250,15 @@ async function loadServerPlugins( ): Promise { // 单独取,否则commonOptions拿不到 const isBuild = options.isBuild; - const { appName, dts, exportName, immediate, ...commonOptions } = options; + const { + appName, + dts, + exportName, + immediate, + swc, + swcOptions, + ...commonOptions + } = options; const { adapter, appPath } = options as Required; const commonPlugins = await loadCommonPlugins(commonOptions); return await loadConditionPlugins([ @@ -269,6 +277,8 @@ async function loadServerPlugins( exportName, initAppOnBoot: immediate, outputFormat: 'esm', + swcOptions, + tsCompiler: swc ? 'swc' : 'esbuild', }), ], }, diff --git a/internal/vite-config/src/typing.ts b/internal/vite-config/src/typing.ts index 6827bf9fb56..2ec879d2caa 100644 --- a/internal/vite-config/src/typing.ts +++ b/internal/vite-config/src/typing.ts @@ -1,3 +1,4 @@ +import type { Options as SwcPluginOptions } from '@swc/core'; import type { PluginVisualizerOptions } from 'rollup-plugin-visualizer'; import type { ConfigEnv, PluginOption, UserConfig } from 'vite'; import type { PluginOptions } from 'vite-plugin-dts'; @@ -151,6 +152,10 @@ interface ServerPluginOptions extends CommonPluginOptions { exportName?: string; /** 立即启动 */ immediate?: boolean; + /** 是否开启swc */ + swc?: boolean; + /** swc 插件配置 */ + swcOptions?: SwcPluginOptions; } type ApplicationOptions = ApplicationPluginOptions; diff --git a/internal/vite-config/src/utils/env.ts b/internal/vite-config/src/utils/env.ts index b05356b5f82..3fe1749b6f4 100644 --- a/internal/vite-config/src/utils/env.ts +++ b/internal/vite-config/src/utils/env.ts @@ -116,6 +116,7 @@ async function loadServerEnv(match = 'VITE_', confFiles = getConfFiles()) { VITE_EXPORT_NAME, VITE_IMMEDIATE, VITE_PORT, + VITE_SWC, VITE_VISUALIZER, } = envConfig; @@ -126,6 +127,7 @@ async function loadServerEnv(match = 'VITE_', confFiles = getConfFiles()) { exportName: getString(VITE_EXPORT_NAME, 'default'), immediate: getBoolean(VITE_IMMEDIATE), port: getNumber(VITE_PORT, 5173), + swc: getBoolean(VITE_SWC), visualizer: getBoolean(VITE_VISUALIZER), } satisfies { port: number; diff --git a/pnpm-lock.yaml b/pnpm-lock.yaml index c6db08a48f2..c0ae881df52 100644 --- a/pnpm-lock.yaml +++ b/pnpm-lock.yaml @@ -63,6 +63,9 @@ catalogs: '@stylistic/stylelint-plugin': specifier: ^3.1.1 version: 3.1.1 + '@swc/core': + specifier: ^1.7.40 + version: 1.7.40 '@tailwindcss/nesting': specifier: 0.0.0-insiders.565cd3e version: 0.0.0-insiders.565cd3e @@ -639,7 +642,7 @@ importers: devDependencies: '@nestjs/cli': specifier: ^10.0.0 - version: 10.4.5 + version: 10.4.5(@swc/core@1.7.40(@swc/helpers@0.5.13)) '@types/express': specifier: ^4.17.17 version: 4.17.21 @@ -1165,6 +1168,9 @@ importers: '@pnpm/workspace.read-manifest': specifier: 'catalog:' version: 2.2.1 + '@swc/core': + specifier: 'catalog:' + version: 1.7.40(@swc/helpers@0.5.13) '@types/archiver': specifier: 'catalog:' version: 6.0.3 @@ -1212,7 +1218,7 @@ importers: version: 1.0.7 vite-plugin-node: specifier: 'catalog:' - version: 4.0.0(vite@5.4.10(@types/node@22.7.9)(less@4.2.0)(sass@1.79.5)(terser@5.36.0)) + version: 4.0.0(@swc/core@1.7.40(@swc/helpers@0.5.13))(vite@5.4.10(@types/node@22.7.9)(less@4.2.0)(sass@1.79.5)(terser@5.36.0)) packages/@core/base/design: {} @@ -4601,9 +4607,88 @@ packages: '@surma/rollup-plugin-off-main-thread@2.2.3': resolution: {integrity: sha512-lR8q/9W7hZpMWweNiAKU7NQerBnzQQLvi8qnTDU/fxItPhtZVMbPV3lbCwjhIlNBe9Bbr5V+KHshvWmVSG9cxQ==} + '@swc/core-darwin-arm64@1.7.40': + resolution: {integrity: sha512-LRRrCiRJLb1kpQtxMNNsr5W82Inr0dy5Imho+4HQzVx/Ismi0qX4hQBgzJAnyOBNLK1+OBVb/912UVhKXppdfQ==} + engines: {node: '>=10'} + cpu: [arm64] + os: [darwin] + + '@swc/core-darwin-x64@1.7.40': + resolution: {integrity: sha512-Lpl0XK/4fLzS5jsK48opUuGXrqJXwqJckYYPwyGbCfCXm4MsBe+7dX2hq/Kc4YMY25+NeTmzAXhla8TT4WYD/g==} + engines: {node: '>=10'} + cpu: [x64] + os: [darwin] + + '@swc/core-linux-arm-gnueabihf@1.7.40': + resolution: {integrity: sha512-4bEvvjptpoc5BRPr/R419h6fXTEuub+frpxxlxBOEKxgXjAF/S3xdxyPijUAakmW/xXBF0u7OC4KYI+38yQp6g==} + engines: {node: '>=10'} + cpu: [arm] + os: [linux] + + '@swc/core-linux-arm64-gnu@1.7.40': + resolution: {integrity: sha512-v2fBlHJ/6Ovz0L2xFAI9TRiKyl9DTdx139PuAHD9gyzp16Utl/W0MPd4t2cYdkI6hPXE9PsJCSzMOrduh+YoDg==} + engines: {node: '>=10'} + cpu: [arm64] + os: [linux] + libc: [glibc] + + '@swc/core-linux-arm64-musl@1.7.40': + resolution: {integrity: sha512-uMkduQuU4LFVkW6txv8AVArT8GjJVJ5IHoWloXaUBMT447iE8NALmpePdZWhMyj6KV7j0y23CM5rzV/I2eNGLg==} + engines: {node: '>=10'} + cpu: [arm64] + os: [linux] + libc: [musl] + + '@swc/core-linux-x64-gnu@1.7.40': + resolution: {integrity: sha512-4LZdY1MBSnXyTpW5fpBU/+JGAhkuHT+VnFTDNegRboN5nSPh7y0Yvn4LmIioESV+sWzjKkEXujJPGjrp+oSp5w==} + engines: {node: '>=10'} + cpu: [x64] + os: [linux] + libc: [glibc] + + '@swc/core-linux-x64-musl@1.7.40': + resolution: {integrity: sha512-FPjOwT3SgI6PAwH1O8bhOGBPzuvzOlzKeCtxLaCjruHJu9V8KKBrMTWOZT/FJyYC9mX5Ip1+l9j30UqUZdQxtA==} + engines: {node: '>=10'} + cpu: [x64] + os: [linux] + libc: [musl] + + '@swc/core-win32-arm64-msvc@1.7.40': + resolution: {integrity: sha512-//ovXdD9GsTmhPmXJlXnIbRQkeuL6PSrYSr7uCMNcclrUdJG0YkO0GMM2afUKYbdJcunylDDWsSS8PFWn0QxmA==} + engines: {node: '>=10'} + cpu: [arm64] + os: [win32] + + '@swc/core-win32-ia32-msvc@1.7.40': + resolution: {integrity: sha512-iD/1auVhHGlhWAPrWmfRWL3w4AvXIWGVXZiSA109/xnRIPiHKb/HqqTp/qB94E/ZHMPRgLKkLTNwamlkueUs8g==} + engines: {node: '>=10'} + cpu: [ia32] + os: [win32] + + '@swc/core-win32-x64-msvc@1.7.40': + resolution: {integrity: sha512-ZlFAV1WFPhhWQ/8esiygmetkb905XIcMMtHRRG0FBGCllO+HVL5nikUaLDgTClz1onmEY9sMXUFQeoPtvliV+w==} + engines: {node: '>=10'} + cpu: [x64] + os: [win32] + + '@swc/core@1.7.40': + resolution: {integrity: sha512-0HIzM5vigVT5IvNum+pPuST9p8xFhN6mhdIKju7qYYeNuZG78lwms/2d8WgjTJJlzp6JlPguXGrMMNzjQw0qNg==} + engines: {node: '>=10'} + peerDependencies: + '@swc/helpers': '*' + peerDependenciesMeta: + '@swc/helpers': + optional: true + + '@swc/counter@0.1.3': + resolution: {integrity: sha512-e2BR4lsJkkRlKZ/qCHPw9ZaSxc0MVUd7gtbtaB7aMvHeJVYe8sOB8DBZkP2DtISHGSku9sCK6T6cnY0CtXrOCQ==} + '@swc/helpers@0.5.13': resolution: {integrity: sha512-UoKGxQ3r5kYI9dALKJapMmuK+1zWM/H17Z1+iwnNmzcJRnfFuevZs375TA5rW31pu4BS4NoSy1fRsexDXfWn5w==} + '@swc/types@0.1.13': + resolution: {integrity: sha512-JL7eeCk6zWCbiYQg2xQSdLXQJl8Qoc9rXmG2cEKvHe3CKwMHwHGpfOb8frzNLmbycOo6I51qxnLnn9ESf4I20Q==} + '@sxzz/popperjs-es@2.11.7': resolution: {integrity: sha512-Ccy0NlLkzr0Ex2FKvh2X+OyERHXJ88XJ1MXtsI9y9fGexlaXaVTPzBCRBwIxFkORuOb+uBqeu+RqnpgYTEZRUQ==} @@ -13522,7 +13607,7 @@ snapshots: '@microsoft/tsdoc@0.15.0': {} - '@nestjs/cli@10.4.5': + '@nestjs/cli@10.4.5(@swc/core@1.7.40(@swc/helpers@0.5.13))': dependencies: '@angular-devkit/core': 17.3.8(chokidar@3.6.0) '@angular-devkit/schematics': 17.3.8(chokidar@3.6.0) @@ -13532,7 +13617,7 @@ snapshots: chokidar: 3.6.0 cli-table3: 0.6.5 commander: 4.1.1 - fork-ts-checker-webpack-plugin: 9.0.2(typescript@5.3.3)(webpack@5.94.0) + fork-ts-checker-webpack-plugin: 9.0.2(typescript@5.3.3)(webpack@5.94.0(@swc/core@1.7.40(@swc/helpers@0.5.13))) glob: 10.4.2 inquirer: 8.2.6 node-emoji: 1.11.0 @@ -13541,8 +13626,10 @@ snapshots: tsconfig-paths: 4.2.0 tsconfig-paths-webpack-plugin: 4.1.0 typescript: 5.3.3 - webpack: 5.94.0 + webpack: 5.94.0(@swc/core@1.7.40(@swc/helpers@0.5.13)) webpack-node-externals: 3.0.0 + optionalDependencies: + '@swc/core': 1.7.40(@swc/helpers@0.5.13) transitivePeerDependencies: - esbuild - uglify-js @@ -14162,10 +14249,63 @@ snapshots: magic-string: 0.25.9 string.prototype.matchall: 4.0.11 + '@swc/core-darwin-arm64@1.7.40': + optional: true + + '@swc/core-darwin-x64@1.7.40': + optional: true + + '@swc/core-linux-arm-gnueabihf@1.7.40': + optional: true + + '@swc/core-linux-arm64-gnu@1.7.40': + optional: true + + '@swc/core-linux-arm64-musl@1.7.40': + optional: true + + '@swc/core-linux-x64-gnu@1.7.40': + optional: true + + '@swc/core-linux-x64-musl@1.7.40': + optional: true + + '@swc/core-win32-arm64-msvc@1.7.40': + optional: true + + '@swc/core-win32-ia32-msvc@1.7.40': + optional: true + + '@swc/core-win32-x64-msvc@1.7.40': + optional: true + + '@swc/core@1.7.40(@swc/helpers@0.5.13)': + dependencies: + '@swc/counter': 0.1.3 + '@swc/types': 0.1.13 + optionalDependencies: + '@swc/core-darwin-arm64': 1.7.40 + '@swc/core-darwin-x64': 1.7.40 + '@swc/core-linux-arm-gnueabihf': 1.7.40 + '@swc/core-linux-arm64-gnu': 1.7.40 + '@swc/core-linux-arm64-musl': 1.7.40 + '@swc/core-linux-x64-gnu': 1.7.40 + '@swc/core-linux-x64-musl': 1.7.40 + '@swc/core-win32-arm64-msvc': 1.7.40 + '@swc/core-win32-ia32-msvc': 1.7.40 + '@swc/core-win32-x64-msvc': 1.7.40 + '@swc/helpers': 0.5.13 + + '@swc/counter@0.1.3': {} + '@swc/helpers@0.5.13': dependencies: tslib: 2.8.0 + '@swc/types@0.1.13': + dependencies: + '@swc/counter': 0.1.3 + '@sxzz/popperjs-es@2.11.7': {} '@tailwindcss/nesting@0.0.0-insiders.565cd3e(postcss@8.4.47)': @@ -17066,7 +17206,7 @@ snapshots: cross-spawn: 7.0.3 signal-exit: 4.1.0 - fork-ts-checker-webpack-plugin@9.0.2(typescript@5.3.3)(webpack@5.94.0): + fork-ts-checker-webpack-plugin@9.0.2(typescript@5.3.3)(webpack@5.94.0(@swc/core@1.7.40(@swc/helpers@0.5.13))): dependencies: '@babel/code-frame': 7.25.7 chalk: 4.1.2 @@ -17081,7 +17221,7 @@ snapshots: semver: 7.6.3 tapable: 2.2.1 typescript: 5.3.3 - webpack: 5.94.0 + webpack: 5.94.0(@swc/core@1.7.40(@swc/helpers@0.5.13)) form-data@4.0.1: dependencies: @@ -20464,14 +20604,16 @@ snapshots: term-size@2.2.1: {} - terser-webpack-plugin@5.3.10(webpack@5.94.0): + terser-webpack-plugin@5.3.10(@swc/core@1.7.40(@swc/helpers@0.5.13))(webpack@5.94.0(@swc/core@1.7.40(@swc/helpers@0.5.13))): dependencies: '@jridgewell/trace-mapping': 0.3.25 jest-worker: 27.5.1 schema-utils: 3.3.0 serialize-javascript: 6.0.2 terser: 5.36.0 - webpack: 5.94.0 + webpack: 5.94.0(@swc/core@1.7.40(@swc/helpers@0.5.13)) + optionalDependencies: + '@swc/core': 1.7.40(@swc/helpers@0.5.13) terser@5.36.0: dependencies: @@ -21022,12 +21164,14 @@ snapshots: picocolors: 1.1.1 vite: 5.4.10(@types/node@22.7.9)(less@4.2.0)(sass@1.79.5)(terser@5.36.0) - vite-plugin-node@4.0.0(vite@5.4.10(@types/node@22.7.9)(less@4.2.0)(sass@1.79.5)(terser@5.36.0)): + vite-plugin-node@4.0.0(@swc/core@1.7.40(@swc/helpers@0.5.13))(vite@5.4.10(@types/node@22.7.9)(less@4.2.0)(sass@1.79.5)(terser@5.36.0)): dependencies: '@rollup/pluginutils': 4.2.1 chalk: 4.1.2 debug: 4.3.7 vite: 5.4.10(@types/node@22.7.9)(less@4.2.0)(sass@1.79.5)(terser@5.36.0) + optionalDependencies: + '@swc/core': 1.7.40(@swc/helpers@0.5.13) transitivePeerDependencies: - supports-color @@ -21312,7 +21456,7 @@ snapshots: webpack-virtual-modules@0.6.2: {} - webpack@5.94.0: + webpack@5.94.0(@swc/core@1.7.40(@swc/helpers@0.5.13)): dependencies: '@types/estree': 1.0.6 '@webassemblyjs/ast': 1.12.1 @@ -21334,7 +21478,7 @@ snapshots: neo-async: 2.6.2 schema-utils: 3.3.0 tapable: 2.2.1 - terser-webpack-plugin: 5.3.10(webpack@5.94.0) + terser-webpack-plugin: 5.3.10(@swc/core@1.7.40(@swc/helpers@0.5.13))(webpack@5.94.0(@swc/core@1.7.40(@swc/helpers@0.5.13))) watchpack: 2.4.2 webpack-sources: 3.2.3 transitivePeerDependencies: diff --git a/pnpm-workspace.yaml b/pnpm-workspace.yaml index d74f7db846f..e5db9af03f2 100644 --- a/pnpm-workspace.yaml +++ b/pnpm-workspace.yaml @@ -33,6 +33,7 @@ catalog: "@playwright/test": ^1.48.1 "@pnpm/workspace.read-manifest": ^2.2.1 "@stylistic/stylelint-plugin": ^3.1.1 + "@swc/core": ^1.7.40 "@tailwindcss/nesting": 0.0.0-insiders.565cd3e "@tailwindcss/typography": ^0.5.15 "@tanstack/vue-query": ^5.59.16 From adb6337ced32cdd6a74982489f46f7dd499f81d5 Mon Sep 17 00:00:00 2001 From: Dlovely <591562538@qq.com> Date: Tue, 29 Oct 2024 17:48:35 +0800 Subject: [PATCH 3/9] =?UTF-8?q?feat:=20=E6=8F=90=E4=BE=9BJWT=E9=AA=8C?= =?UTF-8?q?=E8=AF=81=E5=8F=8A=E9=89=B4=E6=9D=83?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- apps/backend-nest/.env.development | 3 + apps/backend-nest/.env.production | 3 + apps/backend-nest/package.json | 14 +- apps/backend-nest/src/app/index.module.ts | 8 +- apps/backend-nest/src/app/index.ts | 6 + apps/backend-nest/src/auth/index.module.ts | 19 ++ apps/backend-nest/src/auth/index.service.ts | 90 ++++++ apps/backend-nest/src/auth/index.ts | 4 + apps/backend-nest/src/auth/jwt.strategy.ts | 18 ++ apps/backend-nest/src/auth/local.strategy.ts | 22 ++ apps/backend-nest/src/guards/auth.guard.ts | 30 ++ apps/backend-nest/src/guards/index.ts | 15 + apps/backend-nest/src/plugins/cookies.ts | 28 ++ apps/backend-nest/src/plugins/index.ts | 8 + .../src/routes/auth.controller.ts | 94 ++++++ apps/backend-nest/src/routes/index.ts | 13 + .../src/routes/user.controller.ts | 11 + apps/backend-nest/src/utils/cookie-utils.ts | 18 ++ apps/backend-nest/src/utils/mock-data.ts | 186 ++++++++++++ pnpm-lock.yaml | 267 +++++++++++++++++- 20 files changed, 845 insertions(+), 12 deletions(-) create mode 100644 apps/backend-nest/src/auth/index.module.ts create mode 100644 apps/backend-nest/src/auth/index.service.ts create mode 100644 apps/backend-nest/src/auth/index.ts create mode 100644 apps/backend-nest/src/auth/jwt.strategy.ts create mode 100644 apps/backend-nest/src/auth/local.strategy.ts create mode 100644 apps/backend-nest/src/guards/auth.guard.ts create mode 100644 apps/backend-nest/src/guards/index.ts create mode 100644 apps/backend-nest/src/plugins/cookies.ts create mode 100644 apps/backend-nest/src/plugins/index.ts create mode 100644 apps/backend-nest/src/routes/auth.controller.ts create mode 100644 apps/backend-nest/src/routes/index.ts create mode 100644 apps/backend-nest/src/routes/user.controller.ts create mode 100644 apps/backend-nest/src/utils/cookie-utils.ts create mode 100644 apps/backend-nest/src/utils/mock-data.ts diff --git a/apps/backend-nest/.env.development b/apps/backend-nest/.env.development index f462586e469..cf1244b427d 100644 --- a/apps/backend-nest/.env.development +++ b/apps/backend-nest/.env.development @@ -3,3 +3,6 @@ VITE_PORT=5777 # 是否开启 SWC VITE_SWC=true + +# JWT密钥 +VITE_JWT_SECRET=your_jwt_secret diff --git a/apps/backend-nest/.env.production b/apps/backend-nest/.env.production index 86969148c8e..81e05c869ff 100644 --- a/apps/backend-nest/.env.production +++ b/apps/backend-nest/.env.production @@ -3,3 +3,6 @@ VITE_PORT=3000 # 是否开启 SWC VITE_SWC=false + +# JWT密钥 +VITE_JWT_SECRET=your_jwt_secret diff --git a/apps/backend-nest/package.json b/apps/backend-nest/package.json index 5e137807eaf..165fda47706 100644 --- a/apps/backend-nest/package.json +++ b/apps/backend-nest/package.json @@ -15,13 +15,25 @@ "dependencies": { "@nestjs/common": "^10.0.0", "@nestjs/core": "^10.0.0", + "@nestjs/jwt": "^10.2.0", + "@nestjs/passport": "^10.0.3", "@nestjs/platform-express": "^10.0.0", + "@nestjs/swagger": "^8.0.0", + "class-transformer": "^0.5.1", + "class-validator": "^0.14.1", + "cookie-parser": "^1.4.7", + "passport": "^0.7.0", + "passport-jwt": "^4.0.1", + "passport-local": "^1.0.0", "reflect-metadata": "^0.2.0", "rxjs": "^7.8.1" }, "devDependencies": { "@nestjs/cli": "^10.0.0", + "@types/cookie-parser": "^1.4.7", "@types/express": "^4.17.17", - "@types/node": "catalog:" + "@types/node": "catalog:", + "@types/passport-jwt": "^4.0.1", + "@types/passport-local": "^1.0.38" } } diff --git a/apps/backend-nest/src/app/index.module.ts b/apps/backend-nest/src/app/index.module.ts index c972661300f..983fb37340a 100644 --- a/apps/backend-nest/src/app/index.module.ts +++ b/apps/backend-nest/src/app/index.module.ts @@ -1,5 +1,11 @@ import { Module } from '@nestjs/common'; -@Module({}) +import guards from '#/guards'; +import { RoutesModule } from '#/routes'; + +@Module({ + imports: [RoutesModule], + providers: [...guards], +}) // eslint-disable-next-line @typescript-eslint/no-extraneous-class export class AppModule {} diff --git a/apps/backend-nest/src/app/index.ts b/apps/backend-nest/src/app/index.ts index e4c58a329e8..e1feac61bfb 100644 --- a/apps/backend-nest/src/app/index.ts +++ b/apps/backend-nest/src/app/index.ts @@ -2,6 +2,8 @@ import type { INestApplication } from '@nestjs/common'; import { NestFactory } from '@nestjs/core'; +import plugins from '#/plugins'; + import { AppModule } from './index.module'; let app: INestApplication; @@ -11,6 +13,10 @@ async function createApp() { app.enableCors(); + for (const plugin of plugins) { + app.use(plugin); + } + return app; } diff --git a/apps/backend-nest/src/auth/index.module.ts b/apps/backend-nest/src/auth/index.module.ts new file mode 100644 index 00000000000..14d20be548b --- /dev/null +++ b/apps/backend-nest/src/auth/index.module.ts @@ -0,0 +1,19 @@ +import { Module } from '@nestjs/common'; +import { JwtModule } from '@nestjs/jwt'; +import { PassportModule } from '@nestjs/passport'; + +import { AuthService } from './index.service'; +import { JwtStrategy } from './jwt.strategy'; +import { LocalStrategy } from './local.strategy'; + +@Module({ + imports: [ + PassportModule, + JwtModule.register({ + secret: import.meta.env.VITE_JWT_SECRET, + }), + ], + providers: [AuthService, LocalStrategy, JwtStrategy], +}) +// eslint-disable-next-line @typescript-eslint/no-extraneous-class +export class AuthModule {} diff --git a/apps/backend-nest/src/auth/index.service.ts b/apps/backend-nest/src/auth/index.service.ts new file mode 100644 index 00000000000..60b24aa9422 --- /dev/null +++ b/apps/backend-nest/src/auth/index.service.ts @@ -0,0 +1,90 @@ +import { Injectable } from '@nestjs/common'; +import { JwtService } from '@nestjs/jwt'; + +export interface UserInfo { + id: number; + password: string; + realName: string; + roles: string[]; + username: string; +} + +@Injectable() +export class AuthService { + // TODO: Replace with your own secret key + static ACCESS_TOKEN_SECRET = 'access_token_secret'; + static MOCK_CODES = [ + // super + { + codes: ['AC_100100', 'AC_100110', 'AC_100120', 'AC_100010'], + username: 'vben', + }, + { + // admin + codes: ['AC_100010', 'AC_100020', 'AC_100030'], + username: 'admin', + }, + { + // user + codes: ['AC_1000001', 'AC_1000002'], + username: 'jack', + }, + ]; + static MOCK_USERS: UserInfo[] = [ + { + id: 0, + password: '123456', + realName: 'Vben', + roles: ['super'], + username: 'vben', + }, + { + id: 1, + password: '123456', + realName: 'Admin', + roles: ['admin'], + username: 'admin', + }, + { + id: 2, + password: '123456', + realName: 'Jack', + roles: ['user'], + username: 'jack', + }, + ]; + static REFRESH_TOKEN_SECRET = 'refresh_token_secret'; + + constructor(private readonly JwtService: JwtService) {} + + public getAccessToken(user: UserInfo) { + return this.JwtService.sign(user, { + expiresIn: '7d', + }); + } + + public getRefreshToken(user: UserInfo) { + return this.JwtService.sign(user, { + expiresIn: '30d', + }); + } + + public async validateUser(username: string, password: string) { + const findUser = AuthService.MOCK_USERS.find( + (item) => item.username === username && item.password === password, + ); + + if (!findUser) { + return; + } + + return findUser; + } +} + +declare global { + export namespace Express { + // eslint-disable-next-line @typescript-eslint/no-empty-object-type + export interface User extends UserInfo {} + } +} diff --git a/apps/backend-nest/src/auth/index.ts b/apps/backend-nest/src/auth/index.ts new file mode 100644 index 00000000000..b361db1cf35 --- /dev/null +++ b/apps/backend-nest/src/auth/index.ts @@ -0,0 +1,4 @@ +export { AuthModule } from './index.module'; +export { AuthService } from './index.service'; + +export type { UserInfo } from './index.service'; diff --git a/apps/backend-nest/src/auth/jwt.strategy.ts b/apps/backend-nest/src/auth/jwt.strategy.ts new file mode 100644 index 00000000000..93ba6568b65 --- /dev/null +++ b/apps/backend-nest/src/auth/jwt.strategy.ts @@ -0,0 +1,18 @@ +import { Injectable } from '@nestjs/common'; +import { PassportStrategy } from '@nestjs/passport'; +import { ExtractJwt, Strategy } from 'passport-jwt'; + +@Injectable() +export class JwtStrategy extends PassportStrategy(Strategy) { + constructor() { + super({ + jwtFromRequest: ExtractJwt.fromAuthHeaderAsBearerToken(), + ignoreExpiration: false, + secretOrKey: import.meta.env.VITE_JWT_SECRET, + }); + } + + async validate(payload: any) { + return { ...payload }; + } +} diff --git a/apps/backend-nest/src/auth/local.strategy.ts b/apps/backend-nest/src/auth/local.strategy.ts new file mode 100644 index 00000000000..e1aafae6cc9 --- /dev/null +++ b/apps/backend-nest/src/auth/local.strategy.ts @@ -0,0 +1,22 @@ +import { Injectable, UnauthorizedException } from '@nestjs/common'; +import { PassportStrategy } from '@nestjs/passport'; +import { Strategy } from 'passport-local'; + +import { AuthService } from './index.service'; + +@Injectable() +export class LocalStrategy extends PassportStrategy(Strategy) { + constructor(private readonly AuthService: AuthService) { + super(); + } + + async validate(username: string, password: string): Promise { + const findUser = await this.AuthService.validateUser(username, password); + + if (!findUser) { + throw new UnauthorizedException(); + } + + return findUser; + } +} diff --git a/apps/backend-nest/src/guards/auth.guard.ts b/apps/backend-nest/src/guards/auth.guard.ts new file mode 100644 index 00000000000..34f082b3c69 --- /dev/null +++ b/apps/backend-nest/src/guards/auth.guard.ts @@ -0,0 +1,30 @@ +import type { Reflector } from '@nestjs/core'; + +import { type ExecutionContext, Injectable, SetMetadata } from '@nestjs/common'; +import { AuthGuard } from '@nestjs/passport'; + +const IS_PUBLIC_KEY = 'isPublic'; +export const Public = () => SetMetadata(IS_PUBLIC_KEY, true); + +@Injectable() +export class JwtAuthGuard extends AuthGuard('jwt') { + constructor(private readonly Reflector: Reflector) { + super(); + } + + override canActivate(context: ExecutionContext) { + const isPublic = this.Reflector.getAllAndOverride(IS_PUBLIC_KEY, [ + context.getHandler(), + context.getClass(), + ]); + + if (isPublic) { + return true; + } + + return super.canActivate(context); + } +} + +// 默认导出,便于glob导入 +export default JwtAuthGuard; diff --git a/apps/backend-nest/src/guards/index.ts b/apps/backend-nest/src/guards/index.ts new file mode 100644 index 00000000000..798a3aafd13 --- /dev/null +++ b/apps/backend-nest/src/guards/index.ts @@ -0,0 +1,15 @@ +import type { ClassProvider, Type } from '@nestjs/common'; + +import { APP_GUARD } from '@nestjs/core'; + +const glob_result = import.meta.glob('./*.guard.ts', { + import: 'default', + eager: true, +}); + +export default Object.values(glob_result).map((useClass) => ({ + provide: APP_GUARD, + useClass, +})); + +export { Public } from './auth.guard'; diff --git a/apps/backend-nest/src/plugins/cookies.ts b/apps/backend-nest/src/plugins/cookies.ts new file mode 100644 index 00000000000..84396746c76 --- /dev/null +++ b/apps/backend-nest/src/plugins/cookies.ts @@ -0,0 +1,28 @@ +import { createParamDecorator, type ExecutionContext } from '@nestjs/common'; +import cookieParser from 'cookie-parser'; + +export default cookieParser(); + +export const Cookies = createParamDecorator( + (data: string, ctx: ExecutionContext) => { + const request: Express.Request = ctx.switchToHttp().getRequest(); + return data ? request.cookies?.[data] : request.cookies; + }, +); + +declare global { + export namespace Express { + export interface Request { + /** + * 请求密钥 + * [可选] 如果向`cookie-parser`传递了密钥,则此属性将包含密钥。 + * 可以被其他中间件使用 + */ + secret?: string | undefined; + /** 解析尚未签名的cookie */ + cookies: Record; + /** 解析已签名的cookie */ + signedCookies: Record; + } + } +} diff --git a/apps/backend-nest/src/plugins/index.ts b/apps/backend-nest/src/plugins/index.ts new file mode 100644 index 00000000000..8ba79429d1a --- /dev/null +++ b/apps/backend-nest/src/plugins/index.ts @@ -0,0 +1,8 @@ +const glob_result = import.meta.glob(['./*.ts', '!./index.ts'], { + import: 'default', + eager: true, +}); + +export default Object.values(glob_result); + +export { Cookies } from './cookies'; diff --git a/apps/backend-nest/src/routes/auth.controller.ts b/apps/backend-nest/src/routes/auth.controller.ts new file mode 100644 index 00000000000..24a337acaea --- /dev/null +++ b/apps/backend-nest/src/routes/auth.controller.ts @@ -0,0 +1,94 @@ +import type { UserInfo } from '#/auth'; + +import { + All, + Controller, + ForbiddenException, + Post, + Request, + Response, + UseGuards, +} from '@nestjs/common'; +import { JwtService } from '@nestjs/jwt'; +import { AuthGuard } from '@nestjs/passport'; + +import { AuthService } from '#/auth'; +import { Public } from '#/guards'; +import { Cookies } from '#/plugins'; +import { + clearRefreshTokenCookie, + setRefreshTokenCookie, +} from '#/utils/cookie-utils'; + +@Controller('auth') +export class AuthController { + constructor( + private readonly AuthService: AuthService, + private readonly JwtService: JwtService, + ) {} + + @All('codes') + public codes(@Request() req: Express.Request) { + const codes = AuthService.MOCK_CODES.find( + (item) => item.username === (req.user as Express.User).username, + )?.codes; + + return codes ?? []; + } + + @UseGuards(AuthGuard('local')) + @Public() + @Post('login') + public login(@Request() req: Express.Request, @Response() res: any) { + // 生成令牌 + const accessToken = this.AuthService.getAccessToken( + req.user as Express.User, + ); + const refreshToken = this.AuthService.getRefreshToken( + req.user as Express.User, + ); + + setRefreshTokenCookie(res, refreshToken); + + return { accessToken }; + } + + @Post('logout') + public logout(@Response() res: any, @Cookies('jwt') refreshToken?: string) { + if (!refreshToken) { + return ''; + } + + clearRefreshTokenCookie(res); + + return ''; + } + + @Post('refresh') + public refresh(@Response() res: any, @Cookies('jwt') refreshToken?: string) { + if (!refreshToken) { + throw new ForbiddenException(); + } + + clearRefreshTokenCookie(res); + + const userinfo = this.JwtService.verify(refreshToken); + if (!userinfo) { + throw new ForbiddenException(); + } + + const findUser = AuthService.MOCK_USERS.find( + (item) => item.username === userinfo.username, + ); + if (!findUser) { + throw new ForbiddenException(); + } + const accessToken = this.AuthService.getAccessToken(findUser); + + setRefreshTokenCookie(res, refreshToken); + + return accessToken; + } +} + +export default AuthController; diff --git a/apps/backend-nest/src/routes/index.ts b/apps/backend-nest/src/routes/index.ts new file mode 100644 index 00000000000..61dd4027cf5 --- /dev/null +++ b/apps/backend-nest/src/routes/index.ts @@ -0,0 +1,13 @@ +import { Module, type Type } from '@nestjs/common'; + +const controller_glob_result = import.meta.glob('./*.controller.ts', { + import: 'default', + eager: true, +}); +const controllers = Object.values(controller_glob_result); + +@Module({ + controllers, +}) +// eslint-disable-next-line @typescript-eslint/no-extraneous-class +export class RoutesModule {} diff --git a/apps/backend-nest/src/routes/user.controller.ts b/apps/backend-nest/src/routes/user.controller.ts new file mode 100644 index 00000000000..c58d322b600 --- /dev/null +++ b/apps/backend-nest/src/routes/user.controller.ts @@ -0,0 +1,11 @@ +import { All, Controller, Request } from '@nestjs/common'; + +@Controller('user') +export class UserController { + @All('info') + public codes(@Request() req: Express.Request) { + return req.user as Express.User; + } +} + +export default UserController; diff --git a/apps/backend-nest/src/utils/cookie-utils.ts b/apps/backend-nest/src/utils/cookie-utils.ts new file mode 100644 index 00000000000..bf6f7c1ed79 --- /dev/null +++ b/apps/backend-nest/src/utils/cookie-utils.ts @@ -0,0 +1,18 @@ +import type { Response } from 'express'; + +export function clearRefreshTokenCookie(res: Response) { + res.clearCookie('jwt', { + httpOnly: true, + sameSite: 'none', + secure: true, + }); +} + +export function setRefreshTokenCookie(res: Response, refreshToken: string) { + res.cookie('jwt', refreshToken, { + httpOnly: true, + maxAge: 24 * 60 * 60 * 1000, + sameSite: 'none', + secure: true, + }); +} diff --git a/apps/backend-nest/src/utils/mock-data.ts b/apps/backend-nest/src/utils/mock-data.ts new file mode 100644 index 00000000000..71970a2859f --- /dev/null +++ b/apps/backend-nest/src/utils/mock-data.ts @@ -0,0 +1,186 @@ +export interface UserInfo { + id: number; + password: string; + realName: string; + roles: string[]; + username: string; +} + +export const MOCK_USERS: UserInfo[] = [ + { + id: 0, + password: '123456', + realName: 'Vben', + roles: ['super'], + username: 'vben', + }, + { + id: 1, + password: '123456', + realName: 'Admin', + roles: ['admin'], + username: 'admin', + }, + { + id: 2, + password: '123456', + realName: 'Jack', + roles: ['user'], + username: 'jack', + }, +]; + +export const MOCK_CODES = [ + // super + { + codes: ['AC_100100', 'AC_100110', 'AC_100120', 'AC_100010'], + username: 'vben', + }, + { + // admin + codes: ['AC_100010', 'AC_100020', 'AC_100030'], + username: 'admin', + }, + { + // user + codes: ['AC_1000001', 'AC_1000002'], + username: 'jack', + }, +]; + +const dashboardMenus = [ + { + component: 'BasicLayout', + meta: { + order: -1, + title: 'page.dashboard.title', + }, + name: 'Dashboard', + path: '/', + redirect: '/analytics', + children: [ + { + name: 'Analytics', + path: '/analytics', + component: '/dashboard/analytics/index', + meta: { + affixTab: true, + title: 'page.dashboard.analytics', + }, + }, + { + name: 'Workspace', + path: '/workspace', + component: '/dashboard/workspace/index', + meta: { + title: 'page.dashboard.workspace', + }, + }, + ], + }, +]; + +const createDemosMenus = (role: 'admin' | 'super' | 'user') => { + const roleWithMenus = { + admin: { + component: '/demos/access/admin-visible', + meta: { + icon: 'mdi:button-cursor', + title: 'demos.access.adminVisible', + }, + name: 'AccessAdminVisibleDemo', + path: '/demos/access/admin-visible', + }, + super: { + component: '/demos/access/super-visible', + meta: { + icon: 'mdi:button-cursor', + title: 'demos.access.superVisible', + }, + name: 'AccessSuperVisibleDemo', + path: '/demos/access/super-visible', + }, + user: { + component: '/demos/access/user-visible', + meta: { + icon: 'mdi:button-cursor', + title: 'demos.access.userVisible', + }, + name: 'AccessUserVisibleDemo', + path: '/demos/access/user-visible', + }, + }; + + return [ + { + component: 'BasicLayout', + meta: { + icon: 'ic:baseline-view-in-ar', + keepAlive: true, + order: 1000, + title: 'demos.title', + }, + name: 'Demos', + path: '/demos', + redirect: '/demos/access', + children: [ + { + name: 'AccessDemos', + path: '/demosaccess', + meta: { + icon: 'mdi:cloud-key-outline', + title: 'demos.access.backendPermissions', + }, + redirect: '/demos/access/page-control', + children: [ + { + name: 'AccessPageControlDemo', + path: '/demos/access/page-control', + component: '/demos/access/index', + meta: { + icon: 'mdi:page-previous-outline', + title: 'demos.access.pageAccess', + }, + }, + { + name: 'AccessButtonControlDemo', + path: '/demos/access/button-control', + component: '/demos/access/button-control', + meta: { + icon: 'mdi:button-cursor', + title: 'demos.access.buttonControl', + }, + }, + { + name: 'AccessMenuVisible403Demo', + path: '/demos/access/menu-visible-403', + component: '/demos/access/menu-visible-403', + meta: { + authority: ['no-body'], + icon: 'mdi:button-cursor', + menuVisibleWithForbidden: true, + title: 'demos.access.menuVisible403', + }, + }, + roleWithMenus[role], + ], + }, + ], + }, + ]; +}; + +export const MOCK_MENUS = [ + { + menus: [...dashboardMenus, ...createDemosMenus('super')], + username: 'vben', + }, + { + menus: [...dashboardMenus, ...createDemosMenus('admin')], + username: 'admin', + }, + { + menus: [...dashboardMenus, ...createDemosMenus('user')], + username: 'jack', + }, +]; diff --git a/pnpm-lock.yaml b/pnpm-lock.yaml index c0ae881df52..65096d389a5 100644 --- a/pnpm-lock.yaml +++ b/pnpm-lock.yaml @@ -626,13 +626,40 @@ importers: dependencies: '@nestjs/common': specifier: ^10.0.0 - version: 10.4.6(reflect-metadata@0.2.2)(rxjs@7.8.1) + version: 10.4.6(class-transformer@0.5.1)(class-validator@0.14.1)(reflect-metadata@0.2.2)(rxjs@7.8.1) '@nestjs/core': specifier: ^10.0.0 - version: 10.4.6(@nestjs/common@10.4.6(reflect-metadata@0.2.2)(rxjs@7.8.1))(@nestjs/platform-express@10.4.6)(encoding@0.1.13)(reflect-metadata@0.2.2)(rxjs@7.8.1) + version: 10.4.6(@nestjs/common@10.4.6(class-transformer@0.5.1)(class-validator@0.14.1)(reflect-metadata@0.2.2)(rxjs@7.8.1))(@nestjs/platform-express@10.4.6)(encoding@0.1.13)(reflect-metadata@0.2.2)(rxjs@7.8.1) + '@nestjs/jwt': + specifier: ^10.2.0 + version: 10.2.0(@nestjs/common@10.4.6(class-transformer@0.5.1)(class-validator@0.14.1)(reflect-metadata@0.2.2)(rxjs@7.8.1)) + '@nestjs/passport': + specifier: ^10.0.3 + version: 10.0.3(@nestjs/common@10.4.6(class-transformer@0.5.1)(class-validator@0.14.1)(reflect-metadata@0.2.2)(rxjs@7.8.1))(passport@0.7.0) '@nestjs/platform-express': specifier: ^10.0.0 - version: 10.4.6(@nestjs/common@10.4.6(reflect-metadata@0.2.2)(rxjs@7.8.1))(@nestjs/core@10.4.6) + version: 10.4.6(@nestjs/common@10.4.6(class-transformer@0.5.1)(class-validator@0.14.1)(reflect-metadata@0.2.2)(rxjs@7.8.1))(@nestjs/core@10.4.6) + '@nestjs/swagger': + specifier: ^8.0.0 + version: 8.0.0(@nestjs/common@10.4.6(class-transformer@0.5.1)(class-validator@0.14.1)(reflect-metadata@0.2.2)(rxjs@7.8.1))(@nestjs/core@10.4.6(@nestjs/common@10.4.6(class-transformer@0.5.1)(class-validator@0.14.1)(reflect-metadata@0.2.2)(rxjs@7.8.1))(@nestjs/platform-express@10.4.6)(encoding@0.1.13)(reflect-metadata@0.2.2)(rxjs@7.8.1))(class-transformer@0.5.1)(class-validator@0.14.1)(reflect-metadata@0.2.2) + class-transformer: + specifier: ^0.5.1 + version: 0.5.1 + class-validator: + specifier: ^0.14.1 + version: 0.14.1 + cookie-parser: + specifier: ^1.4.7 + version: 1.4.7 + passport: + specifier: ^0.7.0 + version: 0.7.0 + passport-jwt: + specifier: ^4.0.1 + version: 4.0.1 + passport-local: + specifier: ^1.0.0 + version: 1.0.0 reflect-metadata: specifier: ^0.2.0 version: 0.2.2 @@ -643,12 +670,21 @@ importers: '@nestjs/cli': specifier: ^10.0.0 version: 10.4.5(@swc/core@1.7.40(@swc/helpers@0.5.13)) + '@types/cookie-parser': + specifier: ^1.4.7 + version: 1.4.7 '@types/express': specifier: ^4.17.17 version: 4.17.21 '@types/node': specifier: 'catalog:' version: 22.7.9 + '@types/passport-jwt': + specifier: ^4.0.1 + version: 4.0.1 + '@types/passport-local': + specifier: ^1.0.38 + version: 1.0.38 apps/web-antd: dependencies: @@ -4165,6 +4201,30 @@ packages: '@nestjs/websockets': optional: true + '@nestjs/jwt@10.2.0': + resolution: {integrity: sha512-x8cG90SURkEiLOehNaN2aRlotxT0KZESUliOPKKnjWiyJOcWurkF3w345WOX0P4MgFzUjGoZ1Sy0aZnxeihT0g==} + peerDependencies: + '@nestjs/common': ^8.0.0 || ^9.0.0 || ^10.0.0 + + '@nestjs/mapped-types@2.0.5': + resolution: {integrity: sha512-bSJv4pd6EY99NX9CjBIyn4TVDoSit82DUZlL4I3bqNfy5Gt+gXTa86i3I/i0iIV9P4hntcGM5GyO+FhZAhxtyg==} + peerDependencies: + '@nestjs/common': ^8.0.0 || ^9.0.0 || ^10.0.0 + class-transformer: ^0.4.0 || ^0.5.0 + class-validator: ^0.13.0 || ^0.14.0 + reflect-metadata: ^0.1.12 || ^0.2.0 + peerDependenciesMeta: + class-transformer: + optional: true + class-validator: + optional: true + + '@nestjs/passport@10.0.3': + resolution: {integrity: sha512-znJ9Y4S8ZDVY+j4doWAJ8EuuVO7SkQN3yOBmzxbGaXbvcSwFDAdGJ+OMCg52NdzIO4tQoN4pYKx8W6M0ArfFRQ==} + peerDependencies: + '@nestjs/common': ^8.0.0 || ^9.0.0 || ^10.0.0 + passport: ^0.4.0 || ^0.5.0 || ^0.6.0 || ^0.7.0 + '@nestjs/platform-express@10.4.6': resolution: {integrity: sha512-HcyCpAKccAasrLSGRTGWv5BKRs0rwTIFOSsk6laNyqfqvgvYcJQAedarnm4jmaemtmSJ0PFI9PmtEZADd2ahCg==} peerDependencies: @@ -4176,6 +4236,23 @@ packages: peerDependencies: typescript: '>=4.8.2' + '@nestjs/swagger@8.0.0': + resolution: {integrity: sha512-CJlceQSSU2chhxoskK7tPUM8IA2mf5vMXXpsHdM21Bn5uQAD9V8gpSjgBnD7oXBryY6hIzWOgQXj7efJkIOSbg==} + peerDependencies: + '@fastify/static': ^6.0.0 || ^7.0.0 + '@nestjs/common': ^9.0.0 || ^10.0.0 + '@nestjs/core': ^9.0.0 || ^10.0.0 + class-transformer: '*' + class-validator: '*' + reflect-metadata: ^0.1.12 || ^0.2.0 + peerDependenciesMeta: + '@fastify/static': + optional: true + class-transformer: + optional: true + class-validator: + optional: true + '@netlify/functions@2.8.2': resolution: {integrity: sha512-DeoAQh8LuNPvBE4qsKlezjKj0PyXDryOFJfJKo3Z1qZLKzQ21sT314KQKPVjfvw6knqijj+IO+0kHXy/TJiqNA==} engines: {node: '>=14.0.0'} @@ -4764,6 +4841,9 @@ packages: '@types/conventional-commits-parser@5.0.0': resolution: {integrity: sha512-loB369iXNmAZglwWATL+WRe+CRMmmBPtpolYzIebFaX4YA3x+BEfLqhUAV9WanycKI3TG1IMr5bMJDajDKLlUQ==} + '@types/cookie-parser@1.4.7': + resolution: {integrity: sha512-Fvuyi354Z+uayxzIGCwYTayFKocfV7TuDYZClCdIP9ckhvAu/ixDtCB6qx2TT0FKjPLf1f3P/J1rgf6lPs64mw==} + '@types/eslint@9.6.1': resolution: {integrity: sha512-FXx2pKgId/WyYo2jXw63kk7/+TY7u7AziEJxJAnSFzHlqTAS3Ync6SvgYAN/k4/PQpnnVuzoMuVnByKK2qp0ag==} @@ -4800,6 +4880,9 @@ packages: '@types/jsonfile@6.1.4': resolution: {integrity: sha512-D5qGUYwjvnNNextdU59/+fI+spnwtTFmyQP0h+PfIOSkNfpU6AOICUOkm4i0OnSk+NyjdPJrxCDro0sJsWlRpQ==} + '@types/jsonwebtoken@9.0.5': + resolution: {integrity: sha512-VRLSGzik+Unrup6BsouBeHsf4d1hOEgYWTm/7Nmw1sXoN1+tRly/Gy/po3yeahnP4jfnQWWAhQAqcNfH7ngOkA==} + '@types/jsonwebtoken@9.0.7': resolution: {integrity: sha512-ugo316mmTYBl2g81zDFnZ7cfxlut3o+/EQdaP7J8QN2kY6lJ22hmQYCK5EHcJHbrW+dkCGSCPgbG8JtYj6qSrg==} @@ -4851,6 +4934,18 @@ packages: '@types/parse-json@4.0.2': resolution: {integrity: sha512-dISoDXWWQwUquiKsyZ4Ng+HX2KsPL7LyHKHQwgGFEA3IaKac4Obd+h2a/a6waisAoepJlBcx9paWqjA8/HVjCw==} + '@types/passport-jwt@4.0.1': + resolution: {integrity: sha512-Y0Ykz6nWP4jpxgEUYq8NoVZeCQPo1ZndJLfapI249g1jHChvRfZRO/LS3tqu26YgAS/laI1qx98sYGz0IalRXQ==} + + '@types/passport-local@1.0.38': + resolution: {integrity: sha512-nsrW4A963lYE7lNTv9cr5WmiUD1ibYJvWrpE13oxApFsRt77b0RdtZvKbCdNIY4v/QZ6TRQWaDDEwV1kCTmcXg==} + + '@types/passport-strategy@0.2.38': + resolution: {integrity: sha512-GC6eMqqojOooq993Tmnmp7AUTbbQSgilyvpCYQjT+H6JfG/g6RGc7nXEniZlp0zyKJ0WUdOiZWLBZft9Yug1uA==} + + '@types/passport@1.0.16': + resolution: {integrity: sha512-FD0qD5hbPWQzaM0wHUnJ/T0BBCJBxCeemtnCwc/ThhTg3x9jfrAcRUmj5Dopza+MfFS9acTe3wk7rcVnRIp/0A==} + '@types/postcss-import@14.0.3': resolution: {integrity: sha512-raZhRVTf6Vw5+QbmQ7LOHSDML71A5rj4+EqDzAbrZPfxfoGzFxMHRCq16VlddGIZpHELw0BG4G0YE2ANkdZiIQ==} @@ -4884,6 +4979,9 @@ packages: '@types/unist@3.0.3': resolution: {integrity: sha512-ko/gIFJRv177XgZsZcBwnqJN5x/Gien8qNOn0D5bQU/zAzVf9Zt3BlcUiLqhV9y4ARk0GbT3tnUiPNgnTXzc/Q==} + '@types/validator@13.12.2': + resolution: {integrity: sha512-6SlHBzUW8Jhf3liqrGGXyTJSIFe4nqlJ5A5KaMZ2l/vbM3Wh3KSybots/wfWVzNLK4D1NZluDlSQIbIEPx6oyA==} + '@types/web-bluetooth@0.0.16': resolution: {integrity: sha512-oh8q2Zc32S6gd/j50GowEjKLoOVOwHP/bWVjKJInBwQqdOYMdPrf1oVlelTlyfFK3CKxL1uahMDAr+vy8T7yMQ==} @@ -5766,6 +5864,12 @@ packages: citty@0.1.6: resolution: {integrity: sha512-tskPPKEs8D2KPafUypv2gxwJP8h/OaJmC82QQGGDQcHvXX43xF2VDACcJVmZ0EuSxkpO9Kc4MlrA3q0+FG58AQ==} + class-transformer@0.5.1: + resolution: {integrity: sha512-SQa1Ws6hUbfC98vKGxZH3KFY0Y1lm5Zm0SY8XX9zbK7FJCyVEac3ATW0RIpwzW+oOfmHE5PMPufDG9hCfoEOMw==} + + class-validator@0.14.1: + resolution: {integrity: sha512-2VEG9JICxIqTpoK1eMzZqaV+u/EiwEJkMGzTrZf6sU/fwsnOITVgYJ8yojSy6CaXtO9V0Cc6ZQZ8h8m4UBuLwQ==} + class-variance-authority@0.7.0: resolution: {integrity: sha512-jFI8IQw4hczaL4ALINxqLEXQbWcNjoSkloa4IaufXCJr6QawJyw7tuRysRsrE8w2p/4gGaxKIt/hX3qz/IbD1A==} @@ -5994,6 +6098,10 @@ packages: cookie-es@1.2.2: resolution: {integrity: sha512-+W7VmiVINB+ywl1HGXJXmrqkOhpKrIiVZV6tQuV54ZyQC7MMuBt81Vc336GMLoHBq5hV/F9eXgt5Mnx0Rha5Fg==} + cookie-parser@1.4.7: + resolution: {integrity: sha512-nGUvgXnotP3BsjiLX2ypbQnWoGUPIIfHQNZkkC668ntrzGWEZVW70HDEB1qnNGMicPje6EttlIgzo51YSwNQGw==} + engines: {node: '>= 0.8.0'} + cookie-signature@1.0.6: resolution: {integrity: sha512-QADzlaHc8icV8I7vbaJXJwod9HWYp8uCqf1xa4OfNu1T7JVxQIrUgOWtHdNDtPiywmFbiS12VjotIXLrKM3orQ==} @@ -6001,6 +6109,10 @@ packages: resolution: {integrity: sha512-6DnInpx7SJ2AK3+CTUE/ZM0vWTUboZCegxhC2xiIydHR9jNuTAASBrfEpHhiGOZw/nX51bHt6YQl8jsGo4y/0w==} engines: {node: '>= 0.6'} + cookie@0.7.2: + resolution: {integrity: sha512-yki5XnKuf750l50uGTllt6kKILY4nQ1eNIQatoXEByZ5dWgnKqbnqmTrBE5B4N7lrMJKQ2ytWMiTO2o0v6Ew/w==} + engines: {node: '>= 0.6'} + copy-anything@2.0.6: resolution: {integrity: sha512-1j20GZTsvKNkc4BY3NpMOM8tt///wY3FpIzozTOFO2ffuZcV61nojHXVKIy3WM+7ADCy5FVhdZYHYDdgTU0yJw==} @@ -7939,6 +8051,9 @@ packages: resolution: {integrity: sha512-+bT2uH4E5LGE7h/n3evcS/sQlJXCpIp6ym8OWJ5eV6+67Dsql/LaaT7qJBAt2rzfoa/5QBGBhxDix1dMt2kQKQ==} engines: {node: '>= 0.8.0'} + libphonenumber-js@1.11.12: + resolution: {integrity: sha512-QkJn9/D7zZ1ucvT++TQSvZuSA2xAWeUytU+DiEQwbPKLyrDpvbul2AFs1CGbRAPpSCCk47aRAb5DX5mmcayp4g==} + lilconfig@2.1.0: resolution: {integrity: sha512-utWOt/GHzuUxnLKxB6dk81RoOeoNeHgbrXiuGk4yyF5qlRz+iIVWu56E2fqGHFrXz0QNUhLB/8nKqvRH66JKGQ==} engines: {node: '>=10'} @@ -8702,6 +8817,21 @@ packages: pascal-case@3.1.2: resolution: {integrity: sha512-uWlGT3YSnK9x3BQJaOdcZwrnV6hPpd8jFH1/ucpiLRPh/2zCVJKS19E4GvYHvaCcACn3foXZ0cLB9Wrx1KGe5g==} + passport-jwt@4.0.1: + resolution: {integrity: sha512-UCKMDYhNuGOBE9/9Ycuoyh7vP6jpeTp/+sfMJl7nLff/t6dps+iaeE0hhNkKN8/HZHcJ7lCdOyDxHdDoxoSvdQ==} + + passport-local@1.0.0: + resolution: {integrity: sha512-9wCE6qKznvf9mQYYbgJ3sVOHmCWoUNMVFoZzNoznmISbhnNNPhN9xfY3sLmScHMetEJeoY7CXwfhCe7argfQow==} + engines: {node: '>= 0.4.0'} + + passport-strategy@1.0.0: + resolution: {integrity: sha512-CB97UUvDKJde2V0KDWWB3lyf6PC3FaZP7YxZ2G8OAtn9p4HI9j9JLP9qjOGZFvyl8uwNT8qM+hGnz/n16NI7oA==} + engines: {node: '>= 0.4.0'} + + passport@0.7.0: + resolution: {integrity: sha512-cPLl+qZpSc+ireUvt+IzqbED1cHHkDoVYMo30jbJIdOOjQ1MQYZBPiNvmi8UM6lJuOpTPXJGZQk0DtC4y61MYQ==} + engines: {node: '>= 0.4.0'} + path-browserify@1.0.1: resolution: {integrity: sha512-b7uo2UCUOYZcnF/3ID0lulOJi/bafxa1xPe7ZPsammBSpjSWQkjNxlt635YGS2MiR9GjvuXCtz2emr3jbsz98g==} @@ -8760,6 +8890,9 @@ packages: resolution: {integrity: sha512-vE7JKRyES09KiunauX7nd2Q9/L7lhok4smP9RZTDeD4MVs72Dp2qNFVz39Nz5a0FVEW0BJR6C0DYrq6unoziZA==} engines: {node: '>= 14.16'} + pause@0.0.1: + resolution: {integrity: sha512-KG8UEiEVkR3wGEb4m5yZkVCzigAD+cVEJck2CzYZO37ZGJfctvVptVO192MwrtPhzONn6go8ylnOdMhKqi4nfg==} + perfect-debounce@1.0.0: resolution: {integrity: sha512-xCy9V055GLEqoFaHoC1SoLIaLmWctgCUaBaWxDZ7/Zx4CTyX7cJQLJOok/orfjZAh9kEYpjJa4d0KcJmCbctZA==} @@ -10182,6 +10315,9 @@ packages: engines: {node: '>=14.0.0'} hasBin: true + swagger-ui-dist@5.17.14: + resolution: {integrity: sha512-CVbSfaLpstV65OnSjbXfVd6Sta3q3F7Cj/yYuvHMp1P90LztOLs6PfUnKEVAeiIVQt9u2SaPwv0LiH/OyMjHRw==} + symbol-observable@4.0.0: resolution: {integrity: sha512-b19dMThMV4HVFynSAM1++gBHAbk2Tc/osgLIBZMKsyqh34jb2e8Os7T6ZW/Bt3pJFdBTd2JwAnAAEQV7rSNvcQ==} engines: {node: '>=0.10'} @@ -10681,6 +10817,10 @@ packages: validate-npm-package-license@3.0.4: resolution: {integrity: sha512-DpKm2Ui/xN7/HQKCtpZxoRWBhZ9Z0kqtygG8XCgNQ8ZlDnxuQmWhj566j8fN4Cu3/JmbhsDo7fcAJq4s9h27Ew==} + validator@13.12.0: + resolution: {integrity: sha512-c1Q0mCiPlgdTVVVIJIrBuxNicYE+t/7oKeI9MWLj3fh/uq2Pxh/3eeWbVZ4OcGW1TUf53At0njHw5SMdA3tmMg==} + engines: {node: '>= 0.10'} + vary@1.1.2: resolution: {integrity: sha512-BNGbWLfd0eUPabhkXUVm0j8uuvREyTh5ovRa/dyow/BqAbZJyC+5fU+IzQOzmAKzYqYRAISoRhdQr3eIZ/PXqg==} engines: {node: '>= 0.8'} @@ -13635,17 +13775,20 @@ snapshots: - uglify-js - webpack-cli - '@nestjs/common@10.4.6(reflect-metadata@0.2.2)(rxjs@7.8.1)': + '@nestjs/common@10.4.6(class-transformer@0.5.1)(class-validator@0.14.1)(reflect-metadata@0.2.2)(rxjs@7.8.1)': dependencies: iterare: 1.2.1 reflect-metadata: 0.2.2 rxjs: 7.8.1 tslib: 2.7.0 uid: 2.0.2 + optionalDependencies: + class-transformer: 0.5.1 + class-validator: 0.14.1 - '@nestjs/core@10.4.6(@nestjs/common@10.4.6(reflect-metadata@0.2.2)(rxjs@7.8.1))(@nestjs/platform-express@10.4.6)(encoding@0.1.13)(reflect-metadata@0.2.2)(rxjs@7.8.1)': + '@nestjs/core@10.4.6(@nestjs/common@10.4.6(class-transformer@0.5.1)(class-validator@0.14.1)(reflect-metadata@0.2.2)(rxjs@7.8.1))(@nestjs/platform-express@10.4.6)(encoding@0.1.13)(reflect-metadata@0.2.2)(rxjs@7.8.1)': dependencies: - '@nestjs/common': 10.4.6(reflect-metadata@0.2.2)(rxjs@7.8.1) + '@nestjs/common': 10.4.6(class-transformer@0.5.1)(class-validator@0.14.1)(reflect-metadata@0.2.2)(rxjs@7.8.1) '@nuxtjs/opencollective': 0.3.2(encoding@0.1.13) fast-safe-stringify: 2.1.1 iterare: 1.2.1 @@ -13655,14 +13798,33 @@ snapshots: tslib: 2.7.0 uid: 2.0.2 optionalDependencies: - '@nestjs/platform-express': 10.4.6(@nestjs/common@10.4.6(reflect-metadata@0.2.2)(rxjs@7.8.1))(@nestjs/core@10.4.6) + '@nestjs/platform-express': 10.4.6(@nestjs/common@10.4.6(class-transformer@0.5.1)(class-validator@0.14.1)(reflect-metadata@0.2.2)(rxjs@7.8.1))(@nestjs/core@10.4.6) transitivePeerDependencies: - encoding - '@nestjs/platform-express@10.4.6(@nestjs/common@10.4.6(reflect-metadata@0.2.2)(rxjs@7.8.1))(@nestjs/core@10.4.6)': + '@nestjs/jwt@10.2.0(@nestjs/common@10.4.6(class-transformer@0.5.1)(class-validator@0.14.1)(reflect-metadata@0.2.2)(rxjs@7.8.1))': dependencies: - '@nestjs/common': 10.4.6(reflect-metadata@0.2.2)(rxjs@7.8.1) - '@nestjs/core': 10.4.6(@nestjs/common@10.4.6(reflect-metadata@0.2.2)(rxjs@7.8.1))(@nestjs/platform-express@10.4.6)(encoding@0.1.13)(reflect-metadata@0.2.2)(rxjs@7.8.1) + '@nestjs/common': 10.4.6(class-transformer@0.5.1)(class-validator@0.14.1)(reflect-metadata@0.2.2)(rxjs@7.8.1) + '@types/jsonwebtoken': 9.0.5 + jsonwebtoken: 9.0.2 + + '@nestjs/mapped-types@2.0.5(@nestjs/common@10.4.6(class-transformer@0.5.1)(class-validator@0.14.1)(reflect-metadata@0.2.2)(rxjs@7.8.1))(class-transformer@0.5.1)(class-validator@0.14.1)(reflect-metadata@0.2.2)': + dependencies: + '@nestjs/common': 10.4.6(class-transformer@0.5.1)(class-validator@0.14.1)(reflect-metadata@0.2.2)(rxjs@7.8.1) + reflect-metadata: 0.2.2 + optionalDependencies: + class-transformer: 0.5.1 + class-validator: 0.14.1 + + '@nestjs/passport@10.0.3(@nestjs/common@10.4.6(class-transformer@0.5.1)(class-validator@0.14.1)(reflect-metadata@0.2.2)(rxjs@7.8.1))(passport@0.7.0)': + dependencies: + '@nestjs/common': 10.4.6(class-transformer@0.5.1)(class-validator@0.14.1)(reflect-metadata@0.2.2)(rxjs@7.8.1) + passport: 0.7.0 + + '@nestjs/platform-express@10.4.6(@nestjs/common@10.4.6(class-transformer@0.5.1)(class-validator@0.14.1)(reflect-metadata@0.2.2)(rxjs@7.8.1))(@nestjs/core@10.4.6)': + dependencies: + '@nestjs/common': 10.4.6(class-transformer@0.5.1)(class-validator@0.14.1)(reflect-metadata@0.2.2)(rxjs@7.8.1) + '@nestjs/core': 10.4.6(@nestjs/common@10.4.6(class-transformer@0.5.1)(class-validator@0.14.1)(reflect-metadata@0.2.2)(rxjs@7.8.1))(@nestjs/platform-express@10.4.6)(encoding@0.1.13)(reflect-metadata@0.2.2)(rxjs@7.8.1) body-parser: 1.20.3 cors: 2.8.5 express: 4.21.1 @@ -13682,6 +13844,21 @@ snapshots: transitivePeerDependencies: - chokidar + '@nestjs/swagger@8.0.0(@nestjs/common@10.4.6(class-transformer@0.5.1)(class-validator@0.14.1)(reflect-metadata@0.2.2)(rxjs@7.8.1))(@nestjs/core@10.4.6(@nestjs/common@10.4.6(class-transformer@0.5.1)(class-validator@0.14.1)(reflect-metadata@0.2.2)(rxjs@7.8.1))(@nestjs/platform-express@10.4.6)(encoding@0.1.13)(reflect-metadata@0.2.2)(rxjs@7.8.1))(class-transformer@0.5.1)(class-validator@0.14.1)(reflect-metadata@0.2.2)': + dependencies: + '@microsoft/tsdoc': 0.15.0 + '@nestjs/common': 10.4.6(class-transformer@0.5.1)(class-validator@0.14.1)(reflect-metadata@0.2.2)(rxjs@7.8.1) + '@nestjs/core': 10.4.6(@nestjs/common@10.4.6(class-transformer@0.5.1)(class-validator@0.14.1)(reflect-metadata@0.2.2)(rxjs@7.8.1))(@nestjs/platform-express@10.4.6)(encoding@0.1.13)(reflect-metadata@0.2.2)(rxjs@7.8.1) + '@nestjs/mapped-types': 2.0.5(@nestjs/common@10.4.6(class-transformer@0.5.1)(class-validator@0.14.1)(reflect-metadata@0.2.2)(rxjs@7.8.1))(class-transformer@0.5.1)(class-validator@0.14.1)(reflect-metadata@0.2.2) + js-yaml: 4.1.0 + lodash: 4.17.21 + path-to-regexp: 3.3.0 + reflect-metadata: 0.2.2 + swagger-ui-dist: 5.17.14 + optionalDependencies: + class-transformer: 0.5.1 + class-validator: 0.14.1 + '@netlify/functions@2.8.2': dependencies: '@netlify/serverless-functions-api': 1.26.1 @@ -14375,6 +14552,10 @@ snapshots: dependencies: '@types/node': 22.7.9 + '@types/cookie-parser@1.4.7': + dependencies: + '@types/express': 4.17.21 + '@types/eslint@9.6.1': dependencies: '@types/estree': 1.0.6 @@ -14423,6 +14604,10 @@ snapshots: '@types/node': 22.7.9 optional: true + '@types/jsonwebtoken@9.0.5': + dependencies: + '@types/node': 22.7.9 + '@types/jsonwebtoken@9.0.7': dependencies: '@types/node': 22.7.7 @@ -14472,6 +14657,26 @@ snapshots: '@types/parse-json@4.0.2': {} + '@types/passport-jwt@4.0.1': + dependencies: + '@types/jsonwebtoken': 9.0.7 + '@types/passport-strategy': 0.2.38 + + '@types/passport-local@1.0.38': + dependencies: + '@types/express': 4.17.21 + '@types/passport': 1.0.16 + '@types/passport-strategy': 0.2.38 + + '@types/passport-strategy@0.2.38': + dependencies: + '@types/express': 4.17.21 + '@types/passport': 1.0.16 + + '@types/passport@1.0.16': + dependencies: + '@types/express': 4.17.21 + '@types/postcss-import@14.0.3': dependencies: postcss: 8.4.47 @@ -14507,6 +14712,8 @@ snapshots: '@types/unist@3.0.3': {} + '@types/validator@13.12.2': {} + '@types/web-bluetooth@0.0.16': {} '@types/web-bluetooth@0.0.20': {} @@ -15677,6 +15884,14 @@ snapshots: dependencies: consola: 3.2.3 + class-transformer@0.5.1: {} + + class-validator@0.14.1: + dependencies: + '@types/validator': 13.12.2 + libphonenumber-js: 1.11.12 + validator: 13.12.0 + class-variance-authority@0.7.0: dependencies: clsx: 2.1.1 @@ -15884,10 +16099,17 @@ snapshots: cookie-es@1.2.2: {} + cookie-parser@1.4.7: + dependencies: + cookie: 0.7.2 + cookie-signature: 1.0.6 + cookie-signature@1.0.6: {} cookie@0.7.1: {} + cookie@0.7.2: {} + copy-anything@2.0.6: dependencies: is-what: 3.14.1 @@ -18135,6 +18357,8 @@ snapshots: prelude-ls: 1.2.1 type-check: 0.4.0 + libphonenumber-js@1.11.12: {} + lilconfig@2.1.0: {} lilconfig@3.1.2: {} @@ -19021,6 +19245,23 @@ snapshots: no-case: 3.0.4 tslib: 2.8.0 + passport-jwt@4.0.1: + dependencies: + jsonwebtoken: 9.0.2 + passport-strategy: 1.0.0 + + passport-local@1.0.0: + dependencies: + passport-strategy: 1.0.0 + + passport-strategy@1.0.0: {} + + passport@0.7.0: + dependencies: + passport-strategy: 1.0.0 + pause: 0.0.1 + utils-merge: 1.0.1 + path-browserify@1.0.1: {} path-exists@4.0.0: {} @@ -19059,6 +19300,8 @@ snapshots: pathval@2.0.0: {} + pause@0.0.1: {} + perfect-debounce@1.0.0: {} picocolors@1.1.1: {} @@ -20520,6 +20763,8 @@ snapshots: csso: 5.0.5 picocolors: 1.1.1 + swagger-ui-dist@5.17.14: {} + symbol-observable@4.0.0: {} synckit@0.6.2: @@ -21046,6 +21291,8 @@ snapshots: spdx-correct: 3.2.0 spdx-expression-parse: 3.0.1 + validator@13.12.0: {} + vary@1.1.2: {} vdirs@0.1.8(vue@3.5.12(typescript@5.6.3)): From 82887ca608e0c67515ba3295c3a6a73801ac333d Mon Sep 17 00:00:00 2001 From: Dlovely <591562538@qq.com> Date: Wed, 30 Oct 2024 09:52:31 +0800 Subject: [PATCH 4/9] =?UTF-8?q?feat:=20=E6=8F=90=E4=BE=9Bvben=E6=89=80?= =?UTF-8?q?=E5=BF=85=E9=9C=80=E7=9A=84=E6=A0=B8=E5=BF=83=E6=8E=A5=E5=8F=A3?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../backend-nest/src/routes/index.controller.ts | 17 +++++++++++++++++ 1 file changed, 17 insertions(+) create mode 100644 apps/backend-nest/src/routes/index.controller.ts diff --git a/apps/backend-nest/src/routes/index.controller.ts b/apps/backend-nest/src/routes/index.controller.ts new file mode 100644 index 00000000000..397865e6a6d --- /dev/null +++ b/apps/backend-nest/src/routes/index.controller.ts @@ -0,0 +1,17 @@ +import type { Response as ExpressResponse } from 'express'; + +import { All, Controller, Query, Response } from '@nestjs/common'; + +@Controller() +export class UserController { + @All('status') + public status( + @Response() res: ExpressResponse, + @Query('status') status: string, + ) { + res.status(Number(status)); + return status; + } +} + +export default UserController; From 6911873ddfb3ac0bdc9b843704fae3921a0b6469 Mon Sep 17 00:00:00 2001 From: MZ-Dlovely <591562538@qq.com> Date: Sun, 3 Nov 2024 19:37:39 +0800 Subject: [PATCH 5/9] =?UTF-8?q?feat:=20=E6=8F=90=E4=BE=9B=E7=BB=9F?= =?UTF-8?q?=E4=B8=80=E5=93=8D=E5=BA=94=E7=9A=84=E8=BF=87=E6=BB=A4=E5=99=A8?= =?UTF-8?q?=E5=8F=8A=E6=8B=A6=E6=88=AA=E5=99=A8?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../src/filters/http-exception.filter.ts | 42 ++++++++++++++++ .../src/interceptor/transform.interceptor.ts | 23 +++++++++ apps/backend-nest/src/interfaces/response.ts | 49 +++++++++++++++++++ 3 files changed, 114 insertions(+) create mode 100644 apps/backend-nest/src/filters/http-exception.filter.ts create mode 100644 apps/backend-nest/src/interceptor/transform.interceptor.ts create mode 100644 apps/backend-nest/src/interfaces/response.ts diff --git a/apps/backend-nest/src/filters/http-exception.filter.ts b/apps/backend-nest/src/filters/http-exception.filter.ts new file mode 100644 index 00000000000..cdcac0a6ae5 --- /dev/null +++ b/apps/backend-nest/src/filters/http-exception.filter.ts @@ -0,0 +1,42 @@ +import type { ArgumentsHost, ExceptionFilter } from '@nestjs/common'; +import type { Response } from 'express'; + +import { BadRequestException, Catch, HttpException } from '@nestjs/common'; + +import { ResponseClass } from '#/interfaces/response'; + +@Catch(HttpException) +export class HttpExceptionFilter implements ExceptionFilter { + catch(exception: HttpException, host: ArgumentsHost) { + const ctx = host.switchToHttp(); + const response = ctx.getResponse(); + const status = exception.getStatus(); + const results = exception.getResponse() as any; + + // eslint-disable-next-line unicorn/throw-new-error + const result = ResponseClass.Error(results.message); + + // 参数校验错误,默认都是BadRequestException + const isArrayMessage = Array.isArray(results.message); + const isValidationError = + isArrayMessage && + typeof results.message[0] === 'string' && + results.message[0].includes('⓿'); + if (exception instanceof BadRequestException && isValidationError) { + const message: Array<{ field: string; message: Array }> = []; + results.message.forEach((item: string) => { + const [key, val] = item.split('⓿') as [string, string]; + const findData = message.find((item) => item.field === key); + if (findData) { + findData.message.push(val); + } else { + message.push({ field: key, message: [val] }); + } + }); + + result.error = message; + } + + return response.status(status).json(result); + } +} diff --git a/apps/backend-nest/src/interceptor/transform.interceptor.ts b/apps/backend-nest/src/interceptor/transform.interceptor.ts new file mode 100644 index 00000000000..a813ad06eeb --- /dev/null +++ b/apps/backend-nest/src/interceptor/transform.interceptor.ts @@ -0,0 +1,23 @@ +import type { + CallHandler, + ExecutionContext, + NestInterceptor, +} from '@nestjs/common'; + +import { Injectable } from '@nestjs/common'; +import { Observable } from 'rxjs'; +import { map } from 'rxjs/operators'; + +import { ResponseClass } from '#/interfaces/response'; + +@Injectable() +export class TransformInterceptor + implements NestInterceptor> +{ + intercept( + _: ExecutionContext, + next: CallHandler, + ): Observable> { + return next.handle().pipe(map((data) => ResponseClass.Success(data))); + } +} diff --git a/apps/backend-nest/src/interfaces/response.ts b/apps/backend-nest/src/interfaces/response.ts new file mode 100644 index 00000000000..40696012845 --- /dev/null +++ b/apps/backend-nest/src/interfaces/response.ts @@ -0,0 +1,49 @@ +export class ResponseClass { + constructor( + public code: number, + public data: T, + public error: any, + public message: string | string[], + ) {} + + static Error(message: string | string[], error: any = null) { + return new ResponseClass(-1, null, error, message); + } + + static PageSuccess( + page: number | string, + pageSize: number | string, + list: T[], + { message = 'ok' } = {}, + ) { + const pageData = pagination( + Number.parseInt(`${page}`), + Number.parseInt(`${pageSize}`), + list, + ); + + const result = ResponseClass.Success({ + items: pageData, + total: list.length, + }); + + result.message = message; + + return result; + } + + static Success(data: T) { + return new ResponseClass(0, data, null, 'ok'); + } +} + +export function pagination( + pageNo: number, + pageSize: number, + array: T[], +): T[] { + const offset = (pageNo - 1) * Number(pageSize); + return offset + Number(pageSize) >= array.length + ? array.slice(offset) + : array.slice(offset, offset + Number(pageSize)); +} From eac498631a81c78a8849087976cd88878285dc37 Mon Sep 17 00:00:00 2001 From: MZ-Dlovely <591562538@qq.com> Date: Sun, 3 Nov 2024 21:05:40 +0800 Subject: [PATCH 6/9] =?UTF-8?q?feat:=20=E6=8F=90=E4=BE=9B=E5=90=8E?= =?UTF-8?q?=E7=AB=AF=E6=9C=8D=E5=8A=A1=E5=99=A8=E5=B8=B8=E7=94=A8=E7=9A=84?= =?UTF-8?q?=E6=8E=A5=E5=8F=A3?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- apps/backend-nest/package.json | 3 +++ apps/backend-nest/src/app/index.module.ts | 7 +++++-- apps/backend-nest/src/auth/index.module.ts | 5 ++++- apps/backend-nest/src/auth/local.strategy.ts | 4 ++-- .../src/filters/http-exception.filter.ts | 3 +++ apps/backend-nest/src/filters/index.ts | 13 +++++++++++++ apps/backend-nest/src/guards/auth.guard.ts | 10 ++++------ apps/backend-nest/src/interceptor/index.ts | 13 +++++++++++++ .../src/interceptor/transform.interceptor.ts | 19 +++++++++++++++++-- apps/backend-nest/src/interfaces/response.ts | 4 ++++ .../src/routes/index.controller.ts | 19 +++++++++++++++++++ apps/backend-nest/src/routes/index.ts | 4 +--- 12 files changed, 88 insertions(+), 16 deletions(-) create mode 100644 apps/backend-nest/src/filters/index.ts create mode 100644 apps/backend-nest/src/interceptor/index.ts diff --git a/apps/backend-nest/package.json b/apps/backend-nest/package.json index 165fda47706..e18640e0674 100644 --- a/apps/backend-nest/package.json +++ b/apps/backend-nest/package.json @@ -12,6 +12,9 @@ "preview": "vite preview", "typecheck": "vue-tsc --noEmit --skipLibCheck" }, + "imports": { + "#/*": "./src/*" + }, "dependencies": { "@nestjs/common": "^10.0.0", "@nestjs/core": "^10.0.0", diff --git a/apps/backend-nest/src/app/index.module.ts b/apps/backend-nest/src/app/index.module.ts index 983fb37340a..3a324fb7b2f 100644 --- a/apps/backend-nest/src/app/index.module.ts +++ b/apps/backend-nest/src/app/index.module.ts @@ -1,11 +1,14 @@ import { Module } from '@nestjs/common'; +import { AuthModule } from '#/auth'; +import filters from '#/filters'; import guards from '#/guards'; +import interceptors from '#/interceptor'; import { RoutesModule } from '#/routes'; @Module({ - imports: [RoutesModule], - providers: [...guards], + imports: [RoutesModule, AuthModule], + providers: [...guards, ...interceptors, ...filters], }) // eslint-disable-next-line @typescript-eslint/no-extraneous-class export class AppModule {} diff --git a/apps/backend-nest/src/auth/index.module.ts b/apps/backend-nest/src/auth/index.module.ts index 14d20be548b..7fa1d99a47b 100644 --- a/apps/backend-nest/src/auth/index.module.ts +++ b/apps/backend-nest/src/auth/index.module.ts @@ -1,4 +1,4 @@ -import { Module } from '@nestjs/common'; +import { Global, Module } from '@nestjs/common'; import { JwtModule } from '@nestjs/jwt'; import { PassportModule } from '@nestjs/passport'; @@ -10,10 +10,13 @@ import { LocalStrategy } from './local.strategy'; imports: [ PassportModule, JwtModule.register({ + global: true, secret: import.meta.env.VITE_JWT_SECRET, }), ], providers: [AuthService, LocalStrategy, JwtStrategy], + exports: [AuthService], }) +@Global() // eslint-disable-next-line @typescript-eslint/no-extraneous-class export class AuthModule {} diff --git a/apps/backend-nest/src/auth/local.strategy.ts b/apps/backend-nest/src/auth/local.strategy.ts index e1aafae6cc9..842cf5790c3 100644 --- a/apps/backend-nest/src/auth/local.strategy.ts +++ b/apps/backend-nest/src/auth/local.strategy.ts @@ -1,4 +1,4 @@ -import { Injectable, UnauthorizedException } from '@nestjs/common'; +import { ForbiddenException, Injectable } from '@nestjs/common'; import { PassportStrategy } from '@nestjs/passport'; import { Strategy } from 'passport-local'; @@ -14,7 +14,7 @@ export class LocalStrategy extends PassportStrategy(Strategy) { const findUser = await this.AuthService.validateUser(username, password); if (!findUser) { - throw new UnauthorizedException(); + throw new ForbiddenException('用户名或密码错误'); } return findUser; diff --git a/apps/backend-nest/src/filters/http-exception.filter.ts b/apps/backend-nest/src/filters/http-exception.filter.ts index cdcac0a6ae5..e731de6ede2 100644 --- a/apps/backend-nest/src/filters/http-exception.filter.ts +++ b/apps/backend-nest/src/filters/http-exception.filter.ts @@ -40,3 +40,6 @@ export class HttpExceptionFilter implements ExceptionFilter { return response.status(status).json(result); } } + +// 默认导出,便于glob导入 +export default HttpExceptionFilter; diff --git a/apps/backend-nest/src/filters/index.ts b/apps/backend-nest/src/filters/index.ts new file mode 100644 index 00000000000..5eed7520729 --- /dev/null +++ b/apps/backend-nest/src/filters/index.ts @@ -0,0 +1,13 @@ +import type { ClassProvider, Type } from '@nestjs/common'; + +import { APP_FILTER } from '@nestjs/core'; + +const glob_result = import.meta.glob('./*.filter.ts', { + import: 'default', + eager: true, +}); + +export default Object.values(glob_result).map((useClass) => ({ + provide: APP_FILTER, + useClass, +})); diff --git a/apps/backend-nest/src/guards/auth.guard.ts b/apps/backend-nest/src/guards/auth.guard.ts index 34f082b3c69..a459995203a 100644 --- a/apps/backend-nest/src/guards/auth.guard.ts +++ b/apps/backend-nest/src/guards/auth.guard.ts @@ -1,10 +1,8 @@ -import type { Reflector } from '@nestjs/core'; - -import { type ExecutionContext, Injectable, SetMetadata } from '@nestjs/common'; +import { type ExecutionContext, Injectable } from '@nestjs/common'; +import { Reflector } from '@nestjs/core'; import { AuthGuard } from '@nestjs/passport'; -const IS_PUBLIC_KEY = 'isPublic'; -export const Public = () => SetMetadata(IS_PUBLIC_KEY, true); +export const Public = Reflector.createDecorator(); @Injectable() export class JwtAuthGuard extends AuthGuard('jwt') { @@ -13,7 +11,7 @@ export class JwtAuthGuard extends AuthGuard('jwt') { } override canActivate(context: ExecutionContext) { - const isPublic = this.Reflector.getAllAndOverride(IS_PUBLIC_KEY, [ + const isPublic = this.Reflector.getAllAndOverride(Public, [ context.getHandler(), context.getClass(), ]); diff --git a/apps/backend-nest/src/interceptor/index.ts b/apps/backend-nest/src/interceptor/index.ts new file mode 100644 index 00000000000..9d2e5e8cb98 --- /dev/null +++ b/apps/backend-nest/src/interceptor/index.ts @@ -0,0 +1,13 @@ +import type { ClassProvider, Type } from '@nestjs/common'; + +import { APP_INTERCEPTOR } from '@nestjs/core'; + +const glob_result = import.meta.glob('./*.interceptor.ts', { + import: 'default', + eager: true, +}); + +export default Object.values(glob_result).map((useClass) => ({ + provide: APP_INTERCEPTOR, + useClass, +})); diff --git a/apps/backend-nest/src/interceptor/transform.interceptor.ts b/apps/backend-nest/src/interceptor/transform.interceptor.ts index a813ad06eeb..9c66714f160 100644 --- a/apps/backend-nest/src/interceptor/transform.interceptor.ts +++ b/apps/backend-nest/src/interceptor/transform.interceptor.ts @@ -5,19 +5,34 @@ import type { } from '@nestjs/common'; import { Injectable } from '@nestjs/common'; +import { Reflector } from '@nestjs/core'; import { Observable } from 'rxjs'; import { map } from 'rxjs/operators'; -import { ResponseClass } from '#/interfaces/response'; +import { ResponseClass, SkipResCheck } from '#/interfaces/response'; @Injectable() export class TransformInterceptor implements NestInterceptor> { + constructor(private readonly Reflector: Reflector) {} + intercept( - _: ExecutionContext, + context: ExecutionContext, next: CallHandler, ): Observable> { + const isSkipResCheck = this.Reflector.getAllAndOverride( + SkipResCheck, + [context.getHandler(), context.getClass()], + ); + + if (isSkipResCheck) { + return next.handle(); + } + return next.handle().pipe(map((data) => ResponseClass.Success(data))); } } + +// 默认导出,便于glob导入 +export default TransformInterceptor; diff --git a/apps/backend-nest/src/interfaces/response.ts b/apps/backend-nest/src/interfaces/response.ts index 40696012845..8238d306651 100644 --- a/apps/backend-nest/src/interfaces/response.ts +++ b/apps/backend-nest/src/interfaces/response.ts @@ -1,3 +1,7 @@ +import { Reflector } from '@nestjs/core'; + +export const SkipResCheck = Reflector.createDecorator(); + export class ResponseClass { constructor( public code: number, diff --git a/apps/backend-nest/src/routes/index.controller.ts b/apps/backend-nest/src/routes/index.controller.ts index 397865e6a6d..21821f04205 100644 --- a/apps/backend-nest/src/routes/index.controller.ts +++ b/apps/backend-nest/src/routes/index.controller.ts @@ -2,8 +2,27 @@ import type { Response as ExpressResponse } from 'express'; import { All, Controller, Query, Response } from '@nestjs/common'; +import { Public } from '#/guards'; +import { SkipResCheck } from '#/interfaces/response'; + @Controller() export class UserController { + @All() + @Public() + @SkipResCheck() + public index() { + return ` +

Hello Vben Admin

+

Mock service is starting

+ +`; + } + @All('status') public status( @Response() res: ExpressResponse, diff --git a/apps/backend-nest/src/routes/index.ts b/apps/backend-nest/src/routes/index.ts index 61dd4027cf5..0ce08526c55 100644 --- a/apps/backend-nest/src/routes/index.ts +++ b/apps/backend-nest/src/routes/index.ts @@ -6,8 +6,6 @@ const controller_glob_result = import.meta.glob('./*.controller.ts', { }); const controllers = Object.values(controller_glob_result); -@Module({ - controllers, -}) +@Module({ controllers }) // eslint-disable-next-line @typescript-eslint/no-extraneous-class export class RoutesModule {} From 5010897c7b2bb06c6e8ea039c6281283fb3d2fc5 Mon Sep 17 00:00:00 2001 From: Dlovely <591562538@qq.com> Date: Mon, 4 Nov 2024 16:50:17 +0800 Subject: [PATCH 7/9] =?UTF-8?q?fix:=20=E8=BF=90=E8=A1=8C=E6=B5=8B=E8=AF=95?= =?UTF-8?q?=EF=BC=8C=E4=BF=AE=E5=A4=8D=E6=8E=A5=E5=8F=A3=E5=93=8D=E5=BA=94?= =?UTF-8?q?=E9=94=99=E8=AF=AF=E7=9A=84=E9=97=AE=E9=A2=98?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- apps/backend-nest/src/app/index.module.ts | 10 ++++++-- .../src/filters/http-exception.filter.ts | 10 +++++++- .../src/interceptor/transform.interceptor.ts | 16 ++++++++----- apps/backend-nest/src/middlewares/index.ts | 8 +++++++ .../src/middlewares/logger.middleware.ts | 23 +++++++++++++++++++ .../plugins/{cookies.ts => cookies.plugin.ts} | 0 apps/backend-nest/src/plugins/index.ts | 4 ++-- .../src/routes/auth.controller.ts | 22 +++++++++++++----- .../src/routes/index.controller.ts | 6 ++--- .../src/routes/user.controller.ts | 4 ++-- 10 files changed, 81 insertions(+), 22 deletions(-) create mode 100644 apps/backend-nest/src/middlewares/index.ts create mode 100644 apps/backend-nest/src/middlewares/logger.middleware.ts rename apps/backend-nest/src/plugins/{cookies.ts => cookies.plugin.ts} (100%) diff --git a/apps/backend-nest/src/app/index.module.ts b/apps/backend-nest/src/app/index.module.ts index 3a324fb7b2f..e477706704d 100644 --- a/apps/backend-nest/src/app/index.module.ts +++ b/apps/backend-nest/src/app/index.module.ts @@ -1,14 +1,20 @@ +import type { MiddlewareConsumer, NestModule } from '@nestjs/common'; + import { Module } from '@nestjs/common'; import { AuthModule } from '#/auth'; import filters from '#/filters'; import guards from '#/guards'; import interceptors from '#/interceptor'; +import middlewares from '#/middlewares'; import { RoutesModule } from '#/routes'; @Module({ imports: [RoutesModule, AuthModule], providers: [...guards, ...interceptors, ...filters], }) -// eslint-disable-next-line @typescript-eslint/no-extraneous-class -export class AppModule {} +export class AppModule implements NestModule { + configure(consumer: MiddlewareConsumer) { + consumer.apply(...middlewares).forRoutes('*'); + } +} diff --git a/apps/backend-nest/src/filters/http-exception.filter.ts b/apps/backend-nest/src/filters/http-exception.filter.ts index e731de6ede2..853ae2ef903 100644 --- a/apps/backend-nest/src/filters/http-exception.filter.ts +++ b/apps/backend-nest/src/filters/http-exception.filter.ts @@ -1,12 +1,19 @@ import type { ArgumentsHost, ExceptionFilter } from '@nestjs/common'; import type { Response } from 'express'; -import { BadRequestException, Catch, HttpException } from '@nestjs/common'; +import { + BadRequestException, + Catch, + HttpException, + Logger, +} from '@nestjs/common'; import { ResponseClass } from '#/interfaces/response'; @Catch(HttpException) export class HttpExceptionFilter implements ExceptionFilter { + private readonly logger = new Logger('HTTP错误响应'); + catch(exception: HttpException, host: ArgumentsHost) { const ctx = host.switchToHttp(); const response = ctx.getResponse(); @@ -37,6 +44,7 @@ export class HttpExceptionFilter implements ExceptionFilter { result.error = message; } + this.logger.verbose(JSON.stringify(result)); return response.status(status).json(result); } } diff --git a/apps/backend-nest/src/interceptor/transform.interceptor.ts b/apps/backend-nest/src/interceptor/transform.interceptor.ts index 9c66714f160..ba51c1b65af 100644 --- a/apps/backend-nest/src/interceptor/transform.interceptor.ts +++ b/apps/backend-nest/src/interceptor/transform.interceptor.ts @@ -4,7 +4,7 @@ import type { NestInterceptor, } from '@nestjs/common'; -import { Injectable } from '@nestjs/common'; +import { Injectable, Logger } from '@nestjs/common'; import { Reflector } from '@nestjs/core'; import { Observable } from 'rxjs'; import { map } from 'rxjs/operators'; @@ -15,6 +15,8 @@ import { ResponseClass, SkipResCheck } from '#/interfaces/response'; export class TransformInterceptor implements NestInterceptor> { + private readonly logger = new Logger('HTTP响应'); + constructor(private readonly Reflector: Reflector) {} intercept( @@ -26,11 +28,13 @@ export class TransformInterceptor [context.getHandler(), context.getClass()], ); - if (isSkipResCheck) { - return next.handle(); - } - - return next.handle().pipe(map((data) => ResponseClass.Success(data))); + return next.handle().pipe( + map((data) => { + data = isSkipResCheck ? data : ResponseClass.Success(data); + this.logger.verbose(JSON.stringify(data)); + return data; + }), + ); } } diff --git a/apps/backend-nest/src/middlewares/index.ts b/apps/backend-nest/src/middlewares/index.ts new file mode 100644 index 00000000000..e74a6f453d1 --- /dev/null +++ b/apps/backend-nest/src/middlewares/index.ts @@ -0,0 +1,8 @@ +import type { Type } from '@nestjs/common'; + +const glob_result = import.meta.glob('./*.middleware.ts', { + import: 'default', + eager: true, +}); + +export default Object.values(glob_result); diff --git a/apps/backend-nest/src/middlewares/logger.middleware.ts b/apps/backend-nest/src/middlewares/logger.middleware.ts new file mode 100644 index 00000000000..98bbc9e9084 --- /dev/null +++ b/apps/backend-nest/src/middlewares/logger.middleware.ts @@ -0,0 +1,23 @@ +import type { NestMiddleware } from '@nestjs/common'; +import type { NextFunction, Request, Response } from 'express'; + +import { Injectable, Logger } from '@nestjs/common'; + +@Injectable() +export class LoggerMiddleware implements NestMiddleware { + private readonly logger = new Logger('HTTP请求'); + + use(req: Request, _: Response, next: NextFunction) { + const { method, originalUrl: url, body, query, ip } = req; + + // 记录日志 + this.logger.verbose( + `[${method}] ${url} ${JSON.stringify({ body, query })} - ${ip}`, + ); + + next(); + } +} + +// 默认导出,便于glob导入 +export default LoggerMiddleware; diff --git a/apps/backend-nest/src/plugins/cookies.ts b/apps/backend-nest/src/plugins/cookies.plugin.ts similarity index 100% rename from apps/backend-nest/src/plugins/cookies.ts rename to apps/backend-nest/src/plugins/cookies.plugin.ts diff --git a/apps/backend-nest/src/plugins/index.ts b/apps/backend-nest/src/plugins/index.ts index 8ba79429d1a..c781e737464 100644 --- a/apps/backend-nest/src/plugins/index.ts +++ b/apps/backend-nest/src/plugins/index.ts @@ -1,8 +1,8 @@ -const glob_result = import.meta.glob(['./*.ts', '!./index.ts'], { +const glob_result = import.meta.glob('./*.plugin.ts', { import: 'default', eager: true, }); export default Object.values(glob_result); -export { Cookies } from './cookies'; +export { Cookies } from './cookies.plugin'; diff --git a/apps/backend-nest/src/routes/auth.controller.ts b/apps/backend-nest/src/routes/auth.controller.ts index 24a337acaea..09601f5e031 100644 --- a/apps/backend-nest/src/routes/auth.controller.ts +++ b/apps/backend-nest/src/routes/auth.controller.ts @@ -5,8 +5,8 @@ import { Controller, ForbiddenException, Post, - Request, - Response, + Req, + Res, UseGuards, } from '@nestjs/common'; import { JwtService } from '@nestjs/jwt'; @@ -28,7 +28,7 @@ export class AuthController { ) {} @All('codes') - public codes(@Request() req: Express.Request) { + public codes(@Req() req: Express.Request) { const codes = AuthService.MOCK_CODES.find( (item) => item.username === (req.user as Express.User).username, )?.codes; @@ -39,7 +39,10 @@ export class AuthController { @UseGuards(AuthGuard('local')) @Public() @Post('login') - public login(@Request() req: Express.Request, @Response() res: any) { + public login( + @Req() req: Express.Request, + @Res({ passthrough: true }) res: any, + ) { // 生成令牌 const accessToken = this.AuthService.getAccessToken( req.user as Express.User, @@ -54,7 +57,11 @@ export class AuthController { } @Post('logout') - public logout(@Response() res: any, @Cookies('jwt') refreshToken?: string) { + @Public() + public logout( + @Res({ passthrough: true }) res: any, + @Cookies('jwt') refreshToken?: string, + ) { if (!refreshToken) { return ''; } @@ -65,7 +72,10 @@ export class AuthController { } @Post('refresh') - public refresh(@Response() res: any, @Cookies('jwt') refreshToken?: string) { + public refresh( + @Res({ passthrough: true }) res: any, + @Cookies('jwt') refreshToken?: string, + ) { if (!refreshToken) { throw new ForbiddenException(); } diff --git a/apps/backend-nest/src/routes/index.controller.ts b/apps/backend-nest/src/routes/index.controller.ts index 21821f04205..6cd7d77be3b 100644 --- a/apps/backend-nest/src/routes/index.controller.ts +++ b/apps/backend-nest/src/routes/index.controller.ts @@ -1,6 +1,6 @@ -import type { Response as ExpressResponse } from 'express'; +import type { Response } from 'express'; -import { All, Controller, Query, Response } from '@nestjs/common'; +import { All, Controller, Query, Res } from '@nestjs/common'; import { Public } from '#/guards'; import { SkipResCheck } from '#/interfaces/response'; @@ -25,7 +25,7 @@ export class UserController { @All('status') public status( - @Response() res: ExpressResponse, + @Res({ passthrough: true }) res: Response, @Query('status') status: string, ) { res.status(Number(status)); diff --git a/apps/backend-nest/src/routes/user.controller.ts b/apps/backend-nest/src/routes/user.controller.ts index c58d322b600..3de016262c8 100644 --- a/apps/backend-nest/src/routes/user.controller.ts +++ b/apps/backend-nest/src/routes/user.controller.ts @@ -1,9 +1,9 @@ -import { All, Controller, Request } from '@nestjs/common'; +import { All, Controller, Req } from '@nestjs/common'; @Controller('user') export class UserController { @All('info') - public codes(@Request() req: Express.Request) { + public codes(@Req() req: Express.Request) { return req.user as Express.User; } } From bf0183a743dddc8da48bd4419111c0b296cbc7b1 Mon Sep 17 00:00:00 2001 From: Dlovely <591562538@qq.com> Date: Mon, 4 Nov 2024 16:50:49 +0800 Subject: [PATCH 8/9] =?UTF-8?q?docs:=20=E6=9B=B4=E6=96=B0nestjs=E6=A8=A1?= =?UTF-8?q?=E7=89=88=E7=9B=B8=E5=85=B3=E6=96=87=E6=A1=A3?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- apps/backend-nest/.env | 2 +- apps/backend-nest/.env.development | 2 +- apps/web-antd/.env.development | 2 +- docs/src/guide/essentials/server.md | 85 ++++++++++++++++++++++++++++- 4 files changed, 87 insertions(+), 4 deletions(-) diff --git a/apps/backend-nest/.env b/apps/backend-nest/.env index 4d805fc5937..6f30c9d621a 100644 --- a/apps/backend-nest/.env +++ b/apps/backend-nest/.env @@ -4,7 +4,7 @@ VITE_ADAPTER=nest # 应用名称 VITE_APP_NAME=Vben Server -# 应用入口 +# 应用入口的路径 VITE_APP_PATH=src # 应用入口的导出变量 diff --git a/apps/backend-nest/.env.development b/apps/backend-nest/.env.development index cf1244b427d..a06c08c378f 100644 --- a/apps/backend-nest/.env.development +++ b/apps/backend-nest/.env.development @@ -1,5 +1,5 @@ # 端口号 -VITE_PORT=5777 +VITE_PORT=5320 # 是否开启 SWC VITE_SWC=true diff --git a/apps/web-antd/.env.development b/apps/web-antd/.env.development index c138f482918..1eae9e67d48 100644 --- a/apps/web-antd/.env.development +++ b/apps/web-antd/.env.development @@ -7,7 +7,7 @@ VITE_BASE=/ VITE_GLOB_API_URL=/api # 是否开启 Nitro Mock服务,true 为开启,false 为关闭 -VITE_NITRO_MOCK=true +VITE_NITRO_MOCK=false # 是否打开 devtools,true 为打开,false 为关闭 VITE_DEVTOOLS=false diff --git a/docs/src/guide/essentials/server.md b/docs/src/guide/essentials/server.md index 74a45d2ee34..988b6bb8838 100644 --- a/docs/src/guide/essentials/server.md +++ b/docs/src/guide/essentials/server.md @@ -349,7 +349,7 @@ Mock 服务代码位于`apps/backend-mock`目录下,无需手动启动,已 [Nitro](https://nitro.unjs.io/) 语法简单,可以根据自己的需求进行配置及开发,具体配置可以查看 [Nitro 文档](https://nitro.unjs.io/)。 -## 关闭 Mock 服务 +### 关闭 Mock 服务 mock的本质是一个真实的后端服务,如果不需要 mock 服务,可以在项目根目录下的 `.env.development` 文件中配置 `VITE_NITRO_MOCK=false` 即可关闭 mock 服务。 @@ -357,3 +357,86 @@ mock的本质是一个真实的后端服务,如果不需要 mock 服务,可 # .env.development VITE_NITRO_MOCK=false ``` + +## NodeJS服务端 + +::: tip 说明 + +如果使用 NodeJS 作为服务端开发语言,也可以使用`Vben Admin`框架进行工程化管理。模板代码位于`apps/backend-nest`目录下,以[`vite-plugin-node`插件](https://github.com/axe-me/vite-plugin-node)配合`Vite`启动,以[NestJS](https://nestjs.com/)为服务运行程序搭建,可以根据自己的需求进行配置及开发。 + +::: + +### 启动服务 + +在项目根目录下运行以下命令即可启动服务: + +```bash +pnpm dev:nest +``` + +### 更改适配器 + +在项目根目录下的 `.env.development` 文件中配置 `VITE_ADAPTER` 即可更改适配器: + +```bash +# 可选的适配器有:express、nest、koa、fastify +VITE_ADAPTER=nest +``` + +::: tip 自定义适配器 + +参考[`vite-plugin-node`自定义适配器介绍](https://github.com/axe-me/vite-plugin-node?tab=readme-ov-file#custom-adapter),在项目根目录下的 `vite.config.mts` 文件中配置 `server.adapter` 即可自定义适配器。 + +```ts +// vite.config.mts +import { defineConfig } from '@vben/vite-config'; + +export default defineConfig(async () => { + return { + server: { + adapter({ app, server, req, res, next }) { + app(res, res); + }, + }, + vite: {}, + }; +}, 'server'); +``` + +::: + +### 配置应用入口文件 + +在项目根目录下的 `.env` 文件中配置 `VITE_APP_PATH` 和 `VITE_EXPORT_NAME` 即可更改应用入口: + +```bash +# 应用入口的路径,例如入口文件为`src/index.ts`则可以配置为`src` +VITE_APP_PATH=src + +# 应用入口的导出变量,例如入口文件使用默认导出则可以配置为`default` +VITE_EXPORT_NAME=default +``` + +### 立即启动服务 + +在项目根目录下的 `.env` 文件中配置 `VITE_IMMEDIATE` 即可立即启动服务: + +```bash +# 立即启动 +VITE_IMMEDIATE=true +``` + +### 依据环境设置的参数 + +由于是服务端程序,开发环境和生产环境的参数类型高度一致,在此统一介绍,具体参考`.env.development`和`.env.production`文件。 + +```bash +# 端口号 +VITE_PORT=5320 + +# 是否开启 SWC 编译 +VITE_SWC=true + +# JWT密钥 +VITE_JWT_SECRET=your_jwt_secret +``` From 6ea7a63af222a1dc27ad8a06ecd2e56c474bbeab Mon Sep 17 00:00:00 2001 From: Dlovely <591562538@qq.com> Date: Mon, 4 Nov 2024 17:58:20 +0800 Subject: [PATCH 9/9] chore: changeset --- .changeset/old-dots-live.md | 9 +++++++++ 1 file changed, 9 insertions(+) create mode 100644 .changeset/old-dots-live.md diff --git a/.changeset/old-dots-live.md b/.changeset/old-dots-live.md new file mode 100644 index 00000000000..c41399938a5 --- /dev/null +++ b/.changeset/old-dots-live.md @@ -0,0 +1,9 @@ +--- +'@vben/backend-nest': patch +'@vben/docs': patch +'@vben/vite-config': patch +--- + +feat: 新增nest模板 + +feat: 新增server类型的vite配置