@x12i/graphenix-trace-format 1.0.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.
Files changed (54) hide show
  1. package/README.md +242 -0
  2. package/dist/index.d.ts +11 -0
  3. package/dist/index.d.ts.map +1 -0
  4. package/dist/index.js +11 -0
  5. package/dist/index.js.map +1 -0
  6. package/dist/internal/trace-v2-utils.d.ts +10 -0
  7. package/dist/internal/trace-v2-utils.d.ts.map +1 -0
  8. package/dist/internal/trace-v2-utils.js +65 -0
  9. package/dist/internal/trace-v2-utils.js.map +1 -0
  10. package/dist/trace/append-execution-event.d.ts +5 -0
  11. package/dist/trace/append-execution-event.d.ts.map +1 -0
  12. package/dist/trace/append-execution-event.js +6 -0
  13. package/dist/trace/append-execution-event.js.map +1 -0
  14. package/dist/trace/append-trace-event.d.ts +5 -0
  15. package/dist/trace/append-trace-event.d.ts.map +1 -0
  16. package/dist/trace/append-trace-event.js +6 -0
  17. package/dist/trace/append-trace-event.js.map +1 -0
  18. package/dist/trace/create-empty-execution-trace.d.ts +10 -0
  19. package/dist/trace/create-empty-execution-trace.d.ts.map +1 -0
  20. package/dist/trace/create-empty-execution-trace.js +133 -0
  21. package/dist/trace/create-empty-execution-trace.js.map +1 -0
  22. package/dist/trace/create-execution-trace.d.ts +5 -0
  23. package/dist/trace/create-execution-trace.d.ts.map +1 -0
  24. package/dist/trace/create-execution-trace.js +53 -0
  25. package/dist/trace/create-execution-trace.js.map +1 -0
  26. package/dist/trace/derive-graph-status.d.ts +4 -0
  27. package/dist/trace/derive-graph-status.d.ts.map +1 -0
  28. package/dist/trace/derive-graph-status.js +59 -0
  29. package/dist/trace/derive-graph-status.js.map +1 -0
  30. package/dist/trace/summarize-execution-trace.d.ts +3 -0
  31. package/dist/trace/summarize-execution-trace.d.ts.map +1 -0
  32. package/dist/trace/summarize-execution-trace.js +60 -0
  33. package/dist/trace/summarize-execution-trace.js.map +1 -0
  34. package/dist/validators/validate-execution-trace-v1.d.ts +4 -0
  35. package/dist/validators/validate-execution-trace-v1.d.ts.map +1 -0
  36. package/dist/validators/validate-execution-trace-v1.js +155 -0
  37. package/dist/validators/validate-execution-trace-v1.js.map +1 -0
  38. package/dist/validators/validate-execution-trace-v2-structural.d.ts +3 -0
  39. package/dist/validators/validate-execution-trace-v2-structural.d.ts.map +1 -0
  40. package/dist/validators/validate-execution-trace-v2-structural.js +215 -0
  41. package/dist/validators/validate-execution-trace-v2-structural.js.map +1 -0
  42. package/dist/validators/validate-execution-trace-v2.d.ts +6 -0
  43. package/dist/validators/validate-execution-trace-v2.d.ts.map +1 -0
  44. package/dist/validators/validate-execution-trace-v2.js +40 -0
  45. package/dist/validators/validate-execution-trace-v2.js.map +1 -0
  46. package/dist/validators/validate-execution-trace.d.ts +7 -0
  47. package/dist/validators/validate-execution-trace.d.ts.map +1 -0
  48. package/dist/validators/validate-execution-trace.js +31 -0
  49. package/dist/validators/validate-execution-trace.js.map +1 -0
  50. package/dist/validators/validate-trace-against-plan.d.ts +4 -0
  51. package/dist/validators/validate-trace-against-plan.d.ts.map +1 -0
  52. package/dist/validators/validate-trace-against-plan.js +200 -0
  53. package/dist/validators/validate-trace-against-plan.js.map +1 -0
  54. package/package.json +51 -0
