@openacp/cli 0.4.5 → 0.4.8
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.
- package/README.md +81 -15
- package/dist/agent-registry-7HC6D4CH.js +7 -0
- package/dist/{chunk-WHKLPZGK.js → chunk-6MJLVZXV.js} +8 -8
- package/dist/{chunk-V5P3K4A5.js → chunk-BBPWAWE3.js} +1137 -119
- package/dist/chunk-BBPWAWE3.js.map +1 -0
- package/dist/{chunk-3QACY5E3.js → chunk-C6YIUTGR.js} +2 -2
- package/dist/{chunk-2SY7Y2VB.js → chunk-HZD3CGPK.js} +2 -2
- package/dist/{chunk-BLVZFCKN.js → chunk-UAUTLC4E.js} +27 -3
- package/dist/{chunk-BLVZFCKN.js.map → chunk-UAUTLC4E.js.map} +1 -1
- package/dist/chunk-VA2M52CM.js +15 -0
- package/dist/chunk-VA2M52CM.js.map +1 -0
- package/dist/{chunk-WF5XDN4D.js → chunk-ZRFBLD3W.js} +6 -2
- package/dist/chunk-ZRFBLD3W.js.map +1 -0
- package/dist/cli.js +388 -38
- package/dist/cli.js.map +1 -1
- package/dist/{config-J5YQOMDU.js → config-H2DSEHNW.js} +2 -2
- package/dist/config-editor-SKS4LJLT.js +11 -0
- package/dist/{daemon-SLGQGRKO.js → daemon-VF6HJQXD.js} +3 -3
- package/dist/index.d.ts +111 -10
- package/dist/index.js +13 -10
- package/dist/integrate-WUPLRJD3.js +145 -0
- package/dist/integrate-WUPLRJD3.js.map +1 -0
- package/dist/{main-3CDOICYN.js → main-NV7YN3VY.js} +27 -14
- package/dist/main-NV7YN3VY.js.map +1 -0
- package/dist/{setup-JQZBPXWS.js → setup-FCVL75K6.js} +3 -3
- package/dist/setup-FCVL75K6.js.map +1 -0
- package/package.json +1 -1
- package/dist/chunk-V5P3K4A5.js.map +0 -1
- package/dist/chunk-WF5XDN4D.js.map +0 -1
- package/dist/config-editor-IXL4BFG3.js +0 -11
- package/dist/main-3CDOICYN.js.map +0 -1
- /package/dist/{config-J5YQOMDU.js.map → agent-registry-7HC6D4CH.js.map} +0 -0
- /package/dist/{chunk-WHKLPZGK.js.map → chunk-6MJLVZXV.js.map} +0 -0
- /package/dist/{chunk-3QACY5E3.js.map → chunk-C6YIUTGR.js.map} +0 -0
- /package/dist/{chunk-2SY7Y2VB.js.map → chunk-HZD3CGPK.js.map} +0 -0
- /package/dist/{config-editor-IXL4BFG3.js.map → config-H2DSEHNW.js.map} +0 -0
- /package/dist/{daemon-SLGQGRKO.js.map → config-editor-SKS4LJLT.js.map} +0 -0
- /package/dist/{setup-JQZBPXWS.js.map → daemon-VF6HJQXD.js.map} +0 -0
package/dist/cli.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/cli.ts","../../src/core/api-client.ts","../../src/cli/commands.ts"],"sourcesContent":["#!/usr/bin/env node\n\nimport { setDefaultAutoSelectFamily } from \"node:net\";\nsetDefaultAutoSelectFamily(false);\n\nimport {\n printHelp,\n cmdVersion,\n cmdInstall,\n cmdUninstall,\n cmdPlugins,\n cmdRuntime,\n cmdStart,\n cmdStop,\n cmdStatus,\n cmdLogs,\n cmdConfig,\n cmdReset,\n cmdUpdate,\n cmdDefault,\n} from './cli/commands.js'\n\nconst args = process.argv.slice(2);\nconst command = args[0];\n\nconst commands: Record<string, () => Promise<void>> = {\n '--help': async () => printHelp(),\n '-h': async () => printHelp(),\n '--version': () => cmdVersion(),\n '-v': () => cmdVersion(),\n 'install': () => cmdInstall(args),\n 'uninstall': () => cmdUninstall(args),\n 'plugins': () => cmdPlugins(),\n 'runtime': () => cmdRuntime(args),\n 'start': () => cmdStart(),\n 'stop': () => cmdStop(),\n 'status': () => cmdStatus(),\n 'logs': () => cmdLogs(),\n 'config': () => cmdConfig(),\n 'reset': () => cmdReset(),\n 'update': () => cmdUpdate(),\n '--daemon-child': async () => {\n const { startServer } = await import('./main.js')\n await startServer()\n },\n}\n\nasync function main() {\n const handler = command ? commands[command] : undefined\n if (handler) {\n await handler()\n } else {\n await cmdDefault(command)\n }\n}\n\nmain().catch((err) => {\n console.error(\"Fatal:\", err);\n process.exit(1);\n});\n","import * as fs from 'node:fs'\nimport * as path from 'node:path'\nimport * as os from 'node:os'\n\nconst DEFAULT_PORT_FILE = path.join(os.homedir(), '.openacp', 'api.port')\n\nexport function readApiPort(portFilePath: string = DEFAULT_PORT_FILE): number | null {\n try {\n const content = fs.readFileSync(portFilePath, 'utf-8').trim()\n const port = parseInt(content, 10)\n return isNaN(port) ? null : port\n } catch {\n return null\n }\n}\n\nexport function removeStalePortFile(portFilePath: string = DEFAULT_PORT_FILE): void {\n try {\n fs.unlinkSync(portFilePath)\n } catch {\n // ignore\n }\n}\n\nexport async function apiCall(\n port: number,\n urlPath: string,\n options?: RequestInit,\n): Promise<Response> {\n return fetch(`http://127.0.0.1:${port}${urlPath}`, options)\n}\n","import { installPlugin, uninstallPlugin, listPlugins } from '../core/plugin-manager.js'\nimport { readApiPort, removeStalePortFile, apiCall } from '../core/api-client.js'\nimport { getCurrentVersion, getLatestVersion, compareVersions, runUpdate, checkAndPromptUpdate } from './version.js'\n\nexport function printHelp(): void {\n console.log(`\nOpenACP - Self-hosted bridge for AI coding agents\n\nUsage:\n openacp Start (mode from config)\n openacp start Start as background daemon\n openacp stop Stop background daemon\n openacp status Show daemon status\n openacp logs Tail daemon log file\n openacp config Edit configuration\n openacp reset Delete all data and start fresh\n openacp update Update to latest version\n openacp install <package> Install a plugin adapter\n openacp uninstall <package> Uninstall a plugin adapter\n openacp plugins List installed plugins\n openacp --foreground Force foreground mode\n openacp --version Show version\n openacp --help Show this help\n\nRuntime (requires running daemon):\n openacp runtime new [agent] [workspace] Create a new session\n openacp runtime cancel <id> Cancel a session\n openacp runtime status Show active sessions\n openacp runtime agents List available agents\n\nNote: \"openacp status\" shows daemon process health.\n \"openacp runtime status\" shows active agent sessions.\n\nInstall:\n npm install -g @openacp/cli\n\nExamples:\n openacp\n openacp install @openacp/adapter-discord\n openacp uninstall @openacp/adapter-discord\n`)\n}\n\nexport async function cmdVersion(): Promise<void> {\n try {\n const { createRequire } = await import(\"node:module\")\n const require = createRequire(import.meta.url)\n const pkg = require(\"../../package.json\")\n console.log(`openacp v${pkg.version}`)\n } catch {\n console.log(\"openacp v0.0.0-dev\")\n }\n}\n\nexport async function cmdInstall(args: string[]): Promise<void> {\n const pkg = args[1]\n if (!pkg) {\n console.error(\"Usage: openacp install <package>\")\n process.exit(1)\n }\n installPlugin(pkg)\n}\n\nexport async function cmdUninstall(args: string[]): Promise<void> {\n const pkg = args[1]\n if (!pkg) {\n console.error(\"Usage: openacp uninstall <package>\")\n process.exit(1)\n }\n uninstallPlugin(pkg)\n}\n\nexport async function cmdPlugins(): Promise<void> {\n const plugins = listPlugins()\n const entries = Object.entries(plugins)\n if (entries.length === 0) {\n console.log(\"No plugins installed.\")\n } else {\n console.log(\"Installed plugins:\")\n for (const [name, version] of entries) {\n console.log(` ${name}@${version}`)\n }\n }\n}\n\nexport async function cmdRuntime(args: string[]): Promise<void> {\n const subCmd = args[1]\n\n const port = readApiPort()\n if (port === null) {\n console.error('OpenACP is not running. Start with `openacp start`')\n process.exit(1)\n }\n\n try {\n if (subCmd === 'new') {\n const agent = args[2]\n const workspaceIdx = args.indexOf('--workspace')\n const workspace = workspaceIdx !== -1 ? args[workspaceIdx + 1] : args[3]\n const body: Record<string, string> = {}\n if (agent) body.agent = agent\n if (workspace) body.workspace = workspace\n\n const res = await apiCall(port, '/api/sessions', {\n method: 'POST',\n headers: { 'Content-Type': 'application/json' },\n body: JSON.stringify(body),\n })\n const data = await res.json() as Record<string, unknown>\n if (!res.ok) {\n console.error(`Error: ${data.error}`)\n process.exit(1)\n }\n console.log('Session created')\n console.log(` ID : ${data.sessionId}`)\n console.log(` Agent : ${data.agent}`)\n console.log(` Workspace : ${data.workspace}`)\n console.log(` Status : ${data.status}`)\n\n } else if (subCmd === 'cancel') {\n const sessionId = args[2]\n if (!sessionId) {\n console.error('Usage: openacp runtime cancel <session-id>')\n process.exit(1)\n }\n const res = await apiCall(port, `/api/sessions/${encodeURIComponent(sessionId)}`, {\n method: 'DELETE',\n })\n const data = await res.json() as Record<string, unknown>\n if (!res.ok) {\n console.error(`Error: ${data.error}`)\n process.exit(1)\n }\n console.log(`Session ${sessionId} cancelled`)\n\n } else if (subCmd === 'status') {\n const res = await apiCall(port, '/api/sessions')\n const data = await res.json() as { sessions: Array<{ id: string; agent: string; status: string; name: string | null }> }\n if (data.sessions.length === 0) {\n console.log('No active sessions.')\n } else {\n console.log(`Active sessions: ${data.sessions.length}\\n`)\n for (const s of data.sessions) {\n const name = s.name ? ` \"${s.name}\"` : ''\n console.log(` ${s.id} ${s.agent} ${s.status}${name}`)\n }\n }\n\n } else if (subCmd === 'agents') {\n const res = await apiCall(port, '/api/agents')\n const data = await res.json() as { agents: Array<{ name: string; command: string; args: string[] }>; default: string }\n console.log('Available agents:')\n for (const a of data.agents) {\n const isDefault = a.name === data.default ? ' (default)' : ''\n console.log(` ${a.name}${isDefault}`)\n }\n\n } else {\n console.error(`Unknown runtime command: ${subCmd || '(none)'}\\n`)\n console.log('Usage:')\n console.log(' openacp runtime new [agent] [workspace] Create a new session')\n console.log(' openacp runtime cancel <id> Cancel a session')\n console.log(' openacp runtime status Show active sessions')\n console.log(' openacp runtime agents List available agents')\n process.exit(1)\n }\n } catch (err) {\n if (err instanceof TypeError && (err as any).cause?.code === 'ECONNREFUSED') {\n console.error('OpenACP is not running (stale port file)')\n removeStalePortFile()\n process.exit(1)\n }\n throw err\n }\n}\n\nexport async function cmdStart(): Promise<void> {\n await checkAndPromptUpdate()\n const { startDaemon, getPidPath } = await import('../core/daemon.js')\n const { ConfigManager } = await import('../core/config.js')\n const cm = new ConfigManager()\n if (await cm.exists()) {\n await cm.load()\n const config = cm.get()\n const result = startDaemon(getPidPath(), config.logging.logDir)\n if ('error' in result) {\n console.error(result.error)\n process.exit(1)\n }\n console.log(`OpenACP daemon started (PID ${result.pid})`)\n } else {\n console.error('No config found. Run \"openacp\" first to set up.')\n process.exit(1)\n }\n}\n\nexport async function cmdStop(): Promise<void> {\n const { stopDaemon } = await import('../core/daemon.js')\n const result = stopDaemon()\n if (result.stopped) {\n console.log(`OpenACP daemon stopped (was PID ${result.pid})`)\n } else {\n console.error(result.error)\n process.exit(1)\n }\n}\n\nexport async function cmdStatus(): Promise<void> {\n const { getStatus } = await import('../core/daemon.js')\n const status = getStatus()\n if (status.running) {\n console.log(`OpenACP is running (PID ${status.pid})`)\n } else {\n console.log('OpenACP is not running')\n }\n}\n\nexport async function cmdLogs(): Promise<void> {\n const { spawn } = await import('node:child_process')\n const { ConfigManager, expandHome } = await import('../core/config.js')\n const pathMod = await import('node:path')\n const cm = new ConfigManager()\n let logDir = '~/.openacp/logs'\n if (await cm.exists()) {\n await cm.load()\n logDir = cm.get().logging.logDir\n }\n const logFile = pathMod.join(expandHome(logDir), 'openacp.log')\n const tail = spawn('tail', ['-f', '-n', '50', logFile], { stdio: 'inherit' })\n tail.on('error', (err: Error) => {\n console.error(`Cannot tail log file: ${err.message}`)\n process.exit(1)\n })\n}\n\nexport async function cmdConfig(): Promise<void> {\n const { runConfigEditor } = await import('../core/config-editor.js')\n const { ConfigManager } = await import('../core/config.js')\n const cm = new ConfigManager()\n if (!(await cm.exists())) {\n console.error('No config found. Run \"openacp\" first to set up.')\n process.exit(1)\n }\n await runConfigEditor(cm)\n}\n\nexport async function cmdReset(): Promise<void> {\n const { getStatus } = await import('../core/daemon.js')\n const status = getStatus()\n if (status.running) {\n console.error('OpenACP is running. Stop it first: openacp stop')\n process.exit(1)\n }\n\n const { confirm } = await import('@inquirer/prompts')\n const yes = await confirm({\n message: 'This will delete all OpenACP data (~/.openacp). You will need to set up again. Continue?',\n default: false,\n })\n if (!yes) {\n console.log('Aborted.')\n return\n }\n\n const { uninstallAutoStart } = await import('../core/autostart.js')\n uninstallAutoStart()\n\n const fs = await import('node:fs')\n const os = await import('node:os')\n const path = await import('node:path')\n const openacpDir = path.join(os.homedir(), '.openacp')\n fs.rmSync(openacpDir, { recursive: true, force: true })\n\n console.log('Reset complete. Run `openacp` to set up again.')\n}\n\nexport async function cmdUpdate(): Promise<void> {\n const current = getCurrentVersion()\n const latest = await getLatestVersion()\n if (!latest) {\n console.error('Could not check for updates. Check your internet connection.')\n process.exit(1)\n }\n if (compareVersions(current, latest) >= 0) {\n console.log(`Already up to date (v${current})`)\n return\n }\n console.log(`Update available: v${current} → v${latest}`)\n const ok = await runUpdate()\n if (ok) {\n console.log(`\\x1b[32m✓ Updated to v${latest}\\x1b[0m`)\n } else {\n console.error('Update failed. Try manually: npm install -g @openacp/cli@latest')\n process.exit(1)\n }\n}\n\nexport async function cmdDefault(command: string | undefined): Promise<void> {\n const forceForeground = command === '--foreground'\n\n // Reject unknown commands\n if (command && !command.startsWith('-')) {\n console.error(`Unknown command: ${command}`)\n printHelp()\n process.exit(1)\n }\n\n await checkAndPromptUpdate()\n\n const { ConfigManager } = await import('../core/config.js')\n const cm = new ConfigManager()\n\n // If no config, run setup first\n if (!(await cm.exists())) {\n const { runSetup } = await import('../core/setup.js')\n const shouldStart = await runSetup(cm)\n if (!shouldStart) process.exit(0)\n }\n\n await cm.load()\n const config = cm.get()\n\n if (!forceForeground && config.runMode === 'daemon') {\n const { startDaemon, getPidPath } = await import('../core/daemon.js')\n const result = startDaemon(getPidPath(), config.logging.logDir)\n if ('error' in result) {\n console.error(result.error)\n process.exit(1)\n }\n console.log(`OpenACP daemon started (PID ${result.pid})`)\n return\n }\n\n const { markRunning } = await import('../core/daemon.js')\n markRunning()\n const { startServer } = await import('../main.js')\n await startServer()\n}\n"],"mappings":";;;;;;;;;;;;;;;;;AAEA,SAAS,kCAAkC;;;ACF3C,YAAY,QAAQ;AACpB,YAAY,UAAU;AACtB,YAAY,QAAQ;AAEpB,IAAM,oBAAyB,UAAQ,WAAQ,GAAG,YAAY,UAAU;AAEjE,SAAS,YAAY,eAAuB,mBAAkC;AACnF,MAAI;AACF,UAAM,UAAa,gBAAa,cAAc,OAAO,EAAE,KAAK;AAC5D,UAAM,OAAO,SAAS,SAAS,EAAE;AACjC,WAAO,MAAM,IAAI,IAAI,OAAO;AAAA,EAC9B,QAAQ;AACN,WAAO;AAAA,EACT;AACF;AAEO,SAAS,oBAAoB,eAAuB,mBAAyB;AAClF,MAAI;AACF,IAAG,cAAW,YAAY;AAAA,EAC5B,QAAQ;AAAA,EAER;AACF;AAEA,eAAsB,QACpB,MACA,SACA,SACmB;AACnB,SAAO,MAAM,oBAAoB,IAAI,GAAG,OAAO,IAAI,OAAO;AAC5D;;;AC1BO,SAAS,YAAkB;AAChC,UAAQ,IAAI;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,CAmCb;AACD;AAEA,eAAsB,aAA4B;AAChD,MAAI;AACF,UAAM,EAAE,cAAc,IAAI,MAAM,OAAO,QAAa;AACpD,UAAMA,WAAU,cAAc,YAAY,GAAG;AAC7C,UAAM,MAAMA,SAAQ,oBAAoB;AACxC,YAAQ,IAAI,YAAY,IAAI,OAAO,EAAE;AAAA,EACvC,QAAQ;AACN,YAAQ,IAAI,oBAAoB;AAAA,EAClC;AACF;AAEA,eAAsB,WAAWC,OAA+B;AAC9D,QAAM,MAAMA,MAAK,CAAC;AAClB,MAAI,CAAC,KAAK;AACR,YAAQ,MAAM,kCAAkC;AAChD,YAAQ,KAAK,CAAC;AAAA,EAChB;AACA,gBAAc,GAAG;AACnB;AAEA,eAAsB,aAAaA,OAA+B;AAChE,QAAM,MAAMA,MAAK,CAAC;AAClB,MAAI,CAAC,KAAK;AACR,YAAQ,MAAM,oCAAoC;AAClD,YAAQ,KAAK,CAAC;AAAA,EAChB;AACA,kBAAgB,GAAG;AACrB;AAEA,eAAsB,aAA4B;AAChD,QAAM,UAAU,YAAY;AAC5B,QAAM,UAAU,OAAO,QAAQ,OAAO;AACtC,MAAI,QAAQ,WAAW,GAAG;AACxB,YAAQ,IAAI,uBAAuB;AAAA,EACrC,OAAO;AACL,YAAQ,IAAI,oBAAoB;AAChC,eAAW,CAAC,MAAM,OAAO,KAAK,SAAS;AACrC,cAAQ,IAAI,KAAK,IAAI,IAAI,OAAO,EAAE;AAAA,IACpC;AAAA,EACF;AACF;AAEA,eAAsB,WAAWA,OAA+B;AAC9D,QAAM,SAASA,MAAK,CAAC;AAErB,QAAM,OAAO,YAAY;AACzB,MAAI,SAAS,MAAM;AACjB,YAAQ,MAAM,oDAAoD;AAClE,YAAQ,KAAK,CAAC;AAAA,EAChB;AAEA,MAAI;AACF,QAAI,WAAW,OAAO;AACpB,YAAM,QAAQA,MAAK,CAAC;AACpB,YAAM,eAAeA,MAAK,QAAQ,aAAa;AAC/C,YAAM,YAAY,iBAAiB,KAAKA,MAAK,eAAe,CAAC,IAAIA,MAAK,CAAC;AACvE,YAAM,OAA+B,CAAC;AACtC,UAAI,MAAO,MAAK,QAAQ;AACxB,UAAI,UAAW,MAAK,YAAY;AAEhC,YAAM,MAAM,MAAM,QAAQ,MAAM,iBAAiB;AAAA,QAC/C,QAAQ;AAAA,QACR,SAAS,EAAE,gBAAgB,mBAAmB;AAAA,QAC9C,MAAM,KAAK,UAAU,IAAI;AAAA,MAC3B,CAAC;AACD,YAAM,OAAO,MAAM,IAAI,KAAK;AAC5B,UAAI,CAAC,IAAI,IAAI;AACX,gBAAQ,MAAM,UAAU,KAAK,KAAK,EAAE;AACpC,gBAAQ,KAAK,CAAC;AAAA,MAChB;AACA,cAAQ,IAAI,iBAAiB;AAC7B,cAAQ,IAAI,iBAAiB,KAAK,SAAS,EAAE;AAC7C,cAAQ,IAAI,iBAAiB,KAAK,KAAK,EAAE;AACzC,cAAQ,IAAI,iBAAiB,KAAK,SAAS,EAAE;AAC7C,cAAQ,IAAI,iBAAiB,KAAK,MAAM,EAAE;AAAA,IAE5C,WAAW,WAAW,UAAU;AAC9B,YAAM,YAAYA,MAAK,CAAC;AACxB,UAAI,CAAC,WAAW;AACd,gBAAQ,MAAM,4CAA4C;AAC1D,gBAAQ,KAAK,CAAC;AAAA,MAChB;AACA,YAAM,MAAM,MAAM,QAAQ,MAAM,iBAAiB,mBAAmB,SAAS,CAAC,IAAI;AAAA,QAChF,QAAQ;AAAA,MACV,CAAC;AACD,YAAM,OAAO,MAAM,IAAI,KAAK;AAC5B,UAAI,CAAC,IAAI,IAAI;AACX,gBAAQ,MAAM,UAAU,KAAK,KAAK,EAAE;AACpC,gBAAQ,KAAK,CAAC;AAAA,MAChB;AACA,cAAQ,IAAI,WAAW,SAAS,YAAY;AAAA,IAE9C,WAAW,WAAW,UAAU;AAC9B,YAAM,MAAM,MAAM,QAAQ,MAAM,eAAe;AAC/C,YAAM,OAAO,MAAM,IAAI,KAAK;AAC5B,UAAI,KAAK,SAAS,WAAW,GAAG;AAC9B,gBAAQ,IAAI,qBAAqB;AAAA,MACnC,OAAO;AACL,gBAAQ,IAAI,oBAAoB,KAAK,SAAS,MAAM;AAAA,CAAI;AACxD,mBAAW,KAAK,KAAK,UAAU;AAC7B,gBAAM,OAAO,EAAE,OAAO,MAAM,EAAE,IAAI,MAAM;AACxC,kBAAQ,IAAI,KAAK,EAAE,EAAE,KAAK,EAAE,KAAK,KAAK,EAAE,MAAM,GAAG,IAAI,EAAE;AAAA,QACzD;AAAA,MACF;AAAA,IAEF,WAAW,WAAW,UAAU;AAC9B,YAAM,MAAM,MAAM,QAAQ,MAAM,aAAa;AAC7C,YAAM,OAAO,MAAM,IAAI,KAAK;AAC5B,cAAQ,IAAI,mBAAmB;AAC/B,iBAAW,KAAK,KAAK,QAAQ;AAC3B,cAAM,YAAY,EAAE,SAAS,KAAK,UAAU,eAAe;AAC3D,gBAAQ,IAAI,KAAK,EAAE,IAAI,GAAG,SAAS,EAAE;AAAA,MACvC;AAAA,IAEF,OAAO;AACL,cAAQ,MAAM,4BAA4B,UAAU,QAAQ;AAAA,CAAI;AAChE,cAAQ,IAAI,QAAQ;AACpB,cAAQ,IAAI,iEAAiE;AAC7E,cAAQ,IAAI,wDAAwD;AACpE,cAAQ,IAAI,4DAA4D;AACxE,cAAQ,IAAI,6DAA6D;AACzE,cAAQ,KAAK,CAAC;AAAA,IAChB;AAAA,EACF,SAAS,KAAK;AACZ,QAAI,eAAe,aAAc,IAAY,OAAO,SAAS,gBAAgB;AAC3E,cAAQ,MAAM,0CAA0C;AACxD,0BAAoB;AACpB,cAAQ,KAAK,CAAC;AAAA,IAChB;AACA,UAAM;AAAA,EACR;AACF;AAEA,eAAsB,WAA0B;AAC9C,QAAM,qBAAqB;AAC3B,QAAM,EAAE,aAAa,WAAW,IAAI,MAAM,OAAO,sBAAmB;AACpE,QAAM,EAAE,cAAc,IAAI,MAAM,OAAO,sBAAmB;AAC1D,QAAM,KAAK,IAAI,cAAc;AAC7B,MAAI,MAAM,GAAG,OAAO,GAAG;AACrB,UAAM,GAAG,KAAK;AACd,UAAM,SAAS,GAAG,IAAI;AACtB,UAAM,SAAS,YAAY,WAAW,GAAG,OAAO,QAAQ,MAAM;AAC9D,QAAI,WAAW,QAAQ;AACrB,cAAQ,MAAM,OAAO,KAAK;AAC1B,cAAQ,KAAK,CAAC;AAAA,IAChB;AACA,YAAQ,IAAI,+BAA+B,OAAO,GAAG,GAAG;AAAA,EAC1D,OAAO;AACL,YAAQ,MAAM,iDAAiD;AAC/D,YAAQ,KAAK,CAAC;AAAA,EAChB;AACF;AAEA,eAAsB,UAAyB;AAC7C,QAAM,EAAE,WAAW,IAAI,MAAM,OAAO,sBAAmB;AACvD,QAAM,SAAS,WAAW;AAC1B,MAAI,OAAO,SAAS;AAClB,YAAQ,IAAI,mCAAmC,OAAO,GAAG,GAAG;AAAA,EAC9D,OAAO;AACL,YAAQ,MAAM,OAAO,KAAK;AAC1B,YAAQ,KAAK,CAAC;AAAA,EAChB;AACF;AAEA,eAAsB,YAA2B;AAC/C,QAAM,EAAE,UAAU,IAAI,MAAM,OAAO,sBAAmB;AACtD,QAAM,SAAS,UAAU;AACzB,MAAI,OAAO,SAAS;AAClB,YAAQ,IAAI,2BAA2B,OAAO,GAAG,GAAG;AAAA,EACtD,OAAO;AACL,YAAQ,IAAI,wBAAwB;AAAA,EACtC;AACF;AAEA,eAAsB,UAAyB;AAC7C,QAAM,EAAE,MAAM,IAAI,MAAM,OAAO,eAAoB;AACnD,QAAM,EAAE,eAAe,WAAW,IAAI,MAAM,OAAO,sBAAmB;AACtE,QAAM,UAAU,MAAM,OAAO,MAAW;AACxC,QAAM,KAAK,IAAI,cAAc;AAC7B,MAAI,SAAS;AACb,MAAI,MAAM,GAAG,OAAO,GAAG;AACrB,UAAM,GAAG,KAAK;AACd,aAAS,GAAG,IAAI,EAAE,QAAQ;AAAA,EAC5B;AACA,QAAM,UAAU,QAAQ,KAAK,WAAW,MAAM,GAAG,aAAa;AAC9D,QAAM,OAAO,MAAM,QAAQ,CAAC,MAAM,MAAM,MAAM,OAAO,GAAG,EAAE,OAAO,UAAU,CAAC;AAC5E,OAAK,GAAG,SAAS,CAAC,QAAe;AAC/B,YAAQ,MAAM,yBAAyB,IAAI,OAAO,EAAE;AACpD,YAAQ,KAAK,CAAC;AAAA,EAChB,CAAC;AACH;AAEA,eAAsB,YAA2B;AAC/C,QAAM,EAAE,gBAAgB,IAAI,MAAM,OAAO,6BAA0B;AACnE,QAAM,EAAE,cAAc,IAAI,MAAM,OAAO,sBAAmB;AAC1D,QAAM,KAAK,IAAI,cAAc;AAC7B,MAAI,CAAE,MAAM,GAAG,OAAO,GAAI;AACxB,YAAQ,MAAM,iDAAiD;AAC/D,YAAQ,KAAK,CAAC;AAAA,EAChB;AACA,QAAM,gBAAgB,EAAE;AAC1B;AAEA,eAAsB,WAA0B;AAC9C,QAAM,EAAE,UAAU,IAAI,MAAM,OAAO,sBAAmB;AACtD,QAAM,SAAS,UAAU;AACzB,MAAI,OAAO,SAAS;AAClB,YAAQ,MAAM,iDAAiD;AAC/D,YAAQ,KAAK,CAAC;AAAA,EAChB;AAEA,QAAM,EAAE,QAAQ,IAAI,MAAM,OAAO,mBAAmB;AACpD,QAAM,MAAM,MAAM,QAAQ;AAAA,IACxB,SAAS;AAAA,IACT,SAAS;AAAA,EACX,CAAC;AACD,MAAI,CAAC,KAAK;AACR,YAAQ,IAAI,UAAU;AACtB;AAAA,EACF;AAEA,QAAM,EAAE,mBAAmB,IAAI,MAAM,OAAO,yBAAsB;AAClE,qBAAmB;AAEnB,QAAMC,MAAK,MAAM,OAAO,IAAS;AACjC,QAAMC,MAAK,MAAM,OAAO,IAAS;AACjC,QAAMC,QAAO,MAAM,OAAO,MAAW;AACrC,QAAM,aAAaA,MAAK,KAAKD,IAAG,QAAQ,GAAG,UAAU;AACrD,EAAAD,IAAG,OAAO,YAAY,EAAE,WAAW,MAAM,OAAO,KAAK,CAAC;AAEtD,UAAQ,IAAI,gDAAgD;AAC9D;AAEA,eAAsB,YAA2B;AAC/C,QAAM,UAAU,kBAAkB;AAClC,QAAM,SAAS,MAAM,iBAAiB;AACtC,MAAI,CAAC,QAAQ;AACX,YAAQ,MAAM,8DAA8D;AAC5E,YAAQ,KAAK,CAAC;AAAA,EAChB;AACA,MAAI,gBAAgB,SAAS,MAAM,KAAK,GAAG;AACzC,YAAQ,IAAI,wBAAwB,OAAO,GAAG;AAC9C;AAAA,EACF;AACA,UAAQ,IAAI,sBAAsB,OAAO,YAAO,MAAM,EAAE;AACxD,QAAM,KAAK,MAAM,UAAU;AAC3B,MAAI,IAAI;AACN,YAAQ,IAAI,8BAAyB,MAAM,SAAS;AAAA,EACtD,OAAO;AACL,YAAQ,MAAM,iEAAiE;AAC/E,YAAQ,KAAK,CAAC;AAAA,EAChB;AACF;AAEA,eAAsB,WAAWG,UAA4C;AAC3E,QAAM,kBAAkBA,aAAY;AAGpC,MAAIA,YAAW,CAACA,SAAQ,WAAW,GAAG,GAAG;AACvC,YAAQ,MAAM,oBAAoBA,QAAO,EAAE;AAC3C,cAAU;AACV,YAAQ,KAAK,CAAC;AAAA,EAChB;AAEA,QAAM,qBAAqB;AAE3B,QAAM,EAAE,cAAc,IAAI,MAAM,OAAO,sBAAmB;AAC1D,QAAM,KAAK,IAAI,cAAc;AAG7B,MAAI,CAAE,MAAM,GAAG,OAAO,GAAI;AACxB,UAAM,EAAE,SAAS,IAAI,MAAM,OAAO,qBAAkB;AACpD,UAAM,cAAc,MAAM,SAAS,EAAE;AACrC,QAAI,CAAC,YAAa,SAAQ,KAAK,CAAC;AAAA,EAClC;AAEA,QAAM,GAAG,KAAK;AACd,QAAM,SAAS,GAAG,IAAI;AAEtB,MAAI,CAAC,mBAAmB,OAAO,YAAY,UAAU;AACnD,UAAM,EAAE,aAAa,WAAW,IAAI,MAAM,OAAO,sBAAmB;AACpE,UAAM,SAAS,YAAY,WAAW,GAAG,OAAO,QAAQ,MAAM;AAC9D,QAAI,WAAW,QAAQ;AACrB,cAAQ,MAAM,OAAO,KAAK;AAC1B,cAAQ,KAAK,CAAC;AAAA,IAChB;AACA,YAAQ,IAAI,+BAA+B,OAAO,GAAG,GAAG;AACxD;AAAA,EACF;AAEA,QAAM,EAAE,YAAY,IAAI,MAAM,OAAO,sBAAmB;AACxD,cAAY;AACZ,QAAM,EAAE,YAAY,IAAI,MAAM,OAAO,oBAAY;AACjD,QAAM,YAAY;AACpB;;;AF9UA,2BAA2B,KAAK;AAmBhC,IAAM,OAAO,QAAQ,KAAK,MAAM,CAAC;AACjC,IAAM,UAAU,KAAK,CAAC;AAEtB,IAAM,WAAgD;AAAA,EACpD,UAAU,YAAY,UAAU;AAAA,EAChC,MAAM,YAAY,UAAU;AAAA,EAC5B,aAAa,MAAM,WAAW;AAAA,EAC9B,MAAM,MAAM,WAAW;AAAA,EACvB,WAAW,MAAM,WAAW,IAAI;AAAA,EAChC,aAAa,MAAM,aAAa,IAAI;AAAA,EACpC,WAAW,MAAM,WAAW;AAAA,EAC5B,WAAW,MAAM,WAAW,IAAI;AAAA,EAChC,SAAS,MAAM,SAAS;AAAA,EACxB,QAAQ,MAAM,QAAQ;AAAA,EACtB,UAAU,MAAM,UAAU;AAAA,EAC1B,QAAQ,MAAM,QAAQ;AAAA,EACtB,UAAU,MAAM,UAAU;AAAA,EAC1B,SAAS,MAAM,SAAS;AAAA,EACxB,UAAU,MAAM,UAAU;AAAA,EAC1B,kBAAkB,YAAY;AAC5B,UAAM,EAAE,YAAY,IAAI,MAAM,OAAO,oBAAW;AAChD,UAAM,YAAY;AAAA,EACpB;AACF;AAEA,eAAe,OAAO;AACpB,QAAM,UAAU,UAAU,SAAS,OAAO,IAAI;AAC9C,MAAI,SAAS;AACX,UAAM,QAAQ;AAAA,EAChB,OAAO;AACL,UAAM,WAAW,OAAO;AAAA,EAC1B;AACF;AAEA,KAAK,EAAE,MAAM,CAAC,QAAQ;AACpB,UAAQ,MAAM,UAAU,GAAG;AAC3B,UAAQ,KAAK,CAAC;AAChB,CAAC;","names":["require","args","fs","os","path","command"]}
|
|
1
|
+
{"version":3,"sources":["../../src/cli.ts","../../src/core/api-client.ts","../../src/cli/commands.ts"],"sourcesContent":["#!/usr/bin/env node\n\nimport { setDefaultAutoSelectFamily } from \"node:net\";\nsetDefaultAutoSelectFamily(false);\n\nimport {\n printHelp,\n cmdVersion,\n cmdInstall,\n cmdUninstall,\n cmdPlugins,\n cmdApi,\n cmdStart,\n cmdStop,\n cmdStatus,\n cmdLogs,\n cmdConfig,\n cmdReset,\n cmdUpdate,\n cmdDefault,\n cmdAdopt,\n cmdIntegrate,\n} from './cli/commands.js'\n\nconst args = process.argv.slice(2);\nconst command = args[0];\n\nconst commands: Record<string, () => Promise<void>> = {\n '--help': async () => printHelp(),\n '-h': async () => printHelp(),\n '--version': () => cmdVersion(),\n '-v': () => cmdVersion(),\n 'install': () => cmdInstall(args),\n 'uninstall': () => cmdUninstall(args),\n 'plugins': () => cmdPlugins(),\n 'api': () => cmdApi(args),\n 'start': () => cmdStart(),\n 'stop': () => cmdStop(),\n 'status': () => cmdStatus(),\n 'logs': () => cmdLogs(),\n 'config': () => cmdConfig(),\n 'reset': () => cmdReset(),\n 'update': () => cmdUpdate(),\n 'adopt': () => cmdAdopt(args),\n 'integrate': () => cmdIntegrate(args),\n '--daemon-child': async () => {\n const { startServer } = await import('./main.js')\n await startServer()\n },\n}\n\nasync function main() {\n const handler = command ? commands[command] : undefined\n if (handler) {\n await handler()\n } else {\n await cmdDefault(command)\n }\n}\n\nmain().catch((err) => {\n console.error(\"Fatal:\", err);\n process.exit(1);\n});\n","import * as fs from 'node:fs'\nimport * as path from 'node:path'\nimport * as os from 'node:os'\n\nconst DEFAULT_PORT_FILE = path.join(os.homedir(), '.openacp', 'api.port')\n\nexport function readApiPort(portFilePath: string = DEFAULT_PORT_FILE): number | null {\n try {\n const content = fs.readFileSync(portFilePath, 'utf-8').trim()\n const port = parseInt(content, 10)\n return isNaN(port) ? null : port\n } catch {\n return null\n }\n}\n\nexport function removeStalePortFile(portFilePath: string = DEFAULT_PORT_FILE): void {\n try {\n fs.unlinkSync(portFilePath)\n } catch {\n // ignore\n }\n}\n\nexport async function apiCall(\n port: number,\n urlPath: string,\n options?: RequestInit,\n): Promise<Response> {\n return fetch(`http://127.0.0.1:${port}${urlPath}`, options)\n}\n","import { installPlugin, uninstallPlugin, listPlugins } from '../core/plugin-manager.js'\nimport { readApiPort, removeStalePortFile, apiCall } from '../core/api-client.js'\nimport { getCurrentVersion, getLatestVersion, compareVersions, runUpdate, checkAndPromptUpdate } from './version.js'\n\nexport function printHelp(): void {\n console.log(`\nOpenACP - Self-hosted bridge for AI coding agents\n\nUsage:\n openacp Start (mode from config)\n openacp start Start as background daemon\n openacp stop Stop background daemon\n openacp status Show daemon status\n openacp logs Tail daemon log file\n openacp config Edit configuration\n openacp reset Delete all data and start fresh\n openacp update Update to latest version\n openacp install <package> Install a plugin adapter\n openacp uninstall <package> Uninstall a plugin adapter\n openacp plugins List installed plugins\n openacp --foreground Force foreground mode\n openacp --version Show version\n openacp --help Show this help\n adopt <agent> <id> Adopt an external agent session into OpenACP\n integrate <agent> Install/uninstall agent integration for session transfer\n\nAPI (requires running daemon):\n openacp api status Show active sessions\n openacp api session <id> Show session details\n openacp api new [agent] [workspace] Create a new session\n openacp api send <id> <prompt> Send prompt to session\n openacp api cancel <id> Cancel a session\n openacp api dangerous <id> [on|off] Toggle dangerous mode\n openacp api agents List available agents\n openacp api topics [--status s1,s2] List topics\n openacp api delete-topic <id> [--force] Delete a topic\n openacp api cleanup [--status s1,s2] Cleanup finished topics\n openacp api health Show system health\n openacp api adapters List registered adapters\n openacp api tunnel Show tunnel status\n openacp api config Show runtime config\n openacp api config set <key> <value> Update config value\n openacp api restart Restart daemon\n openacp api notify <message> Send notification to all channels\n openacp api version Show daemon version\n\nNote: \"openacp status\" shows daemon process health.\n \"openacp api status\" shows active agent sessions.\n \"openacp --version\" shows CLI version.\n \"openacp api version\" shows running daemon version.\n\nInstall:\n npm install -g @openacp/cli\n\nExamples:\n openacp\n openacp install @openacp/adapter-discord\n openacp uninstall @openacp/adapter-discord\n`)\n}\n\nexport async function cmdVersion(): Promise<void> {\n const { getCurrentVersion } = await import(\"./version.js\")\n console.log(`openacp v${getCurrentVersion()}`)\n}\n\nexport async function cmdInstall(args: string[]): Promise<void> {\n const pkg = args[1]\n if (!pkg) {\n console.error(\"Usage: openacp install <package>\")\n process.exit(1)\n }\n installPlugin(pkg)\n}\n\nexport async function cmdUninstall(args: string[]): Promise<void> {\n const pkg = args[1]\n if (!pkg) {\n console.error(\"Usage: openacp uninstall <package>\")\n process.exit(1)\n }\n uninstallPlugin(pkg)\n}\n\nexport async function cmdPlugins(): Promise<void> {\n const plugins = listPlugins()\n const entries = Object.entries(plugins)\n if (entries.length === 0) {\n console.log(\"No plugins installed.\")\n } else {\n console.log(\"Installed plugins:\")\n for (const [name, version] of entries) {\n console.log(` ${name}@${version}`)\n }\n }\n}\n\nexport async function cmdApi(args: string[]): Promise<void> {\n const subCmd = args[1]\n\n const port = readApiPort()\n if (port === null) {\n console.error('OpenACP is not running. Start with `openacp start`')\n process.exit(1)\n }\n\n try {\n if (subCmd === 'new') {\n const agent = args[2]\n const workspaceIdx = args.indexOf('--workspace')\n const workspace = workspaceIdx !== -1 ? args[workspaceIdx + 1] : args[3]\n const body: Record<string, string> = {}\n if (agent) body.agent = agent\n if (workspace) body.workspace = workspace\n\n const res = await apiCall(port, '/api/sessions', {\n method: 'POST',\n headers: { 'Content-Type': 'application/json' },\n body: JSON.stringify(body),\n })\n const data = await res.json() as Record<string, unknown>\n if (!res.ok) {\n console.error(`Error: ${data.error}`)\n process.exit(1)\n }\n console.log('Session created')\n console.log(` ID : ${data.sessionId}`)\n console.log(` Agent : ${data.agent}`)\n console.log(` Workspace : ${data.workspace}`)\n console.log(` Status : ${data.status}`)\n\n } else if (subCmd === 'cancel') {\n const sessionId = args[2]\n if (!sessionId) {\n console.error('Usage: openacp api cancel <session-id>')\n process.exit(1)\n }\n const res = await apiCall(port, `/api/sessions/${encodeURIComponent(sessionId)}`, {\n method: 'DELETE',\n })\n const data = await res.json() as Record<string, unknown>\n if (!res.ok) {\n console.error(`Error: ${data.error}`)\n process.exit(1)\n }\n console.log(`Session ${sessionId} cancelled`)\n\n } else if (subCmd === 'status') {\n const res = await apiCall(port, '/api/sessions')\n const data = await res.json() as { sessions: Array<{ id: string; agent: string; status: string; name: string | null }> }\n if (data.sessions.length === 0) {\n console.log('No active sessions.')\n } else {\n console.log(`Active sessions: ${data.sessions.length}\\n`)\n for (const s of data.sessions) {\n const name = s.name ? ` \"${s.name}\"` : ''\n console.log(` ${s.id} ${s.agent} ${s.status}${name}`)\n }\n }\n\n } else if (subCmd === 'agents') {\n const res = await apiCall(port, '/api/agents')\n const data = await res.json() as { agents: Array<{ name: string; command: string; args: string[] }>; default: string }\n console.log('Available agents:')\n for (const a of data.agents) {\n const isDefault = a.name === data.default ? ' (default)' : ''\n console.log(` ${a.name}${isDefault}`)\n }\n\n } else if (subCmd === 'topics') {\n const statusIdx = args.indexOf('--status')\n const statusParam = statusIdx !== -1 ? args[statusIdx + 1] : undefined\n const query = statusParam ? `?status=${encodeURIComponent(statusParam)}` : ''\n const res = await apiCall(port, `/api/topics${query}`)\n const data = await res.json() as { topics: Array<{ sessionId: string; topicId: number | null; name: string | null; status: string; agentName: string; lastActiveAt: string }> }\n if (data.topics.length === 0) {\n console.log('No topics found.')\n } else {\n console.log(`Topics: ${data.topics.length}\\n`)\n for (const t of data.topics) {\n const name = t.name ? ` \"${t.name}\"` : ''\n const topic = t.topicId ? `Topic #${t.topicId}` : 'headless'\n console.log(` ${t.sessionId} ${t.agentName} ${t.status}${name} ${topic}`)\n }\n }\n\n } else if (subCmd === 'delete-topic') {\n const sessionId = args[2]\n if (!sessionId) {\n console.error('Usage: openacp api delete-topic <session-id> [--force]')\n process.exit(1)\n }\n const force = args.includes('--force')\n const query = force ? '?force=true' : ''\n const res = await apiCall(port, `/api/topics/${encodeURIComponent(sessionId)}${query}`, { method: 'DELETE' })\n const data = await res.json() as Record<string, unknown>\n if (res.status === 409) {\n console.error(`Session \"${sessionId}\" is active (${(data.session as any)?.status}). Use --force to delete.`)\n process.exit(1)\n }\n if (!res.ok) {\n console.error(`Error: ${data.error}`)\n process.exit(1)\n }\n const topicLabel = data.topicId ? `Topic #${data.topicId}` : 'headless session'\n console.log(`${topicLabel} deleted (session ${sessionId})`)\n\n } else if (subCmd === 'cleanup') {\n const statusIdx = args.indexOf('--status')\n const statusParam = statusIdx !== -1 ? args[statusIdx + 1] : undefined\n const body: Record<string, unknown> = {}\n if (statusParam) body.statuses = statusParam.split(',')\n const res = await apiCall(port, '/api/topics/cleanup', {\n method: 'POST',\n headers: { 'Content-Type': 'application/json' },\n body: JSON.stringify(body),\n })\n const data = await res.json() as { deleted: string[]; failed: Array<{ sessionId: string; error: string }> }\n if (data.deleted.length === 0 && data.failed.length === 0) {\n console.log('Nothing to clean up.')\n } else {\n console.log(`Cleaned up ${data.deleted.length} topics${data.deleted.length ? ': ' + data.deleted.join(', ') : ''} (${data.failed.length} failed)`)\n for (const f of data.failed) {\n console.error(` Failed: ${f.sessionId} — ${f.error}`)\n }\n }\n\n } else if (subCmd === 'send') {\n const sessionId = args[2]\n if (!sessionId) {\n console.error('Usage: openacp api send <session-id> <prompt>')\n process.exit(1)\n }\n const prompt = args.slice(3).join(' ')\n if (!prompt) {\n console.error('Usage: openacp api send <session-id> <prompt>')\n process.exit(1)\n }\n const res = await apiCall(port, `/api/sessions/${encodeURIComponent(sessionId)}/prompt`, {\n method: 'POST',\n headers: { 'Content-Type': 'application/json' },\n body: JSON.stringify({ prompt }),\n })\n const data = await res.json() as Record<string, unknown>\n if (!res.ok) {\n console.error(`Error: ${data.error}`)\n process.exit(1)\n }\n console.log(`Prompt sent to session ${sessionId} (queue depth: ${data.queueDepth})`)\n\n } else if (subCmd === 'session') {\n const sessionId = args[2]\n if (!sessionId) {\n console.error('Usage: openacp api session <session-id>')\n process.exit(1)\n }\n const res = await apiCall(port, `/api/sessions/${encodeURIComponent(sessionId)}`)\n const data = await res.json() as Record<string, unknown>\n if (!res.ok) {\n console.error(`Error: ${data.error}`)\n process.exit(1)\n }\n console.log(`Session details:`)\n console.log(` ID : ${data.id}`)\n console.log(` Agent : ${data.agent}`)\n console.log(` Status : ${data.status}`)\n console.log(` Name : ${data.name ?? '(none)'}`)\n console.log(` Workspace : ${data.workspace}`)\n console.log(` Created : ${data.createdAt}`)\n console.log(` Dangerous : ${data.dangerous}`)\n console.log(` Queue depth : ${data.queueDepth}`)\n console.log(` Prompt active : ${data.promptActive}`)\n console.log(` Channel : ${data.channelId ?? '(none)'}`)\n console.log(` Thread : ${data.threadId ?? '(none)'}`)\n\n } else if (subCmd === 'dangerous') {\n const sessionId = args[2]\n if (!sessionId) {\n console.error('Usage: openacp api dangerous <session-id> [on|off]')\n process.exit(1)\n }\n const toggle = args[3]\n if (!toggle || (toggle !== 'on' && toggle !== 'off')) {\n console.error('Usage: openacp api dangerous <session-id> [on|off]')\n process.exit(1)\n }\n const res = await apiCall(port, `/api/sessions/${encodeURIComponent(sessionId)}/dangerous`, {\n method: 'PATCH',\n headers: { 'Content-Type': 'application/json' },\n body: JSON.stringify({ enabled: toggle === 'on' }),\n })\n const data = await res.json() as Record<string, unknown>\n if (!res.ok) {\n console.error(`Error: ${data.error}`)\n process.exit(1)\n }\n const state = toggle === 'on' ? 'enabled' : 'disabled'\n console.log(`Dangerous mode ${state} for session ${sessionId}`)\n\n } else if (subCmd === 'health') {\n const res = await apiCall(port, '/api/health')\n const data = await res.json() as Record<string, unknown>\n if (!res.ok) {\n console.error(`Error: ${data.error}`)\n process.exit(1)\n }\n const uptimeSeconds = typeof data.uptimeSeconds === 'number' ? data.uptimeSeconds : 0\n const hours = Math.floor(uptimeSeconds / 3600)\n const minutes = Math.floor((uptimeSeconds % 3600) / 60)\n const memoryBytes = typeof data.memoryUsage === 'number' ? data.memoryUsage : 0\n const memoryMB = (memoryBytes / 1024 / 1024).toFixed(1)\n const sessions = data.sessions as Record<string, unknown> ?? {}\n console.log(`Status : ${data.status}`)\n console.log(`Uptime : ${hours}h ${minutes}m`)\n console.log(`Version : ${data.version}`)\n console.log(`Memory : ${memoryMB} MB`)\n console.log(`Sessions : ${sessions.active ?? 0} active / ${sessions.total ?? 0} total`)\n console.log(`Adapters : ${data.adapters}`)\n console.log(`Tunnel : ${data.tunnel}`)\n\n } else if (subCmd === 'restart') {\n const res = await apiCall(port, '/api/restart', { method: 'POST' })\n const data = await res.json() as Record<string, unknown>\n if (!res.ok) {\n console.error(`Error: ${data.error}`)\n process.exit(1)\n }\n console.log('Restart signal sent. OpenACP is restarting...')\n\n } else if (subCmd === 'config') {\n const subSubCmd = args[2]\n if (!subSubCmd) {\n const res = await apiCall(port, '/api/config')\n const data = await res.json() as Record<string, unknown>\n if (!res.ok) {\n console.error(`Error: ${data.error}`)\n process.exit(1)\n }\n console.log(JSON.stringify(data.config, null, 2))\n } else if (subSubCmd === 'set') {\n const configPath = args[3]\n const configValue = args[4]\n if (!configPath || configValue === undefined) {\n console.error('Usage: openacp api config set <path> <value>')\n process.exit(1)\n }\n let value: unknown = configValue\n try {\n value = JSON.parse(configValue)\n } catch {\n // keep as string\n }\n const res = await apiCall(port, '/api/config', {\n method: 'PATCH',\n headers: { 'Content-Type': 'application/json' },\n body: JSON.stringify({ path: configPath, value }),\n })\n const data = await res.json() as Record<string, unknown>\n if (!res.ok) {\n console.error(`Error: ${data.error}`)\n process.exit(1)\n }\n console.log(`Config updated: ${configPath} = ${JSON.stringify(value)}`)\n if (data.needsRestart) {\n console.log('Note: restart required for this change to take effect.')\n }\n } else {\n console.error(`Unknown config subcommand: ${subSubCmd}`)\n console.log(' openacp api config Show runtime config')\n console.log(' openacp api config set <key> <value> Update config value')\n process.exit(1)\n }\n\n } else if (subCmd === 'adapters') {\n const res = await apiCall(port, '/api/adapters')\n const data = await res.json() as { adapters: Array<{ name: string; type: string }> }\n if (!res.ok) {\n console.error(`Error: ${(data as any).error}`)\n process.exit(1)\n }\n console.log('Registered adapters:')\n for (const a of data.adapters) {\n console.log(` ${a.name} (${a.type})`)\n }\n\n } else if (subCmd === 'tunnel') {\n const res = await apiCall(port, '/api/tunnel')\n const data = await res.json() as Record<string, unknown>\n if (!res.ok) {\n console.error(`Error: ${data.error}`)\n process.exit(1)\n }\n if (data.enabled) {\n console.log(`Tunnel provider : ${data.provider}`)\n console.log(`Tunnel URL : ${data.url}`)\n } else {\n console.log('Tunnel: not enabled')\n }\n\n } else if (subCmd === 'notify') {\n const message = args.slice(2).join(' ')\n if (!message) {\n console.error('Usage: openacp api notify <message>')\n process.exit(1)\n }\n const res = await apiCall(port, '/api/notify', {\n method: 'POST',\n headers: { 'Content-Type': 'application/json' },\n body: JSON.stringify({ message }),\n })\n const data = await res.json() as Record<string, unknown>\n if (!res.ok) {\n console.error(`Error: ${data.error}`)\n process.exit(1)\n }\n console.log('Notification sent to all channels.')\n\n } else if (subCmd === 'version') {\n const res = await apiCall(port, '/api/version')\n const data = await res.json() as Record<string, unknown>\n if (!res.ok) {\n console.error(`Error: ${data.error}`)\n process.exit(1)\n }\n console.log(`Daemon version: ${data.version}`)\n\n } else {\n console.error(`Unknown api command: ${subCmd || '(none)'}\\n`)\n console.log('Usage:')\n console.log(' openacp api status Show active sessions')\n console.log(' openacp api session <id> Show session details')\n console.log(' openacp api new [agent] [workspace] Create a new session')\n console.log(' openacp api send <id> <prompt> Send prompt to session')\n console.log(' openacp api cancel <id> Cancel a session')\n console.log(' openacp api dangerous <id> [on|off] Toggle dangerous mode')\n console.log(' openacp api agents List available agents')\n console.log(' openacp api topics [--status s1,s2] List topics')\n console.log(' openacp api delete-topic <id> [--force] Delete a topic')\n console.log(' openacp api cleanup [--status s1,s2] Cleanup finished topics')\n console.log(' openacp api health Show system health')\n console.log(' openacp api adapters List registered adapters')\n console.log(' openacp api tunnel Show tunnel status')\n console.log(' openacp api config Show runtime config')\n console.log(' openacp api config set <key> <value> Update config value')\n console.log(' openacp api restart Restart daemon')\n console.log(' openacp api notify <message> Send notification to all channels')\n console.log(' openacp api version Show daemon version')\n process.exit(1)\n }\n } catch (err) {\n if (err instanceof TypeError && (err as any).cause?.code === 'ECONNREFUSED') {\n console.error('OpenACP is not running (stale port file)')\n removeStalePortFile()\n process.exit(1)\n }\n throw err\n }\n}\n\nexport async function cmdStart(): Promise<void> {\n await checkAndPromptUpdate()\n const { startDaemon, getPidPath } = await import('../core/daemon.js')\n const { ConfigManager } = await import('../core/config.js')\n const cm = new ConfigManager()\n if (await cm.exists()) {\n await cm.load()\n const config = cm.get()\n const result = startDaemon(getPidPath(), config.logging.logDir)\n if ('error' in result) {\n console.error(result.error)\n process.exit(1)\n }\n console.log(`OpenACP daemon started (PID ${result.pid})`)\n } else {\n console.error('No config found. Run \"openacp\" first to set up.')\n process.exit(1)\n }\n}\n\nexport async function cmdStop(): Promise<void> {\n const { stopDaemon } = await import('../core/daemon.js')\n const result = stopDaemon()\n if (result.stopped) {\n console.log(`OpenACP daemon stopped (was PID ${result.pid})`)\n } else {\n console.error(result.error)\n process.exit(1)\n }\n}\n\nexport async function cmdStatus(): Promise<void> {\n const { getStatus } = await import('../core/daemon.js')\n const status = getStatus()\n if (status.running) {\n console.log(`OpenACP is running (PID ${status.pid})`)\n } else {\n console.log('OpenACP is not running')\n }\n}\n\nexport async function cmdLogs(): Promise<void> {\n const { spawn } = await import('node:child_process')\n const { ConfigManager, expandHome } = await import('../core/config.js')\n const pathMod = await import('node:path')\n const cm = new ConfigManager()\n let logDir = '~/.openacp/logs'\n if (await cm.exists()) {\n await cm.load()\n logDir = cm.get().logging.logDir\n }\n const logFile = pathMod.join(expandHome(logDir), 'openacp.log')\n const tail = spawn('tail', ['-f', '-n', '50', logFile], { stdio: 'inherit' })\n tail.on('error', (err: Error) => {\n console.error(`Cannot tail log file: ${err.message}`)\n process.exit(1)\n })\n}\n\nexport async function cmdConfig(): Promise<void> {\n const { runConfigEditor } = await import('../core/config-editor.js')\n const { ConfigManager } = await import('../core/config.js')\n const cm = new ConfigManager()\n if (!(await cm.exists())) {\n console.error('No config found. Run \"openacp\" first to set up.')\n process.exit(1)\n }\n await runConfigEditor(cm)\n}\n\nexport async function cmdReset(): Promise<void> {\n const { getStatus } = await import('../core/daemon.js')\n const status = getStatus()\n if (status.running) {\n console.error('OpenACP is running. Stop it first: openacp stop')\n process.exit(1)\n }\n\n const { confirm } = await import('@inquirer/prompts')\n const yes = await confirm({\n message: 'This will delete all OpenACP data (~/.openacp). You will need to set up again. Continue?',\n default: false,\n })\n if (!yes) {\n console.log('Aborted.')\n return\n }\n\n const { uninstallAutoStart } = await import('../core/autostart.js')\n uninstallAutoStart()\n\n const fs = await import('node:fs')\n const os = await import('node:os')\n const path = await import('node:path')\n const openacpDir = path.join(os.homedir(), '.openacp')\n fs.rmSync(openacpDir, { recursive: true, force: true })\n\n console.log('Reset complete. Run `openacp` to set up again.')\n}\n\nexport async function cmdUpdate(): Promise<void> {\n const current = getCurrentVersion()\n const latest = await getLatestVersion()\n if (!latest) {\n console.error('Could not check for updates. Check your internet connection.')\n process.exit(1)\n }\n if (compareVersions(current, latest) >= 0) {\n console.log(`Already up to date (v${current})`)\n return\n }\n console.log(`Update available: v${current} → v${latest}`)\n const ok = await runUpdate()\n if (ok) {\n console.log(`\\x1b[32m✓ Updated to v${latest}\\x1b[0m`)\n } else {\n console.error('Update failed. Try manually: npm install -g @openacp/cli@latest')\n process.exit(1)\n }\n}\n\nexport async function cmdAdopt(args: string[]): Promise<void> {\n const agent = args[1];\n const sessionId = args[2];\n\n if (!agent || !sessionId) {\n console.log(\"Usage: openacp adopt <agent> <session_id> [--cwd <path>]\");\n console.log(\"Example: openacp adopt claude abc123-def456 --cwd /path/to/project\");\n process.exit(1);\n }\n\n const cwdIdx = args.indexOf(\"--cwd\");\n const cwd = cwdIdx !== -1 && args[cwdIdx + 1] ? args[cwdIdx + 1] : process.cwd();\n\n const port = readApiPort();\n if (!port) {\n console.log(\"OpenACP is not running. Start it with: openacp start\");\n process.exit(1);\n }\n\n try {\n const res = await fetch(`http://127.0.0.1:${port}/api/sessions/adopt`, {\n method: \"POST\",\n headers: { \"Content-Type\": \"application/json\" },\n body: JSON.stringify({ agent, agentSessionId: sessionId, cwd }),\n });\n const data = await res.json() as Record<string, unknown>;\n\n if (data.ok) {\n if (data.status === \"existing\") {\n console.log(`Session already on Telegram. Topic pinged.`);\n } else {\n console.log(`Session transferred to Telegram.`);\n }\n console.log(` Session ID: ${data.sessionId}`);\n console.log(` Thread ID: ${data.threadId}`);\n } else {\n console.log(`Error: ${(data.message as string) || (data.error as string)}`);\n process.exit(1);\n }\n } catch (err) {\n console.log(`Failed to connect to OpenACP: ${err instanceof Error ? err.message : err}`);\n process.exit(1);\n }\n}\n\nexport async function cmdIntegrate(args: string[]): Promise<void> {\n const { getIntegration, listIntegrations } = await import(\"./integrate.js\");\n\n const agent = args[1];\n const uninstall = args.includes(\"--uninstall\");\n\n if (!agent) {\n console.log(\"Usage: openacp integrate <agent> [--uninstall]\");\n console.log(`Available integrations: ${listIntegrations().join(\", \")}`);\n process.exit(1);\n }\n\n const integration = getIntegration(agent);\n if (!integration) {\n console.log(`No integration available for '${agent}'.`);\n console.log(`Available: ${listIntegrations().join(\", \")}`);\n process.exit(1);\n }\n\n for (const item of integration.items) {\n if (uninstall) {\n console.log(`Removing ${agent}/${item.id}...`);\n const result = await item.uninstall();\n for (const log of result.logs) console.log(` ${log}`);\n if (result.success) {\n console.log(` ${item.name} removed.`);\n } else {\n console.log(` Failed to remove ${item.name}.`);\n process.exit(1);\n }\n } else {\n console.log(`Installing ${agent}/${item.id}...`);\n const result = await item.install();\n for (const log of result.logs) console.log(` ${log}`);\n if (result.success) {\n console.log(` ${item.name} installed.`);\n } else {\n console.log(` Failed to install ${item.name}.`);\n process.exit(1);\n }\n }\n }\n}\n\nexport async function cmdDefault(command: string | undefined): Promise<void> {\n const forceForeground = command === '--foreground'\n\n // Reject unknown commands\n if (command && !command.startsWith('-')) {\n console.error(`Unknown command: ${command}`)\n printHelp()\n process.exit(1)\n }\n\n await checkAndPromptUpdate()\n\n const { ConfigManager } = await import('../core/config.js')\n const cm = new ConfigManager()\n\n // If no config, run setup first\n if (!(await cm.exists())) {\n const { runSetup } = await import('../core/setup.js')\n const shouldStart = await runSetup(cm)\n if (!shouldStart) process.exit(0)\n }\n\n await cm.load()\n const config = cm.get()\n\n if (!forceForeground && config.runMode === 'daemon') {\n const { startDaemon, getPidPath } = await import('../core/daemon.js')\n const result = startDaemon(getPidPath(), config.logging.logDir)\n if ('error' in result) {\n console.error(result.error)\n process.exit(1)\n }\n console.log(`OpenACP daemon started (PID ${result.pid})`)\n return\n }\n\n const { markRunning } = await import('../core/daemon.js')\n markRunning()\n const { startServer } = await import('../main.js')\n await startServer()\n}\n"],"mappings":"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","names":["getCurrentVersion","args","fs","os","path","command"]}
|
|
@@ -3,7 +3,7 @@ import {
|
|
|
3
3
|
ConfigSchema,
|
|
4
4
|
PLUGINS_DIR,
|
|
5
5
|
expandHome
|
|
6
|
-
} from "./chunk-
|
|
6
|
+
} from "./chunk-ZRFBLD3W.js";
|
|
7
7
|
import "./chunk-LYKCQTH5.js";
|
|
8
8
|
export {
|
|
9
9
|
ConfigManager,
|
|
@@ -11,4 +11,4 @@ export {
|
|
|
11
11
|
PLUGINS_DIR,
|
|
12
12
|
expandHome
|
|
13
13
|
};
|
|
14
|
-
//# sourceMappingURL=config-
|
|
14
|
+
//# sourceMappingURL=config-H2DSEHNW.js.map
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import {
|
|
2
|
+
runConfigEditor
|
|
3
|
+
} from "./chunk-6MJLVZXV.js";
|
|
4
|
+
import "./chunk-UAUTLC4E.js";
|
|
5
|
+
import "./chunk-ZRFBLD3W.js";
|
|
6
|
+
import "./chunk-MRKYJ422.js";
|
|
7
|
+
import "./chunk-LYKCQTH5.js";
|
|
8
|
+
export {
|
|
9
|
+
runConfigEditor
|
|
10
|
+
};
|
|
11
|
+
//# sourceMappingURL=config-editor-SKS4LJLT.js.map
|
|
@@ -10,8 +10,8 @@ import {
|
|
|
10
10
|
startDaemon,
|
|
11
11
|
stopDaemon,
|
|
12
12
|
writePidFile
|
|
13
|
-
} from "./chunk-
|
|
14
|
-
import "./chunk-
|
|
13
|
+
} from "./chunk-C6YIUTGR.js";
|
|
14
|
+
import "./chunk-ZRFBLD3W.js";
|
|
15
15
|
import "./chunk-LYKCQTH5.js";
|
|
16
16
|
export {
|
|
17
17
|
clearRunning,
|
|
@@ -26,4 +26,4 @@ export {
|
|
|
26
26
|
stopDaemon,
|
|
27
27
|
writePidFile
|
|
28
28
|
};
|
|
29
|
-
//# sourceMappingURL=daemon-
|
|
29
|
+
//# sourceMappingURL=daemon-VF6HJQXD.js.map
|
package/dist/index.d.ts
CHANGED
|
@@ -99,6 +99,7 @@ type SessionStatus = "initializing" | "active" | "cancelled" | "finished" | "err
|
|
|
99
99
|
interface SessionRecord<P = Record<string, unknown>> {
|
|
100
100
|
sessionId: string;
|
|
101
101
|
agentSessionId: string;
|
|
102
|
+
originalAgentSessionId?: string;
|
|
102
103
|
agentName: string;
|
|
103
104
|
workingDir: string;
|
|
104
105
|
channelId: string;
|
|
@@ -296,7 +297,21 @@ declare const ConfigSchema: z.ZodObject<{
|
|
|
296
297
|
token?: string | undefined;
|
|
297
298
|
} | undefined;
|
|
298
299
|
}>>;
|
|
300
|
+
integrations: z.ZodDefault<z.ZodRecord<z.ZodString, z.ZodObject<{
|
|
301
|
+
installed: z.ZodBoolean;
|
|
302
|
+
installedAt: z.ZodOptional<z.ZodString>;
|
|
303
|
+
}, "strip", z.ZodTypeAny, {
|
|
304
|
+
installed: boolean;
|
|
305
|
+
installedAt?: string | undefined;
|
|
306
|
+
}, {
|
|
307
|
+
installed: boolean;
|
|
308
|
+
installedAt?: string | undefined;
|
|
309
|
+
}>>>;
|
|
299
310
|
}, "strip", z.ZodTypeAny, {
|
|
311
|
+
api: {
|
|
312
|
+
port: number;
|
|
313
|
+
host: string;
|
|
314
|
+
};
|
|
300
315
|
tunnel: {
|
|
301
316
|
options: Record<string, unknown>;
|
|
302
317
|
enabled: boolean;
|
|
@@ -336,13 +351,13 @@ declare const ConfigSchema: z.ZodObject<{
|
|
|
336
351
|
};
|
|
337
352
|
runMode: "foreground" | "daemon";
|
|
338
353
|
autoStart: boolean;
|
|
339
|
-
api: {
|
|
340
|
-
port: number;
|
|
341
|
-
host: string;
|
|
342
|
-
};
|
|
343
354
|
sessionStore: {
|
|
344
355
|
ttlDays: number;
|
|
345
356
|
};
|
|
357
|
+
integrations: Record<string, {
|
|
358
|
+
installed: boolean;
|
|
359
|
+
installedAt?: string | undefined;
|
|
360
|
+
}>;
|
|
346
361
|
}, {
|
|
347
362
|
agents: Record<string, {
|
|
348
363
|
command: string;
|
|
@@ -355,6 +370,10 @@ declare const ConfigSchema: z.ZodObject<{
|
|
|
355
370
|
adapter: z.ZodOptional<z.ZodString>;
|
|
356
371
|
}, z.ZodTypeAny, "passthrough">>;
|
|
357
372
|
defaultAgent: string;
|
|
373
|
+
api?: {
|
|
374
|
+
port?: number | undefined;
|
|
375
|
+
host?: string | undefined;
|
|
376
|
+
} | undefined;
|
|
358
377
|
tunnel?: {
|
|
359
378
|
options?: Record<string, unknown> | undefined;
|
|
360
379
|
enabled?: boolean | undefined;
|
|
@@ -383,13 +402,13 @@ declare const ConfigSchema: z.ZodObject<{
|
|
|
383
402
|
} | undefined;
|
|
384
403
|
runMode?: "foreground" | "daemon" | undefined;
|
|
385
404
|
autoStart?: boolean | undefined;
|
|
386
|
-
api?: {
|
|
387
|
-
port?: number | undefined;
|
|
388
|
-
host?: string | undefined;
|
|
389
|
-
} | undefined;
|
|
390
405
|
sessionStore?: {
|
|
391
406
|
ttlDays?: number | undefined;
|
|
392
407
|
} | undefined;
|
|
408
|
+
integrations?: Record<string, {
|
|
409
|
+
installed: boolean;
|
|
410
|
+
installedAt?: string | undefined;
|
|
411
|
+
}> | undefined;
|
|
393
412
|
}>;
|
|
394
413
|
type Config = z.infer<typeof ConfigSchema>;
|
|
395
414
|
declare function expandHome(p: string): string;
|
|
@@ -438,6 +457,7 @@ interface IChannelAdapter {
|
|
|
438
457
|
sendNotification(notification: NotificationMessage): Promise<void>;
|
|
439
458
|
createSessionThread(sessionId: string, name: string): Promise<string>;
|
|
440
459
|
renameSessionThread(sessionId: string, newName: string): Promise<void>;
|
|
460
|
+
deleteSessionThread(sessionId: string): Promise<void>;
|
|
441
461
|
sendSkillCommands(sessionId: string, commands: AgentCommand[]): Promise<void>;
|
|
442
462
|
cleanupSkillCommands(sessionId: string): Promise<void>;
|
|
443
463
|
}
|
|
@@ -456,6 +476,7 @@ declare abstract class ChannelAdapter<TCore = unknown> implements IChannelAdapte
|
|
|
456
476
|
abstract sendNotification(notification: NotificationMessage): Promise<void>;
|
|
457
477
|
abstract createSessionThread(sessionId: string, name: string): Promise<string>;
|
|
458
478
|
abstract renameSessionThread(sessionId: string, newName: string): Promise<void>;
|
|
479
|
+
deleteSessionThread(_sessionId: string): Promise<void>;
|
|
459
480
|
sendSkillCommands(_sessionId: string, _commands: AgentCommand[]): Promise<void>;
|
|
460
481
|
cleanupSkillCommands(_sessionId: string): Promise<void>;
|
|
461
482
|
}
|
|
@@ -684,6 +705,7 @@ interface SessionStore {
|
|
|
684
705
|
save(record: SessionRecord): Promise<void>;
|
|
685
706
|
get(sessionId: string): SessionRecord | undefined;
|
|
686
707
|
findByPlatform(channelId: string, predicate: (platform: Record<string, unknown>) => boolean): SessionRecord | undefined;
|
|
708
|
+
findByAgentSessionId(agentSessionId: string): SessionRecord | undefined;
|
|
687
709
|
list(channelId?: string): SessionRecord[];
|
|
688
710
|
remove(sessionId: string): Promise<void>;
|
|
689
711
|
}
|
|
@@ -695,6 +717,8 @@ declare class SessionManager {
|
|
|
695
717
|
createSession(channelId: string, agentName: string, workingDirectory: string, agentManager: AgentManager): Promise<Session>;
|
|
696
718
|
getSession(sessionId: string): Session | undefined;
|
|
697
719
|
getSessionByThread(channelId: string, threadId: string): Session | undefined;
|
|
720
|
+
getSessionByAgentSessionId(agentSessionId: string): Session | undefined;
|
|
721
|
+
getRecordByAgentSessionId(agentSessionId: string): SessionRecord | undefined;
|
|
698
722
|
getRecordByThread(channelId: string, threadId: string): SessionRecord | undefined;
|
|
699
723
|
registerSession(session: Session): void;
|
|
700
724
|
updateSessionPlatform(sessionId: string, platform: Record<string, unknown>): Promise<void>;
|
|
@@ -705,6 +729,10 @@ declare class SessionManager {
|
|
|
705
729
|
getSessionRecord(sessionId: string): SessionRecord | undefined;
|
|
706
730
|
cancelSession(sessionId: string): Promise<void>;
|
|
707
731
|
listSessions(channelId?: string): Session[];
|
|
732
|
+
listRecords(filter?: {
|
|
733
|
+
statuses?: string[];
|
|
734
|
+
}): SessionRecord[];
|
|
735
|
+
removeRecord(sessionId: string): Promise<void>;
|
|
708
736
|
destroyAll(): Promise<void>;
|
|
709
737
|
}
|
|
710
738
|
|
|
@@ -728,6 +756,16 @@ declare class OpenACPCore {
|
|
|
728
756
|
stop(): Promise<void>;
|
|
729
757
|
handleMessage(message: IncomingMessage): Promise<void>;
|
|
730
758
|
handleNewSession(channelId: string, agentName?: string, workspacePath?: string): Promise<Session>;
|
|
759
|
+
adoptSession(agentName: string, agentSessionId: string, cwd: string): Promise<{
|
|
760
|
+
ok: true;
|
|
761
|
+
sessionId: string;
|
|
762
|
+
threadId: string;
|
|
763
|
+
status: "adopted" | "existing";
|
|
764
|
+
} | {
|
|
765
|
+
ok: false;
|
|
766
|
+
error: string;
|
|
767
|
+
message: string;
|
|
768
|
+
}>;
|
|
731
769
|
handleNewChat(channelId: string, currentThreadId: string): Promise<Session | null>;
|
|
732
770
|
private lazyResume;
|
|
733
771
|
wireSessionEvents(session: Session, adapter: ChannelAdapter): void;
|
|
@@ -771,6 +809,51 @@ declare function isAutoStartInstalled(): boolean;
|
|
|
771
809
|
|
|
772
810
|
declare function runConfigEditor(configManager: ConfigManager): Promise<void>;
|
|
773
811
|
|
|
812
|
+
interface TopicInfo {
|
|
813
|
+
sessionId: string;
|
|
814
|
+
topicId: number | null;
|
|
815
|
+
name: string | null;
|
|
816
|
+
status: string;
|
|
817
|
+
agentName: string;
|
|
818
|
+
lastActiveAt: string;
|
|
819
|
+
}
|
|
820
|
+
interface DeleteTopicResult {
|
|
821
|
+
ok: boolean;
|
|
822
|
+
needsConfirmation?: boolean;
|
|
823
|
+
topicId?: number | null;
|
|
824
|
+
session?: {
|
|
825
|
+
id: string;
|
|
826
|
+
name: string | null;
|
|
827
|
+
status: string;
|
|
828
|
+
};
|
|
829
|
+
error?: string;
|
|
830
|
+
}
|
|
831
|
+
interface CleanupResult {
|
|
832
|
+
deleted: string[];
|
|
833
|
+
failed: {
|
|
834
|
+
sessionId: string;
|
|
835
|
+
error: string;
|
|
836
|
+
}[];
|
|
837
|
+
}
|
|
838
|
+
interface SystemTopicIds {
|
|
839
|
+
notificationTopicId: number | null;
|
|
840
|
+
assistantTopicId: number | null;
|
|
841
|
+
}
|
|
842
|
+
declare class TopicManager {
|
|
843
|
+
private sessionManager;
|
|
844
|
+
private adapter;
|
|
845
|
+
private systemTopicIds;
|
|
846
|
+
constructor(sessionManager: SessionManager, adapter: IChannelAdapter | null, systemTopicIds: SystemTopicIds);
|
|
847
|
+
listTopics(filter?: {
|
|
848
|
+
statuses?: string[];
|
|
849
|
+
}): TopicInfo[];
|
|
850
|
+
deleteTopic(sessionId: string, options?: {
|
|
851
|
+
confirmed?: boolean;
|
|
852
|
+
}): Promise<DeleteTopicResult>;
|
|
853
|
+
cleanup(statuses?: string[]): Promise<CleanupResult>;
|
|
854
|
+
private isSystemTopic;
|
|
855
|
+
}
|
|
856
|
+
|
|
774
857
|
interface ApiConfig {
|
|
775
858
|
port: number;
|
|
776
859
|
host: string;
|
|
@@ -778,10 +861,12 @@ interface ApiConfig {
|
|
|
778
861
|
declare class ApiServer {
|
|
779
862
|
private core;
|
|
780
863
|
private config;
|
|
864
|
+
private topicManager?;
|
|
781
865
|
private server;
|
|
782
866
|
private actualPort;
|
|
783
867
|
private portFilePath;
|
|
784
|
-
|
|
868
|
+
private startedAt;
|
|
869
|
+
constructor(core: OpenACPCore, config: ApiConfig, portFilePath?: string, topicManager?: TopicManager | undefined);
|
|
785
870
|
start(): Promise<void>;
|
|
786
871
|
stop(): Promise<void>;
|
|
787
872
|
getPort(): number;
|
|
@@ -789,10 +874,25 @@ declare class ApiServer {
|
|
|
789
874
|
private removePortFile;
|
|
790
875
|
private handleRequest;
|
|
791
876
|
private handleCreateSession;
|
|
877
|
+
private handleSendPrompt;
|
|
878
|
+
private handleGetSession;
|
|
879
|
+
private handleToggleDangerous;
|
|
880
|
+
private handleHealth;
|
|
881
|
+
private handleVersion;
|
|
882
|
+
private handleGetConfig;
|
|
883
|
+
private handleUpdateConfig;
|
|
884
|
+
private handleListAdapters;
|
|
885
|
+
private handleTunnelStatus;
|
|
886
|
+
private handleNotify;
|
|
887
|
+
private handleRestart;
|
|
792
888
|
private handleCancelSession;
|
|
793
889
|
private handleListSessions;
|
|
890
|
+
private handleAdoptSession;
|
|
794
891
|
private handleListAgents;
|
|
795
892
|
private sendJson;
|
|
893
|
+
private handleListTopics;
|
|
894
|
+
private handleDeleteTopic;
|
|
895
|
+
private handleCleanupTopics;
|
|
796
896
|
private readBody;
|
|
797
897
|
}
|
|
798
898
|
|
|
@@ -828,9 +928,10 @@ declare class TelegramAdapter extends ChannelAdapter<OpenACPCore> {
|
|
|
828
928
|
sendNotification(notification: NotificationMessage): Promise<void>;
|
|
829
929
|
createSessionThread(sessionId: string, name: string): Promise<string>;
|
|
830
930
|
renameSessionThread(sessionId: string, newName: string): Promise<void>;
|
|
931
|
+
deleteSessionThread(sessionId: string): Promise<void>;
|
|
831
932
|
sendSkillCommands(sessionId: string, commands: AgentCommand[]): Promise<void>;
|
|
832
933
|
cleanupSkillCommands(sessionId: string): Promise<void>;
|
|
833
934
|
private finalizeDraft;
|
|
834
935
|
}
|
|
835
936
|
|
|
836
|
-
export { type AdapterFactory, type AgentCommand, type AgentDefinition, type AgentEvent, AgentInstance, AgentManager, type ApiConfig, ApiServer, ChannelAdapter, type ChannelConfig, type Config, ConfigManager, type IChannelAdapter, type IncomingMessage, type Logger, type LoggingConfig, MessageTransformer, NotificationManager, type NotificationMessage, OpenACPCore, type OutgoingMessage, PLUGINS_DIR, PermissionGate, type PermissionOption, type PermissionRequest, type PlanEntry, PromptQueue, Session, type SessionEvents, SessionManager, type SessionRecord, type SessionStatus, StderrCapture, TelegramAdapter, type TelegramPlatformData, TypedEmitter, cleanupOldSessionLogs, createChildLogger, createSessionLogger, expandHome, getPidPath, getStatus, initLogger, installAutoStart, installPlugin, isAutoStartInstalled, isAutoStartSupported, listPlugins, loadAdapterFactory, log, nodeToWebReadable, nodeToWebWritable, runConfigEditor, shutdownLogger, startDaemon, stopDaemon, uninstallAutoStart, uninstallPlugin };
|
|
937
|
+
export { type AdapterFactory, type AgentCommand, type AgentDefinition, type AgentEvent, AgentInstance, AgentManager, type ApiConfig, ApiServer, ChannelAdapter, type ChannelConfig, type CleanupResult, type Config, ConfigManager, type DeleteTopicResult, type IChannelAdapter, type IncomingMessage, type Logger, type LoggingConfig, MessageTransformer, NotificationManager, type NotificationMessage, OpenACPCore, type OutgoingMessage, PLUGINS_DIR, PermissionGate, type PermissionOption, type PermissionRequest, type PlanEntry, PromptQueue, Session, type SessionEvents, SessionManager, type SessionRecord, type SessionStatus, StderrCapture, TelegramAdapter, type TelegramPlatformData, type TopicInfo, TopicManager, TypedEmitter, cleanupOldSessionLogs, createChildLogger, createSessionLogger, expandHome, getPidPath, getStatus, initLogger, installAutoStart, installPlugin, isAutoStartInstalled, isAutoStartSupported, listPlugins, loadAdapterFactory, log, nodeToWebReadable, nodeToWebWritable, runConfigEditor, shutdownLogger, startDaemon, stopDaemon, uninstallAutoStart, uninstallPlugin };
|
package/dist/index.js
CHANGED
|
@@ -12,37 +12,39 @@ import {
|
|
|
12
12
|
SessionManager,
|
|
13
13
|
StderrCapture,
|
|
14
14
|
TelegramAdapter,
|
|
15
|
+
TopicManager,
|
|
15
16
|
TypedEmitter,
|
|
16
17
|
nodeToWebReadable,
|
|
17
18
|
nodeToWebWritable
|
|
18
|
-
} from "./chunk-
|
|
19
|
+
} from "./chunk-BBPWAWE3.js";
|
|
19
20
|
import {
|
|
20
21
|
runConfigEditor
|
|
21
|
-
} from "./chunk-
|
|
22
|
+
} from "./chunk-6MJLVZXV.js";
|
|
23
|
+
import "./chunk-UAUTLC4E.js";
|
|
24
|
+
import "./chunk-VA2M52CM.js";
|
|
22
25
|
import {
|
|
23
26
|
installPlugin,
|
|
24
27
|
listPlugins,
|
|
25
28
|
loadAdapterFactory,
|
|
26
29
|
uninstallPlugin
|
|
27
|
-
} from "./chunk-
|
|
30
|
+
} from "./chunk-HZD3CGPK.js";
|
|
28
31
|
import {
|
|
29
32
|
getPidPath,
|
|
30
33
|
getStatus,
|
|
31
34
|
startDaemon,
|
|
32
35
|
stopDaemon
|
|
33
|
-
} from "./chunk-
|
|
36
|
+
} from "./chunk-C6YIUTGR.js";
|
|
37
|
+
import {
|
|
38
|
+
ConfigManager,
|
|
39
|
+
PLUGINS_DIR,
|
|
40
|
+
expandHome
|
|
41
|
+
} from "./chunk-ZRFBLD3W.js";
|
|
34
42
|
import {
|
|
35
43
|
installAutoStart,
|
|
36
44
|
isAutoStartInstalled,
|
|
37
45
|
isAutoStartSupported,
|
|
38
46
|
uninstallAutoStart
|
|
39
47
|
} from "./chunk-MRKYJ422.js";
|
|
40
|
-
import "./chunk-BLVZFCKN.js";
|
|
41
|
-
import {
|
|
42
|
-
ConfigManager,
|
|
43
|
-
PLUGINS_DIR,
|
|
44
|
-
expandHome
|
|
45
|
-
} from "./chunk-WF5XDN4D.js";
|
|
46
48
|
import {
|
|
47
49
|
cleanupOldSessionLogs,
|
|
48
50
|
createChildLogger,
|
|
@@ -67,6 +69,7 @@ export {
|
|
|
67
69
|
SessionManager,
|
|
68
70
|
StderrCapture,
|
|
69
71
|
TelegramAdapter,
|
|
72
|
+
TopicManager,
|
|
70
73
|
TypedEmitter,
|
|
71
74
|
cleanupOldSessionLogs,
|
|
72
75
|
createChildLogger,
|
|
@@ -0,0 +1,145 @@
|
|
|
1
|
+
// src/cli/integrate.ts
|
|
2
|
+
import { existsSync, mkdirSync, readFileSync, writeFileSync, unlinkSync, chmodSync } from "fs";
|
|
3
|
+
import { join } from "path";
|
|
4
|
+
import { homedir } from "os";
|
|
5
|
+
var CLAUDE_DIR = join(homedir(), ".claude");
|
|
6
|
+
var HOOKS_DIR = join(CLAUDE_DIR, "hooks");
|
|
7
|
+
var COMMANDS_DIR = join(CLAUDE_DIR, "commands");
|
|
8
|
+
var SETTINGS_FILE = join(CLAUDE_DIR, "settings.json");
|
|
9
|
+
var INJECT_HOOK_FILE = join(HOOKS_DIR, "openacp-inject-session.sh");
|
|
10
|
+
var HANDOFF_SCRIPT_FILE = join(HOOKS_DIR, "openacp-handoff.sh");
|
|
11
|
+
var HANDOFF_COMMAND_FILE = join(COMMANDS_DIR, "openacp:handoff.md");
|
|
12
|
+
var INJECT_HOOK_CONTENT = `#!/bin/bash
|
|
13
|
+
INPUT=$(cat)
|
|
14
|
+
SESSION_ID=$(echo "$INPUT" | jq -r '.session_id')
|
|
15
|
+
CWD=$(echo "$INPUT" | jq -r '.cwd')
|
|
16
|
+
|
|
17
|
+
echo "CLAUDE_SESSION_ID: $SESSION_ID"
|
|
18
|
+
echo "CLAUDE_WORKING_DIR: $CWD"
|
|
19
|
+
|
|
20
|
+
exit 0
|
|
21
|
+
`;
|
|
22
|
+
var HANDOFF_SCRIPT_CONTENT = `#!/bin/bash
|
|
23
|
+
SESSION_ID=$1
|
|
24
|
+
CWD=$2
|
|
25
|
+
|
|
26
|
+
if [ -z "$SESSION_ID" ]; then
|
|
27
|
+
echo "Usage: openacp-handoff.sh <session_id> [cwd]"
|
|
28
|
+
exit 1
|
|
29
|
+
fi
|
|
30
|
+
|
|
31
|
+
openacp adopt claude "$SESSION_ID" \${CWD:+--cwd "$CWD"}
|
|
32
|
+
`;
|
|
33
|
+
var HANDOFF_COMMAND_CONTENT = `---
|
|
34
|
+
description: Transfer current session to OpenACP (Telegram)
|
|
35
|
+
---
|
|
36
|
+
|
|
37
|
+
Look at the context injected at the start of this message to find
|
|
38
|
+
CLAUDE_SESSION_ID and CLAUDE_WORKING_DIR, then run:
|
|
39
|
+
|
|
40
|
+
bash ~/.claude/hooks/openacp-handoff.sh <CLAUDE_SESSION_ID> <CLAUDE_WORKING_DIR>
|
|
41
|
+
`;
|
|
42
|
+
var HOOK_MARKER = "openacp-inject-session.sh";
|
|
43
|
+
function mergeClaudeSettings() {
|
|
44
|
+
let settings = {};
|
|
45
|
+
if (existsSync(SETTINGS_FILE)) {
|
|
46
|
+
const raw = readFileSync(SETTINGS_FILE, "utf-8");
|
|
47
|
+
writeFileSync(`${SETTINGS_FILE}.bak`, raw);
|
|
48
|
+
settings = JSON.parse(raw);
|
|
49
|
+
}
|
|
50
|
+
const hooks = settings.hooks ?? {};
|
|
51
|
+
settings.hooks = hooks;
|
|
52
|
+
const userPromptSubmit = hooks.UserPromptSubmit ?? [];
|
|
53
|
+
hooks.UserPromptSubmit = userPromptSubmit;
|
|
54
|
+
const alreadyInstalled = userPromptSubmit.some(
|
|
55
|
+
(group) => group.hooks?.some((h) => h.command?.includes(HOOK_MARKER))
|
|
56
|
+
);
|
|
57
|
+
if (!alreadyInstalled) {
|
|
58
|
+
userPromptSubmit.push({
|
|
59
|
+
hooks: [
|
|
60
|
+
{
|
|
61
|
+
type: "command",
|
|
62
|
+
command: INJECT_HOOK_FILE
|
|
63
|
+
}
|
|
64
|
+
]
|
|
65
|
+
});
|
|
66
|
+
}
|
|
67
|
+
writeFileSync(SETTINGS_FILE, JSON.stringify(settings, null, 2) + "\n");
|
|
68
|
+
}
|
|
69
|
+
function removeClaudeSettings() {
|
|
70
|
+
if (!existsSync(SETTINGS_FILE)) return;
|
|
71
|
+
const raw = readFileSync(SETTINGS_FILE, "utf-8");
|
|
72
|
+
const settings = JSON.parse(raw);
|
|
73
|
+
const hooks = settings.hooks;
|
|
74
|
+
if (!hooks?.UserPromptSubmit) return;
|
|
75
|
+
hooks.UserPromptSubmit = hooks.UserPromptSubmit.filter(
|
|
76
|
+
(group) => !group.hooks?.some((h) => h.command?.includes("openacp-"))
|
|
77
|
+
);
|
|
78
|
+
if (hooks.UserPromptSubmit.length === 0) {
|
|
79
|
+
delete hooks.UserPromptSubmit;
|
|
80
|
+
}
|
|
81
|
+
writeFileSync(SETTINGS_FILE, JSON.stringify(settings, null, 2) + "\n");
|
|
82
|
+
}
|
|
83
|
+
var claudeHandoffItem = {
|
|
84
|
+
id: "handoff",
|
|
85
|
+
name: "Handoff",
|
|
86
|
+
description: "Transfer sessions between terminal and Telegram",
|
|
87
|
+
isInstalled() {
|
|
88
|
+
return existsSync(INJECT_HOOK_FILE) && existsSync(HANDOFF_SCRIPT_FILE) && existsSync(HANDOFF_COMMAND_FILE);
|
|
89
|
+
},
|
|
90
|
+
async install() {
|
|
91
|
+
const logs = [];
|
|
92
|
+
try {
|
|
93
|
+
mkdirSync(HOOKS_DIR, { recursive: true });
|
|
94
|
+
mkdirSync(COMMANDS_DIR, { recursive: true });
|
|
95
|
+
writeFileSync(INJECT_HOOK_FILE, INJECT_HOOK_CONTENT);
|
|
96
|
+
chmodSync(INJECT_HOOK_FILE, 493);
|
|
97
|
+
logs.push(`Created ${INJECT_HOOK_FILE}`);
|
|
98
|
+
writeFileSync(HANDOFF_SCRIPT_FILE, HANDOFF_SCRIPT_CONTENT);
|
|
99
|
+
chmodSync(HANDOFF_SCRIPT_FILE, 493);
|
|
100
|
+
logs.push(`Created ${HANDOFF_SCRIPT_FILE}`);
|
|
101
|
+
writeFileSync(HANDOFF_COMMAND_FILE, HANDOFF_COMMAND_CONTENT);
|
|
102
|
+
logs.push(`Created ${HANDOFF_COMMAND_FILE}`);
|
|
103
|
+
mergeClaudeSettings();
|
|
104
|
+
logs.push(`Updated ${SETTINGS_FILE}`);
|
|
105
|
+
return { success: true, logs };
|
|
106
|
+
} catch (err) {
|
|
107
|
+
logs.push(`Error: ${err instanceof Error ? err.message : String(err)}`);
|
|
108
|
+
return { success: false, logs };
|
|
109
|
+
}
|
|
110
|
+
},
|
|
111
|
+
async uninstall() {
|
|
112
|
+
const logs = [];
|
|
113
|
+
try {
|
|
114
|
+
for (const file of [INJECT_HOOK_FILE, HANDOFF_SCRIPT_FILE, HANDOFF_COMMAND_FILE]) {
|
|
115
|
+
if (existsSync(file)) {
|
|
116
|
+
unlinkSync(file);
|
|
117
|
+
logs.push(`Removed ${file}`);
|
|
118
|
+
}
|
|
119
|
+
}
|
|
120
|
+
removeClaudeSettings();
|
|
121
|
+
logs.push(`Updated ${SETTINGS_FILE}`);
|
|
122
|
+
return { success: true, logs };
|
|
123
|
+
} catch (err) {
|
|
124
|
+
logs.push(`Error: ${err instanceof Error ? err.message : String(err)}`);
|
|
125
|
+
return { success: false, logs };
|
|
126
|
+
}
|
|
127
|
+
}
|
|
128
|
+
};
|
|
129
|
+
var claudeIntegration = {
|
|
130
|
+
items: [claudeHandoffItem]
|
|
131
|
+
};
|
|
132
|
+
var integrations = {
|
|
133
|
+
claude: claudeIntegration
|
|
134
|
+
};
|
|
135
|
+
function getIntegration(agentName) {
|
|
136
|
+
return integrations[agentName];
|
|
137
|
+
}
|
|
138
|
+
function listIntegrations() {
|
|
139
|
+
return Object.keys(integrations);
|
|
140
|
+
}
|
|
141
|
+
export {
|
|
142
|
+
getIntegration,
|
|
143
|
+
listIntegrations
|
|
144
|
+
};
|
|
145
|
+
//# sourceMappingURL=integrate-WUPLRJD3.js.map
|