agim-cli 1.2.147 → 1.2.149

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 (350) hide show
  1. package/CHANGELOG.md +158 -0
  2. package/dist/core/skills/builtin/ECC_LICENSE +21 -0
  3. package/dist/core/skills/builtin/ECC_NOTICE.md +28 -0
  4. package/dist/core/skills/builtin/accessibility/SKILL.md +146 -0
  5. package/dist/core/skills/builtin/agent-eval/SKILL.md +145 -0
  6. package/dist/core/skills/builtin/agent-harness-construction/SKILL.md +73 -0
  7. package/dist/core/skills/builtin/agent-introspection-debugging/SKILL.md +153 -0
  8. package/dist/core/skills/builtin/agentic-engineering/SKILL.md +63 -0
  9. package/dist/core/skills/builtin/ai-first-engineering/SKILL.md +51 -0
  10. package/dist/core/skills/builtin/ai-regression-testing/SKILL.md +385 -0
  11. package/dist/core/skills/builtin/android-clean-architecture/SKILL.md +339 -0
  12. package/dist/core/skills/builtin/angular-developer/SKILL.md +154 -0
  13. package/dist/core/skills/builtin/angular-developer/references/angular-animations.md +160 -0
  14. package/dist/core/skills/builtin/angular-developer/references/angular-aria.md +410 -0
  15. package/dist/core/skills/builtin/angular-developer/references/cli.md +86 -0
  16. package/dist/core/skills/builtin/angular-developer/references/component-harnesses.md +59 -0
  17. package/dist/core/skills/builtin/angular-developer/references/component-styling.md +91 -0
  18. package/dist/core/skills/builtin/angular-developer/references/components.md +117 -0
  19. package/dist/core/skills/builtin/angular-developer/references/creating-services.md +97 -0
  20. package/dist/core/skills/builtin/angular-developer/references/data-resolvers.md +69 -0
  21. package/dist/core/skills/builtin/angular-developer/references/define-routes.md +67 -0
  22. package/dist/core/skills/builtin/angular-developer/references/defining-providers.md +72 -0
  23. package/dist/core/skills/builtin/angular-developer/references/di-fundamentals.md +120 -0
  24. package/dist/core/skills/builtin/angular-developer/references/e2e-testing.md +56 -0
  25. package/dist/core/skills/builtin/angular-developer/references/effects.md +83 -0
  26. package/dist/core/skills/builtin/angular-developer/references/hierarchical-injectors.md +43 -0
  27. package/dist/core/skills/builtin/angular-developer/references/host-elements.md +80 -0
  28. package/dist/core/skills/builtin/angular-developer/references/injection-context.md +63 -0
  29. package/dist/core/skills/builtin/angular-developer/references/inputs.md +101 -0
  30. package/dist/core/skills/builtin/angular-developer/references/linked-signal.md +59 -0
  31. package/dist/core/skills/builtin/angular-developer/references/loading-strategies.md +61 -0
  32. package/dist/core/skills/builtin/angular-developer/references/mcp.md +108 -0
  33. package/dist/core/skills/builtin/angular-developer/references/navigate-to-routes.md +69 -0
  34. package/dist/core/skills/builtin/angular-developer/references/outputs.md +86 -0
  35. package/dist/core/skills/builtin/angular-developer/references/reactive-forms.md +122 -0
  36. package/dist/core/skills/builtin/angular-developer/references/rendering-strategies.md +44 -0
  37. package/dist/core/skills/builtin/angular-developer/references/resource.md +77 -0
  38. package/dist/core/skills/builtin/angular-developer/references/route-animations.md +56 -0
  39. package/dist/core/skills/builtin/angular-developer/references/route-guards.md +52 -0
  40. package/dist/core/skills/builtin/angular-developer/references/router-lifecycle.md +45 -0
  41. package/dist/core/skills/builtin/angular-developer/references/router-testing.md +87 -0
  42. package/dist/core/skills/builtin/angular-developer/references/show-routes-with-outlets.md +68 -0
  43. package/dist/core/skills/builtin/angular-developer/references/signal-forms.md +795 -0
  44. package/dist/core/skills/builtin/angular-developer/references/signals-overview.md +94 -0
  45. package/dist/core/skills/builtin/angular-developer/references/tailwind-css.md +69 -0
  46. package/dist/core/skills/builtin/angular-developer/references/template-driven-forms.md +114 -0
  47. package/dist/core/skills/builtin/angular-developer/references/testing-fundamentals.md +65 -0
  48. package/dist/core/skills/builtin/api-connector-builder/SKILL.md +120 -0
  49. package/dist/core/skills/builtin/api-design/SKILL.md +523 -0
  50. package/dist/core/skills/builtin/architecture-decision-records/SKILL.md +179 -0
  51. package/dist/core/skills/builtin/article-writing/SKILL.md +79 -0
  52. package/dist/core/skills/builtin/automation-audit-ops/SKILL.md +142 -0
  53. package/dist/core/skills/builtin/autonomous-agent-harness/SKILL.md +273 -0
  54. package/dist/core/skills/builtin/autonomous-loops/SKILL.md +610 -0
  55. package/dist/core/skills/builtin/backend-patterns/SKILL.md +561 -0
  56. package/dist/core/skills/builtin/benchmark/SKILL.md +93 -0
  57. package/dist/core/skills/builtin/benchmark-optimization-loop/SKILL.md +69 -0
  58. package/dist/core/skills/builtin/blueprint/SKILL.md +105 -0
  59. package/dist/core/skills/builtin/browser-qa/SKILL.md +87 -0
  60. package/dist/core/skills/builtin/bun-runtime/SKILL.md +84 -0
  61. package/dist/core/skills/builtin/cisco-ios-patterns/SKILL.md +163 -0
  62. package/dist/core/skills/builtin/claude-devfleet/SKILL.md +111 -0
  63. package/dist/core/skills/builtin/click-path-audit/SKILL.md +244 -0
  64. package/dist/core/skills/builtin/clickhouse-io/SKILL.md +439 -0
  65. package/dist/core/skills/builtin/code-tour/SKILL.md +236 -0
  66. package/dist/core/skills/builtin/codebase-onboarding/SKILL.md +233 -0
  67. package/dist/core/skills/builtin/codehealth-mcp/SKILL.md +166 -0
  68. package/dist/core/skills/builtin/coding-standards/SKILL.md +550 -0
  69. package/dist/core/skills/builtin/compose-multiplatform-patterns/SKILL.md +299 -0
  70. package/dist/core/skills/builtin/config-gc/SKILL.md +119 -0
  71. package/dist/core/skills/builtin/content-engine/SKILL.md +131 -0
  72. package/dist/core/skills/builtin/content-hash-cache-pattern/SKILL.md +161 -0
  73. package/dist/core/skills/builtin/context-budget/SKILL.md +135 -0
  74. package/dist/core/skills/builtin/continuous-agent-loop/SKILL.md +45 -0
  75. package/dist/core/skills/builtin/continuous-learning/SKILL.md +131 -0
  76. package/dist/core/skills/builtin/continuous-learning/config.json +18 -0
  77. package/dist/core/skills/builtin/continuous-learning/evaluate-session.sh +69 -0
  78. package/dist/core/skills/builtin/continuous-learning-v2/SKILL.md +360 -0
  79. package/dist/core/skills/builtin/continuous-learning-v2/agents/observer-loop.sh +335 -0
  80. package/dist/core/skills/builtin/continuous-learning-v2/agents/observer.md +198 -0
  81. package/dist/core/skills/builtin/continuous-learning-v2/agents/session-guardian.sh +150 -0
  82. package/dist/core/skills/builtin/continuous-learning-v2/agents/start-observer.sh +248 -0
  83. package/dist/core/skills/builtin/continuous-learning-v2/config.json +8 -0
  84. package/dist/core/skills/builtin/continuous-learning-v2/hooks/observe.sh +498 -0
  85. package/dist/core/skills/builtin/continuous-learning-v2/scripts/detect-project.sh +322 -0
  86. package/dist/core/skills/builtin/continuous-learning-v2/scripts/instinct-cli.py +1914 -0
  87. package/dist/core/skills/builtin/continuous-learning-v2/scripts/lib/homunculus-dir.sh +31 -0
  88. package/dist/core/skills/builtin/continuous-learning-v2/scripts/migrate-homunculus.sh +62 -0
  89. package/dist/core/skills/builtin/continuous-learning-v2/scripts/test_parse_instinct.py +1045 -0
  90. package/dist/core/skills/builtin/cost-aware-llm-pipeline/SKILL.md +183 -0
  91. package/dist/core/skills/builtin/cost-tracking/SKILL.md +147 -0
  92. package/dist/core/skills/builtin/council/SKILL.md +203 -0
  93. package/dist/core/skills/builtin/cpp-coding-standards/SKILL.md +723 -0
  94. package/dist/core/skills/builtin/cpp-testing/SKILL.md +324 -0
  95. package/dist/core/skills/builtin/crosspost/SKILL.md +111 -0
  96. package/dist/core/skills/builtin/csharp-testing/SKILL.md +321 -0
  97. package/dist/core/skills/builtin/customs-trade-compliance/SKILL.md +263 -0
  98. package/dist/core/skills/builtin/dart-flutter-patterns/SKILL.md +563 -0
  99. package/dist/core/skills/builtin/dashboard-builder/SKILL.md +108 -0
  100. package/dist/core/skills/builtin/data-scraper-agent/SKILL.md +764 -0
  101. package/dist/core/skills/builtin/data-throughput-accelerator/SKILL.md +72 -0
  102. package/dist/core/skills/builtin/database-migrations/SKILL.md +429 -0
  103. package/dist/core/skills/builtin/deep-research/SKILL.md +159 -0
  104. package/dist/core/skills/builtin/defi-amm-security/SKILL.md +166 -0
  105. package/dist/core/skills/builtin/deployment-patterns/SKILL.md +427 -0
  106. package/dist/core/skills/builtin/design-system/SKILL.md +82 -0
  107. package/dist/core/skills/builtin/django-celery/SKILL.md +457 -0
  108. package/dist/core/skills/builtin/django-patterns/SKILL.md +734 -0
  109. package/dist/core/skills/builtin/django-security/SKILL.md +593 -0
  110. package/dist/core/skills/builtin/django-tdd/SKILL.md +729 -0
  111. package/dist/core/skills/builtin/django-verification/SKILL.md +469 -0
  112. package/dist/core/skills/builtin/dmux-workflows/SKILL.md +191 -0
  113. package/dist/core/skills/builtin/docker-patterns/SKILL.md +364 -0
  114. package/dist/core/skills/builtin/documentation-lookup/SKILL.md +90 -0
  115. package/dist/core/skills/builtin/dotnet-patterns/SKILL.md +321 -0
  116. package/dist/core/skills/builtin/dynamic-workflow-mode/SKILL.md +123 -0
  117. package/dist/core/skills/builtin/e2e-testing/SKILL.md +326 -0
  118. package/dist/core/skills/builtin/email-ops/SKILL.md +121 -0
  119. package/dist/core/skills/builtin/energy-procurement/SKILL.md +228 -0
  120. package/dist/core/skills/builtin/enterprise-agent-ops/SKILL.md +50 -0
  121. package/dist/core/skills/builtin/error-handling/SKILL.md +376 -0
  122. package/dist/core/skills/builtin/eval-harness/SKILL.md +270 -0
  123. package/dist/core/skills/builtin/evm-token-decimals/SKILL.md +130 -0
  124. package/dist/core/skills/builtin/exa-search/SKILL.md +107 -0
  125. package/dist/core/skills/builtin/fal-ai-media/SKILL.md +288 -0
  126. package/dist/core/skills/builtin/fastapi-patterns/SKILL.md +513 -0
  127. package/dist/core/skills/builtin/finance-billing-ops/SKILL.md +127 -0
  128. package/dist/core/skills/builtin/flox-environments/SKILL.md +496 -0
  129. package/dist/core/skills/builtin/flutter-dart-code-review/SKILL.md +435 -0
  130. package/dist/core/skills/builtin/foundation-models-on-device/SKILL.md +243 -0
  131. package/dist/core/skills/builtin/frontend-a11y/SKILL.md +445 -0
  132. package/dist/core/skills/builtin/frontend-design-direction/SKILL.md +92 -0
  133. package/dist/core/skills/builtin/frontend-patterns/SKILL.md +656 -0
  134. package/dist/core/skills/builtin/frontend-slides/SKILL.md +184 -0
  135. package/dist/core/skills/builtin/frontend-slides/STYLE_PRESETS.md +330 -0
  136. package/dist/core/skills/builtin/frontend-slides/animation-patterns.md +122 -0
  137. package/dist/core/skills/builtin/frontend-slides/html-template.md +419 -0
  138. package/dist/core/skills/builtin/frontend-slides/scripts/export-pdf.sh +418 -0
  139. package/dist/core/skills/builtin/frontend-slides/scripts/extract-pptx.py +96 -0
  140. package/dist/core/skills/builtin/frontend-slides/viewport-base.css +153 -0
  141. package/dist/core/skills/builtin/fsharp-testing/SKILL.md +280 -0
  142. package/dist/core/skills/builtin/gan-style-harness/SKILL.md +278 -0
  143. package/dist/core/skills/builtin/gateguard/SKILL.md +132 -0
  144. package/dist/core/skills/builtin/git-workflow/SKILL.md +715 -0
  145. package/dist/core/skills/builtin/github-ops/SKILL.md +144 -0
  146. package/dist/core/skills/builtin/golang-patterns/SKILL.md +674 -0
  147. package/dist/core/skills/builtin/golang-testing/SKILL.md +720 -0
  148. package/dist/core/skills/builtin/healthcare-cdss-patterns/SKILL.md +245 -0
  149. package/dist/core/skills/builtin/healthcare-emr-patterns/SKILL.md +159 -0
  150. package/dist/core/skills/builtin/healthcare-eval-harness/SKILL.md +207 -0
  151. package/dist/core/skills/builtin/healthcare-phi-compliance/SKILL.md +145 -0
  152. package/dist/core/skills/builtin/hermes-imports/SKILL.md +88 -0
  153. package/dist/core/skills/builtin/hexagonal-architecture/SKILL.md +276 -0
  154. package/dist/core/skills/builtin/hipaa-compliance/SKILL.md +78 -0
  155. package/dist/core/skills/builtin/hookify-rules/SKILL.md +128 -0
  156. package/dist/core/skills/builtin/inherit-legacy-style/SKILL.md +156 -0
  157. package/dist/core/skills/builtin/intent-driven-development/SKILL.md +360 -0
  158. package/dist/core/skills/builtin/inventory-demand-planning/SKILL.md +247 -0
  159. package/dist/core/skills/builtin/ios-icon-gen/SKILL.md +157 -0
  160. package/dist/core/skills/builtin/ios-icon-gen/scripts/generate_icons.swift +258 -0
  161. package/dist/core/skills/builtin/ios-icon-gen/scripts/iconify_gen.sh +235 -0
  162. package/dist/core/skills/builtin/iterative-retrieval/SKILL.md +211 -0
  163. package/dist/core/skills/builtin/java-coding-standards/SKILL.md +383 -0
  164. package/dist/core/skills/builtin/jira-integration/SKILL.md +302 -0
  165. package/dist/core/skills/builtin/jpa-patterns/SKILL.md +151 -0
  166. package/dist/core/skills/builtin/knowledge-ops/SKILL.md +154 -0
  167. package/dist/core/skills/builtin/kotlin-coroutines-flows/SKILL.md +284 -0
  168. package/dist/core/skills/builtin/kotlin-exposed-patterns/SKILL.md +719 -0
  169. package/dist/core/skills/builtin/kotlin-ktor-patterns/SKILL.md +689 -0
  170. package/dist/core/skills/builtin/kotlin-patterns/SKILL.md +711 -0
  171. package/dist/core/skills/builtin/kotlin-testing/SKILL.md +824 -0
  172. package/dist/core/skills/builtin/kubernetes-patterns/SKILL.md +755 -0
  173. package/dist/core/skills/builtin/laravel-patterns/SKILL.md +415 -0
  174. package/dist/core/skills/builtin/laravel-plugin-discovery/SKILL.md +229 -0
  175. package/dist/core/skills/builtin/laravel-security/SKILL.md +947 -0
  176. package/dist/core/skills/builtin/laravel-tdd/SKILL.md +674 -0
  177. package/dist/core/skills/builtin/laravel-verification/SKILL.md +179 -0
  178. package/dist/core/skills/builtin/latency-critical-systems/SKILL.md +73 -0
  179. package/dist/core/skills/builtin/lead-intelligence/SKILL.md +321 -0
  180. package/dist/core/skills/builtin/lead-intelligence/agents/enrichment-agent.md +85 -0
  181. package/dist/core/skills/builtin/lead-intelligence/agents/mutual-mapper.md +75 -0
  182. package/dist/core/skills/builtin/lead-intelligence/agents/outreach-drafter.md +98 -0
  183. package/dist/core/skills/builtin/lead-intelligence/agents/signal-scorer.md +60 -0
  184. package/dist/core/skills/builtin/liquid-glass-design/SKILL.md +279 -0
  185. package/dist/core/skills/builtin/llm-trading-agent-security/SKILL.md +146 -0
  186. package/dist/core/skills/builtin/logistics-exception-management/SKILL.md +222 -0
  187. package/dist/core/skills/builtin/make-interfaces-feel-better/SKILL.md +151 -0
  188. package/dist/core/skills/builtin/market-research/SKILL.md +75 -0
  189. package/dist/core/skills/builtin/marketing-campaign/SKILL.md +113 -0
  190. package/dist/core/skills/builtin/mcp-server-patterns/SKILL.md +69 -0
  191. package/dist/core/skills/builtin/messages-ops/SKILL.md +104 -0
  192. package/dist/core/skills/builtin/mle-workflow/SKILL.md +346 -0
  193. package/dist/core/skills/builtin/motion-advanced/SKILL.md +596 -0
  194. package/dist/core/skills/builtin/motion-foundations/SKILL.md +299 -0
  195. package/dist/core/skills/builtin/motion-patterns/SKILL.md +434 -0
  196. package/dist/core/skills/builtin/motion-ui/SKILL.md +575 -0
  197. package/dist/core/skills/builtin/mysql-patterns/SKILL.md +412 -0
  198. package/dist/core/skills/builtin/nanoclaw-repl/SKILL.md +33 -0
  199. package/dist/core/skills/builtin/nestjs-patterns/SKILL.md +230 -0
  200. package/dist/core/skills/builtin/netmiko-ssh-automation/SKILL.md +173 -0
  201. package/dist/core/skills/builtin/network-bgp-diagnostics/SKILL.md +167 -0
  202. package/dist/core/skills/builtin/network-config-validation/SKILL.md +210 -0
  203. package/dist/core/skills/builtin/network-interface-health/SKILL.md +152 -0
  204. package/dist/core/skills/builtin/nextjs-turbopack/SKILL.md +57 -0
  205. package/dist/core/skills/builtin/nodejs-keccak256/SKILL.md +102 -0
  206. package/dist/core/skills/builtin/nutrient-document-processing/SKILL.md +167 -0
  207. package/dist/core/skills/builtin/nuxt4-patterns/SKILL.md +100 -0
  208. package/dist/core/skills/builtin/openclaw-persona-forge/SKILL.md +288 -0
  209. package/dist/core/skills/builtin/openclaw-persona-forge/gacha.py +224 -0
  210. package/dist/core/skills/builtin/openclaw-persona-forge/gacha.sh +5 -0
  211. package/dist/core/skills/builtin/openclaw-persona-forge/references/avatar-style.md +124 -0
  212. package/dist/core/skills/builtin/openclaw-persona-forge/references/boundary-rules.md +53 -0
  213. package/dist/core/skills/builtin/openclaw-persona-forge/references/error-handling.md +53 -0
  214. package/dist/core/skills/builtin/openclaw-persona-forge/references/identity-tension.md +48 -0
  215. package/dist/core/skills/builtin/openclaw-persona-forge/references/naming-system.md +39 -0
  216. package/dist/core/skills/builtin/openclaw-persona-forge/references/output-template.md +166 -0
  217. package/dist/core/skills/builtin/opensource-pipeline/SKILL.md +255 -0
  218. package/dist/core/skills/builtin/orch-add-feature/SKILL.md +44 -0
  219. package/dist/core/skills/builtin/orch-build-mvp/SKILL.md +48 -0
  220. package/dist/core/skills/builtin/orch-change-feature/SKILL.md +42 -0
  221. package/dist/core/skills/builtin/orch-fix-defect/SKILL.md +42 -0
  222. package/dist/core/skills/builtin/orch-pipeline/SKILL.md +120 -0
  223. package/dist/core/skills/builtin/orch-refine-code/SKILL.md +43 -0
  224. package/dist/core/skills/builtin/parallel-execution-optimizer/SKILL.md +72 -0
  225. package/dist/core/skills/builtin/perl-patterns/SKILL.md +504 -0
  226. package/dist/core/skills/builtin/perl-security/SKILL.md +503 -0
  227. package/dist/core/skills/builtin/perl-testing/SKILL.md +475 -0
  228. package/dist/core/skills/builtin/plan-orchestrate/SKILL.md +262 -0
  229. package/dist/core/skills/builtin/plankton-code-quality/SKILL.md +236 -0
  230. package/dist/core/skills/builtin/postgres-patterns/SKILL.md +147 -0
  231. package/dist/core/skills/builtin/prediction-market-oracle-research/SKILL.md +63 -0
  232. package/dist/core/skills/builtin/prediction-market-risk-review/SKILL.md +60 -0
  233. package/dist/core/skills/builtin/prisma-patterns/SKILL.md +371 -0
  234. package/dist/core/skills/builtin/product-capability/SKILL.md +141 -0
  235. package/dist/core/skills/builtin/product-lens/SKILL.md +92 -0
  236. package/dist/core/skills/builtin/production-audit/SKILL.md +206 -0
  237. package/dist/core/skills/builtin/production-scheduling/SKILL.md +238 -0
  238. package/dist/core/skills/builtin/prompt-optimizer/SKILL.md +398 -0
  239. package/dist/core/skills/builtin/python-patterns/SKILL.md +750 -0
  240. package/dist/core/skills/builtin/python-testing/SKILL.md +816 -0
  241. package/dist/core/skills/builtin/pytorch-patterns/SKILL.md +396 -0
  242. package/dist/core/skills/builtin/quality-nonconformance/SKILL.md +260 -0
  243. package/dist/core/skills/builtin/quarkus-patterns/SKILL.md +722 -0
  244. package/dist/core/skills/builtin/quarkus-security/SKILL.md +467 -0
  245. package/dist/core/skills/builtin/quarkus-tdd/SKILL.md +811 -0
  246. package/dist/core/skills/builtin/quarkus-verification/SKILL.md +479 -0
  247. package/dist/core/skills/builtin/ralphinho-rfc-pipeline/SKILL.md +67 -0
  248. package/dist/core/skills/builtin/react-patterns/SKILL.md +341 -0
  249. package/dist/core/skills/builtin/react-performance/SKILL.md +574 -0
  250. package/dist/core/skills/builtin/react-testing/SKILL.md +423 -0
  251. package/dist/core/skills/builtin/recsys-pipeline-architect/SKILL.md +114 -0
  252. package/dist/core/skills/builtin/recursive-decision-ledger/SKILL.md +79 -0
  253. package/dist/core/skills/builtin/redis-patterns/SKILL.md +403 -0
  254. package/dist/core/skills/builtin/regex-vs-llm-structured-text/SKILL.md +220 -0
  255. package/dist/core/skills/builtin/repo-scan/SKILL.md +78 -0
  256. package/dist/core/skills/builtin/research-ops/SKILL.md +112 -0
  257. package/dist/core/skills/builtin/returns-reverse-logistics/SKILL.md +240 -0
  258. package/dist/core/skills/builtin/rules-distill/SKILL.md +264 -0
  259. package/dist/core/skills/builtin/rules-distill/scripts/scan-rules.sh +58 -0
  260. package/dist/core/skills/builtin/rules-distill/scripts/scan-skills.sh +129 -0
  261. package/dist/core/skills/builtin/rust-patterns/SKILL.md +499 -0
  262. package/dist/core/skills/builtin/rust-testing/SKILL.md +500 -0
  263. package/dist/core/skills/builtin/safety-guard/SKILL.md +75 -0
  264. package/dist/core/skills/builtin/santa-method/SKILL.md +306 -0
  265. package/dist/core/skills/builtin/scientific-db-pubmed-database/SKILL.md +175 -0
  266. package/dist/core/skills/builtin/scientific-db-uspto-database/SKILL.md +177 -0
  267. package/dist/core/skills/builtin/scientific-pkg-gget/SKILL.md +166 -0
  268. package/dist/core/skills/builtin/scientific-thinking-literature-review/SKILL.md +192 -0
  269. package/dist/core/skills/builtin/scientific-thinking-scholar-evaluation/SKILL.md +160 -0
  270. package/dist/core/skills/builtin/search-first/SKILL.md +182 -0
  271. package/dist/core/skills/builtin/security-bounty-hunter/SKILL.md +99 -0
  272. package/dist/core/skills/builtin/security-review/SKILL.md +503 -0
  273. package/dist/core/skills/builtin/security-review/cloud-infrastructure-security.md +361 -0
  274. package/dist/core/skills/builtin/security-scan/SKILL.md +165 -0
  275. package/dist/core/skills/builtin/seo/SKILL.md +154 -0
  276. package/dist/core/skills/builtin/skill-comply/SKILL.md +58 -0
  277. package/dist/core/skills/builtin/skill-comply/fixtures/compliant_trace.jsonl +5 -0
  278. package/dist/core/skills/builtin/skill-comply/fixtures/noncompliant_trace.jsonl +3 -0
  279. package/dist/core/skills/builtin/skill-comply/fixtures/tdd_spec.yaml +44 -0
  280. package/dist/core/skills/builtin/skill-comply/prompts/classifier.md +24 -0
  281. package/dist/core/skills/builtin/skill-comply/prompts/scenario_generator.md +62 -0
  282. package/dist/core/skills/builtin/skill-comply/prompts/spec_generator.md +42 -0
  283. package/dist/core/skills/builtin/skill-comply/pyproject.toml +15 -0
  284. package/dist/core/skills/builtin/skill-comply/scripts/__init__.py +0 -0
  285. package/dist/core/skills/builtin/skill-comply/scripts/classifier.py +85 -0
  286. package/dist/core/skills/builtin/skill-comply/scripts/grader.py +124 -0
  287. package/dist/core/skills/builtin/skill-comply/scripts/parser.py +107 -0
  288. package/dist/core/skills/builtin/skill-comply/scripts/report.py +170 -0
  289. package/dist/core/skills/builtin/skill-comply/scripts/run.py +127 -0
  290. package/dist/core/skills/builtin/skill-comply/scripts/runner.py +186 -0
  291. package/dist/core/skills/builtin/skill-comply/scripts/scenario_generator.py +70 -0
  292. package/dist/core/skills/builtin/skill-comply/scripts/spec_generator.py +72 -0
  293. package/dist/core/skills/builtin/skill-comply/scripts/utils.py +13 -0
  294. package/dist/core/skills/builtin/skill-comply/tests/test_grader.py +197 -0
  295. package/dist/core/skills/builtin/skill-comply/tests/test_parser.py +90 -0
  296. package/dist/core/skills/builtin/skill-comply/tests/test_runner.py +172 -0
  297. package/dist/core/skills/builtin/skill-scout/SKILL.md +140 -0
  298. package/dist/core/skills/builtin/skill-stocktake/SKILL.md +194 -0
  299. package/dist/core/skills/builtin/skill-stocktake/scripts/quick-diff.sh +87 -0
  300. package/dist/core/skills/builtin/skill-stocktake/scripts/save-results.sh +56 -0
  301. package/dist/core/skills/builtin/skill-stocktake/scripts/scan.sh +170 -0
  302. package/dist/core/skills/builtin/springboot-patterns/SKILL.md +314 -0
  303. package/dist/core/skills/builtin/springboot-security/SKILL.md +272 -0
  304. package/dist/core/skills/builtin/springboot-tdd/SKILL.md +158 -0
  305. package/dist/core/skills/builtin/springboot-verification/SKILL.md +231 -0
  306. package/dist/core/skills/builtin/strategic-compact/SKILL.md +135 -0
  307. package/dist/core/skills/builtin/swift-actor-persistence/SKILL.md +143 -0
  308. package/dist/core/skills/builtin/swift-concurrency-6-2/SKILL.md +216 -0
  309. package/dist/core/skills/builtin/swift-protocol-di-testing/SKILL.md +190 -0
  310. package/dist/core/skills/builtin/swiftui-patterns/SKILL.md +259 -0
  311. package/dist/core/skills/builtin/tdd-workflow/SKILL.md +463 -0
  312. package/dist/core/skills/builtin/team-agent-orchestration/SKILL.md +110 -0
  313. package/dist/core/skills/builtin/team-builder/SKILL.md +168 -0
  314. package/dist/core/skills/builtin/terminal-ops/SKILL.md +109 -0
  315. package/dist/core/skills/builtin/tinystruct-patterns/SKILL.md +203 -0
  316. package/dist/core/skills/builtin/tinystruct-patterns/references/architecture.md +90 -0
  317. package/dist/core/skills/builtin/tinystruct-patterns/references/data-handling.md +60 -0
  318. package/dist/core/skills/builtin/tinystruct-patterns/references/database.md +99 -0
  319. package/dist/core/skills/builtin/tinystruct-patterns/references/routing.md +64 -0
  320. package/dist/core/skills/builtin/tinystruct-patterns/references/system-usage.md +97 -0
  321. package/dist/core/skills/builtin/tinystruct-patterns/references/testing.md +72 -0
  322. package/dist/core/skills/builtin/token-budget-advisor/SKILL.md +133 -0
  323. package/dist/core/skills/builtin/ui-demo/SKILL.md +465 -0
  324. package/dist/core/skills/builtin/ui-to-vue/SKILL.md +134 -0
  325. package/dist/core/skills/builtin/uncloud/SKILL.md +343 -0
  326. package/dist/core/skills/builtin/unified-notifications-ops/SKILL.md +187 -0
  327. package/dist/core/skills/builtin/verification-loop/SKILL.md +126 -0
  328. package/dist/core/skills/builtin/video-editing/SKILL.md +310 -0
  329. package/dist/core/skills/builtin/videodb/SKILL.md +374 -0
  330. package/dist/core/skills/builtin/videodb/reference/api-reference.md +550 -0
  331. package/dist/core/skills/builtin/videodb/reference/capture-reference.md +407 -0
  332. package/dist/core/skills/builtin/videodb/reference/capture.md +101 -0
  333. package/dist/core/skills/builtin/videodb/reference/editor.md +443 -0
  334. package/dist/core/skills/builtin/videodb/reference/generative.md +331 -0
  335. package/dist/core/skills/builtin/videodb/reference/rtstream-reference.md +564 -0
  336. package/dist/core/skills/builtin/videodb/reference/rtstream.md +65 -0
  337. package/dist/core/skills/builtin/videodb/reference/search.md +230 -0
  338. package/dist/core/skills/builtin/videodb/reference/streaming.md +406 -0
  339. package/dist/core/skills/builtin/videodb/reference/use-cases.md +118 -0
  340. package/dist/core/skills/builtin/videodb/scripts/ws_listener.py +282 -0
  341. package/dist/core/skills/builtin/visa-doc-translate/README.md +86 -0
  342. package/dist/core/skills/builtin/visa-doc-translate/SKILL.md +117 -0
  343. package/dist/core/skills/builtin/vite-patterns/SKILL.md +449 -0
  344. package/dist/core/skills/builtin/windows-desktop-e2e/SKILL.md +887 -0
  345. package/dist/core/skills/builtin/x-api/SKILL.md +234 -0
  346. package/dist/core/skills/loader.d.ts +23 -12
  347. package/dist/core/skills/loader.d.ts.map +1 -1
  348. package/dist/core/skills/loader.js +105 -2
  349. package/dist/core/skills/loader.js.map +1 -1
  350. package/package.json +1 -1
