@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,306 +0,0 @@
1
- ---
2
- name: homelab-wireguard-vpn
3
- description: WireGuard VPN server setup, peer configuration, key generation, split tunneling vs full tunnel routing, and remote access to a home network from mobile and laptop clients.
4
- metadata:
5
- origin: community
6
- ---
7
-
8
- # Homelab WireGuard VPN
9
-
10
- WireGuard is a fast, modern VPN protocol. It is the right choice for remote access to a
11
- home network — simpler to configure than OpenVPN and faster than most alternatives.
12
-
13
- All configuration examples show common setups. Review each command — especially the
14
- iptables forwarding rules and key file permissions — before applying them to your
15
- system, and make changes in a maintenance window.
16
-
17
- ## When to Use
18
-
19
- - Setting up WireGuard server on a Raspberry Pi, Linux host, pfSense, or router
20
- - Generating WireGuard keypairs and writing peer config files
21
- - Configuring remote access from a phone or laptop to a home network
22
- - Explaining split tunneling (route only home traffic) vs full tunnel (route all traffic)
23
- - Troubleshooting WireGuard connections that will not come up
24
- - Automating peer configuration generation for multiple clients
25
-
26
- ## How WireGuard Works
27
-
28
- ```
29
- Your phone (WireGuard client)
30
-
31
- │ Encrypted UDP tunnel (port 51820)
32
-
33
- Your home router (WireGuard server — needs a public IP or DDNS)
34
-
35
- Your home network (192.168.1.0/24, NAS, Pi, etc.)
36
-
37
- Every device has a keypair (public + private key).
38
- The server knows each client's public key.
39
- The client knows the server's public key + endpoint (IP:port).
40
- Traffic is encrypted end-to-end with no central server or certificate authority.
41
- ```
42
-
43
- ## Server Setup (Linux)
44
-
45
- ```bash
46
- # Install WireGuard
47
- sudo apt update && sudo apt install wireguard -y
48
-
49
- # Generate server keypair — create files with private permissions from the start
50
- sudo mkdir -p /etc/wireguard
51
- sudo sh -c 'umask 077; wg genkey > /etc/wireguard/server_private.key'
52
- sudo sh -c 'wg pubkey < /etc/wireguard/server_private.key > /etc/wireguard/server_public.key'
53
-
54
- # Write server config — substitute the actual private key value
55
- # Do not store private keys in version control or share them
56
- sudo tee /etc/wireguard/wg0.conf << 'EOF'
57
- [Interface]
58
- Address = 10.8.0.1/24 # VPN subnet — server gets .1
59
- ListenPort = 51820
60
- PrivateKey = <paste_server_private_key_here>
61
-
62
- # Scoped forwarding rules: allow VPN traffic in/out, not a blanket FORWARD ACCEPT
63
- PostUp = iptables -A FORWARD -i wg0 -o eth0 -j ACCEPT
64
- PostUp = iptables -A FORWARD -i eth0 -o wg0 -m conntrack --ctstate RELATED,ESTABLISHED -j ACCEPT
65
- PostUp = iptables -t nat -A POSTROUTING -o eth0 -j MASQUERADE
66
- PostDown = iptables -D FORWARD -i wg0 -o eth0 -j ACCEPT
67
- PostDown = iptables -D FORWARD -i eth0 -o wg0 -m conntrack --ctstate RELATED,ESTABLISHED -j ACCEPT
68
- PostDown = iptables -t nat -D POSTROUTING -o eth0 -j MASQUERADE
69
-
70
- [Peer]
71
- # Phone — replace with the actual phone public key
72
- PublicKey = <phone_public_key>
73
- AllowedIPs = 10.8.0.2/32
74
-
75
- [Peer]
76
- # Laptop — replace with the actual laptop public key
77
- PublicKey = <laptop_public_key>
78
- AllowedIPs = 10.8.0.3/32
79
- EOF
80
- sudo chmod 600 /etc/wireguard/wg0.conf
81
-
82
- # Replace eth0 with your actual outbound interface name
83
- # Check with: ip route show default
84
-
85
- # Enable IP forwarding (required for routing traffic through the server)
86
- echo "net.ipv4.ip_forward=1" | sudo tee /etc/sysctl.d/99-wireguard.conf
87
- sudo sysctl --system
88
-
89
- # Start WireGuard and enable on boot
90
- sudo wg-quick up wg0
91
- sudo systemctl enable wg-quick@wg0
92
- ```
93
-
94
- ## Client Configuration
95
-
96
- ```bash
97
- # Generate a unique keypair for each client device
98
- # Run on the client, or on the server and transfer the private key securely — never in plaintext
99
- umask 077
100
- wg genkey | tee phone_private.key | wg pubkey > phone_public.key
101
-
102
- # Client config file (phone_wg0.conf):
103
- [Interface]
104
- PrivateKey = <phone_private_key>
105
- Address = 10.8.0.2/32
106
- DNS = 192.168.1.2 # Optional: use Pi-hole for DNS over the tunnel
107
-
108
- [Peer]
109
- PublicKey = <server_public_key>
110
- Endpoint = your-home-ip.ddns.net:51820 # Your public IP or DDNS hostname
111
- AllowedIPs = 192.168.1.0/24 # Split tunnel: only home network traffic
112
- # AllowedIPs = 0.0.0.0/0, ::/0 # Full tunnel: all traffic through VPN
113
-
114
- PersistentKeepalive = 25 # Keep NAT hole open (required for mobile clients)
115
- ```
116
-
117
- ## Split Tunnel vs Full Tunnel
118
-
119
- ```
120
- # Split tunnel: AllowedIPs = 192.168.1.0/24
121
- Only traffic destined for your home network goes through the VPN.
122
- Internet traffic (YouTube, Spotify) goes directly — better performance on mobile.
123
- Best for: "I just want to reach my NAS and Pi from anywhere."
124
-
125
- # Full tunnel: AllowedIPs = 0.0.0.0/0, ::/0
126
- ALL traffic goes through your home internet connection.
127
- Useful for: piggybacking home DNS/Pi-hole ad blocking.
128
- Downside: home upload speed becomes your bottleneck everywhere.
129
-
130
- # Multi-subnet split tunnel (most common homelab use case):
131
- AllowedIPs = 192.168.10.0/24, 192.168.20.0/24, 192.168.30.0/24, 10.8.0.0/24
132
- Routes all your VLANs through the tunnel; internet stays direct.
133
- ```
134
-
135
- ## Key Generation and Peer Management
136
-
137
- ```python
138
- import subprocess
139
-
140
- def generate_keypair() -> tuple[str, str]:
141
- """Generate a WireGuard keypair. Returns (private_key, public_key)."""
142
- private = subprocess.check_output(["wg", "genkey"]).decode().strip()
143
- public = subprocess.run(
144
- ["wg", "pubkey"], input=private.encode(), capture_output=True
145
- ).stdout.decode().strip()
146
- return private, public
147
-
148
- def generate_preshared_key() -> str:
149
- return subprocess.check_output(["wg", "genpsk"]).decode().strip()
150
-
151
- def build_client_config(
152
- client_private_key: str,
153
- client_vpn_ip: str, # e.g. "10.8.0.3"
154
- server_public_key: str,
155
- server_endpoint: str, # e.g. "home.example.com:51820"
156
- allowed_ips: str = "192.168.1.0/24",
157
- dns: str = "",
158
- ) -> str:
159
- dns_line = f"DNS = {dns}\n" if dns else ""
160
- return f"""[Interface]
161
- PrivateKey = {client_private_key}
162
- Address = {client_vpn_ip}/32
163
- {dns_line}
164
- [Peer]
165
- PublicKey = {server_public_key}
166
- Endpoint = {server_endpoint}
167
- AllowedIPs = {allowed_ips}
168
- PersistentKeepalive = 25
169
- """
170
-
171
- def build_server_peer_block(
172
- client_public_key: str,
173
- client_vpn_ip: str,
174
- comment: str = "",
175
- ) -> str:
176
- comment_line = f"# {comment}\n" if comment else ""
177
- return f"""
178
- {comment_line}[Peer]
179
- PublicKey = {client_public_key}
180
- AllowedIPs = {client_vpn_ip}/32
181
- """
182
- ```
183
-
184
- Keep private keys out of source control. If you use this script, write key material
185
- to files with mode 600 and never log or print it.
186
-
187
- ## pfSense / OPNsense WireGuard
188
-
189
- ```
190
- # pfSense: VPN → WireGuard → Add Tunnel
191
- Interface Keys: Generate (creates keypair automatically)
192
- Listen Port: 51820
193
- Interface Address: 10.8.0.1/24
194
-
195
- # Add Peer (one per client):
196
- Public Key: <client public key>
197
- Allowed IPs: 10.8.0.2/32
198
-
199
- # Assign the WireGuard interface:
200
- Interfaces → Assignments → Add (select wg0)
201
- Enable interface, no IP needed (it is set in the tunnel config)
202
-
203
- # Firewall rules:
204
- WAN → Allow UDP port 51820 inbound (so clients can reach the server)
205
- WireGuard interface → Allow traffic to LAN networks you want reachable
206
- ```
207
-
208
- ## DDNS (Dynamic DNS) for Home Servers
209
-
210
- Most home internet connections have a dynamic IP. Use DDNS so your VPN endpoint
211
- stays reachable after an IP change.
212
-
213
- ```bash
214
- # Option 1: Cloudflare DDNS — store credentials in a secrets file, not inline
215
- # docker-compose entry using an env file:
216
- ddns-updater:
217
- image: qmcgaw/ddns-updater
218
- env_file: ./ddns.env # store zone_id and token here, not in compose
219
- restart: unless-stopped
220
-
221
- # ddns.env (chmod 600, not committed to git):
222
- # SETTINGS_CLOUDFLARE_ZONE_ID=your_zone_id
223
- # SETTINGS_CLOUDFLARE_TOKEN=your_api_token
224
-
225
- # Option 2: DuckDNS (free, simple)
226
- Sign up at duckdns.org → get a token and subdomain (myhome.duckdns.org)
227
- Store token in /etc/ddns.env (mode 600), then use a small root-owned script:
228
-
229
- # /usr/local/bin/update-duckdns
230
- #!/bin/sh
231
- set -eu
232
- . /etc/ddns.env
233
- curl --fail --silent --show-error --max-time 10 \
234
- --get "https://www.duckdns.org/update" \
235
- --data-urlencode "domains=myhome" \
236
- --data-urlencode "token=${DUCKDNS_TOKEN}" \
237
- --data-urlencode "ip="
238
-
239
- # Cron job:
240
- */5 * * * * /usr/local/bin/update-duckdns >/dev/null 2>&1
241
- ```
242
-
243
- ## Troubleshooting
244
-
245
- ```bash
246
- # Check WireGuard status and last handshake
247
- sudo wg show
248
-
249
- # If "latest handshake" is never or very old, the tunnel is not connected.
250
- # Check:
251
- # 1. Is UDP port 51820 open on the router/firewall?
252
- sudo ufw status # or check pfSense/UniFi firewall rules
253
-
254
- # 2. Is the server public key in the client config correct?
255
- sudo wg show wg0 public-key # Compare to what is in the client config
256
-
257
- # 3. Is IP forwarding enabled on the server?
258
- cat /proc/sys/net/ipv4/ip_forward # Should be 1
259
-
260
- # 4. Does the client AllowedIPs cover the IP you are trying to reach?
261
- # If AllowedIPs = 192.168.1.0/24 and you are trying to reach 192.168.3.5, it will not route.
262
-
263
- # Check kernel logs for WireGuard errors
264
- dmesg | grep wireguard
265
-
266
- # Restart WireGuard
267
- sudo wg-quick down wg0 && sudo wg-quick up wg0
268
- ```
269
-
270
- ## Anti-Patterns
271
-
272
- ```
273
- # BAD: Storing private keys in version control or sharing them
274
- # Private keys are equivalent to passwords — never commit them to git
275
-
276
- # BAD: Using AllowedIPs = 0.0.0.0/0 on mobile without considering the impact
277
- # Full tunnel routes all mobile traffic through your home upload — usually slow
278
-
279
- # BAD: Not setting PersistentKeepalive on mobile clients
280
- # Mobile clients behind NAT drop idle tunnels without it
281
-
282
- # BAD: Opening port 51820 in the firewall but forgetting IP forwarding on the server
283
- # Tunnel connects but no traffic routes — confusing to debug
284
-
285
- # BAD: Sharing a keypair across multiple client devices
286
- # Each device must have its own unique keypair — shared keys break the security model
287
-
288
- # BAD: Using a broad "FORWARD ACCEPT" iptables rule
289
- # Scope forwarding rules to the wg0 interface and direction only
290
- ```
291
-
292
- ## Best Practices
293
-
294
- - Generate a unique keypair per client device — never reuse keys
295
- - Use split tunneling (`AllowedIPs = <home subnets>`) for mobile
296
- - Set `PersistentKeepalive = 25` on all mobile clients
297
- - Use DDNS if your ISP assigns a dynamic IP; store credentials in env files, not inline
298
- - Use scoped iptables forwarding rules (inbound on wg0 only) rather than a blanket FORWARD ACCEPT
299
- - Add Pi-hole's IP as `DNS =` in client configs to get ad blocking over the VPN
300
- - Rotate the server keypair periodically and update all client configs
301
-
302
- ## Related Skills
303
-
304
- - homelab-network-setup
305
- - homelab-vlan-segmentation
306
- - homelab-pihole-dns
@@ -1,128 +0,0 @@
1
- ---
2
- name: hookify-rules
3
- description: This skill should be used when the user asks to create a hookify rule, write a hook rule, configure hookify, add a hookify rule, or needs guidance on hookify rule syntax and patterns.
4
- ---
5
-
6
- # Writing Hookify Rules
7
-
8
- ## Overview
9
-
10
- Hookify rules are markdown files with YAML frontmatter that define patterns to watch for and messages to show when those patterns match. Rules are stored in `.claude/hookify.{rule-name}.local.md` files.
11
-
12
- ## Rule File Format
13
-
14
- ### Basic Structure
15
-
16
- ```markdown
17
- ---
18
- name: rule-identifier
19
- enabled: true
20
- event: bash|file|stop|prompt|all
21
- pattern: regex-pattern-here
22
- ---
23
-
24
- Message to show Claude when this rule triggers.
25
- Can include markdown formatting, warnings, suggestions, etc.
26
- ```
27
-
28
- ### Frontmatter Fields
29
-
30
- | Field | Required | Values | Description |
31
- |-------|----------|--------|-------------|
32
- | name | Yes | kebab-case string | Unique identifier (verb-first: warn-*, block-*, require-*) |
33
- | enabled | Yes | true/false | Toggle without deleting |
34
- | event | Yes | bash/file/stop/prompt/all | Which hook event triggers this |
35
- | action | No | warn/block | warn (default) shows message; block prevents operation |
36
- | pattern | Yes* | regex string | Pattern to match (*or use conditions for complex rules) |
37
-
38
- ### Advanced Format (Multiple Conditions)
39
-
40
- ```markdown
41
- ---
42
- name: warn-env-api-keys
43
- enabled: true
44
- event: file
45
- conditions:
46
- - field: file_path
47
- operator: regex_match
48
- pattern: \.env$
49
- - field: new_text
50
- operator: contains
51
- pattern: API_KEY
52
- ---
53
-
54
- You're adding an API key to a .env file. Ensure this file is in .gitignore!
55
- ```
56
-
57
- **Condition fields by event:**
58
- - bash: `command`
59
- - file: `file_path`, `new_text`, `old_text`, `content`
60
- - prompt: `user_prompt`
61
-
62
- **Operators:** `regex_match`, `contains`, `equals`, `not_contains`, `starts_with`, `ends_with`
63
-
64
- All conditions must match for rule to trigger.
65
-
66
- ## Event Type Guide
67
-
68
- ### bash Events
69
- Match Bash command patterns:
70
- - Dangerous commands: `rm\s+-rf`, `dd\s+if=`, `mkfs`
71
- - Privilege escalation: `sudo\s+`, `su\s+`
72
- - Permission issues: `chmod\s+777`
73
-
74
- ### file Events
75
- Match Edit/Write/MultiEdit operations:
76
- - Debug code: `console\.log\(`, `debugger`
77
- - Security risks: `eval\(`, `innerHTML\s*=`
78
- - Sensitive files: `\.env$`, `credentials`, `\.pem$`
79
-
80
- ### stop Events
81
- Completion checks and reminders. Pattern `.*` matches always.
82
-
83
- ### prompt Events
84
- Match user prompt content for workflow enforcement.
85
-
86
- ## Pattern Writing Tips
87
-
88
- ### Regex Basics
89
- - Escape special chars: `.` to `\.`, `(` to `\(`
90
- - `\s` whitespace, `\d` digit, `\w` word char
91
- - `+` one or more, `*` zero or more, `?` optional
92
- - `|` OR operator
93
-
94
- ### Common Pitfalls
95
- - **Too broad**: `log` matches "login", "dialog" — use `console\.log\(`
96
- - **Too specific**: `rm -rf /tmp` — use `rm\s+-rf`
97
- - **YAML escaping**: Use unquoted patterns; quoted strings need `\\s`
98
-
99
- ### Testing
100
- ```bash
101
- python3 -c "import re; print(re.search(r'your_pattern', 'test text'))"
102
- ```
103
-
104
- ## File Organization
105
-
106
- - **Location**: `.claude/` directory in project root
107
- - **Naming**: `.claude/hookify.{descriptive-name}.local.md`
108
- - **Gitignore**: Add `.claude/*.local.md` to `.gitignore`
109
-
110
- ## Commands
111
-
112
- - `/hookify [description]` - Create new rules (auto-analyzes conversation if no args)
113
- - `/hookify-list` - View all rules in table format
114
- - `/hookify-configure` - Toggle rules on/off interactively
115
- - `/hookify-help` - Full documentation
116
-
117
- ## Quick Reference
118
-
119
- Minimum viable rule:
120
- ```markdown
121
- ---
122
- name: my-rule
123
- enabled: true
124
- event: bash
125
- pattern: dangerous_command
126
- ---
127
- Warning message here
128
- ```
@@ -1,157 +0,0 @@
1
- ---
2
- name: inherit-legacy-style
3
- description: Legacy-project style inheritance skill. Use when the user types /inherit-legacy-style, or when onboarding an AI coding agent onto a hand-written legacy project and you need to prevent "style drift" (the model imposing its pretrained mainstream idioms onto the project). Language- and framework-agnostic — it aligns meta-architecture only, not syntax. Once run, it becomes a behavioral constraint on all subsequent coding tasks. Do NOT use for pure research or one-off questions unrelated to code-style alignment.
4
- metadata:
5
- origin: community
6
- allowed-tools: Read, Glob, Grep, Bash, Edit, Write, AskUserQuestion
7
- ---
8
-
9
- # Inherit Legacy Style
10
-
11
- Prevents AI code style drift in legacy projects by scanning the codebase for implicit conventions across 4 meta-architecture dimensions, resolving conflicts with the user one at a time, and crystallizing the consensus into an enforceable `.ai-style-rules.md`. Fully language- and framework-agnostic.
12
-
13
- ## When to Activate
14
-
15
- - User types `/inherit-legacy-style`
16
- - User mentions onboarding AI onto a hand-written legacy project
17
- - User is worried about AI-generated code "drifting" from existing project conventions
18
- - User wants to extract and codify their project's implicit coding rules
19
-
20
- ## When to Use
21
-
22
- Use this skill when you need to preserve legacy project style and prevent AI-generated style drift. See **When to Activate** above for trigger conditions.
23
-
24
- ## Prerequisites
25
-
26
- - Git (recommended; non-Git projects fall back to file timestamps for incremental mode)
27
- - Read/Write access to the project root (generates `.ai-style-rules.md` and optionally `CLAUDE.md`)
28
-
29
- ## Workflow
30
-
31
- ### Step 0 — Auto-Detect Mode
32
-
33
- Silently check for `.ai-style-rules.md` at the project root:
34
-
35
- | File exists? | Mode |
36
- |---|---|
37
- | No | **Branch A — First-time Full-Scan** |
38
- | Yes | **Branch B — Incremental Sniff** |
39
-
40
- Announce the mode in one line and proceed — never ask the user to pick.
41
-
42
- ### Branch A — First-time Full-Scan
43
-
44
- **1. Measure scale, pick a scanning tier**
45
-
46
- ```bash
47
- git ls-files | grep -cE '\.(js|ts|jsx|tsx|vue|py|go|rs|java|kt|rb|php|cs|swift|c|cpp|h)$'
48
- ```
49
-
50
- | Tier | Source files | Strategy |
51
- |---|---|---|
52
- | Small | ≲ 50 | Full close-read every source |
53
- | Medium | 50–500 | Infra layer = full read; business layer = sample 2–3 per dimension |
54
- | Large | ≳ 500 | Strict sampling + budget cap; `--stat` summary first, then targeted reads |
55
-
56
- **2. Scan along 4 dimensions**
57
-
58
- 1. **File Anatomy** — in-file declaration order (imports → types → main logic → helpers → export)
59
- 2. **State & Control Flow** — naming conventions for async state, pagination, flags
60
- 3. **Infrastructure** — where cross-cutting utils live (interceptors, formatters, middleware)
61
- 4. **Error Handling** — try/catch vs global interceptor vs Result return; null-check habits
62
-
63
- **3. Apply signal-threshold noise reduction**
64
-
65
- Before interrupting the user, evaluate signal strength:
66
-
67
- - **Weak signal** → auto-suppress: minority <5% AND count <10 → majority wins, minority goes to DONTs
68
- - **Strong signal** → grill: near-even split, or semantic fork on a core dimension
69
- - **Small-project exception**: sources ≲50, "3 vs 2" is NOT a majority → grill it
70
-
71
- **4. Resolve conflicts one at a time (Grilling Protocol)**
72
-
73
- For each strong-signal conflict, present exactly ONE question with 4 options:
74
-
75
- > Evidence: `pathA` uses style X, `pathB` uses style Y
76
- > WARNING: Risk: mixing both fractures the project style
77
- > Choose: `1` follow X `2` follow Y `3` this is evolution, update rules `4` I have a new rule
78
-
79
- Suspend until the user answers, then proceed to the next conflict. Never stack questions.
80
-
81
- **5. Generate `.ai-style-rules.md`** with three mandatory sections:
82
- - **[Golden Files]** — real exemplar paths annotated with what they demonstrate
83
- - **[Naming & State-Control Rules]** — concrete, checkable conventions
84
- - **[DONTs]** — anti-patterns that must not propagate
85
-
86
- **6. Install the persistent hook**
87
-
88
- Ask the user for enforcement strength (use `AskUserQuestion`):
89
-
90
- | Option | Mechanism |
91
- |---|---|
92
- | **1** Soft hook (recommended) | Write `@.ai-style-rules.md` reference into project `CLAUDE.md` |
93
- | **2** Hard hook | Soft hook + `PreToolUse[Write\|Edit\|MultiEdit]` Hook in `settings.json` |
94
- | **3** No hook | Keep the rules file; user references manually |
95
-
96
- ### Branch B — Incremental Sniff
97
-
98
- 1. Read existing `.ai-style-rules.md`; if it has a commit fingerprint, `git diff <last_hash> HEAD --stat` to pinpoint delta
99
- 2. Read recent Git changes (`git log -3 --stat` → inspect suspect files on demand)
100
- 3. For oversized diffs (>hundreds of files): `--stat` summary only + sample the largest changes
101
- 4. Compare new code against recorded rules → conflicts go through Grilling Protocol
102
- 5. Append evolution log at the end of `.ai-style-rules.md` (never overwrite old rules)
103
-
104
- ### Per-Turn Enforcement
105
-
106
- When `.ai-style-rules.md` is in context (loaded via CLAUDE.md), every code-writing task must open with a **compliance declaration** in the reasoning chain, naming the exemplar being followed and the DONTs being avoided.
107
-
108
- ## How It Works
109
-
110
- This skill auto-detects whether it's a first-time or incremental run via `.ai-style-rules.md` presence:
111
-
112
- - **First-time (Branch A)** — Measures project scale, scans codebase across 4 meta-architecture dimensions (File Anatomy, State & Control Flow, Infrastructure, Error Handling), applies signal-threshold noise reduction to suppress weak conflicts, resolves strong-signal conflicts one-at-a-time with the user, generates `.ai-style-rules.md` with Golden Files / Naming Rules / DONTs, and offers optional enforcement hooks.
113
- - **Incremental (Branch B)** — Reads existing rules, checks recent Git diffs for new or conflicting patterns, runs the same one-at-a-time grilling protocol for any conflicts found, and appends evolution logs without overwriting existing rules.
114
- - **Per-Turn Enforcement** — When hooked via `CLAUDE.md`, every code-writing task opens with a compliance declaration naming the exemplar followed and the DONTs avoided.
115
-
116
- ## Output Specification
117
-
118
- - `.ai-style-rules.md` at project root (with commit fingerprint + scale tier in header)
119
- - Optionally `CLAUDE.md` with `@.ai-style-rules.md` reference
120
- - Evolution logs appended as `### [YYYY-MM-DD] Style Evolution Log` entries
121
-
122
- ## Anti-Patterns
123
-
124
- - FAIL: Do NOT skip the scale measurement step — sampling a 30-file project "starves" it; full-scanning a 5,000-file repo blows up
125
- - FAIL: Do NOT stack multiple conflict questions at once — grilling is strictly one-at-a-time
126
- - FAIL: Do NOT overwrite old rules in incremental mode — always append evolution logs
127
- - FAIL: Do NOT default to "hard hook" without asking — enforcement strength is the user's call
128
- - FAIL: Do NOT judge syntax or tech-stack quality — this skill aligns meta-architecture only
129
- - FAIL: Do NOT copy bugs from exemplar files — reuse structure, flag defects
130
-
131
- ## Best Practices
132
-
133
- - Announce the detected mode (first-time vs incremental) and scale tier in one line before scanning
134
- - For large projects, read `--stat` summaries first, then targeted `Read` on suspect files
135
- - Let the signal threshold handle noise — a 843-vs-8 naming split should auto-resolve without user interruption
136
- - When in doubt about signal strength, lean toward asking
137
- - The CLAUDE.md soft hook (`@.ai-style-rules.md`) is usually sufficient; hard hook only if the user wants mechanical enforcement
138
-
139
- ## Related Skills
140
-
141
- - `init` — initialize a new CLAUDE.md with codebase documentation
142
- - `code-review` — review diffs for correctness and style issues
143
- - `simplify` — review code for reuse and simplification opportunities
144
-
145
- ## Examples
146
-
147
- 1. **First-time onboarding**
148
- - User: "Help me onboard AI to this older codebase without changing its style."
149
- - Action: Run Branch A full-scan → measure scale → scan 4 dimensions → grill conflicts → generate `.ai-style-rules.md` → offer hook strength (soft/hard/none).
150
-
151
- 2. **Incremental update after team changes**
152
- - User: "We added a new module; keep existing style rules intact."
153
- - Action: Run Branch B incremental sniff → compare Git deltas to recorded rules → grill any new conflicts → append evolution log without overwriting.
154
-
155
- 3. **Enforcing DONTs via CLAUDE.md**
156
- - User: "Make sure all new code stays consistent with the project's rules."
157
- - Action: Soft hook installed → `.ai-style-rules.md` auto-loaded every session → every code-writing task opens with compliance declaration, reusing exemplar patterns and avoiding DONTs.