prime-dev-cli 1.0.18 → 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 (247) 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 +8 -8
  4. package/dist/server/.next/app-path-routes-manifest.json +4 -0
  5. package/dist/server/.next/build-manifest.json +6 -6
  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 +1 -1
  15. package/dist/server/.next/server/app/_not-found/page.js +1 -1
  16. package/dist/server/.next/server/app/_not-found/page.js.nft.json +1 -1
  17. package/dist/server/.next/server/app/_not-found/page_client-reference-manifest.js +1 -1
  18. package/dist/server/.next/server/app/_not-found.html +1 -1
  19. package/dist/server/.next/server/app/_not-found.rsc +2 -2
  20. package/dist/server/.next/server/app/api/admin-status/route/app-build-manifest.json +10 -0
  21. package/dist/server/.next/server/app/api/admin-status/route/app-paths-manifest.json +3 -0
  22. package/dist/server/.next/server/app/api/admin-status/route/build-manifest.json +16 -0
  23. package/dist/server/.next/server/app/api/admin-status/route/next-font-manifest.json +6 -0
  24. package/dist/server/.next/server/app/api/admin-status/route/react-loadable-manifest.json +1 -0
  25. package/dist/server/.next/server/app/api/admin-status/route/server-reference-manifest.json +4 -0
  26. package/dist/server/.next/server/app/api/admin-status/route.js +8 -0
  27. package/dist/server/.next/server/app/api/admin-status/route.js.map +5 -0
  28. package/dist/server/.next/server/app/api/admin-status/route.js.nft.json +1 -0
  29. package/dist/server/.next/server/app/api/admin-status/route_client-reference-manifest.js +2 -0
  30. package/dist/server/.next/server/app/api/all-projects-envs/route.js +1 -1
  31. package/dist/server/.next/server/app/api/all-projects-envs/route.js.nft.json +1 -1
  32. package/dist/server/.next/server/app/api/check-mock-intercept/route.js +1 -1
  33. package/dist/server/.next/server/app/api/check-mock-intercept/route.js.nft.json +1 -1
  34. package/dist/server/.next/server/app/api/check-workspace/route.js +1 -1
  35. package/dist/server/.next/server/app/api/check-workspace/route.js.nft.json +1 -1
  36. package/dist/server/.next/server/app/api/cleanup-mock/route.js +1 -1
  37. package/dist/server/.next/server/app/api/cleanup-mock/route.js.nft.json +1 -1
  38. package/dist/server/.next/server/app/api/cleanup-project/route.js +1 -1
  39. package/dist/server/.next/server/app/api/cleanup-project/route.js.nft.json +1 -1
  40. package/dist/server/.next/server/app/api/current-branch/route.js +1 -1
  41. package/dist/server/.next/server/app/api/current-branch/route.js.nft.json +1 -1
  42. package/dist/server/.next/server/app/api/delete-mock-api/route.js +1 -1
  43. package/dist/server/.next/server/app/api/delete-mock-api/route.js.nft.json +1 -1
  44. package/dist/server/.next/server/app/api/get-mock-data/route.js +1 -1
  45. package/dist/server/.next/server/app/api/get-mock-data/route.js.nft.json +1 -1
  46. package/dist/server/.next/server/app/api/initialize-workspace/route.js +1 -1
  47. package/dist/server/.next/server/app/api/initialize-workspace/route.js.nft.json +1 -1
  48. package/dist/server/.next/server/app/api/memory-status/route.js +1 -1
  49. package/dist/server/.next/server/app/api/memory-status/route.js.nft.json +1 -1
  50. package/dist/server/.next/server/app/api/microapp-proxy-change-stream/route.js +1 -1
  51. package/dist/server/.next/server/app/api/microapp-proxy-change-stream/route.js.nft.json +1 -1
  52. package/dist/server/.next/server/app/api/microapp-proxy-config/route.js +1 -1
  53. package/dist/server/.next/server/app/api/microapp-proxy-config/route.js.nft.json +1 -1
  54. package/dist/server/.next/server/app/api/mock-file/route.js +1 -1
  55. package/dist/server/.next/server/app/api/mock-file/route.js.nft.json +1 -1
  56. package/dist/server/.next/server/app/api/mock-file-content/route.js +1 -1
  57. package/dist/server/.next/server/app/api/mock-file-content/route.js.nft.json +1 -1
  58. package/dist/server/.next/server/app/api/mock-open-status/route.js +1 -1
  59. package/dist/server/.next/server/app/api/mock-open-status/route.js.nft.json +1 -1
  60. package/dist/server/.next/server/app/api/mock-setting/route.js +1 -1
  61. package/dist/server/.next/server/app/api/mock-setting/route.js.nft.json +1 -1
  62. package/dist/server/.next/server/app/api/open-all-mock/route.js +1 -1
  63. package/dist/server/.next/server/app/api/open-all-mock/route.js.nft.json +1 -1
  64. package/dist/server/.next/server/app/api/open-project/route.js +1 -1
  65. package/dist/server/.next/server/app/api/open-project/route.js.nft.json +1 -1
  66. package/dist/server/.next/server/app/api/process/logs/route.js +1 -1
  67. package/dist/server/.next/server/app/api/process/logs/route.js.nft.json +1 -1
  68. package/dist/server/.next/server/app/api/process/logs/stream/route.js +1 -1
  69. package/dist/server/.next/server/app/api/process/logs/stream/route.js.nft.json +1 -1
  70. package/dist/server/.next/server/app/api/process/start/route.js +1 -1
  71. package/dist/server/.next/server/app/api/process/start/route.js.nft.json +1 -1
  72. package/dist/server/.next/server/app/api/process/status/route.js +1 -1
  73. package/dist/server/.next/server/app/api/process/status/route.js.nft.json +1 -1
  74. package/dist/server/.next/server/app/api/project-config/route.js +1 -1
  75. package/dist/server/.next/server/app/api/project-config/route.js.nft.json +1 -1
  76. package/dist/server/.next/server/app/api/retry-project/route.js +1 -1
  77. package/dist/server/.next/server/app/api/retry-project/route.js.nft.json +1 -1
  78. package/dist/server/.next/server/app/api/uat-git-flow/abort/route/app-build-manifest.json +10 -0
  79. package/dist/server/.next/server/app/api/uat-git-flow/abort/route/app-paths-manifest.json +3 -0
  80. package/dist/server/.next/server/app/api/uat-git-flow/abort/route/build-manifest.json +16 -0
  81. package/dist/server/.next/server/app/api/uat-git-flow/abort/route/next-font-manifest.json +6 -0
  82. package/dist/server/.next/server/app/api/uat-git-flow/abort/route/react-loadable-manifest.json +1 -0
  83. package/dist/server/.next/server/app/api/uat-git-flow/abort/route/server-reference-manifest.json +4 -0
  84. package/dist/server/.next/server/app/api/uat-git-flow/abort/route.js +8 -0
  85. package/dist/server/.next/server/app/api/uat-git-flow/abort/route.js.map +5 -0
  86. package/dist/server/.next/server/app/api/uat-git-flow/abort/route.js.nft.json +1 -0
  87. package/dist/server/.next/server/app/api/uat-git-flow/abort/route_client-reference-manifest.js +2 -0
  88. package/dist/server/.next/server/app/api/uat-git-flow/route/app-build-manifest.json +10 -0
  89. package/dist/server/.next/server/app/api/uat-git-flow/route/app-paths-manifest.json +3 -0
  90. package/dist/server/.next/server/app/api/uat-git-flow/route/build-manifest.json +16 -0
  91. package/dist/server/.next/server/app/api/uat-git-flow/route/next-font-manifest.json +6 -0
  92. package/dist/server/.next/server/app/api/uat-git-flow/route/react-loadable-manifest.json +1 -0
  93. package/dist/server/.next/server/app/api/uat-git-flow/route/server-reference-manifest.json +4 -0
  94. package/dist/server/.next/server/app/api/uat-git-flow/route.js +9 -0
  95. package/dist/server/.next/server/app/api/uat-git-flow/route.js.map +5 -0
  96. package/dist/server/.next/server/app/api/uat-git-flow/route.js.nft.json +1 -0
  97. package/dist/server/.next/server/app/api/uat-git-flow/route_client-reference-manifest.js +2 -0
  98. package/dist/server/.next/server/app/api/uat-git-flow/step/route/app-build-manifest.json +10 -0
  99. package/dist/server/.next/server/app/api/uat-git-flow/step/route/app-paths-manifest.json +3 -0
  100. package/dist/server/.next/server/app/api/uat-git-flow/step/route/build-manifest.json +16 -0
  101. package/dist/server/.next/server/app/api/uat-git-flow/step/route/next-font-manifest.json +6 -0
  102. package/dist/server/.next/server/app/api/uat-git-flow/step/route/react-loadable-manifest.json +1 -0
  103. package/dist/server/.next/server/app/api/uat-git-flow/step/route/server-reference-manifest.json +4 -0
  104. package/dist/server/.next/server/app/api/uat-git-flow/step/route.js +9 -0
  105. package/dist/server/.next/server/app/api/uat-git-flow/step/route.js.map +5 -0
  106. package/dist/server/.next/server/app/api/uat-git-flow/step/route.js.nft.json +1 -0
  107. package/dist/server/.next/server/app/api/uat-git-flow/step/route_client-reference-manifest.js +2 -0
  108. package/dist/server/.next/server/app/api/workspace/create/route.js +1 -1
  109. package/dist/server/.next/server/app/api/workspace/create/route.js.nft.json +1 -1
  110. package/dist/server/.next/server/app/configuration/page/app-build-manifest.json +3 -3
  111. package/dist/server/.next/server/app/configuration/page.js +1 -1
  112. package/dist/server/.next/server/app/configuration/page.js.nft.json +1 -1
  113. package/dist/server/.next/server/app/configuration/page_client-reference-manifest.js +1 -1
  114. package/dist/server/.next/server/app/configuration.html +1 -1
  115. package/dist/server/.next/server/app/configuration.rsc +3 -3
  116. package/dist/server/.next/server/app/index.html +1 -1
  117. package/dist/server/.next/server/app/index.rsc +2 -2
  118. package/dist/server/.next/server/app/initialization/page/app-build-manifest.json +3 -3
  119. package/dist/server/.next/server/app/initialization/page.js +1 -1
  120. package/dist/server/.next/server/app/initialization/page.js.nft.json +1 -1
  121. package/dist/server/.next/server/app/initialization/page_client-reference-manifest.js +1 -1
  122. package/dist/server/.next/server/app/initialization.html +1 -1
  123. package/dist/server/.next/server/app/initialization.rsc +3 -3
  124. package/dist/server/.next/server/app/page/app-build-manifest.json +1 -1
  125. package/dist/server/.next/server/app/page.js +1 -1
  126. package/dist/server/.next/server/app/page.js.nft.json +1 -1
  127. package/dist/server/.next/server/app/page_client-reference-manifest.js +1 -1
  128. package/dist/server/.next/server/app-paths-manifest.json +4 -0
  129. package/dist/server/.next/server/chunks/{[root-of-the-server]__8fcbb2f0._.js → [root-of-the-server]__0879b2d6._.js} +2 -2
  130. package/dist/server/.next/server/chunks/[root-of-the-server]__0d56f35b._.js +3 -0
  131. package/dist/server/.next/server/chunks/[root-of-the-server]__0d56f35b._.js.map +1 -0
  132. package/dist/server/.next/server/chunks/{[root-of-the-server]__771e8133._.js → [root-of-the-server]__0e8a08fc._.js} +2 -2
  133. package/dist/server/.next/server/chunks/{[root-of-the-server]__21616bf9._.js → [root-of-the-server]__1e792460._.js} +2 -2
  134. package/dist/server/.next/server/chunks/{[root-of-the-server]__03c2b225._.js → [root-of-the-server]__2a29597f._.js} +2 -2
  135. package/dist/server/.next/server/chunks/{[root-of-the-server]__5348b4aa._.js → [root-of-the-server]__2a78acef._.js} +2 -2
  136. package/dist/server/.next/server/chunks/{[root-of-the-server]__5100a0c5._.js → [root-of-the-server]__2f8b52da._.js} +2 -2
  137. package/dist/server/.next/server/chunks/{[root-of-the-server]__3dfc0dc4._.js → [root-of-the-server]__2ffbf0d3._.js} +2 -2
  138. package/dist/server/.next/server/chunks/{[root-of-the-server]__899d82eb._.js → [root-of-the-server]__452b5f9c._.js} +2 -2
  139. package/dist/server/.next/server/chunks/[root-of-the-server]__4ab3dd83._.js +16 -0
  140. package/dist/server/.next/server/chunks/[root-of-the-server]__4ab3dd83._.js.map +1 -0
  141. package/dist/server/.next/server/chunks/{[root-of-the-server]__2fcc7175._.js → [root-of-the-server]__4b595942._.js} +2 -2
  142. package/dist/server/.next/server/chunks/{[root-of-the-server]__973c48a6._.js → [root-of-the-server]__4ec3205b._.js} +2 -2
  143. package/dist/server/.next/server/chunks/{[root-of-the-server]__072f5c45._.js → [root-of-the-server]__4fd52ac1._.js} +2 -2
  144. package/dist/server/.next/server/chunks/{[root-of-the-server]__6e5dc117._.js → [root-of-the-server]__5c9f62f9._.js} +2 -2
  145. package/dist/server/.next/server/chunks/[root-of-the-server]__6cbd50e9._.js +16 -0
  146. package/dist/server/.next/server/chunks/[root-of-the-server]__6cbd50e9._.js.map +1 -0
  147. package/dist/server/.next/server/chunks/[root-of-the-server]__703c317f._.js +3 -0
  148. package/dist/server/.next/server/chunks/[root-of-the-server]__703c317f._.js.map +1 -0
  149. package/dist/server/.next/server/chunks/{[root-of-the-server]__7500acb0._.js → [root-of-the-server]__8637b7f1._.js} +2 -2
  150. package/dist/server/.next/server/chunks/[root-of-the-server]__98088bea._.js +3 -0
  151. package/dist/server/.next/server/chunks/[root-of-the-server]__98088bea._.js.map +1 -0
  152. package/dist/server/.next/server/chunks/{[root-of-the-server]__94e10604._.js → [root-of-the-server]__a6fbefc6._.js} +2 -2
  153. package/dist/server/.next/server/chunks/{[root-of-the-server]__31a13318._.js → [root-of-the-server]__a74239fc._.js} +2 -2
  154. package/dist/server/.next/server/chunks/{[root-of-the-server]__388e6150._.js → [root-of-the-server]__aaa3fe74._.js} +2 -2
  155. package/dist/server/.next/server/chunks/{[root-of-the-server]__7fc974c9._.js → [root-of-the-server]__b176e8df._.js} +2 -2
  156. package/dist/server/.next/server/chunks/{[root-of-the-server]__a292866b._.js → [root-of-the-server]__be14bdb6._.js} +2 -2
  157. package/dist/server/.next/server/chunks/{[root-of-the-server]__f815ea40._.js → [root-of-the-server]__c18498ef._.js} +2 -2
  158. package/dist/server/.next/server/chunks/{[root-of-the-server]__c8b26634._.js → [root-of-the-server]__c9627539._.js} +2 -2
  159. package/dist/server/.next/server/chunks/{[root-of-the-server]__5355b75a._.js → [root-of-the-server]__dda45cac._.js} +2 -2
  160. package/dist/server/.next/server/chunks/{[root-of-the-server]__d0112f7b._.js → [root-of-the-server]__de18efbd._.js} +3 -3
  161. package/dist/server/.next/server/chunks/{[root-of-the-server]__d0112f7b._.js.map → [root-of-the-server]__de18efbd._.js.map} +1 -1
  162. package/dist/server/.next/server/chunks/{[root-of-the-server]__2ba93285._.js → [root-of-the-server]__e0b7050d._.js} +2 -2
  163. package/dist/server/.next/server/chunks/{[root-of-the-server]__419d3b16._.js → [root-of-the-server]__ec681197._.js} +2 -2
  164. package/dist/server/.next/server/chunks/_24087f66._.js +3 -0
  165. package/dist/server/.next/server/chunks/_24087f66._.js.map +1 -0
  166. package/dist/server/.next/server/chunks/_61c263b3._.js +3 -0
  167. package/dist/server/.next/server/chunks/_61c263b3._.js.map +1 -0
  168. package/dist/server/.next/server/chunks/ssr/[root-of-the-server]__2e9964e3._.js +3 -0
  169. package/dist/server/.next/server/chunks/ssr/{[root-of-the-server]__63c188bd._.js → [root-of-the-server]__b8a5c1ab._.js} +2 -2
  170. package/dist/server/.next/server/chunks/ssr/_5579d68f._.js +57 -0
  171. package/dist/server/.next/server/chunks/ssr/_5579d68f._.js.map +1 -0
  172. package/dist/server/.next/server/chunks/ssr/{_a1cb0beb._.js → _a1ab1c09._.js} +6 -2
  173. package/dist/server/.next/server/chunks/ssr/_a1ab1c09._.js.map +1 -0
  174. package/dist/server/.next/server/chunks/ssr/_ee0c9da0._.js +8 -0
  175. package/dist/server/.next/server/chunks/ssr/_ee0c9da0._.js.map +1 -0
  176. package/dist/server/.next/server/chunks/ssr/packages_server_src_7cef6dbd._.js +1 -1
  177. package/dist/server/.next/server/chunks/ssr/packages_server_src_7cef6dbd._.js.map +1 -1
  178. package/dist/server/.next/server/middleware-build-manifest.js +4 -4
  179. package/dist/server/.next/server/pages/404.html +1 -1
  180. package/dist/server/.next/server/pages/500.html +1 -1
  181. package/dist/server/.next/server/pages/_app/build-manifest.json +2 -2
  182. package/dist/server/.next/server/pages/_document.js +1 -1
  183. package/dist/server/.next/server/pages/_document.js.nft.json +1 -1
  184. package/dist/server/.next/server/pages/_error/build-manifest.json +2 -2
  185. package/dist/server/.next/server/pages/_error.js +1 -1
  186. package/dist/server/.next/server/pages/_error.js.nft.json +1 -1
  187. package/dist/server/.next/server/server-reference-manifest.js +1 -1
  188. package/dist/server/.next/server/server-reference-manifest.json +1 -1
  189. package/dist/server/.next/static/chunks/{d65b8ba84ba3d819.js → 1091ba2f3c451a47.js} +1 -1
  190. package/dist/server/.next/static/chunks/{294d677a4838a994.js → 1154a499e8e3867b.js} +1 -1
  191. package/dist/server/.next/static/chunks/{f9ef1d12f3c1646a.js → 1aa036ed62a506c8.js} +2 -2
  192. package/dist/server/.next/static/chunks/205cbae70a6c50e1.js.map +1 -0
  193. package/dist/server/.next/static/chunks/{479d60165927b286.js.map → 2602bf706e977560.js.map} +1 -1
  194. package/dist/server/.next/static/chunks/2d2322acba49236a.js +57 -0
  195. package/dist/server/.next/static/chunks/{dcfeeb80bf779e48.js → 43c514797c454939.js} +6 -2
  196. package/dist/server/.next/static/chunks/511924c894f8e3de.css.map +1 -0
  197. package/dist/server/.next/static/chunks/861aac2fba8d4e28.css +3 -0
  198. package/dist/server/.next/static/chunks/888146b3e75fe817.js.map +1 -0
  199. package/dist/server/.next/static/chunks/9148331cad3a934e.js +7 -0
  200. package/dist/server/.next/static/chunks/99154153690ad580.js.map +1 -0
  201. package/dist/server/.next/static/chunks/9bc1bbb3fe6e5eb3.js +3 -0
  202. package/dist/server/.next/static/chunks/e70508cc9f59709d.js.map +1 -0
  203. package/dist/server/.next/static/chunks/pages/_app.js +2 -2
  204. package/dist/server/.next/static/chunks/pages/_error.js +2 -2
  205. package/dist/server/.next/trace +1 -1
  206. package/package.json +1 -1
  207. package/dist/server/.next/server/chunks/[root-of-the-server]__629e6d6a._.js +0 -3
  208. package/dist/server/.next/server/chunks/[root-of-the-server]__629e6d6a._.js.map +0 -1
  209. package/dist/server/.next/server/chunks/ssr/[root-of-the-server]__e3a2aebd._.js +0 -3
  210. package/dist/server/.next/server/chunks/ssr/_a1cb0beb._.js.map +0 -1
  211. package/dist/server/.next/server/chunks/ssr/_bee8e6b2._.js +0 -61
  212. package/dist/server/.next/server/chunks/ssr/_bee8e6b2._.js.map +0 -1
  213. package/dist/server/.next/static/chunks/1e69de6d92e0d593.js.map +0 -1
  214. package/dist/server/.next/static/chunks/249ab5825a2160c6.js.map +0 -1
  215. package/dist/server/.next/static/chunks/37783149158d61fd.css +0 -3
  216. package/dist/server/.next/static/chunks/851593de9d497459.css.map +0 -1
  217. package/dist/server/.next/static/chunks/a4de3104c17624f9.js.map +0 -1
  218. package/dist/server/.next/static/chunks/bb95e2f817926795.js +0 -3
  219. package/dist/server/.next/static/chunks/f90a10be5908d5fa.js +0 -61
  220. /package/dist/server/.next/server/chunks/{[root-of-the-server]__8fcbb2f0._.js.map → [root-of-the-server]__0879b2d6._.js.map} +0 -0
  221. /package/dist/server/.next/server/chunks/{[root-of-the-server]__771e8133._.js.map → [root-of-the-server]__0e8a08fc._.js.map} +0 -0
  222. /package/dist/server/.next/server/chunks/{[root-of-the-server]__21616bf9._.js.map → [root-of-the-server]__1e792460._.js.map} +0 -0
  223. /package/dist/server/.next/server/chunks/{[root-of-the-server]__03c2b225._.js.map → [root-of-the-server]__2a29597f._.js.map} +0 -0
  224. /package/dist/server/.next/server/chunks/{[root-of-the-server]__5348b4aa._.js.map → [root-of-the-server]__2a78acef._.js.map} +0 -0
  225. /package/dist/server/.next/server/chunks/{[root-of-the-server]__5100a0c5._.js.map → [root-of-the-server]__2f8b52da._.js.map} +0 -0
  226. /package/dist/server/.next/server/chunks/{[root-of-the-server]__3dfc0dc4._.js.map → [root-of-the-server]__2ffbf0d3._.js.map} +0 -0
  227. /package/dist/server/.next/server/chunks/{[root-of-the-server]__899d82eb._.js.map → [root-of-the-server]__452b5f9c._.js.map} +0 -0
  228. /package/dist/server/.next/server/chunks/{[root-of-the-server]__2fcc7175._.js.map → [root-of-the-server]__4b595942._.js.map} +0 -0
  229. /package/dist/server/.next/server/chunks/{[root-of-the-server]__973c48a6._.js.map → [root-of-the-server]__4ec3205b._.js.map} +0 -0
  230. /package/dist/server/.next/server/chunks/{[root-of-the-server]__072f5c45._.js.map → [root-of-the-server]__4fd52ac1._.js.map} +0 -0
  231. /package/dist/server/.next/server/chunks/{[root-of-the-server]__6e5dc117._.js.map → [root-of-the-server]__5c9f62f9._.js.map} +0 -0
  232. /package/dist/server/.next/server/chunks/{[root-of-the-server]__7500acb0._.js.map → [root-of-the-server]__8637b7f1._.js.map} +0 -0
  233. /package/dist/server/.next/server/chunks/{[root-of-the-server]__94e10604._.js.map → [root-of-the-server]__a6fbefc6._.js.map} +0 -0
  234. /package/dist/server/.next/server/chunks/{[root-of-the-server]__31a13318._.js.map → [root-of-the-server]__a74239fc._.js.map} +0 -0
  235. /package/dist/server/.next/server/chunks/{[root-of-the-server]__388e6150._.js.map → [root-of-the-server]__aaa3fe74._.js.map} +0 -0
  236. /package/dist/server/.next/server/chunks/{[root-of-the-server]__7fc974c9._.js.map → [root-of-the-server]__b176e8df._.js.map} +0 -0
  237. /package/dist/server/.next/server/chunks/{[root-of-the-server]__a292866b._.js.map → [root-of-the-server]__be14bdb6._.js.map} +0 -0
  238. /package/dist/server/.next/server/chunks/{[root-of-the-server]__f815ea40._.js.map → [root-of-the-server]__c18498ef._.js.map} +0 -0
  239. /package/dist/server/.next/server/chunks/{[root-of-the-server]__c8b26634._.js.map → [root-of-the-server]__c9627539._.js.map} +0 -0
  240. /package/dist/server/.next/server/chunks/{[root-of-the-server]__5355b75a._.js.map → [root-of-the-server]__dda45cac._.js.map} +0 -0
  241. /package/dist/server/.next/server/chunks/{[root-of-the-server]__2ba93285._.js.map → [root-of-the-server]__e0b7050d._.js.map} +0 -0
  242. /package/dist/server/.next/server/chunks/{[root-of-the-server]__419d3b16._.js.map → [root-of-the-server]__ec681197._.js.map} +0 -0
  243. /package/dist/server/.next/server/chunks/ssr/{[root-of-the-server]__e3a2aebd._.js.map → [root-of-the-server]__2e9964e3._.js.map} +0 -0
  244. /package/dist/server/.next/server/chunks/ssr/{[root-of-the-server]__63c188bd._.js.map → [root-of-the-server]__b8a5c1ab._.js.map} +0 -0
  245. /package/dist/server/.next/static/{rBe6tUwudOthfNpVSim6S → tz_bf3MbzRijrx8XdXPWA}/_buildManifest.js +0 -0
  246. /package/dist/server/.next/static/{rBe6tUwudOthfNpVSim6S → tz_bf3MbzRijrx8XdXPWA}/_clientMiddlewareManifest.json +0 -0
  247. /package/dist/server/.next/static/{rBe6tUwudOthfNpVSim6S → tz_bf3MbzRijrx8XdXPWA}/_ssgManifest.js +0 -0
