@tracemarketplace/shared 0.0.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (63) hide show
  1. package/dist/extractors/claude-code.d.ts +3 -0
  2. package/dist/extractors/claude-code.d.ts.map +1 -0
  3. package/dist/extractors/claude-code.js +158 -0
  4. package/dist/extractors/claude-code.js.map +1 -0
  5. package/dist/extractors/codex.d.ts +3 -0
  6. package/dist/extractors/codex.d.ts.map +1 -0
  7. package/dist/extractors/codex.js +192 -0
  8. package/dist/extractors/codex.js.map +1 -0
  9. package/dist/extractors/cursor.d.ts +3 -0
  10. package/dist/extractors/cursor.d.ts.map +1 -0
  11. package/dist/extractors/cursor.js +99 -0
  12. package/dist/extractors/cursor.js.map +1 -0
  13. package/dist/hash.d.ts +4 -0
  14. package/dist/hash.d.ts.map +1 -0
  15. package/dist/hash.js +13 -0
  16. package/dist/hash.js.map +1 -0
  17. package/dist/hash.test.d.ts +2 -0
  18. package/dist/hash.test.d.ts.map +1 -0
  19. package/dist/hash.test.js +67 -0
  20. package/dist/hash.test.js.map +1 -0
  21. package/dist/index.d.ts +9 -0
  22. package/dist/index.d.ts.map +1 -0
  23. package/dist/index.js +9 -0
  24. package/dist/index.js.map +1 -0
  25. package/dist/scoring.d.ts +5 -0
  26. package/dist/scoring.d.ts.map +1 -0
  27. package/dist/scoring.js +114 -0
  28. package/dist/scoring.js.map +1 -0
  29. package/dist/scoring.test.d.ts +2 -0
  30. package/dist/scoring.test.d.ts.map +1 -0
  31. package/dist/scoring.test.js +157 -0
  32. package/dist/scoring.test.js.map +1 -0
  33. package/dist/types.d.ts +98 -0
  34. package/dist/types.d.ts.map +1 -0
  35. package/dist/types.js +2 -0
  36. package/dist/types.js.map +1 -0
  37. package/dist/utils.d.ts +3 -0
  38. package/dist/utils.d.ts.map +1 -0
  39. package/dist/utils.js +11 -0
  40. package/dist/utils.js.map +1 -0
  41. package/dist/validators.d.ts +247 -0
  42. package/dist/validators.d.ts.map +1 -0
  43. package/dist/validators.js +36 -0
  44. package/dist/validators.js.map +1 -0
  45. package/dist/validators.test.d.ts +2 -0
  46. package/dist/validators.test.d.ts.map +1 -0
  47. package/dist/validators.test.js +52 -0
  48. package/dist/validators.test.js.map +1 -0
  49. package/package.json +42 -0
  50. package/src/extractors/claude-code.ts +178 -0
  51. package/src/extractors/codex.ts +208 -0
  52. package/src/extractors/cursor.ts +118 -0
  53. package/src/hash.test.ts +72 -0
  54. package/src/hash.ts +15 -0
  55. package/src/index.ts +8 -0
  56. package/src/scoring.test.ts +173 -0
  57. package/src/scoring.ts +149 -0
  58. package/src/types.ts +96 -0
  59. package/src/utils.ts +9 -0
  60. package/src/validators.test.ts +61 -0
  61. package/src/validators.ts +41 -0
  62. package/tsconfig.json +8 -0
  63. package/vitest.config.ts +8 -0
