@lucern/contracts 1.0.15 → 1.0.17
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/CHANGELOG.md +6 -0
- package/dist/api-enums.contract.d.ts +2 -2
- package/dist/api-enums.contract.js +2 -8
- package/dist/api-enums.contract.js.map +1 -1
- package/dist/context-pack.contract.d.ts +33 -7
- package/dist/context-pack.contract.js.map +1 -1
- package/dist/function-registry/beliefs.js +113 -115
- package/dist/function-registry/beliefs.js.map +1 -1
- package/dist/function-registry/coding.js +72 -91
- package/dist/function-registry/coding.js.map +1 -1
- package/dist/function-registry/context.js +72 -91
- package/dist/function-registry/context.js.map +1 -1
- package/dist/function-registry/contracts.js +72 -91
- package/dist/function-registry/contracts.js.map +1 -1
- package/dist/function-registry/coordination.js +72 -91
- package/dist/function-registry/coordination.js.map +1 -1
- package/dist/function-registry/edges.js +72 -91
- package/dist/function-registry/edges.js.map +1 -1
- package/dist/function-registry/evidence.js +186 -125
- package/dist/function-registry/evidence.js.map +1 -1
- package/dist/function-registry/graph.js +72 -91
- package/dist/function-registry/graph.js.map +1 -1
- package/dist/function-registry/helpers.js +72 -91
- package/dist/function-registry/helpers.js.map +1 -1
- package/dist/function-registry/identity.js +72 -91
- package/dist/function-registry/identity.js.map +1 -1
- package/dist/function-registry/index.js +72 -91
- package/dist/function-registry/index.js.map +1 -1
- package/dist/function-registry/judgments.js +72 -91
- package/dist/function-registry/judgments.js.map +1 -1
- package/dist/function-registry/legacy.js +72 -91
- package/dist/function-registry/legacy.js.map +1 -1
- package/dist/function-registry/lenses.js +72 -91
- package/dist/function-registry/lenses.js.map +1 -1
- package/dist/function-registry/manifest.d.ts +3 -3
- package/dist/function-registry/manifest.js +3 -3
- package/dist/function-registry/manifest.js.map +1 -1
- package/dist/function-registry/nodes.js +72 -91
- package/dist/function-registry/nodes.js.map +1 -1
- package/dist/function-registry/ontologies.js +72 -91
- package/dist/function-registry/ontologies.js.map +1 -1
- package/dist/function-registry/pipeline.js +72 -91
- package/dist/function-registry/pipeline.js.map +1 -1
- package/dist/function-registry/questions.js +72 -91
- package/dist/function-registry/questions.js.map +1 -1
- package/dist/function-registry/tasks.js +72 -91
- package/dist/function-registry/tasks.js.map +1 -1
- package/dist/function-registry/topics.js +72 -91
- package/dist/function-registry/topics.js.map +1 -1
- package/dist/function-registry/worktrees.js +72 -91
- package/dist/function-registry/worktrees.js.map +1 -1
- package/dist/generated/convexSchemas.js +2 -2
- package/dist/generated/convexSchemas.js.map +1 -1
- package/dist/index.d.ts +4 -4
- package/dist/index.js +166 -130
- package/dist/index.js.map +1 -1
- package/dist/manifests/invariant-manifest.d.ts +1 -1
- package/dist/manifests/invariants/index.d.ts +1 -1
- package/dist/manifests/invariants/index.js +1 -1
- package/dist/manifests/invariants/index.js.map +1 -1
- package/dist/manifests/invariants/inv-1-beliefs-append-only.d.ts +1 -1
- package/dist/manifests/invariants/inv-14-no-silent-transitions.d.ts +1 -1
- package/dist/manifests/invariants/manifest-1-projections-declare-audit.d.ts +1 -1
- package/dist/manifests/invariants/manifest-1-projections-declare-audit.js +1 -1
- package/dist/manifests/invariants/manifest-1-projections-declare-audit.js.map +1 -1
- package/dist/projections/{modulate-confidence.projection.d.ts → append-sl-scoring.projection.d.ts} +69 -69
- package/dist/projections/{modulate-confidence.projection.js → append-sl-scoring.projection.js} +14 -14
- package/dist/projections/append-sl-scoring.projection.js.map +1 -0
- package/dist/projections/check-convex-args-shape.js +88 -29
- package/dist/projections/check-convex-args-shape.js.map +1 -1
- package/dist/projections/create-evidence.projection.js +76 -17
- package/dist/projections/create-evidence.projection.js.map +1 -1
- package/dist/projections/index.d.ts +47 -47
- package/dist/projections/index.js +88 -29
- package/dist/projections/index.js.map +1 -1
- package/dist/proof-attestation.json +3 -3
- package/dist/schemas/index.js +6 -4
- package/dist/schemas/index.js.map +1 -1
- package/dist/schemas/manifest.d.ts +110 -60
- package/dist/schemas/manifest.js +6 -4
- package/dist/schemas/manifest.js.map +1 -1
- package/dist/schemas/tables/kernel/intelligence.d.ts +20 -10
- package/dist/schemas/tables/kernel/intelligence.js +4 -2
- package/dist/schemas/tables/kernel/intelligence.js.map +1 -1
- package/dist/schemas/tables/kernel/spine.d.ts +2 -2
- package/dist/schemas/tables/kernel/spine.js +2 -2
- package/dist/schemas/tables/kernel/spine.js.map +1 -1
- package/dist/schemas.values.js +6 -4
- package/dist/schemas.values.js.map +1 -1
- package/dist/sdk-methods.contract.d.ts +12 -16
- package/dist/sdk-tools.contract.js +69 -88
- package/dist/sdk-tools.contract.js.map +1 -1
- package/dist/sdk-tools.contract.registry.js +69 -88
- package/dist/sdk-tools.contract.registry.js.map +1 -1
- package/dist/sdk-tools.contract.values.js +69 -88
- package/dist/sdk-tools.contract.values.js.map +1 -1
- package/dist/tool-contracts.d.ts +1 -1
- package/dist/tool-contracts.graph.js +3 -3
- package/dist/tool-contracts.graph.js.map +1 -1
- package/dist/tool-contracts.intelligence-evidence.js +7 -7
- package/dist/tool-contracts.intelligence-evidence.js.map +1 -1
- package/dist/tool-contracts.js +70 -89
- package/dist/tool-contracts.js.map +1 -1
- package/dist/tool-contracts.lifecycle.d.ts +2 -2
- package/dist/tool-contracts.lifecycle.js +49 -68
- package/dist/tool-contracts.lifecycle.js.map +1 -1
- package/dist/tool-contracts.pipeline-coordination.js +1 -1
- package/dist/tool-contracts.pipeline-coordination.js.map +1 -1
- package/dist/tool-contracts.questions-listing.js +9 -9
- package/dist/tool-contracts.questions-listing.js.map +1 -1
- package/dist/{tool-contracts.values-BhxfrXS5.d.ts → tool-contracts.values-CCoI3qQY.d.ts} +3 -3
- package/dist/tool-contracts.values.d.ts +1 -1
- package/dist/tool-contracts.values.js +70 -89
- package/dist/tool-contracts.values.js.map +1 -1
- package/package.json +1 -1
- package/dist/projections/modulate-confidence.projection.js.map +0 -1
|
@@ -6,15 +6,23 @@ import { v } from 'convex/values';
|
|
|
6
6
|
// src/tool-contracts.lifecycle.ts
|
|
7
7
|
var CREATE_BELIEF = {
|
|
8
8
|
name: "create_belief",
|
|
9
|
-
description: "Commit a new belief (knowledge unit) to the reasoning graph. Like `git commit` \u2014 creates an atomic, traceable knowledge object with a prior. Creation stores the vacuous opinion `(0, 0, 1, a)`; attach supporting or contradicting evidence with create_evidence or link_evidence_to_belief to record evidential updates.",
|
|
9
|
+
description: "Commit a new belief (knowledge unit) to the reasoning graph. Like `git commit` \u2014 creates an atomic, traceable knowledge object with a prior. Creation requires a topic epistemic-node anchor and writes a `scoped_by` edge directly from belief node to topic node; orphan beliefs are invalid. Creation stores the vacuous opinion `(0, 0, 1, a)`; attach supporting or contradicting evidence with create_evidence or link_evidence_to_belief to record evidential updates.",
|
|
10
10
|
parameters: {
|
|
11
11
|
canonicalText: {
|
|
12
12
|
type: "string",
|
|
13
13
|
description: "The belief statement \u2014 what the agent holds to be true"
|
|
14
14
|
},
|
|
15
|
+
topicGlobalId: {
|
|
16
|
+
type: "string",
|
|
17
|
+
description: "Required globalId (UUID) of the topic node in epistemicNodes that anchors the belief"
|
|
18
|
+
},
|
|
19
|
+
topicNodeId: {
|
|
20
|
+
type: "string",
|
|
21
|
+
description: "Optional internal epistemicNodes _id for the topic anchor. Prefer topicGlobalId for public callers."
|
|
22
|
+
},
|
|
15
23
|
topicId: {
|
|
16
24
|
type: "string",
|
|
17
|
-
description: "
|
|
25
|
+
description: "Deprecated compatibility alias for topicGlobalId. Must identify a topic epistemicNode, not a legacy topics-table row."
|
|
18
26
|
},
|
|
19
27
|
baseRate: {
|
|
20
28
|
type: "number",
|
|
@@ -29,7 +37,7 @@ var CREATE_BELIEF = {
|
|
|
29
37
|
description: "Optional extra metadata merged into the node (e.g., { codeAnchors: ['path/to/file.ts'] } for coding intelligence)"
|
|
30
38
|
}
|
|
31
39
|
},
|
|
32
|
-
required: ["canonicalText"],
|
|
40
|
+
required: ["canonicalText", "topicGlobalId"],
|
|
33
41
|
response: {
|
|
34
42
|
description: "The created canonical belief record",
|
|
35
43
|
fields: {
|
|
@@ -38,7 +46,7 @@ var CREATE_BELIEF = {
|
|
|
38
46
|
beliefId: "string \u2014 canonical belief ID",
|
|
39
47
|
text: "string \u2014 canonical belief formulation",
|
|
40
48
|
topicId: "string",
|
|
41
|
-
|
|
49
|
+
beliefStatus: "string \u2014 assumption | hypothesis | active | superseded | resolved_true | resolved_false",
|
|
42
50
|
scoringState: "string \u2014 unscored | scored"
|
|
43
51
|
}
|
|
44
52
|
},
|
|
@@ -61,7 +69,7 @@ var GET_BELIEF = {
|
|
|
61
69
|
beliefId: "string \u2014 canonical belief ID",
|
|
62
70
|
text: "string \u2014 canonical belief formulation",
|
|
63
71
|
topicId: "string",
|
|
64
|
-
|
|
72
|
+
beliefStatus: "string \u2014 assumption | hypothesis | active | superseded | resolved_true | resolved_false",
|
|
65
73
|
scoringState: "string \u2014 unscored | scored"
|
|
66
74
|
}
|
|
67
75
|
},
|
|
@@ -90,34 +98,24 @@ var REFINE_BELIEF = {
|
|
|
90
98
|
ontologyPrimitive: "belief",
|
|
91
99
|
tier: "showcase"
|
|
92
100
|
};
|
|
93
|
-
var
|
|
94
|
-
name: "
|
|
95
|
-
description: "Internal
|
|
101
|
+
var APPEND_SL_SCORING = {
|
|
102
|
+
name: "append_sl_scoring",
|
|
103
|
+
description: "Internal evidence-backed Subjective Logic scoring append. This is not a public MCP tool: callers should attach supporting or contradicting evidence, and governed system paths append the derived SL tuple.",
|
|
96
104
|
parameters: {
|
|
97
|
-
nodeId: { type: "string", description: "The belief
|
|
98
|
-
belief: {
|
|
99
|
-
type: "number",
|
|
100
|
-
description: "Subjective-logic belief mass `b` in [0, 1]"
|
|
101
|
-
},
|
|
105
|
+
nodeId: { type: "string", description: "The belief receiving the SL score" },
|
|
106
|
+
belief: { type: "number", description: "Subjective Logic belief mass b" },
|
|
102
107
|
disbelief: {
|
|
103
108
|
type: "number",
|
|
104
|
-
description: "Subjective
|
|
109
|
+
description: "Subjective Logic disbelief mass d"
|
|
105
110
|
},
|
|
106
111
|
uncertainty: {
|
|
107
112
|
type: "number",
|
|
108
|
-
description: "Subjective
|
|
109
|
-
},
|
|
110
|
-
baseRate: {
|
|
111
|
-
type: "number",
|
|
112
|
-
description: "Subjective-logic base rate `a` in [0, 1]. Required for tuple payloads."
|
|
113
|
-
},
|
|
114
|
-
worktreeId: {
|
|
115
|
-
type: "string",
|
|
116
|
-
description: "Completed worktree that tested this belief when confidence policy requires merge-backed scoring."
|
|
113
|
+
description: "Subjective Logic uncertainty mass u"
|
|
117
114
|
},
|
|
115
|
+
baseRate: { type: "number", description: "Subjective Logic base rate a" },
|
|
118
116
|
trigger: {
|
|
119
117
|
type: "string",
|
|
120
|
-
description: "
|
|
118
|
+
description: "Evidence-bearing cause of the scoring event",
|
|
121
119
|
enum: [
|
|
122
120
|
"evidence_added",
|
|
123
121
|
"evidence_removed",
|
|
@@ -128,64 +126,39 @@ var MODULATE_CONFIDENCE = {
|
|
|
128
126
|
"worktree_completed",
|
|
129
127
|
"fusion",
|
|
130
128
|
"discount",
|
|
131
|
-
"deduction"
|
|
129
|
+
"deduction",
|
|
130
|
+
"backfill_synthetic"
|
|
132
131
|
]
|
|
133
132
|
},
|
|
134
|
-
|
|
135
|
-
type: "
|
|
136
|
-
description: "
|
|
137
|
-
},
|
|
138
|
-
triggeringQuestionId: {
|
|
139
|
-
type: "string",
|
|
140
|
-
description: "Answered question whose resolution supports this modulation"
|
|
141
|
-
},
|
|
142
|
-
triggeringAnswerId: {
|
|
143
|
-
type: "string",
|
|
144
|
-
description: "Answer node whose content supports this modulation"
|
|
145
|
-
},
|
|
146
|
-
triggeringContradictionId: {
|
|
147
|
-
type: "string",
|
|
148
|
-
description: "Contradiction record that caused a contradiction-triggered modulation"
|
|
149
|
-
},
|
|
150
|
-
triggeringWorktreeId: {
|
|
151
|
-
type: "string",
|
|
152
|
-
description: "Completed worktree whose outcome caused a worktree-triggered modulation"
|
|
133
|
+
provenance: {
|
|
134
|
+
type: "object",
|
|
135
|
+
description: "At least one of evidence, question, answer, contradiction, or worktree."
|
|
153
136
|
},
|
|
154
137
|
rationale: {
|
|
155
138
|
type: "string",
|
|
156
|
-
description: "
|
|
139
|
+
description: "Why this evidence-bearing event moved the SL tuple"
|
|
157
140
|
}
|
|
158
141
|
},
|
|
159
|
-
required: [
|
|
160
|
-
"nodeId",
|
|
161
|
-
"belief",
|
|
162
|
-
"disbelief",
|
|
163
|
-
"uncertainty",
|
|
164
|
-
"baseRate",
|
|
165
|
-
"trigger",
|
|
166
|
-
"rationale"
|
|
167
|
-
],
|
|
142
|
+
required: ["nodeId", "belief", "disbelief", "uncertainty", "baseRate", "trigger", "rationale"],
|
|
168
143
|
response: {
|
|
169
|
-
description: "
|
|
144
|
+
description: "Internal SL scoring append receipt",
|
|
170
145
|
fields: {
|
|
171
|
-
|
|
172
|
-
nodeId: "string \u2014 canonical belief ID",
|
|
173
|
-
newConfidence: "number",
|
|
146
|
+
nodeId: "string",
|
|
174
147
|
previousConfidence: "number",
|
|
175
|
-
|
|
176
|
-
|
|
177
|
-
propagationSummary: "object \u2014 bounded inline cascade summary with totalCandidateTargets, inlineTargets, and remainingTargetCount"
|
|
148
|
+
newConfidence: "number",
|
|
149
|
+
beliefConfidenceId: "string"
|
|
178
150
|
}
|
|
179
151
|
},
|
|
180
152
|
ownerModule: "graph-primitives",
|
|
181
153
|
ontologyPrimitive: "belief",
|
|
182
|
-
tier: "
|
|
154
|
+
tier: "workhorse",
|
|
155
|
+
internal: true
|
|
183
156
|
};
|
|
184
157
|
var FORK_BELIEF = {
|
|
185
158
|
name: "fork_belief",
|
|
186
|
-
description: "Branch off
|
|
159
|
+
description: "Branch off an evidence-bearing belief to create a new formulation. Like `git fork` \u2014 the parent remains immutable with full history, and every fork must cite evidence already attached to the parent through SL scoring. `forkMode=supersede` marks the parent superseded and requires contradicting evidence; `forkMode=branch` preserves the parent and creates a derived child.",
|
|
187
160
|
parameters: {
|
|
188
|
-
nodeId: { type: "string", description: "The
|
|
161
|
+
nodeId: { type: "string", description: "The belief to fork from" },
|
|
189
162
|
newFormulation: {
|
|
190
163
|
type: "string",
|
|
191
164
|
description: "The evolved belief statement"
|
|
@@ -197,12 +170,20 @@ var FORK_BELIEF = {
|
|
|
197
170
|
"refinement",
|
|
198
171
|
"contradiction_response",
|
|
199
172
|
"scope_change",
|
|
200
|
-
"confidence_collapse"
|
|
201
|
-
"manual"
|
|
173
|
+
"confidence_collapse"
|
|
202
174
|
]
|
|
175
|
+
},
|
|
176
|
+
forkMode: {
|
|
177
|
+
type: "string",
|
|
178
|
+
description: "supersede replaces the parent; branch creates a child while preserving the parent.",
|
|
179
|
+
enum: ["supersede", "branch"]
|
|
180
|
+
},
|
|
181
|
+
triggeringEvidenceId: {
|
|
182
|
+
type: "string",
|
|
183
|
+
description: "Evidence already attached to the parent belief that caused the fork."
|
|
203
184
|
}
|
|
204
185
|
},
|
|
205
|
-
required: ["nodeId", "newFormulation", "forkReason"],
|
|
186
|
+
required: ["nodeId", "newFormulation", "forkReason", "triggeringEvidenceId"],
|
|
206
187
|
response: {
|
|
207
188
|
description: "The forked canonical belief record",
|
|
208
189
|
fields: {
|
|
@@ -704,7 +685,7 @@ var REASONING_METHODS = [
|
|
|
704
685
|
// src/tool-contracts.graph.ts
|
|
705
686
|
var QUERY_LINEAGE = {
|
|
706
687
|
name: "query_lineage",
|
|
707
|
-
description: "Trace a belief's full ancestry \u2014 every fork, score, and
|
|
688
|
+
description: "Trace a belief's full ancestry \u2014 every fork, score, and SL scoring event. Like `git log --graph`. Returns the complete evolution chain showing how understanding developed over time. Lineage is permanent and can never be erased (Invariant #3).",
|
|
708
689
|
parameters: {
|
|
709
690
|
nodeId: { type: "string", description: "Starting node to trace from" },
|
|
710
691
|
depth: {
|
|
@@ -903,7 +884,7 @@ var FIND_CONTRADICTIONS = {
|
|
|
903
884
|
};
|
|
904
885
|
var BISECT_CONFIDENCE = {
|
|
905
886
|
name: "bisect_confidence",
|
|
906
|
-
description: "Find when a belief's confidence diverged from reality. Like `git bisect` \u2014 binary search through the credence history to find the inflection point. Given a belief that is now known to be wrong (or right), traces back through
|
|
887
|
+
description: "Find when a belief's confidence diverged from reality. Like `git bisect` \u2014 binary search through the credence history to find the inflection point. Given a belief that is now known to be wrong (or right), traces back through SL scoring events to identify which evidence or event caused the divergence.",
|
|
907
888
|
parameters: {
|
|
908
889
|
nodeId: { type: "string", description: "The belief to bisect" },
|
|
909
890
|
expectedDirection: {
|
|
@@ -922,7 +903,7 @@ var BISECT_CONFIDENCE = {
|
|
|
922
903
|
fields: {
|
|
923
904
|
beliefId: "string \u2014 canonical belief ID",
|
|
924
905
|
expectedDirection: "string \u2014 overconfident | underconfident",
|
|
925
|
-
inflectionEntry: "object \u2014 the
|
|
906
|
+
inflectionEntry: "object \u2014 the scoring event where divergence began",
|
|
926
907
|
triggerEvent: "string | null \u2014 what caused the divergence",
|
|
927
908
|
confidenceBefore: "number | null",
|
|
928
909
|
confidenceAfter: "number | null",
|
|
@@ -1867,18 +1848,18 @@ var SEARCH_EVIDENCE = {
|
|
|
1867
1848
|
};
|
|
1868
1849
|
var CREATE_EVIDENCE = {
|
|
1869
1850
|
name: "create_evidence",
|
|
1870
|
-
description: "Commit evidence to the reasoning graph. Like `git commit` \u2014 creates a traceable evidence record with canonical public IDs.
|
|
1851
|
+
description: "Commit evidence to the reasoning graph. Like `git commit` \u2014 creates a traceable evidence record with canonical public IDs. Evidence creation must link to at least one belief and must include a signed impact score. Positive scores support the belief; negative scores contradict it. SL confidence is derived from these weighted evidence relations.",
|
|
1871
1852
|
parameters: {
|
|
1872
1853
|
topicId: { type: "string", description: "Topic scope" },
|
|
1873
1854
|
text: { type: "string", description: "Canonical evidence text" },
|
|
1874
1855
|
source: { type: "string", description: "Source URL or source label" },
|
|
1875
1856
|
targetId: {
|
|
1876
1857
|
type: "string",
|
|
1877
|
-
description: "
|
|
1858
|
+
description: "Belief identifier to link immediately"
|
|
1878
1859
|
},
|
|
1879
1860
|
weight: {
|
|
1880
1861
|
type: "number",
|
|
1881
|
-
description: "
|
|
1862
|
+
description: "Required nonzero signed impact score: -1.0 (contradicts) to +1.0 (supports)."
|
|
1882
1863
|
},
|
|
1883
1864
|
evidenceRelation: {
|
|
1884
1865
|
type: "string",
|
|
@@ -1887,7 +1868,7 @@ var CREATE_EVIDENCE = {
|
|
|
1887
1868
|
},
|
|
1888
1869
|
confidence: {
|
|
1889
1870
|
type: "number",
|
|
1890
|
-
description: "
|
|
1871
|
+
description: "Deprecated hint. Runtime confidence is derived from the signed impact score."
|
|
1891
1872
|
},
|
|
1892
1873
|
beliefRelations: {
|
|
1893
1874
|
type: "array",
|
|
@@ -1909,7 +1890,7 @@ var CREATE_EVIDENCE = {
|
|
|
1909
1890
|
},
|
|
1910
1891
|
kind: { type: "string", description: "Optional evidence kind" }
|
|
1911
1892
|
},
|
|
1912
|
-
required: ["text", "rationale"],
|
|
1893
|
+
required: ["text", "rationale", "weight"],
|
|
1913
1894
|
response: {
|
|
1914
1895
|
description: "The created canonical evidence record",
|
|
1915
1896
|
fields: {
|
|
@@ -1984,7 +1965,7 @@ var LINK_EVIDENCE = {
|
|
|
1984
1965
|
},
|
|
1985
1966
|
rationale: { type: "string", description: "Why this link exists" }
|
|
1986
1967
|
},
|
|
1987
|
-
required: ["evidenceId", "targetId"],
|
|
1968
|
+
required: ["evidenceId", "targetId", "weight"],
|
|
1988
1969
|
response: {
|
|
1989
1970
|
description: "The created canonical evidence edge summary",
|
|
1990
1971
|
fields: {
|
|
@@ -2020,7 +2001,7 @@ var LINK_EVIDENCE_TO_BELIEF = {
|
|
|
2020
2001
|
},
|
|
2021
2002
|
rationale: { type: "string", description: "Why this evidence is relevant" }
|
|
2022
2003
|
},
|
|
2023
|
-
required: ["evidenceId", "beliefId"],
|
|
2004
|
+
required: ["evidenceId", "beliefId", "weight"],
|
|
2024
2005
|
response: {
|
|
2025
2006
|
description: "The created edge linking evidence to belief",
|
|
2026
2007
|
fields: {
|
|
@@ -2822,6 +2803,10 @@ var COMPILE_CONTEXT = {
|
|
|
2822
2803
|
type: "number",
|
|
2823
2804
|
description: "Optional per-section item limit"
|
|
2824
2805
|
},
|
|
2806
|
+
contentTopicLimit: {
|
|
2807
|
+
type: "number",
|
|
2808
|
+
description: "Dimension-seeded compiles synthesize every matching worktree but bound raw belief/question/evidence enrichment to this many carrier topics (max 16) so hosted Convex queries remain fast. Receipts report any omitted raw topic enrichment."
|
|
2809
|
+
},
|
|
2825
2810
|
maxDepth: {
|
|
2826
2811
|
type: "number",
|
|
2827
2812
|
description: "Optional descendant topic depth for neighborhood expansion"
|
|
@@ -2835,6 +2820,11 @@ var COMPILE_CONTEXT = {
|
|
|
2835
2820
|
response: {
|
|
2836
2821
|
description: "Compiled context pack for the requested topic",
|
|
2837
2822
|
fields: {
|
|
2823
|
+
contextNarrative: "array \u2014 first field; ordered synthesis blocks with kind/text, starting with executive_summary and canonical narrative blocks before raw objects",
|
|
2824
|
+
narrativeCoverage: "object \u2014 recordsSynthesized, recordsNamed, recordsOmitted, topicsSynthesized, topicsEnriched, topicContentOmitted, enrichmentMode, and blocksEmitted for the narrative",
|
|
2825
|
+
synthesisLints: "array \u2014 inline quality warnings for degenerate synthesis blocks or weak narrative coverage",
|
|
2826
|
+
retrievalReceipt: "object \u2014 candidateCounts, coverageWarning, narrativeCoverage, synthesisLints, and suggestedNextActions",
|
|
2827
|
+
supportingObjects: "object \u2014 raw graph records grouped behind the synthesis: invariants, activeBeliefs, openQuestions, recentEvidence, worktrees, lanes, entities, and contradictions",
|
|
2838
2828
|
schemaVersion: "string",
|
|
2839
2829
|
topicId: "string",
|
|
2840
2830
|
topicName: "string",
|
|
@@ -2842,15 +2832,6 @@ var COMPILE_CONTEXT = {
|
|
|
2842
2832
|
generatedAt: "number \u2014 deterministic graph-backed reference timestamp for this compilation",
|
|
2843
2833
|
ranking: "string \u2014 baseline_v1 | weighted_v1",
|
|
2844
2834
|
summary: "object \u2014 counts and scoped health signals",
|
|
2845
|
-
invariants: "array \u2014 high-confidence invariant beliefs",
|
|
2846
|
-
activeBeliefs: "array \u2014 current high-signal beliefs",
|
|
2847
|
-
openQuestions: "array \u2014 unresolved questions ranked for this query",
|
|
2848
|
-
recentEvidence: "array \u2014 recent evidence ranked for this query",
|
|
2849
|
-
contradictions: "array \u2014 unresolved contradiction records",
|
|
2850
|
-
relatedEntities: "array | undefined \u2014 ranked ontological entities in scope",
|
|
2851
|
-
contextNarrative: "array \u2014 ordered synthesis blocks with kind/text, starting with executive_summary and canonical narrative blocks before raw objects",
|
|
2852
|
-
retrievalReceipt: "object \u2014 candidateCounts, coverageWarning, narrativeCoverage, synthesisLints, and suggestedNextActions",
|
|
2853
|
-
narrativeCoverage: "object \u2014 recordsSynthesized, recordsNamed, recordsOmitted, and blocksEmitted for the narrative",
|
|
2854
2835
|
injectionPolicy: "object \u2014 token-budgeted section selections",
|
|
2855
2836
|
diagnostics: "object \u2014 scoring and utilization telemetry"
|
|
2856
2837
|
}
|
|
@@ -4269,7 +4250,7 @@ var TRIGGER_BELIEF_REVIEW = {
|
|
|
4269
4250
|
};
|
|
4270
4251
|
var EVALUATE_CONTRACT = {
|
|
4271
4252
|
name: "evaluate_contract",
|
|
4272
|
-
description: "Run a contract evaluation and record the append-only result. Like `git test` for a belief binding \u2014 executes the evaluator, logs the result, and applies any allowed
|
|
4253
|
+
description: "Run a contract evaluation and record the append-only result. Like `git test` for a belief binding \u2014 executes the evaluator, logs the result, and applies any allowed SL scoring action.",
|
|
4273
4254
|
parameters: {
|
|
4274
4255
|
contractId: { type: "string", description: "Which contract to evaluate" },
|
|
4275
4256
|
trigger: {
|
|
@@ -4625,7 +4606,7 @@ var MCP_TOOL_CONTRACTS = {
|
|
|
4625
4606
|
create_belief: CREATE_BELIEF,
|
|
4626
4607
|
get_belief: GET_BELIEF,
|
|
4627
4608
|
refine_belief: REFINE_BELIEF,
|
|
4628
|
-
|
|
4609
|
+
append_sl_scoring: APPEND_SL_SCORING,
|
|
4629
4610
|
fork_belief: FORK_BELIEF,
|
|
4630
4611
|
archive_belief: ARCHIVE_BELIEF,
|
|
4631
4612
|
create_epistemic_contract: CREATE_EPISTEMIC_CONTRACT,
|
|
@@ -5120,12 +5101,12 @@ var LUCERN_OPERATION_MANIFEST = {
|
|
|
5120
5101
|
internalSystem,
|
|
5121
5102
|
"Lucern system/background operation. Available to platform code paths, hidden from public MCP discovery."
|
|
5122
5103
|
),
|
|
5123
|
-
|
|
5124
|
-
name: "
|
|
5104
|
+
append_sl_scoring: {
|
|
5105
|
+
name: "append_sl_scoring",
|
|
5125
5106
|
surfaceClass: "platform_internal",
|
|
5126
5107
|
surfaceIntent: "system",
|
|
5127
5108
|
surfaces: internalSdkRestOnly,
|
|
5128
|
-
rationale: "Internal SL
|
|
5109
|
+
rationale: "Internal SL scoring append primitive. Public callers attach evidence or contradiction relations; confidence is derived algorithmically."
|
|
5129
5110
|
},
|
|
5130
5111
|
...entries(
|
|
5131
5112
|
LEGACY_COMPAT_OPERATION_NAMES,
|
|
@@ -5513,11 +5494,39 @@ var createEvidenceInputSchemaBase = z.object({
|
|
|
5513
5494
|
metadata: jsonRecordSchema.optional(),
|
|
5514
5495
|
trustedBypassAccessCheck: z.boolean().optional()
|
|
5515
5496
|
}).passthrough();
|
|
5516
|
-
function
|
|
5517
|
-
return typeof value === "number" && Number.isFinite(value) && value !== 0;
|
|
5497
|
+
function isSignedImpactScore(value) {
|
|
5498
|
+
return typeof value === "number" && Number.isFinite(value) && value >= -1 && value <= 1 && value !== 0;
|
|
5518
5499
|
}
|
|
5519
|
-
function
|
|
5520
|
-
|
|
5500
|
+
function validateSignedImpactScore(value, ctx, path) {
|
|
5501
|
+
if (!isSignedImpactScore(value)) {
|
|
5502
|
+
ctx.addIssue({
|
|
5503
|
+
code: z.ZodIssueCode.custom,
|
|
5504
|
+
message: "evidence-to-belief links require an explicit nonzero signed impact score in [-1, 1]",
|
|
5505
|
+
path
|
|
5506
|
+
});
|
|
5507
|
+
return false;
|
|
5508
|
+
}
|
|
5509
|
+
return true;
|
|
5510
|
+
}
|
|
5511
|
+
function validateRelationImpactConsistency(relation, weight, ctx, path) {
|
|
5512
|
+
const normalized = normalizeRelationAlias(relation);
|
|
5513
|
+
if (!normalized || !isSignedImpactScore(weight)) {
|
|
5514
|
+
return;
|
|
5515
|
+
}
|
|
5516
|
+
if (normalized === "supports" && weight < 0) {
|
|
5517
|
+
ctx.addIssue({
|
|
5518
|
+
code: z.ZodIssueCode.custom,
|
|
5519
|
+
message: "supporting evidence requires a positive impact score",
|
|
5520
|
+
path
|
|
5521
|
+
});
|
|
5522
|
+
}
|
|
5523
|
+
if (normalized === "contradicts" && weight > 0) {
|
|
5524
|
+
ctx.addIssue({
|
|
5525
|
+
code: z.ZodIssueCode.custom,
|
|
5526
|
+
message: "contradicting evidence requires a negative impact score",
|
|
5527
|
+
path
|
|
5528
|
+
});
|
|
5529
|
+
}
|
|
5521
5530
|
}
|
|
5522
5531
|
var createEvidenceInputSchema = createEvidenceInputSchemaBase.superRefine(
|
|
5523
5532
|
(input, ctx) => {
|
|
@@ -5534,13 +5543,27 @@ var createEvidenceInputSchema = createEvidenceInputSchemaBase.superRefine(
|
|
|
5534
5543
|
input.linkedBeliefNodeId || kind === "belief" || kind === "unknown" && target
|
|
5535
5544
|
);
|
|
5536
5545
|
const weight = typeof input.weight === "number" ? input.weight : void 0;
|
|
5537
|
-
|
|
5546
|
+
const hasBeliefRelations = (input.beliefRelations?.length ?? 0) > 0;
|
|
5547
|
+
if (!linksPrimaryBelief && !hasBeliefRelations) {
|
|
5548
|
+
ctx.addIssue({
|
|
5549
|
+
code: z.ZodIssueCode.custom,
|
|
5550
|
+
message: "create_evidence requires at least one linked belief; evidence cannot be created as an orphan or linked only to a question/worktree",
|
|
5551
|
+
path: ["linkedBeliefNodeId"]
|
|
5552
|
+
});
|
|
5553
|
+
}
|
|
5554
|
+
if (kind === "question" || kind === "worktree") {
|
|
5538
5555
|
ctx.addIssue({
|
|
5539
5556
|
code: z.ZodIssueCode.custom,
|
|
5540
|
-
message: "belief
|
|
5541
|
-
path: ["
|
|
5557
|
+
message: "create_evidence targetId must be a belief. Link evidence to questions/worktrees only after the evidence has a belief impact edge.",
|
|
5558
|
+
path: ["targetId"]
|
|
5542
5559
|
});
|
|
5543
5560
|
}
|
|
5561
|
+
if (linksPrimaryBelief) {
|
|
5562
|
+
validateSignedImpactScore(weight, ctx, ["weight"]);
|
|
5563
|
+
validateRelationImpactConsistency(input.evidenceRelation, weight, ctx, [
|
|
5564
|
+
"weight"
|
|
5565
|
+
]);
|
|
5566
|
+
}
|
|
5544
5567
|
input.beliefRelations?.forEach((relation, index) => {
|
|
5545
5568
|
const beliefNodeId = relation.beliefNodeId ?? relation.beliefId ?? relation.targetId;
|
|
5546
5569
|
if (!beliefNodeId) {
|
|
@@ -5551,15 +5574,18 @@ var createEvidenceInputSchema = createEvidenceInputSchemaBase.superRefine(
|
|
|
5551
5574
|
});
|
|
5552
5575
|
}
|
|
5553
5576
|
const relationWeight2 = typeof relation.weight === "number" ? relation.weight : void 0;
|
|
5554
|
-
if (beliefNodeId
|
|
5555
|
-
|
|
5556
|
-
|
|
5557
|
-
|
|
5558
|
-
|
|
5559
|
-
|
|
5560
|
-
|
|
5561
|
-
|
|
5562
|
-
|
|
5577
|
+
if (beliefNodeId) {
|
|
5578
|
+
validateSignedImpactScore(relationWeight2, ctx, [
|
|
5579
|
+
"beliefRelations",
|
|
5580
|
+
index,
|
|
5581
|
+
"weight"
|
|
5582
|
+
]);
|
|
5583
|
+
validateRelationImpactConsistency(
|
|
5584
|
+
relation.evidenceRelation ?? relation.relation,
|
|
5585
|
+
relationWeight2,
|
|
5586
|
+
ctx,
|
|
5587
|
+
["beliefRelations", index, "weight"]
|
|
5588
|
+
);
|
|
5563
5589
|
}
|
|
5564
5590
|
});
|
|
5565
5591
|
}
|
|
@@ -5613,18 +5639,28 @@ function targetKind(targetId) {
|
|
|
5613
5639
|
}
|
|
5614
5640
|
return "unknown";
|
|
5615
5641
|
}
|
|
5616
|
-
function
|
|
5642
|
+
function normalizeRelationAlias(value) {
|
|
5617
5643
|
if (value === "supports" || value === "supporting") {
|
|
5618
5644
|
return "supports";
|
|
5619
5645
|
}
|
|
5620
5646
|
if (value === "contradicts" || value === "contradicting") {
|
|
5621
5647
|
return "contradicts";
|
|
5622
5648
|
}
|
|
5649
|
+
return void 0;
|
|
5650
|
+
}
|
|
5651
|
+
function normalizeRelation(value, weight) {
|
|
5652
|
+
const alias = normalizeRelationAlias(value);
|
|
5653
|
+
if (alias) {
|
|
5654
|
+
return alias;
|
|
5655
|
+
}
|
|
5623
5656
|
if (weight === void 0 || !hasNonzeroWeight(weight)) {
|
|
5624
5657
|
return void 0;
|
|
5625
5658
|
}
|
|
5626
5659
|
return weight < 0 ? "contradicts" : "supports";
|
|
5627
5660
|
}
|
|
5661
|
+
function hasNonzeroWeight(value) {
|
|
5662
|
+
return typeof value === "number" && Number.isFinite(value) && value !== 0;
|
|
5663
|
+
}
|
|
5628
5664
|
function normalizeConfidence(confidence, weight) {
|
|
5629
5665
|
if (confidence !== void 0) {
|
|
5630
5666
|
return Math.min(1, Math.max(0, confidence));
|
|
@@ -5651,6 +5687,7 @@ function normalizeBeliefRelation(relation) {
|
|
|
5651
5687
|
beliefNodeId,
|
|
5652
5688
|
relation: evidenceRelation,
|
|
5653
5689
|
confidence: normalizeConfidence(relation.confidence, weight),
|
|
5690
|
+
weight,
|
|
5654
5691
|
rationale: relation.rationale
|
|
5655
5692
|
});
|
|
5656
5693
|
}
|
|
@@ -5699,6 +5736,7 @@ var createEvidenceProjection = defineProjection({
|
|
|
5699
5736
|
linkedBeliefNodeId,
|
|
5700
5737
|
evidenceRelation,
|
|
5701
5738
|
confidence,
|
|
5739
|
+
weight,
|
|
5702
5740
|
beliefRelations: beliefRelations && beliefRelations.length > 0 ? beliefRelations : void 0,
|
|
5703
5741
|
rationale: input.rationale,
|
|
5704
5742
|
trustedBypassAccessCheck: input.trustedBypassAccessCheck ?? true
|
|
@@ -5728,12 +5766,14 @@ var createEvidenceProjection = defineProjection({
|
|
|
5728
5766
|
v.literal("contradicts")
|
|
5729
5767
|
)
|
|
5730
5768
|
),
|
|
5769
|
+
weight: v.optional(v.number()),
|
|
5731
5770
|
beliefRelations: v.optional(
|
|
5732
5771
|
v.array(
|
|
5733
5772
|
v.object({
|
|
5734
5773
|
beliefNodeId: v.string(),
|
|
5735
5774
|
relation: v.union(v.literal("supports"), v.literal("contradicts")),
|
|
5736
5775
|
confidence: v.optional(v.number()),
|
|
5776
|
+
weight: v.number(),
|
|
5737
5777
|
rationale: v.optional(v.string())
|
|
5738
5778
|
})
|
|
5739
5779
|
)
|
|
@@ -5751,8 +5791,12 @@ var beliefRelationSchema2 = z.object({
|
|
|
5751
5791
|
targetId: z.string().optional().describe("Belief target ID alias for beliefId/beliefNodeId."),
|
|
5752
5792
|
relation: z.enum(["supports", "contradicts", "supporting", "contradicting"]).optional().describe("Relation alias for how the evidence bears on the belief."),
|
|
5753
5793
|
evidenceRelation: evidenceRelationSchema2.optional().describe("Canonical relation: supports or contradicts."),
|
|
5754
|
-
confidence: z.number().optional().describe(
|
|
5755
|
-
|
|
5794
|
+
confidence: z.number().optional().describe(
|
|
5795
|
+
"Deprecated read-only hint. Runtime SL confidence is derived from signed weight."
|
|
5796
|
+
),
|
|
5797
|
+
weight: z.number().min(-1).max(1).refine((value) => value !== 0, {
|
|
5798
|
+
message: "Evidence impact weight must be nonzero."
|
|
5799
|
+
}).describe("Required signed impact score from -1.0 to +1.0 for this belief."),
|
|
5756
5800
|
rationale: z.string().optional().describe("Why this relation exists.")
|
|
5757
5801
|
});
|
|
5758
5802
|
var createEvidenceArgs = z.object({
|
|
@@ -5761,7 +5805,7 @@ var createEvidenceArgs = z.object({
|
|
|
5761
5805
|
source: z.string().optional().describe("Source URL or source label."),
|
|
5762
5806
|
sourceUrl: z.string().optional().describe("Canonical source URL."),
|
|
5763
5807
|
targetId: z.string().optional().describe(
|
|
5764
|
-
"Belief
|
|
5808
|
+
"Belief identifier to link immediately. Evidence creation cannot target only a question or worktree."
|
|
5765
5809
|
),
|
|
5766
5810
|
linkedBeliefNodeId: z.string().optional().describe("Belief node this evidence bears on."),
|
|
5767
5811
|
evidenceRelation: evidenceRelationSchema2.optional().describe(
|
|
@@ -5770,8 +5814,14 @@ var createEvidenceArgs = z.object({
|
|
|
5770
5814
|
beliefRelations: z.array(beliefRelationSchema2).optional().describe(
|
|
5771
5815
|
"Additional belief relations for one evidence record. Use when the same evidence supports or contradicts multiple beliefs."
|
|
5772
5816
|
),
|
|
5773
|
-
confidence: z.number().optional().describe(
|
|
5774
|
-
|
|
5817
|
+
confidence: z.number().optional().describe(
|
|
5818
|
+
"Deprecated hint. Runtime confidence is derived from signed weight."
|
|
5819
|
+
),
|
|
5820
|
+
weight: z.number().min(-1).max(1).refine((value) => value !== 0, {
|
|
5821
|
+
message: "Evidence impact weight must be nonzero."
|
|
5822
|
+
}).describe(
|
|
5823
|
+
"Required signed impact score from -1.0 to +1.0 for targetId/linkedBeliefNodeId."
|
|
5824
|
+
),
|
|
5775
5825
|
metadata: jsonRecordSchema2.optional().describe("Metadata merged into the canonical evidence node."),
|
|
5776
5826
|
rationale: z.string().describe("Why this evidence should enter the reasoning graph."),
|
|
5777
5827
|
reasoning: z.string().optional().describe("Reasoning note preserved in evidence metadata."),
|
|
@@ -5793,7 +5843,9 @@ var addEvidenceArgs = z.object({
|
|
|
5793
5843
|
topicId: z.string().optional().describe("Topic scope hint."),
|
|
5794
5844
|
sourceUrl: z.string().optional().describe("URL of the source material."),
|
|
5795
5845
|
targetNodeId: z.string().describe("The belief this evidence bears on."),
|
|
5796
|
-
weight: z.number().
|
|
5846
|
+
weight: z.number().min(-1).max(1).refine((value) => value !== 0, {
|
|
5847
|
+
message: "Evidence impact weight must be nonzero."
|
|
5848
|
+
}).describe("Required signed impact score from -1.0 to +1.0."),
|
|
5797
5849
|
reasoning: z.string().describe("Why this evidence is relevant to the target belief."),
|
|
5798
5850
|
title: z.string().optional().describe("Optional short title."),
|
|
5799
5851
|
content: z.string().optional().describe("Optional long-form evidence content."),
|
|
@@ -5813,19 +5865,21 @@ var createEvidenceInput = (input, context) => {
|
|
|
5813
5865
|
);
|
|
5814
5866
|
};
|
|
5815
5867
|
function relationWeight(input) {
|
|
5816
|
-
if (typeof input.weight === "number" && Number.isFinite(input.weight) && input.weight !== 0) {
|
|
5868
|
+
if (typeof input.weight === "number" && Number.isFinite(input.weight) && input.weight !== 0 && input.weight >= -1 && input.weight <= 1) {
|
|
5869
|
+
const relation = String(
|
|
5870
|
+
input.evidenceRelation ?? input.relation ?? input.type ?? ""
|
|
5871
|
+
);
|
|
5872
|
+
if ((relation === "supports" || relation === "supporting") && input.weight < 0) {
|
|
5873
|
+
throw new Error("Supporting evidence links require positive weight.");
|
|
5874
|
+
}
|
|
5875
|
+
if ((relation === "contradicts" || relation === "contradicting") && input.weight > 0) {
|
|
5876
|
+
throw new Error("Contradicting evidence links require negative weight.");
|
|
5877
|
+
}
|
|
5817
5878
|
return input.weight;
|
|
5818
5879
|
}
|
|
5819
|
-
|
|
5820
|
-
|
|
5880
|
+
throw new Error(
|
|
5881
|
+
"Belief evidence links require explicit nonzero weight in [-1, 1]."
|
|
5821
5882
|
);
|
|
5822
|
-
if (relation !== "supports" && relation !== "supporting" && relation !== "contradicts" && relation !== "contradicting") {
|
|
5823
|
-
throw new Error(
|
|
5824
|
-
"Belief evidence links require evidenceRelation='supports'|'contradicts' or a nonzero signed weight."
|
|
5825
|
-
);
|
|
5826
|
-
}
|
|
5827
|
-
const confidence = typeof input.confidence === "number" ? Math.max(0, Math.min(1, input.confidence)) : 0.7;
|
|
5828
|
-
return relation === "contradicts" || relation === "contradicting" ? -confidence : confidence;
|
|
5829
5883
|
}
|
|
5830
5884
|
var linkEvidenceToBeliefInput = (input, context) => {
|
|
5831
5885
|
const weight = relationWeight(input);
|
|
@@ -5834,6 +5888,7 @@ var linkEvidenceToBeliefInput = (input, context) => {
|
|
|
5834
5888
|
beliefNodeId: input.beliefNodeId ?? input.beliefId ?? input.targetId,
|
|
5835
5889
|
insightId: input.insightId ?? input.evidenceNodeId ?? input.evidenceId,
|
|
5836
5890
|
type: weight < 0 ? "contradicting" : "supporting",
|
|
5891
|
+
weight,
|
|
5837
5892
|
confidence: Math.min(1, Math.abs(weight)),
|
|
5838
5893
|
rationale: input.rationale ?? input.context,
|
|
5839
5894
|
trustedBypassAccessCheck: input.trustedBypassAccessCheck ?? true
|
|
@@ -5910,7 +5965,12 @@ var evidenceContracts = [
|
|
|
5910
5965
|
functionName: "create",
|
|
5911
5966
|
kind: "mutation",
|
|
5912
5967
|
inputProjection: (input, context) => {
|
|
5913
|
-
|
|
5968
|
+
if (typeof input.weight !== "number" || !Number.isFinite(input.weight) || input.weight === 0 || input.weight < -1 || input.weight > 1) {
|
|
5969
|
+
throw new Error(
|
|
5970
|
+
"add_evidence requires explicit nonzero weight in [-1, 1]."
|
|
5971
|
+
);
|
|
5972
|
+
}
|
|
5973
|
+
const weight = input.weight;
|
|
5914
5974
|
return createEvidenceInput(
|
|
5915
5975
|
{
|
|
5916
5976
|
...input,
|
|
@@ -5919,6 +5979,7 @@ var evidenceContracts = [
|
|
|
5919
5979
|
linkedBeliefNodeId: input.linkedBeliefNodeId ?? input.targetNodeId ?? input.targetId,
|
|
5920
5980
|
evidenceRelation: weight < 0 ? "contradicts" : "supports",
|
|
5921
5981
|
confidence: Math.min(1, Math.max(0, Math.abs(weight))),
|
|
5982
|
+
weight,
|
|
5922
5983
|
rationale: input.reasoning,
|
|
5923
5984
|
metadata: {
|
|
5924
5985
|
...recordValue(input.metadata),
|