prime-dev-cli 1.0.17 → 1.0.19

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (321) hide show
  1. package/bin/cli.mjs +6 -1
  2. package/dist/server/.next/BUILD_ID +1 -1
  3. package/dist/server/.next/app-build-manifest.json +20 -24
  4. package/dist/server/.next/app-path-routes-manifest.json +4 -0
  5. package/dist/server/.next/build-manifest.json +9 -10
  6. package/dist/server/.next/cache/.rscinfo +1 -1
  7. package/dist/server/.next/cache/.tsbuildinfo +1 -1
  8. package/dist/server/.next/cache/eslint/.cache_1qa5vxt +1 -1
  9. package/dist/server/.next/fallback-build-manifest.json +6 -6
  10. package/dist/server/.next/next-minimal-server.js.nft.json +1 -1
  11. package/dist/server/.next/next-server.js.nft.json +1 -1
  12. package/dist/server/.next/prerender-manifest.json +9 -9
  13. package/dist/server/.next/required-server-files.json +1 -0
  14. package/dist/server/.next/server/app/_not-found/page/app-build-manifest.json +4 -5
  15. package/dist/server/.next/server/app/_not-found/page/build-manifest.json +3 -4
  16. package/dist/server/.next/server/app/_not-found/page.js +1 -1
  17. package/dist/server/.next/server/app/_not-found/page.js.nft.json +1 -1
  18. package/dist/server/.next/server/app/_not-found/page_client-reference-manifest.js +1 -1
  19. package/dist/server/.next/server/app/_not-found.html +1 -1
  20. package/dist/server/.next/server/app/_not-found.rsc +2 -2
  21. package/dist/server/.next/server/app/api/admin-status/route/app-build-manifest.json +10 -0
  22. package/dist/server/.next/server/app/api/admin-status/route/app-paths-manifest.json +3 -0
  23. package/dist/server/.next/server/app/api/admin-status/route/build-manifest.json +16 -0
  24. package/dist/server/.next/server/app/api/admin-status/route/next-font-manifest.json +6 -0
  25. package/dist/server/.next/server/app/api/admin-status/route/react-loadable-manifest.json +1 -0
  26. package/dist/server/.next/server/app/api/admin-status/route/server-reference-manifest.json +4 -0
  27. package/dist/server/.next/server/app/api/admin-status/route.js +8 -0
  28. package/dist/server/.next/server/app/api/admin-status/route.js.map +5 -0
  29. package/dist/server/.next/server/app/api/admin-status/route.js.nft.json +1 -0
  30. package/dist/server/.next/server/app/api/admin-status/route_client-reference-manifest.js +2 -0
  31. package/dist/server/.next/server/app/api/all-projects-envs/route/app-build-manifest.json +3 -4
  32. package/dist/server/.next/server/app/api/all-projects-envs/route/build-manifest.json +3 -4
  33. package/dist/server/.next/server/app/api/all-projects-envs/route.js +1 -1
  34. package/dist/server/.next/server/app/api/all-projects-envs/route.js.nft.json +1 -1
  35. package/dist/server/.next/server/app/api/check-mock-intercept/route/app-build-manifest.json +3 -4
  36. package/dist/server/.next/server/app/api/check-mock-intercept/route/build-manifest.json +3 -4
  37. package/dist/server/.next/server/app/api/check-mock-intercept/route.js +1 -1
  38. package/dist/server/.next/server/app/api/check-mock-intercept/route.js.nft.json +1 -1
  39. package/dist/server/.next/server/app/api/check-workspace/route/app-build-manifest.json +3 -4
  40. package/dist/server/.next/server/app/api/check-workspace/route/build-manifest.json +3 -4
  41. package/dist/server/.next/server/app/api/check-workspace/route.js +1 -1
  42. package/dist/server/.next/server/app/api/check-workspace/route.js.nft.json +1 -1
  43. package/dist/server/.next/server/app/api/cleanup-mock/route/app-build-manifest.json +3 -4
  44. package/dist/server/.next/server/app/api/cleanup-mock/route/build-manifest.json +3 -4
  45. package/dist/server/.next/server/app/api/cleanup-mock/route.js +1 -1
  46. package/dist/server/.next/server/app/api/cleanup-mock/route.js.nft.json +1 -1
  47. package/dist/server/.next/server/app/api/cleanup-project/route/app-build-manifest.json +3 -4
  48. package/dist/server/.next/server/app/api/cleanup-project/route/build-manifest.json +3 -4
  49. package/dist/server/.next/server/app/api/cleanup-project/route.js +1 -1
  50. package/dist/server/.next/server/app/api/cleanup-project/route.js.nft.json +1 -1
  51. package/dist/server/.next/server/app/api/current-branch/route/app-build-manifest.json +3 -4
  52. package/dist/server/.next/server/app/api/current-branch/route/build-manifest.json +3 -4
  53. package/dist/server/.next/server/app/api/current-branch/route.js +1 -1
  54. package/dist/server/.next/server/app/api/current-branch/route.js.nft.json +1 -1
  55. package/dist/server/.next/server/app/api/delete-mock-api/route/app-build-manifest.json +3 -4
  56. package/dist/server/.next/server/app/api/delete-mock-api/route/build-manifest.json +3 -4
  57. package/dist/server/.next/server/app/api/delete-mock-api/route.js +1 -1
  58. package/dist/server/.next/server/app/api/delete-mock-api/route.js.nft.json +1 -1
  59. package/dist/server/.next/server/app/api/get-mock-data/route/app-build-manifest.json +3 -4
  60. package/dist/server/.next/server/app/api/get-mock-data/route/build-manifest.json +3 -4
  61. package/dist/server/.next/server/app/api/get-mock-data/route.js +1 -1
  62. package/dist/server/.next/server/app/api/get-mock-data/route.js.nft.json +1 -1
  63. package/dist/server/.next/server/app/api/initialize-workspace/route/app-build-manifest.json +3 -4
  64. package/dist/server/.next/server/app/api/initialize-workspace/route/build-manifest.json +3 -4
  65. package/dist/server/.next/server/app/api/initialize-workspace/route.js +1 -1
  66. package/dist/server/.next/server/app/api/initialize-workspace/route.js.nft.json +1 -1
  67. package/dist/server/.next/server/app/api/memory-status/route/app-build-manifest.json +3 -4
  68. package/dist/server/.next/server/app/api/memory-status/route/build-manifest.json +3 -4
  69. package/dist/server/.next/server/app/api/memory-status/route.js +1 -1
  70. package/dist/server/.next/server/app/api/memory-status/route.js.nft.json +1 -1
  71. package/dist/server/.next/server/app/api/microapp-proxy-change-stream/route/app-build-manifest.json +3 -4
  72. package/dist/server/.next/server/app/api/microapp-proxy-change-stream/route/build-manifest.json +3 -4
  73. package/dist/server/.next/server/app/api/microapp-proxy-change-stream/route.js +1 -1
  74. package/dist/server/.next/server/app/api/microapp-proxy-change-stream/route.js.nft.json +1 -1
  75. package/dist/server/.next/server/app/api/microapp-proxy-config/route/app-build-manifest.json +3 -4
  76. package/dist/server/.next/server/app/api/microapp-proxy-config/route/build-manifest.json +3 -4
  77. package/dist/server/.next/server/app/api/microapp-proxy-config/route.js +1 -1
  78. package/dist/server/.next/server/app/api/microapp-proxy-config/route.js.nft.json +1 -1
  79. package/dist/server/.next/server/app/api/mock-file/route/app-build-manifest.json +3 -4
  80. package/dist/server/.next/server/app/api/mock-file/route/build-manifest.json +3 -4
  81. package/dist/server/.next/server/app/api/mock-file/route.js +1 -1
  82. package/dist/server/.next/server/app/api/mock-file/route.js.nft.json +1 -1
  83. package/dist/server/.next/server/app/api/mock-file-content/route/app-build-manifest.json +3 -4
  84. package/dist/server/.next/server/app/api/mock-file-content/route/build-manifest.json +3 -4
  85. package/dist/server/.next/server/app/api/mock-file-content/route.js +1 -1
  86. package/dist/server/.next/server/app/api/mock-file-content/route.js.nft.json +1 -1
  87. package/dist/server/.next/server/app/api/mock-open-status/route/app-build-manifest.json +3 -4
  88. package/dist/server/.next/server/app/api/mock-open-status/route/build-manifest.json +3 -4
  89. package/dist/server/.next/server/app/api/mock-open-status/route.js +1 -1
  90. package/dist/server/.next/server/app/api/mock-open-status/route.js.nft.json +1 -1
  91. package/dist/server/.next/server/app/api/mock-setting/route/app-build-manifest.json +3 -4
  92. package/dist/server/.next/server/app/api/mock-setting/route/build-manifest.json +3 -4
  93. package/dist/server/.next/server/app/api/mock-setting/route.js +1 -1
  94. package/dist/server/.next/server/app/api/mock-setting/route.js.nft.json +1 -1
  95. package/dist/server/.next/server/app/api/open-all-mock/route/app-build-manifest.json +3 -4
  96. package/dist/server/.next/server/app/api/open-all-mock/route/build-manifest.json +3 -4
  97. package/dist/server/.next/server/app/api/open-all-mock/route.js +1 -1
  98. package/dist/server/.next/server/app/api/open-all-mock/route.js.nft.json +1 -1
  99. package/dist/server/.next/server/app/api/open-project/route/app-build-manifest.json +3 -4
  100. package/dist/server/.next/server/app/api/open-project/route/build-manifest.json +3 -4
  101. package/dist/server/.next/server/app/api/open-project/route.js +1 -1
  102. package/dist/server/.next/server/app/api/open-project/route.js.nft.json +1 -1
  103. package/dist/server/.next/server/app/api/process/logs/route/app-build-manifest.json +3 -4
  104. package/dist/server/.next/server/app/api/process/logs/route/build-manifest.json +3 -4
  105. package/dist/server/.next/server/app/api/process/logs/route.js +1 -1
  106. package/dist/server/.next/server/app/api/process/logs/route.js.nft.json +1 -1
  107. package/dist/server/.next/server/app/api/process/logs/stream/route/app-build-manifest.json +3 -4
  108. package/dist/server/.next/server/app/api/process/logs/stream/route/build-manifest.json +3 -4
  109. package/dist/server/.next/server/app/api/process/logs/stream/route.js +1 -1
  110. package/dist/server/.next/server/app/api/process/logs/stream/route.js.nft.json +1 -1
  111. package/dist/server/.next/server/app/api/process/start/route/app-build-manifest.json +3 -4
  112. package/dist/server/.next/server/app/api/process/start/route/build-manifest.json +3 -4
  113. package/dist/server/.next/server/app/api/process/start/route.js +1 -1
  114. package/dist/server/.next/server/app/api/process/start/route.js.nft.json +1 -1
  115. package/dist/server/.next/server/app/api/process/status/route/app-build-manifest.json +3 -4
  116. package/dist/server/.next/server/app/api/process/status/route/build-manifest.json +3 -4
  117. package/dist/server/.next/server/app/api/process/status/route.js +1 -1
  118. package/dist/server/.next/server/app/api/process/status/route.js.nft.json +1 -1
  119. package/dist/server/.next/server/app/api/project-config/route/app-build-manifest.json +3 -4
  120. package/dist/server/.next/server/app/api/project-config/route/build-manifest.json +3 -4
  121. package/dist/server/.next/server/app/api/project-config/route.js +1 -1
  122. package/dist/server/.next/server/app/api/project-config/route.js.nft.json +1 -1
  123. package/dist/server/.next/server/app/api/retry-project/route/app-build-manifest.json +3 -4
  124. package/dist/server/.next/server/app/api/retry-project/route/build-manifest.json +3 -4
  125. package/dist/server/.next/server/app/api/retry-project/route.js +1 -1
  126. package/dist/server/.next/server/app/api/retry-project/route.js.nft.json +1 -1
  127. package/dist/server/.next/server/app/api/uat-git-flow/abort/route/app-build-manifest.json +10 -0
  128. package/dist/server/.next/server/app/api/uat-git-flow/abort/route/app-paths-manifest.json +3 -0
  129. package/dist/server/.next/server/app/api/uat-git-flow/abort/route/build-manifest.json +16 -0
  130. package/dist/server/.next/server/app/api/uat-git-flow/abort/route/next-font-manifest.json +6 -0
  131. package/dist/server/.next/server/app/api/uat-git-flow/abort/route/react-loadable-manifest.json +1 -0
  132. package/dist/server/.next/server/app/api/uat-git-flow/abort/route/server-reference-manifest.json +4 -0
  133. package/dist/server/.next/server/app/api/uat-git-flow/abort/route.js +8 -0
  134. package/dist/server/.next/server/app/api/uat-git-flow/abort/route.js.map +5 -0
  135. package/dist/server/.next/server/app/api/uat-git-flow/abort/route.js.nft.json +1 -0
  136. package/dist/server/.next/server/app/api/uat-git-flow/abort/route_client-reference-manifest.js +2 -0
  137. package/dist/server/.next/server/app/api/uat-git-flow/route/app-build-manifest.json +10 -0
  138. package/dist/server/.next/server/app/api/uat-git-flow/route/app-paths-manifest.json +3 -0
  139. package/dist/server/.next/server/app/api/uat-git-flow/route/build-manifest.json +16 -0
  140. package/dist/server/.next/server/app/api/uat-git-flow/route/next-font-manifest.json +6 -0
  141. package/dist/server/.next/server/app/api/uat-git-flow/route/react-loadable-manifest.json +1 -0
  142. package/dist/server/.next/server/app/api/uat-git-flow/route/server-reference-manifest.json +4 -0
  143. package/dist/server/.next/server/app/api/uat-git-flow/route.js +9 -0
  144. package/dist/server/.next/server/app/api/uat-git-flow/route.js.map +5 -0
  145. package/dist/server/.next/server/app/api/uat-git-flow/route.js.nft.json +1 -0
  146. package/dist/server/.next/server/app/api/uat-git-flow/route_client-reference-manifest.js +2 -0
  147. package/dist/server/.next/server/app/api/uat-git-flow/step/route/app-build-manifest.json +10 -0
  148. package/dist/server/.next/server/app/api/uat-git-flow/step/route/app-paths-manifest.json +3 -0
  149. package/dist/server/.next/server/app/api/uat-git-flow/step/route/build-manifest.json +16 -0
  150. package/dist/server/.next/server/app/api/uat-git-flow/step/route/next-font-manifest.json +6 -0
  151. package/dist/server/.next/server/app/api/uat-git-flow/step/route/react-loadable-manifest.json +1 -0
  152. package/dist/server/.next/server/app/api/uat-git-flow/step/route/server-reference-manifest.json +4 -0
  153. package/dist/server/.next/server/app/api/uat-git-flow/step/route.js +9 -0
  154. package/dist/server/.next/server/app/api/uat-git-flow/step/route.js.map +5 -0
  155. package/dist/server/.next/server/app/api/uat-git-flow/step/route.js.nft.json +1 -0
  156. package/dist/server/.next/server/app/api/uat-git-flow/step/route_client-reference-manifest.js +2 -0
  157. package/dist/server/.next/server/app/api/workspace/create/route/app-build-manifest.json +3 -4
  158. package/dist/server/.next/server/app/api/workspace/create/route/build-manifest.json +3 -4
  159. package/dist/server/.next/server/app/api/workspace/create/route.js +1 -1
  160. package/dist/server/.next/server/app/api/workspace/create/route.js.nft.json +1 -1
  161. package/dist/server/.next/server/app/configuration/page/app-build-manifest.json +6 -7
  162. package/dist/server/.next/server/app/configuration/page/build-manifest.json +3 -4
  163. package/dist/server/.next/server/app/configuration/page.js +1 -1
  164. package/dist/server/.next/server/app/configuration/page.js.nft.json +1 -1
  165. package/dist/server/.next/server/app/configuration/page_client-reference-manifest.js +1 -1
  166. package/dist/server/.next/server/app/configuration.html +1 -1
  167. package/dist/server/.next/server/app/configuration.rsc +3 -3
  168. package/dist/server/.next/server/app/favicon.ico/route/app-build-manifest.json +3 -4
  169. package/dist/server/.next/server/app/favicon.ico/route/build-manifest.json +3 -4
  170. package/dist/server/.next/server/app/index.html +1 -1
  171. package/dist/server/.next/server/app/index.rsc +2 -2
  172. package/dist/server/.next/server/app/initialization/page/app-build-manifest.json +6 -7
  173. package/dist/server/.next/server/app/initialization/page/build-manifest.json +3 -4
  174. package/dist/server/.next/server/app/initialization/page.js +1 -1
  175. package/dist/server/.next/server/app/initialization/page.js.nft.json +1 -1
  176. package/dist/server/.next/server/app/initialization/page_client-reference-manifest.js +1 -1
  177. package/dist/server/.next/server/app/initialization.html +1 -1
  178. package/dist/server/.next/server/app/initialization.rsc +3 -3
  179. package/dist/server/.next/server/app/page/app-build-manifest.json +4 -5
  180. package/dist/server/.next/server/app/page/build-manifest.json +3 -4
  181. package/dist/server/.next/server/app/page.js +1 -1
  182. package/dist/server/.next/server/app/page.js.nft.json +1 -1
  183. package/dist/server/.next/server/app/page_client-reference-manifest.js +1 -1
  184. package/dist/server/.next/server/app-paths-manifest.json +4 -0
  185. package/dist/server/.next/server/chunks/{[root-of-the-server]__8fcbb2f0._.js → [root-of-the-server]__0879b2d6._.js} +2 -2
  186. package/dist/server/.next/server/chunks/[root-of-the-server]__0d56f35b._.js +3 -0
  187. package/dist/server/.next/server/chunks/[root-of-the-server]__0d56f35b._.js.map +1 -0
  188. package/dist/server/.next/server/chunks/{[root-of-the-server]__771e8133._.js → [root-of-the-server]__0e8a08fc._.js} +2 -2
  189. package/dist/server/.next/server/chunks/{[root-of-the-server]__21616bf9._.js → [root-of-the-server]__1e792460._.js} +2 -2
  190. package/dist/server/.next/server/chunks/{[root-of-the-server]__03c2b225._.js → [root-of-the-server]__2a29597f._.js} +2 -2
  191. package/dist/server/.next/server/chunks/{[root-of-the-server]__5348b4aa._.js → [root-of-the-server]__2a78acef._.js} +2 -2
  192. package/dist/server/.next/server/chunks/{[root-of-the-server]__5100a0c5._.js → [root-of-the-server]__2f8b52da._.js} +2 -2
  193. package/dist/server/.next/server/chunks/{[root-of-the-server]__3dfc0dc4._.js → [root-of-the-server]__2ffbf0d3._.js} +2 -2
  194. package/dist/server/.next/server/chunks/{[root-of-the-server]__899d82eb._.js → [root-of-the-server]__452b5f9c._.js} +2 -2
  195. package/dist/server/.next/server/chunks/[root-of-the-server]__4ab3dd83._.js +16 -0
  196. package/dist/server/.next/server/chunks/[root-of-the-server]__4ab3dd83._.js.map +1 -0
  197. package/dist/server/.next/server/chunks/{[root-of-the-server]__2fcc7175._.js → [root-of-the-server]__4b595942._.js} +2 -2
  198. package/dist/server/.next/server/chunks/{[root-of-the-server]__973c48a6._.js → [root-of-the-server]__4ec3205b._.js} +2 -2
  199. package/dist/server/.next/server/chunks/{[root-of-the-server]__072f5c45._.js → [root-of-the-server]__4fd52ac1._.js} +2 -2
  200. package/dist/server/.next/server/chunks/{[root-of-the-server]__6e5dc117._.js → [root-of-the-server]__5c9f62f9._.js} +2 -2
  201. package/dist/server/.next/server/chunks/[root-of-the-server]__6cbd50e9._.js +16 -0
  202. package/dist/server/.next/server/chunks/[root-of-the-server]__6cbd50e9._.js.map +1 -0
  203. package/dist/server/.next/server/chunks/[root-of-the-server]__703c317f._.js +3 -0
  204. package/dist/server/.next/server/chunks/[root-of-the-server]__703c317f._.js.map +1 -0
  205. package/dist/server/.next/server/chunks/{[root-of-the-server]__7500acb0._.js → [root-of-the-server]__8637b7f1._.js} +2 -2
  206. package/dist/server/.next/server/chunks/[root-of-the-server]__98088bea._.js +3 -0
  207. package/dist/server/.next/server/chunks/[root-of-the-server]__98088bea._.js.map +1 -0
  208. package/dist/server/.next/server/chunks/{[root-of-the-server]__94e10604._.js → [root-of-the-server]__a6fbefc6._.js} +2 -2
  209. package/dist/server/.next/server/chunks/{[root-of-the-server]__31a13318._.js → [root-of-the-server]__a74239fc._.js} +2 -2
  210. package/dist/server/.next/server/chunks/{[root-of-the-server]__388e6150._.js → [root-of-the-server]__aaa3fe74._.js} +2 -2
  211. package/dist/server/.next/server/chunks/{[root-of-the-server]__7fc974c9._.js → [root-of-the-server]__b176e8df._.js} +2 -2
  212. package/dist/server/.next/server/chunks/{[root-of-the-server]__a292866b._.js → [root-of-the-server]__be14bdb6._.js} +2 -2
  213. package/dist/server/.next/server/chunks/{[root-of-the-server]__f815ea40._.js → [root-of-the-server]__c18498ef._.js} +2 -2
  214. package/dist/server/.next/server/chunks/{[root-of-the-server]__c8b26634._.js → [root-of-the-server]__c9627539._.js} +2 -2
  215. package/dist/server/.next/server/chunks/{[root-of-the-server]__5355b75a._.js → [root-of-the-server]__dda45cac._.js} +2 -2
  216. package/dist/server/.next/server/chunks/[root-of-the-server]__de18efbd._.js +16 -0
  217. package/dist/server/.next/server/chunks/[root-of-the-server]__de18efbd._.js.map +1 -0
  218. package/dist/server/.next/server/chunks/{[root-of-the-server]__2ba93285._.js → [root-of-the-server]__e0b7050d._.js} +2 -2
  219. package/dist/server/.next/server/chunks/{[root-of-the-server]__419d3b16._.js → [root-of-the-server]__ec681197._.js} +2 -2
  220. package/dist/server/.next/server/chunks/_24087f66._.js +3 -0
  221. package/dist/server/.next/server/chunks/_24087f66._.js.map +1 -0
  222. package/dist/server/.next/server/chunks/_61c263b3._.js +3 -0
  223. package/dist/server/.next/server/chunks/_61c263b3._.js.map +1 -0
  224. package/dist/server/.next/server/chunks/ssr/[root-of-the-server]__2e9964e3._.js +3 -0
  225. package/dist/server/.next/server/chunks/ssr/{[root-of-the-server]__f617a52d._.js → [root-of-the-server]__7b253128._.js} +2 -2
  226. package/dist/server/.next/server/chunks/ssr/{[root-of-the-server]__f617a52d._.js.map → [root-of-the-server]__7b253128._.js.map} +1 -1
  227. package/dist/server/.next/server/chunks/ssr/{[root-of-the-server]__c53d10ac._.js → [root-of-the-server]__a085452f._.js} +2 -2
  228. package/dist/server/.next/server/chunks/ssr/[root-of-the-server]__a085452f._.js.map +1 -0
  229. package/dist/server/.next/server/chunks/ssr/{[root-of-the-server]__63c188bd._.js → [root-of-the-server]__b8a5c1ab._.js} +2 -2
  230. package/dist/server/.next/server/chunks/ssr/_5579d68f._.js +57 -0
  231. package/dist/server/.next/server/chunks/ssr/_5579d68f._.js.map +1 -0
  232. package/dist/server/.next/server/chunks/ssr/_a1ab1c09._.js +8 -0
  233. package/dist/server/.next/server/chunks/ssr/_a1ab1c09._.js.map +1 -0
  234. package/dist/server/.next/server/chunks/ssr/_ee0c9da0._.js +8 -0
  235. package/dist/server/.next/server/chunks/ssr/_ee0c9da0._.js.map +1 -0
  236. package/dist/server/.next/server/chunks/ssr/packages_server_src_7cef6dbd._.js +1 -1
  237. package/dist/server/.next/server/chunks/ssr/packages_server_src_7cef6dbd._.js.map +1 -1
  238. package/dist/server/.next/server/middleware-build-manifest.js +7 -8
  239. package/dist/server/.next/server/pages/404.html +1 -1
  240. package/dist/server/.next/server/pages/500.html +1 -1
  241. package/dist/server/.next/server/pages/_app/build-manifest.json +2 -2
  242. package/dist/server/.next/server/pages/_document.js +1 -1
  243. package/dist/server/.next/server/pages/_document.js.nft.json +1 -1
  244. package/dist/server/.next/server/pages/_error/build-manifest.json +2 -2
  245. package/dist/server/.next/server/pages/_error.js +1 -1
  246. package/dist/server/.next/server/pages/_error.js.nft.json +1 -1
  247. package/dist/server/.next/server/server-reference-manifest.js +1 -1
  248. package/dist/server/.next/server/server-reference-manifest.json +1 -1
  249. package/dist/server/.next/static/chunks/{d65b8ba84ba3d819.js → 1091ba2f3c451a47.js} +1 -1
  250. package/dist/server/.next/static/chunks/{294d677a4838a994.js → 1154a499e8e3867b.js} +1 -1
  251. package/dist/server/.next/static/chunks/{f9ef1d12f3c1646a.js → 1aa036ed62a506c8.js} +2 -2
  252. package/dist/server/.next/static/chunks/205cbae70a6c50e1.js.map +1 -0
  253. package/dist/server/.next/static/chunks/{479d60165927b286.js.map → 2602bf706e977560.js.map} +1 -1
  254. package/dist/server/.next/static/chunks/2d2322acba49236a.js +57 -0
  255. package/dist/server/.next/static/chunks/43c514797c454939.js +7 -0
  256. package/dist/server/.next/static/chunks/511924c894f8e3de.css.map +1 -0
  257. package/dist/server/.next/static/chunks/861aac2fba8d4e28.css +3 -0
  258. package/dist/server/.next/static/chunks/888146b3e75fe817.js.map +1 -0
  259. package/dist/server/.next/static/chunks/9148331cad3a934e.js +7 -0
  260. package/dist/server/.next/static/chunks/{84f5ecdc99cc0be6.js.map → 988047fb36ff8bd4.js.map} +1 -1
  261. package/dist/server/.next/static/chunks/99154153690ad580.js.map +1 -0
  262. package/dist/server/.next/static/chunks/9bc1bbb3fe6e5eb3.js +3 -0
  263. package/dist/server/.next/static/chunks/c4c1da381d908575.js +5 -0
  264. package/dist/server/.next/static/chunks/d8d9344b4a8007c0.js.map +1 -0
  265. package/dist/server/.next/static/chunks/e5e4fd3e83ab66f8.js +4 -0
  266. package/dist/server/.next/static/chunks/e70508cc9f59709d.js.map +1 -0
  267. package/dist/server/.next/static/chunks/pages/_app.js +2 -2
  268. package/dist/server/.next/static/chunks/pages/_error.js +2 -2
  269. package/dist/server/.next/trace +1 -1
  270. package/package.json +1 -1
  271. package/dist/server/.next/server/chunks/[root-of-the-server]__629e6d6a._.js +0 -3
  272. package/dist/server/.next/server/chunks/[root-of-the-server]__629e6d6a._.js.map +0 -1
  273. package/dist/server/.next/server/chunks/[root-of-the-server]__f6d4fb58._.js +0 -16
  274. package/dist/server/.next/server/chunks/[root-of-the-server]__f6d4fb58._.js.map +0 -1
  275. package/dist/server/.next/server/chunks/ssr/[root-of-the-server]__c53d10ac._.js.map +0 -1
  276. package/dist/server/.next/server/chunks/ssr/[root-of-the-server]__e3a2aebd._.js +0 -3
  277. package/dist/server/.next/server/chunks/ssr/_5d353cf8._.js +0 -61
  278. package/dist/server/.next/server/chunks/ssr/_5d353cf8._.js.map +0 -1
  279. package/dist/server/.next/server/chunks/ssr/_e037a20f._.js +0 -4
  280. package/dist/server/.next/server/chunks/ssr/_e037a20f._.js.map +0 -1
  281. package/dist/server/.next/static/chunks/0dfafa95d29e5c79.js +0 -3
  282. package/dist/server/.next/static/chunks/1ad898191df92f90.css +0 -3
  283. package/dist/server/.next/static/chunks/5f8beee58a024d75.js +0 -3
  284. package/dist/server/.next/static/chunks/7e0a49ac2b139df9.js.map +0 -1
  285. package/dist/server/.next/static/chunks/9650e7136a9bfc30.js +0 -61
  286. package/dist/server/.next/static/chunks/a7b45611d4ad55fe.js +0 -4
  287. package/dist/server/.next/static/chunks/a9cba6096fe97a30.js +0 -5
  288. package/dist/server/.next/static/chunks/b0840b8d648f6401.css.map +0 -1
  289. package/dist/server/.next/static/chunks/c2cc02f47cf64419.js.map +0 -1
  290. package/dist/server/.next/static/chunks/cf3b2abf3523d13f.js +0 -3
  291. package/dist/server/.next/static/chunks/d0ab7593ca8c77ca.js.map +0 -1
  292. package/dist/server/.next/static/chunks/f31695470ae3a484.js.map +0 -1
  293. package/dist/server/.next/static/chunks/ffb74809cc596ae9.js.map +0 -1
  294. /package/dist/server/.next/server/chunks/{[root-of-the-server]__8fcbb2f0._.js.map → [root-of-the-server]__0879b2d6._.js.map} +0 -0
  295. /package/dist/server/.next/server/chunks/{[root-of-the-server]__771e8133._.js.map → [root-of-the-server]__0e8a08fc._.js.map} +0 -0
  296. /package/dist/server/.next/server/chunks/{[root-of-the-server]__21616bf9._.js.map → [root-of-the-server]__1e792460._.js.map} +0 -0
  297. /package/dist/server/.next/server/chunks/{[root-of-the-server]__03c2b225._.js.map → [root-of-the-server]__2a29597f._.js.map} +0 -0
  298. /package/dist/server/.next/server/chunks/{[root-of-the-server]__5348b4aa._.js.map → [root-of-the-server]__2a78acef._.js.map} +0 -0
  299. /package/dist/server/.next/server/chunks/{[root-of-the-server]__5100a0c5._.js.map → [root-of-the-server]__2f8b52da._.js.map} +0 -0
  300. /package/dist/server/.next/server/chunks/{[root-of-the-server]__3dfc0dc4._.js.map → [root-of-the-server]__2ffbf0d3._.js.map} +0 -0
  301. /package/dist/server/.next/server/chunks/{[root-of-the-server]__899d82eb._.js.map → [root-of-the-server]__452b5f9c._.js.map} +0 -0
  302. /package/dist/server/.next/server/chunks/{[root-of-the-server]__2fcc7175._.js.map → [root-of-the-server]__4b595942._.js.map} +0 -0
  303. /package/dist/server/.next/server/chunks/{[root-of-the-server]__973c48a6._.js.map → [root-of-the-server]__4ec3205b._.js.map} +0 -0
  304. /package/dist/server/.next/server/chunks/{[root-of-the-server]__072f5c45._.js.map → [root-of-the-server]__4fd52ac1._.js.map} +0 -0
  305. /package/dist/server/.next/server/chunks/{[root-of-the-server]__6e5dc117._.js.map → [root-of-the-server]__5c9f62f9._.js.map} +0 -0
  306. /package/dist/server/.next/server/chunks/{[root-of-the-server]__7500acb0._.js.map → [root-of-the-server]__8637b7f1._.js.map} +0 -0
  307. /package/dist/server/.next/server/chunks/{[root-of-the-server]__94e10604._.js.map → [root-of-the-server]__a6fbefc6._.js.map} +0 -0
  308. /package/dist/server/.next/server/chunks/{[root-of-the-server]__31a13318._.js.map → [root-of-the-server]__a74239fc._.js.map} +0 -0
  309. /package/dist/server/.next/server/chunks/{[root-of-the-server]__388e6150._.js.map → [root-of-the-server]__aaa3fe74._.js.map} +0 -0
  310. /package/dist/server/.next/server/chunks/{[root-of-the-server]__7fc974c9._.js.map → [root-of-the-server]__b176e8df._.js.map} +0 -0
  311. /package/dist/server/.next/server/chunks/{[root-of-the-server]__a292866b._.js.map → [root-of-the-server]__be14bdb6._.js.map} +0 -0
  312. /package/dist/server/.next/server/chunks/{[root-of-the-server]__f815ea40._.js.map → [root-of-the-server]__c18498ef._.js.map} +0 -0
  313. /package/dist/server/.next/server/chunks/{[root-of-the-server]__c8b26634._.js.map → [root-of-the-server]__c9627539._.js.map} +0 -0
  314. /package/dist/server/.next/server/chunks/{[root-of-the-server]__5355b75a._.js.map → [root-of-the-server]__dda45cac._.js.map} +0 -0
  315. /package/dist/server/.next/server/chunks/{[root-of-the-server]__2ba93285._.js.map → [root-of-the-server]__e0b7050d._.js.map} +0 -0
  316. /package/dist/server/.next/server/chunks/{[root-of-the-server]__419d3b16._.js.map → [root-of-the-server]__ec681197._.js.map} +0 -0
  317. /package/dist/server/.next/server/chunks/ssr/{[root-of-the-server]__e3a2aebd._.js.map → [root-of-the-server]__2e9964e3._.js.map} +0 -0
  318. /package/dist/server/.next/server/chunks/ssr/{[root-of-the-server]__63c188bd._.js.map → [root-of-the-server]__b8a5c1ab._.js.map} +0 -0
  319. /package/dist/server/.next/static/{Xoig0sIWc0oIgbMH6U6Ew → tz_bf3MbzRijrx8XdXPWA}/_buildManifest.js +0 -0
  320. /package/dist/server/.next/static/{Xoig0sIWc0oIgbMH6U6Ew → tz_bf3MbzRijrx8XdXPWA}/_clientMiddlewareManifest.json +0 -0
  321. /package/dist/server/.next/static/{Xoig0sIWc0oIgbMH6U6Ew → tz_bf3MbzRijrx8XdXPWA}/_ssgManifest.js +0 -0