@@ -0,0 +1,3 @@
1
+ import type { NormalizedTrace } from "../types.js";
2
+ export declare function extractClaudeCode(sessionFilePath: string, submittedBy?: string): Promise<NormalizedTrace>;
3
+ //# sourceMappingURL=claude-code.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"claude-code.d.ts","sourceRoot":"","sources":["../../src/extractors/claude-code.ts"],"names":[],"mappings":"AAIA,OAAO,KAAK,EACV,eAAe,EAIhB,MAAM,aAAa,CAAC;AAErB,wBAAsB,iBAAiB,CACrC,eAAe,EAAE,MAAM,EACvB,WAAW,SAAY,GACtB,OAAO,CAAC,eAAe,CAAC,CAmK1B"}
@@ -0,0 +1,158 @@
1
+ import { createReadStream } from "fs";
2
+ import { createInterface } from "readline";
3
+ import { randomUUID } from "crypto";
4
+ import { hashString, computeContentHash } from "../hash.js";
5
+ export async function extractClaudeCode(sessionFilePath, submittedBy = "unknown") {
6
+ const lines = [];
7
+ const rl = createInterface({
8
+ input: createReadStream(sessionFilePath),
9
+ crlfDelay: Infinity,
10
+ });
11
+ for await (const line of rl) {
12
+ if (!line.trim())
13
+ continue;
14
+ try {
15
+ lines.push(JSON.parse(line));
16
+ }
17
+ catch { }
18
+ }
19
+ const sessionId = sessionFilePath.split("/").pop()?.replace(".jsonl", "") ?? randomUUID();
20
+ const turns = [];
21
+ let totalInputTokens = 0;
22
+ let totalOutputTokens = 0;
23
+ let totalCacheReadTokens = 0;
24
+ let gitBranch = null;
25
+ let cwdHash = null;
26
+ for (const line of lines) {
27
+ if (!line.message)
28
+ continue;
29
+ const { role, content, usage, model } = line.message;
30
+ const tokenUsage = usage
31
+ ? {
32
+ input_tokens: usage.input_tokens ?? 0,
33
+ output_tokens: usage.output_tokens ?? 0,
34
+ cache_read_input_tokens: usage.cache_read_input_tokens ?? null,
35
+ cache_creation_input_tokens: usage.cache_creation_input_tokens ?? null,
36
+ reasoning_tokens: null,
37
+ }
38
+ : null;
39
+ if (tokenUsage) {
40
+ totalInputTokens += tokenUsage.input_tokens;
41
+ totalOutputTokens += tokenUsage.output_tokens;
42
+ totalCacheReadTokens += tokenUsage.cache_read_input_tokens ?? 0;
43
+ }
44
+ if (line.gitBranch)
45
+ gitBranch = line.gitBranch;
46
+ if (line.cwd && !cwdHash)
47
+ cwdHash = hashString(line.cwd);
48
+ const contentBlocks = [];
49
+ const rawContent = Array.isArray(content)
50
+ ? content
51
+ : typeof content === "string"
52
+ ? [{ type: "text", text: content }]
53
+ : [];
54
+ for (const block of rawContent) {
55
+ if (!block || !block.type)
56
+ continue;
57
+ if (block.type === "file-history-snapshot")
58
+ continue;
59
+ if (block.type === "text") {
60
+ contentBlocks.push({ type: "text", text: block.text ?? "" });
61
+ }
62
+ else if (block.type === "thinking") {
63
+ contentBlocks.push({
64
+ type: "thinking",
65
+ text: block.thinking ?? block.text ?? "",
66
+ });
67
+ }
68
+ else if (block.type === "tool_use") {
69
+ contentBlocks.push({
70
+ type: "tool_use",
71
+ tool_call_id: block.id ?? randomUUID(),
72
+ tool_name: block.name ?? "",
73
+ tool_input: block.input ?? {},
74
+ });
75
+ }
76
+ else if (block.type === "tool_result") {
77
+ const resultContent = Array.isArray(block.content)
78
+ ? block.content.map((c) => c.text ?? "").join("\n")
79
+ : block.content ?? null;
80
+ contentBlocks.push({
81
+ type: "tool_result",
82
+ tool_call_id: block.tool_use_id ?? "",
83
+ is_error: block.is_error ?? false,
84
+ result_content: resultContent,
85
+ exit_code: null,
86
+ });
87
+ }
88
+ }
89
+ if (contentBlocks.length === 0)
90
+ continue;
91
+ turns.push({
92
+ turn_id: line.uuid ?? randomUUID(),
93
+ parent_turn_id: line.parentUuid ?? null,
94
+ role: role === "assistant" ? "assistant" : "user",
95
+ timestamp: line.timestamp ?? null,
96
+ content: contentBlocks,
97
+ model: model ?? null,
98
+ usage: tokenUsage,
99
+ source_metadata: {
100
+ uuid: line.uuid,
101
+ parentUuid: line.parentUuid,
102
+ gitBranch: line.gitBranch,
103
+ },
104
+ });
105
+ }
106
+ const startedAt = turns[0]?.timestamp ?? new Date().toISOString();
107
+ const endedAt = turns[turns.length - 1]?.timestamp ?? new Date().toISOString();
108
+ const allBlocks = turns.flatMap((t) => t.content);
109
+ const toolCallCount = allBlocks.filter((b) => b.type === "tool_use").length;
110
+ const hasFileChanges = allBlocks.some((b) => b.type === "tool_use" &&
111
+ (b.tool_name?.toLowerCase().includes("write") ||
112
+ b.tool_name?.toLowerCase().includes("edit")));
113
+ const hasShellCommands = allBlocks.some((b) => b.type === "tool_use" &&
114
+ (b.tool_name?.toLowerCase().includes("bash") ||
115
+ b.tool_name?.toLowerCase().includes("exec")));
116
+ const hasThinking = allBlocks.some((b) => b.type === "thinking");
117
+ const partialTrace = {
118
+ schema_version: "1.0",
119
+ source_tool: "claude_code",
120
+ source_session_id: sessionId,
121
+ source_version: null,
122
+ submitted_by: submittedBy,
123
+ submitted_at: new Date().toISOString(),
124
+ extracted_at: new Date().toISOString(),
125
+ git_branch: gitBranch,
126
+ cwd_hash: cwdHash,
127
+ working_language: null,
128
+ started_at: startedAt,
129
+ ended_at: endedAt,
130
+ turns,
131
+ turn_count: turns.length,
132
+ tool_call_count: toolCallCount,
133
+ has_tool_calls: toolCallCount > 0,
134
+ has_thinking_blocks: hasThinking,
135
+ has_file_changes: hasFileChanges,
136
+ has_shell_commands: hasShellCommands,
137
+ total_input_tokens: totalInputTokens || null,
138
+ total_output_tokens: totalOutputTokens || null,
139
+ total_cache_read_tokens: totalCacheReadTokens || null,
140
+ content_fidelity: "full",
141
+ env_state: {
142
+ git_branch: gitBranch,
143
+ inferred_file_tree: null,
144
+ inferred_changed_files: null,
145
+ inferred_error_files: null,
146
+ shell_exit_codes: null,
147
+ open_files_in_editor: null,
148
+ extraction_method: "passive",
149
+ },
150
+ score: null,
151
+ raw_r2_key: "",
152
+ normalized_r2_key: "",
153
+ };
154
+ const contentHash = computeContentHash(partialTrace);
155
+ const traceId = hashString("claude_code" + sessionId + contentHash);
156
+ return { ...partialTrace, trace_id: traceId };
157
+ }
158
+ //# sourceMappingURL=claude-code.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"claude-code.js","sourceRoot":"","sources":["../../src/extractors/claude-code.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,3 @@
1
+ import type { NormalizedTrace } from "../types.js";
2
+ export declare function extractCodex(rolloutFileBuffer: Buffer, submittedBy?: string): Promise<NormalizedTrace>;
3
+ //# sourceMappingURL=codex.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"codex.d.ts","sourceRoot":"","sources":["../../src/extractors/codex.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EACV,eAAe,EAGhB,MAAM,aAAa,CAAC;AAErB,wBAAsB,YAAY,CAChC,iBAAiB,EAAE,MAAM,EACzB,WAAW,SAAY,GACtB,OAAO,CAAC,eAAe,CAAC,CAoM1B"}
@@ -0,0 +1,192 @@
1
+ import { randomUUID } from "crypto";
2
+ import { hashString, computeContentHash } from "../hash.js";
3
+ export async function extractCodex(rolloutFileBuffer, submittedBy = "unknown") {
4
+ const events = [];
5
+ for (const line of rolloutFileBuffer.toString("utf-8").split("\n")) {
6
+ if (!line.trim())
7
+ continue;
8
+ try {
9
+ events.push(JSON.parse(line));
10
+ }
11
+ catch { }
12
+ }
13
+ const sessionMetaPayload = (events.find(e => e["type"] === "session_meta")?.["payload"] ?? {});
14
+ const sessionId = sessionMetaPayload["id"] ?? randomUUID();
15
+ const cwd = sessionMetaPayload["cwd"] ?? null;
16
+ const cliVersion = sessionMetaPayload["cli_version"] ?? null;
17
+ const turns = [];
18
+ let inTask = false;
19
+ let currentTurnId = null;
20
+ let currentUserMessage = null;
21
+ let currentBlocks = [];
22
+ let taskTimestamp = null;
23
+ let currentModel = null;
24
+ for (const event of events) {
25
+ const type = event["type"];
26
+ const payload = (event["payload"] ?? {});
27
+ const timestamp = event["timestamp"] ?? null;
28
+ if (type === "event_msg" && payload["type"] === "task_started") {
29
+ inTask = true;
30
+ currentTurnId = payload["turn_id"] ?? randomUUID();
31
+ currentUserMessage = null;
32
+ currentBlocks = [];
33
+ taskTimestamp = timestamp;
34
+ continue;
35
+ }
36
+ if (type === "event_msg" && payload["type"] === "task_complete") {
37
+ if (inTask) {
38
+ if (currentUserMessage) {
39
+ turns.push({
40
+ turn_id: "user_" + currentTurnId,
41
+ parent_turn_id: null,
42
+ role: "user",
43
+ timestamp: taskTimestamp,
44
+ content: [{ type: "text", text: currentUserMessage }],
45
+ model: null,
46
+ usage: null,
47
+ source_metadata: { turn_id: currentTurnId },
48
+ });
49
+ }
50
+ const lastMsg = payload["last_agent_message"];
51
+ if (lastMsg) {
52
+ const alreadyCaptured = currentBlocks.some(b => b.type === "text" && b.text === lastMsg);
53
+ if (!alreadyCaptured)
54
+ currentBlocks.push({ type: "text", text: lastMsg });
55
+ }
56
+ if (currentBlocks.length > 0) {
57
+ turns.push({
58
+ turn_id: currentTurnId ?? randomUUID(),
59
+ parent_turn_id: currentUserMessage ? "user_" + currentTurnId : null,
60
+ role: "assistant",
61
+ timestamp: taskTimestamp,
62
+ content: currentBlocks,
63
+ model: currentModel,
64
+ usage: null,
65
+ source_metadata: { turn_id: currentTurnId },
66
+ });
67
+ }
68
+ }
69
+ inTask = false;
70
+ currentTurnId = null;
71
+ currentUserMessage = null;
72
+ currentBlocks = [];
73
+ taskTimestamp = null;
74
+ currentModel = null;
75
+ continue;
76
+ }
77
+ if (!inTask)
78
+ continue;
79
+ if (type === "turn_context") {
80
+ currentModel = payload["model"] ?? null;
81
+ continue;
82
+ }
83
+ if (type === "event_msg") {
84
+ switch (payload["type"]) {
85
+ case "user_message":
86
+ currentUserMessage = payload["message"] ?? "";
87
+ break;
88
+ case "agent_reasoning":
89
+ if (payload["text"])
90
+ currentBlocks.push({ type: "thinking", text: payload["text"] });
91
+ break;
92
+ case "agent_message":
93
+ if (payload["message"])
94
+ currentBlocks.push({ type: "text", text: payload["message"] });
95
+ break;
96
+ }
97
+ }
98
+ else if (type === "response_item") {
99
+ switch (payload["type"]) {
100
+ case "function_call": {
101
+ const callId = payload["call_id"] ?? randomUUID();
102
+ let toolInput = {};
103
+ try {
104
+ toolInput = JSON.parse(payload["arguments"] ?? "{}");
105
+ }
106
+ catch {
107
+ toolInput = { raw: payload["arguments"] };
108
+ }
109
+ currentBlocks.push({
110
+ type: "tool_use",
111
+ tool_call_id: callId,
112
+ tool_name: payload["name"] ?? "unknown",
113
+ tool_input: toolInput,
114
+ });
115
+ break;
116
+ }
117
+ case "function_call_output": {
118
+ const output = payload["output"];
119
+ const isError = typeof output === "string"
120
+ && output.includes("Process exited with code")
121
+ && !output.includes("code 0");
122
+ currentBlocks.push({
123
+ type: "tool_result",
124
+ tool_call_id: payload["call_id"] ?? "",
125
+ is_error: isError,
126
+ result_content: output ?? null,
127
+ exit_code: null,
128
+ });
129
+ break;
130
+ }
131
+ case "web_search_call": {
132
+ const action = payload["action"];
133
+ currentBlocks.push({
134
+ type: "tool_use",
135
+ tool_call_id: randomUUID(),
136
+ tool_name: "web_search",
137
+ tool_input: { query: action?.["query"] ?? "", queries: action?.["queries"] ?? [] },
138
+ });
139
+ break;
140
+ }
141
+ }
142
+ }
143
+ }
144
+ const allBlocks = turns.flatMap(t => t.content);
145
+ const toolCallCount = allBlocks.filter(b => b.type === "tool_use").length;
146
+ const hasFileChanges = allBlocks.some(b => b.type === "tool_use" && ["write_file", "file_change", "create_file"].includes(b.tool_name));
147
+ const hasShellCommands = allBlocks.some(b => b.type === "tool_use" && ["exec_command", "bash", "shell"].includes(b.tool_name));
148
+ const hasThinking = allBlocks.some(b => b.type === "thinking");
149
+ const startedAt = sessionMetaPayload["timestamp"] ?? events[0]?.["timestamp"] ?? new Date().toISOString();
150
+ const endedAt = events[events.length - 1]?.["timestamp"] ?? new Date().toISOString();
151
+ const partialTrace = {
152
+ schema_version: "1.0",
153
+ source_tool: "codex_cli",
154
+ source_session_id: sessionId,
155
+ source_version: cliVersion,
156
+ submitted_by: submittedBy,
157
+ submitted_at: new Date().toISOString(),
158
+ extracted_at: new Date().toISOString(),
159
+ git_branch: null,
160
+ cwd_hash: cwd ? hashString(cwd) : null,
161
+ working_language: null,
162
+ started_at: startedAt,
163
+ ended_at: endedAt,
164
+ turns,
165
+ turn_count: turns.length,
166
+ tool_call_count: toolCallCount,
167
+ has_tool_calls: toolCallCount > 0,
168
+ has_thinking_blocks: hasThinking,
169
+ has_file_changes: hasFileChanges,
170
+ has_shell_commands: hasShellCommands,
171
+ total_input_tokens: null,
172
+ total_output_tokens: null,
173
+ total_cache_read_tokens: null,
174
+ content_fidelity: "full",
175
+ env_state: {
176
+ git_branch: null,
177
+ inferred_file_tree: null,
178
+ inferred_changed_files: null,
179
+ inferred_error_files: null,
180
+ shell_exit_codes: null,
181
+ open_files_in_editor: null,
182
+ extraction_method: "passive",
183
+ },
184
+ score: null,
185
+ raw_r2_key: "",
186
+ normalized_r2_key: "",
187
+ };
188
+ const contentHash = computeContentHash(partialTrace);
189
+ const traceId = hashString("codex_cli" + sessionId + contentHash);
190
+ return { ...partialTrace, trace_id: traceId };
191
+ }
192
+ //# sourceMappingURL=codex.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"codex.js","sourceRoot":"","sources":["../../src/extractors/codex.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,3 @@
1
+ import type { NormalizedTrace } from "../types.js";
2
+ export declare function extractCursor(dbPath: string, sessionId: string, submittedBy?: string): Promise<NormalizedTrace>;
3
+ //# sourceMappingURL=cursor.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"cursor.d.ts","sourceRoot":"","sources":["../../src/extractors/cursor.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,eAAe,EAAoB,MAAM,aAAa,CAAC;AAErE,wBAAsB,aAAa,CACjC,MAAM,EAAE,MAAM,EACd,SAAS,EAAE,MAAM,EACjB,WAAW,SAAY,GACtB,OAAO,CAAC,eAAe,CAAC,CA6G1B"}
@@ -0,0 +1,99 @@
1
+ import { hashString, computeContentHash } from "../hash.js";
2
+ export async function extractCursor(dbPath, sessionId, submittedBy = "unknown") {
3
+ const Database = (await import("better-sqlite3")).default;
4
+ const db = new Database(dbPath, { readonly: true });
5
+ try {
6
+ const composerRow = db
7
+ .prepare("SELECT value FROM cursorDiskKV WHERE key = ?")
8
+ .get(`composerData:${sessionId}`);
9
+ if (!composerRow)
10
+ throw new Error(`Session ${sessionId} not found in cursor DB`);
11
+ const composerData = JSON.parse(composerRow.value);
12
+ const headers = composerData.fullConversationHeadersOnly ?? [];
13
+ const turns = [];
14
+ const openFiles = [];
15
+ for (const header of headers) {
16
+ const bubbleId = header.bubbleId ?? header.id;
17
+ if (!bubbleId)
18
+ continue;
19
+ const blobRow = db
20
+ .prepare("SELECT value FROM cursorDiskKV WHERE key = ?")
21
+ .get(`agentKv:blob:${bubbleId}`);
22
+ if (!blobRow)
23
+ continue;
24
+ const blob = JSON.parse(blobRow.value);
25
+ const role = blob.type === "user" || blob.role === "user" ? "user" : "assistant";
26
+ const text = blob.text ?? blob.content ?? blob.message ?? "";
27
+ if (blob.context?.openFiles) {
28
+ openFiles.push(...blob.context.openFiles.map((f) => (typeof f === "string" ? f : f.path ?? "")));
29
+ }
30
+ const tokenUsage = blob.usage
31
+ ? {
32
+ input_tokens: blob.usage.promptTokens ?? 0,
33
+ output_tokens: blob.usage.completionTokens ?? 0,
34
+ cache_read_input_tokens: null,
35
+ cache_creation_input_tokens: null,
36
+ reasoning_tokens: null,
37
+ }
38
+ : null;
39
+ turns.push({
40
+ turn_id: bubbleId,
41
+ parent_turn_id: null,
42
+ role,
43
+ timestamp: blob.createdAt ?? header.createdAt ?? null,
44
+ content: [{ type: "text", text }],
45
+ model: blob.model ?? null,
46
+ usage: tokenUsage,
47
+ source_metadata: { bubbleId, type: blob.type },
48
+ });
49
+ }
50
+ db.close();
51
+ const startedAt = turns[0]?.timestamp ?? new Date().toISOString();
52
+ const endedAt = turns[turns.length - 1]?.timestamp ?? new Date().toISOString();
53
+ const partialTrace = {
54
+ schema_version: "1.0",
55
+ source_tool: "cursor",
56
+ source_session_id: sessionId,
57
+ source_version: null,
58
+ submitted_by: submittedBy,
59
+ submitted_at: new Date().toISOString(),
60
+ extracted_at: new Date().toISOString(),
61
+ git_branch: null,
62
+ cwd_hash: null,
63
+ working_language: null,
64
+ started_at: startedAt,
65
+ ended_at: endedAt,
66
+ turns,
67
+ turn_count: turns.length,
68
+ tool_call_count: 0,
69
+ has_tool_calls: false,
70
+ has_thinking_blocks: false,
71
+ has_file_changes: false,
72
+ has_shell_commands: false,
73
+ total_input_tokens: null,
74
+ total_output_tokens: null,
75
+ total_cache_read_tokens: null,
76
+ content_fidelity: "chat_only",
77
+ env_state: {
78
+ git_branch: null,
79
+ inferred_file_tree: null,
80
+ inferred_changed_files: null,
81
+ inferred_error_files: null,
82
+ shell_exit_codes: null,
83
+ open_files_in_editor: openFiles.length > 0 ? openFiles : null,
84
+ extraction_method: "passive",
85
+ },
86
+ score: null,
87
+ raw_r2_key: "",
88
+ normalized_r2_key: "",
89
+ };
90
+ const contentHash = computeContentHash(partialTrace);
91
+ const traceId = hashString("cursor" + sessionId + contentHash);
92
+ return { ...partialTrace, trace_id: traceId };
93
+ }
94
+ catch (err) {
95
+ db.close();
96
+ throw err;
97
+ }
98
+ }
99
+ //# sourceMappingURL=cursor.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"cursor.js","sourceRoot":"","sources":["../../src/extractors/cursor.ts"],"names":[],"mappings":"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"}
package/dist/hash.d.ts ADDED
@@ -0,0 +1,4 @@
1
+ import type { NormalizedTrace } from "./types.js";
2
+ export declare function computeContentHash(trace: NormalizedTrace): string;
3
+ export declare function hashString(s: string): string;
4
+ //# sourceMappingURL=hash.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"hash.d.ts","sourceRoot":"","sources":["../src/hash.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,YAAY,CAAC;AAElD,wBAAgB,kBAAkB,CAAC,KAAK,EAAE,eAAe,GAAG,MAAM,CAOjE;AAED,wBAAgB,UAAU,CAAC,CAAC,EAAE,MAAM,GAAG,MAAM,CAE5C"}
package/dist/hash.js ADDED
@@ -0,0 +1,13 @@
1
+ import { createHash } from "crypto";
2
+ export function computeContentHash(trace) {
3
+ const content = JSON.stringify({
4
+ source_tool: trace.source_tool,
5
+ source_session_id: trace.source_session_id,
6
+ turns: trace.turns,
7
+ });
8
+ return createHash("sha256").update(content).digest("hex");
9
+ }
10
+ export function hashString(s) {
11
+ return createHash("sha256").update(s).digest("hex");
12
+ }
13
+ //# sourceMappingURL=hash.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"hash.js","sourceRoot":"","sources":["../src/hash.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,QAAQ,CAAC;AAGpC,MAAM,UAAU,kBAAkB,CAAC,KAAsB;IACvD,MAAM,OAAO,GAAG,IAAI,CAAC,SAAS,CAAC;QAC7B,WAAW,EAAE,KAAK,CAAC,WAAW;QAC9B,iBAAiB,EAAE,KAAK,CAAC,iBAAiB;QAC1C,KAAK,EAAE,KAAK,CAAC,KAAK;KACnB,CAAC,CAAC;IACH,OAAO,UAAU,CAAC,QAAQ,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;AAC5D,CAAC;AAED,MAAM,UAAU,UAAU,CAAC,CAAS;IAClC,OAAO,UAAU,CAAC,QAAQ,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;AACtD,CAAC"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=hash.test.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"hash.test.d.ts","sourceRoot":"","sources":["../src/hash.test.ts"],"names":[],"mappings":""}
@@ -0,0 +1,67 @@
1
+ import { describe, it, expect } from "vitest";
2
+ import { computeContentHash } from "./hash.js";
3
+ function makeTrace(overrides = {}) {
4
+ return {
5
+ trace_id: "test-id",
6
+ schema_version: "1.0",
7
+ source_tool: "claude_code",
8
+ source_session_id: "session-abc",
9
+ source_version: null,
10
+ submitted_by: "user1",
11
+ submitted_at: "2024-01-01T00:00:00Z",
12
+ extracted_at: "2024-01-01T00:00:00Z",
13
+ git_branch: null,
14
+ cwd_hash: null,
15
+ working_language: null,
16
+ started_at: "2024-01-01T00:00:00Z",
17
+ ended_at: "2024-01-01T00:01:00Z",
18
+ turns: [],
19
+ turn_count: 0,
20
+ tool_call_count: 0,
21
+ has_tool_calls: false,
22
+ has_thinking_blocks: false,
23
+ has_file_changes: false,
24
+ has_shell_commands: false,
25
+ total_input_tokens: null,
26
+ total_output_tokens: null,
27
+ total_cache_read_tokens: null,
28
+ content_fidelity: "full",
29
+ env_state: null,
30
+ score: null,
31
+ raw_r2_key: "",
32
+ normalized_r2_key: "",
33
+ ...overrides,
34
+ };
35
+ }
36
+ describe("computeContentHash", () => {
37
+ it("returns the same hash for identical input", () => {
38
+ const trace = makeTrace();
39
+ expect(computeContentHash(trace)).toBe(computeContentHash(trace));
40
+ });
41
+ it("returns different hashes for different session_ids", () => {
42
+ const a = makeTrace({ source_session_id: "session-aaa" });
43
+ const b = makeTrace({ source_session_id: "session-bbb" });
44
+ expect(computeContentHash(a)).not.toBe(computeContentHash(b));
45
+ });
46
+ it("returns different hashes for different turns", () => {
47
+ const a = makeTrace({ turns: [] });
48
+ const b = makeTrace({
49
+ turns: [{
50
+ turn_id: "t1",
51
+ parent_turn_id: null,
52
+ role: "user",
53
+ timestamp: null,
54
+ content: [{ type: "text", text: "hello" }],
55
+ model: null,
56
+ usage: null,
57
+ source_metadata: {},
58
+ }],
59
+ });
60
+ expect(computeContentHash(a)).not.toBe(computeContentHash(b));
61
+ });
62
+ it("output is a 64-char hex string", () => {
63
+ const hash = computeContentHash(makeTrace());
64
+ expect(hash).toMatch(/^[0-9a-f]{64}$/);
65
+ });
66
+ });
67
+ //# sourceMappingURL=hash.test.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"hash.test.js","sourceRoot":"","sources":["../src/hash.test.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,9 @@
1
+ export * from "./types.js";
2
+ export * from "./hash.js";
3
+ export * from "./scoring.js";
4
+ export * from "./utils.js";
5
+ export * from "./validators.js";
6
+ export { extractClaudeCode } from "./extractors/claude-code.js";
7
+ export { extractCodex } from "./extractors/codex.js";
8
+ export { extractCursor } from "./extractors/cursor.js";
9
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,YAAY,CAAC;AAC3B,cAAc,WAAW,CAAC;AAC1B,cAAc,cAAc,CAAC;AAC7B,cAAc,YAAY,CAAC;AAC3B,cAAc,iBAAiB,CAAC;AAChC,OAAO,EAAE,iBAAiB,EAAE,MAAM,6BAA6B,CAAC;AAChE,OAAO,EAAE,YAAY,EAAE,MAAM,uBAAuB,CAAC;AACrD,OAAO,EAAE,aAAa,EAAE,MAAM,wBAAwB,CAAC"}
package/dist/index.js ADDED
@@ -0,0 +1,9 @@
1
+ export * from "./types.js";
2
+ export * from "./hash.js";
3
+ export * from "./scoring.js";
4
+ export * from "./utils.js";
5
+ export * from "./validators.js";
6
+ export { extractClaudeCode } from "./extractors/claude-code.js";
7
+ export { extractCodex } from "./extractors/codex.js";
8
+ export { extractCursor } from "./extractors/cursor.js";
9
+ //# sourceMappingURL=index.js.map