@@ -0,0 +1,31 @@
1
+ import { EXECUTION_TRACE_FORMAT } from "@x12i/graphenix-executable-contracts";
2
+ import { EXECUTION_TRACE_FORMAT_V2 } from "@x12i/graphenix-executable-contracts";
3
+ import { isRecord } from "@x12i/graphenix-executable-contracts";
4
+ import { validateExecutionTraceV1 } from "./validate-execution-trace-v1.js";
5
+ import { validateExecutionTraceV2 } from "./validate-execution-trace-v2.js";
6
+ export function validateExecutionTrace(trace, planOrNodePlans) {
7
+ if (isRecord(trace) && trace.format === EXECUTION_TRACE_FORMAT_V2) {
8
+ if (planOrNodePlans && isV2Plan(planOrNodePlans)) {
9
+ return validateExecutionTraceV2(trace, planOrNodePlans);
10
+ }
11
+ return validateExecutionTraceV2(trace);
12
+ }
13
+ if (isRecord(trace) && trace.format === EXECUTION_TRACE_FORMAT) {
14
+ const nodePlans = planOrNodePlans && !isV2Plan(planOrNodePlans)
15
+ ? planOrNodePlans
16
+ : undefined;
17
+ return validateExecutionTraceV1(trace, nodePlans);
18
+ }
19
+ return validateExecutionTraceV1(trace);
20
+ }
21
+ function isV2Plan(value) {
22
+ return isRecord(value) && "nodePlans" in value && "finalizerPlans" in value;
23
+ }
24
+ export function assertExecutionTrace(trace, plan) {
25
+ const result = validateExecutionTraceV2(trace, plan);
26
+ if (!result.valid) {
27
+ const summary = result.errors.map((e) => `${e.path}: ${e.message}`).join("; ");
28
+ throw new Error(`Invalid execution trace: ${summary}`);
29
+ }
30
+ }
31
+ //# sourceMappingURL=validate-execution-trace.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"validate-execution-trace.js","sourceRoot":"","sources":["../../src/validators/validate-execution-trace.ts"],"names":[],"mappings":"AAIA,OAAO,EAAE,sBAAsB,EAAE,MAAM,sCAAsC,CAAC;AAC9E,OAAO,EAAE,yBAAyB,EAAE,MAAM,sCAAsC,CAAC;AACjF,OAAO,EAAE,QAAQ,EAAE,MAAM,sCAAsC,CAAC;AAChE,OAAO,EAAE,wBAAwB,EAAE,MAAM,kCAAkC,CAAC;AAC5E,OAAO,EAAE,wBAAwB,EAAE,MAAM,kCAAkC,CAAC;AAE5E,MAAM,UAAU,sBAAsB,CACpC,KAAc,EACd,eAAmF;IAEnF,IAAI,QAAQ,CAAC,KAAK,CAAC,IAAI,KAAK,CAAC,MAAM,KAAK,yBAAyB,EAAE,CAAC;QAClE,IAAI,eAAe,IAAI,QAAQ,CAAC,eAAe,CAAC,EAAE,CAAC;YACjD,OAAO,wBAAwB,CAAC,KAAK,EAAE,eAAe,CAAC,CAAC;QAC1D,CAAC;QACD,OAAO,wBAAwB,CAAC,KAAK,CAAC,CAAC;IACzC,CAAC;IAED,IAAI,QAAQ,CAAC,KAAK,CAAC,IAAI,KAAK,CAAC,MAAM,KAAK,sBAAsB,EAAE,CAAC;QAC/D,MAAM,SAAS,GAAG,eAAe,IAAI,CAAC,QAAQ,CAAC,eAAe,CAAC;YAC7D,CAAC,CAAC,eAAe;YACjB,CAAC,CAAC,SAAS,CAAC;QACd,OAAO,wBAAwB,CAAC,KAAK,EAAE,SAAS,CAAC,CAAC;IACpD,CAAC;IAED,OAAO,wBAAwB,CAAC,KAAK,CAAC,CAAC;AACzC,CAAC;AAED,SAAS,QAAQ,CACf,KAAwE;IAExE,OAAO,QAAQ,CAAC,KAAK,CAAC,IAAI,WAAW,IAAI,KAAK,IAAI,gBAAgB,IAAI,KAAK,CAAC;AAC9E,CAAC;AAED,MAAM,UAAU,oBAAoB,CAClC,KAAc,EACd,IAA2B;IAE3B,MAAM,MAAM,GAAG,wBAAwB,CAAC,KAAK,EAAE,IAAI,CAAC,CAAC;IACrD,IAAI,CAAC,MAAM,CAAC,KAAK,EAAE,CAAC;QAClB,MAAM,OAAO,GAAG,MAAM,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,GAAG,CAAC,CAAC,IAAI,KAAK,CAAC,CAAC,OAAO,EAAE,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAC/E,MAAM,IAAI,KAAK,CAAC,4BAA4B,OAAO,EAAE,CAAC,CAAC;IACzD,CAAC;AACH,CAAC"}
@@ -0,0 +1,4 @@
1
+ import type { ExecutableGraphPlanV2 } from "@x12i/graphenix-executable-contracts";
2
+ import type { TraceValidationResult } from "@x12i/graphenix-executable-contracts";
3
+ export declare function validateTraceAgainstPlan(trace: unknown, plan: ExecutableGraphPlanV2): TraceValidationResult;
4
+ //# sourceMappingURL=validate-trace-against-plan.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"validate-trace-against-plan.d.ts","sourceRoot":"","sources":["../../src/validators/validate-trace-against-plan.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,qBAAqB,EAAE,MAAM,sCAAsC,CAAC;AAClF,OAAO,KAAK,EAAE,qBAAqB,EAAE,MAAM,sCAAsC,CAAC;AA6FlF,wBAAgB,wBAAwB,CACtC,KAAK,EAAE,OAAO,EACd,IAAI,EAAE,qBAAqB,GAC1B,qBAAqB,CA8TvB"}
@@ -0,0 +1,200 @@
1
+ import { execError, isRecord } from "@x12i/graphenix-executable-contracts";
2
+ import { collectDeferredGateIds, isAiBackedUnit, isTerminalNodeStatus, isTerminalUnitStatus } from "../internal/trace-v2-utils.js";
3
+ import { deriveGraphStatus } from "../trace/derive-graph-status.js";
4
+ import { summarizeExecutionTrace } from "../trace/summarize-execution-trace.js";
5
+ const AI_SLOTS = new Set([
6
+ "preActionModel",
7
+ "skillModel",
8
+ "postActionModel",
9
+ "finalizerModel"
10
+ ]);
11
+ function validateFallbackTrace(unitId, fallback, plan, errors) {
12
+ if (fallback.applied !== true)
13
+ return;
14
+ const owner = fallback.owner;
15
+ if (owner !== "executor" && owner !== "invocationLayer") {
16
+ errors.push(execError("EXECUTION_TRACE_V2_FALLBACK_OWNER_MISSING", `Unit ${unitId} fallback must declare owner.`, `/unitExecutions/${unitId}/fallback/owner`));
17
+ }
18
+ const planOwner = plan.policies.fallbackPolicy.owner;
19
+ if (owner !== planOwner) {
20
+ errors.push(execError("EXECUTION_TRACE_V2_FALLBACK_NOT_ALLOWED", `Unit ${unitId} fallback owner does not match plan policy owner.`, `/unitExecutions/${unitId}/fallback/owner`));
21
+ }
22
+ if (fallback.allowedByPolicy === false) {
23
+ errors.push(execError("EXECUTION_TRACE_V2_FALLBACK_NOT_ALLOWED", `Unit ${unitId} fallback was not allowed by plan policy.`, `/unitExecutions/${unitId}/fallback/allowedByPolicy`));
24
+ }
25
+ const from = fallback.from;
26
+ const to = fallback.to;
27
+ if (isRecord(from) && isRecord(to)) {
28
+ const fromSlot = inferSlotFromSelection(from);
29
+ const toSlot = inferSlotFromSelection(to);
30
+ if (fromSlot && toSlot && fromSlot !== toSlot) {
31
+ errors.push(execError("EXECUTION_TRACE_V2_FALLBACK_CROSS_SLOT", `Unit ${unitId} fallback crosses model slots.`, `/unitExecutions/${unitId}/fallback`));
32
+ }
33
+ }
34
+ if (typeof fallback.sourceGraphCaseId === "string") {
35
+ const graphCase = plan.caseSelection.graphModelCase.caseId;
36
+ if (fallback.sourceGraphCaseId !== graphCase) {
37
+ errors.push(execError("EXECUTION_TRACE_V2_FALLBACK_GRAPH_CASE", `Unit ${unitId} fallback must not switch graph case.`, `/unitExecutions/${unitId}/fallback/sourceGraphCaseId`));
38
+ }
39
+ }
40
+ }
41
+ function inferSlotFromSelection(selection) {
42
+ void selection;
43
+ return undefined;
44
+ }
45
+ export function validateTraceAgainstPlan(trace, plan) {
46
+ const errors = [];
47
+ if (!isRecord(trace)) {
48
+ return {
49
+ valid: false,
50
+ errors: [
51
+ execError("EXECUTION_TRACE_V2_INVALID", "Execution trace must be an object.", "")
52
+ ]
53
+ };
54
+ }
55
+ const traceRecord = trace;
56
+ if (isRecord(traceRecord.source) &&
57
+ traceRecord.source.graphHash !== plan.source.graphHash) {
58
+ errors.push(execError("EXECUTION_TRACE_V2_SOURCE_MISMATCH", "trace.source.graphHash must match plan source graph hash.", "/source/graphHash"));
59
+ }
60
+ if (isRecord(traceRecord.plan) &&
61
+ traceRecord.plan.planId !== plan.planId) {
62
+ errors.push(execError("EXECUTION_TRACE_V2_PLAN_MISMATCH", "trace.plan.planId must match executable plan.", "/plan/planId"));
63
+ }
64
+ if (isRecord(traceRecord.runtime) &&
65
+ traceRecord.runtime.jobId !== plan.runtimeBinding.jobId) {
66
+ errors.push(execError("EXECUTION_TRACE_V2_RUNTIME_MISMATCH", "trace.runtime.jobId must match plan runtime binding.", "/runtime/jobId"));
67
+ }
68
+ const isExecutionComplete = ["completed", "failed", "partial", "cancelled"].includes(String(traceRecord.status ?? ""));
69
+ for (const nodeRef of plan.topology.nodes) {
70
+ const nodeId = nodeRef.nodeId;
71
+ const nodeTrace = isRecord(traceRecord.nodeExecutions)
72
+ ? traceRecord.nodeExecutions[nodeId]
73
+ : undefined;
74
+ if (!isRecord(nodeTrace)) {
75
+ if (isExecutionComplete) {
76
+ errors.push(execError("EXECUTION_TRACE_V2_NODE_OUTCOME_MISSING", `Plan node ${nodeId} has no node execution trace.`, `/nodeExecutions/${nodeId}`));
77
+ }
78
+ continue;
79
+ }
80
+ if (isExecutionComplete &&
81
+ !isTerminalNodeStatus(String(nodeTrace.status ?? ""))) {
82
+ errors.push(execError("EXECUTION_TRACE_V2_NODE_OUTCOME_MISSING", `Plan node ${nodeId} must have terminal status after execution.`, `/nodeExecutions/${nodeId}/status`));
83
+ }
84
+ }
85
+ const allUnits = [
86
+ ...Object.values(plan.nodePlans).flatMap((n) => n.executionUnits),
87
+ ...Object.values(plan.finalizerPlans).flatMap((f) => f.executionUnits)
88
+ ];
89
+ const unitExecutions = isRecord(traceRecord.unitExecutions)
90
+ ? traceRecord.unitExecutions
91
+ : {};
92
+ const modelInvocations = isRecord(traceRecord.modelInvocations)
93
+ ? traceRecord.modelInvocations
94
+ : {};
95
+ for (const plannedUnit of allUnits) {
96
+ const unitTrace = unitExecutions[plannedUnit.unitId];
97
+ if (!isRecord(unitTrace)) {
98
+ if (isExecutionComplete) {
99
+ errors.push(execError("EXECUTION_TRACE_V2_UNIT_OUTCOME_MISSING", `Plan unit ${plannedUnit.unitId} has no unit execution trace.`, `/unitExecutions/${plannedUnit.unitId}`));
100
+ }
101
+ continue;
102
+ }
103
+ if (isExecutionComplete &&
104
+ !isTerminalUnitStatus(String(unitTrace.status ?? ""))) {
105
+ errors.push(execError("EXECUTION_TRACE_V2_UNIT_OUTCOME_MISSING", `Plan unit ${plannedUnit.unitId} must have terminal status after execution.`, `/unitExecutions/${plannedUnit.unitId}/status`));
106
+ }
107
+ const nodePlan = plan.nodePlans[plannedUnit.nodeId];
108
+ const executionClass = nodePlan?.executionClass ?? "aiTask";
109
+ if (executionClass === "localTask") {
110
+ const invocationIds = unitTrace.modelInvocationIds;
111
+ if (Array.isArray(invocationIds) && invocationIds.length > 0) {
112
+ errors.push(execError("EXECUTION_TRACE_V2_LOCAL_TASK_REQUIRES_NO_MODEL", `Local task unit ${plannedUnit.unitId} must not have model invocations.`, `/unitExecutions/${plannedUnit.unitId}/modelInvocationIds`));
113
+ }
114
+ }
115
+ else if (isAiBackedUnit(String(plannedUnit.unitKind), executionClass) &&
116
+ Array.isArray(unitTrace.modelInvocationIds)) {
117
+ for (const invocationId of unitTrace.modelInvocationIds) {
118
+ if (!modelInvocations[String(invocationId)]) {
119
+ errors.push(execError("EXECUTION_TRACE_V2_UNKNOWN_INVOCATION", `Unit ${plannedUnit.unitId} references unknown invocation ${invocationId}.`, `/unitExecutions/${plannedUnit.unitId}/modelInvocationIds`));
120
+ }
121
+ }
122
+ }
123
+ if (isRecord(unitTrace.fallback)) {
124
+ validateFallbackTrace(plannedUnit.unitId, unitTrace.fallback, plan, errors);
125
+ }
126
+ if (isRecord(unitTrace.retry) && isRecord(unitTrace.fallback)) {
127
+ const retry = unitTrace.retry;
128
+ const fallback = unitTrace.fallback;
129
+ if (retry.attempted === true && fallback.applied === true) {
130
+ const retryInvocations = Array.isArray(retry.invocationIds)
131
+ ? retry.invocationIds
132
+ : [];
133
+ const fallbackInvocations = Array.isArray(fallback.invocationIds)
134
+ ? fallback.invocationIds
135
+ : [];
136
+ if (retryInvocations.some((id) => fallbackInvocations.includes(String(id)))) {
137
+ errors.push(execError("EXECUTION_TRACE_V2_FALLBACK_NOT_ALLOWED", `Unit ${plannedUnit.unitId} must not represent retry and fallback on same invocation.`, `/unitExecutions/${plannedUnit.unitId}/retry`));
138
+ }
139
+ }
140
+ }
141
+ }
142
+ const gateEvaluations = isRecord(traceRecord.gateEvaluations)
143
+ ? traceRecord.gateEvaluations
144
+ : {};
145
+ for (const gateId of collectDeferredGateIds(plan)) {
146
+ const gateTrace = gateEvaluations[gateId];
147
+ if (!isRecord(gateTrace) && isExecutionComplete) {
148
+ errors.push(execError("EXECUTION_TRACE_V2_GATE_EVALUATION_MISSING", `Deferred gate ${gateId} has no evaluation trace.`, `/gateEvaluations/${gateId}`));
149
+ }
150
+ }
151
+ for (const [invocationId, invocation] of Object.entries(modelInvocations)) {
152
+ if (!isRecord(invocation))
153
+ continue;
154
+ const unitId = invocation.unitId;
155
+ if (typeof unitId === "string" && !unitExecutions[unitId]) {
156
+ errors.push(execError("EXECUTION_TRACE_V2_UNKNOWN_INVOCATION", `Model invocation ${invocationId} references unknown unit ${unitId}.`, `/modelInvocations/${invocationId}/unitId`));
157
+ }
158
+ const resolved = invocation.resolvedInvocation;
159
+ if (isRecord(resolved) && isRecord(invocation.plannedSelection)) {
160
+ const planned = invocation.plannedSelection;
161
+ if (planned.kind === "profileChoice" &&
162
+ typeof resolved.profileChoiceKey !== "string") {
163
+ errors.push(execError("EXECUTION_TRACE_V2_INVALID", `Invocation ${invocationId} must record profileChoiceKey.`, `/modelInvocations/${invocationId}/resolvedInvocation/profileChoiceKey`));
164
+ }
165
+ if (planned.kind === "model" &&
166
+ plan.policies.directModelPolicy === "forbidden" &&
167
+ resolved.resolutionSource !== "directModel" &&
168
+ !invocation.directModelPolicyResult) {
169
+ errors.push(execError("EXECUTION_TRACE_V2_DATA_POLICY_VIOLATION", `Direct model invocation ${invocationId} must record policy result.`, `/modelInvocations/${invocationId}/directModelPolicyResult`));
170
+ }
171
+ }
172
+ const slot = invocation.slot;
173
+ if (typeof slot === "string" && !AI_SLOTS.has(slot)) {
174
+ errors.push(execError("EXECUTION_TRACE_V2_INVALID", `Invocation ${invocationId} has invalid slot.`, `/modelInvocations/${invocationId}/slot`));
175
+ }
176
+ }
177
+ if (traceRecord.status === "completed" && !traceRecord.finalOutput) {
178
+ const hasFinalizer = plan.topology.finalizerNodeIds.length > 0;
179
+ if (hasFinalizer) {
180
+ errors.push(execError("EXECUTION_TRACE_V2_FINAL_OUTPUT_MISSING", "Completed trace must record finalOutput when plan declares response contract.", "/finalOutput"));
181
+ }
182
+ }
183
+ if (isRecord(traceRecord.totals)) {
184
+ const derived = summarizeExecutionTrace(traceRecord);
185
+ const totals = traceRecord.totals;
186
+ if (typeof totals.inputTokens === "number" &&
187
+ typeof derived.inputTokens === "number" &&
188
+ totals.inputTokens !== derived.inputTokens) {
189
+ errors.push(execError("EXECUTION_TRACE_V2_TOTALS_MISMATCH", "totals.inputTokens does not match derived usage.", "/totals/inputTokens"));
190
+ }
191
+ }
192
+ const derivedStatus = deriveGraphStatus(traceRecord);
193
+ if (isExecutionComplete &&
194
+ traceRecord.status !== derivedStatus &&
195
+ traceRecord.status !== "cancelled") {
196
+ errors.push(execError("EXECUTION_TRACE_V2_STATUS_MISMATCH", `trace.status ${traceRecord.status} is inconsistent with derived status ${derivedStatus}.`, "/status"));
197
+ }
198
+ return { valid: errors.length === 0, errors };
199
+ }
200
+ //# sourceMappingURL=validate-trace-against-plan.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"validate-trace-against-plan.js","sourceRoot":"","sources":["../../src/validators/validate-trace-against-plan.ts"],"names":[],"mappings":"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"}
package/package.json ADDED
@@ -0,0 +1,51 @@
1
+ {
2
+ "name": "@x12i/graphenix-trace-format",
3
+ "version": "1.0.0",
4
+ "description": "GraphExecutionTrace format: append-only events, validation, and trace helpers.",
5
+ "license": "MIT",
6
+ "type": "module",
7
+ "main": "dist/index.js",
8
+ "types": "dist/index.d.ts",
9
+ "exports": {
10
+ ".": {
11
+ "types": "./dist/index.d.ts",
12
+ "import": "./dist/index.js",
13
+ "default": "./dist/index.js"
14
+ }
15
+ },
16
+ "scripts": {
17
+ "build": "tsc -p tsconfig.json",
18
+ "clean": "rimraf dist"
19
+ },
20
+ "files": [
21
+ "dist",
22
+ "README.md"
23
+ ],
24
+ "keywords": [
25
+ "graph",
26
+ "graphenix",
27
+ "trace",
28
+ "execution"
29
+ ],
30
+ "repository": {
31
+ "type": "git",
32
+ "url": "git+https://github.com/x12i/graphenix-format.git",
33
+ "directory": "packages/trace-format"
34
+ },
35
+ "bugs": {
36
+ "url": "https://github.com/x12i/graphenix-format/issues"
37
+ },
38
+ "homepage": "https://github.com/x12i/graphenix-format/tree/master/packages/trace-format#readme",
39
+ "publishConfig": {
40
+ "access": "public",
41
+ "registry": "https://registry.npmjs.org/"
42
+ },
43
+ "dependencies": {
44
+ "@x12i/graphenix-executable-contracts": "^1.0.0"
45
+ },
46
+ "devDependencies": {
47
+ "@types/node": "^22.10.1",
48
+ "rimraf": "^6.0.1",
49
+ "typescript": "^5.6.3"
50
+ }
51
+ }