@juspay/neurolink 9.32.0 → 9.32.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +6 -0
- package/dist/auth/anthropicOAuth.js +1 -1
- package/dist/cli/commands/proxy.js +18 -5
- package/dist/client/aiSdkAdapter.js +1 -1
- package/dist/client/index.js +137 -501
- package/dist/core/factory.js +0 -1
- package/dist/core/redisConversationMemoryManager.js +1 -1
- package/dist/features/ppt/slideGenerator.js +0 -1
- package/dist/features/ppt/utils.js +0 -1
- package/dist/lib/server/routes/claudeProxyRoutes.js +45 -9
- package/dist/mcp/elicitationProtocol.js +1 -1
- package/dist/mcp/servers/agent/directToolsServer.js +0 -1
- package/dist/providers/azureOpenai.js +1 -1
- package/dist/providers/huggingFace.js +0 -1
- package/dist/providers/openaiCompatible.js +0 -1
- package/dist/sdk/toolRegistration.js +0 -1
- package/dist/server/openapi/generator.js +1 -1
- package/dist/server/routes/claudeProxyRoutes.js +45 -9
- package/dist/types/configTypes.js +0 -5
- package/dist/types/modelTypes.js +0 -1
- package/dist/types/tools.js +0 -1
- package/dist/types/typeAliases.js +0 -1
- package/dist/types/utilities.js +1 -1
- package/dist/types/workflowTypes.js +0 -1
- package/dist/utils/providerRetry.js +0 -1
- package/dist/utils/providerUtils.js +0 -1
- package/package.json +2 -2
- package/dist/client/adapters/providerImageAdapter.js +0 -588
- package/dist/client/adapters/tts/googleTTSHandler.js +0 -344
- package/dist/client/adapters/video/directorPipeline.js +0 -516
- package/dist/client/adapters/video/ffmpegAdapter.js +0 -206
- package/dist/client/adapters/video/frameExtractor.js +0 -143
- package/dist/client/adapters/video/vertexVideoHandler.js +0 -763
- package/dist/client/adapters/video/videoAnalyzer.js +0 -238
- package/dist/client/adapters/video/videoMerger.js +0 -171
- package/dist/client/agent/directTools.js +0 -840
- package/dist/client/auth/AuthProviderFactory.js +0 -111
- package/dist/client/auth/AuthProviderRegistry.js +0 -190
- package/dist/client/auth/RequestContext.js +0 -78
- package/dist/client/auth/accountPool.js +0 -178
- package/dist/client/auth/anthropicOAuth.js +0 -974
- package/dist/client/auth/authContext.js +0 -314
- package/dist/client/auth/errors.js +0 -39
- package/dist/client/auth/index.js +0 -61
- package/dist/client/auth/middleware/AuthMiddleware.js +0 -519
- package/dist/client/auth/middleware/rateLimitByUser.js +0 -554
- package/dist/client/auth/providers/BaseAuthProvider.js +0 -723
- package/dist/client/auth/providers/CognitoProvider.js +0 -304
- package/dist/client/auth/providers/KeycloakProvider.js +0 -393
- package/dist/client/auth/providers/auth0.js +0 -274
- package/dist/client/auth/providers/betterAuth.js +0 -182
- package/dist/client/auth/providers/clerk.js +0 -317
- package/dist/client/auth/providers/custom.js +0 -112
- package/dist/client/auth/providers/firebase.js +0 -226
- package/dist/client/auth/providers/jwt.js +0 -212
- package/dist/client/auth/providers/oauth2.js +0 -303
- package/dist/client/auth/providers/supabase.js +0 -259
- package/dist/client/auth/providers/workos.js +0 -284
- package/dist/client/auth/serverBridge.js +0 -25
- package/dist/client/auth/sessionManager.js +0 -437
- package/dist/client/auth/tokenStore.js +0 -799
- package/dist/client/client/aiSdkAdapter.js +0 -487
- package/dist/client/client/auth.js +0 -473
- package/dist/client/client/errors.js +0 -552
- package/dist/client/client/httpClient.js +0 -837
- package/dist/client/client/index.js +0 -172
- package/dist/client/client/interceptors.js +0 -601
- package/dist/client/client/sseClient.js +0 -545
- package/dist/client/client/streamingClient.js +0 -917
- package/dist/client/client/wsClient.js +0 -369
- package/dist/client/config/configManager.js +0 -303
- package/dist/client/config/conversationMemory.js +0 -86
- package/dist/client/config/taskClassificationConfig.js +0 -148
- package/dist/client/constants/contextWindows.js +0 -295
- package/dist/client/constants/enums.js +0 -853
- package/dist/client/constants/index.js +0 -207
- package/dist/client/constants/performance.js +0 -389
- package/dist/client/constants/retry.js +0 -266
- package/dist/client/constants/timeouts.js +0 -182
- package/dist/client/constants/tokens.js +0 -380
- package/dist/client/constants/videoErrors.js +0 -46
- package/dist/client/context/budgetChecker.js +0 -98
- package/dist/client/context/contextCompactor.js +0 -205
- package/dist/client/context/emergencyTruncation.js +0 -88
- package/dist/client/context/errorDetection.js +0 -171
- package/dist/client/context/errors.js +0 -21
- package/dist/client/context/fileTokenBudget.js +0 -127
- package/dist/client/context/prompts/summarizationPrompt.js +0 -117
- package/dist/client/context/stages/fileReadDeduplicator.js +0 -66
- package/dist/client/context/stages/slidingWindowTruncator.js +0 -190
- package/dist/client/context/stages/structuredSummarizer.js +0 -99
- package/dist/client/context/stages/toolOutputPruner.js +0 -52
- package/dist/client/context/summarizationEngine.js +0 -136
- package/dist/client/context/toolOutputLimits.js +0 -78
- package/dist/client/context/toolPairRepair.js +0 -66
- package/dist/client/core/analytics.js +0 -88
- package/dist/client/core/baseProvider.js +0 -1385
- package/dist/client/core/constants.js +0 -140
- package/dist/client/core/conversationMemoryFactory.js +0 -141
- package/dist/client/core/conversationMemoryInitializer.js +0 -128
- package/dist/client/core/conversationMemoryManager.js +0 -344
- package/dist/client/core/dynamicModels.js +0 -358
- package/dist/client/core/evaluation.js +0 -309
- package/dist/client/core/evaluationProviders.js +0 -248
- package/dist/client/core/factory.js +0 -412
- package/dist/client/core/infrastructure/baseError.js +0 -22
- package/dist/client/core/infrastructure/baseFactory.js +0 -54
- package/dist/client/core/infrastructure/baseRegistry.js +0 -53
- package/dist/client/core/infrastructure/index.js +0 -5
- package/dist/client/core/infrastructure/retry.js +0 -20
- package/dist/client/core/infrastructure/typedEventEmitter.js +0 -23
- package/dist/client/core/modelConfiguration.js +0 -851
- package/dist/client/core/modules/GenerationHandler.js +0 -588
- package/dist/client/core/modules/MessageBuilder.js +0 -273
- package/dist/client/core/modules/StreamHandler.js +0 -185
- package/dist/client/core/modules/TelemetryHandler.js +0 -203
- package/dist/client/core/modules/ToolsManager.js +0 -499
- package/dist/client/core/modules/Utilities.js +0 -331
- package/dist/client/core/redisConversationMemoryManager.js +0 -1435
- package/dist/client/core/streamAnalytics.js +0 -131
- package/dist/client/evaluation/contextBuilder.js +0 -134
- package/dist/client/evaluation/index.js +0 -61
- package/dist/client/evaluation/prompts.js +0 -73
- package/dist/client/evaluation/ragasEvaluator.js +0 -110
- package/dist/client/evaluation/retryManager.js +0 -78
- package/dist/client/evaluation/scoring.js +0 -61
- package/dist/client/factories/providerFactory.js +0 -166
- package/dist/client/factories/providerRegistry.js +0 -166
- package/dist/client/features/ppt/constants.js +0 -896
- package/dist/client/features/ppt/contentPlanner.js +0 -529
- package/dist/client/features/ppt/presentationOrchestrator.js +0 -236
- package/dist/client/features/ppt/slideGenerator.js +0 -532
- package/dist/client/features/ppt/slideRenderers.js +0 -2383
- package/dist/client/features/ppt/slideTypeInference.js +0 -405
- package/dist/client/features/ppt/types.js +0 -13
- package/dist/client/features/ppt/utils.js +0 -443
- package/dist/client/files/fileReferenceRegistry.js +0 -1543
- package/dist/client/files/fileTools.js +0 -450
- package/dist/client/files/streamingReader.js +0 -321
- package/dist/client/files/types.js +0 -23
- package/dist/client/hitl/hitlErrors.js +0 -54
- package/dist/client/hitl/hitlManager.js +0 -460
- package/dist/client/mcp/agentExposure.js +0 -356
- package/dist/client/mcp/auth/index.js +0 -11
- package/dist/client/mcp/auth/oauthClientProvider.js +0 -325
- package/dist/client/mcp/auth/tokenStorage.js +0 -134
- package/dist/client/mcp/batching/index.js +0 -10
- package/dist/client/mcp/batching/requestBatcher.js +0 -441
- package/dist/client/mcp/caching/index.js +0 -10
- package/dist/client/mcp/caching/toolCache.js +0 -433
- package/dist/client/mcp/elicitation/elicitationManager.js +0 -376
- package/dist/client/mcp/elicitation/index.js +0 -11
- package/dist/client/mcp/elicitation/types.js +0 -10
- package/dist/client/mcp/elicitationProtocol.js +0 -375
- package/dist/client/mcp/enhancedToolDiscovery.js +0 -481
- package/dist/client/mcp/externalServerManager.js +0 -1478
- package/dist/client/mcp/factory.js +0 -161
- package/dist/client/mcp/flexibleToolValidator.js +0 -161
- package/dist/client/mcp/httpRateLimiter.js +0 -391
- package/dist/client/mcp/httpRetryHandler.js +0 -178
- package/dist/client/mcp/index.js +0 -74
- package/dist/client/mcp/mcpCircuitBreaker.js +0 -427
- package/dist/client/mcp/mcpClientFactory.js +0 -708
- package/dist/client/mcp/mcpRegistryClient.js +0 -488
- package/dist/client/mcp/mcpServerBase.js +0 -373
- package/dist/client/mcp/multiServerManager.js +0 -579
- package/dist/client/mcp/registry.js +0 -158
- package/dist/client/mcp/routing/index.js +0 -10
- package/dist/client/mcp/routing/toolRouter.js +0 -416
- package/dist/client/mcp/serverCapabilities.js +0 -502
- package/dist/client/mcp/servers/agent/directToolsServer.js +0 -150
- package/dist/client/mcp/toolAnnotations.js +0 -239
- package/dist/client/mcp/toolConverter.js +0 -258
- package/dist/client/mcp/toolDiscoveryService.js +0 -798
- package/dist/client/mcp/toolIntegration.js +0 -334
- package/dist/client/mcp/toolRegistry.js +0 -729
- package/dist/client/memory/hippocampusInitializer.js +0 -19
- package/dist/client/memory/memoryRetrievalTools.js +0 -166
- package/dist/client/middleware/builtin/analytics.js +0 -132
- package/dist/client/middleware/builtin/autoEvaluation.js +0 -203
- package/dist/client/middleware/builtin/guardrails.js +0 -109
- package/dist/client/middleware/builtin/lifecycle.js +0 -168
- package/dist/client/middleware/factory.js +0 -327
- package/dist/client/middleware/registry.js +0 -295
- package/dist/client/middleware/utils/guardrailsUtils.js +0 -396
- package/dist/client/models/anthropicModels.js +0 -527
- package/dist/client/neurolink.js +0 -8233
- package/dist/client/observability/exporterRegistry.js +0 -413
- package/dist/client/observability/exporters/arizeExporter.js +0 -138
- package/dist/client/observability/exporters/baseExporter.js +0 -190
- package/dist/client/observability/exporters/braintrustExporter.js +0 -154
- package/dist/client/observability/exporters/datadogExporter.js +0 -196
- package/dist/client/observability/exporters/laminarExporter.js +0 -302
- package/dist/client/observability/exporters/langfuseExporter.js +0 -209
- package/dist/client/observability/exporters/langsmithExporter.js +0 -143
- package/dist/client/observability/exporters/otelExporter.js +0 -164
- package/dist/client/observability/exporters/posthogExporter.js +0 -287
- package/dist/client/observability/exporters/sentryExporter.js +0 -165
- package/dist/client/observability/index.js +0 -31
- package/dist/client/observability/metricsAggregator.js +0 -556
- package/dist/client/observability/otelBridge.js +0 -131
- package/dist/client/observability/retryPolicy.js +0 -383
- package/dist/client/observability/sampling/samplers.js +0 -216
- package/dist/client/observability/spanProcessor.js +0 -303
- package/dist/client/observability/tokenTracker.js +0 -413
- package/dist/client/observability/types/exporterTypes.js +0 -5
- package/dist/client/observability/types/index.js +0 -4
- package/dist/client/observability/types/spanTypes.js +0 -92
- package/dist/client/observability/utils/safeMetadata.js +0 -25
- package/dist/client/observability/utils/spanSerializer.js +0 -292
- package/dist/client/processors/archive/ArchiveProcessor.js +0 -1308
- package/dist/client/processors/base/BaseFileProcessor.js +0 -614
- package/dist/client/processors/base/types.js +0 -82
- package/dist/client/processors/config/fileTypes.js +0 -520
- package/dist/client/processors/config/index.js +0 -92
- package/dist/client/processors/config/languageMap.js +0 -410
- package/dist/client/processors/config/mimeTypes.js +0 -363
- package/dist/client/processors/config/sizeLimits.js +0 -258
- package/dist/client/processors/document/ExcelProcessor.js +0 -590
- package/dist/client/processors/document/OpenDocumentProcessor.js +0 -212
- package/dist/client/processors/document/PptxProcessor.js +0 -157
- package/dist/client/processors/document/RtfProcessor.js +0 -361
- package/dist/client/processors/document/WordProcessor.js +0 -353
- package/dist/client/processors/errors/FileErrorCode.js +0 -255
- package/dist/client/processors/errors/errorHelpers.js +0 -386
- package/dist/client/processors/errors/errorSerializer.js +0 -507
- package/dist/client/processors/errors/index.js +0 -49
- package/dist/client/processors/markup/SvgProcessor.js +0 -240
- package/dist/client/processors/media/AudioProcessor.js +0 -707
- package/dist/client/processors/media/VideoProcessor.js +0 -1045
- package/dist/client/providers/amazonBedrock.js +0 -1512
- package/dist/client/providers/amazonSagemaker.js +0 -162
- package/dist/client/providers/anthropic.js +0 -831
- package/dist/client/providers/azureOpenai.js +0 -143
- package/dist/client/providers/googleAiStudio.js +0 -1200
- package/dist/client/providers/googleNativeGemini3.js +0 -543
- package/dist/client/providers/googleVertex.js +0 -2936
- package/dist/client/providers/huggingFace.js +0 -315
- package/dist/client/providers/litellm.js +0 -488
- package/dist/client/providers/mistral.js +0 -157
- package/dist/client/providers/ollama.js +0 -1579
- package/dist/client/providers/openAI.js +0 -627
- package/dist/client/providers/openRouter.js +0 -543
- package/dist/client/providers/openaiCompatible.js +0 -290
- package/dist/client/providers/providerTypeUtils.js +0 -46
- package/dist/client/providers/sagemaker/adaptive-semaphore.js +0 -215
- package/dist/client/providers/sagemaker/client.js +0 -472
- package/dist/client/providers/sagemaker/config.js +0 -317
- package/dist/client/providers/sagemaker/detection.js +0 -606
- package/dist/client/providers/sagemaker/error-constants.js +0 -227
- package/dist/client/providers/sagemaker/errors.js +0 -299
- package/dist/client/providers/sagemaker/language-model.js +0 -775
- package/dist/client/providers/sagemaker/parsers.js +0 -634
- package/dist/client/providers/sagemaker/streaming.js +0 -331
- package/dist/client/providers/sagemaker/structured-parser.js +0 -625
- package/dist/client/proxy/accountQuota.js +0 -162
- package/dist/client/proxy/claudeFormat.js +0 -595
- package/dist/client/proxy/modelRouter.js +0 -29
- package/dist/client/proxy/oauthFetch.js +0 -367
- package/dist/client/proxy/proxyFetch.js +0 -586
- package/dist/client/proxy/requestLogger.js +0 -207
- package/dist/client/proxy/tokenRefresh.js +0 -124
- package/dist/client/proxy/usageStats.js +0 -74
- package/dist/client/proxy/utils/noProxyUtils.js +0 -149
- package/dist/client/rag/ChunkerFactory.js +0 -320
- package/dist/client/rag/ChunkerRegistry.js +0 -421
- package/dist/client/rag/chunkers/BaseChunker.js +0 -143
- package/dist/client/rag/chunkers/CharacterChunker.js +0 -28
- package/dist/client/rag/chunkers/HTMLChunker.js +0 -38
- package/dist/client/rag/chunkers/JSONChunker.js +0 -68
- package/dist/client/rag/chunkers/LaTeXChunker.js +0 -63
- package/dist/client/rag/chunkers/MarkdownChunker.js +0 -306
- package/dist/client/rag/chunkers/RecursiveChunker.js +0 -139
- package/dist/client/rag/chunkers/SemanticMarkdownChunker.js +0 -138
- package/dist/client/rag/chunkers/SentenceChunker.js +0 -66
- package/dist/client/rag/chunkers/TokenChunker.js +0 -61
- package/dist/client/rag/chunkers/index.js +0 -15
- package/dist/client/rag/chunking/characterChunker.js +0 -142
- package/dist/client/rag/chunking/chunkerRegistry.js +0 -194
- package/dist/client/rag/chunking/htmlChunker.js +0 -247
- package/dist/client/rag/chunking/index.js +0 -17
- package/dist/client/rag/chunking/jsonChunker.js +0 -281
- package/dist/client/rag/chunking/latexChunker.js +0 -251
- package/dist/client/rag/chunking/markdownChunker.js +0 -373
- package/dist/client/rag/chunking/recursiveChunker.js +0 -148
- package/dist/client/rag/chunking/semanticChunker.js +0 -306
- package/dist/client/rag/chunking/sentenceChunker.js +0 -230
- package/dist/client/rag/chunking/tokenChunker.js +0 -183
- package/dist/client/rag/document/MDocument.js +0 -392
- package/dist/client/rag/document/index.js +0 -5
- package/dist/client/rag/document/loaders.js +0 -500
- package/dist/client/rag/errors/RAGError.js +0 -274
- package/dist/client/rag/errors/index.js +0 -6
- package/dist/client/rag/graphRag/graphRAG.js +0 -401
- package/dist/client/rag/graphRag/index.js +0 -4
- package/dist/client/rag/index.js +0 -141
- package/dist/client/rag/metadata/MetadataExtractorFactory.js +0 -418
- package/dist/client/rag/metadata/MetadataExtractorRegistry.js +0 -362
- package/dist/client/rag/metadata/index.js +0 -9
- package/dist/client/rag/metadata/metadataExtractor.js +0 -280
- package/dist/client/rag/pipeline/RAGPipeline.js +0 -436
- package/dist/client/rag/pipeline/contextAssembly.js +0 -341
- package/dist/client/rag/pipeline/index.js +0 -5
- package/dist/client/rag/ragIntegration.js +0 -321
- package/dist/client/rag/reranker/RerankerFactory.js +0 -430
- package/dist/client/rag/reranker/RerankerRegistry.js +0 -402
- package/dist/client/rag/reranker/index.js +0 -9
- package/dist/client/rag/reranker/reranker.js +0 -277
- package/dist/client/rag/resilience/CircuitBreaker.js +0 -431
- package/dist/client/rag/resilience/RetryHandler.js +0 -304
- package/dist/client/rag/resilience/index.js +0 -7
- package/dist/client/rag/retrieval/hybridSearch.js +0 -335
- package/dist/client/rag/retrieval/index.js +0 -5
- package/dist/client/rag/retrieval/vectorQueryTool.js +0 -307
- package/dist/client/rag/types.js +0 -8
- package/dist/client/sdk/toolRegistration.js +0 -377
- package/dist/client/server/abstract/baseServerAdapter.js +0 -575
- package/dist/client/server/adapters/expressAdapter.js +0 -486
- package/dist/client/server/adapters/fastifyAdapter.js +0 -472
- package/dist/client/server/adapters/honoAdapter.js +0 -632
- package/dist/client/server/adapters/koaAdapter.js +0 -510
- package/dist/client/server/errors.js +0 -486
- package/dist/client/server/factory/serverAdapterFactory.js +0 -160
- package/dist/client/server/index.js +0 -108
- package/dist/client/server/middleware/abortSignal.js +0 -111
- package/dist/client/server/middleware/auth.js +0 -388
- package/dist/client/server/middleware/cache.js +0 -359
- package/dist/client/server/middleware/common.js +0 -281
- package/dist/client/server/middleware/deprecation.js +0 -190
- package/dist/client/server/middleware/mcpBodyAttachment.js +0 -63
- package/dist/client/server/middleware/rateLimit.js +0 -227
- package/dist/client/server/middleware/validation.js +0 -388
- package/dist/client/server/openapi/generator.js +0 -398
- package/dist/client/server/openapi/index.js +0 -36
- package/dist/client/server/openapi/schemas.js +0 -695
- package/dist/client/server/openapi/templates.js +0 -374
- package/dist/client/server/routes/agentRoutes.js +0 -189
- package/dist/client/server/routes/claudeProxyRoutes.js +0 -1600
- package/dist/client/server/routes/healthRoutes.js +0 -187
- package/dist/client/server/routes/index.js +0 -57
- package/dist/client/server/routes/mcpRoutes.js +0 -342
- package/dist/client/server/routes/memoryRoutes.js +0 -350
- package/dist/client/server/routes/openApiRoutes.js +0 -126
- package/dist/client/server/routes/toolRoutes.js +0 -199
- package/dist/client/server/streaming/dataStream.js +0 -486
- package/dist/client/server/streaming/index.js +0 -11
- package/dist/client/server/types.js +0 -67
- package/dist/client/server/utils/redaction.js +0 -334
- package/dist/client/server/utils/validation.js +0 -243
- package/dist/client/server/websocket/WebSocketHandler.js +0 -383
- package/dist/client/server/websocket/index.js +0 -4
- package/dist/client/services/server/ai/observability/instrumentation.js +0 -808
- package/dist/client/telemetry/attributes.js +0 -100
- package/dist/client/telemetry/index.js +0 -26
- package/dist/client/telemetry/telemetryService.js +0 -308
- package/dist/client/telemetry/tracers.js +0 -17
- package/dist/client/telemetry/withSpan.js +0 -34
- package/dist/client/types/actionTypes.js +0 -6
- package/dist/client/types/analytics.js +0 -5
- package/dist/client/types/authTypes.js +0 -9
- package/dist/client/types/circuitBreakerErrors.js +0 -34
- package/dist/client/types/cli.js +0 -21
- package/dist/client/types/clientTypes.js +0 -10
- package/dist/client/types/common.js +0 -51
- package/dist/client/types/configTypes.js +0 -49
- package/dist/client/types/content.js +0 -19
- package/dist/client/types/contextTypes.js +0 -400
- package/dist/client/types/conversation.js +0 -47
- package/dist/client/types/conversationMemoryInterface.js +0 -6
- package/dist/client/types/domainTypes.js +0 -5
- package/dist/client/types/errors.js +0 -167
- package/dist/client/types/evaluation.js +0 -5
- package/dist/client/types/evaluationProviders.js +0 -5
- package/dist/client/types/evaluationTypes.js +0 -1
- package/dist/client/types/externalMcp.js +0 -6
- package/dist/client/types/fileReferenceTypes.js +0 -8
- package/dist/client/types/fileTypes.js +0 -4
- package/dist/client/types/generateTypes.js +0 -1
- package/dist/client/types/guardrails.js +0 -1
- package/dist/client/types/hitlTypes.js +0 -8
- package/dist/client/types/index.js +0 -57
- package/dist/client/types/mcpTypes.js +0 -5
- package/dist/client/types/middlewareTypes.js +0 -1
- package/dist/client/types/modelTypes.js +0 -30
- package/dist/client/types/multimodal.js +0 -135
- package/dist/client/types/observability.js +0 -6
- package/dist/client/types/pptTypes.js +0 -82
- package/dist/client/types/providers.js +0 -111
- package/dist/client/types/proxyTypes.js +0 -16
- package/dist/client/types/ragTypes.js +0 -7
- package/dist/client/types/sdkTypes.js +0 -8
- package/dist/client/types/serviceTypes.js +0 -5
- package/dist/client/types/streamTypes.js +0 -1
- package/dist/client/types/subscriptionTypes.js +0 -9
- package/dist/client/types/taskClassificationTypes.js +0 -5
- package/dist/client/types/tools.js +0 -24
- package/dist/client/types/ttsTypes.js +0 -57
- package/dist/client/types/typeAliases.js +0 -48
- package/dist/client/types/utilities.js +0 -4
- package/dist/client/types/workflowTypes.js +0 -30
- package/dist/client/utils/async/withTimeout.js +0 -98
- package/dist/client/utils/asyncMutex.js +0 -60
- package/dist/client/utils/conversationMemory.js +0 -431
- package/dist/client/utils/csvProcessor.js +0 -846
- package/dist/client/utils/errorHandling.js +0 -936
- package/dist/client/utils/evaluationUtils.js +0 -131
- package/dist/client/utils/factoryProcessing.js +0 -589
- package/dist/client/utils/fileDetector.js +0 -2161
- package/dist/client/utils/imageCache.js +0 -376
- package/dist/client/utils/imageProcessor.js +0 -704
- package/dist/client/utils/logger.js +0 -491
- package/dist/client/utils/mcpDefaults.js +0 -134
- package/dist/client/utils/messageBuilder.js +0 -1653
- package/dist/client/utils/modelAliasResolver.js +0 -54
- package/dist/client/utils/modelDetection.js +0 -80
- package/dist/client/utils/modelRouter.js +0 -292
- package/dist/client/utils/multimodalOptionsBuilder.js +0 -65
- package/dist/client/utils/observabilityHelpers.js +0 -47
- package/dist/client/utils/parameterValidation.js +0 -966
- package/dist/client/utils/pdfProcessor.js +0 -410
- package/dist/client/utils/performance.js +0 -222
- package/dist/client/utils/pricing.js +0 -340
- package/dist/client/utils/promptRedaction.js +0 -62
- package/dist/client/utils/providerConfig.js +0 -1009
- package/dist/client/utils/providerHealth.js +0 -1237
- package/dist/client/utils/providerRetry.js +0 -112
- package/dist/client/utils/providerUtils.js +0 -434
- package/dist/client/utils/rateLimiter.js +0 -200
- package/dist/client/utils/redis.js +0 -368
- package/dist/client/utils/retryHandler.js +0 -269
- package/dist/client/utils/retryability.js +0 -22
- package/dist/client/utils/sanitizers/svg.js +0 -481
- package/dist/client/utils/schemaConversion.js +0 -255
- package/dist/client/utils/taskClassificationUtils.js +0 -149
- package/dist/client/utils/taskClassifier.js +0 -94
- package/dist/client/utils/thinkingConfig.js +0 -104
- package/dist/client/utils/timeout.js +0 -359
- package/dist/client/utils/tokenEstimation.js +0 -142
- package/dist/client/utils/tokenLimits.js +0 -125
- package/dist/client/utils/tokenUtils.js +0 -239
- package/dist/client/utils/toolUtils.js +0 -75
- package/dist/client/utils/transformationUtils.js +0 -554
- package/dist/client/utils/ttsProcessor.js +0 -286
- package/dist/client/utils/typeUtils.js +0 -97
- package/dist/client/utils/videoAnalysisProcessor.js +0 -67
- package/dist/client/workflow/config.js +0 -398
- package/dist/client/workflow/core/ensembleExecutor.js +0 -407
- package/dist/client/workflow/core/judgeScorer.js +0 -544
- package/dist/client/workflow/core/responseConditioner.js +0 -225
- package/dist/client/workflow/core/types/conditionerTypes.js +0 -7
- package/dist/client/workflow/core/types/ensembleTypes.js +0 -7
- package/dist/client/workflow/core/types/index.js +0 -7
- package/dist/client/workflow/core/types/judgeTypes.js +0 -7
- package/dist/client/workflow/core/types/layerTypes.js +0 -7
- package/dist/client/workflow/core/types/registryTypes.js +0 -7
- package/dist/client/workflow/core/workflowRegistry.js +0 -304
- package/dist/client/workflow/core/workflowRunner.js +0 -586
- package/dist/client/workflow/index.js +0 -50
- package/dist/client/workflow/types.js +0 -9
- package/dist/client/workflow/utils/types/index.js +0 -7
- package/dist/client/workflow/utils/workflowMetrics.js +0 -311
- package/dist/client/workflow/utils/workflowValidation.js +0 -420
- package/dist/client/workflow/workflows/adaptiveWorkflow.js +0 -366
- package/dist/client/workflow/workflows/consensusWorkflow.js +0 -192
- package/dist/client/workflow/workflows/fallbackWorkflow.js +0 -225
- package/dist/client/workflow/workflows/multiJudgeWorkflow.js +0 -351
- /package/dist/client/{client/reactHooks.js → reactHooks.js} +0 -0
|
@@ -1,936 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Robust Error Handling Utilities for NeuroLink
|
|
3
|
-
* Provides structured error management for tool execution and system operations
|
|
4
|
-
*/
|
|
5
|
-
import { ErrorCategory, ErrorSeverity } from "../constants/enums.js";
|
|
6
|
-
import { logger } from "./logger.js";
|
|
7
|
-
import { CircuitBreakerOpenError } from "../types/circuitBreakerErrors.js";
|
|
8
|
-
// Error codes for different scenarios
|
|
9
|
-
export const ERROR_CODES = {
|
|
10
|
-
// Tool errors
|
|
11
|
-
TOOL_NOT_FOUND: "TOOL_NOT_FOUND",
|
|
12
|
-
TOOL_EXECUTION_FAILED: "TOOL_EXECUTION_FAILED",
|
|
13
|
-
TOOL_TIMEOUT: "TOOL_TIMEOUT",
|
|
14
|
-
TOOL_VALIDATION_FAILED: "TOOL_VALIDATION_FAILED",
|
|
15
|
-
// Parameter errors
|
|
16
|
-
INVALID_PARAMETERS: "INVALID_PARAMETERS",
|
|
17
|
-
MISSING_REQUIRED_PARAM: "MISSING_REQUIRED_PARAM",
|
|
18
|
-
// System errors
|
|
19
|
-
MEMORY_EXHAUSTED: "MEMORY_EXHAUSTED",
|
|
20
|
-
NETWORK_ERROR: "NETWORK_ERROR",
|
|
21
|
-
PERMISSION_DENIED: "PERMISSION_DENIED",
|
|
22
|
-
// Provider errors
|
|
23
|
-
PROVIDER_NOT_AVAILABLE: "PROVIDER_NOT_AVAILABLE",
|
|
24
|
-
PROVIDER_AUTH_FAILED: "PROVIDER_AUTH_FAILED",
|
|
25
|
-
PROVIDER_QUOTA_EXCEEDED: "PROVIDER_QUOTA_EXCEEDED",
|
|
26
|
-
// Configuration errors
|
|
27
|
-
INVALID_CONFIGURATION: "INVALID_CONFIGURATION",
|
|
28
|
-
MISSING_CONFIGURATION: "MISSING_CONFIGURATION",
|
|
29
|
-
// Video validation errors
|
|
30
|
-
INVALID_VIDEO_RESOLUTION: "INVALID_VIDEO_RESOLUTION",
|
|
31
|
-
INVALID_VIDEO_LENGTH: "INVALID_VIDEO_LENGTH",
|
|
32
|
-
INVALID_VIDEO_ASPECT_RATIO: "INVALID_VIDEO_ASPECT_RATIO",
|
|
33
|
-
INVALID_VIDEO_AUDIO: "INVALID_VIDEO_AUDIO",
|
|
34
|
-
INVALID_VIDEO_MODE: "INVALID_VIDEO_MODE",
|
|
35
|
-
MISSING_VIDEO_IMAGE: "MISSING_VIDEO_IMAGE",
|
|
36
|
-
EMPTY_VIDEO_PROMPT: "EMPTY_VIDEO_PROMPT",
|
|
37
|
-
VIDEO_PROMPT_TOO_LONG: "VIDEO_PROMPT_TOO_LONG",
|
|
38
|
-
// Image validation errors
|
|
39
|
-
EMPTY_IMAGE_PATH: "EMPTY_IMAGE_PATH",
|
|
40
|
-
INVALID_IMAGE_TYPE: "INVALID_IMAGE_TYPE",
|
|
41
|
-
IMAGE_TOO_LARGE: "IMAGE_TOO_LARGE",
|
|
42
|
-
IMAGE_TOO_SMALL: "IMAGE_TOO_SMALL",
|
|
43
|
-
INVALID_IMAGE_FORMAT: "INVALID_IMAGE_FORMAT",
|
|
44
|
-
// PDF validation errors
|
|
45
|
-
PDF_PAGE_LIMIT_EXCEEDED: "PDF_PAGE_LIMIT_EXCEEDED",
|
|
46
|
-
// Rate limiter errors
|
|
47
|
-
RATE_LIMITER_QUEUE_FULL: "RATE_LIMITER_QUEUE_FULL",
|
|
48
|
-
RATE_LIMITER_QUEUE_TIMEOUT: "RATE_LIMITER_QUEUE_TIMEOUT",
|
|
49
|
-
RATE_LIMITER_RESET: "RATE_LIMITER_RESET",
|
|
50
|
-
// PPT validation errors
|
|
51
|
-
MISSING_PPT_PROPERTIES: "MISSING_PPT_PROPERTIES",
|
|
52
|
-
INVALID_PPT_PAGES: "INVALID_PPT_PAGES",
|
|
53
|
-
INVALID_PPT_FORMAT: "INVALID_PPT_FORMAT",
|
|
54
|
-
INVALID_PPT_PROVIDER: "INVALID_PPT_PROVIDER",
|
|
55
|
-
INVALID_PPT_OUTPUT_OPTIONS: "INVALID_PPT_OUTPUT_OPTIONS",
|
|
56
|
-
INVALID_PPT_OUTPUT_PATH: "INVALID_PPT_OUTPUT_PATH",
|
|
57
|
-
INVALID_PPT_LOGO_PATH: "INVALID_PPT_LOGO_PATH",
|
|
58
|
-
INVALID_PPT_MODE: "INVALID_PPT_MODE",
|
|
59
|
-
INVALID_PPT_PROMPT: "INVALID_PPT_PROMPT",
|
|
60
|
-
};
|
|
61
|
-
/**
|
|
62
|
-
* Enhanced error class with structured information
|
|
63
|
-
*/
|
|
64
|
-
export class NeuroLinkError extends Error {
|
|
65
|
-
code;
|
|
66
|
-
category;
|
|
67
|
-
severity;
|
|
68
|
-
retriable;
|
|
69
|
-
context;
|
|
70
|
-
timestamp;
|
|
71
|
-
toolName;
|
|
72
|
-
serverId;
|
|
73
|
-
constructor(options) {
|
|
74
|
-
super(options.message);
|
|
75
|
-
this.name = "NeuroLinkError";
|
|
76
|
-
this.code = options.code;
|
|
77
|
-
this.category = options.category;
|
|
78
|
-
this.severity = options.severity;
|
|
79
|
-
this.retriable = options.retriable;
|
|
80
|
-
this.context = options.context || {};
|
|
81
|
-
this.timestamp = new Date();
|
|
82
|
-
this.toolName = options.toolName;
|
|
83
|
-
this.serverId = options.serverId;
|
|
84
|
-
// Preserve original error stack if provided
|
|
85
|
-
if (options.originalError) {
|
|
86
|
-
this.stack = options.originalError.stack;
|
|
87
|
-
this.context.originalMessage = options.originalError.message;
|
|
88
|
-
}
|
|
89
|
-
}
|
|
90
|
-
/**
|
|
91
|
-
* Convert to JSON for logging and serialization
|
|
92
|
-
*/
|
|
93
|
-
toJSON() {
|
|
94
|
-
return {
|
|
95
|
-
code: this.code,
|
|
96
|
-
message: this.message,
|
|
97
|
-
category: this.category,
|
|
98
|
-
severity: this.severity,
|
|
99
|
-
retriable: this.retriable,
|
|
100
|
-
context: this.context,
|
|
101
|
-
timestamp: this.timestamp,
|
|
102
|
-
toolName: this.toolName,
|
|
103
|
-
serverId: this.serverId,
|
|
104
|
-
};
|
|
105
|
-
}
|
|
106
|
-
}
|
|
107
|
-
/**
|
|
108
|
-
* Error factory for common error scenarios
|
|
109
|
-
*/
|
|
110
|
-
export class ErrorFactory {
|
|
111
|
-
/**
|
|
112
|
-
* Create a tool not found error
|
|
113
|
-
*/
|
|
114
|
-
static toolNotFound(toolName, availableTools) {
|
|
115
|
-
return new NeuroLinkError({
|
|
116
|
-
code: ERROR_CODES.TOOL_NOT_FOUND,
|
|
117
|
-
message: `Tool '${toolName}' not found`,
|
|
118
|
-
category: ErrorCategory.VALIDATION,
|
|
119
|
-
severity: ErrorSeverity.MEDIUM,
|
|
120
|
-
retriable: false,
|
|
121
|
-
context: { toolName, availableTools },
|
|
122
|
-
toolName,
|
|
123
|
-
});
|
|
124
|
-
}
|
|
125
|
-
/**
|
|
126
|
-
* Create a tool execution failed error
|
|
127
|
-
*/
|
|
128
|
-
static toolExecutionFailed(toolName, originalError, serverId) {
|
|
129
|
-
return new NeuroLinkError({
|
|
130
|
-
code: ERROR_CODES.TOOL_EXECUTION_FAILED,
|
|
131
|
-
message: `Tool '${toolName}' execution failed: ${originalError.message}`,
|
|
132
|
-
category: ErrorCategory.EXECUTION,
|
|
133
|
-
severity: ErrorSeverity.HIGH,
|
|
134
|
-
retriable: true,
|
|
135
|
-
originalError,
|
|
136
|
-
toolName,
|
|
137
|
-
serverId,
|
|
138
|
-
});
|
|
139
|
-
}
|
|
140
|
-
/**
|
|
141
|
-
* Create a tool timeout error
|
|
142
|
-
*/
|
|
143
|
-
static toolTimeout(toolName, timeoutMs, serverId) {
|
|
144
|
-
return new NeuroLinkError({
|
|
145
|
-
code: ERROR_CODES.TOOL_TIMEOUT,
|
|
146
|
-
message: `Tool '${toolName}' timed out after ${timeoutMs}ms`,
|
|
147
|
-
category: ErrorCategory.TIMEOUT,
|
|
148
|
-
severity: ErrorSeverity.HIGH,
|
|
149
|
-
retriable: true,
|
|
150
|
-
context: { timeoutMs },
|
|
151
|
-
toolName,
|
|
152
|
-
serverId,
|
|
153
|
-
});
|
|
154
|
-
}
|
|
155
|
-
/**
|
|
156
|
-
* Create a parameter validation error
|
|
157
|
-
*/
|
|
158
|
-
static invalidParameters(toolName, validationError, providedParams) {
|
|
159
|
-
return new NeuroLinkError({
|
|
160
|
-
code: ERROR_CODES.INVALID_PARAMETERS,
|
|
161
|
-
message: `Invalid parameters for tool '${toolName}': ${validationError.message}`,
|
|
162
|
-
category: ErrorCategory.VALIDATION,
|
|
163
|
-
severity: ErrorSeverity.MEDIUM,
|
|
164
|
-
retriable: false,
|
|
165
|
-
context: { providedParams },
|
|
166
|
-
originalError: validationError,
|
|
167
|
-
toolName,
|
|
168
|
-
});
|
|
169
|
-
}
|
|
170
|
-
/**
|
|
171
|
-
* Create a network error
|
|
172
|
-
*/
|
|
173
|
-
static networkError(toolName, originalError, serverId) {
|
|
174
|
-
return new NeuroLinkError({
|
|
175
|
-
code: ERROR_CODES.NETWORK_ERROR,
|
|
176
|
-
message: `Network error in tool '${toolName}': ${originalError.message}`,
|
|
177
|
-
category: ErrorCategory.NETWORK,
|
|
178
|
-
severity: ErrorSeverity.HIGH,
|
|
179
|
-
retriable: true,
|
|
180
|
-
originalError,
|
|
181
|
-
toolName,
|
|
182
|
-
serverId,
|
|
183
|
-
});
|
|
184
|
-
}
|
|
185
|
-
/**
|
|
186
|
-
* Create a memory exhaustion error
|
|
187
|
-
*/
|
|
188
|
-
static memoryExhausted(toolName, memoryUsageMB) {
|
|
189
|
-
return new NeuroLinkError({
|
|
190
|
-
code: ERROR_CODES.MEMORY_EXHAUSTED,
|
|
191
|
-
message: `Memory exhausted during tool '${toolName}' execution (${memoryUsageMB}MB used)`,
|
|
192
|
-
category: ErrorCategory.RESOURCE,
|
|
193
|
-
severity: ErrorSeverity.CRITICAL,
|
|
194
|
-
retriable: false,
|
|
195
|
-
context: { memoryUsageMB },
|
|
196
|
-
toolName,
|
|
197
|
-
});
|
|
198
|
-
}
|
|
199
|
-
// ============================================================================
|
|
200
|
-
// CONFIGURATION ERRORS
|
|
201
|
-
// ============================================================================
|
|
202
|
-
/**
|
|
203
|
-
* Create a missing configuration error (e.g., missing API key)
|
|
204
|
-
*/
|
|
205
|
-
static missingConfiguration(configName, context) {
|
|
206
|
-
return new NeuroLinkError({
|
|
207
|
-
code: ERROR_CODES.MISSING_CONFIGURATION,
|
|
208
|
-
message: `Missing required configuration: ${configName}`,
|
|
209
|
-
category: ErrorCategory.VALIDATION,
|
|
210
|
-
severity: ErrorSeverity.HIGH,
|
|
211
|
-
retriable: false,
|
|
212
|
-
context: context || {},
|
|
213
|
-
});
|
|
214
|
-
}
|
|
215
|
-
/**
|
|
216
|
-
* Create an invalid configuration error (e.g., NaN for numeric values)
|
|
217
|
-
*/
|
|
218
|
-
static invalidConfiguration(configName, reason, context) {
|
|
219
|
-
return new NeuroLinkError({
|
|
220
|
-
code: ERROR_CODES.INVALID_CONFIGURATION,
|
|
221
|
-
message: `Invalid configuration for '${configName}': ${reason}`,
|
|
222
|
-
category: ErrorCategory.VALIDATION,
|
|
223
|
-
severity: ErrorSeverity.HIGH,
|
|
224
|
-
retriable: false,
|
|
225
|
-
context: context || {},
|
|
226
|
-
});
|
|
227
|
-
}
|
|
228
|
-
// ============================================================================
|
|
229
|
-
// VIDEO VALIDATION ERRORS
|
|
230
|
-
// ============================================================================
|
|
231
|
-
/**
|
|
232
|
-
* Create an invalid video resolution error
|
|
233
|
-
*/
|
|
234
|
-
static invalidVideoResolution(resolution) {
|
|
235
|
-
return new NeuroLinkError({
|
|
236
|
-
code: ERROR_CODES.INVALID_VIDEO_RESOLUTION,
|
|
237
|
-
message: `Invalid resolution '${resolution}'. Use '720p' or '1080p'`,
|
|
238
|
-
category: ErrorCategory.VALIDATION,
|
|
239
|
-
severity: ErrorSeverity.MEDIUM,
|
|
240
|
-
retriable: false,
|
|
241
|
-
context: {
|
|
242
|
-
field: "output.video.resolution",
|
|
243
|
-
providedValue: resolution,
|
|
244
|
-
suggestions: ["Use '720p' for standard HD", "Use '1080p' for full HD"],
|
|
245
|
-
},
|
|
246
|
-
});
|
|
247
|
-
}
|
|
248
|
-
/**
|
|
249
|
-
* Create an invalid video length error
|
|
250
|
-
*/
|
|
251
|
-
static invalidVideoLength(length) {
|
|
252
|
-
return new NeuroLinkError({
|
|
253
|
-
code: ERROR_CODES.INVALID_VIDEO_LENGTH,
|
|
254
|
-
message: `Invalid length '${length}'. Use 4, 6, or 8 seconds`,
|
|
255
|
-
category: ErrorCategory.VALIDATION,
|
|
256
|
-
severity: ErrorSeverity.MEDIUM,
|
|
257
|
-
retriable: false,
|
|
258
|
-
context: {
|
|
259
|
-
field: "output.video.length",
|
|
260
|
-
providedValue: length,
|
|
261
|
-
suggestions: [
|
|
262
|
-
"Use 4 for short clips",
|
|
263
|
-
"Use 6 for balanced duration (recommended)",
|
|
264
|
-
"Use 8 for longer videos",
|
|
265
|
-
],
|
|
266
|
-
},
|
|
267
|
-
});
|
|
268
|
-
}
|
|
269
|
-
/**
|
|
270
|
-
* Create an invalid video aspect ratio error
|
|
271
|
-
*/
|
|
272
|
-
static invalidVideoAspectRatio(aspectRatio) {
|
|
273
|
-
return new NeuroLinkError({
|
|
274
|
-
code: ERROR_CODES.INVALID_VIDEO_ASPECT_RATIO,
|
|
275
|
-
message: `Invalid aspect ratio '${aspectRatio}'. Use '9:16' or '16:9'`,
|
|
276
|
-
category: ErrorCategory.VALIDATION,
|
|
277
|
-
severity: ErrorSeverity.MEDIUM,
|
|
278
|
-
retriable: false,
|
|
279
|
-
context: {
|
|
280
|
-
field: "output.video.aspectRatio",
|
|
281
|
-
providedValue: aspectRatio,
|
|
282
|
-
suggestions: [
|
|
283
|
-
"Use '9:16' for portrait/vertical video",
|
|
284
|
-
"Use '16:9' for landscape",
|
|
285
|
-
],
|
|
286
|
-
},
|
|
287
|
-
});
|
|
288
|
-
}
|
|
289
|
-
/**
|
|
290
|
-
* Create an invalid video audio option error
|
|
291
|
-
*/
|
|
292
|
-
static invalidVideoAudio(audio) {
|
|
293
|
-
return new NeuroLinkError({
|
|
294
|
-
code: ERROR_CODES.INVALID_VIDEO_AUDIO,
|
|
295
|
-
message: `Invalid audio option '${audio}'. Must be true or false`,
|
|
296
|
-
category: ErrorCategory.VALIDATION,
|
|
297
|
-
severity: ErrorSeverity.MEDIUM,
|
|
298
|
-
retriable: false,
|
|
299
|
-
context: {
|
|
300
|
-
field: "output.video.audio",
|
|
301
|
-
providedValue: audio,
|
|
302
|
-
suggestions: [
|
|
303
|
-
"Set audio: true to enable audio generation",
|
|
304
|
-
"Set audio: false to disable",
|
|
305
|
-
],
|
|
306
|
-
},
|
|
307
|
-
});
|
|
308
|
-
}
|
|
309
|
-
/**
|
|
310
|
-
* Create an invalid video mode error
|
|
311
|
-
*/
|
|
312
|
-
static invalidVideoMode() {
|
|
313
|
-
return new NeuroLinkError({
|
|
314
|
-
code: ERROR_CODES.INVALID_VIDEO_MODE,
|
|
315
|
-
message: "Video generation requires output.mode to be 'video'",
|
|
316
|
-
category: ErrorCategory.VALIDATION,
|
|
317
|
-
severity: ErrorSeverity.MEDIUM,
|
|
318
|
-
retriable: false,
|
|
319
|
-
context: {
|
|
320
|
-
field: "output.mode",
|
|
321
|
-
suggestions: ["Set output: { mode: 'video' } for video generation"],
|
|
322
|
-
},
|
|
323
|
-
});
|
|
324
|
-
}
|
|
325
|
-
/**
|
|
326
|
-
* Create a missing video image error
|
|
327
|
-
*/
|
|
328
|
-
static missingVideoImage() {
|
|
329
|
-
return new NeuroLinkError({
|
|
330
|
-
code: ERROR_CODES.MISSING_VIDEO_IMAGE,
|
|
331
|
-
message: "Video generation requires an input image",
|
|
332
|
-
category: ErrorCategory.VALIDATION,
|
|
333
|
-
severity: ErrorSeverity.MEDIUM,
|
|
334
|
-
retriable: false,
|
|
335
|
-
context: {
|
|
336
|
-
field: "input.images",
|
|
337
|
-
suggestions: [
|
|
338
|
-
"Provide an image via input.images array",
|
|
339
|
-
"Example: input: { text: 'prompt', images: [imageBuffer] }",
|
|
340
|
-
],
|
|
341
|
-
},
|
|
342
|
-
});
|
|
343
|
-
}
|
|
344
|
-
/**
|
|
345
|
-
* Create an empty video prompt error
|
|
346
|
-
*/
|
|
347
|
-
static emptyVideoPrompt() {
|
|
348
|
-
return new NeuroLinkError({
|
|
349
|
-
code: ERROR_CODES.EMPTY_VIDEO_PROMPT,
|
|
350
|
-
message: "Video prompt cannot be empty",
|
|
351
|
-
category: ErrorCategory.VALIDATION,
|
|
352
|
-
severity: ErrorSeverity.MEDIUM,
|
|
353
|
-
retriable: false,
|
|
354
|
-
context: {
|
|
355
|
-
field: "input.text",
|
|
356
|
-
suggestions: [
|
|
357
|
-
"Provide a text prompt describing the desired video motion/content",
|
|
358
|
-
"Example: 'Smooth camera pan with dramatic lighting'",
|
|
359
|
-
],
|
|
360
|
-
},
|
|
361
|
-
});
|
|
362
|
-
}
|
|
363
|
-
/**
|
|
364
|
-
* Create a video prompt too long error
|
|
365
|
-
*/
|
|
366
|
-
static videoPromptTooLong(length, maxLength) {
|
|
367
|
-
return new NeuroLinkError({
|
|
368
|
-
code: ERROR_CODES.VIDEO_PROMPT_TOO_LONG,
|
|
369
|
-
message: `Video prompt must be ${maxLength} characters or less (got ${length})`,
|
|
370
|
-
category: ErrorCategory.VALIDATION,
|
|
371
|
-
severity: ErrorSeverity.MEDIUM,
|
|
372
|
-
retriable: false,
|
|
373
|
-
context: {
|
|
374
|
-
field: "input.text",
|
|
375
|
-
providedLength: length,
|
|
376
|
-
maxLength,
|
|
377
|
-
suggestions: [
|
|
378
|
-
`Shorten your prompt to ${maxLength} characters or less`,
|
|
379
|
-
"Focus on key visual elements and camera motion",
|
|
380
|
-
],
|
|
381
|
-
},
|
|
382
|
-
});
|
|
383
|
-
}
|
|
384
|
-
// ============================================================================
|
|
385
|
-
// IMAGE VALIDATION ERRORS
|
|
386
|
-
// ============================================================================
|
|
387
|
-
/**
|
|
388
|
-
* Create an empty image path error
|
|
389
|
-
*/
|
|
390
|
-
static emptyImagePath() {
|
|
391
|
-
return new NeuroLinkError({
|
|
392
|
-
code: ERROR_CODES.EMPTY_IMAGE_PATH,
|
|
393
|
-
message: "Image path or URL cannot be empty",
|
|
394
|
-
category: ErrorCategory.VALIDATION,
|
|
395
|
-
severity: ErrorSeverity.MEDIUM,
|
|
396
|
-
retriable: false,
|
|
397
|
-
context: {
|
|
398
|
-
field: "input.images",
|
|
399
|
-
suggestions: ["Provide a valid file path or URL"],
|
|
400
|
-
},
|
|
401
|
-
});
|
|
402
|
-
}
|
|
403
|
-
/**
|
|
404
|
-
* Create an invalid image type error
|
|
405
|
-
*/
|
|
406
|
-
static invalidImageType() {
|
|
407
|
-
return new NeuroLinkError({
|
|
408
|
-
code: ERROR_CODES.INVALID_IMAGE_TYPE,
|
|
409
|
-
message: "Image must be a Buffer, file path string, or URL",
|
|
410
|
-
category: ErrorCategory.VALIDATION,
|
|
411
|
-
severity: ErrorSeverity.MEDIUM,
|
|
412
|
-
retriable: false,
|
|
413
|
-
context: {
|
|
414
|
-
field: "input.images",
|
|
415
|
-
suggestions: [
|
|
416
|
-
"Provide image as Buffer: fs.readFileSync('image.jpg')",
|
|
417
|
-
"Or as file path string: './image.jpg'",
|
|
418
|
-
"Or as URL: 'https://example.com/image.jpg'",
|
|
419
|
-
],
|
|
420
|
-
},
|
|
421
|
-
});
|
|
422
|
-
}
|
|
423
|
-
// ============================================================================
|
|
424
|
-
// PDF VALIDATION ERRORS
|
|
425
|
-
// ============================================================================
|
|
426
|
-
/**
|
|
427
|
-
* Create a PDF page limit exceeded error
|
|
428
|
-
*/
|
|
429
|
-
static pdfPageLimitExceeded(estimatedPages, maxPages, provider) {
|
|
430
|
-
const alternatives = [
|
|
431
|
-
`Split the PDF into smaller files (max ${maxPages} pages each)`,
|
|
432
|
-
"Extract only the pages you need using a PDF editor",
|
|
433
|
-
"For large files, consider Google AI Studio which supports up to 2000MB file size (though page limits still apply)",
|
|
434
|
-
"Convert specific pages to images manually before processing",
|
|
435
|
-
"Bypass this limit with { enforceLimits: false } (not recommended - may cause API errors or unexpected costs)",
|
|
436
|
-
];
|
|
437
|
-
return new NeuroLinkError({
|
|
438
|
-
code: ERROR_CODES.PDF_PAGE_LIMIT_EXCEEDED,
|
|
439
|
-
message: `PDF page limit exceeded: ${estimatedPages} pages detected, but ${provider} supports maximum ${maxPages} pages.\n\n` +
|
|
440
|
-
`Alternatives:\n` +
|
|
441
|
-
alternatives.map((alt, i) => `${i + 1}. ${alt}`).join("\n"),
|
|
442
|
-
category: ErrorCategory.VALIDATION,
|
|
443
|
-
severity: ErrorSeverity.MEDIUM,
|
|
444
|
-
retriable: false,
|
|
445
|
-
context: {
|
|
446
|
-
estimatedPages,
|
|
447
|
-
maxPages,
|
|
448
|
-
provider,
|
|
449
|
-
alternatives,
|
|
450
|
-
},
|
|
451
|
-
});
|
|
452
|
-
}
|
|
453
|
-
/**
|
|
454
|
-
* Create an image too large error
|
|
455
|
-
*/
|
|
456
|
-
static imageTooLarge(sizeMB, maxMB) {
|
|
457
|
-
return new NeuroLinkError({
|
|
458
|
-
code: ERROR_CODES.IMAGE_TOO_LARGE,
|
|
459
|
-
message: `Image size (${sizeMB}MB) exceeds maximum (${maxMB}MB)`,
|
|
460
|
-
category: ErrorCategory.VALIDATION,
|
|
461
|
-
severity: ErrorSeverity.MEDIUM,
|
|
462
|
-
retriable: false,
|
|
463
|
-
context: {
|
|
464
|
-
field: "input.images",
|
|
465
|
-
sizeMB,
|
|
466
|
-
maxMB,
|
|
467
|
-
suggestions: [
|
|
468
|
-
`Compress or resize the image to under ${maxMB}MB`,
|
|
469
|
-
"Use a lower quality JPEG compression",
|
|
470
|
-
"Reduce image dimensions",
|
|
471
|
-
],
|
|
472
|
-
},
|
|
473
|
-
});
|
|
474
|
-
}
|
|
475
|
-
/**
|
|
476
|
-
* Create an image too small error
|
|
477
|
-
*/
|
|
478
|
-
static imageTooSmall() {
|
|
479
|
-
return new NeuroLinkError({
|
|
480
|
-
code: ERROR_CODES.IMAGE_TOO_SMALL,
|
|
481
|
-
message: "Image data is too small to be a valid image file",
|
|
482
|
-
category: ErrorCategory.VALIDATION,
|
|
483
|
-
severity: ErrorSeverity.MEDIUM,
|
|
484
|
-
retriable: false,
|
|
485
|
-
context: {
|
|
486
|
-
field: "input.images",
|
|
487
|
-
suggestions: ["Provide a valid JPEG, PNG, or WebP image file"],
|
|
488
|
-
},
|
|
489
|
-
});
|
|
490
|
-
}
|
|
491
|
-
/**
|
|
492
|
-
* Create an invalid image format error
|
|
493
|
-
*/
|
|
494
|
-
static invalidImageFormat() {
|
|
495
|
-
return new NeuroLinkError({
|
|
496
|
-
code: ERROR_CODES.INVALID_IMAGE_FORMAT,
|
|
497
|
-
message: "Unsupported image format. Use JPEG, PNG, or WebP",
|
|
498
|
-
category: ErrorCategory.VALIDATION,
|
|
499
|
-
severity: ErrorSeverity.MEDIUM,
|
|
500
|
-
retriable: false,
|
|
501
|
-
context: {
|
|
502
|
-
field: "input.images",
|
|
503
|
-
suggestions: [
|
|
504
|
-
"Convert your image to JPEG, PNG, or WebP format",
|
|
505
|
-
"Ensure the file is not corrupted",
|
|
506
|
-
"Check that the file extension matches the actual format",
|
|
507
|
-
],
|
|
508
|
-
},
|
|
509
|
-
});
|
|
510
|
-
}
|
|
511
|
-
// ============================================================================
|
|
512
|
-
// RATE LIMITER ERRORS
|
|
513
|
-
// ============================================================================
|
|
514
|
-
/**
|
|
515
|
-
* Create a rate limiter queue full error
|
|
516
|
-
*/
|
|
517
|
-
static rateLimiterQueueFull(maxQueueSize) {
|
|
518
|
-
return new NeuroLinkError({
|
|
519
|
-
code: ERROR_CODES.RATE_LIMITER_QUEUE_FULL,
|
|
520
|
-
message: `Rate limiter queue full: too many pending requests (${maxQueueSize} max)`,
|
|
521
|
-
category: ErrorCategory.RESOURCE,
|
|
522
|
-
severity: ErrorSeverity.HIGH,
|
|
523
|
-
retriable: true,
|
|
524
|
-
context: { maxQueueSize },
|
|
525
|
-
});
|
|
526
|
-
}
|
|
527
|
-
/**
|
|
528
|
-
* Create a rate limiter queue timeout error
|
|
529
|
-
*/
|
|
530
|
-
static rateLimiterQueueTimeout(timeoutMs) {
|
|
531
|
-
return new NeuroLinkError({
|
|
532
|
-
code: ERROR_CODES.RATE_LIMITER_QUEUE_TIMEOUT,
|
|
533
|
-
message: `Rate limiter queue timeout: request exceeded ${timeoutMs}ms wait time`,
|
|
534
|
-
category: ErrorCategory.TIMEOUT,
|
|
535
|
-
severity: ErrorSeverity.HIGH,
|
|
536
|
-
retriable: true,
|
|
537
|
-
context: { timeoutMs },
|
|
538
|
-
});
|
|
539
|
-
}
|
|
540
|
-
/**
|
|
541
|
-
* Create a rate limiter reset error
|
|
542
|
-
*/
|
|
543
|
-
static rateLimiterReset() {
|
|
544
|
-
return new NeuroLinkError({
|
|
545
|
-
code: ERROR_CODES.RATE_LIMITER_RESET,
|
|
546
|
-
message: "Rate limiter was reset while request was pending",
|
|
547
|
-
category: ErrorCategory.EXECUTION,
|
|
548
|
-
severity: ErrorSeverity.MEDIUM,
|
|
549
|
-
retriable: true,
|
|
550
|
-
context: {},
|
|
551
|
-
});
|
|
552
|
-
}
|
|
553
|
-
// ============================================================================
|
|
554
|
-
// PPT VALIDATION ERRORS
|
|
555
|
-
// ============================================================================
|
|
556
|
-
/**
|
|
557
|
-
* Create a generic missing PPT property error
|
|
558
|
-
*/
|
|
559
|
-
static missingPPTProperty(field, suggestions) {
|
|
560
|
-
const defaultSuggestions = [`Provide the required '${field}' field`];
|
|
561
|
-
return new NeuroLinkError({
|
|
562
|
-
code: ERROR_CODES.MISSING_PPT_PROPERTIES,
|
|
563
|
-
message: `PPT generation requires '${field}' field`,
|
|
564
|
-
category: ErrorCategory.VALIDATION,
|
|
565
|
-
severity: ErrorSeverity.MEDIUM,
|
|
566
|
-
retriable: false,
|
|
567
|
-
context: {
|
|
568
|
-
field,
|
|
569
|
-
suggestions: suggestions || defaultSuggestions,
|
|
570
|
-
},
|
|
571
|
-
});
|
|
572
|
-
}
|
|
573
|
-
/**
|
|
574
|
-
* Create an invalid PPT pages error
|
|
575
|
-
*/
|
|
576
|
-
static invalidPPTPages(pages, reason) {
|
|
577
|
-
return new NeuroLinkError({
|
|
578
|
-
code: ERROR_CODES.INVALID_PPT_PAGES,
|
|
579
|
-
message: `Invalid pages value '${pages}': ${reason}`,
|
|
580
|
-
category: ErrorCategory.VALIDATION,
|
|
581
|
-
severity: ErrorSeverity.MEDIUM,
|
|
582
|
-
retriable: false,
|
|
583
|
-
context: {
|
|
584
|
-
field: "output.ppt.pages",
|
|
585
|
-
providedValue: pages,
|
|
586
|
-
suggestions: [
|
|
587
|
-
"Use a number between 5 and 50",
|
|
588
|
-
"For longer presentations, consider breaking into multiple decks",
|
|
589
|
-
],
|
|
590
|
-
},
|
|
591
|
-
});
|
|
592
|
-
}
|
|
593
|
-
/**
|
|
594
|
-
* Create an invalid PPT format error
|
|
595
|
-
*/
|
|
596
|
-
static invalidPPTFormat(format) {
|
|
597
|
-
return new NeuroLinkError({
|
|
598
|
-
code: ERROR_CODES.INVALID_PPT_FORMAT,
|
|
599
|
-
message: `Invalid format '${format}'. Only 'pptx' is supported`,
|
|
600
|
-
category: ErrorCategory.VALIDATION,
|
|
601
|
-
severity: ErrorSeverity.MEDIUM,
|
|
602
|
-
retriable: false,
|
|
603
|
-
context: {
|
|
604
|
-
field: "output.ppt.format",
|
|
605
|
-
providedValue: format,
|
|
606
|
-
suggestions: ["Use format: 'pptx' or omit (defaults to 'pptx')"],
|
|
607
|
-
},
|
|
608
|
-
});
|
|
609
|
-
}
|
|
610
|
-
/**
|
|
611
|
-
* Create a generic invalid PPT output options error
|
|
612
|
-
*/
|
|
613
|
-
static invalidPPTOutputOptions(field, value, validOptions) {
|
|
614
|
-
const suggestions = validOptions
|
|
615
|
-
? validOptions.map((opt) => `Use '${opt}'`)
|
|
616
|
-
: ["Check the documentation for valid options"];
|
|
617
|
-
return new NeuroLinkError({
|
|
618
|
-
code: ERROR_CODES.INVALID_PPT_OUTPUT_OPTIONS,
|
|
619
|
-
message: `Invalid ${field} value '${value}'`,
|
|
620
|
-
category: ErrorCategory.VALIDATION,
|
|
621
|
-
severity: ErrorSeverity.MEDIUM,
|
|
622
|
-
retriable: false,
|
|
623
|
-
context: {
|
|
624
|
-
field: `output.ppt.${field}`,
|
|
625
|
-
providedValue: value,
|
|
626
|
-
suggestions,
|
|
627
|
-
},
|
|
628
|
-
});
|
|
629
|
-
}
|
|
630
|
-
/**
|
|
631
|
-
* Create an invalid PPT output path error
|
|
632
|
-
*/
|
|
633
|
-
static invalidPPTOutputPath(path, reason) {
|
|
634
|
-
return new NeuroLinkError({
|
|
635
|
-
code: ERROR_CODES.INVALID_PPT_OUTPUT_PATH,
|
|
636
|
-
message: `Invalid outputPath '${path}': ${reason}`,
|
|
637
|
-
category: ErrorCategory.VALIDATION,
|
|
638
|
-
severity: ErrorSeverity.MEDIUM,
|
|
639
|
-
retriable: false,
|
|
640
|
-
context: {
|
|
641
|
-
field: "output.ppt.outputPath",
|
|
642
|
-
providedValue: path,
|
|
643
|
-
suggestions: [
|
|
644
|
-
"Provide a valid file path string",
|
|
645
|
-
"Example: './presentations/my-deck.pptx'",
|
|
646
|
-
"Omit to use auto-generated path",
|
|
647
|
-
],
|
|
648
|
-
},
|
|
649
|
-
});
|
|
650
|
-
}
|
|
651
|
-
/**
|
|
652
|
-
* Create an invalid PPT mode error
|
|
653
|
-
*/
|
|
654
|
-
static invalidPPTMode() {
|
|
655
|
-
return new NeuroLinkError({
|
|
656
|
-
code: ERROR_CODES.INVALID_PPT_MODE,
|
|
657
|
-
message: "Presentation generation requires output.mode to be 'ppt'",
|
|
658
|
-
category: ErrorCategory.VALIDATION,
|
|
659
|
-
severity: ErrorSeverity.MEDIUM,
|
|
660
|
-
retriable: false,
|
|
661
|
-
context: {
|
|
662
|
-
field: "output.mode",
|
|
663
|
-
suggestions: [
|
|
664
|
-
"Set output: { mode: 'ppt' } for presentation generation",
|
|
665
|
-
],
|
|
666
|
-
},
|
|
667
|
-
});
|
|
668
|
-
}
|
|
669
|
-
/**
|
|
670
|
-
* Create an invalid PPT prompt error
|
|
671
|
-
*/
|
|
672
|
-
static invalidPPTPrompt(reason) {
|
|
673
|
-
return new NeuroLinkError({
|
|
674
|
-
code: ERROR_CODES.INVALID_PPT_PROMPT,
|
|
675
|
-
message: `Invalid PPT prompt: ${reason}`,
|
|
676
|
-
category: ErrorCategory.VALIDATION,
|
|
677
|
-
severity: ErrorSeverity.MEDIUM,
|
|
678
|
-
retriable: false,
|
|
679
|
-
context: {
|
|
680
|
-
field: "input.text",
|
|
681
|
-
suggestions: [
|
|
682
|
-
"Provide a non-empty text prompt",
|
|
683
|
-
"Keep the prompt under 1000 characters",
|
|
684
|
-
"Focus on key topics and structure for the presentation",
|
|
685
|
-
],
|
|
686
|
-
},
|
|
687
|
-
});
|
|
688
|
-
}
|
|
689
|
-
/**
|
|
690
|
-
* Create an invalid PPT logo path error
|
|
691
|
-
*/
|
|
692
|
-
static invalidPPTLogoPath(path, reason) {
|
|
693
|
-
return new NeuroLinkError({
|
|
694
|
-
code: ERROR_CODES.INVALID_PPT_LOGO_PATH,
|
|
695
|
-
message: `Invalid logoPath '${path}': ${reason}`,
|
|
696
|
-
category: ErrorCategory.VALIDATION,
|
|
697
|
-
severity: ErrorSeverity.MEDIUM,
|
|
698
|
-
retriable: false,
|
|
699
|
-
context: {
|
|
700
|
-
field: "output.ppt.logoPath",
|
|
701
|
-
providedValue: path,
|
|
702
|
-
suggestions: [
|
|
703
|
-
"Provide a valid file path string",
|
|
704
|
-
"Example: './assets/logo.png'",
|
|
705
|
-
"Omit to skip logo inclusion",
|
|
706
|
-
],
|
|
707
|
-
},
|
|
708
|
-
});
|
|
709
|
-
}
|
|
710
|
-
/**
|
|
711
|
-
* Create an invalid PPT provider error
|
|
712
|
-
*/
|
|
713
|
-
static invalidPPTProvider(provider) {
|
|
714
|
-
return new NeuroLinkError({
|
|
715
|
-
code: ERROR_CODES.INVALID_PPT_PROVIDER,
|
|
716
|
-
message: `Invalid provider '${provider}' for PPT generation. Supported providers: vertex, openai, azure, anthropic, google-ai, bedrock`,
|
|
717
|
-
category: ErrorCategory.VALIDATION,
|
|
718
|
-
severity: ErrorSeverity.MEDIUM,
|
|
719
|
-
retriable: false,
|
|
720
|
-
context: {
|
|
721
|
-
field: "provider",
|
|
722
|
-
providedValue: provider,
|
|
723
|
-
suggestions: [
|
|
724
|
-
"Use 'vertex' for Google Vertex AI (Gemini)",
|
|
725
|
-
"Use 'openai' for OpenAI GPT models",
|
|
726
|
-
"Use 'azure' for Azure OpenAI",
|
|
727
|
-
"Use 'anthropic' for Anthropic Claude models",
|
|
728
|
-
"Use 'google-ai' for Google AI Studio (Gemini)",
|
|
729
|
-
"Use 'bedrock' for AWS Bedrock (Claude, Llama, Nova, etc.)",
|
|
730
|
-
],
|
|
731
|
-
},
|
|
732
|
-
});
|
|
733
|
-
}
|
|
734
|
-
}
|
|
735
|
-
/**
|
|
736
|
-
* Timeout wrapper for async operations
|
|
737
|
-
*/
|
|
738
|
-
export async function withTimeout(promise, timeoutMs, timeoutError) {
|
|
739
|
-
const timeoutPromise = new Promise((_, reject) => {
|
|
740
|
-
setTimeout(() => {
|
|
741
|
-
reject(timeoutError || new Error(`Operation timed out after ${timeoutMs}ms`));
|
|
742
|
-
}, timeoutMs);
|
|
743
|
-
});
|
|
744
|
-
return Promise.race([promise, timeoutPromise]);
|
|
745
|
-
}
|
|
746
|
-
/**
|
|
747
|
-
* Retry mechanism for retriable operations
|
|
748
|
-
*/
|
|
749
|
-
export async function withRetry(operation, options) {
|
|
750
|
-
const { maxAttempts, delayMs, isRetriable = () => true, onRetry } = options;
|
|
751
|
-
let lastError;
|
|
752
|
-
for (let attempt = 1; attempt <= maxAttempts; attempt++) {
|
|
753
|
-
try {
|
|
754
|
-
return await operation();
|
|
755
|
-
}
|
|
756
|
-
catch (error) {
|
|
757
|
-
lastError = error instanceof Error ? error : new Error(String(error));
|
|
758
|
-
// Don't retry on the last attempt or if error is not retriable
|
|
759
|
-
if (attempt === maxAttempts || !isRetriable(lastError)) {
|
|
760
|
-
throw lastError;
|
|
761
|
-
}
|
|
762
|
-
if (onRetry) {
|
|
763
|
-
onRetry(attempt, lastError);
|
|
764
|
-
}
|
|
765
|
-
// Wait before retry
|
|
766
|
-
await new Promise((resolve) => setTimeout(resolve, delayMs));
|
|
767
|
-
}
|
|
768
|
-
}
|
|
769
|
-
if (lastError) {
|
|
770
|
-
throw lastError;
|
|
771
|
-
}
|
|
772
|
-
throw new Error("Retry operation failed with no error information");
|
|
773
|
-
}
|
|
774
|
-
/**
|
|
775
|
-
* Circuit breaker for preventing cascading failures
|
|
776
|
-
*/
|
|
777
|
-
export class CircuitBreaker {
|
|
778
|
-
failureThreshold;
|
|
779
|
-
resetTimeoutMs;
|
|
780
|
-
failures = 0;
|
|
781
|
-
lastFailureTime = 0;
|
|
782
|
-
state = "closed";
|
|
783
|
-
name;
|
|
784
|
-
constructor(failureThreshold = 5, resetTimeoutMs = 60000, name = "tool-execution") {
|
|
785
|
-
this.failureThreshold = failureThreshold;
|
|
786
|
-
this.resetTimeoutMs = resetTimeoutMs;
|
|
787
|
-
this.name = name;
|
|
788
|
-
}
|
|
789
|
-
async execute(operation) {
|
|
790
|
-
if (this.state === "open") {
|
|
791
|
-
const retryAfterMs = this.resetTimeoutMs - (Date.now() - this.lastFailureTime);
|
|
792
|
-
if (retryAfterMs > 0) {
|
|
793
|
-
throw new CircuitBreakerOpenError({
|
|
794
|
-
breakerName: this.name,
|
|
795
|
-
retryAfter: new Date(this.lastFailureTime + this.resetTimeoutMs),
|
|
796
|
-
retryAfterMs,
|
|
797
|
-
breakerState: "open",
|
|
798
|
-
failureCount: this.failures,
|
|
799
|
-
});
|
|
800
|
-
}
|
|
801
|
-
this.state = "half-open";
|
|
802
|
-
}
|
|
803
|
-
try {
|
|
804
|
-
const result = await operation();
|
|
805
|
-
this.onSuccess();
|
|
806
|
-
return result;
|
|
807
|
-
}
|
|
808
|
-
catch (error) {
|
|
809
|
-
this.onFailure();
|
|
810
|
-
throw error;
|
|
811
|
-
}
|
|
812
|
-
}
|
|
813
|
-
onSuccess() {
|
|
814
|
-
this.failures = 0;
|
|
815
|
-
this.state = "closed";
|
|
816
|
-
}
|
|
817
|
-
onFailure() {
|
|
818
|
-
this.failures++;
|
|
819
|
-
this.lastFailureTime = Date.now();
|
|
820
|
-
if (this.failures >= this.failureThreshold) {
|
|
821
|
-
this.state = "open";
|
|
822
|
-
}
|
|
823
|
-
}
|
|
824
|
-
getState() {
|
|
825
|
-
return this.state;
|
|
826
|
-
}
|
|
827
|
-
getFailureCount() {
|
|
828
|
-
return this.failures;
|
|
829
|
-
}
|
|
830
|
-
}
|
|
831
|
-
/**
|
|
832
|
-
* Detect AbortError from any source (DOMException, plain Error, or message-based).
|
|
833
|
-
* Used to short-circuit retry/fallback loops when an abort signal fires.
|
|
834
|
-
*
|
|
835
|
-
* Uses `includes()` for message checks because provider error handlers
|
|
836
|
-
* (e.g., googleVertex.formatProviderError) wrap the original AbortError
|
|
837
|
-
* in a formatted error like "❌ Provider Error\n\nThis operation was aborted\n\n..."
|
|
838
|
-
* which destroys the exact message match.
|
|
839
|
-
*/
|
|
840
|
-
export function isAbortError(error) {
|
|
841
|
-
if (error instanceof DOMException && error.name === "AbortError") {
|
|
842
|
-
return true;
|
|
843
|
-
}
|
|
844
|
-
if (error instanceof Error && error.name === "AbortError") {
|
|
845
|
-
return true;
|
|
846
|
-
}
|
|
847
|
-
if (error instanceof Error &&
|
|
848
|
-
(error.message?.includes("This operation was aborted") ||
|
|
849
|
-
error.message?.includes("The operation was aborted") ||
|
|
850
|
-
error.message?.includes("The user aborted a request"))) {
|
|
851
|
-
return true;
|
|
852
|
-
}
|
|
853
|
-
return false;
|
|
854
|
-
}
|
|
855
|
-
/**
|
|
856
|
-
* Error handler that decides whether to retry based on error type
|
|
857
|
-
*/
|
|
858
|
-
export function isRetriableError(error) {
|
|
859
|
-
if (error instanceof NeuroLinkError) {
|
|
860
|
-
return error.retriable;
|
|
861
|
-
}
|
|
862
|
-
// Check for common retriable error patterns
|
|
863
|
-
const retriablePatterns = [
|
|
864
|
-
/timeout/i,
|
|
865
|
-
/network/i,
|
|
866
|
-
/connection/i,
|
|
867
|
-
/temporary/i,
|
|
868
|
-
/rate limit/i,
|
|
869
|
-
/quota/i,
|
|
870
|
-
/503/i, // Service unavailable
|
|
871
|
-
/502/i, // Bad gateway
|
|
872
|
-
/504/i, // Gateway timeout
|
|
873
|
-
];
|
|
874
|
-
return retriablePatterns.some((pattern) => pattern.test(error.message));
|
|
875
|
-
}
|
|
876
|
-
/**
|
|
877
|
-
* Determines if an error is likely recoverable (rate limit, timeout, network issues).
|
|
878
|
-
* Useful for deciding whether to retry or fail fast.
|
|
879
|
-
*/
|
|
880
|
-
export function isRecoverableError(error) {
|
|
881
|
-
// Check NeuroLinkError.retriable first
|
|
882
|
-
const errorWithRetriable = error;
|
|
883
|
-
if ("retriable" in error &&
|
|
884
|
-
typeof errorWithRetriable.retriable === "boolean") {
|
|
885
|
-
return errorWithRetriable.retriable;
|
|
886
|
-
}
|
|
887
|
-
const message = error.message?.toLowerCase() || "";
|
|
888
|
-
// Rate limit errors
|
|
889
|
-
if (message.includes("rate limit") || message.includes("too many requests")) {
|
|
890
|
-
return true;
|
|
891
|
-
}
|
|
892
|
-
if (/\b429\b/.test(message)) {
|
|
893
|
-
return true;
|
|
894
|
-
}
|
|
895
|
-
// Timeout errors
|
|
896
|
-
if (message.includes("timeout") ||
|
|
897
|
-
message.includes("etimedout") ||
|
|
898
|
-
message.includes("timed out")) {
|
|
899
|
-
return true;
|
|
900
|
-
}
|
|
901
|
-
// Network errors
|
|
902
|
-
if (message.includes("econnreset") ||
|
|
903
|
-
message.includes("econnrefused") ||
|
|
904
|
-
message.includes("network") ||
|
|
905
|
-
message.includes("socket")) {
|
|
906
|
-
return true;
|
|
907
|
-
}
|
|
908
|
-
// Server errors (use word boundaries to avoid false matches)
|
|
909
|
-
if (/\b50[0234]\b/.test(message)) {
|
|
910
|
-
return true;
|
|
911
|
-
}
|
|
912
|
-
return false;
|
|
913
|
-
}
|
|
914
|
-
/**
|
|
915
|
-
* Enhanced error logger that provides structured logging
|
|
916
|
-
*/
|
|
917
|
-
export function logStructuredError(error, context) {
|
|
918
|
-
const logData = {
|
|
919
|
-
...error.toJSON(),
|
|
920
|
-
...context,
|
|
921
|
-
};
|
|
922
|
-
switch (error.severity) {
|
|
923
|
-
case ErrorSeverity.CRITICAL:
|
|
924
|
-
logger.error(`[CRITICAL] ${error.message}`, logData);
|
|
925
|
-
break;
|
|
926
|
-
case ErrorSeverity.HIGH:
|
|
927
|
-
logger.error(`[HIGH] ${error.message}`, logData);
|
|
928
|
-
break;
|
|
929
|
-
case ErrorSeverity.MEDIUM:
|
|
930
|
-
logger.warn(`[MEDIUM] ${error.message}`, logData);
|
|
931
|
-
break;
|
|
932
|
-
case ErrorSeverity.LOW:
|
|
933
|
-
logger.info(`[LOW] ${error.message}`, logData);
|
|
934
|
-
break;
|
|
935
|
-
}
|
|
936
|
-
}
|