@ebowwa/coder 0.2.1 → 0.7.64

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 (401) hide show
  1. package/README.md +31 -32
  2. package/dist/core/__tests__/permissions.test.d.ts +12 -0
  3. package/dist/core/__tests__/permissions.test.d.ts.map +1 -0
  4. package/dist/core/__tests__/permissions.test.js +851 -0
  5. package/dist/core/agent-loop/__tests__/compaction.test.d.ts +5 -0
  6. package/dist/core/agent-loop/__tests__/compaction.test.d.ts.map +1 -0
  7. package/dist/core/agent-loop/__tests__/compaction.test.js +209 -0
  8. package/dist/core/agent-loop/__tests__/formatters.test.d.ts +5 -0
  9. package/dist/core/agent-loop/__tests__/formatters.test.d.ts.map +1 -0
  10. package/dist/core/agent-loop/__tests__/formatters.test.js +195 -0
  11. package/dist/core/agent-loop/__tests__/index.test.d.ts +5 -0
  12. package/dist/core/agent-loop/__tests__/index.test.d.ts.map +1 -0
  13. package/dist/core/agent-loop/__tests__/index.test.js +121 -0
  14. package/dist/core/agent-loop/__tests__/loop-state.test.d.ts +5 -0
  15. package/dist/core/agent-loop/__tests__/loop-state.test.d.ts.map +1 -0
  16. package/dist/core/agent-loop/__tests__/loop-state.test.js +340 -0
  17. package/dist/core/agent-loop/__tests__/message-builder.test.d.ts +5 -0
  18. package/dist/core/agent-loop/__tests__/message-builder.test.d.ts.map +1 -0
  19. package/dist/core/agent-loop/__tests__/message-builder.test.js +178 -0
  20. package/dist/core/agent-loop/__tests__/tool-executor.test.d.ts +5 -0
  21. package/dist/core/agent-loop/__tests__/tool-executor.test.d.ts.map +1 -0
  22. package/dist/core/agent-loop/__tests__/tool-executor.test.js +331 -0
  23. package/dist/core/agent-loop/compaction.d.ts +39 -0
  24. package/dist/core/agent-loop/compaction.d.ts.map +1 -0
  25. package/dist/core/agent-loop/compaction.js +51 -0
  26. package/dist/core/agent-loop/formatters.d.ts +21 -0
  27. package/dist/core/agent-loop/formatters.d.ts.map +1 -0
  28. package/dist/core/agent-loop/formatters.js +42 -0
  29. package/dist/core/agent-loop/index.d.ts +25 -0
  30. package/dist/core/agent-loop/index.d.ts.map +1 -0
  31. package/dist/core/agent-loop/index.js +83 -0
  32. package/dist/core/agent-loop/loop-state.d.ts +74 -0
  33. package/dist/core/agent-loop/loop-state.d.ts.map +1 -0
  34. package/dist/core/agent-loop/loop-state.js +147 -0
  35. package/dist/core/agent-loop/message-builder.d.ts +13 -0
  36. package/dist/core/agent-loop/message-builder.d.ts.map +1 -0
  37. package/dist/core/agent-loop/message-builder.js +49 -0
  38. package/dist/core/agent-loop/tool-executor.d.ts +23 -0
  39. package/dist/core/agent-loop/tool-executor.d.ts.map +1 -0
  40. package/dist/core/agent-loop/tool-executor.js +152 -0
  41. package/dist/core/agent-loop/turn-executor.d.ts +57 -0
  42. package/dist/core/agent-loop/turn-executor.d.ts.map +1 -0
  43. package/dist/core/agent-loop/turn-executor.js +124 -0
  44. package/dist/core/agent-loop/types.d.ts +141 -0
  45. package/dist/core/agent-loop/types.d.ts.map +1 -0
  46. package/dist/core/agent-loop/types.js +4 -0
  47. package/dist/core/agent-loop.d.ts +17 -0
  48. package/dist/core/agent-loop.d.ts.map +1 -0
  49. package/dist/core/agent-loop.js +16 -0
  50. package/dist/core/api-client-impl.d.ts +62 -0
  51. package/dist/core/api-client-impl.d.ts.map +1 -0
  52. package/dist/core/api-client-impl.js +479 -0
  53. package/dist/core/api-client.d.ts +6 -0
  54. package/dist/core/api-client.d.ts.map +1 -0
  55. package/dist/core/api-client.js +5 -0
  56. package/dist/core/checkpoints.d.ts +128 -0
  57. package/dist/core/checkpoints.d.ts.map +1 -0
  58. package/dist/core/checkpoints.js +438 -0
  59. package/dist/core/claude-md.d.ts +71 -0
  60. package/dist/core/claude-md.d.ts.map +1 -0
  61. package/dist/core/claude-md.js +198 -0
  62. package/dist/core/cognitive-security/hooks.d.ts +138 -0
  63. package/dist/core/cognitive-security/hooks.d.ts.map +1 -0
  64. package/dist/core/cognitive-security/hooks.js +389 -0
  65. package/dist/core/cognitive-security/index.d.ts +751 -0
  66. package/dist/core/cognitive-security/index.d.ts.map +1 -0
  67. package/dist/core/cognitive-security/index.js +1123 -0
  68. package/dist/core/cognitive-security/middleware.d.ts +136 -0
  69. package/dist/core/cognitive-security/middleware.d.ts.map +1 -0
  70. package/dist/core/cognitive-security/middleware.js +376 -0
  71. package/dist/core/config-loader.d.ts +127 -0
  72. package/dist/core/config-loader.d.ts.map +1 -0
  73. package/dist/core/config-loader.js +219 -0
  74. package/dist/core/context-compaction.d.ts +87 -0
  75. package/dist/core/context-compaction.d.ts.map +1 -0
  76. package/dist/core/context-compaction.js +428 -0
  77. package/dist/core/git-status.d.ts +25 -0
  78. package/dist/core/git-status.d.ts.map +1 -0
  79. package/dist/core/git-status.js +204 -0
  80. package/dist/core/image.d.ts +69 -0
  81. package/dist/core/image.d.ts.map +1 -0
  82. package/dist/core/image.js +290 -0
  83. package/dist/core/image.test.d.ts +2 -0
  84. package/dist/core/image.test.d.ts.map +1 -0
  85. package/dist/core/image.test.js +149 -0
  86. package/dist/core/models.d.ts +123 -0
  87. package/dist/core/models.d.ts.map +1 -0
  88. package/dist/core/models.js +325 -0
  89. package/dist/core/permissions.d.ts +81 -0
  90. package/dist/core/permissions.d.ts.map +1 -0
  91. package/dist/core/permissions.js +327 -0
  92. package/dist/core/retry.d.ts +25 -0
  93. package/dist/core/retry.d.ts.map +1 -0
  94. package/dist/core/retry.js +121 -0
  95. package/dist/core/session-store.d.ts +9 -0
  96. package/dist/core/session-store.d.ts.map +1 -0
  97. package/dist/core/session-store.js +10 -0
  98. package/dist/core/sessions/export.d.ts +47 -0
  99. package/dist/core/sessions/export.d.ts.map +1 -0
  100. package/dist/core/sessions/export.js +256 -0
  101. package/dist/core/sessions/index.d.ts +132 -0
  102. package/dist/core/sessions/index.d.ts.map +1 -0
  103. package/dist/core/sessions/index.js +442 -0
  104. package/dist/core/sessions/metadata.d.ts +77 -0
  105. package/dist/core/sessions/metadata.d.ts.map +1 -0
  106. package/dist/core/sessions/metadata.js +233 -0
  107. package/dist/core/sessions/persistence.d.ts +72 -0
  108. package/dist/core/sessions/persistence.d.ts.map +1 -0
  109. package/dist/core/sessions/persistence.js +201 -0
  110. package/dist/core/sessions/types.d.ts +110 -0
  111. package/dist/core/sessions/types.d.ts.map +1 -0
  112. package/dist/core/sessions/types.js +4 -0
  113. package/dist/core/stream-highlighter.d.ts +18 -0
  114. package/dist/core/stream-highlighter.d.ts.map +1 -0
  115. package/dist/core/stream-highlighter.js +916 -0
  116. package/dist/core/system-reminders.d.ts +89 -0
  117. package/dist/core/system-reminders.d.ts.map +1 -0
  118. package/dist/core/system-reminders.js +285 -0
  119. package/dist/ecosystem/hooks/__tests__/index.test.d.ts +5 -0
  120. package/dist/ecosystem/hooks/__tests__/index.test.d.ts.map +1 -0
  121. package/dist/ecosystem/hooks/__tests__/index.test.js +458 -0
  122. package/dist/ecosystem/hooks/index.d.ts +59 -0
  123. package/dist/ecosystem/hooks/index.d.ts.map +1 -0
  124. package/dist/ecosystem/hooks/index.js +294 -0
  125. package/dist/ecosystem/hooks/prompt-evaluator.d.ts +32 -0
  126. package/dist/ecosystem/hooks/prompt-evaluator.d.ts.map +1 -0
  127. package/dist/ecosystem/hooks/prompt-evaluator.js +229 -0
  128. package/dist/ecosystem/skills/index.d.ts +55 -0
  129. package/dist/ecosystem/skills/index.d.ts.map +1 -0
  130. package/dist/ecosystem/skills/index.js +258 -0
  131. package/dist/ecosystem/tools/__tests__/index.test.d.ts +7 -0
  132. package/dist/ecosystem/tools/__tests__/index.test.d.ts.map +1 -0
  133. package/dist/ecosystem/tools/__tests__/index.test.js +856 -0
  134. package/dist/ecosystem/tools/index.d.ts +24 -0
  135. package/dist/ecosystem/tools/index.d.ts.map +1 -0
  136. package/dist/ecosystem/tools/index.js +1709 -0
  137. package/dist/index.d.ts +24 -0
  138. package/dist/index.d.ts.map +1 -0
  139. package/dist/index.js +32 -2
  140. package/dist/interfaces/mcp/client.d.ts +40 -0
  141. package/dist/interfaces/mcp/client.d.ts.map +1 -0
  142. package/dist/interfaces/mcp/client.js +309 -0
  143. package/dist/interfaces/ui/index.d.ts +36 -0
  144. package/dist/interfaces/ui/index.d.ts.map +1 -0
  145. package/dist/interfaces/ui/index.js +61 -0
  146. package/dist/interfaces/ui/spinner.d.ts +140 -0
  147. package/dist/interfaces/ui/spinner.d.ts.map +1 -0
  148. package/dist/interfaces/ui/spinner.js +342 -0
  149. package/dist/interfaces/ui/terminal/cli/index.d.ts +12 -0
  150. package/dist/interfaces/ui/terminal/cli/index.d.ts.map +1 -0
  151. package/dist/interfaces/ui/terminal/cli/index.js +167 -0
  152. package/dist/interfaces/ui/terminal/shared/args.d.ts +39 -0
  153. package/dist/interfaces/ui/terminal/shared/args.d.ts.map +1 -0
  154. package/dist/interfaces/ui/terminal/shared/args.js +176 -0
  155. package/dist/interfaces/ui/terminal/shared/index.d.ts +11 -0
  156. package/dist/interfaces/ui/terminal/shared/index.d.ts.map +1 -0
  157. package/dist/interfaces/ui/terminal/shared/index.js +16 -0
  158. package/dist/interfaces/ui/terminal/shared/loading-state.d.ts +124 -0
  159. package/dist/interfaces/ui/terminal/shared/loading-state.d.ts.map +1 -0
  160. package/dist/interfaces/ui/terminal/shared/loading-state.js +246 -0
  161. package/dist/interfaces/ui/terminal/shared/query.d.ts +22 -0
  162. package/dist/interfaces/ui/terminal/shared/query.d.ts.map +1 -0
  163. package/dist/interfaces/ui/terminal/shared/query.js +100 -0
  164. package/dist/interfaces/ui/terminal/shared/setup.d.ts +33 -0
  165. package/dist/interfaces/ui/terminal/shared/setup.d.ts.map +1 -0
  166. package/dist/interfaces/ui/terminal/shared/setup.js +226 -0
  167. package/dist/interfaces/ui/terminal/shared/status-line.d.ts +117 -0
  168. package/dist/interfaces/ui/terminal/shared/status-line.d.ts.map +1 -0
  169. package/dist/interfaces/ui/terminal/shared/status-line.js +267 -0
  170. package/dist/interfaces/ui/terminal/shared/system-prompt.d.ts +38 -0
  171. package/dist/interfaces/ui/terminal/shared/system-prompt.d.ts.map +1 -0
  172. package/dist/interfaces/ui/terminal/shared/system-prompt.js +102 -0
  173. package/dist/interfaces/ui/terminal/tui/HelpPanel.d.ts +39 -0
  174. package/dist/interfaces/ui/terminal/tui/HelpPanel.d.ts.map +1 -0
  175. package/dist/interfaces/ui/terminal/tui/HelpPanel.js +215 -0
  176. package/dist/interfaces/ui/terminal/tui/InputContext.d.ts +91 -0
  177. package/dist/interfaces/ui/terminal/tui/InputContext.d.ts.map +1 -0
  178. package/dist/interfaces/ui/terminal/tui/InputContext.js +154 -0
  179. package/dist/interfaces/ui/terminal/tui/InputField.d.ts +18 -0
  180. package/dist/interfaces/ui/terminal/tui/InputField.d.ts.map +1 -0
  181. package/dist/interfaces/ui/terminal/tui/InputField.js +41 -0
  182. package/dist/interfaces/ui/terminal/tui/InteractiveTUI.d.ts +16 -0
  183. package/dist/interfaces/ui/terminal/tui/InteractiveTUI.d.ts.map +1 -0
  184. package/dist/interfaces/ui/terminal/tui/InteractiveTUI.js +451 -0
  185. package/dist/interfaces/ui/terminal/tui/MessageArea.d.ts +10 -0
  186. package/dist/interfaces/ui/terminal/tui/MessageArea.d.ts.map +1 -0
  187. package/dist/interfaces/ui/terminal/tui/MessageArea.js +91 -0
  188. package/dist/interfaces/ui/terminal/tui/MessageStore.d.ts +48 -0
  189. package/dist/interfaces/ui/terminal/tui/MessageStore.d.ts.map +1 -0
  190. package/dist/interfaces/ui/terminal/tui/MessageStore.js +151 -0
  191. package/dist/interfaces/ui/terminal/tui/StatusBar.d.ts +9 -0
  192. package/dist/interfaces/ui/terminal/tui/StatusBar.d.ts.map +1 -0
  193. package/dist/interfaces/ui/terminal/tui/StatusBar.js +36 -0
  194. package/dist/interfaces/ui/terminal/tui/commands.d.ts +21 -0
  195. package/dist/interfaces/ui/terminal/tui/commands.d.ts.map +1 -0
  196. package/dist/interfaces/ui/terminal/tui/commands.js +359 -0
  197. package/dist/interfaces/ui/terminal/tui/components/InteractiveElements.d.ts +115 -0
  198. package/dist/interfaces/ui/terminal/tui/components/InteractiveElements.d.ts.map +1 -0
  199. package/dist/interfaces/ui/terminal/tui/components/InteractiveElements.js +306 -0
  200. package/dist/interfaces/ui/terminal/tui/components/MultilineInput.d.ts +92 -0
  201. package/dist/interfaces/ui/terminal/tui/components/MultilineInput.d.ts.map +1 -0
  202. package/dist/interfaces/ui/terminal/tui/components/MultilineInput.js +399 -0
  203. package/dist/interfaces/ui/terminal/tui/components/PaneManager.d.ts +59 -0
  204. package/dist/interfaces/ui/terminal/tui/components/PaneManager.d.ts.map +1 -0
  205. package/dist/interfaces/ui/terminal/tui/components/PaneManager.js +139 -0
  206. package/dist/interfaces/ui/terminal/tui/components/Sidebar.d.ts +68 -0
  207. package/dist/interfaces/ui/terminal/tui/components/Sidebar.d.ts.map +1 -0
  208. package/dist/interfaces/ui/terminal/tui/components/Sidebar.js +340 -0
  209. package/dist/interfaces/ui/terminal/tui/components/index.d.ts +23 -0
  210. package/dist/interfaces/ui/terminal/tui/components/index.d.ts.map +1 -0
  211. package/dist/interfaces/ui/terminal/tui/components/index.js +51 -0
  212. package/dist/interfaces/ui/terminal/tui/console.d.ts +20 -0
  213. package/dist/interfaces/ui/terminal/tui/console.d.ts.map +1 -0
  214. package/dist/interfaces/ui/terminal/tui/console.js +46 -0
  215. package/dist/interfaces/ui/terminal/tui/index.d.ts +20 -0
  216. package/dist/interfaces/ui/terminal/tui/index.d.ts.map +1 -0
  217. package/dist/interfaces/ui/terminal/tui/index.js +28 -0
  218. package/dist/interfaces/ui/terminal/tui/run.d.ts +13 -0
  219. package/dist/interfaces/ui/terminal/tui/run.d.ts.map +1 -0
  220. package/dist/interfaces/ui/terminal/tui/run.js +31 -0
  221. package/dist/interfaces/ui/terminal/tui/spinner.d.ts +44 -0
  222. package/dist/interfaces/ui/terminal/tui/spinner.d.ts.map +1 -0
  223. package/dist/interfaces/ui/terminal/tui/spinner.js +59 -0
  224. package/dist/interfaces/ui/terminal/tui/tui-app.d.ts +39 -0
  225. package/dist/interfaces/ui/terminal/tui/tui-app.d.ts.map +1 -0
  226. package/dist/interfaces/ui/terminal/tui/tui-app.js +198 -0
  227. package/dist/interfaces/ui/terminal/tui/tui-footer.d.ts +167 -0
  228. package/dist/interfaces/ui/terminal/tui/tui-footer.d.ts.map +1 -0
  229. package/dist/interfaces/ui/terminal/tui/tui-footer.js +330 -0
  230. package/dist/interfaces/ui/terminal/tui/types.d.ts +165 -0
  231. package/dist/interfaces/ui/terminal/tui/types.d.ts.map +1 -0
  232. package/dist/interfaces/ui/terminal/tui/types.js +5 -0
  233. package/dist/interfaces/ui/terminal/tui/useInputHandler.d.ts +23 -0
  234. package/dist/interfaces/ui/terminal/tui/useInputHandler.d.ts.map +1 -0
  235. package/dist/interfaces/ui/terminal/tui/useInputHandler.js +72 -0
  236. package/dist/interfaces/ui/terminal/tui/useNativeInput.d.ts +90 -0
  237. package/dist/interfaces/ui/terminal/tui/useNativeInput.d.ts.map +1 -0
  238. package/dist/interfaces/ui/terminal/tui/useNativeInput.js +188 -0
  239. package/dist/native/index.d.ts +480 -0
  240. package/dist/native/index.d.ts.map +1 -0
  241. package/dist/native/index.js +1625 -0
  242. package/dist/teammates/index.d.ts +161 -0
  243. package/dist/teammates/index.d.ts.map +1 -0
  244. package/dist/teammates/index.js +827 -0
  245. package/dist/types/index.d.ts +482 -0
  246. package/dist/types/index.d.ts.map +1 -0
  247. package/dist/types/index.js +52 -0
  248. package/native/README.md +5 -5
  249. package/native/index.darwin-arm64.node +0 -0
  250. package/native/index.node +0 -0
  251. package/native/package.json +4 -4
  252. package/package.json +33 -16
  253. package/packages/src/core/__tests__/permissions.test.ts +1091 -0
  254. package/packages/src/core/agent-loop/__tests__/compaction.test.ts +280 -0
  255. package/packages/src/core/agent-loop/__tests__/formatters.test.ts +234 -0
  256. package/packages/src/core/agent-loop/__tests__/index.test.ts +162 -0
  257. package/packages/src/core/agent-loop/__tests__/loop-state.test.ts +413 -0
  258. package/packages/src/core/agent-loop/__tests__/message-builder.test.ts +229 -0
  259. package/packages/src/core/agent-loop/__tests__/tool-executor.test.ts +457 -0
  260. package/packages/src/core/agent-loop/compaction.ts +88 -0
  261. package/packages/src/core/agent-loop/formatters.ts +50 -0
  262. package/packages/src/core/agent-loop/index.ts +135 -0
  263. package/packages/src/core/agent-loop/loop-state.ts +187 -0
  264. package/packages/src/core/agent-loop/message-builder.ts +62 -0
  265. package/packages/src/core/agent-loop/tool-executor.ts +211 -0
  266. package/packages/src/core/agent-loop/turn-executor.ts +222 -0
  267. package/packages/src/core/agent-loop/types.ts +148 -0
  268. package/packages/src/core/agent-loop.ts +18 -0
  269. package/packages/src/core/api-client-impl.ts +619 -0
  270. package/packages/src/core/api-client.ts +6 -0
  271. package/packages/src/core/checkpoints.ts +606 -0
  272. package/packages/src/core/claude-md.ts +272 -0
  273. package/packages/src/core/cognitive-security/hooks.ts +590 -0
  274. package/packages/src/core/cognitive-security/index.ts +2041 -0
  275. package/packages/src/core/cognitive-security/middleware.ts +536 -0
  276. package/packages/src/core/config-loader.ts +324 -0
  277. package/packages/src/core/context-compaction.ts +578 -0
  278. package/packages/src/core/git-status.ts +262 -0
  279. package/packages/src/core/image.test.ts +180 -0
  280. package/packages/src/core/image.ts +350 -0
  281. package/packages/src/core/lmdb.db +0 -0
  282. package/packages/src/core/lmdb.db-lock +0 -0
  283. package/packages/src/core/models.ts +430 -0
  284. package/packages/src/core/normalizers/todo +4 -0
  285. package/packages/src/core/permissions.ts +431 -0
  286. package/packages/src/core/retry.ts +170 -0
  287. package/packages/src/core/session-store.ts +36 -0
  288. package/packages/src/core/sessions/export.ts +329 -0
  289. package/packages/src/core/sessions/index.ts +587 -0
  290. package/packages/src/core/sessions/metadata.ts +309 -0
  291. package/packages/src/core/sessions/persistence.ts +244 -0
  292. package/packages/src/core/sessions/types.ts +169 -0
  293. package/packages/src/core/stream-highlighter.ts +1123 -0
  294. package/packages/src/core/system-reminders.ts +402 -0
  295. package/packages/src/core/todo +8 -0
  296. package/packages/src/ecosystem/hooks/__tests__/index.test.ts +561 -0
  297. package/packages/src/ecosystem/hooks/index.ts +341 -0
  298. package/packages/src/ecosystem/hooks/prompt-evaluator.ts +300 -0
  299. package/packages/src/ecosystem/skills/index.ts +295 -0
  300. package/packages/src/ecosystem/tools/__tests__/index.test.ts +1335 -0
  301. package/packages/src/ecosystem/tools/index.ts +1877 -0
  302. package/packages/src/index.ts +120 -0
  303. package/packages/src/interfaces/mcp/client.ts +389 -0
  304. package/packages/src/interfaces/ui/Screenshot 2026-03-02 at 9.23.10/342/200/257PM.png +0 -0
  305. package/packages/src/interfaces/ui/Screenshot 2026-03-03 at 10.55.11/342/200/257AM.png +0 -0
  306. package/packages/src/interfaces/ui/index.ts +161 -0
  307. package/packages/src/interfaces/ui/lmdb.db +0 -0
  308. package/packages/src/interfaces/ui/lmdb.db-lock +0 -0
  309. package/packages/src/interfaces/ui/spinner.ts +451 -0
  310. package/packages/src/interfaces/ui/terminal/cli/index.ts +228 -0
  311. package/packages/src/interfaces/ui/terminal/lmdb.db +0 -0
  312. package/packages/src/interfaces/ui/terminal/lmdb.db-lock +0 -0
  313. package/packages/src/interfaces/ui/terminal/shared/args.ts +222 -0
  314. package/packages/src/interfaces/ui/terminal/shared/index.ts +71 -0
  315. package/packages/src/interfaces/ui/terminal/shared/loading-state.ts +322 -0
  316. package/packages/src/interfaces/ui/terminal/shared/query.ts +146 -0
  317. package/packages/src/interfaces/ui/terminal/shared/setup.ts +295 -0
  318. package/packages/src/interfaces/ui/terminal/shared/status-line.ts +358 -0
  319. package/packages/src/interfaces/ui/terminal/shared/system-prompt.ts +146 -0
  320. package/packages/src/interfaces/ui/terminal/tui/HelpPanel.tsx +262 -0
  321. package/packages/src/interfaces/ui/terminal/tui/InputContext.tsx +232 -0
  322. package/packages/src/interfaces/ui/terminal/tui/InputField.tsx +62 -0
  323. package/packages/src/interfaces/ui/terminal/tui/InteractiveTUI.tsx +537 -0
  324. package/packages/src/interfaces/ui/terminal/tui/MessageArea.tsx +107 -0
  325. package/packages/src/interfaces/ui/terminal/tui/MessageStore.tsx +240 -0
  326. package/packages/src/interfaces/ui/terminal/tui/StatusBar.tsx +54 -0
  327. package/packages/src/interfaces/ui/terminal/tui/commands.ts +438 -0
  328. package/packages/src/interfaces/ui/terminal/tui/components/InteractiveElements.tsx +584 -0
  329. package/packages/src/interfaces/ui/terminal/tui/components/MultilineInput.tsx +614 -0
  330. package/packages/src/interfaces/ui/terminal/tui/components/PaneManager.tsx +333 -0
  331. package/packages/src/interfaces/ui/terminal/tui/components/Sidebar.tsx +604 -0
  332. package/packages/src/interfaces/ui/terminal/tui/components/index.ts +118 -0
  333. package/packages/src/interfaces/ui/terminal/tui/console.ts +49 -0
  334. package/packages/src/interfaces/ui/terminal/tui/index.ts +90 -0
  335. package/packages/src/interfaces/ui/terminal/tui/run.tsx +42 -0
  336. package/packages/src/interfaces/ui/terminal/tui/spinner.ts +69 -0
  337. package/packages/src/interfaces/ui/terminal/tui/tui-app.tsx +390 -0
  338. package/packages/src/interfaces/ui/terminal/tui/tui-footer.ts +422 -0
  339. package/packages/src/interfaces/ui/terminal/tui/types.ts +186 -0
  340. package/packages/src/interfaces/ui/terminal/tui/useInputHandler.ts +104 -0
  341. package/packages/src/interfaces/ui/terminal/tui/useNativeInput.ts +239 -0
  342. package/packages/src/lmdb.db +0 -0
  343. package/packages/src/lmdb.db-lock +0 -0
  344. package/packages/src/native/index.ts +2345 -0
  345. package/packages/src/teammates/index.ts +982 -0
  346. package/packages/src/types/index.ts +722 -0
  347. package/dist/cli.js +0 -148
  348. package/dist/index-0pkak453.js +0 -136
  349. package/dist/index-0qd0x8b4.js +0 -110
  350. package/dist/index-0x3kprq6.js +0 -240
  351. package/dist/index-1eawy937.js +0 -308
  352. package/dist/index-24m2aygy.js +0 -240
  353. package/dist/index-29xcjnne.js +0 -280
  354. package/dist/index-2avyytn5.js +0 -349
  355. package/dist/index-4ms367ey.js +0 -136
  356. package/dist/index-4w2t3b0m.js +0 -240
  357. package/dist/index-4xfgd8nz.js +0 -261
  358. package/dist/index-5acjp9gc.js +0 -157
  359. package/dist/index-5s15hr56.js +0 -136
  360. package/dist/index-6e4wf341.js +0 -349
  361. package/dist/index-6fvnkedw.js +0 -240
  362. package/dist/index-6rqpmd4g.js +0 -128
  363. package/dist/index-77ckwnbm.js +0 -280
  364. package/dist/index-9knxy49k.js +0 -128
  365. package/dist/index-9zrnw4zx.js +0 -128
  366. package/dist/index-bk21w99v.js +0 -280
  367. package/dist/index-c41n76fv.js +0 -240
  368. package/dist/index-cb4ppjdt.js +0 -255
  369. package/dist/index-cfb2edt6.js +0 -240
  370. package/dist/index-cmfa38hh.js +0 -308
  371. package/dist/index-datjz8q1.js +0 -257
  372. package/dist/index-eadf4wvn.js +0 -240
  373. package/dist/index-em5k0m3z.js +0 -345
  374. package/dist/index-gh8r333a.js +0 -110
  375. package/dist/index-gkx6k2tr.js +0 -261
  376. package/dist/index-h5cabfks.js +0 -155
  377. package/dist/index-hcrpwyy3.js +0 -261
  378. package/dist/index-hk7fwwa8.js +0 -257
  379. package/dist/index-jb8cw7f8.js +0 -136
  380. package/dist/index-kbyw4th1.js +0 -347
  381. package/dist/index-kgj5gqnm.js +0 -345
  382. package/dist/index-mdf6xp1z.js +0 -255
  383. package/dist/index-mrhv8kvc.js +0 -280
  384. package/dist/index-mt4743dd.js +0 -161
  385. package/dist/index-qnwsg97q.js +0 -240
  386. package/dist/index-qwdy6x44.js +0 -261
  387. package/dist/index-rmj77261.js +0 -157
  388. package/dist/index-sbbw1a61.js +0 -349
  389. package/dist/index-svy5bcpn.js +0 -345
  390. package/dist/index-tvmy7tm9.js +0 -261
  391. package/dist/index-tzz4vzkj.js +0 -312
  392. package/dist/index-vz80zmhe.js +0 -110
  393. package/dist/index-wed2fk67.js +0 -240
  394. package/dist/index-wksgzz8e.js +0 -280
  395. package/dist/index-wn2m4wma.js +0 -240
  396. package/dist/index-xha05vjc.js +0 -257
  397. package/dist/index-yc6eh8p8.js +0 -136
  398. package/dist/index-ycjxx9ft.js +0 -240
  399. package/dist/index-z0gzd0fc.js +0 -110
  400. package/dist/index-z8cwtf8j.js +0 -240
  401. package/dist/index-zy5mtt00.js +0 -128
