prime-dev-cli 1.0.7 → 1.0.9
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/config/projects.json +34 -1
- package/dist/server/.next/BUILD_ID +1 -1
- package/dist/server/.next/app-build-manifest.json +34 -180
- package/dist/server/.next/app-path-routes-manifest.json +13 -12
- package/dist/server/.next/build/chunks/[root-of-the-server]__5583c180._.js +491 -0
- package/dist/server/.next/build/chunks/[root-of-the-server]__5583c180._.js.map +11 -0
- package/dist/server/.next/build/chunks/[root-of-the-server]__f95a3f97._.js +173 -0
- package/dist/server/.next/build/chunks/[root-of-the-server]__f95a3f97._.js.map +7 -0
- package/dist/server/.next/build/chunks/[turbopack]_runtime.js +688 -0
- package/dist/server/.next/build/chunks/[turbopack]_runtime.js.map +10 -0
- package/dist/server/.next/build/chunks/node_modules__pnpm_ec38a98b._.js +6748 -0
- package/dist/server/.next/build/chunks/node_modules__pnpm_ec38a98b._.js.map +47 -0
- package/dist/server/.next/build/chunks/packages_server_postcss_config_mjs_transform_ts_18d17415._.js +17 -0
- package/dist/server/.next/build/chunks/packages_server_postcss_config_mjs_transform_ts_18d17415._.js.map +5 -0
- package/dist/server/.next/build-manifest.json +22 -24
- package/dist/server/.next/cache/.rscinfo +1 -1
- package/dist/server/.next/cache/.tsbuildinfo +1 -1
- package/dist/server/.next/cache/eslint/.cache_1qa5vxt +1 -1
- package/dist/server/.next/cache/webpack/client-production/0.pack +0 -0
- package/dist/server/.next/cache/webpack/client-production/1.pack +0 -0
- package/dist/server/.next/cache/webpack/client-production/2.pack +0 -0
- package/dist/server/.next/cache/webpack/client-production/index.pack +0 -0
- package/dist/server/.next/cache/webpack/client-production/index.pack.old +0 -0
- package/dist/server/.next/cache/webpack/edge-server-production/index.pack +0 -0
- package/dist/server/.next/cache/webpack/edge-server-production/index.pack.old +0 -0
- package/dist/server/.next/cache/webpack/server-production/0.pack +0 -0
- package/dist/server/.next/cache/webpack/server-production/1.pack +0 -0
- package/dist/server/.next/cache/webpack/server-production/index.pack +0 -0
- package/dist/server/.next/cache/webpack/server-production/index.pack.old +0 -0
- package/dist/server/.next/fallback-build-manifest.json +23 -0
- package/dist/server/.next/next-minimal-server.js.nft.json +1 -1
- package/dist/server/.next/next-server.js.nft.json +1 -1
- package/dist/server/.next/prerender-manifest.json +3 -3
- package/dist/server/.next/required-server-files.json +0 -2
- package/dist/server/.next/server/app/_not-found/page/app-build-manifest.json +13 -0
- package/dist/server/.next/server/app/_not-found/page/app-paths-manifest.json +3 -0
- package/dist/server/.next/server/app/_not-found/page/build-manifest.json +17 -0
- package/dist/server/.next/server/app/_not-found/page/next-font-manifest.json +6 -0
- package/dist/server/.next/server/app/_not-found/page/react-loadable-manifest.json +1 -0
- package/dist/server/.next/server/app/_not-found/page/server-reference-manifest.json +4 -0
- package/dist/server/.next/server/app/_not-found/page.js +13 -1
- package/dist/server/.next/server/app/_not-found/page.js.map +5 -0
- package/dist/server/.next/server/app/_not-found/page.js.nft.json +1 -1
- package/dist/server/.next/server/app/_not-found/page_client-reference-manifest.js +2 -1
- package/dist/server/.next/server/app/_not-found.html +1 -1
- package/dist/server/.next/server/app/_not-found.rsc +11 -11
- package/dist/server/.next/server/app/api/all-projects-envs/route/app-build-manifest.json +11 -0
- package/dist/server/.next/server/app/api/all-projects-envs/route/app-paths-manifest.json +3 -0
- package/dist/server/.next/server/app/api/all-projects-envs/route/build-manifest.json +17 -0
- package/dist/server/.next/server/app/api/all-projects-envs/route/next-font-manifest.json +6 -0
- package/dist/server/.next/server/app/api/all-projects-envs/route/react-loadable-manifest.json +1 -0
- package/dist/server/.next/server/app/api/all-projects-envs/route/server-reference-manifest.json +4 -0
- package/dist/server/.next/server/app/api/all-projects-envs/route.js +8 -1
- package/dist/server/.next/server/app/api/all-projects-envs/route.js.map +5 -0
- package/dist/server/.next/server/app/api/all-projects-envs/route.js.nft.json +1 -1
- package/dist/server/.next/server/app/api/all-projects-envs/route_client-reference-manifest.js +2 -1
- package/dist/server/.next/server/app/api/check-mock-intercept/route/app-build-manifest.json +11 -0
- package/dist/server/.next/server/app/api/check-mock-intercept/route/app-paths-manifest.json +3 -0
- package/dist/server/.next/server/app/api/check-mock-intercept/route/build-manifest.json +17 -0
- package/dist/server/.next/server/app/api/check-mock-intercept/route/next-font-manifest.json +6 -0
- package/dist/server/.next/server/app/api/check-mock-intercept/route/react-loadable-manifest.json +1 -0
- package/dist/server/.next/server/app/api/check-mock-intercept/route/server-reference-manifest.json +4 -0
- package/dist/server/.next/server/app/api/check-mock-intercept/route.js +8 -1
- package/dist/server/.next/server/app/api/check-mock-intercept/route.js.map +5 -0
- package/dist/server/.next/server/app/api/check-mock-intercept/route.js.nft.json +1 -1
- package/dist/server/.next/server/app/api/check-mock-intercept/route_client-reference-manifest.js +2 -1
- package/dist/server/.next/server/app/api/check-workspace/route/app-build-manifest.json +11 -0
- package/dist/server/.next/server/app/api/check-workspace/route/app-paths-manifest.json +3 -0
- package/dist/server/.next/server/app/api/check-workspace/route/build-manifest.json +17 -0
- package/dist/server/.next/server/app/api/check-workspace/route/next-font-manifest.json +6 -0
- package/dist/server/.next/server/app/api/check-workspace/route/react-loadable-manifest.json +1 -0
- package/dist/server/.next/server/app/api/check-workspace/route/server-reference-manifest.json +4 -0
- package/dist/server/.next/server/app/api/check-workspace/route.js +7 -14
- package/dist/server/.next/server/app/api/check-workspace/route.js.map +5 -0
- package/dist/server/.next/server/app/api/check-workspace/route.js.nft.json +1 -1
- package/dist/server/.next/server/app/api/check-workspace/route_client-reference-manifest.js +2 -1
- package/dist/server/.next/server/app/api/cleanup-mock/route/app-build-manifest.json +11 -0
- package/dist/server/.next/server/app/api/cleanup-mock/route/app-paths-manifest.json +3 -0
- package/dist/server/.next/server/app/api/cleanup-mock/route/build-manifest.json +17 -0
- package/dist/server/.next/server/app/api/cleanup-mock/route/next-font-manifest.json +6 -0
- package/dist/server/.next/server/app/api/cleanup-mock/route/react-loadable-manifest.json +1 -0
- package/dist/server/.next/server/app/api/cleanup-mock/route/server-reference-manifest.json +4 -0
- package/dist/server/.next/server/app/api/cleanup-mock/route.js +8 -6
- package/dist/server/.next/server/app/api/cleanup-mock/route.js.map +5 -0
- package/dist/server/.next/server/app/api/cleanup-mock/route.js.nft.json +1 -1
- package/dist/server/.next/server/app/api/cleanup-mock/route_client-reference-manifest.js +2 -1
- package/dist/server/.next/server/app/api/cleanup-project/route/app-build-manifest.json +11 -0
- package/dist/server/.next/server/app/api/cleanup-project/route/app-paths-manifest.json +3 -0
- package/dist/server/.next/server/app/api/cleanup-project/route/build-manifest.json +17 -0
- package/dist/server/.next/server/app/api/cleanup-project/route/next-font-manifest.json +6 -0
- package/dist/server/.next/server/app/api/cleanup-project/route/react-loadable-manifest.json +1 -0
- package/dist/server/.next/server/app/api/cleanup-project/route/server-reference-manifest.json +4 -0
- package/dist/server/.next/server/app/api/cleanup-project/route.js +8 -1
- package/dist/server/.next/server/app/api/cleanup-project/route.js.map +5 -0
- package/dist/server/.next/server/app/api/cleanup-project/route.js.nft.json +1 -1
- package/dist/server/.next/server/app/api/cleanup-project/route_client-reference-manifest.js +2 -1
- package/dist/server/.next/server/app/api/delete-mock-api/route/app-build-manifest.json +11 -0
- package/dist/server/.next/server/app/api/delete-mock-api/route/app-paths-manifest.json +3 -0
- package/dist/server/.next/server/app/api/delete-mock-api/route/build-manifest.json +17 -0
- package/dist/server/.next/server/app/api/delete-mock-api/route/next-font-manifest.json +6 -0
- package/dist/server/.next/server/app/api/delete-mock-api/route/react-loadable-manifest.json +1 -0
- package/dist/server/.next/server/app/api/delete-mock-api/route/server-reference-manifest.json +4 -0
- package/dist/server/.next/server/app/api/delete-mock-api/route.js +8 -0
- package/dist/server/.next/server/app/api/delete-mock-api/route.js.map +5 -0
- package/dist/server/.next/server/app/api/delete-mock-api/route.js.nft.json +1 -0
- package/dist/server/.next/server/app/api/delete-mock-api/route_client-reference-manifest.js +2 -0
- package/dist/server/.next/server/app/api/get-mock-data/route/app-build-manifest.json +11 -0
- package/dist/server/.next/server/app/api/get-mock-data/route/app-paths-manifest.json +3 -0
- package/dist/server/.next/server/app/api/get-mock-data/route/build-manifest.json +17 -0
- package/dist/server/.next/server/app/api/get-mock-data/route/next-font-manifest.json +6 -0
- package/dist/server/.next/server/app/api/get-mock-data/route/react-loadable-manifest.json +1 -0
- package/dist/server/.next/server/app/api/get-mock-data/route/server-reference-manifest.json +4 -0
- package/dist/server/.next/server/app/api/get-mock-data/route.js +8 -1
- package/dist/server/.next/server/app/api/get-mock-data/route.js.map +5 -0
- package/dist/server/.next/server/app/api/get-mock-data/route.js.nft.json +1 -1
- package/dist/server/.next/server/app/api/get-mock-data/route_client-reference-manifest.js +2 -1
- package/dist/server/.next/server/app/api/initialize-workspace/route/app-build-manifest.json +11 -0
- package/dist/server/.next/server/app/api/initialize-workspace/route/app-paths-manifest.json +3 -0
- package/dist/server/.next/server/app/api/initialize-workspace/route/build-manifest.json +17 -0
- package/dist/server/.next/server/app/api/initialize-workspace/route/next-font-manifest.json +6 -0
- package/dist/server/.next/server/app/api/initialize-workspace/route/react-loadable-manifest.json +1 -0
- package/dist/server/.next/server/app/api/initialize-workspace/route/server-reference-manifest.json +4 -0
- package/dist/server/.next/server/app/api/initialize-workspace/route.js +7 -18
- package/dist/server/.next/server/app/api/initialize-workspace/route.js.map +5 -0
- package/dist/server/.next/server/app/api/initialize-workspace/route.js.nft.json +1 -1
- package/dist/server/.next/server/app/api/initialize-workspace/route_client-reference-manifest.js +2 -1
- package/dist/server/.next/server/app/api/microapp-proxy-change-stream/route/app-build-manifest.json +11 -0
- package/dist/server/.next/server/app/api/microapp-proxy-change-stream/route/app-paths-manifest.json +3 -0
- package/dist/server/.next/server/app/api/microapp-proxy-change-stream/route/build-manifest.json +17 -0
- package/dist/server/.next/server/app/api/microapp-proxy-change-stream/route/next-font-manifest.json +6 -0
- package/dist/server/.next/server/app/api/microapp-proxy-change-stream/route/react-loadable-manifest.json +1 -0
- package/dist/server/.next/server/app/api/microapp-proxy-change-stream/route/server-reference-manifest.json +4 -0
- package/dist/server/.next/server/app/api/microapp-proxy-change-stream/route.js +8 -5
- package/dist/server/.next/server/app/api/microapp-proxy-change-stream/route.js.map +5 -0
- package/dist/server/.next/server/app/api/microapp-proxy-change-stream/route.js.nft.json +1 -1
- package/dist/server/.next/server/app/api/microapp-proxy-change-stream/route_client-reference-manifest.js +2 -1
- package/dist/server/.next/server/app/api/microapp-proxy-config/route/app-build-manifest.json +11 -0
- package/dist/server/.next/server/app/api/microapp-proxy-config/route/app-paths-manifest.json +3 -0
- package/dist/server/.next/server/app/api/microapp-proxy-config/route/build-manifest.json +17 -0
- package/dist/server/.next/server/app/api/microapp-proxy-config/route/next-font-manifest.json +6 -0
- package/dist/server/.next/server/app/api/microapp-proxy-config/route/react-loadable-manifest.json +1 -0
- package/dist/server/.next/server/app/api/microapp-proxy-config/route/server-reference-manifest.json +4 -0
- package/dist/server/.next/server/app/api/microapp-proxy-config/route.js +8 -3
- package/dist/server/.next/server/app/api/microapp-proxy-config/route.js.map +5 -0
- package/dist/server/.next/server/app/api/microapp-proxy-config/route.js.nft.json +1 -1
- package/dist/server/.next/server/app/api/microapp-proxy-config/route_client-reference-manifest.js +2 -1
- package/dist/server/.next/server/app/api/mock-file/route/app-build-manifest.json +11 -0
- package/dist/server/.next/server/app/api/mock-file/route/app-paths-manifest.json +3 -0
- package/dist/server/.next/server/app/api/mock-file/route/build-manifest.json +17 -0
- package/dist/server/.next/server/app/api/mock-file/route/next-font-manifest.json +6 -0
- package/dist/server/.next/server/app/api/mock-file/route/react-loadable-manifest.json +1 -0
- package/dist/server/.next/server/app/api/mock-file/route/server-reference-manifest.json +4 -0
- package/dist/server/.next/server/app/api/mock-file/route.js +8 -6
- package/dist/server/.next/server/app/api/mock-file/route.js.map +5 -0
- package/dist/server/.next/server/app/api/mock-file/route.js.nft.json +1 -1
- package/dist/server/.next/server/app/api/mock-file/route_client-reference-manifest.js +2 -1
- package/dist/server/.next/server/app/api/mock-file-content/route/app-build-manifest.json +11 -0
- package/dist/server/.next/server/app/api/mock-file-content/route/app-paths-manifest.json +3 -0
- package/dist/server/.next/server/app/api/mock-file-content/route/build-manifest.json +17 -0
- package/dist/server/.next/server/app/api/mock-file-content/route/next-font-manifest.json +6 -0
- package/dist/server/.next/server/app/api/mock-file-content/route/react-loadable-manifest.json +1 -0
- package/dist/server/.next/server/app/api/mock-file-content/route/server-reference-manifest.json +4 -0
- package/dist/server/.next/server/app/api/mock-file-content/route.js +8 -1
- package/dist/server/.next/server/app/api/mock-file-content/route.js.map +5 -0
- package/dist/server/.next/server/app/api/mock-file-content/route.js.nft.json +1 -1
- package/dist/server/.next/server/app/api/mock-file-content/route_client-reference-manifest.js +2 -1
- package/dist/server/.next/server/app/api/mock-open-status/route/app-build-manifest.json +11 -0
- package/dist/server/.next/server/app/api/mock-open-status/route/app-paths-manifest.json +3 -0
- package/dist/server/.next/server/app/api/mock-open-status/route/build-manifest.json +17 -0
- package/dist/server/.next/server/app/api/mock-open-status/route/next-font-manifest.json +6 -0
- package/dist/server/.next/server/app/api/mock-open-status/route/react-loadable-manifest.json +1 -0
- package/dist/server/.next/server/app/api/mock-open-status/route/server-reference-manifest.json +4 -0
- package/dist/server/.next/server/app/api/mock-open-status/route.js +8 -6
- package/dist/server/.next/server/app/api/mock-open-status/route.js.map +5 -0
- package/dist/server/.next/server/app/api/mock-open-status/route.js.nft.json +1 -1
- package/dist/server/.next/server/app/api/mock-open-status/route_client-reference-manifest.js +2 -1
- package/dist/server/.next/server/app/api/mock-setting/route/app-build-manifest.json +11 -0
- package/dist/server/.next/server/app/api/mock-setting/route/app-paths-manifest.json +3 -0
- package/dist/server/.next/server/app/api/mock-setting/route/build-manifest.json +17 -0
- package/dist/server/.next/server/app/api/mock-setting/route/next-font-manifest.json +6 -0
- package/dist/server/.next/server/app/api/mock-setting/route/react-loadable-manifest.json +1 -0
- package/dist/server/.next/server/app/api/mock-setting/route/server-reference-manifest.json +4 -0
- package/dist/server/.next/server/app/api/mock-setting/route.js +8 -1
- package/dist/server/.next/server/app/api/mock-setting/route.js.map +5 -0
- package/dist/server/.next/server/app/api/mock-setting/route.js.nft.json +1 -1
- package/dist/server/.next/server/app/api/mock-setting/route_client-reference-manifest.js +2 -1
- package/dist/server/.next/server/app/api/open-all-mock/route/app-build-manifest.json +11 -0
- package/dist/server/.next/server/app/api/open-all-mock/route/app-paths-manifest.json +3 -0
- package/dist/server/.next/server/app/api/open-all-mock/route/build-manifest.json +17 -0
- package/dist/server/.next/server/app/api/open-all-mock/route/next-font-manifest.json +6 -0
- package/dist/server/.next/server/app/api/open-all-mock/route/react-loadable-manifest.json +1 -0
- package/dist/server/.next/server/app/api/open-all-mock/route/server-reference-manifest.json +4 -0
- package/dist/server/.next/server/app/api/open-all-mock/route.js +8 -11
- package/dist/server/.next/server/app/api/open-all-mock/route.js.map +5 -0
- package/dist/server/.next/server/app/api/open-all-mock/route.js.nft.json +1 -1
- package/dist/server/.next/server/app/api/open-all-mock/route_client-reference-manifest.js +2 -1
- package/dist/server/.next/server/app/api/open-project/route/app-build-manifest.json +11 -0
- package/dist/server/.next/server/app/api/open-project/route/app-paths-manifest.json +3 -0
- package/dist/server/.next/server/app/api/open-project/route/build-manifest.json +17 -0
- package/dist/server/.next/server/app/api/open-project/route/next-font-manifest.json +6 -0
- package/dist/server/.next/server/app/api/open-project/route/react-loadable-manifest.json +1 -0
- package/dist/server/.next/server/app/api/open-project/route/server-reference-manifest.json +4 -0
- package/dist/server/.next/server/app/api/open-project/route.js +7 -14
- package/dist/server/.next/server/app/api/open-project/route.js.map +5 -0
- package/dist/server/.next/server/app/api/open-project/route.js.nft.json +1 -1
- package/dist/server/.next/server/app/api/open-project/route_client-reference-manifest.js +2 -1
- package/dist/server/.next/server/app/api/process/logs/route/app-build-manifest.json +11 -0
- package/dist/server/.next/server/app/api/process/logs/route/app-paths-manifest.json +3 -0
- package/dist/server/.next/server/app/api/process/logs/route/build-manifest.json +17 -0
- package/dist/server/.next/server/app/api/process/logs/route/next-font-manifest.json +6 -0
- package/dist/server/.next/server/app/api/process/logs/route/react-loadable-manifest.json +1 -0
- package/dist/server/.next/server/app/api/process/logs/route/server-reference-manifest.json +4 -0
- package/dist/server/.next/server/app/api/process/logs/route.js +8 -1
- package/dist/server/.next/server/app/api/process/logs/route.js.map +5 -0
- package/dist/server/.next/server/app/api/process/logs/route.js.nft.json +1 -1
- package/dist/server/.next/server/app/api/process/logs/route_client-reference-manifest.js +2 -1
- package/dist/server/.next/server/app/api/process/logs/stream/route/app-build-manifest.json +11 -0
- package/dist/server/.next/server/app/api/process/logs/stream/route/app-paths-manifest.json +3 -0
- package/dist/server/.next/server/app/api/process/logs/stream/route/build-manifest.json +17 -0
- package/dist/server/.next/server/app/api/process/logs/stream/route/next-font-manifest.json +6 -0
- package/dist/server/.next/server/app/api/process/logs/stream/route/react-loadable-manifest.json +1 -0
- package/dist/server/.next/server/app/api/process/logs/stream/route/server-reference-manifest.json +4 -0
- package/dist/server/.next/server/app/api/process/logs/stream/route.js +7 -9
- package/dist/server/.next/server/app/api/process/logs/stream/route.js.map +5 -0
- package/dist/server/.next/server/app/api/process/logs/stream/route.js.nft.json +1 -1
- package/dist/server/.next/server/app/api/process/logs/stream/route_client-reference-manifest.js +2 -1
- package/dist/server/.next/server/app/api/process/start/route/app-build-manifest.json +11 -0
- package/dist/server/.next/server/app/api/process/start/route/app-paths-manifest.json +3 -0
- package/dist/server/.next/server/app/api/process/start/route/build-manifest.json +17 -0
- package/dist/server/.next/server/app/api/process/start/route/next-font-manifest.json +6 -0
- package/dist/server/.next/server/app/api/process/start/route/react-loadable-manifest.json +1 -0
- package/dist/server/.next/server/app/api/process/start/route/server-reference-manifest.json +4 -0
- package/dist/server/.next/server/app/api/process/start/route.js +8 -1
- package/dist/server/.next/server/app/api/process/start/route.js.map +5 -0
- package/dist/server/.next/server/app/api/process/start/route.js.nft.json +1 -1
- package/dist/server/.next/server/app/api/process/start/route_client-reference-manifest.js +2 -1
- package/dist/server/.next/server/app/api/process/status/route/app-build-manifest.json +11 -0
- package/dist/server/.next/server/app/api/process/status/route/app-paths-manifest.json +3 -0
- package/dist/server/.next/server/app/api/process/status/route/build-manifest.json +17 -0
- package/dist/server/.next/server/app/api/process/status/route/next-font-manifest.json +6 -0
- package/dist/server/.next/server/app/api/process/status/route/react-loadable-manifest.json +1 -0
- package/dist/server/.next/server/app/api/process/status/route/server-reference-manifest.json +4 -0
- package/dist/server/.next/server/app/api/process/status/route.js +8 -1
- package/dist/server/.next/server/app/api/process/status/route.js.map +5 -0
- package/dist/server/.next/server/app/api/process/status/route.js.nft.json +1 -1
- package/dist/server/.next/server/app/api/process/status/route_client-reference-manifest.js +2 -1
- package/dist/server/.next/server/app/api/project-config/route/app-build-manifest.json +11 -0
- package/dist/server/.next/server/app/api/project-config/route/app-paths-manifest.json +3 -0
- package/dist/server/.next/server/app/api/project-config/route/build-manifest.json +17 -0
- package/dist/server/.next/server/app/api/project-config/route/next-font-manifest.json +6 -0
- package/dist/server/.next/server/app/api/project-config/route/react-loadable-manifest.json +1 -0
- package/dist/server/.next/server/app/api/project-config/route/server-reference-manifest.json +4 -0
- package/dist/server/.next/server/app/api/project-config/route.js +8 -1
- package/dist/server/.next/server/app/api/project-config/route.js.map +5 -0
- package/dist/server/.next/server/app/api/project-config/route.js.nft.json +1 -1
- package/dist/server/.next/server/app/api/project-config/route_client-reference-manifest.js +2 -1
- package/dist/server/.next/server/app/api/retry-project/route/app-build-manifest.json +11 -0
- package/dist/server/.next/server/app/api/retry-project/route/app-paths-manifest.json +3 -0
- package/dist/server/.next/server/app/api/retry-project/route/build-manifest.json +17 -0
- package/dist/server/.next/server/app/api/retry-project/route/next-font-manifest.json +6 -0
- package/dist/server/.next/server/app/api/retry-project/route/react-loadable-manifest.json +1 -0
- package/dist/server/.next/server/app/api/retry-project/route/server-reference-manifest.json +4 -0
- package/dist/server/.next/server/app/api/retry-project/route.js +7 -14
- package/dist/server/.next/server/app/api/retry-project/route.js.map +5 -0
- package/dist/server/.next/server/app/api/retry-project/route.js.nft.json +1 -1
- package/dist/server/.next/server/app/api/retry-project/route_client-reference-manifest.js +2 -1
- package/dist/server/.next/server/app/configuration/page/app-build-manifest.json +15 -0
- package/dist/server/.next/server/app/configuration/page/app-paths-manifest.json +3 -0
- package/dist/server/.next/server/app/configuration/page/build-manifest.json +17 -0
- package/dist/server/.next/server/app/configuration/page/next-font-manifest.json +6 -0
- package/dist/server/.next/server/app/configuration/page/react-loadable-manifest.json +1 -0
- package/dist/server/.next/server/app/configuration/page/server-reference-manifest.json +4 -0
- package/dist/server/.next/server/app/configuration/page.js +14 -37
- package/dist/server/.next/server/app/configuration/page.js.map +5 -0
- package/dist/server/.next/server/app/configuration/page.js.nft.json +1 -1
- package/dist/server/.next/server/app/configuration/page_client-reference-manifest.js +2 -1
- package/dist/server/.next/server/app/configuration.html +1 -1
- package/dist/server/.next/server/app/configuration.rsc +13 -13
- package/dist/server/.next/server/app/favicon.ico/route/app-build-manifest.json +11 -0
- package/dist/server/.next/server/app/favicon.ico/route/app-paths-manifest.json +3 -0
- package/dist/server/.next/server/app/favicon.ico/route/build-manifest.json +17 -0
- package/dist/server/.next/server/app/favicon.ico/route.js +9 -1
- package/dist/server/.next/server/app/favicon.ico/route.js.map +5 -0
- package/dist/server/.next/server/app/favicon.ico/route.js.nft.json +1 -1
- package/dist/server/.next/server/app/index.html +1 -1
- package/dist/server/.next/server/app/index.rsc +11 -11
- package/dist/server/.next/server/app/initialization/page/app-build-manifest.json +15 -0
- package/dist/server/.next/server/app/initialization/page/app-paths-manifest.json +3 -0
- package/dist/server/.next/server/app/initialization/page/build-manifest.json +17 -0
- package/dist/server/.next/server/app/initialization/page/next-font-manifest.json +6 -0
- package/dist/server/.next/server/app/initialization/page/react-loadable-manifest.json +1 -0
- package/dist/server/.next/server/app/initialization/page/server-reference-manifest.json +4 -0
- package/dist/server/.next/server/app/initialization/page.js +14 -1
- package/dist/server/.next/server/app/initialization/page.js.map +5 -0
- package/dist/server/.next/server/app/initialization/page.js.nft.json +1 -1
- package/dist/server/.next/server/app/initialization/page_client-reference-manifest.js +2 -1
- package/dist/server/.next/server/app/initialization.html +1 -1
- package/dist/server/.next/server/app/initialization.rsc +12 -12
- package/dist/server/.next/server/app/page/app-build-manifest.json +13 -0
- package/dist/server/.next/server/app/page/app-paths-manifest.json +3 -0
- package/dist/server/.next/server/app/page/build-manifest.json +17 -0
- package/dist/server/.next/server/app/page/next-font-manifest.json +6 -0
- package/dist/server/.next/server/app/page/react-loadable-manifest.json +1 -0
- package/dist/server/.next/server/app/page/server-reference-manifest.json +4 -0
- package/dist/server/.next/server/app/page.js +16 -1
- package/dist/server/.next/server/app/page.js.map +5 -0
- package/dist/server/.next/server/app/page.js.nft.json +1 -1
- package/dist/server/.next/server/app/page_client-reference-manifest.js +2 -1
- package/dist/server/.next/server/app-paths-manifest.json +13 -12
- package/dist/server/.next/server/chunks/9bf22_next_37c78c05._.js +15 -0
- package/dist/server/.next/server/chunks/9bf22_next_37c78c05._.js.map +1 -0
- package/dist/server/.next/server/chunks/9bf22_next_dist_6f19b364._.js +22 -0
- package/dist/server/.next/server/chunks/9bf22_next_dist_6f19b364._.js.map +1 -0
- package/dist/server/.next/server/chunks/9bf22_next_dist_7a32bfc3._.js +22 -0
- package/dist/server/.next/server/chunks/9bf22_next_dist_7a32bfc3._.js.map +1 -0
- package/dist/server/.next/server/chunks/9bf22_next_dist_800492fd._.js +4 -0
- package/dist/server/.next/server/chunks/9bf22_next_dist_800492fd._.js.map +1 -0
- package/dist/server/.next/server/chunks/[root-of-the-server]__0111ac14._.js +18 -0
- package/dist/server/.next/server/chunks/[root-of-the-server]__0111ac14._.js.map +1 -0
- package/dist/server/.next/server/chunks/[root-of-the-server]__1efea51d._.js +13 -0
- package/dist/server/.next/server/chunks/[root-of-the-server]__1efea51d._.js.map +1 -0
- package/dist/server/.next/server/chunks/[root-of-the-server]__21616bf9._.js +3 -0
- package/dist/server/.next/server/chunks/[root-of-the-server]__21616bf9._.js.map +1 -0
- package/dist/server/.next/server/chunks/[root-of-the-server]__27f3b464._.js +3 -0
- package/dist/server/.next/server/chunks/[root-of-the-server]__27f3b464._.js.map +1 -0
- package/dist/server/.next/server/chunks/[root-of-the-server]__29969c0b._.js +3 -0
- package/dist/server/.next/server/chunks/[root-of-the-server]__29969c0b._.js.map +1 -0
- package/dist/server/.next/server/chunks/[root-of-the-server]__3da8edfd._.js +3 -0
- package/dist/server/.next/server/chunks/[root-of-the-server]__3da8edfd._.js.map +1 -0
- package/dist/server/.next/server/chunks/[root-of-the-server]__525f44e0._.js +7 -0
- package/dist/server/.next/server/chunks/[root-of-the-server]__525f44e0._.js.map +1 -0
- package/dist/server/.next/server/chunks/[root-of-the-server]__5fde5218._.js +3 -0
- package/dist/server/.next/server/chunks/[root-of-the-server]__5fde5218._.js.map +1 -0
- package/dist/server/.next/server/chunks/[root-of-the-server]__616d1a09._.js +3 -0
- package/dist/server/.next/server/chunks/[root-of-the-server]__616d1a09._.js.map +1 -0
- package/dist/server/.next/server/chunks/[root-of-the-server]__63462bcb._.js +16 -0
- package/dist/server/.next/server/chunks/[root-of-the-server]__63462bcb._.js.map +1 -0
- package/dist/server/.next/server/chunks/[root-of-the-server]__66ca8d3f._.js +11 -0
- package/dist/server/.next/server/chunks/[root-of-the-server]__66ca8d3f._.js.map +1 -0
- package/dist/server/.next/server/chunks/[root-of-the-server]__7a46f739._.js +16 -0
- package/dist/server/.next/server/chunks/[root-of-the-server]__7a46f739._.js.map +1 -0
- package/dist/server/.next/server/chunks/[root-of-the-server]__84542811._.js +8 -0
- package/dist/server/.next/server/chunks/[root-of-the-server]__84542811._.js.map +1 -0
- package/dist/server/.next/server/chunks/[root-of-the-server]__92625851._.js +5 -0
- package/dist/server/.next/server/chunks/[root-of-the-server]__92625851._.js.map +1 -0
- package/dist/server/.next/server/chunks/[root-of-the-server]__9544d1f9._.js +20 -0
- package/dist/server/.next/server/chunks/[root-of-the-server]__9544d1f9._.js.map +1 -0
- package/dist/server/.next/server/chunks/[root-of-the-server]__b68e0025._.js +3 -0
- package/dist/server/.next/server/chunks/[root-of-the-server]__b68e0025._.js.map +1 -0
- package/dist/server/.next/server/chunks/[root-of-the-server]__c43c9880._.js +3 -0
- package/dist/server/.next/server/chunks/[root-of-the-server]__c43c9880._.js.map +1 -0
- package/dist/server/.next/server/chunks/[root-of-the-server]__c513ec4a._.js +8 -0
- package/dist/server/.next/server/chunks/[root-of-the-server]__c513ec4a._.js.map +1 -0
- package/dist/server/.next/server/chunks/[root-of-the-server]__dfe36c1a._.js +3 -0
- package/dist/server/.next/server/chunks/[root-of-the-server]__dfe36c1a._.js.map +1 -0
- package/dist/server/.next/server/chunks/[root-of-the-server]__ec0f2f72._.js +3 -0
- package/dist/server/.next/server/chunks/[root-of-the-server]__ec0f2f72._.js.map +1 -0
- package/dist/server/.next/server/chunks/[root-of-the-server]__ec631eb4._.js +3 -0
- package/dist/server/.next/server/chunks/[root-of-the-server]__ec631eb4._.js.map +1 -0
- package/dist/server/.next/server/chunks/[root-of-the-server]__f6d4fb58._.js +16 -0
- package/dist/server/.next/server/chunks/[root-of-the-server]__f6d4fb58._.js.map +1 -0
- package/dist/server/.next/server/chunks/[root-of-the-server]__fab72f0c._.js +3 -0
- package/dist/server/.next/server/chunks/[root-of-the-server]__fab72f0c._.js.map +1 -0
- package/dist/server/.next/server/chunks/[turbopack]_runtime.js +688 -0
- package/dist/server/.next/server/chunks/[turbopack]_runtime.js.map +10 -0
- package/dist/server/.next/server/chunks/_88faf93c._.js +14 -0
- package/dist/server/.next/server/chunks/_88faf93c._.js.map +1 -0
- package/dist/server/.next/server/chunks/ssr/9bf22_next_dist_05ac4f07._.js +4 -0
- package/dist/server/.next/server/chunks/ssr/9bf22_next_dist_05ac4f07._.js.map +1 -0
- package/dist/server/.next/server/chunks/ssr/9bf22_next_dist_0c9074c5._.js +22 -0
- package/dist/server/.next/server/chunks/ssr/9bf22_next_dist_0c9074c5._.js.map +1 -0
- package/dist/server/.next/server/chunks/ssr/9bf22_next_dist_client_components_forbidden-error_bdb9d650.js +3 -0
- package/dist/server/.next/server/chunks/ssr/9bf22_next_dist_client_components_forbidden-error_bdb9d650.js.map +1 -0
- package/dist/server/.next/server/chunks/ssr/9bf22_next_dist_client_components_unauthorized-error_67370d77.js +3 -0
- package/dist/server/.next/server/chunks/ssr/9bf22_next_dist_client_components_unauthorized-error_67370d77.js.map +1 -0
- package/dist/server/.next/server/chunks/ssr/9bf22_next_f7d8365b._.js +3 -0
- package/dist/server/.next/server/chunks/ssr/9bf22_next_f7d8365b._.js.map +1 -0
- package/dist/server/.next/server/chunks/ssr/[root-of-the-server]__065bacdf._.js +8 -0
- package/dist/server/.next/server/chunks/ssr/[root-of-the-server]__065bacdf._.js.map +1 -0
- package/dist/server/.next/server/chunks/ssr/[root-of-the-server]__63c188bd._.js +3 -0
- package/dist/server/.next/server/chunks/ssr/[root-of-the-server]__63c188bd._.js.map +1 -0
- package/dist/server/.next/server/chunks/ssr/[root-of-the-server]__6d393273._.js +3 -0
- package/dist/server/.next/server/chunks/ssr/[root-of-the-server]__6d393273._.js.map +1 -0
- package/dist/server/.next/server/chunks/ssr/[root-of-the-server]__789bc4bd._.js +3 -0
- package/dist/server/.next/server/chunks/ssr/[root-of-the-server]__789bc4bd._.js.map +1 -0
- package/dist/server/.next/server/chunks/ssr/[root-of-the-server]__b0aa0fa4._.js +6 -0
- package/dist/server/.next/server/chunks/ssr/[root-of-the-server]__b0aa0fa4._.js.map +1 -0
- package/dist/server/.next/server/chunks/ssr/[root-of-the-server]__b3e3ec35._.js +3 -0
- package/dist/server/.next/server/chunks/ssr/[root-of-the-server]__b3e3ec35._.js.map +1 -0
- package/dist/server/.next/server/chunks/ssr/[root-of-the-server]__c53d10ac._.js +3 -0
- package/dist/server/.next/server/chunks/ssr/[root-of-the-server]__c53d10ac._.js.map +1 -0
- package/dist/server/.next/server/chunks/ssr/[root-of-the-server]__f617a52d._.js +3 -0
- package/dist/server/.next/server/chunks/ssr/[root-of-the-server]__f617a52d._.js.map +1 -0
- package/dist/server/.next/server/chunks/ssr/[turbopack]_runtime.js +688 -0
- package/dist/server/.next/server/chunks/ssr/[turbopack]_runtime.js.map +10 -0
- package/dist/server/.next/server/chunks/ssr/_2488faea._.js +61 -0
- package/dist/server/.next/server/chunks/ssr/_2488faea._.js.map +1 -0
- package/dist/server/.next/server/chunks/ssr/_89496b8a._.js +3 -0
- package/dist/server/.next/server/chunks/ssr/_89496b8a._.js.map +1 -0
- package/dist/server/.next/server/chunks/ssr/_b0947ff2._.js +3 -0
- package/dist/server/.next/server/chunks/ssr/_b0947ff2._.js.map +1 -0
- package/dist/server/.next/server/chunks/ssr/_c38b6dab._.js +3 -0
- package/dist/server/.next/server/chunks/ssr/_c38b6dab._.js.map +1 -0
- package/dist/server/.next/server/chunks/ssr/_c9f0c772._.js +3 -0
- package/dist/server/.next/server/chunks/ssr/_c9f0c772._.js.map +1 -0
- package/dist/server/.next/server/chunks/ssr/_e037a20f._.js +4 -0
- package/dist/server/.next/server/chunks/ssr/_e037a20f._.js.map +1 -0
- package/dist/server/.next/server/chunks/ssr/_fbed5872._.js +3 -0
- package/dist/server/.next/server/chunks/ssr/_fbed5872._.js.map +1 -0
- package/dist/server/.next/server/chunks/ssr/node_modules__pnpm_50840a33._.js +3 -0
- package/dist/server/.next/server/chunks/ssr/node_modules__pnpm_50840a33._.js.map +1 -0
- package/dist/server/.next/server/chunks/ssr/node_modules__pnpm_bde53e93._.js +3 -0
- package/dist/server/.next/server/chunks/ssr/node_modules__pnpm_bde53e93._.js.map +1 -0
- package/dist/server/.next/server/chunks/ssr/node_modules__pnpm_da0d20e8._.js +4 -0
- package/dist/server/.next/server/chunks/ssr/node_modules__pnpm_da0d20e8._.js.map +1 -0
- package/dist/server/.next/server/chunks/ssr/packages_server_src_7cef6dbd._.js +3 -0
- package/dist/server/.next/server/chunks/ssr/packages_server_src_7cef6dbd._.js.map +1 -0
- package/dist/server/.next/server/chunks/ssr/packages_server_src_app_eb845476._.js +3 -0
- package/dist/server/.next/server/chunks/ssr/packages_server_src_app_eb845476._.js.map +1 -0
- package/dist/server/.next/server/chunks/ssr/packages_server_src_app_layout_tsx_0712e1b4._.js +3 -0
- package/dist/server/.next/server/chunks/ssr/packages_server_src_app_layout_tsx_0712e1b4._.js.map +1 -0
- package/dist/server/.next/server/middleware-build-manifest.js +33 -1
- package/dist/server/.next/server/middleware-manifest.json +2 -2
- package/dist/server/.next/server/next-font-manifest.js +1 -1
- package/dist/server/.next/server/next-font-manifest.json +6 -1
- package/dist/server/.next/server/pages/404.html +1 -1
- package/dist/server/.next/server/pages/500.html +1 -1
- package/dist/server/.next/server/pages/_app/build-manifest.json +15 -0
- package/dist/server/.next/server/pages/_app/next-font-manifest.json +6 -0
- package/dist/server/.next/server/pages/_app/pages-manifest.json +3 -0
- package/dist/server/.next/server/pages/_app/react-loadable-manifest.json +1 -0
- package/dist/server/.next/server/pages/_app.js +5 -1
- package/dist/server/.next/server/pages/_app.js.map +5 -0
- package/dist/server/.next/server/pages/_app.js.nft.json +1 -1
- package/dist/server/.next/server/pages/_document/next-font-manifest.json +6 -0
- package/dist/server/.next/server/pages/_document/pages-manifest.json +3 -0
- package/dist/server/.next/server/pages/_document/react-loadable-manifest.json +1 -0
- package/dist/server/.next/server/pages/_document.js +6 -1
- package/dist/server/.next/server/pages/_document.js.map +5 -0
- package/dist/server/.next/server/pages/_document.js.nft.json +1 -1
- package/dist/server/.next/server/pages/_error/build-manifest.json +15 -0
- package/dist/server/.next/server/pages/_error/next-font-manifest.json +6 -0
- package/dist/server/.next/server/pages/_error/pages-manifest.json +3 -0
- package/dist/server/.next/server/pages/_error/react-loadable-manifest.json +1 -0
- package/dist/server/.next/server/pages/_error.js +8 -1
- package/dist/server/.next/server/pages/_error.js.map +5 -0
- package/dist/server/.next/server/pages/_error.js.nft.json +1 -1
- package/dist/server/.next/server/pages-manifest.json +1 -1
- package/dist/server/.next/server/server-reference-manifest.js +1 -1
- package/dist/server/.next/server/server-reference-manifest.json +5 -1
- package/dist/server/.next/static/0L93NbbowsMpjl-fJPWIj/_buildManifest.js +1 -0
- package/dist/server/.next/static/0L93NbbowsMpjl-fJPWIj/_ssgManifest.js +1 -0
- package/dist/server/.next/static/CcPdKvbUmZBYZz_Z0RQOI/_buildManifest.js +1 -0
- package/dist/server/.next/static/CcPdKvbUmZBYZz_Z0RQOI/_clientMiddlewareManifest.json +1 -0
- package/dist/server/.next/static/CcPdKvbUmZBYZz_Z0RQOI/_ssgManifest.js +1 -0
- package/dist/server/.next/static/G7Z-m_yayOJWJic2pMxim/_buildManifest.js +1 -0
- package/dist/server/.next/static/G7Z-m_yayOJWJic2pMxim/_clientMiddlewareManifest.json +1 -0
- package/dist/server/.next/static/G7Z-m_yayOJWJic2pMxim/_ssgManifest.js +1 -0
- package/dist/server/.next/static/Vj8TOfdXSkRSgi8JoSCLF/_buildManifest.js +1 -0
- package/dist/server/.next/static/Vj8TOfdXSkRSgi8JoSCLF/_ssgManifest.js +1 -0
- package/dist/server/.next/static/chunks/09f18d884b3a25a2.js.map +1 -0
- package/dist/server/.next/static/chunks/0dfafa95d29e5c79.js +3 -0
- package/dist/server/.next/static/chunks/0e57f1354cda05d5.js +3 -0
- package/dist/server/.next/static/chunks/1923d6510bea25be.js +3 -0
- package/dist/server/.next/static/chunks/1f1c09f06b1f73d5.css +3 -0
- package/dist/server/.next/static/chunks/2316c3dde76bf12d.js.map +1 -0
- package/dist/server/.next/static/chunks/249486689b72c55c.js +3 -0
- package/dist/server/.next/static/chunks/28309924e4c23ccc.js +5 -0
- package/dist/server/.next/static/chunks/2af4b91fa7a98c52.js.map +1 -0
- package/dist/server/.next/static/chunks/2b6075b99689b028.css.map +1 -0
- package/dist/server/.next/static/chunks/2c669537f498f2db.js.map +1 -0
- package/dist/server/.next/static/chunks/371387b426d53320.js +3 -0
- package/dist/server/.next/static/chunks/4553c25757d4836f.js +3 -0
- package/dist/server/.next/static/chunks/4695aadfc21f48b8.js +5 -0
- package/dist/server/.next/static/chunks/512b4b5323114f56.js +61 -0
- package/dist/server/.next/static/chunks/5a52f39dbf60c0c2.js +3 -0
- package/dist/server/.next/static/chunks/5e9dc9d078da6e2d.js.map +1 -0
- package/dist/server/.next/static/chunks/62b241f445063308.js.map +1 -0
- package/dist/server/.next/static/chunks/65c345a4e9ef046d.js.map +1 -0
- package/dist/server/.next/static/chunks/671a03c1fdfc08f8.js.map +1 -0
- package/dist/server/.next/static/chunks/684226c5a0f22bc1.js +3 -0
- package/dist/server/.next/static/chunks/6c6c1dcf9e7e2204.js.map +1 -0
- package/dist/server/.next/static/chunks/76692beeeb707278.css.map +1 -0
- package/dist/server/.next/static/chunks/7d7379cdf8fe9ec5.js +3 -0
- package/dist/server/.next/static/chunks/84f5ecdc99cc0be6.js.map +1 -0
- package/dist/server/.next/static/chunks/86b5e8830b67bd88.js.map +1 -0
- package/dist/server/.next/static/chunks/8969a52917bb9c0d.js.map +1 -0
- package/dist/server/.next/static/chunks/8d6bbd36cdf03018.js +5 -0
- package/dist/server/.next/static/chunks/9af4740ebb92591d.js.map +1 -0
- package/dist/server/.next/static/chunks/a7b45611d4ad55fe.js +4 -0
- package/dist/server/.next/static/chunks/a9cba6096fe97a30.js +5 -0
- package/dist/server/.next/static/chunks/c2cc02f47cf64419.js.map +1 -0
- package/dist/server/.next/static/chunks/cf3b2abf3523d13f.js +3 -0
- package/dist/server/.next/static/chunks/cf6e515377591a1f.js +3 -0
- package/dist/server/.next/static/chunks/d0ab7593ca8c77ca.js.map +1 -0
- package/dist/server/.next/static/chunks/d5028315079b40b4.js +5 -0
- package/dist/server/.next/static/chunks/da35f4984aadc7ee.css +3 -0
- package/dist/server/.next/static/chunks/ebfa652ea6e39124.js.map +1 -0
- package/dist/server/.next/static/chunks/ec548c7ce307cf6d.js +1 -0
- package/dist/server/.next/static/chunks/ecfccf4677b4777a.js +3 -0
- package/dist/server/.next/static/chunks/fc31ec097889736e.js +61 -0
- package/dist/server/.next/static/chunks/ffb74809cc596ae9.js.map +1 -0
- package/dist/server/.next/static/chunks/pages/_app.js +5 -0
- package/dist/server/.next/static/chunks/pages/_error.js +5 -0
- package/dist/server/.next/static/media/favicon.45db1c09.ico +0 -0
- package/dist/server/.next/static/qPRyAah5ijpk6JBI-hD27/_buildManifest.js +1 -0
- package/dist/server/.next/static/qPRyAah5ijpk6JBI-hD27/_clientMiddlewareManifest.json +1 -0
- package/dist/server/.next/static/qPRyAah5ijpk6JBI-hD27/_ssgManifest.js +1 -0
- package/dist/server/.next/trace +1 -4
- package/dist/server/.next/transform.js +7 -0
- package/dist/server/.next/transform.js.map +5 -0
- package/dist/server/.next/turbopack +0 -0
- package/package.json +1 -1
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
module.exports={60354:function(e){var{g:t,__dirname:r,m:n,e:o}=e;{"use strict";Object.defineProperty(o,"__esModule",{value:!0});var a={DynamicServerError:function(){return t},isDynamicServerError:function(){return c}};for(var i in a)Object.defineProperty(o,i,{enumerable:!0,get:a[i]});let e="DYNAMIC_SERVER_USAGE";class t extends Error{constructor(t){super("Dynamic server usage: "+t),this.description=t,this.digest=e}}function c(t){return"object"==typeof t&&null!==t&&"digest"in t&&"string"==typeof t.digest&&t.digest===e}("function"==typeof o.default||"object"==typeof o.default&&null!==o.default)&&void 0===o.default.__esModule&&(Object.defineProperty(o.default,"__esModule",{value:!0}),Object.assign(o.default,o),n.exports=o.default)}},61855:function(e){var{g:t,__dirname:r,m:n,e:o}=e;{"use strict";Object.defineProperty(o,"__esModule",{value:!0});var a={StaticGenBailoutError:function(){return t},isStaticGenBailoutError:function(){return c}};for(var i in a)Object.defineProperty(o,i,{enumerable:!0,get:a[i]});let e="NEXT_STATIC_GEN_BAILOUT";class t extends Error{constructor(...t){super(...t),this.code=e}}function c(t){return"object"==typeof t&&null!==t&&"code"in t&&t.code===e}("function"==typeof o.default||"object"==typeof o.default&&null!==o.default)&&void 0===o.default.__esModule&&(Object.defineProperty(o.default,"__esModule",{value:!0}),Object.assign(o.default,o),n.exports=o.default)}},69869:function(e){var{g:t,__dirname:r,m:n,e:o}=e;{"use strict";Object.defineProperty(o,"__esModule",{value:!0});var a={isHangingPromiseRejectionError:function(){return c},makeHangingPromise:function(){return s}};for(var i in a)Object.defineProperty(o,i,{enumerable:!0,get:a[i]});function c(t){return"object"==typeof t&&null!==t&&"digest"in t&&t.digest===e}let e="HANGING_PROMISE_REJECTION";class t extends Error{constructor(t){super(`During prerendering, ${t} rejects when the prerender is complete. Typically these errors are handled by React but if you move ${t} to a different context by using \`setTimeout\`, \`after\`, or similar functions you may observe this error and you should handle it in that context.`),this.expression=t,this.digest=e}}let r=new WeakMap;function s(e,n){if(e.aborted)return Promise.reject(new t(n));{let o=new Promise((o,a)=>{let i=a.bind(null,new t(n)),c=r.get(e);if(c)c.push(i);else{let t=[i];r.set(e,t),e.addEventListener("abort",()=>{for(let e=0;e<t.length;e++)t[e]()},{once:!0})}});return o.catch(u),o}}function u(){}}},87900:function(e){var{g:t,__dirname:r,m:n,e:o}=e;{"use strict";Object.defineProperty(o,"__esModule",{value:!0});var a={METADATA_BOUNDARY_NAME:function(){return e},OUTLET_BOUNDARY_NAME:function(){return r},VIEWPORT_BOUNDARY_NAME:function(){return t}};for(var i in a)Object.defineProperty(o,i,{enumerable:!0,get:a[i]});let e="__next_metadata_boundary__",t="__next_viewport_boundary__",r="__next_outlet_boundary__"}},65200:function(e){var{g:t,__dirname:r,m:n,e:o}=e;{"use strict";Object.defineProperty(o,"__esModule",{value:!0});var a={atLeastOneTask:function(){return c},scheduleImmediate:function(){return t},scheduleOnNextTick:function(){return e},waitAtLeastOneReactRenderTask:function(){return s}};for(var i in a)Object.defineProperty(o,i,{enumerable:!0,get:a[i]});let e=e=>{Promise.resolve().then(()=>{process.nextTick(e)})},t=e=>{setImmediate(e)};function c(){return new Promise(e=>t(e))}function s(){return new Promise(e=>setImmediate(e))}}},55766:function(e){var{g:t,__dirname:r,m:n,e:o}=e;{"use strict";Object.defineProperty(o,"__esModule",{value:!0});var a,i={Postpone:function(){return E},abortAndThrowOnSynchronousRequestDataAccess:function(){return b},abortOnSynchronousPlatformIOAccess:function(){return h},accessedDynamicData:function(){return S},annotateDynamicAccess:function(){return x},consumeDynamicAccess:function(){return k},createDynamicTrackingState:function(){return s},createDynamicValidationState:function(){return u},createHangingInputAbortSignal:function(){return j},createPostponedAbortSignal:function(){return T},formatDynamicAPIAccesses:function(){return A},getFirstDynamicReason:function(){return d},isDynamicPostpone:function(){return R},isPrerenderInterruptedError:function(){return w},markCurrentScopeAsDynamic:function(){return l},postponeWithTracking:function(){return _},throwIfDisallowedDynamic:function(){return M},throwToInterruptStaticGeneration:function(){return y},trackAllowedDynamicAccess:function(){return I},trackDynamicDataInDynamicRender:function(){return p},trackFallbackParamAccessed:function(){return f},trackSynchronousPlatformIOAccessInDev:function(){return g},trackSynchronousRequestDataAccessInDev:function(){return X},useDynamicRouteParams:function(){return N}};for(var c in i)Object.defineProperty(o,c,{enumerable:!0,get:i[c]});let t=(a=e.r(94507))&&a.__esModule?a:{default:a},r=e.r(60354),n=e.r(61855),$=e.r(83943),U=e.r(86103),C=e.r(69869),B=e.r(87900),W=e.r(65200),G="function"==typeof t.default.unstable_postpone;function s(e){return{isDebugDynamicAccesses:e,dynamicAccesses:[],syncDynamicExpression:void 0,syncDynamicErrorWithStack:null}}function u(){return{hasSuspendedDynamic:!1,hasDynamicMetadata:!1,hasDynamicViewport:!1,hasSyncDynamicErrors:!1,dynamicErrors:[]}}function d(e){var t;return null==(t=e.dynamicAccesses[0])?void 0:t.expression}function l(e,t,o){if((!t||"cache"!==t.type&&"unstable-cache"!==t.type)&&!e.forceDynamic&&!e.forceStatic){if(e.dynamicShouldError)throw Object.defineProperty(new n.StaticGenBailoutError(`Route ${e.route} with \`dynamic = "error"\` couldn't be rendered statically because it used \`${o}\`. See more info here: https://nextjs.org/docs/app/building-your-application/rendering/static-and-dynamic#dynamic-rendering`),"__NEXT_ERROR_CODE",{value:"E553",enumerable:!1,configurable:!0});if(t){if("prerender-ppr"===t.type)_(e.route,o,t.dynamicTracking);else if("prerender-legacy"===t.type){t.revalidate=0;let n=Object.defineProperty(new r.DynamicServerError(`Route ${e.route} couldn't be rendered statically because it used ${o}. See more info here: https://nextjs.org/docs/messages/dynamic-server-error`),"__NEXT_ERROR_CODE",{value:"E550",enumerable:!1,configurable:!0});throw e.dynamicUsageDescription=o,e.dynamicUsageStack=n.stack,n}}}}function f(e,t){let r=$.workUnitAsyncStorage.getStore();r&&"prerender-ppr"===r.type&&_(e.route,t,r.dynamicTracking)}function y(e,t,n){let o=Object.defineProperty(new r.DynamicServerError(`Route ${t.route} couldn't be rendered statically because it used \`${e}\`. See more info here: https://nextjs.org/docs/messages/dynamic-server-error`),"__NEXT_ERROR_CODE",{value:"E558",enumerable:!1,configurable:!0});throw n.revalidate=0,t.dynamicUsageDescription=e,t.dynamicUsageStack=o.stack,o}function p(e,t){t&&"cache"!==t.type&&"unstable-cache"!==t.type&&("prerender"===t.type||"prerender-legacy"===t.type)&&(t.revalidate=0)}function m(e,t,r){let n=O(`Route ${e} needs to bail out of prerendering at this point because it used ${t}.`);r.controller.abort(n);let o=r.dynamicTracking;o&&o.dynamicAccesses.push({stack:o.isDebugDynamicAccesses?Error().stack:void 0,expression:t})}function h(e,t,r,n){let o=n.dynamicTracking;o&&null===o.syncDynamicErrorWithStack&&(o.syncDynamicExpression=t,o.syncDynamicErrorWithStack=r),m(e,t,n)}function g(e){e.prerenderPhase=!1}function b(e,t,r,n){if(!1===n.controller.signal.aborted){let o=n.dynamicTracking;o&&null===o.syncDynamicErrorWithStack&&(o.syncDynamicExpression=t,o.syncDynamicErrorWithStack=r,!0===n.validating&&(o.syncDynamicLogged=!0)),m(e,t,n)}throw O(`Route ${e} needs to bail out of prerendering at this point because it used ${t}.`)}let X=g;function E({reason:e,route:t}){let r=$.workUnitAsyncStorage.getStore();_(t,e,r&&"prerender-ppr"===r.type?r.dynamicTracking:null)}function _(e,r,n){P(),n&&n.dynamicAccesses.push({stack:n.isDebugDynamicAccesses?Error().stack:void 0,expression:r}),t.default.unstable_postpone(D(e,r))}function D(e,t){return`Route ${e} needs to bail out of prerendering at this point because it used ${t}. React throws this special object to indicate where. It should not be caught by your own try/catch. Learn more: https://nextjs.org/docs/messages/ppr-caught-error`}function R(e){return"object"==typeof e&&null!==e&&"string"==typeof e.message&&v(e.message)}function v(e){return e.includes("needs to bail out of prerendering at this point because it used")&&e.includes("Learn more: https://nextjs.org/docs/messages/ppr-caught-error")}if(!1===v(D("%%%","^^^")))throw Object.defineProperty(Error("Invariant: isDynamicPostpone misidentified a postpone reason. This is a bug in Next.js"),"__NEXT_ERROR_CODE",{value:"E296",enumerable:!1,configurable:!0});let L="NEXT_PRERENDER_INTERRUPTED";function O(e){let t=Object.defineProperty(Error(e),"__NEXT_ERROR_CODE",{value:"E394",enumerable:!1,configurable:!0});return t.digest=L,t}function w(e){return"object"==typeof e&&null!==e&&e.digest===L&&"name"in e&&"message"in e&&e instanceof Error}function S(e){return e.length>0}function k(e,t){return e.dynamicAccesses.push(...t.dynamicAccesses),e.dynamicAccesses}function A(e){return e.filter(e=>"string"==typeof e.stack&&e.stack.length>0).map(({expression:e,stack:t})=>(t=t.split("\n").slice(4).filter(e=>!(e.includes("node_modules/next/")||e.includes(" (<anonymous>)")||e.includes(" (node:"))).join("\n"),`Dynamic API Usage Debug - ${e}:
|
|
2
|
+
${t}`))}function P(){if(!G)throw Object.defineProperty(Error("Invariant: React.unstable_postpone is not defined. This suggests the wrong version of React was loaded. This is a bug in Next.js"),"__NEXT_ERROR_CODE",{value:"E224",enumerable:!1,configurable:!0})}function T(e){P();let r=new AbortController;try{t.default.unstable_postpone(e)}catch(e){r.abort(e)}return r.signal}function j(e){let t=new AbortController;return e.cacheSignal?e.cacheSignal.inputReady().then(()=>{t.abort()}):(0,W.scheduleOnNextTick)(()=>t.abort()),t.signal}function x(e,t){let r=t.dynamicTracking;r&&r.dynamicAccesses.push({stack:r.isDebugDynamicAccesses?Error().stack:void 0,expression:e})}function N(e){let r=U.workAsyncStorage.getStore();if(r&&r.isStaticGeneration&&r.fallbackRouteParams&&r.fallbackRouteParams.size>0){let n=$.workUnitAsyncStorage.getStore();n&&("prerender"===n.type?t.default.use((0,C.makeHangingPromise)(n.renderSignal,e)):"prerender-ppr"===n.type?_(r.route,e,n.dynamicTracking):"prerender-legacy"===n.type&&y(e,r,n))}}let V=/\n\s+at Suspense \(<anonymous>\)/,Y=RegExp(`\\n\\s+at ${B.METADATA_BOUNDARY_NAME}[\\n\\s]`),q=RegExp(`\\n\\s+at ${B.VIEWPORT_BOUNDARY_NAME}[\\n\\s]`),H=RegExp(`\\n\\s+at ${B.OUTLET_BOUNDARY_NAME}[\\n\\s]`);function I(e,t,r,n,o){if(!H.test(t)){if(Y.test(t)){r.hasDynamicMetadata=!0;return}if(q.test(t)){r.hasDynamicViewport=!0;return}if(V.test(t)){r.hasSuspendedDynamic=!0;return}else if(n.syncDynamicErrorWithStack||o.syncDynamicErrorWithStack){r.hasSyncDynamicErrors=!0;return}else{let n=function(e,t){let r=Object.defineProperty(Error(e),"__NEXT_ERROR_CODE",{value:"E394",enumerable:!1,configurable:!0});return r.stack="Error: "+e+t,r}(`Route "${e}": A component accessed data, headers, params, searchParams, or a short-lived cache without a Suspense boundary nor a "use cache" above it. We don't have the exact line number added to error messages yet but you can see which component in the stack below. See more info: https://nextjs.org/docs/messages/next-prerender-missing-suspense`,t);r.dynamicErrors.push(n);return}}}function M(e,t,r,o){let a,i,c;if(r.syncDynamicErrorWithStack?(a=r.syncDynamicErrorWithStack,i=r.syncDynamicExpression,c=!0===r.syncDynamicLogged):o.syncDynamicErrorWithStack?(a=o.syncDynamicErrorWithStack,i=o.syncDynamicExpression,c=!0===o.syncDynamicLogged):(a=null,i=void 0,c=!1),t.hasSyncDynamicErrors&&a)throw c||console.error(a),new n.StaticGenBailoutError;let s=t.dynamicErrors;if(s.length){for(let e=0;e<s.length;e++)console.error(s[e]);throw new n.StaticGenBailoutError}if(!t.hasSuspendedDynamic){if(t.hasDynamicMetadata){if(a)throw console.error(a),Object.defineProperty(new n.StaticGenBailoutError(`Route "${e}" has a \`generateMetadata\` that could not finish rendering before ${i} was used. Follow the instructions in the error for this expression to resolve.`),"__NEXT_ERROR_CODE",{value:"E608",enumerable:!1,configurable:!0});throw Object.defineProperty(new n.StaticGenBailoutError(`Route "${e}" has a \`generateMetadata\` that depends on Request data (\`cookies()\`, etc...) or external data (\`fetch(...)\`, etc...) but the rest of the route was static or only used cached data (\`"use cache"\`). If you expected this route to be prerenderable update your \`generateMetadata\` to not use Request data and only use cached external data. Otherwise, add \`await connection()\` somewhere within this route to indicate explicitly it should not be prerendered.`),"__NEXT_ERROR_CODE",{value:"E534",enumerable:!1,configurable:!0})}else if(t.hasDynamicViewport){if(a)throw console.error(a),Object.defineProperty(new n.StaticGenBailoutError(`Route "${e}" has a \`generateViewport\` that could not finish rendering before ${i} was used. Follow the instructions in the error for this expression to resolve.`),"__NEXT_ERROR_CODE",{value:"E573",enumerable:!1,configurable:!0});throw Object.defineProperty(new n.StaticGenBailoutError(`Route "${e}" has a \`generateViewport\` that depends on Request data (\`cookies()\`, etc...) or external data (\`fetch(...)\`, etc...) but the rest of the route was static or only used cached data (\`"use cache"\`). If you expected this route to be prerenderable update your \`generateViewport\` to not use Request data and only use cached external data. Otherwise, add \`await connection()\` somewhere within this route to indicate explicitly it should not be prerendered.`),"__NEXT_ERROR_CODE",{value:"E590",enumerable:!1,configurable:!0})}}}}}};
|
|
3
|
+
|
|
4
|
+
//# sourceMappingURL=9bf22_next_dist_800492fd._.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["turbopack:///[project]/node_modules/.pnpm/next@15.3.4_react-dom@19.1.0_react@19.1.0__react@19.1.0/node_modules/next/src/client/components/hooks-server-context.ts","turbopack:///[project]/node_modules/.pnpm/next@15.3.4_react-dom@19.1.0_react@19.1.0__react@19.1.0/node_modules/next/src/client/components/static-generation-bailout.ts","turbopack:///[project]/node_modules/.pnpm/next@15.3.4_react-dom@19.1.0_react@19.1.0__react@19.1.0/node_modules/next/src/server/dynamic-rendering-utils.ts","turbopack:///[project]/node_modules/.pnpm/next@15.3.4_react-dom@19.1.0_react@19.1.0__react@19.1.0/node_modules/next/src/lib/metadata/metadata-constants.tsx","turbopack:///[project]/node_modules/.pnpm/next@15.3.4_react-dom@19.1.0_react@19.1.0__react@19.1.0/node_modules/next/src/lib/scheduler.ts","turbopack:///[project]/node_modules/.pnpm/next@15.3.4_react-dom@19.1.0_react@19.1.0__react@19.1.0/node_modules/next/src/server/app-render/dynamic-rendering.ts"],"sourcesContent":["const DYNAMIC_ERROR_CODE = 'DYNAMIC_SERVER_USAGE'\n\nexport class DynamicServerError extends Error {\n digest: typeof DYNAMIC_ERROR_CODE = DYNAMIC_ERROR_CODE\n\n constructor(public readonly description: string) {\n super(`Dynamic server usage: ${description}`)\n }\n}\n\nexport function isDynamicServerError(err: unknown): err is DynamicServerError {\n if (\n typeof err !== 'object' ||\n err === null ||\n !('digest' in err) ||\n typeof err.digest !== 'string'\n ) {\n return false\n }\n\n return err.digest === DYNAMIC_ERROR_CODE\n}\n","const NEXT_STATIC_GEN_BAILOUT = 'NEXT_STATIC_GEN_BAILOUT'\n\nexport class StaticGenBailoutError extends Error {\n public readonly code = NEXT_STATIC_GEN_BAILOUT\n}\n\nexport function isStaticGenBailoutError(\n error: unknown\n): error is StaticGenBailoutError {\n if (typeof error !== 'object' || error === null || !('code' in error)) {\n return false\n }\n\n return error.code === NEXT_STATIC_GEN_BAILOUT\n}\n","export function isHangingPromiseRejectionError(\n err: unknown\n): err is HangingPromiseRejectionError {\n if (typeof err !== 'object' || err === null || !('digest' in err)) {\n return false\n }\n\n return err.digest === HANGING_PROMISE_REJECTION\n}\n\nconst HANGING_PROMISE_REJECTION = 'HANGING_PROMISE_REJECTION'\n\nclass HangingPromiseRejectionError extends Error {\n public readonly digest = HANGING_PROMISE_REJECTION\n\n constructor(public readonly expression: string) {\n super(\n `During prerendering, ${expression} rejects when the prerender is complete. Typically these errors are handled by React but if you move ${expression} to a different context by using \\`setTimeout\\`, \\`after\\`, or similar functions you may observe this error and you should handle it in that context.`\n )\n }\n}\n\ntype AbortListeners = Array<(err: unknown) => void>\nconst abortListenersBySignal = new WeakMap<AbortSignal, AbortListeners>()\n\n/**\n * This function constructs a promise that will never resolve. This is primarily\n * useful for dynamicIO where we use promise resolution timing to determine which\n * parts of a render can be included in a prerender.\n *\n * @internal\n */\nexport function makeHangingPromise<T>(\n signal: AbortSignal,\n expression: string\n): Promise<T> {\n if (signal.aborted) {\n return Promise.reject(new HangingPromiseRejectionError(expression))\n } else {\n const hangingPromise = new Promise<T>((_, reject) => {\n const boundRejection = reject.bind(\n null,\n new HangingPromiseRejectionError(expression)\n )\n let currentListeners = abortListenersBySignal.get(signal)\n if (currentListeners) {\n currentListeners.push(boundRejection)\n } else {\n const listeners = [boundRejection]\n abortListenersBySignal.set(signal, listeners)\n signal.addEventListener(\n 'abort',\n () => {\n for (let i = 0; i < listeners.length; i++) {\n listeners[i]()\n }\n },\n { once: true }\n )\n }\n })\n // We are fine if no one actually awaits this promise. We shouldn't consider this an unhandled rejection so\n // we attach a noop catch handler here to suppress this warning. If you actually await somewhere or construct\n // your own promise out of it you'll need to ensure you handle the error when it rejects.\n hangingPromise.catch(ignoreReject)\n return hangingPromise\n }\n}\n\nfunction ignoreReject() {}\n","export const METADATA_BOUNDARY_NAME = '__next_metadata_boundary__'\nexport const VIEWPORT_BOUNDARY_NAME = '__next_viewport_boundary__'\nexport const OUTLET_BOUNDARY_NAME = '__next_outlet_boundary__'\n","export type ScheduledFn<T = void> = () => T | PromiseLike<T>\nexport type SchedulerFn<T = void> = (cb: ScheduledFn<T>) => void\n\n/**\n * Schedules a function to be called on the next tick after the other promises\n * have been resolved.\n *\n * @param cb the function to schedule\n */\nexport const scheduleOnNextTick = <T = void>(cb: ScheduledFn<T>): void => {\n // We use Promise.resolve().then() here so that the operation is scheduled at\n // the end of the promise job queue, we then add it to the next process tick\n // to ensure it's evaluated afterwards.\n //\n // This was inspired by the implementation of the DataLoader interface: https://github.com/graphql/dataloader/blob/d336bd15282664e0be4b4a657cb796f09bafbc6b/src/index.js#L213-L255\n //\n Promise.resolve().then(() => {\n if (process.env.NEXT_RUNTIME === 'edge') {\n setTimeout(cb, 0)\n } else {\n process.nextTick(cb)\n }\n })\n}\n\n/**\n * Schedules a function to be called using `setImmediate` or `setTimeout` if\n * `setImmediate` is not available (like in the Edge runtime).\n *\n * @param cb the function to schedule\n */\nexport const scheduleImmediate = <T = void>(cb: ScheduledFn<T>): void => {\n if (process.env.NEXT_RUNTIME === 'edge') {\n setTimeout(cb, 0)\n } else {\n setImmediate(cb)\n }\n}\n\n/**\n * returns a promise than resolves in a future task. There is no guarantee that the task it resolves in\n * will be the next task but if you await it you can at least be sure that the current task is over and\n * most usefully that the entire microtask queue of the current task has been emptied.\n */\nexport function atLeastOneTask() {\n return new Promise<void>((resolve) => scheduleImmediate(resolve))\n}\n\n/**\n * This utility function is extracted to make it easier to find places where we are doing\n * specific timing tricks to try to schedule work after React has rendered. This is especially\n * important at the moment because Next.js uses the edge builds of React which use setTimeout to\n * schedule work when you might expect that something like setImmediate would do the trick.\n *\n * Long term we should switch to the node versions of React rendering when possible and then\n * update this to use setImmediate rather than setTimeout\n */\nexport function waitAtLeastOneReactRenderTask(): Promise<void> {\n if (process.env.NEXT_RUNTIME === 'edge') {\n return new Promise((r) => setTimeout(r, 0))\n } else {\n return new Promise((r) => setImmediate(r))\n }\n}\n","/**\n * The functions provided by this module are used to communicate certain properties\n * about the currently running code so that Next.js can make decisions on how to handle\n * the current execution in different rendering modes such as pre-rendering, resuming, and SSR.\n *\n * Today Next.js treats all code as potentially static. Certain APIs may only make sense when dynamically rendering.\n * Traditionally this meant deopting the entire render to dynamic however with PPR we can now deopt parts\n * of a React tree as dynamic while still keeping other parts static. There are really two different kinds of\n * Dynamic indications.\n *\n * The first is simply an intention to be dynamic. unstable_noStore is an example of this where\n * the currently executing code simply declares that the current scope is dynamic but if you use it\n * inside unstable_cache it can still be cached. This type of indication can be removed if we ever\n * make the default dynamic to begin with because the only way you would ever be static is inside\n * a cache scope which this indication does not affect.\n *\n * The second is an indication that a dynamic data source was read. This is a stronger form of dynamic\n * because it means that it is inappropriate to cache this at all. using a dynamic data source inside\n * unstable_cache should error. If you want to use some dynamic data inside unstable_cache you should\n * read that data outside the cache and pass it in as an argument to the cached function.\n */\n\nimport type { WorkStore } from '../app-render/work-async-storage.external'\nimport type {\n WorkUnitStore,\n RequestStore,\n PrerenderStoreLegacy,\n PrerenderStoreModern,\n} from '../app-render/work-unit-async-storage.external'\n\n// Once postpone is in stable we should switch to importing the postpone export directly\nimport React from 'react'\n\nimport { DynamicServerError } from '../../client/components/hooks-server-context'\nimport { StaticGenBailoutError } from '../../client/components/static-generation-bailout'\nimport { workUnitAsyncStorage } from './work-unit-async-storage.external'\nimport { workAsyncStorage } from '../app-render/work-async-storage.external'\nimport { makeHangingPromise } from '../dynamic-rendering-utils'\nimport {\n METADATA_BOUNDARY_NAME,\n VIEWPORT_BOUNDARY_NAME,\n OUTLET_BOUNDARY_NAME,\n} from '../../lib/metadata/metadata-constants'\nimport { scheduleOnNextTick } from '../../lib/scheduler'\n\nconst hasPostpone = typeof React.unstable_postpone === 'function'\n\nexport type DynamicAccess = {\n /**\n * If debugging, this will contain the stack trace of where the dynamic access\n * occurred. This is used to provide more information to the user about why\n * their page is being rendered dynamically.\n */\n stack?: string\n\n /**\n * The expression that was accessed dynamically.\n */\n expression: string\n}\n\n// Stores dynamic reasons used during an RSC render.\nexport type DynamicTrackingState = {\n /**\n * When true, stack information will also be tracked during dynamic access.\n */\n readonly isDebugDynamicAccesses: boolean | undefined\n\n /**\n * The dynamic accesses that occurred during the render.\n */\n readonly dynamicAccesses: Array<DynamicAccess>\n\n syncDynamicExpression: undefined | string\n syncDynamicErrorWithStack: null | Error\n // Dev only\n syncDynamicLogged?: boolean\n}\n\n// Stores dynamic reasons used during an SSR render.\nexport type DynamicValidationState = {\n hasSuspendedDynamic: boolean\n hasDynamicMetadata: boolean\n hasDynamicViewport: boolean\n hasSyncDynamicErrors: boolean\n dynamicErrors: Array<Error>\n}\n\nexport function createDynamicTrackingState(\n isDebugDynamicAccesses: boolean | undefined\n): DynamicTrackingState {\n return {\n isDebugDynamicAccesses,\n dynamicAccesses: [],\n syncDynamicExpression: undefined,\n syncDynamicErrorWithStack: null,\n }\n}\n\nexport function createDynamicValidationState(): DynamicValidationState {\n return {\n hasSuspendedDynamic: false,\n hasDynamicMetadata: false,\n hasDynamicViewport: false,\n hasSyncDynamicErrors: false,\n dynamicErrors: [],\n }\n}\n\nexport function getFirstDynamicReason(\n trackingState: DynamicTrackingState\n): undefined | string {\n return trackingState.dynamicAccesses[0]?.expression\n}\n\n/**\n * This function communicates that the current scope should be treated as dynamic.\n *\n * In most cases this function is a no-op but if called during\n * a PPR prerender it will postpone the current sub-tree and calling\n * it during a normal prerender will cause the entire prerender to abort\n */\nexport function markCurrentScopeAsDynamic(\n store: WorkStore,\n workUnitStore: undefined | Exclude<WorkUnitStore, PrerenderStoreModern>,\n expression: string\n): void {\n if (workUnitStore) {\n if (\n workUnitStore.type === 'cache' ||\n workUnitStore.type === 'unstable-cache'\n ) {\n // inside cache scopes marking a scope as dynamic has no effect because the outer cache scope\n // creates a cache boundary. This is subtly different from reading a dynamic data source which is\n // forbidden inside a cache scope.\n return\n }\n }\n\n // If we're forcing dynamic rendering or we're forcing static rendering, we\n // don't need to do anything here because the entire page is already dynamic\n // or it's static and it should not throw or postpone here.\n if (store.forceDynamic || store.forceStatic) return\n\n if (store.dynamicShouldError) {\n throw new StaticGenBailoutError(\n `Route ${store.route} with \\`dynamic = \"error\"\\` couldn't be rendered statically because it used \\`${expression}\\`. See more info here: https://nextjs.org/docs/app/building-your-application/rendering/static-and-dynamic#dynamic-rendering`\n )\n }\n\n if (workUnitStore) {\n if (workUnitStore.type === 'prerender-ppr') {\n postponeWithTracking(\n store.route,\n expression,\n workUnitStore.dynamicTracking\n )\n } else if (workUnitStore.type === 'prerender-legacy') {\n workUnitStore.revalidate = 0\n\n // We aren't prerendering but we are generating a static page. We need to bail out of static generation\n const err = new DynamicServerError(\n `Route ${store.route} couldn't be rendered statically because it used ${expression}. See more info here: https://nextjs.org/docs/messages/dynamic-server-error`\n )\n store.dynamicUsageDescription = expression\n store.dynamicUsageStack = err.stack\n\n throw err\n } else if (\n process.env.NODE_ENV === 'development' &&\n workUnitStore &&\n workUnitStore.type === 'request'\n ) {\n workUnitStore.usedDynamic = true\n }\n }\n}\n\n/**\n * This function communicates that some dynamic path parameter was read. This\n * differs from the more general `trackDynamicDataAccessed` in that it is will\n * not error when `dynamic = \"error\"` is set.\n *\n * @param store The static generation store\n * @param expression The expression that was accessed dynamically\n */\nexport function trackFallbackParamAccessed(\n store: WorkStore,\n expression: string\n): void {\n const prerenderStore = workUnitAsyncStorage.getStore()\n if (!prerenderStore || prerenderStore.type !== 'prerender-ppr') return\n\n postponeWithTracking(store.route, expression, prerenderStore.dynamicTracking)\n}\n\n/**\n * This function is meant to be used when prerendering without dynamicIO or PPR.\n * When called during a build it will cause Next.js to consider the route as dynamic.\n *\n * @internal\n */\nexport function throwToInterruptStaticGeneration(\n expression: string,\n store: WorkStore,\n prerenderStore: PrerenderStoreLegacy\n): never {\n // We aren't prerendering but we are generating a static page. We need to bail out of static generation\n const err = new DynamicServerError(\n `Route ${store.route} couldn't be rendered statically because it used \\`${expression}\\`. See more info here: https://nextjs.org/docs/messages/dynamic-server-error`\n )\n\n prerenderStore.revalidate = 0\n\n store.dynamicUsageDescription = expression\n store.dynamicUsageStack = err.stack\n\n throw err\n}\n\n/**\n * This function should be used to track whether something dynamic happened even when\n * we are in a dynamic render. This is useful for Dev where all renders are dynamic but\n * we still track whether dynamic APIs were accessed for helpful messaging\n *\n * @internal\n */\nexport function trackDynamicDataInDynamicRender(\n _store: WorkStore,\n workUnitStore: void | WorkUnitStore\n) {\n if (workUnitStore) {\n if (\n workUnitStore.type === 'cache' ||\n workUnitStore.type === 'unstable-cache'\n ) {\n // inside cache scopes marking a scope as dynamic has no effect because the outer cache scope\n // creates a cache boundary. This is subtly different from reading a dynamic data source which is\n // forbidden inside a cache scope.\n return\n }\n if (\n workUnitStore.type === 'prerender' ||\n workUnitStore.type === 'prerender-legacy'\n ) {\n workUnitStore.revalidate = 0\n }\n if (\n process.env.NODE_ENV === 'development' &&\n workUnitStore.type === 'request'\n ) {\n workUnitStore.usedDynamic = true\n }\n }\n}\n\n// Despite it's name we don't actually abort unless we have a controller to call abort on\n// There are times when we let a prerender run long to discover caches where we want the semantics\n// of tracking dynamic access without terminating the prerender early\nfunction abortOnSynchronousDynamicDataAccess(\n route: string,\n expression: string,\n prerenderStore: PrerenderStoreModern\n): void {\n const reason = `Route ${route} needs to bail out of prerendering at this point because it used ${expression}.`\n\n const error = createPrerenderInterruptedError(reason)\n\n prerenderStore.controller.abort(error)\n\n const dynamicTracking = prerenderStore.dynamicTracking\n if (dynamicTracking) {\n dynamicTracking.dynamicAccesses.push({\n // When we aren't debugging, we don't need to create another error for the\n // stack trace.\n stack: dynamicTracking.isDebugDynamicAccesses\n ? new Error().stack\n : undefined,\n expression,\n })\n }\n}\n\nexport function abortOnSynchronousPlatformIOAccess(\n route: string,\n expression: string,\n errorWithStack: Error,\n prerenderStore: PrerenderStoreModern\n): void {\n const dynamicTracking = prerenderStore.dynamicTracking\n if (dynamicTracking) {\n if (dynamicTracking.syncDynamicErrorWithStack === null) {\n dynamicTracking.syncDynamicExpression = expression\n dynamicTracking.syncDynamicErrorWithStack = errorWithStack\n }\n }\n abortOnSynchronousDynamicDataAccess(route, expression, prerenderStore)\n}\n\nexport function trackSynchronousPlatformIOAccessInDev(\n requestStore: RequestStore\n): void {\n // We don't actually have a controller to abort but we do the semantic equivalent by\n // advancing the request store out of prerender mode\n requestStore.prerenderPhase = false\n}\n\n/**\n * use this function when prerendering with dynamicIO. If we are doing a\n * prospective prerender we don't actually abort because we want to discover\n * all caches for the shell. If this is the actual prerender we do abort.\n *\n * This function accepts a prerenderStore but the caller should ensure we're\n * actually running in dynamicIO mode.\n *\n * @internal\n */\nexport function abortAndThrowOnSynchronousRequestDataAccess(\n route: string,\n expression: string,\n errorWithStack: Error,\n prerenderStore: PrerenderStoreModern\n): never {\n const prerenderSignal = prerenderStore.controller.signal\n if (prerenderSignal.aborted === false) {\n // TODO it would be better to move this aborted check into the callsite so we can avoid making\n // the error object when it isn't relevant to the aborting of the prerender however\n // since we need the throw semantics regardless of whether we abort it is easier to land\n // this way. See how this was handled with `abortOnSynchronousPlatformIOAccess` for a closer\n // to ideal implementation\n const dynamicTracking = prerenderStore.dynamicTracking\n if (dynamicTracking) {\n if (dynamicTracking.syncDynamicErrorWithStack === null) {\n dynamicTracking.syncDynamicExpression = expression\n dynamicTracking.syncDynamicErrorWithStack = errorWithStack\n if (prerenderStore.validating === true) {\n // We always log Request Access in dev at the point of calling the function\n // So we mark the dynamic validation as not requiring it to be printed\n dynamicTracking.syncDynamicLogged = true\n }\n }\n }\n abortOnSynchronousDynamicDataAccess(route, expression, prerenderStore)\n }\n throw createPrerenderInterruptedError(\n `Route ${route} needs to bail out of prerendering at this point because it used ${expression}.`\n )\n}\n\n// For now these implementations are the same so we just reexport\nexport const trackSynchronousRequestDataAccessInDev =\n trackSynchronousPlatformIOAccessInDev\n\n/**\n * This component will call `React.postpone` that throws the postponed error.\n */\ntype PostponeProps = {\n reason: string\n route: string\n}\nexport function Postpone({ reason, route }: PostponeProps): never {\n const prerenderStore = workUnitAsyncStorage.getStore()\n const dynamicTracking =\n prerenderStore && prerenderStore.type === 'prerender-ppr'\n ? prerenderStore.dynamicTracking\n : null\n postponeWithTracking(route, reason, dynamicTracking)\n}\n\nexport function postponeWithTracking(\n route: string,\n expression: string,\n dynamicTracking: null | DynamicTrackingState\n): never {\n assertPostpone()\n if (dynamicTracking) {\n dynamicTracking.dynamicAccesses.push({\n // When we aren't debugging, we don't need to create another error for the\n // stack trace.\n stack: dynamicTracking.isDebugDynamicAccesses\n ? new Error().stack\n : undefined,\n expression,\n })\n }\n\n React.unstable_postpone(createPostponeReason(route, expression))\n}\n\nfunction createPostponeReason(route: string, expression: string) {\n return (\n `Route ${route} needs to bail out of prerendering at this point because it used ${expression}. ` +\n `React throws this special object to indicate where. It should not be caught by ` +\n `your own try/catch. Learn more: https://nextjs.org/docs/messages/ppr-caught-error`\n )\n}\n\nexport function isDynamicPostpone(err: unknown) {\n if (\n typeof err === 'object' &&\n err !== null &&\n typeof (err as any).message === 'string'\n ) {\n return isDynamicPostponeReason((err as any).message)\n }\n return false\n}\n\nfunction isDynamicPostponeReason(reason: string) {\n return (\n reason.includes(\n 'needs to bail out of prerendering at this point because it used'\n ) &&\n reason.includes(\n 'Learn more: https://nextjs.org/docs/messages/ppr-caught-error'\n )\n )\n}\n\nif (isDynamicPostponeReason(createPostponeReason('%%%', '^^^')) === false) {\n throw new Error(\n 'Invariant: isDynamicPostpone misidentified a postpone reason. This is a bug in Next.js'\n )\n}\n\nconst NEXT_PRERENDER_INTERRUPTED = 'NEXT_PRERENDER_INTERRUPTED'\n\nfunction createPrerenderInterruptedError(message: string): Error {\n const error = new Error(message)\n ;(error as any).digest = NEXT_PRERENDER_INTERRUPTED\n return error\n}\n\ntype DigestError = Error & {\n digest: string\n}\n\nexport function isPrerenderInterruptedError(\n error: unknown\n): error is DigestError {\n return (\n typeof error === 'object' &&\n error !== null &&\n (error as any).digest === NEXT_PRERENDER_INTERRUPTED &&\n 'name' in error &&\n 'message' in error &&\n error instanceof Error\n )\n}\n\nexport function accessedDynamicData(\n dynamicAccesses: Array<DynamicAccess>\n): boolean {\n return dynamicAccesses.length > 0\n}\n\nexport function consumeDynamicAccess(\n serverDynamic: DynamicTrackingState,\n clientDynamic: DynamicTrackingState\n): DynamicTrackingState['dynamicAccesses'] {\n // We mutate because we only call this once we are no longer writing\n // to the dynamicTrackingState and it's more efficient than creating a new\n // array.\n serverDynamic.dynamicAccesses.push(...clientDynamic.dynamicAccesses)\n return serverDynamic.dynamicAccesses\n}\n\nexport function formatDynamicAPIAccesses(\n dynamicAccesses: Array<DynamicAccess>\n): string[] {\n return dynamicAccesses\n .filter(\n (access): access is Required<DynamicAccess> =>\n typeof access.stack === 'string' && access.stack.length > 0\n )\n .map(({ expression, stack }) => {\n stack = stack\n .split('\\n')\n // Remove the \"Error: \" prefix from the first line of the stack trace as\n // well as the first 4 lines of the stack trace which is the distance\n // from the user code and the `new Error().stack` call.\n .slice(4)\n .filter((line) => {\n // Exclude Next.js internals from the stack trace.\n if (line.includes('node_modules/next/')) {\n return false\n }\n\n // Exclude anonymous functions from the stack trace.\n if (line.includes(' (<anonymous>)')) {\n return false\n }\n\n // Exclude Node.js internals from the stack trace.\n if (line.includes(' (node:')) {\n return false\n }\n\n return true\n })\n .join('\\n')\n return `Dynamic API Usage Debug - ${expression}:\\n${stack}`\n })\n}\n\nfunction assertPostpone() {\n if (!hasPostpone) {\n throw new Error(\n `Invariant: React.unstable_postpone is not defined. This suggests the wrong version of React was loaded. This is a bug in Next.js`\n )\n }\n}\n\n/**\n * This is a bit of a hack to allow us to abort a render using a Postpone instance instead of an Error which changes React's\n * abort semantics slightly.\n */\nexport function createPostponedAbortSignal(reason: string): AbortSignal {\n assertPostpone()\n const controller = new AbortController()\n // We get our hands on a postpone instance by calling postpone and catching the throw\n try {\n React.unstable_postpone(reason)\n } catch (x: unknown) {\n controller.abort(x)\n }\n return controller.signal\n}\n\n/**\n * In a prerender, we may end up with hanging Promises as inputs due them\n * stalling on connection() or because they're loading dynamic data. In that\n * case we need to abort the encoding of arguments since they'll never complete.\n */\nexport function createHangingInputAbortSignal(\n workUnitStore: PrerenderStoreModern\n): AbortSignal {\n const controller = new AbortController()\n\n if (workUnitStore.cacheSignal) {\n // If we have a cacheSignal it means we're in a prospective render. If the input\n // we're waiting on is coming from another cache, we do want to wait for it so that\n // we can resolve this cache entry too.\n workUnitStore.cacheSignal.inputReady().then(() => {\n controller.abort()\n })\n } else {\n // Otherwise we're in the final render and we should already have all our caches\n // filled. We might still be waiting on some microtasks so we wait one tick before\n // giving up. When we give up, we still want to render the content of this cache\n // as deeply as we can so that we can suspend as deeply as possible in the tree\n // or not at all if we don't end up waiting for the input.\n scheduleOnNextTick(() => controller.abort())\n }\n\n return controller.signal\n}\n\nexport function annotateDynamicAccess(\n expression: string,\n prerenderStore: PrerenderStoreModern\n) {\n const dynamicTracking = prerenderStore.dynamicTracking\n if (dynamicTracking) {\n dynamicTracking.dynamicAccesses.push({\n stack: dynamicTracking.isDebugDynamicAccesses\n ? new Error().stack\n : undefined,\n expression,\n })\n }\n}\n\nexport function useDynamicRouteParams(expression: string) {\n const workStore = workAsyncStorage.getStore()\n\n if (\n workStore &&\n workStore.isStaticGeneration &&\n workStore.fallbackRouteParams &&\n workStore.fallbackRouteParams.size > 0\n ) {\n // There are fallback route params, we should track these as dynamic\n // accesses.\n const workUnitStore = workUnitAsyncStorage.getStore()\n if (workUnitStore) {\n // We're prerendering with dynamicIO or PPR or both\n if (workUnitStore.type === 'prerender') {\n // We are in a prerender with dynamicIO semantics\n // We are going to hang here and never resolve. This will cause the currently\n // rendering component to effectively be a dynamic hole\n React.use(makeHangingPromise(workUnitStore.renderSignal, expression))\n } else if (workUnitStore.type === 'prerender-ppr') {\n // We're prerendering with PPR\n postponeWithTracking(\n workStore.route,\n expression,\n workUnitStore.dynamicTracking\n )\n } else if (workUnitStore.type === 'prerender-legacy') {\n throwToInterruptStaticGeneration(expression, workStore, workUnitStore)\n }\n }\n }\n}\n\nconst hasSuspenseRegex = /\\n\\s+at Suspense \\(<anonymous>\\)/\nconst hasMetadataRegex = new RegExp(\n `\\\\n\\\\s+at ${METADATA_BOUNDARY_NAME}[\\\\n\\\\s]`\n)\nconst hasViewportRegex = new RegExp(\n `\\\\n\\\\s+at ${VIEWPORT_BOUNDARY_NAME}[\\\\n\\\\s]`\n)\nconst hasOutletRegex = new RegExp(`\\\\n\\\\s+at ${OUTLET_BOUNDARY_NAME}[\\\\n\\\\s]`)\n\nexport function trackAllowedDynamicAccess(\n route: string,\n componentStack: string,\n dynamicValidation: DynamicValidationState,\n serverDynamic: DynamicTrackingState,\n clientDynamic: DynamicTrackingState\n) {\n if (hasOutletRegex.test(componentStack)) {\n // We don't need to track that this is dynamic. It is only so when something else is also dynamic.\n return\n } else if (hasMetadataRegex.test(componentStack)) {\n dynamicValidation.hasDynamicMetadata = true\n return\n } else if (hasViewportRegex.test(componentStack)) {\n dynamicValidation.hasDynamicViewport = true\n return\n } else if (hasSuspenseRegex.test(componentStack)) {\n dynamicValidation.hasSuspendedDynamic = true\n return\n } else if (\n serverDynamic.syncDynamicErrorWithStack ||\n clientDynamic.syncDynamicErrorWithStack\n ) {\n dynamicValidation.hasSyncDynamicErrors = true\n return\n } else {\n const message = `Route \"${route}\": A component accessed data, headers, params, searchParams, or a short-lived cache without a Suspense boundary nor a \"use cache\" above it. We don't have the exact line number added to error messages yet but you can see which component in the stack below. See more info: https://nextjs.org/docs/messages/next-prerender-missing-suspense`\n const error = createErrorWithComponentStack(message, componentStack)\n dynamicValidation.dynamicErrors.push(error)\n return\n }\n}\n\nfunction createErrorWithComponentStack(\n message: string,\n componentStack: string\n) {\n const error = new Error(message)\n error.stack = 'Error: ' + message + componentStack\n return error\n}\n\nexport function throwIfDisallowedDynamic(\n route: string,\n dynamicValidation: DynamicValidationState,\n serverDynamic: DynamicTrackingState,\n clientDynamic: DynamicTrackingState\n): void {\n let syncError: null | Error\n let syncExpression: undefined | string\n let syncLogged: boolean\n if (serverDynamic.syncDynamicErrorWithStack) {\n syncError = serverDynamic.syncDynamicErrorWithStack\n syncExpression = serverDynamic.syncDynamicExpression!\n syncLogged = serverDynamic.syncDynamicLogged === true\n } else if (clientDynamic.syncDynamicErrorWithStack) {\n syncError = clientDynamic.syncDynamicErrorWithStack\n syncExpression = clientDynamic.syncDynamicExpression!\n syncLogged = clientDynamic.syncDynamicLogged === true\n } else {\n syncError = null\n syncExpression = undefined\n syncLogged = false\n }\n\n if (dynamicValidation.hasSyncDynamicErrors && syncError) {\n if (!syncLogged) {\n // In dev we already log errors about sync dynamic access. But during builds we need to ensure\n // the offending sync error is logged before we exit the build\n console.error(syncError)\n }\n // The actual error should have been logged when the sync access ocurred\n throw new StaticGenBailoutError()\n }\n\n const dynamicErrors = dynamicValidation.dynamicErrors\n if (dynamicErrors.length) {\n for (let i = 0; i < dynamicErrors.length; i++) {\n console.error(dynamicErrors[i])\n }\n\n throw new StaticGenBailoutError()\n }\n\n if (!dynamicValidation.hasSuspendedDynamic) {\n if (dynamicValidation.hasDynamicMetadata) {\n if (syncError) {\n console.error(syncError)\n throw new StaticGenBailoutError(\n `Route \"${route}\" has a \\`generateMetadata\\` that could not finish rendering before ${syncExpression} was used. Follow the instructions in the error for this expression to resolve.`\n )\n }\n throw new StaticGenBailoutError(\n `Route \"${route}\" has a \\`generateMetadata\\` that depends on Request data (\\`cookies()\\`, etc...) or external data (\\`fetch(...)\\`, etc...) but the rest of the route was static or only used cached data (\\`\"use cache\"\\`). If you expected this route to be prerenderable update your \\`generateMetadata\\` to not use Request data and only use cached external data. Otherwise, add \\`await connection()\\` somewhere within this route to indicate explicitly it should not be prerendered.`\n )\n } else if (dynamicValidation.hasDynamicViewport) {\n if (syncError) {\n console.error(syncError)\n throw new StaticGenBailoutError(\n `Route \"${route}\" has a \\`generateViewport\\` that could not finish rendering before ${syncExpression} was used. Follow the instructions in the error for this expression to resolve.`\n )\n }\n throw new StaticGenBailoutError(\n `Route \"${route}\" has a \\`generateViewport\\` that depends on Request data (\\`cookies()\\`, etc...) or external data (\\`fetch(...)\\`, etc...) but the rest of the route was static or only used cached data (\\`\"use cache\"\\`). If you expected this route to be prerenderable update your \\`generateViewport\\` to not use Request data and only use cached external data. Otherwise, add \\`await connection()\\` somewhere within this route to indicate explicitly it should not be prerendered.`\n )\n }\n }\n}\n"],"names":["DynamicServerError","isDynamicServerError","DYNAMIC_ERROR_CODE","Error","constructor","description","digest","err","StaticGenBailoutError","isStaticGenBailoutError","NEXT_STATIC_GEN_BAILOUT","code","error","isHangingPromiseRejectionError","makeHangingPromise","HANGING_PROMISE_REJECTION","HangingPromiseRejectionError","expression","abortListenersBySignal","WeakMap","signal","aborted","Promise","reject","hangingPromise","_","boundRejection","bind","currentListeners","get","push","listeners","set","addEventListener","i","length","once","catch","ignoreReject","METADATA_BOUNDARY_NAME","OUTLET_BOUNDARY_NAME","VIEWPORT_BOUNDARY_NAME","atLeastOneTask","scheduleImmediate","scheduleOnNextTick","waitAtLeastOneReactRenderTask","cb","resolve","then","process","env","NEXT_RUNTIME","nextTick","setImmediate","r","Postpone","abortAndThrowOnSynchronousRequestDataAccess","abortOnSynchronousPlatformIOAccess","accessedDynamicData","annotateDynamicAccess","consumeDynamicAccess","createDynamicTrackingState","createDynamicValidationState","createHangingInputAbortSignal","createPostponedAbortSignal","formatDynamicAPIAccesses","getFirstDynamicReason","isDynamicPostpone","isPrerenderInterruptedError","markCurrentScopeAsDynamic","postponeWithTracking","throwIfDisallowedDynamic","throwToInterruptStaticGeneration","trackAllowedDynamicAccess","trackDynamicDataInDynamicRender","trackFallbackParamAccessed","trackSynchronousPlatformIOAccessInDev","trackSynchronousRequestDataAccessInDev","useDynamicRouteParams","hasPostpone","React","unstable_postpone","isDebugDynamicAccesses","dynamicAccesses","syncDynamicExpression","undefined","syncDynamicErrorWithStack","hasSuspendedDynamic","hasDynamicMetadata","hasDynamicViewport","hasSyncDynamicErrors","dynamicErrors","trackingState","store","workUnitStore","type","forceDynamic","forceStatic","dynamicShouldError","route","dynamicTracking","revalidate","dynamicUsageDescription","dynamicUsageStack","stack","NODE_ENV","prerenderStore","workUnitAsyncStorage","getStore","_store","abortOnSynchronousDynamicDataAccess","reason","createPrerenderInterruptedError","controller","abort","errorWithStack","requestStore","prerenderPhase","prerenderSignal","validating","syncDynamicLogged","assertPostpone","createPostponeReason","message","isDynamicPostponeReason","includes","NEXT_PRERENDER_INTERRUPTED","serverDynamic","clientDynamic","filter","access","map","split","slice","line","join","AbortController","x","cacheSignal","inputReady","workStore","workAsyncStorage","isStaticGeneration","fallbackRouteParams","size","use","renderSignal","hasSuspenseRegex","hasMetadataRegex","RegExp","hasViewportRegex","hasOutletRegex","componentStack","dynamicValidation","test","createErrorWithComponentStack","syncError","syncExpression","syncLogged","console"],"mappings":"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","ignoreList":[0,1,2,3,4,5]}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
module.exports={83886:function(e){var{g:t,__dirname:s,m:r,e:o}=e;r.exports=e.x("fs",()=>require("fs"))},45935:function(e){var{g:t,__dirname:s,m:r,e:o}=e;r.exports=e.x("next/dist/server/app-render/after-task-async-storage.external.js",()=>require("next/dist/server/app-render/after-task-async-storage.external.js"))},35692:e=>{"use strict";var{g:t,__dirname:s}=e;e.s({ProjectStatus:()=>a,getProjectsConfig:()=>i,saveProjectsConfig:()=>n});var r=e.i(9892),o=e.i(88941);async function i(){try{await (0,r.access)(o.PROJECT_CONFIG_PATH,r.constants.F_OK)}catch{return await n({}),{}}try{let e=await (0,r.readFile)(o.PROJECT_CONFIG_PATH,"utf-8");if(!e)return{};return JSON.parse(e)}catch(e){throw console.error("读取或解析项目配置文件失败:",e),Error("无法加载项目配置")}}async function n(e){let t=o.PROJECT_CONFIG_PATH+".tmp";try{await (0,r.writeFile)(t,JSON.stringify(e,null,2),"utf-8"),await (0,r.rename)(t,o.PROJECT_CONFIG_PATH)}catch(e){throw console.error("保存项目配置文件失败:",e),Error("无法保存项目配置")}}var a=function(e){return e.PENDING="pending",e.EXISTING="existing",e.CLONING="cloning",e.SUCCESS="success",e.FAILED="failed",e.RETRYING="retrying",e}({})},88941:e=>{"use strict";var{g:t,__dirname:s}=e;{e.s({PROJECT_CONFIG_PATH:()=>s,ProjectStatus:()=>i,WORKSPACE_CONFIG:()=>t});var r=e.i(13442),o=e.i(30331);let t={WORKSPACE_ROOT:(0,o.join)((0,r.homedir)(),"Documents","prime-workspace"),GIT_TIMEOUT:3e5,MAX_CONCURRENT_CLONES:Math.max(2,Math.min((0,r.cpus)().length,8)),MAX_RETRY_ATTEMPTS:3},s=(0,o.join)((0,r.homedir)(),".prime-projects.json");var i=function(e){return e.PENDING="pending",e.EXISTING="existing",e.CLONING="cloning",e.SUCCESS="success",e.FAILED="failed",e.RETRYING="retrying",e.INCOMPLETE="incomplete",e}({})}},29549:function(e){var{g:t,__dirname:s,m:r,e:o}=e;r.exports=e.x("next/dist/compiled/next-server/app-page-turbo.runtime.prod.js",()=>require("next/dist/compiled/next-server/app-page-turbo.runtime.prod.js"))},83943:function(e){var{g:t,__dirname:s,m:r,e:o}=e;r.exports=e.x("next/dist/server/app-render/work-unit-async-storage.external.js",()=>require("next/dist/server/app-render/work-unit-async-storage.external.js"))},86103:function(e){var{g:t,__dirname:s,m:r,e:o}=e;r.exports=e.x("next/dist/server/app-render/work-async-storage.external.js",()=>require("next/dist/server/app-render/work-async-storage.external.js"))},30331:function(e){var{g:t,__dirname:s,m:r,e:o}=e;r.exports=e.x("path",()=>require("path"))},23430:function(e){var{g:t,__dirname:s,m:r,e:o}=e;r.exports=e.x("next/dist/compiled/@opentelemetry/api",()=>require("next/dist/compiled/@opentelemetry/api"))},13442:function(e){var{g:t,__dirname:s,m:r,e:o}=e;r.exports=e.x("os",()=>require("os"))},52670:function(e){var{g:t,__dirname:s,m:r,e:o}=e;r.exports=e.x("next/dist/compiled/next-server/app-route-turbo.runtime.prod.js",()=>require("next/dist/compiled/next-server/app-route-turbo.runtime.prod.js"))},9892:function(e){var{g:t,__dirname:s,m:r,e:o}=e;r.exports=e.x("fs/promises",()=>require("fs/promises"))},15650:function(e){var{g:t,__dirname:s,m:r,e:o}=e;r.exports=e.x("module",()=>require("module"))},99577:function(e){var{g:t,__dirname:s,m:r,e:o}=e},99664:e=>{"use strict";var{g:t,__dirname:s}=e;{e.s({DELETE:()=>p,GET:()=>u,POST:()=>c});var r=e.i(15494),o=e.i(83886),i=e.i(30331),n=e.i(35692),a=e.i(88941);let t=(0,e.i(15650).createRequire)({get url(){return`file://${e.P("packages/server/src/app/api/mock-file/route.ts")}`}}.url);async function c(e){try{let{projectName:t,apiName:s,method:c,siteName:u,content:p}=await e.json();if(!t||!s||!c||!u||void 0===p)return r.NextResponse.json({success:!1,error:"缺少必要参数:projectName, apiName, method, siteName, content"},{status:400});if(!(await (0,n.getProjectsConfig)())[t])return r.NextResponse.json({success:!1,error:`项目 ${t} 不存在`},{status:404});let l=(0,i.join)(a.WORKSPACE_CONFIG.WORKSPACE_ROOT,t),m=(0,i.join)(l,".mock"),d=(0,i.join)(m,s),g=(0,i.join)(d,c.toLowerCase()),j=(0,i.join)(g,`${u}.js`);try{await o.promises.access(l)}catch{return r.NextResponse.json({success:!1,error:`项目目录 ${t} 不存在`},{status:404})}try{await o.promises.access(m)}catch{await o.promises.mkdir(m,{recursive:!0})}try{await o.promises.access(d)}catch{await o.promises.mkdir(d,{recursive:!0})}try{await o.promises.access(g)}catch{await o.promises.mkdir(g,{recursive:!0})}let f=(0,i.join)(g,"setting.js"),x=!1;try{await o.promises.access(f),console.log(`setting.js文件已存在: ${f}`)}catch{let e=`module.exports = {
|
|
2
|
+
// 当前场景名称
|
|
3
|
+
currentSite: '${u}',
|
|
4
|
+
// 开启Mock的场景列表
|
|
5
|
+
open: ['${u}']
|
|
6
|
+
};`;await o.promises.writeFile(f,e,"utf-8"),x=!0,console.log(`setting.js文件创建成功: ${f}`)}return await o.promises.writeFile(j,p,"utf-8"),r.NextResponse.json({success:!0,message:"Mock文件创建成功",data:{projectName:t,apiName:s,method:c.toLowerCase(),siteName:u,filePath:(0,i.join)(".mock",s,c.toLowerCase(),`${u}.js`),settingCreated:x,createdAt:new Date().toISOString()}})}catch(t){let e=t instanceof Error?t.message:"创建Mock文件失败";return console.error("创建Mock文件失败:",t),r.NextResponse.json({success:!1,error:e},{status:500})}}async function u(e){try{let{searchParams:s}=new URL(e.url),c=s.get("project");if(!c)return r.NextResponse.json({success:!1,error:"项目名称参数缺失"},{status:400});if(!(await (0,n.getProjectsConfig)())[c])return r.NextResponse.json({success:!1,error:`项目 ${c} 不存在`},{status:404});let u=(0,i.join)(a.WORKSPACE_CONFIG.WORKSPACE_ROOT,c),p=(0,i.join)(u,".mock");try{await o.promises.access(p)}catch{return r.NextResponse.json({success:!0,data:{projectName:c,mockFiles:[]},message:"Mock目录不存在,返回空列表"})}let l=[];for(let e of(await o.promises.readdir(p,{withFileTypes:!0})))if(e.isDirectory()){let s=(0,i.join)(p,e.name),r=await o.promises.readdir(s,{withFileTypes:!0}),n=[];for(let a of r)if(a.isDirectory()){let r,c=(0,i.join)(s,a.name),u=await o.promises.readdir(c,{withFileTypes:!0}),p=(0,i.join)(c,"setting.js");try{await o.promises.access(p);let e=(0,i.resolve)(p);delete t.cache[e],r=t(e)}catch(e){console.warn(`读取setting.js失败: ${p}`,e)}let l=u.filter(e=>e.isFile()&&e.name.endsWith(".js")&&"setting.js"!==e.name).map(t=>({siteName:t.name.replace(".js",""),fileName:t.name,filePath:(0,i.join)(".mock",e.name,a.name,t.name)}));l.length>0&&n.push({method:a.name,setting:r,files:l})}n.length>0&&l.push({apiName:e.name,methods:n})}return r.NextResponse.json({success:!0,data:{projectName:c,mockFiles:l},message:"获取Mock文件列表成功"})}catch(t){let e=t instanceof Error?t.message:"获取Mock文件列表失败";return console.error("获取Mock文件列表失败:",t),r.NextResponse.json({success:!1,error:e},{status:500})}}async function p(e){try{let{searchParams:s}=new URL(e.url),c=s.get("project"),u=s.get("apiName"),p=s.get("method"),l=s.get("siteName");if(!c||!u||!p||!l)return r.NextResponse.json({success:!1,error:"缺少必要参数:project, apiName, method, siteName"},{status:400});if(!(await (0,n.getProjectsConfig)())[c])return r.NextResponse.json({success:!1,error:`项目 ${c} 不存在`},{status:404});let m=(0,i.join)(a.WORKSPACE_CONFIG.WORKSPACE_ROOT,c),d=(0,i.join)(m,".mock",u,p.toLowerCase()),g=(0,i.join)(d,`${l}.js`);try{await o.promises.access(g)}catch{return r.NextResponse.json({success:!1,error:"Mock文件不存在"},{status:404})}try{if((await o.promises.readdir(d)).filter(e=>e.endsWith(".js")&&"setting.js"!==e).length<=1)return r.NextResponse.json({success:!1,error:"不能删除最后一个场景,每个接口至少需要保留一个场景"},{status:400})}catch(e){return console.error("检查场景文件失败:",e),r.NextResponse.json({success:!1,error:"检查场景文件失败"},{status:500})}await o.promises.unlink(g);let j=(0,i.join)(d,"setting.js");try{await o.promises.access(j);let e=(0,i.resolve)(j);delete t.cache[e];let s=t(e);if(s.currentSite===l){let e=(await o.promises.readdir(d)).filter(e=>e.endsWith(".js")&&"setting.js"!==e);if(e.length>0){let t=e[0].replace(".js",""),r=s.open.filter(e=>e!==l),i=`module.exports = {
|
|
7
|
+
// 当前场景名称
|
|
8
|
+
currentSite: '${t}',
|
|
9
|
+
// 开启Mock的场景列表
|
|
10
|
+
open: ${JSON.stringify(r)}
|
|
11
|
+
};`;await o.promises.writeFile(j,i,"utf-8")}}else{let e=s.open.filter(e=>e!==l),t=`module.exports = {
|
|
12
|
+
// 当前场景名称
|
|
13
|
+
currentSite: '${s.currentSite}',
|
|
14
|
+
// 开启Mock的场景列表
|
|
15
|
+
open: ${JSON.stringify(e)}
|
|
16
|
+
};`;await o.promises.writeFile(j,t,"utf-8")}}catch(e){console.warn("更新setting.js失败:",e)}return r.NextResponse.json({success:!0,message:"Mock场景删除成功",data:{projectName:c,apiName:u,method:p.toLowerCase(),siteName:l,deletedFile:(0,i.join)(".mock",u,p.toLowerCase(),`${l}.js`)}})}catch(t){let e=t instanceof Error?t.message:"删除Mock文件失败";return console.error("删除Mock文件失败:",t),r.NextResponse.json({success:!1,error:e},{status:500})}}}},35699:e=>{"use strict";var{g:t,__dirname:s}=e;{e.s({patchFetch:()=>a,routeModule:()=>t,serverHooks:()=>u,workAsyncStorage:()=>s,workUnitAsyncStorage:()=>c});var r=e.i(45746),o=e.i(93828),i=e.i(18250),n=e.i(99664);let t=new r.AppRouteRouteModule({definition:{kind:o.RouteKind.APP_ROUTE,page:"/api/mock-file/route",pathname:"/api/mock-file",filename:"route",bundlePath:""},resolvedPagePath:"[project]/packages/server/src/app/api/mock-file/route.ts",nextConfigOutput:"",userland:n}),{workAsyncStorage:s,workUnitAsyncStorage:c,serverHooks:u}=t;function a(){return(0,i.patchFetch)({workAsyncStorage:s,workUnitAsyncStorage:c})}}}};
|
|
17
|
+
|
|
18
|
+
//# sourceMappingURL=%5Broot-of-the-server%5D__0111ac14._.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["turbopack:///[project]/packages/server/src/lib/workspace-config.ts","turbopack:///[project]/packages/server/src/lib/workspace-types.ts","turbopack:///[project]/packages/server/src/app/api/mock-file/route.ts","turbopack:///[project]/node_modules/.pnpm/next@15.3.4_react-dom@19.1.0_react@19.1.0__react@19.1.0/node_modules/next/dist/src/build/templates/app-route.ts"],"sourcesContent":["import { readFile, writeFile, access, constants, rename } from 'fs/promises';\nimport type { ProjectsConfig } from './workspace-types';\nimport { PROJECT_CONFIG_PATH } from './workspace-types';\n\n/**\n * 读取并解析项目配置文件\n * @returns {Promise<ProjectsConfig>} 项目配置对象\n */\nexport async function getProjectsConfig(): Promise<ProjectsConfig> {\n try {\n await access(PROJECT_CONFIG_PATH, constants.F_OK);\n } catch {\n // 文件不存在,创建并写入空对象\n await saveProjectsConfig({});\n return {};\n }\n\n try {\n const configContent = await readFile(PROJECT_CONFIG_PATH, 'utf-8');\n // 如果文件为空,返回空对象\n if (!configContent) {\n return {};\n }\n return JSON.parse(configContent);\n } catch (error) {\n console.error('读取或解析项目配置文件失败:', error);\n // 在出错时返回空对象或抛出错误,这里选择抛出以通知调用者\n throw new Error('无法加载项目配置');\n }\n}\n\n/**\n * 将项目配置写入文件(原子操作)\n * @param {ProjectsConfig} config - 要保存的配置对象\n */\nexport async function saveProjectsConfig(config: ProjectsConfig): Promise<void> {\n const tempConfigPath = PROJECT_CONFIG_PATH + '.tmp';\n try {\n await writeFile(tempConfigPath, JSON.stringify(config, null, 2), 'utf-8');\n await rename(tempConfigPath, PROJECT_CONFIG_PATH);\n } catch (error) {\n console.error('保存项目配置文件失败:', error);\n throw new Error('无法保存项目配置');\n }\n}\n\n/**\n * 项目状态枚举\n */\nexport enum ProjectStatus {\n PENDING = 'pending',\n EXISTING = 'existing',\n CLONING = 'cloning',\n SUCCESS = 'success',\n FAILED = 'failed',\n RETRYING = 'retrying',\n}\n\n/**\n * 项目进度信息接口\n */\nexport interface ProjectProgress {\n projectName: string;\n status: ProjectStatus;\n progress: number; // 0-100\n message: string;\n error?: string;\n startTime?: number;\n endTime?: number;\n}\n\n/**\n * 初始化结果接口\n */\nexport interface InitializationResult {\n success: boolean;\n totalProjects: number;\n successCount: number;\n failedCount: number;\n failedProjects: string[];\n workspacePath: string;\n duration: number;\n}\n\n/**\n * Git 操作配置接口\n */\nexport interface GitOperationConfig {\n repoUrl: string;\n targetDir: string;\n timeout: number;\n onProgress?: (progress: number, message: string) => void;\n onError?: (error: string) => void;\n}","import { homedir, cpus } from 'os';\nimport { join } from 'path';\n\n/**\n * 工作空间配置常量\n */\nexport const WORKSPACE_CONFIG = {\n // 工作空间根目录路径\n WORKSPACE_ROOT: join(homedir(), 'Documents', 'prime-workspace'),\n\n // Git 操作超时时间 (毫秒)\n GIT_TIMEOUT: 300000, // 5分钟\n\n // 最大并发克隆数量(基于CPU核心数,最小2个,最大8个)\n MAX_CONCURRENT_CLONES: Math.max(2, Math.min(cpus().length, 8)),\n\n // 重试次数限制\n MAX_RETRY_ATTEMPTS: 3,\n} as const;\n\nexport const PROJECT_CONFIG_PATH = join(homedir(), '.prime-projects.json');\n\nexport interface ProjectConfig {\n repo: string;\n mockingIntercept?: boolean;\n mockOpen?: boolean;\n envs: {\n [envName: string]: {\n host: string;\n currentProxy: string;\n proxyEnv: {\n [key: string]: string;\n };\n envFileName: string;\n proxyKey: string;\n subApps?: string[];\n };\n };\n}\n\nexport interface ProjectsConfig {\n [projectName: string]: ProjectConfig;\n}\n\n/**\n * 项目状态枚举\n */\nexport enum ProjectStatus {\n PENDING = 'pending',\n EXISTING = 'existing',\n CLONING = 'cloning',\n SUCCESS = 'success',\n FAILED = 'failed',\n RETRYING = 'retrying',\n INCOMPLETE = 'incomplete', // 不完整的项目,需要清理\n}\n\n/**\n * 项目进度信息接口\n */\nexport interface ProjectProgress {\n projectName: string;\n status: ProjectStatus;\n progress: number; // 0-100\n message: string;\n error?: string;\n startTime?: number;\n endTime?: number;\n}\n\n/**\n * 初始化结果接口\n */\nexport interface InitializationResult {\n success: boolean;\n totalProjects: number;\n successCount: number;\n failedCount: number;\n failedProjects: string[];\n workspacePath: string;\n duration: number;\n}\n\n/**\n * Git 操作配置接口\n */\nexport interface GitOperationConfig {\n repoUrl: string;\n targetDir: string;\n timeout: number;\n onProgress?: (progress: number, message: string) => void;\n onError?: (error: string) => void;\n onLog?: (projectName: string, logType: 'stdout' | 'stderr' | 'progress', content: string) => void;\n} ","import { NextRequest, NextResponse } from 'next/server';\nimport { promises as fs } from 'fs';\nimport { join, resolve } from 'path';\nimport { getProjectsConfig } from '@/lib/workspace-config';\nimport { WORKSPACE_CONFIG } from '@/lib/workspace-types';\nimport { createRequire } from \"module\";\nconst require = createRequire(import.meta.url);\n\nexport async function POST(request: NextRequest) {\n try {\n // 解析请求体\n const { projectName, apiName, method, siteName, content } = await request.json();\n\n // 参数验证\n if (!projectName || !apiName || !method || !siteName || content === undefined) {\n return NextResponse.json(\n {\n success: false,\n error: '缺少必要参数:projectName, apiName, method, siteName, content',\n },\n { status: 400 },\n );\n }\n\n // 验证项目是否存在\n const projectsConfig = await getProjectsConfig();\n if (!projectsConfig[projectName]) {\n return NextResponse.json(\n { success: false, error: `项目 ${projectName} 不存在` },\n { status: 404 },\n );\n }\n\n // 构建文件路径\n const projectPath = join(WORKSPACE_CONFIG.WORKSPACE_ROOT, projectName);\n const mockPath = join(projectPath, '.mock');\n const apiPath = join(mockPath, apiName);\n const methodPath = join(apiPath, method.toLowerCase());\n const filePath = join(methodPath, `${siteName}.js`);\n\n // 检查项目目录是否存在\n try {\n await fs.access(projectPath);\n } catch {\n return NextResponse.json(\n { success: false, error: `项目目录 ${projectName} 不存在` },\n { status: 404 },\n );\n }\n\n // 确保 .mock 目录存在\n try {\n await fs.access(mockPath);\n } catch {\n await fs.mkdir(mockPath, { recursive: true });\n }\n\n // 确保 API 目录存在\n try {\n await fs.access(apiPath);\n } catch {\n await fs.mkdir(apiPath, { recursive: true });\n }\n\n // 确保 Method 目录存在\n try {\n await fs.access(methodPath);\n } catch {\n await fs.mkdir(methodPath, { recursive: true });\n }\n\n // 如果setting.js不存在,则创建setting.js\n const settingFilePath = join(methodPath, 'setting.js');\n let settingCreated = false;\n try {\n await fs.access(settingFilePath);\n console.log(`setting.js文件已存在: ${settingFilePath}`);\n } catch {\n // setting.js不存在,创建它\n const settingContent = `module.exports = {\n // 当前场景名称\n currentSite: '${siteName}',\n // 开启Mock的场景列表\n open: ['${siteName}']\n};`;\n await fs.writeFile(settingFilePath, settingContent, 'utf-8');\n settingCreated = true;\n console.log(`setting.js文件创建成功: ${settingFilePath}`);\n }\n\n // 写入文件内容\n await fs.writeFile(filePath, content, 'utf-8');\n\n return NextResponse.json({\n success: true,\n message: 'Mock文件创建成功',\n data: {\n projectName,\n apiName,\n method: method.toLowerCase(),\n siteName,\n filePath: join('.mock', apiName, method.toLowerCase(), `${siteName}.js`),\n settingCreated,\n createdAt: new Date().toISOString(),\n },\n });\n } catch (error) {\n const errorMessage = error instanceof Error ? error.message : '创建Mock文件失败';\n console.error('创建Mock文件失败:', error);\n return NextResponse.json(\n { success: false, error: errorMessage },\n { status: 500 },\n );\n }\n}\n\nexport async function GET(request: NextRequest) {\n try {\n const { searchParams } = new URL(request.url);\n const projectName = searchParams.get('project');\n\n if (!projectName) {\n return NextResponse.json(\n { success: false, error: '项目名称参数缺失' },\n { status: 400 },\n );\n }\n\n // 验证项目是否存在\n const projectsConfig = await getProjectsConfig();\n if (!projectsConfig[projectName]) {\n return NextResponse.json(\n { success: false, error: `项目 ${projectName} 不存在` },\n { status: 404 },\n );\n }\n\n // 构建路径\n const projectPath = join(WORKSPACE_CONFIG.WORKSPACE_ROOT, projectName);\n const mockPath = join(projectPath, '.mock');\n\n // 检查 .mock 目录是否存在\n try {\n await fs.access(mockPath);\n } catch {\n return NextResponse.json({\n success: true,\n data: {\n projectName,\n mockFiles: [],\n },\n message: 'Mock目录不存在,返回空列表',\n });\n }\n\n // 读取 .mock 目录结构\n const mockFiles: Array<{\n apiName: string;\n methods: Array<{\n method: string;\n setting?: {\n currentSite?: string;\n [key: string]: unknown;\n };\n files: Array<{\n siteName: string;\n fileName: string;\n filePath: string;\n }>;\n }>;\n }> = [];\n\n const apiDirs = await fs.readdir(mockPath, { withFileTypes: true });\n \n for (const apiDir of apiDirs) {\n if (apiDir.isDirectory()) {\n const apiPath = join(mockPath, apiDir.name);\n const methodDirs = await fs.readdir(apiPath, { withFileTypes: true });\n \n const apiMethods: Array<{\n method: string;\n setting?: {\n currentSite?: string;\n [key: string]: unknown;\n };\n files: Array<{\n siteName: string;\n fileName: string;\n filePath: string;\n }>;\n }> = [];\n\n for (const methodDir of methodDirs) {\n if (methodDir.isDirectory()) {\n const methodPath = join(apiPath, methodDir.name);\n const files = await fs.readdir(methodPath, { withFileTypes: true });\n \n // 读取setting.js文件内容\n let setting: { currentSite?: string; [key: string]: unknown } | undefined;\n const settingFilePath = join(methodPath, 'setting.js');\n try {\n await fs.access(settingFilePath);\n // 使用require直接导入setting.js\n const resolvedPath = resolve(settingFilePath);\n delete require.cache[resolvedPath];\n setting = require(resolvedPath);\n } catch (error) {\n // setting.js文件不存在或读取失败,忽略\n console.warn(`读取setting.js失败: ${settingFilePath}`, error);\n }\n \n const methodFiles = files\n .filter(file => file.isFile() && file.name.endsWith('.js') && file.name !== 'setting.js')\n .map(file => ({\n siteName: file.name.replace('.js', ''),\n fileName: file.name,\n filePath: join('.mock', apiDir.name, methodDir.name, file.name),\n }));\n\n if (methodFiles.length > 0) {\n apiMethods.push({\n method: methodDir.name,\n setting,\n files: methodFiles,\n });\n }\n }\n }\n\n if (apiMethods.length > 0) {\n mockFiles.push({\n apiName: apiDir.name,\n methods: apiMethods,\n });\n }\n }\n }\n\n return NextResponse.json({\n success: true,\n data: {\n projectName,\n mockFiles,\n },\n message: '获取Mock文件列表成功',\n });\n } catch (error) {\n const errorMessage = error instanceof Error ? error.message : '获取Mock文件列表失败';\n console.error('获取Mock文件列表失败:', error);\n return NextResponse.json(\n { success: false, error: errorMessage },\n { status: 500 },\n );\n }\n}\n\nexport async function DELETE(request: NextRequest) {\n try {\n const { searchParams } = new URL(request.url);\n const projectName = searchParams.get('project');\n const apiName = searchParams.get('apiName');\n const method = searchParams.get('method');\n const siteName = searchParams.get('siteName');\n\n if (!projectName || !apiName || !method || !siteName) {\n return NextResponse.json(\n { success: false, error: '缺少必要参数:project, apiName, method, siteName' },\n { status: 400 },\n );\n }\n\n // 验证项目是否存在\n const projectsConfig = await getProjectsConfig();\n if (!projectsConfig[projectName]) {\n return NextResponse.json(\n { success: false, error: `项目 ${projectName} 不存在` },\n { status: 404 },\n );\n }\n\n // 构建文件路径\n const projectPath = join(WORKSPACE_CONFIG.WORKSPACE_ROOT, projectName);\n const methodPath = join(projectPath, '.mock', apiName, method.toLowerCase());\n const filePath = join(methodPath, `${siteName}.js`);\n\n // 检查文件是否存在\n try {\n await fs.access(filePath);\n } catch {\n return NextResponse.json(\n { success: false, error: 'Mock文件不存在' },\n { status: 404 },\n );\n }\n\n // 检查是否为该接口的最后一个场景,如果是则不允许删除\n try {\n const methodFiles = await fs.readdir(methodPath);\n // 过滤出.js文件(排除setting.js)\n const scenarioFiles = methodFiles.filter(file => file.endsWith('.js') && file !== 'setting.js');\n \n if (scenarioFiles.length <= 1) {\n return NextResponse.json(\n { success: false, error: '不能删除最后一个场景,每个接口至少需要保留一个场景' },\n { status: 400 },\n );\n }\n } catch (error) {\n console.error('检查场景文件失败:', error);\n return NextResponse.json(\n { success: false, error: '检查场景文件失败' },\n { status: 500 },\n );\n }\n\n // 删除文件\n await fs.unlink(filePath);\n\n // 检查是否需要更新setting.js中的currentSite\n const settingFilePath = join(methodPath, 'setting.js');\n try {\n await fs.access(settingFilePath);\n // 读取当前设置\n const resolvedPath = resolve(settingFilePath);\n delete require.cache[resolvedPath];\n const currentSetting = require(resolvedPath);\n \n // 如果删除的是当前选中的场景,需要切换到其他场景\n if (currentSetting.currentSite === siteName) {\n const remainingFiles = await fs.readdir(methodPath);\n const remainingScenarios = remainingFiles.filter(file => file.endsWith('.js') && file !== 'setting.js');\n \n if (remainingScenarios.length > 0) {\n // 选择第一个剩余的场景作为新的当前场景\n const newCurrentSite = remainingScenarios[0].replace('.js', '');\n const newOpen = currentSetting.open.filter((site: string) => site !== siteName);\n \n const newSettingContent = `module.exports = {\n // 当前场景名称\n currentSite: '${newCurrentSite}',\n // 开启Mock的场景列表\n open: ${JSON.stringify(newOpen)}\n};`;\n \n await fs.writeFile(settingFilePath, newSettingContent, 'utf-8');\n }\n } else {\n // 如果删除的不是当前场景,只需要从open列表中移除\n const newOpen = currentSetting.open.filter((site: string) => site !== siteName);\n \n const newSettingContent = `module.exports = {\n // 当前场景名称\n currentSite: '${currentSetting.currentSite}',\n // 开启Mock的场景列表\n open: ${JSON.stringify(newOpen)}\n};`;\n \n await fs.writeFile(settingFilePath, newSettingContent, 'utf-8');\n }\n } catch (error) {\n console.warn('更新setting.js失败:', error);\n // 不阻止删除操作,只是警告\n }\n\n return NextResponse.json({\n success: true,\n message: 'Mock场景删除成功',\n data: {\n projectName,\n apiName,\n method: method.toLowerCase(),\n siteName,\n deletedFile: join('.mock', apiName, method.toLowerCase(), `${siteName}.js`),\n },\n });\n } catch (error) {\n const errorMessage = error instanceof Error ? error.message : '删除Mock文件失败';\n console.error('删除Mock文件失败:', error);\n return NextResponse.json(\n { success: false, error: errorMessage },\n { status: 500 },\n );\n }\n} ","import {\n AppRouteRouteModule,\n type AppRouteRouteModuleOptions,\n} from '../../server/route-modules/app-route/module.compiled'\nimport { RouteKind } from '../../server/route-kind'\nimport { patchFetch as _patchFetch } from '../../server/lib/patch-fetch'\n\nimport * as userland from 'VAR_USERLAND'\n\n// These are injected by the loader afterwards. This is injected as a variable\n// instead of a replacement because this could also be `undefined` instead of\n// an empty string.\ndeclare const nextConfigOutput: AppRouteRouteModuleOptions['nextConfigOutput']\n\n// We inject the nextConfigOutput here so that we can use them in the route\n// module.\n// INJECT:nextConfigOutput\n\nconst routeModule = new AppRouteRouteModule({\n definition: {\n kind: RouteKind.APP_ROUTE,\n page: 'VAR_DEFINITION_PAGE',\n pathname: 'VAR_DEFINITION_PATHNAME',\n filename: 'VAR_DEFINITION_FILENAME',\n bundlePath: 'VAR_DEFINITION_BUNDLE_PATH',\n },\n resolvedPagePath: 'VAR_RESOLVED_PAGE_PATH',\n nextConfigOutput,\n userland,\n})\n\n// Pull out the exports that we need to expose from the module. This should\n// be eliminated when we've moved the other routes to the new format. These\n// are used to hook into the route.\nconst { workAsyncStorage, workUnitAsyncStorage, serverHooks } = routeModule\n\nfunction patchFetch() {\n return _patchFetch({\n workAsyncStorage,\n workUnitAsyncStorage,\n })\n}\n\nexport {\n routeModule,\n workAsyncStorage,\n workUnitAsyncStorage,\n serverHooks,\n patchFetch,\n}\n"],"names":["AppRouteRouteModule","RouteKind","patchFetch","_patchFetch","userland","routeModule","definition","kind","APP_ROUTE","page","pathname","filename","bundlePath","resolvedPagePath","nextConfigOutput","workAsyncStorage","workUnitAsyncStorage","serverHooks"],"mappings":"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","ignoreList":[3]}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
module.exports={83886:function(e){var{g:r,__dirname:t,m:s,e:n}=e;s.exports=e.x("fs",()=>require("fs"))},45935:function(e){var{g:r,__dirname:t,m:s,e:n}=e;s.exports=e.x("next/dist/server/app-render/after-task-async-storage.external.js",()=>require("next/dist/server/app-render/after-task-async-storage.external.js"))},35692:e=>{"use strict";var{g:r,__dirname:t}=e;e.s({ProjectStatus:()=>a,getProjectsConfig:()=>o,saveProjectsConfig:()=>i});var s=e.i(9892),n=e.i(88941);async function o(){try{await (0,s.access)(n.PROJECT_CONFIG_PATH,s.constants.F_OK)}catch{return await i({}),{}}try{let e=await (0,s.readFile)(n.PROJECT_CONFIG_PATH,"utf-8");if(!e)return{};return JSON.parse(e)}catch(e){throw console.error("读取或解析项目配置文件失败:",e),Error("无法加载项目配置")}}async function i(e){let r=n.PROJECT_CONFIG_PATH+".tmp";try{await (0,s.writeFile)(r,JSON.stringify(e,null,2),"utf-8"),await (0,s.rename)(r,n.PROJECT_CONFIG_PATH)}catch(e){throw console.error("保存项目配置文件失败:",e),Error("无法保存项目配置")}}var a=function(e){return e.PENDING="pending",e.EXISTING="existing",e.CLONING="cloning",e.SUCCESS="success",e.FAILED="failed",e.RETRYING="retrying",e}({})},88941:e=>{"use strict";var{g:r,__dirname:t}=e;{e.s({PROJECT_CONFIG_PATH:()=>t,ProjectStatus:()=>o,WORKSPACE_CONFIG:()=>r});var s=e.i(13442),n=e.i(30331);let r={WORKSPACE_ROOT:(0,n.join)((0,s.homedir)(),"Documents","prime-workspace"),GIT_TIMEOUT:3e5,MAX_CONCURRENT_CLONES:Math.max(2,Math.min((0,s.cpus)().length,8)),MAX_RETRY_ATTEMPTS:3},t=(0,n.join)((0,s.homedir)(),".prime-projects.json");var o=function(e){return e.PENDING="pending",e.EXISTING="existing",e.CLONING="cloning",e.SUCCESS="success",e.FAILED="failed",e.RETRYING="retrying",e.INCOMPLETE="incomplete",e}({})}},29549:function(e){var{g:r,__dirname:t,m:s,e:n}=e;s.exports=e.x("next/dist/compiled/next-server/app-page-turbo.runtime.prod.js",()=>require("next/dist/compiled/next-server/app-page-turbo.runtime.prod.js"))},83943:function(e){var{g:r,__dirname:t,m:s,e:n}=e;s.exports=e.x("next/dist/server/app-render/work-unit-async-storage.external.js",()=>require("next/dist/server/app-render/work-unit-async-storage.external.js"))},86103:function(e){var{g:r,__dirname:t,m:s,e:n}=e;s.exports=e.x("next/dist/server/app-render/work-async-storage.external.js",()=>require("next/dist/server/app-render/work-async-storage.external.js"))},30331:function(e){var{g:r,__dirname:t,m:s,e:n}=e;s.exports=e.x("path",()=>require("path"))},23430:function(e){var{g:r,__dirname:t,m:s,e:n}=e;s.exports=e.x("next/dist/compiled/@opentelemetry/api",()=>require("next/dist/compiled/@opentelemetry/api"))},13442:function(e){var{g:r,__dirname:t,m:s,e:n}=e;s.exports=e.x("os",()=>require("os"))},52670:function(e){var{g:r,__dirname:t,m:s,e:n}=e;s.exports=e.x("next/dist/compiled/next-server/app-route-turbo.runtime.prod.js",()=>require("next/dist/compiled/next-server/app-route-turbo.runtime.prod.js"))},9892:function(e){var{g:r,__dirname:t,m:s,e:n}=e;s.exports=e.x("fs/promises",()=>require("fs/promises"))},15650:function(e){var{g:r,__dirname:t,m:s,e:n}=e;s.exports=e.x("module",()=>require("module"))},94995:function(e){var{g:r,__dirname:t,m:s,e:n}=e},45640:e=>{"use strict";var{g:r,__dirname:t}=e;{e.s({POST:()=>c});var s=e.i(15494),n=e.i(83886),o=e.i(30331),i=e.i(35692),a=e.i(88941);let r=(0,e.i(15650).createRequire)({get url(){return`file://${e.P("packages/server/src/app/api/open-all-mock/route.ts")}`}}.url);async function c(e){try{let{projectName:t}=await e.json();if(!t)return s.NextResponse.json({success:!1,error:"项目名称参数缺失"},{status:400});if(!(await (0,i.getProjectsConfig)())[t])return s.NextResponse.json({success:!1,error:`项目 ${t} 不存在`},{status:404});let c=(0,o.join)(a.WORKSPACE_CONFIG.WORKSPACE_ROOT,t),p=(0,o.join)(c,".mock");try{await n.promises.access(p)}catch{return s.NextResponse.json({success:!0,message:"Mock目录不存在,无需处理",data:{projectName:t,timestamp:new Date().toISOString()}})}let u=async e=>{for(let t of(await n.promises.readdir(e,{withFileTypes:!0}))){let s=(0,o.join)(e,t.name);if(t.isDirectory())await u(s);else if(t.name.endsWith(".js")&&"setting.js"!==t.name){let s=(0,o.join)(e),i=(0,o.join)(s,"setting.js"),a=t.name.replace(".js","");try{await n.promises.access(i)}catch{let e=`module.exports = {
|
|
2
|
+
// 当前场景名称
|
|
3
|
+
currentSite: '${a}',
|
|
4
|
+
// 开启Mock的场景列表
|
|
5
|
+
open: ['${a}']
|
|
6
|
+
};`;await n.promises.writeFile(i,e,"utf-8")}try{let e=(0,o.resolve)(i);delete r.cache[e];let t=r(e);Array.isArray(t.open)||(t.open=[]),t.open.includes(a)||t.open.push(a);let s=`module.exports = {
|
|
7
|
+
// 当前场景名称
|
|
8
|
+
currentSite: '${t.currentSite||a}',
|
|
9
|
+
// 开启Mock的场景列表
|
|
10
|
+
open: ${JSON.stringify(t.open)}
|
|
11
|
+
};`;await n.promises.writeFile(i,s,"utf-8")}catch(e){console.warn(`解析setting.js失败: ${i}`,e)}}}};return await u(p),s.NextResponse.json({success:!0,message:"所有Mock场景已开启",data:{projectName:t,timestamp:new Date().toISOString()}})}catch(r){let e=r instanceof Error?r.message:"开启Mock场景失败";return console.error("开启Mock场景失败:",r),s.NextResponse.json({success:!1,error:e},{status:500})}}}},40988:e=>{"use strict";var{g:r,__dirname:t}=e;{e.s({patchFetch:()=>a,routeModule:()=>r,serverHooks:()=>p,workAsyncStorage:()=>t,workUnitAsyncStorage:()=>c});var s=e.i(45746),n=e.i(93828),o=e.i(18250),i=e.i(45640);let r=new s.AppRouteRouteModule({definition:{kind:n.RouteKind.APP_ROUTE,page:"/api/open-all-mock/route",pathname:"/api/open-all-mock",filename:"route",bundlePath:""},resolvedPagePath:"[project]/packages/server/src/app/api/open-all-mock/route.ts",nextConfigOutput:"",userland:i}),{workAsyncStorage:t,workUnitAsyncStorage:c,serverHooks:p}=r;function a(){return(0,o.patchFetch)({workAsyncStorage:t,workUnitAsyncStorage:c})}}}};
|
|
12
|
+
|
|
13
|
+
//# sourceMappingURL=%5Broot-of-the-server%5D__1efea51d._.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["turbopack:///[project]/packages/server/src/lib/workspace-config.ts","turbopack:///[project]/packages/server/src/lib/workspace-types.ts","turbopack:///[project]/packages/server/src/app/api/open-all-mock/route.ts","turbopack:///[project]/node_modules/.pnpm/next@15.3.4_react-dom@19.1.0_react@19.1.0__react@19.1.0/node_modules/next/dist/src/build/templates/app-route.ts"],"sourcesContent":["import { readFile, writeFile, access, constants, rename } from 'fs/promises';\nimport type { ProjectsConfig } from './workspace-types';\nimport { PROJECT_CONFIG_PATH } from './workspace-types';\n\n/**\n * 读取并解析项目配置文件\n * @returns {Promise<ProjectsConfig>} 项目配置对象\n */\nexport async function getProjectsConfig(): Promise<ProjectsConfig> {\n try {\n await access(PROJECT_CONFIG_PATH, constants.F_OK);\n } catch {\n // 文件不存在,创建并写入空对象\n await saveProjectsConfig({});\n return {};\n }\n\n try {\n const configContent = await readFile(PROJECT_CONFIG_PATH, 'utf-8');\n // 如果文件为空,返回空对象\n if (!configContent) {\n return {};\n }\n return JSON.parse(configContent);\n } catch (error) {\n console.error('读取或解析项目配置文件失败:', error);\n // 在出错时返回空对象或抛出错误,这里选择抛出以通知调用者\n throw new Error('无法加载项目配置');\n }\n}\n\n/**\n * 将项目配置写入文件(原子操作)\n * @param {ProjectsConfig} config - 要保存的配置对象\n */\nexport async function saveProjectsConfig(config: ProjectsConfig): Promise<void> {\n const tempConfigPath = PROJECT_CONFIG_PATH + '.tmp';\n try {\n await writeFile(tempConfigPath, JSON.stringify(config, null, 2), 'utf-8');\n await rename(tempConfigPath, PROJECT_CONFIG_PATH);\n } catch (error) {\n console.error('保存项目配置文件失败:', error);\n throw new Error('无法保存项目配置');\n }\n}\n\n/**\n * 项目状态枚举\n */\nexport enum ProjectStatus {\n PENDING = 'pending',\n EXISTING = 'existing',\n CLONING = 'cloning',\n SUCCESS = 'success',\n FAILED = 'failed',\n RETRYING = 'retrying',\n}\n\n/**\n * 项目进度信息接口\n */\nexport interface ProjectProgress {\n projectName: string;\n status: ProjectStatus;\n progress: number; // 0-100\n message: string;\n error?: string;\n startTime?: number;\n endTime?: number;\n}\n\n/**\n * 初始化结果接口\n */\nexport interface InitializationResult {\n success: boolean;\n totalProjects: number;\n successCount: number;\n failedCount: number;\n failedProjects: string[];\n workspacePath: string;\n duration: number;\n}\n\n/**\n * Git 操作配置接口\n */\nexport interface GitOperationConfig {\n repoUrl: string;\n targetDir: string;\n timeout: number;\n onProgress?: (progress: number, message: string) => void;\n onError?: (error: string) => void;\n}","import { homedir, cpus } from 'os';\nimport { join } from 'path';\n\n/**\n * 工作空间配置常量\n */\nexport const WORKSPACE_CONFIG = {\n // 工作空间根目录路径\n WORKSPACE_ROOT: join(homedir(), 'Documents', 'prime-workspace'),\n\n // Git 操作超时时间 (毫秒)\n GIT_TIMEOUT: 300000, // 5分钟\n\n // 最大并发克隆数量(基于CPU核心数,最小2个,最大8个)\n MAX_CONCURRENT_CLONES: Math.max(2, Math.min(cpus().length, 8)),\n\n // 重试次数限制\n MAX_RETRY_ATTEMPTS: 3,\n} as const;\n\nexport const PROJECT_CONFIG_PATH = join(homedir(), '.prime-projects.json');\n\nexport interface ProjectConfig {\n repo: string;\n mockingIntercept?: boolean;\n mockOpen?: boolean;\n envs: {\n [envName: string]: {\n host: string;\n currentProxy: string;\n proxyEnv: {\n [key: string]: string;\n };\n envFileName: string;\n proxyKey: string;\n subApps?: string[];\n };\n };\n}\n\nexport interface ProjectsConfig {\n [projectName: string]: ProjectConfig;\n}\n\n/**\n * 项目状态枚举\n */\nexport enum ProjectStatus {\n PENDING = 'pending',\n EXISTING = 'existing',\n CLONING = 'cloning',\n SUCCESS = 'success',\n FAILED = 'failed',\n RETRYING = 'retrying',\n INCOMPLETE = 'incomplete', // 不完整的项目,需要清理\n}\n\n/**\n * 项目进度信息接口\n */\nexport interface ProjectProgress {\n projectName: string;\n status: ProjectStatus;\n progress: number; // 0-100\n message: string;\n error?: string;\n startTime?: number;\n endTime?: number;\n}\n\n/**\n * 初始化结果接口\n */\nexport interface InitializationResult {\n success: boolean;\n totalProjects: number;\n successCount: number;\n failedCount: number;\n failedProjects: string[];\n workspacePath: string;\n duration: number;\n}\n\n/**\n * Git 操作配置接口\n */\nexport interface GitOperationConfig {\n repoUrl: string;\n targetDir: string;\n timeout: number;\n onProgress?: (progress: number, message: string) => void;\n onError?: (error: string) => void;\n onLog?: (projectName: string, logType: 'stdout' | 'stderr' | 'progress', content: string) => void;\n} ","import { NextRequest, NextResponse } from 'next/server';\nimport { promises as fs } from 'fs';\nimport { join, resolve } from 'path';\nimport { getProjectsConfig } from '@/lib/workspace-config';\nimport { WORKSPACE_CONFIG } from '@/lib/workspace-types';\nimport { createRequire } from \"module\";\nconst require = createRequire(import.meta.url);\n\nexport async function POST(request: NextRequest) {\n try {\n // 解析请求体\n const { projectName } = await request.json();\n\n if (!projectName) {\n return NextResponse.json(\n { success: false, error: '项目名称参数缺失' },\n { status: 400 },\n );\n }\n\n // 验证项目是否存在\n const projectsConfig = await getProjectsConfig();\n if (!projectsConfig[projectName]) {\n return NextResponse.json(\n { success: false, error: `项目 ${projectName} 不存在` },\n { status: 404 },\n );\n }\n\n // 构建 .mock 目录路径\n const projectPath = join(WORKSPACE_CONFIG.WORKSPACE_ROOT, projectName);\n const mockPath = join(projectPath, '.mock');\n\n // 检查 .mock 目录是否存在\n try {\n await fs.access(mockPath);\n } catch {\n return NextResponse.json({\n success: true,\n message: 'Mock目录不存在,无需处理',\n data: {\n projectName,\n timestamp: new Date().toISOString(),\n },\n });\n }\n\n // 递归处理所有目录\n const processDirectory = async (dirPath: string) => {\n const entries = await fs.readdir(dirPath, { withFileTypes: true });\n\n for (const entry of entries) {\n const fullPath = join(dirPath, entry.name);\n\n if (entry.isDirectory()) {\n // 递归处理子目录\n await processDirectory(fullPath);\n } else if (entry.name.endsWith('.js') && entry.name !== 'setting.js') {\n // 找到 mock 文件,确保对应的 setting.js 存在\n const methodDir = join(dirPath);\n const settingPath = join(methodDir, 'setting.js');\n const siteName = entry.name.replace('.js', '');\n\n try {\n // 检查 setting.js 是否存在\n await fs.access(settingPath);\n } catch {\n // setting.js 不存在,创建默认的 setting.js\n const settingContent = `module.exports = {\n // 当前场景名称\n currentSite: '${siteName}',\n // 开启Mock的场景列表\n open: ['${siteName}']\n};`;\n await fs.writeFile(settingPath, settingContent, 'utf-8');\n }\n\n // 使用require直接导入并更新 setting.js\n try {\n const resolvedPath = resolve(settingPath);\n delete require.cache[resolvedPath];\n \n const currentConfig = require(resolvedPath);\n\n // 确保当前场景在 open 数组中\n if (!Array.isArray(currentConfig.open)) {\n currentConfig.open = [];\n }\n if (!currentConfig.open.includes(siteName)) {\n currentConfig.open.push(siteName);\n }\n\n // 更新 setting.js 当前开启场景是单项的\n const newContent = `module.exports = {\n // 当前场景名称\n currentSite: '${currentConfig.currentSite || siteName}',\n // 开启Mock的场景列表\n open: ${JSON.stringify(currentConfig.open)}\n};`;\n await fs.writeFile(settingPath, newContent, 'utf-8');\n } catch (parseError) {\n console.warn(`解析setting.js失败: ${settingPath}`, parseError);\n }\n }\n }\n };\n\n // 开始处理\n await processDirectory(mockPath);\n\n return NextResponse.json({\n success: true,\n message: '所有Mock场景已开启',\n data: {\n projectName,\n timestamp: new Date().toISOString(),\n },\n });\n\n } catch (error) {\n const errorMessage = error instanceof Error ? error.message : '开启Mock场景失败';\n console.error('开启Mock场景失败:', error);\n return NextResponse.json(\n { success: false, error: errorMessage },\n { status: 500 },\n );\n }\n}","import {\n AppRouteRouteModule,\n type AppRouteRouteModuleOptions,\n} from '../../server/route-modules/app-route/module.compiled'\nimport { RouteKind } from '../../server/route-kind'\nimport { patchFetch as _patchFetch } from '../../server/lib/patch-fetch'\n\nimport * as userland from 'VAR_USERLAND'\n\n// These are injected by the loader afterwards. This is injected as a variable\n// instead of a replacement because this could also be `undefined` instead of\n// an empty string.\ndeclare const nextConfigOutput: AppRouteRouteModuleOptions['nextConfigOutput']\n\n// We inject the nextConfigOutput here so that we can use them in the route\n// module.\n// INJECT:nextConfigOutput\n\nconst routeModule = new AppRouteRouteModule({\n definition: {\n kind: RouteKind.APP_ROUTE,\n page: 'VAR_DEFINITION_PAGE',\n pathname: 'VAR_DEFINITION_PATHNAME',\n filename: 'VAR_DEFINITION_FILENAME',\n bundlePath: 'VAR_DEFINITION_BUNDLE_PATH',\n },\n resolvedPagePath: 'VAR_RESOLVED_PAGE_PATH',\n nextConfigOutput,\n userland,\n})\n\n// Pull out the exports that we need to expose from the module. This should\n// be eliminated when we've moved the other routes to the new format. These\n// are used to hook into the route.\nconst { workAsyncStorage, workUnitAsyncStorage, serverHooks } = routeModule\n\nfunction patchFetch() {\n return _patchFetch({\n workAsyncStorage,\n workUnitAsyncStorage,\n })\n}\n\nexport {\n routeModule,\n workAsyncStorage,\n workUnitAsyncStorage,\n serverHooks,\n patchFetch,\n}\n"],"names":["AppRouteRouteModule","RouteKind","patchFetch","_patchFetch","userland","routeModule","definition","kind","APP_ROUTE","page","pathname","filename","bundlePath","resolvedPagePath","nextConfigOutput","workAsyncStorage","workUnitAsyncStorage","serverHooks"],"mappings":"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","ignoreList":[3]}
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
module.exports={45935:function(e){var{g:r,__dirname:t,m:s,e:n}=e;s.exports=e.x("next/dist/server/app-render/after-task-async-storage.external.js",()=>require("next/dist/server/app-render/after-task-async-storage.external.js"))},29549:function(e){var{g:r,__dirname:t,m:s,e:n}=e;s.exports=e.x("next/dist/compiled/next-server/app-page-turbo.runtime.prod.js",()=>require("next/dist/compiled/next-server/app-page-turbo.runtime.prod.js"))},83943:function(e){var{g:r,__dirname:t,m:s,e:n}=e;s.exports=e.x("next/dist/server/app-render/work-unit-async-storage.external.js",()=>require("next/dist/server/app-render/work-unit-async-storage.external.js"))},86103:function(e){var{g:r,__dirname:t,m:s,e:n}=e;s.exports=e.x("next/dist/server/app-render/work-async-storage.external.js",()=>require("next/dist/server/app-render/work-async-storage.external.js"))},30331:function(e){var{g:r,__dirname:t,m:s,e:n}=e;s.exports=e.x("path",()=>require("path"))},23430:function(e){var{g:r,__dirname:t,m:s,e:n}=e;s.exports=e.x("next/dist/compiled/@opentelemetry/api",()=>require("next/dist/compiled/@opentelemetry/api"))},13442:function(e){var{g:r,__dirname:t,m:s,e:n}=e;s.exports=e.x("os",()=>require("os"))},52670:function(e){var{g:r,__dirname:t,m:s,e:n}=e;s.exports=e.x("next/dist/compiled/next-server/app-route-turbo.runtime.prod.js",()=>require("next/dist/compiled/next-server/app-route-turbo.runtime.prod.js"))},88941:e=>{"use strict";var{g:r,__dirname:t}=e;{e.s({PROJECT_CONFIG_PATH:()=>t,ProjectStatus:()=>o,WORKSPACE_CONFIG:()=>r});var s=e.i(13442),n=e.i(30331);let r={WORKSPACE_ROOT:(0,n.join)((0,s.homedir)(),"Documents","prime-workspace"),GIT_TIMEOUT:3e5,MAX_CONCURRENT_CLONES:Math.max(2,Math.min((0,s.cpus)().length,8)),MAX_RETRY_ATTEMPTS:3},t=(0,n.join)((0,s.homedir)(),".prime-projects.json");var o=function(e){return e.PENDING="pending",e.EXISTING="existing",e.CLONING="cloning",e.SUCCESS="success",e.FAILED="failed",e.RETRYING="retrying",e.INCOMPLETE="incomplete",e}({})}},83886:function(e){var{g:r,__dirname:t,m:s,e:n}=e;s.exports=e.x("fs",()=>require("fs"))},23485:function(e){var{g:r,__dirname:t,m:s,e:n}=e},11858:e=>{"use strict";var{g:r,__dirname:t}=e;e.s({POST:()=>i});var s=e.i(15494),n=e.i(83886),o=e.i(30331),a=e.i(88941);async function i(e){try{let{projectName:r}=await e.json();if(!r||"string"!=typeof r)return s.NextResponse.json({success:!1,error:"项目名称不能为空"},{status:400});let t=a.WORKSPACE_CONFIG.WORKSPACE_ROOT,i=(0,o.join)(t,r);try{await n.promises.access(i)}catch{return s.NextResponse.json({success:!1,error:"项目目录不存在"},{status:404})}try{return await n.promises.rm(i,{recursive:!0,force:!0}),console.log(`手动清理项目成功: ${i}`),s.NextResponse.json({success:!0,message:`项目 ${r} 已成功清理`})}catch(e){return console.error(`清理项目失败 ${i}:`,e),s.NextResponse.json({success:!1,error:`清理项目失败: ${e instanceof Error?e.message:String(e)}`},{status:500})}}catch(e){return console.error("清理项目请求处理失败:",e),s.NextResponse.json({success:!1,error:"服务器内部错误"},{status:500})}}},69318:e=>{"use strict";var{g:r,__dirname:t}=e;{e.s({patchFetch:()=>i,routeModule:()=>r,serverHooks:()=>c,workAsyncStorage:()=>t,workUnitAsyncStorage:()=>p});var s=e.i(45746),n=e.i(93828),o=e.i(18250),a=e.i(11858);let r=new s.AppRouteRouteModule({definition:{kind:n.RouteKind.APP_ROUTE,page:"/api/cleanup-project/route",pathname:"/api/cleanup-project",filename:"route",bundlePath:""},resolvedPagePath:"[project]/packages/server/src/app/api/cleanup-project/route.ts",nextConfigOutput:"",userland:a}),{workAsyncStorage:t,workUnitAsyncStorage:p,serverHooks:c}=r;function i(){return(0,o.patchFetch)({workAsyncStorage:t,workUnitAsyncStorage:p})}}}};
|
|
2
|
+
|
|
3
|
+
//# sourceMappingURL=%5Broot-of-the-server%5D__21616bf9._.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["turbopack:///[project]/packages/server/src/lib/workspace-types.ts","turbopack:///[project]/packages/server/src/app/api/cleanup-project/route.ts","turbopack:///[project]/node_modules/.pnpm/next@15.3.4_react-dom@19.1.0_react@19.1.0__react@19.1.0/node_modules/next/dist/src/build/templates/app-route.ts"],"sourcesContent":["import { homedir, cpus } from 'os';\nimport { join } from 'path';\n\n/**\n * 工作空间配置常量\n */\nexport const WORKSPACE_CONFIG = {\n // 工作空间根目录路径\n WORKSPACE_ROOT: join(homedir(), 'Documents', 'prime-workspace'),\n\n // Git 操作超时时间 (毫秒)\n GIT_TIMEOUT: 300000, // 5分钟\n\n // 最大并发克隆数量(基于CPU核心数,最小2个,最大8个)\n MAX_CONCURRENT_CLONES: Math.max(2, Math.min(cpus().length, 8)),\n\n // 重试次数限制\n MAX_RETRY_ATTEMPTS: 3,\n} as const;\n\nexport const PROJECT_CONFIG_PATH = join(homedir(), '.prime-projects.json');\n\nexport interface ProjectConfig {\n repo: string;\n mockingIntercept?: boolean;\n mockOpen?: boolean;\n envs: {\n [envName: string]: {\n host: string;\n currentProxy: string;\n proxyEnv: {\n [key: string]: string;\n };\n envFileName: string;\n proxyKey: string;\n subApps?: string[];\n };\n };\n}\n\nexport interface ProjectsConfig {\n [projectName: string]: ProjectConfig;\n}\n\n/**\n * 项目状态枚举\n */\nexport enum ProjectStatus {\n PENDING = 'pending',\n EXISTING = 'existing',\n CLONING = 'cloning',\n SUCCESS = 'success',\n FAILED = 'failed',\n RETRYING = 'retrying',\n INCOMPLETE = 'incomplete', // 不完整的项目,需要清理\n}\n\n/**\n * 项目进度信息接口\n */\nexport interface ProjectProgress {\n projectName: string;\n status: ProjectStatus;\n progress: number; // 0-100\n message: string;\n error?: string;\n startTime?: number;\n endTime?: number;\n}\n\n/**\n * 初始化结果接口\n */\nexport interface InitializationResult {\n success: boolean;\n totalProjects: number;\n successCount: number;\n failedCount: number;\n failedProjects: string[];\n workspacePath: string;\n duration: number;\n}\n\n/**\n * Git 操作配置接口\n */\nexport interface GitOperationConfig {\n repoUrl: string;\n targetDir: string;\n timeout: number;\n onProgress?: (progress: number, message: string) => void;\n onError?: (error: string) => void;\n onLog?: (projectName: string, logType: 'stdout' | 'stderr' | 'progress', content: string) => void;\n} ","import { NextRequest, NextResponse } from 'next/server';\nimport { promises as fs } from 'fs';\nimport { join } from 'path';\nimport { WORKSPACE_CONFIG } from '@/lib/workspace-types';\n\nexport async function POST(request: NextRequest) {\n try {\n const { projectName } = await request.json();\n\n if (!projectName || typeof projectName !== 'string') {\n return NextResponse.json({\n success: false,\n error: '项目名称不能为空'\n }, { status: 400 });\n }\n\n const workspacePath = WORKSPACE_CONFIG.WORKSPACE_ROOT;\n const projectPath = join(workspacePath, projectName);\n\n // 检查项目目录是否存在\n try {\n await fs.access(projectPath);\n } catch {\n return NextResponse.json({\n success: false,\n error: '项目目录不存在'\n }, { status: 404 });\n }\n\n // 删除项目目录\n try {\n await fs.rm(projectPath, { recursive: true, force: true });\n console.log(`手动清理项目成功: ${projectPath}`);\n \n return NextResponse.json({\n success: true,\n message: `项目 ${projectName} 已成功清理`\n });\n } catch (error) {\n console.error(`清理项目失败 ${projectPath}:`, error);\n return NextResponse.json({\n success: false,\n error: `清理项目失败: ${error instanceof Error ? error.message : String(error)}`\n }, { status: 500 });\n }\n\n } catch (error) {\n console.error('清理项目请求处理失败:', error);\n return NextResponse.json({\n success: false,\n error: '服务器内部错误'\n }, { status: 500 });\n }\n} ","import {\n AppRouteRouteModule,\n type AppRouteRouteModuleOptions,\n} from '../../server/route-modules/app-route/module.compiled'\nimport { RouteKind } from '../../server/route-kind'\nimport { patchFetch as _patchFetch } from '../../server/lib/patch-fetch'\n\nimport * as userland from 'VAR_USERLAND'\n\n// These are injected by the loader afterwards. This is injected as a variable\n// instead of a replacement because this could also be `undefined` instead of\n// an empty string.\ndeclare const nextConfigOutput: AppRouteRouteModuleOptions['nextConfigOutput']\n\n// We inject the nextConfigOutput here so that we can use them in the route\n// module.\n// INJECT:nextConfigOutput\n\nconst routeModule = new AppRouteRouteModule({\n definition: {\n kind: RouteKind.APP_ROUTE,\n page: 'VAR_DEFINITION_PAGE',\n pathname: 'VAR_DEFINITION_PATHNAME',\n filename: 'VAR_DEFINITION_FILENAME',\n bundlePath: 'VAR_DEFINITION_BUNDLE_PATH',\n },\n resolvedPagePath: 'VAR_RESOLVED_PAGE_PATH',\n nextConfigOutput,\n userland,\n})\n\n// Pull out the exports that we need to expose from the module. This should\n// be eliminated when we've moved the other routes to the new format. These\n// are used to hook into the route.\nconst { workAsyncStorage, workUnitAsyncStorage, serverHooks } = routeModule\n\nfunction patchFetch() {\n return _patchFetch({\n workAsyncStorage,\n workUnitAsyncStorage,\n })\n}\n\nexport {\n routeModule,\n workAsyncStorage,\n workUnitAsyncStorage,\n serverHooks,\n patchFetch,\n}\n"],"names":["AppRouteRouteModule","RouteKind","patchFetch","_patchFetch","userland","routeModule","definition","kind","APP_ROUTE","page","pathname","filename","bundlePath","resolvedPagePath","nextConfigOutput","workAsyncStorage","workUnitAsyncStorage","serverHooks"],"mappings":"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","ignoreList":[2]}
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
module.exports={83886:function(e){var{g:t,__dirname:r,m:s,e:n}=e;s.exports=e.x("fs",()=>require("fs"))},45935:function(e){var{g:t,__dirname:r,m:s,e:n}=e;s.exports=e.x("next/dist/server/app-render/after-task-async-storage.external.js",()=>require("next/dist/server/app-render/after-task-async-storage.external.js"))},35692:e=>{"use strict";var{g:t,__dirname:r}=e;e.s({ProjectStatus:()=>a,getProjectsConfig:()=>o,saveProjectsConfig:()=>i});var s=e.i(9892),n=e.i(88941);async function o(){try{await (0,s.access)(n.PROJECT_CONFIG_PATH,s.constants.F_OK)}catch{return await i({}),{}}try{let e=await (0,s.readFile)(n.PROJECT_CONFIG_PATH,"utf-8");if(!e)return{};return JSON.parse(e)}catch(e){throw console.error("读取或解析项目配置文件失败:",e),Error("无法加载项目配置")}}async function i(e){let t=n.PROJECT_CONFIG_PATH+".tmp";try{await (0,s.writeFile)(t,JSON.stringify(e,null,2),"utf-8"),await (0,s.rename)(t,n.PROJECT_CONFIG_PATH)}catch(e){throw console.error("保存项目配置文件失败:",e),Error("无法保存项目配置")}}var a=function(e){return e.PENDING="pending",e.EXISTING="existing",e.CLONING="cloning",e.SUCCESS="success",e.FAILED="failed",e.RETRYING="retrying",e}({})},88941:e=>{"use strict";var{g:t,__dirname:r}=e;{e.s({PROJECT_CONFIG_PATH:()=>r,ProjectStatus:()=>o,WORKSPACE_CONFIG:()=>t});var s=e.i(13442),n=e.i(30331);let t={WORKSPACE_ROOT:(0,n.join)((0,s.homedir)(),"Documents","prime-workspace"),GIT_TIMEOUT:3e5,MAX_CONCURRENT_CLONES:Math.max(2,Math.min((0,s.cpus)().length,8)),MAX_RETRY_ATTEMPTS:3},r=(0,n.join)((0,s.homedir)(),".prime-projects.json");var o=function(e){return e.PENDING="pending",e.EXISTING="existing",e.CLONING="cloning",e.SUCCESS="success",e.FAILED="failed",e.RETRYING="retrying",e.INCOMPLETE="incomplete",e}({})}},29549:function(e){var{g:t,__dirname:r,m:s,e:n}=e;s.exports=e.x("next/dist/compiled/next-server/app-page-turbo.runtime.prod.js",()=>require("next/dist/compiled/next-server/app-page-turbo.runtime.prod.js"))},83943:function(e){var{g:t,__dirname:r,m:s,e:n}=e;s.exports=e.x("next/dist/server/app-render/work-unit-async-storage.external.js",()=>require("next/dist/server/app-render/work-unit-async-storage.external.js"))},86103:function(e){var{g:t,__dirname:r,m:s,e:n}=e;s.exports=e.x("next/dist/server/app-render/work-async-storage.external.js",()=>require("next/dist/server/app-render/work-async-storage.external.js"))},30331:function(e){var{g:t,__dirname:r,m:s,e:n}=e;s.exports=e.x("path",()=>require("path"))},23430:function(e){var{g:t,__dirname:r,m:s,e:n}=e;s.exports=e.x("next/dist/compiled/@opentelemetry/api",()=>require("next/dist/compiled/@opentelemetry/api"))},13442:function(e){var{g:t,__dirname:r,m:s,e:n}=e;s.exports=e.x("os",()=>require("os"))},52670:function(e){var{g:t,__dirname:r,m:s,e:n}=e;s.exports=e.x("next/dist/compiled/next-server/app-route-turbo.runtime.prod.js",()=>require("next/dist/compiled/next-server/app-route-turbo.runtime.prod.js"))},9892:function(e){var{g:t,__dirname:r,m:s,e:n}=e;s.exports=e.x("fs/promises",()=>require("fs/promises"))},15650:function(e){var{g:t,__dirname:r,m:s,e:n}=e;s.exports=e.x("module",()=>require("module"))},48647:function(e){var{g:t,__dirname:r,m:s,e:n}=e},68385:e=>{"use strict";var{g:t,__dirname:r}=e;{e.s({PUT:()=>c});var s=e.i(15494),n=e.i(83886),o=e.i(30331),i=e.i(35692),a=e.i(88941);let t=(0,e.i(15650).createRequire)({get url(){return`file://${e.P("packages/server/src/app/api/mock-setting/route.ts")}`}}.url);async function c(e){try{let{projectName:r,apiName:c,method:u,currentSite:p}=await e.json();if(!r||!c||!u||!p)return s.NextResponse.json({success:!1,error:"缺少必要参数:projectName, apiName, method, currentSite"},{status:400});if(!(await (0,i.getProjectsConfig)())[r])return s.NextResponse.json({success:!1,error:`项目 ${r} 不存在`},{status:404});let g=(0,o.join)(a.WORKSPACE_CONFIG.WORKSPACE_ROOT,r),l=(0,o.join)(g,".mock",c,u.toLowerCase(),"setting.js");try{await n.promises.access(l)}catch{return s.NextResponse.json({success:!1,error:"setting.js文件不存在"},{status:404})}let m={};try{let e=(0,o.resolve)(l);delete t.cache[e],m=t(e)}catch(e){console.warn(`解析setting.js失败: ${l}`,e)}m.currentSite=p;let x=`module.exports = ${JSON.stringify(m,null,2).replace(/"([^"]+)":/g,"$1:")};`;return await n.promises.writeFile(l,x,"utf-8"),s.NextResponse.json({success:!0,message:"Mock设置更新成功",data:{projectName:r,apiName:c,method:u.toLowerCase(),currentSite:p,filePath:(0,o.join)(".mock",c,u.toLowerCase(),"setting.js"),updatedAt:new Date().toISOString()}})}catch(t){let e=t instanceof Error?t.message:"更新Mock设置失败";return console.error("更新Mock设置失败:",t),s.NextResponse.json({success:!1,error:e},{status:500})}}}},68510:e=>{"use strict";var{g:t,__dirname:r}=e;{e.s({patchFetch:()=>a,routeModule:()=>t,serverHooks:()=>u,workAsyncStorage:()=>r,workUnitAsyncStorage:()=>c});var s=e.i(45746),n=e.i(93828),o=e.i(18250),i=e.i(68385);let t=new s.AppRouteRouteModule({definition:{kind:n.RouteKind.APP_ROUTE,page:"/api/mock-setting/route",pathname:"/api/mock-setting",filename:"route",bundlePath:""},resolvedPagePath:"[project]/packages/server/src/app/api/mock-setting/route.ts",nextConfigOutput:"",userland:i}),{workAsyncStorage:r,workUnitAsyncStorage:c,serverHooks:u}=t;function a(){return(0,o.patchFetch)({workAsyncStorage:r,workUnitAsyncStorage:c})}}}};
|
|
2
|
+
|
|
3
|
+
//# sourceMappingURL=%5Broot-of-the-server%5D__27f3b464._.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["turbopack:///[project]/packages/server/src/lib/workspace-config.ts","turbopack:///[project]/packages/server/src/lib/workspace-types.ts","turbopack:///[project]/packages/server/src/app/api/mock-setting/route.ts","turbopack:///[project]/node_modules/.pnpm/next@15.3.4_react-dom@19.1.0_react@19.1.0__react@19.1.0/node_modules/next/dist/src/build/templates/app-route.ts"],"sourcesContent":["import { readFile, writeFile, access, constants, rename } from 'fs/promises';\nimport type { ProjectsConfig } from './workspace-types';\nimport { PROJECT_CONFIG_PATH } from './workspace-types';\n\n/**\n * 读取并解析项目配置文件\n * @returns {Promise<ProjectsConfig>} 项目配置对象\n */\nexport async function getProjectsConfig(): Promise<ProjectsConfig> {\n try {\n await access(PROJECT_CONFIG_PATH, constants.F_OK);\n } catch {\n // 文件不存在,创建并写入空对象\n await saveProjectsConfig({});\n return {};\n }\n\n try {\n const configContent = await readFile(PROJECT_CONFIG_PATH, 'utf-8');\n // 如果文件为空,返回空对象\n if (!configContent) {\n return {};\n }\n return JSON.parse(configContent);\n } catch (error) {\n console.error('读取或解析项目配置文件失败:', error);\n // 在出错时返回空对象或抛出错误,这里选择抛出以通知调用者\n throw new Error('无法加载项目配置');\n }\n}\n\n/**\n * 将项目配置写入文件(原子操作)\n * @param {ProjectsConfig} config - 要保存的配置对象\n */\nexport async function saveProjectsConfig(config: ProjectsConfig): Promise<void> {\n const tempConfigPath = PROJECT_CONFIG_PATH + '.tmp';\n try {\n await writeFile(tempConfigPath, JSON.stringify(config, null, 2), 'utf-8');\n await rename(tempConfigPath, PROJECT_CONFIG_PATH);\n } catch (error) {\n console.error('保存项目配置文件失败:', error);\n throw new Error('无法保存项目配置');\n }\n}\n\n/**\n * 项目状态枚举\n */\nexport enum ProjectStatus {\n PENDING = 'pending',\n EXISTING = 'existing',\n CLONING = 'cloning',\n SUCCESS = 'success',\n FAILED = 'failed',\n RETRYING = 'retrying',\n}\n\n/**\n * 项目进度信息接口\n */\nexport interface ProjectProgress {\n projectName: string;\n status: ProjectStatus;\n progress: number; // 0-100\n message: string;\n error?: string;\n startTime?: number;\n endTime?: number;\n}\n\n/**\n * 初始化结果接口\n */\nexport interface InitializationResult {\n success: boolean;\n totalProjects: number;\n successCount: number;\n failedCount: number;\n failedProjects: string[];\n workspacePath: string;\n duration: number;\n}\n\n/**\n * Git 操作配置接口\n */\nexport interface GitOperationConfig {\n repoUrl: string;\n targetDir: string;\n timeout: number;\n onProgress?: (progress: number, message: string) => void;\n onError?: (error: string) => void;\n}","import { homedir, cpus } from 'os';\nimport { join } from 'path';\n\n/**\n * 工作空间配置常量\n */\nexport const WORKSPACE_CONFIG = {\n // 工作空间根目录路径\n WORKSPACE_ROOT: join(homedir(), 'Documents', 'prime-workspace'),\n\n // Git 操作超时时间 (毫秒)\n GIT_TIMEOUT: 300000, // 5分钟\n\n // 最大并发克隆数量(基于CPU核心数,最小2个,最大8个)\n MAX_CONCURRENT_CLONES: Math.max(2, Math.min(cpus().length, 8)),\n\n // 重试次数限制\n MAX_RETRY_ATTEMPTS: 3,\n} as const;\n\nexport const PROJECT_CONFIG_PATH = join(homedir(), '.prime-projects.json');\n\nexport interface ProjectConfig {\n repo: string;\n mockingIntercept?: boolean;\n mockOpen?: boolean;\n envs: {\n [envName: string]: {\n host: string;\n currentProxy: string;\n proxyEnv: {\n [key: string]: string;\n };\n envFileName: string;\n proxyKey: string;\n subApps?: string[];\n };\n };\n}\n\nexport interface ProjectsConfig {\n [projectName: string]: ProjectConfig;\n}\n\n/**\n * 项目状态枚举\n */\nexport enum ProjectStatus {\n PENDING = 'pending',\n EXISTING = 'existing',\n CLONING = 'cloning',\n SUCCESS = 'success',\n FAILED = 'failed',\n RETRYING = 'retrying',\n INCOMPLETE = 'incomplete', // 不完整的项目,需要清理\n}\n\n/**\n * 项目进度信息接口\n */\nexport interface ProjectProgress {\n projectName: string;\n status: ProjectStatus;\n progress: number; // 0-100\n message: string;\n error?: string;\n startTime?: number;\n endTime?: number;\n}\n\n/**\n * 初始化结果接口\n */\nexport interface InitializationResult {\n success: boolean;\n totalProjects: number;\n successCount: number;\n failedCount: number;\n failedProjects: string[];\n workspacePath: string;\n duration: number;\n}\n\n/**\n * Git 操作配置接口\n */\nexport interface GitOperationConfig {\n repoUrl: string;\n targetDir: string;\n timeout: number;\n onProgress?: (progress: number, message: string) => void;\n onError?: (error: string) => void;\n onLog?: (projectName: string, logType: 'stdout' | 'stderr' | 'progress', content: string) => void;\n} ","import { NextRequest, NextResponse } from 'next/server';\nimport { promises as fs } from 'fs';\nimport { join, resolve } from 'path';\nimport { getProjectsConfig } from '@/lib/workspace-config';\nimport { WORKSPACE_CONFIG } from '@/lib/workspace-types';\nimport { createRequire } from \"module\";\nconst require = createRequire(import.meta.url);\n\nexport async function PUT(request: NextRequest) {\n try {\n // 解析请求体\n const { projectName, apiName, method, currentSite } = await request.json();\n\n // 参数验证\n if (!projectName || !apiName || !method || !currentSite) {\n return NextResponse.json(\n {\n success: false,\n error: '缺少必要参数:projectName, apiName, method, currentSite',\n },\n { status: 400 },\n );\n }\n\n // 验证项目是否存在\n const projectsConfig = await getProjectsConfig();\n if (!projectsConfig[projectName]) {\n return NextResponse.json(\n { success: false, error: `项目 ${projectName} 不存在` },\n { status: 404 },\n );\n }\n\n // 构建setting.js文件路径\n const projectPath = join(WORKSPACE_CONFIG.WORKSPACE_ROOT, projectName);\n const settingFilePath = join(projectPath, '.mock', apiName, method.toLowerCase(), 'setting.js');\n\n // 检查setting.js文件是否存在\n try {\n await fs.access(settingFilePath);\n } catch {\n return NextResponse.json(\n { success: false, error: 'setting.js文件不存在' },\n { status: 404 },\n );\n }\n\n // 使用require直接导入setting.js\n let currentConfig: { currentSite?: string; [key: string]: unknown } = {};\n \n try {\n const resolvedPath = resolve(settingFilePath);\n delete require.cache[resolvedPath];\n currentConfig = require(resolvedPath);\n } catch (parseError) {\n console.warn(`解析setting.js失败: ${settingFilePath}`, parseError);\n }\n\n // 更新currentSite\n currentConfig.currentSite = currentSite;\n\n // 生成新的文件内容\n const newContent = `module.exports = ${JSON.stringify(currentConfig, null, 2).replace(/\"([^\"]+)\":/g, '$1:')};`;\n\n // 写入文件\n await fs.writeFile(settingFilePath, newContent, 'utf-8');\n\n return NextResponse.json({\n success: true,\n message: 'Mock设置更新成功',\n data: {\n projectName,\n apiName,\n method: method.toLowerCase(),\n currentSite,\n filePath: join('.mock', apiName, method.toLowerCase(), 'setting.js'),\n updatedAt: new Date().toISOString(),\n },\n });\n } catch (error) {\n const errorMessage = error instanceof Error ? error.message : '更新Mock设置失败';\n console.error('更新Mock设置失败:', error);\n return NextResponse.json(\n { success: false, error: errorMessage },\n { status: 500 },\n );\n }\n} ","import {\n AppRouteRouteModule,\n type AppRouteRouteModuleOptions,\n} from '../../server/route-modules/app-route/module.compiled'\nimport { RouteKind } from '../../server/route-kind'\nimport { patchFetch as _patchFetch } from '../../server/lib/patch-fetch'\n\nimport * as userland from 'VAR_USERLAND'\n\n// These are injected by the loader afterwards. This is injected as a variable\n// instead of a replacement because this could also be `undefined` instead of\n// an empty string.\ndeclare const nextConfigOutput: AppRouteRouteModuleOptions['nextConfigOutput']\n\n// We inject the nextConfigOutput here so that we can use them in the route\n// module.\n// INJECT:nextConfigOutput\n\nconst routeModule = new AppRouteRouteModule({\n definition: {\n kind: RouteKind.APP_ROUTE,\n page: 'VAR_DEFINITION_PAGE',\n pathname: 'VAR_DEFINITION_PATHNAME',\n filename: 'VAR_DEFINITION_FILENAME',\n bundlePath: 'VAR_DEFINITION_BUNDLE_PATH',\n },\n resolvedPagePath: 'VAR_RESOLVED_PAGE_PATH',\n nextConfigOutput,\n userland,\n})\n\n// Pull out the exports that we need to expose from the module. This should\n// be eliminated when we've moved the other routes to the new format. These\n// are used to hook into the route.\nconst { workAsyncStorage, workUnitAsyncStorage, serverHooks } = routeModule\n\nfunction patchFetch() {\n return _patchFetch({\n workAsyncStorage,\n workUnitAsyncStorage,\n })\n}\n\nexport {\n routeModule,\n workAsyncStorage,\n workUnitAsyncStorage,\n serverHooks,\n patchFetch,\n}\n"],"names":["AppRouteRouteModule","RouteKind","patchFetch","_patchFetch","userland","routeModule","definition","kind","APP_ROUTE","page","pathname","filename","bundlePath","resolvedPagePath","nextConfigOutput","workAsyncStorage","workUnitAsyncStorage","serverHooks"],"mappings":"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","ignoreList":[3]}
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
module.exports={83886:function(e){var{g:r,__dirname:t,m:s,e:n}=e;s.exports=e.x("fs",()=>require("fs"))},45935:function(e){var{g:r,__dirname:t,m:s,e:n}=e;s.exports=e.x("next/dist/server/app-render/after-task-async-storage.external.js",()=>require("next/dist/server/app-render/after-task-async-storage.external.js"))},35692:e=>{"use strict";var{g:r,__dirname:t}=e;e.s({ProjectStatus:()=>a,getProjectsConfig:()=>o,saveProjectsConfig:()=>i});var s=e.i(9892),n=e.i(88941);async function o(){try{await (0,s.access)(n.PROJECT_CONFIG_PATH,s.constants.F_OK)}catch{return await i({}),{}}try{let e=await (0,s.readFile)(n.PROJECT_CONFIG_PATH,"utf-8");if(!e)return{};return JSON.parse(e)}catch(e){throw console.error("读取或解析项目配置文件失败:",e),Error("无法加载项目配置")}}async function i(e){let r=n.PROJECT_CONFIG_PATH+".tmp";try{await (0,s.writeFile)(r,JSON.stringify(e,null,2),"utf-8"),await (0,s.rename)(r,n.PROJECT_CONFIG_PATH)}catch(e){throw console.error("保存项目配置文件失败:",e),Error("无法保存项目配置")}}var a=function(e){return e.PENDING="pending",e.EXISTING="existing",e.CLONING="cloning",e.SUCCESS="success",e.FAILED="failed",e.RETRYING="retrying",e}({})},88941:e=>{"use strict";var{g:r,__dirname:t}=e;{e.s({PROJECT_CONFIG_PATH:()=>t,ProjectStatus:()=>o,WORKSPACE_CONFIG:()=>r});var s=e.i(13442),n=e.i(30331);let r={WORKSPACE_ROOT:(0,n.join)((0,s.homedir)(),"Documents","prime-workspace"),GIT_TIMEOUT:3e5,MAX_CONCURRENT_CLONES:Math.max(2,Math.min((0,s.cpus)().length,8)),MAX_RETRY_ATTEMPTS:3},t=(0,n.join)((0,s.homedir)(),".prime-projects.json");var o=function(e){return e.PENDING="pending",e.EXISTING="existing",e.CLONING="cloning",e.SUCCESS="success",e.FAILED="failed",e.RETRYING="retrying",e.INCOMPLETE="incomplete",e}({})}},29549:function(e){var{g:r,__dirname:t,m:s,e:n}=e;s.exports=e.x("next/dist/compiled/next-server/app-page-turbo.runtime.prod.js",()=>require("next/dist/compiled/next-server/app-page-turbo.runtime.prod.js"))},83943:function(e){var{g:r,__dirname:t,m:s,e:n}=e;s.exports=e.x("next/dist/server/app-render/work-unit-async-storage.external.js",()=>require("next/dist/server/app-render/work-unit-async-storage.external.js"))},86103:function(e){var{g:r,__dirname:t,m:s,e:n}=e;s.exports=e.x("next/dist/server/app-render/work-async-storage.external.js",()=>require("next/dist/server/app-render/work-async-storage.external.js"))},30331:function(e){var{g:r,__dirname:t,m:s,e:n}=e;s.exports=e.x("path",()=>require("path"))},23430:function(e){var{g:r,__dirname:t,m:s,e:n}=e;s.exports=e.x("next/dist/compiled/@opentelemetry/api",()=>require("next/dist/compiled/@opentelemetry/api"))},13442:function(e){var{g:r,__dirname:t,m:s,e:n}=e;s.exports=e.x("os",()=>require("os"))},52670:function(e){var{g:r,__dirname:t,m:s,e:n}=e;s.exports=e.x("next/dist/compiled/next-server/app-route-turbo.runtime.prod.js",()=>require("next/dist/compiled/next-server/app-route-turbo.runtime.prod.js"))},9892:function(e){var{g:r,__dirname:t,m:s,e:n}=e;s.exports=e.x("fs/promises",()=>require("fs/promises"))},15564:function(e){var{g:r,__dirname:t,m:s,e:n}=e},35139:e=>{"use strict";var{g:r,__dirname:t}=e;e.s({DELETE:()=>c});var s=e.i(15494),n=e.i(83886),o=e.i(30331),i=e.i(35692),a=e.i(88941);async function c(e){try{let{searchParams:r}=new URL(e.url),t=r.get("project"),c=r.get("apiName");if(!t||!c)return s.NextResponse.json({success:!1,error:"缺少必要参数:project, apiName"},{status:400});if(!(await (0,i.getProjectsConfig)())[t])return s.NextResponse.json({success:!1,error:`项目 ${t} 不存在`},{status:404});let p=(0,o.join)(a.WORKSPACE_CONFIG.WORKSPACE_ROOT,t),u=(0,o.join)(p,".mock",c);try{await n.promises.access(u)}catch{return s.NextResponse.json({success:!1,error:"Mock接口目录不存在"},{status:404})}await n.promises.rmdir(u,{recursive:!0});let d=(0,o.join)(p,".mock");try{let e=await n.promises.readdir(d);0===e.length&&await n.promises.rmdir(d)}catch{}return s.NextResponse.json({success:!0,message:"Mock接口删除成功",data:{projectName:t,apiName:c,deletedPath:(0,o.join)(".mock",c)}})}catch(r){let e=r instanceof Error?r.message:"删除Mock接口失败";return console.error("删除Mock接口失败:",r),s.NextResponse.json({success:!1,error:e},{status:500})}}},19444:e=>{"use strict";var{g:r,__dirname:t}=e;{e.s({patchFetch:()=>a,routeModule:()=>r,serverHooks:()=>p,workAsyncStorage:()=>t,workUnitAsyncStorage:()=>c});var s=e.i(45746),n=e.i(93828),o=e.i(18250),i=e.i(35139);let r=new s.AppRouteRouteModule({definition:{kind:n.RouteKind.APP_ROUTE,page:"/api/delete-mock-api/route",pathname:"/api/delete-mock-api",filename:"route",bundlePath:""},resolvedPagePath:"[project]/packages/server/src/app/api/delete-mock-api/route.ts",nextConfigOutput:"",userland:i}),{workAsyncStorage:t,workUnitAsyncStorage:c,serverHooks:p}=r;function a(){return(0,o.patchFetch)({workAsyncStorage:t,workUnitAsyncStorage:c})}}}};
|
|
2
|
+
|
|
3
|
+
//# sourceMappingURL=%5Broot-of-the-server%5D__29969c0b._.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["turbopack:///[project]/packages/server/src/lib/workspace-config.ts","turbopack:///[project]/packages/server/src/lib/workspace-types.ts","turbopack:///[project]/packages/server/src/app/api/delete-mock-api/route.ts","turbopack:///[project]/node_modules/.pnpm/next@15.3.4_react-dom@19.1.0_react@19.1.0__react@19.1.0/node_modules/next/dist/src/build/templates/app-route.ts"],"sourcesContent":["import { readFile, writeFile, access, constants, rename } from 'fs/promises';\nimport type { ProjectsConfig } from './workspace-types';\nimport { PROJECT_CONFIG_PATH } from './workspace-types';\n\n/**\n * 读取并解析项目配置文件\n * @returns {Promise<ProjectsConfig>} 项目配置对象\n */\nexport async function getProjectsConfig(): Promise<ProjectsConfig> {\n try {\n await access(PROJECT_CONFIG_PATH, constants.F_OK);\n } catch {\n // 文件不存在,创建并写入空对象\n await saveProjectsConfig({});\n return {};\n }\n\n try {\n const configContent = await readFile(PROJECT_CONFIG_PATH, 'utf-8');\n // 如果文件为空,返回空对象\n if (!configContent) {\n return {};\n }\n return JSON.parse(configContent);\n } catch (error) {\n console.error('读取或解析项目配置文件失败:', error);\n // 在出错时返回空对象或抛出错误,这里选择抛出以通知调用者\n throw new Error('无法加载项目配置');\n }\n}\n\n/**\n * 将项目配置写入文件(原子操作)\n * @param {ProjectsConfig} config - 要保存的配置对象\n */\nexport async function saveProjectsConfig(config: ProjectsConfig): Promise<void> {\n const tempConfigPath = PROJECT_CONFIG_PATH + '.tmp';\n try {\n await writeFile(tempConfigPath, JSON.stringify(config, null, 2), 'utf-8');\n await rename(tempConfigPath, PROJECT_CONFIG_PATH);\n } catch (error) {\n console.error('保存项目配置文件失败:', error);\n throw new Error('无法保存项目配置');\n }\n}\n\n/**\n * 项目状态枚举\n */\nexport enum ProjectStatus {\n PENDING = 'pending',\n EXISTING = 'existing',\n CLONING = 'cloning',\n SUCCESS = 'success',\n FAILED = 'failed',\n RETRYING = 'retrying',\n}\n\n/**\n * 项目进度信息接口\n */\nexport interface ProjectProgress {\n projectName: string;\n status: ProjectStatus;\n progress: number; // 0-100\n message: string;\n error?: string;\n startTime?: number;\n endTime?: number;\n}\n\n/**\n * 初始化结果接口\n */\nexport interface InitializationResult {\n success: boolean;\n totalProjects: number;\n successCount: number;\n failedCount: number;\n failedProjects: string[];\n workspacePath: string;\n duration: number;\n}\n\n/**\n * Git 操作配置接口\n */\nexport interface GitOperationConfig {\n repoUrl: string;\n targetDir: string;\n timeout: number;\n onProgress?: (progress: number, message: string) => void;\n onError?: (error: string) => void;\n}","import { homedir, cpus } from 'os';\nimport { join } from 'path';\n\n/**\n * 工作空间配置常量\n */\nexport const WORKSPACE_CONFIG = {\n // 工作空间根目录路径\n WORKSPACE_ROOT: join(homedir(), 'Documents', 'prime-workspace'),\n\n // Git 操作超时时间 (毫秒)\n GIT_TIMEOUT: 300000, // 5分钟\n\n // 最大并发克隆数量(基于CPU核心数,最小2个,最大8个)\n MAX_CONCURRENT_CLONES: Math.max(2, Math.min(cpus().length, 8)),\n\n // 重试次数限制\n MAX_RETRY_ATTEMPTS: 3,\n} as const;\n\nexport const PROJECT_CONFIG_PATH = join(homedir(), '.prime-projects.json');\n\nexport interface ProjectConfig {\n repo: string;\n mockingIntercept?: boolean;\n mockOpen?: boolean;\n envs: {\n [envName: string]: {\n host: string;\n currentProxy: string;\n proxyEnv: {\n [key: string]: string;\n };\n envFileName: string;\n proxyKey: string;\n subApps?: string[];\n };\n };\n}\n\nexport interface ProjectsConfig {\n [projectName: string]: ProjectConfig;\n}\n\n/**\n * 项目状态枚举\n */\nexport enum ProjectStatus {\n PENDING = 'pending',\n EXISTING = 'existing',\n CLONING = 'cloning',\n SUCCESS = 'success',\n FAILED = 'failed',\n RETRYING = 'retrying',\n INCOMPLETE = 'incomplete', // 不完整的项目,需要清理\n}\n\n/**\n * 项目进度信息接口\n */\nexport interface ProjectProgress {\n projectName: string;\n status: ProjectStatus;\n progress: number; // 0-100\n message: string;\n error?: string;\n startTime?: number;\n endTime?: number;\n}\n\n/**\n * 初始化结果接口\n */\nexport interface InitializationResult {\n success: boolean;\n totalProjects: number;\n successCount: number;\n failedCount: number;\n failedProjects: string[];\n workspacePath: string;\n duration: number;\n}\n\n/**\n * Git 操作配置接口\n */\nexport interface GitOperationConfig {\n repoUrl: string;\n targetDir: string;\n timeout: number;\n onProgress?: (progress: number, message: string) => void;\n onError?: (error: string) => void;\n onLog?: (projectName: string, logType: 'stdout' | 'stderr' | 'progress', content: string) => void;\n} ","import { NextRequest, NextResponse } from 'next/server';\nimport { promises as fs } from 'fs';\nimport { join } from 'path';\nimport { getProjectsConfig } from '@/lib/workspace-config';\nimport { WORKSPACE_CONFIG } from '@/lib/workspace-types';\n\nexport async function DELETE(request: NextRequest) {\n try {\n const { searchParams } = new URL(request.url);\n const projectName = searchParams.get('project');\n const apiName = searchParams.get('apiName');\n\n if (!projectName || !apiName) {\n return NextResponse.json(\n { success: false, error: '缺少必要参数:project, apiName' },\n { status: 400 },\n );\n }\n\n // 验证项目是否存在\n const projectsConfig = await getProjectsConfig();\n if (!projectsConfig[projectName]) {\n return NextResponse.json(\n { success: false, error: `项目 ${projectName} 不存在` },\n { status: 404 },\n );\n }\n\n // 构建API目录路径\n const projectPath = join(WORKSPACE_CONFIG.WORKSPACE_ROOT, projectName);\n const apiPath = join(projectPath, '.mock', apiName);\n\n // 检查API目录是否存在\n try {\n await fs.access(apiPath);\n } catch {\n return NextResponse.json(\n { success: false, error: 'Mock接口目录不存在' },\n { status: 404 },\n );\n }\n\n // 递归删除整个API目录\n await fs.rmdir(apiPath, { recursive: true });\n\n // 检查.mock目录是否为空,如果为空则删除.mock目录\n const mockPath = join(projectPath, '.mock');\n try {\n const mockFiles = await fs.readdir(mockPath);\n if (mockFiles.length === 0) {\n await fs.rmdir(mockPath);\n }\n } catch {\n // 忽略目录删除错误\n }\n\n return NextResponse.json({\n success: true,\n message: 'Mock接口删除成功',\n data: {\n projectName,\n apiName,\n deletedPath: join('.mock', apiName),\n },\n });\n } catch (error) {\n const errorMessage = error instanceof Error ? error.message : '删除Mock接口失败';\n console.error('删除Mock接口失败:', error);\n return NextResponse.json(\n { success: false, error: errorMessage },\n { status: 500 },\n );\n }\n}\n","import {\n AppRouteRouteModule,\n type AppRouteRouteModuleOptions,\n} from '../../server/route-modules/app-route/module.compiled'\nimport { RouteKind } from '../../server/route-kind'\nimport { patchFetch as _patchFetch } from '../../server/lib/patch-fetch'\n\nimport * as userland from 'VAR_USERLAND'\n\n// These are injected by the loader afterwards. This is injected as a variable\n// instead of a replacement because this could also be `undefined` instead of\n// an empty string.\ndeclare const nextConfigOutput: AppRouteRouteModuleOptions['nextConfigOutput']\n\n// We inject the nextConfigOutput here so that we can use them in the route\n// module.\n// INJECT:nextConfigOutput\n\nconst routeModule = new AppRouteRouteModule({\n definition: {\n kind: RouteKind.APP_ROUTE,\n page: 'VAR_DEFINITION_PAGE',\n pathname: 'VAR_DEFINITION_PATHNAME',\n filename: 'VAR_DEFINITION_FILENAME',\n bundlePath: 'VAR_DEFINITION_BUNDLE_PATH',\n },\n resolvedPagePath: 'VAR_RESOLVED_PAGE_PATH',\n nextConfigOutput,\n userland,\n})\n\n// Pull out the exports that we need to expose from the module. This should\n// be eliminated when we've moved the other routes to the new format. These\n// are used to hook into the route.\nconst { workAsyncStorage, workUnitAsyncStorage, serverHooks } = routeModule\n\nfunction patchFetch() {\n return _patchFetch({\n workAsyncStorage,\n workUnitAsyncStorage,\n })\n}\n\nexport {\n routeModule,\n workAsyncStorage,\n workUnitAsyncStorage,\n serverHooks,\n patchFetch,\n}\n"],"names":["AppRouteRouteModule","RouteKind","patchFetch","_patchFetch","userland","routeModule","definition","kind","APP_ROUTE","page","pathname","filename","bundlePath","resolvedPagePath","nextConfigOutput","workAsyncStorage","workUnitAsyncStorage","serverHooks"],"mappings":"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","ignoreList":[3]}
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
module.exports={83886:function(e){var{g:t,__dirname:r,m:s,e:o}=e;s.exports=e.x("fs",()=>require("fs"))},45935:function(e){var{g:t,__dirname:r,m:s,e:o}=e;s.exports=e.x("next/dist/server/app-render/after-task-async-storage.external.js",()=>require("next/dist/server/app-render/after-task-async-storage.external.js"))},35692:e=>{"use strict";var{g:t,__dirname:r}=e;e.s({ProjectStatus:()=>i,getProjectsConfig:()=>n,saveProjectsConfig:()=>a});var s=e.i(9892),o=e.i(88941);async function n(){try{await (0,s.access)(o.PROJECT_CONFIG_PATH,s.constants.F_OK)}catch{return await a({}),{}}try{let e=await (0,s.readFile)(o.PROJECT_CONFIG_PATH,"utf-8");if(!e)return{};return JSON.parse(e)}catch(e){throw console.error("读取或解析项目配置文件失败:",e),Error("无法加载项目配置")}}async function a(e){let t=o.PROJECT_CONFIG_PATH+".tmp";try{await (0,s.writeFile)(t,JSON.stringify(e,null,2),"utf-8"),await (0,s.rename)(t,o.PROJECT_CONFIG_PATH)}catch(e){throw console.error("保存项目配置文件失败:",e),Error("无法保存项目配置")}}var i=function(e){return e.PENDING="pending",e.EXISTING="existing",e.CLONING="cloning",e.SUCCESS="success",e.FAILED="failed",e.RETRYING="retrying",e}({})},88941:e=>{"use strict";var{g:t,__dirname:r}=e;{e.s({PROJECT_CONFIG_PATH:()=>r,ProjectStatus:()=>n,WORKSPACE_CONFIG:()=>t});var s=e.i(13442),o=e.i(30331);let t={WORKSPACE_ROOT:(0,o.join)((0,s.homedir)(),"Documents","prime-workspace"),GIT_TIMEOUT:3e5,MAX_CONCURRENT_CLONES:Math.max(2,Math.min((0,s.cpus)().length,8)),MAX_RETRY_ATTEMPTS:3},r=(0,o.join)((0,s.homedir)(),".prime-projects.json");var n=function(e){return e.PENDING="pending",e.EXISTING="existing",e.CLONING="cloning",e.SUCCESS="success",e.FAILED="failed",e.RETRYING="retrying",e.INCOMPLETE="incomplete",e}({})}},29549:function(e){var{g:t,__dirname:r,m:s,e:o}=e;s.exports=e.x("next/dist/compiled/next-server/app-page-turbo.runtime.prod.js",()=>require("next/dist/compiled/next-server/app-page-turbo.runtime.prod.js"))},83943:function(e){var{g:t,__dirname:r,m:s,e:o}=e;s.exports=e.x("next/dist/server/app-render/work-unit-async-storage.external.js",()=>require("next/dist/server/app-render/work-unit-async-storage.external.js"))},86103:function(e){var{g:t,__dirname:r,m:s,e:o}=e;s.exports=e.x("next/dist/server/app-render/work-async-storage.external.js",()=>require("next/dist/server/app-render/work-async-storage.external.js"))},30331:function(e){var{g:t,__dirname:r,m:s,e:o}=e;s.exports=e.x("path",()=>require("path"))},23430:function(e){var{g:t,__dirname:r,m:s,e:o}=e;s.exports=e.x("next/dist/compiled/@opentelemetry/api",()=>require("next/dist/compiled/@opentelemetry/api"))},13442:function(e){var{g:t,__dirname:r,m:s,e:o}=e;s.exports=e.x("os",()=>require("os"))},52670:function(e){var{g:t,__dirname:r,m:s,e:o}=e;s.exports=e.x("next/dist/compiled/next-server/app-route-turbo.runtime.prod.js",()=>require("next/dist/compiled/next-server/app-route-turbo.runtime.prod.js"))},9892:function(e){var{g:t,__dirname:r,m:s,e:o}=e;s.exports=e.x("fs/promises",()=>require("fs/promises"))},8773:function(e){var{g:t,__dirname:r,m:s,e:o}=e},55859:e=>{"use strict";var{g:t,__dirname:r}=e;e.s({GET:()=>c,PUT:()=>u});var s=e.i(15494),o=e.i(83886),n=e.i(30331),a=e.i(35692),i=e.i(88941);async function c(e){try{let{searchParams:t}=new URL(e.url),r=t.get("project"),c=t.get("apiName"),u=t.get("method"),p=t.get("siteName");if(!r||!c||!u||!p)return s.NextResponse.json({success:!1,error:"缺少必要参数:project, apiName, method, siteName"},{status:400});if(!(await (0,a.getProjectsConfig)())[r])return s.NextResponse.json({success:!1,error:`项目 ${r} 不存在`},{status:404});let m=(0,n.join)(i.WORKSPACE_CONFIG.WORKSPACE_ROOT,r),x=(0,n.join)(m,".mock",c,u.toLowerCase(),`${p}.js`);try{await o.promises.access(x)}catch{return s.NextResponse.json({success:!1,error:"Mock文件不存在"},{status:404})}let d=await o.promises.readFile(x,"utf-8");return s.NextResponse.json({success:!0,data:{projectName:r,apiName:c,method:u.toLowerCase(),siteName:p,content:d,filePath:(0,n.join)(".mock",c,u.toLowerCase(),`${p}.js`)},message:"获取Mock文件内容成功"})}catch(t){let e=t instanceof Error?t.message:"获取Mock文件内容失败";return console.error("获取Mock文件内容失败:",t),s.NextResponse.json({success:!1,error:e},{status:500})}}async function u(e){try{let{projectName:t,apiName:r,method:c,siteName:u,content:p}=await e.json();if(!t||!r||!c||!u||void 0===p)return s.NextResponse.json({success:!1,error:"缺少必要参数:projectName, apiName, method, siteName, content"},{status:400});if(!(await (0,a.getProjectsConfig)())[t])return s.NextResponse.json({success:!1,error:`项目 ${t} 不存在`},{status:404});let m=(0,n.join)(i.WORKSPACE_CONFIG.WORKSPACE_ROOT,t),x=(0,n.join)(m,".mock",r,c.toLowerCase(),`${u}.js`);try{await o.promises.access(x)}catch{return s.NextResponse.json({success:!1,error:"Mock文件不存在"},{status:404})}return await o.promises.writeFile(x,p,"utf-8"),s.NextResponse.json({success:!0,message:"Mock文件内容更新成功",data:{projectName:t,apiName:r,method:c.toLowerCase(),siteName:u,filePath:(0,n.join)(".mock",r,c.toLowerCase(),`${u}.js`),updatedAt:new Date().toISOString()}})}catch(t){let e=t instanceof Error?t.message:"更新Mock文件内容失败";return console.error("更新Mock文件内容失败:",t),s.NextResponse.json({success:!1,error:e},{status:500})}}},19627:e=>{"use strict";var{g:t,__dirname:r}=e;{e.s({patchFetch:()=>i,routeModule:()=>t,serverHooks:()=>u,workAsyncStorage:()=>r,workUnitAsyncStorage:()=>c});var s=e.i(45746),o=e.i(93828),n=e.i(18250),a=e.i(55859);let t=new s.AppRouteRouteModule({definition:{kind:o.RouteKind.APP_ROUTE,page:"/api/mock-file-content/route",pathname:"/api/mock-file-content",filename:"route",bundlePath:""},resolvedPagePath:"[project]/packages/server/src/app/api/mock-file-content/route.ts",nextConfigOutput:"",userland:a}),{workAsyncStorage:r,workUnitAsyncStorage:c,serverHooks:u}=t;function i(){return(0,n.patchFetch)({workAsyncStorage:r,workUnitAsyncStorage:c})}}}};
|
|
2
|
+
|
|
3
|
+
//# sourceMappingURL=%5Broot-of-the-server%5D__3da8edfd._.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["turbopack:///[project]/packages/server/src/lib/workspace-config.ts","turbopack:///[project]/packages/server/src/lib/workspace-types.ts","turbopack:///[project]/packages/server/src/app/api/mock-file-content/route.ts","turbopack:///[project]/node_modules/.pnpm/next@15.3.4_react-dom@19.1.0_react@19.1.0__react@19.1.0/node_modules/next/dist/src/build/templates/app-route.ts"],"sourcesContent":["import { readFile, writeFile, access, constants, rename } from 'fs/promises';\nimport type { ProjectsConfig } from './workspace-types';\nimport { PROJECT_CONFIG_PATH } from './workspace-types';\n\n/**\n * 读取并解析项目配置文件\n * @returns {Promise<ProjectsConfig>} 项目配置对象\n */\nexport async function getProjectsConfig(): Promise<ProjectsConfig> {\n try {\n await access(PROJECT_CONFIG_PATH, constants.F_OK);\n } catch {\n // 文件不存在,创建并写入空对象\n await saveProjectsConfig({});\n return {};\n }\n\n try {\n const configContent = await readFile(PROJECT_CONFIG_PATH, 'utf-8');\n // 如果文件为空,返回空对象\n if (!configContent) {\n return {};\n }\n return JSON.parse(configContent);\n } catch (error) {\n console.error('读取或解析项目配置文件失败:', error);\n // 在出错时返回空对象或抛出错误,这里选择抛出以通知调用者\n throw new Error('无法加载项目配置');\n }\n}\n\n/**\n * 将项目配置写入文件(原子操作)\n * @param {ProjectsConfig} config - 要保存的配置对象\n */\nexport async function saveProjectsConfig(config: ProjectsConfig): Promise<void> {\n const tempConfigPath = PROJECT_CONFIG_PATH + '.tmp';\n try {\n await writeFile(tempConfigPath, JSON.stringify(config, null, 2), 'utf-8');\n await rename(tempConfigPath, PROJECT_CONFIG_PATH);\n } catch (error) {\n console.error('保存项目配置文件失败:', error);\n throw new Error('无法保存项目配置');\n }\n}\n\n/**\n * 项目状态枚举\n */\nexport enum ProjectStatus {\n PENDING = 'pending',\n EXISTING = 'existing',\n CLONING = 'cloning',\n SUCCESS = 'success',\n FAILED = 'failed',\n RETRYING = 'retrying',\n}\n\n/**\n * 项目进度信息接口\n */\nexport interface ProjectProgress {\n projectName: string;\n status: ProjectStatus;\n progress: number; // 0-100\n message: string;\n error?: string;\n startTime?: number;\n endTime?: number;\n}\n\n/**\n * 初始化结果接口\n */\nexport interface InitializationResult {\n success: boolean;\n totalProjects: number;\n successCount: number;\n failedCount: number;\n failedProjects: string[];\n workspacePath: string;\n duration: number;\n}\n\n/**\n * Git 操作配置接口\n */\nexport interface GitOperationConfig {\n repoUrl: string;\n targetDir: string;\n timeout: number;\n onProgress?: (progress: number, message: string) => void;\n onError?: (error: string) => void;\n}","import { homedir, cpus } from 'os';\nimport { join } from 'path';\n\n/**\n * 工作空间配置常量\n */\nexport const WORKSPACE_CONFIG = {\n // 工作空间根目录路径\n WORKSPACE_ROOT: join(homedir(), 'Documents', 'prime-workspace'),\n\n // Git 操作超时时间 (毫秒)\n GIT_TIMEOUT: 300000, // 5分钟\n\n // 最大并发克隆数量(基于CPU核心数,最小2个,最大8个)\n MAX_CONCURRENT_CLONES: Math.max(2, Math.min(cpus().length, 8)),\n\n // 重试次数限制\n MAX_RETRY_ATTEMPTS: 3,\n} as const;\n\nexport const PROJECT_CONFIG_PATH = join(homedir(), '.prime-projects.json');\n\nexport interface ProjectConfig {\n repo: string;\n mockingIntercept?: boolean;\n mockOpen?: boolean;\n envs: {\n [envName: string]: {\n host: string;\n currentProxy: string;\n proxyEnv: {\n [key: string]: string;\n };\n envFileName: string;\n proxyKey: string;\n subApps?: string[];\n };\n };\n}\n\nexport interface ProjectsConfig {\n [projectName: string]: ProjectConfig;\n}\n\n/**\n * 项目状态枚举\n */\nexport enum ProjectStatus {\n PENDING = 'pending',\n EXISTING = 'existing',\n CLONING = 'cloning',\n SUCCESS = 'success',\n FAILED = 'failed',\n RETRYING = 'retrying',\n INCOMPLETE = 'incomplete', // 不完整的项目,需要清理\n}\n\n/**\n * 项目进度信息接口\n */\nexport interface ProjectProgress {\n projectName: string;\n status: ProjectStatus;\n progress: number; // 0-100\n message: string;\n error?: string;\n startTime?: number;\n endTime?: number;\n}\n\n/**\n * 初始化结果接口\n */\nexport interface InitializationResult {\n success: boolean;\n totalProjects: number;\n successCount: number;\n failedCount: number;\n failedProjects: string[];\n workspacePath: string;\n duration: number;\n}\n\n/**\n * Git 操作配置接口\n */\nexport interface GitOperationConfig {\n repoUrl: string;\n targetDir: string;\n timeout: number;\n onProgress?: (progress: number, message: string) => void;\n onError?: (error: string) => void;\n onLog?: (projectName: string, logType: 'stdout' | 'stderr' | 'progress', content: string) => void;\n} ","import { NextRequest, NextResponse } from 'next/server';\nimport { promises as fs } from 'fs';\nimport { join } from 'path';\nimport { getProjectsConfig } from '@/lib/workspace-config';\nimport { WORKSPACE_CONFIG } from '@/lib/workspace-types';\n\nexport async function GET(request: NextRequest) {\n try {\n const { searchParams } = new URL(request.url);\n const projectName = searchParams.get('project');\n const apiName = searchParams.get('apiName');\n const method = searchParams.get('method');\n const siteName = searchParams.get('siteName');\n\n if (!projectName || !apiName || !method || !siteName) {\n return NextResponse.json(\n { success: false, error: '缺少必要参数:project, apiName, method, siteName' },\n { status: 400 },\n );\n }\n\n // 验证项目是否存在\n const projectsConfig = await getProjectsConfig();\n if (!projectsConfig[projectName]) {\n return NextResponse.json(\n { success: false, error: `项目 ${projectName} 不存在` },\n { status: 404 },\n );\n }\n\n // 构建文件路径\n const projectPath = join(WORKSPACE_CONFIG.WORKSPACE_ROOT, projectName);\n const filePath = join(projectPath, '.mock', apiName, method.toLowerCase(), `${siteName}.js`);\n\n // 检查文件是否存在\n try {\n await fs.access(filePath);\n } catch {\n return NextResponse.json(\n { success: false, error: 'Mock文件不存在' },\n { status: 404 },\n );\n }\n\n // 读取文件内容\n const content = await fs.readFile(filePath, 'utf-8');\n\n return NextResponse.json({\n success: true,\n data: {\n projectName,\n apiName,\n method: method.toLowerCase(),\n siteName,\n content,\n filePath: join('.mock', apiName, method.toLowerCase(), `${siteName}.js`),\n },\n message: '获取Mock文件内容成功',\n });\n } catch (error) {\n const errorMessage = error instanceof Error ? error.message : '获取Mock文件内容失败';\n console.error('获取Mock文件内容失败:', error);\n return NextResponse.json(\n { success: false, error: errorMessage },\n { status: 500 },\n );\n }\n}\n\nexport async function PUT(request: NextRequest) {\n try {\n // 解析请求体\n const { projectName, apiName, method, siteName, content } = await request.json();\n\n // 参数验证\n if (!projectName || !apiName || !method || !siteName || content === undefined) {\n return NextResponse.json(\n {\n success: false,\n error: '缺少必要参数:projectName, apiName, method, siteName, content',\n },\n { status: 400 },\n );\n }\n\n // 验证项目是否存在\n const projectsConfig = await getProjectsConfig();\n if (!projectsConfig[projectName]) {\n return NextResponse.json(\n { success: false, error: `项目 ${projectName} 不存在` },\n { status: 404 },\n );\n }\n\n // 构建文件路径\n const projectPath = join(WORKSPACE_CONFIG.WORKSPACE_ROOT, projectName);\n const filePath = join(projectPath, '.mock', apiName, method.toLowerCase(), `${siteName}.js`);\n\n // 检查文件是否存在\n try {\n await fs.access(filePath);\n } catch {\n return NextResponse.json(\n { success: false, error: 'Mock文件不存在' },\n { status: 404 },\n );\n }\n\n // 写入文件内容\n await fs.writeFile(filePath, content, 'utf-8');\n\n return NextResponse.json({\n success: true,\n message: 'Mock文件内容更新成功',\n data: {\n projectName,\n apiName,\n method: method.toLowerCase(),\n siteName,\n filePath: join('.mock', apiName, method.toLowerCase(), `${siteName}.js`),\n updatedAt: new Date().toISOString(),\n },\n });\n } catch (error) {\n const errorMessage = error instanceof Error ? error.message : '更新Mock文件内容失败';\n console.error('更新Mock文件内容失败:', error);\n return NextResponse.json(\n { success: false, error: errorMessage },\n { status: 500 },\n );\n }\n} ","import {\n AppRouteRouteModule,\n type AppRouteRouteModuleOptions,\n} from '../../server/route-modules/app-route/module.compiled'\nimport { RouteKind } from '../../server/route-kind'\nimport { patchFetch as _patchFetch } from '../../server/lib/patch-fetch'\n\nimport * as userland from 'VAR_USERLAND'\n\n// These are injected by the loader afterwards. This is injected as a variable\n// instead of a replacement because this could also be `undefined` instead of\n// an empty string.\ndeclare const nextConfigOutput: AppRouteRouteModuleOptions['nextConfigOutput']\n\n// We inject the nextConfigOutput here so that we can use them in the route\n// module.\n// INJECT:nextConfigOutput\n\nconst routeModule = new AppRouteRouteModule({\n definition: {\n kind: RouteKind.APP_ROUTE,\n page: 'VAR_DEFINITION_PAGE',\n pathname: 'VAR_DEFINITION_PATHNAME',\n filename: 'VAR_DEFINITION_FILENAME',\n bundlePath: 'VAR_DEFINITION_BUNDLE_PATH',\n },\n resolvedPagePath: 'VAR_RESOLVED_PAGE_PATH',\n nextConfigOutput,\n userland,\n})\n\n// Pull out the exports that we need to expose from the module. This should\n// be eliminated when we've moved the other routes to the new format. These\n// are used to hook into the route.\nconst { workAsyncStorage, workUnitAsyncStorage, serverHooks } = routeModule\n\nfunction patchFetch() {\n return _patchFetch({\n workAsyncStorage,\n workUnitAsyncStorage,\n })\n}\n\nexport {\n routeModule,\n workAsyncStorage,\n workUnitAsyncStorage,\n serverHooks,\n patchFetch,\n}\n"],"names":["AppRouteRouteModule","RouteKind","patchFetch","_patchFetch","userland","routeModule","definition","kind","APP_ROUTE","page","pathname","filename","bundlePath","resolvedPagePath","nextConfigOutput","workAsyncStorage","workUnitAsyncStorage","serverHooks"],"mappings":"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","ignoreList":[3]}
|