create-hq 6.0.0 → 7.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (315) hide show
  1. package/dist/__tests__/scaffold.test.d.ts +2 -0
  2. package/dist/__tests__/scaffold.test.d.ts.map +1 -0
  3. package/dist/__tests__/scaffold.test.js +150 -0
  4. package/dist/__tests__/scaffold.test.js.map +1 -0
  5. package/dist/cloud-sync.d.ts +11 -0
  6. package/dist/cloud-sync.d.ts.map +1 -0
  7. package/dist/cloud-sync.js +25 -0
  8. package/dist/cloud-sync.js.map +1 -0
  9. package/dist/deps.d.ts.map +1 -1
  10. package/dist/deps.js +7 -1
  11. package/dist/deps.js.map +1 -1
  12. package/dist/fetch-template.d.ts +14 -0
  13. package/dist/fetch-template.d.ts.map +1 -0
  14. package/dist/fetch-template.js +136 -0
  15. package/dist/fetch-template.js.map +1 -0
  16. package/dist/index.js +8 -7
  17. package/dist/index.js.map +1 -1
  18. package/dist/scaffold.d.ts +2 -2
  19. package/dist/scaffold.d.ts.map +1 -1
  20. package/dist/scaffold.js +95 -286
  21. package/dist/scaffold.js.map +1 -1
  22. package/dist/ui.d.ts +2 -3
  23. package/dist/ui.d.ts.map +1 -1
  24. package/dist/ui.js +90 -44
  25. package/dist/ui.js.map +1 -1
  26. package/package.json +48 -40
  27. package/template/.claude/CLAUDE.md +0 -202
  28. package/template/.claude/commands/checkpoint.md +0 -127
  29. package/template/.claude/commands/cleanup.md +0 -307
  30. package/template/.claude/commands/execute-task.md +0 -440
  31. package/template/.claude/commands/exit-plan.md +0 -41
  32. package/template/.claude/commands/handoff.md +0 -97
  33. package/template/.claude/commands/learn.md +0 -218
  34. package/template/.claude/commands/metrics.md +0 -118
  35. package/template/.claude/commands/newworker.md +0 -162
  36. package/template/.claude/commands/nexttask.md +0 -67
  37. package/template/.claude/commands/prd.md +0 -238
  38. package/template/.claude/commands/reanchor.md +0 -51
  39. package/template/.claude/commands/remember.md +0 -126
  40. package/template/.claude/commands/run-project.md +0 -348
  41. package/template/.claude/commands/run.md +0 -110
  42. package/template/.claude/commands/search-reindex.md +0 -62
  43. package/template/.claude/commands/search.md +0 -100
  44. package/template/.claude/commands/setup.md +0 -381
  45. package/template/.claude/scripts/pure-ralph-loop.ps1 +0 -312
  46. package/template/.claude/scripts/pure-ralph-loop.sh +0 -859
  47. package/template/CHANGELOG.md +0 -220
  48. package/template/LICENSE +0 -21
  49. package/template/MIGRATION.md +0 -259
  50. package/template/README.md +0 -368
  51. package/template/data/journal/.gitkeep +0 -0
  52. package/template/docs/images/ascii-banner-options.md +0 -122
  53. package/template/docs/images/hq-banner.svg +0 -105
  54. package/template/knowledge/Ralph/01-overview.md +0 -71
  55. package/template/knowledge/Ralph/02-core-concepts.md +0 -114
  56. package/template/knowledge/Ralph/03-how-ralph-works.md +0 -184
  57. package/template/knowledge/Ralph/04-back-pressure.md +0 -222
  58. package/template/knowledge/Ralph/05-specifications.md +0 -210
  59. package/template/knowledge/Ralph/06-agents-md.md +0 -222
  60. package/template/knowledge/Ralph/07-implementation.md +0 -316
  61. package/template/knowledge/Ralph/08-economics.md +0 -182
  62. package/template/knowledge/Ralph/09-resources.md +0 -145
  63. package/template/knowledge/Ralph/10-claude-code-workflow.md +0 -212
  64. package/template/knowledge/Ralph/11-team-training-guide.md +0 -383
  65. package/template/knowledge/Ralph/README.md +0 -40
  66. package/template/knowledge/ai-security-framework/CONTRIBUTING.md +0 -139
  67. package/template/knowledge/ai-security-framework/GLOSSARY.md +0 -176
  68. package/template/knowledge/ai-security-framework/LICENSE +0 -21
  69. package/template/knowledge/ai-security-framework/QUICK-START.md +0 -172
  70. package/template/knowledge/ai-security-framework/README.md +0 -232
  71. package/template/knowledge/ai-security-framework/checklists/browser-security.md +0 -301
  72. package/template/knowledge/ai-security-framework/checklists/credential-isolation.md +0 -322
  73. package/template/knowledge/ai-security-framework/checklists/incident-response.md +0 -288
  74. package/template/knowledge/ai-security-framework/checklists/pre-flight.md +0 -249
  75. package/template/knowledge/ai-security-framework/checklists/weekly-audit.md +0 -159
  76. package/template/knowledge/ai-security-framework/configs/audit-logging.md +0 -372
  77. package/template/knowledge/ai-security-framework/configs/kill-switches.md +0 -354
  78. package/template/knowledge/ai-security-framework/docs/01-core-principles.md +0 -256
  79. package/template/knowledge/ai-security-framework/docs/02-threat-landscape.md +0 -326
  80. package/template/knowledge/ai-security-framework/docs/03-security-posture.md +0 -250
  81. package/template/knowledge/ai-security-framework/templates/agents-security.md +0 -233
  82. package/template/knowledge/design-styles/README.md +0 -42
  83. package/template/knowledge/design-styles/american-industrial.md +0 -136
  84. package/template/knowledge/design-styles/ethereal-abstract.md +0 -133
  85. package/template/knowledge/design-styles/liminal-portal.md +0 -111
  86. package/template/knowledge/design-styles/swipes/american-industrial/G-3m4YPW0AADdu2.jpeg +0 -0
  87. package/template/knowledge/design-styles/swipes/american-industrial/G-JJlt5WwAABK3K.png +0 -0
  88. package/template/knowledge/design-styles/swipes/american-industrial/G-JJmj5W0AEbJ-7.png +0 -0
  89. package/template/knowledge/design-styles/swipes/american-industrial/G59fgNuXkAAKLJQ (1).jpeg +0 -0
  90. package/template/knowledge/design-styles/swipes/american-industrial/G59fgNuXkAAKLJQ.jpeg +0 -0
  91. package/template/knowledge/design-styles/swipes/american-industrial/G7fVkn3WEAAM-ST.jpeg +0 -0
  92. package/template/knowledge/design-styles/swipes/american-industrial/G8ECO5JWEAIksyn.png +0 -0
  93. package/template/knowledge/design-styles/swipes/american-industrial/G9-3GQSWoAA8eqZ.png +0 -0
  94. package/template/knowledge/design-styles/swipes/american-industrial/G9xEOqrXkAEZRcs.png +0 -0
  95. package/template/knowledge/design-styles/swipes/american-industrial/G_MVeJrXQAA8sx4.jpeg +0 -0
  96. package/template/knowledge/design-styles/swipes/american-industrial/G_RSkmGXkAAgAVZ.png +0 -0
  97. package/template/knowledge/design-styles/swipes/american-industrial/README.md +0 -31
  98. package/template/knowledge/design-styles/swipes/american-industrial/qyqtg7Dq.png +0 -0
  99. package/template/knowledge/dev-team/README.md +0 -35
  100. package/template/knowledge/dev-team/patterns/README.md +0 -34
  101. package/template/knowledge/dev-team/patterns/frontend/react-best-practices.md +0 -178
  102. package/template/knowledge/dev-team/troubleshooting/README.md +0 -31
  103. package/template/knowledge/dev-team/workflows/README.md +0 -49
  104. package/template/knowledge/hq/checkpoint-schema.json +0 -51
  105. package/template/knowledge/hq/index-md-spec.md +0 -74
  106. package/template/knowledge/hq/thread-schema.md +0 -153
  107. package/template/knowledge/hq-core/checkpoint-schema.json +0 -51
  108. package/template/knowledge/hq-core/index-md-spec.md +0 -74
  109. package/template/knowledge/hq-core/thread-schema.md +0 -153
  110. package/template/knowledge/loom/README.md +0 -51
  111. package/template/knowledge/loom/architecture.md +0 -125
  112. package/template/knowledge/loom/code-style.md +0 -169
  113. package/template/knowledge/loom/llm-proxy.md +0 -132
  114. package/template/knowledge/loom/state-machine.md +0 -131
  115. package/template/knowledge/loom/thread-system.md +0 -117
  116. package/template/knowledge/loom/tools.md +0 -94
  117. package/template/knowledge/loom/weaver.md +0 -96
  118. package/template/knowledge/loom/web-frontend.md +0 -131
  119. package/template/knowledge/projects/README.md +0 -72
  120. package/template/knowledge/projects/templates/README.template.md +0 -28
  121. package/template/knowledge/workers/README.md +0 -195
  122. package/template/knowledge/workers/ralph-loop-pattern.md +0 -157
  123. package/template/knowledge/workers/skill-schema.md +0 -182
  124. package/template/knowledge/workers/state-machine.md +0 -102
  125. package/template/knowledge/workers/templates/base-worker.yaml +0 -73
  126. package/template/knowledge/workers/templates/code-worker.yaml +0 -85
  127. package/template/knowledge/workers/templates/skill.yaml +0 -49
  128. package/template/knowledge/workers/templates/social-worker.yaml +0 -70
  129. package/template/modules/examples/full-manifest.yaml +0 -92
  130. package/template/modules/examples/minimal.yaml +0 -14
  131. package/template/modules/modules.yaml +0 -59
  132. package/template/projects/.gitkeep +0 -0
  133. package/template/projects/incorporate-workers-into-pure-ralph/prd.json +0 -88
  134. package/template/projects/pure-ralph-branch-isolation/README.md +0 -114
  135. package/template/projects/pure-ralph-branch-isolation/prd.json +0 -123
  136. package/template/projects/purist-ralph-loop/README.md +0 -148
  137. package/template/projects/purist-ralph-loop/prd.json +0 -135
  138. package/template/projects/ralph-test/prd.json +0 -50
  139. package/template/prompts/pure-ralph-base.md +0 -551
  140. package/template/settings/.gitkeep +0 -0
  141. package/template/settings/pure-ralph.json +0 -42
  142. package/template/social-content/drafts/INDEX.md +0 -21
  143. package/template/social-content/drafts/linkedin/.gitkeep +0 -1
  144. package/template/social-content/drafts/x/.gitkeep +0 -1
  145. package/template/social-content/images/.gitkeep +0 -1
  146. package/template/starter-projects/code-worker/README.md +0 -97
  147. package/template/starter-projects/code-worker/prd.json +0 -45
  148. package/template/starter-projects/personal-assistant/README.md +0 -42
  149. package/template/starter-projects/personal-assistant/prd.json +0 -43
  150. package/template/starter-projects/social-media/README.md +0 -60
  151. package/template/starter-projects/social-media/prd.json +0 -43
  152. package/template/workers/content-brand/README.md +0 -59
  153. package/template/workers/content-brand/skills/messaging-alignment.md +0 -91
  154. package/template/workers/content-brand/skills/tone-check.md +0 -76
  155. package/template/workers/content-brand/skills/voice-analysis.md +0 -68
  156. package/template/workers/content-brand/worker.yaml +0 -81
  157. package/template/workers/content-legal/README.md +0 -80
  158. package/template/workers/content-legal/skills/claim-substantiation.md +0 -150
  159. package/template/workers/content-legal/skills/compliance-scan.md +0 -123
  160. package/template/workers/content-legal/skills/disclaimer-check.md +0 -146
  161. package/template/workers/content-legal/worker.yaml +0 -118
  162. package/template/workers/content-product/README.md +0 -77
  163. package/template/workers/content-product/skills/claim-verification.md +0 -96
  164. package/template/workers/content-product/skills/feature-accuracy.md +0 -117
  165. package/template/workers/content-product/skills/stats-check.md +0 -128
  166. package/template/workers/content-product/worker.yaml +0 -97
  167. package/template/workers/content-sales/README.md +0 -70
  168. package/template/workers/content-sales/skills/conversion-analysis.md +0 -96
  169. package/template/workers/content-sales/skills/cta-audit.md +0 -107
  170. package/template/workers/content-sales/skills/value-prop-check.md +0 -114
  171. package/template/workers/content-sales/worker.yaml +0 -93
  172. package/template/workers/content-shared/cli.ts +0 -242
  173. package/template/workers/content-shared/index.ts +0 -234
  174. package/template/workers/content-shared/lib/accuracy-analyzer.ts +0 -661
  175. package/template/workers/content-shared/lib/analyze.ts +0 -370
  176. package/template/workers/content-shared/lib/brand-analyzer.ts +0 -526
  177. package/template/workers/content-shared/lib/cms-integration.ts +0 -446
  178. package/template/workers/content-shared/lib/compliance-analyzer.ts +0 -655
  179. package/template/workers/content-shared/lib/conversion-analyzer.ts +0 -555
  180. package/template/workers/content-shared/lib/github-integration.ts +0 -582
  181. package/template/workers/content-shared/lib/output.ts +0 -373
  182. package/template/workers/content-shared/lib/parser.ts +0 -771
  183. package/template/workers/content-shared/lib/priority.ts +0 -439
  184. package/template/workers/content-shared/lib/recommendations.ts +0 -512
  185. package/template/workers/content-shared/lib/reporter.ts +0 -749
  186. package/template/workers/content-shared/lib/restructure.ts +0 -664
  187. package/template/workers/content-shared/lib/scorer.ts +0 -140
  188. package/template/workers/content-shared/lib/types.ts +0 -227
  189. package/template/workers/content-shared/lib/variants.ts +0 -595
  190. package/template/workers/content-shared/package.json +0 -51
  191. package/template/workers/content-shared/pnpm-lock.yaml +0 -39
  192. package/template/workers/content-shared/test/sample-page.json +0 -115
  193. package/template/workers/content-shared/tsconfig.json +0 -20
  194. package/template/workers/dev-team/README.md +0 -166
  195. package/template/workers/dev-team/_template.yaml +0 -70
  196. package/template/workers/dev-team/architect/package.json +0 -27
  197. package/template/workers/dev-team/architect/skills/api-design.md +0 -89
  198. package/template/workers/dev-team/architect/skills/refactor-plan.md +0 -96
  199. package/template/workers/dev-team/architect/skills/system-design.md +0 -100
  200. package/template/workers/dev-team/architect/src/index.ts +0 -49
  201. package/template/workers/dev-team/architect/src/mcp-server.ts +0 -122
  202. package/template/workers/dev-team/architect/src/skills/api-design.ts +0 -316
  203. package/template/workers/dev-team/architect/src/skills/refactor-plan.ts +0 -264
  204. package/template/workers/dev-team/architect/src/skills/system-design.ts +0 -212
  205. package/template/workers/dev-team/architect/tsconfig.json +0 -19
  206. package/template/workers/dev-team/architect/worker.yaml +0 -128
  207. package/template/workers/dev-team/backend-dev/package-lock.json +0 -1252
  208. package/template/workers/dev-team/backend-dev/package.json +0 -27
  209. package/template/workers/dev-team/backend-dev/skills/implement-endpoint.md +0 -70
  210. package/template/workers/dev-team/backend-dev/skills/implement-service.md +0 -62
  211. package/template/workers/dev-team/backend-dev/src/index.ts +0 -51
  212. package/template/workers/dev-team/backend-dev/src/mcp-server.ts +0 -109
  213. package/template/workers/dev-team/backend-dev/src/skills/implement-endpoint.ts +0 -122
  214. package/template/workers/dev-team/backend-dev/src/skills/implement-service.ts +0 -126
  215. package/template/workers/dev-team/backend-dev/tsconfig.json +0 -19
  216. package/template/workers/dev-team/backend-dev/worker.yaml +0 -128
  217. package/template/workers/dev-team/code-reviewer/package-lock.json +0 -1080
  218. package/template/workers/dev-team/code-reviewer/package.json +0 -24
  219. package/template/workers/dev-team/code-reviewer/skills/merge-to-production.md +0 -61
  220. package/template/workers/dev-team/code-reviewer/skills/merge-to-staging.md +0 -54
  221. package/template/workers/dev-team/code-reviewer/skills/request-changes.md +0 -63
  222. package/template/workers/dev-team/code-reviewer/skills/review-pr.md +0 -77
  223. package/template/workers/dev-team/code-reviewer/src/index.ts +0 -56
  224. package/template/workers/dev-team/code-reviewer/src/mcp-server.ts +0 -101
  225. package/template/workers/dev-team/code-reviewer/tsconfig.json +0 -19
  226. package/template/workers/dev-team/code-reviewer/worker.yaml +0 -90
  227. package/template/workers/dev-team/database-dev/package.json +0 -22
  228. package/template/workers/dev-team/database-dev/skills/create-schema.md +0 -48
  229. package/template/workers/dev-team/database-dev/src/index.ts +0 -50
  230. package/template/workers/dev-team/database-dev/src/mcp-server.ts +0 -76
  231. package/template/workers/dev-team/database-dev/tsconfig.json +0 -18
  232. package/template/workers/dev-team/database-dev/worker.yaml +0 -90
  233. package/template/workers/dev-team/frontend-dev/package.json +0 -22
  234. package/template/workers/dev-team/frontend-dev/skills/create-component.md +0 -26
  235. package/template/workers/dev-team/frontend-dev/src/index.ts +0 -50
  236. package/template/workers/dev-team/frontend-dev/src/mcp-server.ts +0 -77
  237. package/template/workers/dev-team/frontend-dev/tsconfig.json +0 -18
  238. package/template/workers/dev-team/frontend-dev/worker.yaml +0 -132
  239. package/template/workers/dev-team/infra-dev/package.json +0 -24
  240. package/template/workers/dev-team/infra-dev/skills/add-monitoring.md +0 -73
  241. package/template/workers/dev-team/infra-dev/skills/configure-deployment.md +0 -80
  242. package/template/workers/dev-team/infra-dev/skills/create-dockerfile.md +0 -62
  243. package/template/workers/dev-team/infra-dev/skills/setup-cicd.md +0 -63
  244. package/template/workers/dev-team/infra-dev/src/index.ts +0 -55
  245. package/template/workers/dev-team/infra-dev/src/mcp-server.ts +0 -82
  246. package/template/workers/dev-team/infra-dev/tsconfig.json +0 -19
  247. package/template/workers/dev-team/infra-dev/worker.yaml +0 -92
  248. package/template/workers/dev-team/knowledge-curator/package.json +0 -24
  249. package/template/workers/dev-team/knowledge-curator/skills/curate-troubleshooting.md +0 -63
  250. package/template/workers/dev-team/knowledge-curator/skills/process-learnings.md +0 -61
  251. package/template/workers/dev-team/knowledge-curator/skills/sync-documentation.md +0 -76
  252. package/template/workers/dev-team/knowledge-curator/skills/update-patterns.md +0 -63
  253. package/template/workers/dev-team/knowledge-curator/src/index.ts +0 -53
  254. package/template/workers/dev-team/knowledge-curator/src/mcp-server.ts +0 -92
  255. package/template/workers/dev-team/knowledge-curator/tsconfig.json +0 -19
  256. package/template/workers/dev-team/knowledge-curator/worker.yaml +0 -80
  257. package/template/workers/dev-team/motion-designer/package.json +0 -22
  258. package/template/workers/dev-team/motion-designer/skills/add-animation.md +0 -25
  259. package/template/workers/dev-team/motion-designer/skills/generate-image.md +0 -36
  260. package/template/workers/dev-team/motion-designer/src/index.ts +0 -63
  261. package/template/workers/dev-team/motion-designer/src/mcp-server.ts +0 -79
  262. package/template/workers/dev-team/motion-designer/tsconfig.json +0 -18
  263. package/template/workers/dev-team/motion-designer/worker.yaml +0 -84
  264. package/template/workers/dev-team/product-planner/queue.json +0 -4
  265. package/template/workers/dev-team/product-planner/worker.yaml +0 -220
  266. package/template/workers/dev-team/project-manager/package-lock.json +0 -1252
  267. package/template/workers/dev-team/project-manager/package.json +0 -27
  268. package/template/workers/dev-team/project-manager/skills/create-prd.md +0 -66
  269. package/template/workers/dev-team/project-manager/skills/next-issue.md +0 -51
  270. package/template/workers/dev-team/project-manager/skills/project-status.md +0 -59
  271. package/template/workers/dev-team/project-manager/skills/update-learnings.md +0 -65
  272. package/template/workers/dev-team/project-manager/src/index.ts +0 -54
  273. package/template/workers/dev-team/project-manager/src/mcp-server.ts +0 -207
  274. package/template/workers/dev-team/project-manager/src/skills/create-prd.ts +0 -86
  275. package/template/workers/dev-team/project-manager/src/skills/next-issue.ts +0 -137
  276. package/template/workers/dev-team/project-manager/src/skills/project-status.ts +0 -131
  277. package/template/workers/dev-team/project-manager/src/skills/update-learnings.ts +0 -94
  278. package/template/workers/dev-team/project-manager/tsconfig.json +0 -19
  279. package/template/workers/dev-team/project-manager/worker.yaml +0 -96
  280. package/template/workers/dev-team/qa-tester/package.json +0 -24
  281. package/template/workers/dev-team/qa-tester/skills/create-demo-account.md +0 -36
  282. package/template/workers/dev-team/qa-tester/skills/run-tests.md +0 -36
  283. package/template/workers/dev-team/qa-tester/skills/write-test.md +0 -27
  284. package/template/workers/dev-team/qa-tester/src/index.ts +0 -61
  285. package/template/workers/dev-team/qa-tester/src/mcp-server.ts +0 -88
  286. package/template/workers/dev-team/qa-tester/tsconfig.json +0 -18
  287. package/template/workers/dev-team/qa-tester/worker.yaml +0 -116
  288. package/template/workers/dev-team/task-executor/package-lock.json +0 -1252
  289. package/template/workers/dev-team/task-executor/package.json +0 -27
  290. package/template/workers/dev-team/task-executor/skills/analyze-issue.md +0 -101
  291. package/template/workers/dev-team/task-executor/skills/execute.md +0 -133
  292. package/template/workers/dev-team/task-executor/skills/report-learnings.md +0 -106
  293. package/template/workers/dev-team/task-executor/skills/validate-completion.md +0 -121
  294. package/template/workers/dev-team/task-executor/src/index.ts +0 -54
  295. package/template/workers/dev-team/task-executor/src/mcp-server.ts +0 -139
  296. package/template/workers/dev-team/task-executor/src/skills/analyze-issue.ts +0 -219
  297. package/template/workers/dev-team/task-executor/src/skills/execute.ts +0 -132
  298. package/template/workers/dev-team/task-executor/src/skills/report-learnings.ts +0 -119
  299. package/template/workers/dev-team/task-executor/src/skills/validate-completion.ts +0 -142
  300. package/template/workers/dev-team/task-executor/tsconfig.json +0 -19
  301. package/template/workers/dev-team/task-executor/worker.yaml +0 -110
  302. package/template/workers/registry.yaml +0 -171
  303. package/template/workers/security-scanner/README.md +0 -73
  304. package/template/workers/security-scanner/skills/pre-deploy-check.md +0 -205
  305. package/template/workers/security-scanner/worker.yaml +0 -26
  306. package/template/workspace/checkpoints/.gitkeep +0 -0
  307. package/template/workspace/content-ideas/inbox.jsonl +0 -0
  308. package/template/workspace/drafts/.gitkeep +0 -0
  309. package/template/workspace/learnings/.gitkeep +0 -3
  310. package/template/workspace/orchestrator/.gitkeep +0 -0
  311. package/template/workspace/ralph-test/COMPLETE.md +0 -18
  312. package/template/workspace/ralph-test/hello.txt +0 -2
  313. package/template/workspace/reports/.gitkeep +0 -0
  314. package/template/workspace/scratch/.gitkeep +0 -0
  315. package/template/workspace/threads/.gitkeep +0 -3
