@lssm/example.personalization 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 (63) hide show
  1. package/.turbo/turbo-build$colon$bundle.log +88 -17
  2. package/.turbo/turbo-build.log +87 -16
  3. package/CHANGELOG.md +7 -6
  4. package/dist/behavior-tracking.js +49 -1
  5. package/dist/docs/index.js +1 -1
  6. package/dist/docs/personalization.docblock.js +29 -8
  7. package/dist/example.js +38 -1
  8. package/dist/index.js +7 -1
  9. package/dist/libs/contracts/dist/docs/PUBLISHING.docblock.js +16 -0
  10. package/dist/libs/contracts/dist/docs/accessibility_wcag_compliance_specs.docblock.js +16 -0
  11. package/dist/libs/contracts/dist/docs/index.js +29 -0
  12. package/dist/libs/contracts/dist/docs/presentations.js +71 -0
  13. package/dist/libs/contracts/dist/docs/registry.js +44 -0
  14. package/dist/libs/contracts/dist/docs/tech/PHASE_1_QUICKSTART.docblock.js +16 -0
  15. package/dist/libs/contracts/dist/docs/tech/PHASE_2_AI_NATIVE_OPERATIONS.docblock.js +16 -0
  16. package/dist/libs/contracts/dist/docs/tech/PHASE_3_AUTO_EVOLUTION.docblock.js +16 -0
  17. package/dist/libs/contracts/dist/docs/tech/PHASE_4_PERSONALIZATION_ENGINE.docblock.js +16 -0
  18. package/dist/libs/contracts/dist/docs/tech/PHASE_5_ZERO_TOUCH_OPERATIONS.docblock.js +16 -0
  19. package/dist/libs/contracts/dist/docs/tech/auth/better-auth-nextjs.docblock.js +80 -0
  20. package/dist/libs/contracts/dist/docs/tech/contracts/openapi-export.docblock.js +57 -0
  21. package/dist/libs/contracts/dist/docs/tech/lifecycle-stage-system.docblock.js +16 -0
  22. package/dist/libs/contracts/dist/docs/tech/llm/llm-integration.docblock.js +357 -0
  23. package/dist/libs/contracts/dist/docs/tech/mcp-endpoints.docblock.js +37 -0
  24. package/dist/libs/contracts/dist/docs/tech/presentation-runtime.docblock.js +16 -0
  25. package/dist/libs/contracts/dist/docs/tech/schema/README.docblock.js +20 -0
  26. package/dist/libs/contracts/dist/docs/tech/studio/learning-events.docblock.js +48 -0
  27. package/dist/libs/contracts/dist/docs/tech/studio/learning-journeys.docblock.js +79 -0
  28. package/dist/libs/contracts/dist/docs/tech/studio/platform-admin-panel.docblock.js +84 -0
  29. package/dist/libs/contracts/dist/docs/tech/studio/project-access-teams.docblock.js +45 -0
  30. package/dist/libs/contracts/dist/docs/tech/studio/project-routing.docblock.js +67 -0
  31. package/dist/libs/contracts/dist/docs/tech/studio/sandbox-unlogged.docblock.js +40 -0
  32. package/dist/libs/contracts/dist/docs/tech/studio/team-invitations.docblock.js +69 -0
  33. package/dist/libs/contracts/dist/docs/tech/studio/workspace-ops.docblock.js +47 -0
  34. package/dist/libs/contracts/dist/docs/tech/studio/workspaces.docblock.js +62 -0
  35. package/dist/libs/contracts/dist/docs/tech/telemetry-ingest.docblock.js +155 -0
  36. package/dist/libs/contracts/dist/docs/tech/templates/runtime.docblock.js +20 -0
  37. package/dist/libs/contracts/dist/docs/tech/vscode-extension.docblock.js +101 -0
  38. package/dist/libs/contracts/dist/docs/tech/workflows/overview.docblock.js +20 -0
  39. package/dist/libs/logger/dist/context.node.js +78 -0
  40. package/dist/libs/logger/dist/elysia-plugin.js +3 -0
  41. package/dist/libs/logger/dist/formatters.js +163 -0
  42. package/dist/libs/logger/dist/index.js +7 -0
  43. package/dist/libs/logger/dist/logger.node.js +189 -0
  44. package/dist/libs/logger/dist/timer.js +126 -0
  45. package/dist/libs/logger/dist/tracer.node.js +115 -0
  46. package/dist/libs/logger/dist/types.js +13 -0
  47. package/dist/libs/overlay-engine/dist/index.js +6 -0
  48. package/dist/libs/overlay-engine/dist/merger.js +106 -0
  49. package/dist/libs/overlay-engine/dist/registry.js +106 -0
  50. package/dist/libs/overlay-engine/dist/runtime.js +53 -0
  51. package/dist/libs/overlay-engine/dist/signer.js +45 -0
  52. package/dist/libs/overlay-engine/dist/spec.js +7 -0
  53. package/dist/libs/overlay-engine/dist/validator.js +93 -0
  54. package/dist/libs/personalization/dist/analyzer.js +54 -0
  55. package/dist/libs/personalization/dist/store.js +58 -0
  56. package/dist/libs/personalization/dist/tracker.js +92 -0
  57. package/dist/libs/workflow-composer/dist/composer.js +28 -0
  58. package/dist/libs/workflow-composer/dist/injector.js +72 -0
  59. package/dist/libs/workflow-composer/dist/validator.js +36 -0
  60. package/dist/overlay-customization.js +53 -1
  61. package/dist/workflow-extension.js +67 -1
  62. package/package.json +9 -8
  63. package/tsconfig.tsbuildinfo +1 -1
