@rubix0270/arboris 1.0.1 → 1.0.3

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (451) hide show
  1. package/package.json +8 -19
  2. package/run.mjs +10 -0
  3. package/dist/cli.mjs +0 -382
  4. package/manifest.json +0 -323
  5. package/prisma/skills/accessibility/SKILL.md +0 -147
  6. package/prisma/skills/agent-architecture-audit/SKILL.md +0 -257
  7. package/prisma/skills/agent-eval/SKILL.md +0 -146
  8. package/prisma/skills/agent-harness-construction/SKILL.md +0 -74
  9. package/prisma/skills/agent-introspection-debugging/SKILL.md +0 -154
  10. package/prisma/skills/agent-payment-x402/SKILL.md +0 -225
  11. package/prisma/skills/agent-self-evaluation/SKILL.md +0 -182
  12. package/prisma/skills/agent-self-evaluation/examples/high-score-example.md +0 -87
  13. package/prisma/skills/agent-self-evaluation/examples/low-score-example.md +0 -86
  14. package/prisma/skills/agent-self-evaluation/references/evaluation-criteria.md +0 -71
  15. package/prisma/skills/agent-self-evaluation/references/hook-integration.md +0 -64
  16. package/prisma/skills/agent-self-evaluation/scripts/evaluate.py +0 -408
  17. package/prisma/skills/agent-self-evaluation/templates/evaluation-report.md +0 -86
  18. package/prisma/skills/agent-sort/SKILL.md +0 -216
  19. package/prisma/skills/agentic-engineering/SKILL.md +0 -64
  20. package/prisma/skills/agentic-os/SKILL.md +0 -388
  21. package/prisma/skills/ai-first-engineering/SKILL.md +0 -52
  22. package/prisma/skills/ai-regression-testing/SKILL.md +0 -386
  23. package/prisma/skills/android-clean-architecture/SKILL.md +0 -340
  24. package/prisma/skills/angular-developer/SKILL.md +0 -155
  25. package/prisma/skills/angular-developer/references/angular-animations.md +0 -160
  26. package/prisma/skills/angular-developer/references/angular-aria.md +0 -410
  27. package/prisma/skills/angular-developer/references/cli.md +0 -86
  28. package/prisma/skills/angular-developer/references/component-harnesses.md +0 -59
  29. package/prisma/skills/angular-developer/references/component-styling.md +0 -91
  30. package/prisma/skills/angular-developer/references/components.md +0 -117
  31. package/prisma/skills/angular-developer/references/creating-services.md +0 -97
  32. package/prisma/skills/angular-developer/references/data-resolvers.md +0 -69
  33. package/prisma/skills/angular-developer/references/define-routes.md +0 -67
  34. package/prisma/skills/angular-developer/references/defining-providers.md +0 -72
  35. package/prisma/skills/angular-developer/references/di-fundamentals.md +0 -120
  36. package/prisma/skills/angular-developer/references/e2e-testing.md +0 -56
  37. package/prisma/skills/angular-developer/references/effects.md +0 -83
  38. package/prisma/skills/angular-developer/references/hierarchical-injectors.md +0 -43
  39. package/prisma/skills/angular-developer/references/host-elements.md +0 -80
  40. package/prisma/skills/angular-developer/references/injection-context.md +0 -63
  41. package/prisma/skills/angular-developer/references/inputs.md +0 -101
  42. package/prisma/skills/angular-developer/references/linked-signal.md +0 -59
  43. package/prisma/skills/angular-developer/references/loading-strategies.md +0 -61
  44. package/prisma/skills/angular-developer/references/mcp.md +0 -108
  45. package/prisma/skills/angular-developer/references/navigate-to-routes.md +0 -69
  46. package/prisma/skills/angular-developer/references/outputs.md +0 -86
  47. package/prisma/skills/angular-developer/references/reactive-forms.md +0 -122
  48. package/prisma/skills/angular-developer/references/rendering-strategies.md +0 -44
  49. package/prisma/skills/angular-developer/references/resource.md +0 -77
  50. package/prisma/skills/angular-developer/references/route-animations.md +0 -56
  51. package/prisma/skills/angular-developer/references/route-guards.md +0 -52
  52. package/prisma/skills/angular-developer/references/router-lifecycle.md +0 -45
  53. package/prisma/skills/angular-developer/references/router-testing.md +0 -87
  54. package/prisma/skills/angular-developer/references/show-routes-with-outlets.md +0 -68
  55. package/prisma/skills/angular-developer/references/signal-forms.md +0 -795
  56. package/prisma/skills/angular-developer/references/signals-overview.md +0 -94
  57. package/prisma/skills/angular-developer/references/tailwind-css.md +0 -69
  58. package/prisma/skills/angular-developer/references/template-driven-forms.md +0 -114
  59. package/prisma/skills/angular-developer/references/testing-fundamentals.md +0 -65
  60. package/prisma/skills/api-connector-builder/SKILL.md +0 -121
  61. package/prisma/skills/api-design/SKILL.md +0 -524
  62. package/prisma/skills/architecture-decision-records/SKILL.md +0 -180
  63. package/prisma/skills/article-writing/SKILL.md +0 -80
  64. package/prisma/skills/automation-audit-ops/SKILL.md +0 -143
  65. package/prisma/skills/autonomous-agent-harness/SKILL.md +0 -274
  66. package/prisma/skills/autonomous-loops/SKILL.md +0 -611
  67. package/prisma/skills/backend-patterns/SKILL.md +0 -562
  68. package/prisma/skills/benchmark/SKILL.md +0 -94
  69. package/prisma/skills/benchmark-methodology/SKILL.md +0 -190
  70. package/prisma/skills/benchmark-optimization-loop/SKILL.md +0 -70
  71. package/prisma/skills/blender-motion-state-inspection/SKILL.md +0 -165
  72. package/prisma/skills/blueprint/SKILL.md +0 -106
  73. package/prisma/skills/brand-discovery/SKILL.md +0 -145
  74. package/prisma/skills/brand-discovery/references/10_purpose-why.md +0 -40
  75. package/prisma/skills/brand-discovery/references/20_positioning.md +0 -44
  76. package/prisma/skills/brand-discovery/references/30_audience-niche.md +0 -52
  77. package/prisma/skills/brand-discovery/references/40_personality-archetype.md +0 -57
  78. package/prisma/skills/brand-discovery/references/50_voice-tone.md +0 -59
  79. package/prisma/skills/brand-discovery/references/60_narrative-story.md +0 -50
  80. package/prisma/skills/brand-discovery/references/70_founder-tension.md +0 -49
  81. package/prisma/skills/brand-discovery/references/90_SYNTHESIS.md +0 -133
  82. package/prisma/skills/brand-voice/SKILL.md +0 -98
  83. package/prisma/skills/brand-voice/references/voice-profile-schema.md +0 -55
  84. package/prisma/skills/browser-qa/SKILL.md +0 -105
  85. package/prisma/skills/bun-runtime/SKILL.md +0 -85
  86. package/prisma/skills/canary-watch/SKILL.md +0 -108
  87. package/prisma/skills/carrier-relationship-management/SKILL.md +0 -212
  88. package/prisma/skills/cisco-ios-patterns/SKILL.md +0 -164
  89. package/prisma/skills/ck/SKILL.md +0 -148
  90. package/prisma/skills/ck/commands/forget.mjs +0 -44
  91. package/prisma/skills/ck/commands/info.mjs +0 -24
  92. package/prisma/skills/ck/commands/init.mjs +0 -143
  93. package/prisma/skills/ck/commands/list.mjs +0 -40
  94. package/prisma/skills/ck/commands/migrate.mjs +0 -202
  95. package/prisma/skills/ck/commands/resume.mjs +0 -36
  96. package/prisma/skills/ck/commands/save.mjs +0 -210
  97. package/prisma/skills/ck/commands/shared.mjs +0 -387
  98. package/prisma/skills/ck/hooks/session-start.mjs +0 -224
  99. package/prisma/skills/claude-devfleet/SKILL.md +0 -112
  100. package/prisma/skills/click-path-audit/SKILL.md +0 -245
  101. package/prisma/skills/clickhouse-io/SKILL.md +0 -440
  102. package/prisma/skills/code-tour/SKILL.md +0 -254
  103. package/prisma/skills/codebase-onboarding/SKILL.md +0 -234
  104. package/prisma/skills/codehealth-mcp/SKILL.md +0 -167
  105. package/prisma/skills/coding-standards/SKILL.md +0 -551
  106. package/prisma/skills/competitive-platform-analysis/SKILL.md +0 -214
  107. package/prisma/skills/competitive-report-structure/SKILL.md +0 -162
  108. package/prisma/skills/compose-multiplatform-patterns/SKILL.md +0 -300
  109. package/prisma/skills/config-gc/SKILL.md +0 -120
  110. package/prisma/skills/configure-ecc/SKILL.md +0 -385
  111. package/prisma/skills/connections-optimizer/SKILL.md +0 -190
  112. package/prisma/skills/content-engine/SKILL.md +0 -132
  113. package/prisma/skills/content-hash-cache-pattern/SKILL.md +0 -162
  114. package/prisma/skills/context-budget/SKILL.md +0 -136
  115. package/prisma/skills/continuous-agent-loop/SKILL.md +0 -46
  116. package/prisma/skills/continuous-learning/SKILL.md +0 -132
  117. package/prisma/skills/continuous-learning/config.json +0 -18
  118. package/prisma/skills/continuous-learning/evaluate-session.sh +0 -69
  119. package/prisma/skills/continuous-learning-v2/SKILL.md +0 -361
  120. package/prisma/skills/continuous-learning-v2/agents/observer-loop.sh +0 -359
  121. package/prisma/skills/continuous-learning-v2/agents/observer.md +0 -189
  122. package/prisma/skills/continuous-learning-v2/agents/session-guardian.sh +0 -150
  123. package/prisma/skills/continuous-learning-v2/agents/start-observer.sh +0 -248
  124. package/prisma/skills/continuous-learning-v2/config.json +0 -8
  125. package/prisma/skills/continuous-learning-v2/hooks/observe.sh +0 -585
  126. package/prisma/skills/continuous-learning-v2/scripts/detect-project.sh +0 -322
  127. package/prisma/skills/continuous-learning-v2/scripts/instinct-cli.py +0 -1956
  128. package/prisma/skills/continuous-learning-v2/scripts/lib/homunculus-dir.sh +0 -31
  129. package/prisma/skills/continuous-learning-v2/scripts/migrate-homunculus.sh +0 -68
  130. package/prisma/skills/continuous-learning-v2/scripts/test_parse_instinct.py +0 -1421
  131. package/prisma/skills/cost-aware-llm-pipeline/SKILL.md +0 -184
  132. package/prisma/skills/cost-tracking/SKILL.md +0 -97
  133. package/prisma/skills/council/SKILL.md +0 -204
  134. package/prisma/skills/cpp-coding-standards/SKILL.md +0 -724
  135. package/prisma/skills/cpp-testing/SKILL.md +0 -325
  136. package/prisma/skills/crosspost/SKILL.md +0 -112
  137. package/prisma/skills/csharp-testing/SKILL.md +0 -322
  138. package/prisma/skills/customer-billing-ops/SKILL.md +0 -141
  139. package/prisma/skills/customs-trade-compliance/SKILL.md +0 -263
  140. package/prisma/skills/dart-flutter-patterns/SKILL.md +0 -564
  141. package/prisma/skills/dashboard-builder/SKILL.md +0 -109
  142. package/prisma/skills/data-scraper-agent/SKILL.md +0 -765
  143. package/prisma/skills/data-throughput-accelerator/SKILL.md +0 -73
  144. package/prisma/skills/database-migrations/SKILL.md +0 -430
  145. package/prisma/skills/deep-research/SKILL.md +0 -160
  146. package/prisma/skills/defi-amm-security/SKILL.md +0 -167
  147. package/prisma/skills/delivery-gate/SKILL.md +0 -126
  148. package/prisma/skills/delivery-gate/hooks/quality-gate.py +0 -220
  149. package/prisma/skills/deployment-patterns/SKILL.md +0 -428
  150. package/prisma/skills/design-system/SKILL.md +0 -83
  151. package/prisma/skills/django-celery/SKILL.md +0 -458
  152. package/prisma/skills/django-patterns/SKILL.md +0 -735
  153. package/prisma/skills/django-security/SKILL.md +0 -644
  154. package/prisma/skills/django-tdd/SKILL.md +0 -730
  155. package/prisma/skills/django-verification/SKILL.md +0 -470
  156. package/prisma/skills/dmux-workflows/SKILL.md +0 -192
  157. package/prisma/skills/docker-patterns/SKILL.md +0 -365
  158. package/prisma/skills/documentation-lookup/SKILL.md +0 -91
  159. package/prisma/skills/dotnet-patterns/SKILL.md +0 -322
  160. package/prisma/skills/dynamic-workflow-mode/SKILL.md +0 -124
  161. package/prisma/skills/e2e-testing/SKILL.md +0 -327
  162. package/prisma/skills/ecc-guide/SKILL.md +0 -190
  163. package/prisma/skills/ecc-recipes/SKILL.md +0 -149
  164. package/prisma/skills/ecc-tools-cost-audit/SKILL.md +0 -161
  165. package/prisma/skills/email-ops/SKILL.md +0 -122
  166. package/prisma/skills/energy-procurement/SKILL.md +0 -228
  167. package/prisma/skills/enterprise-agent-ops/SKILL.md +0 -51
  168. package/prisma/skills/error-handling/SKILL.md +0 -377
  169. package/prisma/skills/eval-harness/SKILL.md +0 -271
  170. package/prisma/skills/evm-token-decimals/SKILL.md +0 -131
  171. package/prisma/skills/exa-search/SKILL.md +0 -108
  172. package/prisma/skills/fal-ai-media/SKILL.md +0 -289
  173. package/prisma/skills/fastapi-patterns/SKILL.md +0 -514
  174. package/prisma/skills/finance-billing-ops/SKILL.md +0 -128
  175. package/prisma/skills/flox-environments/SKILL.md +0 -497
  176. package/prisma/skills/flutter-dart-code-review/SKILL.md +0 -436
  177. package/prisma/skills/foundation-models-on-device/SKILL.md +0 -243
  178. package/prisma/skills/frontend-a11y/SKILL.md +0 -446
  179. package/prisma/skills/frontend-design-direction/SKILL.md +0 -93
  180. package/prisma/skills/frontend-patterns/SKILL.md +0 -657
  181. package/prisma/skills/frontend-slides/SKILL.md +0 -185
  182. package/prisma/skills/frontend-slides/STYLE_PRESETS.md +0 -330
  183. package/prisma/skills/frontend-slides/animation-patterns.md +0 -122
  184. package/prisma/skills/frontend-slides/html-template.md +0 -419
  185. package/prisma/skills/frontend-slides/scripts/export-pdf.sh +0 -418
  186. package/prisma/skills/frontend-slides/scripts/extract-pptx.py +0 -96
  187. package/prisma/skills/frontend-slides/viewport-base.css +0 -153
  188. package/prisma/skills/fsharp-testing/SKILL.md +0 -281
  189. package/prisma/skills/gan-style-harness/SKILL.md +0 -279
  190. package/prisma/skills/gateguard/SKILL.md +0 -133
  191. package/prisma/skills/generating-python-installer/SKILL.md +0 -820
  192. package/prisma/skills/git-workflow/SKILL.md +0 -716
  193. package/prisma/skills/github-ops/SKILL.md +0 -145
  194. package/prisma/skills/golang-patterns/SKILL.md +0 -675
  195. package/prisma/skills/golang-testing/SKILL.md +0 -721
  196. package/prisma/skills/google-workspace-ops/SKILL.md +0 -96
  197. package/prisma/skills/growth-log/SKILL.md +0 -128
  198. package/prisma/skills/healthcare-cdss-patterns/SKILL.md +0 -246
  199. package/prisma/skills/healthcare-emr-patterns/SKILL.md +0 -160
  200. package/prisma/skills/healthcare-eval-harness/SKILL.md +0 -208
  201. package/prisma/skills/healthcare-phi-compliance/SKILL.md +0 -146
  202. package/prisma/skills/hermes-imports/SKILL.md +0 -89
  203. package/prisma/skills/hexagonal-architecture/SKILL.md +0 -277
  204. package/prisma/skills/hipaa-compliance/SKILL.md +0 -79
  205. package/prisma/skills/homelab-network-readiness/SKILL.md +0 -170
  206. package/prisma/skills/homelab-network-setup/SKILL.md +0 -130
  207. package/prisma/skills/homelab-pihole-dns/SKILL.md +0 -275
  208. package/prisma/skills/homelab-vlan-segmentation/SKILL.md +0 -312
  209. package/prisma/skills/homelab-wireguard-vpn/SKILL.md +0 -306
  210. package/prisma/skills/hookify-rules/SKILL.md +0 -128
  211. package/prisma/skills/inherit-legacy-style/SKILL.md +0 -157
  212. package/prisma/skills/intent-driven-development/SKILL.md +0 -360
  213. package/prisma/skills/inventory-demand-planning/SKILL.md +0 -247
  214. package/prisma/skills/investor-materials/SKILL.md +0 -97
  215. package/prisma/skills/investor-outreach/SKILL.md +0 -92
  216. package/prisma/skills/ios-icon-gen/SKILL.md +0 -158
  217. package/prisma/skills/ios-icon-gen/scripts/generate_icons.swift +0 -258
  218. package/prisma/skills/ios-icon-gen/scripts/iconify_gen.sh +0 -235
  219. package/prisma/skills/iterative-retrieval/SKILL.md +0 -212
  220. package/prisma/skills/ito-basket-compare/SKILL.md +0 -64
  221. package/prisma/skills/ito-data-atlas-agent/SKILL.md +0 -64
  222. package/prisma/skills/ito-market-intelligence/SKILL.md +0 -61
  223. package/prisma/skills/ito-trade-planner/SKILL.md +0 -68
  224. package/prisma/skills/java-coding-standards/SKILL.md +0 -384
  225. package/prisma/skills/jira-integration/SKILL.md +0 -303
  226. package/prisma/skills/jpa-patterns/SKILL.md +0 -152
  227. package/prisma/skills/knowledge-ops/SKILL.md +0 -155
  228. package/prisma/skills/kotlin-coroutines-flows/SKILL.md +0 -285
  229. package/prisma/skills/kotlin-exposed-patterns/SKILL.md +0 -720
  230. package/prisma/skills/kotlin-ktor-patterns/SKILL.md +0 -690
  231. package/prisma/skills/kotlin-patterns/SKILL.md +0 -712
  232. package/prisma/skills/kotlin-testing/SKILL.md +0 -825
  233. package/prisma/skills/kubernetes-patterns/SKILL.md +0 -756
  234. package/prisma/skills/laravel-patterns/SKILL.md +0 -416
  235. package/prisma/skills/laravel-plugin-discovery/SKILL.md +0 -230
  236. package/prisma/skills/laravel-security/SKILL.md +0 -948
  237. package/prisma/skills/laravel-tdd/SKILL.md +0 -675
  238. package/prisma/skills/laravel-verification/SKILL.md +0 -180
  239. package/prisma/skills/latency-critical-systems/SKILL.md +0 -74
  240. package/prisma/skills/lead-intelligence/SKILL.md +0 -322
  241. package/prisma/skills/lead-intelligence/agents/enrichment-agent.md +0 -85
  242. package/prisma/skills/lead-intelligence/agents/mutual-mapper.md +0 -75
  243. package/prisma/skills/lead-intelligence/agents/outreach-drafter.md +0 -98
  244. package/prisma/skills/lead-intelligence/agents/signal-scorer.md +0 -60
  245. package/prisma/skills/liquid-glass-design/SKILL.md +0 -279
  246. package/prisma/skills/llm-trading-agent-security/SKILL.md +0 -147
  247. package/prisma/skills/logistics-exception-management/SKILL.md +0 -222
  248. package/prisma/skills/loop-design-check/SKILL.md +0 -143
  249. package/prisma/skills/mailtrap-email-integration/SKILL.md +0 -77
  250. package/prisma/skills/make-interfaces-feel-better/SKILL.md +0 -152
  251. package/prisma/skills/manim-video/SKILL.md +0 -90
  252. package/prisma/skills/manim-video/assets/network_graph_scene.py +0 -52
  253. package/prisma/skills/market-research/SKILL.md +0 -76
  254. package/prisma/skills/marketing-campaign/SKILL.md +0 -114
  255. package/prisma/skills/mcp-server-patterns/SKILL.md +0 -70
  256. package/prisma/skills/messages-ops/SKILL.md +0 -105
  257. package/prisma/skills/ml-adoption-playbook/SKILL.md +0 -57
  258. package/prisma/skills/mle-workflow/SKILL.md +0 -347
  259. package/prisma/skills/motion-advanced/SKILL.md +0 -596
  260. package/prisma/skills/motion-foundations/SKILL.md +0 -299
  261. package/prisma/skills/motion-patterns/SKILL.md +0 -434
  262. package/prisma/skills/motion-ui/SKILL.md +0 -576
  263. package/prisma/skills/mysql-patterns/SKILL.md +0 -413
  264. package/prisma/skills/nanoclaw-repl/SKILL.md +0 -34
  265. package/prisma/skills/nestjs-patterns/SKILL.md +0 -231
  266. package/prisma/skills/netmiko-ssh-automation/SKILL.md +0 -174
  267. package/prisma/skills/network-bgp-diagnostics/SKILL.md +0 -168
  268. package/prisma/skills/network-config-validation/SKILL.md +0 -211
  269. package/prisma/skills/network-interface-health/SKILL.md +0 -153
  270. package/prisma/skills/nextjs-turbopack/SKILL.md +0 -58
  271. package/prisma/skills/nodejs-keccak256/SKILL.md +0 -103
  272. package/prisma/skills/nutrient-document-processing/SKILL.md +0 -168
  273. package/prisma/skills/nuxt4-patterns/SKILL.md +0 -101
  274. package/prisma/skills/openclaw-persona-forge/SKILL.md +0 -289
  275. package/prisma/skills/openclaw-persona-forge/gacha.py +0 -224
  276. package/prisma/skills/openclaw-persona-forge/gacha.sh +0 -5
  277. package/prisma/skills/openclaw-persona-forge/references/avatar-style.md +0 -124
  278. package/prisma/skills/openclaw-persona-forge/references/boundary-rules.md +0 -53
  279. package/prisma/skills/openclaw-persona-forge/references/error-handling.md +0 -53
  280. package/prisma/skills/openclaw-persona-forge/references/identity-tension.md +0 -48
  281. package/prisma/skills/openclaw-persona-forge/references/naming-system.md +0 -39
  282. package/prisma/skills/openclaw-persona-forge/references/output-template.md +0 -166
  283. package/prisma/skills/opensource-pipeline/SKILL.md +0 -256
  284. package/prisma/skills/orch-add-feature/SKILL.md +0 -45
  285. package/prisma/skills/orch-build-mvp/SKILL.md +0 -49
  286. package/prisma/skills/orch-change-feature/SKILL.md +0 -43
  287. package/prisma/skills/orch-fix-defect/SKILL.md +0 -43
  288. package/prisma/skills/orch-pipeline/SKILL.md +0 -121
  289. package/prisma/skills/orch-refine-code/SKILL.md +0 -44
  290. package/prisma/skills/parallel-execution-optimizer/SKILL.md +0 -73
  291. package/prisma/skills/perl-patterns/SKILL.md +0 -505
  292. package/prisma/skills/perl-security/SKILL.md +0 -504
  293. package/prisma/skills/perl-testing/SKILL.md +0 -476
  294. package/prisma/skills/plan-orchestrate/SKILL.md +0 -263
  295. package/prisma/skills/plankton-code-quality/SKILL.md +0 -237
  296. package/prisma/skills/postgres-patterns/SKILL.md +0 -148
  297. package/prisma/skills/prediction-market-oracle-research/SKILL.md +0 -64
  298. package/prisma/skills/prediction-market-risk-review/SKILL.md +0 -61
  299. package/prisma/skills/prisma-patterns/SKILL.md +0 -401
  300. package/prisma/skills/product-capability/SKILL.md +0 -142
  301. package/prisma/skills/product-lens/SKILL.md +0 -93
  302. package/prisma/skills/production-audit/SKILL.md +0 -207
  303. package/prisma/skills/production-scheduling/SKILL.md +0 -238
  304. package/prisma/skills/project-flow-ops/SKILL.md +0 -112
  305. package/prisma/skills/prompt-optimizer/SKILL.md +0 -398
  306. package/prisma/skills/python-patterns/SKILL.md +0 -751
  307. package/prisma/skills/python-testing/SKILL.md +0 -817
  308. package/prisma/skills/pytorch-patterns/SKILL.md +0 -397
  309. package/prisma/skills/quality-nonconformance/SKILL.md +0 -260
  310. package/prisma/skills/quarkus-patterns/SKILL.md +0 -723
  311. package/prisma/skills/quarkus-security/SKILL.md +0 -468
  312. package/prisma/skills/quarkus-tdd/SKILL.md +0 -812
  313. package/prisma/skills/quarkus-verification/SKILL.md +0 -480
  314. package/prisma/skills/ralphinho-rfc-pipeline/SKILL.md +0 -68
  315. package/prisma/skills/react-native-patterns/SKILL.md +0 -326
  316. package/prisma/skills/react-patterns/SKILL.md +0 -342
  317. package/prisma/skills/react-performance/SKILL.md +0 -575
  318. package/prisma/skills/react-testing/SKILL.md +0 -424
  319. package/prisma/skills/recsys-pipeline-architect/SKILL.md +0 -115
  320. package/prisma/skills/recursive-decision-ledger/SKILL.md +0 -80
  321. package/prisma/skills/redis-patterns/SKILL.md +0 -404
  322. package/prisma/skills/regex-vs-llm-structured-text/SKILL.md +0 -221
  323. package/prisma/skills/remotion-video-creation/SKILL.md +0 -43
  324. package/prisma/skills/remotion-video-creation/rules/3d.md +0 -86
  325. package/prisma/skills/remotion-video-creation/rules/animations.md +0 -29
  326. package/prisma/skills/remotion-video-creation/rules/assets/charts-bar-chart.tsx +0 -173
  327. package/prisma/skills/remotion-video-creation/rules/assets/text-animations-typewriter.tsx +0 -100
  328. package/prisma/skills/remotion-video-creation/rules/assets/text-animations-word-highlight.tsx +0 -108
  329. package/prisma/skills/remotion-video-creation/rules/assets.md +0 -78
  330. package/prisma/skills/remotion-video-creation/rules/audio.md +0 -172
  331. package/prisma/skills/remotion-video-creation/rules/calculate-metadata.md +0 -104
  332. package/prisma/skills/remotion-video-creation/rules/can-decode.md +0 -75
  333. package/prisma/skills/remotion-video-creation/rules/charts.md +0 -58
  334. package/prisma/skills/remotion-video-creation/rules/compositions.md +0 -146
  335. package/prisma/skills/remotion-video-creation/rules/display-captions.md +0 -126
  336. package/prisma/skills/remotion-video-creation/rules/extract-frames.md +0 -229
  337. package/prisma/skills/remotion-video-creation/rules/fonts.md +0 -152
  338. package/prisma/skills/remotion-video-creation/rules/get-audio-duration.md +0 -58
  339. package/prisma/skills/remotion-video-creation/rules/get-video-dimensions.md +0 -68
  340. package/prisma/skills/remotion-video-creation/rules/get-video-duration.md +0 -58
  341. package/prisma/skills/remotion-video-creation/rules/gifs.md +0 -138
  342. package/prisma/skills/remotion-video-creation/rules/images.md +0 -130
  343. package/prisma/skills/remotion-video-creation/rules/import-srt-captions.md +0 -67
  344. package/prisma/skills/remotion-video-creation/rules/lottie.md +0 -67
  345. package/prisma/skills/remotion-video-creation/rules/measuring-dom-nodes.md +0 -34
  346. package/prisma/skills/remotion-video-creation/rules/measuring-text.md +0 -143
  347. package/prisma/skills/remotion-video-creation/rules/sequencing.md +0 -106
  348. package/prisma/skills/remotion-video-creation/rules/tailwind.md +0 -11
  349. package/prisma/skills/remotion-video-creation/rules/text-animations.md +0 -20
  350. package/prisma/skills/remotion-video-creation/rules/timing.md +0 -179
  351. package/prisma/skills/remotion-video-creation/rules/transcribe-captions.md +0 -19
  352. package/prisma/skills/remotion-video-creation/rules/transitions.md +0 -122
  353. package/prisma/skills/remotion-video-creation/rules/trimming.md +0 -52
  354. package/prisma/skills/remotion-video-creation/rules/videos.md +0 -171
  355. package/prisma/skills/repo-scan/SKILL.md +0 -79
  356. package/prisma/skills/research-ops/SKILL.md +0 -113
  357. package/prisma/skills/returns-reverse-logistics/SKILL.md +0 -240
  358. package/prisma/skills/rules-distill/SKILL.md +0 -265
  359. package/prisma/skills/rules-distill/scripts/scan-rules.sh +0 -58
  360. package/prisma/skills/rules-distill/scripts/scan-skills.sh +0 -129
  361. package/prisma/skills/rust-patterns/SKILL.md +0 -500
  362. package/prisma/skills/rust-testing/SKILL.md +0 -501
  363. package/prisma/skills/safety-guard/SKILL.md +0 -76
  364. package/prisma/skills/santa-method/SKILL.md +0 -307
  365. package/prisma/skills/scientific-db-pubmed-database/SKILL.md +0 -176
  366. package/prisma/skills/scientific-db-uspto-database/SKILL.md +0 -178
  367. package/prisma/skills/scientific-pkg-gget/SKILL.md +0 -167
  368. package/prisma/skills/scientific-thinking-literature-review/SKILL.md +0 -193
  369. package/prisma/skills/scientific-thinking-scholar-evaluation/SKILL.md +0 -161
  370. package/prisma/skills/search-first/SKILL.md +0 -183
  371. package/prisma/skills/security-bounty-hunter/SKILL.md +0 -100
  372. package/prisma/skills/security-review/SKILL.md +0 -504
  373. package/prisma/skills/security-review/cloud-infrastructure-security.md +0 -361
  374. package/prisma/skills/security-scan/SKILL.md +0 -166
  375. package/prisma/skills/seo/SKILL.md +0 -155
  376. package/prisma/skills/skill-comply/SKILL.md +0 -59
  377. package/prisma/skills/skill-comply/fixtures/compliant_trace.jsonl +0 -5
  378. package/prisma/skills/skill-comply/fixtures/noncompliant_trace.jsonl +0 -3
  379. package/prisma/skills/skill-comply/fixtures/tdd_spec.yaml +0 -44
  380. package/prisma/skills/skill-comply/prompts/classifier.md +0 -24
  381. package/prisma/skills/skill-comply/prompts/scenario_generator.md +0 -62
  382. package/prisma/skills/skill-comply/prompts/spec_generator.md +0 -42
  383. package/prisma/skills/skill-comply/pyproject.toml +0 -15
  384. package/prisma/skills/skill-comply/scripts/__init__.py +0 -0
  385. package/prisma/skills/skill-comply/scripts/classifier.py +0 -85
  386. package/prisma/skills/skill-comply/scripts/grader.py +0 -124
  387. package/prisma/skills/skill-comply/scripts/parser.py +0 -107
  388. package/prisma/skills/skill-comply/scripts/report.py +0 -170
  389. package/prisma/skills/skill-comply/scripts/run.py +0 -127
  390. package/prisma/skills/skill-comply/scripts/runner.py +0 -194
  391. package/prisma/skills/skill-comply/scripts/scenario_generator.py +0 -70
  392. package/prisma/skills/skill-comply/scripts/spec_generator.py +0 -72
  393. package/prisma/skills/skill-comply/scripts/utils.py +0 -13
  394. package/prisma/skills/skill-comply/tests/test_grader.py +0 -197
  395. package/prisma/skills/skill-comply/tests/test_parser.py +0 -90
  396. package/prisma/skills/skill-comply/tests/test_runner.py +0 -172
  397. package/prisma/skills/skill-scout/SKILL.md +0 -141
  398. package/prisma/skills/skill-stocktake/SKILL.md +0 -195
  399. package/prisma/skills/skill-stocktake/scripts/quick-diff.sh +0 -87
  400. package/prisma/skills/skill-stocktake/scripts/save-results.sh +0 -56
  401. package/prisma/skills/skill-stocktake/scripts/scan.sh +0 -170
  402. package/prisma/skills/social-graph-ranker/SKILL.md +0 -155
  403. package/prisma/skills/social-publisher/SKILL.md +0 -130
  404. package/prisma/skills/springboot-patterns/SKILL.md +0 -315
  405. package/prisma/skills/springboot-security/SKILL.md +0 -273
  406. package/prisma/skills/springboot-tdd/SKILL.md +0 -159
  407. package/prisma/skills/springboot-verification/SKILL.md +0 -232
  408. package/prisma/skills/strategic-compact/SKILL.md +0 -136
  409. package/prisma/skills/swift-actor-persistence/SKILL.md +0 -144
  410. package/prisma/skills/swift-concurrency-6-2/SKILL.md +0 -216
  411. package/prisma/skills/swift-protocol-di-testing/SKILL.md +0 -191
  412. package/prisma/skills/swiftui-patterns/SKILL.md +0 -259
  413. package/prisma/skills/taste/SKILL.md +0 -264
  414. package/prisma/skills/taste/references/genre-taxonomy.md +0 -87
  415. package/prisma/skills/tdd-workflow/SKILL.md +0 -583
  416. package/prisma/skills/team-agent-orchestration/SKILL.md +0 -111
  417. package/prisma/skills/team-builder/SKILL.md +0 -169
  418. package/prisma/skills/terminal-ops/SKILL.md +0 -110
  419. package/prisma/skills/tinystruct-patterns/SKILL.md +0 -279
  420. package/prisma/skills/tinystruct-patterns/references/architecture.md +0 -90
  421. package/prisma/skills/tinystruct-patterns/references/data-handling.md +0 -60
  422. package/prisma/skills/tinystruct-patterns/references/database.md +0 -99
  423. package/prisma/skills/tinystruct-patterns/references/routing.md +0 -64
  424. package/prisma/skills/tinystruct-patterns/references/system-usage.md +0 -97
  425. package/prisma/skills/tinystruct-patterns/references/testing.md +0 -72
  426. package/prisma/skills/token-budget-advisor/SKILL.md +0 -134
  427. package/prisma/skills/ui-demo/SKILL.md +0 -466
  428. package/prisma/skills/ui-to-vue/SKILL.md +0 -135
  429. package/prisma/skills/uncloud/SKILL.md +0 -344
  430. package/prisma/skills/unified-notifications-ops/SKILL.md +0 -188
  431. package/prisma/skills/verification-loop/SKILL.md +0 -127
  432. package/prisma/skills/video-editing/SKILL.md +0 -311
  433. package/prisma/skills/videodb/SKILL.md +0 -375
  434. package/prisma/skills/videodb/reference/api-reference.md +0 -550
  435. package/prisma/skills/videodb/reference/capture-reference.md +0 -407
  436. package/prisma/skills/videodb/reference/capture.md +0 -101
  437. package/prisma/skills/videodb/reference/editor.md +0 -443
  438. package/prisma/skills/videodb/reference/generative.md +0 -331
  439. package/prisma/skills/videodb/reference/rtstream-reference.md +0 -564
  440. package/prisma/skills/videodb/reference/rtstream.md +0 -65
  441. package/prisma/skills/videodb/reference/search.md +0 -230
  442. package/prisma/skills/videodb/reference/streaming.md +0 -406
  443. package/prisma/skills/videodb/reference/use-cases.md +0 -118
  444. package/prisma/skills/videodb/scripts/ws_listener.py +0 -282
  445. package/prisma/skills/visa-doc-translate/README.md +0 -86
  446. package/prisma/skills/visa-doc-translate/SKILL.md +0 -117
  447. package/prisma/skills/vite-patterns/SKILL.md +0 -450
  448. package/prisma/skills/vue-patterns/SKILL.md +0 -471
  449. package/prisma/skills/windows-desktop-e2e/SKILL.md +0 -888
  450. package/prisma/skills/workspace-surface-audit/SKILL.md +0 -126
  451. package/prisma/skills/x-api/SKILL.md +0 -235
