claude-code-orchestrator-kit 1.4.0 → 1.4.15

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.
Files changed (219) hide show
  1. package/.claude/agents/business/workers/lead-research-assistant.md +199 -0
  2. package/.claude/agents/database/workers/database-architect.md +3 -3
  3. package/.claude/agents/database/workers/supabase-auditor.md +7 -7
  4. package/.claude/agents/development/workers/code-reviewer.md +17 -2
  5. package/.claude/agents/frontend/workers/nextjs-ui-designer.md +30 -0
  6. package/.claude/agents/health/workers/bug-fixer.md +31 -2
  7. package/.claude/agents/health/workers/bug-hunter.md +0 -1
  8. package/.claude/agents/health/workers/dead-code-hunter.md +167 -75
  9. package/.claude/agents/health/workers/dead-code-remover.md +217 -66
  10. package/.claude/agents/health/workers/dependency-auditor.md +83 -24
  11. package/.claude/agents/health/workers/dependency-updater.md +0 -1
  12. package/.claude/agents/health/workers/security-scanner.md +0 -1
  13. package/.claude/agents/infrastructure/workers/deployment-engineer.md +446 -0
  14. package/.claude/agents/infrastructure/workers/infrastructure-specialist.md +2 -2
  15. package/.claude/agents/meta/workers/meta-agent-v3.md +22 -0
  16. package/.claude/agents/testing/workers/integration-tester.md +1 -1
  17. package/.claude/agents/testing/workers/test-writer.md +16 -0
  18. package/.claude/commands/health-bugs.md +14 -281
  19. package/.claude/commands/health-cleanup.md +14 -281
  20. package/.claude/commands/health-deps.md +14 -281
  21. package/.claude/commands/health-metrics.md +51 -709
  22. package/.claude/commands/health-reuse.md +14 -311
  23. package/.claude/commands/health-security.md +14 -281
  24. package/.claude/commands/push.md +17 -3
  25. package/.claude/commands/speckit.implement.md +0 -11
  26. package/.claude/commands/speckit.taskstoissues.md +95 -5
  27. package/.claude/commands/worktree.md +150 -0
  28. package/.claude/scripts/gates/check-bundle-size.sh +0 -0
  29. package/.claude/scripts/gates/check-coverage.sh +0 -0
  30. package/.claude/scripts/gates/check-security.sh +0 -0
  31. package/.claude/scripts/release.sh +469 -94
  32. package/.claude/skills/algorithmic-art/LICENSE.txt +202 -0
  33. package/.claude/skills/algorithmic-art/SKILL.md +405 -0
  34. package/.claude/skills/algorithmic-art/templates/generator_template.js +223 -0
  35. package/.claude/skills/algorithmic-art/templates/viewer.html +599 -0
  36. package/.claude/skills/artifacts-builder/LICENSE.txt +202 -0
  37. package/.claude/skills/artifacts-builder/SKILL.md +74 -0
  38. package/.claude/skills/artifacts-builder/scripts/bundle-artifact.sh +54 -0
  39. package/.claude/skills/artifacts-builder/scripts/init-artifact.sh +322 -0
  40. package/.claude/skills/artifacts-builder/scripts/shadcn-components.tar.gz +0 -0
  41. package/.claude/skills/bug-health-inline/SKILL.md +221 -0
  42. package/.claude/skills/bug-health-inline/references/worker-prompts.md +182 -0
  43. package/.claude/skills/canvas-design/LICENSE.txt +202 -0
  44. package/.claude/skills/canvas-design/SKILL.md +130 -0
  45. package/.claude/skills/canvas-design/canvas-fonts/ArsenalSC-OFL.txt +93 -0
  46. package/.claude/skills/canvas-design/canvas-fonts/ArsenalSC-Regular.ttf +0 -0
  47. package/.claude/skills/canvas-design/canvas-fonts/BigShoulders-Bold.ttf +0 -0
  48. package/.claude/skills/canvas-design/canvas-fonts/BigShoulders-OFL.txt +93 -0
  49. package/.claude/skills/canvas-design/canvas-fonts/BigShoulders-Regular.ttf +0 -0
  50. package/.claude/skills/canvas-design/canvas-fonts/Boldonse-OFL.txt +93 -0
  51. package/.claude/skills/canvas-design/canvas-fonts/Boldonse-Regular.ttf +0 -0
  52. package/.claude/skills/canvas-design/canvas-fonts/BricolageGrotesque-Bold.ttf +0 -0
  53. package/.claude/skills/canvas-design/canvas-fonts/BricolageGrotesque-OFL.txt +93 -0
  54. package/.claude/skills/canvas-design/canvas-fonts/BricolageGrotesque-Regular.ttf +0 -0
  55. package/.claude/skills/canvas-design/canvas-fonts/CrimsonPro-Bold.ttf +0 -0
  56. package/.claude/skills/canvas-design/canvas-fonts/CrimsonPro-Italic.ttf +0 -0
  57. package/.claude/skills/canvas-design/canvas-fonts/CrimsonPro-OFL.txt +93 -0
  58. package/.claude/skills/canvas-design/canvas-fonts/CrimsonPro-Regular.ttf +0 -0
  59. package/.claude/skills/canvas-design/canvas-fonts/DMMono-OFL.txt +93 -0
  60. package/.claude/skills/canvas-design/canvas-fonts/DMMono-Regular.ttf +0 -0
  61. package/.claude/skills/canvas-design/canvas-fonts/EricaOne-OFL.txt +94 -0
  62. package/.claude/skills/canvas-design/canvas-fonts/EricaOne-Regular.ttf +0 -0
  63. package/.claude/skills/canvas-design/canvas-fonts/GeistMono-Bold.ttf +0 -0
  64. package/.claude/skills/canvas-design/canvas-fonts/GeistMono-OFL.txt +93 -0
  65. package/.claude/skills/canvas-design/canvas-fonts/GeistMono-Regular.ttf +0 -0
  66. package/.claude/skills/canvas-design/canvas-fonts/Gloock-OFL.txt +93 -0
  67. package/.claude/skills/canvas-design/canvas-fonts/Gloock-Regular.ttf +0 -0
  68. package/.claude/skills/canvas-design/canvas-fonts/IBMPlexMono-Bold.ttf +0 -0
  69. package/.claude/skills/canvas-design/canvas-fonts/IBMPlexMono-OFL.txt +93 -0
  70. package/.claude/skills/canvas-design/canvas-fonts/IBMPlexMono-Regular.ttf +0 -0
  71. package/.claude/skills/canvas-design/canvas-fonts/IBMPlexSerif-Bold.ttf +0 -0
  72. package/.claude/skills/canvas-design/canvas-fonts/IBMPlexSerif-BoldItalic.ttf +0 -0
  73. package/.claude/skills/canvas-design/canvas-fonts/IBMPlexSerif-Italic.ttf +0 -0
  74. package/.claude/skills/canvas-design/canvas-fonts/IBMPlexSerif-Regular.ttf +0 -0
  75. package/.claude/skills/canvas-design/canvas-fonts/InstrumentSans-Bold.ttf +0 -0
  76. package/.claude/skills/canvas-design/canvas-fonts/InstrumentSans-BoldItalic.ttf +0 -0
  77. package/.claude/skills/canvas-design/canvas-fonts/InstrumentSans-Italic.ttf +0 -0
  78. package/.claude/skills/canvas-design/canvas-fonts/InstrumentSans-OFL.txt +93 -0
  79. package/.claude/skills/canvas-design/canvas-fonts/InstrumentSans-Regular.ttf +0 -0
  80. package/.claude/skills/canvas-design/canvas-fonts/InstrumentSerif-Italic.ttf +0 -0
  81. package/.claude/skills/canvas-design/canvas-fonts/InstrumentSerif-Regular.ttf +0 -0
  82. package/.claude/skills/canvas-design/canvas-fonts/Italiana-OFL.txt +93 -0
  83. package/.claude/skills/canvas-design/canvas-fonts/Italiana-Regular.ttf +0 -0
  84. package/.claude/skills/canvas-design/canvas-fonts/JetBrainsMono-Bold.ttf +0 -0
  85. package/.claude/skills/canvas-design/canvas-fonts/JetBrainsMono-OFL.txt +93 -0
  86. package/.claude/skills/canvas-design/canvas-fonts/JetBrainsMono-Regular.ttf +0 -0
  87. package/.claude/skills/canvas-design/canvas-fonts/Jura-Light.ttf +0 -0
  88. package/.claude/skills/canvas-design/canvas-fonts/Jura-Medium.ttf +0 -0
  89. package/.claude/skills/canvas-design/canvas-fonts/Jura-OFL.txt +93 -0
  90. package/.claude/skills/canvas-design/canvas-fonts/LibreBaskerville-OFL.txt +93 -0
  91. package/.claude/skills/canvas-design/canvas-fonts/LibreBaskerville-Regular.ttf +0 -0
  92. package/.claude/skills/canvas-design/canvas-fonts/Lora-Bold.ttf +0 -0
  93. package/.claude/skills/canvas-design/canvas-fonts/Lora-BoldItalic.ttf +0 -0
  94. package/.claude/skills/canvas-design/canvas-fonts/Lora-Italic.ttf +0 -0
  95. package/.claude/skills/canvas-design/canvas-fonts/Lora-OFL.txt +93 -0
  96. package/.claude/skills/canvas-design/canvas-fonts/Lora-Regular.ttf +0 -0
  97. package/.claude/skills/canvas-design/canvas-fonts/NationalPark-Bold.ttf +0 -0
  98. package/.claude/skills/canvas-design/canvas-fonts/NationalPark-OFL.txt +93 -0
  99. package/.claude/skills/canvas-design/canvas-fonts/NationalPark-Regular.ttf +0 -0
  100. package/.claude/skills/canvas-design/canvas-fonts/NothingYouCouldDo-OFL.txt +93 -0
  101. package/.claude/skills/canvas-design/canvas-fonts/NothingYouCouldDo-Regular.ttf +0 -0
  102. package/.claude/skills/canvas-design/canvas-fonts/Outfit-Bold.ttf +0 -0
  103. package/.claude/skills/canvas-design/canvas-fonts/Outfit-OFL.txt +93 -0
  104. package/.claude/skills/canvas-design/canvas-fonts/Outfit-Regular.ttf +0 -0
  105. package/.claude/skills/canvas-design/canvas-fonts/PixelifySans-Medium.ttf +0 -0
  106. package/.claude/skills/canvas-design/canvas-fonts/PixelifySans-OFL.txt +93 -0
  107. package/.claude/skills/canvas-design/canvas-fonts/PoiretOne-OFL.txt +93 -0
  108. package/.claude/skills/canvas-design/canvas-fonts/PoiretOne-Regular.ttf +0 -0
  109. package/.claude/skills/canvas-design/canvas-fonts/RedHatMono-Bold.ttf +0 -0
  110. package/.claude/skills/canvas-design/canvas-fonts/RedHatMono-OFL.txt +93 -0
  111. package/.claude/skills/canvas-design/canvas-fonts/RedHatMono-Regular.ttf +0 -0
  112. package/.claude/skills/canvas-design/canvas-fonts/Silkscreen-OFL.txt +93 -0
  113. package/.claude/skills/canvas-design/canvas-fonts/Silkscreen-Regular.ttf +0 -0
  114. package/.claude/skills/canvas-design/canvas-fonts/SmoochSans-Medium.ttf +0 -0
  115. package/.claude/skills/canvas-design/canvas-fonts/SmoochSans-OFL.txt +93 -0
  116. package/.claude/skills/canvas-design/canvas-fonts/Tektur-Medium.ttf +0 -0
  117. package/.claude/skills/canvas-design/canvas-fonts/Tektur-OFL.txt +93 -0
  118. package/.claude/skills/canvas-design/canvas-fonts/Tektur-Regular.ttf +0 -0
  119. package/.claude/skills/canvas-design/canvas-fonts/WorkSans-Bold.ttf +0 -0
  120. package/.claude/skills/canvas-design/canvas-fonts/WorkSans-BoldItalic.ttf +0 -0
  121. package/.claude/skills/canvas-design/canvas-fonts/WorkSans-Italic.ttf +0 -0
  122. package/.claude/skills/canvas-design/canvas-fonts/WorkSans-OFL.txt +93 -0
  123. package/.claude/skills/canvas-design/canvas-fonts/WorkSans-Regular.ttf +0 -0
  124. package/.claude/skills/canvas-design/canvas-fonts/YoungSerif-OFL.txt +93 -0
  125. package/.claude/skills/canvas-design/canvas-fonts/YoungSerif-Regular.ttf +0 -0
  126. package/.claude/skills/changelog-generator/SKILL.md +104 -0
  127. package/.claude/skills/cleanup-health-inline/SKILL.md +224 -0
  128. package/.claude/skills/code-reviewer/SKILL.md +209 -0
  129. package/.claude/skills/code-reviewer/references/code_review_checklist.md +103 -0
  130. package/.claude/skills/code-reviewer/references/coding_standards.md +103 -0
  131. package/.claude/skills/code-reviewer/references/common_antipatterns.md +103 -0
  132. package/.claude/skills/code-reviewer/scripts/code_quality_checker.py +114 -0
  133. package/.claude/skills/code-reviewer/scripts/pr_analyzer.py +114 -0
  134. package/.claude/skills/code-reviewer/scripts/review_report_generator.py +114 -0
  135. package/.claude/skills/content-research-writer/SKILL.md +538 -0
  136. package/.claude/skills/deps-health-inline/SKILL.md +227 -0
  137. package/.claude/skills/frontend-aesthetics/SKILL.md +51 -396
  138. package/.claude/skills/git-commit-helper/SKILL.md +203 -0
  139. package/.claude/skills/lead-research-assistant/SKILL.md +199 -0
  140. package/.claude/skills/reuse-health-inline/SKILL.md +248 -0
  141. package/.claude/skills/rollback-changes/SKILL.md +50 -524
  142. package/.claude/skills/run-quality-gate/SKILL.md +36 -346
  143. package/.claude/skills/security-health-inline/SKILL.md +224 -0
  144. package/.claude/skills/senior-devops/SKILL.md +209 -0
  145. package/.claude/skills/senior-devops/references/cicd_pipeline_guide.md +103 -0
  146. package/.claude/skills/senior-devops/references/deployment_strategies.md +103 -0
  147. package/.claude/skills/senior-devops/references/infrastructure_as_code.md +103 -0
  148. package/.claude/skills/senior-devops/scripts/deployment_manager.py +114 -0
  149. package/.claude/skills/senior-devops/scripts/pipeline_generator.py +114 -0
  150. package/.claude/skills/senior-devops/scripts/terraform_scaffolder.py +114 -0
  151. package/.claude/skills/senior-prompt-engineer/SKILL.md +226 -0
  152. package/.claude/skills/senior-prompt-engineer/references/agentic_system_design.md +80 -0
  153. package/.claude/skills/senior-prompt-engineer/references/llm_evaluation_frameworks.md +80 -0
  154. package/.claude/skills/senior-prompt-engineer/references/prompt_engineering_patterns.md +80 -0
  155. package/.claude/skills/senior-prompt-engineer/scripts/agent_orchestrator.py +100 -0
  156. package/.claude/skills/senior-prompt-engineer/scripts/prompt_optimizer.py +100 -0
  157. package/.claude/skills/senior-prompt-engineer/scripts/rag_evaluator.py +100 -0
  158. package/.claude/skills/setup-knip/SKILL.md +372 -0
  159. package/.claude/skills/systematic-debugging/CREATION-LOG.md +119 -0
  160. package/.claude/skills/systematic-debugging/SKILL.md +296 -0
  161. package/.claude/skills/systematic-debugging/condition-based-waiting-example.ts +158 -0
  162. package/.claude/skills/systematic-debugging/condition-based-waiting.md +115 -0
  163. package/.claude/skills/systematic-debugging/defense-in-depth.md +122 -0
  164. package/.claude/skills/systematic-debugging/find-polluter.sh +63 -0
  165. package/.claude/skills/systematic-debugging/root-cause-tracing.md +169 -0
  166. package/.claude/skills/systematic-debugging/test-academic.md +14 -0
  167. package/.claude/skills/systematic-debugging/test-pressure-1.md +58 -0
  168. package/.claude/skills/systematic-debugging/test-pressure-2.md +68 -0
  169. package/.claude/skills/systematic-debugging/test-pressure-3.md +69 -0
  170. package/.claude/skills/theme-factory/LICENSE.txt +202 -0
  171. package/.claude/skills/theme-factory/SKILL.md +59 -0
  172. package/.claude/skills/theme-factory/theme-showcase.pdf +0 -0
  173. package/.claude/skills/theme-factory/themes/arctic-frost.md +19 -0
  174. package/.claude/skills/theme-factory/themes/botanical-garden.md +19 -0
  175. package/.claude/skills/theme-factory/themes/desert-rose.md +19 -0
  176. package/.claude/skills/theme-factory/themes/forest-canopy.md +19 -0
  177. package/.claude/skills/theme-factory/themes/golden-hour.md +19 -0
  178. package/.claude/skills/theme-factory/themes/midnight-galaxy.md +19 -0
  179. package/.claude/skills/theme-factory/themes/modern-minimalist.md +19 -0
  180. package/.claude/skills/theme-factory/themes/ocean-depths.md +19 -0
  181. package/.claude/skills/theme-factory/themes/sunset-boulevard.md +19 -0
  182. package/.claude/skills/theme-factory/themes/tech-innovation.md +19 -0
  183. package/.claude/skills/ui-design-system/SKILL.md +32 -0
  184. package/.claude/skills/ui-design-system/scripts/design_token_generator.py +529 -0
  185. package/.claude/skills/ux-researcher-designer/SKILL.md +30 -0
  186. package/.claude/skills/ux-researcher-designer/scripts/persona_generator.py +508 -0
  187. package/.claude/skills/webapp-testing/LICENSE.txt +202 -0
  188. package/.claude/skills/webapp-testing/SKILL.md +96 -0
  189. package/.claude/skills/webapp-testing/examples/console_logging.py +35 -0
  190. package/.claude/skills/webapp-testing/examples/element_discovery.py +40 -0
  191. package/.claude/skills/webapp-testing/examples/static_html_automation.py +33 -0
  192. package/.claude/skills/webapp-testing/scripts/with_server.py +106 -0
  193. package/.gitignore +4 -0
  194. package/README.md +492 -1093
  195. package/README.ru.md +719 -0
  196. package/docs/Agents Ecosystem/AGENT-ORCHESTRATION.md +2 -2
  197. package/docs/{SPECKIT-GUIDE.md → COMMANDS-GUIDE.md} +252 -20
  198. package/docs/reports/skills/new-skills-analysis-2025-12.md +331 -0
  199. package/package.json +11 -3
  200. package/.claude/agents/health/orchestrators/bug-orchestrator.md +0 -1084
  201. package/.claude/agents/health/orchestrators/dead-code-orchestrator.md +0 -1064
  202. package/.claude/agents/health/orchestrators/dependency-orchestrator.md +0 -1064
  203. package/.claude/agents/health/orchestrators/reuse-orchestrator.md +0 -1112
  204. package/.claude/agents/health/orchestrators/security-orchestrator.md +0 -1064
  205. package/.claude/commands/worktree-cleanup.md +0 -382
  206. package/.claude/commands/worktree-create.md +0 -287
  207. package/.claude/commands/worktree-list.md +0 -239
  208. package/.claude/commands/worktree-remove.md +0 -339
  209. package/.claude/project-index.md +0 -75
  210. package/.claude/skills/load-project-context/SKILL.md +0 -89
  211. package/.claude/skills/resume-session/SKILL.md +0 -164
  212. package/.claude/skills/save-session-context/SKILL.md +0 -123
  213. package/.claude/templates/project-index.template.md +0 -67
  214. package/.claude/templates/session/context.template.md +0 -40
  215. package/.claude/templates/session/log.template.md +0 -72
  216. package/.github/BRANCH_PROTECTION.md +0 -137
  217. package/.github/workflows/build.yml +0 -70
  218. package/.github/workflows/deploy-staging.yml +0 -90
  219. package/.github/workflows/test.yml +0 -104
