@yoda.digital/iris-gateway 1.13.3
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +515 -0
- package/README.md +282 -0
- package/dist/auto-reply/engine.d.ts +13 -0
- package/dist/auto-reply/engine.d.ts.map +1 -0
- package/dist/auto-reply/engine.js +70 -0
- package/dist/auto-reply/engine.js.map +1 -0
- package/dist/auto-reply/types.d.ts +37 -0
- package/dist/auto-reply/types.d.ts.map +1 -0
- package/dist/auto-reply/types.js +2 -0
- package/dist/auto-reply/types.js.map +1 -0
- package/dist/bridge/circuit-breaker.d.ts +40 -0
- package/dist/bridge/circuit-breaker.d.ts.map +1 -0
- package/dist/bridge/circuit-breaker.js +82 -0
- package/dist/bridge/circuit-breaker.js.map +1 -0
- package/dist/bridge/event-handler.d.ts +18 -0
- package/dist/bridge/event-handler.d.ts.map +1 -0
- package/dist/bridge/event-handler.js +128 -0
- package/dist/bridge/event-handler.js.map +1 -0
- package/dist/bridge/message-queue.d.ts +50 -0
- package/dist/bridge/message-queue.d.ts.map +1 -0
- package/dist/bridge/message-queue.js +110 -0
- package/dist/bridge/message-queue.js.map +1 -0
- package/dist/bridge/message-router.d.ts +37 -0
- package/dist/bridge/message-router.d.ts.map +1 -0
- package/dist/bridge/message-router.js +329 -0
- package/dist/bridge/message-router.js.map +1 -0
- package/dist/bridge/opencode-client.d.ts +55 -0
- package/dist/bridge/opencode-client.d.ts.map +1 -0
- package/dist/bridge/opencode-client.js +282 -0
- package/dist/bridge/opencode-client.js.map +1 -0
- package/dist/bridge/routers/channels.d.ts +11 -0
- package/dist/bridge/routers/channels.d.ts.map +1 -0
- package/dist/bridge/routers/channels.js +164 -0
- package/dist/bridge/routers/channels.js.map +1 -0
- package/dist/bridge/routers/cli.d.ts +11 -0
- package/dist/bridge/routers/cli.d.ts.map +1 -0
- package/dist/bridge/routers/cli.js +31 -0
- package/dist/bridge/routers/cli.js.map +1 -0
- package/dist/bridge/routers/governance.d.ts +13 -0
- package/dist/bridge/routers/governance.d.ts.map +1 -0
- package/dist/bridge/routers/governance.js +115 -0
- package/dist/bridge/routers/governance.js.map +1 -0
- package/dist/bridge/routers/intelligence.d.ts +23 -0
- package/dist/bridge/routers/intelligence.d.ts.map +1 -0
- package/dist/bridge/routers/intelligence.js +165 -0
- package/dist/bridge/routers/intelligence.js.map +1 -0
- package/dist/bridge/routers/skills-handlers.d.ts +122 -0
- package/dist/bridge/routers/skills-handlers.d.ts.map +1 -0
- package/dist/bridge/routers/skills-handlers.js +396 -0
- package/dist/bridge/routers/skills-handlers.js.map +1 -0
- package/dist/bridge/routers/skills-router.d.ts +5 -0
- package/dist/bridge/routers/skills-router.d.ts.map +1 -0
- package/dist/bridge/routers/skills-router.js +22 -0
- package/dist/bridge/routers/skills-router.js.map +1 -0
- package/dist/bridge/routers/skills.d.ts +2 -0
- package/dist/bridge/routers/skills.d.ts.map +1 -0
- package/dist/bridge/routers/skills.js +4 -0
- package/dist/bridge/routers/skills.js.map +1 -0
- package/dist/bridge/routers/system.d.ts +29 -0
- package/dist/bridge/routers/system.d.ts.map +1 -0
- package/dist/bridge/routers/system.js +132 -0
- package/dist/bridge/routers/system.js.map +1 -0
- package/dist/bridge/routers/vault.d.ts +11 -0
- package/dist/bridge/routers/vault.d.ts.map +1 -0
- package/dist/bridge/routers/vault.js +97 -0
- package/dist/bridge/routers/vault.js.map +1 -0
- package/dist/bridge/session-map.d.ts +24 -0
- package/dist/bridge/session-map.d.ts.map +1 -0
- package/dist/bridge/session-map.js +78 -0
- package/dist/bridge/session-map.js.map +1 -0
- package/dist/bridge/stream-coalescer.d.ts +26 -0
- package/dist/bridge/stream-coalescer.d.ts.map +1 -0
- package/dist/bridge/stream-coalescer.js +82 -0
- package/dist/bridge/stream-coalescer.js.map +1 -0
- package/dist/bridge/supervisor.d.ts +50 -0
- package/dist/bridge/supervisor.d.ts.map +1 -0
- package/dist/bridge/supervisor.js +139 -0
- package/dist/bridge/supervisor.js.map +1 -0
- package/dist/bridge/tool-server.d.ts +73 -0
- package/dist/bridge/tool-server.d.ts.map +1 -0
- package/dist/bridge/tool-server.js +209 -0
- package/dist/bridge/tool-server.js.map +1 -0
- package/dist/canvas/components.d.ts +71 -0
- package/dist/canvas/components.d.ts.map +1 -0
- package/dist/canvas/components.js +2 -0
- package/dist/canvas/components.js.map +1 -0
- package/dist/canvas/renderer.d.ts +2 -0
- package/dist/canvas/renderer.d.ts.map +1 -0
- package/dist/canvas/renderer.js +240 -0
- package/dist/canvas/renderer.js.map +1 -0
- package/dist/canvas/server.d.ts +24 -0
- package/dist/canvas/server.d.ts.map +1 -0
- package/dist/canvas/server.js +134 -0
- package/dist/canvas/server.js.map +1 -0
- package/dist/canvas/session.d.ts +23 -0
- package/dist/canvas/session.d.ts.map +1 -0
- package/dist/canvas/session.js +64 -0
- package/dist/canvas/session.js.map +1 -0
- package/dist/channels/adapter.d.ts +90 -0
- package/dist/channels/adapter.d.ts.map +1 -0
- package/dist/channels/adapter.js +2 -0
- package/dist/channels/adapter.js.map +1 -0
- package/dist/channels/discord/client.d.ts +3 -0
- package/dist/channels/discord/client.d.ts.map +1 -0
- package/dist/channels/discord/client.js +13 -0
- package/dist/channels/discord/client.js.map +1 -0
- package/dist/channels/discord/index.d.ts +41 -0
- package/dist/channels/discord/index.d.ts.map +1 -0
- package/dist/channels/discord/index.js +113 -0
- package/dist/channels/discord/index.js.map +1 -0
- package/dist/channels/discord/normalize.d.ts +4 -0
- package/dist/channels/discord/normalize.d.ts.map +1 -0
- package/dist/channels/discord/normalize.js +20 -0
- package/dist/channels/discord/normalize.js.map +1 -0
- package/dist/channels/discord/send.d.ts +13 -0
- package/dist/channels/discord/send.d.ts.map +1 -0
- package/dist/channels/discord/send.js +54 -0
- package/dist/channels/discord/send.js.map +1 -0
- package/dist/channels/mention-gating.d.ts +13 -0
- package/dist/channels/mention-gating.d.ts.map +1 -0
- package/dist/channels/mention-gating.js +42 -0
- package/dist/channels/mention-gating.js.map +1 -0
- package/dist/channels/message-cache.d.ts +17 -0
- package/dist/channels/message-cache.d.ts.map +1 -0
- package/dist/channels/message-cache.js +43 -0
- package/dist/channels/message-cache.js.map +1 -0
- package/dist/channels/registry.d.ts +9 -0
- package/dist/channels/registry.d.ts.map +1 -0
- package/dist/channels/registry.js +19 -0
- package/dist/channels/registry.js.map +1 -0
- package/dist/channels/slack/index.d.ts +38 -0
- package/dist/channels/slack/index.d.ts.map +1 -0
- package/dist/channels/slack/index.js +105 -0
- package/dist/channels/slack/index.js.map +1 -0
- package/dist/channels/slack/normalize.d.ts +14 -0
- package/dist/channels/slack/normalize.d.ts.map +1 -0
- package/dist/channels/slack/normalize.js +23 -0
- package/dist/channels/slack/normalize.js.map +1 -0
- package/dist/channels/slack/send.d.ts +13 -0
- package/dist/channels/slack/send.d.ts.map +1 -0
- package/dist/channels/slack/send.js +48 -0
- package/dist/channels/slack/send.js.map +1 -0
- package/dist/channels/telegram/index.d.ts +42 -0
- package/dist/channels/telegram/index.d.ts.map +1 -0
- package/dist/channels/telegram/index.js +125 -0
- package/dist/channels/telegram/index.js.map +1 -0
- package/dist/channels/telegram/normalize.d.ts +4 -0
- package/dist/channels/telegram/normalize.d.ts.map +1 -0
- package/dist/channels/telegram/normalize.js +25 -0
- package/dist/channels/telegram/normalize.js.map +1 -0
- package/dist/channels/telegram/send.d.ts +13 -0
- package/dist/channels/telegram/send.d.ts.map +1 -0
- package/dist/channels/telegram/send.js +55 -0
- package/dist/channels/telegram/send.js.map +1 -0
- package/dist/channels/webchat/index.d.ts +20 -0
- package/dist/channels/webchat/index.d.ts.map +1 -0
- package/dist/channels/webchat/index.js +42 -0
- package/dist/channels/webchat/index.js.map +1 -0
- package/dist/channels/whatsapp/connection.d.ts +43 -0
- package/dist/channels/whatsapp/connection.d.ts.map +1 -0
- package/dist/channels/whatsapp/connection.js +76 -0
- package/dist/channels/whatsapp/connection.js.map +1 -0
- package/dist/channels/whatsapp/index.d.ts +38 -0
- package/dist/channels/whatsapp/index.d.ts.map +1 -0
- package/dist/channels/whatsapp/index.js +99 -0
- package/dist/channels/whatsapp/index.js.map +1 -0
- package/dist/channels/whatsapp/normalize.d.ts +4 -0
- package/dist/channels/whatsapp/normalize.d.ts.map +1 -0
- package/dist/channels/whatsapp/normalize.js +31 -0
- package/dist/channels/whatsapp/normalize.js.map +1 -0
- package/dist/channels/whatsapp/send.d.ts +12 -0
- package/dist/channels/whatsapp/send.d.ts.map +1 -0
- package/dist/channels/whatsapp/send.js +48 -0
- package/dist/channels/whatsapp/send.js.map +1 -0
- package/dist/cli/banner.d.ts +2 -0
- package/dist/cli/banner.d.ts.map +1 -0
- package/dist/cli/banner.js +18 -0
- package/dist/cli/banner.js.map +1 -0
- package/dist/cli/commands/config-cmd.d.ts +13 -0
- package/dist/cli/commands/config-cmd.d.ts.map +1 -0
- package/dist/cli/commands/config-cmd.js +76 -0
- package/dist/cli/commands/config-cmd.js.map +1 -0
- package/dist/cli/commands/cron-cmd.d.ts +23 -0
- package/dist/cli/commands/cron-cmd.d.ts.map +1 -0
- package/dist/cli/commands/cron-cmd.js +88 -0
- package/dist/cli/commands/cron-cmd.js.map +1 -0
- package/dist/cli/commands/doctor.d.ts +7 -0
- package/dist/cli/commands/doctor.d.ts.map +1 -0
- package/dist/cli/commands/doctor.js +88 -0
- package/dist/cli/commands/doctor.js.map +1 -0
- package/dist/cli/commands/gateway.d.ts +8 -0
- package/dist/cli/commands/gateway.d.ts.map +1 -0
- package/dist/cli/commands/gateway.js +33 -0
- package/dist/cli/commands/gateway.js.map +1 -0
- package/dist/cli/commands/init.d.ts +7 -0
- package/dist/cli/commands/init.d.ts.map +1 -0
- package/dist/cli/commands/init.js +308 -0
- package/dist/cli/commands/init.js.map +1 -0
- package/dist/cli/commands/pairing.d.ts +19 -0
- package/dist/cli/commands/pairing.d.ts.map +1 -0
- package/dist/cli/commands/pairing.js +70 -0
- package/dist/cli/commands/pairing.js.map +1 -0
- package/dist/cli/commands/scan.d.ts +8 -0
- package/dist/cli/commands/scan.d.ts.map +1 -0
- package/dist/cli/commands/scan.js +39 -0
- package/dist/cli/commands/scan.js.map +1 -0
- package/dist/cli/commands/security.d.ts +15 -0
- package/dist/cli/commands/security.d.ts.map +1 -0
- package/dist/cli/commands/security.js +49 -0
- package/dist/cli/commands/security.js.map +1 -0
- package/dist/cli/commands/send.d.ts +10 -0
- package/dist/cli/commands/send.d.ts.map +1 -0
- package/dist/cli/commands/send.js +64 -0
- package/dist/cli/commands/send.js.map +1 -0
- package/dist/cli/commands/session.d.ts +13 -0
- package/dist/cli/commands/session.d.ts.map +1 -0
- package/dist/cli/commands/session.js +48 -0
- package/dist/cli/commands/session.js.map +1 -0
- package/dist/cli/commands/status.d.ts +7 -0
- package/dist/cli/commands/status.d.ts.map +1 -0
- package/dist/cli/commands/status.js +43 -0
- package/dist/cli/commands/status.js.map +1 -0
- package/dist/cli/executor.d.ts +19 -0
- package/dist/cli/executor.d.ts.map +1 -0
- package/dist/cli/executor.js +75 -0
- package/dist/cli/executor.js.map +1 -0
- package/dist/cli/program.d.ts +3 -0
- package/dist/cli/program.d.ts.map +1 -0
- package/dist/cli/program.js +49 -0
- package/dist/cli/program.js.map +1 -0
- package/dist/cli/registry.d.ts +15 -0
- package/dist/cli/registry.d.ts.map +1 -0
- package/dist/cli/registry.js +64 -0
- package/dist/cli/registry.js.map +1 -0
- package/dist/cli/types.d.ts +40 -0
- package/dist/cli/types.d.ts.map +1 -0
- package/dist/cli/types.js +2 -0
- package/dist/cli/types.js.map +1 -0
- package/dist/config/loader.d.ts +4 -0
- package/dist/config/loader.d.ts.map +1 -0
- package/dist/config/loader.js +31 -0
- package/dist/config/loader.js.map +1 -0
- package/dist/config/paths.d.ts +4 -0
- package/dist/config/paths.d.ts.map +1 -0
- package/dist/config/paths.js +14 -0
- package/dist/config/paths.js.map +1 -0
- package/dist/config/schema.d.ts +1414 -0
- package/dist/config/schema.d.ts.map +1 -0
- package/dist/config/schema.js +256 -0
- package/dist/config/schema.js.map +1 -0
- package/dist/config/types.d.ts +176 -0
- package/dist/config/types.d.ts.map +1 -0
- package/dist/config/types.js +2 -0
- package/dist/config/types.js.map +1 -0
- package/dist/cron/run-log.d.ts +14 -0
- package/dist/cron/run-log.d.ts.map +1 -0
- package/dist/cron/run-log.js +16 -0
- package/dist/cron/run-log.js.map +1 -0
- package/dist/cron/service.d.ts +29 -0
- package/dist/cron/service.d.ts.map +1 -0
- package/dist/cron/service.js +98 -0
- package/dist/cron/service.js.map +1 -0
- package/dist/cron/store.d.ts +20 -0
- package/dist/cron/store.d.ts.map +1 -0
- package/dist/cron/store.js +61 -0
- package/dist/cron/store.js.map +1 -0
- package/dist/gateway/adapters.d.ts +37 -0
- package/dist/gateway/adapters.d.ts.map +1 -0
- package/dist/gateway/adapters.js +83 -0
- package/dist/gateway/adapters.js.map +1 -0
- package/dist/gateway/health.d.ts +19 -0
- package/dist/gateway/health.d.ts.map +1 -0
- package/dist/gateway/health.js +117 -0
- package/dist/gateway/health.js.map +1 -0
- package/dist/gateway/intelligence-wiring.d.ts +38 -0
- package/dist/gateway/intelligence-wiring.d.ts.map +1 -0
- package/dist/gateway/intelligence-wiring.js +49 -0
- package/dist/gateway/intelligence-wiring.js.map +1 -0
- package/dist/gateway/lifecycle.d.ts +71 -0
- package/dist/gateway/lifecycle.d.ts.map +1 -0
- package/dist/gateway/lifecycle.js +318 -0
- package/dist/gateway/lifecycle.js.map +1 -0
- package/dist/gateway/metrics.d.ts +27 -0
- package/dist/gateway/metrics.d.ts.map +1 -0
- package/dist/gateway/metrics.js +99 -0
- package/dist/gateway/metrics.js.map +1 -0
- package/dist/gateway/security-wiring.d.ts +16 -0
- package/dist/gateway/security-wiring.d.ts.map +1 -0
- package/dist/gateway/security-wiring.js +18 -0
- package/dist/gateway/security-wiring.js.map +1 -0
- package/dist/gateway/shutdown.d.ts +37 -0
- package/dist/gateway/shutdown.d.ts.map +1 -0
- package/dist/gateway/shutdown.js +60 -0
- package/dist/gateway/shutdown.js.map +1 -0
- package/dist/governance/engine.d.ts +11 -0
- package/dist/governance/engine.d.ts.map +1 -0
- package/dist/governance/engine.js +57 -0
- package/dist/governance/engine.js.map +1 -0
- package/dist/governance/policy.d.ts +68 -0
- package/dist/governance/policy.d.ts.map +1 -0
- package/dist/governance/policy.js +300 -0
- package/dist/governance/policy.js.map +1 -0
- package/dist/governance/types.d.ts +18 -0
- package/dist/governance/types.d.ts.map +1 -0
- package/dist/governance/types.js +2 -0
- package/dist/governance/types.js.map +1 -0
- package/dist/heartbeat/active-hours.d.ts +7 -0
- package/dist/heartbeat/active-hours.d.ts.map +1 -0
- package/dist/heartbeat/active-hours.js +38 -0
- package/dist/heartbeat/active-hours.js.map +1 -0
- package/dist/heartbeat/activity.d.ts +16 -0
- package/dist/heartbeat/activity.d.ts.map +1 -0
- package/dist/heartbeat/activity.js +41 -0
- package/dist/heartbeat/activity.js.map +1 -0
- package/dist/heartbeat/checkers.d.ts +34 -0
- package/dist/heartbeat/checkers.d.ts.map +1 -0
- package/dist/heartbeat/checkers.js +161 -0
- package/dist/heartbeat/checkers.js.map +1 -0
- package/dist/heartbeat/coalesce.d.ts +16 -0
- package/dist/heartbeat/coalesce.d.ts.map +1 -0
- package/dist/heartbeat/coalesce.js +36 -0
- package/dist/heartbeat/coalesce.js.map +1 -0
- package/dist/heartbeat/empty-check.d.ts +12 -0
- package/dist/heartbeat/empty-check.d.ts.map +1 -0
- package/dist/heartbeat/empty-check.js +24 -0
- package/dist/heartbeat/empty-check.js.map +1 -0
- package/dist/heartbeat/engine.d.ts +39 -0
- package/dist/heartbeat/engine.d.ts.map +1 -0
- package/dist/heartbeat/engine.js +235 -0
- package/dist/heartbeat/engine.js.map +1 -0
- package/dist/heartbeat/store.d.ts +32 -0
- package/dist/heartbeat/store.d.ts.map +1 -0
- package/dist/heartbeat/store.js +127 -0
- package/dist/heartbeat/store.js.map +1 -0
- package/dist/heartbeat/types.d.ts +74 -0
- package/dist/heartbeat/types.d.ts.map +1 -0
- package/dist/heartbeat/types.js +2 -0
- package/dist/heartbeat/types.js.map +1 -0
- package/dist/heartbeat/visibility.d.ts +8 -0
- package/dist/heartbeat/visibility.d.ts.map +1 -0
- package/dist/heartbeat/visibility.js +13 -0
- package/dist/heartbeat/visibility.js.map +1 -0
- package/dist/index.d.ts +2 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +4 -0
- package/dist/index.js.map +1 -0
- package/dist/instance/coordinator.d.ts +30 -0
- package/dist/instance/coordinator.d.ts.map +1 -0
- package/dist/instance/coordinator.js +113 -0
- package/dist/instance/coordinator.js.map +1 -0
- package/dist/intelligence/arcs/detector.d.ts +57 -0
- package/dist/intelligence/arcs/detector.d.ts.map +1 -0
- package/dist/intelligence/arcs/detector.js +140 -0
- package/dist/intelligence/arcs/detector.js.map +1 -0
- package/dist/intelligence/arcs/lifecycle.d.ts +39 -0
- package/dist/intelligence/arcs/lifecycle.d.ts.map +1 -0
- package/dist/intelligence/arcs/lifecycle.js +87 -0
- package/dist/intelligence/arcs/lifecycle.js.map +1 -0
- package/dist/intelligence/arcs/store.d.ts +30 -0
- package/dist/intelligence/arcs/store.d.ts.map +1 -0
- package/dist/intelligence/arcs/store.js +117 -0
- package/dist/intelligence/arcs/store.js.map +1 -0
- package/dist/intelligence/bus.d.ts +21 -0
- package/dist/intelligence/bus.d.ts.map +1 -0
- package/dist/intelligence/bus.js +26 -0
- package/dist/intelligence/bus.js.map +1 -0
- package/dist/intelligence/cross-channel/resolver.d.ts +43 -0
- package/dist/intelligence/cross-channel/resolver.d.ts.map +1 -0
- package/dist/intelligence/cross-channel/resolver.js +129 -0
- package/dist/intelligence/cross-channel/resolver.js.map +1 -0
- package/dist/intelligence/goals/lifecycle.d.ts +66 -0
- package/dist/intelligence/goals/lifecycle.d.ts.map +1 -0
- package/dist/intelligence/goals/lifecycle.js +135 -0
- package/dist/intelligence/goals/lifecycle.js.map +1 -0
- package/dist/intelligence/goals/store.d.ts +30 -0
- package/dist/intelligence/goals/store.d.ts.map +1 -0
- package/dist/intelligence/goals/store.js +105 -0
- package/dist/intelligence/goals/store.js.map +1 -0
- package/dist/intelligence/health/gate.d.ts +41 -0
- package/dist/intelligence/health/gate.d.ts.map +1 -0
- package/dist/intelligence/health/gate.js +140 -0
- package/dist/intelligence/health/gate.js.map +1 -0
- package/dist/intelligence/health/trend-detector.d.ts +43 -0
- package/dist/intelligence/health/trend-detector.d.ts.map +1 -0
- package/dist/intelligence/health/trend-detector.js +160 -0
- package/dist/intelligence/health/trend-detector.js.map +1 -0
- package/dist/intelligence/inference/engine.d.ts +32 -0
- package/dist/intelligence/inference/engine.d.ts.map +1 -0
- package/dist/intelligence/inference/engine.js +98 -0
- package/dist/intelligence/inference/engine.js.map +1 -0
- package/dist/intelligence/inference/rules/engagement-trend.d.ts +9 -0
- package/dist/intelligence/inference/rules/engagement-trend.d.ts.map +1 -0
- package/dist/intelligence/inference/rules/engagement-trend.js +50 -0
- package/dist/intelligence/inference/rules/engagement-trend.js.map +1 -0
- package/dist/intelligence/inference/rules/index.d.ts +3 -0
- package/dist/intelligence/inference/rules/index.d.ts.map +1 -0
- package/dist/intelligence/inference/rules/index.js +13 -0
- package/dist/intelligence/inference/rules/index.js.map +1 -0
- package/dist/intelligence/inference/rules/language-stability.d.ts +9 -0
- package/dist/intelligence/inference/rules/language-stability.d.ts.map +1 -0
- package/dist/intelligence/inference/rules/language-stability.js +68 -0
- package/dist/intelligence/inference/rules/language-stability.js.map +1 -0
- package/dist/intelligence/inference/rules/response-cadence.d.ts +9 -0
- package/dist/intelligence/inference/rules/response-cadence.d.ts.map +1 -0
- package/dist/intelligence/inference/rules/response-cadence.js +53 -0
- package/dist/intelligence/inference/rules/response-cadence.js.map +1 -0
- package/dist/intelligence/inference/rules/session-pattern.d.ts +9 -0
- package/dist/intelligence/inference/rules/session-pattern.d.ts.map +1 -0
- package/dist/intelligence/inference/rules/session-pattern.js +53 -0
- package/dist/intelligence/inference/rules/session-pattern.js.map +1 -0
- package/dist/intelligence/inference/rules/timezone-from-hours.d.ts +3 -0
- package/dist/intelligence/inference/rules/timezone-from-hours.d.ts.map +1 -0
- package/dist/intelligence/inference/rules/timezone-from-hours.js +93 -0
- package/dist/intelligence/inference/rules/timezone-from-hours.js.map +1 -0
- package/dist/intelligence/inference/store.d.ts +21 -0
- package/dist/intelligence/inference/store.d.ts.map +1 -0
- package/dist/intelligence/inference/store.js +82 -0
- package/dist/intelligence/inference/store.js.map +1 -0
- package/dist/intelligence/outcomes/analyzer.d.ts +52 -0
- package/dist/intelligence/outcomes/analyzer.d.ts.map +1 -0
- package/dist/intelligence/outcomes/analyzer.js +103 -0
- package/dist/intelligence/outcomes/analyzer.js.map +1 -0
- package/dist/intelligence/outcomes/categorizer.d.ts +12 -0
- package/dist/intelligence/outcomes/categorizer.d.ts.map +1 -0
- package/dist/intelligence/outcomes/categorizer.js +19 -0
- package/dist/intelligence/outcomes/categorizer.js.map +1 -0
- package/dist/intelligence/outcomes/store.d.ts +21 -0
- package/dist/intelligence/outcomes/store.d.ts.map +1 -0
- package/dist/intelligence/outcomes/store.js +107 -0
- package/dist/intelligence/outcomes/store.js.map +1 -0
- package/dist/intelligence/prompt-assembler.d.ts +39 -0
- package/dist/intelligence/prompt-assembler.d.ts.map +1 -0
- package/dist/intelligence/prompt-assembler.js +99 -0
- package/dist/intelligence/prompt-assembler.js.map +1 -0
- package/dist/intelligence/store.d.ts +50 -0
- package/dist/intelligence/store.d.ts.map +1 -0
- package/dist/intelligence/store.js +102 -0
- package/dist/intelligence/store.js.map +1 -0
- package/dist/intelligence/triggers/evaluator.d.ts +27 -0
- package/dist/intelligence/triggers/evaluator.d.ts.map +1 -0
- package/dist/intelligence/triggers/evaluator.js +81 -0
- package/dist/intelligence/triggers/evaluator.js.map +1 -0
- package/dist/intelligence/triggers/rules.d.ts +10 -0
- package/dist/intelligence/triggers/rules.d.ts.map +1 -0
- package/dist/intelligence/triggers/rules.js +186 -0
- package/dist/intelligence/triggers/rules.js.map +1 -0
- package/dist/intelligence/types.d.ts +182 -0
- package/dist/intelligence/types.d.ts.map +1 -0
- package/dist/intelligence/types.js +3 -0
- package/dist/intelligence/types.js.map +1 -0
- package/dist/logging/logger.d.ts +5 -0
- package/dist/logging/logger.d.ts.map +1 -0
- package/dist/logging/logger.js +20 -0
- package/dist/logging/logger.js.map +1 -0
- package/dist/media/compress.d.ts +13 -0
- package/dist/media/compress.d.ts.map +1 -0
- package/dist/media/compress.js +38 -0
- package/dist/media/compress.js.map +1 -0
- package/dist/media/fetch.d.ts +18 -0
- package/dist/media/fetch.d.ts.map +1 -0
- package/dist/media/fetch.js +62 -0
- package/dist/media/fetch.js.map +1 -0
- package/dist/media/mime.d.ts +11 -0
- package/dist/media/mime.d.ts.map +1 -0
- package/dist/media/mime.js +112 -0
- package/dist/media/mime.js.map +1 -0
- package/dist/media/parse.d.ts +20 -0
- package/dist/media/parse.d.ts.map +1 -0
- package/dist/media/parse.js +52 -0
- package/dist/media/parse.js.map +1 -0
- package/dist/media/server.d.ts +17 -0
- package/dist/media/server.d.ts.map +1 -0
- package/dist/media/server.js +76 -0
- package/dist/media/server.js.map +1 -0
- package/dist/media/store.d.ts +26 -0
- package/dist/media/store.d.ts.map +1 -0
- package/dist/media/store.js +100 -0
- package/dist/media/store.js.map +1 -0
- package/dist/onboarding/enricher.d.ts +25 -0
- package/dist/onboarding/enricher.d.ts.map +1 -0
- package/dist/onboarding/enricher.js +151 -0
- package/dist/onboarding/enricher.js.map +1 -0
- package/dist/onboarding/signals.d.ts +13 -0
- package/dist/onboarding/signals.d.ts.map +1 -0
- package/dist/onboarding/signals.js +79 -0
- package/dist/onboarding/signals.js.map +1 -0
- package/dist/onboarding/types.d.ts +28 -0
- package/dist/onboarding/types.d.ts.map +1 -0
- package/dist/onboarding/types.js +2 -0
- package/dist/onboarding/types.js.map +1 -0
- package/dist/plugins/hook-bus.d.ts +7 -0
- package/dist/plugins/hook-bus.d.ts.map +1 -0
- package/dist/plugins/hook-bus.js +25 -0
- package/dist/plugins/hook-bus.js.map +1 -0
- package/dist/plugins/loader.d.ts +14 -0
- package/dist/plugins/loader.d.ts.map +1 -0
- package/dist/plugins/loader.js +108 -0
- package/dist/plugins/loader.js.map +1 -0
- package/dist/plugins/registry.d.ts +13 -0
- package/dist/plugins/registry.d.ts.map +1 -0
- package/dist/plugins/registry.js +32 -0
- package/dist/plugins/registry.js.map +1 -0
- package/dist/plugins/types.d.ts +67 -0
- package/dist/plugins/types.d.ts.map +1 -0
- package/dist/plugins/types.js +2 -0
- package/dist/plugins/types.js.map +1 -0
- package/dist/proactive/engine.d.ts +46 -0
- package/dist/proactive/engine.d.ts.map +1 -0
- package/dist/proactive/engine.js +238 -0
- package/dist/proactive/engine.js.map +1 -0
- package/dist/proactive/store.d.ts +35 -0
- package/dist/proactive/store.d.ts.map +1 -0
- package/dist/proactive/store.js +186 -0
- package/dist/proactive/store.js.map +1 -0
- package/dist/proactive/types.d.ts +91 -0
- package/dist/proactive/types.d.ts.map +1 -0
- package/dist/proactive/types.js +2 -0
- package/dist/proactive/types.js.map +1 -0
- package/dist/sdk/client.d.ts +222 -0
- package/dist/sdk/client.d.ts.map +1 -0
- package/dist/sdk/client.js +108 -0
- package/dist/sdk/client.js.map +1 -0
- package/dist/security/allowlist-store.d.ts +17 -0
- package/dist/security/allowlist-store.d.ts.map +1 -0
- package/dist/security/allowlist-store.js +52 -0
- package/dist/security/allowlist-store.js.map +1 -0
- package/dist/security/dm-policy.d.ts +32 -0
- package/dist/security/dm-policy.d.ts.map +1 -0
- package/dist/security/dm-policy.js +67 -0
- package/dist/security/dm-policy.js.map +1 -0
- package/dist/security/pairing-store.d.ts +25 -0
- package/dist/security/pairing-store.d.ts.map +1 -0
- package/dist/security/pairing-store.js +103 -0
- package/dist/security/pairing-store.js.map +1 -0
- package/dist/security/rate-limiter.d.ts +17 -0
- package/dist/security/rate-limiter.d.ts.map +1 -0
- package/dist/security/rate-limiter.js +43 -0
- package/dist/security/rate-limiter.js.map +1 -0
- package/dist/security/scan-rules.d.ts +3 -0
- package/dist/security/scan-rules.d.ts.map +1 -0
- package/dist/security/scan-rules.js +79 -0
- package/dist/security/scan-rules.js.map +1 -0
- package/dist/security/scan-types.d.ts +27 -0
- package/dist/security/scan-types.d.ts.map +1 -0
- package/dist/security/scan-types.js +2 -0
- package/dist/security/scan-types.js.map +1 -0
- package/dist/security/scanner.d.ts +8 -0
- package/dist/security/scanner.d.ts.map +1 -0
- package/dist/security/scanner.js +105 -0
- package/dist/security/scanner.js.map +1 -0
- package/dist/usage/tracker.d.ts +13 -0
- package/dist/usage/tracker.d.ts.map +1 -0
- package/dist/usage/tracker.js +66 -0
- package/dist/usage/tracker.js.map +1 -0
- package/dist/usage/types.d.ts +28 -0
- package/dist/usage/types.d.ts.map +1 -0
- package/dist/usage/types.js +2 -0
- package/dist/usage/types.js.map +1 -0
- package/dist/utils/file-lock.d.ts +2 -0
- package/dist/utils/file-lock.d.ts.map +1 -0
- package/dist/utils/file-lock.js +15 -0
- package/dist/utils/file-lock.js.map +1 -0
- package/dist/utils/retry.d.ts +8 -0
- package/dist/utils/retry.d.ts.map +1 -0
- package/dist/utils/retry.js +35 -0
- package/dist/utils/retry.js.map +1 -0
- package/dist/utils/text-chunker.d.ts +3 -0
- package/dist/utils/text-chunker.d.ts.map +1 -0
- package/dist/utils/text-chunker.js +58 -0
- package/dist/utils/text-chunker.js.map +1 -0
- package/dist/utils/typed-emitter.d.ts +14 -0
- package/dist/utils/typed-emitter.d.ts.map +1 -0
- package/dist/utils/typed-emitter.js +27 -0
- package/dist/utils/typed-emitter.js.map +1 -0
- package/dist/utils/types.d.ts +22 -0
- package/dist/utils/types.d.ts.map +1 -0
- package/dist/utils/types.js +13 -0
- package/dist/utils/types.js.map +1 -0
- package/dist/vault/db.d.ts +19 -0
- package/dist/vault/db.d.ts.map +1 -0
- package/dist/vault/db.js +201 -0
- package/dist/vault/db.js.map +1 -0
- package/dist/vault/search.d.ts +16 -0
- package/dist/vault/search.d.ts.map +1 -0
- package/dist/vault/search.js +75 -0
- package/dist/vault/search.js.map +1 -0
- package/dist/vault/store.d.ts +68 -0
- package/dist/vault/store.d.ts.map +1 -0
- package/dist/vault/store.js +170 -0
- package/dist/vault/store.js.map +1 -0
- package/dist/vault/types.d.ts +50 -0
- package/dist/vault/types.d.ts.map +1 -0
- package/dist/vault/types.js +2 -0
- package/dist/vault/types.js.map +1 -0
- package/docs/sdk/getting-started.md +133 -0
- package/package.json +87 -0
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"session-pattern.js","sourceRoot":"","sources":["../../../../src/intelligence/inference/rules/session-pattern.ts"],"names":[],"mappings":"AAIA;;;;;GAKG;AACH,MAAM,CAAC,MAAM,kBAAkB,GAAkB;IAC/C,EAAE,EAAE,iBAAiB;IACrB,YAAY,EAAE,CAAC,aAAa,CAAC;IAC7B,UAAU,EAAE,EAAE;IACd,UAAU,EAAE,SAAS,EAAE,UAAU;IAEjC,QAAQ,CAAC,GAAoB,EAAE,SAA+B;QAC5D,MAAM,cAAc,GAAG,SAAS,CAAC,CAAC,aAAa;QAE/C,MAAM,UAAU,GAAG,GAAG;aACnB,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,UAAU,CAAC;aACxB,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC;QAEzB,IAAI,UAAU,CAAC,MAAM,GAAG,EAAE;YAAE,OAAO,IAAI,CAAC;QAExC,sBAAsB;QACtB,MAAM,QAAQ,GAAe,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QAC/C,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,UAAU,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE,CAAC;YAC3C,MAAM,GAAG,GAAG,UAAU,CAAC,CAAC,CAAC,GAAG,UAAU,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC;YAC9C,IAAI,GAAG,GAAG,cAAc,EAAE,CAAC;gBACzB,QAAQ,CAAC,IAAI,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;YACjC,CAAC;iBAAM,CAAC;gBACN,QAAQ,CAAC,QAAQ,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,CAAC;YACpD,CAAC;QACH,CAAC;QAED,IAAI,QAAQ,CAAC,MAAM,GAAG,CAAC;YAAE,OAAO,IAAI,CAAC;QAErC,MAAM,cAAc,GAAG,QAAQ,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC;QACrD,MAAM,SAAS,GAAG,cAAc,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,GAAG,cAAc,CAAC,MAAM,CAAC;QAEpF,IAAI,OAAe,CAAC;QACpB,IAAI,SAAS,IAAI,CAAC;YAAE,OAAO,GAAG,OAAO,CAAC;aACjC,IAAI,SAAS,IAAI,CAAC;YAAE,OAAO,GAAG,UAAU,CAAC;;YACzC,OAAO,GAAG,UAAU,CAAC;QAE1B,MAAM,UAAU,GAAG,IAAI,CAAC,GAAG,CAAC,GAAG,GAAG,QAAQ,CAAC,MAAM,GAAG,IAAI,EAAE,IAAI,CAAC,CAAC;QAEhE,OAAO;YACL,KAAK,EAAE,OAAO;YACd,UAAU;YACV,QAAQ,EAAE,IAAI,CAAC,SAAS,CAAC;gBACvB,YAAY,EAAE,QAAQ,CAAC,MAAM;gBAC7B,qBAAqB,EAAE,IAAI,CAAC,KAAK,CAAC,SAAS,GAAG,EAAE,CAAC,GAAG,EAAE;gBACtD,aAAa,EAAE,UAAU,CAAC,MAAM;aACjC,CAAC;SACH,CAAC;IACJ,CAAC;CACF,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"timezone-from-hours.d.ts","sourceRoot":"","sources":["../../../../src/intelligence/inference/rules/timezone-from-hours.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,cAAc,CAAC;AAmDlD,eAAO,MAAM,qBAAqB,EAAE,aAyDnC,CAAC"}
|
|
@@ -0,0 +1,93 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Infers timezone from active hour patterns.
|
|
3
|
+
* Clusters active hours into day/evening windows and maps
|
|
4
|
+
* to IANA timezone based on cluster center + language signals.
|
|
5
|
+
*/
|
|
6
|
+
// Map of hour offsets (from UTC) to timezone, grouped by script/language
|
|
7
|
+
const TIMEZONE_HINTS = {
|
|
8
|
+
"ro": ["Europe/Chisinau", "Europe/Bucharest"],
|
|
9
|
+
"ru": ["Europe/Moscow", "Europe/Chisinau"],
|
|
10
|
+
"uk": ["Europe/Kyiv"],
|
|
11
|
+
"de": ["Europe/Berlin"],
|
|
12
|
+
"fr": ["Europe/Paris"],
|
|
13
|
+
"es": ["Europe/Madrid", "America/Mexico_City"],
|
|
14
|
+
"pt": ["Europe/Lisbon", "America/Sao_Paulo"],
|
|
15
|
+
"ja": ["Asia/Tokyo"],
|
|
16
|
+
"zh": ["Asia/Shanghai"],
|
|
17
|
+
"ko": ["Asia/Seoul"],
|
|
18
|
+
"ar": ["Asia/Riyadh"],
|
|
19
|
+
"hi": ["Asia/Kolkata"],
|
|
20
|
+
"th": ["Asia/Bangkok"],
|
|
21
|
+
"tr": ["Europe/Istanbul"],
|
|
22
|
+
};
|
|
23
|
+
function clusterHours(hours) {
|
|
24
|
+
if (hours.length === 0)
|
|
25
|
+
return { center: 12, spread: 12 };
|
|
26
|
+
// Convert to radians for circular mean (hours wrap around)
|
|
27
|
+
const sinSum = hours.reduce((s, h) => s + Math.sin((h / 24) * 2 * Math.PI), 0);
|
|
28
|
+
const cosSum = hours.reduce((s, h) => s + Math.cos((h / 24) * 2 * Math.PI), 0);
|
|
29
|
+
const meanAngle = Math.atan2(sinSum / hours.length, cosSum / hours.length);
|
|
30
|
+
const center = ((meanAngle / (2 * Math.PI)) * 24 + 24) % 24;
|
|
31
|
+
// Circular spread
|
|
32
|
+
const r = Math.sqrt((sinSum / hours.length) ** 2 + (cosSum / hours.length) ** 2);
|
|
33
|
+
const spread = (1 - r) * 12; // 0 = all same hour, 12 = uniform
|
|
34
|
+
return { center: Math.round(center), spread };
|
|
35
|
+
}
|
|
36
|
+
function estimateUtcOffset(activityCenter) {
|
|
37
|
+
// Assume people are most active around 10-20 local time
|
|
38
|
+
// Activity center of 15 (3pm local) maps to offset = center - 15
|
|
39
|
+
const typicalLocalCenter = 15;
|
|
40
|
+
return activityCenter - typicalLocalCenter;
|
|
41
|
+
}
|
|
42
|
+
export const timezoneFromHoursRule = {
|
|
43
|
+
id: "timezone_inferred",
|
|
44
|
+
inputSignals: ["active_hour", "language"],
|
|
45
|
+
minSamples: 5,
|
|
46
|
+
cooldownMs: 3_600_000, // 1 hour
|
|
47
|
+
evaluate(raw, existing) {
|
|
48
|
+
const hourSignals = raw.filter((s) => s.signalType === "active_hour");
|
|
49
|
+
const langSignals = raw.filter((s) => s.signalType === "language");
|
|
50
|
+
if (hourSignals.length < 5)
|
|
51
|
+
return null;
|
|
52
|
+
// Get last 14 days of hours
|
|
53
|
+
const twoWeeksAgo = Date.now() - 14 * 86_400_000;
|
|
54
|
+
const recentHours = hourSignals
|
|
55
|
+
.filter((s) => s.observedAt > twoWeeksAgo)
|
|
56
|
+
.map((s) => parseInt(s.value, 10))
|
|
57
|
+
.filter((h) => !isNaN(h));
|
|
58
|
+
if (recentHours.length < 5)
|
|
59
|
+
return null;
|
|
60
|
+
const { center, spread } = clusterHours(recentHours);
|
|
61
|
+
// If spread is too wide, hours are random — can't infer timezone
|
|
62
|
+
if (spread > 8)
|
|
63
|
+
return null;
|
|
64
|
+
const utcOffset = estimateUtcOffset(center);
|
|
65
|
+
// Try to narrow down using language
|
|
66
|
+
const topLang = langSignals.length > 0
|
|
67
|
+
? langSignals.sort((a, b) => b.confidence - a.confidence)[0].value
|
|
68
|
+
: null;
|
|
69
|
+
let timezone;
|
|
70
|
+
if (topLang && TIMEZONE_HINTS[topLang]) {
|
|
71
|
+
// Pick the timezone hint closest to our estimated offset
|
|
72
|
+
const hints = TIMEZONE_HINTS[topLang];
|
|
73
|
+
timezone = hints[0]; // Default to first hint for the language
|
|
74
|
+
}
|
|
75
|
+
else {
|
|
76
|
+
// Generic offset-based timezone
|
|
77
|
+
timezone = `UTC${utcOffset >= 0 ? "+" : ""}${utcOffset}`;
|
|
78
|
+
}
|
|
79
|
+
const confidence = Math.min(0.5 + recentHours.length * 0.02, 0.85);
|
|
80
|
+
return {
|
|
81
|
+
value: timezone,
|
|
82
|
+
confidence,
|
|
83
|
+
evidence: JSON.stringify({
|
|
84
|
+
sampleCount: recentHours.length,
|
|
85
|
+
activityCenter: center,
|
|
86
|
+
spread,
|
|
87
|
+
estimatedOffset: utcOffset,
|
|
88
|
+
languageHint: topLang,
|
|
89
|
+
}),
|
|
90
|
+
};
|
|
91
|
+
},
|
|
92
|
+
};
|
|
93
|
+
//# sourceMappingURL=timezone-from-hours.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"timezone-from-hours.js","sourceRoot":"","sources":["../../../../src/intelligence/inference/rules/timezone-from-hours.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import type { VaultDB } from "../../vault/db.js";
|
|
2
|
+
import type { DerivedSignal, InferenceLogEntry } from "../types.js";
|
|
3
|
+
export declare class InferenceStore {
|
|
4
|
+
private readonly db;
|
|
5
|
+
constructor(vaultDb: VaultDB);
|
|
6
|
+
writeDerivedSignal(params: {
|
|
7
|
+
senderId: string;
|
|
8
|
+
channelId?: string | null;
|
|
9
|
+
signalType: string;
|
|
10
|
+
value: string;
|
|
11
|
+
confidence?: number;
|
|
12
|
+
evidence?: string | null;
|
|
13
|
+
expiresAt?: number | null;
|
|
14
|
+
}): DerivedSignal;
|
|
15
|
+
getDerivedSignal(id: string): DerivedSignal | null;
|
|
16
|
+
getDerivedSignals(senderId: string, signalType?: string): DerivedSignal[];
|
|
17
|
+
logInference(entry: InferenceLogEntry): void;
|
|
18
|
+
getLastInferenceRun(ruleId: string, senderId: string): number | null;
|
|
19
|
+
private toDerivedSignal;
|
|
20
|
+
}
|
|
21
|
+
//# sourceMappingURL=store.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"store.d.ts","sourceRoot":"","sources":["../../../src/intelligence/inference/store.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,mBAAmB,CAAC;AAEjD,OAAO,KAAK,EAAE,aAAa,EAAE,iBAAiB,EAAE,MAAM,aAAa,CAAC;AAyBpE,qBAAa,cAAc;IACzB,OAAO,CAAC,QAAQ,CAAC,EAAE,CAAoB;gBAE3B,OAAO,EAAE,OAAO;IAO5B,kBAAkB,CAAC,MAAM,EAAE;QACzB,QAAQ,EAAE,MAAM,CAAC;QACjB,SAAS,CAAC,EAAE,MAAM,GAAG,IAAI,CAAC;QAC1B,UAAU,EAAE,MAAM,CAAC;QACnB,KAAK,EAAE,MAAM,CAAC;QACd,UAAU,CAAC,EAAE,MAAM,CAAC;QACpB,QAAQ,CAAC,EAAE,MAAM,GAAG,IAAI,CAAC;QACzB,SAAS,CAAC,EAAE,MAAM,GAAG,IAAI,CAAC;KAC3B,GAAG,aAAa;IAwCjB,gBAAgB,CAAC,EAAE,EAAE,MAAM,GAAG,aAAa,GAAG,IAAI;IAKlD,iBAAiB,CAAC,QAAQ,EAAE,MAAM,EAAE,UAAU,CAAC,EAAE,MAAM,GAAG,aAAa,EAAE;IASzE,YAAY,CAAC,KAAK,EAAE,iBAAiB,GAAG,IAAI;IAM5C,mBAAmB,CAAC,MAAM,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,GAAG,MAAM,GAAG,IAAI;IAOpE,OAAO,CAAC,eAAe;CAcxB"}
|
|
@@ -0,0 +1,82 @@
|
|
|
1
|
+
import { randomUUID } from "node:crypto";
|
|
2
|
+
const SCHEMA_SQL = `CREATE TABLE IF NOT EXISTS derived_signals (
|
|
3
|
+
id TEXT PRIMARY KEY,
|
|
4
|
+
sender_id TEXT NOT NULL,
|
|
5
|
+
channel_id TEXT,
|
|
6
|
+
signal_type TEXT NOT NULL,
|
|
7
|
+
value TEXT NOT NULL,
|
|
8
|
+
confidence REAL DEFAULT 0.5,
|
|
9
|
+
evidence TEXT,
|
|
10
|
+
created_at INTEGER NOT NULL,
|
|
11
|
+
updated_at INTEGER NOT NULL,
|
|
12
|
+
expires_at INTEGER
|
|
13
|
+
);
|
|
14
|
+
CREATE INDEX IF NOT EXISTS idx_derived_sender ON derived_signals(sender_id, signal_type);
|
|
15
|
+
|
|
16
|
+
CREATE TABLE IF NOT EXISTS inference_log (
|
|
17
|
+
id INTEGER PRIMARY KEY AUTOINCREMENT,
|
|
18
|
+
rule_id TEXT NOT NULL,
|
|
19
|
+
sender_id TEXT NOT NULL,
|
|
20
|
+
result TEXT,
|
|
21
|
+
details TEXT,
|
|
22
|
+
executed_at INTEGER NOT NULL
|
|
23
|
+
);`;
|
|
24
|
+
export class InferenceStore {
|
|
25
|
+
db;
|
|
26
|
+
constructor(vaultDb) {
|
|
27
|
+
this.db = vaultDb.raw();
|
|
28
|
+
this.db.exec(SCHEMA_SQL);
|
|
29
|
+
}
|
|
30
|
+
// ── Derived Signals ──
|
|
31
|
+
writeDerivedSignal(params) {
|
|
32
|
+
const now = Date.now();
|
|
33
|
+
const existing = this.db
|
|
34
|
+
.prepare("SELECT id FROM derived_signals WHERE sender_id = ? AND signal_type = ? AND (channel_id = ? OR (channel_id IS NULL AND ? IS NULL))")
|
|
35
|
+
.get(params.senderId, params.signalType, params.channelId ?? null, params.channelId ?? null);
|
|
36
|
+
if (existing) {
|
|
37
|
+
this.db.prepare(`UPDATE derived_signals SET value = ?, confidence = ?, evidence = ?, updated_at = ?, expires_at = ?
|
|
38
|
+
WHERE id = ?`).run(params.value, params.confidence ?? 0.5, params.evidence ?? null, now, params.expiresAt ?? null, existing.id);
|
|
39
|
+
return this.getDerivedSignal(existing.id);
|
|
40
|
+
}
|
|
41
|
+
const id = randomUUID();
|
|
42
|
+
this.db.prepare(`INSERT INTO derived_signals (id, sender_id, channel_id, signal_type, value, confidence, evidence, created_at, updated_at, expires_at)
|
|
43
|
+
VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?)`).run(id, params.senderId, params.channelId ?? null, params.signalType, params.value, params.confidence ?? 0.5, params.evidence ?? null, now, now, params.expiresAt ?? null);
|
|
44
|
+
return this.getDerivedSignal(id);
|
|
45
|
+
}
|
|
46
|
+
getDerivedSignal(id) {
|
|
47
|
+
const row = this.db.prepare("SELECT * FROM derived_signals WHERE id = ?").get(id);
|
|
48
|
+
return row ? this.toDerivedSignal(row) : null;
|
|
49
|
+
}
|
|
50
|
+
getDerivedSignals(senderId, signalType) {
|
|
51
|
+
const query = signalType
|
|
52
|
+
? "SELECT * FROM derived_signals WHERE sender_id = ? AND signal_type = ? ORDER BY updated_at DESC"
|
|
53
|
+
: "SELECT * FROM derived_signals WHERE sender_id = ? ORDER BY updated_at DESC";
|
|
54
|
+
const args = signalType ? [senderId, signalType] : [senderId];
|
|
55
|
+
const rows = this.db.prepare(query).all(...args);
|
|
56
|
+
return rows.map((r) => this.toDerivedSignal(r));
|
|
57
|
+
}
|
|
58
|
+
logInference(entry) {
|
|
59
|
+
this.db.prepare("INSERT INTO inference_log (rule_id, sender_id, result, details, executed_at) VALUES (?, ?, ?, ?, ?)").run(entry.ruleId, entry.senderId, entry.result, entry.details, entry.executedAt);
|
|
60
|
+
}
|
|
61
|
+
getLastInferenceRun(ruleId, senderId) {
|
|
62
|
+
const row = this.db
|
|
63
|
+
.prepare("SELECT executed_at FROM inference_log WHERE rule_id = ? AND sender_id = ? ORDER BY executed_at DESC LIMIT 1")
|
|
64
|
+
.get(ruleId, senderId);
|
|
65
|
+
return row?.executed_at ?? null;
|
|
66
|
+
}
|
|
67
|
+
toDerivedSignal(row) {
|
|
68
|
+
return {
|
|
69
|
+
id: row["id"],
|
|
70
|
+
senderId: row["sender_id"],
|
|
71
|
+
channelId: row["channel_id"],
|
|
72
|
+
signalType: row["signal_type"],
|
|
73
|
+
value: row["value"],
|
|
74
|
+
confidence: row["confidence"],
|
|
75
|
+
evidence: row["evidence"],
|
|
76
|
+
createdAt: row["created_at"],
|
|
77
|
+
updatedAt: row["updated_at"],
|
|
78
|
+
expiresAt: row["expires_at"],
|
|
79
|
+
};
|
|
80
|
+
}
|
|
81
|
+
}
|
|
82
|
+
//# sourceMappingURL=store.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"store.js","sourceRoot":"","sources":["../../../src/intelligence/inference/store.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,UAAU,EAAE,MAAM,aAAa,CAAC;AAGzC,MAAM,UAAU,GAAG;;;;;;;;;;;;;;;;;;;;;GAqBhB,CAAC;AAEJ,MAAM,OAAO,cAAc;IACR,EAAE,CAAoB;IAEvC,YAAY,OAAgB;QAC1B,IAAI,CAAC,EAAE,GAAG,OAAO,CAAC,GAAG,EAAE,CAAC;QACxB,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;IAC3B,CAAC;IAED,wBAAwB;IAExB,kBAAkB,CAAC,MAQlB;QACC,MAAM,GAAG,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;QACvB,MAAM,QAAQ,GAAG,IAAI,CAAC,EAAE;aACrB,OAAO,CAAC,mIAAmI,CAAC;aAC5I,GAAG,CAAC,MAAM,CAAC,QAAQ,EAAE,MAAM,CAAC,UAAU,EAAE,MAAM,CAAC,SAAS,IAAI,IAAI,EAAE,MAAM,CAAC,SAAS,IAAI,IAAI,CAA+B,CAAC;QAE7H,IAAI,QAAQ,EAAE,CAAC;YACb,IAAI,CAAC,EAAE,CAAC,OAAO,CACb;sBACc,CACf,CAAC,GAAG,CACH,MAAM,CAAC,KAAK,EACZ,MAAM,CAAC,UAAU,IAAI,GAAG,EACxB,MAAM,CAAC,QAAQ,IAAI,IAAI,EACvB,GAAG,EACH,MAAM,CAAC,SAAS,IAAI,IAAI,EACxB,QAAQ,CAAC,EAAE,CACZ,CAAC;YACF,OAAO,IAAI,CAAC,gBAAgB,CAAC,QAAQ,CAAC,EAAE,CAAE,CAAC;QAC7C,CAAC;QAED,MAAM,EAAE,GAAG,UAAU,EAAE,CAAC;QACxB,IAAI,CAAC,EAAE,CAAC,OAAO,CACb;6CACuC,CACxC,CAAC,GAAG,CACH,EAAE,EACF,MAAM,CAAC,QAAQ,EACf,MAAM,CAAC,SAAS,IAAI,IAAI,EACxB,MAAM,CAAC,UAAU,EACjB,MAAM,CAAC,KAAK,EACZ,MAAM,CAAC,UAAU,IAAI,GAAG,EACxB,MAAM,CAAC,QAAQ,IAAI,IAAI,EACvB,GAAG,EACH,GAAG,EACH,MAAM,CAAC,SAAS,IAAI,IAAI,CACzB,CAAC;QACF,OAAO,IAAI,CAAC,gBAAgB,CAAC,EAAE,CAAE,CAAC;IACpC,CAAC;IAED,gBAAgB,CAAC,EAAU;QACzB,MAAM,GAAG,GAAG,IAAI,CAAC,EAAE,CAAC,OAAO,CAAC,4CAA4C,CAAC,CAAC,GAAG,CAAC,EAAE,CAAwC,CAAC;QACzH,OAAO,GAAG,CAAC,CAAC,CAAC,IAAI,CAAC,eAAe,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;IAChD,CAAC;IAED,iBAAiB,CAAC,QAAgB,EAAE,UAAmB;QACrD,MAAM,KAAK,GAAG,UAAU;YACtB,CAAC,CAAC,gGAAgG;YAClG,CAAC,CAAC,4EAA4E,CAAC;QACjF,MAAM,IAAI,GAAG,UAAU,CAAC,CAAC,CAAC,CAAC,QAAQ,EAAE,UAAU,CAAC,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC;QAC9D,MAAM,IAAI,GAAG,IAAI,CAAC,EAAE,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,GAAG,CAAC,GAAG,IAAI,CAA8B,CAAC;QAC9E,OAAO,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC,CAAC,CAAC,CAAC;IAClD,CAAC;IAED,YAAY,CAAC,KAAwB;QACnC,IAAI,CAAC,EAAE,CAAC,OAAO,CACb,qGAAqG,CACtG,CAAC,GAAG,CAAC,KAAK,CAAC,MAAM,EAAE,KAAK,CAAC,QAAQ,EAAE,KAAK,CAAC,MAAM,EAAE,KAAK,CAAC,OAAO,EAAE,KAAK,CAAC,UAAU,CAAC,CAAC;IACrF,CAAC;IAED,mBAAmB,CAAC,MAAc,EAAE,QAAgB;QAClD,MAAM,GAAG,GAAG,IAAI,CAAC,EAAE;aAChB,OAAO,CAAC,6GAA6G,CAAC;aACtH,GAAG,CAAC,MAAM,EAAE,QAAQ,CAAwC,CAAC;QAChE,OAAO,GAAG,EAAE,WAAW,IAAI,IAAI,CAAC;IAClC,CAAC;IAEO,eAAe,CAAC,GAA4B;QAClD,OAAO;YACL,EAAE,EAAE,GAAG,CAAC,IAAI,CAAW;YACvB,QAAQ,EAAE,GAAG,CAAC,WAAW,CAAW;YACpC,SAAS,EAAE,GAAG,CAAC,YAAY,CAAkB;YAC7C,UAAU,EAAE,GAAG,CAAC,aAAa,CAAW;YACxC,KAAK,EAAE,GAAG,CAAC,OAAO,CAAW;YAC7B,UAAU,EAAE,GAAG,CAAC,YAAY,CAAW;YACvC,QAAQ,EAAE,GAAG,CAAC,UAAU,CAAkB;YAC1C,SAAS,EAAE,GAAG,CAAC,YAAY,CAAW;YACtC,SAAS,EAAE,GAAG,CAAC,YAAY,CAAW;YACtC,SAAS,EAAE,GAAG,CAAC,YAAY,CAAkB;SAC9C,CAAC;IACJ,CAAC;CACF"}
|
|
@@ -0,0 +1,52 @@
|
|
|
1
|
+
import type { IntelligenceStore } from "../store.js";
|
|
2
|
+
import type { IntelligenceBus } from "../bus.js";
|
|
3
|
+
import type { Logger } from "../../logging/logger.js";
|
|
4
|
+
import type { CategoryRate, TimingPattern } from "../types.js";
|
|
5
|
+
/**
|
|
6
|
+
* Outcome-aware analysis layer.
|
|
7
|
+
* Queries IntelligenceStore for category rates and timing patterns,
|
|
8
|
+
* then determines whether a proactive message should be sent.
|
|
9
|
+
*
|
|
10
|
+
* All deterministic — no AI calls.
|
|
11
|
+
*/
|
|
12
|
+
export declare class OutcomeAnalyzer {
|
|
13
|
+
private readonly store;
|
|
14
|
+
private readonly bus;
|
|
15
|
+
private readonly logger;
|
|
16
|
+
constructor(store: IntelligenceStore, bus: IntelligenceBus, logger: Logger);
|
|
17
|
+
/**
|
|
18
|
+
* Record that a proactive message was sent.
|
|
19
|
+
* Called after PulseEngine successfully delivers a message.
|
|
20
|
+
*/
|
|
21
|
+
recordSent(params: {
|
|
22
|
+
intentId: string;
|
|
23
|
+
senderId: string;
|
|
24
|
+
channelId: string;
|
|
25
|
+
what: string;
|
|
26
|
+
category?: string;
|
|
27
|
+
}): void;
|
|
28
|
+
/**
|
|
29
|
+
* Record that a user engaged with a proactive message.
|
|
30
|
+
* Called when a user sends a message after receiving a proactive one.
|
|
31
|
+
*/
|
|
32
|
+
recordEngagement(senderId: string, quality?: "positive" | "neutral" | "negative"): void;
|
|
33
|
+
/**
|
|
34
|
+
* Determine if a proactive message should be sent to this user now.
|
|
35
|
+
* Uses category engagement rates and timing patterns.
|
|
36
|
+
*/
|
|
37
|
+
shouldSend(senderId: string, what: string, intentCategory?: string): {
|
|
38
|
+
send: boolean;
|
|
39
|
+
reason: string;
|
|
40
|
+
};
|
|
41
|
+
/**
|
|
42
|
+
* Get engagement summary for a user.
|
|
43
|
+
* Used by the prompt assembler to inject context.
|
|
44
|
+
*/
|
|
45
|
+
getSummary(senderId: string): {
|
|
46
|
+
rates: CategoryRate[];
|
|
47
|
+
timing: TimingPattern;
|
|
48
|
+
topCategory: string | null;
|
|
49
|
+
worstCategory: string | null;
|
|
50
|
+
};
|
|
51
|
+
}
|
|
52
|
+
//# sourceMappingURL=analyzer.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"analyzer.d.ts","sourceRoot":"","sources":["../../../src/intelligence/outcomes/analyzer.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,aAAa,CAAC;AACrD,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,WAAW,CAAC;AACjD,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,yBAAyB,CAAC;AACtD,OAAO,KAAK,EAAE,YAAY,EAAE,aAAa,EAAE,MAAM,aAAa,CAAC;AAG/D;;;;;;GAMG;AACH,qBAAa,eAAe;IAExB,OAAO,CAAC,QAAQ,CAAC,KAAK;IACtB,OAAO,CAAC,QAAQ,CAAC,GAAG;IACpB,OAAO,CAAC,QAAQ,CAAC,MAAM;gBAFN,KAAK,EAAE,iBAAiB,EACxB,GAAG,EAAE,eAAe,EACpB,MAAM,EAAE,MAAM;IAGjC;;;OAGG;IACH,UAAU,CAAC,MAAM,EAAE;QACjB,QAAQ,EAAE,MAAM,CAAC;QACjB,QAAQ,EAAE,MAAM,CAAC;QACjB,SAAS,EAAE,MAAM,CAAC;QAClB,IAAI,EAAE,MAAM,CAAC;QACb,QAAQ,CAAC,EAAE,MAAM,CAAC;KACnB,GAAG,IAAI;IA0BR;;;OAGG;IACH,gBAAgB,CAAC,QAAQ,EAAE,MAAM,EAAE,OAAO,GAAE,UAAU,GAAG,SAAS,GAAG,UAAsB,GAAG,IAAI;IAalG;;;OAGG;IACH,UAAU,CAAC,QAAQ,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,EAAE,cAAc,CAAC,EAAE,MAAM,GAAG;QAAE,IAAI,EAAE,OAAO,CAAC;QAAC,MAAM,EAAE,MAAM,CAAA;KAAE;IAoCtG;;;OAGG;IACH,UAAU,CAAC,QAAQ,EAAE,MAAM,GAAG;QAC5B,KAAK,EAAE,YAAY,EAAE,CAAC;QACtB,MAAM,EAAE,aAAa,CAAC;QACtB,WAAW,EAAE,MAAM,GAAG,IAAI,CAAC;QAC3B,aAAa,EAAE,MAAM,GAAG,IAAI,CAAC;KAC9B;CAUF"}
|
|
@@ -0,0 +1,103 @@
|
|
|
1
|
+
import { categorizeIntent } from "./categorizer.js";
|
|
2
|
+
/**
|
|
3
|
+
* Outcome-aware analysis layer.
|
|
4
|
+
* Queries IntelligenceStore for category rates and timing patterns,
|
|
5
|
+
* then determines whether a proactive message should be sent.
|
|
6
|
+
*
|
|
7
|
+
* All deterministic — no AI calls.
|
|
8
|
+
*/
|
|
9
|
+
export class OutcomeAnalyzer {
|
|
10
|
+
store;
|
|
11
|
+
bus;
|
|
12
|
+
logger;
|
|
13
|
+
constructor(store, bus, logger) {
|
|
14
|
+
this.store = store;
|
|
15
|
+
this.bus = bus;
|
|
16
|
+
this.logger = logger;
|
|
17
|
+
}
|
|
18
|
+
/**
|
|
19
|
+
* Record that a proactive message was sent.
|
|
20
|
+
* Called after PulseEngine successfully delivers a message.
|
|
21
|
+
*/
|
|
22
|
+
recordSent(params) {
|
|
23
|
+
const now = new Date();
|
|
24
|
+
const category = categorizeIntent(params.what, params.category);
|
|
25
|
+
const outcome = this.store.recordOutcome({
|
|
26
|
+
intentId: params.intentId,
|
|
27
|
+
senderId: params.senderId,
|
|
28
|
+
channelId: params.channelId,
|
|
29
|
+
category,
|
|
30
|
+
sentAt: Date.now(),
|
|
31
|
+
dayOfWeek: now.getDay(),
|
|
32
|
+
hourOfDay: now.getHours(),
|
|
33
|
+
});
|
|
34
|
+
this.bus.emit({
|
|
35
|
+
type: "outcome_recorded",
|
|
36
|
+
senderId: params.senderId,
|
|
37
|
+
outcome,
|
|
38
|
+
});
|
|
39
|
+
this.logger.info({ intentId: params.intentId, category }, "Outcome recorded");
|
|
40
|
+
}
|
|
41
|
+
/**
|
|
42
|
+
* Record that a user engaged with a proactive message.
|
|
43
|
+
* Called when a user sends a message after receiving a proactive one.
|
|
44
|
+
*/
|
|
45
|
+
recordEngagement(senderId, quality = "neutral") {
|
|
46
|
+
const engaged = this.store.markEngaged(senderId, Date.now(), quality);
|
|
47
|
+
if (engaged) {
|
|
48
|
+
this.bus.emit({
|
|
49
|
+
type: "outcome_engaged",
|
|
50
|
+
senderId,
|
|
51
|
+
category: "unknown", // We don't track category on engagement side
|
|
52
|
+
quality,
|
|
53
|
+
});
|
|
54
|
+
this.logger.info({ senderId, quality }, "Outcome engagement recorded");
|
|
55
|
+
}
|
|
56
|
+
}
|
|
57
|
+
/**
|
|
58
|
+
* Determine if a proactive message should be sent to this user now.
|
|
59
|
+
* Uses category engagement rates and timing patterns.
|
|
60
|
+
*/
|
|
61
|
+
shouldSend(senderId, what, intentCategory) {
|
|
62
|
+
const category = categorizeIntent(what, intentCategory);
|
|
63
|
+
const rates = this.store.getCategoryRates(senderId);
|
|
64
|
+
const timing = this.store.getTimingPatterns(senderId);
|
|
65
|
+
// Find rate for this category
|
|
66
|
+
const categoryRate = rates.find((r) => r.category === category);
|
|
67
|
+
// New category with no history — allow
|
|
68
|
+
if (!categoryRate || categoryRate.count < 3) {
|
|
69
|
+
return { send: true, reason: `new_category:${category}` };
|
|
70
|
+
}
|
|
71
|
+
// Category engagement rate below 15% with 5+ samples — skip
|
|
72
|
+
if (categoryRate.rate < 0.15 && categoryRate.count >= 5) {
|
|
73
|
+
return {
|
|
74
|
+
send: false,
|
|
75
|
+
reason: `low_engagement:${category}=${Math.round(categoryRate.rate * 100)}%`,
|
|
76
|
+
};
|
|
77
|
+
}
|
|
78
|
+
// Check timing — is now a bad time?
|
|
79
|
+
const now = new Date();
|
|
80
|
+
const currentDay = now.getDay();
|
|
81
|
+
const currentHour = now.getHours();
|
|
82
|
+
if (timing.worstDays.includes(currentDay) && timing.worstHours.includes(currentHour)) {
|
|
83
|
+
return {
|
|
84
|
+
send: false,
|
|
85
|
+
reason: `bad_timing:day=${currentDay},hour=${currentHour}`,
|
|
86
|
+
};
|
|
87
|
+
}
|
|
88
|
+
return { send: true, reason: `ok:${category}=${Math.round((categoryRate.rate) * 100)}%` };
|
|
89
|
+
}
|
|
90
|
+
/**
|
|
91
|
+
* Get engagement summary for a user.
|
|
92
|
+
* Used by the prompt assembler to inject context.
|
|
93
|
+
*/
|
|
94
|
+
getSummary(senderId) {
|
|
95
|
+
const rates = this.store.getCategoryRates(senderId);
|
|
96
|
+
const timing = this.store.getTimingPatterns(senderId);
|
|
97
|
+
const sorted = [...rates].sort((a, b) => b.rate - a.rate);
|
|
98
|
+
const topCategory = sorted.length > 0 ? sorted[0].category : null;
|
|
99
|
+
const worstCategory = sorted.length > 0 ? sorted[sorted.length - 1].category : null;
|
|
100
|
+
return { rates, timing, topCategory, worstCategory };
|
|
101
|
+
}
|
|
102
|
+
}
|
|
103
|
+
//# sourceMappingURL=analyzer.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"analyzer.js","sourceRoot":"","sources":["../../../src/intelligence/outcomes/analyzer.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Intent category validator.
|
|
3
|
+
* The AI passes the category directly — no keyword guessing needed.
|
|
4
|
+
* Falls back to "general" if no category provided or invalid.
|
|
5
|
+
*/
|
|
6
|
+
/**
|
|
7
|
+
* Validate and return a category for a proactive intent.
|
|
8
|
+
* @param _what - The intent text (unused — kept for backward compat)
|
|
9
|
+
* @param category - Category string from the AI (optional)
|
|
10
|
+
*/
|
|
11
|
+
export declare function categorizeIntent(_what: string, category?: string): string;
|
|
12
|
+
//# sourceMappingURL=categorizer.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"categorizer.d.ts","sourceRoot":"","sources":["../../../src/intelligence/outcomes/categorizer.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAMH;;;;GAIG;AACH,wBAAgB,gBAAgB,CAAC,KAAK,EAAE,MAAM,EAAE,QAAQ,CAAC,EAAE,MAAM,GAAG,MAAM,CAGzE"}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Intent category validator.
|
|
3
|
+
* The AI passes the category directly — no keyword guessing needed.
|
|
4
|
+
* Falls back to "general" if no category provided or invalid.
|
|
5
|
+
*/
|
|
6
|
+
const VALID_CATEGORIES = new Set([
|
|
7
|
+
"task", "work", "health", "hobby", "social", "reminder", "general",
|
|
8
|
+
]);
|
|
9
|
+
/**
|
|
10
|
+
* Validate and return a category for a proactive intent.
|
|
11
|
+
* @param _what - The intent text (unused — kept for backward compat)
|
|
12
|
+
* @param category - Category string from the AI (optional)
|
|
13
|
+
*/
|
|
14
|
+
export function categorizeIntent(_what, category) {
|
|
15
|
+
if (category && VALID_CATEGORIES.has(category))
|
|
16
|
+
return category;
|
|
17
|
+
return "general";
|
|
18
|
+
}
|
|
19
|
+
//# sourceMappingURL=categorizer.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"categorizer.js","sourceRoot":"","sources":["../../../src/intelligence/outcomes/categorizer.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH,MAAM,gBAAgB,GAAG,IAAI,GAAG,CAAC;IAC/B,MAAM,EAAE,MAAM,EAAE,QAAQ,EAAE,OAAO,EAAE,QAAQ,EAAE,UAAU,EAAE,SAAS;CACnE,CAAC,CAAC;AAEH;;;;GAIG;AACH,MAAM,UAAU,gBAAgB,CAAC,KAAa,EAAE,QAAiB;IAC/D,IAAI,QAAQ,IAAI,gBAAgB,CAAC,GAAG,CAAC,QAAQ,CAAC;QAAE,OAAO,QAAQ,CAAC;IAChE,OAAO,SAAS,CAAC;AACnB,CAAC"}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import type { VaultDB } from "../../vault/db.js";
|
|
2
|
+
import type { ProactiveOutcome, CategoryRate, TimingPattern } from "../types.js";
|
|
3
|
+
export declare class OutcomesStore {
|
|
4
|
+
private readonly db;
|
|
5
|
+
constructor(vaultDb: VaultDB);
|
|
6
|
+
recordOutcome(params: {
|
|
7
|
+
intentId: string;
|
|
8
|
+
senderId: string;
|
|
9
|
+
channelId: string;
|
|
10
|
+
category: string;
|
|
11
|
+
sentAt: number;
|
|
12
|
+
dayOfWeek: number;
|
|
13
|
+
hourOfDay: number;
|
|
14
|
+
}): ProactiveOutcome;
|
|
15
|
+
markEngaged(senderId: string, engagedAt: number, quality: string): boolean;
|
|
16
|
+
getCategoryRates(senderId: string, windowDays?: number): CategoryRate[];
|
|
17
|
+
getTimingPatterns(senderId: string, windowDays?: number): TimingPattern;
|
|
18
|
+
getOutcome(id: string): ProactiveOutcome | null;
|
|
19
|
+
private toOutcome;
|
|
20
|
+
}
|
|
21
|
+
//# sourceMappingURL=store.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"store.d.ts","sourceRoot":"","sources":["../../../src/intelligence/outcomes/store.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,mBAAmB,CAAC;AAEjD,OAAO,KAAK,EAAE,gBAAgB,EAAE,YAAY,EAAE,aAAa,EAAE,MAAM,aAAa,CAAC;AAoBjF,qBAAa,aAAa;IACxB,OAAO,CAAC,QAAQ,CAAC,EAAE,CAAoB;gBAE3B,OAAO,EAAE,OAAO;IAO5B,aAAa,CAAC,MAAM,EAAE;QACpB,QAAQ,EAAE,MAAM,CAAC;QACjB,QAAQ,EAAE,MAAM,CAAC;QACjB,SAAS,EAAE,MAAM,CAAC;QAClB,QAAQ,EAAE,MAAM,CAAC;QACjB,MAAM,EAAE,MAAM,CAAC;QACf,SAAS,EAAE,MAAM,CAAC;QAClB,SAAS,EAAE,MAAM,CAAC;KACnB,GAAG,gBAAgB;IAWpB,WAAW,CAAC,QAAQ,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,GAAG,OAAO;IAkB1E,gBAAgB,CAAC,QAAQ,EAAE,MAAM,EAAE,UAAU,SAAK,GAAG,YAAY,EAAE;IAqBnE,iBAAiB,CAAC,QAAQ,EAAE,MAAM,EAAE,UAAU,SAAK,GAAG,aAAa;IA2BnE,UAAU,CAAC,EAAE,EAAE,MAAM,GAAG,gBAAgB,GAAG,IAAI;IAK/C,OAAO,CAAC,SAAS;CAiBlB"}
|
|
@@ -0,0 +1,107 @@
|
|
|
1
|
+
import { metrics } from "../../gateway/metrics.js";
|
|
2
|
+
import { randomUUID } from "node:crypto";
|
|
3
|
+
const SCHEMA_SQL = `CREATE TABLE IF NOT EXISTS proactive_outcomes (
|
|
4
|
+
id TEXT PRIMARY KEY,
|
|
5
|
+
intent_id TEXT NOT NULL,
|
|
6
|
+
sender_id TEXT NOT NULL,
|
|
7
|
+
channel_id TEXT NOT NULL,
|
|
8
|
+
category TEXT NOT NULL,
|
|
9
|
+
sent_at INTEGER NOT NULL,
|
|
10
|
+
engaged INTEGER DEFAULT 0,
|
|
11
|
+
engaged_at INTEGER,
|
|
12
|
+
response_quality TEXT,
|
|
13
|
+
time_to_engage_ms INTEGER,
|
|
14
|
+
day_of_week INTEGER,
|
|
15
|
+
hour_of_day INTEGER,
|
|
16
|
+
created_at INTEGER NOT NULL
|
|
17
|
+
);
|
|
18
|
+
CREATE INDEX IF NOT EXISTS idx_outcomes_sender_cat ON proactive_outcomes(sender_id, category);
|
|
19
|
+
CREATE INDEX IF NOT EXISTS idx_outcomes_sender_time ON proactive_outcomes(sender_id, sent_at);`;
|
|
20
|
+
export class OutcomesStore {
|
|
21
|
+
db;
|
|
22
|
+
constructor(vaultDb) {
|
|
23
|
+
this.db = vaultDb.raw();
|
|
24
|
+
this.db.exec(SCHEMA_SQL);
|
|
25
|
+
}
|
|
26
|
+
// ── Proactive Outcomes ──
|
|
27
|
+
recordOutcome(params) {
|
|
28
|
+
const id = randomUUID();
|
|
29
|
+
const now = Date.now();
|
|
30
|
+
this.db.prepare(`INSERT INTO proactive_outcomes (id, intent_id, sender_id, channel_id, category, sent_at, day_of_week, hour_of_day, created_at)
|
|
31
|
+
VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?)`).run(id, params.intentId, params.senderId, params.channelId, params.category, params.sentAt, params.dayOfWeek, params.hourOfDay, now);
|
|
32
|
+
metrics.outcomesLogged.inc({ type: params.category });
|
|
33
|
+
return this.getOutcome(id);
|
|
34
|
+
}
|
|
35
|
+
markEngaged(senderId, engagedAt, quality) {
|
|
36
|
+
const cutoff = engagedAt - 86_400_000; // 24h window
|
|
37
|
+
const row = this.db.prepare(`SELECT id, sent_at FROM proactive_outcomes
|
|
38
|
+
WHERE sender_id = ? AND engaged = 0 AND sent_at > ?
|
|
39
|
+
ORDER BY sent_at DESC LIMIT 1`).get(senderId, cutoff);
|
|
40
|
+
if (!row)
|
|
41
|
+
return false;
|
|
42
|
+
const timeToEngage = engagedAt - row.sent_at;
|
|
43
|
+
this.db.prepare(`UPDATE proactive_outcomes SET engaged = 1, engaged_at = ?, response_quality = ?, time_to_engage_ms = ?
|
|
44
|
+
WHERE id = ?`).run(engagedAt, quality, timeToEngage, row.id);
|
|
45
|
+
return true;
|
|
46
|
+
}
|
|
47
|
+
getCategoryRates(senderId, windowDays = 30) {
|
|
48
|
+
const cutoff = Date.now() - windowDays * 86_400_000;
|
|
49
|
+
const rows = this.db.prepare(`SELECT category,
|
|
50
|
+
COUNT(*) as count,
|
|
51
|
+
SUM(engaged) as responded,
|
|
52
|
+
AVG(CASE WHEN engaged = 1 THEN time_to_engage_ms END) as avg_response_ms
|
|
53
|
+
FROM proactive_outcomes
|
|
54
|
+
WHERE sender_id = ? AND sent_at > ?
|
|
55
|
+
GROUP BY category`).all(senderId, cutoff);
|
|
56
|
+
return rows.map((r) => ({
|
|
57
|
+
category: r["category"],
|
|
58
|
+
count: r["count"],
|
|
59
|
+
responded: r["responded"] ?? 0,
|
|
60
|
+
rate: (r["responded"] ?? 0) / (r["count"] || 1),
|
|
61
|
+
avgResponseMs: r["avg_response_ms"],
|
|
62
|
+
}));
|
|
63
|
+
}
|
|
64
|
+
getTimingPatterns(senderId, windowDays = 30) {
|
|
65
|
+
const cutoff = Date.now() - windowDays * 86_400_000;
|
|
66
|
+
const rows = this.db.prepare(`SELECT day_of_week, hour_of_day,
|
|
67
|
+
COUNT(*) as total,
|
|
68
|
+
SUM(engaged) as engaged
|
|
69
|
+
FROM proactive_outcomes
|
|
70
|
+
WHERE sender_id = ? AND sent_at > ?
|
|
71
|
+
GROUP BY day_of_week, hour_of_day
|
|
72
|
+
HAVING total >= 2`).all(senderId, cutoff);
|
|
73
|
+
const rateBySlot = rows.map((r) => ({
|
|
74
|
+
day: r["day_of_week"],
|
|
75
|
+
hour: r["hour_of_day"],
|
|
76
|
+
rate: (r["engaged"] ?? 0) / (r["total"] || 1),
|
|
77
|
+
}));
|
|
78
|
+
const sorted = [...rateBySlot].sort((a, b) => b.rate - a.rate);
|
|
79
|
+
const bestDays = [...new Set(sorted.filter((s) => s.rate >= 0.5).map((s) => s.day))];
|
|
80
|
+
const bestHours = [...new Set(sorted.filter((s) => s.rate >= 0.5).map((s) => s.hour))];
|
|
81
|
+
const worstDays = [...new Set(sorted.filter((s) => s.rate < 0.2).map((s) => s.day))];
|
|
82
|
+
const worstHours = [...new Set(sorted.filter((s) => s.rate < 0.2).map((s) => s.hour))];
|
|
83
|
+
return { bestDays, bestHours, worstDays, worstHours };
|
|
84
|
+
}
|
|
85
|
+
getOutcome(id) {
|
|
86
|
+
const row = this.db.prepare("SELECT * FROM proactive_outcomes WHERE id = ?").get(id);
|
|
87
|
+
return row ? this.toOutcome(row) : null;
|
|
88
|
+
}
|
|
89
|
+
toOutcome(row) {
|
|
90
|
+
return {
|
|
91
|
+
id: row["id"],
|
|
92
|
+
intentId: row["intent_id"],
|
|
93
|
+
senderId: row["sender_id"],
|
|
94
|
+
channelId: row["channel_id"],
|
|
95
|
+
category: row["category"],
|
|
96
|
+
sentAt: row["sent_at"],
|
|
97
|
+
engaged: !!row["engaged"],
|
|
98
|
+
engagedAt: row["engaged_at"],
|
|
99
|
+
responseQuality: row["response_quality"],
|
|
100
|
+
timeToEngageMs: row["time_to_engage_ms"],
|
|
101
|
+
dayOfWeek: row["day_of_week"],
|
|
102
|
+
hourOfDay: row["hour_of_day"],
|
|
103
|
+
createdAt: row["created_at"],
|
|
104
|
+
};
|
|
105
|
+
}
|
|
106
|
+
}
|
|
107
|
+
//# sourceMappingURL=store.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"store.js","sourceRoot":"","sources":["../../../src/intelligence/outcomes/store.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
import type { ArcLifecycle } from "./arcs/lifecycle.js";
|
|
2
|
+
import type { GoalLifecycle } from "./goals/lifecycle.js";
|
|
3
|
+
import type { OutcomeAnalyzer } from "./outcomes/analyzer.js";
|
|
4
|
+
import type { CrossChannelResolver } from "./cross-channel/resolver.js";
|
|
5
|
+
import type { HealthGate } from "./health/gate.js";
|
|
6
|
+
import type { TriggerResult, PromptSections } from "./types.js";
|
|
7
|
+
/**
|
|
8
|
+
* Structured prompt assembler.
|
|
9
|
+
* Replaces ad-hoc string concatenation with independently toggleable sections.
|
|
10
|
+
* Each section is null when there's nothing to inject (no token waste).
|
|
11
|
+
*
|
|
12
|
+
* Called during system prompt transform to build intelligence context.
|
|
13
|
+
*/
|
|
14
|
+
export declare class PromptAssembler {
|
|
15
|
+
private readonly arcs;
|
|
16
|
+
private readonly goals;
|
|
17
|
+
private readonly outcomes;
|
|
18
|
+
private readonly crossChannel;
|
|
19
|
+
private readonly healthGate;
|
|
20
|
+
constructor(arcs: ArcLifecycle | null, goals: GoalLifecycle | null, outcomes: OutcomeAnalyzer | null, crossChannel: CrossChannelResolver | null, healthGate: HealthGate | null);
|
|
21
|
+
/**
|
|
22
|
+
* Assemble all intelligence sections for a user.
|
|
23
|
+
*/
|
|
24
|
+
assemble(senderId: string, triggerFlags?: TriggerResult[], userLanguage?: string): PromptSections;
|
|
25
|
+
/**
|
|
26
|
+
* Render all sections into a single string for system prompt injection.
|
|
27
|
+
* Only includes non-null sections.
|
|
28
|
+
*/
|
|
29
|
+
render(senderId: string, triggerFlags?: TriggerResult[], userLanguage?: string): string | null;
|
|
30
|
+
/**
|
|
31
|
+
* Build proactive context section from outcome data.
|
|
32
|
+
*/
|
|
33
|
+
private buildProactiveContext;
|
|
34
|
+
/**
|
|
35
|
+
* Build trigger flags section from fired triggers.
|
|
36
|
+
*/
|
|
37
|
+
private buildTriggerFlags;
|
|
38
|
+
}
|
|
39
|
+
//# sourceMappingURL=prompt-assembler.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"prompt-assembler.d.ts","sourceRoot":"","sources":["../../src/intelligence/prompt-assembler.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,qBAAqB,CAAC;AACxD,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAC;AAC1D,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,wBAAwB,CAAC;AAC9D,OAAO,KAAK,EAAE,oBAAoB,EAAE,MAAM,6BAA6B,CAAC;AACxE,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,kBAAkB,CAAC;AACnD,OAAO,KAAK,EAAE,aAAa,EAAE,cAAc,EAAE,MAAM,YAAY,CAAC;AAEhE;;;;;;GAMG;AACH,qBAAa,eAAe;IAExB,OAAO,CAAC,QAAQ,CAAC,IAAI;IACrB,OAAO,CAAC,QAAQ,CAAC,KAAK;IACtB,OAAO,CAAC,QAAQ,CAAC,QAAQ;IACzB,OAAO,CAAC,QAAQ,CAAC,YAAY;IAC7B,OAAO,CAAC,QAAQ,CAAC,UAAU;gBAJV,IAAI,EAAE,YAAY,GAAG,IAAI,EACzB,KAAK,EAAE,aAAa,GAAG,IAAI,EAC3B,QAAQ,EAAE,eAAe,GAAG,IAAI,EAChC,YAAY,EAAE,oBAAoB,GAAG,IAAI,EACzC,UAAU,EAAE,UAAU,GAAG,IAAI;IAGhD;;OAEG;IACH,QAAQ,CAAC,QAAQ,EAAE,MAAM,EAAE,YAAY,CAAC,EAAE,aAAa,EAAE,EAAE,YAAY,CAAC,EAAE,MAAM,GAAG,cAAc;IAWjG;;;OAGG;IACH,MAAM,CAAC,QAAQ,EAAE,MAAM,EAAE,YAAY,CAAC,EAAE,aAAa,EAAE,EAAE,YAAY,CAAC,EAAE,MAAM,GAAG,MAAM,GAAG,IAAI;IAc9F;;OAEG;IACH,OAAO,CAAC,qBAAqB;IAiC7B;;OAEG;IACH,OAAO,CAAC,iBAAiB;CAU1B"}
|