@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,207 @@
|
|
|
1
|
+
---
|
|
2
|
+
name: healthcare-eval-harness
|
|
3
|
+
description: Patient safety evaluation harness for healthcare application deployments. Automated test suites for CDSS accuracy, PHI exposure, clinical workflow integrity, and integration compliance. Blocks deployments on safety failures.
|
|
4
|
+
origin: Health1 Super Speciality Hospitals — contributed by Dr. Keyur Patel
|
|
5
|
+
version: "1.0.0"
|
|
6
|
+
---
|
|
7
|
+
|
|
8
|
+
# Healthcare Eval Harness — Patient Safety Verification
|
|
9
|
+
|
|
10
|
+
Automated verification system for healthcare application deployments. A single CRITICAL failure blocks deployment. Patient safety is non-negotiable.
|
|
11
|
+
|
|
12
|
+
> **Note:** Examples use Jest as the reference test runner. Adapt commands for your framework (Vitest, pytest, PHPUnit, etc.) — the test categories and pass thresholds are framework-agnostic.
|
|
13
|
+
|
|
14
|
+
## When to Use
|
|
15
|
+
|
|
16
|
+
- Before any deployment of EMR/EHR applications
|
|
17
|
+
- After modifying CDSS logic (drug interactions, dose validation, scoring)
|
|
18
|
+
- After changing database schemas that touch patient data
|
|
19
|
+
- After modifying authentication or access control
|
|
20
|
+
- During CI/CD pipeline configuration for healthcare apps
|
|
21
|
+
- After resolving merge conflicts in clinical modules
|
|
22
|
+
|
|
23
|
+
## How It Works
|
|
24
|
+
|
|
25
|
+
The eval harness runs five test categories in order. The first three (CDSS Accuracy, PHI Exposure, Data Integrity) are CRITICAL gates requiring 100% pass rate — a single failure blocks deployment. The remaining two (Clinical Workflow, Integration) are HIGH gates requiring 95%+ pass rate.
|
|
26
|
+
|
|
27
|
+
Each category maps to a Jest test path pattern. The CI pipeline runs CRITICAL gates with `--bail` (stop on first failure) and enforces coverage thresholds with `--coverage --coverageThreshold`.
|
|
28
|
+
|
|
29
|
+
### Eval Categories
|
|
30
|
+
|
|
31
|
+
**1. CDSS Accuracy (CRITICAL — 100% required)**
|
|
32
|
+
|
|
33
|
+
Tests all clinical decision support logic: drug interaction pairs (both directions), dose validation rules, clinical scoring vs published specs, no false negatives, no silent failures.
|
|
34
|
+
|
|
35
|
+
```bash
|
|
36
|
+
npx jest --testPathPattern='tests/cdss' --bail --ci --coverage
|
|
37
|
+
```
|
|
38
|
+
|
|
39
|
+
**2. PHI Exposure (CRITICAL — 100% required)**
|
|
40
|
+
|
|
41
|
+
Tests for protected health information leaks: API error responses, console output, URL parameters, browser storage, cross-facility isolation, unauthenticated access, service role key absence.
|
|
42
|
+
|
|
43
|
+
```bash
|
|
44
|
+
npx jest --testPathPattern='tests/security/phi' --bail --ci
|
|
45
|
+
```
|
|
46
|
+
|
|
47
|
+
**3. Data Integrity (CRITICAL — 100% required)**
|
|
48
|
+
|
|
49
|
+
Tests clinical data safety: locked encounters, audit trail entries, cascade delete protection, concurrent edit handling, no orphaned records.
|
|
50
|
+
|
|
51
|
+
```bash
|
|
52
|
+
npx jest --testPathPattern='tests/data-integrity' --bail --ci
|
|
53
|
+
```
|
|
54
|
+
|
|
55
|
+
**4. Clinical Workflow (HIGH — 95%+ required)**
|
|
56
|
+
|
|
57
|
+
Tests end-to-end flows: encounter lifecycle, template rendering, medication sets, drug/diagnosis search, prescription PDF, red flag alerts.
|
|
58
|
+
|
|
59
|
+
```bash
|
|
60
|
+
tmp_json=$(mktemp)
|
|
61
|
+
npx jest --testPathPattern='tests/clinical' --ci --json --outputFile="$tmp_json" || true
|
|
62
|
+
total=$(jq '.numTotalTests // 0' "$tmp_json")
|
|
63
|
+
passed=$(jq '.numPassedTests // 0' "$tmp_json")
|
|
64
|
+
if [ "$total" -eq 0 ]; then
|
|
65
|
+
echo "No clinical tests found" >&2
|
|
66
|
+
exit 1
|
|
67
|
+
fi
|
|
68
|
+
rate=$(echo "scale=2; $passed * 100 / $total" | bc)
|
|
69
|
+
echo "Clinical pass rate: ${rate}% ($passed/$total)"
|
|
70
|
+
```
|
|
71
|
+
|
|
72
|
+
**5. Integration Compliance (HIGH — 95%+ required)**
|
|
73
|
+
|
|
74
|
+
Tests external systems: HL7 message parsing (v2.x), FHIR validation, lab result mapping, malformed message handling.
|
|
75
|
+
|
|
76
|
+
```bash
|
|
77
|
+
tmp_json=$(mktemp)
|
|
78
|
+
npx jest --testPathPattern='tests/integration' --ci --json --outputFile="$tmp_json" || true
|
|
79
|
+
total=$(jq '.numTotalTests // 0' "$tmp_json")
|
|
80
|
+
passed=$(jq '.numPassedTests // 0' "$tmp_json")
|
|
81
|
+
if [ "$total" -eq 0 ]; then
|
|
82
|
+
echo "No integration tests found" >&2
|
|
83
|
+
exit 1
|
|
84
|
+
fi
|
|
85
|
+
rate=$(echo "scale=2; $passed * 100 / $total" | bc)
|
|
86
|
+
echo "Integration pass rate: ${rate}% ($passed/$total)"
|
|
87
|
+
```
|
|
88
|
+
|
|
89
|
+
### Pass/Fail Matrix
|
|
90
|
+
|
|
91
|
+
| Category | Threshold | On Failure |
|
|
92
|
+
|----------|-----------|------------|
|
|
93
|
+
| CDSS Accuracy | 100% | **BLOCK deployment** |
|
|
94
|
+
| PHI Exposure | 100% | **BLOCK deployment** |
|
|
95
|
+
| Data Integrity | 100% | **BLOCK deployment** |
|
|
96
|
+
| Clinical Workflow | 95%+ | WARN, allow with review |
|
|
97
|
+
| Integration | 95%+ | WARN, allow with review |
|
|
98
|
+
|
|
99
|
+
### CI/CD Integration
|
|
100
|
+
|
|
101
|
+
```yaml
|
|
102
|
+
name: Healthcare Safety Gate
|
|
103
|
+
on: [push, pull_request]
|
|
104
|
+
|
|
105
|
+
jobs:
|
|
106
|
+
safety-gate:
|
|
107
|
+
runs-on: ubuntu-latest
|
|
108
|
+
steps:
|
|
109
|
+
- uses: actions/checkout@v4
|
|
110
|
+
- uses: actions/setup-node@v4
|
|
111
|
+
with:
|
|
112
|
+
node-version: '20'
|
|
113
|
+
- run: npm ci
|
|
114
|
+
|
|
115
|
+
# CRITICAL gates — 100% required, bail on first failure
|
|
116
|
+
- name: CDSS Accuracy
|
|
117
|
+
run: npx jest --testPathPattern='tests/cdss' --bail --ci --coverage --coverageThreshold='{"global":{"branches":80,"functions":80,"lines":80}}'
|
|
118
|
+
|
|
119
|
+
- name: PHI Exposure Check
|
|
120
|
+
run: npx jest --testPathPattern='tests/security/phi' --bail --ci
|
|
121
|
+
|
|
122
|
+
- name: Data Integrity
|
|
123
|
+
run: npx jest --testPathPattern='tests/data-integrity' --bail --ci
|
|
124
|
+
|
|
125
|
+
# HIGH gates — 95%+ required, custom threshold check
|
|
126
|
+
# HIGH gates — 95%+ required
|
|
127
|
+
- name: Clinical Workflows
|
|
128
|
+
run: |
|
|
129
|
+
TMP_JSON=$(mktemp)
|
|
130
|
+
npx jest --testPathPattern='tests/clinical' --ci --json --outputFile="$TMP_JSON" || true
|
|
131
|
+
TOTAL=$(jq '.numTotalTests // 0' "$TMP_JSON")
|
|
132
|
+
PASSED=$(jq '.numPassedTests // 0' "$TMP_JSON")
|
|
133
|
+
if [ "$TOTAL" -eq 0 ]; then
|
|
134
|
+
echo "::error::No clinical tests found"; exit 1
|
|
135
|
+
fi
|
|
136
|
+
RATE=$(echo "scale=2; $PASSED * 100 / $TOTAL" | bc)
|
|
137
|
+
echo "Pass rate: ${RATE}% ($PASSED/$TOTAL)"
|
|
138
|
+
if (( $(echo "$RATE < 95" | bc -l) )); then
|
|
139
|
+
echo "::warning::Clinical pass rate ${RATE}% below 95%"
|
|
140
|
+
fi
|
|
141
|
+
|
|
142
|
+
- name: Integration Compliance
|
|
143
|
+
run: |
|
|
144
|
+
TMP_JSON=$(mktemp)
|
|
145
|
+
npx jest --testPathPattern='tests/integration' --ci --json --outputFile="$TMP_JSON" || true
|
|
146
|
+
TOTAL=$(jq '.numTotalTests // 0' "$TMP_JSON")
|
|
147
|
+
PASSED=$(jq '.numPassedTests // 0' "$TMP_JSON")
|
|
148
|
+
if [ "$TOTAL" -eq 0 ]; then
|
|
149
|
+
echo "::error::No integration tests found"; exit 1
|
|
150
|
+
fi
|
|
151
|
+
RATE=$(echo "scale=2; $PASSED * 100 / $TOTAL" | bc)
|
|
152
|
+
echo "Pass rate: ${RATE}% ($PASSED/$TOTAL)"
|
|
153
|
+
if (( $(echo "$RATE < 95" | bc -l) )); then
|
|
154
|
+
echo "::warning::Integration pass rate ${RATE}% below 95%"
|
|
155
|
+
fi
|
|
156
|
+
```
|
|
157
|
+
|
|
158
|
+
### Anti-Patterns
|
|
159
|
+
|
|
160
|
+
- Skipping CDSS tests "because they passed last time"
|
|
161
|
+
- Setting CRITICAL thresholds below 100%
|
|
162
|
+
- Using `--no-bail` on CRITICAL test suites
|
|
163
|
+
- Mocking the CDSS engine in integration tests (must test real logic)
|
|
164
|
+
- Allowing deployments when safety gate is red
|
|
165
|
+
- Running tests without `--coverage` on CDSS suites
|
|
166
|
+
|
|
167
|
+
## Examples
|
|
168
|
+
|
|
169
|
+
### Example 1: Run All Critical Gates Locally
|
|
170
|
+
|
|
171
|
+
```bash
|
|
172
|
+
npx jest --testPathPattern='tests/cdss' --bail --ci --coverage && \
|
|
173
|
+
npx jest --testPathPattern='tests/security/phi' --bail --ci && \
|
|
174
|
+
npx jest --testPathPattern='tests/data-integrity' --bail --ci
|
|
175
|
+
```
|
|
176
|
+
|
|
177
|
+
### Example 2: Check HIGH Gate Pass Rate
|
|
178
|
+
|
|
179
|
+
```bash
|
|
180
|
+
tmp_json=$(mktemp)
|
|
181
|
+
npx jest --testPathPattern='tests/clinical' --ci --json --outputFile="$tmp_json" || true
|
|
182
|
+
jq '{
|
|
183
|
+
passed: (.numPassedTests // 0),
|
|
184
|
+
total: (.numTotalTests // 0),
|
|
185
|
+
rate: (if (.numTotalTests // 0) == 0 then 0 else ((.numPassedTests // 0) / (.numTotalTests // 1) * 100) end)
|
|
186
|
+
}' "$tmp_json"
|
|
187
|
+
# Expected: { "passed": 21, "total": 22, "rate": 95.45 }
|
|
188
|
+
```
|
|
189
|
+
|
|
190
|
+
### Example 3: Eval Report
|
|
191
|
+
|
|
192
|
+
```
|
|
193
|
+
## Healthcare Eval: 2026-03-27 [commit abc1234]
|
|
194
|
+
|
|
195
|
+
### Patient Safety: PASS
|
|
196
|
+
|
|
197
|
+
| Category | Tests | Pass | Fail | Status |
|
|
198
|
+
|----------|-------|------|------|--------|
|
|
199
|
+
| CDSS Accuracy | 39 | 39 | 0 | PASS |
|
|
200
|
+
| PHI Exposure | 8 | 8 | 0 | PASS |
|
|
201
|
+
| Data Integrity | 12 | 12 | 0 | PASS |
|
|
202
|
+
| Clinical Workflow | 22 | 21 | 1 | 95.5% PASS |
|
|
203
|
+
| Integration | 6 | 6 | 0 | PASS |
|
|
204
|
+
|
|
205
|
+
### Coverage: 84% (target: 80%+)
|
|
206
|
+
### Verdict: SAFE TO DEPLOY
|
|
207
|
+
```
|
|
@@ -0,0 +1,145 @@
|
|
|
1
|
+
---
|
|
2
|
+
name: healthcare-phi-compliance
|
|
3
|
+
description: Protected Health Information (PHI) and Personally Identifiable Information (PII) compliance patterns for healthcare applications. Covers data classification, access control, audit trails, encryption, and common leak vectors.
|
|
4
|
+
origin: Health1 Super Speciality Hospitals — contributed by Dr. Keyur Patel
|
|
5
|
+
version: "1.0.0"
|
|
6
|
+
---
|
|
7
|
+
|
|
8
|
+
# Healthcare PHI/PII Compliance Patterns
|
|
9
|
+
|
|
10
|
+
Patterns for protecting patient data, clinician data, and financial data in healthcare applications. Applicable to HIPAA (US), DISHA (India), GDPR (EU), and general healthcare data protection.
|
|
11
|
+
|
|
12
|
+
## When to Use
|
|
13
|
+
|
|
14
|
+
- Building any feature that touches patient records
|
|
15
|
+
- Implementing access control or authentication for clinical systems
|
|
16
|
+
- Designing database schemas for healthcare data
|
|
17
|
+
- Building APIs that return patient or clinician data
|
|
18
|
+
- Implementing audit trails or logging
|
|
19
|
+
- Reviewing code for data exposure vulnerabilities
|
|
20
|
+
- Setting up Row-Level Security (RLS) for multi-tenant healthcare systems
|
|
21
|
+
|
|
22
|
+
## How It Works
|
|
23
|
+
|
|
24
|
+
Healthcare data protection operates on three layers: **classification** (what is sensitive), **access control** (who can see it), and **audit** (who did see it).
|
|
25
|
+
|
|
26
|
+
### Data Classification
|
|
27
|
+
|
|
28
|
+
**PHI (Protected Health Information)** — any data that can identify a patient AND relates to their health: patient name, date of birth, address, phone, email, national ID numbers (SSN, Aadhaar, NHS number), medical record numbers, diagnoses, medications, lab results, imaging, insurance policy and claim details, appointment and admission records, or any combination of the above.
|
|
29
|
+
|
|
30
|
+
**PII (Non-patient-sensitive data)** in healthcare systems: clinician/staff personal details, doctor fee structures and payout amounts, employee salary and bank details, vendor payment information.
|
|
31
|
+
|
|
32
|
+
### Access Control: Row-Level Security
|
|
33
|
+
|
|
34
|
+
```sql
|
|
35
|
+
ALTER TABLE patients ENABLE ROW LEVEL SECURITY;
|
|
36
|
+
|
|
37
|
+
-- Scope access by facility
|
|
38
|
+
CREATE POLICY "staff_read_own_facility"
|
|
39
|
+
ON patients FOR SELECT TO authenticated
|
|
40
|
+
USING (facility_id IN (
|
|
41
|
+
SELECT facility_id FROM staff_assignments
|
|
42
|
+
WHERE user_id = auth.uid() AND role IN ('doctor','nurse','lab_tech','admin')
|
|
43
|
+
));
|
|
44
|
+
|
|
45
|
+
-- Audit log: insert-only (tamper-proof)
|
|
46
|
+
CREATE POLICY "audit_insert_only" ON audit_log FOR INSERT
|
|
47
|
+
TO authenticated WITH CHECK (user_id = auth.uid());
|
|
48
|
+
CREATE POLICY "audit_no_modify" ON audit_log FOR UPDATE USING (false);
|
|
49
|
+
CREATE POLICY "audit_no_delete" ON audit_log FOR DELETE USING (false);
|
|
50
|
+
```
|
|
51
|
+
|
|
52
|
+
### Audit Trail
|
|
53
|
+
|
|
54
|
+
Every PHI access or modification must be logged:
|
|
55
|
+
|
|
56
|
+
```typescript
|
|
57
|
+
interface AuditEntry {
|
|
58
|
+
timestamp: string;
|
|
59
|
+
user_id: string;
|
|
60
|
+
patient_id: string;
|
|
61
|
+
action: 'create' | 'read' | 'update' | 'delete' | 'print' | 'export';
|
|
62
|
+
resource_type: string;
|
|
63
|
+
resource_id: string;
|
|
64
|
+
changes?: { before: object; after: object };
|
|
65
|
+
ip_address: string;
|
|
66
|
+
session_id: string;
|
|
67
|
+
}
|
|
68
|
+
```
|
|
69
|
+
|
|
70
|
+
### Common Leak Vectors
|
|
71
|
+
|
|
72
|
+
**Error messages:** Never include patient-identifying data in error messages thrown to the client. Log details server-side only.
|
|
73
|
+
|
|
74
|
+
**Console output:** Never log full patient objects. Use opaque internal record IDs (UUIDs) — not medical record numbers, national IDs, or names.
|
|
75
|
+
|
|
76
|
+
**URL parameters:** Never put patient-identifying data in query strings or path segments that could appear in logs or browser history. Use opaque UUIDs only.
|
|
77
|
+
|
|
78
|
+
**Browser storage:** Never store PHI in localStorage or sessionStorage. Keep PHI in memory only, fetch on demand.
|
|
79
|
+
|
|
80
|
+
**Service role keys:** Never use the service_role key in client-side code. Always use the anon/publishable key and let RLS enforce access.
|
|
81
|
+
|
|
82
|
+
**Logs and monitoring:** Never log full patient records. Use opaque record IDs only (not medical record numbers). Sanitize stack traces before sending to error tracking services.
|
|
83
|
+
|
|
84
|
+
### Database Schema Tagging
|
|
85
|
+
|
|
86
|
+
Mark PHI/PII columns at the schema level:
|
|
87
|
+
|
|
88
|
+
```sql
|
|
89
|
+
COMMENT ON COLUMN patients.name IS 'PHI: patient_name';
|
|
90
|
+
COMMENT ON COLUMN patients.dob IS 'PHI: date_of_birth';
|
|
91
|
+
COMMENT ON COLUMN patients.aadhaar IS 'PHI: national_id';
|
|
92
|
+
COMMENT ON COLUMN doctor_payouts.amount IS 'PII: financial';
|
|
93
|
+
```
|
|
94
|
+
|
|
95
|
+
### Deployment Checklist
|
|
96
|
+
|
|
97
|
+
Before every deployment:
|
|
98
|
+
- No PHI in error messages or stack traces
|
|
99
|
+
- No PHI in console.log/console.error
|
|
100
|
+
- No PHI in URL parameters
|
|
101
|
+
- No PHI in browser storage
|
|
102
|
+
- No service_role key in client code
|
|
103
|
+
- RLS enabled on all PHI/PII tables
|
|
104
|
+
- Audit trail for all data modifications
|
|
105
|
+
- Session timeout configured
|
|
106
|
+
- API authentication on all PHI endpoints
|
|
107
|
+
- Cross-facility data isolation verified
|
|
108
|
+
|
|
109
|
+
## Examples
|
|
110
|
+
|
|
111
|
+
### Example 1: Safe vs Unsafe Error Handling
|
|
112
|
+
|
|
113
|
+
```typescript
|
|
114
|
+
// BAD — leaks PHI in error
|
|
115
|
+
throw new Error(`Patient ${patient.name} not found in ${patient.facility}`);
|
|
116
|
+
|
|
117
|
+
// GOOD — generic error, details logged server-side with opaque IDs only
|
|
118
|
+
logger.error('Patient lookup failed', { recordId: patient.id, facilityId });
|
|
119
|
+
throw new Error('Record not found');
|
|
120
|
+
```
|
|
121
|
+
|
|
122
|
+
### Example 2: RLS Policy for Multi-Facility Isolation
|
|
123
|
+
|
|
124
|
+
```sql
|
|
125
|
+
-- Doctor at Facility A cannot see Facility B patients
|
|
126
|
+
CREATE POLICY "facility_isolation"
|
|
127
|
+
ON patients FOR SELECT TO authenticated
|
|
128
|
+
USING (facility_id IN (
|
|
129
|
+
SELECT facility_id FROM staff_assignments WHERE user_id = auth.uid()
|
|
130
|
+
));
|
|
131
|
+
|
|
132
|
+
-- Test: login as doctor-facility-a, query facility-b patients
|
|
133
|
+
-- Expected: 0 rows returned
|
|
134
|
+
```
|
|
135
|
+
|
|
136
|
+
### Example 3: Safe Logging
|
|
137
|
+
|
|
138
|
+
```typescript
|
|
139
|
+
// BAD — logs identifiable patient data
|
|
140
|
+
console.log('Processing patient:', patient);
|
|
141
|
+
|
|
142
|
+
// GOOD — logs only opaque internal record ID
|
|
143
|
+
console.log('Processing record:', patient.id);
|
|
144
|
+
// Note: even patient.id should be an opaque UUID, not a medical record number
|
|
145
|
+
```
|
|
@@ -0,0 +1,87 @@
|
|
|
1
|
+
---
|
|
2
|
+
name: hermes-imports
|
|
3
|
+
description: Convert local Hermes operator workflows into sanitized the toolset skills and release-pack artifacts. Use when preparing a Hermes workflow for public the toolset reuse without leaking private workspace state, credentials, or local-only paths.
|
|
4
|
+
---
|
|
5
|
+
|
|
6
|
+
# Hermes Imports
|
|
7
|
+
|
|
8
|
+
Use this skill when turning a repeated Hermes workflow into something safe to ship in the toolset.
|
|
9
|
+
|
|
10
|
+
Hermes is the operator shell. the toolset is the reusable workflow layer. Imports should move stable patterns from Hermes into the toolset without moving private state.
|
|
11
|
+
|
|
12
|
+
## When To Use
|
|
13
|
+
|
|
14
|
+
- A Hermes workflow has repeated enough times to become reusable.
|
|
15
|
+
- A local operator prompt should become a public the toolset skill.
|
|
16
|
+
- A launch, content, research, or engineering workflow needs sanitized handoff docs.
|
|
17
|
+
- A workflow mentions local paths, credentials, personal datasets, or private account names that must be removed before publication.
|
|
18
|
+
|
|
19
|
+
## Import Rules
|
|
20
|
+
|
|
21
|
+
- Convert local paths to repo-relative paths or placeholders.
|
|
22
|
+
- Replace live account names with role labels such as `operator`, `default profile`, or `workspace owner`.
|
|
23
|
+
- Describe credential requirements by provider name only.
|
|
24
|
+
- Keep examples narrow and operational.
|
|
25
|
+
- Do not ship raw workspace exports, tokens, OAuth files, health data, CRM data, or finance data.
|
|
26
|
+
- If the workflow requires private state to make sense, keep it local.
|
|
27
|
+
|
|
28
|
+
## Sanitization Checklist
|
|
29
|
+
|
|
30
|
+
Before committing an imported workflow, scan for:
|
|
31
|
+
|
|
32
|
+
- absolute paths such as `/Users/...`
|
|
33
|
+
- `~/.hermes` paths unless the doc is explicitly explaining local setup
|
|
34
|
+
- API keys, tokens, cookies, OAuth files, or bearer strings
|
|
35
|
+
- phone numbers, private email addresses, and personal contact graphs
|
|
36
|
+
- client names, family names, or account names that are not already public
|
|
37
|
+
- revenue, health, or CRM details
|
|
38
|
+
- raw logs that include tool output from private systems
|
|
39
|
+
|
|
40
|
+
## Conversion Pattern
|
|
41
|
+
|
|
42
|
+
1. Identify the repeatable operator loop.
|
|
43
|
+
2. Strip private inputs and outputs.
|
|
44
|
+
3. Rewrite local paths as repo-relative examples.
|
|
45
|
+
4. Turn one-off instructions into a `When To Use` section and a short process.
|
|
46
|
+
5. Add concrete output requirements.
|
|
47
|
+
6. Run a secret and local-path scan before opening a PR.
|
|
48
|
+
|
|
49
|
+
## Example: Launch Handoff
|
|
50
|
+
|
|
51
|
+
Local Hermes prompt:
|
|
52
|
+
|
|
53
|
+
```text
|
|
54
|
+
Read my local workspace files and finalize launch copy.
|
|
55
|
+
```
|
|
56
|
+
|
|
57
|
+
the toolset-safe version:
|
|
58
|
+
|
|
59
|
+
```text
|
|
60
|
+
Use the public release pack under docs/releases/<version>/.
|
|
61
|
+
Return one X thread, one LinkedIn post, one recording checklist, and the missing assets list.
|
|
62
|
+
```
|
|
63
|
+
|
|
64
|
+
## Example: Quiet-Hours Operator Job
|
|
65
|
+
|
|
66
|
+
Local Hermes job:
|
|
67
|
+
|
|
68
|
+
```text
|
|
69
|
+
Run my private inbox, finance, and content checks overnight.
|
|
70
|
+
```
|
|
71
|
+
|
|
72
|
+
the toolset-safe version:
|
|
73
|
+
|
|
74
|
+
```text
|
|
75
|
+
Describe the scheduler policy, the quiet-hours window, the escalation rules, and the categories of checks. Do not include private data sources or credentials.
|
|
76
|
+
```
|
|
77
|
+
|
|
78
|
+
## Output Contract
|
|
79
|
+
|
|
80
|
+
Return:
|
|
81
|
+
|
|
82
|
+
- candidate the toolset skill name
|
|
83
|
+
- sanitized workflow summary
|
|
84
|
+
- required public inputs
|
|
85
|
+
- private inputs removed
|
|
86
|
+
- remaining risks
|
|
87
|
+
- files that should be created or updated
|