viba-cli 0.38.0 → 0.40.0

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 (230) hide show
  1. package/.next/BUILD_ID +1 -1
  2. package/.next/build-manifest.json +2 -2
  3. package/.next/fallback-build-manifest.json +2 -2
  4. package/.next/prerender-manifest.json +3 -3
  5. package/.next/server/app/_global-error.html +2 -2
  6. package/.next/server/app/_global-error.rsc +1 -1
  7. package/.next/server/app/_global-error.segments/__PAGE__.segment.rsc +1 -1
  8. package/.next/server/app/_global-error.segments/_full.segment.rsc +1 -1
  9. package/.next/server/app/_global-error.segments/_head.segment.rsc +1 -1
  10. package/.next/server/app/_global-error.segments/_index.segment.rsc +1 -1
  11. package/.next/server/app/_global-error.segments/_tree.segment.rsc +1 -1
  12. package/.next/server/app/_not-found/page_client-reference-manifest.js +1 -1
  13. package/.next/server/app/_not-found.html +2 -2
  14. package/.next/server/app/_not-found.rsc +3 -3
  15. package/.next/server/app/_not-found.segments/_full.segment.rsc +3 -3
  16. package/.next/server/app/_not-found.segments/_head.segment.rsc +1 -1
  17. package/.next/server/app/_not-found.segments/_index.segment.rsc +3 -3
  18. package/.next/server/app/_not-found.segments/_not-found/__PAGE__.segment.rsc +1 -1
  19. package/.next/server/app/_not-found.segments/_not-found.segment.rsc +1 -1
  20. package/.next/server/app/_not-found.segments/_tree.segment.rsc +2 -2
  21. package/.next/server/app/api/custom-scripts/route.js +2 -2
  22. package/.next/server/app/api/custom-scripts/route.js.nft.json +1 -1
  23. package/.next/server/app/api/git/action/route.js +3 -3
  24. package/.next/server/app/api/git/action/route.js.nft.json +1 -1
  25. package/.next/server/app/api/git/branches/route.js +3 -3
  26. package/.next/server/app/api/git/branches/route.js.nft.json +1 -1
  27. package/.next/server/app/api/git/diff/route.js +2 -2
  28. package/.next/server/app/api/git/diff/route.js.nft.json +1 -1
  29. package/.next/server/app/api/git/log/route.js +2 -2
  30. package/.next/server/app/api/git/log/route.js.nft.json +1 -1
  31. package/.next/server/app/api/git/status/route.js +3 -3
  32. package/.next/server/app/api/git/status/route.js.nft.json +1 -1
  33. package/.next/server/app/api/repos/clone/route.js +2 -2
  34. package/.next/server/app/api/repos/clone/route.js.nft.json +1 -1
  35. package/.next/server/app/api/repos/route.js +2 -2
  36. package/.next/server/app/api/repos/route.js.nft.json +1 -1
  37. package/.next/server/app/api/settings/route.js.nft.json +1 -1
  38. package/.next/server/app/credentials/page/server-reference-manifest.json +7 -7
  39. package/.next/server/app/credentials/page.js.nft.json +1 -1
  40. package/.next/server/app/credentials/page_client-reference-manifest.js +1 -1
  41. package/.next/server/app/credentials.html +2 -2
  42. package/.next/server/app/credentials.rsc +5 -5
  43. package/.next/server/app/credentials.segments/_full.segment.rsc +5 -5
  44. package/.next/server/app/credentials.segments/_head.segment.rsc +1 -1
  45. package/.next/server/app/credentials.segments/_index.segment.rsc +3 -3
  46. package/.next/server/app/credentials.segments/_tree.segment.rsc +2 -2
  47. package/.next/server/app/credentials.segments/credentials/__PAGE__.segment.rsc +2 -2
  48. package/.next/server/app/credentials.segments/credentials.segment.rsc +1 -1
  49. package/.next/server/app/git/changes/page.js.nft.json +1 -1
  50. package/.next/server/app/git/changes/page_client-reference-manifest.js +1 -1
  51. package/.next/server/app/git/changes.html +2 -2
  52. package/.next/server/app/git/changes.rsc +8 -8
  53. package/.next/server/app/git/changes.segments/_full.segment.rsc +8 -8
  54. package/.next/server/app/git/changes.segments/_head.segment.rsc +1 -1
  55. package/.next/server/app/git/changes.segments/_index.segment.rsc +3 -3
  56. package/.next/server/app/git/changes.segments/_tree.segment.rsc +2 -2
  57. package/.next/server/app/git/changes.segments/git/changes/__PAGE__.segment.rsc +2 -2
  58. package/.next/server/app/git/changes.segments/git/changes.segment.rsc +1 -1
  59. package/.next/server/app/git/changes.segments/git.segment.rsc +3 -3
  60. package/.next/server/app/git/custom-scripts/page.js.nft.json +1 -1
  61. package/.next/server/app/git/custom-scripts/page_client-reference-manifest.js +1 -1
  62. package/.next/server/app/git/custom-scripts.html +2 -2
  63. package/.next/server/app/git/custom-scripts.rsc +7 -7
  64. package/.next/server/app/git/custom-scripts.segments/_full.segment.rsc +7 -7
  65. package/.next/server/app/git/custom-scripts.segments/_head.segment.rsc +1 -1
  66. package/.next/server/app/git/custom-scripts.segments/_index.segment.rsc +3 -3
  67. package/.next/server/app/git/custom-scripts.segments/_tree.segment.rsc +2 -2
  68. package/.next/server/app/git/custom-scripts.segments/git/custom-scripts/__PAGE__.segment.rsc +2 -2
  69. package/.next/server/app/git/custom-scripts.segments/git/custom-scripts.segment.rsc +1 -1
  70. package/.next/server/app/git/custom-scripts.segments/git.segment.rsc +3 -3
  71. package/.next/server/app/git/history/page.js.nft.json +1 -1
  72. package/.next/server/app/git/history/page_client-reference-manifest.js +1 -1
  73. package/.next/server/app/git/history.html +2 -2
  74. package/.next/server/app/git/history.rsc +8 -8
  75. package/.next/server/app/git/history.segments/_full.segment.rsc +8 -8
  76. package/.next/server/app/git/history.segments/_head.segment.rsc +1 -1
  77. package/.next/server/app/git/history.segments/_index.segment.rsc +3 -3
  78. package/.next/server/app/git/history.segments/_tree.segment.rsc +2 -2
  79. package/.next/server/app/git/history.segments/git/history/__PAGE__.segment.rsc +2 -2
  80. package/.next/server/app/git/history.segments/git/history.segment.rsc +1 -1
  81. package/.next/server/app/git/history.segments/git.segment.rsc +3 -3
  82. package/.next/server/app/git/page.js.nft.json +1 -1
  83. package/.next/server/app/git/page_client-reference-manifest.js +1 -1
  84. package/.next/server/app/git/stashes/page.js.nft.json +1 -1
  85. package/.next/server/app/git/stashes/page_client-reference-manifest.js +1 -1
  86. package/.next/server/app/git/stashes.html +2 -2
  87. package/.next/server/app/git/stashes.rsc +7 -7
  88. package/.next/server/app/git/stashes.segments/_full.segment.rsc +7 -7
  89. package/.next/server/app/git/stashes.segments/_head.segment.rsc +1 -1
  90. package/.next/server/app/git/stashes.segments/_index.segment.rsc +3 -3
  91. package/.next/server/app/git/stashes.segments/_tree.segment.rsc +2 -2
  92. package/.next/server/app/git/stashes.segments/git/stashes/__PAGE__.segment.rsc +2 -2
  93. package/.next/server/app/git/stashes.segments/git/stashes.segment.rsc +1 -1
  94. package/.next/server/app/git/stashes.segments/git.segment.rsc +3 -3
  95. package/.next/server/app/git.html +2 -2
  96. package/.next/server/app/git.rsc +8 -8
  97. package/.next/server/app/git.segments/_full.segment.rsc +8 -8
  98. package/.next/server/app/git.segments/_head.segment.rsc +1 -1
  99. package/.next/server/app/git.segments/_index.segment.rsc +3 -3
  100. package/.next/server/app/git.segments/_tree.segment.rsc +2 -2
  101. package/.next/server/app/git.segments/git/__PAGE__.segment.rsc +2 -2
  102. package/.next/server/app/git.segments/git.segment.rsc +3 -3
  103. package/.next/server/app/index.html +2 -2
  104. package/.next/server/app/index.rsc +5 -5
  105. package/.next/server/app/index.segments/__PAGE__.segment.rsc +2 -2
  106. package/.next/server/app/index.segments/_full.segment.rsc +5 -5
  107. package/.next/server/app/index.segments/_head.segment.rsc +1 -1
  108. package/.next/server/app/index.segments/_index.segment.rsc +3 -3
  109. package/.next/server/app/index.segments/_tree.segment.rsc +2 -2
  110. package/.next/server/app/new/page/server-reference-manifest.json +29 -29
  111. package/.next/server/app/new/page.js +2 -2
  112. package/.next/server/app/new/page.js.nft.json +1 -1
  113. package/.next/server/app/new/page_client-reference-manifest.js +1 -1
  114. package/.next/server/app/page/server-reference-manifest.json +29 -29
  115. package/.next/server/app/page.js +1 -1
  116. package/.next/server/app/page.js.nft.json +1 -1
  117. package/.next/server/app/page_client-reference-manifest.js +1 -1
  118. package/.next/server/app/session/[sessionId]/page/server-reference-manifest.json +19 -19
  119. package/.next/server/app/session/[sessionId]/page.js +1 -1
  120. package/.next/server/app/session/[sessionId]/page.js.nft.json +1 -1
  121. package/.next/server/app/session/[sessionId]/page_client-reference-manifest.js +1 -1
  122. package/.next/server/chunks/[root-of-the-server]__01a6baa7._.js +1 -1
  123. package/.next/server/chunks/[root-of-the-server]__01a6baa7._.js.map +1 -1
  124. package/.next/server/chunks/[root-of-the-server]__2ea0148f._.js +7 -0
  125. package/.next/server/chunks/[root-of-the-server]__2ea0148f._.js.map +1 -0
  126. package/.next/server/chunks/[root-of-the-server]__51f9ab28._.js +3 -0
  127. package/.next/server/chunks/{[root-of-the-server]__7f2f8f49._.js.map → [root-of-the-server]__51f9ab28._.js.map} +1 -1
  128. package/.next/server/chunks/[root-of-the-server]__52f9b7e2._.js +3 -0
  129. package/.next/server/chunks/{[root-of-the-server]__afea2116._.js.map → [root-of-the-server]__52f9b7e2._.js.map} +1 -1
  130. package/.next/server/chunks/[root-of-the-server]__5b08b37e._.js +3 -0
  131. package/.next/server/chunks/{[root-of-the-server]__7324fe0b._.js.map → [root-of-the-server]__5b08b37e._.js.map} +1 -1
  132. package/.next/server/chunks/[root-of-the-server]__8b29248a._.js +3 -0
  133. package/.next/server/chunks/{[root-of-the-server]__82d53572._.js.map → [root-of-the-server]__8b29248a._.js.map} +1 -1
  134. package/.next/server/chunks/[root-of-the-server]__f52f1c06._.js +3 -0
  135. package/.next/server/chunks/{[root-of-the-server]__5349b858._.js.map → [root-of-the-server]__f52f1c06._.js.map} +1 -1
  136. package/.next/server/chunks/node_modules_next_dist_esm_build_templates_app-route_0002606b.js +1 -1
  137. package/.next/server/chunks/node_modules_next_dist_esm_build_templates_app-route_0002606b.js.map +1 -1
  138. package/.next/server/chunks/ssr/[root-of-the-server]__05e6fb4c._.js +1 -1
  139. package/.next/server/chunks/ssr/{[root-of-the-server]__79a7a15d._.js → [root-of-the-server]__0ed2deb1._.js} +2 -2
  140. package/.next/server/chunks/ssr/{[root-of-the-server]__79a7a15d._.js.map → [root-of-the-server]__0ed2deb1._.js.map} +1 -1
  141. package/.next/server/chunks/ssr/{[root-of-the-server]__2798aa4d._.js → [root-of-the-server]__1ed5a76d._.js} +3 -3
  142. package/.next/server/chunks/ssr/{[root-of-the-server]__2798aa4d._.js.map → [root-of-the-server]__1ed5a76d._.js.map} +1 -1
  143. package/.next/server/chunks/ssr/[root-of-the-server]__46af1502._.js +1 -1
  144. package/.next/server/chunks/ssr/[root-of-the-server]__46af1502._.js.map +1 -1
  145. package/.next/server/chunks/ssr/{[root-of-the-server]__05b3451a._.js → [root-of-the-server]__a65a3900._.js} +2 -2
  146. package/.next/server/chunks/ssr/{[root-of-the-server]__05b3451a._.js.map → [root-of-the-server]__a65a3900._.js.map} +1 -1
  147. package/.next/server/chunks/ssr/[root-of-the-server]__d52659cf._.js +3 -0
  148. package/.next/server/chunks/ssr/[root-of-the-server]__d52659cf._.js.map +1 -0
  149. package/.next/server/chunks/ssr/{_523ff032._.js → _2eaa7035._.js} +2 -2
  150. package/.next/server/chunks/ssr/{_523ff032._.js.map → _2eaa7035._.js.map} +1 -1
  151. package/.next/server/chunks/ssr/{_be721a9c._.js → _4343fa01._.js} +2 -2
  152. package/.next/server/chunks/ssr/{_be721a9c._.js.map → _4343fa01._.js.map} +1 -1
  153. package/.next/server/chunks/ssr/_476e86d1._.js +1 -1
  154. package/.next/server/chunks/ssr/_4d07d45e._.js +1 -1
  155. package/.next/server/chunks/ssr/_4d07d45e._.js.map +1 -1
  156. package/.next/server/chunks/ssr/_57f63a65._.js +1 -1
  157. package/.next/server/chunks/ssr/_57f63a65._.js.map +1 -1
  158. package/.next/server/chunks/ssr/_707e5fab._.js +1 -1
  159. package/.next/server/chunks/ssr/_9493de08._.js +1 -1
  160. package/.next/server/chunks/ssr/{_787bdec7._.js → _a07f93fb._.js} +2 -2
  161. package/.next/server/chunks/ssr/{_787bdec7._.js.map → _a07f93fb._.js.map} +1 -1
  162. package/.next/server/chunks/ssr/{_2a7fa4b0._.js → _ebf4c61c._.js} +2 -2
  163. package/.next/server/chunks/ssr/{_2a7fa4b0._.js.map → _ebf4c61c._.js.map} +1 -1
  164. package/.next/server/chunks/ssr/_ff20dbae._.js +3 -0
  165. package/.next/server/chunks/ssr/{_e17414c3._.js.map → _ff20dbae._.js.map} +1 -1
  166. package/.next/server/chunks/ssr/src_app_credentials_page_tsx_63d8d34a._.js +1 -1
  167. package/.next/server/chunks/ssr/src_app_credentials_page_tsx_63d8d34a._.js.map +1 -1
  168. package/.next/server/chunks/ssr/src_app_git_changes_page_tsx_f6dc28dc._.js +2 -2
  169. package/.next/server/chunks/ssr/src_app_git_changes_page_tsx_f6dc28dc._.js.map +1 -1
  170. package/.next/server/chunks/ssr/src_app_providers_tsx_2ae5be81._.js +1 -1
  171. package/.next/server/chunks/ssr/src_app_providers_tsx_2ae5be81._.js.map +1 -1
  172. package/.next/server/chunks/ssr/src_app_session_[sessionId]_SessionPageClient_tsx_dab490d7._.js +1 -1
  173. package/.next/server/chunks/ssr/src_app_session_[sessionId]_SessionPageClient_tsx_dab490d7._.js.map +1 -1
  174. package/.next/server/chunks/ssr/src_components_GitRepoSelector_tsx_05c81afa._.js +3 -3
  175. package/.next/server/chunks/ssr/src_components_GitRepoSelector_tsx_05c81afa._.js.map +1 -1
  176. package/.next/server/chunks/ssr/src_components_git_029e6e6f._.js +3 -0
  177. package/.next/server/chunks/ssr/src_components_git_029e6e6f._.js.map +1 -0
  178. package/.next/server/chunks/ssr/src_components_git_history-view_tsx_fd62126a._.js +4 -4
  179. package/.next/server/chunks/ssr/src_components_git_history-view_tsx_fd62126a._.js.map +1 -1
  180. package/.next/server/chunks/ssr/src_db5b513b._.js +3 -0
  181. package/.next/server/chunks/ssr/src_db5b513b._.js.map +1 -0
  182. package/.next/server/pages/404.html +2 -2
  183. package/.next/server/pages/500.html +2 -2
  184. package/.next/server/server-reference-manifest.js +1 -1
  185. package/.next/server/server-reference-manifest.json +48 -48
  186. package/.next/static/chunks/{ff0443d5f56a7060.js → 1ca050861ead915f.js} +1 -1
  187. package/.next/static/chunks/1f428267926cd032.js +3 -0
  188. package/.next/static/chunks/4aab1f3ea2ed1aef.js +1 -0
  189. package/.next/static/chunks/4de7bc5a00a1aed9.js +3 -0
  190. package/.next/static/chunks/5e0dada5236f9065.js +8 -0
  191. package/.next/static/chunks/{58e245f27f38e5ff.js → 73c13373731456db.js} +1 -1
  192. package/.next/static/chunks/73f859ef915277c7.js +3 -0
  193. package/.next/static/chunks/74f887e69c1fcefa.js +9 -0
  194. package/.next/static/chunks/977137e155012c13.js +1 -0
  195. package/.next/static/chunks/b18cc1247b979318.js +1 -0
  196. package/.next/static/chunks/d85a06040ea88b62.js +1 -0
  197. package/.next/static/chunks/{bcc203fd591a3e1b.js → db4cb4eb290e3be9.js} +1 -1
  198. package/.next/static/chunks/e5bcfa7f94c34b77.js +1 -0
  199. package/.next/static/chunks/eec24a7b35c2d7bd.css +1 -0
  200. package/.next/static/chunks/{46c9f58659e11b7d.js → fa9e48c3aa7e4365.js} +1 -1
  201. package/README.md +3 -0
  202. package/bin/viba.mjs +120 -4
  203. package/package.json +1 -1
  204. package/.next/server/chunks/[root-of-the-server]__2dcb1454._.js +0 -3
  205. package/.next/server/chunks/[root-of-the-server]__2dcb1454._.js.map +0 -1
  206. package/.next/server/chunks/[root-of-the-server]__5349b858._.js +0 -3
  207. package/.next/server/chunks/[root-of-the-server]__7324fe0b._.js +0 -3
  208. package/.next/server/chunks/[root-of-the-server]__7f2f8f49._.js +0 -3
  209. package/.next/server/chunks/[root-of-the-server]__82d53572._.js +0 -3
  210. package/.next/server/chunks/[root-of-the-server]__afea2116._.js +0 -3
  211. package/.next/server/chunks/[root-of-the-server]__b17e6c62._.js +0 -7
  212. package/.next/server/chunks/[root-of-the-server]__b17e6c62._.js.map +0 -1
  213. package/.next/server/chunks/ssr/[root-of-the-server]__30652385._.js +0 -3
  214. package/.next/server/chunks/ssr/[root-of-the-server]__30652385._.js.map +0 -1
  215. package/.next/server/chunks/ssr/_e17414c3._.js +0 -3
  216. package/.next/server/chunks/ssr/src_hooks_use-workspace-title_ts_9edd343b._.js +0 -3
  217. package/.next/server/chunks/ssr/src_hooks_use-workspace-title_ts_9edd343b._.js.map +0 -1
  218. package/.next/static/chunks/0eca2eff234acf1b.js +0 -1
  219. package/.next/static/chunks/47ad182e478611c4.css +0 -1
  220. package/.next/static/chunks/4b818f2593bc4300.js +0 -1
  221. package/.next/static/chunks/4d93976ea0e8b685.js +0 -9
  222. package/.next/static/chunks/78859d33c5671d29.js +0 -8
  223. package/.next/static/chunks/94fb2462104985a8.js +0 -3
  224. package/.next/static/chunks/9f82d45ee88d5dc1.js +0 -3
  225. package/.next/static/chunks/a29874cab09f6b0f.js +0 -3
  226. package/.next/static/chunks/e152c322e888ccea.js +0 -1
  227. package/.next/static/chunks/fff7986d66d302cf.js +0 -1
  228. /package/.next/static/{mx8z_YoNSm8FluLvondrw → SPowgKQ4GVFmr1hEouu16}/_buildManifest.js +0 -0
  229. /package/.next/static/{mx8z_YoNSm8FluLvondrw → SPowgKQ4GVFmr1hEouu16}/_clientMiddlewareManifest.json +0 -0
  230. /package/.next/static/{mx8z_YoNSm8FluLvondrw → SPowgKQ4GVFmr1hEouu16}/_ssgManifest.js +0 -0
