@openacp/cli 0.6.9 → 2026.41.1

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 (133) hide show
  1. package/README.md +116 -152
  2. package/dist/cli.d.ts +11 -0
  3. package/dist/cli.js +27740 -415
  4. package/dist/cli.js.map +1 -1
  5. package/dist/data/registry-snapshot.json +1 -1
  6. package/dist/index.d.ts +1944 -463
  7. package/dist/index.js +17365 -102
  8. package/dist/index.js.map +1 -1
  9. package/package.json +13 -7
  10. package/dist/action-detect-P7ZE4NEM.js +0 -16
  11. package/dist/action-detect-P7ZE4NEM.js.map +0 -1
  12. package/dist/adapter-LNEGLMOE.js +0 -799
  13. package/dist/adapter-LNEGLMOE.js.map +0 -1
  14. package/dist/admin-6SYB6XCZ.js +0 -23
  15. package/dist/admin-6SYB6XCZ.js.map +0 -1
  16. package/dist/agent-catalog-FC3HGDEQ.js +0 -11
  17. package/dist/agent-catalog-FC3HGDEQ.js.map +0 -1
  18. package/dist/agent-dependencies-4OWBMZWZ.js +0 -24
  19. package/dist/agent-dependencies-4OWBMZWZ.js.map +0 -1
  20. package/dist/agent-registry-WT4NXPYG.js +0 -9
  21. package/dist/agent-registry-WT4NXPYG.js.map +0 -1
  22. package/dist/agent-store-VZLFPTZU.js +0 -9
  23. package/dist/agent-store-VZLFPTZU.js.map +0 -1
  24. package/dist/agents-QO7DKARJ.js +0 -15
  25. package/dist/agents-QO7DKARJ.js.map +0 -1
  26. package/dist/api-client-CFQT5U7D.js +0 -14
  27. package/dist/api-client-CFQT5U7D.js.map +0 -1
  28. package/dist/autostart-X33OGMX6.js +0 -23
  29. package/dist/autostart-X33OGMX6.js.map +0 -1
  30. package/dist/chunk-2CJ46J3C.js +0 -154
  31. package/dist/chunk-2CJ46J3C.js.map +0 -1
  32. package/dist/chunk-2HMQOC7N.js +0 -134
  33. package/dist/chunk-2HMQOC7N.js.map +0 -1
  34. package/dist/chunk-33RP6K2O.js +0 -435
  35. package/dist/chunk-33RP6K2O.js.map +0 -1
  36. package/dist/chunk-34M4OS5P.js +0 -83
  37. package/dist/chunk-34M4OS5P.js.map +0 -1
  38. package/dist/chunk-4CTX774K.js +0 -265
  39. package/dist/chunk-4CTX774K.js.map +0 -1
  40. package/dist/chunk-7QJS2XBD.js +0 -92
  41. package/dist/chunk-7QJS2XBD.js.map +0 -1
  42. package/dist/chunk-BDYVCIBH.js +0 -735
  43. package/dist/chunk-BDYVCIBH.js.map +0 -1
  44. package/dist/chunk-BN3X7UXB.js +0 -738
  45. package/dist/chunk-BN3X7UXB.js.map +0 -1
  46. package/dist/chunk-BNLGTZ34.js +0 -122
  47. package/dist/chunk-BNLGTZ34.js.map +0 -1
  48. package/dist/chunk-GAK6PIBW.js +0 -224
  49. package/dist/chunk-GAK6PIBW.js.map +0 -1
  50. package/dist/chunk-H5P2C6H4.js +0 -4740
  51. package/dist/chunk-H5P2C6H4.js.map +0 -1
  52. package/dist/chunk-I7WC6E5S.js +0 -71
  53. package/dist/chunk-I7WC6E5S.js.map +0 -1
  54. package/dist/chunk-J4SJTKIK.js +0 -203
  55. package/dist/chunk-J4SJTKIK.js.map +0 -1
  56. package/dist/chunk-JHYXKVV2.js +0 -183
  57. package/dist/chunk-JHYXKVV2.js.map +0 -1
  58. package/dist/chunk-JKBFUAJK.js +0 -282
  59. package/dist/chunk-JKBFUAJK.js.map +0 -1
  60. package/dist/chunk-JUYDFUSN.js +0 -673
  61. package/dist/chunk-JUYDFUSN.js.map +0 -1
  62. package/dist/chunk-KIRH7TUJ.js +0 -219
  63. package/dist/chunk-KIRH7TUJ.js.map +0 -1
  64. package/dist/chunk-LBIKITQT.js +0 -22
  65. package/dist/chunk-LBIKITQT.js.map +0 -1
  66. package/dist/chunk-LGP2YGRL.js +0 -4880
  67. package/dist/chunk-LGP2YGRL.js.map +0 -1
  68. package/dist/chunk-NAMYZIS5.js +0 -1
  69. package/dist/chunk-NAMYZIS5.js.map +0 -1
  70. package/dist/chunk-NVPG6JCL.js +0 -724
  71. package/dist/chunk-NVPG6JCL.js.map +0 -1
  72. package/dist/chunk-O7CPGUAI.js +0 -298
  73. package/dist/chunk-O7CPGUAI.js.map +0 -1
  74. package/dist/chunk-S64CB6J3.js +0 -98
  75. package/dist/chunk-S64CB6J3.js.map +0 -1
  76. package/dist/chunk-UKT3G5IA.js +0 -484
  77. package/dist/chunk-UKT3G5IA.js.map +0 -1
  78. package/dist/chunk-V5GZQEIY.js +0 -101
  79. package/dist/chunk-V5GZQEIY.js.map +0 -1
  80. package/dist/chunk-VOIJ6OY4.js +0 -63
  81. package/dist/chunk-VOIJ6OY4.js.map +0 -1
  82. package/dist/chunk-VUNV25KB.js +0 -16
  83. package/dist/chunk-VUNV25KB.js.map +0 -1
  84. package/dist/chunk-W3EYKZNQ.js +0 -45
  85. package/dist/chunk-W3EYKZNQ.js.map +0 -1
  86. package/dist/chunk-WTZDAYZX.js +0 -172
  87. package/dist/chunk-WTZDAYZX.js.map +0 -1
  88. package/dist/chunk-XANPHG7W.js +0 -145
  89. package/dist/chunk-XANPHG7W.js.map +0 -1
  90. package/dist/config-6S355X75.js +0 -15
  91. package/dist/config-6S355X75.js.map +0 -1
  92. package/dist/config-editor-RVLWZLVB.js +0 -13
  93. package/dist/config-editor-RVLWZLVB.js.map +0 -1
  94. package/dist/config-registry-AHYI4MYL.js +0 -18
  95. package/dist/config-registry-AHYI4MYL.js.map +0 -1
  96. package/dist/daemon-4CS6HMB5.js +0 -30
  97. package/dist/daemon-4CS6HMB5.js.map +0 -1
  98. package/dist/discord-7IVQKB2H.js +0 -2083
  99. package/dist/discord-7IVQKB2H.js.map +0 -1
  100. package/dist/dist-UHQK5CXN.js +0 -21151
  101. package/dist/dist-UHQK5CXN.js.map +0 -1
  102. package/dist/doctor-HZZ5BSHB.js +0 -10
  103. package/dist/doctor-HZZ5BSHB.js.map +0 -1
  104. package/dist/doctor-OLYBO3V3.js +0 -15
  105. package/dist/doctor-OLYBO3V3.js.map +0 -1
  106. package/dist/install-cloudflared-Z7VCGOVG.js +0 -33
  107. package/dist/install-cloudflared-Z7VCGOVG.js.map +0 -1
  108. package/dist/install-jq-HUYSQWKR.js +0 -32
  109. package/dist/install-jq-HUYSQWKR.js.map +0 -1
  110. package/dist/integrate-PNEHRY2I.js +0 -373
  111. package/dist/integrate-PNEHRY2I.js.map +0 -1
  112. package/dist/log-NXABYJTT.js +0 -24
  113. package/dist/log-NXABYJTT.js.map +0 -1
  114. package/dist/main-ZK4MPMBG.js +0 -238
  115. package/dist/main-ZK4MPMBG.js.map +0 -1
  116. package/dist/menu-YY5MKHEK.js +0 -16
  117. package/dist/menu-YY5MKHEK.js.map +0 -1
  118. package/dist/new-session-FEO4J4VU.js +0 -17
  119. package/dist/new-session-FEO4J4VU.js.map +0 -1
  120. package/dist/post-upgrade-CJG5I7M2.js +0 -80
  121. package/dist/post-upgrade-CJG5I7M2.js.map +0 -1
  122. package/dist/session-IUSI7P5S.js +0 -20
  123. package/dist/session-IUSI7P5S.js.map +0 -1
  124. package/dist/settings-RQPAM4KC.js +0 -14
  125. package/dist/settings-RQPAM4KC.js.map +0 -1
  126. package/dist/setup-3GQSYBE4.js +0 -35
  127. package/dist/setup-3GQSYBE4.js.map +0 -1
  128. package/dist/suggest-7D6B542M.js +0 -38
  129. package/dist/suggest-7D6B542M.js.map +0 -1
  130. package/dist/tunnel-service-CJLUH6SZ.js +0 -1174
  131. package/dist/tunnel-service-CJLUH6SZ.js.map +0 -1
  132. package/dist/version-NQZBM5M7.js +0 -16
  133. package/dist/version-NQZBM5M7.js.map +0 -1
