@dexto/core 1.2.4 → 1.2.6
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +60 -0
- package/dist/agent/DextoAgent.cjs +579 -345
- package/dist/agent/DextoAgent.d.ts +131 -83
- package/dist/agent/DextoAgent.d.ts.map +1 -1
- package/dist/agent/DextoAgent.js +573 -336
- package/dist/agent/agentCard.cjs +4 -2
- package/dist/agent/agentCard.d.ts +0 -1
- package/dist/agent/agentCard.d.ts.map +1 -1
- package/dist/agent/agentCard.js +4 -2
- package/dist/agent/index.cjs +3 -7
- package/dist/agent/index.d.ts +3 -3
- package/dist/agent/index.d.ts.map +1 -1
- package/dist/agent/index.js +7 -6
- package/dist/agent/schemas.cjs +179 -75
- package/dist/agent/schemas.d.ts +2678 -586
- package/dist/agent/schemas.d.ts.map +1 -1
- package/dist/agent/schemas.js +172 -65
- package/dist/agent/state-manager.cjs +28 -23
- package/dist/agent/state-manager.d.ts +4 -1
- package/dist/agent/state-manager.d.ts.map +1 -1
- package/dist/agent/state-manager.js +28 -23
- package/dist/{preferences/constants.cjs → agent/types.cjs} +2 -14
- package/dist/agent/types.d.ts +54 -0
- package/dist/agent/types.d.ts.map +1 -0
- package/dist/agent/types.js +0 -0
- package/dist/approval/errors.cjs +89 -8
- package/dist/approval/errors.d.ts +5 -3
- package/dist/approval/errors.d.ts.map +1 -1
- package/dist/approval/errors.js +89 -8
- package/dist/approval/{providers/factory.d.ts → factory.d.ts} +2 -2
- package/dist/approval/factory.d.ts.map +1 -0
- package/dist/approval/{providers/factory.js → factory.js} +1 -1
- package/dist/approval/index.cjs +4 -6
- package/dist/approval/index.d.ts +3 -5
- package/dist/approval/index.d.ts.map +1 -1
- package/dist/approval/index.js +4 -5
- package/dist/approval/manager.cjs +140 -37
- package/dist/approval/manager.d.ts +56 -17
- package/dist/approval/manager.d.ts.map +1 -1
- package/dist/approval/manager.js +141 -38
- package/dist/approval/schemas.cjs +9 -1
- package/dist/approval/schemas.d.ts +120 -35
- package/dist/approval/schemas.d.ts.map +1 -1
- package/dist/approval/schemas.js +9 -2
- package/dist/approval/types.cjs +14 -2
- package/dist/approval/types.d.ts +64 -12
- package/dist/approval/types.d.ts.map +1 -1
- package/dist/approval/types.js +12 -1
- package/dist/context/compression/middle-removal.cjs +11 -11
- package/dist/context/compression/middle-removal.d.ts +3 -1
- package/dist/context/compression/middle-removal.d.ts.map +1 -1
- package/dist/context/compression/middle-removal.js +11 -11
- package/dist/context/compression/oldest-removal.cjs +18 -5
- package/dist/context/compression/oldest-removal.d.ts +3 -1
- package/dist/context/compression/oldest-removal.d.ts.map +1 -1
- package/dist/context/compression/oldest-removal.js +18 -5
- package/dist/context/manager.cjs +94 -67
- package/dist/context/manager.d.ts +13 -10
- package/dist/context/manager.d.ts.map +1 -1
- package/dist/context/manager.js +94 -67
- package/dist/context/utils.cjs +79 -65
- package/dist/context/utils.d.ts +15 -12
- package/dist/context/utils.d.ts.map +1 -1
- package/dist/context/utils.js +45 -31
- package/dist/errors/DextoRuntimeError.d.ts +5 -5
- package/dist/errors/DextoRuntimeError.d.ts.map +1 -1
- package/dist/errors/result-bridge.cjs +2 -3
- package/dist/errors/result-bridge.d.ts +5 -3
- package/dist/errors/result-bridge.d.ts.map +1 -1
- package/dist/errors/result-bridge.js +1 -2
- package/dist/errors/types.cjs +1 -2
- package/dist/errors/types.d.ts +5 -8
- package/dist/errors/types.d.ts.map +1 -1
- package/dist/errors/types.js +1 -2
- package/dist/events/index.cjs +125 -55
- package/dist/events/index.d.ts +204 -97
- package/dist/events/index.d.ts.map +1 -1
- package/dist/events/index.js +123 -55
- package/dist/filesystem/filesystem-service.cjs +40 -30
- package/dist/filesystem/filesystem-service.d.ts +9 -1
- package/dist/filesystem/filesystem-service.d.ts.map +1 -1
- package/dist/filesystem/filesystem-service.js +40 -30
- package/dist/filesystem/path-validator.cjs +4 -3
- package/dist/filesystem/path-validator.d.ts +3 -1
- package/dist/filesystem/path-validator.d.ts.map +1 -1
- package/dist/filesystem/path-validator.js +4 -3
- package/dist/filesystem/types.d.ts +3 -3
- package/dist/filesystem/types.d.ts.map +1 -1
- package/dist/index.browser.cjs +7 -0
- package/dist/index.browser.d.ts +2 -0
- package/dist/index.browser.d.ts.map +1 -1
- package/dist/index.browser.js +4 -0
- package/dist/index.cjs +0 -7
- package/dist/index.d.ts +12 -3
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +0 -4
- package/dist/llm/formatters/anthropic.cjs +32 -21
- package/dist/llm/formatters/anthropic.d.ts +3 -0
- package/dist/llm/formatters/anthropic.d.ts.map +1 -1
- package/dist/llm/formatters/anthropic.js +32 -21
- package/dist/llm/formatters/factory.cjs +6 -7
- package/dist/llm/formatters/factory.d.ts +2 -1
- package/dist/llm/formatters/factory.d.ts.map +1 -1
- package/dist/llm/formatters/factory.js +4 -5
- package/dist/llm/formatters/openai.cjs +38 -9
- package/dist/llm/formatters/openai.d.ts +3 -0
- package/dist/llm/formatters/openai.d.ts.map +1 -1
- package/dist/llm/formatters/openai.js +38 -9
- package/dist/llm/formatters/vercel.cjs +49 -8
- package/dist/llm/formatters/vercel.d.ts +3 -0
- package/dist/llm/formatters/vercel.d.ts.map +1 -1
- package/dist/llm/formatters/vercel.js +49 -8
- package/dist/llm/registry.cjs +153 -17
- package/dist/llm/registry.d.ts +5 -2
- package/dist/llm/registry.d.ts.map +1 -1
- package/dist/llm/registry.js +143 -7
- package/dist/llm/resolver.cjs +4 -4
- package/dist/llm/resolver.d.ts +3 -2
- package/dist/llm/resolver.d.ts.map +1 -1
- package/dist/llm/resolver.js +4 -4
- package/dist/llm/schemas.cjs +6 -3
- package/dist/llm/schemas.d.ts +51 -17
- package/dist/llm/schemas.d.ts.map +1 -1
- package/dist/llm/schemas.js +5 -3
- package/dist/llm/services/anthropic.cjs +216 -183
- package/dist/llm/services/anthropic.d.ts +3 -1
- package/dist/llm/services/anthropic.d.ts.map +1 -1
- package/dist/llm/services/anthropic.js +217 -184
- package/dist/llm/services/factory.cjs +15 -9
- package/dist/llm/services/factory.d.ts +2 -1
- package/dist/llm/services/factory.d.ts.map +1 -1
- package/dist/llm/services/factory.js +15 -9
- package/dist/llm/services/openai.cjs +262 -225
- package/dist/llm/services/openai.d.ts +3 -1
- package/dist/llm/services/openai.d.ts.map +1 -1
- package/dist/llm/services/openai.js +263 -226
- package/dist/llm/services/test-utils.integration.cjs +58 -12
- package/dist/llm/services/test-utils.integration.d.ts.map +1 -1
- package/dist/llm/services/test-utils.integration.js +58 -12
- package/dist/llm/services/types.d.ts +9 -0
- package/dist/llm/services/types.d.ts.map +1 -1
- package/dist/llm/services/vercel.cjs +163 -111
- package/dist/llm/services/vercel.d.ts +3 -1
- package/dist/llm/services/vercel.d.ts.map +1 -1
- package/dist/llm/services/vercel.js +157 -105
- package/dist/llm/tokenizer/factory.cjs +2 -2
- package/dist/llm/tokenizer/factory.d.ts +3 -1
- package/dist/llm/tokenizer/factory.d.ts.map +1 -1
- package/dist/llm/tokenizer/factory.js +2 -2
- package/dist/llm/tokenizer/openai.cjs +16 -9
- package/dist/llm/tokenizer/openai.d.ts +4 -1
- package/dist/llm/tokenizer/openai.d.ts.map +1 -1
- package/dist/llm/tokenizer/openai.js +16 -9
- package/dist/llm/validation.cjs +8 -9
- package/dist/llm/validation.d.ts +3 -1
- package/dist/llm/validation.d.ts.map +1 -1
- package/dist/llm/validation.js +5 -6
- package/dist/logger/factory.cjs +54 -0
- package/dist/logger/factory.d.ts +36 -0
- package/dist/logger/factory.d.ts.map +1 -0
- package/dist/logger/factory.js +31 -0
- package/dist/logger/index.cjs +42 -3
- package/dist/logger/index.d.ts +17 -1
- package/dist/logger/index.d.ts.map +1 -1
- package/dist/logger/index.js +26 -1
- package/dist/logger/logger.cjs +30 -17
- package/dist/logger/logger.d.ts.map +1 -1
- package/dist/logger/logger.js +30 -17
- package/dist/logger/v2/dexto-logger.cjs +141 -0
- package/dist/logger/v2/dexto-logger.d.ts +54 -0
- package/dist/logger/v2/dexto-logger.d.ts.map +1 -0
- package/dist/logger/v2/dexto-logger.js +118 -0
- package/dist/{preferences → logger/v2}/error-codes.cjs +11 -10
- package/dist/logger/v2/error-codes.d.ts +13 -0
- package/dist/logger/v2/error-codes.d.ts.map +1 -0
- package/dist/logger/v2/error-codes.js +13 -0
- package/dist/logger/v2/errors.cjs +107 -0
- package/dist/logger/v2/errors.d.ts +32 -0
- package/dist/logger/v2/errors.d.ts.map +1 -0
- package/dist/logger/v2/errors.js +84 -0
- package/dist/logger/v2/schemas.cjs +57 -0
- package/dist/logger/v2/schemas.d.ts +147 -0
- package/dist/logger/v2/schemas.d.ts.map +1 -0
- package/dist/logger/v2/schemas.js +33 -0
- package/dist/logger/v2/transport-factory.cjs +53 -0
- package/dist/logger/v2/transport-factory.d.ts +21 -0
- package/dist/logger/v2/transport-factory.d.ts.map +1 -0
- package/dist/logger/v2/transport-factory.js +29 -0
- package/dist/logger/v2/transports/console-transport.cjs +79 -0
- package/dist/logger/v2/transports/console-transport.d.ts +23 -0
- package/dist/logger/v2/transports/console-transport.d.ts.map +1 -0
- package/dist/logger/v2/transports/console-transport.js +46 -0
- package/dist/logger/v2/transports/file-transport.cjs +161 -0
- package/dist/logger/v2/transports/file-transport.d.ts +46 -0
- package/dist/logger/v2/transports/file-transport.d.ts.map +1 -0
- package/dist/logger/v2/transports/file-transport.js +128 -0
- package/dist/logger/v2/types.cjs +49 -0
- package/dist/logger/v2/types.d.ts +123 -0
- package/dist/logger/v2/types.d.ts.map +1 -0
- package/dist/logger/v2/types.js +26 -0
- package/dist/mcp/manager.cjs +88 -78
- package/dist/mcp/manager.d.ts +3 -1
- package/dist/mcp/manager.d.ts.map +1 -1
- package/dist/mcp/manager.js +88 -78
- package/dist/mcp/mcp-client.cjs +109 -79
- package/dist/mcp/mcp-client.d.ts +3 -0
- package/dist/mcp/mcp-client.d.ts.map +1 -1
- package/dist/mcp/mcp-client.js +102 -72
- package/dist/memory/index.cjs +2 -0
- package/dist/memory/index.d.ts +1 -1
- package/dist/memory/index.d.ts.map +1 -1
- package/dist/memory/index.js +3 -1
- package/dist/memory/manager.cjs +9 -7
- package/dist/memory/manager.d.ts +3 -1
- package/dist/memory/manager.d.ts.map +1 -1
- package/dist/memory/manager.js +9 -7
- package/dist/memory/schemas.cjs +10 -0
- package/dist/memory/schemas.d.ts +37 -8
- package/dist/memory/schemas.d.ts.map +1 -1
- package/dist/memory/schemas.js +9 -0
- package/dist/plugins/manager.cjs +21 -19
- package/dist/plugins/manager.d.ts +3 -1
- package/dist/plugins/manager.d.ts.map +1 -1
- package/dist/plugins/manager.js +21 -19
- package/dist/plugins/schemas.d.ts +9 -9
- package/dist/plugins/types.d.ts +2 -2
- package/dist/plugins/types.d.ts.map +1 -1
- package/dist/process/command-validator.cjs +30 -20
- package/dist/process/command-validator.d.ts +4 -1
- package/dist/process/command-validator.d.ts.map +1 -1
- package/dist/process/command-validator.js +30 -20
- package/dist/process/process-service.cjs +23 -21
- package/dist/process/process-service.d.ts +3 -1
- package/dist/process/process-service.d.ts.map +1 -1
- package/dist/process/process-service.js +23 -21
- package/dist/prompts/index.cjs +6 -8
- package/dist/prompts/index.d.ts +2 -4
- package/dist/prompts/index.d.ts.map +1 -1
- package/dist/prompts/index.js +4 -6
- package/dist/prompts/prompt-manager.cjs +25 -20
- package/dist/prompts/prompt-manager.d.ts +3 -1
- package/dist/prompts/prompt-manager.d.ts.map +1 -1
- package/dist/prompts/prompt-manager.js +25 -20
- package/dist/prompts/providers/config-prompt-provider.cjs +331 -0
- package/dist/prompts/providers/config-prompt-provider.d.ts +34 -0
- package/dist/prompts/providers/config-prompt-provider.d.ts.map +1 -0
- package/dist/prompts/providers/config-prompt-provider.js +308 -0
- package/dist/prompts/providers/custom-prompt-provider.cjs +11 -7
- package/dist/prompts/providers/custom-prompt-provider.d.ts +3 -1
- package/dist/prompts/providers/custom-prompt-provider.d.ts.map +1 -1
- package/dist/prompts/providers/custom-prompt-provider.js +11 -7
- package/dist/prompts/providers/mcp-prompt-provider.cjs +7 -6
- package/dist/prompts/providers/mcp-prompt-provider.d.ts +3 -1
- package/dist/prompts/providers/mcp-prompt-provider.d.ts.map +1 -1
- package/dist/prompts/providers/mcp-prompt-provider.js +7 -6
- package/dist/prompts/schemas.cjs +42 -23
- package/dist/prompts/schemas.d.ts +123 -14
- package/dist/prompts/schemas.d.ts.map +1 -1
- package/dist/prompts/schemas.js +39 -22
- package/dist/prompts/types.d.ts +1 -1
- package/dist/prompts/types.d.ts.map +1 -1
- package/dist/resources/handlers/blob-handler.cjs +15 -11
- package/dist/resources/handlers/blob-handler.d.ts +3 -1
- package/dist/resources/handlers/blob-handler.d.ts.map +1 -1
- package/dist/resources/handlers/blob-handler.js +15 -11
- package/dist/resources/handlers/factory.cjs +3 -3
- package/dist/resources/handlers/factory.d.ts +2 -1
- package/dist/resources/handlers/factory.d.ts.map +1 -1
- package/dist/resources/handlers/factory.js +3 -3
- package/dist/resources/handlers/filesystem-handler.cjs +10 -8
- package/dist/resources/handlers/filesystem-handler.d.ts +3 -1
- package/dist/resources/handlers/filesystem-handler.d.ts.map +1 -1
- package/dist/resources/handlers/filesystem-handler.js +10 -8
- package/dist/resources/internal-provider.cjs +28 -20
- package/dist/resources/internal-provider.d.ts +3 -1
- package/dist/resources/internal-provider.d.ts.map +1 -1
- package/dist/resources/internal-provider.js +28 -20
- package/dist/resources/manager.cjs +34 -25
- package/dist/resources/manager.d.ts +3 -1
- package/dist/resources/manager.d.ts.map +1 -1
- package/dist/resources/manager.js +34 -25
- package/dist/resources/schemas.d.ts +6 -6
- package/dist/search/search-service.cjs +8 -6
- package/dist/search/search-service.d.ts +3 -1
- package/dist/search/search-service.d.ts.map +1 -1
- package/dist/search/search-service.js +8 -6
- package/dist/session/chat-session.cjs +40 -27
- package/dist/session/chat-session.d.ts +10 -7
- package/dist/session/chat-session.d.ts.map +1 -1
- package/dist/session/chat-session.js +40 -27
- package/dist/session/history/database.cjs +18 -11
- package/dist/session/history/database.d.ts +3 -1
- package/dist/session/history/database.d.ts.map +1 -1
- package/dist/session/history/database.js +18 -11
- package/dist/session/history/factory.cjs +2 -2
- package/dist/session/history/factory.d.ts +5 -1
- package/dist/session/history/factory.d.ts.map +1 -1
- package/dist/session/history/factory.js +2 -2
- package/dist/session/session-manager.cjs +37 -53
- package/dist/session/session-manager.d.ts +3 -17
- package/dist/session/session-manager.d.ts.map +1 -1
- package/dist/session/session-manager.js +37 -53
- package/dist/session/title-generator.cjs +3 -2
- package/dist/session/title-generator.d.ts +2 -1
- package/dist/session/title-generator.d.ts.map +1 -1
- package/dist/session/title-generator.js +3 -2
- package/dist/storage/blob/factory.cjs +9 -18
- package/dist/storage/blob/factory.d.ts +5 -4
- package/dist/storage/blob/factory.d.ts.map +1 -1
- package/dist/storage/blob/factory.js +8 -17
- package/dist/storage/blob/local-blob-store.cjs +25 -32
- package/dist/storage/blob/local-blob-store.d.ts +3 -2
- package/dist/storage/blob/local-blob-store.d.ts.map +1 -1
- package/dist/storage/blob/local-blob-store.js +25 -32
- package/dist/storage/blob/memory-blob-store.cjs +326 -0
- package/dist/storage/blob/memory-blob-store.d.ts +66 -0
- package/dist/storage/blob/memory-blob-store.d.ts.map +1 -0
- package/dist/storage/blob/memory-blob-store.js +303 -0
- package/dist/storage/blob/schemas.cjs +3 -1
- package/dist/storage/blob/schemas.d.ts +6 -6
- package/dist/storage/blob/schemas.d.ts.map +1 -1
- package/dist/storage/blob/schemas.js +3 -1
- package/dist/storage/cache/factory.cjs +7 -8
- package/dist/storage/cache/factory.d.ts +4 -1
- package/dist/storage/cache/factory.d.ts.map +1 -1
- package/dist/storage/cache/factory.js +4 -5
- package/dist/storage/cache/redis-store.cjs +4 -1
- package/dist/storage/cache/redis-store.d.ts +3 -1
- package/dist/storage/cache/redis-store.d.ts.map +1 -1
- package/dist/storage/cache/redis-store.js +4 -1
- package/dist/storage/database/factory.cjs +13 -16
- package/dist/storage/database/factory.d.ts +5 -3
- package/dist/storage/database/factory.d.ts.map +1 -1
- package/dist/storage/database/factory.js +9 -12
- package/dist/storage/database/postgres-store.cjs +4 -1
- package/dist/storage/database/postgres-store.d.ts +3 -1
- package/dist/storage/database/postgres-store.d.ts.map +1 -1
- package/dist/storage/database/postgres-store.js +4 -1
- package/dist/storage/database/schemas.cjs +3 -4
- package/dist/storage/database/schemas.d.ts +8 -16
- package/dist/storage/database/schemas.d.ts.map +1 -1
- package/dist/storage/database/schemas.js +3 -4
- package/dist/storage/database/sqlite-store.cjs +17 -45
- package/dist/storage/database/sqlite-store.d.ts +3 -3
- package/dist/storage/database/sqlite-store.d.ts.map +1 -1
- package/dist/storage/database/sqlite-store.js +17 -45
- package/dist/storage/schemas.cjs +3 -1
- package/dist/storage/schemas.d.ts +16 -23
- package/dist/storage/schemas.d.ts.map +1 -1
- package/dist/storage/schemas.js +3 -1
- package/dist/storage/storage-manager.cjs +15 -15
- package/dist/storage/storage-manager.d.ts +6 -6
- package/dist/storage/storage-manager.d.ts.map +1 -1
- package/dist/storage/storage-manager.js +15 -15
- package/dist/systemPrompt/contributors.cjs +15 -15
- package/dist/systemPrompt/contributors.d.ts +5 -3
- package/dist/systemPrompt/contributors.d.ts.map +1 -1
- package/dist/systemPrompt/contributors.js +15 -15
- package/dist/systemPrompt/in-built-prompts.cjs +0 -5
- package/dist/systemPrompt/in-built-prompts.d.ts +1 -2
- package/dist/systemPrompt/in-built-prompts.d.ts.map +1 -1
- package/dist/systemPrompt/in-built-prompts.js +0 -4
- package/dist/systemPrompt/manager.cjs +31 -23
- package/dist/systemPrompt/manager.d.ts +5 -3
- package/dist/systemPrompt/manager.d.ts.map +1 -1
- package/dist/systemPrompt/manager.js +31 -23
- package/dist/systemPrompt/registry.cjs +1 -2
- package/dist/systemPrompt/registry.d.ts +1 -1
- package/dist/systemPrompt/registry.d.ts.map +1 -1
- package/dist/systemPrompt/registry.js +1 -2
- package/dist/systemPrompt/schemas.cjs +24 -18
- package/dist/systemPrompt/schemas.d.ts +46 -222
- package/dist/systemPrompt/schemas.d.ts.map +1 -1
- package/dist/systemPrompt/schemas.js +14 -18
- package/dist/telemetry/decorators.cjs +54 -15
- package/dist/telemetry/decorators.d.ts.map +1 -1
- package/dist/telemetry/decorators.js +54 -15
- package/dist/telemetry/utils.cjs +21 -14
- package/dist/telemetry/utils.d.ts +7 -3
- package/dist/telemetry/utils.d.ts.map +1 -1
- package/dist/telemetry/utils.js +21 -14
- package/dist/tools/confirmation/allowed-tools-provider/factory.cjs +2 -2
- package/dist/tools/confirmation/allowed-tools-provider/factory.d.ts +2 -1
- package/dist/tools/confirmation/allowed-tools-provider/factory.d.ts.map +1 -1
- package/dist/tools/confirmation/allowed-tools-provider/factory.js +2 -2
- package/dist/tools/confirmation/allowed-tools-provider/storage.cjs +7 -6
- package/dist/tools/confirmation/allowed-tools-provider/storage.d.ts +3 -1
- package/dist/tools/confirmation/allowed-tools-provider/storage.d.ts.map +1 -1
- package/dist/tools/confirmation/allowed-tools-provider/storage.js +7 -6
- package/dist/tools/errors.cjs +2 -1
- package/dist/tools/errors.d.ts.map +1 -1
- package/dist/tools/errors.js +2 -1
- package/dist/tools/internal-tools/constants.cjs +2 -1
- package/dist/tools/internal-tools/constants.d.ts +1 -1
- package/dist/tools/internal-tools/constants.d.ts.map +1 -1
- package/dist/tools/internal-tools/constants.js +2 -1
- package/dist/tools/internal-tools/implementations/bash-exec-tool.cjs +1 -1
- package/dist/tools/internal-tools/implementations/bash-exec-tool.js +1 -1
- package/dist/tools/internal-tools/implementations/delegate-to-url-tool.cjs +192 -0
- package/dist/tools/internal-tools/implementations/delegate-to-url-tool.d.ts +33 -0
- package/dist/tools/internal-tools/implementations/delegate-to-url-tool.d.ts.map +1 -0
- package/dist/tools/internal-tools/implementations/delegate-to-url-tool.js +169 -0
- package/dist/tools/internal-tools/provider.cjs +21 -17
- package/dist/tools/internal-tools/provider.d.ts +3 -1
- package/dist/tools/internal-tools/provider.d.ts.map +1 -1
- package/dist/tools/internal-tools/provider.js +21 -17
- package/dist/tools/internal-tools/registry.cjs +5 -0
- package/dist/tools/internal-tools/registry.d.ts.map +1 -1
- package/dist/tools/internal-tools/registry.js +5 -0
- package/dist/tools/schemas.cjs +16 -4
- package/dist/tools/schemas.d.ts +21 -9
- package/dist/tools/schemas.d.ts.map +1 -1
- package/dist/tools/schemas.js +15 -4
- package/dist/tools/tool-manager.cjs +64 -47
- package/dist/tools/tool-manager.d.ts +4 -2
- package/dist/tools/tool-manager.d.ts.map +1 -1
- package/dist/tools/tool-manager.js +61 -44
- package/dist/tools/types.d.ts +0 -4
- package/dist/tools/types.d.ts.map +1 -1
- package/dist/utils/env-file.cjs +118 -0
- package/dist/utils/env-file.d.ts +5 -0
- package/dist/utils/env-file.d.ts.map +1 -0
- package/dist/utils/env-file.js +85 -0
- package/dist/utils/error-conversion.cjs +23 -1
- package/dist/utils/error-conversion.d.ts +2 -1
- package/dist/utils/error-conversion.d.ts.map +1 -1
- package/dist/utils/error-conversion.js +23 -1
- package/dist/utils/execution-context.d.ts.map +1 -1
- package/dist/utils/fs-walk.d.ts.map +1 -1
- package/dist/utils/index.cjs +7 -9
- package/dist/utils/index.d.ts +3 -4
- package/dist/utils/index.d.ts.map +1 -1
- package/dist/utils/index.js +3 -4
- package/dist/utils/path.cjs +22 -57
- package/dist/utils/path.d.ts +8 -7
- package/dist/utils/path.d.ts.map +1 -1
- package/dist/utils/path.js +21 -54
- package/dist/utils/result.cjs +37 -14
- package/dist/utils/result.d.ts.map +1 -1
- package/dist/utils/result.js +37 -14
- package/dist/utils/schema.cjs +2 -3
- package/dist/utils/schema.d.ts +2 -1
- package/dist/utils/schema.d.ts.map +1 -1
- package/dist/utils/schema.js +1 -2
- package/dist/utils/service-initializer.cjs +88 -61
- package/dist/utils/service-initializer.d.ts +4 -2
- package/dist/utils/service-initializer.d.ts.map +1 -1
- package/dist/utils/service-initializer.js +70 -43
- package/package.json +7 -3
- package/dist/Dexto.cjs +0 -251
- package/dist/Dexto.d.ts +0 -191
- package/dist/Dexto.d.ts.map +0 -1
- package/dist/Dexto.js +0 -228
- package/dist/agent/registry/error-codes.cjs +0 -44
- package/dist/agent/registry/error-codes.d.ts +0 -21
- package/dist/agent/registry/error-codes.d.ts.map +0 -1
- package/dist/agent/registry/error-codes.js +0 -21
- package/dist/agent/registry/errors.cjs +0 -188
- package/dist/agent/registry/errors.d.ts +0 -63
- package/dist/agent/registry/errors.d.ts.map +0 -1
- package/dist/agent/registry/errors.js +0 -165
- package/dist/agent/registry/registry.cjs +0 -479
- package/dist/agent/registry/registry.d.ts +0 -130
- package/dist/agent/registry/registry.d.ts.map +0 -1
- package/dist/agent/registry/registry.js +0 -453
- package/dist/agent/registry/types.cjs +0 -74
- package/dist/agent/registry/types.d.ts +0 -142
- package/dist/agent/registry/types.d.ts.map +0 -1
- package/dist/agent/registry/types.js +0 -48
- package/dist/agent/registry/user-registry.cjs +0 -140
- package/dist/agent/registry/user-registry.d.ts +0 -34
- package/dist/agent/registry/user-registry.d.ts.map +0 -1
- package/dist/agent/registry/user-registry.js +0 -105
- package/dist/approval/providers/event-based-approval-provider.cjs +0 -156
- package/dist/approval/providers/event-based-approval-provider.d.ts +0 -39
- package/dist/approval/providers/event-based-approval-provider.d.ts.map +0 -1
- package/dist/approval/providers/event-based-approval-provider.js +0 -133
- package/dist/approval/providers/factory.d.ts.map +0 -1
- package/dist/approval/providers/noop-approval-provider.cjs +0 -54
- package/dist/approval/providers/noop-approval-provider.d.ts +0 -18
- package/dist/approval/providers/noop-approval-provider.d.ts.map +0 -1
- package/dist/approval/providers/noop-approval-provider.js +0 -31
- package/dist/config/agent-resolver.cjs +0 -153
- package/dist/config/agent-resolver.d.ts +0 -14
- package/dist/config/agent-resolver.d.ts.map +0 -1
- package/dist/config/agent-resolver.js +0 -123
- package/dist/config/error-codes.cjs +0 -39
- package/dist/config/error-codes.d.ts +0 -16
- package/dist/config/error-codes.d.ts.map +0 -1
- package/dist/config/error-codes.js +0 -16
- package/dist/config/errors.cjs +0 -126
- package/dist/config/errors.d.ts +0 -34
- package/dist/config/errors.d.ts.map +0 -1
- package/dist/config/errors.js +0 -103
- package/dist/config/index.cjs +0 -26
- package/dist/config/index.d.ts +0 -4
- package/dist/config/index.d.ts.map +0 -1
- package/dist/config/index.js +0 -3
- package/dist/config/loader.cjs +0 -119
- package/dist/config/loader.d.ts +0 -16
- package/dist/config/loader.d.ts.map +0 -1
- package/dist/config/loader.js +0 -86
- package/dist/config/writer.cjs +0 -182
- package/dist/config/writer.d.ts +0 -35
- package/dist/config/writer.d.ts.map +0 -1
- package/dist/config/writer.js +0 -147
- package/dist/preferences/constants.d.ts +0 -2
- package/dist/preferences/constants.d.ts.map +0 -1
- package/dist/preferences/constants.js +0 -5
- package/dist/preferences/error-codes.d.ts +0 -8
- package/dist/preferences/error-codes.d.ts.map +0 -1
- package/dist/preferences/error-codes.js +0 -12
- package/dist/preferences/errors.cjs +0 -75
- package/dist/preferences/errors.d.ts +0 -18
- package/dist/preferences/errors.d.ts.map +0 -1
- package/dist/preferences/errors.js +0 -51
- package/dist/preferences/index.cjs +0 -55
- package/dist/preferences/index.d.ts +0 -6
- package/dist/preferences/index.d.ts.map +0 -1
- package/dist/preferences/index.js +0 -32
- package/dist/preferences/loader.cjs +0 -138
- package/dist/preferences/loader.d.ts +0 -51
- package/dist/preferences/loader.d.ts.map +0 -1
- package/dist/preferences/loader.js +0 -110
- package/dist/preferences/schemas.cjs +0 -75
- package/dist/preferences/schemas.d.ts +0 -110
- package/dist/preferences/schemas.d.ts.map +0 -1
- package/dist/preferences/schemas.js +0 -49
- package/dist/prompts/providers/file-prompt-provider.cjs +0 -399
- package/dist/prompts/providers/file-prompt-provider.d.ts +0 -47
- package/dist/prompts/providers/file-prompt-provider.d.ts.map +0 -1
- package/dist/prompts/providers/file-prompt-provider.js +0 -376
- package/dist/prompts/providers/starter-prompt-provider.cjs +0 -170
- package/dist/prompts/providers/starter-prompt-provider.d.ts +0 -45
- package/dist/prompts/providers/starter-prompt-provider.d.ts.map +0 -1
- package/dist/prompts/providers/starter-prompt-provider.js +0 -147
- package/dist/utils/api-key-store.cjs +0 -56
- package/dist/utils/api-key-store.d.ts +0 -24
- package/dist/utils/api-key-store.d.ts.map +0 -1
- package/dist/utils/api-key-store.js +0 -31
- package/dist/utils/env.cjs +0 -154
- package/dist/utils/env.d.ts +0 -28
- package/dist/utils/env.d.ts.map +0 -1
- package/dist/utils/env.js +0 -119
- package/dist/utils/port-utils.cjs +0 -37
- package/dist/utils/port-utils.d.ts +0 -10
- package/dist/utils/port-utils.d.ts.map +0 -1
- package/dist/utils/port-utils.js +0 -14
- package/dist/utils/port-utils.spec.cjs +0 -26
- package/dist/utils/port-utils.spec.js +0 -25
- /package/dist/approval/{providers/factory.cjs → factory.cjs} +0 -0
|
@@ -3,8 +3,7 @@ import { promises as fs, createReadStream } from "fs";
|
|
|
3
3
|
import path from "path";
|
|
4
4
|
import { createHash } from "crypto";
|
|
5
5
|
import { pathToFileURL } from "url";
|
|
6
|
-
import {
|
|
7
|
-
import { getDextoPath } from "../../utils/path.js";
|
|
6
|
+
import { DextoLogComponent } from "../../logger/v2/types.js";
|
|
8
7
|
import { StorageError } from "../errors.js";
|
|
9
8
|
class LocalBlobStore {
|
|
10
9
|
config;
|
|
@@ -13,27 +12,13 @@ class LocalBlobStore {
|
|
|
13
12
|
statsCache = null;
|
|
14
13
|
statsCachePromise = null;
|
|
15
14
|
lastStatsRefresh = 0;
|
|
16
|
-
|
|
15
|
+
logger;
|
|
17
16
|
static STATS_REFRESH_INTERVAL_MS = 6e4;
|
|
18
17
|
// 1 minute
|
|
19
|
-
constructor(config,
|
|
18
|
+
constructor(config, logger) {
|
|
20
19
|
this.config = config;
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
if (!trimmed) {
|
|
24
|
-
throw StorageError.blobInvalidConfig("agentId cannot be empty or whitespace-only");
|
|
25
|
-
}
|
|
26
|
-
if (!/^[a-zA-Z0-9_-]+$/.test(trimmed)) {
|
|
27
|
-
throw StorageError.blobInvalidConfig(
|
|
28
|
-
"agentId must contain only alphanumeric characters, hyphens, and underscores"
|
|
29
|
-
);
|
|
30
|
-
}
|
|
31
|
-
this.agentId = trimmed;
|
|
32
|
-
} else {
|
|
33
|
-
this.agentId = agentId;
|
|
34
|
-
}
|
|
35
|
-
const blobSubdir = this.agentId ? `blobs-${this.agentId}` : "blobs";
|
|
36
|
-
this.storePath = config.storePath || getDextoPath("data", blobSubdir);
|
|
20
|
+
this.storePath = config.storePath;
|
|
21
|
+
this.logger = logger.createChild(DextoLogComponent.STORAGE);
|
|
37
22
|
}
|
|
38
23
|
async connect() {
|
|
39
24
|
if (this.connected) return;
|
|
@@ -42,14 +27,14 @@ class LocalBlobStore {
|
|
|
42
27
|
await this.refreshStatsCache();
|
|
43
28
|
this.lastStatsRefresh = Date.now();
|
|
44
29
|
this.connected = true;
|
|
45
|
-
logger.debug(`LocalBlobStore connected at: ${this.storePath}`);
|
|
30
|
+
this.logger.debug(`LocalBlobStore connected at: ${this.storePath}`);
|
|
46
31
|
} catch (error) {
|
|
47
32
|
throw StorageError.blobOperationFailed("connect", "local", error);
|
|
48
33
|
}
|
|
49
34
|
}
|
|
50
35
|
async disconnect() {
|
|
51
36
|
this.connected = false;
|
|
52
|
-
logger.debug("LocalBlobStore disconnected");
|
|
37
|
+
this.logger.debug("LocalBlobStore disconnected");
|
|
53
38
|
}
|
|
54
39
|
/**
|
|
55
40
|
* Normalize metadata after JSON parsing to ensure createdAt is a Date object
|
|
@@ -82,7 +67,9 @@ class LocalBlobStore {
|
|
|
82
67
|
const existingMeta = await fs.readFile(metaPath, "utf-8");
|
|
83
68
|
const parsed = JSON.parse(existingMeta);
|
|
84
69
|
const existingMetadata = this.normalizeMetadata(parsed);
|
|
85
|
-
logger.debug(
|
|
70
|
+
this.logger.debug(
|
|
71
|
+
`Blob ${id} already exists, returning existing reference (deduplication)`
|
|
72
|
+
);
|
|
86
73
|
return {
|
|
87
74
|
id,
|
|
88
75
|
uri: `blob:${id}`,
|
|
@@ -114,7 +101,9 @@ class LocalBlobStore {
|
|
|
114
101
|
fs.writeFile(blobPath, buffer),
|
|
115
102
|
fs.writeFile(metaPath, JSON.stringify(storedMetadata, null, 2))
|
|
116
103
|
]);
|
|
117
|
-
logger.debug(
|
|
104
|
+
this.logger.debug(
|
|
105
|
+
`Stored blob ${id} (${buffer.length} bytes, ${storedMetadata.mimeType})`
|
|
106
|
+
);
|
|
118
107
|
this.updateStatsCacheAfterStore(buffer.length);
|
|
119
108
|
return {
|
|
120
109
|
id,
|
|
@@ -203,7 +192,7 @@ class LocalBlobStore {
|
|
|
203
192
|
const parsed = JSON.parse(metaContent);
|
|
204
193
|
const metadata = this.normalizeMetadata(parsed);
|
|
205
194
|
await Promise.all([fs.unlink(blobPath), fs.unlink(metaPath)]);
|
|
206
|
-
logger.debug(`Deleted blob: ${id}`);
|
|
195
|
+
this.logger.debug(`Deleted blob: ${id}`);
|
|
207
196
|
this.updateStatsCacheAfterDelete(metadata.size);
|
|
208
197
|
} catch (error) {
|
|
209
198
|
if (error instanceof Error && "code" in error && error.code === "ENOENT") {
|
|
@@ -239,14 +228,16 @@ class LocalBlobStore {
|
|
|
239
228
|
]);
|
|
240
229
|
deletedCount++;
|
|
241
230
|
this.updateStatsCacheAfterDelete(metadata.size);
|
|
242
|
-
logger.debug(`Cleaned up old blob: ${id}`);
|
|
231
|
+
this.logger.debug(`Cleaned up old blob: ${id}`);
|
|
243
232
|
}
|
|
244
233
|
} catch (error) {
|
|
245
|
-
logger.warn(
|
|
234
|
+
this.logger.warn(
|
|
235
|
+
`Failed to process blob metadata ${metaFile}: ${String(error)}`
|
|
236
|
+
);
|
|
246
237
|
}
|
|
247
238
|
}
|
|
248
239
|
if (deletedCount > 0) {
|
|
249
|
-
logger.info(`Blob cleanup: removed ${deletedCount} old blobs`);
|
|
240
|
+
this.logger.info(`Blob cleanup: removed ${deletedCount} old blobs`);
|
|
250
241
|
}
|
|
251
242
|
return deletedCount;
|
|
252
243
|
} catch (error) {
|
|
@@ -289,12 +280,14 @@ class LocalBlobStore {
|
|
|
289
280
|
metadata
|
|
290
281
|
});
|
|
291
282
|
} catch (error) {
|
|
292
|
-
logger.warn(
|
|
283
|
+
this.logger.warn(
|
|
284
|
+
`Failed to process blob metadata ${metaFile}: ${String(error)}`
|
|
285
|
+
);
|
|
293
286
|
}
|
|
294
287
|
}
|
|
295
288
|
return blobs;
|
|
296
289
|
} catch (error) {
|
|
297
|
-
logger.warn(`Failed to list blobs: ${String(error)}`);
|
|
290
|
+
this.logger.warn(`Failed to list blobs: ${String(error)}`);
|
|
298
291
|
return [];
|
|
299
292
|
}
|
|
300
293
|
}
|
|
@@ -326,13 +319,13 @@ class LocalBlobStore {
|
|
|
326
319
|
const stat = await fs.stat(path.join(this.storePath, datFile));
|
|
327
320
|
stats.totalSize += stat.size;
|
|
328
321
|
} catch (error) {
|
|
329
|
-
logger.debug(
|
|
322
|
+
this.logger.debug(
|
|
330
323
|
`Skipping size calculation for ${datFile}: ${error instanceof Error ? error.message : String(error)}`
|
|
331
324
|
);
|
|
332
325
|
}
|
|
333
326
|
}
|
|
334
327
|
} catch (error) {
|
|
335
|
-
logger.warn(`Failed to refresh blob stats cache: ${String(error)}`);
|
|
328
|
+
this.logger.warn(`Failed to refresh blob stats cache: ${String(error)}`);
|
|
336
329
|
}
|
|
337
330
|
this.statsCache = stats;
|
|
338
331
|
}
|
|
@@ -0,0 +1,326 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __defProp = Object.defineProperty;
|
|
3
|
+
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
4
|
+
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
5
|
+
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
6
|
+
var __export = (target, all) => {
|
|
7
|
+
for (var name in all)
|
|
8
|
+
__defProp(target, name, { get: all[name], enumerable: true });
|
|
9
|
+
};
|
|
10
|
+
var __copyProps = (to, from, except, desc) => {
|
|
11
|
+
if (from && typeof from === "object" || typeof from === "function") {
|
|
12
|
+
for (let key of __getOwnPropNames(from))
|
|
13
|
+
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
14
|
+
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
15
|
+
}
|
|
16
|
+
return to;
|
|
17
|
+
};
|
|
18
|
+
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
19
|
+
var memory_blob_store_exports = {};
|
|
20
|
+
__export(memory_blob_store_exports, {
|
|
21
|
+
InMemoryBlobStore: () => InMemoryBlobStore
|
|
22
|
+
});
|
|
23
|
+
module.exports = __toCommonJS(memory_blob_store_exports);
|
|
24
|
+
var import_crypto = require("crypto");
|
|
25
|
+
var import_stream = require("stream");
|
|
26
|
+
var import_types = require("../../logger/v2/types.js");
|
|
27
|
+
var import_errors = require("../errors.js");
|
|
28
|
+
class InMemoryBlobStore {
|
|
29
|
+
config;
|
|
30
|
+
blobs = /* @__PURE__ */ new Map();
|
|
31
|
+
connected = false;
|
|
32
|
+
logger;
|
|
33
|
+
constructor(config, logger) {
|
|
34
|
+
this.config = config;
|
|
35
|
+
this.logger = logger.createChild(import_types.DextoLogComponent.STORAGE);
|
|
36
|
+
}
|
|
37
|
+
async connect() {
|
|
38
|
+
if (this.connected) return;
|
|
39
|
+
this.connected = true;
|
|
40
|
+
this.logger.debug("InMemoryBlobStore connected");
|
|
41
|
+
}
|
|
42
|
+
async disconnect() {
|
|
43
|
+
this.blobs.clear();
|
|
44
|
+
this.connected = false;
|
|
45
|
+
this.logger.debug("InMemoryBlobStore disconnected");
|
|
46
|
+
}
|
|
47
|
+
isConnected() {
|
|
48
|
+
return this.connected;
|
|
49
|
+
}
|
|
50
|
+
getStoreType() {
|
|
51
|
+
return "in-memory";
|
|
52
|
+
}
|
|
53
|
+
async store(input, metadata = {}) {
|
|
54
|
+
if (!this.connected) {
|
|
55
|
+
throw import_errors.StorageError.blobBackendNotConnected("in-memory");
|
|
56
|
+
}
|
|
57
|
+
const buffer = await this.inputToBuffer(input);
|
|
58
|
+
if (buffer.length > this.config.maxBlobSize) {
|
|
59
|
+
throw import_errors.StorageError.blobSizeExceeded(buffer.length, this.config.maxBlobSize);
|
|
60
|
+
}
|
|
61
|
+
const hash = (0, import_crypto.createHash)("sha256").update(buffer).digest("hex").substring(0, 16);
|
|
62
|
+
const id = hash;
|
|
63
|
+
const existing = this.blobs.get(id);
|
|
64
|
+
if (existing) {
|
|
65
|
+
this.logger.debug(
|
|
66
|
+
`Blob ${id} already exists, returning existing reference (deduplication)`
|
|
67
|
+
);
|
|
68
|
+
return {
|
|
69
|
+
id,
|
|
70
|
+
uri: `blob:${id}`,
|
|
71
|
+
metadata: existing.metadata
|
|
72
|
+
};
|
|
73
|
+
}
|
|
74
|
+
const currentSize = this.getTotalSize();
|
|
75
|
+
if (currentSize + buffer.length > this.config.maxTotalSize) {
|
|
76
|
+
throw import_errors.StorageError.blobTotalSizeExceeded(
|
|
77
|
+
currentSize + buffer.length,
|
|
78
|
+
this.config.maxTotalSize
|
|
79
|
+
);
|
|
80
|
+
}
|
|
81
|
+
const storedMetadata = {
|
|
82
|
+
id,
|
|
83
|
+
mimeType: metadata.mimeType || this.detectMimeType(buffer, metadata.originalName),
|
|
84
|
+
originalName: metadata.originalName,
|
|
85
|
+
createdAt: metadata.createdAt || /* @__PURE__ */ new Date(),
|
|
86
|
+
source: metadata.source || "system",
|
|
87
|
+
size: buffer.length,
|
|
88
|
+
hash
|
|
89
|
+
};
|
|
90
|
+
this.blobs.set(id, { data: buffer, metadata: storedMetadata });
|
|
91
|
+
this.logger.debug(`Stored blob ${id} (${buffer.length} bytes, ${storedMetadata.mimeType})`);
|
|
92
|
+
return {
|
|
93
|
+
id,
|
|
94
|
+
uri: `blob:${id}`,
|
|
95
|
+
metadata: storedMetadata
|
|
96
|
+
};
|
|
97
|
+
}
|
|
98
|
+
async retrieve(reference, format = "base64") {
|
|
99
|
+
if (!this.connected) {
|
|
100
|
+
throw import_errors.StorageError.blobBackendNotConnected("in-memory");
|
|
101
|
+
}
|
|
102
|
+
const id = this.parseReference(reference);
|
|
103
|
+
const blob = this.blobs.get(id);
|
|
104
|
+
if (!blob) {
|
|
105
|
+
throw import_errors.StorageError.blobNotFound(reference);
|
|
106
|
+
}
|
|
107
|
+
switch (format) {
|
|
108
|
+
case "base64":
|
|
109
|
+
return {
|
|
110
|
+
format: "base64",
|
|
111
|
+
data: blob.data.toString("base64"),
|
|
112
|
+
metadata: blob.metadata
|
|
113
|
+
};
|
|
114
|
+
case "buffer":
|
|
115
|
+
return {
|
|
116
|
+
format: "buffer",
|
|
117
|
+
data: Buffer.from(blob.data),
|
|
118
|
+
metadata: { ...blob.metadata }
|
|
119
|
+
};
|
|
120
|
+
case "path":
|
|
121
|
+
throw new Error(
|
|
122
|
+
"Path format not supported for in-memory blobs. Use local blob storage for filesystem paths."
|
|
123
|
+
);
|
|
124
|
+
case "stream": {
|
|
125
|
+
const stream = import_stream.Readable.from(blob.data);
|
|
126
|
+
return {
|
|
127
|
+
format: "stream",
|
|
128
|
+
data: stream,
|
|
129
|
+
metadata: blob.metadata
|
|
130
|
+
};
|
|
131
|
+
}
|
|
132
|
+
case "url": {
|
|
133
|
+
const base64 = blob.data.toString("base64");
|
|
134
|
+
const mimeType = blob.metadata.mimeType || "application/octet-stream";
|
|
135
|
+
const dataUrl = `data:${mimeType};base64,${base64}`;
|
|
136
|
+
return {
|
|
137
|
+
format: "url",
|
|
138
|
+
data: dataUrl,
|
|
139
|
+
metadata: blob.metadata
|
|
140
|
+
};
|
|
141
|
+
}
|
|
142
|
+
default:
|
|
143
|
+
throw import_errors.StorageError.blobInvalidInput(format, `Unsupported format: ${format}`);
|
|
144
|
+
}
|
|
145
|
+
}
|
|
146
|
+
async exists(reference) {
|
|
147
|
+
if (!this.connected) {
|
|
148
|
+
throw import_errors.StorageError.blobBackendNotConnected("in-memory");
|
|
149
|
+
}
|
|
150
|
+
const id = this.parseReference(reference);
|
|
151
|
+
return this.blobs.has(id);
|
|
152
|
+
}
|
|
153
|
+
async delete(reference) {
|
|
154
|
+
if (!this.connected) {
|
|
155
|
+
throw import_errors.StorageError.blobBackendNotConnected("in-memory");
|
|
156
|
+
}
|
|
157
|
+
const id = this.parseReference(reference);
|
|
158
|
+
if (!this.blobs.has(id)) {
|
|
159
|
+
throw import_errors.StorageError.blobNotFound(reference);
|
|
160
|
+
}
|
|
161
|
+
this.blobs.delete(id);
|
|
162
|
+
this.logger.debug(`Deleted blob: ${id}`);
|
|
163
|
+
}
|
|
164
|
+
async cleanup(olderThan) {
|
|
165
|
+
if (!this.connected) {
|
|
166
|
+
throw import_errors.StorageError.blobBackendNotConnected("in-memory");
|
|
167
|
+
}
|
|
168
|
+
const cutoffDate = olderThan || new Date(Date.now() - 30 * 24 * 60 * 60 * 1e3);
|
|
169
|
+
let deletedCount = 0;
|
|
170
|
+
for (const [id, { metadata }] of this.blobs.entries()) {
|
|
171
|
+
if (metadata.createdAt < cutoffDate) {
|
|
172
|
+
this.blobs.delete(id);
|
|
173
|
+
deletedCount++;
|
|
174
|
+
this.logger.debug(`Cleaned up old blob: ${id}`);
|
|
175
|
+
}
|
|
176
|
+
}
|
|
177
|
+
if (deletedCount > 0) {
|
|
178
|
+
this.logger.info(`Blob cleanup: removed ${deletedCount} old blobs from memory`);
|
|
179
|
+
}
|
|
180
|
+
return deletedCount;
|
|
181
|
+
}
|
|
182
|
+
async getStats() {
|
|
183
|
+
if (!this.connected) {
|
|
184
|
+
throw import_errors.StorageError.blobBackendNotConnected("in-memory");
|
|
185
|
+
}
|
|
186
|
+
return {
|
|
187
|
+
count: this.blobs.size,
|
|
188
|
+
totalSize: this.getTotalSize(),
|
|
189
|
+
backendType: "in-memory",
|
|
190
|
+
storePath: "memory://"
|
|
191
|
+
};
|
|
192
|
+
}
|
|
193
|
+
async listBlobs() {
|
|
194
|
+
if (!this.connected) {
|
|
195
|
+
throw import_errors.StorageError.blobBackendNotConnected("in-memory");
|
|
196
|
+
}
|
|
197
|
+
return Array.from(this.blobs.entries()).map(([id, { metadata }]) => ({
|
|
198
|
+
id,
|
|
199
|
+
uri: `blob:${id}`,
|
|
200
|
+
metadata
|
|
201
|
+
}));
|
|
202
|
+
}
|
|
203
|
+
getStoragePath() {
|
|
204
|
+
return void 0;
|
|
205
|
+
}
|
|
206
|
+
/**
|
|
207
|
+
* Calculate total size of all blobs in memory
|
|
208
|
+
*/
|
|
209
|
+
getTotalSize() {
|
|
210
|
+
return Array.from(this.blobs.values()).reduce((sum, { data }) => sum + data.length, 0);
|
|
211
|
+
}
|
|
212
|
+
/**
|
|
213
|
+
* Convert various input types to Buffer.
|
|
214
|
+
* Copied from LocalBlobStore with minor adaptations.
|
|
215
|
+
*/
|
|
216
|
+
async inputToBuffer(input) {
|
|
217
|
+
if (Buffer.isBuffer(input)) {
|
|
218
|
+
return input;
|
|
219
|
+
}
|
|
220
|
+
if (input instanceof Uint8Array) {
|
|
221
|
+
return Buffer.from(input);
|
|
222
|
+
}
|
|
223
|
+
if (input instanceof ArrayBuffer) {
|
|
224
|
+
return Buffer.from(new Uint8Array(input));
|
|
225
|
+
}
|
|
226
|
+
if (typeof input === "string") {
|
|
227
|
+
if (input.startsWith("data:")) {
|
|
228
|
+
const commaIndex = input.indexOf(",");
|
|
229
|
+
if (commaIndex !== -1 && input.includes(";base64,")) {
|
|
230
|
+
const base64Data = input.substring(commaIndex + 1);
|
|
231
|
+
return Buffer.from(base64Data, "base64");
|
|
232
|
+
}
|
|
233
|
+
throw import_errors.StorageError.blobEncodingError(
|
|
234
|
+
"inputToBuffer",
|
|
235
|
+
"Unsupported data URI format"
|
|
236
|
+
);
|
|
237
|
+
}
|
|
238
|
+
try {
|
|
239
|
+
return Buffer.from(input, "base64");
|
|
240
|
+
} catch {
|
|
241
|
+
throw import_errors.StorageError.blobEncodingError("inputToBuffer", "Invalid base64 string");
|
|
242
|
+
}
|
|
243
|
+
}
|
|
244
|
+
throw import_errors.StorageError.blobInvalidInput(input, `Unsupported input type: ${typeof input}`);
|
|
245
|
+
}
|
|
246
|
+
/**
|
|
247
|
+
* Parse blob reference to extract ID.
|
|
248
|
+
* Copied from LocalBlobStore.
|
|
249
|
+
*/
|
|
250
|
+
parseReference(reference) {
|
|
251
|
+
if (!reference) {
|
|
252
|
+
throw import_errors.StorageError.blobInvalidReference(reference, "Empty reference");
|
|
253
|
+
}
|
|
254
|
+
if (reference.startsWith("blob:")) {
|
|
255
|
+
const id = reference.substring(5);
|
|
256
|
+
if (!id) {
|
|
257
|
+
throw import_errors.StorageError.blobInvalidReference(reference, "Empty blob ID after prefix");
|
|
258
|
+
}
|
|
259
|
+
return id;
|
|
260
|
+
}
|
|
261
|
+
return reference;
|
|
262
|
+
}
|
|
263
|
+
/**
|
|
264
|
+
* Detect MIME type from buffer content and/or filename.
|
|
265
|
+
* Copied from LocalBlobStore.
|
|
266
|
+
*/
|
|
267
|
+
detectMimeType(buffer, filename) {
|
|
268
|
+
const header = buffer.subarray(0, 16);
|
|
269
|
+
if (header.length >= 3) {
|
|
270
|
+
const jpegSignature = header.subarray(0, 3);
|
|
271
|
+
if (jpegSignature.equals(Buffer.from([255, 216, 255]))) {
|
|
272
|
+
return "image/jpeg";
|
|
273
|
+
}
|
|
274
|
+
}
|
|
275
|
+
if (header.length >= 4) {
|
|
276
|
+
const signature = header.subarray(0, 4);
|
|
277
|
+
if (signature.equals(Buffer.from([137, 80, 78, 71]))) return "image/png";
|
|
278
|
+
if (signature.equals(Buffer.from([71, 73, 70, 56]))) return "image/gif";
|
|
279
|
+
if (signature.equals(Buffer.from([37, 80, 68, 70]))) return "application/pdf";
|
|
280
|
+
}
|
|
281
|
+
if (filename) {
|
|
282
|
+
const ext = filename.split(".").pop()?.toLowerCase();
|
|
283
|
+
const mimeTypes = {
|
|
284
|
+
jpg: "image/jpeg",
|
|
285
|
+
jpeg: "image/jpeg",
|
|
286
|
+
png: "image/png",
|
|
287
|
+
gif: "image/gif",
|
|
288
|
+
pdf: "application/pdf",
|
|
289
|
+
txt: "text/plain",
|
|
290
|
+
json: "application/json",
|
|
291
|
+
xml: "text/xml",
|
|
292
|
+
html: "text/html",
|
|
293
|
+
css: "text/css",
|
|
294
|
+
js: "text/javascript",
|
|
295
|
+
md: "text/markdown",
|
|
296
|
+
mp3: "audio/mpeg",
|
|
297
|
+
mp4: "video/mp4",
|
|
298
|
+
wav: "audio/wav"
|
|
299
|
+
};
|
|
300
|
+
if (ext && mimeTypes[ext]) return mimeTypes[ext];
|
|
301
|
+
}
|
|
302
|
+
if (this.isTextBuffer(buffer)) {
|
|
303
|
+
return "text/plain";
|
|
304
|
+
}
|
|
305
|
+
return "application/octet-stream";
|
|
306
|
+
}
|
|
307
|
+
/**
|
|
308
|
+
* Check if buffer contains text content.
|
|
309
|
+
* Copied from LocalBlobStore.
|
|
310
|
+
*/
|
|
311
|
+
isTextBuffer(buffer) {
|
|
312
|
+
let printableCount = 0;
|
|
313
|
+
const sampleSize = Math.min(512, buffer.length);
|
|
314
|
+
for (let i = 0; i < sampleSize; i++) {
|
|
315
|
+
const byte = buffer[i];
|
|
316
|
+
if (byte !== void 0 && (byte >= 32 && byte <= 126 || byte === 9 || byte === 10 || byte === 13)) {
|
|
317
|
+
printableCount++;
|
|
318
|
+
}
|
|
319
|
+
}
|
|
320
|
+
return printableCount / sampleSize > 0.7;
|
|
321
|
+
}
|
|
322
|
+
}
|
|
323
|
+
// Annotate the CommonJS export names for ESM import in node:
|
|
324
|
+
0 && (module.exports = {
|
|
325
|
+
InMemoryBlobStore
|
|
326
|
+
});
|
|
@@ -0,0 +1,66 @@
|
|
|
1
|
+
import type { IDextoLogger } from '../../logger/v2/types.js';
|
|
2
|
+
import type { BlobStore, BlobInput, BlobMetadata, BlobReference, BlobData, BlobStats } from './types.js';
|
|
3
|
+
import type { InMemoryBlobStoreConfig } from './schemas.js';
|
|
4
|
+
/**
|
|
5
|
+
* In-memory blob store implementation.
|
|
6
|
+
*
|
|
7
|
+
* Stores blobs in memory with content-based deduplication and size limits.
|
|
8
|
+
* Suitable for development, testing, and scenarios where blob persistence
|
|
9
|
+
* across restarts is not required.
|
|
10
|
+
*
|
|
11
|
+
* Features:
|
|
12
|
+
* - Content-based deduplication (same as LocalBlobStore)
|
|
13
|
+
* - Configurable size limits (per-blob and total)
|
|
14
|
+
* - Automatic cleanup of old blobs
|
|
15
|
+
* - MIME type detection
|
|
16
|
+
* - Multi-format retrieval (base64, buffer, stream, data URI)
|
|
17
|
+
*
|
|
18
|
+
* Limitations:
|
|
19
|
+
* - Data lost on restart (no persistence)
|
|
20
|
+
* - Path format not supported (no filesystem)
|
|
21
|
+
* - Memory usage proportional to blob size
|
|
22
|
+
*/
|
|
23
|
+
export declare class InMemoryBlobStore implements BlobStore {
|
|
24
|
+
private config;
|
|
25
|
+
private blobs;
|
|
26
|
+
private connected;
|
|
27
|
+
private logger;
|
|
28
|
+
constructor(config: InMemoryBlobStoreConfig, logger: IDextoLogger);
|
|
29
|
+
connect(): Promise<void>;
|
|
30
|
+
disconnect(): Promise<void>;
|
|
31
|
+
isConnected(): boolean;
|
|
32
|
+
getStoreType(): string;
|
|
33
|
+
store(input: BlobInput, metadata?: BlobMetadata): Promise<BlobReference>;
|
|
34
|
+
retrieve(reference: string, format?: 'base64' | 'buffer' | 'path' | 'stream' | 'url'): Promise<BlobData>;
|
|
35
|
+
exists(reference: string): Promise<boolean>;
|
|
36
|
+
delete(reference: string): Promise<void>;
|
|
37
|
+
cleanup(olderThan?: Date): Promise<number>;
|
|
38
|
+
getStats(): Promise<BlobStats>;
|
|
39
|
+
listBlobs(): Promise<BlobReference[]>;
|
|
40
|
+
getStoragePath(): string | undefined;
|
|
41
|
+
/**
|
|
42
|
+
* Calculate total size of all blobs in memory
|
|
43
|
+
*/
|
|
44
|
+
private getTotalSize;
|
|
45
|
+
/**
|
|
46
|
+
* Convert various input types to Buffer.
|
|
47
|
+
* Copied from LocalBlobStore with minor adaptations.
|
|
48
|
+
*/
|
|
49
|
+
private inputToBuffer;
|
|
50
|
+
/**
|
|
51
|
+
* Parse blob reference to extract ID.
|
|
52
|
+
* Copied from LocalBlobStore.
|
|
53
|
+
*/
|
|
54
|
+
private parseReference;
|
|
55
|
+
/**
|
|
56
|
+
* Detect MIME type from buffer content and/or filename.
|
|
57
|
+
* Copied from LocalBlobStore.
|
|
58
|
+
*/
|
|
59
|
+
private detectMimeType;
|
|
60
|
+
/**
|
|
61
|
+
* Check if buffer contains text content.
|
|
62
|
+
* Copied from LocalBlobStore.
|
|
63
|
+
*/
|
|
64
|
+
private isTextBuffer;
|
|
65
|
+
}
|
|
66
|
+
//# sourceMappingURL=memory-blob-store.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"memory-blob-store.d.ts","sourceRoot":"","sources":["../../../src/storage/blob/memory-blob-store.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,0BAA0B,CAAC;AAG7D,OAAO,KAAK,EACR,SAAS,EACT,SAAS,EACT,YAAY,EACZ,aAAa,EACb,QAAQ,EACR,SAAS,EAEZ,MAAM,YAAY,CAAC;AACpB,OAAO,KAAK,EAAE,uBAAuB,EAAE,MAAM,cAAc,CAAC;AAE5D;;;;;;;;;;;;;;;;;;GAkBG;AACH,qBAAa,iBAAkB,YAAW,SAAS;IAC/C,OAAO,CAAC,MAAM,CAA0B;IACxC,OAAO,CAAC,KAAK,CAA0E;IACvF,OAAO,CAAC,SAAS,CAAS;IAC1B,OAAO,CAAC,MAAM,CAAe;gBAEjB,MAAM,EAAE,uBAAuB,EAAE,MAAM,EAAE,YAAY;IAK3D,OAAO,IAAI,OAAO,CAAC,IAAI,CAAC;IAMxB,UAAU,IAAI,OAAO,CAAC,IAAI,CAAC;IAOjC,WAAW,IAAI,OAAO;IAItB,YAAY,IAAI,MAAM;IAIhB,KAAK,CAAC,KAAK,EAAE,SAAS,EAAE,QAAQ,GAAE,YAAiB,GAAG,OAAO,CAAC,aAAa,CAAC;IA8D5E,QAAQ,CACV,SAAS,EAAE,MAAM,EACjB,MAAM,GAAE,QAAQ,GAAG,QAAQ,GAAG,MAAM,GAAG,QAAQ,GAAG,KAAgB,GACnE,OAAO,CAAC,QAAQ,CAAC;IA6Dd,MAAM,CAAC,SAAS,EAAE,MAAM,GAAG,OAAO,CAAC,OAAO,CAAC;IAS3C,MAAM,CAAC,SAAS,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAexC,OAAO,CAAC,SAAS,CAAC,EAAE,IAAI,GAAG,OAAO,CAAC,MAAM,CAAC;IAwB1C,QAAQ,IAAI,OAAO,CAAC,SAAS,CAAC;IAc9B,SAAS,IAAI,OAAO,CAAC,aAAa,EAAE,CAAC;IAY3C,cAAc,IAAI,MAAM,GAAG,SAAS;IAKpC;;OAEG;IACH,OAAO,CAAC,YAAY;IAIpB;;;OAGG;YACW,aAAa;IAuC3B;;;OAGG;IACH,OAAO,CAAC,cAAc;IAgBtB;;;OAGG;IACH,OAAO,CAAC,cAAc;IAkDtB;;;OAGG;IACH,OAAO,CAAC,YAAY;CAiBvB"}
|