@proofhound/core 0.1.6
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/LICENSE +190 -0
- package/dist/index.d.ts +7 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +10 -0
- package/dist/index.js.map +1 -0
- package/dist/infra/index.d.ts +12 -0
- package/dist/infra/index.d.ts.map +1 -0
- package/dist/infra/index.js +27 -0
- package/dist/infra/index.js.map +1 -0
- package/dist/server/channels/mcp/annotation.tools.d.ts +4 -0
- package/dist/server/channels/mcp/annotation.tools.d.ts.map +1 -0
- package/dist/server/channels/mcp/annotation.tools.js +132 -0
- package/dist/server/channels/mcp/annotation.tools.js.map +1 -0
- package/dist/server/channels/mcp/canary-release.tools.d.ts +4 -0
- package/dist/server/channels/mcp/canary-release.tools.d.ts.map +1 -0
- package/dist/server/channels/mcp/canary-release.tools.js +279 -0
- package/dist/server/channels/mcp/canary-release.tools.js.map +1 -0
- package/dist/server/channels/mcp/connector.tools.d.ts +4 -0
- package/dist/server/channels/mcp/connector.tools.d.ts.map +1 -0
- package/dist/server/channels/mcp/connector.tools.js +211 -0
- package/dist/server/channels/mcp/connector.tools.js.map +1 -0
- package/dist/server/channels/mcp/dataset-import.tools.d.ts +4 -0
- package/dist/server/channels/mcp/dataset-import.tools.d.ts.map +1 -0
- package/dist/server/channels/mcp/dataset-import.tools.js +107 -0
- package/dist/server/channels/mcp/dataset-import.tools.js.map +1 -0
- package/dist/server/channels/mcp/dataset.tools.d.ts +4 -0
- package/dist/server/channels/mcp/dataset.tools.d.ts.map +1 -0
- package/dist/server/channels/mcp/dataset.tools.js +166 -0
- package/dist/server/channels/mcp/dataset.tools.js.map +1 -0
- package/dist/server/channels/mcp/experiment.tools.d.ts +4 -0
- package/dist/server/channels/mcp/experiment.tools.d.ts.map +1 -0
- package/dist/server/channels/mcp/experiment.tools.js +133 -0
- package/dist/server/channels/mcp/experiment.tools.js.map +1 -0
- package/dist/server/channels/mcp/index.d.ts +19 -0
- package/dist/server/channels/mcp/index.d.ts.map +1 -0
- package/dist/server/channels/mcp/index.js +35 -0
- package/dist/server/channels/mcp/index.js.map +1 -0
- package/dist/server/channels/mcp/mcp-context.d.ts +30 -0
- package/dist/server/channels/mcp/mcp-context.d.ts.map +1 -0
- package/dist/server/channels/mcp/mcp-context.js +110 -0
- package/dist/server/channels/mcp/mcp-context.js.map +1 -0
- package/dist/server/channels/mcp/mcp-server.factory.d.ts +13 -0
- package/dist/server/channels/mcp/mcp-server.factory.d.ts.map +1 -0
- package/dist/server/channels/mcp/mcp-server.factory.js +42 -0
- package/dist/server/channels/mcp/mcp-server.factory.js.map +1 -0
- package/dist/server/channels/mcp/mcp.controller.d.ts +10 -0
- package/dist/server/channels/mcp/mcp.controller.d.ts.map +1 -0
- package/dist/server/channels/mcp/mcp.controller.js +67 -0
- package/dist/server/channels/mcp/mcp.controller.js.map +1 -0
- package/dist/server/channels/mcp/mcp.module.d.ts +3 -0
- package/dist/server/channels/mcp/mcp.module.d.ts.map +1 -0
- package/dist/server/channels/mcp/mcp.module.js +114 -0
- package/dist/server/channels/mcp/mcp.module.js.map +1 -0
- package/dist/server/channels/mcp/mcp.tokens.d.ts +2 -0
- package/dist/server/channels/mcp/mcp.tokens.d.ts.map +1 -0
- package/dist/server/channels/mcp/mcp.tokens.js +8 -0
- package/dist/server/channels/mcp/mcp.tokens.js.map +1 -0
- package/dist/server/channels/mcp/mcp.transport.d.ts +11 -0
- package/dist/server/channels/mcp/mcp.transport.d.ts.map +1 -0
- package/dist/server/channels/mcp/mcp.transport.js +71 -0
- package/dist/server/channels/mcp/mcp.transport.js.map +1 -0
- package/dist/server/channels/mcp/mcp.types.d.ts +16 -0
- package/dist/server/channels/mcp/mcp.types.d.ts.map +1 -0
- package/dist/server/channels/mcp/mcp.types.js +3 -0
- package/dist/server/channels/mcp/mcp.types.js.map +1 -0
- package/dist/server/channels/mcp/model.tools.d.ts +4 -0
- package/dist/server/channels/mcp/model.tools.d.ts.map +1 -0
- package/dist/server/channels/mcp/model.tools.js +215 -0
- package/dist/server/channels/mcp/model.tools.js.map +1 -0
- package/dist/server/channels/mcp/monitoring.tools.d.ts +4 -0
- package/dist/server/channels/mcp/monitoring.tools.d.ts.map +1 -0
- package/dist/server/channels/mcp/monitoring.tools.js +81 -0
- package/dist/server/channels/mcp/monitoring.tools.js.map +1 -0
- package/dist/server/channels/mcp/optimization.tools.d.ts +4 -0
- package/dist/server/channels/mcp/optimization.tools.d.ts.map +1 -0
- package/dist/server/channels/mcp/optimization.tools.js +104 -0
- package/dist/server/channels/mcp/optimization.tools.js.map +1 -0
- package/dist/server/channels/mcp/prompt.tools.d.ts +5 -0
- package/dist/server/channels/mcp/prompt.tools.d.ts.map +1 -0
- package/dist/server/channels/mcp/prompt.tools.js +258 -0
- package/dist/server/channels/mcp/prompt.tools.js.map +1 -0
- package/dist/server/channels/mcp/quick-start.tools.d.ts +4 -0
- package/dist/server/channels/mcp/quick-start.tools.d.ts.map +1 -0
- package/dist/server/channels/mcp/quick-start.tools.js +48 -0
- package/dist/server/channels/mcp/quick-start.tools.js.map +1 -0
- package/dist/server/channels/mcp/release-line.tools.d.ts +4 -0
- package/dist/server/channels/mcp/release-line.tools.d.ts.map +1 -0
- package/dist/server/channels/mcp/release-line.tools.js +101 -0
- package/dist/server/channels/mcp/release-line.tools.js.map +1 -0
- package/dist/server/channels/mcp/run-result.tools.d.ts +4 -0
- package/dist/server/channels/mcp/run-result.tools.d.ts.map +1 -0
- package/dist/server/channels/mcp/run-result.tools.js +116 -0
- package/dist/server/channels/mcp/run-result.tools.js.map +1 -0
- package/dist/server/channels/mcp/token.tools.d.ts +4 -0
- package/dist/server/channels/mcp/token.tools.d.ts.map +1 -0
- package/dist/server/channels/mcp/token.tools.js +87 -0
- package/dist/server/channels/mcp/token.tools.js.map +1 -0
- package/dist/server/common/access-control.d.ts +5 -0
- package/dist/server/common/access-control.d.ts.map +1 -0
- package/dist/server/common/access-control.js +25 -0
- package/dist/server/common/access-control.js.map +1 -0
- package/dist/server/common/actor-context.d.ts +11 -0
- package/dist/server/common/actor-context.d.ts.map +1 -0
- package/dist/server/common/actor-context.js +8 -0
- package/dist/server/common/actor-context.js.map +1 -0
- package/dist/server/common/contracts/access-control.service.d.ts +6 -0
- package/dist/server/common/contracts/access-control.service.d.ts.map +1 -0
- package/dist/server/common/contracts/access-control.service.js +13 -0
- package/dist/server/common/contracts/access-control.service.js.map +1 -0
- package/dist/server/common/contracts/actor-context.resolver.d.ts +7 -0
- package/dist/server/common/contracts/actor-context.resolver.d.ts.map +1 -0
- package/dist/server/common/contracts/actor-context.resolver.js +15 -0
- package/dist/server/common/contracts/actor-context.resolver.js.map +1 -0
- package/dist/server/common/contracts/connector-context.resolver.d.ts +19 -0
- package/dist/server/common/contracts/connector-context.resolver.d.ts.map +1 -0
- package/dist/server/common/contracts/connector-context.resolver.js +23 -0
- package/dist/server/common/contracts/connector-context.resolver.js.map +1 -0
- package/dist/server/common/contracts/http-actor.guard.d.ts +13 -0
- package/dist/server/common/contracts/http-actor.guard.d.ts.map +1 -0
- package/dist/server/common/contracts/http-actor.guard.js +87 -0
- package/dist/server/common/contracts/http-actor.guard.js.map +1 -0
- package/dist/server/common/contracts/index.d.ts +23 -0
- package/dist/server/common/contracts/index.d.ts.map +1 -0
- package/dist/server/common/contracts/index.js +45 -0
- package/dist/server/common/contracts/index.js.map +1 -0
- package/dist/server/common/contracts/limiter-key.strategy.d.ts +8 -0
- package/dist/server/common/contracts/limiter-key.strategy.d.ts.map +1 -0
- package/dist/server/common/contracts/limiter-key.strategy.js +24 -0
- package/dist/server/common/contracts/limiter-key.strategy.js.map +1 -0
- package/dist/server/common/contracts/local-access-control.service.d.ts +7 -0
- package/dist/server/common/contracts/local-access-control.service.d.ts.map +1 -0
- package/dist/server/common/contracts/local-access-control.service.js +41 -0
- package/dist/server/common/contracts/local-access-control.service.js.map +1 -0
- package/dist/server/common/contracts/local-actor-context.resolver.d.ts +13 -0
- package/dist/server/common/contracts/local-actor-context.resolver.d.ts.map +1 -0
- package/dist/server/common/contracts/local-actor-context.resolver.js +102 -0
- package/dist/server/common/contracts/local-actor-context.resolver.js.map +1 -0
- package/dist/server/common/contracts/local-contracts.module.d.ts +3 -0
- package/dist/server/common/contracts/local-contracts.module.d.ts.map +1 -0
- package/dist/server/common/contracts/local-contracts.module.js +78 -0
- package/dist/server/common/contracts/local-contracts.module.js.map +1 -0
- package/dist/server/common/contracts/local-mcp-auth.resolver.d.ts +12 -0
- package/dist/server/common/contracts/local-mcp-auth.resolver.d.ts.map +1 -0
- package/dist/server/common/contracts/local-mcp-auth.resolver.js +66 -0
- package/dist/server/common/contracts/local-mcp-auth.resolver.js.map +1 -0
- package/dist/server/common/contracts/local-project-context.resolver.d.ts +8 -0
- package/dist/server/common/contracts/local-project-context.resolver.d.ts.map +1 -0
- package/dist/server/common/contracts/local-project-context.resolver.js +27 -0
- package/dist/server/common/contracts/local-project-context.resolver.js.map +1 -0
- package/dist/server/common/contracts/local-user-token.verifier.d.ts +26 -0
- package/dist/server/common/contracts/local-user-token.verifier.d.ts.map +1 -0
- package/dist/server/common/contracts/local-user-token.verifier.js +96 -0
- package/dist/server/common/contracts/local-user-token.verifier.js.map +1 -0
- package/dist/server/common/contracts/mcp-auth.resolver.d.ts +7 -0
- package/dist/server/common/contracts/mcp-auth.resolver.d.ts.map +1 -0
- package/dist/server/common/contracts/mcp-auth.resolver.js +12 -0
- package/dist/server/common/contracts/mcp-auth.resolver.js.map +1 -0
- package/dist/server/common/contracts/project-context.resolver.d.ts +11 -0
- package/dist/server/common/contracts/project-context.resolver.d.ts.map +1 -0
- package/dist/server/common/contracts/project-context.resolver.js +22 -0
- package/dist/server/common/contracts/project-context.resolver.js.map +1 -0
- package/dist/server/common/contracts/quota-policy.hook.d.ts +24 -0
- package/dist/server/common/contracts/quota-policy.hook.d.ts.map +1 -0
- package/dist/server/common/contracts/quota-policy.hook.js +22 -0
- package/dist/server/common/contracts/quota-policy.hook.js.map +1 -0
- package/dist/server/common/contracts/runtime-limits.provider.d.ts +17 -0
- package/dist/server/common/contracts/runtime-limits.provider.d.ts.map +1 -0
- package/dist/server/common/contracts/runtime-limits.provider.js +23 -0
- package/dist/server/common/contracts/runtime-limits.provider.js.map +1 -0
- package/dist/server/common/contracts/token.service.d.ts +11 -0
- package/dist/server/common/contracts/token.service.d.ts.map +1 -0
- package/dist/server/common/contracts/token.service.js +12 -0
- package/dist/server/common/contracts/token.service.js.map +1 -0
- package/dist/server/common/contracts/types.d.ts +45 -0
- package/dist/server/common/contracts/types.d.ts.map +1 -0
- package/dist/server/common/contracts/types.js +8 -0
- package/dist/server/common/contracts/types.js.map +1 -0
- package/dist/server/common/contracts/workflow-authorization.hook.d.ts +9 -0
- package/dist/server/common/contracts/workflow-authorization.hook.d.ts.map +1 -0
- package/dist/server/common/contracts/workflow-authorization.hook.js +27 -0
- package/dist/server/common/contracts/workflow-authorization.hook.js.map +1 -0
- package/dist/server/common/decorators/current-project.decorator.d.ts +5 -0
- package/dist/server/common/decorators/current-project.decorator.d.ts.map +1 -0
- package/dist/server/common/decorators/current-project.decorator.js +22 -0
- package/dist/server/common/decorators/current-project.decorator.js.map +1 -0
- package/dist/server/common/decorators/current-user.decorator.d.ts +13 -0
- package/dist/server/common/decorators/current-user.decorator.d.ts.map +1 -0
- package/dist/server/common/decorators/current-user.decorator.js +9 -0
- package/dist/server/common/decorators/current-user.decorator.js.map +1 -0
- package/dist/server/common/errors/db-error.d.ts +2 -0
- package/dist/server/common/errors/db-error.d.ts.map +1 -0
- package/dist/server/common/errors/db-error.js +12 -0
- package/dist/server/common/errors/db-error.js.map +1 -0
- package/dist/server/common/project-context.d.ts +22 -0
- package/dist/server/common/project-context.d.ts.map +1 -0
- package/dist/server/common/project-context.js +60 -0
- package/dist/server/common/project-context.js.map +1 -0
- package/dist/server/common/project-context.module.d.ts +3 -0
- package/dist/server/common/project-context.module.d.ts.map +1 -0
- package/dist/server/common/project-context.module.js +22 -0
- package/dist/server/common/project-context.module.js.map +1 -0
- package/dist/server/index.d.ts +4 -0
- package/dist/server/index.d.ts.map +1 -0
- package/dist/server/index.js +8 -0
- package/dist/server/index.js.map +1 -0
- package/dist/server/infrastructure/llm/run-result-writer.d.ts +10 -0
- package/dist/server/infrastructure/llm/run-result-writer.d.ts.map +1 -0
- package/dist/server/infrastructure/llm/run-result-writer.js +103 -0
- package/dist/server/infrastructure/llm/run-result-writer.js.map +1 -0
- package/dist/server/infrastructure/orchestration/bullmq.module.d.ts +3 -0
- package/dist/server/infrastructure/orchestration/bullmq.module.d.ts.map +1 -0
- package/dist/server/infrastructure/orchestration/bullmq.module.js +36 -0
- package/dist/server/infrastructure/orchestration/bullmq.module.js.map +1 -0
- package/dist/server/infrastructure/orchestration/bullmq.service.d.ts +10 -0
- package/dist/server/infrastructure/orchestration/bullmq.service.d.ts.map +1 -0
- package/dist/server/infrastructure/orchestration/bullmq.service.js +44 -0
- package/dist/server/infrastructure/orchestration/bullmq.service.js.map +1 -0
- package/dist/server/infrastructure/orchestration/dbos.module.d.ts +3 -0
- package/dist/server/infrastructure/orchestration/dbos.module.d.ts.map +1 -0
- package/dist/server/infrastructure/orchestration/dbos.module.js +21 -0
- package/dist/server/infrastructure/orchestration/dbos.module.js.map +1 -0
- package/dist/server/infrastructure/orchestration/dbos.service.d.ts +7 -0
- package/dist/server/infrastructure/orchestration/dbos.service.d.ts.map +1 -0
- package/dist/server/infrastructure/orchestration/dbos.service.js +43 -0
- package/dist/server/infrastructure/orchestration/dbos.service.js.map +1 -0
- package/dist/server/infrastructure/orchestration/index.d.ts +6 -0
- package/dist/server/infrastructure/orchestration/index.d.ts.map +1 -0
- package/dist/server/infrastructure/orchestration/index.js +14 -0
- package/dist/server/infrastructure/orchestration/index.js.map +1 -0
- package/dist/server/infrastructure/orchestration/orchestration.constants.d.ts +2 -0
- package/dist/server/infrastructure/orchestration/orchestration.constants.d.ts.map +1 -0
- package/dist/server/infrastructure/orchestration/orchestration.constants.js +5 -0
- package/dist/server/infrastructure/orchestration/orchestration.constants.js.map +1 -0
- package/dist/server/infrastructure/orchestration/orchestration.module.d.ts +3 -0
- package/dist/server/infrastructure/orchestration/orchestration.module.d.ts.map +1 -0
- package/dist/server/infrastructure/orchestration/orchestration.module.js +22 -0
- package/dist/server/infrastructure/orchestration/orchestration.module.js.map +1 -0
- package/dist/server/modules/annotation/annotation.controller.d.ts +245 -0
- package/dist/server/modules/annotation/annotation.controller.d.ts.map +1 -0
- package/dist/server/modules/annotation/annotation.controller.js +159 -0
- package/dist/server/modules/annotation/annotation.controller.js.map +1 -0
- package/dist/server/modules/annotation/annotation.module.d.ts +3 -0
- package/dist/server/modules/annotation/annotation.module.d.ts.map +1 -0
- package/dist/server/modules/annotation/annotation.module.js +26 -0
- package/dist/server/modules/annotation/annotation.module.js.map +1 -0
- package/dist/server/modules/annotation/annotation.repository.d.ts +28 -0
- package/dist/server/modules/annotation/annotation.repository.d.ts.map +1 -0
- package/dist/server/modules/annotation/annotation.repository.js +634 -0
- package/dist/server/modules/annotation/annotation.repository.js.map +1 -0
- package/dist/server/modules/annotation/annotation.service.d.ts +26 -0
- package/dist/server/modules/annotation/annotation.service.d.ts.map +1 -0
- package/dist/server/modules/annotation/annotation.service.js +144 -0
- package/dist/server/modules/annotation/annotation.service.js.map +1 -0
- package/dist/server/modules/canary-release/canary-release.controller.d.ts +629 -0
- package/dist/server/modules/canary-release/canary-release.controller.d.ts.map +1 -0
- package/dist/server/modules/canary-release/canary-release.controller.js +244 -0
- package/dist/server/modules/canary-release/canary-release.controller.js.map +1 -0
- package/dist/server/modules/canary-release/canary-release.module.d.ts +3 -0
- package/dist/server/modules/canary-release/canary-release.module.d.ts.map +1 -0
- package/dist/server/modules/canary-release/canary-release.module.js +27 -0
- package/dist/server/modules/canary-release/canary-release.module.js.map +1 -0
- package/dist/server/modules/canary-release/canary-release.repository.d.ts +686 -0
- package/dist/server/modules/canary-release/canary-release.repository.d.ts.map +1 -0
- package/dist/server/modules/canary-release/canary-release.repository.js +673 -0
- package/dist/server/modules/canary-release/canary-release.repository.js.map +1 -0
- package/dist/server/modules/canary-release/canary-release.service.d.ts +55 -0
- package/dist/server/modules/canary-release/canary-release.service.d.ts.map +1 -0
- package/dist/server/modules/canary-release/canary-release.service.js +573 -0
- package/dist/server/modules/canary-release/canary-release.service.js.map +1 -0
- package/dist/server/modules/canary-release/canary-runtime.d.ts +60 -0
- package/dist/server/modules/canary-release/canary-runtime.d.ts.map +1 -0
- package/dist/server/modules/canary-release/canary-runtime.js +328 -0
- package/dist/server/modules/canary-release/canary-runtime.js.map +1 -0
- package/dist/server/modules/connector/connector.controller.d.ts +446 -0
- package/dist/server/modules/connector/connector.controller.d.ts.map +1 -0
- package/dist/server/modules/connector/connector.controller.js +235 -0
- package/dist/server/modules/connector/connector.controller.js.map +1 -0
- package/dist/server/modules/connector/connector.driver-factory.d.ts +66 -0
- package/dist/server/modules/connector/connector.driver-factory.d.ts.map +1 -0
- package/dist/server/modules/connector/connector.driver-factory.js +314 -0
- package/dist/server/modules/connector/connector.driver-factory.js.map +1 -0
- package/dist/server/modules/connector/connector.module.d.ts +3 -0
- package/dist/server/modules/connector/connector.module.d.ts.map +1 -0
- package/dist/server/modules/connector/connector.module.js +28 -0
- package/dist/server/modules/connector/connector.module.js.map +1 -0
- package/dist/server/modules/connector/connector.repository.d.ts +369 -0
- package/dist/server/modules/connector/connector.repository.d.ts.map +1 -0
- package/dist/server/modules/connector/connector.repository.js +323 -0
- package/dist/server/modules/connector/connector.repository.js.map +1 -0
- package/dist/server/modules/connector/connector.service.d.ts +60 -0
- package/dist/server/modules/connector/connector.service.d.ts.map +1 -0
- package/dist/server/modules/connector/connector.service.js +682 -0
- package/dist/server/modules/connector/connector.service.js.map +1 -0
- package/dist/server/modules/dataset/dataset-field-schema.util.d.ts +4 -0
- package/dist/server/modules/dataset/dataset-field-schema.util.d.ts.map +1 -0
- package/dist/server/modules/dataset/dataset-field-schema.util.js +57 -0
- package/dist/server/modules/dataset/dataset-field-schema.util.js.map +1 -0
- package/dist/server/modules/dataset/dataset-import.controller.d.ts +79 -0
- package/dist/server/modules/dataset/dataset-import.controller.d.ts.map +1 -0
- package/dist/server/modules/dataset/dataset-import.controller.js +124 -0
- package/dist/server/modules/dataset/dataset-import.controller.js.map +1 -0
- package/dist/server/modules/dataset/dataset-import.repository.d.ts +63 -0
- package/dist/server/modules/dataset/dataset-import.repository.d.ts.map +1 -0
- package/dist/server/modules/dataset/dataset-import.repository.js +176 -0
- package/dist/server/modules/dataset/dataset-import.repository.js.map +1 -0
- package/dist/server/modules/dataset/dataset-import.service.d.ts +36 -0
- package/dist/server/modules/dataset/dataset-import.service.d.ts.map +1 -0
- package/dist/server/modules/dataset/dataset-import.service.js +227 -0
- package/dist/server/modules/dataset/dataset-import.service.js.map +1 -0
- package/dist/server/modules/dataset/dataset.controller.d.ts +127 -0
- package/dist/server/modules/dataset/dataset.controller.d.ts.map +1 -0
- package/dist/server/modules/dataset/dataset.controller.js +168 -0
- package/dist/server/modules/dataset/dataset.controller.js.map +1 -0
- package/dist/server/modules/dataset/dataset.module.d.ts +3 -0
- package/dist/server/modules/dataset/dataset.module.d.ts.map +1 -0
- package/dist/server/modules/dataset/dataset.module.js +29 -0
- package/dist/server/modules/dataset/dataset.module.js.map +1 -0
- package/dist/server/modules/dataset/dataset.repository.d.ts +75 -0
- package/dist/server/modules/dataset/dataset.repository.d.ts.map +1 -0
- package/dist/server/modules/dataset/dataset.repository.js +238 -0
- package/dist/server/modules/dataset/dataset.repository.js.map +1 -0
- package/dist/server/modules/dataset/dataset.service.d.ts +50 -0
- package/dist/server/modules/dataset/dataset.service.d.ts.map +1 -0
- package/dist/server/modules/dataset/dataset.service.js +343 -0
- package/dist/server/modules/dataset/dataset.service.js.map +1 -0
- package/dist/server/modules/experiment/experiment.aggregator.d.ts +14 -0
- package/dist/server/modules/experiment/experiment.aggregator.d.ts.map +1 -0
- package/dist/server/modules/experiment/experiment.aggregator.js +39 -0
- package/dist/server/modules/experiment/experiment.aggregator.js.map +1 -0
- package/dist/server/modules/experiment/experiment.controller.d.ts +361 -0
- package/dist/server/modules/experiment/experiment.controller.d.ts.map +1 -0
- package/dist/server/modules/experiment/experiment.controller.js +162 -0
- package/dist/server/modules/experiment/experiment.controller.js.map +1 -0
- package/dist/server/modules/experiment/experiment.launcher.d.ts +14 -0
- package/dist/server/modules/experiment/experiment.launcher.d.ts.map +1 -0
- package/dist/server/modules/experiment/experiment.launcher.js +54 -0
- package/dist/server/modules/experiment/experiment.launcher.js.map +1 -0
- package/dist/server/modules/experiment/experiment.module.d.ts +3 -0
- package/dist/server/modules/experiment/experiment.module.d.ts.map +1 -0
- package/dist/server/modules/experiment/experiment.module.js +38 -0
- package/dist/server/modules/experiment/experiment.module.js.map +1 -0
- package/dist/server/modules/experiment/experiment.recovery.d.ts +15 -0
- package/dist/server/modules/experiment/experiment.recovery.d.ts.map +1 -0
- package/dist/server/modules/experiment/experiment.recovery.js +80 -0
- package/dist/server/modules/experiment/experiment.recovery.js.map +1 -0
- package/dist/server/modules/experiment/experiment.renderer.d.ts +2 -0
- package/dist/server/modules/experiment/experiment.renderer.d.ts.map +1 -0
- package/dist/server/modules/experiment/experiment.renderer.js +6 -0
- package/dist/server/modules/experiment/experiment.renderer.js.map +1 -0
- package/dist/server/modules/experiment/experiment.repository.d.ts +88 -0
- package/dist/server/modules/experiment/experiment.repository.d.ts.map +1 -0
- package/dist/server/modules/experiment/experiment.repository.js +173 -0
- package/dist/server/modules/experiment/experiment.repository.js.map +1 -0
- package/dist/server/modules/experiment/experiment.service.d.ts +57 -0
- package/dist/server/modules/experiment/experiment.service.d.ts.map +1 -0
- package/dist/server/modules/experiment/experiment.service.js +539 -0
- package/dist/server/modules/experiment/experiment.service.js.map +1 -0
- package/dist/server/modules/experiment/experiment.workflow.d.ts +51 -0
- package/dist/server/modules/experiment/experiment.workflow.d.ts.map +1 -0
- package/dist/server/modules/experiment/experiment.workflow.js +465 -0
- package/dist/server/modules/experiment/experiment.workflow.js.map +1 -0
- package/dist/server/modules/model/model.controller.d.ts +23 -0
- package/dist/server/modules/model/model.controller.d.ts.map +1 -0
- package/dist/server/modules/model/model.controller.js +76 -0
- package/dist/server/modules/model/model.controller.js.map +1 -0
- package/dist/server/modules/model/model.module.d.ts +3 -0
- package/dist/server/modules/model/model.module.d.ts.map +1 -0
- package/dist/server/modules/model/model.module.js +29 -0
- package/dist/server/modules/model/model.module.js.map +1 -0
- package/dist/server/modules/model/model.repository.d.ts +511 -0
- package/dist/server/modules/model/model.repository.d.ts.map +1 -0
- package/dist/server/modules/model/model.repository.js +181 -0
- package/dist/server/modules/model/model.repository.js.map +1 -0
- package/dist/server/modules/model/model.service.d.ts +79 -0
- package/dist/server/modules/model/model.service.d.ts.map +1 -0
- package/dist/server/modules/model/model.service.js +643 -0
- package/dist/server/modules/model/model.service.js.map +1 -0
- package/dist/server/modules/model/project-model.controller.d.ts +261 -0
- package/dist/server/modules/model/project-model.controller.d.ts.map +1 -0
- package/dist/server/modules/model/project-model.controller.js +198 -0
- package/dist/server/modules/model/project-model.controller.js.map +1 -0
- package/dist/server/modules/monitoring/monitoring.controller.d.ts +204 -0
- package/dist/server/modules/monitoring/monitoring.controller.d.ts.map +1 -0
- package/dist/server/modules/monitoring/monitoring.controller.js +129 -0
- package/dist/server/modules/monitoring/monitoring.controller.js.map +1 -0
- package/dist/server/modules/monitoring/monitoring.module.d.ts +3 -0
- package/dist/server/modules/monitoring/monitoring.module.d.ts.map +1 -0
- package/dist/server/modules/monitoring/monitoring.module.js +26 -0
- package/dist/server/modules/monitoring/monitoring.module.js.map +1 -0
- package/dist/server/modules/monitoring/monitoring.repository.d.ts +15 -0
- package/dist/server/modules/monitoring/monitoring.repository.d.ts.map +1 -0
- package/dist/server/modules/monitoring/monitoring.repository.js +618 -0
- package/dist/server/modules/monitoring/monitoring.repository.js.map +1 -0
- package/dist/server/modules/monitoring/monitoring.service.d.ts +15 -0
- package/dist/server/modules/monitoring/monitoring.service.d.ts.map +1 -0
- package/dist/server/modules/monitoring/monitoring.service.js +70 -0
- package/dist/server/modules/monitoring/monitoring.service.js.map +1 -0
- package/dist/server/modules/optimization/optimization.controller.d.ts +579 -0
- package/dist/server/modules/optimization/optimization.controller.d.ts.map +1 -0
- package/dist/server/modules/optimization/optimization.controller.js +119 -0
- package/dist/server/modules/optimization/optimization.controller.js.map +1 -0
- package/dist/server/modules/optimization/optimization.launcher.d.ts +14 -0
- package/dist/server/modules/optimization/optimization.launcher.d.ts.map +1 -0
- package/dist/server/modules/optimization/optimization.launcher.js +56 -0
- package/dist/server/modules/optimization/optimization.launcher.js.map +1 -0
- package/dist/server/modules/optimization/optimization.module.d.ts +3 -0
- package/dist/server/modules/optimization/optimization.module.d.ts.map +1 -0
- package/dist/server/modules/optimization/optimization.module.js +42 -0
- package/dist/server/modules/optimization/optimization.module.js.map +1 -0
- package/dist/server/modules/optimization/optimization.recovery.d.ts +15 -0
- package/dist/server/modules/optimization/optimization.recovery.d.ts.map +1 -0
- package/dist/server/modules/optimization/optimization.recovery.js +80 -0
- package/dist/server/modules/optimization/optimization.recovery.js.map +1 -0
- package/dist/server/modules/optimization/optimization.repository.d.ts +375 -0
- package/dist/server/modules/optimization/optimization.repository.d.ts.map +1 -0
- package/dist/server/modules/optimization/optimization.repository.js +849 -0
- package/dist/server/modules/optimization/optimization.repository.js.map +1 -0
- package/dist/server/modules/optimization/optimization.service.d.ts +74 -0
- package/dist/server/modules/optimization/optimization.service.d.ts.map +1 -0
- package/dist/server/modules/optimization/optimization.service.js +1753 -0
- package/dist/server/modules/optimization/optimization.service.js.map +1 -0
- package/dist/server/modules/optimization/optimization.workflow.d.ts +118 -0
- package/dist/server/modules/optimization/optimization.workflow.d.ts.map +1 -0
- package/dist/server/modules/optimization/optimization.workflow.js +2007 -0
- package/dist/server/modules/optimization/optimization.workflow.js.map +1 -0
- package/dist/server/modules/production-release/production-release.controller.d.ts +125 -0
- package/dist/server/modules/production-release/production-release.controller.d.ts.map +1 -0
- package/dist/server/modules/production-release/production-release.controller.js +107 -0
- package/dist/server/modules/production-release/production-release.controller.js.map +1 -0
- package/dist/server/modules/production-release/production-release.module.d.ts +3 -0
- package/dist/server/modules/production-release/production-release.module.d.ts.map +1 -0
- package/dist/server/modules/production-release/production-release.module.js +27 -0
- package/dist/server/modules/production-release/production-release.module.js.map +1 -0
- package/dist/server/modules/production-release/production-release.repository.d.ts +109 -0
- package/dist/server/modules/production-release/production-release.repository.d.ts.map +1 -0
- package/dist/server/modules/production-release/production-release.repository.js +372 -0
- package/dist/server/modules/production-release/production-release.repository.js.map +1 -0
- package/dist/server/modules/production-release/production-release.service.d.ts +33 -0
- package/dist/server/modules/production-release/production-release.service.d.ts.map +1 -0
- package/dist/server/modules/production-release/production-release.service.js +370 -0
- package/dist/server/modules/production-release/production-release.service.js.map +1 -0
- package/dist/server/modules/prompt/prompt-try-run.service.d.ts +26 -0
- package/dist/server/modules/prompt/prompt-try-run.service.d.ts.map +1 -0
- package/dist/server/modules/prompt/prompt-try-run.service.js +213 -0
- package/dist/server/modules/prompt/prompt-try-run.service.js.map +1 -0
- package/dist/server/modules/prompt/prompt.controller.d.ts +489 -0
- package/dist/server/modules/prompt/prompt.controller.d.ts.map +1 -0
- package/dist/server/modules/prompt/prompt.controller.js +236 -0
- package/dist/server/modules/prompt/prompt.controller.js.map +1 -0
- package/dist/server/modules/prompt/prompt.module.d.ts +3 -0
- package/dist/server/modules/prompt/prompt.module.d.ts.map +1 -0
- package/dist/server/modules/prompt/prompt.module.js +28 -0
- package/dist/server/modules/prompt/prompt.module.js.map +1 -0
- package/dist/server/modules/prompt/prompt.repository.d.ts +190 -0
- package/dist/server/modules/prompt/prompt.repository.d.ts.map +1 -0
- package/dist/server/modules/prompt/prompt.repository.js +522 -0
- package/dist/server/modules/prompt/prompt.repository.js.map +1 -0
- package/dist/server/modules/prompt/prompt.service.d.ts +46 -0
- package/dist/server/modules/prompt/prompt.service.d.ts.map +1 -0
- package/dist/server/modules/prompt/prompt.service.js +508 -0
- package/dist/server/modules/prompt/prompt.service.js.map +1 -0
- package/dist/server/modules/quick-start/quick-start.controller.d.ts +75 -0
- package/dist/server/modules/quick-start/quick-start.controller.d.ts.map +1 -0
- package/dist/server/modules/quick-start/quick-start.controller.js +86 -0
- package/dist/server/modules/quick-start/quick-start.controller.js.map +1 -0
- package/dist/server/modules/quick-start/quick-start.module.d.ts +3 -0
- package/dist/server/modules/quick-start/quick-start.module.d.ts.map +1 -0
- package/dist/server/modules/quick-start/quick-start.module.js +27 -0
- package/dist/server/modules/quick-start/quick-start.module.js.map +1 -0
- package/dist/server/modules/quick-start/quick-start.service.d.ts +77 -0
- package/dist/server/modules/quick-start/quick-start.service.d.ts.map +1 -0
- package/dist/server/modules/quick-start/quick-start.service.js +130 -0
- package/dist/server/modules/quick-start/quick-start.service.js.map +1 -0
- package/dist/server/modules/release-line/release-line.controller.d.ts +749 -0
- package/dist/server/modules/release-line/release-line.controller.d.ts.map +1 -0
- package/dist/server/modules/release-line/release-line.controller.js +108 -0
- package/dist/server/modules/release-line/release-line.controller.js.map +1 -0
- package/dist/server/modules/release-line/release-line.module.d.ts +3 -0
- package/dist/server/modules/release-line/release-line.module.d.ts.map +1 -0
- package/dist/server/modules/release-line/release-line.module.js +31 -0
- package/dist/server/modules/release-line/release-line.module.js.map +1 -0
- package/dist/server/modules/release-line/release-line.repository.d.ts +89 -0
- package/dist/server/modules/release-line/release-line.repository.d.ts.map +1 -0
- package/dist/server/modules/release-line/release-line.repository.js +834 -0
- package/dist/server/modules/release-line/release-line.repository.js.map +1 -0
- package/dist/server/modules/release-line/release-line.service.d.ts +109 -0
- package/dist/server/modules/release-line/release-line.service.d.ts.map +1 -0
- package/dist/server/modules/release-line/release-line.service.js +287 -0
- package/dist/server/modules/release-line/release-line.service.js.map +1 -0
- package/dist/server/modules/release-line/release-runner.repository.d.ts +89 -0
- package/dist/server/modules/release-line/release-runner.repository.d.ts.map +1 -0
- package/dist/server/modules/release-line/release-runner.repository.js +449 -0
- package/dist/server/modules/release-line/release-runner.repository.js.map +1 -0
- package/dist/server/modules/release-line/release-runner.service.d.ts +40 -0
- package/dist/server/modules/release-line/release-runner.service.d.ts.map +1 -0
- package/dist/server/modules/release-line/release-runner.service.js +417 -0
- package/dist/server/modules/release-line/release-runner.service.js.map +1 -0
- package/dist/server/modules/run-result/run-result.controller.d.ts +129 -0
- package/dist/server/modules/run-result/run-result.controller.d.ts.map +1 -0
- package/dist/server/modules/run-result/run-result.controller.js +103 -0
- package/dist/server/modules/run-result/run-result.controller.js.map +1 -0
- package/dist/server/modules/run-result/run-result.module.d.ts +3 -0
- package/dist/server/modules/run-result/run-result.module.d.ts.map +1 -0
- package/dist/server/modules/run-result/run-result.module.js +26 -0
- package/dist/server/modules/run-result/run-result.module.js.map +1 -0
- package/dist/server/modules/run-result/run-result.repository.d.ts +27 -0
- package/dist/server/modules/run-result/run-result.repository.d.ts.map +1 -0
- package/dist/server/modules/run-result/run-result.repository.js +521 -0
- package/dist/server/modules/run-result/run-result.repository.js.map +1 -0
- package/dist/server/modules/run-result/run-result.service.d.ts +22 -0
- package/dist/server/modules/run-result/run-result.service.d.ts.map +1 -0
- package/dist/server/modules/run-result/run-result.service.js +61 -0
- package/dist/server/modules/run-result/run-result.service.js.map +1 -0
- package/dist/server/modules/token/token.controller.d.ts +57 -0
- package/dist/server/modules/token/token.controller.d.ts.map +1 -0
- package/dist/server/modules/token/token.controller.js +99 -0
- package/dist/server/modules/token/token.controller.js.map +1 -0
- package/dist/server/modules/token/token.module.d.ts +3 -0
- package/dist/server/modules/token/token.module.d.ts.map +1 -0
- package/dist/server/modules/token/token.module.js +22 -0
- package/dist/server/modules/token/token.module.js.map +1 -0
- package/dist/server/modules/token/token.repository.d.ts +264 -0
- package/dist/server/modules/token/token.repository.d.ts.map +1 -0
- package/dist/server/modules/token/token.repository.js +97 -0
- package/dist/server/modules/token/token.repository.js.map +1 -0
- package/dist/server/modules/token/token.service.d.ts +23 -0
- package/dist/server/modules/token/token.service.d.ts.map +1 -0
- package/dist/server/modules/token/token.service.js +124 -0
- package/dist/server/modules/token/token.service.js.map +1 -0
- package/dist/server/proofhound-server.module.d.ts +7 -0
- package/dist/server/proofhound-server.module.d.ts.map +1 -0
- package/dist/server/proofhound-server.module.js +72 -0
- package/dist/server/proofhound-server.module.js.map +1 -0
- package/dist/shared/config/config.module.d.ts +3 -0
- package/dist/shared/config/config.module.d.ts.map +1 -0
- package/dist/shared/config/config.module.js +33 -0
- package/dist/shared/config/config.module.js.map +1 -0
- package/dist/shared/crypto/crypto.module.d.ts +3 -0
- package/dist/shared/crypto/crypto.module.d.ts.map +1 -0
- package/dist/shared/crypto/crypto.module.js +24 -0
- package/dist/shared/crypto/crypto.module.js.map +1 -0
- package/dist/shared/crypto/crypto.service.d.ts +9 -0
- package/dist/shared/crypto/crypto.service.d.ts.map +1 -0
- package/dist/shared/crypto/crypto.service.js +37 -0
- package/dist/shared/crypto/crypto.service.js.map +1 -0
- package/dist/shared/database/database.constants.d.ts +2 -0
- package/dist/shared/database/database.constants.d.ts.map +1 -0
- package/dist/shared/database/database.constants.js +5 -0
- package/dist/shared/database/database.constants.js.map +1 -0
- package/dist/shared/database/database.module.d.ts +3 -0
- package/dist/shared/database/database.module.d.ts.map +1 -0
- package/dist/shared/database/database.module.js +27 -0
- package/dist/shared/database/database.module.js.map +1 -0
- package/dist/shared/filters/pino-exception.filter.d.ts +9 -0
- package/dist/shared/filters/pino-exception.filter.d.ts.map +1 -0
- package/dist/shared/filters/pino-exception.filter.js +58 -0
- package/dist/shared/filters/pino-exception.filter.js.map +1 -0
- package/dist/shared/health/health.controller.d.ts +11 -0
- package/dist/shared/health/health.controller.d.ts.map +1 -0
- package/dist/shared/health/health.controller.js +51 -0
- package/dist/shared/health/health.controller.js.map +1 -0
- package/dist/shared/health/health.service.d.ts +25 -0
- package/dist/shared/health/health.service.d.ts.map +1 -0
- package/dist/shared/health/health.service.js +74 -0
- package/dist/shared/health/health.service.js.map +1 -0
- package/dist/shared/llm/runtime-limits.d.ts +4 -0
- package/dist/shared/llm/runtime-limits.d.ts.map +1 -0
- package/dist/shared/llm/runtime-limits.js +23 -0
- package/dist/shared/llm/runtime-limits.js.map +1 -0
- package/dist/shared/redis/redis-mutex.service.d.ts +20 -0
- package/dist/shared/redis/redis-mutex.service.d.ts.map +1 -0
- package/dist/shared/redis/redis-mutex.service.js +75 -0
- package/dist/shared/redis/redis-mutex.service.js.map +1 -0
- package/dist/shared/redis/redis.constants.d.ts +3 -0
- package/dist/shared/redis/redis.constants.d.ts.map +1 -0
- package/dist/shared/redis/redis.constants.js +6 -0
- package/dist/shared/redis/redis.constants.js.map +1 -0
- package/dist/shared/redis/redis.module.d.ts +8 -0
- package/dist/shared/redis/redis.module.d.ts.map +1 -0
- package/dist/shared/redis/redis.module.js +54 -0
- package/dist/shared/redis/redis.module.js.map +1 -0
- package/dist/shared/runtime-module-options.d.ts +5 -0
- package/dist/shared/runtime-module-options.d.ts.map +1 -0
- package/dist/shared/runtime-module-options.js +3 -0
- package/dist/shared/runtime-module-options.js.map +1 -0
- package/dist/webhook/channels/webhook/local-connector-context.resolver.d.ts +8 -0
- package/dist/webhook/channels/webhook/local-connector-context.resolver.d.ts.map +1 -0
- package/dist/webhook/channels/webhook/local-connector-context.resolver.js +63 -0
- package/dist/webhook/channels/webhook/local-connector-context.resolver.js.map +1 -0
- package/dist/webhook/channels/webhook/webhook-token.util.d.ts +4 -0
- package/dist/webhook/channels/webhook/webhook-token.util.d.ts.map +1 -0
- package/dist/webhook/channels/webhook/webhook-token.util.js +26 -0
- package/dist/webhook/channels/webhook/webhook-token.util.js.map +1 -0
- package/dist/webhook/channels/webhook/webhook.controller.d.ts +226 -0
- package/dist/webhook/channels/webhook/webhook.controller.d.ts.map +1 -0
- package/dist/webhook/channels/webhook/webhook.controller.js +121 -0
- package/dist/webhook/channels/webhook/webhook.controller.js.map +1 -0
- package/dist/webhook/channels/webhook/webhook.module.d.ts +3 -0
- package/dist/webhook/channels/webhook/webhook.module.d.ts.map +1 -0
- package/dist/webhook/channels/webhook/webhook.module.js +27 -0
- package/dist/webhook/channels/webhook/webhook.module.js.map +1 -0
- package/dist/webhook/channels/webhook/webhook.repository.d.ts +85 -0
- package/dist/webhook/channels/webhook/webhook.repository.d.ts.map +1 -0
- package/dist/webhook/channels/webhook/webhook.repository.js +268 -0
- package/dist/webhook/channels/webhook/webhook.repository.js.map +1 -0
- package/dist/webhook/channels/webhook/webhook.service.d.ts +144 -0
- package/dist/webhook/channels/webhook/webhook.service.d.ts.map +1 -0
- package/dist/webhook/channels/webhook/webhook.service.js +494 -0
- package/dist/webhook/channels/webhook/webhook.service.js.map +1 -0
- package/dist/webhook/index.d.ts +4 -0
- package/dist/webhook/index.d.ts.map +1 -0
- package/dist/webhook/index.js +8 -0
- package/dist/webhook/index.js.map +1 -0
- package/dist/webhook/infrastructure/orchestration/bullmq.module.d.ts +3 -0
- package/dist/webhook/infrastructure/orchestration/bullmq.module.d.ts.map +1 -0
- package/dist/webhook/infrastructure/orchestration/bullmq.module.js +34 -0
- package/dist/webhook/infrastructure/orchestration/bullmq.module.js.map +1 -0
- package/dist/webhook/infrastructure/orchestration/bullmq.service.d.ts +10 -0
- package/dist/webhook/infrastructure/orchestration/bullmq.service.d.ts.map +1 -0
- package/dist/webhook/infrastructure/orchestration/bullmq.service.js +42 -0
- package/dist/webhook/infrastructure/orchestration/bullmq.service.js.map +1 -0
- package/dist/webhook/proofhound-webhook.module.d.ts +7 -0
- package/dist/webhook/proofhound-webhook.module.d.ts.map +1 -0
- package/dist/webhook/proofhound-webhook.module.js +31 -0
- package/dist/webhook/proofhound-webhook.module.js.map +1 -0
- package/dist/worker/config/worker-concurrency.d.ts +3 -0
- package/dist/worker/config/worker-concurrency.d.ts.map +1 -0
- package/dist/worker/config/worker-concurrency.js +10 -0
- package/dist/worker/config/worker-concurrency.js.map +1 -0
- package/dist/worker/consumers/llm.consumer.d.ts +29 -0
- package/dist/worker/consumers/llm.consumer.d.ts.map +1 -0
- package/dist/worker/consumers/llm.consumer.js +234 -0
- package/dist/worker/consumers/llm.consumer.js.map +1 -0
- package/dist/worker/consumers/probe.consumer.d.ts +16 -0
- package/dist/worker/consumers/probe.consumer.d.ts.map +1 -0
- package/dist/worker/consumers/probe.consumer.js +76 -0
- package/dist/worker/consumers/probe.consumer.js.map +1 -0
- package/dist/worker/index.d.ts +4 -0
- package/dist/worker/index.d.ts.map +1 -0
- package/dist/worker/index.js +9 -0
- package/dist/worker/index.js.map +1 -0
- package/dist/worker/infrastructure/llm/model-secret.provider.d.ts +4 -0
- package/dist/worker/infrastructure/llm/model-secret.provider.d.ts.map +1 -0
- package/dist/worker/infrastructure/llm/model-secret.provider.js +14 -0
- package/dist/worker/infrastructure/llm/model-secret.provider.js.map +1 -0
- package/dist/worker/proofhound-worker.module.d.ts +7 -0
- package/dist/worker/proofhound-worker.module.d.ts.map +1 -0
- package/dist/worker/proofhound-worker.module.js +44 -0
- package/dist/worker/proofhound-worker.module.js.map +1 -0
- package/dist/worker/runners/llm-runner.d.ts +42 -0
- package/dist/worker/runners/llm-runner.d.ts.map +1 -0
- package/dist/worker/runners/llm-runner.js +178 -0
- package/dist/worker/runners/llm-runner.js.map +1 -0
- package/dist/worker/runners/model-secret.d.ts +11 -0
- package/dist/worker/runners/model-secret.d.ts.map +1 -0
- package/dist/worker/runners/model-secret.js +14 -0
- package/dist/worker/runners/model-secret.js.map +1 -0
- package/dist/worker/runners/probe-runner.d.ts +22 -0
- package/dist/worker/runners/probe-runner.d.ts.map +1 -0
- package/dist/worker/runners/probe-runner.js +52 -0
- package/dist/worker/runners/probe-runner.js.map +1 -0
- package/dist/worker/runners/run-result-writer.d.ts +10 -0
- package/dist/worker/runners/run-result-writer.d.ts.map +1 -0
- package/dist/worker/runners/run-result-writer.js +84 -0
- package/dist/worker/runners/run-result-writer.js.map +1 -0
- package/dist/worker/scripts/probe-model-from-env.d.ts +2 -0
- package/dist/worker/scripts/probe-model-from-env.d.ts.map +1 -0
- package/dist/worker/scripts/probe-model-from-env.js +130 -0
- package/dist/worker/scripts/probe-model-from-env.js.map +1 -0
- package/package.json +93 -0
|
@@ -0,0 +1,74 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
3
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
4
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
5
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
6
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
7
|
+
};
|
|
8
|
+
var __metadata = (this && this.__metadata) || function (k, v) {
|
|
9
|
+
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
10
|
+
};
|
|
11
|
+
var __param = (this && this.__param) || function (paramIndex, decorator) {
|
|
12
|
+
return function (target, key) { decorator(target, key, paramIndex); }
|
|
13
|
+
};
|
|
14
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
15
|
+
exports.HealthService = void 0;
|
|
16
|
+
const common_1 = require("@nestjs/common");
|
|
17
|
+
const drizzle_orm_1 = require("drizzle-orm");
|
|
18
|
+
const database_constants_1 = require("../database/database.constants");
|
|
19
|
+
const redis_constants_1 = require("../redis/redis.constants");
|
|
20
|
+
const CHECK_TIMEOUT_MS = 1_000;
|
|
21
|
+
let HealthService = class HealthService {
|
|
22
|
+
constructor(db, redis) {
|
|
23
|
+
this.db = db;
|
|
24
|
+
this.redis = redis;
|
|
25
|
+
}
|
|
26
|
+
liveness() {
|
|
27
|
+
return { status: 'ok' };
|
|
28
|
+
}
|
|
29
|
+
async readiness() {
|
|
30
|
+
const [database, redis] = await Promise.all([
|
|
31
|
+
this.checkDependency('database', () => this.db.execute((0, drizzle_orm_1.sql) `SELECT 1`)),
|
|
32
|
+
this.checkDependency('redis', () => this.redis.ping()),
|
|
33
|
+
]);
|
|
34
|
+
return {
|
|
35
|
+
status: database.status === 'ok' && redis.status === 'ok' ? 'ok' : 'error',
|
|
36
|
+
checks: { database, redis },
|
|
37
|
+
};
|
|
38
|
+
}
|
|
39
|
+
async checkDependency(name, operation) {
|
|
40
|
+
const startedAt = Date.now();
|
|
41
|
+
try {
|
|
42
|
+
await withTimeout(operation(), CHECK_TIMEOUT_MS, name);
|
|
43
|
+
return { status: 'ok', latencyMs: Date.now() - startedAt };
|
|
44
|
+
}
|
|
45
|
+
catch (error) {
|
|
46
|
+
return {
|
|
47
|
+
status: 'error',
|
|
48
|
+
latencyMs: Date.now() - startedAt,
|
|
49
|
+
errorClass: error instanceof Error ? error.name : 'UnknownError',
|
|
50
|
+
};
|
|
51
|
+
}
|
|
52
|
+
}
|
|
53
|
+
};
|
|
54
|
+
exports.HealthService = HealthService;
|
|
55
|
+
exports.HealthService = HealthService = __decorate([
|
|
56
|
+
(0, common_1.Injectable)(),
|
|
57
|
+
__param(0, (0, common_1.Inject)(database_constants_1.DATABASE_CLIENT)),
|
|
58
|
+
__param(1, (0, common_1.Inject)(redis_constants_1.REDIS_CLIENT)),
|
|
59
|
+
__metadata("design:paramtypes", [Object, Function])
|
|
60
|
+
], HealthService);
|
|
61
|
+
async function withTimeout(promise, timeoutMs, name) {
|
|
62
|
+
let timer;
|
|
63
|
+
const timeout = new Promise((_resolve, reject) => {
|
|
64
|
+
timer = setTimeout(() => reject(new Error(`${name}_health_check_timeout`)), timeoutMs);
|
|
65
|
+
});
|
|
66
|
+
try {
|
|
67
|
+
return await Promise.race([promise, timeout]);
|
|
68
|
+
}
|
|
69
|
+
finally {
|
|
70
|
+
if (timer)
|
|
71
|
+
clearTimeout(timer);
|
|
72
|
+
}
|
|
73
|
+
}
|
|
74
|
+
//# sourceMappingURL=health.service.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"health.service.js","sourceRoot":"","sources":["../../../src/shared/health/health.service.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;AAAA,2CAAoD;AAEpD,6CAAkC;AAElC,uEAAiE;AACjE,8DAAwD;AAExD,MAAM,gBAAgB,GAAG,KAAK,CAAC;AAiBxB,IAAM,aAAa,GAAnB,MAAM,aAAa;IACxB,YAC4C,EAAY,EACf,KAAY;QADT,OAAE,GAAF,EAAE,CAAU;QACf,UAAK,GAAL,KAAK,CAAO;IAClD,CAAC;IAEJ,QAAQ;QACN,OAAO,EAAE,MAAM,EAAE,IAAI,EAAE,CAAC;IAC1B,CAAC;IAED,KAAK,CAAC,SAAS;QACb,MAAM,CAAC,QAAQ,EAAE,KAAK,CAAC,GAAG,MAAM,OAAO,CAAC,GAAG,CAAC;YAC1C,IAAI,CAAC,eAAe,CAAC,UAAU,EAAE,GAAG,EAAE,CAAC,IAAI,CAAC,EAAE,CAAC,OAAO,CAAC,IAAA,iBAAG,EAAA,UAAU,CAAC,CAAC;YACtE,IAAI,CAAC,eAAe,CAAC,OAAO,EAAE,GAAG,EAAE,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,EAAE,CAAC;SACvD,CAAC,CAAC;QAEH,OAAO;YACL,MAAM,EAAE,QAAQ,CAAC,MAAM,KAAK,IAAI,IAAI,KAAK,CAAC,MAAM,KAAK,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,OAAO;YAC1E,MAAM,EAAE,EAAE,QAAQ,EAAE,KAAK,EAAE;SAC5B,CAAC;IACJ,CAAC;IAEO,KAAK,CAAC,eAAe,CAAC,IAAe,EAAE,SAAiC;QAC9E,MAAM,SAAS,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;QAE7B,IAAI,CAAC;YACH,MAAM,WAAW,CAAC,SAAS,EAAE,EAAE,gBAAgB,EAAE,IAAI,CAAC,CAAC;YACvD,OAAO,EAAE,MAAM,EAAE,IAAI,EAAE,SAAS,EAAE,IAAI,CAAC,GAAG,EAAE,GAAG,SAAS,EAAE,CAAC;QAC7D,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,OAAO;gBACL,MAAM,EAAE,OAAO;gBACf,SAAS,EAAE,IAAI,CAAC,GAAG,EAAE,GAAG,SAAS;gBACjC,UAAU,EAAE,KAAK,YAAY,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,cAAc;aACjE,CAAC;QACJ,CAAC;IACH,CAAC;CACF,CAAA;AApCY,sCAAa;wBAAb,aAAa;IADzB,IAAA,mBAAU,GAAE;IAGR,WAAA,IAAA,eAAM,EAAC,oCAAe,CAAC,CAAA;IACvB,WAAA,IAAA,eAAM,EAAC,8BAAY,CAAC,CAAA;;GAHZ,aAAa,CAoCzB;AAED,KAAK,UAAU,WAAW,CAAI,OAAmB,EAAE,SAAiB,EAAE,IAAY;IAChF,IAAI,KAAgD,CAAC;IACrD,MAAM,OAAO,GAAG,IAAI,OAAO,CAAQ,CAAC,QAAQ,EAAE,MAAM,EAAE,EAAE;QACtD,KAAK,GAAG,UAAU,CAAC,GAAG,EAAE,CAAC,MAAM,CAAC,IAAI,KAAK,CAAC,GAAG,IAAI,uBAAuB,CAAC,CAAC,EAAE,SAAS,CAAC,CAAC;IACzF,CAAC,CAAC,CAAC;IAEH,IAAI,CAAC;QACH,OAAO,MAAM,OAAO,CAAC,IAAI,CAAC,CAAC,OAAO,EAAE,OAAO,CAAC,CAAC,CAAC;IAChD,CAAC;YAAS,CAAC;QACT,IAAI,KAAK;YAAE,YAAY,CAAC,KAAK,CAAC,CAAC;IACjC,CAAC;AACH,CAAC"}
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
import type { ModelInvocationConfig } from '@proofhound/llm-client';
|
|
2
|
+
import type { RuntimeLimits } from '@proofhound/orchestration-shared';
|
|
3
|
+
export declare function applyRuntimeLimits(model: ModelInvocationConfig, limits: RuntimeLimits | undefined): ModelInvocationConfig;
|
|
4
|
+
//# sourceMappingURL=runtime-limits.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"runtime-limits.d.ts","sourceRoot":"","sources":["../../../src/shared/llm/runtime-limits.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,qBAAqB,EAAE,MAAM,wBAAwB,CAAC;AACpE,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,kCAAkC,CAAC;AAEtE,wBAAgB,kBAAkB,CAChC,KAAK,EAAE,qBAAqB,EAC5B,MAAM,EAAE,aAAa,GAAG,SAAS,GAChC,qBAAqB,CAWvB"}
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.applyRuntimeLimits = applyRuntimeLimits;
|
|
4
|
+
function applyRuntimeLimits(model, limits) {
|
|
5
|
+
if (!limits)
|
|
6
|
+
return model;
|
|
7
|
+
return {
|
|
8
|
+
...model,
|
|
9
|
+
rpmLimit: mergeTokenBucketLimit(model.rpmLimit, limits.rpmLimit),
|
|
10
|
+
tpmLimit: mergeTokenBucketLimit(model.tpmLimit, limits.tpmLimit),
|
|
11
|
+
concurrencyLimit: typeof limits.concurrency === 'number'
|
|
12
|
+
? Math.min(model.concurrencyLimit, limits.concurrency)
|
|
13
|
+
: model.concurrencyLimit,
|
|
14
|
+
};
|
|
15
|
+
}
|
|
16
|
+
function mergeTokenBucketLimit(modelLimit, runtimeLimit) {
|
|
17
|
+
if (typeof runtimeLimit !== 'number' || runtimeLimit <= 0)
|
|
18
|
+
return modelLimit;
|
|
19
|
+
if (modelLimit <= 0)
|
|
20
|
+
return runtimeLimit;
|
|
21
|
+
return Math.min(modelLimit, runtimeLimit);
|
|
22
|
+
}
|
|
23
|
+
//# sourceMappingURL=runtime-limits.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"runtime-limits.js","sourceRoot":"","sources":["../../../src/shared/llm/runtime-limits.ts"],"names":[],"mappings":";;AAGA,gDAcC;AAdD,SAAgB,kBAAkB,CAChC,KAA4B,EAC5B,MAAiC;IAEjC,IAAI,CAAC,MAAM;QAAE,OAAO,KAAK,CAAC;IAC1B,OAAO;QACL,GAAG,KAAK;QACR,QAAQ,EAAE,qBAAqB,CAAC,KAAK,CAAC,QAAQ,EAAE,MAAM,CAAC,QAAQ,CAAC;QAChE,QAAQ,EAAE,qBAAqB,CAAC,KAAK,CAAC,QAAQ,EAAE,MAAM,CAAC,QAAQ,CAAC;QAChE,gBAAgB,EACd,OAAO,MAAM,CAAC,WAAW,KAAK,QAAQ;YACpC,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,gBAAgB,EAAE,MAAM,CAAC,WAAW,CAAC;YACtD,CAAC,CAAC,KAAK,CAAC,gBAAgB;KAC7B,CAAC;AACJ,CAAC;AAED,SAAS,qBAAqB,CAAC,UAAkB,EAAE,YAAgC;IACjF,IAAI,OAAO,YAAY,KAAK,QAAQ,IAAI,YAAY,IAAI,CAAC;QAAE,OAAO,UAAU,CAAC;IAC7E,IAAI,UAAU,IAAI,CAAC;QAAE,OAAO,YAAY,CAAC;IACzC,OAAO,IAAI,CAAC,GAAG,CAAC,UAAU,EAAE,YAAY,CAAC,CAAC;AAC5C,CAAC"}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import type Redis from 'ioredis';
|
|
2
|
+
export interface RedisMutexAcquireInput {
|
|
3
|
+
key: string;
|
|
4
|
+
ttlMs: number;
|
|
5
|
+
}
|
|
6
|
+
export declare class RedisMutexLease {
|
|
7
|
+
private readonly redis;
|
|
8
|
+
readonly key: string;
|
|
9
|
+
readonly token: string;
|
|
10
|
+
readonly ttlMs: number;
|
|
11
|
+
constructor(redis: Redis, key: string, token: string, ttlMs: number);
|
|
12
|
+
renew(): Promise<boolean>;
|
|
13
|
+
release(): Promise<boolean>;
|
|
14
|
+
}
|
|
15
|
+
export declare class RedisMutexService {
|
|
16
|
+
private readonly redis;
|
|
17
|
+
constructor(redis: Redis);
|
|
18
|
+
acquire(input: RedisMutexAcquireInput): Promise<RedisMutexLease | null>;
|
|
19
|
+
}
|
|
20
|
+
//# sourceMappingURL=redis-mutex.service.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"redis-mutex.service.d.ts","sourceRoot":"","sources":["../../../src/shared/redis/redis-mutex.service.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,KAAK,MAAM,SAAS,CAAC;AAiBjC,MAAM,WAAW,sBAAsB;IACrC,GAAG,EAAE,MAAM,CAAC;IACZ,KAAK,EAAE,MAAM,CAAC;CACf;AAED,qBAAa,eAAe;IAExB,OAAO,CAAC,QAAQ,CAAC,KAAK;IACtB,QAAQ,CAAC,GAAG,EAAE,MAAM;IACpB,QAAQ,CAAC,KAAK,EAAE,MAAM;IACtB,QAAQ,CAAC,KAAK,EAAE,MAAM;gBAHL,KAAK,EAAE,KAAK,EACpB,GAAG,EAAE,MAAM,EACX,KAAK,EAAE,MAAM,EACb,KAAK,EAAE,MAAM;IAGlB,KAAK,IAAI,OAAO,CAAC,OAAO,CAAC;IAKzB,OAAO,IAAI,OAAO,CAAC,OAAO,CAAC;CAIlC;AAED,qBACa,iBAAiB;IACM,OAAO,CAAC,QAAQ,CAAC,KAAK;gBAAL,KAAK,EAAE,KAAK;IAEzD,OAAO,CAAC,KAAK,EAAE,sBAAsB,GAAG,OAAO,CAAC,eAAe,GAAG,IAAI,CAAC;CAW9E"}
|
|
@@ -0,0 +1,75 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
3
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
4
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
5
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
6
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
7
|
+
};
|
|
8
|
+
var __metadata = (this && this.__metadata) || function (k, v) {
|
|
9
|
+
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
10
|
+
};
|
|
11
|
+
var __param = (this && this.__param) || function (paramIndex, decorator) {
|
|
12
|
+
return function (target, key) { decorator(target, key, paramIndex); }
|
|
13
|
+
};
|
|
14
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
15
|
+
exports.RedisMutexService = exports.RedisMutexLease = void 0;
|
|
16
|
+
const node_crypto_1 = require("node:crypto");
|
|
17
|
+
const common_1 = require("@nestjs/common");
|
|
18
|
+
const redis_constants_1 = require("./redis.constants");
|
|
19
|
+
const RELEASE_IF_OWNER_SCRIPT = `
|
|
20
|
+
if redis.call('GET', KEYS[1]) == ARGV[1] then
|
|
21
|
+
return redis.call('DEL', KEYS[1])
|
|
22
|
+
end
|
|
23
|
+
return 0
|
|
24
|
+
`;
|
|
25
|
+
const RENEW_IF_OWNER_SCRIPT = `
|
|
26
|
+
if redis.call('GET', KEYS[1]) == ARGV[1] then
|
|
27
|
+
return redis.call('PEXPIRE', KEYS[1], ARGV[2])
|
|
28
|
+
end
|
|
29
|
+
return 0
|
|
30
|
+
`;
|
|
31
|
+
class RedisMutexLease {
|
|
32
|
+
constructor(redis, key, token, ttlMs) {
|
|
33
|
+
this.redis = redis;
|
|
34
|
+
this.key = key;
|
|
35
|
+
this.token = token;
|
|
36
|
+
this.ttlMs = ttlMs;
|
|
37
|
+
}
|
|
38
|
+
async renew() {
|
|
39
|
+
const result = await this.redis.eval(RENEW_IF_OWNER_SCRIPT, 1, this.key, this.token, this.ttlMs);
|
|
40
|
+
return isRedisTruthy(result);
|
|
41
|
+
}
|
|
42
|
+
async release() {
|
|
43
|
+
const result = await this.redis.eval(RELEASE_IF_OWNER_SCRIPT, 1, this.key, this.token);
|
|
44
|
+
return isRedisTruthy(result);
|
|
45
|
+
}
|
|
46
|
+
}
|
|
47
|
+
exports.RedisMutexLease = RedisMutexLease;
|
|
48
|
+
let RedisMutexService = class RedisMutexService {
|
|
49
|
+
constructor(redis) {
|
|
50
|
+
this.redis = redis;
|
|
51
|
+
}
|
|
52
|
+
async acquire(input) {
|
|
53
|
+
const key = input.key.trim();
|
|
54
|
+
const ttlMs = Math.floor(input.ttlMs);
|
|
55
|
+
if (key.length === 0)
|
|
56
|
+
throw new Error('redis_mutex_key_required');
|
|
57
|
+
if (!Number.isFinite(ttlMs) || ttlMs <= 0)
|
|
58
|
+
throw new Error('redis_mutex_invalid_ttl');
|
|
59
|
+
const token = (0, node_crypto_1.randomUUID)();
|
|
60
|
+
const result = await this.redis.set(key, token, 'PX', ttlMs, 'NX');
|
|
61
|
+
if (result !== 'OK')
|
|
62
|
+
return null;
|
|
63
|
+
return new RedisMutexLease(this.redis, key, token, ttlMs);
|
|
64
|
+
}
|
|
65
|
+
};
|
|
66
|
+
exports.RedisMutexService = RedisMutexService;
|
|
67
|
+
exports.RedisMutexService = RedisMutexService = __decorate([
|
|
68
|
+
(0, common_1.Injectable)(),
|
|
69
|
+
__param(0, (0, common_1.Inject)(redis_constants_1.REDIS_CLIENT)),
|
|
70
|
+
__metadata("design:paramtypes", [Function])
|
|
71
|
+
], RedisMutexService);
|
|
72
|
+
function isRedisTruthy(result) {
|
|
73
|
+
return result === 1 || result === '1';
|
|
74
|
+
}
|
|
75
|
+
//# sourceMappingURL=redis-mutex.service.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"redis-mutex.service.js","sourceRoot":"","sources":["../../../src/shared/redis/redis-mutex.service.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;AAAA,6CAAyC;AACzC,2CAAoD;AAEpD,uDAAiD;AAEjD,MAAM,uBAAuB,GAAG;;;;;CAK/B,CAAC;AAEF,MAAM,qBAAqB,GAAG;;;;;CAK7B,CAAC;AAOF,MAAa,eAAe;IAC1B,YACmB,KAAY,EACpB,GAAW,EACX,KAAa,EACb,KAAa;QAHL,UAAK,GAAL,KAAK,CAAO;QACpB,QAAG,GAAH,GAAG,CAAQ;QACX,UAAK,GAAL,KAAK,CAAQ;QACb,UAAK,GAAL,KAAK,CAAQ;IACrB,CAAC;IAEJ,KAAK,CAAC,KAAK;QACT,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,qBAAqB,EAAE,CAAC,EAAE,IAAI,CAAC,GAAG,EAAE,IAAI,CAAC,KAAK,EAAE,IAAI,CAAC,KAAK,CAAC,CAAC;QACjG,OAAO,aAAa,CAAC,MAAM,CAAC,CAAC;IAC/B,CAAC;IAED,KAAK,CAAC,OAAO;QACX,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,uBAAuB,EAAE,CAAC,EAAE,IAAI,CAAC,GAAG,EAAE,IAAI,CAAC,KAAK,CAAC,CAAC;QACvF,OAAO,aAAa,CAAC,MAAM,CAAC,CAAC;IAC/B,CAAC;CACF;AAjBD,0CAiBC;AAGM,IAAM,iBAAiB,GAAvB,MAAM,iBAAiB;IAC5B,YAAmD,KAAY;QAAZ,UAAK,GAAL,KAAK,CAAO;IAAG,CAAC;IAEnE,KAAK,CAAC,OAAO,CAAC,KAA6B;QACzC,MAAM,GAAG,GAAG,KAAK,CAAC,GAAG,CAAC,IAAI,EAAE,CAAC;QAC7B,MAAM,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;QACtC,IAAI,GAAG,CAAC,MAAM,KAAK,CAAC;YAAE,MAAM,IAAI,KAAK,CAAC,0BAA0B,CAAC,CAAC;QAClE,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,KAAK,CAAC,IAAI,KAAK,IAAI,CAAC;YAAE,MAAM,IAAI,KAAK,CAAC,yBAAyB,CAAC,CAAC;QAEtF,MAAM,KAAK,GAAG,IAAA,wBAAU,GAAE,CAAC;QAC3B,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,GAAG,EAAE,KAAK,EAAE,IAAI,EAAE,KAAK,EAAE,IAAI,CAAC,CAAC;QACnE,IAAI,MAAM,KAAK,IAAI;YAAE,OAAO,IAAI,CAAC;QACjC,OAAO,IAAI,eAAe,CAAC,IAAI,CAAC,KAAK,EAAE,GAAG,EAAE,KAAK,EAAE,KAAK,CAAC,CAAC;IAC5D,CAAC;CACF,CAAA;AAdY,8CAAiB;4BAAjB,iBAAiB;IAD7B,IAAA,mBAAU,GAAE;IAEE,WAAA,IAAA,eAAM,EAAC,8BAAY,CAAC,CAAA;;GADtB,iBAAiB,CAc7B;AAED,SAAS,aAAa,CAAC,MAAe;IACpC,OAAO,MAAM,KAAK,CAAC,IAAI,MAAM,KAAK,GAAG,CAAC;AACxC,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"redis.constants.d.ts","sourceRoot":"","sources":["../../../src/shared/redis/redis.constants.ts"],"names":[],"mappings":"AAAA,eAAO,MAAM,YAAY,eAAyB,CAAC;AACnD,eAAO,MAAM,aAAa,eAA0B,CAAC"}
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.REDIS_LIMITER = exports.REDIS_CLIENT = void 0;
|
|
4
|
+
exports.REDIS_CLIENT = Symbol('REDIS_CLIENT');
|
|
5
|
+
exports.REDIS_LIMITER = Symbol('REDIS_LIMITER');
|
|
6
|
+
//# sourceMappingURL=redis.constants.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"redis.constants.js","sourceRoot":"","sources":["../../../src/shared/redis/redis.constants.ts"],"names":[],"mappings":";;;AAAa,QAAA,YAAY,GAAG,MAAM,CAAC,cAAc,CAAC,CAAC;AACtC,QAAA,aAAa,GAAG,MAAM,CAAC,eAAe,CAAC,CAAC"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import { type OnModuleDestroy } from '@nestjs/common';
|
|
2
|
+
import { ModuleRef } from '@nestjs/core';
|
|
3
|
+
export declare class RedisModule implements OnModuleDestroy {
|
|
4
|
+
private readonly moduleRef;
|
|
5
|
+
constructor(moduleRef: ModuleRef);
|
|
6
|
+
onModuleDestroy(): Promise<void>;
|
|
7
|
+
}
|
|
8
|
+
//# sourceMappingURL=redis.module.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"redis.module.d.ts","sourceRoot":"","sources":["../../../src/shared/redis/redis.module.ts"],"names":[],"mappings":"AAAA,OAAO,EAAkB,KAAK,eAAe,EAAE,MAAM,gBAAgB,CAAC;AACtE,OAAO,EAAE,SAAS,EAAE,MAAM,cAAc,CAAC;AAMzC,qBAea,WAAY,YAAW,eAAe;IAClB,OAAO,CAAC,QAAQ,CAAC,SAAS;gBAAT,SAAS,EAAE,SAAS;IAE9D,eAAe,IAAI,OAAO,CAAC,IAAI,CAAC;CAIvC"}
|
|
@@ -0,0 +1,54 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
3
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
4
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
5
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
6
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
7
|
+
};
|
|
8
|
+
var __metadata = (this && this.__metadata) || function (k, v) {
|
|
9
|
+
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
10
|
+
};
|
|
11
|
+
var __param = (this && this.__param) || function (paramIndex, decorator) {
|
|
12
|
+
return function (target, key) { decorator(target, key, paramIndex); }
|
|
13
|
+
};
|
|
14
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
15
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
16
|
+
};
|
|
17
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
18
|
+
exports.RedisModule = void 0;
|
|
19
|
+
const common_1 = require("@nestjs/common");
|
|
20
|
+
const core_1 = require("@nestjs/core");
|
|
21
|
+
const limiter_1 = require("@proofhound/limiter");
|
|
22
|
+
const ioredis_1 = __importDefault(require("ioredis"));
|
|
23
|
+
const redis_constants_1 = require("./redis.constants");
|
|
24
|
+
const redis_mutex_service_1 = require("./redis-mutex.service");
|
|
25
|
+
let RedisModule = class RedisModule {
|
|
26
|
+
constructor(moduleRef) {
|
|
27
|
+
this.moduleRef = moduleRef;
|
|
28
|
+
}
|
|
29
|
+
async onModuleDestroy() {
|
|
30
|
+
const redis = this.moduleRef.get(redis_constants_1.REDIS_CLIENT, { strict: false });
|
|
31
|
+
await redis?.quit();
|
|
32
|
+
}
|
|
33
|
+
};
|
|
34
|
+
exports.RedisModule = RedisModule;
|
|
35
|
+
exports.RedisModule = RedisModule = __decorate([
|
|
36
|
+
(0, common_1.Module)({
|
|
37
|
+
providers: [
|
|
38
|
+
{
|
|
39
|
+
provide: redis_constants_1.REDIS_CLIENT,
|
|
40
|
+
useFactory: () => new ioredis_1.default(process.env['REDIS_URL'] ?? 'redis://localhost:6379', { maxRetriesPerRequest: null }),
|
|
41
|
+
},
|
|
42
|
+
{
|
|
43
|
+
provide: redis_constants_1.REDIS_LIMITER,
|
|
44
|
+
inject: [redis_constants_1.REDIS_CLIENT],
|
|
45
|
+
useFactory: (redis) => new limiter_1.RedisLimiter(redis),
|
|
46
|
+
},
|
|
47
|
+
redis_mutex_service_1.RedisMutexService,
|
|
48
|
+
],
|
|
49
|
+
exports: [redis_constants_1.REDIS_CLIENT, redis_constants_1.REDIS_LIMITER, redis_mutex_service_1.RedisMutexService],
|
|
50
|
+
}),
|
|
51
|
+
__param(0, (0, common_1.Inject)(core_1.ModuleRef)),
|
|
52
|
+
__metadata("design:paramtypes", [core_1.ModuleRef])
|
|
53
|
+
], RedisModule);
|
|
54
|
+
//# sourceMappingURL=redis.module.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"redis.module.js","sourceRoot":"","sources":["../../../src/shared/redis/redis.module.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;AAAA,2CAAsE;AACtE,uCAAyC;AACzC,iDAAmD;AACnD,sDAA4B;AAC5B,uDAAgE;AAChE,+DAA0D;AAiBnD,IAAM,WAAW,GAAjB,MAAM,WAAW;IACtB,YAAgD,SAAoB;QAApB,cAAS,GAAT,SAAS,CAAW;IAAG,CAAC;IAExE,KAAK,CAAC,eAAe;QACnB,MAAM,KAAK,GAAG,IAAI,CAAC,SAAS,CAAC,GAAG,CAAQ,8BAAY,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE,CAAC,CAAC;QACzE,MAAM,KAAK,EAAE,IAAI,EAAE,CAAC;IACtB,CAAC;CACF,CAAA;AAPY,kCAAW;sBAAX,WAAW;IAfvB,IAAA,eAAM,EAAC;QACN,SAAS,EAAE;YACT;gBACE,OAAO,EAAE,8BAAY;gBACrB,UAAU,EAAE,GAAG,EAAE,CAAC,IAAI,iBAAK,CAAC,OAAO,CAAC,GAAG,CAAC,WAAW,CAAC,IAAI,wBAAwB,EAAE,EAAE,oBAAoB,EAAE,IAAI,EAAE,CAAC;aAClH;YACD;gBACE,OAAO,EAAE,+BAAa;gBACtB,MAAM,EAAE,CAAC,8BAAY,CAAC;gBACtB,UAAU,EAAE,CAAC,KAAY,EAAE,EAAE,CAAC,IAAI,sBAAY,CAAC,KAAK,CAAC;aACtD;YACD,uCAAiB;SAClB;QACD,OAAO,EAAE,CAAC,8BAAY,EAAE,+BAAa,EAAE,uCAAiB,CAAC;KAC1D,CAAC;IAEa,WAAA,IAAA,eAAM,EAAC,gBAAS,CAAC,CAAA;qCAA6B,gBAAS;GADzD,WAAW,CAOvB"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"runtime-module-options.d.ts","sourceRoot":"","sources":["../../src/shared/runtime-module-options.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,aAAa,EAAE,IAAI,EAAE,MAAM,gBAAgB,CAAC;AAE1D,MAAM,WAAW,8BAA8B;IAG7C,SAAS,EAAE,IAAI,CAAC,OAAO,CAAC,GAAG,aAAa,CAAC;CAC1C"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"runtime-module-options.js","sourceRoot":"","sources":["../../src/shared/runtime-module-options.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import { ConnectorContextResolver, type ConnectorResolveResult } from '../../../server/common/contracts/connector-context.resolver';
|
|
2
|
+
import { WebhookRepository } from './webhook.repository';
|
|
3
|
+
export declare class LocalConnectorContextResolver extends ConnectorContextResolver {
|
|
4
|
+
private readonly repo;
|
|
5
|
+
constructor(repo: WebhookRepository);
|
|
6
|
+
resolveFromWebhookToken(webhookSlug: string, pathName: string, token: string): Promise<ConnectorResolveResult>;
|
|
7
|
+
}
|
|
8
|
+
//# sourceMappingURL=local-connector-context.resolver.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"local-connector-context.resolver.d.ts","sourceRoot":"","sources":["../../../../src/webhook/channels/webhook/local-connector-context.resolver.ts"],"names":[],"mappings":"AAgBA,OAAO,EACL,wBAAwB,EACxB,KAAK,sBAAsB,EAC5B,MAAM,6DAA6D,CAAC;AACrE,OAAO,EAAE,iBAAiB,EAAE,MAAM,sBAAsB,CAAC;AAGzD,qBACa,6BAA8B,SAAQ,wBAAwB;IAClC,OAAO,CAAC,QAAQ,CAAC,IAAI;gBAAJ,IAAI,EAAE,iBAAiB;IAIzE,uBAAuB,CAC3B,WAAW,EAAE,MAAM,EACnB,QAAQ,EAAE,MAAM,EAChB,KAAK,EAAE,MAAM,GACZ,OAAO,CAAC,sBAAsB,CAAC;CAsBnC"}
|
|
@@ -0,0 +1,63 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
// LocalConnectorContextResolver — OSS default for ConnectorContextResolver (§3.4)
|
|
3
|
+
// See docs/specs/08-saas-adapter-boundary.md §3.4 and docs/specs/09-mcp-server.md is unrelated.
|
|
4
|
+
//
|
|
5
|
+
// Extracted from the previously-inline WebhookService.authorizeConnector. Validates inbound webhook
|
|
6
|
+
// credentials and produces { connector, projectContext, actorContext, webhookTokenId } in one shot —
|
|
7
|
+
// the webhook entry does NOT go through ProjectContextResolver (§3.1).
|
|
8
|
+
//
|
|
9
|
+
// Lives in the webhook runtime because it depends on WebhookRepository. The abstract
|
|
10
|
+
// ConnectorContextResolver lives in server/common/contracts (the shared adapter seam); importing it
|
|
11
|
+
// here is acyclic (the abstract never imports the webhook runtime).
|
|
12
|
+
//
|
|
13
|
+
// expired-vs-invalid distinction: the repo query deliberately omits the `expires_at > now()` filter so
|
|
14
|
+
// a missing row → `invalid_webhook_token`, while a present-but-expired row → `expired_webhook_token`.
|
|
15
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
16
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
17
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
18
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
19
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
20
|
+
};
|
|
21
|
+
var __metadata = (this && this.__metadata) || function (k, v) {
|
|
22
|
+
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
23
|
+
};
|
|
24
|
+
var __param = (this && this.__param) || function (paramIndex, decorator) {
|
|
25
|
+
return function (target, key) { decorator(target, key, paramIndex); }
|
|
26
|
+
};
|
|
27
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
28
|
+
exports.LocalConnectorContextResolver = void 0;
|
|
29
|
+
const node_crypto_1 = require("node:crypto");
|
|
30
|
+
const common_1 = require("@nestjs/common");
|
|
31
|
+
const connector_context_resolver_1 = require("../../../server/common/contracts/connector-context.resolver");
|
|
32
|
+
const webhook_repository_1 = require("./webhook.repository");
|
|
33
|
+
const webhook_token_util_1 = require("./webhook-token.util");
|
|
34
|
+
let LocalConnectorContextResolver = class LocalConnectorContextResolver extends connector_context_resolver_1.ConnectorContextResolver {
|
|
35
|
+
constructor(repo) {
|
|
36
|
+
super();
|
|
37
|
+
this.repo = repo;
|
|
38
|
+
}
|
|
39
|
+
async resolveFromWebhookToken(webhookSlug, pathName, token) {
|
|
40
|
+
const tokenHash = (0, node_crypto_1.createHash)('sha256').update(token).digest('hex');
|
|
41
|
+
const result = await this.repo.findConnectorWithValidToken((0, webhook_token_util_1.normalizeSlug)(webhookSlug), (0, webhook_token_util_1.normalizePathName)(pathName), tokenHash);
|
|
42
|
+
if (!result)
|
|
43
|
+
throw new common_1.UnauthorizedException('invalid_webhook_token');
|
|
44
|
+
const expiresAt = result.tokenExpiresAt ? new Date(result.tokenExpiresAt).getTime() : null;
|
|
45
|
+
if (expiresAt !== null && expiresAt <= Date.now()) {
|
|
46
|
+
throw new common_1.UnauthorizedException('expired_webhook_token');
|
|
47
|
+
}
|
|
48
|
+
await this.repo.touchTokenLastUsed(result.tokenId);
|
|
49
|
+
return {
|
|
50
|
+
connector: result.connector,
|
|
51
|
+
projectContext: { projectId: result.connector.projectId, source: 'local' },
|
|
52
|
+
actorContext: { actorId: result.connector.id, actorKind: 'system_webhook' },
|
|
53
|
+
webhookTokenId: result.tokenId,
|
|
54
|
+
};
|
|
55
|
+
}
|
|
56
|
+
};
|
|
57
|
+
exports.LocalConnectorContextResolver = LocalConnectorContextResolver;
|
|
58
|
+
exports.LocalConnectorContextResolver = LocalConnectorContextResolver = __decorate([
|
|
59
|
+
(0, common_1.Injectable)(),
|
|
60
|
+
__param(0, (0, common_1.Inject)(webhook_repository_1.WebhookRepository)),
|
|
61
|
+
__metadata("design:paramtypes", [webhook_repository_1.WebhookRepository])
|
|
62
|
+
], LocalConnectorContextResolver);
|
|
63
|
+
//# sourceMappingURL=local-connector-context.resolver.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"local-connector-context.resolver.js","sourceRoot":"","sources":["../../../../src/webhook/channels/webhook/local-connector-context.resolver.ts"],"names":[],"mappings":";AAAA,kFAAkF;AAClF,gGAAgG;AAChG,EAAE;AACF,oGAAoG;AACpG,qGAAqG;AACrG,uEAAuE;AACvE,EAAE;AACF,qFAAqF;AACrF,oGAAoG;AACpG,oEAAoE;AACpE,EAAE;AACF,uGAAuG;AACvG,sGAAsG;;;;;;;;;;;;;;;AAEtG,6CAAyC;AACzC,2CAA2E;AAC3E,4GAGqE;AACrE,6DAAyD;AACzD,6DAAwE;AAGjE,IAAM,6BAA6B,GAAnC,MAAM,6BAA8B,SAAQ,qDAAwB;IACzE,YAAwD,IAAuB;QAC7E,KAAK,EAAE,CAAC;QAD8C,SAAI,GAAJ,IAAI,CAAmB;IAE/E,CAAC;IAED,KAAK,CAAC,uBAAuB,CAC3B,WAAmB,EACnB,QAAgB,EAChB,KAAa;QAEb,MAAM,SAAS,GAAG,IAAA,wBAAU,EAAC,QAAQ,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;QACnE,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,IAAI,CAAC,2BAA2B,CACxD,IAAA,kCAAa,EAAC,WAAW,CAAC,EAC1B,IAAA,sCAAiB,EAAC,QAAQ,CAAC,EAC3B,SAAS,CACV,CAAC;QACF,IAAI,CAAC,MAAM;YAAE,MAAM,IAAI,8BAAqB,CAAC,uBAAuB,CAAC,CAAC;QAEtE,MAAM,SAAS,GAAG,MAAM,CAAC,cAAc,CAAC,CAAC,CAAC,IAAI,IAAI,CAAC,MAAM,CAAC,cAAc,CAAC,CAAC,OAAO,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC;QAC3F,IAAI,SAAS,KAAK,IAAI,IAAI,SAAS,IAAI,IAAI,CAAC,GAAG,EAAE,EAAE,CAAC;YAClD,MAAM,IAAI,8BAAqB,CAAC,uBAAuB,CAAC,CAAC;QAC3D,CAAC;QACD,MAAM,IAAI,CAAC,IAAI,CAAC,kBAAkB,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC;QAEnD,OAAO;YACL,SAAS,EAAE,MAAM,CAAC,SAAS;YAC3B,cAAc,EAAE,EAAE,SAAS,EAAE,MAAM,CAAC,SAAS,CAAC,SAAS,EAAE,MAAM,EAAE,OAAO,EAAE;YAC1E,YAAY,EAAE,EAAE,OAAO,EAAE,MAAM,CAAC,SAAS,CAAC,EAAE,EAAE,SAAS,EAAE,gBAAgB,EAAE;YAC3E,cAAc,EAAE,MAAM,CAAC,OAAO;SAC/B,CAAC;IACJ,CAAC;CACF,CAAA;AA/BY,sEAA6B;wCAA7B,6BAA6B;IADzC,IAAA,mBAAU,GAAE;IAEE,WAAA,IAAA,eAAM,EAAC,sCAAiB,CAAC,CAAA;qCAAwB,sCAAiB;GADpE,6BAA6B,CA+BzC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"webhook-token.util.d.ts","sourceRoot":"","sources":["../../../../src/webhook/channels/webhook/webhook-token.util.ts"],"names":[],"mappings":"AAMA,wBAAgB,gBAAgB,CAAC,MAAM,EAAE,MAAM,GAAG,IAAI,GAAG,MAAM,CAI9D;AAED,wBAAgB,aAAa,CAAC,KAAK,EAAE,MAAM,GAAG,MAAM,CAEnD;AAED,wBAAgB,iBAAiB,CAAC,KAAK,EAAE,MAAM,GAAG,MAAM,CAMvD"}
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
// Shared webhook inbound-credential helpers.
|
|
3
|
+
// Extracted from webhook.service.ts so both the service (bearer parsing at the call site) and
|
|
4
|
+
// LocalConnectorContextResolver (slug / path normalization) can use them without a circular import.
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.parseBearerToken = parseBearerToken;
|
|
7
|
+
exports.normalizeSlug = normalizeSlug;
|
|
8
|
+
exports.normalizePathName = normalizePathName;
|
|
9
|
+
const common_1 = require("@nestjs/common");
|
|
10
|
+
function parseBearerToken(header) {
|
|
11
|
+
const match = /^Bearer\s+(.+)$/iu.exec(header ?? '');
|
|
12
|
+
if (!match?.[1])
|
|
13
|
+
throw new common_1.UnauthorizedException('missing_api_token');
|
|
14
|
+
return match[1].trim();
|
|
15
|
+
}
|
|
16
|
+
function normalizeSlug(value) {
|
|
17
|
+
return value.trim().toLowerCase();
|
|
18
|
+
}
|
|
19
|
+
function normalizePathName(value) {
|
|
20
|
+
return value
|
|
21
|
+
.split('/')
|
|
22
|
+
.map((part) => part.trim())
|
|
23
|
+
.filter(Boolean)
|
|
24
|
+
.join('/');
|
|
25
|
+
}
|
|
26
|
+
//# sourceMappingURL=webhook-token.util.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"webhook-token.util.js","sourceRoot":"","sources":["../../../../src/webhook/channels/webhook/webhook-token.util.ts"],"names":[],"mappings":";AAAA,6CAA6C;AAC7C,8FAA8F;AAC9F,oGAAoG;;AAIpG,4CAIC;AAED,sCAEC;AAED,8CAMC;AAlBD,2CAAuD;AAEvD,SAAgB,gBAAgB,CAAC,MAAqB;IACpD,MAAM,KAAK,GAAG,mBAAmB,CAAC,IAAI,CAAC,MAAM,IAAI,EAAE,CAAC,CAAC;IACrD,IAAI,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC;QAAE,MAAM,IAAI,8BAAqB,CAAC,mBAAmB,CAAC,CAAC;IACtE,OAAO,KAAK,CAAC,CAAC,CAAC,CAAC,IAAI,EAAE,CAAC;AACzB,CAAC;AAED,SAAgB,aAAa,CAAC,KAAa;IACzC,OAAO,KAAK,CAAC,IAAI,EAAE,CAAC,WAAW,EAAE,CAAC;AACpC,CAAC;AAED,SAAgB,iBAAiB,CAAC,KAAa;IAC7C,OAAO,KAAK;SACT,KAAK,CAAC,GAAG,CAAC;SACV,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,IAAI,EAAE,CAAC;SAC1B,MAAM,CAAC,OAAO,CAAC;SACf,IAAI,CAAC,GAAG,CAAC,CAAC;AACf,CAAC"}
|