@heyai-rules/pilo-masterkit 2.1.0 → 3.1.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/.agent/agents/PILO_MASTER.md +77 -77
- package/.agent/agents/architect.md +211 -211
- package/.agent/agents/backend-specialist.md +263 -263
- package/.agent/agents/build-error-resolver.md +114 -114
- package/.agent/agents/chief-of-staff.md +151 -151
- package/.agent/agents/code-archaeologist.md +106 -106
- package/.agent/agents/code-reviewer.md +237 -237
- package/.agent/agents/cpp-build-resolver.md +90 -90
- package/.agent/agents/cpp-reviewer.md +72 -72
- package/.agent/agents/csharp-reviewer.md +101 -101
- package/.agent/agents/dart-build-resolver.md +201 -201
- package/.agent/agents/database-architect.md +226 -226
- package/.agent/agents/database-reviewer.md +91 -91
- package/.agent/agents/debugger.md +225 -225
- package/.agent/agents/devops-engineer.md +242 -242
- package/.agent/agents/doc-updater.md +107 -107
- package/.agent/agents/docs-lookup.md +68 -68
- package/.agent/agents/documentation-writer.md +104 -104
- package/.agent/agents/e2e-runner.md +107 -107
- package/.agent/agents/explorer-agent.md +73 -73
- package/.agent/agents/flutter-reviewer.md +243 -243
- package/.agent/agents/frontend-specialist.md +593 -593
- package/.agent/agents/game-developer.md +162 -162
- package/.agent/agents/gan-evaluator.md +209 -209
- package/.agent/agents/gan-generator.md +131 -131
- package/.agent/agents/gan-planner.md +99 -99
- package/.agent/agents/go-build-resolver.md +94 -94
- package/.agent/agents/go-reviewer.md +76 -76
- package/.agent/agents/harness-optimizer.md +35 -35
- package/.agent/agents/healthcare-reviewer.md +83 -83
- package/.agent/agents/java-build-resolver.md +153 -153
- package/.agent/agents/java-reviewer.md +92 -92
- package/.agent/agents/kotlin-build-resolver.md +118 -118
- package/.agent/agents/kotlin-reviewer.md +159 -159
- package/.agent/agents/loop-operator.md +36 -36
- package/.agent/agents/mobile-developer.md +377 -377
- package/.agent/agents/opensource-forker.md +198 -198
- package/.agent/agents/opensource-packager.md +249 -249
- package/.agent/agents/opensource-sanitizer.md +188 -188
- package/.agent/agents/orchestrator.md +416 -416
- package/.agent/agents/penetration-tester.md +188 -188
- package/.agent/agents/performance-optimizer.md +446 -446
- package/.agent/agents/personas/athena-agent/agent.json +10 -10
- package/.agent/agents/personas/athena-agent/athena-backend-logic-architecture-profile.md +3 -3
- package/.agent/agents/personas/athena-agent/context-files/agents.md +1 -1
- package/.agent/agents/personas/athena-agent/context-files/identity.md +1 -1
- package/.agent/agents/personas/athena-agent/context-files/soul.md +1 -1
- package/.agent/agents/personas/athena-agent/context-files/user-predefined.md +1 -1
- package/.agent/agents/personas/athena-agent/user-context-files/system/bootstrap.md +1 -1
- package/.agent/agents/personas/athena-agent/user-context-files/system/user.md +1 -1
- package/.agent/agents/personas/da-vinci-agent/agent.json +10 -10
- package/.agent/agents/personas/da-vinci-agent/context-files/agents.md +1 -1
- package/.agent/agents/personas/da-vinci-agent/context-files/identity.md +1 -1
- package/.agent/agents/personas/da-vinci-agent/context-files/soul.md +1 -1
- package/.agent/agents/personas/da-vinci-agent/context-files/user-predefined.md +1 -1
- package/.agent/agents/personas/da-vinci-agent/da-vinci-frontend-ui-ux-design-profile.md +3 -3
- package/.agent/agents/personas/da-vinci-agent/user-context-files/system/bootstrap.md +1 -1
- package/.agent/agents/personas/da-vinci-agent/user-context-files/system/user.md +1 -1
- package/.agent/agents/personas/duong-tang-agent/agent.json +10 -10
- package/.agent/agents/personas/duong-tang-agent/context-files/agents.md +1 -1
- package/.agent/agents/personas/duong-tang-agent/context-files/identity.md +1 -1
- package/.agent/agents/personas/duong-tang-agent/context-files/soul.md +1 -1
- package/.agent/agents/personas/duong-tang-agent/context-files/user-predefined.md +1 -1
- package/.agent/agents/personas/duong-tang-agent/tang-monk-quality-testing-documentation-profile.md +3 -3
- package/.agent/agents/personas/duong-tang-agent/user-context-files/system/bootstrap.md +1 -1
- package/.agent/agents/personas/duong-tang-agent/user-context-files/system/user.md +1 -1
- package/.agent/agents/personas/gia-cat-luong-agent/agent.json +10 -10
- package/.agent/agents/personas/gia-cat-luong-agent/context-files/agents.md +1 -1
- package/.agent/agents/personas/gia-cat-luong-agent/context-files/identity.md +1 -1
- package/.agent/agents/personas/gia-cat-luong-agent/context-files/soul.md +1 -1
- package/.agent/agents/personas/gia-cat-luong-agent/context-files/user-predefined.md +1 -1
- package/.agent/agents/personas/gia-cat-luong-agent/kongming-research-strategy-analysis-profile.md +3 -3
- package/.agent/agents/personas/gia-cat-luong-agent/user-context-files/system/bootstrap.md +1 -1
- package/.agent/agents/personas/gia-cat-luong-agent/user-context-files/system/user.md +1 -1
- package/.agent/agents/personas/mihata-agent/agent.json +10 -10
- package/.agent/agents/personas/mihata-agent/context-files/agents.md +1 -1
- package/.agent/agents/personas/mihata-agent/context-files/identity.md +1 -1
- package/.agent/agents/personas/mihata-agent/context-files/soul.md +1 -1
- package/.agent/agents/personas/mihata-agent/context-files/user-predefined.md +1 -1
- package/.agent/agents/personas/mihata-agent/mihata-multi-agent-orchestration-profile.md +3 -3
- package/.agent/agents/personas/mihata-agent/user-context-files/system/bootstrap.md +1 -1
- package/.agent/agents/personas/mihata-agent/user-context-files/system/user.md +1 -1
- package/.agent/agents/personas/tesla-agent/agent.json +10 -10
- package/.agent/agents/personas/tesla-agent/context-files/agents.md +1 -1
- package/.agent/agents/personas/tesla-agent/context-files/identity.md +1 -1
- package/.agent/agents/personas/tesla-agent/context-files/soul.md +1 -1
- package/.agent/agents/personas/tesla-agent/context-files/user-predefined.md +1 -1
- package/.agent/agents/personas/tesla-agent/tesla-fullstack-system-optimization-profile.md +3 -3
- package/.agent/agents/personas/tesla-agent/user-context-files/system/bootstrap.md +1 -1
- package/.agent/agents/personas/tesla-agent/user-context-files/system/user.md +1 -1
- package/.agent/agents/personas/tu-ma-y-agent/agent.json +10 -10
- package/.agent/agents/personas/tu-ma-y-agent/context-files/agents.md +1 -1
- package/.agent/agents/personas/tu-ma-y-agent/context-files/identity.md +1 -1
- package/.agent/agents/personas/tu-ma-y-agent/context-files/soul.md +1 -1
- package/.agent/agents/personas/tu-ma-y-agent/context-files/user-predefined.md +1 -1
- package/.agent/agents/personas/tu-ma-y-agent/simayi-feasibility-risk-control-profile.md +3 -3
- package/.agent/agents/personas/tu-ma-y-agent/user-context-files/system/bootstrap.md +1 -1
- package/.agent/agents/personas/tu-ma-y-agent/user-context-files/system/user.md +1 -1
- package/.agent/agents/personas/venti-agent/agent.json +10 -10
- package/.agent/agents/personas/venti-agent/context-files/agents.md +1 -1
- package/.agent/agents/personas/venti-agent/context-files/identity.md +1 -1
- package/.agent/agents/personas/venti-agent/context-files/soul.md +1 -1
- package/.agent/agents/personas/venti-agent/context-files/user-predefined.md +1 -1
- package/.agent/agents/personas/venti-agent/user-context-files/system/bootstrap.md +1 -1
- package/.agent/agents/personas/venti-agent/user-context-files/system/user.md +1 -1
- package/.agent/agents/personas/venti-agent/venti-learning-communication-mentoring-profile.md +3 -3
- package/.agent/agents/planner.md +212 -212
- package/.agent/agents/product-manager.md +112 -112
- package/.agent/agents/product-owner.md +95 -95
- package/.agent/agents/project-planner.md +406 -406
- package/.agent/agents/python-reviewer.md +98 -98
- package/.agent/agents/pytorch-build-resolver.md +120 -120
- package/.agent/agents/qa-automation-engineer.md +103 -103
- package/.agent/agents/refactor-cleaner.md +85 -85
- package/.agent/agents/rust-build-resolver.md +148 -148
- package/.agent/agents/rust-reviewer.md +94 -94
- package/.agent/agents/security-auditor.md +170 -170
- package/.agent/agents/security-reviewer.md +108 -108
- package/.agent/agents/seo-specialist.md +111 -111
- package/.agent/agents/tdd-guide.md +91 -91
- package/.agent/agents/test-engineer.md +158 -158
- package/.agent/agents/typescript-reviewer.md +112 -112
- package/.agent/contexts/dev.md +20 -20
- package/.agent/contexts/research.md +26 -26
- package/.agent/contexts/review.md +22 -22
- package/.agent/hooks/hooks.json +395 -395
- package/.agent/hooks/readme.md +222 -222
- package/.agent/mcp-configs/mcp-servers.json +181 -181
- package/.agent/rules/ARCHITECTURAL_BLUEPRINTS.md +62 -62
- package/.agent/rules/CODE_CRAFTSMANSHIP.md +69 -69
- package/.agent/rules/CORE_RULES.md +72 -72
- package/.agent/rules/PROJECT_MAP.md +58 -58
- package/.agent/rules/QUALITY_ASSURANCE.md +54 -54
- package/.agent/rules/SECURITY_ARMOR.md +44 -44
- package/.agent/rules/VERSION_ORCHESTRATION.md +64 -64
- package/.agent/rules/WORKFLOW_ORCHESTRATION.md +55 -55
- package/.agent/rules/common/agents.md +50 -50
- package/.agent/rules/common/code-review.md +124 -124
- package/.agent/rules/common/coding-style.md +48 -48
- package/.agent/rules/common/development-workflow.md +44 -44
- package/.agent/rules/common/git-workflow.md +24 -24
- package/.agent/rules/common/hooks.md +30 -30
- package/.agent/rules/common/patterns.md +31 -31
- package/.agent/rules/common/performance.md +55 -55
- package/.agent/rules/common/security.md +29 -29
- package/.agent/rules/common/testing.md +29 -29
- package/.agent/rules/cpp/coding-style.md +44 -44
- package/.agent/rules/cpp/hooks.md +39 -39
- package/.agent/rules/cpp/patterns.md +51 -51
- package/.agent/rules/cpp/security.md +51 -51
- package/.agent/rules/cpp/testing.md +44 -44
- package/.agent/rules/csharp/coding-style.md +72 -72
- package/.agent/rules/csharp/hooks.md +25 -25
- package/.agent/rules/csharp/patterns.md +50 -50
- package/.agent/rules/csharp/security.md +58 -58
- package/.agent/rules/csharp/testing.md +46 -46
- package/.agent/rules/dart/coding-style.md +159 -159
- package/.agent/rules/dart/hooks.md +66 -66
- package/.agent/rules/dart/patterns.md +261 -261
- package/.agent/rules/dart/security.md +135 -135
- package/.agent/rules/dart/testing.md +215 -215
- package/.agent/rules/golang/coding-style.md +32 -32
- package/.agent/rules/golang/hooks.md +17 -17
- package/.agent/rules/golang/patterns.md +45 -45
- package/.agent/rules/golang/security.md +34 -34
- package/.agent/rules/golang/testing.md +31 -31
- package/.agent/rules/java/coding-style.md +114 -114
- package/.agent/rules/java/hooks.md +18 -18
- package/.agent/rules/java/patterns.md +146 -146
- package/.agent/rules/java/security.md +100 -100
- package/.agent/rules/java/testing.md +131 -131
- package/.agent/rules/kotlin/coding-style.md +86 -86
- package/.agent/rules/kotlin/hooks.md +17 -17
- package/.agent/rules/kotlin/patterns.md +146 -146
- package/.agent/rules/kotlin/security.md +82 -82
- package/.agent/rules/kotlin/testing.md +128 -128
- package/.agent/rules/perl/coding-style.md +46 -46
- package/.agent/rules/perl/hooks.md +22 -22
- package/.agent/rules/perl/patterns.md +76 -76
- package/.agent/rules/perl/security.md +69 -69
- package/.agent/rules/perl/testing.md +54 -54
- package/.agent/rules/php/coding-style.md +40 -40
- package/.agent/rules/php/hooks.md +24 -24
- package/.agent/rules/php/patterns.md +33 -33
- package/.agent/rules/php/security.md +37 -37
- package/.agent/rules/php/testing.md +39 -39
- package/.agent/rules/python/coding-style.md +42 -42
- package/.agent/rules/python/hooks.md +19 -19
- package/.agent/rules/python/patterns.md +39 -39
- package/.agent/rules/python/security.md +30 -30
- package/.agent/rules/python/testing.md +38 -38
- package/.agent/rules/readme.md +111 -111
- package/.agent/rules/rust/coding-style.md +151 -151
- package/.agent/rules/rust/hooks.md +16 -16
- package/.agent/rules/rust/patterns.md +168 -168
- package/.agent/rules/rust/security.md +141 -141
- package/.agent/rules/rust/testing.md +154 -154
- package/.agent/rules/swift/coding-style.md +47 -47
- package/.agent/rules/swift/hooks.md +20 -20
- package/.agent/rules/swift/patterns.md +66 -66
- package/.agent/rules/swift/security.md +33 -33
- package/.agent/rules/swift/testing.md +45 -45
- package/.agent/rules/typescript/coding-style.md +199 -199
- package/.agent/rules/typescript/hooks.md +22 -22
- package/.agent/rules/typescript/patterns.md +52 -52
- package/.agent/rules/typescript/security.md +28 -28
- package/.agent/rules/typescript/testing.md +18 -18
- package/.agent/rules/web/coding-style.md +96 -96
- package/.agent/rules/web/design-quality.md +63 -63
- package/.agent/rules/web/hooks.md +120 -120
- package/.agent/rules/web/patterns.md +79 -79
- package/.agent/rules/web/performance.md +64 -64
- package/.agent/rules/web/security.md +57 -57
- package/.agent/rules/web/testing.md +55 -55
- package/.agent/rules/zh/agents.md +50 -50
- package/.agent/rules/zh/code-review.md +124 -124
- package/.agent/rules/zh/coding-style.md +48 -48
- package/.agent/rules/zh/development-workflow.md +44 -44
- package/.agent/rules/zh/git-workflow.md +24 -24
- package/.agent/rules/zh/hooks.md +30 -30
- package/.agent/rules/zh/patterns.md +31 -31
- package/.agent/rules/zh/performance.md +55 -55
- package/.agent/rules/zh/readme.md +108 -108
- package/.agent/rules/zh/security.md +29 -29
- package/.agent/rules/zh/testing.md +29 -29
- package/.agent/scripts/auto_preview.py +148 -148
- package/.agent/scripts/checklist.py +217 -217
- package/.agent/scripts/session_manager.py +120 -120
- package/.agent/scripts/verify_all.py +327 -327
- package/.agent/skills/agent-eval/SKILL.md +145 -145
- package/.agent/skills/agent-harness-construction/SKILL.md +73 -73
- package/.agent/skills/agent-payment-x402/SKILL.md +178 -178
- package/.agent/skills/agentic-engineering/SKILL.md +63 -63
- package/.agent/skills/ai-first-engineering/SKILL.md +51 -51
- package/.agent/skills/ai-regression-testing/SKILL.md +385 -385
- package/.agent/skills/android-clean-architecture/SKILL.md +339 -339
- package/.agent/skills/api-design/SKILL.md +523 -523
- package/.agent/skills/api-patterns/SKILL.md +81 -81
- package/.agent/skills/api-patterns/api-style.md +42 -42
- package/.agent/skills/api-patterns/auth.md +24 -24
- package/.agent/skills/api-patterns/documentation.md +26 -26
- package/.agent/skills/api-patterns/graphql.md +41 -41
- package/.agent/skills/api-patterns/rate-limiting.md +31 -31
- package/.agent/skills/api-patterns/response.md +37 -37
- package/.agent/skills/api-patterns/rest.md +40 -40
- package/.agent/skills/api-patterns/scripts/api_validator.py +211 -211
- package/.agent/skills/api-patterns/security-testing.md +122 -122
- package/.agent/skills/api-patterns/trpc.md +41 -41
- package/.agent/skills/api-patterns/versioning.md +22 -22
- package/.agent/skills/app-builder/SKILL.md +75 -75
- package/.agent/skills/app-builder/agent-coordination.md +71 -71
- package/.agent/skills/app-builder/feature-building.md +53 -53
- package/.agent/skills/app-builder/project-detection.md +34 -34
- package/.agent/skills/app-builder/scaffolding.md +118 -118
- package/.agent/skills/app-builder/tech-stack.md +41 -41
- package/.agent/skills/app-builder/templates/SKILL.md +39 -39
- package/.agent/skills/app-builder/templates/astro-static/TEMPLATE.md +76 -76
- package/.agent/skills/app-builder/templates/chrome-extension/TEMPLATE.md +92 -92
- package/.agent/skills/app-builder/templates/cli-tool/TEMPLATE.md +88 -88
- package/.agent/skills/app-builder/templates/electron-desktop/TEMPLATE.md +88 -88
- package/.agent/skills/app-builder/templates/express-api/TEMPLATE.md +83 -83
- package/.agent/skills/app-builder/templates/flutter-app/TEMPLATE.md +90 -90
- package/.agent/skills/app-builder/templates/monorepo-turborepo/TEMPLATE.md +90 -90
- package/.agent/skills/app-builder/templates/nextjs-fullstack/TEMPLATE.md +122 -122
- package/.agent/skills/app-builder/templates/nextjs-saas/TEMPLATE.md +122 -122
- package/.agent/skills/app-builder/templates/nextjs-static/TEMPLATE.md +169 -169
- package/.agent/skills/app-builder/templates/nuxt-app/TEMPLATE.md +134 -134
- package/.agent/skills/app-builder/templates/python-fastapi/TEMPLATE.md +83 -83
- package/.agent/skills/app-builder/templates/react-native-app/TEMPLATE.md +119 -119
- package/.agent/skills/architecture/SKILL.md +55 -55
- package/.agent/skills/architecture/context-discovery.md +43 -43
- package/.agent/skills/architecture/examples.md +94 -94
- package/.agent/skills/architecture/pattern-selection.md +68 -68
- package/.agent/skills/architecture/patterns-reference.md +50 -50
- package/.agent/skills/architecture/trade-off-analysis.md +77 -77
- package/.agent/skills/architecture-decision-records/SKILL.md +179 -179
- package/.agent/skills/article-writing/SKILL.md +79 -79
- package/.agent/skills/autonomous-agent-harness/SKILL.md +267 -267
- package/.agent/skills/autonomous-loops/SKILL.md +610 -610
- package/.agent/skills/backend-patterns/SKILL.md +598 -598
- package/.agent/skills/bash-linux/SKILL.md +199 -199
- package/.agent/skills/behavioral-modes/SKILL.md +242 -242
- package/.agent/skills/benchmark/SKILL.md +93 -93
- package/.agent/skills/blueprint/SKILL.md +105 -105
- package/.agent/skills/brainstorming/SKILL.md +163 -163
- package/.agent/skills/brainstorming/dynamic-questioning.md +350 -350
- package/.agent/skills/brand-voice/SKILL.md +97 -97
- package/.agent/skills/brand-voice/references/voice-profile-schema.md +55 -55
- package/.agent/skills/browser-qa/SKILL.md +87 -87
- package/.agent/skills/bun-runtime/SKILL.md +84 -84
- package/.agent/skills/canary-watch/SKILL.md +99 -99
- package/.agent/skills/carrier-relationship-management/SKILL.md +212 -212
- package/.agent/skills/ck/SKILL.md +147 -147
- package/.agent/skills/ck/commands/forget.mjs +44 -44
- package/.agent/skills/ck/commands/info.mjs +24 -24
- package/.agent/skills/ck/commands/init.mjs +143 -143
- package/.agent/skills/ck/commands/list.mjs +40 -40
- package/.agent/skills/ck/commands/migrate.mjs +202 -202
- package/.agent/skills/ck/commands/resume.mjs +36 -36
- package/.agent/skills/ck/commands/save.mjs +210 -210
- package/.agent/skills/ck/commands/shared.mjs +387 -387
- package/.agent/skills/ck/hooks/session-start.mjs +224 -224
- package/.agent/skills/claude-api/SKILL.md +337 -337
- package/.agent/skills/claude-devfleet/SKILL.md +103 -103
- package/.agent/skills/clean-code/SKILL.md +201 -201
- package/.agent/skills/click-path-audit/SKILL.md +244 -244
- package/.agent/skills/clickhouse-io/SKILL.md +439 -439
- package/.agent/skills/code-review-checklist/SKILL.md +109 -109
- package/.agent/skills/codebase-onboarding/SKILL.md +233 -233
- package/.agent/skills/coding-standards/SKILL.md +530 -530
- package/.agent/skills/compose-multiplatform-patterns/SKILL.md +299 -299
- package/.agent/skills/configure-ecc/SKILL.md +367 -367
- package/.agent/skills/connections-optimizer/SKILL.md +189 -189
- package/.agent/skills/content-engine/SKILL.md +131 -131
- package/.agent/skills/content-hash-cache-pattern/SKILL.md +161 -161
- package/.agent/skills/context-budget/SKILL.md +135 -135
- package/.agent/skills/continuous-agent-loop/SKILL.md +45 -45
- package/.agent/skills/continuous-learning/SKILL.md +119 -119
- package/.agent/skills/continuous-learning/config.json +18 -18
- package/.agent/skills/continuous-learning/evaluate-session.sh +69 -69
- package/.agent/skills/continuous-learning-v2/SKILL.md +365 -365
- package/.agent/skills/continuous-learning-v2/agents/observer-loop.sh +271 -271
- package/.agent/skills/continuous-learning-v2/agents/observer.md +198 -198
- package/.agent/skills/continuous-learning-v2/agents/session-guardian.sh +150 -150
- package/.agent/skills/continuous-learning-v2/agents/start-observer.sh +244 -244
- package/.agent/skills/continuous-learning-v2/config.json +8 -8
- package/.agent/skills/continuous-learning-v2/hooks/observe.sh +428 -428
- package/.agent/skills/continuous-learning-v2/scripts/detect-project.sh +228 -228
- package/.agent/skills/continuous-learning-v2/scripts/instinct-cli.py +1426 -1426
- package/.agent/skills/continuous-learning-v2/scripts/test-parse-instinct.py +984 -984
- package/.agent/skills/cost-aware-llm-pipeline/SKILL.md +183 -183
- package/.agent/skills/cpp-coding-standards/SKILL.md +723 -723
- package/.agent/skills/cpp-testing/SKILL.md +324 -324
- package/.agent/skills/crosspost/SKILL.md +111 -111
- package/.agent/skills/csharp-testing/SKILL.md +321 -321
- package/.agent/skills/customer-billing-ops/SKILL.md +140 -140
- package/.agent/skills/customs-trade-compliance/SKILL.md +263 -263
- package/.agent/skills/dart-flutter-patterns/SKILL.md +563 -563
- package/.agent/skills/data-scraper-agent/SKILL.md +764 -764
- package/.agent/skills/database-design/SKILL.md +52 -52
- package/.agent/skills/database-design/database-selection.md +43 -43
- package/.agent/skills/database-design/indexing.md +39 -39
- package/.agent/skills/database-design/migrations.md +48 -48
- package/.agent/skills/database-design/optimization.md +36 -36
- package/.agent/skills/database-design/orm-selection.md +30 -30
- package/.agent/skills/database-design/schema-design.md +56 -56
- package/.agent/skills/database-design/scripts/schema_validator.py +172 -172
- package/.agent/skills/database-migrations/SKILL.md +429 -429
- package/.agent/skills/deep-research/SKILL.md +155 -155
- package/.agent/skills/deployment-patterns/SKILL.md +427 -427
- package/.agent/skills/deployment-procedures/SKILL.md +241 -241
- package/.agent/skills/design-system/SKILL.md +82 -82
- package/.agent/skills/django-patterns/SKILL.md +734 -734
- package/.agent/skills/django-security/SKILL.md +593 -593
- package/.agent/skills/django-tdd/SKILL.md +729 -729
- package/.agent/skills/django-verification/SKILL.md +469 -469
- package/.agent/skills/dmux-workflows/SKILL.md +191 -191
- package/.agent/skills/doc.md +177 -177
- package/.agent/skills/docker-patterns/SKILL.md +364 -364
- package/.agent/skills/documentation-lookup/SKILL.md +90 -90
- package/.agent/skills/documentation-templates/SKILL.md +194 -194
- package/.agent/skills/dotnet-patterns/SKILL.md +321 -321
- package/.agent/skills/e2e-testing/SKILL.md +326 -326
- package/.agent/skills/energy-procurement/SKILL.md +228 -228
- package/.agent/skills/enterprise-agent-ops/SKILL.md +50 -50
- package/.agent/skills/eval-harness/SKILL.md +270 -270
- package/.agent/skills/exa-search/SKILL.md +103 -103
- package/.agent/skills/fal-ai-media/SKILL.md +284 -284
- package/.agent/skills/flutter-dart-code-review/SKILL.md +435 -435
- package/.agent/skills/foundation-models-on-device/SKILL.md +243 -243
- package/.agent/skills/frontend-design/SKILL.md +452 -452
- package/.agent/skills/frontend-design/animation-guide.md +331 -331
- package/.agent/skills/frontend-design/color-system.md +311 -311
- package/.agent/skills/frontend-design/decision-trees.md +418 -418
- package/.agent/skills/frontend-design/motion-graphics.md +306 -306
- package/.agent/skills/frontend-design/scripts/accessibility_checker.py +183 -183
- package/.agent/skills/frontend-design/scripts/ux_audit.py +722 -722
- package/.agent/skills/frontend-design/typography-system.md +345 -345
- package/.agent/skills/frontend-design/ux-psychology.md +1116 -1116
- package/.agent/skills/frontend-design/visual-effects.md +383 -383
- package/.agent/skills/frontend-patterns/SKILL.md +642 -642
- package/.agent/skills/frontend-slides/SKILL.md +184 -184
- package/.agent/skills/frontend-slides/style-presets.md +330 -330
- package/.agent/skills/game-development/2d-games/SKILL.md +119 -119
- package/.agent/skills/game-development/3d-games/SKILL.md +135 -135
- package/.agent/skills/game-development/SKILL.md +167 -167
- package/.agent/skills/game-development/game-art/SKILL.md +185 -185
- package/.agent/skills/game-development/game-audio/SKILL.md +190 -190
- package/.agent/skills/game-development/game-design/SKILL.md +129 -129
- package/.agent/skills/game-development/mobile-games/SKILL.md +108 -108
- package/.agent/skills/game-development/multiplayer/SKILL.md +132 -132
- package/.agent/skills/game-development/pc-games/SKILL.md +144 -144
- package/.agent/skills/game-development/vr-ar/SKILL.md +123 -123
- package/.agent/skills/game-development/web-games/SKILL.md +150 -150
- package/.agent/skills/gan-style-harness/SKILL.md +278 -278
- package/.agent/skills/geo-fundamentals/SKILL.md +156 -156
- package/.agent/skills/geo-fundamentals/scripts/geo_checker.py +289 -289
- package/.agent/skills/git-workflow/SKILL.md +715 -715
- package/.agent/skills/golang-patterns/SKILL.md +674 -674
- package/.agent/skills/golang-testing/SKILL.md +720 -720
- package/.agent/skills/google-workspace-ops/SKILL.md +95 -95
- package/.agent/skills/healthcare-cdss-patterns/SKILL.md +245 -245
- package/.agent/skills/healthcare-emr-patterns/SKILL.md +159 -159
- package/.agent/skills/healthcare-eval-harness/SKILL.md +207 -207
- package/.agent/skills/healthcare-phi-compliance/SKILL.md +145 -145
- package/.agent/skills/hexagonal-architecture/SKILL.md +276 -276
- package/.agent/skills/i18n-localization/SKILL.md +154 -154
- package/.agent/skills/i18n-localization/scripts/i18n_checker.py +241 -241
- package/.agent/skills/intelligent-routing/SKILL.md +335 -335
- package/.agent/skills/inventory-demand-planning/SKILL.md +247 -247
- package/.agent/skills/investor-materials/SKILL.md +96 -96
- package/.agent/skills/investor-outreach/SKILL.md +91 -91
- package/.agent/skills/iterative-retrieval/SKILL.md +211 -211
- package/.agent/skills/java-coding-standards/SKILL.md +147 -147
- package/.agent/skills/jira-integration/SKILL.md +293 -293
- package/.agent/skills/jpa-patterns/SKILL.md +151 -151
- package/.agent/skills/kotlin-coroutines-flows/SKILL.md +284 -284
- package/.agent/skills/kotlin-exposed-patterns/SKILL.md +719 -719
- package/.agent/skills/kotlin-ktor-patterns/SKILL.md +689 -689
- package/.agent/skills/kotlin-patterns/SKILL.md +711 -711
- package/.agent/skills/kotlin-testing/SKILL.md +824 -824
- package/.agent/skills/laravel-patterns/SKILL.md +415 -415
- package/.agent/skills/laravel-plugin-discovery/SKILL.md +229 -229
- package/.agent/skills/laravel-security/SKILL.md +285 -285
- package/.agent/skills/laravel-tdd/SKILL.md +283 -283
- package/.agent/skills/laravel-verification/SKILL.md +179 -179
- package/.agent/skills/lead-intelligence/SKILL.md +321 -321
- package/.agent/skills/lead-intelligence/agents/enrichment-agent.md +85 -85
- package/.agent/skills/lead-intelligence/agents/mutual-mapper.md +75 -75
- package/.agent/skills/lead-intelligence/agents/outreach-drafter.md +98 -98
- package/.agent/skills/lead-intelligence/agents/signal-scorer.md +60 -60
- package/.agent/skills/lint-and-validate/SKILL.md +45 -45
- package/.agent/skills/lint-and-validate/scripts/lint_runner.py +184 -184
- package/.agent/skills/lint-and-validate/scripts/type_coverage.py +173 -173
- package/.agent/skills/liquid-glass-design/SKILL.md +279 -279
- package/.agent/skills/logistics-exception-management/SKILL.md +222 -222
- package/.agent/skills/manim-video/SKILL.md +89 -89
- package/.agent/skills/manim-video/assets/network-graph-scene.py +52 -52
- package/.agent/skills/market-research/SKILL.md +75 -75
- package/.agent/skills/mcp-server-patterns/SKILL.md +67 -67
- package/.agent/skills/mobile-design/SKILL.md +394 -394
- package/.agent/skills/mobile-design/decision-trees.md +516 -516
- package/.agent/skills/mobile-design/mobile-backend.md +491 -491
- package/.agent/skills/mobile-design/mobile-color-system.md +420 -420
- package/.agent/skills/mobile-design/mobile-debugging.md +122 -122
- package/.agent/skills/mobile-design/mobile-design-thinking.md +357 -357
- package/.agent/skills/mobile-design/mobile-navigation.md +458 -458
- package/.agent/skills/mobile-design/mobile-performance.md +767 -767
- package/.agent/skills/mobile-design/mobile-testing.md +356 -356
- package/.agent/skills/mobile-design/mobile-typography.md +433 -433
- package/.agent/skills/mobile-design/platform-android.md +666 -666
- package/.agent/skills/mobile-design/platform-ios.md +561 -561
- package/.agent/skills/mobile-design/scripts/mobile_audit.py +670 -670
- package/.agent/skills/mobile-design/touch-psychology.md +537 -537
- package/.agent/skills/nanoclaw-repl/SKILL.md +33 -33
- package/.agent/skills/nestjs-patterns/SKILL.md +230 -230
- package/.agent/skills/nextjs-react-expert/1-async-eliminating-waterfalls.md +351 -351
- package/.agent/skills/nextjs-react-expert/2-bundle-bundle-size-optimization.md +240 -240
- package/.agent/skills/nextjs-react-expert/3-server-server-side-performance.md +490 -490
- package/.agent/skills/nextjs-react-expert/4-client-client-side-data-fetching.md +264 -264
- package/.agent/skills/nextjs-react-expert/5-rerender-re-render-optimization.md +581 -581
- package/.agent/skills/nextjs-react-expert/6-rendering-rendering-performance.md +432 -432
- package/.agent/skills/nextjs-react-expert/7-js-javascript-performance.md +684 -684
- package/.agent/skills/nextjs-react-expert/8-advanced-advanced-patterns.md +150 -150
- package/.agent/skills/nextjs-react-expert/9-cache-components.md +103 -103
- package/.agent/skills/nextjs-react-expert/SKILL.md +293 -293
- package/.agent/skills/nextjs-react-expert/scripts/convert_rules.py +222 -222
- package/.agent/skills/nextjs-react-expert/scripts/react_performance_checker.py +252 -252
- package/.agent/skills/nextjs-turbopack/SKILL.md +44 -44
- package/.agent/skills/nodejs-best-practices/SKILL.md +333 -333
- package/.agent/skills/nutrient-document-processing/SKILL.md +167 -167
- package/.agent/skills/nuxt4-patterns/SKILL.md +100 -100
- package/.agent/skills/openclaw-persona-forge/SKILL.md +296 -296
- package/.agent/skills/openclaw-persona-forge/gacha.py +224 -224
- package/.agent/skills/openclaw-persona-forge/gacha.sh +5 -5
- package/.agent/skills/openclaw-persona-forge/references/avatar-style.md +124 -124
- package/.agent/skills/openclaw-persona-forge/references/boundary-rules.md +53 -53
- package/.agent/skills/openclaw-persona-forge/references/error-handling.md +53 -53
- package/.agent/skills/openclaw-persona-forge/references/identity-tension.md +48 -48
- package/.agent/skills/openclaw-persona-forge/references/naming-system.md +39 -39
- package/.agent/skills/openclaw-persona-forge/references/output-template.md +166 -166
- package/.agent/skills/opensource-pipeline/SKILL.md +255 -255
- package/.agent/skills/parallel-agents/SKILL.md +175 -175
- package/.agent/skills/performance-profiling/SKILL.md +143 -143
- package/.agent/skills/performance-profiling/scripts/lighthouse_audit.py +76 -76
- package/.agent/skills/perl-patterns/SKILL.md +504 -504
- package/.agent/skills/perl-security/SKILL.md +503 -503
- package/.agent/skills/perl-testing/SKILL.md +475 -475
- package/.agent/skills/plan-writing/SKILL.md +152 -152
- package/.agent/skills/plankton-code-quality/SKILL.md +236 -236
- package/.agent/skills/postgres-patterns/SKILL.md +147 -147
- package/.agent/skills/powershell-windows/SKILL.md +167 -167
- package/.agent/skills/product-lens/SKILL.md +85 -85
- package/.agent/skills/production-scheduling/SKILL.md +238 -238
- package/.agent/skills/project-flow-ops/SKILL.md +111 -111
- package/.agent/skills/project-guidelines-example/SKILL.md +349 -349
- package/.agent/skills/prompt-optimizer/SKILL.md +397 -397
- package/.agent/skills/python-patterns/SKILL.md +750 -750
- package/.agent/skills/python-testing/SKILL.md +816 -816
- package/.agent/skills/pytorch-patterns/SKILL.md +396 -396
- package/.agent/skills/quality-nonconformance/SKILL.md +260 -260
- package/.agent/skills/ralphinho-rfc-pipeline/SKILL.md +67 -67
- package/.agent/skills/red-team-tactics/SKILL.md +199 -199
- package/.agent/skills/regex-vs-llm-structured-text/SKILL.md +220 -220
- package/.agent/skills/remotion-video-creation/SKILL.md +43 -43
- package/.agent/skills/remotion-video-creation/rules/3d.md +86 -86
- package/.agent/skills/remotion-video-creation/rules/animations.md +29 -29
- package/.agent/skills/remotion-video-creation/rules/assets/charts-bar-chart.tsx +173 -173
- package/.agent/skills/remotion-video-creation/rules/assets/text-animations-typewriter.tsx +100 -100
- package/.agent/skills/remotion-video-creation/rules/assets/text-animations-word-highlight.tsx +108 -108
- package/.agent/skills/remotion-video-creation/rules/assets.md +78 -78
- package/.agent/skills/remotion-video-creation/rules/audio.md +172 -172
- package/.agent/skills/remotion-video-creation/rules/calculate-metadata.md +104 -104
- package/.agent/skills/remotion-video-creation/rules/can-decode.md +75 -75
- package/.agent/skills/remotion-video-creation/rules/charts.md +58 -58
- package/.agent/skills/remotion-video-creation/rules/compositions.md +146 -146
- package/.agent/skills/remotion-video-creation/rules/display-captions.md +126 -126
- package/.agent/skills/remotion-video-creation/rules/extract-frames.md +229 -229
- package/.agent/skills/remotion-video-creation/rules/fonts.md +152 -152
- package/.agent/skills/remotion-video-creation/rules/get-audio-duration.md +58 -58
- package/.agent/skills/remotion-video-creation/rules/get-video-dimensions.md +68 -68
- package/.agent/skills/remotion-video-creation/rules/get-video-duration.md +58 -58
- package/.agent/skills/remotion-video-creation/rules/gifs.md +138 -138
- package/.agent/skills/remotion-video-creation/rules/images.md +130 -130
- package/.agent/skills/remotion-video-creation/rules/import-srt-captions.md +67 -67
- package/.agent/skills/remotion-video-creation/rules/lottie.md +67 -67
- package/.agent/skills/remotion-video-creation/rules/measuring-dom-nodes.md +34 -34
- package/.agent/skills/remotion-video-creation/rules/measuring-text.md +143 -143
- package/.agent/skills/remotion-video-creation/rules/sequencing.md +106 -106
- package/.agent/skills/remotion-video-creation/rules/tailwind.md +11 -11
- package/.agent/skills/remotion-video-creation/rules/text-animations.md +20 -20
- package/.agent/skills/remotion-video-creation/rules/timing.md +179 -179
- package/.agent/skills/remotion-video-creation/rules/transcribe-captions.md +19 -19
- package/.agent/skills/remotion-video-creation/rules/transitions.md +122 -122
- package/.agent/skills/remotion-video-creation/rules/trimming.md +52 -52
- package/.agent/skills/remotion-video-creation/rules/videos.md +171 -171
- package/.agent/skills/repo-scan/SKILL.md +63 -63
- package/.agent/skills/returns-reverse-logistics/SKILL.md +240 -240
- package/.agent/skills/rules-distill/SKILL.md +264 -264
- package/.agent/skills/rules-distill/scripts/scan-rules.sh +58 -58
- package/.agent/skills/rules-distill/scripts/scan-skills.sh +129 -129
- package/.agent/skills/rust-patterns/SKILL.md +499 -499
- package/.agent/skills/rust-pro/SKILL.md +175 -175
- package/.agent/skills/rust-testing/SKILL.md +500 -500
- package/.agent/skills/safety-guard/SKILL.md +75 -75
- package/.agent/skills/santa-method/SKILL.md +306 -306
- package/.agent/skills/search-first/SKILL.md +161 -161
- package/.agent/skills/security-review/SKILL.md +495 -495
- package/.agent/skills/security-review/cloud-infrastructure-security.md +361 -361
- package/.agent/skills/security-scan/SKILL.md +165 -165
- package/.agent/skills/seo-fundamentals/SKILL.md +129 -129
- package/.agent/skills/seo-fundamentals/scripts/seo_checker.py +219 -219
- package/.agent/skills/server-management/SKILL.md +161 -161
- package/.agent/skills/skill-comply/SKILL.md +58 -58
- package/.agent/skills/skill-comply/fixtures/compliant-trace.jsonl +5 -5
- package/.agent/skills/skill-comply/fixtures/noncompliant-trace.jsonl +3 -3
- package/.agent/skills/skill-comply/fixtures/tdd-spec.yaml +44 -44
- package/.agent/skills/skill-comply/prompts/classifier.md +24 -24
- package/.agent/skills/skill-comply/prompts/scenario-generator.md +62 -62
- package/.agent/skills/skill-comply/prompts/spec-generator.md +42 -42
- package/.agent/skills/skill-comply/pyproject.toml +15 -15
- package/.agent/skills/skill-comply/scripts/classifier.py +85 -85
- package/.agent/skills/skill-comply/scripts/grader.py +122 -122
- package/.agent/skills/skill-comply/scripts/parser.py +107 -107
- package/.agent/skills/skill-comply/scripts/report.py +170 -170
- package/.agent/skills/skill-comply/scripts/run.py +127 -127
- package/.agent/skills/skill-comply/scripts/runner.py +161 -161
- package/.agent/skills/skill-comply/scripts/scenario-generator.py +70 -70
- package/.agent/skills/skill-comply/scripts/spec-generator.py +72 -72
- package/.agent/skills/skill-comply/scripts/utils.py +13 -13
- package/.agent/skills/skill-comply/tests/test-grader.py +137 -137
- package/.agent/skills/skill-comply/tests/test-parser.py +90 -90
- package/.agent/skills/skill-stocktake/SKILL.md +193 -193
- package/.agent/skills/skill-stocktake/scripts/quick-diff.sh +87 -87
- package/.agent/skills/skill-stocktake/scripts/save-results.sh +56 -56
- package/.agent/skills/skill-stocktake/scripts/scan.sh +170 -170
- package/.agent/skills/social-graph-ranker/SKILL.md +154 -154
- package/.agent/skills/springboot-patterns/SKILL.md +314 -314
- package/.agent/skills/springboot-security/SKILL.md +272 -272
- package/.agent/skills/springboot-tdd/SKILL.md +158 -158
- package/.agent/skills/springboot-verification/SKILL.md +231 -231
- package/.agent/skills/strategic-compact/SKILL.md +131 -131
- package/.agent/skills/strategic-compact/suggest-compact.sh +54 -54
- package/.agent/skills/swift-actor-persistence/SKILL.md +143 -143
- package/.agent/skills/swift-concurrency-6-2/SKILL.md +216 -216
- package/.agent/skills/swift-protocol-di-testing/SKILL.md +190 -190
- package/.agent/skills/swiftui-patterns/SKILL.md +259 -259
- package/.agent/skills/systematic-debugging/SKILL.md +109 -109
- package/.agent/skills/tailwind-patterns/SKILL.md +269 -269
- package/.agent/skills/tdd-workflow/SKILL.md +463 -463
- package/.agent/skills/team-builder/SKILL.md +168 -168
- package/.agent/skills/testing-patterns/SKILL.md +178 -178
- package/.agent/skills/testing-patterns/scripts/test_runner.py +219 -219
- package/.agent/skills/token-budget-advisor/SKILL.md +133 -133
- package/.agent/skills/ui-demo/SKILL.md +465 -465
- package/.agent/skills/ui-ux-pro-max/SKILL.md +292 -292
- package/.agent/skills/ui-ux-pro-max/data/charts.csv +26 -26
- package/.agent/skills/ui-ux-pro-max/data/colors.csv +97 -97
- package/.agent/skills/ui-ux-pro-max/data/icons.csv +101 -101
- package/.agent/skills/ui-ux-pro-max/data/landing.csv +31 -31
- package/.agent/skills/ui-ux-pro-max/data/products.csv +96 -96
- package/.agent/skills/ui-ux-pro-max/data/react-performance.csv +45 -45
- package/.agent/skills/ui-ux-pro-max/data/stacks/astro.csv +54 -54
- package/.agent/skills/ui-ux-pro-max/data/stacks/flutter.csv +53 -53
- package/.agent/skills/ui-ux-pro-max/data/stacks/html-tailwind.csv +56 -56
- package/.agent/skills/ui-ux-pro-max/data/stacks/jetpack-compose.csv +53 -53
- package/.agent/skills/ui-ux-pro-max/data/stacks/nextjs.csv +53 -53
- package/.agent/skills/ui-ux-pro-max/data/stacks/nuxt-ui.csv +51 -51
- package/.agent/skills/ui-ux-pro-max/data/stacks/nuxtjs.csv +59 -59
- package/.agent/skills/ui-ux-pro-max/data/stacks/react-native.csv +52 -52
- package/.agent/skills/ui-ux-pro-max/data/stacks/react.csv +54 -54
- package/.agent/skills/ui-ux-pro-max/data/stacks/shadcn.csv +61 -61
- package/.agent/skills/ui-ux-pro-max/data/stacks/svelte.csv +54 -54
- package/.agent/skills/ui-ux-pro-max/data/stacks/swiftui.csv +51 -51
- package/.agent/skills/ui-ux-pro-max/data/stacks/vue.csv +50 -50
- package/.agent/skills/ui-ux-pro-max/data/styles.csv +68 -68
- package/.agent/skills/ui-ux-pro-max/data/typography.csv +57 -57
- package/.agent/skills/ui-ux-pro-max/data/ui-reasoning.csv +101 -101
- package/.agent/skills/ui-ux-pro-max/data/ux-guidelines.csv +99 -99
- package/.agent/skills/ui-ux-pro-max/data/web-interface.csv +31 -31
- package/.agent/skills/ui-ux-pro-max/scripts/core.py +253 -253
- package/.agent/skills/ui-ux-pro-max/scripts/design_system.py +1067 -1067
- package/.agent/skills/ui-ux-pro-max/scripts/search.py +114 -114
- package/.agent/skills/verification-loop/SKILL.md +126 -126
- package/.agent/skills/video-editing/SKILL.md +310 -310
- package/.agent/skills/videodb/SKILL.md +374 -374
- package/.agent/skills/videodb/reference/api-reference.md +550 -550
- package/.agent/skills/videodb/reference/capture-reference.md +407 -407
- package/.agent/skills/videodb/reference/capture.md +101 -101
- package/.agent/skills/videodb/reference/editor.md +443 -443
- package/.agent/skills/videodb/reference/generative.md +331 -331
- package/.agent/skills/videodb/reference/rtstream-reference.md +564 -564
- package/.agent/skills/videodb/reference/rtstream.md +65 -65
- package/.agent/skills/videodb/reference/search.md +230 -230
- package/.agent/skills/videodb/reference/streaming.md +406 -406
- package/.agent/skills/videodb/reference/use-cases.md +118 -118
- package/.agent/skills/videodb/scripts/ws-listener.py +282 -282
- package/.agent/skills/visa-doc-translate/SKILL.md +117 -117
- package/.agent/skills/visa-doc-translate/readme.md +86 -86
- package/.agent/skills/vulnerability-scanner/SKILL.md +276 -276
- package/.agent/skills/vulnerability-scanner/checklists.md +121 -121
- package/.agent/skills/vulnerability-scanner/scripts/security_scan.py +458 -458
- package/.agent/skills/web-design-guidelines/SKILL.md +57 -57
- package/.agent/skills/webapp-testing/SKILL.md +187 -187
- package/.agent/skills/webapp-testing/scripts/playwright_runner.py +173 -173
- package/.agent/skills/workspace-surface-audit/SKILL.md +125 -125
- package/.agent/skills/x-api/SKILL.md +230 -230
- package/.agent/tasks/lessons.md +40 -40
- package/.agent/tasks/todo.md +33 -33
- package/.agent/tasks/two-track-merge-contract.md +1 -1
- package/.agent/workflows/aside.md +164 -164
- package/.agent/workflows/brainstorm.md +113 -113
- package/.agent/workflows/build-fix.md +62 -62
- package/.agent/workflows/checkpoint.md +74 -74
- package/.agent/workflows/claw.md +23 -23
- package/.agent/workflows/clean-memory.md +34 -34
- package/.agent/workflows/code-review.md +289 -289
- package/.agent/workflows/context-budget.md +23 -23
- package/.agent/workflows/cpp-build.md +173 -173
- package/.agent/workflows/cpp-review.md +132 -132
- package/.agent/workflows/cpp-test.md +251 -251
- package/.agent/workflows/create.md +59 -59
- package/.agent/workflows/debug.md +103 -103
- package/.agent/workflows/deploy.md +176 -176
- package/.agent/workflows/devfleet.md +23 -23
- package/.agent/workflows/docs.md +23 -23
- package/.agent/workflows/e2e.md +268 -268
- package/.agent/workflows/enhance.md +63 -63
- package/.agent/workflows/eval.md +23 -23
- package/.agent/workflows/evolve.md +178 -178
- package/.agent/workflows/flutter-build.md +164 -164
- package/.agent/workflows/flutter-review.md +116 -116
- package/.agent/workflows/flutter-test.md +144 -144
- package/.agent/workflows/gan-build.md +99 -99
- package/.agent/workflows/gan-design.md +35 -35
- package/.agent/workflows/go-build.md +183 -183
- package/.agent/workflows/go-review.md +148 -148
- package/.agent/workflows/go-test.md +268 -268
- package/.agent/workflows/gradle-build.md +70 -70
- package/.agent/workflows/harness-audit.md +73 -73
- package/.agent/workflows/init-docs.md +46 -46
- package/.agent/workflows/instinct-export.md +66 -66
- package/.agent/workflows/instinct-import.md +114 -114
- package/.agent/workflows/instinct-status.md +59 -59
- package/.agent/workflows/jira.md +106 -106
- package/.agent/workflows/kotlin-build.md +174 -174
- package/.agent/workflows/kotlin-review.md +140 -140
- package/.agent/workflows/kotlin-test.md +312 -312
- package/.agent/workflows/learn-eval.md +116 -116
- package/.agent/workflows/learn.md +70 -70
- package/.agent/workflows/loop-start.md +32 -32
- package/.agent/workflows/loop-status.md +24 -24
- package/.agent/workflows/model-route.md +26 -26
- package/.agent/workflows/multi-backend.md +158 -158
- package/.agent/workflows/multi-execute.md +315 -315
- package/.agent/workflows/multi-frontend.md +158 -158
- package/.agent/workflows/multi-plan.md +268 -268
- package/.agent/workflows/multi-workflow.md +191 -191
- package/.agent/workflows/orchestrate.md +135 -135
- package/.agent/workflows/plan.md +117 -117
- package/.agent/workflows/pm2.md +272 -272
- package/.agent/workflows/preview.md +81 -81
- package/.agent/workflows/projects.md +39 -39
- package/.agent/workflows/promote.md +41 -41
- package/.agent/workflows/prompt-optimize.md +23 -23
- package/.agent/workflows/prp-commit.md +112 -112
- package/.agent/workflows/prp-implement.md +385 -385
- package/.agent/workflows/prp-plan.md +502 -502
- package/.agent/workflows/prp-pr.md +184 -184
- package/.agent/workflows/prp-prd.md +447 -447
- package/.agent/workflows/prune.md +31 -31
- package/.agent/workflows/python-review.md +297 -297
- package/.agent/workflows/quality-gate.md +29 -29
- package/.agent/workflows/refactor-clean.md +80 -80
- package/.agent/workflows/resume-session.md +156 -156
- package/.agent/workflows/rules-distill.md +20 -20
- package/.agent/workflows/rust-build.md +187 -187
- package/.agent/workflows/rust-review.md +142 -142
- package/.agent/workflows/rust-test.md +308 -308
- package/.agent/workflows/santa-loop.md +175 -175
- package/.agent/workflows/save-session.md +275 -275
- package/.agent/workflows/sessions.md +333 -333
- package/.agent/workflows/setup-pm.md +80 -80
- package/.agent/workflows/skill-create.md +174 -174
- package/.agent/workflows/skill-health.md +54 -54
- package/.agent/workflows/status.md +86 -86
- package/.agent/workflows/tdd.md +231 -231
- package/.agent/workflows/test-coverage.md +69 -69
- package/.agent/workflows/test.md +144 -144
- package/.agent/workflows/ui-ux-pro-max.md +295 -295
- package/.agent/workflows/update-codemaps.md +72 -72
- package/.agent/workflows/update-docs.md +84 -84
- package/.agent/workflows/verify.md +23 -23
- package/LICENSE +176 -176
- package/README.md +144 -144
- package/package.json +1 -1
- package/scripts/release-check.js +55 -55
- package/src/bin/cli.js +424 -354
- package/src/lib/installer.js +223 -11
|
@@ -1,374 +1,374 @@
|
|
|
1
|
-
---
|
|
2
|
-
name: videodb
|
|
3
|
-
description: See, Understand, Act on video and audio. See- ingest from local files, URLs, RTSP/live feeds, or live record desktop; return realtime context and playable stream links. Understand- extract frames, build visual/semantic/temporal indexes, and search moments with timestamps and auto-clips. Act- transcode and normalize (codec, fps, resolution, aspect ratio), perform timeline edits (subtitles, text/image overlays, branding, audio overlays, dubbing, translation), generate media assets (image, audio, video), and create real time alerts for events from live streams or desktop capture.
|
|
4
|
-
origin: ECC
|
|
5
|
-
allowed-tools: Read Grep Glob Bash(python:*)
|
|
6
|
-
argument-hint: "[task description]"
|
|
7
|
-
---
|
|
8
|
-
|
|
9
|
-
# VideoDB Skill
|
|
10
|
-
|
|
11
|
-
**Perception + memory + actions for video, live streams, and desktop sessions.**
|
|
12
|
-
|
|
13
|
-
## When to use
|
|
14
|
-
|
|
15
|
-
### Desktop Perception
|
|
16
|
-
- Start/stop a **desktop session** capturing **screen, mic, and system audio**
|
|
17
|
-
- Stream **live context** and store **episodic session memory**
|
|
18
|
-
- Run **real-time alerts/triggers** on what's spoken and what's happening on screen
|
|
19
|
-
- Produce **session summaries**, a searchable timeline, and **playable evidence links**
|
|
20
|
-
|
|
21
|
-
### Video ingest + stream
|
|
22
|
-
- Ingest a **file or URL** and return a **playable web stream link**
|
|
23
|
-
- Transcode/normalize: **codec, bitrate, fps, resolution, aspect ratio**
|
|
24
|
-
|
|
25
|
-
### Index + search (timestamps + evidence)
|
|
26
|
-
- Build **visual**, **spoken**, and **keyword** indexes
|
|
27
|
-
- Search and return exact moments with **timestamps** and **playable evidence**
|
|
28
|
-
- Auto-create **clips** from search results
|
|
29
|
-
|
|
30
|
-
### Timeline editing + generation
|
|
31
|
-
- Subtitles: **generate**, **translate**, **burn-in**
|
|
32
|
-
- Overlays: **text/image/branding**, motion captions
|
|
33
|
-
- Audio: **background music**, **voiceover**, **dubbing**
|
|
34
|
-
- Programmatic composition and exports via **timeline operations**
|
|
35
|
-
|
|
36
|
-
### Live streams (RTSP) + monitoring
|
|
37
|
-
- Connect **RTSP/live feeds**
|
|
38
|
-
- Run **real-time visual and spoken understanding** and emit **events/alerts** for monitoring workflows
|
|
39
|
-
|
|
40
|
-
## How it works
|
|
41
|
-
|
|
42
|
-
### Common inputs
|
|
43
|
-
- Local **file path**, public **URL**, or **RTSP URL**
|
|
44
|
-
- Desktop capture request: **start / stop / summarize session**
|
|
45
|
-
- Desired operations: get context for understanding, transcode spec, index spec, search query, clip ranges, timeline edits, alert rules
|
|
46
|
-
|
|
47
|
-
### Common outputs
|
|
48
|
-
- **Stream URL**
|
|
49
|
-
- Search results with **timestamps** and **evidence links**
|
|
50
|
-
- Generated assets: subtitles, audio, images, clips
|
|
51
|
-
- **Event/alert payloads** for live streams
|
|
52
|
-
- Desktop **session summaries** and memory entries
|
|
53
|
-
|
|
54
|
-
### Running Python code
|
|
55
|
-
|
|
56
|
-
Before running any VideoDB code, change to the project directory and load environment variables:
|
|
57
|
-
|
|
58
|
-
```python
|
|
59
|
-
from dotenv import load_dotenv
|
|
60
|
-
load_dotenv(".env")
|
|
61
|
-
|
|
62
|
-
import videodb
|
|
63
|
-
conn = videodb.connect()
|
|
64
|
-
```
|
|
65
|
-
|
|
66
|
-
This reads `VIDEO_DB_API_KEY` from:
|
|
67
|
-
1. Environment (if already exported)
|
|
68
|
-
2. Project's `.env` file in current directory
|
|
69
|
-
|
|
70
|
-
If the key is missing, `videodb.connect()` raises `AuthenticationError` automatically.
|
|
71
|
-
|
|
72
|
-
Do NOT write a script file when a short inline command works.
|
|
73
|
-
|
|
74
|
-
When writing inline Python (`python -c "..."`), always use properly formatted code — use semicolons to separate statements and keep it readable. For anything longer than ~3 statements, use a heredoc instead:
|
|
75
|
-
|
|
76
|
-
```bash
|
|
77
|
-
python << 'EOF'
|
|
78
|
-
from dotenv import load_dotenv
|
|
79
|
-
load_dotenv(".env")
|
|
80
|
-
|
|
81
|
-
import videodb
|
|
82
|
-
conn = videodb.connect()
|
|
83
|
-
coll = conn.get_collection()
|
|
84
|
-
print(f"Videos: {len(coll.get_videos())}")
|
|
85
|
-
EOF
|
|
86
|
-
```
|
|
87
|
-
|
|
88
|
-
### Setup
|
|
89
|
-
|
|
90
|
-
When the user asks to "setup videodb" or similar:
|
|
91
|
-
|
|
92
|
-
### 1. Install SDK
|
|
93
|
-
|
|
94
|
-
```bash
|
|
95
|
-
pip install "videodb[capture]" python-dotenv
|
|
96
|
-
```
|
|
97
|
-
|
|
98
|
-
If `videodb[capture]` fails on Linux, install without the capture extra:
|
|
99
|
-
|
|
100
|
-
```bash
|
|
101
|
-
pip install videodb python-dotenv
|
|
102
|
-
```
|
|
103
|
-
|
|
104
|
-
### 2. Configure API key
|
|
105
|
-
|
|
106
|
-
The user must set `VIDEO_DB_API_KEY` using **either** method:
|
|
107
|
-
|
|
108
|
-
- **Export in terminal** (before starting Claude): `export VIDEO_DB_API_KEY=your-key`
|
|
109
|
-
- **Project `.env` file**: Save `VIDEO_DB_API_KEY=your-key` in the project's `.env` file
|
|
110
|
-
|
|
111
|
-
Get a free API key at [console.videodb.io](https://console.videodb.io) (50 free uploads, no credit card).
|
|
112
|
-
|
|
113
|
-
**Do NOT** read, write, or handle the API key yourself. Always let the user set it.
|
|
114
|
-
|
|
115
|
-
### Quick Reference
|
|
116
|
-
|
|
117
|
-
### Upload media
|
|
118
|
-
|
|
119
|
-
```python
|
|
120
|
-
# URL
|
|
121
|
-
video = coll.upload(url="https://example.com/video.mp4")
|
|
122
|
-
|
|
123
|
-
# YouTube
|
|
124
|
-
video = coll.upload(url="https://www.youtube.com/watch?v=VIDEO_ID")
|
|
125
|
-
|
|
126
|
-
# Local file
|
|
127
|
-
video = coll.upload(file_path="/path/to/video.mp4")
|
|
128
|
-
```
|
|
129
|
-
|
|
130
|
-
### Transcript + subtitle
|
|
131
|
-
|
|
132
|
-
```python
|
|
133
|
-
# force=True skips the error if the video is already indexed
|
|
134
|
-
video.index_spoken_words(force=True)
|
|
135
|
-
text = video.get_transcript_text()
|
|
136
|
-
stream_url = video.add_subtitle()
|
|
137
|
-
```
|
|
138
|
-
|
|
139
|
-
### Search inside videos
|
|
140
|
-
|
|
141
|
-
```python
|
|
142
|
-
from videodb.exceptions import InvalidRequestError
|
|
143
|
-
|
|
144
|
-
video.index_spoken_words(force=True)
|
|
145
|
-
|
|
146
|
-
# search() raises InvalidRequestError when no results are found.
|
|
147
|
-
# Always wrap in try/except and treat "No results found" as empty.
|
|
148
|
-
try:
|
|
149
|
-
results = video.search("product demo")
|
|
150
|
-
shots = results.get_shots()
|
|
151
|
-
stream_url = results.compile()
|
|
152
|
-
except InvalidRequestError as e:
|
|
153
|
-
if "No results found" in str(e):
|
|
154
|
-
shots = []
|
|
155
|
-
else:
|
|
156
|
-
raise
|
|
157
|
-
```
|
|
158
|
-
|
|
159
|
-
### Scene search
|
|
160
|
-
|
|
161
|
-
```python
|
|
162
|
-
import re
|
|
163
|
-
from videodb import SearchType, IndexType, SceneExtractionType
|
|
164
|
-
from videodb.exceptions import InvalidRequestError
|
|
165
|
-
|
|
166
|
-
# index_scenes() has no force parameter — it raises an error if a scene
|
|
167
|
-
# index already exists. Extract the existing index ID from the error.
|
|
168
|
-
try:
|
|
169
|
-
scene_index_id = video.index_scenes(
|
|
170
|
-
extraction_type=SceneExtractionType.shot_based,
|
|
171
|
-
prompt="Describe the visual content in this scene.",
|
|
172
|
-
)
|
|
173
|
-
except Exception as e:
|
|
174
|
-
match = re.search(r"id\s+([a-f0-9]+)", str(e))
|
|
175
|
-
if match:
|
|
176
|
-
scene_index_id = match.group(1)
|
|
177
|
-
else:
|
|
178
|
-
raise
|
|
179
|
-
|
|
180
|
-
# Use score_threshold to filter low-relevance noise (recommended: 0.3+)
|
|
181
|
-
try:
|
|
182
|
-
results = video.search(
|
|
183
|
-
query="person writing on a whiteboard",
|
|
184
|
-
search_type=SearchType.semantic,
|
|
185
|
-
index_type=IndexType.scene,
|
|
186
|
-
scene_index_id=scene_index_id,
|
|
187
|
-
score_threshold=0.3,
|
|
188
|
-
)
|
|
189
|
-
shots = results.get_shots()
|
|
190
|
-
stream_url = results.compile()
|
|
191
|
-
except InvalidRequestError as e:
|
|
192
|
-
if "No results found" in str(e):
|
|
193
|
-
shots = []
|
|
194
|
-
else:
|
|
195
|
-
raise
|
|
196
|
-
```
|
|
197
|
-
|
|
198
|
-
### Timeline editing
|
|
199
|
-
|
|
200
|
-
**Important:** Always validate timestamps before building a timeline:
|
|
201
|
-
- `start` must be >= 0 (negative values are silently accepted but produce broken output)
|
|
202
|
-
- `start` must be < `end`
|
|
203
|
-
- `end` must be <= `video.length`
|
|
204
|
-
|
|
205
|
-
```python
|
|
206
|
-
from videodb.timeline import Timeline
|
|
207
|
-
from videodb.asset import VideoAsset, TextAsset, TextStyle
|
|
208
|
-
|
|
209
|
-
timeline = Timeline(conn)
|
|
210
|
-
timeline.add_inline(VideoAsset(asset_id=video.id, start=10, end=30))
|
|
211
|
-
timeline.add_overlay(0, TextAsset(text="The End", duration=3, style=TextStyle(fontsize=36)))
|
|
212
|
-
stream_url = timeline.generate_stream()
|
|
213
|
-
```
|
|
214
|
-
|
|
215
|
-
### Transcode video (resolution / quality change)
|
|
216
|
-
|
|
217
|
-
```python
|
|
218
|
-
from videodb import TranscodeMode, VideoConfig, AudioConfig
|
|
219
|
-
|
|
220
|
-
# Change resolution, quality, or aspect ratio server-side
|
|
221
|
-
job_id = conn.transcode(
|
|
222
|
-
source="https://example.com/video.mp4",
|
|
223
|
-
callback_url="https://example.com/webhook",
|
|
224
|
-
mode=TranscodeMode.economy,
|
|
225
|
-
video_config=VideoConfig(resolution=720, quality=23, aspect_ratio="16:9"),
|
|
226
|
-
audio_config=AudioConfig(mute=False),
|
|
227
|
-
)
|
|
228
|
-
```
|
|
229
|
-
|
|
230
|
-
### Reframe aspect ratio (for social platforms)
|
|
231
|
-
|
|
232
|
-
**Warning:** `reframe()` is a slow server-side operation. For long videos it can take
|
|
233
|
-
several minutes and may time out. Best practices:
|
|
234
|
-
- Always limit to a short segment using `start`/`end` when possible
|
|
235
|
-
- For full-length videos, use `callback_url` for async processing
|
|
236
|
-
- Trim the video on a `Timeline` first, then reframe the shorter result
|
|
237
|
-
|
|
238
|
-
```python
|
|
239
|
-
from videodb import ReframeMode
|
|
240
|
-
|
|
241
|
-
# Always prefer reframing a short segment:
|
|
242
|
-
reframed = video.reframe(start=0, end=60, target="vertical", mode=ReframeMode.smart)
|
|
243
|
-
|
|
244
|
-
# Async reframe for full-length videos (returns None, result via webhook):
|
|
245
|
-
video.reframe(target="vertical", callback_url="https://example.com/webhook")
|
|
246
|
-
|
|
247
|
-
# Presets: "vertical" (9:16), "square" (1:1), "landscape" (16:9)
|
|
248
|
-
reframed = video.reframe(start=0, end=60, target="square")
|
|
249
|
-
|
|
250
|
-
# Custom dimensions
|
|
251
|
-
reframed = video.reframe(start=0, end=60, target={"width": 1280, "height": 720})
|
|
252
|
-
```
|
|
253
|
-
|
|
254
|
-
### Generative media
|
|
255
|
-
|
|
256
|
-
```python
|
|
257
|
-
image = coll.generate_image(
|
|
258
|
-
prompt="a sunset over mountains",
|
|
259
|
-
aspect_ratio="16:9",
|
|
260
|
-
)
|
|
261
|
-
```
|
|
262
|
-
|
|
263
|
-
## Error handling
|
|
264
|
-
|
|
265
|
-
```python
|
|
266
|
-
from videodb.exceptions import AuthenticationError, InvalidRequestError
|
|
267
|
-
|
|
268
|
-
try:
|
|
269
|
-
conn = videodb.connect()
|
|
270
|
-
except AuthenticationError:
|
|
271
|
-
print("Check your VIDEO_DB_API_KEY")
|
|
272
|
-
|
|
273
|
-
try:
|
|
274
|
-
video = coll.upload(url="https://example.com/video.mp4")
|
|
275
|
-
except InvalidRequestError as e:
|
|
276
|
-
print(f"Upload failed: {e}")
|
|
277
|
-
```
|
|
278
|
-
|
|
279
|
-
### Common pitfalls
|
|
280
|
-
|
|
281
|
-
| Scenario | Error message | Solution |
|
|
282
|
-
|----------|--------------|----------|
|
|
283
|
-
| Indexing an already-indexed video | `Spoken word index for video already exists` | Use `video.index_spoken_words(force=True)` to skip if already indexed |
|
|
284
|
-
| Scene index already exists | `Scene index with id XXXX already exists` | Extract the existing `scene_index_id` from the error with `re.search(r"id\s+([a-f0-9]+)", str(e))` |
|
|
285
|
-
| Search finds no matches | `InvalidRequestError: No results found` | Catch the exception and treat as empty results (`shots = []`) |
|
|
286
|
-
| Reframe times out | Blocks indefinitely on long videos | Use `start`/`end` to limit segment, or pass `callback_url` for async |
|
|
287
|
-
| Negative timestamps on Timeline | Silently produces broken stream | Always validate `start >= 0` before creating `VideoAsset` |
|
|
288
|
-
| `generate_video()` / `create_collection()` fails | `Operation not allowed` or `maximum limit` | Plan-gated features — inform the user about plan limits |
|
|
289
|
-
|
|
290
|
-
## Examples
|
|
291
|
-
|
|
292
|
-
### Canonical prompts
|
|
293
|
-
- "Start desktop capture and alert when a password field appears."
|
|
294
|
-
- "Record my session and produce an actionable summary when it ends."
|
|
295
|
-
- "Ingest this file and return a playable stream link."
|
|
296
|
-
- "Index this folder and find every scene with people, return timestamps."
|
|
297
|
-
- "Generate subtitles, burn them in, and add light background music."
|
|
298
|
-
- "Connect this RTSP URL and alert when a person enters the zone."
|
|
299
|
-
|
|
300
|
-
### Screen Recording (Desktop Capture)
|
|
301
|
-
|
|
302
|
-
Use `ws_listener.py` to capture WebSocket events during recording sessions. Desktop capture supports **macOS** only.
|
|
303
|
-
|
|
304
|
-
#### Quick Start
|
|
305
|
-
|
|
306
|
-
1. **Choose state dir**: `STATE_DIR="${VIDEODB_EVENTS_DIR:-$HOME/.local/state/videodb}"`
|
|
307
|
-
2. **Start listener**: `VIDEODB_EVENTS_DIR="$STATE_DIR" python scripts/ws_listener.py --clear "$STATE_DIR" &`
|
|
308
|
-
3. **Get WebSocket ID**: `cat "$STATE_DIR/videodb_ws_id"`
|
|
309
|
-
4. **Run capture code** (see reference/capture.md for the full workflow)
|
|
310
|
-
5. **Events written to**: `$STATE_DIR/videodb_events.jsonl`
|
|
311
|
-
|
|
312
|
-
Use `--clear` whenever you start a fresh capture run so stale transcript and visual events do not leak into the new session.
|
|
313
|
-
|
|
314
|
-
#### Query Events
|
|
315
|
-
|
|
316
|
-
```python
|
|
317
|
-
import json
|
|
318
|
-
import os
|
|
319
|
-
import time
|
|
320
|
-
from pathlib import Path
|
|
321
|
-
|
|
322
|
-
events_dir = Path(os.environ.get("VIDEODB_EVENTS_DIR", Path.home() / ".local" / "state" / "videodb"))
|
|
323
|
-
events_file = events_dir / "videodb_events.jsonl"
|
|
324
|
-
events = []
|
|
325
|
-
|
|
326
|
-
if events_file.exists():
|
|
327
|
-
with events_file.open(encoding="utf-8") as handle:
|
|
328
|
-
for line in handle:
|
|
329
|
-
try:
|
|
330
|
-
events.append(json.loads(line))
|
|
331
|
-
except json.JSONDecodeError:
|
|
332
|
-
continue
|
|
333
|
-
|
|
334
|
-
transcripts = [e["data"]["text"] for e in events if e.get("channel") == "transcript"]
|
|
335
|
-
cutoff = time.time() - 300
|
|
336
|
-
recent_visual = [
|
|
337
|
-
e for e in events
|
|
338
|
-
if e.get("channel") == "visual_index" and e["unix_ts"] > cutoff
|
|
339
|
-
]
|
|
340
|
-
```
|
|
341
|
-
|
|
342
|
-
## Additional docs
|
|
343
|
-
|
|
344
|
-
Reference documentation is in the `reference/` directory adjacent to this SKILL.md file. Use the Glob tool to locate it if needed.
|
|
345
|
-
|
|
346
|
-
- [reference/api-reference.md](reference/api-reference.md) - Complete VideoDB Python SDK API reference
|
|
347
|
-
- [reference/search.md](reference/search.md) - In-depth guide to video search (spoken word and scene-based)
|
|
348
|
-
- [reference/editor.md](reference/editor.md) - Timeline editing, assets, and composition
|
|
349
|
-
- [reference/streaming.md](reference/streaming.md) - HLS streaming and instant playback
|
|
350
|
-
- [reference/generative.md](reference/generative.md) - AI-powered media generation (images, video, audio)
|
|
351
|
-
- [reference/rtstream.md](reference/rtstream.md) - Live stream ingestion workflow (RTSP/RTMP)
|
|
352
|
-
- [reference/rtstream-reference.md](reference/rtstream-reference.md) - RTStream SDK methods and AI pipelines
|
|
353
|
-
- [reference/capture.md](reference/capture.md) - Desktop capture workflow
|
|
354
|
-
- [reference/capture-reference.md](reference/capture-reference.md) - Capture SDK and WebSocket events
|
|
355
|
-
- [reference/use-cases.md](reference/use-cases.md) - Common video processing patterns and examples
|
|
356
|
-
|
|
357
|
-
**Do not use ffmpeg, moviepy, or local encoding tools** when VideoDB supports the operation. The following are all handled server-side by VideoDB — trimming, combining clips, overlaying audio or music, adding subtitles, text/image overlays, transcoding, resolution changes, aspect-ratio conversion, resizing for platform requirements, transcription, and media generation. Only fall back to local tools for operations listed under Limitations in reference/editor.md (transitions, speed changes, crop/zoom, colour grading, volume mixing).
|
|
358
|
-
|
|
359
|
-
### When to use what
|
|
360
|
-
|
|
361
|
-
| Problem | VideoDB solution |
|
|
362
|
-
|---------|-----------------|
|
|
363
|
-
| Platform rejects video aspect ratio or resolution | `video.reframe()` or `conn.transcode()` with `VideoConfig` |
|
|
364
|
-
| Need to resize video for Twitter/Instagram/TikTok | `video.reframe(target="vertical")` or `target="square"` |
|
|
365
|
-
| Need to change resolution (e.g. 1080p → 720p) | `conn.transcode()` with `VideoConfig(resolution=720)` |
|
|
366
|
-
| Need to overlay audio/music on video | `AudioAsset` on a `Timeline` |
|
|
367
|
-
| Need to add subtitles | `video.add_subtitle()` or `CaptionAsset` |
|
|
368
|
-
| Need to combine/trim clips | `VideoAsset` on a `Timeline` |
|
|
369
|
-
| Need to generate voiceover, music, or SFX | `coll.generate_voice()`, `generate_music()`, `generate_sound_effect()` |
|
|
370
|
-
|
|
371
|
-
## Provenance
|
|
372
|
-
|
|
373
|
-
Reference material for this skill is vendored locally under `skills/videodb/reference/`.
|
|
374
|
-
Use the local copies above instead of following external repository links at runtime.
|
|
1
|
+
---
|
|
2
|
+
name: videodb
|
|
3
|
+
description: See, Understand, Act on video and audio. See- ingest from local files, URLs, RTSP/live feeds, or live record desktop; return realtime context and playable stream links. Understand- extract frames, build visual/semantic/temporal indexes, and search moments with timestamps and auto-clips. Act- transcode and normalize (codec, fps, resolution, aspect ratio), perform timeline edits (subtitles, text/image overlays, branding, audio overlays, dubbing, translation), generate media assets (image, audio, video), and create real time alerts for events from live streams or desktop capture.
|
|
4
|
+
origin: ECC
|
|
5
|
+
allowed-tools: Read Grep Glob Bash(python:*)
|
|
6
|
+
argument-hint: "[task description]"
|
|
7
|
+
---
|
|
8
|
+
|
|
9
|
+
# VideoDB Skill
|
|
10
|
+
|
|
11
|
+
**Perception + memory + actions for video, live streams, and desktop sessions.**
|
|
12
|
+
|
|
13
|
+
## When to use
|
|
14
|
+
|
|
15
|
+
### Desktop Perception
|
|
16
|
+
- Start/stop a **desktop session** capturing **screen, mic, and system audio**
|
|
17
|
+
- Stream **live context** and store **episodic session memory**
|
|
18
|
+
- Run **real-time alerts/triggers** on what's spoken and what's happening on screen
|
|
19
|
+
- Produce **session summaries**, a searchable timeline, and **playable evidence links**
|
|
20
|
+
|
|
21
|
+
### Video ingest + stream
|
|
22
|
+
- Ingest a **file or URL** and return a **playable web stream link**
|
|
23
|
+
- Transcode/normalize: **codec, bitrate, fps, resolution, aspect ratio**
|
|
24
|
+
|
|
25
|
+
### Index + search (timestamps + evidence)
|
|
26
|
+
- Build **visual**, **spoken**, and **keyword** indexes
|
|
27
|
+
- Search and return exact moments with **timestamps** and **playable evidence**
|
|
28
|
+
- Auto-create **clips** from search results
|
|
29
|
+
|
|
30
|
+
### Timeline editing + generation
|
|
31
|
+
- Subtitles: **generate**, **translate**, **burn-in**
|
|
32
|
+
- Overlays: **text/image/branding**, motion captions
|
|
33
|
+
- Audio: **background music**, **voiceover**, **dubbing**
|
|
34
|
+
- Programmatic composition and exports via **timeline operations**
|
|
35
|
+
|
|
36
|
+
### Live streams (RTSP) + monitoring
|
|
37
|
+
- Connect **RTSP/live feeds**
|
|
38
|
+
- Run **real-time visual and spoken understanding** and emit **events/alerts** for monitoring workflows
|
|
39
|
+
|
|
40
|
+
## How it works
|
|
41
|
+
|
|
42
|
+
### Common inputs
|
|
43
|
+
- Local **file path**, public **URL**, or **RTSP URL**
|
|
44
|
+
- Desktop capture request: **start / stop / summarize session**
|
|
45
|
+
- Desired operations: get context for understanding, transcode spec, index spec, search query, clip ranges, timeline edits, alert rules
|
|
46
|
+
|
|
47
|
+
### Common outputs
|
|
48
|
+
- **Stream URL**
|
|
49
|
+
- Search results with **timestamps** and **evidence links**
|
|
50
|
+
- Generated assets: subtitles, audio, images, clips
|
|
51
|
+
- **Event/alert payloads** for live streams
|
|
52
|
+
- Desktop **session summaries** and memory entries
|
|
53
|
+
|
|
54
|
+
### Running Python code
|
|
55
|
+
|
|
56
|
+
Before running any VideoDB code, change to the project directory and load environment variables:
|
|
57
|
+
|
|
58
|
+
```python
|
|
59
|
+
from dotenv import load_dotenv
|
|
60
|
+
load_dotenv(".env")
|
|
61
|
+
|
|
62
|
+
import videodb
|
|
63
|
+
conn = videodb.connect()
|
|
64
|
+
```
|
|
65
|
+
|
|
66
|
+
This reads `VIDEO_DB_API_KEY` from:
|
|
67
|
+
1. Environment (if already exported)
|
|
68
|
+
2. Project's `.env` file in current directory
|
|
69
|
+
|
|
70
|
+
If the key is missing, `videodb.connect()` raises `AuthenticationError` automatically.
|
|
71
|
+
|
|
72
|
+
Do NOT write a script file when a short inline command works.
|
|
73
|
+
|
|
74
|
+
When writing inline Python (`python -c "..."`), always use properly formatted code — use semicolons to separate statements and keep it readable. For anything longer than ~3 statements, use a heredoc instead:
|
|
75
|
+
|
|
76
|
+
```bash
|
|
77
|
+
python << 'EOF'
|
|
78
|
+
from dotenv import load_dotenv
|
|
79
|
+
load_dotenv(".env")
|
|
80
|
+
|
|
81
|
+
import videodb
|
|
82
|
+
conn = videodb.connect()
|
|
83
|
+
coll = conn.get_collection()
|
|
84
|
+
print(f"Videos: {len(coll.get_videos())}")
|
|
85
|
+
EOF
|
|
86
|
+
```
|
|
87
|
+
|
|
88
|
+
### Setup
|
|
89
|
+
|
|
90
|
+
When the user asks to "setup videodb" or similar:
|
|
91
|
+
|
|
92
|
+
### 1. Install SDK
|
|
93
|
+
|
|
94
|
+
```bash
|
|
95
|
+
pip install "videodb[capture]" python-dotenv
|
|
96
|
+
```
|
|
97
|
+
|
|
98
|
+
If `videodb[capture]` fails on Linux, install without the capture extra:
|
|
99
|
+
|
|
100
|
+
```bash
|
|
101
|
+
pip install videodb python-dotenv
|
|
102
|
+
```
|
|
103
|
+
|
|
104
|
+
### 2. Configure API key
|
|
105
|
+
|
|
106
|
+
The user must set `VIDEO_DB_API_KEY` using **either** method:
|
|
107
|
+
|
|
108
|
+
- **Export in terminal** (before starting Claude): `export VIDEO_DB_API_KEY=your-key`
|
|
109
|
+
- **Project `.env` file**: Save `VIDEO_DB_API_KEY=your-key` in the project's `.env` file
|
|
110
|
+
|
|
111
|
+
Get a free API key at [console.videodb.io](https://console.videodb.io) (50 free uploads, no credit card).
|
|
112
|
+
|
|
113
|
+
**Do NOT** read, write, or handle the API key yourself. Always let the user set it.
|
|
114
|
+
|
|
115
|
+
### Quick Reference
|
|
116
|
+
|
|
117
|
+
### Upload media
|
|
118
|
+
|
|
119
|
+
```python
|
|
120
|
+
# URL
|
|
121
|
+
video = coll.upload(url="https://example.com/video.mp4")
|
|
122
|
+
|
|
123
|
+
# YouTube
|
|
124
|
+
video = coll.upload(url="https://www.youtube.com/watch?v=VIDEO_ID")
|
|
125
|
+
|
|
126
|
+
# Local file
|
|
127
|
+
video = coll.upload(file_path="/path/to/video.mp4")
|
|
128
|
+
```
|
|
129
|
+
|
|
130
|
+
### Transcript + subtitle
|
|
131
|
+
|
|
132
|
+
```python
|
|
133
|
+
# force=True skips the error if the video is already indexed
|
|
134
|
+
video.index_spoken_words(force=True)
|
|
135
|
+
text = video.get_transcript_text()
|
|
136
|
+
stream_url = video.add_subtitle()
|
|
137
|
+
```
|
|
138
|
+
|
|
139
|
+
### Search inside videos
|
|
140
|
+
|
|
141
|
+
```python
|
|
142
|
+
from videodb.exceptions import InvalidRequestError
|
|
143
|
+
|
|
144
|
+
video.index_spoken_words(force=True)
|
|
145
|
+
|
|
146
|
+
# search() raises InvalidRequestError when no results are found.
|
|
147
|
+
# Always wrap in try/except and treat "No results found" as empty.
|
|
148
|
+
try:
|
|
149
|
+
results = video.search("product demo")
|
|
150
|
+
shots = results.get_shots()
|
|
151
|
+
stream_url = results.compile()
|
|
152
|
+
except InvalidRequestError as e:
|
|
153
|
+
if "No results found" in str(e):
|
|
154
|
+
shots = []
|
|
155
|
+
else:
|
|
156
|
+
raise
|
|
157
|
+
```
|
|
158
|
+
|
|
159
|
+
### Scene search
|
|
160
|
+
|
|
161
|
+
```python
|
|
162
|
+
import re
|
|
163
|
+
from videodb import SearchType, IndexType, SceneExtractionType
|
|
164
|
+
from videodb.exceptions import InvalidRequestError
|
|
165
|
+
|
|
166
|
+
# index_scenes() has no force parameter — it raises an error if a scene
|
|
167
|
+
# index already exists. Extract the existing index ID from the error.
|
|
168
|
+
try:
|
|
169
|
+
scene_index_id = video.index_scenes(
|
|
170
|
+
extraction_type=SceneExtractionType.shot_based,
|
|
171
|
+
prompt="Describe the visual content in this scene.",
|
|
172
|
+
)
|
|
173
|
+
except Exception as e:
|
|
174
|
+
match = re.search(r"id\s+([a-f0-9]+)", str(e))
|
|
175
|
+
if match:
|
|
176
|
+
scene_index_id = match.group(1)
|
|
177
|
+
else:
|
|
178
|
+
raise
|
|
179
|
+
|
|
180
|
+
# Use score_threshold to filter low-relevance noise (recommended: 0.3+)
|
|
181
|
+
try:
|
|
182
|
+
results = video.search(
|
|
183
|
+
query="person writing on a whiteboard",
|
|
184
|
+
search_type=SearchType.semantic,
|
|
185
|
+
index_type=IndexType.scene,
|
|
186
|
+
scene_index_id=scene_index_id,
|
|
187
|
+
score_threshold=0.3,
|
|
188
|
+
)
|
|
189
|
+
shots = results.get_shots()
|
|
190
|
+
stream_url = results.compile()
|
|
191
|
+
except InvalidRequestError as e:
|
|
192
|
+
if "No results found" in str(e):
|
|
193
|
+
shots = []
|
|
194
|
+
else:
|
|
195
|
+
raise
|
|
196
|
+
```
|
|
197
|
+
|
|
198
|
+
### Timeline editing
|
|
199
|
+
|
|
200
|
+
**Important:** Always validate timestamps before building a timeline:
|
|
201
|
+
- `start` must be >= 0 (negative values are silently accepted but produce broken output)
|
|
202
|
+
- `start` must be < `end`
|
|
203
|
+
- `end` must be <= `video.length`
|
|
204
|
+
|
|
205
|
+
```python
|
|
206
|
+
from videodb.timeline import Timeline
|
|
207
|
+
from videodb.asset import VideoAsset, TextAsset, TextStyle
|
|
208
|
+
|
|
209
|
+
timeline = Timeline(conn)
|
|
210
|
+
timeline.add_inline(VideoAsset(asset_id=video.id, start=10, end=30))
|
|
211
|
+
timeline.add_overlay(0, TextAsset(text="The End", duration=3, style=TextStyle(fontsize=36)))
|
|
212
|
+
stream_url = timeline.generate_stream()
|
|
213
|
+
```
|
|
214
|
+
|
|
215
|
+
### Transcode video (resolution / quality change)
|
|
216
|
+
|
|
217
|
+
```python
|
|
218
|
+
from videodb import TranscodeMode, VideoConfig, AudioConfig
|
|
219
|
+
|
|
220
|
+
# Change resolution, quality, or aspect ratio server-side
|
|
221
|
+
job_id = conn.transcode(
|
|
222
|
+
source="https://example.com/video.mp4",
|
|
223
|
+
callback_url="https://example.com/webhook",
|
|
224
|
+
mode=TranscodeMode.economy,
|
|
225
|
+
video_config=VideoConfig(resolution=720, quality=23, aspect_ratio="16:9"),
|
|
226
|
+
audio_config=AudioConfig(mute=False),
|
|
227
|
+
)
|
|
228
|
+
```
|
|
229
|
+
|
|
230
|
+
### Reframe aspect ratio (for social platforms)
|
|
231
|
+
|
|
232
|
+
**Warning:** `reframe()` is a slow server-side operation. For long videos it can take
|
|
233
|
+
several minutes and may time out. Best practices:
|
|
234
|
+
- Always limit to a short segment using `start`/`end` when possible
|
|
235
|
+
- For full-length videos, use `callback_url` for async processing
|
|
236
|
+
- Trim the video on a `Timeline` first, then reframe the shorter result
|
|
237
|
+
|
|
238
|
+
```python
|
|
239
|
+
from videodb import ReframeMode
|
|
240
|
+
|
|
241
|
+
# Always prefer reframing a short segment:
|
|
242
|
+
reframed = video.reframe(start=0, end=60, target="vertical", mode=ReframeMode.smart)
|
|
243
|
+
|
|
244
|
+
# Async reframe for full-length videos (returns None, result via webhook):
|
|
245
|
+
video.reframe(target="vertical", callback_url="https://example.com/webhook")
|
|
246
|
+
|
|
247
|
+
# Presets: "vertical" (9:16), "square" (1:1), "landscape" (16:9)
|
|
248
|
+
reframed = video.reframe(start=0, end=60, target="square")
|
|
249
|
+
|
|
250
|
+
# Custom dimensions
|
|
251
|
+
reframed = video.reframe(start=0, end=60, target={"width": 1280, "height": 720})
|
|
252
|
+
```
|
|
253
|
+
|
|
254
|
+
### Generative media
|
|
255
|
+
|
|
256
|
+
```python
|
|
257
|
+
image = coll.generate_image(
|
|
258
|
+
prompt="a sunset over mountains",
|
|
259
|
+
aspect_ratio="16:9",
|
|
260
|
+
)
|
|
261
|
+
```
|
|
262
|
+
|
|
263
|
+
## Error handling
|
|
264
|
+
|
|
265
|
+
```python
|
|
266
|
+
from videodb.exceptions import AuthenticationError, InvalidRequestError
|
|
267
|
+
|
|
268
|
+
try:
|
|
269
|
+
conn = videodb.connect()
|
|
270
|
+
except AuthenticationError:
|
|
271
|
+
print("Check your VIDEO_DB_API_KEY")
|
|
272
|
+
|
|
273
|
+
try:
|
|
274
|
+
video = coll.upload(url="https://example.com/video.mp4")
|
|
275
|
+
except InvalidRequestError as e:
|
|
276
|
+
print(f"Upload failed: {e}")
|
|
277
|
+
```
|
|
278
|
+
|
|
279
|
+
### Common pitfalls
|
|
280
|
+
|
|
281
|
+
| Scenario | Error message | Solution |
|
|
282
|
+
|----------|--------------|----------|
|
|
283
|
+
| Indexing an already-indexed video | `Spoken word index for video already exists` | Use `video.index_spoken_words(force=True)` to skip if already indexed |
|
|
284
|
+
| Scene index already exists | `Scene index with id XXXX already exists` | Extract the existing `scene_index_id` from the error with `re.search(r"id\s+([a-f0-9]+)", str(e))` |
|
|
285
|
+
| Search finds no matches | `InvalidRequestError: No results found` | Catch the exception and treat as empty results (`shots = []`) |
|
|
286
|
+
| Reframe times out | Blocks indefinitely on long videos | Use `start`/`end` to limit segment, or pass `callback_url` for async |
|
|
287
|
+
| Negative timestamps on Timeline | Silently produces broken stream | Always validate `start >= 0` before creating `VideoAsset` |
|
|
288
|
+
| `generate_video()` / `create_collection()` fails | `Operation not allowed` or `maximum limit` | Plan-gated features — inform the user about plan limits |
|
|
289
|
+
|
|
290
|
+
## Examples
|
|
291
|
+
|
|
292
|
+
### Canonical prompts
|
|
293
|
+
- "Start desktop capture and alert when a password field appears."
|
|
294
|
+
- "Record my session and produce an actionable summary when it ends."
|
|
295
|
+
- "Ingest this file and return a playable stream link."
|
|
296
|
+
- "Index this folder and find every scene with people, return timestamps."
|
|
297
|
+
- "Generate subtitles, burn them in, and add light background music."
|
|
298
|
+
- "Connect this RTSP URL and alert when a person enters the zone."
|
|
299
|
+
|
|
300
|
+
### Screen Recording (Desktop Capture)
|
|
301
|
+
|
|
302
|
+
Use `ws_listener.py` to capture WebSocket events during recording sessions. Desktop capture supports **macOS** only.
|
|
303
|
+
|
|
304
|
+
#### Quick Start
|
|
305
|
+
|
|
306
|
+
1. **Choose state dir**: `STATE_DIR="${VIDEODB_EVENTS_DIR:-$HOME/.local/state/videodb}"`
|
|
307
|
+
2. **Start listener**: `VIDEODB_EVENTS_DIR="$STATE_DIR" python scripts/ws_listener.py --clear "$STATE_DIR" &`
|
|
308
|
+
3. **Get WebSocket ID**: `cat "$STATE_DIR/videodb_ws_id"`
|
|
309
|
+
4. **Run capture code** (see reference/capture.md for the full workflow)
|
|
310
|
+
5. **Events written to**: `$STATE_DIR/videodb_events.jsonl`
|
|
311
|
+
|
|
312
|
+
Use `--clear` whenever you start a fresh capture run so stale transcript and visual events do not leak into the new session.
|
|
313
|
+
|
|
314
|
+
#### Query Events
|
|
315
|
+
|
|
316
|
+
```python
|
|
317
|
+
import json
|
|
318
|
+
import os
|
|
319
|
+
import time
|
|
320
|
+
from pathlib import Path
|
|
321
|
+
|
|
322
|
+
events_dir = Path(os.environ.get("VIDEODB_EVENTS_DIR", Path.home() / ".local" / "state" / "videodb"))
|
|
323
|
+
events_file = events_dir / "videodb_events.jsonl"
|
|
324
|
+
events = []
|
|
325
|
+
|
|
326
|
+
if events_file.exists():
|
|
327
|
+
with events_file.open(encoding="utf-8") as handle:
|
|
328
|
+
for line in handle:
|
|
329
|
+
try:
|
|
330
|
+
events.append(json.loads(line))
|
|
331
|
+
except json.JSONDecodeError:
|
|
332
|
+
continue
|
|
333
|
+
|
|
334
|
+
transcripts = [e["data"]["text"] for e in events if e.get("channel") == "transcript"]
|
|
335
|
+
cutoff = time.time() - 300
|
|
336
|
+
recent_visual = [
|
|
337
|
+
e for e in events
|
|
338
|
+
if e.get("channel") == "visual_index" and e["unix_ts"] > cutoff
|
|
339
|
+
]
|
|
340
|
+
```
|
|
341
|
+
|
|
342
|
+
## Additional docs
|
|
343
|
+
|
|
344
|
+
Reference documentation is in the `reference/` directory adjacent to this SKILL.md file. Use the Glob tool to locate it if needed.
|
|
345
|
+
|
|
346
|
+
- [reference/api-reference.md](reference/api-reference.md) - Complete VideoDB Python SDK API reference
|
|
347
|
+
- [reference/search.md](reference/search.md) - In-depth guide to video search (spoken word and scene-based)
|
|
348
|
+
- [reference/editor.md](reference/editor.md) - Timeline editing, assets, and composition
|
|
349
|
+
- [reference/streaming.md](reference/streaming.md) - HLS streaming and instant playback
|
|
350
|
+
- [reference/generative.md](reference/generative.md) - AI-powered media generation (images, video, audio)
|
|
351
|
+
- [reference/rtstream.md](reference/rtstream.md) - Live stream ingestion workflow (RTSP/RTMP)
|
|
352
|
+
- [reference/rtstream-reference.md](reference/rtstream-reference.md) - RTStream SDK methods and AI pipelines
|
|
353
|
+
- [reference/capture.md](reference/capture.md) - Desktop capture workflow
|
|
354
|
+
- [reference/capture-reference.md](reference/capture-reference.md) - Capture SDK and WebSocket events
|
|
355
|
+
- [reference/use-cases.md](reference/use-cases.md) - Common video processing patterns and examples
|
|
356
|
+
|
|
357
|
+
**Do not use ffmpeg, moviepy, or local encoding tools** when VideoDB supports the operation. The following are all handled server-side by VideoDB — trimming, combining clips, overlaying audio or music, adding subtitles, text/image overlays, transcoding, resolution changes, aspect-ratio conversion, resizing for platform requirements, transcription, and media generation. Only fall back to local tools for operations listed under Limitations in reference/editor.md (transitions, speed changes, crop/zoom, colour grading, volume mixing).
|
|
358
|
+
|
|
359
|
+
### When to use what
|
|
360
|
+
|
|
361
|
+
| Problem | VideoDB solution |
|
|
362
|
+
|---------|-----------------|
|
|
363
|
+
| Platform rejects video aspect ratio or resolution | `video.reframe()` or `conn.transcode()` with `VideoConfig` |
|
|
364
|
+
| Need to resize video for Twitter/Instagram/TikTok | `video.reframe(target="vertical")` or `target="square"` |
|
|
365
|
+
| Need to change resolution (e.g. 1080p → 720p) | `conn.transcode()` with `VideoConfig(resolution=720)` |
|
|
366
|
+
| Need to overlay audio/music on video | `AudioAsset` on a `Timeline` |
|
|
367
|
+
| Need to add subtitles | `video.add_subtitle()` or `CaptionAsset` |
|
|
368
|
+
| Need to combine/trim clips | `VideoAsset` on a `Timeline` |
|
|
369
|
+
| Need to generate voiceover, music, or SFX | `coll.generate_voice()`, `generate_music()`, `generate_sound_effect()` |
|
|
370
|
+
|
|
371
|
+
## Provenance
|
|
372
|
+
|
|
373
|
+
Reference material for this skill is vendored locally under `skills/videodb/reference/`.
|
|
374
|
+
Use the local copies above instead of following external repository links at runtime.
|