@lssm/example.kb-update-pipeline 0.0.0-canary-20251217060834 → 0.0.0-canary-20251217072406

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 (142) hide show
  1. package/.turbo/turbo-build$colon$bundle.log +220 -29
  2. package/.turbo/turbo-build.log +219 -28
  3. package/CHANGELOG.md +5 -5
  4. package/dist/contracts/index.js +3 -1
  5. package/dist/contracts/pipeline.d.ts +39 -39
  6. package/dist/contracts/pipeline.js +185 -1
  7. package/dist/docs/index.js +1 -1
  8. package/dist/docs/kb-update-pipeline.docblock.js +29 -17
  9. package/dist/entities/index.js +3 -1
  10. package/dist/entities/models.js +76 -1
  11. package/dist/events.d.ts +21 -21
  12. package/dist/events.js +127 -1
  13. package/dist/example.js +42 -1
  14. package/dist/feature.js +78 -1
  15. package/dist/handlers/index.js +3 -1
  16. package/dist/handlers/memory.handlers.js +92 -1
  17. package/dist/index.d.ts +0 -2
  18. package/dist/index.js +11 -1
  19. package/dist/kb-update-pipeline.feature.js +78 -1
  20. package/dist/libs/contracts/dist/capabilities/openbanking.js +88 -0
  21. package/dist/libs/contracts/dist/client/index.js +5 -0
  22. package/dist/libs/contracts/dist/client/react/feature-render.js +2 -0
  23. package/dist/libs/contracts/dist/client/react/form-render.js +4 -0
  24. package/dist/libs/contracts/dist/client/react/index.js +4 -0
  25. package/dist/libs/contracts/dist/contract-registry/index.js +1 -0
  26. package/dist/libs/contracts/dist/contract-registry/schemas.js +60 -0
  27. package/dist/libs/contracts/dist/docs/PUBLISHING.docblock.js +16 -0
  28. package/dist/libs/contracts/dist/docs/accessibility_wcag_compliance_specs.docblock.js +16 -0
  29. package/dist/libs/contracts/dist/docs/index.js +29 -0
  30. package/dist/libs/contracts/dist/docs/presentations.js +71 -0
  31. package/dist/libs/contracts/dist/docs/registry.js +44 -0
  32. package/dist/libs/contracts/dist/docs/tech/PHASE_1_QUICKSTART.docblock.js +16 -0
  33. package/dist/libs/contracts/dist/docs/tech/PHASE_2_AI_NATIVE_OPERATIONS.docblock.js +16 -0
  34. package/dist/libs/contracts/dist/docs/tech/PHASE_3_AUTO_EVOLUTION.docblock.js +16 -0
  35. package/dist/libs/contracts/dist/docs/tech/PHASE_4_PERSONALIZATION_ENGINE.docblock.js +16 -0
  36. package/dist/libs/contracts/dist/docs/tech/PHASE_5_ZERO_TOUCH_OPERATIONS.docblock.js +16 -0
  37. package/dist/libs/contracts/dist/docs/tech/auth/better-auth-nextjs.docblock.js +80 -0
  38. package/dist/libs/contracts/dist/docs/tech/contracts/openapi-export.docblock.js +57 -0
  39. package/dist/libs/contracts/dist/docs/tech/lifecycle-stage-system.docblock.js +16 -0
  40. package/dist/libs/contracts/dist/docs/tech/llm/llm-integration.docblock.js +357 -0
  41. package/dist/libs/contracts/dist/docs/tech/mcp-endpoints.docblock.js +37 -0
  42. package/dist/libs/contracts/dist/docs/tech/presentation-runtime.docblock.js +16 -0
  43. package/dist/libs/contracts/dist/docs/tech/schema/README.docblock.js +20 -0
  44. package/dist/libs/contracts/dist/docs/tech/studio/learning-events.docblock.js +48 -0
  45. package/dist/libs/contracts/dist/docs/tech/studio/learning-journeys.docblock.js +79 -0
  46. package/dist/libs/contracts/dist/docs/tech/studio/platform-admin-panel.docblock.js +84 -0
  47. package/dist/libs/contracts/dist/docs/tech/studio/project-access-teams.docblock.js +45 -0
  48. package/dist/libs/contracts/dist/docs/tech/studio/project-routing.docblock.js +67 -0
  49. package/dist/libs/contracts/dist/docs/tech/studio/sandbox-unlogged.docblock.js +40 -0
  50. package/dist/libs/contracts/dist/docs/tech/studio/team-invitations.docblock.js +69 -0
  51. package/dist/libs/contracts/dist/docs/tech/studio/workspace-ops.docblock.js +47 -0
  52. package/dist/libs/contracts/dist/docs/tech/studio/workspaces.docblock.js +62 -0
  53. package/dist/libs/contracts/dist/docs/tech/telemetry-ingest.docblock.js +155 -0
  54. package/dist/libs/contracts/dist/docs/tech/templates/runtime.docblock.js +20 -0
  55. package/dist/libs/contracts/dist/docs/tech/vscode-extension.docblock.js +101 -0
  56. package/dist/libs/contracts/dist/docs/tech/workflows/overview.docblock.js +20 -0
  57. package/dist/libs/contracts/dist/events.js +10 -0
  58. package/dist/libs/contracts/dist/experiments/evaluator.js +1 -0
  59. package/dist/libs/contracts/dist/index.js +71 -0
  60. package/dist/libs/contracts/dist/install.js +2 -0
  61. package/dist/libs/contracts/dist/integrations/contracts.js +377 -0
  62. package/dist/libs/contracts/dist/integrations/index.js +18 -0
  63. package/dist/libs/contracts/dist/integrations/openbanking/contracts/accounts.js +228 -0
  64. package/dist/libs/contracts/dist/integrations/openbanking/contracts/balances.js +159 -0
  65. package/dist/libs/contracts/dist/integrations/openbanking/contracts/index.js +3 -0
  66. package/dist/libs/contracts/dist/integrations/openbanking/contracts/transactions.js +210 -0
  67. package/dist/libs/contracts/dist/integrations/openbanking/models.js +242 -0
  68. package/dist/libs/contracts/dist/integrations/openbanking/telemetry.js +13 -0
  69. package/dist/libs/contracts/dist/integrations/providers/elevenlabs.js +52 -0
  70. package/dist/libs/contracts/dist/integrations/providers/gcs-storage.js +75 -0
  71. package/dist/libs/contracts/dist/integrations/providers/gmail.js +87 -0
  72. package/dist/libs/contracts/dist/integrations/providers/google-calendar.js +66 -0
  73. package/dist/libs/contracts/dist/integrations/providers/index.js +11 -0
  74. package/dist/libs/contracts/dist/integrations/providers/mistral.js +68 -0
  75. package/dist/libs/contracts/dist/integrations/providers/postmark.js +68 -0
  76. package/dist/libs/contracts/dist/integrations/providers/powens.js +116 -0
  77. package/dist/libs/contracts/dist/integrations/providers/qdrant.js +73 -0
  78. package/dist/libs/contracts/dist/integrations/providers/registry.js +10 -0
  79. package/dist/libs/contracts/dist/integrations/providers/stripe.js +83 -0
  80. package/dist/libs/contracts/dist/integrations/providers/twilio-sms.js +61 -0
  81. package/dist/libs/contracts/dist/jsonschema.js +1 -0
  82. package/dist/libs/contracts/dist/knowledge/contracts.js +306 -0
  83. package/dist/libs/contracts/dist/knowledge/index.js +7 -0
  84. package/dist/libs/contracts/dist/knowledge/spaces/email-threads.js +34 -0
  85. package/dist/libs/contracts/dist/knowledge/spaces/financial-docs.js +34 -0
  86. package/dist/libs/contracts/dist/knowledge/spaces/financial-overview.js +38 -0
  87. package/dist/libs/contracts/dist/knowledge/spaces/index.js +6 -0
  88. package/dist/libs/contracts/dist/knowledge/spaces/product-canon.js +34 -0
  89. package/dist/libs/contracts/dist/knowledge/spaces/support-faq.js +37 -0
  90. package/dist/libs/contracts/dist/knowledge/spaces/uploaded-docs.js +34 -0
  91. package/dist/libs/contracts/dist/llm/exporters.js +19 -0
  92. package/dist/libs/contracts/dist/llm/index.js +2 -0
  93. package/dist/libs/contracts/dist/llm/prompts.js +1 -0
  94. package/dist/libs/contracts/dist/onboarding-base.js +196 -0
  95. package/dist/libs/contracts/dist/openapi.js +1 -0
  96. package/dist/libs/contracts/dist/ownership.js +21 -0
  97. package/dist/libs/contracts/dist/presentations.js +1 -0
  98. package/dist/libs/contracts/dist/presentations.v2.js +11 -0
  99. package/dist/libs/contracts/dist/prompt.js +1 -0
  100. package/dist/libs/contracts/dist/promptRegistry.js +1 -0
  101. package/dist/libs/contracts/dist/regenerator/index.js +1 -0
  102. package/dist/libs/contracts/dist/regenerator/service.js +6 -0
  103. package/dist/libs/contracts/dist/registry.js +2 -0
  104. package/dist/libs/contracts/dist/resources.js +1 -0
  105. package/dist/libs/contracts/dist/schema/dist/EnumType.js +2 -0
  106. package/dist/libs/contracts/dist/schema/dist/FieldType.js +49 -0
  107. package/dist/libs/contracts/dist/schema/dist/ScalarTypeEnum.js +236 -0
  108. package/dist/libs/contracts/dist/schema/dist/SchemaModel.js +39 -0
  109. package/dist/libs/contracts/dist/schema/dist/entity/defineEntity.js +1 -0
  110. package/dist/libs/contracts/dist/schema/dist/entity/index.js +2 -0
  111. package/dist/libs/contracts/dist/schema/dist/entity/types.js +1 -0
  112. package/dist/libs/contracts/dist/schema/dist/index.js +6 -0
  113. package/dist/libs/contracts/dist/server/graphql-pothos.js +6 -0
  114. package/dist/libs/contracts/dist/server/index.js +8 -0
  115. package/dist/libs/contracts/dist/server/mcp/createMcpServer.js +4 -0
  116. package/dist/libs/contracts/dist/server/mcp/registerPresentations.js +2 -0
  117. package/dist/libs/contracts/dist/server/mcp/registerPrompts.js +1 -0
  118. package/dist/libs/contracts/dist/server/mcp/registerResources.js +2 -0
  119. package/dist/libs/contracts/dist/server/mcp/registerTools.js +1 -0
  120. package/dist/libs/contracts/dist/server/provider-mcp.js +1 -0
  121. package/dist/libs/contracts/dist/server/rest-elysia.js +1 -0
  122. package/dist/libs/contracts/dist/server/rest-express.js +1 -0
  123. package/dist/libs/contracts/dist/server/rest-generic.js +1 -0
  124. package/dist/libs/contracts/dist/server/rest-next-app.js +1 -0
  125. package/dist/libs/contracts/dist/server/rest-next-pages.js +1 -0
  126. package/dist/libs/contracts/dist/spec.js +34 -0
  127. package/dist/libs/contracts/dist/telemetry/index.js +1 -0
  128. package/dist/libs/contracts/dist/telemetry/tracker.js +1 -0
  129. package/dist/libs/contracts/dist/tests/index.js +1 -0
  130. package/dist/libs/contracts/dist/tests/runner.js +2 -0
  131. package/dist/libs/contracts/dist/workflow/index.js +1 -0
  132. package/dist/libs/contracts/dist/workflow/runner.js +1 -0
  133. package/dist/libs/schema/dist/EnumType.js +56 -0
  134. package/dist/libs/schema/dist/FieldType.js +49 -0
  135. package/dist/libs/schema/dist/ScalarTypeEnum.js +236 -0
  136. package/dist/libs/schema/dist/SchemaModel.js +39 -0
  137. package/dist/libs/schema/dist/entity/defineEntity.js +1 -0
  138. package/dist/libs/schema/dist/entity/index.js +2 -0
  139. package/dist/libs/schema/dist/entity/types.js +1 -0
  140. package/dist/libs/schema/dist/index.js +6 -0
  141. package/package.json +7 -7
  142. package/tsconfig.tsbuildinfo +1 -1