@@ -1,3 +1,3 @@
1
- module.exports=[50081,e=>{"use strict";var r=e.i(47909),t=e.i(74017),a=e.i(96250),o=e.i(59756),i=e.i(61916),s=e.i(74677),n=e.i(69741),c=e.i(16795),l=e.i(87718),h=e.i(95169),u=e.i(47587),m=e.i(66012),d=e.i(70101),f=e.i(26937),p=e.i(10372),w=e.i(93695);e.i(52474);var g=e.i(220),b=e.i(89171),R=e.i(87140),k=e.i(72881),E=e.i(14487),q=e.i(81183),v=e.i(74129),x=e.i(69719),y=e.i(2157);let N=x.z.object({repoPath:x.z.string(),action:x.z.enum(["commit","push","pull","stage","unstage","fetch","checkout","checkout-to-local","branch","create-tag","delete-branch","delete-worktree","delete-remote-branch","delete-remote","delete-tag","delete-remote-tag","rename-branch","rename-remote-branch","rename-remote","add-remote","reset","revert","cherry-pick","cherry-pick-multiple","cherry-pick-abort","rebase","merge","check-merge-conflicts","check-rebase-conflicts","get-conflict-state","get-conflict-file-versions","resolve-conflict-file","continue-merge","abort-merge","continue-rebase","abort-rebase","get-remotes","get-remote-branches","get-tracking-branch","get-latest-commit-message","push-to-remote","pull-from-remote","stash","stash-list","stash-apply","stash-drop","stash-pop","stash-files","stash-file-diff","reword","discard","cleanup-lock-file"]),data:x.z.any().optional()});async function C(e,r,t){let a=(0,k.getRepositories)().find(r=>r.path===e);if(a?.credentialId){let e=await (0,E.getCredentialById)(a.credentialId);if(e){let r=await (0,E.getCredentialToken)(e.id);if(r)return{username:e.username,token:r}}}if(t){let e=await r.getRemoteUrl(t);if(e){let r=await (0,E.findCredentialForRemote)(e);if(r)return{username:r.credential.username,token:r.token}}}}function B(e,r){return e?{mimeType:r,base64:e.toString("base64")}:null}async function T(e){try{let r=await e.json(),{repoPath:t,action:a,data:o}=N.parse(r);if(!y.default.existsSync(t))return b.NextResponse.json({error:`Path not found: ${t}`},{status:404});let i=new R.GitService(t);switch(a){case"commit":if(!o?.message)throw Error("Commit message is required");await i.commit(o.message,o.files,{initialBranch:o?.initialBranch});break;case"push":let s=await C(t,i,void 0);if(!s)try{let e=await i.getBranches(),r=e.current,a=e.trackingInfo[r];if(a&&a.upstream){let e=a.upstream.indexOf("/");if(e>0){let r=a.upstream.slice(0,e);s=await C(t,i,r)}}}catch(e){console.warn("[API] Failed to resolve upstream for push credentials:",e)}await i.push({credentials:s});break;case"pull":await i.pull();break;case"fetch":o?.allRemotes?await i.fetchAllRemotes():o?.remote?await i.fetchRemote(o.remote):await i.fetch();break;case"stage":if(!o?.files)throw Error("Files are required for staging");await i.stage(o.files);break;case"unstage":if(!o?.files)throw Error("Files are required for unstaging");await i.unstage(o.files);break;case"discard":await i.discardUnstagedChanges({includeUntracked:o?.includeUntracked??!0});break;case"checkout":if(!o?.branch)throw Error("Branch name is required for checkout");await i.checkout(o.branch);break;case"checkout-to-local":if(!o?.remoteBranch)throw Error("Remote branch is required for checkout-to-local");if(!o?.localBranch)throw Error("Local branch name is required for checkout-to-local");await i.checkoutRemoteToLocal(o.remoteBranch,o.localBranch);break;case"branch":if(!o?.branch)throw Error("Branch name is required to create branch");await i.createBranch(o.branch,o?.fromRef);break;case"create-tag":if(!o?.tagName)throw Error("Tag name is required to create tag");if(!o?.commitHash)throw Error("Commit hash is required to create tag");if(o?.pushToRemote){let e="string"==typeof o?.remote&&o.remote.trim()?o.remote.trim():void 0;if(!e){let r=await i.getBranches(),t=r.current,a=t?r.trackingInfo?.[t]?.upstream:void 0;if(a){let r=a.indexOf("/");r>0&&(e=a.slice(0,r))}}if(!e){let r=await i.getRemotes();e=r.includes("origin")?"origin":r[0]}let r=e?await C(t,i,e):void 0;await i.createTag(o.tagName,o.commitHash,{pushToRemote:!0,remote:e??void 0,credentials:r})}else await i.createTag(o.tagName,o.commitHash,{pushToRemote:!1});break;case"delete-branch":if(!o?.branch)throw Error("Branch name is required to delete branch");await i.deleteBranch(o.branch);break;case"delete-worktree":if(!o?.path)throw Error("Worktree path is required to delete worktree");await i.deleteWorktree(o.path);break;case"delete-remote-branch":if(!o?.remote)throw Error("Remote name is required to delete remote branch");if(!o?.branch)throw Error("Branch name is required to delete remote branch");let n=await C(t,i,o.remote);await i.deleteRemoteBranch(o.remote,o.branch,n);break;case"delete-remote":if(!o?.name)throw Error("Remote name is required to delete remote");await i.deleteRemote(o.name);break;case"delete-tag":if(!o?.tag)throw Error("Tag name is required to delete tag");await i.deleteTag(o.tag);break;case"delete-remote-tag":if(!o?.remote)throw Error("Remote name is required to delete remote tag");if(!o?.tag)throw Error("Tag name is required to delete remote tag");let c=await C(t,i,o.remote);await i.deleteRemoteTag(o.remote,o.tag,c);break;case"rename-branch":if(!o?.oldName)throw Error("Old branch name is required to rename branch");if(!o?.newName)throw Error("New branch name is required to rename branch");if(o?.renameTrackingRemote){let e=await i.getTrackingBranch(o.oldName),r=e?await C(t,i,e.remote):void 0;await i.renameBranch(o.oldName,o.newName,{renameTrackingRemote:!0,credentials:r})}else await i.renameBranch(o.oldName,o.newName);break;case"rename-remote-branch":if(!o?.remote)throw Error("Remote name is required to rename remote branch");if(!o?.oldName)throw Error("Old branch name is required to rename remote branch");if(!o?.newName)throw Error("New branch name is required to rename remote branch");let l=await C(t,i,o.remote);await i.renameRemoteBranch(o.remote,o.oldName,o.newName,l);break;case"rename-remote":if(!o?.oldName)throw Error("Old remote name is required to rename remote");if(!o?.newName)throw Error("New remote name is required to rename remote");await i.renameRemote(o.oldName,o.newName);break;case"add-remote":if(!o?.name)throw Error("Remote name is required to add remote");if(!o?.url)throw Error("Remote URL is required to add remote");await i.addRemote(o.name,o.url);break;case"reset":if(!o?.commitHash)throw Error("Commit hash is required for reset");await i.reset(o.commitHash,o.mode??"hard");break;case"revert":if(!o?.commitHash)throw Error("Commit hash is required for revert");await i.revert(o.commitHash);break;case"cherry-pick":if(!o?.commitHash)throw Error("Commit hash is required for cherry-pick");await i.cherryPick(o.commitHash);break;case"cherry-pick-multiple":if(!Array.isArray(o?.commitHashes)||0===o.commitHashes.length)throw Error("Commit hashes are required for multi cherry-pick");if(!o.commitHashes.every(e=>"string"==typeof e&&e.trim().length>0))throw Error("All commit hashes must be non-empty strings");await i.cherryPickMultiple(o.commitHashes);break;case"cherry-pick-abort":await i.abortCherryPick();break;case"rebase":if(!o?.ontoBranch)throw Error("Target branch is required for rebase");await i.rebase(o.ontoBranch,o.stashChanges??!0);break;case"reword":if(!o?.commitHash)throw Error("Commit hash is required for reword");if(!o?.message)throw Error("New message is required for reword");await i.reword(o.commitHash,o.message,o.branch);break;case"merge":if(!o?.targetBranch)throw Error("Target branch is required for merge");await i.merge(o.targetBranch,{rebaseBeforeMerge:o.rebaseBeforeMerge??!1,squash:o.squash??!1,fastForward:o.fastForward??!1,squashMessage:o.squashMessage});break;case"check-merge-conflicts":if(!o?.sourceBranch)throw Error("Source branch is required for merge conflict check");let h=await i.willMergeHaveConflicts(o.sourceBranch,o.targetBranch);return b.NextResponse.json({success:!0,hasConflicts:h});case"check-rebase-conflicts":if(!o?.ontoBranch)throw Error("Target branch is required for rebase conflict check");if(!o?.sourceBranch)throw Error("Source branch is required for rebase conflict check");let u=await i.willRebaseHaveConflicts(o.ontoBranch,o.sourceBranch);return b.NextResponse.json({success:!0,hasConflicts:u});case"get-conflict-state":let m=await i.getConflictState();return b.NextResponse.json({success:!0,...m});case"get-conflict-file-versions":if(!o?.path)throw Error("File path is required");let d=await i.getConflictFileVersions(o.path);return b.NextResponse.json({success:!0,...d});case"resolve-conflict-file":if(!o?.path)throw Error("File path is required");if(!o?.strategy)throw Error("Resolution strategy is required");if(!["ours","theirs","manual"].includes(o.strategy))throw Error("Resolution strategy must be ours, theirs, or manual");await i.resolveConflictFile(o.path,o.strategy,{content:o.content,stage:o.stage??!0});break;case"continue-merge":await i.continueMerge();break;case"abort-merge":await i.abortMerge();break;case"continue-rebase":await i.continueRebase();break;case"abort-rebase":await i.abortRebase();break;case"get-remotes":let f=await i.getRemotes();return b.NextResponse.json({success:!0,remotes:f});case"get-remote-branches":if(!o?.remote)throw Error("Remote name is required");let p=await i.getRemoteBranches(o.remote);return b.NextResponse.json({success:!0,branches:p});case"get-tracking-branch":if(!o?.branch)throw Error("Branch name is required");let w=await i.getTrackingBranch(o.branch);return b.NextResponse.json({success:!0,tracking:w});case"get-latest-commit-message":if(!o?.branch)throw Error("Branch name is required");let g=await i.getLatestCommitMessage(o.branch);return b.NextResponse.json({success:!0,message:g});case"push-to-remote":if(console.log("[API] push-to-remote action received:",o),!o?.localBranch)throw Error("Local branch is required");if(!o?.remote)throw Error("Remote is required");if(!o?.remoteBranch)throw Error("Remote branch is required");let k=await C(t,i,o.remote);console.log("[API] Calling git.pushToRemote..."),await i.pushToRemote(o.localBranch,o.remote,o.remoteBranch,{rebaseFirst:o.rebaseFirst??!o.forcePush,forcePush:o.forcePush??!1,pushLocalOnlyTags:o.pushLocalOnlyTags??!0,setUpstream:o.setUpstream??!1,squash:o.squash??!1,squashMessage:o.squashMessage,credentials:k}),console.log("[API] git.pushToRemote completed");break;case"pull-from-remote":if(console.log("[API] pull-from-remote action received:",o),!o?.localBranch)throw Error("Local branch is required");if(!o?.remote)throw Error("Remote is required");if(!o?.remoteBranch)throw Error("Remote branch is required");console.log("[API] Calling git.pullFromRemote..."),await i.pullFromRemote(o.localBranch,o.remote,o.remoteBranch,{rebase:o.rebase??!0}),console.log("[API] git.pullFromRemote completed");break;case"stash":await i.stash(o?.message);break;case"stash-list":let E=await i.getStashes();return b.NextResponse.json({success:!0,stashes:E});case"stash-apply":if(o?.index===void 0)throw Error("Stash index is required");await i.applyStash(o.index);break;case"stash-drop":if(o?.index===void 0)throw Error("Stash index is required");await i.dropStash(o.index);break;case"stash-pop":if(o?.index===void 0)throw Error("Stash index is required");await i.popStash(o.index);break;case"stash-files":if(o?.index===void 0)throw Error("Stash index is required");let v=await i.getStashFiles(o.index);return b.NextResponse.json({success:!0,files:v});case"stash-file-diff":if(o?.index===void 0)throw Error("Stash index is required");if(!o?.file)throw Error("File path is required");if((0,q.isImageFile)(o.file)){let e=(0,q.getImageMimeType)(o.file),[r,t,a]=await Promise.all([i.getFileContentBuffer(o.file,`stash@{${o.index}}^1`),i.getFileContentBuffer(o.file,`stash@{${o.index}}`),i.getStashFilePatch(o.index,o.file)]);return b.NextResponse.json({success:!0,left:"",right:"",diff:a,imageDiff:{left:B(r,e),right:B(t,e)}})}let x=await i.getStashFileDiff(o.index,o.file);return b.NextResponse.json({success:!0,...x});case"cleanup-lock-file":let T=await i.cleanupLockFile();return b.NextResponse.json({success:!0,cleaned:T});default:return b.NextResponse.json({error:"Invalid action"},{status:400})}return b.NextResponse.json({success:!0})}catch(e){return(0,v.handleGitError)(e)}}e.s(["POST",()=>T],76457);var P=e.i(76457);let A=new r.AppRouteRouteModule({definition:{kind:t.RouteKind.APP_ROUTE,page:"/api/git/action/route",pathname:"/api/git/action",filename:"route",bundlePath:""},distDir:".next",relativeProjectDir:"",resolvedPagePath:"[project]/src/app/api/git/action/route.ts",nextConfigOutput:"",userland:P}),{workAsyncStorage:S,workUnitAsyncStorage:H,serverHooks:F}=A;function I(){return(0,a.patchFetch)({workAsyncStorage:S,workUnitAsyncStorage:H})}async function O(e,r,a){A.isDev&&(0,o.addRequestMeta)(e,"devRequestTimingInternalsEnd",process.hrtime.bigint());let b="/api/git/action/route";b=b.replace(/\/index$/,"")||"/";let R=await A.prepare(e,r,{srcPage:b,multiZoneDraftMode:!1});if(!R)return r.statusCode=400,r.end("Bad Request"),null==a.waitUntil||a.waitUntil.call(a,Promise.resolve()),null;let{buildId:k,params:E,nextConfig:q,parsedUrl:v,isDraftMode:x,prerenderManifest:y,routerServerContext:N,isOnDemandRevalidate:C,revalidateOnlyGenerated:B,resolvedPathname:T,clientReferenceManifest:P,serverActionsManifest:S}=R,H=(0,n.normalizeAppPath)(b),F=!!(y.dynamicRoutes[H]||y.routes[T]),I=async()=>((null==N?void 0:N.render404)?await N.render404(e,r,v,!1):r.end("This page could not be found"),null);if(F&&!x){let e=!!y.routes[T],r=y.dynamicRoutes[H];if(r&&!1===r.fallback&&!e){if(q.experimental.adapterPath)return await I();throw new w.NoFallbackError}}let O=null;!F||A.isDev||x||(O="/index"===(O=T)?"/":O);let j=!0===A.isDev||!F,M=F&&!j;S&&P&&(0,s.setManifestsSingleton)({page:b,clientReferenceManifest:P,serverActionsManifest:S});let U=e.method||"GET",_=(0,i.getTracer)(),D=_.getActiveScopeSpan(),L={params:E,prerenderManifest:y,renderOpts:{experimental:{authInterrupts:!!q.experimental.authInterrupts},cacheComponents:!!q.cacheComponents,supportsDynamicResponse:j,incrementalCache:(0,o.getRequestMeta)(e,"incrementalCache"),cacheLifeProfiles:q.cacheLife,waitUntil:a.waitUntil,onClose:e=>{r.on("close",e)},onAfterTaskError:void 0,onInstrumentationRequestError:(r,t,a,o)=>A.onRequestError(e,r,a,o,N)},sharedContext:{buildId:k}},$=new c.NodeNextRequest(e),K=new c.NodeNextResponse(r),z=l.NextRequestAdapter.fromNodeNextRequest($,(0,l.signalFromNodeResponse)(r));try{let s=async e=>A.handle(z,L).finally(()=>{if(!e)return;e.setAttributes({"http.status_code":r.statusCode,"next.rsc":!1});let t=_.getRootSpanAttributes();if(!t)return;if(t.get("next.span_type")!==h.BaseServerSpan.handleRequest)return void console.warn(`Unexpected root span type '${t.get("next.span_type")}'. Please report this Next.js issue https://github.com/vercel/next.js`);let a=t.get("next.route");if(a){let r=`${U} ${a}`;e.setAttributes({"next.route":a,"http.route":a,"next.span_name":r}),e.updateName(r)}else e.updateName(`${U} ${b}`)}),n=!!(0,o.getRequestMeta)(e,"minimalMode"),c=async o=>{var i,c;let l=async({previousCacheEntry:t})=>{try{if(!n&&C&&B&&!t)return r.statusCode=404,r.setHeader("x-nextjs-cache","REVALIDATED"),r.end("This page could not be found"),null;let i=await s(o);e.fetchMetrics=L.renderOpts.fetchMetrics;let c=L.renderOpts.pendingWaitUntil;c&&a.waitUntil&&(a.waitUntil(c),c=void 0);let l=L.renderOpts.collectedTags;if(!F)return await (0,m.sendResponse)($,K,i,L.renderOpts.pendingWaitUntil),null;{let e=await i.blob(),r=(0,d.toNodeOutgoingHttpHeaders)(i.headers);l&&(r[p.NEXT_CACHE_TAGS_HEADER]=l),!r["content-type"]&&e.type&&(r["content-type"]=e.type);let t=void 0!==L.renderOpts.collectedRevalidate&&!(L.renderOpts.collectedRevalidate>=p.INFINITE_CACHE)&&L.renderOpts.collectedRevalidate,a=void 0===L.renderOpts.collectedExpire||L.renderOpts.collectedExpire>=p.INFINITE_CACHE?void 0:L.renderOpts.collectedExpire;return{value:{kind:g.CachedRouteKind.APP_ROUTE,status:i.status,body:Buffer.from(await e.arrayBuffer()),headers:r},cacheControl:{revalidate:t,expire:a}}}}catch(r){throw(null==t?void 0:t.isStale)&&await A.onRequestError(e,r,{routerKind:"App Router",routePath:b,routeType:"route",revalidateReason:(0,u.getRevalidateReason)({isStaticGeneration:M,isOnDemandRevalidate:C})},!1,N),r}},h=await A.handleResponse({req:e,nextConfig:q,cacheKey:O,routeKind:t.RouteKind.APP_ROUTE,isFallback:!1,prerenderManifest:y,isRoutePPREnabled:!1,isOnDemandRevalidate:C,revalidateOnlyGenerated:B,responseGenerator:l,waitUntil:a.waitUntil,isMinimalMode:n});if(!F)return null;if((null==h||null==(i=h.value)?void 0:i.kind)!==g.CachedRouteKind.APP_ROUTE)throw Object.defineProperty(Error(`Invariant: app-route received invalid cache entry ${null==h||null==(c=h.value)?void 0:c.kind}`),"__NEXT_ERROR_CODE",{value:"E701",enumerable:!1,configurable:!0});n||r.setHeader("x-nextjs-cache",C?"REVALIDATED":h.isMiss?"MISS":h.isStale?"STALE":"HIT"),x&&r.setHeader("Cache-Control","private, no-cache, no-store, max-age=0, must-revalidate");let w=(0,d.fromNodeOutgoingHttpHeaders)(h.value.headers);return n&&F||w.delete(p.NEXT_CACHE_TAGS_HEADER),!h.cacheControl||r.getHeader("Cache-Control")||w.get("Cache-Control")||w.set("Cache-Control",(0,f.getCacheControlHeader)(h.cacheControl)),await (0,m.sendResponse)($,K,new Response(h.value.body,{headers:w,status:h.value.status||200})),null};D?await c(D):await _.withPropagatedContext(e.headers,()=>_.trace(h.BaseServerSpan.handleRequest,{spanName:`${U} ${b}`,kind:i.SpanKind.SERVER,attributes:{"http.method":U,"http.target":e.url}},c))}catch(r){if(r instanceof w.NoFallbackError||await A.onRequestError(e,r,{routerKind:"App Router",routePath:H,routeType:"route",revalidateReason:(0,u.getRevalidateReason)({isStaticGeneration:M,isOnDemandRevalidate:C})},!1,N),F)throw r;return await (0,m.sendResponse)($,K,new Response(null,{status:500})),null}}e.s(["handler",()=>O,"patchFetch",()=>I,"routeModule",()=>A,"serverHooks",()=>F,"workAsyncStorage",()=>S,"workUnitAsyncStorage",()=>H],50081)}];
1
+ module.exports=[50081,e=>{"use strict";var r=e.i(47909),t=e.i(74017),a=e.i(96250),o=e.i(59756),i=e.i(61916),s=e.i(74677),n=e.i(69741),c=e.i(16795),l=e.i(87718),h=e.i(95169),u=e.i(47587),m=e.i(66012),d=e.i(70101),f=e.i(26937),g=e.i(10372),w=e.i(93695);e.i(52474);var p=e.i(220),b=e.i(89171),R=e.i(87140),k=e.i(72881),E=e.i(14487),q=e.i(81183),v=e.i(74129),x=e.i(69719),N=e.i(2157);let y=x.z.object({repoPath:x.z.string(),action:x.z.enum(["commit","push","pull","stage","unstage","fetch","checkout","checkout-to-local","branch","create-tag","delete-branch","delete-worktree","delete-remote-branch","delete-remote","delete-tag","delete-remote-tag","rename-branch","rename-remote-branch","rename-remote","add-remote","reset","revert","cherry-pick","cherry-pick-multiple","cherry-pick-abort","rebase","merge","check-merge-conflicts","check-rebase-conflicts","get-conflict-state","get-conflict-file-versions","resolve-conflict-file","continue-merge","abort-merge","continue-rebase","abort-rebase","get-remotes","get-remote-branches","get-tracking-branch","get-latest-commit-message","get-merge-base","push-to-remote","pull-from-remote","stash","stash-list","stash-apply","stash-drop","stash-pop","stash-files","stash-file-diff","reword","discard","cleanup-lock-file"]),data:x.z.any().optional()});async function C(e,r,t){let a=(0,k.getRepositories)().find(r=>r.path===e);if(a?.credentialId){let e=await (0,E.getCredentialById)(a.credentialId);if(e){let r=await (0,E.getCredentialToken)(e.id);if(r)return{username:e.username,token:r}}}if(t){let e=await r.getRemoteUrl(t);if(e){let r=await (0,E.findCredentialForRemote)(e);if(r)return{username:r.credential.username,token:r.token}}}}function B(e,r){return e?{mimeType:r,base64:e.toString("base64")}:null}async function T(e){try{let r=await e.json(),{repoPath:t,action:a,data:o}=y.parse(r);if(!N.default.existsSync(t))return b.NextResponse.json({error:`Path not found: ${t}`},{status:404});let i=new R.GitService(t);switch(a){case"commit":if(!o?.message)throw Error("Commit message is required");await i.commit(o.message,o.files,{initialBranch:o?.initialBranch});break;case"push":let s=await C(t,i,void 0);if(!s)try{let e=await i.getBranches(),r=e.current,a=e.trackingInfo[r];if(a&&a.upstream){let e=a.upstream.indexOf("/");if(e>0){let r=a.upstream.slice(0,e);s=await C(t,i,r)}}}catch(e){console.warn("[API] Failed to resolve upstream for push credentials:",e)}await i.push({credentials:s});break;case"pull":await i.pull();break;case"fetch":o?.allRemotes?await i.fetchAllRemotes():o?.remote?await i.fetchRemote(o.remote):await i.fetch();break;case"stage":if(!o?.files)throw Error("Files are required for staging");await i.stage(o.files);break;case"unstage":if(!o?.files)throw Error("Files are required for unstaging");await i.unstage(o.files);break;case"discard":await i.discardUnstagedChanges({includeUntracked:o?.includeUntracked??!0});break;case"checkout":if(!o?.branch)throw Error("Branch name is required for checkout");await i.checkout(o.branch);break;case"checkout-to-local":if(!o?.remoteBranch)throw Error("Remote branch is required for checkout-to-local");if(!o?.localBranch)throw Error("Local branch name is required for checkout-to-local");await i.checkoutRemoteToLocal(o.remoteBranch,o.localBranch);break;case"branch":if(!o?.branch)throw Error("Branch name is required to create branch");await i.createBranch(o.branch,o?.fromRef);break;case"create-tag":if(!o?.tagName)throw Error("Tag name is required to create tag");if(!o?.commitHash)throw Error("Commit hash is required to create tag");if(o?.pushToRemote){let e="string"==typeof o?.remote&&o.remote.trim()?o.remote.trim():void 0;if(!e){let r=await i.getBranches(),t=r.current,a=t?r.trackingInfo?.[t]?.upstream:void 0;if(a){let r=a.indexOf("/");r>0&&(e=a.slice(0,r))}}if(!e){let r=await i.getRemotes();e=r.includes("origin")?"origin":r[0]}let r=e?await C(t,i,e):void 0;await i.createTag(o.tagName,o.commitHash,{pushToRemote:!0,remote:e??void 0,credentials:r})}else await i.createTag(o.tagName,o.commitHash,{pushToRemote:!1});break;case"delete-branch":if(!o?.branch)throw Error("Branch name is required to delete branch");await i.deleteBranch(o.branch);break;case"delete-worktree":if(!o?.path)throw Error("Worktree path is required to delete worktree");await i.deleteWorktree(o.path);break;case"delete-remote-branch":if(!o?.remote)throw Error("Remote name is required to delete remote branch");if(!o?.branch)throw Error("Branch name is required to delete remote branch");let n=await C(t,i,o.remote);await i.deleteRemoteBranch(o.remote,o.branch,n);break;case"delete-remote":if(!o?.name)throw Error("Remote name is required to delete remote");await i.deleteRemote(o.name);break;case"delete-tag":if(!o?.tag)throw Error("Tag name is required to delete tag");await i.deleteTag(o.tag);break;case"delete-remote-tag":if(!o?.remote)throw Error("Remote name is required to delete remote tag");if(!o?.tag)throw Error("Tag name is required to delete remote tag");let c=await C(t,i,o.remote);await i.deleteRemoteTag(o.remote,o.tag,c);break;case"rename-branch":if(!o?.oldName)throw Error("Old branch name is required to rename branch");if(!o?.newName)throw Error("New branch name is required to rename branch");if(o?.renameTrackingRemote){let e=await i.getTrackingBranch(o.oldName),r=e?await C(t,i,e.remote):void 0;await i.renameBranch(o.oldName,o.newName,{renameTrackingRemote:!0,credentials:r})}else await i.renameBranch(o.oldName,o.newName);break;case"rename-remote-branch":if(!o?.remote)throw Error("Remote name is required to rename remote branch");if(!o?.oldName)throw Error("Old branch name is required to rename remote branch");if(!o?.newName)throw Error("New branch name is required to rename remote branch");let l=await C(t,i,o.remote);await i.renameRemoteBranch(o.remote,o.oldName,o.newName,l);break;case"rename-remote":if(!o?.oldName)throw Error("Old remote name is required to rename remote");if(!o?.newName)throw Error("New remote name is required to rename remote");await i.renameRemote(o.oldName,o.newName);break;case"add-remote":if(!o?.name)throw Error("Remote name is required to add remote");if(!o?.url)throw Error("Remote URL is required to add remote");await i.addRemote(o.name,o.url);break;case"reset":if(!o?.commitHash)throw Error("Commit hash is required for reset");await i.reset(o.commitHash,o.mode??"hard");break;case"revert":if(!o?.commitHash)throw Error("Commit hash is required for revert");await i.revert(o.commitHash);break;case"cherry-pick":if(!o?.commitHash)throw Error("Commit hash is required for cherry-pick");await i.cherryPick(o.commitHash);break;case"cherry-pick-multiple":if(!Array.isArray(o?.commitHashes)||0===o.commitHashes.length)throw Error("Commit hashes are required for multi cherry-pick");if(!o.commitHashes.every(e=>"string"==typeof e&&e.trim().length>0))throw Error("All commit hashes must be non-empty strings");await i.cherryPickMultiple(o.commitHashes);break;case"cherry-pick-abort":await i.abortCherryPick();break;case"rebase":if(!o?.ontoBranch)throw Error("Target branch is required for rebase");await i.rebase(o.ontoBranch,o.stashChanges??!0);break;case"reword":if(!o?.commitHash)throw Error("Commit hash is required for reword");if(!o?.message)throw Error("New message is required for reword");await i.reword(o.commitHash,o.message,o.branch);break;case"merge":if(!o?.targetBranch)throw Error("Target branch is required for merge");await i.merge(o.targetBranch,{rebaseBeforeMerge:o.rebaseBeforeMerge??!1,squash:o.squash??!1,fastForward:o.fastForward??!1,squashMessage:o.squashMessage});break;case"check-merge-conflicts":if(!o?.sourceBranch)throw Error("Source branch is required for merge conflict check");let h=await i.willMergeHaveConflicts(o.sourceBranch,o.targetBranch);return b.NextResponse.json({success:!0,hasConflicts:h});case"check-rebase-conflicts":if(!o?.ontoBranch)throw Error("Target branch is required for rebase conflict check");if(!o?.sourceBranch)throw Error("Source branch is required for rebase conflict check");let u=await i.willRebaseHaveConflicts(o.ontoBranch,o.sourceBranch);return b.NextResponse.json({success:!0,hasConflicts:u});case"get-conflict-state":let m=await i.getConflictState();return b.NextResponse.json({success:!0,...m});case"get-conflict-file-versions":if(!o?.path)throw Error("File path is required");let d=await i.getConflictFileVersions(o.path);return b.NextResponse.json({success:!0,...d});case"resolve-conflict-file":if(!o?.path)throw Error("File path is required");if(!o?.strategy)throw Error("Resolution strategy is required");if(!["ours","theirs","manual"].includes(o.strategy))throw Error("Resolution strategy must be ours, theirs, or manual");await i.resolveConflictFile(o.path,o.strategy,{content:o.content,stage:o.stage??!0});break;case"continue-merge":await i.continueMerge();break;case"abort-merge":await i.abortMerge();break;case"continue-rebase":await i.continueRebase();break;case"abort-rebase":await i.abortRebase();break;case"get-remotes":let f=await i.getRemotes();return b.NextResponse.json({success:!0,remotes:f});case"get-remote-branches":if(!o?.remote)throw Error("Remote name is required");let g=await i.getRemoteBranches(o.remote);return b.NextResponse.json({success:!0,branches:g});case"get-tracking-branch":if(!o?.branch)throw Error("Branch name is required");let w=await i.getTrackingBranch(o.branch);return b.NextResponse.json({success:!0,tracking:w});case"get-latest-commit-message":if(!o?.branch)throw Error("Branch name is required");let p=await i.getLatestCommitMessage(o.branch);return b.NextResponse.json({success:!0,message:p});case"get-merge-base":if(!o?.targetRef)throw Error("Target ref is required");if(!o?.sourceRef)throw Error("Source ref is required");let k=await i.getMergeBase(o.targetRef,o.sourceRef);return b.NextResponse.json({success:!0,mergeBase:k});case"push-to-remote":if(console.log("[API] push-to-remote action received:",o),!o?.localBranch)throw Error("Local branch is required");if(!o?.remote)throw Error("Remote is required");if(!o?.remoteBranch)throw Error("Remote branch is required");let E=await C(t,i,o.remote);console.log("[API] Calling git.pushToRemote..."),await i.pushToRemote(o.localBranch,o.remote,o.remoteBranch,{rebaseFirst:o.rebaseFirst??!o.forcePush,forcePush:o.forcePush??!1,pushLocalOnlyTags:o.pushLocalOnlyTags??!0,setUpstream:o.setUpstream??!1,squash:o.squash??!1,squashMessage:o.squashMessage,credentials:E}),console.log("[API] git.pushToRemote completed");break;case"pull-from-remote":if(console.log("[API] pull-from-remote action received:",o),!o?.localBranch)throw Error("Local branch is required");if(!o?.remote)throw Error("Remote is required");if(!o?.remoteBranch)throw Error("Remote branch is required");console.log("[API] Calling git.pullFromRemote..."),await i.pullFromRemote(o.localBranch,o.remote,o.remoteBranch,{rebase:o.rebase??!0}),console.log("[API] git.pullFromRemote completed");break;case"stash":await i.stash(o?.message);break;case"stash-list":let v=await i.getStashes();return b.NextResponse.json({success:!0,stashes:v});case"stash-apply":if(o?.index===void 0)throw Error("Stash index is required");await i.applyStash(o.index);break;case"stash-drop":if(o?.index===void 0)throw Error("Stash index is required");await i.dropStash(o.index);break;case"stash-pop":if(o?.index===void 0)throw Error("Stash index is required");await i.popStash(o.index);break;case"stash-files":if(o?.index===void 0)throw Error("Stash index is required");let x=await i.getStashFiles(o.index);return b.NextResponse.json({success:!0,files:x});case"stash-file-diff":if(o?.index===void 0)throw Error("Stash index is required");if(!o?.file)throw Error("File path is required");if((0,q.isImageFile)(o.file)){let e=(0,q.getImageMimeType)(o.file),[r,t,a]=await Promise.all([i.getFileContentBuffer(o.file,`stash@{${o.index}}^1`),i.getFileContentBuffer(o.file,`stash@{${o.index}}`),i.getStashFilePatch(o.index,o.file)]);return b.NextResponse.json({success:!0,left:"",right:"",diff:a,imageDiff:{left:B(r,e),right:B(t,e)}})}let T=await i.getStashFileDiff(o.index,o.file);return b.NextResponse.json({success:!0,...T});case"cleanup-lock-file":let P=await i.cleanupLockFile();return b.NextResponse.json({success:!0,cleaned:P});default:return b.NextResponse.json({error:"Invalid action"},{status:400})}return b.NextResponse.json({success:!0})}catch(e){return(0,v.handleGitError)(e)}}e.s(["POST",()=>T],76457);var P=e.i(76457);let A=new r.AppRouteRouteModule({definition:{kind:t.RouteKind.APP_ROUTE,page:"/api/git/action/route",pathname:"/api/git/action",filename:"route",bundlePath:""},distDir:".next",relativeProjectDir:"",resolvedPagePath:"[project]/src/app/api/git/action/route.ts",nextConfigOutput:"",userland:P}),{workAsyncStorage:S,workUnitAsyncStorage:H,serverHooks:F}=A;function I(){return(0,a.patchFetch)({workAsyncStorage:S,workUnitAsyncStorage:H})}async function O(e,r,a){A.isDev&&(0,o.addRequestMeta)(e,"devRequestTimingInternalsEnd",process.hrtime.bigint());let b="/api/git/action/route";b=b.replace(/\/index$/,"")||"/";let R=await A.prepare(e,r,{srcPage:b,multiZoneDraftMode:!1});if(!R)return r.statusCode=400,r.end("Bad Request"),null==a.waitUntil||a.waitUntil.call(a,Promise.resolve()),null;let{buildId:k,params:E,nextConfig:q,parsedUrl:v,isDraftMode:x,prerenderManifest:N,routerServerContext:y,isOnDemandRevalidate:C,revalidateOnlyGenerated:B,resolvedPathname:T,clientReferenceManifest:P,serverActionsManifest:S}=R,H=(0,n.normalizeAppPath)(b),F=!!(N.dynamicRoutes[H]||N.routes[T]),I=async()=>((null==y?void 0:y.render404)?await y.render404(e,r,v,!1):r.end("This page could not be found"),null);if(F&&!x){let e=!!N.routes[T],r=N.dynamicRoutes[H];if(r&&!1===r.fallback&&!e){if(q.experimental.adapterPath)return await I();throw new w.NoFallbackError}}let O=null;!F||A.isDev||x||(O="/index"===(O=T)?"/":O);let j=!0===A.isDev||!F,M=F&&!j;S&&P&&(0,s.setManifestsSingleton)({page:b,clientReferenceManifest:P,serverActionsManifest:S});let U=e.method||"GET",_=(0,i.getTracer)(),D=_.getActiveScopeSpan(),L={params:E,prerenderManifest:N,renderOpts:{experimental:{authInterrupts:!!q.experimental.authInterrupts},cacheComponents:!!q.cacheComponents,supportsDynamicResponse:j,incrementalCache:(0,o.getRequestMeta)(e,"incrementalCache"),cacheLifeProfiles:q.cacheLife,waitUntil:a.waitUntil,onClose:e=>{r.on("close",e)},onAfterTaskError:void 0,onInstrumentationRequestError:(r,t,a,o)=>A.onRequestError(e,r,a,o,y)},sharedContext:{buildId:k}},$=new c.NodeNextRequest(e),K=new c.NodeNextResponse(r),z=l.NextRequestAdapter.fromNodeNextRequest($,(0,l.signalFromNodeResponse)(r));try{let s=async e=>A.handle(z,L).finally(()=>{if(!e)return;e.setAttributes({"http.status_code":r.statusCode,"next.rsc":!1});let t=_.getRootSpanAttributes();if(!t)return;if(t.get("next.span_type")!==h.BaseServerSpan.handleRequest)return void console.warn(`Unexpected root span type '${t.get("next.span_type")}'. Please report this Next.js issue https://github.com/vercel/next.js`);let a=t.get("next.route");if(a){let r=`${U} ${a}`;e.setAttributes({"next.route":a,"http.route":a,"next.span_name":r}),e.updateName(r)}else e.updateName(`${U} ${b}`)}),n=!!(0,o.getRequestMeta)(e,"minimalMode"),c=async o=>{var i,c;let l=async({previousCacheEntry:t})=>{try{if(!n&&C&&B&&!t)return r.statusCode=404,r.setHeader("x-nextjs-cache","REVALIDATED"),r.end("This page could not be found"),null;let i=await s(o);e.fetchMetrics=L.renderOpts.fetchMetrics;let c=L.renderOpts.pendingWaitUntil;c&&a.waitUntil&&(a.waitUntil(c),c=void 0);let l=L.renderOpts.collectedTags;if(!F)return await (0,m.sendResponse)($,K,i,L.renderOpts.pendingWaitUntil),null;{let e=await i.blob(),r=(0,d.toNodeOutgoingHttpHeaders)(i.headers);l&&(r[g.NEXT_CACHE_TAGS_HEADER]=l),!r["content-type"]&&e.type&&(r["content-type"]=e.type);let t=void 0!==L.renderOpts.collectedRevalidate&&!(L.renderOpts.collectedRevalidate>=g.INFINITE_CACHE)&&L.renderOpts.collectedRevalidate,a=void 0===L.renderOpts.collectedExpire||L.renderOpts.collectedExpire>=g.INFINITE_CACHE?void 0:L.renderOpts.collectedExpire;return{value:{kind:p.CachedRouteKind.APP_ROUTE,status:i.status,body:Buffer.from(await e.arrayBuffer()),headers:r},cacheControl:{revalidate:t,expire:a}}}}catch(r){throw(null==t?void 0:t.isStale)&&await A.onRequestError(e,r,{routerKind:"App Router",routePath:b,routeType:"route",revalidateReason:(0,u.getRevalidateReason)({isStaticGeneration:M,isOnDemandRevalidate:C})},!1,y),r}},h=await A.handleResponse({req:e,nextConfig:q,cacheKey:O,routeKind:t.RouteKind.APP_ROUTE,isFallback:!1,prerenderManifest:N,isRoutePPREnabled:!1,isOnDemandRevalidate:C,revalidateOnlyGenerated:B,responseGenerator:l,waitUntil:a.waitUntil,isMinimalMode:n});if(!F)return null;if((null==h||null==(i=h.value)?void 0:i.kind)!==p.CachedRouteKind.APP_ROUTE)throw Object.defineProperty(Error(`Invariant: app-route received invalid cache entry ${null==h||null==(c=h.value)?void 0:c.kind}`),"__NEXT_ERROR_CODE",{value:"E701",enumerable:!1,configurable:!0});n||r.setHeader("x-nextjs-cache",C?"REVALIDATED":h.isMiss?"MISS":h.isStale?"STALE":"HIT"),x&&r.setHeader("Cache-Control","private, no-cache, no-store, max-age=0, must-revalidate");let w=(0,d.fromNodeOutgoingHttpHeaders)(h.value.headers);return n&&F||w.delete(g.NEXT_CACHE_TAGS_HEADER),!h.cacheControl||r.getHeader("Cache-Control")||w.get("Cache-Control")||w.set("Cache-Control",(0,f.getCacheControlHeader)(h.cacheControl)),await (0,m.sendResponse)($,K,new Response(h.value.body,{headers:w,status:h.value.status||200})),null};D?await c(D):await _.withPropagatedContext(e.headers,()=>_.trace(h.BaseServerSpan.handleRequest,{spanName:`${U} ${b}`,kind:i.SpanKind.SERVER,attributes:{"http.method":U,"http.target":e.url}},c))}catch(r){if(r instanceof w.NoFallbackError||await A.onRequestError(e,r,{routerKind:"App Router",routePath:H,routeType:"route",revalidateReason:(0,u.getRevalidateReason)({isStaticGeneration:M,isOnDemandRevalidate:C})},!1,y),F)throw r;return await (0,m.sendResponse)($,K,new Response(null,{status:500})),null}}e.s(["handler",()=>O,"patchFetch",()=>I,"routeModule",()=>A,"serverHooks",()=>F,"workAsyncStorage",()=>S,"workUnitAsyncStorage",()=>H],50081)}];
2
2
 
