@dexto/core 1.2.4 → 1.2.5
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 +164 -64
- package/dist/agent/schemas.d.ts +2605 -517
- package/dist/agent/schemas.d.ts.map +1 -1
- package/dist/agent/schemas.js +167 -64
- 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/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.d.ts +6 -6
- 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/prompt-manager.cjs +25 -18
- 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 -18
- 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/file-prompt-provider.cjs +14 -12
- package/dist/prompts/providers/file-prompt-provider.d.ts +3 -1
- package/dist/prompts/providers/file-prompt-provider.d.ts.map +1 -1
- package/dist/prompts/providers/file-prompt-provider.js +14 -12
- 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/providers/starter-prompt-provider.cjs +7 -5
- package/dist/prompts/providers/starter-prompt-provider.d.ts +3 -1
- package/dist/prompts/providers/starter-prompt-provider.d.ts.map +1 -1
- package/dist/prompts/providers/starter-prompt-provider.js +7 -5
- package/dist/prompts/schemas.d.ts +3 -3
- 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/manager.cjs +11 -8
- package/dist/systemPrompt/manager.d.ts +4 -2
- package/dist/systemPrompt/manager.d.ts.map +1 -1
- package/dist/systemPrompt/manager.js +11 -8
- package/dist/systemPrompt/schemas.cjs +21 -1
- package/dist/systemPrompt/schemas.d.ts +53 -53
- package/dist/systemPrompt/schemas.d.ts.map +1 -1
- package/dist/systemPrompt/schemas.js +11 -1
- 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 +87 -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 +69 -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/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
|
@@ -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"}
|
|
@@ -0,0 +1,303 @@
|
|
|
1
|
+
import "../../chunk-C6A6W6XS.js";
|
|
2
|
+
import { createHash } from "crypto";
|
|
3
|
+
import { Readable } from "stream";
|
|
4
|
+
import { DextoLogComponent } from "../../logger/v2/types.js";
|
|
5
|
+
import { StorageError } from "../errors.js";
|
|
6
|
+
class InMemoryBlobStore {
|
|
7
|
+
config;
|
|
8
|
+
blobs = /* @__PURE__ */ new Map();
|
|
9
|
+
connected = false;
|
|
10
|
+
logger;
|
|
11
|
+
constructor(config, logger) {
|
|
12
|
+
this.config = config;
|
|
13
|
+
this.logger = logger.createChild(DextoLogComponent.STORAGE);
|
|
14
|
+
}
|
|
15
|
+
async connect() {
|
|
16
|
+
if (this.connected) return;
|
|
17
|
+
this.connected = true;
|
|
18
|
+
this.logger.debug("InMemoryBlobStore connected");
|
|
19
|
+
}
|
|
20
|
+
async disconnect() {
|
|
21
|
+
this.blobs.clear();
|
|
22
|
+
this.connected = false;
|
|
23
|
+
this.logger.debug("InMemoryBlobStore disconnected");
|
|
24
|
+
}
|
|
25
|
+
isConnected() {
|
|
26
|
+
return this.connected;
|
|
27
|
+
}
|
|
28
|
+
getStoreType() {
|
|
29
|
+
return "in-memory";
|
|
30
|
+
}
|
|
31
|
+
async store(input, metadata = {}) {
|
|
32
|
+
if (!this.connected) {
|
|
33
|
+
throw StorageError.blobBackendNotConnected("in-memory");
|
|
34
|
+
}
|
|
35
|
+
const buffer = await this.inputToBuffer(input);
|
|
36
|
+
if (buffer.length > this.config.maxBlobSize) {
|
|
37
|
+
throw StorageError.blobSizeExceeded(buffer.length, this.config.maxBlobSize);
|
|
38
|
+
}
|
|
39
|
+
const hash = createHash("sha256").update(buffer).digest("hex").substring(0, 16);
|
|
40
|
+
const id = hash;
|
|
41
|
+
const existing = this.blobs.get(id);
|
|
42
|
+
if (existing) {
|
|
43
|
+
this.logger.debug(
|
|
44
|
+
`Blob ${id} already exists, returning existing reference (deduplication)`
|
|
45
|
+
);
|
|
46
|
+
return {
|
|
47
|
+
id,
|
|
48
|
+
uri: `blob:${id}`,
|
|
49
|
+
metadata: existing.metadata
|
|
50
|
+
};
|
|
51
|
+
}
|
|
52
|
+
const currentSize = this.getTotalSize();
|
|
53
|
+
if (currentSize + buffer.length > this.config.maxTotalSize) {
|
|
54
|
+
throw StorageError.blobTotalSizeExceeded(
|
|
55
|
+
currentSize + buffer.length,
|
|
56
|
+
this.config.maxTotalSize
|
|
57
|
+
);
|
|
58
|
+
}
|
|
59
|
+
const storedMetadata = {
|
|
60
|
+
id,
|
|
61
|
+
mimeType: metadata.mimeType || this.detectMimeType(buffer, metadata.originalName),
|
|
62
|
+
originalName: metadata.originalName,
|
|
63
|
+
createdAt: metadata.createdAt || /* @__PURE__ */ new Date(),
|
|
64
|
+
source: metadata.source || "system",
|
|
65
|
+
size: buffer.length,
|
|
66
|
+
hash
|
|
67
|
+
};
|
|
68
|
+
this.blobs.set(id, { data: buffer, metadata: storedMetadata });
|
|
69
|
+
this.logger.debug(`Stored blob ${id} (${buffer.length} bytes, ${storedMetadata.mimeType})`);
|
|
70
|
+
return {
|
|
71
|
+
id,
|
|
72
|
+
uri: `blob:${id}`,
|
|
73
|
+
metadata: storedMetadata
|
|
74
|
+
};
|
|
75
|
+
}
|
|
76
|
+
async retrieve(reference, format = "base64") {
|
|
77
|
+
if (!this.connected) {
|
|
78
|
+
throw StorageError.blobBackendNotConnected("in-memory");
|
|
79
|
+
}
|
|
80
|
+
const id = this.parseReference(reference);
|
|
81
|
+
const blob = this.blobs.get(id);
|
|
82
|
+
if (!blob) {
|
|
83
|
+
throw StorageError.blobNotFound(reference);
|
|
84
|
+
}
|
|
85
|
+
switch (format) {
|
|
86
|
+
case "base64":
|
|
87
|
+
return {
|
|
88
|
+
format: "base64",
|
|
89
|
+
data: blob.data.toString("base64"),
|
|
90
|
+
metadata: blob.metadata
|
|
91
|
+
};
|
|
92
|
+
case "buffer":
|
|
93
|
+
return {
|
|
94
|
+
format: "buffer",
|
|
95
|
+
data: Buffer.from(blob.data),
|
|
96
|
+
metadata: { ...blob.metadata }
|
|
97
|
+
};
|
|
98
|
+
case "path":
|
|
99
|
+
throw new Error(
|
|
100
|
+
"Path format not supported for in-memory blobs. Use local blob storage for filesystem paths."
|
|
101
|
+
);
|
|
102
|
+
case "stream": {
|
|
103
|
+
const stream = Readable.from(blob.data);
|
|
104
|
+
return {
|
|
105
|
+
format: "stream",
|
|
106
|
+
data: stream,
|
|
107
|
+
metadata: blob.metadata
|
|
108
|
+
};
|
|
109
|
+
}
|
|
110
|
+
case "url": {
|
|
111
|
+
const base64 = blob.data.toString("base64");
|
|
112
|
+
const mimeType = blob.metadata.mimeType || "application/octet-stream";
|
|
113
|
+
const dataUrl = `data:${mimeType};base64,${base64}`;
|
|
114
|
+
return {
|
|
115
|
+
format: "url",
|
|
116
|
+
data: dataUrl,
|
|
117
|
+
metadata: blob.metadata
|
|
118
|
+
};
|
|
119
|
+
}
|
|
120
|
+
default:
|
|
121
|
+
throw StorageError.blobInvalidInput(format, `Unsupported format: ${format}`);
|
|
122
|
+
}
|
|
123
|
+
}
|
|
124
|
+
async exists(reference) {
|
|
125
|
+
if (!this.connected) {
|
|
126
|
+
throw StorageError.blobBackendNotConnected("in-memory");
|
|
127
|
+
}
|
|
128
|
+
const id = this.parseReference(reference);
|
|
129
|
+
return this.blobs.has(id);
|
|
130
|
+
}
|
|
131
|
+
async delete(reference) {
|
|
132
|
+
if (!this.connected) {
|
|
133
|
+
throw StorageError.blobBackendNotConnected("in-memory");
|
|
134
|
+
}
|
|
135
|
+
const id = this.parseReference(reference);
|
|
136
|
+
if (!this.blobs.has(id)) {
|
|
137
|
+
throw StorageError.blobNotFound(reference);
|
|
138
|
+
}
|
|
139
|
+
this.blobs.delete(id);
|
|
140
|
+
this.logger.debug(`Deleted blob: ${id}`);
|
|
141
|
+
}
|
|
142
|
+
async cleanup(olderThan) {
|
|
143
|
+
if (!this.connected) {
|
|
144
|
+
throw StorageError.blobBackendNotConnected("in-memory");
|
|
145
|
+
}
|
|
146
|
+
const cutoffDate = olderThan || new Date(Date.now() - 30 * 24 * 60 * 60 * 1e3);
|
|
147
|
+
let deletedCount = 0;
|
|
148
|
+
for (const [id, { metadata }] of this.blobs.entries()) {
|
|
149
|
+
if (metadata.createdAt < cutoffDate) {
|
|
150
|
+
this.blobs.delete(id);
|
|
151
|
+
deletedCount++;
|
|
152
|
+
this.logger.debug(`Cleaned up old blob: ${id}`);
|
|
153
|
+
}
|
|
154
|
+
}
|
|
155
|
+
if (deletedCount > 0) {
|
|
156
|
+
this.logger.info(`Blob cleanup: removed ${deletedCount} old blobs from memory`);
|
|
157
|
+
}
|
|
158
|
+
return deletedCount;
|
|
159
|
+
}
|
|
160
|
+
async getStats() {
|
|
161
|
+
if (!this.connected) {
|
|
162
|
+
throw StorageError.blobBackendNotConnected("in-memory");
|
|
163
|
+
}
|
|
164
|
+
return {
|
|
165
|
+
count: this.blobs.size,
|
|
166
|
+
totalSize: this.getTotalSize(),
|
|
167
|
+
backendType: "in-memory",
|
|
168
|
+
storePath: "memory://"
|
|
169
|
+
};
|
|
170
|
+
}
|
|
171
|
+
async listBlobs() {
|
|
172
|
+
if (!this.connected) {
|
|
173
|
+
throw StorageError.blobBackendNotConnected("in-memory");
|
|
174
|
+
}
|
|
175
|
+
return Array.from(this.blobs.entries()).map(([id, { metadata }]) => ({
|
|
176
|
+
id,
|
|
177
|
+
uri: `blob:${id}`,
|
|
178
|
+
metadata
|
|
179
|
+
}));
|
|
180
|
+
}
|
|
181
|
+
getStoragePath() {
|
|
182
|
+
return void 0;
|
|
183
|
+
}
|
|
184
|
+
/**
|
|
185
|
+
* Calculate total size of all blobs in memory
|
|
186
|
+
*/
|
|
187
|
+
getTotalSize() {
|
|
188
|
+
return Array.from(this.blobs.values()).reduce((sum, { data }) => sum + data.length, 0);
|
|
189
|
+
}
|
|
190
|
+
/**
|
|
191
|
+
* Convert various input types to Buffer.
|
|
192
|
+
* Copied from LocalBlobStore with minor adaptations.
|
|
193
|
+
*/
|
|
194
|
+
async inputToBuffer(input) {
|
|
195
|
+
if (Buffer.isBuffer(input)) {
|
|
196
|
+
return input;
|
|
197
|
+
}
|
|
198
|
+
if (input instanceof Uint8Array) {
|
|
199
|
+
return Buffer.from(input);
|
|
200
|
+
}
|
|
201
|
+
if (input instanceof ArrayBuffer) {
|
|
202
|
+
return Buffer.from(new Uint8Array(input));
|
|
203
|
+
}
|
|
204
|
+
if (typeof input === "string") {
|
|
205
|
+
if (input.startsWith("data:")) {
|
|
206
|
+
const commaIndex = input.indexOf(",");
|
|
207
|
+
if (commaIndex !== -1 && input.includes(";base64,")) {
|
|
208
|
+
const base64Data = input.substring(commaIndex + 1);
|
|
209
|
+
return Buffer.from(base64Data, "base64");
|
|
210
|
+
}
|
|
211
|
+
throw StorageError.blobEncodingError(
|
|
212
|
+
"inputToBuffer",
|
|
213
|
+
"Unsupported data URI format"
|
|
214
|
+
);
|
|
215
|
+
}
|
|
216
|
+
try {
|
|
217
|
+
return Buffer.from(input, "base64");
|
|
218
|
+
} catch {
|
|
219
|
+
throw StorageError.blobEncodingError("inputToBuffer", "Invalid base64 string");
|
|
220
|
+
}
|
|
221
|
+
}
|
|
222
|
+
throw StorageError.blobInvalidInput(input, `Unsupported input type: ${typeof input}`);
|
|
223
|
+
}
|
|
224
|
+
/**
|
|
225
|
+
* Parse blob reference to extract ID.
|
|
226
|
+
* Copied from LocalBlobStore.
|
|
227
|
+
*/
|
|
228
|
+
parseReference(reference) {
|
|
229
|
+
if (!reference) {
|
|
230
|
+
throw StorageError.blobInvalidReference(reference, "Empty reference");
|
|
231
|
+
}
|
|
232
|
+
if (reference.startsWith("blob:")) {
|
|
233
|
+
const id = reference.substring(5);
|
|
234
|
+
if (!id) {
|
|
235
|
+
throw StorageError.blobInvalidReference(reference, "Empty blob ID after prefix");
|
|
236
|
+
}
|
|
237
|
+
return id;
|
|
238
|
+
}
|
|
239
|
+
return reference;
|
|
240
|
+
}
|
|
241
|
+
/**
|
|
242
|
+
* Detect MIME type from buffer content and/or filename.
|
|
243
|
+
* Copied from LocalBlobStore.
|
|
244
|
+
*/
|
|
245
|
+
detectMimeType(buffer, filename) {
|
|
246
|
+
const header = buffer.subarray(0, 16);
|
|
247
|
+
if (header.length >= 3) {
|
|
248
|
+
const jpegSignature = header.subarray(0, 3);
|
|
249
|
+
if (jpegSignature.equals(Buffer.from([255, 216, 255]))) {
|
|
250
|
+
return "image/jpeg";
|
|
251
|
+
}
|
|
252
|
+
}
|
|
253
|
+
if (header.length >= 4) {
|
|
254
|
+
const signature = header.subarray(0, 4);
|
|
255
|
+
if (signature.equals(Buffer.from([137, 80, 78, 71]))) return "image/png";
|
|
256
|
+
if (signature.equals(Buffer.from([71, 73, 70, 56]))) return "image/gif";
|
|
257
|
+
if (signature.equals(Buffer.from([37, 80, 68, 70]))) return "application/pdf";
|
|
258
|
+
}
|
|
259
|
+
if (filename) {
|
|
260
|
+
const ext = filename.split(".").pop()?.toLowerCase();
|
|
261
|
+
const mimeTypes = {
|
|
262
|
+
jpg: "image/jpeg",
|
|
263
|
+
jpeg: "image/jpeg",
|
|
264
|
+
png: "image/png",
|
|
265
|
+
gif: "image/gif",
|
|
266
|
+
pdf: "application/pdf",
|
|
267
|
+
txt: "text/plain",
|
|
268
|
+
json: "application/json",
|
|
269
|
+
xml: "text/xml",
|
|
270
|
+
html: "text/html",
|
|
271
|
+
css: "text/css",
|
|
272
|
+
js: "text/javascript",
|
|
273
|
+
md: "text/markdown",
|
|
274
|
+
mp3: "audio/mpeg",
|
|
275
|
+
mp4: "video/mp4",
|
|
276
|
+
wav: "audio/wav"
|
|
277
|
+
};
|
|
278
|
+
if (ext && mimeTypes[ext]) return mimeTypes[ext];
|
|
279
|
+
}
|
|
280
|
+
if (this.isTextBuffer(buffer)) {
|
|
281
|
+
return "text/plain";
|
|
282
|
+
}
|
|
283
|
+
return "application/octet-stream";
|
|
284
|
+
}
|
|
285
|
+
/**
|
|
286
|
+
* Check if buffer contains text content.
|
|
287
|
+
* Copied from LocalBlobStore.
|
|
288
|
+
*/
|
|
289
|
+
isTextBuffer(buffer) {
|
|
290
|
+
let printableCount = 0;
|
|
291
|
+
const sampleSize = Math.min(512, buffer.length);
|
|
292
|
+
for (let i = 0; i < sampleSize; i++) {
|
|
293
|
+
const byte = buffer[i];
|
|
294
|
+
if (byte !== void 0 && (byte >= 32 && byte <= 126 || byte === 9 || byte === 10 || byte === 13)) {
|
|
295
|
+
printableCount++;
|
|
296
|
+
}
|
|
297
|
+
}
|
|
298
|
+
return printableCount / sampleSize > 0.7;
|
|
299
|
+
}
|
|
300
|
+
}
|
|
301
|
+
export {
|
|
302
|
+
InMemoryBlobStore
|
|
303
|
+
};
|