prism-pr 1.0.0-alpha.47
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/README.md +964 -0
- package/bin/run.js +9 -0
- package/dist/ai/agents/architecture-reviewer.d.ts +3 -0
- package/dist/ai/agents/architecture-reviewer.d.ts.map +1 -0
- package/dist/ai/agents/architecture-reviewer.js +67 -0
- package/dist/ai/agents/architecture-reviewer.js.map +1 -0
- package/dist/ai/agents/blade-reviewer.d.ts +3 -0
- package/dist/ai/agents/blade-reviewer.d.ts.map +1 -0
- package/dist/ai/agents/blade-reviewer.js +59 -0
- package/dist/ai/agents/blade-reviewer.js.map +1 -0
- package/dist/ai/agents/config-reviewer.d.ts +3 -0
- package/dist/ai/agents/config-reviewer.d.ts.map +1 -0
- package/dist/ai/agents/config-reviewer.js +106 -0
- package/dist/ai/agents/config-reviewer.js.map +1 -0
- package/dist/ai/agents/csharp-reviewer.d.ts +3 -0
- package/dist/ai/agents/csharp-reviewer.d.ts.map +1 -0
- package/dist/ai/agents/csharp-reviewer.js +59 -0
- package/dist/ai/agents/csharp-reviewer.js.map +1 -0
- package/dist/ai/agents/css-reviewer.d.ts +3 -0
- package/dist/ai/agents/css-reviewer.d.ts.map +1 -0
- package/dist/ai/agents/css-reviewer.js +65 -0
- package/dist/ai/agents/css-reviewer.js.map +1 -0
- package/dist/ai/agents/framework-rules/index.d.ts +33 -0
- package/dist/ai/agents/framework-rules/index.d.ts.map +1 -0
- package/dist/ai/agents/framework-rules/index.js +67 -0
- package/dist/ai/agents/framework-rules/index.js.map +1 -0
- package/dist/ai/agents/framework-rules/normalize.d.ts +40 -0
- package/dist/ai/agents/framework-rules/normalize.d.ts.map +1 -0
- package/dist/ai/agents/framework-rules/normalize.js +102 -0
- package/dist/ai/agents/framework-rules/normalize.js.map +1 -0
- package/dist/ai/agents/framework-rules/routing-map.d.ts +3 -0
- package/dist/ai/agents/framework-rules/routing-map.d.ts.map +1 -0
- package/dist/ai/agents/framework-rules/routing-map.js +15 -0
- package/dist/ai/agents/framework-rules/routing-map.js.map +1 -0
- package/dist/ai/agents/html-reviewer.d.ts +3 -0
- package/dist/ai/agents/html-reviewer.d.ts.map +1 -0
- package/dist/ai/agents/html-reviewer.js +61 -0
- package/dist/ai/agents/html-reviewer.js.map +1 -0
- package/dist/ai/agents/performance-reviewer.d.ts +3 -0
- package/dist/ai/agents/performance-reviewer.d.ts.map +1 -0
- package/dist/ai/agents/performance-reviewer.js +60 -0
- package/dist/ai/agents/performance-reviewer.js.map +1 -0
- package/dist/ai/agents/php-reviewer.d.ts +3 -0
- package/dist/ai/agents/php-reviewer.d.ts.map +1 -0
- package/dist/ai/agents/php-reviewer.js +62 -0
- package/dist/ai/agents/php-reviewer.js.map +1 -0
- package/dist/ai/agents/prompts/architecture-reviewer.txt +39 -0
- package/dist/ai/agents/prompts/blade-reviewer.txt +39 -0
- package/dist/ai/agents/prompts/config-reviewer.txt +47 -0
- package/dist/ai/agents/prompts/csharp-reviewer.txt +39 -0
- package/dist/ai/agents/prompts/css-reviewer.txt +41 -0
- package/dist/ai/agents/prompts/html-reviewer.txt +43 -0
- package/dist/ai/agents/prompts/performance-reviewer.txt +38 -0
- package/dist/ai/agents/prompts/php-reviewer.txt +87 -0
- package/dist/ai/agents/prompts/python-reviewer.txt +42 -0
- package/dist/ai/agents/prompts/security-reviewer.txt +36 -0
- package/dist/ai/agents/prompts/sql-reviewer.txt +43 -0
- package/dist/ai/agents/prompts/testing-reviewer.txt +38 -0
- package/dist/ai/agents/prompts/ts-reviewer.txt +54 -0
- package/dist/ai/agents/prompts/ux-text-reviewer.txt +68 -0
- package/dist/ai/agents/python-reviewer.d.ts +3 -0
- package/dist/ai/agents/python-reviewer.d.ts.map +1 -0
- package/dist/ai/agents/python-reviewer.js +59 -0
- package/dist/ai/agents/python-reviewer.js.map +1 -0
- package/dist/ai/agents/registry.d.ts +20 -0
- package/dist/ai/agents/registry.d.ts.map +1 -0
- package/dist/ai/agents/registry.js +65 -0
- package/dist/ai/agents/registry.js.map +1 -0
- package/dist/ai/agents/security-reviewer.d.ts +3 -0
- package/dist/ai/agents/security-reviewer.d.ts.map +1 -0
- package/dist/ai/agents/security-reviewer.js +69 -0
- package/dist/ai/agents/security-reviewer.js.map +1 -0
- package/dist/ai/agents/shared/content-builder.d.ts +14 -0
- package/dist/ai/agents/shared/content-builder.d.ts.map +1 -0
- package/dist/ai/agents/shared/content-builder.js +158 -0
- package/dist/ai/agents/shared/content-builder.js.map +1 -0
- package/dist/ai/agents/shared/finding-schema.d.ts +54 -0
- package/dist/ai/agents/shared/finding-schema.d.ts.map +1 -0
- package/dist/ai/agents/shared/finding-schema.js +65 -0
- package/dist/ai/agents/shared/finding-schema.js.map +1 -0
- package/dist/ai/agents/shared/line-validator.d.ts +8 -0
- package/dist/ai/agents/shared/line-validator.d.ts.map +1 -0
- package/dist/ai/agents/shared/line-validator.js +12 -0
- package/dist/ai/agents/shared/line-validator.js.map +1 -0
- package/dist/ai/agents/shared/prompt-builder.d.ts +3 -0
- package/dist/ai/agents/shared/prompt-builder.d.ts.map +1 -0
- package/dist/ai/agents/shared/prompt-builder.js +68 -0
- package/dist/ai/agents/shared/prompt-builder.js.map +1 -0
- package/dist/ai/agents/sql-reviewer.d.ts +3 -0
- package/dist/ai/agents/sql-reviewer.d.ts.map +1 -0
- package/dist/ai/agents/sql-reviewer.js +61 -0
- package/dist/ai/agents/sql-reviewer.js.map +1 -0
- package/dist/ai/agents/testing-reviewer.d.ts +3 -0
- package/dist/ai/agents/testing-reviewer.d.ts.map +1 -0
- package/dist/ai/agents/testing-reviewer.js +80 -0
- package/dist/ai/agents/testing-reviewer.js.map +1 -0
- package/dist/ai/agents/ts-reviewer.d.ts +3 -0
- package/dist/ai/agents/ts-reviewer.d.ts.map +1 -0
- package/dist/ai/agents/ts-reviewer.js +63 -0
- package/dist/ai/agents/ts-reviewer.js.map +1 -0
- package/dist/ai/agents/ux-text-reviewer.d.ts +3 -0
- package/dist/ai/agents/ux-text-reviewer.d.ts.map +1 -0
- package/dist/ai/agents/ux-text-reviewer.js +116 -0
- package/dist/ai/agents/ux-text-reviewer.js.map +1 -0
- package/dist/ai/orchestrator/agent-classifier.d.ts +28 -0
- package/dist/ai/orchestrator/agent-classifier.d.ts.map +1 -0
- package/dist/ai/orchestrator/agent-classifier.js +137 -0
- package/dist/ai/orchestrator/agent-classifier.js.map +1 -0
- package/dist/ai/orchestrator/consolidation.d.ts +12 -0
- package/dist/ai/orchestrator/consolidation.d.ts.map +1 -0
- package/dist/ai/orchestrator/consolidation.js +34 -0
- package/dist/ai/orchestrator/consolidation.js.map +1 -0
- package/dist/ai/orchestrator/context-analyzer.d.ts +47 -0
- package/dist/ai/orchestrator/context-analyzer.d.ts.map +1 -0
- package/dist/ai/orchestrator/context-analyzer.js +368 -0
- package/dist/ai/orchestrator/context-analyzer.js.map +1 -0
- package/dist/ai/orchestrator/deduplicator.d.ts +43 -0
- package/dist/ai/orchestrator/deduplicator.d.ts.map +1 -0
- package/dist/ai/orchestrator/deduplicator.js +97 -0
- package/dist/ai/orchestrator/deduplicator.js.map +1 -0
- package/dist/ai/orchestrator/orchestrator.d.ts +57 -0
- package/dist/ai/orchestrator/orchestrator.d.ts.map +1 -0
- package/dist/ai/orchestrator/orchestrator.js +181 -0
- package/dist/ai/orchestrator/orchestrator.js.map +1 -0
- package/dist/ai/orchestrator/rule-based-strategy.d.ts +20 -0
- package/dist/ai/orchestrator/rule-based-strategy.d.ts.map +1 -0
- package/dist/ai/orchestrator/rule-based-strategy.js +55 -0
- package/dist/ai/orchestrator/rule-based-strategy.js.map +1 -0
- package/dist/ai/orchestrator/semaphore.d.ts +25 -0
- package/dist/ai/orchestrator/semaphore.d.ts.map +1 -0
- package/dist/ai/orchestrator/semaphore.js +52 -0
- package/dist/ai/orchestrator/semaphore.js.map +1 -0
- package/dist/ai/orchestrator/severity-pipeline.d.ts +21 -0
- package/dist/ai/orchestrator/severity-pipeline.d.ts.map +1 -0
- package/dist/ai/orchestrator/severity-pipeline.js +69 -0
- package/dist/ai/orchestrator/severity-pipeline.js.map +1 -0
- package/dist/ai/orchestrator/strategy.d.ts +20 -0
- package/dist/ai/orchestrator/strategy.d.ts.map +1 -0
- package/dist/ai/orchestrator/strategy.js +2 -0
- package/dist/ai/orchestrator/strategy.js.map +1 -0
- package/dist/ai/providers/anthropic-provider.d.ts +14 -0
- package/dist/ai/providers/anthropic-provider.d.ts.map +1 -0
- package/dist/ai/providers/anthropic-provider.js +108 -0
- package/dist/ai/providers/anthropic-provider.js.map +1 -0
- package/dist/ai/providers/claude-code-provider.d.ts +12 -0
- package/dist/ai/providers/claude-code-provider.d.ts.map +1 -0
- package/dist/ai/providers/claude-code-provider.js +103 -0
- package/dist/ai/providers/claude-code-provider.js.map +1 -0
- package/dist/ai/providers/errors.d.ts +22 -0
- package/dist/ai/providers/errors.d.ts.map +1 -0
- package/dist/ai/providers/errors.js +44 -0
- package/dist/ai/providers/errors.js.map +1 -0
- package/dist/ai/skills/skill-registry.d.ts +21 -0
- package/dist/ai/skills/skill-registry.d.ts.map +1 -0
- package/dist/ai/skills/skill-registry.js +27 -0
- package/dist/ai/skills/skill-registry.js.map +1 -0
- package/dist/ai/text-extractor/extractor.d.ts +15 -0
- package/dist/ai/text-extractor/extractor.d.ts.map +1 -0
- package/dist/ai/text-extractor/extractor.js +63 -0
- package/dist/ai/text-extractor/extractor.js.map +1 -0
- package/dist/ai/text-extractor/index.d.ts +4 -0
- package/dist/ai/text-extractor/index.d.ts.map +1 -0
- package/dist/ai/text-extractor/index.js +3 -0
- package/dist/ai/text-extractor/index.js.map +1 -0
- package/dist/ai/text-extractor/patterns.d.ts +21 -0
- package/dist/ai/text-extractor/patterns.d.ts.map +1 -0
- package/dist/ai/text-extractor/patterns.js +169 -0
- package/dist/ai/text-extractor/patterns.js.map +1 -0
- package/dist/ai/text-extractor/types.d.ts +47 -0
- package/dist/ai/text-extractor/types.d.ts.map +1 -0
- package/dist/ai/text-extractor/types.js +2 -0
- package/dist/ai/text-extractor/types.js.map +1 -0
- package/dist/bitbucket/client.d.ts +38 -0
- package/dist/bitbucket/client.d.ts.map +1 -0
- package/dist/bitbucket/client.js +448 -0
- package/dist/bitbucket/client.js.map +1 -0
- package/dist/bitbucket/errors.d.ts +75 -0
- package/dist/bitbucket/errors.d.ts.map +1 -0
- package/dist/bitbucket/errors.js +127 -0
- package/dist/bitbucket/errors.js.map +1 -0
- package/dist/bitbucket/mappers.d.ts +3 -0
- package/dist/bitbucket/mappers.d.ts.map +1 -0
- package/dist/bitbucket/mappers.js +14 -0
- package/dist/bitbucket/mappers.js.map +1 -0
- package/dist/commands/guard/check.d.ts +19 -0
- package/dist/commands/guard/check.d.ts.map +1 -0
- package/dist/commands/guard/check.js +224 -0
- package/dist/commands/guard/check.js.map +1 -0
- package/dist/commands/guard/index.d.ts +7 -0
- package/dist/commands/guard/index.d.ts.map +1 -0
- package/dist/commands/guard/index.js +65 -0
- package/dist/commands/guard/index.js.map +1 -0
- package/dist/commands/interactive.d.ts +10 -0
- package/dist/commands/interactive.d.ts.map +1 -0
- package/dist/commands/interactive.js +88 -0
- package/dist/commands/interactive.js.map +1 -0
- package/dist/commands/login.d.ts +35 -0
- package/dist/commands/login.d.ts.map +1 -0
- package/dist/commands/login.js +164 -0
- package/dist/commands/login.js.map +1 -0
- package/dist/commands/logout.d.ts +12 -0
- package/dist/commands/logout.d.ts.map +1 -0
- package/dist/commands/logout.js +23 -0
- package/dist/commands/logout.js.map +1 -0
- package/dist/commands/review/start.d.ts +22 -0
- package/dist/commands/review/start.d.ts.map +1 -0
- package/dist/commands/review/start.js +120 -0
- package/dist/commands/review/start.js.map +1 -0
- package/dist/commands/rules/push.d.ts +13 -0
- package/dist/commands/rules/push.d.ts.map +1 -0
- package/dist/commands/rules/push.js +75 -0
- package/dist/commands/rules/push.js.map +1 -0
- package/dist/commands/rules/stats.d.ts +14 -0
- package/dist/commands/rules/stats.d.ts.map +1 -0
- package/dist/commands/rules/stats.js +101 -0
- package/dist/commands/rules/stats.js.map +1 -0
- package/dist/commands/rules/sync.d.ts +15 -0
- package/dist/commands/rules/sync.d.ts.map +1 -0
- package/dist/commands/rules/sync.js +144 -0
- package/dist/commands/rules/sync.js.map +1 -0
- package/dist/config/config-manager.d.ts +14 -0
- package/dist/config/config-manager.d.ts.map +1 -0
- package/dist/config/config-manager.js +85 -0
- package/dist/config/config-manager.js.map +1 -0
- package/dist/config/convention-builder.d.ts +13 -0
- package/dist/config/convention-builder.d.ts.map +1 -0
- package/dist/config/convention-builder.js +31 -0
- package/dist/config/convention-builder.js.map +1 -0
- package/dist/config/credentials.d.ts +14 -0
- package/dist/config/credentials.d.ts.map +1 -0
- package/dist/config/credentials.js +85 -0
- package/dist/config/credentials.js.map +1 -0
- package/dist/config/encryption.d.ts +20 -0
- package/dist/config/encryption.d.ts.map +1 -0
- package/dist/config/encryption.js +94 -0
- package/dist/config/encryption.js.map +1 -0
- package/dist/config/repo-config-loader.d.ts +34 -0
- package/dist/config/repo-config-loader.d.ts.map +1 -0
- package/dist/config/repo-config-loader.js +103 -0
- package/dist/config/repo-config-loader.js.map +1 -0
- package/dist/core/cli-workflow-callbacks.d.ts +35 -0
- package/dist/core/cli-workflow-callbacks.d.ts.map +1 -0
- package/dist/core/cli-workflow-callbacks.js +141 -0
- package/dist/core/cli-workflow-callbacks.js.map +1 -0
- package/dist/core/comment-publisher.d.ts +61 -0
- package/dist/core/comment-publisher.d.ts.map +1 -0
- package/dist/core/comment-publisher.js +172 -0
- package/dist/core/comment-publisher.js.map +1 -0
- package/dist/core/integrity-checker.d.ts +22 -0
- package/dist/core/integrity-checker.d.ts.map +1 -0
- package/dist/core/integrity-checker.js +83 -0
- package/dist/core/integrity-checker.js.map +1 -0
- package/dist/core/review-workflow.d.ts +34 -0
- package/dist/core/review-workflow.d.ts.map +1 -0
- package/dist/core/review-workflow.js +21 -0
- package/dist/core/review-workflow.js.map +1 -0
- package/dist/core/session-manager.d.ts +107 -0
- package/dist/core/session-manager.d.ts.map +1 -0
- package/dist/core/session-manager.js +164 -0
- package/dist/core/session-manager.js.map +1 -0
- package/dist/core/workflow-callbacks.d.ts +74 -0
- package/dist/core/workflow-callbacks.d.ts.map +1 -0
- package/dist/core/workflow-callbacks.js +2 -0
- package/dist/core/workflow-callbacks.js.map +1 -0
- package/dist/core/workflow-engine.d.ts +48 -0
- package/dist/core/workflow-engine.d.ts.map +1 -0
- package/dist/core/workflow-engine.js +442 -0
- package/dist/core/workflow-engine.js.map +1 -0
- package/dist/errors/base.d.ts +6 -0
- package/dist/errors/base.d.ts.map +1 -0
- package/dist/errors/base.js +13 -0
- package/dist/errors/base.js.map +1 -0
- package/dist/errors/config-error.d.ts +5 -0
- package/dist/errors/config-error.d.ts.map +1 -0
- package/dist/errors/config-error.js +9 -0
- package/dist/errors/config-error.js.map +1 -0
- package/dist/errors/index.d.ts +5 -0
- package/dist/errors/index.d.ts.map +1 -0
- package/dist/errors/index.js +5 -0
- package/dist/errors/index.js.map +1 -0
- package/dist/errors/validation-error.d.ts +5 -0
- package/dist/errors/validation-error.d.ts.map +1 -0
- package/dist/errors/validation-error.js +9 -0
- package/dist/errors/validation-error.js.map +1 -0
- package/dist/errors/workflow-error.d.ts +6 -0
- package/dist/errors/workflow-error.d.ts.map +1 -0
- package/dist/errors/workflow-error.js +11 -0
- package/dist/errors/workflow-error.js.map +1 -0
- package/dist/guard/ast-grep-strategy.d.ts +25 -0
- package/dist/guard/ast-grep-strategy.d.ts.map +1 -0
- package/dist/guard/ast-grep-strategy.js +112 -0
- package/dist/guard/ast-grep-strategy.js.map +1 -0
- package/dist/guard/diff-pattern-matcher.d.ts +52 -0
- package/dist/guard/diff-pattern-matcher.d.ts.map +1 -0
- package/dist/guard/diff-pattern-matcher.js +325 -0
- package/dist/guard/diff-pattern-matcher.js.map +1 -0
- package/dist/guard/file-fetcher.d.ts +3 -0
- package/dist/guard/file-fetcher.d.ts.map +1 -0
- package/dist/guard/file-fetcher.js +21 -0
- package/dist/guard/file-fetcher.js.map +1 -0
- package/dist/guard/guard-engine.d.ts +8 -0
- package/dist/guard/guard-engine.d.ts.map +1 -0
- package/dist/guard/guard-engine.js +78 -0
- package/dist/guard/guard-engine.js.map +1 -0
- package/dist/guard/match-strategy.d.ts +14 -0
- package/dist/guard/match-strategy.d.ts.map +1 -0
- package/dist/guard/match-strategy.js +7 -0
- package/dist/guard/match-strategy.js.map +1 -0
- package/dist/guard/patterns-loader.d.ts +16 -0
- package/dist/guard/patterns-loader.d.ts.map +1 -0
- package/dist/guard/patterns-loader.js +61 -0
- package/dist/guard/patterns-loader.js.map +1 -0
- package/dist/guard/types.d.ts +61 -0
- package/dist/guard/types.d.ts.map +1 -0
- package/dist/guard/types.js +2 -0
- package/dist/guard/types.js.map +1 -0
- package/dist/memory/engram-client.d.ts +15 -0
- package/dist/memory/engram-client.d.ts.map +1 -0
- package/dist/memory/engram-client.js +167 -0
- package/dist/memory/engram-client.js.map +1 -0
- package/dist/memory/review-memory-service.d.ts +13 -0
- package/dist/memory/review-memory-service.d.ts.map +1 -0
- package/dist/memory/review-memory-service.js +43 -0
- package/dist/memory/review-memory-service.js.map +1 -0
- package/dist/persistence/database.d.ts +8 -0
- package/dist/persistence/database.d.ts.map +1 -0
- package/dist/persistence/database.js +58 -0
- package/dist/persistence/database.js.map +1 -0
- package/dist/persistence/false-positive-repository.d.ts +12 -0
- package/dist/persistence/false-positive-repository.d.ts.map +1 -0
- package/dist/persistence/false-positive-repository.js +58 -0
- package/dist/persistence/false-positive-repository.js.map +1 -0
- package/dist/persistence/migrations/0000_peaceful_blur.sql +66 -0
- package/dist/persistence/migrations/0001_phase3a_schema.sql +15 -0
- package/dist/persistence/migrations/0002_stack_profile.sql +1 -0
- package/dist/persistence/migrations/0003_known_workspaces.sql +5 -0
- package/dist/persistence/migrations/0004_review_memory.sql +24 -0
- package/dist/persistence/migrations/meta/0000_snapshot.json +468 -0
- package/dist/persistence/migrations/meta/_journal.json +41 -0
- package/dist/persistence/profile-repository.d.ts +33 -0
- package/dist/persistence/profile-repository.d.ts.map +1 -0
- package/dist/persistence/profile-repository.js +94 -0
- package/dist/persistence/profile-repository.js.map +1 -0
- package/dist/persistence/repository.d.ts +70 -0
- package/dist/persistence/repository.d.ts.map +1 -0
- package/dist/persistence/repository.js +225 -0
- package/dist/persistence/repository.js.map +1 -0
- package/dist/persistence/schema.d.ts +1333 -0
- package/dist/persistence/schema.d.ts.map +1 -0
- package/dist/persistence/schema.js +92 -0
- package/dist/persistence/schema.js.map +1 -0
- package/dist/persistence/workspace-repository.d.ts +14 -0
- package/dist/persistence/workspace-repository.d.ts.map +1 -0
- package/dist/persistence/workspace-repository.js +30 -0
- package/dist/persistence/workspace-repository.js.map +1 -0
- package/dist/rules-engine/finding-aggregator.d.ts +13 -0
- package/dist/rules-engine/finding-aggregator.d.ts.map +1 -0
- package/dist/rules-engine/finding-aggregator.js +135 -0
- package/dist/rules-engine/finding-aggregator.js.map +1 -0
- package/dist/rules-engine/pattern-generator.d.ts +26 -0
- package/dist/rules-engine/pattern-generator.d.ts.map +1 -0
- package/dist/rules-engine/pattern-generator.js +116 -0
- package/dist/rules-engine/pattern-generator.js.map +1 -0
- package/dist/rules-engine/rule-prompt-builder.d.ts +32 -0
- package/dist/rules-engine/rule-prompt-builder.d.ts.map +1 -0
- package/dist/rules-engine/rule-prompt-builder.js +124 -0
- package/dist/rules-engine/rule-prompt-builder.js.map +1 -0
- package/dist/rules-engine/types.d.ts +80 -0
- package/dist/rules-engine/types.d.ts.map +1 -0
- package/dist/rules-engine/types.js +18 -0
- package/dist/rules-engine/types.js.map +1 -0
- package/dist/rules-repo/rules-cache.d.ts +14 -0
- package/dist/rules-repo/rules-cache.d.ts.map +1 -0
- package/dist/rules-repo/rules-cache.js +43 -0
- package/dist/rules-repo/rules-cache.js.map +1 -0
- package/dist/rules-repo/rules-repo-client.d.ts +27 -0
- package/dist/rules-repo/rules-repo-client.d.ts.map +1 -0
- package/dist/rules-repo/rules-repo-client.js +85 -0
- package/dist/rules-repo/rules-repo-client.js.map +1 -0
- package/dist/rules-repo/types.d.ts +16 -0
- package/dist/rules-repo/types.d.ts.map +1 -0
- package/dist/rules-repo/types.js +10 -0
- package/dist/rules-repo/types.js.map +1 -0
- package/dist/stack-detector/ai-stack-fallback.d.ts +12 -0
- package/dist/stack-detector/ai-stack-fallback.d.ts.map +1 -0
- package/dist/stack-detector/ai-stack-fallback.js +67 -0
- package/dist/stack-detector/ai-stack-fallback.js.map +1 -0
- package/dist/stack-detector/ai-stack-schema.d.ts +28 -0
- package/dist/stack-detector/ai-stack-schema.d.ts.map +1 -0
- package/dist/stack-detector/ai-stack-schema.js +13 -0
- package/dist/stack-detector/ai-stack-schema.js.map +1 -0
- package/dist/stack-detector/formatter.d.ts +7 -0
- package/dist/stack-detector/formatter.d.ts.map +1 -0
- package/dist/stack-detector/formatter.js +37 -0
- package/dist/stack-detector/formatter.js.map +1 -0
- package/dist/stack-detector/index.d.ts +7 -0
- package/dist/stack-detector/index.d.ts.map +1 -0
- package/dist/stack-detector/index.js +5 -0
- package/dist/stack-detector/index.js.map +1 -0
- package/dist/stack-detector/merge-profiles.d.ts +5 -0
- package/dist/stack-detector/merge-profiles.d.ts.map +1 -0
- package/dist/stack-detector/merge-profiles.js +36 -0
- package/dist/stack-detector/merge-profiles.js.map +1 -0
- package/dist/stack-detector/parsers.d.ts +12 -0
- package/dist/stack-detector/parsers.d.ts.map +1 -0
- package/dist/stack-detector/parsers.js +259 -0
- package/dist/stack-detector/parsers.js.map +1 -0
- package/dist/stack-detector/stack-detector.d.ts +11 -0
- package/dist/stack-detector/stack-detector.d.ts.map +1 -0
- package/dist/stack-detector/stack-detector.js +83 -0
- package/dist/stack-detector/stack-detector.js.map +1 -0
- package/dist/stack-detector/types.d.ts +13 -0
- package/dist/stack-detector/types.d.ts.map +1 -0
- package/dist/stack-detector/types.js +2 -0
- package/dist/stack-detector/types.js.map +1 -0
- package/dist/tui/app.d.ts +9 -0
- package/dist/tui/app.d.ts.map +1 -0
- package/dist/tui/app.js +45 -0
- package/dist/tui/app.js.map +1 -0
- package/dist/tui/callbacks/tui-workflow-callbacks.d.ts +32 -0
- package/dist/tui/callbacks/tui-workflow-callbacks.d.ts.map +1 -0
- package/dist/tui/callbacks/tui-workflow-callbacks.js +88 -0
- package/dist/tui/callbacks/tui-workflow-callbacks.js.map +1 -0
- package/dist/tui/components/key-hint.d.ts +7 -0
- package/dist/tui/components/key-hint.d.ts.map +1 -0
- package/dist/tui/components/key-hint.js +6 -0
- package/dist/tui/components/key-hint.js.map +1 -0
- package/dist/tui/components/scroll-list.d.ts +20 -0
- package/dist/tui/components/scroll-list.d.ts.map +1 -0
- package/dist/tui/components/scroll-list.js +85 -0
- package/dist/tui/components/scroll-list.js.map +1 -0
- package/dist/tui/components/searchable-list.d.ts +15 -0
- package/dist/tui/components/searchable-list.d.ts.map +1 -0
- package/dist/tui/components/searchable-list.js +97 -0
- package/dist/tui/components/searchable-list.js.map +1 -0
- package/dist/tui/components/severity-badge.d.ts +6 -0
- package/dist/tui/components/severity-badge.d.ts.map +1 -0
- package/dist/tui/components/severity-badge.js +17 -0
- package/dist/tui/components/severity-badge.js.map +1 -0
- package/dist/tui/components/severity-selector.d.ts +9 -0
- package/dist/tui/components/severity-selector.d.ts.map +1 -0
- package/dist/tui/components/severity-selector.js +29 -0
- package/dist/tui/components/severity-selector.js.map +1 -0
- package/dist/tui/components/spinner.d.ts +6 -0
- package/dist/tui/components/spinner.d.ts.map +1 -0
- package/dist/tui/components/spinner.js +19 -0
- package/dist/tui/components/spinner.js.map +1 -0
- package/dist/tui/components/status-bar.d.ts +10 -0
- package/dist/tui/components/status-bar.d.ts.map +1 -0
- package/dist/tui/components/status-bar.js +7 -0
- package/dist/tui/components/status-bar.js.map +1 -0
- package/dist/tui/deps-context.d.ts +27 -0
- package/dist/tui/deps-context.d.ts.map +1 -0
- package/dist/tui/deps-context.js +9 -0
- package/dist/tui/deps-context.js.map +1 -0
- package/dist/tui/error-boundary.d.ts +16 -0
- package/dist/tui/error-boundary.d.ts.map +1 -0
- package/dist/tui/error-boundary.js +30 -0
- package/dist/tui/error-boundary.js.map +1 -0
- package/dist/tui/hooks/use-agent-recommendations.d.ts +10 -0
- package/dist/tui/hooks/use-agent-recommendations.d.ts.map +1 -0
- package/dist/tui/hooks/use-agent-recommendations.js +66 -0
- package/dist/tui/hooks/use-agent-recommendations.js.map +1 -0
- package/dist/tui/hooks/use-auth.d.ts +14 -0
- package/dist/tui/hooks/use-auth.d.ts.map +1 -0
- package/dist/tui/hooks/use-auth.js +32 -0
- package/dist/tui/hooks/use-auth.js.map +1 -0
- package/dist/tui/hooks/use-bitbucket.d.ts +18 -0
- package/dist/tui/hooks/use-bitbucket.d.ts.map +1 -0
- package/dist/tui/hooks/use-bitbucket.js +31 -0
- package/dist/tui/hooks/use-bitbucket.js.map +1 -0
- package/dist/tui/hooks/use-review.d.ts +6 -0
- package/dist/tui/hooks/use-review.d.ts.map +1 -0
- package/dist/tui/hooks/use-review.js +24 -0
- package/dist/tui/hooks/use-review.js.map +1 -0
- package/dist/tui/hooks/use-session.d.ts +47 -0
- package/dist/tui/hooks/use-session.d.ts.map +1 -0
- package/dist/tui/hooks/use-session.js +17 -0
- package/dist/tui/hooks/use-session.js.map +1 -0
- package/dist/tui/screen-router.d.ts +3 -0
- package/dist/tui/screen-router.d.ts.map +1 -0
- package/dist/tui/screen-router.js +73 -0
- package/dist/tui/screen-router.js.map +1 -0
- package/dist/tui/screens/agent-select.d.ts +3 -0
- package/dist/tui/screens/agent-select.d.ts.map +1 -0
- package/dist/tui/screens/agent-select.js +173 -0
- package/dist/tui/screens/agent-select.js.map +1 -0
- package/dist/tui/screens/finding-detail.d.ts +3 -0
- package/dist/tui/screens/finding-detail.d.ts.map +1 -0
- package/dist/tui/screens/finding-detail.js +48 -0
- package/dist/tui/screens/finding-detail.js.map +1 -0
- package/dist/tui/screens/findings-list.d.ts +3 -0
- package/dist/tui/screens/findings-list.d.ts.map +1 -0
- package/dist/tui/screens/findings-list.js +108 -0
- package/dist/tui/screens/findings-list.js.map +1 -0
- package/dist/tui/screens/guard-detail.d.ts +3 -0
- package/dist/tui/screens/guard-detail.d.ts.map +1 -0
- package/dist/tui/screens/guard-detail.js +41 -0
- package/dist/tui/screens/guard-detail.js.map +1 -0
- package/dist/tui/screens/guard-home.d.ts +3 -0
- package/dist/tui/screens/guard-home.d.ts.map +1 -0
- package/dist/tui/screens/guard-home.js +81 -0
- package/dist/tui/screens/guard-home.js.map +1 -0
- package/dist/tui/screens/guard-results.d.ts +3 -0
- package/dist/tui/screens/guard-results.d.ts.map +1 -0
- package/dist/tui/screens/guard-results.js +103 -0
- package/dist/tui/screens/guard-results.js.map +1 -0
- package/dist/tui/screens/guard-running.d.ts +3 -0
- package/dist/tui/screens/guard-running.d.ts.map +1 -0
- package/dist/tui/screens/guard-running.js +92 -0
- package/dist/tui/screens/guard-running.js.map +1 -0
- package/dist/tui/screens/home.d.ts +3 -0
- package/dist/tui/screens/home.d.ts.map +1 -0
- package/dist/tui/screens/home.js +44 -0
- package/dist/tui/screens/home.js.map +1 -0
- package/dist/tui/screens/integrity-report.d.ts +3 -0
- package/dist/tui/screens/integrity-report.d.ts.map +1 -0
- package/dist/tui/screens/integrity-report.js +29 -0
- package/dist/tui/screens/integrity-report.js.map +1 -0
- package/dist/tui/screens/login.d.ts +3 -0
- package/dist/tui/screens/login.d.ts.map +1 -0
- package/dist/tui/screens/login.js +81 -0
- package/dist/tui/screens/login.js.map +1 -0
- package/dist/tui/screens/pr-list.d.ts +3 -0
- package/dist/tui/screens/pr-list.d.ts.map +1 -0
- package/dist/tui/screens/pr-list.js +76 -0
- package/dist/tui/screens/pr-list.js.map +1 -0
- package/dist/tui/screens/publish-confirm.d.ts +3 -0
- package/dist/tui/screens/publish-confirm.d.ts.map +1 -0
- package/dist/tui/screens/publish-confirm.js +42 -0
- package/dist/tui/screens/publish-confirm.js.map +1 -0
- package/dist/tui/screens/publishing.d.ts +3 -0
- package/dist/tui/screens/publishing.d.ts.map +1 -0
- package/dist/tui/screens/publishing.js +50 -0
- package/dist/tui/screens/publishing.js.map +1 -0
- package/dist/tui/screens/repo-select.d.ts +3 -0
- package/dist/tui/screens/repo-select.d.ts.map +1 -0
- package/dist/tui/screens/repo-select.js +76 -0
- package/dist/tui/screens/repo-select.js.map +1 -0
- package/dist/tui/screens/review-running.d.ts +3 -0
- package/dist/tui/screens/review-running.d.ts.map +1 -0
- package/dist/tui/screens/review-running.js +187 -0
- package/dist/tui/screens/review-running.js.map +1 -0
- package/dist/tui/screens/session-detail.d.ts +7 -0
- package/dist/tui/screens/session-detail.d.ts.map +1 -0
- package/dist/tui/screens/session-detail.js +28 -0
- package/dist/tui/screens/session-detail.js.map +1 -0
- package/dist/tui/screens/session-list.d.ts +7 -0
- package/dist/tui/screens/session-list.d.ts.map +1 -0
- package/dist/tui/screens/session-list.js +38 -0
- package/dist/tui/screens/session-list.js.map +1 -0
- package/dist/tui/screens/url-input.d.ts +3 -0
- package/dist/tui/screens/url-input.d.ts.map +1 -0
- package/dist/tui/screens/url-input.js +111 -0
- package/dist/tui/screens/url-input.js.map +1 -0
- package/dist/tui/screens/welcome.d.ts +3 -0
- package/dist/tui/screens/welcome.d.ts.map +1 -0
- package/dist/tui/screens/welcome.js +48 -0
- package/dist/tui/screens/welcome.js.map +1 -0
- package/dist/tui/screens/workspace-select.d.ts +3 -0
- package/dist/tui/screens/workspace-select.d.ts.map +1 -0
- package/dist/tui/screens/workspace-select.js +128 -0
- package/dist/tui/screens/workspace-select.js.map +1 -0
- package/dist/tui/state/router-context.d.ts +14 -0
- package/dist/tui/state/router-context.d.ts.map +1 -0
- package/dist/tui/state/router-context.js +9 -0
- package/dist/tui/state/router-context.js.map +1 -0
- package/dist/tui/state/router-reducer.d.ts +23 -0
- package/dist/tui/state/router-reducer.d.ts.map +1 -0
- package/dist/tui/state/router-reducer.js +21 -0
- package/dist/tui/state/router-reducer.js.map +1 -0
- package/dist/tui/state/tui-context.d.ts +11 -0
- package/dist/tui/state/tui-context.d.ts.map +1 -0
- package/dist/tui/state/tui-context.js +9 -0
- package/dist/tui/state/tui-context.js.map +1 -0
- package/dist/tui/state/tui-reducer.d.ts +212 -0
- package/dist/tui/state/tui-reducer.d.ts.map +1 -0
- package/dist/tui/state/tui-reducer.js +321 -0
- package/dist/tui/state/tui-reducer.js.map +1 -0
- package/dist/tui/utils/group-by-file.d.ts +7 -0
- package/dist/tui/utils/group-by-file.d.ts.map +1 -0
- package/dist/tui/utils/group-by-file.js +18 -0
- package/dist/tui/utils/group-by-file.js.map +1 -0
- package/dist/tui/utils/group-matches-by-file.d.ts +7 -0
- package/dist/tui/utils/group-matches-by-file.d.ts.map +1 -0
- package/dist/tui/utils/group-matches-by-file.js +18 -0
- package/dist/tui/utils/group-matches-by-file.js.map +1 -0
- package/dist/tui/utils/group-repos-by-project.d.ts +9 -0
- package/dist/tui/utils/group-repos-by-project.d.ts.map +1 -0
- package/dist/tui/utils/group-repos-by-project.js +48 -0
- package/dist/tui/utils/group-repos-by-project.js.map +1 -0
- package/dist/types/agent.d.ts +46 -0
- package/dist/types/agent.d.ts.map +1 -0
- package/dist/types/agent.js +2 -0
- package/dist/types/agent.js.map +1 -0
- package/dist/types/bitbucket.d.ts +90 -0
- package/dist/types/bitbucket.d.ts.map +1 -0
- package/dist/types/bitbucket.js +2 -0
- package/dist/types/bitbucket.js.map +1 -0
- package/dist/types/config.d.ts +17 -0
- package/dist/types/config.d.ts.map +1 -0
- package/dist/types/config.js +2 -0
- package/dist/types/config.js.map +1 -0
- package/dist/types/diff.d.ts +24 -0
- package/dist/types/diff.d.ts.map +1 -0
- package/dist/types/diff.js +2 -0
- package/dist/types/diff.js.map +1 -0
- package/dist/types/engram.d.ts +29 -0
- package/dist/types/engram.d.ts.map +1 -0
- package/dist/types/engram.js +2 -0
- package/dist/types/engram.js.map +1 -0
- package/dist/types/false-positive.d.ts +12 -0
- package/dist/types/false-positive.d.ts.map +1 -0
- package/dist/types/false-positive.js +2 -0
- package/dist/types/false-positive.js.map +1 -0
- package/dist/types/index.d.ts +14 -0
- package/dist/types/index.d.ts.map +1 -0
- package/dist/types/index.js +3 -0
- package/dist/types/index.js.map +1 -0
- package/dist/types/provider.d.ts +31 -0
- package/dist/types/provider.d.ts.map +1 -0
- package/dist/types/provider.js +2 -0
- package/dist/types/provider.js.map +1 -0
- package/dist/types/repo-config.d.ts +336 -0
- package/dist/types/repo-config.d.ts.map +1 -0
- package/dist/types/repo-config.js +62 -0
- package/dist/types/repo-config.js.map +1 -0
- package/dist/types/review-finding.d.ts +34 -0
- package/dist/types/review-finding.d.ts.map +1 -0
- package/dist/types/review-finding.js +11 -0
- package/dist/types/review-finding.js.map +1 -0
- package/dist/types/review-session.d.ts +21 -0
- package/dist/types/review-session.d.ts.map +1 -0
- package/dist/types/review-session.js +2 -0
- package/dist/types/review-session.js.map +1 -0
- package/dist/types/skill.d.ts +7 -0
- package/dist/types/skill.d.ts.map +1 -0
- package/dist/types/skill.js +2 -0
- package/dist/types/skill.js.map +1 -0
- package/dist/utils/comment-formatter.d.ts +19 -0
- package/dist/utils/comment-formatter.d.ts.map +1 -0
- package/dist/utils/comment-formatter.js +53 -0
- package/dist/utils/comment-formatter.js.map +1 -0
- package/dist/utils/cost-estimator.d.ts +19 -0
- package/dist/utils/cost-estimator.d.ts.map +1 -0
- package/dist/utils/cost-estimator.js +32 -0
- package/dist/utils/cost-estimator.js.map +1 -0
- package/dist/utils/diff-parser.d.ts +7 -0
- package/dist/utils/diff-parser.d.ts.map +1 -0
- package/dist/utils/diff-parser.js +175 -0
- package/dist/utils/diff-parser.js.map +1 -0
- package/dist/utils/file-filter.d.ts +16 -0
- package/dist/utils/file-filter.d.ts.map +1 -0
- package/dist/utils/file-filter.js +64 -0
- package/dist/utils/file-filter.js.map +1 -0
- package/dist/utils/hash.d.ts +25 -0
- package/dist/utils/hash.d.ts.map +1 -0
- package/dist/utils/hash.js +45 -0
- package/dist/utils/hash.js.map +1 -0
- package/dist/utils/logger.d.ts +17 -0
- package/dist/utils/logger.d.ts.map +1 -0
- package/dist/utils/logger.js +40 -0
- package/dist/utils/logger.js.map +1 -0
- package/dist/utils/parse-bitbucket-url.d.ts +12 -0
- package/dist/utils/parse-bitbucket-url.d.ts.map +1 -0
- package/dist/utils/parse-bitbucket-url.js +41 -0
- package/dist/utils/parse-bitbucket-url.js.map +1 -0
- package/dist/utils/paths.d.ts +6 -0
- package/dist/utils/paths.d.ts.map +1 -0
- package/dist/utils/paths.js +27 -0
- package/dist/utils/paths.js.map +1 -0
- package/dist/utils/summary-generator.d.ts +17 -0
- package/dist/utils/summary-generator.d.ts.map +1 -0
- package/dist/utils/summary-generator.js +76 -0
- package/dist/utils/summary-generator.js.map +1 -0
- package/oclif.manifest.json +467 -0
- package/package.json +100 -0
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
export interface BitbucketPrCoordinates {
|
|
2
|
+
workspace: string;
|
|
3
|
+
repo: string;
|
|
4
|
+
prId: number;
|
|
5
|
+
}
|
|
6
|
+
export type BitbucketUrlParseReason = 'malformed-url' | 'wrong-host' | 'not-pr-path' | 'missing-segments' | 'invalid-pr-id';
|
|
7
|
+
export declare class BitbucketUrlParseError extends Error {
|
|
8
|
+
readonly reason: BitbucketUrlParseReason;
|
|
9
|
+
constructor(reason: BitbucketUrlParseReason, raw: string);
|
|
10
|
+
}
|
|
11
|
+
export declare function parseBitbucketUrl(raw: string): BitbucketPrCoordinates;
|
|
12
|
+
//# sourceMappingURL=parse-bitbucket-url.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"parse-bitbucket-url.d.ts","sourceRoot":"","sources":["../../src/utils/parse-bitbucket-url.ts"],"names":[],"mappings":"AAAA,MAAM,WAAW,sBAAsB;IACrC,SAAS,EAAE,MAAM,CAAC;IAClB,IAAI,EAAE,MAAM,CAAC;IACb,IAAI,EAAE,MAAM,CAAC;CACd;AAED,MAAM,MAAM,uBAAuB,GAC/B,eAAe,GACf,YAAY,GACZ,aAAa,GACb,kBAAkB,GAClB,eAAe,CAAC;AAEpB,qBAAa,sBAAuB,SAAQ,KAAK;IAC/C,QAAQ,CAAC,MAAM,EAAE,uBAAuB,CAAC;gBAE7B,MAAM,EAAE,uBAAuB,EAAE,GAAG,EAAE,MAAM;CAMzD;AAED,wBAAgB,iBAAiB,CAAC,GAAG,EAAE,MAAM,GAAG,sBAAsB,CAqCrE"}
|
|
@@ -0,0 +1,41 @@
|
|
|
1
|
+
export class BitbucketUrlParseError extends Error {
|
|
2
|
+
reason;
|
|
3
|
+
constructor(reason, raw) {
|
|
4
|
+
super(`Cannot parse Bitbucket PR URL (${reason}): ${raw}`);
|
|
5
|
+
this.name = 'BitbucketUrlParseError';
|
|
6
|
+
this.reason = reason;
|
|
7
|
+
Object.setPrototypeOf(this, new.target.prototype);
|
|
8
|
+
}
|
|
9
|
+
}
|
|
10
|
+
export function parseBitbucketUrl(raw) {
|
|
11
|
+
let parsed;
|
|
12
|
+
try {
|
|
13
|
+
parsed = new URL(raw);
|
|
14
|
+
}
|
|
15
|
+
catch {
|
|
16
|
+
throw new BitbucketUrlParseError('malformed-url', raw);
|
|
17
|
+
}
|
|
18
|
+
if (parsed.hostname !== 'bitbucket.org') {
|
|
19
|
+
throw new BitbucketUrlParseError('wrong-host', raw);
|
|
20
|
+
}
|
|
21
|
+
const segments = parsed.pathname.split('/').filter(Boolean);
|
|
22
|
+
// segments: [workspace, repo, 'pull-requests', prIdStr, ...rest]
|
|
23
|
+
if (segments.length < 3 || segments[2] !== 'pull-requests') {
|
|
24
|
+
throw new BitbucketUrlParseError('not-pr-path', raw);
|
|
25
|
+
}
|
|
26
|
+
const workspace = segments[0];
|
|
27
|
+
const repo = segments[1];
|
|
28
|
+
const prIdStr = segments[3];
|
|
29
|
+
if (!workspace || !repo) {
|
|
30
|
+
throw new BitbucketUrlParseError('missing-segments', raw);
|
|
31
|
+
}
|
|
32
|
+
if (!prIdStr) {
|
|
33
|
+
throw new BitbucketUrlParseError('missing-segments', raw);
|
|
34
|
+
}
|
|
35
|
+
const prId = parseInt(prIdStr, 10);
|
|
36
|
+
if (!Number.isInteger(prId) || prId <= 0) {
|
|
37
|
+
throw new BitbucketUrlParseError('invalid-pr-id', raw);
|
|
38
|
+
}
|
|
39
|
+
return { workspace, repo, prId };
|
|
40
|
+
}
|
|
41
|
+
//# sourceMappingURL=parse-bitbucket-url.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"parse-bitbucket-url.js","sourceRoot":"","sources":["../../src/utils/parse-bitbucket-url.ts"],"names":[],"mappings":"AAaA,MAAM,OAAO,sBAAuB,SAAQ,KAAK;IACtC,MAAM,CAA0B;IAEzC,YAAY,MAA+B,EAAE,GAAW;QACtD,KAAK,CAAC,kCAAkC,MAAM,MAAM,GAAG,EAAE,CAAC,CAAC;QAC3D,IAAI,CAAC,IAAI,GAAG,wBAAwB,CAAC;QACrC,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC;QACrB,MAAM,CAAC,cAAc,CAAC,IAAI,EAAE,GAAG,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC;IACpD,CAAC;CACF;AAED,MAAM,UAAU,iBAAiB,CAAC,GAAW;IAC3C,IAAI,MAAW,CAAC;IAChB,IAAI,CAAC;QACH,MAAM,GAAG,IAAI,GAAG,CAAC,GAAG,CAAC,CAAC;IACxB,CAAC;IAAC,MAAM,CAAC;QACP,MAAM,IAAI,sBAAsB,CAAC,eAAe,EAAE,GAAG,CAAC,CAAC;IACzD,CAAC;IAED,IAAI,MAAM,CAAC,QAAQ,KAAK,eAAe,EAAE,CAAC;QACxC,MAAM,IAAI,sBAAsB,CAAC,YAAY,EAAE,GAAG,CAAC,CAAC;IACtD,CAAC;IAED,MAAM,QAAQ,GAAG,MAAM,CAAC,QAAQ,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC;IAE5D,iEAAiE;IACjE,IAAI,QAAQ,CAAC,MAAM,GAAG,CAAC,IAAI,QAAQ,CAAC,CAAC,CAAC,KAAK,eAAe,EAAE,CAAC;QAC3D,MAAM,IAAI,sBAAsB,CAAC,aAAa,EAAE,GAAG,CAAC,CAAC;IACvD,CAAC;IAED,MAAM,SAAS,GAAG,QAAQ,CAAC,CAAC,CAAC,CAAC;IAC9B,MAAM,IAAI,GAAG,QAAQ,CAAC,CAAC,CAAC,CAAC;IACzB,MAAM,OAAO,GAAG,QAAQ,CAAC,CAAC,CAAC,CAAC;IAE5B,IAAI,CAAC,SAAS,IAAI,CAAC,IAAI,EAAE,CAAC;QACxB,MAAM,IAAI,sBAAsB,CAAC,kBAAkB,EAAE,GAAG,CAAC,CAAC;IAC5D,CAAC;IAED,IAAI,CAAC,OAAO,EAAE,CAAC;QACb,MAAM,IAAI,sBAAsB,CAAC,kBAAkB,EAAE,GAAG,CAAC,CAAC;IAC5D,CAAC;IAED,MAAM,IAAI,GAAG,QAAQ,CAAC,OAAO,EAAE,EAAE,CAAC,CAAC;IACnC,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC,IAAI,CAAC,IAAI,IAAI,IAAI,CAAC,EAAE,CAAC;QACzC,MAAM,IAAI,sBAAsB,CAAC,eAAe,EAAE,GAAG,CAAC,CAAC;IACzD,CAAC;IAED,OAAO,EAAE,SAAS,EAAE,IAAI,EAAE,IAAI,EAAE,CAAC;AACnC,CAAC"}
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
export declare function getConfigDir(): string;
|
|
2
|
+
export declare function getCredentialsPath(): string;
|
|
3
|
+
export declare function getConfigPath(): string;
|
|
4
|
+
export declare function getDbPath(): string;
|
|
5
|
+
export declare function ensureConfigDir(): void;
|
|
6
|
+
//# sourceMappingURL=paths.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"paths.d.ts","sourceRoot":"","sources":["../../src/utils/paths.ts"],"names":[],"mappings":"AAKA,wBAAgB,YAAY,IAAI,MAAM,CAYrC;AAED,wBAAgB,kBAAkB,IAAI,MAAM,CAE3C;AAED,wBAAgB,aAAa,IAAI,MAAM,CAEtC;AAED,wBAAgB,SAAS,IAAI,MAAM,CAElC;AAED,wBAAgB,eAAe,IAAI,IAAI,CAEtC"}
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
import path from 'node:path';
|
|
2
|
+
import os from 'node:os';
|
|
3
|
+
import fs from 'node:fs';
|
|
4
|
+
import { ConfigError } from '../errors/index.js';
|
|
5
|
+
export function getConfigDir() {
|
|
6
|
+
if (process.platform === 'win32') {
|
|
7
|
+
const appData = process.env['APPDATA'];
|
|
8
|
+
if (!appData) {
|
|
9
|
+
throw new ConfigError('APPDATA environment variable is not set — cannot determine config directory', 'Cannot find config directory: APPDATA is not set');
|
|
10
|
+
}
|
|
11
|
+
return path.join(appData, 'prism-cli');
|
|
12
|
+
}
|
|
13
|
+
return path.join(os.homedir(), '.config', 'prism-cli');
|
|
14
|
+
}
|
|
15
|
+
export function getCredentialsPath() {
|
|
16
|
+
return path.join(getConfigDir(), 'credentials.json');
|
|
17
|
+
}
|
|
18
|
+
export function getConfigPath() {
|
|
19
|
+
return path.join(getConfigDir(), 'config.json');
|
|
20
|
+
}
|
|
21
|
+
export function getDbPath() {
|
|
22
|
+
return path.join(getConfigDir(), 'prism.db');
|
|
23
|
+
}
|
|
24
|
+
export function ensureConfigDir() {
|
|
25
|
+
fs.mkdirSync(getConfigDir(), { recursive: true, mode: 0o700 });
|
|
26
|
+
}
|
|
27
|
+
//# sourceMappingURL=paths.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"paths.js","sourceRoot":"","sources":["../../src/utils/paths.ts"],"names":[],"mappings":"AAAA,OAAO,IAAI,MAAM,WAAW,CAAC;AAC7B,OAAO,EAAE,MAAM,SAAS,CAAC;AACzB,OAAO,EAAE,MAAM,SAAS,CAAC;AACzB,OAAO,EAAE,WAAW,EAAE,MAAM,oBAAoB,CAAC;AAEjD,MAAM,UAAU,YAAY;IAC1B,IAAI,OAAO,CAAC,QAAQ,KAAK,OAAO,EAAE,CAAC;QACjC,MAAM,OAAO,GAAG,OAAO,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC;QACvC,IAAI,CAAC,OAAO,EAAE,CAAC;YACb,MAAM,IAAI,WAAW,CACnB,6EAA6E,EAC7E,kDAAkD,CACnD,CAAC;QACJ,CAAC;QACD,OAAO,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,WAAW,CAAC,CAAC;IACzC,CAAC;IACD,OAAO,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,OAAO,EAAE,EAAE,SAAS,EAAE,WAAW,CAAC,CAAC;AACzD,CAAC;AAED,MAAM,UAAU,kBAAkB;IAChC,OAAO,IAAI,CAAC,IAAI,CAAC,YAAY,EAAE,EAAE,kBAAkB,CAAC,CAAC;AACvD,CAAC;AAED,MAAM,UAAU,aAAa;IAC3B,OAAO,IAAI,CAAC,IAAI,CAAC,YAAY,EAAE,EAAE,aAAa,CAAC,CAAC;AAClD,CAAC;AAED,MAAM,UAAU,SAAS;IACvB,OAAO,IAAI,CAAC,IAAI,CAAC,YAAY,EAAE,EAAE,UAAU,CAAC,CAAC;AAC/C,CAAC;AAED,MAAM,UAAU,eAAe;IAC7B,EAAE,CAAC,SAAS,CAAC,YAAY,EAAE,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,IAAI,EAAE,KAAK,EAAE,CAAC,CAAC;AACjE,CAAC"}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
export interface SummaryParams {
|
|
2
|
+
status: 'clean' | 'findings';
|
|
3
|
+
sessionId: string | null;
|
|
4
|
+
severityCounts: {
|
|
5
|
+
critical: number;
|
|
6
|
+
high: number;
|
|
7
|
+
medium: number;
|
|
8
|
+
low: number;
|
|
9
|
+
};
|
|
10
|
+
agentIds: string[];
|
|
11
|
+
filesReviewed: number;
|
|
12
|
+
totalFiles: number;
|
|
13
|
+
approved: boolean;
|
|
14
|
+
timestamp?: string;
|
|
15
|
+
}
|
|
16
|
+
export declare function buildReviewSummary(params: SummaryParams): string;
|
|
17
|
+
//# sourceMappingURL=summary-generator.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"summary-generator.d.ts","sourceRoot":"","sources":["../../src/utils/summary-generator.ts"],"names":[],"mappings":"AAAA,MAAM,WAAW,aAAa;IAC5B,MAAM,EAAE,OAAO,GAAG,UAAU,CAAC;IAC7B,SAAS,EAAE,MAAM,GAAG,IAAI,CAAC;IACzB,cAAc,EAAE;QAAE,QAAQ,EAAE,MAAM,CAAC;QAAC,IAAI,EAAE,MAAM,CAAC;QAAC,MAAM,EAAE,MAAM,CAAC;QAAC,GAAG,EAAE,MAAM,CAAA;KAAE,CAAC;IAChF,QAAQ,EAAE,MAAM,EAAE,CAAC;IACnB,aAAa,EAAE,MAAM,CAAC;IACtB,UAAU,EAAE,MAAM,CAAC;IACnB,QAAQ,EAAE,OAAO,CAAC;IAClB,SAAS,CAAC,EAAE,MAAM,CAAC;CACpB;AAqBD,wBAAgB,kBAAkB,CAAC,MAAM,EAAE,aAAa,GAAG,MAAM,CA6EhE"}
|
|
@@ -0,0 +1,76 @@
|
|
|
1
|
+
const SEVERITY_ROWS = [
|
|
2
|
+
{ key: 'critical', emoji: '🔴', label: 'Critical' },
|
|
3
|
+
{ key: 'high', emoji: '🟠', label: 'High' },
|
|
4
|
+
{ key: 'medium', emoji: '🟡', label: 'Medium' },
|
|
5
|
+
{ key: 'low', emoji: '🔵', label: 'Low' },
|
|
6
|
+
];
|
|
7
|
+
function formatTimestamp(iso) {
|
|
8
|
+
const date = new Date(iso);
|
|
9
|
+
return date.toLocaleDateString('en-US', {
|
|
10
|
+
year: 'numeric',
|
|
11
|
+
month: 'short',
|
|
12
|
+
day: 'numeric',
|
|
13
|
+
hour: '2-digit',
|
|
14
|
+
minute: '2-digit',
|
|
15
|
+
timeZoneName: 'short',
|
|
16
|
+
});
|
|
17
|
+
}
|
|
18
|
+
export function buildReviewSummary(params) {
|
|
19
|
+
const { status, sessionId, severityCounts, agentIds, filesReviewed, totalFiles, approved, timestamp = new Date().toISOString(), } = params;
|
|
20
|
+
const sessionTag = sessionId ?? 'none';
|
|
21
|
+
const statusTag = status === 'clean' ? 'CLEAN' : 'FINDINGS';
|
|
22
|
+
// Status line
|
|
23
|
+
let statusLine;
|
|
24
|
+
if (status === 'clean') {
|
|
25
|
+
statusLine = approved
|
|
26
|
+
? '✅ No issues found — PR approved automatically'
|
|
27
|
+
: '✅ No issues found';
|
|
28
|
+
}
|
|
29
|
+
else {
|
|
30
|
+
const total = severityCounts.critical +
|
|
31
|
+
severityCounts.high +
|
|
32
|
+
severityCounts.medium +
|
|
33
|
+
severityCounts.low;
|
|
34
|
+
statusLine = `⚠️ ${total} finding(s) found`;
|
|
35
|
+
}
|
|
36
|
+
// Severity table (findings only, omit rows with count 0)
|
|
37
|
+
let severityTable = '';
|
|
38
|
+
if (status === 'findings') {
|
|
39
|
+
const activeRows = SEVERITY_ROWS.filter(({ key }) => severityCounts[key] > 0);
|
|
40
|
+
if (activeRows.length > 0) {
|
|
41
|
+
const rows = activeRows
|
|
42
|
+
.map(({ key, emoji, label }) => `| ${emoji} ${label} | ${severityCounts[key]} |`)
|
|
43
|
+
.join('\n');
|
|
44
|
+
severityTable =
|
|
45
|
+
`| Severity | Count |\n` +
|
|
46
|
+
`|----------|-------|\n` +
|
|
47
|
+
rows +
|
|
48
|
+
'\n\n';
|
|
49
|
+
}
|
|
50
|
+
}
|
|
51
|
+
// Approval line (only on clean + approved)
|
|
52
|
+
const approvalLine = status === 'clean' && approved
|
|
53
|
+
? '\n✅ PR approved automatically — no issues detected.\n'
|
|
54
|
+
: '';
|
|
55
|
+
const metricsTable = `| Metric | Value |\n` +
|
|
56
|
+
`|--------|-------|\n` +
|
|
57
|
+
`| Files reviewed | ${filesReviewed} / ${totalFiles} |\n` +
|
|
58
|
+
`| Agents | ${agentIds.length} |`;
|
|
59
|
+
const formattedDate = formatTimestamp(timestamp);
|
|
60
|
+
const output = `<!-- PRISM:REVIEW:START | PRISM:STATUS:${statusTag} | PRISM:VERSION:1 | PRISM:SESSION:${sessionTag} -->\n` +
|
|
61
|
+
`\n` +
|
|
62
|
+
`## 🔍 PRISM Code Review\n` +
|
|
63
|
+
`\n` +
|
|
64
|
+
`**Status:** ${statusLine}\n` +
|
|
65
|
+
`\n` +
|
|
66
|
+
severityTable +
|
|
67
|
+
metricsTable +
|
|
68
|
+
`\n` +
|
|
69
|
+
approvalLine +
|
|
70
|
+
`\n` +
|
|
71
|
+
`---\n` +
|
|
72
|
+
`<sub>Generated by PRISM • ${formattedDate}</sub>\n` +
|
|
73
|
+
`<!-- PRISM:REVIEW:END -->\n`;
|
|
74
|
+
return output;
|
|
75
|
+
}
|
|
76
|
+
//# sourceMappingURL=summary-generator.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"summary-generator.js","sourceRoot":"","sources":["../../src/utils/summary-generator.ts"],"names":[],"mappings":"AAWA,MAAM,aAAa,GAAwF;IACzG,EAAE,GAAG,EAAE,UAAU,EAAE,KAAK,EAAE,IAAI,EAAE,KAAK,EAAE,UAAU,EAAE;IACnD,EAAE,GAAG,EAAE,MAAM,EAAM,KAAK,EAAE,IAAI,EAAE,KAAK,EAAE,MAAM,EAAM;IACnD,EAAE,GAAG,EAAE,QAAQ,EAAI,KAAK,EAAE,IAAI,EAAE,KAAK,EAAE,QAAQ,EAAI;IACnD,EAAE,GAAG,EAAE,KAAK,EAAO,KAAK,EAAE,IAAI,EAAE,KAAK,EAAE,KAAK,EAAO;CACpD,CAAC;AAEF,SAAS,eAAe,CAAC,GAAW;IAClC,MAAM,IAAI,GAAG,IAAI,IAAI,CAAC,GAAG,CAAC,CAAC;IAC3B,OAAO,IAAI,CAAC,kBAAkB,CAAC,OAAO,EAAE;QACtC,IAAI,EAAE,SAAS;QACf,KAAK,EAAE,OAAO;QACd,GAAG,EAAE,SAAS;QACd,IAAI,EAAE,SAAS;QACf,MAAM,EAAE,SAAS;QACjB,YAAY,EAAE,OAAO;KACtB,CAAC,CAAC;AACL,CAAC;AAED,MAAM,UAAU,kBAAkB,CAAC,MAAqB;IACtD,MAAM,EACJ,MAAM,EACN,SAAS,EACT,cAAc,EACd,QAAQ,EACR,aAAa,EACb,UAAU,EACV,QAAQ,EACR,SAAS,GAAG,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE,GACrC,GAAG,MAAM,CAAC;IAEX,MAAM,UAAU,GAAG,SAAS,IAAI,MAAM,CAAC;IACvC,MAAM,SAAS,GAAG,MAAM,KAAK,OAAO,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,UAAU,CAAC;IAE5D,cAAc;IACd,IAAI,UAAkB,CAAC;IACvB,IAAI,MAAM,KAAK,OAAO,EAAE,CAAC;QACvB,UAAU,GAAG,QAAQ;YACnB,CAAC,CAAC,+CAA+C;YACjD,CAAC,CAAC,mBAAmB,CAAC;IAC1B,CAAC;SAAM,CAAC;QACN,MAAM,KAAK,GACT,cAAc,CAAC,QAAQ;YACvB,cAAc,CAAC,IAAI;YACnB,cAAc,CAAC,MAAM;YACrB,cAAc,CAAC,GAAG,CAAC;QACrB,UAAU,GAAG,MAAM,KAAK,mBAAmB,CAAC;IAC9C,CAAC;IAED,yDAAyD;IACzD,IAAI,aAAa,GAAG,EAAE,CAAC;IACvB,IAAI,MAAM,KAAK,UAAU,EAAE,CAAC;QAC1B,MAAM,UAAU,GAAG,aAAa,CAAC,MAAM,CAAC,CAAC,EAAE,GAAG,EAAE,EAAE,EAAE,CAAC,cAAc,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,CAAC;QAC9E,IAAI,UAAU,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YAC1B,MAAM,IAAI,GAAG,UAAU;iBACpB,GAAG,CAAC,CAAC,EAAE,GAAG,EAAE,KAAK,EAAE,KAAK,EAAE,EAAE,EAAE,CAAC,KAAK,KAAK,IAAI,KAAK,MAAM,cAAc,CAAC,GAAG,CAAC,IAAI,CAAC;iBAChF,IAAI,CAAC,IAAI,CAAC,CAAC;YACd,aAAa;gBACX,wBAAwB;oBACxB,wBAAwB;oBACxB,IAAI;oBACJ,MAAM,CAAC;QACX,CAAC;IACH,CAAC;IAED,2CAA2C;IAC3C,MAAM,YAAY,GAChB,MAAM,KAAK,OAAO,IAAI,QAAQ;QAC5B,CAAC,CAAC,uDAAuD;QACzD,CAAC,CAAC,EAAE,CAAC;IAET,MAAM,YAAY,GAChB,sBAAsB;QACtB,sBAAsB;QACtB,sBAAsB,aAAa,MAAM,UAAU,MAAM;QACzD,cAAc,QAAQ,CAAC,MAAM,IAAI,CAAC;IAEpC,MAAM,aAAa,GAAG,eAAe,CAAC,SAAS,CAAC,CAAC;IAEjD,MAAM,MAAM,GACV,0CAA0C,SAAS,sCAAsC,UAAU,QAAQ;QAC3G,IAAI;QACJ,2BAA2B;QAC3B,IAAI;QACJ,eAAe,UAAU,IAAI;QAC7B,IAAI;QACJ,aAAa;QACb,YAAY;QACZ,IAAI;QACJ,YAAY;QACZ,IAAI;QACJ,OAAO;QACP,6BAA6B,aAAa,UAAU;QACpD,6BAA6B,CAAC;IAEhC,OAAO,MAAM,CAAC;AAChB,CAAC"}
|
|
@@ -0,0 +1,467 @@
|
|
|
1
|
+
{
|
|
2
|
+
"commands": {
|
|
3
|
+
"interactive": {
|
|
4
|
+
"aliases": [],
|
|
5
|
+
"args": {},
|
|
6
|
+
"description": "Launch the interactive TUI",
|
|
7
|
+
"examples": [
|
|
8
|
+
"$ prism"
|
|
9
|
+
],
|
|
10
|
+
"flags": {
|
|
11
|
+
"no-tui": {
|
|
12
|
+
"description": "Disable TUI mode (use command mode instead)",
|
|
13
|
+
"name": "no-tui",
|
|
14
|
+
"allowNo": false,
|
|
15
|
+
"type": "boolean"
|
|
16
|
+
}
|
|
17
|
+
},
|
|
18
|
+
"hasDynamicHelp": false,
|
|
19
|
+
"hiddenAliases": [],
|
|
20
|
+
"id": "interactive",
|
|
21
|
+
"pluginAlias": "prism-pr",
|
|
22
|
+
"pluginName": "prism-pr",
|
|
23
|
+
"pluginType": "core",
|
|
24
|
+
"strict": true,
|
|
25
|
+
"enableJsonFlag": false,
|
|
26
|
+
"isESM": true,
|
|
27
|
+
"relativePath": [
|
|
28
|
+
"dist",
|
|
29
|
+
"commands",
|
|
30
|
+
"interactive.js"
|
|
31
|
+
]
|
|
32
|
+
},
|
|
33
|
+
"login": {
|
|
34
|
+
"aliases": [],
|
|
35
|
+
"args": {},
|
|
36
|
+
"description": "Authenticate with Bitbucket using your Atlassian API token",
|
|
37
|
+
"examples": [
|
|
38
|
+
"$ prism login"
|
|
39
|
+
],
|
|
40
|
+
"flags": {},
|
|
41
|
+
"hasDynamicHelp": false,
|
|
42
|
+
"hiddenAliases": [],
|
|
43
|
+
"id": "login",
|
|
44
|
+
"pluginAlias": "prism-pr",
|
|
45
|
+
"pluginName": "prism-pr",
|
|
46
|
+
"pluginType": "core",
|
|
47
|
+
"strict": true,
|
|
48
|
+
"enableJsonFlag": false,
|
|
49
|
+
"isESM": true,
|
|
50
|
+
"relativePath": [
|
|
51
|
+
"dist",
|
|
52
|
+
"commands",
|
|
53
|
+
"login.js"
|
|
54
|
+
]
|
|
55
|
+
},
|
|
56
|
+
"logout": {
|
|
57
|
+
"aliases": [],
|
|
58
|
+
"args": {},
|
|
59
|
+
"description": "Remove stored Bitbucket credentials",
|
|
60
|
+
"examples": [
|
|
61
|
+
"$ prism logout"
|
|
62
|
+
],
|
|
63
|
+
"flags": {},
|
|
64
|
+
"hasDynamicHelp": false,
|
|
65
|
+
"hiddenAliases": [],
|
|
66
|
+
"id": "logout",
|
|
67
|
+
"pluginAlias": "prism-pr",
|
|
68
|
+
"pluginName": "prism-pr",
|
|
69
|
+
"pluginType": "core",
|
|
70
|
+
"strict": true,
|
|
71
|
+
"enableJsonFlag": false,
|
|
72
|
+
"isESM": true,
|
|
73
|
+
"relativePath": [
|
|
74
|
+
"dist",
|
|
75
|
+
"commands",
|
|
76
|
+
"logout.js"
|
|
77
|
+
]
|
|
78
|
+
},
|
|
79
|
+
"guard:check": {
|
|
80
|
+
"aliases": [],
|
|
81
|
+
"args": {},
|
|
82
|
+
"description": "Check a PR against learned patterns (non-interactive)",
|
|
83
|
+
"examples": [
|
|
84
|
+
"$ prism guard check --workspace acme --repo my-repo --pr 42",
|
|
85
|
+
"$ prism guard check --workspace acme --repo my-repo --pr 42 --min-severity high",
|
|
86
|
+
"$ prism guard check --workspace acme --repo my-repo --pr 42 --json"
|
|
87
|
+
],
|
|
88
|
+
"flags": {
|
|
89
|
+
"workspace": {
|
|
90
|
+
"char": "w",
|
|
91
|
+
"description": "Bitbucket workspace slug",
|
|
92
|
+
"name": "workspace",
|
|
93
|
+
"required": true,
|
|
94
|
+
"hasDynamicHelp": false,
|
|
95
|
+
"multiple": false,
|
|
96
|
+
"type": "option"
|
|
97
|
+
},
|
|
98
|
+
"repo": {
|
|
99
|
+
"char": "r",
|
|
100
|
+
"description": "Repository slug",
|
|
101
|
+
"name": "repo",
|
|
102
|
+
"required": true,
|
|
103
|
+
"hasDynamicHelp": false,
|
|
104
|
+
"multiple": false,
|
|
105
|
+
"type": "option"
|
|
106
|
+
},
|
|
107
|
+
"pr": {
|
|
108
|
+
"char": "p",
|
|
109
|
+
"description": "Pull request ID",
|
|
110
|
+
"name": "pr",
|
|
111
|
+
"required": true,
|
|
112
|
+
"hasDynamicHelp": false,
|
|
113
|
+
"multiple": false,
|
|
114
|
+
"type": "option"
|
|
115
|
+
},
|
|
116
|
+
"patterns": {
|
|
117
|
+
"description": "Path to patterns file",
|
|
118
|
+
"name": "patterns",
|
|
119
|
+
"default": ".prism-patterns.json",
|
|
120
|
+
"hasDynamicHelp": false,
|
|
121
|
+
"multiple": false,
|
|
122
|
+
"type": "option"
|
|
123
|
+
},
|
|
124
|
+
"min-severity": {
|
|
125
|
+
"description": "Minimum severity to report (critical, high, medium, low, info)",
|
|
126
|
+
"name": "min-severity",
|
|
127
|
+
"hasDynamicHelp": false,
|
|
128
|
+
"multiple": false,
|
|
129
|
+
"type": "option"
|
|
130
|
+
},
|
|
131
|
+
"json": {
|
|
132
|
+
"description": "Output results as JSON",
|
|
133
|
+
"name": "json",
|
|
134
|
+
"allowNo": false,
|
|
135
|
+
"type": "boolean"
|
|
136
|
+
},
|
|
137
|
+
"verbose": {
|
|
138
|
+
"description": "Enable verbose output",
|
|
139
|
+
"name": "verbose",
|
|
140
|
+
"allowNo": false,
|
|
141
|
+
"type": "boolean"
|
|
142
|
+
},
|
|
143
|
+
"remote": {
|
|
144
|
+
"description": "Fetch patterns from remote rules repository",
|
|
145
|
+
"name": "remote",
|
|
146
|
+
"allowNo": false,
|
|
147
|
+
"type": "boolean"
|
|
148
|
+
},
|
|
149
|
+
"skip-ast": {
|
|
150
|
+
"description": "Skip ast-grep matching, use keyword-only",
|
|
151
|
+
"name": "skip-ast",
|
|
152
|
+
"allowNo": false,
|
|
153
|
+
"type": "boolean"
|
|
154
|
+
}
|
|
155
|
+
},
|
|
156
|
+
"hasDynamicHelp": false,
|
|
157
|
+
"hiddenAliases": [],
|
|
158
|
+
"id": "guard:check",
|
|
159
|
+
"pluginAlias": "prism-pr",
|
|
160
|
+
"pluginName": "prism-pr",
|
|
161
|
+
"pluginType": "core",
|
|
162
|
+
"strict": true,
|
|
163
|
+
"enableJsonFlag": false,
|
|
164
|
+
"isESM": true,
|
|
165
|
+
"relativePath": [
|
|
166
|
+
"dist",
|
|
167
|
+
"commands",
|
|
168
|
+
"guard",
|
|
169
|
+
"check.js"
|
|
170
|
+
]
|
|
171
|
+
},
|
|
172
|
+
"guard": {
|
|
173
|
+
"aliases": [],
|
|
174
|
+
"args": {},
|
|
175
|
+
"description": "Launch the Guard Check TUI",
|
|
176
|
+
"examples": [
|
|
177
|
+
"$ prism guard"
|
|
178
|
+
],
|
|
179
|
+
"flags": {},
|
|
180
|
+
"hasDynamicHelp": false,
|
|
181
|
+
"hiddenAliases": [],
|
|
182
|
+
"id": "guard",
|
|
183
|
+
"pluginAlias": "prism-pr",
|
|
184
|
+
"pluginName": "prism-pr",
|
|
185
|
+
"pluginType": "core",
|
|
186
|
+
"strict": true,
|
|
187
|
+
"enableJsonFlag": false,
|
|
188
|
+
"isESM": true,
|
|
189
|
+
"relativePath": [
|
|
190
|
+
"dist",
|
|
191
|
+
"commands",
|
|
192
|
+
"guard",
|
|
193
|
+
"index.js"
|
|
194
|
+
]
|
|
195
|
+
},
|
|
196
|
+
"review:start": {
|
|
197
|
+
"aliases": [],
|
|
198
|
+
"args": {},
|
|
199
|
+
"description": "Run an AI code review on a Bitbucket pull request",
|
|
200
|
+
"examples": [
|
|
201
|
+
"$ prism review start --pr 42 --repo my-repo --workspace my-company",
|
|
202
|
+
"$ prism review start --pr 42 --repo my-repo --workspace my-company --verbose"
|
|
203
|
+
],
|
|
204
|
+
"flags": {
|
|
205
|
+
"pr": {
|
|
206
|
+
"description": "Pull request ID",
|
|
207
|
+
"name": "pr",
|
|
208
|
+
"required": true,
|
|
209
|
+
"hasDynamicHelp": false,
|
|
210
|
+
"multiple": false,
|
|
211
|
+
"type": "option"
|
|
212
|
+
},
|
|
213
|
+
"repo": {
|
|
214
|
+
"description": "Repository slug",
|
|
215
|
+
"name": "repo",
|
|
216
|
+
"required": true,
|
|
217
|
+
"hasDynamicHelp": false,
|
|
218
|
+
"multiple": false,
|
|
219
|
+
"type": "option"
|
|
220
|
+
},
|
|
221
|
+
"workspace": {
|
|
222
|
+
"description": "Bitbucket workspace slug",
|
|
223
|
+
"name": "workspace",
|
|
224
|
+
"required": true,
|
|
225
|
+
"hasDynamicHelp": false,
|
|
226
|
+
"multiple": false,
|
|
227
|
+
"type": "option"
|
|
228
|
+
},
|
|
229
|
+
"verbose": {
|
|
230
|
+
"description": "Enable verbose/debug logging",
|
|
231
|
+
"name": "verbose",
|
|
232
|
+
"allowNo": false,
|
|
233
|
+
"type": "boolean"
|
|
234
|
+
},
|
|
235
|
+
"provider": {
|
|
236
|
+
"description": "AI provider to use (anthropic or claude-code)",
|
|
237
|
+
"name": "provider",
|
|
238
|
+
"required": false,
|
|
239
|
+
"hasDynamicHelp": false,
|
|
240
|
+
"multiple": false,
|
|
241
|
+
"options": [
|
|
242
|
+
"anthropic",
|
|
243
|
+
"claude-code"
|
|
244
|
+
],
|
|
245
|
+
"type": "option"
|
|
246
|
+
}
|
|
247
|
+
},
|
|
248
|
+
"hasDynamicHelp": false,
|
|
249
|
+
"hiddenAliases": [],
|
|
250
|
+
"id": "review:start",
|
|
251
|
+
"pluginAlias": "prism-pr",
|
|
252
|
+
"pluginName": "prism-pr",
|
|
253
|
+
"pluginType": "core",
|
|
254
|
+
"strict": true,
|
|
255
|
+
"enableJsonFlag": false,
|
|
256
|
+
"isESM": true,
|
|
257
|
+
"relativePath": [
|
|
258
|
+
"dist",
|
|
259
|
+
"commands",
|
|
260
|
+
"review",
|
|
261
|
+
"start.js"
|
|
262
|
+
]
|
|
263
|
+
},
|
|
264
|
+
"rules:push": {
|
|
265
|
+
"aliases": [],
|
|
266
|
+
"args": {},
|
|
267
|
+
"description": "Push local patterns file to the remote rules repository",
|
|
268
|
+
"examples": [
|
|
269
|
+
"$ prism rules push --workspace acme --repo my-repo"
|
|
270
|
+
],
|
|
271
|
+
"flags": {
|
|
272
|
+
"workspace": {
|
|
273
|
+
"char": "w",
|
|
274
|
+
"description": "Bitbucket workspace slug",
|
|
275
|
+
"name": "workspace",
|
|
276
|
+
"required": true,
|
|
277
|
+
"hasDynamicHelp": false,
|
|
278
|
+
"multiple": false,
|
|
279
|
+
"type": "option"
|
|
280
|
+
},
|
|
281
|
+
"repo": {
|
|
282
|
+
"char": "r",
|
|
283
|
+
"description": "Repository slug",
|
|
284
|
+
"name": "repo",
|
|
285
|
+
"required": true,
|
|
286
|
+
"hasDynamicHelp": false,
|
|
287
|
+
"multiple": false,
|
|
288
|
+
"type": "option"
|
|
289
|
+
},
|
|
290
|
+
"patterns": {
|
|
291
|
+
"description": "Path to patterns file",
|
|
292
|
+
"name": "patterns",
|
|
293
|
+
"default": ".prism-patterns.json",
|
|
294
|
+
"hasDynamicHelp": false,
|
|
295
|
+
"multiple": false,
|
|
296
|
+
"type": "option"
|
|
297
|
+
},
|
|
298
|
+
"verbose": {
|
|
299
|
+
"description": "Enable verbose output",
|
|
300
|
+
"name": "verbose",
|
|
301
|
+
"allowNo": false,
|
|
302
|
+
"type": "boolean"
|
|
303
|
+
}
|
|
304
|
+
},
|
|
305
|
+
"hasDynamicHelp": false,
|
|
306
|
+
"hiddenAliases": [],
|
|
307
|
+
"id": "rules:push",
|
|
308
|
+
"pluginAlias": "prism-pr",
|
|
309
|
+
"pluginName": "prism-pr",
|
|
310
|
+
"pluginType": "core",
|
|
311
|
+
"strict": true,
|
|
312
|
+
"enableJsonFlag": false,
|
|
313
|
+
"isESM": true,
|
|
314
|
+
"relativePath": [
|
|
315
|
+
"dist",
|
|
316
|
+
"commands",
|
|
317
|
+
"rules",
|
|
318
|
+
"push.js"
|
|
319
|
+
]
|
|
320
|
+
},
|
|
321
|
+
"rules:stats": {
|
|
322
|
+
"aliases": [],
|
|
323
|
+
"args": {},
|
|
324
|
+
"description": "Show aggregated finding patterns for a repository",
|
|
325
|
+
"examples": [
|
|
326
|
+
"$ prism rules stats --workspace acme --repo my-repo",
|
|
327
|
+
"$ prism rules stats --workspace acme --repo my-repo --sessions 20 --top 20"
|
|
328
|
+
],
|
|
329
|
+
"flags": {
|
|
330
|
+
"workspace": {
|
|
331
|
+
"char": "w",
|
|
332
|
+
"description": "Bitbucket workspace slug",
|
|
333
|
+
"name": "workspace",
|
|
334
|
+
"required": true,
|
|
335
|
+
"hasDynamicHelp": false,
|
|
336
|
+
"multiple": false,
|
|
337
|
+
"type": "option"
|
|
338
|
+
},
|
|
339
|
+
"repo": {
|
|
340
|
+
"char": "r",
|
|
341
|
+
"description": "Repository slug",
|
|
342
|
+
"name": "repo",
|
|
343
|
+
"required": true,
|
|
344
|
+
"hasDynamicHelp": false,
|
|
345
|
+
"multiple": false,
|
|
346
|
+
"type": "option"
|
|
347
|
+
},
|
|
348
|
+
"sessions": {
|
|
349
|
+
"char": "s",
|
|
350
|
+
"description": "Number of sessions to include",
|
|
351
|
+
"name": "sessions",
|
|
352
|
+
"default": 10,
|
|
353
|
+
"hasDynamicHelp": false,
|
|
354
|
+
"multiple": false,
|
|
355
|
+
"type": "option"
|
|
356
|
+
},
|
|
357
|
+
"top": {
|
|
358
|
+
"char": "t",
|
|
359
|
+
"description": "Max patterns to show",
|
|
360
|
+
"name": "top",
|
|
361
|
+
"default": 10,
|
|
362
|
+
"hasDynamicHelp": false,
|
|
363
|
+
"multiple": false,
|
|
364
|
+
"type": "option"
|
|
365
|
+
},
|
|
366
|
+
"verbose": {
|
|
367
|
+
"description": "Enable verbose logging",
|
|
368
|
+
"name": "verbose",
|
|
369
|
+
"allowNo": false,
|
|
370
|
+
"type": "boolean"
|
|
371
|
+
}
|
|
372
|
+
},
|
|
373
|
+
"hasDynamicHelp": false,
|
|
374
|
+
"hiddenAliases": [],
|
|
375
|
+
"id": "rules:stats",
|
|
376
|
+
"pluginAlias": "prism-pr",
|
|
377
|
+
"pluginName": "prism-pr",
|
|
378
|
+
"pluginType": "core",
|
|
379
|
+
"strict": true,
|
|
380
|
+
"enableJsonFlag": false,
|
|
381
|
+
"isESM": true,
|
|
382
|
+
"relativePath": [
|
|
383
|
+
"dist",
|
|
384
|
+
"commands",
|
|
385
|
+
"rules",
|
|
386
|
+
"stats.js"
|
|
387
|
+
]
|
|
388
|
+
},
|
|
389
|
+
"rules:sync": {
|
|
390
|
+
"aliases": [],
|
|
391
|
+
"args": {},
|
|
392
|
+
"description": "Generate .prism-patterns.json from review history",
|
|
393
|
+
"examples": [
|
|
394
|
+
"$ prism rules sync --workspace acme --repo my-repo",
|
|
395
|
+
"$ prism rules sync --workspace acme --repo my-repo --output ./custom/.prism-patterns.json",
|
|
396
|
+
"$ prism rules sync --workspace acme --repo my-repo --sessions 20",
|
|
397
|
+
"$ prism rules sync --workspace acme --repo my-repo --skip-rules"
|
|
398
|
+
],
|
|
399
|
+
"flags": {
|
|
400
|
+
"workspace": {
|
|
401
|
+
"char": "w",
|
|
402
|
+
"description": "Bitbucket workspace slug",
|
|
403
|
+
"name": "workspace",
|
|
404
|
+
"required": true,
|
|
405
|
+
"hasDynamicHelp": false,
|
|
406
|
+
"multiple": false,
|
|
407
|
+
"type": "option"
|
|
408
|
+
},
|
|
409
|
+
"repo": {
|
|
410
|
+
"char": "r",
|
|
411
|
+
"description": "Repository slug",
|
|
412
|
+
"name": "repo",
|
|
413
|
+
"required": true,
|
|
414
|
+
"hasDynamicHelp": false,
|
|
415
|
+
"multiple": false,
|
|
416
|
+
"type": "option"
|
|
417
|
+
},
|
|
418
|
+
"output": {
|
|
419
|
+
"char": "o",
|
|
420
|
+
"description": "Output path for .prism-patterns.json",
|
|
421
|
+
"name": "output",
|
|
422
|
+
"default": ".prism-patterns.json",
|
|
423
|
+
"hasDynamicHelp": false,
|
|
424
|
+
"multiple": false,
|
|
425
|
+
"type": "option"
|
|
426
|
+
},
|
|
427
|
+
"sessions": {
|
|
428
|
+
"char": "s",
|
|
429
|
+
"description": "Number of most-recent sessions to include",
|
|
430
|
+
"name": "sessions",
|
|
431
|
+
"default": 10,
|
|
432
|
+
"hasDynamicHelp": false,
|
|
433
|
+
"multiple": false,
|
|
434
|
+
"type": "option"
|
|
435
|
+
},
|
|
436
|
+
"verbose": {
|
|
437
|
+
"description": "Enable verbose logging",
|
|
438
|
+
"name": "verbose",
|
|
439
|
+
"allowNo": false,
|
|
440
|
+
"type": "boolean"
|
|
441
|
+
},
|
|
442
|
+
"skip-rules": {
|
|
443
|
+
"description": "Skip ast-grep rule generation (faster, produces v2 file without rules)",
|
|
444
|
+
"name": "skip-rules",
|
|
445
|
+
"allowNo": false,
|
|
446
|
+
"type": "boolean"
|
|
447
|
+
}
|
|
448
|
+
},
|
|
449
|
+
"hasDynamicHelp": false,
|
|
450
|
+
"hiddenAliases": [],
|
|
451
|
+
"id": "rules:sync",
|
|
452
|
+
"pluginAlias": "prism-pr",
|
|
453
|
+
"pluginName": "prism-pr",
|
|
454
|
+
"pluginType": "core",
|
|
455
|
+
"strict": true,
|
|
456
|
+
"enableJsonFlag": false,
|
|
457
|
+
"isESM": true,
|
|
458
|
+
"relativePath": [
|
|
459
|
+
"dist",
|
|
460
|
+
"commands",
|
|
461
|
+
"rules",
|
|
462
|
+
"sync.js"
|
|
463
|
+
]
|
|
464
|
+
}
|
|
465
|
+
},
|
|
466
|
+
"version": "1.0.0-alpha.47"
|
|
467
|
+
}
|