prime-dev-cli 1.0.13 → 1.0.15
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/server/.next/BUILD_ID +1 -1
- package/dist/server/.next/app-build-manifest.json +5 -5
- package/dist/server/.next/app-path-routes-manifest.json +2 -0
- package/dist/server/.next/build-manifest.json +6 -6
- 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/fallback-build-manifest.json +6 -6
- 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 +9 -9
- package/dist/server/.next/server/app/_not-found/page/app-build-manifest.json +1 -1
- package/dist/server/.next/server/app/_not-found/page.js +3 -2
- 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 +1 -1
- package/dist/server/.next/server/app/_not-found.html +1 -1
- package/dist/server/.next/server/app/_not-found.rsc +3 -3
- package/dist/server/.next/server/app/api/all-projects-envs/route.js +1 -1
- package/dist/server/.next/server/app/api/all-projects-envs/route.js.nft.json +1 -1
- package/dist/server/.next/server/app/api/check-mock-intercept/route.js +1 -1
- package/dist/server/.next/server/app/api/check-mock-intercept/route.js.nft.json +1 -1
- package/dist/server/.next/server/app/api/check-workspace/route.js +1 -1
- package/dist/server/.next/server/app/api/check-workspace/route.js.nft.json +1 -1
- package/dist/server/.next/server/app/api/cleanup-mock/route.js +1 -1
- package/dist/server/.next/server/app/api/cleanup-mock/route.js.nft.json +1 -1
- package/dist/server/.next/server/app/api/delete-mock-api/route.js +1 -1
- package/dist/server/.next/server/app/api/delete-mock-api/route.js.nft.json +1 -1
- package/dist/server/.next/server/app/api/get-mock-data/route.js +1 -1
- package/dist/server/.next/server/app/api/get-mock-data/route.js.nft.json +1 -1
- package/dist/server/.next/server/app/api/initialize-workspace/route.js +1 -1
- package/dist/server/.next/server/app/api/initialize-workspace/route.js.nft.json +1 -1
- package/dist/server/.next/server/app/api/memory-status/route/app-build-manifest.json +11 -0
- package/dist/server/.next/server/app/api/memory-status/route/app-paths-manifest.json +3 -0
- package/dist/server/.next/server/app/api/memory-status/route/build-manifest.json +17 -0
- package/dist/server/.next/server/app/api/memory-status/route/next-font-manifest.json +6 -0
- package/dist/server/.next/server/app/api/memory-status/route/react-loadable-manifest.json +1 -0
- package/dist/server/.next/server/app/api/memory-status/route/server-reference-manifest.json +4 -0
- package/dist/server/.next/server/app/api/memory-status/route.js +8 -0
- package/dist/server/.next/server/app/api/memory-status/route.js.map +5 -0
- package/dist/server/.next/server/app/api/memory-status/route.js.nft.json +1 -0
- package/dist/server/.next/server/app/api/memory-status/route_client-reference-manifest.js +2 -0
- package/dist/server/.next/server/app/api/microapp-proxy-change-stream/route.js +1 -1
- 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-config/route.js +1 -1
- package/dist/server/.next/server/app/api/microapp-proxy-config/route.js.nft.json +1 -1
- package/dist/server/.next/server/app/api/mock-file/route.js +1 -1
- package/dist/server/.next/server/app/api/mock-file/route.js.nft.json +1 -1
- package/dist/server/.next/server/app/api/mock-file-content/route.js +1 -1
- package/dist/server/.next/server/app/api/mock-file-content/route.js.nft.json +1 -1
- package/dist/server/.next/server/app/api/mock-open-status/route.js +1 -1
- package/dist/server/.next/server/app/api/mock-open-status/route.js.nft.json +1 -1
- package/dist/server/.next/server/app/api/mock-setting/route.js +1 -1
- package/dist/server/.next/server/app/api/mock-setting/route.js.nft.json +1 -1
- package/dist/server/.next/server/app/api/open-all-mock/route.js +1 -1
- package/dist/server/.next/server/app/api/open-all-mock/route.js.nft.json +1 -1
- package/dist/server/.next/server/app/api/open-project/route.js.nft.json +1 -1
- package/dist/server/.next/server/app/api/process/logs/route.js +1 -1
- package/dist/server/.next/server/app/api/process/logs/route.js.nft.json +1 -1
- package/dist/server/.next/server/app/api/process/logs/stream/route.js +1 -1
- package/dist/server/.next/server/app/api/process/logs/stream/route.js.nft.json +1 -1
- package/dist/server/.next/server/app/api/process/start/route.js +1 -1
- package/dist/server/.next/server/app/api/process/start/route.js.nft.json +1 -1
- package/dist/server/.next/server/app/api/process/status/route.js +1 -1
- package/dist/server/.next/server/app/api/process/status/route.js.nft.json +1 -1
- package/dist/server/.next/server/app/api/project-config/route.js +1 -1
- package/dist/server/.next/server/app/api/project-config/route.js.nft.json +1 -1
- package/dist/server/.next/server/app/api/retry-project/route.js +1 -1
- package/dist/server/.next/server/app/api/retry-project/route.js.nft.json +1 -1
- package/dist/server/.next/server/app/api/workspace/create/route/app-build-manifest.json +11 -0
- package/dist/server/.next/server/app/api/workspace/create/route/app-paths-manifest.json +3 -0
- package/dist/server/.next/server/app/api/workspace/create/route/build-manifest.json +17 -0
- package/dist/server/.next/server/app/api/workspace/create/route/next-font-manifest.json +6 -0
- package/dist/server/.next/server/app/api/workspace/create/route/react-loadable-manifest.json +1 -0
- package/dist/server/.next/server/app/api/workspace/create/route/server-reference-manifest.json +4 -0
- package/dist/server/.next/server/app/api/workspace/create/route.js +7 -0
- package/dist/server/.next/server/app/api/workspace/create/route.js.map +5 -0
- package/dist/server/.next/server/app/api/workspace/create/route.js.nft.json +1 -0
- package/dist/server/.next/server/app/api/workspace/create/route_client-reference-manifest.js +2 -0
- package/dist/server/.next/server/app/configuration/page/app-build-manifest.json +2 -2
- package/dist/server/.next/server/app/configuration/page.js +3 -2
- 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 +1 -1
- package/dist/server/.next/server/app/configuration.html +1 -1
- package/dist/server/.next/server/app/configuration.rsc +4 -4
- package/dist/server/.next/server/app/index.html +1 -1
- package/dist/server/.next/server/app/index.rsc +3 -3
- package/dist/server/.next/server/app/initialization/page/app-build-manifest.json +1 -1
- package/dist/server/.next/server/app/initialization/page.js +3 -2
- 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 +1 -1
- package/dist/server/.next/server/app/initialization.html +1 -1
- package/dist/server/.next/server/app/initialization.rsc +3 -3
- package/dist/server/.next/server/app/page/app-build-manifest.json +1 -1
- package/dist/server/.next/server/app/page.js +3 -2
- package/dist/server/.next/server/app/page.js.nft.json +1 -1
- package/dist/server/.next/server/app/page_client-reference-manifest.js +1 -1
- package/dist/server/.next/server/app-paths-manifest.json +2 -0
- package/dist/server/.next/server/chunks/[root-of-the-server]__03c2b225._.js +3 -0
- package/dist/server/.next/server/chunks/[root-of-the-server]__03c2b225._.js.map +1 -0
- package/dist/server/.next/server/chunks/{[root-of-the-server]__582946e6._.js → [root-of-the-server]__072f5c45._.js} +2 -2
- package/dist/server/.next/server/chunks/{[root-of-the-server]__582946e6._.js.map → [root-of-the-server]__072f5c45._.js.map} +1 -1
- package/dist/server/.next/server/chunks/{[root-of-the-server]__5cddc64c._.js → [root-of-the-server]__2ba93285._.js} +2 -2
- package/dist/server/.next/server/chunks/{[root-of-the-server]__5cddc64c._.js.map → [root-of-the-server]__2ba93285._.js.map} +1 -1
- package/dist/server/.next/server/chunks/[root-of-the-server]__2fcc7175._.js +5 -0
- package/dist/server/.next/server/chunks/[root-of-the-server]__2fcc7175._.js.map +1 -0
- package/dist/server/.next/server/chunks/{[root-of-the-server]__933f7077._.js → [root-of-the-server]__31a13318._.js} +2 -2
- package/dist/server/.next/server/chunks/{[root-of-the-server]__933f7077._.js.map → [root-of-the-server]__31a13318._.js.map} +1 -1
- package/dist/server/.next/server/chunks/[root-of-the-server]__388e6150._.js +5 -0
- package/dist/server/.next/server/chunks/[root-of-the-server]__388e6150._.js.map +1 -0
- package/dist/server/.next/server/chunks/{[root-of-the-server]__4dc677cb._.js → [root-of-the-server]__3dfc0dc4._.js} +2 -2
- package/dist/server/.next/server/chunks/[root-of-the-server]__3dfc0dc4._.js.map +1 -0
- package/dist/server/.next/server/chunks/{[root-of-the-server]__42bc7b42._.js → [root-of-the-server]__419d3b16._.js} +2 -2
- package/dist/server/.next/server/chunks/[root-of-the-server]__419d3b16._.js.map +1 -0
- package/dist/server/.next/server/chunks/{[root-of-the-server]__a6211ee0._.js → [root-of-the-server]__5100a0c5._.js} +2 -2
- package/dist/server/.next/server/chunks/[root-of-the-server]__5100a0c5._.js.map +1 -0
- package/dist/server/.next/server/chunks/{[root-of-the-server]__da89e112._.js → [root-of-the-server]__5348b4aa._.js} +2 -2
- package/dist/server/.next/server/chunks/[root-of-the-server]__5348b4aa._.js.map +1 -0
- package/dist/server/.next/server/chunks/{[root-of-the-server]__e301c560._.js → [root-of-the-server]__5355b75a._.js} +2 -2
- package/dist/server/.next/server/chunks/[root-of-the-server]__5355b75a._.js.map +1 -0
- package/dist/server/.next/server/chunks/[root-of-the-server]__629e6d6a._.js +3 -0
- package/dist/server/.next/server/chunks/[root-of-the-server]__629e6d6a._.js.map +1 -0
- package/dist/server/.next/server/chunks/{[root-of-the-server]__ef09a48e._.js → [root-of-the-server]__6e5dc117._.js} +2 -2
- package/dist/server/.next/server/chunks/[root-of-the-server]__6e5dc117._.js.map +1 -0
- package/dist/server/.next/server/chunks/{[root-of-the-server]__be3de126._.js → [root-of-the-server]__7500acb0._.js} +2 -2
- package/dist/server/.next/server/chunks/[root-of-the-server]__7500acb0._.js.map +1 -0
- package/dist/server/.next/server/chunks/{[root-of-the-server]__e07d75ff._.js → [root-of-the-server]__771e8133._.js} +2 -2
- package/dist/server/.next/server/chunks/[root-of-the-server]__771e8133._.js.map +1 -0
- package/dist/server/.next/server/chunks/{[root-of-the-server]__837d58ae._.js → [root-of-the-server]__7fc974c9._.js} +2 -2
- package/dist/server/.next/server/chunks/{[root-of-the-server]__837d58ae._.js.map → [root-of-the-server]__7fc974c9._.js.map} +1 -1
- package/dist/server/.next/server/chunks/{[root-of-the-server]__802aba2d._.js → [root-of-the-server]__899d82eb._.js} +2 -2
- package/dist/server/.next/server/chunks/{[root-of-the-server]__802aba2d._.js.map → [root-of-the-server]__899d82eb._.js.map} +1 -1
- package/dist/server/.next/server/chunks/[root-of-the-server]__8fcbb2f0._.js +3 -0
- package/dist/server/.next/server/chunks/[root-of-the-server]__8fcbb2f0._.js.map +1 -0
- package/dist/server/.next/server/chunks/{[root-of-the-server]__07de450e._.js → [root-of-the-server]__973c48a6._.js} +2 -2
- package/dist/server/.next/server/chunks/[root-of-the-server]__973c48a6._.js.map +1 -0
- package/dist/server/.next/server/chunks/[root-of-the-server]__a292866b._.js +15 -0
- package/dist/server/.next/server/chunks/[root-of-the-server]__a292866b._.js.map +1 -0
- package/dist/server/.next/server/chunks/[root-of-the-server]__c8b26634._.js +3 -0
- package/dist/server/.next/server/chunks/[root-of-the-server]__c8b26634._.js.map +1 -0
- package/dist/server/.next/server/chunks/{[root-of-the-server]__aca25fcf._.js → [root-of-the-server]__f815ea40._.js} +2 -2
- package/dist/server/.next/server/chunks/[root-of-the-server]__f815ea40._.js.map +1 -0
- package/dist/server/.next/server/chunks/ssr/[root-of-the-server]__828c7089._.js +3 -0
- package/dist/server/.next/server/chunks/ssr/[root-of-the-server]__828c7089._.js.map +1 -0
- package/dist/server/.next/server/chunks/ssr/[root-of-the-server]__e3a2aebd._.js +3 -0
- package/dist/server/.next/server/chunks/ssr/{_bb352729._.js → _5d353cf8._.js} +3 -3
- package/dist/server/.next/server/chunks/ssr/_5d353cf8._.js.map +1 -0
- package/dist/server/.next/server/chunks/ssr/packages_server_src_eb289b89._.js +5 -0
- package/dist/server/.next/server/chunks/ssr/packages_server_src_eb289b89._.js.map +1 -0
- package/dist/server/.next/server/middleware-build-manifest.js +4 -4
- 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 +2 -2
- package/dist/server/.next/server/pages/_error/build-manifest.json +2 -2
- package/dist/server/.next/server/server-reference-manifest.js +1 -1
- package/dist/server/.next/server/server-reference-manifest.json +1 -1
- package/dist/server/.next/static/chunks/1ad898191df92f90.css +3 -0
- package/dist/server/.next/static/chunks/{2befba13bed43c5f.js → 294d677a4838a994.js} +1 -1
- package/dist/server/.next/static/chunks/2c0e57fbc9520adc.js +61 -0
- package/dist/server/.next/static/chunks/{a898634af0862944.js.map → 479d60165927b286.js.map} +1 -1
- package/dist/server/.next/static/chunks/765c1fd313250591.js.map +1 -0
- package/dist/server/.next/static/chunks/b0840b8d648f6401.css.map +1 -0
- package/dist/server/.next/static/chunks/{d74cc70dd8ef74c9.js → d65b8ba84ba3d819.js} +2 -2
- package/dist/server/.next/static/chunks/{4cbec079b6e3e189.js → f9ef1d12f3c1646a.js} +2 -2
- package/dist/server/.next/static/chunks/pages/_app.js +2 -2
- package/dist/server/.next/static/chunks/pages/_error.js +2 -2
- package/dist/server/.next/trace +1 -1
- package/package.json +1 -1
- package/dist/server/.next/server/chunks/[root-of-the-server]__07de450e._.js.map +0 -1
- package/dist/server/.next/server/chunks/[root-of-the-server]__09808308._.js +0 -3
- package/dist/server/.next/server/chunks/[root-of-the-server]__09808308._.js.map +0 -1
- package/dist/server/.next/server/chunks/[root-of-the-server]__09914a79._.js +0 -3
- package/dist/server/.next/server/chunks/[root-of-the-server]__09914a79._.js.map +0 -1
- package/dist/server/.next/server/chunks/[root-of-the-server]__42bc7b42._.js.map +0 -1
- package/dist/server/.next/server/chunks/[root-of-the-server]__4dc677cb._.js.map +0 -1
- package/dist/server/.next/server/chunks/[root-of-the-server]__52d487d8._.js +0 -5
- package/dist/server/.next/server/chunks/[root-of-the-server]__52d487d8._.js.map +0 -1
- package/dist/server/.next/server/chunks/[root-of-the-server]__616d1a09._.js +0 -3
- package/dist/server/.next/server/chunks/[root-of-the-server]__616d1a09._.js.map +0 -1
- package/dist/server/.next/server/chunks/[root-of-the-server]__66ca8d3f._.js +0 -11
- package/dist/server/.next/server/chunks/[root-of-the-server]__66ca8d3f._.js.map +0 -1
- package/dist/server/.next/server/chunks/[root-of-the-server]__a6211ee0._.js.map +0 -1
- package/dist/server/.next/server/chunks/[root-of-the-server]__aca25fcf._.js.map +0 -1
- package/dist/server/.next/server/chunks/[root-of-the-server]__be3de126._.js.map +0 -1
- package/dist/server/.next/server/chunks/[root-of-the-server]__da89e112._.js.map +0 -1
- package/dist/server/.next/server/chunks/[root-of-the-server]__e07d75ff._.js.map +0 -1
- package/dist/server/.next/server/chunks/[root-of-the-server]__e301c560._.js.map +0 -1
- package/dist/server/.next/server/chunks/[root-of-the-server]__ef09a48e._.js.map +0 -1
- package/dist/server/.next/server/chunks/ssr/[root-of-the-server]__6d393273._.js +0 -3
- package/dist/server/.next/server/chunks/ssr/_bb352729._.js.map +0 -1
- package/dist/server/.next/server/chunks/ssr/packages_server_src_app_layout_tsx_0712e1b4._.js +0 -3
- package/dist/server/.next/server/chunks/ssr/packages_server_src_app_layout_tsx_0712e1b4._.js.map +0 -1
- package/dist/server/.next/static/chunks/344b0062191ace22.css.map +0 -1
- package/dist/server/.next/static/chunks/6c91d5f280e79a14.css +0 -3
- package/dist/server/.next/static/chunks/700389bfed628512.js +0 -61
- package/dist/server/.next/static/chunks/8d4c1c4e33fc41f3.js.map +0 -1
- /package/dist/server/.next/server/chunks/ssr/{[root-of-the-server]__6d393273._.js.map → [root-of-the-server]__e3a2aebd._.js.map} +0 -0
- /package/dist/server/.next/static/{cNaVG6i0DQd1B_k41f9v_ → 49cZ1UWtOwiNisWunvj9J}/_buildManifest.js +0 -0
- /package/dist/server/.next/static/{cNaVG6i0DQd1B_k41f9v_ → 49cZ1UWtOwiNisWunvj9J}/_clientMiddlewareManifest.json +0 -0
- /package/dist/server/.next/static/{cNaVG6i0DQd1B_k41f9v_ → 49cZ1UWtOwiNisWunvj9J}/_ssgManifest.js +0 -0
|
@@ -1,4 +1,4 @@
|
|
|
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"))},
|
|
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"))},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"))},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}({})},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}.cjs`);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.cjs"),x=!1;try{await o.promises.access(f),console.log(`setting.cjs文件已存在: ${f}`)}catch{let e=`module.exports = {
|
|
2
2
|
// 当前场景名称
|
|
3
3
|
currentSite: '${u}',
|
|
4
4
|
// 开启Mock的场景列表
|
|
@@ -15,4 +15,4 @@ module.exports={83886:function(e){var{g:t,__dirname:s,m:r,e:o}=e;r.exports=e.x("
|
|
|
15
15
|
open: ${JSON.stringify(e)}
|
|
16
16
|
};`;await o.promises.writeFile(j,t,"utf-8")}}catch(e){console.warn("更新setting.cjs失败:",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}.cjs`)}})}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
17
|
|
|
18
|
-
//# sourceMappingURL=%5Broot-of-the-server%
|
|
18
|
+
//# sourceMappingURL=%5Broot-of-the-server%5D__2ba93285._.js.map
|
|
@@ -1 +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}.cjs`);\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.cjs不存在,则创建setting.cjs\n const settingFilePath = join(methodPath, 'setting.cjs');\n let settingCreated = false;\n try {\n await fs.access(settingFilePath);\n console.log(`setting.cjs文件已存在: ${settingFilePath}`);\n } catch {\n // setting.cjs不存在,创建它\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.cjs文件创建成功: ${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}.cjs`),\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.cjs文件内容\n let setting: { currentSite?: string; [key: string]: unknown } | undefined;\n const settingFilePath = join(methodPath, 'setting.cjs');\n try {\n await fs.access(settingFilePath);\n // 使用require直接导入setting.cjs\n const resolvedPath = resolve(settingFilePath);\n delete require.cache[resolvedPath];\n setting = require(resolvedPath);\n } catch (error) {\n // setting.cjs文件不存在或读取失败,忽略\n console.warn(`读取setting.cjs失败: ${settingFilePath}`, error);\n }\n \n const methodFiles = files\n .filter(file => file.isFile() && file.name.endsWith('.cjs') && file.name !== 'setting.cjs')\n .map(file => ({\n siteName: file.name.replace('.cjs', ''),\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}.cjs`);\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 // 过滤出.cjs文件(排除setting.cjs)\n const scenarioFiles = methodFiles.filter(file => file.endsWith('.cjs') && file !== 'setting.cjs');\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.cjs中的currentSite\n const settingFilePath = join(methodPath, 'setting.cjs');\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('.cjs') && file !== 'setting.cjs');\n \n if (remainingScenarios.length > 0) {\n // 选择第一个剩余的场景作为新的当前场景\n const newCurrentSite = remainingScenarios[0].replace('.cjs', '');\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.cjs失败:', 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}.cjs`),\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]}
|
|
1
|
+
{"version":3,"sources":["turbopack:///[project]/packages/server/src/lib/workspace-types.ts","turbopack:///[project]/packages/server/src/lib/workspace-config.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 { 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 { 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 { 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}.cjs`);\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.cjs不存在,则创建setting.cjs\n const settingFilePath = join(methodPath, 'setting.cjs');\n let settingCreated = false;\n try {\n await fs.access(settingFilePath);\n console.log(`setting.cjs文件已存在: ${settingFilePath}`);\n } catch {\n // setting.cjs不存在,创建它\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.cjs文件创建成功: ${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}.cjs`),\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.cjs文件内容\n let setting: { currentSite?: string; [key: string]: unknown } | undefined;\n const settingFilePath = join(methodPath, 'setting.cjs');\n try {\n await fs.access(settingFilePath);\n // 使用require直接导入setting.cjs\n const resolvedPath = resolve(settingFilePath);\n delete require.cache[resolvedPath];\n setting = require(resolvedPath);\n } catch (error) {\n // setting.cjs文件不存在或读取失败,忽略\n console.warn(`读取setting.cjs失败: ${settingFilePath}`, error);\n }\n \n const methodFiles = files\n .filter(file => file.isFile() && file.name.endsWith('.cjs') && file.name !== 'setting.cjs')\n .map(file => ({\n siteName: file.name.replace('.cjs', ''),\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}.cjs`);\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 // 过滤出.cjs文件(排除setting.cjs)\n const scenarioFiles = methodFiles.filter(file => file.endsWith('.cjs') && file !== 'setting.cjs');\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.cjs中的currentSite\n const settingFilePath = join(methodPath, 'setting.cjs');\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('.cjs') && file !== 'setting.cjs');\n \n if (remainingScenarios.length > 0) {\n // 选择第一个剩余的场景作为新的当前场景\n const newCurrentSite = remainingScenarios[0].replace('.cjs', '');\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.cjs失败:', 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}.cjs`),\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":"ubAAA,IAAA,EAAA,EAAA,CAAA,CAAA,OACA,EAAA,EAAA,CAAA,CAAA,OAKO,IAAM,EAAmB,CAE9B,eAAgB,CAAA,EAAA,EAAA,IAAA,AAAG,EAAE,CAAA,EAAA,EAAA,OAAA,AAAM,IAAK,YAAa,EAA7B,WAAK,MAGrB,YAAa,IAGb,sBAAuB,KAAK,GAAG,CAAC,EAAG,KAAK,GAAG,CAAC,CAAA,EAAA,EAAA,IAAA,AAAG,IAAI,MAAM,CAAE,IAG3D,iBAH4C,EAGxB,CACtB,EAEa,EAAsB,CAAA,EAAA,EAAA,IAAA,AAAG,EAAE,CAAA,EAAA,EAAA,OAAA,AAAM,IAAK,cAAhB,UA2B5B,CA3BiC,GA2B5B,EAAA,SAAA,CAAA,6JAAA,s3CC/CZ,IAAA,EAAA,EAAA,CAAA,CAAA,MAEA,EAAA,EAAA,CAAA,CAAA,OAMO,eAAe,IACpB,GAAI,CACF,MAAM,CAAA,EAAA,EAAA,MAAA,AAAK,EAAE,EAAA,mBAAmB,CAAE,EAAA,GAA5B,MAAqC,CAAC,IAAI,AAAnC,CACf,CAAE,KAAM,CAGN,OADA,MAHkC,AAG5B,EAAmB,CAAC,GACnB,CAAC,CACV,CAEA,GAAI,CACF,IAAM,EAAgB,MAAM,CAAA,EAAA,EAAA,QAAA,AAAO,EAAE,EAAA,mBAAmB,CAAE,GAA9B,MAE5B,GAAI,CAAC,EACH,CAHmC,KAG5B,CAAC,EAEV,IAHoB,GAGb,KAAK,KAAK,CAAC,EACpB,CAAE,MAAO,EAAO,CAGd,MAFA,QAAQ,KAAK,CAAC,iBAAkB,GAE1B,AAAI,MAAM,WAClB,CACF,CAMO,eAAe,EAAmB,CAAsB,EAC7D,IAAM,EAAiB,EAAA,mBAAmB,CAAG,OAC7C,GAAI,CACF,KAFqB,CAEf,CAAA,EAAA,EAAA,SAAA,AAAQ,EAAE,EAAgB,KAAK,SAAS,CAAC,EAAQ,KAAjD,AAAuD,GAAI,SACjE,MAAM,CAAA,EAAA,EAAA,MAAA,AAAK,EAAE,EAAgB,EAAA,mBAAmB,CAClD,CAAE,EADM,IACC,EAAO,CAEd,MADA,AAF6B,QAErB,KAAK,CAAC,cAAe,GACvB,AAAI,MAAM,WAClB,CACF,CAKO,IAAK,EAAA,SAAA,CAAA,mIAAA,kPCjDZ,IAAA,EAAA,EAAA,CAAA,CAAA,OACA,EAAA,EAAA,CAAA,CAAA,OACA,EAAA,EAAA,CAAA,CAAA,OACA,EAAA,EAAA,CAAA,CAAA,OACA,EAAA,EAAA,CAAA,CAAA,OAEA,IAAM,EAAU,CAAA,EAAA,AADhB,EAAA,CAAA,CAAA,OACgB,aAAA,AAAY,EAAE,YAAd,yEAA0B,GAAG,EAEtC,eAAe,EAAK,CAAoB,EAC7C,GAAI,CAEF,GAAM,aAAE,CAAW,SAAE,CAAO,QAAE,CAAM,UAAE,CAAQ,CAAE,SAAO,CAAE,CAAG,MAAM,EAAQ,IAAI,GAG9E,GAAI,CAAC,GAAe,CAAC,GAAW,CAAC,GAAU,CAAC,GAAY,KAAY,MAClE,KAD6E,EACtE,EAAA,YAAY,CAAC,IAAI,CACtB,CACE,SAAS,EACT,MAAO,AAHJ,wDAIL,EACA,CAAE,OAAQ,GAAI,GAMlB,GAAI,CADmB,AAClB,OADwB,CAAA,EAAA,EAAA,iBAAgB,AAAhB,GAAgB,CAC1B,CAAC,EAAY,CAC9B,CADgC,MACzB,EAAA,EAFoB,UAER,CAAC,IAAI,CACtB,CAAE,SAAS,EAAO,MADb,AACoB,CAAC,GAAG,EAAE,EAAY,IAAI,CAAC,AAAC,EACjD,CAAE,OAAQ,GAAI,GAKlB,IAAM,EAAc,CAAA,EAAA,EAAA,IAAA,AAAG,EAAE,EAAA,gBAAgB,CAAC,WAAtB,GAAoC,CAAE,GACpD,CADmB,CACR,CAAA,EAAA,EAAA,IAAA,AAAG,EAAE,EAAa,SAC7B,EAAU,CAAA,EAAA,EAAA,IAAG,AAAH,EAAK,EAAU,GACzB,CAFW,CAEE,CAAA,EAAA,EAAA,IAAA,AAAG,EAAE,EAAS,EAAO,QADxB,GACmC,IAC7C,EAAW,CAAA,EAAA,EAAA,IADE,AACF,AAAG,EAAE,EAAY,CAAA,EAAG,EAAS,IAAI,CAAC,EAGnD,GAAI,CACF,MAAM,EAAA,IAJS,IAIP,CAAC,MAAM,CAAC,EAClB,CAAE,KAAM,CACN,OAAO,EAAA,EAFD,UAEa,CAAC,IAAI,CACtB,CAAE,SAAS,EAAO,MADb,AACoB,CAAC,KAAK,EAAE,EAAY,IAAI,CAAC,AAAC,EACnD,CAAE,OAAQ,GAAI,EAElB,CAGA,GAAI,CACF,MAAM,EAAA,QAAE,CAAC,MAAM,CAAC,EAClB,CAAE,KAAM,CACN,MAAM,EAAA,GAFA,KAEE,CAAC,KAAK,CAAC,EAAU,CAAE,WAAW,CAAK,EAC7C,CAGA,GAAI,AAJI,CAKN,MAAM,EAAA,QAAE,CAAC,MAAM,CAAC,EAClB,CAAE,KAAM,CACN,MAAM,EAAA,GAFA,KAEE,CAAC,KAAK,CAAC,EAAS,CAAE,WAAW,CAAK,EAC5C,CAGA,GAAI,AAJI,CAKN,MAAM,EAAA,QAAE,CAAC,MAAM,CAAC,EAClB,CAAE,KAAM,CACN,MAAM,EAAA,GAFA,KAEE,CAAC,KAAK,CAAC,EAAY,CAAE,UAAW,EAAK,EAC/C,CAGA,GAJQ,CAIF,EAAkB,CAAA,EAAA,EAAA,IAAA,AAAG,EAAE,EAAY,eACrC,GAAiB,EACrB,GAAI,CACF,IAHsB,EAGhB,EAAA,QAAE,CAAC,MAAM,CAAC,GAChB,QAAQ,GAAG,CAAC,CAAC,IADP,cACyB,EAAE,EAAA,CAAiB,CACpD,CAAE,KAAM,CAEN,IAAM,EAAiB,CAAC;;gBAEd,EAAE,EAAS;;UAEjB,EAAE,EAAS;EACnB,CAAC,AACG,OAAM,EAAA,QAAE,CAAC,SAAS,CAAC,EAAiB,EAAgB,SACpD,GAAiB,CADX,CAEN,QAAQ,GAAG,CAAC,CAAC,mBAAmB,EAAE,EAAA,CAAiB,CACrD,CAKA,OAFA,MAAM,EAAA,QAAE,CAAC,SAAS,CAAC,EAAU,EAAS,SAE/B,EAAA,EAFD,UAEa,CAAC,IAAI,CAAC,CACvB,SAAS,EACT,MAFK,EAEI,aACT,KAAM,aACJ,UACA,EACA,OAAQ,EAAO,WAAW,YAC1B,EACA,SAAU,CAAA,EAAA,EAAA,IAAA,AAAG,EAAE,QAAS,EAAS,EAAO,WAAW,GAAI,CAAA,EAAG,CAAhD,CAAyD,IAAI,CAAC,iBACxE,EACA,UAAW,IAAI,OAAO,WAAW,EACnC,CACF,EACF,CAAE,MAAO,EAAO,CACd,IAAM,EAAe,aAAiB,MAAQ,EAAM,OAAO,CAAG,aAE9D,OADA,QAAQ,KAAK,CAAC,cAAe,GACtB,EAAA,YAAY,CAAC,IAAI,CACtB,CAAE,QAAS,GAAO,MAAO,AADpB,CACiC,EACtC,CAAE,OAAQ,GAAI,EAElB,CACF,CAEO,eAAe,EAAI,CAAoB,EAC5C,GAAI,CACF,GAAM,cAAE,CAAY,CAAE,CAAG,IAAI,IAAI,EAAQ,GAAG,EACtC,EAAc,EAAa,GAAG,CAAC,WAErC,GAAI,CAAC,EACH,OAAO,EAAA,EADS,UACG,CAAC,IAAI,CACtB,CAAE,SAAS,EAAO,MADb,AACoB,UAAW,EACpC,CAAE,OAAQ,GAAI,GAMlB,GAAI,CAAC,CADkB,MAAM,CAAA,EAAA,EAAA,iBAAA,AAAgB,GAAA,CAC1B,CAAC,EAAY,CAC9B,CADgC,MACzB,EAAA,EAFoB,UAER,CAAC,IAAI,CACtB,CAAE,SAAS,EAAO,MADb,AACoB,CAAC,GAAG,EAAE,EAAY,IAAI,CAAC,AAAC,EACjD,CAAE,OAAQ,GAAI,GAKlB,IAAM,EAAc,CAAA,EAAA,EAAA,IAAA,AAAG,EAAE,EAAA,gBAAgB,CAAC,WAAtB,GAAoC,CAAE,GACpD,CADmB,CACR,CAAA,EAAA,EAAA,IAAA,AAAG,EAAE,EAAa,SAGnC,GAAI,CACF,MAAM,EAAA,OAJS,CAIP,CAAC,MAAM,CAAC,EAClB,CAAE,KAAM,CACN,OAAO,EAAA,EAFD,UAEa,CAAC,IAAI,CAAC,CACvB,SAAS,EACT,KAAM,CAFD,YAGH,EACA,UAAW,EAAE,AACf,EACA,QAAS,iBACX,EACF,CAGA,IAAM,EAcD,EAAE,CAIP,IAAK,IAAM,IAFK,MAEK,CAFC,EAAA,KAEQ,GAFN,CAAC,OAAO,CAAC,EAAU,CAAE,eAAe,CAAK,AAA3C,EAA2C,EAG/D,GAAI,EAAO,WAAW,GAAI,CACxB,IAAM,EAAU,GAAA,EAAA,IAAA,AAAG,EAAE,EAAU,EAAO,IAAI,EACpC,EAAa,MAAM,EAAA,QAAE,CAAC,CADZ,MACmB,CAAC,EAAS,CAAE,eAAe,CAAK,AAA1C,GAEnB,EAWD,EAAE,CAEP,IAAK,IAAM,KAAa,EACtB,GAAI,EAAU,IADoB,OACT,GAAI,CAC3B,IAII,EAJE,EAAa,CAAA,EAAA,EAAA,IAAA,AAAG,EAAE,EAAS,EAAU,IAAI,EACzC,EAAQ,MAAM,EAAA,QAAE,CAAC,CADJ,MACW,CAAC,EAAY,CAAE,cAAe,EAAxC,AAA6C,GAI3D,EAAkB,CAAA,EAAA,EAAA,IAAA,AAAG,EAAE,EAAY,eACzC,GAAI,CACF,MAAM,EAAA,CAFgB,OAEd,CAAC,MAAM,CAAC,GAEhB,IAAM,EAAe,CAAA,EAAA,EAAA,MAFf,CAEqB,AAAN,EAAQ,EAC7B,QAAO,EAAQ,KAAK,CAAC,EAAa,CAClC,EAAU,EAAQ,EAFG,AAGvB,CAAE,MAAO,EAAO,CAEd,QAAQ,IAAI,CAAC,CAAC,iBAAiB,EAAE,EAAA,CAAiB,CAAE,EACtD,CAEA,IAAM,EAAc,EACjB,MAAM,CAAC,GAAQ,EAAK,MAAM,IAAM,EAAK,IAAI,CAAC,QAAQ,CAAC,SAAyB,gBAAd,EAAK,IAAI,EACvE,GAAG,CAAC,IAAS,CACZ,EADW,OACD,EAAK,IAAI,CAAC,OAAO,CAAC,OAAQ,IACpC,SAAU,EAAK,IAAI,CACnB,SAAU,CAAA,EAAA,EAAA,IAAA,AAAG,EAAE,QAAS,EAAO,IAAI,CAAE,EAAU,IAAI,CAAE,EAAK,IAAI,EAApD,AACZ,CAAC,EAEC,EAAY,MAAM,CAAG,GACvB,AAD0B,EACf,IAAI,CAAC,CACd,OAAQ,EAAU,IAAI,SACtB,EACA,MAAO,CACT,EAEJ,CAGE,EAAW,MAAM,CAAG,GAAG,AACzB,EAAU,IAAI,CAAC,CACb,QAAS,EAAO,IAAI,CACpB,QAAS,CACX,EAEJ,CAGF,OAAO,EAAA,YAAY,CAAC,IAAI,CAAC,CACvB,QAAS,GACT,KAAM,CAFD,YAGH,YACA,CACF,EACA,QAAS,cACX,EACF,CAAE,MAAO,EAAO,CACd,IAAM,EAAe,aAAiB,MAAQ,EAAM,OAAO,CAAG,eAE9D,OADA,QAAQ,KAAK,CAAC,gBAAiB,GACxB,EAAA,YAAY,CAAC,IAAI,CACtB,CAAE,SAAS,EAAO,MADb,AACoB,CAAa,EACtC,CAAE,OAAQ,GAAI,EAElB,CACF,CAEO,eAAe,EAAO,CAAoB,EAC/C,GAAI,CACF,GAAM,cAAE,CAAY,CAAE,CAAG,IAAI,IAAI,EAAQ,GAAG,EACtC,EAAc,EAAa,GAAG,CAAC,WAC/B,EAAU,EAAa,GAAG,CAAC,WAC3B,EAAS,EAAa,GAAG,CAAC,UAC1B,EAAW,EAAa,GAAG,CAAC,YAElC,GAAI,CAAC,GAAe,CAAC,GAAW,CAAC,GAAU,CAAC,EAC1C,OAAO,CAD6C,CAC7C,YAAY,CAAC,IAAI,CACtB,CAAE,SAAS,EAAO,MAAO,AADpB,2CACgE,EACrE,CAAE,OAAQ,GAAI,GAMlB,GAAI,CAAC,CADkB,MAAM,CAAA,EAAA,EAAA,iBAAA,AAAgB,GAAA,CAC1B,CAAC,EAAY,CAC9B,CADgC,MACzB,EAAA,EAFoB,UAER,CAAC,IAAI,CACtB,CAAE,QAAS,GAAO,MAAO,AADpB,CACqB,GAAG,EAAE,EAAY,IAAI,CAAC,AAAC,EACjD,CAAE,OAAQ,GAAI,GAKlB,IAAM,EAAc,CAAA,EAAA,EAAA,IAAA,AAAG,EAAE,EAAA,gBAAgB,CAAC,WAAtB,GAAoC,CAAE,GACpD,CADmB,CACN,CAAA,EAAA,EAAA,IAAA,AAAG,EAAE,EAAa,QAAS,EAAS,EAAO,WAAW,IACnE,CADa,CACF,CAAA,EAAA,EAAA,IAAG,AAAH,EAAK,EAAY,CAAA,EAAG,EAAS,IAAI,CAAC,EAGnD,GAAI,CACF,MAAM,EAAA,IAJS,IAIP,CAAC,MAAM,CAAC,EAClB,CAAE,KAAM,CACN,OAAO,EAAA,EAFD,UAEa,CAAC,IAAI,CACtB,CAAE,SAAS,EAAO,MAAO,AADpB,WACgC,EACrC,CAAE,OAAQ,GAAI,EAElB,CAGA,GAAI,CAKF,GAFsB,AAElB,CAJgB,MAAM,EAAA,QAAE,CAAC,OAAO,CAAC,EAAA,EAEH,MAAM,CAAC,GAAQ,EAAK,GAF5B,KAEoC,CAAC,SAAW,AAAS,mBAEjE,MAAM,EAAI,EAC1B,CAD6B,MACtB,EAAA,YAAY,CAAC,IAAI,CACtB,CAAE,SAAS,EAAO,MAAO,AADpB,2BACgD,EACrD,CAAE,OAAQ,GAAI,EAGpB,CAAE,MAAO,EAAO,CAEd,OADA,QAAQ,KAAK,CAAC,YAAa,GACpB,EAAA,YAAY,CAAC,IAAI,CACtB,CAAE,QAAS,GAAO,MADb,AACoB,UAAW,EACpC,CAAE,OAAQ,GAAI,EAElB,CAGA,MAAM,EAAA,QAAE,CAAC,MAAM,CAAC,GAGhB,IAAM,EAAkB,CAAA,EAAA,EAAA,IAAA,AAAG,EAHrB,AAGuB,EAAY,eACzC,GAAI,CACF,MAAM,EAAA,CAFgB,OAEd,CAAC,MAAM,CAAC,GAEhB,IAAM,EAAe,CAAA,EAAA,EAAA,MAFf,CAEe,AAAM,EAAE,EAC7B,QAAO,EAAQ,KAAK,CAAC,EAAa,CAClC,IAAM,EAFe,AAEE,EAAQ,GAG/B,GAAI,EAAe,WAAW,GAAK,EAAU,CAE3C,IAAM,EAAqB,CADJ,MAAM,EAAA,QAAE,CAAC,OAAO,CAAC,EAAA,EACE,MAAM,CAAC,GAAQ,EAAK,GADjC,KACyC,CAAC,SAAoB,gBAAT,GAElF,GAAI,EAAmB,MAAM,CAAG,EAAG,CAEjC,IAAM,EAAiB,CAAkB,CAAC,EAAE,CAAC,OAAO,CAAC,OAAQ,IACvD,EAAU,EAAe,IAAI,CAAC,MAAM,CAAC,AAAC,GAAiB,IAAS,GAEhE,EAAoB,CAAC;;gBAErB,EAAE,EAAe;;QAEzB,EAAE,KAAK,SAAS,CAAC,SAAS;EAChC,CAAC,AAEO,OAAM,EAAA,QAAE,CAAC,SAAS,CAAC,EAAiB,EAAmB,QACzD,CACF,IAFU,CAEH,CAEL,IAAM,EAAU,EAAe,IAAI,CAAC,MAAM,CAAC,AAAC,GAAiB,IAAS,GAEhE,EAAoB,CAAC;;gBAEnB,EAAE,EAAe,WAAW,CAAC;;QAErC,EAAE,KAAK,SAAS,CAAC,SAAS;EAChC,CAAC,AAEK,OAAM,EAAA,QAAE,CAAC,SAAS,CAAC,EAAiB,EAAmB,QACzD,CACF,CAAE,GAFQ,GAED,EAAO,CACd,QAAQ,IAAI,CAAC,mBAAoB,EAEnC,CAEA,OAAO,EAAA,YAAY,CAAC,IAAI,CAAC,CACvB,QAAS,GACT,MAFK,EAEI,aACT,KAAM,aACJ,UACA,EACA,OAAQ,EAAO,WAAW,YAC1B,EACA,YAAa,CAAA,EAAA,EAAA,IAAA,AAAG,EAAE,QAAS,EAAS,EAAO,WAAW,GAAI,CAAA,EAAG,CAAhD,CAAyD,IAAI,CAAC,CAC7E,CACF,EACF,CAAE,MAAO,EAAO,CACd,IAAM,EAAe,aAAiB,MAAQ,EAAM,OAAO,CAAG,aAE9D,OADA,QAAQ,KAAK,CAAC,cAAe,GACtB,EAAA,YAAY,CAAC,IAAI,CACtB,CAAE,SAAS,EAAO,MADb,AACoB,CAAa,EACtC,CAAE,OAAQ,GAAI,EAElB,CACF,iKC/XA,IAAA,EAGO,EAAA,CAAA,AAFLA,CAEK,OACP,EAA0B,EAAyB,CAA1CC,AAA0C,CAAA,GAAA,EAH9B,EAIrB,CADkB,CAD2C,AAEnB,EAAA,CAAjCC,AAAiC,CAFnC,AAEmC,GADhB,CAC8C,GAExE,EAAwC,EAAA,CAAA,CAFjBC,AAEiB,EAA5BC,KAWZ,IAbkC,AAa5BC,EAAc,GAXM,CAWN,EAbsB,AAalBL,YAXgB,OAWhBA,CAAoB,CAC1CM,WAAY,CACVC,KAAMN,EAAAA,SAAAA,CAAUO,SAAS,CACzBC,KAAM,uBACNC,SAAU,iBACVC,SAAU,QACVC,WAAY,EACd,EACAC,iBAAkB,2DAClBC,iBAXF,CAA0B,WAYxBV,CACF,GAKM,kBAAEW,CAAgB,sBAAEC,CAAoB,aAAEC,CAAW,CAAE,CAAGZ,EAEhE,SAASH,IACP,MAAA,CAAA,EAAA,EAAOC,UAAAA,EAAY,kBACjBY,uBACAC,CACF,EACF","ignoreList":[3]}
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
module.exports={45935:function(e){var{g:t,__dirname:o,m:r,e:s}=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"))},29549:function(e){var{g:t,__dirname:o,m:r,e:s}=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:o,m:r,e:s}=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:o,m:r,e:s}=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:o,m:r,e:s}=e;r.exports=e.x("path",()=>require("path"))},23430:function(e){var{g:t,__dirname:o,m:r,e:s}=e;r.exports=e.x("next/dist/compiled/@opentelemetry/api",()=>require("next/dist/compiled/@opentelemetry/api"))},13442:function(e){var{g:t,__dirname:o,m:r,e:s}=e;r.exports=e.x("os",()=>require("os"))},52670:function(e){var{g:t,__dirname:o,m:r,e:s}=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:o,m:r,e:s}=e;r.exports=e.x("fs/promises",()=>require("fs/promises"))},87485:function(e){var{g:t,__dirname:o,m:r,e:s}=e;r.exports=e.x("child_process",()=>require("child_process"))},4713:function(e){var{g:t,__dirname:o,m:r,e:s}=e;r.exports=e.x("util",()=>require("util"))},70967:e=>{"use strict";var{g:t,__dirname:o}=e;{e.s({appendLog:()=>h,cleanupOldLogs:()=>g,deleteProcessLogs:()=>m,getLogsDirSize:()=>f,getProcessLogPath:()=>i,readLastNLines:()=>d,rotateLogFile:()=>u,startLogCleanupTask:()=>y,stopLogCleanupTask:()=>E,truncateLogLine:()=>c,writeLogsSync:()=>p});var r=e.i(9892),s=e.i(30331),n=e.i(13442);let t={MAX_FILE_SIZE:5242880,MAX_LOG_FILES:3,MAX_LOG_AGE_DAYS:7,MAX_LINE_LENGTH:1e3,CLEANUP_INTERVAL:18e5};function a(){return s.default.join(n.default.homedir(),".prime-process-logs")}function i(e){return s.default.join(a(),`${e}.log`)}function c(e){return e.length<=t.MAX_LINE_LENGTH?e:e.substring(0,t.MAX_LINE_LENGTH)+"... [truncated]"}async function l(e){try{return(await r.default.stat(e)).size}catch{return 0}}async function u(e){let o=i(e),s=await l(o);if(!(s<t.MAX_FILE_SIZE)){console.log(`[日志管理] 轮转日志文件: ${e}, 大小: ${(s/1024/1024).toFixed(2)}MB`);try{let s=`${o}.${t.MAX_LOG_FILES}`;try{await r.default.unlink(s)}catch{}for(let e=t.MAX_LOG_FILES-1;e>=1;e--){let t=1===e?o:`${o}.${e}`,s=`${o}.${e+1}`;try{await r.default.rename(t,s)}catch{}}await r.default.rename(o,`${o}.1`),await r.default.writeFile(o,"","utf-8"),console.log(`[日志管理] 日志轮转完成: ${e}`)}catch(t){console.error(`[日志管理] 轮转日志文件失败: ${e}`,t)}}}async function h(e,t){await u(e);let o=i(e),s=c(t);try{await r.default.mkdir(a(),{recursive:!0}),await r.default.appendFile(o,s+"\n","utf-8")}catch(t){console.error(`[日志管理] 追加日志失败: ${e}`,t)}}async function p(e,t){await u(e);let o=i(e),s=t.map(e=>c(e));try{await r.default.mkdir(a(),{recursive:!0}),await r.default.writeFile(o,s.join("\n")+"\n","utf-8")}catch(t){console.error(`[日志管理] 写入日志失败: ${e}`,t)}}async function d(e,t=100){let o=i(e);try{return(await r.default.readFile(o,"utf-8")).split("\n").filter(e=>e.trim()).slice(-t)}catch{return[]}}async function g(){console.log("[日志管理] 开始清理旧日志...");try{let e=a();try{await r.default.access(e)}catch{console.log("[日志管理] 日志目录不存在,无需清理");return}let o=await r.default.readdir(e),n=Date.now(),i=24*t.MAX_LOG_AGE_DAYS*36e5,c=0,l=0;for(let t of o){let o=s.default.join(e,t);try{let e=await r.default.stat(o);if(n-e.mtime.getTime()>i){l+=e.size;try{await r.default.unlink(o),c++,console.log(`[日志管理] 删除过期日志: ${t}`)}catch(e){e?.code!=="ENOENT"&&console.error(`[日志管理] 删除文件失败: ${t}`,e)}}}catch(e){e?.code!=="ENOENT"&&console.error(`[日志管理] 处理文件失败: ${t}`,e)}}console.log(`[日志管理] 清理完成: 删除 ${c} 个文件, 释放 ${(l/1024/1024).toFixed(2)}MB`)}catch(e){console.error("[日志管理] 清理日志失败:",e)}}async function m(e){let o=i(e);try{await r.default.unlink(o)}catch(t){t?.code!=="ENOENT"&&console.error(`[日志管理] 删除主日志文件失败: ${e}`,t)}for(let s=1;s<=t.MAX_LOG_FILES;s++)try{await r.default.unlink(`${o}.${s}`)}catch(t){t?.code!=="ENOENT"&&console.error(`[日志管理] 删除轮转日志文件失败: ${e}.${s}`,t)}console.log(`[日志管理] 删除进程日志: ${e}`)}async function f(){try{let e=a(),t=await r.default.readdir(e),o=0,n=0;for(let a of t)try{let t=await r.default.stat(s.default.join(e,a));o+=t.size,n++}catch{}return{totalSize:o,fileCount:n}}catch{return{totalSize:0,fileCount:0}}}let o=null;function y(){o||(console.log("[日志管理] 启动定期清理任务"),g(),o=setInterval(()=>{g()},t.CLEANUP_INTERVAL))}function E(){o&&(clearInterval(o),o=null,console.log("[日志管理] 停止定期清理任务"))}process.on("SIGINT",()=>{E()}),process.on("SIGTERM",()=>{E()})}},94722:e=>{"use strict";var{g:t,__dirname:o}=e;{e.s({sseConnectionManager:()=>o});class t{connections=new Map;encoder=new TextEncoder;heartbeatInterval=null;HEARTBEAT_INTERVAL=3e4;CONNECTION_TIMEOUT=12e4;MAX_CONNECTIONS_PER_ENV=10;constructor(){this.startHeartbeat()}clearAllConnections(){console.log("[SSE] 开始清理所有连接...");let e=Array.from(this.connections.values()).reduce((e,t)=>e+t.size,0);this.connections.forEach(e=>{e.forEach(e=>{try{e.controller.close()}catch{}})}),this.connections.clear(),console.log(`[SSE] 已清理 ${e} 个连接`)}addConnection(e,t,o){console.log(`[SSE] 添加连接: 环境=${e}, 客户端=${o}`),this.connections.has(e)||this.connections.set(e,new Set);let r=this.connections.get(e);if(r.size>=this.MAX_CONNECTIONS_PER_ENV){console.warn(`[SSE] 环境 ${e} 连接数已达上限,清理最旧的连接`);let t=Array.from(r).sort((e,t)=>e.timestamp-t.timestamp)[0];if(t){try{t.controller.close()}catch{}r.delete(t)}}let s={controller:t,timestamp:Date.now(),clientId:o,envName:e};r.add(s),this.sendToConnection(s,{type:"heartbeat",timestamp:Date.now()}),console.log(`[SSE] 当前连接统计: ${this.getConnectionStats()}`)}removeConnection(e,t){console.log(`[SSE] 移除连接: 环境=${e}, 客户端=${t}`);let o=this.connections.get(e);if(o){let r=Array.from(o).find(e=>e.clientId===t);r&&(o.delete(r),0===o.size&&this.connections.delete(e))}console.log(`[SSE] 当前连接统计: ${this.getConnectionStats()}`)}broadcastToEnv(e,t){console.log(`[SSE] 向环境 ${e} 广播配置变化消息`);let o=this.connections.get(e);if(!o||0===o.size)return void console.log(`[SSE] 环境 ${e} 没有活跃连接,跳过广播`);let r=[];o.forEach(e=>{try{this.sendToConnection(e,t)}catch(t){console.error(`[SSE] 发送消息到客户端 ${e.clientId} 失败:`,t),r.push(e)}}),r.forEach(e=>{o.delete(e),console.log(`[SSE] 清理无效连接: 客户端=${e.clientId}`)}),console.log(`[SSE] 成功发送给 ${o.size} 个连接`)}sendToConnection(e,t){let o=`data: ${JSON.stringify(t)}
|
|
2
|
+
|
|
3
|
+
`,r=this.encoder.encode(o);try{e.controller.enqueue(r),e.timestamp=Date.now()}catch(e){throw console.error(`[SSE] 发送消息失败:`,e),e}}startHeartbeat(){this.heartbeatInterval=setInterval(()=>{this.sendHeartbeat(),this.cleanupStaleConnections()},this.HEARTBEAT_INTERVAL),console.log(`[SSE] 心跳机制已启动,间隔: ${this.HEARTBEAT_INTERVAL}ms`)}sendHeartbeat(){let e={type:"heartbeat",timestamp:Date.now()},t=0;this.connections.forEach(o=>{t+=o.size;let r=[];o.forEach(t=>{try{this.sendToConnection(t,e)}catch{r.push(t)}}),r.forEach(e=>o.delete(e))}),t>0&&console.log(`[SSE] 心跳发送完成,活跃连接数: ${t}`)}cleanupStaleConnections(){let e=Date.now(),t=0;this.connections.forEach((o,r)=>{let s=[];o.forEach(t=>{e-t.timestamp>this.CONNECTION_TIMEOUT&&s.push(t)}),s.forEach(e=>{o.delete(e),t++,console.log(`[SSE] 清理过期连接: 环境=${r}, 客户端=${e.clientId}`)}),0===o.size&&this.connections.delete(r)}),t>0&&console.log(`[SSE] 连接清理完成,清理数量: ${t}`)}getConnectionStats(){let e=[],t=0;return this.connections.forEach((o,r)=>{let s=o.size;t+=s,e.push(`${r}: ${s}`)}),`总计 ${t} 个连接 (${e.join(", ")})`}stop(){this.heartbeatInterval&&(clearInterval(this.heartbeatInterval),this.heartbeatInterval=null,console.log(`[SSE] 心跳机制已停止`)),this.connections.forEach(e=>{e.forEach(e=>{try{e.controller.close()}catch(e){console.error(`[SSE] 关闭连接失败:`,e)}})}),this.connections.clear(),console.log(`[SSE] 所有连接已关闭`)}}let o=new t;process.on("SIGINT",()=>{console.log("[SSE] 收到退出信号,正在清理连接..."),o.stop(),process.exit(0)}),process.on("SIGTERM",()=>{console.log("[SSE] 收到终止信号,正在清理连接..."),o.stop(),process.exit(0)})}},71034:function(e){var{g:t,__dirname:o,m:r,e:s}=e},20248:e=>{"use strict";var{g:t,__dirname:o}=e;{e.s({memoryMonitor:()=>n});var r=e.i(87485);let o=(0,e.i(4713).promisify)(r.exec),s={warningMB:512,criticalMB:1024,heapUsagePercent:90},n=new class{monitorTimer=null;thresholds;cleanupCallbacks=[];lastWarningTime=0;warningCooldown=3e5;constructor(e={}){this.thresholds={...s,...e}}registerCleanupCallback(e){this.cleanupCallbacks.push(e)}async getSystemMemory(){try{{let{stdout:e}=await o(`ps -o rss= -g ${process.pid}`),t=e.trim().split("\n").reduce((e,t)=>{let o=parseInt(t.trim());return e+(isNaN(o)?0:o)},0);return 1024*t}}catch{}return 0}getMemoryUsage(){let e=process.memoryUsage();return{rss:e.rss,heapTotal:e.heapTotal,heapUsed:e.heapUsed,external:e.external,arrayBuffers:e.arrayBuffers}}async getFullMemoryUsage(){let e=this.getMemoryUsage(),t=await this.getSystemMemory();return{...e,systemTotal:t>0?t:void 0}}formatBytes(e){return`${(e/1024/1024).toFixed(2)} MB`}async checkMemory(){let e=await this.getFullMemoryUsage(),t=e.rss/1024/1024,o=e.heapUsed/e.heapTotal*100,r=e.systemTotal?e.systemTotal/1024/1024:null,s={rss:this.formatBytes(e.rss),heapUsed:this.formatBytes(e.heapUsed),heapTotal:this.formatBytes(e.heapTotal),heapUsagePercent:`${o.toFixed(2)}%`};e.systemTotal&&(s.systemTotal=this.formatBytes(e.systemTotal)),console.log("[内存监控] 当前使用:",s);let n=r||t;if(n>=this.thresholds.criticalMB){console.error(`[内存监控] ⚠️ 内存使用达到临界值: ${n.toFixed(2)}MB`),await this.triggerCleanup("critical");return}if(n>=this.thresholds.warningMB||o>=this.thresholds.heapUsagePercent){let e=Date.now();e-this.lastWarningTime>this.warningCooldown&&(console.warn(`[内存监控] ⚠️ 内存使用较高: ${n.toFixed(2)}MB (堆使用率: ${o.toFixed(2)}%)`),this.lastWarningTime=e,await this.triggerCleanup("warning"))}}async triggerCleanup(e){console.log(`[内存监控] 开始 ${"critical"===e?"紧急":"常规"} 清理...`);let o=this.getMemoryUsage();for(let e of this.cleanupCallbacks)try{await e()}catch(e){console.error("[内存监控] 清理回调执行失败:",e)}t.gc?(t.gc(),console.log("[内存监控] 已触发垃圾回收")):"critical"===e&&console.warn("[内存监控] 垃圾回收不可用。启动 Node.js 时使用 --expose-gc 标志以启用手动垃圾回收");let r=this.getMemoryUsage(),s=(o.rss-r.rss)/1024/1024;console.log(`[内存监控] 清理完成,释放内存: ${s.toFixed(2)}MB`)}start(){if(this.monitorTimer)return void console.warn("[内存监控] 监控器已经在运行");console.log("[内存监控] 启动内存监控",{interval:`60秒`,thresholds:{warning:`${this.thresholds.warningMB}MB`,critical:`${this.thresholds.criticalMB}MB`,heapUsage:`${this.thresholds.heapUsagePercent}%`}}),this.checkMemory(),this.monitorTimer=setInterval(()=>{this.checkMemory()},6e4)}stop(){this.monitorTimer&&(clearInterval(this.monitorTimer),this.monitorTimer=null,console.log("[内存监控] 监控器已停止"))}async check(){return await this.checkMemory(),await this.getFullMemoryUsage()}};process.on("SIGINT",()=>{n.stop()}),process.on("SIGTERM",()=>{n.stop()})}},44691:e=>{"use strict";var{g:t,__dirname:o}=e;e.s({GET:()=>i,POST:()=>c});var r=e.i(15494),s=e.i(20248),n=e.i(70967),a=e.i(94722);async function i(){try{let e=await s.memoryMonitor.check(),t=await (0,n.getLogsDirSize)(),o={rss:`${(e.rss/1024/1024).toFixed(2)} MB`,heapUsed:`${(e.heapUsed/1024/1024).toFixed(2)} MB`,heapTotal:`${(e.heapTotal/1024/1024).toFixed(2)} MB`,heapUsagePercent:`${(e.heapUsed/e.heapTotal*100).toFixed(2)}%`,external:`${(e.external/1024/1024).toFixed(2)} MB`};return e.systemTotal&&(o.systemTotal=`${(e.systemTotal/1024/1024).toFixed(2)} MB`,o.note="systemTotal 包含所有子进程和相关资源"),r.NextResponse.json({success:!0,data:{memory:o,logs:{totalSize:`${(t.totalSize/1024/1024).toFixed(2)} MB`,fileCount:t.fileCount},connections:a.sseConnectionManager.getConnectionStats(),timestamp:new Date().toISOString()}})}catch(e){return r.NextResponse.json({success:!1,error:e instanceof Error?e.message:"获取内存状态失败"},{status:500})}}async function c(){try{return await s.memoryMonitor.check(),r.NextResponse.json({success:!0,message:"已触发内存检查和清理"})}catch(e){return r.NextResponse.json({success:!1,error:e instanceof Error?e.message:"触发清理失败"},{status:500})}}},74662:e=>{"use strict";var{g:t,__dirname:o}=e;{e.s({patchFetch:()=>i,routeModule:()=>t,serverHooks:()=>l,workAsyncStorage:()=>o,workUnitAsyncStorage:()=>c});var r=e.i(45746),s=e.i(93828),n=e.i(18250),a=e.i(44691);let t=new r.AppRouteRouteModule({definition:{kind:s.RouteKind.APP_ROUTE,page:"/api/memory-status/route",pathname:"/api/memory-status",filename:"route",bundlePath:""},resolvedPagePath:"[project]/packages/server/src/app/api/memory-status/route.ts",nextConfigOutput:"",userland:a}),{workAsyncStorage:o,workUnitAsyncStorage:c,serverHooks:l}=t;function i(){return(0,n.patchFetch)({workAsyncStorage:o,workUnitAsyncStorage:c})}}}};
|
|
4
|
+
|
|
5
|
+
//# sourceMappingURL=%5Broot-of-the-server%5D__2fcc7175._.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["turbopack:///[project]/packages/server/src/lib/log-manager.ts","turbopack:///[project]/packages/server/src/lib/sse-connection-manager.ts","turbopack:///[project]/packages/server/src/lib/memory-monitor.ts","turbopack:///[project]/packages/server/src/app/api/memory-status/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":["/**\n * 日志管理器 - 处理日志文件的轮转、清理和大小限制\n */\nimport fs from 'fs/promises';\nimport path from 'path';\nimport os from 'os';\n\n// 日志配置\nconst LOG_CONFIG = {\n MAX_FILE_SIZE: 5 * 1024 * 1024, // 5MB\n MAX_LOG_FILES: 3, // 保留最多 3 个日志文件\n MAX_LOG_AGE_DAYS: 7, // 日志保留 7 天\n MAX_LINE_LENGTH: 1000, // 单行最大长度\n CLEANUP_INTERVAL: 30 * 60 * 1000, // 30 分钟清理一次\n};\n\n// 获取日志目录\nfunction getLogDir(): string {\n return path.join(os.homedir(), '.prime-process-logs');\n}\n\n// 获取进程日志文件路径\nexport function getProcessLogPath(processKey: string): string {\n return path.join(getLogDir(), `${processKey}.log`);\n}\n\n// 截断过长的日志行\nexport function truncateLogLine(line: string): string {\n if (line.length <= LOG_CONFIG.MAX_LINE_LENGTH) {\n return line;\n }\n return line.substring(0, LOG_CONFIG.MAX_LINE_LENGTH) + '... [truncated]';\n}\n\n/**\n * 获取文件大小\n */\nasync function getFileSize(filePath: string): Promise<number> {\n try {\n const stats = await fs.stat(filePath);\n return stats.size;\n } catch {\n return 0;\n }\n}\n\n/**\n * 轮转日志文件\n * 当日志文件超过大小限制时,将其重命名并创建新文件\n */\nexport async function rotateLogFile(processKey: string): Promise<void> {\n const logPath = getProcessLogPath(processKey);\n const fileSize = await getFileSize(logPath);\n\n // 如果文件大小未超过限制,不需要轮转\n if (fileSize < LOG_CONFIG.MAX_FILE_SIZE) {\n return;\n }\n\n console.log(`[日志管理] 轮转日志文件: ${processKey}, 大小: ${(fileSize / 1024 / 1024).toFixed(2)}MB`);\n\n try {\n // 删除最旧的日志文件\n const oldestLogPath = `${logPath}.${LOG_CONFIG.MAX_LOG_FILES}`;\n try {\n await fs.unlink(oldestLogPath);\n } catch {\n // 文件不存在,忽略\n }\n\n // 轮转现有的日志文件\n for (let i = LOG_CONFIG.MAX_LOG_FILES - 1; i >= 1; i--) {\n const oldPath = i === 1 ? logPath : `${logPath}.${i}`;\n const newPath = `${logPath}.${i + 1}`;\n\n try {\n await fs.rename(oldPath, newPath);\n } catch {\n // 文件不存在,继续\n }\n }\n\n // 重命名当前日志文件\n await fs.rename(logPath, `${logPath}.1`);\n\n // 创建新的空日志文件\n await fs.writeFile(logPath, '', 'utf-8');\n\n console.log(`[日志管理] 日志轮转完成: ${processKey}`);\n } catch (error) {\n console.error(`[日志管理] 轮转日志文件失败: ${processKey}`, error);\n }\n}\n\n/**\n * 追加日志到文件\n * 如果文件过大,先进行轮转\n */\nexport async function appendLog(processKey: string, logLine: string): Promise<void> {\n // 先检查是否需要轮转\n await rotateLogFile(processKey);\n\n const logPath = getProcessLogPath(processKey);\n const truncatedLine = truncateLogLine(logLine);\n\n try {\n // 确保日志目录存在\n await fs.mkdir(getLogDir(), { recursive: true });\n\n // 追加日志\n await fs.appendFile(logPath, truncatedLine + '\\n', 'utf-8');\n } catch (error) {\n console.error(`[日志管理] 追加日志失败: ${processKey}`, error);\n }\n}\n\n/**\n * 批量写入日志(用于初始写入或同步)\n */\nexport async function writeLogsSync(processKey: string, logs: string[]): Promise<void> {\n await rotateLogFile(processKey);\n\n const logPath = getProcessLogPath(processKey);\n const truncatedLogs = logs.map(line => truncateLogLine(line));\n\n try {\n await fs.mkdir(getLogDir(), { recursive: true });\n await fs.writeFile(logPath, truncatedLogs.join('\\n') + '\\n', 'utf-8');\n } catch (error) {\n console.error(`[日志管理] 写入日志失败: ${processKey}`, error);\n }\n}\n\n/**\n * 读取日志文件的最后 N 行\n */\nexport async function readLastNLines(processKey: string, n: number = 100): Promise<string[]> {\n const logPath = getProcessLogPath(processKey);\n\n try {\n const content = await fs.readFile(logPath, 'utf-8');\n const lines = content.split('\\n').filter(line => line.trim());\n return lines.slice(-n);\n } catch {\n return [];\n }\n}\n\n/**\n * 清理旧的日志文件\n * 删除超过保留期限的日志文件\n */\nexport async function cleanupOldLogs(): Promise<void> {\n console.log('[日志管理] 开始清理旧日志...');\n\n try {\n const logDir = getLogDir();\n\n // 确保目录存在\n try {\n await fs.access(logDir);\n } catch {\n console.log('[日志管理] 日志目录不存在,无需清理');\n return;\n }\n\n const files = await fs.readdir(logDir);\n const now = Date.now();\n const maxAge = LOG_CONFIG.MAX_LOG_AGE_DAYS * 24 * 60 * 60 * 1000;\n\n let deletedCount = 0;\n let freedSpace = 0;\n\n for (const file of files) {\n const filePath = path.join(logDir, file);\n\n try {\n const stats = await fs.stat(filePath);\n\n // 删除超过保留期的文件\n if (now - stats.mtime.getTime() > maxAge) {\n freedSpace += stats.size;\n try {\n await fs.unlink(filePath);\n deletedCount++;\n console.log(`[日志管理] 删除过期日志: ${file}`);\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n } catch (unlinkError: any) {\n // 如果文件已经不存在,忽略错误\n if (unlinkError?.code !== 'ENOENT') {\n console.error(`[日志管理] 删除文件失败: ${file}`, unlinkError);\n }\n }\n }\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n } catch (error: any) {\n // 如果文件不存在,跳过(可能已被删除)\n if (error?.code !== 'ENOENT') {\n console.error(`[日志管理] 处理文件失败: ${file}`, error);\n }\n }\n }\n\n console.log(`[日志管理] 清理完成: 删除 ${deletedCount} 个文件, 释放 ${(freedSpace / 1024 / 1024).toFixed(2)}MB`);\n } catch (error) {\n console.error('[日志管理] 清理日志失败:', error);\n }\n}\n\n/**\n * 删除指定进程的所有日志文件\n */\nexport async function deleteProcessLogs(processKey: string): Promise<void> {\n const logPath = getProcessLogPath(processKey);\n\n try {\n // 删除主日志文件\n await fs.unlink(logPath);\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n } catch (error: any) {\n // 文件不存在,忽略\n if (error?.code !== 'ENOENT') {\n console.error(`[日志管理] 删除主日志文件失败: ${processKey}`, error);\n }\n }\n\n // 删除轮转的日志文件\n for (let i = 1; i <= LOG_CONFIG.MAX_LOG_FILES; i++) {\n try {\n await fs.unlink(`${logPath}.${i}`);\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n } catch (error: any) {\n // 文件不存在,忽略\n if (error?.code !== 'ENOENT') {\n console.error(`[日志管理] 删除轮转日志文件失败: ${processKey}.${i}`, error);\n }\n }\n }\n\n console.log(`[日志管理] 删除进程日志: ${processKey}`);\n}\n\n/**\n * 获取日志目录的总大小\n */\nexport async function getLogsDirSize(): Promise<{ totalSize: number; fileCount: number }> {\n try {\n const logDir = getLogDir();\n const files = await fs.readdir(logDir);\n\n let totalSize = 0;\n let fileCount = 0;\n\n for (const file of files) {\n try {\n const stats = await fs.stat(path.join(logDir, file));\n totalSize += stats.size;\n fileCount++;\n } catch {\n // 忽略错误\n }\n }\n\n return { totalSize, fileCount };\n } catch {\n return { totalSize: 0, fileCount: 0 };\n }\n}\n\n// 定期清理任务\nlet cleanupTimer: NodeJS.Timeout | null = null;\n\n/**\n * 启动定期清理任务\n */\nexport function startLogCleanupTask(): void {\n if (cleanupTimer) {\n return; // 已经启动\n }\n\n console.log('[日志管理] 启动定期清理任务');\n\n // 立即执行一次\n cleanupOldLogs();\n\n // 设置定期清理\n cleanupTimer = setInterval(() => {\n cleanupOldLogs();\n }, LOG_CONFIG.CLEANUP_INTERVAL);\n}\n\n/**\n * 停止定期清理任务\n */\nexport function stopLogCleanupTask(): void {\n if (cleanupTimer) {\n clearInterval(cleanupTimer);\n cleanupTimer = null;\n console.log('[日志管理] 停止定期清理任务');\n }\n}\n\n// 进程退出时停止清理任务\nprocess.on('SIGINT', () => {\n stopLogCleanupTask();\n});\n\nprocess.on('SIGTERM', () => {\n stopLogCleanupTask();\n});\n\n","/**\n * SSE连接管理器\n * 用于管理MicroApp代理配置变化推送的SSE连接\n */\n\nexport interface ConnectionInfo {\n controller: ReadableStreamDefaultController<Uint8Array>;\n timestamp: number;\n clientId: string;\n envName: string;\n}\n\nexport interface ConfigChangeMessage {\n type: 'microapp-proxy-config-change';\n envName: string;\n timestamp: number;\n changes: {\n before: string[];\n after: string[];\n added: string[];\n removed: string[];\n };\n projectName: string;\n message: string;\n}\n\nexport interface HeartbeatMessage {\n type: 'heartbeat';\n timestamp: number;\n}\n\ntype SSEMessage = ConfigChangeMessage | HeartbeatMessage;\n\n/**\n * SSE连接管理器类\n */\nclass SSEConnectionManager {\n private connections = new Map<string, Set<ConnectionInfo>>();\n private encoder = new TextEncoder();\n private heartbeatInterval: NodeJS.Timeout | null = null;\n private readonly HEARTBEAT_INTERVAL = 30000; // 30秒心跳\n private readonly CONNECTION_TIMEOUT = 120000; // 2分钟连接超时\n private readonly MAX_CONNECTIONS_PER_ENV = 10; // 每个环境最多10个连接\n\n constructor() {\n this.startHeartbeat();\n }\n \n /**\n * 清理所有连接(用于内存清理)\n */\n clearAllConnections(): void {\n console.log('[SSE] 开始清理所有连接...');\n const totalConnections = Array.from(this.connections.values()).reduce((sum, set) => sum + set.size, 0);\n \n this.connections.forEach((connections) => {\n connections.forEach(conn => {\n try {\n conn.controller.close();\n } catch {\n // 忽略关闭错误\n }\n });\n });\n \n this.connections.clear();\n console.log(`[SSE] 已清理 ${totalConnections} 个连接`);\n }\n\n /**\n * 添加新的SSE连接\n */\n addConnection(envName: string, controller: ReadableStreamDefaultController<Uint8Array>, clientId: string): void {\n console.log(`[SSE] 添加连接: 环境=${envName}, 客户端=${clientId}`);\n \n if (!this.connections.has(envName)) {\n this.connections.set(envName, new Set());\n }\n \n const connections = this.connections.get(envName)!;\n \n // 检查连接数限制\n if (connections.size >= this.MAX_CONNECTIONS_PER_ENV) {\n console.warn(`[SSE] 环境 ${envName} 连接数已达上限,清理最旧的连接`);\n // 找到最旧的连接并关闭\n const oldestConn = Array.from(connections).sort((a, b) => a.timestamp - b.timestamp)[0];\n if (oldestConn) {\n try {\n oldestConn.controller.close();\n } catch {\n // 忽略关闭错误\n }\n connections.delete(oldestConn);\n }\n }\n \n const connectionInfo: ConnectionInfo = {\n controller,\n timestamp: Date.now(),\n clientId,\n envName,\n };\n \n connections.add(connectionInfo);\n \n // 发送连接确认消息\n this.sendToConnection(connectionInfo, {\n type: 'heartbeat',\n timestamp: Date.now(),\n });\n\n console.log(`[SSE] 当前连接统计: ${this.getConnectionStats()}`);\n }\n\n /**\n * 移除SSE连接\n */\n removeConnection(envName: string, clientId: string): void {\n console.log(`[SSE] 移除连接: 环境=${envName}, 客户端=${clientId}`);\n \n const connections = this.connections.get(envName);\n if (connections) {\n const connectionToRemove = Array.from(connections).find(conn => conn.clientId === clientId);\n if (connectionToRemove) {\n connections.delete(connectionToRemove);\n \n // 如果该环境没有连接了,删除整个entry\n if (connections.size === 0) {\n this.connections.delete(envName);\n }\n }\n }\n\n console.log(`[SSE] 当前连接统计: ${this.getConnectionStats()}`);\n }\n\n /**\n * 向指定环境广播消息\n */\n broadcastToEnv(envName: string, message: ConfigChangeMessage): void {\n console.log(`[SSE] 向环境 ${envName} 广播配置变化消息`);\n \n const connections = this.connections.get(envName);\n if (!connections || connections.size === 0) {\n console.log(`[SSE] 环境 ${envName} 没有活跃连接,跳过广播`);\n return;\n }\n\n const deadConnections: ConnectionInfo[] = [];\n \n connections.forEach(connectionInfo => {\n try {\n this.sendToConnection(connectionInfo, message);\n } catch (error) {\n console.error(`[SSE] 发送消息到客户端 ${connectionInfo.clientId} 失败:`, error);\n deadConnections.push(connectionInfo);\n }\n });\n\n // 清理无效连接\n deadConnections.forEach(conn => {\n connections.delete(conn);\n console.log(`[SSE] 清理无效连接: 客户端=${conn.clientId}`);\n });\n\n console.log(`[SSE] 成功发送给 ${connections.size} 个连接`);\n }\n\n /**\n * 向单个连接发送消息\n */\n private sendToConnection(connectionInfo: ConnectionInfo, message: SSEMessage): void {\n const data = `data: ${JSON.stringify(message)}\\n\\n`;\n const encodedData = this.encoder.encode(data);\n \n try {\n connectionInfo.controller.enqueue(encodedData);\n connectionInfo.timestamp = Date.now(); // 更新最后活跃时间\n } catch (error) {\n console.error(`[SSE] 发送消息失败:`, error);\n throw error;\n }\n }\n\n /**\n * 启动心跳机制\n */\n private startHeartbeat(): void {\n this.heartbeatInterval = setInterval(() => {\n this.sendHeartbeat();\n this.cleanupStaleConnections();\n }, this.HEARTBEAT_INTERVAL);\n \n console.log(`[SSE] 心跳机制已启动,间隔: ${this.HEARTBEAT_INTERVAL}ms`);\n }\n\n /**\n * 发送心跳消息\n */\n private sendHeartbeat(): void {\n const heartbeatMessage: HeartbeatMessage = {\n type: 'heartbeat',\n timestamp: Date.now(),\n };\n\n let totalConnections = 0;\n this.connections.forEach((connections) => {\n totalConnections += connections.size;\n const deadConnections: ConnectionInfo[] = [];\n \n connections.forEach(connectionInfo => {\n try {\n this.sendToConnection(connectionInfo, heartbeatMessage);\n } catch {\n deadConnections.push(connectionInfo);\n }\n });\n\n // 清理无效连接\n deadConnections.forEach(conn => connections.delete(conn));\n });\n\n if (totalConnections > 0) {\n console.log(`[SSE] 心跳发送完成,活跃连接数: ${totalConnections}`);\n }\n }\n\n /**\n * 清理过期连接\n */\n private cleanupStaleConnections(): void {\n const now = Date.now();\n let cleanedCount = 0;\n\n this.connections.forEach((connections, envName) => {\n const staleConnections: ConnectionInfo[] = [];\n \n connections.forEach(connectionInfo => {\n if (now - connectionInfo.timestamp > this.CONNECTION_TIMEOUT) {\n staleConnections.push(connectionInfo);\n }\n });\n\n staleConnections.forEach(conn => {\n connections.delete(conn);\n cleanedCount++;\n console.log(`[SSE] 清理过期连接: 环境=${envName}, 客户端=${conn.clientId}`);\n });\n\n // 如果该环境没有连接了,删除整个entry\n if (connections.size === 0) {\n this.connections.delete(envName);\n }\n });\n\n if (cleanedCount > 0) {\n console.log(`[SSE] 连接清理完成,清理数量: ${cleanedCount}`);\n }\n }\n\n /**\n * 获取连接统计信息\n */\n getConnectionStats(): string {\n const stats: string[] = [];\n let totalConnections = 0;\n \n this.connections.forEach((connections, envName) => {\n const count = connections.size;\n totalConnections += count;\n stats.push(`${envName}: ${count}`);\n });\n\n return `总计 ${totalConnections} 个连接 (${stats.join(', ')})`;\n }\n\n /**\n * 停止连接管理器\n */\n stop(): void {\n if (this.heartbeatInterval) {\n clearInterval(this.heartbeatInterval);\n this.heartbeatInterval = null;\n console.log(`[SSE] 心跳机制已停止`);\n }\n\n // 关闭所有连接\n this.connections.forEach((connections) => {\n connections.forEach(connectionInfo => {\n try {\n connectionInfo.controller.close();\n } catch (error) {\n console.error(`[SSE] 关闭连接失败:`, error);\n }\n });\n });\n\n this.connections.clear();\n console.log(`[SSE] 所有连接已关闭`);\n }\n}\n\n// 创建全局实例\nexport const sseConnectionManager = new SSEConnectionManager();\n\n// 在进程退出时清理资源\nprocess.on('SIGINT', () => {\n console.log('[SSE] 收到退出信号,正在清理连接...');\n sseConnectionManager.stop();\n process.exit(0);\n});\n\nprocess.on('SIGTERM', () => {\n console.log('[SSE] 收到终止信号,正在清理连接...');\n sseConnectionManager.stop();\n process.exit(0);\n}); ","/**\n * 内存监控器 - 监控服务内存使用并在必要时触发清理\n */\nimport { exec } from 'child_process';\nimport { promisify } from 'util';\n\nconst execAsync = promisify(exec);\n\ninterface MemoryStats {\n rss: number; // 常驻集大小\n heapTotal: number; // 堆总大小\n heapUsed: number; // 已使用堆大小\n external: number; // C++ 对象大小\n arrayBuffers: number; // ArrayBuffer 大小\n systemTotal?: number; // 系统级总内存(包括子进程)\n}\n\ninterface MemoryThresholds {\n warningMB: number; // 警告阈值 (MB)\n criticalMB: number; // 临界阈值 (MB)\n heapUsagePercent: number; // 堆使用率阈值 (%)\n}\n\nconst DEFAULT_THRESHOLDS: MemoryThresholds = {\n warningMB: 512, // 512MB 时警告\n criticalMB: 1024, // 1GB 时紧急清理\n heapUsagePercent: 90, // 堆使用率 90% 时警告\n};\n\nconst MONITOR_INTERVAL = 60 * 1000; // 每分钟检查一次\n\nclass MemoryMonitor {\n private monitorTimer: NodeJS.Timeout | null = null;\n private thresholds: MemoryThresholds;\n private cleanupCallbacks: Array<() => Promise<void>> = [];\n private lastWarningTime = 0;\n private warningCooldown = 5 * 60 * 1000; // 5分钟警告冷却\n\n constructor(thresholds: Partial<MemoryThresholds> = {}) {\n this.thresholds = { ...DEFAULT_THRESHOLDS, ...thresholds };\n }\n\n /**\n * 注册清理回调函数\n * 当内存达到临界值时会调用这些函数\n */\n registerCleanupCallback(callback: () => Promise<void>): void {\n this.cleanupCallbacks.push(callback);\n }\n\n /**\n * 获取系统级总内存使用(包括子进程)\n */\n private async getSystemMemory(): Promise<number> {\n try {\n if (process.platform === 'darwin' || process.platform === 'linux') {\n // macOS/Linux: 使用 ps 命令获取进程组的总内存\n const { stdout } = await execAsync(`ps -o rss= -g ${process.pid}`);\n const lines = stdout.trim().split('\\n');\n const total = lines.reduce((sum, line) => {\n const rss = parseInt(line.trim());\n return sum + (isNaN(rss) ? 0 : rss);\n }, 0);\n return total * 1024; // ps 返回的是 KB,转换为字节\n } else if (process.platform === 'win32') {\n // Windows: 使用 wmic 命令\n const { stdout } = await execAsync(`wmic process where ProcessId=${process.pid} get WorkingSetSize`);\n const match = stdout.match(/\\d+/);\n return match ? parseInt(match[0]) : 0;\n }\n } catch {\n // 如果获取失败,返回 0\n }\n return 0;\n }\n\n /**\n * 获取当前内存使用情况\n */\n getMemoryUsage(): MemoryStats {\n const usage = process.memoryUsage();\n return {\n rss: usage.rss,\n heapTotal: usage.heapTotal,\n heapUsed: usage.heapUsed,\n external: usage.external,\n arrayBuffers: usage.arrayBuffers,\n };\n }\n \n /**\n * 获取完整的内存使用情况(包括系统级)\n */\n async getFullMemoryUsage(): Promise<MemoryStats> {\n const usage = this.getMemoryUsage();\n const systemTotal = await this.getSystemMemory();\n return {\n ...usage,\n systemTotal: systemTotal > 0 ? systemTotal : undefined,\n };\n }\n\n /**\n * 格式化内存大小\n */\n private formatBytes(bytes: number): string {\n const mb = bytes / 1024 / 1024;\n return `${mb.toFixed(2)} MB`;\n }\n\n /**\n * 检查内存使用情况\n */\n private async checkMemory(): Promise<void> {\n const stats = await this.getFullMemoryUsage();\n const rssMB = stats.rss / 1024 / 1024;\n const heapUsagePercent = (stats.heapUsed / stats.heapTotal) * 100;\n const systemTotalMB = stats.systemTotal ? stats.systemTotal / 1024 / 1024 : null;\n\n // 记录当前内存使用\n const memoryInfo: Record<string, string> = {\n rss: this.formatBytes(stats.rss),\n heapUsed: this.formatBytes(stats.heapUsed),\n heapTotal: this.formatBytes(stats.heapTotal),\n heapUsagePercent: `${heapUsagePercent.toFixed(2)}%`,\n };\n \n if (stats.systemTotal) {\n memoryInfo.systemTotal = this.formatBytes(stats.systemTotal);\n }\n \n console.log('[内存监控] 当前使用:', memoryInfo);\n\n // 使用系统总内存进行阈值检查(如果可用),否则使用 RSS\n const checkMemoryMB = systemTotalMB || rssMB;\n\n // 检查是否超过临界阈值\n if (checkMemoryMB >= this.thresholds.criticalMB) {\n console.error(`[内存监控] ⚠️ 内存使用达到临界值: ${checkMemoryMB.toFixed(2)}MB`);\n await this.triggerCleanup('critical');\n return;\n }\n\n // 检查是否超过警告阈值\n if (checkMemoryMB >= this.thresholds.warningMB || heapUsagePercent >= this.thresholds.heapUsagePercent) {\n const now = Date.now();\n if (now - this.lastWarningTime > this.warningCooldown) {\n console.warn(`[内存监控] ⚠️ 内存使用较高: ${checkMemoryMB.toFixed(2)}MB (堆使用率: ${heapUsagePercent.toFixed(2)}%)`);\n this.lastWarningTime = now;\n \n // 触发轻度清理\n await this.triggerCleanup('warning');\n }\n }\n }\n\n /**\n * 触发清理操作\n */\n private async triggerCleanup(level: 'warning' | 'critical'): Promise<void> {\n console.log(`[内存监控] 开始 ${level === 'critical' ? '紧急' : '常规'} 清理...`);\n\n const beforeStats = this.getMemoryUsage();\n\n // 执行所有注册的清理回调\n for (const callback of this.cleanupCallbacks) {\n try {\n await callback();\n } catch (error) {\n console.error('[内存监控] 清理回调执行失败:', error);\n }\n }\n\n // 强制垃圾回收(如果可用)\n if (global.gc) {\n global.gc();\n console.log('[内存监控] 已触发垃圾回收');\n } else if (level === 'critical') {\n console.warn('[内存监控] 垃圾回收不可用。启动 Node.js 时使用 --expose-gc 标志以启用手动垃圾回收');\n }\n\n const afterStats = this.getMemoryUsage();\n const freedMB = (beforeStats.rss - afterStats.rss) / 1024 / 1024;\n\n console.log(`[内存监控] 清理完成,释放内存: ${freedMB.toFixed(2)}MB`);\n }\n\n /**\n * 启动内存监控\n */\n start(): void {\n if (this.monitorTimer) {\n console.warn('[内存监控] 监控器已经在运行');\n return;\n }\n\n console.log('[内存监控] 启动内存监控', {\n interval: `${MONITOR_INTERVAL / 1000}秒`,\n thresholds: {\n warning: `${this.thresholds.warningMB}MB`,\n critical: `${this.thresholds.criticalMB}MB`,\n heapUsage: `${this.thresholds.heapUsagePercent}%`,\n },\n });\n\n // 立即检查一次\n this.checkMemory();\n\n // 定期检查\n this.monitorTimer = setInterval(() => {\n this.checkMemory();\n }, MONITOR_INTERVAL);\n }\n\n /**\n * 停止内存监控\n */\n stop(): void {\n if (this.monitorTimer) {\n clearInterval(this.monitorTimer);\n this.monitorTimer = null;\n console.log('[内存监控] 监控器已停止');\n }\n }\n\n /**\n * 手动触发内存检查\n */\n async check(): Promise<MemoryStats> {\n await this.checkMemory();\n return await this.getFullMemoryUsage();\n }\n}\n\n// 创建全局实例\nexport const memoryMonitor = new MemoryMonitor();\n\n// 进程退出时停止监控\nprocess.on('SIGINT', () => {\n memoryMonitor.stop();\n});\n\nprocess.on('SIGTERM', () => {\n memoryMonitor.stop();\n});\n\n// 导出类型\nexport type { MemoryStats, MemoryThresholds };\n\n","/**\n * 内存状态查询 API\n * 用于监控和调试内存使用情况\n */\nimport { NextResponse } from 'next/server';\nimport { memoryMonitor } from '@/lib/memory-monitor';\nimport { getLogsDirSize } from '@/lib/log-manager';\nimport { sseConnectionManager } from '@/lib/sse-connection-manager';\n\nexport async function GET() {\n try {\n const memoryUsage = await memoryMonitor.check();\n const logStats = await getLogsDirSize();\n \n const memoryData: Record<string, string> = {\n rss: `${(memoryUsage.rss / 1024 / 1024).toFixed(2)} MB`,\n heapUsed: `${(memoryUsage.heapUsed / 1024 / 1024).toFixed(2)} MB`,\n heapTotal: `${(memoryUsage.heapTotal / 1024 / 1024).toFixed(2)} MB`,\n heapUsagePercent: `${((memoryUsage.heapUsed / memoryUsage.heapTotal) * 100).toFixed(2)}%`,\n external: `${(memoryUsage.external / 1024 / 1024).toFixed(2)} MB`,\n };\n \n if (memoryUsage.systemTotal) {\n memoryData.systemTotal = `${(memoryUsage.systemTotal / 1024 / 1024).toFixed(2)} MB`;\n memoryData.note = 'systemTotal 包含所有子进程和相关资源';\n }\n \n return NextResponse.json({\n success: true,\n data: {\n memory: memoryData,\n logs: {\n totalSize: `${(logStats.totalSize / 1024 / 1024).toFixed(2)} MB`,\n fileCount: logStats.fileCount,\n },\n connections: sseConnectionManager.getConnectionStats(),\n timestamp: new Date().toISOString(),\n }\n });\n } catch (error) {\n return NextResponse.json({\n success: false,\n error: error instanceof Error ? error.message : '获取内存状态失败'\n }, { status: 500 });\n }\n}\n\n/**\n * 触发手动清理\n */\nexport async function POST() {\n try {\n await memoryMonitor.check();\n \n return NextResponse.json({\n success: true,\n message: '已触发内存检查和清理'\n });\n } catch (error) {\n return NextResponse.json({\n success: false,\n error: error instanceof Error ? error.message : '触发清理失败'\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":"+sDAEC,EAAA,CAAA,CAAA,mPACD,IAAA,EAAA,EAAA,CAAA,CAAA,MACA,EAAA,EAAA,CAAA,CAAA,OACA,EAAA,EAAA,CAAA,CAAA,OAGA,IAAM,EAAa,CACjB,cAAe,IAAI,IACnB,GAD0B,WACX,EACf,iBAAkB,EAClB,gBAAiB,IACjB,iBAAkB,IACpB,CADyB,CAIzB,IAJ8B,KAIrB,IACP,OAAO,EAAA,OAAI,CAAC,IAAI,CAAC,EAAA,OAAE,CAAC,OAAO,GAAI,GAAxB,eAAU,IACnB,CAGO,SAAS,EAAkB,CAAkB,EAClD,OAAO,EAAA,OAAI,CAAC,IAAI,CAAC,IAAa,CAAA,EAAG,EAAW,IAAI,CAAC,CACnD,CAGO,OAJE,EAIO,EAAgB,CAAY,SAC1C,AAAI,EAAK,MAAM,EAAI,EAAW,eAAe,CACpC,CADsC,CAGxC,EAAK,SAAS,CAAC,EAAG,EAAW,eAAe,EAAI,iBACzD,CAKA,eAAe,EAAY,CAAgB,EACzC,GAAI,CAEF,MAAO,CADO,MAAM,EAAA,OAAE,CAAC,IAAI,CAAC,EAAA,EACf,IAAI,AACnB,CAAE,KAAM,CACN,OAAO,AAHa,CAItB,CACF,CAMO,eAAe,EAAc,CAAkB,EACpD,IAAM,EAAU,EAAkB,GAC5B,EAAW,MAAM,EAAY,GAGnC,KAAI,EAAW,EAAW,aAAA,AAAa,EAAE,CAIzC,QAAQ,GAAG,CAAC,CAAC,eAAe,EAAE,EAAW,MAAM,EAAE,CAAC,EAAW,KAAO,IAAA,CAAI,CAAE,OAAO,CAAC,GAAG,EAAE,CAAC,EAExF,GAAI,CAEF,IAAM,EAAgB,CAAA,EAAG,EAAQ,CAAC,EAAE,EAAW,aAAa,CAAA,CAAE,CAC9D,GAAI,CACF,MAAM,EAAA,OAAE,CAAC,MAAM,CAAC,EAClB,CAAE,KAAM,CAER,CAGA,IAAK,IAAI,EAND,AAMK,EAAW,aAAa,CAAG,EAAG,GAAK,EAAG,IAAK,CACtD,IAAM,EAAU,AAAM,MAAI,EAAU,CAAA,EAAG,EAAQ,CAAC,EAAE,EAAA,CAAG,CAC/C,EAAU,CAAA,EAAG,EAAQ,CAAC,EAAE,EAAI,EAAA,CAAG,CAErC,GAAI,CACF,MAAM,EAAA,OAAE,CAAC,MAAM,CAAC,EAAS,EAC3B,CAAE,KAAM,CAER,CACF,CAGA,MAAM,CAPI,CAOJ,OAAE,CAAC,MAAM,CAAC,EAAS,CAAA,EAAG,EAAQ,EAAE,CAAC,EAGvC,MAAM,EAAA,AAHA,OAGE,CAAC,SAAS,CAAC,EAAS,GAAI,SAEhC,GAFM,KAEE,GAAG,CAAC,CAAC,eAAe,EAAE,EAAA,CAAY,CAC5C,CAAE,MAAO,EAAO,CACd,QAAQ,KAAK,CAAC,CAAC,iBAAiB,EAAE,EAAA,CAAY,CAAE,EAClD,EACF,CAMO,eAAe,EAAU,CAAkB,CAAE,CAAe,EAEjE,MAAM,EAAc,GAEpB,IAAM,EAAU,EAAkB,GAC5B,EAAgB,EAAgB,GAEtC,GAAI,CAEF,MAAM,EAAA,OAAE,CAAC,KAAK,CAAC,IAAa,CAAE,WAAW,CAAK,GAG9C,CAHM,KAGA,EAAA,OAAE,CAAC,UAAU,CAAC,EAAS,EAAgB,KAAM,OAA7C,CACR,CAAE,MAAO,EAAO,CACd,QAAQ,KAAK,CAAC,CAAC,eAAe,EAAE,EAAA,CAAY,CAAE,EAChD,CACF,CAKO,eAAe,EAAc,CAAkB,CAAE,CAAc,EACpE,MAAM,EAAc,GAEpB,IAAM,EAAU,EAAkB,GAC5B,EAAgB,EAAK,GAAG,CAAC,GAAQ,EAAgB,IAEvD,GAAI,CACF,MAAM,EAAA,OAAE,CAAC,KAAK,CAAC,IAAa,CAAE,UAAW,EAAK,GAC9C,CADM,KACA,EAAA,OAAE,CAAC,SAAS,CAAC,EAAS,EAAc,IAAI,CAAC,MAAQ,EAAjD,GAAuD,QAC/D,CAAE,MAAO,EAAO,CACd,QAAQ,KAAK,CAAC,CAAC,eAAe,EAAE,EAAA,CAAY,CAAE,EAChD,CACF,CAKO,eAAe,EAAe,CAAkB,CAAE,EAAY,GAAG,EACtE,IAAM,EAAU,EAAkB,GAElC,GAAI,CAGF,MADc,AACP,CAFS,MAAM,EAAA,OAAE,CAAC,QAAQ,CAAC,EAAS,QAAA,EACrB,KAAK,CADL,AACM,MAAM,MAAM,CAAC,GAAQ,EAAK,IAAI,IAC7C,KAAK,CAAC,CAAC,EACtB,CAAE,KAAM,CACN,MAAO,EAAE,AACX,CACF,CAMO,eAAe,IACpB,QAAQ,GAAG,CAAC,qBAEZ,GAAI,CACF,IAAM,EAAS,IAGf,GAAI,CACF,MAAM,EAAA,OAAE,CAAC,MAAM,CAAC,EAClB,CAAE,KAAM,CACN,QAAQ,GAFF,AAEK,CAAC,uBACZ,MACF,CAEA,IAAM,EAAQ,MAAM,EAAA,OAAE,CAAC,OAAO,CAAC,GACzB,EAAM,KAAK,GAAG,GACd,EAAuC,CAFzB,IAEM,AAAwB,KAAK,KAAK,MAAlB,CAA3B,KAEX,EAAe,EACf,EAAa,EAEjB,IAAK,IAAM,KAAQ,EAAO,CACxB,IAAM,EAAW,EAAA,OAAI,CAAC,IAAI,CAAC,EAAQ,GAEnC,GAAI,CACF,IAAM,EAAQ,MAAM,EAAA,AAHL,OAGO,CAAC,IAAI,CAAC,GAG5B,GAAI,EAAM,EAAM,KAAK,CAAC,MAHF,CAGS,GAAK,EAAQ,CACxC,GAAc,EAAM,IAAI,CACxB,GAAI,CACF,MAAM,EAAA,OAAE,CAAC,MAAM,CAAC,GAChB,IACA,QAAQ,GAAG,CAAC,CAFN,AAEO,eAAe,EAAE,EAAA,CAAM,CAEtC,CAAE,MAAO,EAAkB,CAErB,GAAa,OAAS,UACxB,AADkC,QAC1B,KAAK,CAAC,CAAC,eAAe,EAAE,EAAA,CAAM,CAAE,EAE5C,CACF,CAEA,CAAE,MAAO,EAAY,CAEjB,GAAO,OAAS,UAAU,AAC5B,QAAQ,KAAK,CAAC,CAAC,eAAe,EAAE,EAAA,CAAM,CAAE,EAE5C,CACF,CAEA,QAAQ,GAAG,CAAC,CAAC,gBAAgB,EAAE,EAAa,SAAS,EAAE,AAAC,GAAa,KAAO,IAAA,CAAI,CAAE,OAAO,CAAC,GAAG,EAAE,CAAC,CAClG,CAAE,MAAO,EAAO,CACd,QAAQ,KAAK,CAAC,iBAAkB,EAClC,CACF,CAKO,eAAe,EAAkB,CAAkB,EACxD,IAAM,EAAU,EAAkB,GAElC,GAAI,CAEF,MAAM,EAAA,OAAE,CAAC,MAAM,CAAC,EAElB,CAAE,MAAO,EAAY,CAEf,GAAO,KAJL,EAIc,UAAU,AAC5B,QAAQ,KAAK,CAAC,CAAC,kBAAkB,EAAE,EAAA,CAAY,CAAE,EAErD,CAGA,IAAK,IAAI,EAAI,EAAG,GAAK,EAAW,aAAa,CAAE,IAAK,AAClD,GAAI,CACF,MAAM,EAAA,OAAE,CAAC,MAAM,CAAC,CAAA,EAAG,EAAQ,CAAC,EAAE,EAAA,CAAG,CAEnC,CAAE,MAAO,CAFD,CAEa,CAEf,GAAO,OAAS,UAAU,AAC5B,QAAQ,KAAK,CAAC,CAAC,mBAAmB,EAAE,EAAW,CAAC,EAAE,EAAA,CAAG,CAAE,EAE3D,CAGF,QAAQ,GAAG,CAAC,CAAC,eAAe,EAAE,EAAA,CAAY,CAC5C,CAKO,eAAe,IACpB,GAAI,CACF,IAAM,EAAS,IACT,EAAQ,MAAM,EAAA,OAAE,CAAC,OAAO,CAAC,GAE3B,EAAY,EACZ,EAAY,EAEhB,IAAK,IAAM,AALS,KAKD,EACjB,GAAI,CADoB,AAEtB,IAAM,EAAQ,MAAM,EAAA,OAAE,CAAC,IAAI,CAAC,EAAA,OAAI,CAAC,IAAI,CAAC,EAAQ,IAC9C,CADoB,EACP,EAAM,IAAI,CACvB,GACF,CAAE,GAH4B,EAGtB,CAER,CAGF,MAAO,WAAE,YAAW,CAAU,CAChC,CAAE,KAAM,CACN,MAAO,CAAE,UAAW,EAAG,UAAW,CAAE,CACtC,CACF,CAGA,IAAI,EAAsC,KAKnC,SAAS,IACV,IAIJ,QAAQ,EAJU,CAIP,CAAC,mBAGZ,IAGA,EAAe,YAAY,KACzB,GACF,EAAG,EAAW,gBAAgB,EAChC,CAKO,SAAS,IACV,IACF,UADgB,IACF,GACd,EAAe,KACf,QAAQ,GAAG,CAAC,mBAEhB,CAGA,QAAQ,EAAE,CAAC,SAAU,KACnB,GACF,GAEA,QAAQ,EAAE,CAAC,UAAW,KACpB,GACF,oDClTC,EAAA,CAAA,CAAA,6BAiCD,OAAM,EACI,YAAc,IAAI,GAAmC,CACrD,QAAU,IAAI,WAAc,CAC5B,kBAA2C,IAAK,AACvC,oBAAqB,GAAM,CAC3B,mBAAqB,IAAO,CAC5B,wBAA0B,EAAG,AAE9C,cAAc,CACZ,IAAI,CAAC,cAAc,EACrB,CAKA,qBAA4B,CAC1B,QAAQ,GAAG,CAAC,qBACZ,IAAM,EAAmB,MAAM,IAAI,CAAC,IAAI,CAAC,WAAW,CAAC,MAAM,IAAI,MAAM,CAAC,CAAC,EAAK,IAAQ,EAAM,EAAI,IAAI,CAAE,GAEpG,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,AAAC,IACxB,EAAY,OAAO,CAAC,IAClB,GAAI,CACF,EAAK,UAAU,CAAC,KAAK,EACvB,CAAE,KAAM,CAER,CACF,EACF,GAEA,IAAI,CAAC,WAAW,CAAC,KAAK,GACtB,QAAQ,GAAG,CAAC,CAAC,UAAU,EAAE,EAAiB,IAAI,CAAC,CACjD,CAKA,cAAc,CAAe,CAAE,CAAuD,CAAE,CAAgB,CAAQ,CAC9G,QAAQ,GAAG,CAAC,CAAC,eAAe,EAAE,EAAQ,MAAM,EAAE,EAAA,CAAU,EAEpD,AAAC,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,IACxB,IAAI,CAAC,CAD6B,UAClB,CAAC,GAAG,CAAC,EAAS,IAAI,KAGpC,IAAM,EAAc,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,GAGzC,GAAI,EAAY,IAAI,EAAI,IAAI,CAAC,uBAAuB,CAAE,CACpD,QAAQ,IAAI,CAAC,CAAC,SAAS,EAAE,EAAQ,gBAAgB,CAAC,EAElD,IAAM,EAAa,MAAM,IAAI,CAAC,GAAa,IAAI,CAAC,CAAC,EAAG,IAAM,EAAE,SAAS,CAAG,EAAE,SAAS,CAAC,CAAC,EAAE,CACvF,GAAI,EAAY,CACd,GAAI,CACF,EAAW,UAAU,CAAC,KAAK,EAC7B,CAAE,KAAM,CAER,CACA,EAAY,MAAM,CAAC,EACrB,CACF,CAEA,IAAM,EAAiC,YACrC,EACA,UAAW,KAAK,GAAG,GACnB,mBACA,CACF,EAEA,EAAY,GAAG,CAAC,GAGhB,IAAI,CAAC,gBAAgB,CAAC,EAAgB,CACpC,KAAM,YACN,UAAW,KAAK,GAAG,EACrB,GAEA,QAAQ,GAAG,CAAC,CAAC,cAAc,EAAE,IAAI,CAAC,kBAAkB,GAAA,CAAI,CAC1D,CAKA,iBAAiB,CAAe,CAAE,CAAgB,CAAQ,CACxD,QAAQ,GAAG,CAAC,CAAC,eAAe,EAAE,EAAQ,MAAM,EAAE,EAAA,CAAU,EAExD,IAAM,EAAc,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,GACzC,GAAI,EAAa,CACf,IAAM,EAAqB,MAAM,IAAI,CAAC,GAAa,IAAI,CAAC,GAAQ,EAAK,QAAQ,GAAK,GAC9E,IACF,EAAY,MAAM,CAAC,GAGM,GAAG,CAJN,AAIlB,EAAY,IAAI,EAClB,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,GAG9B,CAEA,QAAQ,GAAG,CAAC,CAAC,cAAc,EAAE,IAAI,CAAC,kBAAkB,GAAA,CAAI,CAC1D,CAKA,eAAe,CAAe,CAAE,CAA4B,CAAQ,CAClE,QAAQ,GAAG,CAAC,CAAC,UAAU,EAAE,EAAQ,SAAS,CAAC,EAE3C,IAAM,EAAc,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,GACzC,GAAI,CAAC,GAAoC,IAArB,EAAY,IAAI,CAAQ,YAC1C,QAAQ,GAAG,CAAC,CAAC,SAAS,EAAE,EAAQ,YAAY,CAAC,EAI/C,IAAM,EAAoC,EAAE,CAE5C,EAAY,OAAO,CAAC,IAClB,GAAI,CACF,IAAI,CAAC,gBAAgB,CAAC,EAAgB,EACxC,CAAE,MAAO,EAAO,CACd,QAAQ,KAAK,CAAC,CAAC,eAAe,EAAE,EAAe,QAAQ,CAAC,IAAI,CAAC,CAAE,GAC/D,EAAgB,IAAI,CAAC,EACvB,CACF,GAGA,EAAgB,OAAO,CAAC,IACtB,EAAY,MAAM,CAAC,GACnB,QAAQ,GAAG,CAAC,CAAC,kBAAkB,EAAE,EAAK,QAAQ,CAAA,CAAE,CAClD,GAEA,QAAQ,GAAG,CAAC,CAAC,YAAY,EAAE,EAAY,IAAI,CAAC,IAAI,CAAC,CACnD,CAKQ,iBAAiB,CAA8B,CAAE,CAAmB,CAAQ,CAClF,IAAM,EAAO,CAAC,MAAM,EAAE,KAAK,SAAS,CAAC,SAAS;AAAA;AAAI,CAAC,CAC7C,EAAc,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,GAExC,GAAI,CACF,EAAe,UAAU,CAAC,OAAO,CAAC,GAClC,EAAe,SAAS,CAAG,KAAK,GAAG,EACrC,CAAE,CADuC,KAChC,EAAO,CAEd,GAHkD,GAElD,QAAQ,KAAK,CAAC,CAAC,aAAa,CAAC,CAAE,GACzB,CACR,CACF,CAKQ,gBAAuB,CAC7B,IAAI,CAAC,iBAAiB,CAAG,YAAY,KACnC,IAAI,CAAC,aAAa,GAClB,IAAI,CAAC,uBAAuB,EAC9B,EAAG,IAAI,CAAC,kBAAkB,EAE1B,QAAQ,GAAG,CAAC,CAAC,kBAAkB,EAAE,IAAI,CAAC,kBAAkB,CAAC,EAAE,CAAC,CAC9D,CAKQ,eAAsB,CAC5B,IAAM,EAAqC,CACzC,KAAM,YACN,UAAW,KAAK,GAAG,EACrB,EAEI,EAAmB,EACvB,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,AAAC,IACxB,GAAoB,EAAY,IAAI,CACpC,IAAM,EAAoC,EAAE,CAE5C,EAAY,OAAO,CAAC,IAClB,GAAI,CACF,IAAI,CAAC,gBAAgB,CAAC,EAAgB,EACxC,CAAE,KAAM,CACN,EAAgB,IAAI,CAAC,EACvB,CACF,GAGA,EAAgB,OAAO,CAAC,GAAQ,EAAY,MAAM,CAAC,GACrD,GAEI,EAAmB,GAAG,AACxB,QAAQ,GAAG,CAAC,CAAC,oBAAoB,EAAE,EAAA,CAAkB,CAEzD,CAKQ,yBAAgC,CACtC,IAAM,EAAM,KAAK,GAAG,GAChB,EAAe,EAEnB,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,CAAC,EAAa,KACrC,IAAM,EAAqC,EAAE,CAE7C,EAAY,OAAO,CAAC,IACd,EAAM,EAAe,SAAS,CAAG,IAAI,CAAC,kBAAkB,EAAE,AAC5D,EAAiB,IAAI,CAAC,EAE1B,GAEA,EAAiB,OAAO,CAAC,IACvB,EAAY,MAAM,CAAC,GACnB,IACA,QAAQ,GAAG,CAAC,CAAC,iBAAiB,EAAE,EAAQ,MAAM,EAAE,EAAK,QAAQ,CAAA,CAAE,CACjE,GAGyB,GAAG,CAAxB,EAAY,IAAI,EAClB,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,EAE5B,GAEI,EAAe,GAAG,AACpB,QAAQ,GAAG,CAAC,CAAC,mBAAmB,EAAE,EAAA,CAAc,CAEpD,CAKA,oBAA6B,CAC3B,IAAM,EAAkB,EAAE,CACtB,EAAmB,EAQvB,OANA,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,CAAC,EAAa,KACrC,IAAM,EAAQ,EAAY,IAAI,CAC9B,GAAoB,EACpB,EAAM,IAAI,CAAC,CAAA,EAAG,EAAQ,EAAE,EAAE,EAAA,CAAO,CACnC,GAEO,CAAC,GAAG,EAAE,EAAiB,MAAM,EAAE,EAAM,IAAI,CAAC,MAAM,CAAC,CAAC,AAC3D,CAKA,MAAa,CACP,IAAI,CAAC,iBAAiB,EAAE,CAC1B,cAAc,IAAI,CAAC,iBAAiB,EACpC,IAAI,CAAC,iBAAiB,CAAG,KACzB,QAAQ,GAAG,CAAC,CAAC,aAAa,CAAC,GAI7B,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,AAAC,IACxB,EAAY,OAAO,CAAC,IAClB,GAAI,CACF,EAAe,UAAU,CAAC,KAAK,EACjC,CAAE,MAAO,EAAO,CACd,QAAQ,KAAK,CAAC,CAAC,aAAa,CAAC,CAAE,EACjC,CACF,EACF,GAEA,IAAI,CAAC,WAAW,CAAC,KAAK,GACtB,QAAQ,GAAG,CAAC,CAAC,aAAa,CAAC,CAC7B,CACF,CAGO,IAAM,EAAuB,IAAI,EAGxC,QAAQ,EAAE,CAAC,SAAU,KACnB,QAAQ,GAAG,CAAC,0BACZ,EAAqB,IAAI,GACzB,QAAQ,IAAI,CAAC,EACf,GAEA,QAAQ,EAAE,CAAC,UAAW,KACpB,QAAQ,GAAG,CAAC,0BACZ,EAAqB,IAAI,GACzB,QAAQ,IAAI,CAAC,EACf,sGC1TC,EAAA,CAAA,CAAA,uBACD,IAAA,EAAA,EAAA,CAAA,CAAA,OAGA,IAAM,EAAY,CAAA,EAFlB,AAEkB,EAFlB,CAAA,CAAA,MAEkB,SAAA,AAAQ,EAAE,EAAA,IAAI,EAiB1B,EAAuC,CAC3C,KAlBgB,KAkBL,IACX,WAAY,EAnBc,GAoB1B,iBAAkB,EACpB,EAgNa,EAAgB,IA5M7B,AA4MiC,MA5M3B,AACI,aAAsC,IAAK,AAC3C,WAA6B,CAC7B,iBAA+C,EAAE,AAAC,CAClD,gBAAkB,CAAE,CACpB,gBAAkB,GAAc,AAExC,CAF8B,KAAK,OAEvB,EAAwC,CAAC,CAAC,CAAE,CACtD,IAAI,CAAC,UAAU,CAAG,CAAE,GAAG,CAAkB,CAAE,GAAG,CAAU,AAAC,CAC3D,CAMA,wBAAwB,CAA6B,CAAQ,CAC3D,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,EAC7B,CAKA,MAAc,iBAAmC,CAC/C,GAAI,CACiE,CAEjE,GAAM,QAAE,CAAM,CAAE,CAAG,MAAM,EAAU,CAAC,cAAc,EAAE,QAAQ,GAAG,CAAA,CAAE,EAE3D,EAAQ,AADA,EAAO,IAAI,GAAG,KAAK,CAAC,MACd,MAAM,CAAC,CAAC,EAAK,KAC/B,IAAM,EAAM,SAAS,EAAK,IAAI,IAC9B,OAAO,EAAO,IAAD,GAAO,GAAO,EAAI,CAAA,CAAG,AACpC,EAAG,GACH,OAAO,AAAQ,MAAM,AACvB,CAMF,CAAE,KAAM,AANC,CAQT,CACA,OAAO,CACT,CAKA,CAhB8C,eAgBhB,CAC5B,IAAM,EAAQ,QAAQ,WAAW,GACjC,MAAO,CACL,IAAK,EAAM,GAAG,CACd,UAAW,EAAM,SAAS,CAC1B,SAAU,EAAM,QAAQ,CACxB,SAAU,EAAM,QAAQ,CACxB,aAAc,EAAM,YAAY,AAClC,CACF,CAKA,MAAM,oBAA2C,CAC/C,IAAM,EAAQ,IAAI,CAAC,cAAc,GAC3B,EAAc,MAAM,IAAI,CAAC,eAAe,GAC9C,MAAO,CACL,GAAG,CAAK,CACR,YAAa,EAAc,EAAI,OAAc,CAC/C,CACF,CAKQ,YAAY,CAAa,CAAU,CAEzC,MAAO,CAAA,EAAG,CADC,EAAQ,KAAO,IAAA,EACb,OAAO,CAAC,GAAG,GAAG,CAAC,AAC9B,CAKA,MAAc,aAA6B,CACzC,IAAM,EAAQ,MAAM,IAAI,CAAC,kBAAkB,GACrC,EAAQ,EAAM,GAAG,CAAG,KAAO,KAC3B,EAAoB,EAAM,QAAQ,CAAG,EAAM,SAAS,CAAI,IACxD,EAAgB,EAAM,WAAW,CAAG,EAAM,WAAW,CAAG,KAAO,KAAO,KAGtE,EAAqC,CACzC,IAAK,IAAI,CAAC,WAAW,CAAC,EAAM,GAAG,EAC/B,SAAU,IAAI,CAAC,WAAW,CAAC,EAAM,QAAQ,EACzC,UAAW,IAAI,CAAC,WAAW,CAAC,EAAM,SAAS,EAC3C,iBAAkB,CAAA,EAAG,EAAiB,OAAO,CAAC,GAAG,CAAC,CAAC,AACrD,EAEI,EAAM,WAAW,EAAE,AACrB,GAAW,WAAW,CAAG,IAAI,CAAC,WAAW,CAAC,EAAM,YAAW,EAG7D,QAAQ,GAAG,CAAC,eAAgB,GAG5B,IAAM,EAAgB,GAAiB,EAGvC,GAAI,GAAiB,IAAI,CAAC,UAAU,CAAC,UAAU,CAAE,CAC/C,QAAQ,KAAK,CAAC,CAAC,qBAAqB,EAAE,EAAc,OAAO,CAAC,GAAG,EAAE,CAAC,EAClE,MAAM,IAAI,CAAC,cAAc,CAAC,YAC1B,MACF,CAGA,GAAI,GAAiB,IAAI,CAAC,UAAU,CAAC,SAAS,EAAI,GAAoB,IAAI,CAAC,UAAU,CAAC,gBAAgB,CAAE,CACtG,IAAM,EAAM,KAAK,GAAG,GAChB,EAAM,IAAI,CAAC,eAAe,CAAG,IAAI,CAAC,eAAe,EAAE,CACrD,QAAQ,IAAI,CAAC,CAAC,kBAAkB,EAAE,EAAc,OAAO,CAAC,GAAG,UAAU,EAAE,EAAiB,OAAO,CAAC,GAAG,EAAE,CAAC,EACtG,IAAI,CAAC,eAAe,CAAG,EAGvB,MAAM,IAAI,CAAC,cAAc,CAAC,WAE9B,CACF,CAKA,MAAc,eAAe,CAA6B,CAAiB,CACzE,QAAQ,GAAG,CAAC,CAAC,UAAU,EAAY,aAAV,EAAuB,KAAO,KAAK,MAAM,CAAC,EAEnE,IAAM,EAAc,IAAI,CAAC,cAAc,GAGvC,IAAK,IAAM,KAAY,IAAI,CAAC,gBAAgB,CAAE,AAC5C,GAAI,CACF,MAAM,GACR,CAAE,MAAO,EAAO,CACd,QAAQ,KAAK,CAAC,mBAAoB,EACpC,CAIE,EAAO,EAAE,EACX,AADa,EACN,EAAE,GACT,QAAQ,GAAG,CAAC,mBACH,AAAU,YAAY,IAC/B,QAAQ,IAAI,CAAC,yDAGf,IAAM,EAAa,IAAI,CAAC,cAAc,GAChC,EAAU,CAAC,EAAY,GAAG,CAAG,EAAW,GAAA,AAAG,EAAI,KAAO,KAE5D,QAAQ,GAAG,CAAC,CAAC,kBAAkB,EAAE,EAAQ,OAAO,CAAC,GAAG,EAAE,CAAC,CACzD,CAKA,OAAc,CACZ,GAAI,IAAI,CAAC,YAAY,CAAE,YACrB,QAAQ,IAAI,CAAC,mBAIf,QAAQ,GAAG,CAAC,gBAAiB,CAC3B,SAAU,GAAG,EAA0B,CACvC,WAAY,CACV,IAF8B,IAErB,CAF0B,AAE1B,CAF2B,CAExB,IAAI,CAAC,UAAU,CAAC,SAAS,CAAC,EAAE,CAAC,CACzC,SAAU,CAAA,EAAG,IAAI,CAAC,UAAU,CAAC,UAAU,CAAC,EAAE,CAAC,CAC3C,UAAW,CAAA,EAAG,IAAI,CAAC,UAAU,CAAC,gBAAgB,CAAC,CAAC,CAAC,AACnD,CACF,GAGA,IAAI,CAAC,WAAW,GAGhB,IAAI,CAAC,YAAY,CAAG,YAAY,KAC9B,IAAI,CAAC,WAAW,EAClB,EAtLqB,CAsLlB,GACL,CAKA,AA5L4B,MA4Lf,AA5LqB,CA6L5B,IAAI,CAAC,IA7LiC,QA6LrB,EAAE,CACrB,cAAc,IAAI,CAAC,YAAY,EAC/B,IAAI,CAAC,YAAY,CAAG,KACpB,QAAQ,GAAG,CAAC,iBAEhB,CAKA,MAAM,OAA8B,CAElC,OADA,MAAM,IAAI,CAAC,WAAW,GACf,MAAM,IAAI,CAAC,kBAAkB,EACtC,CACF,EAMA,QAAQ,EAAE,CAAC,SAAU,KACnB,EAAc,IAAI,EACpB,GAEA,QAAQ,EAAE,CAAC,UAAW,KACpB,EAAc,IAAI,EACpB,mDCjPC,EAAA,CAAA,CAAA,wBACD,IAAA,EAAA,EAAA,CAAA,CAAA,OACA,EAAA,EAAA,CAAA,CAAA,OACA,EAAA,EAAA,CAAA,CAAA,OACA,EAAA,EAAA,CAAA,CAAA,OAEO,eAAe,IACpB,GAAI,CACF,IAAM,EAAc,MAAM,EAAA,aAAa,CAAC,KAAK,GACvC,EAAW,MAAM,CAAA,EAAA,EAAA,CADG,aACU,AAAb,IAEjB,EAAqC,CACzC,IAAK,CAAA,EAAG,CAAC,EAAY,GAAG,CAAG,CAHN,IAGa,IAAA,CAAI,CAAE,OAAO,CAAC,GAAG,GAAG,CAAC,CACvD,SAAU,CAAA,EAAG,CAAC,EAAY,QAAQ,CAAG,KAAO,IAAA,CAAI,CAAE,OAAO,CAAC,GAAG,GAAG,CAAC,CACjE,UAAW,CAAA,EAAG,CAAC,EAAY,SAAS,CAAG,KAAO,IAAA,CAAI,CAAE,OAAO,CAAC,GAAG,GAAG,CAAC,CACnE,iBAAkB,CAAA,EAAG,CAAE,EAAY,QAAQ,CAAG,EAAY,SAAS,CAAI,GAAA,CAAG,CAAE,OAAO,CAAC,GAAG,CAAC,CAAC,CACzF,SAAU,CAAA,EAAG,CAAC,EAAY,QAAQ,CAAG,KAAO,IAAA,CAAI,CAAE,OAAO,CAAC,GAAG,GAAG,CAAC,AACnE,EAOA,OALI,EAAY,WAAW,EAAE,CAC3B,EAAW,WAAW,CAAG,CAAA,EAAG,AAAC,GAAY,WAAW,CAAG,KAAO,IAAA,CAAI,CAAE,OAAO,CAAC,GAAG,GAAG,CAAC,CACnF,EAAW,IAAI,CAAG,4BAGb,EAAA,YAAY,CAAC,IAAI,CAAC,CACvB,SAAS,EACT,KAAM,CAFD,AAGH,OAAQ,EACR,KAAM,CACJ,UAAW,CAAA,EAAG,CAAC,EAAS,SAAS,CAAG,KAAO,IAAA,CAAI,CAAE,OAAO,CAAC,GAAG,GAAG,CAAC,CAChE,UAAW,EAAS,SAAS,AAC/B,EACA,YAAa,EAAA,oBAAoB,CAAC,eAArB,GAAuC,GACpD,UAAW,IAAI,OAAO,WAAW,EACnC,CACF,EACF,CAAE,MAAO,EAAO,CACd,OAAO,EAAA,YAAY,CAAC,IAAI,CAAC,CACvB,SAAS,EACT,MAAO,AAFF,aAEmB,MAAQ,EAAM,OAAO,CAAG,UAClD,EAAG,CAAE,OAAQ,GAAI,EACnB,CACF,CAKO,eAAe,IACpB,GAAI,CAGF,OAFA,MAAM,EAAA,aAAa,CAAC,KAAK,GAElB,EAAA,YAAY,AAFb,CAEc,IAAI,CAAC,CACvB,SAAS,EACT,MAFK,EAEI,YACX,EACF,CAAE,MAAO,EAAO,CACd,OAAO,EAAA,YAAY,CAAC,IAAI,CAAC,CACvB,SAAS,EACT,MAFK,AAEE,aAAiB,MAAQ,EAAM,OAAO,CAAG,QAClD,EAAG,CAAE,OAAQ,GAAI,EACnB,CACF,gKChEA,IAAA,EAGO,EAAA,CAFLA,AAEK,CAAA,OACP,EAA0B,EAAyB,CAA1CC,AAA0C,CAAA,GAAA,EAH9B,EAIrB,CADkB,CAD2C,AAEnB,EAAA,CAAjCC,AAAiC,CAFnC,AAEmC,GADhB,CAC8C,GAExE,EAAwC,EAAA,CAAA,CAFjBC,AAEiB,EAA5BC,KAWZ,IAbkC,AAa5BC,EAAc,GAXM,CAWN,EAAIL,AAbkB,YAEF,OAWhBA,CAAoB,CAC1CM,WAAY,CACVC,KAAMN,EAAAA,SAAAA,CAAUO,SAAS,CACzBC,KAAM,2BACNC,SAAU,qBACVC,SAAU,QACVC,WAAY,EACd,EACAC,iBAAkB,+DAClBC,iBAXF,CAA0B,WAYxBV,CACF,GAKM,kBAAEW,CAAgB,sBAAEC,CAAoB,aAAEC,CAAW,CAAE,CAAGZ,EAEhE,SAASH,IACP,MAAA,CAAA,EAAA,EAAOC,UAAAA,EAAY,kBACjBY,uBACAC,CACF,EACF","ignoreList":[4]}
|
|
@@ -1,3 +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"))},
|
|
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"))},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"))},35692:e=>{"use strict";var{g:r,__dirname:t}=e;e.s({ProjectStatus:()=>i,getProjectsConfig:()=>o,saveProjectsConfig:()=>c});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 c({}),{}}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 c(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 i=function(e){return e.PENDING="pending",e.EXISTING="existing",e.CLONING="cloning",e.SUCCESS="success",e.FAILED="failed",e.RETRYING="retrying",e}({})},15079:e=>{"use strict";var{g:r,__dirname:t}=e;e.s({createProjectEnvFiles:()=>o,createProjectMockDirectories:()=>c,updateProjectEnvFile:()=>i});var s=e.i(83886),n=e.i(30331);async function o(e,r,t){let o=(0,n.join)(t,e),c=[],i=[];try{let e=r.envs||{};for(let r in e){let t=e[r];if(t.envFileName&&t.proxyKey){let e=(0,n.join)(o,t.envFileName);try{await s.promises.access(e),i.push(t.envFileName)}catch{let r=t.proxyEnv[t.currentProxy]||"",n=`${t.proxyKey}=${r}`;await s.promises.writeFile(e,n,"utf-8"),c.push(t.envFileName)}}}return{success:!0,createdFiles:c,skippedFiles:i}}catch(t){let r=t instanceof Error?t.message:String(t);return console.error(`在为项目 ${e} 创建环境文件时出错:`,t),{success:!1,createdFiles:c,skippedFiles:i,error:r}}}async function c(e,r){let t=(0,n.join)(r,e),o=(0,n.join)(t,".mock"),c=[],i=[];try{try{await s.promises.access(o),i.push(".mock")}catch{await s.promises.mkdir(o,{recursive:!0}),c.push(".mock")}return{success:!0,createdDirectories:c,skippedDirectories:i}}catch(t){let r=t instanceof Error?t.message:String(t);return console.error(`在为项目 ${e} 创建Mock目录时出错:`,t),{success:!1,createdDirectories:c,skippedDirectories:i,error:r}}}async function i(e,r,t,o){try{let c=t.envs[r];if(!c)return{success:!1,error:`环境 ${r} 不存在于项目 ${e} 配置中`};if(!c.envFileName||!c.proxyKey)return{success:!1,error:`环境 ${r} 缺少 envFileName 或 proxyKey 配置`};let i=(0,n.join)(o,e),a=(0,n.join)(i,c.envFileName),u=c.proxyEnv[c.currentProxy]||c.currentProxy,p=`${c.proxyKey}=${u}`;return await s.promises.writeFile(a,p,"utf-8"),console.log(`已更新环境文件: ${a}, 内容: ${p}`),{success:!0,updatedFile:c.envFileName}}catch(s){let t=s instanceof Error?s.message:String(s);return console.error(`更新项目 ${e} 环境 ${r} 的环境文件时出错:`,s),{success:!1,error:t}}}},24468:function(e){var{g:r,__dirname:t,m:s,e:n}=e},32875:e=>{"use strict";var{g:r,__dirname:t}=e;e.s({GET:()=>i,PUT:()=>a});var s=e.i(15494),n=e.i(35692),o=e.i(15079),c=e.i(88941);async function i(e){try{let{searchParams:r}=new URL(e.url),t=r.get("project");if(!t)return s.NextResponse.json({success:!1,error:"项目名称参数缺失"},{status:400});let o=await (0,n.getProjectsConfig)();if(!o[t])return s.NextResponse.json({success:!1,error:`项目 ${t} 不存在`},{status:404});let c=o[t];return s.NextResponse.json({success:!0,data:{projectName:t,repo:c.repo,mockingIntercept:c.mockingIntercept,mockOpen:c.mockOpen,envs:c.envs}})}catch(r){let e=r instanceof Error?r.message:"获取项目配置失败";return console.error("获取项目配置失败:",r),s.NextResponse.json({success:!1,error:e},{status:500})}}async function a(e){try{let{projectName:r,envName:t,newProxy:i,customProxyUrl:a,projectConfig:u}=await e.json();if(!r)return s.NextResponse.json({success:!1,error:"缺少必要参数:projectName"},{status:400});if(u){let e=await (0,n.getProjectsConfig)();if(!e[r])return s.NextResponse.json({success:!1,error:`项目 ${r} 不存在`},{status:404});return void 0!==u.mockingIntercept&&(e[r].mockingIntercept=u.mockingIntercept),void 0!==u.mockOpen&&(e[r].mockOpen=u.mockOpen),await (0,n.saveProjectsConfig)(e),s.NextResponse.json({success:!0,message:"项目配置更新成功",data:{projectName:r,mockingIntercept:e[r].mockingIntercept,mockOpen:e[r].mockOpen}})}if(!t||!i)return s.NextResponse.json({success:!1,error:"缺少必要参数:envName, newProxy"},{status:400});let p=await (0,n.getProjectsConfig)();if(!p[r])return s.NextResponse.json({success:!1,error:`项目 ${r} 不存在`},{status:404});if(!p[r].envs[t])return s.NextResponse.json({success:!1,error:`项目 ${r} 中不存在环境 ${t}`},{status:404});let l=p[r].envs[t];if("custom"===i){if(!a||""===a.trim())return s.NextResponse.json({success:!1,error:"选择 custom 时必须提供自定义代理地址"},{status:400})}else if(!l.proxyEnv[i])return s.NextResponse.json({success:!1,error:`代理环境 ${i} 不在可选范围内`},{status:400});p[r].envs[t].currentProxy=i,"custom"===i&&void 0!==a&&(p[r].envs[t].proxyEnv.custom=a),await (0,n.saveProjectsConfig)(p);let m=await (0,o.updateProjectEnvFile)(r,t,p[r],c.WORKSPACE_CONFIG.WORKSPACE_ROOT),x={projectName:r,envName:t,currentProxy:p[r].envs[t].currentProxy,currentProxyUrl:"custom"===i?a:l.proxyEnv[i]};if(!m.success)return console.warn(`环境文件更新失败: ${m.error}`),s.NextResponse.json({success:!0,message:"代理环境更新成功,但环境文件更新失败",warning:`环境文件更新失败: ${m.error}`,data:x});return s.NextResponse.json({success:!0,message:"代理环境更新成功",data:{...x,updatedEnvFile:m.updatedFile}})}catch(r){let e=r instanceof Error?r.message:"更新项目配置失败";return console.error("更新项目配置失败:",r),s.NextResponse.json({success:!1,error:e},{status:500})}}},42106:e=>{"use strict";var{g:r,__dirname:t}=e;{e.s({patchFetch:()=>i,routeModule:()=>r,serverHooks:()=>u,workAsyncStorage:()=>t,workUnitAsyncStorage:()=>a});var s=e.i(45746),n=e.i(93828),o=e.i(18250),c=e.i(32875);let r=new s.AppRouteRouteModule({definition:{kind:n.RouteKind.APP_ROUTE,page:"/api/project-config/route",pathname:"/api/project-config",filename:"route",bundlePath:""},resolvedPagePath:"[project]/packages/server/src/app/api/project-config/route.ts",nextConfigOutput:"",userland:c}),{workAsyncStorage:t,workUnitAsyncStorage:a,serverHooks:u}=r;function i(){return(0,o.patchFetch)({workAsyncStorage:t,workUnitAsyncStorage:a})}}}};
|
|
2
2
|
|
|
3
|
-
//# sourceMappingURL=%5Broot-of-the-server%
|
|
3
|
+
//# sourceMappingURL=%5Broot-of-the-server%5D__31a13318._.js.map
|
|
@@ -1 +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/lib/env-file-operations.ts","turbopack:///[project]/packages/server/src/app/api/project-config/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 { promises as fs } from 'fs';\nimport { join } from 'path';\nimport type { ProjectConfig } from './workspace-types';\n\n/**\n * 为指定项目创建环境文件,如果文件已存在则跳过。\n * @param projectName - 项目名称\n * @param projectConfig - 项目配置\n * @param workspacePath - 工作空间根路径\n * @returns 一个包含已创建和已跳过文件列表的对象\n */\nexport async function createProjectEnvFiles(\n projectName: string,\n projectConfig: ProjectConfig,\n workspacePath: string,\n): Promise<{\n success: boolean;\n createdFiles: string[];\n skippedFiles: string[];\n error?: string;\n}> {\n const projectPath = join(workspacePath, projectName);\n const createdFiles: string[] = [];\n const skippedFiles: string[] = [];\n\n try {\n const envs = projectConfig.envs || {};\n for (const envName in envs) {\n const envConfig = envs[envName];\n if (envConfig.envFileName && envConfig.proxyKey) {\n const filePath = join(projectPath, envConfig.envFileName);\n \n try {\n await fs.access(filePath);\n // 文件已存在,跳过\n skippedFiles.push(envConfig.envFileName);\n } catch {\n // 文件不存在,创建它\n const currentProxyUrl = envConfig.proxyEnv[envConfig.currentProxy] || '';\n const content = `${envConfig.proxyKey}=${currentProxyUrl}`;\n await fs.writeFile(filePath, content, 'utf-8');\n createdFiles.push(envConfig.envFileName);\n }\n }\n }\n return { success: true, createdFiles, skippedFiles };\n } catch (error) {\n const errorMessage = error instanceof Error ? error.message : String(error);\n console.error(`在为项目 ${projectName} 创建环境文件时出错:`, error);\n return { success: false, createdFiles, skippedFiles, error: errorMessage };\n }\n}\n\n/**\n * 为指定项目创建.mock文件夹\n * @param projectName - 项目名称\n * @param workspacePath - 工作空间根路径\n * @returns 创建结果\n */\nexport async function createProjectMockDirectories(\n projectName: string,\n workspacePath: string,\n): Promise<{\n success: boolean;\n createdDirectories: string[];\n skippedDirectories: string[];\n error?: string;\n}> {\n const projectPath = join(workspacePath, projectName);\n const mockPath = join(projectPath, '.mock');\n const createdDirectories: string[] = [];\n const skippedDirectories: string[] = [];\n\n try {\n // 创建 .mock 文件夹\n try {\n await fs.access(mockPath);\n skippedDirectories.push('.mock');\n } catch {\n await fs.mkdir(mockPath, { recursive: true });\n createdDirectories.push('.mock');\n }\n\n return { success: true, createdDirectories, skippedDirectories };\n } catch (error) {\n const errorMessage = error instanceof Error ? error.message : String(error);\n console.error(`在为项目 ${projectName} 创建Mock目录时出错:`, error);\n return { success: false, createdDirectories, skippedDirectories, error: errorMessage };\n }\n}\n\n/**\n * 更新指定项目环境的环境文件内容\n * @param projectName - 项目名称\n * @param envName - 环境名称\n * @param projectConfig - 项目配置\n * @param workspacePath - 工作空间根路径\n * @returns 更新结果\n */\nexport async function updateProjectEnvFile(\n projectName: string,\n envName: string,\n projectConfig: ProjectConfig,\n workspacePath: string,\n): Promise<{\n success: boolean;\n updatedFile?: string;\n error?: string;\n}> {\n try {\n const envConfig = projectConfig.envs[envName];\n \n if (!envConfig) {\n return {\n success: false,\n error: `环境 ${envName} 不存在于项目 ${projectName} 配置中`,\n };\n }\n\n if (!envConfig.envFileName || !envConfig.proxyKey) {\n return {\n success: false,\n error: `环境 ${envName} 缺少 envFileName 或 proxyKey 配置`,\n };\n }\n\n const projectPath = join(workspacePath, projectName);\n const filePath = join(projectPath, envConfig.envFileName);\n \n // 获取当前代理URL\n const currentProxyUrl = envConfig.proxyEnv[envConfig.currentProxy] || envConfig.currentProxy;\n const content = `${envConfig.proxyKey}=${currentProxyUrl}`;\n \n // 写入文件内容\n await fs.writeFile(filePath, content, 'utf-8');\n \n console.log(`已更新环境文件: ${filePath}, 内容: ${content}`);\n \n return {\n success: true,\n updatedFile: envConfig.envFileName,\n };\n } catch (error) {\n const errorMessage = error instanceof Error ? error.message : String(error);\n console.error(`更新项目 ${projectName} 环境 ${envName} 的环境文件时出错:`, error);\n return {\n success: false,\n error: errorMessage,\n };\n }\n} ","import { NextRequest, NextResponse } from 'next/server';\nimport {\n getProjectsConfig,\n saveProjectsConfig,\n} from '@/lib/workspace-config';\nimport { updateProjectEnvFile } from '@/lib/env-file-operations';\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\n if (!projectName) {\n return NextResponse.json(\n { success: false, error: '项目名称参数缺失' },\n { status: 400 },\n );\n }\n\n // 读取项目配置文件\n const projectsConfig = await getProjectsConfig();\n\n // 检查项目是否存在\n if (!projectsConfig[projectName]) {\n return NextResponse.json(\n { success: false, error: `项目 ${projectName} 不存在` },\n { status: 404 },\n );\n }\n\n const projectConfig = projectsConfig[projectName];\n\n return NextResponse.json({\n success: true,\n data: {\n projectName,\n repo: projectConfig.repo,\n mockingIntercept: projectConfig.mockingIntercept,\n mockOpen: projectConfig.mockOpen,\n envs: projectConfig.envs,\n },\n });\n } catch (error) {\n const errorMessage =\n error instanceof Error ? error.message : '获取项目配置失败';\n console.error('获取项目配置失败:', 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, envName, newProxy, customProxyUrl, projectConfig } =\n await request.json();\n\n // 参数验证\n if (!projectName) {\n return NextResponse.json(\n {\n success: false,\n error: '缺少必要参数:projectName',\n },\n { status: 400 },\n );\n }\n\n // 如果是项目级配置更新\n if (projectConfig) {\n // 读取当前配置文件\n const projectsConfig = await getProjectsConfig();\n\n // 检查项目是否存在\n if (!projectsConfig[projectName]) {\n return NextResponse.json(\n { success: false, error: `项目 ${projectName} 不存在` },\n { status: 404 },\n );\n }\n\n // 更新项目级配置\n if (projectConfig.mockingIntercept !== undefined) {\n projectsConfig[projectName].mockingIntercept = projectConfig.mockingIntercept;\n }\n if (projectConfig.mockOpen !== undefined) {\n projectsConfig[projectName].mockOpen = projectConfig.mockOpen;\n }\n\n // 保存更新后的配置\n await saveProjectsConfig(projectsConfig);\n\n return NextResponse.json({\n success: true,\n message: '项目配置更新成功',\n data: {\n projectName,\n mockingIntercept: projectsConfig[projectName].mockingIntercept,\n mockOpen: projectsConfig[projectName].mockOpen,\n },\n });\n }\n\n // 环境级配置更新的参数验证\n if (!envName || !newProxy) {\n return NextResponse.json(\n {\n success: false,\n error: '缺少必要参数:envName, newProxy',\n },\n { status: 400 },\n );\n }\n\n // 读取当前配置文件\n const projectsConfig = await getProjectsConfig();\n\n // 检查项目是否存在\n if (!projectsConfig[projectName]) {\n return NextResponse.json(\n { success: false, error: `项目 ${projectName} 不存在` },\n { status: 404 },\n );\n }\n\n // 检查环境是否存在\n if (!projectsConfig[projectName].envs[envName]) {\n return NextResponse.json(\n {\n success: false,\n error: `项目 ${projectName} 中不存在环境 ${envName}`,\n },\n { status: 404 },\n );\n }\n\n const envConfig = projectsConfig[projectName].envs[envName];\n\n // 验证新的代理地址是否在可选范围内\n if (newProxy === 'custom') {\n // 对于 custom 选项,只有在自定义代理 URL 为空时才报错\n // 如果自定义地址与现有预设值相同,这是允许的\n if (!customProxyUrl || customProxyUrl.trim() === '') {\n return NextResponse.json(\n { success: false, error: '选择 custom 时必须提供自定义代理地址' },\n { status: 400 },\n );\n }\n } else {\n // 对于其他选项,检查是否存在于 proxyEnv 中\n if (!envConfig.proxyEnv[newProxy]) {\n return NextResponse.json(\n { success: false, error: `代理环境 ${newProxy} 不在可选范围内` },\n { status: 400 },\n );\n }\n }\n\n // 更新 currentProxy 字段\n projectsConfig[projectName].envs[envName].currentProxy = newProxy;\n\n // 如果选择的是 custom,需要更新 custom 字段的值\n if (newProxy === 'custom' && customProxyUrl !== undefined) {\n projectsConfig[projectName].envs[envName].proxyEnv.custom =\n customProxyUrl;\n }\n\n // 保存更新后的配置\n await saveProjectsConfig(projectsConfig);\n\n // 更新项目的环境文件\n const envFileResult = await updateProjectEnvFile(\n projectName,\n envName,\n projectsConfig[projectName],\n WORKSPACE_CONFIG.WORKSPACE_ROOT,\n );\n\n // 准备响应数据\n const responseData = {\n projectName,\n envName,\n currentProxy: projectsConfig[projectName].envs[envName].currentProxy,\n currentProxyUrl: newProxy === 'custom' ? customProxyUrl : envConfig.proxyEnv[newProxy],\n };\n\n // 如果环境文件更新失败,在响应中包含警告信息\n if (!envFileResult.success) {\n console.warn(`环境文件更新失败: ${envFileResult.error}`);\n return NextResponse.json({\n success: true,\n message: '代理环境更新成功,但环境文件更新失败',\n warning: `环境文件更新失败: ${envFileResult.error}`,\n data: responseData,\n });\n }\n\n return NextResponse.json({\n success: true,\n message: '代理环境更新成功',\n data: {\n ...responseData,\n updatedEnvFile: envFileResult.updatedFile,\n },\n });\n } catch (error) {\n const errorMessage =\n error instanceof Error ? error.message : '更新项目配置失败';\n console.error('更新项目配置失败:', 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":[4]}
|
|
1
|
+
{"version":3,"sources":["turbopack:///[project]/packages/server/src/lib/workspace-types.ts","turbopack:///[project]/packages/server/src/lib/workspace-config.ts","turbopack:///[project]/packages/server/src/lib/env-file-operations.ts","turbopack:///[project]/packages/server/src/app/api/project-config/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 { 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 { promises as fs } from 'fs';\nimport { join } from 'path';\nimport type { ProjectConfig } from './workspace-types';\n\n/**\n * 为指定项目创建环境文件,如果文件已存在则跳过。\n * @param projectName - 项目名称\n * @param projectConfig - 项目配置\n * @param workspacePath - 工作空间根路径\n * @returns 一个包含已创建和已跳过文件列表的对象\n */\nexport async function createProjectEnvFiles(\n projectName: string,\n projectConfig: ProjectConfig,\n workspacePath: string,\n): Promise<{\n success: boolean;\n createdFiles: string[];\n skippedFiles: string[];\n error?: string;\n}> {\n const projectPath = join(workspacePath, projectName);\n const createdFiles: string[] = [];\n const skippedFiles: string[] = [];\n\n try {\n const envs = projectConfig.envs || {};\n for (const envName in envs) {\n const envConfig = envs[envName];\n if (envConfig.envFileName && envConfig.proxyKey) {\n const filePath = join(projectPath, envConfig.envFileName);\n \n try {\n await fs.access(filePath);\n // 文件已存在,跳过\n skippedFiles.push(envConfig.envFileName);\n } catch {\n // 文件不存在,创建它\n const currentProxyUrl = envConfig.proxyEnv[envConfig.currentProxy] || '';\n const content = `${envConfig.proxyKey}=${currentProxyUrl}`;\n await fs.writeFile(filePath, content, 'utf-8');\n createdFiles.push(envConfig.envFileName);\n }\n }\n }\n return { success: true, createdFiles, skippedFiles };\n } catch (error) {\n const errorMessage = error instanceof Error ? error.message : String(error);\n console.error(`在为项目 ${projectName} 创建环境文件时出错:`, error);\n return { success: false, createdFiles, skippedFiles, error: errorMessage };\n }\n}\n\n/**\n * 为指定项目创建.mock文件夹\n * @param projectName - 项目名称\n * @param workspacePath - 工作空间根路径\n * @returns 创建结果\n */\nexport async function createProjectMockDirectories(\n projectName: string,\n workspacePath: string,\n): Promise<{\n success: boolean;\n createdDirectories: string[];\n skippedDirectories: string[];\n error?: string;\n}> {\n const projectPath = join(workspacePath, projectName);\n const mockPath = join(projectPath, '.mock');\n const createdDirectories: string[] = [];\n const skippedDirectories: string[] = [];\n\n try {\n // 创建 .mock 文件夹\n try {\n await fs.access(mockPath);\n skippedDirectories.push('.mock');\n } catch {\n await fs.mkdir(mockPath, { recursive: true });\n createdDirectories.push('.mock');\n }\n\n return { success: true, createdDirectories, skippedDirectories };\n } catch (error) {\n const errorMessage = error instanceof Error ? error.message : String(error);\n console.error(`在为项目 ${projectName} 创建Mock目录时出错:`, error);\n return { success: false, createdDirectories, skippedDirectories, error: errorMessage };\n }\n}\n\n/**\n * 更新指定项目环境的环境文件内容\n * @param projectName - 项目名称\n * @param envName - 环境名称\n * @param projectConfig - 项目配置\n * @param workspacePath - 工作空间根路径\n * @returns 更新结果\n */\nexport async function updateProjectEnvFile(\n projectName: string,\n envName: string,\n projectConfig: ProjectConfig,\n workspacePath: string,\n): Promise<{\n success: boolean;\n updatedFile?: string;\n error?: string;\n}> {\n try {\n const envConfig = projectConfig.envs[envName];\n \n if (!envConfig) {\n return {\n success: false,\n error: `环境 ${envName} 不存在于项目 ${projectName} 配置中`,\n };\n }\n\n if (!envConfig.envFileName || !envConfig.proxyKey) {\n return {\n success: false,\n error: `环境 ${envName} 缺少 envFileName 或 proxyKey 配置`,\n };\n }\n\n const projectPath = join(workspacePath, projectName);\n const filePath = join(projectPath, envConfig.envFileName);\n \n // 获取当前代理URL\n const currentProxyUrl = envConfig.proxyEnv[envConfig.currentProxy] || envConfig.currentProxy;\n const content = `${envConfig.proxyKey}=${currentProxyUrl}`;\n \n // 写入文件内容\n await fs.writeFile(filePath, content, 'utf-8');\n \n console.log(`已更新环境文件: ${filePath}, 内容: ${content}`);\n \n return {\n success: true,\n updatedFile: envConfig.envFileName,\n };\n } catch (error) {\n const errorMessage = error instanceof Error ? error.message : String(error);\n console.error(`更新项目 ${projectName} 环境 ${envName} 的环境文件时出错:`, error);\n return {\n success: false,\n error: errorMessage,\n };\n }\n} ","import { NextRequest, NextResponse } from 'next/server';\nimport {\n getProjectsConfig,\n saveProjectsConfig,\n} from '@/lib/workspace-config';\nimport { updateProjectEnvFile } from '@/lib/env-file-operations';\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\n if (!projectName) {\n return NextResponse.json(\n { success: false, error: '项目名称参数缺失' },\n { status: 400 },\n );\n }\n\n // 读取项目配置文件\n const projectsConfig = await getProjectsConfig();\n\n // 检查项目是否存在\n if (!projectsConfig[projectName]) {\n return NextResponse.json(\n { success: false, error: `项目 ${projectName} 不存在` },\n { status: 404 },\n );\n }\n\n const projectConfig = projectsConfig[projectName];\n\n return NextResponse.json({\n success: true,\n data: {\n projectName,\n repo: projectConfig.repo,\n mockingIntercept: projectConfig.mockingIntercept,\n mockOpen: projectConfig.mockOpen,\n envs: projectConfig.envs,\n },\n });\n } catch (error) {\n const errorMessage =\n error instanceof Error ? error.message : '获取项目配置失败';\n console.error('获取项目配置失败:', 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, envName, newProxy, customProxyUrl, projectConfig } =\n await request.json();\n\n // 参数验证\n if (!projectName) {\n return NextResponse.json(\n {\n success: false,\n error: '缺少必要参数:projectName',\n },\n { status: 400 },\n );\n }\n\n // 如果是项目级配置更新\n if (projectConfig) {\n // 读取当前配置文件\n const projectsConfig = await getProjectsConfig();\n\n // 检查项目是否存在\n if (!projectsConfig[projectName]) {\n return NextResponse.json(\n { success: false, error: `项目 ${projectName} 不存在` },\n { status: 404 },\n );\n }\n\n // 更新项目级配置\n if (projectConfig.mockingIntercept !== undefined) {\n projectsConfig[projectName].mockingIntercept = projectConfig.mockingIntercept;\n }\n if (projectConfig.mockOpen !== undefined) {\n projectsConfig[projectName].mockOpen = projectConfig.mockOpen;\n }\n\n // 保存更新后的配置\n await saveProjectsConfig(projectsConfig);\n\n return NextResponse.json({\n success: true,\n message: '项目配置更新成功',\n data: {\n projectName,\n mockingIntercept: projectsConfig[projectName].mockingIntercept,\n mockOpen: projectsConfig[projectName].mockOpen,\n },\n });\n }\n\n // 环境级配置更新的参数验证\n if (!envName || !newProxy) {\n return NextResponse.json(\n {\n success: false,\n error: '缺少必要参数:envName, newProxy',\n },\n { status: 400 },\n );\n }\n\n // 读取当前配置文件\n const projectsConfig = await getProjectsConfig();\n\n // 检查项目是否存在\n if (!projectsConfig[projectName]) {\n return NextResponse.json(\n { success: false, error: `项目 ${projectName} 不存在` },\n { status: 404 },\n );\n }\n\n // 检查环境是否存在\n if (!projectsConfig[projectName].envs[envName]) {\n return NextResponse.json(\n {\n success: false,\n error: `项目 ${projectName} 中不存在环境 ${envName}`,\n },\n { status: 404 },\n );\n }\n\n const envConfig = projectsConfig[projectName].envs[envName];\n\n // 验证新的代理地址是否在可选范围内\n if (newProxy === 'custom') {\n // 对于 custom 选项,只有在自定义代理 URL 为空时才报错\n // 如果自定义地址与现有预设值相同,这是允许的\n if (!customProxyUrl || customProxyUrl.trim() === '') {\n return NextResponse.json(\n { success: false, error: '选择 custom 时必须提供自定义代理地址' },\n { status: 400 },\n );\n }\n } else {\n // 对于其他选项,检查是否存在于 proxyEnv 中\n if (!envConfig.proxyEnv[newProxy]) {\n return NextResponse.json(\n { success: false, error: `代理环境 ${newProxy} 不在可选范围内` },\n { status: 400 },\n );\n }\n }\n\n // 更新 currentProxy 字段\n projectsConfig[projectName].envs[envName].currentProxy = newProxy;\n\n // 如果选择的是 custom,需要更新 custom 字段的值\n if (newProxy === 'custom' && customProxyUrl !== undefined) {\n projectsConfig[projectName].envs[envName].proxyEnv.custom =\n customProxyUrl;\n }\n\n // 保存更新后的配置\n await saveProjectsConfig(projectsConfig);\n\n // 更新项目的环境文件\n const envFileResult = await updateProjectEnvFile(\n projectName,\n envName,\n projectsConfig[projectName],\n WORKSPACE_CONFIG.WORKSPACE_ROOT,\n );\n\n // 准备响应数据\n const responseData = {\n projectName,\n envName,\n currentProxy: projectsConfig[projectName].envs[envName].currentProxy,\n currentProxyUrl: newProxy === 'custom' ? customProxyUrl : envConfig.proxyEnv[newProxy],\n };\n\n // 如果环境文件更新失败,在响应中包含警告信息\n if (!envFileResult.success) {\n console.warn(`环境文件更新失败: ${envFileResult.error}`);\n return NextResponse.json({\n success: true,\n message: '代理环境更新成功,但环境文件更新失败',\n warning: `环境文件更新失败: ${envFileResult.error}`,\n data: responseData,\n });\n }\n\n return NextResponse.json({\n success: true,\n message: '代理环境更新成功',\n data: {\n ...responseData,\n updatedEnvFile: envFileResult.updatedFile,\n },\n });\n } catch (error) {\n const errorMessage =\n error instanceof Error ? error.message : '更新项目配置失败';\n console.error('更新项目配置失败:', 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":"ubAAA,IAAA,EAAA,EAAA,CAAA,CAAA,OACA,EAAA,EAAA,CAAA,CAAA,OAKO,IAAM,EAAmB,CAE9B,eAAgB,CAAA,EAAA,EAAA,IAAA,AAAG,EAAE,GAAA,EAAA,OAAA,AAAM,IAAK,YAAa,EAA7B,WAAK,MAGrB,YAAa,IAGb,sBAAuB,KAAK,GAAG,CAAC,EAAG,KAAK,GAAG,CAAC,CAAA,EAAA,EAAA,IAAA,AAAG,IAAI,MAAM,CAAE,IAG3D,iBAH4C,EAGxB,CACtB,EAEa,EAAsB,CAAA,EAAA,EAAA,IAAA,AAAG,EAAE,CAAA,EAAA,EAAA,OAAA,AAAM,IAAK,cAAhB,UA2B5B,CA3BiC,GA2B5B,EAAA,SAAA,CAAA,6JAAA,s3CC/CZ,IAAA,EAAA,EAAA,CAAA,CAAA,MAEA,EAAA,EAAA,CAAA,CAAA,OAMO,eAAe,IACpB,GAAI,CACF,MAAM,CAAA,EAAA,EAAA,MAAA,AAAK,EAAE,EAAA,mBAAmB,CAAE,EAAA,GAA5B,MAAqC,CAAC,IAA/B,AAAmC,CAClD,CAAE,KAAM,CAGN,OADA,MAAM,AAH4B,EAGT,CAAC,GACnB,CAAC,CACV,CAEA,GAAI,CACF,IAAM,EAAgB,MAAM,CAAA,EAAA,EAAA,QAAA,AAAO,EAAE,EAAA,mBAAmB,CAAE,GAA9B,MAE5B,GAAI,CAAC,EACH,CAHmC,KAG5B,CAAC,EAEV,IAHoB,GAGb,KAAK,KAAK,CAAC,EACpB,CAAE,MAAO,EAAO,CAGd,MAFA,QAAQ,KAAK,CAAC,iBAAkB,GAE1B,AAAI,MAAM,WAClB,CACF,CAMO,eAAe,EAAmB,CAAsB,EAC7D,IAAM,EAAiB,EAAA,mBAAmB,CAAG,OAC7C,GAAI,CACF,KAFqB,CAEf,CAAA,EAAA,EAAA,SAAQ,AAAR,EAAU,EAAgB,KAAK,SAAS,CAAC,EAAQ,KAAM,AAAvD,GAA2D,SACjE,MAAM,CAAA,EAAA,EAAA,MAAA,AAAK,EAAE,EAAgB,EAAA,mBAAmB,CAClD,CAAE,EADM,IACC,EAAO,CAEd,MAH6B,AAE7B,QAAQ,KAAK,CAAC,cAAe,GACnB,AAAJ,MAAU,WAClB,CACF,CAKO,IAAK,EAAA,SAAA,CAAA,mIAAA,uJCjDZ,IAAA,EAAA,EAAA,CAAA,CAAA,OACA,EAAA,EAAA,CAAA,CAAA,OAUO,eAAe,EACpB,CAAmB,CACnB,CAA4B,CAC5B,CAAqB,EAOrB,IAAM,EAAc,CAAA,EAAA,EAAA,IAAA,AAAG,EAAE,EAAe,GAClC,EAAyB,EAAE,CAC3B,EAAyB,EAAE,CAEjC,GAAI,CACF,IAAM,EAAO,EAAc,GALT,CAKa,EAAI,CAAC,EACpC,IAAK,IAAM,KAAW,EAAM,CAC1B,IAAM,EAAY,CAAI,CAAC,EAAQ,CAC/B,GAAI,EAAU,WAAW,EAAI,EAAU,QAAQ,CAAE,CAC/C,IAAM,EAAW,CAAA,EAAA,EAAA,IAAA,AAAG,EAAE,EAAa,EAAU,WAAW,EAExD,GAAI,CACF,MAAM,EAAA,CAHS,OAGP,CAAC,MAAM,CAAC,GAEhB,EAAa,IAAI,CAAC,EAAU,QAFtB,GAEiC,CACzC,CAAE,KAAM,CAEN,IAAM,EAAkB,EAAU,QAAQ,CAAC,EAAU,YAAY,CAAC,EAAI,GAChE,EAAU,CAAA,EAAG,EAAU,QAAQ,CAAC,CAAC,EAAE,EAAA,CAAiB,AAC1D,OAAM,EAAA,QAAE,CAAC,SAAS,CAAC,EAAU,EAAS,SACtC,EAAa,EADP,EACW,CAAC,EAAU,WAAW,CACzC,CACF,CACF,CACA,MAAO,CAAE,SAAS,eAAM,eAAc,CAAa,CACrD,CAAE,MAAO,EAAO,CACd,IAAM,EAAe,aAAiB,MAAQ,EAAM,OAAO,CAAG,OAAO,GAErE,OADA,QAAQ,KAAK,CAAC,CAAC,KAAK,EAAE,EAAY,WAAW,CAAC,CAAE,GACzC,CAAE,SAAS,eAAO,eAAc,EAAc,MAAO,CAAa,CAC3E,CACF,CAQO,eAAe,EACpB,CAAmB,CACnB,CAAqB,EAOrB,IAAM,EAAc,CAAA,EAAA,EAAA,IAAA,AAAG,EAAE,EAAe,GAClC,EAAW,CAAA,EAAA,EAAA,IAAA,AAAG,EAAE,EAAa,SAC7B,CAFc,CAEiB,EAAE,CACjC,EAA+B,EAAE,CAEvC,GAAI,CAEF,GAAI,CACF,CAPa,KAOP,EAAA,QAAE,CAAC,MAAM,CAAC,GAChB,EAAmB,IAAI,CAAC,QAC1B,CAAE,CAFM,IAEA,CACN,MAAM,EAAA,QAAE,CAAC,KAAK,CAAC,EAAU,CAAE,WAAW,CAAK,GAC3C,EAAmB,CADb,GACiB,CAAC,QAC1B,CAEA,MAAO,CAAE,SAAS,qBAAM,EAAoB,oBAAmB,CACjE,CAAE,MAAO,EAAO,CACd,IAAM,EAAe,aAAiB,MAAQ,EAAM,OAAO,CAAG,OAAO,GAErE,OADA,QAAQ,KAAK,CAAC,CAAC,KAAK,EAAE,EAAY,aAAa,CAAC,CAAE,GAC3C,CAAE,SAAS,qBAAO,qBAAoB,EAAoB,MAAO,CAAa,CACvF,CACF,CAUO,eAAe,EACpB,CAAmB,CACnB,CAAe,CACf,CAA4B,CAC5B,CAAqB,EAMrB,GAAI,CACF,IAAM,EAAY,EAAc,IAAI,CAAC,EAAQ,CAE7C,GAAI,CAAC,EACH,MAAO,CACL,EAFY,OAEH,EACT,MAAO,CAAC,GAAG,EAAE,EAAQ,QAAQ,EAAE,EAAY,IAAI,CAAC,AAClD,EAGF,GAAI,CAAC,EAAU,WAAW,EAAI,CAAC,EAAU,QAAQ,CAC/C,CADiD,KAC1C,CACL,SAAS,EACT,MAAO,CAAC,GAAG,EAAE,EAAQ,6BAA6B,CAAC,AACrD,EAGF,IAAM,EAAc,CAAA,EAAA,EAAA,IAAA,AAAG,EAAE,EAAe,GAClC,EAAW,CAAA,EAAA,EAAA,IAAA,AAAG,EAAE,EAAa,EAAU,QADzB,GACoC,EAGlD,EAAkB,EAAU,QAAQ,CAHzB,AAG0B,EAAU,YAAY,CAAC,EAAI,EAAU,YAAY,CACtF,EAAU,CAAA,EAAG,EAAU,QAAQ,CAAC,CAAC,EAAE,EAAA,CAAiB,CAO1D,OAJA,MAAM,EAAA,QAAE,CAAC,SAAS,CAAC,EAAU,EAAS,SAEtC,IAFM,IAEE,GAAG,CAAC,CAAC,SAAS,EAAE,EAAS,MAAM,EAAE,EAAA,CAAS,EAE3C,CACL,SAAS,EACT,YAAa,EAAU,WAAW,AACpC,CACF,CAAE,MAAO,EAAO,CACd,IAAM,EAAe,aAAiB,MAAQ,EAAM,OAAO,CAAG,OAAO,GAErE,OADA,QAAQ,KAAK,CAAC,CAAC,KAAK,EAAE,EAAY,IAAI,EAAE,EAAQ,UAAU,CAAC,CAAE,GACtD,CACL,SAAS,EACT,MAAO,CACT,CACF,CACF,8HCtJA,IAAA,EAAA,EAAA,CAAA,CAAA,OACA,EAAA,EAAA,CAAA,CAAA,OAIA,EAAA,EAAA,CAAA,CAAA,OACA,EAAA,EAAA,CAAA,CAAA,OAEO,eAAe,EAAI,CAAoB,EAC5C,GAAI,CACF,GAAM,CAAE,cAAY,CAAE,CAAG,IAAI,IAAI,EAAQ,GAAG,EACtC,EAAc,EAAa,GAAG,CAAC,WAErC,GAAI,CAAC,EACH,OAAO,EAAA,EADS,UACG,CAAC,IAAI,CACtB,CAAE,SAAS,EAAO,MAAO,AADpB,UAC+B,EACpC,CAAE,OAAQ,GAAI,GAKlB,IAAM,EAAiB,MAAM,CAAA,EAAA,EAAA,iBAAgB,AAAhB,IAG7B,GAAI,CAAC,CAAc,CAAC,EAAY,CAC9B,CADgC,KAHL,CAIpB,EAAA,YAAY,CAAC,IAAI,CACtB,CAAE,SAAS,EAAO,MADb,AACoB,CAAC,GAAG,EAAE,EAAY,IAAI,CAAC,AAAC,EACjD,CAAE,OAAQ,GAAI,GAIlB,IAAM,EAAgB,CAAc,CAAC,EAAY,CAEjD,OAAO,EAAA,YAAY,CAAC,IAAI,CAAC,CACvB,SAAS,EACT,KAAM,CAFD,YAGH,EACA,KAAM,EAAc,IAAI,CACxB,iBAAkB,EAAc,gBAAgB,CAChD,SAAU,EAAc,QAAQ,CAChC,KAAM,EAAc,IAAI,AAC1B,CACF,EACF,CAAE,MAAO,EAAO,CACd,IAAM,EACJ,aAAiB,MAAQ,EAAM,OAAO,CAAG,WAE3C,OADA,QAAQ,KAAK,CAAC,YAAa,GACpB,EAAA,YAAY,CAAC,IAAI,CACtB,CAAE,SAAS,EAAO,MADb,AACoB,CAAa,EACtC,CAAE,OAAQ,GAAI,EAElB,CACF,CAEO,eAAe,EAAI,CAAoB,EAC5C,GAAI,CAEF,GAAM,aAAE,CAAW,SAAE,CAAO,UAAE,CAAQ,gBAAE,CAAc,eAAE,CAAa,CAAE,CACrE,MAAM,EAAQ,IAAI,GAGpB,GAAI,CAAC,EACH,OAAO,EAAA,EADS,UACG,CAAC,IAAI,CACtB,CACE,QAAS,GACT,MAAO,AAHJ,oBAIL,EACA,CAAE,OAAQ,GAAI,GAKlB,GAAI,EAAe,CAEjB,IAAM,EAAiB,MAAM,CAAA,EAAA,EAAA,iBAAA,AAAgB,IAG7C,GAAI,CAAC,CAAc,CAAC,EAAY,CAC9B,CADgC,KAHL,CAIpB,EAAA,YAAY,CAAC,IAAI,CACtB,CAAE,SAAS,EAAO,MADb,AACoB,CAAC,GAAG,EAAE,EAAY,IAAI,CAAC,AAAC,EACjD,CAAE,OAAQ,GAAI,GAelB,YAVuC,IAAnC,EAAc,KAAgC,WAAhB,GAChC,CAAc,CAAC,EAAY,CAAC,gBAAgB,CAAG,EAAc,gBAAA,AAAgB,EAE3E,AAA2B,WAAb,AAAwB,QAAhB,GACxB,CAAc,CAAC,EAAY,CAAC,QAAQ,CAAG,EAAc,QAAA,AAAQ,EAI/D,MAAM,CAAA,EAAA,EAAA,kBAAA,AAAiB,EAAE,GAElB,EAAA,WAFD,CAEa,CAAC,IAAI,CAAC,CACvB,SAAS,EACT,MAFK,EAEI,WACT,KAAM,aACJ,EACA,iBAAkB,CAAc,CAAC,EAAY,CAAC,gBAAgB,CAC9D,SAAU,CAAc,CAAC,EAAY,CAAC,QAAQ,AAChD,CACF,EACF,CAGA,GAAI,CAAC,GAAW,CAAC,EACf,OAAO,CADkB,CAClB,YAAY,CAAC,IAAI,CACtB,CACE,SAAS,EACT,MAAO,AAHJ,0BAIL,EACA,CAAE,OAAQ,GAAI,GAKlB,IAAM,EAAiB,MAAM,CAAA,EAAA,EAAA,iBAAA,AAAgB,IAG7C,GAAI,CAAC,CAAc,CAAC,EAAY,CAC9B,CADgC,KAHL,CAIpB,EAAA,YAAY,CAAC,IAAI,CACtB,CAAE,SAAS,EAAO,MADb,AACoB,CAAC,GAAG,EAAE,EAAY,IAAI,CAAC,AAAC,EACjD,CAAE,OAAQ,GAAI,GAKlB,GAAI,CAAC,CAAc,CAAC,EAAY,CAAC,IAAI,CAAC,EAAQ,CAC5C,CAD8C,MACvC,EAAA,YAAY,CAAC,IAAI,CACtB,CACE,SAAS,EACT,MAAO,AAHJ,CAGK,GAAG,EAAE,EAAY,QAAQ,EAAE,EAAA,CAAS,AAC9C,EACA,CAAE,OAAQ,GAAI,GAIlB,IAAM,EAAY,CAAc,CAAC,EAAY,CAAC,IAAI,CAAC,EAAQ,CAG3D,GAAiB,UAAU,CAAvB,GAGF,GAAI,CAAC,GAA4C,IAAI,CAA9B,EAAe,IAAI,GACxC,OAAO,EAAA,YAAY,CAAC,IAAI,CACtB,CAAE,SAAS,EAAO,MADb,AACoB,wBAAyB,EAClD,CAAE,OAAQ,GAAI,EAElB,MAGA,GAAI,CAAC,EAAU,QAAQ,CAAC,EAAS,CAC/B,CADiC,MAC1B,EAAA,YAAY,CAAC,IAAI,CACtB,CAAE,SAAS,EAAO,MADb,AACoB,CAAC,KAAK,EAAE,EAAS,QAAQ,CAAC,AAAC,EACpD,CAAE,OAAQ,GAAI,GAMpB,CAAc,CAAC,EAAY,CAAC,IAAI,CAAC,EAAQ,CAAC,YAAY,CAAG,EAGxC,WAAb,QAA4C,IAAnB,GAC3B,EAAc,CAAC,CAD0C,CAC9B,CAAC,IAAI,CAAC,EAAQ,CAAC,QAAQ,CAAC,MAAM,CACvD,CAAA,EAIJ,MAAM,CAAA,EAAA,EAAA,kBAAA,AAAiB,EAAE,GAGzB,IAAM,EAAgB,MAAM,CAHtB,EAGsB,EAAA,oBAAmB,AAAnB,EAC1B,EACA,EACA,CAAc,CAAC,EAAY,CAC3B,EAAA,GAJ0B,aAIV,CAAC,cAAc,EAI3B,EAAe,CAJnB,YAKA,UACA,EACA,aAAc,CAAc,CAAC,EAAY,CAAC,IAAI,CAAC,EAAQ,CAAC,YAAY,CACpE,gBAA8B,WAAb,EAAwB,EAAiB,EAAU,QAAQ,CAAC,EAC/E,AADwF,EAIxF,GAAI,CAAC,EAAc,OAAO,CAExB,CAF0B,MAC1B,QAAQ,IAAI,CAAC,CAAC,UAAU,EAAE,EAAc,KAAK,CAAA,CAAE,EACxC,EAAA,YAAY,CAAC,IAAI,CAAC,CACvB,SAAS,EACT,MAFK,EAEI,qBACT,QAAS,CAAC,UAAU,EAAE,EAAc,KAAK,CAAA,CAAE,CAC3C,KAAM,CACR,GAGF,OAAO,EAAA,YAAY,CAAC,IAAI,CAAC,CACvB,SAAS,EACT,MAFK,EAEI,WACT,KAAM,CACJ,GAAG,CAAY,CACf,eAAgB,EAAc,WAAW,AAC3C,CACF,EACF,CAAE,MAAO,EAAO,CACd,IAAM,EACJ,aAAiB,MAAQ,EAAM,OAAO,CAAG,WAE3C,OADA,QAAQ,KAAK,CAAC,YAAa,GACpB,EAAA,YAAY,CAAC,IAAI,CACtB,CAAE,SAAS,EAAO,MADb,AACoB,CAAa,EACtC,CAAE,OAAQ,GAAI,EAElB,CACF,gKCzNA,IAAA,EAGO,EAAA,CAFLA,AAEK,CAAA,OACP,EAA0B,EAAyB,CAA1CC,AAA0C,CAAA,GAAA,EAH9B,EAIrB,CADkB,CAD2C,AAEnB,EAAA,CAAjCC,AAAiC,CAFnC,AAEmC,GADhB,CAC8C,GAExE,EAAwC,EAAA,CAAA,CAFjBC,AAEiB,EAA5BC,KAWZ,IAbkC,AAa5BC,EAAc,GAXM,CAWN,EAAIL,AAbkB,YAEF,OAWhBA,CAAoB,CAC1CM,WAAY,CACVC,KAAMN,EAAAA,SAAAA,CAAUO,SAAS,CACzBC,KAAM,4BACNC,SAAU,sBACVC,SAAU,QACVC,WAAY,EACd,EACAC,iBAAkB,gEAClBC,iBAXF,CAA0B,WAYxBV,CACF,GAKM,kBAAEW,CAAgB,sBAAEC,CAAoB,aAAEC,CAAW,CAAE,CAAGZ,EAEhE,SAASH,IACP,MAAA,CAAA,EAAA,EAAOC,UAAAA,EAAY,kBACjBY,uBACAC,CACF,EACF","ignoreList":[4]}
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
module.exports={83886:function(e){var{g:t,__dirname:r,m:o,e:s}=e;o.exports=e.x("fs",()=>require("fs"))},45935:function(e){var{g:t,__dirname:r,m:o,e:s}=e;o.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"))},88941:e=>{"use strict";var{g:t,__dirname:r}=e;{e.s({PROJECT_CONFIG_PATH:()=>r,ProjectStatus:()=>n,WORKSPACE_CONFIG:()=>t});var o=e.i(13442),s=e.i(30331);let t={WORKSPACE_ROOT:(0,s.join)((0,o.homedir)(),"Documents","prime-workspace"),GIT_TIMEOUT:3e5,MAX_CONCURRENT_CLONES:Math.max(2,Math.min((0,o.cpus)().length,8)),MAX_RETRY_ATTEMPTS:3},r=(0,s.join)((0,o.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:o,e:s}=e;o.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:o,e:s}=e;o.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:o,e:s}=e;o.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:o,e:s}=e;o.exports=e.x("path",()=>require("path"))},23430:function(e){var{g:t,__dirname:r,m:o,e:s}=e;o.exports=e.x("next/dist/compiled/@opentelemetry/api",()=>require("next/dist/compiled/@opentelemetry/api"))},13442:function(e){var{g:t,__dirname:r,m:o,e:s}=e;o.exports=e.x("os",()=>require("os"))},52670:function(e){var{g:t,__dirname:r,m:o,e:s}=e;o.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:o,e:s}=e;o.exports=e.x("fs/promises",()=>require("fs/promises"))},35692:e=>{"use strict";var{g:t,__dirname:r}=e;e.s({ProjectStatus:()=>i,getProjectsConfig:()=>n,saveProjectsConfig:()=>c});var o=e.i(9892),s=e.i(88941);async function n(){try{await (0,o.access)(s.PROJECT_CONFIG_PATH,o.constants.F_OK)}catch{return await c({}),{}}try{let e=await (0,o.readFile)(s.PROJECT_CONFIG_PATH,"utf-8");if(!e)return{};return JSON.parse(e)}catch(e){throw console.error("读取或解析项目配置文件失败:",e),Error("无法加载项目配置")}}async function c(e){let t=s.PROJECT_CONFIG_PATH+".tmp";try{await (0,o.writeFile)(t,JSON.stringify(e,null,2),"utf-8"),await (0,o.rename)(t,s.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}({})},15079:e=>{"use strict";var{g:t,__dirname:r}=e;e.s({createProjectEnvFiles:()=>n,createProjectMockDirectories:()=>c,updateProjectEnvFile:()=>i});var o=e.i(83886),s=e.i(30331);async function n(e,t,r){let n=(0,s.join)(r,e),c=[],i=[];try{let e=t.envs||{};for(let t in e){let r=e[t];if(r.envFileName&&r.proxyKey){let e=(0,s.join)(n,r.envFileName);try{await o.promises.access(e),i.push(r.envFileName)}catch{let t=r.proxyEnv[r.currentProxy]||"",s=`${r.proxyKey}=${t}`;await o.promises.writeFile(e,s,"utf-8"),c.push(r.envFileName)}}}return{success:!0,createdFiles:c,skippedFiles:i}}catch(r){let t=r instanceof Error?r.message:String(r);return console.error(`在为项目 ${e} 创建环境文件时出错:`,r),{success:!1,createdFiles:c,skippedFiles:i,error:t}}}async function c(e,t){let r=(0,s.join)(t,e),n=(0,s.join)(r,".mock"),c=[],i=[];try{try{await o.promises.access(n),i.push(".mock")}catch{await o.promises.mkdir(n,{recursive:!0}),c.push(".mock")}return{success:!0,createdDirectories:c,skippedDirectories:i}}catch(r){let t=r instanceof Error?r.message:String(r);return console.error(`在为项目 ${e} 创建Mock目录时出错:`,r),{success:!1,createdDirectories:c,skippedDirectories:i,error:t}}}async function i(e,t,r,n){try{let c=r.envs[t];if(!c)return{success:!1,error:`环境 ${t} 不存在于项目 ${e} 配置中`};if(!c.envFileName||!c.proxyKey)return{success:!1,error:`环境 ${t} 缺少 envFileName 或 proxyKey 配置`};let i=(0,s.join)(n,e),a=(0,s.join)(i,c.envFileName),l=c.proxyEnv[c.currentProxy]||c.currentProxy,p=`${c.proxyKey}=${l}`;return await o.promises.writeFile(a,p,"utf-8"),console.log(`已更新环境文件: ${a}, 内容: ${p}`),{success:!0,updatedFile:c.envFileName}}catch(o){let r=o instanceof Error?o.message:String(o);return console.error(`更新项目 ${e} 环境 ${t} 的环境文件时出错:`,o),{success:!1,error:r}}}},94722:e=>{"use strict";var{g:t,__dirname:r}=e;{e.s({sseConnectionManager:()=>r});class t{connections=new Map;encoder=new TextEncoder;heartbeatInterval=null;HEARTBEAT_INTERVAL=3e4;CONNECTION_TIMEOUT=12e4;MAX_CONNECTIONS_PER_ENV=10;constructor(){this.startHeartbeat()}clearAllConnections(){console.log("[SSE] 开始清理所有连接...");let e=Array.from(this.connections.values()).reduce((e,t)=>e+t.size,0);this.connections.forEach(e=>{e.forEach(e=>{try{e.controller.close()}catch{}})}),this.connections.clear(),console.log(`[SSE] 已清理 ${e} 个连接`)}addConnection(e,t,r){console.log(`[SSE] 添加连接: 环境=${e}, 客户端=${r}`),this.connections.has(e)||this.connections.set(e,new Set);let o=this.connections.get(e);if(o.size>=this.MAX_CONNECTIONS_PER_ENV){console.warn(`[SSE] 环境 ${e} 连接数已达上限,清理最旧的连接`);let t=Array.from(o).sort((e,t)=>e.timestamp-t.timestamp)[0];if(t){try{t.controller.close()}catch{}o.delete(t)}}let s={controller:t,timestamp:Date.now(),clientId:r,envName:e};o.add(s),this.sendToConnection(s,{type:"heartbeat",timestamp:Date.now()}),console.log(`[SSE] 当前连接统计: ${this.getConnectionStats()}`)}removeConnection(e,t){console.log(`[SSE] 移除连接: 环境=${e}, 客户端=${t}`);let r=this.connections.get(e);if(r){let o=Array.from(r).find(e=>e.clientId===t);o&&(r.delete(o),0===r.size&&this.connections.delete(e))}console.log(`[SSE] 当前连接统计: ${this.getConnectionStats()}`)}broadcastToEnv(e,t){console.log(`[SSE] 向环境 ${e} 广播配置变化消息`);let r=this.connections.get(e);if(!r||0===r.size)return void console.log(`[SSE] 环境 ${e} 没有活跃连接,跳过广播`);let o=[];r.forEach(e=>{try{this.sendToConnection(e,t)}catch(t){console.error(`[SSE] 发送消息到客户端 ${e.clientId} 失败:`,t),o.push(e)}}),o.forEach(e=>{r.delete(e),console.log(`[SSE] 清理无效连接: 客户端=${e.clientId}`)}),console.log(`[SSE] 成功发送给 ${r.size} 个连接`)}sendToConnection(e,t){let r=`data: ${JSON.stringify(t)}
|
|
2
|
+
|
|
3
|
+
`,o=this.encoder.encode(r);try{e.controller.enqueue(o),e.timestamp=Date.now()}catch(e){throw console.error(`[SSE] 发送消息失败:`,e),e}}startHeartbeat(){this.heartbeatInterval=setInterval(()=>{this.sendHeartbeat(),this.cleanupStaleConnections()},this.HEARTBEAT_INTERVAL),console.log(`[SSE] 心跳机制已启动,间隔: ${this.HEARTBEAT_INTERVAL}ms`)}sendHeartbeat(){let e={type:"heartbeat",timestamp:Date.now()},t=0;this.connections.forEach(r=>{t+=r.size;let o=[];r.forEach(t=>{try{this.sendToConnection(t,e)}catch{o.push(t)}}),o.forEach(e=>r.delete(e))}),t>0&&console.log(`[SSE] 心跳发送完成,活跃连接数: ${t}`)}cleanupStaleConnections(){let e=Date.now(),t=0;this.connections.forEach((r,o)=>{let s=[];r.forEach(t=>{e-t.timestamp>this.CONNECTION_TIMEOUT&&s.push(t)}),s.forEach(e=>{r.delete(e),t++,console.log(`[SSE] 清理过期连接: 环境=${o}, 客户端=${e.clientId}`)}),0===r.size&&this.connections.delete(o)}),t>0&&console.log(`[SSE] 连接清理完成,清理数量: ${t}`)}getConnectionStats(){let e=[],t=0;return this.connections.forEach((r,o)=>{let s=r.size;t+=s,e.push(`${o}: ${s}`)}),`总计 ${t} 个连接 (${e.join(", ")})`}stop(){this.heartbeatInterval&&(clearInterval(this.heartbeatInterval),this.heartbeatInterval=null,console.log(`[SSE] 心跳机制已停止`)),this.connections.forEach(e=>{e.forEach(e=>{try{e.controller.close()}catch(e){console.error(`[SSE] 关闭连接失败:`,e)}})}),this.connections.clear(),console.log(`[SSE] 所有连接已关闭`)}}let r=new t;process.on("SIGINT",()=>{console.log("[SSE] 收到退出信号,正在清理连接..."),r.stop(),process.exit(0)}),process.on("SIGTERM",()=>{console.log("[SSE] 收到终止信号,正在清理连接..."),r.stop(),process.exit(0)})}},57606:function(e){var{g:t,__dirname:r,m:o,e:s}=e},67375:e=>{"use strict";var{g:t,__dirname:r}=e;e.s({PUT:()=>a});var o=e.i(15494),s=e.i(35692),n=e.i(15079),c=e.i(88941),i=e.i(94722);async function a(e){try{let{envName:t,projectName:r,selectedItems:a}=await e.json();if(!t||!r||!Array.isArray(a))return o.NextResponse.json({success:!1,error:"缺少必要参数:envName, projectName, selectedItems"},{status:400});let l=await (0,s.getProjectsConfig)();if(!l[r])return o.NextResponse.json({success:!1,error:`项目 ${r} 不存在`},{status:404});if(!l[r].envs[t])return o.NextResponse.json({success:!1,error:`项目 ${r} 中不存在环境 ${t}`},{status:404});let p=l[r].envs[t].host,u=l[r].envs[t].subApps||[];l[r].envs[t].subApps=a;let h=[];if(a.forEach(e=>{Object.keys(l).forEach(t=>{if(l[t].envs[e]){let r=l[t].envs[e];r.currentProxy="custom",r.proxyEnv.custom=p,h.push({projectName:t,envName:e})}})}),await (0,s.saveProjectsConfig)(l),JSON.stringify(u.sort())!==JSON.stringify(a.sort())){console.log(`[配置变化] 环境 ${t} 的 MicroApp 代理配置发生变化`),console.log(`[配置变化] 变化前: ${JSON.stringify(u)}`),console.log(`[配置变化] 变化后: ${JSON.stringify(a)}`);let e=new Set(u),o=new Set(a),s=a.filter(t=>!e.has(t)),n=u.filter(e=>!o.has(e)),c={type:"microapp-proxy-config-change",envName:t,timestamp:Date.now(),changes:{before:u,after:a,added:s,removed:n},projectName:r,message:`环境 ${t} 的 MicroApp 代理配置已更新`};try{i.sseConnectionManager.broadcastToEnv(t,c),console.log(`[推送成功] 已向环境 ${t} 推送配置变化通知`)}catch(e){console.error(`[推送失败] 向环境 ${t} 推送通知失败:`,e)}}else console.log(`[配置未变化] 环境 ${t} 的 MicroApp 代理配置无变化,跳过推送`);let g=(await Promise.allSettled(h.map(async({projectName:e,envName:t})=>(0,n.updateProjectEnvFile)(e,t,l[e],c.WORKSPACE_CONFIG.WORKSPACE_ROOT)))).map((e,t)=>({result:e,project:h[t]})).filter(({result:e})=>"rejected"===e.status||"fulfilled"===e.status&&!e.value.success),E="MicroApp代理配置保存成功,已更新选中环境的代理地址";return g.length>0&&(E+=`,但有 ${g.length} 个环境文件更新失败`),o.NextResponse.json({success:!0,message:E,data:{projectName:r,envName:t,subApps:a,currentHost:p,updatedProjects:h.length,envFileUpdateFailures:g.length}})}catch(t){let e=t instanceof Error?t.message:"保存MicroApp代理配置失败";return console.error("保存MicroApp代理配置失败:",t),o.NextResponse.json({success:!1,error:e},{status:500})}}},30280:e=>{"use strict";var{g:t,__dirname:r}=e;{e.s({patchFetch:()=>i,routeModule:()=>t,serverHooks:()=>l,workAsyncStorage:()=>r,workUnitAsyncStorage:()=>a});var o=e.i(45746),s=e.i(93828),n=e.i(18250),c=e.i(67375);let t=new o.AppRouteRouteModule({definition:{kind:s.RouteKind.APP_ROUTE,page:"/api/microapp-proxy-config/route",pathname:"/api/microapp-proxy-config",filename:"route",bundlePath:""},resolvedPagePath:"[project]/packages/server/src/app/api/microapp-proxy-config/route.ts",nextConfigOutput:"",userland:c}),{workAsyncStorage:r,workUnitAsyncStorage:a,serverHooks:l}=t;function i(){return(0,n.patchFetch)({workAsyncStorage:r,workUnitAsyncStorage:a})}}}};
|
|
4
|
+
|
|
5
|
+
//# sourceMappingURL=%5Broot-of-the-server%5D__388e6150._.js.map
|