@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,404 +0,0 @@
1
- ---
2
- name: redis-patterns
3
- description: Redis data structure patterns, caching strategies, distributed locks, rate limiting, pub/sub, and connection management for production applications.
4
- metadata:
5
- origin: ECC
6
- ---
7
-
8
- # Redis Patterns
9
-
10
- Quick reference for Redis best practices across common backend use cases.
11
-
12
- ## How It Works
13
-
14
- Redis is an in-memory data structure store that supports strings, hashes, lists, sets, sorted sets, streams, and more. Individual Redis commands are atomic on a single instance; multi-step workflows require Lua scripts, MULTI/EXEC transactions, or explicit synchronization to stay atomic. Data is optionally persisted via RDB snapshots or AOF logs. Clients communicate over TCP using the RESP protocol; connection pools are essential to avoid per-request handshake overhead.
15
-
16
- ## When to Activate
17
-
18
- - Adding caching to an application
19
- - Implementing rate limiting or throttling
20
- - Building distributed locks or coordination
21
- - Setting up session or token storage
22
- - Using Pub/Sub or Redis Streams for messaging
23
- - Configuring Redis in production (pooling, eviction, clustering)
24
-
25
- ## Data Structure Cheat Sheet
26
-
27
- | Use Case | Structure | Example Key |
28
- |----------|-----------|-------------|
29
- | Simple cache | String | `product:123` |
30
- | User session | Hash | `session:abc` |
31
- | Leaderboard | Sorted Set | `scores:weekly` |
32
- | Unique visitors | Set | `visitors:2024-01-01` |
33
- | Activity feed | List | `feed:user:456` |
34
- | Event stream | Stream | `events:orders` |
35
- | Counters / rate limits | String (INCR) | `ratelimit:user:123` |
36
- | Bloom filter / HLL | HyperLogLog | `hll:pageviews` |
37
-
38
- ## Core Patterns
39
-
40
- ### Cache-Aside (Lazy Loading)
41
-
42
- ```python
43
- import redis
44
- import json
45
-
46
- r = redis.Redis(host='localhost', port=6379, decode_responses=True)
47
-
48
- def get_product(product_id: int):
49
- cache_key = f"product:{product_id}"
50
- cached = r.get(cache_key)
51
-
52
- if cached:
53
- return json.loads(cached)
54
-
55
- product = db.query("SELECT * FROM products WHERE id = %s", product_id)
56
- r.setex(cache_key, 3600, json.dumps(product)) # TTL: 1 hour
57
- return product
58
- ```
59
-
60
- ### Write-Through Cache
61
-
62
- ```python
63
- def update_product(product_id: int, data: dict):
64
- # Write to DB first
65
- db.execute("UPDATE products SET ... WHERE id = %s", product_id)
66
-
67
- # Immediately update cache
68
- cache_key = f"product:{product_id}"
69
- r.setex(cache_key, 3600, json.dumps(data))
70
- ```
71
-
72
- ### Cache Invalidation
73
-
74
- ```python
75
- # Tag-based invalidation — group related keys under a set
76
- def cache_product(product_id: int, category_id: int, data: dict):
77
- key = f"product:{product_id}"
78
- tag = f"tag:category:{category_id}"
79
- pipe = r.pipeline(transaction=True)
80
- pipe.setex(key, 3600, json.dumps(data))
81
- pipe.sadd(tag, key)
82
- pipe.expire(tag, 3600)
83
- pipe.execute()
84
-
85
- def invalidate_category(category_id: int):
86
- tag = f"tag:category:{category_id}"
87
- keys = r.smembers(tag)
88
- if keys:
89
- r.delete(*keys)
90
- r.delete(tag)
91
- ```
92
-
93
- ### Session Storage
94
-
95
- ```python
96
- import time
97
- import uuid
98
-
99
- def create_session(user_id: int, ttl: int = 86400) -> str:
100
- session_id = str(uuid.uuid4())
101
- key = f"session:{session_id}"
102
- pipe = r.pipeline(transaction=True)
103
- pipe.hset(key, mapping={
104
- "user_id": user_id,
105
- "created_at": int(time.time()),
106
- })
107
- pipe.expire(key, ttl)
108
- pipe.execute()
109
- return session_id
110
-
111
- def get_session(session_id: str) -> dict | None:
112
- data = r.hgetall(f"session:{session_id}")
113
- return data if data else None
114
-
115
- def delete_session(session_id: str):
116
- r.delete(f"session:{session_id}")
117
- ```
118
-
119
- ## Rate Limiting
120
-
121
- ### Fixed Window (Simple)
122
-
123
- ```python
124
- def is_rate_limited(user_id: int, limit: int = 100, window: int = 60) -> bool:
125
- key = f"ratelimit:{user_id}:{int(time.time()) // window}"
126
- pipe = r.pipeline(transaction=True)
127
- pipe.incr(key)
128
- pipe.expire(key, window)
129
- count, _ = pipe.execute()
130
- return count > limit
131
- ```
132
-
133
- ### Sliding Window (Lua — Atomic)
134
-
135
- ```lua
136
- -- sliding_window.lua
137
- local key = KEYS[1]
138
- local now = tonumber(ARGV[1])
139
- local window = tonumber(ARGV[2])
140
- local limit = tonumber(ARGV[3])
141
-
142
- redis.call('ZREMRANGEBYSCORE', key, 0, now - window)
143
- local count = redis.call('ZCARD', key)
144
-
145
- if count < limit then
146
- -- Use unique member (now + sequence) to avoid collisions within the same millisecond
147
- local seq_key = key .. ':seq'
148
- local seq = redis.call('INCR', seq_key)
149
- redis.call('EXPIRE', seq_key, math.ceil(window / 1000))
150
- redis.call('ZADD', key, now, now .. '-' .. seq)
151
- redis.call('EXPIRE', key, math.ceil(window / 1000))
152
- return 1
153
- end
154
- return 0
155
- ```
156
-
157
- ```python
158
- sliding_window = r.register_script(open('sliding_window.lua').read())
159
-
160
- def allow_request(user_id: int) -> bool:
161
- key = f"ratelimit:sliding:{user_id}"
162
- now = int(time.time() * 1000)
163
- return bool(sliding_window(keys=[key], args=[now, 60000, 100]))
164
- ```
165
-
166
- ## Distributed Locks
167
-
168
- ### Distributed Lock (Single Node — SET NX PX)
169
-
170
- ```python
171
- import uuid
172
-
173
- def acquire_lock(resource: str, ttl_ms: int = 5000) -> str | None:
174
- lock_key = f"lock:{resource}"
175
- token = str(uuid.uuid4())
176
- acquired = r.set(lock_key, token, px=ttl_ms, nx=True)
177
- return token if acquired else None
178
-
179
- def release_lock(resource: str, token: str) -> bool:
180
- release_script = """
181
- if redis.call('get', KEYS[1]) == ARGV[1] then
182
- return redis.call('del', KEYS[1])
183
- else
184
- return 0
185
- end
186
- """
187
- result = r.eval(release_script, 1, f"lock:{resource}", token)
188
- return bool(result)
189
-
190
- # Usage
191
- token = acquire_lock("order:payment:123")
192
- if token:
193
- try:
194
- process_payment()
195
- finally:
196
- release_lock("order:payment:123", token)
197
- ```
198
-
199
- > For multi-node setups use the `redlock-py` library which implements the full Redlock algorithm.
200
-
201
- ## Pub/Sub & Streams
202
-
203
- ### Pub/Sub (Fire-and-Forget)
204
-
205
- ```python
206
- # Publisher
207
- def publish_event(channel: str, payload: dict):
208
- r.publish(channel, json.dumps(payload))
209
-
210
- # Subscriber (blocking — run in separate thread/process)
211
- def subscribe_events(channel: str):
212
- pubsub = r.pubsub()
213
- pubsub.subscribe(channel)
214
- for message in pubsub.listen():
215
- if message['type'] == 'message':
216
- handle(json.loads(message['data']))
217
- ```
218
-
219
- ### Redis Streams (Durable Queue)
220
-
221
- ```python
222
- # Producer
223
- def emit(stream: str, event: dict):
224
- r.xadd(stream, event, maxlen=10000) # Cap stream length
225
-
226
- # Consumer group — guarantees at-least-once delivery
227
- try:
228
- r.xgroup_create('events:orders', 'processor', id='0', mkstream=True)
229
- except Exception:
230
- pass # Group already exists
231
-
232
- def consume(stream: str, group: str, consumer: str):
233
- while True:
234
- messages = r.xreadgroup(group, consumer, {stream: '>'}, count=10, block=2000)
235
- for _, entries in (messages or []):
236
- for msg_id, data in entries:
237
- process(data)
238
- r.xack(stream, group, msg_id)
239
- ```
240
-
241
- > Prefer **Streams** over Pub/Sub when you need delivery guarantees, consumer groups, or replay.
242
-
243
- ## Key Design
244
-
245
- ### Naming Conventions
246
-
247
- ```
248
- # Pattern: resource:id:field
249
- user:123:profile
250
- order:456:status
251
- cache:product:789
252
-
253
- # Pattern: namespace:resource:id
254
- myapp:session:abc123
255
- myapp:ratelimit:user:123
256
-
257
- # Pattern: resource:date (time-bound keys)
258
- stats:pageviews:2024-01-01
259
- ```
260
-
261
- ### TTL Strategy
262
-
263
- | Data Type | Suggested TTL |
264
- |-----------|--------------|
265
- | User session | 24h (`86400`) |
266
- | API response cache | 5–15 min |
267
- | Rate limit window | Match window size |
268
- | Short-lived tokens | 5–10 min |
269
- | Leaderboard | 1h–24h |
270
- | Static/reference data | 1h–1 week |
271
-
272
- Always set a TTL. Keys without TTL accumulate indefinitely and cause memory pressure.
273
-
274
- ## Connection Management
275
-
276
- ### Connection Pooling
277
-
278
- ```python
279
- from redis import ConnectionPool, Redis
280
-
281
- pool = ConnectionPool(
282
- host='localhost',
283
- port=6379,
284
- db=0,
285
- max_connections=20,
286
- decode_responses=True,
287
- socket_connect_timeout=2,
288
- socket_timeout=2,
289
- )
290
-
291
- r = Redis(connection_pool=pool)
292
- ```
293
-
294
- ### Cluster Mode
295
-
296
- ```python
297
- from redis.cluster import RedisCluster
298
-
299
- r = RedisCluster(
300
- startup_nodes=[{"host": "redis-1", "port": 6379}],
301
- decode_responses=True,
302
- skip_full_coverage_check=True,
303
- )
304
- ```
305
-
306
- ### Sentinel (High Availability)
307
-
308
- ```python
309
- from redis.sentinel import Sentinel
310
-
311
- sentinel = Sentinel(
312
- [('sentinel-1', 26379), ('sentinel-2', 26379)],
313
- socket_timeout=0.5,
314
- )
315
- master = sentinel.master_for('mymaster', decode_responses=True)
316
- replica = sentinel.slave_for('mymaster', decode_responses=True)
317
- ```
318
-
319
- ## Eviction Policies
320
-
321
- | Policy | Behavior | Best For |
322
- |--------|----------|----------|
323
- | `noeviction` | Error on write when full | Queues / critical data |
324
- | `allkeys-lru` | Evict least recently used | General cache |
325
- | `volatile-lru` | LRU only among keys with TTL | Mixed data store |
326
- | `allkeys-lfu` | Evict least frequently used | Skewed access patterns |
327
- | `volatile-ttl` | Evict soonest-to-expire | Prioritize long-lived data |
328
-
329
- Set via `redis.conf`: `maxmemory-policy allkeys-lru`
330
-
331
- ## Anti-Patterns
332
-
333
- | Anti-Pattern | Problem | Fix |
334
- |---|---|---|
335
- | Keys with no TTL | Memory grows unbounded | Always set TTL |
336
- | `KEYS *` in production | Blocks the server (O(N)) | Use `SCAN` cursor |
337
- | Storing large blobs (>100KB) | Slow serialization, memory pressure | Store reference + fetch from object store |
338
- | Single Redis for everything | No isolation between cache & queue | Use separate DBs or instances |
339
- | Ignoring connection pool limits | Connection exhaustion under load | Size pool to workload |
340
- | Not handling cache miss stampede | Thundering herd on cold start | Use locks or probabilistic early expiry |
341
- | `FLUSHALL` without thought | Wipes entire instance | Scope deletes by key pattern |
342
-
343
- ### Cache Miss Stampede Prevention
344
-
345
- ```python
346
- import threading
347
-
348
- _locks: dict[str, threading.Lock] = {}
349
- _locks_mutex = threading.Lock()
350
-
351
- def get_with_lock(key: str, fetch_fn, ttl: int = 300):
352
- cached = r.get(key)
353
- if cached:
354
- return json.loads(cached)
355
-
356
- with _locks_mutex:
357
- if key not in _locks:
358
- _locks[key] = threading.Lock()
359
- lock = _locks[key]
360
- with lock:
361
- cached = r.get(key) # Re-check after acquiring lock
362
- if cached:
363
- return json.loads(cached)
364
- value = fetch_fn()
365
- r.setex(key, ttl, json.dumps(value))
366
- return value
367
- ```
368
-
369
- > Note: for multi-process deployments, replace the in-process lock with `acquire_lock`/`release_lock` from the Distributed Locks section above.
370
-
371
- ## Examples
372
-
373
- **Add caching to a Django/Flask API endpoint:**
374
- Use cache-aside with `setex` and a 5-minute TTL on the response. Key on the request parameters.
375
-
376
- **Rate-limit an API by user:**
377
- Use fixed-window with `pipeline(transaction=True)` for low-traffic endpoints; use sliding-window Lua for accurate per-user throttling.
378
-
379
- **Coordinate a background job across workers:**
380
- Use `acquire_lock` with a TTL that exceeds the expected job duration. Always release in a `finally` block.
381
-
382
- **Fan-out notifications to multiple subscribers:**
383
- Use Pub/Sub for fire-and-forget. Switch to Streams if you need guaranteed delivery or replay for late consumers.
384
-
385
- ## Quick Reference
386
-
387
- | Pattern | When to Use |
388
- |---------|-------------|
389
- | Cache-aside | Read-heavy, tolerate slight staleness |
390
- | Write-through | Strong consistency required |
391
- | Distributed lock | Prevent concurrent access to a resource |
392
- | Sliding window rate limit | Accurate per-user throttling |
393
- | Redis Streams | Durable event queue with consumer groups |
394
- | Pub/Sub | Broadcast with no delivery guarantees needed |
395
- | Sorted Set leaderboard | Ranked scoring, pagination |
396
- | HyperLogLog | Approximate unique count at low memory |
397
-
398
- ## Related
399
-
400
- - Skill: `postgres-patterns` — relational data patterns
401
- - Skill: `backend-patterns` — API and service layer patterns
402
- - Skill: `database-migrations` — schema versioning
403
- - Skill: `django-patterns` — Django cache framework integration
404
- - Agent: `database-reviewer` — full database review workflow
@@ -1,221 +0,0 @@
1
- ---
2
- name: regex-vs-llm-structured-text
3
- description: Decision framework for choosing between regex and LLM when parsing structured text — start with regex, add LLM only for low-confidence edge cases.
4
- metadata:
5
- origin: ECC
6
- ---
7
-
8
- # Regex vs LLM for Structured Text Parsing
9
-
10
- A practical decision framework for parsing structured text (quizzes, forms, invoices, documents). The key insight: regex handles 95-98% of cases cheaply and deterministically. Reserve expensive LLM calls for the remaining edge cases.
11
-
12
- ## When to Activate
13
-
14
- - Parsing structured text with repeating patterns (questions, forms, tables)
15
- - Deciding between regex and LLM for text extraction
16
- - Building hybrid pipelines that combine both approaches
17
- - Optimizing cost/accuracy tradeoffs in text processing
18
-
19
- ## Decision Framework
20
-
21
- ```
22
- Is the text format consistent and repeating?
23
- ├── Yes (>90% follows a pattern) → Start with Regex
24
- │ ├── Regex handles 95%+ → Done, no LLM needed
25
- │ └── Regex handles <95% → Add LLM for edge cases only
26
- └── No (free-form, highly variable) → Use LLM directly
27
- ```
28
-
29
- ## Architecture Pattern
30
-
31
- ```
32
- Source Text
33
-
34
-
35
- [Regex Parser] ─── Extracts structure (95-98% accuracy)
36
-
37
-
38
- [Text Cleaner] ─── Removes noise (markers, page numbers, artifacts)
39
-
40
-
41
- [Confidence Scorer] ─── Flags low-confidence extractions
42
-
43
- ├── High confidence (≥0.95) → Direct output
44
-
45
- └── Low confidence (<0.95) → [LLM Validator] → Output
46
- ```
47
-
48
- ## Implementation
49
-
50
- ### 1. Regex Parser (Handles the Majority)
51
-
52
- ```python
53
- import re
54
- from dataclasses import dataclass
55
-
56
- @dataclass(frozen=True)
57
- class ParsedItem:
58
- id: str
59
- text: str
60
- choices: tuple[str, ...]
61
- answer: str
62
- confidence: float = 1.0
63
-
64
- def parse_structured_text(content: str) -> list[ParsedItem]:
65
- """Parse structured text using regex patterns."""
66
- pattern = re.compile(
67
- r"(?P<id>\d+)\.\s*(?P<text>.+?)\n"
68
- r"(?P<choices>(?:[A-D]\..+?\n)+)"
69
- r"Answer:\s*(?P<answer>[A-D])",
70
- re.MULTILINE | re.DOTALL,
71
- )
72
- items = []
73
- for match in pattern.finditer(content):
74
- choices = tuple(
75
- c.strip() for c in re.findall(r"[A-D]\.\s*(.+)", match.group("choices"))
76
- )
77
- items.append(ParsedItem(
78
- id=match.group("id"),
79
- text=match.group("text").strip(),
80
- choices=choices,
81
- answer=match.group("answer"),
82
- ))
83
- return items
84
- ```
85
-
86
- ### 2. Confidence Scoring
87
-
88
- Flag items that may need LLM review:
89
-
90
- ```python
91
- @dataclass(frozen=True)
92
- class ConfidenceFlag:
93
- item_id: str
94
- score: float
95
- reasons: tuple[str, ...]
96
-
97
- def score_confidence(item: ParsedItem) -> ConfidenceFlag:
98
- """Score extraction confidence and flag issues."""
99
- reasons = []
100
- score = 1.0
101
-
102
- if len(item.choices) < 3:
103
- reasons.append("few_choices")
104
- score -= 0.3
105
-
106
- if not item.answer:
107
- reasons.append("missing_answer")
108
- score -= 0.5
109
-
110
- if len(item.text) < 10:
111
- reasons.append("short_text")
112
- score -= 0.2
113
-
114
- return ConfidenceFlag(
115
- item_id=item.id,
116
- score=max(0.0, score),
117
- reasons=tuple(reasons),
118
- )
119
-
120
- def identify_low_confidence(
121
- items: list[ParsedItem],
122
- threshold: float = 0.95,
123
- ) -> list[ConfidenceFlag]:
124
- """Return items below confidence threshold."""
125
- flags = [score_confidence(item) for item in items]
126
- return [f for f in flags if f.score < threshold]
127
- ```
128
-
129
- ### 3. LLM Validator (Edge Cases Only)
130
-
131
- ```python
132
- def validate_with_llm(
133
- item: ParsedItem,
134
- original_text: str,
135
- client,
136
- ) -> ParsedItem:
137
- """Use LLM to fix low-confidence extractions."""
138
- response = client.messages.create(
139
- model="claude-haiku-4-5-20251001", # Cheapest model for validation
140
- max_tokens=500,
141
- messages=[{
142
- "role": "user",
143
- "content": (
144
- f"Extract the question, choices, and answer from this text.\n\n"
145
- f"Text: {original_text}\n\n"
146
- f"Current extraction: {item}\n\n"
147
- f"Return corrected JSON if needed, or 'CORRECT' if accurate."
148
- ),
149
- }],
150
- )
151
- # Parse LLM response and return corrected item...
152
- return corrected_item
153
- ```
154
-
155
- ### 4. Hybrid Pipeline
156
-
157
- ```python
158
- def process_document(
159
- content: str,
160
- *,
161
- llm_client=None,
162
- confidence_threshold: float = 0.95,
163
- ) -> list[ParsedItem]:
164
- """Full pipeline: regex -> confidence check -> LLM for edge cases."""
165
- # Step 1: Regex extraction (handles 95-98%)
166
- items = parse_structured_text(content)
167
-
168
- # Step 2: Confidence scoring
169
- low_confidence = identify_low_confidence(items, confidence_threshold)
170
-
171
- if not low_confidence or llm_client is None:
172
- return items
173
-
174
- # Step 3: LLM validation (only for flagged items)
175
- low_conf_ids = {f.item_id for f in low_confidence}
176
- result = []
177
- for item in items:
178
- if item.id in low_conf_ids:
179
- result.append(validate_with_llm(item, content, llm_client))
180
- else:
181
- result.append(item)
182
-
183
- return result
184
- ```
185
-
186
- ## Real-World Metrics
187
-
188
- From a production quiz parsing pipeline (410 items):
189
-
190
- | Metric | Value |
191
- |--------|-------|
192
- | Regex success rate | 98.0% |
193
- | Low confidence items | 8 (2.0%) |
194
- | LLM calls needed | ~5 |
195
- | Cost savings vs all-LLM | ~95% |
196
- | Test coverage | 93% |
197
-
198
- ## Best Practices
199
-
200
- - **Start with regex** — even imperfect regex gives you a baseline to improve
201
- - **Use confidence scoring** to programmatically identify what needs LLM help
202
- - **Use the cheapest LLM** for validation (Haiku-class models are sufficient)
203
- - **Never mutate** parsed items — return new instances from cleaning/validation steps
204
- - **TDD works well** for parsers — write tests for known patterns first, then edge cases
205
- - **Log metrics** (regex success rate, LLM call count) to track pipeline health
206
-
207
- ## Anti-Patterns to Avoid
208
-
209
- - Sending all text to an LLM when regex handles 95%+ of cases (expensive and slow)
210
- - Using regex for free-form, highly variable text (LLM is better here)
211
- - Skipping confidence scoring and hoping regex "just works"
212
- - Mutating parsed objects during cleaning/validation steps
213
- - Not testing edge cases (malformed input, missing fields, encoding issues)
214
-
215
- ## When to Use
216
-
217
- - Quiz/exam question parsing
218
- - Form data extraction
219
- - Invoice/receipt processing
220
- - Document structure parsing (headers, sections, tables)
221
- - Any structured text with repeating patterns where cost matters
@@ -1,43 +0,0 @@
1
- ---
2
- name: remotion-video-creation
3
- description: Best practices for Remotion - Video creation in React. 29 domain-specific rules covering 3D, animations, audio, captions, charts, transitions, and more.
4
- metadata:
5
- tags: remotion, video, react, animation, composition, three.js, lottie
6
- ---
7
-
8
- ## When to use
9
-
10
- Use this skills whenever you are dealing with Remotion code to obtain the domain-specific knowledge.
11
-
12
- ## How to use
13
-
14
- Read individual rule files for detailed explanations and code examples:
15
-
16
- - [rules/3d.md](rules/3d.md) - 3D content in Remotion using Three.js and React Three Fiber
17
- - [rules/animations.md](rules/animations.md) - Fundamental animation skills for Remotion
18
- - [rules/assets.md](rules/assets.md) - Importing images, videos, audio, and fonts into Remotion
19
- - [rules/audio.md](rules/audio.md) - Using audio and sound in Remotion - importing, trimming, volume, speed, pitch
20
- - [rules/calculate-metadata.md](rules/calculate-metadata.md) - Dynamically set composition duration, dimensions, and props
21
- - [rules/can-decode.md](rules/can-decode.md) - Check if a video can be decoded by the browser using Mediabunny
22
- - [rules/charts.md](rules/charts.md) - Chart and data visualization patterns for Remotion
23
- - [rules/compositions.md](rules/compositions.md) - Defining compositions, stills, folders, default props and dynamic metadata
24
- - [rules/display-captions.md](rules/display-captions.md) - Displaying captions in Remotion with TikTok-style pages and word highlighting
25
- - [rules/extract-frames.md](rules/extract-frames.md) - Extract frames from videos at specific timestamps using Mediabunny
26
- - [rules/fonts.md](rules/fonts.md) - Loading Google Fonts and local fonts in Remotion
27
- - [rules/get-audio-duration.md](rules/get-audio-duration.md) - Getting the duration of an audio file in seconds with Mediabunny
28
- - [rules/get-video-dimensions.md](rules/get-video-dimensions.md) - Getting the width and height of a video file with Mediabunny
29
- - [rules/get-video-duration.md](rules/get-video-duration.md) - Getting the duration of a video file in seconds with Mediabunny
30
- - [rules/gifs.md](rules/gifs.md) - Displaying GIFs synchronized with Remotion's timeline
31
- - [rules/images.md](rules/images.md) - Embedding images in Remotion using the Img component
32
- - [rules/import-srt-captions.md](rules/import-srt-captions.md) - Importing .srt subtitle files into Remotion using @remotion/captions
33
- - [rules/lottie.md](rules/lottie.md) - Embedding Lottie animations in Remotion
34
- - [rules/measuring-dom-nodes.md](rules/measuring-dom-nodes.md) - Measuring DOM element dimensions in Remotion
35
- - [rules/measuring-text.md](rules/measuring-text.md) - Measuring text dimensions, fitting text to containers, and checking overflow
36
- - [rules/sequencing.md](rules/sequencing.md) - Sequencing patterns for Remotion - delay, trim, limit duration of items
37
- - [rules/tailwind.md](rules/tailwind.md) - Using TailwindCSS in Remotion
38
- - [rules/text-animations.md](rules/text-animations.md) - Typography and text animation patterns for Remotion
39
- - [rules/timing.md](rules/timing.md) - Interpolation curves in Remotion - linear, easing, spring animations
40
- - [rules/transcribe-captions.md](rules/transcribe-captions.md) - Transcribing audio to generate captions in Remotion
41
- - [rules/transitions.md](rules/transitions.md) - Scene transition patterns for Remotion
42
- - [rules/trimming.md](rules/trimming.md) - Trimming patterns for Remotion - cut the beginning or end of animations
43
- - [rules/videos.md](rules/videos.md) - Embedding videos in Remotion - trimming, volume, speed, looping, pitch