@@ -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
@@ -1,4 +1,4 @@
1
- module.exports={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"))},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(" ")}
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
2
  `),u?.(l,"stdout",`[目标目录] ${g}
3
3
  `),u?.(l,"stdout",`[仓库地址] ${t}
4
4
  `);let f=(0,s.spawn)("git",m,{cwd:r,stdio:["pipe","pipe","pipe"]}),x="",j=0;u?.(l,"stdout",`[进程启动] Git 进程 PID: ${f.pid}
@@ -11,6 +11,6 @@ module.exports={29549:function(e){var{g:t,__dirname:r,m:s,e:n}=e;s.exports=e.x("
11
11
  ${x}
12
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
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:()=>l,getCursorSchemaUrl:()=>a,getEditorSchemaUrl:()=>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,t="cursor"){return"webstorm"===t?c(e):a(e)}function l(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})}}}};
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
15
 
16
- //# sourceMappingURL=%5Broot-of-the-server%5D__d0112f7b._.js.map
16
+ //# sourceMappingURL=%5Broot-of-the-server%5D__de18efbd._.js.map
@@ -1 +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';\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 * 根据编辑器类型生成对应的 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 '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
+ {"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
@@ -1,8 +1,8 @@
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:()=>a});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 a({}),{}}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 a(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}({})},15650:function(e){var{g:r,__dirname:t,m:s,e:n}=e;s.exports=e.x("module",()=>require("module"))},80298:function(e){var{g:r,__dirname:t,m:s,e:n}=e},17717: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),a=e.i(35692),i=e.i(88941);let r=(0,e.i(15650).createRequire)({get url(){return`file://${e.P("packages/server/src/app/api/cleanup-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,a.getProjectsConfig)())[t])return s.NextResponse.json({success:!1,error:`项目 ${t} 不存在`},{status:404});let c=(0,o.join)(i.WORKSPACE_CONFIG.WORKSPACE_ROOT,t),u=(0,o.join)(c,".mock");try{await n.promises.access(u)}catch{return s.NextResponse.json({success:!0,message:"Mock目录不存在,无需清理",data:{projectName:t,timestamp:new Date().toISOString()}})}let p=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 p(s);else if("setting.cjs"===t.name)try{let e=(0,o.resolve)(s);delete r.cache[e];let t=r(e),a=`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:()=>i,getProjectsConfig:()=>o,saveProjectsConfig:()=>a});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 a({}),{}}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 a(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}({})},15650:function(e){var{g:r,__dirname:t,m:s,e:n}=e;s.exports=e.x("module",()=>require("module"))},80298:function(e){var{g:r,__dirname:t,m:s,e:n}=e},17717: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),a=e.i(35692),i=e.i(88941);let r=(0,e.i(15650).createRequire)({get url(){return`file://${e.P("packages/server/src/app/api/cleanup-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,a.getProjectsConfig)())[t])return s.NextResponse.json({success:!1,error:`项目 ${t} 不存在`},{status:404});let c=(0,o.join)(i.WORKSPACE_CONFIG.WORKSPACE_ROOT,t),u=(0,o.join)(c,".mock");try{await n.promises.access(u)}catch{return s.NextResponse.json({success:!0,message:"Mock目录不存在,无需清理",data:{projectName:t,timestamp:new Date().toISOString()}})}let p=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 p(s);else if("setting.cjs"===t.name)try{let e=(0,o.resolve)(s);delete r.cache[e];let t=r(e),a=`module.exports = {
2
2
  // 当前场景名称
3
3
  currentSite: '${t.currentSite||""}',
4
4
  // 开启Mock的场景列表(已清空)
5
5
  open: []
6
6
  };`;await n.promises.writeFile(s,a,"utf-8")}catch(e){console.warn(`解析setting.cjs失败: ${s}`,e)}}};return await p(u),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})}}}},30706:e=>{"use strict";var{g:r,__dirname:t}=e;{e.s({patchFetch:()=>i,routeModule:()=>r,serverHooks:()=>u,workAsyncStorage:()=>t,workUnitAsyncStorage:()=>c});var s=e.i(45746),n=e.i(93828),o=e.i(18250),a=e.i(17717);let r=new s.AppRouteRouteModule({definition:{kind:n.RouteKind.APP_ROUTE,page:"/api/cleanup-mock/route",pathname:"/api/cleanup-mock",filename:"route",bundlePath:""},resolvedPagePath:"[project]/packages/server/src/app/api/cleanup-mock/route.ts",nextConfigOutput:"",userland:a}),{workAsyncStorage:t,workUnitAsyncStorage:c,serverHooks:u}=r;function i(){return(0,o.patchFetch)({workAsyncStorage:t,workUnitAsyncStorage:c})}}}};
7
7
 
8
- //# sourceMappingURL=%5Broot-of-the-server%5D__419d3b16._.js.map
8
+ //# sourceMappingURL=%5Broot-of-the-server%5D__ec681197._.js.map
@@ -0,0 +1,3 @@
1
+ module.exports={75405:e=>{"use strict";var{g:t,__dirname:a}=e;{e.s({clearStepRun:()=>o,createStepRun:()=>s,getStepRun:()=>r,updateStepRun:()=>c});let t=new Map;function n(){let e=Date.now();for(let[a,n]of t.entries())e-n.updatedAt>36e5&&t.delete(a)}function s(e){n(),t.set(e.runId,{...e,updatedAt:Date.now()})}function r(e){n();let a=t.get(e);return a||null}function c(e){t.set(e.runId,{...e,updatedAt:Date.now()})}function o(e){t.delete(e)}}},9967:e=>{"use strict";var{g:t,__dirname:a}=e;{e.s({POST:()=>b});var n=e.i(15494),s=e.i(87485),r=e.i(83886),c=e.i(30331),o=e.i(88941),i=e.i(35692),d=e.i(77159),u=e.i(79810),p=e.i(75405);let t=/\\s/;function m(e){return!(!e||t.test(e)||e.startsWith("-"))}function h(e,t){return new Promise((a,n)=>{let r=(0,s.spawn)("git",t,{cwd:e,stdio:["ignore","pipe","pipe"]}),c="",o="";r.stdout?.on("data",e=>{c+=e.toString()}),r.stderr?.on("data",e=>{o+=e.toString()}),r.on("close",e=>{a({code:e,stdout:c,stderr:o})}),r.on("error",e=>{n(e)})})}function g(e){return`git ${e.join(" ")}`}function l(e,t,a,n){0===n.code?e.push(`[${t}] 完成: ${a}`):e.push(`[${t}] 失败: ${a} ${n.stderr||n.stdout}`)}function f(e){for(let t=e.currentIndex;t<e.projects.length;t+=1){let a=e.projects[t];if("pending"!==a.status){e.currentIndex=t+1;continue}let n=function(e,t){if("pending"!==t.status)return null;let{createBranch:a,baseBranch:n,mergeBranch:s}=e;switch(t.phase){case"need-current-branch":return{id:`${t.name}-current-branch-${Date.now()}`,projectName:t.name,description:"检查当前分支",args:["branch","--show-current"],kind:"need-current-branch"};case"need-fetch":return{id:`${t.name}-fetch-${Date.now()}`,projectName:t.name,description:"拉取远端",args:["fetch","origin"],kind:"need-fetch"};case"need-base-check":return{id:`${t.name}-base-check-${Date.now()}`,projectName:t.name,description:`检查 origin/${n}`,args:["ls-remote","--heads","origin",n],kind:"need-base-check"};case"need-remote-create-check":return{id:`${t.name}-remote-create-check-${Date.now()}`,projectName:t.name,description:`检查远端分支 ${a}`,args:["ls-remote","--heads","origin",a],kind:"need-remote-create-check"};case"need-local-create-check":return{id:`${t.name}-local-create-check-${Date.now()}`,projectName:t.name,description:`检查本地分支 ${a}`,args:["show-ref","--verify",`refs/heads/${a}`],kind:"need-local-create-check"};case"need-checkout-remote-create":return{id:`${t.name}-checkout-remote-${Date.now()}`,projectName:t.name,description:`切换到远端分支 ${a}`,args:["checkout","-B",a,`origin/${a}`],kind:"need-checkout-remote-create"};case"need-create-branch":return{id:`${t.name}-create-branch-${Date.now()}`,projectName:t.name,description:`创建分支 ${a}`,args:["checkout","-B",a,`origin/${n}`],kind:"need-create-branch"};case"need-push-branch":return{id:`${t.name}-push-branch-${Date.now()}`,projectName:t.name,description:`推送分支 ${a}`,args:["push","-u","origin",a],kind:"need-push-branch"};case"need-merge-check":return{id:`${t.name}-merge-check-${Date.now()}`,projectName:t.name,description:`检查 origin/${s}`,args:["ls-remote","--heads","origin",s],kind:"need-merge-check"};case"need-status":return{id:`${t.name}-status-${Date.now()}`,projectName:t.name,description:"检查工作区",args:["status","--porcelain"],kind:"need-status"};case"need-checkout-create":return{id:`${t.name}-checkout-create-${Date.now()}`,projectName:t.name,description:`切换到分支 ${a}`,args:["checkout",a],kind:"need-checkout-create"};case"need-fetch-after-checkout":return{id:`${t.name}-fetch-after-checkout-${Date.now()}`,projectName:t.name,description:"拉取远端",args:["fetch","origin"],kind:"need-fetch-after-checkout"};case"need-merge":return{id:`${t.name}-merge-${Date.now()}`,projectName:t.name,description:`合并 origin/${s}`,args:["merge","--no-ff","--no-edit",`origin/${s}`],kind:"need-merge"};case"need-merge-abort":return{id:`${t.name}-merge-abort-${Date.now()}`,projectName:t.name,description:"终止合并",args:["merge","--abort"],kind:"need-merge-abort"};case"need-push-merge":return{id:`${t.name}-push-merge-${Date.now()}`,projectName:t.name,description:`推送合并结果 ${a}`,args:["push","origin",a],kind:"need-push-merge"};case"need-main-fetch":return{id:`${t.name}-main-fetch-${Date.now()}`,projectName:t.name,description:"拉取远端",args:["fetch","origin"],kind:"need-main-fetch"};case"need-main-check":return{id:`${t.name}-main-check-${Date.now()}`,projectName:t.name,description:"检查 origin/main",args:["ls-remote","--heads","origin","main"],kind:"need-main-check"};case"need-status-main":return{id:`${t.name}-status-main-${Date.now()}`,projectName:t.name,description:"检查工作区",args:["status","--porcelain"],kind:"need-status-main"};case"need-checkout-main":return{id:`${t.name}-checkout-main-${Date.now()}`,projectName:t.name,description:"切换到 main",args:["checkout","main"],kind:"need-checkout-main"};case"need-merge-into-main":return{id:`${t.name}-merge-into-main-${Date.now()}`,projectName:t.name,description:`合并 origin/${a} 到 main`,args:["merge","--no-ff","--no-edit",`origin/${a}`],kind:"need-merge-into-main"};case"need-merge-into-main-abort":return{id:`${t.name}-merge-into-main-abort-${Date.now()}`,projectName:t.name,description:"终止合并到 main",args:["merge","--abort"],kind:"need-merge-into-main-abort"};case"need-push-main":return{id:`${t.name}-push-main-${Date.now()}`,projectName:t.name,description:"推送 main",args:["push","origin","main"],kind:"need-push-main"};default:return null}}(e,a);if(n)return e.currentIndex=t,e.currentStep=n,n;e.currentIndex=t+1}return e.currentStep=null,null}async function k(e){let{createBranch:t}=e;for(let a of[...e.projects].reverse()){if(!a.originalBranch)continue;e.operationLogs.push(`[${a.name}] 回滚: ${g(["checkout",a.originalBranch])}`);let n=await h(a.path,["checkout",a.originalBranch]);if(l(e.operationLogs,a.name,`回滚切换分支 ${a.originalBranch}`,n),a.createdLocalBranch&&!a.hadLocalBranch){e.operationLogs.push(`[${a.name}] 回滚: ${g(["branch","-D",t])}`);let n=await h(a.path,["branch","-D",t]);l(e.operationLogs,a.name,`回滚删除本地分支 ${t}`,n)}}}async function $(e,t){let a=e.projects.find(e=>e.name===t.projectName);if(!a)return void e.feedbacks.push(`[${t.projectName}] 项目不存在,跳过。`);e.operationLogs.push(`[${a.name}] ${g(t.args)}`);let n=await h(a.path,t.args);switch(l(e.operationLogs,a.name,t.description,n),t.kind){case"need-current-branch":a.originalBranch=n.stdout.replace(/\s+/g," ").trim()||"HEAD",0===n.code?a.phase="need-fetch":(a.status="failed",e.feedbacks.push(`[${a.name}] 获取当前分支失败。`));break;case"need-fetch":0===n.code?a.phase="need-base-check":(a.status="failed",e.feedbacks.push(`[${a.name}] 拉取远端失败: ${n.stderr||n.stdout}`));break;case"need-base-check":a.baseExists=!!n.stdout.trim(),a.baseExists?a.phase="need-remote-create-check":(a.status="failed",e.feedbacks.push(`[${a.name}] origin/${e.baseBranch} 不存在,无法创建分支。`));break;case"need-remote-create-check":a.remoteCreateExists=!!n.stdout.trim(),a.phase="need-local-create-check";break;case"need-local-create-check":a.localCreateExists=0===n.code,a.localCreateExists?a.phase="need-checkout-create":a.remoteCreateExists?(a.hadLocalBranch=!1,a.phase="need-checkout-remote-create"):(a.hadLocalBranch=!1,a.phase="need-create-branch");break;case"need-checkout-remote-create":0===n.code?a.phase="need-merge-check":(a.status="failed",e.feedbacks.push(`[${a.name}] 切换到远端分支失败: ${n.stderr||n.stdout}`));break;case"need-create-branch":0===n.code?(a.createdLocalBranch=!0,a.phase="need-push-branch"):(a.status="failed",e.feedbacks.push(`[${a.name}] 创建分支失败: ${n.stderr||n.stdout}`));break;case"need-push-branch":0===n.code?a.phase="need-merge-check":(a.status="failed",e.feedbacks.push(`[${a.name}] 推送新分支失败: ${n.stderr||n.stdout}`));break;case"need-merge-check":a.mergeExists=!!n.stdout.trim(),a.mergeExists?a.phase="need-status":(a.status="failed",e.feedbacks.push(`[${a.name}] origin/${e.mergeBranch} 不存在,无法合并。`));break;case"need-status":a.statusClean=0===n.stdout.trim().length,a.statusClean?a.phase="need-checkout-create":(a.status="failed",e.feedbacks.push(`[${a.name}] 工作区有未提交改动,请先处理后再执行合并。`));break;case"need-checkout-create":0===n.code?a.phase="need-fetch-after-checkout":(a.status="failed",e.feedbacks.push(`[${a.name}] 切换到分支失败: ${n.stderr||n.stdout}`));break;case"need-fetch-after-checkout":0===n.code?a.phase="need-merge":(a.status="failed",e.feedbacks.push(`[${a.name}] 拉取远端失败: ${n.stderr||n.stdout}`));break;case"need-merge":0===n.code?a.phase="need-push-merge":(a.phase="need-merge-abort",e.feedbacks.push(`[${a.name}] 合并冲突,准备终止合并。`));break;case"need-merge-abort":0!==n.code&&e.feedbacks.push(`[${a.name}] 终止合并失败: ${n.stderr||n.stdout}`),a.status="failed",e.feedbacks.push(`[${a.name}] 合并冲突,已终止合并,请手动处理。`);break;case"need-push-merge":0===n.code?a.phase="need-main-fetch":(a.status="failed",e.feedbacks.push(`[${a.name}] 推送合并结果失败: ${n.stderr||n.stdout}`));break;case"need-main-fetch":0===n.code?a.phase="need-main-check":(a.status="failed",e.feedbacks.push(`[${a.name}] 拉取远端失败: ${n.stderr||n.stdout}`));break;case"need-main-check":n.stdout.trim()?a.phase="need-status-main":(a.status="failed",e.feedbacks.push(`[${a.name}] origin/main 不存在,无法合并。`));break;case"need-status-main":0===n.stdout.trim().length?a.phase="need-checkout-main":(a.status="failed",e.feedbacks.push(`[${a.name}] 工作区有未提交改动,请先处理后再合并 main。`));break;case"need-checkout-main":0===n.code?a.phase="need-merge-into-main":(a.status="failed",e.feedbacks.push(`[${a.name}] 切换到 main 失败: ${n.stderr||n.stdout}`));break;case"need-merge-into-main":0===n.code?a.phase="need-push-main":(a.phase="need-merge-into-main-abort",e.feedbacks.push(`[${a.name}] 合并到 main 冲突,准备终止合并。`));break;case"need-merge-into-main-abort":0!==n.code&&e.feedbacks.push(`[${a.name}] 终止合并到 main 失败: ${n.stderr||n.stdout}`),a.status="failed",e.feedbacks.push(`[${a.name}] 合并到 main 冲突,已终止合并,请手动处理。`);break;case"need-push-main":0===n.code?(a.status="done",a.phase="done"):(a.status="failed",e.feedbacks.push(`[${a.name}] 推送 main 失败: ${n.stderr||n.stdout}`))}}async function b(e){try{let t=await e.json(),a="string"==typeof t.action?t.action:"";if("start"===a){let e=Array.isArray(t.projects)?t.projects:[],a="string"==typeof t.createBranch?t.createBranch.trim():"",s="string"==typeof t.baseBranch?t.baseBranch.trim():"",h="string"==typeof t.mergeBranch?t.mergeBranch.trim():"",l="string"==typeof t.runId?t.runId:"",k=[],$=[];if(0===e.length||!a||!s||!h)return n.NextResponse.json({success:!1,operationLogs:k,feedbacks:["缺少必要参数,请填写完整后重试。"]},{status:400});if(!m(a)||!m(s)||!m(h))return n.NextResponse.json({success:!1,operationLogs:k,feedbacks:["分支名称不合法,请避免空格或以 - 开头。"]},{status:400});if(!l)return n.NextResponse.json({success:!1,operationLogs:k,feedbacks:["缺少 runId,请刷新页面后重试。"]},{status:400});(0,u.createUatGitFlowState)(l);let b=await (0,i.getProjectsConfig)(),j=o.WORKSPACE_CONFIG.WORKSPACE_ROOT,w=[];for(let t of e){let e=String(t),a=(0,d.sanitizeProjectName)(e);if(!a||a!==e){k.push(`[${e}] 失败: 项目名称包含无效字符`),$.push(`[${e}] 项目名称包含无效字符,已跳过。`);continue}if(!b[a]){k.push(`[${a}] 失败: 未在项目配置中找到`),$.push(`[${a}] 未在项目配置中找到,已跳过。`);continue}let n=(0,c.join)(j,a);if(!(0,r.existsSync)(n)){k.push(`[${a}] 失败: 项目目录不存在`),$.push(`[${a}] 项目目录不存在,已跳过。`);continue}if(!(0,r.existsSync)((0,c.join)(n,".git"))){k.push(`[${a}] 失败: 非 Git 仓库`),$.push(`[${a}] 不是有效的 Git 仓库,已跳过。`);continue}w.push({name:a,path:n,phase:"need-current-branch",status:"pending",originalBranch:"",createdLocalBranch:!1,hadLocalBranch:!0,baseExists:null,remoteCreateExists:null,localCreateExists:null,mergeExists:null,statusClean:null})}let N={runId:l,createBranch:a,baseBranch:s,mergeBranch:h,projects:w,currentIndex:0,operationLogs:k,feedbacks:$,currentStep:null,updatedAt:Date.now()},x=f(N);return(0,p.createStepRun)(N),n.NextResponse.json({success:!0,runId:l,nextStep:x?{stepId:x.id,projectName:x.projectName,description:x.description,command:g(x.args)}:null,operationLogs:N.operationLogs,feedbacks:N.feedbacks,isComplete:null===x})}if("execute"===a){let e="string"==typeof t.runId?t.runId:"",a="string"==typeof t.stepId?t.stepId:"",s=(0,p.getStepRun)(e);if(!s)return n.NextResponse.json({success:!1,operationLogs:[],feedbacks:["未找到执行上下文,请重新开始。"]},{status:404});if((0,u.isUatGitFlowAborted)(e))return s.operationLogs.push("已收到中断请求,开始回滚已执行的本地操作。"),await k(s),(0,p.clearStepRun)(e),(0,u.clearUatGitFlowState)(e),n.NextResponse.json({success:!0,runId:e,nextStep:null,operationLogs:s.operationLogs,feedbacks:s.feedbacks,isComplete:!0,aborted:!0});if(!s.currentStep||s.currentStep.id!==a)return n.NextResponse.json({success:!1,operationLogs:s.operationLogs,feedbacks:["步骤已更新,请重新确认。"]},{status:409});await $(s,s.currentStep);let r=f(s);return(0,p.updateStepRun)(s),r||((0,p.clearStepRun)(e),(0,u.clearUatGitFlowState)(e)),n.NextResponse.json({success:!0,runId:e,nextStep:r?{stepId:r.id,projectName:r.projectName,description:r.description,command:g(r.args)}:null,operationLogs:s.operationLogs,feedbacks:s.feedbacks,isComplete:null===r})}if("abort"===a){let e="string"==typeof t.runId?t.runId:"",a=(0,p.getStepRun)(e);if(!a)return n.NextResponse.json({success:!1,operationLogs:[],feedbacks:["未找到执行上下文,请重新开始。"]},{status:404});return a.operationLogs.push("已收到中断请求,开始回滚已执行的本地操作。"),await k(a),(0,p.clearStepRun)(e),(0,u.clearUatGitFlowState)(e),n.NextResponse.json({success:!0,runId:e,nextStep:null,operationLogs:a.operationLogs,feedbacks:a.feedbacks,isComplete:!0,aborted:!0})}return n.NextResponse.json({success:!1,operationLogs:[],feedbacks:["未知操作类型。"]},{status:400})}catch(e){return console.error("UAT git 分步执行失败:",e),n.NextResponse.json({success:!1,operationLogs:[],feedbacks:[e instanceof Error?e.message:"执行失败"]},{status:500})}}}},3301:e=>{"use strict";var{g:t,__dirname:a}=e;{e.s({patchFetch:()=>o,routeModule:()=>t,serverHooks:()=>d,workAsyncStorage:()=>a,workUnitAsyncStorage:()=>i});var n=e.i(45746),s=e.i(93828),r=e.i(18250),c=e.i(9967);let t=new n.AppRouteRouteModule({definition:{kind:s.RouteKind.APP_ROUTE,page:"/api/uat-git-flow/step/route",pathname:"/api/uat-git-flow/step",filename:"route",bundlePath:""},resolvedPagePath:"[project]/packages/server/src/app/api/uat-git-flow/step/route.ts",nextConfigOutput:"",userland:c}),{workAsyncStorage:a,workUnitAsyncStorage:i,serverHooks:d}=t;function o(){return(0,r.patchFetch)({workAsyncStorage:a,workUnitAsyncStorage:i})}}}};
2
+
3
+ //# sourceMappingURL=_24087f66._.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["turbopack:///[project]/packages/server/src/app/api/uat-git-flow/step-state.ts","turbopack:///[project]/packages/server/src/app/api/uat-git-flow/step/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":["type ProjectPhase =\n | 'need-current-branch'\n | 'need-fetch'\n | 'need-base-check'\n | 'need-remote-create-check'\n | 'need-local-create-check'\n | 'need-checkout-remote-create'\n | 'need-create-branch'\n | 'need-push-branch'\n | 'need-merge-check'\n | 'need-status'\n | 'need-checkout-create'\n | 'need-fetch-after-checkout'\n | 'need-merge'\n | 'need-merge-abort'\n | 'need-push-merge'\n | 'need-checkout-main'\n | 'need-merge-into-main'\n | 'need-merge-into-main-abort'\n | 'need-main-check'\n | 'need-status-main'\n | 'need-main-fetch'\n | 'need-push-main'\n | 'done'\n | 'failed';\n\nexport type StepDescriptor = {\n id: string;\n projectName: string;\n description: string;\n args: string[];\n kind: ProjectPhase;\n};\n\nexport type ProjectRunState = {\n name: string;\n path: string;\n phase: ProjectPhase;\n status: 'pending' | 'done' | 'failed';\n originalBranch: string;\n createdLocalBranch: boolean;\n hadLocalBranch: boolean;\n baseExists: boolean | null;\n remoteCreateExists: boolean | null;\n localCreateExists: boolean | null;\n mergeExists: boolean | null;\n statusClean: boolean | null;\n};\n\nexport type RunState = {\n runId: string;\n createBranch: string;\n baseBranch: string;\n mergeBranch: string;\n projects: ProjectRunState[];\n currentIndex: number;\n operationLogs: string[];\n feedbacks: string[];\n currentStep: StepDescriptor | null;\n updatedAt: number;\n};\n\nconst runStates = new Map<string, RunState>();\nconst RUN_STATE_TTL = 1000 * 60 * 60;\n\nfunction cleanupRunStates() {\n const now = Date.now();\n for (const [runId, state] of runStates.entries()) {\n if (now - state.updatedAt > RUN_STATE_TTL) {\n runStates.delete(runId);\n }\n }\n}\n\nexport function createStepRun(state: RunState) {\n cleanupRunStates();\n runStates.set(state.runId, { ...state, updatedAt: Date.now() });\n}\n\nexport function getStepRun(runId: string) {\n cleanupRunStates();\n const state = runStates.get(runId);\n if (!state) return null;\n return state;\n}\n\nexport function updateStepRun(state: RunState) {\n runStates.set(state.runId, { ...state, updatedAt: Date.now() });\n}\n\nexport function clearStepRun(runId: string) {\n runStates.delete(runId);\n}\n","import { NextRequest, NextResponse } from 'next/server';\nimport { spawn } from 'child_process';\nimport { existsSync } from 'fs';\nimport { join } from 'path';\nimport { WORKSPACE_CONFIG } from '@/lib/workspace-types';\nimport { getProjectsConfig } from '@/lib/workspace-config';\nimport { sanitizeProjectName } from '@/lib/git-operations';\nimport { createUatGitFlowState, isUatGitFlowAborted, clearUatGitFlowState } from '../state';\nimport {\n clearStepRun,\n createStepRun,\n getStepRun,\n updateStepRun,\n type ProjectRunState,\n type RunState,\n type StepDescriptor,\n} from '../step-state';\n\ntype GitResult = {\n code: number | null;\n stdout: string;\n stderr: string;\n};\n\nconst invalidBranchChars = /\\\\s/;\n\nfunction isValidBranchName(name: string) {\n if (!name) return false;\n if (invalidBranchChars.test(name)) return false;\n if (name.startsWith('-')) return false;\n return true;\n}\n\nfunction runGitCommand(cwd: string, args: string[]): Promise<GitResult> {\n return new Promise((resolve, reject) => {\n const child = spawn('git', args, {\n cwd,\n stdio: ['ignore', 'pipe', 'pipe']\n });\n\n let stdout = '';\n let stderr = '';\n\n child.stdout?.on('data', (data: Buffer) => {\n stdout += data.toString();\n });\n\n child.stderr?.on('data', (data: Buffer) => {\n stderr += data.toString();\n });\n\n child.on('close', (code) => {\n resolve({ code, stdout, stderr });\n });\n\n child.on('error', (error) => {\n reject(error);\n });\n });\n}\n\nfunction formatCommand(args: string[]) {\n return `git ${args.join(' ')}`;\n}\n\nfunction sanitizeLogValue(value: string) {\n return value.replace(/\\s+/g, ' ').trim();\n}\n\nfunction logCommandResult(operationLogs: string[], projectName: string, step: string, result: GitResult) {\n if (result.code === 0) {\n operationLogs.push(`[${projectName}] 完成: ${step}`);\n } else {\n operationLogs.push(`[${projectName}] 失败: ${step} ${result.stderr || result.stdout}`);\n }\n}\n\nfunction initProjectRunState(projectName: string, projectPath: string): ProjectRunState {\n return {\n name: projectName,\n path: projectPath,\n phase: 'need-current-branch',\n status: 'pending',\n originalBranch: '',\n createdLocalBranch: false,\n hadLocalBranch: true,\n baseExists: null,\n remoteCreateExists: null,\n localCreateExists: null,\n mergeExists: null,\n statusClean: null,\n };\n}\n\nfunction buildStep(run: RunState, project: ProjectRunState): StepDescriptor | null {\n if (project.status !== 'pending') return null;\n const { createBranch, baseBranch, mergeBranch } = run;\n\n switch (project.phase) {\n case 'need-current-branch':\n return {\n id: `${project.name}-current-branch-${Date.now()}`,\n projectName: project.name,\n description: '检查当前分支',\n args: ['branch', '--show-current'],\n kind: 'need-current-branch',\n };\n case 'need-fetch':\n return {\n id: `${project.name}-fetch-${Date.now()}`,\n projectName: project.name,\n description: '拉取远端',\n args: ['fetch', 'origin'],\n kind: 'need-fetch',\n };\n case 'need-base-check':\n return {\n id: `${project.name}-base-check-${Date.now()}`,\n projectName: project.name,\n description: `检查 origin/${baseBranch}`,\n args: ['ls-remote', '--heads', 'origin', baseBranch],\n kind: 'need-base-check',\n };\n case 'need-remote-create-check':\n return {\n id: `${project.name}-remote-create-check-${Date.now()}`,\n projectName: project.name,\n description: `检查远端分支 ${createBranch}`,\n args: ['ls-remote', '--heads', 'origin', createBranch],\n kind: 'need-remote-create-check',\n };\n case 'need-local-create-check':\n return {\n id: `${project.name}-local-create-check-${Date.now()}`,\n projectName: project.name,\n description: `检查本地分支 ${createBranch}`,\n args: ['show-ref', '--verify', `refs/heads/${createBranch}`],\n kind: 'need-local-create-check',\n };\n case 'need-checkout-remote-create':\n return {\n id: `${project.name}-checkout-remote-${Date.now()}`,\n projectName: project.name,\n description: `切换到远端分支 ${createBranch}`,\n args: ['checkout', '-B', createBranch, `origin/${createBranch}`],\n kind: 'need-checkout-remote-create',\n };\n case 'need-create-branch':\n return {\n id: `${project.name}-create-branch-${Date.now()}`,\n projectName: project.name,\n description: `创建分支 ${createBranch}`,\n args: ['checkout', '-B', createBranch, `origin/${baseBranch}`],\n kind: 'need-create-branch',\n };\n case 'need-push-branch':\n return {\n id: `${project.name}-push-branch-${Date.now()}`,\n projectName: project.name,\n description: `推送分支 ${createBranch}`,\n args: ['push', '-u', 'origin', createBranch],\n kind: 'need-push-branch',\n };\n case 'need-merge-check':\n return {\n id: `${project.name}-merge-check-${Date.now()}`,\n projectName: project.name,\n description: `检查 origin/${mergeBranch}`,\n args: ['ls-remote', '--heads', 'origin', mergeBranch],\n kind: 'need-merge-check',\n };\n case 'need-status':\n return {\n id: `${project.name}-status-${Date.now()}`,\n projectName: project.name,\n description: '检查工作区',\n args: ['status', '--porcelain'],\n kind: 'need-status',\n };\n case 'need-checkout-create':\n return {\n id: `${project.name}-checkout-create-${Date.now()}`,\n projectName: project.name,\n description: `切换到分支 ${createBranch}`,\n args: ['checkout', createBranch],\n kind: 'need-checkout-create',\n };\n case 'need-fetch-after-checkout':\n return {\n id: `${project.name}-fetch-after-checkout-${Date.now()}`,\n projectName: project.name,\n description: '拉取远端',\n args: ['fetch', 'origin'],\n kind: 'need-fetch-after-checkout',\n };\n case 'need-merge':\n return {\n id: `${project.name}-merge-${Date.now()}`,\n projectName: project.name,\n description: `合并 origin/${mergeBranch}`,\n args: ['merge', '--no-ff', '--no-edit', `origin/${mergeBranch}`],\n kind: 'need-merge',\n };\n case 'need-merge-abort':\n return {\n id: `${project.name}-merge-abort-${Date.now()}`,\n projectName: project.name,\n description: '终止合并',\n args: ['merge', '--abort'],\n kind: 'need-merge-abort',\n };\n case 'need-push-merge':\n return {\n id: `${project.name}-push-merge-${Date.now()}`,\n projectName: project.name,\n description: `推送合并结果 ${createBranch}`,\n args: ['push', 'origin', createBranch],\n kind: 'need-push-merge',\n };\n case 'need-main-fetch':\n return {\n id: `${project.name}-main-fetch-${Date.now()}`,\n projectName: project.name,\n description: '拉取远端',\n args: ['fetch', 'origin'],\n kind: 'need-main-fetch',\n };\n case 'need-main-check':\n return {\n id: `${project.name}-main-check-${Date.now()}`,\n projectName: project.name,\n description: '检查 origin/main',\n args: ['ls-remote', '--heads', 'origin', 'main'],\n kind: 'need-main-check',\n };\n case 'need-status-main':\n return {\n id: `${project.name}-status-main-${Date.now()}`,\n projectName: project.name,\n description: '检查工作区',\n args: ['status', '--porcelain'],\n kind: 'need-status-main',\n };\n case 'need-checkout-main':\n return {\n id: `${project.name}-checkout-main-${Date.now()}`,\n projectName: project.name,\n description: '切换到 main',\n args: ['checkout', 'main'],\n kind: 'need-checkout-main',\n };\n case 'need-merge-into-main':\n return {\n id: `${project.name}-merge-into-main-${Date.now()}`,\n projectName: project.name,\n description: `合并 origin/${createBranch} 到 main`,\n args: ['merge', '--no-ff', '--no-edit', `origin/${createBranch}`],\n kind: 'need-merge-into-main',\n };\n case 'need-merge-into-main-abort':\n return {\n id: `${project.name}-merge-into-main-abort-${Date.now()}`,\n projectName: project.name,\n description: '终止合并到 main',\n args: ['merge', '--abort'],\n kind: 'need-merge-into-main-abort',\n };\n case 'need-push-main':\n return {\n id: `${project.name}-push-main-${Date.now()}`,\n projectName: project.name,\n description: '推送 main',\n args: ['push', 'origin', 'main'],\n kind: 'need-push-main',\n };\n default:\n return null;\n }\n}\n\nfunction advanceToNextStep(run: RunState) {\n for (let i = run.currentIndex; i < run.projects.length; i += 1) {\n const project = run.projects[i];\n if (project.status !== 'pending') {\n run.currentIndex = i + 1;\n continue;\n }\n const step = buildStep(run, project);\n if (step) {\n run.currentIndex = i;\n run.currentStep = step;\n return step;\n }\n run.currentIndex = i + 1;\n }\n run.currentStep = null;\n return null;\n}\n\nasync function rollbackRun(run: RunState) {\n const { createBranch } = run;\n for (const project of [...run.projects].reverse()) {\n if (!project.originalBranch) continue;\n run.operationLogs.push(`[${project.name}] 回滚: ${formatCommand(['checkout', project.originalBranch])}`);\n const rollbackCheckout = await runGitCommand(project.path, ['checkout', project.originalBranch]);\n logCommandResult(run.operationLogs, project.name, `回滚切换分支 ${project.originalBranch}`, rollbackCheckout);\n\n if (project.createdLocalBranch && !project.hadLocalBranch) {\n run.operationLogs.push(`[${project.name}] 回滚: ${formatCommand(['branch', '-D', createBranch])}`);\n const rollbackDelete = await runGitCommand(project.path, ['branch', '-D', createBranch]);\n logCommandResult(run.operationLogs, project.name, `回滚删除本地分支 ${createBranch}`, rollbackDelete);\n }\n }\n}\n\nasync function executeStep(run: RunState, step: StepDescriptor) {\n const project = run.projects.find(item => item.name === step.projectName);\n if (!project) {\n run.feedbacks.push(`[${step.projectName}] 项目不存在,跳过。`);\n return;\n }\n\n run.operationLogs.push(`[${project.name}] ${formatCommand(step.args)}`);\n const result = await runGitCommand(project.path, step.args);\n logCommandResult(run.operationLogs, project.name, step.description, result);\n\n switch (step.kind) {\n case 'need-current-branch': {\n project.originalBranch = sanitizeLogValue(result.stdout) || 'HEAD';\n if (result.code === 0) {\n project.phase = 'need-fetch';\n } else {\n project.status = 'failed';\n run.feedbacks.push(`[${project.name}] 获取当前分支失败。`);\n }\n break;\n }\n case 'need-fetch': {\n if (result.code === 0) {\n project.phase = 'need-base-check';\n } else {\n project.status = 'failed';\n run.feedbacks.push(`[${project.name}] 拉取远端失败: ${result.stderr || result.stdout}`);\n }\n break;\n }\n case 'need-base-check': {\n project.baseExists = Boolean(result.stdout.trim());\n if (!project.baseExists) {\n project.status = 'failed';\n run.feedbacks.push(`[${project.name}] origin/${run.baseBranch} 不存在,无法创建分支。`);\n } else {\n project.phase = 'need-remote-create-check';\n }\n break;\n }\n case 'need-remote-create-check': {\n project.remoteCreateExists = Boolean(result.stdout.trim());\n project.phase = 'need-local-create-check';\n break;\n }\n case 'need-local-create-check': {\n project.localCreateExists = result.code === 0;\n if (project.localCreateExists) {\n project.phase = 'need-checkout-create';\n } else if (project.remoteCreateExists) {\n project.hadLocalBranch = false;\n project.phase = 'need-checkout-remote-create';\n } else {\n project.hadLocalBranch = false;\n project.phase = 'need-create-branch';\n }\n break;\n }\n case 'need-checkout-remote-create': {\n if (result.code === 0) {\n project.phase = 'need-merge-check';\n } else {\n project.status = 'failed';\n run.feedbacks.push(`[${project.name}] 切换到远端分支失败: ${result.stderr || result.stdout}`);\n }\n break;\n }\n case 'need-create-branch': {\n if (result.code === 0) {\n project.createdLocalBranch = true;\n project.phase = 'need-push-branch';\n } else {\n project.status = 'failed';\n run.feedbacks.push(`[${project.name}] 创建分支失败: ${result.stderr || result.stdout}`);\n }\n break;\n }\n case 'need-push-branch': {\n if (result.code === 0) {\n project.phase = 'need-merge-check';\n } else {\n project.status = 'failed';\n run.feedbacks.push(`[${project.name}] 推送新分支失败: ${result.stderr || result.stdout}`);\n }\n break;\n }\n case 'need-merge-check': {\n project.mergeExists = Boolean(result.stdout.trim());\n if (!project.mergeExists) {\n project.status = 'failed';\n run.feedbacks.push(`[${project.name}] origin/${run.mergeBranch} 不存在,无法合并。`);\n } else {\n project.phase = 'need-status';\n }\n break;\n }\n case 'need-status': {\n project.statusClean = result.stdout.trim().length === 0;\n if (!project.statusClean) {\n project.status = 'failed';\n run.feedbacks.push(`[${project.name}] 工作区有未提交改动,请先处理后再执行合并。`);\n } else {\n project.phase = 'need-checkout-create';\n }\n break;\n }\n case 'need-checkout-create': {\n if (result.code === 0) {\n project.phase = 'need-fetch-after-checkout';\n } else {\n project.status = 'failed';\n run.feedbacks.push(`[${project.name}] 切换到分支失败: ${result.stderr || result.stdout}`);\n }\n break;\n }\n case 'need-fetch-after-checkout': {\n if (result.code === 0) {\n project.phase = 'need-merge';\n } else {\n project.status = 'failed';\n run.feedbacks.push(`[${project.name}] 拉取远端失败: ${result.stderr || result.stdout}`);\n }\n break;\n }\n case 'need-merge': {\n if (result.code === 0) {\n project.phase = 'need-push-merge';\n } else {\n project.phase = 'need-merge-abort';\n run.feedbacks.push(`[${project.name}] 合并冲突,准备终止合并。`);\n }\n break;\n }\n case 'need-merge-abort': {\n if (result.code !== 0) {\n run.feedbacks.push(`[${project.name}] 终止合并失败: ${result.stderr || result.stdout}`);\n }\n project.status = 'failed';\n run.feedbacks.push(`[${project.name}] 合并冲突,已终止合并,请手动处理。`);\n break;\n }\n case 'need-push-merge': {\n if (result.code === 0) {\n project.phase = 'need-main-fetch';\n } else {\n project.status = 'failed';\n run.feedbacks.push(`[${project.name}] 推送合并结果失败: ${result.stderr || result.stdout}`);\n }\n break;\n }\n case 'need-main-fetch': {\n if (result.code === 0) {\n project.phase = 'need-main-check';\n } else {\n project.status = 'failed';\n run.feedbacks.push(`[${project.name}] 拉取远端失败: ${result.stderr || result.stdout}`);\n }\n break;\n }\n case 'need-main-check': {\n const mainExists = Boolean(result.stdout.trim());\n if (!mainExists) {\n project.status = 'failed';\n run.feedbacks.push(`[${project.name}] origin/main 不存在,无法合并。`);\n } else {\n project.phase = 'need-status-main';\n }\n break;\n }\n case 'need-status-main': {\n const statusClean = result.stdout.trim().length === 0;\n if (!statusClean) {\n project.status = 'failed';\n run.feedbacks.push(`[${project.name}] 工作区有未提交改动,请先处理后再合并 main。`);\n } else {\n project.phase = 'need-checkout-main';\n }\n break;\n }\n case 'need-checkout-main': {\n if (result.code === 0) {\n project.phase = 'need-merge-into-main';\n } else {\n project.status = 'failed';\n run.feedbacks.push(`[${project.name}] 切换到 main 失败: ${result.stderr || result.stdout}`);\n }\n break;\n }\n case 'need-merge-into-main': {\n if (result.code === 0) {\n project.phase = 'need-push-main';\n } else {\n project.phase = 'need-merge-into-main-abort';\n run.feedbacks.push(`[${project.name}] 合并到 main 冲突,准备终止合并。`);\n }\n break;\n }\n case 'need-merge-into-main-abort': {\n if (result.code !== 0) {\n run.feedbacks.push(`[${project.name}] 终止合并到 main 失败: ${result.stderr || result.stdout}`);\n }\n project.status = 'failed';\n run.feedbacks.push(`[${project.name}] 合并到 main 冲突,已终止合并,请手动处理。`);\n break;\n }\n case 'need-push-main': {\n if (result.code === 0) {\n project.status = 'done';\n project.phase = 'done';\n } else {\n project.status = 'failed';\n run.feedbacks.push(`[${project.name}] 推送 main 失败: ${result.stderr || result.stdout}`);\n }\n break;\n }\n default:\n break;\n }\n}\n\nexport async function POST(request: NextRequest) {\n try {\n const body = await request.json();\n const action = typeof body.action === 'string' ? body.action : '';\n\n if (action === 'start') {\n const projects = Array.isArray(body.projects) ? body.projects : [];\n const createBranch = typeof body.createBranch === 'string' ? body.createBranch.trim() : '';\n const baseBranch = typeof body.baseBranch === 'string' ? body.baseBranch.trim() : '';\n const mergeBranch = typeof body.mergeBranch === 'string' ? body.mergeBranch.trim() : '';\n const runId = typeof body.runId === 'string' ? body.runId : '';\n\n const operationLogs: string[] = [];\n const feedbacks: string[] = [];\n\n if (projects.length === 0 || !createBranch || !baseBranch || !mergeBranch) {\n return NextResponse.json({\n success: false,\n operationLogs,\n feedbacks: ['缺少必要参数,请填写完整后重试。'],\n }, { status: 400 });\n }\n\n if (!isValidBranchName(createBranch) || !isValidBranchName(baseBranch) || !isValidBranchName(mergeBranch)) {\n return NextResponse.json({\n success: false,\n operationLogs,\n feedbacks: ['分支名称不合法,请避免空格或以 - 开头。'],\n }, { status: 400 });\n }\n\n if (!runId) {\n return NextResponse.json({\n success: false,\n operationLogs,\n feedbacks: ['缺少 runId,请刷新页面后重试。'],\n }, { status: 400 });\n }\n\n createUatGitFlowState(runId);\n const projectsConfig = await getProjectsConfig();\n const workspacePath = WORKSPACE_CONFIG.WORKSPACE_ROOT;\n const runProjects: ProjectRunState[] = [];\n\n for (const rawProjectName of projects) {\n const originalName = String(rawProjectName);\n const projectName = sanitizeProjectName(originalName);\n\n if (!projectName || projectName !== originalName) {\n operationLogs.push(`[${originalName}] 失败: 项目名称包含无效字符`);\n feedbacks.push(`[${originalName}] 项目名称包含无效字符,已跳过。`);\n continue;\n }\n\n if (!projectsConfig[projectName]) {\n operationLogs.push(`[${projectName}] 失败: 未在项目配置中找到`);\n feedbacks.push(`[${projectName}] 未在项目配置中找到,已跳过。`);\n continue;\n }\n\n const projectPath = join(workspacePath, projectName);\n if (!existsSync(projectPath)) {\n operationLogs.push(`[${projectName}] 失败: 项目目录不存在`);\n feedbacks.push(`[${projectName}] 项目目录不存在,已跳过。`);\n continue;\n }\n\n if (!existsSync(join(projectPath, '.git'))) {\n operationLogs.push(`[${projectName}] 失败: 非 Git 仓库`);\n feedbacks.push(`[${projectName}] 不是有效的 Git 仓库,已跳过。`);\n continue;\n }\n\n runProjects.push(initProjectRunState(projectName, projectPath));\n }\n\n const runState: RunState = {\n runId,\n createBranch,\n baseBranch,\n mergeBranch,\n projects: runProjects,\n currentIndex: 0,\n operationLogs,\n feedbacks,\n currentStep: null,\n updatedAt: Date.now(),\n };\n\n const nextStep = advanceToNextStep(runState);\n createStepRun(runState);\n\n return NextResponse.json({\n success: true,\n runId,\n nextStep: nextStep ? {\n stepId: nextStep.id,\n projectName: nextStep.projectName,\n description: nextStep.description,\n command: formatCommand(nextStep.args),\n } : null,\n operationLogs: runState.operationLogs,\n feedbacks: runState.feedbacks,\n isComplete: nextStep === null,\n });\n }\n\n if (action === 'execute') {\n const runId = typeof body.runId === 'string' ? body.runId : '';\n const stepId = typeof body.stepId === 'string' ? body.stepId : '';\n\n const runState = getStepRun(runId);\n if (!runState) {\n return NextResponse.json({\n success: false,\n operationLogs: [],\n feedbacks: ['未找到执行上下文,请重新开始。'],\n }, { status: 404 });\n }\n\n if (isUatGitFlowAborted(runId)) {\n runState.operationLogs.push('已收到中断请求,开始回滚已执行的本地操作。');\n await rollbackRun(runState);\n clearStepRun(runId);\n clearUatGitFlowState(runId);\n return NextResponse.json({\n success: true,\n runId,\n nextStep: null,\n operationLogs: runState.operationLogs,\n feedbacks: runState.feedbacks,\n isComplete: true,\n aborted: true,\n });\n }\n\n if (!runState.currentStep || runState.currentStep.id !== stepId) {\n return NextResponse.json({\n success: false,\n operationLogs: runState.operationLogs,\n feedbacks: ['步骤已更新,请重新确认。'],\n }, { status: 409 });\n }\n\n await executeStep(runState, runState.currentStep);\n\n const nextStep = advanceToNextStep(runState);\n updateStepRun(runState);\n\n if (!nextStep) {\n clearStepRun(runId);\n clearUatGitFlowState(runId);\n }\n\n return NextResponse.json({\n success: true,\n runId,\n nextStep: nextStep ? {\n stepId: nextStep.id,\n projectName: nextStep.projectName,\n description: nextStep.description,\n command: formatCommand(nextStep.args),\n } : null,\n operationLogs: runState.operationLogs,\n feedbacks: runState.feedbacks,\n isComplete: nextStep === null,\n });\n }\n\n if (action === 'abort') {\n const runId = typeof body.runId === 'string' ? body.runId : '';\n const runState = getStepRun(runId);\n if (!runState) {\n return NextResponse.json({\n success: false,\n operationLogs: [],\n feedbacks: ['未找到执行上下文,请重新开始。'],\n }, { status: 404 });\n }\n\n runState.operationLogs.push('已收到中断请求,开始回滚已执行的本地操作。');\n await rollbackRun(runState);\n clearStepRun(runId);\n clearUatGitFlowState(runId);\n\n return NextResponse.json({\n success: true,\n runId,\n nextStep: null,\n operationLogs: runState.operationLogs,\n feedbacks: runState.feedbacks,\n isComplete: true,\n aborted: true,\n });\n }\n\n return NextResponse.json({\n success: false,\n operationLogs: [],\n feedbacks: ['未知操作类型。'],\n }, { status: 400 });\n } catch (error) {\n console.error('UAT git 分步执行失败:', error);\n return NextResponse.json({\n success: false,\n operationLogs: [],\n feedbacks: [error instanceof Error ? error.message : '执行失败'],\n }, { status: 500 });\n }\n}\n","import {\n AppRouteRouteModule,\n type AppRouteRouteModuleOptions,\n} from '../../server/route-modules/app-route/module.compiled'\nimport { RouteKind } from '../../server/route-kind'\nimport { patchFetch as _patchFetch } from '../../server/lib/patch-fetch'\n\nimport * as userland from 'VAR_USERLAND'\n\n// These are injected by the loader afterwards. This is injected as a variable\n// instead of a replacement because this could also be `undefined` instead of\n// an empty string.\ndeclare const nextConfigOutput: AppRouteRouteModuleOptions['nextConfigOutput']\n\n// We inject the nextConfigOutput here so that we can use them in the route\n// module.\n// INJECT:nextConfigOutput\n\nconst routeModule = new AppRouteRouteModule({\n definition: {\n kind: RouteKind.APP_ROUTE,\n page: 'VAR_DEFINITION_PAGE',\n pathname: 'VAR_DEFINITION_PATHNAME',\n filename: 'VAR_DEFINITION_FILENAME',\n bundlePath: 'VAR_DEFINITION_BUNDLE_PATH',\n },\n resolvedPagePath: 'VAR_RESOLVED_PAGE_PATH',\n nextConfigOutput,\n userland,\n})\n\n// Pull out the exports that we need to expose from the module. This should\n// be eliminated when we've moved the other routes to the new format. These\n// are used to hook into the route.\nconst { workAsyncStorage, workUnitAsyncStorage, serverHooks } = routeModule\n\nfunction patchFetch() {\n return _patchFetch({\n workAsyncStorage,\n workUnitAsyncStorage,\n })\n}\n\nexport {\n routeModule,\n workAsyncStorage,\n workUnitAsyncStorage,\n serverHooks,\n patchFetch,\n}\n"],"names":["AppRouteRouteModule","RouteKind","patchFetch","_patchFetch","userland","routeModule","definition","kind","APP_ROUTE","page","pathname","filename","bundlePath","resolvedPagePath","nextConfigOutput","workAsyncStorage","workUnitAsyncStorage","serverHooks"],"mappings":"kJA8DA,IAAM,EAAY,IAAI,IAGtB,SAAS,IACP,IAAM,EAAM,KAAK,GAAG,GACpB,IAAK,GAAM,CAAC,EAAO,EAAM,GAAI,EAAU,OAAO,GAAI,AAC5C,EAAM,EAAM,SAAS,CALP,EAKU,IAC1B,CANuB,CAMb,IANkB,EAMZ,CAAC,EADwB,AAI/C,CAEO,SAAS,EAAc,CAAe,EAC3C,IACA,EAAU,GAAG,CAAC,EAAM,KAAK,CAAE,CAAE,GAAG,CAAK,CAAE,UAAW,KAAK,GAAG,EAAG,EAC/D,CAEO,SAAS,EAAW,CAAa,EACtC,IACA,IAAM,EAAQ,EAAU,GAAG,CAAC,UAC5B,AAAK,GAAc,CAAf,GAAQ,AAEd,CAEO,SAAS,EAAc,CAAe,EAC3C,EAAU,GAAG,CAAC,EAAM,KAAK,CAAE,CAAE,GAAG,CAAK,CAAE,UAAW,KAAK,GAAG,EAAG,EAC/D,CAEO,SAAS,EAAa,CAAa,EACxC,EAAU,MAAM,CAAC,EACnB,oEC5FA,IAAA,EAAA,EAAA,CAAA,CAAA,OACA,EAAA,EAAA,CAAA,CAAA,OACA,EAAA,EAAA,CAAA,CAAA,OACA,EAAA,EAAA,CAAA,CAAA,OACA,EAAA,EAAA,CAAA,CAAA,OACA,EAAA,EAAA,CAAA,CAAA,OACA,EAAA,EAAA,CAAA,CAAA,OACA,EAAA,EAAA,CAAA,CAAA,OACA,EAAA,EAAA,CAAA,CAAA,OAgBA,IAAM,EAAqB,MAE3B,SAAS,EAAkB,CAAY,UACjC,CAAC,GACD,EAAmB,CADZ,GACgB,CAAC,GADV,CAEd,EAAK,CAD0B,OAAO,EACvB,CAAC,KAEtB,CAF4B,AAI5B,OAJmC,EAI1B,EAAc,CAAW,CAAE,CAAc,EAChD,OAAO,IAAI,QAAQ,CAAC,EAAS,KAC3B,IAAM,EAAQ,CAAA,EAAA,EAAA,KAAA,AAAI,EAAE,MAAO,EAAM,KAC/B,EACA,MAAO,CAAC,OAFI,EAEM,OAAQ,OAAO,AACnC,GAEI,EAAS,GACT,EAAS,GAEb,EAAM,MAAM,EAAE,GAAG,OAAQ,AAAC,IACxB,GAAU,EAAK,QAAQ,EACzB,GAEA,EAAM,MAAM,EAAE,GAAG,OAAQ,AAAC,IACxB,GAAU,EAAK,QAAQ,EACzB,GAEA,EAAM,EAAE,CAAC,QAAS,AAAC,IACjB,EAAQ,MAAE,SAAM,SAAQ,CAAO,EACjC,GAEA,EAAM,EAAE,CAAC,QAAU,AAAD,IAChB,EAAO,EACT,EACF,EACF,CAEA,SAAS,EAAc,CAAc,EACnC,MAAO,CAAC,IAAI,EAAE,EAAK,IAAI,CAAC,KAAA,CAAM,AAChC,CAMA,SAAS,EAAiB,CAAuB,CAAE,CAAmB,CAAE,CAAY,CAAE,CAAiB,EACjF,GAAG,CAAnB,EAAO,IAAI,CACb,EAAc,IAAI,CAAC,CAAC,CAAC,EAAE,EAAY,MAAM,EAAE,EAAA,CAAM,EAEjD,EAAc,IAAI,CAAC,CAAC,CAAC,EAAE,EAAY,MAAM,EAAE,EAAK,CAAC,EAAE,EAAO,MAAM,EAAI,EAAO,MAAM,CAAA,CAAE,CAEvF,CA6MA,SAAS,EAAkB,CAAa,EACtC,IAAK,IAAI,EAAI,EAAI,YAAY,CAAE,EAAI,EAAI,QAAQ,CAAC,MAAM,CAAE,GAAK,EAAG,CAC9D,IAAM,EAAU,EAAI,QAAQ,CAAC,EAAE,CAC/B,GAAuB,YAAnB,EAAQ,MAAM,CAAgB,CAChC,EAAI,YAAY,CAAG,EAAI,EACvB,QACF,CACA,IAAM,EAAO,AAjMjB,SAAS,AAAU,CAAa,CAAE,CAAwB,EACxD,GAAuB,AAAnB,cAAQ,MAAM,CAAgB,OAAO,KACzC,GAAM,cAAE,CAAY,YAAE,CAAU,CAAE,aAAW,CAAE,CAAG,EAElD,OAAQ,EAAQ,KAAK,EACnB,IAAK,sBACH,MAAO,CACL,GAAI,CAAA,EAAG,EAAQ,IAAI,CAAC,gBAAgB,EAAE,KAAK,GAAG,GAAA,CAAI,CAClD,YAAa,EAAQ,IAAI,CACzB,YAAa,SACb,KAAM,CAAC,SAAU,iBAAiB,CAClC,KAAM,qBACR,CACF,KAAK,aACH,MAAO,CACL,GAAI,CAAA,EAAG,EAAQ,IAAI,CAAC,OAAO,EAAE,KAAK,GAAG,GAAA,CAAI,CACzC,YAAa,EAAQ,IAAI,CACzB,YAAa,OACb,KAAM,CAAC,QAAS,SAAS,CACzB,KAAM,YACR,CACF,KAAK,kBACH,MAAO,CACL,GAAI,CAAA,EAAG,EAAQ,IAAI,CAAC,YAAY,EAAE,KAAK,GAAG,GAAA,CAAI,CAC9C,YAAa,EAAQ,IAAI,CACzB,YAAa,CAAC,UAAU,EAAE,EAAA,CAAY,CACtC,KAAM,CAAC,YAAa,UAAW,SAAU,EAAW,CACpD,KAAM,iBACR,CACF,KAAK,2BACH,MAAO,CACL,GAAI,CAAA,EAAG,EAAQ,IAAI,CAAC,qBAAqB,EAAE,KAAK,GAAG,GAAA,CAAI,CACvD,YAAa,EAAQ,IAAI,CACzB,YAAa,CAAC,OAAO,EAAE,EAAA,CAAc,CACrC,KAAM,CAAC,YAAa,UAAW,SAAU,EAAa,CACtD,KAAM,0BACR,CACF,KAAK,0BACH,MAAO,CACL,GAAI,CAAA,EAAG,EAAQ,IAAI,CAAC,oBAAoB,EAAE,KAAK,GAAG,GAAA,CAAI,CACtD,YAAa,EAAQ,IAAI,CACzB,YAAa,CAAC,OAAO,EAAE,EAAA,CAAc,CACrC,KAAM,CAAC,WAAY,WAAY,CAAC,WAAW,EAAE,EAAA,CAAc,CAAC,CAC5D,KAAM,yBACR,CACF,KAAK,8BACH,MAAO,CACL,GAAI,CAAA,EAAG,EAAQ,IAAI,CAAC,iBAAiB,EAAE,KAAK,GAAG,GAAA,CAAI,CACnD,YAAa,EAAQ,IAAI,CACzB,YAAa,CAAC,QAAQ,EAAE,EAAA,CAAc,CACtC,KAAM,CAAC,WAAY,KAAM,EAAc,CAAC,OAAO,EAAE,EAAA,CAAc,CAAC,CAChE,KAAM,6BACR,CACF,KAAK,qBACH,MAAO,CACL,GAAI,CAAA,EAAG,EAAQ,IAAI,CAAC,eAAe,EAAE,KAAK,GAAG,GAAA,CAAI,CACjD,YAAa,EAAQ,IAAI,CACzB,YAAa,CAAC,KAAK,EAAE,EAAA,CAAc,CACnC,KAAM,CAAC,WAAY,KAAM,EAAc,CAAC,OAAO,EAAE,EAAA,CAAY,CAAC,CAC9D,KAAM,oBACR,CACF,KAAK,mBACH,MAAO,CACL,GAAI,CAAA,EAAG,EAAQ,IAAI,CAAC,aAAa,EAAE,KAAK,GAAG,GAAA,CAAI,CAC/C,YAAa,EAAQ,IAAI,CACzB,YAAa,CAAC,KAAK,EAAE,EAAA,CAAc,CACnC,KAAM,CAAC,OAAQ,KAAM,SAAU,EAAa,CAC5C,KAAM,kBACR,CACF,KAAK,mBACH,MAAO,CACL,GAAI,CAAA,EAAG,EAAQ,IAAI,CAAC,aAAa,EAAE,KAAK,GAAG,GAAA,CAAI,CAC/C,YAAa,EAAQ,IAAI,CACzB,YAAa,CAAC,UAAU,EAAE,EAAA,CAAa,CACvC,KAAM,CAAC,YAAa,UAAW,SAAU,EAAY,CACrD,KAAM,kBACR,CACF,KAAK,cACH,MAAO,CACL,GAAI,CAAA,EAAG,EAAQ,IAAI,CAAC,QAAQ,EAAE,KAAK,GAAG,GAAA,CAAI,CAC1C,YAAa,EAAQ,IAAI,CACzB,YAAa,QACb,KAAM,CAAC,SAAU,cAAc,CAC/B,KAAM,aACR,CACF,KAAK,uBACH,MAAO,CACL,GAAI,CAAA,EAAG,EAAQ,IAAI,CAAC,iBAAiB,EAAE,KAAK,GAAG,GAAA,CAAI,CACnD,YAAa,EAAQ,IAAI,CACzB,YAAa,CAAC,MAAM,EAAE,EAAA,CAAc,CACpC,KAAM,CAAC,WAAY,EAAa,CAChC,KAAM,sBACR,CACF,KAAK,4BACH,MAAO,CACL,GAAI,CAAA,EAAG,EAAQ,IAAI,CAAC,sBAAsB,EAAE,KAAK,GAAG,GAAA,CAAI,CACxD,YAAa,EAAQ,IAAI,CACzB,YAAa,OACb,KAAM,CAAC,QAAS,SAAS,CACzB,KAAM,2BACR,CACF,KAAK,aACH,MAAO,CACL,GAAI,CAAA,EAAG,EAAQ,IAAI,CAAC,OAAO,EAAE,KAAK,GAAG,GAAA,CAAI,CACzC,YAAa,EAAQ,IAAI,CACzB,YAAa,CAAC,UAAU,EAAE,EAAA,CAAa,CACvC,KAAM,CAAC,QAAS,UAAW,YAAa,CAAC,OAAO,EAAE,EAAA,CAAa,CAAC,CAChE,KAAM,YACR,CACF,KAAK,mBACH,MAAO,CACL,GAAI,CAAA,EAAG,EAAQ,IAAI,CAAC,aAAa,EAAE,KAAK,GAAG,GAAA,CAAI,CAC/C,YAAa,EAAQ,IAAI,CACzB,YAAa,OACb,KAAM,CAAC,QAAS,UAAU,CAC1B,KAAM,kBACR,CACF,KAAK,kBACH,MAAO,CACL,GAAI,CAAA,EAAG,EAAQ,IAAI,CAAC,YAAY,EAAE,KAAK,GAAG,GAAA,CAAI,CAC9C,YAAa,EAAQ,IAAI,CACzB,YAAa,CAAC,OAAO,EAAE,EAAA,CAAc,CACrC,KAAM,CAAC,OAAQ,SAAU,EAAa,CACtC,KAAM,iBACR,CACF,KAAK,kBACH,MAAO,CACL,GAAI,CAAA,EAAG,EAAQ,IAAI,CAAC,YAAY,EAAE,KAAK,GAAG,GAAA,CAAI,CAC9C,YAAa,EAAQ,IAAI,CACzB,YAAa,OACb,KAAM,CAAC,QAAS,SAAS,CACzB,KAAM,iBACR,CACF,KAAK,kBACH,MAAO,CACL,GAAI,CAAA,EAAG,EAAQ,IAAI,CAAC,YAAY,EAAE,KAAK,GAAG,GAAA,CAAI,CAC9C,YAAa,EAAQ,IAAI,CACzB,YAAa,iBACb,KAAM,CAAC,YAAa,UAAW,SAAU,OAAO,CAChD,KAAM,iBACR,CACF,KAAK,mBACH,MAAO,CACL,GAAI,CAAA,EAAG,EAAQ,IAAI,CAAC,aAAa,EAAE,KAAK,GAAG,GAAA,CAAI,CAC/C,YAAa,EAAQ,IAAI,CACzB,YAAa,QACb,KAAM,CAAC,SAAU,cAAc,CAC/B,KAAM,kBACR,CACF,KAAK,qBACH,MAAO,CACL,GAAI,CAAA,EAAG,EAAQ,IAAI,CAAC,eAAe,EAAE,KAAK,GAAG,GAAA,CAAI,CACjD,YAAa,EAAQ,IAAI,CACzB,YAAa,WACb,KAAM,CAAC,WAAY,OAAO,CAC1B,KAAM,oBACR,CACF,KAAK,uBACH,MAAO,CACL,GAAI,CAAA,EAAG,EAAQ,IAAI,CAAC,iBAAiB,EAAE,KAAK,GAAG,GAAA,CAAI,CACnD,YAAa,EAAQ,IAAI,CACzB,YAAa,CAAC,UAAU,EAAE,EAAa,OAAO,CAAC,CAC/C,KAAM,CAAC,QAAS,UAAW,YAAa,CAAC,OAAO,EAAE,EAAA,CAAc,CAAC,CACjE,KAAM,sBACR,CACF,KAAK,6BACH,MAAO,CACL,GAAI,CAAA,EAAG,EAAQ,IAAI,CAAC,uBAAuB,EAAE,KAAK,GAAG,GAAA,CAAI,CACzD,YAAa,EAAQ,IAAI,CACzB,YAAa,aACb,KAAM,CAAC,QAAS,UAAU,CAC1B,KAAM,4BACR,CACF,KAAK,iBACH,MAAO,CACL,GAAI,CAAA,EAAG,EAAQ,IAAI,CAAC,WAAW,EAAE,KAAK,GAAG,GAAA,CAAI,CAC7C,YAAa,EAAQ,IAAI,CACzB,YAAa,UACb,KAAM,CAAC,OAAQ,SAAU,OAAO,CAChC,KAAM,gBACR,CACF,SACE,OAAO,IACX,CACF,EAS2B,EAAK,GAC5B,GAAI,EAGF,IAHQ,GACR,EAAI,YAAY,CAAG,EACnB,EAAI,WAAW,CAAG,EACX,EAET,EAAI,YAAY,CAAG,EAAI,CACzB,CAEA,OADA,EAAI,WAAW,CAAG,KACX,IACT,CAEA,eAAe,EAAY,CAAa,EACtC,GAAM,cAAE,CAAY,CAAE,CAAG,EACzB,IAAK,IAAM,IAAW,IAAI,EAAI,QAAQ,CAAC,CAAC,OAAO,GAAI,CACjD,GAAI,CAAC,EAAQ,cAAc,CAAE,SAC7B,EAAI,aAAa,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAQ,IAAI,CAAC,MAAM,EAAE,EAAc,CAAC,WAAY,EAAQ,cAAc,CAAC,EAAA,CAAG,EACrG,IAAM,EAAmB,MAAM,EAAc,EAAQ,IAAI,CAAE,CAAC,WAAY,EAAQ,cAAc,CAAC,EAG/F,GAFA,EAAiB,EAAI,aAAa,CAAE,EAAQ,IAAI,CAAE,CAAC,OAAO,EAAE,EAAQ,cAAc,CAAA,CAAE,CAAE,GAElF,EAAQ,kBAAkB,EAAI,CAAC,EAAQ,cAAc,CAAE,CACzD,EAAI,aAAa,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAQ,IAAI,CAAC,MAAM,EAAE,EAAc,CAAC,SAAU,KAAM,EAAa,EAAA,CAAG,EAC/F,IAAM,EAAiB,MAAM,EAAc,EAAQ,IAAI,CAAE,CAAC,SAAU,KAAM,EAAa,EACvF,EAAiB,EAAI,aAAa,CAAE,EAAQ,IAAI,CAAE,CAAC,SAAS,EAAE,EAAA,CAAc,CAAE,EAChF,CACF,CACF,CAEA,eAAe,EAAY,CAAa,CAAE,CAAoB,EAC5D,IAAM,EAAU,EAAI,QAAQ,CAAC,IAAI,CAAC,GAAQ,EAAK,IAAI,GAAK,EAAK,WAAW,EACxE,GAAI,CAAC,EAAS,YACZ,EAAI,SAAS,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAK,WAAW,CAAC,WAAW,CAAC,EAItD,EAAI,aAAa,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAQ,IAAI,CAAC,EAAE,EAAE,EAAc,EAAK,IAAI,EAAA,CAAG,EACtE,IAAM,EAAS,MAAM,EAAc,EAAQ,IAAI,CAAE,EAAK,IAAI,EAG1D,OAFA,EAAiB,EAAI,aAAa,CAAE,EAAQ,IAAI,CAAE,EAAK,WAAW,CAAE,GAE5D,EAAK,IAAI,EACf,IAAK,sBACH,EAAQ,cAAc,CAtQnB,AAsQsB,AAAiB,EAAO,MAAM,CAtQ9C,OAAO,CAAC,OAAQ,KAAK,IAAI,IAsQ0B,OACxC,GAAG,CAAnB,EAAO,IAAI,CACb,EAAQ,KAAK,CAAG,cAEhB,EAAQ,MAAM,CAAG,SACjB,EAAI,SAAS,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAQ,IAAI,CAAC,WAAW,CAAC,GAElD,KAEF,KAAK,aACiB,GAAG,CAAnB,EAAO,IAAI,CACb,EAAQ,KAAK,CAAG,mBAEhB,EAAQ,MAAM,CAAG,SACjB,EAAI,SAAS,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAQ,IAAI,CAAC,UAAU,EAAE,EAAO,MAAM,EAAI,EAAO,MAAM,CAAA,CAAE,GAElF,KAEF,KAAK,kBACH,EAAQ,UAAU,EAAG,CAAQ,EAAO,MAAM,CAAC,IAAI,GAC1C,EAAQ,UAAU,CAIrB,CAJuB,CAIf,KAAK,CAAG,4BAHhB,EAAQ,MAAM,CAAG,SACjB,EAAI,SAAS,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAQ,IAAI,CAAC,SAAS,EAAE,EAAI,UAAU,CAAC,YAAY,CAAC,GAI7E,KAEF,KAAK,2BACH,EAAQ,kBAAkB,EAAG,CAAQ,EAAO,MAAM,CAAC,IAAI,GACvD,EAAQ,KAAK,CAAG,0BAChB,KAEF,KAAK,0BACH,EAAQ,iBAAiB,CAAmB,IAAhB,EAAO,IAAI,CACnC,EAAQ,iBAAiB,CAC3B,CAD6B,CACrB,KAAK,CAAG,uBACP,EAAQ,kBAAkB,EAAE,AACrC,EAAQ,cAAc,EAAG,EACzB,EAAQ,KAAK,CAAG,gCAEhB,EAAQ,cAAc,EAAG,EACzB,EAAQ,KAAK,CAAG,sBAElB,KAEF,KAAK,8BACC,AAAgB,GAAG,GAAZ,IAAI,CACb,EAAQ,KAAK,CAAG,oBAEhB,EAAQ,MAAM,CAAG,SACjB,EAAI,SAAS,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAQ,IAAI,CAAC,aAAa,EAAE,EAAO,MAAM,EAAI,EAAO,MAAM,CAAA,CAAE,GAErF,KAEF,KAAK,qBACC,AAAgB,GAAG,GAAZ,IAAI,EACb,EAAQ,kBAAkB,EAAG,EAC7B,EAAQ,KAAK,CAAG,qBAEhB,EAAQ,MAAM,CAAG,SACjB,EAAI,SAAS,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAQ,IAAI,CAAC,UAAU,EAAE,EAAO,MAAM,EAAI,EAAO,MAAM,CAAA,CAAE,GAElF,KAEF,KAAK,mBACC,AAAgB,GAAG,GAAZ,IAAI,CACb,EAAQ,KAAK,CAAG,oBAEhB,EAAQ,MAAM,CAAG,SACjB,EAAI,SAAS,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAQ,IAAI,CAAC,WAAW,EAAE,EAAO,MAAM,EAAI,EAAO,MAAM,CAAA,CAAE,GAEnF,KAEF,KAAK,mBACH,EAAQ,WAAW,CAAG,EAAQ,EAAO,MAAM,CAAC,IAAI,GAC3C,EAAQ,WAAW,CAItB,CAJwB,CAIhB,KAAK,CAAG,eAHhB,EAAQ,MAAM,CAAG,SACjB,EAAI,SAAS,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAQ,IAAI,CAAC,SAAS,EAAE,EAAI,WAAW,CAAC,UAAU,CAAC,GAI5E,KAEF,KAAK,cACH,EAAQ,WAAW,CAAmC,IAAhC,EAAO,MAAM,CAAC,IAAI,GAAG,MAAM,CAC5C,EAAQ,WAAW,CAItB,CAJwB,CAIhB,KAAK,CAAG,wBAHhB,EAAQ,MAAM,CAAG,SACjB,EAAI,SAAS,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAQ,IAAI,CAAC,uBAAuB,CAAC,GAI9D,KAEF,KAAK,uBACiB,GAAG,CAAnB,EAAO,IAAI,CACb,EAAQ,KAAK,CAAG,6BAEhB,EAAQ,MAAM,CAAG,SACjB,EAAI,SAAS,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAQ,IAAI,CAAC,WAAW,EAAE,EAAO,MAAM,EAAI,EAAO,MAAM,CAAA,CAAE,GAEnF,KAEF,KAAK,4BACiB,GAAG,CAAnB,EAAO,IAAI,CACb,EAAQ,KAAK,CAAG,cAEhB,EAAQ,MAAM,CAAG,SACjB,EAAI,SAAS,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAQ,IAAI,CAAC,UAAU,EAAE,EAAO,MAAM,EAAI,EAAO,MAAM,CAAA,CAAE,GAElF,KAEF,KAAK,aACiB,GAAG,CAAnB,EAAO,IAAI,CACb,EAAQ,KAAK,CAAG,mBAEhB,EAAQ,KAAK,CAAG,mBAChB,EAAI,SAAS,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAQ,IAAI,CAAC,cAAc,CAAC,GAErD,KAEF,KAAK,mBACC,AAAgB,GAAG,GAAZ,IAAI,EACb,EAAI,SAAS,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAQ,IAAI,CAAC,UAAU,EAAE,EAAO,MAAM,EAAI,EAAO,MAAM,CAAA,CAAE,EAElF,EAAQ,MAAM,CAAG,SACjB,EAAI,SAAS,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAQ,IAAI,CAAC,mBAAmB,CAAC,EACxD,KAEF,KAAK,kBACC,AAAgB,GAAG,GAAZ,IAAI,CACb,EAAQ,KAAK,CAAG,mBAEhB,EAAQ,MAAM,CAAG,SACjB,EAAI,SAAS,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAQ,IAAI,CAAC,YAAY,EAAE,EAAO,MAAM,EAAI,EAAO,MAAM,CAAA,CAAE,GAEpF,KAEF,KAAK,kBACC,AAAgB,GAAG,GAAZ,IAAI,CACb,EAAQ,KAAK,CAAG,mBAEhB,EAAQ,MAAM,CAAG,SACjB,EAAI,SAAS,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAQ,IAAI,CAAC,UAAU,EAAE,EAAO,MAAM,EAAI,EAAO,MAAM,CAAA,CAAE,GAElF,KAEF,KAAK,kBACwB,EAAO,MAAM,CAAC,IAAI,GAK3C,EAAQ,KAAK,CAAG,oBAHhB,EAAQ,MAAM,CAAG,SACjB,EAAI,SAAS,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAQ,IAAI,CAAC,uBAAuB,CAAC,GAI9D,KAEF,KAAK,mBACiB,AAAgC,MAAzB,MAAM,CAAC,IAAI,GAAG,MAAM,CAK7C,EAAQ,KAAK,CAAG,sBAHhB,EAAQ,MAAM,CAAG,SACjB,EAAI,SAAS,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAQ,IAAI,CAAC,0BAA0B,CAAC,GAIjE,KAEF,KAAK,qBACC,AAAgB,GAAG,GAAZ,IAAI,CACb,EAAQ,KAAK,CAAG,wBAEhB,EAAQ,MAAM,CAAG,SACjB,EAAI,SAAS,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAQ,IAAI,CAAC,eAAe,EAAE,EAAO,MAAM,EAAI,EAAO,MAAM,CAAA,CAAE,GAEvF,KAEF,KAAK,uBACiB,GAAG,CAAnB,EAAO,IAAI,CACb,EAAQ,KAAK,CAAG,kBAEhB,EAAQ,KAAK,CAAG,6BAChB,EAAI,SAAS,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAQ,IAAI,CAAC,qBAAqB,CAAC,GAE5D,KAEF,KAAK,6BACiB,GAAG,CAAnB,EAAO,IAAI,EACb,EAAI,SAAS,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAQ,IAAI,CAAC,iBAAiB,EAAE,EAAO,MAAM,EAAI,EAAO,MAAM,CAAA,CAAE,EAEzF,EAAQ,MAAM,CAAG,SACjB,EAAI,SAAS,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAQ,IAAI,CAAC,0BAA0B,CAAC,EAC/D,KAEF,KAAK,iBACiB,GAAG,CAAnB,EAAO,IAAI,EACb,EAAQ,MAAM,CAAG,OACjB,EAAQ,KAAK,CAAG,SAEhB,EAAQ,MAAM,CAAG,SACjB,EAAI,SAAS,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAQ,IAAI,CAAC,cAAc,EAAE,EAAO,MAAM,EAAI,EAAO,MAAM,CAAA,CAAE,EAM1F,CACF,CAEO,eAAe,EAAK,CAAoB,EAC7C,GAAI,CACF,IAAM,EAAO,MAAM,EAAQ,IAAI,GACzB,EAAgC,UAAvB,OAAO,EAAK,MAAM,CAAgB,EAAK,MAAM,CAAG,GAE/D,GAAe,UAAX,EAAoB,CACtB,IAAM,EAAW,MAAM,OAAO,CAAC,EAAK,QAAQ,EAAI,EAAK,QAAQ,CAAG,EAAE,CAC5D,EAAe,AAA6B,iBAAtB,EAAK,YAAY,CAAgB,EAAK,YAAY,CAAC,IAAI,GAAK,GAClF,EAAwC,UAA3B,OAAO,EAAK,UAAU,CAAgB,EAAK,UAAU,CAAC,IAAI,GAAK,GAC5E,EAA0C,UAA5B,OAAO,EAAK,WAAW,CAAgB,EAAK,WAAW,CAAC,IAAI,GAAK,GAC/E,EAA8B,UAAtB,OAAO,EAAK,KAAK,CAAgB,EAAK,KAAK,CAAG,GAEtD,EAA0B,EAAE,CAC5B,EAAsB,EAAE,CAE9B,GAAwB,IAApB,EAAS,MAAM,EAAU,CAAC,GAAgB,CAAC,GAAc,CAAC,EAC5D,OAAO,EAAA,EADkE,UACtD,CAAC,IAAI,CAAC,CACvB,SAAS,EACT,MAFK,UAGL,UAAW,CAAC,mBACd,AADiC,EAC9B,CAAE,OAAQ,GAAI,GAGnB,GAAI,CAAC,EAAkB,IAAiB,CAAC,EAAkB,IAAe,CAAC,EAAkB,GAC3F,OAAO,EAAA,EADkG,UACtF,CAAC,IAAI,CAAC,CACvB,SAAS,QADJ,QAEL,EACA,UAAW,CAAC,wBAAwB,AACtC,EAAG,CAAE,OAAQ,GAAI,GAGnB,GAAI,CAAC,EACH,KADU,EACH,EAAA,YAAY,CAAC,IAAI,CAAC,CACvB,SAAS,QADJ,QAEL,EACA,UAAW,CAAC,qBAAqB,AACnC,EAAG,CAAE,OAAQ,GAAI,GAGnB,CAAA,EAAA,EAAA,qBAAA,AAAoB,EAAE,GACtB,IAAM,EAAiB,IADvB,EAC6B,CAAA,EAAA,EAAA,iBAAA,AAAgB,IACvC,EAAgB,EAAA,WADO,KACS,CAAC,cAAc,CAC/C,EAAiC,EADjB,AACmB,CAEzC,IAAK,IAAM,KAAkB,EAAU,CACrC,IAAM,EAAe,OAAO,GACtB,EAAc,CAAA,EAAA,EAAA,mBAAA,AAAkB,EAAE,GAExC,GAAI,CAAC,GAAe,IAAgB,CAFhB,CAE8B,CAChD,EAAc,IAAI,CAAC,CAAC,CAAC,EAAE,EAAa,gBAAgB,CAAC,EACrD,EAAU,IAAI,CAAC,CAAC,CAAC,EAAE,EAAa,iBAAiB,CAAC,EAClD,QACF,CAEA,GAAI,CAAC,CAAc,CAAC,EAAY,CAAE,CAChC,EAAc,IAAI,CAAC,CAAC,CAAC,EAAE,EAAY,eAAe,CAAC,EACnD,EAAU,IAAI,CAAC,CAAC,CAAC,EAAE,EAAY,gBAAgB,CAAC,EAChD,QACF,CAEA,IAAM,EAAc,CAAA,EAAA,EAAA,IAAA,AAAG,EAAE,EAAe,GACxC,GAAI,CAAC,CAAA,EAAA,EAAA,UAAA,AAAS,EAAE,GAAc,CADV,AAElB,EAAc,IAAI,CAAC,CAAC,CAAC,EAAE,EAAY,OADhC,MAC6C,CAAC,EACjD,EAAU,IAAI,CAAC,CAAC,CAAC,EAAE,EAAY,cAAc,CAAC,EAC9C,QACF,CAEA,GAAI,CAAC,CAAA,EAAA,EAAA,UAAA,AAAS,EAAE,CAAA,EAAA,EAAA,IAAA,AAAG,EAAE,EAAa,SAAU,CAC1C,CADG,CACW,IAAI,CAAC,CAAC,CAAC,EAAE,EAAY,KADrB,SACmC,CAAC,EAClD,EAAU,IAAI,CAAC,CAAC,CAAC,EAAE,EAAY,mBAAmB,CAAC,EACnD,QACF,CAEA,EAAY,IAAI,CAnhBf,AAmhBgB,CAlhBrB,KAkhByC,CAlhBnC,CACN,KAihBsD,CAjhBhD,CACN,MAAO,sBACP,OAAQ,UACR,eAAgB,GAChB,oBAAoB,EACpB,gBAAgB,EAChB,WAAY,KACZ,mBAAoB,KACpB,kBAAmB,KACnB,YAAa,KACb,YAAa,IACf,EAugBI,CAEA,IAAM,EAAqB,OACzB,EACA,eACA,yBACA,EACA,SAAU,EACV,aAAc,gBACd,YACA,EACA,YAAa,KACb,UAAW,KAAK,GAAG,EACrB,EAEM,EAAW,EAAkB,GAGnC,MAFA,CAAA,EAAA,EAAA,aAAA,AAAY,EAAE,GAEP,EAAA,YAAY,CAAC,GAFpB,CAEwB,CAAC,CACvB,SAAS,QADJ,AAEL,EACA,SAAU,EAAW,CACnB,OAAQ,EAAS,EAAE,CACnB,YAAa,EAAS,WAAW,CACjC,YAAa,EAAS,WAAW,CACjC,QAAS,EAAc,EAAS,IAAI,CACtC,EAAI,KACJ,cAAe,EAAS,aAAa,CACrC,UAAW,EAAS,SAAS,CAC7B,WAAyB,OAAb,CACd,EACF,CAEA,GAAe,YAAX,EAAsB,CACxB,IAAM,EAA8B,UAAtB,OAAO,EAAK,KAAK,CAAgB,EAAK,KAAK,CAAG,GACtD,EAAgC,UAAvB,OAAO,EAAK,MAAM,CAAgB,EAAK,MAAM,CAAG,GAEzD,EAAW,CAAA,EAAA,EAAA,UAAA,AAAS,EAAE,GAC5B,GAAI,CAAC,EACH,OAAO,CADM,CACN,MAFQ,MAEI,CAAC,IAAI,CAAC,CACvB,SAAS,EACT,MAFK,QAEU,EAAE,CACjB,UAAW,CAAC,kBACd,AADgC,EAC7B,CAAE,OAAQ,GAAI,GAGnB,GAAI,CAAA,EAAA,EAAA,mBAAA,AAAkB,EAAE,GAKtB,KAL8B,EAC9B,EAAS,GADP,UACoB,CAAC,IAAI,CAAC,yBAC5B,MAAM,EAAY,GAClB,CAAA,EAAA,EAAA,YAAA,AAAW,EAAE,GACb,CAAA,EAAA,EAAA,cADA,MACA,AAAmB,EAAE,GACd,EAAA,SADP,GACmB,CAAC,IAAI,CAAC,CACvB,SAAS,QACT,AAFK,EAGL,SAAU,KACV,cAAe,EAAS,aAAa,CACrC,UAAW,EAAS,SAAS,CAC7B,YAAY,EACZ,SAAS,CACX,GAGF,GAAI,CAAC,EAAS,WAAW,EAAI,EAAS,WAAW,CAAC,EAAE,GAAK,EACvD,MAD+D,CACxD,EAAA,YAAY,CAAC,IAAI,CAAC,CACvB,SAAS,EACT,MAFK,QAEU,EAAS,aAAa,CACrC,UAAW,CAAC,eAAe,AAC7B,EAAG,CAAE,OAAQ,GAAI,EAGnB,OAAM,EAAY,EAAU,EAAS,WAAW,EAEhD,IAAM,EAAW,EAAkB,GAQnC,MAPA,CAAA,EAAA,EAAA,aAAA,AAAY,EAAE,GAET,IACH,CAAA,EAAA,EAAA,CADa,QAFf,GAGa,AAAX,EAAa,GACb,CAAA,EAAA,EAAA,cADA,MACA,AAAmB,EAAE,IAGhB,EAAA,QAHL,IAGiB,CAAC,IAAI,CAAC,CACvB,SAAS,QADJ,AAEL,EACA,SAAU,EAAW,CACnB,OAAQ,EAAS,EAAE,CACnB,YAAa,EAAS,WAAW,CACjC,YAAa,EAAS,WAAW,CACjC,QAAS,EAAc,EAAS,IAAI,CACtC,EAAI,KACJ,cAAe,EAAS,aAAa,CACrC,UAAW,EAAS,SAAS,CAC7B,WAAyB,OAAb,CACd,EACF,CAEA,GAAe,UAAX,EAAoB,CACtB,IAAM,EAA8B,UAAtB,OAAO,EAAK,KAAK,CAAgB,EAAK,KAAK,CAAG,GACtD,EAAW,CAAA,EAAA,EAAA,UAAS,AAAT,EAAW,GAC5B,GAAI,CAAC,EACH,OAAO,CADM,CACN,MAFQ,MAEI,CAAC,IAAI,CAAC,CACvB,SAAS,EACT,MAFK,QAEU,EAAE,CACjB,UAAW,CAAC,kBACd,AADgC,EAC7B,CAAE,OAAQ,GAAI,GAQnB,OALA,EAAS,aAAa,CAAC,IAAI,CAAC,yBAC5B,MAAM,EAAY,GAClB,CAAA,EAAA,EAAA,YAAA,AAAW,EAAE,GACb,GAAA,EAAA,cADA,MACA,AAAmB,EAAE,GAEd,EAAA,SAFP,GAEmB,CAAC,IAAI,CAAC,CACvB,SAAS,QACT,AAFK,EAGL,SAAU,KACV,cAAe,EAAS,aAAa,CACrC,UAAW,EAAS,SAAS,CAC7B,YAAY,EACZ,QAAS,EACX,EACF,CAEA,OAAO,EAAA,YAAY,CAAC,IAAI,CAAC,CACvB,SAAS,EACT,MAFK,QAEU,EAAE,CACjB,UAAW,CAAC,UAAU,AACxB,EAAG,CAAE,OAAQ,GAAI,EACnB,CAAE,MAAO,EAAO,CAEd,OADA,QAAQ,KAAK,CAAC,kBAAmB,GAC1B,EAAA,YAAY,CAAC,IAAI,CAAC,CACvB,SAAS,EACT,MAFK,QAEU,EAAE,CACjB,UAAW,CAAC,aAAiB,MAAQ,EAAM,OAAO,CAAG,OAAO,AAC9D,EAAG,CAAE,OAAQ,GAAI,EACnB,CACF,gKCzuBA,IAAA,EAGO,EAAA,CAFLA,AAEK,CAAA,OACP,EAA0B,EAAyB,CAA1CC,AAA0C,CAAA,GAAA,EAH9B,EAIrB,CADkB,CAD2C,AAEnB,EAAA,CAAjCC,AAAiC,CAFnC,AAEmC,GADhB,CAC8C,GAExE,EAAwC,EAAA,CAAA,CAFjBC,AAEiB,EAA5BC,IAWZ,IAAMC,CAb4B,CAad,IAXM,AAWN,EAAIL,CAbkB,YAEF,MAWhBA,CAAoB,CAC1CM,WAAY,CACVC,KAAMN,EAAAA,SAAAA,CAAUO,SAAS,CACzBC,KAAM,+BACNC,SAAU,yBACVC,SAAU,QACVC,WAAY,EACd,EACAC,iBAAkB,mEAClBC,iBAXF,CAA0B,WAYxBV,CACF,GAKM,CAAEW,kBAAgB,sBAAEC,CAAoB,aAAEC,CAAW,CAAE,CAAGZ,EAEhE,SAASH,IACP,MAAA,CAAA,EAAA,EAAOC,UAAAA,EAAY,kBACjBY,uBACAC,CACF,EACF","ignoreList":[2]}
@@ -0,0 +1,3 @@
1
+ module.exports={32970:t=>{"use strict";var{g:e,__dirname:i}=t;{t.s({POST:()=>d});var a=t.i(15494),o=t.i(87485),r=t.i(83886),n=t.i(30331),s=t.i(88941),u=t.i(35692),c=t.i(77159),h=t.i(79810);let e=/\\s/;function $(t){return!(!t||e.test(t)||t.startsWith("-"))}function p(t,e){return new Promise((i,a)=>{let r=(0,o.spawn)("git",e,{cwd:t,stdio:["ignore","pipe","pipe"]}),n="",s="";r.stdout?.on("data",t=>{n+=t.toString()}),r.stderr?.on("data",t=>{s+=t.toString()}),r.on("close",t=>{i({code:t,stdout:n,stderr:s})}),r.on("error",t=>{a(t)})})}function l(t){return`git ${t.join(" ")}`}function g(t,e,i,a){0===a.code?t.push(`[${e}] 完成: ${i}`):t.push(`[${e}] 失败: ${i} ${a.stderr||a.stdout}`)}async function d(t){let e="";try{let i=await t.json(),o=Array.isArray(i.projects)?i.projects:[],d="string"==typeof i.createBranch?i.createBranch.trim():"",f="string"==typeof i.baseBranch?i.baseBranch.trim():"",m="string"==typeof i.mergeBranch?i.mergeBranch.trim():"",w=!!i.dryRun,B="string"==typeof i.runId?i.runId:"",k=[],b=[],y=[],j=new Map,A=(t,e,i,a)=>{j.has(t)||(j.set(t,{success:e,reason:i,rollbackActions:a}),y.push({projectName:t,success:e,reason:i,rollbackActions:a}))},R=async(t,e,i)=>{let a=[];if(i.originalBranch&&"HEAD"!==i.originalBranch){let o=l(["checkout",i.originalBranch]);k.push(`[${t}] 回滚: ${o}`);let r=await p(e,["checkout",i.originalBranch]);g(k,t,`回滚切换分支 ${i.originalBranch}`,r),a.push(o)}if(i.createdLocalBranch&&!i.hadLocalBranch){let i=l(["branch","-D",d]);k.push(`[${t}] 回滚: ${i}`);let o=await p(e,["branch","-D",d]);g(k,t,`回滚删除本地分支 ${d}`,o),a.push(i)}return a};if(0===o.length||!d||!f||!m)return a.NextResponse.json({success:!1,operationLogs:k,feedbacks:["缺少必要参数,请填写完整后重试。"]},{status:400});if(!$(d)||!$(f)||!$(m))return a.NextResponse.json({success:!1,operationLogs:k,feedbacks:["分支名称不合法,请避免空格或以 - 开头。"]},{status:400});if(!B)return a.NextResponse.json({success:!1,operationLogs:k,feedbacks:["缺少 runId,请刷新页面后重试。"]},{status:400});(0,h.createUatGitFlowState)(B),e=B;let S=await (0,u.getProjectsConfig)(),v=s.WORKSPACE_CONFIG.WORKSPACE_ROOT,P=[],x=()=>(0,h.isUatGitFlowAborted)(B);for(let t of o){if(x()){b.push("已收到中断请求,开始回滚已执行的本地操作。");break}let e=String(t),i=(0,c.sanitizeProjectName)(e);if(!i||i!==e){k.push(`[${e}] 失败: 项目名称包含无效字符`),b.push(`[${e}] 项目名称包含无效字符,已跳过。`),A(e,!1,"项目名称包含无效字符");continue}if(!S[i]){k.push(`[${i}] 失败: 未在项目配置中找到`),b.push(`[${i}] 未在项目配置中找到,已跳过。`),A(i,!1,"未在项目配置中找到");continue}let a=(0,n.join)(v,i);if(!(0,r.existsSync)(a)){k.push(`[${i}] 失败: 项目目录不存在`),b.push(`[${i}] 项目目录不存在,已跳过。`),A(i,!1,"项目目录不存在");continue}if(!(0,r.existsSync)((0,n.join)(a,".git"))){k.push(`[${i}] 失败: 非 Git 仓库`),b.push(`[${i}] 不是有效的 Git 仓库,已跳过。`),A(i,!1,"不是有效的 Git 仓库");continue}if(w){k.push(`[${i}] ${l(["fetch","origin"])}`),k.push(`[${i}] ${l(["ls-remote","--heads","origin",f])}`),k.push(`[${i}] ${l(["ls-remote","--heads","origin",d])}`),k.push(`[${i}] ${l(["show-ref","--verify",`refs/heads/${d}`])}`),k.push(`[${i}] ${l(["checkout","-B",d,`origin/${f}`])}`),k.push(`[${i}] ${l(["push","-u","origin",d])}`),k.push(`[${i}] ${l(["ls-remote","--heads","origin",m])}`),k.push(`[${i}] ${l(["status","--porcelain"])}`),k.push(`[${i}] ${l(["checkout",d])}`),k.push(`[${i}] ${l(["merge","--no-ff","--no-edit",`origin/${m}`])}`),k.push(`[${i}] ${l(["push","origin",d])}`),k.push(`[${i}] ${l(["checkout","main"])}`),k.push(`[${i}] ${l(["fetch","origin"])}`),k.push(`[${i}] ${l(["ls-remote","--heads","origin","main"])}`),k.push(`[${i}] ${l(["status","--porcelain"])}`),k.push(`[${i}] ${l(["merge","--no-ff","--no-edit",`origin/${d}`])}`),k.push(`[${i}] ${l(["push","origin","main"])}`);continue}k.push(`[${i}] 检查当前分支`);let o=await p(a,["branch","--show-current"]);g(k,i,"当前分支检查",o);let s={originalBranch:o.stdout.replace(/\s+/g," ").trim()||"HEAD",createdLocalBranch:!1,hadLocalBranch:!0};k.push(`[${i}] ${l(["fetch","origin"])}`);let u=await p(a,["fetch","origin"]);if(g(k,i,"拉取远端",u),0!==u.code){b.push(`[${i}] 拉取远端失败: ${u.stderr||u.stdout}`);let t=await R(i,a,s);A(i,!1,"拉取远端失败",t);continue}k.push(`[${i}] ${l(["ls-remote","--heads","origin",f])}`);let h=await p(a,["ls-remote","--heads","origin",f]);if(g(k,i,`检查 origin/${f}`,h),!h.stdout.trim()){b.push(`[${i}] origin/${f} 不存在,无法创建分支。`);let t=await R(i,a,s);A(i,!1,`origin/${f} 不存在`,t);continue}k.push(`[${i}] ${l(["ls-remote","--heads","origin",d])}`);let $=await p(a,["ls-remote","--heads","origin",d]);g(k,i,`检查远端分支 ${d}`,$),k.push(`[${i}] ${l(["show-ref","--verify",`refs/heads/${d}`])}`);let B=await p(a,["show-ref","--verify",`refs/heads/${d}`]);if(g(k,i,`检查本地分支 ${d}`,B),0===B.code){k.push(`[${i}] ${l(["checkout",d])}`);let t=await p(a,["checkout",d]);if(g(k,i,`切换到本地分支 ${d}`,t),0!==t.code){b.push(`[${i}] 切换到本地分支失败: ${t.stderr||t.stdout}`);let e=await R(i,a,s);A(i,!1,"切换到本地分支失败",e);continue}k.push(`[${i}] ${l(["fetch","origin"])}`);let e=await p(a,["fetch","origin"]);if(g(k,i,"拉取远端",e),0!==e.code){b.push(`[${i}] 拉取远端失败: ${e.stderr||e.stdout}`);let t=await R(i,a,s);A(i,!1,"拉取远端失败",t);continue}}else if(s.hadLocalBranch=!1,$.stdout.trim()){k.push(`[${i}] ${l(["checkout","-B",d,`origin/${d}`])}`);let t=await p(a,["checkout","-B",d,`origin/${d}`]);if(g(k,i,`切换到远端分支 ${d}`,t),0!==t.code){b.push(`[${i}] 切换到已有远端分支失败: ${t.stderr||t.stdout}`);let e=await R(i,a,s);A(i,!1,"切换到已有远端分支失败",e);continue}}else{k.push(`[${i}] ${l(["checkout","-B",d,`origin/${f}`])}`);let t=await p(a,["checkout","-B",d,`origin/${f}`]);if(g(k,i,`创建分支 ${d}`,t),0!==t.code){b.push(`[${i}] 创建分支失败: ${t.stderr||t.stdout}`);let e=await R(i,a,s);A(i,!1,"创建分支失败",e);continue}s.createdLocalBranch=!0,k.push(`[${i}] ${l(["push","-u","origin",d])}`);let e=await p(a,["push","-u","origin",d]);if(g(k,i,`推送分支 ${d}`,e),0!==e.code){b.push(`[${i}] 推送新分支失败: ${e.stderr||e.stdout}`);let t=await R(i,a,s);A(i,!1,"推送新分支失败",t);continue}}k.push(`[${i}] ${l(["ls-remote","--heads","origin",m])}`);let y=await p(a,["ls-remote","--heads","origin",m]);if(g(k,i,`检查 origin/${m}`,y),!y.stdout.trim()){b.push(`[${i}] origin/${m} 不存在,无法合并。`);let t=await R(i,a,s);A(i,!1,`origin/${m} 不存在`,t);continue}if(P.push({name:i,info:s}),x()){b.push("已收到中断请求,开始回滚已执行的本地操作。");break}k.push(`[${i}] ${l(["status","--porcelain"])}`);let j=await p(a,["status","--porcelain"]);if(g(k,i,"检查工作区",j),j.stdout.trim()){b.push(`[${i}] 工作区有未提交改动,请先处理后再执行合并。`);let t=await R(i,a,s);A(i,!1,"工作区有未提交改动",t);continue}k.push(`[${i}] ${l(["checkout",d])}`);let L=await p(a,["checkout",d]);if(g(k,i,`切换到分支 ${d}`,L),0!==L.code){b.push(`[${i}] 切换到分支失败: ${L.stderr||L.stdout}`);let t=await R(i,a,s);A(i,!1,"切换到分支失败",t);continue}k.push(`[${i}] ${l(["merge","--no-ff","--no-edit",`origin/${m}`])}`);let G=await p(a,["merge","--no-ff","--no-edit",`origin/${m}`]);if(g(k,i,`合并 origin/${m}`,G),0!==G.code){k.push(`[${i}] ${l(["merge","--abort"])}`);let t=await p(a,["merge","--abort"]);g(k,i,"终止合并",t),b.push(`[${i}] 合并冲突,已终止合并,请手动处理。`);let e=await R(i,a,s);A(i,!1,"合并冲突",e);continue}k.push(`[${i}] ${l(["push","origin",d])}`);let O=await p(a,["push","origin",d]);if(g(k,i,`推送合并结果 ${d}`,O),0!==O.code){b.push(`[${i}] 推送合并结果失败: ${O.stderr||O.stdout}`);let t=await R(i,a,s);A(i,!1,"推送合并结果失败",t);continue}k.push(`[${i}] ${l(["fetch","origin"])}`);let D=await p(a,["fetch","origin"]);if(g(k,i,"拉取远端",D),0!==D.code){b.push(`[${i}] 拉取远端失败: ${D.stderr||D.stdout}`);let t=await R(i,a,s);A(i,!1,"拉取远端失败",t);continue}k.push(`[${i}] ${l(["ls-remote","--heads","origin","main"])}`);let E=await p(a,["ls-remote","--heads","origin","main"]);if(g(k,i,"检查 origin/main",E),!E.stdout.trim()){b.push(`[${i}] origin/main 不存在,无法合并。`);let t=await R(i,a,s);A(i,!1,"origin/main 不存在",t);continue}k.push(`[${i}] ${l(["status","--porcelain"])}`);let F=await p(a,["status","--porcelain"]);if(g(k,i,"检查工作区",F),F.stdout.trim()){b.push(`[${i}] 工作区有未提交改动,请先处理后再合并 main。`);let t=await R(i,a,s);A(i,!1,"工作区有未提交改动",t);continue}k.push(`[${i}] ${l(["checkout","main"])}`);let N=await p(a,["checkout","main"]);if(g(k,i,"切换到 main",N),0!==N.code){b.push(`[${i}] 切换到 main 失败: ${N.stderr||N.stdout}`);let t=await R(i,a,s);A(i,!1,"切换到 main 失败",t);continue}k.push(`[${i}] ${l(["merge","--no-ff","--no-edit",`origin/${d}`])}`);let U=await p(a,["merge","--no-ff","--no-edit",`origin/${d}`]);if(g(k,i,`合并 origin/${d} 到 main`,U),0!==U.code){k.push(`[${i}] ${l(["merge","--abort"])}`);let t=await p(a,["merge","--abort"]);g(k,i,"终止合并到 main",t),b.push(`[${i}] 合并到 main 冲突,已终止合并,请手动处理。`);let e=await R(i,a,s);A(i,!1,"合并到 main 冲突",e);continue}k.push(`[${i}] ${l(["push","origin","main"])}`);let C=await p(a,["push","origin","main"]);if(g(k,i,"推送 main",C),0!==C.code){b.push(`[${i}] 推送 main 失败: ${C.stderr||C.stdout}`);let t=await R(i,a,s);A(i,!1,"推送 main 失败",t);continue}A(i,!0)}if((0,h.isUatGitFlowAborted)(B))for(let t of P.reverse()){let{name:e,info:i}=t,a=(0,n.join)(v,e);if(i.originalBranch&&"HEAD"!==i.originalBranch){k.push(`[${e}] 回滚: ${l(["checkout",i.originalBranch])}`);let t=await p(a,["checkout",i.originalBranch]);g(k,e,`回滚切换分支 ${i.originalBranch}`,t)}if(i.createdLocalBranch&&!i.hadLocalBranch){k.push(`[${e}] 回滚: ${l(["branch","-D",d])}`);let t=await p(a,["branch","-D",d]);g(k,e,`回滚删除本地分支 ${d}`,t)}}return a.NextResponse.json({success:0===b.length,operationLogs:k,feedbacks:b,projectResults:y})}catch(t){return console.error("UAT git 操作流执行失败:",t),a.NextResponse.json({success:!1,operationLogs:[],feedbacks:[t instanceof Error?t.message:"执行失败"]},{status:500})}finally{e&&(0,h.clearUatGitFlowState)(e)}}}},7044:t=>{"use strict";var{g:e,__dirname:i}=t;{t.s({patchFetch:()=>s,routeModule:()=>e,serverHooks:()=>c,workAsyncStorage:()=>i,workUnitAsyncStorage:()=>u});var a=t.i(45746),o=t.i(93828),r=t.i(18250),n=t.i(32970);let e=new a.AppRouteRouteModule({definition:{kind:o.RouteKind.APP_ROUTE,page:"/api/uat-git-flow/route",pathname:"/api/uat-git-flow",filename:"route",bundlePath:""},resolvedPagePath:"[project]/packages/server/src/app/api/uat-git-flow/route.ts",nextConfigOutput:"",userland:n}),{workAsyncStorage:i,workUnitAsyncStorage:u,serverHooks:c}=e;function s(){return(0,r.patchFetch)({workAsyncStorage:i,workUnitAsyncStorage:u})}}}};
2
+
3
+ //# sourceMappingURL=_61c263b3._.js.map