@inkeep/agents-api 0.0.0-dev-20260121145510
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/LICENSE.md +56 -0
- package/SUPPLEMENTAL_TERMS.md +40 -0
- package/dist/.well-known/workflow/v1/flow.cjs +46383 -0
- package/dist/.well-known/workflow/v1/flow.cjs.debug.json +6 -0
- package/dist/.well-known/workflow/v1/manifest.debug.json +55 -0
- package/dist/.well-known/workflow/v1/step.cjs +218683 -0
- package/dist/.well-known/workflow/v1/step.cjs.debug.json +6 -0
- package/dist/.well-known/workflow/v1/webhook.mjs +29 -0
- package/dist/createApp.d.ts +10 -0
- package/dist/createApp.js +170 -0
- package/dist/data/db/index.d.ts +4 -0
- package/dist/data/db/index.js +5 -0
- package/dist/data/db/manageDbClient.d.ts +6 -0
- package/dist/data/db/manageDbClient.js +9 -0
- package/dist/data/db/manageDbPool.d.ts +6 -0
- package/dist/data/db/manageDbPool.js +9 -0
- package/dist/data/db/runDbClient.d.ts +6 -0
- package/dist/data/db/runDbClient.js +9 -0
- package/dist/domains/evals/index.d.ts +13 -0
- package/dist/domains/evals/index.js +13 -0
- package/dist/domains/evals/routes/datasetTriggers.d.ts +7 -0
- package/dist/domains/evals/routes/datasetTriggers.js +65 -0
- package/dist/domains/evals/routes/evaluationTriggers.d.ts +11 -0
- package/dist/domains/evals/routes/evaluationTriggers.js +311 -0
- package/dist/domains/evals/routes/index.d.ts +7 -0
- package/dist/domains/evals/routes/index.js +12 -0
- package/dist/domains/evals/scripts/build-workflow.d.ts +1 -0
- package/dist/domains/evals/scripts/build-workflow.js +31 -0
- package/dist/domains/evals/services/EvaluationService.d.ts +96 -0
- package/dist/domains/evals/services/EvaluationService.js +863 -0
- package/dist/domains/evals/services/conversationEvaluation.d.ts +15 -0
- package/dist/domains/evals/services/conversationEvaluation.js +102 -0
- package/dist/domains/evals/services/datasetRun.d.ts +16 -0
- package/dist/domains/evals/services/datasetRun.js +43 -0
- package/dist/domains/evals/services/evaluationJob.d.ts +17 -0
- package/dist/domains/evals/services/evaluationJob.js +65 -0
- package/dist/domains/evals/services/startEvaluation.d.ts +19 -0
- package/dist/domains/evals/services/startEvaluation.js +18 -0
- package/dist/domains/evals/workflow/functions/evaluateConversation.d.ts +31 -0
- package/dist/domains/evals/workflow/functions/evaluateConversation.js +135 -0
- package/dist/domains/evals/workflow/functions/runDatasetItem.d.ts +39 -0
- package/dist/domains/evals/workflow/functions/runDatasetItem.js +205 -0
- package/dist/domains/evals/workflow/index.d.ts +4 -0
- package/dist/domains/evals/workflow/index.js +5 -0
- package/dist/domains/evals/workflow/routes.d.ts +7 -0
- package/dist/domains/evals/workflow/routes.js +106 -0
- package/dist/domains/evals/workflow/world.d.ts +4 -0
- package/dist/domains/evals/workflow/world.js +36 -0
- package/dist/domains/index.d.ts +4 -0
- package/dist/domains/index.js +5 -0
- package/dist/domains/manage/index.d.ts +12 -0
- package/dist/domains/manage/index.js +31 -0
- package/dist/domains/manage/routes/agent.d.ts +9 -0
- package/dist/domains/manage/routes/agent.js +266 -0
- package/dist/domains/manage/routes/agentFull.d.ts +9 -0
- package/dist/domains/manage/routes/agentFull.js +207 -0
- package/dist/domains/manage/routes/agentToolRelations.d.ts +9 -0
- package/dist/domains/manage/routes/agentToolRelations.js +289 -0
- package/dist/domains/manage/routes/apiKeys.d.ts +9 -0
- package/dist/domains/manage/routes/apiKeys.js +217 -0
- package/dist/domains/manage/routes/artifactComponents.d.ts +9 -0
- package/dist/domains/manage/routes/artifactComponents.js +210 -0
- package/dist/domains/manage/routes/branches.d.ts +9 -0
- package/dist/domains/manage/routes/branches.js +182 -0
- package/dist/domains/manage/routes/cliAuth.d.ts +9 -0
- package/dist/domains/manage/routes/cliAuth.js +60 -0
- package/dist/domains/manage/routes/contextConfigs.d.ts +9 -0
- package/dist/domains/manage/routes/contextConfigs.js +189 -0
- package/dist/domains/manage/routes/conversations.d.ts +7 -0
- package/dist/domains/manage/routes/conversations.js +59 -0
- package/dist/domains/manage/routes/credentialStores.d.ts +9 -0
- package/dist/domains/manage/routes/credentialStores.js +86 -0
- package/dist/domains/manage/routes/credentials.d.ts +9 -0
- package/dist/domains/manage/routes/credentials.js +207 -0
- package/dist/domains/manage/routes/dataComponents.d.ts +9 -0
- package/dist/domains/manage/routes/dataComponents.js +192 -0
- package/dist/domains/manage/routes/evals/datasetItems.d.ts +9 -0
- package/dist/domains/manage/routes/evals/datasetItems.js +310 -0
- package/dist/domains/manage/routes/evals/datasetRunConfigs.d.ts +9 -0
- package/dist/domains/manage/routes/evals/datasetRunConfigs.js +402 -0
- package/dist/domains/manage/routes/evals/datasetRuns.d.ts +9 -0
- package/dist/domains/manage/routes/evals/datasetRuns.js +256 -0
- package/dist/domains/manage/routes/evals/datasets.d.ts +9 -0
- package/dist/domains/manage/routes/evals/datasets.js +238 -0
- package/dist/domains/manage/routes/evals/evaluationJobConfigEvaluatorRelations.d.ts +9 -0
- package/dist/domains/manage/routes/evals/evaluationJobConfigEvaluatorRelations.js +146 -0
- package/dist/domains/manage/routes/evals/evaluationJobConfigs.d.ts +9 -0
- package/dist/domains/manage/routes/evals/evaluationJobConfigs.js +364 -0
- package/dist/domains/manage/routes/evals/evaluationResults.d.ts +7 -0
- package/dist/domains/manage/routes/evals/evaluationResults.js +192 -0
- package/dist/domains/manage/routes/evals/evaluationRunConfigs.d.ts +9 -0
- package/dist/domains/manage/routes/evals/evaluationRunConfigs.js +403 -0
- package/dist/domains/manage/routes/evals/evaluationSuiteConfigEvaluatorRelations.d.ts +9 -0
- package/dist/domains/manage/routes/evals/evaluationSuiteConfigEvaluatorRelations.js +146 -0
- package/dist/domains/manage/routes/evals/evaluationSuiteConfigs.d.ts +9 -0
- package/dist/domains/manage/routes/evals/evaluationSuiteConfigs.js +246 -0
- package/dist/domains/manage/routes/evals/evaluators.d.ts +9 -0
- package/dist/domains/manage/routes/evals/evaluators.js +281 -0
- package/dist/domains/manage/routes/evals/index.d.ts +9 -0
- package/dist/domains/manage/routes/evals/index.js +26 -0
- package/dist/domains/manage/routes/externalAgents.d.ts +9 -0
- package/dist/domains/manage/routes/externalAgents.js +199 -0
- package/dist/domains/manage/routes/functionTools.d.ts +9 -0
- package/dist/domains/manage/routes/functionTools.js +256 -0
- package/dist/domains/manage/routes/functions.d.ts +9 -0
- package/dist/domains/manage/routes/functions.js +285 -0
- package/dist/domains/manage/routes/index.d.ts +7 -0
- package/dist/domains/manage/routes/index.js +68 -0
- package/dist/domains/manage/routes/invitations.d.ts +9 -0
- package/dist/domains/manage/routes/invitations.js +41 -0
- package/dist/domains/manage/routes/mcp.d.ts +7 -0
- package/dist/domains/manage/routes/mcp.js +45 -0
- package/dist/domains/manage/routes/mcpCatalog.d.ts +9 -0
- package/dist/domains/manage/routes/mcpCatalog.js +454 -0
- package/dist/domains/manage/routes/oauth.d.ts +10 -0
- package/dist/domains/manage/routes/oauth.js +327 -0
- package/dist/domains/manage/routes/playgroundToken.d.ts +9 -0
- package/dist/domains/manage/routes/playgroundToken.js +127 -0
- package/dist/domains/manage/routes/projectFull.d.ts +9 -0
- package/dist/domains/manage/routes/projectFull.js +304 -0
- package/dist/domains/manage/routes/projectMembers.d.ts +9 -0
- package/dist/domains/manage/routes/projectMembers.js +201 -0
- package/dist/domains/manage/routes/projectPermissions.d.ts +9 -0
- package/dist/domains/manage/routes/projectPermissions.js +68 -0
- package/dist/domains/manage/routes/projects.d.ts +9 -0
- package/dist/domains/manage/routes/projects.js +279 -0
- package/dist/domains/manage/routes/ref.d.ts +9 -0
- package/dist/domains/manage/routes/ref.js +33 -0
- package/dist/domains/manage/routes/signoz.d.ts +10 -0
- package/dist/domains/manage/routes/signoz.js +159 -0
- package/dist/domains/manage/routes/subAgentArtifactComponents.d.ts +9 -0
- package/dist/domains/manage/routes/subAgentArtifactComponents.js +202 -0
- package/dist/domains/manage/routes/subAgentDataComponents.d.ts +9 -0
- package/dist/domains/manage/routes/subAgentDataComponents.js +201 -0
- package/dist/domains/manage/routes/subAgentExternalAgentRelations.d.ts +9 -0
- package/dist/domains/manage/routes/subAgentExternalAgentRelations.js +216 -0
- package/dist/domains/manage/routes/subAgentFunctionTools.d.ts +9 -0
- package/dist/domains/manage/routes/subAgentFunctionTools.js +205 -0
- package/dist/domains/manage/routes/subAgentRelations.d.ts +9 -0
- package/dist/domains/manage/routes/subAgentRelations.js +263 -0
- package/dist/domains/manage/routes/subAgentTeamAgentRelations.d.ts +9 -0
- package/dist/domains/manage/routes/subAgentTeamAgentRelations.js +216 -0
- package/dist/domains/manage/routes/subAgentToolRelations.d.ts +9 -0
- package/dist/domains/manage/routes/subAgentToolRelations.js +289 -0
- package/dist/domains/manage/routes/subAgents.d.ts +9 -0
- package/dist/domains/manage/routes/subAgents.js +220 -0
- package/dist/domains/manage/routes/thirdPartyMCPServers.d.ts +9 -0
- package/dist/domains/manage/routes/thirdPartyMCPServers.js +72 -0
- package/dist/domains/manage/routes/tools.d.ts +9 -0
- package/dist/domains/manage/routes/tools.js +261 -0
- package/dist/domains/manage/routes/triggers.d.ts +9 -0
- package/dist/domains/manage/routes/triggers.js +455 -0
- package/dist/domains/manage/routes/userOrganizations.d.ts +9 -0
- package/dist/domains/manage/routes/userOrganizations.js +58 -0
- package/dist/domains/run/a2a/client.d.ts +186 -0
- package/dist/domains/run/a2a/client.js +524 -0
- package/dist/domains/run/a2a/handlers.d.ts +7 -0
- package/dist/domains/run/a2a/handlers.js +574 -0
- package/dist/domains/run/a2a/transfer.d.ts +27 -0
- package/dist/domains/run/a2a/transfer.js +50 -0
- package/dist/domains/run/a2a/types.d.ts +75 -0
- package/dist/domains/run/a2a/types.js +22 -0
- package/dist/domains/run/agents/Agent.d.ts +273 -0
- package/dist/domains/run/agents/Agent.js +2104 -0
- package/dist/domains/run/agents/ModelFactory.d.ts +63 -0
- package/dist/domains/run/agents/ModelFactory.js +194 -0
- package/dist/domains/run/agents/SystemPromptBuilder.d.ts +21 -0
- package/dist/domains/run/agents/SystemPromptBuilder.js +48 -0
- package/dist/domains/run/agents/ToolSessionManager.d.ts +63 -0
- package/dist/domains/run/agents/ToolSessionManager.js +146 -0
- package/dist/domains/run/agents/generateTaskHandler.d.ts +44 -0
- package/dist/domains/run/agents/generateTaskHandler.js +396 -0
- package/dist/domains/run/agents/relationTools.d.ts +64 -0
- package/dist/domains/run/agents/relationTools.js +365 -0
- package/dist/domains/run/agents/types.d.ts +31 -0
- package/dist/domains/run/agents/types.js +1 -0
- package/dist/domains/run/agents/versions/v1/Phase1Config.d.ts +29 -0
- package/dist/domains/run/agents/versions/v1/Phase1Config.js +458 -0
- package/dist/domains/run/agents/versions/v1/Phase2Config.d.ts +33 -0
- package/dist/domains/run/agents/versions/v1/Phase2Config.js +341 -0
- package/dist/domains/run/constants/execution-limits/defaults.d.ts +51 -0
- package/dist/domains/run/constants/execution-limits/defaults.js +52 -0
- package/dist/domains/run/constants/execution-limits/index.d.ts +6 -0
- package/dist/domains/run/constants/execution-limits/index.js +21 -0
- package/dist/domains/run/context/ContextFetcher.d.ts +68 -0
- package/dist/domains/run/context/ContextFetcher.js +276 -0
- package/dist/domains/run/context/ContextResolver.d.ts +56 -0
- package/dist/domains/run/context/ContextResolver.js +273 -0
- package/dist/domains/run/context/context.d.ts +19 -0
- package/dist/domains/run/context/context.js +108 -0
- package/dist/domains/run/context/contextCache.d.ts +56 -0
- package/dist/domains/run/context/contextCache.js +174 -0
- package/dist/domains/run/context/index.d.ts +6 -0
- package/dist/domains/run/context/index.js +7 -0
- package/dist/domains/run/context/validation.d.ts +39 -0
- package/dist/domains/run/context/validation.js +255 -0
- package/dist/domains/run/data/agent.d.ts +7 -0
- package/dist/domains/run/data/agent.js +67 -0
- package/dist/domains/run/data/agents.d.ts +34 -0
- package/dist/domains/run/data/agents.js +131 -0
- package/dist/domains/run/data/conversations.d.ts +129 -0
- package/dist/domains/run/data/conversations.js +517 -0
- package/dist/domains/run/handlers/executionHandler.d.ts +44 -0
- package/dist/domains/run/handlers/executionHandler.js +485 -0
- package/dist/domains/run/index.d.ts +13 -0
- package/dist/domains/run/index.js +21 -0
- package/dist/domains/run/routes/agents.d.ts +13 -0
- package/dist/domains/run/routes/agents.js +141 -0
- package/dist/domains/run/routes/chat.d.ts +14 -0
- package/dist/domains/run/routes/chat.js +300 -0
- package/dist/domains/run/routes/chatDataStream.d.ts +14 -0
- package/dist/domains/run/routes/chatDataStream.js +381 -0
- package/dist/domains/run/routes/mcp.d.ts +14 -0
- package/dist/domains/run/routes/mcp.js +483 -0
- package/dist/domains/run/routes/webhooks.d.ts +15 -0
- package/dist/domains/run/routes/webhooks.js +416 -0
- package/dist/domains/run/services/AgentSession.d.ts +354 -0
- package/dist/domains/run/services/AgentSession.js +1203 -0
- package/dist/domains/run/services/ArtifactParser.d.ts +105 -0
- package/dist/domains/run/services/ArtifactParser.js +338 -0
- package/dist/domains/run/services/ArtifactService.d.ts +122 -0
- package/dist/domains/run/services/ArtifactService.js +629 -0
- package/dist/domains/run/services/BaseCompressor.d.ts +183 -0
- package/dist/domains/run/services/BaseCompressor.js +500 -0
- package/dist/domains/run/services/ConversationCompressor.d.ts +32 -0
- package/dist/domains/run/services/ConversationCompressor.js +91 -0
- package/dist/domains/run/services/IncrementalStreamParser.d.ts +98 -0
- package/dist/domains/run/services/IncrementalStreamParser.js +327 -0
- package/dist/domains/run/services/MidGenerationCompressor.d.ts +63 -0
- package/dist/domains/run/services/MidGenerationCompressor.js +104 -0
- package/dist/domains/run/services/PendingToolApprovalManager.d.ts +62 -0
- package/dist/domains/run/services/PendingToolApprovalManager.js +133 -0
- package/dist/domains/run/services/ResponseFormatter.d.ts +39 -0
- package/dist/domains/run/services/ResponseFormatter.js +152 -0
- package/dist/domains/run/services/evaluationRunConfigMatcher.d.ts +4 -0
- package/dist/domains/run/services/evaluationRunConfigMatcher.js +7 -0
- package/dist/domains/run/tools/NativeSandboxExecutor.d.ts +38 -0
- package/dist/domains/run/tools/NativeSandboxExecutor.js +432 -0
- package/dist/domains/run/tools/SandboxExecutorFactory.d.ts +36 -0
- package/dist/domains/run/tools/SandboxExecutorFactory.js +80 -0
- package/dist/domains/run/tools/VercelSandboxExecutor.d.ts +71 -0
- package/dist/domains/run/tools/VercelSandboxExecutor.js +340 -0
- package/dist/domains/run/tools/distill-conversation-history-tool.d.ts +62 -0
- package/dist/domains/run/tools/distill-conversation-history-tool.js +206 -0
- package/dist/domains/run/tools/distill-conversation-tool.d.ts +41 -0
- package/dist/domains/run/tools/distill-conversation-tool.js +141 -0
- package/dist/domains/run/tools/sandbox-utils.d.ts +18 -0
- package/dist/domains/run/tools/sandbox-utils.js +53 -0
- package/dist/domains/run/types/chat.d.ts +27 -0
- package/dist/domains/run/types/chat.js +1 -0
- package/dist/domains/run/types/executionContext.d.ts +40 -0
- package/dist/domains/run/types/executionContext.js +28 -0
- package/dist/domains/run/types/xml.d.ts +5 -0
- package/dist/domains/run/utils/SchemaProcessor.d.ts +52 -0
- package/dist/domains/run/utils/SchemaProcessor.js +182 -0
- package/dist/domains/run/utils/agent-operations.d.ts +62 -0
- package/dist/domains/run/utils/agent-operations.js +53 -0
- package/dist/domains/run/utils/artifact-component-schema.d.ts +42 -0
- package/dist/domains/run/utils/artifact-component-schema.js +186 -0
- package/dist/domains/run/utils/cleanup.d.ts +21 -0
- package/dist/domains/run/utils/cleanup.js +59 -0
- package/dist/domains/run/utils/data-component-schema.d.ts +2 -0
- package/dist/domains/run/utils/data-component-schema.js +3 -0
- package/dist/domains/run/utils/default-status-schemas.d.ts +20 -0
- package/dist/domains/run/utils/default-status-schemas.js +24 -0
- package/dist/domains/run/utils/json-postprocessor.d.ts +13 -0
- package/dist/domains/run/utils/json-postprocessor.js +19 -0
- package/dist/domains/run/utils/model-context-utils.d.ts +39 -0
- package/dist/domains/run/utils/model-context-utils.js +181 -0
- package/dist/domains/run/utils/model-resolver.d.ts +6 -0
- package/dist/domains/run/utils/model-resolver.js +24 -0
- package/dist/domains/run/utils/project.d.ts +207 -0
- package/dist/domains/run/utils/project.js +315 -0
- package/dist/domains/run/utils/schema-validation.d.ts +44 -0
- package/dist/domains/run/utils/schema-validation.js +97 -0
- package/dist/domains/run/utils/stream-helpers.d.ts +193 -0
- package/dist/domains/run/utils/stream-helpers.js +510 -0
- package/dist/domains/run/utils/stream-registry.d.ts +22 -0
- package/dist/domains/run/utils/stream-registry.js +33 -0
- package/dist/domains/run/utils/token-estimator.d.ts +23 -0
- package/dist/domains/run/utils/token-estimator.js +17 -0
- package/dist/domains/run/utils/tracer.d.ts +7 -0
- package/dist/domains/run/utils/tracer.js +7 -0
- package/dist/env.d.ts +89 -0
- package/dist/env.js +69 -0
- package/dist/factory.d.ts +1535 -0
- package/dist/factory.js +42 -0
- package/dist/index.d.ts +1530 -0
- package/dist/index.js +59 -0
- package/dist/initialization.d.ts +6 -0
- package/dist/initialization.js +65 -0
- package/dist/instrumentation.d.ts +17 -0
- package/dist/instrumentation.js +68 -0
- package/dist/logger.d.ts +2 -0
- package/dist/logger.js +3 -0
- package/dist/middleware/branchScopedDb.d.ts +31 -0
- package/dist/middleware/branchScopedDb.js +137 -0
- package/dist/middleware/cors.d.ts +36 -0
- package/dist/middleware/cors.js +131 -0
- package/dist/middleware/errorHandler.d.ts +12 -0
- package/dist/middleware/errorHandler.js +88 -0
- package/dist/middleware/evalsAuth.d.ts +16 -0
- package/dist/middleware/evalsAuth.js +52 -0
- package/dist/middleware/index.d.ts +8 -0
- package/dist/middleware/index.js +9 -0
- package/dist/middleware/manageAuth.d.ts +25 -0
- package/dist/middleware/manageAuth.js +80 -0
- package/dist/middleware/projectAccess.d.ts +31 -0
- package/dist/middleware/projectAccess.js +118 -0
- package/dist/middleware/projectConfig.d.ts +25 -0
- package/dist/middleware/projectConfig.js +89 -0
- package/dist/middleware/ref.d.ts +61 -0
- package/dist/middleware/ref.js +239 -0
- package/dist/middleware/requirePermission.d.ts +14 -0
- package/dist/middleware/requirePermission.js +80 -0
- package/dist/middleware/runAuth.d.ts +29 -0
- package/dist/middleware/runAuth.js +253 -0
- package/dist/middleware/sessionAuth.d.ts +17 -0
- package/dist/middleware/sessionAuth.js +58 -0
- package/dist/middleware/tenantAccess.d.ts +22 -0
- package/dist/middleware/tenantAccess.js +63 -0
- package/dist/middleware/tracing.d.ts +7 -0
- package/dist/middleware/tracing.js +50 -0
- package/dist/openapi.d.ts +7 -0
- package/dist/openapi.js +156 -0
- package/dist/ssoHelpers.d.ts +20 -0
- package/dist/ssoHelpers.js +51 -0
- package/dist/templates/v1/phase1/system-prompt.js +5 -0
- package/dist/templates/v1/phase1/thinking-preparation.js +5 -0
- package/dist/templates/v1/phase1/tool.js +5 -0
- package/dist/templates/v1/phase2/data-component.js +5 -0
- package/dist/templates/v1/phase2/data-components.js +5 -0
- package/dist/templates/v1/phase2/system-prompt.js +5 -0
- package/dist/templates/v1/shared/artifact-retrieval-guidance.js +5 -0
- package/dist/templates/v1/shared/artifact.js +5 -0
- package/dist/types/app.d.ts +64 -0
- package/dist/types/app.js +1 -0
- package/dist/types/index.d.ts +2 -0
- package/dist/types/index.js +1 -0
- package/dist/types/runExecutionContext.d.ts +25 -0
- package/dist/types/runExecutionContext.js +28 -0
- package/dist/utils/oauthService.d.ts +71 -0
- package/dist/utils/oauthService.js +106 -0
- package/dist/utils/signozHelpers.d.ts +9 -0
- package/dist/utils/signozHelpers.js +33 -0
- package/dist/utils/speakeasy.d.ts +93 -0
- package/dist/utils/speakeasy.js +44 -0
- package/dist/utils/tempApiKeys.d.ts +17 -0
- package/dist/utils/tempApiKeys.js +26 -0
- package/dist/utils/workflowApiHelpers.d.ts +1 -0
- package/dist/utils/workflowApiHelpers.js +1 -0
- package/package.json +125 -0
|
@@ -0,0 +1,279 @@
|
|
|
1
|
+
import manageDbClient_default from "../../../data/db/manageDbClient.js";
|
|
2
|
+
import runDbClient_default from "../../../data/db/runDbClient.js";
|
|
3
|
+
import { requireProjectPermission } from "../../../middleware/projectAccess.js";
|
|
4
|
+
import { speakeasyOffsetLimitPagination } from "../../../utils/speakeasy.js";
|
|
5
|
+
import { requirePermission } from "../../../middleware/requirePermission.js";
|
|
6
|
+
import { OpenAPIHono, createRoute } from "@hono/zod-openapi";
|
|
7
|
+
import { ErrorResponseSchema, PaginationQueryParamsSchema, ProjectApiInsertSchema, ProjectApiUpdateSchema, ProjectListResponse, ProjectResponse, TenantIdParamsSchema, TenantParamsSchema, cascadeDeleteByProject, commonGetErrorResponses, createApiError, createProject, createProjectMetadataAndBranch, deleteProject, deleteProjectWithBranch, doltCheckout, getProject, getProjectMainBranchName, isAuthzEnabled, listAccessibleProjectIds, listProjectsWithMetadataPaginated, removeProjectFromSpiceDb, syncProjectToSpiceDb, updateProject } from "@inkeep/agents-core";
|
|
8
|
+
|
|
9
|
+
//#region src/domains/manage/routes/projects.ts
|
|
10
|
+
const app = new OpenAPIHono();
|
|
11
|
+
app.use("/", async (c, next) => {
|
|
12
|
+
if (c.req.method === "POST") return requirePermission({ project: ["create"] })(c, next);
|
|
13
|
+
return next();
|
|
14
|
+
});
|
|
15
|
+
app.use("/:id", async (c, next) => {
|
|
16
|
+
if (c.req.method === "GET") return requireProjectPermission("view")(c, next);
|
|
17
|
+
if (c.req.method === "PATCH") return requireProjectPermission("edit")(c, next);
|
|
18
|
+
if (c.req.method === "DELETE") return requireProjectPermission("edit")(c, next);
|
|
19
|
+
return next();
|
|
20
|
+
});
|
|
21
|
+
app.openapi(createRoute({
|
|
22
|
+
method: "get",
|
|
23
|
+
path: "/",
|
|
24
|
+
summary: "List Projects",
|
|
25
|
+
description: "List all projects within a tenant with pagination. When authorization is enabled, only returns projects the user has access to.",
|
|
26
|
+
operationId: "list-projects",
|
|
27
|
+
tags: ["Projects"],
|
|
28
|
+
request: {
|
|
29
|
+
params: TenantParamsSchema,
|
|
30
|
+
query: PaginationQueryParamsSchema
|
|
31
|
+
},
|
|
32
|
+
responses: {
|
|
33
|
+
200: {
|
|
34
|
+
description: "List of projects retrieved successfully",
|
|
35
|
+
content: { "application/json": { schema: ProjectListResponse } }
|
|
36
|
+
},
|
|
37
|
+
...commonGetErrorResponses
|
|
38
|
+
},
|
|
39
|
+
...speakeasyOffsetLimitPagination
|
|
40
|
+
}), async (c) => {
|
|
41
|
+
const configDb = c.get("db");
|
|
42
|
+
const { tenantId } = c.req.valid("param");
|
|
43
|
+
const userId = c.get("userId");
|
|
44
|
+
const tenantRole = c.get("tenantRole") || "member";
|
|
45
|
+
const page = Number(c.req.query("page")) || 1;
|
|
46
|
+
const limit = Math.min(Number(c.req.query("limit")) || 10, 100);
|
|
47
|
+
let accessibleIds;
|
|
48
|
+
if (isAuthzEnabled(tenantId) && userId) {
|
|
49
|
+
const result$1 = await listAccessibleProjectIds({
|
|
50
|
+
tenantId,
|
|
51
|
+
userId,
|
|
52
|
+
orgRole: tenantRole
|
|
53
|
+
});
|
|
54
|
+
if (result$1 !== "all") accessibleIds = result$1;
|
|
55
|
+
}
|
|
56
|
+
const result = await listProjectsWithMetadataPaginated(runDbClient_default, configDb)({
|
|
57
|
+
tenantId,
|
|
58
|
+
pagination: {
|
|
59
|
+
page,
|
|
60
|
+
limit
|
|
61
|
+
},
|
|
62
|
+
projectIds: accessibleIds
|
|
63
|
+
});
|
|
64
|
+
const transformedData = result.data.map((project) => ({
|
|
65
|
+
id: project.id,
|
|
66
|
+
tenantId: project.tenantId,
|
|
67
|
+
name: project.name ?? project.id,
|
|
68
|
+
description: project.description,
|
|
69
|
+
models: project.models,
|
|
70
|
+
stopWhen: project.stopWhen,
|
|
71
|
+
createdAt: project.createdAt,
|
|
72
|
+
updatedAt: project.configUpdatedAt ?? project.createdAt
|
|
73
|
+
}));
|
|
74
|
+
return c.json({
|
|
75
|
+
data: transformedData,
|
|
76
|
+
pagination: result.pagination
|
|
77
|
+
});
|
|
78
|
+
});
|
|
79
|
+
app.openapi(createRoute({
|
|
80
|
+
method: "get",
|
|
81
|
+
path: "/{id}",
|
|
82
|
+
summary: "Get Project",
|
|
83
|
+
description: "Get a single project by ID",
|
|
84
|
+
operationId: "get-project-by-id",
|
|
85
|
+
tags: ["Projects"],
|
|
86
|
+
request: { params: TenantIdParamsSchema },
|
|
87
|
+
responses: {
|
|
88
|
+
200: {
|
|
89
|
+
description: "Project found",
|
|
90
|
+
content: { "application/json": { schema: ProjectResponse } }
|
|
91
|
+
},
|
|
92
|
+
...commonGetErrorResponses
|
|
93
|
+
}
|
|
94
|
+
}), async (c) => {
|
|
95
|
+
const db = c.get("db");
|
|
96
|
+
const { tenantId, id } = c.req.valid("param");
|
|
97
|
+
const project = await getProject(db)({ scopes: {
|
|
98
|
+
tenantId,
|
|
99
|
+
projectId: id
|
|
100
|
+
} });
|
|
101
|
+
if (!project) throw createApiError({
|
|
102
|
+
code: "not_found",
|
|
103
|
+
message: "Project not found"
|
|
104
|
+
});
|
|
105
|
+
return c.json({ data: project });
|
|
106
|
+
});
|
|
107
|
+
app.openapi(createRoute({
|
|
108
|
+
method: "post",
|
|
109
|
+
path: "/",
|
|
110
|
+
summary: "Create Project",
|
|
111
|
+
description: "Create a new project. When authorization is enabled, the creator is automatically granted admin role.",
|
|
112
|
+
operationId: "create-project",
|
|
113
|
+
tags: ["Projects"],
|
|
114
|
+
request: {
|
|
115
|
+
params: TenantParamsSchema,
|
|
116
|
+
body: { content: { "application/json": { schema: ProjectApiInsertSchema } } }
|
|
117
|
+
},
|
|
118
|
+
responses: {
|
|
119
|
+
201: {
|
|
120
|
+
description: "Project created successfully",
|
|
121
|
+
content: { "application/json": { schema: ProjectResponse } }
|
|
122
|
+
},
|
|
123
|
+
409: {
|
|
124
|
+
description: "Project already exists",
|
|
125
|
+
content: { "application/json": { schema: ErrorResponseSchema } }
|
|
126
|
+
},
|
|
127
|
+
...commonGetErrorResponses
|
|
128
|
+
}
|
|
129
|
+
}), async (c) => {
|
|
130
|
+
const configDb = c.get("db");
|
|
131
|
+
const userId = c.get("userId");
|
|
132
|
+
const { tenantId } = c.req.valid("param");
|
|
133
|
+
const body = c.req.valid("json");
|
|
134
|
+
try {
|
|
135
|
+
const runtimeProject = await createProjectMetadataAndBranch(runDbClient_default, configDb)({
|
|
136
|
+
tenantId,
|
|
137
|
+
projectId: body.id,
|
|
138
|
+
createdBy: userId
|
|
139
|
+
});
|
|
140
|
+
const projectMainBranch = getProjectMainBranchName(tenantId, body.id);
|
|
141
|
+
await doltCheckout(configDb)({ branch: projectMainBranch });
|
|
142
|
+
const newResolvedRef = {
|
|
143
|
+
type: "branch",
|
|
144
|
+
name: projectMainBranch,
|
|
145
|
+
hash: ""
|
|
146
|
+
};
|
|
147
|
+
c.set("resolvedRef", newResolvedRef);
|
|
148
|
+
const projectConfig = await createProject(configDb)({
|
|
149
|
+
tenantId,
|
|
150
|
+
...body
|
|
151
|
+
});
|
|
152
|
+
if (isAuthzEnabled(tenantId)) {
|
|
153
|
+
if (!userId) throw createApiError({
|
|
154
|
+
code: "unauthorized",
|
|
155
|
+
message: "User not found"
|
|
156
|
+
});
|
|
157
|
+
try {
|
|
158
|
+
await syncProjectToSpiceDb({
|
|
159
|
+
tenantId,
|
|
160
|
+
projectId: body.id,
|
|
161
|
+
creatorUserId: userId
|
|
162
|
+
});
|
|
163
|
+
} catch (syncError) {
|
|
164
|
+
console.warn("Failed to sync project to SpiceDB:", syncError);
|
|
165
|
+
}
|
|
166
|
+
}
|
|
167
|
+
return c.json({ data: {
|
|
168
|
+
...projectConfig,
|
|
169
|
+
mainBranchName: runtimeProject.mainBranchName
|
|
170
|
+
} }, 201);
|
|
171
|
+
} catch (error) {
|
|
172
|
+
if (error?.cause?.code === "23505" || error?.message?.includes("already exists")) throw createApiError({
|
|
173
|
+
code: "conflict",
|
|
174
|
+
message: "Project with this ID already exists"
|
|
175
|
+
});
|
|
176
|
+
throw error;
|
|
177
|
+
}
|
|
178
|
+
});
|
|
179
|
+
app.openapi(createRoute({
|
|
180
|
+
method: "patch",
|
|
181
|
+
path: "/{id}",
|
|
182
|
+
summary: "Update Project",
|
|
183
|
+
description: "Update an existing project",
|
|
184
|
+
operationId: "update-project",
|
|
185
|
+
tags: ["Projects"],
|
|
186
|
+
request: {
|
|
187
|
+
params: TenantIdParamsSchema,
|
|
188
|
+
body: { content: { "application/json": { schema: ProjectApiUpdateSchema } } }
|
|
189
|
+
},
|
|
190
|
+
responses: {
|
|
191
|
+
200: {
|
|
192
|
+
description: "Project updated successfully",
|
|
193
|
+
content: { "application/json": { schema: ProjectResponse } }
|
|
194
|
+
},
|
|
195
|
+
...commonGetErrorResponses
|
|
196
|
+
}
|
|
197
|
+
}), async (c) => {
|
|
198
|
+
const db = c.get("db");
|
|
199
|
+
const { tenantId, id } = c.req.valid("param");
|
|
200
|
+
const body = c.req.valid("json");
|
|
201
|
+
const project = await updateProject(db)({
|
|
202
|
+
scopes: {
|
|
203
|
+
tenantId,
|
|
204
|
+
projectId: id
|
|
205
|
+
},
|
|
206
|
+
data: body
|
|
207
|
+
});
|
|
208
|
+
if (!project) throw createApiError({
|
|
209
|
+
code: "not_found",
|
|
210
|
+
message: "Project not found"
|
|
211
|
+
});
|
|
212
|
+
return c.json({ data: project });
|
|
213
|
+
});
|
|
214
|
+
app.openapi(createRoute({
|
|
215
|
+
method: "delete",
|
|
216
|
+
path: "/{id}",
|
|
217
|
+
summary: "Delete Project",
|
|
218
|
+
description: "Delete a project and its branch. Must be called from the main branch.",
|
|
219
|
+
operationId: "delete-project",
|
|
220
|
+
tags: ["Projects"],
|
|
221
|
+
request: { params: TenantIdParamsSchema },
|
|
222
|
+
responses: {
|
|
223
|
+
204: { description: "Project deleted successfully" },
|
|
224
|
+
409: {
|
|
225
|
+
description: "Cannot delete project with existing resources",
|
|
226
|
+
content: { "application/json": { schema: ErrorResponseSchema } }
|
|
227
|
+
},
|
|
228
|
+
...commonGetErrorResponses
|
|
229
|
+
}
|
|
230
|
+
}), async (c) => {
|
|
231
|
+
const configDb = c.get("db");
|
|
232
|
+
const resolvedRef = c.get("resolvedRef");
|
|
233
|
+
const { tenantId, id } = c.req.valid("param");
|
|
234
|
+
const expectedMainBranch = `${tenantId}_${id}_main`;
|
|
235
|
+
if (resolvedRef?.name !== expectedMainBranch) throw createApiError({
|
|
236
|
+
code: "bad_request",
|
|
237
|
+
message: "Project deletion must be performed from the main branch"
|
|
238
|
+
});
|
|
239
|
+
try {
|
|
240
|
+
await cascadeDeleteByProject(runDbClient_default)({
|
|
241
|
+
scopes: {
|
|
242
|
+
tenantId,
|
|
243
|
+
projectId: id
|
|
244
|
+
},
|
|
245
|
+
fullBranchName: resolvedRef.name
|
|
246
|
+
});
|
|
247
|
+
await deleteProject(configDb)({ scopes: {
|
|
248
|
+
tenantId,
|
|
249
|
+
projectId: id
|
|
250
|
+
} });
|
|
251
|
+
await doltCheckout(configDb)({ branch: "main" });
|
|
252
|
+
if (!await deleteProjectWithBranch(runDbClient_default, manageDbClient_default)({
|
|
253
|
+
tenantId,
|
|
254
|
+
projectId: id
|
|
255
|
+
})) throw createApiError({
|
|
256
|
+
code: "not_found",
|
|
257
|
+
message: "Project not found"
|
|
258
|
+
});
|
|
259
|
+
if (isAuthzEnabled(tenantId)) try {
|
|
260
|
+
await removeProjectFromSpiceDb({
|
|
261
|
+
tenantId,
|
|
262
|
+
projectId: id
|
|
263
|
+
});
|
|
264
|
+
} catch (syncError) {
|
|
265
|
+
console.warn("Failed to remove project from SpiceDB:", syncError);
|
|
266
|
+
}
|
|
267
|
+
return c.body(null, 204);
|
|
268
|
+
} catch (error) {
|
|
269
|
+
if (error.message?.includes("Cannot delete project with existing resources")) throw createApiError({
|
|
270
|
+
code: "conflict",
|
|
271
|
+
message: "Cannot delete project with existing resources"
|
|
272
|
+
});
|
|
273
|
+
throw error;
|
|
274
|
+
}
|
|
275
|
+
});
|
|
276
|
+
var projects_default = app;
|
|
277
|
+
|
|
278
|
+
//#endregion
|
|
279
|
+
export { projects_default as default };
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import { ManageAppVariables } from "../../../types/app.js";
|
|
2
|
+
import { OpenAPIHono } from "@hono/zod-openapi";
|
|
3
|
+
|
|
4
|
+
//#region src/domains/manage/routes/ref.d.ts
|
|
5
|
+
declare const app: OpenAPIHono<{
|
|
6
|
+
Variables: ManageAppVariables;
|
|
7
|
+
}, {}, "/">;
|
|
8
|
+
//#endregion
|
|
9
|
+
export { app as default };
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
import { OpenAPIHono, createRoute, z } from "@hono/zod-openapi";
|
|
2
|
+
import { ResolvedRefSchema, TenantProjectParamsSchema, commonGetErrorResponses, createApiError } from "@inkeep/agents-core";
|
|
3
|
+
|
|
4
|
+
//#region src/domains/manage/routes/ref.ts
|
|
5
|
+
const app = new OpenAPIHono();
|
|
6
|
+
const ResolvedRefResponseSchema = z.object({ data: ResolvedRefSchema }).openapi("ResolvedRefResponse");
|
|
7
|
+
app.openapi(createRoute({
|
|
8
|
+
method: "get",
|
|
9
|
+
path: "/resolve",
|
|
10
|
+
summary: "Resolve Ref",
|
|
11
|
+
description: "Resolve a ref string (branch name, tag name, or commit hash) to its full resolved ref with type and commit hash. Pass the ref as a query parameter.",
|
|
12
|
+
operationId: "resolve-ref",
|
|
13
|
+
tags: ["Refs"],
|
|
14
|
+
request: { params: TenantProjectParamsSchema },
|
|
15
|
+
responses: {
|
|
16
|
+
200: {
|
|
17
|
+
description: "Ref resolved successfully",
|
|
18
|
+
content: { "application/json": { schema: ResolvedRefResponseSchema } }
|
|
19
|
+
},
|
|
20
|
+
...commonGetErrorResponses
|
|
21
|
+
}
|
|
22
|
+
}), async (c) => {
|
|
23
|
+
const resolvedRef = c.get("resolvedRef");
|
|
24
|
+
if (!resolvedRef) throw createApiError({
|
|
25
|
+
code: "not_found",
|
|
26
|
+
message: "Could not resolve ref"
|
|
27
|
+
});
|
|
28
|
+
return c.json({ data: resolvedRef });
|
|
29
|
+
});
|
|
30
|
+
var ref_default = app;
|
|
31
|
+
|
|
32
|
+
//#endregion
|
|
33
|
+
export { ref_default as default };
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import { ManageAppVariables } from "../../../types/app.js";
|
|
2
|
+
import { Hono } from "hono";
|
|
3
|
+
import * as hono_types5 from "hono/types";
|
|
4
|
+
|
|
5
|
+
//#region src/domains/manage/routes/signoz.d.ts
|
|
6
|
+
declare const app: Hono<{
|
|
7
|
+
Variables: ManageAppVariables;
|
|
8
|
+
}, hono_types5.BlankSchema, "/">;
|
|
9
|
+
//#endregion
|
|
10
|
+
export { app as default };
|
|
@@ -0,0 +1,159 @@
|
|
|
1
|
+
import { getLogger as getLogger$1 } from "../../../logger.js";
|
|
2
|
+
import { env } from "../../../env.js";
|
|
3
|
+
import { enforceProjectFilter } from "../../../utils/signozHelpers.js";
|
|
4
|
+
import { Hono } from "hono";
|
|
5
|
+
import { createApiError, projectExists } from "@inkeep/agents-core";
|
|
6
|
+
import axios from "axios";
|
|
7
|
+
|
|
8
|
+
//#region src/domains/manage/routes/signoz.ts
|
|
9
|
+
const logger = getLogger$1("signoz-proxy");
|
|
10
|
+
const app = new Hono();
|
|
11
|
+
app.post("/query", async (c) => {
|
|
12
|
+
let payload = await c.req.json();
|
|
13
|
+
const requestedProjectId = payload.projectId;
|
|
14
|
+
const tenantId = c.get("tenantId");
|
|
15
|
+
const db = c.get("db");
|
|
16
|
+
if (!tenantId) throw createApiError({
|
|
17
|
+
code: "unauthorized",
|
|
18
|
+
message: "Tenant ID not found"
|
|
19
|
+
});
|
|
20
|
+
logger.debug({
|
|
21
|
+
tenantId,
|
|
22
|
+
projectId: requestedProjectId,
|
|
23
|
+
hasProjectId: !!requestedProjectId
|
|
24
|
+
}, "Processing SigNoz query request");
|
|
25
|
+
if (requestedProjectId) {
|
|
26
|
+
if (!await projectExists(db)({
|
|
27
|
+
tenantId,
|
|
28
|
+
projectId: requestedProjectId
|
|
29
|
+
})) {
|
|
30
|
+
logger.warn({
|
|
31
|
+
tenantId,
|
|
32
|
+
projectId: requestedProjectId
|
|
33
|
+
}, "Project not found or access denied");
|
|
34
|
+
return c.json({
|
|
35
|
+
error: "Forbidden",
|
|
36
|
+
message: "You do not have access to this project"
|
|
37
|
+
}, 403);
|
|
38
|
+
}
|
|
39
|
+
payload = enforceProjectFilter(payload, requestedProjectId);
|
|
40
|
+
logger.debug({ projectId: requestedProjectId }, "Project filter enforced");
|
|
41
|
+
}
|
|
42
|
+
const signozUrl = env.SIGNOZ_URL || env.PUBLIC_SIGNOZ_URL;
|
|
43
|
+
const signozApiKey = env.SIGNOZ_API_KEY;
|
|
44
|
+
if (!signozUrl || !signozApiKey) {
|
|
45
|
+
logger.error({}, "SigNoz not configured");
|
|
46
|
+
return c.json({
|
|
47
|
+
error: "Service Unavailable",
|
|
48
|
+
message: "SigNoz is not configured"
|
|
49
|
+
}, 500);
|
|
50
|
+
}
|
|
51
|
+
try {
|
|
52
|
+
const signozEndpoint = `${signozUrl}/api/v4/query_range`;
|
|
53
|
+
logger.debug({ endpoint: signozEndpoint }, "Proxying to SigNoz");
|
|
54
|
+
const response = await axios.post(signozEndpoint, payload, {
|
|
55
|
+
headers: {
|
|
56
|
+
"Content-Type": "application/json",
|
|
57
|
+
"SIGNOZ-API-KEY": signozApiKey
|
|
58
|
+
},
|
|
59
|
+
timeout: 3e4
|
|
60
|
+
});
|
|
61
|
+
logger.debug({ status: response.status }, "SigNoz query successful");
|
|
62
|
+
return c.json(response.data);
|
|
63
|
+
} catch (error) {
|
|
64
|
+
if (axios.isAxiosError(error)) {
|
|
65
|
+
if (error.code === "ECONNREFUSED" || error.code === "ENOTFOUND") {
|
|
66
|
+
logger.error({ error: error.message }, "SigNoz service unavailable");
|
|
67
|
+
return c.json({
|
|
68
|
+
error: "Service Unavailable",
|
|
69
|
+
message: "SigNoz service is unavailable"
|
|
70
|
+
}, 503);
|
|
71
|
+
}
|
|
72
|
+
if (error.response?.status === 401 || error.response?.status === 403) {
|
|
73
|
+
logger.error({ status: error.response.status }, "SigNoz authentication failed");
|
|
74
|
+
return c.json({
|
|
75
|
+
error: "Internal Server Error",
|
|
76
|
+
message: "SigNoz authentication failed"
|
|
77
|
+
}, 500);
|
|
78
|
+
}
|
|
79
|
+
if (error.response?.status === 400) {
|
|
80
|
+
logger.warn({ status: error.response.status }, "Invalid SigNoz query");
|
|
81
|
+
return c.json({
|
|
82
|
+
error: "Bad Request",
|
|
83
|
+
message: "Invalid query parameters"
|
|
84
|
+
}, 400);
|
|
85
|
+
}
|
|
86
|
+
}
|
|
87
|
+
logger.error({ error }, "SigNoz query failed");
|
|
88
|
+
return c.json({
|
|
89
|
+
error: "Internal Server Error",
|
|
90
|
+
message: "Failed to query SigNoz"
|
|
91
|
+
}, 500);
|
|
92
|
+
}
|
|
93
|
+
});
|
|
94
|
+
app.get("/health", async (c) => {
|
|
95
|
+
const signozUrl = env.SIGNOZ_URL || env.PUBLIC_SIGNOZ_URL;
|
|
96
|
+
const signozApiKey = env.SIGNOZ_API_KEY;
|
|
97
|
+
logger.debug({
|
|
98
|
+
hasUrl: !!signozUrl,
|
|
99
|
+
hasApiKey: !!signozApiKey,
|
|
100
|
+
url: signozUrl
|
|
101
|
+
}, "Checking SigNoz configuration");
|
|
102
|
+
if (!signozUrl || !signozApiKey) {
|
|
103
|
+
logger.warn({}, "SigNoz credentials not set");
|
|
104
|
+
return c.json({
|
|
105
|
+
status: "not_configured",
|
|
106
|
+
configured: false,
|
|
107
|
+
error: "SIGNOZ_URL or SIGNOZ_API_KEY not set"
|
|
108
|
+
});
|
|
109
|
+
}
|
|
110
|
+
try {
|
|
111
|
+
const testPayload = {
|
|
112
|
+
start: Date.now() - 3e5,
|
|
113
|
+
end: Date.now(),
|
|
114
|
+
step: 60,
|
|
115
|
+
compositeQuery: {
|
|
116
|
+
queryType: "builder",
|
|
117
|
+
panelType: "table",
|
|
118
|
+
builderQueries: {}
|
|
119
|
+
}
|
|
120
|
+
};
|
|
121
|
+
const signozEndpoint = `${signozUrl}/api/v4/query_range`;
|
|
122
|
+
logger.debug({ endpoint: signozEndpoint }, "Testing SigNoz connection");
|
|
123
|
+
await axios.post(signozEndpoint, testPayload, {
|
|
124
|
+
headers: {
|
|
125
|
+
"Content-Type": "application/json",
|
|
126
|
+
"SIGNOZ-API-KEY": signozApiKey
|
|
127
|
+
},
|
|
128
|
+
timeout: 5e3,
|
|
129
|
+
validateStatus: (status) => status === 200 || status === 400
|
|
130
|
+
});
|
|
131
|
+
logger.debug({}, "SigNoz health check successful");
|
|
132
|
+
return c.json({
|
|
133
|
+
status: "ok",
|
|
134
|
+
configured: true
|
|
135
|
+
});
|
|
136
|
+
} catch (error) {
|
|
137
|
+
logger.error({
|
|
138
|
+
error,
|
|
139
|
+
message: error instanceof Error ? error.message : "Unknown error",
|
|
140
|
+
code: axios.isAxiosError(error) ? error.code : void 0,
|
|
141
|
+
status: axios.isAxiosError(error) ? error.response?.status : void 0
|
|
142
|
+
}, "SigNoz connection test failed");
|
|
143
|
+
let errorMessage = "Failed to connect to SigNoz";
|
|
144
|
+
if (axios.isAxiosError(error)) {
|
|
145
|
+
if (error.code === "ECONNREFUSED" || error.code === "ENOTFOUND") errorMessage = "Check SIGNOZ_URL";
|
|
146
|
+
else if (error.response?.status === 401 || error.response?.status === 403) errorMessage = "Invalid SIGNOZ_API_KEY";
|
|
147
|
+
else if (error.code === "ETIMEDOUT" || error.code === "ECONNABORTED") errorMessage = "SigNoz connection timed out";
|
|
148
|
+
}
|
|
149
|
+
return c.json({
|
|
150
|
+
status: "connection_failed",
|
|
151
|
+
configured: false,
|
|
152
|
+
error: errorMessage
|
|
153
|
+
});
|
|
154
|
+
}
|
|
155
|
+
});
|
|
156
|
+
var signoz_default = app;
|
|
157
|
+
|
|
158
|
+
//#endregion
|
|
159
|
+
export { signoz_default as default };
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import { ManageAppVariables } from "../../../types/app.js";
|
|
2
|
+
import { OpenAPIHono } from "@hono/zod-openapi";
|
|
3
|
+
|
|
4
|
+
//#region src/domains/manage/routes/subAgentArtifactComponents.d.ts
|
|
5
|
+
declare const app: OpenAPIHono<{
|
|
6
|
+
Variables: ManageAppVariables;
|
|
7
|
+
}, {}, "/">;
|
|
8
|
+
//#endregion
|
|
9
|
+
export { app as default };
|