@@ -1,3 +1,3 @@
1
- module.exports={83886:function(e){var{g:t,__dirname:r,m:s,e:o}=e;s.exports=e.x("fs",()=>require("fs"))},45935:function(e){var{g:t,__dirname:r,m:s,e:o}=e;s.exports=e.x("next/dist/server/app-render/after-task-async-storage.external.js",()=>require("next/dist/server/app-render/after-task-async-storage.external.js"))},88941:e=>{"use strict";var{g:t,__dirname:r}=e;{e.s({PROJECT_CONFIG_PATH:()=>r,ProjectStatus:()=>n,WORKSPACE_CONFIG:()=>t});var s=e.i(13442),o=e.i(30331);let t={WORKSPACE_ROOT:(0,o.join)((0,s.homedir)(),"Documents","prime-workspace"),GIT_TIMEOUT:3e5,MAX_CONCURRENT_CLONES:Math.max(2,Math.min((0,s.cpus)().length,8)),MAX_RETRY_ATTEMPTS:3},r=(0,o.join)((0,s.homedir)(),".prime-projects.json");var n=function(e){return e.PENDING="pending",e.EXISTING="existing",e.CLONING="cloning",e.SUCCESS="success",e.FAILED="failed",e.RETRYING="retrying",e.INCOMPLETE="incomplete",e}({})}},29549:function(e){var{g:t,__dirname:r,m:s,e:o}=e;s.exports=e.x("next/dist/compiled/next-server/app-page-turbo.runtime.prod.js",()=>require("next/dist/compiled/next-server/app-page-turbo.runtime.prod.js"))},83943:function(e){var{g:t,__dirname:r,m:s,e:o}=e;s.exports=e.x("next/dist/server/app-render/work-unit-async-storage.external.js",()=>require("next/dist/server/app-render/work-unit-async-storage.external.js"))},86103:function(e){var{g:t,__dirname:r,m:s,e:o}=e;s.exports=e.x("next/dist/server/app-render/work-async-storage.external.js",()=>require("next/dist/server/app-render/work-async-storage.external.js"))},30331:function(e){var{g:t,__dirname:r,m:s,e:o}=e;s.exports=e.x("path",()=>require("path"))},23430:function(e){var{g:t,__dirname:r,m:s,e:o}=e;s.exports=e.x("next/dist/compiled/@opentelemetry/api",()=>require("next/dist/compiled/@opentelemetry/api"))},13442:function(e){var{g:t,__dirname:r,m:s,e:o}=e;s.exports=e.x("os",()=>require("os"))},52670:function(e){var{g:t,__dirname:r,m:s,e:o}=e;s.exports=e.x("next/dist/compiled/next-server/app-route-turbo.runtime.prod.js",()=>require("next/dist/compiled/next-server/app-route-turbo.runtime.prod.js"))},9892:function(e){var{g:t,__dirname:r,m:s,e:o}=e;s.exports=e.x("fs/promises",()=>require("fs/promises"))},35692:e=>{"use strict";var{g:t,__dirname:r}=e;e.s({ProjectStatus:()=>i,getProjectsConfig:()=>n,saveProjectsConfig:()=>a});var s=e.i(9892),o=e.i(88941);async function n(){try{await (0,s.access)(o.PROJECT_CONFIG_PATH,s.constants.F_OK)}catch{return await a({}),{}}try{let e=await (0,s.readFile)(o.PROJECT_CONFIG_PATH,"utf-8");if(!e)return{};return JSON.parse(e)}catch(e){throw console.error("读取或解析项目配置文件失败:",e),Error("无法加载项目配置")}}async function a(e){let t=o.PROJECT_CONFIG_PATH+".tmp";try{await (0,s.writeFile)(t,JSON.stringify(e,null,2),"utf-8"),await (0,s.rename)(t,o.PROJECT_CONFIG_PATH)}catch(e){throw console.error("保存项目配置文件失败:",e),Error("无法保存项目配置")}}var i=function(e){return e.PENDING="pending",e.EXISTING="existing",e.CLONING="cloning",e.SUCCESS="success",e.FAILED="failed",e.RETRYING="retrying",e}({})},8773:function(e){var{g:t,__dirname:r,m:s,e:o}=e},55859:e=>{"use strict";var{g:t,__dirname:r}=e;e.s({GET:()=>c,PUT:()=>u});var s=e.i(15494),o=e.i(83886),n=e.i(30331),a=e.i(35692),i=e.i(88941);async function c(e){try{let{searchParams:t}=new URL(e.url),r=t.get("project"),c=t.get("apiName"),u=t.get("method"),p=t.get("siteName");if(!r||!c||!u||!p)return s.NextResponse.json({success:!1,error:"缺少必要参数:project, apiName, method, siteName"},{status:400});if(!(await (0,a.getProjectsConfig)())[r])return s.NextResponse.json({success:!1,error:`项目 ${r} 不存在`},{status:404});let m=(0,n.join)(i.WORKSPACE_CONFIG.WORKSPACE_ROOT,r),x=(0,n.join)(m,".mock",c,u.toLowerCase(),`${p}.cjs`);try{await o.promises.access(x)}catch{return s.NextResponse.json({success:!1,error:"Mock文件不存在"},{status:404})}let d=await o.promises.readFile(x,"utf-8");return s.NextResponse.json({success:!0,data:{projectName:r,apiName:c,method:u.toLowerCase(),siteName:p,content:d,filePath:(0,n.join)(".mock",c,u.toLowerCase(),`${p}.cjs`)},message:"获取Mock文件内容成功"})}catch(t){let e=t instanceof Error?t.message:"获取Mock文件内容失败";return console.error("获取Mock文件内容失败:",t),s.NextResponse.json({success:!1,error:e},{status:500})}}async function u(e){try{let{projectName:t,apiName:r,method:c,siteName:u,content:p}=await e.json();if(!t||!r||!c||!u||void 0===p)return s.NextResponse.json({success:!1,error:"缺少必要参数:projectName, apiName, method, siteName, content"},{status:400});if(!(await (0,a.getProjectsConfig)())[t])return s.NextResponse.json({success:!1,error:`项目 ${t} 不存在`},{status:404});let m=(0,n.join)(i.WORKSPACE_CONFIG.WORKSPACE_ROOT,t),x=(0,n.join)(m,".mock",r,c.toLowerCase(),`${u}.cjs`);try{await o.promises.access(x)}catch{return s.NextResponse.json({success:!1,error:"Mock文件不存在"},{status:404})}return await o.promises.writeFile(x,p,"utf-8"),s.NextResponse.json({success:!0,message:"Mock文件内容更新成功",data:{projectName:t,apiName:r,method:c.toLowerCase(),siteName:u,filePath:(0,n.join)(".mock",r,c.toLowerCase(),`${u}.cjs`),updatedAt:new Date().toISOString()}})}catch(t){let e=t instanceof Error?t.message:"更新Mock文件内容失败";return console.error("更新Mock文件内容失败:",t),s.NextResponse.json({success:!1,error:e},{status:500})}}},19627:e=>{"use strict";var{g:t,__dirname:r}=e;{e.s({patchFetch:()=>i,routeModule:()=>t,serverHooks:()=>u,workAsyncStorage:()=>r,workUnitAsyncStorage:()=>c});var s=e.i(45746),o=e.i(93828),n=e.i(18250),a=e.i(55859);let t=new s.AppRouteRouteModule({definition:{kind:o.RouteKind.APP_ROUTE,page:"/api/mock-file-content/route",pathname:"/api/mock-file-content",filename:"route",bundlePath:""},resolvedPagePath:"[project]/packages/server/src/app/api/mock-file-content/route.ts",nextConfigOutput:"",userland:a}),{workAsyncStorage:r,workUnitAsyncStorage:c,serverHooks:u}=t;function i(){return(0,n.patchFetch)({workAsyncStorage:r,workUnitAsyncStorage:c})}}}};
1
+ module.exports={83886:function(e){var{g:t,__dirname:r,m:s,e:o}=e;s.exports=e.x("fs",()=>require("fs"))},45935:function(e){var{g:t,__dirname:r,m:s,e:o}=e;s.exports=e.x("next/dist/server/app-render/after-task-async-storage.external.js",()=>require("next/dist/server/app-render/after-task-async-storage.external.js"))},88941:e=>{"use strict";var{g:t,__dirname:r}=e;{e.s({PROJECT_CONFIG_PATH:()=>r,ProjectStatus:()=>n,WORKSPACE_CONFIG:()=>t});var s=e.i(13442),o=e.i(30331);let t={WORKSPACE_ROOT:(0,o.join)((0,s.homedir)(),"Documents","prime-workspace"),GIT_TIMEOUT:3e5,MAX_CONCURRENT_CLONES:Math.max(2,Math.min((0,s.cpus)().length,8)),MAX_RETRY_ATTEMPTS:3},r=(0,o.join)((0,s.homedir)(),".prime-projects.json");var n=function(e){return e.PENDING="pending",e.EXISTING="existing",e.CLONING="cloning",e.SUCCESS="success",e.FAILED="failed",e.RETRYING="retrying",e.INCOMPLETE="incomplete",e}({})}},30331:function(e){var{g:t,__dirname:r,m:s,e:o}=e;s.exports=e.x("path",()=>require("path"))},29549:function(e){var{g:t,__dirname:r,m:s,e:o}=e;s.exports=e.x("next/dist/compiled/next-server/app-page-turbo.runtime.prod.js",()=>require("next/dist/compiled/next-server/app-page-turbo.runtime.prod.js"))},83943:function(e){var{g:t,__dirname:r,m:s,e:o}=e;s.exports=e.x("next/dist/server/app-render/work-unit-async-storage.external.js",()=>require("next/dist/server/app-render/work-unit-async-storage.external.js"))},86103:function(e){var{g:t,__dirname:r,m:s,e:o}=e;s.exports=e.x("next/dist/server/app-render/work-async-storage.external.js",()=>require("next/dist/server/app-render/work-async-storage.external.js"))},23430:function(e){var{g:t,__dirname:r,m:s,e:o}=e;s.exports=e.x("next/dist/compiled/@opentelemetry/api",()=>require("next/dist/compiled/@opentelemetry/api"))},52670:function(e){var{g:t,__dirname:r,m:s,e:o}=e;s.exports=e.x("next/dist/compiled/next-server/app-route-turbo.runtime.prod.js",()=>require("next/dist/compiled/next-server/app-route-turbo.runtime.prod.js"))},13442:function(e){var{g:t,__dirname:r,m:s,e:o}=e;s.exports=e.x("os",()=>require("os"))},9892:function(e){var{g:t,__dirname:r,m:s,e:o}=e;s.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:()=>a});var s=e.i(9892),o=e.i(88941);async function n(){try{await (0,s.access)(o.PROJECT_CONFIG_PATH,s.constants.F_OK)}catch{return await a({}),{}}try{let e=await (0,s.readFile)(o.PROJECT_CONFIG_PATH,"utf-8");if(!e)return{};return JSON.parse(e)}catch(e){throw console.error("读取或解析项目配置文件失败:",e),Error("无法加载项目配置")}}async function a(e){let t=o.PROJECT_CONFIG_PATH+".tmp";try{await (0,s.writeFile)(t,JSON.stringify(e,null,2),"utf-8"),await (0,s.rename)(t,o.PROJECT_CONFIG_PATH)}catch(e){throw console.error("保存项目配置文件失败:",e),Error("无法保存项目配置")}}var i=function(e){return e.PENDING="pending",e.EXISTING="existing",e.CLONING="cloning",e.SUCCESS="success",e.FAILED="failed",e.RETRYING="retrying",e}({})},8773:function(e){var{g:t,__dirname:r,m:s,e:o}=e},55859:e=>{"use strict";var{g:t,__dirname:r}=e;e.s({GET:()=>c,PUT:()=>u});var s=e.i(15494),o=e.i(83886),n=e.i(30331),a=e.i(35692),i=e.i(88941);async function c(e){try{let{searchParams:t}=new URL(e.url),r=t.get("project"),c=t.get("apiName"),u=t.get("method"),p=t.get("siteName");if(!r||!c||!u||!p)return s.NextResponse.json({success:!1,error:"缺少必要参数:project, apiName, method, siteName"},{status:400});if(!(await (0,a.getProjectsConfig)())[r])return s.NextResponse.json({success:!1,error:`项目 ${r} 不存在`},{status:404});let m=(0,n.join)(i.WORKSPACE_CONFIG.WORKSPACE_ROOT,r),x=(0,n.join)(m,".mock",c,u.toLowerCase(),`${p}.cjs`);try{await o.promises.access(x)}catch{return s.NextResponse.json({success:!1,error:"Mock文件不存在"},{status:404})}let d=await o.promises.readFile(x,"utf-8");return s.NextResponse.json({success:!0,data:{projectName:r,apiName:c,method:u.toLowerCase(),siteName:p,content:d,filePath:(0,n.join)(".mock",c,u.toLowerCase(),`${p}.cjs`)},message:"获取Mock文件内容成功"})}catch(t){let e=t instanceof Error?t.message:"获取Mock文件内容失败";return console.error("获取Mock文件内容失败:",t),s.NextResponse.json({success:!1,error:e},{status:500})}}async function u(e){try{let{projectName:t,apiName:r,method:c,siteName:u,content:p}=await e.json();if(!t||!r||!c||!u||void 0===p)return s.NextResponse.json({success:!1,error:"缺少必要参数:projectName, apiName, method, siteName, content"},{status:400});if(!(await (0,a.getProjectsConfig)())[t])return s.NextResponse.json({success:!1,error:`项目 ${t} 不存在`},{status:404});let m=(0,n.join)(i.WORKSPACE_CONFIG.WORKSPACE_ROOT,t),x=(0,n.join)(m,".mock",r,c.toLowerCase(),`${u}.cjs`);try{await o.promises.access(x)}catch{return s.NextResponse.json({success:!1,error:"Mock文件不存在"},{status:404})}return await o.promises.writeFile(x,p,"utf-8"),s.NextResponse.json({success:!0,message:"Mock文件内容更新成功",data:{projectName:t,apiName:r,method:c.toLowerCase(),siteName:u,filePath:(0,n.join)(".mock",r,c.toLowerCase(),`${u}.cjs`),updatedAt:new Date().toISOString()}})}catch(t){let e=t instanceof Error?t.message:"更新Mock文件内容失败";return console.error("更新Mock文件内容失败:",t),s.NextResponse.json({success:!1,error:e},{status:500})}}},19627:e=>{"use strict";var{g:t,__dirname:r}=e;{e.s({patchFetch:()=>i,routeModule:()=>t,serverHooks:()=>u,workAsyncStorage:()=>r,workUnitAsyncStorage:()=>c});var s=e.i(45746),o=e.i(93828),n=e.i(18250),a=e.i(55859);let t=new s.AppRouteRouteModule({definition:{kind:o.RouteKind.APP_ROUTE,page:"/api/mock-file-content/route",pathname:"/api/mock-file-content",filename:"route",bundlePath:""},resolvedPagePath:"[project]/packages/server/src/app/api/mock-file-content/route.ts",nextConfigOutput:"",userland:a}),{workAsyncStorage:r,workUnitAsyncStorage:c,serverHooks:u}=t;function i(){return(0,n.patchFetch)({workAsyncStorage:r,workUnitAsyncStorage:c})}}}};
2
2
 
