claudecode-omc 5.5.2 → 5.6.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/README.md +63 -0
- package/bundled/manifest.json +3 -2
- package/bundled/upstream/ecc/.omc-source/bundle.json +23 -0
- package/bundled/upstream/ecc/.omc-source/last-plan-apply.json +439 -0
- package/bundled/upstream/ecc/.omc-source/manifests/.claude-plugin/marketplace.json +47 -0
- package/bundled/upstream/ecc/agents/a11y-architect.md +141 -0
- package/bundled/upstream/ecc/agents/architect.md +211 -0
- package/bundled/upstream/ecc/agents/build-error-resolver.md +114 -0
- package/bundled/upstream/ecc/agents/chief-of-staff.md +151 -0
- package/bundled/upstream/ecc/agents/code-architect.md +71 -0
- package/bundled/upstream/ecc/agents/code-explorer.md +69 -0
- package/bundled/upstream/ecc/agents/code-reviewer.md +237 -0
- package/bundled/upstream/ecc/agents/code-simplifier.md +47 -0
- package/bundled/upstream/ecc/agents/comment-analyzer.md +45 -0
- package/bundled/upstream/ecc/agents/conversation-analyzer.md +52 -0
- package/bundled/upstream/ecc/agents/cpp-build-resolver.md +90 -0
- package/bundled/upstream/ecc/agents/cpp-reviewer.md +72 -0
- package/bundled/upstream/ecc/agents/csharp-reviewer.md +101 -0
- package/bundled/upstream/ecc/agents/dart-build-resolver.md +201 -0
- package/bundled/upstream/ecc/agents/database-reviewer.md +91 -0
- package/bundled/upstream/ecc/agents/doc-updater.md +107 -0
- package/bundled/upstream/ecc/agents/docs-lookup.md +68 -0
- package/bundled/upstream/ecc/agents/e2e-runner.md +107 -0
- package/bundled/upstream/ecc/agents/flutter-reviewer.md +243 -0
- package/bundled/upstream/ecc/agents/gan-evaluator.md +209 -0
- package/bundled/upstream/ecc/agents/gan-generator.md +131 -0
- package/bundled/upstream/ecc/agents/gan-planner.md +99 -0
- package/bundled/upstream/ecc/agents/go-build-resolver.md +94 -0
- package/bundled/upstream/ecc/agents/go-reviewer.md +76 -0
- package/bundled/upstream/ecc/agents/harness-optimizer.md +35 -0
- package/bundled/upstream/ecc/agents/healthcare-reviewer.md +83 -0
- package/bundled/upstream/ecc/agents/java-build-resolver.md +153 -0
- package/bundled/upstream/ecc/agents/java-reviewer.md +92 -0
- package/bundled/upstream/ecc/agents/kotlin-build-resolver.md +118 -0
- package/bundled/upstream/ecc/agents/kotlin-reviewer.md +159 -0
- package/bundled/upstream/ecc/agents/loop-operator.md +36 -0
- package/bundled/upstream/ecc/agents/opensource-forker.md +198 -0
- package/bundled/upstream/ecc/agents/opensource-packager.md +249 -0
- package/bundled/upstream/ecc/agents/opensource-sanitizer.md +188 -0
- package/bundled/upstream/ecc/agents/performance-optimizer.md +446 -0
- package/bundled/upstream/ecc/agents/planner.md +212 -0
- package/bundled/upstream/ecc/agents/pr-test-analyzer.md +45 -0
- package/bundled/upstream/ecc/agents/python-reviewer.md +98 -0
- package/bundled/upstream/ecc/agents/pytorch-build-resolver.md +120 -0
- package/bundled/upstream/ecc/agents/refactor-cleaner.md +85 -0
- package/bundled/upstream/ecc/agents/rust-build-resolver.md +148 -0
- package/bundled/upstream/ecc/agents/rust-reviewer.md +94 -0
- package/bundled/upstream/ecc/agents/security-reviewer.md +108 -0
- package/bundled/upstream/ecc/agents/seo-specialist.md +62 -0
- package/bundled/upstream/ecc/agents/silent-failure-hunter.md +50 -0
- package/bundled/upstream/ecc/agents/tdd-guide.md +91 -0
- package/bundled/upstream/ecc/agents/type-design-analyzer.md +41 -0
- package/bundled/upstream/ecc/agents/typescript-reviewer.md +112 -0
- package/bundled/upstream/ecc/commands/agent-sort.md +23 -0
- package/bundled/upstream/ecc/commands/aside.md +164 -0
- package/bundled/upstream/ecc/commands/build-fix.md +62 -0
- package/bundled/upstream/ecc/commands/checkpoint.md +74 -0
- package/bundled/upstream/ecc/commands/claw.md +23 -0
- package/bundled/upstream/ecc/commands/code-review.md +289 -0
- package/bundled/upstream/ecc/commands/context-budget.md +23 -0
- package/bundled/upstream/ecc/commands/cpp-build.md +173 -0
- package/bundled/upstream/ecc/commands/cpp-review.md +132 -0
- package/bundled/upstream/ecc/commands/cpp-test.md +251 -0
- package/bundled/upstream/ecc/commands/devfleet.md +23 -0
- package/bundled/upstream/ecc/commands/docs.md +23 -0
- package/bundled/upstream/ecc/commands/e2e.md +268 -0
- package/bundled/upstream/ecc/commands/eval.md +23 -0
- package/bundled/upstream/ecc/commands/evolve.md +178 -0
- package/bundled/upstream/ecc/commands/feature-dev.md +49 -0
- package/bundled/upstream/ecc/commands/flutter-build.md +164 -0
- package/bundled/upstream/ecc/commands/flutter-review.md +116 -0
- package/bundled/upstream/ecc/commands/flutter-test.md +144 -0
- package/bundled/upstream/ecc/commands/gan-build.md +99 -0
- package/bundled/upstream/ecc/commands/gan-design.md +35 -0
- package/bundled/upstream/ecc/commands/go-build.md +183 -0
- package/bundled/upstream/ecc/commands/go-review.md +148 -0
- package/bundled/upstream/ecc/commands/go-test.md +268 -0
- package/bundled/upstream/ecc/commands/gradle-build.md +70 -0
- package/bundled/upstream/ecc/commands/harness-audit.md +73 -0
- package/bundled/upstream/ecc/commands/hookify-configure.md +14 -0
- package/bundled/upstream/ecc/commands/hookify-help.md +46 -0
- package/bundled/upstream/ecc/commands/hookify-list.md +21 -0
- package/bundled/upstream/ecc/commands/hookify.md +50 -0
- package/bundled/upstream/ecc/commands/instinct-export.md +66 -0
- package/bundled/upstream/ecc/commands/instinct-import.md +114 -0
- package/bundled/upstream/ecc/commands/instinct-status.md +59 -0
- package/bundled/upstream/ecc/commands/jira.md +106 -0
- package/bundled/upstream/ecc/commands/kotlin-build.md +174 -0
- package/bundled/upstream/ecc/commands/kotlin-review.md +140 -0
- package/bundled/upstream/ecc/commands/kotlin-test.md +312 -0
- package/bundled/upstream/ecc/commands/learn-eval.md +116 -0
- package/bundled/upstream/ecc/commands/learn.md +70 -0
- package/bundled/upstream/ecc/commands/loop-start.md +32 -0
- package/bundled/upstream/ecc/commands/loop-status.md +24 -0
- package/bundled/upstream/ecc/commands/model-route.md +26 -0
- package/bundled/upstream/ecc/commands/multi-backend.md +158 -0
- package/bundled/upstream/ecc/commands/multi-execute.md +315 -0
- package/bundled/upstream/ecc/commands/multi-frontend.md +158 -0
- package/bundled/upstream/ecc/commands/multi-plan.md +268 -0
- package/bundled/upstream/ecc/commands/multi-workflow.md +191 -0
- package/bundled/upstream/ecc/commands/orchestrate.md +135 -0
- package/bundled/upstream/ecc/commands/plan.md +117 -0
- package/bundled/upstream/ecc/commands/pm2.md +272 -0
- package/bundled/upstream/ecc/commands/projects.md +39 -0
- package/bundled/upstream/ecc/commands/promote.md +41 -0
- package/bundled/upstream/ecc/commands/prompt-optimize.md +23 -0
- package/bundled/upstream/ecc/commands/prp-commit.md +112 -0
- package/bundled/upstream/ecc/commands/prp-implement.md +385 -0
- package/bundled/upstream/ecc/commands/prp-plan.md +502 -0
- package/bundled/upstream/ecc/commands/prp-pr.md +184 -0
- package/bundled/upstream/ecc/commands/prp-prd.md +447 -0
- package/bundled/upstream/ecc/commands/prune.md +31 -0
- package/bundled/upstream/ecc/commands/python-review.md +297 -0
- package/bundled/upstream/ecc/commands/quality-gate.md +29 -0
- package/bundled/upstream/ecc/commands/refactor-clean.md +80 -0
- package/bundled/upstream/ecc/commands/resume-session.md +156 -0
- package/bundled/upstream/ecc/commands/review-pr.md +37 -0
- package/bundled/upstream/ecc/commands/rules-distill.md +20 -0
- package/bundled/upstream/ecc/commands/rust-build.md +187 -0
- package/bundled/upstream/ecc/commands/rust-review.md +142 -0
- package/bundled/upstream/ecc/commands/rust-test.md +308 -0
- package/bundled/upstream/ecc/commands/santa-loop.md +175 -0
- package/bundled/upstream/ecc/commands/save-session.md +275 -0
- package/bundled/upstream/ecc/commands/sessions.md +339 -0
- package/bundled/upstream/ecc/commands/setup-pm.md +80 -0
- package/bundled/upstream/ecc/commands/skill-create.md +174 -0
- package/bundled/upstream/ecc/commands/skill-health.md +54 -0
- package/bundled/upstream/ecc/commands/tdd.md +231 -0
- package/bundled/upstream/ecc/commands/test-coverage.md +69 -0
- package/bundled/upstream/ecc/commands/update-codemaps.md +72 -0
- package/bundled/upstream/ecc/commands/update-docs.md +84 -0
- package/bundled/upstream/ecc/commands/verify.md +23 -0
- package/bundled/upstream/ecc/hooks/README.md +237 -0
- package/bundled/upstream/ecc/hooks/hooks.json +330 -0
- package/bundled/upstream/ecc/skills/accessibility/SKILL.md +146 -0
- package/bundled/upstream/ecc/skills/agent-eval/SKILL.md +145 -0
- package/bundled/upstream/ecc/skills/agent-harness-construction/SKILL.md +73 -0
- package/bundled/upstream/ecc/skills/agent-introspection-debugging/SKILL.md +153 -0
- package/bundled/upstream/ecc/skills/agent-payment-x402/SKILL.md +178 -0
- package/bundled/upstream/ecc/skills/agent-sort/SKILL.md +215 -0
- package/bundled/upstream/ecc/skills/agentic-engineering/SKILL.md +63 -0
- package/bundled/upstream/ecc/skills/ai-first-engineering/SKILL.md +51 -0
- package/bundled/upstream/ecc/skills/ai-regression-testing/SKILL.md +385 -0
- package/bundled/upstream/ecc/skills/android-clean-architecture/SKILL.md +339 -0
- package/bundled/upstream/ecc/skills/api-connector-builder/SKILL.md +120 -0
- package/bundled/upstream/ecc/skills/api-design/SKILL.md +523 -0
- package/bundled/upstream/ecc/skills/architecture-decision-records/SKILL.md +179 -0
- package/bundled/upstream/ecc/skills/article-writing/SKILL.md +79 -0
- package/bundled/upstream/ecc/skills/automation-audit-ops/SKILL.md +142 -0
- package/bundled/upstream/ecc/skills/autonomous-agent-harness/SKILL.md +267 -0
- package/bundled/upstream/ecc/skills/autonomous-loops/SKILL.md +610 -0
- package/bundled/upstream/ecc/skills/backend-patterns/SKILL.md +598 -0
- package/bundled/upstream/ecc/skills/benchmark/SKILL.md +93 -0
- package/bundled/upstream/ecc/skills/blueprint/SKILL.md +105 -0
- package/bundled/upstream/ecc/skills/brand-voice/SKILL.md +97 -0
- package/bundled/upstream/ecc/skills/brand-voice/references/voice-profile-schema.md +55 -0
- package/bundled/upstream/ecc/skills/browser-qa/SKILL.md +87 -0
- package/bundled/upstream/ecc/skills/bun-runtime/SKILL.md +84 -0
- package/bundled/upstream/ecc/skills/canary-watch/SKILL.md +99 -0
- package/bundled/upstream/ecc/skills/carrier-relationship-management/SKILL.md +212 -0
- package/bundled/upstream/ecc/skills/ck/SKILL.md +147 -0
- package/bundled/upstream/ecc/skills/ck/commands/forget.mjs +44 -0
- package/bundled/upstream/ecc/skills/ck/commands/info.mjs +24 -0
- package/bundled/upstream/ecc/skills/ck/commands/init.mjs +143 -0
- package/bundled/upstream/ecc/skills/ck/commands/list.mjs +40 -0
- package/bundled/upstream/ecc/skills/ck/commands/migrate.mjs +202 -0
- package/bundled/upstream/ecc/skills/ck/commands/resume.mjs +36 -0
- package/bundled/upstream/ecc/skills/ck/commands/save.mjs +210 -0
- package/bundled/upstream/ecc/skills/ck/commands/shared.mjs +387 -0
- package/bundled/upstream/ecc/skills/ck/hooks/session-start.mjs +224 -0
- package/bundled/upstream/ecc/skills/claude-api/SKILL.md +337 -0
- package/bundled/upstream/ecc/skills/claude-devfleet/SKILL.md +103 -0
- package/bundled/upstream/ecc/skills/click-path-audit/SKILL.md +244 -0
- package/bundled/upstream/ecc/skills/clickhouse-io/SKILL.md +439 -0
- package/bundled/upstream/ecc/skills/code-tour/SKILL.md +236 -0
- package/bundled/upstream/ecc/skills/codebase-onboarding/SKILL.md +233 -0
- package/bundled/upstream/ecc/skills/coding-standards/SKILL.md +549 -0
- package/bundled/upstream/ecc/skills/compose-multiplatform-patterns/SKILL.md +299 -0
- package/bundled/upstream/ecc/skills/configure-ecc/SKILL.md +367 -0
- package/bundled/upstream/ecc/skills/connections-optimizer/SKILL.md +189 -0
- package/bundled/upstream/ecc/skills/content-engine/SKILL.md +131 -0
- package/bundled/upstream/ecc/skills/content-hash-cache-pattern/SKILL.md +161 -0
- package/bundled/upstream/ecc/skills/context-budget/SKILL.md +135 -0
- package/bundled/upstream/ecc/skills/continuous-agent-loop/SKILL.md +45 -0
- package/bundled/upstream/ecc/skills/continuous-learning/SKILL.md +123 -0
- package/bundled/upstream/ecc/skills/continuous-learning/config.json +18 -0
- package/bundled/upstream/ecc/skills/continuous-learning/evaluate-session.sh +69 -0
- package/bundled/upstream/ecc/skills/continuous-learning-v2/SKILL.md +346 -0
- package/bundled/upstream/ecc/skills/continuous-learning-v2/agents/observer-loop.sh +282 -0
- package/bundled/upstream/ecc/skills/continuous-learning-v2/agents/observer.md +198 -0
- package/bundled/upstream/ecc/skills/continuous-learning-v2/agents/session-guardian.sh +150 -0
- package/bundled/upstream/ecc/skills/continuous-learning-v2/agents/start-observer.sh +244 -0
- package/bundled/upstream/ecc/skills/continuous-learning-v2/config.json +8 -0
- package/bundled/upstream/ecc/skills/continuous-learning-v2/hooks/observe.sh +460 -0
- package/bundled/upstream/ecc/skills/continuous-learning-v2/scripts/detect-project.sh +243 -0
- package/bundled/upstream/ecc/skills/continuous-learning-v2/scripts/instinct-cli.py +1426 -0
- package/bundled/upstream/ecc/skills/continuous-learning-v2/scripts/test_parse_instinct.py +984 -0
- package/bundled/upstream/ecc/skills/cost-aware-llm-pipeline/SKILL.md +183 -0
- package/bundled/upstream/ecc/skills/council/SKILL.md +203 -0
- package/bundled/upstream/ecc/skills/cpp-coding-standards/SKILL.md +723 -0
- package/bundled/upstream/ecc/skills/cpp-testing/SKILL.md +324 -0
- package/bundled/upstream/ecc/skills/crosspost/SKILL.md +111 -0
- package/bundled/upstream/ecc/skills/csharp-testing/SKILL.md +321 -0
- package/bundled/upstream/ecc/skills/customer-billing-ops/SKILL.md +140 -0
- package/bundled/upstream/ecc/skills/customs-trade-compliance/SKILL.md +263 -0
- package/bundled/upstream/ecc/skills/dart-flutter-patterns/SKILL.md +563 -0
- package/bundled/upstream/ecc/skills/dashboard-builder/SKILL.md +108 -0
- package/bundled/upstream/ecc/skills/data-scraper-agent/SKILL.md +764 -0
- package/bundled/upstream/ecc/skills/database-migrations/SKILL.md +429 -0
- package/bundled/upstream/ecc/skills/deep-research/SKILL.md +155 -0
- package/bundled/upstream/ecc/skills/defi-amm-security/SKILL.md +160 -0
- package/bundled/upstream/ecc/skills/deployment-patterns/SKILL.md +427 -0
- package/bundled/upstream/ecc/skills/design-system/SKILL.md +82 -0
- package/bundled/upstream/ecc/skills/django-patterns/SKILL.md +734 -0
- package/bundled/upstream/ecc/skills/django-security/SKILL.md +593 -0
- package/bundled/upstream/ecc/skills/django-tdd/SKILL.md +729 -0
- package/bundled/upstream/ecc/skills/django-verification/SKILL.md +469 -0
- package/bundled/upstream/ecc/skills/dmux-workflows/SKILL.md +191 -0
- package/bundled/upstream/ecc/skills/docker-patterns/SKILL.md +364 -0
- package/bundled/upstream/ecc/skills/documentation-lookup/SKILL.md +90 -0
- package/bundled/upstream/ecc/skills/dotnet-patterns/SKILL.md +321 -0
- package/bundled/upstream/ecc/skills/e2e-testing/SKILL.md +326 -0
- package/bundled/upstream/ecc/skills/ecc-tools-cost-audit/SKILL.md +160 -0
- package/bundled/upstream/ecc/skills/email-ops/SKILL.md +121 -0
- package/bundled/upstream/ecc/skills/energy-procurement/SKILL.md +228 -0
- package/bundled/upstream/ecc/skills/enterprise-agent-ops/SKILL.md +50 -0
- package/bundled/upstream/ecc/skills/eval-harness/SKILL.md +270 -0
- package/bundled/upstream/ecc/skills/evm-token-decimals/SKILL.md +130 -0
- package/bundled/upstream/ecc/skills/exa-search/SKILL.md +103 -0
- package/bundled/upstream/ecc/skills/fal-ai-media/SKILL.md +284 -0
- package/bundled/upstream/ecc/skills/finance-billing-ops/SKILL.md +127 -0
- package/bundled/upstream/ecc/skills/flutter-dart-code-review/SKILL.md +435 -0
- package/bundled/upstream/ecc/skills/foundation-models-on-device/SKILL.md +243 -0
- package/bundled/upstream/ecc/skills/frontend-design/SKILL.md +145 -0
- package/bundled/upstream/ecc/skills/frontend-patterns/SKILL.md +642 -0
- package/bundled/upstream/ecc/skills/frontend-slides/SKILL.md +184 -0
- package/bundled/upstream/ecc/skills/frontend-slides/STYLE_PRESETS.md +330 -0
- package/bundled/upstream/ecc/skills/gan-style-harness/SKILL.md +278 -0
- package/bundled/upstream/ecc/skills/gateguard/SKILL.md +121 -0
- package/bundled/upstream/ecc/skills/git-workflow/SKILL.md +715 -0
- package/bundled/upstream/ecc/skills/github-ops/SKILL.md +144 -0
- package/bundled/upstream/ecc/skills/golang-patterns/SKILL.md +674 -0
- package/bundled/upstream/ecc/skills/golang-testing/SKILL.md +720 -0
- package/bundled/upstream/ecc/skills/google-workspace-ops/SKILL.md +95 -0
- package/bundled/upstream/ecc/skills/healthcare-cdss-patterns/SKILL.md +245 -0
- package/bundled/upstream/ecc/skills/healthcare-emr-patterns/SKILL.md +159 -0
- package/bundled/upstream/ecc/skills/healthcare-eval-harness/SKILL.md +207 -0
- package/bundled/upstream/ecc/skills/healthcare-phi-compliance/SKILL.md +145 -0
- package/bundled/upstream/ecc/skills/hexagonal-architecture/SKILL.md +276 -0
- package/bundled/upstream/ecc/skills/hipaa-compliance/SKILL.md +78 -0
- package/bundled/upstream/ecc/skills/hookify-rules/SKILL.md +128 -0
- package/bundled/upstream/ecc/skills/inventory-demand-planning/SKILL.md +247 -0
- package/bundled/upstream/ecc/skills/investor-materials/SKILL.md +96 -0
- package/bundled/upstream/ecc/skills/investor-outreach/SKILL.md +91 -0
- package/bundled/upstream/ecc/skills/iterative-retrieval/SKILL.md +211 -0
- package/bundled/upstream/ecc/skills/java-coding-standards/SKILL.md +147 -0
- package/bundled/upstream/ecc/skills/jira-integration/SKILL.md +293 -0
- package/bundled/upstream/ecc/skills/jpa-patterns/SKILL.md +151 -0
- package/bundled/upstream/ecc/skills/knowledge-ops/SKILL.md +154 -0
- package/bundled/upstream/ecc/skills/kotlin-coroutines-flows/SKILL.md +284 -0
- package/bundled/upstream/ecc/skills/kotlin-exposed-patterns/SKILL.md +719 -0
- package/bundled/upstream/ecc/skills/kotlin-ktor-patterns/SKILL.md +689 -0
- package/bundled/upstream/ecc/skills/kotlin-patterns/SKILL.md +711 -0
- package/bundled/upstream/ecc/skills/kotlin-testing/SKILL.md +824 -0
- package/bundled/upstream/ecc/skills/laravel-patterns/SKILL.md +415 -0
- package/bundled/upstream/ecc/skills/laravel-plugin-discovery/SKILL.md +229 -0
- package/bundled/upstream/ecc/skills/laravel-security/SKILL.md +285 -0
- package/bundled/upstream/ecc/skills/laravel-tdd/SKILL.md +283 -0
- package/bundled/upstream/ecc/skills/laravel-verification/SKILL.md +179 -0
- package/bundled/upstream/ecc/skills/lead-intelligence/SKILL.md +321 -0
- package/bundled/upstream/ecc/skills/lead-intelligence/agents/enrichment-agent.md +85 -0
- package/bundled/upstream/ecc/skills/lead-intelligence/agents/mutual-mapper.md +75 -0
- package/bundled/upstream/ecc/skills/lead-intelligence/agents/outreach-drafter.md +98 -0
- package/bundled/upstream/ecc/skills/lead-intelligence/agents/signal-scorer.md +60 -0
- package/bundled/upstream/ecc/skills/liquid-glass-design/SKILL.md +279 -0
- package/bundled/upstream/ecc/skills/llm-trading-agent-security/SKILL.md +146 -0
- package/bundled/upstream/ecc/skills/logistics-exception-management/SKILL.md +222 -0
- package/bundled/upstream/ecc/skills/manim-video/SKILL.md +89 -0
- package/bundled/upstream/ecc/skills/manim-video/assets/network_graph_scene.py +52 -0
- package/bundled/upstream/ecc/skills/market-research/SKILL.md +75 -0
- package/bundled/upstream/ecc/skills/mcp-server-patterns/SKILL.md +69 -0
- package/bundled/upstream/ecc/skills/messages-ops/SKILL.md +104 -0
- package/bundled/upstream/ecc/skills/nanoclaw-repl/SKILL.md +33 -0
- package/bundled/upstream/ecc/skills/nestjs-patterns/SKILL.md +230 -0
- package/bundled/upstream/ecc/skills/nextjs-turbopack/SKILL.md +44 -0
- package/bundled/upstream/ecc/skills/nodejs-keccak256/SKILL.md +102 -0
- package/bundled/upstream/ecc/skills/nutrient-document-processing/SKILL.md +167 -0
- package/bundled/upstream/ecc/skills/nuxt4-patterns/SKILL.md +100 -0
- package/bundled/upstream/ecc/skills/openclaw-persona-forge/SKILL.md +296 -0
- package/bundled/upstream/ecc/skills/openclaw-persona-forge/gacha.py +224 -0
- package/bundled/upstream/ecc/skills/openclaw-persona-forge/gacha.sh +5 -0
- package/bundled/upstream/ecc/skills/openclaw-persona-forge/references/avatar-style.md +124 -0
- package/bundled/upstream/ecc/skills/openclaw-persona-forge/references/boundary-rules.md +53 -0
- package/bundled/upstream/ecc/skills/openclaw-persona-forge/references/error-handling.md +53 -0
- package/bundled/upstream/ecc/skills/openclaw-persona-forge/references/identity-tension.md +48 -0
- package/bundled/upstream/ecc/skills/openclaw-persona-forge/references/naming-system.md +39 -0
- package/bundled/upstream/ecc/skills/openclaw-persona-forge/references/output-template.md +166 -0
- package/bundled/upstream/ecc/skills/opensource-pipeline/SKILL.md +255 -0
- package/bundled/upstream/ecc/skills/perl-patterns/SKILL.md +504 -0
- package/bundled/upstream/ecc/skills/perl-security/SKILL.md +503 -0
- package/bundled/upstream/ecc/skills/perl-testing/SKILL.md +475 -0
- package/bundled/upstream/ecc/skills/plankton-code-quality/SKILL.md +236 -0
- package/bundled/upstream/ecc/skills/postgres-patterns/SKILL.md +147 -0
- package/bundled/upstream/ecc/skills/product-capability/SKILL.md +141 -0
- package/bundled/upstream/ecc/skills/product-lens/SKILL.md +92 -0
- package/bundled/upstream/ecc/skills/production-scheduling/SKILL.md +238 -0
- package/bundled/upstream/ecc/skills/project-flow-ops/SKILL.md +111 -0
- package/bundled/upstream/ecc/skills/prompt-optimizer/SKILL.md +397 -0
- package/bundled/upstream/ecc/skills/python-patterns/SKILL.md +750 -0
- package/bundled/upstream/ecc/skills/python-testing/SKILL.md +816 -0
- package/bundled/upstream/ecc/skills/pytorch-patterns/SKILL.md +396 -0
- package/bundled/upstream/ecc/skills/quality-nonconformance/SKILL.md +260 -0
- package/bundled/upstream/ecc/skills/ralphinho-rfc-pipeline/SKILL.md +67 -0
- package/bundled/upstream/ecc/skills/regex-vs-llm-structured-text/SKILL.md +220 -0
- package/bundled/upstream/ecc/skills/remotion-video-creation/SKILL.md +43 -0
- package/bundled/upstream/ecc/skills/remotion-video-creation/rules/3d.md +86 -0
- package/bundled/upstream/ecc/skills/remotion-video-creation/rules/animations.md +29 -0
- package/bundled/upstream/ecc/skills/remotion-video-creation/rules/assets/charts-bar-chart.tsx +173 -0
- package/bundled/upstream/ecc/skills/remotion-video-creation/rules/assets/text-animations-typewriter.tsx +100 -0
- package/bundled/upstream/ecc/skills/remotion-video-creation/rules/assets/text-animations-word-highlight.tsx +108 -0
- package/bundled/upstream/ecc/skills/remotion-video-creation/rules/assets.md +78 -0
- package/bundled/upstream/ecc/skills/remotion-video-creation/rules/audio.md +172 -0
- package/bundled/upstream/ecc/skills/remotion-video-creation/rules/calculate-metadata.md +104 -0
- package/bundled/upstream/ecc/skills/remotion-video-creation/rules/can-decode.md +75 -0
- package/bundled/upstream/ecc/skills/remotion-video-creation/rules/charts.md +58 -0
- package/bundled/upstream/ecc/skills/remotion-video-creation/rules/compositions.md +146 -0
- package/bundled/upstream/ecc/skills/remotion-video-creation/rules/display-captions.md +126 -0
- package/bundled/upstream/ecc/skills/remotion-video-creation/rules/extract-frames.md +229 -0
- package/bundled/upstream/ecc/skills/remotion-video-creation/rules/fonts.md +152 -0
- package/bundled/upstream/ecc/skills/remotion-video-creation/rules/get-audio-duration.md +58 -0
- package/bundled/upstream/ecc/skills/remotion-video-creation/rules/get-video-dimensions.md +68 -0
- package/bundled/upstream/ecc/skills/remotion-video-creation/rules/get-video-duration.md +58 -0
- package/bundled/upstream/ecc/skills/remotion-video-creation/rules/gifs.md +138 -0
- package/bundled/upstream/ecc/skills/remotion-video-creation/rules/images.md +130 -0
- package/bundled/upstream/ecc/skills/remotion-video-creation/rules/import-srt-captions.md +67 -0
- package/bundled/upstream/ecc/skills/remotion-video-creation/rules/lottie.md +67 -0
- package/bundled/upstream/ecc/skills/remotion-video-creation/rules/measuring-dom-nodes.md +34 -0
- package/bundled/upstream/ecc/skills/remotion-video-creation/rules/measuring-text.md +143 -0
- package/bundled/upstream/ecc/skills/remotion-video-creation/rules/sequencing.md +106 -0
- package/bundled/upstream/ecc/skills/remotion-video-creation/rules/tailwind.md +11 -0
- package/bundled/upstream/ecc/skills/remotion-video-creation/rules/text-animations.md +20 -0
- package/bundled/upstream/ecc/skills/remotion-video-creation/rules/timing.md +179 -0
- package/bundled/upstream/ecc/skills/remotion-video-creation/rules/transcribe-captions.md +19 -0
- package/bundled/upstream/ecc/skills/remotion-video-creation/rules/transitions.md +122 -0
- package/bundled/upstream/ecc/skills/remotion-video-creation/rules/trimming.md +52 -0
- package/bundled/upstream/ecc/skills/remotion-video-creation/rules/videos.md +171 -0
- package/bundled/upstream/ecc/skills/repo-scan/SKILL.md +78 -0
- package/bundled/upstream/ecc/skills/research-ops/SKILL.md +112 -0
- package/bundled/upstream/ecc/skills/returns-reverse-logistics/SKILL.md +240 -0
- package/bundled/upstream/ecc/skills/rules-distill/SKILL.md +264 -0
- package/bundled/upstream/ecc/skills/rules-distill/scripts/scan-rules.sh +58 -0
- package/bundled/upstream/ecc/skills/rules-distill/scripts/scan-skills.sh +129 -0
- package/bundled/upstream/ecc/skills/rust-patterns/SKILL.md +499 -0
- package/bundled/upstream/ecc/skills/rust-testing/SKILL.md +500 -0
- package/bundled/upstream/ecc/skills/safety-guard/SKILL.md +75 -0
- package/bundled/upstream/ecc/skills/santa-method/SKILL.md +306 -0
- package/bundled/upstream/ecc/skills/search-first/SKILL.md +161 -0
- package/bundled/upstream/ecc/skills/security-bounty-hunter/SKILL.md +99 -0
- package/bundled/upstream/ecc/skills/security-review/SKILL.md +495 -0
- package/bundled/upstream/ecc/skills/security-review/cloud-infrastructure-security.md +361 -0
- package/bundled/upstream/ecc/skills/security-scan/SKILL.md +165 -0
- package/bundled/upstream/ecc/skills/seo/SKILL.md +154 -0
- package/bundled/upstream/ecc/skills/skill-comply/SKILL.md +58 -0
- package/bundled/upstream/ecc/skills/skill-comply/fixtures/compliant_trace.jsonl +5 -0
- package/bundled/upstream/ecc/skills/skill-comply/fixtures/noncompliant_trace.jsonl +3 -0
- package/bundled/upstream/ecc/skills/skill-comply/fixtures/tdd_spec.yaml +44 -0
- package/bundled/upstream/ecc/skills/skill-comply/prompts/classifier.md +24 -0
- package/bundled/upstream/ecc/skills/skill-comply/prompts/scenario_generator.md +62 -0
- package/bundled/upstream/ecc/skills/skill-comply/prompts/spec_generator.md +42 -0
- package/bundled/upstream/ecc/skills/skill-comply/pyproject.toml +15 -0
- package/bundled/upstream/ecc/skills/skill-comply/scripts/__init__.py +0 -0
- package/bundled/upstream/ecc/skills/skill-comply/scripts/classifier.py +85 -0
- package/bundled/upstream/ecc/skills/skill-comply/scripts/grader.py +124 -0
- package/bundled/upstream/ecc/skills/skill-comply/scripts/parser.py +107 -0
- package/bundled/upstream/ecc/skills/skill-comply/scripts/report.py +170 -0
- package/bundled/upstream/ecc/skills/skill-comply/scripts/run.py +127 -0
- package/bundled/upstream/ecc/skills/skill-comply/scripts/runner.py +161 -0
- package/bundled/upstream/ecc/skills/skill-comply/scripts/scenario_generator.py +70 -0
- package/bundled/upstream/ecc/skills/skill-comply/scripts/spec_generator.py +72 -0
- package/bundled/upstream/ecc/skills/skill-comply/scripts/utils.py +13 -0
- package/bundled/upstream/ecc/skills/skill-comply/tests/test_grader.py +197 -0
- package/bundled/upstream/ecc/skills/skill-comply/tests/test_parser.py +90 -0
- package/bundled/upstream/ecc/skills/skill-stocktake/SKILL.md +193 -0
- package/bundled/upstream/ecc/skills/skill-stocktake/scripts/quick-diff.sh +87 -0
- package/bundled/upstream/ecc/skills/skill-stocktake/scripts/save-results.sh +56 -0
- package/bundled/upstream/ecc/skills/skill-stocktake/scripts/scan.sh +170 -0
- package/bundled/upstream/ecc/skills/social-graph-ranker/SKILL.md +154 -0
- package/bundled/upstream/ecc/skills/springboot-patterns/SKILL.md +314 -0
- package/bundled/upstream/ecc/skills/springboot-security/SKILL.md +272 -0
- package/bundled/upstream/ecc/skills/springboot-tdd/SKILL.md +158 -0
- package/bundled/upstream/ecc/skills/springboot-verification/SKILL.md +231 -0
- package/bundled/upstream/ecc/skills/strategic-compact/SKILL.md +131 -0
- package/bundled/upstream/ecc/skills/strategic-compact/suggest-compact.sh +54 -0
- package/bundled/upstream/ecc/skills/swift-actor-persistence/SKILL.md +143 -0
- package/bundled/upstream/ecc/skills/swift-concurrency-6-2/SKILL.md +216 -0
- package/bundled/upstream/ecc/skills/swift-protocol-di-testing/SKILL.md +190 -0
- package/bundled/upstream/ecc/skills/swiftui-patterns/SKILL.md +259 -0
- package/bundled/upstream/ecc/skills/tdd-workflow/SKILL.md +463 -0
- package/bundled/upstream/ecc/skills/team-builder/SKILL.md +168 -0
- package/bundled/upstream/ecc/skills/terminal-ops/SKILL.md +109 -0
- package/bundled/upstream/ecc/skills/token-budget-advisor/SKILL.md +133 -0
- package/bundled/upstream/ecc/skills/ui-demo/SKILL.md +465 -0
- package/bundled/upstream/ecc/skills/unified-notifications-ops/SKILL.md +187 -0
- package/bundled/upstream/ecc/skills/verification-loop/SKILL.md +126 -0
- package/bundled/upstream/ecc/skills/video-editing/SKILL.md +310 -0
- package/bundled/upstream/ecc/skills/videodb/SKILL.md +374 -0
- package/bundled/upstream/ecc/skills/videodb/reference/api-reference.md +550 -0
- package/bundled/upstream/ecc/skills/videodb/reference/capture-reference.md +407 -0
- package/bundled/upstream/ecc/skills/videodb/reference/capture.md +101 -0
- package/bundled/upstream/ecc/skills/videodb/reference/editor.md +443 -0
- package/bundled/upstream/ecc/skills/videodb/reference/generative.md +331 -0
- package/bundled/upstream/ecc/skills/videodb/reference/rtstream-reference.md +564 -0
- package/bundled/upstream/ecc/skills/videodb/reference/rtstream.md +65 -0
- package/bundled/upstream/ecc/skills/videodb/reference/search.md +230 -0
- package/bundled/upstream/ecc/skills/videodb/reference/streaming.md +406 -0
- package/bundled/upstream/ecc/skills/videodb/reference/use-cases.md +118 -0
- package/bundled/upstream/ecc/skills/videodb/scripts/ws_listener.py +282 -0
- package/bundled/upstream/ecc/skills/visa-doc-translate/README.md +86 -0
- package/bundled/upstream/ecc/skills/visa-doc-translate/SKILL.md +117 -0
- package/bundled/upstream/ecc/skills/workspace-surface-audit/SKILL.md +125 -0
- package/bundled/upstream/ecc/skills/x-api/SKILL.md +230 -0
- package/bundled/upstream/superpowers/.omc-source/last-plan-apply.json +22 -0
- package/package.json +3 -1
- package/src/catalog/source-catalog.js +391 -0
- package/src/cli/artifact.js +3 -2
- package/src/cli/doctor.js +25 -4
- package/src/cli/index.js +19 -0
- package/src/cli/plan.js +220 -0
- package/src/cli/setup.js +209 -12
- package/src/cli/source.js +110 -3
- package/src/config/paths.js +31 -0
- package/src/config/sources.js +103 -10
- package/src/merge/hook-merger.js +1 -0
|
@@ -0,0 +1,188 @@
|
|
|
1
|
+
---
|
|
2
|
+
name: opensource-sanitizer
|
|
3
|
+
description: Verify an open-source fork is fully sanitized before release. Scans for leaked secrets, PII, internal references, and dangerous files using 20+ regex patterns. Generates a PASS/FAIL/PASS-WITH-WARNINGS report. Second stage of the opensource-pipeline skill. Use PROACTIVELY before any public release.
|
|
4
|
+
tools: ["Read", "Grep", "Glob", "Bash"]
|
|
5
|
+
model: sonnet
|
|
6
|
+
---
|
|
7
|
+
|
|
8
|
+
# Open-Source Sanitizer
|
|
9
|
+
|
|
10
|
+
You are an independent auditor that verifies a forked project is fully sanitized for open-source release. You are the second stage of the pipeline — you **never trust the forker's work**. Verify everything independently.
|
|
11
|
+
|
|
12
|
+
## Your Role
|
|
13
|
+
|
|
14
|
+
- Scan every file for secret patterns, PII, and internal references
|
|
15
|
+
- Audit git history for leaked credentials
|
|
16
|
+
- Verify `.env.example` completeness
|
|
17
|
+
- Generate a detailed PASS/FAIL report
|
|
18
|
+
- **Read-only** — you never modify files, only report
|
|
19
|
+
|
|
20
|
+
## Workflow
|
|
21
|
+
|
|
22
|
+
### Step 1: Secrets Scan (CRITICAL — any match = FAIL)
|
|
23
|
+
|
|
24
|
+
Scan every text file (excluding `node_modules`, `.git`, `__pycache__`, `*.min.js`, binaries):
|
|
25
|
+
|
|
26
|
+
```
|
|
27
|
+
# API keys
|
|
28
|
+
pattern: [A-Za-z0-9_]*(api[_-]?key|apikey|api[_-]?secret)[A-Za-z0-9_]*\s*[=:]\s*['"]?[A-Za-z0-9+/=_-]{16,}
|
|
29
|
+
|
|
30
|
+
# AWS
|
|
31
|
+
pattern: AKIA[0-9A-Z]{16}
|
|
32
|
+
pattern: (?i)(aws_secret_access_key|aws_secret)\s*[=:]\s*['"]?[A-Za-z0-9+/=]{20,}
|
|
33
|
+
|
|
34
|
+
# Database URLs with credentials
|
|
35
|
+
pattern: (postgres|mysql|mongodb|redis)://[^:]+:[^@]+@[^\s'"]+
|
|
36
|
+
|
|
37
|
+
# JWT tokens (3-segment: header.payload.signature)
|
|
38
|
+
pattern: eyJ[A-Za-z0-9_-]{20,}\.eyJ[A-Za-z0-9_-]{20,}\.[A-Za-z0-9_-]+
|
|
39
|
+
|
|
40
|
+
# Private keys
|
|
41
|
+
pattern: -----BEGIN\s+(RSA\s+|EC\s+|DSA\s+|OPENSSH\s+)?PRIVATE KEY-----
|
|
42
|
+
|
|
43
|
+
# GitHub tokens (personal, server, OAuth, user-to-server)
|
|
44
|
+
pattern: gh[pousr]_[A-Za-z0-9_]{36,}
|
|
45
|
+
pattern: github_pat_[A-Za-z0-9_]{22,}
|
|
46
|
+
|
|
47
|
+
# Google OAuth secrets
|
|
48
|
+
pattern: GOCSPX-[A-Za-z0-9_-]+
|
|
49
|
+
|
|
50
|
+
# Slack webhooks
|
|
51
|
+
pattern: https://hooks\.slack\.com/services/T[A-Z0-9]+/B[A-Z0-9]+/[A-Za-z0-9]+
|
|
52
|
+
|
|
53
|
+
# SendGrid / Mailgun
|
|
54
|
+
pattern: SG\.[A-Za-z0-9_-]{22}\.[A-Za-z0-9_-]{43}
|
|
55
|
+
pattern: key-[A-Za-z0-9]{32}
|
|
56
|
+
```
|
|
57
|
+
|
|
58
|
+
#### Heuristic Patterns (WARNING — manual review, does NOT auto-fail)
|
|
59
|
+
|
|
60
|
+
```
|
|
61
|
+
# High-entropy strings in config files
|
|
62
|
+
pattern: ^[A-Z_]+=[A-Za-z0-9+/=_-]{32,}$
|
|
63
|
+
severity: WARNING (manual review needed)
|
|
64
|
+
```
|
|
65
|
+
|
|
66
|
+
### Step 2: PII Scan (CRITICAL)
|
|
67
|
+
|
|
68
|
+
```
|
|
69
|
+
# Personal email addresses (not generic like noreply@, info@)
|
|
70
|
+
pattern: [a-zA-Z0-9._%+-]+@(gmail|yahoo|hotmail|outlook|protonmail|icloud)\.(com|net|org)
|
|
71
|
+
severity: CRITICAL
|
|
72
|
+
|
|
73
|
+
# Private IP addresses indicating internal infrastructure
|
|
74
|
+
pattern: (192\.168\.\d+\.\d+|10\.\d+\.\d+\.\d+|172\.(1[6-9]|2\d|3[01])\.\d+\.\d+)
|
|
75
|
+
severity: CRITICAL (if not documented as placeholder in .env.example)
|
|
76
|
+
|
|
77
|
+
# SSH connection strings
|
|
78
|
+
pattern: ssh\s+[a-z]+@[0-9.]+
|
|
79
|
+
severity: CRITICAL
|
|
80
|
+
```
|
|
81
|
+
|
|
82
|
+
### Step 3: Internal References Scan (CRITICAL)
|
|
83
|
+
|
|
84
|
+
```
|
|
85
|
+
# Absolute paths to specific user home directories
|
|
86
|
+
pattern: /home/[a-z][a-z0-9_-]*/ (anything other than /home/user/)
|
|
87
|
+
pattern: /Users/[A-Za-z][A-Za-z0-9_-]*/ (macOS home directories)
|
|
88
|
+
pattern: C:\\Users\\[A-Za-z] (Windows home directories)
|
|
89
|
+
severity: CRITICAL
|
|
90
|
+
|
|
91
|
+
# Internal secret file references
|
|
92
|
+
pattern: \.secrets/
|
|
93
|
+
pattern: source\s+~/\.secrets/
|
|
94
|
+
severity: CRITICAL
|
|
95
|
+
```
|
|
96
|
+
|
|
97
|
+
### Step 4: Dangerous Files Check (CRITICAL — existence = FAIL)
|
|
98
|
+
|
|
99
|
+
Verify these do NOT exist:
|
|
100
|
+
```
|
|
101
|
+
.env (any variant: .env.local, .env.production, .env.*.local)
|
|
102
|
+
*.pem, *.key, *.p12, *.pfx, *.jks
|
|
103
|
+
credentials.json, service-account*.json
|
|
104
|
+
.secrets/, secrets/
|
|
105
|
+
.claude/settings.json
|
|
106
|
+
sessions/
|
|
107
|
+
*.map (source maps expose original source structure and file paths)
|
|
108
|
+
node_modules/, __pycache__/, .venv/, venv/
|
|
109
|
+
```
|
|
110
|
+
|
|
111
|
+
### Step 5: Configuration Completeness (WARNING)
|
|
112
|
+
|
|
113
|
+
Verify:
|
|
114
|
+
- `.env.example` exists
|
|
115
|
+
- Every env var referenced in code has an entry in `.env.example`
|
|
116
|
+
- `docker-compose.yml` (if present) uses `${VAR}` syntax, not hardcoded values
|
|
117
|
+
|
|
118
|
+
### Step 6: Git History Audit
|
|
119
|
+
|
|
120
|
+
```bash
|
|
121
|
+
# Should be a single initial commit
|
|
122
|
+
cd PROJECT_DIR
|
|
123
|
+
git log --oneline | wc -l
|
|
124
|
+
# If > 1, history was not cleaned — FAIL
|
|
125
|
+
|
|
126
|
+
# Search history for potential secrets
|
|
127
|
+
git log -p | grep -iE '(password|secret|api.?key|token)' | head -20
|
|
128
|
+
```
|
|
129
|
+
|
|
130
|
+
## Output Format
|
|
131
|
+
|
|
132
|
+
Generate `SANITIZATION_REPORT.md` in the project directory:
|
|
133
|
+
|
|
134
|
+
```markdown
|
|
135
|
+
# Sanitization Report: {project-name}
|
|
136
|
+
|
|
137
|
+
**Date:** {date}
|
|
138
|
+
**Auditor:** opensource-sanitizer v1.0.0
|
|
139
|
+
**Verdict:** PASS | FAIL | PASS WITH WARNINGS
|
|
140
|
+
|
|
141
|
+
## Summary
|
|
142
|
+
|
|
143
|
+
| Category | Status | Findings |
|
|
144
|
+
|----------|--------|----------|
|
|
145
|
+
| Secrets | PASS/FAIL | {count} findings |
|
|
146
|
+
| PII | PASS/FAIL | {count} findings |
|
|
147
|
+
| Internal References | PASS/FAIL | {count} findings |
|
|
148
|
+
| Dangerous Files | PASS/FAIL | {count} findings |
|
|
149
|
+
| Config Completeness | PASS/WARN | {count} findings |
|
|
150
|
+
| Git History | PASS/FAIL | {count} findings |
|
|
151
|
+
|
|
152
|
+
## Critical Findings (Must Fix Before Release)
|
|
153
|
+
|
|
154
|
+
1. **[SECRETS]** `src/config.py:42` — Hardcoded database password: `DB_P...` (truncated)
|
|
155
|
+
2. **[INTERNAL]** `docker-compose.yml:15` — References internal domain
|
|
156
|
+
|
|
157
|
+
## Warnings (Review Before Release)
|
|
158
|
+
|
|
159
|
+
1. **[CONFIG]** `src/app.py:8` — Port 8080 hardcoded, should be configurable
|
|
160
|
+
|
|
161
|
+
## .env.example Audit
|
|
162
|
+
|
|
163
|
+
- Variables in code but NOT in .env.example: {list}
|
|
164
|
+
- Variables in .env.example but NOT in code: {list}
|
|
165
|
+
|
|
166
|
+
## Recommendation
|
|
167
|
+
|
|
168
|
+
{If FAIL: "Fix the {N} critical findings and re-run sanitizer."}
|
|
169
|
+
{If PASS: "Project is clear for open-source release. Proceed to packager."}
|
|
170
|
+
{If WARNINGS: "Project passes critical checks. Review {N} warnings before release."}
|
|
171
|
+
```
|
|
172
|
+
|
|
173
|
+
## Examples
|
|
174
|
+
|
|
175
|
+
### Example: Scan a sanitized Node.js project
|
|
176
|
+
Input: `Verify project: /home/user/opensource-staging/my-api`
|
|
177
|
+
Action: Runs all 6 scan categories across 47 files, checks git log (1 commit), verifies `.env.example` covers 5 variables found in code
|
|
178
|
+
Output: `SANITIZATION_REPORT.md` — PASS WITH WARNINGS (one hardcoded port in README)
|
|
179
|
+
|
|
180
|
+
## Rules
|
|
181
|
+
|
|
182
|
+
- **Never** display full secret values — truncate to first 4 chars + "..."
|
|
183
|
+
- **Never** modify source files — only generate reports (SANITIZATION_REPORT.md)
|
|
184
|
+
- **Always** scan every text file, not just known extensions
|
|
185
|
+
- **Always** check git history, even for fresh repos
|
|
186
|
+
- **Be paranoid** — false positives are acceptable, false negatives are not
|
|
187
|
+
- A single CRITICAL finding in any category = overall FAIL
|
|
188
|
+
- Warnings alone = PASS WITH WARNINGS (user decides)
|
|
@@ -0,0 +1,446 @@
|
|
|
1
|
+
---
|
|
2
|
+
name: performance-optimizer
|
|
3
|
+
description: Performance analysis and optimization specialist. Use PROACTIVELY for identifying bottlenecks, optimizing slow code, reducing bundle sizes, and improving runtime performance. Profiling, memory leaks, render optimization, and algorithmic improvements.
|
|
4
|
+
tools: ["Read", "Write", "Edit", "Bash", "Grep", "Glob"]
|
|
5
|
+
model: sonnet
|
|
6
|
+
---
|
|
7
|
+
|
|
8
|
+
# Performance Optimizer
|
|
9
|
+
|
|
10
|
+
You are an expert performance specialist focused on identifying bottlenecks and optimizing application speed, memory usage, and efficiency. Your mission is to make code faster, lighter, and more responsive.
|
|
11
|
+
|
|
12
|
+
## Core Responsibilities
|
|
13
|
+
|
|
14
|
+
1. **Performance Profiling** — Identify slow code paths, memory leaks, and bottlenecks
|
|
15
|
+
2. **Bundle Optimization** — Reduce JavaScript bundle sizes, lazy loading, code splitting
|
|
16
|
+
3. **Runtime Optimization** — Improve algorithmic efficiency, reduce unnecessary computations
|
|
17
|
+
4. **React/Rendering Optimization** — Prevent unnecessary re-renders, optimize component trees
|
|
18
|
+
5. **Database & Network** — Optimize queries, reduce API calls, implement caching
|
|
19
|
+
6. **Memory Management** — Detect leaks, optimize memory usage, cleanup resources
|
|
20
|
+
|
|
21
|
+
## Analysis Commands
|
|
22
|
+
|
|
23
|
+
```bash
|
|
24
|
+
# Bundle analysis
|
|
25
|
+
npx bundle-analyzer
|
|
26
|
+
npx source-map-explorer build/static/js/*.js
|
|
27
|
+
|
|
28
|
+
# Lighthouse performance audit
|
|
29
|
+
npx lighthouse https://your-app.com --view
|
|
30
|
+
|
|
31
|
+
# Node.js profiling
|
|
32
|
+
node --prof your-app.js
|
|
33
|
+
node --prof-process isolate-*.log
|
|
34
|
+
|
|
35
|
+
# Memory analysis
|
|
36
|
+
node --inspect your-app.js # Then use Chrome DevTools
|
|
37
|
+
|
|
38
|
+
# React profiling (in browser)
|
|
39
|
+
# React DevTools > Profiler tab
|
|
40
|
+
|
|
41
|
+
# Network analysis
|
|
42
|
+
npx webpack-bundle-analyzer
|
|
43
|
+
```
|
|
44
|
+
|
|
45
|
+
## Performance Review Workflow
|
|
46
|
+
|
|
47
|
+
### 1. Identify Performance Issues
|
|
48
|
+
|
|
49
|
+
**Critical Performance Indicators:**
|
|
50
|
+
|
|
51
|
+
| Metric | Target | Action if Exceeded |
|
|
52
|
+
|--------|--------|-------------------|
|
|
53
|
+
| First Contentful Paint | < 1.8s | Optimize critical path, inline critical CSS |
|
|
54
|
+
| Largest Contentful Paint | < 2.5s | Lazy load images, optimize server response |
|
|
55
|
+
| Time to Interactive | < 3.8s | Code splitting, reduce JavaScript |
|
|
56
|
+
| Cumulative Layout Shift | < 0.1 | Reserve space for images, avoid layout thrashing |
|
|
57
|
+
| Total Blocking Time | < 200ms | Break up long tasks, use web workers |
|
|
58
|
+
| Bundle Size (gzipped) | < 200KB | Tree shaking, lazy loading, code splitting |
|
|
59
|
+
|
|
60
|
+
### 2. Algorithmic Analysis
|
|
61
|
+
|
|
62
|
+
Check for inefficient algorithms:
|
|
63
|
+
|
|
64
|
+
| Pattern | Complexity | Better Alternative |
|
|
65
|
+
|---------|------------|-------------------|
|
|
66
|
+
| Nested loops on same data | O(n²) | Use Map/Set for O(1) lookups |
|
|
67
|
+
| Repeated array searches | O(n) per search | Convert to Map for O(1) |
|
|
68
|
+
| Sorting inside loop | O(n² log n) | Sort once outside loop |
|
|
69
|
+
| String concatenation in loop | O(n²) | Use array.join() |
|
|
70
|
+
| Deep cloning large objects | O(n) each time | Use shallow copy or immer |
|
|
71
|
+
| Recursion without memoization | O(2^n) | Add memoization |
|
|
72
|
+
|
|
73
|
+
```typescript
|
|
74
|
+
// BAD: O(n²) - searching array in loop
|
|
75
|
+
for (const user of users) {
|
|
76
|
+
const posts = allPosts.filter(p => p.userId === user.id); // O(n) per user
|
|
77
|
+
}
|
|
78
|
+
|
|
79
|
+
// GOOD: O(n) - group once with Map
|
|
80
|
+
const postsByUser = new Map<number, Post[]>();
|
|
81
|
+
for (const post of allPosts) {
|
|
82
|
+
const userPosts = postsByUser.get(post.userId) || [];
|
|
83
|
+
userPosts.push(post);
|
|
84
|
+
postsByUser.set(post.userId, userPosts);
|
|
85
|
+
}
|
|
86
|
+
// Now O(1) lookup per user
|
|
87
|
+
```
|
|
88
|
+
|
|
89
|
+
### 3. React Performance Optimization
|
|
90
|
+
|
|
91
|
+
**Common React Anti-patterns:**
|
|
92
|
+
|
|
93
|
+
```tsx
|
|
94
|
+
// BAD: Inline function creation in render
|
|
95
|
+
<Button onClick={() => handleClick(id)}>Submit</Button>
|
|
96
|
+
|
|
97
|
+
// GOOD: Stable callback with useCallback
|
|
98
|
+
const handleButtonClick = useCallback(() => handleClick(id), [handleClick, id]);
|
|
99
|
+
<Button onClick={handleButtonClick}>Submit</Button>
|
|
100
|
+
|
|
101
|
+
// BAD: Object creation in render
|
|
102
|
+
<Child style={{ color: 'red' }} />
|
|
103
|
+
|
|
104
|
+
// GOOD: Stable object reference
|
|
105
|
+
const style = useMemo(() => ({ color: 'red' }), []);
|
|
106
|
+
<Child style={style} />
|
|
107
|
+
|
|
108
|
+
// BAD: Expensive computation on every render
|
|
109
|
+
const sortedItems = items.sort((a, b) => a.name.localeCompare(b.name));
|
|
110
|
+
|
|
111
|
+
// GOOD: Memoize expensive computations
|
|
112
|
+
const sortedItems = useMemo(
|
|
113
|
+
() => [...items].sort((a, b) => a.name.localeCompare(b.name)),
|
|
114
|
+
[items]
|
|
115
|
+
);
|
|
116
|
+
|
|
117
|
+
// BAD: List without keys or with index
|
|
118
|
+
{items.map((item, index) => <Item key={index} />)}
|
|
119
|
+
|
|
120
|
+
// GOOD: Stable unique keys
|
|
121
|
+
{items.map(item => <Item key={item.id} item={item} />)}
|
|
122
|
+
```
|
|
123
|
+
|
|
124
|
+
**React Performance Checklist:**
|
|
125
|
+
|
|
126
|
+
- [ ] `useMemo` for expensive computations
|
|
127
|
+
- [ ] `useCallback` for functions passed to children
|
|
128
|
+
- [ ] `React.memo` for frequently re-rendered components
|
|
129
|
+
- [ ] Proper dependency arrays in hooks
|
|
130
|
+
- [ ] Virtualization for long lists (react-window, react-virtualized)
|
|
131
|
+
- [ ] Lazy loading for heavy components (`React.lazy`)
|
|
132
|
+
- [ ] Code splitting at route level
|
|
133
|
+
|
|
134
|
+
### 4. Bundle Size Optimization
|
|
135
|
+
|
|
136
|
+
**Bundle Analysis Checklist:**
|
|
137
|
+
|
|
138
|
+
```bash
|
|
139
|
+
# Analyze bundle composition
|
|
140
|
+
npx webpack-bundle-analyzer build/static/js/*.js
|
|
141
|
+
|
|
142
|
+
# Check for duplicate dependencies
|
|
143
|
+
npx duplicate-package-checker-analyzer
|
|
144
|
+
|
|
145
|
+
# Find largest files
|
|
146
|
+
du -sh node_modules/* | sort -hr | head -20
|
|
147
|
+
```
|
|
148
|
+
|
|
149
|
+
**Optimization Strategies:**
|
|
150
|
+
|
|
151
|
+
| Issue | Solution |
|
|
152
|
+
|-------|----------|
|
|
153
|
+
| Large vendor bundle | Tree shaking, smaller alternatives |
|
|
154
|
+
| Duplicate code | Extract to shared module |
|
|
155
|
+
| Unused exports | Remove dead code with knip |
|
|
156
|
+
| Moment.js | Use date-fns or dayjs (smaller) |
|
|
157
|
+
| Lodash | Use lodash-es or native methods |
|
|
158
|
+
| Large icons library | Import only needed icons |
|
|
159
|
+
|
|
160
|
+
```javascript
|
|
161
|
+
// BAD: Import entire library
|
|
162
|
+
import _ from 'lodash';
|
|
163
|
+
import moment from 'moment';
|
|
164
|
+
|
|
165
|
+
// GOOD: Import only what you need
|
|
166
|
+
import debounce from 'lodash/debounce';
|
|
167
|
+
import { format, addDays } from 'date-fns';
|
|
168
|
+
|
|
169
|
+
// Or use lodash-es with tree shaking
|
|
170
|
+
import { debounce, throttle } from 'lodash-es';
|
|
171
|
+
```
|
|
172
|
+
|
|
173
|
+
### 5. Database & Query Optimization
|
|
174
|
+
|
|
175
|
+
**Query Optimization Patterns:**
|
|
176
|
+
|
|
177
|
+
```sql
|
|
178
|
+
-- BAD: Select all columns
|
|
179
|
+
SELECT * FROM users WHERE active = true;
|
|
180
|
+
|
|
181
|
+
-- GOOD: Select only needed columns
|
|
182
|
+
SELECT id, name, email FROM users WHERE active = true;
|
|
183
|
+
|
|
184
|
+
-- BAD: N+1 queries (in application loop)
|
|
185
|
+
-- 1 query for users, then N queries for each user's orders
|
|
186
|
+
|
|
187
|
+
-- GOOD: Single query with JOIN or batch fetch
|
|
188
|
+
SELECT u.*, o.id as order_id, o.total
|
|
189
|
+
FROM users u
|
|
190
|
+
LEFT JOIN orders o ON u.id = o.user_id
|
|
191
|
+
WHERE u.active = true;
|
|
192
|
+
|
|
193
|
+
-- Add index for frequently queried columns
|
|
194
|
+
CREATE INDEX idx_users_active ON users(active);
|
|
195
|
+
CREATE INDEX idx_orders_user_id ON orders(user_id);
|
|
196
|
+
```
|
|
197
|
+
|
|
198
|
+
**Database Performance Checklist:**
|
|
199
|
+
|
|
200
|
+
- [ ] Indexes on frequently queried columns
|
|
201
|
+
- [ ] Composite indexes for multi-column queries
|
|
202
|
+
- [ ] Avoid SELECT * in production code
|
|
203
|
+
- [ ] Use connection pooling
|
|
204
|
+
- [ ] Implement query result caching
|
|
205
|
+
- [ ] Use pagination for large result sets
|
|
206
|
+
- [ ] Monitor slow query logs
|
|
207
|
+
|
|
208
|
+
### 6. Network & API Optimization
|
|
209
|
+
|
|
210
|
+
**Network Optimization Strategies:**
|
|
211
|
+
|
|
212
|
+
```typescript
|
|
213
|
+
// BAD: Multiple sequential requests
|
|
214
|
+
const user = await fetchUser(id);
|
|
215
|
+
const posts = await fetchPosts(user.id);
|
|
216
|
+
const comments = await fetchComments(posts[0].id);
|
|
217
|
+
|
|
218
|
+
// GOOD: Parallel requests when independent
|
|
219
|
+
const [user, posts] = await Promise.all([
|
|
220
|
+
fetchUser(id),
|
|
221
|
+
fetchPosts(id)
|
|
222
|
+
]);
|
|
223
|
+
|
|
224
|
+
// GOOD: Batch requests when possible
|
|
225
|
+
const results = await batchFetch(['user1', 'user2', 'user3']);
|
|
226
|
+
|
|
227
|
+
// Implement request caching
|
|
228
|
+
const fetchWithCache = async (url: string, ttl = 300000) => {
|
|
229
|
+
const cached = cache.get(url);
|
|
230
|
+
if (cached) return cached;
|
|
231
|
+
|
|
232
|
+
const data = await fetch(url).then(r => r.json());
|
|
233
|
+
cache.set(url, data, ttl);
|
|
234
|
+
return data;
|
|
235
|
+
};
|
|
236
|
+
|
|
237
|
+
// Debounce rapid API calls
|
|
238
|
+
const debouncedSearch = debounce(async (query: string) => {
|
|
239
|
+
const results = await searchAPI(query);
|
|
240
|
+
setResults(results);
|
|
241
|
+
}, 300);
|
|
242
|
+
```
|
|
243
|
+
|
|
244
|
+
**Network Optimization Checklist:**
|
|
245
|
+
|
|
246
|
+
- [ ] Parallel independent requests with `Promise.all`
|
|
247
|
+
- [ ] Implement request caching
|
|
248
|
+
- [ ] Debounce rapid-fire requests
|
|
249
|
+
- [ ] Use streaming for large responses
|
|
250
|
+
- [ ] Implement pagination for large datasets
|
|
251
|
+
- [ ] Use GraphQL or API batching to reduce requests
|
|
252
|
+
- [ ] Enable compression (gzip/brotli) on server
|
|
253
|
+
|
|
254
|
+
### 7. Memory Leak Detection
|
|
255
|
+
|
|
256
|
+
**Common Memory Leak Patterns:**
|
|
257
|
+
|
|
258
|
+
```typescript
|
|
259
|
+
// BAD: Event listener without cleanup
|
|
260
|
+
useEffect(() => {
|
|
261
|
+
window.addEventListener('resize', handleResize);
|
|
262
|
+
// Missing cleanup!
|
|
263
|
+
}, []);
|
|
264
|
+
|
|
265
|
+
// GOOD: Clean up event listeners
|
|
266
|
+
useEffect(() => {
|
|
267
|
+
window.addEventListener('resize', handleResize);
|
|
268
|
+
return () => window.removeEventListener('resize', handleResize);
|
|
269
|
+
}, []);
|
|
270
|
+
|
|
271
|
+
// BAD: Timer without cleanup
|
|
272
|
+
useEffect(() => {
|
|
273
|
+
setInterval(() => pollData(), 1000);
|
|
274
|
+
// Missing cleanup!
|
|
275
|
+
}, []);
|
|
276
|
+
|
|
277
|
+
// GOOD: Clean up timers
|
|
278
|
+
useEffect(() => {
|
|
279
|
+
const interval = setInterval(() => pollData(), 1000);
|
|
280
|
+
return () => clearInterval(interval);
|
|
281
|
+
}, []);
|
|
282
|
+
|
|
283
|
+
// BAD: Holding references in closures
|
|
284
|
+
const Component = () => {
|
|
285
|
+
const largeData = useLargeData();
|
|
286
|
+
useEffect(() => {
|
|
287
|
+
eventEmitter.on('update', () => {
|
|
288
|
+
console.log(largeData); // Closure keeps reference
|
|
289
|
+
});
|
|
290
|
+
}, [largeData]);
|
|
291
|
+
};
|
|
292
|
+
|
|
293
|
+
// GOOD: Use refs or proper dependencies
|
|
294
|
+
const largeDataRef = useRef(largeData);
|
|
295
|
+
useEffect(() => {
|
|
296
|
+
largeDataRef.current = largeData;
|
|
297
|
+
}, [largeData]);
|
|
298
|
+
|
|
299
|
+
useEffect(() => {
|
|
300
|
+
const handleUpdate = () => {
|
|
301
|
+
console.log(largeDataRef.current);
|
|
302
|
+
};
|
|
303
|
+
eventEmitter.on('update', handleUpdate);
|
|
304
|
+
return () => eventEmitter.off('update', handleUpdate);
|
|
305
|
+
}, []);
|
|
306
|
+
```
|
|
307
|
+
|
|
308
|
+
**Memory Leak Detection:**
|
|
309
|
+
|
|
310
|
+
```bash
|
|
311
|
+
# Chrome DevTools Memory tab:
|
|
312
|
+
# 1. Take heap snapshot
|
|
313
|
+
# 2. Perform action
|
|
314
|
+
# 3. Take another snapshot
|
|
315
|
+
# 4. Compare to find objects that shouldn't exist
|
|
316
|
+
# 5. Look for detached DOM nodes, event listeners, closures
|
|
317
|
+
|
|
318
|
+
# Node.js memory debugging
|
|
319
|
+
node --inspect app.js
|
|
320
|
+
# Open chrome://inspect
|
|
321
|
+
# Take heap snapshots and compare
|
|
322
|
+
```
|
|
323
|
+
|
|
324
|
+
## Performance Testing
|
|
325
|
+
|
|
326
|
+
### Lighthouse Audits
|
|
327
|
+
|
|
328
|
+
```bash
|
|
329
|
+
# Run full lighthouse audit
|
|
330
|
+
npx lighthouse https://your-app.com --view --preset=desktop
|
|
331
|
+
|
|
332
|
+
# CI mode for automated checks
|
|
333
|
+
npx lighthouse https://your-app.com --output=json --output-path=./lighthouse.json
|
|
334
|
+
|
|
335
|
+
# Check specific metrics
|
|
336
|
+
npx lighthouse https://your-app.com --only-categories=performance
|
|
337
|
+
```
|
|
338
|
+
|
|
339
|
+
### Performance Budgets
|
|
340
|
+
|
|
341
|
+
```json
|
|
342
|
+
// package.json
|
|
343
|
+
{
|
|
344
|
+
"bundlesize": [
|
|
345
|
+
{
|
|
346
|
+
"path": "./build/static/js/*.js",
|
|
347
|
+
"maxSize": "200 kB"
|
|
348
|
+
}
|
|
349
|
+
]
|
|
350
|
+
}
|
|
351
|
+
```
|
|
352
|
+
|
|
353
|
+
### Web Vitals Monitoring
|
|
354
|
+
|
|
355
|
+
```typescript
|
|
356
|
+
// Track Core Web Vitals
|
|
357
|
+
import { getCLS, getFID, getLCP, getFCP, getTTFB } from 'web-vitals';
|
|
358
|
+
|
|
359
|
+
getCLS(console.log); // Cumulative Layout Shift
|
|
360
|
+
getFID(console.log); // First Input Delay
|
|
361
|
+
getLCP(console.log); // Largest Contentful Paint
|
|
362
|
+
getFCP(console.log); // First Contentful Paint
|
|
363
|
+
getTTFB(console.log); // Time to First Byte
|
|
364
|
+
```
|
|
365
|
+
|
|
366
|
+
## Performance Report Template
|
|
367
|
+
|
|
368
|
+
````markdown
|
|
369
|
+
# Performance Audit Report
|
|
370
|
+
|
|
371
|
+
## Executive Summary
|
|
372
|
+
- **Overall Score**: X/100
|
|
373
|
+
- **Critical Issues**: X
|
|
374
|
+
- **Recommendations**: X
|
|
375
|
+
|
|
376
|
+
## Bundle Analysis
|
|
377
|
+
| Metric | Current | Target | Status |
|
|
378
|
+
|--------|---------|--------|--------|
|
|
379
|
+
| Total Size (gzip) | XXX KB | < 200 KB | WARNING: |
|
|
380
|
+
| Main Bundle | XXX KB | < 100 KB | PASS: |
|
|
381
|
+
| Vendor Bundle | XXX KB | < 150 KB | WARNING: |
|
|
382
|
+
|
|
383
|
+
## Web Vitals
|
|
384
|
+
| Metric | Current | Target | Status |
|
|
385
|
+
|--------|---------|--------|--------|
|
|
386
|
+
| LCP | X.Xs | < 2.5s | PASS: |
|
|
387
|
+
| FID | XXms | < 100ms | PASS: |
|
|
388
|
+
| CLS | X.XX | < 0.1 | WARNING: |
|
|
389
|
+
|
|
390
|
+
## Critical Issues
|
|
391
|
+
|
|
392
|
+
### 1. [Issue Title]
|
|
393
|
+
**File**: path/to/file.ts:42
|
|
394
|
+
**Impact**: High - Causes XXXms delay
|
|
395
|
+
**Fix**: [Description of fix]
|
|
396
|
+
|
|
397
|
+
```typescript
|
|
398
|
+
// Before (slow)
|
|
399
|
+
const slowCode = ...;
|
|
400
|
+
|
|
401
|
+
// After (optimized)
|
|
402
|
+
const fastCode = ...;
|
|
403
|
+
```
|
|
404
|
+
|
|
405
|
+
### 2. [Issue Title]
|
|
406
|
+
...
|
|
407
|
+
|
|
408
|
+
## Recommendations
|
|
409
|
+
1. [Priority recommendation]
|
|
410
|
+
2. [Priority recommendation]
|
|
411
|
+
3. [Priority recommendation]
|
|
412
|
+
|
|
413
|
+
## Estimated Impact
|
|
414
|
+
- Bundle size reduction: XX KB (XX%)
|
|
415
|
+
- LCP improvement: XXms
|
|
416
|
+
- Time to Interactive improvement: XXms
|
|
417
|
+
````
|
|
418
|
+
|
|
419
|
+
## When to Run
|
|
420
|
+
|
|
421
|
+
**ALWAYS:** Before major releases, after adding new features, when users report slowness, during performance regression testing.
|
|
422
|
+
|
|
423
|
+
**IMMEDIATELY:** Lighthouse score drops, bundle size increases >10%, memory usage grows, slow page loads.
|
|
424
|
+
|
|
425
|
+
## Red Flags - Act Immediately
|
|
426
|
+
|
|
427
|
+
| Issue | Action |
|
|
428
|
+
|-------|--------|
|
|
429
|
+
| Bundle > 500KB gzip | Code split, lazy load, tree shake |
|
|
430
|
+
| LCP > 4s | Optimize critical path, preload resources |
|
|
431
|
+
| Memory usage growing | Check for leaks, review useEffect cleanup |
|
|
432
|
+
| CPU spikes | Profile with Chrome DevTools |
|
|
433
|
+
| Database query > 1s | Add index, optimize query, cache results |
|
|
434
|
+
|
|
435
|
+
## Success Metrics
|
|
436
|
+
|
|
437
|
+
- Lighthouse performance score > 90
|
|
438
|
+
- All Core Web Vitals in "good" range
|
|
439
|
+
- Bundle size under budget
|
|
440
|
+
- No memory leaks detected
|
|
441
|
+
- Test suite still passing
|
|
442
|
+
- No performance regressions
|
|
443
|
+
|
|
444
|
+
---
|
|
445
|
+
|
|
446
|
+
**Remember**: Performance is a feature. Users notice speed. Every 100ms of improvement matters. Optimize for the 90th percentile, not the average.
|