@@ -1,655 +0,0 @@
1
- /**
2
- * Regulatory Compliance Analyzer (US-010)
3
- * Checks content for compliance issues, regulated terms, and missing disclaimers
4
- */
5
-
6
- import type {
7
- AnalysisInput,
8
- ComplianceAnalysis,
9
- RegulatedTerm,
10
- Finding,
11
- Recommendation,
12
- } from './types.js';
13
-
14
- // ============================================
15
- // Regulated Terms Database
16
- // ============================================
17
-
18
- /**
19
- * Terms that require proof, disclaimers, or carry legal risk
20
- */
21
- export const REGULATED_TERMS: Array<{
22
- term: string;
23
- patterns: RegExp[];
24
- requiresProof: boolean;
25
- disclaimer?: string;
26
- risk: 'high' | 'medium' | 'low';
27
- category: string;
28
- alternative?: string;
29
- }> = [
30
- // Compliance/Security Claims
31
- {
32
- term: 'SOC 2',
33
- patterns: [/\bSOC\s*2\b/gi, /\bSOC\s*II\b/gi, /\bSOC2\b/gi],
34
- requiresProof: true,
35
- disclaimer: 'SOC 2 Type I/II certification details available upon request',
36
- risk: 'high',
37
- category: 'Compliance',
38
- },
39
- {
40
- term: 'HIPAA',
41
- patterns: [/\bHIPAA\b/gi],
42
- requiresProof: true,
43
- disclaimer: 'HIPAA compliance applies when used with covered entities under a BAA',
44
- risk: 'high',
45
- category: 'Compliance',
46
- },
47
- {
48
- term: 'GDPR',
49
- patterns: [/\bGDPR\b/gi],
50
- requiresProof: true,
51
- disclaimer: 'GDPR compliance details available in our Data Processing Agreement',
52
- risk: 'high',
53
- category: 'Compliance',
54
- },
55
- {
56
- term: 'PCI DSS',
57
- patterns: [/\bPCI\s*(?:DSS)?\b/gi, /\bPCI\s*compliant\b/gi],
58
- requiresProof: true,
59
- disclaimer: 'PCI DSS compliance level documentation available upon request',
60
- risk: 'high',
61
- category: 'Compliance',
62
- },
63
- {
64
- term: 'ISO 27001',
65
- patterns: [/\bISO\s*27001\b/gi, /\bISO\s*certification\b/gi],
66
- requiresProof: true,
67
- disclaimer: 'ISO 27001 certification documentation available upon request',
68
- risk: 'high',
69
- category: 'Compliance',
70
- },
71
- {
72
- term: 'FedRAMP',
73
- patterns: [/\bFedRAMP\b/gi],
74
- requiresProof: true,
75
- disclaimer: 'FedRAMP authorization status available on marketplace.fedramp.gov',
76
- risk: 'high',
77
- category: 'Compliance',
78
- },
79
- {
80
- term: 'CCPA',
81
- patterns: [/\bCCPA\b/gi],
82
- requiresProof: true,
83
- disclaimer: 'CCPA compliance details available in our Privacy Policy',
84
- risk: 'medium',
85
- category: 'Compliance',
86
- },
87
-
88
- // Absolute Claims
89
- {
90
- term: 'guaranteed',
91
- patterns: [/\bguarantee[ds]?\b/gi, /\bguaranty\b/gi],
92
- requiresProof: false,
93
- risk: 'high',
94
- category: 'Claims',
95
- alternative: 'designed to help',
96
- disclaimer: 'Results may vary. See terms for guarantee conditions.',
97
- },
98
- {
99
- term: '100%',
100
- patterns: [/\b100\s*%/gi, /\bhundred\s*percent\b/gi],
101
- requiresProof: false,
102
- risk: 'high',
103
- category: 'Claims',
104
- alternative: 'up to 100%',
105
- },
106
- {
107
- term: 'always',
108
- patterns: [/\balways\b/gi],
109
- requiresProof: false,
110
- risk: 'medium',
111
- category: 'Claims',
112
- alternative: 'consistently',
113
- },
114
- {
115
- term: 'never',
116
- patterns: [/\bnever\b/gi],
117
- requiresProof: false,
118
- risk: 'medium',
119
- category: 'Claims',
120
- alternative: 'designed to prevent',
121
- },
122
- {
123
- term: 'zero',
124
- patterns: [/\bzero\s+(?:downtime|errors?|bugs?|issues?|risk)\b/gi],
125
- requiresProof: false,
126
- risk: 'medium',
127
- category: 'Claims',
128
- alternative: 'minimal',
129
- },
130
- {
131
- term: 'unlimited',
132
- patterns: [/\bunlimited\b/gi],
133
- requiresProof: false,
134
- risk: 'medium',
135
- category: 'Claims',
136
- disclaimer: 'Subject to fair use policy',
137
- },
138
-
139
- // Superlative Claims
140
- {
141
- term: 'best',
142
- patterns: [/\bbest\b/gi, /\b#1\b/gi, /\bnumber\s*one\b/gi],
143
- requiresProof: true,
144
- risk: 'medium',
145
- category: 'Claims',
146
- alternative: 'leading',
147
- },
148
- {
149
- term: 'only',
150
- patterns: [/\bonly\s+(?:solution|platform|provider|option)\b/gi],
151
- requiresProof: true,
152
- risk: 'medium',
153
- category: 'Claims',
154
- alternative: 'one of few',
155
- },
156
- {
157
- term: 'fastest',
158
- patterns: [/\bfastest\b/gi],
159
- requiresProof: true,
160
- risk: 'medium',
161
- category: 'Claims',
162
- alternative: 'fast',
163
- },
164
- {
165
- term: 'most',
166
- patterns: [/\bmost\s+(?:trusted|secure|reliable|advanced|popular)\b/gi],
167
- requiresProof: true,
168
- risk: 'medium',
169
- category: 'Claims',
170
- alternative: 'highly',
171
- },
172
-
173
- // Financial/ROI Claims
174
- {
175
- term: 'ROI',
176
- patterns: [/\bROI\b/gi, /\breturn\s+on\s+investment\b/gi],
177
- requiresProof: true,
178
- risk: 'medium',
179
- category: 'Financial',
180
- disclaimer: 'Individual results may vary based on implementation',
181
- },
182
- {
183
- term: 'save money',
184
- patterns: [/\bsave\s+\$[\d,]+/gi, /\bsave\s+\d+%/gi, /\bcost\s+savings?\b/gi],
185
- requiresProof: true,
186
- risk: 'medium',
187
- category: 'Financial',
188
- disclaimer: 'Savings based on average customer data',
189
- },
190
-
191
- // Industry-Specific
192
- {
193
- term: 'medical',
194
- patterns: [/\bmedical\s*(?:grade|device|approved)\b/gi],
195
- requiresProof: true,
196
- risk: 'high',
197
- category: 'Industry',
198
- disclaimer: 'For informational purposes only. Not a medical device.',
199
- },
200
- {
201
- term: 'FDA',
202
- patterns: [/\bFDA\s*(?:approved|cleared|registered)\b/gi],
203
- requiresProof: true,
204
- risk: 'high',
205
- category: 'Industry',
206
- },
207
- {
208
- term: 'bank-level',
209
- patterns: [/\bbank[-\s]*level\b/gi, /\bbanking[-\s]*grade\b/gi],
210
- requiresProof: false,
211
- risk: 'low',
212
- category: 'Security',
213
- disclaimer: 'Refers to AES-256 encryption standard',
214
- },
215
- ];
216
-
217
- // ============================================
218
- // Required Disclaimers by Context
219
- // ============================================
220
-
221
- const CONTEXT_DISCLAIMERS: Record<string, { patterns: RegExp[]; disclaimer: string }> = {
222
- testimonials: {
223
- patterns: [/testimonial/gi, /customer\s+(?:story|review|quote)/gi],
224
- disclaimer: 'Individual results may vary',
225
- },
226
- pricing: {
227
- patterns: [/pricing/gi, /\$/gi, /cost/gi, /fee/gi],
228
- disclaimer: 'Pricing subject to change. Additional fees may apply.',
229
- },
230
- trials: {
231
- patterns: [/free\s+trial/gi, /try\s+free/gi, /\d+[-\s]*day\s+trial/gi],
232
- disclaimer: 'Credit card may be required. Cancel anytime.',
233
- },
234
- results: {
235
- patterns: [/result[s]?/gi, /outcome[s]?/gi, /case\s+study/gi],
236
- disclaimer: 'Results shown are representative examples. Individual results may vary.',
237
- },
238
- };
239
-
240
- // ============================================
241
- // Scoring Weights
242
- // ============================================
243
-
244
- const WEIGHTS = {
245
- regulatedTerms: 0.40,
246
- disclaimers: 0.30,
247
- substantiation: 0.30,
248
- };
249
-
250
- // ============================================
251
- // Main Analysis Function
252
- // ============================================
253
-
254
- /**
255
- * Analyze content for regulatory compliance issues
256
- */
257
- export function analyzeCompliance(content: AnalysisInput): ComplianceAnalysis {
258
- const findings: Finding[] = [];
259
- const recommendations: Recommendation[] = [];
260
- const regulatedTermsFound: RegulatedTerm[] = [];
261
- const missingDisclaimers: string[] = [];
262
- const unsubstantiatedClaims: string[] = [];
263
-
264
- // Check regulated terms
265
- const termsResult = checkRegulatedTerms(
266
- content,
267
- findings,
268
- recommendations,
269
- regulatedTermsFound
270
- );
271
-
272
- // Check disclaimers
273
- const disclaimerResult = checkDisclaimers(
274
- content,
275
- findings,
276
- recommendations,
277
- missingDisclaimers
278
- );
279
-
280
- // Check claim substantiation
281
- const substantiationResult = checkSubstantiation(
282
- content,
283
- findings,
284
- recommendations,
285
- unsubstantiatedClaims
286
- );
287
-
288
- // Calculate overall score
289
- const overallScore = Math.round(
290
- termsResult.score * WEIGHTS.regulatedTerms +
291
- disclaimerResult.score * WEIGHTS.disclaimers +
292
- substantiationResult.score * WEIGHTS.substantiation
293
- );
294
-
295
- return {
296
- overallScore,
297
- regulatedTermsFound,
298
- missingDisclaimers,
299
- unsubstantiatedClaims,
300
- findings,
301
- recommendations,
302
- };
303
- }
304
-
305
- // ============================================
306
- // Regulated Terms Check
307
- // ============================================
308
-
309
- interface TermsResult {
310
- score: number;
311
- }
312
-
313
- function checkRegulatedTerms(
314
- content: AnalysisInput,
315
- findings: Finding[],
316
- recommendations: Recommendation[],
317
- regulatedTermsFound: RegulatedTerm[]
318
- ): TermsResult {
319
- let score = 100;
320
- const allText = getAllText(content);
321
-
322
- for (const termDef of REGULATED_TERMS) {
323
- for (const pattern of termDef.patterns) {
324
- const matches = allText.matchAll(pattern);
325
- const matchArray = [...matches];
326
-
327
- if (matchArray.length > 0) {
328
- // Find location of match
329
- const location = findTermLocation(content, pattern);
330
-
331
- const regulatedTerm: RegulatedTerm = {
332
- term: termDef.term,
333
- location,
334
- requiresProof: termDef.requiresProof,
335
- hasProof: false, // Would need external verification
336
- disclaimer: termDef.disclaimer,
337
- risk: termDef.risk,
338
- };
339
-
340
- regulatedTermsFound.push(regulatedTerm);
341
-
342
- // Score based on risk level
343
- const riskPenalty = termDef.risk === 'high' ? 15 : termDef.risk === 'medium' ? 8 : 3;
344
-
345
- if (termDef.requiresProof) {
346
- findings.push({
347
- severity: termDef.risk === 'high' ? 'warning' : 'info',
348
- category: `Compliance - ${termDef.category}`,
349
- message: `Regulated term "${termDef.term}" requires substantiation`,
350
- location,
351
- evidence: matchArray[0][0],
352
- });
353
- score -= riskPenalty;
354
-
355
- if (termDef.disclaimer) {
356
- recommendations.push({
357
- priority: termDef.risk === 'high' ? 'high' : 'medium',
358
- category: 'Compliance',
359
- current: `Uses "${termDef.term}" without disclaimer`,
360
- suggested: `Add disclaimer: "${termDef.disclaimer}"`,
361
- rationale: 'Regulated claims require proper disclaimers',
362
- });
363
- }
364
- }
365
-
366
- if (termDef.alternative) {
367
- recommendations.push({
368
- priority: termDef.risk === 'high' ? 'high' : 'medium',
369
- category: 'Compliance',
370
- current: `Uses "${termDef.term}"`,
371
- suggested: `Consider using "${termDef.alternative}" instead`,
372
- rationale: 'Reduces legal risk while maintaining message',
373
- });
374
- }
375
-
376
- break; // Only count each term once
377
- }
378
- }
379
- }
380
-
381
- // Report summary
382
- const highRiskCount = regulatedTermsFound.filter(t => t.risk === 'high').length;
383
- const mediumRiskCount = regulatedTermsFound.filter(t => t.risk === 'medium').length;
384
-
385
- if (highRiskCount > 0) {
386
- findings.push({
387
- severity: 'warning',
388
- category: 'Compliance Summary',
389
- message: `Found ${highRiskCount} high-risk regulated term(s)`,
390
- });
391
- }
392
-
393
- if (mediumRiskCount > 0) {
394
- findings.push({
395
- severity: 'info',
396
- category: 'Compliance Summary',
397
- message: `Found ${mediumRiskCount} medium-risk regulated term(s)`,
398
- });
399
- }
400
-
401
- if (regulatedTermsFound.length === 0) {
402
- findings.push({
403
- severity: 'pass',
404
- category: 'Compliance Summary',
405
- message: 'No high-risk regulated terms found',
406
- });
407
- }
408
-
409
- return { score: Math.max(0, score) };
410
- }
411
-
412
- // ============================================
413
- // Disclaimer Check
414
- // ============================================
415
-
416
- interface DisclaimerResult {
417
- score: number;
418
- }
419
-
420
- function checkDisclaimers(
421
- content: AnalysisInput,
422
- findings: Finding[],
423
- recommendations: Recommendation[],
424
- missingDisclaimers: string[]
425
- ): DisclaimerResult {
426
- let score = 100;
427
- const allText = getAllText(content).toLowerCase();
428
-
429
- // Check for context-specific disclaimers
430
- for (const [context, config] of Object.entries(CONTEXT_DISCLAIMERS)) {
431
- const hasContext = config.patterns.some(pattern => pattern.test(allText));
432
-
433
- if (hasContext) {
434
- // Check if corresponding disclaimer exists
435
- const hasDisclaimer = allText.includes('results may vary') ||
436
- allText.includes('individual results') ||
437
- allText.includes('subject to') ||
438
- allText.includes('terms apply') ||
439
- allText.includes('disclaimer');
440
-
441
- if (!hasDisclaimer) {
442
- missingDisclaimers.push(config.disclaimer);
443
- findings.push({
444
- severity: 'info',
445
- category: 'Compliance - Disclaimers',
446
- message: `${context.charAt(0).toUpperCase() + context.slice(1)} content may need disclaimer`,
447
- });
448
- score -= 10;
449
- recommendations.push({
450
- priority: 'medium',
451
- category: 'Disclaimers',
452
- current: `${context} content without disclaimer`,
453
- suggested: `Add: "${config.disclaimer}"`,
454
- rationale: 'Disclaimers protect against legal claims',
455
- });
456
- }
457
- }
458
- }
459
-
460
- // Check for financial projections
461
- const financialPatterns = [
462
- /\bwill\s+save\b/gi,
463
- /\bwill\s+(?:increase|boost|grow)\b/gi,
464
- /\bexpect\s+to\b/gi,
465
- ];
466
-
467
- const hasFinancialProjections = financialPatterns.some(pattern => pattern.test(allText));
468
- if (hasFinancialProjections) {
469
- const hasForwardDisclaimer = allText.includes('forward-looking') ||
470
- allText.includes('no guarantee') ||
471
- allText.includes('may vary');
472
-
473
- if (!hasForwardDisclaimer) {
474
- missingDisclaimers.push('Projections are estimates and actual results may vary');
475
- findings.push({
476
- severity: 'warning',
477
- category: 'Compliance - Disclaimers',
478
- message: 'Financial projections may need disclaimer',
479
- });
480
- score -= 15;
481
- recommendations.push({
482
- priority: 'high',
483
- category: 'Disclaimers',
484
- current: 'Financial projections without disclaimer',
485
- suggested: 'Add: "Projections are estimates and actual results may vary"',
486
- rationale: 'Forward-looking statements require appropriate disclaimers',
487
- });
488
- }
489
- }
490
-
491
- // Report findings
492
- if (missingDisclaimers.length === 0) {
493
- findings.push({
494
- severity: 'pass',
495
- category: 'Compliance - Disclaimers',
496
- message: 'No obvious missing disclaimers detected',
497
- });
498
- }
499
-
500
- return { score: Math.max(0, score) };
501
- }
502
-
503
- // ============================================
504
- // Claim Substantiation Check
505
- // ============================================
506
-
507
- interface SubstantiationResult {
508
- score: number;
509
- }
510
-
511
- function checkSubstantiation(
512
- content: AnalysisInput,
513
- findings: Finding[],
514
- recommendations: Recommendation[],
515
- unsubstantiatedClaims: string[]
516
- ): SubstantiationResult {
517
- let score = 100;
518
-
519
- // Check claims for substantiation
520
- for (const claim of content.claims) {
521
- const claimLower = claim.toLowerCase();
522
-
523
- // Check if claim has supporting evidence patterns
524
- const hasEvidence =
525
- /\bstudy\b/i.test(claim) ||
526
- /\bresearch\b/i.test(claim) ||
527
- /\bdata\b/i.test(claim) ||
528
- /\bsurvey\b/i.test(claim) ||
529
- /\breport\b/i.test(claim) ||
530
- /according to/i.test(claim) ||
531
- /based on/i.test(claim);
532
-
533
- // Check if it's a risky claim type
534
- const isRiskyClaim =
535
- /\b(always|never|guaranteed|100%|best|only|most|fastest)\b/i.test(claimLower);
536
-
537
- if (isRiskyClaim && !hasEvidence) {
538
- unsubstantiatedClaims.push(claim);
539
- findings.push({
540
- severity: 'warning',
541
- category: 'Compliance - Substantiation',
542
- message: 'Claim may need substantiation',
543
- evidence: truncate(claim, 100),
544
- });
545
- score -= 10;
546
- }
547
- }
548
-
549
- // Check stats for sources
550
- const statsWithoutSources = content.stats.filter(stat => {
551
- const labelLower = stat.label.toLowerCase();
552
- return !labelLower.includes('source') &&
553
- !labelLower.includes('based on') &&
554
- !labelLower.includes('according') &&
555
- !labelLower.includes('study') &&
556
- !labelLower.includes('report');
557
- });
558
-
559
- if (statsWithoutSources.length > 0 && content.stats.length > 0) {
560
- const percentage = Math.round((statsWithoutSources.length / content.stats.length) * 100);
561
- if (percentage > 50) {
562
- findings.push({
563
- severity: 'info',
564
- category: 'Compliance - Substantiation',
565
- message: `${percentage}% of statistics lack source attribution`,
566
- });
567
- score -= 5;
568
- recommendations.push({
569
- priority: 'low',
570
- category: 'Substantiation',
571
- current: 'Statistics without sources',
572
- suggested: 'Add source attribution for third-party statistics',
573
- rationale: 'Sourced statistics are more defensible',
574
- });
575
- }
576
- }
577
-
578
- // Report findings
579
- if (unsubstantiatedClaims.length === 0) {
580
- findings.push({
581
- severity: 'pass',
582
- category: 'Compliance - Substantiation',
583
- message: 'No obviously unsubstantiated claims detected',
584
- });
585
- } else {
586
- recommendations.push({
587
- priority: 'high',
588
- category: 'Substantiation',
589
- current: `${unsubstantiatedClaims.length} claim(s) lack substantiation`,
590
- suggested: 'Add supporting data, sources, or soften language',
591
- rationale: 'Unsubstantiated claims can lead to legal challenges',
592
- });
593
- }
594
-
595
- return { score: Math.max(0, score) };
596
- }
597
-
598
- // ============================================
599
- // Helper Functions
600
- // ============================================
601
-
602
- /**
603
- * Get all text from content
604
- */
605
- function getAllText(content: AnalysisInput): string {
606
- return [
607
- content.title,
608
- ...content.headings,
609
- ...content.paragraphs,
610
- ...content.ctas.map(c => c.text),
611
- ...content.claims,
612
- ].join(' ');
613
- }
614
-
615
- /**
616
- * Find the location of a term in content
617
- */
618
- function findTermLocation(content: AnalysisInput, pattern: RegExp): string {
619
- // Check title
620
- if (pattern.test(content.title)) {
621
- return 'Page title';
622
- }
623
-
624
- // Check headings
625
- for (let i = 0; i < content.headings.length; i++) {
626
- if (pattern.test(content.headings[i])) {
627
- return `Heading: ${truncate(content.headings[i], 50)}`;
628
- }
629
- }
630
-
631
- // Check sections
632
- for (const section of content.sections) {
633
- const sectionText = section.content.join(' ');
634
- if (pattern.test(sectionText)) {
635
- return `Section: ${section.type} (${section.heading || section.id})`;
636
- }
637
- }
638
-
639
- // Check CTAs
640
- for (const cta of content.ctas) {
641
- if (pattern.test(cta.text)) {
642
- return `CTA: ${cta.text}`;
643
- }
644
- }
645
-
646
- return 'Body content';
647
- }
648
-
649
- /**
650
- * Truncate string with ellipsis
651
- */
652
- function truncate(str: string, maxLength: number): string {
653
- if (str.length <= maxLength) return str;
654
- return str.slice(0, maxLength - 3) + '...';
655
- }