@tschmz/imp 0.1.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +19 -0
- package/LICENSE +201 -0
- package/README.md +21 -0
- package/config.example.json +143 -0
- package/dist/agents/default-system-prompt.d.ts +1 -0
- package/dist/agents/default-system-prompt.js +67 -0
- package/dist/agents/default-system-prompt.js.map +1 -0
- package/dist/agents/registry.d.ts +6 -0
- package/dist/agents/registry.js +12 -0
- package/dist/agents/registry.js.map +1 -0
- package/dist/application/backup-use-cases.d.ts +28 -0
- package/dist/application/backup-use-cases.js +571 -0
- package/dist/application/backup-use-cases.js.map +1 -0
- package/dist/application/commands/agent-command.d.ts +2 -0
- package/dist/application/commands/agent-command.js +61 -0
- package/dist/application/commands/agent-command.js.map +1 -0
- package/dist/application/commands/config-command.d.ts +2 -0
- package/dist/application/commands/config-command.js +39 -0
- package/dist/application/commands/config-command.js.map +1 -0
- package/dist/application/commands/conversation-context.d.ts +6 -0
- package/dist/application/commands/conversation-context.js +35 -0
- package/dist/application/commands/conversation-context.js.map +1 -0
- package/dist/application/commands/export-command.d.ts +2 -0
- package/dist/application/commands/export-command.js +25 -0
- package/dist/application/commands/export-command.js.map +1 -0
- package/dist/application/commands/help-command.d.ts +3 -0
- package/dist/application/commands/help-command.js +40 -0
- package/dist/application/commands/help-command.js.map +1 -0
- package/dist/application/commands/history-command.d.ts +2 -0
- package/dist/application/commands/history-command.js +23 -0
- package/dist/application/commands/history-command.js.map +1 -0
- package/dist/application/commands/logs-command.d.ts +2 -0
- package/dist/application/commands/logs-command.js +42 -0
- package/dist/application/commands/logs-command.js.map +1 -0
- package/dist/application/commands/new-command.d.ts +2 -0
- package/dist/application/commands/new-command.js +37 -0
- package/dist/application/commands/new-command.js.map +1 -0
- package/dist/application/commands/parse-inbound-command.d.ts +15 -0
- package/dist/application/commands/parse-inbound-command.js +33 -0
- package/dist/application/commands/parse-inbound-command.js.map +1 -0
- package/dist/application/commands/ping-command.d.ts +2 -0
- package/dist/application/commands/ping-command.js +18 -0
- package/dist/application/commands/ping-command.js.map +1 -0
- package/dist/application/commands/priority-inbound-commands.d.ts +2 -0
- package/dist/application/commands/priority-inbound-commands.js +14 -0
- package/dist/application/commands/priority-inbound-commands.js.map +1 -0
- package/dist/application/commands/registry.d.ts +7 -0
- package/dist/application/commands/registry.js +38 -0
- package/dist/application/commands/registry.js.map +1 -0
- package/dist/application/commands/reload-command.d.ts +2 -0
- package/dist/application/commands/reload-command.js +23 -0
- package/dist/application/commands/reload-command.js.map +1 -0
- package/dist/application/commands/rename-command.d.ts +2 -0
- package/dist/application/commands/rename-command.js +36 -0
- package/dist/application/commands/rename-command.js.map +1 -0
- package/dist/application/commands/renderers.d.ts +13 -0
- package/dist/application/commands/renderers.js +238 -0
- package/dist/application/commands/renderers.js.map +1 -0
- package/dist/application/commands/reset-command.d.ts +2 -0
- package/dist/application/commands/reset-command.js +36 -0
- package/dist/application/commands/reset-command.js.map +1 -0
- package/dist/application/commands/restart-command.d.ts +2 -0
- package/dist/application/commands/restart-command.js +23 -0
- package/dist/application/commands/restart-command.js.map +1 -0
- package/dist/application/commands/restore-command.d.ts +2 -0
- package/dist/application/commands/restore-command.js +52 -0
- package/dist/application/commands/restore-command.js.map +1 -0
- package/dist/application/commands/status-command.d.ts +2 -0
- package/dist/application/commands/status-command.js +24 -0
- package/dist/application/commands/status-command.js.map +1 -0
- package/dist/application/commands/types.d.ts +49 -0
- package/dist/application/commands/types.js +2 -0
- package/dist/application/commands/types.js.map +1 -0
- package/dist/application/commands/utils.d.ts +4 -0
- package/dist/application/commands/utils.js +26 -0
- package/dist/application/commands/utils.js.map +1 -0
- package/dist/application/commands/whoami-command.d.ts +2 -0
- package/dist/application/commands/whoami-command.js +27 -0
- package/dist/application/commands/whoami-command.js.map +1 -0
- package/dist/application/config-key-path.d.ts +2 -0
- package/dist/application/config-key-path.js +65 -0
- package/dist/application/config-key-path.js.map +1 -0
- package/dist/application/get-config-value-use-case.d.ts +4 -0
- package/dist/application/get-config-value-use-case.js +30 -0
- package/dist/application/get-config-value-use-case.js.map +1 -0
- package/dist/application/handle-incoming-message.d.ts +7 -0
- package/dist/application/handle-incoming-message.js +56 -0
- package/dist/application/handle-incoming-message.js.map +1 -0
- package/dist/application/inbound/dispatch-command.d.ts +2 -0
- package/dist/application/inbound/dispatch-command.js +23 -0
- package/dist/application/inbound/dispatch-command.js.map +1 -0
- package/dist/application/inbound/execute-agent.d.ts +2 -0
- package/dist/application/inbound/execute-agent.js +41 -0
- package/dist/application/inbound/execute-agent.js.map +1 -0
- package/dist/application/inbound/persist-conversation.d.ts +2 -0
- package/dist/application/inbound/persist-conversation.js +7 -0
- package/dist/application/inbound/persist-conversation.js.map +1 -0
- package/dist/application/inbound/resolve-conversation.d.ts +2 -0
- package/dist/application/inbound/resolve-conversation.js +19 -0
- package/dist/application/inbound/resolve-conversation.js.map +1 -0
- package/dist/application/inbound/resolve-skills.d.ts +2 -0
- package/dist/application/inbound/resolve-skills.js +73 -0
- package/dist/application/inbound/resolve-skills.js.map +1 -0
- package/dist/application/inbound/run-hooks-start.d.ts +2 -0
- package/dist/application/inbound/run-hooks-start.js +4 -0
- package/dist/application/inbound/run-hooks-start.js.map +1 -0
- package/dist/application/inbound/run-hooks-success-error.d.ts +3 -0
- package/dist/application/inbound/run-hooks-success-error.js +18 -0
- package/dist/application/inbound/run-hooks-success-error.js.map +1 -0
- package/dist/application/inbound/types.d.ts +21 -0
- package/dist/application/inbound/types.js +2 -0
- package/dist/application/inbound/types.js.map +1 -0
- package/dist/application/init-config-use-case.d.ts +5 -0
- package/dist/application/init-config-use-case.js +62 -0
- package/dist/application/init-config-use-case.js.map +1 -0
- package/dist/application/message-processor.d.ts +19 -0
- package/dist/application/message-processor.js +122 -0
- package/dist/application/message-processor.js.map +1 -0
- package/dist/application/reload-config-use-case.d.ts +15 -0
- package/dist/application/reload-config-use-case.js +26 -0
- package/dist/application/reload-config-use-case.js.map +1 -0
- package/dist/application/run-daemon-use-case.d.ts +27 -0
- package/dist/application/run-daemon-use-case.js +42 -0
- package/dist/application/run-daemon-use-case.js.map +1 -0
- package/dist/application/runtime-target.d.ts +25 -0
- package/dist/application/runtime-target.js +41 -0
- package/dist/application/runtime-target.js.map +1 -0
- package/dist/application/service-use-cases.d.ts +45 -0
- package/dist/application/service-use-cases.js +100 -0
- package/dist/application/service-use-cases.js.map +1 -0
- package/dist/application/set-config-value-use-case.d.ts +5 -0
- package/dist/application/set-config-value-use-case.js +87 -0
- package/dist/application/set-config-value-use-case.js.map +1 -0
- package/dist/application/validate-config-use-case.d.ts +3 -0
- package/dist/application/validate-config-use-case.js +14 -0
- package/dist/application/validate-config-use-case.js.map +1 -0
- package/dist/application/view-logs-use-case.d.ts +6 -0
- package/dist/application/view-logs-use-case.js +14 -0
- package/dist/application/view-logs-use-case.js.map +1 -0
- package/dist/cli/create-cli.d.ts +68 -0
- package/dist/cli/create-cli.js +188 -0
- package/dist/cli/create-cli.js.map +1 -0
- package/dist/config/default-app-config.d.ts +20 -0
- package/dist/config/default-app-config.js +138 -0
- package/dist/config/default-app-config.js.map +1 -0
- package/dist/config/discover-config-path.d.ts +10 -0
- package/dist/config/discover-config-path.js +71 -0
- package/dist/config/discover-config-path.js.map +1 -0
- package/dist/config/init-app-config.d.ts +13 -0
- package/dist/config/init-app-config.js +31 -0
- package/dist/config/init-app-config.js.map +1 -0
- package/dist/config/load-app-config.d.ts +2 -0
- package/dist/config/load-app-config.js +29 -0
- package/dist/config/load-app-config.js.map +1 -0
- package/dist/config/prompt-init-config.d.ts +15 -0
- package/dist/config/prompt-init-config.js +201 -0
- package/dist/config/prompt-init-config.js.map +1 -0
- package/dist/config/resolve-runtime-config.d.ts +8 -0
- package/dist/config/resolve-runtime-config.js +122 -0
- package/dist/config/resolve-runtime-config.js.map +1 -0
- package/dist/config/schema.d.ts +3 -0
- package/dist/config/schema.js +203 -0
- package/dist/config/schema.js.map +1 -0
- package/dist/config/secret-value.d.ts +20 -0
- package/dist/config/secret-value.js +69 -0
- package/dist/config/secret-value.js.map +1 -0
- package/dist/config/types.d.ts +76 -0
- package/dist/config/types.js +2 -0
- package/dist/config/types.js.map +1 -0
- package/dist/config/validate-secret-references.d.ts +7 -0
- package/dist/config/validate-secret-references.js +14 -0
- package/dist/config/validate-secret-references.js.map +1 -0
- package/dist/daemon/bootstrap/acquire-runtime-state.d.ts +6 -0
- package/dist/daemon/bootstrap/acquire-runtime-state.js +19 -0
- package/dist/daemon/bootstrap/acquire-runtime-state.js.map +1 -0
- package/dist/daemon/bootstrap/build-runtime-components.d.ts +21 -0
- package/dist/daemon/bootstrap/build-runtime-components.js +26 -0
- package/dist/daemon/bootstrap/build-runtime-components.js.map +1 -0
- package/dist/daemon/bootstrap/prepare-runtime-filesystem.d.ts +2 -0
- package/dist/daemon/bootstrap/prepare-runtime-filesystem.js +11 -0
- package/dist/daemon/bootstrap/prepare-runtime-filesystem.js.map +1 -0
- package/dist/daemon/create-daemon.d.ts +13 -0
- package/dist/daemon/create-daemon.js +98 -0
- package/dist/daemon/create-daemon.js.map +1 -0
- package/dist/daemon/runtime-bootstrap.d.ts +12 -0
- package/dist/daemon/runtime-bootstrap.js +24 -0
- package/dist/daemon/runtime-bootstrap.js.map +1 -0
- package/dist/daemon/runtime-runner.d.ts +18 -0
- package/dist/daemon/runtime-runner.js +126 -0
- package/dist/daemon/runtime-runner.js.map +1 -0
- package/dist/daemon/runtime-shutdown.d.ts +15 -0
- package/dist/daemon/runtime-shutdown.js +50 -0
- package/dist/daemon/runtime-shutdown.js.map +1 -0
- package/dist/daemon/runtime-state.d.ts +10 -0
- package/dist/daemon/runtime-state.js +90 -0
- package/dist/daemon/runtime-state.js.map +1 -0
- package/dist/daemon/types.d.ts +63 -0
- package/dist/daemon/types.js +2 -0
- package/dist/daemon/types.js.map +1 -0
- package/dist/domain/agent.d.ts +51 -0
- package/dist/domain/agent.js +2 -0
- package/dist/domain/agent.js.map +1 -0
- package/dist/domain/conversation.d.ts +51 -0
- package/dist/domain/conversation.js +2 -0
- package/dist/domain/conversation.js.map +1 -0
- package/dist/domain/errors.d.ts +13 -0
- package/dist/domain/errors.js +27 -0
- package/dist/domain/errors.js.map +1 -0
- package/dist/domain/message.d.ts +27 -0
- package/dist/domain/message.js +2 -0
- package/dist/domain/message.js.map +1 -0
- package/dist/files/backup.d.ts +2 -0
- package/dist/files/backup.js +7 -0
- package/dist/files/backup.js.map +1 -0
- package/dist/files/managed-file.d.ts +11 -0
- package/dist/files/managed-file.js +82 -0
- package/dist/files/managed-file.js.map +1 -0
- package/dist/files/tar-archive.d.ts +7 -0
- package/dist/files/tar-archive.js +308 -0
- package/dist/files/tar-archive.js.map +1 -0
- package/dist/index.d.ts +2 -0
- package/dist/index.js +2 -0
- package/dist/index.js.map +1 -0
- package/dist/logging/daemon-startup-failure-reporter.d.ts +2 -0
- package/dist/logging/daemon-startup-failure-reporter.js +19 -0
- package/dist/logging/daemon-startup-failure-reporter.js.map +1 -0
- package/dist/logging/file-logger.d.ts +3 -0
- package/dist/logging/file-logger.js +87 -0
- package/dist/logging/file-logger.js.map +1 -0
- package/dist/logging/types.d.ts +34 -0
- package/dist/logging/types.js +2 -0
- package/dist/logging/types.js.map +1 -0
- package/dist/logging/view-logs.d.ts +27 -0
- package/dist/logging/view-logs.js +171 -0
- package/dist/logging/view-logs.js.map +1 -0
- package/dist/main.d.ts +2 -0
- package/dist/main.js +109 -0
- package/dist/main.js.map +1 -0
- package/dist/plugins/hook-runner.d.ts +11 -0
- package/dist/plugins/hook-runner.js +41 -0
- package/dist/plugins/hook-runner.js.map +1 -0
- package/dist/plugins/index.d.ts +2 -0
- package/dist/plugins/index.js +2 -0
- package/dist/plugins/index.js.map +1 -0
- package/dist/plugins/types.d.ts +64 -0
- package/dist/plugins/types.js +2 -0
- package/dist/plugins/types.js.map +1 -0
- package/dist/runtime/agent-execution.d.ts +42 -0
- package/dist/runtime/agent-execution.js +109 -0
- package/dist/runtime/agent-execution.js.map +1 -0
- package/dist/runtime/context.d.ts +20 -0
- package/dist/runtime/context.js +2 -0
- package/dist/runtime/context.js.map +1 -0
- package/dist/runtime/create-oauth-api-key-resolver.d.ts +9 -0
- package/dist/runtime/create-oauth-api-key-resolver.js +66 -0
- package/dist/runtime/create-oauth-api-key-resolver.js.map +1 -0
- package/dist/runtime/create-pi-agent-engine.d.ts +28 -0
- package/dist/runtime/create-pi-agent-engine.js +150 -0
- package/dist/runtime/create-pi-agent-engine.js.map +1 -0
- package/dist/runtime/mcp-tool-cache.d.ts +13 -0
- package/dist/runtime/mcp-tool-cache.js +43 -0
- package/dist/runtime/mcp-tool-cache.js.map +1 -0
- package/dist/runtime/mcp-tool-runtime.d.ts +76 -0
- package/dist/runtime/mcp-tool-runtime.js +180 -0
- package/dist/runtime/mcp-tool-runtime.js.map +1 -0
- package/dist/runtime/message-mapping.d.ts +11 -0
- package/dist/runtime/message-mapping.js +129 -0
- package/dist/runtime/message-mapping.js.map +1 -0
- package/dist/runtime/model-resolution.d.ts +5 -0
- package/dist/runtime/model-resolution.js +13 -0
- package/dist/runtime/model-resolution.js.map +1 -0
- package/dist/runtime/pipeline/execute-agent-stage.d.ts +12 -0
- package/dist/runtime/pipeline/execute-agent-stage.js +25 -0
- package/dist/runtime/pipeline/execute-agent-stage.js.map +1 -0
- package/dist/runtime/pipeline/resolve-model-stage.d.ts +8 -0
- package/dist/runtime/pipeline/resolve-model-stage.js +9 -0
- package/dist/runtime/pipeline/resolve-model-stage.js.map +1 -0
- package/dist/runtime/pipeline/resolve-prompt-stage.d.ts +12 -0
- package/dist/runtime/pipeline/resolve-prompt-stage.js +30 -0
- package/dist/runtime/pipeline/resolve-prompt-stage.js.map +1 -0
- package/dist/runtime/pipeline/resolve-tools-stage.d.ts +27 -0
- package/dist/runtime/pipeline/resolve-tools-stage.js +46 -0
- package/dist/runtime/pipeline/resolve-tools-stage.js.map +1 -0
- package/dist/runtime/prompt-template.d.ts +54 -0
- package/dist/runtime/prompt-template.js +78 -0
- package/dist/runtime/prompt-template.js.map +1 -0
- package/dist/runtime/system-prompt-cache.d.ts +33 -0
- package/dist/runtime/system-prompt-cache.js +77 -0
- package/dist/runtime/system-prompt-cache.js.map +1 -0
- package/dist/runtime/system-prompt-resolution.d.ts +22 -0
- package/dist/runtime/system-prompt-resolution.js +170 -0
- package/dist/runtime/system-prompt-resolution.js.map +1 -0
- package/dist/runtime/tool-resolution.d.ts +19 -0
- package/dist/runtime/tool-resolution.js +281 -0
- package/dist/runtime/tool-resolution.js.map +1 -0
- package/dist/runtime/types.d.ts +23 -0
- package/dist/runtime/types.js +2 -0
- package/dist/runtime/types.js.map +1 -0
- package/dist/service/install-plan.d.ts +21 -0
- package/dist/service/install-plan.js +71 -0
- package/dist/service/install-plan.js.map +1 -0
- package/dist/service/install-service.d.ts +32 -0
- package/dist/service/install-service.js +80 -0
- package/dist/service/install-service.js.map +1 -0
- package/dist/service/linux-service-environment.d.ts +5 -0
- package/dist/service/linux-service-environment.js +61 -0
- package/dist/service/linux-service-environment.js.map +1 -0
- package/dist/service/manage-service.d.ts +14 -0
- package/dist/service/manage-service.js +36 -0
- package/dist/service/manage-service.js.map +1 -0
- package/dist/service/platforms/get-service-platform-adapter.d.ts +3 -0
- package/dist/service/platforms/get-service-platform-adapter.js +12 -0
- package/dist/service/platforms/get-service-platform-adapter.js.map +1 -0
- package/dist/service/platforms/linux-systemd-user-adapter.d.ts +2 -0
- package/dist/service/platforms/linux-systemd-user-adapter.js +99 -0
- package/dist/service/platforms/linux-systemd-user-adapter.js.map +1 -0
- package/dist/service/platforms/macos-launchd-adapter.d.ts +2 -0
- package/dist/service/platforms/macos-launchd-adapter.js +122 -0
- package/dist/service/platforms/macos-launchd-adapter.js.map +1 -0
- package/dist/service/platforms/service-platform-adapter.d.ts +35 -0
- package/dist/service/platforms/service-platform-adapter.js +16 -0
- package/dist/service/platforms/service-platform-adapter.js.map +1 -0
- package/dist/service/platforms/windows-winsw-adapter.d.ts +2 -0
- package/dist/service/platforms/windows-winsw-adapter.js +47 -0
- package/dist/service/platforms/windows-winsw-adapter.js.map +1 -0
- package/dist/service/service-error.d.ts +7 -0
- package/dist/service/service-error.js +45 -0
- package/dist/service/service-error.js.map +1 -0
- package/dist/service/service-installer.d.ts +8 -0
- package/dist/service/service-installer.js +40 -0
- package/dist/service/service-installer.js.map +1 -0
- package/dist/service/service-operation-result.d.ts +9 -0
- package/dist/service/service-operation-result.js +2 -0
- package/dist/service/service-operation-result.js.map +1 -0
- package/dist/service/uninstall-service.d.ts +13 -0
- package/dist/service/uninstall-service.js +45 -0
- package/dist/service/uninstall-service.js.map +1 -0
- package/dist/skills/discovery.d.ts +10 -0
- package/dist/skills/discovery.js +216 -0
- package/dist/skills/discovery.js.map +1 -0
- package/dist/skills/types.d.ts +20 -0
- package/dist/skills/types.js +2 -0
- package/dist/skills/types.js.map +1 -0
- package/dist/storage/fs-store.d.ts +3 -0
- package/dist/storage/fs-store.js +707 -0
- package/dist/storage/fs-store.js.map +1 -0
- package/dist/storage/types.d.ts +29 -0
- package/dist/storage/types.js +2 -0
- package/dist/storage/types.js.map +1 -0
- package/dist/tools/registry.d.ts +7 -0
- package/dist/tools/registry.js +18 -0
- package/dist/tools/registry.js.map +1 -0
- package/dist/tools/types.d.ts +14 -0
- package/dist/tools/types.js +2 -0
- package/dist/tools/types.js.map +1 -0
- package/dist/transports/builtins.d.ts +1 -0
- package/dist/transports/builtins.js +15 -0
- package/dist/transports/builtins.js.map +1 -0
- package/dist/transports/registry.d.ts +21 -0
- package/dist/transports/registry.js +28 -0
- package/dist/transports/registry.js.map +1 -0
- package/dist/transports/telegram/openai-voice-transcriber.d.ts +18 -0
- package/dist/transports/telegram/openai-voice-transcriber.js +75 -0
- package/dist/transports/telegram/openai-voice-transcriber.js.map +1 -0
- package/dist/transports/telegram/render-telegram-message.d.ts +2 -0
- package/dist/transports/telegram/render-telegram-message.js +458 -0
- package/dist/transports/telegram/render-telegram-message.js.map +1 -0
- package/dist/transports/telegram/telegram-transport.d.ts +56 -0
- package/dist/transports/telegram/telegram-transport.js +414 -0
- package/dist/transports/telegram/telegram-transport.js.map +1 -0
- package/dist/transports/telegram/transport-adapter.d.ts +33 -0
- package/dist/transports/telegram/transport-adapter.js +62 -0
- package/dist/transports/telegram/transport-adapter.js.map +1 -0
- package/dist/transports/types.d.ts +15 -0
- package/dist/transports/types.js +2 -0
- package/dist/transports/types.js.map +1 -0
- package/package.json +49 -0
|
@@ -0,0 +1,171 @@
|
|
|
1
|
+
import { readFile, watch } from "node:fs/promises";
|
|
2
|
+
export async function viewDaemonLogs(options) {
|
|
3
|
+
const stdout = options.stdout ?? process.stdout;
|
|
4
|
+
const readFileImpl = options.dependencies?.readFile ?? readFile;
|
|
5
|
+
const watchImpl = options.dependencies?.watch ?? watch;
|
|
6
|
+
const lines = options.lines ?? 50;
|
|
7
|
+
assertPositiveLineCount(lines);
|
|
8
|
+
const targets = resolveLogTargets(options.runtimeConfig, options.endpointId);
|
|
9
|
+
const multiEndpoint = targets.length > 1;
|
|
10
|
+
for (const target of targets) {
|
|
11
|
+
const recentLines = await readRecentLogLines(target.logFilePath, lines, readFileImpl);
|
|
12
|
+
writeLogLines(stdout, target.endpointId, recentLines, multiEndpoint);
|
|
13
|
+
}
|
|
14
|
+
if (!options.follow) {
|
|
15
|
+
return;
|
|
16
|
+
}
|
|
17
|
+
await followLogTargets({
|
|
18
|
+
targets,
|
|
19
|
+
stdout,
|
|
20
|
+
signal: options.signal,
|
|
21
|
+
multiEndpoint,
|
|
22
|
+
readFile: readFileImpl,
|
|
23
|
+
watch: watchImpl,
|
|
24
|
+
});
|
|
25
|
+
}
|
|
26
|
+
export function resolveLogTargets(runtimeConfig, endpointId) {
|
|
27
|
+
if (endpointId) {
|
|
28
|
+
const targetBot = runtimeConfig.activeEndpoints.find((endpoint) => endpoint.id === endpointId);
|
|
29
|
+
if (!targetBot) {
|
|
30
|
+
throw new Error(`Unknown endpoint ID: ${endpointId}`);
|
|
31
|
+
}
|
|
32
|
+
return [
|
|
33
|
+
{
|
|
34
|
+
endpointId: targetBot.id,
|
|
35
|
+
logFilePath: targetBot.paths.logFilePath,
|
|
36
|
+
},
|
|
37
|
+
];
|
|
38
|
+
}
|
|
39
|
+
return runtimeConfig.activeEndpoints.map((endpoint) => ({
|
|
40
|
+
endpointId: endpoint.id,
|
|
41
|
+
logFilePath: endpoint.paths.logFilePath,
|
|
42
|
+
}));
|
|
43
|
+
}
|
|
44
|
+
export async function readRecentLogLines(logFilePath, lines, readFileImpl = readFile) {
|
|
45
|
+
try {
|
|
46
|
+
const content = await readFileImpl(logFilePath, "utf8");
|
|
47
|
+
const allLines = content
|
|
48
|
+
.split("\n")
|
|
49
|
+
.map((line) => line.trimEnd())
|
|
50
|
+
.filter((line) => line.length > 0);
|
|
51
|
+
return allLines.slice(-lines);
|
|
52
|
+
}
|
|
53
|
+
catch (error) {
|
|
54
|
+
if (isMissingFileError(error)) {
|
|
55
|
+
throw new Error(`Log file not found: ${logFilePath}`);
|
|
56
|
+
}
|
|
57
|
+
throw error;
|
|
58
|
+
}
|
|
59
|
+
}
|
|
60
|
+
async function followLogTargets(options) {
|
|
61
|
+
const abortController = options.signal ? undefined : new AbortController();
|
|
62
|
+
const signal = options.signal ?? abortController?.signal;
|
|
63
|
+
const cleanup = registerFollowCleanup(abortController);
|
|
64
|
+
const offsets = new Map();
|
|
65
|
+
const watchers = [];
|
|
66
|
+
const pendingWatchTasks = [];
|
|
67
|
+
try {
|
|
68
|
+
for (const target of options.targets) {
|
|
69
|
+
const content = await options.readFile(target.logFilePath, "utf8");
|
|
70
|
+
offsets.set(target.endpointId, content.length);
|
|
71
|
+
const watcher = options.watch(target.logFilePath, {
|
|
72
|
+
signal,
|
|
73
|
+
});
|
|
74
|
+
watchers.push(watcher);
|
|
75
|
+
pendingWatchTasks.push(watchTarget(watcher, target, options, offsets));
|
|
76
|
+
}
|
|
77
|
+
if (!signal) {
|
|
78
|
+
return;
|
|
79
|
+
}
|
|
80
|
+
await waitForAbort(signal);
|
|
81
|
+
}
|
|
82
|
+
finally {
|
|
83
|
+
cleanup.dispose();
|
|
84
|
+
await Promise.allSettled(watchers.map((watcher) => closeWatcher(watcher)));
|
|
85
|
+
await Promise.allSettled(pendingWatchTasks);
|
|
86
|
+
}
|
|
87
|
+
}
|
|
88
|
+
async function watchTarget(watcher, target, options, offsets) {
|
|
89
|
+
try {
|
|
90
|
+
for await (const event of watcher) {
|
|
91
|
+
if (event.eventType !== "change") {
|
|
92
|
+
continue;
|
|
93
|
+
}
|
|
94
|
+
const content = await options.readFile(target.logFilePath, "utf8");
|
|
95
|
+
const previousOffset = offsets.get(target.endpointId) ?? 0;
|
|
96
|
+
const nextChunk = content.slice(previousOffset);
|
|
97
|
+
offsets.set(target.endpointId, content.length);
|
|
98
|
+
const newLines = nextChunk
|
|
99
|
+
.split("\n")
|
|
100
|
+
.map((line) => line.trimEnd())
|
|
101
|
+
.filter((line) => line.length > 0);
|
|
102
|
+
writeLogLines(options.stdout, target.endpointId, newLines, options.multiEndpoint);
|
|
103
|
+
}
|
|
104
|
+
}
|
|
105
|
+
catch (error) {
|
|
106
|
+
if (isAbortError(error)) {
|
|
107
|
+
return;
|
|
108
|
+
}
|
|
109
|
+
throw error;
|
|
110
|
+
}
|
|
111
|
+
}
|
|
112
|
+
function writeLogLines(stdout, endpointId, lines, multiEndpoint) {
|
|
113
|
+
for (const line of lines) {
|
|
114
|
+
stdout.write(multiEndpoint ? `[${endpointId}] ${line}\n` : `${line}\n`);
|
|
115
|
+
}
|
|
116
|
+
}
|
|
117
|
+
function assertPositiveLineCount(lines) {
|
|
118
|
+
if (!Number.isInteger(lines) || lines <= 0) {
|
|
119
|
+
throw new Error("`--lines` must be a positive integer.");
|
|
120
|
+
}
|
|
121
|
+
}
|
|
122
|
+
function registerFollowCleanup(abortController) {
|
|
123
|
+
if (!abortController) {
|
|
124
|
+
return {
|
|
125
|
+
dispose() { },
|
|
126
|
+
};
|
|
127
|
+
}
|
|
128
|
+
const abort = () => {
|
|
129
|
+
abortController.abort();
|
|
130
|
+
};
|
|
131
|
+
process.once("SIGINT", abort);
|
|
132
|
+
process.once("SIGTERM", abort);
|
|
133
|
+
return {
|
|
134
|
+
dispose() {
|
|
135
|
+
process.off("SIGINT", abort);
|
|
136
|
+
process.off("SIGTERM", abort);
|
|
137
|
+
},
|
|
138
|
+
};
|
|
139
|
+
}
|
|
140
|
+
function waitForAbort(signal) {
|
|
141
|
+
if (signal.aborted) {
|
|
142
|
+
return Promise.resolve();
|
|
143
|
+
}
|
|
144
|
+
return new Promise((resolve) => {
|
|
145
|
+
signal.addEventListener("abort", () => resolve(), { once: true });
|
|
146
|
+
});
|
|
147
|
+
}
|
|
148
|
+
async function closeWatcher(watcher) {
|
|
149
|
+
const iterator = watcher[Symbol.asyncIterator]();
|
|
150
|
+
if (typeof iterator.return !== "function") {
|
|
151
|
+
return;
|
|
152
|
+
}
|
|
153
|
+
try {
|
|
154
|
+
await iterator.return();
|
|
155
|
+
}
|
|
156
|
+
catch (error) {
|
|
157
|
+
if (isAbortError(error)) {
|
|
158
|
+
return;
|
|
159
|
+
}
|
|
160
|
+
throw error;
|
|
161
|
+
}
|
|
162
|
+
}
|
|
163
|
+
function isMissingFileError(error) {
|
|
164
|
+
return error instanceof Error && "code" in error && error.code === "ENOENT";
|
|
165
|
+
}
|
|
166
|
+
function isAbortError(error) {
|
|
167
|
+
return (error instanceof Error &&
|
|
168
|
+
(error.name === "AbortError" ||
|
|
169
|
+
(error.name === "Error" && error.message.includes("This operation was aborted"))));
|
|
170
|
+
}
|
|
171
|
+
//# sourceMappingURL=view-logs.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"view-logs.js","sourceRoot":"","sources":["../../src/logging/view-logs.ts"],"names":[],"mappings":"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"}
|
package/dist/main.d.ts
ADDED
package/dist/main.js
ADDED
|
@@ -0,0 +1,109 @@
|
|
|
1
|
+
#!/usr/bin/env node
|
|
2
|
+
import { createBackupUseCases } from "./application/backup-use-cases.js";
|
|
3
|
+
import { createGetConfigValueUseCase } from "./application/get-config-value-use-case.js";
|
|
4
|
+
import { createInitConfigUseCase } from "./application/init-config-use-case.js";
|
|
5
|
+
import { createReloadConfigUseCase } from "./application/reload-config-use-case.js";
|
|
6
|
+
import { createRunDaemonUseCase } from "./application/run-daemon-use-case.js";
|
|
7
|
+
import { createServiceUseCases } from "./application/service-use-cases.js";
|
|
8
|
+
import { createSetConfigValueUseCase } from "./application/set-config-value-use-case.js";
|
|
9
|
+
import { createValidateConfigUseCase } from "./application/validate-config-use-case.js";
|
|
10
|
+
import { createViewLogsUseCase } from "./application/view-logs-use-case.js";
|
|
11
|
+
import { createCli } from "./cli/create-cli.js";
|
|
12
|
+
import { ConfigurationError, RuntimeStateError, TransportResolutionError, UnsupportedPlatformError, } from "./domain/errors.js";
|
|
13
|
+
import { createDaemonStartupFailureReporter } from "./logging/daemon-startup-failure-reporter.js";
|
|
14
|
+
const EXIT_CODES = {
|
|
15
|
+
unknown: 1,
|
|
16
|
+
configuration: 2,
|
|
17
|
+
unsupportedPlatform: 3,
|
|
18
|
+
transportResolution: 4,
|
|
19
|
+
runtimeState: 5,
|
|
20
|
+
};
|
|
21
|
+
async function main() {
|
|
22
|
+
const serviceUseCases = createServiceUseCases();
|
|
23
|
+
const startupFailureReporter = createDaemonStartupFailureReporter();
|
|
24
|
+
const runDaemonUseCase = createRunDaemonUseCase({ startupFailureReporter });
|
|
25
|
+
const validateConfigUseCase = createValidateConfigUseCase();
|
|
26
|
+
const backupUseCases = createBackupUseCases();
|
|
27
|
+
const cli = createCli({
|
|
28
|
+
startDaemon: async (options) => {
|
|
29
|
+
const outcome = await runDaemonUseCase(options);
|
|
30
|
+
presentRunDaemonOutcome(outcome);
|
|
31
|
+
},
|
|
32
|
+
viewLogs: createViewLogsUseCase(),
|
|
33
|
+
validateConfig: validateConfigUseCase,
|
|
34
|
+
reloadConfig: createReloadConfigUseCase(),
|
|
35
|
+
getConfigValue: createGetConfigValueUseCase(),
|
|
36
|
+
setConfigValue: createSetConfigValueUseCase(),
|
|
37
|
+
initConfig: createInitConfigUseCase(),
|
|
38
|
+
createBackup: backupUseCases.createBackup,
|
|
39
|
+
restoreBackup: backupUseCases.restoreBackup,
|
|
40
|
+
installService: serviceUseCases.installService,
|
|
41
|
+
uninstallService: serviceUseCases.uninstallService,
|
|
42
|
+
startService: serviceUseCases.startService,
|
|
43
|
+
stopService: serviceUseCases.stopService,
|
|
44
|
+
restartService: serviceUseCases.restartService,
|
|
45
|
+
statusService: serviceUseCases.statusService,
|
|
46
|
+
});
|
|
47
|
+
if (process.argv.length <= 2) {
|
|
48
|
+
cli.outputHelp();
|
|
49
|
+
return;
|
|
50
|
+
}
|
|
51
|
+
await cli.parseAsync(process.argv);
|
|
52
|
+
}
|
|
53
|
+
function presentRunDaemonOutcome(outcome) {
|
|
54
|
+
if (outcome.status === "started") {
|
|
55
|
+
return;
|
|
56
|
+
}
|
|
57
|
+
presentCliError(outcome.error);
|
|
58
|
+
}
|
|
59
|
+
function presentCliError(error) {
|
|
60
|
+
const normalizedError = normalizeCliError(error);
|
|
61
|
+
console.error(`${normalizedError.label}: ${normalizedError.message}`);
|
|
62
|
+
process.exitCode = normalizedError.exitCode;
|
|
63
|
+
}
|
|
64
|
+
function normalizeCliError(error) {
|
|
65
|
+
if (error instanceof ConfigurationError) {
|
|
66
|
+
return {
|
|
67
|
+
label: "Configuration error",
|
|
68
|
+
message: error.message,
|
|
69
|
+
exitCode: EXIT_CODES.configuration,
|
|
70
|
+
};
|
|
71
|
+
}
|
|
72
|
+
if (error instanceof UnsupportedPlatformError) {
|
|
73
|
+
return {
|
|
74
|
+
label: "Unsupported platform",
|
|
75
|
+
message: error.message,
|
|
76
|
+
exitCode: EXIT_CODES.unsupportedPlatform,
|
|
77
|
+
};
|
|
78
|
+
}
|
|
79
|
+
if (error instanceof TransportResolutionError) {
|
|
80
|
+
return {
|
|
81
|
+
label: "Transport resolution error",
|
|
82
|
+
message: error.message,
|
|
83
|
+
exitCode: EXIT_CODES.transportResolution,
|
|
84
|
+
};
|
|
85
|
+
}
|
|
86
|
+
if (error instanceof RuntimeStateError) {
|
|
87
|
+
return {
|
|
88
|
+
label: "Runtime state error",
|
|
89
|
+
message: error.message,
|
|
90
|
+
exitCode: EXIT_CODES.runtimeState,
|
|
91
|
+
};
|
|
92
|
+
}
|
|
93
|
+
if (error instanceof Error) {
|
|
94
|
+
return {
|
|
95
|
+
label: "Unexpected error",
|
|
96
|
+
message: error.message,
|
|
97
|
+
exitCode: EXIT_CODES.unknown,
|
|
98
|
+
};
|
|
99
|
+
}
|
|
100
|
+
return {
|
|
101
|
+
label: "Unexpected error",
|
|
102
|
+
message: String(error),
|
|
103
|
+
exitCode: EXIT_CODES.unknown,
|
|
104
|
+
};
|
|
105
|
+
}
|
|
106
|
+
main().catch((error) => {
|
|
107
|
+
presentCliError(error);
|
|
108
|
+
});
|
|
109
|
+
//# sourceMappingURL=main.js.map
|
package/dist/main.js.map
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"main.js","sourceRoot":"","sources":["../src/main.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import type { Logger } from "../logging/types.js";
|
|
2
|
+
import type { HookRegistration, MaybePromise } from "./types.js";
|
|
3
|
+
export type HookFn<TContext> = (context: TContext) => MaybePromise<void>;
|
|
4
|
+
export interface HookRunnerOptions {
|
|
5
|
+
logger?: Logger;
|
|
6
|
+
}
|
|
7
|
+
export interface HookRunner<THooks> {
|
|
8
|
+
run<TContext>(hookName: string, selectHook: (hooks: THooks) => HookFn<TContext> | undefined, context: TContext): Promise<void>;
|
|
9
|
+
runErrorHook<TContext>(hookName: string, selectHook: (hooks: THooks) => HookFn<TContext> | undefined, context: TContext): Promise<void>;
|
|
10
|
+
}
|
|
11
|
+
export declare function createHookRunner<THooks>(registrations?: ReadonlyArray<HookRegistration<THooks>>, options?: HookRunnerOptions): HookRunner<THooks>;
|
|
@@ -0,0 +1,41 @@
|
|
|
1
|
+
export function createHookRunner(registrations = [], options = {}) {
|
|
2
|
+
return {
|
|
3
|
+
async run(hookName, selectHook, context) {
|
|
4
|
+
for (const registration of registrations) {
|
|
5
|
+
const hook = selectHook(registration.hooks);
|
|
6
|
+
if (!hook) {
|
|
7
|
+
continue;
|
|
8
|
+
}
|
|
9
|
+
try {
|
|
10
|
+
await hook(context);
|
|
11
|
+
}
|
|
12
|
+
catch (error) {
|
|
13
|
+
await logHookFailure(options.logger, hookName, registration.name, error);
|
|
14
|
+
throw error;
|
|
15
|
+
}
|
|
16
|
+
}
|
|
17
|
+
},
|
|
18
|
+
async runErrorHook(hookName, selectHook, context) {
|
|
19
|
+
for (const registration of registrations) {
|
|
20
|
+
const hook = selectHook(registration.hooks);
|
|
21
|
+
if (!hook) {
|
|
22
|
+
continue;
|
|
23
|
+
}
|
|
24
|
+
try {
|
|
25
|
+
await hook(context);
|
|
26
|
+
}
|
|
27
|
+
catch (error) {
|
|
28
|
+
await logHookFailure(options.logger, hookName, registration.name, error);
|
|
29
|
+
}
|
|
30
|
+
}
|
|
31
|
+
},
|
|
32
|
+
};
|
|
33
|
+
}
|
|
34
|
+
async function logHookFailure(logger, hookName, registrationName, error) {
|
|
35
|
+
await logger?.error("plugin hook failed", {
|
|
36
|
+
hookName,
|
|
37
|
+
hookRegistrationName: registrationName,
|
|
38
|
+
errorType: error instanceof Error ? error.name : typeof error,
|
|
39
|
+
}, error instanceof Error ? error : new Error(String(error ?? "Unknown hook error")));
|
|
40
|
+
}
|
|
41
|
+
//# sourceMappingURL=hook-runner.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"hook-runner.js","sourceRoot":"","sources":["../../src/plugins/hook-runner.ts"],"names":[],"mappings":"AAsBA,MAAM,UAAU,gBAAgB,CAC9B,gBAAyD,EAAE,EAC3D,UAA6B,EAAE;IAE/B,OAAO;QACL,KAAK,CAAC,GAAG,CACP,QAAgB,EAChB,UAA2D,EAC3D,OAAiB;YAEjB,KAAK,MAAM,YAAY,IAAI,aAAa,EAAE,CAAC;gBACzC,MAAM,IAAI,GAAG,UAAU,CAAC,YAAY,CAAC,KAAK,CAAC,CAAC;gBAC5C,IAAI,CAAC,IAAI,EAAE,CAAC;oBACV,SAAS;gBACX,CAAC;gBAED,IAAI,CAAC;oBACH,MAAM,IAAI,CAAC,OAAO,CAAC,CAAC;gBACtB,CAAC;gBAAC,OAAO,KAAK,EAAE,CAAC;oBACf,MAAM,cAAc,CAAC,OAAO,CAAC,MAAM,EAAE,QAAQ,EAAE,YAAY,CAAC,IAAI,EAAE,KAAK,CAAC,CAAC;oBACzE,MAAM,KAAK,CAAC;gBACd,CAAC;YACH,CAAC;QACH,CAAC;QAED,KAAK,CAAC,YAAY,CAChB,QAAgB,EAChB,UAA2D,EAC3D,OAAiB;YAEjB,KAAK,MAAM,YAAY,IAAI,aAAa,EAAE,CAAC;gBACzC,MAAM,IAAI,GAAG,UAAU,CAAC,YAAY,CAAC,KAAK,CAAC,CAAC;gBAC5C,IAAI,CAAC,IAAI,EAAE,CAAC;oBACV,SAAS;gBACX,CAAC;gBAED,IAAI,CAAC;oBACH,MAAM,IAAI,CAAC,OAAO,CAAC,CAAC;gBACtB,CAAC;gBAAC,OAAO,KAAK,EAAE,CAAC;oBACf,MAAM,cAAc,CAAC,OAAO,CAAC,MAAM,EAAE,QAAQ,EAAE,YAAY,CAAC,IAAI,EAAE,KAAK,CAAC,CAAC;gBAC3E,CAAC;YACH,CAAC;QACH,CAAC;KACF,CAAC;AACJ,CAAC;AAED,KAAK,UAAU,cAAc,CAC3B,MAA0B,EAC1B,QAAgB,EAChB,gBAAwB,EACxB,KAAc;IAEd,MAAM,MAAM,EAAE,KAAK,CACjB,oBAAoB,EACpB;QACE,QAAQ;QACR,oBAAoB,EAAE,gBAAgB;QACtC,SAAS,EAAE,KAAK,YAAY,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,OAAO,KAAK;KAC9D,EACD,KAAK,YAAY,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,KAAK,CAAC,MAAM,CAAC,KAAK,IAAI,oBAAoB,CAAC,CAAC,CAClF,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export { createHookRunner, type HookFn, type HookRunner } from "./hook-runner.js";
|
|
2
|
+
export type { AgentEngineLifecycleHooks, AgentEngineRunErrorContext, AgentEngineRunStartContext, AgentEngineRunSuccessContext, CommandContribution, HookRegistration, ImpPlugin, InboundMessageErrorContext, InboundMessageLifecycleHooks, InboundMessageStartContext, InboundMessageSuccessContext, MaybePromise, PluginContributions, PluginHooks, ToolContribution, } from "./types.js";
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/plugins/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,gBAAgB,EAAgC,MAAM,kBAAkB,CAAC"}
|
|
@@ -0,0 +1,64 @@
|
|
|
1
|
+
import type { InboundCommandHandler } from "../application/commands/types.js";
|
|
2
|
+
import type { AgentRunInput, AgentRunResult } from "../runtime/context.js";
|
|
3
|
+
import type { ToolDefinition } from "../tools/types.js";
|
|
4
|
+
import type { IncomingMessage, OutgoingMessage } from "../domain/message.js";
|
|
5
|
+
export type MaybePromise<T> = T | Promise<T>;
|
|
6
|
+
export interface InboundMessageStartContext {
|
|
7
|
+
message: IncomingMessage;
|
|
8
|
+
}
|
|
9
|
+
export interface InboundMessageSuccessContext {
|
|
10
|
+
message: IncomingMessage;
|
|
11
|
+
response: OutgoingMessage;
|
|
12
|
+
durationMs: number;
|
|
13
|
+
}
|
|
14
|
+
export interface InboundMessageErrorContext {
|
|
15
|
+
message: IncomingMessage;
|
|
16
|
+
error: unknown;
|
|
17
|
+
durationMs: number;
|
|
18
|
+
}
|
|
19
|
+
export interface InboundMessageLifecycleHooks {
|
|
20
|
+
onInboundMessageStart?(context: InboundMessageStartContext): MaybePromise<void>;
|
|
21
|
+
onInboundMessageSuccess?(context: InboundMessageSuccessContext): MaybePromise<void>;
|
|
22
|
+
onInboundMessageError?(context: InboundMessageErrorContext): MaybePromise<void>;
|
|
23
|
+
}
|
|
24
|
+
export interface AgentEngineRunStartContext {
|
|
25
|
+
input: AgentRunInput;
|
|
26
|
+
}
|
|
27
|
+
export interface AgentEngineRunSuccessContext {
|
|
28
|
+
input: AgentRunInput;
|
|
29
|
+
result: AgentRunResult;
|
|
30
|
+
durationMs: number;
|
|
31
|
+
}
|
|
32
|
+
export interface AgentEngineRunErrorContext {
|
|
33
|
+
input: AgentRunInput;
|
|
34
|
+
error: unknown;
|
|
35
|
+
durationMs: number;
|
|
36
|
+
}
|
|
37
|
+
export interface AgentEngineLifecycleHooks {
|
|
38
|
+
onAgentEngineRunStart?(context: AgentEngineRunStartContext): MaybePromise<void>;
|
|
39
|
+
onAgentEngineRunSuccess?(context: AgentEngineRunSuccessContext): MaybePromise<void>;
|
|
40
|
+
onAgentEngineRunError?(context: AgentEngineRunErrorContext): MaybePromise<void>;
|
|
41
|
+
}
|
|
42
|
+
export interface CommandContribution {
|
|
43
|
+
inboundCommands: ReadonlyArray<InboundCommandHandler>;
|
|
44
|
+
}
|
|
45
|
+
export interface ToolContribution {
|
|
46
|
+
tools: ReadonlyArray<ToolDefinition>;
|
|
47
|
+
}
|
|
48
|
+
export interface PluginHooks {
|
|
49
|
+
inboundMessage?: InboundMessageLifecycleHooks;
|
|
50
|
+
agentEngine?: AgentEngineLifecycleHooks;
|
|
51
|
+
}
|
|
52
|
+
export interface PluginContributions {
|
|
53
|
+
commands?: CommandContribution;
|
|
54
|
+
tools?: ToolContribution;
|
|
55
|
+
}
|
|
56
|
+
export interface ImpPlugin {
|
|
57
|
+
id: string;
|
|
58
|
+
hooks?: PluginHooks;
|
|
59
|
+
contributions?: PluginContributions;
|
|
60
|
+
}
|
|
61
|
+
export interface HookRegistration<THooks> {
|
|
62
|
+
name: string;
|
|
63
|
+
hooks: THooks;
|
|
64
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.js","sourceRoot":"","sources":["../../src/plugins/types.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,42 @@
|
|
|
1
|
+
import { Agent, type AgentOptions } from "@mariozechner/pi-agent-core";
|
|
2
|
+
import type { Api as AiApi, Model } from "@mariozechner/pi-ai";
|
|
3
|
+
import type { AgentDefinition } from "../domain/agent.js";
|
|
4
|
+
import type { ConversationEvent } from "../domain/conversation.js";
|
|
5
|
+
import type { ToolDefinition } from "../tools/types.js";
|
|
6
|
+
import { toAgentMessages } from "./message-mapping.js";
|
|
7
|
+
import type { WorkingDirectoryState } from "./tool-resolution.js";
|
|
8
|
+
export type AgentHandle = Pick<Agent, "prompt"> & {
|
|
9
|
+
state: Pick<Agent["state"], "messages">;
|
|
10
|
+
} & Partial<Pick<Agent, "subscribe">>;
|
|
11
|
+
export interface ExecuteAgentOptions {
|
|
12
|
+
createAgent?: (options: AgentOptions) => AgentHandle;
|
|
13
|
+
getApiKey?: (provider: string, agent: AgentDefinition) => Promise<string | undefined> | string | undefined;
|
|
14
|
+
agent: AgentDefinition;
|
|
15
|
+
model: Model<AiApi>;
|
|
16
|
+
systemPrompt: string;
|
|
17
|
+
tools: ToolDefinition[];
|
|
18
|
+
userText: string;
|
|
19
|
+
conversationMessages: Parameters<typeof toAgentMessages>[0];
|
|
20
|
+
onPayload: AgentOptions["onPayload"];
|
|
21
|
+
workingDirectoryState: WorkingDirectoryState;
|
|
22
|
+
initialWorkingDirectory: string;
|
|
23
|
+
conversation: {
|
|
24
|
+
transport: string;
|
|
25
|
+
externalId: string;
|
|
26
|
+
};
|
|
27
|
+
parentMessageId: string;
|
|
28
|
+
correlationId: string;
|
|
29
|
+
}
|
|
30
|
+
export interface ExecuteAgentResult {
|
|
31
|
+
message: {
|
|
32
|
+
conversation: {
|
|
33
|
+
transport: string;
|
|
34
|
+
externalId: string;
|
|
35
|
+
};
|
|
36
|
+
text: string;
|
|
37
|
+
};
|
|
38
|
+
conversationEvents: ConversationEvent[];
|
|
39
|
+
workingDirectory?: string;
|
|
40
|
+
}
|
|
41
|
+
export declare function defaultCreateAgent(options: AgentOptions): AgentHandle;
|
|
42
|
+
export declare function executeAgent(options: ExecuteAgentOptions): Promise<ExecuteAgentResult>;
|
|
@@ -0,0 +1,109 @@
|
|
|
1
|
+
import { Agent, } from "@mariozechner/pi-agent-core";
|
|
2
|
+
import { getAssistantText, toAgentMessages, toConversationEvents } from "./message-mapping.js";
|
|
3
|
+
export function defaultCreateAgent(options) {
|
|
4
|
+
return new Agent(options);
|
|
5
|
+
}
|
|
6
|
+
export async function executeAgent(options) {
|
|
7
|
+
const createAgent = options.createAgent ?? defaultCreateAgent;
|
|
8
|
+
const initialMessages = toAgentMessages(options.conversationMessages, options.model);
|
|
9
|
+
const agent = createAgent({
|
|
10
|
+
initialState: {
|
|
11
|
+
systemPrompt: options.systemPrompt,
|
|
12
|
+
model: options.model,
|
|
13
|
+
thinkingLevel: "off",
|
|
14
|
+
tools: options.tools,
|
|
15
|
+
messages: initialMessages,
|
|
16
|
+
},
|
|
17
|
+
...(options.getApiKey
|
|
18
|
+
? {
|
|
19
|
+
getApiKey: (provider) => options.getApiKey?.(provider, options.agent),
|
|
20
|
+
}
|
|
21
|
+
: {}),
|
|
22
|
+
...(options.onPayload ? { onPayload: options.onPayload } : {}),
|
|
23
|
+
});
|
|
24
|
+
const eventMessages = collectConversationEventMessages(agent);
|
|
25
|
+
try {
|
|
26
|
+
await agent.prompt(options.userText);
|
|
27
|
+
}
|
|
28
|
+
finally {
|
|
29
|
+
eventMessages.unsubscribe?.();
|
|
30
|
+
}
|
|
31
|
+
const appendedMessages = eventMessages.messages.length > 0
|
|
32
|
+
? eventMessages.messages
|
|
33
|
+
: agent.state.messages.slice(initialMessages.length);
|
|
34
|
+
const assistantMessage = [...agent.state.messages]
|
|
35
|
+
.reverse()
|
|
36
|
+
.find((message) => message.role === "assistant");
|
|
37
|
+
if (!assistantMessage) {
|
|
38
|
+
throw new Error(`Agent "${options.agent.id}" did not produce an assistant message.`);
|
|
39
|
+
}
|
|
40
|
+
if (assistantMessage.stopReason === "error" || assistantMessage.stopReason === "aborted") {
|
|
41
|
+
throw new Error(`Agent "${options.agent.id}" failed: ` +
|
|
42
|
+
`${assistantMessage.errorMessage ?? "unknown upstream error"}`);
|
|
43
|
+
}
|
|
44
|
+
const responseText = getAssistantText(assistantMessage);
|
|
45
|
+
if (!responseText.trim()) {
|
|
46
|
+
throw new Error(`Agent "${options.agent.id}" produced an assistant message without text content.`);
|
|
47
|
+
}
|
|
48
|
+
return {
|
|
49
|
+
message: {
|
|
50
|
+
conversation: options.conversation,
|
|
51
|
+
text: responseText,
|
|
52
|
+
},
|
|
53
|
+
conversationEvents: toConversationEvents(appendedMessages, {
|
|
54
|
+
parentMessageId: options.parentMessageId,
|
|
55
|
+
correlationId: options.correlationId,
|
|
56
|
+
}),
|
|
57
|
+
...(options.workingDirectoryState.get() !== options.initialWorkingDirectory
|
|
58
|
+
? { workingDirectory: options.workingDirectoryState.get() }
|
|
59
|
+
: {}),
|
|
60
|
+
};
|
|
61
|
+
}
|
|
62
|
+
function collectConversationEventMessages(agent) {
|
|
63
|
+
const messages = [];
|
|
64
|
+
const seen = new Set();
|
|
65
|
+
const recordMessage = (message) => {
|
|
66
|
+
if (message.role !== "assistant" && message.role !== "toolResult") {
|
|
67
|
+
return;
|
|
68
|
+
}
|
|
69
|
+
const key = getAgentMessageKey(message);
|
|
70
|
+
if (seen.has(key)) {
|
|
71
|
+
return;
|
|
72
|
+
}
|
|
73
|
+
seen.add(key);
|
|
74
|
+
messages.push(message);
|
|
75
|
+
};
|
|
76
|
+
const unsubscribe = agent.subscribe?.((event) => {
|
|
77
|
+
if (isConversationMessageEvent(event)) {
|
|
78
|
+
recordMessage(event.message);
|
|
79
|
+
}
|
|
80
|
+
});
|
|
81
|
+
return { messages, unsubscribe };
|
|
82
|
+
}
|
|
83
|
+
function isConversationMessageEvent(event) {
|
|
84
|
+
return event.type === "message_end";
|
|
85
|
+
}
|
|
86
|
+
function getAgentMessageKey(message) {
|
|
87
|
+
if (message.role === "toolResult") {
|
|
88
|
+
return JSON.stringify([
|
|
89
|
+
message.role,
|
|
90
|
+
message.timestamp,
|
|
91
|
+
message.toolCallId,
|
|
92
|
+
message.toolName,
|
|
93
|
+
message.isError,
|
|
94
|
+
message.content,
|
|
95
|
+
message.details ?? null,
|
|
96
|
+
]);
|
|
97
|
+
}
|
|
98
|
+
return JSON.stringify([
|
|
99
|
+
message.role,
|
|
100
|
+
message.timestamp,
|
|
101
|
+
message.responseId ?? null,
|
|
102
|
+
message.provider,
|
|
103
|
+
message.model,
|
|
104
|
+
message.stopReason,
|
|
105
|
+
message.errorMessage ?? null,
|
|
106
|
+
message.content,
|
|
107
|
+
]);
|
|
108
|
+
}
|
|
109
|
+
//# sourceMappingURL=agent-execution.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"agent-execution.js","sourceRoot":"","sources":["../../src/runtime/agent-execution.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import type { AgentDefinition } from "../domain/agent.js";
|
|
2
|
+
import type { ConversationContext, ConversationEvent } from "../domain/conversation.js";
|
|
3
|
+
import type { IncomingMessage, OutgoingMessage } from "../domain/message.js";
|
|
4
|
+
import type { SkillDefinition } from "../skills/types.js";
|
|
5
|
+
export interface AgentRunRuntimeContext {
|
|
6
|
+
configPath?: string;
|
|
7
|
+
dataRoot?: string;
|
|
8
|
+
availableSkills?: SkillDefinition[];
|
|
9
|
+
}
|
|
10
|
+
export interface AgentRunInput {
|
|
11
|
+
agent: AgentDefinition;
|
|
12
|
+
conversation: ConversationContext;
|
|
13
|
+
message: IncomingMessage;
|
|
14
|
+
runtime?: AgentRunRuntimeContext;
|
|
15
|
+
}
|
|
16
|
+
export interface AgentRunResult {
|
|
17
|
+
message: OutgoingMessage;
|
|
18
|
+
conversationEvents: ConversationEvent[];
|
|
19
|
+
workingDirectory?: string;
|
|
20
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"context.js","sourceRoot":"","sources":["../../src/runtime/context.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import { getOAuthApiKey } from "@mariozechner/pi-ai/oauth";
|
|
2
|
+
import type { Logger } from "../logging/types.js";
|
|
3
|
+
interface OAuthApiKeyResolverDependencies {
|
|
4
|
+
readTextFile?: (path: string) => Promise<string>;
|
|
5
|
+
writeTextFile?: (path: string, content: string) => Promise<void>;
|
|
6
|
+
getOAuthApiKeyFn?: typeof getOAuthApiKey;
|
|
7
|
+
}
|
|
8
|
+
export declare function createOAuthApiKeyResolver(authFilePath: string | undefined, logger?: Logger, dependencies?: OAuthApiKeyResolverDependencies): (provider: string) => Promise<string | undefined>;
|
|
9
|
+
export {};
|