@@ -1,71 +0,0 @@
1
- // src/adapters/discord/action-detect.ts
2
- import { nanoid } from "nanoid";
3
- import { ActionRowBuilder, ButtonBuilder, ButtonStyle } from "discord.js";
4
- var CMD_NEW_RE = /\/new(?:\s+([^\s\u0080-\uFFFF]+)(?:\s+([^\s\u0080-\uFFFF]+))?)?/;
5
- var CMD_CANCEL_RE = /\/cancel\b/;
6
- var KW_NEW_RE = /(?:create|new)\s+session/i;
7
- var KW_CANCEL_RE = /(?:cancel|stop)\s+session/i;
8
- function detectAction(text) {
9
- if (!text) return null;
10
- const cancelCmd = CMD_CANCEL_RE.exec(text);
11
- if (cancelCmd) return { type: "cancel_session" };
12
- const newCmd = CMD_NEW_RE.exec(text);
13
- if (newCmd) {
14
- return {
15
- type: "new_session",
16
- agent: newCmd[1] || void 0,
17
- workspace: newCmd[2] || void 0
18
- };
19
- }
20
- if (KW_CANCEL_RE.test(text)) return { type: "cancel_session" };
21
- if (KW_NEW_RE.test(text)) return { type: "new_session", agent: void 0, workspace: void 0 };
22
- return null;
23
- }
24
- var ACTION_TTL_MS = 5 * 60 * 1e3;
25
- var actionMap = /* @__PURE__ */ new Map();
26
- function storeAction(action) {
27
- const id = nanoid(8);
28
- actionMap.set(id, { action, createdAt: Date.now() });
29
- for (const [key, entry] of actionMap) {
30
- if (Date.now() - entry.createdAt > ACTION_TTL_MS) {
31
- actionMap.delete(key);
32
- }
33
- }
34
- return id;
35
- }
36
- function getAction(id) {
37
- const entry = actionMap.get(id);
38
- if (!entry) return void 0;
39
- if (Date.now() - entry.createdAt > ACTION_TTL_MS) {
40
- actionMap.delete(id);
41
- return void 0;
42
- }
43
- return entry.action;
44
- }
45
- function removeAction(id) {
46
- actionMap.delete(id);
47
- }
48
- function buildActionKeyboard(actionId, action) {
49
- const row = new ActionRowBuilder();
50
- if (action.type === "new_session") {
51
- row.addComponents(
52
- new ButtonBuilder().setCustomId(`a:${actionId}`).setLabel("\u2705 Create session").setStyle(ButtonStyle.Success),
53
- new ButtonBuilder().setCustomId(`a:dismiss:${actionId}`).setLabel("\u274C Cancel").setStyle(ButtonStyle.Secondary)
54
- );
55
- } else {
56
- row.addComponents(
57
- new ButtonBuilder().setCustomId(`a:${actionId}`).setLabel("\u26D4 Cancel session").setStyle(ButtonStyle.Danger),
58
- new ButtonBuilder().setCustomId(`a:dismiss:${actionId}`).setLabel("\u274C No").setStyle(ButtonStyle.Secondary)
59
- );
60
- }
61
- return row;
62
- }
63
-
64
- export {
65
- detectAction,
66
- storeAction,
67
- getAction,
68
- removeAction,
69
- buildActionKeyboard
70
- };
71
- //# sourceMappingURL=chunk-I7WC6E5S.js.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../../src/adapters/discord/action-detect.ts"],"sourcesContent":["import { nanoid } from 'nanoid'\nimport { ActionRowBuilder, ButtonBuilder, ButtonStyle } from 'discord.js'\n\nexport interface DetectedAction {\n type: 'new_session' | 'cancel_session'\n agent?: string\n workspace?: string\n}\n\n// Command patterns: /new [agent] [workspace], /cancel\n// Agent and workspace are ASCII-only tokens (no Unicode letters) to avoid matching non-ASCII words\nconst CMD_NEW_RE = /\\/new(?:\\s+([^\\s\\u0080-\\uFFFF]+)(?:\\s+([^\\s\\u0080-\\uFFFF]+))?)?/\nconst CMD_CANCEL_RE = /\\/cancel\\b/\n\n// Keyword patterns (compound phrases only to avoid false positives)\nconst KW_NEW_RE = /(?:create|new)\\s+session/i\nconst KW_CANCEL_RE = /(?:cancel|stop)\\s+session/i\n\nexport function detectAction(text: string): DetectedAction | null {\n if (!text) return null\n\n // Priority 1: command pattern\n const cancelCmd = CMD_CANCEL_RE.exec(text)\n if (cancelCmd) return { type: 'cancel_session' }\n\n const newCmd = CMD_NEW_RE.exec(text)\n if (newCmd) {\n return {\n type: 'new_session',\n agent: newCmd[1] || undefined,\n workspace: newCmd[2] || undefined,\n }\n }\n\n // Priority 2: keyword matching\n if (KW_CANCEL_RE.test(text)) return { type: 'cancel_session' }\n if (KW_NEW_RE.test(text)) return { type: 'new_session', agent: undefined, workspace: undefined }\n\n return null\n}\n\n// --- TTL action map ---\n\nconst ACTION_TTL_MS = 5 * 60 * 1000 // 5 minutes\nconst actionMap: Map<string, { action: DetectedAction; createdAt: number }> = new Map()\n\nexport function storeAction(action: DetectedAction): string {\n const id = nanoid(8)\n actionMap.set(id, { action, createdAt: Date.now() })\n // Cleanup expired entries\n for (const [key, entry] of actionMap) {\n if (Date.now() - entry.createdAt > ACTION_TTL_MS) {\n actionMap.delete(key)\n }\n }\n return id\n}\n\nexport function getAction(id: string): DetectedAction | undefined {\n const entry = actionMap.get(id)\n if (!entry) return undefined\n if (Date.now() - entry.createdAt > ACTION_TTL_MS) {\n actionMap.delete(id)\n return undefined\n }\n return entry.action\n}\n\nexport function removeAction(id: string): void {\n actionMap.delete(id)\n}\n\nexport function buildActionKeyboard(\n actionId: string,\n action: DetectedAction,\n): ActionRowBuilder<ButtonBuilder> {\n const row = new ActionRowBuilder<ButtonBuilder>()\n\n if (action.type === 'new_session') {\n row.addComponents(\n new ButtonBuilder()\n .setCustomId(`a:${actionId}`)\n .setLabel('✅ Create session')\n .setStyle(ButtonStyle.Success),\n new ButtonBuilder()\n .setCustomId(`a:dismiss:${actionId}`)\n .setLabel('❌ Cancel')\n .setStyle(ButtonStyle.Secondary),\n )\n } else {\n row.addComponents(\n new ButtonBuilder()\n .setCustomId(`a:${actionId}`)\n .setLabel('⛔ Cancel session')\n .setStyle(ButtonStyle.Danger),\n new ButtonBuilder()\n .setCustomId(`a:dismiss:${actionId}`)\n .setLabel('❌ No')\n .setStyle(ButtonStyle.Secondary),\n )\n }\n\n return row\n}\n"],"mappings":";AAAA,SAAS,cAAc;AACvB,SAAS,kBAAkB,eAAe,mBAAmB;AAU7D,IAAM,aAAa;AACnB,IAAM,gBAAgB;AAGtB,IAAM,YAAY;AAClB,IAAM,eAAe;AAEd,SAAS,aAAa,MAAqC;AAChE,MAAI,CAAC,KAAM,QAAO;AAGlB,QAAM,YAAY,cAAc,KAAK,IAAI;AACzC,MAAI,UAAW,QAAO,EAAE,MAAM,iBAAiB;AAE/C,QAAM,SAAS,WAAW,KAAK,IAAI;AACnC,MAAI,QAAQ;AACV,WAAO;AAAA,MACL,MAAM;AAAA,MACN,OAAO,OAAO,CAAC,KAAK;AAAA,MACpB,WAAW,OAAO,CAAC,KAAK;AAAA,IAC1B;AAAA,EACF;AAGA,MAAI,aAAa,KAAK,IAAI,EAAG,QAAO,EAAE,MAAM,iBAAiB;AAC7D,MAAI,UAAU,KAAK,IAAI,EAAG,QAAO,EAAE,MAAM,eAAe,OAAO,QAAW,WAAW,OAAU;AAE/F,SAAO;AACT;AAIA,IAAM,gBAAgB,IAAI,KAAK;AAC/B,IAAM,YAAwE,oBAAI,IAAI;AAE/E,SAAS,YAAY,QAAgC;AAC1D,QAAM,KAAK,OAAO,CAAC;AACnB,YAAU,IAAI,IAAI,EAAE,QAAQ,WAAW,KAAK,IAAI,EAAE,CAAC;AAEnD,aAAW,CAAC,KAAK,KAAK,KAAK,WAAW;AACpC,QAAI,KAAK,IAAI,IAAI,MAAM,YAAY,eAAe;AAChD,gBAAU,OAAO,GAAG;AAAA,IACtB;AAAA,EACF;AACA,SAAO;AACT;AAEO,SAAS,UAAU,IAAwC;AAChE,QAAM,QAAQ,UAAU,IAAI,EAAE;AAC9B,MAAI,CAAC,MAAO,QAAO;AACnB,MAAI,KAAK,IAAI,IAAI,MAAM,YAAY,eAAe;AAChD,cAAU,OAAO,EAAE;AACnB,WAAO;AAAA,EACT;AACA,SAAO,MAAM;AACf;AAEO,SAAS,aAAa,IAAkB;AAC7C,YAAU,OAAO,EAAE;AACrB;AAEO,SAAS,oBACd,UACA,QACiC;AACjC,QAAM,MAAM,IAAI,iBAAgC;AAEhD,MAAI,OAAO,SAAS,eAAe;AACjC,QAAI;AAAA,MACF,IAAI,cAAc,EACf,YAAY,KAAK,QAAQ,EAAE,EAC3B,SAAS,uBAAkB,EAC3B,SAAS,YAAY,OAAO;AAAA,MAC/B,IAAI,cAAc,EACf,YAAY,aAAa,QAAQ,EAAE,EACnC,SAAS,eAAU,EACnB,SAAS,YAAY,SAAS;AAAA,IACnC;AAAA,EACF,OAAO;AACL,QAAI;AAAA,MACF,IAAI,cAAc,EACf,YAAY,KAAK,QAAQ,EAAE,EAC3B,SAAS,uBAAkB,EAC3B,SAAS,YAAY,MAAM;AAAA,MAC9B,IAAI,cAAc,EACf,YAAY,aAAa,QAAQ,EAAE,EACnC,SAAS,WAAM,EACf,SAAS,YAAY,SAAS;AAAA,IACnC;AAAA,EACF;AAEA,SAAO;AACT;","names":[]}
@@ -1,203 +0,0 @@
1
- import {
2
- log
3
- } from "./chunk-GAK6PIBW.js";
4
-
5
- // src/adapters/discord/commands/agents.ts
6
- import {
7
- ActionRowBuilder,
8
- ButtonBuilder,
9
- ButtonStyle
10
- } from "discord.js";
11
- var AGENTS_PER_PAGE = 5;
12
- function buildProgressBar(percent) {
13
- const filled = Math.round(percent / 10);
14
- const empty = 10 - filled;
15
- return "\u2588".repeat(filled) + "\u2591".repeat(empty);
16
- }
17
- function truncate(text, maxLen) {
18
- if (text.length <= maxLen) return text;
19
- return text.slice(0, maxLen - 1) + "\u2026";
20
- }
21
- async function handleAgents(interaction, adapter, page = 0) {
22
- await interaction.deferReply({ ephemeral: true });
23
- const { content, components } = buildAgentsContent(adapter, page);
24
- await interaction.editReply({ content, components });
25
- }
26
- async function showAgentsList(interaction, adapter, page = 0) {
27
- const { content, components } = buildAgentsContent(adapter, page);
28
- await interaction.followUp({ content, components, ephemeral: true });
29
- }
30
- function buildAgentsContent(adapter, page) {
31
- const catalog = adapter.core.agentCatalog;
32
- const items = catalog.getAvailable();
33
- const installed = items.filter((i) => i.installed);
34
- const available = items.filter((i) => !i.installed);
35
- let content = "**\u{1F916} Agents**\n\n";
36
- if (installed.length > 0) {
37
- content += "**Installed:**\n";
38
- for (const item of installed) {
39
- content += `\u2705 **${item.name}**`;
40
- if (item.description) content += ` \u2014 *${truncate(item.description, 50)}*`;
41
- content += "\n";
42
- }
43
- content += "\n";
44
- }
45
- const components = [];
46
- if (available.length > 0) {
47
- const totalPages = Math.ceil(available.length / AGENTS_PER_PAGE);
48
- const safePage = Math.max(0, Math.min(page, totalPages - 1));
49
- const pageItems = available.slice(safePage * AGENTS_PER_PAGE, (safePage + 1) * AGENTS_PER_PAGE);
50
- content += `**Available to install:**`;
51
- if (totalPages > 1) content += ` (${safePage + 1}/${totalPages})`;
52
- content += "\n";
53
- for (const item of pageItems) {
54
- if (item.available) {
55
- content += `\u2B07\uFE0F **${item.name}**`;
56
- } else {
57
- const deps = item.missingDeps?.join(", ") ?? "requirements not met";
58
- content += `\u26A0\uFE0F **${item.name}** *(needs: ${deps})*`;
59
- }
60
- if (item.description) content += `
61
- *${truncate(item.description, 60)}*`;
62
- content += "\n";
63
- }
64
- const installable = pageItems.filter((i) => i.available);
65
- if (installable.length > 0) {
66
- const installRow = new ActionRowBuilder();
67
- for (const item of installable) {
68
- installRow.addComponents(
69
- new ButtonBuilder().setCustomId(`ag:install:${item.key}`).setLabel(`\u2B07\uFE0F ${item.name}`).setStyle(ButtonStyle.Secondary)
70
- );
71
- }
72
- components.push(installRow);
73
- }
74
- if (totalPages > 1) {
75
- const pageRow = new ActionRowBuilder();
76
- if (safePage > 0) {
77
- pageRow.addComponents(
78
- new ButtonBuilder().setCustomId(`ag:page:${safePage - 1}`).setLabel("\u25C0\uFE0F Prev").setStyle(ButtonStyle.Secondary)
79
- );
80
- }
81
- if (safePage < totalPages - 1) {
82
- pageRow.addComponents(
83
- new ButtonBuilder().setCustomId(`ag:page:${safePage + 1}`).setLabel("Next \u25B6\uFE0F").setStyle(ButtonStyle.Secondary)
84
- );
85
- }
86
- if (pageRow.components.length > 0) components.push(pageRow);
87
- }
88
- } else {
89
- content += "*All agents are already installed!*";
90
- }
91
- return { content, components };
92
- }
93
- async function handleInstall(interaction, adapter) {
94
- await interaction.deferReply({ ephemeral: true });
95
- const nameOrId = interaction.options.getString("name", true);
96
- await installAgentWithProgress(interaction, adapter, nameOrId);
97
- }
98
- async function handleAgentButton(interaction, adapter) {
99
- const { customId } = interaction;
100
- if (customId.startsWith("ag:install:")) {
101
- const nameOrId = customId.replace("ag:install:", "");
102
- try {
103
- await interaction.deferReply({ ephemeral: true });
104
- } catch {
105
- }
106
- await installAgentWithProgress(interaction, adapter, nameOrId);
107
- return;
108
- }
109
- if (customId.startsWith("ag:page:")) {
110
- const page = parseInt(customId.replace("ag:page:", ""), 10);
111
- const { content, components } = buildAgentsContent(adapter, page);
112
- try {
113
- await interaction.update({ content, components });
114
- } catch (err) {
115
- log.warn({ err }, "[discord-agents] Failed to update page");
116
- }
117
- }
118
- }
119
- async function installAgentWithProgress(interaction, adapter, nameOrId) {
120
- const catalog = adapter.core.agentCatalog;
121
- let statusText = `\u23F3 Installing **${nameOrId}**...`;
122
- let lastEdit = 0;
123
- const EDIT_THROTTLE_MS = 1500;
124
- const editStatus = async (text) => {
125
- const now = Date.now();
126
- if (now - lastEdit > EDIT_THROTTLE_MS) {
127
- lastEdit = now;
128
- statusText = text;
129
- try {
130
- if (interaction.deferred || interaction.replied) {
131
- await interaction.editReply(text);
132
- }
133
- } catch {
134
- }
135
- } else {
136
- statusText = text;
137
- }
138
- };
139
- try {
140
- if (interaction.deferred || interaction.replied) {
141
- await interaction.editReply(statusText);
142
- }
143
- } catch {
144
- }
145
- const progress = {
146
- onStart(_id, _name) {
147
- },
148
- async onStep(step) {
149
- await editStatus(`\u23F3 **${nameOrId}**: ${step}`);
150
- },
151
- async onDownloadProgress(percent) {
152
- const bar = buildProgressBar(percent);
153
- await editStatus(`\u23F3 **${nameOrId}**
154
- Downloading... ${bar} ${percent}%`);
155
- },
156
- async onSuccess(name) {
157
- const row = new ActionRowBuilder().addComponents(
158
- new ButtonBuilder().setCustomId(`na:${nameOrId}`).setLabel(`\u{1F680} Start session with ${name}`).setStyle(ButtonStyle.Primary)
159
- );
160
- try {
161
- if (interaction.deferred || interaction.replied) {
162
- await interaction.editReply({
163
- content: `\u2705 **${name}** installed!`,
164
- components: [row]
165
- });
166
- }
167
- } catch {
168
- }
169
- },
170
- async onError(error) {
171
- try {
172
- if (interaction.deferred || interaction.replied) {
173
- await interaction.editReply(`\u274C ${error}`);
174
- }
175
- } catch {
176
- }
177
- }
178
- };
179
- const result = await catalog.install(nameOrId, progress);
180
- if (result.ok && result.setupSteps?.length) {
181
- let setupText = `\u{1F4CB} **Setup for ${result.agentKey}:**
182
-
183
- `;
184
- for (const step of result.setupSteps) {
185
- setupText += `\u2192 ${step}
186
- `;
187
- }
188
- setupText += `
189
- *Run in terminal: \`openacp agents info ${result.agentKey}\`*`;
190
- try {
191
- await interaction.followUp({ content: setupText, ephemeral: true });
192
- } catch {
193
- }
194
- }
195
- }
196
-
197
- export {
198
- handleAgents,
199
- showAgentsList,
200
- handleInstall,
201
- handleAgentButton
202
- };
203
- //# sourceMappingURL=chunk-J4SJTKIK.js.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../../src/adapters/discord/commands/agents.ts"],"sourcesContent":["import {\n ActionRowBuilder,\n ButtonBuilder,\n ButtonStyle,\n} from 'discord.js'\nimport type { ChatInputCommandInteraction, ButtonInteraction } from 'discord.js'\nimport { log } from '../../../core/log.js'\nimport type { InstallProgress } from '../../../core/types.js'\nimport type { DiscordAdapter } from '../adapter.js'\n\nconst AGENTS_PER_PAGE = 5\n\nfunction buildProgressBar(percent: number): string {\n const filled = Math.round(percent / 10)\n const empty = 10 - filled\n return '█'.repeat(filled) + '░'.repeat(empty)\n}\n\nfunction truncate(text: string, maxLen: number): string {\n if (text.length <= maxLen) return text\n return text.slice(0, maxLen - 1) + '…'\n}\n\nexport async function handleAgents(\n interaction: ChatInputCommandInteraction,\n adapter: DiscordAdapter,\n page = 0,\n): Promise<void> {\n await interaction.deferReply({ ephemeral: true })\n const { content, components } = buildAgentsContent(adapter, page)\n await interaction.editReply({ content, components })\n}\n\nexport async function showAgentsList(\n interaction: ButtonInteraction,\n adapter: DiscordAdapter,\n page = 0,\n): Promise<void> {\n const { content, components } = buildAgentsContent(adapter, page)\n await interaction.followUp({ content, components, ephemeral: true })\n}\n\nfunction buildAgentsContent(\n adapter: DiscordAdapter,\n page: number,\n): { content: string; components: ActionRowBuilder<ButtonBuilder>[] } {\n const catalog = adapter.core.agentCatalog\n const items = catalog.getAvailable()\n\n const installed = items.filter((i: any) => i.installed)\n const available = items.filter((i: any) => !i.installed)\n\n let content = '**🤖 Agents**\\n\\n'\n\n if (installed.length > 0) {\n content += '**Installed:**\\n'\n for (const item of installed) {\n content += `✅ **${item.name}**`\n if (item.description) content += ` — *${truncate(item.description, 50)}*`\n content += '\\n'\n }\n content += '\\n'\n }\n\n const components: ActionRowBuilder<ButtonBuilder>[] = []\n\n if (available.length > 0) {\n const totalPages = Math.ceil(available.length / AGENTS_PER_PAGE)\n const safePage = Math.max(0, Math.min(page, totalPages - 1))\n const pageItems = available.slice(safePage * AGENTS_PER_PAGE, (safePage + 1) * AGENTS_PER_PAGE)\n\n content += `**Available to install:**`\n if (totalPages > 1) content += ` (${safePage + 1}/${totalPages})`\n content += '\\n'\n\n for (const item of pageItems) {\n if (item.available) {\n content += `⬇️ **${item.name}**`\n } else {\n const deps = item.missingDeps?.join(', ') ?? 'requirements not met'\n content += `⚠️ **${item.name}** *(needs: ${deps})*`\n }\n if (item.description) content += `\\n *${truncate(item.description, 60)}*`\n content += '\\n'\n }\n\n // Install buttons row\n const installable = pageItems.filter((i: any) => i.available)\n if (installable.length > 0) {\n const installRow = new ActionRowBuilder<ButtonBuilder>()\n for (const item of installable) {\n installRow.addComponents(\n new ButtonBuilder()\n .setCustomId(`ag:install:${item.key}`)\n .setLabel(`⬇️ ${item.name}`)\n .setStyle(ButtonStyle.Secondary),\n )\n }\n components.push(installRow)\n }\n\n // Pagination row\n if (totalPages > 1) {\n const pageRow = new ActionRowBuilder<ButtonBuilder>()\n if (safePage > 0) {\n pageRow.addComponents(\n new ButtonBuilder()\n .setCustomId(`ag:page:${safePage - 1}`)\n .setLabel('◀️ Prev')\n .setStyle(ButtonStyle.Secondary),\n )\n }\n if (safePage < totalPages - 1) {\n pageRow.addComponents(\n new ButtonBuilder()\n .setCustomId(`ag:page:${safePage + 1}`)\n .setLabel('Next ▶️')\n .setStyle(ButtonStyle.Secondary),\n )\n }\n if (pageRow.components.length > 0) components.push(pageRow)\n }\n } else {\n content += '*All agents are already installed!*'\n }\n\n return { content, components }\n}\n\nexport async function handleInstall(\n interaction: ChatInputCommandInteraction,\n adapter: DiscordAdapter,\n): Promise<void> {\n await interaction.deferReply({ ephemeral: true })\n\n const nameOrId = interaction.options.getString('name', true)\n await installAgentWithProgress(interaction, adapter, nameOrId)\n}\n\nexport async function handleAgentButton(\n interaction: ButtonInteraction,\n adapter: DiscordAdapter,\n): Promise<void> {\n const { customId } = interaction\n\n if (customId.startsWith('ag:install:')) {\n const nameOrId = customId.replace('ag:install:', '')\n try { await interaction.deferReply({ ephemeral: true }) } catch { /* ignore */ }\n await installAgentWithProgress(interaction, adapter, nameOrId)\n return\n }\n\n if (customId.startsWith('ag:page:')) {\n const page = parseInt(customId.replace('ag:page:', ''), 10)\n const { content, components } = buildAgentsContent(adapter, page)\n try {\n await interaction.update({ content, components })\n } catch (err) {\n log.warn({ err }, '[discord-agents] Failed to update page')\n }\n }\n}\n\nasync function installAgentWithProgress(\n interaction: ChatInputCommandInteraction | ButtonInteraction,\n adapter: DiscordAdapter,\n nameOrId: string,\n): Promise<void> {\n const catalog = adapter.core.agentCatalog\n\n // Track the latest status for periodic edits\n let statusText = `⏳ Installing **${nameOrId}**...`\n let lastEdit = 0\n const EDIT_THROTTLE_MS = 1500\n\n const editStatus = async (text: string) => {\n const now = Date.now()\n if (now - lastEdit > EDIT_THROTTLE_MS) {\n lastEdit = now\n statusText = text\n try {\n if (interaction.deferred || interaction.replied) {\n await interaction.editReply(text)\n }\n } catch { /* rate limit or unchanged */ }\n } else {\n statusText = text\n }\n }\n\n // Set initial message\n try {\n if (interaction.deferred || interaction.replied) {\n await interaction.editReply(statusText)\n }\n } catch { /* ignore */ }\n\n const progress: InstallProgress = {\n onStart(_id, _name) { /* initial message already sent */ },\n async onStep(step) { await editStatus(`⏳ **${nameOrId}**: ${step}`) },\n async onDownloadProgress(percent) {\n const bar = buildProgressBar(percent)\n await editStatus(`⏳ **${nameOrId}**\\nDownloading... ${bar} ${percent}%`)\n },\n async onSuccess(name) {\n const row = new ActionRowBuilder<ButtonBuilder>().addComponents(\n new ButtonBuilder()\n .setCustomId(`na:${nameOrId}`)\n .setLabel(`🚀 Start session with ${name}`)\n .setStyle(ButtonStyle.Primary),\n )\n try {\n if (interaction.deferred || interaction.replied) {\n await interaction.editReply({\n content: `✅ **${name}** installed!`,\n components: [row],\n })\n }\n } catch { /* ignore */ }\n },\n async onError(error) {\n try {\n if (interaction.deferred || interaction.replied) {\n await interaction.editReply(`❌ ${error}`)\n }\n } catch { /* ignore */ }\n },\n }\n\n const result = await catalog.install(nameOrId, progress)\n\n // Show setup steps as a follow-up message\n if (result.ok && result.setupSteps?.length) {\n let setupText = `📋 **Setup for ${result.agentKey}:**\\n\\n`\n for (const step of result.setupSteps) {\n setupText += `→ ${step}\\n`\n }\n setupText += `\\n*Run in terminal: \\`openacp agents info ${result.agentKey}\\`*`\n try {\n await interaction.followUp({ content: setupText, ephemeral: true })\n } catch { /* ignore */ }\n }\n}\n"],"mappings":"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","names":[]}
@@ -1,183 +0,0 @@
1
- // src/core/config-registry.ts
2
- import * as fs from "fs";
3
- import * as path from "path";
4
- import * as os from "os";
5
- var CONFIG_REGISTRY = [
6
- {
7
- path: "defaultAgent",
8
- displayName: "Default Agent",
9
- group: "agent",
10
- type: "select",
11
- options: (config) => {
12
- try {
13
- const agentsPath = path.join(os.homedir(), ".openacp", "agents.json");
14
- if (fs.existsSync(agentsPath)) {
15
- const data = JSON.parse(fs.readFileSync(agentsPath, "utf-8"));
16
- return Object.keys(data.installed ?? {});
17
- }
18
- } catch {
19
- }
20
- return Object.keys(config.agents ?? {});
21
- },
22
- scope: "safe",
23
- hotReload: true
24
- },
25
- {
26
- path: "channels.telegram.displayVerbosity",
27
- displayName: "Telegram Verbosity",
28
- group: "display",
29
- type: "select",
30
- options: ["low", "medium", "high"],
31
- scope: "safe",
32
- hotReload: true
33
- },
34
- {
35
- path: "channels.discord.displayVerbosity",
36
- displayName: "Discord Verbosity",
37
- group: "display",
38
- type: "select",
39
- options: ["low", "medium", "high"],
40
- scope: "safe",
41
- hotReload: true
42
- },
43
- {
44
- path: "logging.level",
45
- displayName: "Log Level",
46
- group: "logging",
47
- type: "select",
48
- options: ["silent", "debug", "info", "warn", "error", "fatal"],
49
- scope: "safe",
50
- hotReload: true
51
- },
52
- {
53
- path: "tunnel.enabled",
54
- displayName: "Tunnel",
55
- group: "tunnel",
56
- type: "toggle",
57
- scope: "safe",
58
- hotReload: false
59
- },
60
- {
61
- path: "security.maxConcurrentSessions",
62
- displayName: "Max Concurrent Sessions",
63
- group: "security",
64
- type: "number",
65
- scope: "safe",
66
- hotReload: true
67
- },
68
- {
69
- path: "security.sessionTimeoutMinutes",
70
- displayName: "Session Timeout (min)",
71
- group: "security",
72
- type: "number",
73
- scope: "safe",
74
- hotReload: true
75
- },
76
- {
77
- path: "workspace.baseDir",
78
- displayName: "Workspace Directory",
79
- group: "workspace",
80
- type: "string",
81
- scope: "safe",
82
- hotReload: true
83
- },
84
- {
85
- path: "sessionStore.ttlDays",
86
- displayName: "Session Store TTL (days)",
87
- group: "storage",
88
- type: "number",
89
- scope: "safe",
90
- hotReload: true
91
- },
92
- {
93
- path: "speech.stt.provider",
94
- displayName: "Speech to Text",
95
- group: "speech",
96
- type: "select",
97
- options: ["groq"],
98
- scope: "safe",
99
- hotReload: true
100
- },
101
- {
102
- path: "speech.stt.apiKey",
103
- displayName: "STT API Key",
104
- group: "speech",
105
- type: "string",
106
- scope: "sensitive",
107
- hotReload: true
108
- },
109
- {
110
- path: "speech.tts.provider",
111
- displayName: "Text to Speech",
112
- group: "speech",
113
- type: "select",
114
- options: ["edge-tts"],
115
- scope: "safe",
116
- hotReload: true
117
- },
118
- {
119
- path: "speech.tts.providers.edge-tts.voice",
120
- displayName: "Edge TTS Voice",
121
- group: "speech",
122
- type: "select",
123
- options: [
124
- "en-US-AriaNeural",
125
- "en-US-GuyNeural",
126
- "en-US-JennyNeural",
127
- "en-GB-SoniaNeural",
128
- "en-AU-NatashaNeural",
129
- "vi-VN-HoaiMyNeural",
130
- "vi-VN-NamMinhNeural",
131
- "zh-CN-XiaoxiaoNeural",
132
- "zh-CN-YunxiNeural",
133
- "ja-JP-NanamiNeural",
134
- "ja-JP-KeitaNeural",
135
- "ko-KR-SunHiNeural",
136
- "ko-KR-InJoonNeural",
137
- "es-ES-ElviraNeural",
138
- "fr-FR-DeniseNeural",
139
- "de-DE-KatjaNeural",
140
- "pt-BR-FranciscaNeural",
141
- "hi-IN-SwaraNeural",
142
- "ar-SA-ZariyahNeural"
143
- ],
144
- scope: "safe",
145
- hotReload: true
146
- }
147
- ];
148
- function getFieldDef(path2) {
149
- return CONFIG_REGISTRY.find((f) => f.path === path2);
150
- }
151
- function getSafeFields() {
152
- return CONFIG_REGISTRY.filter((f) => f.scope === "safe");
153
- }
154
- function isHotReloadable(path2) {
155
- const def = getFieldDef(path2);
156
- return def?.hotReload ?? false;
157
- }
158
- function resolveOptions(def, config) {
159
- if (!def.options) return void 0;
160
- return typeof def.options === "function" ? def.options(config) : def.options;
161
- }
162
- function getConfigValue(config, path2) {
163
- const parts = path2.split(".");
164
- let current = config;
165
- for (const part of parts) {
166
- if (current && typeof current === "object" && part in current) {
167
- current = current[part];
168
- } else {
169
- return void 0;
170
- }
171
- }
172
- return current;
173
- }
174
-
175
- export {
176
- CONFIG_REGISTRY,
177
- getFieldDef,
178
- getSafeFields,
179
- isHotReloadable,
180
- resolveOptions,
181
- getConfigValue
182
- };
183
- //# sourceMappingURL=chunk-JHYXKVV2.js.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../../src/core/config-registry.ts"],"sourcesContent":["import * as fs from \"node:fs\";\nimport * as path from \"node:path\";\nimport * as os from \"node:os\";\nimport type { Config } from \"./config.js\";\n\nexport interface ConfigFieldDef {\n path: string;\n displayName: string;\n group: string;\n type: \"toggle\" | \"select\" | \"number\" | \"string\";\n options?: string[] | ((config: Config) => string[]);\n scope: \"safe\" | \"sensitive\";\n hotReload: boolean;\n}\n\nexport const CONFIG_REGISTRY: ConfigFieldDef[] = [\n {\n path: \"defaultAgent\",\n displayName: \"Default Agent\",\n group: \"agent\",\n type: \"select\",\n options: (config) => {\n try {\n const agentsPath = path.join(os.homedir(), \".openacp\", \"agents.json\");\n if (fs.existsSync(agentsPath)) {\n const data = JSON.parse(fs.readFileSync(agentsPath, \"utf-8\"));\n return Object.keys(data.installed ?? {});\n }\n } catch {\n /* fallback */\n }\n return Object.keys(config.agents ?? {});\n },\n scope: \"safe\",\n hotReload: true,\n },\n {\n path: \"channels.telegram.displayVerbosity\",\n displayName: \"Telegram Verbosity\",\n group: \"display\",\n type: \"select\",\n options: [\"low\", \"medium\", \"high\"],\n scope: \"safe\",\n hotReload: true,\n },\n {\n path: \"channels.discord.displayVerbosity\",\n displayName: \"Discord Verbosity\",\n group: \"display\",\n type: \"select\",\n options: [\"low\", \"medium\", \"high\"],\n scope: \"safe\",\n hotReload: true,\n },\n {\n path: \"logging.level\",\n displayName: \"Log Level\",\n group: \"logging\",\n type: \"select\",\n options: [\"silent\", \"debug\", \"info\", \"warn\", \"error\", \"fatal\"],\n scope: \"safe\",\n hotReload: true,\n },\n {\n path: \"tunnel.enabled\",\n displayName: \"Tunnel\",\n group: \"tunnel\",\n type: \"toggle\",\n scope: \"safe\",\n hotReload: false,\n },\n {\n path: \"security.maxConcurrentSessions\",\n displayName: \"Max Concurrent Sessions\",\n group: \"security\",\n type: \"number\",\n scope: \"safe\",\n hotReload: true,\n },\n {\n path: \"security.sessionTimeoutMinutes\",\n displayName: \"Session Timeout (min)\",\n group: \"security\",\n type: \"number\",\n scope: \"safe\",\n hotReload: true,\n },\n {\n path: \"workspace.baseDir\",\n displayName: \"Workspace Directory\",\n group: \"workspace\",\n type: \"string\",\n scope: \"safe\",\n hotReload: true,\n },\n {\n path: \"sessionStore.ttlDays\",\n displayName: \"Session Store TTL (days)\",\n group: \"storage\",\n type: \"number\",\n scope: \"safe\",\n hotReload: true,\n },\n {\n path: \"speech.stt.provider\",\n displayName: \"Speech to Text\",\n group: \"speech\",\n type: \"select\",\n options: [\"groq\"],\n scope: \"safe\",\n hotReload: true,\n },\n {\n path: \"speech.stt.apiKey\",\n displayName: \"STT API Key\",\n group: \"speech\",\n type: \"string\",\n scope: \"sensitive\",\n hotReload: true,\n },\n {\n path: \"speech.tts.provider\",\n displayName: \"Text to Speech\",\n group: \"speech\",\n type: \"select\",\n options: [\"edge-tts\"],\n scope: \"safe\",\n hotReload: true,\n },\n {\n path: \"speech.tts.providers.edge-tts.voice\",\n displayName: \"Edge TTS Voice\",\n group: \"speech\",\n type: \"select\",\n options: [\n \"en-US-AriaNeural\",\n \"en-US-GuyNeural\",\n \"en-US-JennyNeural\",\n \"en-GB-SoniaNeural\",\n \"en-AU-NatashaNeural\",\n \"vi-VN-HoaiMyNeural\",\n \"vi-VN-NamMinhNeural\",\n \"zh-CN-XiaoxiaoNeural\",\n \"zh-CN-YunxiNeural\",\n \"ja-JP-NanamiNeural\",\n \"ja-JP-KeitaNeural\",\n \"ko-KR-SunHiNeural\",\n \"ko-KR-InJoonNeural\",\n \"es-ES-ElviraNeural\",\n \"fr-FR-DeniseNeural\",\n \"de-DE-KatjaNeural\",\n \"pt-BR-FranciscaNeural\",\n \"hi-IN-SwaraNeural\",\n \"ar-SA-ZariyahNeural\",\n ],\n scope: \"safe\",\n hotReload: true,\n },\n];\n\nexport function getFieldDef(path: string): ConfigFieldDef | undefined {\n return CONFIG_REGISTRY.find((f) => f.path === path);\n}\n\nexport function getSafeFields(): ConfigFieldDef[] {\n return CONFIG_REGISTRY.filter((f) => f.scope === \"safe\");\n}\n\nexport function isHotReloadable(path: string): boolean {\n const def = getFieldDef(path);\n return def?.hotReload ?? false;\n}\n\nexport function resolveOptions(\n def: ConfigFieldDef,\n config: Config,\n): string[] | undefined {\n if (!def.options) return undefined;\n return typeof def.options === \"function\" ? def.options(config) : def.options;\n}\n\nexport function getConfigValue(config: Config, path: string): unknown {\n const parts = path.split(\".\");\n let current: unknown = config;\n for (const part of parts) {\n if (current && typeof current === \"object\" && part in current) {\n current = (current as Record<string, unknown>)[part];\n } else {\n return undefined;\n }\n }\n return current;\n}\n"],"mappings":"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","names":["path"]}