3
3
  //# sourceMappingURL=node_modules_next_dist_esm_build_templates_app-route_0002606b.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/app/api/git/action/route.ts","../../../node_modules/next/dist/esm/build/templates/app-route.js"],"sourcesContent":["import { NextResponse } from 'next/server';\nimport { GitService } from '@/lib/git';\nimport { getRepositories } from '@/lib/store';\nimport { getCredentialById, getCredentialToken, findCredentialForRemote } from '@/lib/credentials';\nimport { getImageMimeType, isImageFile } from '@/lib/utils';\nimport { handleGitError } from '@/lib/api-utils';\nimport { z } from 'zod';\nimport fs from 'node:fs';\n\nconst actionSchema = z.object({\n repoPath: z.string(),\n action: z.enum(['commit', 'push', 'pull', 'stage', 'unstage', 'fetch', 'checkout', 'checkout-to-local', 'branch', 'create-tag', 'delete-branch', 'delete-worktree', 'delete-remote-branch', 'delete-remote', 'delete-tag', 'delete-remote-tag', 'rename-branch', 'rename-remote-branch', 'rename-remote', 'add-remote', 'reset', 'revert', 'cherry-pick', 'cherry-pick-multiple', 'cherry-pick-abort', 'rebase', 'merge', 'check-merge-conflicts', 'check-rebase-conflicts', 'get-conflict-state', 'get-conflict-file-versions', 'resolve-conflict-file', 'continue-merge', 'abort-merge', 'continue-rebase', 'abort-rebase', 'get-remotes', 'get-remote-branches', 'get-tracking-branch', 'get-latest-commit-message', 'push-to-remote', 'pull-from-remote', 'stash', 'stash-list', 'stash-apply', 'stash-drop', 'stash-pop', 'stash-files', 'stash-file-diff', 'reword', 'discard', 'cleanup-lock-file']),\n data: z.any().optional(), // Payload depends on action\n});\n\nasync function resolveCredentials(repoPath: string, git: GitService, remoteName?: string) {\n const repos = getRepositories();\n const repoConfig = repos.find(r => r.path === repoPath);\n \n // 1. Check for explicitly associated credential\n if (repoConfig?.credentialId) {\n const cred = await getCredentialById(repoConfig.credentialId);\n if (cred) {\n const token = await getCredentialToken(cred.id);\n if (token) {\n return { username: cred.username, token };\n }\n }\n }\n\n // 2. Fallback: try to find matching credential by URL\n if (remoteName) {\n const remoteUrl = await git.getRemoteUrl(remoteName);\n if (remoteUrl) {\n const result = await findCredentialForRemote(remoteUrl);\n if (result) {\n return { username: result.credential.username, token: result.token };\n }\n }\n }\n\n return undefined;\n}\n\nfunction toImageSide(buffer: Buffer | null, mimeType: string) {\n if (!buffer) return null;\n return {\n mimeType,\n base64: buffer.toString('base64'),\n };\n}\n\nexport async function POST(request: Request) {\n try {\n const body = await request.json();\n const { repoPath, action, data } = actionSchema.parse(body);\n\n // Check if path exists\n if (!fs.existsSync(repoPath)) {\n return NextResponse.json({ error: `Path not found: ${repoPath}` }, { status: 404 });\n }\n\n const git = new GitService(repoPath);\n\n switch (action) {\n case 'commit':\n if (!data?.message) throw new Error('Commit message is required');\n await git.commit(data.message, data.files, { initialBranch: data?.initialBranch });\n break;\n case 'push':\n // Try to resolve credentials\n let pushCredentials = await resolveCredentials(repoPath, git, undefined);\n \n if (!pushCredentials) {\n // If no associated credential, try to infer from upstream\n try {\n const status = await git.getBranches();\n const current = status.current;\n const tracking = status.trackingInfo[current];\n if (tracking && tracking.upstream) {\n const slashIndex = tracking.upstream.indexOf('/');\n if (slashIndex > 0) {\n const remoteName = tracking.upstream.slice(0, slashIndex);\n pushCredentials = await resolveCredentials(repoPath, git, remoteName);\n }\n }\n } catch (e) {\n // Ignore errors finding upstream, just proceed without creds\n console.warn('[API] Failed to resolve upstream for push credentials:', e);\n }\n }\n \n await git.push({ credentials: pushCredentials });\n break;\n case 'pull':\n await git.pull();\n break;\n case 'fetch':\n if (data?.allRemotes) {\n await git.fetchAllRemotes();\n } else if (data?.remote) {\n await git.fetchRemote(data.remote);\n } else {\n await git.fetch();\n }\n break;\n case 'stage':\n if (!data?.files) throw new Error('Files are required for staging');\n await git.stage(data.files);\n break;\n case 'unstage':\n if (!data?.files) throw new Error('Files are required for unstaging');\n await git.unstage(data.files);\n break;\n case 'discard':\n await git.discardUnstagedChanges({\n includeUntracked: data?.includeUntracked ?? true,\n });\n break;\n case 'checkout':\n if (!data?.branch) throw new Error('Branch name is required for checkout');\n await git.checkout(data.branch);\n break;\n case 'checkout-to-local':\n if (!data?.remoteBranch) throw new Error('Remote branch is required for checkout-to-local');\n if (!data?.localBranch) throw new Error('Local branch name is required for checkout-to-local');\n await git.checkoutRemoteToLocal(data.remoteBranch, data.localBranch);\n break;\n case 'branch':\n if (!data?.branch) throw new Error('Branch name is required to create branch');\n await git.createBranch(data.branch, data?.fromRef);\n break;\n case 'create-tag':\n if (!data?.tagName) throw new Error('Tag name is required to create tag');\n if (!data?.commitHash) throw new Error('Commit hash is required to create tag');\n if (data?.pushToRemote) {\n let remoteForTag = typeof data?.remote === 'string' && data.remote.trim() ? data.remote.trim() : undefined;\n if (!remoteForTag) {\n const branches = await git.getBranches();\n const current = branches.current;\n const trackingUpstream = current ? branches.trackingInfo?.[current]?.upstream : undefined;\n if (trackingUpstream) {\n const slashIndex = trackingUpstream.indexOf('/');\n if (slashIndex > 0) {\n remoteForTag = trackingUpstream.slice(0, slashIndex);\n }\n }\n }\n if (!remoteForTag) {\n const remotes = await git.getRemotes();\n if (remotes.includes('origin')) {\n remoteForTag = 'origin';\n } else {\n remoteForTag = remotes[0];\n }\n }\n\n const tagCreds = remoteForTag ? await resolveCredentials(repoPath, git, remoteForTag) : undefined;\n await git.createTag(data.tagName, data.commitHash, {\n pushToRemote: true,\n remote: remoteForTag ?? undefined,\n credentials: tagCreds,\n });\n } else {\n await git.createTag(data.tagName, data.commitHash, { pushToRemote: false });\n }\n break;\n case 'delete-branch':\n if (!data?.branch) throw new Error('Branch name is required to delete branch');\n await git.deleteBranch(data.branch);\n break;\n case 'delete-worktree':\n if (!data?.path) throw new Error('Worktree path is required to delete worktree');\n await git.deleteWorktree(data.path);\n break;\n case 'delete-remote-branch':\n if (!data?.remote) throw new Error('Remote name is required to delete remote branch');\n if (!data?.branch) throw new Error('Branch name is required to delete remote branch');\n \n const deleteCreds = await resolveCredentials(repoPath, git, data.remote);\n await git.deleteRemoteBranch(data.remote, data.branch, deleteCreds);\n break;\n case 'delete-remote':\n if (!data?.name) throw new Error('Remote name is required to delete remote');\n await git.deleteRemote(data.name);\n break;\n case 'delete-tag':\n if (!data?.tag) throw new Error('Tag name is required to delete tag');\n await git.deleteTag(data.tag);\n break;\n case 'delete-remote-tag':\n if (!data?.remote) throw new Error('Remote name is required to delete remote tag');\n if (!data?.tag) throw new Error('Tag name is required to delete remote tag');\n\n const deleteTagCreds = await resolveCredentials(repoPath, git, data.remote);\n await git.deleteRemoteTag(data.remote, data.tag, deleteTagCreds);\n break;\n case 'rename-branch':\n if (!data?.oldName) throw new Error('Old branch name is required to rename branch');\n if (!data?.newName) throw new Error('New branch name is required to rename branch');\n if (data?.renameTrackingRemote) {\n const tracking = await git.getTrackingBranch(data.oldName);\n const renameTrackingCreds = tracking\n ? await resolveCredentials(repoPath, git, tracking.remote)\n : undefined;\n await git.renameBranch(data.oldName, data.newName, {\n renameTrackingRemote: true,\n credentials: renameTrackingCreds,\n });\n } else {\n await git.renameBranch(data.oldName, data.newName);\n }\n break;\n case 'rename-remote-branch':\n if (!data?.remote) throw new Error('Remote name is required to rename remote branch');\n if (!data?.oldName) throw new Error('Old branch name is required to rename remote branch');\n if (!data?.newName) throw new Error('New branch name is required to rename remote branch');\n\n const renameCreds = await resolveCredentials(repoPath, git, data.remote);\n await git.renameRemoteBranch(data.remote, data.oldName, data.newName, renameCreds);\n break;\n case 'rename-remote':\n if (!data?.oldName) throw new Error('Old remote name is required to rename remote');\n if (!data?.newName) throw new Error('New remote name is required to rename remote');\n await git.renameRemote(data.oldName, data.newName);\n break;\n case 'add-remote':\n if (!data?.name) throw new Error('Remote name is required to add remote');\n if (!data?.url) throw new Error('Remote URL is required to add remote');\n await git.addRemote(data.name, data.url);\n break;\n case 'reset':\n if (!data?.commitHash) throw new Error('Commit hash is required for reset');\n await git.reset(data.commitHash, data.mode ?? 'hard');\n break;\n case 'revert':\n if (!data?.commitHash) throw new Error('Commit hash is required for revert');\n await git.revert(data.commitHash);\n break;\n case 'cherry-pick':\n if (!data?.commitHash) throw new Error('Commit hash is required for cherry-pick');\n await git.cherryPick(data.commitHash);\n break;\n case 'cherry-pick-multiple':\n if (!Array.isArray(data?.commitHashes) || data.commitHashes.length === 0) {\n throw new Error('Commit hashes are required for multi cherry-pick');\n }\n if (!data.commitHashes.every((hash: unknown) => typeof hash === 'string' && hash.trim().length > 0)) {\n throw new Error('All commit hashes must be non-empty strings');\n }\n await git.cherryPickMultiple(data.commitHashes);\n break;\n case 'cherry-pick-abort':\n await git.abortCherryPick();\n break;\n case 'rebase':\n if (!data?.ontoBranch) throw new Error('Target branch is required for rebase');\n await git.rebase(data.ontoBranch, data.stashChanges ?? true);\n break;\n case 'reword':\n if (!data?.commitHash) throw new Error('Commit hash is required for reword');\n if (!data?.message) throw new Error('New message is required for reword');\n await git.reword(data.commitHash, data.message, data.branch);\n break;\n case 'merge':\n if (!data?.targetBranch) throw new Error('Target branch is required for merge');\n await git.merge(data.targetBranch, {\n rebaseBeforeMerge: data.rebaseBeforeMerge ?? false,\n squash: data.squash ?? false,\n fastForward: data.fastForward ?? false,\n squashMessage: data.squashMessage,\n });\n break;\n case 'check-merge-conflicts':\n if (!data?.sourceBranch) throw new Error('Source branch is required for merge conflict check');\n const hasConflicts = await git.willMergeHaveConflicts(data.sourceBranch, data.targetBranch);\n return NextResponse.json({ success: true, hasConflicts });\n case 'check-rebase-conflicts':\n if (!data?.ontoBranch) throw new Error('Target branch is required for rebase conflict check');\n if (!data?.sourceBranch) throw new Error('Source branch is required for rebase conflict check');\n const hasRebaseConflicts = await git.willRebaseHaveConflicts(data.ontoBranch, data.sourceBranch);\n return NextResponse.json({ success: true, hasConflicts: hasRebaseConflicts });\n case 'get-conflict-state':\n const conflictState = await git.getConflictState();\n return NextResponse.json({ success: true, ...conflictState });\n case 'get-conflict-file-versions':\n if (!data?.path) throw new Error('File path is required');\n const versions = await git.getConflictFileVersions(data.path);\n return NextResponse.json({ success: true, ...versions });\n case 'resolve-conflict-file':\n if (!data?.path) throw new Error('File path is required');\n if (!data?.strategy) throw new Error('Resolution strategy is required');\n if (!['ours', 'theirs', 'manual'].includes(data.strategy)) {\n throw new Error('Resolution strategy must be ours, theirs, or manual');\n }\n await git.resolveConflictFile(data.path, data.strategy, {\n content: data.content,\n stage: data.stage ?? true,\n });\n break;\n case 'continue-merge':\n await git.continueMerge();\n break;\n case 'abort-merge':\n await git.abortMerge();\n break;\n case 'continue-rebase':\n await git.continueRebase();\n break;\n case 'abort-rebase':\n await git.abortRebase();\n break;\n case 'get-remotes':\n const remotes = await git.getRemotes();\n return NextResponse.json({ success: true, remotes });\n case 'get-remote-branches':\n if (!data?.remote) throw new Error('Remote name is required');\n const remoteBranches = await git.getRemoteBranches(data.remote);\n return NextResponse.json({ success: true, branches: remoteBranches });\n case 'get-tracking-branch':\n if (!data?.branch) throw new Error('Branch name is required');\n const tracking = await git.getTrackingBranch(data.branch);\n return NextResponse.json({ success: true, tracking });\n case 'get-latest-commit-message':\n if (!data?.branch) throw new Error('Branch name is required');\n const message = await git.getLatestCommitMessage(data.branch);\n return NextResponse.json({ success: true, message });\n case 'push-to-remote':\n console.log('[API] push-to-remote action received:', data);\n if (!data?.localBranch) throw new Error('Local branch is required');\n if (!data?.remote) throw new Error('Remote is required');\n if (!data?.remoteBranch) throw new Error('Remote branch is required');\n \n const creds = await resolveCredentials(repoPath, git, data.remote);\n \n console.log('[API] Calling git.pushToRemote...');\n await git.pushToRemote(data.localBranch, data.remote, data.remoteBranch, {\n rebaseFirst: data.rebaseFirst ?? !(data.forcePush ?? false),\n forcePush: data.forcePush ?? false,\n pushLocalOnlyTags: data.pushLocalOnlyTags ?? true,\n setUpstream: data.setUpstream ?? false,\n squash: data.squash ?? false,\n squashMessage: data.squashMessage,\n credentials: creds,\n });\n console.log('[API] git.pushToRemote completed');\n break;\n case 'pull-from-remote':\n console.log('[API] pull-from-remote action received:', data);\n if (!data?.localBranch) throw new Error('Local branch is required');\n if (!data?.remote) throw new Error('Remote is required');\n if (!data?.remoteBranch) throw new Error('Remote branch is required');\n console.log('[API] Calling git.pullFromRemote...');\n await git.pullFromRemote(data.localBranch, data.remote, data.remoteBranch, {\n rebase: data.rebase ?? true,\n });\n console.log('[API] git.pullFromRemote completed');\n break;\n case 'stash':\n await git.stash(data?.message);\n break;\n case 'stash-list':\n const stashes = await git.getStashes();\n return NextResponse.json({ success: true, stashes });\n case 'stash-apply':\n if (data?.index === undefined) throw new Error('Stash index is required');\n await git.applyStash(data.index);\n break;\n case 'stash-drop':\n if (data?.index === undefined) throw new Error('Stash index is required');\n await git.dropStash(data.index);\n break;\n case 'stash-pop':\n if (data?.index === undefined) throw new Error('Stash index is required');\n await git.popStash(data.index);\n break;\n case 'stash-files':\n if (data?.index === undefined) throw new Error('Stash index is required');\n const stashFiles = await git.getStashFiles(data.index);\n return NextResponse.json({ success: true, files: stashFiles });\n case 'stash-file-diff':\n if (data?.index === undefined) throw new Error('Stash index is required');\n if (!data?.file) throw new Error('File path is required');\n if (isImageFile(data.file)) {\n const mimeType = getImageMimeType(data.file);\n const [leftBuffer, rightBuffer, diff] = await Promise.all([\n git.getFileContentBuffer(data.file, `stash@{${data.index}}^1`),\n git.getFileContentBuffer(data.file, `stash@{${data.index}}`),\n git.getStashFilePatch(data.index, data.file),\n ]);\n\n return NextResponse.json({\n success: true,\n left: '',\n right: '',\n diff,\n imageDiff: {\n left: toImageSide(leftBuffer, mimeType),\n right: toImageSide(rightBuffer, mimeType),\n },\n });\n }\n\n const stashFileDiff = await git.getStashFileDiff(data.index, data.file);\n return NextResponse.json({ success: true, ...stashFileDiff });\n case 'cleanup-lock-file':\n const cleaned = await git.cleanupLockFile();\n return NextResponse.json({ success: true, cleaned });\n default:\n return NextResponse.json({ error: 'Invalid action' }, { status: 400 });\n }\n\n return NextResponse.json({ success: true });\n } catch (error) {\n return handleGitError(error);\n }\n}\n","import { AppRouteRouteModule } from \"next/dist/esm/server/route-modules/app-route/module.compiled\";\nimport { RouteKind } from \"next/dist/esm/server/route-kind\";\nimport { patchFetch as _patchFetch } from \"next/dist/esm/server/lib/patch-fetch\";\nimport { addRequestMeta, getRequestMeta } from \"next/dist/esm/server/request-meta\";\nimport { getTracer, SpanKind } from \"next/dist/esm/server/lib/trace/tracer\";\nimport { setManifestsSingleton } from \"next/dist/esm/server/app-render/manifests-singleton\";\nimport { normalizeAppPath } from \"next/dist/esm/shared/lib/router/utils/app-paths\";\nimport { NodeNextRequest, NodeNextResponse } from \"next/dist/esm/server/base-http/node\";\nimport { NextRequestAdapter, signalFromNodeResponse } from \"next/dist/esm/server/web/spec-extension/adapters/next-request\";\nimport { BaseServerSpan } from \"next/dist/esm/server/lib/trace/constants\";\nimport { getRevalidateReason } from \"next/dist/esm/server/instrumentation/utils\";\nimport { sendResponse } from \"next/dist/esm/server/send-response\";\nimport { fromNodeOutgoingHttpHeaders, toNodeOutgoingHttpHeaders } from \"next/dist/esm/server/web/utils\";\nimport { getCacheControlHeader } from \"next/dist/esm/server/lib/cache-control\";\nimport { INFINITE_CACHE, NEXT_CACHE_TAGS_HEADER } from \"next/dist/esm/lib/constants\";\nimport { NoFallbackError } from \"next/dist/esm/shared/lib/no-fallback-error.external\";\nimport { CachedRouteKind } from \"next/dist/esm/server/response-cache\";\nimport * as userland from \"INNER_APP_ROUTE\";\n// We inject the nextConfigOutput here so that we can use them in the route\n// module.\nconst nextConfigOutput = \"\"\nconst routeModule = new AppRouteRouteModule({\n definition: {\n kind: RouteKind.APP_ROUTE,\n page: \"/api/git/action/route\",\n pathname: \"/api/git/action\",\n filename: \"route\",\n bundlePath: \"\"\n },\n distDir: process.env.__NEXT_RELATIVE_DIST_DIR || '',\n relativeProjectDir: process.env.__NEXT_RELATIVE_PROJECT_DIR || '',\n resolvedPagePath: \"[project]/src/app/api/git/action/route.ts\",\n nextConfigOutput,\n userland\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;\nfunction patchFetch() {\n return _patchFetch({\n workAsyncStorage,\n workUnitAsyncStorage\n });\n}\nexport { routeModule, workAsyncStorage, workUnitAsyncStorage, serverHooks, patchFetch, };\nexport async function handler(req, res, ctx) {\n if (routeModule.isDev) {\n addRequestMeta(req, 'devRequestTimingInternalsEnd', process.hrtime.bigint());\n }\n let srcPage = \"/api/git/action/route\";\n // turbopack doesn't normalize `/index` in the page name\n // so we need to to process dynamic routes properly\n // TODO: fix turbopack providing differing value from webpack\n if (process.env.TURBOPACK) {\n srcPage = srcPage.replace(/\\/index$/, '') || '/';\n } else if (srcPage === '/index') {\n // we always normalize /index specifically\n srcPage = '/';\n }\n const multiZoneDraftMode = process.env.__NEXT_MULTI_ZONE_DRAFT_MODE;\n const prepareResult = await routeModule.prepare(req, res, {\n srcPage,\n multiZoneDraftMode\n });\n if (!prepareResult) {\n res.statusCode = 400;\n res.end('Bad Request');\n ctx.waitUntil == null ? void 0 : ctx.waitUntil.call(ctx, Promise.resolve());\n return null;\n }\n const { buildId, params, nextConfig, parsedUrl, isDraftMode, prerenderManifest, routerServerContext, isOnDemandRevalidate, revalidateOnlyGenerated, resolvedPathname, clientReferenceManifest, serverActionsManifest } = prepareResult;\n const normalizedSrcPage = normalizeAppPath(srcPage);\n let isIsr = Boolean(prerenderManifest.dynamicRoutes[normalizedSrcPage] || prerenderManifest.routes[resolvedPathname]);\n const render404 = async ()=>{\n // TODO: should route-module itself handle rendering the 404\n if (routerServerContext == null ? void 0 : routerServerContext.render404) {\n await routerServerContext.render404(req, res, parsedUrl, false);\n } else {\n res.end('This page could not be found');\n }\n return null;\n };\n if (isIsr && !isDraftMode) {\n const isPrerendered = Boolean(prerenderManifest.routes[resolvedPathname]);\n const prerenderInfo = prerenderManifest.dynamicRoutes[normalizedSrcPage];\n if (prerenderInfo) {\n if (prerenderInfo.fallback === false && !isPrerendered) {\n if (nextConfig.experimental.adapterPath) {\n return await render404();\n }\n throw new NoFallbackError();\n }\n }\n }\n let cacheKey = null;\n if (isIsr && !routeModule.isDev && !isDraftMode) {\n cacheKey = resolvedPathname;\n // ensure /index and / is normalized to one key\n cacheKey = cacheKey === '/index' ? '/' : cacheKey;\n }\n const supportsDynamicResponse = // If we're in development, we always support dynamic HTML\n routeModule.isDev === true || // If this is not SSG or does not have static paths, then it supports\n // dynamic HTML.\n !isIsr;\n // This is a revalidation request if the request is for a static\n // page and it is not being resumed from a postponed render and\n // it is not a dynamic RSC request then it is a revalidation\n // request.\n const isStaticGeneration = isIsr && !supportsDynamicResponse;\n // Before rendering (which initializes component tree modules), we have to\n // set the reference manifests to our global store so Server Action's\n // encryption util can access to them at the top level of the page module.\n if (serverActionsManifest && clientReferenceManifest) {\n setManifestsSingleton({\n page: srcPage,\n clientReferenceManifest,\n serverActionsManifest\n });\n }\n const method = req.method || 'GET';\n const tracer = getTracer();\n const activeSpan = tracer.getActiveScopeSpan();\n const context = {\n params,\n prerenderManifest,\n renderOpts: {\n experimental: {\n authInterrupts: Boolean(nextConfig.experimental.authInterrupts)\n },\n cacheComponents: Boolean(nextConfig.cacheComponents),\n supportsDynamicResponse,\n incrementalCache: getRequestMeta(req, 'incrementalCache'),\n cacheLifeProfiles: nextConfig.cacheLife,\n waitUntil: ctx.waitUntil,\n onClose: (cb)=>{\n res.on('close', cb);\n },\n onAfterTaskError: undefined,\n onInstrumentationRequestError: (error, _request, errorContext, silenceLog)=>routeModule.onRequestError(req, error, errorContext, silenceLog, routerServerContext)\n },\n sharedContext: {\n buildId\n }\n };\n const nodeNextReq = new NodeNextRequest(req);\n const nodeNextRes = new NodeNextResponse(res);\n const nextReq = NextRequestAdapter.fromNodeNextRequest(nodeNextReq, signalFromNodeResponse(res));\n try {\n const invokeRouteModule = async (span)=>{\n return routeModule.handle(nextReq, context).finally(()=>{\n if (!span) return;\n span.setAttributes({\n 'http.status_code': res.statusCode,\n 'next.rsc': false\n });\n const rootSpanAttributes = tracer.getRootSpanAttributes();\n // We were unable to get attributes, probably OTEL is not enabled\n if (!rootSpanAttributes) {\n return;\n }\n if (rootSpanAttributes.get('next.span_type') !== BaseServerSpan.handleRequest) {\n console.warn(`Unexpected root span type '${rootSpanAttributes.get('next.span_type')}'. Please report this Next.js issue https://github.com/vercel/next.js`);\n return;\n }\n const route = rootSpanAttributes.get('next.route');\n if (route) {\n const name = `${method} ${route}`;\n span.setAttributes({\n 'next.route': route,\n 'http.route': route,\n 'next.span_name': name\n });\n span.updateName(name);\n } else {\n span.updateName(`${method} ${srcPage}`);\n }\n });\n };\n const isMinimalMode = Boolean(process.env.MINIMAL_MODE || getRequestMeta(req, 'minimalMode'));\n const handleResponse = async (currentSpan)=>{\n var _cacheEntry_value;\n const responseGenerator = async ({ previousCacheEntry })=>{\n try {\n if (!isMinimalMode && isOnDemandRevalidate && revalidateOnlyGenerated && !previousCacheEntry) {\n res.statusCode = 404;\n // on-demand revalidate always sets this header\n res.setHeader('x-nextjs-cache', 'REVALIDATED');\n res.end('This page could not be found');\n return null;\n }\n const response = await invokeRouteModule(currentSpan);\n req.fetchMetrics = context.renderOpts.fetchMetrics;\n let pendingWaitUntil = context.renderOpts.pendingWaitUntil;\n // Attempt using provided waitUntil if available\n // if it's not we fallback to sendResponse's handling\n if (pendingWaitUntil) {\n if (ctx.waitUntil) {\n ctx.waitUntil(pendingWaitUntil);\n pendingWaitUntil = undefined;\n }\n }\n const cacheTags = context.renderOpts.collectedTags;\n // If the request is for a static response, we can cache it so long\n // as it's not edge.\n if (isIsr) {\n const blob = await response.blob();\n // Copy the headers from the response.\n const headers = toNodeOutgoingHttpHeaders(response.headers);\n if (cacheTags) {\n headers[NEXT_CACHE_TAGS_HEADER] = cacheTags;\n }\n if (!headers['content-type'] && blob.type) {\n headers['content-type'] = blob.type;\n }\n const revalidate = typeof context.renderOpts.collectedRevalidate === 'undefined' || context.renderOpts.collectedRevalidate >= INFINITE_CACHE ? false : context.renderOpts.collectedRevalidate;\n const expire = typeof context.renderOpts.collectedExpire === 'undefined' || context.renderOpts.collectedExpire >= INFINITE_CACHE ? undefined : context.renderOpts.collectedExpire;\n // Create the cache entry for the response.\n const cacheEntry = {\n value: {\n kind: CachedRouteKind.APP_ROUTE,\n status: response.status,\n body: Buffer.from(await blob.arrayBuffer()),\n headers\n },\n cacheControl: {\n revalidate,\n expire\n }\n };\n return cacheEntry;\n } else {\n // send response without caching if not ISR\n await sendResponse(nodeNextReq, nodeNextRes, response, context.renderOpts.pendingWaitUntil);\n return null;\n }\n } catch (err) {\n // if this is a background revalidate we need to report\n // the request error here as it won't be bubbled\n if (previousCacheEntry == null ? void 0 : previousCacheEntry.isStale) {\n const silenceLog = false;\n await routeModule.onRequestError(req, err, {\n routerKind: 'App Router',\n routePath: srcPage,\n routeType: 'route',\n revalidateReason: getRevalidateReason({\n isStaticGeneration,\n isOnDemandRevalidate\n })\n }, silenceLog, routerServerContext);\n }\n throw err;\n }\n };\n const cacheEntry = await routeModule.handleResponse({\n req,\n nextConfig,\n cacheKey,\n routeKind: RouteKind.APP_ROUTE,\n isFallback: false,\n prerenderManifest,\n isRoutePPREnabled: false,\n isOnDemandRevalidate,\n revalidateOnlyGenerated,\n responseGenerator,\n waitUntil: ctx.waitUntil,\n isMinimalMode\n });\n // we don't create a cacheEntry for ISR\n if (!isIsr) {\n return null;\n }\n if ((cacheEntry == null ? void 0 : (_cacheEntry_value = cacheEntry.value) == null ? void 0 : _cacheEntry_value.kind) !== CachedRouteKind.APP_ROUTE) {\n var _cacheEntry_value1;\n throw Object.defineProperty(new Error(`Invariant: app-route received invalid cache entry ${cacheEntry == null ? void 0 : (_cacheEntry_value1 = cacheEntry.value) == null ? void 0 : _cacheEntry_value1.kind}`), \"__NEXT_ERROR_CODE\", {\n value: \"E701\",\n enumerable: false,\n configurable: true\n });\n }\n if (!isMinimalMode) {\n res.setHeader('x-nextjs-cache', isOnDemandRevalidate ? 'REVALIDATED' : cacheEntry.isMiss ? 'MISS' : cacheEntry.isStale ? 'STALE' : 'HIT');\n }\n // Draft mode should never be cached\n if (isDraftMode) {\n res.setHeader('Cache-Control', 'private, no-cache, no-store, max-age=0, must-revalidate');\n }\n const headers = fromNodeOutgoingHttpHeaders(cacheEntry.value.headers);\n if (!(isMinimalMode && isIsr)) {\n headers.delete(NEXT_CACHE_TAGS_HEADER);\n }\n // If cache control is already set on the response we don't\n // override it to allow users to customize it via next.config\n if (cacheEntry.cacheControl && !res.getHeader('Cache-Control') && !headers.get('Cache-Control')) {\n headers.set('Cache-Control', getCacheControlHeader(cacheEntry.cacheControl));\n }\n await sendResponse(nodeNextReq, nodeNextRes, // @ts-expect-error - Argument of type 'Buffer<ArrayBufferLike>' is not assignable to parameter of type 'BodyInit | null | undefined'.\n new Response(cacheEntry.value.body, {\n headers,\n status: cacheEntry.value.status || 200\n }));\n return null;\n };\n // TODO: activeSpan code path is for when wrapped by\n // next-server can be removed when this is no longer used\n if (activeSpan) {\n await handleResponse(activeSpan);\n } else {\n await tracer.withPropagatedContext(req.headers, ()=>tracer.trace(BaseServerSpan.handleRequest, {\n spanName: `${method} ${srcPage}`,\n kind: SpanKind.SERVER,\n attributes: {\n 'http.method': method,\n 'http.target': req.url\n }\n }, handleResponse));\n }\n } catch (err) {\n if (!(err instanceof NoFallbackError)) {\n const silenceLog = false;\n await routeModule.onRequestError(req, err, {\n routerKind: 'App Router',\n routePath: normalizedSrcPage,\n routeType: 'route',\n revalidateReason: getRevalidateReason({\n isStaticGeneration,\n isOnDemandRevalidate\n })\n }, silenceLog, routerServerContext);\n }\n // rethrow so that we can handle serving error page\n // If this is during static generation, throw the error again.\n if (isIsr) throw err;\n // Otherwise, send a 500 response.\n await sendResponse(nodeNextReq, nodeNextRes, new Response(null, {\n status: 500\n }));\n return null;\n }\n}\n\n//# sourceMappingURL=app-route.js.map\n"],"names":[],"mappings":"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","ignoreList":[1]}