@@ -0,0 +1,245 @@
1
+ ---
2
+ name: healthcare-cdss-patterns
3
+ description: [ECC] Clinical Decision Support System (CDSS) development patterns. Drug interaction checking, dose validation, clinical scoring (NEWS2, qSOFA), alert severity classification, and integration into EMR workflows.
4
+ origin: Health1 Super Speciality Hospitals — contributed by Dr. Keyur Patel
5
+ version: "1.0.0"
6
+ ---
7
+
8
+ # Healthcare CDSS Development Patterns
9
+
10
+ Patterns for building Clinical Decision Support Systems that integrate into EMR workflows. CDSS modules are patient safety critical — zero tolerance for false negatives.
11
+
12
+ ## When to Use
13
+
14
+ - Implementing drug interaction checking
15
+ - Building dose validation engines
16
+ - Implementing clinical scoring systems (NEWS2, qSOFA, APACHE, GCS)
17
+ - Designing alert systems for abnormal clinical values
18
+ - Building medication order entry with safety checks
19
+ - Integrating lab result interpretation with clinical context
20
+
21
+ ## How It Works
22
+
23
+ The CDSS engine is a **pure function library with zero side effects**. Input clinical data, output alerts. This makes it fully testable.
24
+
25
+ Three primary modules:
26
+
27
+ 1. **`checkInteractions(newDrug, currentMeds, allergies)`** — Checks a new drug against current medications and known allergies. Returns severity-sorted `InteractionAlert[]`. Uses `DrugInteractionPair` data model.
28
+ 2. **`validateDose(drug, dose, route, weight, age, renalFunction)`** — Validates a prescribed dose against weight-based, age-adjusted, and renal-adjusted rules. Returns `DoseValidationResult`.
29
+ 3. **`calculateNEWS2(vitals)`** — National Early Warning Score 2 from `NEWS2Input`. Returns `NEWS2Result` with total score, risk level, and escalation guidance.
30
+
31
+ ```
32
+ EMR UI
33
+ ↓ (user enters data)
34
+ CDSS Engine (pure functions, no side effects)
35
+ ├── Drug Interaction Checker
36
+ ├── Dose Validator
37
+ ├── Clinical Scoring (NEWS2, qSOFA, etc.)
38
+ └── Alert Classifier
39
+ ↓ (returns alerts)
40
+ EMR UI (displays alerts inline, blocks if critical)
41
+ ```
42
+
43
+ ### Drug Interaction Checking
44
+
45
+ ```typescript
46
+ interface DrugInteractionPair {
47
+ drugA: string; // generic name
48
+ drugB: string; // generic name
49
+ severity: 'critical' | 'major' | 'minor';
50
+ mechanism: string;
51
+ clinicalEffect: string;
52
+ recommendation: string;
53
+ }
54
+
55
+ function checkInteractions(
56
+ newDrug: string,
57
+ currentMedications: string[],
58
+ allergyList: string[]
59
+ ): InteractionAlert[] {
60
+ if (!newDrug) return [];
61
+ const alerts: InteractionAlert[] = [];
62
+ for (const current of currentMedications) {
63
+ const interaction = findInteraction(newDrug, current);
64
+ if (interaction) {
65
+ alerts.push({ severity: interaction.severity, pair: [newDrug, current],
66
+ message: interaction.clinicalEffect, recommendation: interaction.recommendation });
67
+ }
68
+ }
69
+ for (const allergy of allergyList) {
70
+ if (isCrossReactive(newDrug, allergy)) {
71
+ alerts.push({ severity: 'critical', pair: [newDrug, allergy],
72
+ message: `Cross-reactivity with documented allergy: ${allergy}`,
73
+ recommendation: 'Do not prescribe without allergy consultation' });
74
+ }
75
+ }
76
+ return alerts.sort((a, b) => severityOrder(a.severity) - severityOrder(b.severity));
77
+ }
78
+ ```
79
+
80
+ Interaction pairs must be **bidirectional**: if Drug A interacts with Drug B, then Drug B interacts with Drug A.
81
+
82
+ ### Dose Validation
83
+
84
+ ```typescript
85
+ interface DoseValidationResult {
86
+ valid: boolean;
87
+ message: string;
88
+ suggestedRange: { min: number; max: number; unit: string } | null;
89
+ factors: string[];
90
+ }
91
+
92
+ function validateDose(
93
+ drug: string,
94
+ dose: number,
95
+ route: 'oral' | 'iv' | 'im' | 'sc' | 'topical',
96
+ patientWeight?: number,
97
+ patientAge?: number,
98
+ renalFunction?: number
99
+ ): DoseValidationResult {
100
+ const rules = getDoseRules(drug, route);
101
+ if (!rules) return { valid: true, message: 'No validation rules available', suggestedRange: null, factors: [] };
102
+ const factors: string[] = [];
103
+
104
+ // SAFETY: if rules require weight but weight missing, BLOCK (not pass)
105
+ if (rules.weightBased) {
106
+ if (!patientWeight || patientWeight <= 0) {
107
+ return { valid: false, message: `Weight required for ${drug} (mg/kg drug)`,
108
+ suggestedRange: null, factors: ['weight_missing'] };
109
+ }
110
+ factors.push('weight');
111
+ const maxDose = rules.maxPerKg * patientWeight;
112
+ if (dose > maxDose) {
113
+ return { valid: false, message: `Dose exceeds max for ${patientWeight}kg`,
114
+ suggestedRange: { min: rules.minPerKg * patientWeight, max: maxDose, unit: rules.unit }, factors };
115
+ }
116
+ }
117
+
118
+ // Age-based adjustment (when rules define age brackets and age is provided)
119
+ if (rules.ageAdjusted && patientAge !== undefined) {
120
+ factors.push('age');
121
+ const ageMax = rules.getAgeAdjustedMax(patientAge);
122
+ if (dose > ageMax) {
123
+ return { valid: false, message: `Exceeds age-adjusted max for ${patientAge}yr`,
124
+ suggestedRange: { min: rules.typicalMin, max: ageMax, unit: rules.unit }, factors };
125
+ }
126
+ }
127
+
128
+ // Renal adjustment (when rules define eGFR brackets and eGFR is provided)
129
+ if (rules.renalAdjusted && renalFunction !== undefined) {
130
+ factors.push('renal');
131
+ const renalMax = rules.getRenalAdjustedMax(renalFunction);
132
+ if (dose > renalMax) {
133
+ return { valid: false, message: `Exceeds renal-adjusted max for eGFR ${renalFunction}`,
134
+ suggestedRange: { min: rules.typicalMin, max: renalMax, unit: rules.unit }, factors };
135
+ }
136
+ }
137
+
138
+ // Absolute max
139
+ if (dose > rules.absoluteMax) {
140
+ return { valid: false, message: `Exceeds absolute max ${rules.absoluteMax}${rules.unit}`,
141
+ suggestedRange: { min: rules.typicalMin, max: rules.absoluteMax, unit: rules.unit },
142
+ factors: [...factors, 'absolute_max'] };
143
+ }
144
+ return { valid: true, message: 'Within range',
145
+ suggestedRange: { min: rules.typicalMin, max: rules.typicalMax, unit: rules.unit }, factors };
146
+ }
147
+ ```
148
+
149
+ ### Clinical Scoring: NEWS2
150
+
151
+ ```typescript
152
+ interface NEWS2Input {
153
+ respiratoryRate: number; oxygenSaturation: number; supplementalOxygen: boolean;
154
+ temperature: number; systolicBP: number; heartRate: number;
155
+ consciousness: 'alert' | 'voice' | 'pain' | 'unresponsive';
156
+ }
157
+ interface NEWS2Result {
158
+ total: number; // 0-20
159
+ risk: 'low' | 'low-medium' | 'medium' | 'high';
160
+ components: Record<string, number>;
161
+ escalation: string;
162
+ }
163
+ ```
164
+
165
+ Scoring tables must match the Royal College of Physicians specification exactly.
166
+
167
+ ### Alert Severity and UI Behavior
168
+
169
+ | Severity | UI Behavior | Clinician Action Required |
170
+ |----------|-------------|--------------------------|
171
+ | Critical | Block action. Non-dismissable modal. Red. | Must document override reason to proceed |
172
+ | Major | Warning banner inline. Orange. | Must acknowledge before proceeding |
173
+ | Minor | Info note inline. Yellow. | Awareness only, no action required |
174
+
175
+ Critical alerts must NEVER be auto-dismissed or implemented as toast notifications. Override reasons must be stored in the audit trail.
176
+
177
+ ### Testing CDSS (Zero Tolerance for False Negatives)
178
+
179
+ ```typescript
180
+ describe('CDSS — Patient Safety', () => {
181
+ INTERACTION_PAIRS.forEach(({ drugA, drugB, severity }) => {
182
+ it(`detects ${drugA} + ${drugB} (${severity})`, () => {
183
+ const alerts = checkInteractions(drugA, [drugB], []);
184
+ expect(alerts.length).toBeGreaterThan(0);
185
+ expect(alerts[0].severity).toBe(severity);
186
+ });
187
+ it(`detects ${drugB} + ${drugA} (reverse)`, () => {
188
+ const alerts = checkInteractions(drugB, [drugA], []);
189
+ expect(alerts.length).toBeGreaterThan(0);
190
+ });
191
+ });
192
+ it('blocks mg/kg drug when weight is missing', () => {
193
+ const result = validateDose('gentamicin', 300, 'iv');
194
+ expect(result.valid).toBe(false);
195
+ expect(result.factors).toContain('weight_missing');
196
+ });
197
+ it('handles malformed drug data gracefully', () => {
198
+ expect(() => checkInteractions('', [], [])).not.toThrow();
199
+ });
200
+ });
201
+ ```
202
+
203
+ Pass criteria: 100%. A single missed interaction is a patient safety event.
204
+
205
+ ### Anti-Patterns
206
+
207
+ - Making CDSS checks optional or skippable without documented reason
208
+ - Implementing interaction checks as toast notifications
209
+ - Using `any` types for drug or clinical data
210
+ - Hardcoding interaction pairs instead of using a maintainable data structure
211
+ - Silently catching errors in CDSS engine (must surface failures loudly)
212
+ - Skipping weight-based validation when weight is not available (must block, not pass)
213
+
214
+ ## Examples
215
+
216
+ ### Example 1: Drug Interaction Check
217
+
218
+ ```typescript
219
+ const alerts = checkInteractions('warfarin', ['aspirin', 'metformin'], ['penicillin']);
220
+ // [{ severity: 'critical', pair: ['warfarin', 'aspirin'],
221
+ // message: 'Increased bleeding risk', recommendation: 'Avoid combination' }]
222
+ ```
223
+
224
+ ### Example 2: Dose Validation
225
+
226
+ ```typescript
227
+ const ok = validateDose('paracetamol', 1000, 'oral', 70, 45);
228
+ // { valid: true, suggestedRange: { min: 500, max: 4000, unit: 'mg' } }
229
+
230
+ const bad = validateDose('paracetamol', 5000, 'oral', 70, 45);
231
+ // { valid: false, message: 'Exceeds absolute max 4000mg' }
232
+
233
+ const noWeight = validateDose('gentamicin', 300, 'iv');
234
+ // { valid: false, factors: ['weight_missing'] }
235
+ ```
236
+
237
+ ### Example 3: NEWS2 Scoring
238
+
239
+ ```typescript
240
+ const result = calculateNEWS2({
241
+ respiratoryRate: 24, oxygenSaturation: 93, supplementalOxygen: true,
242
+ temperature: 38.5, systolicBP: 100, heartRate: 110, consciousness: 'voice'
243
+ });
244
+ // { total: 13, risk: 'high', escalation: 'Urgent clinical review. Consider ICU.' }
245
+ ```
@@ -0,0 +1,159 @@
1
+ ---
2
+ name: healthcare-emr-patterns
3
+ description: [ECC] EMR/EHR development patterns for healthcare applications. Clinical safety, encounter workflows, prescription generation, clinical decision support integration, and accessibility-first UI for medical data entry.
4
+ origin: Health1 Super Speciality Hospitals — contributed by Dr. Keyur Patel
5
+ version: "1.0.0"
6
+ ---
7
+
8
+ # Healthcare EMR Development Patterns
9
+
10
+ Patterns for building Electronic Medical Record (EMR) and Electronic Health Record (EHR) systems. Prioritizes patient safety, clinical accuracy, and practitioner efficiency.
11
+
12
+ ## When to Use
13
+
14
+ - Building patient encounter workflows (complaint, exam, diagnosis, prescription)
15
+ - Implementing clinical note-taking (structured + free text + voice-to-text)
16
+ - Designing prescription/medication modules with drug interaction checking
17
+ - Integrating Clinical Decision Support Systems (CDSS)
18
+ - Building lab result displays with reference range highlighting
19
+ - Implementing audit trails for clinical data
20
+ - Designing healthcare-accessible UIs for clinical data entry
21
+
22
+ ## How It Works
23
+
24
+ ### Patient Safety First
25
+
26
+ Every design decision must be evaluated against: "Could this harm a patient?"
27
+
28
+ - Drug interactions MUST alert, not silently pass
29
+ - Abnormal lab values MUST be visually flagged
30
+ - Critical vitals MUST trigger escalation workflows
31
+ - No clinical data modification without audit trail
32
+
33
+ ### Single-Page Encounter Flow
34
+
35
+ Clinical encounters should flow vertically on a single page — no tab switching:
36
+
37
+ ```
38
+ Patient Header (sticky — always visible)
39
+ ├── Demographics, allergies, active medications
40
+
41
+ Encounter Flow (vertical scroll)
42
+ ├── 1. Chief Complaint (structured templates + free text)
43
+ ├── 2. History of Present Illness
44
+ ├── 3. Physical Examination (system-wise)
45
+ ├── 4. Vitals (auto-trigger clinical scoring)
46
+ ├── 5. Diagnosis (ICD-10/SNOMED search)
47
+ ├── 6. Medications (drug DB + interaction check)
48
+ ├── 7. Investigations (lab/radiology orders)
49
+ ├── 8. Plan & Follow-up
50
+ └── 9. Sign / Lock / Print
51
+ ```
52
+
53
+ ### Smart Template System
54
+
55
+ ```typescript
56
+ interface ClinicalTemplate {
57
+ id: string;
58
+ name: string; // e.g., "Chest Pain"
59
+ chips: string[]; // clickable symptom chips
60
+ requiredFields: string[]; // mandatory data points
61
+ redFlags: string[]; // triggers non-dismissable alert
62
+ icdSuggestions: string[]; // pre-mapped diagnosis codes
63
+ }
64
+ ```
65
+
66
+ Red flags in any template must trigger a visible, non-dismissable alert — NOT a toast notification.
67
+
68
+ ### Medication Safety Pattern
69
+
70
+ ```
71
+ User selects drug
72
+ → Check current medications for interactions
73
+ → Check encounter medications for interactions
74
+ → Check patient allergies
75
+ → Validate dose against weight/age/renal function
76
+ → If CRITICAL interaction: BLOCK prescribing entirely
77
+ → Clinician must document override reason to proceed past a block
78
+ → If MAJOR interaction: display warning, require acknowledgment
79
+ → Log all alerts and override reasons in audit trail
80
+ ```
81
+
82
+ Critical interactions **block prescribing by default**. The clinician must explicitly override with a documented reason stored in the audit trail. The system never silently allows a critical interaction.
83
+
84
+ ### Locked Encounter Pattern
85
+
86
+ Once a clinical encounter is signed:
87
+ - No edits allowed — only an addendum (a separate linked record)
88
+ - Both original and addendum appear in the patient timeline
89
+ - Audit trail captures who signed, when, and any addendum records
90
+
91
+ ### UI Patterns for Clinical Data
92
+
93
+ **Vitals Display:** Current values with normal range highlighting (green/yellow/red), trend arrows vs previous, clinical scoring auto-calculated (NEWS2, qSOFA), escalation guidance inline.
94
+
95
+ **Lab Results Display:** Normal range highlighting, previous value comparison, critical values with non-dismissable alert, collection/analysis timestamps, pending orders with expected turnaround.
96
+
97
+ **Prescription PDF:** One-click generation with patient demographics, allergies, diagnosis, drug details (generic + brand, dose, route, frequency, duration), clinician signature block.
98
+
99
+ ### Accessibility for Healthcare
100
+
101
+ Healthcare UIs have stricter requirements than typical web apps:
102
+ - 4.5:1 minimum contrast (WCAG AA) — clinicians work in varied lighting
103
+ - Large touch targets (44x44px minimum) — for gloved/rushed interaction
104
+ - Keyboard navigation — for power users entering data rapidly
105
+ - No color-only indicators — always pair color with text/icon (colorblind clinicians)
106
+ - Screen reader labels on all form fields
107
+ - No auto-dismissing toasts for clinical alerts — clinician must actively acknowledge
108
+
109
+ ### Anti-Patterns
110
+
111
+ - Storing clinical data in browser localStorage
112
+ - Silent failures in drug interaction checking
113
+ - Dismissable toasts for critical clinical alerts
114
+ - Tab-based encounter UIs that fragment the clinical workflow
115
+ - Allowing edits to signed/locked encounters
116
+ - Displaying clinical data without audit trail
117
+ - Using `any` type for clinical data structures
118
+
119
+ ## Examples
120
+
121
+ ### Example 1: Patient Encounter Flow
122
+
123
+ ```
124
+ Doctor opens encounter for Patient #4521
125
+ → Sticky header shows: "Rajesh M, 58M, Allergies: Penicillin, Active Meds: Metformin 500mg"
126
+ → Chief Complaint: selects "Chest Pain" template
127
+ → Clicks chips: "substernal", "radiating to left arm", "crushing"
128
+ → Red flag "crushing substernal chest pain" triggers non-dismissable alert
129
+ → Examination: CVS system — "S1 S2 normal, no murmur"
130
+ → Vitals: HR 110, BP 90/60, SpO2 94%
131
+ → NEWS2 auto-calculates: score 8, risk HIGH, escalation alert shown
132
+ → Diagnosis: searches "ACS" → selects ICD-10 I21.9
133
+ → Medications: selects Aspirin 300mg
134
+ → CDSS checks against Metformin: no interaction
135
+ → Signs encounter → locked, addendum-only from this point
136
+ ```
137
+
138
+ ### Example 2: Medication Safety Workflow
139
+
140
+ ```
141
+ Doctor prescribes Warfarin for Patient #4521
142
+ → CDSS detects: Warfarin + Aspirin = CRITICAL interaction
143
+ → UI: red non-dismissable modal blocks prescribing
144
+ → Doctor clicks "Override with reason"
145
+ → Types: "Benefits outweigh risks — monitored INR protocol"
146
+ → Override reason + alert stored in audit trail
147
+ → Prescription proceeds with documented override
148
+ ```
149
+
150
+ ### Example 3: Locked Encounter + Addendum
151
+
152
+ ```
153
+ Encounter #E-2024-0891 signed by Dr. Shah at 14:30
154
+ → All fields locked — no edit buttons visible
155
+ → "Add Addendum" button available
156
+ → Dr. Shah clicks addendum, adds: "Lab results received — Troponin elevated"
157
+ → New record E-2024-0891-A1 linked to original
158
+ → Timeline shows both: original encounter + addendum with timestamps
159
+ ```
@@ -0,0 +1,207 @@
1
+ ---
2
+ name: healthcare-eval-harness
3
+ description: [ECC] 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
+ ```