@@ -0,0 +1,72 @@
1
+ import { validateExtension } from "./validator.js";
2
+
3
+ //#region ../../libs/workflow-composer/dist/injector.js
4
+ function applyWorkflowExtension(base, extension) {
5
+ validateExtension(extension, base);
6
+ const spec = cloneWorkflowSpec(base);
7
+ const steps = [...spec.definition.steps];
8
+ let transitions = [...spec.definition.transitions];
9
+ const hiddenSet = new Set(extension.hiddenSteps ?? []);
10
+ hiddenSet.forEach((stepId) => {
11
+ const idx = steps.findIndex((step) => step.id === stepId);
12
+ if (idx !== -1) steps.splice(idx, 1);
13
+ });
14
+ if (hiddenSet.size) transitions = transitions.filter((transition) => !hiddenSet.has(transition.from) && !hiddenSet.has(transition.to));
15
+ extension.customSteps?.forEach((injection) => {
16
+ insertStep(steps, injection);
17
+ wireTransitions(transitions, injection);
18
+ });
19
+ spec.definition.steps = steps;
20
+ spec.definition.transitions = dedupeTransitions(transitions);
21
+ spec.meta = {
22
+ ...spec.meta,
23
+ version: spec.meta.version
24
+ };
25
+ return spec;
26
+ }
27
+ function insertStep(steps, injection) {
28
+ const anchorIndex = resolveAnchorIndex(steps, injection);
29
+ if (anchorIndex === -1) throw new Error(`Unable to place injected step "${injection.inject.id}"`);
30
+ steps.splice(anchorIndex, 0, { ...injection.inject });
31
+ }
32
+ function resolveAnchorIndex(steps, injection) {
33
+ if (injection.after) {
34
+ const idx = steps.findIndex((step) => step.id === injection.after);
35
+ return idx === -1 ? -1 : idx + 1;
36
+ }
37
+ if (injection.before) {
38
+ const idx = steps.findIndex((step) => step.id === injection.before);
39
+ return idx === -1 ? -1 : idx;
40
+ }
41
+ return steps.length;
42
+ }
43
+ function wireTransitions(transitions, injection) {
44
+ if (!injection.inject.id) return;
45
+ if (injection.transitionFrom) transitions.push({
46
+ from: injection.transitionFrom,
47
+ to: injection.inject.id,
48
+ condition: injection.when
49
+ });
50
+ if (injection.transitionTo) transitions.push({
51
+ from: injection.inject.id,
52
+ to: injection.transitionTo,
53
+ condition: injection.when
54
+ });
55
+ }
56
+ function dedupeTransitions(transitions) {
57
+ const seen = /* @__PURE__ */ new Set();
58
+ const result = [];
59
+ transitions.forEach((transition) => {
60
+ const key = `${transition.from}->${transition.to}:${transition.condition ?? ""}`;
61
+ if (seen.has(key)) return;
62
+ seen.add(key);
63
+ result.push(transition);
64
+ });
65
+ return result;
66
+ }
67
+ function cloneWorkflowSpec(spec) {
68
+ return JSON.parse(JSON.stringify(spec));
69
+ }
70
+
71
+ //#endregion
72
+ export { applyWorkflowExtension };
@@ -0,0 +1,36 @@
1
+ //#region ../../libs/workflow-composer/dist/validator.js
2
+ function validateExtension(extension, base) {
3
+ const issues = [];
4
+ const stepIds = new Set(base.definition.steps.map((step) => step.id));
5
+ extension.customSteps?.forEach((injection, idx) => {
6
+ if (!injection.inject.id) issues.push({
7
+ code: "workflow.extension.step.id",
8
+ message: `customSteps[${idx}] is missing an id`
9
+ });
10
+ if (!injection.after && !injection.before) issues.push({
11
+ code: "workflow.extension.step.anchor",
12
+ message: `customSteps[${idx}] must set after or before`
13
+ });
14
+ if (injection.after && !stepIds.has(injection.after)) issues.push({
15
+ code: "workflow.extension.step.after",
16
+ message: `customSteps[${idx}] references unknown step "${injection.after}"`
17
+ });
18
+ if (injection.before && !stepIds.has(injection.before)) issues.push({
19
+ code: "workflow.extension.step.before",
20
+ message: `customSteps[${idx}] references unknown step "${injection.before}"`
21
+ });
22
+ });
23
+ extension.hiddenSteps?.forEach((stepId) => {
24
+ if (!stepIds.has(stepId)) issues.push({
25
+ code: "workflow.extension.hidden-step",
26
+ message: `hidden step "${stepId}" does not exist`
27
+ });
28
+ });
29
+ if (issues.length) {
30
+ const reason = issues.map((issue) => `${issue.code}: ${issue.message}`).join("; ");
31
+ throw new Error(`Invalid workflow extension for ${extension.workflow}: ${reason}`);
32
+ }
33
+ }
34
+
35
+ //#endregion
36
+ export { validateExtension };
@@ -1 +1,53 @@
1
- import{LogLevel as e,Logger as t}from"@lssm/lib.logger";import{defineOverlay as n}from"@lssm/lib.overlay-engine/spec";import{signOverlay as r}from"@lssm/lib.overlay-engine/signer";import{OverlayEngine as i,OverlayRegistry as a}from"@lssm/lib.overlay-engine";const o=new t({level:process.env.NODE_ENV===`production`?e.INFO:e.DEBUG,environment:process.env.NODE_ENV||`development`,enableColors:process.env.NODE_ENV!==`production`});async function s(){let e=new a({allowUnsigned:!0}),t=new i({registry:e}),s=await r(n({overlayId:`demo-overlay`,version:`1.0.0`,appliesTo:{capability:`billing.createOrder`,tenantId:`demo`},modifications:[{type:`hideField`,field:`internalNotes`},{type:`renameLabel`,field:`customerReference`,newLabel:`PO Number`}]}),process.env.PRIVATE_KEY_PEM??``);e.register(s);let c=t.apply({target:{fields:[{key:`customerReference`,label:`Customer Reference`,visible:!0},{key:`internalNotes`,label:`Internal Notes`,visible:!0}]},capability:`billing.createOrder`,tenantId:`demo`});o.info(`Overlay applied`,{fields:c.target.fields})}export{s as runOverlayCustomizationExample};
1
+ import { LogLevel } from "./libs/logger/dist/types.js";
2
+ import { Logger } from "./libs/logger/dist/logger.node.js";
3
+ import "./libs/logger/dist/index.js";
4
+ import { defineOverlay } from "./libs/overlay-engine/dist/spec.js";
5
+ import { signOverlay } from "./libs/overlay-engine/dist/signer.js";
6
+ import { OverlayRegistry } from "./libs/overlay-engine/dist/registry.js";
7
+ import { OverlayEngine } from "./libs/overlay-engine/dist/runtime.js";
8
+ import "./libs/overlay-engine/dist/index.js";
9
+
10
+ //#region src/overlay-customization.ts
11
+ const logger = new Logger({
12
+ level: process.env.NODE_ENV === "production" ? LogLevel.INFO : LogLevel.DEBUG,
13
+ environment: process.env.NODE_ENV || "development",
14
+ enableColors: process.env.NODE_ENV !== "production"
15
+ });
16
+ async function runOverlayCustomizationExample() {
17
+ const registry = new OverlayRegistry({ allowUnsigned: true });
18
+ const engine = new OverlayEngine({ registry });
19
+ const signed = await signOverlay(defineOverlay({
20
+ overlayId: "demo-overlay",
21
+ version: "1.0.0",
22
+ appliesTo: {
23
+ capability: "billing.createOrder",
24
+ tenantId: "demo"
25
+ },
26
+ modifications: [{
27
+ type: "hideField",
28
+ field: "internalNotes"
29
+ }, {
30
+ type: "renameLabel",
31
+ field: "customerReference",
32
+ newLabel: "PO Number"
33
+ }]
34
+ }), process.env.PRIVATE_KEY_PEM ?? "");
35
+ registry.register(signed);
36
+ const result = engine.apply({
37
+ target: { fields: [{
38
+ key: "customerReference",
39
+ label: "Customer Reference",
40
+ visible: true
41
+ }, {
42
+ key: "internalNotes",
43
+ label: "Internal Notes",
44
+ visible: true
45
+ }] },
46
+ capability: "billing.createOrder",
47
+ tenantId: "demo"
48
+ });
49
+ logger.info("Overlay applied", { fields: result.target.fields });
50
+ }
51
+
52
+ //#endregion
53
+ export { runOverlayCustomizationExample };
@@ -1 +1,67 @@
1
- import{LogLevel as e,Logger as t}from"@lssm/lib.logger";import{WorkflowComposer as n}from"@lssm/lib.workflow-composer";const r=new t({level:process.env.NODE_ENV===`production`?e.INFO:e.DEBUG,environment:process.env.NODE_ENV||`development`,enableColors:process.env.NODE_ENV!==`production`}),i={meta:{name:`billing.invoiceApproval`,version:1,title:`Invoice Approval`,owners:[],tags:[],description:``,domain:`billing`,stability:`stable`},definition:{steps:[{id:`validate-invoice`,type:`automation`,label:`Validate Invoice`},{id:`final-approval`,type:`human`,label:`Final Approval`}],transitions:[{from:`validate-invoice`,to:`final-approval`}]}};function a(){let e=new n;return e.register({workflow:`billing.invoiceApproval`,tenantId:`acme`,customSteps:[{after:`validate-invoice`,inject:{id:`acme-legal`,type:`human`,label:`ACME Legal Review`},transitionTo:`final-approval`}]}),e.compose({base:i,tenantId:`acme`})}function o(e){r.info(`Tenant workflow composed`,{workflow:e.meta.name,steps:e.definition.steps.map(e=>e.id)})}export{a as composeTenantWorkflowExample,o as logTenantWorkflowSteps};
1
+ import { LogLevel } from "./libs/logger/dist/types.js";
2
+ import { Logger } from "./libs/logger/dist/logger.node.js";
3
+ import "./libs/logger/dist/index.js";
4
+ import { WorkflowComposer } from "./libs/workflow-composer/dist/composer.js";
5
+
6
+ //#region src/workflow-extension.ts
7
+ const logger = new Logger({
8
+ level: process.env.NODE_ENV === "production" ? LogLevel.INFO : LogLevel.DEBUG,
9
+ environment: process.env.NODE_ENV || "development",
10
+ enableColors: process.env.NODE_ENV !== "production"
11
+ });
12
+ const BaseWorkflow = {
13
+ meta: {
14
+ name: "billing.invoiceApproval",
15
+ version: 1,
16
+ title: "Invoice Approval",
17
+ owners: [],
18
+ tags: [],
19
+ description: "",
20
+ domain: "billing",
21
+ stability: "stable"
22
+ },
23
+ definition: {
24
+ steps: [{
25
+ id: "validate-invoice",
26
+ type: "automation",
27
+ label: "Validate Invoice"
28
+ }, {
29
+ id: "final-approval",
30
+ type: "human",
31
+ label: "Final Approval"
32
+ }],
33
+ transitions: [{
34
+ from: "validate-invoice",
35
+ to: "final-approval"
36
+ }]
37
+ }
38
+ };
39
+ function composeTenantWorkflowExample() {
40
+ const composer = new WorkflowComposer();
41
+ composer.register({
42
+ workflow: "billing.invoiceApproval",
43
+ tenantId: "acme",
44
+ customSteps: [{
45
+ after: "validate-invoice",
46
+ inject: {
47
+ id: "acme-legal",
48
+ type: "human",
49
+ label: "ACME Legal Review"
50
+ },
51
+ transitionTo: "final-approval"
52
+ }]
53
+ });
54
+ return composer.compose({
55
+ base: BaseWorkflow,
56
+ tenantId: "acme"
57
+ });
58
+ }
59
+ function logTenantWorkflowSteps(workflow) {
60
+ logger.info("Tenant workflow composed", {
61
+ workflow: workflow.meta.name,
62
+ steps: workflow.definition.steps.map((step) => step.id)
63
+ });
64
+ }
65
+
66
+ //#endregion
67
+ export { composeTenantWorkflowExample, logTenantWorkflowSteps };
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@lssm/example.personalization",
3
- "version": "0.0.0-canary-20251217060834",
3
+ "version": "0.0.0-canary-20251217072406",
4
4
  "description": "Personalization examples: behavior tracking, overlay customization, workflow extension.",
