@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,52 @@
|
|
|
1
|
+
import { readFile, writeFile } from "node:fs/promises";
|
|
2
|
+
import { mkdirSync } from "node:fs";
|
|
3
|
+
import { join } from "node:path";
|
|
4
|
+
import { withFileLock } from "../utils/file-lock.js";
|
|
5
|
+
export class AllowlistStore {
|
|
6
|
+
filePath;
|
|
7
|
+
constructor(dataDir) {
|
|
8
|
+
mkdirSync(dataDir, { recursive: true });
|
|
9
|
+
this.filePath = join(dataDir, "allowlist.json");
|
|
10
|
+
}
|
|
11
|
+
async isAllowed(channelId, senderId) {
|
|
12
|
+
const entries = await this.readEntries();
|
|
13
|
+
return entries.some((e) => e.channelId === channelId && e.senderId === senderId);
|
|
14
|
+
}
|
|
15
|
+
async add(channelId, senderId, approvedBy) {
|
|
16
|
+
await withFileLock(this.filePath, async () => {
|
|
17
|
+
const entries = await this.readEntries();
|
|
18
|
+
const exists = entries.some((e) => e.channelId === channelId && e.senderId === senderId);
|
|
19
|
+
if (!exists) {
|
|
20
|
+
entries.push({ channelId, senderId, approvedBy, approvedAt: Date.now() });
|
|
21
|
+
await this.writeEntries(entries);
|
|
22
|
+
}
|
|
23
|
+
});
|
|
24
|
+
}
|
|
25
|
+
async remove(channelId, senderId) {
|
|
26
|
+
return withFileLock(this.filePath, async () => {
|
|
27
|
+
const entries = await this.readEntries();
|
|
28
|
+
const filtered = entries.filter((e) => !(e.channelId === channelId && e.senderId === senderId));
|
|
29
|
+
const removed = filtered.length < entries.length;
|
|
30
|
+
if (removed)
|
|
31
|
+
await this.writeEntries(filtered);
|
|
32
|
+
return removed;
|
|
33
|
+
});
|
|
34
|
+
}
|
|
35
|
+
async list(channelId) {
|
|
36
|
+
const entries = await this.readEntries();
|
|
37
|
+
return entries.filter((e) => e.channelId === channelId);
|
|
38
|
+
}
|
|
39
|
+
async readEntries() {
|
|
40
|
+
try {
|
|
41
|
+
const raw = await readFile(this.filePath, "utf-8");
|
|
42
|
+
return JSON.parse(raw);
|
|
43
|
+
}
|
|
44
|
+
catch {
|
|
45
|
+
return [];
|
|
46
|
+
}
|
|
47
|
+
}
|
|
48
|
+
async writeEntries(entries) {
|
|
49
|
+
await writeFile(this.filePath, JSON.stringify(entries, null, 2));
|
|
50
|
+
}
|
|
51
|
+
}
|
|
52
|
+
//# sourceMappingURL=allowlist-store.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"allowlist-store.js","sourceRoot":"","sources":["../../src/security/allowlist-store.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
import type { DmPolicyMode, SecurityConfig } from "../config/types.js";
|
|
2
|
+
import type { AllowlistStore } from "./allowlist-store.js";
|
|
3
|
+
import type { PairingStore } from "./pairing-store.js";
|
|
4
|
+
import type { RateLimiter } from "./rate-limiter.js";
|
|
5
|
+
export interface SecurityCheckParams {
|
|
6
|
+
readonly channelId: string;
|
|
7
|
+
readonly senderId: string;
|
|
8
|
+
readonly senderName: string;
|
|
9
|
+
readonly chatType: "dm" | "group";
|
|
10
|
+
readonly channelDmPolicy?: DmPolicyMode;
|
|
11
|
+
}
|
|
12
|
+
export type SecurityCheckResult = {
|
|
13
|
+
allowed: true;
|
|
14
|
+
} | {
|
|
15
|
+
allowed: false;
|
|
16
|
+
reason: "disabled" | "not_allowed" | "rate_limited";
|
|
17
|
+
message?: string;
|
|
18
|
+
} | {
|
|
19
|
+
allowed: false;
|
|
20
|
+
reason: "pairing_required";
|
|
21
|
+
pairingCode: string;
|
|
22
|
+
message: string;
|
|
23
|
+
};
|
|
24
|
+
export declare class SecurityGate {
|
|
25
|
+
private readonly pairingStore;
|
|
26
|
+
private readonly allowlistStore;
|
|
27
|
+
private readonly rateLimiter;
|
|
28
|
+
private readonly config;
|
|
29
|
+
constructor(pairingStore: PairingStore, allowlistStore: AllowlistStore, rateLimiter: RateLimiter, config: SecurityConfig);
|
|
30
|
+
check(params: SecurityCheckParams): Promise<SecurityCheckResult>;
|
|
31
|
+
}
|
|
32
|
+
//# sourceMappingURL=dm-policy.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"dm-policy.d.ts","sourceRoot":"","sources":["../../src/security/dm-policy.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,YAAY,EAAE,cAAc,EAAE,MAAM,oBAAoB,CAAC;AACvE,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,sBAAsB,CAAC;AAC3D,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,oBAAoB,CAAC;AACvD,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,mBAAmB,CAAC;AAErD,MAAM,WAAW,mBAAmB;IAClC,QAAQ,CAAC,SAAS,EAAE,MAAM,CAAC;IAC3B,QAAQ,CAAC,QAAQ,EAAE,MAAM,CAAC;IAC1B,QAAQ,CAAC,UAAU,EAAE,MAAM,CAAC;IAC5B,QAAQ,CAAC,QAAQ,EAAE,IAAI,GAAG,OAAO,CAAC;IAClC,QAAQ,CAAC,eAAe,CAAC,EAAE,YAAY,CAAC;CACzC;AAED,MAAM,MAAM,mBAAmB,GAC3B;IAAE,OAAO,EAAE,IAAI,CAAA;CAAE,GACjB;IACE,OAAO,EAAE,KAAK,CAAC;IACf,MAAM,EAAE,UAAU,GAAG,aAAa,GAAG,cAAc,CAAC;IACpD,OAAO,CAAC,EAAE,MAAM,CAAC;CAClB,GACD;IACE,OAAO,EAAE,KAAK,CAAC;IACf,MAAM,EAAE,kBAAkB,CAAC;IAC3B,WAAW,EAAE,MAAM,CAAC;IACpB,OAAO,EAAE,MAAM,CAAC;CACjB,CAAC;AAEN,qBAAa,YAAY;IAErB,OAAO,CAAC,QAAQ,CAAC,YAAY;IAC7B,OAAO,CAAC,QAAQ,CAAC,cAAc;IAC/B,OAAO,CAAC,QAAQ,CAAC,WAAW;IAC5B,OAAO,CAAC,QAAQ,CAAC,MAAM;gBAHN,YAAY,EAAE,YAAY,EAC1B,cAAc,EAAE,cAAc,EAC9B,WAAW,EAAE,WAAW,EACxB,MAAM,EAAE,cAAc;IAGnC,KAAK,CAAC,MAAM,EAAE,mBAAmB,GAAG,OAAO,CAAC,mBAAmB,CAAC;CAqEvE"}
|
|
@@ -0,0 +1,67 @@
|
|
|
1
|
+
export class SecurityGate {
|
|
2
|
+
pairingStore;
|
|
3
|
+
allowlistStore;
|
|
4
|
+
rateLimiter;
|
|
5
|
+
config;
|
|
6
|
+
constructor(pairingStore, allowlistStore, rateLimiter, config) {
|
|
7
|
+
this.pairingStore = pairingStore;
|
|
8
|
+
this.allowlistStore = allowlistStore;
|
|
9
|
+
this.rateLimiter = rateLimiter;
|
|
10
|
+
this.config = config;
|
|
11
|
+
}
|
|
12
|
+
async check(params) {
|
|
13
|
+
const policy = params.channelDmPolicy ?? this.config.defaultDmPolicy;
|
|
14
|
+
// Rate limit check (applies to all modes except disabled)
|
|
15
|
+
if (policy !== "disabled") {
|
|
16
|
+
const rateLimitKey = `${params.channelId}:${params.senderId}`;
|
|
17
|
+
const rateResult = this.rateLimiter.check(rateLimitKey);
|
|
18
|
+
if (!rateResult.allowed) {
|
|
19
|
+
return {
|
|
20
|
+
allowed: false,
|
|
21
|
+
reason: "rate_limited",
|
|
22
|
+
message: `Rate limited. Try again in ${Math.ceil((rateResult.retryAfterMs ?? 0) / 1000)}s.`,
|
|
23
|
+
};
|
|
24
|
+
}
|
|
25
|
+
this.rateLimiter.hit(rateLimitKey);
|
|
26
|
+
}
|
|
27
|
+
switch (policy) {
|
|
28
|
+
case "open":
|
|
29
|
+
return { allowed: true };
|
|
30
|
+
case "disabled":
|
|
31
|
+
return {
|
|
32
|
+
allowed: false,
|
|
33
|
+
reason: "disabled",
|
|
34
|
+
message: "This channel is currently disabled.",
|
|
35
|
+
};
|
|
36
|
+
case "allowlist": {
|
|
37
|
+
const isAllowed = await this.allowlistStore.isAllowed(params.channelId, params.senderId);
|
|
38
|
+
if (isAllowed)
|
|
39
|
+
return { allowed: true };
|
|
40
|
+
return {
|
|
41
|
+
allowed: false,
|
|
42
|
+
reason: "not_allowed",
|
|
43
|
+
message: "You are not on the allowlist for this channel.",
|
|
44
|
+
};
|
|
45
|
+
}
|
|
46
|
+
case "pairing": {
|
|
47
|
+
const isAllowed = await this.allowlistStore.isAllowed(params.channelId, params.senderId);
|
|
48
|
+
if (isAllowed)
|
|
49
|
+
return { allowed: true };
|
|
50
|
+
const code = await this.pairingStore.issueCode(params.channelId, params.senderId);
|
|
51
|
+
return {
|
|
52
|
+
allowed: false,
|
|
53
|
+
reason: "pairing_required",
|
|
54
|
+
pairingCode: code,
|
|
55
|
+
message: `Hi ${params.senderName}! To start chatting, ask the owner to approve your pairing code: ${code}`,
|
|
56
|
+
};
|
|
57
|
+
}
|
|
58
|
+
default:
|
|
59
|
+
return {
|
|
60
|
+
allowed: false,
|
|
61
|
+
reason: "disabled",
|
|
62
|
+
message: "Unknown policy mode.",
|
|
63
|
+
};
|
|
64
|
+
}
|
|
65
|
+
}
|
|
66
|
+
}
|
|
67
|
+
//# sourceMappingURL=dm-policy.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"dm-policy.js","sourceRoot":"","sources":["../../src/security/dm-policy.ts"],"names":[],"mappings":"AA2BA,MAAM,OAAO,YAAY;IAEJ;IACA;IACA;IACA;IAJnB,YACmB,YAA0B,EAC1B,cAA8B,EAC9B,WAAwB,EACxB,MAAsB;QAHtB,iBAAY,GAAZ,YAAY,CAAc;QAC1B,mBAAc,GAAd,cAAc,CAAgB;QAC9B,gBAAW,GAAX,WAAW,CAAa;QACxB,WAAM,GAAN,MAAM,CAAgB;IACtC,CAAC;IAEJ,KAAK,CAAC,KAAK,CAAC,MAA2B;QACrC,MAAM,MAAM,GACV,MAAM,CAAC,eAAe,IAAI,IAAI,CAAC,MAAM,CAAC,eAAe,CAAC;QAExD,0DAA0D;QAC1D,IAAI,MAAM,KAAK,UAAU,EAAE,CAAC;YAC1B,MAAM,YAAY,GAAG,GAAG,MAAM,CAAC,SAAS,IAAI,MAAM,CAAC,QAAQ,EAAE,CAAC;YAC9D,MAAM,UAAU,GAAG,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC;YACxD,IAAI,CAAC,UAAU,CAAC,OAAO,EAAE,CAAC;gBACxB,OAAO;oBACL,OAAO,EAAE,KAAK;oBACd,MAAM,EAAE,cAAc;oBACtB,OAAO,EAAE,8BAA8B,IAAI,CAAC,IAAI,CAAC,CAAC,UAAU,CAAC,YAAY,IAAI,CAAC,CAAC,GAAG,IAAI,CAAC,IAAI;iBAC5F,CAAC;YACJ,CAAC;YACD,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,YAAY,CAAC,CAAC;QACrC,CAAC;QAED,QAAQ,MAAM,EAAE,CAAC;YACf,KAAK,MAAM;gBACT,OAAO,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC;YAE3B,KAAK,UAAU;gBACb,OAAO;oBACL,OAAO,EAAE,KAAK;oBACd,MAAM,EAAE,UAAU;oBAClB,OAAO,EAAE,qCAAqC;iBAC/C,CAAC;YAEJ,KAAK,WAAW,CAAC,CAAC,CAAC;gBACjB,MAAM,SAAS,GAAG,MAAM,IAAI,CAAC,cAAc,CAAC,SAAS,CACnD,MAAM,CAAC,SAAS,EAChB,MAAM,CAAC,QAAQ,CAChB,CAAC;gBACF,IAAI,SAAS;oBAAE,OAAO,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC;gBACxC,OAAO;oBACL,OAAO,EAAE,KAAK;oBACd,MAAM,EAAE,aAAa;oBACrB,OAAO,EAAE,gDAAgD;iBAC1D,CAAC;YACJ,CAAC;YAED,KAAK,SAAS,CAAC,CAAC,CAAC;gBACf,MAAM,SAAS,GAAG,MAAM,IAAI,CAAC,cAAc,CAAC,SAAS,CACnD,MAAM,CAAC,SAAS,EAChB,MAAM,CAAC,QAAQ,CAChB,CAAC;gBACF,IAAI,SAAS;oBAAE,OAAO,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC;gBAExC,MAAM,IAAI,GAAG,MAAM,IAAI,CAAC,YAAY,CAAC,SAAS,CAC5C,MAAM,CAAC,SAAS,EAChB,MAAM,CAAC,QAAQ,CAChB,CAAC;gBACF,OAAO;oBACL,OAAO,EAAE,KAAK;oBACd,MAAM,EAAE,kBAAkB;oBAC1B,WAAW,EAAE,IAAI;oBACjB,OAAO,EAAE,MAAM,MAAM,CAAC,UAAU,oEAAoE,IAAI,EAAE;iBAC3G,CAAC;YACJ,CAAC;YAED;gBACE,OAAO;oBACL,OAAO,EAAE,KAAK;oBACd,MAAM,EAAE,UAAU;oBAClB,OAAO,EAAE,sBAAsB;iBAChC,CAAC;QACN,CAAC;IACH,CAAC;CACF"}
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
export interface PairingRequest {
|
|
2
|
+
readonly code: string;
|
|
3
|
+
readonly channelId: string;
|
|
4
|
+
readonly senderId: string;
|
|
5
|
+
readonly createdAt: number;
|
|
6
|
+
readonly expiresAt: number;
|
|
7
|
+
}
|
|
8
|
+
export declare class PairingStore {
|
|
9
|
+
private readonly filePath;
|
|
10
|
+
private readonly ttlMs;
|
|
11
|
+
private readonly codeLength;
|
|
12
|
+
constructor(dataDir: string, ttlMs?: number, codeLength?: number);
|
|
13
|
+
issueCode(channelId: string, senderId: string): Promise<string>;
|
|
14
|
+
approveCode(code: string): Promise<{
|
|
15
|
+
channelId: string;
|
|
16
|
+
senderId: string;
|
|
17
|
+
} | null>;
|
|
18
|
+
listPending(): Promise<PairingRequest[]>;
|
|
19
|
+
revokeCode(code: string): Promise<boolean>;
|
|
20
|
+
private generateCode;
|
|
21
|
+
private pruneExpired;
|
|
22
|
+
private readRequests;
|
|
23
|
+
private writeRequests;
|
|
24
|
+
}
|
|
25
|
+
//# sourceMappingURL=pairing-store.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"pairing-store.d.ts","sourceRoot":"","sources":["../../src/security/pairing-store.ts"],"names":[],"mappings":"AAQA,MAAM,WAAW,cAAc;IAC7B,QAAQ,CAAC,IAAI,EAAE,MAAM,CAAC;IACtB,QAAQ,CAAC,SAAS,EAAE,MAAM,CAAC;IAC3B,QAAQ,CAAC,QAAQ,EAAE,MAAM,CAAC;IAC1B,QAAQ,CAAC,SAAS,EAAE,MAAM,CAAC;IAC3B,QAAQ,CAAC,SAAS,EAAE,MAAM,CAAC;CAC5B;AAED,qBAAa,YAAY;IACvB,OAAO,CAAC,QAAQ,CAAC,QAAQ,CAAS;IAClC,OAAO,CAAC,QAAQ,CAAC,KAAK,CAAS;IAC/B,OAAO,CAAC,QAAQ,CAAC,UAAU,CAAS;gBAExB,OAAO,EAAE,MAAM,EAAE,KAAK,SAAY,EAAE,UAAU,SAAI;IAOxD,SAAS,CAAC,SAAS,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC;IAwB/D,WAAW,CACf,IAAI,EAAE,MAAM,GACX,OAAO,CAAC;QAAE,SAAS,EAAE,MAAM,CAAC;QAAC,QAAQ,EAAE,MAAM,CAAA;KAAE,GAAG,IAAI,CAAC;IAkBpD,WAAW,IAAI,OAAO,CAAC,cAAc,EAAE,CAAC;IAYxC,UAAU,CAAC,IAAI,EAAE,MAAM,GAAG,OAAO,CAAC,OAAO,CAAC;IAYhD,OAAO,CAAC,YAAY;IASpB,OAAO,CAAC,YAAY;YAUN,YAAY;YASZ,aAAa;CAG5B"}
|
|
@@ -0,0 +1,103 @@
|
|
|
1
|
+
import { readFile, writeFile } from "node:fs/promises";
|
|
2
|
+
import { mkdirSync } from "node:fs";
|
|
3
|
+
import { randomBytes } from "node:crypto";
|
|
4
|
+
import { join } from "node:path";
|
|
5
|
+
import { withFileLock } from "../utils/file-lock.js";
|
|
6
|
+
const ALPHABET = "ABCDEFGHJKLMNPQRSTUVWXYZ23456789"; // No 0O1I
|
|
7
|
+
export class PairingStore {
|
|
8
|
+
filePath;
|
|
9
|
+
ttlMs;
|
|
10
|
+
codeLength;
|
|
11
|
+
constructor(dataDir, ttlMs = 3_600_000, codeLength = 8) {
|
|
12
|
+
mkdirSync(dataDir, { recursive: true });
|
|
13
|
+
this.filePath = join(dataDir, "pairing.json");
|
|
14
|
+
this.ttlMs = ttlMs;
|
|
15
|
+
this.codeLength = codeLength;
|
|
16
|
+
}
|
|
17
|
+
async issueCode(channelId, senderId) {
|
|
18
|
+
return withFileLock(this.filePath, async () => {
|
|
19
|
+
const requests = await this.readRequests();
|
|
20
|
+
this.pruneExpired(requests);
|
|
21
|
+
const existing = requests.find((r) => r.channelId === channelId && r.senderId === senderId);
|
|
22
|
+
if (existing)
|
|
23
|
+
return existing.code;
|
|
24
|
+
const code = this.generateCode();
|
|
25
|
+
const now = Date.now();
|
|
26
|
+
requests.push({
|
|
27
|
+
code,
|
|
28
|
+
channelId,
|
|
29
|
+
senderId,
|
|
30
|
+
createdAt: now,
|
|
31
|
+
expiresAt: now + this.ttlMs,
|
|
32
|
+
});
|
|
33
|
+
await this.writeRequests(requests);
|
|
34
|
+
return code;
|
|
35
|
+
});
|
|
36
|
+
}
|
|
37
|
+
async approveCode(code) {
|
|
38
|
+
return withFileLock(this.filePath, async () => {
|
|
39
|
+
const requests = await this.readRequests();
|
|
40
|
+
this.pruneExpired(requests);
|
|
41
|
+
const idx = requests.findIndex((r) => r.code === code.toUpperCase());
|
|
42
|
+
if (idx === -1)
|
|
43
|
+
return null;
|
|
44
|
+
const request = requests[idx];
|
|
45
|
+
const result = { channelId: request.channelId, senderId: request.senderId };
|
|
46
|
+
requests.splice(idx, 1);
|
|
47
|
+
await this.writeRequests(requests);
|
|
48
|
+
return result;
|
|
49
|
+
});
|
|
50
|
+
}
|
|
51
|
+
async listPending() {
|
|
52
|
+
return withFileLock(this.filePath, async () => {
|
|
53
|
+
const requests = await this.readRequests();
|
|
54
|
+
const before = requests.length;
|
|
55
|
+
this.pruneExpired(requests);
|
|
56
|
+
if (requests.length !== before) {
|
|
57
|
+
await this.writeRequests(requests);
|
|
58
|
+
}
|
|
59
|
+
return [...requests];
|
|
60
|
+
});
|
|
61
|
+
}
|
|
62
|
+
async revokeCode(code) {
|
|
63
|
+
return withFileLock(this.filePath, async () => {
|
|
64
|
+
const requests = await this.readRequests();
|
|
65
|
+
const idx = requests.findIndex((r) => r.code === code.toUpperCase());
|
|
66
|
+
if (idx === -1)
|
|
67
|
+
return false;
|
|
68
|
+
requests.splice(idx, 1);
|
|
69
|
+
await this.writeRequests(requests);
|
|
70
|
+
return true;
|
|
71
|
+
});
|
|
72
|
+
}
|
|
73
|
+
generateCode() {
|
|
74
|
+
const bytes = randomBytes(this.codeLength);
|
|
75
|
+
let code = "";
|
|
76
|
+
for (let i = 0; i < this.codeLength; i++) {
|
|
77
|
+
code += ALPHABET[bytes[i] % ALPHABET.length];
|
|
78
|
+
}
|
|
79
|
+
return code;
|
|
80
|
+
}
|
|
81
|
+
pruneExpired(requests) {
|
|
82
|
+
const now = Date.now();
|
|
83
|
+
let i = requests.length;
|
|
84
|
+
while (i--) {
|
|
85
|
+
if (requests[i].expiresAt <= now) {
|
|
86
|
+
requests.splice(i, 1);
|
|
87
|
+
}
|
|
88
|
+
}
|
|
89
|
+
}
|
|
90
|
+
async readRequests() {
|
|
91
|
+
try {
|
|
92
|
+
const raw = await readFile(this.filePath, "utf-8");
|
|
93
|
+
return JSON.parse(raw);
|
|
94
|
+
}
|
|
95
|
+
catch {
|
|
96
|
+
return [];
|
|
97
|
+
}
|
|
98
|
+
}
|
|
99
|
+
async writeRequests(requests) {
|
|
100
|
+
await writeFile(this.filePath, JSON.stringify(requests, null, 2));
|
|
101
|
+
}
|
|
102
|
+
}
|
|
103
|
+
//# sourceMappingURL=pairing-store.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"pairing-store.js","sourceRoot":"","sources":["../../src/security/pairing-store.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
export interface RateLimitConfig {
|
|
2
|
+
readonly perMinute: number;
|
|
3
|
+
readonly perHour: number;
|
|
4
|
+
}
|
|
5
|
+
export interface RateLimitResult {
|
|
6
|
+
readonly allowed: boolean;
|
|
7
|
+
readonly retryAfterMs?: number;
|
|
8
|
+
}
|
|
9
|
+
export declare class RateLimiter {
|
|
10
|
+
private readonly config;
|
|
11
|
+
private readonly windows;
|
|
12
|
+
constructor(config: RateLimitConfig);
|
|
13
|
+
check(key: string): RateLimitResult;
|
|
14
|
+
hit(key: string): void;
|
|
15
|
+
private getTimestamps;
|
|
16
|
+
}
|
|
17
|
+
//# sourceMappingURL=rate-limiter.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"rate-limiter.d.ts","sourceRoot":"","sources":["../../src/security/rate-limiter.ts"],"names":[],"mappings":"AAAA,MAAM,WAAW,eAAe;IAC9B,QAAQ,CAAC,SAAS,EAAE,MAAM,CAAC;IAC3B,QAAQ,CAAC,OAAO,EAAE,MAAM,CAAC;CAC1B;AAED,MAAM,WAAW,eAAe;IAC9B,QAAQ,CAAC,OAAO,EAAE,OAAO,CAAC;IAC1B,QAAQ,CAAC,YAAY,CAAC,EAAE,MAAM,CAAC;CAChC;AAED,qBAAa,WAAW;IAGV,OAAO,CAAC,QAAQ,CAAC,MAAM;IAFnC,OAAO,CAAC,QAAQ,CAAC,OAAO,CAA+B;gBAE1B,MAAM,EAAE,eAAe;IAEpD,KAAK,CAAC,GAAG,EAAE,MAAM,GAAG,eAAe;IAsBnC,GAAG,CAAC,GAAG,EAAE,MAAM,GAAG,IAAI;IAOtB,OAAO,CAAC,aAAa;CAWtB"}
|
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
export class RateLimiter {
|
|
2
|
+
config;
|
|
3
|
+
windows = new Map();
|
|
4
|
+
constructor(config) {
|
|
5
|
+
this.config = config;
|
|
6
|
+
}
|
|
7
|
+
check(key) {
|
|
8
|
+
const now = Date.now();
|
|
9
|
+
const timestamps = this.getTimestamps(key, now);
|
|
10
|
+
const oneMinuteAgo = now - 60_000;
|
|
11
|
+
const oneHourAgo = now - 3_600_000;
|
|
12
|
+
const minuteCount = timestamps.filter((t) => t > oneMinuteAgo).length;
|
|
13
|
+
if (minuteCount >= this.config.perMinute) {
|
|
14
|
+
const oldest = timestamps.find((t) => t > oneMinuteAgo);
|
|
15
|
+
return { allowed: false, retryAfterMs: oldest + 60_000 - now };
|
|
16
|
+
}
|
|
17
|
+
const hourCount = timestamps.filter((t) => t > oneHourAgo).length;
|
|
18
|
+
if (hourCount >= this.config.perHour) {
|
|
19
|
+
const oldest = timestamps.find((t) => t > oneHourAgo);
|
|
20
|
+
return { allowed: false, retryAfterMs: oldest + 3_600_000 - now };
|
|
21
|
+
}
|
|
22
|
+
return { allowed: true };
|
|
23
|
+
}
|
|
24
|
+
hit(key) {
|
|
25
|
+
const now = Date.now();
|
|
26
|
+
const timestamps = this.getTimestamps(key, now);
|
|
27
|
+
timestamps.push(now);
|
|
28
|
+
this.windows.set(key, timestamps);
|
|
29
|
+
}
|
|
30
|
+
getTimestamps(key, now) {
|
|
31
|
+
const existing = this.windows.get(key) ?? [];
|
|
32
|
+
const oneHourAgo = now - 3_600_000;
|
|
33
|
+
const pruned = existing.filter((t) => t > oneHourAgo);
|
|
34
|
+
if (pruned.length === 0) {
|
|
35
|
+
this.windows.delete(key);
|
|
36
|
+
}
|
|
37
|
+
else {
|
|
38
|
+
this.windows.set(key, pruned);
|
|
39
|
+
}
|
|
40
|
+
return pruned;
|
|
41
|
+
}
|
|
42
|
+
}
|
|
43
|
+
//# sourceMappingURL=rate-limiter.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"rate-limiter.js","sourceRoot":"","sources":["../../src/security/rate-limiter.ts"],"names":[],"mappings":"AAUA,MAAM,OAAO,WAAW;IAGO;IAFZ,OAAO,GAAG,IAAI,GAAG,EAAoB,CAAC;IAEvD,YAA6B,MAAuB;QAAvB,WAAM,GAAN,MAAM,CAAiB;IAAG,CAAC;IAExD,KAAK,CAAC,GAAW;QACf,MAAM,GAAG,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;QACvB,MAAM,UAAU,GAAG,IAAI,CAAC,aAAa,CAAC,GAAG,EAAE,GAAG,CAAC,CAAC;QAEhD,MAAM,YAAY,GAAG,GAAG,GAAG,MAAM,CAAC;QAClC,MAAM,UAAU,GAAG,GAAG,GAAG,SAAS,CAAC;QAEnC,MAAM,WAAW,GAAG,UAAU,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,GAAG,YAAY,CAAC,CAAC,MAAM,CAAC;QACtE,IAAI,WAAW,IAAI,IAAI,CAAC,MAAM,CAAC,SAAS,EAAE,CAAC;YACzC,MAAM,MAAM,GAAG,UAAU,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,GAAG,YAAY,CAAE,CAAC;YACzD,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE,YAAY,EAAE,MAAM,GAAG,MAAM,GAAG,GAAG,EAAE,CAAC;QACjE,CAAC;QAED,MAAM,SAAS,GAAG,UAAU,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,GAAG,UAAU,CAAC,CAAC,MAAM,CAAC;QAClE,IAAI,SAAS,IAAI,IAAI,CAAC,MAAM,CAAC,OAAO,EAAE,CAAC;YACrC,MAAM,MAAM,GAAG,UAAU,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,GAAG,UAAU,CAAE,CAAC;YACvD,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE,YAAY,EAAE,MAAM,GAAG,SAAS,GAAG,GAAG,EAAE,CAAC;QACpE,CAAC;QAED,OAAO,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC;IAC3B,CAAC;IAED,GAAG,CAAC,GAAW;QACb,MAAM,GAAG,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;QACvB,MAAM,UAAU,GAAG,IAAI,CAAC,aAAa,CAAC,GAAG,EAAE,GAAG,CAAC,CAAC;QAChD,UAAU,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;QACrB,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,GAAG,EAAE,UAAU,CAAC,CAAC;IACpC,CAAC;IAEO,aAAa,CAAC,GAAW,EAAE,GAAW;QAC5C,MAAM,QAAQ,GAAG,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,GAAG,CAAC,IAAI,EAAE,CAAC;QAC7C,MAAM,UAAU,GAAG,GAAG,GAAG,SAAS,CAAC;QACnC,MAAM,MAAM,GAAG,QAAQ,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,GAAG,UAAU,CAAC,CAAC;QACtD,IAAI,MAAM,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;YACxB,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC;QAC3B,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,GAAG,EAAE,MAAM,CAAC,CAAC;QAChC,CAAC;QACD,OAAO,MAAM,CAAC;IAChB,CAAC;CACF"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"scan-rules.d.ts","sourceRoot":"","sources":["../../src/security/scan-rules.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,iBAAiB,CAAC;AAEhD,eAAO,MAAM,UAAU,EAAE,SAAS,QAAQ,EA6EhC,CAAC"}
|
|
@@ -0,0 +1,79 @@
|
|
|
1
|
+
export const SCAN_RULES = [
|
|
2
|
+
{
|
|
3
|
+
id: "dangerous-exec",
|
|
4
|
+
severity: "critical",
|
|
5
|
+
description: "Shell command execution detected",
|
|
6
|
+
type: "line",
|
|
7
|
+
pattern: /\b(exec|execSync|spawn|spawnSync|execFile)\s*\(/,
|
|
8
|
+
context: /child_process/,
|
|
9
|
+
contextType: "import",
|
|
10
|
+
},
|
|
11
|
+
{
|
|
12
|
+
id: "dynamic-eval",
|
|
13
|
+
severity: "critical",
|
|
14
|
+
description: "Dynamic code execution (eval/Function constructor)",
|
|
15
|
+
type: "line",
|
|
16
|
+
pattern: /\beval\s*\(|new\s+Function\s*\(/,
|
|
17
|
+
},
|
|
18
|
+
{
|
|
19
|
+
id: "crypto-mining",
|
|
20
|
+
severity: "critical",
|
|
21
|
+
description: "Cryptocurrency mining signatures",
|
|
22
|
+
type: "line",
|
|
23
|
+
pattern: /stratum\+tcp|coinhive|cryptonight|xmrig/i,
|
|
24
|
+
},
|
|
25
|
+
{
|
|
26
|
+
id: "env-harvesting",
|
|
27
|
+
severity: "critical",
|
|
28
|
+
description: "Environment variables accessed near network calls",
|
|
29
|
+
type: "source",
|
|
30
|
+
pattern: /process\.env/,
|
|
31
|
+
context: /\bfetch\b|http\.request|https\.request|axios\b|got\(/,
|
|
32
|
+
contextType: "source",
|
|
33
|
+
},
|
|
34
|
+
{
|
|
35
|
+
id: "data-exfiltration",
|
|
36
|
+
severity: "warn",
|
|
37
|
+
description: "File read combined with network request",
|
|
38
|
+
type: "source",
|
|
39
|
+
pattern: /readFileSync|readFile|createReadStream/,
|
|
40
|
+
context: /\bfetch\b|http\.request|https\.request/,
|
|
41
|
+
contextType: "source",
|
|
42
|
+
},
|
|
43
|
+
{
|
|
44
|
+
id: "obfuscated-code",
|
|
45
|
+
severity: "warn",
|
|
46
|
+
description: "Obfuscated code detected (hex/base64 sequences)",
|
|
47
|
+
type: "line",
|
|
48
|
+
pattern: /(\\x[0-9a-fA-F]{2}){6,}|atob\s*\(.*[A-Za-z0-9+/=]{200,}/,
|
|
49
|
+
},
|
|
50
|
+
{
|
|
51
|
+
id: "suspicious-network",
|
|
52
|
+
severity: "warn",
|
|
53
|
+
description: "WebSocket connection to non-standard port",
|
|
54
|
+
type: "line",
|
|
55
|
+
pattern: /new\s+WebSocket\s*\(\s*['"`]wss?:\/\/[^'"]*:\d{4,5}/,
|
|
56
|
+
},
|
|
57
|
+
{
|
|
58
|
+
id: "global-override",
|
|
59
|
+
severity: "warn",
|
|
60
|
+
description: "Global object or prototype manipulation",
|
|
61
|
+
type: "line",
|
|
62
|
+
pattern: /globalThis\s*[.[=]|Object\.defineProperty\s*\(\s*global/,
|
|
63
|
+
},
|
|
64
|
+
{
|
|
65
|
+
id: "fs-write",
|
|
66
|
+
severity: "info",
|
|
67
|
+
description: "Filesystem write operations",
|
|
68
|
+
type: "line",
|
|
69
|
+
pattern: /writeFileSync|writeFile|appendFile|createWriteStream/,
|
|
70
|
+
},
|
|
71
|
+
{
|
|
72
|
+
id: "dns-lookup",
|
|
73
|
+
severity: "info",
|
|
74
|
+
description: "DNS resolution calls",
|
|
75
|
+
type: "line",
|
|
76
|
+
pattern: /dns\.resolve|dns\.lookup|dns\.reverse/,
|
|
77
|
+
},
|
|
78
|
+
];
|
|
79
|
+
//# sourceMappingURL=scan-rules.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"scan-rules.js","sourceRoot":"","sources":["../../src/security/scan-rules.ts"],"names":[],"mappings":"AAEA,MAAM,CAAC,MAAM,UAAU,GAAwB;IAC7C;QACE,EAAE,EAAE,gBAAgB;QACpB,QAAQ,EAAE,UAAU;QACpB,WAAW,EAAE,kCAAkC;QAC/C,IAAI,EAAE,MAAM;QACZ,OAAO,EAAE,iDAAiD;QAC1D,OAAO,EAAE,eAAe;QACxB,WAAW,EAAE,QAAQ;KACtB;IACD;QACE,EAAE,EAAE,cAAc;QAClB,QAAQ,EAAE,UAAU;QACpB,WAAW,EAAE,oDAAoD;QACjE,IAAI,EAAE,MAAM;QACZ,OAAO,EAAE,iCAAiC;KAC3C;IACD;QACE,EAAE,EAAE,eAAe;QACnB,QAAQ,EAAE,UAAU;QACpB,WAAW,EAAE,kCAAkC;QAC/C,IAAI,EAAE,MAAM;QACZ,OAAO,EAAE,0CAA0C;KACpD;IACD;QACE,EAAE,EAAE,gBAAgB;QACpB,QAAQ,EAAE,UAAU;QACpB,WAAW,EAAE,mDAAmD;QAChE,IAAI,EAAE,QAAQ;QACd,OAAO,EAAE,cAAc;QACvB,OAAO,EAAE,sDAAsD;QAC/D,WAAW,EAAE,QAAQ;KACtB;IACD;QACE,EAAE,EAAE,mBAAmB;QACvB,QAAQ,EAAE,MAAM;QAChB,WAAW,EAAE,yCAAyC;QACtD,IAAI,EAAE,QAAQ;QACd,OAAO,EAAE,wCAAwC;QACjD,OAAO,EAAE,wCAAwC;QACjD,WAAW,EAAE,QAAQ;KACtB;IACD;QACE,EAAE,EAAE,iBAAiB;QACrB,QAAQ,EAAE,MAAM;QAChB,WAAW,EAAE,iDAAiD;QAC9D,IAAI,EAAE,MAAM;QACZ,OAAO,EAAE,yDAAyD;KACnE;IACD;QACE,EAAE,EAAE,oBAAoB;QACxB,QAAQ,EAAE,MAAM;QAChB,WAAW,EAAE,2CAA2C;QACxD,IAAI,EAAE,MAAM;QACZ,OAAO,EAAE,qDAAqD;KAC/D;IACD;QACE,EAAE,EAAE,iBAAiB;QACrB,QAAQ,EAAE,MAAM;QAChB,WAAW,EAAE,yCAAyC;QACtD,IAAI,EAAE,MAAM;QACZ,OAAO,EAAE,yDAAyD;KACnE;IACD;QACE,EAAE,EAAE,UAAU;QACd,QAAQ,EAAE,MAAM;QAChB,WAAW,EAAE,6BAA6B;QAC1C,IAAI,EAAE,MAAM;QACZ,OAAO,EAAE,sDAAsD;KAChE;IACD;QACE,EAAE,EAAE,YAAY;QAChB,QAAQ,EAAE,MAAM;QAChB,WAAW,EAAE,sBAAsB;QACnC,IAAI,EAAE,MAAM;QACZ,OAAO,EAAE,uCAAuC;KACjD;CACO,CAAC"}
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
export type ScanSeverity = "critical" | "warn" | "info";
|
|
2
|
+
export interface ScanRule {
|
|
3
|
+
readonly id: string;
|
|
4
|
+
readonly severity: ScanSeverity;
|
|
5
|
+
readonly description: string;
|
|
6
|
+
readonly type: "line" | "source";
|
|
7
|
+
readonly pattern: RegExp;
|
|
8
|
+
readonly context?: RegExp;
|
|
9
|
+
readonly contextType?: "import" | "source";
|
|
10
|
+
}
|
|
11
|
+
export interface ScanFinding {
|
|
12
|
+
readonly ruleId: string;
|
|
13
|
+
readonly severity: ScanSeverity;
|
|
14
|
+
readonly file: string;
|
|
15
|
+
readonly line: number;
|
|
16
|
+
readonly message: string;
|
|
17
|
+
readonly evidence: string;
|
|
18
|
+
}
|
|
19
|
+
export interface ScanResult {
|
|
20
|
+
readonly safe: boolean;
|
|
21
|
+
readonly scannedFiles: number;
|
|
22
|
+
readonly findings: ScanFinding[];
|
|
23
|
+
readonly critical: number;
|
|
24
|
+
readonly warn: number;
|
|
25
|
+
readonly info: number;
|
|
26
|
+
}
|
|
27
|
+
//# sourceMappingURL=scan-types.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"scan-types.d.ts","sourceRoot":"","sources":["../../src/security/scan-types.ts"],"names":[],"mappings":"AAAA,MAAM,MAAM,YAAY,GAAG,UAAU,GAAG,MAAM,GAAG,MAAM,CAAC;AAExD,MAAM,WAAW,QAAQ;IACvB,QAAQ,CAAC,EAAE,EAAE,MAAM,CAAC;IACpB,QAAQ,CAAC,QAAQ,EAAE,YAAY,CAAC;IAChC,QAAQ,CAAC,WAAW,EAAE,MAAM,CAAC;IAC7B,QAAQ,CAAC,IAAI,EAAE,MAAM,GAAG,QAAQ,CAAC;IACjC,QAAQ,CAAC,OAAO,EAAE,MAAM,CAAC;IACzB,QAAQ,CAAC,OAAO,CAAC,EAAE,MAAM,CAAC;IAC1B,QAAQ,CAAC,WAAW,CAAC,EAAE,QAAQ,GAAG,QAAQ,CAAC;CAC5C;AAED,MAAM,WAAW,WAAW;IAC1B,QAAQ,CAAC,MAAM,EAAE,MAAM,CAAC;IACxB,QAAQ,CAAC,QAAQ,EAAE,YAAY,CAAC;IAChC,QAAQ,CAAC,IAAI,EAAE,MAAM,CAAC;IACtB,QAAQ,CAAC,IAAI,EAAE,MAAM,CAAC;IACtB,QAAQ,CAAC,OAAO,EAAE,MAAM,CAAC;IACzB,QAAQ,CAAC,QAAQ,EAAE,MAAM,CAAC;CAC3B;AAED,MAAM,WAAW,UAAU;IACzB,QAAQ,CAAC,IAAI,EAAE,OAAO,CAAC;IACvB,QAAQ,CAAC,YAAY,EAAE,MAAM,CAAC;IAC9B,QAAQ,CAAC,QAAQ,EAAE,WAAW,EAAE,CAAC;IACjC,QAAQ,CAAC,QAAQ,EAAE,MAAM,CAAC;IAC1B,QAAQ,CAAC,IAAI,EAAE,MAAM,CAAC;IACtB,QAAQ,CAAC,IAAI,EAAE,MAAM,CAAC;CACvB"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"scan-types.js","sourceRoot":"","sources":["../../src/security/scan-types.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import type { ScanFinding, ScanResult } from "./scan-types.js";
|
|
2
|
+
export declare class SecurityScanner {
|
|
3
|
+
scanSource(source: string, filePath: string): ScanFinding[];
|
|
4
|
+
buildResult(findings: ScanFinding[], scannedFiles: number): ScanResult;
|
|
5
|
+
scanDirectory(dir: string): Promise<ScanResult>;
|
|
6
|
+
private discoverFiles;
|
|
7
|
+
}
|
|
8
|
+
//# sourceMappingURL=scanner.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"scanner.d.ts","sourceRoot":"","sources":["../../src/security/scanner.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAAE,WAAW,EAAE,UAAU,EAAE,MAAM,iBAAiB,CAAC;AAM/D,qBAAa,eAAe;IAC1B,UAAU,CAAC,MAAM,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,GAAG,WAAW,EAAE;IAsD3D,WAAW,CAAC,QAAQ,EAAE,WAAW,EAAE,EAAE,YAAY,EAAE,MAAM,GAAG,UAAU;IAOhE,aAAa,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,CAAC,UAAU,CAAC;YAcvC,aAAa;CAgB5B"}
|
|
@@ -0,0 +1,105 @@
|
|
|
1
|
+
import { readdir, readFile, stat } from "node:fs/promises";
|
|
2
|
+
import { join, extname } from "node:path";
|
|
3
|
+
import { SCAN_RULES } from "./scan-rules.js";
|
|
4
|
+
const SCANNABLE_EXTENSIONS = new Set([".ts", ".js", ".tsx", ".jsx", ".mjs", ".cjs"]);
|
|
5
|
+
const MAX_FILE_SIZE = 1_048_576; // 1MB
|
|
6
|
+
const MAX_FILES = 500;
|
|
7
|
+
export class SecurityScanner {
|
|
8
|
+
scanSource(source, filePath) {
|
|
9
|
+
const findings = [];
|
|
10
|
+
const lines = source.split("\n");
|
|
11
|
+
const matchedRules = new Set();
|
|
12
|
+
// Line rules
|
|
13
|
+
for (const rule of SCAN_RULES) {
|
|
14
|
+
if (rule.type !== "line" || matchedRules.has(rule.id))
|
|
15
|
+
continue;
|
|
16
|
+
if (rule.context && rule.contextType === "import" && !rule.context.test(source))
|
|
17
|
+
continue;
|
|
18
|
+
for (let i = 0; i < lines.length; i++) {
|
|
19
|
+
if (rule.pattern.test(lines[i])) {
|
|
20
|
+
findings.push({
|
|
21
|
+
ruleId: rule.id,
|
|
22
|
+
severity: rule.severity,
|
|
23
|
+
file: filePath,
|
|
24
|
+
line: i + 1,
|
|
25
|
+
message: rule.description,
|
|
26
|
+
evidence: lines[i].trim().slice(0, 200),
|
|
27
|
+
});
|
|
28
|
+
matchedRules.add(rule.id);
|
|
29
|
+
break;
|
|
30
|
+
}
|
|
31
|
+
}
|
|
32
|
+
}
|
|
33
|
+
// Source rules
|
|
34
|
+
for (const rule of SCAN_RULES) {
|
|
35
|
+
if (rule.type !== "source" || matchedRules.has(rule.id))
|
|
36
|
+
continue;
|
|
37
|
+
if (!rule.pattern.test(source))
|
|
38
|
+
continue;
|
|
39
|
+
if (rule.context && !rule.context.test(source))
|
|
40
|
+
continue;
|
|
41
|
+
// Find first matching line for evidence
|
|
42
|
+
let evidenceLine = 1;
|
|
43
|
+
let evidence = "";
|
|
44
|
+
for (let i = 0; i < lines.length; i++) {
|
|
45
|
+
if (rule.pattern.test(lines[i])) {
|
|
46
|
+
evidenceLine = i + 1;
|
|
47
|
+
evidence = lines[i].trim().slice(0, 200);
|
|
48
|
+
break;
|
|
49
|
+
}
|
|
50
|
+
}
|
|
51
|
+
findings.push({
|
|
52
|
+
ruleId: rule.id,
|
|
53
|
+
severity: rule.severity,
|
|
54
|
+
file: filePath,
|
|
55
|
+
line: evidenceLine,
|
|
56
|
+
message: rule.description,
|
|
57
|
+
evidence,
|
|
58
|
+
});
|
|
59
|
+
matchedRules.add(rule.id);
|
|
60
|
+
}
|
|
61
|
+
return findings;
|
|
62
|
+
}
|
|
63
|
+
buildResult(findings, scannedFiles) {
|
|
64
|
+
const critical = findings.filter((f) => f.severity === "critical").length;
|
|
65
|
+
const warn = findings.filter((f) => f.severity === "warn").length;
|
|
66
|
+
const info = findings.filter((f) => f.severity === "info").length;
|
|
67
|
+
return { safe: critical === 0, scannedFiles, findings, critical, warn, info };
|
|
68
|
+
}
|
|
69
|
+
async scanDirectory(dir) {
|
|
70
|
+
const files = await this.discoverFiles(dir);
|
|
71
|
+
const allFindings = [];
|
|
72
|
+
for (const file of files) {
|
|
73
|
+
try {
|
|
74
|
+
const source = await readFile(file, "utf-8");
|
|
75
|
+
allFindings.push(...this.scanSource(source, file));
|
|
76
|
+
}
|
|
77
|
+
catch {
|
|
78
|
+
// Skip unreadable files
|
|
79
|
+
}
|
|
80
|
+
}
|
|
81
|
+
return this.buildResult(allFindings, files.length);
|
|
82
|
+
}
|
|
83
|
+
async discoverFiles(dir, collected = []) {
|
|
84
|
+
if (collected.length >= MAX_FILES)
|
|
85
|
+
return collected;
|
|
86
|
+
const entries = await readdir(dir, { withFileTypes: true });
|
|
87
|
+
for (const entry of entries) {
|
|
88
|
+
if (collected.length >= MAX_FILES)
|
|
89
|
+
break;
|
|
90
|
+
if (entry.name.startsWith(".") || entry.name === "node_modules")
|
|
91
|
+
continue;
|
|
92
|
+
const full = join(dir, entry.name);
|
|
93
|
+
if (entry.isDirectory()) {
|
|
94
|
+
await this.discoverFiles(full, collected);
|
|
95
|
+
}
|
|
96
|
+
else if (SCANNABLE_EXTENSIONS.has(extname(entry.name))) {
|
|
97
|
+
const s = await stat(full);
|
|
98
|
+
if (s.size <= MAX_FILE_SIZE)
|
|
99
|
+
collected.push(full);
|
|
100
|
+
}
|
|
101
|
+
}
|
|
102
|
+
return collected;
|
|
103
|
+
}
|
|
104
|
+
}
|
|
105
|
+
//# sourceMappingURL=scanner.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"scanner.js","sourceRoot":"","sources":["../../src/security/scanner.ts"],"names":[],"mappings":"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"}
|