@mesrai/cli 0.4.21

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 (629) hide show
  1. package/README.md +670 -0
  2. package/dist/agents/agent.interface.d.ts +41 -0
  3. package/dist/agents/agent.interface.d.ts.map +1 -0
  4. package/dist/agents/agent.interface.js +2 -0
  5. package/dist/agents/agent.interface.js.map +1 -0
  6. package/dist/agents/claude-code.agent.d.ts +14 -0
  7. package/dist/agents/claude-code.agent.d.ts.map +1 -0
  8. package/dist/agents/claude-code.agent.js +90 -0
  9. package/dist/agents/claude-code.agent.js.map +1 -0
  10. package/dist/agents/codex.agent.d.ts +14 -0
  11. package/dist/agents/codex.agent.d.ts.map +1 -0
  12. package/dist/agents/codex.agent.js +77 -0
  13. package/dist/agents/codex.agent.js.map +1 -0
  14. package/dist/agents/cursor.agent.d.ts +29 -0
  15. package/dist/agents/cursor.agent.d.ts.map +1 -0
  16. package/dist/agents/cursor.agent.js +85 -0
  17. package/dist/agents/cursor.agent.js.map +1 -0
  18. package/dist/cli.d.ts +4 -0
  19. package/dist/cli.d.ts.map +1 -0
  20. package/dist/cli.js +60 -0
  21. package/dist/cli.js.map +1 -0
  22. package/dist/commands/auth/index.d.ts +3 -0
  23. package/dist/commands/auth/index.d.ts.map +1 -0
  24. package/dist/commands/auth/index.js +37 -0
  25. package/dist/commands/auth/index.js.map +1 -0
  26. package/dist/commands/auth/login.d.ts +11 -0
  27. package/dist/commands/auth/login.d.ts.map +1 -0
  28. package/dist/commands/auth/login.js +158 -0
  29. package/dist/commands/auth/login.js.map +1 -0
  30. package/dist/commands/auth/logout.d.ts +2 -0
  31. package/dist/commands/auth/logout.d.ts.map +1 -0
  32. package/dist/commands/auth/logout.js +26 -0
  33. package/dist/commands/auth/logout.js.map +1 -0
  34. package/dist/commands/auth/status.d.ts +2 -0
  35. package/dist/commands/auth/status.d.ts.map +1 -0
  36. package/dist/commands/auth/status.js +82 -0
  37. package/dist/commands/auth/status.js.map +1 -0
  38. package/dist/commands/auth/team-key.d.ts +5 -0
  39. package/dist/commands/auth/team-key.d.ts.map +1 -0
  40. package/dist/commands/auth/team-key.js +112 -0
  41. package/dist/commands/auth/team-key.js.map +1 -0
  42. package/dist/commands/auth/token.d.ts +2 -0
  43. package/dist/commands/auth/token.d.ts.map +1 -0
  44. package/dist/commands/auth/token.js +33 -0
  45. package/dist/commands/auth/token.js.map +1 -0
  46. package/dist/commands/config.d.ts +5 -0
  47. package/dist/commands/config.d.ts.map +1 -0
  48. package/dist/commands/config.js +26 -0
  49. package/dist/commands/config.js.map +1 -0
  50. package/dist/commands/diff.d.ts +3 -0
  51. package/dist/commands/diff.d.ts.map +1 -0
  52. package/dist/commands/diff.js +23 -0
  53. package/dist/commands/diff.js.map +1 -0
  54. package/dist/commands/hook/index.d.ts +3 -0
  55. package/dist/commands/hook/index.d.ts.map +1 -0
  56. package/dist/commands/hook/index.js +24 -0
  57. package/dist/commands/hook/index.js.map +1 -0
  58. package/dist/commands/hook/install.d.ts +11 -0
  59. package/dist/commands/hook/install.d.ts.map +1 -0
  60. package/dist/commands/hook/install.js +149 -0
  61. package/dist/commands/hook/install.js.map +1 -0
  62. package/dist/commands/hook/status.d.ts +2 -0
  63. package/dist/commands/hook/status.d.ts.map +1 -0
  64. package/dist/commands/hook/status.js +36 -0
  65. package/dist/commands/hook/status.js.map +1 -0
  66. package/dist/commands/hook/uninstall.d.ts +5 -0
  67. package/dist/commands/hook/uninstall.d.ts.map +1 -0
  68. package/dist/commands/hook/uninstall.js +66 -0
  69. package/dist/commands/hook/uninstall.js.map +1 -0
  70. package/dist/commands/memory/capture.d.ts +8 -0
  71. package/dist/commands/memory/capture.d.ts.map +1 -0
  72. package/dist/commands/memory/capture.js +124 -0
  73. package/dist/commands/memory/capture.js.map +1 -0
  74. package/dist/commands/memory/disable.d.ts +5 -0
  75. package/dist/commands/memory/disable.d.ts.map +1 -0
  76. package/dist/commands/memory/disable.js +67 -0
  77. package/dist/commands/memory/disable.js.map +1 -0
  78. package/dist/commands/memory/enable.d.ts +7 -0
  79. package/dist/commands/memory/enable.d.ts.map +1 -0
  80. package/dist/commands/memory/enable.js +74 -0
  81. package/dist/commands/memory/enable.js.map +1 -0
  82. package/dist/commands/memory/hooks.d.ts +31 -0
  83. package/dist/commands/memory/hooks.d.ts.map +1 -0
  84. package/dist/commands/memory/hooks.js +283 -0
  85. package/dist/commands/memory/hooks.js.map +1 -0
  86. package/dist/commands/memory/index.d.ts +3 -0
  87. package/dist/commands/memory/index.d.ts.map +1 -0
  88. package/dist/commands/memory/index.js +36 -0
  89. package/dist/commands/memory/index.js.map +1 -0
  90. package/dist/commands/memory/session-hooks/claude-code.d.ts +2 -0
  91. package/dist/commands/memory/session-hooks/claude-code.d.ts.map +1 -0
  92. package/dist/commands/memory/session-hooks/claude-code.js +24 -0
  93. package/dist/commands/memory/session-hooks/claude-code.js.map +1 -0
  94. package/dist/commands/memory/session-hooks/codex.d.ts +2 -0
  95. package/dist/commands/memory/session-hooks/codex.d.ts.map +1 -0
  96. package/dist/commands/memory/session-hooks/codex.js +16 -0
  97. package/dist/commands/memory/session-hooks/codex.js.map +1 -0
  98. package/dist/commands/memory/session-hooks/cursor.d.ts +2 -0
  99. package/dist/commands/memory/session-hooks/cursor.d.ts.map +1 -0
  100. package/dist/commands/memory/session-hooks/cursor.js +20 -0
  101. package/dist/commands/memory/session-hooks/cursor.js.map +1 -0
  102. package/dist/commands/memory/session-hooks/index.d.ts +3 -0
  103. package/dist/commands/memory/session-hooks/index.d.ts.map +1 -0
  104. package/dist/commands/memory/session-hooks/index.js +21 -0
  105. package/dist/commands/memory/session-hooks/index.js.map +1 -0
  106. package/dist/commands/memory/session-hooks/shared.d.ts +7 -0
  107. package/dist/commands/memory/session-hooks/shared.d.ts.map +1 -0
  108. package/dist/commands/memory/session-hooks/shared.js +52 -0
  109. package/dist/commands/memory/session-hooks/shared.js.map +1 -0
  110. package/dist/commands/memory/session-hooks-install-codex.d.ts +19 -0
  111. package/dist/commands/memory/session-hooks-install-codex.d.ts.map +1 -0
  112. package/dist/commands/memory/session-hooks-install-codex.js +91 -0
  113. package/dist/commands/memory/session-hooks-install-codex.js.map +1 -0
  114. package/dist/commands/memory/session-hooks-install-cursor.d.ts +9 -0
  115. package/dist/commands/memory/session-hooks-install-cursor.d.ts.map +1 -0
  116. package/dist/commands/memory/session-hooks-install-cursor.js +119 -0
  117. package/dist/commands/memory/session-hooks-install-cursor.js.map +1 -0
  118. package/dist/commands/memory/session-hooks-install.d.ts +9 -0
  119. package/dist/commands/memory/session-hooks-install.d.ts.map +1 -0
  120. package/dist/commands/memory/session-hooks-install.js +173 -0
  121. package/dist/commands/memory/session-hooks-install.js.map +1 -0
  122. package/dist/commands/pr.d.ts +2 -0
  123. package/dist/commands/pr.d.ts.map +1 -0
  124. package/dist/commands/pr.js +2 -0
  125. package/dist/commands/pr.js.map +1 -0
  126. package/dist/commands/review.d.ts +2 -0
  127. package/dist/commands/review.d.ts.map +1 -0
  128. package/dist/commands/review.js +2 -0
  129. package/dist/commands/review.js.map +1 -0
  130. package/dist/commands/rules.d.ts +31 -0
  131. package/dist/commands/rules.d.ts.map +1 -0
  132. package/dist/commands/rules.js +159 -0
  133. package/dist/commands/rules.js.map +1 -0
  134. package/dist/commands/schema.d.ts +3 -0
  135. package/dist/commands/schema.d.ts.map +1 -0
  136. package/dist/commands/schema.js +62 -0
  137. package/dist/commands/schema.js.map +1 -0
  138. package/dist/commands/skills.d.ts +3 -0
  139. package/dist/commands/skills.d.ts.map +1 -0
  140. package/dist/commands/skills.js +85 -0
  141. package/dist/commands/skills.js.map +1 -0
  142. package/dist/commands/status.d.ts +3 -0
  143. package/dist/commands/status.d.ts.map +1 -0
  144. package/dist/commands/status.js +99 -0
  145. package/dist/commands/status.js.map +1 -0
  146. package/dist/commands/subscribe.d.ts +4 -0
  147. package/dist/commands/subscribe.d.ts.map +1 -0
  148. package/dist/commands/subscribe.js +25 -0
  149. package/dist/commands/subscribe.js.map +1 -0
  150. package/dist/commands/update.d.ts +10 -0
  151. package/dist/commands/update.d.ts.map +1 -0
  152. package/dist/commands/update.js +112 -0
  153. package/dist/commands/update.js.map +1 -0
  154. package/dist/constants.d.ts +3 -0
  155. package/dist/constants.d.ts.map +1 -0
  156. package/dist/constants.js +6 -0
  157. package/dist/constants.js.map +1 -0
  158. package/dist/features/centralized-config/actions.d.ts +20 -0
  159. package/dist/features/centralized-config/actions.d.ts.map +1 -0
  160. package/dist/features/centralized-config/actions.js +114 -0
  161. package/dist/features/centralized-config/actions.js.map +1 -0
  162. package/dist/features/centralized-config/command.d.ts +4 -0
  163. package/dist/features/centralized-config/command.d.ts.map +1 -0
  164. package/dist/features/centralized-config/command.js +43 -0
  165. package/dist/features/centralized-config/command.js.map +1 -0
  166. package/dist/features/pr/command.d.ts +4 -0
  167. package/dist/features/pr/command.d.ts.map +1 -0
  168. package/dist/features/pr/command.js +222 -0
  169. package/dist/features/pr/command.js.map +1 -0
  170. package/dist/features/repo-config/actions.d.ts +33 -0
  171. package/dist/features/repo-config/actions.d.ts.map +1 -0
  172. package/dist/features/repo-config/actions.js +271 -0
  173. package/dist/features/repo-config/actions.js.map +1 -0
  174. package/dist/features/repo-config/command.d.ts +15 -0
  175. package/dist/features/repo-config/command.d.ts.map +1 -0
  176. package/dist/features/repo-config/command.js +135 -0
  177. package/dist/features/repo-config/command.js.map +1 -0
  178. package/dist/features/review/command.d.ts +4 -0
  179. package/dist/features/review/command.d.ts.map +1 -0
  180. package/dist/features/review/command.js +404 -0
  181. package/dist/features/review/command.js.map +1 -0
  182. package/dist/features/review/diff.d.ts +23 -0
  183. package/dist/features/review/diff.d.ts.map +1 -0
  184. package/dist/features/review/diff.js +47 -0
  185. package/dist/features/review/diff.js.map +1 -0
  186. package/dist/features/review/errors.d.ts +3 -0
  187. package/dist/features/review/errors.d.ts.map +1 -0
  188. package/dist/features/review/errors.js +26 -0
  189. package/dist/features/review/errors.js.map +1 -0
  190. package/dist/features/review/hunk-context.d.ts +25 -0
  191. package/dist/features/review/hunk-context.d.ts.map +1 -0
  192. package/dist/features/review/hunk-context.js +158 -0
  193. package/dist/features/review/hunk-context.js.map +1 -0
  194. package/dist/features/review/hunk-viewer.d.ts +25 -0
  195. package/dist/features/review/hunk-viewer.d.ts.map +1 -0
  196. package/dist/features/review/hunk-viewer.js +59 -0
  197. package/dist/features/review/hunk-viewer.js.map +1 -0
  198. package/dist/features/review/no-changes.d.ts +6 -0
  199. package/dist/features/review/no-changes.d.ts.map +1 -0
  200. package/dist/features/review/no-changes.js +31 -0
  201. package/dist/features/review/no-changes.js.map +1 -0
  202. package/dist/features/review/options.d.ts +7 -0
  203. package/dist/features/review/options.d.ts.map +1 -0
  204. package/dist/features/review/options.js +18 -0
  205. package/dist/features/review/options.js.map +1 -0
  206. package/dist/features/review/result.d.ts +40 -0
  207. package/dist/features/review/result.d.ts.map +1 -0
  208. package/dist/features/review/result.js +95 -0
  209. package/dist/features/review/result.js.map +1 -0
  210. package/dist/formatters/json.d.ts +7 -0
  211. package/dist/formatters/json.d.ts.map +1 -0
  212. package/dist/formatters/json.js +7 -0
  213. package/dist/formatters/json.js.map +1 -0
  214. package/dist/formatters/markdown.d.ts +7 -0
  215. package/dist/formatters/markdown.d.ts.map +1 -0
  216. package/dist/formatters/markdown.js +93 -0
  217. package/dist/formatters/markdown.js.map +1 -0
  218. package/dist/formatters/prompt.d.ts +12 -0
  219. package/dist/formatters/prompt.d.ts.map +1 -0
  220. package/dist/formatters/prompt.js +90 -0
  221. package/dist/formatters/prompt.js.map +1 -0
  222. package/dist/formatters/repo-config.d.ts +7 -0
  223. package/dist/formatters/repo-config.d.ts.map +1 -0
  224. package/dist/formatters/repo-config.js +99 -0
  225. package/dist/formatters/repo-config.js.map +1 -0
  226. package/dist/formatters/terminal.d.ts +7 -0
  227. package/dist/formatters/terminal.d.ts.map +1 -0
  228. package/dist/formatters/terminal.js +130 -0
  229. package/dist/formatters/terminal.js.map +1 -0
  230. package/dist/index.d.ts +3 -0
  231. package/dist/index.d.ts.map +1 -0
  232. package/dist/index.js +51 -0
  233. package/dist/index.js.map +1 -0
  234. package/dist/services/api/api-core.d.ts +27 -0
  235. package/dist/services/api/api-core.d.ts.map +1 -0
  236. package/dist/services/api/api-core.js +451 -0
  237. package/dist/services/api/api-core.js.map +1 -0
  238. package/dist/services/api/api.interface.d.ts +101 -0
  239. package/dist/services/api/api.interface.d.ts.map +1 -0
  240. package/dist/services/api/api.interface.js +2 -0
  241. package/dist/services/api/api.interface.js.map +1 -0
  242. package/dist/services/api/api.real.d.ts +19 -0
  243. package/dist/services/api/api.real.d.ts.map +1 -0
  244. package/dist/services/api/api.real.js +20 -0
  245. package/dist/services/api/api.real.js.map +1 -0
  246. package/dist/services/api/auth.api.d.ts +17 -0
  247. package/dist/services/api/auth.api.d.ts.map +1 -0
  248. package/dist/services/api/auth.api.js +73 -0
  249. package/dist/services/api/auth.api.js.map +1 -0
  250. package/dist/services/api/cli-auth.api.d.ts +29 -0
  251. package/dist/services/api/cli-auth.api.d.ts.map +1 -0
  252. package/dist/services/api/cli-auth.api.js +23 -0
  253. package/dist/services/api/cli-auth.api.js.map +1 -0
  254. package/dist/services/api/config.api.d.ts +34 -0
  255. package/dist/services/api/config.api.d.ts.map +1 -0
  256. package/dist/services/api/config.api.js +108 -0
  257. package/dist/services/api/config.api.js.map +1 -0
  258. package/dist/services/api/index.d.ts +4 -0
  259. package/dist/services/api/index.d.ts.map +1 -0
  260. package/dist/services/api/index.js +3 -0
  261. package/dist/services/api/index.js.map +1 -0
  262. package/dist/services/api/memory.api.d.ts +10 -0
  263. package/dist/services/api/memory.api.d.ts.map +1 -0
  264. package/dist/services/api/memory.api.js +19 -0
  265. package/dist/services/api/memory.api.js.map +1 -0
  266. package/dist/services/api/review.api.d.ts +27 -0
  267. package/dist/services/api/review.api.d.ts.map +1 -0
  268. package/dist/services/api/review.api.js +140 -0
  269. package/dist/services/api/review.api.js.map +1 -0
  270. package/dist/services/api/rules.api.d.ts +13 -0
  271. package/dist/services/api/rules.api.d.ts.map +1 -0
  272. package/dist/services/api/rules.api.js +41 -0
  273. package/dist/services/api/rules.api.js.map +1 -0
  274. package/dist/services/api/sessions.api.d.ts +6 -0
  275. package/dist/services/api/sessions.api.d.ts.map +1 -0
  276. package/dist/services/api/sessions.api.js +129 -0
  277. package/dist/services/api/sessions.api.js.map +1 -0
  278. package/dist/services/api/trial.api.d.ts +10 -0
  279. package/dist/services/api/trial.api.d.ts.map +1 -0
  280. package/dist/services/api/trial.api.js +11 -0
  281. package/dist/services/api/trial.api.js.map +1 -0
  282. package/dist/services/auth.service.d.ts +29 -0
  283. package/dist/services/auth.service.d.ts.map +1 -0
  284. package/dist/services/auth.service.js +190 -0
  285. package/dist/services/auth.service.js.map +1 -0
  286. package/dist/services/browser-login.service.d.ts +23 -0
  287. package/dist/services/browser-login.service.d.ts.map +1 -0
  288. package/dist/services/browser-login.service.js +187 -0
  289. package/dist/services/browser-login.service.js.map +1 -0
  290. package/dist/services/centralized-config.service.d.ts +24 -0
  291. package/dist/services/centralized-config.service.d.ts.map +1 -0
  292. package/dist/services/centralized-config.service.js +112 -0
  293. package/dist/services/centralized-config.service.js.map +1 -0
  294. package/dist/services/context.service.d.ts +25 -0
  295. package/dist/services/context.service.d.ts.map +1 -0
  296. package/dist/services/context.service.js +134 -0
  297. package/dist/services/context.service.js.map +1 -0
  298. package/dist/services/device-login.service.d.ts +23 -0
  299. package/dist/services/device-login.service.d.ts.map +1 -0
  300. package/dist/services/device-login.service.js +70 -0
  301. package/dist/services/device-login.service.js.map +1 -0
  302. package/dist/services/fix.service.d.ts +31 -0
  303. package/dist/services/fix.service.d.ts.map +1 -0
  304. package/dist/services/fix.service.js +121 -0
  305. package/dist/services/fix.service.js.map +1 -0
  306. package/dist/services/git-hooks.service.d.ts +20 -0
  307. package/dist/services/git-hooks.service.d.ts.map +1 -0
  308. package/dist/services/git-hooks.service.js +126 -0
  309. package/dist/services/git-hooks.service.js.map +1 -0
  310. package/dist/services/git.service.d.ts +44 -0
  311. package/dist/services/git.service.d.ts.map +1 -0
  312. package/dist/services/git.service.js +321 -0
  313. package/dist/services/git.service.js.map +1 -0
  314. package/dist/services/hook-logger.service.d.ts +18 -0
  315. package/dist/services/hook-logger.service.d.ts.map +1 -0
  316. package/dist/services/hook-logger.service.js +48 -0
  317. package/dist/services/hook-logger.service.js.map +1 -0
  318. package/dist/services/lifecycle-events.d.ts +49 -0
  319. package/dist/services/lifecycle-events.d.ts.map +1 -0
  320. package/dist/services/lifecycle-events.js +86 -0
  321. package/dist/services/lifecycle-events.js.map +1 -0
  322. package/dist/services/lifecycle-git-context.d.ts +15 -0
  323. package/dist/services/lifecycle-git-context.d.ts.map +1 -0
  324. package/dist/services/lifecycle-git-context.js +23 -0
  325. package/dist/services/lifecycle-git-context.js.map +1 -0
  326. package/dist/services/lifecycle-local-turn-state.d.ts +14 -0
  327. package/dist/services/lifecycle-local-turn-state.d.ts.map +1 -0
  328. package/dist/services/lifecycle-local-turn-state.js +18 -0
  329. package/dist/services/lifecycle-local-turn-state.js.map +1 -0
  330. package/dist/services/lifecycle-transcript.d.ts +25 -0
  331. package/dist/services/lifecycle-transcript.d.ts.map +1 -0
  332. package/dist/services/lifecycle-transcript.js +29 -0
  333. package/dist/services/lifecycle-transcript.js.map +1 -0
  334. package/dist/services/lifecycle-turn-data.d.ts +11 -0
  335. package/dist/services/lifecycle-turn-data.d.ts.map +1 -0
  336. package/dist/services/lifecycle-turn-data.js +23 -0
  337. package/dist/services/lifecycle-turn-data.js.map +1 -0
  338. package/dist/services/lifecycle.service.d.ts +14 -0
  339. package/dist/services/lifecycle.service.d.ts.map +1 -0
  340. package/dist/services/lifecycle.service.js +276 -0
  341. package/dist/services/lifecycle.service.js.map +1 -0
  342. package/dist/services/repo-config.service.d.ts +22 -0
  343. package/dist/services/repo-config.service.d.ts.map +1 -0
  344. package/dist/services/repo-config.service.js +81 -0
  345. package/dist/services/repo-config.service.js.map +1 -0
  346. package/dist/services/repo-settings-wizard.service.d.ts +19 -0
  347. package/dist/services/repo-settings-wizard.service.d.ts.map +1 -0
  348. package/dist/services/repo-settings-wizard.service.js +260 -0
  349. package/dist/services/repo-settings-wizard.service.js.map +1 -0
  350. package/dist/services/repo-settings.service.d.ts +30 -0
  351. package/dist/services/repo-settings.service.d.ts.map +1 -0
  352. package/dist/services/repo-settings.service.js +99 -0
  353. package/dist/services/repo-settings.service.js.map +1 -0
  354. package/dist/services/review-auth-fallback.d.ts +7 -0
  355. package/dist/services/review-auth-fallback.d.ts.map +1 -0
  356. package/dist/services/review-auth-fallback.js +25 -0
  357. package/dist/services/review-auth-fallback.js.map +1 -0
  358. package/dist/services/review-config-builder.d.ts +19 -0
  359. package/dist/services/review-config-builder.d.ts.map +1 -0
  360. package/dist/services/review-config-builder.js +29 -0
  361. package/dist/services/review-config-builder.js.map +1 -0
  362. package/dist/services/review-file-filter.d.ts +3 -0
  363. package/dist/services/review-file-filter.d.ts.map +1 -0
  364. package/dist/services/review-file-filter.js +35 -0
  365. package/dist/services/review-file-filter.js.map +1 -0
  366. package/dist/services/review-normalizer.d.ts +6 -0
  367. package/dist/services/review-normalizer.d.ts.map +1 -0
  368. package/dist/services/review-normalizer.js +62 -0
  369. package/dist/services/review-normalizer.js.map +1 -0
  370. package/dist/services/review-verbose.d.ts +28 -0
  371. package/dist/services/review-verbose.d.ts.map +1 -0
  372. package/dist/services/review-verbose.js +52 -0
  373. package/dist/services/review-verbose.js.map +1 -0
  374. package/dist/services/review.service.d.ts +38 -0
  375. package/dist/services/review.service.d.ts.map +1 -0
  376. package/dist/services/review.service.js +152 -0
  377. package/dist/services/review.service.js.map +1 -0
  378. package/dist/services/rules.service.d.ts +16 -0
  379. package/dist/services/rules.service.d.ts.map +1 -0
  380. package/dist/services/rules.service.js +98 -0
  381. package/dist/services/rules.service.js.map +1 -0
  382. package/dist/services/session-local.service.d.ts +25 -0
  383. package/dist/services/session-local.service.d.ts.map +1 -0
  384. package/dist/services/session-local.service.js +79 -0
  385. package/dist/services/session-local.service.js.map +1 -0
  386. package/dist/services/transcript-parser.service.d.ts +10 -0
  387. package/dist/services/transcript-parser.service.d.ts.map +1 -0
  388. package/dist/services/transcript-parser.service.js +127 -0
  389. package/dist/services/transcript-parser.service.js.map +1 -0
  390. package/dist/services/transcript.service.d.ts +33 -0
  391. package/dist/services/transcript.service.d.ts.map +1 -0
  392. package/dist/services/transcript.service.js +264 -0
  393. package/dist/services/transcript.service.js.map +1 -0
  394. package/dist/types/auth.d.ts +18 -0
  395. package/dist/types/auth.d.ts.map +1 -0
  396. package/dist/types/auth.js +2 -0
  397. package/dist/types/auth.js.map +1 -0
  398. package/dist/types/cli.d.ts +41 -0
  399. package/dist/types/cli.d.ts.map +1 -0
  400. package/dist/types/cli.js +2 -0
  401. package/dist/types/cli.js.map +1 -0
  402. package/dist/types/command-output.d.ts +29 -0
  403. package/dist/types/command-output.d.ts.map +1 -0
  404. package/dist/types/command-output.js +2 -0
  405. package/dist/types/command-output.js.map +1 -0
  406. package/dist/types/config.d.ts +68 -0
  407. package/dist/types/config.d.ts.map +1 -0
  408. package/dist/types/config.js +2 -0
  409. package/dist/types/config.js.map +1 -0
  410. package/dist/types/errors.d.ts +8 -0
  411. package/dist/types/errors.d.ts.map +1 -0
  412. package/dist/types/errors.js +15 -0
  413. package/dist/types/errors.js.map +1 -0
  414. package/dist/types/index.d.ts +10 -0
  415. package/dist/types/index.d.ts.map +1 -0
  416. package/dist/types/index.js +2 -0
  417. package/dist/types/index.js.map +1 -0
  418. package/dist/types/memory.d.ts +39 -0
  419. package/dist/types/memory.d.ts.map +1 -0
  420. package/dist/types/memory.js +2 -0
  421. package/dist/types/memory.js.map +1 -0
  422. package/dist/types/repo-config.d.ts +24 -0
  423. package/dist/types/repo-config.d.ts.map +1 -0
  424. package/dist/types/repo-config.js +2 -0
  425. package/dist/types/repo-config.js.map +1 -0
  426. package/dist/types/review.d.ts +112 -0
  427. package/dist/types/review.d.ts.map +1 -0
  428. package/dist/types/review.js +2 -0
  429. package/dist/types/review.js.map +1 -0
  430. package/dist/types/rules.d.ts +42 -0
  431. package/dist/types/rules.d.ts.map +1 -0
  432. package/dist/types/rules.js +7 -0
  433. package/dist/types/rules.js.map +1 -0
  434. package/dist/types/session-events.d.ts +48 -0
  435. package/dist/types/session-events.d.ts.map +1 -0
  436. package/dist/types/session-events.js +2 -0
  437. package/dist/types/session-events.js.map +1 -0
  438. package/dist/types/session.d.ts +150 -0
  439. package/dist/types/session.d.ts.map +1 -0
  440. package/dist/types/session.js +9 -0
  441. package/dist/types/session.js.map +1 -0
  442. package/dist/types/trial.d.ts +10 -0
  443. package/dist/types/trial.d.ts.map +1 -0
  444. package/dist/types/trial.js +2 -0
  445. package/dist/types/trial.js.map +1 -0
  446. package/dist/ui/interactive-formatters.d.ts +6 -0
  447. package/dist/ui/interactive-formatters.d.ts.map +1 -0
  448. package/dist/ui/interactive-formatters.js +61 -0
  449. package/dist/ui/interactive-formatters.js.map +1 -0
  450. package/dist/ui/interactive-helpers.d.ts +20 -0
  451. package/dist/ui/interactive-helpers.d.ts.map +1 -0
  452. package/dist/ui/interactive-helpers.js +82 -0
  453. package/dist/ui/interactive-helpers.js.map +1 -0
  454. package/dist/ui/interactive-renderers.d.ts +6 -0
  455. package/dist/ui/interactive-renderers.d.ts.map +1 -0
  456. package/dist/ui/interactive-renderers.js +82 -0
  457. package/dist/ui/interactive-renderers.js.map +1 -0
  458. package/dist/ui/interactive.d.ts +25 -0
  459. package/dist/ui/interactive.d.ts.map +1 -0
  460. package/dist/ui/interactive.js +228 -0
  461. package/dist/ui/interactive.js.map +1 -0
  462. package/dist/utils/auth-mode.d.ts +7 -0
  463. package/dist/utils/auth-mode.d.ts.map +1 -0
  464. package/dist/utils/auth-mode.js +42 -0
  465. package/dist/utils/auth-mode.js.map +1 -0
  466. package/dist/utils/banner.d.ts +2 -0
  467. package/dist/utils/banner.d.ts.map +1 -0
  468. package/dist/utils/banner.js +180 -0
  469. package/dist/utils/banner.js.map +1 -0
  470. package/dist/utils/cli-exit.d.ts +13 -0
  471. package/dist/utils/cli-exit.d.ts.map +1 -0
  472. package/dist/utils/cli-exit.js +29 -0
  473. package/dist/utils/cli-exit.js.map +1 -0
  474. package/dist/utils/clipboard.d.ts +2 -0
  475. package/dist/utils/clipboard.d.ts.map +1 -0
  476. package/dist/utils/clipboard.js +11 -0
  477. package/dist/utils/clipboard.js.map +1 -0
  478. package/dist/utils/command-context.d.ts +12 -0
  479. package/dist/utils/command-context.d.ts.map +1 -0
  480. package/dist/utils/command-context.js +15 -0
  481. package/dist/utils/command-context.js.map +1 -0
  482. package/dist/utils/command-errors.d.ts +12 -0
  483. package/dist/utils/command-errors.d.ts.map +1 -0
  484. package/dist/utils/command-errors.js +112 -0
  485. package/dist/utils/command-errors.js.map +1 -0
  486. package/dist/utils/command-output.d.ts +5 -0
  487. package/dist/utils/command-output.d.ts.map +1 -0
  488. package/dist/utils/command-output.js +46 -0
  489. package/dist/utils/command-output.js.map +1 -0
  490. package/dist/utils/command-schema.d.ts +29 -0
  491. package/dist/utils/command-schema.d.ts.map +1 -0
  492. package/dist/utils/command-schema.js +74 -0
  493. package/dist/utils/command-schema.js.map +1 -0
  494. package/dist/utils/commander-errors.d.ts +8 -0
  495. package/dist/utils/commander-errors.d.ts.map +1 -0
  496. package/dist/utils/commander-errors.js +79 -0
  497. package/dist/utils/commander-errors.js.map +1 -0
  498. package/dist/utils/commander-setup.d.ts +3 -0
  499. package/dist/utils/commander-setup.d.ts.map +1 -0
  500. package/dist/utils/commander-setup.js +10 -0
  501. package/dist/utils/commander-setup.js.map +1 -0
  502. package/dist/utils/config.d.ts +13 -0
  503. package/dist/utils/config.d.ts.map +1 -0
  504. package/dist/utils/config.js +71 -0
  505. package/dist/utils/config.js.map +1 -0
  506. package/dist/utils/credentials.d.ts +6 -0
  507. package/dist/utils/credentials.d.ts.map +1 -0
  508. package/dist/utils/credentials.js +64 -0
  509. package/dist/utils/credentials.js.map +1 -0
  510. package/dist/utils/device.d.ts +7 -0
  511. package/dist/utils/device.d.ts.map +1 -0
  512. package/dist/utils/device.js +133 -0
  513. package/dist/utils/device.js.map +1 -0
  514. package/dist/utils/field-mask.d.ts +2 -0
  515. package/dist/utils/field-mask.d.ts.map +1 -0
  516. package/dist/utils/field-mask.js +93 -0
  517. package/dist/utils/field-mask.js.map +1 -0
  518. package/dist/utils/git-diff.d.ts +5 -0
  519. package/dist/utils/git-diff.d.ts.map +1 -0
  520. package/dist/utils/git-diff.js +14 -0
  521. package/dist/utils/git-diff.js.map +1 -0
  522. package/dist/utils/git-file-reader.d.ts +22 -0
  523. package/dist/utils/git-file-reader.d.ts.map +1 -0
  524. package/dist/utils/git-file-reader.js +45 -0
  525. package/dist/utils/git-file-reader.js.map +1 -0
  526. package/dist/utils/git-file-selection.d.ts +14 -0
  527. package/dist/utils/git-file-selection.d.ts.map +1 -0
  528. package/dist/utils/git-file-selection.js +20 -0
  529. package/dist/utils/git-file-selection.js.map +1 -0
  530. package/dist/utils/git-file-targets.d.ts +4 -0
  531. package/dist/utils/git-file-targets.d.ts.map +1 -0
  532. package/dist/utils/git-file-targets.js +11 -0
  533. package/dist/utils/git-file-targets.js.map +1 -0
  534. package/dist/utils/git-remote.d.ts +7 -0
  535. package/dist/utils/git-remote.d.ts.map +1 -0
  536. package/dist/utils/git-remote.js +94 -0
  537. package/dist/utils/git-remote.js.map +1 -0
  538. package/dist/utils/git-status.d.ts +7 -0
  539. package/dist/utils/git-status.d.ts.map +1 -0
  540. package/dist/utils/git-status.js +36 -0
  541. package/dist/utils/git-status.js.map +1 -0
  542. package/dist/utils/hunk.d.ts +15 -0
  543. package/dist/utils/hunk.d.ts.map +1 -0
  544. package/dist/utils/hunk.js +44 -0
  545. package/dist/utils/hunk.js.map +1 -0
  546. package/dist/utils/input-validation.d.ts +11 -0
  547. package/dist/utils/input-validation.d.ts.map +1 -0
  548. package/dist/utils/input-validation.js +73 -0
  549. package/dist/utils/input-validation.js.map +1 -0
  550. package/dist/utils/install-instructions.d.ts +6 -0
  551. package/dist/utils/install-instructions.d.ts.map +1 -0
  552. package/dist/utils/install-instructions.js +18 -0
  553. package/dist/utils/install-instructions.js.map +1 -0
  554. package/dist/utils/logger.d.ts +13 -0
  555. package/dist/utils/logger.d.ts.map +1 -0
  556. package/dist/utils/logger.js +48 -0
  557. package/dist/utils/logger.js.map +1 -0
  558. package/dist/utils/rate-limit.d.ts +5 -0
  559. package/dist/utils/rate-limit.d.ts.map +1 -0
  560. package/dist/utils/rate-limit.js +56 -0
  561. package/dist/utils/rate-limit.js.map +1 -0
  562. package/dist/utils/recent-activity.d.ts +9 -0
  563. package/dist/utils/recent-activity.d.ts.map +1 -0
  564. package/dist/utils/recent-activity.js +139 -0
  565. package/dist/utils/recent-activity.js.map +1 -0
  566. package/dist/utils/repo-settings-dashboard.d.ts +6 -0
  567. package/dist/utils/repo-settings-dashboard.d.ts.map +1 -0
  568. package/dist/utils/repo-settings-dashboard.js +36 -0
  569. package/dist/utils/repo-settings-dashboard.js.map +1 -0
  570. package/dist/utils/repo-settings-patterns.d.ts +7 -0
  571. package/dist/utils/repo-settings-patterns.d.ts.map +1 -0
  572. package/dist/utils/repo-settings-patterns.js +66 -0
  573. package/dist/utils/repo-settings-patterns.js.map +1 -0
  574. package/dist/utils/repo-settings-schema.d.ts +6 -0
  575. package/dist/utils/repo-settings-schema.d.ts.map +1 -0
  576. package/dist/utils/repo-settings-schema.js +70 -0
  577. package/dist/utils/repo-settings-schema.js.map +1 -0
  578. package/dist/utils/review-output.d.ts +4 -0
  579. package/dist/utils/review-output.d.ts.map +1 -0
  580. package/dist/utils/review-output.js +18 -0
  581. package/dist/utils/review-output.js.map +1 -0
  582. package/dist/utils/skills-sync-manifest.d.ts +5 -0
  583. package/dist/utils/skills-sync-manifest.d.ts.map +1 -0
  584. package/dist/utils/skills-sync-manifest.js +39 -0
  585. package/dist/utils/skills-sync-manifest.js.map +1 -0
  586. package/dist/utils/skills-sync-paths.d.ts +5 -0
  587. package/dist/utils/skills-sync-paths.d.ts.map +1 -0
  588. package/dist/utils/skills-sync-paths.js +60 -0
  589. package/dist/utils/skills-sync-paths.js.map +1 -0
  590. package/dist/utils/skills-sync-targets.d.ts +3 -0
  591. package/dist/utils/skills-sync-targets.d.ts.map +1 -0
  592. package/dist/utils/skills-sync-targets.js +218 -0
  593. package/dist/utils/skills-sync-targets.js.map +1 -0
  594. package/dist/utils/skills-sync.d.ts +39 -0
  595. package/dist/utils/skills-sync.d.ts.map +1 -0
  596. package/dist/utils/skills-sync.js +200 -0
  597. package/dist/utils/skills-sync.js.map +1 -0
  598. package/dist/utils/skills.d.ts +13 -0
  599. package/dist/utils/skills.d.ts.map +1 -0
  600. package/dist/utils/skills.js +117 -0
  601. package/dist/utils/skills.js.map +1 -0
  602. package/dist/utils/stream-input.d.ts +13 -0
  603. package/dist/utils/stream-input.d.ts.map +1 -0
  604. package/dist/utils/stream-input.js +36 -0
  605. package/dist/utils/stream-input.js.map +1 -0
  606. package/dist/utils/team-key-auth.d.ts +5 -0
  607. package/dist/utils/team-key-auth.d.ts.map +1 -0
  608. package/dist/utils/team-key-auth.js +14 -0
  609. package/dist/utils/team-key-auth.js.map +1 -0
  610. package/dist/utils/update-check.d.ts +2 -0
  611. package/dist/utils/update-check.d.ts.map +1 -0
  612. package/dist/utils/update-check.js +30 -0
  613. package/dist/utils/update-check.js.map +1 -0
  614. package/package.json +90 -0
  615. package/skills/README.md +64 -0
  616. package/skills/hunk-review/SKILL.md +154 -0
  617. package/skills/mesrai-business-rules-validation/SKILL.md +65 -0
  618. package/skills/mesrai-centralized-config/SKILL.md +102 -0
  619. package/skills/mesrai-mesrai-rules/SKILL.md +103 -0
  620. package/skills/mesrai-mesrai-rules/instructions/create-mesrai-rule.md +56 -0
  621. package/skills/mesrai-mesrai-rules/instructions/update-mesrai-rule.md +63 -0
  622. package/skills/mesrai-mesrai-rules/instructions/view-mesrai-rules.md +65 -0
  623. package/skills/mesrai-mesrai-rules/rules/create-mesrai-rule.md +48 -0
  624. package/skills/mesrai-mesrai-rules/rules/update-mesrai-rule.md +55 -0
  625. package/skills/mesrai-mesrai-rules/rules/view-mesrai-rules.md +56 -0
  626. package/skills/mesrai-pr-suggestions-resolver/SKILL.md +61 -0
  627. package/skills/mesrai-review/SKILL.md +53 -0
  628. package/skills/mesrai-review-dev/SKILL.md +55 -0
  629. package/skills/mesrai-review-dev/scripts/run-local-cli.sh +49 -0
