@lssm/lib.contracts 1.11.1 → 1.41.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (293) hide show
  1. package/README.md +1 -1
  2. package/dist/_virtual/rolldown_runtime.js +1 -0
  3. package/dist/app-config/app-config.feature.js +1 -0
  4. package/dist/app-config/contracts.js +1 -1
  5. package/dist/app-config/docs/app-config.docblock.js +220 -0
  6. package/dist/app-config/events.js +1 -1
  7. package/dist/app-config/index.js +1 -1
  8. package/dist/app-config/lifecycle-contracts.js +1 -1
  9. package/dist/capabilities/docs/capabilities.docblock.js +1 -0
  10. package/dist/contract-registry/index.js +1 -0
  11. package/dist/contract-registry/schemas.js +1 -0
  12. package/dist/contract-registry/types.js +0 -0
  13. package/dist/data-views/docs/data-views.docblock.js +1 -0
  14. package/dist/docs/PUBLISHING.docblock.js +76 -0
  15. package/dist/docs/accessibility_wcag_compliance_specs.docblock.js +350 -0
  16. package/dist/docs/index.js +1 -0
  17. package/dist/docs/meta.docs.js +13 -0
  18. package/dist/docs/presentations.js +1 -0
  19. package/dist/docs/registry.js +1 -0
  20. package/dist/docs/tech/PHASE_1_QUICKSTART.docblock.js +383 -0
  21. package/dist/docs/tech/PHASE_2_AI_NATIVE_OPERATIONS.docblock.js +68 -0
  22. package/dist/docs/tech/PHASE_3_AUTO_EVOLUTION.docblock.js +140 -0
  23. package/dist/docs/tech/PHASE_4_PERSONALIZATION_ENGINE.docblock.js +86 -0
  24. package/dist/docs/tech/PHASE_5_ZERO_TOUCH_OPERATIONS.docblock.js +1 -0
  25. package/dist/docs/tech/auth/better-auth-nextjs.docblock.js +58 -0
  26. package/dist/docs/tech/contracts/README.docblock.js +1 -0
  27. package/dist/docs/tech/contracts/create-subscription.docblock.js +1 -0
  28. package/dist/docs/tech/contracts/graphql-typed-outputs.docblock.js +180 -0
  29. package/dist/docs/tech/contracts/migrations.docblock.js +1 -0
  30. package/dist/docs/tech/contracts/openapi-export.docblock.js +38 -0
  31. package/dist/docs/tech/contracts/ops-to-presentation-linking.docblock.js +62 -0
  32. package/dist/docs/tech/contracts/overlays.docblock.js +68 -0
  33. package/dist/docs/tech/contracts/tests.docblock.js +132 -0
  34. package/dist/docs/tech/contracts/themes.docblock.js +1 -0
  35. package/dist/docs/tech/contracts/vertical-pocket-family-office.docblock.js +106 -0
  36. package/dist/docs/tech/lifecycle-stage-system.docblock.js +213 -0
  37. package/dist/docs/tech/llm/llm-integration.docblock.js +289 -0
  38. package/dist/docs/tech/mcp-endpoints.docblock.js +1 -0
  39. package/dist/docs/tech/presentation-runtime.docblock.js +1 -0
  40. package/dist/docs/tech/schema/README.docblock.js +262 -0
  41. package/dist/docs/tech/studio/learning-events.docblock.js +1 -0
  42. package/dist/docs/tech/studio/learning-journeys.docblock.js +57 -0
  43. package/dist/docs/tech/studio/platform-admin-panel.docblock.js +63 -0
  44. package/dist/docs/tech/studio/project-access-teams.docblock.js +36 -0
  45. package/dist/docs/tech/studio/project-routing.docblock.js +1 -0
  46. package/dist/docs/tech/studio/sandbox-unlogged.docblock.js +20 -0
  47. package/dist/docs/tech/studio/team-invitations.docblock.js +65 -0
  48. package/dist/docs/tech/studio/workspace-ops.docblock.js +1 -0
  49. package/dist/docs/tech/studio/workspaces.docblock.js +41 -0
  50. package/dist/docs/tech/telemetry-ingest.docblock.js +122 -0
  51. package/dist/docs/tech/templates/runtime.docblock.js +1 -0
  52. package/dist/docs/tech/vscode-extension.docblock.js +68 -0
  53. package/dist/docs/tech/workflows/overview.docblock.js +1 -0
  54. package/dist/docs/tech-contracts.docs.js +76 -0
  55. package/dist/docs/types.js +0 -0
  56. package/dist/events.js +1 -1
  57. package/dist/experiments/docs/experiments.docblock.js +128 -0
  58. package/dist/forms/docs/forms.docblock.js +1 -0
  59. package/dist/index.js +1 -1
  60. package/dist/install.js +1 -1
  61. package/dist/integrations/contracts.js +1 -1
  62. package/dist/integrations/docs/integrations.docblock.js +1 -0
  63. package/dist/integrations/index.js +1 -1
  64. package/dist/integrations/openbanking/contracts/accounts.js +1 -1
  65. package/dist/integrations/openbanking/contracts/balances.js +1 -1
  66. package/dist/integrations/openbanking/contracts/index.js +1 -1
  67. package/dist/integrations/openbanking/contracts/transactions.js +1 -1
  68. package/dist/integrations/openbanking/models.js +1 -1
  69. package/dist/integrations/openbanking/openbanking.feature.js +1 -0
  70. package/dist/integrations/providers/impls/index.js +1 -1
  71. package/dist/integrations/providers/impls/provider-factory.js +1 -1
  72. package/dist/integrations/providers/index.js +1 -1
  73. package/dist/integrations/providers/registry.js +1 -0
  74. package/dist/integrations/secrets/aws-secret-manager.js +1 -0
  75. package/dist/integrations/secrets/gcp-secret-manager.js +1 -1
  76. package/dist/integrations/secrets/index.js +1 -1
  77. package/dist/integrations/secrets/scaleway-secret-manager.js +1 -0
  78. package/dist/jobs/define-job.js +1 -0
  79. package/dist/jobs/gcp-cloud-tasks.js +1 -1
  80. package/dist/jobs/gcp-pubsub.js +1 -1
  81. package/dist/jobs/handlers/index.js +1 -1
  82. package/dist/jobs/handlers/ping-handler.js +1 -0
  83. package/dist/jobs/index.js +1 -1
  84. package/dist/jobs/memory-queue.js +1 -1
  85. package/dist/jobs/queue.js +1 -0
  86. package/dist/jobs/scaleway-sqs-queue.js +1 -0
  87. package/dist/knowledge/contracts.js +1 -1
  88. package/dist/knowledge/docs/knowledge.docblock.js +138 -0
  89. package/dist/llm/exporters.js +8 -0
  90. package/dist/llm/index.js +1 -0
  91. package/dist/llm/prompts.js +220 -0
  92. package/dist/llm/types.js +0 -0
  93. package/dist/onboarding-base.js +1 -1
  94. package/dist/openapi.js +1 -0
  95. package/dist/openbanking/docs/openbanking.docblock.js +109 -0
  96. package/dist/policy/docs/policy.docblock.js +1 -0
  97. package/dist/presentations/docs/presentations-conventions.docblock.js +8 -0
  98. package/dist/presentations.js +1 -1
  99. package/dist/presentations.v2.js +7 -1
  100. package/dist/prompt.js +1 -1
  101. package/dist/promptRegistry.js +1 -1
  102. package/dist/regenerator/docs/regenerator.docblock.js +184 -0
  103. package/dist/registry.js +1 -1
  104. package/dist/resources.js +1 -1
  105. package/dist/schema-to-markdown.js +10 -0
  106. package/dist/server/graphql-pothos.js +1 -1
  107. package/dist/server/index.js +1 -1
  108. package/dist/server/mcp/createMcpServer.js +1 -0
  109. package/dist/server/mcp/mcpTypes.js +0 -0
  110. package/dist/server/mcp/registerPresentations.js +1 -0
  111. package/dist/server/mcp/registerPrompts.js +3 -0
  112. package/dist/server/mcp/registerResources.js +1 -0
  113. package/dist/server/mcp/registerTools.js +1 -0
  114. package/dist/server/provider-mcp.js +1 -1
  115. package/dist/telemetry/docs/telemetry.docblock.js +139 -0
  116. package/package.json +354 -193
  117. package/dist/app-config/branding.d.ts +0 -55
  118. package/dist/app-config/contracts.d.ts +0 -244
  119. package/dist/app-config/events.d.ts +0 -122
  120. package/dist/app-config/index.d.ts +0 -8
  121. package/dist/app-config/lifecycle-contracts.d.ts +0 -382
  122. package/dist/app-config/lifecycle.d.ts +0 -27
  123. package/dist/app-config/runtime.d.ts +0 -114
  124. package/dist/app-config/spec.d.ts +0 -175
  125. package/dist/app-config/validation.d.ts +0 -47
  126. package/dist/capabilities/openbanking.d.ts +0 -9
  127. package/dist/capabilities.d.ts +0 -45
  128. package/dist/client/index.d.ts +0 -6
  129. package/dist/client/react/drivers/rn-reusables.d.ts +0 -22
  130. package/dist/client/react/drivers/shadcn.d.ts +0 -12
  131. package/dist/client/react/feature-render.d.ts +0 -20
  132. package/dist/client/react/form-render.d.ts +0 -91
  133. package/dist/client/react/index.d.ts +0 -5
  134. package/dist/contracts-adapter-hydration.d.ts +0 -15
  135. package/dist/contracts-adapter-input.d.ts +0 -10
  136. package/dist/data-views/query-generator.d.ts +0 -39
  137. package/dist/data-views/runtime.d.ts +0 -26
  138. package/dist/data-views.d.ts +0 -131
  139. package/dist/events.d.ts +0 -44
  140. package/dist/experiments/evaluator.d.ts +0 -37
  141. package/dist/experiments/spec-resolver.d.ts +0 -16
  142. package/dist/experiments/spec.d.ts +0 -89
  143. package/dist/features.d.ts +0 -87
  144. package/dist/forms.d.ts +0 -258
  145. package/dist/graphql-federation/dist/index.js +0 -1
  146. package/dist/index.d.ts +0 -130
  147. package/dist/install.d.ts +0 -76
  148. package/dist/integrations/binding.d.ts +0 -17
  149. package/dist/integrations/connection.d.ts +0 -51
  150. package/dist/integrations/contracts.d.ts +0 -435
  151. package/dist/integrations/health.d.ts +0 -21
  152. package/dist/integrations/index.d.ts +0 -53
  153. package/dist/integrations/openbanking/contracts/accounts.d.ts +0 -287
  154. package/dist/integrations/openbanking/contracts/balances.d.ts +0 -163
  155. package/dist/integrations/openbanking/contracts/index.d.ts +0 -9
  156. package/dist/integrations/openbanking/contracts/transactions.d.ts +0 -211
  157. package/dist/integrations/openbanking/guards.d.ts +0 -12
  158. package/dist/integrations/openbanking/models.d.ts +0 -228
  159. package/dist/integrations/openbanking/telemetry.d.ts +0 -15
  160. package/dist/integrations/providers/calendar.d.ts +0 -78
  161. package/dist/integrations/providers/elevenlabs.d.ts +0 -7
  162. package/dist/integrations/providers/email.d.ts +0 -86
  163. package/dist/integrations/providers/embedding.d.ts +0 -24
  164. package/dist/integrations/providers/gcs-storage.d.ts +0 -7
  165. package/dist/integrations/providers/gmail.d.ts +0 -7
  166. package/dist/integrations/providers/google-calendar.d.ts +0 -7
  167. package/dist/integrations/providers/impls/elevenlabs-voice.d.ts +0 -20
  168. package/dist/integrations/providers/impls/gcs-storage.d.ts +0 -24
  169. package/dist/integrations/providers/impls/gmail-inbound.d.ts +0 -26
  170. package/dist/integrations/providers/impls/gmail-outbound.d.ts +0 -18
  171. package/dist/integrations/providers/impls/google-calendar.d.ts +0 -23
  172. package/dist/integrations/providers/impls/index.d.ts +0 -15
  173. package/dist/integrations/providers/impls/mistral-embedding.d.ts +0 -23
  174. package/dist/integrations/providers/impls/mistral-llm.d.ts +0 -31
  175. package/dist/integrations/providers/impls/postmark-email.d.ts +0 -19
  176. package/dist/integrations/providers/impls/powens-client.d.ts +0 -124
  177. package/dist/integrations/providers/impls/powens-openbanking.d.ts +0 -27
  178. package/dist/integrations/providers/impls/provider-factory.d.ts +0 -26
  179. package/dist/integrations/providers/impls/qdrant-vector.d.ts +0 -24
  180. package/dist/integrations/providers/impls/stripe-payments.d.ts +0 -28
  181. package/dist/integrations/providers/impls/twilio-sms.d.ts +0 -20
  182. package/dist/integrations/providers/index.d.ts +0 -36
  183. package/dist/integrations/providers/llm.d.ts +0 -82
  184. package/dist/integrations/providers/mistral.d.ts +0 -7
  185. package/dist/integrations/providers/openbanking.d.ts +0 -128
  186. package/dist/integrations/providers/payments.d.ts +0 -109
  187. package/dist/integrations/providers/postmark.d.ts +0 -7
  188. package/dist/integrations/providers/powens.d.ts +0 -7
  189. package/dist/integrations/providers/qdrant.d.ts +0 -7
  190. package/dist/integrations/providers/sms.d.ts +0 -34
  191. package/dist/integrations/providers/storage.d.ts +0 -60
  192. package/dist/integrations/providers/stripe.d.ts +0 -7
  193. package/dist/integrations/providers/twilio-sms.d.ts +0 -7
  194. package/dist/integrations/providers/vector-store.d.ts +0 -43
  195. package/dist/integrations/providers/voice.d.ts +0 -34
  196. package/dist/integrations/runtime.d.ts +0 -99
  197. package/dist/integrations/secrets/env-secret-provider.d.ts +0 -31
  198. package/dist/integrations/secrets/gcp-secret-manager.d.ts +0 -32
  199. package/dist/integrations/secrets/index.d.ts +0 -5
  200. package/dist/integrations/secrets/manager.d.ts +0 -47
  201. package/dist/integrations/secrets/provider.d.ts +0 -52
  202. package/dist/integrations/spec.d.ts +0 -79
  203. package/dist/jobs/gcp-cloud-tasks.d.ts +0 -41
  204. package/dist/jobs/gcp-pubsub.d.ts +0 -25
  205. package/dist/jobs/handlers/gmail-sync-handler.d.ts +0 -9
  206. package/dist/jobs/handlers/index.d.ts +0 -3
  207. package/dist/jobs/handlers/storage-document-handler.d.ts +0 -12
  208. package/dist/jobs/index.d.ts +0 -7
  209. package/dist/jobs/memory-queue.d.ts +0 -18
  210. package/dist/jobs/queue.d.ts +0 -26
  211. package/dist/jsonschema.d.ts +0 -26
  212. package/dist/knowledge/binding.d.ts +0 -25
  213. package/dist/knowledge/contracts.d.ts +0 -316
  214. package/dist/knowledge/index.d.ts +0 -10
  215. package/dist/knowledge/ingestion/document-processor.d.ts +0 -24
  216. package/dist/knowledge/ingestion/embedding-service.d.ts +0 -12
  217. package/dist/knowledge/ingestion/gmail-adapter.d.ts +0 -18
  218. package/dist/knowledge/ingestion/index.d.ts +0 -6
  219. package/dist/knowledge/ingestion/storage-adapter.d.ts +0 -15
  220. package/dist/knowledge/ingestion/vector-indexer.d.ts +0 -18
  221. package/dist/knowledge/query/index.d.ts +0 -2
  222. package/dist/knowledge/query/service.d.ts +0 -29
  223. package/dist/knowledge/runtime.d.ts +0 -32
  224. package/dist/knowledge/source.d.ts +0 -32
  225. package/dist/knowledge/spaces/email-threads.d.ts +0 -7
  226. package/dist/knowledge/spaces/financial-docs.d.ts +0 -7
  227. package/dist/knowledge/spaces/financial-overview.d.ts +0 -7
  228. package/dist/knowledge/spaces/index.d.ts +0 -7
  229. package/dist/knowledge/spaces/product-canon.d.ts +0 -7
  230. package/dist/knowledge/spaces/support-faq.d.ts +0 -7
  231. package/dist/knowledge/spaces/uploaded-docs.d.ts +0 -7
  232. package/dist/knowledge/spec.d.ts +0 -52
  233. package/dist/markdown.d.ts +0 -21
  234. package/dist/migrations.d.ts +0 -52
  235. package/dist/onboarding-base.d.ts +0 -137
  236. package/dist/ownership.d.ts +0 -75
  237. package/dist/policy/engine.d.ts +0 -39
  238. package/dist/policy/opa-adapter.d.ts +0 -45
  239. package/dist/policy/spec.d.ts +0 -114
  240. package/dist/presentations.backcompat.d.ts +0 -7
  241. package/dist/presentations.d.ts +0 -96
  242. package/dist/presentations.v2.d.ts +0 -95
  243. package/dist/prompt.d.ts +0 -60
  244. package/dist/promptRegistry.d.ts +0 -15
  245. package/dist/regenerator/adapters.d.ts +0 -19
  246. package/dist/regenerator/executor.d.ts +0 -70
  247. package/dist/regenerator/index.d.ts +0 -7
  248. package/dist/regenerator/service.d.ts +0 -33
  249. package/dist/regenerator/sinks.d.ts +0 -26
  250. package/dist/regenerator/types.d.ts +0 -107
  251. package/dist/regenerator/utils.d.ts +0 -9
  252. package/dist/registry.d.ts +0 -72
  253. package/dist/resources.d.ts +0 -64
  254. package/dist/schema/dist/EnumType.js +0 -1
  255. package/dist/schema/dist/FieldType.js +0 -1
  256. package/dist/schema/dist/ScalarTypeEnum.js +0 -1
  257. package/dist/schema/dist/SchemaModel.js +0 -1
  258. package/dist/schema/dist/index.js +0 -1
  259. package/dist/server/graphql-pothos.d.ts +0 -31
  260. package/dist/server/graphql-schema-export.d.ts +0 -6
  261. package/dist/server/graphql-schema-export.js +0 -1
  262. package/dist/server/index.d.ts +0 -9
  263. package/dist/server/provider-mcp.d.ts +0 -51
  264. package/dist/server/rest-elysia.d.ts +0 -40
  265. package/dist/server/rest-express.d.ts +0 -16
  266. package/dist/server/rest-generic.d.ts +0 -32
  267. package/dist/server/rest-next-app.d.ts +0 -35
  268. package/dist/server/rest-next-mcp.d.ts +0 -11
  269. package/dist/server/rest-next-pages.d.ts +0 -9
  270. package/dist/spec.d.ts +0 -171
  271. package/dist/telemetry/anomaly.d.ts +0 -27
  272. package/dist/telemetry/index.d.ts +0 -4
  273. package/dist/telemetry/spec.d.ts +0 -98
  274. package/dist/telemetry/tracker.d.ts +0 -51
  275. package/dist/tests/index.d.ts +0 -3
  276. package/dist/tests/runner.d.ts +0 -43
  277. package/dist/tests/spec.d.ts +0 -89
  278. package/dist/themes.d.ts +0 -55
  279. package/dist/translations/catalog.d.ts +0 -28
  280. package/dist/translations/tenant.d.ts +0 -15
  281. package/dist/types/all.d.ts +0 -60
  282. package/dist/types.d.ts +0 -88
  283. package/dist/workflow/adapters/db-adapter.d.ts +0 -34
  284. package/dist/workflow/adapters/file-adapter.d.ts +0 -14
  285. package/dist/workflow/adapters/index.d.ts +0 -4
  286. package/dist/workflow/adapters/memory-store.d.ts +0 -18
  287. package/dist/workflow/expression.d.ts +0 -9
  288. package/dist/workflow/index.d.ts +0 -10
  289. package/dist/workflow/runner.d.ts +0 -74
  290. package/dist/workflow/sla-monitor.d.ts +0 -20
  291. package/dist/workflow/spec.d.ts +0 -99
  292. package/dist/workflow/state.d.ts +0 -35
  293. package/dist/workflow/validation.d.ts +0 -28
