atena-cli 0.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (475) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +210 -0
  3. package/dist/agent.d.ts +44 -0
  4. package/dist/agent.d.ts.map +1 -0
  5. package/dist/agent.js +731 -0
  6. package/dist/agent.js.map +1 -0
  7. package/dist/agents.d.ts +33 -0
  8. package/dist/agents.d.ts.map +1 -0
  9. package/dist/agents.js +162 -0
  10. package/dist/agents.js.map +1 -0
  11. package/dist/autocomplete.d.ts +4 -0
  12. package/dist/autocomplete.d.ts.map +1 -0
  13. package/dist/autocomplete.js +96 -0
  14. package/dist/autocomplete.js.map +1 -0
  15. package/dist/cli/commands/connect.d.ts +3 -0
  16. package/dist/cli/commands/connect.d.ts.map +1 -0
  17. package/dist/cli/commands/connect.js +31 -0
  18. package/dist/cli/commands/connect.js.map +1 -0
  19. package/dist/cli/commands/deploy.d.ts +3 -0
  20. package/dist/cli/commands/deploy.d.ts.map +1 -0
  21. package/dist/cli/commands/deploy.js +26 -0
  22. package/dist/cli/commands/deploy.js.map +1 -0
  23. package/dist/cli/commands/login.d.ts +3 -0
  24. package/dist/cli/commands/login.d.ts.map +1 -0
  25. package/dist/cli/commands/login.js +46 -0
  26. package/dist/cli/commands/login.js.map +1 -0
  27. package/dist/cli/commands/vault.d.ts +3 -0
  28. package/dist/cli/commands/vault.d.ts.map +1 -0
  29. package/dist/cli/commands/vault.js +73 -0
  30. package/dist/cli/commands/vault.js.map +1 -0
  31. package/dist/cli/index.d.ts +3 -0
  32. package/dist/cli/index.d.ts.map +1 -0
  33. package/dist/cli/index.js +309 -0
  34. package/dist/cli/index.js.map +1 -0
  35. package/dist/cli/init/setup.d.ts +3 -0
  36. package/dist/cli/init/setup.d.ts.map +1 -0
  37. package/dist/cli/init/setup.js +74 -0
  38. package/dist/cli/init/setup.js.map +1 -0
  39. package/dist/cli/menus.d.ts +2 -0
  40. package/dist/cli/menus.d.ts.map +1 -0
  41. package/dist/cli/menus.js +111 -0
  42. package/dist/cli/menus.js.map +1 -0
  43. package/dist/cli/postinstall.d.ts +9 -0
  44. package/dist/cli/postinstall.d.ts.map +1 -0
  45. package/dist/cli/postinstall.js +81 -0
  46. package/dist/cli/postinstall.js.map +1 -0
  47. package/dist/cli/realtime-input.d.ts +4 -0
  48. package/dist/cli/realtime-input.d.ts.map +1 -0
  49. package/dist/cli/realtime-input.js +268 -0
  50. package/dist/cli/realtime-input.js.map +1 -0
  51. package/dist/cli/setup.d.ts +26 -0
  52. package/dist/cli/setup.d.ts.map +1 -0
  53. package/dist/cli/setup.js +202 -0
  54. package/dist/cli/setup.js.map +1 -0
  55. package/dist/cli/themes.d.ts +30 -0
  56. package/dist/cli/themes.d.ts.map +1 -0
  57. package/dist/cli/themes.js +225 -0
  58. package/dist/cli/themes.js.map +1 -0
  59. package/dist/cli/ui.d.ts +70 -0
  60. package/dist/cli/ui.d.ts.map +1 -0
  61. package/dist/cli/ui.js +455 -0
  62. package/dist/cli/ui.js.map +1 -0
  63. package/dist/commands.d.ts +16 -0
  64. package/dist/commands.d.ts.map +1 -0
  65. package/dist/commands.js +230 -0
  66. package/dist/commands.js.map +1 -0
  67. package/dist/config.d.ts +42 -0
  68. package/dist/config.d.ts.map +1 -0
  69. package/dist/config.js +140 -0
  70. package/dist/config.js.map +1 -0
  71. package/dist/context.d.ts +23 -0
  72. package/dist/context.d.ts.map +1 -0
  73. package/dist/context.js +80 -0
  74. package/dist/context.js.map +1 -0
  75. package/dist/core/agent.d.ts +94 -0
  76. package/dist/core/agent.d.ts.map +1 -0
  77. package/dist/core/agent.js +1280 -0
  78. package/dist/core/agent.js.map +1 -0
  79. package/dist/core/agents/enterprise/backend.d.ts +3 -0
  80. package/dist/core/agents/enterprise/backend.d.ts.map +1 -0
  81. package/dist/core/agents/enterprise/backend.js +35 -0
  82. package/dist/core/agents/enterprise/backend.js.map +1 -0
  83. package/dist/core/agents/enterprise/cloud.d.ts +3 -0
  84. package/dist/core/agents/enterprise/cloud.d.ts.map +1 -0
  85. package/dist/core/agents/enterprise/cloud.js +35 -0
  86. package/dist/core/agents/enterprise/cloud.js.map +1 -0
  87. package/dist/core/agents/enterprise/datascience.d.ts +3 -0
  88. package/dist/core/agents/enterprise/datascience.d.ts.map +1 -0
  89. package/dist/core/agents/enterprise/datascience.js +35 -0
  90. package/dist/core/agents/enterprise/datascience.js.map +1 -0
  91. package/dist/core/agents/enterprise/design.d.ts +3 -0
  92. package/dist/core/agents/enterprise/design.d.ts.map +1 -0
  93. package/dist/core/agents/enterprise/design.js +35 -0
  94. package/dist/core/agents/enterprise/design.js.map +1 -0
  95. package/dist/core/agents/enterprise/devops.d.ts +3 -0
  96. package/dist/core/agents/enterprise/devops.d.ts.map +1 -0
  97. package/dist/core/agents/enterprise/devops.js +35 -0
  98. package/dist/core/agents/enterprise/devops.js.map +1 -0
  99. package/dist/core/agents/enterprise/finance.d.ts +3 -0
  100. package/dist/core/agents/enterprise/finance.d.ts.map +1 -0
  101. package/dist/core/agents/enterprise/finance.js +35 -0
  102. package/dist/core/agents/enterprise/finance.js.map +1 -0
  103. package/dist/core/agents/enterprise/frontend.d.ts +3 -0
  104. package/dist/core/agents/enterprise/frontend.d.ts.map +1 -0
  105. package/dist/core/agents/enterprise/frontend.js +35 -0
  106. package/dist/core/agents/enterprise/frontend.js.map +1 -0
  107. package/dist/core/agents/enterprise/hr.d.ts +3 -0
  108. package/dist/core/agents/enterprise/hr.d.ts.map +1 -0
  109. package/dist/core/agents/enterprise/hr.js +35 -0
  110. package/dist/core/agents/enterprise/hr.js.map +1 -0
  111. package/dist/core/agents/enterprise/index.d.ts +4 -0
  112. package/dist/core/agents/enterprise/index.d.ts.map +1 -0
  113. package/dist/core/agents/enterprise/index.js +44 -0
  114. package/dist/core/agents/enterprise/index.js.map +1 -0
  115. package/dist/core/agents/enterprise/legal.d.ts +3 -0
  116. package/dist/core/agents/enterprise/legal.d.ts.map +1 -0
  117. package/dist/core/agents/enterprise/legal.js +35 -0
  118. package/dist/core/agents/enterprise/legal.js.map +1 -0
  119. package/dist/core/agents/enterprise/marketing.d.ts +3 -0
  120. package/dist/core/agents/enterprise/marketing.d.ts.map +1 -0
  121. package/dist/core/agents/enterprise/marketing.js +35 -0
  122. package/dist/core/agents/enterprise/marketing.js.map +1 -0
  123. package/dist/core/agents/enterprise/pm.d.ts +3 -0
  124. package/dist/core/agents/enterprise/pm.d.ts.map +1 -0
  125. package/dist/core/agents/enterprise/pm.js +35 -0
  126. package/dist/core/agents/enterprise/pm.js.map +1 -0
  127. package/dist/core/agents/enterprise/product.d.ts +3 -0
  128. package/dist/core/agents/enterprise/product.d.ts.map +1 -0
  129. package/dist/core/agents/enterprise/product.js +35 -0
  130. package/dist/core/agents/enterprise/product.js.map +1 -0
  131. package/dist/core/agents/enterprise/qa.d.ts +3 -0
  132. package/dist/core/agents/enterprise/qa.d.ts.map +1 -0
  133. package/dist/core/agents/enterprise/qa.js +35 -0
  134. package/dist/core/agents/enterprise/qa.js.map +1 -0
  135. package/dist/core/agents/enterprise/sales.d.ts +3 -0
  136. package/dist/core/agents/enterprise/sales.d.ts.map +1 -0
  137. package/dist/core/agents/enterprise/sales.js +35 -0
  138. package/dist/core/agents/enterprise/sales.js.map +1 -0
  139. package/dist/core/agents/enterprise/security.d.ts +3 -0
  140. package/dist/core/agents/enterprise/security.d.ts.map +1 -0
  141. package/dist/core/agents/enterprise/security.js +36 -0
  142. package/dist/core/agents/enterprise/security.js.map +1 -0
  143. package/dist/core/agents/enterprise/support.d.ts +3 -0
  144. package/dist/core/agents/enterprise/support.d.ts.map +1 -0
  145. package/dist/core/agents/enterprise/support.js +35 -0
  146. package/dist/core/agents/enterprise/support.js.map +1 -0
  147. package/dist/core/agents.d.ts +84 -0
  148. package/dist/core/agents.d.ts.map +1 -0
  149. package/dist/core/agents.js +266 -0
  150. package/dist/core/agents.js.map +1 -0
  151. package/dist/core/analytics.d.ts +21 -0
  152. package/dist/core/analytics.d.ts.map +1 -0
  153. package/dist/core/analytics.js +57 -0
  154. package/dist/core/analytics.js.map +1 -0
  155. package/dist/core/auth.d.ts +43 -0
  156. package/dist/core/auth.d.ts.map +1 -0
  157. package/dist/core/auth.js +110 -0
  158. package/dist/core/auth.js.map +1 -0
  159. package/dist/core/code_indexer.d.ts +14 -0
  160. package/dist/core/code_indexer.d.ts.map +1 -0
  161. package/dist/core/code_indexer.js +52 -0
  162. package/dist/core/code_indexer.js.map +1 -0
  163. package/dist/core/commands.d.ts +16 -0
  164. package/dist/core/commands.d.ts.map +1 -0
  165. package/dist/core/commands.js +285 -0
  166. package/dist/core/commands.js.map +1 -0
  167. package/dist/core/consensus.d.ts +25 -0
  168. package/dist/core/consensus.d.ts.map +1 -0
  169. package/dist/core/consensus.js +49 -0
  170. package/dist/core/consensus.js.map +1 -0
  171. package/dist/core/context.d.ts +23 -0
  172. package/dist/core/context.d.ts.map +1 -0
  173. package/dist/core/context.js +82 -0
  174. package/dist/core/context.js.map +1 -0
  175. package/dist/core/eden-ai-sdk.d.ts +11 -0
  176. package/dist/core/eden-ai-sdk.d.ts.map +1 -0
  177. package/dist/core/eden-ai-sdk.js +158 -0
  178. package/dist/core/eden-ai-sdk.js.map +1 -0
  179. package/dist/core/events.d.ts +64 -0
  180. package/dist/core/events.d.ts.map +1 -0
  181. package/dist/core/events.js +18 -0
  182. package/dist/core/events.js.map +1 -0
  183. package/dist/core/groq-client.d.ts +7 -0
  184. package/dist/core/groq-client.d.ts.map +1 -0
  185. package/dist/core/groq-client.js +112 -0
  186. package/dist/core/groq-client.js.map +1 -0
  187. package/dist/core/mcp.d.ts +51 -0
  188. package/dist/core/mcp.d.ts.map +1 -0
  189. package/dist/core/mcp.js +201 -0
  190. package/dist/core/mcp.js.map +1 -0
  191. package/dist/core/memory.d.ts +20 -0
  192. package/dist/core/memory.d.ts.map +1 -0
  193. package/dist/core/memory.js +61 -0
  194. package/dist/core/memory.js.map +1 -0
  195. package/dist/core/model-profiles.d.ts +62 -0
  196. package/dist/core/model-profiles.d.ts.map +1 -0
  197. package/dist/core/model-profiles.js +841 -0
  198. package/dist/core/model-profiles.js.map +1 -0
  199. package/dist/core/moonshot-client.d.ts +7 -0
  200. package/dist/core/moonshot-client.d.ts.map +1 -0
  201. package/dist/core/moonshot-client.js +102 -0
  202. package/dist/core/moonshot-client.js.map +1 -0
  203. package/dist/core/nexus.d.ts +16 -0
  204. package/dist/core/nexus.d.ts.map +1 -0
  205. package/dist/core/nexus.js +31 -0
  206. package/dist/core/nexus.js.map +1 -0
  207. package/dist/core/notifications.d.ts +16 -0
  208. package/dist/core/notifications.d.ts.map +1 -0
  209. package/dist/core/notifications.js +26 -0
  210. package/dist/core/notifications.js.map +1 -0
  211. package/dist/core/ollama-client.d.ts +16 -0
  212. package/dist/core/ollama-client.d.ts.map +1 -0
  213. package/dist/core/ollama-client.js +138 -0
  214. package/dist/core/ollama-client.js.map +1 -0
  215. package/dist/core/orchestrator.d.ts +96 -0
  216. package/dist/core/orchestrator.d.ts.map +1 -0
  217. package/dist/core/orchestrator.js +801 -0
  218. package/dist/core/orchestrator.js.map +1 -0
  219. package/dist/core/permissions.d.ts +34 -0
  220. package/dist/core/permissions.d.ts.map +1 -0
  221. package/dist/core/permissions.js +224 -0
  222. package/dist/core/permissions.js.map +1 -0
  223. package/dist/core/providers.d.ts +22 -0
  224. package/dist/core/providers.d.ts.map +1 -0
  225. package/dist/core/providers.js +81 -0
  226. package/dist/core/providers.js.map +1 -0
  227. package/dist/core/researcher.d.ts +24 -0
  228. package/dist/core/researcher.d.ts.map +1 -0
  229. package/dist/core/researcher.js +97 -0
  230. package/dist/core/researcher.js.map +1 -0
  231. package/dist/core/sandbox.d.ts +22 -0
  232. package/dist/core/sandbox.d.ts.map +1 -0
  233. package/dist/core/sandbox.js +79 -0
  234. package/dist/core/sandbox.js.map +1 -0
  235. package/dist/core/scavenger.d.ts +5 -0
  236. package/dist/core/scavenger.d.ts.map +1 -0
  237. package/dist/core/scavenger.js +51 -0
  238. package/dist/core/scavenger.js.map +1 -0
  239. package/dist/core/server.d.ts +21 -0
  240. package/dist/core/server.d.ts.map +1 -0
  241. package/dist/core/server.js +776 -0
  242. package/dist/core/server.js.map +1 -0
  243. package/dist/core/sessions.d.ts +54 -0
  244. package/dist/core/sessions.d.ts.map +1 -0
  245. package/dist/core/sessions.js +182 -0
  246. package/dist/core/sessions.js.map +1 -0
  247. package/dist/core/setup.d.ts +12 -0
  248. package/dist/core/setup.d.ts.map +1 -0
  249. package/dist/core/setup.js +70 -0
  250. package/dist/core/setup.js.map +1 -0
  251. package/dist/core/skills.d.ts +17 -0
  252. package/dist/core/skills.d.ts.map +1 -0
  253. package/dist/core/skills.js +123 -0
  254. package/dist/core/skills.js.map +1 -0
  255. package/dist/core/stats.d.ts +54 -0
  256. package/dist/core/stats.d.ts.map +1 -0
  257. package/dist/core/stats.js +221 -0
  258. package/dist/core/stats.js.map +1 -0
  259. package/dist/core/swarm_manager.d.ts +20 -0
  260. package/dist/core/swarm_manager.d.ts.map +1 -0
  261. package/dist/core/swarm_manager.js +48 -0
  262. package/dist/core/swarm_manager.js.map +1 -0
  263. package/dist/core/system.d.ts +39 -0
  264. package/dist/core/system.d.ts.map +1 -0
  265. package/dist/core/system.js +129 -0
  266. package/dist/core/system.js.map +1 -0
  267. package/dist/core/tasks.d.ts +24 -0
  268. package/dist/core/tasks.d.ts.map +1 -0
  269. package/dist/core/tasks.js +66 -0
  270. package/dist/core/tasks.js.map +1 -0
  271. package/dist/core/telegram.d.ts +9 -0
  272. package/dist/core/telegram.d.ts.map +1 -0
  273. package/dist/core/telegram.js +49 -0
  274. package/dist/core/telegram.js.map +1 -0
  275. package/dist/core/tools/acquire_skill.d.ts +3 -0
  276. package/dist/core/tools/acquire_skill.d.ts.map +1 -0
  277. package/dist/core/tools/acquire_skill.js +30 -0
  278. package/dist/core/tools/acquire_skill.js.map +1 -0
  279. package/dist/core/tools/agent_tools.d.ts +4 -0
  280. package/dist/core/tools/agent_tools.d.ts.map +1 -0
  281. package/dist/core/tools/agent_tools.js +117 -0
  282. package/dist/core/tools/agent_tools.js.map +1 -0
  283. package/dist/core/tools/code_search.d.ts +3 -0
  284. package/dist/core/tools/code_search.d.ts.map +1 -0
  285. package/dist/core/tools/code_search.js +43 -0
  286. package/dist/core/tools/code_search.js.map +1 -0
  287. package/dist/core/tools/craft_tool.d.ts +3 -0
  288. package/dist/core/tools/craft_tool.d.ts.map +1 -0
  289. package/dist/core/tools/craft_tool.js +32 -0
  290. package/dist/core/tools/craft_tool.js.map +1 -0
  291. package/dist/core/tools/discord.d.ts +3 -0
  292. package/dist/core/tools/discord.d.ts.map +1 -0
  293. package/dist/core/tools/discord.js +206 -0
  294. package/dist/core/tools/discord.js.map +1 -0
  295. package/dist/core/tools/dynamic/registry.d.ts +15 -0
  296. package/dist/core/tools/dynamic/registry.d.ts.map +1 -0
  297. package/dist/core/tools/dynamic/registry.js +59 -0
  298. package/dist/core/tools/dynamic/registry.js.map +1 -0
  299. package/dist/core/tools/github.d.ts +3 -0
  300. package/dist/core/tools/github.d.ts.map +1 -0
  301. package/dist/core/tools/github.js +357 -0
  302. package/dist/core/tools/github.js.map +1 -0
  303. package/dist/core/tools/google.d.ts +3 -0
  304. package/dist/core/tools/google.d.ts.map +1 -0
  305. package/dist/core/tools/google.js +409 -0
  306. package/dist/core/tools/google.js.map +1 -0
  307. package/dist/core/tools/index.d.ts +4 -0
  308. package/dist/core/tools/index.d.ts.map +1 -0
  309. package/dist/core/tools/index.js +2338 -0
  310. package/dist/core/tools/index.js.map +1 -0
  311. package/dist/core/tools/optimize_prompt.d.ts +3 -0
  312. package/dist/core/tools/optimize_prompt.d.ts.map +1 -0
  313. package/dist/core/tools/optimize_prompt.js +43 -0
  314. package/dist/core/tools/optimize_prompt.js.map +1 -0
  315. package/dist/core/tools/predict_healing.d.ts +3 -0
  316. package/dist/core/tools/predict_healing.d.ts.map +1 -0
  317. package/dist/core/tools/predict_healing.js +34 -0
  318. package/dist/core/tools/predict_healing.js.map +1 -0
  319. package/dist/core/tools/sage_memory.d.ts +3 -0
  320. package/dist/core/tools/sage_memory.d.ts.map +1 -0
  321. package/dist/core/tools/sage_memory.js +29 -0
  322. package/dist/core/tools/sage_memory.js.map +1 -0
  323. package/dist/core/tools/self_heal.d.ts +3 -0
  324. package/dist/core/tools/self_heal.d.ts.map +1 -0
  325. package/dist/core/tools/self_heal.js +46 -0
  326. package/dist/core/tools/self_heal.js.map +1 -0
  327. package/dist/core/tools/send_briefing.d.ts +3 -0
  328. package/dist/core/tools/send_briefing.d.ts.map +1 -0
  329. package/dist/core/tools/send_briefing.js +31 -0
  330. package/dist/core/tools/send_briefing.js.map +1 -0
  331. package/dist/core/tools/slack.d.ts +3 -0
  332. package/dist/core/tools/slack.d.ts.map +1 -0
  333. package/dist/core/tools/slack.js +256 -0
  334. package/dist/core/tools/slack.js.map +1 -0
  335. package/dist/core/tools/telegram.d.ts +3 -0
  336. package/dist/core/tools/telegram.d.ts.map +1 -0
  337. package/dist/core/tools/telegram.js +211 -0
  338. package/dist/core/tools/telegram.js.map +1 -0
  339. package/dist/core/tools/vox.d.ts +3 -0
  340. package/dist/core/tools/vox.d.ts.map +1 -0
  341. package/dist/core/tools/vox.js +29 -0
  342. package/dist/core/tools/vox.js.map +1 -0
  343. package/dist/core/types/index.d.ts +164 -0
  344. package/dist/core/types/index.d.ts.map +1 -0
  345. package/dist/core/types/index.js +3 -0
  346. package/dist/core/types/index.js.map +1 -0
  347. package/dist/core/vault.d.ts +20 -0
  348. package/dist/core/vault.d.ts.map +1 -0
  349. package/dist/core/vault.js +91 -0
  350. package/dist/core/vault.js.map +1 -0
  351. package/dist/core/verify_v3.d.ts +2 -0
  352. package/dist/core/verify_v3.d.ts.map +1 -0
  353. package/dist/core/verify_v3.js +38 -0
  354. package/dist/core/verify_v3.js.map +1 -0
  355. package/dist/core/verify_v3_5.d.ts +2 -0
  356. package/dist/core/verify_v3_5.d.ts.map +1 -0
  357. package/dist/core/verify_v3_5.js +56 -0
  358. package/dist/core/verify_v3_5.js.map +1 -0
  359. package/dist/core/verify_v4.d.ts +2 -0
  360. package/dist/core/verify_v4.d.ts.map +1 -0
  361. package/dist/core/verify_v4.js +42 -0
  362. package/dist/core/verify_v4.js.map +1 -0
  363. package/dist/core/verify_v5.d.ts +2 -0
  364. package/dist/core/verify_v5.d.ts.map +1 -0
  365. package/dist/core/verify_v5.js +53 -0
  366. package/dist/core/verify_v5.js.map +1 -0
  367. package/dist/core/verify_v6.d.ts +2 -0
  368. package/dist/core/verify_v6.d.ts.map +1 -0
  369. package/dist/core/verify_v6.js +42 -0
  370. package/dist/core/verify_v6.js.map +1 -0
  371. package/dist/core/verify_v7.d.ts +2 -0
  372. package/dist/core/verify_v7.d.ts.map +1 -0
  373. package/dist/core/verify_v7.js +29 -0
  374. package/dist/core/verify_v7.js.map +1 -0
  375. package/dist/core/verify_v8.d.ts +2 -0
  376. package/dist/core/verify_v8.d.ts.map +1 -0
  377. package/dist/core/verify_v8.js +32 -0
  378. package/dist/core/verify_v8.js.map +1 -0
  379. package/dist/core/workflows.d.ts +24 -0
  380. package/dist/core/workflows.d.ts.map +1 -0
  381. package/dist/core/workflows.js +47 -0
  382. package/dist/core/workflows.js.map +1 -0
  383. package/dist/core/workspaces.d.ts +13 -0
  384. package/dist/core/workspaces.d.ts.map +1 -0
  385. package/dist/core/workspaces.js +45 -0
  386. package/dist/core/workspaces.js.map +1 -0
  387. package/dist/enquirer-input.d.ts +3 -0
  388. package/dist/enquirer-input.d.ts.map +1 -0
  389. package/dist/enquirer-input.js +112 -0
  390. package/dist/enquirer-input.js.map +1 -0
  391. package/dist/index.d.ts +3 -0
  392. package/dist/index.d.ts.map +1 -0
  393. package/dist/index.js +241 -0
  394. package/dist/index.js.map +1 -0
  395. package/dist/mcp.d.ts +51 -0
  396. package/dist/mcp.d.ts.map +1 -0
  397. package/dist/mcp.js +201 -0
  398. package/dist/mcp.js.map +1 -0
  399. package/dist/ollama-client.d.ts +15 -0
  400. package/dist/ollama-client.d.ts.map +1 -0
  401. package/dist/ollama-client.js +95 -0
  402. package/dist/ollama-client.js.map +1 -0
  403. package/dist/permissions.d.ts +34 -0
  404. package/dist/permissions.d.ts.map +1 -0
  405. package/dist/permissions.js +224 -0
  406. package/dist/permissions.js.map +1 -0
  407. package/dist/realtime-input.d.ts +2 -0
  408. package/dist/realtime-input.d.ts.map +1 -0
  409. package/dist/realtime-input.js +308 -0
  410. package/dist/realtime-input.js.map +1 -0
  411. package/dist/server.d.ts +20 -0
  412. package/dist/server.d.ts.map +1 -0
  413. package/dist/server.js +203 -0
  414. package/dist/server.js.map +1 -0
  415. package/dist/sessions.d.ts +50 -0
  416. package/dist/sessions.d.ts.map +1 -0
  417. package/dist/sessions.js +181 -0
  418. package/dist/sessions.js.map +1 -0
  419. package/dist/simple-input.d.ts +2 -0
  420. package/dist/simple-input.d.ts.map +1 -0
  421. package/dist/simple-input.js +83 -0
  422. package/dist/simple-input.js.map +1 -0
  423. package/dist/skills.d.ts +17 -0
  424. package/dist/skills.d.ts.map +1 -0
  425. package/dist/skills.js +194 -0
  426. package/dist/skills.js.map +1 -0
  427. package/dist/stats.d.ts +54 -0
  428. package/dist/stats.d.ts.map +1 -0
  429. package/dist/stats.js +220 -0
  430. package/dist/stats.js.map +1 -0
  431. package/dist/tools/discord.d.ts +3 -0
  432. package/dist/tools/discord.d.ts.map +1 -0
  433. package/dist/tools/discord.js +206 -0
  434. package/dist/tools/discord.js.map +1 -0
  435. package/dist/tools/github.d.ts +3 -0
  436. package/dist/tools/github.d.ts.map +1 -0
  437. package/dist/tools/github.js +357 -0
  438. package/dist/tools/github.js.map +1 -0
  439. package/dist/tools/google.d.ts +3 -0
  440. package/dist/tools/google.d.ts.map +1 -0
  441. package/dist/tools/google.js +409 -0
  442. package/dist/tools/google.js.map +1 -0
  443. package/dist/tools/index.d.ts +4 -0
  444. package/dist/tools/index.d.ts.map +1 -0
  445. package/dist/tools/index.js +2139 -0
  446. package/dist/tools/index.js.map +1 -0
  447. package/dist/tools/slack.d.ts +3 -0
  448. package/dist/tools/slack.d.ts.map +1 -0
  449. package/dist/tools/slack.js +256 -0
  450. package/dist/tools/slack.js.map +1 -0
  451. package/dist/tools/telegram.d.ts +3 -0
  452. package/dist/tools/telegram.d.ts.map +1 -0
  453. package/dist/tools/telegram.js +211 -0
  454. package/dist/tools/telegram.js.map +1 -0
  455. package/dist/types/index.d.ts +152 -0
  456. package/dist/types/index.d.ts.map +1 -0
  457. package/dist/types/index.js +3 -0
  458. package/dist/types/index.js.map +1 -0
  459. package/dist/ui.d.ts +101 -0
  460. package/dist/ui.d.ts.map +1 -0
  461. package/dist/ui.js +317 -0
  462. package/dist/ui.js.map +1 -0
  463. package/dist/web/src/lib/utils.d.ts +3 -0
  464. package/dist/web/src/lib/utils.d.ts.map +1 -0
  465. package/dist/web/src/lib/utils.js +6 -0
  466. package/dist/web/src/lib/utils.js.map +1 -0
  467. package/dist/web/src/main.d.ts +2 -0
  468. package/dist/web/src/main.d.ts.map +1 -0
  469. package/dist/web/src/main.js +5 -0
  470. package/dist/web/src/main.js.map +1 -0
  471. package/dist/web/vite.config.d.ts +3 -0
  472. package/dist/web/vite.config.d.ts.map +1 -0
  473. package/dist/web/vite.config.js +12 -0
  474. package/dist/web/vite.config.js.map +1 -0
  475. package/package.json +83 -0
