@vauban-org/agent-sdk 1.0.0 → 1.3.0
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/CONTRACT.md +6918 -742
- package/dist/adapters/llm/anthropic-direct.d.ts +1 -0
- package/dist/adapters/llm/anthropic-direct.d.ts.map +1 -1
- package/dist/adapters/llm/anthropic-direct.js +43 -0
- package/dist/adapters/llm/anthropic-direct.js.map +1 -1
- package/dist/adapters/llm/cascade.d.ts.map +1 -1
- package/dist/adapters/llm/cascade.js +57 -14
- package/dist/adapters/llm/cascade.js.map +1 -1
- package/dist/adapters/llm/litellm.d.ts +2 -0
- package/dist/adapters/llm/litellm.d.ts.map +1 -1
- package/dist/adapters/llm/litellm.js +44 -0
- package/dist/adapters/llm/litellm.js.map +1 -1
- package/dist/compute/difficulty-estimator.d.ts +53 -0
- package/dist/compute/difficulty-estimator.d.ts.map +1 -0
- package/dist/compute/difficulty-estimator.js +82 -0
- package/dist/compute/difficulty-estimator.js.map +1 -0
- package/dist/compute/strategies/mixture-of-agents.d.ts +40 -0
- package/dist/compute/strategies/mixture-of-agents.d.ts.map +1 -0
- package/dist/compute/strategies/mixture-of-agents.js +110 -0
- package/dist/compute/strategies/mixture-of-agents.js.map +1 -0
- package/dist/compute/strategies/tree-of-thoughts.d.ts +48 -0
- package/dist/compute/strategies/tree-of-thoughts.d.ts.map +1 -0
- package/dist/compute/strategies/tree-of-thoughts.js +242 -0
- package/dist/compute/strategies/tree-of-thoughts.js.map +1 -0
- package/dist/compute/strategies/two-phase-orient.d.ts +72 -0
- package/dist/compute/strategies/two-phase-orient.d.ts.map +1 -0
- package/dist/compute/strategies/two-phase-orient.js +85 -0
- package/dist/compute/strategies/two-phase-orient.js.map +1 -0
- package/dist/constitution/types.d.ts +10 -10
- package/dist/container/protocol.d.ts +134 -0
- package/dist/container/protocol.d.ts.map +1 -0
- package/dist/container/protocol.js +157 -0
- package/dist/container/protocol.js.map +1 -0
- package/dist/container/runtime.d.ts +140 -0
- package/dist/container/runtime.d.ts.map +1 -0
- package/dist/container/runtime.js +256 -0
- package/dist/container/runtime.js.map +1 -0
- package/dist/events/catalogue.d.ts +46 -46
- package/dist/events/schemas/agent.completed.v1.d.ts +4 -4
- package/dist/events/schemas/agent.failed.v1.d.ts +2 -2
- package/dist/events/schemas/agent.hitl_resolved.v1.d.ts +2 -2
- package/dist/events/schemas/agent.started.v1.d.ts +2 -2
- package/dist/events/schemas/brain.skill.extracted.v1.d.ts +4 -4
- package/dist/events/schemas/cc.cost.anomaly_detected.v1.d.ts +2 -2
- package/dist/events/schemas/cc.cost.recorded.v1.d.ts +4 -4
- package/dist/events/schemas/citadel.sprint.analyzed.v1.d.ts +6 -6
- package/dist/events/schemas/citadel.sprint.closed.v1.d.ts +2 -2
- package/dist/events/schemas/forge.inbox.reply_classified.v1.d.ts +6 -6
- package/dist/events/schemas/forge.lead.qualified.v1.d.ts +2 -2
- package/dist/events/schemas/forge.outreach.sent.v1.d.ts +4 -4
- package/dist/events/schemas/incident.detected.v1.d.ts +2 -2
- package/dist/events/schemas/vauban.goal.checked.v1.d.ts +2 -2
- package/dist/events/schemas/vauban.rebalancing.checked.v1.d.ts +2 -2
- package/dist/events/schemas/vauban.tax.checked.v1.d.ts +2 -2
- package/dist/events/schemas/vauban.vault.analyzed.v1.d.ts +6 -6
- package/dist/identity/agent-persona.d.ts +73 -0
- package/dist/identity/agent-persona.d.ts.map +1 -0
- package/dist/identity/agent-persona.js +165 -0
- package/dist/identity/agent-persona.js.map +1 -0
- package/dist/identity/persona-prompt.d.ts +25 -0
- package/dist/identity/persona-prompt.d.ts.map +1 -0
- package/dist/identity/persona-prompt.js +71 -0
- package/dist/identity/persona-prompt.js.map +1 -0
- package/dist/identity/persona-schema.d.ts +120 -0
- package/dist/identity/persona-schema.d.ts.map +1 -0
- package/dist/identity/persona-schema.js +103 -0
- package/dist/identity/persona-schema.js.map +1 -0
- package/dist/index.d.ts +41 -3
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +31 -1
- package/dist/index.js.map +1 -1
- package/dist/loop/minimal-loop.js +293 -287
- package/dist/memory/episodic-rrf.d.ts +114 -0
- package/dist/memory/episodic-rrf.d.ts.map +1 -0
- package/dist/memory/episodic-rrf.js +148 -0
- package/dist/memory/episodic-rrf.js.map +1 -0
- package/dist/mesh/attenuation.d.ts +78 -0
- package/dist/mesh/attenuation.d.ts.map +1 -0
- package/dist/mesh/attenuation.js +141 -0
- package/dist/mesh/attenuation.js.map +1 -0
- package/dist/mesh/delegate.d.ts +96 -0
- package/dist/mesh/delegate.d.ts.map +1 -0
- package/dist/mesh/delegate.js +172 -0
- package/dist/mesh/delegate.js.map +1 -0
- package/dist/mesh/dispatcher.d.ts +119 -0
- package/dist/mesh/dispatcher.d.ts.map +1 -0
- package/dist/mesh/dispatcher.js +207 -0
- package/dist/mesh/dispatcher.js.map +1 -0
- package/dist/mesh/index.d.ts +12 -0
- package/dist/mesh/index.d.ts.map +1 -0
- package/dist/mesh/index.js +11 -0
- package/dist/mesh/index.js.map +1 -0
- package/dist/mesh/types.d.ts +30 -0
- package/dist/mesh/types.d.ts.map +1 -0
- package/dist/mesh/types.js +11 -0
- package/dist/mesh/types.js.map +1 -0
- package/dist/orchestration/ooda/agent.d.ts.map +1 -1
- package/dist/orchestration/ooda/agent.js +36 -0
- package/dist/orchestration/ooda/agent.js.map +1 -1
- package/dist/orchestration/ooda/skills.d.ts +104 -0
- package/dist/orchestration/ooda/skills.d.ts.map +1 -1
- package/dist/orchestration/ooda/skills.js +106 -0
- package/dist/orchestration/ooda/skills.js.map +1 -1
- package/dist/orchestration/ooda/types.d.ts +11 -0
- package/dist/orchestration/ooda/types.d.ts.map +1 -1
- package/dist/ports/bastion-action.contract.test.d.ts +11 -0
- package/dist/ports/bastion-action.contract.test.d.ts.map +1 -0
- package/dist/ports/bastion-action.contract.test.js +238 -0
- package/dist/ports/bastion-action.contract.test.js.map +1 -0
- package/dist/ports/bastion-action.d.ts +133 -0
- package/dist/ports/bastion-action.d.ts.map +1 -0
- package/dist/ports/bastion-action.js +73 -0
- package/dist/ports/bastion-action.js.map +1 -0
- package/dist/ports/brain.d.ts +31 -0
- package/dist/ports/brain.d.ts.map +1 -1
- package/dist/ports/brain.js +115 -1
- package/dist/ports/brain.js.map +1 -1
- package/dist/ports/citadel-action.contract.test.d.ts +11 -0
- package/dist/ports/citadel-action.contract.test.d.ts.map +1 -0
- package/dist/ports/citadel-action.contract.test.js +317 -0
- package/dist/ports/citadel-action.contract.test.js.map +1 -0
- package/dist/ports/citadel-action.d.ts +111 -0
- package/dist/ports/citadel-action.d.ts.map +1 -0
- package/dist/ports/citadel-action.js +62 -0
- package/dist/ports/citadel-action.js.map +1 -0
- package/dist/ports/compliance-contract.d.ts +123 -0
- package/dist/ports/compliance-contract.d.ts.map +1 -0
- package/dist/ports/compliance-contract.js +35 -0
- package/dist/ports/compliance-contract.js.map +1 -0
- package/dist/ports/db.d.ts +38 -0
- package/dist/ports/db.d.ts.map +1 -1
- package/dist/ports/db.js +88 -1
- package/dist/ports/db.js.map +1 -1
- package/dist/ports/delegation.contract.test.d.ts +9 -0
- package/dist/ports/delegation.contract.test.d.ts.map +1 -0
- package/dist/ports/delegation.contract.test.js +337 -0
- package/dist/ports/delegation.contract.test.js.map +1 -0
- package/dist/ports/delegation.d.ts +134 -0
- package/dist/ports/delegation.d.ts.map +1 -0
- package/dist/ports/delegation.js +105 -0
- package/dist/ports/delegation.js.map +1 -0
- package/dist/ports/event-bus.d.ts +29 -0
- package/dist/ports/event-bus.d.ts.map +1 -1
- package/dist/ports/event-bus.js +106 -1
- package/dist/ports/event-bus.js.map +1 -1
- package/dist/ports/federation.contract.test.d.ts +9 -0
- package/dist/ports/federation.contract.test.d.ts.map +1 -0
- package/dist/ports/federation.contract.test.js +279 -0
- package/dist/ports/federation.contract.test.js.map +1 -0
- package/dist/ports/federation.d.ts +140 -0
- package/dist/ports/federation.d.ts.map +1 -0
- package/dist/ports/federation.js +57 -0
- package/dist/ports/federation.js.map +1 -0
- package/dist/ports/index.d.ts +28 -2
- package/dist/ports/index.d.ts.map +1 -1
- package/dist/ports/index.js +17 -2
- package/dist/ports/index.js.map +1 -1
- package/dist/ports/llm-provider.d.ts +37 -0
- package/dist/ports/llm-provider.d.ts.map +1 -1
- package/dist/ports/llm-provider.js +99 -1
- package/dist/ports/llm-provider.js.map +1 -1
- package/dist/ports/logger.d.ts +27 -0
- package/dist/ports/logger.d.ts.map +1 -1
- package/dist/ports/logger.js +87 -0
- package/dist/ports/logger.js.map +1 -1
- package/dist/ports/manifest-registry.contract.test.d.ts +9 -0
- package/dist/ports/manifest-registry.contract.test.d.ts.map +1 -0
- package/dist/ports/manifest-registry.contract.test.js +246 -0
- package/dist/ports/manifest-registry.contract.test.js.map +1 -0
- package/dist/ports/manifest-registry.d.ts +116 -0
- package/dist/ports/manifest-registry.d.ts.map +1 -0
- package/dist/ports/manifest-registry.js +79 -0
- package/dist/ports/manifest-registry.js.map +1 -0
- package/dist/ports/observability.contract.test.d.ts +12 -0
- package/dist/ports/observability.contract.test.d.ts.map +1 -0
- package/dist/ports/observability.contract.test.js +260 -0
- package/dist/ports/observability.contract.test.js.map +1 -0
- package/dist/ports/observability.d.ts +98 -0
- package/dist/ports/observability.d.ts.map +1 -0
- package/dist/ports/observability.js +59 -0
- package/dist/ports/observability.js.map +1 -0
- package/dist/ports/outcome.d.ts +26 -0
- package/dist/ports/outcome.d.ts.map +1 -1
- package/dist/ports/outcome.js +62 -1
- package/dist/ports/outcome.js.map +1 -1
- package/dist/ports/privacy.contract.test.d.ts +12 -0
- package/dist/ports/privacy.contract.test.d.ts.map +1 -0
- package/dist/ports/privacy.contract.test.js +325 -0
- package/dist/ports/privacy.contract.test.js.map +1 -0
- package/dist/ports/privacy.d.ts +132 -0
- package/dist/ports/privacy.d.ts.map +1 -0
- package/dist/ports/privacy.js +83 -0
- package/dist/ports/privacy.js.map +1 -0
- package/dist/ports/tenant-context.contract.test.d.ts +14 -0
- package/dist/ports/tenant-context.contract.test.d.ts.map +1 -0
- package/dist/ports/tenant-context.contract.test.js +352 -0
- package/dist/ports/tenant-context.contract.test.js.map +1 -0
- package/dist/ports/tenant-context.d.ts +103 -0
- package/dist/ports/tenant-context.d.ts.map +1 -0
- package/dist/ports/tenant-context.js +48 -0
- package/dist/ports/tenant-context.js.map +1 -0
- package/dist/ports/vauban-finance-action.contract.test.d.ts +11 -0
- package/dist/ports/vauban-finance-action.contract.test.d.ts.map +1 -0
- package/dist/ports/vauban-finance-action.contract.test.js +260 -0
- package/dist/ports/vauban-finance-action.contract.test.js.map +1 -0
- package/dist/ports/vauban-finance-action.d.ts +106 -0
- package/dist/ports/vauban-finance-action.d.ts.map +1 -0
- package/dist/ports/vauban-finance-action.js +60 -0
- package/dist/ports/vauban-finance-action.js.map +1 -0
- package/dist/ports/workflow-runtime.d.ts +204 -0
- package/dist/ports/workflow-runtime.d.ts.map +1 -0
- package/dist/ports/workflow-runtime.js +72 -0
- package/dist/ports/workflow-runtime.js.map +1 -0
- package/dist/proof/cert-verify.d.ts +80 -0
- package/dist/proof/cert-verify.d.ts.map +1 -0
- package/dist/proof/cert-verify.js +178 -0
- package/dist/proof/cert-verify.js.map +1 -0
- package/dist/replay/replay.d.ts.map +1 -1
- package/dist/replay/replay.js +5 -1
- package/dist/replay/replay.js.map +1 -1
- package/dist/retry/index.d.ts +129 -0
- package/dist/retry/index.d.ts.map +1 -0
- package/dist/retry/index.js +156 -0
- package/dist/retry/index.js.map +1 -0
- package/dist/retry/presets.d.ts +39 -0
- package/dist/retry/presets.d.ts.map +1 -0
- package/dist/retry/presets.js +69 -0
- package/dist/retry/presets.js.map +1 -0
- package/dist/skill-loop/ab-runner.d.ts +67 -0
- package/dist/skill-loop/ab-runner.d.ts.map +1 -0
- package/dist/skill-loop/ab-runner.js +160 -0
- package/dist/skill-loop/ab-runner.js.map +1 -0
- package/dist/skill-loop/adoption.d.ts +67 -0
- package/dist/skill-loop/adoption.d.ts.map +1 -0
- package/dist/skill-loop/adoption.js +126 -0
- package/dist/skill-loop/adoption.js.map +1 -0
- package/dist/skill-loop/candidate.d.ts +45 -0
- package/dist/skill-loop/candidate.d.ts.map +1 -0
- package/dist/skill-loop/candidate.js +43 -0
- package/dist/skill-loop/candidate.js.map +1 -0
- package/dist/skill-loop/evaluator.d.ts +42 -0
- package/dist/skill-loop/evaluator.d.ts.map +1 -0
- package/dist/skill-loop/evaluator.js +184 -0
- package/dist/skill-loop/evaluator.js.map +1 -0
- package/dist/skill-loop/index.d.ts +27 -0
- package/dist/skill-loop/index.d.ts.map +1 -0
- package/dist/skill-loop/index.js +27 -0
- package/dist/skill-loop/index.js.map +1 -0
- package/dist/skill-loop/reflexion-replay.d.ts +87 -0
- package/dist/skill-loop/reflexion-replay.d.ts.map +1 -0
- package/dist/skill-loop/reflexion-replay.js +110 -0
- package/dist/skill-loop/reflexion-replay.js.map +1 -0
- package/dist/skill-loop/sign-off.d.ts +88 -0
- package/dist/skill-loop/sign-off.d.ts.map +1 -0
- package/dist/skill-loop/sign-off.js +146 -0
- package/dist/skill-loop/sign-off.js.map +1 -0
- package/dist/skill-loop/value-metric.d.ts +55 -0
- package/dist/skill-loop/value-metric.d.ts.map +1 -0
- package/dist/skill-loop/value-metric.js +69 -0
- package/dist/skill-loop/value-metric.js.map +1 -0
- package/dist/skill-loop/versioning.d.ts +36 -0
- package/dist/skill-loop/versioning.d.ts.map +1 -0
- package/dist/skill-loop/versioning.js +47 -0
- package/dist/skill-loop/versioning.js.map +1 -0
- package/dist/skill-manifest/anchor.d.ts +91 -0
- package/dist/skill-manifest/anchor.d.ts.map +1 -0
- package/dist/skill-manifest/anchor.js +331 -0
- package/dist/skill-manifest/anchor.js.map +1 -0
- package/dist/skill-manifest/builder.d.ts +47 -0
- package/dist/skill-manifest/builder.d.ts.map +1 -0
- package/dist/skill-manifest/builder.js +93 -0
- package/dist/skill-manifest/builder.js.map +1 -0
- package/dist/skill-manifest/index.d.ts +13 -0
- package/dist/skill-manifest/index.d.ts.map +1 -0
- package/dist/skill-manifest/index.js +9 -0
- package/dist/skill-manifest/index.js.map +1 -0
- package/dist/skill-manifest/types.d.ts +67 -0
- package/dist/skill-manifest/types.d.ts.map +1 -0
- package/dist/skill-manifest/types.js +16 -0
- package/dist/skill-manifest/types.js.map +1 -0
- package/dist/skill-manifest/verifier.d.ts +42 -0
- package/dist/skill-manifest/verifier.d.ts.map +1 -0
- package/dist/skill-manifest/verifier.js +136 -0
- package/dist/skill-manifest/verifier.js.map +1 -0
- package/dist/skills/_secrets.d.ts +16 -0
- package/dist/skills/_secrets.d.ts.map +1 -0
- package/dist/skills/_secrets.js +20 -0
- package/dist/skills/_secrets.js.map +1 -0
- package/dist/skills/alpaca-quote.d.ts +2 -2
- package/dist/skills/alpaca-quote.d.ts.map +1 -1
- package/dist/skills/alpaca-quote.js +51 -20
- package/dist/skills/alpaca-quote.js.map +1 -1
- package/dist/skills/brain-query.d.ts +4 -4
- package/dist/skills/brain-store.d.ts +6 -6
- package/dist/skills/errors.d.ts +15 -0
- package/dist/skills/errors.d.ts.map +1 -1
- package/dist/skills/errors.js +21 -0
- package/dist/skills/errors.js.map +1 -1
- package/dist/skills/hitl-request.d.ts +2 -2
- package/dist/skills/index.d.ts +3 -1
- package/dist/skills/index.d.ts.map +1 -1
- package/dist/skills/index.js +4 -1
- package/dist/skills/index.js.map +1 -1
- package/dist/skills/markdown/loader.d.ts +52 -0
- package/dist/skills/markdown/loader.d.ts.map +1 -0
- package/dist/skills/markdown/loader.js +93 -0
- package/dist/skills/markdown/loader.js.map +1 -0
- package/dist/skills/markdown/schema.d.ts +432 -0
- package/dist/skills/markdown/schema.d.ts.map +1 -0
- package/dist/skills/markdown/schema.js +121 -0
- package/dist/skills/markdown/schema.js.map +1 -0
- package/dist/skills/poc-md-loader/markdown-loader.d.ts +77 -0
- package/dist/skills/poc-md-loader/markdown-loader.d.ts.map +1 -0
- package/dist/skills/poc-md-loader/markdown-loader.js +125 -0
- package/dist/skills/poc-md-loader/markdown-loader.js.map +1 -0
- package/dist/skills/poc-md-loader/runner.d.ts +24 -0
- package/dist/skills/poc-md-loader/runner.d.ts.map +1 -0
- package/dist/skills/poc-md-loader/runner.js +57 -0
- package/dist/skills/poc-md-loader/runner.js.map +1 -0
- package/dist/skills/poc-md-loader/vitest.poc.config.d.ts +3 -0
- package/dist/skills/poc-md-loader/vitest.poc.config.d.ts.map +1 -0
- package/dist/skills/poc-md-loader/vitest.poc.config.js +13 -0
- package/dist/skills/poc-md-loader/vitest.poc.config.js.map +1 -0
- package/dist/skills/poc-md-loader/web-search/script.d.ts +33 -0
- package/dist/skills/poc-md-loader/web-search/script.d.ts.map +1 -0
- package/dist/skills/poc-md-loader/web-search/script.js +75 -0
- package/dist/skills/poc-md-loader/web-search/script.js.map +1 -0
- package/dist/skills/record-outcome.d.ts +4 -4
- package/dist/skills/send-email.d.ts +2 -2
- package/dist/skills/send-email.d.ts.map +1 -1
- package/dist/skills/send-email.js +4 -3
- package/dist/skills/send-email.js.map +1 -1
- package/dist/skills/slack-notify.d.ts +4 -4
- package/dist/skills/slack-notify.d.ts.map +1 -1
- package/dist/skills/slack-notify.js +52 -21
- package/dist/skills/slack-notify.js.map +1 -1
- package/dist/skills/starknet-balance.d.ts +1 -1
- package/dist/skills/telegram-notify.d.ts +4 -4
- package/dist/skills/telegram-notify.d.ts.map +1 -1
- package/dist/skills/telegram-notify.js +48 -19
- package/dist/skills/telegram-notify.js.map +1 -1
- package/dist/skills/web-search.d.ts +1 -1
- package/dist/skills/web-search.d.ts.map +1 -1
- package/dist/skills/web-search.js +85 -40
- package/dist/skills/web-search.js.map +1 -1
- package/dist/telemetry/bus.d.ts +54 -0
- package/dist/telemetry/bus.d.ts.map +1 -0
- package/dist/telemetry/bus.js +159 -0
- package/dist/telemetry/bus.js.map +1 -0
- package/dist/telemetry/index.d.ts +35 -0
- package/dist/telemetry/index.d.ts.map +1 -0
- package/dist/telemetry/index.js +30 -0
- package/dist/telemetry/index.js.map +1 -0
- package/dist/telemetry/port.d.ts +121 -0
- package/dist/telemetry/port.d.ts.map +1 -0
- package/dist/telemetry/port.js +48 -0
- package/dist/telemetry/port.js.map +1 -0
- package/dist/telemetry/sinks/otlp.d.ts +45 -0
- package/dist/telemetry/sinks/otlp.d.ts.map +1 -0
- package/dist/telemetry/sinks/otlp.js +195 -0
- package/dist/telemetry/sinks/otlp.js.map +1 -0
- package/dist/telemetry/sinks/sqlite.d.ts +32 -0
- package/dist/telemetry/sinks/sqlite.d.ts.map +1 -0
- package/dist/telemetry/sinks/sqlite.js +170 -0
- package/dist/telemetry/sinks/sqlite.js.map +1 -0
- package/dist/telemetry/sinks/stdout.d.ts +22 -0
- package/dist/telemetry/sinks/stdout.d.ts.map +1 -0
- package/dist/telemetry/sinks/stdout.js +38 -0
- package/dist/telemetry/sinks/stdout.js.map +1 -0
- package/dist/testing/index.d.ts +3 -0
- package/dist/testing/test-brain-port.d.ts +4 -0
- package/dist/testing/test-brain-port.d.ts.map +1 -1
- package/dist/testing/test-brain-port.js +75 -20
- package/dist/testing/test-brain-port.js.map +1 -1
- package/dist/testing/test-event-bus.d.ts.map +1 -1
- package/dist/testing/test-event-bus.js +89 -36
- package/dist/testing/test-event-bus.js.map +1 -1
- package/dist/trace/schema.d.ts +1 -1
- package/dist/trace/schema.d.ts.map +1 -1
- package/dist/trace/schema.js +1 -1
- package/dist/trace/schema.js.map +1 -1
- package/dist/verify/formal/index.d.ts +44 -0
- package/dist/verify/formal/index.d.ts.map +1 -0
- package/dist/verify/formal/index.js +98 -0
- package/dist/verify/formal/index.js.map +1 -0
- package/dist/verify/formal/policy.d.ts +105 -0
- package/dist/verify/formal/policy.d.ts.map +1 -0
- package/dist/verify/formal/policy.js +159 -0
- package/dist/verify/formal/policy.js.map +1 -0
- package/dist/verify/formal/result.d.ts +50 -0
- package/dist/verify/formal/result.d.ts.map +1 -0
- package/dist/verify/formal/result.js +21 -0
- package/dist/verify/formal/result.js.map +1 -0
- package/dist/verify/formal/solver.d.ts +67 -0
- package/dist/verify/formal/solver.d.ts.map +1 -0
- package/dist/verify/formal/solver.js +184 -0
- package/dist/verify/formal/solver.js.map +1 -0
- package/dist/verify/formal/spec-language.d.ts +80 -0
- package/dist/verify/formal/spec-language.d.ts.map +1 -0
- package/dist/verify/formal/spec-language.js +219 -0
- package/dist/verify/formal/spec-language.js.map +1 -0
- package/docs/attestation.md +199 -0
- package/docs/identity.md +193 -0
- package/docs/telemetry/migration.md +155 -0
- package/docs/telemetry/overview.md +154 -0
- package/docs/telemetry/privacy.md +127 -0
- package/docs/telemetry/sinks/cc.md +155 -0
- package/docs/telemetry/sinks/otlp.md +146 -0
- package/docs/telemetry/sinks/sqlite.md +126 -0
- package/docs/telemetry/sinks/stdout.md +82 -0
- package/package.json +18 -2
- package/src/adapters/llm/anthropic-direct.ts +51 -0
- package/src/adapters/llm/cascade.ts +64 -19
- package/src/adapters/llm/litellm.ts +49 -0
- package/src/compute/difficulty-estimator.ts +111 -0
- package/src/compute/strategies/mixture-of-agents.ts +150 -0
- package/src/compute/strategies/tree-of-thoughts.ts +293 -0
- package/src/compute/strategies/two-phase-orient.ts +147 -0
- package/src/container/protocol.ts +243 -0
- package/src/container/runtime.ts +424 -0
- package/src/db/migrations/026_formal_verify_results.sql +30 -0
- package/src/identity/agent-persona.ts +203 -0
- package/src/identity/persona-prompt.ts +84 -0
- package/src/identity/persona-schema.ts +127 -0
- package/src/index.ts +368 -2
- package/src/memory/episodic-rrf.ts +224 -0
- package/src/mesh/attenuation.ts +190 -0
- package/src/mesh/delegate.ts +254 -0
- package/src/mesh/dispatcher.ts +301 -0
- package/src/mesh/index.ts +39 -0
- package/src/mesh/types.ts +31 -0
- package/src/orchestration/ooda/agent.ts +50 -0
- package/src/orchestration/ooda/skills.ts +177 -0
- package/src/orchestration/ooda/types.ts +12 -0
- package/src/ports/bastion-action.contract.test.ts +355 -0
- package/src/ports/bastion-action.ts +198 -0
- package/src/ports/brain.ts +177 -15
- package/src/ports/citadel-action.contract.test.ts +430 -0
- package/src/ports/citadel-action.ts +174 -0
- package/src/ports/compliance-contract.ts +191 -0
- package/src/ports/db.ts +98 -0
- package/src/ports/delegation.contract.test.ts +428 -0
- package/src/ports/delegation.ts +211 -0
- package/src/ports/event-bus.ts +133 -0
- package/src/ports/federation.contract.test.ts +355 -0
- package/src/ports/federation.ts +190 -0
- package/src/ports/index.ts +186 -1
- package/src/ports/llm-provider.ts +123 -0
- package/src/ports/logger.ts +104 -0
- package/src/ports/manifest-registry.contract.test.ts +324 -0
- package/src/ports/manifest-registry.ts +188 -0
- package/src/ports/observability.contract.test.ts +315 -0
- package/src/ports/observability.ts +150 -0
- package/src/ports/outcome.ts +69 -0
- package/src/ports/privacy.contract.test.ts +413 -0
- package/src/ports/privacy.ts +207 -0
- package/src/ports/tenant-context.contract.test.ts +454 -0
- package/src/ports/tenant-context.ts +150 -0
- package/src/ports/vauban-finance-action.contract.test.ts +335 -0
- package/src/ports/vauban-finance-action.ts +166 -0
- package/src/ports/workflow-runtime.ts +327 -0
- package/src/proof/cert-verify.ts +249 -0
- package/src/replay/replay.ts +11 -8
- package/src/retry/index.ts +227 -0
- package/src/retry/presets.ts +75 -0
- package/src/skill-loop/ab-runner.ts +196 -0
- package/src/skill-loop/adoption.ts +188 -0
- package/src/skill-loop/candidate.ts +75 -0
- package/src/skill-loop/evaluator.ts +238 -0
- package/src/skill-loop/index.ts +51 -0
- package/src/skill-loop/reflexion-replay.ts +173 -0
- package/src/skill-loop/sign-off.ts +247 -0
- package/src/skill-loop/value-metric.ts +120 -0
- package/src/skill-loop/versioning.ts +75 -0
- package/src/skill-manifest/anchor.ts +401 -0
- package/src/skill-manifest/builder.ts +129 -0
- package/src/skill-manifest/index.ts +18 -0
- package/src/skill-manifest/types.ts +72 -0
- package/src/skill-manifest/verifier.ts +198 -0
- package/src/skills/_secrets.ts +25 -0
- package/src/skills/alpaca-quote.ts +68 -23
- package/src/skills/errors.ts +30 -2
- package/src/skills/index.ts +19 -0
- package/src/skills/markdown/loader.ts +129 -0
- package/src/skills/markdown/schema.ts +144 -0
- package/src/skills/poc-md-loader/e2e-parity.test.ts +237 -0
- package/src/skills/poc-md-loader/markdown-loader.ts +161 -0
- package/src/skills/poc-md-loader/runner.ts +82 -0
- package/src/skills/poc-md-loader/vitest.poc.config.ts +13 -0
- package/src/skills/poc-md-loader/web-search/SKILL.md +42 -0
- package/src/skills/poc-md-loader/web-search/script.ts +109 -0
- package/src/skills/send-email.ts +4 -3
- package/src/skills/slack-notify.ts +73 -30
- package/src/skills/telegram-notify.ts +70 -24
- package/src/skills/web-search.ts +132 -50
- package/src/telemetry/bus.test.ts +231 -0
- package/src/telemetry/bus.ts +241 -0
- package/src/telemetry/index.ts +49 -0
- package/src/telemetry/port.ts +160 -0
- package/src/telemetry/sinks/otlp.test.ts +146 -0
- package/src/telemetry/sinks/otlp.ts +250 -0
- package/src/telemetry/sinks/sqlite.test.ts +121 -0
- package/src/telemetry/sinks/sqlite.ts +260 -0
- package/src/telemetry/sinks/stdout.test.ts +109 -0
- package/src/telemetry/sinks/stdout.ts +59 -0
- package/src/testing/test-brain-port.ts +98 -24
- package/src/testing/test-event-bus.ts +104 -43
- package/src/trace/schema.ts +1 -1
- package/src/verify/formal/index.ts +154 -0
- package/src/verify/formal/policy.ts +253 -0
- package/src/verify/formal/result.ts +52 -0
- package/src/verify/formal/solver.ts +235 -0
- package/src/verify/formal/spec-language.ts +274 -0
package/src/ports/index.ts
CHANGED
|
@@ -6,7 +6,7 @@
|
|
|
6
6
|
* via each agent's setXxxDeps() setter.
|
|
7
7
|
*/
|
|
8
8
|
export type { LoggerPort } from "./logger.js";
|
|
9
|
-
export { noopLogger } from "./logger.js";
|
|
9
|
+
export { noopLogger, LoggerFlushError } from "./logger.js";
|
|
10
10
|
|
|
11
11
|
export type {
|
|
12
12
|
BrainPort,
|
|
@@ -25,13 +25,18 @@ export {
|
|
|
25
25
|
InMemoryEpisodicMemory,
|
|
26
26
|
InMemorySemanticMemory,
|
|
27
27
|
InMemoryProceduralMemory,
|
|
28
|
+
BrainUnavailableError,
|
|
29
|
+
BrainRateLimitError,
|
|
28
30
|
} from "./brain.js";
|
|
29
31
|
|
|
30
32
|
export type { OutcomePort, AgentRunRef } from "./outcome.js";
|
|
33
|
+
export { OutcomeWriteError } from "./outcome.js";
|
|
31
34
|
|
|
32
35
|
export type { CloudEvent, EventBusPort } from "./event-bus.js";
|
|
36
|
+
export { EventPublishError } from "./event-bus.js";
|
|
33
37
|
|
|
34
38
|
export type { DbPort, DbClient } from "./db.js";
|
|
39
|
+
export { DbConnectionLostError, DbQueryTimeoutError } from "./db.js";
|
|
35
40
|
|
|
36
41
|
export type { AgentDescriptor, AgentRegistryPort } from "./agent-registry.js";
|
|
37
42
|
|
|
@@ -46,5 +51,185 @@ export type {
|
|
|
46
51
|
ChatResponse,
|
|
47
52
|
StreamDelta,
|
|
48
53
|
} from "./llm-provider.js";
|
|
54
|
+
export { LLMProviderError, LLMRateLimitError } from "./llm-provider.js";
|
|
49
55
|
|
|
50
56
|
export type { PricePort, PriceEntry } from "./price.js";
|
|
57
|
+
|
|
58
|
+
export type {
|
|
59
|
+
ComplianceContractPort,
|
|
60
|
+
ComplianceContract,
|
|
61
|
+
ComplianceRule,
|
|
62
|
+
ComplianceGate,
|
|
63
|
+
ComplianceAuditResult,
|
|
64
|
+
ComplianceViolation,
|
|
65
|
+
ManifestValidationResult,
|
|
66
|
+
PolicyConflict,
|
|
67
|
+
CapabilityInvocation,
|
|
68
|
+
TenantContext,
|
|
69
|
+
LegalBasisRef,
|
|
70
|
+
LegalBasisDecl,
|
|
71
|
+
LegalBasisDomain,
|
|
72
|
+
Jurisdiction,
|
|
73
|
+
DataClass,
|
|
74
|
+
ComplianceMode,
|
|
75
|
+
EnforcementLevel,
|
|
76
|
+
RuleSource,
|
|
77
|
+
} from "./compliance-contract.js";
|
|
78
|
+
export {
|
|
79
|
+
CompliancePolicyError,
|
|
80
|
+
ComplianceEvaluationTimeoutError,
|
|
81
|
+
SUPPORTED_JURISDICTIONS_V0,
|
|
82
|
+
} from "./compliance-contract.js";
|
|
83
|
+
|
|
84
|
+
export type {
|
|
85
|
+
WorkflowRuntimePort,
|
|
86
|
+
WorkflowContext,
|
|
87
|
+
WorkflowRun,
|
|
88
|
+
WorkflowHandler,
|
|
89
|
+
WorkflowStatus,
|
|
90
|
+
JournalEntry,
|
|
91
|
+
StepKind,
|
|
92
|
+
StepStatus,
|
|
93
|
+
StepOpts,
|
|
94
|
+
EventFilter,
|
|
95
|
+
ChildWorkflowOpts,
|
|
96
|
+
StartWorkflowOpts,
|
|
97
|
+
ResumeWorkflowOpts,
|
|
98
|
+
SendSignalOpts,
|
|
99
|
+
JournalMigrator,
|
|
100
|
+
MigrationResult,
|
|
101
|
+
} from "./workflow-runtime.js";
|
|
102
|
+
export {
|
|
103
|
+
WorkflowNotFoundError,
|
|
104
|
+
WorkflowNonDeterminismError,
|
|
105
|
+
WorkflowSignalTimeoutError,
|
|
106
|
+
WorkflowLeaseConflictError,
|
|
107
|
+
WorkflowVersionMismatchError,
|
|
108
|
+
} from "./workflow-runtime.js";
|
|
109
|
+
|
|
110
|
+
// ─── Sprint-636 V2.1 — 9 new ports (manifest, tenant, federation, delegation, products, observability, privacy)
|
|
111
|
+
|
|
112
|
+
export type * from "./manifest-registry.js";
|
|
113
|
+
export {
|
|
114
|
+
ManifestNotFoundError,
|
|
115
|
+
ManifestSignatureInvalidError,
|
|
116
|
+
ManifestVersionConflictError,
|
|
117
|
+
ManifestComplianceConflictError,
|
|
118
|
+
ManifestValidationError,
|
|
119
|
+
} from "./manifest-registry.js";
|
|
120
|
+
|
|
121
|
+
export type * from "./tenant-context.js";
|
|
122
|
+
export {
|
|
123
|
+
TenantNotFoundError,
|
|
124
|
+
DegradedModeExhaustedError,
|
|
125
|
+
InvalidGlacisAttestationError,
|
|
126
|
+
} from "./tenant-context.js";
|
|
127
|
+
|
|
128
|
+
export type {
|
|
129
|
+
FederationPort,
|
|
130
|
+
FederationMessage,
|
|
131
|
+
FederationMessageHeader,
|
|
132
|
+
AgentRef,
|
|
133
|
+
ContentClaim,
|
|
134
|
+
TransportMeta,
|
|
135
|
+
MessageId,
|
|
136
|
+
ReceiveOpts,
|
|
137
|
+
VerifyResult as FederationVerifyResult,
|
|
138
|
+
} from "./federation.js";
|
|
139
|
+
export {
|
|
140
|
+
FederationSignatureInvalidError,
|
|
141
|
+
FederationRoutingError,
|
|
142
|
+
FederationDelegationChainError,
|
|
143
|
+
} from "./federation.js";
|
|
144
|
+
|
|
145
|
+
export type {
|
|
146
|
+
DelegationPort,
|
|
147
|
+
DelegationClaim,
|
|
148
|
+
CapabilityScope,
|
|
149
|
+
RootCapability,
|
|
150
|
+
VerifyChainResult,
|
|
151
|
+
} from "./delegation.js";
|
|
152
|
+
export {
|
|
153
|
+
DelegationNotNarrowingError,
|
|
154
|
+
DelegationExpiredError,
|
|
155
|
+
DelegationRevokedError,
|
|
156
|
+
DelegationChainTooDeepError,
|
|
157
|
+
} from "./delegation.js";
|
|
158
|
+
|
|
159
|
+
export type {
|
|
160
|
+
BastionActionPort,
|
|
161
|
+
SwapParams,
|
|
162
|
+
SwapResult,
|
|
163
|
+
DepositParams,
|
|
164
|
+
DepositResult,
|
|
165
|
+
WithdrawParams,
|
|
166
|
+
WithdrawResult,
|
|
167
|
+
TransferParams,
|
|
168
|
+
TransferResult,
|
|
169
|
+
PolicyValidation,
|
|
170
|
+
ClientPolicy,
|
|
171
|
+
TokenAddress,
|
|
172
|
+
VaultAddress,
|
|
173
|
+
TenantId as BastionTenantId,
|
|
174
|
+
ActionContext as BastionActionContext,
|
|
175
|
+
} from "./bastion-action.js";
|
|
176
|
+
export {
|
|
177
|
+
BastionPolicyViolationError,
|
|
178
|
+
BastionInsufficientFundsError,
|
|
179
|
+
BastionSlippageExceededError,
|
|
180
|
+
BastionContractError,
|
|
181
|
+
BastionTransferUnauthorizedError,
|
|
182
|
+
} from "./bastion-action.js";
|
|
183
|
+
|
|
184
|
+
export type {
|
|
185
|
+
VFinanceActionPort,
|
|
186
|
+
MarketSignal,
|
|
187
|
+
SolvencyClaim,
|
|
188
|
+
TradeRecord,
|
|
189
|
+
TradeClaim,
|
|
190
|
+
StrategyRunInput,
|
|
191
|
+
StrategyRunClaim,
|
|
192
|
+
PortfolioId,
|
|
193
|
+
ProofGrade,
|
|
194
|
+
ActionContext as VFActionContext,
|
|
195
|
+
} from "./vauban-finance-action.js";
|
|
196
|
+
export {
|
|
197
|
+
VFOracleQuorumError,
|
|
198
|
+
VFProofGradeMismatchError,
|
|
199
|
+
VFAnchoringForbiddenError,
|
|
200
|
+
VFProofGenerationError,
|
|
201
|
+
} from "./vauban-finance-action.js";
|
|
202
|
+
|
|
203
|
+
export type {
|
|
204
|
+
CitadelActionPort,
|
|
205
|
+
AgentTier,
|
|
206
|
+
SprintInput,
|
|
207
|
+
SprintRef,
|
|
208
|
+
TaskRef,
|
|
209
|
+
TaskStatus,
|
|
210
|
+
VerificationEvidence,
|
|
211
|
+
SealedSprintClaim,
|
|
212
|
+
DecisionInput,
|
|
213
|
+
DecisionClaim,
|
|
214
|
+
ActionContext as CitadelActionContext,
|
|
215
|
+
} from "./citadel-action.js";
|
|
216
|
+
export {
|
|
217
|
+
CitadelTierViolationError,
|
|
218
|
+
CitadelTaskRefNotFoundError,
|
|
219
|
+
CitadelSprintNotActiveError,
|
|
220
|
+
CitadelInvalidStateTransitionError,
|
|
221
|
+
} from "./citadel-action.js";
|
|
222
|
+
|
|
223
|
+
export type * from "./observability.js";
|
|
224
|
+
export { NoopObservabilityPort } from "./observability.js";
|
|
225
|
+
|
|
226
|
+
export type {
|
|
227
|
+
RevelationMask,
|
|
228
|
+
ZkProofInput,
|
|
229
|
+
VerifyResult as PrivacyVerifyResult,
|
|
230
|
+
Commitment,
|
|
231
|
+
SmtResult,
|
|
232
|
+
PrivacyContext,
|
|
233
|
+
PrivacyPort,
|
|
234
|
+
} from "./privacy.js";
|
|
235
|
+
export { NoopPrivacyAdapter, PrivacyNoopWarning } from "./privacy.js";
|
|
@@ -7,6 +7,10 @@
|
|
|
7
7
|
*
|
|
8
8
|
* Plan v6 §3.2 — canonical interface.
|
|
9
9
|
*
|
|
10
|
+
* OTel instrumentation: import { createTracedLLMProviderPort } to wrap any
|
|
11
|
+
* LLMProviderPort implementation with OpenTelemetry spans per completion.
|
|
12
|
+
* Gracefully degrades to noop spans when no OTel SDK is installed.
|
|
13
|
+
*
|
|
10
14
|
* @public
|
|
11
15
|
*/
|
|
12
16
|
|
|
@@ -66,3 +70,122 @@ export interface LLMProviderPort {
|
|
|
66
70
|
*/
|
|
67
71
|
estimateCost?(req: ChatRequest): { usd: number };
|
|
68
72
|
}
|
|
73
|
+
|
|
74
|
+
// ─── Typed errors ─────────────────────────────────────────────────────────────
|
|
75
|
+
|
|
76
|
+
/**
|
|
77
|
+
* Base class for all LLM provider errors.
|
|
78
|
+
* Concrete implementations throw subclasses so callers can switch on error type.
|
|
79
|
+
*/
|
|
80
|
+
export class LLMProviderError extends Error {
|
|
81
|
+
/** The provider identifier (e.g. "groq", "litellm", "anthropic"). */
|
|
82
|
+
readonly provider: string;
|
|
83
|
+
/** The model that was being called (e.g. "llama-3.3-70b"). */
|
|
84
|
+
readonly model: string;
|
|
85
|
+
|
|
86
|
+
constructor(
|
|
87
|
+
message: string,
|
|
88
|
+
provider: string,
|
|
89
|
+
model: string,
|
|
90
|
+
public readonly cause?: unknown
|
|
91
|
+
) {
|
|
92
|
+
super(message);
|
|
93
|
+
this.name = "LLMProviderError";
|
|
94
|
+
this.provider = provider;
|
|
95
|
+
this.model = model;
|
|
96
|
+
Object.setPrototypeOf(this, new.target.prototype);
|
|
97
|
+
}
|
|
98
|
+
}
|
|
99
|
+
|
|
100
|
+
/**
|
|
101
|
+
* Thrown when the LLM provider returns 429 (rate limit exceeded).
|
|
102
|
+
* Callers should retry after the delay indicated in `retryAfterMs`
|
|
103
|
+
* or switch to a fallback provider.
|
|
104
|
+
*/
|
|
105
|
+
export class LLMRateLimitError extends LLMProviderError {
|
|
106
|
+
/** Retry-After delay in milliseconds. */
|
|
107
|
+
readonly retryAfterMs: number;
|
|
108
|
+
|
|
109
|
+
constructor(
|
|
110
|
+
message: string,
|
|
111
|
+
provider: string,
|
|
112
|
+
model: string,
|
|
113
|
+
retryAfterMs: number,
|
|
114
|
+
cause?: unknown
|
|
115
|
+
) {
|
|
116
|
+
super(message, provider, model, cause);
|
|
117
|
+
this.name = "LLMRateLimitError";
|
|
118
|
+
this.retryAfterMs = retryAfterMs;
|
|
119
|
+
Object.setPrototypeOf(this, new.target.prototype);
|
|
120
|
+
}
|
|
121
|
+
}
|
|
122
|
+
|
|
123
|
+
// ─── OTel-traced wrapper ──────────────────────────────────────────────────────
|
|
124
|
+
|
|
125
|
+
import type { Span } from "@opentelemetry/api";
|
|
126
|
+
import { SpanStatusCode, trace } from "@opentelemetry/api";
|
|
127
|
+
|
|
128
|
+
const PORT_TRACER = trace.getTracer("vauban-agent-sdk.ports", "0.1.0");
|
|
129
|
+
|
|
130
|
+
/**
|
|
131
|
+
* Wrap any LLMProviderPort implementation with OTel spans per complete() call.
|
|
132
|
+
* The span captures the model, provider, and token usage on success.
|
|
133
|
+
* Gracefully degrades to noop spans when no OTel SDK is installed.
|
|
134
|
+
*
|
|
135
|
+
* Usage:
|
|
136
|
+
* const raw: LLMProviderPort = buildAnthropicAdapter(...);
|
|
137
|
+
* const traced = createTracedLLMProviderPort(raw);
|
|
138
|
+
* const resp = await traced.complete(req) // emits "llm-provider.complete" span
|
|
139
|
+
*/
|
|
140
|
+
export function createTracedLLMProviderPort(
|
|
141
|
+
impl: LLMProviderPort
|
|
142
|
+
): LLMProviderPort {
|
|
143
|
+
return {
|
|
144
|
+
async complete(req) {
|
|
145
|
+
return PORT_TRACER.startActiveSpan(
|
|
146
|
+
"llm-provider.complete",
|
|
147
|
+
{
|
|
148
|
+
attributes: {
|
|
149
|
+
"gen_ai.request.model": req.model ?? "unknown",
|
|
150
|
+
"gen_ai.request.message_count": req.messages.length,
|
|
151
|
+
"vauban.port.name": "llm-provider",
|
|
152
|
+
},
|
|
153
|
+
},
|
|
154
|
+
async (span: Span) => {
|
|
155
|
+
try {
|
|
156
|
+
const resp = await impl.complete(req);
|
|
157
|
+
span.setAttributes({
|
|
158
|
+
"gen_ai.usage.input_tokens": resp.usage.inputTokens,
|
|
159
|
+
"gen_ai.usage.output_tokens": resp.usage.outputTokens,
|
|
160
|
+
"gen_ai.response.model": resp.model,
|
|
161
|
+
"gen_ai.response.finish_reasons": [resp.finishReason],
|
|
162
|
+
});
|
|
163
|
+
if (resp.usage.costUsd !== undefined) {
|
|
164
|
+
span.setAttribute("gen_ai.usage.cost_usd", resp.usage.costUsd);
|
|
165
|
+
}
|
|
166
|
+
span.setStatus({ code: SpanStatusCode.OK });
|
|
167
|
+
return resp;
|
|
168
|
+
} catch (err) {
|
|
169
|
+
const message = err instanceof Error ? err.message : String(err);
|
|
170
|
+
span.setStatus({ code: SpanStatusCode.ERROR, message });
|
|
171
|
+
if (err instanceof Error) span.recordException(err);
|
|
172
|
+
throw err;
|
|
173
|
+
} finally {
|
|
174
|
+
span.end();
|
|
175
|
+
}
|
|
176
|
+
}
|
|
177
|
+
);
|
|
178
|
+
},
|
|
179
|
+
|
|
180
|
+
async *stream(req) {
|
|
181
|
+
if (!impl.stream) return;
|
|
182
|
+
for await (const chunk of impl.stream(req)) {
|
|
183
|
+
yield chunk;
|
|
184
|
+
}
|
|
185
|
+
},
|
|
186
|
+
|
|
187
|
+
estimateCost(req: ChatRequest): { usd: number } {
|
|
188
|
+
return impl.estimateCost?.(req) ?? { usd: 0 };
|
|
189
|
+
},
|
|
190
|
+
};
|
|
191
|
+
}
|
package/src/ports/logger.ts
CHANGED
|
@@ -3,7 +3,17 @@
|
|
|
3
3
|
*
|
|
4
4
|
* Shape matches Pino's child-logger subset. Host wires any concrete
|
|
5
5
|
* logger (pino, winston, console-shim) that implements these methods.
|
|
6
|
+
*
|
|
7
|
+
* OTel instrumentation: import { createTracedLoggerPort } to wrap any
|
|
8
|
+
* LoggerPort implementation with OpenTelemetry spans per log call.
|
|
9
|
+
* Gracefully degrades to noop spans when no OTel SDK is installed.
|
|
6
10
|
*/
|
|
11
|
+
|
|
12
|
+
import type { Span } from "@opentelemetry/api";
|
|
13
|
+
import { SpanStatusCode, trace } from "@opentelemetry/api";
|
|
14
|
+
|
|
15
|
+
const PORT_TRACER = trace.getTracer("vauban-agent-sdk.ports", "0.1.0");
|
|
16
|
+
|
|
7
17
|
export interface LoggerPort {
|
|
8
18
|
debug(objOrMsg: object | string, msg?: string): void;
|
|
9
19
|
info(objOrMsg: object | string, msg?: string): void;
|
|
@@ -12,6 +22,29 @@ export interface LoggerPort {
|
|
|
12
22
|
child?(bindings: Record<string, unknown>): LoggerPort;
|
|
13
23
|
}
|
|
14
24
|
|
|
25
|
+
// ─── Typed errors ─────────────────────────────────────────────────────────────
|
|
26
|
+
|
|
27
|
+
/**
|
|
28
|
+
* Thrown when the log transport fails to flush pending buffers (disk full,
|
|
29
|
+
* network timeout on remote sink, or backend refused connection).
|
|
30
|
+
* Callers may retry flush or discard pending entries depending on criticality.
|
|
31
|
+
*/
|
|
32
|
+
export class LoggerFlushError extends Error {
|
|
33
|
+
/** Number of log entries that could not be flushed. */
|
|
34
|
+
readonly pendingCount: number;
|
|
35
|
+
|
|
36
|
+
constructor(
|
|
37
|
+
message: string,
|
|
38
|
+
pendingCount: number,
|
|
39
|
+
public readonly cause?: unknown
|
|
40
|
+
) {
|
|
41
|
+
super(message);
|
|
42
|
+
this.name = "LoggerFlushError";
|
|
43
|
+
this.pendingCount = pendingCount;
|
|
44
|
+
Object.setPrototypeOf(this, new.target.prototype);
|
|
45
|
+
}
|
|
46
|
+
}
|
|
47
|
+
|
|
15
48
|
/**
|
|
16
49
|
* noopLogger — convenience for tests where logs are not asserted.
|
|
17
50
|
*/
|
|
@@ -21,3 +54,74 @@ export const noopLogger: LoggerPort = {
|
|
|
21
54
|
warn: () => {},
|
|
22
55
|
error: () => {},
|
|
23
56
|
};
|
|
57
|
+
|
|
58
|
+
/**
|
|
59
|
+
* Wrap any LoggerPort implementation with OTel spans per log call.
|
|
60
|
+
* Each log level emits a short-lived span capturing the level and
|
|
61
|
+
* optional metadata. Gracefully degrades to noop spans when no OTel
|
|
62
|
+
* SDK is installed.
|
|
63
|
+
*
|
|
64
|
+
* Usage:
|
|
65
|
+
* const raw: LoggerPort = pino();
|
|
66
|
+
* const traced = createTracedLoggerPort(raw);
|
|
67
|
+
* traced.info("boot") // emits "logger.info" span
|
|
68
|
+
*/
|
|
69
|
+
export function createTracedLoggerPort(impl: LoggerPort): LoggerPort {
|
|
70
|
+
function tracedLog(
|
|
71
|
+
level: string,
|
|
72
|
+
objOrMsg: object | string,
|
|
73
|
+
msg?: string
|
|
74
|
+
): void {
|
|
75
|
+
PORT_TRACER.startActiveSpan(
|
|
76
|
+
`logger.${level}`,
|
|
77
|
+
{
|
|
78
|
+
attributes: {
|
|
79
|
+
"log.level": level,
|
|
80
|
+
"vauban.port.name": "logger",
|
|
81
|
+
},
|
|
82
|
+
},
|
|
83
|
+
(span: Span) => {
|
|
84
|
+
try {
|
|
85
|
+
const fn = (
|
|
86
|
+
impl as unknown as Record<string, (...args: unknown[]) => void>
|
|
87
|
+
)[level];
|
|
88
|
+
if (typeof fn !== "function") {
|
|
89
|
+
span.setStatus({
|
|
90
|
+
code: SpanStatusCode.ERROR,
|
|
91
|
+
message: `LoggerPort missing method: ${level}`,
|
|
92
|
+
});
|
|
93
|
+
return;
|
|
94
|
+
}
|
|
95
|
+
if (msg !== undefined) {
|
|
96
|
+
fn(objOrMsg, msg);
|
|
97
|
+
} else {
|
|
98
|
+
fn(objOrMsg);
|
|
99
|
+
}
|
|
100
|
+
span.setStatus({ code: SpanStatusCode.OK });
|
|
101
|
+
} catch (err) {
|
|
102
|
+
span.setStatus({
|
|
103
|
+
code: SpanStatusCode.ERROR,
|
|
104
|
+
message: err instanceof Error ? err.message : String(err),
|
|
105
|
+
});
|
|
106
|
+
} finally {
|
|
107
|
+
span.end();
|
|
108
|
+
}
|
|
109
|
+
}
|
|
110
|
+
);
|
|
111
|
+
}
|
|
112
|
+
|
|
113
|
+
return {
|
|
114
|
+
debug: (objOrMsg: object | string, msg?: string) =>
|
|
115
|
+
tracedLog("debug", objOrMsg, msg),
|
|
116
|
+
info: (objOrMsg: object | string, msg?: string) =>
|
|
117
|
+
tracedLog("info", objOrMsg, msg),
|
|
118
|
+
warn: (objOrMsg: object | string, msg?: string) =>
|
|
119
|
+
tracedLog("warn", objOrMsg, msg),
|
|
120
|
+
error: (objOrMsg: object | string, msg?: string) =>
|
|
121
|
+
tracedLog("error", objOrMsg, msg),
|
|
122
|
+
child: impl.child
|
|
123
|
+
? (bindings: Record<string, unknown>) =>
|
|
124
|
+
createTracedLoggerPort(impl.child!(bindings))
|
|
125
|
+
: undefined,
|
|
126
|
+
};
|
|
127
|
+
}
|