5
5
  "type": "module",
6
6
  "main": "./dist/index.js",
@@ -29,15 +29,16 @@
29
29
  "test": "bun test"
30
30
  },
31
31
  "dependencies": {
32
- "@lssm/lib.personalization": "0.0.0-canary-20251217060834",
33
- "@lssm/lib.overlay-engine": "0.0.0-canary-20251217060834",
34
- "@lssm/lib.workflow-composer": "0.0.0-canary-20251217060834",
35
- "@lssm/lib.contracts": "0.0.0-canary-20251217060834",
36
- "@lssm/lib.logger": "0.0.0-canary-20251217060834"
32
+ "@lssm/lib.personalization": "0.0.0-canary-20251217072406",
33
+ "@lssm/lib.overlay-engine": "0.0.0-canary-20251217072406",
34
+ "@lssm/lib.workflow-composer": "0.0.0-canary-20251217072406",
35
+ "@lssm/lib.schema": "0.0.0-canary-20251217072406",
36
+ "@lssm/lib.contracts": "0.0.0-canary-20251217072406",
37
+ "@lssm/lib.logger": "0.0.0-canary-20251217072406"
37
38
  },
38
39
  "devDependencies": {
39
- "@lssm/tool.tsdown": "0.0.0-canary-20251217060834",
40
- "@lssm/tool.typescript": "0.0.0-canary-20251217060834",
40
+ "@lssm/tool.tsdown": "0.0.0-canary-20251217072406",
41
+ "@lssm/tool.typescript": "0.0.0-canary-20251217072406",
41
42
  "tsdown": "^0.17.4",
42
43
  "typescript": "^5.9.3"
43
44
  },