@@ -1,311 +0,0 @@
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
- metadata:
5
- origin: ECC
6
- ---
7
-
8
- # Video Editing
9
-
10
- AI-assisted editing for real footage. Not generation from prompts. Editing existing video fast.
11
-
12
- ## When to Activate
13
-
14
- - User wants to edit, cut, or structure video footage
15
- - Turning long recordings into short-form content
16
- - Building vlogs, tutorials, or demo videos from raw capture
17
- - Adding overlays, subtitles, music, or voiceover to existing video
18
- - Reframing video for different platforms (YouTube, TikTok, Instagram)
19
- - User says "edit video", "cut this footage", "make a vlog", or "video workflow"
20
-
21
- ## Core Thesis
22
-
23
- 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.
24
-
25
- ## The Pipeline
26
-
27
- ```
28
- Screen Studio / raw footage
29
- → Claude / Codex
30
- → FFmpeg
31
- → Remotion
32
- → ElevenLabs / fal.ai
33
- → Descript or CapCut
34
- ```
35
-
36
- Each layer has a specific job. Do not skip layers. Do not try to make one tool do everything.
37
-
38
- ## Layer 1: Capture (Screen Studio / Raw Footage)
39
-
40
- Collect the source material:
41
- - **Screen Studio**: polished screen recordings for app demos, coding sessions, browser workflows
42
- - **Raw camera footage**: vlog footage, interviews, event recordings
43
- - **Desktop capture via VideoDB**: session recording with real-time context (see `videodb` skill)
44
-
45
- Output: raw files ready for organization.
46
-
47
- ## Layer 2: Organization (Claude / Codex)
48
-
49
- Use Claude Code or Codex to:
50
- - **Transcribe and label**: generate transcript, identify topics and themes
51
- - **Plan structure**: decide what stays, what gets cut, what order works
52
- - **Identify dead sections**: find pauses, tangents, repeated takes
53
- - **Generate edit decision list**: timestamps for cuts, segments to keep
54
- - **Scaffold FFmpeg and Remotion code**: generate the commands and compositions
55
-
56
- ```
57
- Example prompt:
58
- "Here's the transcript of a 4-hour recording. Identify the 8 strongest segments
59
- for a 24-minute vlog. Give me FFmpeg cut commands for each segment."
60
- ```
61
-
62
- This layer is about structure, not final creative taste.
63
-
64
- ## Layer 3: Deterministic Cuts (FFmpeg)
65
-
66
- FFmpeg handles the boring but critical work: splitting, trimming, concatenating, and preprocessing.
67
-
68
- ### Extract segment by timestamp
69
-
70
- ```bash
71
- ffmpeg -i raw.mp4 -ss 00:12:30 -to 00:15:45 -c copy segment_01.mp4
72
- ```
73
-
74
- ### Batch cut from edit decision list
75
-
76
- ```bash
77
- #!/bin/bash
78
- # cuts.txt: start,end,label
79
- while IFS=, read -r start end label; do
80
- ffmpeg -i raw.mp4 -ss "$start" -to "$end" -c copy "segments/${label}.mp4"
81
- done < cuts.txt
82
- ```
83
-
84
- ### Concatenate segments
85
-
86
- ```bash
87
- # Create file list
88
- for f in segments/*.mp4; do echo "file '$f'"; done > concat.txt
89
- ffmpeg -f concat -safe 0 -i concat.txt -c copy assembled.mp4
90
- ```
91
-
92
- ### Create proxy for faster editing
93
-
94
- ```bash
95
- ffmpeg -i raw.mp4 -vf "scale=960:-2" -c:v libx264 -preset ultrafast -crf 28 proxy.mp4
96
- ```
97
-
98
- ### Extract audio for transcription
99
-
100
- ```bash
101
- ffmpeg -i raw.mp4 -vn -acodec pcm_s16le -ar 16000 audio.wav
102
- ```
103
-
104
- ### Normalize audio levels
105
-
106
- ```bash
107
- ffmpeg -i segment.mp4 -af loudnorm=I=-16:TP=-1.5:LRA=11 -c:v copy normalized.mp4
108
- ```
109
-
110
- ## Layer 4: Programmable Composition (Remotion)
111
-
112
- Remotion turns editing problems into composable code. Use it for things that traditional editors make painful:
113
-
114
- ### When to use Remotion
115
-
116
- - Overlays: text, images, branding, lower thirds
117
- - Data visualizations: charts, stats, animated numbers
118
- - Motion graphics: transitions, explainer animations
119
- - Composable scenes: reusable templates across videos
120
- - Product demos: annotated screenshots, UI highlights
121
-
122
- ### Basic Remotion composition
123
-
124
- ```tsx
125
- import { AbsoluteFill, Sequence, Video, useCurrentFrame } from "remotion";
126
-
127
- export const VlogComposition: React.FC = () => {
128
- const frame = useCurrentFrame();
129
-
130
- return (
131
- <AbsoluteFill>
132
- {/* Main footage */}
133
- <Sequence from={0} durationInFrames={300}>
134
- <Video src="/segments/intro.mp4" />
135
- </Sequence>
136
-
137
- {/* Title overlay */}
138
- <Sequence from={30} durationInFrames={90}>
139
- <AbsoluteFill style={{
140
- justifyContent: "center",
141
- alignItems: "center",
142
- }}>
143
- <h1 style={{
144
- fontSize: 72,
145
- color: "white",
146
- textShadow: "2px 2px 8px rgba(0,0,0,0.8)",
147
- }}>
148
- The AI Editing Stack
149
- </h1>
150
- </AbsoluteFill>
151
- </Sequence>
152
-
153
- {/* Next segment */}
154
- <Sequence from={300} durationInFrames={450}>
155
- <Video src="/segments/demo.mp4" />
156
- </Sequence>
157
- </AbsoluteFill>
158
- );
159
- };
160
- ```
161
-
162
- ### Render output
163
-
164
- ```bash
165
- npx remotion render src/index.ts VlogComposition output.mp4
166
- ```
167
-
168
- See the [Remotion docs](https://www.remotion.dev/docs) for detailed patterns and API reference.
169
-
170
- ## Layer 5: Generated Assets (ElevenLabs / fal.ai)
171
-
172
- Generate only what you need. Do not generate the whole video.
173
-
174
- ### Voiceover with ElevenLabs
175
-
176
- ```python
177
- import os
178
- import requests
179
-
180
- resp = requests.post(
181
- f"https://api.elevenlabs.io/v1/text-to-speech/{voice_id}",
182
- headers={
183
- "xi-api-key": os.environ["ELEVENLABS_API_KEY"],
184
- "Content-Type": "application/json"
185
- },
186
- json={
187
- "text": "Your narration text here",
188
- "model_id": "eleven_turbo_v2_5",
189
- "voice_settings": {"stability": 0.5, "similarity_boost": 0.75}
190
- }
191
- )
192
- with open("voiceover.mp3", "wb") as f:
193
- f.write(resp.content)
194
- ```
195
-
196
- ### Music and SFX with fal.ai
197
-
198
- Use the `fal-ai-media` skill for:
199
- - Background music generation
200
- - Sound effects (ThinkSound model for video-to-audio)
201
- - Transition sounds
202
-
203
- ### Generated visuals with fal.ai
204
-
205
- Use for insert shots, thumbnails, or b-roll that doesn't exist:
206
- ```
207
- generate(app_id: "fal-ai/nano-banana-pro", input_data: {
208
- "prompt": "professional thumbnail for tech vlog, dark background, code on screen",
209
- "image_size": "landscape_16_9"
210
- })
211
- ```
212
-
213
- ### VideoDB generative audio
214
-
215
- If VideoDB is configured:
216
- ```python
217
- voiceover = coll.generate_voice(text="Narration here", voice="alloy")
218
- music = coll.generate_music(prompt="lo-fi background for coding vlog", duration=120)
219
- sfx = coll.generate_sound_effect(prompt="subtle whoosh transition")
220
- ```
221
-
222
- ## Layer 6: Final Polish (Descript / CapCut)
223
-
224
- The last layer is human. Use a traditional editor for:
225
- - **Pacing**: adjust cuts that feel too fast or slow
226
- - **Captions**: auto-generated, then manually cleaned
227
- - **Color grading**: basic correction and mood
228
- - **Final audio mix**: balance voice, music, and SFX levels
229
- - **Export**: platform-specific formats and quality settings
230
-
231
- This is where taste lives. AI clears the repetitive work. You make the final calls.
232
-
233
- ## Social Media Reframing
234
-
235
- Different platforms need different aspect ratios:
236
-
237
- | Platform | Aspect Ratio | Resolution |
238
- |----------|-------------|------------|
239
- | YouTube | 16:9 | 1920x1080 |
240
- | TikTok / Reels | 9:16 | 1080x1920 |
241
- | Instagram Feed | 1:1 | 1080x1080 |
242
- | X / Twitter | 16:9 or 1:1 | 1280x720 or 720x720 |
243
-
244
- ### Reframe with FFmpeg
245
-
246
- ```bash
247
- # 16:9 to 9:16 (center crop)
248
- ffmpeg -i input.mp4 -vf "crop=ih*9/16:ih,scale=1080:1920" vertical.mp4
249
-
250
- # 16:9 to 1:1 (center crop)
251
- ffmpeg -i input.mp4 -vf "crop=ih:ih,scale=1080:1080" square.mp4
252
- ```
253
-
254
- ### Reframe with VideoDB
255
-
256
- ```python
257
- from videodb import ReframeMode
258
-
259
- # Smart reframe (AI-guided subject tracking)
260
- reframed = video.reframe(start=0, end=60, target="vertical", mode=ReframeMode.smart)
261
- ```
262
-
263
- ## Scene Detection and Auto-Cut
264
-
265
- ### FFmpeg scene detection
266
-
267
- ```bash
268
- # Detect scene changes (threshold 0.3 = moderate sensitivity)
269
- ffmpeg -i input.mp4 -vf "select='gt(scene,0.3)',showinfo" -vsync vfr -f null - 2>&1 | grep showinfo
270
- ```
271
-
272
- ### Silence detection for auto-cut
273
-
274
- ```bash
275
- # Find silent segments (useful for cutting dead air)
276
- ffmpeg -i input.mp4 -af silencedetect=noise=-30dB:d=2 -f null - 2>&1 | grep silence
277
- ```
278
-
279
- ### Highlight extraction
280
-
281
- Use Claude to analyze transcript + scene timestamps:
282
- ```
283
- "Given this transcript with timestamps and these scene change points,
284
- identify the 5 most engaging 30-second clips for social media."
285
- ```
286
-
287
- ## What Each Tool Does Best
288
-
289
- | Tool | Strength | Weakness |
290
- |------|----------|----------|
291
- | Claude / Codex | Organization, planning, code generation | Not the creative taste layer |
292
- | FFmpeg | Deterministic cuts, batch processing, format conversion | No visual editing UI |
293
- | Remotion | Programmable overlays, composable scenes, reusable templates | Learning curve for non-devs |
294
- | Screen Studio | Polished screen recordings immediately | Only screen capture |
295
- | ElevenLabs | Voice, narration, music, SFX | Not the center of the workflow |
296
- | Descript / CapCut | Final pacing, captions, polish | Manual, not automatable |
297
-
298
- ## Key Principles
299
-
300
- 1. **Edit, don't generate.** This workflow is for cutting real footage, not creating from prompts.
301
- 2. **Structure before style.** Get the story right in Layer 2 before touching anything visual.
302
- 3. **FFmpeg is the backbone.** Boring but critical. Where long footage becomes manageable.
303
- 4. **Remotion for repeatability.** If you'll do it more than once, make it a Remotion component.
304
- 5. **Generate selectively.** Only use AI generation for assets that don't exist, not for everything.
305
- 6. **Taste is the last layer.** AI clears repetitive work. You make the final creative calls.
306
-
307
- ## Related Skills
308
-
309
- - `fal-ai-media` — AI image, video, and audio generation
310
- - `videodb` — Server-side video processing, indexing, and streaming
311
- - `content-engine` — Platform-native content distribution
@@ -1,375 +0,0 @@
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
- metadata:
5
- origin: ECC
6
- allowed-tools: Read Grep Glob Bash(python:*)
7
- argument-hint: "[task description]"
8
- ---
9
-
10
- # VideoDB Skill
11
-
12
- **Perception + memory + actions for video, live streams, and desktop sessions.**
13
-
14
- ## When to use
15
-
16
- ### Desktop Perception
17
- - Start/stop a **desktop session** capturing **screen, mic, and system audio**
18
- - Stream **live context** and store **episodic session memory**
19
- - Run **real-time alerts/triggers** on what's spoken and what's happening on screen
20
- - Produce **session summaries**, a searchable timeline, and **playable evidence links**
21
-
22
- ### Video ingest + stream
23
- - Ingest a **file or URL** and return a **playable web stream link**
24
- - Transcode/normalize: **codec, bitrate, fps, resolution, aspect ratio**
25
-
26
- ### Index + search (timestamps + evidence)
27
- - Build **visual**, **spoken**, and **keyword** indexes
28
- - Search and return exact moments with **timestamps** and **playable evidence**
29
- - Auto-create **clips** from search results
30
-
31
- ### Timeline editing + generation
32
- - Subtitles: **generate**, **translate**, **burn-in**
33
- - Overlays: **text/image/branding**, motion captions
34
- - Audio: **background music**, **voiceover**, **dubbing**
35
- - Programmatic composition and exports via **timeline operations**
36
-
37
- ### Live streams (RTSP) + monitoring
38
- - Connect **RTSP/live feeds**
39
- - Run **real-time visual and spoken understanding** and emit **events/alerts** for monitoring workflows
40
-
41
- ## How it works
42
-
43
- ### Common inputs
44
- - Local **file path**, public **URL**, or **RTSP URL**
45
- - Desktop capture request: **start / stop / summarize session**
46
- - Desired operations: get context for understanding, transcode spec, index spec, search query, clip ranges, timeline edits, alert rules
47
-
48
- ### Common outputs
49
- - **Stream URL**
50
- - Search results with **timestamps** and **evidence links**
51
- - Generated assets: subtitles, audio, images, clips
52
- - **Event/alert payloads** for live streams
53
- - Desktop **session summaries** and memory entries
54
-
55
- ### Running Python code
56
-
57
- Before running any VideoDB code, change to the project directory and load environment variables:
58
-
59
- ```python
60
- from dotenv import load_dotenv
61
- load_dotenv(".env")
62
-
63
- import videodb
64
- conn = videodb.connect()
65
- ```
66
-
67
- This reads `VIDEO_DB_API_KEY` from:
68
- 1. Environment (if already exported)
69
- 2. Project's `.env` file in current directory
70
-
71
- If the key is missing, `videodb.connect()` raises `AuthenticationError` automatically.
72
-
73
- Do NOT write a script file when a short inline command works.
74
-
75
- 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:
76
-
77
- ```bash
78
- python << 'EOF'
79
- from dotenv import load_dotenv
80
- load_dotenv(".env")
81
-
82
- import videodb
83
- conn = videodb.connect()
84
- coll = conn.get_collection()
85
- print(f"Videos: {len(coll.get_videos())}")
86
- EOF
87
- ```
88
-
89
- ### Setup
90
-
91
- When the user asks to "setup videodb" or similar:
92
-
93
- ### 1. Install SDK
94
-
95
- ```bash
96
- pip install "videodb[capture]" python-dotenv
97
- ```
98
-
99
- If `videodb[capture]` fails on Linux, install without the capture extra:
100
-
101
- ```bash
102
- pip install videodb python-dotenv
103
- ```
104
-
105
- ### 2. Configure API key
106
-
107
- The user must set `VIDEO_DB_API_KEY` using **either** method:
108
-
109
- - **Export in terminal** (before starting Claude): `export VIDEO_DB_API_KEY=your-key`
110
- - **Project `.env` file**: Save `VIDEO_DB_API_KEY=your-key` in the project's `.env` file
111
-
112
- Get a free API key at [console.videodb.io](https://console.videodb.io) (50 free uploads, no credit card).
113
-
114
- **Do NOT** read, write, or handle the API key yourself. Always let the user set it.
115
-
116
- ### Quick Reference
117
-
118
- ### Upload media
119
-
120
- ```python
121
- # URL
122
- video = coll.upload(url="https://example.com/video.mp4")
123
-
124
- # YouTube
125
- video = coll.upload(url="https://www.youtube.com/watch?v=VIDEO_ID")
126
-
127
- # Local file
128
- video = coll.upload(file_path="/path/to/video.mp4")
129
- ```
130
-
131
- ### Transcript + subtitle
132
-
133
- ```python
134
- # force=True skips the error if the video is already indexed
135
- video.index_spoken_words(force=True)
136
- text = video.get_transcript_text()
137
- stream_url = video.add_subtitle()
138
- ```
139
-
140
- ### Search inside videos
141
-
142
- ```python
143
- from videodb.exceptions import InvalidRequestError
144
-
145
- video.index_spoken_words(force=True)
146
-
147
- # search() raises InvalidRequestError when no results are found.
148
- # Always wrap in try/except and treat "No results found" as empty.
149
- try:
150
- results = video.search("product demo")
151
- shots = results.get_shots()
152
- stream_url = results.compile()
153
- except InvalidRequestError as e:
154
- if "No results found" in str(e):
155
- shots = []
156
- else:
157
- raise
158
- ```
159
-
160
- ### Scene search
161
-
162
- ```python
163
- import re
164
- from videodb import SearchType, IndexType, SceneExtractionType
165
- from videodb.exceptions import InvalidRequestError
166
-
167
- # index_scenes() has no force parameter — it raises an error if a scene
168
- # index already exists. Extract the existing index ID from the error.
169
- try:
170
- scene_index_id = video.index_scenes(
171
- extraction_type=SceneExtractionType.shot_based,
172
- prompt="Describe the visual content in this scene.",
173
- )
174
- except Exception as e:
175
- match = re.search(r"id\s+([a-f0-9]+)", str(e))
176
- if match:
177
- scene_index_id = match.group(1)
178
- else:
179
- raise
180
-
181
- # Use score_threshold to filter low-relevance noise (recommended: 0.3+)
182
- try:
183
- results = video.search(
184
- query="person writing on a whiteboard",
185
- search_type=SearchType.semantic,
186
- index_type=IndexType.scene,
187
- scene_index_id=scene_index_id,
188
- score_threshold=0.3,
189
- )
190
- shots = results.get_shots()
191
- stream_url = results.compile()
192
- except InvalidRequestError as e:
193
- if "No results found" in str(e):
194
- shots = []
195
- else:
196
- raise
197
- ```
198
-
199
- ### Timeline editing
200
-
201
- **Important:** Always validate timestamps before building a timeline:
202
- - `start` must be >= 0 (negative values are silently accepted but produce broken output)
203
- - `start` must be < `end`
204
- - `end` must be <= `video.length`
205
-
206
- ```python
207
- from videodb.timeline import Timeline
208
- from videodb.asset import VideoAsset, TextAsset, TextStyle
209
-
210
- timeline = Timeline(conn)
211
- timeline.add_inline(VideoAsset(asset_id=video.id, start=10, end=30))
212
- timeline.add_overlay(0, TextAsset(text="The End", duration=3, style=TextStyle(fontsize=36)))
213
- stream_url = timeline.generate_stream()
214
- ```
215
-
216
- ### Transcode video (resolution / quality change)
217
-
218
- ```python
219
- from videodb import TranscodeMode, VideoConfig, AudioConfig
220
-
221
- # Change resolution, quality, or aspect ratio server-side
222
- job_id = conn.transcode(
223
- source="https://example.com/video.mp4",
224
- callback_url="https://example.com/webhook",
225
- mode=TranscodeMode.economy,
226
- video_config=VideoConfig(resolution=720, quality=23, aspect_ratio="16:9"),
227
- audio_config=AudioConfig(mute=False),
228
- )
229
- ```
230
-
231
- ### Reframe aspect ratio (for social platforms)
232
-
233
- **Warning:** `reframe()` is a slow server-side operation. For long videos it can take
234
- several minutes and may time out. Best practices:
235
- - Always limit to a short segment using `start`/`end` when possible
236
- - For full-length videos, use `callback_url` for async processing
237
- - Trim the video on a `Timeline` first, then reframe the shorter result
238
-
239
- ```python
240
- from videodb import ReframeMode
241
-
242
- # Always prefer reframing a short segment:
243
- reframed = video.reframe(start=0, end=60, target="vertical", mode=ReframeMode.smart)
244
-
245
- # Async reframe for full-length videos (returns None, result via webhook):
246
- video.reframe(target="vertical", callback_url="https://example.com/webhook")
247
-
248
- # Presets: "vertical" (9:16), "square" (1:1), "landscape" (16:9)
249
- reframed = video.reframe(start=0, end=60, target="square")
250
-
251
- # Custom dimensions
252
- reframed = video.reframe(start=0, end=60, target={"width": 1280, "height": 720})
253
- ```
254
-
255
- ### Generative media
256
-
257
- ```python
258
- image = coll.generate_image(
259
- prompt="a sunset over mountains",
260
- aspect_ratio="16:9",
261
- )
262
- ```
263
-
264
- ## Error handling
265
-
266
- ```python
267
- from videodb.exceptions import AuthenticationError, InvalidRequestError
268
-
269
- try:
270
- conn = videodb.connect()
271
- except AuthenticationError:
272
- print("Check your VIDEO_DB_API_KEY")
273
-
274
- try:
275
- video = coll.upload(url="https://example.com/video.mp4")
276
- except InvalidRequestError as e:
277
- print(f"Upload failed: {e}")
278
- ```
279
-
280
- ### Common pitfalls
281
-
282
- | Scenario | Error message | Solution |
283
- |----------|--------------|----------|
284
- | Indexing an already-indexed video | `Spoken word index for video already exists` | Use `video.index_spoken_words(force=True)` to skip if already indexed |
285
- | 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))` |
286
- | Search finds no matches | `InvalidRequestError: No results found` | Catch the exception and treat as empty results (`shots = []`) |
287
- | Reframe times out | Blocks indefinitely on long videos | Use `start`/`end` to limit segment, or pass `callback_url` for async |
288
- | Negative timestamps on Timeline | Silently produces broken stream | Always validate `start >= 0` before creating `VideoAsset` |
289
- | `generate_video()` / `create_collection()` fails | `Operation not allowed` or `maximum limit` | Plan-gated features — inform the user about plan limits |
290
-
291
- ## Examples
292
-
293
- ### Canonical prompts
294
- - "Start desktop capture and alert when a password field appears."
295
- - "Record my session and produce an actionable summary when it ends."
296
- - "Ingest this file and return a playable stream link."
297
- - "Index this folder and find every scene with people, return timestamps."
298
- - "Generate subtitles, burn them in, and add light background music."
299
- - "Connect this RTSP URL and alert when a person enters the zone."
300
-
301
- ### Screen Recording (Desktop Capture)
302
-
303
- Use `ws_listener.py` to capture WebSocket events during recording sessions. Desktop capture supports **macOS** only.
304
-
305
- #### Quick Start
306
-
307
- 1. **Choose state dir**: `STATE_DIR="${VIDEODB_EVENTS_DIR:-$HOME/.local/state/videodb}"`
308
- 2. **Start listener**: `VIDEODB_EVENTS_DIR="$STATE_DIR" python scripts/ws_listener.py --clear "$STATE_DIR" &`
309
- 3. **Get WebSocket ID**: `cat "$STATE_DIR/videodb_ws_id"`
310
- 4. **Run capture code** (see reference/capture.md for the full workflow)
311
- 5. **Events written to**: `$STATE_DIR/videodb_events.jsonl`
312
-
313
- Use `--clear` whenever you start a fresh capture run so stale transcript and visual events do not leak into the new session.
314
-
315
- #### Query Events
316
-
317
- ```python
318
- import json
319
- import os
320
- import time
321
- from pathlib import Path
322
-
323
- events_dir = Path(os.environ.get("VIDEODB_EVENTS_DIR", Path.home() / ".local" / "state" / "videodb"))
324
- events_file = events_dir / "videodb_events.jsonl"
325
- events = []
326
-
327
- if events_file.exists():
328
- with events_file.open(encoding="utf-8") as handle:
329
- for line in handle:
330
- try:
331
- events.append(json.loads(line))
332
- except json.JSONDecodeError:
333
- continue
334
-
335
- transcripts = [e["data"]["text"] for e in events if e.get("channel") == "transcript"]
336
- cutoff = time.time() - 300
337
- recent_visual = [
338
- e for e in events
339
- if e.get("channel") == "visual_index" and e["unix_ts"] > cutoff
340
- ]
341
- ```
342
-
343
- ## Additional docs
344
-
345
- Reference documentation is in the `reference/` directory adjacent to this SKILL.md file. Use the Glob tool to locate it if needed.
346
-
347
- - [reference/api-reference.md](reference/api-reference.md) - Complete VideoDB Python SDK API reference
348
- - [reference/search.md](reference/search.md) - In-depth guide to video search (spoken word and scene-based)
349
- - [reference/editor.md](reference/editor.md) - Timeline editing, assets, and composition
350
- - [reference/streaming.md](reference/streaming.md) - HLS streaming and instant playback
351
- - [reference/generative.md](reference/generative.md) - AI-powered media generation (images, video, audio)
352
- - [reference/rtstream.md](reference/rtstream.md) - Live stream ingestion workflow (RTSP/RTMP)
353
- - [reference/rtstream-reference.md](reference/rtstream-reference.md) - RTStream SDK methods and AI pipelines
354
- - [reference/capture.md](reference/capture.md) - Desktop capture workflow
355
- - [reference/capture-reference.md](reference/capture-reference.md) - Capture SDK and WebSocket events
356
- - [reference/use-cases.md](reference/use-cases.md) - Common video processing patterns and examples
357
-
358
- **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).
359
-
360
- ### When to use what
361
-
362
- | Problem | VideoDB solution |
363
- |---------|-----------------|
364
- | Platform rejects video aspect ratio or resolution | `video.reframe()` or `conn.transcode()` with `VideoConfig` |
365
- | Need to resize video for Twitter/Instagram/TikTok | `video.reframe(target="vertical")` or `target="square"` |
366
- | Need to change resolution (e.g. 1080p → 720p) | `conn.transcode()` with `VideoConfig(resolution=720)` |
367
- | Need to overlay audio/music on video | `AudioAsset` on a `Timeline` |
368
- | Need to add subtitles | `video.add_subtitle()` or `CaptionAsset` |
369
- | Need to combine/trim clips | `VideoAsset` on a `Timeline` |
370
- | Need to generate voiceover, music, or SFX | `coll.generate_voice()`, `generate_music()`, `generate_sound_effect()` |
371
-
372
- ## Provenance
373
-
374
- Reference material for this skill is vendored locally under `skills/videodb/reference/`.
375
- Use the local copies above instead of following external repository links at runtime.