@@ -0,0 +1,100 @@
1
+ #!/usr/bin/env python3
2
+ """
3
+ Agent Orchestrator
4
+ Production-grade tool for senior prompt engineer
5
+ """
6
+
7
+ import os
8
+ import sys
9
+ import json
10
+ import logging
11
+ import argparse
12
+ from pathlib import Path
13
+ from typing import Dict, List, Optional
14
+ from datetime import datetime
15
+
16
+ logging.basicConfig(
17
+ level=logging.INFO,
18
+ format='%(asctime)s - %(levelname)s - %(message)s'
19
+ )
20
+ logger = logging.getLogger(__name__)
21
+
22
+ class AgentOrchestrator:
23
+ """Production-grade agent orchestrator"""
24
+
25
+ def __init__(self, config: Dict):
26
+ self.config = config
27
+ self.results = {
28
+ 'status': 'initialized',
29
+ 'start_time': datetime.now().isoformat(),
30
+ 'processed_items': 0
31
+ }
32
+ logger.info(f"Initialized {self.__class__.__name__}")
33
+
34
+ def validate_config(self) -> bool:
35
+ """Validate configuration"""
36
+ logger.info("Validating configuration...")
37
+ # Add validation logic
38
+ logger.info("Configuration validated")
39
+ return True
40
+
41
+ def process(self) -> Dict:
42
+ """Main processing logic"""
43
+ logger.info("Starting processing...")
44
+
45
+ try:
46
+ self.validate_config()
47
+
48
+ # Main processing
49
+ result = self._execute()
50
+
51
+ self.results['status'] = 'completed'
52
+ self.results['end_time'] = datetime.now().isoformat()
53
+
54
+ logger.info("Processing completed successfully")
55
+ return self.results
56
+
57
+ except Exception as e:
58
+ self.results['status'] = 'failed'
59
+ self.results['error'] = str(e)
60
+ logger.error(f"Processing failed: {e}")
61
+ raise
62
+
63
+ def _execute(self) -> Dict:
64
+ """Execute main logic"""
65
+ # Implementation here
66
+ return {'success': True}
67
+
68
+ def main():
69
+ """Main entry point"""
70
+ parser = argparse.ArgumentParser(
71
+ description="Agent Orchestrator"
72
+ )
73
+ parser.add_argument('--input', '-i', required=True, help='Input path')
74
+ parser.add_argument('--output', '-o', required=True, help='Output path')
75
+ parser.add_argument('--config', '-c', help='Configuration file')
76
+ parser.add_argument('--verbose', '-v', action='store_true', help='Verbose output')
77
+
78
+ args = parser.parse_args()
79
+
80
+ if args.verbose:
81
+ logging.getLogger().setLevel(logging.DEBUG)
82
+
83
+ try:
84
+ config = {
85
+ 'input': args.input,
86
+ 'output': args.output
87
+ }
88
+
89
+ processor = AgentOrchestrator(config)
90
+ results = processor.process()
91
+
92
+ print(json.dumps(results, indent=2))
93
+ sys.exit(0)
94
+
95
+ except Exception as e:
96
+ logger.error(f"Fatal error: {e}")
97
+ sys.exit(1)
98
+
99
+ if __name__ == '__main__':
100
+ main()
@@ -0,0 +1,100 @@
1
+ #!/usr/bin/env python3
2
+ """
3
+ Prompt Optimizer
4
+ Production-grade tool for senior prompt engineer
5
+ """
6
+
7
+ import os
8
+ import sys
9
+ import json
10
+ import logging
11
+ import argparse
12
+ from pathlib import Path
13
+ from typing import Dict, List, Optional
14
+ from datetime import datetime
15
+
16
+ logging.basicConfig(
17
+ level=logging.INFO,
18
+ format='%(asctime)s - %(levelname)s - %(message)s'
19
+ )
20
+ logger = logging.getLogger(__name__)
21
+
22
+ class PromptOptimizer:
23
+ """Production-grade prompt optimizer"""
24
+
25
+ def __init__(self, config: Dict):
26
+ self.config = config
27
+ self.results = {
28
+ 'status': 'initialized',
29
+ 'start_time': datetime.now().isoformat(),
30
+ 'processed_items': 0
31
+ }
32
+ logger.info(f"Initialized {self.__class__.__name__}")
33
+
34
+ def validate_config(self) -> bool:
35
+ """Validate configuration"""
36
+ logger.info("Validating configuration...")
37
+ # Add validation logic
38
+ logger.info("Configuration validated")
39
+ return True
40
+
41
+ def process(self) -> Dict:
42
+ """Main processing logic"""
43
+ logger.info("Starting processing...")
44
+
45
+ try:
46
+ self.validate_config()
47
+
48
+ # Main processing
49
+ result = self._execute()
50
+
51
+ self.results['status'] = 'completed'
52
+ self.results['end_time'] = datetime.now().isoformat()
53
+
54
+ logger.info("Processing completed successfully")
55
+ return self.results
56
+
57
+ except Exception as e:
58
+ self.results['status'] = 'failed'
59
+ self.results['error'] = str(e)
60
+ logger.error(f"Processing failed: {e}")
61
+ raise
62
+
63
+ def _execute(self) -> Dict:
64
+ """Execute main logic"""
65
+ # Implementation here
66
+ return {'success': True}
67
+
68
+ def main():
69
+ """Main entry point"""
70
+ parser = argparse.ArgumentParser(
71
+ description="Prompt Optimizer"
72
+ )
73
+ parser.add_argument('--input', '-i', required=True, help='Input path')
74
+ parser.add_argument('--output', '-o', required=True, help='Output path')
75
+ parser.add_argument('--config', '-c', help='Configuration file')
76
+ parser.add_argument('--verbose', '-v', action='store_true', help='Verbose output')
77
+
78
+ args = parser.parse_args()
79
+
80
+ if args.verbose:
81
+ logging.getLogger().setLevel(logging.DEBUG)
82
+
83
+ try:
84
+ config = {
85
+ 'input': args.input,
86
+ 'output': args.output
87
+ }
88
+
89
+ processor = PromptOptimizer(config)
90
+ results = processor.process()
91
+
92
+ print(json.dumps(results, indent=2))
93
+ sys.exit(0)
94
+
95
+ except Exception as e:
96
+ logger.error(f"Fatal error: {e}")
97
+ sys.exit(1)
98
+
99
+ if __name__ == '__main__':
100
+ main()
@@ -0,0 +1,100 @@
1
+ #!/usr/bin/env python3
2
+ """
3
+ Rag Evaluator
4
+ Production-grade tool for senior prompt engineer
5
+ """
6
+
7
+ import os
8
+ import sys
9
+ import json
10
+ import logging
11
+ import argparse
12
+ from pathlib import Path
13
+ from typing import Dict, List, Optional
14
+ from datetime import datetime
15
+
16
+ logging.basicConfig(
17
+ level=logging.INFO,
18
+ format='%(asctime)s - %(levelname)s - %(message)s'
19
+ )
20
+ logger = logging.getLogger(__name__)
21
+
22
+ class RagEvaluator:
23
+ """Production-grade rag evaluator"""
24
+
25
+ def __init__(self, config: Dict):
26
+ self.config = config
27
+ self.results = {
28
+ 'status': 'initialized',
29
+ 'start_time': datetime.now().isoformat(),
30
+ 'processed_items': 0
31
+ }
32
+ logger.info(f"Initialized {self.__class__.__name__}")
33
+
34
+ def validate_config(self) -> bool:
35
+ """Validate configuration"""
36
+ logger.info("Validating configuration...")
37
+ # Add validation logic
38
+ logger.info("Configuration validated")
39
+ return True
40
+
41
+ def process(self) -> Dict:
42
+ """Main processing logic"""
43
+ logger.info("Starting processing...")
44
+
45
+ try:
46
+ self.validate_config()
47
+
48
+ # Main processing
49
+ result = self._execute()
50
+
51
+ self.results['status'] = 'completed'
52
+ self.results['end_time'] = datetime.now().isoformat()
53
+
54
+ logger.info("Processing completed successfully")
55
+ return self.results
56
+
57
+ except Exception as e:
58
+ self.results['status'] = 'failed'
59
+ self.results['error'] = str(e)
60
+ logger.error(f"Processing failed: {e}")
61
+ raise
62
+
63
+ def _execute(self) -> Dict:
64
+ """Execute main logic"""
65
+ # Implementation here
66
+ return {'success': True}
67
+
68
+ def main():
69
+ """Main entry point"""
70
+ parser = argparse.ArgumentParser(
71
+ description="Rag Evaluator"
72
+ )
73
+ parser.add_argument('--input', '-i', required=True, help='Input path')
74
+ parser.add_argument('--output', '-o', required=True, help='Output path')
75
+ parser.add_argument('--config', '-c', help='Configuration file')
76
+ parser.add_argument('--verbose', '-v', action='store_true', help='Verbose output')
77
+
78
+ args = parser.parse_args()
79
+
80
+ if args.verbose:
81
+ logging.getLogger().setLevel(logging.DEBUG)
82
+
83
+ try:
84
+ config = {
85
+ 'input': args.input,
86
+ 'output': args.output
87
+ }
88
+
89
+ processor = RagEvaluator(config)
90
+ results = processor.process()
91
+
92
+ print(json.dumps(results, indent=2))
93
+ sys.exit(0)
94
+
95
+ except Exception as e:
96
+ logger.error(f"Fatal error: {e}")
97
+ sys.exit(1)
98
+
99
+ if __name__ == '__main__':
100
+ main()
@@ -0,0 +1,372 @@
1
+ ---
2
+ name: setup-knip
3
+ description: Install and configure Knip for dead code detection. Use before running dead-code-hunter or dependency-auditor to ensure Knip is available. Handles installation, configuration creation, and validation.
4
+ allowed-tools: Bash, Read, Write, Glob
5
+ ---
6
+
7
+ # Setup Knip
8
+
9
+ Install and configure Knip - the tool for finding unused files, dependencies, and exports in JavaScript/TypeScript projects.
10
+
11
+ ## When to Use
12
+
13
+ - Before running dead-code-hunter agent
14
+ - Before running dependency-auditor agent
15
+ - When project doesn't have Knip configured
16
+ - When upgrading Knip configuration
17
+ - In pre-flight validation of health workflows
18
+
19
+ ## Instructions
20
+
21
+ ### Step 1: Check if Knip is Installed
22
+
23
+ Check package.json for knip in devDependencies.
24
+
25
+ **Tools Used**: Read
26
+
27
+ ```bash
28
+ # Read package.json and check for knip
29
+ ```
30
+
31
+ **Check Logic**:
32
+ - If `devDependencies.knip` exists → Knip is installed
33
+ - If not found → Need to install
34
+
35
+ ### Step 2: Install Knip if Missing
36
+
37
+ If Knip is not installed, add it as devDependency.
38
+
39
+ **Tools Used**: Bash
40
+
41
+ ```bash
42
+ # Detect package manager
43
+ if [ -f "pnpm-lock.yaml" ]; then
44
+ pnpm add -D knip
45
+ elif [ -f "yarn.lock" ]; then
46
+ yarn add -D knip
47
+ elif [ -f "bun.lockb" ]; then
48
+ bun add -D knip
49
+ else
50
+ npm install -D knip
51
+ fi
52
+ ```
53
+
54
+ **Expected Output**:
55
+ ```
56
+ + knip@5.x.x
57
+ ```
58
+
59
+ ### Step 3: Check for Knip Configuration
60
+
61
+ Look for existing Knip configuration files.
62
+
63
+ **Tools Used**: Glob
64
+
65
+ **Configuration Files** (in priority order):
66
+ 1. `knip.json`
67
+ 2. `knip.jsonc`
68
+ 3. `knip.ts`
69
+ 4. `knip.config.ts`
70
+ 5. `knip.config.js`
71
+ 6. `package.json` (knip field)
72
+
73
+ ### Step 4: Create Default Configuration if Missing
74
+
75
+ If no configuration found, create `knip.json` with sensible defaults.
76
+
77
+ **Tools Used**: Write
78
+
79
+ **Default Configuration for Standard Project**:
80
+ ```json
81
+ {
82
+ "$schema": "https://unpkg.com/knip@5/schema.json",
83
+ "entry": ["src/index.{ts,tsx,js,jsx}", "src/main.{ts,tsx,js,jsx}"],
84
+ "project": ["src/**/*.{ts,tsx,js,jsx}"],
85
+ "ignore": [
86
+ "**/*.d.ts",
87
+ "**/*.test.{ts,tsx}",
88
+ "**/*.spec.{ts,tsx}",
89
+ "**/test/**",
90
+ "**/tests/**",
91
+ "**/__tests__/**",
92
+ "**/node_modules/**"
93
+ ],
94
+ "ignoreDependencies": [
95
+ "@types/*"
96
+ ]
97
+ }
98
+ ```
99
+
100
+ **Default Configuration for Next.js Project** (detected by next in dependencies):
101
+ ```json
102
+ {
103
+ "$schema": "https://unpkg.com/knip@5/schema.json",
104
+ "entry": [
105
+ "src/app/**/*.{ts,tsx}",
106
+ "src/pages/**/*.{ts,tsx}",
107
+ "app/**/*.{ts,tsx}",
108
+ "pages/**/*.{ts,tsx}"
109
+ ],
110
+ "project": ["src/**/*.{ts,tsx}", "app/**/*.{ts,tsx}", "pages/**/*.{ts,tsx}"],
111
+ "ignore": [
112
+ "**/*.d.ts",
113
+ "**/*.test.{ts,tsx}",
114
+ "**/*.spec.{ts,tsx}",
115
+ "**/node_modules/**"
116
+ ],
117
+ "next": {
118
+ "entry": [
119
+ "next.config.{js,ts,mjs}",
120
+ "middleware.{js,ts}"
121
+ ]
122
+ }
123
+ }
124
+ ```
125
+
126
+ **Default Configuration for Monorepo** (detected by workspaces in package.json):
127
+ ```json
128
+ {
129
+ "$schema": "https://unpkg.com/knip@5/schema.json",
130
+ "workspaces": {
131
+ "packages/*": {
132
+ "entry": ["src/index.{ts,tsx,js,jsx}"],
133
+ "project": ["src/**/*.{ts,tsx,js,jsx}"]
134
+ },
135
+ "apps/*": {
136
+ "entry": ["src/index.{ts,tsx,js,jsx}", "src/main.{ts,tsx,js,jsx}"],
137
+ "project": ["src/**/*.{ts,tsx,js,jsx}"]
138
+ }
139
+ },
140
+ "ignore": [
141
+ "**/*.d.ts",
142
+ "**/*.test.{ts,tsx}",
143
+ "**/*.spec.{ts,tsx}",
144
+ "**/node_modules/**"
145
+ ]
146
+ }
147
+ ```
148
+
149
+ ### Step 5: Add npm Scripts if Missing
150
+
151
+ Check if package.json has knip scripts, add if missing.
152
+
153
+ **Tools Used**: Read, Bash
154
+
155
+ **Scripts to Add**:
156
+ ```json
157
+ {
158
+ "scripts": {
159
+ "knip": "knip",
160
+ "knip:fix": "knip --fix",
161
+ "knip:deps": "knip --dependencies",
162
+ "knip:exports": "knip --exports",
163
+ "knip:files": "knip --files"
164
+ }
165
+ }
166
+ ```
167
+
168
+ **Add via npm pkg**:
169
+ ```bash
170
+ npm pkg set scripts.knip="knip"
171
+ npm pkg set scripts.knip:fix="knip --fix"
172
+ npm pkg set scripts.knip:deps="knip --dependencies"
173
+ npm pkg set scripts.knip:exports="knip --exports"
174
+ npm pkg set scripts.knip:files="knip --files"
175
+ ```
176
+
177
+ ### Step 6: Validate Installation
178
+
179
+ Run Knip to verify installation works.
180
+
181
+ **Tools Used**: Bash
182
+
183
+ ```bash
184
+ npx knip --help
185
+ ```
186
+
187
+ **Expected**: Help output displayed without errors
188
+
189
+ ### Step 7: Return Result
190
+
191
+ Return structured result indicating setup status.
192
+
193
+ **Expected Output**:
194
+ ```json
195
+ {
196
+ "installed": true,
197
+ "version": "5.x.x",
198
+ "config_file": "knip.json",
199
+ "config_created": true,
200
+ "scripts_added": ["knip", "knip:fix", "knip:deps", "knip:exports", "knip:files"],
201
+ "project_type": "nextjs|monorepo|standard",
202
+ "ready": true
203
+ }
204
+ ```
205
+
206
+ ## Error Handling
207
+
208
+ - **Installation fails**: Return error with package manager output
209
+ - **Configuration invalid**: Return error with validation details
210
+ - **Permission denied**: Return error suggesting sudo or permission fix
211
+ - **Network error**: Return error suggesting offline installation
212
+
213
+ ## Examples
214
+
215
+ ### Example 1: Fresh Project (No Knip)
216
+
217
+ **Initial State**:
218
+ - package.json exists
219
+ - No knip in devDependencies
220
+ - No knip.json
221
+
222
+ **Actions**:
223
+ 1. Install knip via detected package manager
224
+ 2. Detect project type (standard)
225
+ 3. Create knip.json with defaults
226
+ 4. Add npm scripts
227
+ 5. Validate installation
228
+
229
+ **Output**:
230
+ ```json
231
+ {
232
+ "installed": true,
233
+ "version": "5.73.3",
234
+ "config_file": "knip.json",
235
+ "config_created": true,
236
+ "scripts_added": ["knip", "knip:fix", "knip:deps", "knip:exports", "knip:files"],
237
+ "project_type": "standard",
238
+ "ready": true
239
+ }
240
+ ```
241
+
242
+ ### Example 2: Next.js Project with Existing Knip
243
+
244
+ **Initial State**:
245
+ - package.json with next dependency
246
+ - knip already in devDependencies
247
+ - knip.json exists
248
+
249
+ **Actions**:
250
+ 1. Detect knip installed (skip installation)
251
+ 2. Detect existing config (skip creation)
252
+ 3. Check scripts (add missing)
253
+ 4. Validate installation
254
+
255
+ **Output**:
256
+ ```json
257
+ {
258
+ "installed": true,
259
+ "version": "5.73.3",
260
+ "config_file": "knip.json",
261
+ "config_created": false,
262
+ "scripts_added": ["knip:deps"],
263
+ "project_type": "nextjs",
264
+ "ready": true
265
+ }
266
+ ```
267
+
268
+ ### Example 3: Monorepo Project
269
+
270
+ **Initial State**:
271
+ - package.json with workspaces field
272
+ - No knip
273
+
274
+ **Actions**:
275
+ 1. Detect monorepo (workspaces in package.json)
276
+ 2. Install knip
277
+ 3. Create monorepo-specific knip.json
278
+ 4. Add npm scripts
279
+ 5. Validate installation
280
+
281
+ **Output**:
282
+ ```json
283
+ {
284
+ "installed": true,
285
+ "version": "5.73.3",
286
+ "config_file": "knip.json",
287
+ "config_created": true,
288
+ "scripts_added": ["knip", "knip:fix", "knip:deps", "knip:exports", "knip:files"],
289
+ "project_type": "monorepo",
290
+ "ready": true
291
+ }
292
+ ```
293
+
294
+ ## Knip Command Reference
295
+
296
+ For agents using Knip after setup:
297
+
298
+ | Command | Purpose | Use Case |
299
+ |---------|---------|----------|
300
+ | `npx knip` | Full analysis | Complete dead code scan |
301
+ | `npx knip --dependencies` | Dependencies only | dependency-auditor |
302
+ | `npx knip --exports` | Exports only | Unused export detection |
303
+ | `npx knip --files` | Files only | Unused file detection |
304
+ | `npx knip --fix --fix-type exports,types` | Auto-fix exports/types | Safe automated cleanup |
305
+ | `npx knip --fix --fix-type dependencies` | Auto-fix deps | Remove from package.json |
306
+ | `npx knip --reporter json` | JSON output | Machine parsing |
307
+ | `npx knip --reporter compact` | Compact output | Quick review |
308
+
309
+ ## CRITICAL SAFETY WARNING
310
+
311
+ ### NEVER Use `--allow-remove-files`
312
+
313
+ **`npx knip --fix --allow-remove-files` is FORBIDDEN!**
314
+
315
+ Knip has a critical limitation: **it cannot detect dynamic imports**.
316
+
317
+ ```typescript
318
+ // Knip CANNOT see these relationships:
319
+ const module = await import(`./plugins/${name}.ts`);
320
+ const Component = lazy(() => import('./components/Dashboard'));
321
+ require(`./locales/${lang}.json`);
322
+ ```
323
+
324
+ Files loaded via dynamic imports will appear "unused" to Knip but are actually critical!
325
+
326
+ ### Safe Knip Usage
327
+
328
+ **ALLOWED**:
329
+ - `npx knip --fix --fix-type exports` - Safe: removes unused exports from files
330
+ - `npx knip --fix --fix-type types` - Safe: removes unused type exports
331
+ - `npx knip --fix --fix-type dependencies` - Safe: removes from package.json only
332
+
333
+ **FORBIDDEN**:
334
+ - `npx knip --fix --allow-remove-files` - DANGEROUS: may delete files with dynamic imports
335
+ - `npx knip --fix` (without --fix-type) - May include file removal
336
+
337
+ ### Manual Verification Required
338
+
339
+ Before removing ANY file flagged by Knip:
340
+ 1. Search for dynamic imports: `import(`, `require(`, `lazy(`, `loadable(`
341
+ 2. Check for string interpolation in imports
342
+ 3. Verify no config files reference the file
343
+ 4. Run build and tests after removal
344
+
345
+ ## Integration with Agents
346
+
347
+ ### dead-code-hunter Pre-Check
348
+
349
+ ```markdown
350
+ ## Phase 0: Pre-Flight
351
+
352
+ 1. Use setup-knip Skill to ensure Knip is available
353
+ 2. If result.ready === false, halt with setup instructions
354
+ 3. If result.ready === true, proceed with detection
355
+ ```
356
+
357
+ ### dependency-auditor Pre-Check
358
+
359
+ ```markdown
360
+ ## Phase 1: Environment Analysis
361
+
362
+ 1. Use setup-knip Skill before dependency analysis
363
+ 2. Knip will detect unused dependencies more accurately than manual grep
364
+ ```
365
+
366
+ ## Notes
367
+
368
+ - Knip version 5.x is required (major improvements over v4)
369
+ - Configuration is auto-detected for 100+ frameworks
370
+ - Monorepo support is first-class
371
+ - Use `--reporter json` for machine-readable output
372
+ - The `--fix` flag can auto-remove unused exports and dependencies