1
+ {"version":3,"sources":["../../../node_modules/next/dist/esm/build/templates/app-route.js","../../../src/app/api/git/action/route.ts"],"sourcesContent":["import { AppRouteRouteModule } from \"next/dist/esm/server/route-modules/app-route/module.compiled\";\nimport { RouteKind } from \"next/dist/esm/server/route-kind\";\nimport { patchFetch as _patchFetch } from \"next/dist/esm/server/lib/patch-fetch\";\nimport { addRequestMeta, getRequestMeta } from \"next/dist/esm/server/request-meta\";\nimport { getTracer, SpanKind } from \"next/dist/esm/server/lib/trace/tracer\";\nimport { setManifestsSingleton } from \"next/dist/esm/server/app-render/manifests-singleton\";\nimport { normalizeAppPath } from \"next/dist/esm/shared/lib/router/utils/app-paths\";\nimport { NodeNextRequest, NodeNextResponse } from \"next/dist/esm/server/base-http/node\";\nimport { NextRequestAdapter, signalFromNodeResponse } from \"next/dist/esm/server/web/spec-extension/adapters/next-request\";\nimport { BaseServerSpan } from \"next/dist/esm/server/lib/trace/constants\";\nimport { getRevalidateReason } from \"next/dist/esm/server/instrumentation/utils\";\nimport { sendResponse } from \"next/dist/esm/server/send-response\";\nimport { fromNodeOutgoingHttpHeaders, toNodeOutgoingHttpHeaders } from \"next/dist/esm/server/web/utils\";\nimport { getCacheControlHeader } from \"next/dist/esm/server/lib/cache-control\";\nimport { INFINITE_CACHE, NEXT_CACHE_TAGS_HEADER } from \"next/dist/esm/lib/constants\";\nimport { NoFallbackError } from \"next/dist/esm/shared/lib/no-fallback-error.external\";\nimport { CachedRouteKind } from \"next/dist/esm/server/response-cache\";\nimport * as userland from \"INNER_APP_ROUTE\";\n// We inject the nextConfigOutput here so that we can use them in the route\n// module.\nconst nextConfigOutput = \"\"\nconst routeModule = new AppRouteRouteModule({\n definition: {\n kind: RouteKind.APP_ROUTE,\n page: \"/api/git/action/route\",\n pathname: \"/api/git/action\",\n filename: \"route\",\n bundlePath: \"\"\n },\n distDir: process.env.__NEXT_RELATIVE_DIST_DIR || '',\n relativeProjectDir: process.env.__NEXT_RELATIVE_PROJECT_DIR || '',\n resolvedPagePath: \"[project]/src/app/api/git/action/route.ts\",\n nextConfigOutput,\n userland\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;\nfunction patchFetch() {\n return _patchFetch({\n workAsyncStorage,\n workUnitAsyncStorage\n });\n}\nexport { routeModule, workAsyncStorage, workUnitAsyncStorage, serverHooks, patchFetch, };\nexport async function handler(req, res, ctx) {\n if (routeModule.isDev) {\n addRequestMeta(req, 'devRequestTimingInternalsEnd', process.hrtime.bigint());\n }\n let srcPage = \"/api/git/action/route\";\n // turbopack doesn't normalize `/index` in the page name\n // so we need to to process dynamic routes properly\n // TODO: fix turbopack providing differing value from webpack\n if (process.env.TURBOPACK) {\n srcPage = srcPage.replace(/\\/index$/, '') || '/';\n } else if (srcPage === '/index') {\n // we always normalize /index specifically\n srcPage = '/';\n }\n const multiZoneDraftMode = process.env.__NEXT_MULTI_ZONE_DRAFT_MODE;\n const prepareResult = await routeModule.prepare(req, res, {\n srcPage,\n multiZoneDraftMode\n });\n if (!prepareResult) {\n res.statusCode = 400;\n res.end('Bad Request');\n ctx.waitUntil == null ? void 0 : ctx.waitUntil.call(ctx, Promise.resolve());\n return null;\n }\n const { buildId, params, nextConfig, parsedUrl, isDraftMode, prerenderManifest, routerServerContext, isOnDemandRevalidate, revalidateOnlyGenerated, resolvedPathname, clientReferenceManifest, serverActionsManifest } = prepareResult;\n const normalizedSrcPage = normalizeAppPath(srcPage);\n let isIsr = Boolean(prerenderManifest.dynamicRoutes[normalizedSrcPage] || prerenderManifest.routes[resolvedPathname]);\n const render404 = async ()=>{\n // TODO: should route-module itself handle rendering the 404\n if (routerServerContext == null ? void 0 : routerServerContext.render404) {\n await routerServerContext.render404(req, res, parsedUrl, false);\n } else {\n res.end('This page could not be found');\n }\n return null;\n };\n if (isIsr && !isDraftMode) {\n const isPrerendered = Boolean(prerenderManifest.routes[resolvedPathname]);\n const prerenderInfo = prerenderManifest.dynamicRoutes[normalizedSrcPage];\n if (prerenderInfo) {\n if (prerenderInfo.fallback === false && !isPrerendered) {\n if (nextConfig.experimental.adapterPath) {\n return await render404();\n }\n throw new NoFallbackError();\n }\n }\n }\n let cacheKey = null;\n if (isIsr && !routeModule.isDev && !isDraftMode) {\n cacheKey = resolvedPathname;\n // ensure /index and / is normalized to one key\n cacheKey = cacheKey === '/index' ? '/' : cacheKey;\n }\n const supportsDynamicResponse = // If we're in development, we always support dynamic HTML\n routeModule.isDev === true || // If this is not SSG or does not have static paths, then it supports\n // dynamic HTML.\n !isIsr;\n // This is a revalidation request if the request is for a static\n // page and it is not being resumed from a postponed render and\n // it is not a dynamic RSC request then it is a revalidation\n // request.\n const isStaticGeneration = isIsr && !supportsDynamicResponse;\n // Before rendering (which initializes component tree modules), we have to\n // set the reference manifests to our global store so Server Action's\n // encryption util can access to them at the top level of the page module.\n if (serverActionsManifest && clientReferenceManifest) {\n setManifestsSingleton({\n page: srcPage,\n clientReferenceManifest,\n serverActionsManifest\n });\n }\n const method = req.method || 'GET';\n const tracer = getTracer();\n const activeSpan = tracer.getActiveScopeSpan();\n const context = {\n params,\n prerenderManifest,\n renderOpts: {\n experimental: {\n authInterrupts: Boolean(nextConfig.experimental.authInterrupts)\n },\n cacheComponents: Boolean(nextConfig.cacheComponents),\n supportsDynamicResponse,\n incrementalCache: getRequestMeta(req, 'incrementalCache'),\n cacheLifeProfiles: nextConfig.cacheLife,\n waitUntil: ctx.waitUntil,\n onClose: (cb)=>{\n res.on('close', cb);\n },\n onAfterTaskError: undefined,\n onInstrumentationRequestError: (error, _request, errorContext, silenceLog)=>routeModule.onRequestError(req, error, errorContext, silenceLog, routerServerContext)\n },\n sharedContext: {\n buildId\n }\n };\n const nodeNextReq = new NodeNextRequest(req);\n const nodeNextRes = new NodeNextResponse(res);\n const nextReq = NextRequestAdapter.fromNodeNextRequest(nodeNextReq, signalFromNodeResponse(res));\n try {\n const invokeRouteModule = async (span)=>{\n return routeModule.handle(nextReq, context).finally(()=>{\n if (!span) return;\n span.setAttributes({\n 'http.status_code': res.statusCode,\n 'next.rsc': false\n });\n const rootSpanAttributes = tracer.getRootSpanAttributes();\n // We were unable to get attributes, probably OTEL is not enabled\n if (!rootSpanAttributes) {\n return;\n }\n if (rootSpanAttributes.get('next.span_type') !== BaseServerSpan.handleRequest) {\n console.warn(`Unexpected root span type '${rootSpanAttributes.get('next.span_type')}'. Please report this Next.js issue https://github.com/vercel/next.js`);\n return;\n }\n const route = rootSpanAttributes.get('next.route');\n if (route) {\n const name = `${method} ${route}`;\n span.setAttributes({\n 'next.route': route,\n 'http.route': route,\n 'next.span_name': name\n });\n span.updateName(name);\n } else {\n span.updateName(`${method} ${srcPage}`);\n }\n });\n };\n const isMinimalMode = Boolean(process.env.MINIMAL_MODE || getRequestMeta(req, 'minimalMode'));\n const handleResponse = async (currentSpan)=>{\n var _cacheEntry_value;\n const responseGenerator = async ({ previousCacheEntry })=>{\n try {\n if (!isMinimalMode && isOnDemandRevalidate && revalidateOnlyGenerated && !previousCacheEntry) {\n res.statusCode = 404;\n // on-demand revalidate always sets this header\n res.setHeader('x-nextjs-cache', 'REVALIDATED');\n res.end('This page could not be found');\n return null;\n }\n const response = await invokeRouteModule(currentSpan);\n req.fetchMetrics = context.renderOpts.fetchMetrics;\n let pendingWaitUntil = context.renderOpts.pendingWaitUntil;\n // Attempt using provided waitUntil if available\n // if it's not we fallback to sendResponse's handling\n if (pendingWaitUntil) {\n if (ctx.waitUntil) {\n ctx.waitUntil(pendingWaitUntil);\n pendingWaitUntil = undefined;\n }\n }\n const cacheTags = context.renderOpts.collectedTags;\n // If the request is for a static response, we can cache it so long\n // as it's not edge.\n if (isIsr) {\n const blob = await response.blob();\n // Copy the headers from the response.\n const headers = toNodeOutgoingHttpHeaders(response.headers);\n if (cacheTags) {\n headers[NEXT_CACHE_TAGS_HEADER] = cacheTags;\n }\n if (!headers['content-type'] && blob.type) {\n headers['content-type'] = blob.type;\n }\n const revalidate = typeof context.renderOpts.collectedRevalidate === 'undefined' || context.renderOpts.collectedRevalidate >= INFINITE_CACHE ? false : context.renderOpts.collectedRevalidate;\n const expire = typeof context.renderOpts.collectedExpire === 'undefined' || context.renderOpts.collectedExpire >= INFINITE_CACHE ? undefined : context.renderOpts.collectedExpire;\n // Create the cache entry for the response.\n const cacheEntry = {\n value: {\n kind: CachedRouteKind.APP_ROUTE,\n status: response.status,\n body: Buffer.from(await blob.arrayBuffer()),\n headers\n },\n cacheControl: {\n revalidate,\n expire\n }\n };\n return cacheEntry;\n } else {\n // send response without caching if not ISR\n await sendResponse(nodeNextReq, nodeNextRes, response, context.renderOpts.pendingWaitUntil);\n return null;\n }\n } catch (err) {\n // if this is a background revalidate we need to report\n // the request error here as it won't be bubbled\n if (previousCacheEntry == null ? void 0 : previousCacheEntry.isStale) {\n const silenceLog = false;\n await routeModule.onRequestError(req, err, {\n routerKind: 'App Router',\n routePath: srcPage,\n routeType: 'route',\n revalidateReason: getRevalidateReason({\n isStaticGeneration,\n isOnDemandRevalidate\n })\n }, silenceLog, routerServerContext);\n }\n throw err;\n }\n };\n const cacheEntry = await routeModule.handleResponse({\n req,\n nextConfig,\n cacheKey,\n routeKind: RouteKind.APP_ROUTE,\n isFallback: false,\n prerenderManifest,\n isRoutePPREnabled: false,\n isOnDemandRevalidate,\n revalidateOnlyGenerated,\n responseGenerator,\n waitUntil: ctx.waitUntil,\n isMinimalMode\n });\n // we don't create a cacheEntry for ISR\n if (!isIsr) {\n return null;\n }\n if ((cacheEntry == null ? void 0 : (_cacheEntry_value = cacheEntry.value) == null ? void 0 : _cacheEntry_value.kind) !== CachedRouteKind.APP_ROUTE) {\n var _cacheEntry_value1;\n throw Object.defineProperty(new Error(`Invariant: app-route received invalid cache entry ${cacheEntry == null ? void 0 : (_cacheEntry_value1 = cacheEntry.value) == null ? void 0 : _cacheEntry_value1.kind}`), \"__NEXT_ERROR_CODE\", {\n value: \"E701\",\n enumerable: false,\n configurable: true\n });\n }\n if (!isMinimalMode) {\n res.setHeader('x-nextjs-cache', isOnDemandRevalidate ? 'REVALIDATED' : cacheEntry.isMiss ? 'MISS' : cacheEntry.isStale ? 'STALE' : 'HIT');\n }\n // Draft mode should never be cached\n if (isDraftMode) {\n res.setHeader('Cache-Control', 'private, no-cache, no-store, max-age=0, must-revalidate');\n }\n const headers = fromNodeOutgoingHttpHeaders(cacheEntry.value.headers);\n if (!(isMinimalMode && isIsr)) {\n headers.delete(NEXT_CACHE_TAGS_HEADER);\n }\n // If cache control is already set on the response we don't\n // override it to allow users to customize it via next.config\n if (cacheEntry.cacheControl && !res.getHeader('Cache-Control') && !headers.get('Cache-Control')) {\n headers.set('Cache-Control', getCacheControlHeader(cacheEntry.cacheControl));\n }\n await sendResponse(nodeNextReq, nodeNextRes, // @ts-expect-error - Argument of type 'Buffer<ArrayBufferLike>' is not assignable to parameter of type 'BodyInit | null | undefined'.\n new Response(cacheEntry.value.body, {\n headers,\n status: cacheEntry.value.status || 200\n }));\n return null;\n };\n // TODO: activeSpan code path is for when wrapped by\n // next-server can be removed when this is no longer used\n if (activeSpan) {\n await handleResponse(activeSpan);\n } else {\n await tracer.withPropagatedContext(req.headers, ()=>tracer.trace(BaseServerSpan.handleRequest, {\n spanName: `${method} ${srcPage}`,\n kind: SpanKind.SERVER,\n attributes: {\n 'http.method': method,\n 'http.target': req.url\n }\n }, handleResponse));\n }\n } catch (err) {\n if (!(err instanceof NoFallbackError)) {\n const silenceLog = false;\n await routeModule.onRequestError(req, err, {\n routerKind: 'App Router',\n routePath: normalizedSrcPage,\n routeType: 'route',\n revalidateReason: getRevalidateReason({\n isStaticGeneration,\n isOnDemandRevalidate\n })\n }, silenceLog, routerServerContext);\n }\n // rethrow so that we can handle serving error page\n // If this is during static generation, throw the error again.\n if (isIsr) throw err;\n // Otherwise, send a 500 response.\n await sendResponse(nodeNextReq, nodeNextRes, new Response(null, {\n status: 500\n }));\n return null;\n }\n}\n\n//# sourceMappingURL=app-route.js.map\n","import { NextResponse } from 'next/server';\nimport { GitService } from '@/lib/git';\nimport { getRepositories } from '@/lib/store';\nimport { getCredentialById, getCredentialToken, findCredentialForRemote } from '@/lib/credentials';\nimport { getImageMimeType, isImageFile } from '@/lib/utils';\nimport { handleGitError } from '@/lib/api-utils';\nimport { z } from 'zod';\nimport fs from 'node:fs';\n\nconst actionSchema = z.object({\n repoPath: z.string(),\n action: z.enum(['commit', 'push', 'pull', 'stage', 'unstage', 'fetch', 'checkout', 'checkout-to-local', 'branch', 'create-tag', 'delete-branch', 'delete-worktree', 'delete-remote-branch', 'delete-remote', 'delete-tag', 'delete-remote-tag', 'rename-branch', 'rename-remote-branch', 'rename-remote', 'add-remote', 'reset', 'revert', 'cherry-pick', 'cherry-pick-multiple', 'cherry-pick-abort', 'rebase', 'merge', 'check-merge-conflicts', 'check-rebase-conflicts', 'get-conflict-state', 'get-conflict-file-versions', 'resolve-conflict-file', 'continue-merge', 'abort-merge', 'continue-rebase', 'abort-rebase', 'get-remotes', 'get-remote-branches', 'get-tracking-branch', 'get-latest-commit-message', 'get-merge-base', 'push-to-remote', 'pull-from-remote', 'stash', 'stash-list', 'stash-apply', 'stash-drop', 'stash-pop', 'stash-files', 'stash-file-diff', 'reword', 'discard', 'cleanup-lock-file']),\n data: z.any().optional(), // Payload depends on action\n});\n\nasync function resolveCredentials(repoPath: string, git: GitService, remoteName?: string) {\n const repos = getRepositories();\n const repoConfig = repos.find(r => r.path === repoPath);\n \n // 1. Check for explicitly associated credential\n if (repoConfig?.credentialId) {\n const cred = await getCredentialById(repoConfig.credentialId);\n if (cred) {\n const token = await getCredentialToken(cred.id);\n if (token) {\n return { username: cred.username, token };\n }\n }\n }\n\n // 2. Fallback: try to find matching credential by URL\n if (remoteName) {\n const remoteUrl = await git.getRemoteUrl(remoteName);\n if (remoteUrl) {\n const result = await findCredentialForRemote(remoteUrl);\n if (result) {\n return { username: result.credential.username, token: result.token };\n }\n }\n }\n\n return undefined;\n}\n\nfunction toImageSide(buffer: Buffer | null, mimeType: string) {\n if (!buffer) return null;\n return {\n mimeType,\n base64: buffer.toString('base64'),\n };\n}\n\nexport async function POST(request: Request) {\n try {\n const body = await request.json();\n const { repoPath, action, data } = actionSchema.parse(body);\n\n // Check if path exists\n if (!fs.existsSync(repoPath)) {\n return NextResponse.json({ error: `Path not found: ${repoPath}` }, { status: 404 });\n }\n\n const git = new GitService(repoPath);\n\n switch (action) {\n case 'commit':\n if (!data?.message) throw new Error('Commit message is required');\n await git.commit(data.message, data.files, { initialBranch: data?.initialBranch });\n break;\n case 'push':\n // Try to resolve credentials\n let pushCredentials = await resolveCredentials(repoPath, git, undefined);\n \n if (!pushCredentials) {\n // If no associated credential, try to infer from upstream\n try {\n const status = await git.getBranches();\n const current = status.current;\n const tracking = status.trackingInfo[current];\n if (tracking && tracking.upstream) {\n const slashIndex = tracking.upstream.indexOf('/');\n if (slashIndex > 0) {\n const remoteName = tracking.upstream.slice(0, slashIndex);\n pushCredentials = await resolveCredentials(repoPath, git, remoteName);\n }\n }\n } catch (e) {\n // Ignore errors finding upstream, just proceed without creds\n console.warn('[API] Failed to resolve upstream for push credentials:', e);\n }\n }\n \n await git.push({ credentials: pushCredentials });\n break;\n case 'pull':\n await git.pull();\n break;\n case 'fetch':\n if (data?.allRemotes) {\n await git.fetchAllRemotes();\n } else if (data?.remote) {\n await git.fetchRemote(data.remote);\n } else {\n await git.fetch();\n }\n break;\n case 'stage':\n if (!data?.files) throw new Error('Files are required for staging');\n await git.stage(data.files);\n break;\n case 'unstage':\n if (!data?.files) throw new Error('Files are required for unstaging');\n await git.unstage(data.files);\n break;\n case 'discard':\n await git.discardUnstagedChanges({\n includeUntracked: data?.includeUntracked ?? true,\n });\n break;\n case 'checkout':\n if (!data?.branch) throw new Error('Branch name is required for checkout');\n await git.checkout(data.branch);\n break;\n case 'checkout-to-local':\n if (!data?.remoteBranch) throw new Error('Remote branch is required for checkout-to-local');\n if (!data?.localBranch) throw new Error('Local branch name is required for checkout-to-local');\n await git.checkoutRemoteToLocal(data.remoteBranch, data.localBranch);\n break;\n case 'branch':\n if (!data?.branch) throw new Error('Branch name is required to create branch');\n await git.createBranch(data.branch, data?.fromRef);\n break;\n case 'create-tag':\n if (!data?.tagName) throw new Error('Tag name is required to create tag');\n if (!data?.commitHash) throw new Error('Commit hash is required to create tag');\n if (data?.pushToRemote) {\n let remoteForTag = typeof data?.remote === 'string' && data.remote.trim() ? data.remote.trim() : undefined;\n if (!remoteForTag) {\n const branches = await git.getBranches();\n const current = branches.current;\n const trackingUpstream = current ? branches.trackingInfo?.[current]?.upstream : undefined;\n if (trackingUpstream) {\n const slashIndex = trackingUpstream.indexOf('/');\n if (slashIndex > 0) {\n remoteForTag = trackingUpstream.slice(0, slashIndex);\n }\n }\n }\n if (!remoteForTag) {\n const remotes = await git.getRemotes();\n if (remotes.includes('origin')) {\n remoteForTag = 'origin';\n } else {\n remoteForTag = remotes[0];\n }\n }\n\n const tagCreds = remoteForTag ? await resolveCredentials(repoPath, git, remoteForTag) : undefined;\n await git.createTag(data.tagName, data.commitHash, {\n pushToRemote: true,\n remote: remoteForTag ?? undefined,\n credentials: tagCreds,\n });\n } else {\n await git.createTag(data.tagName, data.commitHash, { pushToRemote: false });\n }\n break;\n case 'delete-branch':\n if (!data?.branch) throw new Error('Branch name is required to delete branch');\n await git.deleteBranch(data.branch);\n break;\n case 'delete-worktree':\n if (!data?.path) throw new Error('Worktree path is required to delete worktree');\n await git.deleteWorktree(data.path);\n break;\n case 'delete-remote-branch':\n if (!data?.remote) throw new Error('Remote name is required to delete remote branch');\n if (!data?.branch) throw new Error('Branch name is required to delete remote branch');\n \n const deleteCreds = await resolveCredentials(repoPath, git, data.remote);\n await git.deleteRemoteBranch(data.remote, data.branch, deleteCreds);\n break;\n case 'delete-remote':\n if (!data?.name) throw new Error('Remote name is required to delete remote');\n await git.deleteRemote(data.name);\n break;\n case 'delete-tag':\n if (!data?.tag) throw new Error('Tag name is required to delete tag');\n await git.deleteTag(data.tag);\n break;\n case 'delete-remote-tag':\n if (!data?.remote) throw new Error('Remote name is required to delete remote tag');\n if (!data?.tag) throw new Error('Tag name is required to delete remote tag');\n\n const deleteTagCreds = await resolveCredentials(repoPath, git, data.remote);\n await git.deleteRemoteTag(data.remote, data.tag, deleteTagCreds);\n break;\n case 'rename-branch':\n if (!data?.oldName) throw new Error('Old branch name is required to rename branch');\n if (!data?.newName) throw new Error('New branch name is required to rename branch');\n if (data?.renameTrackingRemote) {\n const tracking = await git.getTrackingBranch(data.oldName);\n const renameTrackingCreds = tracking\n ? await resolveCredentials(repoPath, git, tracking.remote)\n : undefined;\n await git.renameBranch(data.oldName, data.newName, {\n renameTrackingRemote: true,\n credentials: renameTrackingCreds,\n });\n } else {\n await git.renameBranch(data.oldName, data.newName);\n }\n break;\n case 'rename-remote-branch':\n if (!data?.remote) throw new Error('Remote name is required to rename remote branch');\n if (!data?.oldName) throw new Error('Old branch name is required to rename remote branch');\n if (!data?.newName) throw new Error('New branch name is required to rename remote branch');\n\n const renameCreds = await resolveCredentials(repoPath, git, data.remote);\n await git.renameRemoteBranch(data.remote, data.oldName, data.newName, renameCreds);\n break;\n case 'rename-remote':\n if (!data?.oldName) throw new Error('Old remote name is required to rename remote');\n if (!data?.newName) throw new Error('New remote name is required to rename remote');\n await git.renameRemote(data.oldName, data.newName);\n break;\n case 'add-remote':\n if (!data?.name) throw new Error('Remote name is required to add remote');\n if (!data?.url) throw new Error('Remote URL is required to add remote');\n await git.addRemote(data.name, data.url);\n break;\n case 'reset':\n if (!data?.commitHash) throw new Error('Commit hash is required for reset');\n await git.reset(data.commitHash, data.mode ?? 'hard');\n break;\n case 'revert':\n if (!data?.commitHash) throw new Error('Commit hash is required for revert');\n await git.revert(data.commitHash);\n break;\n case 'cherry-pick':\n if (!data?.commitHash) throw new Error('Commit hash is required for cherry-pick');\n await git.cherryPick(data.commitHash);\n break;\n case 'cherry-pick-multiple':\n if (!Array.isArray(data?.commitHashes) || data.commitHashes.length === 0) {\n throw new Error('Commit hashes are required for multi cherry-pick');\n }\n if (!data.commitHashes.every((hash: unknown) => typeof hash === 'string' && hash.trim().length > 0)) {\n throw new Error('All commit hashes must be non-empty strings');\n }\n await git.cherryPickMultiple(data.commitHashes);\n break;\n case 'cherry-pick-abort':\n await git.abortCherryPick();\n break;\n case 'rebase':\n if (!data?.ontoBranch) throw new Error('Target branch is required for rebase');\n await git.rebase(data.ontoBranch, data.stashChanges ?? true);\n break;\n case 'reword':\n if (!data?.commitHash) throw new Error('Commit hash is required for reword');\n if (!data?.message) throw new Error('New message is required for reword');\n await git.reword(data.commitHash, data.message, data.branch);\n break;\n case 'merge':\n if (!data?.targetBranch) throw new Error('Target branch is required for merge');\n await git.merge(data.targetBranch, {\n rebaseBeforeMerge: data.rebaseBeforeMerge ?? false,\n squash: data.squash ?? false,\n fastForward: data.fastForward ?? false,\n squashMessage: data.squashMessage,\n });\n break;\n case 'check-merge-conflicts':\n if (!data?.sourceBranch) throw new Error('Source branch is required for merge conflict check');\n const hasConflicts = await git.willMergeHaveConflicts(data.sourceBranch, data.targetBranch);\n return NextResponse.json({ success: true, hasConflicts });\n case 'check-rebase-conflicts':\n if (!data?.ontoBranch) throw new Error('Target branch is required for rebase conflict check');\n if (!data?.sourceBranch) throw new Error('Source branch is required for rebase conflict check');\n const hasRebaseConflicts = await git.willRebaseHaveConflicts(data.ontoBranch, data.sourceBranch);\n return NextResponse.json({ success: true, hasConflicts: hasRebaseConflicts });\n case 'get-conflict-state':\n const conflictState = await git.getConflictState();\n return NextResponse.json({ success: true, ...conflictState });\n case 'get-conflict-file-versions':\n if (!data?.path) throw new Error('File path is required');\n const versions = await git.getConflictFileVersions(data.path);\n return NextResponse.json({ success: true, ...versions });\n case 'resolve-conflict-file':\n if (!data?.path) throw new Error('File path is required');\n if (!data?.strategy) throw new Error('Resolution strategy is required');\n if (!['ours', 'theirs', 'manual'].includes(data.strategy)) {\n throw new Error('Resolution strategy must be ours, theirs, or manual');\n }\n await git.resolveConflictFile(data.path, data.strategy, {\n content: data.content,\n stage: data.stage ?? true,\n });\n break;\n case 'continue-merge':\n await git.continueMerge();\n break;\n case 'abort-merge':\n await git.abortMerge();\n break;\n case 'continue-rebase':\n await git.continueRebase();\n break;\n case 'abort-rebase':\n await git.abortRebase();\n break;\n case 'get-remotes':\n const remotes = await git.getRemotes();\n return NextResponse.json({ success: true, remotes });\n case 'get-remote-branches':\n if (!data?.remote) throw new Error('Remote name is required');\n const remoteBranches = await git.getRemoteBranches(data.remote);\n return NextResponse.json({ success: true, branches: remoteBranches });\n case 'get-tracking-branch':\n if (!data?.branch) throw new Error('Branch name is required');\n const tracking = await git.getTrackingBranch(data.branch);\n return NextResponse.json({ success: true, tracking });\n case 'get-latest-commit-message':\n if (!data?.branch) throw new Error('Branch name is required');\n const message = await git.getLatestCommitMessage(data.branch);\n return NextResponse.json({ success: true, message });\n case 'get-merge-base':\n if (!data?.targetRef) throw new Error('Target ref is required');\n if (!data?.sourceRef) throw new Error('Source ref is required');\n const mergeBase = await git.getMergeBase(data.targetRef, data.sourceRef);\n return NextResponse.json({ success: true, mergeBase });\n case 'push-to-remote':\n console.log('[API] push-to-remote action received:', data);\n if (!data?.localBranch) throw new Error('Local branch is required');\n if (!data?.remote) throw new Error('Remote is required');\n if (!data?.remoteBranch) throw new Error('Remote branch is required');\n \n const creds = await resolveCredentials(repoPath, git, data.remote);\n \n console.log('[API] Calling git.pushToRemote...');\n await git.pushToRemote(data.localBranch, data.remote, data.remoteBranch, {\n rebaseFirst: data.rebaseFirst ?? !(data.forcePush ?? false),\n forcePush: data.forcePush ?? false,\n pushLocalOnlyTags: data.pushLocalOnlyTags ?? true,\n setUpstream: data.setUpstream ?? false,\n squash: data.squash ?? false,\n squashMessage: data.squashMessage,\n credentials: creds,\n });\n console.log('[API] git.pushToRemote completed');\n break;\n case 'pull-from-remote':\n console.log('[API] pull-from-remote action received:', data);\n if (!data?.localBranch) throw new Error('Local branch is required');\n if (!data?.remote) throw new Error('Remote is required');\n if (!data?.remoteBranch) throw new Error('Remote branch is required');\n console.log('[API] Calling git.pullFromRemote...');\n await git.pullFromRemote(data.localBranch, data.remote, data.remoteBranch, {\n rebase: data.rebase ?? true,\n });\n console.log('[API] git.pullFromRemote completed');\n break;\n case 'stash':\n await git.stash(data?.message);\n break;\n case 'stash-list':\n const stashes = await git.getStashes();\n return NextResponse.json({ success: true, stashes });\n case 'stash-apply':\n if (data?.index === undefined) throw new Error('Stash index is required');\n await git.applyStash(data.index);\n break;\n case 'stash-drop':\n if (data?.index === undefined) throw new Error('Stash index is required');\n await git.dropStash(data.index);\n break;\n case 'stash-pop':\n if (data?.index === undefined) throw new Error('Stash index is required');\n await git.popStash(data.index);\n break;\n case 'stash-files':\n if (data?.index === undefined) throw new Error('Stash index is required');\n const stashFiles = await git.getStashFiles(data.index);\n return NextResponse.json({ success: true, files: stashFiles });\n case 'stash-file-diff':\n if (data?.index === undefined) throw new Error('Stash index is required');\n if (!data?.file) throw new Error('File path is required');\n if (isImageFile(data.file)) {\n const mimeType = getImageMimeType(data.file);\n const [leftBuffer, rightBuffer, diff] = await Promise.all([\n git.getFileContentBuffer(data.file, `stash@{${data.index}}^1`),\n git.getFileContentBuffer(data.file, `stash@{${data.index}}`),\n git.getStashFilePatch(data.index, data.file),\n ]);\n\n return NextResponse.json({\n success: true,\n left: '',\n right: '',\n diff,\n imageDiff: {\n left: toImageSide(leftBuffer, mimeType),\n right: toImageSide(rightBuffer, mimeType),\n },\n });\n }\n\n const stashFileDiff = await git.getStashFileDiff(data.index, data.file);\n return NextResponse.json({ success: true, ...stashFileDiff });\n case 'cleanup-lock-file':\n const cleaned = await git.cleanupLockFile();\n return NextResponse.json({ success: true, cleaned });\n default:\n return NextResponse.json({ error: 'Invalid action' }, { status: 400 });\n }\n\n return NextResponse.json({ success: true });\n } catch (error) {\n return handleGitError(error);\n }\n}\n"],"names":[],"mappings":"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","ignoreList":[0]}
@@ -1,4 +1,4 @@
1
1
  module.exports=[46786,(a,b,c)=>{b.exports=a.x("os",()=>require("os"))},24868,(a,b,c)=>{b.exports=a.x("fs/promises",()=>require("fs/promises"))},37936,(a,b,c)=>{"use strict";Object.defineProperty(c,"__esModule",{value:!0}),Object.defineProperty(c,"registerServerReference",{enumerable:!0,get:function(){return d.registerServerReference}});let d=a.r(11857)},70798,a=>{"use strict";var b=a.i(24868),c=a.i(46786),d=a.i(14747);let e="viba-git-credentials",f=null,g=null,h=!1;function i(){return g?`Secure credential storage is unavailable: ${g}`:"Secure credential storage is unavailable in this runtime."}async function j(){return f||(f=a.A(45581).then(a=>a.default??a).catch(a=>(g=a instanceof Error?a.message:String(a),h||(h=!0,console.warn(`[credentials] ${i()}`)),null))),f}async function k(){let a=await j();if(!a)throw Error(i());return a}function l(){return`${Date.now()}-${Math.random().toString(36).slice(2,9)}`}function m(a){return a.trim().replace(/\/$/,"")}function n(a){return`credential-${a}`}function o(a){return`credential-${a}`}function p(a){return a.keytarAccount||n(a.id)}function q(a){return"gitlab"===a.type?{id:a.id,type:"gitlab",username:a.username,serverUrl:a.serverUrl||"https://gitlab.com",createdAt:a.createdAt,updatedAt:a.updatedAt}:{id:a.id,type:"github",username:a.username,createdAt:a.createdAt,updatedAt:a.updatedAt}}async function r(){let a=d.default.join(c.default.homedir(),".viba");return await b.default.mkdir(a,{recursive:!0}),d.default.join(a,"credentials.json")}function s(a,b){return!!a&&"object"==typeof a&&a.type===b&&"string"==typeof a.username&&"string"==typeof a.createdAt&&"string"==typeof a.updatedAt&&("gitlab"!==b||"string"==typeof a.serverUrl)}function t(a){return!!a&&"object"==typeof a&&"string"==typeof a.id&&!!a.id.trim()&&("github"===a.type||"gitlab"===a.type)&&"string"==typeof a.username&&"string"==typeof a.createdAt&&"string"==typeof a.updatedAt&&(void 0===a.keytarAccount||"string"==typeof a.keytarAccount)&&("gitlab"!==a.type||"string"==typeof a.serverUrl)}async function u(a){let c=await r();await b.default.writeFile(c,JSON.stringify(a,null,2),"utf-8")}async function v(){let a=await r();try{let c=await b.default.readFile(a,"utf-8"),d=JSON.parse(c);if(Array.isArray(d))return d.filter(t);if(!d||"object"!=typeof d)return[];let e=[];if(s(d.github,"github")){let a=d.github;e.push({id:l(),type:"github",username:a.username,createdAt:a.createdAt,updatedAt:a.updatedAt,keytarAccount:o("github")})}if(s(d.gitlab,"gitlab")){let a=d.gitlab;e.push({id:l(),type:"gitlab",username:a.username,serverUrl:a.serverUrl,createdAt:a.createdAt,updatedAt:a.updatedAt,keytarAccount:o("gitlab")})}return e.length>0&&await u(e),e}catch(a){if(a?.code==="ENOENT")return[];return console.error("Failed to parse credentials metadata:",a),[]}}async function w(){return(await v()).map(q).sort((a,b)=>b.updatedAt.localeCompare(a.updatedAt))}async function x(a){let b=(await v()).find(b=>b.id===a);return b?q(b):null}async function y(a){let b=(await v()).find(b=>b.id===a);if(!b)return null;let c=await j();return c?c.getPassword(e,p(b)):null}async function z(a){try{let b=await fetch("https://api.github.com/user",{headers:{Authorization:`Bearer ${a}`,Accept:"application/vnd.github+json","X-GitHub-Api-Version":"2022-11-28"}});if(!b.ok){if(401===b.status)return{valid:!1,error:"Invalid or expired GitHub token."};return{valid:!1,error:`GitHub API returned ${b.status}.`}}let c=await b.json(),d="string"==typeof c?.login?c.login:null;if(!d)return{valid:!1,error:"GitHub API response did not include a username."};return{valid:!0,username:d}}catch(a){return{valid:!1,error:`Failed to verify GitHub token: ${a.message}`}}}async function A(a,b){try{let c=m(a),d=await fetch(`${c}/api/v4/user`,{headers:{"PRIVATE-TOKEN":b}});if(!d.ok){if(401===d.status)return{valid:!1,error:"Invalid or expired GitLab token."};return{valid:!1,error:`GitLab API returned ${d.status}.`}}let e=await d.json(),f="string"==typeof e?.username?e.username:null;if(!f)return{valid:!1,error:"GitLab API response did not include a username."};return{valid:!0,username:f}}catch(a){return{valid:!1,error:`Failed to verify GitLab token: ${a.message}`}}}async function B(a){let b,c=a.trim();if(!c)return{success:!1,error:"GitHub token is required."};try{b=await k()}catch(a){return{success:!1,error:a.message}}let d=await z(c);if(!d.valid||!d.username)return{success:!1,error:d.error||"Failed to verify GitHub token."};let f=await v();if(f.find(a=>"github"===a.type&&a.username===d.username))return{success:!1,error:`A GitHub credential for ${d.username} already exists.`};let g=l(),h=new Date().toISOString(),i=n(g);await b.setPassword(e,i,c);let j={id:g,type:"github",username:d.username,createdAt:h,updatedAt:h,keytarAccount:i};return f.push(j),await u(f),{success:!0,credential:{id:j.id,type:"github",username:j.username,createdAt:j.createdAt,updatedAt:j.updatedAt}}}async function C(a,b){let c,d=m(a),f=b.trim();if(!d)return{success:!1,error:"GitLab server URL is required."};try{new URL(d)}catch{return{success:!1,error:"GitLab server URL must be a valid URL."}}if(!f)return{success:!1,error:"GitLab token is required."};try{c=await k()}catch(a){return{success:!1,error:a.message}}let g=await A(d,f);if(!g.valid||!g.username)return{success:!1,error:g.error||"Failed to verify GitLab token."};let h=await v();if(h.find(a=>"gitlab"===a.type&&a.username===g.username&&a.serverUrl===d))return{success:!1,error:`A GitLab credential for ${g.username} on ${d} already exists.`};let i=l(),j=new Date().toISOString(),o=n(i);await c.setPassword(e,o,f);let p={id:i,type:"gitlab",username:g.username,serverUrl:d,createdAt:j,updatedAt:j,keytarAccount:o};return h.push(p),await u(h),{success:!0,credential:{id:p.id,type:"gitlab",username:p.username,serverUrl:p.serverUrl||d,createdAt:p.createdAt,updatedAt:p.updatedAt}}}async function D(a){let b=await v(),c=b.findIndex(b=>b.id===a);if(-1===c)return{success:!1,error:"Credential not found."};let d=b[c];b.splice(c,1),await u(b);let f=await j();return f&&await f.deletePassword(e,p(d)),{success:!0}}a.s(["createGitHubCredential",()=>B,"createGitLabCredential",()=>C,"deleteCredential",()=>D,"getAllCredentials",()=>w,"getCredentialById",()=>x,"getCredentialToken",()=>y])},66085,a=>{"use strict";var b=a.i(24868),c=a.i(46786),d=a.i(14747);let e="viba-agent-api-credentials",f=["codex"],g=null,h=null,i=!1;function j(a){return f.includes(a)}function k(){return h?`Secure credential storage is unavailable: ${h}`:"Secure credential storage is unavailable in this runtime."}async function l(){return g||(g=a.A(45581).then(a=>a.default??a).catch(a=>(h=a instanceof Error?a.message:String(a),i||(i=!0,console.warn(`[agent-api-credentials] ${k()}`)),null))),g}async function m(){let a=await l();if(!a)throw Error(k());return a}function n(a){return`agent-api-${a}`}function o(a){return a.keytarAccount||n(a.agent)}function p(a){return{agent:a.agent,apiProxy:a.apiProxy,createdAt:a.createdAt,updatedAt:a.updatedAt}}function q(a){return!!a&&"object"==typeof a&&"string"==typeof a.agent&&!!j(a.agent)&&"string"==typeof a.createdAt&&"string"==typeof a.updatedAt&&(void 0===a.apiProxy||"string"==typeof a.apiProxy)&&(void 0===a.keytarAccount||"string"==typeof a.keytarAccount)}async function r(){let a=d.default.join(c.default.homedir(),".viba");return await b.default.mkdir(a,{recursive:!0}),d.default.join(a,"agent-api-configs.json")}async function s(a){let c=await r();await b.default.writeFile(c,JSON.stringify(a,null,2),"utf-8")}async function t(){let a=await r();try{let c=await b.default.readFile(a,"utf-8"),d=JSON.parse(c);if(Array.isArray(d))return d.filter(q);if(!d||"object"!=typeof d)return[];let e=Object.entries(d).filter(([a])=>j(a)).map(([a,b])=>b&&"object"==typeof b?void 0===b.agent?{...b,agent:a}:b:null).filter(q);return e.length>0&&await s(e),e}catch(a){if(a?.code==="ENOENT")return[];return console.error("Failed to parse agent API credential metadata:",a),[]}}async function u(){return(await t()).map(p).sort((a,b)=>b.updatedAt.localeCompare(a.updatedAt))}async function v(a,b,c){let d,f;if(!j(a))return{success:!1,error:`Unsupported agent: ${a}`};let g=b.trim();if(!g)return{success:!1,error:"API key is required."};try{d=function(a){let b=a.trim();if(b){try{new URL(b)}catch{throw Error("API proxy must be a valid URL.")}return b}}(c)}catch(a){return{success:!1,error:a.message}}try{f=await m()}catch(a){return{success:!1,error:a.message}}let h=await t(),i=new Date().toISOString(),k=h.findIndex(b=>b.agent===a),l=k>=0?o(h[k]):n(a);if(await f.setPassword(e,l,g),k>=0){let a=h[k];h[k]={...a,apiProxy:d,updatedAt:i,keytarAccount:l}}else h.push({agent:a,apiProxy:d,createdAt:i,updatedAt:i,keytarAccount:l});await s(h);let q=h.find(b=>b.agent===a);return q?{success:!0,credential:p(q)}:{success:!1,error:"Failed to persist agent API credential."}}async function w(a){if(!j(a))return{success:!1,error:`Unsupported agent: ${a}`};let b=await t(),c=b.findIndex(b=>b.agent===a);if(-1===c)return{success:!1,error:"Agent API credential not found."};let[d]=b.splice(c,1);await s(b);let f=await l();return f&&await f.deletePassword(e,o(d)),{success:!0}}async function x(a){if(!j(a))return null;let b=(await t()).find(b=>b.agent===a);if(!b)return null;let c=await l();if(!c)return null;let d=await c.getPassword(e,o(b));return d?{agent:b.agent,apiKey:d,apiProxy:b.apiProxy}:null}a.s(["createOrUpdateAgentApiCredential",()=>v,"deleteAgentApiCredential",()=>w,"getAgentApiCredentialSecret",()=>x,"getAllAgentApiCredentials",()=>u])},13095,(a,b,c)=>{"use strict";function d(a){for(let b=0;b<a.length;b++){let c=a[b];if("function"!=typeof c)throw Object.defineProperty(Error(`A "use server" file can only export async functions, found ${typeof c}.
2
- Read more: https://nextjs.org/docs/messages/invalid-use-server-value`),"__NEXT_ERROR_CODE",{value:"E352",enumerable:!1,configurable:!0})}}Object.defineProperty(c,"__esModule",{value:!0}),Object.defineProperty(c,"ensureServerEntryExports",{enumerable:!0,get:function(){return d}})},37359,a=>{"use strict";var b=a.i(37936),c=a.i(70798),d=a.i(66085);async function e(){try{let a=await (0,c.getAllCredentials)();return{success:!0,credentials:a}}catch(a){return console.error("Failed to list credentials:",a),{success:!1,error:"Failed to load credentials."}}}async function f(a){let b=await (0,c.createGitHubCredential)(a);return b.success&&b.credential?{success:!0,credential:b.credential}:{success:!1,error:b.error||"Failed to save GitHub credential."}}async function g(a,b){let d=await (0,c.createGitLabCredential)(a,b);return d.success&&d.credential?{success:!0,credential:d.credential}:{success:!1,error:d.error||"Failed to save GitLab credential."}}async function h(){try{let a=await (0,d.getAllAgentApiCredentials)();return{success:!0,credentials:a}}catch(a){return console.error("Failed to list agent API credentials:",a),{success:!1,error:"Failed to load agent API credentials."}}}async function i(a,b,c){let e=await (0,d.createOrUpdateAgentApiCredential)(a,b,c);return e.success&&e.credential?{success:!0,credential:e.credential}:{success:!1,error:e.error||"Failed to save agent API credential."}}async function j(a){try{let b=await (0,c.deleteCredential)(a);if(!b.success)return{success:!1,error:b.error||"Failed to remove credential."};return{success:!0}}catch(a){return console.error("Failed to remove credential:",a),{success:!1,error:"Failed to remove credential."}}}async function k(a){try{let b=await (0,d.deleteAgentApiCredential)(a);if(!b.success)return{success:!1,error:b.error||"Failed to remove agent API credential."};return{success:!0}}catch(a){return console.error("Failed to remove agent API credential:",a),{success:!1,error:"Failed to remove agent API credential."}}}(0,a.i(13095).ensureServerEntryExports)([e,f,g,h,i,j,k]),(0,b.registerServerReference)(e,"008c06297149d94056cb210d81ed9e5e14c82c759a",null),(0,b.registerServerReference)(f,"40aece137a81273f4e2d4215af82b158c70dcf964b",null),(0,b.registerServerReference)(g,"606926b19756cb65e45debacb9fbeca505cec9810d",null),(0,b.registerServerReference)(h,"006b7a10f839b3ad9a8e3cb7090a78f9691c43c62f",null),(0,b.registerServerReference)(i,"70c6e814496d35b292b02ef9356856815db2e8ee55",null),(0,b.registerServerReference)(j,"403516664888f26869fedb1243afbe84a2848d7ebb",null),(0,b.registerServerReference)(k,"402bb7de970222695db6ab05347896fc56c5b72801",null),a.s(["listAgentApiCredentials",()=>h,"listCredentials",()=>e,"removeAgentApiCredential",()=>k,"removeCredential",()=>j,"saveAgentApiCredential",()=>i,"saveGitHubCredential",()=>f,"saveGitLabCredential",()=>g])}];
2
+ Read more: https://nextjs.org/docs/messages/invalid-use-server-value`),"__NEXT_ERROR_CODE",{value:"E352",enumerable:!1,configurable:!0})}}Object.defineProperty(c,"__esModule",{value:!0}),Object.defineProperty(c,"ensureServerEntryExports",{enumerable:!0,get:function(){return d}})},37359,a=>{"use strict";var b=a.i(37936),c=a.i(70798),d=a.i(66085);async function e(){try{let a=await (0,c.getAllCredentials)();return{success:!0,credentials:a}}catch(a){return console.error("Failed to list credentials:",a),{success:!1,error:"Failed to load credentials."}}}async function f(a){let b=await (0,c.createGitHubCredential)(a);return b.success&&b.credential?{success:!0,credential:b.credential}:{success:!1,error:b.error||"Failed to save GitHub credential."}}async function g(a,b){let d=await (0,c.createGitLabCredential)(a,b);return d.success&&d.credential?{success:!0,credential:d.credential}:{success:!1,error:d.error||"Failed to save GitLab credential."}}async function h(){try{let a=await (0,d.getAllAgentApiCredentials)();return{success:!0,credentials:a}}catch(a){return console.error("Failed to list agent API credentials:",a),{success:!1,error:"Failed to load agent API credentials."}}}async function i(a,b,c){let e=await (0,d.createOrUpdateAgentApiCredential)(a,b,c);return e.success&&e.credential?{success:!0,credential:e.credential}:{success:!1,error:e.error||"Failed to save agent API credential."}}async function j(a){try{let b=await (0,c.deleteCredential)(a);if(!b.success)return{success:!1,error:b.error||"Failed to remove credential."};return{success:!0}}catch(a){return console.error("Failed to remove credential:",a),{success:!1,error:"Failed to remove credential."}}}async function k(a){try{let b=await (0,d.deleteAgentApiCredential)(a);if(!b.success)return{success:!1,error:b.error||"Failed to remove agent API credential."};return{success:!0}}catch(a){return console.error("Failed to remove agent API credential:",a),{success:!1,error:"Failed to remove agent API credential."}}}(0,a.i(13095).ensureServerEntryExports)([e,f,g,h,i,j,k]),(0,b.registerServerReference)(e,"0037e57dce0e01173d262d9f2abbeeda52df8d7e4f",null),(0,b.registerServerReference)(f,"405e6eb5e388cacf34bf45187d62ebd23b892a56af",null),(0,b.registerServerReference)(g,"60a683dd28bcaee196e869b42e36340e5666c49497",null),(0,b.registerServerReference)(h,"007854b56845eeafde2c9685b51a376a63b707aad1",null),(0,b.registerServerReference)(i,"70626cc4e20cf7f4bceed9d5acc5e76e729a2afa1d",null),(0,b.registerServerReference)(j,"401ae2970dc4c2fbd2865643135b169242e390fbb9",null),(0,b.registerServerReference)(k,"401216e572e4bf7bf326cda1f4a30eb1603691e246",null),a.s(["listAgentApiCredentials",()=>h,"listCredentials",()=>e,"removeAgentApiCredential",()=>k,"removeCredential",()=>j,"saveAgentApiCredential",()=>i,"saveGitHubCredential",()=>f,"saveGitLabCredential",()=>g])}];
3
3
 