package/dist/mcp.d.ts ADDED
@@ -0,0 +1,51 @@
1
+ import type { ToolRegistryEntry } from './types/index.js';
2
+ export interface MCPServerConfig {
3
+ name: string;
4
+ type: 'stdio' | 'sse';
5
+ command?: string;
6
+ args?: string[];
7
+ env?: Record<string, string>;
8
+ url?: string;
9
+ headers?: Record<string, string>;
10
+ oauth?: {
11
+ clientId: string;
12
+ authorizationUrl: string;
13
+ tokenUrl: string;
14
+ scopes?: string[];
15
+ };
16
+ enabled: boolean;
17
+ }
18
+ export interface MCPConnection {
19
+ name: string;
20
+ status: 'connected' | 'disconnected' | 'error';
21
+ tools: string[];
22
+ error?: string;
23
+ }
24
+ export declare class MCPManager {
25
+ private servers;
26
+ private connections;
27
+ private authTokens;
28
+ constructor();
29
+ private loadConfig;
30
+ private saveConfig;
31
+ private loadAuth;
32
+ private saveAuth;
33
+ addServer(config: MCPServerConfig): Promise<boolean>;
34
+ removeServer(name: string): Promise<boolean>;
35
+ listServers(): MCPServerConfig[];
36
+ getServer(name: string): MCPServerConfig | undefined;
37
+ connect(name: string): Promise<MCPConnection | null>;
38
+ disconnect(name: string): Promise<boolean>;
39
+ getConnection(name: string): MCPConnection | undefined;
40
+ listConnections(): MCPConnection[];
41
+ authenticate(name: string): Promise<boolean>;
42
+ logout(name: string): Promise<boolean>;
43
+ getAuthStatus(name: string): {
44
+ authenticated: boolean;
45
+ hasOAuth: boolean;
46
+ };
47
+ getMCPTools(): Promise<ToolRegistryEntry[]>;
48
+ setupWizard(): Promise<void>;
49
+ }
50
+ export declare const mcpManager: MCPManager;
51
+ //# sourceMappingURL=mcp.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"mcp.d.ts","sourceRoot":"","sources":["../src/mcp.ts"],"names":[],"mappings":"AAMA,OAAO,KAAK,EAAE,iBAAiB,EAAc,MAAM,kBAAkB,CAAC;AAEtE,MAAM,WAAW,eAAe;IAC9B,IAAI,EAAE,MAAM,CAAC;IACb,IAAI,EAAE,OAAO,GAAG,KAAK,CAAC;IACtB,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,IAAI,CAAC,EAAE,MAAM,EAAE,CAAC;IAChB,GAAG,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;IAC7B,GAAG,CAAC,EAAE,MAAM,CAAC;IACb,OAAO,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;IACjC,KAAK,CAAC,EAAE;QACN,QAAQ,EAAE,MAAM,CAAC;QACjB,gBAAgB,EAAE,MAAM,CAAC;QACzB,QAAQ,EAAE,MAAM,CAAC;QACjB,MAAM,CAAC,EAAE,MAAM,EAAE,CAAC;KACnB,CAAC;IACF,OAAO,EAAE,OAAO,CAAC;CAClB;AAED,MAAM,WAAW,aAAa;IAC5B,IAAI,EAAE,MAAM,CAAC;IACb,MAAM,EAAE,WAAW,GAAG,cAAc,GAAG,OAAO,CAAC;IAC/C,KAAK,EAAE,MAAM,EAAE,CAAC;IAChB,KAAK,CAAC,EAAE,MAAM,CAAC;CAChB;AAKD,qBAAa,UAAU;IACrB,OAAO,CAAC,OAAO,CAA2C;IAC1D,OAAO,CAAC,WAAW,CAAyC;IAC5D,OAAO,CAAC,UAAU,CAAkC;;YAOtC,UAAU;YAYV,UAAU;YAUV,QAAQ;YAYR,QAAQ;IAahB,SAAS,CAAC,MAAM,EAAE,eAAe,GAAG,OAAO,CAAC,OAAO,CAAC;IAgBpD,YAAY,CAAC,IAAI,EAAE,MAAM,GAAG,OAAO,CAAC,OAAO,CAAC;IAYlD,WAAW,IAAI,eAAe,EAAE;IAIhC,SAAS,CAAC,IAAI,EAAE,MAAM,GAAG,eAAe,GAAG,SAAS;IAI9C,OAAO,CAAC,IAAI,EAAE,MAAM,GAAG,OAAO,CAAC,aAAa,GAAG,IAAI,CAAC;IAiBpD,UAAU,CAAC,IAAI,EAAE,MAAM,GAAG,OAAO,CAAC,OAAO,CAAC;IAQhD,aAAa,CAAC,IAAI,EAAE,MAAM,GAAG,aAAa,GAAG,SAAS;IAItD,eAAe,IAAI,aAAa,EAAE;IAI5B,YAAY,CAAC,IAAI,EAAE,MAAM,GAAG,OAAO,CAAC,OAAO,CAAC;IAoB5C,MAAM,CAAC,IAAI,EAAE,MAAM,GAAG,OAAO,CAAC,OAAO,CAAC;IAS5C,aAAa,CAAC,IAAI,EAAE,MAAM,GAAG;QAAE,aAAa,EAAE,OAAO,CAAC;QAAC,QAAQ,EAAE,OAAO,CAAA;KAAE;IASpE,WAAW,IAAI,OAAO,CAAC,iBAAiB,EAAE,CAAC;IAuC3C,WAAW,IAAI,OAAO,CAAC,IAAI,CAAC;CASnC;AAGD,eAAO,MAAM,UAAU,YAAmB,CAAC"}
package/dist/mcp.js ADDED
@@ -0,0 +1,201 @@
1
+ // MCP (Model Context Protocol) Server Support for Atena CLI
2
+ // Inspired by Opencode's MCP integration
3
+ import { promises as fs } from 'node:fs';
4
+ import path from 'node:path';
5
+ import { homedir } from 'node:os';
6
+ const MCP_CONFIG_FILE = path.join(homedir(), '.atena', 'mcp-servers.json');
7
+ const MCP_AUTH_FILE = path.join(homedir(), '.atena', 'mcp-auth.json');
8
+ export class MCPManager {
9
+ servers = new Map();
10
+ connections = new Map();
11
+ authTokens = new Map();
12
+ constructor() {
13
+ this.loadConfig();
14
+ this.loadAuth();
15
+ }
16
+ async loadConfig() {
17
+ try {
18
+ const content = await fs.readFile(MCP_CONFIG_FILE, 'utf8');
19
+ const configs = JSON.parse(content);
20
+ for (const config of configs) {
21
+ this.servers.set(config.name, config);
22
+ }
23
+ }
24
+ catch {
25
+ // No config file yet
26
+ }
27
+ }
28
+ async saveConfig() {
29
+ try {
30
+ const configs = Array.from(this.servers.values());
31
+ await fs.mkdir(path.dirname(MCP_CONFIG_FILE), { recursive: true });
32
+ await fs.writeFile(MCP_CONFIG_FILE, JSON.stringify(configs, null, 2), 'utf8');
33
+ }
34
+ catch {
35
+ // Silently fail
36
+ }
37
+ }
38
+ async loadAuth() {
39
+ try {
40
+ const content = await fs.readFile(MCP_AUTH_FILE, 'utf8');
41
+ const tokens = JSON.parse(content);
42
+ for (const [name, token] of Object.entries(tokens)) {
43
+ this.authTokens.set(name, token);
44
+ }
45
+ }
46
+ catch {
47
+ // No auth file yet
48
+ }
49
+ }
50
+ async saveAuth() {
51
+ try {
52
+ const tokens = {};
53
+ for (const [name, token] of this.authTokens) {
54
+ tokens[name] = token;
55
+ }
56
+ await fs.mkdir(path.dirname(MCP_AUTH_FILE), { recursive: true });
57
+ await fs.writeFile(MCP_AUTH_FILE, JSON.stringify(tokens, null, 2), 'utf8');
58
+ }
59
+ catch {
60
+ // Silently fail
61
+ }
62
+ }
63
+ async addServer(config) {
64
+ // Validate config
65
+ if (config.type === 'stdio' && !config.command) {
66
+ console.log('Error: stdio servers require a command');
67
+ return false;
68
+ }
69
+ if (config.type === 'sse' && !config.url) {
70
+ console.log('Error: SSE servers require a URL');
71
+ return false;
72
+ }
73
+ this.servers.set(config.name, config);
74
+ await this.saveConfig();
75
+ return true;
76
+ }
77
+ async removeServer(name) {
78
+ if (!this.servers.has(name)) {
79
+ return false;
80
+ }
81
+ this.servers.delete(name);
82
+ this.connections.delete(name);
83
+ this.authTokens.delete(name);
84
+ await this.saveConfig();
85
+ await this.saveAuth();
86
+ return true;
87
+ }
88
+ listServers() {
89
+ return Array.from(this.servers.values());
90
+ }
91
+ getServer(name) {
92
+ return this.servers.get(name);
93
+ }
94
+ async connect(name) {
95
+ const config = this.servers.get(name);
96
+ if (!config) {
97
+ return null;
98
+ }
99
+ // Simulate connection (real implementation would spawn process or connect to SSE)
100
+ const connection = {
101
+ name,
102
+ status: 'connected',
103
+ tools: [`${name}_tool1`, `${name}_tool2`], // Placeholder
104
+ };
105
+ this.connections.set(name, connection);
106
+ return connection;
107
+ }
108
+ async disconnect(name) {
109
+ if (!this.connections.has(name)) {
110
+ return false;
111
+ }
112
+ this.connections.delete(name);
113
+ return true;
114
+ }
115
+ getConnection(name) {
116
+ return this.connections.get(name);
117
+ }
118
+ listConnections() {
119
+ return Array.from(this.connections.values());
120
+ }
121
+ async authenticate(name) {
122
+ const config = this.servers.get(name);
123
+ if (!config || !config.oauth) {
124
+ return false;
125
+ }
126
+ // In a real implementation, this would open a browser for OAuth
127
+ // For now, we simulate the flow
128
+ console.log(`Starting OAuth flow for ${name}...`);
129
+ console.log(`Authorization URL: ${config.oauth.authorizationUrl}`);
130
+ console.log(`Scopes: ${config.oauth.scopes?.join(', ') || 'none'}`);
131
+ // Simulate getting a token
132
+ const mockToken = `mock_token_${Date.now()}`;
133
+ this.authTokens.set(name, mockToken);
134
+ await this.saveAuth();
135
+ return true;
136
+ }
137
+ async logout(name) {
138
+ if (!this.authTokens.has(name)) {
139
+ return false;
140
+ }
141
+ this.authTokens.delete(name);
142
+ await this.saveAuth();
143
+ return true;
144
+ }
145
+ getAuthStatus(name) {
146
+ const config = this.servers.get(name);
147
+ return {
148
+ authenticated: this.authTokens.has(name),
149
+ hasOAuth: !!config?.oauth,
150
+ };
151
+ }
152
+ // Get all tools from connected MCP servers
153
+ async getMCPTools() {
154
+ const tools = [];
155
+ for (const connection of this.connections.values()) {
156
+ if (connection.status === 'connected') {
157
+ // In real implementation, this would discover tools from the MCP server
158
+ // For now, we create placeholder tool wrappers
159
+ for (const toolName of connection.tools) {
160
+ tools.push({
161
+ definition: {
162
+ name: `mcp_${toolName}`,
163
+ description: `MCP tool: ${toolName}`,
164
+ parameters: {
165
+ type: 'object',
166
+ properties: {
167
+ input: {
168
+ type: 'string',
169
+ description: 'Tool input',
170
+ },
171
+ },
172
+ required: ['input'],
173
+ },
174
+ },
175
+ handler: async (args) => {
176
+ // In real implementation, this would call the MCP server
177
+ return {
178
+ status: 'success',
179
+ output: `MCP tool ${toolName} executed with: ${args.input}`,
180
+ };
181
+ },
182
+ });
183
+ }
184
+ }
185
+ }
186
+ return tools;
187
+ }
188
+ // Interactive setup wizard
189
+ async setupWizard() {
190
+ console.log('\n📦 MCP Server Setup');
191
+ console.log('==================\n');
192
+ console.log('Select server type:');
193
+ console.log('1. stdio (local command)');
194
+ console.log('2. sse (HTTP server)');
195
+ console.log('\nThis is a placeholder. In the full implementation,');
196
+ console.log('this would guide you through setting up an MCP server.');
197
+ }
198
+ }
199
+ // Singleton instance
200
+ export const mcpManager = new MCPManager();
201
+ //# sourceMappingURL=mcp.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"mcp.js","sourceRoot":"","sources":["../src/mcp.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,15 @@
1
+ import type { OllamaChatRequest, OllamaChatResponse, OllamaListResponse, OllamaTool } from './types/index.js';
2
+ export declare class OllamaClient {
3
+ private baseUrl;
4
+ constructor(baseUrl?: string);
5
+ chat(request: OllamaChatRequest): Promise<OllamaChatResponse>;
6
+ chatStream(request: OllamaChatRequest): AsyncGenerator<OllamaChatResponse, void, unknown>;
7
+ listModels(): Promise<OllamaListResponse>;
8
+ pullModel(model: string): Promise<void>;
9
+ toOllamaTools(tools: Array<{
10
+ name: string;
11
+ description: string;
12
+ parameters: unknown;
13
+ }>): OllamaTool[];
14
+ }
15
+ //# sourceMappingURL=ollama-client.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ollama-client.d.ts","sourceRoot":"","sources":["../src/ollama-client.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,iBAAiB,EAAE,kBAAkB,EAAE,kBAAkB,EAAE,UAAU,EAAiB,MAAM,kBAAkB,CAAC;AAE7H,qBAAa,YAAY;IACvB,OAAO,CAAC,OAAO,CAAS;gBAEZ,OAAO,GAAE,MAAiC;IAIhD,IAAI,CAAC,OAAO,EAAE,iBAAiB,GAAG,OAAO,CAAC,kBAAkB,CAAC;IAiB5D,UAAU,CAAC,OAAO,EAAE,iBAAiB,GAAG,cAAc,CAAC,kBAAkB,EAAE,IAAI,EAAE,OAAO,CAAC;IA+C1F,UAAU,IAAI,OAAO,CAAC,kBAAkB,CAAC;IASzC,SAAS,CAAC,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAe7C,aAAa,CAAC,KAAK,EAAE,KAAK,CAAC;QAAE,IAAI,EAAE,MAAM,CAAC;QAAC,WAAW,EAAE,MAAM,CAAC;QAAC,UAAU,EAAE,OAAO,CAAA;KAAE,CAAC,GAAG,UAAU,EAAE;CAUtG"}
@@ -0,0 +1,95 @@
1
+ export class OllamaClient {
2
+ baseUrl;
3
+ constructor(baseUrl = 'http://localhost:11434') {
4
+ this.baseUrl = baseUrl.replace(/\/$/, '');
5
+ }
6
+ async chat(request) {
7
+ const response = await fetch(`${this.baseUrl}/api/chat`, {
8
+ method: 'POST',
9
+ headers: {
10
+ 'Content-Type': 'application/json',
11
+ },
12
+ body: JSON.stringify(request),
13
+ });
14
+ if (!response.ok) {
15
+ const error = await response.text();
16
+ throw new Error(`Ollama API error: ${response.status} ${error}`);
17
+ }
18
+ return response.json();
19
+ }
20
+ async *chatStream(request) {
21
+ const response = await fetch(`${this.baseUrl}/api/chat`, {
22
+ method: 'POST',
23
+ headers: {
24
+ 'Content-Type': 'application/json',
25
+ },
26
+ body: JSON.stringify({ ...request, stream: true }),
27
+ });
28
+ if (!response.ok) {
29
+ const error = await response.text();
30
+ throw new Error(`Ollama API error: ${response.status} ${error}`);
31
+ }
32
+ const reader = response.body?.getReader();
33
+ if (!reader) {
34
+ throw new Error('No response body');
35
+ }
36
+ const decoder = new TextDecoder();
37
+ let buffer = '';
38
+ try {
39
+ while (true) {
40
+ const { done, value } = await reader.read();
41
+ if (done)
42
+ break;
43
+ buffer += decoder.decode(value, { stream: true });
44
+ const lines = buffer.split('\n');
45
+ buffer = lines.pop() || '';
46
+ for (const line of lines) {
47
+ if (line.trim()) {
48
+ try {
49
+ const parsed = JSON.parse(line);
50
+ yield parsed;
51
+ }
52
+ catch {
53
+ // Skip invalid JSON lines
54
+ }
55
+ }
56
+ }
57
+ }
58
+ }
59
+ finally {
60
+ reader.releaseLock();
61
+ }
62
+ }
63
+ async listModels() {
64
+ const response = await fetch(`${this.baseUrl}/api/tags`);
65
+ if (!response.ok) {
66
+ const error = await response.text();
67
+ throw new Error(`Ollama API error: ${response.status} ${error}`);
68
+ }
69
+ return response.json();
70
+ }
71
+ async pullModel(model) {
72
+ const response = await fetch(`${this.baseUrl}/api/pull`, {
73
+ method: 'POST',
74
+ headers: {
75
+ 'Content-Type': 'application/json',
76
+ },
77
+ body: JSON.stringify({ name: model }),
78
+ });
79
+ if (!response.ok) {
80
+ const error = await response.text();
81
+ throw new Error(`Failed to pull model: ${response.status} ${error}`);
82
+ }
83
+ }
84
+ toOllamaTools(tools) {
85
+ return tools.map(tool => ({
86
+ type: 'function',
87
+ function: {
88
+ name: tool.name,
89
+ description: tool.description,
90
+ parameters: tool.parameters,
91
+ },
92
+ }));
93
+ }
94
+ }
95
+ //# sourceMappingURL=ollama-client.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ollama-client.js","sourceRoot":"","sources":["../src/ollama-client.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,34 @@
1
+ export type PermissionLevel = 'ask' | 'auto' | 'deny';
2
+ export interface Permissions {
3
+ fileWrite: PermissionLevel;
4
+ fileDelete: PermissionLevel;
5
+ bash: PermissionLevel;
6
+ network: PermissionLevel;
7
+ }
8
+ export interface PermissionRequest {
9
+ type: keyof Permissions;
10
+ tool: string;
11
+ description: string;
12
+ details?: string;
13
+ dangerous?: boolean;
14
+ }
15
+ export interface PermissionResult {
16
+ allowed: boolean;
17
+ remember: boolean;
18
+ }
19
+ export declare class PermissionManager {
20
+ private permissions;
21
+ private remembered;
22
+ private rl;
23
+ constructor(permissions?: Partial<Permissions>);
24
+ setPermissions(permissions: Partial<Permissions>): void;
25
+ getPermissions(): Permissions;
26
+ private isDangerous;
27
+ private isSafeCommand;
28
+ private askUser;
29
+ checkPermission(request: PermissionRequest): Promise<boolean>;
30
+ close(): void;
31
+ static parsePermissionLevel(level: string): PermissionLevel;
32
+ }
33
+ export declare function parsePermissionsFromEnv(): Partial<Permissions>;
34
+ //# sourceMappingURL=permissions.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"permissions.d.ts","sourceRoot":"","sources":["../src/permissions.ts"],"names":[],"mappings":"AAMA,MAAM,MAAM,eAAe,GAAG,KAAK,GAAG,MAAM,GAAG,MAAM,CAAC;AAEtD,MAAM,WAAW,WAAW;IAC1B,SAAS,EAAE,eAAe,CAAC;IAC3B,UAAU,EAAE,eAAe,CAAC;IAC5B,IAAI,EAAE,eAAe,CAAC;IACtB,OAAO,EAAE,eAAe,CAAC;CAC1B;AAED,MAAM,WAAW,iBAAiB;IAChC,IAAI,EAAE,MAAM,WAAW,CAAC;IACxB,IAAI,EAAE,MAAM,CAAC;IACb,WAAW,EAAE,MAAM,CAAC;IACpB,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,SAAS,CAAC,EAAE,OAAO,CAAC;CACrB;AAED,MAAM,WAAW,gBAAgB;IAC/B,OAAO,EAAE,OAAO,CAAC;IACjB,QAAQ,EAAE,OAAO,CAAC;CACnB;AAqBD,qBAAa,iBAAiB;IAC5B,OAAO,CAAC,WAAW,CAAc;IACjC,OAAO,CAAC,UAAU,CAAmC;IACrD,OAAO,CAAC,EAAE,CAAmC;gBAEjC,WAAW,CAAC,EAAE,OAAO,CAAC,WAAW,CAAC;IAU9C,cAAc,CAAC,WAAW,EAAE,OAAO,CAAC,WAAW,CAAC,GAAG,IAAI;IAIvD,cAAc,IAAI,WAAW;IAI7B,OAAO,CAAC,WAAW;IA0BnB,OAAO,CAAC,aAAa;YAsBP,OAAO;IA4Ff,eAAe,CAAC,OAAO,EAAE,iBAAiB,GAAG,OAAO,CAAC,OAAO,CAAC;IA6BnE,KAAK,IAAI,IAAI;IAQb,MAAM,CAAC,oBAAoB,CAAC,KAAK,EAAE,MAAM,GAAG,eAAe;CAQ5D;AAGD,wBAAgB,uBAAuB,IAAI,OAAO,CAAC,WAAW,CAAC,CAyB9D"}
@@ -0,0 +1,224 @@
1
+ // Permission System for Atena CLI
2
+ // Inspired by Opencode's permission model
3
+ import readline from 'node:readline';
4
+ import { colors, icons } from './ui.js';
5
+ // Safe commands that don't require confirmation
6
+ const SAFE_BASH_COMMANDS = [
7
+ 'ls', 'cat', 'echo', 'pwd', 'which', 'whoami', 'uname',
8
+ 'git status', 'git log', 'git diff', 'git branch',
9
+ 'npm list', 'npm view', 'node --version', 'npm --version',
10
+ 'curl -I', 'curl --head', 'wc -l', 'head', 'tail',
11
+ 'find . -name', 'grep -r', 'ps aux', 'df -h', 'du -sh',
12
+ ];
13
+ // Dangerous patterns that should always ask
14
+ const DANGEROUS_PATTERNS = [
15
+ /rm\s+-rf\s+\//, // rm -rf /
16
+ /rm\s+-rf\s+~\/\./, // rm -rf ~/.*
17
+ />\s*\/etc\//, // Redirect to /etc
18
+ /mkfs\./, // Format filesystem
19
+ /dd\s+if=.*of=\/dev/, // dd to device
20
+ /:\(\)\{\s*:\|:&\};:/, // Fork bomb
21
+ ];
22
+ export class PermissionManager {
23
+ permissions;
24
+ remembered = new Map();
25
+ rl = null;
26
+ constructor(permissions) {
27
+ this.permissions = {
28
+ fileWrite: 'auto',
29
+ fileDelete: 'ask',
30
+ bash: 'ask',
31
+ network: 'auto',
32
+ ...permissions,
33
+ };
34
+ }
35
+ setPermissions(permissions) {
36
+ this.permissions = { ...this.permissions, ...permissions };
37
+ }
38
+ getPermissions() {
39
+ return { ...this.permissions };
40
+ }
41
+ isDangerous(request) {
42
+ if (request.type === 'bash' && request.details) {
43
+ const cmd = request.details.toLowerCase();
44
+ // Check for dangerous patterns
45
+ for (const pattern of DANGEROUS_PATTERNS) {
46
+ if (pattern.test(cmd)) {
47
+ return true;
48
+ }
49
+ }
50
+ // Check for rm -rf patterns
51
+ if (/rm\s+(-[a-zA-Z]*f[a-zA-Z]*\s+|--)force/.test(cmd) &&
52
+ (cmd.includes(' -r') || cmd.includes(' -R') || cmd.includes('--recursive'))) {
53
+ return true;
54
+ }
55
+ // Check for write to system directories
56
+ if (/>\s*(\/usr\/|\/bin\/|\/sbin\/|\/lib\/|\/sys\/|\/proc\/)/.test(cmd)) {
57
+ return true;
58
+ }
59
+ }
60
+ return false;
61
+ }
62
+ isSafeCommand(request) {
63
+ if (request.type !== 'bash' || !request.details) {
64
+ return false;
65
+ }
66
+ const cmd = request.details.trim().toLowerCase();
67
+ // Check against safe command list
68
+ for (const safe of SAFE_BASH_COMMANDS) {
69
+ if (cmd.startsWith(safe.toLowerCase())) {
70
+ return true;
71
+ }
72
+ }
73
+ // Single file reads are safe
74
+ if (/^cat\s+[^|<>]+$/.test(cmd))
75
+ return true;
76
+ if (/^head\s+-n?\s*\d*\s+[^|<>]+$/.test(cmd))
77
+ return true;
78
+ if (/^tail\s+-n?\s*\d*\s+[^|<>]+$/.test(cmd))
79
+ return true;
80
+ return false;
81
+ }
82
+ async askUser(request) {
83
+ // Check remembered decisions
84
+ const key = `${request.type}:${request.tool}:${request.description}`;
85
+ if (this.remembered.has(key)) {
86
+ return { allowed: this.remembered.get(key), remember: true };
87
+ }
88
+ // Auto-allow safe commands
89
+ if (this.isSafeCommand(request)) {
90
+ return { allowed: true, remember: false };
91
+ }
92
+ // Always ask for dangerous operations
93
+ const isDangerous = this.isDangerous(request);
94
+ // Create readline interface if needed
95
+ if (!this.rl) {
96
+ this.rl = readline.createInterface({
97
+ input: process.stdin,
98
+ output: process.stdout,
99
+ });
100
+ }
101
+ return new Promise((resolve) => {
102
+ console.log('\n' + colors.warning('─'.repeat(60)));
103
+ if (isDangerous) {
104
+ console.log(colors.error(` ${icons.warning} ADVERTENCIA: Operación potencialmente peligrosa`));
105
+ }
106
+ else {
107
+ console.log(colors.primary(` ${icons.pending} Permiso requerido`));
108
+ }
109
+ console.log(colors.muted(` Tipo: ${request.type}`));
110
+ console.log(colors.muted(` Tool: ${request.tool}`));
111
+ console.log(colors.text(` ${request.description}`));
112
+ if (request.details) {
113
+ console.log(colors.dim(` Detalles: ${request.details.slice(0, 100)}${request.details.length > 100 ? '...' : ''}`));
114
+ }
115
+ console.log(colors.warning('─'.repeat(60)));
116
+ const options = isDangerous
117
+ ? '[S/N/siempre/nunca] '
118
+ : '[S/N/siempre/nunca/info] ';
119
+ this.rl.question(colors.primary(` ¿Permitir? ${options}`), (answer) => {
120
+ const normalized = answer.trim().toLowerCase();
121
+ let allowed = false;
122
+ let remember = false;
123
+ if (normalized === 's' || normalized === 'si' || normalized === 'y' || normalized === 'yes') {
124
+ allowed = true;
125
+ }
126
+ else if (normalized === 'siempre' || normalized === 'always') {
127
+ allowed = true;
128
+ remember = true;
129
+ }
130
+ else if (normalized === 'nunca' || normalized === 'never') {
131
+ allowed = false;
132
+ remember = true;
133
+ }
134
+ else if (normalized === 'info' && !isDangerous) {
135
+ console.log(colors.info('\n Información adicional:'));
136
+ console.log(colors.muted(' Esta operación modificará archivos o ejecutará comandos.'));
137
+ console.log(colors.muted(' Use "siempre" para no volver a preguntar por operaciones similares.'));
138
+ console.log(colors.muted(' Use "nunca" para bloquear permanentemente operaciones similares.\n'));
139
+ // Ask again
140
+ this.rl.question(colors.primary(` ¿Permitir? [S/N/siempre/nunca] `), (answer2) => {
141
+ const norm2 = answer2.trim().toLowerCase();
142
+ if (norm2 === 's' || norm2 === 'si' || norm2 === 'y') {
143
+ resolve({ allowed: true, remember: false });
144
+ }
145
+ else if (norm2 === 'siempre' || norm2 === 'always') {
146
+ resolve({ allowed: true, remember: true });
147
+ }
148
+ else if (norm2 === 'nunca' || norm2 === 'never') {
149
+ resolve({ allowed: false, remember: true });
150
+ }
151
+ else {
152
+ resolve({ allowed: false, remember: false });
153
+ }
154
+ });
155
+ return;
156
+ }
157
+ // Store remembered decision
158
+ if (remember) {
159
+ this.remembered.set(key, allowed);
160
+ }
161
+ resolve({ allowed, remember });
162
+ });
163
+ });
164
+ }
165
+ async checkPermission(request) {
166
+ const level = this.permissions[request.type];
167
+ switch (level) {
168
+ case 'deny':
169
+ console.log(colors.error(` ${icons.error} Operación denegada por configuración`));
170
+ return false;
171
+ case 'auto':
172
+ // Check if it's a safe command or not dangerous
173
+ if (!this.isDangerous(request)) {
174
+ return true;
175
+ }
176
+ // Fall through to ask for dangerous operations
177
+ case 'ask':
178
+ default:
179
+ const result = await this.askUser(request);
180
+ if (result.allowed) {
181
+ if (result.remember) {
182
+ console.log(colors.muted(` ${icons.info} Decision guardada para operaciones similares`));
183
+ }
184
+ }
185
+ else {
186
+ console.log(colors.error(` ${icons.error} Operación cancelada por el usuario`));
187
+ }
188
+ return result.allowed;
189
+ }
190
+ }
191
+ close() {
192
+ if (this.rl) {
193
+ this.rl.close();
194
+ this.rl = null;
195
+ }
196
+ }
197
+ // Set permission from string (for CLI flags)
198
+ static parsePermissionLevel(level) {
199
+ switch (level.toLowerCase()) {
200
+ case 'ask': return 'ask';
201
+ case 'auto': return 'auto';
202
+ case 'deny': return 'deny';
203
+ default: return 'ask';
204
+ }
205
+ }
206
+ }
207
+ // Environment variable parsing
208
+ export function parsePermissionsFromEnv() {
209
+ const permissions = {};
210
+ if (process.env.ATENA_PERMISSION_FILE_WRITE) {
211
+ permissions.fileWrite = PermissionManager.parsePermissionLevel(process.env.ATENA_PERMISSION_FILE_WRITE);
212
+ }
213
+ if (process.env.ATENA_PERMISSION_FILE_DELETE) {
214
+ permissions.fileDelete = PermissionManager.parsePermissionLevel(process.env.ATENA_PERMISSION_FILE_DELETE);
215
+ }
216
+ if (process.env.ATENA_PERMISSION_BASH) {
217
+ permissions.bash = PermissionManager.parsePermissionLevel(process.env.ATENA_PERMISSION_BASH);
218
+ }
219
+ if (process.env.ATENA_PERMISSION_NETWORK) {
220
+ permissions.network = PermissionManager.parsePermissionLevel(process.env.ATENA_PERMISSION_NETWORK);
221
+ }
222
+ return permissions;
223
+ }
224
+ //# sourceMappingURL=permissions.js.map