@rubix0270/arboris 1.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (451) hide show
  1. package/README.md +151 -0
  2. package/cli/manifest.json +323 -0
  3. package/dist/cli.mjs +376 -0
  4. package/package.json +81 -0
  5. package/prisma/skills/accessibility/SKILL.md +147 -0
  6. package/prisma/skills/agent-architecture-audit/SKILL.md +257 -0
  7. package/prisma/skills/agent-eval/SKILL.md +146 -0
  8. package/prisma/skills/agent-harness-construction/SKILL.md +74 -0
  9. package/prisma/skills/agent-introspection-debugging/SKILL.md +154 -0
  10. package/prisma/skills/agent-payment-x402/SKILL.md +225 -0
  11. package/prisma/skills/agent-self-evaluation/SKILL.md +182 -0
  12. package/prisma/skills/agent-self-evaluation/examples/high-score-example.md +87 -0
  13. package/prisma/skills/agent-self-evaluation/examples/low-score-example.md +86 -0
  14. package/prisma/skills/agent-self-evaluation/references/evaluation-criteria.md +71 -0
  15. package/prisma/skills/agent-self-evaluation/references/hook-integration.md +64 -0
  16. package/prisma/skills/agent-self-evaluation/scripts/evaluate.py +408 -0
  17. package/prisma/skills/agent-self-evaluation/templates/evaluation-report.md +86 -0
  18. package/prisma/skills/agent-sort/SKILL.md +216 -0
  19. package/prisma/skills/agentic-engineering/SKILL.md +64 -0
  20. package/prisma/skills/agentic-os/SKILL.md +388 -0
  21. package/prisma/skills/ai-first-engineering/SKILL.md +52 -0
  22. package/prisma/skills/ai-regression-testing/SKILL.md +386 -0
  23. package/prisma/skills/android-clean-architecture/SKILL.md +340 -0
  24. package/prisma/skills/angular-developer/SKILL.md +155 -0
  25. package/prisma/skills/angular-developer/references/angular-animations.md +160 -0
  26. package/prisma/skills/angular-developer/references/angular-aria.md +410 -0
  27. package/prisma/skills/angular-developer/references/cli.md +86 -0
  28. package/prisma/skills/angular-developer/references/component-harnesses.md +59 -0
  29. package/prisma/skills/angular-developer/references/component-styling.md +91 -0
  30. package/prisma/skills/angular-developer/references/components.md +117 -0
  31. package/prisma/skills/angular-developer/references/creating-services.md +97 -0
  32. package/prisma/skills/angular-developer/references/data-resolvers.md +69 -0
  33. package/prisma/skills/angular-developer/references/define-routes.md +67 -0
  34. package/prisma/skills/angular-developer/references/defining-providers.md +72 -0
  35. package/prisma/skills/angular-developer/references/di-fundamentals.md +120 -0
  36. package/prisma/skills/angular-developer/references/e2e-testing.md +56 -0
  37. package/prisma/skills/angular-developer/references/effects.md +83 -0
  38. package/prisma/skills/angular-developer/references/hierarchical-injectors.md +43 -0
  39. package/prisma/skills/angular-developer/references/host-elements.md +80 -0
  40. package/prisma/skills/angular-developer/references/injection-context.md +63 -0
  41. package/prisma/skills/angular-developer/references/inputs.md +101 -0
  42. package/prisma/skills/angular-developer/references/linked-signal.md +59 -0
  43. package/prisma/skills/angular-developer/references/loading-strategies.md +61 -0
  44. package/prisma/skills/angular-developer/references/mcp.md +108 -0
  45. package/prisma/skills/angular-developer/references/navigate-to-routes.md +69 -0
  46. package/prisma/skills/angular-developer/references/outputs.md +86 -0
  47. package/prisma/skills/angular-developer/references/reactive-forms.md +122 -0
  48. package/prisma/skills/angular-developer/references/rendering-strategies.md +44 -0
  49. package/prisma/skills/angular-developer/references/resource.md +77 -0
  50. package/prisma/skills/angular-developer/references/route-animations.md +56 -0
  51. package/prisma/skills/angular-developer/references/route-guards.md +52 -0
  52. package/prisma/skills/angular-developer/references/router-lifecycle.md +45 -0
  53. package/prisma/skills/angular-developer/references/router-testing.md +87 -0
  54. package/prisma/skills/angular-developer/references/show-routes-with-outlets.md +68 -0
  55. package/prisma/skills/angular-developer/references/signal-forms.md +795 -0
  56. package/prisma/skills/angular-developer/references/signals-overview.md +94 -0
  57. package/prisma/skills/angular-developer/references/tailwind-css.md +69 -0
  58. package/prisma/skills/angular-developer/references/template-driven-forms.md +114 -0
  59. package/prisma/skills/angular-developer/references/testing-fundamentals.md +65 -0
  60. package/prisma/skills/api-connector-builder/SKILL.md +121 -0
  61. package/prisma/skills/api-design/SKILL.md +524 -0
  62. package/prisma/skills/architecture-decision-records/SKILL.md +180 -0
  63. package/prisma/skills/article-writing/SKILL.md +80 -0
  64. package/prisma/skills/automation-audit-ops/SKILL.md +143 -0
  65. package/prisma/skills/autonomous-agent-harness/SKILL.md +274 -0
  66. package/prisma/skills/autonomous-loops/SKILL.md +611 -0
  67. package/prisma/skills/backend-patterns/SKILL.md +562 -0
  68. package/prisma/skills/benchmark/SKILL.md +94 -0
  69. package/prisma/skills/benchmark-methodology/SKILL.md +190 -0
  70. package/prisma/skills/benchmark-optimization-loop/SKILL.md +70 -0
  71. package/prisma/skills/blender-motion-state-inspection/SKILL.md +165 -0
  72. package/prisma/skills/blueprint/SKILL.md +106 -0
  73. package/prisma/skills/brand-discovery/SKILL.md +145 -0
  74. package/prisma/skills/brand-discovery/references/10_purpose-why.md +40 -0
  75. package/prisma/skills/brand-discovery/references/20_positioning.md +44 -0
  76. package/prisma/skills/brand-discovery/references/30_audience-niche.md +52 -0
  77. package/prisma/skills/brand-discovery/references/40_personality-archetype.md +57 -0
  78. package/prisma/skills/brand-discovery/references/50_voice-tone.md +59 -0
  79. package/prisma/skills/brand-discovery/references/60_narrative-story.md +50 -0
  80. package/prisma/skills/brand-discovery/references/70_founder-tension.md +49 -0
  81. package/prisma/skills/brand-discovery/references/90_SYNTHESIS.md +133 -0
  82. package/prisma/skills/brand-voice/SKILL.md +98 -0
  83. package/prisma/skills/brand-voice/references/voice-profile-schema.md +55 -0
  84. package/prisma/skills/browser-qa/SKILL.md +105 -0
  85. package/prisma/skills/bun-runtime/SKILL.md +85 -0
  86. package/prisma/skills/canary-watch/SKILL.md +108 -0
  87. package/prisma/skills/carrier-relationship-management/SKILL.md +212 -0
  88. package/prisma/skills/cisco-ios-patterns/SKILL.md +164 -0
  89. package/prisma/skills/ck/SKILL.md +148 -0
  90. package/prisma/skills/ck/commands/forget.mjs +44 -0
  91. package/prisma/skills/ck/commands/info.mjs +24 -0
  92. package/prisma/skills/ck/commands/init.mjs +143 -0
  93. package/prisma/skills/ck/commands/list.mjs +40 -0
  94. package/prisma/skills/ck/commands/migrate.mjs +202 -0
  95. package/prisma/skills/ck/commands/resume.mjs +36 -0
  96. package/prisma/skills/ck/commands/save.mjs +210 -0
  97. package/prisma/skills/ck/commands/shared.mjs +387 -0
  98. package/prisma/skills/ck/hooks/session-start.mjs +224 -0
  99. package/prisma/skills/claude-devfleet/SKILL.md +112 -0
  100. package/prisma/skills/click-path-audit/SKILL.md +245 -0
  101. package/prisma/skills/clickhouse-io/SKILL.md +440 -0
  102. package/prisma/skills/code-tour/SKILL.md +254 -0
  103. package/prisma/skills/codebase-onboarding/SKILL.md +234 -0
  104. package/prisma/skills/codehealth-mcp/SKILL.md +167 -0
  105. package/prisma/skills/coding-standards/SKILL.md +551 -0
  106. package/prisma/skills/competitive-platform-analysis/SKILL.md +214 -0
  107. package/prisma/skills/competitive-report-structure/SKILL.md +162 -0
  108. package/prisma/skills/compose-multiplatform-patterns/SKILL.md +300 -0
  109. package/prisma/skills/config-gc/SKILL.md +120 -0
  110. package/prisma/skills/configure-ecc/SKILL.md +385 -0
  111. package/prisma/skills/connections-optimizer/SKILL.md +190 -0
  112. package/prisma/skills/content-engine/SKILL.md +132 -0
  113. package/prisma/skills/content-hash-cache-pattern/SKILL.md +162 -0
  114. package/prisma/skills/context-budget/SKILL.md +136 -0
  115. package/prisma/skills/continuous-agent-loop/SKILL.md +46 -0
  116. package/prisma/skills/continuous-learning/SKILL.md +132 -0
  117. package/prisma/skills/continuous-learning/config.json +18 -0
  118. package/prisma/skills/continuous-learning/evaluate-session.sh +69 -0
  119. package/prisma/skills/continuous-learning-v2/SKILL.md +361 -0
  120. package/prisma/skills/continuous-learning-v2/agents/observer-loop.sh +359 -0
  121. package/prisma/skills/continuous-learning-v2/agents/observer.md +189 -0
  122. package/prisma/skills/continuous-learning-v2/agents/session-guardian.sh +150 -0
  123. package/prisma/skills/continuous-learning-v2/agents/start-observer.sh +248 -0
  124. package/prisma/skills/continuous-learning-v2/config.json +8 -0
  125. package/prisma/skills/continuous-learning-v2/hooks/observe.sh +585 -0
  126. package/prisma/skills/continuous-learning-v2/scripts/detect-project.sh +322 -0
  127. package/prisma/skills/continuous-learning-v2/scripts/instinct-cli.py +1956 -0
  128. package/prisma/skills/continuous-learning-v2/scripts/lib/homunculus-dir.sh +31 -0
  129. package/prisma/skills/continuous-learning-v2/scripts/migrate-homunculus.sh +68 -0
  130. package/prisma/skills/continuous-learning-v2/scripts/test_parse_instinct.py +1421 -0
  131. package/prisma/skills/cost-aware-llm-pipeline/SKILL.md +184 -0
  132. package/prisma/skills/cost-tracking/SKILL.md +97 -0
  133. package/prisma/skills/council/SKILL.md +204 -0
  134. package/prisma/skills/cpp-coding-standards/SKILL.md +724 -0
  135. package/prisma/skills/cpp-testing/SKILL.md +325 -0
  136. package/prisma/skills/crosspost/SKILL.md +112 -0
  137. package/prisma/skills/csharp-testing/SKILL.md +322 -0
  138. package/prisma/skills/customer-billing-ops/SKILL.md +141 -0
  139. package/prisma/skills/customs-trade-compliance/SKILL.md +263 -0
  140. package/prisma/skills/dart-flutter-patterns/SKILL.md +564 -0
  141. package/prisma/skills/dashboard-builder/SKILL.md +109 -0
  142. package/prisma/skills/data-scraper-agent/SKILL.md +765 -0
  143. package/prisma/skills/data-throughput-accelerator/SKILL.md +73 -0
  144. package/prisma/skills/database-migrations/SKILL.md +430 -0
  145. package/prisma/skills/deep-research/SKILL.md +160 -0
  146. package/prisma/skills/defi-amm-security/SKILL.md +167 -0
  147. package/prisma/skills/delivery-gate/SKILL.md +126 -0
  148. package/prisma/skills/delivery-gate/hooks/quality-gate.py +220 -0
  149. package/prisma/skills/deployment-patterns/SKILL.md +428 -0
  150. package/prisma/skills/design-system/SKILL.md +83 -0
  151. package/prisma/skills/django-celery/SKILL.md +458 -0
  152. package/prisma/skills/django-patterns/SKILL.md +735 -0
  153. package/prisma/skills/django-security/SKILL.md +644 -0
  154. package/prisma/skills/django-tdd/SKILL.md +730 -0
  155. package/prisma/skills/django-verification/SKILL.md +470 -0
  156. package/prisma/skills/dmux-workflows/SKILL.md +192 -0
  157. package/prisma/skills/docker-patterns/SKILL.md +365 -0
  158. package/prisma/skills/documentation-lookup/SKILL.md +91 -0
  159. package/prisma/skills/dotnet-patterns/SKILL.md +322 -0
  160. package/prisma/skills/dynamic-workflow-mode/SKILL.md +124 -0
  161. package/prisma/skills/e2e-testing/SKILL.md +327 -0
  162. package/prisma/skills/ecc-guide/SKILL.md +190 -0
  163. package/prisma/skills/ecc-recipes/SKILL.md +149 -0
  164. package/prisma/skills/ecc-tools-cost-audit/SKILL.md +161 -0
  165. package/prisma/skills/email-ops/SKILL.md +122 -0
  166. package/prisma/skills/energy-procurement/SKILL.md +228 -0
  167. package/prisma/skills/enterprise-agent-ops/SKILL.md +51 -0
  168. package/prisma/skills/error-handling/SKILL.md +377 -0
  169. package/prisma/skills/eval-harness/SKILL.md +271 -0
  170. package/prisma/skills/evm-token-decimals/SKILL.md +131 -0
  171. package/prisma/skills/exa-search/SKILL.md +108 -0
  172. package/prisma/skills/fal-ai-media/SKILL.md +289 -0
  173. package/prisma/skills/fastapi-patterns/SKILL.md +514 -0
  174. package/prisma/skills/finance-billing-ops/SKILL.md +128 -0
  175. package/prisma/skills/flox-environments/SKILL.md +497 -0
  176. package/prisma/skills/flutter-dart-code-review/SKILL.md +436 -0
  177. package/prisma/skills/foundation-models-on-device/SKILL.md +243 -0
  178. package/prisma/skills/frontend-a11y/SKILL.md +446 -0
  179. package/prisma/skills/frontend-design-direction/SKILL.md +93 -0
  180. package/prisma/skills/frontend-patterns/SKILL.md +657 -0
  181. package/prisma/skills/frontend-slides/SKILL.md +185 -0
  182. package/prisma/skills/frontend-slides/STYLE_PRESETS.md +330 -0
  183. package/prisma/skills/frontend-slides/animation-patterns.md +122 -0
  184. package/prisma/skills/frontend-slides/html-template.md +419 -0
  185. package/prisma/skills/frontend-slides/scripts/export-pdf.sh +418 -0
  186. package/prisma/skills/frontend-slides/scripts/extract-pptx.py +96 -0
  187. package/prisma/skills/frontend-slides/viewport-base.css +153 -0
  188. package/prisma/skills/fsharp-testing/SKILL.md +281 -0
  189. package/prisma/skills/gan-style-harness/SKILL.md +279 -0
  190. package/prisma/skills/gateguard/SKILL.md +133 -0
  191. package/prisma/skills/generating-python-installer/SKILL.md +820 -0
  192. package/prisma/skills/git-workflow/SKILL.md +716 -0
  193. package/prisma/skills/github-ops/SKILL.md +145 -0
  194. package/prisma/skills/golang-patterns/SKILL.md +675 -0
  195. package/prisma/skills/golang-testing/SKILL.md +721 -0
  196. package/prisma/skills/google-workspace-ops/SKILL.md +96 -0
  197. package/prisma/skills/growth-log/SKILL.md +128 -0
  198. package/prisma/skills/healthcare-cdss-patterns/SKILL.md +246 -0
  199. package/prisma/skills/healthcare-emr-patterns/SKILL.md +160 -0
  200. package/prisma/skills/healthcare-eval-harness/SKILL.md +208 -0
  201. package/prisma/skills/healthcare-phi-compliance/SKILL.md +146 -0
  202. package/prisma/skills/hermes-imports/SKILL.md +89 -0
  203. package/prisma/skills/hexagonal-architecture/SKILL.md +277 -0
  204. package/prisma/skills/hipaa-compliance/SKILL.md +79 -0
  205. package/prisma/skills/homelab-network-readiness/SKILL.md +170 -0
  206. package/prisma/skills/homelab-network-setup/SKILL.md +130 -0
  207. package/prisma/skills/homelab-pihole-dns/SKILL.md +275 -0
  208. package/prisma/skills/homelab-vlan-segmentation/SKILL.md +312 -0
  209. package/prisma/skills/homelab-wireguard-vpn/SKILL.md +306 -0
  210. package/prisma/skills/hookify-rules/SKILL.md +128 -0
  211. package/prisma/skills/inherit-legacy-style/SKILL.md +157 -0
  212. package/prisma/skills/intent-driven-development/SKILL.md +360 -0
  213. package/prisma/skills/inventory-demand-planning/SKILL.md +247 -0
  214. package/prisma/skills/investor-materials/SKILL.md +97 -0
  215. package/prisma/skills/investor-outreach/SKILL.md +92 -0
  216. package/prisma/skills/ios-icon-gen/SKILL.md +158 -0
  217. package/prisma/skills/ios-icon-gen/scripts/generate_icons.swift +258 -0
  218. package/prisma/skills/ios-icon-gen/scripts/iconify_gen.sh +235 -0
  219. package/prisma/skills/iterative-retrieval/SKILL.md +212 -0
  220. package/prisma/skills/ito-basket-compare/SKILL.md +64 -0
  221. package/prisma/skills/ito-data-atlas-agent/SKILL.md +64 -0
  222. package/prisma/skills/ito-market-intelligence/SKILL.md +61 -0
  223. package/prisma/skills/ito-trade-planner/SKILL.md +68 -0
  224. package/prisma/skills/java-coding-standards/SKILL.md +384 -0
  225. package/prisma/skills/jira-integration/SKILL.md +303 -0
  226. package/prisma/skills/jpa-patterns/SKILL.md +152 -0
  227. package/prisma/skills/knowledge-ops/SKILL.md +155 -0
  228. package/prisma/skills/kotlin-coroutines-flows/SKILL.md +285 -0
  229. package/prisma/skills/kotlin-exposed-patterns/SKILL.md +720 -0
  230. package/prisma/skills/kotlin-ktor-patterns/SKILL.md +690 -0
  231. package/prisma/skills/kotlin-patterns/SKILL.md +712 -0
  232. package/prisma/skills/kotlin-testing/SKILL.md +825 -0
  233. package/prisma/skills/kubernetes-patterns/SKILL.md +756 -0
  234. package/prisma/skills/laravel-patterns/SKILL.md +416 -0
  235. package/prisma/skills/laravel-plugin-discovery/SKILL.md +230 -0
  236. package/prisma/skills/laravel-security/SKILL.md +948 -0
  237. package/prisma/skills/laravel-tdd/SKILL.md +675 -0
  238. package/prisma/skills/laravel-verification/SKILL.md +180 -0
  239. package/prisma/skills/latency-critical-systems/SKILL.md +74 -0
  240. package/prisma/skills/lead-intelligence/SKILL.md +322 -0
  241. package/prisma/skills/lead-intelligence/agents/enrichment-agent.md +85 -0
  242. package/prisma/skills/lead-intelligence/agents/mutual-mapper.md +75 -0
  243. package/prisma/skills/lead-intelligence/agents/outreach-drafter.md +98 -0
  244. package/prisma/skills/lead-intelligence/agents/signal-scorer.md +60 -0
  245. package/prisma/skills/liquid-glass-design/SKILL.md +279 -0
  246. package/prisma/skills/llm-trading-agent-security/SKILL.md +147 -0
  247. package/prisma/skills/logistics-exception-management/SKILL.md +222 -0
  248. package/prisma/skills/loop-design-check/SKILL.md +143 -0
  249. package/prisma/skills/mailtrap-email-integration/SKILL.md +77 -0
  250. package/prisma/skills/make-interfaces-feel-better/SKILL.md +152 -0
  251. package/prisma/skills/manim-video/SKILL.md +90 -0
  252. package/prisma/skills/manim-video/assets/network_graph_scene.py +52 -0
  253. package/prisma/skills/market-research/SKILL.md +76 -0
  254. package/prisma/skills/marketing-campaign/SKILL.md +114 -0
  255. package/prisma/skills/mcp-server-patterns/SKILL.md +70 -0
  256. package/prisma/skills/messages-ops/SKILL.md +105 -0
  257. package/prisma/skills/ml-adoption-playbook/SKILL.md +57 -0
  258. package/prisma/skills/mle-workflow/SKILL.md +347 -0
  259. package/prisma/skills/motion-advanced/SKILL.md +596 -0
  260. package/prisma/skills/motion-foundations/SKILL.md +299 -0
  261. package/prisma/skills/motion-patterns/SKILL.md +434 -0
  262. package/prisma/skills/motion-ui/SKILL.md +576 -0
  263. package/prisma/skills/mysql-patterns/SKILL.md +413 -0
  264. package/prisma/skills/nanoclaw-repl/SKILL.md +34 -0
  265. package/prisma/skills/nestjs-patterns/SKILL.md +231 -0
  266. package/prisma/skills/netmiko-ssh-automation/SKILL.md +174 -0
  267. package/prisma/skills/network-bgp-diagnostics/SKILL.md +168 -0
  268. package/prisma/skills/network-config-validation/SKILL.md +211 -0
  269. package/prisma/skills/network-interface-health/SKILL.md +153 -0
  270. package/prisma/skills/nextjs-turbopack/SKILL.md +58 -0
  271. package/prisma/skills/nodejs-keccak256/SKILL.md +103 -0
  272. package/prisma/skills/nutrient-document-processing/SKILL.md +168 -0
  273. package/prisma/skills/nuxt4-patterns/SKILL.md +101 -0
  274. package/prisma/skills/openclaw-persona-forge/SKILL.md +289 -0
  275. package/prisma/skills/openclaw-persona-forge/gacha.py +224 -0
  276. package/prisma/skills/openclaw-persona-forge/gacha.sh +5 -0
  277. package/prisma/skills/openclaw-persona-forge/references/avatar-style.md +124 -0
  278. package/prisma/skills/openclaw-persona-forge/references/boundary-rules.md +53 -0
  279. package/prisma/skills/openclaw-persona-forge/references/error-handling.md +53 -0
  280. package/prisma/skills/openclaw-persona-forge/references/identity-tension.md +48 -0
  281. package/prisma/skills/openclaw-persona-forge/references/naming-system.md +39 -0
  282. package/prisma/skills/openclaw-persona-forge/references/output-template.md +166 -0
  283. package/prisma/skills/opensource-pipeline/SKILL.md +256 -0
  284. package/prisma/skills/orch-add-feature/SKILL.md +45 -0
  285. package/prisma/skills/orch-build-mvp/SKILL.md +49 -0
  286. package/prisma/skills/orch-change-feature/SKILL.md +43 -0
  287. package/prisma/skills/orch-fix-defect/SKILL.md +43 -0
  288. package/prisma/skills/orch-pipeline/SKILL.md +121 -0
  289. package/prisma/skills/orch-refine-code/SKILL.md +44 -0
  290. package/prisma/skills/parallel-execution-optimizer/SKILL.md +73 -0
  291. package/prisma/skills/perl-patterns/SKILL.md +505 -0
  292. package/prisma/skills/perl-security/SKILL.md +504 -0
  293. package/prisma/skills/perl-testing/SKILL.md +476 -0
  294. package/prisma/skills/plan-orchestrate/SKILL.md +263 -0
  295. package/prisma/skills/plankton-code-quality/SKILL.md +237 -0
  296. package/prisma/skills/postgres-patterns/SKILL.md +148 -0
  297. package/prisma/skills/prediction-market-oracle-research/SKILL.md +64 -0
  298. package/prisma/skills/prediction-market-risk-review/SKILL.md +61 -0
  299. package/prisma/skills/prisma-patterns/SKILL.md +401 -0
  300. package/prisma/skills/product-capability/SKILL.md +142 -0
  301. package/prisma/skills/product-lens/SKILL.md +93 -0
  302. package/prisma/skills/production-audit/SKILL.md +207 -0
  303. package/prisma/skills/production-scheduling/SKILL.md +238 -0
  304. package/prisma/skills/project-flow-ops/SKILL.md +112 -0
  305. package/prisma/skills/prompt-optimizer/SKILL.md +398 -0
  306. package/prisma/skills/python-patterns/SKILL.md +751 -0
  307. package/prisma/skills/python-testing/SKILL.md +817 -0
  308. package/prisma/skills/pytorch-patterns/SKILL.md +397 -0
  309. package/prisma/skills/quality-nonconformance/SKILL.md +260 -0
  310. package/prisma/skills/quarkus-patterns/SKILL.md +723 -0
  311. package/prisma/skills/quarkus-security/SKILL.md +468 -0
  312. package/prisma/skills/quarkus-tdd/SKILL.md +812 -0
  313. package/prisma/skills/quarkus-verification/SKILL.md +480 -0
  314. package/prisma/skills/ralphinho-rfc-pipeline/SKILL.md +68 -0
  315. package/prisma/skills/react-native-patterns/SKILL.md +326 -0
  316. package/prisma/skills/react-patterns/SKILL.md +342 -0
  317. package/prisma/skills/react-performance/SKILL.md +575 -0
  318. package/prisma/skills/react-testing/SKILL.md +424 -0
  319. package/prisma/skills/recsys-pipeline-architect/SKILL.md +115 -0
  320. package/prisma/skills/recursive-decision-ledger/SKILL.md +80 -0
  321. package/prisma/skills/redis-patterns/SKILL.md +404 -0
  322. package/prisma/skills/regex-vs-llm-structured-text/SKILL.md +221 -0
  323. package/prisma/skills/remotion-video-creation/SKILL.md +43 -0
  324. package/prisma/skills/remotion-video-creation/rules/3d.md +86 -0
  325. package/prisma/skills/remotion-video-creation/rules/animations.md +29 -0
  326. package/prisma/skills/remotion-video-creation/rules/assets/charts-bar-chart.tsx +173 -0
  327. package/prisma/skills/remotion-video-creation/rules/assets/text-animations-typewriter.tsx +100 -0
  328. package/prisma/skills/remotion-video-creation/rules/assets/text-animations-word-highlight.tsx +108 -0
  329. package/prisma/skills/remotion-video-creation/rules/assets.md +78 -0
  330. package/prisma/skills/remotion-video-creation/rules/audio.md +172 -0
  331. package/prisma/skills/remotion-video-creation/rules/calculate-metadata.md +104 -0
  332. package/prisma/skills/remotion-video-creation/rules/can-decode.md +75 -0
  333. package/prisma/skills/remotion-video-creation/rules/charts.md +58 -0
  334. package/prisma/skills/remotion-video-creation/rules/compositions.md +146 -0
  335. package/prisma/skills/remotion-video-creation/rules/display-captions.md +126 -0
  336. package/prisma/skills/remotion-video-creation/rules/extract-frames.md +229 -0
  337. package/prisma/skills/remotion-video-creation/rules/fonts.md +152 -0
  338. package/prisma/skills/remotion-video-creation/rules/get-audio-duration.md +58 -0
  339. package/prisma/skills/remotion-video-creation/rules/get-video-dimensions.md +68 -0
  340. package/prisma/skills/remotion-video-creation/rules/get-video-duration.md +58 -0
  341. package/prisma/skills/remotion-video-creation/rules/gifs.md +138 -0
  342. package/prisma/skills/remotion-video-creation/rules/images.md +130 -0
  343. package/prisma/skills/remotion-video-creation/rules/import-srt-captions.md +67 -0
  344. package/prisma/skills/remotion-video-creation/rules/lottie.md +67 -0
  345. package/prisma/skills/remotion-video-creation/rules/measuring-dom-nodes.md +34 -0
  346. package/prisma/skills/remotion-video-creation/rules/measuring-text.md +143 -0
  347. package/prisma/skills/remotion-video-creation/rules/sequencing.md +106 -0
  348. package/prisma/skills/remotion-video-creation/rules/tailwind.md +11 -0
  349. package/prisma/skills/remotion-video-creation/rules/text-animations.md +20 -0
  350. package/prisma/skills/remotion-video-creation/rules/timing.md +179 -0
  351. package/prisma/skills/remotion-video-creation/rules/transcribe-captions.md +19 -0
  352. package/prisma/skills/remotion-video-creation/rules/transitions.md +122 -0
  353. package/prisma/skills/remotion-video-creation/rules/trimming.md +52 -0
  354. package/prisma/skills/remotion-video-creation/rules/videos.md +171 -0
  355. package/prisma/skills/repo-scan/SKILL.md +79 -0
  356. package/prisma/skills/research-ops/SKILL.md +113 -0
  357. package/prisma/skills/returns-reverse-logistics/SKILL.md +240 -0
  358. package/prisma/skills/rules-distill/SKILL.md +265 -0
  359. package/prisma/skills/rules-distill/scripts/scan-rules.sh +58 -0
  360. package/prisma/skills/rules-distill/scripts/scan-skills.sh +129 -0
  361. package/prisma/skills/rust-patterns/SKILL.md +500 -0
  362. package/prisma/skills/rust-testing/SKILL.md +501 -0
  363. package/prisma/skills/safety-guard/SKILL.md +76 -0
  364. package/prisma/skills/santa-method/SKILL.md +307 -0
  365. package/prisma/skills/scientific-db-pubmed-database/SKILL.md +176 -0
  366. package/prisma/skills/scientific-db-uspto-database/SKILL.md +178 -0
  367. package/prisma/skills/scientific-pkg-gget/SKILL.md +167 -0
  368. package/prisma/skills/scientific-thinking-literature-review/SKILL.md +193 -0
  369. package/prisma/skills/scientific-thinking-scholar-evaluation/SKILL.md +161 -0
  370. package/prisma/skills/search-first/SKILL.md +183 -0
  371. package/prisma/skills/security-bounty-hunter/SKILL.md +100 -0
  372. package/prisma/skills/security-review/SKILL.md +504 -0
  373. package/prisma/skills/security-review/cloud-infrastructure-security.md +361 -0
  374. package/prisma/skills/security-scan/SKILL.md +166 -0
  375. package/prisma/skills/seo/SKILL.md +155 -0
  376. package/prisma/skills/skill-comply/SKILL.md +59 -0
  377. package/prisma/skills/skill-comply/fixtures/compliant_trace.jsonl +5 -0
  378. package/prisma/skills/skill-comply/fixtures/noncompliant_trace.jsonl +3 -0
  379. package/prisma/skills/skill-comply/fixtures/tdd_spec.yaml +44 -0
  380. package/prisma/skills/skill-comply/prompts/classifier.md +24 -0
  381. package/prisma/skills/skill-comply/prompts/scenario_generator.md +62 -0
  382. package/prisma/skills/skill-comply/prompts/spec_generator.md +42 -0
  383. package/prisma/skills/skill-comply/pyproject.toml +15 -0
  384. package/prisma/skills/skill-comply/scripts/__init__.py +0 -0
  385. package/prisma/skills/skill-comply/scripts/classifier.py +85 -0
  386. package/prisma/skills/skill-comply/scripts/grader.py +124 -0
  387. package/prisma/skills/skill-comply/scripts/parser.py +107 -0
  388. package/prisma/skills/skill-comply/scripts/report.py +170 -0
  389. package/prisma/skills/skill-comply/scripts/run.py +127 -0
  390. package/prisma/skills/skill-comply/scripts/runner.py +194 -0
  391. package/prisma/skills/skill-comply/scripts/scenario_generator.py +70 -0
  392. package/prisma/skills/skill-comply/scripts/spec_generator.py +72 -0
  393. package/prisma/skills/skill-comply/scripts/utils.py +13 -0
  394. package/prisma/skills/skill-comply/tests/test_grader.py +197 -0
  395. package/prisma/skills/skill-comply/tests/test_parser.py +90 -0
  396. package/prisma/skills/skill-comply/tests/test_runner.py +172 -0
  397. package/prisma/skills/skill-scout/SKILL.md +141 -0
  398. package/prisma/skills/skill-stocktake/SKILL.md +195 -0
  399. package/prisma/skills/skill-stocktake/scripts/quick-diff.sh +87 -0
  400. package/prisma/skills/skill-stocktake/scripts/save-results.sh +56 -0
  401. package/prisma/skills/skill-stocktake/scripts/scan.sh +170 -0
  402. package/prisma/skills/social-graph-ranker/SKILL.md +155 -0
  403. package/prisma/skills/social-publisher/SKILL.md +130 -0
  404. package/prisma/skills/springboot-patterns/SKILL.md +315 -0
  405. package/prisma/skills/springboot-security/SKILL.md +273 -0
  406. package/prisma/skills/springboot-tdd/SKILL.md +159 -0
  407. package/prisma/skills/springboot-verification/SKILL.md +232 -0
  408. package/prisma/skills/strategic-compact/SKILL.md +136 -0
  409. package/prisma/skills/swift-actor-persistence/SKILL.md +144 -0
  410. package/prisma/skills/swift-concurrency-6-2/SKILL.md +216 -0
  411. package/prisma/skills/swift-protocol-di-testing/SKILL.md +191 -0
  412. package/prisma/skills/swiftui-patterns/SKILL.md +259 -0
  413. package/prisma/skills/taste/SKILL.md +264 -0
  414. package/prisma/skills/taste/references/genre-taxonomy.md +87 -0
  415. package/prisma/skills/tdd-workflow/SKILL.md +583 -0
  416. package/prisma/skills/team-agent-orchestration/SKILL.md +111 -0
  417. package/prisma/skills/team-builder/SKILL.md +169 -0
  418. package/prisma/skills/terminal-ops/SKILL.md +110 -0
  419. package/prisma/skills/tinystruct-patterns/SKILL.md +279 -0
  420. package/prisma/skills/tinystruct-patterns/references/architecture.md +90 -0
  421. package/prisma/skills/tinystruct-patterns/references/data-handling.md +60 -0
  422. package/prisma/skills/tinystruct-patterns/references/database.md +99 -0
  423. package/prisma/skills/tinystruct-patterns/references/routing.md +64 -0
  424. package/prisma/skills/tinystruct-patterns/references/system-usage.md +97 -0
  425. package/prisma/skills/tinystruct-patterns/references/testing.md +72 -0
  426. package/prisma/skills/token-budget-advisor/SKILL.md +134 -0
  427. package/prisma/skills/ui-demo/SKILL.md +466 -0
  428. package/prisma/skills/ui-to-vue/SKILL.md +135 -0
  429. package/prisma/skills/uncloud/SKILL.md +344 -0
  430. package/prisma/skills/unified-notifications-ops/SKILL.md +188 -0
  431. package/prisma/skills/verification-loop/SKILL.md +127 -0
  432. package/prisma/skills/video-editing/SKILL.md +311 -0
  433. package/prisma/skills/videodb/SKILL.md +375 -0
  434. package/prisma/skills/videodb/reference/api-reference.md +550 -0
  435. package/prisma/skills/videodb/reference/capture-reference.md +407 -0
  436. package/prisma/skills/videodb/reference/capture.md +101 -0
  437. package/prisma/skills/videodb/reference/editor.md +443 -0
  438. package/prisma/skills/videodb/reference/generative.md +331 -0
  439. package/prisma/skills/videodb/reference/rtstream-reference.md +564 -0
  440. package/prisma/skills/videodb/reference/rtstream.md +65 -0
  441. package/prisma/skills/videodb/reference/search.md +230 -0
  442. package/prisma/skills/videodb/reference/streaming.md +406 -0
  443. package/prisma/skills/videodb/reference/use-cases.md +118 -0
  444. package/prisma/skills/videodb/scripts/ws_listener.py +282 -0
  445. package/prisma/skills/visa-doc-translate/README.md +86 -0
  446. package/prisma/skills/visa-doc-translate/SKILL.md +117 -0
  447. package/prisma/skills/vite-patterns/SKILL.md +450 -0
  448. package/prisma/skills/vue-patterns/SKILL.md +471 -0
  449. package/prisma/skills/windows-desktop-e2e/SKILL.md +888 -0
  450. package/prisma/skills/workspace-surface-audit/SKILL.md +126 -0
  451. package/prisma/skills/x-api/SKILL.md +235 -0
@@ -0,0 +1,306 @@
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
@@ -0,0 +1,128 @@
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
+ ```
@@ -0,0 +1,157 @@
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.