package/dist/events.js CHANGED
@@ -1 +1,127 @@
1
- import{defineEvent as e,defineSchemaModel as t}from"@lssm/lib.contracts";import{ScalarTypeEnum as n}from"@lssm/lib.schema";const r=e({name:`kb.change.detected`,version:1,description:`KB source change detected.`,payload:t({name:`KbChangeDetectedPayload`,description:`Emitted when a source change is detected.`,fields:{changeCandidateId:{type:n.String_unsecure(),isOptional:!1},sourceDocumentId:{type:n.String_unsecure(),isOptional:!1},riskLevel:{type:n.String_unsecure(),isOptional:!1}}})}),i=e({name:`kb.change.summarized`,version:1,description:`KB change summarized.`,payload:t({name:`KbChangeSummarizedPayload`,description:`Emitted when a change summary is produced.`,fields:{changeCandidateId:{type:n.String_unsecure(),isOptional:!1},summary:{type:n.String_unsecure(),isOptional:!1},riskLevel:{type:n.String_unsecure(),isOptional:!1}}})}),a=e({name:`kb.patch.proposed`,version:1,description:`KB rule patch proposed (draft versions created).`,payload:t({name:`KbPatchProposedPayload`,description:`Emitted when draft rule patches are proposed.`,fields:{changeCandidateId:{type:n.String_unsecure(),isOptional:!1},proposedRuleVersionIds:{type:n.String_unsecure(),isArray:!0,isOptional:!1}}})}),o=e({name:`kb.review.requested`,version:1,description:`KB review requested.`,payload:t({name:`KbReviewRequestedPayload`,description:`Emitted when a review is requested.`,fields:{reviewTaskId:{type:n.String_unsecure(),isOptional:!1},changeCandidateId:{type:n.String_unsecure(),isOptional:!1},assignedRole:{type:n.String_unsecure(),isOptional:!1}}})}),s=e({name:`kb.review.decided`,version:1,description:`KB review decided.`,payload:t({name:`KbReviewDecidedPayload`,description:`Emitted when a review task is decided.`,fields:{reviewTaskId:{type:n.String_unsecure(),isOptional:!1},decision:{type:n.String_unsecure(),isOptional:!1},decidedBy:{type:n.String_unsecure(),isOptional:!1}}})});export{r as KbChangeDetectedEvent,i as KbChangeSummarizedEvent,a as KbPatchProposedEvent,s as KbReviewDecidedEvent,o as KbReviewRequestedEvent};
1
+ import { defineSchemaModel } from "./libs/contracts/dist/schema/dist/SchemaModel.js";
2
+ import { defineEvent } from "./libs/contracts/dist/events.js";
3
+ import "./libs/contracts/dist/index.js";
4
+ import { ScalarTypeEnum } from "./libs/schema/dist/ScalarTypeEnum.js";
5
+ import "./libs/schema/dist/index.js";
6
+
7
+ //#region src/events.ts
8
+ const KbChangeDetectedPayload = defineSchemaModel({
9
+ name: "KbChangeDetectedPayload",
10
+ description: "Emitted when a source change is detected.",
11
+ fields: {
12
+ changeCandidateId: {
13
+ type: ScalarTypeEnum.String_unsecure(),
14
+ isOptional: false
15
+ },
16
+ sourceDocumentId: {
17
+ type: ScalarTypeEnum.String_unsecure(),
18
+ isOptional: false
19
+ },
20
+ riskLevel: {
21
+ type: ScalarTypeEnum.String_unsecure(),
22
+ isOptional: false
23
+ }
24
+ }
25
+ });
26
+ const KbChangeDetectedEvent = defineEvent({
27
+ name: "kb.change.detected",
28
+ version: 1,
29
+ description: "KB source change detected.",
30
+ payload: KbChangeDetectedPayload
31
+ });
32
+ const KbChangeSummarizedPayload = defineSchemaModel({
33
+ name: "KbChangeSummarizedPayload",
34
+ description: "Emitted when a change summary is produced.",
35
+ fields: {
36
+ changeCandidateId: {
37
+ type: ScalarTypeEnum.String_unsecure(),
38
+ isOptional: false
39
+ },
40
+ summary: {
41
+ type: ScalarTypeEnum.String_unsecure(),
42
+ isOptional: false
43
+ },
44
+ riskLevel: {
45
+ type: ScalarTypeEnum.String_unsecure(),
46
+ isOptional: false
47
+ }
48
+ }
49
+ });
50
+ const KbChangeSummarizedEvent = defineEvent({
51
+ name: "kb.change.summarized",
52
+ version: 1,
53
+ description: "KB change summarized.",
54
+ payload: KbChangeSummarizedPayload
55
+ });
56
+ const KbPatchProposedPayload = defineSchemaModel({
57
+ name: "KbPatchProposedPayload",
58
+ description: "Emitted when draft rule patches are proposed.",
59
+ fields: {
60
+ changeCandidateId: {
61
+ type: ScalarTypeEnum.String_unsecure(),
62
+ isOptional: false
63
+ },
64
+ proposedRuleVersionIds: {
65
+ type: ScalarTypeEnum.String_unsecure(),
66
+ isArray: true,
67
+ isOptional: false
68
+ }
69
+ }
70
+ });
71
+ const KbPatchProposedEvent = defineEvent({
72
+ name: "kb.patch.proposed",
73
+ version: 1,
74
+ description: "KB rule patch proposed (draft versions created).",
75
+ payload: KbPatchProposedPayload
76
+ });
77
+ const KbReviewRequestedPayload = defineSchemaModel({
78
+ name: "KbReviewRequestedPayload",
79
+ description: "Emitted when a review is requested.",
80
+ fields: {
81
+ reviewTaskId: {
82
+ type: ScalarTypeEnum.String_unsecure(),
83
+ isOptional: false
84
+ },
85
+ changeCandidateId: {
86
+ type: ScalarTypeEnum.String_unsecure(),
87
+ isOptional: false
88
+ },
89
+ assignedRole: {
90
+ type: ScalarTypeEnum.String_unsecure(),
91
+ isOptional: false
92
+ }
93
+ }
94
+ });
95
+ const KbReviewRequestedEvent = defineEvent({
96
+ name: "kb.review.requested",
97
+ version: 1,
98
+ description: "KB review requested.",
99
+ payload: KbReviewRequestedPayload
100
+ });
101
+ const KbReviewDecidedPayload = defineSchemaModel({
102
+ name: "KbReviewDecidedPayload",
103
+ description: "Emitted when a review task is decided.",
104
+ fields: {
105
+ reviewTaskId: {
106
+ type: ScalarTypeEnum.String_unsecure(),
107
+ isOptional: false
108
+ },
109
+ decision: {
110
+ type: ScalarTypeEnum.String_unsecure(),
111
+ isOptional: false
112
+ },
113
+ decidedBy: {
114
+ type: ScalarTypeEnum.String_unsecure(),
115
+ isOptional: false
116
+ }
117
+ }
118
+ });
119
+ const KbReviewDecidedEvent = defineEvent({
120
+ name: "kb.review.decided",
121
+ version: 1,
122
+ description: "KB review decided.",
123
+ payload: KbReviewDecidedPayload
124
+ });
125
+
126
+ //#endregion
127
+ export { KbChangeDetectedEvent, KbChangeSummarizedEvent, KbPatchProposedEvent, KbReviewDecidedEvent, KbReviewRequestedEvent };
package/dist/example.js CHANGED
@@ -1 +1,42 @@
1
- var e={id:`kb-update-pipeline`,title:`KB Update Pipeline`,summary:`Automation proposes KB updates; humans verify; everything audited and notified.`,tags:[`knowledge`,`pipeline`,`hitl`,`audit`],kind:`knowledge`,visibility:`public`,docs:{rootDocId:`docs.examples.kb-update-pipeline`},entrypoints:{packageName:`@lssm/example.kb-update-pipeline`,feature:`./feature`,contracts:`./contracts`,handlers:`./handlers`,docs:`./docs`},surfaces:{templates:!0,sandbox:{enabled:!0,modes:[`markdown`,`specs`,`builder`]},studio:{enabled:!0,installable:!0},mcp:{enabled:!0}}};export{e as default};
1
+ //#region src/example.ts
2
+ const example = {
3
+ id: "kb-update-pipeline",
4
+ title: "KB Update Pipeline",
5
+ summary: "Automation proposes KB updates; humans verify; everything audited and notified.",
6
+ tags: [
7
+ "knowledge",
8
+ "pipeline",
9
+ "hitl",
10
+ "audit"
11
+ ],
12
+ kind: "knowledge",
13
+ visibility: "public",
14
+ docs: { rootDocId: "docs.examples.kb-update-pipeline" },
15
+ entrypoints: {
16
+ packageName: "@lssm/example.kb-update-pipeline",
17
+ feature: "./feature",
18
+ contracts: "./contracts",
19
+ handlers: "./handlers",
20
+ docs: "./docs"
21
+ },
22
+ surfaces: {
23
+ templates: true,
24
+ sandbox: {
25
+ enabled: true,
26
+ modes: [
27
+ "markdown",
28
+ "specs",
29
+ "builder"
30
+ ]
31
+ },
32
+ studio: {
33
+ enabled: true,
34
+ installable: true
35
+ },
36
+ mcp: { enabled: true }
37
+ }
38
+ };
39
+ var example_default = example;
40
+
41
+ //#endregion
42
+ export { example_default as default };
package/dist/feature.js CHANGED
@@ -1 +1,78 @@
1
- const e={meta:{key:`kb-update-pipeline`,title:`KB Update Pipeline (HITL)`,description:`Automation proposes KB patches; humans verify; publishing is blocked until approvals are complete.`,domain:`knowledge`,owners:[`@examples`],tags:[`knowledge`,`pipeline`,`hitl`,`audit`,`notifications`],stability:`experimental`},operations:[{name:`kbPipeline.runWatch`,version:1},{name:`kbPipeline.createReviewTask`,version:1},{name:`kbPipeline.submitDecision`,version:1},{name:`kbPipeline.publishIfReady`,version:1}],events:[{name:`kb.change.detected`,version:1},{name:`kb.change.summarized`,version:1},{name:`kb.patch.proposed`,version:1},{name:`kb.review.requested`,version:1},{name:`kb.review.decided`,version:1}],presentations:[],opToPresentation:[],presentationsTargets:[],capabilities:{requires:[{key:`identity`,version:1},{key:`notifications`,version:1},{key:`audit-trail`,version:1}]}};export{e as KbUpdatePipelineFeature};
1
+ //#region src/feature.ts
2
+ const KbUpdatePipelineFeature = {
3
+ meta: {
4
+ key: "kb-update-pipeline",
5
+ title: "KB Update Pipeline (HITL)",
6
+ description: "Automation proposes KB patches; humans verify; publishing is blocked until approvals are complete.",
7
+ domain: "knowledge",
8
+ owners: ["@examples"],
9
+ tags: [
10
+ "knowledge",
11
+ "pipeline",
12
+ "hitl",
13
+ "audit",
14
+ "notifications"
15
+ ],
16
+ stability: "experimental"
17
+ },
18
+ operations: [
19
+ {
20
+ name: "kbPipeline.runWatch",
21
+ version: 1
22
+ },
23
+ {
24
+ name: "kbPipeline.createReviewTask",
25
+ version: 1
26
+ },
27
+ {
28
+ name: "kbPipeline.submitDecision",
29
+ version: 1
30
+ },
31
+ {
32
+ name: "kbPipeline.publishIfReady",
33
+ version: 1
34
+ }
35
+ ],
36
+ events: [
37
+ {
38
+ name: "kb.change.detected",
39
+ version: 1
40
+ },
41
+ {
42
+ name: "kb.change.summarized",
43
+ version: 1
44
+ },
45
+ {
46
+ name: "kb.patch.proposed",
47
+ version: 1
48
+ },
49
+ {
50
+ name: "kb.review.requested",
51
+ version: 1
52
+ },
53
+ {
54
+ name: "kb.review.decided",
55
+ version: 1
56
+ }
57
+ ],
58
+ presentations: [],
59
+ opToPresentation: [],
60
+ presentationsTargets: [],
61
+ capabilities: { requires: [
62
+ {
63
+ key: "identity",
64
+ version: 1
65
+ },
66
+ {
67
+ key: "notifications",
68
+ version: 1
69
+ },
70
+ {
71
+ key: "audit-trail",
72
+ version: 1
73
+ }
74
+ ] }
75
+ };
76
+
77
+ //#endregion
78
+ export { KbUpdatePipelineFeature };
@@ -1 +1,3 @@
1
- import{createPipelineMemoryHandlers as e,createPipelineMemoryStore as t}from"./memory.handlers.js";export{e as createPipelineMemoryHandlers,t as createPipelineMemoryStore};
1
+ import { createPipelineMemoryHandlers, createPipelineMemoryStore } from "./memory.handlers.js";
2
+
3
+ export { createPipelineMemoryHandlers, createPipelineMemoryStore };
@@ -1 +1,92 @@
1
- function e(){return{candidates:new Map,reviewTasks:new Map,proposedRuleVersionIdsByCandidate:new Map,approvedRuleVersionIds:new Set,notifications:[]}}function t(e,t){return`${e}_${t.replace(/[^a-zA-Z0-9_-]/g,`_`)}`}function n(e){async function n(t){return{candidates:[...e.candidates.values()].filter(e=>e.sourceDocumentId.startsWith(`${t.jurisdiction}_`)||!0)}}async function r(n){let r=e.candidates.get(n.changeCandidateId);if(!r)throw Error(`CHANGE_CANDIDATE_NOT_FOUND`);let i=r.riskLevel===`high`?`expert`:`curator`,a=t(`review`,n.changeCandidateId),o={id:a,changeCandidateId:n.changeCandidateId,status:`open`,assignedRole:i,decision:void 0,decidedAt:void 0,decidedBy:void 0};return e.reviewTasks.set(a,o),e.notifications.push({kind:`kb.review.requested`,reviewTaskId:a,changeCandidateId:n.changeCandidateId,assignedRole:i,createdAt:new Date}),o}async function i(t){if(!e.candidates.has(t.changeCandidateId))throw Error(`CHANGE_CANDIDATE_NOT_FOUND`);return e.proposedRuleVersionIdsByCandidate.set(t.changeCandidateId,[...t.proposedRuleVersionIds]),{proposedRuleVersionIds:[...t.proposedRuleVersionIds]}}async function a(t){return e.approvedRuleVersionIds.add(t.ruleVersionId),{ruleVersionId:t.ruleVersionId}}async function o(t){let n=e.reviewTasks.get(t.reviewTaskId);if(!n)throw Error(`REVIEW_TASK_NOT_FOUND`);let r=e.candidates.get(n.changeCandidateId);if(!r)throw Error(`CHANGE_CANDIDATE_NOT_FOUND`);if(r.riskLevel===`high`&&t.decision===`approve`&&t.decidedByRole!==`expert`)throw Error(`FORBIDDEN_ROLE`);let i={...n,status:`decided`,decision:t.decision,decidedAt:new Date,decidedBy:t.decidedBy};return e.reviewTasks.set(i.id,i),i}async function s(t){if([...e.reviewTasks.values()].filter(e=>e.status!==`decided`).length)throw Error(`NOT_READY`);if([...e.reviewTasks.values()].some(e=>e.decision===`reject`))return{published:!1,reason:`REJECTED`};for(let t of e.reviewTasks.values())if(t.decision===`approve`&&(e.proposedRuleVersionIdsByCandidate.get(t.changeCandidateId)??[]).filter(t=>!e.approvedRuleVersionIds.has(t)).length)throw Error(`NOT_READY`);return{published:!0}}return{runWatch:n,createReviewTask:r,proposeRulePatch:i,markRuleVersionApproved:a,submitDecision:o,publishIfReady:s}}export{n as createPipelineMemoryHandlers,e as createPipelineMemoryStore};
1
+ //#region src/handlers/memory.handlers.ts
2
+ function createPipelineMemoryStore() {
3
+ return {
4
+ candidates: /* @__PURE__ */ new Map(),
5
+ reviewTasks: /* @__PURE__ */ new Map(),
6
+ proposedRuleVersionIdsByCandidate: /* @__PURE__ */ new Map(),
7
+ approvedRuleVersionIds: /* @__PURE__ */ new Set(),
8
+ notifications: []
9
+ };
10
+ }
11
+ function stableId(prefix, value) {
12
+ return `${prefix}_${value.replace(/[^a-zA-Z0-9_-]/g, "_")}`;
13
+ }
14
+ function createPipelineMemoryHandlers(store) {
15
+ async function runWatch(input) {
16
+ return { candidates: [...store.candidates.values()].filter((c) => c.sourceDocumentId.startsWith(`${input.jurisdiction}_`) || true) };
17
+ }
18
+ async function createReviewTask(input) {
19
+ const candidate = store.candidates.get(input.changeCandidateId);
20
+ if (!candidate) throw new Error("CHANGE_CANDIDATE_NOT_FOUND");
21
+ const assignedRole = candidate.riskLevel === "high" ? "expert" : "curator";
22
+ const id = stableId("review", input.changeCandidateId);
23
+ const task = {
24
+ id,
25
+ changeCandidateId: input.changeCandidateId,
26
+ status: "open",
27
+ assignedRole,
28
+ decision: void 0,
29
+ decidedAt: void 0,
30
+ decidedBy: void 0
31
+ };
32
+ store.reviewTasks.set(id, task);
33
+ store.notifications.push({
34
+ kind: "kb.review.requested",
35
+ reviewTaskId: id,
36
+ changeCandidateId: input.changeCandidateId,
37
+ assignedRole,
38
+ createdAt: /* @__PURE__ */ new Date()
39
+ });
40
+ return task;
41
+ }
42
+ async function proposeRulePatch(input) {
43
+ if (!store.candidates.has(input.changeCandidateId)) throw new Error("CHANGE_CANDIDATE_NOT_FOUND");
44
+ store.proposedRuleVersionIdsByCandidate.set(input.changeCandidateId, [...input.proposedRuleVersionIds]);
45
+ return { proposedRuleVersionIds: [...input.proposedRuleVersionIds] };
46
+ }
47
+ async function markRuleVersionApproved(input) {
48
+ store.approvedRuleVersionIds.add(input.ruleVersionId);
49
+ return { ruleVersionId: input.ruleVersionId };
50
+ }
51
+ async function submitDecision(input) {
52
+ const task = store.reviewTasks.get(input.reviewTaskId);
53
+ if (!task) throw new Error("REVIEW_TASK_NOT_FOUND");
54
+ const candidate = store.candidates.get(task.changeCandidateId);
55
+ if (!candidate) throw new Error("CHANGE_CANDIDATE_NOT_FOUND");
56
+ if (candidate.riskLevel === "high" && input.decision === "approve") {
57
+ if (input.decidedByRole !== "expert") throw new Error("FORBIDDEN_ROLE");
58
+ }
59
+ const decided = {
60
+ ...task,
61
+ status: "decided",
62
+ decision: input.decision,
63
+ decidedAt: /* @__PURE__ */ new Date(),
64
+ decidedBy: input.decidedBy
65
+ };
66
+ store.reviewTasks.set(decided.id, decided);
67
+ return decided;
68
+ }
69
+ async function publishIfReady(_input) {
70
+ if ([...store.reviewTasks.values()].filter((t) => t.status !== "decided").length) throw new Error("NOT_READY");
71
+ if ([...store.reviewTasks.values()].some((t) => t.decision === "reject")) return {
72
+ published: false,
73
+ reason: "REJECTED"
74
+ };
75
+ for (const task of store.reviewTasks.values()) {
76
+ if (task.decision !== "approve") continue;
77
+ if ((store.proposedRuleVersionIdsByCandidate.get(task.changeCandidateId) ?? []).filter((id) => !store.approvedRuleVersionIds.has(id)).length) throw new Error("NOT_READY");
78
+ }
79
+ return { published: true };
80
+ }
81
+ return {
82
+ runWatch,
83
+ createReviewTask,
84
+ proposeRulePatch,
85
+ markRuleVersionApproved,
86
+ submitDecision,
87
+ publishIfReady
88
+ };
89
+ }
90
+
91
+ //#endregion
92
+ export { createPipelineMemoryHandlers, createPipelineMemoryStore };
package/dist/index.d.ts CHANGED
@@ -1,7 +1,5 @@
1
1
  import { KbPipelineCreateReviewTaskContract, KbPipelinePublishIfReadyContract, KbPipelineRunWatchContract, KbPipelineSubmitDecisionContract } from "./contracts/pipeline.js";
