@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,64 +0,0 @@
|
|
|
1
|
-
import { JUDGE_PROMPT } from "./prompts.js";
|
|
2
|
-
export async function runDebateVerification(findings, model, config, memory) {
|
|
3
|
-
const result = [];
|
|
4
|
-
// Check memory suppression first — auto-dismiss permanently suppressed patterns
|
|
5
|
-
const unsuppressed = [];
|
|
6
|
-
for (const f of findings) {
|
|
7
|
-
if (memory && memory.isSuppressed(f.agent, f.category, f.message)) {
|
|
8
|
-
result.push({ ...f, debateVerdict: "dismissed" });
|
|
9
|
-
}
|
|
10
|
-
else {
|
|
11
|
-
unsuppressed.push(f);
|
|
12
|
-
}
|
|
13
|
-
}
|
|
14
|
-
const errors = unsuppressed.filter(f => f.severity === "error");
|
|
15
|
-
const nonErrors = unsuppressed.filter(f => f.severity !== "error");
|
|
16
|
-
// Non-errors pass through without debate
|
|
17
|
-
result.push(...nonErrors);
|
|
18
|
-
// Auto-confirm high-confidence errors
|
|
19
|
-
const needsDebate = [];
|
|
20
|
-
for (const f of errors) {
|
|
21
|
-
if (f.confidence >= config.debate_auto_confirm_above) {
|
|
22
|
-
result.push({ ...f, debateVerdict: "confirmed" });
|
|
23
|
-
}
|
|
24
|
-
else {
|
|
25
|
-
needsDebate.push(f);
|
|
26
|
-
}
|
|
27
|
-
}
|
|
28
|
-
// Sort by lowest confidence first
|
|
29
|
-
needsDebate.sort((a, b) => a.confidence - b.confidence);
|
|
30
|
-
// Cap debates
|
|
31
|
-
const toDebate = needsDebate.slice(0, config.max_debates);
|
|
32
|
-
const autoConfirmRest = needsDebate.slice(config.max_debates);
|
|
33
|
-
for (const f of autoConfirmRest) {
|
|
34
|
-
result.push({ ...f, debateVerdict: "confirmed" });
|
|
35
|
-
}
|
|
36
|
-
// Run debates
|
|
37
|
-
for (const finding of toDebate) {
|
|
38
|
-
const verdict = await debateFinding(finding, model);
|
|
39
|
-
result.push({ ...finding, debateVerdict: verdict });
|
|
40
|
-
}
|
|
41
|
-
return result;
|
|
42
|
-
}
|
|
43
|
-
async function debateFinding(finding, model) {
|
|
44
|
-
const context = `File: ${finding.file}:${finding.line}\nSeverity: ${finding.severity}\nCategory: ${finding.category}\nMessage: ${finding.message}\nSuggestion: ${finding.suggestion ?? "none"}\nConfidence: ${finding.confidence}`;
|
|
45
|
-
try {
|
|
46
|
-
const response = await model.chat({
|
|
47
|
-
messages: [{ role: "user", content: `Evaluate this code review finding:\n\n${context}` }],
|
|
48
|
-
systemPrompt: JUDGE_PROMPT,
|
|
49
|
-
});
|
|
50
|
-
const jsonMatch = response.content.match(/\{[\s\S]*\}/);
|
|
51
|
-
if (jsonMatch) {
|
|
52
|
-
const parsed = JSON.parse(jsonMatch[0]);
|
|
53
|
-
if (["confirmed", "dismissed", "downgraded"].includes(parsed.verdict)) {
|
|
54
|
-
return parsed.verdict;
|
|
55
|
-
}
|
|
56
|
-
}
|
|
57
|
-
}
|
|
58
|
-
catch {
|
|
59
|
-
// On failure, auto-confirm (conservative)
|
|
60
|
-
}
|
|
61
|
-
return "confirmed";
|
|
62
|
-
}
|
|
63
|
-
export { PROSECUTOR_PROMPT, DEFENDER_PROMPT, JUDGE_PROMPT } from "./prompts.js";
|
|
64
|
-
//# sourceMappingURL=index.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/sentinel/debate/index.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,4 +0,0 @@
|
|
|
1
|
-
export declare const PROSECUTOR_PROMPT = "You are the Prosecutor in a code review debate.\nYour job: argue that this finding IS a real bug.\nProvide evidence, reproduction steps, and impact analysis.";
|
|
2
|
-
export declare const DEFENDER_PROMPT = "You are the Defender in a code review debate.\nYour job: argue that this finding is NOT a bug or is acceptable.\nProvide counterexamples, context, and reasons the code is correct.";
|
|
3
|
-
export declare const JUDGE_PROMPT = "You are the Judge and Arbitrator in a code review debate.\nEvaluate the finding and render verdict as JSON:\n{\"verdict\": \"confirmed\" | \"dismissed\" | \"downgraded\", \"reasoning\": \"...\"}\n- confirmed: real bug that needs fixing\n- dismissed: false positive or acceptable code\n- downgraded: real but less severe (error \u2192 warning)";
|
|
4
|
-
//# sourceMappingURL=prompts.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"prompts.d.ts","sourceRoot":"","sources":["../../../src/sentinel/debate/prompts.ts"],"names":[],"mappings":"AAAA,eAAO,MAAM,iBAAiB,kKAE6B,CAAC;AAE5D,eAAO,MAAM,eAAe,wLAEuC,CAAC;AAEpE,eAAO,MAAM,YAAY,2VAK4B,CAAC"}
|
|
@@ -1,13 +0,0 @@
|
|
|
1
|
-
export const PROSECUTOR_PROMPT = `You are the Prosecutor in a code review debate.
|
|
2
|
-
Your job: argue that this finding IS a real bug.
|
|
3
|
-
Provide evidence, reproduction steps, and impact analysis.`;
|
|
4
|
-
export const DEFENDER_PROMPT = `You are the Defender in a code review debate.
|
|
5
|
-
Your job: argue that this finding is NOT a bug or is acceptable.
|
|
6
|
-
Provide counterexamples, context, and reasons the code is correct.`;
|
|
7
|
-
export const JUDGE_PROMPT = `You are the Judge and Arbitrator in a code review debate.
|
|
8
|
-
Evaluate the finding and render verdict as JSON:
|
|
9
|
-
{"verdict": "confirmed" | "dismissed" | "downgraded", "reasoning": "..."}
|
|
10
|
-
- confirmed: real bug that needs fixing
|
|
11
|
-
- dismissed: false positive or acceptable code
|
|
12
|
-
- downgraded: real but less severe (error → warning)`;
|
|
13
|
-
//# sourceMappingURL=prompts.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"prompts.js","sourceRoot":"","sources":["../../../src/sentinel/debate/prompts.ts"],"names":[],"mappings":"AAAA,MAAM,CAAC,MAAM,iBAAiB,GAAG;;2DAE0B,CAAC;AAE5D,MAAM,CAAC,MAAM,eAAe,GAAG;;mEAEoC,CAAC;AAEpE,MAAM,CAAC,MAAM,YAAY,GAAG;;;;;qDAKyB,CAAC"}
|
|
@@ -1,6 +0,0 @@
|
|
|
1
|
-
import type { ONIModel } from "../../models/types.js";
|
|
2
|
-
import type { Finding, SentinelConfig } from "../types.js";
|
|
3
|
-
import type { MemoryStore } from "../memory/index.js";
|
|
4
|
-
export declare function runAutoFix(findings: Finding[], model: ONIModel, config: SentinelConfig, rootDir: string, memory?: MemoryStore): Promise<Finding[]>;
|
|
5
|
-
export { tryDirectFix, tryCreativeFix } from "./strategies.js";
|
|
6
|
-
//# sourceMappingURL=index.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/sentinel/fix/index.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,uBAAuB,CAAC;AACtD,OAAO,KAAK,EAAE,OAAO,EAAE,cAAc,EAAE,MAAM,aAAa,CAAC;AAC3D,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,oBAAoB,CAAC;AAGtD,wBAAsB,UAAU,CAC9B,QAAQ,EAAE,OAAO,EAAE,EACnB,KAAK,EAAE,QAAQ,EACf,MAAM,EAAE,cAAc,EACtB,OAAO,EAAE,MAAM,EACf,MAAM,CAAC,EAAE,WAAW,GACnB,OAAO,CAAC,OAAO,EAAE,CAAC,CAwBpB;AAED,OAAO,EAAE,YAAY,EAAE,cAAc,EAAE,MAAM,iBAAiB,CAAC"}
|
|
@@ -1,27 +0,0 @@
|
|
|
1
|
-
import { tryDirectFix, tryCreativeFix } from "./strategies.js";
|
|
2
|
-
export async function runAutoFix(findings, model, config, rootDir, memory) {
|
|
3
|
-
if (!config.auto_fix)
|
|
4
|
-
return findings;
|
|
5
|
-
return Promise.all(findings.map(async (finding) => {
|
|
6
|
-
// Only fix confirmed findings or non-error findings that weren't dismissed
|
|
7
|
-
if (finding.debateVerdict === "dismissed")
|
|
8
|
-
return finding;
|
|
9
|
-
if (finding.severity === "error" && finding.debateVerdict !== "confirmed")
|
|
10
|
-
return finding;
|
|
11
|
-
const strategies = [tryDirectFix, tryCreativeFix];
|
|
12
|
-
for (const strategy of strategies.slice(0, config.max_fix_attempts)) {
|
|
13
|
-
try {
|
|
14
|
-
const result = await strategy(finding, model);
|
|
15
|
-
if (result) {
|
|
16
|
-
return { ...finding, fixPatch: result.patch, fixStrategy: result.strategy };
|
|
17
|
-
}
|
|
18
|
-
}
|
|
19
|
-
catch {
|
|
20
|
-
continue;
|
|
21
|
-
}
|
|
22
|
-
}
|
|
23
|
-
return finding;
|
|
24
|
-
}));
|
|
25
|
-
}
|
|
26
|
-
export { tryDirectFix, tryCreativeFix } from "./strategies.js";
|
|
27
|
-
//# sourceMappingURL=index.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/sentinel/fix/index.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,YAAY,EAAE,cAAc,EAAE,MAAM,iBAAiB,CAAC;AAE/D,MAAM,CAAC,KAAK,UAAU,UAAU,CAC9B,QAAmB,EACnB,KAAe,EACf,MAAsB,EACtB,OAAe,EACf,MAAoB;IAEpB,IAAI,CAAC,MAAM,CAAC,QAAQ;QAAE,OAAO,QAAQ,CAAC;IAEtC,OAAO,OAAO,CAAC,GAAG,CAChB,QAAQ,CAAC,GAAG,CAAC,KAAK,EAAE,OAAO,EAAE,EAAE;QAC7B,2EAA2E;QAC3E,IAAI,OAAO,CAAC,aAAa,KAAK,WAAW;YAAE,OAAO,OAAO,CAAC;QAC1D,IAAI,OAAO,CAAC,QAAQ,KAAK,OAAO,IAAI,OAAO,CAAC,aAAa,KAAK,WAAW;YAAE,OAAO,OAAO,CAAC;QAE1F,MAAM,UAAU,GAAG,CAAC,YAAY,EAAE,cAAc,CAAC,CAAC;QAClD,KAAK,MAAM,QAAQ,IAAI,UAAU,CAAC,KAAK,CAAC,CAAC,EAAE,MAAM,CAAC,gBAAgB,CAAC,EAAE,CAAC;YACpE,IAAI,CAAC;gBACH,MAAM,MAAM,GAAG,MAAM,QAAQ,CAAC,OAAO,EAAE,KAAK,CAAC,CAAC;gBAC9C,IAAI,MAAM,EAAE,CAAC;oBACX,OAAO,EAAE,GAAG,OAAO,EAAE,QAAQ,EAAE,MAAM,CAAC,KAAK,EAAE,WAAW,EAAE,MAAM,CAAC,QAAQ,EAAE,CAAC;gBAC9E,CAAC;YACH,CAAC;YAAC,MAAM,CAAC;gBACP,SAAS;YACX,CAAC;QACH,CAAC;QAED,OAAO,OAAO,CAAC;IACjB,CAAC,CAAC,CACH,CAAC;AACJ,CAAC;AAED,OAAO,EAAE,YAAY,EAAE,cAAc,EAAE,MAAM,iBAAiB,CAAC"}
|
|
@@ -1,9 +0,0 @@
|
|
|
1
|
-
import type { ONIModel } from "../../models/types.js";
|
|
2
|
-
import type { Finding } from "../types.js";
|
|
3
|
-
export type FixResult = {
|
|
4
|
-
patch: string;
|
|
5
|
-
strategy: "direct" | "pattern" | "creative";
|
|
6
|
-
} | null;
|
|
7
|
-
export declare function tryDirectFix(finding: Finding, model: ONIModel): Promise<FixResult>;
|
|
8
|
-
export declare function tryCreativeFix(finding: Finding, model: ONIModel): Promise<FixResult>;
|
|
9
|
-
//# sourceMappingURL=strategies.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"strategies.d.ts","sourceRoot":"","sources":["../../../src/sentinel/fix/strategies.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,uBAAuB,CAAC;AACtD,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,aAAa,CAAC;AAE3C,MAAM,MAAM,SAAS,GAAG;IAAE,KAAK,EAAE,MAAM,CAAC;IAAC,QAAQ,EAAE,QAAQ,GAAG,SAAS,GAAG,UAAU,CAAA;CAAE,GAAG,IAAI,CAAC;AAE9F,wBAAsB,YAAY,CAAC,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE,QAAQ,GAAG,OAAO,CAAC,SAAS,CAAC,CAcxF;AAED,wBAAsB,cAAc,CAAC,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE,QAAQ,GAAG,OAAO,CAAC,SAAS,CAAC,CAY1F"}
|
|
@@ -1,40 +0,0 @@
|
|
|
1
|
-
export async function tryDirectFix(finding, model) {
|
|
2
|
-
if (!finding.suggestion)
|
|
3
|
-
return null;
|
|
4
|
-
const response = await model.chat({
|
|
5
|
-
messages: [{
|
|
6
|
-
role: "user",
|
|
7
|
-
content: `Generate a unified diff patch to fix this issue:\nFile: ${finding.file}:${finding.line}\nIssue: ${finding.message}\nSuggestion: ${finding.suggestion}\n\nReturn ONLY JSON: {"patch": "unified diff", "explanation": "what changed"}`,
|
|
8
|
-
}],
|
|
9
|
-
systemPrompt: "You are a code fixer. Generate minimal, correct patches.",
|
|
10
|
-
});
|
|
11
|
-
const parsed = tryParseJson(response.content);
|
|
12
|
-
if (parsed?.patch)
|
|
13
|
-
return { patch: String(parsed.patch), strategy: "direct" };
|
|
14
|
-
return null;
|
|
15
|
-
}
|
|
16
|
-
export async function tryCreativeFix(finding, model) {
|
|
17
|
-
const response = await model.chat({
|
|
18
|
-
messages: [{
|
|
19
|
-
role: "user",
|
|
20
|
-
content: `Analyze and fix this code issue:\nFile: ${finding.file}:${finding.line}\nCategory: ${finding.category}\nIssue: ${finding.message}\n\nReturn ONLY JSON: {"patch": "unified diff", "explanation": "root cause and fix"}`,
|
|
21
|
-
}],
|
|
22
|
-
systemPrompt: "You are an expert debugger. Find root causes and generate minimal correct fixes.",
|
|
23
|
-
});
|
|
24
|
-
const parsed = tryParseJson(response.content);
|
|
25
|
-
if (parsed?.patch)
|
|
26
|
-
return { patch: String(parsed.patch), strategy: "creative" };
|
|
27
|
-
return null;
|
|
28
|
-
}
|
|
29
|
-
function tryParseJson(content) {
|
|
30
|
-
try {
|
|
31
|
-
const match = content.match(/\{[\s\S]*\}/);
|
|
32
|
-
if (!match)
|
|
33
|
-
return null;
|
|
34
|
-
return JSON.parse(match[0]);
|
|
35
|
-
}
|
|
36
|
-
catch {
|
|
37
|
-
return null;
|
|
38
|
-
}
|
|
39
|
-
}
|
|
40
|
-
//# sourceMappingURL=strategies.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"strategies.js","sourceRoot":"","sources":["../../../src/sentinel/fix/strategies.ts"],"names":[],"mappings":"AAKA,MAAM,CAAC,KAAK,UAAU,YAAY,CAAC,OAAgB,EAAE,KAAe;IAClE,IAAI,CAAC,OAAO,CAAC,UAAU;QAAE,OAAO,IAAI,CAAC;IAErC,MAAM,QAAQ,GAAG,MAAM,KAAK,CAAC,IAAI,CAAC;QAChC,QAAQ,EAAE,CAAC;gBACT,IAAI,EAAE,MAAM;gBACZ,OAAO,EAAE,2DAA2D,OAAO,CAAC,IAAI,IAAI,OAAO,CAAC,IAAI,YAAY,OAAO,CAAC,OAAO,iBAAiB,OAAO,CAAC,UAAU,gFAAgF;aAC/O,CAAC;QACF,YAAY,EAAE,0DAA0D;KACzE,CAAC,CAAC;IAEH,MAAM,MAAM,GAAG,YAAY,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC;IAC9C,IAAI,MAAM,EAAE,KAAK;QAAE,OAAO,EAAE,KAAK,EAAE,MAAM,CAAC,MAAM,CAAC,KAAK,CAAC,EAAE,QAAQ,EAAE,QAAQ,EAAE,CAAC;IAC9E,OAAO,IAAI,CAAC;AACd,CAAC;AAED,MAAM,CAAC,KAAK,UAAU,cAAc,CAAC,OAAgB,EAAE,KAAe;IACpE,MAAM,QAAQ,GAAG,MAAM,KAAK,CAAC,IAAI,CAAC;QAChC,QAAQ,EAAE,CAAC;gBACT,IAAI,EAAE,MAAM;gBACZ,OAAO,EAAE,2CAA2C,OAAO,CAAC,IAAI,IAAI,OAAO,CAAC,IAAI,eAAe,OAAO,CAAC,QAAQ,YAAY,OAAO,CAAC,OAAO,sFAAsF;aACjO,CAAC;QACF,YAAY,EAAE,kFAAkF;KACjG,CAAC,CAAC;IAEH,MAAM,MAAM,GAAG,YAAY,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC;IAC9C,IAAI,MAAM,EAAE,KAAK;QAAE,OAAO,EAAE,KAAK,EAAE,MAAM,CAAC,MAAM,CAAC,KAAK,CAAC,EAAE,QAAQ,EAAE,UAAU,EAAE,CAAC;IAChF,OAAO,IAAI,CAAC;AACd,CAAC;AAED,SAAS,YAAY,CAAC,OAAe;IACnC,IAAI,CAAC;QACH,MAAM,KAAK,GAAG,OAAO,CAAC,KAAK,CAAC,aAAa,CAAC,CAAC;QAC3C,IAAI,CAAC,KAAK;YAAE,OAAO,IAAI,CAAC;QACxB,OAAO,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC;IAC9B,CAAC;IAAC,MAAM,CAAC;QACP,OAAO,IAAI,CAAC;IACd,CAAC;AACH,CAAC"}
|
package/dist/sentinel/index.d.ts
DELETED
|
@@ -1,14 +0,0 @@
|
|
|
1
|
-
export { Sentinel } from "./sentinel.js";
|
|
2
|
-
export { parseConfig, DEFAULT_CONFIG } from "./config/index.js";
|
|
3
|
-
export { triageFiles, computeRiskScore, assignTier, createAllAnalyzers } from "./triage/index.js";
|
|
4
|
-
export { CustomAnalyzer } from "./triage/analyzers/custom-analyzer.js";
|
|
5
|
-
export { extractImports, extractFunctions, extractExports } from "./triage/analyzers/ts-parser.js";
|
|
6
|
-
export type { ImportInfo, FunctionInfo, ExportInfo } from "./triage/analyzers/ts-parser.js";
|
|
7
|
-
export { runSwarmReview, selectTopology, SPECIALIST_IDS, getAgentPrompt } from "./swarm/index.js";
|
|
8
|
-
export { runDebateVerification } from "./debate/index.js";
|
|
9
|
-
export { runAutoFix } from "./fix/index.js";
|
|
10
|
-
export { formatReport } from "./report/index.js";
|
|
11
|
-
export { MemoryStore } from "./memory/index.js";
|
|
12
|
-
export { parseSentinelArgs } from "./integrations/cli.js";
|
|
13
|
-
export type { Finding, FileScore, SentinelConfig, SentinelReport, Severity, Category, Tier, DebateVerdict, FixStrategy, Analyzer, AnalyzerResult, ScanOptions, PRReviewOptions, SentinelOptions, ReportFormat, ReportSummary, SwarmReviewConfig, MemoryPattern, FixPattern, ReviewRecord, CustomAnalyzerConfig, } from "./types.js";
|
|
14
|
-
//# sourceMappingURL=index.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/sentinel/index.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,QAAQ,EAAE,MAAM,eAAe,CAAC;AACzC,OAAO,EAAE,WAAW,EAAE,cAAc,EAAE,MAAM,mBAAmB,CAAC;AAGhE,OAAO,EAAE,WAAW,EAAE,gBAAgB,EAAE,UAAU,EAAE,kBAAkB,EAAE,MAAM,mBAAmB,CAAC;AAGlG,OAAO,EAAE,cAAc,EAAE,MAAM,uCAAuC,CAAC;AAGvE,OAAO,EAAE,cAAc,EAAE,gBAAgB,EAAE,cAAc,EAAE,MAAM,iCAAiC,CAAC;AACnG,YAAY,EAAE,UAAU,EAAE,YAAY,EAAE,UAAU,EAAE,MAAM,iCAAiC,CAAC;AAG5F,OAAO,EAAE,cAAc,EAAE,cAAc,EAAE,cAAc,EAAE,cAAc,EAAE,MAAM,kBAAkB,CAAC;AAGlG,OAAO,EAAE,qBAAqB,EAAE,MAAM,mBAAmB,CAAC;AAG1D,OAAO,EAAE,UAAU,EAAE,MAAM,gBAAgB,CAAC;AAG5C,OAAO,EAAE,YAAY,EAAE,MAAM,mBAAmB,CAAC;AAGjD,OAAO,EAAE,WAAW,EAAE,MAAM,mBAAmB,CAAC;AAGhD,OAAO,EAAE,iBAAiB,EAAE,MAAM,uBAAuB,CAAC;AAG1D,YAAY,EACV,OAAO,EAAE,SAAS,EAAE,cAAc,EAAE,cAAc,EAClD,QAAQ,EAAE,QAAQ,EAAE,IAAI,EAAE,aAAa,EAAE,WAAW,EACpD,QAAQ,EAAE,cAAc,EAAE,WAAW,EAAE,eAAe,EACtD,eAAe,EAAE,YAAY,EAAE,aAAa,EAC5C,iBAAiB,EAAE,aAAa,EAAE,UAAU,EAAE,YAAY,EAC1D,oBAAoB,GACrB,MAAM,YAAY,CAAC"}
|
package/dist/sentinel/index.js
DELETED
|
@@ -1,22 +0,0 @@
|
|
|
1
|
-
// Core
|
|
2
|
-
export { Sentinel } from "./sentinel.js";
|
|
3
|
-
export { parseConfig, DEFAULT_CONFIG } from "./config/index.js";
|
|
4
|
-
// Triage
|
|
5
|
-
export { triageFiles, computeRiskScore, assignTier, createAllAnalyzers } from "./triage/index.js";
|
|
6
|
-
// Triage — Custom analyzer
|
|
7
|
-
export { CustomAnalyzer } from "./triage/analyzers/custom-analyzer.js";
|
|
8
|
-
// Triage — AST utilities
|
|
9
|
-
export { extractImports, extractFunctions, extractExports } from "./triage/analyzers/ts-parser.js";
|
|
10
|
-
// Swarm
|
|
11
|
-
export { runSwarmReview, selectTopology, SPECIALIST_IDS, getAgentPrompt } from "./swarm/index.js";
|
|
12
|
-
// Debate
|
|
13
|
-
export { runDebateVerification } from "./debate/index.js";
|
|
14
|
-
// Fix
|
|
15
|
-
export { runAutoFix } from "./fix/index.js";
|
|
16
|
-
// Report
|
|
17
|
-
export { formatReport } from "./report/index.js";
|
|
18
|
-
// Memory
|
|
19
|
-
export { MemoryStore } from "./memory/index.js";
|
|
20
|
-
// CLI
|
|
21
|
-
export { parseSentinelArgs } from "./integrations/cli.js";
|
|
22
|
-
//# sourceMappingURL=index.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/sentinel/index.ts"],"names":[],"mappings":"AAAA,OAAO;AACP,OAAO,EAAE,QAAQ,EAAE,MAAM,eAAe,CAAC;AACzC,OAAO,EAAE,WAAW,EAAE,cAAc,EAAE,MAAM,mBAAmB,CAAC;AAEhE,SAAS;AACT,OAAO,EAAE,WAAW,EAAE,gBAAgB,EAAE,UAAU,EAAE,kBAAkB,EAAE,MAAM,mBAAmB,CAAC;AAElG,2BAA2B;AAC3B,OAAO,EAAE,cAAc,EAAE,MAAM,uCAAuC,CAAC;AAEvE,yBAAyB;AACzB,OAAO,EAAE,cAAc,EAAE,gBAAgB,EAAE,cAAc,EAAE,MAAM,iCAAiC,CAAC;AAGnG,QAAQ;AACR,OAAO,EAAE,cAAc,EAAE,cAAc,EAAE,cAAc,EAAE,cAAc,EAAE,MAAM,kBAAkB,CAAC;AAElG,SAAS;AACT,OAAO,EAAE,qBAAqB,EAAE,MAAM,mBAAmB,CAAC;AAE1D,MAAM;AACN,OAAO,EAAE,UAAU,EAAE,MAAM,gBAAgB,CAAC;AAE5C,SAAS;AACT,OAAO,EAAE,YAAY,EAAE,MAAM,mBAAmB,CAAC;AAEjD,SAAS;AACT,OAAO,EAAE,WAAW,EAAE,MAAM,mBAAmB,CAAC;AAEhD,MAAM;AACN,OAAO,EAAE,iBAAiB,EAAE,MAAM,uBAAuB,CAAC"}
|
|
@@ -1,10 +0,0 @@
|
|
|
1
|
-
import type { ReportFormat } from "../types.js";
|
|
2
|
-
export interface SentinelArgs {
|
|
3
|
-
command: "scan" | "gate" | "apply";
|
|
4
|
-
paths: string[];
|
|
5
|
-
format: ReportFormat;
|
|
6
|
-
configPath?: string;
|
|
7
|
-
autoFix?: boolean;
|
|
8
|
-
}
|
|
9
|
-
export declare function parseSentinelArgs(argv: string[]): SentinelArgs;
|
|
10
|
-
//# sourceMappingURL=cli.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"cli.d.ts","sourceRoot":"","sources":["../../../src/sentinel/integrations/cli.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,aAAa,CAAC;AAEhD,MAAM,WAAW,YAAY;IAC3B,OAAO,EAAE,MAAM,GAAG,MAAM,GAAG,OAAO,CAAC;IACnC,KAAK,EAAE,MAAM,EAAE,CAAC;IAChB,MAAM,EAAE,YAAY,CAAC;IACrB,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,OAAO,CAAC,EAAE,OAAO,CAAC;CACnB;AAED,wBAAgB,iBAAiB,CAAC,IAAI,EAAE,MAAM,EAAE,GAAG,YAAY,CAgB9D"}
|
|
@@ -1,24 +0,0 @@
|
|
|
1
|
-
export function parseSentinelArgs(argv) {
|
|
2
|
-
const command = (argv[0] ?? "scan");
|
|
3
|
-
const paths = [];
|
|
4
|
-
let format = "console";
|
|
5
|
-
let configPath;
|
|
6
|
-
let autoFix;
|
|
7
|
-
for (let i = 1; i < argv.length; i++) {
|
|
8
|
-
const arg = argv[i];
|
|
9
|
-
if (arg === "--format" && argv[i + 1]) {
|
|
10
|
-
format = argv[++i];
|
|
11
|
-
}
|
|
12
|
-
else if (arg === "--config" && argv[i + 1]) {
|
|
13
|
-
configPath = argv[++i];
|
|
14
|
-
}
|
|
15
|
-
else if (arg === "--fix") {
|
|
16
|
-
autoFix = true;
|
|
17
|
-
}
|
|
18
|
-
else if (!arg.startsWith("--")) {
|
|
19
|
-
paths.push(arg);
|
|
20
|
-
}
|
|
21
|
-
}
|
|
22
|
-
return { command, paths, format, configPath, autoFix };
|
|
23
|
-
}
|
|
24
|
-
//# sourceMappingURL=cli.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"cli.js","sourceRoot":"","sources":["../../../src/sentinel/integrations/cli.ts"],"names":[],"mappings":"AAUA,MAAM,UAAU,iBAAiB,CAAC,IAAc;IAC9C,MAAM,OAAO,GAAG,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,MAAM,CAA4B,CAAC;IAC/D,MAAM,KAAK,GAAa,EAAE,CAAC;IAC3B,IAAI,MAAM,GAAiB,SAAS,CAAC;IACrC,IAAI,UAA8B,CAAC;IACnC,IAAI,OAA4B,CAAC;IAEjC,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE,CAAC;QACrC,MAAM,GAAG,GAAG,IAAI,CAAC,CAAC,CAAC,CAAC;QACpB,IAAI,GAAG,KAAK,UAAU,IAAI,IAAI,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC;YAAC,MAAM,GAAG,IAAI,CAAC,EAAE,CAAC,CAAiB,CAAC;QAAC,CAAC;aACzE,IAAI,GAAG,KAAK,UAAU,IAAI,IAAI,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC;YAAC,UAAU,GAAG,IAAI,CAAC,EAAE,CAAC,CAAC,CAAC;QAAC,CAAC;aAClE,IAAI,GAAG,KAAK,OAAO,EAAE,CAAC;YAAC,OAAO,GAAG,IAAI,CAAC;QAAC,CAAC;aACxC,IAAI,CAAC,GAAG,CAAC,UAAU,CAAC,IAAI,CAAC,EAAE,CAAC;YAAC,KAAK,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;QAAC,CAAC;IACtD,CAAC;IAED,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE,MAAM,EAAE,UAAU,EAAE,OAAO,EAAE,CAAC;AACzD,CAAC"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/sentinel/integrations/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,iBAAiB,EAAE,KAAK,YAAY,EAAE,MAAM,UAAU,CAAC"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/sentinel/integrations/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,iBAAiB,EAAqB,MAAM,UAAU,CAAC"}
|
|
@@ -1,16 +0,0 @@
|
|
|
1
|
-
import type { MemoryPattern, FixPattern, ReviewRecord } from "../types.js";
|
|
2
|
-
export declare class MemoryStore {
|
|
3
|
-
private falsePositives;
|
|
4
|
-
private fixPatterns;
|
|
5
|
-
private reviews;
|
|
6
|
-
recordFalsePositive(analyzer: string, rule: string, codeShape: string): void;
|
|
7
|
-
isSuppressed(analyzer: string, rule: string, codeShape: string): boolean;
|
|
8
|
-
getFalsePositives(): MemoryPattern[];
|
|
9
|
-
recordFix(category: string, beforeHash: string, afterHash: string, patch: string): void;
|
|
10
|
-
getFixPatterns(category: string): FixPattern[];
|
|
11
|
-
recordReview(data: Omit<ReviewRecord, "id" | "timestamp">): void;
|
|
12
|
-
getReviewHistory(): ReviewRecord[];
|
|
13
|
-
toJSON(): string;
|
|
14
|
-
static fromJSON(json: string): MemoryStore;
|
|
15
|
-
}
|
|
16
|
-
//# sourceMappingURL=index.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/sentinel/memory/index.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,aAAa,EAAE,UAAU,EAAE,YAAY,EAAY,MAAM,aAAa,CAAC;AAErF,qBAAa,WAAW;IACtB,OAAO,CAAC,cAAc,CAAuB;IAC7C,OAAO,CAAC,WAAW,CAAoB;IACvC,OAAO,CAAC,OAAO,CAAsB;IAErC,mBAAmB,CAAC,QAAQ,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,GAAG,IAAI;IAmB5E,YAAY,CAAC,QAAQ,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,GAAG,OAAO;IAMxE,iBAAiB,IAAI,aAAa,EAAE;IAEpC,SAAS,CAAC,QAAQ,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,GAAG,IAAI;IASvF,cAAc,CAAC,QAAQ,EAAE,MAAM,GAAG,UAAU,EAAE;IAI9C,YAAY,CAAC,IAAI,EAAE,IAAI,CAAC,YAAY,EAAE,IAAI,GAAG,WAAW,CAAC,GAAG,IAAI;IAOhE,gBAAgB,IAAI,YAAY,EAAE;IAElC,MAAM,IAAI,MAAM;IAQhB,MAAM,CAAC,QAAQ,CAAC,IAAI,EAAE,MAAM,GAAG,WAAW;CAQ3C"}
|
|
@@ -1,60 +0,0 @@
|
|
|
1
|
-
export class MemoryStore {
|
|
2
|
-
falsePositives = [];
|
|
3
|
-
fixPatterns = [];
|
|
4
|
-
reviews = [];
|
|
5
|
-
recordFalsePositive(analyzer, rule, codeShape) {
|
|
6
|
-
const existing = this.falsePositives.find(p => p.analyzer === analyzer && p.rule === rule && p.codeShape === codeShape);
|
|
7
|
-
if (existing) {
|
|
8
|
-
existing.suppressions++;
|
|
9
|
-
existing.updatedAt = Date.now();
|
|
10
|
-
existing.permanent = existing.suppressions >= 3;
|
|
11
|
-
}
|
|
12
|
-
else {
|
|
13
|
-
this.falsePositives.push({
|
|
14
|
-
id: `fp-${Date.now()}-${Math.random().toString(36).slice(2, 8)}`,
|
|
15
|
-
type: "false_positive",
|
|
16
|
-
analyzer, rule, codeShape,
|
|
17
|
-
suppressions: 1, permanent: false,
|
|
18
|
-
createdAt: Date.now(), updatedAt: Date.now(),
|
|
19
|
-
});
|
|
20
|
-
}
|
|
21
|
-
}
|
|
22
|
-
isSuppressed(analyzer, rule, codeShape) {
|
|
23
|
-
return this.falsePositives.some(p => p.permanent && p.analyzer === analyzer && p.rule === rule && p.codeShape === codeShape);
|
|
24
|
-
}
|
|
25
|
-
getFalsePositives() { return [...this.falsePositives]; }
|
|
26
|
-
recordFix(category, beforeHash, afterHash, patch) {
|
|
27
|
-
this.fixPatterns.push({
|
|
28
|
-
id: `fix-${Date.now()}-${Math.random().toString(36).slice(2, 8)}`,
|
|
29
|
-
category: category,
|
|
30
|
-
beforeHash, afterHash, patch,
|
|
31
|
-
successCount: 1, createdAt: Date.now(),
|
|
32
|
-
});
|
|
33
|
-
}
|
|
34
|
-
getFixPatterns(category) {
|
|
35
|
-
return this.fixPatterns.filter(f => f.category === category);
|
|
36
|
-
}
|
|
37
|
-
recordReview(data) {
|
|
38
|
-
this.reviews.push({
|
|
39
|
-
id: `rev-${Date.now()}-${Math.random().toString(36).slice(2, 8)}`,
|
|
40
|
-
timestamp: Date.now(), ...data,
|
|
41
|
-
});
|
|
42
|
-
}
|
|
43
|
-
getReviewHistory() { return [...this.reviews]; }
|
|
44
|
-
toJSON() {
|
|
45
|
-
return JSON.stringify({
|
|
46
|
-
falsePositives: this.falsePositives,
|
|
47
|
-
fixPatterns: this.fixPatterns,
|
|
48
|
-
reviews: this.reviews,
|
|
49
|
-
});
|
|
50
|
-
}
|
|
51
|
-
static fromJSON(json) {
|
|
52
|
-
const store = new MemoryStore();
|
|
53
|
-
const data = JSON.parse(json);
|
|
54
|
-
store.falsePositives = data.falsePositives ?? [];
|
|
55
|
-
store.fixPatterns = data.fixPatterns ?? [];
|
|
56
|
-
store.reviews = data.reviews ?? [];
|
|
57
|
-
return store;
|
|
58
|
-
}
|
|
59
|
-
}
|
|
60
|
-
//# sourceMappingURL=index.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/sentinel/memory/index.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"console.d.ts","sourceRoot":"","sources":["../../../src/sentinel/report/console.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,aAAa,CAAC;AAIlD,wBAAgB,aAAa,CAAC,MAAM,EAAE,cAAc,GAAG,MAAM,CAwB5D"}
|
|
@@ -1,27 +0,0 @@
|
|
|
1
|
-
const SEVERITY_ICONS = { error: "E", warning: "W", info: "I" };
|
|
2
|
-
export function formatConsole(report) {
|
|
3
|
-
const lines = [];
|
|
4
|
-
lines.push("=== ONI Sentinel Report ===");
|
|
5
|
-
lines.push(`Files: ${report.summary.filesScanned} scanned, ${report.summary.filesSkipped} skipped`);
|
|
6
|
-
lines.push(`Findings: ${report.summary.totalFindings} (${report.summary.bySeverity.error} errors, ${report.summary.bySeverity.warning} warnings, ${report.summary.bySeverity.info} info)`);
|
|
7
|
-
lines.push(`Duration: ${report.duration}ms`);
|
|
8
|
-
lines.push("");
|
|
9
|
-
if (report.findings.length === 0) {
|
|
10
|
-
lines.push("No findings.");
|
|
11
|
-
return lines.join("\n");
|
|
12
|
-
}
|
|
13
|
-
for (const f of report.findings) {
|
|
14
|
-
const icon = SEVERITY_ICONS[f.severity] ?? "?";
|
|
15
|
-
lines.push(`[${icon}] ${f.file}:${f.line} — ${f.message}`);
|
|
16
|
-
lines.push(` Category: ${f.category} | Agent: ${f.agent} | Confidence: ${(f.confidence * 100).toFixed(0)}%`);
|
|
17
|
-
if (f.suggestion)
|
|
18
|
-
lines.push(` Suggestion: ${f.suggestion}`);
|
|
19
|
-
if (f.debateVerdict)
|
|
20
|
-
lines.push(` Verdict: ${f.debateVerdict}`);
|
|
21
|
-
if (f.fixPatch)
|
|
22
|
-
lines.push(` Fix: patch available (${f.fixStrategy})`);
|
|
23
|
-
lines.push("");
|
|
24
|
-
}
|
|
25
|
-
return lines.join("\n");
|
|
26
|
-
}
|
|
27
|
-
//# sourceMappingURL=console.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"console.js","sourceRoot":"","sources":["../../../src/sentinel/report/console.ts"],"names":[],"mappings":"AAEA,MAAM,cAAc,GAA2B,EAAE,KAAK,EAAE,GAAG,EAAE,OAAO,EAAE,GAAG,EAAE,IAAI,EAAE,GAAG,EAAE,CAAC;AAEvF,MAAM,UAAU,aAAa,CAAC,MAAsB;IAClD,MAAM,KAAK,GAAa,EAAE,CAAC;IAC3B,KAAK,CAAC,IAAI,CAAC,6BAA6B,CAAC,CAAC;IAC1C,KAAK,CAAC,IAAI,CAAC,UAAU,MAAM,CAAC,OAAO,CAAC,YAAY,aAAa,MAAM,CAAC,OAAO,CAAC,YAAY,UAAU,CAAC,CAAC;IACpG,KAAK,CAAC,IAAI,CAAC,aAAa,MAAM,CAAC,OAAO,CAAC,aAAa,KAAK,MAAM,CAAC,OAAO,CAAC,UAAU,CAAC,KAAK,YAAY,MAAM,CAAC,OAAO,CAAC,UAAU,CAAC,OAAO,cAAc,MAAM,CAAC,OAAO,CAAC,UAAU,CAAC,IAAI,QAAQ,CAAC,CAAC;IAC3L,KAAK,CAAC,IAAI,CAAC,aAAa,MAAM,CAAC,QAAQ,IAAI,CAAC,CAAC;IAC7C,KAAK,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;IAEf,IAAI,MAAM,CAAC,QAAQ,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;QACjC,KAAK,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;QAC3B,OAAO,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAC1B,CAAC;IAED,KAAK,MAAM,CAAC,IAAI,MAAM,CAAC,QAAQ,EAAE,CAAC;QAChC,MAAM,IAAI,GAAG,cAAc,CAAC,CAAC,CAAC,QAAQ,CAAC,IAAI,GAAG,CAAC;QAC/C,KAAK,CAAC,IAAI,CAAC,IAAI,IAAI,KAAK,CAAC,CAAC,IAAI,IAAI,CAAC,CAAC,IAAI,MAAM,CAAC,CAAC,OAAO,EAAE,CAAC,CAAC;QAC3D,KAAK,CAAC,IAAI,CAAC,iBAAiB,CAAC,CAAC,QAAQ,aAAa,CAAC,CAAC,KAAK,kBAAkB,CAAC,CAAC,CAAC,UAAU,GAAG,GAAG,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC;QAChH,IAAI,CAAC,CAAC,UAAU;YAAE,KAAK,CAAC,IAAI,CAAC,mBAAmB,CAAC,CAAC,UAAU,EAAE,CAAC,CAAC;QAChE,IAAI,CAAC,CAAC,aAAa;YAAE,KAAK,CAAC,IAAI,CAAC,gBAAgB,CAAC,CAAC,aAAa,EAAE,CAAC,CAAC;QACnE,IAAI,CAAC,CAAC,QAAQ;YAAE,KAAK,CAAC,IAAI,CAAC,6BAA6B,CAAC,CAAC,WAAW,GAAG,CAAC,CAAC;QAC1E,KAAK,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;IACjB,CAAC;IAED,OAAO,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;AAC1B,CAAC"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"github.d.ts","sourceRoot":"","sources":["../../../src/sentinel/report/github.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,aAAa,CAAC;AAElD,wBAAgB,YAAY,CAAC,MAAM,EAAE,cAAc,GAAG,MAAM,CAoC3D"}
|
|
@@ -1,36 +0,0 @@
|
|
|
1
|
-
export function formatGitHub(report) {
|
|
2
|
-
const lines = [];
|
|
3
|
-
lines.push("## ONI Sentinel Report");
|
|
4
|
-
lines.push("");
|
|
5
|
-
lines.push(`| Metric | Value |`);
|
|
6
|
-
lines.push(`|--------|-------|`);
|
|
7
|
-
lines.push(`| Files scanned | ${report.summary.filesScanned} |`);
|
|
8
|
-
lines.push(`| Total findings | ${report.summary.totalFindings} |`);
|
|
9
|
-
lines.push(`| Errors | ${report.summary.bySeverity.error} |`);
|
|
10
|
-
lines.push(`| Warnings | ${report.summary.bySeverity.warning} |`);
|
|
11
|
-
lines.push(`| Info | ${report.summary.bySeverity.info} |`);
|
|
12
|
-
lines.push(`| Duration | ${report.duration}ms |`);
|
|
13
|
-
lines.push("");
|
|
14
|
-
if (report.findings.length === 0) {
|
|
15
|
-
lines.push("No findings.");
|
|
16
|
-
return lines.join("\n");
|
|
17
|
-
}
|
|
18
|
-
lines.push("### Findings");
|
|
19
|
-
lines.push("");
|
|
20
|
-
for (const f of report.findings) {
|
|
21
|
-
const severity = f.severity === "error" ? "**ERROR**" : f.severity === "warning" ? "WARNING" : "info";
|
|
22
|
-
lines.push(`#### ${severity}: ${f.message}`);
|
|
23
|
-
lines.push(`**${f.file}:${f.line}** — ${f.category} (${(f.confidence * 100).toFixed(0)}% confidence)`);
|
|
24
|
-
if (f.suggestion)
|
|
25
|
-
lines.push(`> ${f.suggestion}`);
|
|
26
|
-
if (f.fixPatch) {
|
|
27
|
-
lines.push("");
|
|
28
|
-
lines.push("```suggestion");
|
|
29
|
-
lines.push(f.fixPatch);
|
|
30
|
-
lines.push("```");
|
|
31
|
-
}
|
|
32
|
-
lines.push("");
|
|
33
|
-
}
|
|
34
|
-
return lines.join("\n");
|
|
35
|
-
}
|
|
36
|
-
//# sourceMappingURL=github.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"github.js","sourceRoot":"","sources":["../../../src/sentinel/report/github.ts"],"names":[],"mappings":"AAEA,MAAM,UAAU,YAAY,CAAC,MAAsB;IACjD,MAAM,KAAK,GAAa,EAAE,CAAC;IAC3B,KAAK,CAAC,IAAI,CAAC,wBAAwB,CAAC,CAAC;IACrC,KAAK,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;IACf,KAAK,CAAC,IAAI,CAAC,oBAAoB,CAAC,CAAC;IACjC,KAAK,CAAC,IAAI,CAAC,oBAAoB,CAAC,CAAC;IACjC,KAAK,CAAC,IAAI,CAAC,qBAAqB,MAAM,CAAC,OAAO,CAAC,YAAY,IAAI,CAAC,CAAC;IACjE,KAAK,CAAC,IAAI,CAAC,sBAAsB,MAAM,CAAC,OAAO,CAAC,aAAa,IAAI,CAAC,CAAC;IACnE,KAAK,CAAC,IAAI,CAAC,cAAc,MAAM,CAAC,OAAO,CAAC,UAAU,CAAC,KAAK,IAAI,CAAC,CAAC;IAC9D,KAAK,CAAC,IAAI,CAAC,gBAAgB,MAAM,CAAC,OAAO,CAAC,UAAU,CAAC,OAAO,IAAI,CAAC,CAAC;IAClE,KAAK,CAAC,IAAI,CAAC,YAAY,MAAM,CAAC,OAAO,CAAC,UAAU,CAAC,IAAI,IAAI,CAAC,CAAC;IAC3D,KAAK,CAAC,IAAI,CAAC,gBAAgB,MAAM,CAAC,QAAQ,MAAM,CAAC,CAAC;IAClD,KAAK,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;IAEf,IAAI,MAAM,CAAC,QAAQ,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;QACjC,KAAK,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;QAC3B,OAAO,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAC1B,CAAC;IAED,KAAK,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;IAC3B,KAAK,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;IACf,KAAK,MAAM,CAAC,IAAI,MAAM,CAAC,QAAQ,EAAE,CAAC;QAChC,MAAM,QAAQ,GAAG,CAAC,CAAC,QAAQ,KAAK,OAAO,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,CAAC,QAAQ,KAAK,SAAS,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,MAAM,CAAC;QACtG,KAAK,CAAC,IAAI,CAAC,QAAQ,QAAQ,KAAK,CAAC,CAAC,OAAO,EAAE,CAAC,CAAC;QAC7C,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,IAAI,IAAI,CAAC,CAAC,IAAI,QAAQ,CAAC,CAAC,QAAQ,KAAK,CAAC,CAAC,CAAC,UAAU,GAAG,GAAG,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,eAAe,CAAC,CAAC;QACvG,IAAI,CAAC,CAAC,UAAU;YAAE,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,UAAU,EAAE,CAAC,CAAC;QAClD,IAAI,CAAC,CAAC,QAAQ,EAAE,CAAC;YACf,KAAK,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;YACf,KAAK,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC;YAC5B,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC;YACvB,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QACpB,CAAC;QACD,KAAK,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;IACjB,CAAC;IAED,OAAO,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;AAC1B,CAAC"}
|
|
@@ -1,6 +0,0 @@
|
|
|
1
|
-
import type { SentinelReport, ReportFormat } from "../types.js";
|
|
2
|
-
export declare function formatReport(report: SentinelReport, format: ReportFormat): string;
|
|
3
|
-
export { formatConsole } from "./console.js";
|
|
4
|
-
export { formatSarif } from "./sarif.js";
|
|
5
|
-
export { formatGitHub } from "./github.js";
|
|
6
|
-
//# sourceMappingURL=index.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/sentinel/report/index.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,cAAc,EAAE,YAAY,EAAE,MAAM,aAAa,CAAC;AAKhE,wBAAgB,YAAY,CAAC,MAAM,EAAE,cAAc,EAAE,MAAM,EAAE,YAAY,GAAG,MAAM,CAOjF;AAED,OAAO,EAAE,aAAa,EAAE,MAAM,cAAc,CAAC;AAC7C,OAAO,EAAE,WAAW,EAAE,MAAM,YAAY,CAAC;AACzC,OAAO,EAAE,YAAY,EAAE,MAAM,aAAa,CAAC"}
|
|
@@ -1,15 +0,0 @@
|
|
|
1
|
-
import { formatConsole } from "./console.js";
|
|
2
|
-
import { formatSarif } from "./sarif.js";
|
|
3
|
-
import { formatGitHub } from "./github.js";
|
|
4
|
-
export function formatReport(report, format) {
|
|
5
|
-
switch (format) {
|
|
6
|
-
case "console": return formatConsole(report);
|
|
7
|
-
case "sarif": return formatSarif(report);
|
|
8
|
-
case "json": return JSON.stringify(report, null, 2);
|
|
9
|
-
case "github": return formatGitHub(report);
|
|
10
|
-
}
|
|
11
|
-
}
|
|
12
|
-
export { formatConsole } from "./console.js";
|
|
13
|
-
export { formatSarif } from "./sarif.js";
|
|
14
|
-
export { formatGitHub } from "./github.js";
|
|
15
|
-
//# sourceMappingURL=index.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/sentinel/report/index.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,aAAa,EAAE,MAAM,cAAc,CAAC;AAC7C,OAAO,EAAE,WAAW,EAAE,MAAM,YAAY,CAAC;AACzC,OAAO,EAAE,YAAY,EAAE,MAAM,aAAa,CAAC;AAE3C,MAAM,UAAU,YAAY,CAAC,MAAsB,EAAE,MAAoB;IACvE,QAAQ,MAAM,EAAE,CAAC;QACf,KAAK,SAAS,CAAC,CAAC,OAAO,aAAa,CAAC,MAAM,CAAC,CAAC;QAC7C,KAAK,OAAO,CAAC,CAAC,OAAO,WAAW,CAAC,MAAM,CAAC,CAAC;QACzC,KAAK,MAAM,CAAC,CAAC,OAAO,IAAI,CAAC,SAAS,CAAC,MAAM,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC;QACpD,KAAK,QAAQ,CAAC,CAAC,OAAO,YAAY,CAAC,MAAM,CAAC,CAAC;IAC7C,CAAC;AACH,CAAC;AAED,OAAO,EAAE,aAAa,EAAE,MAAM,cAAc,CAAC;AAC7C,OAAO,EAAE,WAAW,EAAE,MAAM,YAAY,CAAC;AACzC,OAAO,EAAE,YAAY,EAAE,MAAM,aAAa,CAAC"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"sarif.d.ts","sourceRoot":"","sources":["../../../src/sentinel/report/sarif.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,aAAa,CAAC;AAIlD,wBAAgB,WAAW,CAAC,MAAM,EAAE,cAAc,GAAG,MAAM,CA0B1D"}
|
|
@@ -1,29 +0,0 @@
|
|
|
1
|
-
const SEVERITY_MAP = { error: "error", warning: "warning", info: "note" };
|
|
2
|
-
export function formatSarif(report) {
|
|
3
|
-
const sarif = {
|
|
4
|
-
$schema: "https://raw.githubusercontent.com/oasis-tcs/sarif-spec/main/sarif-2.1/schema/sarif-schema-2.1.0.json",
|
|
5
|
-
version: "2.1.0",
|
|
6
|
-
runs: [{
|
|
7
|
-
tool: { driver: { name: "ONI Sentinel", version: "1.0.0", rules: [] } },
|
|
8
|
-
results: report.findings.map(f => ({
|
|
9
|
-
ruleId: `${f.category}/${f.agent}`,
|
|
10
|
-
level: SEVERITY_MAP[f.severity] ?? "note",
|
|
11
|
-
message: { text: f.message },
|
|
12
|
-
locations: [{
|
|
13
|
-
physicalLocation: {
|
|
14
|
-
artifactLocation: { uri: f.file },
|
|
15
|
-
region: { startLine: f.line, ...(f.endLine ? { endLine: f.endLine } : {}) },
|
|
16
|
-
},
|
|
17
|
-
}],
|
|
18
|
-
properties: {
|
|
19
|
-
confidence: f.confidence,
|
|
20
|
-
agent: f.agent,
|
|
21
|
-
...(f.debateVerdict ? { debateVerdict: f.debateVerdict } : {}),
|
|
22
|
-
...(f.fixPatch ? { fixAvailable: true, fixStrategy: f.fixStrategy } : {}),
|
|
23
|
-
},
|
|
24
|
-
})),
|
|
25
|
-
}],
|
|
26
|
-
};
|
|
27
|
-
return JSON.stringify(sarif, null, 2);
|
|
28
|
-
}
|
|
29
|
-
//# sourceMappingURL=sarif.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"sarif.js","sourceRoot":"","sources":["../../../src/sentinel/report/sarif.ts"],"names":[],"mappings":"AAEA,MAAM,YAAY,GAA2B,EAAE,KAAK,EAAE,OAAO,EAAE,OAAO,EAAE,SAAS,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC;AAElG,MAAM,UAAU,WAAW,CAAC,MAAsB;IAChD,MAAM,KAAK,GAAG;QACZ,OAAO,EAAE,sGAAsG;QAC/G,OAAO,EAAE,OAAO;QAChB,IAAI,EAAE,CAAC;gBACL,IAAI,EAAE,EAAE,MAAM,EAAE,EAAE,IAAI,EAAE,cAAc,EAAE,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE,EAAW,EAAE,EAAE;gBAChF,OAAO,EAAE,MAAM,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC;oBACjC,MAAM,EAAE,GAAG,CAAC,CAAC,QAAQ,IAAI,CAAC,CAAC,KAAK,EAAE;oBAClC,KAAK,EAAE,YAAY,CAAC,CAAC,CAAC,QAAQ,CAAC,IAAI,MAAM;oBACzC,OAAO,EAAE,EAAE,IAAI,EAAE,CAAC,CAAC,OAAO,EAAE;oBAC5B,SAAS,EAAE,CAAC;4BACV,gBAAgB,EAAE;gCAChB,gBAAgB,EAAE,EAAE,GAAG,EAAE,CAAC,CAAC,IAAI,EAAE;gCACjC,MAAM,EAAE,EAAE,SAAS,EAAE,CAAC,CAAC,IAAI,EAAE,GAAG,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,OAAO,EAAE,CAAC,CAAC,OAAO,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE;6BAC5E;yBACF,CAAC;oBACF,UAAU,EAAE;wBACV,UAAU,EAAE,CAAC,CAAC,UAAU;wBACxB,KAAK,EAAE,CAAC,CAAC,KAAK;wBACd,GAAG,CAAC,CAAC,CAAC,aAAa,CAAC,CAAC,CAAC,EAAE,aAAa,EAAE,CAAC,CAAC,aAAa,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;wBAC9D,GAAG,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,YAAY,EAAE,IAAI,EAAE,WAAW,EAAE,CAAC,CAAC,WAAW,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;qBAC1E;iBACF,CAAC,CAAC;aACJ,CAAC;KACH,CAAC;IACF,OAAO,IAAI,CAAC,SAAS,CAAC,KAAK,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC;AACxC,CAAC"}
|
|
@@ -1,17 +0,0 @@
|
|
|
1
|
-
import type { SentinelOptions, SentinelConfig, SentinelReport, ScanOptions, PRReviewOptions, Finding } from "./types.js";
|
|
2
|
-
import { MemoryStore } from "./memory/index.js";
|
|
3
|
-
export declare class Sentinel {
|
|
4
|
-
readonly config: SentinelConfig;
|
|
5
|
-
private model;
|
|
6
|
-
private fastModel;
|
|
7
|
-
private rootDir;
|
|
8
|
-
private memory;
|
|
9
|
-
constructor(options: SentinelOptions);
|
|
10
|
-
getMemory(): MemoryStore;
|
|
11
|
-
private discoverFiles;
|
|
12
|
-
scan(options: ScanOptions): Promise<SentinelReport>;
|
|
13
|
-
analyzeFile(filePath: string): Promise<Finding[]>;
|
|
14
|
-
reviewPR(options: PRReviewOptions): Promise<SentinelReport>;
|
|
15
|
-
private buildSummary;
|
|
16
|
-
}
|
|
17
|
-
//# sourceMappingURL=sentinel.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"sentinel.d.ts","sourceRoot":"","sources":["../../src/sentinel/sentinel.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EACV,eAAe,EAAE,cAAc,EAAE,cAAc,EAC/C,WAAW,EAAE,eAAe,EAAE,OAAO,EACtC,MAAM,YAAY,CAAC;AAMpB,OAAO,EAAE,WAAW,EAAE,MAAM,mBAAmB,CAAC;AAIhD,qBAAa,QAAQ;IACnB,QAAQ,CAAC,MAAM,EAAE,cAAc,CAAC;IAChC,OAAO,CAAC,KAAK,CAAW;IACxB,OAAO,CAAC,SAAS,CAAW;IAC5B,OAAO,CAAC,OAAO,CAAS;IACxB,OAAO,CAAC,MAAM,CAAc;gBAEhB,OAAO,EAAE,eAAe;IAYpC,SAAS,IAAI,WAAW;IAIxB,OAAO,CAAC,aAAa;IAyBf,IAAI,CAAC,OAAO,EAAE,WAAW,GAAG,OAAO,CAAC,cAAc,CAAC;IAuBnD,WAAW,CAAC,QAAQ,EAAE,MAAM,GAAG,OAAO,CAAC,OAAO,EAAE,CAAC;IAKjD,QAAQ,CAAC,OAAO,EAAE,eAAe,GAAG,OAAO,CAAC,cAAc,CAAC;IAWjE,OAAO,CAAC,YAAY;CAwBrB"}
|