@contractspec/bundle.lifecycle-managed 1.56.1 → 1.58.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/__tests__/assessment-service.test.d.ts +2 -0
- package/dist/__tests__/assessment-service.test.d.ts.map +1 -0
- package/dist/agents/lifecycle-advisor-agent.d.ts +1 -7
- package/dist/agents/lifecycle-advisor-agent.d.ts.map +1 -1
- package/dist/api/rest-handlers.d.ts +14 -17
- package/dist/api/rest-handlers.d.ts.map +1 -1
- package/dist/browser/index.js +213 -0
- package/dist/events/lifecycle-events.d.ts +9 -13
- package/dist/events/lifecycle-events.d.ts.map +1 -1
- package/dist/index.d.ts +5 -5
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +213 -5
- package/dist/node/index.js +213 -0
- package/dist/services/assessment-service.d.ts +39 -44
- package/dist/services/assessment-service.d.ts.map +1 -1
- package/package.json +25 -20
- package/dist/agents/lifecycle-advisor-agent.js +0 -71
- package/dist/agents/lifecycle-advisor-agent.js.map +0 -1
- package/dist/api/rest-handlers.js +0 -23
- package/dist/api/rest-handlers.js.map +0 -1
- package/dist/events/lifecycle-events.js +0 -45
- package/dist/events/lifecycle-events.js.map +0 -1
- package/dist/libs/ai-agent/src/agent/contract-spec-agent.d.ts +0 -5
- package/dist/libs/ai-agent/src/agent/index.d.ts +0 -2
- package/dist/libs/ai-agent/src/agent/unified-agent.d.ts +0 -3
- package/dist/libs/ai-agent/src/approval/index.d.ts +0 -1
- package/dist/libs/ai-agent/src/approval/workflow.d.ts +0 -1
- package/dist/libs/ai-agent/src/exporters/claude-agent-exporter.d.ts +0 -2
- package/dist/libs/ai-agent/src/exporters/index.d.ts +0 -3
- package/dist/libs/ai-agent/src/exporters/opencode-exporter.d.ts +0 -2
- package/dist/libs/ai-agent/src/exporters/types.d.ts +0 -2
- package/dist/libs/ai-agent/src/index.d.ts +0 -14
- package/dist/libs/ai-agent/src/interop/index.d.ts +0 -3
- package/dist/libs/ai-agent/src/interop/spec-consumer.d.ts +0 -2
- package/dist/libs/ai-agent/src/interop/tool-consumer.d.ts +0 -3
- package/dist/libs/ai-agent/src/interop/types.d.ts +0 -2
- package/dist/libs/ai-agent/src/knowledge/index.d.ts +0 -1
- package/dist/libs/ai-agent/src/knowledge/injector.d.ts +0 -1
- package/dist/libs/ai-agent/src/providers/claude-agent-sdk/adapter.d.ts +0 -2
- package/dist/libs/ai-agent/src/providers/claude-agent-sdk/index.d.ts +0 -3
- package/dist/libs/ai-agent/src/providers/claude-agent-sdk/session-bridge.d.ts +0 -1
- package/dist/libs/ai-agent/src/providers/claude-agent-sdk/tool-bridge.d.ts +0 -3
- package/dist/libs/ai-agent/src/providers/index.d.ts +0 -4
- package/dist/libs/ai-agent/src/providers/opencode-sdk/adapter.d.ts +0 -2
- package/dist/libs/ai-agent/src/providers/opencode-sdk/agent-bridge.d.ts +0 -3
- package/dist/libs/ai-agent/src/providers/opencode-sdk/index.d.ts +0 -3
- package/dist/libs/ai-agent/src/providers/opencode-sdk/tool-bridge.d.ts +0 -3
- package/dist/libs/ai-agent/src/providers/registry.d.ts +0 -1
- package/dist/libs/ai-agent/src/providers/types.d.ts +0 -3
- package/dist/libs/ai-agent/src/schema/index.d.ts +0 -2
- package/dist/libs/ai-agent/src/schema/json-schema-to-zod.d.ts +0 -1
- package/dist/libs/ai-agent/src/schema/schema-output.d.ts +0 -2
- package/dist/libs/ai-agent/src/session/index.d.ts +0 -1
- package/dist/libs/ai-agent/src/session/store.d.ts +0 -2
- package/dist/libs/ai-agent/src/spec/index.d.ts +0 -2
- package/dist/libs/ai-agent/src/spec/registry.d.ts +0 -2
- package/dist/libs/ai-agent/src/spec/spec.d.ts +0 -115
- package/dist/libs/ai-agent/src/spec/spec.d.ts.map +0 -1
- package/dist/libs/ai-agent/src/telemetry/adapter.d.ts +0 -1
- package/dist/libs/ai-agent/src/telemetry/index.d.ts +0 -1
- package/dist/libs/ai-agent/src/tools/index.d.ts +0 -4
- package/dist/libs/ai-agent/src/tools/knowledge-tool.d.ts +0 -2
- package/dist/libs/ai-agent/src/tools/mcp-client.d.ts +0 -1
- package/dist/libs/ai-agent/src/tools/mcp-server.d.ts +0 -3
- package/dist/libs/ai-agent/src/tools/tool-adapter.d.ts +0 -3
- package/dist/libs/ai-agent/src/types.d.ts +0 -1
- package/dist/libs/contracts/src/app-config/lifecycle.d.ts +0 -1
- package/dist/libs/contracts/src/app-config/runtime.d.ts +0 -13
- package/dist/libs/contracts/src/app-config/spec.d.ts +0 -9
- package/dist/libs/contracts/src/capabilities/capabilities.d.ts +0 -1
- package/dist/libs/contracts/src/capabilities/context.d.ts +0 -1
- package/dist/libs/contracts/src/capabilities/guards.d.ts +0 -4
- package/dist/libs/contracts/src/capabilities/index.d.ts +0 -5
- package/dist/libs/contracts/src/capabilities/openbanking.d.ts +0 -1
- package/dist/libs/contracts/src/capabilities/validation.d.ts +0 -4
- package/dist/libs/contracts/src/data-views/index.d.ts +0 -3
- package/dist/libs/contracts/src/data-views/registry.d.ts +0 -2
- package/dist/libs/contracts/src/data-views/report/contractVerificationTable.d.ts +0 -1
- package/dist/libs/contracts/src/data-views/spec.d.ts +0 -3
- package/dist/libs/contracts/src/data-views/types.d.ts +0 -2
- package/dist/libs/contracts/src/docs/accessibility_wcag_compliance_specs.docblock.d.ts +0 -1
- package/dist/libs/contracts/src/docs/commands/docsGenerate.command.d.ts +0 -1
- package/dist/libs/contracts/src/docs/commands/docsPublish.command.d.ts +0 -1
- package/dist/libs/contracts/src/docs/commands/index.d.ts +0 -2
- package/dist/libs/contracts/src/docs/contracts.d.ts +0 -6
- package/dist/libs/contracts/src/docs/events/docsGenerated.event.d.ts +0 -1
- package/dist/libs/contracts/src/docs/events/docsPublished.event.d.ts +0 -1
- package/dist/libs/contracts/src/docs/events/index.d.ts +0 -2
- package/dist/libs/contracts/src/docs/forms/docsSearch.form.d.ts +0 -1
- package/dist/libs/contracts/src/docs/forms/index.d.ts +0 -1
- package/dist/libs/contracts/src/docs/index.d.ts +0 -30
- package/dist/libs/contracts/src/docs/presentations.d.ts +0 -2
- package/dist/libs/contracts/src/docs/queries/contractReference.query.d.ts +0 -1
- package/dist/libs/contracts/src/docs/queries/docsIndex.query.d.ts +0 -1
- package/dist/libs/contracts/src/docs/queries/index.d.ts +0 -2
- package/dist/libs/contracts/src/docs/registry.d.ts +0 -10
- package/dist/libs/contracts/src/docs/registry.d.ts.map +0 -1
- package/dist/libs/contracts/src/docs/tech/auth/better-auth-nextjs.docblock.d.ts +0 -1
- package/dist/libs/contracts/src/docs/tech/contracts/README.docblock.d.ts +0 -1
- package/dist/libs/contracts/src/docs/tech/contracts/openapi-export.docblock.d.ts +0 -1
- package/dist/libs/contracts/src/docs/tech/contracts/openapi-import.docblock.d.ts +0 -1
- package/dist/libs/contracts/src/docs/tech/lifecycle-stage-system.docblock.d.ts +0 -1
- package/dist/libs/contracts/src/docs/tech/llm/llm-integration.docblock.d.ts +0 -1
- package/dist/libs/contracts/src/docs/tech/mcp-endpoints.docblock.d.ts +0 -1
- package/dist/libs/contracts/src/docs/tech/presentation-runtime.docblock.d.ts +0 -1
- package/dist/libs/contracts/src/docs/tech/schema/README.docblock.d.ts +0 -1
- package/dist/libs/contracts/src/docs/tech/studio/learning-events.docblock.d.ts +0 -1
- package/dist/libs/contracts/src/docs/tech/studio/learning-journeys.docblock.d.ts +0 -1
- package/dist/libs/contracts/src/docs/tech/studio/platform-admin-panel.docblock.d.ts +0 -1
- package/dist/libs/contracts/src/docs/tech/studio/project-access-teams.docblock.d.ts +0 -1
- package/dist/libs/contracts/src/docs/tech/studio/project-routing.docblock.d.ts +0 -1
- package/dist/libs/contracts/src/docs/tech/studio/sandbox-unlogged.docblock.d.ts +0 -1
- package/dist/libs/contracts/src/docs/tech/studio/team-invitations.docblock.d.ts +0 -1
- package/dist/libs/contracts/src/docs/tech/studio/workspace-ops.docblock.d.ts +0 -1
- package/dist/libs/contracts/src/docs/tech/studio/workspaces.docblock.d.ts +0 -1
- package/dist/libs/contracts/src/docs/tech/telemetry-ingest.docblock.d.ts +0 -1
- package/dist/libs/contracts/src/docs/tech/vscode-extension.docblock.d.ts +0 -1
- package/dist/libs/contracts/src/events.d.ts +0 -5
- package/dist/libs/contracts/src/experiments/spec-resolver.d.ts +0 -4
- package/dist/libs/contracts/src/experiments/spec.d.ts +0 -4
- package/dist/libs/contracts/src/features/index.d.ts +0 -4
- package/dist/libs/contracts/src/features/install.d.ts +0 -6
- package/dist/libs/contracts/src/features/registry.d.ts +0 -2
- package/dist/libs/contracts/src/features/types.d.ts +0 -5
- package/dist/libs/contracts/src/features/validation.d.ts +0 -2
- package/dist/libs/contracts/src/forms/forms.d.ts +0 -3
- package/dist/libs/contracts/src/forms/index.d.ts +0 -1
- package/dist/libs/contracts/src/install.d.ts +0 -7
- package/dist/libs/contracts/src/integrations/connection.d.ts +0 -1
- package/dist/libs/contracts/src/integrations/spec.d.ts +0 -3
- package/dist/libs/contracts/src/knowledge/spec.d.ts +0 -9
- package/dist/libs/contracts/src/knowledge/spec.d.ts.map +0 -1
- package/dist/libs/contracts/src/operations/index.d.ts +0 -3
- package/dist/libs/contracts/src/operations/operation.d.ts +0 -7
- package/dist/libs/contracts/src/operations/registry.d.ts +0 -6
- package/dist/libs/contracts/src/operations/report/getContractVerificationStatus.d.ts +0 -3
- package/dist/libs/contracts/src/operations/report/index.d.ts +0 -4
- package/dist/libs/contracts/src/ownership.d.ts +0 -164
- package/dist/libs/contracts/src/ownership.d.ts.map +0 -1
- package/dist/libs/contracts/src/policy/registry.d.ts +0 -2
- package/dist/libs/contracts/src/policy/spec.d.ts +0 -13
- package/dist/libs/contracts/src/policy/spec.d.ts.map +0 -1
- package/dist/libs/contracts/src/presentations/index.d.ts +0 -3
- package/dist/libs/contracts/src/presentations/presentations.d.ts +0 -3
- package/dist/libs/contracts/src/presentations/registry.d.ts +0 -2
- package/dist/libs/contracts/src/presentations/transform-engine.d.ts +0 -2
- package/dist/libs/contracts/src/registry-utils.d.ts +0 -1
- package/dist/libs/contracts/src/registry.d.ts +0 -3
- package/dist/libs/contracts/src/resources.d.ts +0 -2
- package/dist/libs/contracts/src/telemetry/anomaly.d.ts +0 -2
- package/dist/libs/contracts/src/telemetry/index.d.ts +0 -3
- package/dist/libs/contracts/src/telemetry/spec.d.ts +0 -2
- package/dist/libs/contracts/src/telemetry/tracker.d.ts +0 -3
- package/dist/libs/contracts/src/tests/spec.d.ts +0 -1
- package/dist/libs/contracts/src/themes.d.ts +0 -2
- package/dist/libs/contracts/src/types.d.ts +0 -5
- package/dist/libs/contracts/src/versioning/refs.d.ts +0 -28
- package/dist/libs/contracts/src/versioning/refs.d.ts.map +0 -1
- package/dist/libs/contracts/src/workflow/overview.docblock.d.ts +0 -1
- package/dist/libs/contracts/src/workflow/spec.d.ts +0 -5
- package/dist/libs/contracts/src/workspace-config/workspace-config.docblock.d.ts +0 -1
- package/dist/libs/schema/src/EnumType.d.ts +0 -2
- package/dist/libs/schema/src/FieldType.d.ts +0 -2
- package/dist/libs/schema/src/GraphQLSchemaType.d.ts +0 -2
- package/dist/libs/schema/src/JsonSchemaType.d.ts +0 -2
- package/dist/libs/schema/src/ScalarTypeEnum.d.ts +0 -1
- package/dist/libs/schema/src/SchemaModel.d.ts +0 -4
- package/dist/libs/schema/src/SchemaModelType.d.ts +0 -1
- package/dist/libs/schema/src/ZodSchemaType.d.ts +0 -2
- package/dist/libs/schema/src/entity/defineEntity.d.ts +0 -1
- package/dist/libs/schema/src/entity/generator.d.ts +0 -1
- package/dist/libs/schema/src/entity/index.d.ts +0 -3
- package/dist/libs/schema/src/entity/types.d.ts +0 -1
- package/dist/libs/schema/src/index.d.ts +0 -9
- package/dist/services/assessment-service.js +0 -64
- package/dist/services/assessment-service.js.map +0 -1
|
@@ -0,0 +1,213 @@
|
|
|
1
|
+
// src/services/assessment-service.ts
|
|
2
|
+
import {
|
|
3
|
+
ProductPhase,
|
|
4
|
+
CompanyPhase,
|
|
5
|
+
CapitalPhase
|
|
6
|
+
} from "@contractspec/lib.lifecycle";
|
|
7
|
+
import {
|
|
8
|
+
LifecycleOrchestrator,
|
|
9
|
+
StageSignalCollector,
|
|
10
|
+
StageScorer,
|
|
11
|
+
LifecycleMilestonePlanner
|
|
12
|
+
} from "@contractspec/module.lifecycle-core";
|
|
13
|
+
import {
|
|
14
|
+
LifecycleRecommendationEngine,
|
|
15
|
+
ContractSpecLibraryRecommender,
|
|
16
|
+
LifecycleCeremonyDesigner
|
|
17
|
+
} from "@contractspec/module.lifecycle-advisor";
|
|
18
|
+
import {
|
|
19
|
+
LifecycleKpiPipeline
|
|
20
|
+
} from "@contractspec/lib.observability";
|
|
21
|
+
|
|
22
|
+
class LifecycleAssessmentService {
|
|
23
|
+
orchestrator;
|
|
24
|
+
recommendationEngine;
|
|
25
|
+
libraryRecommender;
|
|
26
|
+
ceremonyDesigner;
|
|
27
|
+
pipeline;
|
|
28
|
+
eventBridge;
|
|
29
|
+
constructor(options) {
|
|
30
|
+
const collector = new StageSignalCollector(options.collector);
|
|
31
|
+
const scorer = new StageScorer;
|
|
32
|
+
const milestonePlanner = new LifecycleMilestonePlanner;
|
|
33
|
+
this.orchestrator = new LifecycleOrchestrator({
|
|
34
|
+
collector,
|
|
35
|
+
scorer,
|
|
36
|
+
milestonePlanner
|
|
37
|
+
});
|
|
38
|
+
this.recommendationEngine = options.recommendationEngine ?? new LifecycleRecommendationEngine;
|
|
39
|
+
this.libraryRecommender = options.libraryRecommender ?? new ContractSpecLibraryRecommender;
|
|
40
|
+
this.ceremonyDesigner = options.ceremonyDesigner ?? new LifecycleCeremonyDesigner;
|
|
41
|
+
this.pipeline = options.pipeline ?? new LifecycleKpiPipeline;
|
|
42
|
+
this.eventBridge = options.eventBridge;
|
|
43
|
+
if (options.onPipelineEvent) {
|
|
44
|
+
this.pipeline.on(options.onPipelineEvent);
|
|
45
|
+
}
|
|
46
|
+
if (this.eventBridge) {
|
|
47
|
+
this.pipeline.on((event) => this.eventBridge?.forward(event));
|
|
48
|
+
}
|
|
49
|
+
}
|
|
50
|
+
async runAssessment(request) {
|
|
51
|
+
const assessment = await this.orchestrator.run(request);
|
|
52
|
+
const upcoming = this.orchestrator.getUpcomingMilestones(assessment.stage, request.completedMilestones);
|
|
53
|
+
this.pipeline.recordAssessment(assessment, request.tenantId);
|
|
54
|
+
const recommendation = this.recommendationEngine.generate(assessment, {
|
|
55
|
+
upcomingMilestones: upcoming
|
|
56
|
+
});
|
|
57
|
+
const libraries = this.libraryRecommender.recommend(assessment.stage);
|
|
58
|
+
const ceremony = this.ceremonyDesigner.design(assessment.stage);
|
|
59
|
+
return {
|
|
60
|
+
assessment,
|
|
61
|
+
recommendation,
|
|
62
|
+
libraries,
|
|
63
|
+
ceremony
|
|
64
|
+
};
|
|
65
|
+
}
|
|
66
|
+
getStagePlaybook(stage) {
|
|
67
|
+
const recommendation = this.recommendationEngine.generate({
|
|
68
|
+
stage,
|
|
69
|
+
confidence: 1,
|
|
70
|
+
axes: {
|
|
71
|
+
product: ProductPhase.Mvp,
|
|
72
|
+
company: CompanyPhase.TinyTeam,
|
|
73
|
+
capital: CapitalPhase.Seed
|
|
74
|
+
},
|
|
75
|
+
signals: [],
|
|
76
|
+
gaps: [],
|
|
77
|
+
focusAreas: [],
|
|
78
|
+
scorecard: [],
|
|
79
|
+
generatedAt: new Date().toISOString()
|
|
80
|
+
}, { upcomingMilestones: this.orchestrator.getUpcomingMilestones(stage) });
|
|
81
|
+
return {
|
|
82
|
+
recommendation,
|
|
83
|
+
libraries: this.libraryRecommender.recommend(stage),
|
|
84
|
+
ceremony: this.ceremonyDesigner.design(stage)
|
|
85
|
+
};
|
|
86
|
+
}
|
|
87
|
+
}
|
|
88
|
+
// src/events/lifecycle-events.ts
|
|
89
|
+
import { lifecycleEventNames } from "@contractspec/lib.analytics";
|
|
90
|
+
|
|
91
|
+
class LifecycleEventBridge {
|
|
92
|
+
publisher;
|
|
93
|
+
constructor(publisher) {
|
|
94
|
+
this.publisher = publisher;
|
|
95
|
+
}
|
|
96
|
+
forward(event) {
|
|
97
|
+
if (!this.publisher)
|
|
98
|
+
return;
|
|
99
|
+
switch (event.type) {
|
|
100
|
+
case "assessment.recorded":
|
|
101
|
+
this.publisher({
|
|
102
|
+
name: lifecycleEventNames.assessmentRun,
|
|
103
|
+
properties: {
|
|
104
|
+
tenantId: event.payload.tenantId,
|
|
105
|
+
stage: event.payload.stage
|
|
106
|
+
}
|
|
107
|
+
});
|
|
108
|
+
break;
|
|
109
|
+
case "stage.changed":
|
|
110
|
+
this.publisher({
|
|
111
|
+
name: lifecycleEventNames.stageChanged,
|
|
112
|
+
properties: {
|
|
113
|
+
tenantId: event.payload.tenantId,
|
|
114
|
+
previousStage: event.payload.previousStage,
|
|
115
|
+
nextStage: event.payload.nextStage
|
|
116
|
+
}
|
|
117
|
+
});
|
|
118
|
+
break;
|
|
119
|
+
case "confidence.low":
|
|
120
|
+
this.publisher({
|
|
121
|
+
name: `${lifecycleEventNames.assessmentRun}.low_confidence`,
|
|
122
|
+
properties: {
|
|
123
|
+
tenantId: event.payload.tenantId,
|
|
124
|
+
confidence: event.payload.confidence
|
|
125
|
+
}
|
|
126
|
+
});
|
|
127
|
+
break;
|
|
128
|
+
}
|
|
129
|
+
}
|
|
130
|
+
}
|
|
131
|
+
// src/agents/lifecycle-advisor-agent.ts
|
|
132
|
+
import { defineAgent } from "@contractspec/lib.ai-agent";
|
|
133
|
+
var LifecycleAdvisorAgent = defineAgent({
|
|
134
|
+
meta: {
|
|
135
|
+
key: "lifecycle.advisor",
|
|
136
|
+
version: "1.0.0",
|
|
137
|
+
title: "Lifecycle Advisor Agent",
|
|
138
|
+
description: "Guides artisans through lifecycle detection, focus areas, and ceremonies.",
|
|
139
|
+
owners: ["team-lifecycle"],
|
|
140
|
+
domain: "operations",
|
|
141
|
+
tags: ["guide", "lifecycle", "ops"],
|
|
142
|
+
stability: "experimental"
|
|
143
|
+
},
|
|
144
|
+
description: "Guides users through lifecycle assessments, highlights gaps, and recommends actions tied to ContractSpec libraries.",
|
|
145
|
+
instructions: `You are the Lifecycle Advisor. Always clarify the user's current stage, confidence, and blockers before suggesting actions.
|
|
146
|
+
- Prioritize simple, mobile-friendly instructions.
|
|
147
|
+
- When in early stages, focus on learning loops, not heavy infra.
|
|
148
|
+
- When in later stages, emphasize repeatability, telemetry, and managed ceremonies.
|
|
149
|
+
- Suggest at most 3 actions at a time. Reference ContractSpec libraries or modules when relevant.`,
|
|
150
|
+
tools: [
|
|
151
|
+
{
|
|
152
|
+
name: "run_assessment",
|
|
153
|
+
description: "Trigger a lifecycle assessment for a tenant.",
|
|
154
|
+
schema: {
|
|
155
|
+
type: "object",
|
|
156
|
+
properties: {
|
|
157
|
+
tenantId: { type: "string" },
|
|
158
|
+
questionnaire: { type: "object", additionalProperties: true }
|
|
159
|
+
},
|
|
160
|
+
required: ["tenantId"]
|
|
161
|
+
},
|
|
162
|
+
automationSafe: true
|
|
163
|
+
},
|
|
164
|
+
{
|
|
165
|
+
name: "fetch_playbook",
|
|
166
|
+
description: "Retrieve stage-specific playbook (actions, ceremonies, libraries).",
|
|
167
|
+
schema: {
|
|
168
|
+
type: "object",
|
|
169
|
+
properties: {
|
|
170
|
+
stage: {
|
|
171
|
+
type: "integer",
|
|
172
|
+
minimum: 0,
|
|
173
|
+
maximum: 6,
|
|
174
|
+
description: "Lifecycle stage number (0-6)"
|
|
175
|
+
}
|
|
176
|
+
},
|
|
177
|
+
required: ["stage"]
|
|
178
|
+
},
|
|
179
|
+
automationSafe: true
|
|
180
|
+
}
|
|
181
|
+
],
|
|
182
|
+
memory: {
|
|
183
|
+
maxEntries: 25,
|
|
184
|
+
ttlMinutes: 120
|
|
185
|
+
},
|
|
186
|
+
policy: {
|
|
187
|
+
confidence: { min: 0.7 },
|
|
188
|
+
escalation: {
|
|
189
|
+
confidenceThreshold: 0.5,
|
|
190
|
+
approvalWorkflow: "ops.lifecycle.escalation"
|
|
191
|
+
},
|
|
192
|
+
flags: ["lifecycle_advisor"]
|
|
193
|
+
}
|
|
194
|
+
});
|
|
195
|
+
// src/api/rest-handlers.ts
|
|
196
|
+
var createLifecycleHandlers = (service) => ({
|
|
197
|
+
runAssessment: async (req) => {
|
|
198
|
+
const payload = req.body ?? {};
|
|
199
|
+
const result = await service.runAssessment(payload);
|
|
200
|
+
return { status: 200, body: result };
|
|
201
|
+
},
|
|
202
|
+
getPlaybook: async (req) => {
|
|
203
|
+
const stage = Number(req.params?.stage ?? 0);
|
|
204
|
+
const result = service.getStagePlaybook(stage);
|
|
205
|
+
return { status: 200, body: result };
|
|
206
|
+
}
|
|
207
|
+
});
|
|
208
|
+
export {
|
|
209
|
+
createLifecycleHandlers,
|
|
210
|
+
LifecycleEventBridge,
|
|
211
|
+
LifecycleAssessmentService,
|
|
212
|
+
LifecycleAdvisorAgent
|
|
213
|
+
};
|
|
@@ -1,49 +1,44 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import {
|
|
3
|
-
import {
|
|
4
|
-
import
|
|
5
|
-
import {
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
interface LifecycleAssessmentRequest extends LifecycleAssessmentInput {
|
|
10
|
-
tenantId?: string;
|
|
11
|
-
completedMilestones?: string[];
|
|
1
|
+
import type { LifecycleAssessment, LifecycleAssessmentInput, LifecycleRecommendation, LifecycleStage } from '@contractspec/lib.lifecycle';
|
|
2
|
+
import { type StageSignalCollectorOptions } from '@contractspec/module.lifecycle-core';
|
|
3
|
+
import { LifecycleRecommendationEngine, ContractSpecLibraryRecommender, LifecycleCeremonyDesigner } from '@contractspec/module.lifecycle-advisor';
|
|
4
|
+
import { LifecycleKpiPipeline, type LifecyclePipelineEvent } from '@contractspec/lib.observability';
|
|
5
|
+
import { LifecycleEventBridge } from '../events/lifecycle-events';
|
|
6
|
+
export interface LifecycleAssessmentRequest extends LifecycleAssessmentInput {
|
|
7
|
+
tenantId?: string;
|
|
8
|
+
completedMilestones?: string[];
|
|
12
9
|
}
|
|
13
|
-
interface LifecycleAssessmentResponse {
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
10
|
+
export interface LifecycleAssessmentResponse {
|
|
11
|
+
assessment: LifecycleAssessment;
|
|
12
|
+
recommendation: LifecycleRecommendation;
|
|
13
|
+
libraries: ReturnType<ContractSpecLibraryRecommender['recommend']>;
|
|
14
|
+
ceremony?: ReturnType<LifecycleCeremonyDesigner['design']>;
|
|
18
15
|
}
|
|
19
|
-
interface LifecycleAssessmentServiceOptions {
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
16
|
+
export interface LifecycleAssessmentServiceOptions {
|
|
17
|
+
collector: StageSignalCollectorOptions;
|
|
18
|
+
pipeline?: LifecycleKpiPipeline;
|
|
19
|
+
recommendationEngine?: LifecycleRecommendationEngine;
|
|
20
|
+
libraryRecommender?: ContractSpecLibraryRecommender;
|
|
21
|
+
ceremonyDesigner?: LifecycleCeremonyDesigner;
|
|
22
|
+
eventBridge?: LifecycleEventBridge;
|
|
23
|
+
onPipelineEvent?: (event: LifecyclePipelineEvent) => void;
|
|
27
24
|
}
|
|
28
|
-
declare class LifecycleAssessmentService {
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
25
|
+
export declare class LifecycleAssessmentService {
|
|
26
|
+
private readonly orchestrator;
|
|
27
|
+
private readonly recommendationEngine;
|
|
28
|
+
private readonly libraryRecommender;
|
|
29
|
+
private readonly ceremonyDesigner;
|
|
30
|
+
private readonly pipeline;
|
|
31
|
+
private readonly eventBridge?;
|
|
32
|
+
constructor(options: LifecycleAssessmentServiceOptions);
|
|
33
|
+
runAssessment(request: LifecycleAssessmentRequest): Promise<LifecycleAssessmentResponse>;
|
|
34
|
+
getStagePlaybook(stage: LifecycleStage): {
|
|
35
|
+
recommendation: LifecycleRecommendation;
|
|
36
|
+
libraries: import("@contractspec/module.lifecycle-advisor").LibraryRecommendation[];
|
|
37
|
+
ceremony: {
|
|
38
|
+
title: string;
|
|
39
|
+
copy: string;
|
|
40
|
+
cues: string[];
|
|
41
|
+
} | undefined;
|
|
42
|
+
};
|
|
46
43
|
}
|
|
47
|
-
//#endregion
|
|
48
|
-
export { LifecycleAssessmentRequest, LifecycleAssessmentResponse, LifecycleAssessmentService, LifecycleAssessmentServiceOptions };
|
|
49
44
|
//# sourceMappingURL=assessment-service.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"assessment-service.d.ts","
|
|
1
|
+
{"version":3,"file":"assessment-service.d.ts","sourceRoot":"","sources":["../../src/services/assessment-service.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EACV,mBAAmB,EACnB,wBAAwB,EACxB,uBAAuB,EACvB,cAAc,EACf,MAAM,6BAA6B,CAAC;AAMrC,OAAO,EAKL,KAAK,2BAA2B,EACjC,MAAM,qCAAqC,CAAC;AAC7C,OAAO,EACL,6BAA6B,EAC7B,8BAA8B,EAC9B,yBAAyB,EAC1B,MAAM,wCAAwC,CAAC;AAChD,OAAO,EACL,oBAAoB,EACpB,KAAK,sBAAsB,EAC5B,MAAM,iCAAiC,CAAC;AACzC,OAAO,EAAE,oBAAoB,EAAE,MAAM,4BAA4B,CAAC;AAElE,MAAM,WAAW,0BAA2B,SAAQ,wBAAwB;IAC1E,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,mBAAmB,CAAC,EAAE,MAAM,EAAE,CAAC;CAChC;AAED,MAAM,WAAW,2BAA2B;IAC1C,UAAU,EAAE,mBAAmB,CAAC;IAChC,cAAc,EAAE,uBAAuB,CAAC;IACxC,SAAS,EAAE,UAAU,CAAC,8BAA8B,CAAC,WAAW,CAAC,CAAC,CAAC;IACnE,QAAQ,CAAC,EAAE,UAAU,CAAC,yBAAyB,CAAC,QAAQ,CAAC,CAAC,CAAC;CAC5D;AAED,MAAM,WAAW,iCAAiC;IAChD,SAAS,EAAE,2BAA2B,CAAC;IACvC,QAAQ,CAAC,EAAE,oBAAoB,CAAC;IAChC,oBAAoB,CAAC,EAAE,6BAA6B,CAAC;IACrD,kBAAkB,CAAC,EAAE,8BAA8B,CAAC;IACpD,gBAAgB,CAAC,EAAE,yBAAyB,CAAC;IAC7C,WAAW,CAAC,EAAE,oBAAoB,CAAC;IACnC,eAAe,CAAC,EAAE,CAAC,KAAK,EAAE,sBAAsB,KAAK,IAAI,CAAC;CAC3D;AAED,qBAAa,0BAA0B;IACrC,OAAO,CAAC,QAAQ,CAAC,YAAY,CAAwB;IACrD,OAAO,CAAC,QAAQ,CAAC,oBAAoB,CAAgC;IACrE,OAAO,CAAC,QAAQ,CAAC,kBAAkB,CAAiC;IACpE,OAAO,CAAC,QAAQ,CAAC,gBAAgB,CAA4B;IAC7D,OAAO,CAAC,QAAQ,CAAC,QAAQ,CAAuB;IAChD,OAAO,CAAC,QAAQ,CAAC,WAAW,CAAC,CAAuB;gBAExC,OAAO,EAAE,iCAAiC;IAyBhD,aAAa,CACjB,OAAO,EAAE,0BAA0B,GAClC,OAAO,CAAC,2BAA2B,CAAC;IAuBvC,gBAAgB,CAAC,KAAK,EAAE,cAAc;;;;;;;;;CAyBvC"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@contractspec/bundle.lifecycle-managed",
|
|
3
|
-
"version": "1.
|
|
3
|
+
"version": "1.58.0",
|
|
4
4
|
"description": "Lifecycle management bundle with analytics and AI advisor",
|
|
5
5
|
"keywords": [
|
|
6
6
|
"contractspec",
|
|
@@ -19,39 +19,44 @@
|
|
|
19
19
|
"scripts": {
|
|
20
20
|
"publish:pkg": "bun publish --tolerate-republish --ignore-scripts --verbose",
|
|
21
21
|
"publish:pkg:canary": "bun publish:pkg --tag canary",
|
|
22
|
-
"build": "bun build:
|
|
23
|
-
"build:bundle": "
|
|
24
|
-
"build:types": "
|
|
25
|
-
"dev": "bun
|
|
22
|
+
"build": "bun run prebuild && bun run build:bundle && bun run build:types",
|
|
23
|
+
"build:bundle": "contractspec-bun-build transpile",
|
|
24
|
+
"build:types": "contractspec-bun-build types",
|
|
25
|
+
"dev": "contractspec-bun-build dev",
|
|
26
26
|
"clean": "rimraf dist .turbo",
|
|
27
27
|
"lint": "bun lint:fix",
|
|
28
28
|
"lint:fix": "eslint src --fix",
|
|
29
29
|
"lint:check": "eslint src",
|
|
30
|
-
"test": "bun test"
|
|
30
|
+
"test": "bun test",
|
|
31
|
+
"prebuild": "contractspec-bun-build prebuild",
|
|
32
|
+
"typecheck": "tsc --noEmit"
|
|
31
33
|
},
|
|
32
34
|
"dependencies": {
|
|
33
|
-
"@contractspec/lib.ai-agent": "1.
|
|
34
|
-
"@contractspec/lib.analytics": "1.
|
|
35
|
-
"@contractspec/lib.lifecycle": "1.
|
|
36
|
-
"@contractspec/lib.observability": "1.
|
|
37
|
-
"@contractspec/module.lifecycle-advisor": "1.
|
|
38
|
-
"@contractspec/module.lifecycle-core": "1.
|
|
35
|
+
"@contractspec/lib.ai-agent": "1.58.0",
|
|
36
|
+
"@contractspec/lib.analytics": "1.58.0",
|
|
37
|
+
"@contractspec/lib.lifecycle": "1.58.0",
|
|
38
|
+
"@contractspec/lib.observability": "1.58.0",
|
|
39
|
+
"@contractspec/module.lifecycle-advisor": "1.58.0",
|
|
40
|
+
"@contractspec/module.lifecycle-core": "1.58.0"
|
|
39
41
|
},
|
|
40
42
|
"devDependencies": {
|
|
41
|
-
"@contractspec/tool.
|
|
42
|
-
"
|
|
43
|
-
"
|
|
44
|
-
"typescript": "^5.9.3"
|
|
43
|
+
"@contractspec/tool.typescript": "1.58.0",
|
|
44
|
+
"typescript": "^5.9.3",
|
|
45
|
+
"@contractspec/tool.bun": "1.57.0"
|
|
45
46
|
},
|
|
46
47
|
"exports": {
|
|
47
|
-
".": "./
|
|
48
|
-
"./*": "./*"
|
|
48
|
+
".": "./src/index.ts"
|
|
49
49
|
},
|
|
50
50
|
"publishConfig": {
|
|
51
51
|
"access": "public",
|
|
52
52
|
"exports": {
|
|
53
|
-
".":
|
|
54
|
-
|
|
53
|
+
".": {
|
|
54
|
+
"types": "./dist/index.d.ts",
|
|
55
|
+
"bun": "./dist/index.js",
|
|
56
|
+
"node": "./dist/node/index.mjs",
|
|
57
|
+
"browser": "./dist/browser/index.js",
|
|
58
|
+
"default": "./dist/index.js"
|
|
59
|
+
}
|
|
55
60
|
},
|
|
56
61
|
"registry": "https://registry.npmjs.org/"
|
|
57
62
|
},
|
|
@@ -1,71 +0,0 @@
|
|
|
1
|
-
import { defineAgent } from "@contractspec/lib.ai-agent";
|
|
2
|
-
|
|
3
|
-
//#region src/agents/lifecycle-advisor-agent.ts
|
|
4
|
-
const LifecycleAdvisorAgent = defineAgent({
|
|
5
|
-
meta: {
|
|
6
|
-
key: "lifecycle.advisor",
|
|
7
|
-
version: "1.0.0",
|
|
8
|
-
title: "Lifecycle Advisor Agent",
|
|
9
|
-
description: "Guides artisans through lifecycle detection, focus areas, and ceremonies.",
|
|
10
|
-
owners: ["team-lifecycle"],
|
|
11
|
-
domain: "operations",
|
|
12
|
-
tags: [
|
|
13
|
-
"guide",
|
|
14
|
-
"lifecycle",
|
|
15
|
-
"ops"
|
|
16
|
-
],
|
|
17
|
-
stability: "experimental"
|
|
18
|
-
},
|
|
19
|
-
description: "Guides users through lifecycle assessments, highlights gaps, and recommends actions tied to ContractSpec libraries.",
|
|
20
|
-
instructions: `You are the Lifecycle Advisor. Always clarify the user's current stage, confidence, and blockers before suggesting actions.
|
|
21
|
-
- Prioritize simple, mobile-friendly instructions.
|
|
22
|
-
- When in early stages, focus on learning loops, not heavy infra.
|
|
23
|
-
- When in later stages, emphasize repeatability, telemetry, and managed ceremonies.
|
|
24
|
-
- Suggest at most 3 actions at a time. Reference ContractSpec libraries or modules when relevant.`,
|
|
25
|
-
tools: [{
|
|
26
|
-
name: "run_assessment",
|
|
27
|
-
description: "Trigger a lifecycle assessment for a tenant.",
|
|
28
|
-
schema: {
|
|
29
|
-
type: "object",
|
|
30
|
-
properties: {
|
|
31
|
-
tenantId: { type: "string" },
|
|
32
|
-
questionnaire: {
|
|
33
|
-
type: "object",
|
|
34
|
-
additionalProperties: true
|
|
35
|
-
}
|
|
36
|
-
},
|
|
37
|
-
required: ["tenantId"]
|
|
38
|
-
},
|
|
39
|
-
automationSafe: true
|
|
40
|
-
}, {
|
|
41
|
-
name: "fetch_playbook",
|
|
42
|
-
description: "Retrieve stage-specific playbook (actions, ceremonies, libraries).",
|
|
43
|
-
schema: {
|
|
44
|
-
type: "object",
|
|
45
|
-
properties: { stage: {
|
|
46
|
-
type: "integer",
|
|
47
|
-
minimum: 0,
|
|
48
|
-
maximum: 6,
|
|
49
|
-
description: "Lifecycle stage number (0-6)"
|
|
50
|
-
} },
|
|
51
|
-
required: ["stage"]
|
|
52
|
-
},
|
|
53
|
-
automationSafe: true
|
|
54
|
-
}],
|
|
55
|
-
memory: {
|
|
56
|
-
maxEntries: 25,
|
|
57
|
-
ttlMinutes: 120
|
|
58
|
-
},
|
|
59
|
-
policy: {
|
|
60
|
-
confidence: { min: .7 },
|
|
61
|
-
escalation: {
|
|
62
|
-
confidenceThreshold: .5,
|
|
63
|
-
approvalWorkflow: "ops.lifecycle.escalation"
|
|
64
|
-
},
|
|
65
|
-
flags: ["lifecycle_advisor"]
|
|
66
|
-
}
|
|
67
|
-
});
|
|
68
|
-
|
|
69
|
-
//#endregion
|
|
70
|
-
export { LifecycleAdvisorAgent };
|
|
71
|
-
//# sourceMappingURL=lifecycle-advisor-agent.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"lifecycle-advisor-agent.js","names":[],"sources":["../../src/agents/lifecycle-advisor-agent.ts"],"sourcesContent":["import { defineAgent } from '@contractspec/lib.ai-agent';\n\nexport const LifecycleAdvisorAgent = defineAgent({\n meta: {\n key: 'lifecycle.advisor',\n version: '1.0.0',\n title: 'Lifecycle Advisor Agent',\n description:\n 'Guides artisans through lifecycle detection, focus areas, and ceremonies.',\n owners: ['team-lifecycle'],\n domain: 'operations',\n tags: ['guide', 'lifecycle', 'ops'],\n stability: 'experimental',\n },\n description:\n 'Guides users through lifecycle assessments, highlights gaps, and recommends actions tied to ContractSpec libraries.',\n instructions: `You are the Lifecycle Advisor. Always clarify the user's current stage, confidence, and blockers before suggesting actions.\n- Prioritize simple, mobile-friendly instructions.\n- When in early stages, focus on learning loops, not heavy infra.\n- When in later stages, emphasize repeatability, telemetry, and managed ceremonies.\n- Suggest at most 3 actions at a time. Reference ContractSpec libraries or modules when relevant.`,\n tools: [\n {\n name: 'run_assessment',\n description: 'Trigger a lifecycle assessment for a tenant.',\n schema: {\n type: 'object',\n properties: {\n tenantId: { type: 'string' },\n questionnaire: { type: 'object', additionalProperties: true },\n },\n required: ['tenantId'],\n },\n automationSafe: true,\n },\n {\n name: 'fetch_playbook',\n description:\n 'Retrieve stage-specific playbook (actions, ceremonies, libraries).',\n schema: {\n type: 'object',\n properties: {\n stage: {\n type: 'integer',\n minimum: 0,\n maximum: 6,\n description: 'Lifecycle stage number (0-6)',\n },\n },\n required: ['stage'],\n },\n automationSafe: true,\n },\n ],\n memory: {\n maxEntries: 25,\n ttlMinutes: 120,\n },\n policy: {\n confidence: { min: 0.7 },\n escalation: {\n confidenceThreshold: 0.5,\n approvalWorkflow: 'ops.lifecycle.escalation',\n },\n flags: ['lifecycle_advisor'],\n },\n});\n"],"mappings":";;;AAEA,MAAa,wBAAwB,YAAY;CAC/C,MAAM;EACJ,KAAK;EACL,SAAS;EACT,OAAO;EACP,aACE;EACF,QAAQ,CAAC,iBAAiB;EAC1B,QAAQ;EACR,MAAM;GAAC;GAAS;GAAa;GAAM;EACnC,WAAW;EACZ;CACD,aACE;CACF,cAAc;;;;;CAKd,OAAO,CACL;EACE,MAAM;EACN,aAAa;EACb,QAAQ;GACN,MAAM;GACN,YAAY;IACV,UAAU,EAAE,MAAM,UAAU;IAC5B,eAAe;KAAE,MAAM;KAAU,sBAAsB;KAAM;IAC9D;GACD,UAAU,CAAC,WAAW;GACvB;EACD,gBAAgB;EACjB,EACD;EACE,MAAM;EACN,aACE;EACF,QAAQ;GACN,MAAM;GACN,YAAY,EACV,OAAO;IACL,MAAM;IACN,SAAS;IACT,SAAS;IACT,aAAa;IACd,EACF;GACD,UAAU,CAAC,QAAQ;GACpB;EACD,gBAAgB;EACjB,CACF;CACD,QAAQ;EACN,YAAY;EACZ,YAAY;EACb;CACD,QAAQ;EACN,YAAY,EAAE,KAAK,IAAK;EACxB,YAAY;GACV,qBAAqB;GACrB,kBAAkB;GACnB;EACD,OAAO,CAAC,oBAAoB;EAC7B;CACF,CAAC"}
|
|
@@ -1,23 +0,0 @@
|
|
|
1
|
-
import "../services/assessment-service.js";
|
|
2
|
-
|
|
3
|
-
//#region src/api/rest-handlers.ts
|
|
4
|
-
const createLifecycleHandlers = (service) => ({
|
|
5
|
-
runAssessment: async (req) => {
|
|
6
|
-
const payload = req.body ?? {};
|
|
7
|
-
return {
|
|
8
|
-
status: 200,
|
|
9
|
-
body: await service.runAssessment(payload)
|
|
10
|
-
};
|
|
11
|
-
},
|
|
12
|
-
getPlaybook: async (req) => {
|
|
13
|
-
const stage = Number(req.params?.stage ?? 0);
|
|
14
|
-
return {
|
|
15
|
-
status: 200,
|
|
16
|
-
body: service.getStagePlaybook(stage)
|
|
17
|
-
};
|
|
18
|
-
}
|
|
19
|
-
});
|
|
20
|
-
|
|
21
|
-
//#endregion
|
|
22
|
-
export { createLifecycleHandlers };
|
|
23
|
-
//# sourceMappingURL=rest-handlers.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"rest-handlers.js","names":[],"sources":["../../src/api/rest-handlers.ts"],"sourcesContent":["import type { LifecycleStage } from '@contractspec/lib.lifecycle';\nimport type {\n LifecycleAssessmentRequest,\n LifecycleAssessmentResponse,\n} from '../services/assessment-service';\nimport { LifecycleAssessmentService } from '../services/assessment-service';\n\nexport interface HttpRequest<\n TBody = unknown,\n TParams = Record<string, string>,\n> {\n body?: TBody;\n params?: TParams;\n query?: Record<string, string | undefined>;\n}\n\nexport interface HttpResponse<T = Record<string, unknown>> {\n status: number;\n body: T;\n}\n\nexport const createLifecycleHandlers = (\n service: LifecycleAssessmentService\n) => ({\n runAssessment: async (\n req: HttpRequest<LifecycleAssessmentRequest>\n ): Promise<HttpResponse<LifecycleAssessmentResponse>> => {\n const payload = req.body ?? {};\n const result = await service.runAssessment(payload);\n return { status: 200, body: result };\n },\n getPlaybook: async (\n req: HttpRequest<unknown, { stage: string }>\n ): Promise<HttpResponse> => {\n const stage = Number(req.params?.stage ?? 0) as LifecycleStage;\n const result = service.getStagePlaybook(stage);\n return { status: 200, body: result };\n },\n});\n"],"mappings":";;;AAqBA,MAAa,2BACX,aACI;CACJ,eAAe,OACb,QACuD;EACvD,MAAM,UAAU,IAAI,QAAQ,EAAE;AAE9B,SAAO;GAAE,QAAQ;GAAK,MADP,MAAM,QAAQ,cAAc,QAAQ;GACf;;CAEtC,aAAa,OACX,QAC0B;EAC1B,MAAM,QAAQ,OAAO,IAAI,QAAQ,SAAS,EAAE;AAE5C,SAAO;GAAE,QAAQ;GAAK,MADP,QAAQ,iBAAiB,MAAM;GACV;;CAEvC"}
|
|
@@ -1,45 +0,0 @@
|
|
|
1
|
-
import { lifecycleEventNames } from "@contractspec/lib.analytics";
|
|
2
|
-
|
|
3
|
-
//#region src/events/lifecycle-events.ts
|
|
4
|
-
var LifecycleEventBridge = class {
|
|
5
|
-
constructor(publisher) {
|
|
6
|
-
this.publisher = publisher;
|
|
7
|
-
}
|
|
8
|
-
forward(event) {
|
|
9
|
-
if (!this.publisher) return;
|
|
10
|
-
switch (event.type) {
|
|
11
|
-
case "assessment.recorded":
|
|
12
|
-
this.publisher({
|
|
13
|
-
name: lifecycleEventNames.assessmentRun,
|
|
14
|
-
properties: {
|
|
15
|
-
tenantId: event.payload.tenantId,
|
|
16
|
-
stage: event.payload.stage
|
|
17
|
-
}
|
|
18
|
-
});
|
|
19
|
-
break;
|
|
20
|
-
case "stage.changed":
|
|
21
|
-
this.publisher({
|
|
22
|
-
name: lifecycleEventNames.stageChanged,
|
|
23
|
-
properties: {
|
|
24
|
-
tenantId: event.payload.tenantId,
|
|
25
|
-
previousStage: event.payload.previousStage,
|
|
26
|
-
nextStage: event.payload.nextStage
|
|
27
|
-
}
|
|
28
|
-
});
|
|
29
|
-
break;
|
|
30
|
-
case "confidence.low":
|
|
31
|
-
this.publisher({
|
|
32
|
-
name: `${lifecycleEventNames.assessmentRun}.low_confidence`,
|
|
33
|
-
properties: {
|
|
34
|
-
tenantId: event.payload.tenantId,
|
|
35
|
-
confidence: event.payload.confidence
|
|
36
|
-
}
|
|
37
|
-
});
|
|
38
|
-
break;
|
|
39
|
-
}
|
|
40
|
-
}
|
|
41
|
-
};
|
|
42
|
-
|
|
43
|
-
//#endregion
|
|
44
|
-
export { LifecycleEventBridge };
|
|
45
|
-
//# sourceMappingURL=lifecycle-events.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"lifecycle-events.js","names":[],"sources":["../../src/events/lifecycle-events.ts"],"sourcesContent":["import type { LifecyclePipelineEvent } from '@contractspec/lib.observability';\nimport { lifecycleEventNames } from '@contractspec/lib.analytics';\n\nexport interface ManagedLifecycleEvent {\n name: string;\n properties: Record<string, unknown>;\n}\n\nexport type LifecycleEventPublisher = (\n event: ManagedLifecycleEvent\n) => Promise<void> | void;\n\nexport class LifecycleEventBridge {\n constructor(private readonly publisher?: LifecycleEventPublisher) {}\n\n forward(event: LifecyclePipelineEvent) {\n if (!this.publisher) return;\n switch (event.type) {\n case 'assessment.recorded':\n this.publisher({\n name: lifecycleEventNames.assessmentRun,\n properties: {\n tenantId: event.payload.tenantId,\n stage: event.payload.stage,\n },\n });\n break;\n case 'stage.changed':\n this.publisher({\n name: lifecycleEventNames.stageChanged,\n properties: {\n tenantId: event.payload.tenantId,\n previousStage: event.payload.previousStage,\n nextStage: event.payload.nextStage,\n },\n });\n break;\n case 'confidence.low':\n this.publisher({\n name: `${lifecycleEventNames.assessmentRun}.low_confidence`,\n properties: {\n tenantId: event.payload.tenantId,\n confidence: event.payload.confidence,\n },\n });\n break;\n }\n }\n}\n"],"mappings":";;;AAYA,IAAa,uBAAb,MAAkC;CAChC,YAAY,AAAiB,WAAqC;EAArC;;CAE7B,QAAQ,OAA+B;AACrC,MAAI,CAAC,KAAK,UAAW;AACrB,UAAQ,MAAM,MAAd;GACE,KAAK;AACH,SAAK,UAAU;KACb,MAAM,oBAAoB;KAC1B,YAAY;MACV,UAAU,MAAM,QAAQ;MACxB,OAAO,MAAM,QAAQ;MACtB;KACF,CAAC;AACF;GACF,KAAK;AACH,SAAK,UAAU;KACb,MAAM,oBAAoB;KAC1B,YAAY;MACV,UAAU,MAAM,QAAQ;MACxB,eAAe,MAAM,QAAQ;MAC7B,WAAW,MAAM,QAAQ;MAC1B;KACF,CAAC;AACF;GACF,KAAK;AACH,SAAK,UAAU;KACb,MAAM,GAAG,oBAAoB,cAAc;KAC3C,YAAY;MACV,UAAU,MAAM,QAAQ;MACxB,YAAY,MAAM,QAAQ;MAC3B;KACF,CAAC;AACF"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
import "./workflow.js";
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
import "../types.js";
|
|
@@ -1,14 +0,0 @@
|
|
|
1
|
-
import { AgentConfidencePolicy, AgentEscalationPolicy, AgentKnowledgeRef, AgentMemoryConfig, AgentMeta, AgentPolicy, AgentSpec, AgentToolConfig } from "./spec/spec.js";
|
|
2
|
-
import "./types.js";
|
|
3
|
-
import "./agent/index.js";
|
|
4
|
-
import "./spec/index.js";
|
|
5
|
-
import "./tools/index.js";
|
|
6
|
-
import "./schema/index.js";
|
|
7
|
-
import "./knowledge/index.js";
|
|
8
|
-
import "./session/index.js";
|
|
9
|
-
import "./telemetry/index.js";
|
|
10
|
-
import "./approval/index.js";
|
|
11
|
-
import "./providers/index.js";
|
|
12
|
-
import "./exporters/index.js";
|
|
13
|
-
import "./interop/index.js";
|
|
14
|
-
import "ai";
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
import "./injector.js";
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
import "../spec/spec.js";
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
import "../../types.js";
|