@codyswann/lisa 1.47.1 → 1.49.0
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/.claude-plugin/marketplace.json +48 -0
- package/all/deletions.json +71 -1
- package/all/merge/.claude/settings.json +28 -0
- package/cdk/copy-overwrite/eslint.config.ts +11 -21
- package/cdk/copy-overwrite/eslint.slow.config.ts +4 -73
- package/cdk/copy-overwrite/jest.config.ts +14 -12
- package/cdk/copy-overwrite/tsconfig.json +1 -1
- package/cdk/create-only/.github/workflows/ci.yml +1 -1
- package/cdk/create-only/.github/workflows/deploy.yml +1 -1
- package/cdk/merge/.claude/settings.json +29 -0
- package/cdk/package-lisa/package.lisa.json +1 -0
- package/dist/configs/eslint/base.d.ts +1491 -0
- package/dist/configs/eslint/base.d.ts.map +1 -0
- package/dist/configs/eslint/base.js +386 -0
- package/dist/configs/eslint/base.js.map +1 -0
- package/dist/configs/eslint/cdk.d.ts +32 -0
- package/dist/configs/eslint/cdk.d.ts.map +1 -0
- package/dist/configs/eslint/cdk.js +127 -0
- package/dist/configs/eslint/cdk.js.map +1 -0
- package/dist/configs/eslint/expo.d.ts +16 -0
- package/dist/configs/eslint/expo.d.ts.map +1 -0
- package/dist/configs/eslint/expo.js +264 -0
- package/dist/configs/eslint/expo.js.map +1 -0
- package/dist/configs/eslint/index.d.ts +18 -0
- package/dist/configs/eslint/index.d.ts.map +1 -0
- package/dist/configs/eslint/index.js +18 -0
- package/dist/configs/eslint/index.js.map +1 -0
- package/dist/configs/eslint/nestjs.d.ts +32 -0
- package/dist/configs/eslint/nestjs.d.ts.map +1 -0
- package/dist/configs/eslint/nestjs.js +128 -0
- package/dist/configs/eslint/nestjs.js.map +1 -0
- package/dist/configs/eslint/slow.d.ts +80 -0
- package/dist/configs/eslint/slow.d.ts.map +1 -0
- package/dist/configs/eslint/slow.js +83 -0
- package/dist/configs/eslint/slow.js.map +1 -0
- package/dist/configs/eslint/typescript.d.ts +19 -0
- package/dist/configs/eslint/typescript.d.ts.map +1 -0
- package/dist/configs/eslint/typescript.js +81 -0
- package/dist/configs/eslint/typescript.js.map +1 -0
- package/{typescript/copy-overwrite/jest.base.ts → dist/configs/jest/base.d.ts} +9 -69
- package/dist/configs/jest/base.d.ts.map +1 -0
- package/dist/configs/jest/base.js +83 -0
- package/dist/configs/jest/base.js.map +1 -0
- package/dist/configs/jest/cdk.d.ts +35 -0
- package/dist/configs/jest/cdk.d.ts.map +1 -0
- package/dist/configs/jest/cdk.js +30 -0
- package/dist/configs/jest/cdk.js.map +1 -0
- package/dist/configs/jest/expo.d.ts +56 -0
- package/dist/configs/jest/expo.d.ts.map +1 -0
- package/dist/configs/jest/expo.js +60 -0
- package/dist/configs/jest/expo.js.map +1 -0
- package/dist/configs/jest/index.d.ts +14 -0
- package/dist/configs/jest/index.d.ts.map +1 -0
- package/dist/configs/jest/index.js +14 -0
- package/dist/configs/jest/index.js.map +1 -0
- package/dist/configs/jest/nestjs.d.ts +35 -0
- package/dist/configs/jest/nestjs.d.ts.map +1 -0
- package/dist/configs/jest/nestjs.js +47 -0
- package/dist/configs/jest/nestjs.js.map +1 -0
- package/dist/configs/jest/typescript.d.ts +31 -0
- package/dist/configs/jest/typescript.d.ts.map +1 -0
- package/dist/configs/jest/typescript.js +34 -0
- package/dist/configs/jest/typescript.js.map +1 -0
- package/dist/core/lisa.d.ts +14 -0
- package/dist/core/lisa.d.ts.map +1 -1
- package/dist/core/lisa.js +47 -0
- package/dist/core/lisa.js.map +1 -1
- package/expo/copy-overwrite/eslint.config.ts +5 -20
- package/expo/copy-overwrite/eslint.expo.ts +2 -2
- package/expo/copy-overwrite/eslint.slow.config.ts +4 -90
- package/expo/copy-overwrite/jest.config.ts +14 -12
- package/expo/copy-overwrite/tsconfig.json +1 -1
- package/expo/create-only/.github/workflows/ci.yml +1 -1
- package/expo/create-only/.github/workflows/deploy.yml +1 -1
- package/expo/deletions.json +33 -0
- package/expo/merge/.claude/settings.json +29 -0
- package/expo/package-lisa/package.lisa.json +1 -10
- package/nestjs/copy-overwrite/eslint.config.ts +5 -20
- package/nestjs/copy-overwrite/eslint.slow.config.ts +4 -89
- package/nestjs/copy-overwrite/jest.config.ts +14 -12
- package/nestjs/copy-overwrite/tsconfig.json +1 -1
- package/nestjs/create-only/.github/workflows/ci.yml +1 -1
- package/nestjs/create-only/.github/workflows/deploy.yml +1 -1
- package/nestjs/deletions.json +8 -0
- package/nestjs/merge/.claude/settings.json +29 -0
- package/nestjs/package-lisa/package.lisa.json +1 -0
- package/package.json +86 -43
- package/plugins/lisa-cdk/.claude-plugin/plugin.json +86 -0
- package/{all/copy-overwrite/.claude/commands/git/commit-and-submit-pr.md → plugins/lisa-cdk/commands/git-commit-and-submit-pr.md} +1 -1
- package/{all/copy-overwrite/.claude/commands/git/commit-submit-pr-and-verify.md → plugins/lisa-cdk/commands/git-commit-submit-pr-and-verify.md} +1 -1
- package/{all/copy-overwrite/.claude/commands/git/commit-submit-pr-deploy-and-verify.md → plugins/lisa-cdk/commands/git-commit-submit-pr-deploy-and-verify.md} +1 -1
- package/{all/copy-overwrite/.claude/commands/git/commit.md → plugins/lisa-cdk/commands/git-commit.md} +1 -1
- package/{all/copy-overwrite/.claude/commands/git/prune.md → plugins/lisa-cdk/commands/git-prune.md} +1 -1
- package/{all/copy-overwrite/.claude/commands/git/submit-pr.md → plugins/lisa-cdk/commands/git-submit-pr.md} +1 -1
- package/plugins/lisa-cdk/commands/jira-add-journey.md +7 -0
- package/{all/copy-overwrite/.claude/commands/jira/create.md → plugins/lisa-cdk/commands/jira-create.md} +1 -1
- package/plugins/lisa-cdk/commands/jira-evidence.md +7 -0
- package/plugins/lisa-cdk/commands/jira-fix.md +7 -0
- package/plugins/lisa-cdk/commands/jira-implement.md +7 -0
- package/plugins/lisa-cdk/commands/jira-journey.md +7 -0
- package/{all/copy-overwrite/.claude/commands/jira/sync.md → plugins/lisa-cdk/commands/jira-sync.md} +1 -1
- package/{all/copy-overwrite/.claude/commands/jira/verify.md → plugins/lisa-cdk/commands/jira-verify.md} +1 -1
- package/{all/copy-overwrite/.claude/commands/lisa/review-implementation.md → plugins/lisa-cdk/commands/lisa-review-implementation.md} +1 -1
- package/{all/copy-overwrite/.claude/commands/plan/add-test-coverage.md → plugins/lisa-cdk/commands/plan-add-test-coverage.md} +1 -1
- package/{all/copy-overwrite/.claude/commands/plan/create.md → plugins/lisa-cdk/commands/plan-create.md} +1 -1
- package/{all/copy-overwrite/.claude/commands/plan/execute.md → plugins/lisa-cdk/commands/plan-execute.md} +1 -1
- package/{all/copy-overwrite/.claude/commands/plan/fix-linter-error.md → plugins/lisa-cdk/commands/plan-fix-linter-error.md} +1 -1
- package/{all/copy-overwrite/.claude/commands/plan/local-code-review.md → plugins/lisa-cdk/commands/plan-local-code-review.md} +1 -1
- package/{all/copy-overwrite/.claude/commands/plan/lower-code-complexity.md → plugins/lisa-cdk/commands/plan-lower-code-complexity.md} +1 -1
- package/{all/copy-overwrite/.claude/commands/plan/reduce-max-lines-per-function.md → plugins/lisa-cdk/commands/plan-reduce-max-lines-per-function.md} +1 -1
- package/{all/copy-overwrite/.claude/commands/plan/reduce-max-lines.md → plugins/lisa-cdk/commands/plan-reduce-max-lines.md} +1 -1
- package/{all/copy-overwrite/.claude/commands/pull-request/review.md → plugins/lisa-cdk/commands/pull-request-review.md} +1 -1
- package/{all/copy-overwrite/.claude/commands/security/zap-scan.md → plugins/lisa-cdk/commands/security-zap-scan.md} +1 -1
- package/{all/copy-overwrite/.claude/commands/sonarqube/check.md → plugins/lisa-cdk/commands/sonarqube-check.md} +1 -1
- package/{all/copy-overwrite/.claude/commands/sonarqube/fix.md → plugins/lisa-cdk/commands/sonarqube-fix.md} +1 -1
- package/{all/copy-overwrite/.claude/commands/tasks/load.md → plugins/lisa-cdk/commands/tasks-load.md} +1 -1
- package/{all/copy-overwrite/.claude/commands/tasks/sync.md → plugins/lisa-cdk/commands/tasks-sync.md} +1 -1
- package/{typescript/copy-overwrite/.claude → plugins/lisa-cdk}/hooks/install-pkgs.sh +3 -3
- package/plugins/lisa-cdk/rules/lisa.md +37 -0
- package/plugins/lisa-cdk/skills/jira-add-journey/SKILL.md +120 -0
- package/plugins/lisa-cdk/skills/jira-create/SKILL.md +95 -0
- package/plugins/lisa-cdk/skills/jira-evidence/SKILL.md +73 -0
- package/plugins/lisa-cdk/skills/jira-evidence/scripts/post-evidence.sh +163 -0
- package/plugins/lisa-cdk/skills/jira-fix/SKILL.md +16 -0
- package/plugins/lisa-cdk/skills/jira-implement/SKILL.md +18 -0
- package/plugins/lisa-cdk/skills/jira-journey/SKILL.md +125 -0
- package/plugins/lisa-cdk/skills/jira-journey/scripts/generate-templates.py +233 -0
- package/plugins/lisa-cdk/skills/jira-journey/scripts/parse-plan.py +368 -0
- package/plugins/lisa-cdk/skills/jira-verify/SKILL.md +48 -0
- package/plugins/lisa-expo/.claude-plugin/plugin.json +86 -0
- package/plugins/lisa-expo/agents/agent-architect.md +310 -0
- package/plugins/lisa-expo/agents/architecture-specialist.md +53 -0
- package/plugins/lisa-expo/agents/debug-specialist.md +204 -0
- package/plugins/lisa-expo/agents/git-history-analyzer.md +183 -0
- package/plugins/lisa-expo/agents/hooks-expert.md +74 -0
- package/plugins/lisa-expo/agents/implementer.md +54 -0
- package/plugins/lisa-expo/agents/learner.md +44 -0
- package/plugins/lisa-expo/agents/performance-specialist.md +95 -0
- package/plugins/lisa-expo/agents/product-specialist.md +72 -0
- package/plugins/lisa-expo/agents/quality-specialist.md +55 -0
- package/plugins/lisa-expo/agents/security-specialist.md +58 -0
- package/plugins/lisa-expo/agents/skill-evaluator.md +246 -0
- package/plugins/lisa-expo/agents/slash-command-architect.md +87 -0
- package/plugins/lisa-expo/agents/test-specialist.md +64 -0
- package/plugins/lisa-expo/agents/verification-specialist.md +189 -0
- package/plugins/lisa-expo/agents/web-search-researcher.md +112 -0
- package/plugins/lisa-expo/commands/git-commit-and-submit-pr.md +7 -0
- package/plugins/lisa-expo/commands/git-commit-submit-pr-and-verify.md +7 -0
- package/plugins/lisa-expo/commands/git-commit-submit-pr-deploy-and-verify.md +7 -0
- package/plugins/lisa-expo/commands/git-commit.md +7 -0
- package/plugins/lisa-expo/commands/git-prune.md +6 -0
- package/plugins/lisa-expo/commands/git-submit-pr.md +7 -0
- package/plugins/lisa-expo/commands/jira-add-journey.md +7 -0
- package/plugins/lisa-expo/commands/jira-create.md +7 -0
- package/plugins/lisa-expo/commands/jira-evidence.md +7 -0
- package/plugins/lisa-expo/commands/jira-fix.md +7 -0
- package/plugins/lisa-expo/commands/jira-implement.md +7 -0
- package/plugins/lisa-expo/commands/jira-journey.md +7 -0
- package/plugins/lisa-expo/commands/jira-sync.md +7 -0
- package/plugins/lisa-expo/commands/jira-verify.md +7 -0
- package/plugins/lisa-expo/commands/lisa-review-implementation.md +7 -0
- package/plugins/lisa-expo/commands/plan-add-test-coverage.md +7 -0
- package/plugins/lisa-expo/commands/plan-create.md +6 -0
- package/plugins/lisa-expo/commands/plan-execute.md +7 -0
- package/plugins/lisa-expo/commands/plan-fix-linter-error.md +7 -0
- package/plugins/lisa-expo/commands/plan-local-code-review.md +6 -0
- package/plugins/lisa-expo/commands/plan-lower-code-complexity.md +6 -0
- package/plugins/lisa-expo/commands/plan-reduce-max-lines-per-function.md +7 -0
- package/plugins/lisa-expo/commands/plan-reduce-max-lines.md +7 -0
- package/plugins/lisa-expo/commands/pull-request-review.md +7 -0
- package/plugins/lisa-expo/commands/security-zap-scan.md +6 -0
- package/plugins/lisa-expo/commands/sonarqube-check.md +6 -0
- package/plugins/lisa-expo/commands/sonarqube-fix.md +6 -0
- package/plugins/lisa-expo/commands/tasks-load.md +7 -0
- package/plugins/lisa-expo/commands/tasks-sync.md +7 -0
- package/plugins/lisa-expo/hooks/debug-hook.sh +47 -0
- package/plugins/lisa-expo/hooks/enforce-plan-rules.sh +15 -0
- package/plugins/lisa-expo/hooks/format-on-edit.sh +76 -0
- package/plugins/lisa-expo/hooks/install-pkgs.sh +64 -0
- package/plugins/lisa-expo/hooks/lint-on-edit.sh +81 -0
- package/plugins/lisa-expo/hooks/notify-ntfy.sh +183 -0
- package/plugins/lisa-expo/hooks/setup-jira-cli.sh +52 -0
- package/plugins/lisa-expo/hooks/sg-scan-on-edit.sh +68 -0
- package/plugins/lisa-expo/hooks/sync-tasks.sh +107 -0
- package/plugins/lisa-expo/hooks/ticket-sync-reminder.sh +23 -0
- package/plugins/lisa-expo/hooks/track-plan-sessions.sh +164 -0
- package/plugins/lisa-expo/hooks/verify-completion.sh +77 -0
- package/plugins/lisa-expo/rules/README.md +240 -0
- package/plugins/lisa-expo/rules/coding-philosophy.md +428 -0
- package/plugins/lisa-expo/rules/lisa.md +37 -0
- package/plugins/lisa-expo/rules/verfication.md +596 -0
- package/plugins/lisa-expo/skills/agent-design-best-practices/SKILL.md +219 -0
- package/plugins/lisa-expo/skills/git-commit/SKILL.md +48 -0
- package/plugins/lisa-expo/skills/git-commit-and-submit-pr/SKILL.md +8 -0
- package/plugins/lisa-expo/skills/git-commit-submit-pr-and-verify/SKILL.md +7 -0
- package/plugins/lisa-expo/skills/git-commit-submit-pr-deploy-and-verify/SKILL.md +7 -0
- package/plugins/lisa-expo/skills/git-prune/SKILL.md +35 -0
- package/plugins/lisa-expo/skills/git-submit-pr/SKILL.md +44 -0
- package/plugins/lisa-expo/skills/jira-add-journey/SKILL.md +126 -0
- package/plugins/lisa-expo/skills/jira-create/SKILL.md +101 -0
- package/plugins/lisa-expo/skills/jira-evidence/SKILL.md +78 -0
- package/plugins/lisa-expo/skills/jira-evidence/scripts/post-evidence.sh +163 -0
- package/plugins/lisa-expo/skills/jira-fix/SKILL.md +16 -0
- package/plugins/lisa-expo/skills/jira-implement/SKILL.md +18 -0
- package/plugins/lisa-expo/skills/jira-journey/SKILL.md +190 -0
- package/plugins/lisa-expo/skills/jira-journey/scripts/generate-templates.py +281 -0
- package/plugins/lisa-expo/skills/jira-journey/scripts/parse-plan.py +368 -0
- package/plugins/lisa-expo/skills/jira-sync/SKILL.md +63 -0
- package/plugins/lisa-expo/skills/jira-verify/SKILL.md +47 -0
- package/plugins/lisa-expo/skills/jsdoc-best-practices/SKILL.md +432 -0
- package/plugins/lisa-expo/skills/lisa-review-implementation/SKILL.md +209 -0
- package/plugins/lisa-expo/skills/plan-add-test-coverage/SKILL.md +44 -0
- package/plugins/lisa-expo/skills/plan-execute/SKILL.md +89 -0
- package/plugins/lisa-expo/skills/plan-fix-linter-error/SKILL.md +45 -0
- package/plugins/lisa-expo/skills/plan-local-code-review/SKILL.md +88 -0
- package/plugins/lisa-expo/skills/plan-lower-code-complexity/SKILL.md +44 -0
- package/plugins/lisa-expo/skills/plan-reduce-max-lines/SKILL.md +45 -0
- package/plugins/lisa-expo/skills/plan-reduce-max-lines-per-function/SKILL.md +46 -0
- package/plugins/lisa-expo/skills/pull-request-review/SKILL.md +68 -0
- package/plugins/lisa-expo/skills/skill-creator/LICENSE.txt +202 -0
- package/plugins/lisa-expo/skills/skill-creator/SKILL.md +210 -0
- package/plugins/lisa-expo/skills/skill-creator/scripts/init_skill.py +305 -0
- package/plugins/lisa-expo/skills/skill-creator/scripts/package_skill.py +112 -0
- package/plugins/lisa-expo/skills/skill-creator/scripts/quick_validate.py +67 -0
- package/plugins/lisa-expo/skills/sonarqube-check/SKILL.md +11 -0
- package/plugins/lisa-expo/skills/sonarqube-fix/SKILL.md +8 -0
- package/plugins/lisa-expo/skills/tasks-load/SKILL.md +88 -0
- package/plugins/lisa-expo/skills/tasks-sync/SKILL.md +108 -0
- package/plugins/lisa-nestjs/.claude-plugin/plugin.json +86 -0
- package/plugins/lisa-nestjs/agents/agent-architect.md +310 -0
- package/plugins/lisa-nestjs/agents/architecture-specialist.md +53 -0
- package/plugins/lisa-nestjs/agents/debug-specialist.md +204 -0
- package/plugins/lisa-nestjs/agents/git-history-analyzer.md +183 -0
- package/plugins/lisa-nestjs/agents/hooks-expert.md +74 -0
- package/plugins/lisa-nestjs/agents/implementer.md +54 -0
- package/plugins/lisa-nestjs/agents/learner.md +44 -0
- package/plugins/lisa-nestjs/agents/performance-specialist.md +95 -0
- package/plugins/lisa-nestjs/agents/product-specialist.md +72 -0
- package/plugins/lisa-nestjs/agents/quality-specialist.md +55 -0
- package/plugins/lisa-nestjs/agents/security-specialist.md +58 -0
- package/plugins/lisa-nestjs/agents/skill-evaluator.md +246 -0
- package/plugins/lisa-nestjs/agents/slash-command-architect.md +87 -0
- package/plugins/lisa-nestjs/agents/test-specialist.md +64 -0
- package/plugins/lisa-nestjs/agents/verification-specialist.md +189 -0
- package/plugins/lisa-nestjs/agents/web-search-researcher.md +112 -0
- package/plugins/lisa-nestjs/commands/git-commit-and-submit-pr.md +7 -0
- package/plugins/lisa-nestjs/commands/git-commit-submit-pr-and-verify.md +7 -0
- package/plugins/lisa-nestjs/commands/git-commit-submit-pr-deploy-and-verify.md +7 -0
- package/plugins/lisa-nestjs/commands/git-commit.md +7 -0
- package/plugins/lisa-nestjs/commands/git-prune.md +6 -0
- package/plugins/lisa-nestjs/commands/git-submit-pr.md +7 -0
- package/plugins/lisa-nestjs/commands/jira-add-journey.md +7 -0
- package/plugins/lisa-nestjs/commands/jira-create.md +7 -0
- package/plugins/lisa-nestjs/commands/jira-evidence.md +7 -0
- package/plugins/lisa-nestjs/commands/jira-fix.md +7 -0
- package/plugins/lisa-nestjs/commands/jira-implement.md +7 -0
- package/plugins/lisa-nestjs/commands/jira-journey.md +7 -0
- package/plugins/lisa-nestjs/commands/jira-sync.md +7 -0
- package/plugins/lisa-nestjs/commands/jira-verify.md +7 -0
- package/plugins/lisa-nestjs/commands/lisa-review-implementation.md +7 -0
- package/plugins/lisa-nestjs/commands/plan-add-test-coverage.md +7 -0
- package/plugins/lisa-nestjs/commands/plan-create.md +6 -0
- package/plugins/lisa-nestjs/commands/plan-execute.md +7 -0
- package/plugins/lisa-nestjs/commands/plan-fix-linter-error.md +7 -0
- package/plugins/lisa-nestjs/commands/plan-local-code-review.md +6 -0
- package/plugins/lisa-nestjs/commands/plan-lower-code-complexity.md +6 -0
- package/plugins/lisa-nestjs/commands/plan-reduce-max-lines-per-function.md +7 -0
- package/plugins/lisa-nestjs/commands/plan-reduce-max-lines.md +7 -0
- package/plugins/lisa-nestjs/commands/pull-request-review.md +7 -0
- package/plugins/lisa-nestjs/commands/security-zap-scan.md +6 -0
- package/plugins/lisa-nestjs/commands/sonarqube-check.md +6 -0
- package/plugins/lisa-nestjs/commands/sonarqube-fix.md +6 -0
- package/plugins/lisa-nestjs/commands/tasks-load.md +7 -0
- package/plugins/lisa-nestjs/commands/tasks-sync.md +7 -0
- package/plugins/lisa-nestjs/hooks/debug-hook.sh +47 -0
- package/plugins/lisa-nestjs/hooks/enforce-plan-rules.sh +15 -0
- package/plugins/lisa-nestjs/hooks/format-on-edit.sh +76 -0
- package/plugins/lisa-nestjs/hooks/install-pkgs.sh +64 -0
- package/plugins/lisa-nestjs/hooks/lint-on-edit.sh +81 -0
- package/plugins/lisa-nestjs/hooks/notify-ntfy.sh +183 -0
- package/plugins/lisa-nestjs/hooks/setup-jira-cli.sh +52 -0
- package/plugins/lisa-nestjs/hooks/sg-scan-on-edit.sh +68 -0
- package/plugins/lisa-nestjs/hooks/sync-tasks.sh +107 -0
- package/plugins/lisa-nestjs/hooks/ticket-sync-reminder.sh +23 -0
- package/plugins/lisa-nestjs/hooks/track-plan-sessions.sh +164 -0
- package/plugins/lisa-nestjs/hooks/verify-completion.sh +77 -0
- package/plugins/lisa-nestjs/rules/README.md +240 -0
- package/plugins/lisa-nestjs/rules/coding-philosophy.md +428 -0
- package/plugins/lisa-nestjs/rules/lisa.md +37 -0
- package/plugins/lisa-nestjs/rules/verfication.md +596 -0
- package/plugins/lisa-nestjs/skills/agent-design-best-practices/SKILL.md +219 -0
- package/plugins/lisa-nestjs/skills/git-commit/SKILL.md +48 -0
- package/plugins/lisa-nestjs/skills/git-commit-and-submit-pr/SKILL.md +8 -0
- package/plugins/lisa-nestjs/skills/git-commit-submit-pr-and-verify/SKILL.md +7 -0
- package/plugins/lisa-nestjs/skills/git-commit-submit-pr-deploy-and-verify/SKILL.md +7 -0
- package/plugins/lisa-nestjs/skills/git-prune/SKILL.md +35 -0
- package/plugins/lisa-nestjs/skills/git-submit-pr/SKILL.md +44 -0
- package/plugins/lisa-nestjs/skills/jira-add-journey/SKILL.md +120 -0
- package/plugins/lisa-nestjs/skills/jira-create/SKILL.md +95 -0
- package/plugins/lisa-nestjs/skills/jira-evidence/SKILL.md +73 -0
- package/plugins/lisa-nestjs/skills/jira-evidence/scripts/post-evidence.sh +163 -0
- package/plugins/lisa-nestjs/skills/jira-fix/SKILL.md +16 -0
- package/plugins/lisa-nestjs/skills/jira-implement/SKILL.md +18 -0
- package/plugins/lisa-nestjs/skills/jira-journey/SKILL.md +125 -0
- package/plugins/lisa-nestjs/skills/jira-journey/scripts/generate-templates.py +233 -0
- package/plugins/lisa-nestjs/skills/jira-journey/scripts/parse-plan.py +368 -0
- package/plugins/lisa-nestjs/skills/jira-sync/SKILL.md +63 -0
- package/plugins/lisa-nestjs/skills/jira-verify/SKILL.md +48 -0
- package/plugins/lisa-nestjs/skills/jsdoc-best-practices/SKILL.md +432 -0
- package/plugins/lisa-nestjs/skills/lisa-review-implementation/SKILL.md +209 -0
- package/plugins/lisa-nestjs/skills/plan-add-test-coverage/SKILL.md +44 -0
- package/plugins/lisa-nestjs/skills/plan-execute/SKILL.md +89 -0
- package/plugins/lisa-nestjs/skills/plan-fix-linter-error/SKILL.md +45 -0
- package/plugins/lisa-nestjs/skills/plan-local-code-review/SKILL.md +88 -0
- package/plugins/lisa-nestjs/skills/plan-lower-code-complexity/SKILL.md +44 -0
- package/plugins/lisa-nestjs/skills/plan-reduce-max-lines/SKILL.md +45 -0
- package/plugins/lisa-nestjs/skills/plan-reduce-max-lines-per-function/SKILL.md +46 -0
- package/plugins/lisa-nestjs/skills/pull-request-review/SKILL.md +68 -0
- package/plugins/lisa-nestjs/skills/security-zap-scan/SKILL.md +33 -0
- package/plugins/lisa-nestjs/skills/skill-creator/LICENSE.txt +202 -0
- package/plugins/lisa-nestjs/skills/skill-creator/SKILL.md +210 -0
- package/plugins/lisa-nestjs/skills/skill-creator/scripts/init_skill.py +305 -0
- package/plugins/lisa-nestjs/skills/skill-creator/scripts/package_skill.py +112 -0
- package/plugins/lisa-nestjs/skills/skill-creator/scripts/quick_validate.py +67 -0
- package/plugins/lisa-nestjs/skills/sonarqube-check/SKILL.md +11 -0
- package/plugins/lisa-nestjs/skills/sonarqube-fix/SKILL.md +8 -0
- package/plugins/lisa-nestjs/skills/tasks-load/SKILL.md +88 -0
- package/plugins/lisa-nestjs/skills/tasks-sync/SKILL.md +108 -0
- package/plugins/lisa-rails/.claude-plugin/plugin.json +77 -0
- package/plugins/lisa-rails/agents/agent-architect.md +310 -0
- package/plugins/lisa-rails/agents/architecture-specialist.md +53 -0
- package/plugins/lisa-rails/agents/debug-specialist.md +204 -0
- package/plugins/lisa-rails/agents/git-history-analyzer.md +183 -0
- package/plugins/lisa-rails/agents/hooks-expert.md +74 -0
- package/plugins/lisa-rails/agents/implementer.md +54 -0
- package/plugins/lisa-rails/agents/learner.md +44 -0
- package/plugins/lisa-rails/agents/performance-specialist.md +95 -0
- package/plugins/lisa-rails/agents/product-specialist.md +72 -0
- package/plugins/lisa-rails/agents/quality-specialist.md +55 -0
- package/plugins/lisa-rails/agents/security-specialist.md +58 -0
- package/plugins/lisa-rails/agents/skill-evaluator.md +246 -0
- package/plugins/lisa-rails/agents/slash-command-architect.md +87 -0
- package/plugins/lisa-rails/agents/test-specialist.md +64 -0
- package/plugins/lisa-rails/agents/verification-specialist.md +189 -0
- package/plugins/lisa-rails/agents/web-search-researcher.md +112 -0
- package/plugins/lisa-rails/commands/git-commit-and-submit-pr.md +7 -0
- package/plugins/lisa-rails/commands/git-commit-submit-pr-and-verify.md +7 -0
- package/plugins/lisa-rails/commands/git-commit-submit-pr-deploy-and-verify.md +7 -0
- package/plugins/lisa-rails/commands/git-commit.md +7 -0
- package/plugins/lisa-rails/commands/git-prune.md +6 -0
- package/plugins/lisa-rails/commands/git-submit-pr.md +7 -0
- package/plugins/lisa-rails/commands/jira-add-journey.md +7 -0
- package/plugins/lisa-rails/commands/jira-create.md +7 -0
- package/plugins/lisa-rails/commands/jira-evidence.md +7 -0
- package/plugins/lisa-rails/commands/jira-fix.md +7 -0
- package/plugins/lisa-rails/commands/jira-implement.md +7 -0
- package/plugins/lisa-rails/commands/jira-journey.md +7 -0
- package/plugins/lisa-rails/commands/jira-sync.md +7 -0
- package/plugins/lisa-rails/commands/jira-verify.md +7 -0
- package/plugins/lisa-rails/commands/lisa-review-implementation.md +7 -0
- package/plugins/lisa-rails/commands/plan-add-test-coverage.md +7 -0
- package/plugins/lisa-rails/commands/plan-create.md +6 -0
- package/plugins/lisa-rails/commands/plan-execute.md +7 -0
- package/plugins/lisa-rails/commands/plan-fix-linter-error.md +7 -0
- package/plugins/lisa-rails/commands/plan-local-code-review.md +6 -0
- package/plugins/lisa-rails/commands/plan-lower-code-complexity.md +6 -0
- package/plugins/lisa-rails/commands/plan-reduce-max-lines-per-function.md +7 -0
- package/plugins/lisa-rails/commands/plan-reduce-max-lines.md +7 -0
- package/plugins/lisa-rails/commands/pull-request-review.md +7 -0
- package/plugins/lisa-rails/commands/security-zap-scan.md +6 -0
- package/plugins/lisa-rails/commands/sonarqube-check.md +6 -0
- package/plugins/lisa-rails/commands/sonarqube-fix.md +6 -0
- package/plugins/lisa-rails/commands/tasks-load.md +7 -0
- package/plugins/lisa-rails/commands/tasks-sync.md +7 -0
- package/plugins/lisa-rails/hooks/debug-hook.sh +47 -0
- package/plugins/lisa-rails/hooks/enforce-plan-rules.sh +15 -0
- package/plugins/lisa-rails/hooks/format-on-edit.sh +76 -0
- package/plugins/lisa-rails/hooks/install-pkgs.sh +64 -0
- package/plugins/lisa-rails/hooks/lint-on-edit.sh +81 -0
- package/plugins/lisa-rails/hooks/notify-ntfy.sh +183 -0
- package/plugins/lisa-rails/hooks/setup-jira-cli.sh +52 -0
- package/plugins/lisa-rails/hooks/sg-scan-on-edit.sh +68 -0
- package/plugins/lisa-rails/hooks/sync-tasks.sh +107 -0
- package/plugins/lisa-rails/hooks/ticket-sync-reminder.sh +23 -0
- package/plugins/lisa-rails/hooks/track-plan-sessions.sh +164 -0
- package/plugins/lisa-rails/hooks/verify-completion.sh +77 -0
- package/plugins/lisa-rails/rules/README.md +240 -0
- package/plugins/lisa-rails/rules/coding-philosophy.md +428 -0
- package/plugins/lisa-rails/rules/lisa.md +37 -0
- package/plugins/lisa-rails/rules/rails-conventions.md +176 -0
- package/plugins/lisa-rails/rules/verfication.md +596 -0
- package/plugins/lisa-rails/skills/agent-design-best-practices/SKILL.md +219 -0
- package/plugins/lisa-rails/skills/git-commit/SKILL.md +48 -0
- package/plugins/lisa-rails/skills/git-commit-and-submit-pr/SKILL.md +8 -0
- package/plugins/lisa-rails/skills/git-commit-submit-pr-and-verify/SKILL.md +7 -0
- package/plugins/lisa-rails/skills/git-commit-submit-pr-deploy-and-verify/SKILL.md +7 -0
- package/plugins/lisa-rails/skills/git-prune/SKILL.md +35 -0
- package/plugins/lisa-rails/skills/git-submit-pr/SKILL.md +44 -0
- package/plugins/lisa-rails/skills/jira-add-journey/SKILL.md +65 -0
- package/plugins/lisa-rails/skills/jira-evidence/SKILL.md +70 -0
- package/plugins/lisa-rails/skills/jira-evidence/scripts/post-evidence.sh +163 -0
- package/plugins/lisa-rails/skills/jira-fix/SKILL.md +16 -0
- package/plugins/lisa-rails/skills/jira-implement/SKILL.md +18 -0
- package/plugins/lisa-rails/skills/jira-journey/SKILL.md +64 -0
- package/plugins/lisa-rails/skills/jira-journey/scripts/generate-templates.py +233 -0
- package/plugins/lisa-rails/skills/jira-journey/scripts/parse-plan.py +368 -0
- package/plugins/lisa-rails/skills/jira-sync/SKILL.md +63 -0
- package/plugins/lisa-rails/skills/jsdoc-best-practices/SKILL.md +432 -0
- package/plugins/lisa-rails/skills/lisa-review-implementation/SKILL.md +209 -0
- package/plugins/lisa-rails/skills/plan-execute/SKILL.md +89 -0
- package/plugins/lisa-rails/skills/plan-local-code-review/SKILL.md +88 -0
- package/plugins/lisa-rails/skills/pull-request-review/SKILL.md +68 -0
- package/plugins/lisa-rails/skills/security-zap-scan/SKILL.md +33 -0
- package/plugins/lisa-rails/skills/skill-creator/LICENSE.txt +202 -0
- package/plugins/lisa-rails/skills/skill-creator/SKILL.md +210 -0
- package/plugins/lisa-rails/skills/skill-creator/scripts/init_skill.py +305 -0
- package/plugins/lisa-rails/skills/skill-creator/scripts/package_skill.py +112 -0
- package/plugins/lisa-rails/skills/skill-creator/scripts/quick_validate.py +67 -0
- package/plugins/lisa-rails/skills/sonarqube-check/SKILL.md +11 -0
- package/plugins/lisa-rails/skills/sonarqube-fix/SKILL.md +8 -0
- package/plugins/lisa-rails/skills/tasks-load/SKILL.md +88 -0
- package/plugins/lisa-rails/skills/tasks-sync/SKILL.md +108 -0
- package/plugins/lisa-typescript/.claude-plugin/plugin.json +86 -0
- package/plugins/lisa-typescript/agents/agent-architect.md +310 -0
- package/plugins/lisa-typescript/agents/architecture-specialist.md +53 -0
- package/plugins/lisa-typescript/agents/debug-specialist.md +204 -0
- package/plugins/lisa-typescript/agents/git-history-analyzer.md +183 -0
- package/plugins/lisa-typescript/agents/hooks-expert.md +74 -0
- package/plugins/lisa-typescript/agents/implementer.md +54 -0
- package/plugins/lisa-typescript/agents/learner.md +44 -0
- package/plugins/lisa-typescript/agents/performance-specialist.md +95 -0
- package/plugins/lisa-typescript/agents/product-specialist.md +72 -0
- package/plugins/lisa-typescript/agents/quality-specialist.md +55 -0
- package/plugins/lisa-typescript/agents/security-specialist.md +58 -0
- package/plugins/lisa-typescript/agents/skill-evaluator.md +246 -0
- package/plugins/lisa-typescript/agents/slash-command-architect.md +87 -0
- package/plugins/lisa-typescript/agents/test-specialist.md +64 -0
- package/plugins/lisa-typescript/agents/verification-specialist.md +189 -0
- package/plugins/lisa-typescript/agents/web-search-researcher.md +112 -0
- package/plugins/lisa-typescript/commands/git-commit-and-submit-pr.md +7 -0
- package/plugins/lisa-typescript/commands/git-commit-submit-pr-and-verify.md +7 -0
- package/plugins/lisa-typescript/commands/git-commit-submit-pr-deploy-and-verify.md +7 -0
- package/plugins/lisa-typescript/commands/git-commit.md +7 -0
- package/plugins/lisa-typescript/commands/git-prune.md +6 -0
- package/plugins/lisa-typescript/commands/git-submit-pr.md +7 -0
- package/plugins/lisa-typescript/commands/jira-add-journey.md +7 -0
- package/plugins/lisa-typescript/commands/jira-create.md +7 -0
- package/plugins/lisa-typescript/commands/jira-evidence.md +7 -0
- package/plugins/lisa-typescript/commands/jira-fix.md +7 -0
- package/plugins/lisa-typescript/commands/jira-implement.md +7 -0
- package/plugins/lisa-typescript/commands/jira-journey.md +7 -0
- package/plugins/lisa-typescript/commands/jira-sync.md +7 -0
- package/plugins/lisa-typescript/commands/jira-verify.md +7 -0
- package/plugins/lisa-typescript/commands/lisa-review-implementation.md +7 -0
- package/plugins/lisa-typescript/commands/plan-add-test-coverage.md +7 -0
- package/plugins/lisa-typescript/commands/plan-create.md +6 -0
- package/plugins/lisa-typescript/commands/plan-execute.md +7 -0
- package/plugins/lisa-typescript/commands/plan-fix-linter-error.md +7 -0
- package/plugins/lisa-typescript/commands/plan-local-code-review.md +6 -0
- package/plugins/lisa-typescript/commands/plan-lower-code-complexity.md +6 -0
- package/plugins/lisa-typescript/commands/plan-reduce-max-lines-per-function.md +7 -0
- package/plugins/lisa-typescript/commands/plan-reduce-max-lines.md +7 -0
- package/plugins/lisa-typescript/commands/pull-request-review.md +7 -0
- package/plugins/lisa-typescript/commands/security-zap-scan.md +6 -0
- package/plugins/lisa-typescript/commands/sonarqube-check.md +6 -0
- package/plugins/lisa-typescript/commands/sonarqube-fix.md +6 -0
- package/plugins/lisa-typescript/commands/tasks-load.md +7 -0
- package/plugins/lisa-typescript/commands/tasks-sync.md +7 -0
- package/plugins/lisa-typescript/hooks/debug-hook.sh +47 -0
- package/plugins/lisa-typescript/hooks/enforce-plan-rules.sh +15 -0
- package/plugins/lisa-typescript/hooks/format-on-edit.sh +76 -0
- package/plugins/lisa-typescript/hooks/install-pkgs.sh +64 -0
- package/plugins/lisa-typescript/hooks/lint-on-edit.sh +81 -0
- package/plugins/lisa-typescript/hooks/notify-ntfy.sh +183 -0
- package/plugins/lisa-typescript/hooks/setup-jira-cli.sh +52 -0
- package/plugins/lisa-typescript/hooks/sg-scan-on-edit.sh +68 -0
- package/plugins/lisa-typescript/hooks/sync-tasks.sh +107 -0
- package/plugins/lisa-typescript/hooks/ticket-sync-reminder.sh +23 -0
- package/plugins/lisa-typescript/hooks/track-plan-sessions.sh +164 -0
- package/plugins/lisa-typescript/hooks/verify-completion.sh +77 -0
- package/plugins/lisa-typescript/rules/README.md +240 -0
- package/plugins/lisa-typescript/rules/coding-philosophy.md +428 -0
- package/plugins/lisa-typescript/rules/lisa.md +37 -0
- package/plugins/lisa-typescript/rules/verfication.md +596 -0
- package/plugins/lisa-typescript/skills/agent-design-best-practices/SKILL.md +219 -0
- package/plugins/lisa-typescript/skills/git-commit/SKILL.md +48 -0
- package/plugins/lisa-typescript/skills/git-commit-and-submit-pr/SKILL.md +8 -0
- package/plugins/lisa-typescript/skills/git-commit-submit-pr-and-verify/SKILL.md +7 -0
- package/plugins/lisa-typescript/skills/git-commit-submit-pr-deploy-and-verify/SKILL.md +7 -0
- package/plugins/lisa-typescript/skills/git-prune/SKILL.md +35 -0
- package/plugins/lisa-typescript/skills/git-submit-pr/SKILL.md +44 -0
- package/plugins/lisa-typescript/skills/jira-add-journey/SKILL.md +120 -0
- package/plugins/lisa-typescript/skills/jira-create/SKILL.md +95 -0
- package/plugins/lisa-typescript/skills/jira-evidence/SKILL.md +73 -0
- package/plugins/lisa-typescript/skills/jira-evidence/scripts/post-evidence.sh +163 -0
- package/plugins/lisa-typescript/skills/jira-fix/SKILL.md +16 -0
- package/plugins/lisa-typescript/skills/jira-implement/SKILL.md +18 -0
- package/plugins/lisa-typescript/skills/jira-journey/SKILL.md +125 -0
- package/plugins/lisa-typescript/skills/jira-journey/scripts/generate-templates.py +233 -0
- package/plugins/lisa-typescript/skills/jira-journey/scripts/parse-plan.py +368 -0
- package/plugins/lisa-typescript/skills/jira-sync/SKILL.md +63 -0
- package/plugins/lisa-typescript/skills/jira-verify/SKILL.md +48 -0
- package/plugins/lisa-typescript/skills/jsdoc-best-practices/SKILL.md +432 -0
- package/plugins/lisa-typescript/skills/lisa-review-implementation/SKILL.md +209 -0
- package/plugins/lisa-typescript/skills/plan-add-test-coverage/SKILL.md +44 -0
- package/plugins/lisa-typescript/skills/plan-execute/SKILL.md +89 -0
- package/plugins/lisa-typescript/skills/plan-fix-linter-error/SKILL.md +45 -0
- package/plugins/lisa-typescript/skills/plan-local-code-review/SKILL.md +88 -0
- package/plugins/lisa-typescript/skills/plan-lower-code-complexity/SKILL.md +44 -0
- package/plugins/lisa-typescript/skills/plan-reduce-max-lines/SKILL.md +45 -0
- package/plugins/lisa-typescript/skills/plan-reduce-max-lines-per-function/SKILL.md +46 -0
- package/plugins/lisa-typescript/skills/pull-request-review/SKILL.md +68 -0
- package/plugins/lisa-typescript/skills/security-zap-scan/SKILL.md +33 -0
- package/plugins/lisa-typescript/skills/skill-creator/LICENSE.txt +202 -0
- package/plugins/lisa-typescript/skills/skill-creator/SKILL.md +210 -0
- package/plugins/lisa-typescript/skills/skill-creator/scripts/init_skill.py +305 -0
- package/plugins/lisa-typescript/skills/skill-creator/scripts/package_skill.py +112 -0
- package/plugins/lisa-typescript/skills/skill-creator/scripts/quick_validate.py +67 -0
- package/plugins/lisa-typescript/skills/sonarqube-check/SKILL.md +11 -0
- package/plugins/lisa-typescript/skills/sonarqube-fix/SKILL.md +8 -0
- package/plugins/lisa-typescript/skills/tasks-load/SKILL.md +88 -0
- package/plugins/lisa-typescript/skills/tasks-sync/SKILL.md +108 -0
- package/plugins/src/base/agents/agent-architect.md +310 -0
- package/plugins/src/base/agents/architecture-specialist.md +53 -0
- package/plugins/src/base/agents/debug-specialist.md +204 -0
- package/plugins/src/base/agents/git-history-analyzer.md +183 -0
- package/plugins/src/base/agents/hooks-expert.md +74 -0
- package/plugins/src/base/agents/implementer.md +54 -0
- package/plugins/src/base/agents/learner.md +44 -0
- package/plugins/src/base/agents/performance-specialist.md +95 -0
- package/plugins/src/base/agents/product-specialist.md +72 -0
- package/plugins/src/base/agents/quality-specialist.md +55 -0
- package/plugins/src/base/agents/security-specialist.md +58 -0
- package/plugins/src/base/agents/skill-evaluator.md +246 -0
- package/plugins/src/base/agents/slash-command-architect.md +87 -0
- package/plugins/src/base/agents/test-specialist.md +64 -0
- package/plugins/src/base/agents/verification-specialist.md +189 -0
- package/plugins/src/base/agents/web-search-researcher.md +112 -0
- package/plugins/src/base/commands/git-commit-and-submit-pr.md +7 -0
- package/plugins/src/base/commands/git-commit-submit-pr-and-verify.md +7 -0
- package/plugins/src/base/commands/git-commit-submit-pr-deploy-and-verify.md +7 -0
- package/plugins/src/base/commands/git-commit.md +7 -0
- package/plugins/src/base/commands/git-prune.md +6 -0
- package/plugins/src/base/commands/git-submit-pr.md +7 -0
- package/plugins/src/base/commands/jira-add-journey.md +7 -0
- package/plugins/src/base/commands/jira-create.md +7 -0
- package/plugins/src/base/commands/jira-evidence.md +7 -0
- package/plugins/src/base/commands/jira-fix.md +7 -0
- package/plugins/src/base/commands/jira-implement.md +7 -0
- package/plugins/src/base/commands/jira-journey.md +7 -0
- package/plugins/src/base/commands/jira-sync.md +7 -0
- package/plugins/src/base/commands/jira-verify.md +7 -0
- package/plugins/src/base/commands/lisa-review-implementation.md +7 -0
- package/plugins/src/base/commands/plan-add-test-coverage.md +7 -0
- package/plugins/src/base/commands/plan-create.md +6 -0
- package/plugins/src/base/commands/plan-execute.md +7 -0
- package/plugins/src/base/commands/plan-fix-linter-error.md +7 -0
- package/plugins/src/base/commands/plan-local-code-review.md +6 -0
- package/plugins/src/base/commands/plan-lower-code-complexity.md +6 -0
- package/plugins/src/base/commands/plan-reduce-max-lines-per-function.md +7 -0
- package/plugins/src/base/commands/plan-reduce-max-lines.md +7 -0
- package/plugins/src/base/commands/pull-request-review.md +7 -0
- package/plugins/src/base/commands/security-zap-scan.md +6 -0
- package/plugins/src/base/commands/sonarqube-check.md +6 -0
- package/plugins/src/base/commands/sonarqube-fix.md +6 -0
- package/plugins/src/base/commands/tasks-load.md +7 -0
- package/plugins/src/base/commands/tasks-sync.md +7 -0
- package/plugins/src/base/hooks/debug-hook.sh +47 -0
- package/plugins/src/base/hooks/enforce-plan-rules.sh +15 -0
- package/plugins/src/base/hooks/format-on-edit.sh +76 -0
- package/plugins/src/base/hooks/install-pkgs.sh +64 -0
- package/plugins/src/base/hooks/lint-on-edit.sh +81 -0
- package/plugins/src/base/hooks/notify-ntfy.sh +183 -0
- package/plugins/src/base/hooks/setup-jira-cli.sh +52 -0
- package/plugins/src/base/hooks/sg-scan-on-edit.sh +68 -0
- package/plugins/src/base/hooks/sync-tasks.sh +107 -0
- package/plugins/src/base/hooks/ticket-sync-reminder.sh +23 -0
- package/plugins/src/base/hooks/track-plan-sessions.sh +164 -0
- package/plugins/src/base/hooks/verify-completion.sh +77 -0
- package/plugins/src/base/rules/README.md +240 -0
- package/plugins/src/base/rules/coding-philosophy.md +428 -0
- package/plugins/src/base/rules/lisa.md +37 -0
- package/plugins/src/base/rules/verfication.md +596 -0
- package/plugins/src/base/skills/agent-design-best-practices/SKILL.md +219 -0
- package/plugins/src/base/skills/git-commit/SKILL.md +48 -0
- package/plugins/src/base/skills/git-commit-and-submit-pr/SKILL.md +8 -0
- package/plugins/src/base/skills/git-commit-submit-pr-and-verify/SKILL.md +7 -0
- package/plugins/src/base/skills/git-commit-submit-pr-deploy-and-verify/SKILL.md +7 -0
- package/plugins/src/base/skills/git-prune/SKILL.md +35 -0
- package/plugins/src/base/skills/git-submit-pr/SKILL.md +44 -0
- package/plugins/src/base/skills/jira-add-journey/SKILL.md +120 -0
- package/plugins/src/base/skills/jira-create/SKILL.md +95 -0
- package/plugins/src/base/skills/jira-evidence/SKILL.md +73 -0
- package/plugins/src/base/skills/jira-evidence/scripts/post-evidence.sh +163 -0
- package/plugins/src/base/skills/jira-fix/SKILL.md +16 -0
- package/plugins/src/base/skills/jira-implement/SKILL.md +18 -0
- package/plugins/src/base/skills/jira-journey/SKILL.md +125 -0
- package/plugins/src/base/skills/jira-journey/scripts/generate-templates.py +233 -0
- package/plugins/src/base/skills/jira-journey/scripts/parse-plan.py +368 -0
- package/plugins/src/base/skills/jira-sync/SKILL.md +63 -0
- package/plugins/src/base/skills/jira-verify/SKILL.md +48 -0
- package/plugins/src/base/skills/jsdoc-best-practices/SKILL.md +432 -0
- package/plugins/src/base/skills/lisa-review-implementation/SKILL.md +209 -0
- package/plugins/src/base/skills/plan-add-test-coverage/SKILL.md +44 -0
- package/plugins/src/base/skills/plan-execute/SKILL.md +89 -0
- package/plugins/src/base/skills/plan-fix-linter-error/SKILL.md +45 -0
- package/plugins/src/base/skills/plan-local-code-review/SKILL.md +88 -0
- package/plugins/src/base/skills/plan-lower-code-complexity/SKILL.md +44 -0
- package/plugins/src/base/skills/plan-reduce-max-lines/SKILL.md +45 -0
- package/plugins/src/base/skills/plan-reduce-max-lines-per-function/SKILL.md +46 -0
- package/plugins/src/base/skills/pull-request-review/SKILL.md +68 -0
- package/plugins/src/base/skills/security-zap-scan/SKILL.md +33 -0
- package/plugins/src/base/skills/skill-creator/LICENSE.txt +202 -0
- package/plugins/src/base/skills/skill-creator/SKILL.md +210 -0
- package/plugins/src/base/skills/skill-creator/scripts/init_skill.py +305 -0
- package/plugins/src/base/skills/skill-creator/scripts/package_skill.py +112 -0
- package/plugins/src/base/skills/skill-creator/scripts/quick_validate.py +67 -0
- package/plugins/src/base/skills/sonarqube-check/SKILL.md +11 -0
- package/plugins/src/base/skills/sonarqube-fix/SKILL.md +8 -0
- package/plugins/src/base/skills/tasks-load/SKILL.md +88 -0
- package/plugins/src/base/skills/tasks-sync/SKILL.md +108 -0
- package/plugins/src/cdk/.claude-plugin/plugin.json +86 -0
- package/plugins/src/expo/.claude-plugin/plugin.json +86 -0
- package/plugins/src/expo/agents/ops-specialist.md +124 -0
- package/plugins/src/expo/rules/expo-verification.md +261 -0
- package/plugins/src/expo/skills/apollo-client/SKILL.md +238 -0
- package/plugins/src/expo/skills/apollo-client/references/mutation-patterns.md +360 -0
- package/plugins/src/expo/skills/atomic-design-gluestack/SKILL.md +360 -0
- package/plugins/src/expo/skills/atomic-design-gluestack/references/atomic-levels.md +417 -0
- package/plugins/src/expo/skills/atomic-design-gluestack/references/folder-structure.md +257 -0
- package/plugins/src/expo/skills/atomic-design-gluestack/references/gluestack-mapping.md +233 -0
- package/plugins/src/expo/skills/atomic-design-gluestack/scripts/validate_atomic_structure.py +329 -0
- package/plugins/src/expo/skills/container-view-pattern/SKILL.md +299 -0
- package/plugins/src/expo/skills/container-view-pattern/references/examples.md +749 -0
- package/plugins/src/expo/skills/container-view-pattern/references/patterns.md +318 -0
- package/plugins/src/expo/skills/container-view-pattern/scripts/create_component.py +200 -0
- package/plugins/src/expo/skills/container-view-pattern/scripts/validate_component.py +209 -0
- package/plugins/src/expo/skills/cross-platform-compatibility/SKILL.md +268 -0
- package/plugins/src/expo/skills/cross-platform-compatibility/references/common-issues.md +619 -0
- package/plugins/src/expo/skills/cross-platform-compatibility/references/file-extensions.md +340 -0
- package/plugins/src/expo/skills/cross-platform-compatibility/references/platform-api.md +276 -0
- package/plugins/src/expo/skills/cross-platform-compatibility/scripts/validate_cross_platform.py +416 -0
- package/plugins/src/expo/skills/directory-structure/SKILL.md +202 -0
- package/plugins/src/expo/skills/directory-structure/scripts/validate_structure.py +445 -0
- package/plugins/src/expo/skills/expo-env-config/SKILL.md +309 -0
- package/plugins/src/expo/skills/expo-env-config/references/validation-patterns.md +417 -0
- package/plugins/src/expo/skills/expo-router-best-practices/SKILL.md +431 -0
- package/plugins/src/expo/skills/expo-router-best-practices/references/official-docs.md +290 -0
- package/plugins/src/expo/skills/expo-router-best-practices/scripts/generate-route.py +171 -0
- package/plugins/src/expo/skills/gluestack-nativewind/SKILL.md +411 -0
- package/plugins/src/expo/skills/gluestack-nativewind/references/color-tokens.md +343 -0
- package/plugins/src/expo/skills/gluestack-nativewind/references/component-mapping.md +307 -0
- package/plugins/src/expo/skills/gluestack-nativewind/references/spacing-scale.md +300 -0
- package/plugins/src/expo/skills/gluestack-nativewind/scripts/validate_styling.py +315 -0
- package/plugins/src/expo/skills/jira-add-journey/SKILL.md +126 -0
- package/plugins/src/expo/skills/jira-create/SKILL.md +101 -0
- package/plugins/src/expo/skills/jira-evidence/SKILL.md +78 -0
- package/plugins/src/expo/skills/jira-evidence/scripts/post-evidence.sh +163 -0
- package/plugins/src/expo/skills/jira-journey/SKILL.md +190 -0
- package/plugins/src/expo/skills/jira-journey/scripts/generate-templates.py +281 -0
- package/plugins/src/expo/skills/jira-journey/scripts/parse-plan.py +368 -0
- package/plugins/src/expo/skills/jira-verify/SKILL.md +47 -0
- package/plugins/src/expo/skills/local-state/SKILL.md +362 -0
- package/plugins/src/expo/skills/local-state/references/async-storage.md +505 -0
- package/plugins/src/expo/skills/local-state/references/persistence-patterns.md +711 -0
- package/plugins/src/expo/skills/local-state/references/reactive-variables.md +446 -0
- package/plugins/src/expo/skills/ops-browser-uat/SKILL.md +124 -0
- package/plugins/src/expo/skills/ops-check-logs/SKILL.md +211 -0
- package/plugins/src/expo/skills/ops-db-ops/SKILL.md +119 -0
- package/plugins/src/expo/skills/ops-deploy/SKILL.md +119 -0
- package/plugins/src/expo/skills/ops-monitor-errors/SKILL.md +99 -0
- package/plugins/src/expo/skills/ops-performance/SKILL.md +165 -0
- package/plugins/src/expo/skills/ops-run-local/SKILL.md +166 -0
- package/plugins/src/expo/skills/ops-verify-health/SKILL.md +101 -0
- package/plugins/src/expo/skills/owasp-zap/SKILL.md +56 -0
- package/plugins/src/expo/skills/playwright-selectors/SKILL.md +223 -0
- package/plugins/src/expo/skills/testing-library/SKILL.md +314 -0
- package/plugins/src/expo/skills/testing-library/references/async-patterns.md +420 -0
- package/plugins/src/expo/skills/testing-library/references/expo-router-testing.md +556 -0
- package/plugins/src/expo/skills/testing-library/references/mocking-patterns.md +590 -0
- package/plugins/src/expo/skills/testing-library/references/query-priority.md +291 -0
- package/plugins/src/nestjs/.claude-plugin/plugin.json +86 -0
- package/plugins/src/nestjs/skills/nestjs-graphql/SKILL.md +176 -0
- package/plugins/src/nestjs/skills/nestjs-graphql/references/advanced-features.md +527 -0
- package/plugins/src/nestjs/skills/nestjs-graphql/references/project-patterns.md +483 -0
- package/plugins/src/nestjs/skills/nestjs-graphql/references/quick-start.md +257 -0
- package/plugins/src/nestjs/skills/nestjs-graphql/references/resolvers-mutations.md +413 -0
- package/plugins/src/nestjs/skills/nestjs-graphql/references/types-scalars.md +513 -0
- package/plugins/src/nestjs/skills/nestjs-rules/SKILL.md +536 -0
- package/plugins/src/nestjs/skills/typeorm-patterns/SKILL.md +275 -0
- package/plugins/src/nestjs/skills/typeorm-patterns/references/configuration-patterns.md +487 -0
- package/plugins/src/nestjs/skills/typeorm-patterns/references/entity-patterns.md +450 -0
- package/plugins/src/nestjs/skills/typeorm-patterns/references/observability-patterns.md +536 -0
- package/plugins/src/rails/.claude-plugin/plugin.json +77 -0
- package/plugins/src/rails/rules/rails-conventions.md +176 -0
- package/plugins/src/rails/skills/action-controller-best-practices/SKILL.md +374 -0
- package/plugins/src/rails/skills/action-view-best-practices/SKILL.md +335 -0
- package/plugins/src/rails/skills/active-record-model-best-practices/SKILL.md +166 -0
- package/plugins/src/rails/skills/jira-add-journey/SKILL.md +65 -0
- package/plugins/src/rails/skills/jira-create/SKILL.md +41 -0
- package/plugins/src/rails/skills/jira-evidence/SKILL.md +70 -0
- package/plugins/src/rails/skills/jira-evidence/scripts/post-evidence.sh +163 -0
- package/plugins/src/rails/skills/jira-journey/SKILL.md +64 -0
- package/plugins/src/rails/skills/jira-verify/SKILL.md +29 -0
- package/plugins/src/rails/skills/plan-add-test-coverage/SKILL.md +45 -0
- package/plugins/src/rails/skills/plan-fix-linter-error/SKILL.md +45 -0
- package/plugins/src/rails/skills/plan-lower-code-complexity/SKILL.md +48 -0
- package/plugins/src/rails/skills/plan-reduce-max-lines/SKILL.md +46 -0
- package/plugins/src/rails/skills/plan-reduce-max-lines-per-function/SKILL.md +46 -0
- package/plugins/src/typescript/.claude-plugin/plugin.json +86 -0
- package/rails/copy-overwrite/.claude/settings.json +80 -0
- package/rails/create-only/.github/workflows/ci.yml +1 -1
- package/rails/deletions.json +11 -1
- package/scripts/build-plugins.sh +22 -0
- package/scripts/cleanup-amplify-branches.sh +150 -0
- package/scripts/cleanup-github-branches.sh +202 -0
- package/scripts/github-status-check.sh +301 -0
- package/scripts/install-claude-plugins.sh +45 -0
- package/scripts/lisa-commit-and-pr-local.sh +204 -0
- package/scripts/lisa-update-local.sh +158 -0
- package/scripts/update-node-version.ts +197 -0
- package/tsconfig/build.json +8 -0
- package/tsconfig/cdk.json +16 -0
- package/tsconfig/eslint.json +12 -0
- package/tsconfig/expo.json +18 -0
- package/tsconfig/nestjs.json +18 -0
- package/tsconfig/spec.json +7 -0
- package/{typescript/copy-overwrite/tsconfig.typescript.json → tsconfig/typescript.json} +1 -1
- package/typescript/copy-overwrite/eslint.config.ts +6 -20
- package/typescript/copy-overwrite/eslint.slow.config.ts +4 -73
- package/typescript/copy-overwrite/jest.config.ts +8 -12
- package/typescript/copy-overwrite/tsconfig.json +1 -1
- package/typescript/create-only/.github/workflows/ci.yml +1 -1
- package/typescript/deletions.json +18 -1
- package/typescript/merge/.claude/settings.json +29 -0
- package/typescript/package-lisa/package.lisa.json +1 -35
- package/all/copy-overwrite/.claude/hooks/check-tired-boss.sh +0 -61
- package/all/copy-overwrite/.claude/rules/lisa.md +0 -53
- package/all/copy-overwrite/.claude/settings.json +0 -321
- package/all/copy-overwrite/.claude/skills/skill-creator/scripts/__pycache__/quick_validate.cpython-312.pyc +0 -0
- package/all/copy-overwrite/CLAUDE.md +0 -59
- package/all/copy-overwrite/HUMAN.md +0 -309
- package/eslint-plugin-code-organization/README.md +0 -149
- package/eslint-plugin-code-organization/__tests__/enforce-statement-order.test.js +0 -473
- package/eslint-plugin-code-organization/index.js +0 -28
- package/eslint-plugin-code-organization/package.json +0 -10
- package/eslint-plugin-code-organization/rules/enforce-statement-order.js +0 -162
- package/expo/copy-overwrite/eslint-plugin-component-structure/README.md +0 -234
- package/expo/copy-overwrite/eslint-plugin-component-structure/__tests__/plugin-index.test.js +0 -89
- package/expo/copy-overwrite/eslint-plugin-component-structure/__tests__/require-memo-in-view.test.js +0 -201
- package/expo/copy-overwrite/eslint-plugin-component-structure/__tests__/single-component-per-file.test.js +0 -294
- package/expo/copy-overwrite/eslint-plugin-component-structure/index.js +0 -37
- package/expo/copy-overwrite/eslint-plugin-component-structure/package.json +0 -10
- package/expo/copy-overwrite/eslint-plugin-component-structure/rules/enforce-component-structure.js +0 -235
- package/expo/copy-overwrite/eslint-plugin-component-structure/rules/no-return-in-view.js +0 -96
- package/expo/copy-overwrite/eslint-plugin-component-structure/rules/require-memo-in-view.js +0 -183
- package/expo/copy-overwrite/eslint-plugin-component-structure/rules/single-component-per-file.js +0 -243
- package/expo/copy-overwrite/eslint-plugin-ui-standards/README.md +0 -192
- package/expo/copy-overwrite/eslint-plugin-ui-standards/index.js +0 -31
- package/expo/copy-overwrite/eslint-plugin-ui-standards/package.json +0 -10
- package/expo/copy-overwrite/eslint-plugin-ui-standards/rules/no-classname-outside-ui.js +0 -56
- package/expo/copy-overwrite/eslint-plugin-ui-standards/rules/no-direct-rn-imports.js +0 -60
- package/rails/copy-overwrite/CLAUDE.md +0 -56
- package/typescript/copy-overwrite/.claude/settings.json +0 -320
- package/typescript/copy-overwrite/eslint-plugin-code-organization/README.md +0 -149
- package/typescript/copy-overwrite/eslint-plugin-code-organization/__tests__/enforce-statement-order.test.js +0 -473
- package/typescript/copy-overwrite/eslint-plugin-code-organization/index.js +0 -28
- package/typescript/copy-overwrite/eslint-plugin-code-organization/package.json +0 -10
- package/typescript/copy-overwrite/eslint-plugin-code-organization/rules/enforce-statement-order.js +0 -162
- package/typescript/copy-overwrite/eslint.base.ts +0 -429
- package/typescript/copy-overwrite/eslint.typescript.ts +0 -142
- package/typescript/copy-overwrite/jest.typescript.ts +0 -72
- /package/{all/copy-overwrite/.claude → plugins/lisa-cdk}/agents/agent-architect.md +0 -0
- /package/{all/copy-overwrite/.claude → plugins/lisa-cdk}/agents/architecture-specialist.md +0 -0
- /package/{all/copy-overwrite/.claude → plugins/lisa-cdk}/agents/debug-specialist.md +0 -0
- /package/{all/copy-overwrite/.claude → plugins/lisa-cdk}/agents/git-history-analyzer.md +0 -0
- /package/{all/copy-overwrite/.claude → plugins/lisa-cdk}/agents/hooks-expert.md +0 -0
- /package/{all/copy-overwrite/.claude → plugins/lisa-cdk}/agents/implementer.md +0 -0
- /package/{all/copy-overwrite/.claude → plugins/lisa-cdk}/agents/learner.md +0 -0
- /package/{all/copy-overwrite/.claude → plugins/lisa-cdk}/agents/performance-specialist.md +0 -0
- /package/{all/copy-overwrite/.claude → plugins/lisa-cdk}/agents/product-specialist.md +0 -0
- /package/{all/copy-overwrite/.claude → plugins/lisa-cdk}/agents/quality-specialist.md +0 -0
- /package/{all/copy-overwrite/.claude → plugins/lisa-cdk}/agents/security-specialist.md +0 -0
- /package/{all/copy-overwrite/.claude → plugins/lisa-cdk}/agents/skill-evaluator.md +0 -0
- /package/{all/copy-overwrite/.claude → plugins/lisa-cdk}/agents/slash-command-architect.md +0 -0
- /package/{all/copy-overwrite/.claude → plugins/lisa-cdk}/agents/test-specialist.md +0 -0
- /package/{all/copy-overwrite/.claude → plugins/lisa-cdk}/agents/verification-specialist.md +0 -0
- /package/{all/copy-overwrite/.claude → plugins/lisa-cdk}/agents/web-search-researcher.md +0 -0
- /package/{all/copy-overwrite/.claude → plugins/lisa-cdk}/hooks/debug-hook.sh +0 -0
- /package/{all/copy-overwrite/.claude → plugins/lisa-cdk}/hooks/enforce-plan-rules.sh +0 -0
- /package/{typescript/copy-overwrite/.claude → plugins/lisa-cdk}/hooks/format-on-edit.sh +0 -0
- /package/{typescript/copy-overwrite/.claude → plugins/lisa-cdk}/hooks/lint-on-edit.sh +0 -0
- /package/{all/copy-overwrite/.claude → plugins/lisa-cdk}/hooks/notify-ntfy.sh +0 -0
- /package/{all/copy-overwrite/.claude → plugins/lisa-cdk}/hooks/setup-jira-cli.sh +0 -0
- /package/{typescript/copy-overwrite/.claude → plugins/lisa-cdk}/hooks/sg-scan-on-edit.sh +0 -0
- /package/{all/copy-overwrite/.claude → plugins/lisa-cdk}/hooks/sync-tasks.sh +0 -0
- /package/{all/copy-overwrite/.claude → plugins/lisa-cdk}/hooks/ticket-sync-reminder.sh +0 -0
- /package/{all/copy-overwrite/.claude → plugins/lisa-cdk}/hooks/track-plan-sessions.sh +0 -0
- /package/{all/copy-overwrite/.claude → plugins/lisa-cdk}/hooks/verify-completion.sh +0 -0
- /package/{all/copy-overwrite/.claude → plugins/lisa-cdk/rules}/README.md +0 -0
- /package/{all/copy-overwrite/.claude → plugins/lisa-cdk}/rules/coding-philosophy.md +0 -0
- /package/{all/copy-overwrite/.claude → plugins/lisa-cdk}/rules/verfication.md +0 -0
- /package/{all/copy-overwrite/.claude → plugins/lisa-cdk}/skills/agent-design-best-practices/SKILL.md +0 -0
- /package/{all/copy-overwrite/.claude → plugins/lisa-cdk}/skills/git-commit/SKILL.md +0 -0
- /package/{all/copy-overwrite/.claude → plugins/lisa-cdk}/skills/git-commit-and-submit-pr/SKILL.md +0 -0
- /package/{all/copy-overwrite/.claude → plugins/lisa-cdk}/skills/git-commit-submit-pr-and-verify/SKILL.md +0 -0
- /package/{all/copy-overwrite/.claude → plugins/lisa-cdk}/skills/git-commit-submit-pr-deploy-and-verify/SKILL.md +0 -0
- /package/{all/copy-overwrite/.claude → plugins/lisa-cdk}/skills/git-prune/SKILL.md +0 -0
- /package/{all/copy-overwrite/.claude → plugins/lisa-cdk}/skills/git-submit-pr/SKILL.md +0 -0
- /package/{all/copy-overwrite/.claude → plugins/lisa-cdk}/skills/jira-sync/SKILL.md +0 -0
- /package/{typescript/copy-overwrite/.claude → plugins/lisa-cdk}/skills/jsdoc-best-practices/SKILL.md +0 -0
- /package/{all/copy-overwrite/.claude → plugins/lisa-cdk}/skills/lisa-review-implementation/SKILL.md +0 -0
- /package/{all/copy-overwrite/.claude → plugins/lisa-cdk}/skills/plan-add-test-coverage/SKILL.md +0 -0
- /package/{all/copy-overwrite/.claude → plugins/lisa-cdk}/skills/plan-execute/SKILL.md +0 -0
- /package/{all/copy-overwrite/.claude → plugins/lisa-cdk}/skills/plan-fix-linter-error/SKILL.md +0 -0
- /package/{all/copy-overwrite/.claude → plugins/lisa-cdk}/skills/plan-local-code-review/SKILL.md +0 -0
- /package/{all/copy-overwrite/.claude → plugins/lisa-cdk}/skills/plan-lower-code-complexity/SKILL.md +0 -0
- /package/{all/copy-overwrite/.claude → plugins/lisa-cdk}/skills/plan-reduce-max-lines/SKILL.md +0 -0
- /package/{all/copy-overwrite/.claude → plugins/lisa-cdk}/skills/plan-reduce-max-lines-per-function/SKILL.md +0 -0
- /package/{all/copy-overwrite/.claude → plugins/lisa-cdk}/skills/pull-request-review/SKILL.md +0 -0
- /package/{all/copy-overwrite/.claude → plugins/lisa-cdk}/skills/security-zap-scan/SKILL.md +0 -0
- /package/{all/copy-overwrite/.claude → plugins/lisa-cdk}/skills/skill-creator/LICENSE.txt +0 -0
- /package/{all/copy-overwrite/.claude → plugins/lisa-cdk}/skills/skill-creator/SKILL.md +0 -0
- /package/{all/copy-overwrite/.claude → plugins/lisa-cdk}/skills/skill-creator/scripts/init_skill.py +0 -0
- /package/{all/copy-overwrite/.claude → plugins/lisa-cdk}/skills/skill-creator/scripts/package_skill.py +0 -0
- /package/{all/copy-overwrite/.claude → plugins/lisa-cdk}/skills/skill-creator/scripts/quick_validate.py +0 -0
- /package/{all/copy-overwrite/.claude → plugins/lisa-cdk}/skills/sonarqube-check/SKILL.md +0 -0
- /package/{all/copy-overwrite/.claude → plugins/lisa-cdk}/skills/sonarqube-fix/SKILL.md +0 -0
- /package/{all/copy-overwrite/.claude → plugins/lisa-cdk}/skills/tasks-load/SKILL.md +0 -0
- /package/{all/copy-overwrite/.claude → plugins/lisa-cdk}/skills/tasks-sync/SKILL.md +0 -0
- /package/{expo/copy-overwrite/.claude → plugins/lisa-expo}/agents/ops-specialist.md +0 -0
- /package/{expo/copy-overwrite/.claude → plugins/lisa-expo}/rules/expo-verification.md +0 -0
- /package/{expo/copy-overwrite/.claude → plugins/lisa-expo}/skills/apollo-client/SKILL.md +0 -0
- /package/{expo/copy-overwrite/.claude → plugins/lisa-expo}/skills/apollo-client/references/mutation-patterns.md +0 -0
- /package/{expo/copy-overwrite/.claude → plugins/lisa-expo}/skills/atomic-design-gluestack/SKILL.md +0 -0
- /package/{expo/copy-overwrite/.claude → plugins/lisa-expo}/skills/atomic-design-gluestack/references/atomic-levels.md +0 -0
- /package/{expo/copy-overwrite/.claude → plugins/lisa-expo}/skills/atomic-design-gluestack/references/folder-structure.md +0 -0
- /package/{expo/copy-overwrite/.claude → plugins/lisa-expo}/skills/atomic-design-gluestack/references/gluestack-mapping.md +0 -0
- /package/{expo/copy-overwrite/.claude → plugins/lisa-expo}/skills/atomic-design-gluestack/scripts/validate_atomic_structure.py +0 -0
- /package/{expo/copy-overwrite/.claude → plugins/lisa-expo}/skills/container-view-pattern/SKILL.md +0 -0
- /package/{expo/copy-overwrite/.claude → plugins/lisa-expo}/skills/container-view-pattern/references/examples.md +0 -0
- /package/{expo/copy-overwrite/.claude → plugins/lisa-expo}/skills/container-view-pattern/references/patterns.md +0 -0
- /package/{expo/copy-overwrite/.claude → plugins/lisa-expo}/skills/container-view-pattern/scripts/create_component.py +0 -0
- /package/{expo/copy-overwrite/.claude → plugins/lisa-expo}/skills/container-view-pattern/scripts/validate_component.py +0 -0
- /package/{expo/copy-overwrite/.claude → plugins/lisa-expo}/skills/cross-platform-compatibility/SKILL.md +0 -0
- /package/{expo/copy-overwrite/.claude → plugins/lisa-expo}/skills/cross-platform-compatibility/references/common-issues.md +0 -0
- /package/{expo/copy-overwrite/.claude → plugins/lisa-expo}/skills/cross-platform-compatibility/references/file-extensions.md +0 -0
- /package/{expo/copy-overwrite/.claude → plugins/lisa-expo}/skills/cross-platform-compatibility/references/platform-api.md +0 -0
- /package/{expo/copy-overwrite/.claude → plugins/lisa-expo}/skills/cross-platform-compatibility/scripts/validate_cross_platform.py +0 -0
- /package/{expo/copy-overwrite/.claude → plugins/lisa-expo}/skills/directory-structure/SKILL.md +0 -0
- /package/{expo/copy-overwrite/.claude → plugins/lisa-expo}/skills/directory-structure/scripts/validate_structure.py +0 -0
- /package/{expo/copy-overwrite/.claude → plugins/lisa-expo}/skills/expo-env-config/SKILL.md +0 -0
- /package/{expo/copy-overwrite/.claude → plugins/lisa-expo}/skills/expo-env-config/references/validation-patterns.md +0 -0
- /package/{expo/copy-overwrite/.claude → plugins/lisa-expo}/skills/expo-router-best-practices/SKILL.md +0 -0
- /package/{expo/copy-overwrite/.claude → plugins/lisa-expo}/skills/expo-router-best-practices/references/official-docs.md +0 -0
- /package/{expo/copy-overwrite/.claude → plugins/lisa-expo}/skills/expo-router-best-practices/scripts/generate-route.py +0 -0
- /package/{expo/copy-overwrite/.claude → plugins/lisa-expo}/skills/gluestack-nativewind/SKILL.md +0 -0
- /package/{expo/copy-overwrite/.claude → plugins/lisa-expo}/skills/gluestack-nativewind/references/color-tokens.md +0 -0
- /package/{expo/copy-overwrite/.claude → plugins/lisa-expo}/skills/gluestack-nativewind/references/component-mapping.md +0 -0
- /package/{expo/copy-overwrite/.claude → plugins/lisa-expo}/skills/gluestack-nativewind/references/spacing-scale.md +0 -0
- /package/{expo/copy-overwrite/.claude → plugins/lisa-expo}/skills/gluestack-nativewind/scripts/validate_styling.py +0 -0
- /package/{expo/copy-overwrite/.claude → plugins/lisa-expo}/skills/local-state/SKILL.md +0 -0
- /package/{expo/copy-overwrite/.claude → plugins/lisa-expo}/skills/local-state/references/async-storage.md +0 -0
- /package/{expo/copy-overwrite/.claude → plugins/lisa-expo}/skills/local-state/references/persistence-patterns.md +0 -0
- /package/{expo/copy-overwrite/.claude → plugins/lisa-expo}/skills/local-state/references/reactive-variables.md +0 -0
- /package/{expo/copy-overwrite/.claude → plugins/lisa-expo}/skills/ops-browser-uat/SKILL.md +0 -0
- /package/{expo/copy-overwrite/.claude → plugins/lisa-expo}/skills/ops-check-logs/SKILL.md +0 -0
- /package/{expo/copy-overwrite/.claude → plugins/lisa-expo}/skills/ops-db-ops/SKILL.md +0 -0
- /package/{expo/copy-overwrite/.claude → plugins/lisa-expo}/skills/ops-deploy/SKILL.md +0 -0
- /package/{expo/copy-overwrite/.claude → plugins/lisa-expo}/skills/ops-monitor-errors/SKILL.md +0 -0
- /package/{expo/copy-overwrite/.claude → plugins/lisa-expo}/skills/ops-performance/SKILL.md +0 -0
- /package/{expo/copy-overwrite/.claude → plugins/lisa-expo}/skills/ops-run-local/SKILL.md +0 -0
- /package/{expo/copy-overwrite/.claude → plugins/lisa-expo}/skills/ops-verify-health/SKILL.md +0 -0
- /package/{expo/copy-overwrite/.claude → plugins/lisa-expo}/skills/owasp-zap/SKILL.md +0 -0
- /package/{expo/copy-overwrite/.claude → plugins/lisa-expo}/skills/playwright-selectors/SKILL.md +0 -0
- /package/{nestjs/copy-overwrite/.claude → plugins/lisa-expo}/skills/security-zap-scan/SKILL.md +0 -0
- /package/{expo/copy-overwrite/.claude → plugins/lisa-expo}/skills/testing-library/SKILL.md +0 -0
- /package/{expo/copy-overwrite/.claude → plugins/lisa-expo}/skills/testing-library/references/async-patterns.md +0 -0
- /package/{expo/copy-overwrite/.claude → plugins/lisa-expo}/skills/testing-library/references/expo-router-testing.md +0 -0
- /package/{expo/copy-overwrite/.claude → plugins/lisa-expo}/skills/testing-library/references/mocking-patterns.md +0 -0
- /package/{expo/copy-overwrite/.claude → plugins/lisa-expo}/skills/testing-library/references/query-priority.md +0 -0
- /package/{nestjs/copy-overwrite/.claude → plugins/lisa-nestjs}/skills/nestjs-graphql/SKILL.md +0 -0
- /package/{nestjs/copy-overwrite/.claude → plugins/lisa-nestjs}/skills/nestjs-graphql/references/advanced-features.md +0 -0
- /package/{nestjs/copy-overwrite/.claude → plugins/lisa-nestjs}/skills/nestjs-graphql/references/project-patterns.md +0 -0
- /package/{nestjs/copy-overwrite/.claude → plugins/lisa-nestjs}/skills/nestjs-graphql/references/quick-start.md +0 -0
- /package/{nestjs/copy-overwrite/.claude → plugins/lisa-nestjs}/skills/nestjs-graphql/references/resolvers-mutations.md +0 -0
- /package/{nestjs/copy-overwrite/.claude → plugins/lisa-nestjs}/skills/nestjs-graphql/references/types-scalars.md +0 -0
- /package/{nestjs/copy-overwrite/.claude → plugins/lisa-nestjs}/skills/nestjs-rules/SKILL.md +0 -0
- /package/{nestjs/copy-overwrite/.claude → plugins/lisa-nestjs}/skills/typeorm-patterns/SKILL.md +0 -0
- /package/{nestjs/copy-overwrite/.claude → plugins/lisa-nestjs}/skills/typeorm-patterns/references/configuration-patterns.md +0 -0
- /package/{nestjs/copy-overwrite/.claude → plugins/lisa-nestjs}/skills/typeorm-patterns/references/entity-patterns.md +0 -0
- /package/{nestjs/copy-overwrite/.claude → plugins/lisa-nestjs}/skills/typeorm-patterns/references/observability-patterns.md +0 -0
- /package/{rails/copy-overwrite/.claude → plugins/lisa-rails}/skills/action-controller-best-practices/SKILL.md +0 -0
- /package/{rails/copy-overwrite/.claude → plugins/lisa-rails}/skills/action-view-best-practices/SKILL.md +0 -0
- /package/{rails/copy-overwrite/.claude → plugins/lisa-rails}/skills/active-record-model-best-practices/SKILL.md +0 -0
- /package/{all/copy-overwrite/.claude → plugins/lisa-rails}/skills/jira-create/SKILL.md +0 -0
- /package/{all/copy-overwrite/.claude → plugins/lisa-rails}/skills/jira-verify/SKILL.md +0 -0
- /package/{rails/copy-overwrite/.claude → plugins/lisa-rails}/skills/plan-add-test-coverage/SKILL.md +0 -0
- /package/{rails/copy-overwrite/.claude → plugins/lisa-rails}/skills/plan-fix-linter-error/SKILL.md +0 -0
- /package/{rails/copy-overwrite/.claude → plugins/lisa-rails}/skills/plan-lower-code-complexity/SKILL.md +0 -0
- /package/{rails/copy-overwrite/.claude → plugins/lisa-rails}/skills/plan-reduce-max-lines/SKILL.md +0 -0
- /package/{rails/copy-overwrite/.claude → plugins/lisa-rails}/skills/plan-reduce-max-lines-per-function/SKILL.md +0 -0
- /package/{all/create-only/scripts → scripts}/setup-deploy-key.sh +0 -0
- /package/{typescript/copy-overwrite/tsconfig.base.json → tsconfig/base.json} +0 -0
|
@@ -4,4 +4,4 @@ allowed-tools: ["Skill"]
|
|
|
4
4
|
argument-hint: "<github-pr-link>"
|
|
5
5
|
---
|
|
6
6
|
|
|
7
|
-
Use the /pull-request-review skill to check for code review comments and implement them. $ARGUMENTS
|
|
7
|
+
Use the /lisa:pull-request-review skill to check for code review comments and implement them. $ARGUMENTS
|
|
@@ -3,4 +3,4 @@ description: "Uses SonarQube / SonarCloud to get the reason that last pull reque
|
|
|
3
3
|
allowed-tools: ["Skill"]
|
|
4
4
|
---
|
|
5
5
|
|
|
6
|
-
Use the /sonarqube-check skill to check why the last PR failed SonarQube quality gates.
|
|
6
|
+
Use the /lisa:sonarqube-check skill to check why the last PR failed SonarQube quality gates.
|
|
@@ -3,4 +3,4 @@ description: "Run SonarQube check, fix failures, and commit"
|
|
|
3
3
|
allowed-tools: ["Skill"]
|
|
4
4
|
---
|
|
5
5
|
|
|
6
|
-
Use the /sonarqube-fix skill to check, fix, and commit SonarQube quality gate failures.
|
|
6
|
+
Use the /lisa:sonarqube-fix skill to check, fix, and commit SonarQube quality gate failures.
|
|
@@ -2,9 +2,9 @@
|
|
|
2
2
|
# This file is managed by Lisa.
|
|
3
3
|
# Do not edit directly — changes will be overwritten on the next `lisa` run.
|
|
4
4
|
|
|
5
|
-
# Only run package installation
|
|
6
|
-
#
|
|
7
|
-
if [
|
|
5
|
+
# Only run package installation when node_modules are missing.
|
|
6
|
+
# This covers remote environments, new worktrees, fresh clones, and CI.
|
|
7
|
+
if [ -d "node_modules" ]; then
|
|
8
8
|
exit 0
|
|
9
9
|
fi
|
|
10
10
|
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
# Lisa-Managed Files
|
|
2
|
+
|
|
3
|
+
The following files are managed by Lisa and will be overwritten on every `lisa` run. Never edit them directly. Where a local override exists, edit that instead.
|
|
4
|
+
|
|
5
|
+
## Files with local overrides (edit the override, not the managed file)
|
|
6
|
+
|
|
7
|
+
| Managed File (do not edit) | Local Override (edit this instead) |
|
|
8
|
+
|---|---|
|
|
9
|
+
| `eslint.config.ts` | `eslint.config.local.ts` |
|
|
10
|
+
| `jest.config.ts` | `jest.config.local.ts` |
|
|
11
|
+
| `tsconfig.json` | `tsconfig.local.json` |
|
|
12
|
+
|
|
13
|
+
## Create-only files (edit freely, Lisa won't overwrite)
|
|
14
|
+
|
|
15
|
+
- `.claude/rules/PROJECT_RULES.md`
|
|
16
|
+
- `eslint.thresholds.json`
|
|
17
|
+
- `jest.thresholds.json`
|
|
18
|
+
|
|
19
|
+
## Deep-merged by Lisa (Lisa wins conflicts, but project can add its own keys)
|
|
20
|
+
|
|
21
|
+
- `.claude/settings.json`
|
|
22
|
+
|
|
23
|
+
## Plugin-managed content (agents, skills, hooks, commands, rules)
|
|
24
|
+
|
|
25
|
+
These resources are distributed via the stack Claude Code plugin (e.g., `typescript@lisa`). Rules — including this file — are injected into each prompt automatically. Do not add these files to your project directory.
|
|
26
|
+
|
|
27
|
+
## Copy-overwrite files (do not edit — full list)
|
|
28
|
+
|
|
29
|
+
- `.prettierrc.json`, `.prettierignore`, `.lintstagedrc.json`, `.versionrc`, `.nvmrc`
|
|
30
|
+
- `.yamllint`, `.gitleaksignore`, `.coderabbit.yml`, `commitlint.config.cjs`, `sgconfig.yml`, `knip.json`
|
|
31
|
+
- `.safety-net.json`, `audit.ignore.config.json`
|
|
32
|
+
- `eslint.base.ts`, `eslint.typescript.ts` (+ `expo`/`nestjs`/`cdk` variants), `eslint.slow.config.ts`
|
|
33
|
+
- `jest.base.ts`, `jest.typescript.ts` (+ variants)
|
|
34
|
+
- `tsconfig.base.json`, `tsconfig.typescript.json` (+ variants), `tsconfig.eslint.json`, `tsconfig.build.json`, `tsconfig.spec.json`
|
|
35
|
+
- `.github/workflows/quality.yml`, `release.yml`, `claude.yml`, and all other Claude/CI workflows
|
|
36
|
+
- `.github/dependabot.yml`, `.github/GITHUB_ACTIONS.md`
|
|
37
|
+
- `ast-grep/rules/`, `ast-grep/utils/`, `ast-grep/rule-tests/`
|
|
@@ -0,0 +1,120 @@
|
|
|
1
|
+
---
|
|
2
|
+
name: jira-add-journey
|
|
3
|
+
description: "Add a Validation Journey section to an existing JIRA ticket by analyzing the change type and generating appropriate verification steps with evidence markers."
|
|
4
|
+
---
|
|
5
|
+
|
|
6
|
+
# Add Validation Journey to Existing JIRA Ticket
|
|
7
|
+
|
|
8
|
+
Read an existing JIRA ticket, analyze the change type, and generate a Validation Journey section with appropriate verification steps based on the project's verification patterns.
|
|
9
|
+
|
|
10
|
+
## Arguments
|
|
11
|
+
|
|
12
|
+
`$ARGUMENTS`: `<TICKET_ID>`
|
|
13
|
+
|
|
14
|
+
- `TICKET_ID` (required): JIRA ticket key (e.g., `PROJ-123`)
|
|
15
|
+
|
|
16
|
+
## Prerequisites
|
|
17
|
+
|
|
18
|
+
- `JIRA_API_TOKEN` environment variable set
|
|
19
|
+
- `jira-cli` configured (`~/.config/.jira/.config.yml`)
|
|
20
|
+
|
|
21
|
+
## Workflow
|
|
22
|
+
|
|
23
|
+
### Step 1: Read the Ticket
|
|
24
|
+
|
|
25
|
+
Use the Atlassian MCP or jira-cli to read the full ticket details:
|
|
26
|
+
|
|
27
|
+
```bash
|
|
28
|
+
jira issue view <TICKET_ID>
|
|
29
|
+
```
|
|
30
|
+
|
|
31
|
+
Extract: title, description, acceptance criteria, components, labels, linked tickets.
|
|
32
|
+
|
|
33
|
+
### Step 2: Check for Existing Journey
|
|
34
|
+
|
|
35
|
+
Run the parser to see if a Validation Journey already exists:
|
|
36
|
+
|
|
37
|
+
```bash
|
|
38
|
+
python3 .claude/skills/jira-journey/scripts/parse-plan.py <TICKET_ID> 2>&1
|
|
39
|
+
```
|
|
40
|
+
|
|
41
|
+
If the parser succeeds and returns steps, the ticket already has a journey. Report this to the user and stop.
|
|
42
|
+
|
|
43
|
+
### Step 3: Analyze the Change Type
|
|
44
|
+
|
|
45
|
+
Examine the ticket description, acceptance criteria, and codebase to determine the change type:
|
|
46
|
+
|
|
47
|
+
1. **API/GraphQL changes** — New or modified endpoints, request/response schemas
|
|
48
|
+
2. **Database migration** — Schema changes, new tables/columns, indexes
|
|
49
|
+
3. **Background job/queue** — New job processors, queue consumers, event handlers
|
|
50
|
+
4. **Library/utility** — Exported functions, shared modules, npm package changes
|
|
51
|
+
5. **Security fix** — Auth, authorization, input validation, OWASP vulnerabilities
|
|
52
|
+
6. **Authentication/authorization** — Role-based access, session management, tokens
|
|
53
|
+
|
|
54
|
+
Use the Explore agent or read the codebase directly to understand which files are affected and what verification approach is appropriate.
|
|
55
|
+
|
|
56
|
+
### Step 4: Map Change Type to Verification Pattern
|
|
57
|
+
|
|
58
|
+
Based on the change type, generate verification steps using patterns from `verfication.md`:
|
|
59
|
+
|
|
60
|
+
| Change Type | Verification Approach |
|
|
61
|
+
|---|---|
|
|
62
|
+
| API/GraphQL | curl commands verifying endpoints, status codes, response schemas |
|
|
63
|
+
| Database migration | Migration execution + schema verification + rollback check |
|
|
64
|
+
| Background job/queue | Enqueue + process + state change verification |
|
|
65
|
+
| Library/utility | Test execution + build verification + export check |
|
|
66
|
+
| Security fix | Exploit reproduction pre-fix + exploit failure post-fix |
|
|
67
|
+
| Auth/authz | Multi-role verification with explicit status codes |
|
|
68
|
+
|
|
69
|
+
### Step 5: Draft the Validation Journey
|
|
70
|
+
|
|
71
|
+
Compose the journey with `[EVIDENCE: name]` markers at key verification points:
|
|
72
|
+
|
|
73
|
+
```text
|
|
74
|
+
h2. Validation Journey
|
|
75
|
+
|
|
76
|
+
h3. Prerequisites
|
|
77
|
+
- List required services, database, env vars
|
|
78
|
+
|
|
79
|
+
h3. Steps
|
|
80
|
+
1. Verify current state before changes
|
|
81
|
+
2. Apply the change
|
|
82
|
+
3. Verify expected new state [EVIDENCE: state-name]
|
|
83
|
+
4. Test error/edge cases [EVIDENCE: error-case]
|
|
84
|
+
5. Verify rollback if applicable [EVIDENCE: rollback]
|
|
85
|
+
|
|
86
|
+
h3. Assertions
|
|
87
|
+
- Describe what must be true after verification
|
|
88
|
+
```
|
|
89
|
+
|
|
90
|
+
### Guidelines for Drafting
|
|
91
|
+
|
|
92
|
+
1. **2-5 evidence markers** — Focus on proving the change works and handles errors
|
|
93
|
+
2. **Concrete, runnable steps** — "Run `curl -s localhost:3000/health | jq .status`" not "Check the endpoint"
|
|
94
|
+
3. **Include environment setup** — Database connection, running services, env vars
|
|
95
|
+
4. **Evidence names in kebab-case** — `api-response`, `schema-check`, `rate-limit-hit`
|
|
96
|
+
5. **Assertions are measurable** — "Returns 200 with `{status: ok}`" not "API works correctly"
|
|
97
|
+
6. **Cover happy path and error path** — At minimum, one success and one failure evidence marker
|
|
98
|
+
|
|
99
|
+
### Step 6: Present to User for Approval
|
|
100
|
+
|
|
101
|
+
Display the drafted Validation Journey to the user and ask for confirmation before appending it to the ticket.
|
|
102
|
+
|
|
103
|
+
### Step 7: Append to Ticket Description
|
|
104
|
+
|
|
105
|
+
After user approval, use the JIRA REST API to append the Validation Journey to the existing ticket description.
|
|
106
|
+
|
|
107
|
+
### Step 8: Verify
|
|
108
|
+
|
|
109
|
+
Run the parser again to confirm the journey was added correctly:
|
|
110
|
+
|
|
111
|
+
```bash
|
|
112
|
+
python3 .claude/skills/jira-journey/scripts/parse-plan.py <TICKET_ID>
|
|
113
|
+
```
|
|
114
|
+
|
|
115
|
+
## When to Use This Skill
|
|
116
|
+
|
|
117
|
+
- Ticket was created before the Validation Journey convention was established
|
|
118
|
+
- Ticket was created manually without following `jira-create` guidelines
|
|
119
|
+
- Ticket needs a journey added or updated based on implementation progress
|
|
120
|
+
- Before starting work on a ticket, to ensure verification steps are documented
|
|
@@ -0,0 +1,95 @@
|
|
|
1
|
+
---
|
|
2
|
+
name: jira-create
|
|
3
|
+
description: This skill should be used when creating JIRA epics, stories, and tasks from code files or descriptions. It analyzes the provided input, determines the appropriate issue hierarchy, and creates issues with comprehensive quality requirements including test-first development and documentation.
|
|
4
|
+
allowed-tools: ["Read", "Glob", "LS", "mcp__atlassian__createJiraIssue", "mcp__atlassian__getVisibleJiraProjects", "mcp__atlassian__getJiraProjectIssueTypesMetadata", "mcp__atlassian__getAccessibleAtlassianResources"]
|
|
5
|
+
---
|
|
6
|
+
|
|
7
|
+
# Create JIRA Issues from $ARGUMENTS
|
|
8
|
+
|
|
9
|
+
Analyze the provided file(s) and create a comprehensive JIRA hierarchy with all mandatory quality gates.
|
|
10
|
+
|
|
11
|
+
## Process
|
|
12
|
+
|
|
13
|
+
1. **Analyze**: Read $ARGUMENTS to understand scope
|
|
14
|
+
2. **Determine Structure**:
|
|
15
|
+
- Epic needed if: multiple features, major changes, >3 related files
|
|
16
|
+
- Direct tasks if: bug fix, single file, minor change
|
|
17
|
+
3. **Create Issues** with hierarchy:
|
|
18
|
+
```
|
|
19
|
+
Epic → User Story → Tasks (test, implement, document, cleanup)
|
|
20
|
+
```
|
|
21
|
+
|
|
22
|
+
## Mandatory for Every Code Issue
|
|
23
|
+
|
|
24
|
+
**Test-First**: Write tests before implementation
|
|
25
|
+
**Quality Gates**: All tests/checks must pass, no SonarCloud violations
|
|
26
|
+
**Documentation**: Check existing, update/create new, remove obsolete
|
|
27
|
+
**Cleanup**: Remove temporary code, scripts, dev configs
|
|
28
|
+
|
|
29
|
+
## Validation Journey
|
|
30
|
+
|
|
31
|
+
Tickets that change runtime behavior should include a `Validation Journey` section in the description. This section is consumed by the `jira-journey` skill to automate verification.
|
|
32
|
+
|
|
33
|
+
### When to Include
|
|
34
|
+
|
|
35
|
+
Include a Validation Journey when the ticket involves:
|
|
36
|
+
- API endpoint changes (new, modified, or removed routes)
|
|
37
|
+
- Database schema changes (migrations, new columns, index changes)
|
|
38
|
+
- Background job or queue processing changes
|
|
39
|
+
- Library or utility function changes that affect exports
|
|
40
|
+
- Security fixes (authentication, authorization, input validation)
|
|
41
|
+
- Performance-critical changes requiring measurement
|
|
42
|
+
|
|
43
|
+
### When to Skip
|
|
44
|
+
|
|
45
|
+
Skip the Validation Journey for:
|
|
46
|
+
- Documentation-only changes
|
|
47
|
+
- Config-only changes (env vars, CI/CD, feature flags with no code)
|
|
48
|
+
- Type-definition-only changes (interfaces, types, no runtime effect)
|
|
49
|
+
|
|
50
|
+
### How to Write
|
|
51
|
+
|
|
52
|
+
Design the journey based on the **change type**. The agent executing the journey determines how to verify each step using patterns from the project's `verfication.md`. Place `[EVIDENCE: name]` markers at key verification points.
|
|
53
|
+
|
|
54
|
+
Add this section to the ticket description:
|
|
55
|
+
|
|
56
|
+
```text
|
|
57
|
+
h2. Validation Journey
|
|
58
|
+
|
|
59
|
+
h3. Prerequisites
|
|
60
|
+
- Local dev server running
|
|
61
|
+
- Database accessible
|
|
62
|
+
- Required environment variables set
|
|
63
|
+
|
|
64
|
+
h3. Steps
|
|
65
|
+
1. Verify the current state before changes
|
|
66
|
+
2. Apply the change (run migration, deploy, etc.)
|
|
67
|
+
3. Verify the expected new state [EVIDENCE: state-after-change]
|
|
68
|
+
4. Test error/edge cases [EVIDENCE: error-handling]
|
|
69
|
+
5. Verify rollback or cleanup if applicable [EVIDENCE: rollback-check]
|
|
70
|
+
|
|
71
|
+
h3. Assertions
|
|
72
|
+
- Describe what must be true after verification
|
|
73
|
+
- Each assertion is verified against the captured evidence
|
|
74
|
+
```
|
|
75
|
+
|
|
76
|
+
### Guidelines
|
|
77
|
+
|
|
78
|
+
1. **Steps must be concrete and verifiable** — "Run `curl -s localhost:3000/health`" not "Check the API"
|
|
79
|
+
2. **Evidence markers at verification points** — Place `[EVIDENCE: name]` at states that prove the change works. Use descriptive kebab-case names (e.g., `api-response`, `schema-check`, `rate-limit-hit`)
|
|
80
|
+
3. **Include 2-5 evidence markers** — Enough to prove the change works across happy path and error cases
|
|
81
|
+
4. **Assertions are testable statements** — "Health check returns 200 with status ok" not "API works"
|
|
82
|
+
5. **Prerequisites include environment setup** — Database connection, env vars, running services
|
|
83
|
+
|
|
84
|
+
## Issue Requirements
|
|
85
|
+
|
|
86
|
+
Each issue must clearly communicate to:
|
|
87
|
+
|
|
88
|
+
- **Coding Assistants**: Implementation requirements
|
|
89
|
+
- **Developers**: Technical approach
|
|
90
|
+
- **Stakeholders**: Business value
|
|
91
|
+
|
|
92
|
+
Default project: from jira-cli config (override via arguments)
|
|
93
|
+
Exclude unless requested: migration plans, performance tests
|
|
94
|
+
|
|
95
|
+
Execute the analysis and create the complete JIRA structure with proper parent-child relationships.
|
|
@@ -0,0 +1,73 @@
|
|
|
1
|
+
---
|
|
2
|
+
name: jira-evidence
|
|
3
|
+
description: "Upload text evidence to GitHub pr-assets release, update PR description, post JIRA comment with code blocks, and move ticket to Code Review. Reusable by any skill that captures evidence and generates evidence/comment.txt + evidence/comment.md."
|
|
4
|
+
---
|
|
5
|
+
|
|
6
|
+
# JIRA Evidence Posting
|
|
7
|
+
|
|
8
|
+
Upload captured evidence and generated templates to GitHub PR description and JIRA ticket. This skill is the posting step — it assumes evidence files and comment templates already exist in the evidence directory.
|
|
9
|
+
|
|
10
|
+
## Arguments
|
|
11
|
+
|
|
12
|
+
`$ARGUMENTS`: `<TICKET_ID> <EVIDENCE_DIR> <PR_NUMBER>`
|
|
13
|
+
|
|
14
|
+
- `TICKET_ID` (required): JIRA ticket key (e.g., `PROJ-123`)
|
|
15
|
+
- `EVIDENCE_DIR` (required): Directory containing evidence and templates (e.g., `./evidence`)
|
|
16
|
+
- `PR_NUMBER` (required): GitHub PR number to update description
|
|
17
|
+
|
|
18
|
+
## Prerequisites
|
|
19
|
+
|
|
20
|
+
- `JIRA_API_TOKEN` environment variable set
|
|
21
|
+
- `jira-cli` configured (`~/.config/.jira/.config.yml`) — server and login are read from there
|
|
22
|
+
- `gh` CLI authenticated
|
|
23
|
+
- Evidence directory containing:
|
|
24
|
+
- `NN-name.txt` or `NN-name.json` text evidence files (e.g., `01-health-check.json`)
|
|
25
|
+
- `comment.txt` — JIRA wiki markup (generated by `generate-templates.py`)
|
|
26
|
+
- `comment.md` — GitHub markdown (generated by `generate-templates.py`)
|
|
27
|
+
|
|
28
|
+
## Usage
|
|
29
|
+
|
|
30
|
+
```bash
|
|
31
|
+
bash .claude/skills/jira-evidence/scripts/post-evidence.sh <TICKET_ID> <EVIDENCE_DIR> <PR_NUMBER>
|
|
32
|
+
```
|
|
33
|
+
|
|
34
|
+
### Example
|
|
35
|
+
|
|
36
|
+
```bash
|
|
37
|
+
bash .claude/skills/jira-evidence/scripts/post-evidence.sh PROJ-123 ./evidence 42
|
|
38
|
+
```
|
|
39
|
+
|
|
40
|
+
## What It Does
|
|
41
|
+
|
|
42
|
+
1. **Read JIRA config** — Reads `~/.config/.jira/.config.yml` to obtain `server` and `login` dynamically
|
|
43
|
+
2. **Upload to GitHub `pr-assets` release** — Uploads evidence files via `gh release upload --clobber`
|
|
44
|
+
3. **Update PR description** — Replaces or appends the `## Evidence` section in the PR body
|
|
45
|
+
4. **Post JIRA comment** — Posts `comment.txt` as a new comment (wiki markup with code blocks)
|
|
46
|
+
5. **Move ticket to Code Review** — Transitions the JIRA ticket
|
|
47
|
+
|
|
48
|
+
## Evidence Naming Convention
|
|
49
|
+
|
|
50
|
+
Text evidence files are named: `{NN}-{evidence-name}.txt` or `{NN}-{evidence-name}.json`
|
|
51
|
+
|
|
52
|
+
```text
|
|
53
|
+
evidence/
|
|
54
|
+
01-health-check.json uploaded
|
|
55
|
+
02-schema-after-migration.txt uploaded
|
|
56
|
+
03-rate-limit-response.txt uploaded
|
|
57
|
+
comment.txt used for JIRA comment
|
|
58
|
+
comment.md used for PR description
|
|
59
|
+
```
|
|
60
|
+
|
|
61
|
+
## Troubleshooting
|
|
62
|
+
|
|
63
|
+
### Evidence not appearing in GitHub PR
|
|
64
|
+
|
|
65
|
+
Evidence files must be in the `pr-assets` GitHub release. If the release does not exist:
|
|
66
|
+
|
|
67
|
+
```bash
|
|
68
|
+
gh release create pr-assets --title "PR Assets" --notes "CDN for PR evidence"
|
|
69
|
+
```
|
|
70
|
+
|
|
71
|
+
### JIRA API returns 403
|
|
72
|
+
|
|
73
|
+
Ensure `JIRA_API_TOKEN` is set and `login` in `~/.config/.jira/.config.yml` matches your Atlassian account email.
|
|
@@ -0,0 +1,163 @@
|
|
|
1
|
+
#!/usr/bin/env bash
|
|
2
|
+
# post-evidence.sh — Upload evidence and post to JIRA + GitHub PR description
|
|
3
|
+
#
|
|
4
|
+
# Usage:
|
|
5
|
+
# bash post-evidence.sh <TICKET_ID> <EVIDENCE_DIR> <PR_NUMBER>
|
|
6
|
+
#
|
|
7
|
+
# Prerequisites:
|
|
8
|
+
# - JIRA_API_TOKEN env var set
|
|
9
|
+
# - jira-cli configured (~/.config/.jira/.config.yml)
|
|
10
|
+
# - gh CLI authenticated
|
|
11
|
+
#
|
|
12
|
+
# What it does:
|
|
13
|
+
# 1. Uploads evidence files to the 'pr-assets' GitHub release
|
|
14
|
+
# 2. Updates the GitHub PR description with evidence/comment.md
|
|
15
|
+
# 3. Uploads image evidence as JIRA attachments
|
|
16
|
+
# 4. Posts/updates the JIRA comment with evidence/comment.txt
|
|
17
|
+
# 5. Moves the JIRA ticket to "Code Review"
|
|
18
|
+
|
|
19
|
+
set -euo pipefail
|
|
20
|
+
|
|
21
|
+
TICKET_ID="${1:?Usage: post-evidence.sh <TICKET_ID> <EVIDENCE_DIR> <PR_NUMBER>}"
|
|
22
|
+
EVIDENCE_DIR="${2:?Usage: post-evidence.sh <TICKET_ID> <EVIDENCE_DIR> <PR_NUMBER>}"
|
|
23
|
+
PR_NUMBER="${3:?Usage: post-evidence.sh <TICKET_ID> <EVIDENCE_DIR> <PR_NUMBER>}"
|
|
24
|
+
|
|
25
|
+
JIRA_CONFIG="${HOME}/.config/.jira/.config.yml"
|
|
26
|
+
if [[ ! -f "$JIRA_CONFIG" ]]; then
|
|
27
|
+
echo "ERROR: jira-cli config not found at $JIRA_CONFIG — run 'jira init' first" >&2
|
|
28
|
+
exit 1
|
|
29
|
+
fi
|
|
30
|
+
JIRA_SERVER=$(grep '^server:' "$JIRA_CONFIG" | awk '{print $2}')
|
|
31
|
+
JIRA_USER=$(grep '^login:' "$JIRA_CONFIG" | awk '{print $2}')
|
|
32
|
+
GH_REPO=$(gh repo view --json nameWithOwner --jq '.nameWithOwner')
|
|
33
|
+
RELEASE_TAG="pr-assets"
|
|
34
|
+
|
|
35
|
+
if [[ -z "${JIRA_API_TOKEN:-}" ]]; then
|
|
36
|
+
echo "ERROR: JIRA_API_TOKEN environment variable is not set" >&2
|
|
37
|
+
exit 1
|
|
38
|
+
fi
|
|
39
|
+
|
|
40
|
+
# Collect numbered evidence files (images + text)
|
|
41
|
+
SCREENSHOTS=()
|
|
42
|
+
while IFS= read -r -d '' f; do
|
|
43
|
+
SCREENSHOTS+=("$f")
|
|
44
|
+
done < <(find "$EVIDENCE_DIR" -maxdepth 1 -name '[0-9][0-9]-*.png' -print0 | sort -z)
|
|
45
|
+
|
|
46
|
+
TEXT_EVIDENCE=()
|
|
47
|
+
while IFS= read -r -d '' f; do
|
|
48
|
+
TEXT_EVIDENCE+=("$f")
|
|
49
|
+
done < <(find "$EVIDENCE_DIR" -maxdepth 1 \( -name '[0-9][0-9]-*.txt' -o -name '[0-9][0-9]-*.json' \) ! -name 'comment.txt' -print0 | sort -z)
|
|
50
|
+
|
|
51
|
+
ALL_EVIDENCE=("${SCREENSHOTS[@]}" "${TEXT_EVIDENCE[@]}")
|
|
52
|
+
|
|
53
|
+
if [[ ${#ALL_EVIDENCE[@]} -eq 0 ]]; then
|
|
54
|
+
echo "ERROR: No numbered evidence files found in $EVIDENCE_DIR (expected NN-*.png, NN-*.txt, or NN-*.json)" >&2
|
|
55
|
+
exit 1
|
|
56
|
+
fi
|
|
57
|
+
|
|
58
|
+
echo "Found ${#SCREENSHOTS[@]} screenshots and ${#TEXT_EVIDENCE[@]} text evidence files to upload"
|
|
59
|
+
|
|
60
|
+
# Compute JIRA auth early (used in steps 3 and 4)
|
|
61
|
+
JIRA_AUTH=$(echo -n "$JIRA_USER:$JIRA_API_TOKEN" | base64)
|
|
62
|
+
|
|
63
|
+
# ── Step 1: Upload to GitHub pr-assets release ──────────────────────────────
|
|
64
|
+
echo ""
|
|
65
|
+
echo "==> Uploading to GitHub release '$RELEASE_TAG'..."
|
|
66
|
+
|
|
67
|
+
for FILE in "${ALL_EVIDENCE[@]}"; do
|
|
68
|
+
FILENAME=$(basename "$FILE")
|
|
69
|
+
echo " ↑ $FILENAME"
|
|
70
|
+
gh release upload "$RELEASE_TAG" "$FILE" --repo "$GH_REPO" --clobber
|
|
71
|
+
done
|
|
72
|
+
|
|
73
|
+
echo " ✓ GitHub release assets uploaded"
|
|
74
|
+
|
|
75
|
+
# ── Step 2: Update GitHub PR description with evidence ──────────────────────
|
|
76
|
+
COMMENT_MD="$EVIDENCE_DIR/comment.md"
|
|
77
|
+
if [[ ! -f "$COMMENT_MD" ]]; then
|
|
78
|
+
echo "ERROR: $COMMENT_MD not found — run generate-templates.py first" >&2
|
|
79
|
+
exit 1
|
|
80
|
+
fi
|
|
81
|
+
|
|
82
|
+
echo ""
|
|
83
|
+
echo "==> Updating GitHub PR #$PR_NUMBER description..."
|
|
84
|
+
|
|
85
|
+
CURRENT_BODY=$(gh pr view "$PR_NUMBER" --json body --jq '.body')
|
|
86
|
+
|
|
87
|
+
# Replace or append the Evidence section
|
|
88
|
+
if echo "$CURRENT_BODY" | grep -q "^## Evidence"; then
|
|
89
|
+
# Replace from "## Evidence" to end of file
|
|
90
|
+
NEW_BODY=$(echo "$CURRENT_BODY" | sed '/^## Evidence/,$d')
|
|
91
|
+
EVIDENCE_SECTION=$(cat "$COMMENT_MD")
|
|
92
|
+
UPDATED_BODY="${NEW_BODY}
|
|
93
|
+
${EVIDENCE_SECTION}"
|
|
94
|
+
else
|
|
95
|
+
EVIDENCE_SECTION=$(cat "$COMMENT_MD")
|
|
96
|
+
UPDATED_BODY="${CURRENT_BODY}
|
|
97
|
+
|
|
98
|
+
${EVIDENCE_SECTION}"
|
|
99
|
+
fi
|
|
100
|
+
|
|
101
|
+
gh pr edit "$PR_NUMBER" --body "$UPDATED_BODY"
|
|
102
|
+
echo " ✓ PR description updated with evidence"
|
|
103
|
+
|
|
104
|
+
# ── Step 3: Upload image evidence as JIRA attachments ───────────────────────
|
|
105
|
+
if [[ ${#SCREENSHOTS[@]} -gt 0 ]]; then
|
|
106
|
+
echo ""
|
|
107
|
+
echo "==> Uploading image attachments to JIRA $TICKET_ID..."
|
|
108
|
+
|
|
109
|
+
for IMG in "${SCREENSHOTS[@]}"; do
|
|
110
|
+
FILENAME=$(basename "$IMG")
|
|
111
|
+
echo " ↑ $FILENAME"
|
|
112
|
+
RESP=$(curl -s -w "\nHTTP_CODE:%{http_code}" \
|
|
113
|
+
-X POST \
|
|
114
|
+
-H "Authorization: Basic $JIRA_AUTH" \
|
|
115
|
+
-H "X-Atlassian-Token: no-check" \
|
|
116
|
+
-F "file=@$IMG" \
|
|
117
|
+
"$JIRA_SERVER/rest/api/3/issue/$TICKET_ID/attachments")
|
|
118
|
+
HTTP_CODE=$(echo "$RESP" | grep "HTTP_CODE:" | cut -d: -f2)
|
|
119
|
+
if [[ "$HTTP_CODE" != "200" ]]; then
|
|
120
|
+
echo " WARNING: Failed to upload $FILENAME (HTTP $HTTP_CODE)" >&2
|
|
121
|
+
fi
|
|
122
|
+
done
|
|
123
|
+
|
|
124
|
+
echo " ✓ JIRA attachments uploaded"
|
|
125
|
+
fi
|
|
126
|
+
|
|
127
|
+
# ── Step 4: Post JIRA comment ────────────────────────────────────────────────
|
|
128
|
+
COMMENT_TXT="$EVIDENCE_DIR/comment.txt"
|
|
129
|
+
if [[ ! -f "$COMMENT_TXT" ]]; then
|
|
130
|
+
echo "ERROR: $COMMENT_TXT not found — run generate-templates.py first" >&2
|
|
131
|
+
exit 1
|
|
132
|
+
fi
|
|
133
|
+
|
|
134
|
+
echo ""
|
|
135
|
+
echo "==> Posting JIRA comment on $TICKET_ID..."
|
|
136
|
+
|
|
137
|
+
COMMENT_BODY=$(cat "$COMMENT_TXT")
|
|
138
|
+
COMMENT_JSON=$(python3 -c "import sys, json; print(json.dumps(sys.stdin.read()))" <<< "$COMMENT_BODY")
|
|
139
|
+
|
|
140
|
+
RESP=$(curl -s -w "\nHTTP_CODE:%{http_code}" \
|
|
141
|
+
-X POST \
|
|
142
|
+
-H "Authorization: Basic $JIRA_AUTH" \
|
|
143
|
+
-H "Content-Type: application/json" \
|
|
144
|
+
"$JIRA_SERVER/rest/api/2/issue/$TICKET_ID/comment" \
|
|
145
|
+
-d "{\"body\": $COMMENT_JSON}")
|
|
146
|
+
HTTP_CODE=$(echo "$RESP" | grep "HTTP_CODE:" | cut -d: -f2)
|
|
147
|
+
|
|
148
|
+
if [[ "$HTTP_CODE" == "201" ]]; then
|
|
149
|
+
echo " ✓ JIRA comment posted"
|
|
150
|
+
else
|
|
151
|
+
echo " WARNING: JIRA comment returned HTTP $HTTP_CODE" >&2
|
|
152
|
+
echo "$RESP" | grep -v "HTTP_CODE:" | head -3
|
|
153
|
+
fi
|
|
154
|
+
|
|
155
|
+
# ── Step 5: Move ticket to Code Review ──────────────────────────────────────
|
|
156
|
+
echo ""
|
|
157
|
+
echo "==> Moving $TICKET_ID to Code Review..."
|
|
158
|
+
jira issue move "$TICKET_ID" "Code Review" 2>&1 && echo " ✓ Ticket moved to Code Review" || echo " WARNING: Could not move ticket" >&2
|
|
159
|
+
|
|
160
|
+
echo ""
|
|
161
|
+
echo "==> Done!"
|
|
162
|
+
echo " JIRA: $JIRA_SERVER/browse/$TICKET_ID"
|
|
163
|
+
echo " GitHub: https://github.com/$GH_REPO/pull/$PR_NUMBER"
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
---
|
|
2
|
+
name: jira-fix
|
|
3
|
+
description: This skill should be used when fixing a bug ticket in JIRA
|
|
4
|
+
---
|
|
5
|
+
|
|
6
|
+
1. Use the JIRA/Atlassian MCP or CLI to fully read this issue, including comments and attachments: $ARGUMENTS
|
|
7
|
+
2. Extract sign-in information if available from the ticket (e.g., test credentials, OTP codes)
|
|
8
|
+
3. Use the project's verification method to attempt to reproduce the bug:
|
|
9
|
+
- For UI projects: Use Playwright MCP browser tools to record a replication
|
|
10
|
+
- For API projects: Use curl or test commands to reproduce the error
|
|
11
|
+
- For library projects: Write a minimal reproduction test
|
|
12
|
+
4. If you cannot reproduce the issue, upload the evidence to the JIRA ticket explaining that you can't replicate it and skip the remaining steps
|
|
13
|
+
5. If there have already been attempts to fix this bug, understand the previous attempts by looking for pull requests and git commits related to it
|
|
14
|
+
6. Fix the bug
|
|
15
|
+
7. Verify the fix using the same verification method used in step 3
|
|
16
|
+
8. Upload the evidence to the JIRA ticket and explain the fix
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
---
|
|
2
|
+
name: jira-implement
|
|
3
|
+
description: This skill should be used when implementing the requirements in a JIRA ticket.
|
|
4
|
+
---
|
|
5
|
+
|
|
6
|
+
Use either the Atlassian MCP or CLI to examine the contents of the JIRA ticket: $ARGUMENTS
|
|
7
|
+
|
|
8
|
+
If neither is available, stop and report that you cannot access the ticket.
|
|
9
|
+
|
|
10
|
+
Read all the details in the ticket, including any URLs and attachments.
|
|
11
|
+
|
|
12
|
+
Make a plan to fulfill the requirements of the ticket.
|
|
13
|
+
|
|
14
|
+
Important: If this involves UI changes, use Playwright MCP browser tools to access the app and get a better understanding of what needs to be done. Create a verification task using browser tools to confirm the implementation.
|
|
15
|
+
|
|
16
|
+
Important: If this involves API or backend changes, use curl or test commands to understand current behavior. Create a verification task to confirm the implementation.
|
|
17
|
+
|
|
18
|
+
If you don't know how to access the app or service, clarify when making the plan.
|