@@ -0,0 +1,561 @@
1
+ /**
2
+ * Hook System Tests
3
+ */
4
+
5
+ import { describe, it, expect, beforeEach, afterEach } from "bun:test";
6
+ import { HookManager, builtInHooks, hookExitCodes } from "../index.js";
7
+ import type { HookEvent, HookInput, HookOutput } from "../../../types/index.js";
8
+
9
+ describe("HookManager", () => {
10
+ let manager: HookManager;
11
+
12
+ beforeEach(() => {
13
+ manager = new HookManager(5000);
14
+ });
15
+
16
+ afterEach(() => {
17
+ manager.clear();
18
+ });
19
+
20
+ describe("registration", () => {
21
+ it("should register a hook", () => {
22
+ manager.register("PreToolUse", {
23
+ event: "PreToolUse",
24
+ command: "echo 'test'",
25
+ enabled: true,
26
+ });
27
+
28
+ const hooks = manager.getHooks("PreToolUse");
29
+ expect(hooks).toHaveLength(1);
30
+ expect(hooks[0]?.command).toBe("echo 'test'");
31
+ });
32
+
33
+ it("should register multiple hooks for the same event", () => {
34
+ manager.register("PreToolUse", {
35
+ event: "PreToolUse",
36
+ command: "echo '1'",
37
+ enabled: true,
38
+ });
39
+
40
+ manager.register("PreToolUse", {
41
+ event: "PreToolUse",
42
+ command: "echo '2'",
43
+ enabled: true,
44
+ });
45
+
46
+ const hooks = manager.getHooks("PreToolUse");
47
+ expect(hooks).toHaveLength(2);
48
+ });
49
+
50
+ it("should register all hooks from a record", () => {
51
+ // Using type assertion since registerAll expects a complete Record
52
+ manager.registerAll({
53
+ PreToolUse: [
54
+ {
55
+ event: "PreToolUse",
56
+ command: "echo '1'",
57
+ enabled: true,
58
+ },
59
+ ],
60
+ PostToolUse: [
61
+ {
62
+ event: "PostToolUse",
63
+ command: "echo '2'",
64
+ enabled: true,
65
+ },
66
+ ],
67
+ } as any);
68
+
69
+ expect(manager.getHooks("PreToolUse")).toHaveLength(1);
70
+ expect(manager.getHooks("PostToolUse")).toHaveLength(1);
71
+ });
72
+ });
73
+
74
+ describe("in-process handlers", () => {
75
+ it("should execute an in-process handler", async () => {
76
+ let called = false;
77
+
78
+ manager.registerHandler("PreToolUse", async (input) => {
79
+ called = true;
80
+ return { decision: "allow" };
81
+ });
82
+
83
+ const result = await manager.execute("PreToolUse", {
84
+ tool_name: "Write",
85
+ tool_input: {},
86
+ });
87
+
88
+ expect(called).toBe(true);
89
+ expect(result.decision).toBe("allow");
90
+ });
91
+
92
+ it("should allow handler to deny execution", async () => {
93
+ manager.registerHandler("PreToolUse", async (input) => {
94
+ return {
95
+ decision: "deny",
96
+ reason: "Not allowed",
97
+ };
98
+ });
99
+
100
+ const result = await manager.execute("PreToolUse", {
101
+ tool_name: "Write",
102
+ tool_input: {},
103
+ });
104
+
105
+ expect(result.decision).toBe("deny");
106
+ expect(result.reason).toBe("Not allowed");
107
+ });
108
+
109
+ it("should allow handler to modify input", async () => {
110
+ manager.registerHandler("PreToolUse", async (input) => {
111
+ return {
112
+ decision: "allow",
113
+ modified_input: {
114
+ tool_input: { modified: true },
115
+ },
116
+ };
117
+ });
118
+
119
+ const input = {
120
+ tool_name: "Write",
121
+ tool_input: { original: true },
122
+ };
123
+
124
+ const result = await manager.execute("PreToolUse", input);
125
+
126
+ expect(result.decision).toBe("allow");
127
+ expect((input as any).tool_input).toEqual({ modified: true });
128
+ });
129
+
130
+ it("should handle handler errors gracefully", async () => {
131
+ manager.registerHandler("PreToolUse", async () => {
132
+ throw new Error("Handler failed");
133
+ });
134
+
135
+ const result = await manager.execute("PreToolUse", {
136
+ tool_name: "Write",
137
+ tool_input: {},
138
+ });
139
+
140
+ expect(result.decision).toBe("deny");
141
+ expect(result.reason).toBe("Hook handler error: Handler failed");
142
+ expect(result.errors?.[0]).toContain("Handler failed");
143
+ });
144
+ });
145
+
146
+ describe("shell command hooks", () => {
147
+ it("should execute a simple shell hook", async () => {
148
+ manager.register("PostToolUse", {
149
+ event: "PostToolUse",
150
+ command: `node -e '
151
+ const input = JSON.parse(require("fs").readFileSync(0, "utf8"));
152
+ console.log(JSON.stringify({ decision: "allow" }));
153
+ '`,
154
+ enabled: true,
155
+ });
156
+
157
+ const result = await manager.execute("PostToolUse", {
158
+ tool_name: "Write",
159
+ tool_input: {},
160
+ tool_result: { content: "test" },
161
+ });
162
+
163
+ expect(result.decision).toBe("allow");
164
+ });
165
+
166
+ it("should parse JSON output from hook", async () => {
167
+ manager.register("PreToolUse", {
168
+ event: "PreToolUse",
169
+ command: `node -e '
170
+ const input = JSON.parse(require("fs").readFileSync(0, "utf8"));
171
+ console.log(JSON.stringify({
172
+ decision: "deny",
173
+ reason: "Test denial"
174
+ }));
175
+ '`,
176
+ enabled: true,
177
+ });
178
+
179
+ const result = await manager.execute("PreToolUse", {
180
+ tool_name: "Write",
181
+ tool_input: {},
182
+ });
183
+
184
+ expect(result.decision).toBe("deny");
185
+ expect(result.reason).toBe("Test denial");
186
+ });
187
+
188
+ it("should default to allow on invalid JSON", async () => {
189
+ manager.register("PreToolUse", {
190
+ event: "PreToolUse",
191
+ command: `echo "not json"`,
192
+ enabled: true,
193
+ });
194
+
195
+ const result = await manager.execute("PreToolUse", {
196
+ tool_name: "Write",
197
+ tool_input: {},
198
+ });
199
+
200
+ expect(result.decision).toBe("allow");
201
+ });
202
+
203
+ it("should handle exit code 1 as deny", async () => {
204
+ manager.register("PreToolUse", {
205
+ event: "PreToolUse",
206
+ command: `node -e '
207
+ console.error("Access denied");
208
+ process.exit(1);
209
+ '`,
210
+ enabled: true,
211
+ });
212
+
213
+ const result = await manager.execute("PreToolUse", {
214
+ tool_name: "Write",
215
+ tool_input: {},
216
+ });
217
+
218
+ expect(result.decision).toBe("deny");
219
+ expect(result.reason).toContain("Access denied");
220
+ });
221
+
222
+ it("should handle exit code 2 as block", async () => {
223
+ manager.register("PreToolUse", {
224
+ event: "PreToolUse",
225
+ command: `node -e '
226
+ console.error("Blocked");
227
+ process.exit(2);
228
+ '`,
229
+ enabled: true,
230
+ });
231
+
232
+ const result = await manager.execute("PreToolUse", {
233
+ tool_name: "Write",
234
+ tool_input: {},
235
+ });
236
+
237
+ expect(result.decision).toBe("block");
238
+ });
239
+
240
+ it("should timeout long-running hooks", async () => {
241
+ manager.register("PreToolUse", {
242
+ event: "PreToolUse",
243
+ command: `node -e '
244
+ setTimeout(() => {}, 10000);
245
+ '`,
246
+ enabled: true,
247
+ timeout: 100,
248
+ });
249
+
250
+ const result = await manager.execute("PreToolUse", {
251
+ tool_name: "Write",
252
+ tool_input: {},
253
+ });
254
+
255
+
256
+ // After timeout, execution is denied
257
+ expect(result.decision).toBe("deny");
258
+ expect(result.reason).toContain("Hook timeout");
259
+ });
260
+ });
261
+
262
+ describe("hook chaining", () => {
263
+ it("should execute multiple hooks in sequence", async () => {
264
+ const order: string[] = [];
265
+
266
+ manager.registerHandler("PreToolUse", async () => {
267
+ order.push("hook1");
268
+ return { decision: "allow" };
269
+ });
270
+
271
+ manager.registerHandler("PreToolUse", async () => {
272
+ order.push("hook2");
273
+ return { decision: "allow" };
274
+ });
275
+
276
+ manager.registerHandler("PreToolUse", async () => {
277
+ order.push("hook3");
278
+ return { decision: "allow" };
279
+ });
280
+
281
+ await manager.execute("PreToolUse", {
282
+ tool_name: "Write",
283
+ tool_input: {},
284
+ });
285
+
286
+ expect(order).toEqual(["hook1", "hook2", "hook3"]);
287
+ });
288
+
289
+ it("should stop on first deny", async () => {
290
+ const order: string[] = [];
291
+
292
+ manager.registerHandler("PreToolUse", async () => {
293
+ order.push("hook1");
294
+ return { decision: "allow" };
295
+ });
296
+
297
+ manager.registerHandler("PreToolUse", async () => {
298
+ order.push("hook2");
299
+ return { decision: "deny", reason: "Stop here" };
300
+ });
301
+
302
+ manager.registerHandler("PreToolUse", async () => {
303
+ order.push("hook3");
304
+ return { decision: "allow" };
305
+ });
306
+
307
+ const result = await manager.execute("PreToolUse", {
308
+ tool_name: "Write",
309
+ tool_input: {},
310
+ });
311
+
312
+ expect(order).toEqual(["hook1", "hook2"]);
313
+ expect(result.decision).toBe("deny");
314
+ expect(result.reason).toBe("Stop here");
315
+ });
316
+
317
+ it("should stop on first block", async () => {
318
+ const order: string[] = [];
319
+
320
+ manager.registerHandler("PreToolUse", async () => {
321
+ order.push("hook1");
322
+ return { decision: "allow" };
323
+ });
324
+
325
+ manager.registerHandler("PreToolUse", async () => {
326
+ order.push("hook2");
327
+ return { decision: "block", reason: "Blocked" };
328
+ });
329
+
330
+ manager.registerHandler("PreToolUse", async () => {
331
+ order.push("hook3");
332
+ return { decision: "allow" };
333
+ });
334
+
335
+ const result = await manager.execute("PreToolUse", {
336
+ tool_name: "Write",
337
+ tool_input: {},
338
+ });
339
+
340
+ expect(order).toEqual(["hook1", "hook2"]);
341
+ expect(result.decision).toBe("block");
342
+ });
343
+ });
344
+
345
+ describe("disabled hooks", () => {
346
+ it("should skip disabled hooks", async () => {
347
+ let called = false;
348
+
349
+ manager.registerHandler("PreToolUse", async () => {
350
+ called = true;
351
+ return { decision: "deny" };
352
+ });
353
+
354
+ const hooks = manager.getHooks("PreToolUse");
355
+ if (hooks[0]) hooks[0].enabled = false;
356
+
357
+ const result = await manager.execute("PreToolUse", {
358
+ tool_name: "Write",
359
+ tool_input: {},
360
+ });
361
+
362
+ expect(called).toBe(false);
363
+ expect(result.decision).toBe("allow");
364
+ });
365
+ });
366
+
367
+ describe("input modification", () => {
368
+ it("should apply modifications from hooks", async () => {
369
+ manager.registerHandler("PreToolUse", async () => {
370
+ return {
371
+ decision: "allow",
372
+ modified_input: {
373
+ tool_input: { step1: true },
374
+ },
375
+ };
376
+ });
377
+
378
+ manager.registerHandler("PreToolUse", async () => {
379
+ return {
380
+ decision: "allow",
381
+ modified_input: {
382
+ tool_input: { step2: true },
383
+ },
384
+ };
385
+ });
386
+
387
+ const input = {
388
+ tool_name: "Write",
389
+ tool_input: { original: true },
390
+ };
391
+
392
+ await manager.execute("PreToolUse", input);
393
+
394
+ expect((input as any).tool_input).toEqual({
395
+ step2: true,
396
+ });
397
+ });
398
+ });
399
+
400
+ describe("clear hooks", () => {
401
+ it("should clear all hooks", () => {
402
+ manager.register("PreToolUse", {
403
+ event: "PreToolUse",
404
+ command: "echo '1'",
405
+ enabled: true,
406
+ });
407
+
408
+ manager.register("PostToolUse", {
409
+ event: "PostToolUse",
410
+ command: "echo '2'",
411
+ enabled: true,
412
+ });
413
+
414
+ expect(manager.getHooks("PreToolUse")).toHaveLength(1);
415
+ expect(manager.getHooks("PostToolUse")).toHaveLength(1);
416
+
417
+ manager.clear();
418
+
419
+ expect(manager.getHooks("PreToolUse")).toHaveLength(0);
420
+ expect(manager.getHooks("PostToolUse")).toHaveLength(0);
421
+ });
422
+
423
+ it("should clear specific event hooks", () => {
424
+ manager.register("PreToolUse", {
425
+ event: "PreToolUse",
426
+ command: "echo '1'",
427
+ enabled: true,
428
+ });
429
+
430
+ manager.register("PostToolUse", {
431
+ event: "PostToolUse",
432
+ command: "echo '2'",
433
+ enabled: true,
434
+ });
435
+
436
+ manager.clear("PreToolUse");
437
+
438
+ expect(manager.getHooks("PreToolUse")).toHaveLength(0);
439
+ expect(manager.getHooks("PostToolUse")).toHaveLength(1);
440
+ });
441
+ });
442
+
443
+ describe("built-in hooks", () => {
444
+ it("should have built-in hooks defined", () => {
445
+ expect(builtInHooks.validateWrite).toBeDefined();
446
+ expect(builtInHooks.logToolUse).toBeDefined();
447
+ });
448
+
449
+ it("should have validateWrite hook disabled by default", () => {
450
+ expect(builtInHooks.validateWrite?.enabled).toBe(false);
451
+ });
452
+
453
+ it("should have logToolUse hook disabled by default", () => {
454
+ expect(builtInHooks.logToolUse?.enabled).toBe(false);
455
+ });
456
+ });
457
+
458
+ describe("hook input structure", () => {
459
+ it("should include timestamp in hook input", async () => {
460
+ let receivedTimestamp = 0;
461
+
462
+ manager.registerHandler("PreToolUse", async (input) => {
463
+ receivedTimestamp = input.timestamp;
464
+ return { decision: "allow" };
465
+ });
466
+
467
+ await manager.execute("PreToolUse", {
468
+ tool_name: "Write",
469
+ tool_input: {},
470
+ });
471
+
472
+ expect(receivedTimestamp).toBeGreaterThan(0);
473
+ });
474
+
475
+ it("should include event in hook input", async () => {
476
+ let receivedEvent: HookEvent | null = null;
477
+
478
+ manager.registerHandler("PreToolUse", async (input) => {
479
+ receivedEvent = input.event;
480
+ return { decision: "allow" };
481
+ });
482
+
483
+ await manager.execute("PreToolUse", {
484
+ tool_name: "Write",
485
+ tool_input: {},
486
+ });
487
+
488
+ expect(receivedEvent === "PreToolUse").toBe(true);
489
+ });
490
+ });
491
+
492
+ describe("real-world scenarios", () => {
493
+ it("should prevent writes to sensitive paths", async () => {
494
+ manager.register("PreToolUse", {
495
+ event: "PreToolUse",
496
+ command: `node -e '
497
+ const input = JSON.parse(require("fs").readFileSync(0, "utf8"));
498
+ if (input.tool_name === "Write") {
499
+ const path = input.tool_input.file_path;
500
+ if (path.includes("/etc/") || path.includes("~/.ssh/")) {
501
+ console.log(JSON.stringify({
502
+ decision: "deny",
503
+ reason: "Cannot write to sensitive path: " + path
504
+ }));
505
+ process.exit(1);
506
+ }
507
+ }
508
+ console.log(JSON.stringify({ decision: "allow" }));
509
+ '`,
510
+ enabled: true,
511
+ });
512
+
513
+ const safeResult = await manager.execute("PreToolUse", {
514
+ tool_name: "Write",
515
+ tool_input: { file_path: "/tmp/test.txt" },
516
+ });
517
+
518
+ expect(safeResult.decision).toBe("allow");
519
+
520
+ const dangerousResult = await manager.execute("PreToolUse", {
521
+ tool_name: "Write",
522
+ tool_input: { file_path: "/etc/passwd" },
523
+ });
524
+
525
+ expect(dangerousResult.decision).toBe("deny");
526
+ expect(dangerousResult.reason).toContain("Cannot write to sensitive path");
527
+ expect(dangerousResult.reason).toContain("/etc/passwd");
528
+ });
529
+
530
+ it("should log all tool uses", async () => {
531
+ const logs: string[] = [];
532
+
533
+ manager.registerHandler("PostToolUse", async (input) => {
534
+ logs.push(`Used: ${input.tool_name}`);
535
+ return { decision: "allow" };
536
+ });
537
+
538
+ await manager.execute("PostToolUse", {
539
+ tool_name: "Read",
540
+ tool_input: { file_path: "test.txt" },
541
+ tool_result: { content: "content" },
542
+ });
543
+
544
+ await manager.execute("PostToolUse", {
545
+ tool_name: "Write",
546
+ tool_input: { file_path: "test.txt" },
547
+ tool_result: { content: "" },
548
+ });
549
+
550
+ expect(logs).toEqual(["Used: Read", "Used: Write"]);
551
+ });
552
+ });
553
+ });
554
+
555
+ describe("hookExitCodes", () => {
556
+ it("should have correct exit codes", () => {
557
+ expect(hookExitCodes.ALLOW).toBe(0);
558
+ expect(hookExitCodes.DENY).toBe(1);
559
+ expect(hookExitCodes.BLOCK).toBe(2);
560
+ });
561
+ });