2
- import "./contracts/index.js";
3
2
  import { ChangeCandidateModel, ChangeRiskLevelEnum, ReviewAssignedRoleEnum, ReviewDecisionEnum, ReviewTaskModel } from "./entities/models.js";
4
- import "./entities/index.js";
5
3
  import { KbChangeDetectedEvent, KbChangeSummarizedEvent, KbPatchProposedEvent, KbReviewDecidedEvent, KbReviewRequestedEvent } from "./events.js";
6
4
  import example from "./example.js";
7
5
  import { PipelineMemoryHandlers, PipelineMemoryStore, createPipelineMemoryHandlers, createPipelineMemoryStore } from "./handlers/memory.handlers.js";
package/dist/index.js CHANGED
@@ -1 +1,11 @@
1
- import{KbChangeDetectedEvent as e,KbChangeSummarizedEvent as t,KbPatchProposedEvent as n,KbReviewDecidedEvent as r,KbReviewRequestedEvent as i}from"./events.js";import a from"./example.js";import{ChangeCandidateModel as o,ChangeRiskLevelEnum as s,ReviewAssignedRoleEnum as c,ReviewDecisionEnum as l,ReviewTaskModel as u}from"./entities/models.js";import"./entities/index.js";import{KbPipelineCreateReviewTaskContract as d,KbPipelinePublishIfReadyContract as f,KbPipelineRunWatchContract as p,KbPipelineSubmitDecisionContract as m}from"./contracts/pipeline.js";import"./contracts/index.js";import{createPipelineMemoryHandlers as h,createPipelineMemoryStore as g}from"./handlers/memory.handlers.js";import{KbUpdatePipelineFeature as _}from"./kb-update-pipeline.feature.js";import"./docs/index.js";export{o as ChangeCandidateModel,s as ChangeRiskLevelEnum,e as KbChangeDetectedEvent,t as KbChangeSummarizedEvent,n as KbPatchProposedEvent,d as KbPipelineCreateReviewTaskContract,f as KbPipelinePublishIfReadyContract,p as KbPipelineRunWatchContract,m as KbPipelineSubmitDecisionContract,r as KbReviewDecidedEvent,i as KbReviewRequestedEvent,_ as KbUpdatePipelineFeature,c as ReviewAssignedRoleEnum,l as ReviewDecisionEnum,u as ReviewTaskModel,h as createPipelineMemoryHandlers,g as createPipelineMemoryStore,a as example};
1
+ import { KbChangeDetectedEvent, KbChangeSummarizedEvent, KbPatchProposedEvent, KbReviewDecidedEvent, KbReviewRequestedEvent } from "./events.js";
2
+ import example_default from "./example.js";
3
+ import { ChangeCandidateModel, ChangeRiskLevelEnum, ReviewAssignedRoleEnum, ReviewDecisionEnum, ReviewTaskModel } from "./entities/models.js";
4
+ import "./entities/index.js";
5
+ import { KbPipelineCreateReviewTaskContract, KbPipelinePublishIfReadyContract, KbPipelineRunWatchContract, KbPipelineSubmitDecisionContract } from "./contracts/pipeline.js";
6
+ import "./contracts/index.js";
7
+ import { createPipelineMemoryHandlers, createPipelineMemoryStore } from "./handlers/memory.handlers.js";
8
+ import { KbUpdatePipelineFeature } from "./kb-update-pipeline.feature.js";
9
+ import "./docs/index.js";
10
+
11
+ export { ChangeCandidateModel, ChangeRiskLevelEnum, KbChangeDetectedEvent, KbChangeSummarizedEvent, KbPatchProposedEvent, KbPipelineCreateReviewTaskContract, KbPipelinePublishIfReadyContract, KbPipelineRunWatchContract, KbPipelineSubmitDecisionContract, KbReviewDecidedEvent, KbReviewRequestedEvent, KbUpdatePipelineFeature, ReviewAssignedRoleEnum, ReviewDecisionEnum, ReviewTaskModel, createPipelineMemoryHandlers, createPipelineMemoryStore, example_default as example };
@@ -1 +1,78 @@
1
- const e={meta:{key:`kb-update-pipeline`,title:`KB Update Pipeline (HITL)`,description:`Automation proposes KB patches; humans verify; publishing is blocked until approvals are complete.`,domain:`knowledge`,owners:[`examples`],tags:[`knowledge`,`pipeline`,`hitl`,`audit`,`notifications`],stability:`experimental`},operations:[{name:`kbPipeline.runWatch`,version:1},{name:`kbPipeline.createReviewTask`,version:1},{name:`kbPipeline.submitDecision`,version:1},{name:`kbPipeline.publishIfReady`,version:1}],events:[{name:`kb.change.detected`,version:1},{name:`kb.change.summarized`,version:1},{name:`kb.patch.proposed`,version:1},{name:`kb.review.requested`,version:1},{name:`kb.review.decided`,version:1}],presentations:[],opToPresentation:[],presentationsTargets:[],capabilities:{requires:[{key:`identity`,version:1},{key:`notifications`,version:1},{key:`audit-trail`,version:1}]}};export{e as KbUpdatePipelineFeature};
1
+ //#region src/kb-update-pipeline.feature.ts
2
+ const KbUpdatePipelineFeature = {
3
+ meta: {
4
+ key: "kb-update-pipeline",
5
+ title: "KB Update Pipeline (HITL)",
6
+ description: "Automation proposes KB patches; humans verify; publishing is blocked until approvals are complete.",
7
+ domain: "knowledge",
8
+ owners: ["examples"],
9
+ tags: [
10
+ "knowledge",
11
+ "pipeline",
12
+ "hitl",
13
+ "audit",
14
+ "notifications"
15
+ ],
16
+ stability: "experimental"
17
+ },
18
+ operations: [
19
+ {
20
+ name: "kbPipeline.runWatch",
21
+ version: 1
22
+ },
23
+ {
24
+ name: "kbPipeline.createReviewTask",
25
+ version: 1
26
+ },
27
+ {
28
+ name: "kbPipeline.submitDecision",
29
+ version: 1
30
+ },
31
+ {
32
+ name: "kbPipeline.publishIfReady",
33
+ version: 1
34
+ }
35
+ ],
36
+ events: [
37
+ {
38
+ name: "kb.change.detected",
39
+ version: 1
40
+ },
41
+ {
42
+ name: "kb.change.summarized",
43
+ version: 1
44
+ },
45
+ {
46
+ name: "kb.patch.proposed",
47
+ version: 1
48
+ },
49
+ {
50
+ name: "kb.review.requested",
51
+ version: 1
52
+ },
53
+ {
54
+ name: "kb.review.decided",
55
+ version: 1
56
+ }
57
+ ],
58
+ presentations: [],
59
+ opToPresentation: [],
60
+ presentationsTargets: [],
61
+ capabilities: { requires: [
62
+ {
63
+ key: "identity",
64
+ version: 1
65
+ },
66
+ {
67
+ key: "notifications",
68
+ version: 1
69
+ },
70
+ {
71
+ key: "audit-trail",
72
+ version: 1
73
+ }
74
+ ] }
75
+ };
76
+
77
+ //#endregion
78
+ export { KbUpdatePipelineFeature };
@@ -0,0 +1,88 @@
1
+ import { StabilityEnum } from "../ownership.js";
2
+
3
+ //#region ../../libs/contracts/dist/capabilities/openbanking.js
4
+ const OWNERS = ["platform.finance"];
5
+ const TAGS = ["open-banking", "finance"];
6
+ const openBankingAccountsReadCapability = {
7
+ meta: {
8
+ key: "openbanking.accounts.read",
9
+ version: 1,
10
+ kind: "integration",
11
+ title: "Open Banking Accounts (Read)",
12
+ description: "Provides read-only access to linked bank accounts, including account summaries and metadata.",
13
+ domain: "finance",
14
+ owners: [...OWNERS],
15
+ tags: [...TAGS],
16
+ stability: StabilityEnum.Experimental
17
+ },
18
+ provides: [
19
+ {
20
+ surface: "operation",
21
+ name: "openbanking.accounts.list",
22
+ version: 1,
23
+ description: "List bank accounts linked to a Powens open banking connection."
24
+ },
25
+ {
26
+ surface: "operation",
27
+ name: "openbanking.accounts.get",
28
+ version: 1,
29
+ description: "Retrieve the canonical bank account record for a specific account."
30
+ },
31
+ {
32
+ surface: "operation",
33
+ name: "openbanking.accounts.sync",
34
+ version: 1,
35
+ description: "Trigger a refresh of bank account metadata from the open banking provider."
36
+ }
37
+ ]
38
+ };
39
+ const openBankingTransactionsReadCapability = {
40
+ meta: {
41
+ key: "openbanking.transactions.read",
42
+ version: 1,
43
+ kind: "integration",
44
+ title: "Open Banking Transactions (Read)",
45
+ description: "Enables retrieval of transaction history for linked bank accounts via open banking providers.",
46
+ domain: "finance",
47
+ owners: [...OWNERS],
48
+ tags: [...TAGS, "transactions"],
49
+ stability: StabilityEnum.Experimental
50
+ },
51
+ provides: [{
52
+ surface: "operation",
53
+ name: "openbanking.transactions.list",
54
+ version: 1,
55
+ description: "List transactions for a given bank account with optional date filtering."
56
+ }, {
57
+ surface: "operation",
58
+ name: "openbanking.transactions.sync",
59
+ version: 1,
60
+ description: "Synchronise transactions from the open banking provider into the canonical ledger."
61
+ }]
62
+ };
63
+ const openBankingBalancesReadCapability = {
64
+ meta: {
65
+ key: "openbanking.balances.read",
66
+ version: 1,
67
+ kind: "integration",
68
+ title: "Open Banking Balances (Read)",
69
+ description: "Allows querying of current and available balances for linked bank accounts via open banking providers.",
70
+ domain: "finance",
71
+ owners: [...OWNERS],
72
+ tags: [...TAGS, "balances"],
73
+ stability: StabilityEnum.Experimental
74
+ },
75
+ provides: [{
76
+ surface: "operation",
77
+ name: "openbanking.balances.get",
78
+ version: 1,
79
+ description: "Retrieve the latest known balances for a specified bank account."
80
+ }, {
81
+ surface: "operation",
82
+ name: "openbanking.balances.refresh",
83
+ version: 1,
84
+ description: "Force a balance refresh from the open banking provider."
85
+ }]
86
+ };
87
+
88
+ //#endregion
@@ -0,0 +1,5 @@
1
+ 'use client';
2
+
3
+ import "./react/feature-render.js";
4
+ import "./react/form-render.js";
5
+ import "./react/index.js";
@@ -0,0 +1,2 @@
1
+ import "../../presentations.v2.js";
2
+ import "react";
@@ -0,0 +1,4 @@
1
+ import "react";
2
+ import "react-hook-form";
3
+ import "@hookform/resolvers/zod";
4
+ import "react/jsx-runtime";
@@ -0,0 +1,4 @@
1
+ 'use client';
2
+
3
+ import "./feature-render.js";
4
+ import "./form-render.js";
@@ -0,0 +1 @@
1
+ import { ContractRegistryFileSchema, ContractRegistryItemSchema, ContractRegistryItemTypeSchema } from "./schemas.js";
@@ -0,0 +1,60 @@
1
+ import { StabilityEnum } from "../ownership.js";
2
+ import z from "zod";
3
+
4
+ //#region ../../libs/contracts/dist/contract-registry/schemas.js
5
+ const ContractRegistryItemTypeSchema = z.enum([
6
+ "contractspec:operation",
7
+ "contractspec:event",
8
+ "contractspec:presentation",
9
+ "contractspec:form",
10
+ "contractspec:feature",
11
+ "contractspec:workflow",
12
+ "contractspec:template",
13
+ "contractspec:integration",
14
+ "contractspec:data-view",
15
+ "contractspec:migration",
16
+ "contractspec:telemetry",
17
+ "contractspec:experiment",
18
+ "contractspec:app-config",
19
+ "contractspec:knowledge"
20
+ ]);
21
+ const ContractRegistryFileSchema = z.object({
22
+ path: z.string().min(1),
23
+ type: z.string().min(1),
24
+ content: z.string().optional()
25
+ });
26
+ const ContractRegistryItemSchema = z.object({
27
+ name: z.string().min(1),
28
+ type: ContractRegistryItemTypeSchema,
29
+ version: z.number().int().nonnegative(),
30
+ title: z.string().min(1),
31
+ description: z.string().min(1),
32
+ meta: z.object({
33
+ stability: z.enum([
34
+ StabilityEnum.Idea,
35
+ StabilityEnum.InCreation,
36
+ StabilityEnum.Experimental,
37
+ StabilityEnum.Beta,
38
+ StabilityEnum.Stable,
39
+ StabilityEnum.Deprecated
40
+ ]),
41
+ owners: z.array(z.string().min(1)).default([]),
42
+ tags: z.array(z.string().min(1)).default([])
43
+ }),
44
+ dependencies: z.array(z.string().min(1)).optional(),
45
+ registryDependencies: z.array(z.string().min(1)).optional(),
46
+ files: z.array(ContractRegistryFileSchema).min(1),
47
+ schema: z.object({
48
+ input: z.unknown().optional(),
49
+ output: z.unknown().optional()
50
+ }).optional()
51
+ });
52
+ const ContractRegistryManifestSchema = z.object({
53
+ $schema: z.string().min(1).optional(),
54
+ name: z.string().min(1),
55
+ homepage: z.string().min(1).optional(),
56
+ items: z.array(ContractRegistryItemSchema)
57
+ });
58
+
59
+ //#endregion
60
+ export { ContractRegistryFileSchema, ContractRegistryItemSchema, ContractRegistryItemTypeSchema };
@@ -0,0 +1,16 @@
1
+ import { registerDocBlocks } from "./registry.js";
2
+
3
+ //#region ../../libs/contracts/dist/docs/PUBLISHING.docblock.js
4
+ const PUBLISHING_DocBlocks = [{
5
+ id: "docs.PUBLISHING",
6
+ title: "Publishing ContractSpec Libraries",
7
+ summary: "This guide describes how we release the ContractSpec libraries to npm. We use a dual-track release system: **Stable** (manual) and **Canary** (automatic).",
8
+ kind: "reference",
9
+ visibility: "public",
10
+ route: "/docs/PUBLISHING",
11
+ tags: ["PUBLISHING"],
12
+ body: "# Publishing ContractSpec Libraries\n\nThis guide describes how we release the ContractSpec libraries to npm. We use a dual-track release system: **Stable** (manual) and **Canary** (automatic).\n\n## Release Tracks\n\n| Track | Branch | npm Tag | Frequency | Versioning | Use Case |\n|-------|--------|---------|-----------|------------|----------|\n| **Stable** | `release` | `latest` | Manual | SemVer (e.g., `1.7.4`) | Production, external users |\n| **Canary** | `main` | `canary` | Every Push | Snapshot (e.g., `1.7.4-canary...`) | Dev, internal testing |\n\n## Prerequisites\n\n- ✅ `NPM_TOKEN` secret is configured in GitHub (owner or automation token with _publish_ scope).\n- ✅ `GITHUB_TOKEN` (built-in) has permissions to create PRs (enabled by default in new repos).\n- ✅ For stable releases: `release` branch exists and is protected.\n\n## Canary Workflow (Automatic)\n\nEvery commit pushed to `main` triggers the `.github/workflows/publish-canary.yml` workflow.\n\n1. **Trigger**: Push to `main`.\n2. **Versioning**: Runs `changeset version --snapshot canary` to generate a temporary snapshot version.\n3. **Publish**: Packages are published to npm with the `canary` tag using `changeset publish --tag canary`.\n\n### Consuming Canary Builds\n\nTo install the latest bleeding-edge version:\n\n```bash\nnpm install @lssm/lib.contracts@canary\n# or\nbun add @lssm/lib.contracts@canary\n```\n\n## Stable Release Workflow (Manual)\n\nStable releases are managed via the `release` branch using the standard [Changesets Action](https://github.com/changesets/action).\n\n1. **Develop on `main`**: Create features and fixes.\n2. **Add Changesets**: Run `bun changeset` to document changes and impact (major/minor/patch).\n3. **Merge to `release`**: When ready to ship, open a PR from `main` to `release` or merge manually.\n4. **\"Version Packages\" PR**:\n - The GitHub Action detects new changesets and automatically creates a Pull Request titled **\"Version Packages\"**.\n - This PR contains the version bumps and updated `CHANGELOG.md` files.\n5. **Merge & Publish**:\n - Review and merge the \"Version Packages\" PR.\n - The Action runs again, detects the versions have been bumped, builds the libraries, and publishes them to npm with the `latest` tag.\n\n### Publishing Steps\n\n1. Ensure all changesets are present on `main`.\n2. Merge `main` into `release`:\n ```bash\n git checkout release\n git pull origin release\n git merge main\n git push origin release\n ```\n3. Go to GitHub Pull Requests. You will see a **\"Version Packages\"** PR created by the bot.\n4. Merge that PR.\n5. The release is now live on npm!\n\n## Manual Verification (Optional)\n\nBefore publishing a new version you can run:\n\n```bash\nbun run build:not-apps\nnpx npm-packlist --json packages/libs/contracts\n```\n\n## Rollback\n\nIf a publish fails mid-way, re-run the workflow once the issue is fixed. Already published packages are skipped automatically. Use `npm deprecate <package>@<version>` if we need to warn consumers about a broken release.\n"
13
+ }];
14
+ registerDocBlocks(PUBLISHING_DocBlocks);
15
+
16
+ //#endregion