3
- //# sourceMappingURL=%5Broot-of-the-server%5D__7500acb0._.js.map
3
+ //# sourceMappingURL=%5Broot-of-the-server%5D__8637b7f1._.js.map
@@ -0,0 +1,3 @@
1
+ module.exports={45935:function(e){var{g:r,__dirname:t,m:s,e:n}=e;s.exports=e.x("next/dist/server/app-render/after-task-async-storage.external.js",()=>require("next/dist/server/app-render/after-task-async-storage.external.js"))},29549:function(e){var{g:r,__dirname:t,m:s,e:n}=e;s.exports=e.x("next/dist/compiled/next-server/app-page-turbo.runtime.prod.js",()=>require("next/dist/compiled/next-server/app-page-turbo.runtime.prod.js"))},83943:function(e){var{g:r,__dirname:t,m:s,e:n}=e;s.exports=e.x("next/dist/server/app-render/work-unit-async-storage.external.js",()=>require("next/dist/server/app-render/work-unit-async-storage.external.js"))},86103:function(e){var{g:r,__dirname:t,m:s,e:n}=e;s.exports=e.x("next/dist/server/app-render/work-async-storage.external.js",()=>require("next/dist/server/app-render/work-async-storage.external.js"))},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"))},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"))},30614:function(e){var{g:r,__dirname:t,m:s,e:n}=e},73421:e=>{"use strict";var{g:r,__dirname:t}=e;e.s({GET:()=>n});var s=e.i(15494);async function n(){let e="1"===process.env.PRIME_ADMIN||"true"===process.env.PRIME_ADMIN;return s.NextResponse.json({success:!0,isAdmin:e})}},2227:e=>{"use strict";var{g:r,__dirname:t}=e;{e.s({patchFetch:()=>i,routeModule:()=>r,serverHooks:()=>u,workAsyncStorage:()=>t,workUnitAsyncStorage:()=>p});var s=e.i(45746),n=e.i(93828),a=e.i(18250),o=e.i(73421);let r=new s.AppRouteRouteModule({definition:{kind:n.RouteKind.APP_ROUTE,page:"/api/admin-status/route",pathname:"/api/admin-status",filename:"route",bundlePath:""},resolvedPagePath:"[project]/packages/server/src/app/api/admin-status/route.ts",nextConfigOutput:"",userland:o}),{workAsyncStorage:t,workUnitAsyncStorage:p,serverHooks:u}=r;function i(){return(0,a.patchFetch)({workAsyncStorage:t,workUnitAsyncStorage:p})}}}};
2
+
3
+ //# sourceMappingURL=%5Broot-of-the-server%5D__98088bea._.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["turbopack:///[project]/packages/server/src/app/api/admin-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":["import { NextResponse } from 'next/server';\n\nexport async function GET() {\n const isAdmin = process.env.PRIME_ADMIN === '1' || process.env.PRIME_ADMIN === 'true';\n return NextResponse.json({\n success: true,\n isAdmin,\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":"2yCAAA,IAAA,EAAA,EAAA,CAAA,CAAA,OAEO,eAAe,IACpB,IAAM,EAAU,AAA4B,cAApB,GAAG,CAAC,WAAW,EAAwC,SAA5B,QAAQ,GAAG,CAAC,WAAW,CAC1E,OAAO,EAAA,YAAY,CAAC,IAAI,CAAC,CACvB,SAAS,EACT,MAFK,GAGP,EACF,+JCRA,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,CAAA,AAFjBC,EAEXC,KAWZ,IAAMC,AAb4B,EAad,GAXM,CAWN,EAbsB,AAalBL,YAXgB,OAWhBA,CAAoB,CAC1CM,WAAY,CACVC,KAAMN,EAAAA,SAAAA,CAAUO,SAAS,CACzBC,KAAM,0BACNC,SAAU,oBACVC,SAAU,QACVC,WAAY,EACd,EACAC,iBAAkB,8DAClBC,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":[1]}
@@ -1,3 +1,3 @@
1
- module.exports={45935:function(e){var{g:r,__dirname:t,m:s,e:n}=e;s.exports=e.x("next/dist/server/app-render/after-task-async-storage.external.js",()=>require("next/dist/server/app-render/after-task-async-storage.external.js"))},29549:function(e){var{g:r,__dirname:t,m:s,e:n}=e;s.exports=e.x("next/dist/compiled/next-server/app-page-turbo.runtime.prod.js",()=>require("next/dist/compiled/next-server/app-page-turbo.runtime.prod.js"))},83943:function(e){var{g:r,__dirname:t,m:s,e:n}=e;s.exports=e.x("next/dist/server/app-render/work-unit-async-storage.external.js",()=>require("next/dist/server/app-render/work-unit-async-storage.external.js"))},86103:function(e){var{g:r,__dirname:t,m:s,e:n}=e;s.exports=e.x("next/dist/server/app-render/work-async-storage.external.js",()=>require("next/dist/server/app-render/work-async-storage.external.js"))},30331:function(e){var{g:r,__dirname:t,m:s,e:n}=e;s.exports=e.x("path",()=>require("path"))},23430:function(e){var{g:r,__dirname:t,m:s,e:n}=e;s.exports=e.x("next/dist/compiled/@opentelemetry/api",()=>require("next/dist/compiled/@opentelemetry/api"))},13442:function(e){var{g:r,__dirname:t,m:s,e:n}=e;s.exports=e.x("os",()=>require("os"))},52670:function(e){var{g:r,__dirname:t,m:s,e:n}=e;s.exports=e.x("next/dist/compiled/next-server/app-route-turbo.runtime.prod.js",()=>require("next/dist/compiled/next-server/app-route-turbo.runtime.prod.js"))},88941:e=>{"use strict";var{g:r,__dirname:t}=e;{e.s({PROJECT_CONFIG_PATH:()=>t,ProjectStatus:()=>o,WORKSPACE_CONFIG:()=>r});var s=e.i(13442),n=e.i(30331);let r={WORKSPACE_ROOT:(0,n.join)((0,s.homedir)(),"Documents","prime-workspace"),GIT_TIMEOUT:3e5,MAX_CONCURRENT_CLONES:Math.max(2,Math.min((0,s.cpus)().length,8)),MAX_RETRY_ATTEMPTS:3},t=(0,n.join)((0,s.homedir)(),".prime-projects.json");var o=function(e){return e.PENDING="pending",e.EXISTING="existing",e.CLONING="cloning",e.SUCCESS="success",e.FAILED="failed",e.RETRYING="retrying",e.INCOMPLETE="incomplete",e}({})}},83886:function(e){var{g:r,__dirname:t,m:s,e:n}=e;s.exports=e.x("fs",()=>require("fs"))},87485:function(e){var{g:r,__dirname:t,m:s,e:n}=e;s.exports=e.x("child_process",()=>require("child_process"))},80275:function(e){var{g:r,__dirname:t,m:s,e:n}=e},1163:e=>{"use strict";var{g:r,__dirname:t}=e;e.s({GET:()=>p});var s=e.i(15494),n=e.i(87485),o=e.i(30331),i=e.i(83886),a=e.i(88941);async function p(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 n=a.WORKSPACE_CONFIG.WORKSPACE_ROOT,p=(0,o.join)(n,t);if(console.log("工作空间路径:",n),console.log("项目路径:",p),console.log("项目目录是否存在:",(0,i.existsSync)(p)),!(0,i.existsSync)(p))return s.NextResponse.json({success:!1,error:`项目目录不存在: ${p}`},{status:404});let u=(0,o.join)(p,".git");if(!(0,i.existsSync)(u))return s.NextResponse.json({success:!1,error:"该项目不是Git仓库"},{status:400});let d=await c(p);return s.NextResponse.json({success:!0,data:d})}catch(e){return console.error("获取分支信息失败:",e),s.NextResponse.json({success:!1,error:e instanceof Error?e.message:"获取分支信息失败"},{status:500})}}async function c(e){return new Promise((r,t)=>{let s=(0,n.spawn)("git",["branch","--show-current"],{cwd:e,stdio:["pipe","pipe","pipe"]}),o="",i="";s.stdout?.on("data",e=>{o+=e.toString()}),s.stderr?.on("data",e=>{i+=e.toString()}),s.on("close",async s=>{if(0!==s)return void t(Error(`获取分支名称失败: ${i}`));let n=o.trim();try{let[t,s]=await Promise.all([u(e),d(e)]);r({currentBranch:n,lastCommit:t,status:s})}catch(e){t(e)}}),s.on("error",e=>{t(Error(`执行git命令失败: ${e.message}`))})})}async function u(e){return new Promise((r,t)=>{let s=(0,n.spawn)("git",["log","-1","--pretty=format:%H|%s|%an|%ad","--date=format:%Y-%m-%d %H:%M:%S"],{cwd:e,stdio:["pipe","pipe","pipe"]}),o="",i="";s.stdout?.on("data",e=>{o+=e.toString()}),s.stderr?.on("data",e=>{i+=e.toString()}),s.on("close",e=>{if(0!==e)return void t(Error(`获取提交信息失败: ${i}`));let s=o.trim().split("|");if(s.length<4)return void t(Error("提交信息格式错误"));r({hash:s[0].substring(0,8),message:s[1],author:s[2],date:s[3]})}),s.on("error",e=>{t(Error(`执行git log命令失败: ${e.message}`))})})}async function d(e){return new Promise((r,t)=>{let s=(0,n.spawn)("git",["status","--porcelain","-b"],{cwd:e,stdio:["pipe","pipe","pipe"]}),o="",i="";s.stdout?.on("data",e=>{o+=e.toString()}),s.stderr?.on("data",e=>{i+=e.toString()}),s.on("close",e=>{if(0!==e)return void t(Error(`获取仓库状态失败: ${i}`));let s=o.trim().split("\n"),n=0,a=0,p=0,c=0,u=0;s.forEach(e=>{if(e.startsWith("##")){let r=e.match(/ahead (\d+)/),t=e.match(/behind (\d+)/);r&&(n=parseInt(r[1],10)),t&&(a=parseInt(t[1],10))}else if(e.length>=2){let r=e.substring(0,2);" "!==r[0]&&"?"!==r[0]&&c++," "!==r[1]&&"?"!==r[1]&&p++,"??"===r&&u++}}),r({ahead:n,behind:a,modified:p,staged:c,untracked:u})}),s.on("error",e=>{t(Error(`执行git status命令失败: ${e.message}`))})})}},96463:e=>{"use strict";var{g:r,__dirname:t}=e;{e.s({patchFetch:()=>a,routeModule:()=>r,serverHooks:()=>c,workAsyncStorage:()=>t,workUnitAsyncStorage:()=>p});var s=e.i(45746),n=e.i(93828),o=e.i(18250),i=e.i(1163);let r=new s.AppRouteRouteModule({definition:{kind:n.RouteKind.APP_ROUTE,page:"/api/current-branch/route",pathname:"/api/current-branch",filename:"route",bundlePath:""},resolvedPagePath:"[project]/packages/server/src/app/api/current-branch/route.ts",nextConfigOutput:"",userland:i}),{workAsyncStorage:t,workUnitAsyncStorage:p,serverHooks:c}=r;function a(){return(0,o.patchFetch)({workAsyncStorage:t,workUnitAsyncStorage:p})}}}};
1
+ module.exports={45935:function(e){var{g:r,__dirname:t,m:s,e:n}=e;s.exports=e.x("next/dist/server/app-render/after-task-async-storage.external.js",()=>require("next/dist/server/app-render/after-task-async-storage.external.js"))},30331:function(e){var{g:r,__dirname:t,m:s,e:n}=e;s.exports=e.x("path",()=>require("path"))},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"))},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"))},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"))},13442:function(e){var{g:r,__dirname:t,m:s,e:n}=e;s.exports=e.x("os",()=>require("os"))},88941:e=>{"use strict";var{g:r,__dirname:t}=e;{e.s({PROJECT_CONFIG_PATH:()=>t,ProjectStatus:()=>o,WORKSPACE_CONFIG:()=>r});var s=e.i(13442),n=e.i(30331);let r={WORKSPACE_ROOT:(0,n.join)((0,s.homedir)(),"Documents","prime-workspace"),GIT_TIMEOUT:3e5,MAX_CONCURRENT_CLONES:Math.max(2,Math.min((0,s.cpus)().length,8)),MAX_RETRY_ATTEMPTS:3},t=(0,n.join)((0,s.homedir)(),".prime-projects.json");var o=function(e){return e.PENDING="pending",e.EXISTING="existing",e.CLONING="cloning",e.SUCCESS="success",e.FAILED="failed",e.RETRYING="retrying",e.INCOMPLETE="incomplete",e}({})}},83886:function(e){var{g:r,__dirname:t,m:s,e:n}=e;s.exports=e.x("fs",()=>require("fs"))},87485:function(e){var{g:r,__dirname:t,m:s,e:n}=e;s.exports=e.x("child_process",()=>require("child_process"))},80275:function(e){var{g:r,__dirname:t,m:s,e:n}=e},1163:e=>{"use strict";var{g:r,__dirname:t}=e;e.s({GET:()=>p});var s=e.i(15494),n=e.i(87485),o=e.i(30331),i=e.i(83886),a=e.i(88941);async function p(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 n=a.WORKSPACE_CONFIG.WORKSPACE_ROOT,p=(0,o.join)(n,t);if(console.log("工作空间路径:",n),console.log("项目路径:",p),console.log("项目目录是否存在:",(0,i.existsSync)(p)),!(0,i.existsSync)(p))return s.NextResponse.json({success:!1,error:`项目目录不存在: ${p}`},{status:404});let u=(0,o.join)(p,".git");if(!(0,i.existsSync)(u))return s.NextResponse.json({success:!1,error:"该项目不是Git仓库"},{status:400});let d=await c(p);return s.NextResponse.json({success:!0,data:d})}catch(e){return console.error("获取分支信息失败:",e),s.NextResponse.json({success:!1,error:e instanceof Error?e.message:"获取分支信息失败"},{status:500})}}async function c(e){return new Promise((r,t)=>{let s=(0,n.spawn)("git",["branch","--show-current"],{cwd:e,stdio:["pipe","pipe","pipe"]}),o="",i="";s.stdout?.on("data",e=>{o+=e.toString()}),s.stderr?.on("data",e=>{i+=e.toString()}),s.on("close",async s=>{if(0!==s)return void t(Error(`获取分支名称失败: ${i}`));let n=o.trim();try{let[t,s]=await Promise.all([u(e),d(e)]);r({currentBranch:n,lastCommit:t,status:s})}catch(e){t(e)}}),s.on("error",e=>{t(Error(`执行git命令失败: ${e.message}`))})})}async function u(e){return new Promise((r,t)=>{let s=(0,n.spawn)("git",["log","-1","--pretty=format:%H|%s|%an|%ad","--date=format:%Y-%m-%d %H:%M:%S"],{cwd:e,stdio:["pipe","pipe","pipe"]}),o="",i="";s.stdout?.on("data",e=>{o+=e.toString()}),s.stderr?.on("data",e=>{i+=e.toString()}),s.on("close",e=>{if(0!==e)return void t(Error(`获取提交信息失败: ${i}`));let s=o.trim().split("|");if(s.length<4)return void t(Error("提交信息格式错误"));r({hash:s[0].substring(0,8),message:s[1],author:s[2],date:s[3]})}),s.on("error",e=>{t(Error(`执行git log命令失败: ${e.message}`))})})}async function d(e){return new Promise((r,t)=>{let s=(0,n.spawn)("git",["status","--porcelain","-b"],{cwd:e,stdio:["pipe","pipe","pipe"]}),o="",i="";s.stdout?.on("data",e=>{o+=e.toString()}),s.stderr?.on("data",e=>{i+=e.toString()}),s.on("close",e=>{if(0!==e)return void t(Error(`获取仓库状态失败: ${i}`));let s=o.trim().split("\n"),n=0,a=0,p=0,c=0,u=0;s.forEach(e=>{if(e.startsWith("##")){let r=e.match(/ahead (\d+)/),t=e.match(/behind (\d+)/);r&&(n=parseInt(r[1],10)),t&&(a=parseInt(t[1],10))}else if(e.length>=2){let r=e.substring(0,2);" "!==r[0]&&"?"!==r[0]&&c++," "!==r[1]&&"?"!==r[1]&&p++,"??"===r&&u++}}),r({ahead:n,behind:a,modified:p,staged:c,untracked:u})}),s.on("error",e=>{t(Error(`执行git status命令失败: ${e.message}`))})})}},96463:e=>{"use strict";var{g:r,__dirname:t}=e;{e.s({patchFetch:()=>a,routeModule:()=>r,serverHooks:()=>c,workAsyncStorage:()=>t,workUnitAsyncStorage:()=>p});var s=e.i(45746),n=e.i(93828),o=e.i(18250),i=e.i(1163);let r=new s.AppRouteRouteModule({definition:{kind:n.RouteKind.APP_ROUTE,page:"/api/current-branch/route",pathname:"/api/current-branch",filename:"route",bundlePath:""},resolvedPagePath:"[project]/packages/server/src/app/api/current-branch/route.ts",nextConfigOutput:"",userland:i}),{workAsyncStorage:t,workUnitAsyncStorage:p,serverHooks:c}=r;function a(){return(0,o.patchFetch)({workAsyncStorage:t,workUnitAsyncStorage:p})}}}};
2
2
 