@@ -0,0 +1,17 @@
1
+ import type { AuthResponse, UserInfo } from '../../types/auth.js';
2
+ import type { IAuthApi } from './api.interface.js';
3
+ type RequestWithRetry = <T>(endpoint: string, options?: RequestInit) => Promise<T>;
4
+ export declare class RealAuthApi implements IAuthApi {
5
+ private readonly requester;
6
+ constructor(requester?: RequestWithRetry);
7
+ login(email: string, password: string): Promise<AuthResponse>;
8
+ refresh(refreshToken: string): Promise<AuthResponse>;
9
+ logout(accessToken: string): Promise<void>;
10
+ generateCIToken(accessToken: string): Promise<string>;
11
+ verify(accessToken: string): Promise<{
12
+ valid: boolean;
13
+ user?: UserInfo;
14
+ }>;
15
+ }
16
+ export {};
17
+ //# sourceMappingURL=auth.api.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"auth.api.d.ts","sourceRoot":"","sources":["../../../src/services/api/auth.api.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,YAAY,EAAE,QAAQ,EAAE,MAAM,qBAAqB,CAAC;AAClE,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,oBAAoB,CAAC;AAGnD,KAAK,gBAAgB,GAAG,CAAC,CAAC,EACtB,QAAQ,EAAE,MAAM,EAChB,OAAO,CAAC,EAAE,WAAW,KACpB,OAAO,CAAC,CAAC,CAAC,CAAC;AAEhB,qBAAa,WAAY,YAAW,QAAQ;IAC5B,OAAO,CAAC,QAAQ,CAAC,SAAS;gBAAT,SAAS,GAAE,gBAAmC;IAErE,KAAK,CAAC,KAAK,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,GAAG,OAAO,CAAC,YAAY,CAAC;IAqB7D,OAAO,CAAC,YAAY,EAAE,MAAM,GAAG,OAAO,CAAC,YAAY,CAAC;IAOpD,MAAM,CAAC,WAAW,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAS1C,eAAe,CAAC,WAAW,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC;IAarD,MAAM,CACR,WAAW,EAAE,MAAM,GACpB,OAAO,CAAC;QAAE,KAAK,EAAE,OAAO,CAAC;QAAC,IAAI,CAAC,EAAE,QAAQ,CAAA;KAAE,CAAC;CA+BlD"}
@@ -0,0 +1,73 @@
1
+ import { requestWithRetry } from './api-core.js';
2
+ export class RealAuthApi {
3
+ requester;
4
+ constructor(requester = requestWithRetry) {
5
+ this.requester = requester;
6
+ }
7
+ async login(email, password) {
8
+ const response = await this.requester('/auth/login', {
9
+ method: 'POST',
10
+ body: JSON.stringify({ email, password }),
11
+ });
12
+ return {
13
+ accessToken: response.accessToken,
14
+ refreshToken: response.refreshToken,
15
+ expiresIn: 3600,
16
+ user: {
17
+ id: 'unknown',
18
+ email,
19
+ orgs: [],
20
+ },
21
+ };
22
+ }
23
+ async refresh(refreshToken) {
24
+ return this.requester('/auth/refresh', {
25
+ method: 'POST',
26
+ body: JSON.stringify({ refreshToken }),
27
+ });
28
+ }
29
+ async logout(accessToken) {
30
+ await this.requester('/auth/logout', {
31
+ method: 'POST',
32
+ headers: {
33
+ Authorization: `Bearer ${accessToken}`,
34
+ },
35
+ });
36
+ }
37
+ async generateCIToken(accessToken) {
38
+ const response = await this.requester('/auth/ci-token', {
39
+ method: 'POST',
40
+ headers: {
41
+ Authorization: `Bearer ${accessToken}`,
42
+ },
43
+ });
44
+ return response.token;
45
+ }
46
+ async verify(accessToken) {
47
+ if (!accessToken || !accessToken.startsWith('eyJ')) {
48
+ return { valid: false };
49
+ }
50
+ try {
51
+ const parts = accessToken.split('.');
52
+ if (parts.length !== 3) {
53
+ return { valid: false };
54
+ }
55
+ const payload = JSON.parse(Buffer.from(parts[1], 'base64').toString());
56
+ if (payload.exp && payload.exp * 1000 < Date.now()) {
57
+ return { valid: false };
58
+ }
59
+ return {
60
+ valid: true,
61
+ user: {
62
+ id: payload.sub || 'unknown',
63
+ email: payload.email || 'unknown',
64
+ orgs: [],
65
+ },
66
+ };
67
+ }
68
+ catch {
69
+ return { valid: false };
70
+ }
71
+ }
72
+ }
73
+ //# sourceMappingURL=auth.api.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"auth.api.js","sourceRoot":"","sources":["../../../src/services/api/auth.api.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,gBAAgB,EAAE,MAAM,eAAe,CAAC;AAOjD,MAAM,OAAO,WAAW;IACS;IAA7B,YAA6B,YAA8B,gBAAgB;QAA9C,cAAS,GAAT,SAAS,CAAqC;IAAG,CAAC;IAE/E,KAAK,CAAC,KAAK,CAAC,KAAa,EAAE,QAAgB;QACvC,MAAM,QAAQ,GAAG,MAAM,IAAI,CAAC,SAAS,CAGlC,aAAa,EAAE;YACd,MAAM,EAAE,MAAM;YACd,IAAI,EAAE,IAAI,CAAC,SAAS,CAAC,EAAE,KAAK,EAAE,QAAQ,EAAE,CAAC;SAC5C,CAAC,CAAC;QAEH,OAAO;YACH,WAAW,EAAE,QAAQ,CAAC,WAAW;YACjC,YAAY,EAAE,QAAQ,CAAC,YAAY;YACnC,SAAS,EAAE,IAAI;YACf,IAAI,EAAE;gBACF,EAAE,EAAE,SAAS;gBACb,KAAK;gBACL,IAAI,EAAE,EAAE;aACX;SACJ,CAAC;IACN,CAAC;IAED,KAAK,CAAC,OAAO,CAAC,YAAoB;QAC9B,OAAO,IAAI,CAAC,SAAS,CAAe,eAAe,EAAE;YACjD,MAAM,EAAE,MAAM;YACd,IAAI,EAAE,IAAI,CAAC,SAAS,CAAC,EAAE,YAAY,EAAE,CAAC;SACzC,CAAC,CAAC;IACP,CAAC;IAED,KAAK,CAAC,MAAM,CAAC,WAAmB;QAC5B,MAAM,IAAI,CAAC,SAAS,CAAO,cAAc,EAAE;YACvC,MAAM,EAAE,MAAM;YACd,OAAO,EAAE;gBACL,aAAa,EAAE,UAAU,WAAW,EAAE;aACzC;SACJ,CAAC,CAAC;IACP,CAAC;IAED,KAAK,CAAC,eAAe,CAAC,WAAmB;QACrC,MAAM,QAAQ,GAAG,MAAM,IAAI,CAAC,SAAS,CACjC,gBAAgB,EAChB;YACI,MAAM,EAAE,MAAM;YACd,OAAO,EAAE;gBACL,aAAa,EAAE,UAAU,WAAW,EAAE;aACzC;SACJ,CACJ,CAAC;QACF,OAAO,QAAQ,CAAC,KAAK,CAAC;IAC1B,CAAC;IAED,KAAK,CAAC,MAAM,CACR,WAAmB;QAEnB,IAAI,CAAC,WAAW,IAAI,CAAC,WAAW,CAAC,UAAU,CAAC,KAAK,CAAC,EAAE,CAAC;YACjD,OAAO,EAAE,KAAK,EAAE,KAAK,EAAE,CAAC;QAC5B,CAAC;QAED,IAAI,CAAC;YACD,MAAM,KAAK,GAAG,WAAW,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;YACrC,IAAI,KAAK,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;gBACrB,OAAO,EAAE,KAAK,EAAE,KAAK,EAAE,CAAC;YAC5B,CAAC;YAED,MAAM,OAAO,GAAG,IAAI,CAAC,KAAK,CACtB,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,QAAQ,CAAC,CAAC,QAAQ,EAAE,CAC7C,CAAC;YAEF,IAAI,OAAO,CAAC,GAAG,IAAI,OAAO,CAAC,GAAG,GAAG,IAAI,GAAG,IAAI,CAAC,GAAG,EAAE,EAAE,CAAC;gBACjD,OAAO,EAAE,KAAK,EAAE,KAAK,EAAE,CAAC;YAC5B,CAAC;YAED,OAAO;gBACH,KAAK,EAAE,IAAI;gBACX,IAAI,EAAE;oBACF,EAAE,EAAE,OAAO,CAAC,GAAG,IAAI,SAAS;oBAC5B,KAAK,EAAE,OAAO,CAAC,KAAK,IAAI,SAAS;oBACjC,IAAI,EAAE,EAAE;iBACX;aACJ,CAAC;QACN,CAAC;QAAC,MAAM,CAAC;YACL,OAAO,EAAE,KAAK,EAAE,KAAK,EAAE,CAAC;QAC5B,CAAC;IACL,CAAC;CACJ"}
@@ -0,0 +1,29 @@
1
+ export interface CliLoginInitResponse {
2
+ verificationUri: string;
3
+ state: string;
4
+ expiresIn: number;
5
+ }
6
+ export interface CliDeviceInitResponse {
7
+ deviceCode: string;
8
+ userCode: string;
9
+ verificationUri: string;
10
+ verificationUriComplete: string;
11
+ expiresIn: number;
12
+ interval: number;
13
+ }
14
+ export type CliLoginPollStatus = 'pending' | 'completed' | 'consumed' | 'denied' | 'expired' | 'not_found';
15
+ export interface CliLoginPollResponse {
16
+ status: CliLoginPollStatus;
17
+ accessToken?: string;
18
+ refreshToken?: string;
19
+ userEmail?: string;
20
+ }
21
+ export declare const cliAuthApi: {
22
+ initLoopback(port: number): Promise<CliLoginInitResponse>;
23
+ initDevice(): Promise<CliDeviceInitResponse>;
24
+ poll(params: {
25
+ state?: string;
26
+ deviceCode?: string;
27
+ }): Promise<CliLoginPollResponse>;
28
+ };
29
+ //# sourceMappingURL=cli-auth.api.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"cli-auth.api.d.ts","sourceRoot":"","sources":["../../../src/services/api/cli-auth.api.ts"],"names":[],"mappings":"AAEA,MAAM,WAAW,oBAAoB;IACjC,eAAe,EAAE,MAAM,CAAC;IACxB,KAAK,EAAE,MAAM,CAAC;IACd,SAAS,EAAE,MAAM,CAAC;CACrB;AAED,MAAM,WAAW,qBAAqB;IAClC,UAAU,EAAE,MAAM,CAAC;IACnB,QAAQ,EAAE,MAAM,CAAC;IACjB,eAAe,EAAE,MAAM,CAAC;IACxB,uBAAuB,EAAE,MAAM,CAAC;IAChC,SAAS,EAAE,MAAM,CAAC;IAClB,QAAQ,EAAE,MAAM,CAAC;CACpB;AAED,MAAM,MAAM,kBAAkB,GACxB,SAAS,GACT,WAAW,GACX,UAAU,GACV,QAAQ,GACR,SAAS,GACT,WAAW,CAAC;AAElB,MAAM,WAAW,oBAAoB;IACjC,MAAM,EAAE,kBAAkB,CAAC;IAC3B,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,SAAS,CAAC,EAAE,MAAM,CAAC;CACtB;AAED,eAAO,MAAM,UAAU;uBACA,MAAM,GAAG,OAAO,CAAC,oBAAoB,CAAC;kBAM3C,OAAO,CAAC,qBAAqB,CAAC;iBAK/B;QACT,KAAK,CAAC,EAAE,MAAM,CAAC;QACf,UAAU,CAAC,EAAE,MAAM,CAAC;KACvB,GAAG,OAAO,CAAC,oBAAoB,CAAC;CASpC,CAAC"}
@@ -0,0 +1,23 @@
1
+ import { request } from './api-core.js';
2
+ export const cliAuthApi = {
3
+ initLoopback(port) {
4
+ return request('/cli/auth/login-init', {
5
+ method: 'POST',
6
+ body: JSON.stringify({ port }),
7
+ });
8
+ },
9
+ initDevice() {
10
+ return request('/cli/auth/device-init', {
11
+ method: 'POST',
12
+ });
13
+ },
14
+ poll(params) {
15
+ const search = new URLSearchParams();
16
+ if (params.state)
17
+ search.append('state', params.state);
18
+ if (params.deviceCode)
19
+ search.append('device_code', params.deviceCode);
20
+ return request(`/cli/auth/login-poll?${search.toString()}`, { method: 'GET' });
21
+ },
22
+ };
23
+ //# sourceMappingURL=cli-auth.api.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"cli-auth.api.js","sourceRoot":"","sources":["../../../src/services/api/cli-auth.api.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,eAAe,CAAC;AAgCxC,MAAM,CAAC,MAAM,UAAU,GAAG;IACtB,YAAY,CAAC,IAAY;QACrB,OAAO,OAAO,CAAuB,sBAAsB,EAAE;YACzD,MAAM,EAAE,MAAM;YACd,IAAI,EAAE,IAAI,CAAC,SAAS,CAAC,EAAE,IAAI,EAAE,CAAC;SACjC,CAAC,CAAC;IACP,CAAC;IACD,UAAU;QACN,OAAO,OAAO,CAAwB,uBAAuB,EAAE;YAC3D,MAAM,EAAE,MAAM;SACjB,CAAC,CAAC;IACP,CAAC;IACD,IAAI,CAAC,MAGJ;QACG,MAAM,MAAM,GAAG,IAAI,eAAe,EAAE,CAAC;QACrC,IAAI,MAAM,CAAC,KAAK;YAAE,MAAM,CAAC,MAAM,CAAC,OAAO,EAAE,MAAM,CAAC,KAAK,CAAC,CAAC;QACvD,IAAI,MAAM,CAAC,UAAU;YAAE,MAAM,CAAC,MAAM,CAAC,aAAa,EAAE,MAAM,CAAC,UAAU,CAAC,CAAC;QACvE,OAAO,OAAO,CACV,wBAAwB,MAAM,CAAC,QAAQ,EAAE,EAAE,EAC3C,EAAE,MAAM,EAAE,KAAK,EAAE,CACpB,CAAC;IACN,CAAC;CACJ,CAAC"}
@@ -0,0 +1,34 @@
1
+ import type { CentralizedConfigActionResponse, CentralizedPrMetadata, CentralizedConfigStatus, CodeReviewParameter, ConfigAddRepositoriesResponse, ConfigRepository, ConfigTeam } from '../../types/config.js';
2
+ import type { RepositorySettings } from '../../types/repo-config.js';
3
+ import type { IConfigApi } from './api.interface.js';
4
+ type RequestWithRetry = <T>(endpoint: string, options?: RequestInit) => Promise<T>;
5
+ export declare class RealConfigApi implements IConfigApi {
6
+ private readonly requester;
7
+ constructor(requester?: RequestWithRetry);
8
+ private buildAuthHeaders;
9
+ getAvailableRepositories(accessToken: string): Promise<ConfigRepository[]>;
10
+ getSelectedRepositories(accessToken: string): Promise<ConfigRepository[]>;
11
+ getTeams(accessToken: string): Promise<ConfigTeam[]>;
12
+ addRepositories(accessToken: string, repositoryIds: string[]): Promise<ConfigAddRepositoriesResponse>;
13
+ getCodeReviewParameter(accessToken: string, teamId: string): Promise<CodeReviewParameter>;
14
+ createOrUpdateCodeReviewParameter(accessToken: string, params: {
15
+ teamId: string;
16
+ repositoryId?: string;
17
+ configValue: Record<string, unknown>;
18
+ }): Promise<CodeReviewParameter>;
19
+ updateCodeReviewParameterRepositories(accessToken: string, teamId: string): Promise<unknown>;
20
+ getRepositorySettings(accessToken: string, repositoryId: string): Promise<RepositorySettings>;
21
+ updateRepositorySettings(accessToken: string, repositoryId: string, settings: RepositorySettings): Promise<RepositorySettings | (CentralizedPrMetadata & {
22
+ mode: 'centralized-pr';
23
+ })>;
24
+ getCentralizedConfigStatus(accessToken: string): Promise<CentralizedConfigStatus>;
25
+ initCentralizedConfig(accessToken: string, params: {
26
+ repositoryId: string;
27
+ syncOption: 'pr' | 'manual';
28
+ }): Promise<CentralizedConfigActionResponse>;
29
+ syncCentralizedConfig(accessToken: string): Promise<CentralizedConfigActionResponse>;
30
+ disableCentralizedConfig(accessToken: string): Promise<CentralizedConfigActionResponse>;
31
+ downloadCentralizedConfig(accessToken: string): Promise<Uint8Array>;
32
+ }
33
+ export {};
34
+ //# sourceMappingURL=config.api.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"config.api.d.ts","sourceRoot":"","sources":["../../../src/services/api/config.api.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EACR,+BAA+B,EAC/B,qBAAqB,EACrB,uBAAuB,EACvB,mBAAmB,EACnB,6BAA6B,EAC7B,gBAAgB,EAChB,UAAU,EACb,MAAM,uBAAuB,CAAC;AAC/B,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,4BAA4B,CAAC;AACrE,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,oBAAoB,CAAC;AAGrD,KAAK,gBAAgB,GAAG,CAAC,CAAC,EACtB,QAAQ,EAAE,MAAM,EAChB,OAAO,CAAC,EAAE,WAAW,KACpB,OAAO,CAAC,CAAC,CAAC,CAAC;AAEhB,qBAAa,aAAc,YAAW,UAAU;IAExC,OAAO,CAAC,QAAQ,CAAC,SAAS;gBAAT,SAAS,GAAE,gBAAmC;IAGnE,OAAO,CAAC,gBAAgB;IAMlB,wBAAwB,CAC1B,WAAW,EAAE,MAAM,GACpB,OAAO,CAAC,gBAAgB,EAAE,CAAC;IASxB,uBAAuB,CACzB,WAAW,EAAE,MAAM,GACpB,OAAO,CAAC,gBAAgB,EAAE,CAAC;IASxB,QAAQ,CAAC,WAAW,EAAE,MAAM,GAAG,OAAO,CAAC,UAAU,EAAE,CAAC;IAMpD,eAAe,CACjB,WAAW,EAAE,MAAM,EACnB,aAAa,EAAE,MAAM,EAAE,GACxB,OAAO,CAAC,6BAA6B,CAAC;IAanC,sBAAsB,CACxB,WAAW,EAAE,MAAM,EACnB,MAAM,EAAE,MAAM,GACf,OAAO,CAAC,mBAAmB,CAAC;IASzB,iCAAiC,CACnC,WAAW,EAAE,MAAM,EACnB,MAAM,EAAE;QACJ,MAAM,EAAE,MAAM,CAAC;QACf,YAAY,CAAC,EAAE,MAAM,CAAC;QACtB,WAAW,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;KACxC,GACF,OAAO,CAAC,mBAAmB,CAAC;IAiBzB,qCAAqC,CACvC,WAAW,EAAE,MAAM,EACnB,MAAM,EAAE,MAAM,GACf,OAAO,CAAC,OAAO,CAAC;IAeb,qBAAqB,CACvB,WAAW,EAAE,MAAM,EACnB,YAAY,EAAE,MAAM,GACrB,OAAO,CAAC,kBAAkB,CAAC;IASxB,wBAAwB,CAC1B,WAAW,EAAE,MAAM,EACnB,YAAY,EAAE,MAAM,EACpB,QAAQ,EAAE,kBAAkB,GAC7B,OAAO,CACN,kBAAkB,GAAG,CAAC,qBAAqB,GAAG;QAAE,IAAI,EAAE,gBAAgB,CAAA;KAAE,CAAC,CAC5E;IAaK,0BAA0B,CAC5B,WAAW,EAAE,MAAM,GACpB,OAAO,CAAC,uBAAuB,CAAC;IAS7B,qBAAqB,CACvB,WAAW,EAAE,MAAM,EACnB,MAAM,EAAE;QACJ,YAAY,EAAE,MAAM,CAAC;QACrB,UAAU,EAAE,IAAI,GAAG,QAAQ,CAAC;KAC/B,GACF,OAAO,CAAC,+BAA+B,CAAC;IAWrC,qBAAqB,CACvB,WAAW,EAAE,MAAM,GACpB,OAAO,CAAC,+BAA+B,CAAC;IAUrC,wBAAwB,CAC1B,WAAW,EAAE,MAAM,GACpB,OAAO,CAAC,+BAA+B,CAAC;IAUrC,yBAAyB,CAAC,WAAW,EAAE,MAAM,GAAG,OAAO,CAAC,UAAU,CAAC;CAM5E"}
@@ -0,0 +1,108 @@
1
+ import { requestBinaryWithRetry, requestWithRetry } from './api-core.js';
2
+ export class RealConfigApi {
3
+ requester;
4
+ constructor(requester = requestWithRetry) {
5
+ this.requester = requester;
6
+ }
7
+ buildAuthHeaders(accessToken) {
8
+ return accessToken.startsWith('mesrai_')
9
+ ? { 'X-Team-Key': accessToken }
10
+ : { Authorization: `Bearer ${accessToken}` };
11
+ }
12
+ async getAvailableRepositories(accessToken) {
13
+ return this.requester('/cli/config/repositories/available', {
14
+ headers: this.buildAuthHeaders(accessToken),
15
+ });
16
+ }
17
+ async getSelectedRepositories(accessToken) {
18
+ return this.requester('/cli/config/repositories/selected', {
19
+ headers: this.buildAuthHeaders(accessToken),
20
+ });
21
+ }
22
+ async getTeams(accessToken) {
23
+ return this.requester('/team/', {
24
+ headers: this.buildAuthHeaders(accessToken),
25
+ });
26
+ }
27
+ async addRepositories(accessToken, repositoryIds) {
28
+ return this.requester('/cli/config/repositories', {
29
+ method: 'POST',
30
+ headers: this.buildAuthHeaders(accessToken),
31
+ body: JSON.stringify({
32
+ repositoryIds,
33
+ }),
34
+ });
35
+ }
36
+ async getCodeReviewParameter(accessToken, teamId) {
37
+ return this.requester(`/parameters/find-by-key?key=CODE_REVIEW_CONFIG&teamId=${encodeURIComponent(teamId)}`, {
38
+ headers: this.buildAuthHeaders(accessToken),
39
+ });
40
+ }
41
+ async createOrUpdateCodeReviewParameter(accessToken, params) {
42
+ return this.requester('/parameters/create-or-update-code-review', {
43
+ method: 'POST',
44
+ headers: this.buildAuthHeaders(accessToken),
45
+ body: JSON.stringify({
46
+ configValue: params.configValue,
47
+ organizationAndTeamData: {
48
+ teamId: params.teamId,
49
+ },
50
+ repositoryId: params.repositoryId,
51
+ }),
52
+ });
53
+ }
54
+ async updateCodeReviewParameterRepositories(accessToken, teamId) {
55
+ return this.requester('/parameters/update-code-review-parameter-repositories', {
56
+ method: 'POST',
57
+ headers: this.buildAuthHeaders(accessToken),
58
+ body: JSON.stringify({
59
+ organizationAndTeamData: {
60
+ teamId,
61
+ },
62
+ }),
63
+ });
64
+ }
65
+ async getRepositorySettings(accessToken, repositoryId) {
66
+ return this.requester(`/cli/config/repositories/${encodeURIComponent(repositoryId)}/settings`, {
67
+ headers: this.buildAuthHeaders(accessToken),
68
+ });
69
+ }
70
+ async updateRepositorySettings(accessToken, repositoryId, settings) {
71
+ return this.requester(`/cli/config/repositories/${encodeURIComponent(repositoryId)}/settings`, {
72
+ method: 'PATCH',
73
+ headers: this.buildAuthHeaders(accessToken),
74
+ body: JSON.stringify(settings),
75
+ });
76
+ }
77
+ async getCentralizedConfigStatus(accessToken) {
78
+ return this.requester('/cli/config/centralized/status', {
79
+ headers: this.buildAuthHeaders(accessToken),
80
+ });
81
+ }
82
+ async initCentralizedConfig(accessToken, params) {
83
+ return this.requester('/cli/config/centralized/init', {
84
+ method: 'POST',
85
+ headers: this.buildAuthHeaders(accessToken),
86
+ body: JSON.stringify(params),
87
+ });
88
+ }
89
+ async syncCentralizedConfig(accessToken) {
90
+ return this.requester('/cli/config/centralized/sync', {
91
+ method: 'POST',
92
+ headers: this.buildAuthHeaders(accessToken),
93
+ });
94
+ }
95
+ async disableCentralizedConfig(accessToken) {
96
+ return this.requester('/cli/config/centralized/disable', {
97
+ method: 'POST',
98
+ headers: this.buildAuthHeaders(accessToken),
99
+ });
100
+ }
101
+ async downloadCentralizedConfig(accessToken) {
102
+ return requestBinaryWithRetry('/cli/config/centralized/download', {
103
+ method: 'GET',
104
+ headers: this.buildAuthHeaders(accessToken),
105
+ });
106
+ }
107
+ }
108
+ //# sourceMappingURL=config.api.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"config.api.js","sourceRoot":"","sources":["../../../src/services/api/config.api.ts"],"names":[],"mappings":"AAWA,OAAO,EAAE,sBAAsB,EAAE,gBAAgB,EAAE,MAAM,eAAe,CAAC;AAOzE,MAAM,OAAO,aAAa;IAED;IADrB,YACqB,YAA8B,gBAAgB;QAA9C,cAAS,GAAT,SAAS,CAAqC;IAChE,CAAC;IAEI,gBAAgB,CAAC,WAAmB;QACxC,OAAO,WAAW,CAAC,UAAU,CAAC,SAAS,CAAC;YACpC,CAAC,CAAC,EAAE,YAAY,EAAE,WAAW,EAAE;YAC/B,CAAC,CAAC,EAAE,aAAa,EAAE,UAAU,WAAW,EAAE,EAAE,CAAC;IACrD,CAAC;IAED,KAAK,CAAC,wBAAwB,CAC1B,WAAmB;QAEnB,OAAO,IAAI,CAAC,SAAS,CACjB,oCAAoC,EACpC;YACI,OAAO,EAAE,IAAI,CAAC,gBAAgB,CAAC,WAAW,CAAC;SAC9C,CACJ,CAAC;IACN,CAAC;IAED,KAAK,CAAC,uBAAuB,CACzB,WAAmB;QAEnB,OAAO,IAAI,CAAC,SAAS,CACjB,mCAAmC,EACnC;YACI,OAAO,EAAE,IAAI,CAAC,gBAAgB,CAAC,WAAW,CAAC;SAC9C,CACJ,CAAC;IACN,CAAC;IAED,KAAK,CAAC,QAAQ,CAAC,WAAmB;QAC9B,OAAO,IAAI,CAAC,SAAS,CAAe,QAAQ,EAAE;YAC1C,OAAO,EAAE,IAAI,CAAC,gBAAgB,CAAC,WAAW,CAAC;SAC9C,CAAC,CAAC;IACP,CAAC;IAED,KAAK,CAAC,eAAe,CACjB,WAAmB,EACnB,aAAuB;QAEvB,OAAO,IAAI,CAAC,SAAS,CACjB,0BAA0B,EAC1B;YACI,MAAM,EAAE,MAAM;YACd,OAAO,EAAE,IAAI,CAAC,gBAAgB,CAAC,WAAW,CAAC;YAC3C,IAAI,EAAE,IAAI,CAAC,SAAS,CAAC;gBACjB,aAAa;aAChB,CAAC;SACL,CACJ,CAAC;IACN,CAAC;IAED,KAAK,CAAC,sBAAsB,CACxB,WAAmB,EACnB,MAAc;QAEd,OAAO,IAAI,CAAC,SAAS,CACjB,yDAAyD,kBAAkB,CAAC,MAAM,CAAC,EAAE,EACrF;YACI,OAAO,EAAE,IAAI,CAAC,gBAAgB,CAAC,WAAW,CAAC;SAC9C,CACJ,CAAC;IACN,CAAC;IAED,KAAK,CAAC,iCAAiC,CACnC,WAAmB,EACnB,MAIC;QAED,OAAO,IAAI,CAAC,SAAS,CACjB,0CAA0C,EAC1C;YACI,MAAM,EAAE,MAAM;YACd,OAAO,EAAE,IAAI,CAAC,gBAAgB,CAAC,WAAW,CAAC;YAC3C,IAAI,EAAE,IAAI,CAAC,SAAS,CAAC;gBACjB,WAAW,EAAE,MAAM,CAAC,WAAW;gBAC/B,uBAAuB,EAAE;oBACrB,MAAM,EAAE,MAAM,CAAC,MAAM;iBACxB;gBACD,YAAY,EAAE,MAAM,CAAC,YAAY;aACpC,CAAC;SACL,CACJ,CAAC;IACN,CAAC;IAED,KAAK,CAAC,qCAAqC,CACvC,WAAmB,EACnB,MAAc;QAEd,OAAO,IAAI,CAAC,SAAS,CACjB,uDAAuD,EACvD;YACI,MAAM,EAAE,MAAM;YACd,OAAO,EAAE,IAAI,CAAC,gBAAgB,CAAC,WAAW,CAAC;YAC3C,IAAI,EAAE,IAAI,CAAC,SAAS,CAAC;gBACjB,uBAAuB,EAAE;oBACrB,MAAM;iBACT;aACJ,CAAC;SACL,CACJ,CAAC;IACN,CAAC;IAED,KAAK,CAAC,qBAAqB,CACvB,WAAmB,EACnB,YAAoB;QAEpB,OAAO,IAAI,CAAC,SAAS,CACjB,4BAA4B,kBAAkB,CAAC,YAAY,CAAC,WAAW,EACvE;YACI,OAAO,EAAE,IAAI,CAAC,gBAAgB,CAAC,WAAW,CAAC;SAC9C,CACJ,CAAC;IACN,CAAC;IAED,KAAK,CAAC,wBAAwB,CAC1B,WAAmB,EACnB,YAAoB,EACpB,QAA4B;QAI5B,OAAO,IAAI,CAAC,SAAS,CAGjB,4BAA4B,kBAAkB,CAAC,YAAY,CAAC,WAAW,EACvE;YACI,MAAM,EAAE,OAAO;YACf,OAAO,EAAE,IAAI,CAAC,gBAAgB,CAAC,WAAW,CAAC;YAC3C,IAAI,EAAE,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC;SACjC,CACJ,CAAC;IACN,CAAC;IAED,KAAK,CAAC,0BAA0B,CAC5B,WAAmB;QAEnB,OAAO,IAAI,CAAC,SAAS,CACjB,gCAAgC,EAChC;YACI,OAAO,EAAE,IAAI,CAAC,gBAAgB,CAAC,WAAW,CAAC;SAC9C,CACJ,CAAC;IACN,CAAC;IAED,KAAK,CAAC,qBAAqB,CACvB,WAAmB,EACnB,MAGC;QAED,OAAO,IAAI,CAAC,SAAS,CACjB,8BAA8B,EAC9B;YACI,MAAM,EAAE,MAAM;YACd,OAAO,EAAE,IAAI,CAAC,gBAAgB,CAAC,WAAW,CAAC;YAC3C,IAAI,EAAE,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC;SAC/B,CACJ,CAAC;IACN,CAAC;IAED,KAAK,CAAC,qBAAqB,CACvB,WAAmB;QAEnB,OAAO,IAAI,CAAC,SAAS,CACjB,8BAA8B,EAC9B;YACI,MAAM,EAAE,MAAM;YACd,OAAO,EAAE,IAAI,CAAC,gBAAgB,CAAC,WAAW,CAAC;SAC9C,CACJ,CAAC;IACN,CAAC;IAED,KAAK,CAAC,wBAAwB,CAC1B,WAAmB;QAEnB,OAAO,IAAI,CAAC,SAAS,CACjB,iCAAiC,EACjC;YACI,MAAM,EAAE,MAAM;YACd,OAAO,EAAE,IAAI,CAAC,gBAAgB,CAAC,WAAW,CAAC;SAC9C,CACJ,CAAC;IACN,CAAC;IAED,KAAK,CAAC,yBAAyB,CAAC,WAAmB;QAC/C,OAAO,sBAAsB,CAAC,kCAAkC,EAAE;YAC9D,MAAM,EAAE,KAAK;YACb,OAAO,EAAE,IAAI,CAAC,gBAAgB,CAAC,WAAW,CAAC;SAC9C,CAAC,CAAC;IACP,CAAC;CACJ"}
@@ -0,0 +1,4 @@
1
+ import { RealApi } from './api.real.js';
2
+ export type { IMesraiApi, IMemoryApi, IRulesApi, ISessionsApi, } from './api.interface.js';
3
+ export declare const api: RealApi;
4
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/services/api/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,eAAe,CAAC;AAExC,YAAY,EACR,UAAU,EACV,UAAU,EACV,SAAS,EACT,YAAY,GACf,MAAM,oBAAoB,CAAC;AAE5B,eAAO,MAAM,GAAG,SAAgB,CAAC"}
@@ -0,0 +1,3 @@
1
+ import { RealApi } from './api.real.js';
2
+ export const api = new RealApi();
3
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/services/api/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,eAAe,CAAC;AASxC,MAAM,CAAC,MAAM,GAAG,GAAG,IAAI,OAAO,EAAE,CAAC"}
@@ -0,0 +1,10 @@
1
+ import type { MemoryCaptureApiRequest, MemoryCaptureApiResponse } from '../../types/memory.js';
2
+ import type { IMemoryApi } from './api.interface.js';
3
+ type RequestFn = <T>(endpoint: string, options?: RequestInit) => Promise<T>;
4
+ export declare class RealMemoryApi implements IMemoryApi {
5
+ private readonly requester;
6
+ constructor(requester?: RequestFn);
7
+ submitCapture(payload: MemoryCaptureApiRequest, accessToken: string): Promise<MemoryCaptureApiResponse>;
8
+ }
9
+ export {};
10
+ //# sourceMappingURL=memory.api.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"memory.api.d.ts","sourceRoot":"","sources":["../../../src/services/api/memory.api.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EACR,uBAAuB,EACvB,wBAAwB,EAC3B,MAAM,uBAAuB,CAAC;AAC/B,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,oBAAoB,CAAC;AAGrD,KAAK,SAAS,GAAG,CAAC,CAAC,EAAE,QAAQ,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,WAAW,KAAK,OAAO,CAAC,CAAC,CAAC,CAAC;AAE5E,qBAAa,aAAc,YAAW,UAAU;IAChC,OAAO,CAAC,QAAQ,CAAC,SAAS;gBAAT,SAAS,GAAE,SAAmB;IAErD,aAAa,CACf,OAAO,EAAE,uBAAuB,EAChC,WAAW,EAAE,MAAM,GACpB,OAAO,CAAC,wBAAwB,CAAC;CAYvC"}
@@ -0,0 +1,19 @@
1
+ import { request } from './api-core.js';
2
+ export class RealMemoryApi {
3
+ requester;
4
+ constructor(requester = request) {
5
+ this.requester = requester;
6
+ }
7
+ async submitCapture(payload, accessToken) {
8
+ const isTeamKey = accessToken.startsWith('mesrai_');
9
+ const headers = isTeamKey
10
+ ? { 'X-Team-Key': accessToken }
11
+ : { Authorization: `Bearer ${accessToken}` };
12
+ return this.requester('/cli/memory/captures', {
13
+ method: 'POST',
14
+ headers,
15
+ body: JSON.stringify(payload),
16
+ });
17
+ }
18
+ }
19
+ //# sourceMappingURL=memory.api.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"memory.api.js","sourceRoot":"","sources":["../../../src/services/api/memory.api.ts"],"names":[],"mappings":"AAKA,OAAO,EAAE,OAAO,EAAE,MAAM,eAAe,CAAC;AAIxC,MAAM,OAAO,aAAa;IACO;IAA7B,YAA6B,YAAuB,OAAO;QAA9B,cAAS,GAAT,SAAS,CAAqB;IAAG,CAAC;IAE/D,KAAK,CAAC,aAAa,CACf,OAAgC,EAChC,WAAmB;QAEnB,MAAM,SAAS,GAAG,WAAW,CAAC,UAAU,CAAC,SAAS,CAAC,CAAC;QACpD,MAAM,OAAO,GAA2B,SAAS;YAC7C,CAAC,CAAC,EAAE,YAAY,EAAE,WAAW,EAAE;YAC/B,CAAC,CAAC,EAAE,aAAa,EAAE,UAAU,WAAW,EAAE,EAAE,CAAC;QAEjD,OAAO,IAAI,CAAC,SAAS,CAA2B,sBAAsB,EAAE;YACpE,MAAM,EAAE,MAAM;YACd,OAAO;YACP,IAAI,EAAE,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC;SAChC,CAAC,CAAC;IACP,CAAC;CACJ"}
@@ -0,0 +1,27 @@
1
+ import type { BusinessValidationResponse, PullRequestSuggestionsResponse, ReviewConfig, ReviewResult, TrialReviewResult } from '../../types/review.js';
2
+ import type { GitMetrics, IReviewApi } from './api.interface.js';
3
+ type RequestWithRetry = <T>(endpoint: string, options?: RequestInit) => Promise<T>;
4
+ export declare class RealReviewApi implements IReviewApi {
5
+ private readonly requester;
6
+ constructor(requester?: RequestWithRetry);
7
+ analyze(diff: string, accessToken: string, config?: ReviewConfig): Promise<ReviewResult>;
8
+ analyzeWithMetrics(diff: string, accessToken: string, config?: ReviewConfig, metrics?: GitMetrics, onProgress?: (status: string) => void): Promise<ReviewResult>;
9
+ private pollReviewJob;
10
+ getPullRequestSuggestions(accessToken: string, params: {
11
+ prUrl?: string;
12
+ prNumber?: number;
13
+ repositoryId?: string;
14
+ format?: 'markdown';
15
+ severity?: string;
16
+ category?: string;
17
+ }): Promise<PullRequestSuggestionsResponse>;
18
+ triggerBusinessValidation(accessToken: string, params: {
19
+ repository?: string;
20
+ taskUrl?: string;
21
+ taskId?: string;
22
+ diff?: string;
23
+ }): Promise<BusinessValidationResponse>;
24
+ trialAnalyze(diff: string, fingerprint: string, metrics?: GitMetrics, githubPat?: string): Promise<TrialReviewResult>;
25
+ }
26
+ export {};
27
+ //# sourceMappingURL=review.api.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"review.api.d.ts","sourceRoot":"","sources":["../../../src/services/api/review.api.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EACR,0BAA0B,EAC1B,8BAA8B,EAC9B,YAAY,EACZ,YAAY,EACZ,iBAAiB,EACpB,MAAM,uBAAuB,CAAC;AAC/B,OAAO,KAAK,EAAE,UAAU,EAAE,UAAU,EAAE,MAAM,oBAAoB,CAAC;AAGjE,KAAK,gBAAgB,GAAG,CAAC,CAAC,EACtB,QAAQ,EAAE,MAAM,EAChB,OAAO,CAAC,EAAE,WAAW,KACpB,OAAO,CAAC,CAAC,CAAC,CAAC;AA2BhB,qBAAa,aAAc,YAAW,UAAU;IAChC,OAAO,CAAC,QAAQ,CAAC,SAAS;gBAAT,SAAS,GAAE,gBAAmC;IAErE,OAAO,CACT,IAAI,EAAE,MAAM,EACZ,WAAW,EAAE,MAAM,EACnB,MAAM,CAAC,EAAE,YAAY,GACtB,OAAO,CAAC,YAAY,CAAC;IAIlB,kBAAkB,CACpB,IAAI,EAAE,MAAM,EACZ,WAAW,EAAE,MAAM,EACnB,MAAM,CAAC,EAAE,YAAY,EACrB,OAAO,CAAC,EAAE,UAAU,EACpB,UAAU,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,KAAK,IAAI,GACtC,OAAO,CAAC,YAAY,CAAC;YA+CV,aAAa;IA8CrB,yBAAyB,CAC3B,WAAW,EAAE,MAAM,EACnB,MAAM,EAAE;QACJ,KAAK,CAAC,EAAE,MAAM,CAAC;QACf,QAAQ,CAAC,EAAE,MAAM,CAAC;QAClB,YAAY,CAAC,EAAE,MAAM,CAAC;QACtB,MAAM,CAAC,EAAE,UAAU,CAAC;QACpB,QAAQ,CAAC,EAAE,MAAM,CAAC;QAClB,QAAQ,CAAC,EAAE,MAAM,CAAC;KACrB,GACF,OAAO,CAAC,8BAA8B,CAAC;IAwCpC,yBAAyB,CAC3B,WAAW,EAAE,MAAM,EACnB,MAAM,EAAE;QACJ,UAAU,CAAC,EAAE,MAAM,CAAC;QACpB,OAAO,CAAC,EAAE,MAAM,CAAC;QACjB,MAAM,CAAC,EAAE,MAAM,CAAC;QAChB,IAAI,CAAC,EAAE,MAAM,CAAC;KACjB,GACF,OAAO,CAAC,0BAA0B,CAAC;IA+BhC,YAAY,CACd,IAAI,EAAE,MAAM,EACZ,WAAW,EAAE,MAAM,EACnB,OAAO,CAAC,EAAE,UAAU,EACpB,SAAS,CAAC,EAAE,MAAM,GACnB,OAAO,CAAC,iBAAiB,CAAC;CAWhC"}
@@ -0,0 +1,140 @@
1
+ import { requestWithRetry } from './api-core.js';
2
+ const POLL_MIN_DELAY_MS = 1_000;
3
+ const POLL_MAX_DELAY_MS = 5_000;
4
+ const POLL_MAX_WAIT_MS = 30 * 60 * 1000;
5
+ export class RealReviewApi {
6
+ requester;
7
+ constructor(requester = requestWithRetry) {
8
+ this.requester = requester;
9
+ }
10
+ async analyze(diff, accessToken, config) {
11
+ return this.analyzeWithMetrics(diff, accessToken, config);
12
+ }
13
+ async analyzeWithMetrics(diff, accessToken, config, metrics, onProgress) {
14
+ const isTeamKey = accessToken.startsWith('mesrai_');
15
+ const authHeaders = isTeamKey
16
+ ? { 'X-Team-Key': accessToken }
17
+ : { Authorization: `Bearer ${accessToken}` };
18
+ // Personal tokens: do NOT pass `teamId` here. Earlier we forwarded
19
+ // the JWT's organizationId in this query param, which the backend's
20
+ // `resolveOrgAndTeamForReview` would feed to `teamService.findById`
21
+ // — that lookup obviously fails (org id is not a team id) and
22
+ // succeeded today only because of a downstream fallback to
23
+ // `findFirstCreatedTeam(orgId)`. Letting the backend take that
24
+ // fallback directly keeps the flow correct without lying about
25
+ // the parameter's meaning.
26
+ const endpoint = '/cli/review';
27
+ // Enqueue: server returns 202 + jobId. We then poll for completion.
28
+ const enqueueResponse = await this.requester(endpoint, {
29
+ method: 'POST',
30
+ headers: {
31
+ ...authHeaders,
32
+ 'X-Mesrai-Async': '1',
33
+ },
34
+ body: JSON.stringify({
35
+ diff,
36
+ config,
37
+ ...metrics,
38
+ }),
39
+ });
40
+ if (!enqueueResponse?.jobId) {
41
+ // Server didn't honor async (older deployment). It must have
42
+ // returned the legacy synchronous body, so just hand it back.
43
+ return enqueueResponse;
44
+ }
45
+ return this.pollReviewJob(enqueueResponse.jobId, authHeaders, onProgress);
46
+ }
47
+ async pollReviewJob(jobId, authHeaders, onProgress) {
48
+ const startedAt = Date.now();
49
+ let delayMs = POLL_MIN_DELAY_MS;
50
+ let lastStatus;
51
+ while (Date.now() - startedAt < POLL_MAX_WAIT_MS) {
52
+ await new Promise((resolve) => setTimeout(resolve, delayMs));
53
+ delayMs = Math.min(delayMs * 2, POLL_MAX_DELAY_MS);
54
+ const statusResponse = await this.requester(`/cli/review/jobs/${encodeURIComponent(jobId)}`, { method: 'GET', headers: { ...authHeaders } });
55
+ if (statusResponse.status !== lastStatus) {
56
+ lastStatus = statusResponse.status;
57
+ onProgress?.(statusResponse.status);
58
+ }
59
+ if (statusResponse.status === 'COMPLETED') {
60
+ if (!statusResponse.result) {
61
+ throw new Error(`CLI review job ${jobId} completed but no result was returned`);
62
+ }
63
+ return statusResponse.result;
64
+ }
65
+ if (statusResponse.status === 'FAILED') {
66
+ throw new Error(statusResponse.error ||
67
+ `CLI review job ${jobId} failed without an error message`);
68
+ }
69
+ }
70
+ throw new Error(`CLI review job ${jobId} did not finish within ${POLL_MAX_WAIT_MS}ms`);
71
+ }
72
+ async getPullRequestSuggestions(accessToken, params) {
73
+ const query = new URLSearchParams();
74
+ if (params.prUrl) {
75
+ query.set('prUrl', params.prUrl);
76
+ }
77
+ if (params.prNumber !== undefined) {
78
+ query.set('prNumber', params.prNumber.toString());
79
+ }
80
+ if (params.repositoryId) {
81
+ query.set('repositoryId', params.repositoryId);
82
+ }
83
+ if (params.format) {
84
+ query.set('format', params.format);
85
+ }
86
+ if (params.severity) {
87
+ query.set('severity', params.severity);
88
+ }
89
+ if (params.category) {
90
+ query.set('category', params.category);
91
+ }
92
+ const queryString = query.toString();
93
+ const endpoint = `/pull-requests/suggestions${queryString ? `?${queryString}` : ''}`;
94
+ const isTeamKey = accessToken.startsWith('mesrai_');
95
+ return this.requester(endpoint, {
96
+ headers: {
97
+ ...(isTeamKey
98
+ ? { 'X-Team-Key': accessToken }
99
+ : { Authorization: `Bearer ${accessToken}` }),
100
+ },
101
+ });
102
+ }
103
+ async triggerBusinessValidation(accessToken, params) {
104
+ const isTeamKey = accessToken.startsWith('mesrai_');
105
+ const body = {};
106
+ if (params.repository) {
107
+ body.repository = params.repository;
108
+ }
109
+ if (params.taskUrl) {
110
+ body.taskUrl = params.taskUrl;
111
+ }
112
+ if (params.taskId) {
113
+ body.taskId = params.taskId;
114
+ }
115
+ if (params.diff) {
116
+ body.diff = params.diff;
117
+ }
118
+ return this.requester('/cli/business-validation', {
119
+ method: 'POST',
120
+ headers: {
121
+ ...(isTeamKey
122
+ ? { 'X-Team-Key': accessToken }
123
+ : { Authorization: `Bearer ${accessToken}` }),
124
+ },
125
+ body: JSON.stringify(body),
126
+ });
127
+ }
128
+ async trialAnalyze(diff, fingerprint, metrics, githubPat) {
129
+ return this.requester('/cli/trial/review', {
130
+ method: 'POST',
131
+ body: JSON.stringify({
132
+ diff,
133
+ fingerprint,
134
+ ...metrics,
135
+ ...(githubPat && { githubPat }),
136
+ }),
137
+ });
138
+ }
139
+ }
140
+ //# sourceMappingURL=review.api.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"review.api.js","sourceRoot":"","sources":["../../../src/services/api/review.api.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,13 @@
1
+ import type { MesraiRuleMutationResult, CreateMesraiRuleRequest, MesraiRule, UpdateMesraiRuleRequest, ViewMesraiRulesRequest } from '../../types/rules.js';
2
+ import type { IRulesApi } from './api.interface.js';
3
+ type RequestWithRetry = <T>(endpoint: string, options?: RequestInit) => Promise<T>;
4
+ export declare class RealRulesApi implements IRulesApi {
5
+ private readonly requester;
6
+ constructor(requester?: RequestWithRetry);
7
+ private buildAuthHeaders;
8
+ createRule(accessToken: string, payload: CreateMesraiRuleRequest): Promise<MesraiRuleMutationResult>;
9
+ updateRule(accessToken: string, ruleId: string, payload: UpdateMesraiRuleRequest): Promise<MesraiRuleMutationResult>;
10
+ viewRules(accessToken: string, query?: ViewMesraiRulesRequest): Promise<MesraiRule[]>;
11
+ }
12
+ export {};
13
+ //# sourceMappingURL=rules.api.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"rules.api.d.ts","sourceRoot":"","sources":["../../../src/services/api/rules.api.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EACR,wBAAwB,EACxB,uBAAuB,EACvB,UAAU,EACV,uBAAuB,EACvB,sBAAsB,EACzB,MAAM,sBAAsB,CAAC;AAE9B,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,oBAAoB,CAAC;AAEpD,KAAK,gBAAgB,GAAG,CAAC,CAAC,EACtB,QAAQ,EAAE,MAAM,EAChB,OAAO,CAAC,EAAE,WAAW,KACpB,OAAO,CAAC,CAAC,CAAC,CAAC;AAEhB,qBAAa,YAAa,YAAW,SAAS;IAEtC,OAAO,CAAC,QAAQ,CAAC,SAAS;gBAAT,SAAS,GAAE,gBAAmC;IAGnE,OAAO,CAAC,gBAAgB;IAMlB,UAAU,CACZ,WAAW,EAAE,MAAM,EACnB,OAAO,EAAE,uBAAuB,GACjC,OAAO,CAAC,wBAAwB,CAAC;IAQ9B,UAAU,CACZ,WAAW,EAAE,MAAM,EACnB,MAAM,EAAE,MAAM,EACd,OAAO,EAAE,uBAAuB,GACjC,OAAO,CAAC,wBAAwB,CAAC;IAW9B,SAAS,CACX,WAAW,EAAE,MAAM,EACnB,KAAK,GAAE,sBAA2B,GACnC,OAAO,CAAC,UAAU,EAAE,CAAC;CAgB3B"}
@@ -0,0 +1,41 @@
1
+ import { requestWithRetry } from './api-core.js';
2
+ export class RealRulesApi {
3
+ requester;
4
+ constructor(requester = requestWithRetry) {
5
+ this.requester = requester;
6
+ }
7
+ buildAuthHeaders(accessToken) {
8
+ return accessToken.startsWith('mesrai_')
9
+ ? { 'X-Team-Key': accessToken }
10
+ : { Authorization: `Bearer ${accessToken}` };
11
+ }
12
+ async createRule(accessToken, payload) {
13
+ return this.requester('/cli/mesrai-rules', {
14
+ method: 'POST',
15
+ headers: this.buildAuthHeaders(accessToken),
16
+ body: JSON.stringify(payload),
17
+ });
18
+ }
19
+ async updateRule(accessToken, ruleId, payload) {
20
+ return this.requester(`/cli/mesrai-rules/${encodeURIComponent(ruleId)}`, {
21
+ method: 'PATCH',
22
+ headers: this.buildAuthHeaders(accessToken),
23
+ body: JSON.stringify(payload),
24
+ });
25
+ }
26
+ async viewRules(accessToken, query = {}) {
27
+ const params = new URLSearchParams();
28
+ if (query.repositoryId) {
29
+ params.set('repositoryId', query.repositoryId);
30
+ }
31
+ if (query.ruleId) {
32
+ params.set('ruleId', query.ruleId);
33
+ }
34
+ const queryString = params.toString();
35
+ const endpoint = `/cli/mesrai-rules${queryString ? `?${queryString}` : ''}`;
36
+ return this.requester(endpoint, {
37
+ headers: this.buildAuthHeaders(accessToken),
38
+ });
39
+ }
40
+ }
41
+ //# sourceMappingURL=rules.api.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"rules.api.js","sourceRoot":"","sources":["../../../src/services/api/rules.api.ts"],"names":[],"mappings":"AAOA,OAAO,EAAE,gBAAgB,EAAE,MAAM,eAAe,CAAC;AAQjD,MAAM,OAAO,YAAY;IAEA;IADrB,YACqB,YAA8B,gBAAgB;QAA9C,cAAS,GAAT,SAAS,CAAqC;IAChE,CAAC;IAEI,gBAAgB,CAAC,WAAmB;QACxC,OAAO,WAAW,CAAC,UAAU,CAAC,SAAS,CAAC;YACpC,CAAC,CAAC,EAAE,YAAY,EAAE,WAAW,EAAE;YAC/B,CAAC,CAAC,EAAE,aAAa,EAAE,UAAU,WAAW,EAAE,EAAE,CAAC;IACrD,CAAC;IAED,KAAK,CAAC,UAAU,CACZ,WAAmB,EACnB,OAAgC;QAEhC,OAAO,IAAI,CAAC,SAAS,CAA2B,mBAAmB,EAAE;YACjE,MAAM,EAAE,MAAM;YACd,OAAO,EAAE,IAAI,CAAC,gBAAgB,CAAC,WAAW,CAAC;YAC3C,IAAI,EAAE,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC;SAChC,CAAC,CAAC;IACP,CAAC;IAED,KAAK,CAAC,UAAU,CACZ,WAAmB,EACnB,MAAc,EACd,OAAgC;QAEhC,OAAO,IAAI,CAAC,SAAS,CACjB,qBAAqB,kBAAkB,CAAC,MAAM,CAAC,EAAE,EACjD;YACI,MAAM,EAAE,OAAO;YACf,OAAO,EAAE,IAAI,CAAC,gBAAgB,CAAC,WAAW,CAAC;YAC3C,IAAI,EAAE,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC;SAChC,CACJ,CAAC;IACN,CAAC;IAED,KAAK,CAAC,SAAS,CACX,WAAmB,EACnB,QAAgC,EAAE;QAElC,MAAM,MAAM,GAAG,IAAI,eAAe,EAAE,CAAC;QACrC,IAAI,KAAK,CAAC,YAAY,EAAE,CAAC;YACrB,MAAM,CAAC,GAAG,CAAC,cAAc,EAAE,KAAK,CAAC,YAAY,CAAC,CAAC;QACnD,CAAC;QACD,IAAI,KAAK,CAAC,MAAM,EAAE,CAAC;YACf,MAAM,CAAC,GAAG,CAAC,QAAQ,EAAE,KAAK,CAAC,MAAM,CAAC,CAAC;QACvC,CAAC;QAED,MAAM,WAAW,GAAG,MAAM,CAAC,QAAQ,EAAE,CAAC;QACtC,MAAM,QAAQ,GAAG,oBAAoB,WAAW,CAAC,CAAC,CAAC,IAAI,WAAW,EAAE,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC;QAE5E,OAAO,IAAI,CAAC,SAAS,CAAe,QAAQ,EAAE;YAC1C,OAAO,EAAE,IAAI,CAAC,gBAAgB,CAAC,WAAW,CAAC;SAC9C,CAAC,CAAC;IACP,CAAC;CACJ"}
@@ -0,0 +1,6 @@
1
+ import type { SessionApiEvent } from '../../types/session-events.js';
2
+ import type { ISessionsApi } from './api.interface.js';
3
+ export declare class RealSessionsApi implements ISessionsApi {
4
+ sendEvent(event: SessionApiEvent, repoRoot: string): Promise<void>;
5
+ }
6
+ //# sourceMappingURL=sessions.api.d.ts.map