@@ -0,0 +1,10 @@
1
+ function e(e,i,a={}){let{format:o=`auto`,title:s,description:c,maxDepth:l=2}=a,u=[];s&&u.push(`# ${s}`,``),c&&u.push(`> ${c}`,``);let d=o===`auto`?Array.isArray(i)?`table`:`detail`:o;return d===`table`&&Array.isArray(i)?u.push(t(e,i,a)):d===`list`&&Array.isArray(i)?u.push(n(e,i,a)):!Array.isArray(i)&&typeof i==`object`&&i?u.push(r(e,i,{...a,maxDepth:l})):u.push(`**Data:** ${String(i)}`,``),u.join(`
2
+ `)}function t(e,t,n={}){let{maxItems:r=100,includeFields:i,excludeFields:c=[]}=n,l=a(e,i,c);if(l.length===0||t.length===0)return`_No data available_
3
+ `;let u=t.slice(0,r),d=[],f=l.map(e=>e.label);d.push(`| ${f.join(` | `)} |`),d.push(`| ${f.map(()=>`---`).join(` | `)} |`);for(let e of u){let t=l.map(t=>s(o(e,t.name)));d.push(`| ${t.join(` | `)} |`)}return t.length>r&&d.push(``,`_Showing ${r} of ${t.length} items_`),d.push(``),d.join(`
4
+ `)}function n(e,t,n={}){let{maxItems:r=50,summaryFields:i,includeFields:c,excludeFields:l=[]}=n,u=a(e,c,l),d=i?u.filter(e=>i.includes(e.name)):u.slice(0,3);if(d.length===0||t.length===0)return`_No data available_
5
+ `;let f=t.slice(0,r),p=[];for(let e of f){let t=s(o(e,d[0]?.name??`id`)),n=d.slice(1).map(t=>`${t.label}: ${s(o(e,t.name))}`).join(` · `),r=n?`- **${t}** (${n})`:`- **${t}**`;p.push(r)}return t.length>r&&p.push(``,`_Showing ${r} of ${t.length} items_`),p.push(``),p.join(`
6
+ `)}function r(e,t,n={}){let{includeFields:r,excludeFields:i=[],maxDepth:s=2}=n;if(typeof t!=`object`||!t)return`_No data available_
7
+ `;let l=a(e,r,i);if(l.length===0)return`_No fields to display_
8
+ `;let u=[];for(let e of l){let n=c(o(t,e.name),s,0);u.push(`**${e.label}:** ${n}`)}return u.push(``),u.join(`
9
+ `)}function i(e,t,n={}){let{numericFields:r=[],countByField:i}=n,a=[];a.push(`**Total Items:** ${t.length}`);for(let e of r){let n=t.map(t=>o(t,e)).filter(e=>typeof e==`number`);if(n.length>0){let t=n.reduce((e,t)=>e+t,0),r=t/n.length,i=Math.min(...n),o=Math.max(...n);a.push(`**${l(e)}:** Sum: ${u(t)}, Avg: ${u(r)}, Min: ${u(i)}, Max: ${u(o)}`)}}if(i){let e={};for(let n of t){let t=String(o(n,i)??`Unknown`);e[t]=(e[t]??0)+1}a.push(``,`**By ${l(i)}:**`);for(let[t,n]of Object.entries(e))a.push(`- ${t}: ${n}`)}return a.push(``),a.join(`
10
+ `)}function a(e,t,n=[]){let r=e.config.fields;return Object.keys(r).filter(e=>!(n.includes(e)||t&&!t.includes(e))).map(e=>{let t=r[e],n=!!(t?.type&&typeof t.type==`object`&&`config`in t.type&&typeof t.type.config?.fields==`object`);return{name:e,label:l(e),isOptional:t?.isOptional??!1,isArray:t?.isArray===!0,isNested:n}})}function o(e,t){if(typeof e!=`object`||!e)return;let n=e;if(t.includes(`.`)){let e=t.split(`.`),r=n;for(let t of e){if(typeof r!=`object`||!r)return;r=r[t]}return r}return n[t]}function s(e){if(e==null)return`-`;if(typeof e==`boolean`)return e?`✓`:`✗`;if(typeof e==`number`)return u(e);if(e instanceof Date)return d(e);if(typeof e==`string`&&f(e))return d(new Date(e));if(Array.isArray(e))return`[${e.length} items]`;if(typeof e==`object`)return`[Object]`;let t=String(e);return t.length>50?`${t.slice(0,47)}...`:t.replace(/\|/g,`\\|`)}function c(e,t,n){return e==null?`_none_`:typeof e==`boolean`?e?`Yes`:`No`:typeof e==`number`?u(e):e instanceof Date?d(e):typeof e==`string`&&f(e)?d(new Date(e)):Array.isArray(e)?e.length===0?`_empty list_`:n>=t?`[${e.length} items]`:e.length<=5&&e.every(e=>typeof e!=`object`)?e.map(e=>s(e)).join(`, `):`[${e.length} items]`:typeof e==`object`?n>=t?`[Object]`:`{${Object.keys(e).length} fields}`:String(e)}function l(e){return e.replace(/([a-z])([A-Z])/g,`$1 $2`).replace(/_/g,` `).replace(/^\w/,e=>e.toUpperCase())}function u(e){return Math.abs(e)>=1e3?new Intl.NumberFormat(`en-US`,{maximumFractionDigits:2}).format(e):Number.isInteger(e)?String(e):e.toFixed(2)}function d(e){return e.toLocaleDateString(`en-US`,{year:`numeric`,month:`short`,day:`numeric`})}function f(e){if(!/^\d{4}-\d{2}-\d{2}/.test(e))return!1;let t=new Date(e);return!isNaN(t.getTime())}export{e as schemaToMarkdown,r as schemaToMarkdownDetail,n as schemaToMarkdownList,i as schemaToMarkdownSummary,t as schemaToMarkdownTable};
@@ -1 +1 @@
1
- import{hydrateResourceIfNeeded as e,parseReturns as t}from"../contracts-adapter-hydration.js";import{createInputTypeBuilder as n}from"../contracts-adapter-input.js";import{defaultGqlField as r}from"../jsonschema.js";import"@pothos/plugin-prisma";import"@pothos/plugin-complexity";import"@pothos/plugin-relay";import"@pothos/plugin-dataloader";import"@pothos/plugin-tracing";function i(i,a,o){let{buildInputFieldArgs:s}=n(i),c=new Map;for(let e of a.listSpecs()){let t=e.io.output;if(t&&`getZod`in t&&typeof t.getZod==`function`){let e=t,n=e.config?.name??`UnknownOutput`;c.has(n)||c.set(n,e)}}for(let[e,t]of c.entries())i.objectType(e,{fields:e=>{let n=Object.entries(t.config.fields),r={};for(let[t,i]of n){let n=i.type,a=`JSON`;n&&typeof n.getPothos==`function`&&(a=n.getPothos().name||`JSON`,a===`String_unsecure`&&(a=`String`),a===`Int_unsecure`&&(a=`Int`),a===`Float_unsecure`&&(a=`Float`),a===`Boolean_unsecure`&&(a=`Boolean`),a===`ID_unsecure`&&(a=`ID`));let o=i.isArray?[a]:a;r[t]=e.field({type:o,nullable:i.isOptional,resolve:e=>e[t]})}return r}});function l(e){let t=e.transport?.gql?.returns;if(t)return t;let n=e.io.output??{};if(n&&`kind`in n&&n.kind===`resource_ref`&&`graphQLType`in n&&n.graphQLType)return String(n.graphQLType);if(n&&`getZod`in n&&typeof n.getZod==`function`){let e=n.config?.name;if(e&&c.has(e))return e}return`JSON`}for(let n of a.listSpecs()){let c=n.transport?.gql?.field??r(n.meta.name,n.meta.version);n.transport?.gql?.returns;let u=n.transport?.gql?.byIdField??`id`,d=n.transport?.gql?.resource,f=n.meta.kind===`query`,p=l(n),m=n.transport?.gql?.returns,h=t(m??p),g=async(t,r,i)=>{if(n.policy.auth!==`anonymous`&&!i.user)throw Error(`Unauthorized`);let s={traceId:i.logger?.getTraceId?.()??void 0,userId:i.user?.id??null,organizationId:i.session?.activeOrganizationId??null,actor:i.user?`user`:`anonymous`,channel:`web`,eventPublisher:i.eventPublisher},c=n.io.input?.getZod().parse(r.input??{}),l=await a.execute(n.meta.name,n.meta.version,c,s),f=n.io.output;if(o&&(d||f?.kind===`resource_ref`)){let t=u??f?.varName??`id`,n=await e(o,l,{template:d??f?.uriTemplate,varName:t,returns:h});if(n!==l)return n}return p?h.inner===`Boolean`&&!h.isList?!!(l?.ok??l):l:n.io.output.getZod().parse(l)},_=e=>{let t=s(n.io.input);return e.field({type:h.isList?[h.inner]:h.inner,complexity:()=>10,resolve:g,args:t?{input:e.arg({type:t,required:!0})}:void 0})};f?i.queryField(c,_):i.mutationField(c,_)}}export{i as registerContractsOnBuilder};
1
+ import{hydrateResourceIfNeeded as e,parseReturns as t}from"../contracts-adapter-hydration.js";import{createInputTypeBuilder as n}from"../contracts-adapter-input.js";import{defaultGqlField as r}from"../jsonschema.js";import"../node_modules/@pothos/plugin-prisma/esm/index.js";import"../node_modules/@pothos/plugin-complexity/esm/index.js";import"../node_modules/@pothos/plugin-dataloader/esm/index.js";import"../node_modules/@pothos/plugin-tracing/esm/index.js";import"@pothos/plugin-relay";function i(i,a,o){let{buildInputFieldArgs:s}=n(i),c=new Map;for(let e of a.listSpecs()){let t=e.io.output;if(t&&`getZod`in t&&typeof t.getZod==`function`){let e=t,n=e.config?.name??`UnknownOutput`;c.has(n)||c.set(n,e)}}for(let[e,t]of c.entries())i.objectType(e,{fields:e=>{let n=Object.entries(t.config.fields),r={};for(let[t,i]of n){let n=i.type,a=`JSON`;n&&typeof n.getPothos==`function`&&(a=n.getPothos().name||`JSON`,a===`String_unsecure`&&(a=`String`),a===`Int_unsecure`&&(a=`Int`),a===`Float_unsecure`&&(a=`Float`),a===`Boolean_unsecure`&&(a=`Boolean`),a===`ID_unsecure`&&(a=`ID`));let o=i.isArray?[a]:a;r[t]=e.field({type:o,nullable:i.isOptional,resolve:e=>e[t]})}return r}});function l(e){let t=e.transport?.gql?.returns;if(t)return t;let n=e.io.output??{};if(n&&`kind`in n&&n.kind===`resource_ref`&&`graphQLType`in n&&n.graphQLType)return String(n.graphQLType);if(n&&`getZod`in n&&typeof n.getZod==`function`){let e=n.config?.name;if(e&&c.has(e))return e}return`JSON`}for(let n of a.listSpecs()){let c=n.transport?.gql?.field??r(n.meta.name,n.meta.version);n.transport?.gql?.returns;let u=n.transport?.gql?.byIdField??`id`,d=n.transport?.gql?.resource,f=n.meta.kind===`query`,p=l(n),m=n.transport?.gql?.returns,h=t(m??p),g=async(t,r,i)=>{if(n.policy.auth!==`anonymous`&&!i.user)throw Error(`Unauthorized`);let s={traceId:i.logger?.getTraceId?.()??void 0,userId:i.user?.id??null,organizationId:i.session?.activeOrganizationId??null,actor:i.user?`user`:`anonymous`,channel:`web`,eventPublisher:i.eventPublisher},c=n.io.input?.getZod().parse(r.input??{}),l=await a.execute(n.meta.name,n.meta.version,c,s),f=n.io.output;if(o&&(d||f?.kind===`resource_ref`)){let t=u??f?.varName??`id`,n=await e(o,l,{template:d??f?.uriTemplate,varName:t,returns:h});if(n!==l)return n}return p?h.inner===`Boolean`&&!h.isList?!!(l?.ok??l):l:n.io.output.getZod().parse(l)},_=e=>{let t=s(n.io.input);return e.field({type:h.isList?[h.inner]:h.inner,complexity:()=>10,resolve:g,args:t?{input:e.arg({type:t,required:!0})}:void 0})};f?i.queryField(c,_):i.mutationField(c,_)}}export{i as registerContractsOnBuilder};
@@ -1 +1 @@
1
- import{registerContractsOnBuilder as e}from"./graphql-pothos.js";import{exportContractsToGraphQLSchema as t}from"./graphql-schema-export.js";import{createMcpServer as n}from"./provider-mcp.js";import{createFetchHandler as r}from"./rest-generic.js";import{elysiaPlugin as i}from"./rest-elysia.js";import{expressRouter as a}from"./rest-express.js";import{makeNextAppHandler as o}from"./rest-next-app.js";import{makeNextPagesHandler as s}from"./rest-next-pages.js";export{r as createFetchHandler,n as createMcpServer,i as elysiaPlugin,t as exportContractsToGraphQLSchema,a as expressRouter,o as makeNextAppHandler,s as makeNextPagesHandler,e as registerContractsOnBuilder};
1
+ import{registerContractsOnBuilder as e}from"./graphql-pothos.js";import{createMcpServer as t}from"./mcp/createMcpServer.js";import"./provider-mcp.js";import{createFetchHandler as n}from"./rest-generic.js";import{elysiaPlugin as r}from"./rest-elysia.js";import{expressRouter as i}from"./rest-express.js";import{makeNextAppHandler as a}from"./rest-next-app.js";import{makeNextPagesHandler as o}from"./rest-next-pages.js";export{n as createFetchHandler,t as createMcpServer,r as elysiaPlugin,i as expressRouter,a as makeNextAppHandler,o as makeNextPagesHandler,e as registerContractsOnBuilder};
@@ -0,0 +1 @@
1
+ import{registerMcpTools as e}from"./registerTools.js";import{registerMcpResources as t}from"./registerResources.js";import{registerMcpPrompts as n}from"./registerPrompts.js";import{registerMcpPresentations as r}from"./registerPresentations.js";function i(i,a,o,s,c){return c.logger.info(`Creating MCP server`),e(i,a,{toolCtx:c.toolCtx}),t(i,o,{logger:c.logger,resourceCtx:c.resourceCtx}),r(i,{logger:c.logger,presentations:c.presentations,presentationsV2:c.presentationsV2}),n(i,s,{promptCtx:c.promptCtx}),i}export{i as createMcpServer};
File without changes
@@ -0,0 +1 @@
1
+ import{createDefaultTransformEngine as e,registerBasicValidation as t,registerDefaultReactRenderer as n}from"../../presentations.v2.js";import{jsonSchemaForPresentation as r}from"../../presentations.js";function i(e){return!e||typeof e!=`object`?!1:`body`in e&&typeof e.body==`string`}function a(a,o){let s=o.presentations,c=o.presentationsV2;if(s)for(let e of s.list()){let t=`presentation.${e.meta.name.replace(/\./g,`_`)}.v${e.meta.version}`,n=`presentation://${e.meta.name}/v${e.meta.version}`;a.registerResource(t,n,{title:`${e.meta.name} v${e.meta.version}`,description:e.meta.description??`Presentation`},async()=>{if(e.content.kind===`markdown`)return{contents:[{uri:n,mimeType:`text/markdown`,text:e.content.content?e.content.content:`See resource: ${e.content.resourceUri??``}`}]};if(e.content.kind===`data`){let t=r(e);return{contents:[{uri:n,mimeType:`application/json`,text:JSON.stringify(t,null,2)}]}}let t={name:e.meta.name,version:e.meta.version,kind:e.content.kind,description:e.meta.description??``};return{contents:[{uri:n,mimeType:`application/json`,text:JSON.stringify(t,null,2)}]}});for(let i of[{ext:`.md`,target:`markdown`},{ext:`.json`,target:`application/json`},{ext:`.xml`,target:`application/xml`}]){let s=`${t}${i.ext}`,c=`${n}${i.ext}`;o.logger.info(`Registering presentation resource ${c} for ${s}`),a.registerResource(s,c,{title:`${e.meta.name} v${e.meta.version} (${i.ext})`,description:`${e.meta.description??`Presentation`} (${i.ext})`},async()=>{if(e.content.kind===`markdown`&&i.target===`markdown`)return{contents:[{uri:c,mimeType:`text/markdown`,text:e.content.content??`See resource: ${e.content.resourceUri??``}`}]};if(e.content.kind===`data`&&i.target===`application/json`)return{contents:[{uri:c,mimeType:`application/json`,text:JSON.stringify(r(e),null,2)}]};let t=JSON.stringify({meta:e.meta,content:e.content},null,2);return i.target===`application/json`?{contents:[{uri:c,mimeType:`application/json`,text:t}]}:i.target===`application/xml`?{contents:[{uri:c,mimeType:`application/xml`,text:`<presentation name="${e.meta.name}" version="${e.meta.version}"><json>${encodeURIComponent(t)}</json></presentation>`}]}:{contents:[{uri:c,mimeType:`text/markdown`,text:`Unsupported presentation for markdown`}]}})}}if(c&&c.length){let r=t(n(e()));for(let e of c){let t=`presentation.${e.meta.name.replace(/\./g,`_`)}.v${e.meta.version}`,n=`presentation://${e.meta.name}/v${e.meta.version}`;o.logger.info(`Registering presentation descriptor ${n} for ${t}`),a.registerResource(t,n,{title:`${e.meta.name} v${e.meta.version}`,description:e.meta.description??`Presentation`,mimeType:`application/json`},async()=>({contents:[{uri:n,mimeType:`application/json`,text:JSON.stringify({meta:e.meta,source:e.source,targets:e.targets},null,2)}]}));for(let o of[{ext:`.md`,target:`markdown`},{ext:`.json`,target:`application/json`},{ext:`.xml`,target:`application/xml`}]){let s=`${t}${o.ext}`,c=`${n}${o.ext}`;a.registerResource(s,c,{title:`${e.meta.name} v${e.meta.version} (${o.ext})`,description:`${e.meta.description??`Presentation`} (${o.ext})`},async()=>{let t=await r.render(o.target,e);return{contents:[{uri:c,mimeType:i(t)&&t.mimeType?t.mimeType:o.target===`markdown`?`text/markdown`:o.target,text:i(t)&&typeof t.body==`string`?t.body:String(t)}]}})}}}}export{a as registerMcpPresentations};
@@ -0,0 +1,3 @@
1
+ import e from"zod";function t(e){let t={};for(let n of e)t[n.name]=n.schema;return t}function n(e,n,r){for(let i of n.list())e.registerPrompt(i.meta.name,{title:i.meta.title,description:i.meta.description,argsSchema:t(i.args)},async e=>{let t=(e,t)=>{let n=e;for(let[e,r]of Object.entries(t))n=n.replace(RegExp(`\\{${e}\\}`,`g`),encodeURIComponent(String(r)));return n};return{messages:[{role:`assistant`,content:{type:`text`,text:(await i.render(i.input.parse(e),{...r.promptCtx(),link:t})).map(e=>e.type===`text`?e.text:`See resource: ${e.title??e.uri}\nURI: ${e.uri}`).join(`
2
+
3
+ `)}}],description:i.meta.description}})}export{n as registerMcpPrompts};
@@ -0,0 +1 @@
1
+ import{ResourceTemplate as e}from"@modelcontextprotocol/sdk/server/mcp.js";import{Buffer as t}from"node:buffer";function n(e){return{title:e.meta.title,description:e.meta.description,mimeType:e.meta.mimeType,_meta:{tags:e.meta.tags??[]}}}function r(r,i,a){for(let o of i.listTemplates())a.logger.info(`Registering resource: `+o.meta.uriTemplate),r.registerResource(o.meta.uriTemplate,new e(o.meta.uriTemplate,{list:void 0}),n(o),async(e,n)=>{let r=o.input.parse(n),i=await o.resolve(r,a.resourceCtx());return typeof i.data==`string`?{contents:[{uri:i.uri,mimeType:i.mimeType??o.meta.mimeType,text:i.data}]}:{contents:[{uri:i.uri,mimeType:i.mimeType??o.meta.mimeType,blob:t.from(i.data).toString(`base64`)}]}}),a.logger.info(`Registered resource: `+o.meta.uriTemplate)}export{r as registerMcpResources};
@@ -0,0 +1 @@
1
+ import{defaultMcpTool as e}from"../../jsonschema.js";function t(t,n,r){for(let i of n.listSpecs()){if(i.meta.kind!==`command`)continue;let a=i.transport?.mcp?.toolName??e(i.meta.name,i.meta.version);t.registerTool(a,{description:i.meta.description,inputSchema:i.io.input?.getZod()},async e=>{let t=await n.execute(i.meta.name,i.meta.version,e??{},r.toolCtx());return{content:[{type:`text`,text:JSON.stringify(t,null,4)}]}})}}export{t as registerMcpTools};
@@ -1 +1 @@
1
- import{createDefaultTransformEngine as e,registerBasicValidation as t,registerDefaultReactRenderer as n}from"../presentations.v2.js";import{defaultMcpTool as r,jsonSchemaForSpec as i}from"../jsonschema.js";import{jsonSchemaForPresentation as a}from"../presentations.js";import o from"zod";import{McpServer as s,ResourceTemplate as c}from"@modelcontextprotocol/sdk/server/mcp.js";import{zodToJsonSchema as l}from"zod-to-json-schema";function u(s,u,d,f,p){for(let e of u.listSpecs()){if(e.meta.kind!==`command`)continue;let{input:t}=i(e),n=e.transport?.mcp?.toolName??r(e.meta.name,e.meta.version);s.registerTool(n,{description:e.meta.description,inputSchema:t},async(t,n)=>{let r=await u.execute(e.meta.name,e.meta.version,t??{},p.toolCtx());return{content:[{type:`text`,text:JSON.stringify(r,null,4)}]}})}for(let e of d.listTemplates())s.registerResource(e.meta.uriTemplate.split(`:`)[0],new c(e.meta.uriTemplate,{}),{description:e.meta.description,inputSchema:l(e.input,{})},async(t,n,r)=>{let i=p.resourceCtx(),a=await e.resolve(n,i);return typeof a.data==`string`?{contents:[{uri:a.uri,mimeType:a.mimeType??e.meta.mimeType,text:a.data}]}:{contents:[{uri:a.uri,mimeType:a.mimeType??e.meta.mimeType,blob:a.data.toString()}]}});let m=p.presentations,h=p.presentationsV2;if(m){t(n(e()));for(let e of m.list()){let t=`presentation.${e.meta.name.replace(/\./g,`_`)}.v${e.meta.version}`,n=`presentation://${e.meta.name}/v${e.meta.version}`;s.registerResource(t,new c(n,{}),{description:e.meta.description??`Presentation`,inputSchema:o.toJSONSchema(o.object({}))},async(t,r,i)=>{if(e.content.kind===`markdown`)return{contents:[{uri:n,mimeType:`text/markdown`,text:e.content.content?e.content.content:`See resource: ${e.content.resourceUri??``}`}]};if(e.content.kind===`data`){let t=a(e);return{contents:[{uri:n,mimeType:`application/json`,text:JSON.stringify(t,null,2)}]}}let o={name:e.meta.name,version:e.meta.version,kind:e.content.kind,description:e.meta.description??``};return{contents:[{uri:n,mimeType:`application/json`,text:JSON.stringify(o,null,2)}]}});for(let r of[{ext:`.md`,target:`markdown`},{ext:`.json`,target:`application/json`},{ext:`.xml`,target:`application/xml`}]){let i=`${t}${r.ext}`,l=`${n}${r.ext}`;s.registerResource(i,new c(l,{}),{description:`${e.meta.description??`Presentation`} (${r.ext})`,inputSchema:o.toJSONSchema(o.object({}))},async()=>{if(e.content.kind===`markdown`&&r.target===`markdown`)return{contents:[{uri:l,mimeType:`text/markdown`,text:e.content.content??`See resource: ${e.content.resourceUri??``}`}]};if(e.content.kind===`data`&&r.target===`application/json`)return{contents:[{uri:l,mimeType:`application/json`,text:JSON.stringify(a(e),null,2)}]};let t=JSON.stringify({meta:e.meta,content:e.content},null,2);return r.target===`application/json`?{contents:[{uri:l,mimeType:`application/json`,text:t}]}:r.target===`application/xml`?{contents:[{uri:l,mimeType:`application/xml`,text:`<presentation name="${e.meta.name}" version="${e.meta.version}"><json>${encodeURIComponent(t)}</json></presentation>`}]}:{contents:[{uri:l,mimeType:`text/markdown`,text:`Unsupported presentation for markdown`}]}})}}}if(h&&h.length){let r=t(n(e()));for(let e of h){let t=`presentation.${e.meta.name.replace(/\./g,`_`)}.v${e.meta.version}`,n=`presentation://${e.meta.name}/v${e.meta.version}`;s.registerResource(t,new c(n,{}),{description:e.meta.description??`Presentation`,inputSchema:o.toJSONSchema(o.object({}))},async()=>({contents:[{uri:n,mimeType:`application/json`,text:JSON.stringify({meta:e.meta,source:e.source,targets:e.targets},null,2)}]}));for(let i of[{ext:`.md`,target:`markdown`},{ext:`.json`,target:`application/json`},{ext:`.xml`,target:`application/xml`}]){let a=`${t}${i.ext}`,l=`${n}${i.ext}`;s.registerResource(a,new c(l,{}),{description:`${e.meta.description??`Presentation`} (${i.ext})`,inputSchema:o.toJSONSchema(o.object({}))},async()=>{let t=await r.render(i.target,e);return{contents:[{uri:l,mimeType:t.mimeType??(i.target===`markdown`?`text/markdown`:i.target),text:t.body??String(t)}]}})}}}for(let e of f.list())s.registerPrompt(e.meta.name,{title:e.meta.title,description:e.meta.title,argsSchema:l(e.input)},async(t,n)=>{let r=(e,t)=>{let n=e;for(let[e,r]of Object.entries(t))n=n.replace(RegExp(`\\{${e}\\}`,`g`),encodeURIComponent(String(r)));return n};return{messages:[{role:`assistant`,content:(await e.render(e.input.parse(t),{...p.promptCtx(),link:r})).map(e=>e.type===`text`?{type:`text`,text:e.text}:{type:`text`,text:`See resource: ${e.title??e.uri}\nURI: ${e.uri}`})[0]}],description:e.meta.description}});return s}export{u as createMcpServer};
1
+ import{createMcpServer as e}from"./mcp/createMcpServer.js";export{e as createMcpServer};
@@ -0,0 +1,139 @@
1
+ import{registerDocBlocks as e}from"../../docs/registry.js";import"../../registry.js";const t=[{id:`docs.tech.contracts.telemetry`,title:`TelemetrySpec`,summary:"Telemetry specs describe product analytics in a durable, type-safe way. They reference existing `EventSpec`s (same name/version) but layer on privacy classification, retention, sampling, and anomaly detection so instrumentation stays compliant and observable.",kind:`reference`,visibility:`public`,route:`/docs/tech/contracts/telemetry`,tags:[`tech`,`contracts`,`telemetry`],body:`## TelemetrySpec
2
+
3
+ Telemetry specs describe product analytics in a durable, type-safe way. They reference existing \`EventSpec\`s (same name/version) but layer on privacy classification, retention, sampling, and anomaly detection so instrumentation stays compliant and observable.
4
+
5
+ - **File location**: \`packages/libs/contracts/src/telemetry/spec.ts\`
6
+ - **Runtime tracker**: \`packages/libs/contracts/src/telemetry/tracker.ts\`
7
+ - **Anomaly monitor**: \`packages/libs/contracts/src/telemetry/anomaly.ts\`
8
+
9
+ ### Core concepts
10
+
11
+ \`\`\`ts
12
+ export interface TelemetrySpec {
13
+ meta: TelemetryMeta;
14
+ events: TelemetryEventDef[];
15
+ config?: TelemetryConfig;
16
+ }
17
+ \`\`\`
18
+
19
+ - \`meta\`: ownership + identifiers (\`name\`, \`version\`, \`domain\`)
20
+ - \`events\`: per-event semantics, property definitions, privacy level, retention, sampling, anomaly rules
21
+ - \`config\`: defaults and provider configuration
22
+ - \`TelemetryRegistry\`: registers specs, resolves latest version, finds event definitions by name/version
23
+
24
+ ### An example
25
+
26
+ \`\`\`ts
27
+ export const SigilTelemetry: TelemetrySpec = {
28
+ meta: {
29
+ name: 'sigil.telemetry',
30
+ version: 1,
31
+ title: 'Sigil telemetry',
32
+ description: 'Core Sigil product telemetry',
33
+ domain: 'sigil',
34
+ owners: ['@team.analytics'],
35
+ tags: ['telemetry'],
36
+ stability: StabilityEnum.Experimental,
37
+ },
38
+ config: {
39
+ defaultRetentionDays: 30,
40
+ defaultSamplingRate: 1,
41
+ providers: [
42
+ { type: 'posthog', config: { projectApiKey: process.env.POSTHOG_KEY } },
43
+ ],
44
+ },
45
+ events: [
46
+ {
47
+ name: 'sigil.telemetry.workflow_step',
48
+ version: 1,
49
+ semantics: {
50
+ what: 'Workflow step executed',
51
+ who: 'Actor executing the workflow',
52
+ },
53
+ privacy: 'internal',
54
+ properties: {
55
+ workflow: { type: 'string', required: true },
56
+ step: { type: 'string', required: true },
57
+ durationMs: { type: 'number' },
58
+ userId: { type: 'string', pii: true, redact: true },
59
+ },
60
+ anomalyDetection: {
61
+ enabled: true,
62
+ minimumSample: 10,
63
+ thresholds: [
64
+ { metric: 'durationMs', max: 1500 },
65
+ ],
66
+ actions: ['alert', 'trigger_regen'],
67
+ },
68
+ },
69
+ ],
70
+ };
71
+ \`\`\`
72
+
73
+ ### Tracking events at runtime
74
+
75
+ \`TelemetryTracker\` performs sampling, PII redaction, provider dispatch, and anomaly detection.
76
+
77
+ \`\`\`ts
78
+ const tracker = new TelemetryTracker({
79
+ registry: telemetryRegistry,
80
+ providers: [
81
+ {
82
+ id: 'posthog',
83
+ async send(dispatch) {
84
+ posthog.capture({
85
+ event: dispatch.name,
86
+ properties: dispatch.properties,
87
+ distinctId: dispatch.context.userId ?? dispatch.context.sessionId,
88
+ });
89
+ },
90
+ },
91
+ ],
92
+ anomalyMonitor: new TelemetryAnomalyMonitor({
93
+ onAnomaly(event) {
94
+ console.warn('Telemetry anomaly detected', event);
95
+ },
96
+ }),
97
+ });
98
+
99
+ await tracker.track('sigil.telemetry.workflow_step', 1, {
100
+ workflow: 'onboarding',
101
+ step: 'verify_email',
102
+ durationMs: 2100,
103
+ userId: 'user-123',
104
+ });
105
+ \`\`\`
106
+
107
+ - Sampling obeys the event-specific rate (fallback to spec defaults)
108
+ - Properties flagged with \`pii\` or \`redact\` are masked before dispatch
109
+ - Anomaly monitor evaluates thresholds and triggers actions (e.g., log, alert, regeneration)
110
+
111
+ ### Spec integration
112
+
113
+ - \`ContractSpec.telemetry\` allows operations to emit success/failure events automatically
114
+ - \`SpecRegistry.execute()\` uses the tracker when \`ctx.telemetry\` is provided
115
+ - \`WorkflowRunner\` (Phase 4 follow-up) will emit telemetry during step transitions
116
+ - \`TelemetrySpec\` events should reuse \`EventSpec\` names/versions to keep analytics/contract parity
117
+
118
+ ### CLI workflow
119
+
120
+ \`\`\`
121
+ contracts-cli create telemetry
122
+ \`\`\`
123
+
124
+ - Interactive wizard prompts for meta, providers, events, properties, retention, anomaly rules
125
+ - Output: \`*.telemetry.ts\` file using \`TelemetrySpec\`
126
+
127
+ ### Best practices
128
+
129
+ - Prefer \`internal\` privacy for non-PII; mark PII properties explicitly with \`pii\` + \`redact\`
130
+ - Keep sampling ≥0.05 except for high-volume events
131
+ - Configure anomaly detection on key metrics (duration, error count, conversion)
132
+ - Check telemetry into source control alongside contracts; regenerate via CLI when specs change
133
+
134
+ ### Next steps
135
+
136
+ - Phase 5: Regenerator monitors telemetry anomalies to propose spec improvements
137
+ - Phase 6: Studio surfaces telemetry controls per tenant via \`TenantAppConfig\`
138
+
139
+ `}];e(t);export{t as tech_contracts_telemetry_DocBlocks};