@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,308 @@
|
|
|
1
|
+
import { createReadStream } from "node:fs";
|
|
2
|
+
import { chmod, mkdir, open, readdir, stat, writeFile } from "node:fs/promises";
|
|
3
|
+
import { dirname, join, posix, relative, resolve, sep } from "node:path";
|
|
4
|
+
const tarBlockSize = 512;
|
|
5
|
+
const zeroBlock = Buffer.alloc(tarBlockSize, 0);
|
|
6
|
+
const defaultReadChunkSize = 64 * 1024;
|
|
7
|
+
const defaultExtractLimits = {
|
|
8
|
+
maxEntrySizeBytes: 512 * 1024 * 1024,
|
|
9
|
+
maxEntries: 10_000,
|
|
10
|
+
};
|
|
11
|
+
export async function createTarArchive(sourceDir, outputPath) {
|
|
12
|
+
const archive = await open(outputPath, "w", 0o600);
|
|
13
|
+
try {
|
|
14
|
+
for (const entry of await listTarEntries(sourceDir)) {
|
|
15
|
+
await archive.write(buildTarHeader(entry));
|
|
16
|
+
if (entry.type === "file") {
|
|
17
|
+
const sourcePath = join(sourceDir, entry.path);
|
|
18
|
+
await writeFileContentToArchive(archive, sourcePath, entry.size);
|
|
19
|
+
}
|
|
20
|
+
}
|
|
21
|
+
await archive.write(zeroBlock);
|
|
22
|
+
await archive.write(zeroBlock);
|
|
23
|
+
await archive.chmod(0o600);
|
|
24
|
+
}
|
|
25
|
+
finally {
|
|
26
|
+
await archive.close();
|
|
27
|
+
}
|
|
28
|
+
}
|
|
29
|
+
export async function extractTarArchive(archivePath, outputDir, options = {}) {
|
|
30
|
+
const archive = await open(archivePath, "r");
|
|
31
|
+
const reader = new TarArchiveReader(archive);
|
|
32
|
+
const directoryModes = new Map();
|
|
33
|
+
const limits = { ...defaultExtractLimits, ...options };
|
|
34
|
+
let entries = 0;
|
|
35
|
+
try {
|
|
36
|
+
while (true) {
|
|
37
|
+
const header = await reader.readBlock();
|
|
38
|
+
if (header === null) {
|
|
39
|
+
break;
|
|
40
|
+
}
|
|
41
|
+
if (isZeroBlock(header)) {
|
|
42
|
+
break;
|
|
43
|
+
}
|
|
44
|
+
entries += 1;
|
|
45
|
+
if (entries > limits.maxEntries) {
|
|
46
|
+
throw new Error(`Invalid backup archive: entry count exceeds limit (${limits.maxEntries})`);
|
|
47
|
+
}
|
|
48
|
+
assertHeaderChecksum(header);
|
|
49
|
+
const entry = parseTarHeader(header);
|
|
50
|
+
const targetPath = resolve(outputDir, entry.path);
|
|
51
|
+
assertArchivePath(targetPath, outputDir);
|
|
52
|
+
if (entry.size > limits.maxEntrySizeBytes) {
|
|
53
|
+
throw new Error(`Invalid backup archive: tar entry too large for ${entry.path} (${entry.size} bytes exceeds ${limits.maxEntrySizeBytes})`);
|
|
54
|
+
}
|
|
55
|
+
if (entry.type === "directory") {
|
|
56
|
+
await mkdir(targetPath, { recursive: true, mode: 0o700 });
|
|
57
|
+
directoryModes.set(targetPath, normalizeExtractedDirectoryMode(entry.mode));
|
|
58
|
+
continue;
|
|
59
|
+
}
|
|
60
|
+
await mkdir(dirname(targetPath), { recursive: true });
|
|
61
|
+
await streamEntryContentToFile(reader, targetPath, entry);
|
|
62
|
+
await reader.skipPadding(entry.size);
|
|
63
|
+
}
|
|
64
|
+
}
|
|
65
|
+
finally {
|
|
66
|
+
await archive.close();
|
|
67
|
+
}
|
|
68
|
+
for (const [path, mode] of [...directoryModes.entries()].sort(([left], [right]) => right.length - left.length)) {
|
|
69
|
+
await chmod(path, mode);
|
|
70
|
+
}
|
|
71
|
+
}
|
|
72
|
+
async function listTarEntries(root, currentDir = root) {
|
|
73
|
+
const dirEntries = await readdir(currentDir, { withFileTypes: true });
|
|
74
|
+
const entries = [];
|
|
75
|
+
for (const dirEntry of dirEntries.sort((left, right) => left.name.localeCompare(right.name))) {
|
|
76
|
+
const absolutePath = join(currentDir, dirEntry.name);
|
|
77
|
+
const relativePath = toTarPath(relative(root, absolutePath));
|
|
78
|
+
const fileStat = await stat(absolutePath);
|
|
79
|
+
if (dirEntry.isDirectory()) {
|
|
80
|
+
entries.push({
|
|
81
|
+
path: `${relativePath}/`,
|
|
82
|
+
type: "directory",
|
|
83
|
+
mode: fileStat.mode & 0o777,
|
|
84
|
+
size: 0,
|
|
85
|
+
mtime: Math.floor(fileStat.mtimeMs / 1000),
|
|
86
|
+
});
|
|
87
|
+
entries.push(...(await listTarEntries(root, absolutePath)));
|
|
88
|
+
continue;
|
|
89
|
+
}
|
|
90
|
+
if (dirEntry.isFile()) {
|
|
91
|
+
entries.push({
|
|
92
|
+
path: relativePath,
|
|
93
|
+
type: "file",
|
|
94
|
+
mode: fileStat.mode & 0o777,
|
|
95
|
+
size: fileStat.size,
|
|
96
|
+
mtime: Math.floor(fileStat.mtimeMs / 1000),
|
|
97
|
+
});
|
|
98
|
+
}
|
|
99
|
+
}
|
|
100
|
+
return entries;
|
|
101
|
+
}
|
|
102
|
+
function buildTarHeader(entry) {
|
|
103
|
+
const header = Buffer.alloc(tarBlockSize, 0);
|
|
104
|
+
const { name, prefix } = splitTarPath(entry.path);
|
|
105
|
+
writeStringField(header, 0, 100, name);
|
|
106
|
+
writeOctalField(header, 100, 8, entry.mode);
|
|
107
|
+
writeOctalField(header, 108, 8, 0);
|
|
108
|
+
writeOctalField(header, 116, 8, 0);
|
|
109
|
+
writeOctalField(header, 124, 12, entry.size);
|
|
110
|
+
writeOctalField(header, 136, 12, entry.mtime);
|
|
111
|
+
header.fill(0x20, 148, 156);
|
|
112
|
+
header[156] = entry.type === "directory" ? "5".charCodeAt(0) : "0".charCodeAt(0);
|
|
113
|
+
writeStringField(header, 257, 6, "ustar");
|
|
114
|
+
writeStringField(header, 263, 2, "00");
|
|
115
|
+
writeStringField(header, 265, 32, "root");
|
|
116
|
+
writeStringField(header, 297, 32, "root");
|
|
117
|
+
writeStringField(header, 345, 155, prefix);
|
|
118
|
+
const checksum = calculateChecksum(header);
|
|
119
|
+
writeChecksumField(header, checksum);
|
|
120
|
+
return header;
|
|
121
|
+
}
|
|
122
|
+
function parseTarHeader(header) {
|
|
123
|
+
const name = readStringField(header, 0, 100);
|
|
124
|
+
const prefix = readStringField(header, 345, 155);
|
|
125
|
+
const path = prefix ? `${prefix}/${name}` : name;
|
|
126
|
+
const typeFlag = String.fromCharCode(header[156] || "0".charCodeAt(0));
|
|
127
|
+
const type = typeFlag === "5" ? "directory" : "file";
|
|
128
|
+
return {
|
|
129
|
+
path,
|
|
130
|
+
type,
|
|
131
|
+
mode: readOctalField(header, 100, 8) || 0o600,
|
|
132
|
+
size: readOctalField(header, 124, 12),
|
|
133
|
+
mtime: readOctalField(header, 136, 12),
|
|
134
|
+
};
|
|
135
|
+
}
|
|
136
|
+
function splitTarPath(path) {
|
|
137
|
+
if (Buffer.byteLength(path) <= 100) {
|
|
138
|
+
return { name: path, prefix: "" };
|
|
139
|
+
}
|
|
140
|
+
const normalized = path.endsWith("/") ? path.slice(0, -1) : path;
|
|
141
|
+
const segments = normalized.split("/");
|
|
142
|
+
for (let index = segments.length - 1; index > 0; index -= 1) {
|
|
143
|
+
const prefix = segments.slice(0, index).join("/");
|
|
144
|
+
const name = segments.slice(index).join("/");
|
|
145
|
+
if (Buffer.byteLength(name) <= 100 && Buffer.byteLength(prefix) <= 155) {
|
|
146
|
+
return {
|
|
147
|
+
name: path.endsWith("/") ? `${name}/` : name,
|
|
148
|
+
prefix,
|
|
149
|
+
};
|
|
150
|
+
}
|
|
151
|
+
}
|
|
152
|
+
throw new Error(`Archive entry path is too long for tar format: ${path}`);
|
|
153
|
+
}
|
|
154
|
+
function writeStringField(buffer, offset, length, value) {
|
|
155
|
+
const encoded = Buffer.from(value, "utf8");
|
|
156
|
+
if (encoded.byteLength > length) {
|
|
157
|
+
throw new Error(`Value does not fit in tar header field: ${value}`);
|
|
158
|
+
}
|
|
159
|
+
encoded.copy(buffer, offset);
|
|
160
|
+
}
|
|
161
|
+
function writeOctalField(buffer, offset, length, value) {
|
|
162
|
+
const encoded = Buffer.from(value.toString(8).padStart(length - 1, "0").slice(-(length - 1)), "ascii");
|
|
163
|
+
encoded.copy(buffer, offset);
|
|
164
|
+
buffer[offset + length - 1] = 0;
|
|
165
|
+
}
|
|
166
|
+
function writeChecksumField(buffer, checksum) {
|
|
167
|
+
const encoded = Buffer.from(checksum.toString(8).padStart(6, "0"), "ascii");
|
|
168
|
+
encoded.copy(buffer, 148);
|
|
169
|
+
buffer[154] = 0;
|
|
170
|
+
buffer[155] = 0x20;
|
|
171
|
+
}
|
|
172
|
+
function readStringField(buffer, offset, length) {
|
|
173
|
+
return buffer
|
|
174
|
+
.subarray(offset, offset + length)
|
|
175
|
+
.toString("utf8")
|
|
176
|
+
.replace(/\0.*$/, "")
|
|
177
|
+
.trim();
|
|
178
|
+
}
|
|
179
|
+
function readOctalField(buffer, offset, length) {
|
|
180
|
+
const raw = buffer
|
|
181
|
+
.subarray(offset, offset + length)
|
|
182
|
+
.toString("ascii")
|
|
183
|
+
.replace(/\0.*$/, "")
|
|
184
|
+
.trim();
|
|
185
|
+
if (!raw) {
|
|
186
|
+
return 0;
|
|
187
|
+
}
|
|
188
|
+
return Number.parseInt(raw, 8);
|
|
189
|
+
}
|
|
190
|
+
function calculateChecksum(buffer) {
|
|
191
|
+
let sum = 0;
|
|
192
|
+
for (const byte of buffer) {
|
|
193
|
+
sum += byte;
|
|
194
|
+
}
|
|
195
|
+
return sum;
|
|
196
|
+
}
|
|
197
|
+
function assertHeaderChecksum(header) {
|
|
198
|
+
const expected = readOctalField(header, 148, 8);
|
|
199
|
+
const copy = Buffer.from(header);
|
|
200
|
+
copy.fill(0x20, 148, 156);
|
|
201
|
+
const actual = calculateChecksum(copy);
|
|
202
|
+
if (expected !== actual) {
|
|
203
|
+
throw new Error("Invalid backup archive: tar header checksum mismatch");
|
|
204
|
+
}
|
|
205
|
+
}
|
|
206
|
+
function isZeroBlock(block) {
|
|
207
|
+
return block.equals(zeroBlock);
|
|
208
|
+
}
|
|
209
|
+
function getPaddingSize(size) {
|
|
210
|
+
const remainder = size % tarBlockSize;
|
|
211
|
+
return remainder === 0 ? 0 : tarBlockSize - remainder;
|
|
212
|
+
}
|
|
213
|
+
function normalizeExtractedDirectoryMode(mode) {
|
|
214
|
+
return mode | 0o100;
|
|
215
|
+
}
|
|
216
|
+
function toTarPath(path) {
|
|
217
|
+
return path.split(sep).join(posix.sep);
|
|
218
|
+
}
|
|
219
|
+
function assertArchivePath(targetPath, outputDir) {
|
|
220
|
+
const normalizedOutputDir = resolve(outputDir);
|
|
221
|
+
if (targetPath !== normalizedOutputDir &&
|
|
222
|
+
!targetPath.startsWith(`${normalizedOutputDir}${sep}`)) {
|
|
223
|
+
throw new Error("Invalid backup archive: contains path traversal entry");
|
|
224
|
+
}
|
|
225
|
+
}
|
|
226
|
+
async function writeFileContentToArchive(archive, sourcePath, size) {
|
|
227
|
+
for await (const chunk of createReadStream(sourcePath)) {
|
|
228
|
+
await archive.write(chunk);
|
|
229
|
+
}
|
|
230
|
+
await writePadding(archive, size);
|
|
231
|
+
}
|
|
232
|
+
async function writePadding(archive, size) {
|
|
233
|
+
const paddingSize = getPaddingSize(size);
|
|
234
|
+
if (paddingSize > 0) {
|
|
235
|
+
await archive.write(Buffer.alloc(paddingSize, 0));
|
|
236
|
+
}
|
|
237
|
+
}
|
|
238
|
+
async function streamEntryContentToFile(reader, targetPath, entry) {
|
|
239
|
+
if (entry.size === 0) {
|
|
240
|
+
await writeFile(targetPath, Buffer.alloc(0), { mode: entry.mode });
|
|
241
|
+
return;
|
|
242
|
+
}
|
|
243
|
+
const output = await open(targetPath, "w", entry.mode);
|
|
244
|
+
try {
|
|
245
|
+
let remaining = entry.size;
|
|
246
|
+
while (remaining > 0) {
|
|
247
|
+
const chunkSize = Math.min(remaining, defaultReadChunkSize);
|
|
248
|
+
const chunk = await reader.readExact(chunkSize, `Invalid backup archive: truncated tar entry for ${entry.path}`);
|
|
249
|
+
let writeOffset = 0;
|
|
250
|
+
while (writeOffset < chunk.byteLength) {
|
|
251
|
+
const { bytesWritten } = await output.write(chunk, writeOffset, chunk.byteLength - writeOffset);
|
|
252
|
+
if (bytesWritten === 0) {
|
|
253
|
+
throw new Error(`Failed to extract tar entry: short write for ${entry.path}`);
|
|
254
|
+
}
|
|
255
|
+
writeOffset += bytesWritten;
|
|
256
|
+
}
|
|
257
|
+
remaining -= chunk.byteLength;
|
|
258
|
+
}
|
|
259
|
+
}
|
|
260
|
+
finally {
|
|
261
|
+
await output.close();
|
|
262
|
+
}
|
|
263
|
+
}
|
|
264
|
+
class TarArchiveReader {
|
|
265
|
+
archive;
|
|
266
|
+
offset = 0;
|
|
267
|
+
constructor(archive) {
|
|
268
|
+
this.archive = archive;
|
|
269
|
+
}
|
|
270
|
+
async readBlock() {
|
|
271
|
+
const block = await this.readChunk(tarBlockSize);
|
|
272
|
+
if (block.byteLength === 0) {
|
|
273
|
+
return null;
|
|
274
|
+
}
|
|
275
|
+
if (block.byteLength < tarBlockSize) {
|
|
276
|
+
throw new Error("Invalid backup archive: truncated tar header");
|
|
277
|
+
}
|
|
278
|
+
return block;
|
|
279
|
+
}
|
|
280
|
+
async readExact(size, errorMessage) {
|
|
281
|
+
const chunk = await this.readChunk(size);
|
|
282
|
+
if (chunk.byteLength !== size) {
|
|
283
|
+
throw new Error(errorMessage);
|
|
284
|
+
}
|
|
285
|
+
return chunk;
|
|
286
|
+
}
|
|
287
|
+
async skipPadding(size) {
|
|
288
|
+
const paddingSize = getPaddingSize(size);
|
|
289
|
+
if (paddingSize === 0) {
|
|
290
|
+
return;
|
|
291
|
+
}
|
|
292
|
+
await this.readExact(paddingSize, "Invalid backup archive: truncated tar padding");
|
|
293
|
+
}
|
|
294
|
+
async readChunk(size) {
|
|
295
|
+
const buffer = Buffer.allocUnsafe(size);
|
|
296
|
+
let totalBytesRead = 0;
|
|
297
|
+
while (totalBytesRead < size) {
|
|
298
|
+
const { bytesRead } = await this.archive.read(buffer, totalBytesRead, size - totalBytesRead, this.offset);
|
|
299
|
+
if (bytesRead === 0) {
|
|
300
|
+
break;
|
|
301
|
+
}
|
|
302
|
+
totalBytesRead += bytesRead;
|
|
303
|
+
this.offset += bytesRead;
|
|
304
|
+
}
|
|
305
|
+
return buffer.subarray(0, totalBytesRead);
|
|
306
|
+
}
|
|
307
|
+
}
|
|
308
|
+
//# sourceMappingURL=tar-archive.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"tar-archive.js","sourceRoot":"","sources":["../../src/files/tar-archive.ts"],"names":[],"mappings":"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"}
|
package/dist/index.d.ts
ADDED
package/dist/index.js
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,2BAA2B,CAAC"}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import { mkdir, writeFile } from "node:fs/promises";
|
|
2
|
+
import { dirname } from "node:path";
|
|
3
|
+
import { createFileLogger } from "./file-logger.js";
|
|
4
|
+
export function createDaemonStartupFailureReporter() {
|
|
5
|
+
return {
|
|
6
|
+
report: async ({ runtimeConfig, error }) => {
|
|
7
|
+
await Promise.all(runtimeConfig.activeEndpoints.map(async (endpoint) => {
|
|
8
|
+
await ensureStartupLogFile(endpoint.paths.logFilePath);
|
|
9
|
+
const logger = createFileLogger(endpoint.paths.logFilePath, runtimeConfig.logging.level);
|
|
10
|
+
await logger.error("daemon failed to start", { endpointId: endpoint.id }, error);
|
|
11
|
+
}));
|
|
12
|
+
},
|
|
13
|
+
};
|
|
14
|
+
}
|
|
15
|
+
async function ensureStartupLogFile(path) {
|
|
16
|
+
await mkdir(dirname(path), { recursive: true });
|
|
17
|
+
await writeFile(path, "", { encoding: "utf8", flag: "a" });
|
|
18
|
+
}
|
|
19
|
+
//# sourceMappingURL=daemon-startup-failure-reporter.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"daemon-startup-failure-reporter.js","sourceRoot":"","sources":["../../src/logging/daemon-startup-failure-reporter.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,EAAE,SAAS,EAAE,MAAM,kBAAkB,CAAC;AACpD,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AAEpC,OAAO,EAAE,gBAAgB,EAAE,MAAM,kBAAkB,CAAC;AAEpD,MAAM,UAAU,kCAAkC;IAChD,OAAO;QACL,MAAM,EAAE,KAAK,EAAE,EAAE,aAAa,EAAE,KAAK,EAAE,EAAE,EAAE;YACzC,MAAM,OAAO,CAAC,GAAG,CACf,aAAa,CAAC,eAAe,CAAC,GAAG,CAAC,KAAK,EAAE,QAAQ,EAAE,EAAE;gBACnD,MAAM,oBAAoB,CAAC,QAAQ,CAAC,KAAK,CAAC,WAAW,CAAC,CAAC;gBACvD,MAAM,MAAM,GAAG,gBAAgB,CAAC,QAAQ,CAAC,KAAK,CAAC,WAAW,EAAE,aAAa,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;gBACzF,MAAM,MAAM,CAAC,KAAK,CAAC,wBAAwB,EAAE,EAAE,UAAU,EAAE,QAAQ,CAAC,EAAE,EAAE,EAAE,KAAK,CAAC,CAAC;YACnF,CAAC,CAAC,CACH,CAAC;QACJ,CAAC;KACF,CAAC;AACJ,CAAC;AAED,KAAK,UAAU,oBAAoB,CAAC,IAAY;IAC9C,MAAM,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC,CAAC;IAChD,MAAM,SAAS,CAAC,IAAI,EAAE,EAAE,EAAE,EAAE,QAAQ,EAAE,MAAM,EAAE,IAAI,EAAE,GAAG,EAAE,CAAC,CAAC;AAC7D,CAAC"}
|
|
@@ -0,0 +1,87 @@
|
|
|
1
|
+
import { appendFile, mkdir, rename, stat, writeFile } from "node:fs/promises";
|
|
2
|
+
import { dirname } from "node:path";
|
|
3
|
+
const LOG_LEVEL_PRIORITY = {
|
|
4
|
+
debug: 10,
|
|
5
|
+
info: 20,
|
|
6
|
+
warn: 30,
|
|
7
|
+
error: 40,
|
|
8
|
+
};
|
|
9
|
+
export function createFileLogger(path, level = "info") {
|
|
10
|
+
return {
|
|
11
|
+
async debug(message, fields) {
|
|
12
|
+
if (!shouldLog("debug", level)) {
|
|
13
|
+
return;
|
|
14
|
+
}
|
|
15
|
+
await writeLogLine(path, "DEBUG", message, fields);
|
|
16
|
+
console.debug(formatConsoleLog(message, fields));
|
|
17
|
+
},
|
|
18
|
+
async info(message, fields) {
|
|
19
|
+
if (!shouldLog("info", level)) {
|
|
20
|
+
return;
|
|
21
|
+
}
|
|
22
|
+
await writeLogLine(path, "INFO", message, fields);
|
|
23
|
+
console.log(formatConsoleLog(message, fields));
|
|
24
|
+
},
|
|
25
|
+
async error(message, fields, error) {
|
|
26
|
+
if (!shouldLog("error", level)) {
|
|
27
|
+
return;
|
|
28
|
+
}
|
|
29
|
+
await writeLogLine(path, "ERROR", message, fields);
|
|
30
|
+
if (error !== undefined) {
|
|
31
|
+
await writeLogLine(path, "ERROR", formatError(error), fields);
|
|
32
|
+
}
|
|
33
|
+
console.error(formatConsoleLog(message, fields));
|
|
34
|
+
if (error !== undefined) {
|
|
35
|
+
console.error(error);
|
|
36
|
+
}
|
|
37
|
+
},
|
|
38
|
+
};
|
|
39
|
+
}
|
|
40
|
+
export async function rotateLogFileOnStartup(path) {
|
|
41
|
+
await mkdir(dirname(path), { recursive: true });
|
|
42
|
+
const hasContent = await hasExistingLogContent(path);
|
|
43
|
+
if (hasContent) {
|
|
44
|
+
await rename(path, `${path}.1`);
|
|
45
|
+
}
|
|
46
|
+
await writeFile(path, "", { encoding: "utf8", flag: "w" });
|
|
47
|
+
}
|
|
48
|
+
async function hasExistingLogContent(path) {
|
|
49
|
+
try {
|
|
50
|
+
const fileStats = await stat(path);
|
|
51
|
+
return fileStats.size > 0;
|
|
52
|
+
}
|
|
53
|
+
catch (error) {
|
|
54
|
+
if (isMissingFileError(error)) {
|
|
55
|
+
return false;
|
|
56
|
+
}
|
|
57
|
+
throw error;
|
|
58
|
+
}
|
|
59
|
+
}
|
|
60
|
+
function shouldLog(entryLevel, configuredLevel) {
|
|
61
|
+
return LOG_LEVEL_PRIORITY[entryLevel] >= LOG_LEVEL_PRIORITY[configuredLevel];
|
|
62
|
+
}
|
|
63
|
+
async function writeLogLine(path, level, message, fields) {
|
|
64
|
+
const payload = {
|
|
65
|
+
ts: new Date().toISOString(),
|
|
66
|
+
level,
|
|
67
|
+
message,
|
|
68
|
+
...(fields ?? {}),
|
|
69
|
+
};
|
|
70
|
+
await appendFile(path, `${JSON.stringify(payload)}\n`, "utf8");
|
|
71
|
+
}
|
|
72
|
+
function isMissingFileError(error) {
|
|
73
|
+
return error instanceof Error && "code" in error && error.code === "ENOENT";
|
|
74
|
+
}
|
|
75
|
+
function formatError(error) {
|
|
76
|
+
if (error instanceof Error) {
|
|
77
|
+
return error.stack ?? `${error.name}: ${error.message}`;
|
|
78
|
+
}
|
|
79
|
+
return String(error);
|
|
80
|
+
}
|
|
81
|
+
function formatConsoleLog(message, fields) {
|
|
82
|
+
if (!fields || Object.keys(fields).length === 0) {
|
|
83
|
+
return message;
|
|
84
|
+
}
|
|
85
|
+
return `${message} ${JSON.stringify(fields)}`;
|
|
86
|
+
}
|
|
87
|
+
//# sourceMappingURL=file-logger.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"file-logger.js","sourceRoot":"","sources":["../../src/logging/file-logger.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
export type LogLevel = "debug" | "info" | "warn" | "error";
|
|
2
|
+
export interface LogFields {
|
|
3
|
+
endpointId?: string;
|
|
4
|
+
transport?: string;
|
|
5
|
+
conversationId?: string;
|
|
6
|
+
messageId?: string;
|
|
7
|
+
agentId?: string;
|
|
8
|
+
correlationId?: string;
|
|
9
|
+
command?: string;
|
|
10
|
+
backupId?: string;
|
|
11
|
+
durationMs?: number;
|
|
12
|
+
errorType?: string;
|
|
13
|
+
hookName?: string;
|
|
14
|
+
hookRegistrationName?: string;
|
|
15
|
+
skillCount?: number;
|
|
16
|
+
skillNames?: string[];
|
|
17
|
+
workspaceDirectory?: string;
|
|
18
|
+
workspaceSkillsPath?: string;
|
|
19
|
+
overriddenSkillNames?: string[];
|
|
20
|
+
initialWorkingDirectory?: string;
|
|
21
|
+
configuredBuiltInTools?: string[];
|
|
22
|
+
resolvedBuiltInTools?: string[];
|
|
23
|
+
missingBuiltInTools?: string[];
|
|
24
|
+
configuredMcpServers?: string[];
|
|
25
|
+
initializedMcpServers?: string[];
|
|
26
|
+
failedMcpServers?: string[];
|
|
27
|
+
resolvedMcpTools?: string[];
|
|
28
|
+
resolvedTools?: string[];
|
|
29
|
+
}
|
|
30
|
+
export interface Logger {
|
|
31
|
+
debug(message: string, fields?: LogFields): Promise<void>;
|
|
32
|
+
info(message: string, fields?: LogFields): Promise<void>;
|
|
33
|
+
error(message: string, fields?: LogFields, error?: unknown): Promise<void>;
|
|
34
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.js","sourceRoot":"","sources":["../../src/logging/types.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
import type { DaemonConfig } from "../daemon/types.js";
|
|
2
|
+
export interface LogTarget {
|
|
3
|
+
endpointId: string;
|
|
4
|
+
logFilePath: string;
|
|
5
|
+
}
|
|
6
|
+
type ReadLogFile = (path: string, encoding: "utf8") => Promise<string>;
|
|
7
|
+
type WatchLogFile = (path: string, options: {
|
|
8
|
+
signal?: AbortSignal;
|
|
9
|
+
}) => AsyncIterable<{
|
|
10
|
+
eventType: string;
|
|
11
|
+
}>;
|
|
12
|
+
interface ViewLogsDependencies {
|
|
13
|
+
readFile?: ReadLogFile;
|
|
14
|
+
watch?: WatchLogFile;
|
|
15
|
+
}
|
|
16
|
+
export declare function viewDaemonLogs(options: {
|
|
17
|
+
runtimeConfig: DaemonConfig;
|
|
18
|
+
endpointId?: string;
|
|
19
|
+
lines?: number;
|
|
20
|
+
follow?: boolean;
|
|
21
|
+
stdout?: NodeJS.WritableStream;
|
|
22
|
+
signal?: AbortSignal;
|
|
23
|
+
dependencies?: ViewLogsDependencies;
|
|
24
|
+
}): Promise<void>;
|
|
25
|
+
export declare function resolveLogTargets(runtimeConfig: DaemonConfig, endpointId?: string): LogTarget[];
|
|
26
|
+
export declare function readRecentLogLines(logFilePath: string, lines: number, readFileImpl?: ReadLogFile): Promise<string[]>;
|
|
27
|
+
export {};
|