4
4
  //# sourceMappingURL=%5Broot-of-the-server%5D__05e6fb4c._.js.map
@@ -1,3 +1,3 @@
1
- module.exports=[24868,(a,b,c)=>{b.exports=a.x("fs/promises",()=>require("fs/promises"))},33405,(a,b,c)=>{b.exports=a.x("child_process",()=>require("child_process"))},46786,(a,b,c)=>{b.exports=a.x("os",()=>require("os"))},22734,(a,b,c)=>{b.exports=a.x("fs",()=>require("fs"))},50227,(a,b,c)=>{b.exports=a.x("node:path",()=>require("node:path"))},70722,(a,b,c)=>{b.exports=a.x("tty",()=>require("tty"))},51615,(a,b,c)=>{b.exports=a.x("node:buffer",()=>require("node:buffer"))},87769,(a,b,c)=>{b.exports=a.x("node:events",()=>require("node:events"))},98624,54569,a=>{"use strict";var b=a.i(37936),c=a.i(24868),d=a.i(46786),e=a.i(14747),f=a.i(4503),g=a.i(38642);let h=new Set([".git","node_modules",".next",".viba","dist","build","coverage"]);function i(){return global.repoResolutionCache||(global.repoResolutionCache=new Map),global.repoResolutionCache}function j(a,b){i().set(a.toLowerCase(),{repoPath:b,resolvedAt:Date.now()})}async function k(a){let b=i().get(a.toLowerCase());return b?Date.now()-b.resolvedAt>3e5?(i().delete(a.toLowerCase()),null):await l(b.repoPath)?b.repoPath:(i().delete(a.toLowerCase()),null):null}async function l(a){try{return await c.default.access(e.default.join(a,".git")),!0}catch{return!1}}async function m(a,b){let d=e.default.join(a,b);if(await l(d))return d;let f=[{dirPath:a,depth:0}],g=0,i=b.toLowerCase();for(let a=0;a<f.length;a+=1){let b,d=f[a];if((g+=1)>5e3)break;try{b=await c.default.readdir(d.dirPath,{withFileTypes:!0})}catch{continue}for(let a of b){if(!a.isDirectory()||function(a,b){let c=a.toLowerCase();return c!==b&&!!(h.has(c)||a.startsWith("."))}(a.name,i))continue;let b=e.default.join(d.dirPath,a.name);if(a.name.toLowerCase()===i&&await l(b))return b;d.depth+1<=5&&f.push({dirPath:b,depth:d.depth+1})}}return null}async function n(a){let b=a.trim();if(!b)return null;let c=await k(b);if(c)return c;let d=await (0,g.getConfig)();for(let a of d.recentRepos.filter(a=>e.default.basename(a).toLowerCase()===b.toLowerCase()))if(await l(a))return j(b,a),a;let f=[],h=new Set;for(let a of d.recentRepos){let b=e.default.dirname(a);h.has(b)||(h.add(b),f.push(b))}for(let a of(d.defaultRoot&&!h.has(d.defaultRoot)&&(h.add(d.defaultRoot),f.push(d.defaultRoot)),f)){let c=await m(a,b);if(c)return j(b,c),c}return null}var o=a.i(70798),p=a.i(46534),q=a.i(13095);async function r(a){try{let b=await n(a);return{success:!0,repoPath:b}}catch(a){return console.error("Failed to resolve repository by name:",a),{success:!1,repoPath:null,error:"Failed to search repositories. Please try again."}}}function s(a){if("gitlab"!==a.type)return null;try{return new URL(a.serverUrl).hostname.toLowerCase()}catch{return null}}async function t(a,b){let c=await (0,o.getAllCredentials)(),d=(0,p.detectGitRemoteProvider)(a,{gitlabHosts:c.flatMap(a=>{if("gitlab"!==a.type)return[];let b=s(a);return b?[b]:[]})}),e=(0,p.parseGitRemoteHost)(a);if(b){let a=await (0,o.getCredentialById)(b);if(!a)return{success:!1,error:"Selected credential was not found. Please choose another credential."};if("github"===d&&"github"!==a.type)return{success:!1,error:"Selected credential does not match this GitHub repository."};if("gitlab"===d&&"gitlab"!==a.type)return{success:!1,error:"Selected credential does not match this GitLab repository."};if("gitlab"===a.type&&e){let b=s(a);if(b&&b!==e)return{success:!1,error:`Selected GitLab credential targets ${b}, but this repository uses ${e}.`}}let c=await (0,o.getCredentialToken)(a.id);return c?{success:!0,credential:a,token:c}:{success:!1,error:"Could not load token for selected credential."}}if(!d)return{success:!0,credential:null,token:null};let f=function(a,b,c){if("github"===b)return a.find(a=>"github"===a.type)||null;if(c){let b=a.find(a=>"gitlab"===a.type&&s(a)===c);if(b)return b}return a.find(a=>"gitlab"===a.type)||null}(c,d,e);if(!f)return{success:!0,credential:null,token:null};let g=await (0,o.getCredentialToken)(f.id);return g?{success:!0,credential:f,token:g}:{success:!0,credential:null,token:null}}async function u(a,b){let g=a.trim();if(!g)return{success:!1,repoPath:null,error:"Please enter a remote repository URL."};let h=function(a){let b=a.trim();if(!b)return null;let c="";try{c=new URL(b).pathname}catch{let a=b.match(/^([^@]+@)?([^:]+):(.+)$/);c=a?a[3]:b}let d=c.replace(/\\/g,"/").replace(/\/+$/,"");if(!d)return null;let f=e.default.posix.basename(d);return f&&"."!==f&&".."!==f?(f.toLowerCase().endsWith(".git")&&(f=f.slice(0,-4)),f.replace(/[^a-zA-Z0-9._-]/g,"-").replace(/^-+/,"").replace(/-+$/,"")||null):null}(g);if(!h)return{success:!1,repoPath:null,error:"Could not determine repository name from URL."};let i=e.default.join(d.default.homedir(),".viba","repos");await c.default.mkdir(i,{recursive:!0});let j=e.default.join(i,h);try{return await c.default.access(j),{success:!1,repoPath:null,error:`Repository already exists at ${j}.`}}catch{}let k=await t(g,b);if(!k.success)return{success:!1,repoPath:null,error:k.error};let l=k.credential&&k.token?function(a,b,c){let d;try{d=new URL(a)}catch{return a}return"https:"!==d.protocol&&"http:"!==d.protocol?a:("github"===b.type?d.username="x-access-token":d.username="oauth2",d.password=c,d.toString())}(g,k.credential,k.token):g,m=(0,f.default)();try{if(await m.clone(l,j),l!==g){let a=(0,f.default)(j);await a.remote(["set-url","origin",g])}return{success:!0,repoPath:j}}catch(b){let a=function(a,b){let c=a;for(let a of b)a&&(c=c.replace(RegExp(a.replace(/[.*+?^${}()|[\]\\]/g,"\\$&"),"g"),"***"));return c.replace(/:\/\/[^/\s@]+@/g,"://***@")}(b instanceof Error?b.message:String(b),[l,k.token??""]);try{await c.default.rm(j,{recursive:!0,force:!0})}catch{}return{success:!1,repoPath:null,error:a||"Failed to clone repository."}}}async function v(){let a=d.default.homedir(),b=e.default.join(a,".viba","drafts");try{await c.default.mkdir(b,{recursive:!0})}catch{}return b}async function w(a){try{let b=await v(),d=e.default.basename(a.id),f=e.default.join(b,`${d}.json`);return await c.default.writeFile(f,JSON.stringify(a,null,2),"utf-8"),{success:!0}}catch(a){return console.error("Failed to save draft:",a),{success:!1,error:"Failed to save draft"}}}async function x(a){try{let b=await v(),d=(await c.default.readdir(b)).filter(a=>a.endsWith(".json")).map(async a=>{try{let d=e.default.join(b,a),f=await c.default.readFile(d,"utf-8");return JSON.parse(f)}catch(b){return console.error(`Failed to parse draft file ${a}:`,b),null}}),f=(await Promise.all(d)).filter(a=>null!==a);if(a)return f.filter(b=>b.repoPath===a).sort((a,b)=>b.timestamp.localeCompare(a.timestamp));return f.sort((a,b)=>b.timestamp.localeCompare(a.timestamp))}catch(a){if("ENOENT"===a.code)return[];return console.error("Failed to list drafts:",a),[]}}async function y(a){try{let b=await v(),d=e.default.basename(a),f=e.default.join(b,`${d}.json`);return await c.default.rm(f,{force:!0}),{success:!0}}catch(a){return console.error("Failed to delete draft:",a),{success:!1,error:"Failed to delete draft"}}}(0,q.ensureServerEntryExports)([r,u]),(0,b.registerServerReference)(r,"406e55689bd4d60b7bef008dfcc9415ff917b2413f",null),(0,b.registerServerReference)(u,"60fbf2fb04f332edcee6563c44f2fef7b415243471",null),a.s(["cloneRemoteRepository",()=>u,"resolveRepositoryByName",()=>r],98624),(0,q.ensureServerEntryExports)([w,x,y]),(0,b.registerServerReference)(w,"405e87466910bb2d5eff3ce247e90fa9cb23615c76",null),(0,b.registerServerReference)(x,"40d40f52a81fb0ea27467e8134fa601de8a89b4d05",null),(0,b.registerServerReference)(y,"40bdd2f8c1c344918cb4a14b7f95e9f9ace09bcd59",null),a.s(["deleteDraft",()=>y,"listDrafts",()=>x,"saveDraft",()=>w],54569)},273,a=>{"use strict";var b=a.i(15271),c=a.i(98624),d=a.i(51817),e=a.i(54569),f=a.i(38642),g=a.i(37359);a.s([],62514),a.i(62514),a.s(["006b7a10f839b3ad9a8e3cb7090a78f9691c43c62f",()=>g.listAgentApiCredentials,"007d90dd1f07569d7a2aae4c796aed2c03e4694188",()=>b.getHomeDirectory,"008c06297149d94056cb210d81ed9e5e14c82c759a",()=>g.listCredentials,"00bac238160f6cbb4f2ca4739ca6a585935b48f718",()=>f.getConfig,"40228ca9cf9057df131ed69114d7b55dcd698cad5f",()=>b.checkAgentCliInstalled,"402c59a757ee26cd5b6333d926910162bae2289139",()=>b.checkDirectoryAccessible,"402efc1bee344cf0f115f1f55563f38d8d9b6f299d",()=>f.updateConfig,"405e87466910bb2d5eff3ce247e90fa9cb23615c76",()=>e.saveDraft,"40678e1105030fe091fb7efdb7818b5a553469f3b2",()=>b.installAgentCli,"4069ff2ff3d5aee19975244970239f292a8c0ef8de",()=>b.getBranches,"406deb432559c7ce9c05f3125d7916008c54ad22b7",()=>b.listPathEntries,"406e55689bd4d60b7bef008dfcc9415ff917b2413f",()=>c.resolveRepositoryByName,"40951eae6d84986ca79cba89568e8a837c2918ec45",()=>d.listSessions,"40a5e24f6e280925fbc5dfc520b7c380871d373dd4",()=>b.listDirectories,"40bdd2f8c1c344918cb4a14b7f95e9f9ace09bcd59",()=>e.deleteDraft,"40d1a1b9e44f81a0f1d8db707ada31607fa8d48e16",()=>d.deleteSession,"40d40f52a81fb0ea27467e8134fa601de8a89b4d05",()=>e.listDrafts,"40e7dfe25f9f0da1741852cf9137e6da99ab049e82",()=>b.checkIsGitRepo,"40ee6b9acab660ba2044c1691d4c83a24cd970c769",()=>d.getSessionPrefillContext,"60281d6697ea4b6f123840e8983a85369c3d08ec6c",()=>d.saveSessionLaunchContext,"6066891bcab85bb2f4db9c126afdcc8f7d7bf9e671",()=>b.checkoutBranch,"60e7cd74eaea66a45846e06028f77dbf85d91b19e1",()=>f.updateRepoSettings,"60fbf2fb04f332edcee6563c44f2fef7b415243471",()=>c.cloneRemoteRepository,"700e352ecc485fe721e4fb0bed02a8d4164d9e24cb",()=>d.createSession,"7f27639e2b4f526e35765066b84359d7e4c45c216e",()=>b.saveAttachments,"7f562b2d529316393195741e7bcfd0b62d6eaa1725",()=>b.listRepoFiles,"7f95b01caed7f9e17d19b04dd1aebe9ffdc28d994e",()=>b.getDefaultDevServerScript,"7fe46f64af5aab56d1a28bffcaa2fe27dceb1be94d",()=>b.startTtydProcess,"7ff3960b4c70fefca8c3019702193765dcf853fb0e",()=>b.getStartupScript],273)},45581,a=>{a.v(b=>Promise.all(["server/chunks/ssr/[externals]_keytar_23140f5c._.js"].map(b=>a.l(b))).then(()=>b(83034)))},44264,a=>{a.v(a=>Promise.resolve().then(()=>a(33405)))},37706,a=>{a.v(b=>Promise.all(["server/chunks/ssr/[root-of-the-server]__edf0aa7a._.js"].map(b=>a.l(b))).then(()=>b(78775)))}];
1
+ module.exports=[24868,(a,b,c)=>{b.exports=a.x("fs/promises",()=>require("fs/promises"))},50227,(a,b,c)=>{b.exports=a.x("node:path",()=>require("node:path"))},46786,(a,b,c)=>{b.exports=a.x("os",()=>require("os"))},22734,(a,b,c)=>{b.exports=a.x("fs",()=>require("fs"))},33405,(a,b,c)=>{b.exports=a.x("child_process",()=>require("child_process"))},70722,(a,b,c)=>{b.exports=a.x("tty",()=>require("tty"))},51615,(a,b,c)=>{b.exports=a.x("node:buffer",()=>require("node:buffer"))},87769,(a,b,c)=>{b.exports=a.x("node:events",()=>require("node:events"))},98624,54569,a=>{"use strict";var b=a.i(37936),c=a.i(24868),d=a.i(46786),e=a.i(14747),f=a.i(4503),g=a.i(38642);let h=new Set([".git","node_modules",".next",".viba","dist","build","coverage"]);function i(){return global.repoResolutionCache||(global.repoResolutionCache=new Map),global.repoResolutionCache}function j(a,b){i().set(a.toLowerCase(),{repoPath:b,resolvedAt:Date.now()})}async function k(a){let b=i().get(a.toLowerCase());return b?Date.now()-b.resolvedAt>3e5?(i().delete(a.toLowerCase()),null):await l(b.repoPath)?b.repoPath:(i().delete(a.toLowerCase()),null):null}async function l(a){try{return await c.default.access(e.default.join(a,".git")),!0}catch{return!1}}async function m(a,b){let d=e.default.join(a,b);if(await l(d))return d;let f=[{dirPath:a,depth:0}],g=0,i=b.toLowerCase();for(let a=0;a<f.length;a+=1){let b,d=f[a];if((g+=1)>5e3)break;try{b=await c.default.readdir(d.dirPath,{withFileTypes:!0})}catch{continue}for(let a of b){if(!a.isDirectory()||function(a,b){let c=a.toLowerCase();return c!==b&&!!(h.has(c)||a.startsWith("."))}(a.name,i))continue;let b=e.default.join(d.dirPath,a.name);if(a.name.toLowerCase()===i&&await l(b))return b;d.depth+1<=5&&f.push({dirPath:b,depth:d.depth+1})}}return null}async function n(a){let b=a.trim();if(!b)return null;let c=await k(b);if(c)return c;let d=await (0,g.getConfig)();for(let a of d.recentRepos.filter(a=>e.default.basename(a).toLowerCase()===b.toLowerCase()))if(await l(a))return j(b,a),a;let f=[],h=new Set;for(let a of d.recentRepos){let b=e.default.dirname(a);h.has(b)||(h.add(b),f.push(b))}for(let a of(d.defaultRoot&&!h.has(d.defaultRoot)&&(h.add(d.defaultRoot),f.push(d.defaultRoot)),f)){let c=await m(a,b);if(c)return j(b,c),c}return null}var o=a.i(70798),p=a.i(46534),q=a.i(13095);async function r(a){try{let b=await n(a);return{success:!0,repoPath:b}}catch(a){return console.error("Failed to resolve repository by name:",a),{success:!1,repoPath:null,error:"Failed to search repositories. Please try again."}}}function s(a){if("gitlab"!==a.type)return null;try{return new URL(a.serverUrl).hostname.toLowerCase()}catch{return null}}async function t(a,b){let c=await (0,o.getAllCredentials)(),d=(0,p.detectGitRemoteProvider)(a,{gitlabHosts:c.flatMap(a=>{if("gitlab"!==a.type)return[];let b=s(a);return b?[b]:[]})}),e=(0,p.parseGitRemoteHost)(a);if(b){let a=await (0,o.getCredentialById)(b);if(!a)return{success:!1,error:"Selected credential was not found. Please choose another credential."};if("github"===d&&"github"!==a.type)return{success:!1,error:"Selected credential does not match this GitHub repository."};if("gitlab"===d&&"gitlab"!==a.type)return{success:!1,error:"Selected credential does not match this GitLab repository."};if("gitlab"===a.type&&e){let b=s(a);if(b&&b!==e)return{success:!1,error:`Selected GitLab credential targets ${b}, but this repository uses ${e}.`}}let c=await (0,o.getCredentialToken)(a.id);return c?{success:!0,credential:a,token:c}:{success:!1,error:"Could not load token for selected credential."}}if(!d)return{success:!0,credential:null,token:null};let f=function(a,b,c){if("github"===b)return a.find(a=>"github"===a.type)||null;if(c){let b=a.find(a=>"gitlab"===a.type&&s(a)===c);if(b)return b}return a.find(a=>"gitlab"===a.type)||null}(c,d,e);if(!f)return{success:!0,credential:null,token:null};let g=await (0,o.getCredentialToken)(f.id);return g?{success:!0,credential:f,token:g}:{success:!0,credential:null,token:null}}async function u(a,b){let g=a.trim();if(!g)return{success:!1,repoPath:null,error:"Please enter a remote repository URL."};let h=function(a){let b=a.trim();if(!b)return null;let c="";try{c=new URL(b).pathname}catch{let a=b.match(/^([^@]+@)?([^:]+):(.+)$/);c=a?a[3]:b}let d=c.replace(/\\/g,"/").replace(/\/+$/,"");if(!d)return null;let f=e.default.posix.basename(d);return f&&"."!==f&&".."!==f?(f.toLowerCase().endsWith(".git")&&(f=f.slice(0,-4)),f.replace(/[^a-zA-Z0-9._-]/g,"-").replace(/^-+/,"").replace(/-+$/,"")||null):null}(g);if(!h)return{success:!1,repoPath:null,error:"Could not determine repository name from URL."};let i=e.default.join(d.default.homedir(),".viba","repos");await c.default.mkdir(i,{recursive:!0});let j=e.default.join(i,h);try{return await c.default.access(j),{success:!1,repoPath:null,error:`Repository already exists at ${j}.`}}catch{}let k=await t(g,b);if(!k.success)return{success:!1,repoPath:null,error:k.error};let l=k.credential&&k.token?function(a,b,c){let d;try{d=new URL(a)}catch{return a}return"https:"!==d.protocol&&"http:"!==d.protocol?a:("github"===b.type?d.username="x-access-token":d.username="oauth2",d.password=c,d.toString())}(g,k.credential,k.token):g,m=(0,f.default)();try{if(await m.clone(l,j),l!==g){let a=(0,f.default)(j);await a.remote(["set-url","origin",g])}return{success:!0,repoPath:j}}catch(b){let a=function(a,b){let c=a;for(let a of b)a&&(c=c.replace(RegExp(a.replace(/[.*+?^${}()|[\]\\]/g,"\\$&"),"g"),"***"));return c.replace(/:\/\/[^/\s@]+@/g,"://***@")}(b instanceof Error?b.message:String(b),[l,k.token??""]);try{await c.default.rm(j,{recursive:!0,force:!0})}catch{}return{success:!1,repoPath:null,error:a||"Failed to clone repository."}}}async function v(){let a=d.default.homedir(),b=e.default.join(a,".viba","drafts");try{await c.default.mkdir(b,{recursive:!0})}catch{}return b}async function w(a){try{let b=await v(),d=e.default.basename(a.id),f=e.default.join(b,`${d}.json`);return await c.default.writeFile(f,JSON.stringify(a,null,2),"utf-8"),{success:!0}}catch(a){return console.error("Failed to save draft:",a),{success:!1,error:"Failed to save draft"}}}async function x(a){try{let b=await v(),d=(await c.default.readdir(b)).filter(a=>a.endsWith(".json")).map(async a=>{try{let d=e.default.join(b,a),f=await c.default.readFile(d,"utf-8");return JSON.parse(f)}catch(b){return console.error(`Failed to parse draft file ${a}:`,b),null}}),f=(await Promise.all(d)).filter(a=>null!==a);if(a)return f.filter(b=>b.repoPath===a).sort((a,b)=>b.timestamp.localeCompare(a.timestamp));return f.sort((a,b)=>b.timestamp.localeCompare(a.timestamp))}catch(a){if("ENOENT"===a.code)return[];return console.error("Failed to list drafts:",a),[]}}async function y(a){try{let b=await v(),d=e.default.basename(a),f=e.default.join(b,`${d}.json`);return await c.default.rm(f,{force:!0}),{success:!0}}catch(a){return console.error("Failed to delete draft:",a),{success:!1,error:"Failed to delete draft"}}}(0,q.ensureServerEntryExports)([r,u]),(0,b.registerServerReference)(r,"4056c2d421a6496afc541c171fc8c5f07896f63d9d",null),(0,b.registerServerReference)(u,"60370cbf08c36feb62e821a4399d1a0c168e16068f",null),a.s(["cloneRemoteRepository",()=>u,"resolveRepositoryByName",()=>r],98624),(0,q.ensureServerEntryExports)([w,x,y]),(0,b.registerServerReference)(w,"40679547d387756c417d2d2f35102b698e0a67d687",null),(0,b.registerServerReference)(x,"405d04a3fc97df7ce43071e3a04c76b03549d8239d",null),(0,b.registerServerReference)(y,"40becbae10bf62199024bd208e66b7a8154f9348d8",null),a.s(["deleteDraft",()=>y,"listDrafts",()=>x,"saveDraft",()=>w],54569)},273,a=>{"use strict";var b=a.i(15271),c=a.i(98624),d=a.i(51817),e=a.i(54569),f=a.i(38642),g=a.i(37359);a.s([],62514),a.i(62514),a.s(["001b894791a4b6460f5e7976aa47184bc45cccd1ca",()=>f.getConfig,"0037e57dce0e01173d262d9f2abbeeda52df8d7e4f",()=>g.listCredentials,"007854b56845eeafde2c9685b51a376a63b707aad1",()=>g.listAgentApiCredentials,"00c42c62027b5d02c596fe16ee30d5783683fcde57",()=>b.getHomeDirectory,"4000b972582455e64c1ab00abe5f79db0789385cae",()=>b.checkDirectoryAccessible,"402089b844ceae2b51bfc1d67e27ed1deb33b9f2ed",()=>b.listPathEntries,"402cc9f24e2f01d3cf38b84bce06380a2c8324bf72",()=>b.installAgentCli,"40359a46ff3adb05f98426e1a48aedde438fecf99b",()=>d.deleteSession,"404b0c3413351a0ceb0c2edd4cfcd6095605249ea1",()=>f.updateConfig,"4056c2d421a6496afc541c171fc8c5f07896f63d9d",()=>c.resolveRepositoryByName,"405d04a3fc97df7ce43071e3a04c76b03549d8239d",()=>e.listDrafts,"40634628ed9cb943f76f6b561a346b4ae6ba9335e3",()=>d.listSessions,"40679547d387756c417d2d2f35102b698e0a67d687",()=>e.saveDraft,"40759173325b9646ec5624f13388be061ee645114b",()=>b.checkAgentCliInstalled,"407ceb272444008516d5f4d59070827b023d1bfccb",()=>b.checkIsGitRepo,"40840d7347bea9b4c4ee1b05b18ef8bb70a8d61c94",()=>b.getBranches,"40bcb98d167ff02ebab0a4e5bd4ddf2ecdf1f61b80",()=>b.listDirectories,"40becbae10bf62199024bd208e66b7a8154f9348d8",()=>e.deleteDraft,"40da6c6fcb5ba59241703ecbdccba707c6ed39c527",()=>d.getSessionPrefillContext,"60014bab1edd0396e44ce41ee05410733e78a9e289",()=>b.checkoutBranch,"60370cbf08c36feb62e821a4399d1a0c168e16068f",()=>c.cloneRemoteRepository,"6039f2db2aff8d97e5fdf12e537278157cb2e4abf9",()=>d.saveSessionLaunchContext,"60e267f5fdf59cea403233b78e9c9539fb282154c6",()=>f.updateRepoSettings,"70b02a987fc1397aca7320ded1dcc15e452f2897ea",()=>d.createSession,"7f1b374fdd8af2a813d5c697cc2795318c69ef2f21",()=>b.getDefaultDevServerScript,"7f297b257751e7e19f85ea91b0cef70d46d19533d5",()=>b.getStartupScript,"7f4d4efe031b5e6237c2104da524b911956ea41afe",()=>b.listRepoFiles,"7f6a24d6dbde9f9a254586e16aca851717e4e475f0",()=>b.startTtydProcess,"7fe6396fcd9d2af4d2846c10ca24c789d2bf63c57d",()=>b.saveAttachments],273)},45581,a=>{a.v(b=>Promise.all(["server/chunks/ssr/[externals]_keytar_23140f5c._.js"].map(b=>a.l(b))).then(()=>b(83034)))},44264,a=>{a.v(a=>Promise.resolve().then(()=>a(33405)))},37706,a=>{a.v(b=>Promise.all(["server/chunks/ssr/[root-of-the-server]__edf0aa7a._.js"].map(b=>a.l(b))).then(()=>b(78775)))}];
2
2
 
3
- //# sourceMappingURL=%5Broot-of-the-server%5D__79a7a15d._.js.map
3
+ //# sourceMappingURL=%5Broot-of-the-server%5D__0ed2deb1._.js.map