@heytherevibin/skillforge 0.2.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +16 -0
- package/CODE_OF_CONDUCT.md +34 -0
- package/CONTRIBUTING.md +38 -0
- package/LICENSE +21 -0
- package/README.md +337 -0
- package/RELEASING.md +93 -0
- package/SECURITY.md +31 -0
- package/STRATEGY.md +26 -0
- package/bin/cli.js +547 -0
- package/lib/packs.js +184 -0
- package/package.json +38 -0
- package/python/app/__init__.py +0 -0
- package/python/app/__pycache__/__init__.cpython-312.pyc +0 -0
- package/python/app/__pycache__/auth.cpython-312.pyc +0 -0
- package/python/app/__pycache__/main.cpython-312.pyc +0 -0
- package/python/app/auth.py +63 -0
- package/python/app/cli.py +78 -0
- package/python/app/db_paths.py +26 -0
- package/python/app/events_cli.py +175 -0
- package/python/app/main.py +647 -0
- package/python/app/materialize.py +138 -0
- package/python/app/mcp_server.py +610 -0
- package/python/app/route_cli.py +117 -0
- package/python/requirements-dev.txt +1 -0
- package/python/requirements.txt +7 -0
- package/python/tests/test_db_paths.py +41 -0
- package/skills/accessibility/SKILL.md +145 -0
- package/skills/agent-architecture-audit/SKILL.md +256 -0
- package/skills/agent-eval/SKILL.md +144 -0
- package/skills/agent-harness-construction/SKILL.md +72 -0
- package/skills/agent-introspection-debugging/SKILL.md +152 -0
- package/skills/agent-payment-x402/SKILL.md +224 -0
- package/skills/agent-sort/SKILL.md +214 -0
- package/skills/agentic-engineering/SKILL.md +62 -0
- package/skills/agentic-os/SKILL.md +386 -0
- package/skills/ai-first-engineering/SKILL.md +50 -0
- package/skills/ai-regression-testing/SKILL.md +384 -0
- package/skills/android-clean-architecture/SKILL.md +338 -0
- package/skills/angular-developer/SKILL.md +153 -0
- package/skills/angular-developer/references/angular-animations.md +160 -0
- package/skills/angular-developer/references/angular-aria.md +410 -0
- package/skills/angular-developer/references/cli.md +86 -0
- package/skills/angular-developer/references/component-harnesses.md +59 -0
- package/skills/angular-developer/references/component-styling.md +91 -0
- package/skills/angular-developer/references/components.md +117 -0
- package/skills/angular-developer/references/creating-services.md +97 -0
- package/skills/angular-developer/references/data-resolvers.md +69 -0
- package/skills/angular-developer/references/define-routes.md +67 -0
- package/skills/angular-developer/references/defining-providers.md +72 -0
- package/skills/angular-developer/references/di-fundamentals.md +120 -0
- package/skills/angular-developer/references/e2e-testing.md +56 -0
- package/skills/angular-developer/references/effects.md +83 -0
- package/skills/angular-developer/references/hierarchical-injectors.md +43 -0
- package/skills/angular-developer/references/host-elements.md +80 -0
- package/skills/angular-developer/references/injection-context.md +63 -0
- package/skills/angular-developer/references/inputs.md +101 -0
- package/skills/angular-developer/references/linked-signal.md +59 -0
- package/skills/angular-developer/references/loading-strategies.md +61 -0
- package/skills/angular-developer/references/mcp.md +108 -0
- package/skills/angular-developer/references/navigate-to-routes.md +69 -0
- package/skills/angular-developer/references/outputs.md +86 -0
- package/skills/angular-developer/references/reactive-forms.md +122 -0
- package/skills/angular-developer/references/rendering-strategies.md +44 -0
- package/skills/angular-developer/references/resource.md +77 -0
- package/skills/angular-developer/references/route-animations.md +56 -0
- package/skills/angular-developer/references/route-guards.md +52 -0
- package/skills/angular-developer/references/router-lifecycle.md +45 -0
- package/skills/angular-developer/references/router-testing.md +87 -0
- package/skills/angular-developer/references/show-routes-with-outlets.md +68 -0
- package/skills/angular-developer/references/signal-forms.md +795 -0
- package/skills/angular-developer/references/signals-overview.md +94 -0
- package/skills/angular-developer/references/tailwind-css.md +69 -0
- package/skills/angular-developer/references/template-driven-forms.md +114 -0
- package/skills/angular-developer/references/testing-fundamentals.md +65 -0
- package/skills/api-connector-builder/SKILL.md +120 -0
- package/skills/api-design/SKILL.md +522 -0
- package/skills/architecture-decision-records/SKILL.md +178 -0
- package/skills/article-writing/SKILL.md +78 -0
- package/skills/automation-audit-ops/SKILL.md +141 -0
- package/skills/autonomous-agent-harness/SKILL.md +272 -0
- package/skills/autonomous-loops/SKILL.md +609 -0
- package/skills/backend-patterns/SKILL.md +560 -0
- package/skills/benchmark/SKILL.md +92 -0
- package/skills/blueprint/SKILL.md +104 -0
- package/skills/browser-qa/SKILL.md +86 -0
- package/skills/bun-runtime/SKILL.md +83 -0
- package/skills/canary-watch/SKILL.md +98 -0
- package/skills/carrier-relationship-management/SKILL.md +211 -0
- package/skills/cisco-ios-patterns/SKILL.md +163 -0
- package/skills/ck/SKILL.md +147 -0
- package/skills/ck/commands/forget.mjs +44 -0
- package/skills/ck/commands/info.mjs +24 -0
- package/skills/ck/commands/init.mjs +143 -0
- package/skills/ck/commands/list.mjs +40 -0
- package/skills/ck/commands/migrate.mjs +202 -0
- package/skills/ck/commands/resume.mjs +36 -0
- package/skills/ck/commands/save.mjs +210 -0
- package/skills/ck/commands/shared.mjs +387 -0
- package/skills/ck/hooks/session-start.mjs +224 -0
- package/skills/claude-devfleet/SKILL.md +103 -0
- package/skills/click-path-audit/SKILL.md +244 -0
- package/skills/clickhouse-io/SKILL.md +438 -0
- package/skills/code-tour/SKILL.md +235 -0
- package/skills/codebase-onboarding/SKILL.md +232 -0
- package/skills/coding-standards/SKILL.md +548 -0
- package/skills/compose-multiplatform-patterns/SKILL.md +298 -0
- package/skills/connections-optimizer/SKILL.md +188 -0
- package/skills/content-engine/SKILL.md +126 -0
- package/skills/content-hash-cache-pattern/SKILL.md +160 -0
- package/skills/context-budget/SKILL.md +134 -0
- package/skills/continuous-agent-loop/SKILL.md +44 -0
- package/skills/continuous-learning/SKILL.md +129 -0
- package/skills/continuous-learning/config.json +18 -0
- package/skills/continuous-learning/evaluate-session.sh +69 -0
- package/skills/continuous-learning-v2/SKILL.md +358 -0
- package/skills/continuous-learning-v2/agents/observer-loop.sh +322 -0
- package/skills/continuous-learning-v2/agents/observer.md +198 -0
- package/skills/continuous-learning-v2/agents/session-guardian.sh +150 -0
- package/skills/continuous-learning-v2/agents/start-observer.sh +248 -0
- package/skills/continuous-learning-v2/config.json +8 -0
- package/skills/continuous-learning-v2/hooks/observe.sh +476 -0
- package/skills/continuous-learning-v2/scripts/detect-project.sh +288 -0
- package/skills/continuous-learning-v2/scripts/instinct-cli.py +1519 -0
- package/skills/continuous-learning-v2/scripts/lib/homunculus-dir.sh +31 -0
- package/skills/continuous-learning-v2/scripts/migrate-homunculus.sh +62 -0
- package/skills/continuous-learning-v2/scripts/test_parse_instinct.py +1018 -0
- package/skills/cost-aware-llm-pipeline/SKILL.md +182 -0
- package/skills/cost-tracking/SKILL.md +147 -0
- package/skills/council/SKILL.md +202 -0
- package/skills/cpp-coding-standards/SKILL.md +722 -0
- package/skills/cpp-testing/SKILL.md +323 -0
- package/skills/crosspost/SKILL.md +110 -0
- package/skills/csharp-testing/SKILL.md +320 -0
- package/skills/customer-billing-ops/SKILL.md +139 -0
- package/skills/customs-trade-compliance/SKILL.md +262 -0
- package/skills/dart-flutter-patterns/SKILL.md +562 -0
- package/skills/dashboard-builder/SKILL.md +108 -0
- package/skills/data-scraper-agent/SKILL.md +764 -0
- package/skills/database-migrations/SKILL.md +428 -0
- package/skills/deep-research/SKILL.md +158 -0
- package/skills/defi-amm-security/SKILL.md +166 -0
- package/skills/deployment-patterns/SKILL.md +426 -0
- package/skills/design-system/SKILL.md +81 -0
- package/skills/django-celery/SKILL.md +456 -0
- package/skills/django-patterns/SKILL.md +733 -0
- package/skills/django-security/SKILL.md +592 -0
- package/skills/django-tdd/SKILL.md +728 -0
- package/skills/django-verification/SKILL.md +468 -0
- package/skills/dmux-workflows/SKILL.md +190 -0
- package/skills/docker-patterns/SKILL.md +363 -0
- package/skills/documentation-lookup/SKILL.md +89 -0
- package/skills/dotnet-patterns/SKILL.md +320 -0
- package/skills/e2e-testing/SKILL.md +325 -0
- package/skills/email-ops/SKILL.md +120 -0
- package/skills/energy-procurement/SKILL.md +227 -0
- package/skills/enterprise-agent-ops/SKILL.md +49 -0
- package/skills/error-handling/SKILL.md +375 -0
- package/skills/eval-harness/SKILL.md +269 -0
- package/skills/evm-token-decimals/SKILL.md +130 -0
- package/skills/exa-search/SKILL.md +106 -0
- package/skills/fal-ai-media/SKILL.md +287 -0
- package/skills/fastapi-patterns/SKILL.md +327 -0
- package/skills/finance-billing-ops/SKILL.md +126 -0
- package/skills/flox-environments/SKILL.md +496 -0
- package/skills/flutter-dart-code-review/SKILL.md +434 -0
- package/skills/foundation-models-on-device/SKILL.md +243 -0
- package/skills/frontend-design-direction/SKILL.md +92 -0
- package/skills/frontend-patterns/SKILL.md +641 -0
- package/skills/frontend-slides/SKILL.md +183 -0
- package/skills/frontend-slides/STYLE_PRESETS.md +330 -0
- package/skills/frontend-slides/animation-patterns.md +122 -0
- package/skills/frontend-slides/html-template.md +419 -0
- package/skills/frontend-slides/scripts/export-pdf.sh +418 -0
- package/skills/frontend-slides/scripts/extract-pptx.py +96 -0
- package/skills/frontend-slides/viewport-base.css +153 -0
- package/skills/fsharp-testing/SKILL.md +279 -0
- package/skills/gan-style-harness/SKILL.md +278 -0
- package/skills/gateguard/SKILL.md +125 -0
- package/skills/git-workflow/SKILL.md +714 -0
- package/skills/github-ops/SKILL.md +143 -0
- package/skills/golang-patterns/SKILL.md +673 -0
- package/skills/golang-testing/SKILL.md +719 -0
- package/skills/google-workspace-ops/SKILL.md +94 -0
- package/skills/healthcare-cdss-patterns/SKILL.md +245 -0
- package/skills/healthcare-emr-patterns/SKILL.md +159 -0
- package/skills/healthcare-eval-harness/SKILL.md +207 -0
- package/skills/healthcare-phi-compliance/SKILL.md +145 -0
- package/skills/hermes-imports/SKILL.md +87 -0
- package/skills/hexagonal-architecture/SKILL.md +275 -0
- package/skills/hipaa-compliance/SKILL.md +78 -0
- package/skills/homelab-network-readiness/SKILL.md +169 -0
- package/skills/homelab-network-setup/SKILL.md +129 -0
- package/skills/homelab-pihole-dns/SKILL.md +274 -0
- package/skills/homelab-vlan-segmentation/SKILL.md +311 -0
- package/skills/homelab-wireguard-vpn/SKILL.md +305 -0
- package/skills/hookify-rules/SKILL.md +128 -0
- package/skills/inventory-demand-planning/SKILL.md +246 -0
- package/skills/investor-materials/SKILL.md +95 -0
- package/skills/investor-outreach/SKILL.md +90 -0
- package/skills/ios-icon-gen/SKILL.md +157 -0
- package/skills/ios-icon-gen/scripts/generate_icons.swift +258 -0
- package/skills/ios-icon-gen/scripts/iconify_gen.sh +235 -0
- package/skills/iterative-retrieval/SKILL.md +209 -0
- package/skills/java-coding-standards/SKILL.md +382 -0
- package/skills/jira-integration/SKILL.md +292 -0
- package/skills/jpa-patterns/SKILL.md +150 -0
- package/skills/knowledge-ops/SKILL.md +153 -0
- package/skills/kotlin-coroutines-flows/SKILL.md +283 -0
- package/skills/kotlin-exposed-patterns/SKILL.md +718 -0
- package/skills/kotlin-ktor-patterns/SKILL.md +688 -0
- package/skills/kotlin-patterns/SKILL.md +710 -0
- package/skills/kotlin-testing/SKILL.md +823 -0
- package/skills/laravel-patterns/SKILL.md +414 -0
- package/skills/laravel-plugin-discovery/SKILL.md +228 -0
- package/skills/laravel-security/SKILL.md +284 -0
- package/skills/laravel-tdd/SKILL.md +282 -0
- package/skills/laravel-verification/SKILL.md +178 -0
- package/skills/lead-intelligence/SKILL.md +320 -0
- package/skills/lead-intelligence/agents/enrichment-agent.md +85 -0
- package/skills/lead-intelligence/agents/mutual-mapper.md +75 -0
- package/skills/lead-intelligence/agents/outreach-drafter.md +98 -0
- package/skills/lead-intelligence/agents/signal-scorer.md +60 -0
- package/skills/liquid-glass-design/SKILL.md +279 -0
- package/skills/llm-trading-agent-security/SKILL.md +146 -0
- package/skills/logistics-exception-management/SKILL.md +221 -0
- package/skills/make-interfaces-feel-better/SKILL.md +151 -0
- package/skills/manim-video/SKILL.md +88 -0
- package/skills/manim-video/assets/network_graph_scene.py +52 -0
- package/skills/market-research/SKILL.md +74 -0
- package/skills/mcp-server-patterns/SKILL.md +68 -0
- package/skills/messages-ops/SKILL.md +103 -0
- package/skills/mle-workflow/SKILL.md +345 -0
- package/skills/motion-advanced/SKILL.md +596 -0
- package/skills/motion-foundations/SKILL.md +299 -0
- package/skills/motion-patterns/SKILL.md +435 -0
- package/skills/motion-ui/SKILL.md +574 -0
- package/skills/mysql-patterns/SKILL.md +411 -0
- package/skills/nanoclaw-repl/SKILL.md +32 -0
- package/skills/nestjs-patterns/SKILL.md +229 -0
- package/skills/netmiko-ssh-automation/SKILL.md +173 -0
- package/skills/network-bgp-diagnostics/SKILL.md +167 -0
- package/skills/network-config-validation/SKILL.md +210 -0
- package/skills/network-interface-health/SKILL.md +152 -0
- package/skills/nextjs-turbopack/SKILL.md +43 -0
- package/skills/nodejs-keccak256/SKILL.md +102 -0
- package/skills/nutrient-document-processing/SKILL.md +166 -0
- package/skills/nuxt4-patterns/SKILL.md +99 -0
- package/skills/openclaw-persona-forge/SKILL.md +288 -0
- package/skills/openclaw-persona-forge/gacha.py +224 -0
- package/skills/openclaw-persona-forge/gacha.sh +5 -0
- package/skills/openclaw-persona-forge/references/avatar-style.md +124 -0
- package/skills/openclaw-persona-forge/references/boundary-rules.md +53 -0
- package/skills/openclaw-persona-forge/references/error-handling.md +53 -0
- package/skills/openclaw-persona-forge/references/identity-tension.md +48 -0
- package/skills/openclaw-persona-forge/references/naming-system.md +39 -0
- package/skills/openclaw-persona-forge/references/output-template.md +166 -0
- package/skills/opensource-pipeline/SKILL.md +254 -0
- package/skills/perl-patterns/SKILL.md +503 -0
- package/skills/perl-security/SKILL.md +502 -0
- package/skills/perl-testing/SKILL.md +474 -0
- package/skills/plan-orchestrate/SKILL.md +253 -0
- package/skills/plankton-code-quality/SKILL.md +236 -0
- package/skills/postgres-patterns/SKILL.md +146 -0
- package/skills/product-capability/SKILL.md +140 -0
- package/skills/product-lens/SKILL.md +91 -0
- package/skills/production-audit/SKILL.md +206 -0
- package/skills/production-scheduling/SKILL.md +237 -0
- package/skills/project-flow-ops/SKILL.md +110 -0
- package/skills/prompt-optimizer/SKILL.md +398 -0
- package/skills/python-patterns/SKILL.md +749 -0
- package/skills/python-testing/SKILL.md +815 -0
- package/skills/pytorch-patterns/SKILL.md +395 -0
- package/skills/quality-nonconformance/SKILL.md +259 -0
- package/skills/quarkus-patterns/SKILL.md +721 -0
- package/skills/quarkus-security/SKILL.md +466 -0
- package/skills/quarkus-tdd/SKILL.md +810 -0
- package/skills/quarkus-verification/SKILL.md +478 -0
- package/skills/ralphinho-rfc-pipeline/SKILL.md +66 -0
- package/skills/redis-patterns/SKILL.md +402 -0
- package/skills/regex-vs-llm-structured-text/SKILL.md +219 -0
- package/skills/remotion-video-creation/SKILL.md +43 -0
- package/skills/remotion-video-creation/rules/3d.md +86 -0
- package/skills/remotion-video-creation/rules/animations.md +29 -0
- package/skills/remotion-video-creation/rules/assets/charts-bar-chart.tsx +173 -0
- package/skills/remotion-video-creation/rules/assets/text-animations-typewriter.tsx +100 -0
- package/skills/remotion-video-creation/rules/assets/text-animations-word-highlight.tsx +108 -0
- package/skills/remotion-video-creation/rules/assets.md +78 -0
- package/skills/remotion-video-creation/rules/audio.md +172 -0
- package/skills/remotion-video-creation/rules/calculate-metadata.md +104 -0
- package/skills/remotion-video-creation/rules/can-decode.md +75 -0
- package/skills/remotion-video-creation/rules/charts.md +58 -0
- package/skills/remotion-video-creation/rules/compositions.md +146 -0
- package/skills/remotion-video-creation/rules/display-captions.md +126 -0
- package/skills/remotion-video-creation/rules/extract-frames.md +229 -0
- package/skills/remotion-video-creation/rules/fonts.md +152 -0
- package/skills/remotion-video-creation/rules/get-audio-duration.md +58 -0
- package/skills/remotion-video-creation/rules/get-video-dimensions.md +68 -0
- package/skills/remotion-video-creation/rules/get-video-duration.md +58 -0
- package/skills/remotion-video-creation/rules/gifs.md +138 -0
- package/skills/remotion-video-creation/rules/images.md +130 -0
- package/skills/remotion-video-creation/rules/import-srt-captions.md +67 -0
- package/skills/remotion-video-creation/rules/lottie.md +67 -0
- package/skills/remotion-video-creation/rules/measuring-dom-nodes.md +34 -0
- package/skills/remotion-video-creation/rules/measuring-text.md +143 -0
- package/skills/remotion-video-creation/rules/sequencing.md +106 -0
- package/skills/remotion-video-creation/rules/tailwind.md +11 -0
- package/skills/remotion-video-creation/rules/text-animations.md +20 -0
- package/skills/remotion-video-creation/rules/timing.md +179 -0
- package/skills/remotion-video-creation/rules/transcribe-captions.md +19 -0
- package/skills/remotion-video-creation/rules/transitions.md +122 -0
- package/skills/remotion-video-creation/rules/trimming.md +52 -0
- package/skills/remotion-video-creation/rules/videos.md +171 -0
- package/skills/repo-scan/SKILL.md +78 -0
- package/skills/research-ops/SKILL.md +111 -0
- package/skills/returns-reverse-logistics/SKILL.md +239 -0
- package/skills/rules-distill/SKILL.md +263 -0
- package/skills/rules-distill/scripts/scan-rules.sh +58 -0
- package/skills/rules-distill/scripts/scan-skills.sh +129 -0
- package/skills/rust-patterns/SKILL.md +498 -0
- package/skills/rust-testing/SKILL.md +499 -0
- package/skills/safety-guard/SKILL.md +74 -0
- package/skills/santa-method/SKILL.md +306 -0
- package/skills/scientific-db-pubmed-database/SKILL.md +175 -0
- package/skills/scientific-db-uspto-database/SKILL.md +177 -0
- package/skills/scientific-pkg-gget/SKILL.md +166 -0
- package/skills/scientific-thinking-literature-review/SKILL.md +192 -0
- package/skills/scientific-thinking-scholar-evaluation/SKILL.md +160 -0
- package/skills/search-first/SKILL.md +181 -0
- package/skills/security-bounty-hunter/SKILL.md +99 -0
- package/skills/security-review/SKILL.md +502 -0
- package/skills/security-review/cloud-infrastructure-security.md +361 -0
- package/skills/seo/SKILL.md +153 -0
- package/skills/skill-comply/SKILL.md +57 -0
- package/skills/skill-comply/fixtures/compliant_trace.jsonl +5 -0
- package/skills/skill-comply/fixtures/noncompliant_trace.jsonl +3 -0
- package/skills/skill-comply/fixtures/tdd_spec.yaml +44 -0
- package/skills/skill-comply/prompts/classifier.md +24 -0
- package/skills/skill-comply/prompts/scenario_generator.md +62 -0
- package/skills/skill-comply/prompts/spec_generator.md +42 -0
- package/skills/skill-comply/pyproject.toml +15 -0
- package/skills/skill-comply/scripts/__init__.py +0 -0
- package/skills/skill-comply/scripts/classifier.py +85 -0
- package/skills/skill-comply/scripts/grader.py +124 -0
- package/skills/skill-comply/scripts/parser.py +107 -0
- package/skills/skill-comply/scripts/report.py +170 -0
- package/skills/skill-comply/scripts/run.py +127 -0
- package/skills/skill-comply/scripts/runner.py +186 -0
- package/skills/skill-comply/scripts/scenario_generator.py +70 -0
- package/skills/skill-comply/scripts/spec_generator.py +72 -0
- package/skills/skill-comply/scripts/utils.py +13 -0
- package/skills/skill-comply/tests/test_grader.py +197 -0
- package/skills/skill-comply/tests/test_parser.py +90 -0
- package/skills/skill-comply/tests/test_runner.py +172 -0
- package/skills/skill-scout/SKILL.md +139 -0
- package/skills/skill-stocktake/SKILL.md +193 -0
- package/skills/skill-stocktake/scripts/quick-diff.sh +87 -0
- package/skills/skill-stocktake/scripts/save-results.sh +56 -0
- package/skills/skill-stocktake/scripts/scan.sh +170 -0
- package/skills/social-graph-ranker/SKILL.md +153 -0
- package/skills/springboot-patterns/SKILL.md +313 -0
- package/skills/springboot-security/SKILL.md +271 -0
- package/skills/springboot-tdd/SKILL.md +157 -0
- package/skills/springboot-verification/SKILL.md +230 -0
- package/skills/strategic-compact/SKILL.md +129 -0
- package/skills/strategic-compact/suggest-compact.sh +54 -0
- package/skills/swift-actor-persistence/SKILL.md +142 -0
- package/skills/swift-concurrency-6-2/SKILL.md +216 -0
- package/skills/swift-protocol-di-testing/SKILL.md +189 -0
- package/skills/swiftui-patterns/SKILL.md +259 -0
- package/skills/tdd-workflow/SKILL.md +462 -0
- package/skills/team-builder/SKILL.md +166 -0
- package/skills/terminal-ops/SKILL.md +108 -0
- package/skills/tinystruct-patterns/SKILL.md +130 -0
- package/skills/tinystruct-patterns/references/architecture.md +77 -0
- package/skills/tinystruct-patterns/references/data-handling.md +35 -0
- package/skills/tinystruct-patterns/references/routing.md +57 -0
- package/skills/tinystruct-patterns/references/system-usage.md +74 -0
- package/skills/tinystruct-patterns/references/testing.md +59 -0
- package/skills/token-budget-advisor/SKILL.md +133 -0
- package/skills/ui-demo/SKILL.md +464 -0
- package/skills/ui-to-vue/SKILL.md +134 -0
- package/skills/unified-notifications-ops/SKILL.md +186 -0
- package/skills/verification-loop/SKILL.md +125 -0
- package/skills/video-editing/SKILL.md +309 -0
- package/skills/videodb/SKILL.md +373 -0
- package/skills/videodb/reference/api-reference.md +550 -0
- package/skills/videodb/reference/capture-reference.md +407 -0
- package/skills/videodb/reference/capture.md +101 -0
- package/skills/videodb/reference/editor.md +443 -0
- package/skills/videodb/reference/generative.md +331 -0
- package/skills/videodb/reference/rtstream-reference.md +564 -0
- package/skills/videodb/reference/rtstream.md +65 -0
- package/skills/videodb/reference/search.md +230 -0
- package/skills/videodb/reference/streaming.md +406 -0
- package/skills/videodb/reference/use-cases.md +118 -0
- package/skills/videodb/scripts/ws_listener.py +282 -0
- package/skills/visa-doc-translate/README.md +86 -0
- package/skills/visa-doc-translate/SKILL.md +117 -0
- package/skills/vite-patterns/SKILL.md +448 -0
- package/skills/windows-desktop-e2e/SKILL.md +787 -0
- package/skills/workspace-surface-audit/SKILL.md +124 -0
- package/skills/x-api/SKILL.md +233 -0
|
@@ -0,0 +1,305 @@
|
|
|
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
|
+
origin: community
|
|
5
|
+
---
|
|
6
|
+
|
|
7
|
+
# Homelab WireGuard VPN
|
|
8
|
+
|
|
9
|
+
WireGuard is a fast, modern VPN protocol. It is the right choice for remote access to a
|
|
10
|
+
home network — simpler to configure than OpenVPN and faster than most alternatives.
|
|
11
|
+
|
|
12
|
+
All configuration examples show common setups. Review each command — especially the
|
|
13
|
+
iptables forwarding rules and key file permissions — before applying them to your
|
|
14
|
+
system, and make changes in a maintenance window.
|
|
15
|
+
|
|
16
|
+
## When to Use
|
|
17
|
+
|
|
18
|
+
- Setting up WireGuard server on a Raspberry Pi, Linux host, pfSense, or router
|
|
19
|
+
- Generating WireGuard keypairs and writing peer config files
|
|
20
|
+
- Configuring remote access from a phone or laptop to a home network
|
|
21
|
+
- Explaining split tunneling (route only home traffic) vs full tunnel (route all traffic)
|
|
22
|
+
- Troubleshooting WireGuard connections that will not come up
|
|
23
|
+
- Automating peer configuration generation for multiple clients
|
|
24
|
+
|
|
25
|
+
## How WireGuard Works
|
|
26
|
+
|
|
27
|
+
```
|
|
28
|
+
Your phone (WireGuard client)
|
|
29
|
+
│
|
|
30
|
+
│ Encrypted UDP tunnel (port 51820)
|
|
31
|
+
│
|
|
32
|
+
Your home router (WireGuard server — needs a public IP or DDNS)
|
|
33
|
+
│
|
|
34
|
+
Your home network (192.168.1.0/24, NAS, Pi, etc.)
|
|
35
|
+
|
|
36
|
+
Every device has a keypair (public + private key).
|
|
37
|
+
The server knows each client's public key.
|
|
38
|
+
The client knows the server's public key + endpoint (IP:port).
|
|
39
|
+
Traffic is encrypted end-to-end with no central server or certificate authority.
|
|
40
|
+
```
|
|
41
|
+
|
|
42
|
+
## Server Setup (Linux)
|
|
43
|
+
|
|
44
|
+
```bash
|
|
45
|
+
# Install WireGuard
|
|
46
|
+
sudo apt update && sudo apt install wireguard -y
|
|
47
|
+
|
|
48
|
+
# Generate server keypair — create files with private permissions from the start
|
|
49
|
+
sudo mkdir -p /etc/wireguard
|
|
50
|
+
sudo sh -c 'umask 077; wg genkey > /etc/wireguard/server_private.key'
|
|
51
|
+
sudo sh -c 'wg pubkey < /etc/wireguard/server_private.key > /etc/wireguard/server_public.key'
|
|
52
|
+
|
|
53
|
+
# Write server config — substitute the actual private key value
|
|
54
|
+
# Do not store private keys in version control or share them
|
|
55
|
+
sudo tee /etc/wireguard/wg0.conf << 'EOF'
|
|
56
|
+
[Interface]
|
|
57
|
+
Address = 10.8.0.1/24 # VPN subnet — server gets .1
|
|
58
|
+
ListenPort = 51820
|
|
59
|
+
PrivateKey = <paste_server_private_key_here>
|
|
60
|
+
|
|
61
|
+
# Scoped forwarding rules: allow VPN traffic in/out, not a blanket FORWARD ACCEPT
|
|
62
|
+
PostUp = iptables -A FORWARD -i wg0 -o eth0 -j ACCEPT
|
|
63
|
+
PostUp = iptables -A FORWARD -i eth0 -o wg0 -m conntrack --ctstate RELATED,ESTABLISHED -j ACCEPT
|
|
64
|
+
PostUp = iptables -t nat -A POSTROUTING -o eth0 -j MASQUERADE
|
|
65
|
+
PostDown = iptables -D FORWARD -i wg0 -o eth0 -j ACCEPT
|
|
66
|
+
PostDown = iptables -D FORWARD -i eth0 -o wg0 -m conntrack --ctstate RELATED,ESTABLISHED -j ACCEPT
|
|
67
|
+
PostDown = iptables -t nat -D POSTROUTING -o eth0 -j MASQUERADE
|
|
68
|
+
|
|
69
|
+
[Peer]
|
|
70
|
+
# Phone — replace with the actual phone public key
|
|
71
|
+
PublicKey = <phone_public_key>
|
|
72
|
+
AllowedIPs = 10.8.0.2/32
|
|
73
|
+
|
|
74
|
+
[Peer]
|
|
75
|
+
# Laptop — replace with the actual laptop public key
|
|
76
|
+
PublicKey = <laptop_public_key>
|
|
77
|
+
AllowedIPs = 10.8.0.3/32
|
|
78
|
+
EOF
|
|
79
|
+
sudo chmod 600 /etc/wireguard/wg0.conf
|
|
80
|
+
|
|
81
|
+
# Replace eth0 with your actual outbound interface name
|
|
82
|
+
# Check with: ip route show default
|
|
83
|
+
|
|
84
|
+
# Enable IP forwarding (required for routing traffic through the server)
|
|
85
|
+
echo "net.ipv4.ip_forward=1" | sudo tee /etc/sysctl.d/99-wireguard.conf
|
|
86
|
+
sudo sysctl --system
|
|
87
|
+
|
|
88
|
+
# Start WireGuard and enable on boot
|
|
89
|
+
sudo wg-quick up wg0
|
|
90
|
+
sudo systemctl enable wg-quick@wg0
|
|
91
|
+
```
|
|
92
|
+
|
|
93
|
+
## Client Configuration
|
|
94
|
+
|
|
95
|
+
```bash
|
|
96
|
+
# Generate a unique keypair for each client device
|
|
97
|
+
# Run on the client, or on the server and transfer the private key securely — never in plaintext
|
|
98
|
+
umask 077
|
|
99
|
+
wg genkey | tee phone_private.key | wg pubkey > phone_public.key
|
|
100
|
+
|
|
101
|
+
# Client config file (phone_wg0.conf):
|
|
102
|
+
[Interface]
|
|
103
|
+
PrivateKey = <phone_private_key>
|
|
104
|
+
Address = 10.8.0.2/32
|
|
105
|
+
DNS = 192.168.1.2 # Optional: use Pi-hole for DNS over the tunnel
|
|
106
|
+
|
|
107
|
+
[Peer]
|
|
108
|
+
PublicKey = <server_public_key>
|
|
109
|
+
Endpoint = your-home-ip.ddns.net:51820 # Your public IP or DDNS hostname
|
|
110
|
+
AllowedIPs = 192.168.1.0/24 # Split tunnel: only home network traffic
|
|
111
|
+
# AllowedIPs = 0.0.0.0/0, ::/0 # Full tunnel: all traffic through VPN
|
|
112
|
+
|
|
113
|
+
PersistentKeepalive = 25 # Keep NAT hole open (required for mobile clients)
|
|
114
|
+
```
|
|
115
|
+
|
|
116
|
+
## Split Tunnel vs Full Tunnel
|
|
117
|
+
|
|
118
|
+
```
|
|
119
|
+
# Split tunnel: AllowedIPs = 192.168.1.0/24
|
|
120
|
+
Only traffic destined for your home network goes through the VPN.
|
|
121
|
+
Internet traffic (YouTube, Spotify) goes directly — better performance on mobile.
|
|
122
|
+
Best for: "I just want to reach my NAS and Pi from anywhere."
|
|
123
|
+
|
|
124
|
+
# Full tunnel: AllowedIPs = 0.0.0.0/0, ::/0
|
|
125
|
+
ALL traffic goes through your home internet connection.
|
|
126
|
+
Useful for: piggybacking home DNS/Pi-hole ad blocking.
|
|
127
|
+
Downside: home upload speed becomes your bottleneck everywhere.
|
|
128
|
+
|
|
129
|
+
# Multi-subnet split tunnel (most common homelab use case):
|
|
130
|
+
AllowedIPs = 192.168.10.0/24, 192.168.20.0/24, 192.168.30.0/24, 10.8.0.0/24
|
|
131
|
+
Routes all your VLANs through the tunnel; internet stays direct.
|
|
132
|
+
```
|
|
133
|
+
|
|
134
|
+
## Key Generation and Peer Management
|
|
135
|
+
|
|
136
|
+
```python
|
|
137
|
+
import subprocess
|
|
138
|
+
|
|
139
|
+
def generate_keypair() -> tuple[str, str]:
|
|
140
|
+
"""Generate a WireGuard keypair. Returns (private_key, public_key)."""
|
|
141
|
+
private = subprocess.check_output(["wg", "genkey"]).decode().strip()
|
|
142
|
+
public = subprocess.run(
|
|
143
|
+
["wg", "pubkey"], input=private.encode(), capture_output=True
|
|
144
|
+
).stdout.decode().strip()
|
|
145
|
+
return private, public
|
|
146
|
+
|
|
147
|
+
def generate_preshared_key() -> str:
|
|
148
|
+
return subprocess.check_output(["wg", "genpsk"]).decode().strip()
|
|
149
|
+
|
|
150
|
+
def build_client_config(
|
|
151
|
+
client_private_key: str,
|
|
152
|
+
client_vpn_ip: str, # e.g. "10.8.0.3"
|
|
153
|
+
server_public_key: str,
|
|
154
|
+
server_endpoint: str, # e.g. "home.example.com:51820"
|
|
155
|
+
allowed_ips: str = "192.168.1.0/24",
|
|
156
|
+
dns: str = "",
|
|
157
|
+
) -> str:
|
|
158
|
+
dns_line = f"DNS = {dns}\n" if dns else ""
|
|
159
|
+
return f"""[Interface]
|
|
160
|
+
PrivateKey = {client_private_key}
|
|
161
|
+
Address = {client_vpn_ip}/32
|
|
162
|
+
{dns_line}
|
|
163
|
+
[Peer]
|
|
164
|
+
PublicKey = {server_public_key}
|
|
165
|
+
Endpoint = {server_endpoint}
|
|
166
|
+
AllowedIPs = {allowed_ips}
|
|
167
|
+
PersistentKeepalive = 25
|
|
168
|
+
"""
|
|
169
|
+
|
|
170
|
+
def build_server_peer_block(
|
|
171
|
+
client_public_key: str,
|
|
172
|
+
client_vpn_ip: str,
|
|
173
|
+
comment: str = "",
|
|
174
|
+
) -> str:
|
|
175
|
+
comment_line = f"# {comment}\n" if comment else ""
|
|
176
|
+
return f"""
|
|
177
|
+
{comment_line}[Peer]
|
|
178
|
+
PublicKey = {client_public_key}
|
|
179
|
+
AllowedIPs = {client_vpn_ip}/32
|
|
180
|
+
"""
|
|
181
|
+
```
|
|
182
|
+
|
|
183
|
+
Keep private keys out of source control. If you use this script, write key material
|
|
184
|
+
to files with mode 600 and never log or print it.
|
|
185
|
+
|
|
186
|
+
## pfSense / OPNsense WireGuard
|
|
187
|
+
|
|
188
|
+
```
|
|
189
|
+
# pfSense: VPN → WireGuard → Add Tunnel
|
|
190
|
+
Interface Keys: Generate (creates keypair automatically)
|
|
191
|
+
Listen Port: 51820
|
|
192
|
+
Interface Address: 10.8.0.1/24
|
|
193
|
+
|
|
194
|
+
# Add Peer (one per client):
|
|
195
|
+
Public Key: <client public key>
|
|
196
|
+
Allowed IPs: 10.8.0.2/32
|
|
197
|
+
|
|
198
|
+
# Assign the WireGuard interface:
|
|
199
|
+
Interfaces → Assignments → Add (select wg0)
|
|
200
|
+
Enable interface, no IP needed (it is set in the tunnel config)
|
|
201
|
+
|
|
202
|
+
# Firewall rules:
|
|
203
|
+
WAN → Allow UDP port 51820 inbound (so clients can reach the server)
|
|
204
|
+
WireGuard interface → Allow traffic to LAN networks you want reachable
|
|
205
|
+
```
|
|
206
|
+
|
|
207
|
+
## DDNS (Dynamic DNS) for Home Servers
|
|
208
|
+
|
|
209
|
+
Most home internet connections have a dynamic IP. Use DDNS so your VPN endpoint
|
|
210
|
+
stays reachable after an IP change.
|
|
211
|
+
|
|
212
|
+
```bash
|
|
213
|
+
# Option 1: Cloudflare DDNS — store credentials in a secrets file, not inline
|
|
214
|
+
# docker-compose entry using an env file:
|
|
215
|
+
ddns-updater:
|
|
216
|
+
image: qmcgaw/ddns-updater
|
|
217
|
+
env_file: ./ddns.env # store zone_id and token here, not in compose
|
|
218
|
+
restart: unless-stopped
|
|
219
|
+
|
|
220
|
+
# ddns.env (chmod 600, not committed to git):
|
|
221
|
+
# SETTINGS_CLOUDFLARE_ZONE_ID=your_zone_id
|
|
222
|
+
# SETTINGS_CLOUDFLARE_TOKEN=your_api_token
|
|
223
|
+
|
|
224
|
+
# Option 2: DuckDNS (free, simple)
|
|
225
|
+
Sign up at duckdns.org → get a token and subdomain (myhome.duckdns.org)
|
|
226
|
+
Store token in /etc/ddns.env (mode 600), then use a small root-owned script:
|
|
227
|
+
|
|
228
|
+
# /usr/local/bin/update-duckdns
|
|
229
|
+
#!/bin/sh
|
|
230
|
+
set -eu
|
|
231
|
+
. /etc/ddns.env
|
|
232
|
+
curl --fail --silent --show-error --max-time 10 \
|
|
233
|
+
--get "https://www.duckdns.org/update" \
|
|
234
|
+
--data-urlencode "domains=myhome" \
|
|
235
|
+
--data-urlencode "token=${DUCKDNS_TOKEN}" \
|
|
236
|
+
--data-urlencode "ip="
|
|
237
|
+
|
|
238
|
+
# Cron job:
|
|
239
|
+
*/5 * * * * /usr/local/bin/update-duckdns >/dev/null 2>&1
|
|
240
|
+
```
|
|
241
|
+
|
|
242
|
+
## Troubleshooting
|
|
243
|
+
|
|
244
|
+
```bash
|
|
245
|
+
# Check WireGuard status and last handshake
|
|
246
|
+
sudo wg show
|
|
247
|
+
|
|
248
|
+
# If "latest handshake" is never or very old, the tunnel is not connected.
|
|
249
|
+
# Check:
|
|
250
|
+
# 1. Is UDP port 51820 open on the router/firewall?
|
|
251
|
+
sudo ufw status # or check pfSense/UniFi firewall rules
|
|
252
|
+
|
|
253
|
+
# 2. Is the server public key in the client config correct?
|
|
254
|
+
sudo wg show wg0 public-key # Compare to what is in the client config
|
|
255
|
+
|
|
256
|
+
# 3. Is IP forwarding enabled on the server?
|
|
257
|
+
cat /proc/sys/net/ipv4/ip_forward # Should be 1
|
|
258
|
+
|
|
259
|
+
# 4. Does the client AllowedIPs cover the IP you are trying to reach?
|
|
260
|
+
# If AllowedIPs = 192.168.1.0/24 and you are trying to reach 192.168.3.5, it will not route.
|
|
261
|
+
|
|
262
|
+
# Check kernel logs for WireGuard errors
|
|
263
|
+
dmesg | grep wireguard
|
|
264
|
+
|
|
265
|
+
# Restart WireGuard
|
|
266
|
+
sudo wg-quick down wg0 && sudo wg-quick up wg0
|
|
267
|
+
```
|
|
268
|
+
|
|
269
|
+
## Anti-Patterns
|
|
270
|
+
|
|
271
|
+
```
|
|
272
|
+
# BAD: Storing private keys in version control or sharing them
|
|
273
|
+
# Private keys are equivalent to passwords — never commit them to git
|
|
274
|
+
|
|
275
|
+
# BAD: Using AllowedIPs = 0.0.0.0/0 on mobile without considering the impact
|
|
276
|
+
# Full tunnel routes all mobile traffic through your home upload — usually slow
|
|
277
|
+
|
|
278
|
+
# BAD: Not setting PersistentKeepalive on mobile clients
|
|
279
|
+
# Mobile clients behind NAT drop idle tunnels without it
|
|
280
|
+
|
|
281
|
+
# BAD: Opening port 51820 in the firewall but forgetting IP forwarding on the server
|
|
282
|
+
# Tunnel connects but no traffic routes — confusing to debug
|
|
283
|
+
|
|
284
|
+
# BAD: Sharing a keypair across multiple client devices
|
|
285
|
+
# Each device must have its own unique keypair — shared keys break the security model
|
|
286
|
+
|
|
287
|
+
# BAD: Using a broad "FORWARD ACCEPT" iptables rule
|
|
288
|
+
# Scope forwarding rules to the wg0 interface and direction only
|
|
289
|
+
```
|
|
290
|
+
|
|
291
|
+
## Best Practices
|
|
292
|
+
|
|
293
|
+
- Generate a unique keypair per client device — never reuse keys
|
|
294
|
+
- Use split tunneling (`AllowedIPs = <home subnets>`) for mobile
|
|
295
|
+
- Set `PersistentKeepalive = 25` on all mobile clients
|
|
296
|
+
- Use DDNS if your ISP assigns a dynamic IP; store credentials in env files, not inline
|
|
297
|
+
- Use scoped iptables forwarding rules (inbound on wg0 only) rather than a blanket FORWARD ACCEPT
|
|
298
|
+
- Add Pi-hole's IP as `DNS =` in client configs to get ad blocking over the VPN
|
|
299
|
+
- Rotate the server keypair periodically and update all client configs
|
|
300
|
+
|
|
301
|
+
## Related Skills
|
|
302
|
+
|
|
303
|
+
- homelab-network-setup
|
|
304
|
+
- homelab-vlan-segmentation
|
|
305
|
+
- 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
|
+
```
|