@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,30 @@
|
|
|
1
|
+
import { discoverConfigPath } from "../config/discover-config-path.js";
|
|
2
|
+
import { loadAppConfig } from "../config/load-app-config.js";
|
|
3
|
+
import { getValueAtKeyPath } from "./config-key-path.js";
|
|
4
|
+
export function createGetConfigValueUseCase() {
|
|
5
|
+
return async ({ configPath, keyPath }) => {
|
|
6
|
+
const { configPath: resolvedConfigPath } = await discoverConfigPath({
|
|
7
|
+
cliConfigPath: configPath,
|
|
8
|
+
});
|
|
9
|
+
const config = await loadAppConfig(resolvedConfigPath);
|
|
10
|
+
const value = getValueAtKeyPath(config, keyPath);
|
|
11
|
+
if (value === undefined) {
|
|
12
|
+
throw new Error(`Config key not found: ${keyPath}`);
|
|
13
|
+
}
|
|
14
|
+
console.log(formatConfigValue(value));
|
|
15
|
+
};
|
|
16
|
+
}
|
|
17
|
+
function formatConfigValue(value) {
|
|
18
|
+
if (value === null) {
|
|
19
|
+
return "null";
|
|
20
|
+
}
|
|
21
|
+
switch (typeof value) {
|
|
22
|
+
case "string":
|
|
23
|
+
case "number":
|
|
24
|
+
case "boolean":
|
|
25
|
+
return String(value);
|
|
26
|
+
default:
|
|
27
|
+
return JSON.stringify(value, null, 2);
|
|
28
|
+
}
|
|
29
|
+
}
|
|
30
|
+
//# sourceMappingURL=get-config-value-use-case.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"get-config-value-use-case.js","sourceRoot":"","sources":["../../src/application/get-config-value-use-case.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,kBAAkB,EAAE,MAAM,mCAAmC,CAAC;AACvE,OAAO,EAAE,aAAa,EAAE,MAAM,8BAA8B,CAAC;AAC7D,OAAO,EAAE,iBAAiB,EAAE,MAAM,sBAAsB,CAAC;AAEzD,MAAM,UAAU,2BAA2B;IAIzC,OAAO,KAAK,EAAE,EAAE,UAAU,EAAE,OAAO,EAAE,EAAE,EAAE;QACvC,MAAM,EAAE,UAAU,EAAE,kBAAkB,EAAE,GAAG,MAAM,kBAAkB,CAAC;YAClE,aAAa,EAAE,UAAU;SAC1B,CAAC,CAAC;QACH,MAAM,MAAM,GAAG,MAAM,aAAa,CAAC,kBAAkB,CAAC,CAAC;QACvD,MAAM,KAAK,GAAG,iBAAiB,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;QAEjD,IAAI,KAAK,KAAK,SAAS,EAAE,CAAC;YACxB,MAAM,IAAI,KAAK,CAAC,yBAAyB,OAAO,EAAE,CAAC,CAAC;QACtD,CAAC;QAED,OAAO,CAAC,GAAG,CAAC,iBAAiB,CAAC,KAAK,CAAC,CAAC,CAAC;IACxC,CAAC,CAAC;AACJ,CAAC;AAED,SAAS,iBAAiB,CAAC,KAAc;IACvC,IAAI,KAAK,KAAK,IAAI,EAAE,CAAC;QACnB,OAAO,MAAM,CAAC;IAChB,CAAC;IAED,QAAQ,OAAO,KAAK,EAAE,CAAC;QACrB,KAAK,QAAQ,CAAC;QACd,KAAK,QAAQ,CAAC;QACd,KAAK,SAAS;YACZ,OAAO,MAAM,CAAC,KAAK,CAAC,CAAC;QACvB;YACE,OAAO,IAAI,CAAC,SAAS,CAAC,KAAK,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC;IAC1C,CAAC;AACH,CAAC"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import type { IncomingMessage, OutgoingMessage } from "../domain/message.js";
|
|
2
|
+
import type { HandleIncomingMessageDependencies } from "./commands/types.js";
|
|
3
|
+
export type { HandleIncomingMessageDependencies, RuntimeCommandInfo } from "./commands/types.js";
|
|
4
|
+
export interface HandleIncomingMessage {
|
|
5
|
+
handle(message: IncomingMessage): Promise<OutgoingMessage>;
|
|
6
|
+
}
|
|
7
|
+
export declare function createHandleIncomingMessage(dependencies: HandleIncomingMessageDependencies): HandleIncomingMessage;
|
|
@@ -0,0 +1,56 @@
|
|
|
1
|
+
import { loadAppConfig } from "../config/load-app-config.js";
|
|
2
|
+
import { readRecentLogLines } from "../logging/view-logs.js";
|
|
3
|
+
import { createHookRunner } from "../plugins/hook-runner.js";
|
|
4
|
+
import { inboundCommandHandlers } from "./commands/registry.js";
|
|
5
|
+
import { dispatchCommand } from "./inbound/dispatch-command.js";
|
|
6
|
+
import { executeAgent } from "./inbound/execute-agent.js";
|
|
7
|
+
import { persistConversation } from "./inbound/persist-conversation.js";
|
|
8
|
+
import { resolveConversation } from "./inbound/resolve-conversation.js";
|
|
9
|
+
import { resolveSkills } from "./inbound/resolve-skills.js";
|
|
10
|
+
import { runHooksStart } from "./inbound/run-hooks-start.js";
|
|
11
|
+
import { runHooksError, runHooksSuccess } from "./inbound/run-hooks-success-error.js";
|
|
12
|
+
export function createHandleIncomingMessage(dependencies) {
|
|
13
|
+
const defaultAgent = dependencies.agentRegistry.get(dependencies.defaultAgentId);
|
|
14
|
+
const availableCommands = dependencies.availableCommands ?? inboundCommandHandlers;
|
|
15
|
+
const loadAppConfigImpl = dependencies.loadAppConfig ?? loadAppConfig;
|
|
16
|
+
const readRecentLogLinesImpl = dependencies.readRecentLogLines ?? readRecentLogLines;
|
|
17
|
+
const hookRunner = createHookRunner(dependencies.inboundMessageHooks, {
|
|
18
|
+
logger: dependencies.logger,
|
|
19
|
+
});
|
|
20
|
+
if (!defaultAgent) {
|
|
21
|
+
throw new Error(`Unknown default agent: ${dependencies.defaultAgentId}`);
|
|
22
|
+
}
|
|
23
|
+
return {
|
|
24
|
+
async handle(message) {
|
|
25
|
+
const context = {
|
|
26
|
+
message,
|
|
27
|
+
dependencies,
|
|
28
|
+
defaultAgent,
|
|
29
|
+
availableCommands,
|
|
30
|
+
loadAppConfig: loadAppConfigImpl,
|
|
31
|
+
readRecentLogLines: readRecentLogLinesImpl,
|
|
32
|
+
hookRunner,
|
|
33
|
+
startedAt: Date.now(),
|
|
34
|
+
availableSkills: [],
|
|
35
|
+
};
|
|
36
|
+
try {
|
|
37
|
+
await runHooksStart(context);
|
|
38
|
+
await dispatchCommand(context);
|
|
39
|
+
await resolveConversation(context);
|
|
40
|
+
await resolveSkills(context);
|
|
41
|
+
await executeAgent(context);
|
|
42
|
+
await persistConversation(context);
|
|
43
|
+
await runHooksSuccess(context);
|
|
44
|
+
if (!context.response) {
|
|
45
|
+
throw new Error("Inbound processing completed without a response");
|
|
46
|
+
}
|
|
47
|
+
return context.response;
|
|
48
|
+
}
|
|
49
|
+
catch (error) {
|
|
50
|
+
await runHooksError(context, error);
|
|
51
|
+
throw error;
|
|
52
|
+
}
|
|
53
|
+
},
|
|
54
|
+
};
|
|
55
|
+
}
|
|
56
|
+
//# sourceMappingURL=handle-incoming-message.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"handle-incoming-message.js","sourceRoot":"","sources":["../../src/application/handle-incoming-message.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,MAAM,8BAA8B,CAAC;AAE7D,OAAO,EAAE,kBAAkB,EAAE,MAAM,yBAAyB,CAAC;AAC7D,OAAO,EAAE,gBAAgB,EAAE,MAAM,2BAA2B,CAAC;AAC7D,OAAO,EAAE,sBAAsB,EAAE,MAAM,wBAAwB,CAAC;AAEhE,OAAO,EAAE,eAAe,EAAE,MAAM,+BAA+B,CAAC;AAChE,OAAO,EAAE,YAAY,EAAE,MAAM,4BAA4B,CAAC;AAC1D,OAAO,EAAE,mBAAmB,EAAE,MAAM,mCAAmC,CAAC;AACxE,OAAO,EAAE,mBAAmB,EAAE,MAAM,mCAAmC,CAAC;AACxE,OAAO,EAAE,aAAa,EAAE,MAAM,6BAA6B,CAAC;AAC5D,OAAO,EAAE,aAAa,EAAE,MAAM,8BAA8B,CAAC;AAC7D,OAAO,EAAE,aAAa,EAAE,eAAe,EAAE,MAAM,sCAAsC,CAAC;AAStF,MAAM,UAAU,2BAA2B,CACzC,YAA+C;IAE/C,MAAM,YAAY,GAAG,YAAY,CAAC,aAAa,CAAC,GAAG,CAAC,YAAY,CAAC,cAAc,CAAC,CAAC;IACjF,MAAM,iBAAiB,GAAG,YAAY,CAAC,iBAAiB,IAAI,sBAAsB,CAAC;IACnF,MAAM,iBAAiB,GAAG,YAAY,CAAC,aAAa,IAAI,aAAa,CAAC;IACtE,MAAM,sBAAsB,GAAG,YAAY,CAAC,kBAAkB,IAAI,kBAAkB,CAAC;IACrF,MAAM,UAAU,GAAG,gBAAgB,CAAC,YAAY,CAAC,mBAAmB,EAAE;QACpE,MAAM,EAAE,YAAY,CAAC,MAAM;KAC5B,CAAC,CAAC;IAEH,IAAI,CAAC,YAAY,EAAE,CAAC;QAClB,MAAM,IAAI,KAAK,CAAC,0BAA0B,YAAY,CAAC,cAAc,EAAE,CAAC,CAAC;IAC3E,CAAC;IAED,OAAO;QACL,KAAK,CAAC,MAAM,CAAC,OAAwB;YACnC,MAAM,OAAO,GAA6B;gBACxC,OAAO;gBACP,YAAY;gBACZ,YAAY;gBACZ,iBAAiB;gBACjB,aAAa,EAAE,iBAAiB;gBAChC,kBAAkB,EAAE,sBAAsB;gBAC1C,UAAU;gBACV,SAAS,EAAE,IAAI,CAAC,GAAG,EAAE;gBACrB,eAAe,EAAE,EAAE;aACpB,CAAC;YAEF,IAAI,CAAC;gBACH,MAAM,aAAa,CAAC,OAAO,CAAC,CAAC;gBAC7B,MAAM,eAAe,CAAC,OAAO,CAAC,CAAC;gBAC/B,MAAM,mBAAmB,CAAC,OAAO,CAAC,CAAC;gBACnC,MAAM,aAAa,CAAC,OAAO,CAAC,CAAC;gBAC7B,MAAM,YAAY,CAAC,OAAO,CAAC,CAAC;gBAC5B,MAAM,mBAAmB,CAAC,OAAO,CAAC,CAAC;gBACnC,MAAM,eAAe,CAAC,OAAO,CAAC,CAAC;gBAE/B,IAAI,CAAC,OAAO,CAAC,QAAQ,EAAE,CAAC;oBACtB,MAAM,IAAI,KAAK,CAAC,iDAAiD,CAAC,CAAC;gBACrE,CAAC;gBAED,OAAO,OAAO,CAAC,QAAQ,CAAC;YAC1B,CAAC;YAAC,OAAO,KAAK,EAAE,CAAC;gBACf,MAAM,aAAa,CAAC,OAAO,EAAE,KAAK,CAAC,CAAC;gBACpC,MAAM,KAAK,CAAC;YACd,CAAC;QACH,CAAC;KACF,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
export async function dispatchCommand(context) {
|
|
2
|
+
if (!context.message.command) {
|
|
3
|
+
return;
|
|
4
|
+
}
|
|
5
|
+
const handler = context.availableCommands.find((candidate) => candidate.canHandle(context.message.command));
|
|
6
|
+
if (!handler) {
|
|
7
|
+
return;
|
|
8
|
+
}
|
|
9
|
+
const commandResponse = await handler.handle({
|
|
10
|
+
message: context.message,
|
|
11
|
+
dependencies: {
|
|
12
|
+
...context.dependencies,
|
|
13
|
+
availableCommands: context.availableCommands,
|
|
14
|
+
},
|
|
15
|
+
logger: context.dependencies.logger,
|
|
16
|
+
loadAppConfig: context.loadAppConfig,
|
|
17
|
+
readRecentLogLines: context.readRecentLogLines,
|
|
18
|
+
});
|
|
19
|
+
if (commandResponse) {
|
|
20
|
+
context.response = commandResponse;
|
|
21
|
+
}
|
|
22
|
+
}
|
|
23
|
+
//# sourceMappingURL=dispatch-command.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"dispatch-command.js","sourceRoot":"","sources":["../../../src/application/inbound/dispatch-command.ts"],"names":[],"mappings":"AAEA,MAAM,CAAC,KAAK,UAAU,eAAe,CAAC,OAAiC;IACrE,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,OAAO,EAAE,CAAC;QAC7B,OAAO;IACT,CAAC;IAED,MAAM,OAAO,GAAG,OAAO,CAAC,iBAAiB,CAAC,IAAI,CAAC,CAAC,SAAS,EAAE,EAAE,CAC3D,SAAS,CAAC,SAAS,CAAC,OAAO,CAAC,OAAO,CAAC,OAAO,CAAC,CAC7C,CAAC;IAEF,IAAI,CAAC,OAAO,EAAE,CAAC;QACb,OAAO;IACT,CAAC;IAED,MAAM,eAAe,GAAG,MAAM,OAAO,CAAC,MAAM,CAAC;QAC3C,OAAO,EAAE,OAAO,CAAC,OAAO;QACxB,YAAY,EAAE;YACZ,GAAG,OAAO,CAAC,YAAY;YACvB,iBAAiB,EAAE,OAAO,CAAC,iBAAiB;SAC7C;QACD,MAAM,EAAE,OAAO,CAAC,YAAY,CAAC,MAAM;QACnC,aAAa,EAAE,OAAO,CAAC,aAAa;QACpC,kBAAkB,EAAE,OAAO,CAAC,kBAAkB;KAC/C,CAAC,CAAC;IAEH,IAAI,eAAe,EAAE,CAAC;QACpB,OAAO,CAAC,QAAQ,GAAG,eAAe,CAAC;IACrC,CAAC;AACH,CAAC"}
|
|
@@ -0,0 +1,41 @@
|
|
|
1
|
+
export async function executeAgent(context) {
|
|
2
|
+
if (context.response || !context.agent || !context.conversation) {
|
|
3
|
+
return;
|
|
4
|
+
}
|
|
5
|
+
const result = await context.dependencies.engine.run({
|
|
6
|
+
agent: context.agent,
|
|
7
|
+
conversation: context.conversation,
|
|
8
|
+
message: context.message,
|
|
9
|
+
runtime: {
|
|
10
|
+
configPath: context.dependencies.runtimeInfo.configPath,
|
|
11
|
+
dataRoot: context.dependencies.runtimeInfo.dataRoot,
|
|
12
|
+
...(context.availableSkills.length > 0 ? { availableSkills: context.availableSkills } : {}),
|
|
13
|
+
},
|
|
14
|
+
});
|
|
15
|
+
context.response = result.message;
|
|
16
|
+
context.conversation = {
|
|
17
|
+
state: {
|
|
18
|
+
...context.conversation.state,
|
|
19
|
+
...(result.workingDirectory ? { workingDirectory: result.workingDirectory } : {}),
|
|
20
|
+
updatedAt: new Date().toISOString(),
|
|
21
|
+
},
|
|
22
|
+
messages: [
|
|
23
|
+
...context.conversation.messages,
|
|
24
|
+
toUserConversationMessage(context.message),
|
|
25
|
+
...result.conversationEvents,
|
|
26
|
+
],
|
|
27
|
+
};
|
|
28
|
+
}
|
|
29
|
+
function toUserConversationMessage(message) {
|
|
30
|
+
return {
|
|
31
|
+
kind: "message",
|
|
32
|
+
id: message.messageId,
|
|
33
|
+
role: "user",
|
|
34
|
+
content: message.text,
|
|
35
|
+
timestamp: Date.parse(message.receivedAt),
|
|
36
|
+
createdAt: message.receivedAt,
|
|
37
|
+
correlationId: message.correlationId,
|
|
38
|
+
...(message.source ? { source: message.source } : {}),
|
|
39
|
+
};
|
|
40
|
+
}
|
|
41
|
+
//# sourceMappingURL=execute-agent.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"execute-agent.js","sourceRoot":"","sources":["../../../src/application/inbound/execute-agent.ts"],"names":[],"mappings":"AAEA,MAAM,CAAC,KAAK,UAAU,YAAY,CAAC,OAAiC;IAClE,IAAI,OAAO,CAAC,QAAQ,IAAI,CAAC,OAAO,CAAC,KAAK,IAAI,CAAC,OAAO,CAAC,YAAY,EAAE,CAAC;QAChE,OAAO;IACT,CAAC;IAED,MAAM,MAAM,GAAG,MAAM,OAAO,CAAC,YAAY,CAAC,MAAM,CAAC,GAAG,CAAC;QACnD,KAAK,EAAE,OAAO,CAAC,KAAK;QACpB,YAAY,EAAE,OAAO,CAAC,YAAY;QAClC,OAAO,EAAE,OAAO,CAAC,OAAO;QACxB,OAAO,EAAE;YACP,UAAU,EAAE,OAAO,CAAC,YAAY,CAAC,WAAW,CAAC,UAAU;YACvD,QAAQ,EAAE,OAAO,CAAC,YAAY,CAAC,WAAW,CAAC,QAAQ;YACnD,GAAG,CAAC,OAAO,CAAC,eAAe,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,EAAE,eAAe,EAAE,OAAO,CAAC,eAAe,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;SAC5F;KACF,CAAC,CAAC;IAEH,OAAO,CAAC,QAAQ,GAAG,MAAM,CAAC,OAAO,CAAC;IAClC,OAAO,CAAC,YAAY,GAAG;QACrB,KAAK,EAAE;YACL,GAAG,OAAO,CAAC,YAAY,CAAC,KAAK;YAC7B,GAAG,CAAC,MAAM,CAAC,gBAAgB,CAAC,CAAC,CAAC,EAAE,gBAAgB,EAAE,MAAM,CAAC,gBAAgB,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;YACjF,SAAS,EAAE,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE;SACpC;QACD,QAAQ,EAAE;YACR,GAAG,OAAO,CAAC,YAAY,CAAC,QAAQ;YAChC,yBAAyB,CAAC,OAAO,CAAC,OAAO,CAAC;YAC1C,GAAG,MAAM,CAAC,kBAAkB;SAC7B;KACF,CAAC;AACJ,CAAC;AAED,SAAS,yBAAyB,CAAC,OAA4C;IAC7E,OAAO;QACL,IAAI,EAAE,SAAkB;QACxB,EAAE,EAAE,OAAO,CAAC,SAAS;QACrB,IAAI,EAAE,MAAe;QACrB,OAAO,EAAE,OAAO,CAAC,IAAI;QACrB,SAAS,EAAE,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,UAAU,CAAC;QACzC,SAAS,EAAE,OAAO,CAAC,UAAU;QAC7B,aAAa,EAAE,OAAO,CAAC,aAAa;QACpC,GAAG,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,MAAM,EAAE,OAAO,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;KACtD,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"persist-conversation.js","sourceRoot":"","sources":["../../../src/application/inbound/persist-conversation.ts"],"names":[],"mappings":"AAEA,MAAM,CAAC,KAAK,UAAU,mBAAmB,CAAC,OAAiC;IACzE,IAAI,CAAC,OAAO,CAAC,YAAY,IAAI,CAAC,OAAO,CAAC,KAAK,IAAI,CAAC,OAAO,CAAC,QAAQ,EAAE,CAAC;QACjE,OAAO;IACT,CAAC;IAED,MAAM,OAAO,CAAC,YAAY,CAAC,iBAAiB,CAAC,GAAG,CAAC,OAAO,CAAC,YAAY,CAAC,CAAC;AACzE,CAAC"}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import { getOrCreateConversationContext } from "../commands/conversation-context.js";
|
|
2
|
+
export async function resolveConversation(context) {
|
|
3
|
+
if (context.response) {
|
|
4
|
+
return;
|
|
5
|
+
}
|
|
6
|
+
const conversation = await getOrCreateConversationContext(context.message, context.defaultAgent.id, context.dependencies.conversationStore, context.dependencies.logger);
|
|
7
|
+
const agent = context.dependencies.agentRegistry.get(conversation.state.agentId) ?? context.defaultAgent;
|
|
8
|
+
await context.dependencies.logger?.debug("resolved conversation context", {
|
|
9
|
+
endpointId: context.message.endpointId,
|
|
10
|
+
transport: context.message.conversation.transport,
|
|
11
|
+
conversationId: context.message.conversation.externalId,
|
|
12
|
+
messageId: context.message.messageId,
|
|
13
|
+
correlationId: context.message.correlationId,
|
|
14
|
+
agentId: agent.id,
|
|
15
|
+
});
|
|
16
|
+
context.conversation = conversation;
|
|
17
|
+
context.agent = agent;
|
|
18
|
+
}
|
|
19
|
+
//# sourceMappingURL=resolve-conversation.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"resolve-conversation.js","sourceRoot":"","sources":["../../../src/application/inbound/resolve-conversation.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,8BAA8B,EAAE,MAAM,qCAAqC,CAAC;AAGrF,MAAM,CAAC,KAAK,UAAU,mBAAmB,CAAC,OAAiC;IACzE,IAAI,OAAO,CAAC,QAAQ,EAAE,CAAC;QACrB,OAAO;IACT,CAAC;IAED,MAAM,YAAY,GAAG,MAAM,8BAA8B,CACvD,OAAO,CAAC,OAAO,EACf,OAAO,CAAC,YAAY,CAAC,EAAE,EACvB,OAAO,CAAC,YAAY,CAAC,iBAAiB,EACtC,OAAO,CAAC,YAAY,CAAC,MAAM,CAC5B,CAAC;IAEF,MAAM,KAAK,GAAG,OAAO,CAAC,YAAY,CAAC,aAAa,CAAC,GAAG,CAAC,YAAY,CAAC,KAAK,CAAC,OAAO,CAAC,IAAI,OAAO,CAAC,YAAY,CAAC;IAEzG,MAAM,OAAO,CAAC,YAAY,CAAC,MAAM,EAAE,KAAK,CAAC,+BAA+B,EAAE;QACxE,UAAU,EAAE,OAAO,CAAC,OAAO,CAAC,UAAU;QACtC,SAAS,EAAE,OAAO,CAAC,OAAO,CAAC,YAAY,CAAC,SAAS;QACjD,cAAc,EAAE,OAAO,CAAC,OAAO,CAAC,YAAY,CAAC,UAAU;QACvD,SAAS,EAAE,OAAO,CAAC,OAAO,CAAC,SAAS;QACpC,aAAa,EAAE,OAAO,CAAC,OAAO,CAAC,aAAa;QAC5C,OAAO,EAAE,KAAK,CAAC,EAAE;KAClB,CAAC,CAAC;IAEH,OAAO,CAAC,YAAY,GAAG,YAAY,CAAC;IACpC,OAAO,CAAC,KAAK,GAAG,KAAK,CAAC;AACxB,CAAC"}
|
|
@@ -0,0 +1,73 @@
|
|
|
1
|
+
import { join } from "node:path";
|
|
2
|
+
import { discoverSkills, mergeSkillCatalogs } from "../../skills/discovery.js";
|
|
3
|
+
export async function resolveSkills(context) {
|
|
4
|
+
if (context.response || !context.agent) {
|
|
5
|
+
return;
|
|
6
|
+
}
|
|
7
|
+
const configuredSkillCatalog = context.agent.skillCatalog ?? [];
|
|
8
|
+
const workspaceDirectory = resolveWorkspaceDirectory(context);
|
|
9
|
+
const workspaceSkillsPath = workspaceDirectory ? join(workspaceDirectory, ".skills") : undefined;
|
|
10
|
+
try {
|
|
11
|
+
const workspaceSkillCatalog = workspaceSkillsPath
|
|
12
|
+
? await discoverSkills([workspaceSkillsPath], { ignoreMissingPaths: true })
|
|
13
|
+
: { skills: [], issues: [] };
|
|
14
|
+
const mergedSkillCatalog = mergeSkillCatalogs(configuredSkillCatalog, workspaceSkillCatalog.skills);
|
|
15
|
+
const skillCatalog = mergedSkillCatalog.skills;
|
|
16
|
+
context.availableSkills = skillCatalog;
|
|
17
|
+
for (const issue of workspaceSkillCatalog.issues) {
|
|
18
|
+
await context.dependencies.logger?.info(issue, {
|
|
19
|
+
endpointId: context.message.endpointId,
|
|
20
|
+
transport: context.message.conversation.transport,
|
|
21
|
+
conversationId: context.message.conversation.externalId,
|
|
22
|
+
messageId: context.message.messageId,
|
|
23
|
+
correlationId: context.message.correlationId,
|
|
24
|
+
agentId: context.agent.id,
|
|
25
|
+
workspaceDirectory,
|
|
26
|
+
workspaceSkillsPath,
|
|
27
|
+
});
|
|
28
|
+
}
|
|
29
|
+
if (mergedSkillCatalog.overriddenSkillNames.length > 0) {
|
|
30
|
+
await context.dependencies.logger?.info("workspace skills override configured agent skills for turn", {
|
|
31
|
+
endpointId: context.message.endpointId,
|
|
32
|
+
transport: context.message.conversation.transport,
|
|
33
|
+
conversationId: context.message.conversation.externalId,
|
|
34
|
+
messageId: context.message.messageId,
|
|
35
|
+
correlationId: context.message.correlationId,
|
|
36
|
+
agentId: context.agent.id,
|
|
37
|
+
workspaceDirectory,
|
|
38
|
+
workspaceSkillsPath,
|
|
39
|
+
overriddenSkillNames: mergedSkillCatalog.overriddenSkillNames,
|
|
40
|
+
});
|
|
41
|
+
}
|
|
42
|
+
await context.dependencies.logger?.debug("resolved available agent skills for turn", {
|
|
43
|
+
endpointId: context.message.endpointId,
|
|
44
|
+
transport: context.message.conversation.transport,
|
|
45
|
+
conversationId: context.message.conversation.externalId,
|
|
46
|
+
messageId: context.message.messageId,
|
|
47
|
+
correlationId: context.message.correlationId,
|
|
48
|
+
agentId: context.agent.id,
|
|
49
|
+
skillCount: skillCatalog.length,
|
|
50
|
+
skillNames: skillCatalog.map((skill) => skill.name),
|
|
51
|
+
...(workspaceDirectory ? { workspaceDirectory, workspaceSkillsPath } : {}),
|
|
52
|
+
...(mergedSkillCatalog.overriddenSkillNames.length > 0
|
|
53
|
+
? { overriddenSkillNames: mergedSkillCatalog.overriddenSkillNames }
|
|
54
|
+
: {}),
|
|
55
|
+
});
|
|
56
|
+
}
|
|
57
|
+
catch (error) {
|
|
58
|
+
context.availableSkills = [];
|
|
59
|
+
void context.dependencies.logger?.error("failed to resolve available agent skills for turn; continuing without skills", {
|
|
60
|
+
endpointId: context.message.endpointId,
|
|
61
|
+
transport: context.message.conversation.transport,
|
|
62
|
+
conversationId: context.message.conversation.externalId,
|
|
63
|
+
messageId: context.message.messageId,
|
|
64
|
+
correlationId: context.message.correlationId,
|
|
65
|
+
agentId: context.agent.id,
|
|
66
|
+
...(workspaceDirectory ? { workspaceDirectory, workspaceSkillsPath } : {}),
|
|
67
|
+
}, error);
|
|
68
|
+
}
|
|
69
|
+
}
|
|
70
|
+
function resolveWorkspaceDirectory(context) {
|
|
71
|
+
return context.conversation?.state.workingDirectory ?? context.agent?.workspace?.cwd;
|
|
72
|
+
}
|
|
73
|
+
//# sourceMappingURL=resolve-skills.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"resolve-skills.js","sourceRoot":"","sources":["../../../src/application/inbound/resolve-skills.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"run-hooks-start.js","sourceRoot":"","sources":["../../../src/application/inbound/run-hooks-start.ts"],"names":[],"mappings":"AAEA,MAAM,CAAC,KAAK,UAAU,aAAa,CAAC,OAAiC;IACnE,MAAM,OAAO,CAAC,UAAU,CAAC,GAAG,CAC1B,uBAAuB,EACvB,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,qBAAqB,EACtC,EAAE,OAAO,EAAE,OAAO,CAAC,OAAO,EAAE,CAC7B,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
export async function runHooksSuccess(context) {
|
|
2
|
+
if (!context.response) {
|
|
3
|
+
return;
|
|
4
|
+
}
|
|
5
|
+
await context.hookRunner.run("onInboundMessageSuccess", (hooks) => hooks.onInboundMessageSuccess, {
|
|
6
|
+
message: context.message,
|
|
7
|
+
response: context.response,
|
|
8
|
+
durationMs: Date.now() - context.startedAt,
|
|
9
|
+
});
|
|
10
|
+
}
|
|
11
|
+
export async function runHooksError(context, error) {
|
|
12
|
+
await context.hookRunner.runErrorHook("onInboundMessageError", (hooks) => hooks.onInboundMessageError, {
|
|
13
|
+
message: context.message,
|
|
14
|
+
error,
|
|
15
|
+
durationMs: Date.now() - context.startedAt,
|
|
16
|
+
});
|
|
17
|
+
}
|
|
18
|
+
//# sourceMappingURL=run-hooks-success-error.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"run-hooks-success-error.js","sourceRoot":"","sources":["../../../src/application/inbound/run-hooks-success-error.ts"],"names":[],"mappings":"AAEA,MAAM,CAAC,KAAK,UAAU,eAAe,CAAC,OAAiC;IACrE,IAAI,CAAC,OAAO,CAAC,QAAQ,EAAE,CAAC;QACtB,OAAO;IACT,CAAC;IAED,MAAM,OAAO,CAAC,UAAU,CAAC,GAAG,CAC1B,yBAAyB,EACzB,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,uBAAuB,EACxC;QACE,OAAO,EAAE,OAAO,CAAC,OAAO;QACxB,QAAQ,EAAE,OAAO,CAAC,QAAQ;QAC1B,UAAU,EAAE,IAAI,CAAC,GAAG,EAAE,GAAG,OAAO,CAAC,SAAS;KAC3C,CACF,CAAC;AACJ,CAAC;AAED,MAAM,CAAC,KAAK,UAAU,aAAa,CACjC,OAAiC,EACjC,KAAc;IAEd,MAAM,OAAO,CAAC,UAAU,CAAC,YAAY,CACnC,uBAAuB,EACvB,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,qBAAqB,EACtC;QACE,OAAO,EAAE,OAAO,CAAC,OAAO;QACxB,KAAK;QACL,UAAU,EAAE,IAAI,CAAC,GAAG,EAAE,GAAG,OAAO,CAAC,SAAS;KAC3C,CACF,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import type { AgentDefinition } from "../../domain/agent.js";
|
|
2
|
+
import type { ConversationContext } from "../../domain/conversation.js";
|
|
3
|
+
import type { IncomingMessage, OutgoingMessage } from "../../domain/message.js";
|
|
4
|
+
import type { HookRunner } from "../../plugins/hook-runner.js";
|
|
5
|
+
import type { InboundMessageLifecycleHooks } from "../../plugins/types.js";
|
|
6
|
+
import type { SkillDefinition } from "../../skills/types.js";
|
|
7
|
+
import type { HandleIncomingMessageDependencies, InboundCommandHandler } from "../commands/types.js";
|
|
8
|
+
export interface InboundProcessingContext {
|
|
9
|
+
message: IncomingMessage;
|
|
10
|
+
dependencies: HandleIncomingMessageDependencies;
|
|
11
|
+
defaultAgent: AgentDefinition;
|
|
12
|
+
availableCommands: ReadonlyArray<InboundCommandHandler>;
|
|
13
|
+
loadAppConfig: NonNullable<HandleIncomingMessageDependencies["loadAppConfig"]>;
|
|
14
|
+
readRecentLogLines: NonNullable<HandleIncomingMessageDependencies["readRecentLogLines"]>;
|
|
15
|
+
hookRunner: HookRunner<InboundMessageLifecycleHooks>;
|
|
16
|
+
startedAt: number;
|
|
17
|
+
response?: OutgoingMessage;
|
|
18
|
+
conversation?: ConversationContext;
|
|
19
|
+
agent?: AgentDefinition;
|
|
20
|
+
availableSkills: SkillDefinition[];
|
|
21
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.js","sourceRoot":"","sources":["../../../src/application/inbound/types.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,62 @@
|
|
|
1
|
+
import { createDefaultAppConfig } from "../config/default-app-config.js";
|
|
2
|
+
import { assertInitConfigCanBeCreated, initAppConfig } from "../config/init-app-config.js";
|
|
3
|
+
import { getProviderEnvironmentVariables, promptForInitialAppConfig } from "../config/prompt-init-config.js";
|
|
4
|
+
import { installService } from "../service/install-service.js";
|
|
5
|
+
export function createInitConfigUseCase() {
|
|
6
|
+
return async ({ configPath, force, defaults }) => {
|
|
7
|
+
const resolvedConfigPath = await assertInitConfigCanBeCreated({ configPath, force });
|
|
8
|
+
const initSetup = defaults
|
|
9
|
+
? {
|
|
10
|
+
config: undefined,
|
|
11
|
+
installService: process.platform !== "win32",
|
|
12
|
+
serviceEnvironment: resolveDefaultServiceEnvironment(),
|
|
13
|
+
}
|
|
14
|
+
: await resolveInitConfig();
|
|
15
|
+
const createdConfigPath = await initAppConfig({
|
|
16
|
+
configPath: resolvedConfigPath,
|
|
17
|
+
force,
|
|
18
|
+
config: initSetup.config,
|
|
19
|
+
});
|
|
20
|
+
console.log(`Created config at ${createdConfigPath}`);
|
|
21
|
+
if (initSetup.installService) {
|
|
22
|
+
const result = await installService({
|
|
23
|
+
configPath: createdConfigPath,
|
|
24
|
+
force,
|
|
25
|
+
serviceEnvironment: initSetup.serviceEnvironment,
|
|
26
|
+
});
|
|
27
|
+
console.log(`Installed ${result.operation.platform} service at ${result.operation.definitionPath}`);
|
|
28
|
+
}
|
|
29
|
+
};
|
|
30
|
+
}
|
|
31
|
+
function resolveDefaultServiceEnvironment() {
|
|
32
|
+
const defaultAgent = createDefaultAppConfig(process.env).agents[0];
|
|
33
|
+
const provider = defaultAgent?.model?.provider;
|
|
34
|
+
if (!provider) {
|
|
35
|
+
return undefined;
|
|
36
|
+
}
|
|
37
|
+
const entries = getProviderEnvironmentVariables(provider)
|
|
38
|
+
.map((name) => [name, process.env[name]?.trim()])
|
|
39
|
+
.filter((entry) => Boolean(entry[1] && entry[1].length > 0));
|
|
40
|
+
if (entries.length === 0) {
|
|
41
|
+
return undefined;
|
|
42
|
+
}
|
|
43
|
+
return Object.fromEntries(entries);
|
|
44
|
+
}
|
|
45
|
+
async function resolveInitConfig() {
|
|
46
|
+
if (!process.stdin.isTTY || !process.stdout.isTTY) {
|
|
47
|
+
throw new Error("`imp init` requires an interactive terminal. Re-run with --defaults to skip prompts.");
|
|
48
|
+
}
|
|
49
|
+
try {
|
|
50
|
+
return await promptForInitialAppConfig();
|
|
51
|
+
}
|
|
52
|
+
catch (error) {
|
|
53
|
+
if (isPromptExitError(error)) {
|
|
54
|
+
throw new Error("Config initialization cancelled.");
|
|
55
|
+
}
|
|
56
|
+
throw error;
|
|
57
|
+
}
|
|
58
|
+
}
|
|
59
|
+
function isPromptExitError(error) {
|
|
60
|
+
return error instanceof Error && error.name === "ExitPromptError";
|
|
61
|
+
}
|
|
62
|
+
//# sourceMappingURL=init-config-use-case.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"init-config-use-case.js","sourceRoot":"","sources":["../../src/application/init-config-use-case.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import type { IncomingMessage } from "../domain/message.js";
|
|
2
|
+
import type { OutgoingMessageDeliveryAction } from "../domain/message.js";
|
|
3
|
+
import type { Logger } from "../logging/types.js";
|
|
4
|
+
import type { TransportHandler, TransportInboundEvent } from "../transports/types.js";
|
|
5
|
+
export interface MessageProcessorDependencies {
|
|
6
|
+
handler: {
|
|
7
|
+
handle(message: IncomingMessage): Promise<import("../domain/message.js").OutgoingMessage>;
|
|
8
|
+
};
|
|
9
|
+
logger?: Logger;
|
|
10
|
+
maxParallel?: number;
|
|
11
|
+
shouldRetry?: (error: unknown, attempt: number, event: TransportInboundEvent) => boolean | Promise<boolean>;
|
|
12
|
+
retryDelayMs?: (attempt: number, event: TransportInboundEvent) => number | Promise<number>;
|
|
13
|
+
onError?: (error: unknown, attempt: number, event: TransportInboundEvent) => Promise<void> | void;
|
|
14
|
+
onRetry?: (error: unknown, attempt: number, event: TransportInboundEvent) => Promise<void> | void;
|
|
15
|
+
prepareEvent?: (event: TransportInboundEvent) => Promise<TransportInboundEvent> | TransportInboundEvent;
|
|
16
|
+
afterDeliveryAction?: (action: OutgoingMessageDeliveryAction, event: TransportInboundEvent) => Promise<void> | void;
|
|
17
|
+
}
|
|
18
|
+
export type MessageProcessor = TransportHandler;
|
|
19
|
+
export declare function createMessageProcessor(dependencies: MessageProcessorDependencies): MessageProcessor;
|
|
@@ -0,0 +1,122 @@
|
|
|
1
|
+
import { priorityInboundCommands } from "./commands/priority-inbound-commands.js";
|
|
2
|
+
export function createMessageProcessor(dependencies) {
|
|
3
|
+
const semaphore = createSemaphore(Math.max(1, dependencies.maxParallel ?? 4));
|
|
4
|
+
const conversationQueues = new Map();
|
|
5
|
+
return {
|
|
6
|
+
async handle(event) {
|
|
7
|
+
const preparedEvent = await dependencies.prepareEvent?.(event) ?? event;
|
|
8
|
+
if (shouldBypassConversationQueue(preparedEvent.message)) {
|
|
9
|
+
await semaphore.withPermit(async () => {
|
|
10
|
+
await processEvent(preparedEvent, dependencies);
|
|
11
|
+
});
|
|
12
|
+
return;
|
|
13
|
+
}
|
|
14
|
+
await enqueueByConversation(preparedEvent, async () => {
|
|
15
|
+
await semaphore.withPermit(async () => {
|
|
16
|
+
await processEvent(preparedEvent, dependencies);
|
|
17
|
+
});
|
|
18
|
+
});
|
|
19
|
+
},
|
|
20
|
+
};
|
|
21
|
+
async function enqueueByConversation(event, operation) {
|
|
22
|
+
const key = "sessionId" in event.message.conversation && event.message.conversation.sessionId
|
|
23
|
+
? `${event.message.conversation.transport}/${event.message.conversation.externalId}/${event.message.conversation.sessionId}`
|
|
24
|
+
: `${event.message.conversation.transport}/${event.message.conversation.externalId}`;
|
|
25
|
+
const previous = conversationQueues.get(key) ?? Promise.resolve();
|
|
26
|
+
let release;
|
|
27
|
+
const current = new Promise((resolve) => {
|
|
28
|
+
release = resolve;
|
|
29
|
+
});
|
|
30
|
+
const next = previous.catch(() => undefined).then(() => current);
|
|
31
|
+
conversationQueues.set(key, next);
|
|
32
|
+
await previous.catch(() => undefined);
|
|
33
|
+
try {
|
|
34
|
+
await operation();
|
|
35
|
+
}
|
|
36
|
+
finally {
|
|
37
|
+
release?.();
|
|
38
|
+
if (conversationQueues.get(key) === next) {
|
|
39
|
+
conversationQueues.delete(key);
|
|
40
|
+
}
|
|
41
|
+
}
|
|
42
|
+
}
|
|
43
|
+
}
|
|
44
|
+
function shouldBypassConversationQueue(message) {
|
|
45
|
+
return Boolean(message.command && priorityInboundCommands.has(message.command));
|
|
46
|
+
}
|
|
47
|
+
async function processEvent(event, dependencies) {
|
|
48
|
+
let attempt = 1;
|
|
49
|
+
for (;;) {
|
|
50
|
+
try {
|
|
51
|
+
await event.runWithProcessing(async () => {
|
|
52
|
+
const response = await dependencies.handler.handle(event.message);
|
|
53
|
+
await event.deliver(response);
|
|
54
|
+
if (response.deliveryAction) {
|
|
55
|
+
await dependencies.afterDeliveryAction?.(response.deliveryAction, event);
|
|
56
|
+
}
|
|
57
|
+
});
|
|
58
|
+
return;
|
|
59
|
+
}
|
|
60
|
+
catch (error) {
|
|
61
|
+
const shouldRetry = await dependencies.shouldRetry?.(error, attempt, event);
|
|
62
|
+
if (shouldRetry) {
|
|
63
|
+
await dependencies.onRetry?.(error, attempt, event);
|
|
64
|
+
const retryDelayMs = (await dependencies.retryDelayMs?.(attempt, event)) ?? 0;
|
|
65
|
+
if (retryDelayMs > 0) {
|
|
66
|
+
await delay(retryDelayMs);
|
|
67
|
+
}
|
|
68
|
+
attempt += 1;
|
|
69
|
+
continue;
|
|
70
|
+
}
|
|
71
|
+
await dependencies.logger?.error("failed to process inbound message", {
|
|
72
|
+
endpointId: event.message.endpointId,
|
|
73
|
+
transport: event.message.conversation.transport,
|
|
74
|
+
conversationId: event.message.conversation.externalId,
|
|
75
|
+
messageId: event.message.messageId,
|
|
76
|
+
correlationId: event.message.correlationId,
|
|
77
|
+
errorType: error instanceof Error ? error.name : typeof error,
|
|
78
|
+
}, error);
|
|
79
|
+
await dependencies.onError?.(error, attempt, event);
|
|
80
|
+
await event.deliverError?.(error);
|
|
81
|
+
return;
|
|
82
|
+
}
|
|
83
|
+
}
|
|
84
|
+
}
|
|
85
|
+
function createSemaphore(maxPermits) {
|
|
86
|
+
let activePermits = 0;
|
|
87
|
+
const waiters = [];
|
|
88
|
+
async function acquirePermit() {
|
|
89
|
+
if (activePermits < maxPermits && waiters.length === 0) {
|
|
90
|
+
activePermits += 1;
|
|
91
|
+
return;
|
|
92
|
+
}
|
|
93
|
+
await new Promise((resolve) => {
|
|
94
|
+
waiters.push(() => {
|
|
95
|
+
activePermits += 1;
|
|
96
|
+
resolve();
|
|
97
|
+
});
|
|
98
|
+
});
|
|
99
|
+
}
|
|
100
|
+
function releasePermit() {
|
|
101
|
+
activePermits -= 1;
|
|
102
|
+
const next = waiters.shift();
|
|
103
|
+
next?.();
|
|
104
|
+
}
|
|
105
|
+
return {
|
|
106
|
+
async withPermit(operation) {
|
|
107
|
+
await acquirePermit();
|
|
108
|
+
try {
|
|
109
|
+
return await operation();
|
|
110
|
+
}
|
|
111
|
+
finally {
|
|
112
|
+
releasePermit();
|
|
113
|
+
}
|
|
114
|
+
},
|
|
115
|
+
};
|
|
116
|
+
}
|
|
117
|
+
async function delay(ms) {
|
|
118
|
+
await new Promise((resolve) => {
|
|
119
|
+
setTimeout(resolve, ms);
|
|
120
|
+
});
|
|
121
|
+
}
|
|
122
|
+
//# sourceMappingURL=message-processor.js.map
|