3
- //# sourceMappingURL=%5Broot-of-the-server%5D__94e10604._.js.map
3
+ //# sourceMappingURL=%5Broot-of-the-server%5D__a6fbefc6._.js.map
@@ -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"))},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})}}}};
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}({})}},30331:function(e){var{g:r,__dirname:t,m:s,e:n}=e;s.exports=e.x("path",()=>require("path"))},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"))},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"))},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"))},13442:function(e){var{g:r,__dirname:t,m:s,e:n}=e;s.exports=e.x("os",()=>require("os"))},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%5D__31a13318._.js.map
3
+ //# sourceMappingURL=%5Broot-of-the-server%5D__a74239fc._.js.map
@@ -1,5 +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)}
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}({})}},30331:function(e){var{g:t,__dirname:r,m:o,e:s}=e;o.exports=e.x("path",()=>require("path"))},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"))},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"))},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"))},13442:function(e){var{g:t,__dirname:r,m:o,e:s}=e;o.exports=e.x("os",()=>require("os"))},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
2
 
3
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
4
 
5
- //# sourceMappingURL=%5Broot-of-the-server%5D__388e6150._.js.map
5
+ //# sourceMappingURL=%5Broot-of-the-server%5D__aaa3fe74._.js.map
@@ -1,4 +1,4 @@
1
- module.exports={88941:e=>{"use strict";var{g:t,__dirname:r}=e;{e.s({PROJECT_CONFIG_PATH:()=>r,ProjectStatus:()=>o,WORKSPACE_CONFIG:()=>t});var s=e.i(13442),n=e.i(30331);let t={WORKSPACE_ROOT:(0,n.join)((0,s.homedir)(),"Documents","prime-workspace"),GIT_TIMEOUT:3e5,MAX_CONCURRENT_CLONES:Math.max(2,Math.min((0,s.cpus)().length,8)),MAX_RETRY_ATTEMPTS:3},r=(0,n.join)((0,s.homedir)(),".prime-projects.json");var o=function(e){return e.PENDING="pending",e.EXISTING="existing",e.CLONING="cloning",e.SUCCESS="success",e.FAILED="failed",e.RETRYING="retrying",e.INCOMPLETE="incomplete",e}({})}},29549:function(e){var{g:t,__dirname:r,m:s,e:n}=e;s.exports=e.x("next/dist/compiled/next-server/app-page-turbo.runtime.prod.js",()=>require("next/dist/compiled/next-server/app-page-turbo.runtime.prod.js"))},83943:function(e){var{g:t,__dirname:r,m:s,e:n}=e;s.exports=e.x("next/dist/server/app-render/work-unit-async-storage.external.js",()=>require("next/dist/server/app-render/work-unit-async-storage.external.js"))},86103:function(e){var{g:t,__dirname:r,m:s,e:n}=e;s.exports=e.x("next/dist/server/app-render/work-async-storage.external.js",()=>require("next/dist/server/app-render/work-async-storage.external.js"))},30331:function(e){var{g:t,__dirname:r,m:s,e:n}=e;s.exports=e.x("path",()=>require("path"))},23430:function(e){var{g:t,__dirname:r,m:s,e:n}=e;s.exports=e.x("next/dist/compiled/@opentelemetry/api",()=>require("next/dist/compiled/@opentelemetry/api"))},13442:function(e){var{g:t,__dirname:r,m:s,e:n}=e;s.exports=e.x("os",()=>require("os"))},52670:function(e){var{g:t,__dirname:r,m:s,e:n}=e;s.exports=e.x("next/dist/compiled/next-server/app-route-turbo.runtime.prod.js",()=>require("next/dist/compiled/next-server/app-route-turbo.runtime.prod.js"))},9892:function(e){var{g:t,__dirname:r,m:s,e:n}=e;s.exports=e.x("fs/promises",()=>require("fs/promises"))},35692:e=>{"use strict";var{g:t,__dirname:r}=e;e.s({ProjectStatus:()=>c,getProjectsConfig:()=>o,saveProjectsConfig:()=>i});var s=e.i(9892),n=e.i(88941);async function o(){try{await (0,s.access)(n.PROJECT_CONFIG_PATH,s.constants.F_OK)}catch{return await i({}),{}}try{let e=await (0,s.readFile)(n.PROJECT_CONFIG_PATH,"utf-8");if(!e)return{};return JSON.parse(e)}catch(e){throw console.error("读取或解析项目配置文件失败:",e),Error("无法加载项目配置")}}async function i(e){let t=n.PROJECT_CONFIG_PATH+".tmp";try{await (0,s.writeFile)(t,JSON.stringify(e,null,2),"utf-8"),await (0,s.rename)(t,n.PROJECT_CONFIG_PATH)}catch(e){throw console.error("保存项目配置文件失败:",e),Error("无法保存项目配置")}}var c=function(e){return e.PENDING="pending",e.EXISTING="existing",e.CLONING="cloning",e.SUCCESS="success",e.FAILED="failed",e.RETRYING="retrying",e}({})},83886:function(e){var{g:t,__dirname:r,m:s,e:n}=e;s.exports=e.x("fs",()=>require("fs"))},87485:function(e){var{g:t,__dirname:r,m:s,e:n}=e;s.exports=e.x("child_process",()=>require("child_process"))},77159:e=>{"use strict";var{g:t,__dirname:r}=e;e.s({checkMultipleProjectsExist:()=>h,checkProjectExists:()=>g,checkProjectStatus:()=>p,cleanupIncompleteProject:()=>m,cloneRepository:()=>a,createWorkspaceDirectory:()=>c,isValidGitUrl:()=>u,sanitizeProjectName:()=>l});var s=e.i(87485),n=e.i(83886),o=e.i(30331),i=e.i(88941);async function c(e){try{return(0,n.existsSync)(e)||(0,n.mkdirSync)(e,{recursive:!0}),{success:!0}}catch(e){return{success:!1,error:`创建工作空间目录失败: ${e instanceof Error?e.message:String(e)}`}}}async function a(e){let{repoUrl:t,targetDir:r,timeout:n,onProgress:c,onError:a,onLog:u}=e,l=(0,o.basename)(t,".git");return new Promise(e=>{let p=Date.now(),g={projectName:l,status:i.ProjectStatus.CLONING,progress:0,message:"开始克隆项目...",startTime:p};c?.(0,"开始克隆项目...");let d=(0,o.join)(r,l),m=["clone","--progress","--verbose",t,d];u?.(l,"stdout",`[开始克隆] 执行命令: git ${m.join(" ")}
1
+ module.exports={88941:e=>{"use strict";var{g:t,__dirname:r}=e;{e.s({PROJECT_CONFIG_PATH:()=>r,ProjectStatus:()=>o,WORKSPACE_CONFIG:()=>t});var s=e.i(13442),n=e.i(30331);let t={WORKSPACE_ROOT:(0,n.join)((0,s.homedir)(),"Documents","prime-workspace"),GIT_TIMEOUT:3e5,MAX_CONCURRENT_CLONES:Math.max(2,Math.min((0,s.cpus)().length,8)),MAX_RETRY_ATTEMPTS:3},r=(0,n.join)((0,s.homedir)(),".prime-projects.json");var o=function(e){return e.PENDING="pending",e.EXISTING="existing",e.CLONING="cloning",e.SUCCESS="success",e.FAILED="failed",e.RETRYING="retrying",e.INCOMPLETE="incomplete",e}({})}},30331:function(e){var{g:t,__dirname:r,m:s,e:n}=e;s.exports=e.x("path",()=>require("path"))},29549:function(e){var{g:t,__dirname:r,m:s,e:n}=e;s.exports=e.x("next/dist/compiled/next-server/app-page-turbo.runtime.prod.js",()=>require("next/dist/compiled/next-server/app-page-turbo.runtime.prod.js"))},83943:function(e){var{g:t,__dirname:r,m:s,e:n}=e;s.exports=e.x("next/dist/server/app-render/work-unit-async-storage.external.js",()=>require("next/dist/server/app-render/work-unit-async-storage.external.js"))},86103:function(e){var{g:t,__dirname:r,m:s,e:n}=e;s.exports=e.x("next/dist/server/app-render/work-async-storage.external.js",()=>require("next/dist/server/app-render/work-async-storage.external.js"))},23430:function(e){var{g:t,__dirname:r,m:s,e:n}=e;s.exports=e.x("next/dist/compiled/@opentelemetry/api",()=>require("next/dist/compiled/@opentelemetry/api"))},52670:function(e){var{g:t,__dirname:r,m:s,e:n}=e;s.exports=e.x("next/dist/compiled/next-server/app-route-turbo.runtime.prod.js",()=>require("next/dist/compiled/next-server/app-route-turbo.runtime.prod.js"))},13442:function(e){var{g:t,__dirname:r,m:s,e:n}=e;s.exports=e.x("os",()=>require("os"))},9892:function(e){var{g:t,__dirname:r,m:s,e:n}=e;s.exports=e.x("fs/promises",()=>require("fs/promises"))},35692:e=>{"use strict";var{g:t,__dirname:r}=e;e.s({ProjectStatus:()=>c,getProjectsConfig:()=>o,saveProjectsConfig:()=>i});var s=e.i(9892),n=e.i(88941);async function o(){try{await (0,s.access)(n.PROJECT_CONFIG_PATH,s.constants.F_OK)}catch{return await i({}),{}}try{let e=await (0,s.readFile)(n.PROJECT_CONFIG_PATH,"utf-8");if(!e)return{};return JSON.parse(e)}catch(e){throw console.error("读取或解析项目配置文件失败:",e),Error("无法加载项目配置")}}async function i(e){let t=n.PROJECT_CONFIG_PATH+".tmp";try{await (0,s.writeFile)(t,JSON.stringify(e,null,2),"utf-8"),await (0,s.rename)(t,n.PROJECT_CONFIG_PATH)}catch(e){throw console.error("保存项目配置文件失败:",e),Error("无法保存项目配置")}}var c=function(e){return e.PENDING="pending",e.EXISTING="existing",e.CLONING="cloning",e.SUCCESS="success",e.FAILED="failed",e.RETRYING="retrying",e}({})},83886:function(e){var{g:t,__dirname:r,m:s,e:n}=e;s.exports=e.x("fs",()=>require("fs"))},87485:function(e){var{g:t,__dirname:r,m:s,e:n}=e;s.exports=e.x("child_process",()=>require("child_process"))},77159:e=>{"use strict";var{g:t,__dirname:r}=e;e.s({checkMultipleProjectsExist:()=>h,checkProjectExists:()=>g,checkProjectStatus:()=>p,cleanupIncompleteProject:()=>m,cloneRepository:()=>a,createWorkspaceDirectory:()=>c,isValidGitUrl:()=>u,sanitizeProjectName:()=>l});var s=e.i(87485),n=e.i(83886),o=e.i(30331),i=e.i(88941);async function c(e){try{return(0,n.existsSync)(e)||(0,n.mkdirSync)(e,{recursive:!0}),{success:!0}}catch(e){return{success:!1,error:`创建工作空间目录失败: ${e instanceof Error?e.message:String(e)}`}}}async function a(e){let{repoUrl:t,targetDir:r,timeout:n,onProgress:c,onError:a,onLog:u}=e,l=(0,o.basename)(t,".git");return new Promise(e=>{let p=Date.now(),g={projectName:l,status:i.ProjectStatus.CLONING,progress:0,message:"开始克隆项目...",startTime:p};c?.(0,"开始克隆项目...");let d=(0,o.join)(r,l),m=["clone","--progress","--verbose",t,d];u?.(l,"stdout",`[开始克隆] 执行命令: git ${m.join(" ")}
2
2
  `),u?.(l,"stdout",`[目标目录] ${d}
3
3
  `),u?.(l,"stdout",`[仓库地址] ${t}
4
4
  `);let h=(0,s.spawn)("git",m,{cwd:r,stdio:["pipe","pipe","pipe"]}),f="",y=0;u?.(l,"stdout",`[进程启动] Git 进程 PID: ${h.pid}
@@ -17,4 +17,4 @@ ${f}
17
17
 
18
18
  `;t.enqueue(e.encode(s)),t.close()}}});return new Response(t,{headers:{"Content-Type":"text/event-stream","Cache-Control":"no-cache",Connection:"keep-alive","Access-Control-Allow-Origin":"*","Access-Control-Allow-Headers":"Cache-Control"}})}},80080:e=>{"use strict";var{g:t,__dirname:r}=e;{e.s({patchFetch:()=>c,routeModule:()=>t,serverHooks:()=>u,workAsyncStorage:()=>r,workUnitAsyncStorage:()=>a});var s=e.i(45746),n=e.i(93828),o=e.i(18250),i=e.i(77854);let t=new s.AppRouteRouteModule({definition:{kind:n.RouteKind.APP_ROUTE,page:"/api/initialize-workspace/route",pathname:"/api/initialize-workspace",filename:"route",bundlePath:""},resolvedPagePath:"[project]/packages/server/src/app/api/initialize-workspace/route.ts",nextConfigOutput:"",userland:i}),{workAsyncStorage:r,workUnitAsyncStorage:a,serverHooks:u}=t;function c(){return(0,o.patchFetch)({workAsyncStorage:r,workUnitAsyncStorage:a})}}}};
19
19
 
20
- //# sourceMappingURL=%5Broot-of-the-server%5D__7fc974c9._.js.map
20
+ //# sourceMappingURL=%5Broot-of-the-server%5D__b176e8df._.js.map
@@ -1,4 +1,4 @@
1
- module.exports={29549:function(e){var{g:t,__dirname:r,m:a,e:n}=e;a.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:a,e:n}=e;a.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:a,e:n}=e;a.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:a,e:n}=e;a.exports=e.x("path",()=>require("path"))},23430:function(e){var{g:t,__dirname:r,m:a,e:n}=e;a.exports=e.x("next/dist/compiled/@opentelemetry/api",()=>require("next/dist/compiled/@opentelemetry/api"))},13442:function(e){var{g:t,__dirname:r,m:a,e:n}=e;a.exports=e.x("os",()=>require("os"))},52670:function(e){var{g:t,__dirname:r,m:a,e:n}=e;a.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:a,e:n}=e;a.exports=e.x("fs/promises",()=>require("fs/promises"))},70967:e=>{"use strict";var{g:t,__dirname:r}=e;{e.s({appendLog:()=>d,cleanupOldLogs:()=>g,deleteProcessLogs:()=>y,getLogsDirSize:()=>m,getProcessLogPath:()=>s,readLastNLines:()=>f,rotateLogFile:()=>u,startLogCleanupTask:()=>w,stopLogCleanupTask:()=>x,truncateLogLine:()=>l,writeLogsSync:()=>p});var a=e.i(9892),n=e.i(30331),o=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 i(){return n.default.join(o.default.homedir(),".prime-process-logs")}function s(e){return n.default.join(i(),`${e}.log`)}function l(e){return e.length<=t.MAX_LINE_LENGTH?e:e.substring(0,t.MAX_LINE_LENGTH)+"... [truncated]"}async function c(e){try{return(await a.default.stat(e)).size}catch{return 0}}async function u(e){let r=s(e),n=await c(r);if(!(n<t.MAX_FILE_SIZE)){console.log(`[日志管理] 轮转日志文件: ${e}, 大小: ${(n/1024/1024).toFixed(2)}MB`);try{let n=`${r}.${t.MAX_LOG_FILES}`;try{await a.default.unlink(n)}catch{}for(let e=t.MAX_LOG_FILES-1;e>=1;e--){let t=1===e?r:`${r}.${e}`,n=`${r}.${e+1}`;try{await a.default.rename(t,n)}catch{}}await a.default.rename(r,`${r}.1`),await a.default.writeFile(r,"","utf-8"),console.log(`[日志管理] 日志轮转完成: ${e}`)}catch(t){console.error(`[日志管理] 轮转日志文件失败: ${e}`,t)}}}async function d(e,t){await u(e);let r=s(e),n=l(t);try{await a.default.mkdir(i(),{recursive:!0}),await a.default.appendFile(r,n+"\n","utf-8")}catch(t){console.error(`[日志管理] 追加日志失败: ${e}`,t)}}async function p(e,t){await u(e);let r=s(e),n=t.map(e=>l(e));try{await a.default.mkdir(i(),{recursive:!0}),await a.default.writeFile(r,n.join("\n")+"\n","utf-8")}catch(t){console.error(`[日志管理] 写入日志失败: ${e}`,t)}}async function f(e,t=100){let r=s(e);try{return(await a.default.readFile(r,"utf-8")).split("\n").filter(e=>e.trim()).slice(-t)}catch{return[]}}async function g(){console.log("[日志管理] 开始清理旧日志...");try{let e=i();try{await a.default.access(e)}catch{console.log("[日志管理] 日志目录不存在,无需清理");return}let r=await a.default.readdir(e),o=Date.now(),s=24*t.MAX_LOG_AGE_DAYS*36e5,l=0,c=0;for(let t of r){let r=n.default.join(e,t);try{let e=await a.default.stat(r);if(o-e.mtime.getTime()>s){c+=e.size;try{await a.default.unlink(r),l++,console.log(`[日志管理] 删除过期日志: ${t}`)}catch(e){e?.code!=="ENOENT"&&console.error(`[日志管理] 删除文件失败: ${t}`,e)}}}catch(e){e?.code!=="ENOENT"&&console.error(`[日志管理] 处理文件失败: ${t}`,e)}}console.log(`[日志管理] 清理完成: 删除 ${l} 个文件, 释放 ${(c/1024/1024).toFixed(2)}MB`)}catch(e){console.error("[日志管理] 清理日志失败:",e)}}async function y(e){let r=s(e);try{await a.default.unlink(r)}catch(t){t?.code!=="ENOENT"&&console.error(`[日志管理] 删除主日志文件失败: ${e}`,t)}for(let n=1;n<=t.MAX_LOG_FILES;n++)try{await a.default.unlink(`${r}.${n}`)}catch(t){t?.code!=="ENOENT"&&console.error(`[日志管理] 删除轮转日志文件失败: ${e}.${n}`,t)}console.log(`[日志管理] 删除进程日志: ${e}`)}async function m(){try{let e=i(),t=await a.default.readdir(e),r=0,o=0;for(let i of t)try{let t=await a.default.stat(n.default.join(e,i));r+=t.size,o++}catch{}return{totalSize:r,fileCount:o}}catch{return{totalSize:0,fileCount:0}}}let r=null;function w(){r||(console.log("[日志管理] 启动定期清理任务"),g(),r=setInterval(()=>{g()},t.CLEANUP_INTERVAL))}function x(){r&&(clearInterval(r),r=null,console.log("[日志管理] 停止定期清理任务"))}process.on("SIGINT",()=>{x()}),process.on("SIGTERM",()=>{x()})}},33939:function(e){var{g:t,__dirname:r,m:a,e:n}=e},82988:e=>{"use strict";var{g:t,__dirname:r}=e;e.s({GET:()=>o});var a=e.i(70967),n=e.i(9892);async function o(e){let{searchParams:t}=new URL(e.url),r=t.get("projectName"),o=t.get("envName");if(!r||!o)return new Response("缺少必要参数",{status:400});let i=`${r}-${o}`,s=(0,a.getProcessLogPath)(i);return new Response(new ReadableStream({async start(t){let r=new TextEncoder;t.enqueue(r.encode(": ping\n\n"));try{for(let e of(await (0,a.readLastNLines)(i,100))){let a=`data: ${JSON.stringify({type:"log",content:e})}
1
+ module.exports={30331:function(e){var{g:t,__dirname:r,m:a,e:n}=e;a.exports=e.x("path",()=>require("path"))},29549:function(e){var{g:t,__dirname:r,m:a,e:n}=e;a.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:a,e:n}=e;a.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:a,e:n}=e;a.exports=e.x("next/dist/server/app-render/work-async-storage.external.js",()=>require("next/dist/server/app-render/work-async-storage.external.js"))},23430:function(e){var{g:t,__dirname:r,m:a,e:n}=e;a.exports=e.x("next/dist/compiled/@opentelemetry/api",()=>require("next/dist/compiled/@opentelemetry/api"))},52670:function(e){var{g:t,__dirname:r,m:a,e:n}=e;a.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"))},13442:function(e){var{g:t,__dirname:r,m:a,e:n}=e;a.exports=e.x("os",()=>require("os"))},9892:function(e){var{g:t,__dirname:r,m:a,e:n}=e;a.exports=e.x("fs/promises",()=>require("fs/promises"))},70967:e=>{"use strict";var{g:t,__dirname:r}=e;{e.s({appendLog:()=>d,cleanupOldLogs:()=>g,deleteProcessLogs:()=>y,getLogsDirSize:()=>m,getProcessLogPath:()=>s,readLastNLines:()=>f,rotateLogFile:()=>u,startLogCleanupTask:()=>w,stopLogCleanupTask:()=>x,truncateLogLine:()=>l,writeLogsSync:()=>p});var a=e.i(9892),n=e.i(30331),o=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 i(){return n.default.join(o.default.homedir(),".prime-process-logs")}function s(e){return n.default.join(i(),`${e}.log`)}function l(e){return e.length<=t.MAX_LINE_LENGTH?e:e.substring(0,t.MAX_LINE_LENGTH)+"... [truncated]"}async function c(e){try{return(await a.default.stat(e)).size}catch{return 0}}async function u(e){let r=s(e),n=await c(r);if(!(n<t.MAX_FILE_SIZE)){console.log(`[日志管理] 轮转日志文件: ${e}, 大小: ${(n/1024/1024).toFixed(2)}MB`);try{let n=`${r}.${t.MAX_LOG_FILES}`;try{await a.default.unlink(n)}catch{}for(let e=t.MAX_LOG_FILES-1;e>=1;e--){let t=1===e?r:`${r}.${e}`,n=`${r}.${e+1}`;try{await a.default.rename(t,n)}catch{}}await a.default.rename(r,`${r}.1`),await a.default.writeFile(r,"","utf-8"),console.log(`[日志管理] 日志轮转完成: ${e}`)}catch(t){console.error(`[日志管理] 轮转日志文件失败: ${e}`,t)}}}async function d(e,t){await u(e);let r=s(e),n=l(t);try{await a.default.mkdir(i(),{recursive:!0}),await a.default.appendFile(r,n+"\n","utf-8")}catch(t){console.error(`[日志管理] 追加日志失败: ${e}`,t)}}async function p(e,t){await u(e);let r=s(e),n=t.map(e=>l(e));try{await a.default.mkdir(i(),{recursive:!0}),await a.default.writeFile(r,n.join("\n")+"\n","utf-8")}catch(t){console.error(`[日志管理] 写入日志失败: ${e}`,t)}}async function f(e,t=100){let r=s(e);try{return(await a.default.readFile(r,"utf-8")).split("\n").filter(e=>e.trim()).slice(-t)}catch{return[]}}async function g(){console.log("[日志管理] 开始清理旧日志...");try{let e=i();try{await a.default.access(e)}catch{console.log("[日志管理] 日志目录不存在,无需清理");return}let r=await a.default.readdir(e),o=Date.now(),s=24*t.MAX_LOG_AGE_DAYS*36e5,l=0,c=0;for(let t of r){let r=n.default.join(e,t);try{let e=await a.default.stat(r);if(o-e.mtime.getTime()>s){c+=e.size;try{await a.default.unlink(r),l++,console.log(`[日志管理] 删除过期日志: ${t}`)}catch(e){e?.code!=="ENOENT"&&console.error(`[日志管理] 删除文件失败: ${t}`,e)}}}catch(e){e?.code!=="ENOENT"&&console.error(`[日志管理] 处理文件失败: ${t}`,e)}}console.log(`[日志管理] 清理完成: 删除 ${l} 个文件, 释放 ${(c/1024/1024).toFixed(2)}MB`)}catch(e){console.error("[日志管理] 清理日志失败:",e)}}async function y(e){let r=s(e);try{await a.default.unlink(r)}catch(t){t?.code!=="ENOENT"&&console.error(`[日志管理] 删除主日志文件失败: ${e}`,t)}for(let n=1;n<=t.MAX_LOG_FILES;n++)try{await a.default.unlink(`${r}.${n}`)}catch(t){t?.code!=="ENOENT"&&console.error(`[日志管理] 删除轮转日志文件失败: ${e}.${n}`,t)}console.log(`[日志管理] 删除进程日志: ${e}`)}async function m(){try{let e=i(),t=await a.default.readdir(e),r=0,o=0;for(let i of t)try{let t=await a.default.stat(n.default.join(e,i));r+=t.size,o++}catch{}return{totalSize:r,fileCount:o}}catch{return{totalSize:0,fileCount:0}}}let r=null;function w(){r||(console.log("[日志管理] 启动定期清理任务"),g(),r=setInterval(()=>{g()},t.CLEANUP_INTERVAL))}function x(){r&&(clearInterval(r),r=null,console.log("[日志管理] 停止定期清理任务"))}process.on("SIGINT",()=>{x()}),process.on("SIGTERM",()=>{x()})}},33939:function(e){var{g:t,__dirname:r,m:a,e:n}=e},82988:e=>{"use strict";var{g:t,__dirname:r}=e;e.s({GET:()=>o});var a=e.i(70967),n=e.i(9892);async function o(e){let{searchParams:t}=new URL(e.url),r=t.get("projectName"),o=t.get("envName");if(!r||!o)return new Response("缺少必要参数",{status:400});let i=`${r}-${o}`,s=(0,a.getProcessLogPath)(i);return new Response(new ReadableStream({async start(t){let r=new TextEncoder;t.enqueue(r.encode(": ping\n\n"));try{for(let e of(await (0,a.readLastNLines)(i,100))){let a=`data: ${JSON.stringify({type:"log",content:e})}
2
2
 
3
3
  `;t.enqueue(r.encode(a))}}catch{let e=`data: ${JSON.stringify({type:"init",message:"等待日志..."})}
4
4
 
@@ -12,4 +12,4 @@ module.exports={29549:function(e){var{g:t,__dirname:r,m:a,e:n}=e;a.exports=e.x("
12
12
 
13
13
  `;t.enqueue(r.encode(e)),o=0,l=0}}t.enqueue(r.encode(": ping\n\n"))},2e3);e.signal.addEventListener("abort",()=>{clearInterval(c),t.close()})}}),{headers:{"Content-Type":"text/event-stream","Cache-Control":"no-cache",Connection:"keep-alive"}})}},13002:e=>{"use strict";var{g:t,__dirname:r}=e;{e.s({patchFetch:()=>s,routeModule:()=>t,serverHooks:()=>c,workAsyncStorage:()=>r,workUnitAsyncStorage:()=>l});var a=e.i(45746),n=e.i(93828),o=e.i(18250),i=e.i(82988);let t=new a.AppRouteRouteModule({definition:{kind:n.RouteKind.APP_ROUTE,page:"/api/process/logs/stream/route",pathname:"/api/process/logs/stream",filename:"route",bundlePath:""},resolvedPagePath:"[project]/packages/server/src/app/api/process/logs/stream/route.ts",nextConfigOutput:"",userland:i}),{workAsyncStorage:r,workUnitAsyncStorage:l,serverHooks:c}=t;function s(){return(0,o.patchFetch)({workAsyncStorage:r,workUnitAsyncStorage:l})}}}};
14
14
 
15
- //# sourceMappingURL=%5Broot-of-the-server%5D__a292866b._.js.map
15
+ //# sourceMappingURL=%5Broot-of-the-server%5D__be14bdb6._.js.map
@@ -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"))},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:()=>a,getProjectsConfig:()=>o,saveProjectsConfig:()=>i});var s=e.i(9892),n=e.i(88941);async function o(){try{await (0,s.access)(n.PROJECT_CONFIG_PATH,s.constants.F_OK)}catch{return await i({}),{}}try{let e=await (0,s.readFile)(n.PROJECT_CONFIG_PATH,"utf-8");if(!e)return{};return JSON.parse(e)}catch(e){throw console.error("读取或解析项目配置文件失败:",e),Error("无法加载项目配置")}}async function i(e){let r=n.PROJECT_CONFIG_PATH+".tmp";try{await (0,s.writeFile)(r,JSON.stringify(e,null,2),"utf-8"),await (0,s.rename)(r,n.PROJECT_CONFIG_PATH)}catch(e){throw console.error("保存项目配置文件失败:",e),Error("无法保存项目配置")}}var a=function(e){return e.PENDING="pending",e.EXISTING="existing",e.CLONING="cloning",e.SUCCESS="success",e.FAILED="failed",e.RETRYING="retrying",e}({})},15564:function(e){var{g:r,__dirname:t,m:s,e:n}=e},35139:e=>{"use strict";var{g:r,__dirname:t}=e;e.s({DELETE:()=>c});var s=e.i(15494),n=e.i(83886),o=e.i(30331),i=e.i(35692),a=e.i(88941);async function c(e){try{let{searchParams:r}=new URL(e.url),t=r.get("project"),c=r.get("apiName");if(!t||!c)return s.NextResponse.json({success:!1,error:"缺少必要参数:project, apiName"},{status:400});if(!(await (0,i.getProjectsConfig)())[t])return s.NextResponse.json({success:!1,error:`项目 ${t} 不存在`},{status:404});let p=(0,o.join)(a.WORKSPACE_CONFIG.WORKSPACE_ROOT,t),u=(0,o.join)(p,".mock",c);try{await n.promises.access(u)}catch{return s.NextResponse.json({success:!1,error:"Mock接口目录不存在"},{status:404})}await n.promises.rmdir(u,{recursive:!0});let d=(0,o.join)(p,".mock");try{let e=await n.promises.readdir(d);0===e.length&&await n.promises.rmdir(d)}catch{}return s.NextResponse.json({success:!0,message:"Mock接口删除成功",data:{projectName:t,apiName:c,deletedPath:(0,o.join)(".mock",c)}})}catch(r){let e=r instanceof Error?r.message:"删除Mock接口失败";return console.error("删除Mock接口失败:",r),s.NextResponse.json({success:!1,error:e},{status:500})}}},19444:e=>{"use strict";var{g:r,__dirname:t}=e;{e.s({patchFetch:()=>a,routeModule:()=>r,serverHooks:()=>p,workAsyncStorage:()=>t,workUnitAsyncStorage:()=>c});var s=e.i(45746),n=e.i(93828),o=e.i(18250),i=e.i(35139);let r=new s.AppRouteRouteModule({definition:{kind:n.RouteKind.APP_ROUTE,page:"/api/delete-mock-api/route",pathname:"/api/delete-mock-api",filename:"route",bundlePath:""},resolvedPagePath:"[project]/packages/server/src/app/api/delete-mock-api/route.ts",nextConfigOutput:"",userland:i}),{workAsyncStorage:t,workUnitAsyncStorage:c,serverHooks:p}=r;function a(){return(0,o.patchFetch)({workAsyncStorage:t,workUnitAsyncStorage:c})}}}};
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}({})}},30331:function(e){var{g:r,__dirname:t,m:s,e:n}=e;s.exports=e.x("path",()=>require("path"))},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"))},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"))},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"))},13442:function(e){var{g:r,__dirname:t,m:s,e:n}=e;s.exports=e.x("os",()=>require("os"))},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:()=>a,getProjectsConfig:()=>o,saveProjectsConfig:()=>i});var s=e.i(9892),n=e.i(88941);async function o(){try{await (0,s.access)(n.PROJECT_CONFIG_PATH,s.constants.F_OK)}catch{return await i({}),{}}try{let e=await (0,s.readFile)(n.PROJECT_CONFIG_PATH,"utf-8");if(!e)return{};return JSON.parse(e)}catch(e){throw console.error("读取或解析项目配置文件失败:",e),Error("无法加载项目配置")}}async function i(e){let r=n.PROJECT_CONFIG_PATH+".tmp";try{await (0,s.writeFile)(r,JSON.stringify(e,null,2),"utf-8"),await (0,s.rename)(r,n.PROJECT_CONFIG_PATH)}catch(e){throw console.error("保存项目配置文件失败:",e),Error("无法保存项目配置")}}var a=function(e){return e.PENDING="pending",e.EXISTING="existing",e.CLONING="cloning",e.SUCCESS="success",e.FAILED="failed",e.RETRYING="retrying",e}({})},15564:function(e){var{g:r,__dirname:t,m:s,e:n}=e},35139:e=>{"use strict";var{g:r,__dirname:t}=e;e.s({DELETE:()=>c});var s=e.i(15494),n=e.i(83886),o=e.i(30331),i=e.i(35692),a=e.i(88941);async function c(e){try{let{searchParams:r}=new URL(e.url),t=r.get("project"),c=r.get("apiName");if(!t||!c)return s.NextResponse.json({success:!1,error:"缺少必要参数:project, apiName"},{status:400});if(!(await (0,i.getProjectsConfig)())[t])return s.NextResponse.json({success:!1,error:`项目 ${t} 不存在`},{status:404});let p=(0,o.join)(a.WORKSPACE_CONFIG.WORKSPACE_ROOT,t),u=(0,o.join)(p,".mock",c);try{await n.promises.access(u)}catch{return s.NextResponse.json({success:!1,error:"Mock接口目录不存在"},{status:404})}await n.promises.rmdir(u,{recursive:!0});let d=(0,o.join)(p,".mock");try{let e=await n.promises.readdir(d);0===e.length&&await n.promises.rmdir(d)}catch{}return s.NextResponse.json({success:!0,message:"Mock接口删除成功",data:{projectName:t,apiName:c,deletedPath:(0,o.join)(".mock",c)}})}catch(r){let e=r instanceof Error?r.message:"删除Mock接口失败";return console.error("删除Mock接口失败:",r),s.NextResponse.json({success:!1,error:e},{status:500})}}},19444:e=>{"use strict";var{g:r,__dirname:t}=e;{e.s({patchFetch:()=>a,routeModule:()=>r,serverHooks:()=>p,workAsyncStorage:()=>t,workUnitAsyncStorage:()=>c});var s=e.i(45746),n=e.i(93828),o=e.i(18250),i=e.i(35139);let r=new s.AppRouteRouteModule({definition:{kind:n.RouteKind.APP_ROUTE,page:"/api/delete-mock-api/route",pathname:"/api/delete-mock-api",filename:"route",bundlePath:""},resolvedPagePath:"[project]/packages/server/src/app/api/delete-mock-api/route.ts",nextConfigOutput:"",userland:i}),{workAsyncStorage:t,workUnitAsyncStorage:c,serverHooks:p}=r;function a(){return(0,o.patchFetch)({workAsyncStorage:t,workUnitAsyncStorage:c})}}}};
2
2
 
3
- //# sourceMappingURL=%5Broot-of-the-server%5D__f815ea40._.js.map
3
+ //# sourceMappingURL=%5Broot-of-the-server%5D__c18498ef._.js.map
@@ -1,3 +1,3 @@
1
- module.exports={45935:function(e){var{g:t,__dirname:r,m:a,e:s}=e;a.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:r,m:a,e:s}=e;a.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:a,e:s}=e;a.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:a,e:s}=e;a.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:a,e:s}=e;a.exports=e.x("path",()=>require("path"))},23430:function(e){var{g:t,__dirname:r,m:a,e:s}=e;a.exports=e.x("next/dist/compiled/@opentelemetry/api",()=>require("next/dist/compiled/@opentelemetry/api"))},13442:function(e){var{g:t,__dirname:r,m:a,e:s}=e;a.exports=e.x("os",()=>require("os"))},52670:function(e){var{g:t,__dirname:r,m:a,e:s}=e;a.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:a,e:s}=e;a.exports=e.x("fs/promises",()=>require("fs/promises"))},70967:e=>{"use strict";var{g:t,__dirname:r}=e;{e.s({appendLog:()=>p,cleanupOldLogs:()=>g,deleteProcessLogs:()=>x,getLogsDirSize:()=>m,getProcessLogPath:()=>i,readLastNLines:()=>f,rotateLogFile:()=>u,startLogCleanupTask:()=>L,stopLogCleanupTask:()=>y,truncateLogLine:()=>c,writeLogsSync:()=>d});var a=e.i(9892),s=e.i(30331),o=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 n(){return s.default.join(o.default.homedir(),".prime-process-logs")}function i(e){return s.default.join(n(),`${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 a.default.stat(e)).size}catch{return 0}}async function u(e){let r=i(e),s=await l(r);if(!(s<t.MAX_FILE_SIZE)){console.log(`[日志管理] 轮转日志文件: ${e}, 大小: ${(s/1024/1024).toFixed(2)}MB`);try{let s=`${r}.${t.MAX_LOG_FILES}`;try{await a.default.unlink(s)}catch{}for(let e=t.MAX_LOG_FILES-1;e>=1;e--){let t=1===e?r:`${r}.${e}`,s=`${r}.${e+1}`;try{await a.default.rename(t,s)}catch{}}await a.default.rename(r,`${r}.1`),await a.default.writeFile(r,"","utf-8"),console.log(`[日志管理] 日志轮转完成: ${e}`)}catch(t){console.error(`[日志管理] 轮转日志文件失败: ${e}`,t)}}}async function p(e,t){await u(e);let r=i(e),s=c(t);try{await a.default.mkdir(n(),{recursive:!0}),await a.default.appendFile(r,s+"\n","utf-8")}catch(t){console.error(`[日志管理] 追加日志失败: ${e}`,t)}}async function d(e,t){await u(e);let r=i(e),s=t.map(e=>c(e));try{await a.default.mkdir(n(),{recursive:!0}),await a.default.writeFile(r,s.join("\n")+"\n","utf-8")}catch(t){console.error(`[日志管理] 写入日志失败: ${e}`,t)}}async function f(e,t=100){let r=i(e);try{return(await a.default.readFile(r,"utf-8")).split("\n").filter(e=>e.trim()).slice(-t)}catch{return[]}}async function g(){console.log("[日志管理] 开始清理旧日志...");try{let e=n();try{await a.default.access(e)}catch{console.log("[日志管理] 日志目录不存在,无需清理");return}let r=await a.default.readdir(e),o=Date.now(),i=24*t.MAX_LOG_AGE_DAYS*36e5,c=0,l=0;for(let t of r){let r=s.default.join(e,t);try{let e=await a.default.stat(r);if(o-e.mtime.getTime()>i){l+=e.size;try{await a.default.unlink(r),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 x(e){let r=i(e);try{await a.default.unlink(r)}catch(t){t?.code!=="ENOENT"&&console.error(`[日志管理] 删除主日志文件失败: ${e}`,t)}for(let s=1;s<=t.MAX_LOG_FILES;s++)try{await a.default.unlink(`${r}.${s}`)}catch(t){t?.code!=="ENOENT"&&console.error(`[日志管理] 删除轮转日志文件失败: ${e}.${s}`,t)}console.log(`[日志管理] 删除进程日志: ${e}`)}async function m(){try{let e=n(),t=await a.default.readdir(e),r=0,o=0;for(let n of t)try{let t=await a.default.stat(s.default.join(e,n));r+=t.size,o++}catch{}return{totalSize:r,fileCount:o}}catch{return{totalSize:0,fileCount:0}}}let r=null;function L(){r||(console.log("[日志管理] 启动定期清理任务"),g(),r=setInterval(()=>{g()},t.CLEANUP_INTERVAL))}function y(){r&&(clearInterval(r),r=null,console.log("[日志管理] 停止定期清理任务"))}process.on("SIGINT",()=>{y()}),process.on("SIGTERM",()=>{y()})}},24713:function(e){var{g:t,__dirname:r,m:a,e:s}=e},57948:e=>{"use strict";var{g:t,__dirname:r}=e;e.s({DELETE:()=>i,GET:()=>n});var a=e.i(15494),s=e.i(70967),o=e.i(9892);async function n(e){try{let{searchParams:t}=new URL(e.url),r=t.get("projectName"),n=t.get("envName"),i=t.get("tail")||"100";if(!r||!n)return a.NextResponse.json({success:!1,error:"缺少必要参数"},{status:400});let c=`${r}-${n}`,l=parseInt(i);try{let e=await (0,s.readLastNLines)(c,l),t=e.length;try{let e=(0,s.getProcessLogPath)(c);t=(await o.default.readFile(e,"utf-8")).split("\n").filter(e=>e.trim()).length}catch{}return a.NextResponse.json({success:!0,data:{logs:e,totalLines:t,tailCount:e.length}})}catch{return a.NextResponse.json({success:!0,data:{logs:[],totalLines:0,tailCount:0}})}}catch(e){return console.error("获取进程日志失败:",e),a.NextResponse.json({success:!1,error:e instanceof Error?e.message:"获取进程日志失败"},{status:500})}}async function i(e){try{let{searchParams:t}=new URL(e.url),r=t.get("projectName"),o=t.get("envName");if(!r||!o)return a.NextResponse.json({success:!1,error:"缺少必要参数"},{status:400});let n=`${r}-${o}`;return await (0,s.deleteProcessLogs)(n),a.NextResponse.json({success:!0,message:"日志已清除"})}catch(e){return console.error("清除进程日志失败:",e),a.NextResponse.json({success:!1,error:e instanceof Error?e.message:"清除进程日志失败"},{status:500})}}},47527:e=>{"use strict";var{g:t,__dirname:r}=e;{e.s({patchFetch:()=>i,routeModule:()=>t,serverHooks:()=>l,workAsyncStorage:()=>r,workUnitAsyncStorage:()=>c});var a=e.i(45746),s=e.i(93828),o=e.i(18250),n=e.i(57948);let t=new a.AppRouteRouteModule({definition:{kind:s.RouteKind.APP_ROUTE,page:"/api/process/logs/route",pathname:"/api/process/logs",filename:"route",bundlePath:""},resolvedPagePath:"[project]/packages/server/src/app/api/process/logs/route.ts",nextConfigOutput:"",userland:n}),{workAsyncStorage:r,workUnitAsyncStorage:c,serverHooks:l}=t;function i(){return(0,o.patchFetch)({workAsyncStorage:r,workUnitAsyncStorage:c})}}}};
1
+ module.exports={45935:function(e){var{g:t,__dirname:r,m:a,e:s}=e;a.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"))},30331:function(e){var{g:t,__dirname:r,m:a,e:s}=e;a.exports=e.x("path",()=>require("path"))},29549:function(e){var{g:t,__dirname:r,m:a,e:s}=e;a.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:a,e:s}=e;a.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:a,e:s}=e;a.exports=e.x("next/dist/server/app-render/work-async-storage.external.js",()=>require("next/dist/server/app-render/work-async-storage.external.js"))},23430:function(e){var{g:t,__dirname:r,m:a,e:s}=e;a.exports=e.x("next/dist/compiled/@opentelemetry/api",()=>require("next/dist/compiled/@opentelemetry/api"))},52670:function(e){var{g:t,__dirname:r,m:a,e:s}=e;a.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"))},13442:function(e){var{g:t,__dirname:r,m:a,e:s}=e;a.exports=e.x("os",()=>require("os"))},9892:function(e){var{g:t,__dirname:r,m:a,e:s}=e;a.exports=e.x("fs/promises",()=>require("fs/promises"))},70967:e=>{"use strict";var{g:t,__dirname:r}=e;{e.s({appendLog:()=>p,cleanupOldLogs:()=>g,deleteProcessLogs:()=>x,getLogsDirSize:()=>m,getProcessLogPath:()=>i,readLastNLines:()=>f,rotateLogFile:()=>u,startLogCleanupTask:()=>L,stopLogCleanupTask:()=>y,truncateLogLine:()=>c,writeLogsSync:()=>d});var a=e.i(9892),s=e.i(30331),o=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 n(){return s.default.join(o.default.homedir(),".prime-process-logs")}function i(e){return s.default.join(n(),`${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 a.default.stat(e)).size}catch{return 0}}async function u(e){let r=i(e),s=await l(r);if(!(s<t.MAX_FILE_SIZE)){console.log(`[日志管理] 轮转日志文件: ${e}, 大小: ${(s/1024/1024).toFixed(2)}MB`);try{let s=`${r}.${t.MAX_LOG_FILES}`;try{await a.default.unlink(s)}catch{}for(let e=t.MAX_LOG_FILES-1;e>=1;e--){let t=1===e?r:`${r}.${e}`,s=`${r}.${e+1}`;try{await a.default.rename(t,s)}catch{}}await a.default.rename(r,`${r}.1`),await a.default.writeFile(r,"","utf-8"),console.log(`[日志管理] 日志轮转完成: ${e}`)}catch(t){console.error(`[日志管理] 轮转日志文件失败: ${e}`,t)}}}async function p(e,t){await u(e);let r=i(e),s=c(t);try{await a.default.mkdir(n(),{recursive:!0}),await a.default.appendFile(r,s+"\n","utf-8")}catch(t){console.error(`[日志管理] 追加日志失败: ${e}`,t)}}async function d(e,t){await u(e);let r=i(e),s=t.map(e=>c(e));try{await a.default.mkdir(n(),{recursive:!0}),await a.default.writeFile(r,s.join("\n")+"\n","utf-8")}catch(t){console.error(`[日志管理] 写入日志失败: ${e}`,t)}}async function f(e,t=100){let r=i(e);try{return(await a.default.readFile(r,"utf-8")).split("\n").filter(e=>e.trim()).slice(-t)}catch{return[]}}async function g(){console.log("[日志管理] 开始清理旧日志...");try{let e=n();try{await a.default.access(e)}catch{console.log("[日志管理] 日志目录不存在,无需清理");return}let r=await a.default.readdir(e),o=Date.now(),i=24*t.MAX_LOG_AGE_DAYS*36e5,c=0,l=0;for(let t of r){let r=s.default.join(e,t);try{let e=await a.default.stat(r);if(o-e.mtime.getTime()>i){l+=e.size;try{await a.default.unlink(r),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 x(e){let r=i(e);try{await a.default.unlink(r)}catch(t){t?.code!=="ENOENT"&&console.error(`[日志管理] 删除主日志文件失败: ${e}`,t)}for(let s=1;s<=t.MAX_LOG_FILES;s++)try{await a.default.unlink(`${r}.${s}`)}catch(t){t?.code!=="ENOENT"&&console.error(`[日志管理] 删除轮转日志文件失败: ${e}.${s}`,t)}console.log(`[日志管理] 删除进程日志: ${e}`)}async function m(){try{let e=n(),t=await a.default.readdir(e),r=0,o=0;for(let n of t)try{let t=await a.default.stat(s.default.join(e,n));r+=t.size,o++}catch{}return{totalSize:r,fileCount:o}}catch{return{totalSize:0,fileCount:0}}}let r=null;function L(){r||(console.log("[日志管理] 启动定期清理任务"),g(),r=setInterval(()=>{g()},t.CLEANUP_INTERVAL))}function y(){r&&(clearInterval(r),r=null,console.log("[日志管理] 停止定期清理任务"))}process.on("SIGINT",()=>{y()}),process.on("SIGTERM",()=>{y()})}},24713:function(e){var{g:t,__dirname:r,m:a,e:s}=e},57948:e=>{"use strict";var{g:t,__dirname:r}=e;e.s({DELETE:()=>i,GET:()=>n});var a=e.i(15494),s=e.i(70967),o=e.i(9892);async function n(e){try{let{searchParams:t}=new URL(e.url),r=t.get("projectName"),n=t.get("envName"),i=t.get("tail")||"100";if(!r||!n)return a.NextResponse.json({success:!1,error:"缺少必要参数"},{status:400});let c=`${r}-${n}`,l=parseInt(i);try{let e=await (0,s.readLastNLines)(c,l),t=e.length;try{let e=(0,s.getProcessLogPath)(c);t=(await o.default.readFile(e,"utf-8")).split("\n").filter(e=>e.trim()).length}catch{}return a.NextResponse.json({success:!0,data:{logs:e,totalLines:t,tailCount:e.length}})}catch{return a.NextResponse.json({success:!0,data:{logs:[],totalLines:0,tailCount:0}})}}catch(e){return console.error("获取进程日志失败:",e),a.NextResponse.json({success:!1,error:e instanceof Error?e.message:"获取进程日志失败"},{status:500})}}async function i(e){try{let{searchParams:t}=new URL(e.url),r=t.get("projectName"),o=t.get("envName");if(!r||!o)return a.NextResponse.json({success:!1,error:"缺少必要参数"},{status:400});let n=`${r}-${o}`;return await (0,s.deleteProcessLogs)(n),a.NextResponse.json({success:!0,message:"日志已清除"})}catch(e){return console.error("清除进程日志失败:",e),a.NextResponse.json({success:!1,error:e instanceof Error?e.message:"清除进程日志失败"},{status:500})}}},47527:e=>{"use strict";var{g:t,__dirname:r}=e;{e.s({patchFetch:()=>i,routeModule:()=>t,serverHooks:()=>l,workAsyncStorage:()=>r,workUnitAsyncStorage:()=>c});var a=e.i(45746),s=e.i(93828),o=e.i(18250),n=e.i(57948);let t=new a.AppRouteRouteModule({definition:{kind:s.RouteKind.APP_ROUTE,page:"/api/process/logs/route",pathname:"/api/process/logs",filename:"route",bundlePath:""},resolvedPagePath:"[project]/packages/server/src/app/api/process/logs/route.ts",nextConfigOutput:"",userland:n}),{workAsyncStorage:r,workUnitAsyncStorage:c,serverHooks:l}=t;function i(){return(0,o.patchFetch)({workAsyncStorage:r,workUnitAsyncStorage:c})}}}};
2
2
 
3
- //# sourceMappingURL=%5Broot-of-the-server%5D__c8b26634._.js.map
3
+ //# sourceMappingURL=%5Broot-of-the-server%5D__c9627539._.js.map
@@ -1,4 +1,4 @@
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:()=>a,getProjectsConfig:()=>o,saveProjectsConfig:()=>i});var s=e.i(9892),n=e.i(88941);async function o(){try{await (0,s.access)(n.PROJECT_CONFIG_PATH,s.constants.F_OK)}catch{return await i({}),{}}try{let e=await (0,s.readFile)(n.PROJECT_CONFIG_PATH,"utf-8");if(!e)return{};return JSON.parse(e)}catch(e){throw console.error("读取或解析项目配置文件失败:",e),Error("无法加载项目配置")}}async function i(e){let r=n.PROJECT_CONFIG_PATH+".tmp";try{await (0,s.writeFile)(r,JSON.stringify(e,null,2),"utf-8"),await (0,s.rename)(r,n.PROJECT_CONFIG_PATH)}catch(e){throw console.error("保存项目配置文件失败:",e),Error("无法保存项目配置")}}var a=function(e){return e.PENDING="pending",e.EXISTING="existing",e.CLONING="cloning",e.SUCCESS="success",e.FAILED="failed",e.RETRYING="retrying",e}({})},15650:function(e){var{g:r,__dirname:t,m:s,e:n}=e;s.exports=e.x("module",()=>require("module"))},94995:function(e){var{g:r,__dirname:t,m:s,e:n}=e},45640:e=>{"use strict";var{g:r,__dirname:t}=e;{e.s({POST:()=>c});var s=e.i(15494),n=e.i(83886),o=e.i(30331),i=e.i(35692),a=e.i(88941);let r=(0,e.i(15650).createRequire)({get url(){return`file://${e.P("packages/server/src/app/api/open-all-mock/route.ts")}`}}.url);async function c(e){try{let{projectName:t}=await e.json();if(!t)return s.NextResponse.json({success:!1,error:"项目名称参数缺失"},{status:400});if(!(await (0,i.getProjectsConfig)())[t])return s.NextResponse.json({success:!1,error:`项目 ${t} 不存在`},{status:404});let c=(0,o.join)(a.WORKSPACE_CONFIG.WORKSPACE_ROOT,t),p=(0,o.join)(c,".mock");try{await n.promises.access(p)}catch{return s.NextResponse.json({success:!0,message:"Mock目录不存在,无需处理",data:{projectName:t,timestamp:new Date().toISOString()}})}let u=async e=>{for(let t of(await n.promises.readdir(e,{withFileTypes:!0}))){let s=(0,o.join)(e,t.name);if(t.isDirectory())await u(s);else if(t.name.endsWith(".cjs")&&"setting.cjs"!==t.name){let s=(0,o.join)(e),i=(0,o.join)(s,"setting.cjs"),a=t.name.replace(".cjs","");try{await n.promises.access(i)}catch{let e=`module.exports = {
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}({})}},30331:function(e){var{g:r,__dirname:t,m:s,e:n}=e;s.exports=e.x("path",()=>require("path"))},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"))},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"))},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"))},13442:function(e){var{g:r,__dirname:t,m:s,e:n}=e;s.exports=e.x("os",()=>require("os"))},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:()=>a,getProjectsConfig:()=>o,saveProjectsConfig:()=>i});var s=e.i(9892),n=e.i(88941);async function o(){try{await (0,s.access)(n.PROJECT_CONFIG_PATH,s.constants.F_OK)}catch{return await i({}),{}}try{let e=await (0,s.readFile)(n.PROJECT_CONFIG_PATH,"utf-8");if(!e)return{};return JSON.parse(e)}catch(e){throw console.error("读取或解析项目配置文件失败:",e),Error("无法加载项目配置")}}async function i(e){let r=n.PROJECT_CONFIG_PATH+".tmp";try{await (0,s.writeFile)(r,JSON.stringify(e,null,2),"utf-8"),await (0,s.rename)(r,n.PROJECT_CONFIG_PATH)}catch(e){throw console.error("保存项目配置文件失败:",e),Error("无法保存项目配置")}}var a=function(e){return e.PENDING="pending",e.EXISTING="existing",e.CLONING="cloning",e.SUCCESS="success",e.FAILED="failed",e.RETRYING="retrying",e}({})},15650:function(e){var{g:r,__dirname:t,m:s,e:n}=e;s.exports=e.x("module",()=>require("module"))},94995:function(e){var{g:r,__dirname:t,m:s,e:n}=e},45640:e=>{"use strict";var{g:r,__dirname:t}=e;{e.s({POST:()=>c});var s=e.i(15494),n=e.i(83886),o=e.i(30331),i=e.i(35692),a=e.i(88941);let r=(0,e.i(15650).createRequire)({get url(){return`file://${e.P("packages/server/src/app/api/open-all-mock/route.ts")}`}}.url);async function c(e){try{let{projectName:t}=await e.json();if(!t)return s.NextResponse.json({success:!1,error:"项目名称参数缺失"},{status:400});if(!(await (0,i.getProjectsConfig)())[t])return s.NextResponse.json({success:!1,error:`项目 ${t} 不存在`},{status:404});let c=(0,o.join)(a.WORKSPACE_CONFIG.WORKSPACE_ROOT,t),p=(0,o.join)(c,".mock");try{await n.promises.access(p)}catch{return s.NextResponse.json({success:!0,message:"Mock目录不存在,无需处理",data:{projectName:t,timestamp:new Date().toISOString()}})}let u=async e=>{for(let t of(await n.promises.readdir(e,{withFileTypes:!0}))){let s=(0,o.join)(e,t.name);if(t.isDirectory())await u(s);else if(t.name.endsWith(".cjs")&&"setting.cjs"!==t.name){let s=(0,o.join)(e),i=(0,o.join)(s,"setting.cjs"),a=t.name.replace(".cjs","");try{await n.promises.access(i)}catch{let e=`module.exports = {
2
2
  // 当前场景名称
3
3
  currentSite: '${a}',
4
4
  // 开启Mock的场景列表
@@ -10,4 +10,4 @@ module.exports={83886:function(e){var{g:r,__dirname:t,m:s,e:n}=e;s.exports=e.x("
10
10
  open: ${JSON.stringify(t.open)}
11
11
  };`;await n.promises.writeFile(i,s,"utf-8")}catch(e){console.warn(`解析setting.cjs失败: ${i}`,e)}}}};return await u(p),s.NextResponse.json({success:!0,message:"所有Mock场景已开启",data:{projectName:t,timestamp:new Date().toISOString()}})}catch(r){let e=r instanceof Error?r.message:"开启Mock场景失败";return console.error("开启Mock场景失败:",r),s.NextResponse.json({success:!1,error:e},{status:500})}}}},40988:e=>{"use strict";var{g:r,__dirname:t}=e;{e.s({patchFetch:()=>a,routeModule:()=>r,serverHooks:()=>p,workAsyncStorage:()=>t,workUnitAsyncStorage:()=>c});var s=e.i(45746),n=e.i(93828),o=e.i(18250),i=e.i(45640);let r=new s.AppRouteRouteModule({definition:{kind:n.RouteKind.APP_ROUTE,page:"/api/open-all-mock/route",pathname:"/api/open-all-mock",filename:"route",bundlePath:""},resolvedPagePath:"[project]/packages/server/src/app/api/open-all-mock/route.ts",nextConfigOutput:"",userland:i}),{workAsyncStorage:t,workUnitAsyncStorage:c,serverHooks:p}=r;function a(){return(0,o.patchFetch)({workAsyncStorage:t,workUnitAsyncStorage:c})}}}};
12
12
 
13
- //# sourceMappingURL=%5Broot-of-the-server%5D__5355b75a._.js.map
13
+ //# sourceMappingURL=%5Broot-of-the-server%5D__dda45cac._.js.map
@@ -0,0 +1,16 @@
1
+ module.exports={30331:function(e){var{g:t,__dirname:r,m:s,e:n}=e;s.exports=e.x("path",()=>require("path"))},29549:function(e){var{g:t,__dirname:r,m:s,e:n}=e;s.exports=e.x("next/dist/compiled/next-server/app-page-turbo.runtime.prod.js",()=>require("next/dist/compiled/next-server/app-page-turbo.runtime.prod.js"))},83943:function(e){var{g:t,__dirname:r,m:s,e:n}=e;s.exports=e.x("next/dist/server/app-render/work-unit-async-storage.external.js",()=>require("next/dist/server/app-render/work-unit-async-storage.external.js"))},86103:function(e){var{g:t,__dirname:r,m:s,e:n}=e;s.exports=e.x("next/dist/server/app-render/work-async-storage.external.js",()=>require("next/dist/server/app-render/work-async-storage.external.js"))},23430:function(e){var{g:t,__dirname:r,m:s,e:n}=e;s.exports=e.x("next/dist/compiled/@opentelemetry/api",()=>require("next/dist/compiled/@opentelemetry/api"))},52670:function(e){var{g:t,__dirname:r,m:s,e:n}=e;s.exports=e.x("next/dist/compiled/next-server/app-route-turbo.runtime.prod.js",()=>require("next/dist/compiled/next-server/app-route-turbo.runtime.prod.js"))},13442:function(e){var{g:t,__dirname:r,m:s,e:n}=e;s.exports=e.x("os",()=>require("os"))},88941:e=>{"use strict";var{g:t,__dirname:r}=e;{e.s({PROJECT_CONFIG_PATH:()=>r,ProjectStatus:()=>i,WORKSPACE_CONFIG:()=>t});var s=e.i(13442),n=e.i(30331);let t={WORKSPACE_ROOT:(0,n.join)((0,s.homedir)(),"Documents","prime-workspace"),GIT_TIMEOUT:3e5,MAX_CONCURRENT_CLONES:Math.max(2,Math.min((0,s.cpus)().length,8)),MAX_RETRY_ATTEMPTS:3},r=(0,n.join)((0,s.homedir)(),".prime-projects.json");var 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}({})}},83886:function(e){var{g:t,__dirname:r,m:s,e:n}=e;s.exports=e.x("fs",()=>require("fs"))},87485:function(e){var{g:t,__dirname:r,m:s,e:n}=e;s.exports=e.x("child_process",()=>require("child_process"))},77159:e=>{"use strict";var{g:t,__dirname:r}=e;e.s({checkMultipleProjectsExist:()=>f,checkProjectExists:()=>d,checkProjectStatus:()=>p,cleanupIncompleteProject:()=>m,cloneRepository:()=>c,createWorkspaceDirectory:()=>a,isValidGitUrl:()=>u,sanitizeProjectName:()=>l});var s=e.i(87485),n=e.i(83886),i=e.i(30331),o=e.i(88941);async function a(e){try{return(0,n.existsSync)(e)||(0,n.mkdirSync)(e,{recursive:!0}),{success:!0}}catch(e){return{success:!1,error:`创建工作空间目录失败: ${e instanceof Error?e.message:String(e)}`}}}async function c(e){let{repoUrl:t,targetDir:r,timeout:n,onProgress:a,onError:c,onLog:u}=e,l=(0,i.basename)(t,".git");return new Promise(e=>{let p=Date.now(),d={projectName:l,status:o.ProjectStatus.CLONING,progress:0,message:"开始克隆项目...",startTime:p};a?.(0,"开始克隆项目...");let g=(0,i.join)(r,l),m=["clone","--progress","--verbose",t,g];u?.(l,"stdout",`[开始克隆] 执行命令: git ${m.join(" ")}
2
+ `),u?.(l,"stdout",`[目标目录] ${g}
3
+ `),u?.(l,"stdout",`[仓库地址] ${t}
4
+ `);let f=(0,s.spawn)("git",m,{cwd:r,stdio:["pipe","pipe","pipe"]}),x="",j=0;u?.(l,"stdout",`[进程启动] Git 进程 PID: ${f.pid}
5
+ `);let S=setTimeout(()=>{u?.(l,"stderr",`[超时警告] Git 进程运行超过 ${n/1e3}s,即将终止
6
+ `),f.kill("SIGTERM");let t={...d,status:o.ProjectStatus.FAILED,progress:j,message:"克隆操作超时",error:`克隆操作超时 (${n/1e3}s)`,endTime:Date.now()};u?.(l,"stderr",`[进程终止] 克隆操作超时
7
+ `),c?.(`${l}: 克隆操作超时`),e(t)},n);f.stdout?.on("data",e=>{let t=e.toString();u?.(l,"stdout",t),j=Math.min(j+10,80),a?.(j,"正在克隆代码...")}),f.stderr?.on("data",e=>{let t=e.toString();x+=t,t.includes("remote:")||t.includes("Receiving objects")||t.includes("Resolving deltas")||t.includes("Counting objects")||t.includes("Enumerating objects")||t.includes("Compressing objects")||t.includes("upload-pack")||t.includes("POST git-")||t.includes("正克隆到")||t.includes("Cloning into")?u?.(l,"progress",t):u?.(l,"stderr",t),t.includes("Receiving objects")||t.includes("Resolving deltas")?(j=Math.min(j+5,90),a?.(j,"正在接收对象...")):t.includes("Counting objects")?(j=Math.min(j+2,70),a?.(j,"正在计算对象...")):t.includes("Enumerating objects")&&(j=Math.min(j+2,50),a?.(j,"正在枚举对象..."))}),f.on("close",t=>{clearTimeout(S);let r=Date.now(),s=r-p;if(u?.(l,"stdout",`[进程结束] Git 进程退出,代码: ${t},耗时: ${Math.round(s/1e3)}s
8
+ `),0===t){u?.(l,"stdout",`[克隆成功] 项目已成功克隆到: ${g}
9
+ `);let t={...d,status:o.ProjectStatus.SUCCESS,progress:100,message:"克隆完成",endTime:r};a?.(100,"克隆完成"),e(t)}else{let s=function(e){let t=e.toLowerCase();return t.includes("authentication failed")||t.includes("access denied")?"身份验证失败,请检查仓库访问权限":t.includes("repository not found")||t.includes("not found")?"仓库不存在或无法访问":t.includes("network")||t.includes("connection")?"网络连接问题,请检查网络设置":t.includes("timeout")?"网络超时,请重试":t.includes("permission denied")?"权限被拒绝,请检查文件系统权限":t.includes("already exists")?"目标目录已存在":e.slice(0,200)+(e.length>200?"...":"")}(x);u?.(l,"stderr",`[克隆失败] 错误信息: ${s}
10
+ `),u?.(l,"stderr",`[完整错误输出]
11
+ ${x}
12
+ `);let n={...d,status:o.ProjectStatus.FAILED,progress:j,message:"克隆失败",error:s||`Git 进程退出,代码: ${t}`,endTime:r};c?.(`${l}: ${n.error}`),e(n)}}),f.on("error",t=>{clearTimeout(S),u?.(l,"stderr",`[进程错误] Git 进程启动失败: ${t.message}
13
+ `),u?.(l,"stderr",`[错误详情] ${t.stack||"No stack trace"}
14
+ `);let r={...d,status:o.ProjectStatus.FAILED,progress:j,message:"进程启动失败",error:`进程启动失败: ${t.message}`,endTime:Date.now()};c?.(`${l}: ${t.message}`),e(r)})})}function u(e){return/^(https?:\/\/|git@)[^\s]+\.git$/i.test(e)}function l(e){return e.replace(/[^a-zA-Z0-9\-_]/g,"")}async function p(e,t){try{let r=(0,i.join)(e,t);if(!(0,n.existsSync)(r))return{exists:!1,status:"not_exists",needsCleanup:!1};let s=(0,i.join)(r,".git");if(!(0,n.existsSync)(s))return{exists:!0,status:"incomplete",needsCleanup:!0};if(!await g(r))return console.log(`检测到不完整的Git仓库: ${r}`),{exists:!0,status:"incomplete",needsCleanup:!0};return{exists:!0,status:"complete",needsCleanup:!1}}catch(e){return console.error(`检查项目 ${t} 状态时出错:`,e),{exists:!1,status:"not_exists",needsCleanup:!1}}}async function d(e,t){return"complete"===(await p(e,t)).status}async function g(e){try{let t=(0,i.join)(e,".git");for(let e of["HEAD","config","refs"]){let r=(0,i.join)(t,e);if(!(0,n.existsSync)(r))return!1}let r=(await n.promises.readdir(e)).filter(e=>".git"!==e);if(0===r.length)return!1;let s=(0,i.join)(t,"HEAD"),o=await n.promises.readFile(s,"utf-8");if(!o.trim()||o.includes("unborn"))return!1;return!0}catch(e){return console.error("检查Git仓库完整性时出错:",e),!1}}async function m(e){try{console.log(`正在清理不完整的项目: ${e}`),await n.promises.rm(e,{recursive:!0,force:!0}),console.log(`清理完成: ${e}`)}catch(t){console.error(`清理项目失败 ${e}:`,t)}}async function f(e,t){let r={},s=t.map(async t=>{let s=await d(e,t);r[t]=s});return await Promise.all(s),r}},19294:function(e){var{g:t,__dirname:r,m:s,e:n}=e},45500:e=>{"use strict";var{g:t,__dirname:r}=e;e.s({checkProjectsOpenable:()=>p,getCursorSchemaUrl:()=>a,getEditorSchemaUrl:()=>l,getVSCodeSchemaUrl:()=>u,getWebStormSchemaUrl:()=>c,validateProjectPath:()=>o});var s=e.i(83886),n=e.i(30331),i=e.i(88941);function o(e){if(e.replace(/[^a-zA-Z0-9\-_]/g,"")!==e)return{valid:!1,error:"项目名称包含无效字符"};let t=(0,n.join)(i.WORKSPACE_CONFIG.WORKSPACE_ROOT,e);return t.startsWith(i.WORKSPACE_CONFIG.WORKSPACE_ROOT)?(0,s.existsSync)(t)?{valid:!0,path:t}:{valid:!1,error:"项目目录不存在"}:{valid:!1,error:"项目路径无效"}}function a(e){return`cursor://file${e}`}function c(e){return`webstorm://open?file=${e}`}function u(e){return`vscode://file${e}`}function l(e,t="cursor"){switch(t){case"webstorm":return c(e);case"vscode":return u(e);default:return a(e)}}function p(e){let t={};return e.forEach(e=>{let r=o(e);t[e]=r.valid}),t}},18089:e=>{"use strict";var{g:t,__dirname:r}=e;e.s({POST:()=>c});var s=e.i(88941),n=e.i(77159),i=e.i(45500),o=e.i(83886),a=e.i(30331);async function c(e){try{let{projectName:t,editor:r="cursor"}=await e.json();if(!t||"string"!=typeof t)return new Response(JSON.stringify({success:!1,error:"项目名称是必需的"}),{status:400,headers:{"Content-Type":"application/json"}});if((0,n.sanitizeProjectName)(t)!==t)return new Response(JSON.stringify({success:!1,error:"项目名称包含无效字符"}),{status:400,headers:{"Content-Type":"application/json"}});let c=s.WORKSPACE_CONFIG.WORKSPACE_ROOT,u=(0,a.join)(c,t);if(!(0,o.existsSync)(u))return new Response(JSON.stringify({success:!1,error:"项目目录不存在",projectName:t,projectPath:u}),{status:404,headers:{"Content-Type":"application/json"}});let l=(0,i.getEditorSchemaUrl)(u,r);return new Response(JSON.stringify({success:!0,projectPath:u,editorUrl:l,cursorUrl:"cursor"===r?l:`cursor://file${u}`}),{status:200,headers:{"Content-Type":"application/json"}})}catch(t){let e=t instanceof Error?t.message:String(t);return console.error("获取项目路径失败:",t),new Response(JSON.stringify({success:!1,error:`获取项目路径失败: ${e}`}),{status:500,headers:{"Content-Type":"application/json"}})}}},4550:e=>{"use strict";var{g:t,__dirname:r}=e;{e.s({patchFetch:()=>a,routeModule:()=>t,serverHooks:()=>u,workAsyncStorage:()=>r,workUnitAsyncStorage:()=>c});var s=e.i(45746),n=e.i(93828),i=e.i(18250),o=e.i(18089);let t=new s.AppRouteRouteModule({definition:{kind:n.RouteKind.APP_ROUTE,page:"/api/open-project/route",pathname:"/api/open-project",filename:"route",bundlePath:""},resolvedPagePath:"[project]/packages/server/src/app/api/open-project/route.ts",nextConfigOutput:"",userland:o}),{workAsyncStorage:r,workUnitAsyncStorage:c,serverHooks:u}=t;function a(){return(0,i.patchFetch)({workAsyncStorage:r,workUnitAsyncStorage:c})}}}};
15
+
16
+ //# sourceMappingURL=%5Broot-of-the-server%5D__de18efbd._.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["turbopack:///[project]/packages/server/src/lib/workspace-types.ts","turbopack:///[project]/packages/server/src/lib/git-operations.ts","turbopack:///[project]/packages/server/src/lib/editor-operations.ts","turbopack:///[project]/packages/server/src/app/api/open-project/route.ts","turbopack:///[project]/node_modules/.pnpm/next@15.3.4_react-dom@19.1.0_react@19.1.0__react@19.1.0/node_modules/next/dist/src/build/templates/app-route.ts"],"sourcesContent":["import { homedir, cpus } from 'os';\nimport { join } from 'path';\n\n/**\n * 工作空间配置常量\n */\nexport const WORKSPACE_CONFIG = {\n // 工作空间根目录路径\n WORKSPACE_ROOT: join(homedir(), 'Documents', 'prime-workspace'),\n\n // Git 操作超时时间 (毫秒)\n GIT_TIMEOUT: 300000, // 5分钟\n\n // 最大并发克隆数量(基于CPU核心数,最小2个,最大8个)\n MAX_CONCURRENT_CLONES: Math.max(2, Math.min(cpus().length, 8)),\n\n // 重试次数限制\n MAX_RETRY_ATTEMPTS: 3,\n} as const;\n\nexport const PROJECT_CONFIG_PATH = join(homedir(), '.prime-projects.json');\n\nexport interface ProjectConfig {\n repo: string;\n mockingIntercept?: boolean;\n mockOpen?: boolean;\n envs: {\n [envName: string]: {\n host: string;\n currentProxy: string;\n proxyEnv: {\n [key: string]: string;\n };\n envFileName: string;\n proxyKey: string;\n subApps?: string[];\n };\n };\n}\n\nexport interface ProjectsConfig {\n [projectName: string]: ProjectConfig;\n}\n\n/**\n * 项目状态枚举\n */\nexport enum ProjectStatus {\n PENDING = 'pending',\n EXISTING = 'existing',\n CLONING = 'cloning',\n SUCCESS = 'success',\n FAILED = 'failed',\n RETRYING = 'retrying',\n INCOMPLETE = 'incomplete', // 不完整的项目,需要清理\n}\n\n/**\n * 项目进度信息接口\n */\nexport interface ProjectProgress {\n projectName: string;\n status: ProjectStatus;\n progress: number; // 0-100\n message: string;\n error?: string;\n startTime?: number;\n endTime?: number;\n}\n\n/**\n * 初始化结果接口\n */\nexport interface InitializationResult {\n success: boolean;\n totalProjects: number;\n successCount: number;\n failedCount: number;\n failedProjects: string[];\n workspacePath: string;\n duration: number;\n}\n\n/**\n * Git 操作配置接口\n */\nexport interface GitOperationConfig {\n repoUrl: string;\n targetDir: string;\n timeout: number;\n onProgress?: (progress: number, message: string) => void;\n onError?: (error: string) => void;\n onLog?: (projectName: string, logType: 'stdout' | 'stderr' | 'progress', content: string) => void;\n} ","import { spawn, ChildProcess } from 'child_process';\nimport { existsSync, mkdirSync } from 'fs';\nimport { promises as fs } from 'fs';\nimport { join, basename } from 'path';\nimport {\n ProjectStatus,\n type GitOperationConfig,\n type ProjectProgress,\n} from './workspace-types';\n\n/**\n * 创建工作空间目录\n * @param workspacePath 工作空间路径\n * @returns 创建结果\n */\nexport async function createWorkspaceDirectory(workspacePath: string): Promise<{ success: boolean; error?: string }> {\n try {\n if (!existsSync(workspacePath)) {\n mkdirSync(workspacePath, { recursive: true });\n }\n return { success: true };\n } catch (error) {\n return { \n success: false, \n error: `创建工作空间目录失败: ${error instanceof Error ? error.message : String(error)}` \n };\n }\n}\n\n/**\n * 执行 Git 克隆操作\n * @param config Git 操作配置\n * @returns Promise<ProjectProgress>\n */\nexport async function cloneRepository(config: GitOperationConfig): Promise<ProjectProgress> {\n const { repoUrl, targetDir, timeout, onProgress, onError, onLog } = config;\n const projectName = basename(repoUrl, '.git');\n \n return new Promise<ProjectProgress>((resolve) => {\n const startTime = Date.now();\n \n // 更新开始状态\n const initialProgress: ProjectProgress = {\n projectName,\n status: ProjectStatus.CLONING,\n progress: 0,\n message: '开始克隆项目...',\n startTime,\n };\n onProgress?.(0, '开始克隆项目...');\n\n // 执行 git clone 命令\n const targetPath = join(targetDir, projectName);\n // 添加 --progress 参数来强制显示进度,--verbose 显示详细信息\n const gitArgs = ['clone', '--progress', '--verbose', repoUrl, targetPath];\n \n // 记录命令启动信息\n onLog?.(projectName, 'stdout', `[开始克隆] 执行命令: git ${gitArgs.join(' ')}\\n`);\n onLog?.(projectName, 'stdout', `[目标目录] ${targetPath}\\n`);\n onLog?.(projectName, 'stdout', `[仓库地址] ${repoUrl}\\n`);\n \n const gitProcess: ChildProcess = spawn('git', gitArgs, {\n cwd: targetDir,\n stdio: ['pipe', 'pipe', 'pipe'],\n });\n\n let errorOutput = '';\n let progressValue = 0;\n \n // 记录进程启动成功\n onLog?.(projectName, 'stdout', `[进程启动] Git 进程 PID: ${gitProcess.pid}\\n`);\n\n // 设置超时\n const timeoutId = setTimeout(() => {\n onLog?.(projectName, 'stderr', `[超时警告] Git 进程运行超过 ${timeout / 1000}s,即将终止\\n`);\n gitProcess.kill('SIGTERM');\n \n const errorResult: ProjectProgress = {\n ...initialProgress,\n status: ProjectStatus.FAILED,\n progress: progressValue,\n message: '克隆操作超时',\n error: `克隆操作超时 (${timeout / 1000}s)`,\n endTime: Date.now(),\n };\n onLog?.(projectName, 'stderr', `[进程终止] 克隆操作超时\\n`);\n onError?.(`${projectName}: 克隆操作超时`);\n resolve(errorResult);\n }, timeout);\n\n // 处理标准输出\n gitProcess.stdout?.on('data', (data: Buffer) => {\n const stdoutText = data.toString();\n \n // 实时发送日志\n onLog?.(projectName, 'stdout', stdoutText);\n \n // 模拟进度更新(Git 克隆没有内置进度,这里基于时间估算)\n progressValue = Math.min(progressValue + 10, 80);\n onProgress?.(progressValue, '正在克隆代码...');\n });\n\n // 处理错误输出\n gitProcess.stderr?.on('data', (data: Buffer) => {\n const stderrText = data.toString();\n errorOutput += stderrText;\n \n // 判断是进度信息还是错误信息\n const isProgressInfo = stderrText.includes('remote:') || \n stderrText.includes('Receiving objects') || \n stderrText.includes('Resolving deltas') ||\n stderrText.includes('Counting objects') ||\n stderrText.includes('Enumerating objects') ||\n stderrText.includes('Compressing objects') ||\n stderrText.includes('upload-pack') ||\n stderrText.includes('POST git-') ||\n stderrText.includes('正克隆到') ||\n stderrText.includes('Cloning into');\n \n // 根据内容类型发送不同的日志\n if (isProgressInfo) {\n onLog?.(projectName, 'progress', stderrText);\n } else {\n onLog?.(projectName, 'stderr', stderrText);\n }\n \n // Git 的进度信息通常在 stderr 中\n if (stderrText.includes('Receiving objects') || stderrText.includes('Resolving deltas')) {\n progressValue = Math.min(progressValue + 5, 90);\n onProgress?.(progressValue, '正在接收对象...');\n } else if (stderrText.includes('Counting objects')) {\n progressValue = Math.min(progressValue + 2, 70);\n onProgress?.(progressValue, '正在计算对象...');\n } else if (stderrText.includes('Enumerating objects')) {\n progressValue = Math.min(progressValue + 2, 50);\n onProgress?.(progressValue, '正在枚举对象...');\n }\n });\n\n // 处理进程结束\n gitProcess.on('close', (code: number | null) => {\n clearTimeout(timeoutId);\n const endTime = Date.now();\n const duration = endTime - startTime;\n \n onLog?.(projectName, 'stdout', `[进程结束] Git 进程退出,代码: ${code},耗时: ${Math.round(duration / 1000)}s\\n`);\n \n if (code === 0) {\n // 克隆成功\n onLog?.(projectName, 'stdout', `[克隆成功] 项目已成功克隆到: ${targetPath}\\n`);\n const successResult: ProjectProgress = {\n ...initialProgress,\n status: ProjectStatus.SUCCESS,\n progress: 100,\n message: '克隆完成',\n endTime,\n };\n onProgress?.(100, '克隆完成');\n resolve(successResult);\n } else {\n // 克隆失败\n const parsedError = parseGitError(errorOutput);\n onLog?.(projectName, 'stderr', `[克隆失败] 错误信息: ${parsedError}\\n`);\n onLog?.(projectName, 'stderr', `[完整错误输出]\\n${errorOutput}\\n`);\n \n const failureResult: ProjectProgress = {\n ...initialProgress,\n status: ProjectStatus.FAILED,\n progress: progressValue,\n message: '克隆失败',\n error: parsedError || `Git 进程退出,代码: ${code}`,\n endTime,\n };\n onError?.(`${projectName}: ${failureResult.error}`);\n resolve(failureResult);\n }\n });\n\n // 处理进程错误\n gitProcess.on('error', (error: Error) => {\n clearTimeout(timeoutId);\n onLog?.(projectName, 'stderr', `[进程错误] Git 进程启动失败: ${error.message}\\n`);\n onLog?.(projectName, 'stderr', `[错误详情] ${error.stack || 'No stack trace'}\\n`);\n \n const errorResult: ProjectProgress = {\n ...initialProgress,\n status: ProjectStatus.FAILED,\n progress: progressValue,\n message: '进程启动失败',\n error: `进程启动失败: ${error.message}`,\n endTime: Date.now(),\n };\n onError?.(`${projectName}: ${error.message}`);\n resolve(errorResult);\n });\n });\n}\n\n/**\n * 解析 Git 错误信息,提供用户友好的错误描述\n * @param errorOutput Git stderr 输出\n * @returns 用户友好的错误描述\n */\nfunction parseGitError(errorOutput: string): string {\n const lowerOutput = errorOutput.toLowerCase();\n \n if (lowerOutput.includes('authentication failed') || lowerOutput.includes('access denied')) {\n return '身份验证失败,请检查仓库访问权限';\n }\n \n if (lowerOutput.includes('repository not found') || lowerOutput.includes('not found')) {\n return '仓库不存在或无法访问';\n }\n \n if (lowerOutput.includes('network') || lowerOutput.includes('connection')) {\n return '网络连接问题,请检查网络设置';\n }\n \n if (lowerOutput.includes('timeout')) {\n return '网络超时,请重试';\n }\n \n if (lowerOutput.includes('permission denied')) {\n return '权限被拒绝,请检查文件系统权限';\n }\n \n if (lowerOutput.includes('already exists')) {\n return '目标目录已存在';\n }\n \n // 返回原始错误的前200个字符\n return errorOutput.slice(0, 200) + (errorOutput.length > 200 ? '...' : '');\n}\n\n/**\n * 验证 Git 仓库 URL 格式\n * @param url Git 仓库 URL\n * @returns 是否有效\n */\nexport function isValidGitUrl(url: string): boolean {\n const gitUrlPattern = /^(https?:\\/\\/|git@)[^\\s]+\\.git$/i;\n return gitUrlPattern.test(url);\n}\n\n/**\n * 清理项目名称,移除不安全字符\n * @param projectName 项目名称\n * @returns 清理后的项目名称\n */\nexport function sanitizeProjectName(projectName: string): string {\n return projectName.replace(/[^a-zA-Z0-9\\-_]/g, '');\n}\n\n/**\n * 项目检查结果类型\n */\nexport type ProjectCheckResult = {\n exists: boolean;\n status: 'not_exists' | 'complete' | 'incomplete';\n needsCleanup: boolean;\n};\n\n/**\n * 检查项目状态(详细版本)\n * @param workspacePath 工作空间路径\n * @param projectName 项目名称\n * @returns Promise<ProjectCheckResult> 详细的项目状态\n */\nexport async function checkProjectStatus(workspacePath: string, projectName: string): Promise<ProjectCheckResult> {\n try {\n const projectPath = join(workspacePath, projectName);\n \n // 检查项目目录是否存在\n if (!existsSync(projectPath)) {\n return {\n exists: false,\n status: 'not_exists',\n needsCleanup: false\n };\n }\n \n // 检查是否为 Git 仓库(存在 .git 目录)\n const gitPath = join(projectPath, '.git');\n if (!existsSync(gitPath)) {\n return {\n exists: true,\n status: 'incomplete',\n needsCleanup: true\n };\n }\n \n // 更严格的完整性检查\n const isComplete = await isGitRepositoryComplete(projectPath);\n if (!isComplete) {\n console.log(`检测到不完整的Git仓库: ${projectPath}`);\n return {\n exists: true,\n status: 'incomplete',\n needsCleanup: true\n };\n }\n \n return {\n exists: true,\n status: 'complete',\n needsCleanup: false\n };\n } catch (error) {\n console.error(`检查项目 ${projectName} 状态时出错:`, error);\n return {\n exists: false,\n status: 'not_exists',\n needsCleanup: false\n };\n }\n}\n\n/**\n * 检查项目是否已存在于工作空间中(兼容版本)\n * @param workspacePath 工作空间路径\n * @param projectName 项目名称\n * @returns Promise<boolean> 项目是否存在且为有效的 Git 仓库\n */\nexport async function checkProjectExists(workspacePath: string, projectName: string): Promise<boolean> {\n const result = await checkProjectStatus(workspacePath, projectName);\n return result.status === 'complete';\n}\n\n/**\n * 检查Git仓库是否完整\n * @param projectPath 项目路径\n * @returns Promise<boolean> 仓库是否完整\n */\nasync function isGitRepositoryComplete(projectPath: string): Promise<boolean> {\n try {\n const gitPath = join(projectPath, '.git');\n \n // 检查关键的Git文件是否存在\n const requiredFiles = ['HEAD', 'config', 'refs'];\n for (const file of requiredFiles) {\n const filePath = join(gitPath, file);\n if (!existsSync(filePath)) {\n return false;\n }\n }\n \n // 检查是否有实际的项目文件(不只是.git目录)\n const entries = await fs.readdir(projectPath);\n const nonGitFiles = entries.filter((entry: string) => entry !== '.git');\n \n // 如果只有.git目录,说明克隆未完成\n if (nonGitFiles.length === 0) {\n return false;\n }\n \n // 检查HEAD文件是否有效\n const headPath = join(gitPath, 'HEAD');\n const headContent = await fs.readFile(headPath, 'utf-8');\n if (!headContent.trim() || headContent.includes('unborn')) {\n return false;\n }\n \n return true;\n } catch (error) {\n console.error('检查Git仓库完整性时出错:', error);\n return false;\n }\n}\n\n/**\n * 清理不完整的项目目录\n * @param projectPath 项目路径\n */\nexport async function cleanupIncompleteProject(projectPath: string): Promise<void> {\n try {\n console.log(`正在清理不完整的项目: ${projectPath}`);\n await fs.rm(projectPath, { recursive: true, force: true });\n console.log(`清理完成: ${projectPath}`);\n } catch (error) {\n console.error(`清理项目失败 ${projectPath}:`, error);\n // 清理失败不抛出错误,避免阻塞后续流程\n }\n}\n\n/**\n * 批量检查多个项目的存在状态\n * @param workspacePath 工作空间路径\n * @param projectNames 项目名称列表\n * @returns Promise<Record<string, boolean>> 项目名称到存在状态的映射\n */\nexport async function checkMultipleProjectsExist(\n workspacePath: string, \n projectNames: string[]\n): Promise<Record<string, boolean>> {\n const results: Record<string, boolean> = {};\n \n // 并行检查所有项目\n const checks = projectNames.map(async (projectName) => {\n const exists = await checkProjectExists(workspacePath, projectName);\n results[projectName] = exists;\n });\n \n await Promise.all(checks);\n return results;\n} ","import { existsSync } from 'fs';\nimport { join } from 'path';\nimport { WORKSPACE_CONFIG } from './workspace-types';\n\n/**\n * 编辑器打开结果接口\n */\nexport interface EditorOpenResult {\n success: boolean;\n message: string;\n error?: string;\n}\n\n/**\n * 验证项目路径是否在工作空间内且存在\n * @param projectName 项目名称\n * @returns 验证结果\n */\nexport function validateProjectPath(projectName: string): { valid: boolean; path?: string; error?: string } {\n // 清理项目名称,防止路径遍历攻击\n const cleanProjectName = projectName.replace(/[^a-zA-Z0-9\\-_]/g, '');\n \n if (cleanProjectName !== projectName) {\n return {\n valid: false,\n error: '项目名称包含无效字符'\n };\n }\n\n const projectPath = join(WORKSPACE_CONFIG.WORKSPACE_ROOT, projectName);\n \n // 检查路径是否在工作空间内(防止路径遍历)\n if (!projectPath.startsWith(WORKSPACE_CONFIG.WORKSPACE_ROOT)) {\n return {\n valid: false,\n error: '项目路径无效'\n };\n }\n\n // 检查项目目录是否存在\n if (!existsSync(projectPath)) {\n return {\n valid: false,\n error: '项目目录不存在'\n };\n }\n\n return {\n valid: true,\n path: projectPath\n };\n}\n\n/**\n * 编辑器类型\n */\nexport type EditorType = 'cursor' | 'webstorm' | 'vscode';\n\n/**\n * 生成 Cursor schema URL\n * @param projectPath 项目的绝对路径\n * @returns cursor://file URL\n */\nexport function getCursorSchemaUrl(projectPath: string): string {\n // 格式: cursor://file/absolute/path/to/folder\n return `cursor://file${projectPath}`;\n}\n\n/**\n * 生成 WebStorm schema URL\n * @param projectPath 项目的绝对路径\n * @returns webstorm://open URL\n */\nexport function getWebStormSchemaUrl(projectPath: string): string {\n // 格式: webstorm://open?file=/absolute/path/to/folder\n return `webstorm://open?file=${projectPath}`;\n}\n\n/**\n * 生成 VSCode schema URL\n * @param projectPath 项目的绝对路径\n * @returns vscode://file URL\n */\nexport function getVSCodeSchemaUrl(projectPath: string): string {\n // 格式: vscode://file/absolute/path/to/folder\n return `vscode://file${projectPath}`;\n}\n\n/**\n * 根据编辑器类型生成对应的 schema URL\n * @param projectPath 项目的绝对路径\n * @param editor 编辑器类型\n * @returns 对应编辑器的 schema URL\n */\nexport function getEditorSchemaUrl(projectPath: string, editor: EditorType = 'cursor'): string {\n switch (editor) {\n case 'webstorm':\n return getWebStormSchemaUrl(projectPath);\n case 'vscode':\n return getVSCodeSchemaUrl(projectPath);\n case 'cursor':\n default:\n return getCursorSchemaUrl(projectPath);\n }\n}\n\n/**\n * 批量检查多个项目是否可以打开\n * @param projectNames 项目名称列表\n * @returns Record<string, boolean> 项目名称到可打开状态的映射\n */\nexport function checkProjectsOpenable(projectNames: string[]): Record<string, boolean> {\n const results: Record<string, boolean> = {};\n\n // 检查每个项目的路径\n projectNames.forEach(projectName => {\n const validation = validateProjectPath(projectName);\n results[projectName] = validation.valid;\n });\n\n return results;\n}\n","import { NextRequest } from 'next/server';\nimport { WORKSPACE_CONFIG } from '@/lib/workspace-types';\nimport { sanitizeProjectName } from '@/lib/git-operations';\nimport { getEditorSchemaUrl, EditorType } from '@/lib/editor-operations';\nimport { existsSync } from 'fs';\nimport { join } from 'path';\n\n/**\n * 获取项目路径 API 端点\n * 返回项目路径,由前端使用 editor schema 协议打开(支持 cursor 和 webstorm)\n */\nexport async function POST(request: NextRequest) {\n try {\n const body = await request.json();\n const { projectName, editor = 'cursor' } = body as { projectName: string; editor?: EditorType };\n\n // 验证项目名称\n if (!projectName || typeof projectName !== 'string') {\n return new Response(\n JSON.stringify({ \n success: false, \n error: '项目名称是必需的' \n }),\n { \n status: 400,\n headers: { 'Content-Type': 'application/json' }\n }\n );\n }\n\n // 清理项目名称,防止路径遍历攻击\n const cleanProjectName = sanitizeProjectName(projectName);\n if (cleanProjectName !== projectName) {\n return new Response(\n JSON.stringify({ \n success: false, \n error: '项目名称包含无效字符' \n }),\n { \n status: 400,\n headers: { 'Content-Type': 'application/json' }\n }\n );\n }\n\n // 构造项目路径\n const workspacePath = WORKSPACE_CONFIG.WORKSPACE_ROOT;\n const projectPath = join(workspacePath, projectName);\n\n // 验证项目目录是否存在\n if (!existsSync(projectPath)) {\n return new Response(\n JSON.stringify({ \n success: false, \n error: '项目目录不存在',\n projectName,\n projectPath\n }),\n { \n status: 404,\n headers: { 'Content-Type': 'application/json' }\n }\n );\n }\n\n // 返回项目路径,由前端使用 editor schema 协议打开\n const editorUrl = getEditorSchemaUrl(projectPath, editor);\n \n return new Response(\n JSON.stringify({ \n success: true, \n projectPath,\n editorUrl,\n // 保持向后兼容\n cursorUrl: editor === 'cursor' ? editorUrl : `cursor://file${projectPath}`,\n }),\n { \n status: 200,\n headers: { 'Content-Type': 'application/json' }\n }\n );\n\n } catch (error) {\n const errorMessage = error instanceof Error ? error.message : String(error);\n console.error(\"获取项目路径失败:\", error);\n \n return new Response(\n JSON.stringify({ \n success: false, \n error: `获取项目路径失败: ${errorMessage}` \n }),\n { \n status: 500,\n headers: { 'Content-Type': 'application/json' }\n }\n );\n }\n}","import {\n AppRouteRouteModule,\n type AppRouteRouteModuleOptions,\n} from '../../server/route-modules/app-route/module.compiled'\nimport { RouteKind } from '../../server/route-kind'\nimport { patchFetch as _patchFetch } from '../../server/lib/patch-fetch'\n\nimport * as userland from 'VAR_USERLAND'\n\n// These are injected by the loader afterwards. This is injected as a variable\n// instead of a replacement because this could also be `undefined` instead of\n// an empty string.\ndeclare const nextConfigOutput: AppRouteRouteModuleOptions['nextConfigOutput']\n\n// We inject the nextConfigOutput here so that we can use them in the route\n// module.\n// INJECT:nextConfigOutput\n\nconst routeModule = new AppRouteRouteModule({\n definition: {\n kind: RouteKind.APP_ROUTE,\n page: 'VAR_DEFINITION_PAGE',\n pathname: 'VAR_DEFINITION_PATHNAME',\n filename: 'VAR_DEFINITION_FILENAME',\n bundlePath: 'VAR_DEFINITION_BUNDLE_PATH',\n },\n resolvedPagePath: 'VAR_RESOLVED_PAGE_PATH',\n nextConfigOutput,\n userland,\n})\n\n// Pull out the exports that we need to expose from the module. This should\n// be eliminated when we've moved the other routes to the new format. These\n// are used to hook into the route.\nconst { workAsyncStorage, workUnitAsyncStorage, serverHooks } = routeModule\n\nfunction patchFetch() {\n return _patchFetch({\n workAsyncStorage,\n workUnitAsyncStorage,\n })\n}\n\nexport {\n routeModule,\n workAsyncStorage,\n workUnitAsyncStorage,\n serverHooks,\n patchFetch,\n}\n"],"names":["AppRouteRouteModule","RouteKind","patchFetch","_patchFetch","userland","routeModule","definition","kind","APP_ROUTE","page","pathname","filename","bundlePath","resolvedPagePath","nextConfigOutput","workAsyncStorage","workUnitAsyncStorage","serverHooks"],"mappings":"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","ignoreList":[4]}
@@ -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"))},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 = {
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}({})}},30331:function(e){var{g:t,__dirname:s,m:r,e:o}=e;r.exports=e.x("path",()=>require("path"))},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"))},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"))},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"))},13442:function(e){var{g:t,__dirname:s,m:r,e:o}=e;r.exports=e.x("os",()=>require("os"))},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%5D__2ba93285._.js.map
18
+ //# sourceMappingURL=%5Broot-of-the-server%5D__e0b7050d._.js.map