aw-ecc 1.4.21
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/.agents/skills/api-design/SKILL.md +523 -0
- package/.agents/skills/api-design/agents/openai.yaml +7 -0
- package/.agents/skills/article-writing/SKILL.md +85 -0
- package/.agents/skills/article-writing/agents/openai.yaml +7 -0
- package/.agents/skills/backend-patterns/SKILL.md +598 -0
- package/.agents/skills/backend-patterns/agents/openai.yaml +7 -0
- package/.agents/skills/bun-runtime/SKILL.md +84 -0
- package/.agents/skills/bun-runtime/agents/openai.yaml +7 -0
- package/.agents/skills/claude-api/SKILL.md +337 -0
- package/.agents/skills/claude-api/agents/openai.yaml +7 -0
- package/.agents/skills/coding-standards/SKILL.md +530 -0
- package/.agents/skills/coding-standards/agents/openai.yaml +7 -0
- package/.agents/skills/content-engine/SKILL.md +88 -0
- package/.agents/skills/content-engine/agents/openai.yaml +7 -0
- package/.agents/skills/crosspost/SKILL.md +188 -0
- package/.agents/skills/crosspost/agents/openai.yaml +7 -0
- package/.agents/skills/deep-research/SKILL.md +155 -0
- package/.agents/skills/deep-research/agents/openai.yaml +7 -0
- package/.agents/skills/dmux-workflows/SKILL.md +144 -0
- package/.agents/skills/dmux-workflows/agents/openai.yaml +7 -0
- package/.agents/skills/documentation-lookup/SKILL.md +90 -0
- package/.agents/skills/documentation-lookup/agents/openai.yaml +7 -0
- package/.agents/skills/e2e-testing/SKILL.md +326 -0
- package/.agents/skills/e2e-testing/agents/openai.yaml +7 -0
- package/.agents/skills/eval-harness/SKILL.md +236 -0
- package/.agents/skills/eval-harness/agents/openai.yaml +7 -0
- package/.agents/skills/everything-claude-code/SKILL.md +442 -0
- package/.agents/skills/everything-claude-code/agents/openai.yaml +6 -0
- package/.agents/skills/exa-search/SKILL.md +170 -0
- package/.agents/skills/exa-search/agents/openai.yaml +7 -0
- package/.agents/skills/fal-ai-media/SKILL.md +277 -0
- package/.agents/skills/fal-ai-media/agents/openai.yaml +7 -0
- package/.agents/skills/frontend-patterns/SKILL.md +642 -0
- package/.agents/skills/frontend-patterns/agents/openai.yaml +7 -0
- package/.agents/skills/frontend-slides/SKILL.md +184 -0
- package/.agents/skills/frontend-slides/STYLE_PRESETS.md +330 -0
- package/.agents/skills/frontend-slides/agents/openai.yaml +7 -0
- package/.agents/skills/investor-materials/SKILL.md +96 -0
- package/.agents/skills/investor-materials/agents/openai.yaml +7 -0
- package/.agents/skills/investor-outreach/SKILL.md +76 -0
- package/.agents/skills/investor-outreach/agents/openai.yaml +7 -0
- package/.agents/skills/market-research/SKILL.md +75 -0
- package/.agents/skills/market-research/agents/openai.yaml +7 -0
- package/.agents/skills/mcp-server-patterns/SKILL.md +67 -0
- package/.agents/skills/nextjs-turbopack/SKILL.md +44 -0
- package/.agents/skills/nextjs-turbopack/agents/openai.yaml +7 -0
- package/.agents/skills/security-review/SKILL.md +495 -0
- package/.agents/skills/security-review/agents/openai.yaml +7 -0
- package/.agents/skills/strategic-compact/SKILL.md +103 -0
- package/.agents/skills/strategic-compact/agents/openai.yaml +7 -0
- package/.agents/skills/tdd-workflow/SKILL.md +410 -0
- package/.agents/skills/tdd-workflow/agents/openai.yaml +7 -0
- package/.agents/skills/verification-loop/SKILL.md +126 -0
- package/.agents/skills/verification-loop/agents/openai.yaml +7 -0
- package/.agents/skills/video-editing/SKILL.md +308 -0
- package/.agents/skills/video-editing/agents/openai.yaml +7 -0
- package/.agents/skills/x-api/SKILL.md +214 -0
- package/.agents/skills/x-api/agents/openai.yaml +7 -0
- package/.claude-plugin/README.md +17 -0
- package/.claude-plugin/plugin.json +24 -0
- package/.codex/AGENTS.md +93 -0
- package/.codex/INSTALL.md +64 -0
- package/.codex/agents/docs-researcher.toml +9 -0
- package/.codex/agents/explorer.toml +9 -0
- package/.codex/agents/reviewer.toml +9 -0
- package/.codex/config.toml +108 -0
- package/.codex/hooks/aw-post-tool-use.sh +5 -0
- package/.codex/hooks/aw-pre-tool-use.sh +5 -0
- package/.codex/hooks/aw-session-start.sh +21 -0
- package/.codex/hooks/aw-stop.sh +5 -0
- package/.codex/hooks/aw-user-prompt-submit.sh +9 -0
- package/.codex/hooks.json +62 -0
- package/.cursor/INSTALL.md +40 -0
- package/.cursor/hooks/adapter.js +120 -0
- package/.cursor/hooks/after-file-edit.js +11 -0
- package/.cursor/hooks/after-mcp-execution.js +11 -0
- package/.cursor/hooks/after-shell-execution.js +11 -0
- package/.cursor/hooks/after-tab-file-edit.js +12 -0
- package/.cursor/hooks/aw-phase-adapter.js +43 -0
- package/.cursor/hooks/before-mcp-execution.js +11 -0
- package/.cursor/hooks/before-read-file.js +13 -0
- package/.cursor/hooks/before-shell-execution.js +11 -0
- package/.cursor/hooks/before-submit-prompt.js +41 -0
- package/.cursor/hooks/before-tab-file-read.js +13 -0
- package/.cursor/hooks/pre-compact.js +11 -0
- package/.cursor/hooks/session-end.js +11 -0
- package/.cursor/hooks/session-start.js +11 -0
- package/.cursor/hooks/shared/aw-phase-definitions.js +190 -0
- package/.cursor/hooks/shared/aw-phase-runner.js +61 -0
- package/.cursor/hooks/shared/session-start.sh +20 -0
- package/.cursor/hooks/shared/user-prompt-submit.sh +155 -0
- package/.cursor/hooks/stop.js +11 -0
- package/.cursor/hooks/subagent-start.js +10 -0
- package/.cursor/hooks/subagent-stop.js +10 -0
- package/.cursor/hooks.json +115 -0
- package/.cursor/rules/common-agents.md +53 -0
- package/.cursor/rules/common-coding-style.md +52 -0
- package/.cursor/rules/common-development-workflow.md +33 -0
- package/.cursor/rules/common-git-workflow.md +28 -0
- package/.cursor/rules/common-hooks.md +34 -0
- package/.cursor/rules/common-patterns.md +35 -0
- package/.cursor/rules/common-performance.md +59 -0
- package/.cursor/rules/common-security.md +33 -0
- package/.cursor/rules/common-testing.md +33 -0
- package/.cursor/rules/golang-coding-style.md +31 -0
- package/.cursor/rules/golang-hooks.md +16 -0
- package/.cursor/rules/golang-patterns.md +44 -0
- package/.cursor/rules/golang-security.md +33 -0
- package/.cursor/rules/golang-testing.md +30 -0
- package/.cursor/rules/kotlin-coding-style.md +39 -0
- package/.cursor/rules/kotlin-hooks.md +16 -0
- package/.cursor/rules/kotlin-patterns.md +50 -0
- package/.cursor/rules/kotlin-security.md +58 -0
- package/.cursor/rules/kotlin-testing.md +38 -0
- package/.cursor/rules/php-coding-style.md +25 -0
- package/.cursor/rules/php-hooks.md +21 -0
- package/.cursor/rules/php-patterns.md +23 -0
- package/.cursor/rules/php-security.md +24 -0
- package/.cursor/rules/php-testing.md +26 -0
- package/.cursor/rules/python-coding-style.md +42 -0
- package/.cursor/rules/python-hooks.md +19 -0
- package/.cursor/rules/python-patterns.md +39 -0
- package/.cursor/rules/python-security.md +30 -0
- package/.cursor/rules/python-testing.md +38 -0
- package/.cursor/rules/swift-coding-style.md +47 -0
- package/.cursor/rules/swift-hooks.md +20 -0
- package/.cursor/rules/swift-patterns.md +66 -0
- package/.cursor/rules/swift-security.md +33 -0
- package/.cursor/rules/swift-testing.md +45 -0
- package/.cursor/rules/typescript-coding-style.md +63 -0
- package/.cursor/rules/typescript-hooks.md +20 -0
- package/.cursor/rules/typescript-patterns.md +50 -0
- package/.cursor/rules/typescript-security.md +26 -0
- package/.cursor/rules/typescript-testing.md +16 -0
- package/.cursor/skills/article-writing/SKILL.md +85 -0
- package/.cursor/skills/bun-runtime/SKILL.md +84 -0
- package/.cursor/skills/content-engine/SKILL.md +88 -0
- package/.cursor/skills/documentation-lookup/SKILL.md +90 -0
- package/.cursor/skills/frontend-slides/SKILL.md +184 -0
- package/.cursor/skills/frontend-slides/STYLE_PRESETS.md +330 -0
- package/.cursor/skills/investor-materials/SKILL.md +96 -0
- package/.cursor/skills/investor-outreach/SKILL.md +76 -0
- package/.cursor/skills/market-research/SKILL.md +75 -0
- package/.cursor/skills/mcp-server-patterns/SKILL.md +67 -0
- package/.cursor/skills/nextjs-turbopack/SKILL.md +44 -0
- package/.opencode/MIGRATION.md +368 -0
- package/.opencode/README.md +204 -0
- package/.opencode/commands/build-fix.md +56 -0
- package/.opencode/commands/checkpoint.md +67 -0
- package/.opencode/commands/code-review.md +68 -0
- package/.opencode/commands/e2e.md +105 -0
- package/.opencode/commands/eval.md +88 -0
- package/.opencode/commands/evolve.md +36 -0
- package/.opencode/commands/go-build.md +87 -0
- package/.opencode/commands/go-review.md +71 -0
- package/.opencode/commands/go-test.md +131 -0
- package/.opencode/commands/harness-audit.md +71 -0
- package/.opencode/commands/instinct-export.md +93 -0
- package/.opencode/commands/instinct-import.md +88 -0
- package/.opencode/commands/instinct-status.md +29 -0
- package/.opencode/commands/learn.md +61 -0
- package/.opencode/commands/loop-start.md +32 -0
- package/.opencode/commands/loop-status.md +24 -0
- package/.opencode/commands/model-route.md +26 -0
- package/.opencode/commands/orchestrate.md +88 -0
- package/.opencode/commands/plan.md +49 -0
- package/.opencode/commands/projects.md +23 -0
- package/.opencode/commands/promote.md +23 -0
- package/.opencode/commands/quality-gate.md +29 -0
- package/.opencode/commands/refactor-clean.md +102 -0
- package/.opencode/commands/rust-build.md +78 -0
- package/.opencode/commands/rust-review.md +65 -0
- package/.opencode/commands/rust-test.md +104 -0
- package/.opencode/commands/security.md +89 -0
- package/.opencode/commands/setup-pm.md +67 -0
- package/.opencode/commands/skill-create.md +117 -0
- package/.opencode/commands/tdd.md +66 -0
- package/.opencode/commands/test-coverage.md +80 -0
- package/.opencode/commands/update-codemaps.md +81 -0
- package/.opencode/commands/update-docs.md +67 -0
- package/.opencode/commands/verify.md +67 -0
- package/.opencode/index.ts +79 -0
- package/.opencode/instructions/INSTRUCTIONS.md +337 -0
- package/.opencode/opencode.json +319 -0
- package/.opencode/package.json +70 -0
- package/.opencode/plugins/ecc-hooks.ts +455 -0
- package/.opencode/plugins/index.ts +12 -0
- package/.opencode/prompts/agents/architect.txt +175 -0
- package/.opencode/prompts/agents/build-error-resolver.txt +233 -0
- package/.opencode/prompts/agents/code-reviewer.txt +103 -0
- package/.opencode/prompts/agents/database-reviewer.txt +247 -0
- package/.opencode/prompts/agents/doc-updater.txt +192 -0
- package/.opencode/prompts/agents/e2e-runner.txt +305 -0
- package/.opencode/prompts/agents/go-build-resolver.txt +325 -0
- package/.opencode/prompts/agents/go-reviewer.txt +241 -0
- package/.opencode/prompts/agents/planner.txt +112 -0
- package/.opencode/prompts/agents/refactor-cleaner.txt +241 -0
- package/.opencode/prompts/agents/rust-build-resolver.txt +93 -0
- package/.opencode/prompts/agents/rust-reviewer.txt +61 -0
- package/.opencode/prompts/agents/security-reviewer.txt +207 -0
- package/.opencode/prompts/agents/tdd-guide.txt +211 -0
- package/.opencode/tools/check-coverage.ts +170 -0
- package/.opencode/tools/format-code.ts +68 -0
- package/.opencode/tools/git-summary.ts +54 -0
- package/.opencode/tools/index.ts +13 -0
- package/.opencode/tools/lint-check.ts +85 -0
- package/.opencode/tools/run-tests.ts +139 -0
- package/.opencode/tools/security-audit.ts +277 -0
- package/.opencode/tsconfig.json +29 -0
- package/AGENTS.md +124 -0
- package/LICENSE +21 -0
- package/README.md +146 -0
- package/README.zh-CN.md +552 -0
- package/agents/architect.md +211 -0
- package/agents/build-error-resolver.md +114 -0
- package/agents/chief-of-staff.md +151 -0
- package/agents/code-reviewer.md +237 -0
- package/agents/cpp-build-resolver.md +90 -0
- package/agents/cpp-reviewer.md +72 -0
- package/agents/database-reviewer.md +91 -0
- package/agents/doc-updater.md +107 -0
- package/agents/docs-lookup.md +68 -0
- package/agents/e2e-runner.md +107 -0
- package/agents/evals/code-reviewer-scenarios.json +23 -0
- package/agents/flutter-reviewer.md +243 -0
- package/agents/go-build-resolver.md +94 -0
- package/agents/go-reviewer.md +76 -0
- package/agents/harness-optimizer.md +35 -0
- package/agents/java-build-resolver.md +153 -0
- package/agents/java-reviewer.md +92 -0
- package/agents/kotlin-build-resolver.md +118 -0
- package/agents/kotlin-reviewer.md +159 -0
- package/agents/loop-operator.md +36 -0
- package/agents/planner.md +212 -0
- package/agents/python-reviewer.md +98 -0
- package/agents/pytorch-build-resolver.md +120 -0
- package/agents/refactor-cleaner.md +85 -0
- package/agents/rust-build-resolver.md +148 -0
- package/agents/rust-reviewer.md +94 -0
- package/agents/security-reviewer.md +108 -0
- package/agents/tdd-guide.md +91 -0
- package/agents/typescript-reviewer.md +112 -0
- package/commands/aside.md +164 -0
- package/commands/brainstorm.md +16 -0
- package/commands/build-fix.md +70 -0
- package/commands/build.md +91 -0
- package/commands/checkpoint.md +74 -0
- package/commands/claw.md +51 -0
- package/commands/code-review.md +24 -0
- package/commands/context-budget.md +29 -0
- package/commands/cpp-build.md +174 -0
- package/commands/cpp-review.md +132 -0
- package/commands/cpp-test.md +252 -0
- package/commands/deploy.md +75 -0
- package/commands/devfleet.md +92 -0
- package/commands/docs.md +31 -0
- package/commands/e2e.md +373 -0
- package/commands/eval.md +120 -0
- package/commands/evolve.md +178 -0
- package/commands/execute.md +51 -0
- package/commands/finish.md +22 -0
- package/commands/go-build.md +184 -0
- package/commands/go-review.md +148 -0
- package/commands/go-test.md +269 -0
- package/commands/gradle-build.md +70 -0
- package/commands/harness-audit.md +71 -0
- package/commands/instinct-export.md +66 -0
- package/commands/instinct-import.md +114 -0
- package/commands/instinct-status.md +59 -0
- package/commands/investigate.md +63 -0
- package/commands/kotlin-build.md +175 -0
- package/commands/kotlin-review.md +140 -0
- package/commands/kotlin-test.md +313 -0
- package/commands/learn-eval.md +116 -0
- package/commands/learn.md +70 -0
- package/commands/loop-start.md +32 -0
- package/commands/loop-status.md +24 -0
- package/commands/model-route.md +26 -0
- package/commands/multi-backend.md +166 -0
- package/commands/multi-execute.md +324 -0
- package/commands/multi-frontend.md +165 -0
- package/commands/multi-plan.md +277 -0
- package/commands/multi-workflow.md +200 -0
- package/commands/orchestrate.md +240 -0
- package/commands/plan.md +130 -0
- package/commands/pm2.md +272 -0
- package/commands/projects.md +39 -0
- package/commands/promote.md +41 -0
- package/commands/prompt-optimize.md +38 -0
- package/commands/prune.md +31 -0
- package/commands/python-review.md +297 -0
- package/commands/quality-gate.md +29 -0
- package/commands/refactor-clean.md +89 -0
- package/commands/resume-session.md +155 -0
- package/commands/review.md +64 -0
- package/commands/rules-distill.md +11 -0
- package/commands/rust-build.md +188 -0
- package/commands/rust-review.md +142 -0
- package/commands/rust-test.md +309 -0
- package/commands/save-session.md +275 -0
- package/commands/sessions.md +333 -0
- package/commands/setup-pm.md +80 -0
- package/commands/ship.md +77 -0
- package/commands/skill-create.md +174 -0
- package/commands/skill-health.md +54 -0
- package/commands/tdd.md +20 -0
- package/commands/test-coverage.md +77 -0
- package/commands/test.md +64 -0
- package/commands/update-codemaps.md +72 -0
- package/commands/update-docs.md +84 -0
- package/commands/verify.md +55 -0
- package/contexts/dev.md +20 -0
- package/contexts/research.md +26 -0
- package/contexts/review.md +22 -0
- package/examples/CLAUDE.md +100 -0
- package/examples/statusline.json +19 -0
- package/examples/user-CLAUDE.md +109 -0
- package/hooks/README.md +219 -0
- package/hooks/hooks.json +320 -0
- package/hooks/run-hook.cmd +31 -0
- package/hooks/session-start +6 -0
- package/install.ps1 +38 -0
- package/install.sh +17 -0
- package/manifests/install-components.json +415 -0
- package/manifests/install-modules.json +500 -0
- package/manifests/install-profiles.json +80 -0
- package/mcp-configs/mcp-servers.json +153 -0
- package/package.json +131 -0
- package/plugins/README.md +85 -0
- package/rules/README.md +106 -0
- package/rules/common/agents.md +50 -0
- package/rules/common/coding-style.md +48 -0
- package/rules/common/development-workflow.md +38 -0
- package/rules/common/git-workflow.md +24 -0
- package/rules/common/hooks.md +30 -0
- package/rules/common/patterns.md +31 -0
- package/rules/common/performance.md +55 -0
- package/rules/common/security.md +29 -0
- package/rules/common/testing.md +29 -0
- package/rules/cpp/coding-style.md +44 -0
- package/rules/cpp/hooks.md +39 -0
- package/rules/cpp/patterns.md +51 -0
- package/rules/cpp/security.md +51 -0
- package/rules/cpp/testing.md +44 -0
- package/rules/csharp/coding-style.md +72 -0
- package/rules/csharp/hooks.md +25 -0
- package/rules/csharp/patterns.md +50 -0
- package/rules/csharp/security.md +58 -0
- package/rules/csharp/testing.md +46 -0
- package/rules/golang/coding-style.md +32 -0
- package/rules/golang/hooks.md +17 -0
- package/rules/golang/patterns.md +45 -0
- package/rules/golang/security.md +34 -0
- package/rules/golang/testing.md +31 -0
- package/rules/java/coding-style.md +114 -0
- package/rules/java/hooks.md +18 -0
- package/rules/java/patterns.md +146 -0
- package/rules/java/security.md +100 -0
- package/rules/java/testing.md +131 -0
- package/rules/kotlin/coding-style.md +86 -0
- package/rules/kotlin/hooks.md +17 -0
- package/rules/kotlin/patterns.md +146 -0
- package/rules/kotlin/security.md +82 -0
- package/rules/kotlin/testing.md +128 -0
- package/rules/perl/coding-style.md +46 -0
- package/rules/perl/hooks.md +22 -0
- package/rules/perl/patterns.md +76 -0
- package/rules/perl/security.md +69 -0
- package/rules/perl/testing.md +54 -0
- package/rules/php/coding-style.md +40 -0
- package/rules/php/hooks.md +24 -0
- package/rules/php/patterns.md +33 -0
- package/rules/php/security.md +37 -0
- package/rules/php/testing.md +39 -0
- package/rules/python/coding-style.md +42 -0
- package/rules/python/hooks.md +19 -0
- package/rules/python/patterns.md +39 -0
- package/rules/python/security.md +30 -0
- package/rules/python/testing.md +38 -0
- package/rules/rust/coding-style.md +151 -0
- package/rules/rust/hooks.md +16 -0
- package/rules/rust/patterns.md +168 -0
- package/rules/rust/security.md +141 -0
- package/rules/rust/testing.md +154 -0
- package/rules/swift/coding-style.md +47 -0
- package/rules/swift/hooks.md +20 -0
- package/rules/swift/patterns.md +66 -0
- package/rules/swift/security.md +33 -0
- package/rules/swift/testing.md +45 -0
- package/rules/typescript/coding-style.md +199 -0
- package/rules/typescript/hooks.md +22 -0
- package/rules/typescript/patterns.md +52 -0
- package/rules/typescript/security.md +28 -0
- package/rules/typescript/testing.md +18 -0
- package/schemas/ecc-install-config.schema.json +58 -0
- package/schemas/hooks.schema.json +197 -0
- package/schemas/install-components.schema.json +58 -0
- package/schemas/install-modules.schema.json +105 -0
- package/schemas/install-profiles.schema.json +45 -0
- package/schemas/install-state.schema.json +210 -0
- package/schemas/package-manager.schema.json +23 -0
- package/schemas/plugin.schema.json +58 -0
- package/schemas/provenance.schema.json +31 -0
- package/schemas/state-store.schema.json +316 -0
- package/scripts/ci/catalog.js +245 -0
- package/scripts/ci/validate-agents.js +81 -0
- package/scripts/ci/validate-commands.js +136 -0
- package/scripts/ci/validate-hooks.js +239 -0
- package/scripts/ci/validate-install-manifests.js +214 -0
- package/scripts/ci/validate-no-personal-paths.js +63 -0
- package/scripts/ci/validate-rules.js +81 -0
- package/scripts/ci/validate-skills.js +56 -0
- package/scripts/claw.js +473 -0
- package/scripts/codex/merge-mcp-config.js +304 -0
- package/scripts/cursor-aw-home/hooks.json +115 -0
- package/scripts/cursor-aw-hooks/adapter.js +120 -0
- package/scripts/cursor-aw-hooks/after-file-edit.js +11 -0
- package/scripts/cursor-aw-hooks/after-mcp-execution.js +11 -0
- package/scripts/cursor-aw-hooks/after-shell-execution.js +11 -0
- package/scripts/cursor-aw-hooks/aw-phase-adapter.js +43 -0
- package/scripts/cursor-aw-hooks/before-mcp-execution.js +11 -0
- package/scripts/cursor-aw-hooks/before-shell-execution.js +11 -0
- package/scripts/cursor-aw-hooks/before-submit-prompt.js +41 -0
- package/scripts/cursor-aw-hooks/pre-compact.js +11 -0
- package/scripts/cursor-aw-hooks/session-end.js +11 -0
- package/scripts/cursor-aw-hooks/session-start.js +11 -0
- package/scripts/cursor-aw-hooks/stop.js +11 -0
- package/scripts/doctor.js +110 -0
- package/scripts/ecc.js +208 -0
- package/scripts/generate-aw-hooks.js +110 -0
- package/scripts/harness-audit.js +512 -0
- package/scripts/hooks/auto-tmux-dev.js +88 -0
- package/scripts/hooks/check-console-log.js +71 -0
- package/scripts/hooks/check-hook-enabled.js +12 -0
- package/scripts/hooks/config-protection.js +125 -0
- package/scripts/hooks/cost-tracker.js +78 -0
- package/scripts/hooks/doc-file-warning.js +63 -0
- package/scripts/hooks/evaluate-session.js +100 -0
- package/scripts/hooks/governance-capture.js +280 -0
- package/scripts/hooks/insaits-security-monitor.py +269 -0
- package/scripts/hooks/insaits-security-wrapper.js +88 -0
- package/scripts/hooks/mcp-health-check.js +588 -0
- package/scripts/hooks/post-bash-build-complete.js +27 -0
- package/scripts/hooks/post-bash-pr-created.js +37 -0
- package/scripts/hooks/post-edit-console-warn.js +54 -0
- package/scripts/hooks/post-edit-format.js +109 -0
- package/scripts/hooks/post-edit-typecheck.js +96 -0
- package/scripts/hooks/post-mcp-log.js +27 -0
- package/scripts/hooks/pre-bash-dev-server-block.js +187 -0
- package/scripts/hooks/pre-bash-git-push-reminder.js +28 -0
- package/scripts/hooks/pre-bash-tmux-reminder.js +33 -0
- package/scripts/hooks/pre-compact.js +48 -0
- package/scripts/hooks/pre-mcp-log.js +26 -0
- package/scripts/hooks/pre-write-doc-warn.js +9 -0
- package/scripts/hooks/quality-gate.js +168 -0
- package/scripts/hooks/run-with-flags-shell.sh +32 -0
- package/scripts/hooks/run-with-flags.js +120 -0
- package/scripts/hooks/session-end-marker.js +29 -0
- package/scripts/hooks/session-end.js +301 -0
- package/scripts/hooks/session-start-rules-context.sh +5 -0
- package/scripts/hooks/session-start.js +98 -0
- package/scripts/hooks/shared/aw-phase-definitions.js +190 -0
- package/scripts/hooks/shared/aw-phase-runner.js +61 -0
- package/scripts/hooks/shared/session-start.sh +20 -0
- package/scripts/hooks/shared/user-prompt-submit.sh +155 -0
- package/scripts/hooks/suggest-compact.js +80 -0
- package/scripts/install-apply.js +140 -0
- package/scripts/install-plan.js +254 -0
- package/scripts/lib/agent-compress.js +244 -0
- package/scripts/lib/aw-harness-registry.js +122 -0
- package/scripts/lib/aw-hook-contract.js +86 -0
- package/scripts/lib/claude-aw-hook-files.js +28 -0
- package/scripts/lib/claude-hook-config.js +76 -0
- package/scripts/lib/codex-aw-hook-files.js +38 -0
- package/scripts/lib/codex-hook-config.js +88 -0
- package/scripts/lib/cursor-aw-hook-files.js +62 -0
- package/scripts/lib/cursor-hook-config.js +148 -0
- package/scripts/lib/hook-flags.js +74 -0
- package/scripts/lib/inspection.js +212 -0
- package/scripts/lib/install/apply.js +23 -0
- package/scripts/lib/install/config.js +82 -0
- package/scripts/lib/install/request.js +120 -0
- package/scripts/lib/install/runtime.js +54 -0
- package/scripts/lib/install-executor.js +778 -0
- package/scripts/lib/install-lifecycle.js +1311 -0
- package/scripts/lib/install-manifests.js +448 -0
- package/scripts/lib/install-state.js +313 -0
- package/scripts/lib/install-targets/antigravity-project.js +69 -0
- package/scripts/lib/install-targets/claude-home.js +54 -0
- package/scripts/lib/install-targets/codex-home.js +62 -0
- package/scripts/lib/install-targets/cursor-project.js +80 -0
- package/scripts/lib/install-targets/helpers.js +307 -0
- package/scripts/lib/install-targets/opencode-home.js +10 -0
- package/scripts/lib/install-targets/registry.js +66 -0
- package/scripts/lib/orchestration-session.js +299 -0
- package/scripts/lib/package-manager.d.ts +119 -0
- package/scripts/lib/package-manager.js +431 -0
- package/scripts/lib/project-detect.js +428 -0
- package/scripts/lib/resolve-ecc-root.js +89 -0
- package/scripts/lib/resolve-formatter.js +185 -0
- package/scripts/lib/session-adapters/canonical-session.js +531 -0
- package/scripts/lib/session-adapters/claude-history.js +160 -0
- package/scripts/lib/session-adapters/dmux-tmux.js +90 -0
- package/scripts/lib/session-adapters/registry.js +127 -0
- package/scripts/lib/session-aliases.d.ts +136 -0
- package/scripts/lib/session-aliases.js +481 -0
- package/scripts/lib/session-manager.d.ts +131 -0
- package/scripts/lib/session-manager.js +464 -0
- package/scripts/lib/shell-split.js +86 -0
- package/scripts/lib/skill-evolution/dashboard.js +401 -0
- package/scripts/lib/skill-evolution/health.js +263 -0
- package/scripts/lib/skill-evolution/index.js +20 -0
- package/scripts/lib/skill-evolution/provenance.js +187 -0
- package/scripts/lib/skill-evolution/tracker.js +146 -0
- package/scripts/lib/skill-evolution/versioning.js +237 -0
- package/scripts/lib/skill-improvement/amendify.js +89 -0
- package/scripts/lib/skill-improvement/evaluate.js +59 -0
- package/scripts/lib/skill-improvement/health.js +118 -0
- package/scripts/lib/skill-improvement/observations.js +108 -0
- package/scripts/lib/state-store/index.js +191 -0
- package/scripts/lib/state-store/migrations.js +178 -0
- package/scripts/lib/state-store/queries.js +697 -0
- package/scripts/lib/state-store/schema.js +92 -0
- package/scripts/lib/tmux-worktree-orchestrator.js +475 -0
- package/scripts/lib/utils.d.ts +183 -0
- package/scripts/lib/utils.js +564 -0
- package/scripts/list-installed.js +90 -0
- package/scripts/orchestrate-codex-worker.sh +107 -0
- package/scripts/orchestrate-worktrees.js +40 -0
- package/scripts/orchestration-status.js +82 -0
- package/scripts/repair.js +97 -0
- package/scripts/session-inspect.js +150 -0
- package/scripts/sessions-cli.js +177 -0
- package/scripts/setup-package-manager.js +204 -0
- package/scripts/skill-create-output.js +244 -0
- package/scripts/status.js +176 -0
- package/scripts/uninstall.js +96 -0
- package/skills/agent-eval/SKILL.md +145 -0
- package/skills/agent-harness-construction/SKILL.md +73 -0
- package/skills/agentic-engineering/SKILL.md +63 -0
- package/skills/ai-first-engineering/SKILL.md +51 -0
- package/skills/ai-regression-testing/SKILL.md +385 -0
- package/skills/android-clean-architecture/SKILL.md +339 -0
- package/skills/api-and-interface-design/SKILL.md +75 -0
- package/skills/api-design/SKILL.md +523 -0
- package/skills/architecture-decision-records/SKILL.md +179 -0
- package/skills/article-writing/SKILL.md +85 -0
- package/skills/autonomous-loops/SKILL.md +610 -0
- package/skills/aw-brainstorm/SKILL.md +115 -0
- package/skills/aw-build/SKILL.md +189 -0
- package/skills/aw-build/evals/build-stage-cases.json +28 -0
- package/skills/aw-debug/SKILL.md +49 -0
- package/skills/aw-deploy/SKILL.md +101 -0
- package/skills/aw-deploy/evals/deploy-stage-cases.json +32 -0
- package/skills/aw-execute/SKILL.md +47 -0
- package/skills/aw-execute/references/mode-code.md +47 -0
- package/skills/aw-execute/references/mode-docs.md +28 -0
- package/skills/aw-execute/references/mode-infra.md +44 -0
- package/skills/aw-execute/references/mode-migration.md +58 -0
- package/skills/aw-execute/references/worker-implementer.md +26 -0
- package/skills/aw-execute/references/worker-parallel-worker.md +23 -0
- package/skills/aw-execute/references/worker-quality-reviewer.md +23 -0
- package/skills/aw-execute/references/worker-spec-reviewer.md +23 -0
- package/skills/aw-execute/scripts/build-worker-bundle.js +229 -0
- package/skills/aw-finish/SKILL.md +111 -0
- package/skills/aw-investigate/SKILL.md +109 -0
- package/skills/aw-plan/SKILL.md +399 -0
- package/skills/aw-prepare/SKILL.md +118 -0
- package/skills/aw-review/SKILL.md +123 -0
- package/skills/aw-rules/SKILL.md +129 -0
- package/skills/aw-rules/references/known-hallucinations.md +43 -0
- package/skills/aw-rules/references/verification-sources.md +50 -0
- package/skills/aw-ship/SKILL.md +115 -0
- package/skills/aw-spec/SKILL.md +128 -0
- package/skills/aw-tasks/SKILL.md +155 -0
- package/skills/aw-test/SKILL.md +118 -0
- package/skills/aw-verify/SKILL.md +51 -0
- package/skills/aw-yolo/SKILL.md +111 -0
- package/skills/backend-patterns/SKILL.md +598 -0
- package/skills/benchmark/SKILL.md +87 -0
- package/skills/blueprint/SKILL.md +105 -0
- package/skills/browser-qa/SKILL.md +81 -0
- package/skills/browser-testing-with-devtools/SKILL.md +81 -0
- package/skills/bun-runtime/SKILL.md +84 -0
- package/skills/canary-watch/SKILL.md +93 -0
- package/skills/carrier-relationship-management/SKILL.md +212 -0
- package/skills/ci-cd-and-automation/SKILL.md +71 -0
- package/skills/claude-api/SKILL.md +337 -0
- package/skills/claude-devfleet/SKILL.md +103 -0
- package/skills/click-path-audit/SKILL.md +244 -0
- package/skills/clickhouse-io/SKILL.md +439 -0
- package/skills/code-simplification/SKILL.md +74 -0
- package/skills/codebase-onboarding/SKILL.md +233 -0
- package/skills/coding-standards/SKILL.md +530 -0
- package/skills/compose-multiplatform-patterns/SKILL.md +299 -0
- package/skills/configure-ecc/SKILL.md +367 -0
- package/skills/content-engine/SKILL.md +88 -0
- package/skills/content-hash-cache-pattern/SKILL.md +161 -0
- package/skills/context-budget/SKILL.md +135 -0
- package/skills/context-engineering/SKILL.md +74 -0
- package/skills/continuous-agent-loop/SKILL.md +45 -0
- package/skills/continuous-learning/SKILL.md +119 -0
- package/skills/continuous-learning/config.json +18 -0
- package/skills/continuous-learning/evaluate-session.sh +69 -0
- package/skills/continuous-learning-v2/SKILL.md +365 -0
- package/skills/continuous-learning-v2/agents/observer-loop.sh +191 -0
- package/skills/continuous-learning-v2/agents/observer.md +198 -0
- package/skills/continuous-learning-v2/agents/session-guardian.sh +150 -0
- package/skills/continuous-learning-v2/agents/start-observer.sh +240 -0
- package/skills/continuous-learning-v2/config.json +8 -0
- package/skills/continuous-learning-v2/hooks/observe.sh +412 -0
- package/skills/continuous-learning-v2/scripts/detect-project.sh +228 -0
- package/skills/continuous-learning-v2/scripts/instinct-cli.py +1426 -0
- package/skills/continuous-learning-v2/scripts/test_parse_instinct.py +984 -0
- package/skills/cost-aware-llm-pipeline/SKILL.md +183 -0
- package/skills/cpp-coding-standards/SKILL.md +723 -0
- package/skills/cpp-testing/SKILL.md +324 -0
- package/skills/crosspost/SKILL.md +190 -0
- package/skills/customs-trade-compliance/SKILL.md +263 -0
- package/skills/data-scraper-agent/SKILL.md +764 -0
- package/skills/database-migrations/SKILL.md +429 -0
- package/skills/deep-research/SKILL.md +155 -0
- package/skills/deployment-patterns/SKILL.md +427 -0
- package/skills/deprecation-and-migration/SKILL.md +75 -0
- package/skills/design-system/SKILL.md +76 -0
- package/skills/django-patterns/SKILL.md +734 -0
- package/skills/django-security/SKILL.md +593 -0
- package/skills/django-tdd/SKILL.md +729 -0
- package/skills/django-verification/SKILL.md +469 -0
- package/skills/dmux-workflows/SKILL.md +191 -0
- package/skills/docker-patterns/SKILL.md +364 -0
- package/skills/documentation-and-adrs/SKILL.md +75 -0
- package/skills/documentation-lookup/SKILL.md +90 -0
- package/skills/e2e-testing/SKILL.md +326 -0
- package/skills/energy-procurement/SKILL.md +228 -0
- package/skills/enterprise-agent-ops/SKILL.md +50 -0
- package/skills/eval-harness/SKILL.md +270 -0
- package/skills/exa-search/SKILL.md +103 -0
- package/skills/fal-ai-media/SKILL.md +284 -0
- package/skills/flutter-dart-code-review/SKILL.md +435 -0
- package/skills/foundation-models-on-device/SKILL.md +243 -0
- package/skills/frontend-patterns/SKILL.md +642 -0
- package/skills/frontend-slides/SKILL.md +184 -0
- package/skills/frontend-slides/STYLE_PRESETS.md +330 -0
- package/skills/frontend-ui-engineering/SKILL.md +68 -0
- package/skills/git-workflow-and-versioning/SKILL.md +75 -0
- package/skills/golang-patterns/SKILL.md +674 -0
- package/skills/golang-testing/SKILL.md +720 -0
- package/skills/idea-refine/SKILL.md +84 -0
- package/skills/incremental-implementation/SKILL.md +86 -0
- package/skills/inventory-demand-planning/SKILL.md +247 -0
- package/skills/investor-materials/SKILL.md +96 -0
- package/skills/investor-outreach/SKILL.md +76 -0
- package/skills/iterative-retrieval/SKILL.md +211 -0
- package/skills/java-coding-standards/SKILL.md +147 -0
- package/skills/jpa-patterns/SKILL.md +151 -0
- package/skills/kotlin-coroutines-flows/SKILL.md +284 -0
- package/skills/kotlin-exposed-patterns/SKILL.md +719 -0
- package/skills/kotlin-ktor-patterns/SKILL.md +689 -0
- package/skills/kotlin-patterns/SKILL.md +711 -0
- package/skills/kotlin-testing/SKILL.md +824 -0
- package/skills/laravel-patterns/SKILL.md +415 -0
- package/skills/laravel-security/SKILL.md +285 -0
- package/skills/laravel-tdd/SKILL.md +283 -0
- package/skills/laravel-verification/SKILL.md +179 -0
- package/skills/liquid-glass-design/SKILL.md +279 -0
- package/skills/logistics-exception-management/SKILL.md +222 -0
- package/skills/market-research/SKILL.md +75 -0
- package/skills/mcp-server-patterns/SKILL.md +67 -0
- package/skills/nanoclaw-repl/SKILL.md +33 -0
- package/skills/nextjs-turbopack/SKILL.md +44 -0
- package/skills/nutrient-document-processing/SKILL.md +167 -0
- package/skills/nuxt4-patterns/SKILL.md +100 -0
- package/skills/performance-optimization/SKILL.md +77 -0
- package/skills/perl-patterns/SKILL.md +504 -0
- package/skills/perl-security/SKILL.md +503 -0
- package/skills/perl-testing/SKILL.md +475 -0
- package/skills/plankton-code-quality/SKILL.md +236 -0
- package/skills/postgres-patterns/SKILL.md +147 -0
- package/skills/product-lens/SKILL.md +79 -0
- package/skills/production-scheduling/SKILL.md +238 -0
- package/skills/project-guidelines-example/SKILL.md +349 -0
- package/skills/prompt-optimizer/SKILL.md +397 -0
- package/skills/python-patterns/SKILL.md +750 -0
- package/skills/python-testing/SKILL.md +816 -0
- package/skills/pytorch-patterns/SKILL.md +396 -0
- package/skills/quality-nonconformance/SKILL.md +260 -0
- package/skills/ralphinho-rfc-pipeline/SKILL.md +67 -0
- package/skills/regex-vs-llm-structured-text/SKILL.md +220 -0
- package/skills/returns-reverse-logistics/SKILL.md +240 -0
- package/skills/rules-distill/SKILL.md +264 -0
- package/skills/rules-distill/scripts/scan-rules.sh +58 -0
- package/skills/rules-distill/scripts/scan-skills.sh +129 -0
- package/skills/rust-patterns/SKILL.md +499 -0
- package/skills/rust-testing/SKILL.md +500 -0
- package/skills/safety-guard/SKILL.md +69 -0
- package/skills/santa-method/SKILL.md +306 -0
- package/skills/search-first/SKILL.md +161 -0
- package/skills/security-and-hardening/SKILL.md +70 -0
- package/skills/security-review/SKILL.md +495 -0
- package/skills/security-review/cloud-infrastructure-security.md +361 -0
- package/skills/security-scan/SKILL.md +165 -0
- package/skills/skill-comply/SKILL.md +58 -0
- package/skills/skill-comply/fixtures/compliant_trace.jsonl +5 -0
- package/skills/skill-comply/fixtures/noncompliant_trace.jsonl +3 -0
- package/skills/skill-comply/fixtures/tdd_spec.yaml +44 -0
- package/skills/skill-comply/prompts/classifier.md +24 -0
- package/skills/skill-comply/prompts/scenario_generator.md +62 -0
- package/skills/skill-comply/prompts/spec_generator.md +42 -0
- package/skills/skill-comply/pyproject.toml +15 -0
- package/skills/skill-comply/scripts/__init__.py +0 -0
- package/skills/skill-comply/scripts/classifier.py +85 -0
- package/skills/skill-comply/scripts/grader.py +122 -0
- package/skills/skill-comply/scripts/parser.py +107 -0
- package/skills/skill-comply/scripts/report.py +170 -0
- package/skills/skill-comply/scripts/run.py +127 -0
- package/skills/skill-comply/scripts/runner.py +161 -0
- package/skills/skill-comply/scripts/scenario_generator.py +70 -0
- package/skills/skill-comply/scripts/spec_generator.py +72 -0
- package/skills/skill-comply/scripts/utils.py +13 -0
- package/skills/skill-comply/tests/test_grader.py +137 -0
- package/skills/skill-comply/tests/test_parser.py +90 -0
- package/skills/skill-quality-review/SKILL.md +102 -0
- package/skills/skill-quality-review/references/review-rubric.md +112 -0
- package/skills/skill-stocktake/SKILL.md +197 -0
- package/skills/skill-stocktake/scripts/quick-diff.sh +87 -0
- package/skills/skill-stocktake/scripts/save-results.sh +56 -0
- package/skills/skill-stocktake/scripts/scan.sh +170 -0
- package/skills/springboot-patterns/SKILL.md +314 -0
- package/skills/springboot-security/SKILL.md +272 -0
- package/skills/springboot-tdd/SKILL.md +158 -0
- package/skills/springboot-verification/SKILL.md +231 -0
- package/skills/strategic-compact/SKILL.md +131 -0
- package/skills/strategic-compact/suggest-compact.sh +54 -0
- package/skills/swift-actor-persistence/SKILL.md +143 -0
- package/skills/swift-concurrency-6-2/SKILL.md +216 -0
- package/skills/swift-protocol-di-testing/SKILL.md +190 -0
- package/skills/swiftui-patterns/SKILL.md +259 -0
- package/skills/tdd-workflow/SKILL.md +145 -0
- package/skills/team-builder/SKILL.md +161 -0
- package/skills/using-aw-skills/SKILL.md +290 -0
- package/skills/using-aw-skills/evals/skill-trigger-cases.tsv +25 -0
- package/skills/using-aw-skills/evals/test-skill-triggers.sh +171 -0
- package/skills/using-aw-skills/hooks/hooks.json +9 -0
- package/skills/using-aw-skills/hooks/session-start.sh +188 -0
- package/skills/using-platform-skills/SKILL.md +163 -0
- package/skills/using-platform-skills/evals/platform-selection-cases.json +52 -0
- package/skills/verification-loop/SKILL.md +126 -0
- package/skills/video-editing/SKILL.md +310 -0
- package/skills/videodb/SKILL.md +374 -0
- package/skills/videodb/reference/api-reference.md +550 -0
- package/skills/videodb/reference/capture-reference.md +407 -0
- package/skills/videodb/reference/capture.md +101 -0
- package/skills/videodb/reference/editor.md +443 -0
- package/skills/videodb/reference/generative.md +331 -0
- package/skills/videodb/reference/rtstream-reference.md +564 -0
- package/skills/videodb/reference/rtstream.md +65 -0
- package/skills/videodb/reference/search.md +230 -0
- package/skills/videodb/reference/streaming.md +406 -0
- package/skills/videodb/reference/use-cases.md +118 -0
- package/skills/videodb/scripts/ws_listener.py +282 -0
- package/skills/visa-doc-translate/README.md +86 -0
- package/skills/visa-doc-translate/SKILL.md +117 -0
- package/skills/x-api/SKILL.md +208 -0
|
@@ -0,0 +1,308 @@
|
|
|
1
|
+
---
|
|
2
|
+
name: video-editing
|
|
3
|
+
description: AI-assisted video editing workflows for cutting, structuring, and augmenting real footage. Covers the full pipeline from raw capture through FFmpeg, Remotion, ElevenLabs, fal.ai, and final polish in Descript or CapCut. Use when the user wants to edit video, cut footage, create vlogs, or build video content.
|
|
4
|
+
origin: ECC
|
|
5
|
+
---
|
|
6
|
+
|
|
7
|
+
# Video Editing
|
|
8
|
+
|
|
9
|
+
AI-assisted editing for real footage. Not generation from prompts. Editing existing video fast.
|
|
10
|
+
|
|
11
|
+
## When to Activate
|
|
12
|
+
|
|
13
|
+
- User wants to edit, cut, or structure video footage
|
|
14
|
+
- Turning long recordings into short-form content
|
|
15
|
+
- Building vlogs, tutorials, or demo videos from raw capture
|
|
16
|
+
- Adding overlays, subtitles, music, or voiceover to existing video
|
|
17
|
+
- Reframing video for different platforms (YouTube, TikTok, Instagram)
|
|
18
|
+
- User says "edit video", "cut this footage", "make a vlog", or "video workflow"
|
|
19
|
+
|
|
20
|
+
## Core Thesis
|
|
21
|
+
|
|
22
|
+
AI video editing is useful when you stop asking it to create the whole video and start using it to compress, structure, and augment real footage. The value is not generation. The value is compression.
|
|
23
|
+
|
|
24
|
+
## The Pipeline
|
|
25
|
+
|
|
26
|
+
```
|
|
27
|
+
Screen Studio / raw footage
|
|
28
|
+
→ Claude / Codex
|
|
29
|
+
→ FFmpeg
|
|
30
|
+
→ Remotion
|
|
31
|
+
→ ElevenLabs / fal.ai
|
|
32
|
+
→ Descript or CapCut
|
|
33
|
+
```
|
|
34
|
+
|
|
35
|
+
Each layer has a specific job. Do not skip layers. Do not try to make one tool do everything.
|
|
36
|
+
|
|
37
|
+
## Layer 1: Capture (Screen Studio / Raw Footage)
|
|
38
|
+
|
|
39
|
+
Collect the source material:
|
|
40
|
+
- **Screen Studio**: polished screen recordings for app demos, coding sessions, browser workflows
|
|
41
|
+
- **Raw camera footage**: vlog footage, interviews, event recordings
|
|
42
|
+
- **Desktop capture via VideoDB**: session recording with real-time context (see `videodb` skill)
|
|
43
|
+
|
|
44
|
+
Output: raw files ready for organization.
|
|
45
|
+
|
|
46
|
+
## Layer 2: Organization (Claude / Codex)
|
|
47
|
+
|
|
48
|
+
Use Claude Code or Codex to:
|
|
49
|
+
- **Transcribe and label**: generate transcript, identify topics and themes
|
|
50
|
+
- **Plan structure**: decide what stays, what gets cut, what order works
|
|
51
|
+
- **Identify dead sections**: find pauses, tangents, repeated takes
|
|
52
|
+
- **Generate edit decision list**: timestamps for cuts, segments to keep
|
|
53
|
+
- **Scaffold FFmpeg and Remotion code**: generate the commands and compositions
|
|
54
|
+
|
|
55
|
+
```
|
|
56
|
+
Example prompt:
|
|
57
|
+
"Here's the transcript of a 4-hour recording. Identify the 8 strongest segments
|
|
58
|
+
for a 24-minute vlog. Give me FFmpeg cut commands for each segment."
|
|
59
|
+
```
|
|
60
|
+
|
|
61
|
+
This layer is about structure, not final creative taste.
|
|
62
|
+
|
|
63
|
+
## Layer 3: Deterministic Cuts (FFmpeg)
|
|
64
|
+
|
|
65
|
+
FFmpeg handles the boring but critical work: splitting, trimming, concatenating, and preprocessing.
|
|
66
|
+
|
|
67
|
+
### Extract segment by timestamp
|
|
68
|
+
|
|
69
|
+
```bash
|
|
70
|
+
ffmpeg -i raw.mp4 -ss 00:12:30 -to 00:15:45 -c copy segment_01.mp4
|
|
71
|
+
```
|
|
72
|
+
|
|
73
|
+
### Batch cut from edit decision list
|
|
74
|
+
|
|
75
|
+
```bash
|
|
76
|
+
#!/bin/bash
|
|
77
|
+
# cuts.txt: start,end,label
|
|
78
|
+
while IFS=, read -r start end label; do
|
|
79
|
+
ffmpeg -i raw.mp4 -ss "$start" -to "$end" -c copy "segments/${label}.mp4"
|
|
80
|
+
done < cuts.txt
|
|
81
|
+
```
|
|
82
|
+
|
|
83
|
+
### Concatenate segments
|
|
84
|
+
|
|
85
|
+
```bash
|
|
86
|
+
# Create file list
|
|
87
|
+
for f in segments/*.mp4; do echo "file '$f'"; done > concat.txt
|
|
88
|
+
ffmpeg -f concat -safe 0 -i concat.txt -c copy assembled.mp4
|
|
89
|
+
```
|
|
90
|
+
|
|
91
|
+
### Create proxy for faster editing
|
|
92
|
+
|
|
93
|
+
```bash
|
|
94
|
+
ffmpeg -i raw.mp4 -vf "scale=960:-2" -c:v libx264 -preset ultrafast -crf 28 proxy.mp4
|
|
95
|
+
```
|
|
96
|
+
|
|
97
|
+
### Extract audio for transcription
|
|
98
|
+
|
|
99
|
+
```bash
|
|
100
|
+
ffmpeg -i raw.mp4 -vn -acodec pcm_s16le -ar 16000 audio.wav
|
|
101
|
+
```
|
|
102
|
+
|
|
103
|
+
### Normalize audio levels
|
|
104
|
+
|
|
105
|
+
```bash
|
|
106
|
+
ffmpeg -i segment.mp4 -af loudnorm=I=-16:TP=-1.5:LRA=11 -c:v copy normalized.mp4
|
|
107
|
+
```
|
|
108
|
+
|
|
109
|
+
## Layer 4: Programmable Composition (Remotion)
|
|
110
|
+
|
|
111
|
+
Remotion turns editing problems into composable code. Use it for things that traditional editors make painful:
|
|
112
|
+
|
|
113
|
+
### When to use Remotion
|
|
114
|
+
|
|
115
|
+
- Overlays: text, images, branding, lower thirds
|
|
116
|
+
- Data visualizations: charts, stats, animated numbers
|
|
117
|
+
- Motion graphics: transitions, explainer animations
|
|
118
|
+
- Composable scenes: reusable templates across videos
|
|
119
|
+
- Product demos: annotated screenshots, UI highlights
|
|
120
|
+
|
|
121
|
+
### Basic Remotion composition
|
|
122
|
+
|
|
123
|
+
```tsx
|
|
124
|
+
import { AbsoluteFill, Sequence, Video, useCurrentFrame } from "remotion";
|
|
125
|
+
|
|
126
|
+
export const VlogComposition: React.FC = () => {
|
|
127
|
+
const frame = useCurrentFrame();
|
|
128
|
+
|
|
129
|
+
return (
|
|
130
|
+
<AbsoluteFill>
|
|
131
|
+
{/* Main footage */}
|
|
132
|
+
<Sequence from={0} durationInFrames={300}>
|
|
133
|
+
<Video src="/segments/intro.mp4" />
|
|
134
|
+
</Sequence>
|
|
135
|
+
|
|
136
|
+
{/* Title overlay */}
|
|
137
|
+
<Sequence from={30} durationInFrames={90}>
|
|
138
|
+
<AbsoluteFill style={{
|
|
139
|
+
justifyContent: "center",
|
|
140
|
+
alignItems: "center",
|
|
141
|
+
}}>
|
|
142
|
+
<h1 style={{
|
|
143
|
+
fontSize: 72,
|
|
144
|
+
color: "white",
|
|
145
|
+
textShadow: "2px 2px 8px rgba(0,0,0,0.8)",
|
|
146
|
+
}}>
|
|
147
|
+
The AI Editing Stack
|
|
148
|
+
</h1>
|
|
149
|
+
</AbsoluteFill>
|
|
150
|
+
</Sequence>
|
|
151
|
+
|
|
152
|
+
{/* Next segment */}
|
|
153
|
+
<Sequence from={300} durationInFrames={450}>
|
|
154
|
+
<Video src="/segments/demo.mp4" />
|
|
155
|
+
</Sequence>
|
|
156
|
+
</AbsoluteFill>
|
|
157
|
+
);
|
|
158
|
+
};
|
|
159
|
+
```
|
|
160
|
+
|
|
161
|
+
### Render output
|
|
162
|
+
|
|
163
|
+
```bash
|
|
164
|
+
npx remotion render src/index.ts VlogComposition output.mp4
|
|
165
|
+
```
|
|
166
|
+
|
|
167
|
+
See the [Remotion docs](https://www.remotion.dev/docs) for detailed patterns and API reference.
|
|
168
|
+
|
|
169
|
+
## Layer 5: Generated Assets (ElevenLabs / fal.ai)
|
|
170
|
+
|
|
171
|
+
Generate only what you need. Do not generate the whole video.
|
|
172
|
+
|
|
173
|
+
### Voiceover with ElevenLabs
|
|
174
|
+
|
|
175
|
+
```python
|
|
176
|
+
import os
|
|
177
|
+
import requests
|
|
178
|
+
|
|
179
|
+
resp = requests.post(
|
|
180
|
+
f"https://api.elevenlabs.io/v1/text-to-speech/{voice_id}",
|
|
181
|
+
headers={
|
|
182
|
+
"xi-api-key": os.environ["ELEVENLABS_API_KEY"],
|
|
183
|
+
"Content-Type": "application/json"
|
|
184
|
+
},
|
|
185
|
+
json={
|
|
186
|
+
"text": "Your narration text here",
|
|
187
|
+
"model_id": "eleven_turbo_v2_5",
|
|
188
|
+
"voice_settings": {"stability": 0.5, "similarity_boost": 0.75}
|
|
189
|
+
}
|
|
190
|
+
)
|
|
191
|
+
with open("voiceover.mp3", "wb") as f:
|
|
192
|
+
f.write(resp.content)
|
|
193
|
+
```
|
|
194
|
+
|
|
195
|
+
### Music and SFX with fal.ai
|
|
196
|
+
|
|
197
|
+
Use the `fal-ai-media` skill for:
|
|
198
|
+
- Background music generation
|
|
199
|
+
- Sound effects (ThinkSound model for video-to-audio)
|
|
200
|
+
- Transition sounds
|
|
201
|
+
|
|
202
|
+
### Generated visuals with fal.ai
|
|
203
|
+
|
|
204
|
+
Use for insert shots, thumbnails, or b-roll that doesn't exist:
|
|
205
|
+
```
|
|
206
|
+
generate(model_name: "fal-ai/nano-banana-pro", input: {
|
|
207
|
+
"prompt": "professional thumbnail for tech vlog, dark background, code on screen",
|
|
208
|
+
"image_size": "landscape_16_9"
|
|
209
|
+
})
|
|
210
|
+
```
|
|
211
|
+
|
|
212
|
+
### VideoDB generative audio
|
|
213
|
+
|
|
214
|
+
If VideoDB is configured:
|
|
215
|
+
```python
|
|
216
|
+
voiceover = coll.generate_voice(text="Narration here", voice="alloy")
|
|
217
|
+
music = coll.generate_music(prompt="lo-fi background for coding vlog", duration=120)
|
|
218
|
+
sfx = coll.generate_sound_effect(prompt="subtle whoosh transition")
|
|
219
|
+
```
|
|
220
|
+
|
|
221
|
+
## Layer 6: Final Polish (Descript / CapCut)
|
|
222
|
+
|
|
223
|
+
The last layer is human. Use a traditional editor for:
|
|
224
|
+
- **Pacing**: adjust cuts that feel too fast or slow
|
|
225
|
+
- **Captions**: auto-generated, then manually cleaned
|
|
226
|
+
- **Color grading**: basic correction and mood
|
|
227
|
+
- **Final audio mix**: balance voice, music, and SFX levels
|
|
228
|
+
- **Export**: platform-specific formats and quality settings
|
|
229
|
+
|
|
230
|
+
This is where taste lives. AI clears the repetitive work. You make the final calls.
|
|
231
|
+
|
|
232
|
+
## Social Media Reframing
|
|
233
|
+
|
|
234
|
+
Different platforms need different aspect ratios:
|
|
235
|
+
|
|
236
|
+
| Platform | Aspect Ratio | Resolution |
|
|
237
|
+
|----------|-------------|------------|
|
|
238
|
+
| YouTube | 16:9 | 1920x1080 |
|
|
239
|
+
| TikTok / Reels | 9:16 | 1080x1920 |
|
|
240
|
+
| Instagram Feed | 1:1 | 1080x1080 |
|
|
241
|
+
| X / Twitter | 16:9 or 1:1 | 1280x720 or 720x720 |
|
|
242
|
+
|
|
243
|
+
### Reframe with FFmpeg
|
|
244
|
+
|
|
245
|
+
```bash
|
|
246
|
+
# 16:9 to 9:16 (center crop)
|
|
247
|
+
ffmpeg -i input.mp4 -vf "crop=ih*9/16:ih,scale=1080:1920" vertical.mp4
|
|
248
|
+
|
|
249
|
+
# 16:9 to 1:1 (center crop)
|
|
250
|
+
ffmpeg -i input.mp4 -vf "crop=ih:ih,scale=1080:1080" square.mp4
|
|
251
|
+
```
|
|
252
|
+
|
|
253
|
+
### Reframe with VideoDB
|
|
254
|
+
|
|
255
|
+
```python
|
|
256
|
+
# Smart reframe (AI-guided subject tracking)
|
|
257
|
+
reframed = video.reframe(start=0, end=60, target="vertical", mode=ReframeMode.smart)
|
|
258
|
+
```
|
|
259
|
+
|
|
260
|
+
## Scene Detection and Auto-Cut
|
|
261
|
+
|
|
262
|
+
### FFmpeg scene detection
|
|
263
|
+
|
|
264
|
+
```bash
|
|
265
|
+
# Detect scene changes (threshold 0.3 = moderate sensitivity)
|
|
266
|
+
ffmpeg -i input.mp4 -vf "select='gt(scene,0.3)',showinfo" -vsync vfr -f null - 2>&1 | grep showinfo
|
|
267
|
+
```
|
|
268
|
+
|
|
269
|
+
### Silence detection for auto-cut
|
|
270
|
+
|
|
271
|
+
```bash
|
|
272
|
+
# Find silent segments (useful for cutting dead air)
|
|
273
|
+
ffmpeg -i input.mp4 -af silencedetect=noise=-30dB:d=2 -f null - 2>&1 | grep silence
|
|
274
|
+
```
|
|
275
|
+
|
|
276
|
+
### Highlight extraction
|
|
277
|
+
|
|
278
|
+
Use Claude to analyze transcript + scene timestamps:
|
|
279
|
+
```
|
|
280
|
+
"Given this transcript with timestamps and these scene change points,
|
|
281
|
+
identify the 5 most engaging 30-second clips for social media."
|
|
282
|
+
```
|
|
283
|
+
|
|
284
|
+
## What Each Tool Does Best
|
|
285
|
+
|
|
286
|
+
| Tool | Strength | Weakness |
|
|
287
|
+
|------|----------|----------|
|
|
288
|
+
| Claude / Codex | Organization, planning, code generation | Not the creative taste layer |
|
|
289
|
+
| FFmpeg | Deterministic cuts, batch processing, format conversion | No visual editing UI |
|
|
290
|
+
| Remotion | Programmable overlays, composable scenes, reusable templates | Learning curve for non-devs |
|
|
291
|
+
| Screen Studio | Polished screen recordings immediately | Only screen capture |
|
|
292
|
+
| ElevenLabs | Voice, narration, music, SFX | Not the center of the workflow |
|
|
293
|
+
| Descript / CapCut | Final pacing, captions, polish | Manual, not automatable |
|
|
294
|
+
|
|
295
|
+
## Key Principles
|
|
296
|
+
|
|
297
|
+
1. **Edit, don't generate.** This workflow is for cutting real footage, not creating from prompts.
|
|
298
|
+
2. **Structure before style.** Get the story right in Layer 2 before touching anything visual.
|
|
299
|
+
3. **FFmpeg is the backbone.** Boring but critical. Where long footage becomes manageable.
|
|
300
|
+
4. **Remotion for repeatability.** If you'll do it more than once, make it a Remotion component.
|
|
301
|
+
5. **Generate selectively.** Only use AI generation for assets that don't exist, not for everything.
|
|
302
|
+
6. **Taste is the last layer.** AI clears repetitive work. You make the final creative calls.
|
|
303
|
+
|
|
304
|
+
## Related Skills
|
|
305
|
+
|
|
306
|
+
- `fal-ai-media` — AI image, video, and audio generation
|
|
307
|
+
- `videodb` — Server-side video processing, indexing, and streaming
|
|
308
|
+
- `content-engine` — Platform-native content distribution
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
interface:
|
|
2
|
+
display_name: "Video Editing"
|
|
3
|
+
short_description: "AI-assisted video editing for real footage"
|
|
4
|
+
brand_color: "#EF4444"
|
|
5
|
+
default_prompt: "Edit video using AI-assisted pipeline: organize, cut, compose, generate assets, polish"
|
|
6
|
+
policy:
|
|
7
|
+
allow_implicit_invocation: true
|
|
@@ -0,0 +1,214 @@
|
|
|
1
|
+
---
|
|
2
|
+
name: x-api
|
|
3
|
+
description: X/Twitter API integration for posting tweets, threads, reading timelines, search, and analytics. Covers OAuth auth patterns, rate limits, and platform-native content posting. Use when the user wants to interact with X programmatically.
|
|
4
|
+
origin: ECC
|
|
5
|
+
---
|
|
6
|
+
|
|
7
|
+
# X API
|
|
8
|
+
|
|
9
|
+
Programmatic interaction with X (Twitter) for posting, reading, searching, and analytics.
|
|
10
|
+
|
|
11
|
+
## When to Activate
|
|
12
|
+
|
|
13
|
+
- User wants to post tweets or threads programmatically
|
|
14
|
+
- Reading timeline, mentions, or user data from X
|
|
15
|
+
- Searching X for content, trends, or conversations
|
|
16
|
+
- Building X integrations or bots
|
|
17
|
+
- Analytics and engagement tracking
|
|
18
|
+
- User says "post to X", "tweet", "X API", or "Twitter API"
|
|
19
|
+
|
|
20
|
+
## Authentication
|
|
21
|
+
|
|
22
|
+
### OAuth 2.0 (App-Only / User Context)
|
|
23
|
+
|
|
24
|
+
Best for: read-heavy operations, search, public data.
|
|
25
|
+
|
|
26
|
+
```bash
|
|
27
|
+
# Environment setup
|
|
28
|
+
export X_BEARER_TOKEN="your-bearer-token"
|
|
29
|
+
```
|
|
30
|
+
|
|
31
|
+
```python
|
|
32
|
+
import os
|
|
33
|
+
import requests
|
|
34
|
+
|
|
35
|
+
bearer = os.environ["X_BEARER_TOKEN"]
|
|
36
|
+
headers = {"Authorization": f"Bearer {bearer}"}
|
|
37
|
+
|
|
38
|
+
# Search recent tweets
|
|
39
|
+
resp = requests.get(
|
|
40
|
+
"https://api.x.com/2/tweets/search/recent",
|
|
41
|
+
headers=headers,
|
|
42
|
+
params={"query": "claude code", "max_results": 10}
|
|
43
|
+
)
|
|
44
|
+
tweets = resp.json()
|
|
45
|
+
```
|
|
46
|
+
|
|
47
|
+
### OAuth 1.0a (User Context)
|
|
48
|
+
|
|
49
|
+
Required for: posting tweets, managing account, DMs.
|
|
50
|
+
|
|
51
|
+
```bash
|
|
52
|
+
# Environment setup — source before use
|
|
53
|
+
export X_API_KEY="your-api-key"
|
|
54
|
+
export X_API_SECRET="your-api-secret"
|
|
55
|
+
export X_ACCESS_TOKEN="your-access-token"
|
|
56
|
+
export X_ACCESS_SECRET="your-access-secret"
|
|
57
|
+
```
|
|
58
|
+
|
|
59
|
+
```python
|
|
60
|
+
import os
|
|
61
|
+
from requests_oauthlib import OAuth1Session
|
|
62
|
+
|
|
63
|
+
oauth = OAuth1Session(
|
|
64
|
+
os.environ["X_API_KEY"],
|
|
65
|
+
client_secret=os.environ["X_API_SECRET"],
|
|
66
|
+
resource_owner_key=os.environ["X_ACCESS_TOKEN"],
|
|
67
|
+
resource_owner_secret=os.environ["X_ACCESS_SECRET"],
|
|
68
|
+
)
|
|
69
|
+
```
|
|
70
|
+
|
|
71
|
+
## Core Operations
|
|
72
|
+
|
|
73
|
+
### Post a Tweet
|
|
74
|
+
|
|
75
|
+
```python
|
|
76
|
+
resp = oauth.post(
|
|
77
|
+
"https://api.x.com/2/tweets",
|
|
78
|
+
json={"text": "Hello from Claude Code"}
|
|
79
|
+
)
|
|
80
|
+
resp.raise_for_status()
|
|
81
|
+
tweet_id = resp.json()["data"]["id"]
|
|
82
|
+
```
|
|
83
|
+
|
|
84
|
+
### Post a Thread
|
|
85
|
+
|
|
86
|
+
```python
|
|
87
|
+
def post_thread(oauth, tweets: list[str]) -> list[str]:
|
|
88
|
+
ids = []
|
|
89
|
+
reply_to = None
|
|
90
|
+
for text in tweets:
|
|
91
|
+
payload = {"text": text}
|
|
92
|
+
if reply_to:
|
|
93
|
+
payload["reply"] = {"in_reply_to_tweet_id": reply_to}
|
|
94
|
+
resp = oauth.post("https://api.x.com/2/tweets", json=payload)
|
|
95
|
+
resp.raise_for_status()
|
|
96
|
+
tweet_id = resp.json()["data"]["id"]
|
|
97
|
+
ids.append(tweet_id)
|
|
98
|
+
reply_to = tweet_id
|
|
99
|
+
return ids
|
|
100
|
+
```
|
|
101
|
+
|
|
102
|
+
### Read User Timeline
|
|
103
|
+
|
|
104
|
+
```python
|
|
105
|
+
resp = requests.get(
|
|
106
|
+
f"https://api.x.com/2/users/{user_id}/tweets",
|
|
107
|
+
headers=headers,
|
|
108
|
+
params={
|
|
109
|
+
"max_results": 10,
|
|
110
|
+
"tweet.fields": "created_at,public_metrics",
|
|
111
|
+
}
|
|
112
|
+
)
|
|
113
|
+
```
|
|
114
|
+
|
|
115
|
+
### Search Tweets
|
|
116
|
+
|
|
117
|
+
```python
|
|
118
|
+
resp = requests.get(
|
|
119
|
+
"https://api.x.com/2/tweets/search/recent",
|
|
120
|
+
headers=headers,
|
|
121
|
+
params={
|
|
122
|
+
"query": "from:affaanmustafa -is:retweet",
|
|
123
|
+
"max_results": 10,
|
|
124
|
+
"tweet.fields": "public_metrics,created_at",
|
|
125
|
+
}
|
|
126
|
+
)
|
|
127
|
+
```
|
|
128
|
+
|
|
129
|
+
### Get User by Username
|
|
130
|
+
|
|
131
|
+
```python
|
|
132
|
+
resp = requests.get(
|
|
133
|
+
"https://api.x.com/2/users/by/username/affaanmustafa",
|
|
134
|
+
headers=headers,
|
|
135
|
+
params={"user.fields": "public_metrics,description,created_at"}
|
|
136
|
+
)
|
|
137
|
+
```
|
|
138
|
+
|
|
139
|
+
### Upload Media and Post
|
|
140
|
+
|
|
141
|
+
```python
|
|
142
|
+
# Media upload uses v1.1 endpoint
|
|
143
|
+
|
|
144
|
+
# Step 1: Upload media
|
|
145
|
+
media_resp = oauth.post(
|
|
146
|
+
"https://upload.twitter.com/1.1/media/upload.json",
|
|
147
|
+
files={"media": open("image.png", "rb")}
|
|
148
|
+
)
|
|
149
|
+
media_id = media_resp.json()["media_id_string"]
|
|
150
|
+
|
|
151
|
+
# Step 2: Post with media
|
|
152
|
+
resp = oauth.post(
|
|
153
|
+
"https://api.x.com/2/tweets",
|
|
154
|
+
json={"text": "Check this out", "media": {"media_ids": [media_id]}}
|
|
155
|
+
)
|
|
156
|
+
```
|
|
157
|
+
|
|
158
|
+
## Rate Limits Reference
|
|
159
|
+
|
|
160
|
+
| Endpoint | Limit | Window |
|
|
161
|
+
|----------|-------|--------|
|
|
162
|
+
| POST /2/tweets | 200 | 15 min |
|
|
163
|
+
| GET /2/tweets/search/recent | 450 | 15 min |
|
|
164
|
+
| GET /2/users/:id/tweets | 1500 | 15 min |
|
|
165
|
+
| GET /2/users/by/username | 300 | 15 min |
|
|
166
|
+
| POST media/upload | 415 | 15 min |
|
|
167
|
+
|
|
168
|
+
Always check `x-rate-limit-remaining` and `x-rate-limit-reset` headers.
|
|
169
|
+
|
|
170
|
+
```python
|
|
171
|
+
import time
|
|
172
|
+
|
|
173
|
+
remaining = int(resp.headers.get("x-rate-limit-remaining", 0))
|
|
174
|
+
if remaining < 5:
|
|
175
|
+
reset = int(resp.headers.get("x-rate-limit-reset", 0))
|
|
176
|
+
wait = max(0, reset - int(time.time()))
|
|
177
|
+
print(f"Rate limit approaching. Resets in {wait}s")
|
|
178
|
+
```
|
|
179
|
+
|
|
180
|
+
## Error Handling
|
|
181
|
+
|
|
182
|
+
```python
|
|
183
|
+
resp = oauth.post("https://api.x.com/2/tweets", json={"text": content})
|
|
184
|
+
if resp.status_code == 201:
|
|
185
|
+
return resp.json()["data"]["id"]
|
|
186
|
+
elif resp.status_code == 429:
|
|
187
|
+
reset = int(resp.headers["x-rate-limit-reset"])
|
|
188
|
+
raise Exception(f"Rate limited. Resets at {reset}")
|
|
189
|
+
elif resp.status_code == 403:
|
|
190
|
+
raise Exception(f"Forbidden: {resp.json().get('detail', 'check permissions')}")
|
|
191
|
+
else:
|
|
192
|
+
raise Exception(f"X API error {resp.status_code}: {resp.text}")
|
|
193
|
+
```
|
|
194
|
+
|
|
195
|
+
## Security
|
|
196
|
+
|
|
197
|
+
- **Never hardcode tokens.** Use environment variables or `.env` files.
|
|
198
|
+
- **Never commit `.env` files.** Add to `.gitignore`.
|
|
199
|
+
- **Rotate tokens** if exposed. Regenerate at developer.x.com.
|
|
200
|
+
- **Use read-only tokens** when write access is not needed.
|
|
201
|
+
- **Store OAuth secrets securely** — not in source code or logs.
|
|
202
|
+
|
|
203
|
+
## Integration with Content Engine
|
|
204
|
+
|
|
205
|
+
Use `content-engine` skill to generate platform-native content, then post via X API:
|
|
206
|
+
1. Generate content with content-engine (X platform format)
|
|
207
|
+
2. Validate length (280 chars for single tweet)
|
|
208
|
+
3. Post via X API using patterns above
|
|
209
|
+
4. Track engagement via public_metrics
|
|
210
|
+
|
|
211
|
+
## Related Skills
|
|
212
|
+
|
|
213
|
+
- `content-engine` — Generate platform-native content for X
|
|
214
|
+
- `crosspost` — Distribute content across X, LinkedIn, and other platforms
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
interface:
|
|
2
|
+
display_name: "X API"
|
|
3
|
+
short_description: "X/Twitter API integration for posting, threads, and analytics"
|
|
4
|
+
brand_color: "#000000"
|
|
5
|
+
default_prompt: "Use X API to post tweets, threads, or retrieve timeline and search data"
|
|
6
|
+
policy:
|
|
7
|
+
allow_implicit_invocation: true
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
### Plugin Manifest Gotchas
|
|
2
|
+
|
|
3
|
+
If you plan to edit `.claude-plugin/plugin.json`, be aware that the Claude plugin validator enforces several **undocumented but strict constraints** that can cause installs to fail with vague errors (for example, `agents: Invalid input`). In particular, component fields must be arrays, `agents` must use explicit file paths rather than directories, and a `version` field is required for reliable validation and installation.
|
|
4
|
+
|
|
5
|
+
These constraints are not obvious from public examples and have caused repeated installation failures in the past. They are documented in detail in `.claude-plugin/PLUGIN_SCHEMA_NOTES.md`, which should be reviewed before making any changes to the plugin manifest.
|
|
6
|
+
|
|
7
|
+
### Custom Endpoints and Gateways
|
|
8
|
+
|
|
9
|
+
ECC does not override Claude Code transport settings. If Claude Code is configured to run through an official LLM gateway or a compatible custom endpoint, the plugin continues to work because hooks, commands, and skills execute locally after the CLI starts successfully.
|
|
10
|
+
|
|
11
|
+
Use Claude Code's own environment/configuration for transport selection, for example:
|
|
12
|
+
|
|
13
|
+
```bash
|
|
14
|
+
export ANTHROPIC_BASE_URL=https://your-gateway.example.com
|
|
15
|
+
export ANTHROPIC_AUTH_TOKEN=your-token
|
|
16
|
+
claude
|
|
17
|
+
```
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
{
|
|
2
|
+
"name": "aw",
|
|
3
|
+
"version": "1.4.21",
|
|
4
|
+
"description": "GoHighLevel Agentic Workspace Engine — agents, skills, commands, hooks, and rules for GHL development workflows.",
|
|
5
|
+
"author": {
|
|
6
|
+
"name": "GoHighLevel",
|
|
7
|
+
"url": "https://github.com/shreyansh-ghl/aw-ecc"
|
|
8
|
+
},
|
|
9
|
+
"homepage": "https://github.com/shreyansh-ghl/aw-ecc",
|
|
10
|
+
"repository": "https://github.com/shreyansh-ghl/aw-ecc",
|
|
11
|
+
"license": "MIT",
|
|
12
|
+
"keywords": [
|
|
13
|
+
"ghl",
|
|
14
|
+
"agentic-workspace",
|
|
15
|
+
"agents",
|
|
16
|
+
"skills",
|
|
17
|
+
"hooks",
|
|
18
|
+
"rules",
|
|
19
|
+
"tdd",
|
|
20
|
+
"code-review",
|
|
21
|
+
"security",
|
|
22
|
+
"workflow"
|
|
23
|
+
]
|
|
24
|
+
}
|
package/.codex/AGENTS.md
ADDED
|
@@ -0,0 +1,93 @@
|
|
|
1
|
+
# ECC for Codex CLI
|
|
2
|
+
|
|
3
|
+
This supplements the root `AGENTS.md` with Codex-specific guidance.
|
|
4
|
+
|
|
5
|
+
## Model Recommendations
|
|
6
|
+
|
|
7
|
+
| Task Type | Recommended Model |
|
|
8
|
+
|-----------|------------------|
|
|
9
|
+
| Routine coding, tests, formatting | GPT 5.4 |
|
|
10
|
+
| Complex features, architecture | GPT 5.4 |
|
|
11
|
+
| Debugging, refactoring | GPT 5.4 |
|
|
12
|
+
| Security review | GPT 5.4 |
|
|
13
|
+
|
|
14
|
+
## Skills Discovery
|
|
15
|
+
|
|
16
|
+
Skills are auto-loaded from `.agents/skills/`. Each skill contains:
|
|
17
|
+
- `SKILL.md` — Detailed instructions and workflow
|
|
18
|
+
- `agents/openai.yaml` — Codex interface metadata
|
|
19
|
+
|
|
20
|
+
Available skills:
|
|
21
|
+
- tdd-workflow — Test-driven development with 80%+ coverage
|
|
22
|
+
- security-review — Comprehensive security checklist
|
|
23
|
+
- coding-standards — Universal coding standards
|
|
24
|
+
- frontend-patterns — React/Next.js patterns
|
|
25
|
+
- frontend-slides — Viewport-safe HTML presentations and PPTX-to-web conversion
|
|
26
|
+
- article-writing — Long-form writing from notes and voice references
|
|
27
|
+
- content-engine — Platform-native social content and repurposing
|
|
28
|
+
- market-research — Source-attributed market and competitor research
|
|
29
|
+
- investor-materials — Decks, memos, models, and one-pagers
|
|
30
|
+
- investor-outreach — Personalized investor outreach and follow-ups
|
|
31
|
+
- backend-patterns — API design, database, caching
|
|
32
|
+
- e2e-testing — Playwright E2E tests
|
|
33
|
+
- eval-harness — Eval-driven development
|
|
34
|
+
- strategic-compact — Context management
|
|
35
|
+
- api-design — REST API design patterns
|
|
36
|
+
- verification-loop — Build, test, lint, typecheck, security
|
|
37
|
+
- deep-research — Multi-source research with firecrawl and exa MCPs
|
|
38
|
+
- exa-search — Neural search via Exa MCP for web, code, and companies
|
|
39
|
+
- claude-api — Anthropic Claude API patterns and SDKs
|
|
40
|
+
- x-api — X/Twitter API integration for posting, threads, and analytics
|
|
41
|
+
- crosspost — Multi-platform content distribution
|
|
42
|
+
- fal-ai-media — AI image/video/audio generation via fal.ai
|
|
43
|
+
- dmux-workflows — Multi-agent orchestration with dmux
|
|
44
|
+
|
|
45
|
+
## MCP Servers
|
|
46
|
+
|
|
47
|
+
Treat the project-local `.codex/config.toml` as the default Codex baseline for ECC. The current ECC baseline enables GitHub, Context7, Exa, Memory, Playwright, and Sequential Thinking; add heavier extras in `~/.codex/config.toml` only when a task actually needs them.
|
|
48
|
+
|
|
49
|
+
### Automatic config.toml merging
|
|
50
|
+
|
|
51
|
+
The sync script (`scripts/sync-ecc-to-codex.sh`) uses a Node-based TOML parser to safely merge ECC MCP servers into `~/.codex/config.toml`:
|
|
52
|
+
|
|
53
|
+
- **Add-only by default** — missing ECC servers are appended; existing servers are never modified or removed.
|
|
54
|
+
- **7 managed servers** — Supabase, Playwright, Context7, Exa, GitHub, Memory, Sequential Thinking.
|
|
55
|
+
- **Package-manager aware** — uses the project's configured package manager (npm/pnpm/yarn/bun) instead of hardcoding `pnpm`.
|
|
56
|
+
- **Drift warnings** — if an existing server's config differs from the ECC recommendation, the script logs a warning.
|
|
57
|
+
- **`--update-mcp`** — explicitly replaces all ECC-managed servers with the latest recommended config (safely removes subtables like `[mcp_servers.supabase.env]`).
|
|
58
|
+
- **User config is always preserved** — custom servers, args, env vars, and credentials outside ECC-managed sections are never touched.
|
|
59
|
+
|
|
60
|
+
## Multi-Agent Support
|
|
61
|
+
|
|
62
|
+
Codex now supports multi-agent workflows behind the experimental `features.multi_agent` flag.
|
|
63
|
+
|
|
64
|
+
- Enable it in `.codex/config.toml` with `[features] multi_agent = true`
|
|
65
|
+
- Define project-local roles under `[agents.<name>]`
|
|
66
|
+
- Point each role at a TOML layer under `.codex/agents/`
|
|
67
|
+
- Use `/agent` inside Codex CLI to inspect and steer child agents
|
|
68
|
+
|
|
69
|
+
Sample role configs in this repo:
|
|
70
|
+
- `.codex/agents/explorer.toml` — read-only evidence gathering
|
|
71
|
+
- `.codex/agents/reviewer.toml` — correctness/security review
|
|
72
|
+
- `.codex/agents/docs-researcher.toml` — API and release-note verification
|
|
73
|
+
|
|
74
|
+
## Key Differences from Claude Code
|
|
75
|
+
|
|
76
|
+
| Feature | Claude Code | Codex CLI |
|
|
77
|
+
|---------|------------|-----------|
|
|
78
|
+
| Hooks | 8+ event types | Not yet supported |
|
|
79
|
+
| Context file | CLAUDE.md + AGENTS.md | AGENTS.md only |
|
|
80
|
+
| Skills | Skills loaded via plugin | `.agents/skills/` directory |
|
|
81
|
+
| Commands | `/slash` commands | Instruction-based |
|
|
82
|
+
| Agents | Subagent Task tool | Multi-agent via `/agent` and `[agents.<name>]` roles |
|
|
83
|
+
| Security | Hook-based enforcement | Instruction + sandbox |
|
|
84
|
+
| MCP | Full support | Supported via `config.toml` and `codex mcp add` |
|
|
85
|
+
|
|
86
|
+
## Security Without Hooks
|
|
87
|
+
|
|
88
|
+
Since Codex lacks hooks, security enforcement is instruction-based:
|
|
89
|
+
1. Always validate inputs at system boundaries
|
|
90
|
+
2. Never hardcode secrets — use environment variables
|
|
91
|
+
3. Run `npm audit` / `pip audit` before committing
|
|
92
|
+
4. Review `git diff` before every push
|
|
93
|
+
5. Use `sandbox_mode = "workspace-write"` in config
|