@oni.bot/core 1.0.0 → 1.0.1
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/package.json +1 -1
- package/dist/oni-code/agent-registry.d.ts +0 -73
- package/dist/oni-code/agent-registry.d.ts.map +0 -1
- package/dist/oni-code/agent-registry.js +0 -151
- package/dist/oni-code/agent-registry.js.map +0 -1
- package/dist/oni-code/bin.d.ts +0 -18
- package/dist/oni-code/bin.d.ts.map +0 -1
- package/dist/oni-code/bin.js +0 -78
- package/dist/oni-code/bin.js.map +0 -1
- package/dist/oni-code/change-tracking.d.ts +0 -28
- package/dist/oni-code/change-tracking.d.ts.map +0 -1
- package/dist/oni-code/change-tracking.js +0 -77
- package/dist/oni-code/change-tracking.js.map +0 -1
- package/dist/oni-code/cli.d.ts +0 -6
- package/dist/oni-code/cli.d.ts.map +0 -1
- package/dist/oni-code/cli.js +0 -30
- package/dist/oni-code/cli.js.map +0 -1
- package/dist/oni-code/conductor.d.ts +0 -203
- package/dist/oni-code/conductor.d.ts.map +0 -1
- package/dist/oni-code/conductor.js +0 -1547
- package/dist/oni-code/conductor.js.map +0 -1
- package/dist/oni-code/config.d.ts +0 -130
- package/dist/oni-code/config.d.ts.map +0 -1
- package/dist/oni-code/config.js +0 -264
- package/dist/oni-code/config.js.map +0 -1
- package/dist/oni-code/context-files.d.ts +0 -22
- package/dist/oni-code/context-files.d.ts.map +0 -1
- package/dist/oni-code/context-files.js +0 -156
- package/dist/oni-code/context-files.js.map +0 -1
- package/dist/oni-code/cron/humanize.d.ts +0 -26
- package/dist/oni-code/cron/humanize.d.ts.map +0 -1
- package/dist/oni-code/cron/humanize.js +0 -83
- package/dist/oni-code/cron/humanize.js.map +0 -1
- package/dist/oni-code/cron/index.d.ts +0 -10
- package/dist/oni-code/cron/index.d.ts.map +0 -1
- package/dist/oni-code/cron/index.js +0 -7
- package/dist/oni-code/cron/index.js.map +0 -1
- package/dist/oni-code/cron/matcher.d.ts +0 -29
- package/dist/oni-code/cron/matcher.d.ts.map +0 -1
- package/dist/oni-code/cron/matcher.js +0 -73
- package/dist/oni-code/cron/matcher.js.map +0 -1
- package/dist/oni-code/cron/parser.d.ts +0 -27
- package/dist/oni-code/cron/parser.d.ts.map +0 -1
- package/dist/oni-code/cron/parser.js +0 -149
- package/dist/oni-code/cron/parser.js.map +0 -1
- package/dist/oni-code/cron/persistence.d.ts +0 -21
- package/dist/oni-code/cron/persistence.d.ts.map +0 -1
- package/dist/oni-code/cron/persistence.js +0 -58
- package/dist/oni-code/cron/persistence.js.map +0 -1
- package/dist/oni-code/cron/scheduler.d.ts +0 -64
- package/dist/oni-code/cron/scheduler.d.ts.map +0 -1
- package/dist/oni-code/cron/scheduler.js +0 -188
- package/dist/oni-code/cron/scheduler.js.map +0 -1
- package/dist/oni-code/cron/store.d.ts +0 -46
- package/dist/oni-code/cron/store.d.ts.map +0 -1
- package/dist/oni-code/cron/store.js +0 -68
- package/dist/oni-code/cron/store.js.map +0 -1
- package/dist/oni-code/env.d.ts +0 -17
- package/dist/oni-code/env.d.ts.map +0 -1
- package/dist/oni-code/env.js +0 -51
- package/dist/oni-code/env.js.map +0 -1
- package/dist/oni-code/file-reader.d.ts +0 -28
- package/dist/oni-code/file-reader.d.ts.map +0 -1
- package/dist/oni-code/file-reader.js +0 -368
- package/dist/oni-code/file-reader.js.map +0 -1
- package/dist/oni-code/file-watcher.d.ts +0 -66
- package/dist/oni-code/file-watcher.d.ts.map +0 -1
- package/dist/oni-code/file-watcher.js +0 -167
- package/dist/oni-code/file-watcher.js.map +0 -1
- package/dist/oni-code/loop-detector.d.ts +0 -64
- package/dist/oni-code/loop-detector.d.ts.map +0 -1
- package/dist/oni-code/loop-detector.js +0 -163
- package/dist/oni-code/loop-detector.js.map +0 -1
- package/dist/oni-code/permissions.d.ts +0 -43
- package/dist/oni-code/permissions.d.ts.map +0 -1
- package/dist/oni-code/permissions.js +0 -98
- package/dist/oni-code/permissions.js.map +0 -1
- package/dist/oni-code/planner.d.ts +0 -26
- package/dist/oni-code/planner.d.ts.map +0 -1
- package/dist/oni-code/planner.js +0 -86
- package/dist/oni-code/planner.js.map +0 -1
- package/dist/oni-code/plugin-loader.d.ts +0 -103
- package/dist/oni-code/plugin-loader.d.ts.map +0 -1
- package/dist/oni-code/plugin-loader.js +0 -171
- package/dist/oni-code/plugin-loader.js.map +0 -1
- package/dist/oni-code/process-tree.d.ts +0 -44
- package/dist/oni-code/process-tree.d.ts.map +0 -1
- package/dist/oni-code/process-tree.js +0 -107
- package/dist/oni-code/process-tree.js.map +0 -1
- package/dist/oni-code/progress-tracker.d.ts +0 -40
- package/dist/oni-code/progress-tracker.d.ts.map +0 -1
- package/dist/oni-code/progress-tracker.js +0 -375
- package/dist/oni-code/progress-tracker.js.map +0 -1
- package/dist/oni-code/scheduler.d.ts +0 -56
- package/dist/oni-code/scheduler.d.ts.map +0 -1
- package/dist/oni-code/scheduler.js +0 -105
- package/dist/oni-code/scheduler.js.map +0 -1
- package/dist/oni-code/session-fork.d.ts +0 -146
- package/dist/oni-code/session-fork.d.ts.map +0 -1
- package/dist/oni-code/session-fork.js +0 -238
- package/dist/oni-code/session-fork.js.map +0 -1
- package/dist/oni-code/session-stats.d.ts +0 -72
- package/dist/oni-code/session-stats.d.ts.map +0 -1
- package/dist/oni-code/session-stats.js +0 -141
- package/dist/oni-code/session-stats.js.map +0 -1
- package/dist/oni-code/session-title.d.ts +0 -25
- package/dist/oni-code/session-title.d.ts.map +0 -1
- package/dist/oni-code/session-title.js +0 -67
- package/dist/oni-code/session-title.js.map +0 -1
- package/dist/oni-code/shell-parser.d.ts +0 -112
- package/dist/oni-code/shell-parser.d.ts.map +0 -1
- package/dist/oni-code/shell-parser.js +0 -657
- package/dist/oni-code/shell-parser.js.map +0 -1
- package/dist/oni-code/summarizer.d.ts +0 -27
- package/dist/oni-code/summarizer.d.ts.map +0 -1
- package/dist/oni-code/summarizer.js +0 -70
- package/dist/oni-code/summarizer.js.map +0 -1
- package/dist/oni-code/swarm-checkpoint.d.ts +0 -52
- package/dist/oni-code/swarm-checkpoint.d.ts.map +0 -1
- package/dist/oni-code/swarm-checkpoint.js +0 -71
- package/dist/oni-code/swarm-checkpoint.js.map +0 -1
- package/dist/oni-code/swarm-runner.d.ts +0 -173
- package/dist/oni-code/swarm-runner.d.ts.map +0 -1
- package/dist/oni-code/swarm-runner.js +0 -873
- package/dist/oni-code/swarm-runner.js.map +0 -1
- package/dist/oni-code/system-prompt.d.ts +0 -13
- package/dist/oni-code/system-prompt.d.ts.map +0 -1
- package/dist/oni-code/system-prompt.js +0 -64
- package/dist/oni-code/system-prompt.js.map +0 -1
- package/dist/oni-code/task-evaluator.d.ts +0 -73
- package/dist/oni-code/task-evaluator.d.ts.map +0 -1
- package/dist/oni-code/task-evaluator.js +0 -172
- package/dist/oni-code/task-evaluator.js.map +0 -1
- package/dist/oni-code/tools/batch.d.ts +0 -12
- package/dist/oni-code/tools/batch.d.ts.map +0 -1
- package/dist/oni-code/tools/batch.js +0 -116
- package/dist/oni-code/tools/batch.js.map +0 -1
- package/dist/oni-code/tools/coding.d.ts +0 -10
- package/dist/oni-code/tools/coding.d.ts.map +0 -1
- package/dist/oni-code/tools/coding.js +0 -557
- package/dist/oni-code/tools/coding.js.map +0 -1
- package/dist/oni-code/tools/cron.d.ts +0 -4
- package/dist/oni-code/tools/cron.d.ts.map +0 -1
- package/dist/oni-code/tools/cron.js +0 -120
- package/dist/oni-code/tools/cron.js.map +0 -1
- package/dist/oni-code/tools/custom.d.ts +0 -43
- package/dist/oni-code/tools/custom.d.ts.map +0 -1
- package/dist/oni-code/tools/custom.js +0 -115
- package/dist/oni-code/tools/custom.js.map +0 -1
- package/dist/oni-code/tools/patch.d.ts +0 -58
- package/dist/oni-code/tools/patch.d.ts.map +0 -1
- package/dist/oni-code/tools/patch.js +0 -247
- package/dist/oni-code/tools/patch.js.map +0 -1
- package/dist/oni-code/tools/plan.d.ts +0 -17
- package/dist/oni-code/tools/plan.d.ts.map +0 -1
- package/dist/oni-code/tools/plan.js +0 -48
- package/dist/oni-code/tools/plan.js.map +0 -1
- package/dist/oni-code/tools/question.d.ts +0 -17
- package/dist/oni-code/tools/question.d.ts.map +0 -1
- package/dist/oni-code/tools/question.js +0 -46
- package/dist/oni-code/tools/question.js.map +0 -1
- package/dist/oni-code/tools/skill.d.ts +0 -36
- package/dist/oni-code/tools/skill.d.ts.map +0 -1
- package/dist/oni-code/tools/skill.js +0 -132
- package/dist/oni-code/tools/skill.js.map +0 -1
- package/dist/oni-code/tools/spawn-agents.d.ts +0 -37
- package/dist/oni-code/tools/spawn-agents.d.ts.map +0 -1
- package/dist/oni-code/tools/spawn-agents.js +0 -91
- package/dist/oni-code/tools/spawn-agents.js.map +0 -1
- package/dist/oni-code/tools/spawn-swarm.d.ts +0 -70
- package/dist/oni-code/tools/spawn-swarm.d.ts.map +0 -1
- package/dist/oni-code/tools/spawn-swarm.js +0 -129
- package/dist/oni-code/tools/spawn-swarm.js.map +0 -1
- package/dist/oni-code/tools/web.d.ts +0 -11
- package/dist/oni-code/tools/web.d.ts.map +0 -1
- package/dist/oni-code/tools/web.js +0 -375
- package/dist/oni-code/tools/web.js.map +0 -1
- package/dist/oni-code/topology-agent-builder.d.ts +0 -22
- package/dist/oni-code/topology-agent-builder.d.ts.map +0 -1
- package/dist/oni-code/topology-agent-builder.js +0 -220
- package/dist/oni-code/topology-agent-builder.js.map +0 -1
- package/dist/oni-code/topology-selector.d.ts +0 -85
- package/dist/oni-code/topology-selector.d.ts.map +0 -1
- package/dist/oni-code/topology-selector.js +0 -338
- package/dist/oni-code/topology-selector.js.map +0 -1
- package/dist/oni-code/ui/App.d.ts +0 -10
- package/dist/oni-code/ui/App.d.ts.map +0 -1
- package/dist/oni-code/ui/App.js +0 -395
- package/dist/oni-code/ui/App.js.map +0 -1
- package/dist/oni-code/ui/FooterPanel.d.ts +0 -16
- package/dist/oni-code/ui/FooterPanel.d.ts.map +0 -1
- package/dist/oni-code/ui/FooterPanel.js +0 -56
- package/dist/oni-code/ui/FooterPanel.js.map +0 -1
- package/dist/oni-code/ui/Header.d.ts +0 -21
- package/dist/oni-code/ui/Header.d.ts.map +0 -1
- package/dist/oni-code/ui/Header.js +0 -105
- package/dist/oni-code/ui/Header.js.map +0 -1
- package/dist/oni-code/ui/InputArea.d.ts +0 -11
- package/dist/oni-code/ui/InputArea.d.ts.map +0 -1
- package/dist/oni-code/ui/InputArea.js +0 -82
- package/dist/oni-code/ui/InputArea.js.map +0 -1
- package/dist/oni-code/ui/MessageBlock.d.ts +0 -11
- package/dist/oni-code/ui/MessageBlock.d.ts.map +0 -1
- package/dist/oni-code/ui/MessageBlock.js +0 -103
- package/dist/oni-code/ui/MessageBlock.js.map +0 -1
- package/dist/oni-code/ui/OutputPane.d.ts +0 -12
- package/dist/oni-code/ui/OutputPane.d.ts.map +0 -1
- package/dist/oni-code/ui/OutputPane.js +0 -8
- package/dist/oni-code/ui/OutputPane.js.map +0 -1
- package/dist/oni-code/ui/PermissionPrompt.d.ts +0 -11
- package/dist/oni-code/ui/PermissionPrompt.d.ts.map +0 -1
- package/dist/oni-code/ui/PermissionPrompt.js +0 -48
- package/dist/oni-code/ui/PermissionPrompt.js.map +0 -1
- package/dist/oni-code/ui/QuestionPrompt.d.ts +0 -8
- package/dist/oni-code/ui/QuestionPrompt.d.ts.map +0 -1
- package/dist/oni-code/ui/QuestionPrompt.js +0 -9
- package/dist/oni-code/ui/QuestionPrompt.js.map +0 -1
- package/dist/oni-code/ui/StatusLine.d.ts +0 -14
- package/dist/oni-code/ui/StatusLine.d.ts.map +0 -1
- package/dist/oni-code/ui/StatusLine.js +0 -23
- package/dist/oni-code/ui/StatusLine.js.map +0 -1
- package/dist/oni-code/ui/SwarmPanel.d.ts +0 -9
- package/dist/oni-code/ui/SwarmPanel.d.ts.map +0 -1
- package/dist/oni-code/ui/SwarmPanel.js +0 -52
- package/dist/oni-code/ui/SwarmPanel.js.map +0 -1
- package/dist/oni-code/ui/ToolCallBlock.d.ts +0 -10
- package/dist/oni-code/ui/ToolCallBlock.d.ts.map +0 -1
- package/dist/oni-code/ui/ToolCallBlock.js +0 -21
- package/dist/oni-code/ui/ToolCallBlock.js.map +0 -1
- package/dist/oni-code/ui/Toolbar.d.ts +0 -8
- package/dist/oni-code/ui/Toolbar.d.ts.map +0 -1
- package/dist/oni-code/ui/Toolbar.js +0 -11
- package/dist/oni-code/ui/Toolbar.js.map +0 -1
- package/dist/oni-code/ui/WelcomeBanner.d.ts +0 -12
- package/dist/oni-code/ui/WelcomeBanner.d.ts.map +0 -1
- package/dist/oni-code/ui/WelcomeBanner.js +0 -24
- package/dist/oni-code/ui/WelcomeBanner.js.map +0 -1
- package/dist/oni-code/ui/activity.d.ts +0 -15
- package/dist/oni-code/ui/activity.d.ts.map +0 -1
- package/dist/oni-code/ui/activity.js +0 -252
- package/dist/oni-code/ui/activity.js.map +0 -1
- package/dist/oni-code/ui/banner.d.ts +0 -16
- package/dist/oni-code/ui/banner.d.ts.map +0 -1
- package/dist/oni-code/ui/banner.js +0 -132
- package/dist/oni-code/ui/banner.js.map +0 -1
- package/dist/oni-code/ui/command-menu.d.ts +0 -7
- package/dist/oni-code/ui/command-menu.d.ts.map +0 -1
- package/dist/oni-code/ui/command-menu.js +0 -20
- package/dist/oni-code/ui/command-menu.js.map +0 -1
- package/dist/oni-code/ui/diff.d.ts +0 -17
- package/dist/oni-code/ui/diff.d.ts.map +0 -1
- package/dist/oni-code/ui/diff.js +0 -37
- package/dist/oni-code/ui/diff.js.map +0 -1
- package/dist/oni-code/ui/format.d.ts +0 -41
- package/dist/oni-code/ui/format.d.ts.map +0 -1
- package/dist/oni-code/ui/format.js +0 -223
- package/dist/oni-code/ui/format.js.map +0 -1
- package/dist/oni-code/ui/input.d.ts +0 -28
- package/dist/oni-code/ui/input.d.ts.map +0 -1
- package/dist/oni-code/ui/input.js +0 -216
- package/dist/oni-code/ui/input.js.map +0 -1
- package/dist/oni-code/ui/insights.d.ts +0 -39
- package/dist/oni-code/ui/insights.d.ts.map +0 -1
- package/dist/oni-code/ui/insights.js +0 -193
- package/dist/oni-code/ui/insights.js.map +0 -1
- package/dist/oni-code/ui/markdown.d.ts +0 -9
- package/dist/oni-code/ui/markdown.d.ts.map +0 -1
- package/dist/oni-code/ui/markdown.js +0 -44
- package/dist/oni-code/ui/markdown.js.map +0 -1
- package/dist/oni-code/ui/panels.d.ts +0 -39
- package/dist/oni-code/ui/panels.d.ts.map +0 -1
- package/dist/oni-code/ui/panels.js +0 -209
- package/dist/oni-code/ui/panels.js.map +0 -1
- package/dist/oni-code/ui/paste.d.ts +0 -17
- package/dist/oni-code/ui/paste.d.ts.map +0 -1
- package/dist/oni-code/ui/paste.js +0 -45
- package/dist/oni-code/ui/paste.js.map +0 -1
- package/dist/oni-code/ui/raw-spinner.d.ts +0 -37
- package/dist/oni-code/ui/raw-spinner.d.ts.map +0 -1
- package/dist/oni-code/ui/raw-spinner.js +0 -121
- package/dist/oni-code/ui/raw-spinner.js.map +0 -1
- package/dist/oni-code/ui/session.d.ts +0 -44
- package/dist/oni-code/ui/session.d.ts.map +0 -1
- package/dist/oni-code/ui/session.js +0 -93
- package/dist/oni-code/ui/session.js.map +0 -1
- package/dist/oni-code/ui/spinner.d.ts +0 -7
- package/dist/oni-code/ui/spinner.d.ts.map +0 -1
- package/dist/oni-code/ui/spinner.js +0 -20
- package/dist/oni-code/ui/spinner.js.map +0 -1
- package/dist/oni-code/ui/swarm-activity.d.ts +0 -50
- package/dist/oni-code/ui/swarm-activity.d.ts.map +0 -1
- package/dist/oni-code/ui/swarm-activity.js +0 -233
- package/dist/oni-code/ui/swarm-activity.js.map +0 -1
- package/dist/oni-code/ui/terminal-size.d.ts +0 -18
- package/dist/oni-code/ui/terminal-size.d.ts.map +0 -1
- package/dist/oni-code/ui/terminal-size.js +0 -45
- package/dist/oni-code/ui/terminal-size.js.map +0 -1
- package/dist/oni-code/ui/theme.d.ts +0 -82
- package/dist/oni-code/ui/theme.d.ts.map +0 -1
- package/dist/oni-code/ui/theme.js +0 -101
- package/dist/oni-code/ui/theme.js.map +0 -1
- package/dist/oni-code/ui/tool-utils.d.ts +0 -10
- package/dist/oni-code/ui/tool-utils.d.ts.map +0 -1
- package/dist/oni-code/ui/tool-utils.js +0 -82
- package/dist/oni-code/ui/tool-utils.js.map +0 -1
- package/dist/oni-code/ui/useTerminalSize.d.ts +0 -3
- package/dist/oni-code/ui/useTerminalSize.d.ts.map +0 -1
- package/dist/oni-code/ui/useTerminalSize.js +0 -16
- package/dist/oni-code/ui/useTerminalSize.js.map +0 -1
- package/dist/oni-code/workspace/change-tracker.d.ts +0 -18
- package/dist/oni-code/workspace/change-tracker.d.ts.map +0 -1
- package/dist/oni-code/workspace/change-tracker.js +0 -67
- package/dist/oni-code/workspace/change-tracker.js.map +0 -1
- package/dist/oni-code/workspace/conflict-detector.d.ts +0 -12
- package/dist/oni-code/workspace/conflict-detector.d.ts.map +0 -1
- package/dist/oni-code/workspace/conflict-detector.js +0 -24
- package/dist/oni-code/workspace/conflict-detector.js.map +0 -1
- package/dist/oni-code/workspace/file-snapshots.d.ts +0 -39
- package/dist/oni-code/workspace/file-snapshots.d.ts.map +0 -1
- package/dist/oni-code/workspace/file-snapshots.js +0 -77
- package/dist/oni-code/workspace/file-snapshots.js.map +0 -1
- package/dist/oni-code/workspace/index.d.ts +0 -5
- package/dist/oni-code/workspace/index.d.ts.map +0 -1
- package/dist/oni-code/workspace/index.js +0 -5
- package/dist/oni-code/workspace/index.js.map +0 -1
- package/dist/oni-code/workspace/project-map.d.ts +0 -14
- package/dist/oni-code/workspace/project-map.d.ts.map +0 -1
- package/dist/oni-code/workspace/project-map.js +0 -91
- package/dist/oni-code/workspace/project-map.js.map +0 -1
- package/dist/sentinel/config/index.d.ts +0 -2
- package/dist/sentinel/config/index.d.ts.map +0 -1
- package/dist/sentinel/config/index.js +0 -2
- package/dist/sentinel/config/index.js.map +0 -1
- package/dist/sentinel/config/schema.d.ts +0 -4
- package/dist/sentinel/config/schema.d.ts.map +0 -1
- package/dist/sentinel/config/schema.js +0 -42
- package/dist/sentinel/config/schema.js.map +0 -1
- package/dist/sentinel/debate/index.d.ts +0 -6
- package/dist/sentinel/debate/index.d.ts.map +0 -1
- package/dist/sentinel/debate/index.js +0 -64
- package/dist/sentinel/debate/index.js.map +0 -1
- package/dist/sentinel/debate/prompts.d.ts +0 -4
- package/dist/sentinel/debate/prompts.d.ts.map +0 -1
- package/dist/sentinel/debate/prompts.js +0 -13
- package/dist/sentinel/debate/prompts.js.map +0 -1
- package/dist/sentinel/fix/index.d.ts +0 -6
- package/dist/sentinel/fix/index.d.ts.map +0 -1
- package/dist/sentinel/fix/index.js +0 -27
- package/dist/sentinel/fix/index.js.map +0 -1
- package/dist/sentinel/fix/strategies.d.ts +0 -9
- package/dist/sentinel/fix/strategies.d.ts.map +0 -1
- package/dist/sentinel/fix/strategies.js +0 -40
- package/dist/sentinel/fix/strategies.js.map +0 -1
- package/dist/sentinel/index.d.ts +0 -14
- package/dist/sentinel/index.d.ts.map +0 -1
- package/dist/sentinel/index.js +0 -22
- package/dist/sentinel/index.js.map +0 -1
- package/dist/sentinel/integrations/cli.d.ts +0 -10
- package/dist/sentinel/integrations/cli.d.ts.map +0 -1
- package/dist/sentinel/integrations/cli.js +0 -24
- package/dist/sentinel/integrations/cli.js.map +0 -1
- package/dist/sentinel/integrations/index.d.ts +0 -2
- package/dist/sentinel/integrations/index.d.ts.map +0 -1
- package/dist/sentinel/integrations/index.js +0 -2
- package/dist/sentinel/integrations/index.js.map +0 -1
- package/dist/sentinel/memory/index.d.ts +0 -16
- package/dist/sentinel/memory/index.d.ts.map +0 -1
- package/dist/sentinel/memory/index.js +0 -60
- package/dist/sentinel/memory/index.js.map +0 -1
- package/dist/sentinel/report/console.d.ts +0 -3
- package/dist/sentinel/report/console.d.ts.map +0 -1
- package/dist/sentinel/report/console.js +0 -27
- package/dist/sentinel/report/console.js.map +0 -1
- package/dist/sentinel/report/github.d.ts +0 -3
- package/dist/sentinel/report/github.d.ts.map +0 -1
- package/dist/sentinel/report/github.js +0 -36
- package/dist/sentinel/report/github.js.map +0 -1
- package/dist/sentinel/report/index.d.ts +0 -6
- package/dist/sentinel/report/index.d.ts.map +0 -1
- package/dist/sentinel/report/index.js +0 -15
- package/dist/sentinel/report/index.js.map +0 -1
- package/dist/sentinel/report/sarif.d.ts +0 -3
- package/dist/sentinel/report/sarif.d.ts.map +0 -1
- package/dist/sentinel/report/sarif.js +0 -29
- package/dist/sentinel/report/sarif.js.map +0 -1
- package/dist/sentinel/sentinel.d.ts +0 -17
- package/dist/sentinel/sentinel.d.ts.map +0 -1
- package/dist/sentinel/sentinel.js +0 -111
- package/dist/sentinel/sentinel.js.map +0 -1
- package/dist/sentinel/swarm/agents.d.ts +0 -6
- package/dist/sentinel/swarm/agents.d.ts.map +0 -1
- package/dist/sentinel/swarm/agents.js +0 -36
- package/dist/sentinel/swarm/agents.js.map +0 -1
- package/dist/sentinel/swarm/index.d.ts +0 -8
- package/dist/sentinel/swarm/index.d.ts.map +0 -1
- package/dist/sentinel/swarm/index.js +0 -74
- package/dist/sentinel/swarm/index.js.map +0 -1
- package/dist/sentinel/swarm/prompts.d.ts +0 -2
- package/dist/sentinel/swarm/prompts.d.ts.map +0 -1
- package/dist/sentinel/swarm/prompts.js +0 -24
- package/dist/sentinel/swarm/prompts.js.map +0 -1
- package/dist/sentinel/swarm/topology.d.ts +0 -10
- package/dist/sentinel/swarm/topology.d.ts.map +0 -1
- package/dist/sentinel/swarm/topology.js +0 -38
- package/dist/sentinel/swarm/topology.js.map +0 -1
- package/dist/sentinel/triage/analyzers/complexity-analyzer.d.ts +0 -7
- package/dist/sentinel/triage/analyzers/complexity-analyzer.d.ts.map +0 -1
- package/dist/sentinel/triage/analyzers/complexity-analyzer.js +0 -94
- package/dist/sentinel/triage/analyzers/complexity-analyzer.js.map +0 -1
- package/dist/sentinel/triage/analyzers/custom-analyzer.d.ts +0 -19
- package/dist/sentinel/triage/analyzers/custom-analyzer.d.ts.map +0 -1
- package/dist/sentinel/triage/analyzers/custom-analyzer.js +0 -268
- package/dist/sentinel/triage/analyzers/custom-analyzer.js.map +0 -1
- package/dist/sentinel/triage/analyzers/dependency-analyzer.d.ts +0 -26
- package/dist/sentinel/triage/analyzers/dependency-analyzer.d.ts.map +0 -1
- package/dist/sentinel/triage/analyzers/dependency-analyzer.js +0 -220
- package/dist/sentinel/triage/analyzers/dependency-analyzer.js.map +0 -1
- package/dist/sentinel/triage/analyzers/diff-analyzer.d.ts +0 -12
- package/dist/sentinel/triage/analyzers/diff-analyzer.d.ts.map +0 -1
- package/dist/sentinel/triage/analyzers/diff-analyzer.js +0 -19
- package/dist/sentinel/triage/analyzers/diff-analyzer.js.map +0 -1
- package/dist/sentinel/triage/analyzers/index.d.ts +0 -14
- package/dist/sentinel/triage/analyzers/index.d.ts.map +0 -1
- package/dist/sentinel/triage/analyzers/index.js +0 -25
- package/dist/sentinel/triage/analyzers/index.js.map +0 -1
- package/dist/sentinel/triage/analyzers/pattern-analyzer.d.ts +0 -7
- package/dist/sentinel/triage/analyzers/pattern-analyzer.d.ts.map +0 -1
- package/dist/sentinel/triage/analyzers/pattern-analyzer.js +0 -180
- package/dist/sentinel/triage/analyzers/pattern-analyzer.js.map +0 -1
- package/dist/sentinel/triage/analyzers/security-analyzer.d.ts +0 -7
- package/dist/sentinel/triage/analyzers/security-analyzer.d.ts.map +0 -1
- package/dist/sentinel/triage/analyzers/security-analyzer.js +0 -96
- package/dist/sentinel/triage/analyzers/security-analyzer.js.map +0 -1
- package/dist/sentinel/triage/analyzers/ts-parser.d.ts +0 -71
- package/dist/sentinel/triage/analyzers/ts-parser.d.ts.map +0 -1
- package/dist/sentinel/triage/analyzers/ts-parser.js +0 -323
- package/dist/sentinel/triage/analyzers/ts-parser.js.map +0 -1
- package/dist/sentinel/triage/analyzers/typescript-analyzer.d.ts +0 -7
- package/dist/sentinel/triage/analyzers/typescript-analyzer.d.ts.map +0 -1
- package/dist/sentinel/triage/analyzers/typescript-analyzer.js +0 -68
- package/dist/sentinel/triage/analyzers/typescript-analyzer.js.map +0 -1
- package/dist/sentinel/triage/index.d.ts +0 -10
- package/dist/sentinel/triage/index.d.ts.map +0 -1
- package/dist/sentinel/triage/index.js +0 -39
- package/dist/sentinel/triage/index.js.map +0 -1
- package/dist/sentinel/triage/scorer.d.ts +0 -9
- package/dist/sentinel/triage/scorer.d.ts.map +0 -1
- package/dist/sentinel/triage/scorer.js +0 -28
- package/dist/sentinel/triage/scorer.js.map +0 -1
- package/dist/sentinel/types.d.ts +0 -125
- package/dist/sentinel/types.d.ts.map +0 -1
- package/dist/sentinel/types.js +0 -6
- package/dist/sentinel/types.js.map +0 -1
|
@@ -1,111 +0,0 @@
|
|
|
1
|
-
import { parseConfig } from "./config/index.js";
|
|
2
|
-
import { triageFiles } from "./triage/index.js";
|
|
3
|
-
import { runSwarmReview } from "./swarm/index.js";
|
|
4
|
-
import { runDebateVerification } from "./debate/index.js";
|
|
5
|
-
import { runAutoFix } from "./fix/index.js";
|
|
6
|
-
import { MemoryStore } from "./memory/index.js";
|
|
7
|
-
import * as fs from "node:fs";
|
|
8
|
-
import * as path from "node:path";
|
|
9
|
-
export class Sentinel {
|
|
10
|
-
config;
|
|
11
|
-
model;
|
|
12
|
-
fastModel;
|
|
13
|
-
rootDir;
|
|
14
|
-
memory;
|
|
15
|
-
constructor(options) {
|
|
16
|
-
this.model = options.model;
|
|
17
|
-
this.fastModel = options.fastModel ?? options.model;
|
|
18
|
-
this.rootDir = options.rootDir ?? process.cwd();
|
|
19
|
-
this.config = typeof options.config === "string"
|
|
20
|
-
? parseConfig()
|
|
21
|
-
: parseConfig(options.config ?? {});
|
|
22
|
-
this.memory = options.memoryJson
|
|
23
|
-
? MemoryStore.fromJSON(options.memoryJson)
|
|
24
|
-
: new MemoryStore();
|
|
25
|
-
}
|
|
26
|
-
getMemory() {
|
|
27
|
-
return this.memory;
|
|
28
|
-
}
|
|
29
|
-
discoverFiles(paths) {
|
|
30
|
-
const files = [];
|
|
31
|
-
for (const p of paths) {
|
|
32
|
-
try {
|
|
33
|
-
const fullPath = path.resolve(this.rootDir, p);
|
|
34
|
-
const stat = fs.statSync(fullPath);
|
|
35
|
-
if (stat.isFile() && (p.endsWith(".ts") || p.endsWith(".js") || p.endsWith(".tsx") || p.endsWith(".jsx"))) {
|
|
36
|
-
files.push({ path: p, content: fs.readFileSync(fullPath, "utf-8") });
|
|
37
|
-
}
|
|
38
|
-
else if (stat.isDirectory()) {
|
|
39
|
-
const entries = fs.readdirSync(fullPath, { recursive: true });
|
|
40
|
-
for (const entry of entries) {
|
|
41
|
-
const entryStr = String(entry);
|
|
42
|
-
if (/\.(ts|js|tsx|jsx)$/.test(entryStr) && !entryStr.includes("node_modules")) {
|
|
43
|
-
const entryPath = path.join(p, entryStr);
|
|
44
|
-
try {
|
|
45
|
-
files.push({ path: entryPath, content: fs.readFileSync(path.resolve(this.rootDir, entryPath), "utf-8") });
|
|
46
|
-
}
|
|
47
|
-
catch { /* skip unreadable */ }
|
|
48
|
-
}
|
|
49
|
-
}
|
|
50
|
-
}
|
|
51
|
-
}
|
|
52
|
-
catch { /* path doesn't exist, skip */ }
|
|
53
|
-
}
|
|
54
|
-
return files;
|
|
55
|
-
}
|
|
56
|
-
async scan(options) {
|
|
57
|
-
const start = Date.now();
|
|
58
|
-
const files = this.discoverFiles(options.paths);
|
|
59
|
-
const triaged = await triageFiles(files, this.config, this.rootDir);
|
|
60
|
-
const swarmFindings = await runSwarmReview(triaged, this.model, this.fastModel);
|
|
61
|
-
const merged = [...triaged.flatMap(t => t.findings), ...swarmFindings];
|
|
62
|
-
const verified = await runDebateVerification(merged, this.model, this.config, this.memory);
|
|
63
|
-
const fixed = await runAutoFix(verified, this.model, this.config, this.rootDir, this.memory);
|
|
64
|
-
const skipped = files.length - triaged.length;
|
|
65
|
-
const duration = Date.now() - start;
|
|
66
|
-
const summary = this.buildSummary(fixed, files.length, skipped);
|
|
67
|
-
// Record review in memory for learning
|
|
68
|
-
this.memory.recordReview({
|
|
69
|
-
totalFindings: summary.totalFindings,
|
|
70
|
-
fixRate: summary.totalFindings > 0 ? summary.fixesApplied / summary.totalFindings : 0,
|
|
71
|
-
falsePositiveRate: summary.totalFindings > 0 ? summary.debateDismissals / summary.totalFindings : 0,
|
|
72
|
-
duration,
|
|
73
|
-
});
|
|
74
|
-
return { findings: fixed, summary, duration, config: this.config };
|
|
75
|
-
}
|
|
76
|
-
async analyzeFile(filePath) {
|
|
77
|
-
const report = await this.scan({ paths: [filePath] });
|
|
78
|
-
return report.findings;
|
|
79
|
-
}
|
|
80
|
-
async reviewPR(options) {
|
|
81
|
-
const start = Date.now();
|
|
82
|
-
const findings = [];
|
|
83
|
-
return {
|
|
84
|
-
findings,
|
|
85
|
-
summary: this.buildSummary(findings, 0, 0),
|
|
86
|
-
duration: Date.now() - start,
|
|
87
|
-
config: this.config,
|
|
88
|
-
};
|
|
89
|
-
}
|
|
90
|
-
buildSummary(findings, totalFiles, skipped) {
|
|
91
|
-
const bySeverity = { error: 0, warning: 0, info: 0 };
|
|
92
|
-
const byCategory = { security: 0, architecture: 0, performance: 0, correctness: 0, style: 0 };
|
|
93
|
-
for (const f of findings) {
|
|
94
|
-
bySeverity[f.severity]++;
|
|
95
|
-
byCategory[f.category]++;
|
|
96
|
-
}
|
|
97
|
-
return {
|
|
98
|
-
totalFiles,
|
|
99
|
-
filesScanned: totalFiles - skipped,
|
|
100
|
-
filesSkipped: skipped,
|
|
101
|
-
totalFindings: findings.length,
|
|
102
|
-
bySeverity,
|
|
103
|
-
byCategory,
|
|
104
|
-
fixesApplied: findings.filter(f => f.fixPatch).length,
|
|
105
|
-
fixesFailed: 0,
|
|
106
|
-
debatesRun: findings.filter(f => f.debateVerdict).length,
|
|
107
|
-
debateDismissals: findings.filter(f => f.debateVerdict === "dismissed").length,
|
|
108
|
-
};
|
|
109
|
-
}
|
|
110
|
-
}
|
|
111
|
-
//# sourceMappingURL=sentinel.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"sentinel.js","sourceRoot":"","sources":["../../src/sentinel/sentinel.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,6 +0,0 @@
|
|
|
1
|
-
export declare const SPECIALIST_IDS: readonly ["security-analyst", "architecture-reviewer", "performance-auditor", "correctness-checker", "style-enforcer"];
|
|
2
|
-
export type SpecialistId = typeof SPECIALIST_IDS[number];
|
|
3
|
-
export declare function getAgentPrompt(id: SpecialistId): string;
|
|
4
|
-
export declare function getAgentRole(id: SpecialistId): string;
|
|
5
|
-
export declare function getAgentCapabilities(id: SpecialistId): string[];
|
|
6
|
-
//# sourceMappingURL=agents.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"agents.d.ts","sourceRoot":"","sources":["../../../src/sentinel/swarm/agents.ts"],"names":[],"mappings":"AAOA,eAAO,MAAM,cAAc,wHAMjB,CAAC;AAEX,MAAM,MAAM,YAAY,GAAG,OAAO,cAAc,CAAC,MAAM,CAAC,CAAC;AAkBzD,wBAAgB,cAAc,CAAC,EAAE,EAAE,YAAY,GAAG,MAAM,CAEvD;AAED,wBAAgB,YAAY,CAAC,EAAE,EAAE,YAAY,GAAG,MAAM,CAErD;AAED,wBAAgB,oBAAoB,CAAC,EAAE,EAAE,YAAY,GAAG,MAAM,EAAE,CAE/D"}
|
|
@@ -1,36 +0,0 @@
|
|
|
1
|
-
// src/sentinel/swarm/agents.ts
|
|
2
|
-
// ============================================================
|
|
3
|
-
// @oni.bot/sentinel — Specialist Agent Definitions
|
|
4
|
-
// ============================================================
|
|
5
|
-
import { AGENT_PROMPTS } from "./prompts.js";
|
|
6
|
-
export const SPECIALIST_IDS = [
|
|
7
|
-
"security-analyst",
|
|
8
|
-
"architecture-reviewer",
|
|
9
|
-
"performance-auditor",
|
|
10
|
-
"correctness-checker",
|
|
11
|
-
"style-enforcer",
|
|
12
|
-
];
|
|
13
|
-
const ROLES = {
|
|
14
|
-
"security-analyst": "Security Analyst",
|
|
15
|
-
"architecture-reviewer": "Architecture Reviewer",
|
|
16
|
-
"performance-auditor": "Performance Auditor",
|
|
17
|
-
"correctness-checker": "Correctness Checker",
|
|
18
|
-
"style-enforcer": "Style Enforcer",
|
|
19
|
-
};
|
|
20
|
-
const CAPABILITIES = {
|
|
21
|
-
"security-analyst": ["security-review", "vulnerability-detection", "owasp-analysis"],
|
|
22
|
-
"architecture-reviewer": ["architecture-review", "coupling-analysis", "solid-check"],
|
|
23
|
-
"performance-auditor": ["performance-review", "complexity-analysis", "memory-leak-detection"],
|
|
24
|
-
"correctness-checker": ["correctness-review", "logic-verification", "edge-case-analysis"],
|
|
25
|
-
"style-enforcer": ["style-review", "naming-check", "consistency-analysis"],
|
|
26
|
-
};
|
|
27
|
-
export function getAgentPrompt(id) {
|
|
28
|
-
return AGENT_PROMPTS[id];
|
|
29
|
-
}
|
|
30
|
-
export function getAgentRole(id) {
|
|
31
|
-
return ROLES[id];
|
|
32
|
-
}
|
|
33
|
-
export function getAgentCapabilities(id) {
|
|
34
|
-
return CAPABILITIES[id];
|
|
35
|
-
}
|
|
36
|
-
//# sourceMappingURL=agents.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"agents.js","sourceRoot":"","sources":["../../../src/sentinel/swarm/agents.ts"],"names":[],"mappings":"AAAA,+BAA+B;AAC/B,+DAA+D;AAC/D,mDAAmD;AACnD,+DAA+D;AAE/D,OAAO,EAAE,aAAa,EAAE,MAAM,cAAc,CAAC;AAE7C,MAAM,CAAC,MAAM,cAAc,GAAG;IAC5B,kBAAkB;IAClB,uBAAuB;IACvB,qBAAqB;IACrB,qBAAqB;IACrB,gBAAgB;CACR,CAAC;AAIX,MAAM,KAAK,GAAiC;IAC1C,kBAAkB,EAAE,kBAAkB;IACtC,uBAAuB,EAAE,uBAAuB;IAChD,qBAAqB,EAAE,qBAAqB;IAC5C,qBAAqB,EAAE,qBAAqB;IAC5C,gBAAgB,EAAE,gBAAgB;CACnC,CAAC;AAEF,MAAM,YAAY,GAAmC;IACnD,kBAAkB,EAAE,CAAC,iBAAiB,EAAE,yBAAyB,EAAE,gBAAgB,CAAC;IACpF,uBAAuB,EAAE,CAAC,qBAAqB,EAAE,mBAAmB,EAAE,aAAa,CAAC;IACpF,qBAAqB,EAAE,CAAC,oBAAoB,EAAE,qBAAqB,EAAE,uBAAuB,CAAC;IAC7F,qBAAqB,EAAE,CAAC,oBAAoB,EAAE,oBAAoB,EAAE,oBAAoB,CAAC;IACzF,gBAAgB,EAAE,CAAC,cAAc,EAAE,cAAc,EAAE,sBAAsB,CAAC;CAC3E,CAAC;AAEF,MAAM,UAAU,cAAc,CAAC,EAAgB;IAC7C,OAAO,aAAa,CAAC,EAAE,CAAC,CAAC;AAC3B,CAAC;AAED,MAAM,UAAU,YAAY,CAAC,EAAgB;IAC3C,OAAO,KAAK,CAAC,EAAE,CAAC,CAAC;AACnB,CAAC;AAED,MAAM,UAAU,oBAAoB,CAAC,EAAgB;IACnD,OAAO,YAAY,CAAC,EAAE,CAAC,CAAC;AAC1B,CAAC"}
|
|
@@ -1,8 +0,0 @@
|
|
|
1
|
-
import type { ONIModel } from "../../models/types.js";
|
|
2
|
-
import type { FileScore, Finding } from "../types.js";
|
|
3
|
-
export declare function runSwarmReview(files: FileScore[], model: ONIModel, fastModel: ONIModel): Promise<Finding[]>;
|
|
4
|
-
export { selectTopology } from "./topology.js";
|
|
5
|
-
export { SPECIALIST_IDS, getAgentPrompt, getAgentRole, getAgentCapabilities } from "./agents.js";
|
|
6
|
-
export type { TopologyConfig } from "./topology.js";
|
|
7
|
-
export type { SpecialistId } from "./agents.js";
|
|
8
|
-
//# sourceMappingURL=index.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/sentinel/swarm/index.ts"],"names":[],"mappings":"AAKA,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,uBAAuB,CAAC;AACtD,OAAO,KAAK,EAAE,SAAS,EAAE,OAAO,EAAE,MAAM,aAAa,CAAC;AAItD,wBAAsB,cAAc,CAClC,KAAK,EAAE,SAAS,EAAE,EAClB,KAAK,EAAE,QAAQ,EACf,SAAS,EAAE,QAAQ,GAClB,OAAO,CAAC,OAAO,EAAE,CAAC,CAwBpB;AAmDD,OAAO,EAAE,cAAc,EAAE,MAAM,eAAe,CAAC;AAC/C,OAAO,EAAE,cAAc,EAAE,cAAc,EAAE,YAAY,EAAE,oBAAoB,EAAE,MAAM,aAAa,CAAC;AACjG,YAAY,EAAE,cAAc,EAAE,MAAM,eAAe,CAAC;AACpD,YAAY,EAAE,YAAY,EAAE,MAAM,aAAa,CAAC"}
|
|
@@ -1,74 +0,0 @@
|
|
|
1
|
-
// src/sentinel/swarm/index.ts
|
|
2
|
-
// ============================================================
|
|
3
|
-
// @oni.bot/sentinel — Swarm Review Orchestrator
|
|
4
|
-
// ============================================================
|
|
5
|
-
import { selectTopology } from "./topology.js";
|
|
6
|
-
import { getAgentPrompt } from "./agents.js";
|
|
7
|
-
export async function runSwarmReview(files, model, fastModel) {
|
|
8
|
-
const allFindings = [];
|
|
9
|
-
for (const fileScore of files) {
|
|
10
|
-
const config = selectTopology(fileScore.tier);
|
|
11
|
-
if (config.skip)
|
|
12
|
-
continue;
|
|
13
|
-
const activeModel = config.model === "fast" ? fastModel : model;
|
|
14
|
-
const agentIds = config.agents ?? [];
|
|
15
|
-
const agentFindings = await Promise.all(agentIds.map(async (agentId) => {
|
|
16
|
-
try {
|
|
17
|
-
return await runSingleAgent(agentId, fileScore, activeModel);
|
|
18
|
-
}
|
|
19
|
-
catch {
|
|
20
|
-
return [];
|
|
21
|
-
}
|
|
22
|
-
}));
|
|
23
|
-
allFindings.push(...agentFindings.flat());
|
|
24
|
-
}
|
|
25
|
-
return allFindings;
|
|
26
|
-
}
|
|
27
|
-
async function runSingleAgent(agentId, fileScore, model) {
|
|
28
|
-
const prompt = getAgentPrompt(agentId);
|
|
29
|
-
const response = await model.chat({
|
|
30
|
-
messages: [
|
|
31
|
-
{
|
|
32
|
-
role: "user",
|
|
33
|
-
content: `Review this file for issues: ${fileScore.file}\n\nStatic analysis score: ${fileScore.score}/100 (tier: ${fileScore.tier})\nExisting findings: ${JSON.stringify(fileScore.findings)}\n\nPlease analyze and return a JSON array of findings.`,
|
|
34
|
-
},
|
|
35
|
-
],
|
|
36
|
-
systemPrompt: prompt,
|
|
37
|
-
});
|
|
38
|
-
return parseFindings(response.content, agentId, fileScore.file);
|
|
39
|
-
}
|
|
40
|
-
function parseFindings(content, agentId, file) {
|
|
41
|
-
try {
|
|
42
|
-
const jsonMatch = content.match(/\[[\s\S]*\]/);
|
|
43
|
-
if (!jsonMatch)
|
|
44
|
-
return [];
|
|
45
|
-
const parsed = JSON.parse(jsonMatch[0]);
|
|
46
|
-
if (!Array.isArray(parsed))
|
|
47
|
-
return [];
|
|
48
|
-
return parsed
|
|
49
|
-
.filter((f) => f && typeof f === "object" && f.message)
|
|
50
|
-
.map((f, i) => {
|
|
51
|
-
const finding = f;
|
|
52
|
-
return {
|
|
53
|
-
id: `${agentId}-${file}-${i}`,
|
|
54
|
-
file: typeof finding.file === "string" ? finding.file : file,
|
|
55
|
-
line: typeof finding.line === "number" ? finding.line : 1,
|
|
56
|
-
severity: finding.severity ?? "info",
|
|
57
|
-
category: finding.category ?? "correctness",
|
|
58
|
-
message: String(finding.message),
|
|
59
|
-
suggestion: typeof finding.suggestion === "string" ? finding.suggestion : undefined,
|
|
60
|
-
confidence: typeof finding.confidence === "number" ? finding.confidence : 0.5,
|
|
61
|
-
agent: agentId,
|
|
62
|
-
relatedFiles: Array.isArray(finding.relatedFiles)
|
|
63
|
-
? finding.relatedFiles
|
|
64
|
-
: undefined,
|
|
65
|
-
};
|
|
66
|
-
});
|
|
67
|
-
}
|
|
68
|
-
catch {
|
|
69
|
-
return [];
|
|
70
|
-
}
|
|
71
|
-
}
|
|
72
|
-
export { selectTopology } from "./topology.js";
|
|
73
|
-
export { SPECIALIST_IDS, getAgentPrompt, getAgentRole, getAgentCapabilities } from "./agents.js";
|
|
74
|
-
//# sourceMappingURL=index.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/sentinel/swarm/index.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"prompts.d.ts","sourceRoot":"","sources":["../../../src/sentinel/swarm/prompts.ts"],"names":[],"mappings":"AAKA,eAAO,MAAM,aAAa,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAsBhD,CAAC"}
|
|
@@ -1,24 +0,0 @@
|
|
|
1
|
-
// src/sentinel/swarm/prompts.ts
|
|
2
|
-
// ============================================================
|
|
3
|
-
// @oni.bot/sentinel — Specialist Agent System Prompts
|
|
4
|
-
// ============================================================
|
|
5
|
-
export const AGENT_PROMPTS = {
|
|
6
|
-
"security-analyst": `You are a senior security analyst reviewing source code.
|
|
7
|
-
Focus: injection vulnerabilities, auth/authz flaws, data exposure, OWASP Top 10, insecure dependencies.
|
|
8
|
-
Return ONLY a JSON array of findings:
|
|
9
|
-
[{"file":"path","line":N,"severity":"error|warning|info","category":"security","message":"description","suggestion":"fix","confidence":0.0-1.0}]
|
|
10
|
-
Only report real issues with confidence >= 0.6.`,
|
|
11
|
-
"architecture-reviewer": `You are a senior software architect reviewing code structure.
|
|
12
|
-
Focus: coupling, cohesion, SOLID violations, dependency direction, module boundary violations.
|
|
13
|
-
Return ONLY a JSON array of findings with category "architecture".`,
|
|
14
|
-
"performance-auditor": `You are a performance engineer reviewing code efficiency.
|
|
15
|
-
Focus: O(n^2)+ algorithms, memory leaks, unnecessary allocations, N+1 patterns, blocking in async.
|
|
16
|
-
Return ONLY a JSON array of findings with category "performance".`,
|
|
17
|
-
"correctness-checker": `You are a correctness verification expert.
|
|
18
|
-
Focus: logic errors, off-by-one, race conditions, null/undefined risks, edge cases, unchecked errors.
|
|
19
|
-
Return ONLY a JSON array of findings with category "correctness".`,
|
|
20
|
-
"style-enforcer": `You are a code style and consistency reviewer.
|
|
21
|
-
Focus: naming violations, inconsistent patterns, missing docs on public APIs, non-idiomatic code, dead code.
|
|
22
|
-
Return ONLY a JSON array of findings with category "style". Only flag issues impacting readability.`,
|
|
23
|
-
};
|
|
24
|
-
//# sourceMappingURL=prompts.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"prompts.js","sourceRoot":"","sources":["../../../src/sentinel/swarm/prompts.ts"],"names":[],"mappings":"AAAA,gCAAgC;AAChC,+DAA+D;AAC/D,sDAAsD;AACtD,+DAA+D;AAE/D,MAAM,CAAC,MAAM,aAAa,GAA2B;IACnD,kBAAkB,EAAE;;;;gDAI0B;IAE9C,uBAAuB,EAAE;;mEAEwC;IAEjE,qBAAqB,EAAE;;kEAEyC;IAEhE,qBAAqB,EAAE;;kEAEyC;IAEhE,gBAAgB,EAAE;;oGAEgF;CACnG,CAAC"}
|
|
@@ -1,10 +0,0 @@
|
|
|
1
|
-
import type { Tier } from "../types.js";
|
|
2
|
-
import type { SpecialistId } from "./agents.js";
|
|
3
|
-
export interface TopologyConfig {
|
|
4
|
-
skip: boolean;
|
|
5
|
-
topology?: "single" | "fanOut";
|
|
6
|
-
agents?: SpecialistId[];
|
|
7
|
-
model?: "fast" | "standard";
|
|
8
|
-
}
|
|
9
|
-
export declare function selectTopology(tier: Tier): TopologyConfig;
|
|
10
|
-
//# sourceMappingURL=topology.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"topology.d.ts","sourceRoot":"","sources":["../../../src/sentinel/swarm/topology.ts"],"names":[],"mappings":"AAKA,OAAO,KAAK,EAAE,IAAI,EAAE,MAAM,aAAa,CAAC;AACxC,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,aAAa,CAAC;AAEhD,MAAM,WAAW,cAAc;IAC7B,IAAI,EAAE,OAAO,CAAC;IACd,QAAQ,CAAC,EAAE,QAAQ,GAAG,QAAQ,CAAC;IAC/B,MAAM,CAAC,EAAE,YAAY,EAAE,CAAC;IACxB,KAAK,CAAC,EAAE,MAAM,GAAG,UAAU,CAAC;CAC7B;AAED,wBAAgB,cAAc,CAAC,IAAI,EAAE,IAAI,GAAG,cAAc,CAgCzD"}
|
|
@@ -1,38 +0,0 @@
|
|
|
1
|
-
// src/sentinel/swarm/topology.ts
|
|
2
|
-
// ============================================================
|
|
3
|
-
// @oni.bot/sentinel — Tier-Based Topology Selector
|
|
4
|
-
// ============================================================
|
|
5
|
-
export function selectTopology(tier) {
|
|
6
|
-
switch (tier) {
|
|
7
|
-
case "clean":
|
|
8
|
-
return { skip: true };
|
|
9
|
-
case "low":
|
|
10
|
-
return {
|
|
11
|
-
skip: false,
|
|
12
|
-
topology: "single",
|
|
13
|
-
agents: ["correctness-checker"],
|
|
14
|
-
model: "fast",
|
|
15
|
-
};
|
|
16
|
-
case "medium":
|
|
17
|
-
return {
|
|
18
|
-
skip: false,
|
|
19
|
-
topology: "fanOut",
|
|
20
|
-
agents: ["security-analyst", "architecture-reviewer", "correctness-checker"],
|
|
21
|
-
model: "standard",
|
|
22
|
-
};
|
|
23
|
-
case "high":
|
|
24
|
-
return {
|
|
25
|
-
skip: false,
|
|
26
|
-
topology: "fanOut",
|
|
27
|
-
agents: [
|
|
28
|
-
"security-analyst",
|
|
29
|
-
"architecture-reviewer",
|
|
30
|
-
"performance-auditor",
|
|
31
|
-
"correctness-checker",
|
|
32
|
-
"style-enforcer",
|
|
33
|
-
],
|
|
34
|
-
model: "standard",
|
|
35
|
-
};
|
|
36
|
-
}
|
|
37
|
-
}
|
|
38
|
-
//# sourceMappingURL=topology.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"topology.js","sourceRoot":"","sources":["../../../src/sentinel/swarm/topology.ts"],"names":[],"mappings":"AAAA,iCAAiC;AACjC,+DAA+D;AAC/D,mDAAmD;AACnD,+DAA+D;AAY/D,MAAM,UAAU,cAAc,CAAC,IAAU;IACvC,QAAQ,IAAI,EAAE,CAAC;QACb,KAAK,OAAO;YACV,OAAO,EAAE,IAAI,EAAE,IAAI,EAAE,CAAC;QACxB,KAAK,KAAK;YACR,OAAO;gBACL,IAAI,EAAE,KAAK;gBACX,QAAQ,EAAE,QAAQ;gBAClB,MAAM,EAAE,CAAC,qBAAqB,CAAC;gBAC/B,KAAK,EAAE,MAAM;aACd,CAAC;QACJ,KAAK,QAAQ;YACX,OAAO;gBACL,IAAI,EAAE,KAAK;gBACX,QAAQ,EAAE,QAAQ;gBAClB,MAAM,EAAE,CAAC,kBAAkB,EAAE,uBAAuB,EAAE,qBAAqB,CAAC;gBAC5E,KAAK,EAAE,UAAU;aAClB,CAAC;QACJ,KAAK,MAAM;YACT,OAAO;gBACL,IAAI,EAAE,KAAK;gBACX,QAAQ,EAAE,QAAQ;gBAClB,MAAM,EAAE;oBACN,kBAAkB;oBAClB,uBAAuB;oBACvB,qBAAqB;oBACrB,qBAAqB;oBACrB,gBAAgB;iBACjB;gBACD,KAAK,EAAE,UAAU;aAClB,CAAC;IACN,CAAC;AACH,CAAC"}
|
|
@@ -1,7 +0,0 @@
|
|
|
1
|
-
import type { Analyzer, AnalyzerResult } from "../../types.js";
|
|
2
|
-
export declare class ComplexityAnalyzer implements Analyzer {
|
|
3
|
-
name: string;
|
|
4
|
-
weight: number;
|
|
5
|
-
analyze(file: string, content: string, _rootDir: string): Promise<AnalyzerResult>;
|
|
6
|
-
}
|
|
7
|
-
//# sourceMappingURL=complexity-analyzer.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"complexity-analyzer.d.ts","sourceRoot":"","sources":["../../../../src/sentinel/triage/analyzers/complexity-analyzer.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,QAAQ,EAAE,cAAc,EAAW,MAAM,gBAAgB,CAAC;AAGxE,qBAAa,kBAAmB,YAAW,QAAQ;IACjD,IAAI,SAAgB;IACpB,MAAM,SAAQ;IAER,OAAO,CAAC,IAAI,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,GAAG,OAAO,CAAC,cAAc,CAAC;CA4FxF"}
|
|
@@ -1,94 +0,0 @@
|
|
|
1
|
-
import { extractFunctions } from "./ts-parser.js";
|
|
2
|
-
export class ComplexityAnalyzer {
|
|
3
|
-
name = "complexity";
|
|
4
|
-
weight = 0.20;
|
|
5
|
-
async analyze(file, content, _rootDir) {
|
|
6
|
-
const lines = content.split("\n");
|
|
7
|
-
const findings = [];
|
|
8
|
-
// Count cyclomatic complexity keywords
|
|
9
|
-
const complexityKeywords = /\b(if|for|while|switch|case)\b|(\?:|\?\s)/g;
|
|
10
|
-
let complexity = 0;
|
|
11
|
-
for (const line of lines) {
|
|
12
|
-
const matches = line.match(complexityKeywords);
|
|
13
|
-
if (matches)
|
|
14
|
-
complexity += matches.length;
|
|
15
|
-
}
|
|
16
|
-
// Track max nesting depth via brace counting
|
|
17
|
-
let depth = 0;
|
|
18
|
-
let maxDepth = 0;
|
|
19
|
-
let maxDepthLine = 0;
|
|
20
|
-
for (let i = 0; i < lines.length; i++) {
|
|
21
|
-
for (const ch of lines[i]) {
|
|
22
|
-
if (ch === "{") {
|
|
23
|
-
depth++;
|
|
24
|
-
if (depth > maxDepth) {
|
|
25
|
-
maxDepth = depth;
|
|
26
|
-
maxDepthLine = i + 1;
|
|
27
|
-
}
|
|
28
|
-
}
|
|
29
|
-
else if (ch === "}") {
|
|
30
|
-
depth = Math.max(0, depth - 1);
|
|
31
|
-
}
|
|
32
|
-
}
|
|
33
|
-
}
|
|
34
|
-
if (complexity > 15) {
|
|
35
|
-
findings.push({
|
|
36
|
-
id: `complexity-high-${file}`,
|
|
37
|
-
file,
|
|
38
|
-
line: 1,
|
|
39
|
-
severity: "warning",
|
|
40
|
-
category: "performance",
|
|
41
|
-
message: `High cyclomatic complexity: ${complexity} decision points detected`,
|
|
42
|
-
suggestion: "Break this file into smaller, single-responsibility functions",
|
|
43
|
-
confidence: 0.85,
|
|
44
|
-
agent: "complexity",
|
|
45
|
-
});
|
|
46
|
-
}
|
|
47
|
-
if (maxDepth > 5) {
|
|
48
|
-
findings.push({
|
|
49
|
-
id: `complexity-nesting-${file}-${maxDepthLine}`,
|
|
50
|
-
file,
|
|
51
|
-
line: maxDepthLine,
|
|
52
|
-
severity: "warning",
|
|
53
|
-
category: "performance",
|
|
54
|
-
message: `Deep nesting detected: ${maxDepth} levels at line ${maxDepthLine}`,
|
|
55
|
-
suggestion: "Reduce nesting by using early returns or extracting logic into helper functions",
|
|
56
|
-
confidence: 0.9,
|
|
57
|
-
agent: "complexity",
|
|
58
|
-
});
|
|
59
|
-
}
|
|
60
|
-
// Function length detection
|
|
61
|
-
const functions = extractFunctions(content, file);
|
|
62
|
-
let maxFunctionLength = 0;
|
|
63
|
-
for (const fn of functions) {
|
|
64
|
-
if (fn.lineCount > maxFunctionLength)
|
|
65
|
-
maxFunctionLength = fn.lineCount;
|
|
66
|
-
if (fn.lineCount > 50) {
|
|
67
|
-
findings.push({
|
|
68
|
-
id: `complexity-long-fn-${file}-${fn.name}`,
|
|
69
|
-
file,
|
|
70
|
-
line: fn.line,
|
|
71
|
-
endLine: fn.endLine,
|
|
72
|
-
severity: "warning",
|
|
73
|
-
category: "performance",
|
|
74
|
-
message: `Overly long function: \`${fn.name}\` is ${fn.lineCount} lines — hard to understand and maintain`,
|
|
75
|
-
suggestion: `Break \`${fn.name}\` into smaller focused functions`,
|
|
76
|
-
confidence: 0.85,
|
|
77
|
-
agent: "complexity",
|
|
78
|
-
});
|
|
79
|
-
}
|
|
80
|
-
}
|
|
81
|
-
// Subtract 1 from maxDepth to treat the outermost function body as depth 0
|
|
82
|
-
const nestingScore = Math.max(0, maxDepth - 1) * 10;
|
|
83
|
-
const functionLengthScore = Math.min(20, Math.max(0, maxFunctionLength - 30));
|
|
84
|
-
const score = Math.min(100, complexity * 3 + nestingScore + functionLengthScore);
|
|
85
|
-
return {
|
|
86
|
-
analyzer: this.name,
|
|
87
|
-
file,
|
|
88
|
-
score,
|
|
89
|
-
findings,
|
|
90
|
-
metadata: { complexity, maxDepth, maxFunctionLength },
|
|
91
|
-
};
|
|
92
|
-
}
|
|
93
|
-
}
|
|
94
|
-
//# sourceMappingURL=complexity-analyzer.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"complexity-analyzer.js","sourceRoot":"","sources":["../../../../src/sentinel/triage/analyzers/complexity-analyzer.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,19 +0,0 @@
|
|
|
1
|
-
import type { Analyzer, AnalyzerResult, CustomAnalyzerConfig } from "../../types.js";
|
|
2
|
-
/**
|
|
3
|
-
* Wraps a user-configured external linting tool as a Sentinel analyzer.
|
|
4
|
-
*
|
|
5
|
-
* The command receives the file path substituted for `{file}`.
|
|
6
|
-
* Output is parsed according to `config.parser`: "sarif", "json", or "text".
|
|
7
|
-
*
|
|
8
|
-
* On failure (non-zero exit, timeout, parse error), returns score 0 with
|
|
9
|
-
* an error finding so the scan continues gracefully.
|
|
10
|
-
*/
|
|
11
|
-
export declare class CustomAnalyzer implements Analyzer {
|
|
12
|
-
readonly name: string;
|
|
13
|
-
readonly weight: number;
|
|
14
|
-
private config;
|
|
15
|
-
constructor(config: CustomAnalyzerConfig, weight?: number);
|
|
16
|
-
analyze(file: string, _content: string, rootDir: string): Promise<AnalyzerResult>;
|
|
17
|
-
private parseOutput;
|
|
18
|
-
}
|
|
19
|
-
//# sourceMappingURL=custom-analyzer.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"custom-analyzer.d.ts","sourceRoot":"","sources":["../../../../src/sentinel/triage/analyzers/custom-analyzer.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,QAAQ,EAAE,cAAc,EAAW,oBAAoB,EAAE,MAAM,gBAAgB,CAAC;AAK9F;;;;;;;;GAQG;AACH,qBAAa,cAAe,YAAW,QAAQ;IAC7C,QAAQ,CAAC,IAAI,EAAE,MAAM,CAAC;IACtB,QAAQ,CAAC,MAAM,EAAE,MAAM,CAAC;IACxB,OAAO,CAAC,MAAM,CAAuB;gBAEzB,MAAM,EAAE,oBAAoB,EAAE,MAAM,SAAO;IAMjD,OAAO,CAAC,IAAI,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,GAAG,OAAO,CAAC,cAAc,CAAC;IAqCvF,OAAO,CAAC,WAAW;CAWpB"}
|