@ccpocket/bridge 0.1.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 (77) hide show
  1. package/README.md +54 -0
  2. package/dist/claude-process.d.ts +108 -0
  3. package/dist/claude-process.js +471 -0
  4. package/dist/claude-process.js.map +1 -0
  5. package/dist/cli.d.ts +2 -0
  6. package/dist/cli.js +42 -0
  7. package/dist/cli.js.map +1 -0
  8. package/dist/codex-process.d.ts +46 -0
  9. package/dist/codex-process.js +420 -0
  10. package/dist/codex-process.js.map +1 -0
  11. package/dist/debug-trace-store.d.ts +15 -0
  12. package/dist/debug-trace-store.js +78 -0
  13. package/dist/debug-trace-store.js.map +1 -0
  14. package/dist/firebase-auth.d.ts +35 -0
  15. package/dist/firebase-auth.js +132 -0
  16. package/dist/firebase-auth.js.map +1 -0
  17. package/dist/gallery-store.d.ts +66 -0
  18. package/dist/gallery-store.js +310 -0
  19. package/dist/gallery-store.js.map +1 -0
  20. package/dist/image-store.d.ts +22 -0
  21. package/dist/image-store.js +113 -0
  22. package/dist/image-store.js.map +1 -0
  23. package/dist/index.d.ts +1 -0
  24. package/dist/index.js +153 -0
  25. package/dist/index.js.map +1 -0
  26. package/dist/mdns.d.ts +6 -0
  27. package/dist/mdns.js +42 -0
  28. package/dist/mdns.js.map +1 -0
  29. package/dist/parser.d.ts +381 -0
  30. package/dist/parser.js +218 -0
  31. package/dist/parser.js.map +1 -0
  32. package/dist/project-history.d.ts +10 -0
  33. package/dist/project-history.js +73 -0
  34. package/dist/project-history.js.map +1 -0
  35. package/dist/prompt-history-backup.d.ts +15 -0
  36. package/dist/prompt-history-backup.js +46 -0
  37. package/dist/prompt-history-backup.js.map +1 -0
  38. package/dist/push-relay.d.ts +27 -0
  39. package/dist/push-relay.js +69 -0
  40. package/dist/push-relay.js.map +1 -0
  41. package/dist/recording-store.d.ts +51 -0
  42. package/dist/recording-store.js +158 -0
  43. package/dist/recording-store.js.map +1 -0
  44. package/dist/screenshot.d.ts +28 -0
  45. package/dist/screenshot.js +98 -0
  46. package/dist/screenshot.js.map +1 -0
  47. package/dist/sdk-process.d.ts +151 -0
  48. package/dist/sdk-process.js +740 -0
  49. package/dist/sdk-process.js.map +1 -0
  50. package/dist/session.d.ts +126 -0
  51. package/dist/session.js +550 -0
  52. package/dist/session.js.map +1 -0
  53. package/dist/sessions-index.d.ts +86 -0
  54. package/dist/sessions-index.js +1027 -0
  55. package/dist/sessions-index.js.map +1 -0
  56. package/dist/setup-launchd.d.ts +8 -0
  57. package/dist/setup-launchd.js +109 -0
  58. package/dist/setup-launchd.js.map +1 -0
  59. package/dist/startup-info.d.ts +8 -0
  60. package/dist/startup-info.js +78 -0
  61. package/dist/startup-info.js.map +1 -0
  62. package/dist/usage.d.ts +17 -0
  63. package/dist/usage.js +236 -0
  64. package/dist/usage.js.map +1 -0
  65. package/dist/version.d.ts +11 -0
  66. package/dist/version.js +39 -0
  67. package/dist/version.js.map +1 -0
  68. package/dist/websocket.d.ts +71 -0
  69. package/dist/websocket.js +1487 -0
  70. package/dist/websocket.js.map +1 -0
  71. package/dist/worktree-store.d.ts +25 -0
  72. package/dist/worktree-store.js +59 -0
  73. package/dist/worktree-store.js.map +1 -0
  74. package/dist/worktree.d.ts +43 -0
  75. package/dist/worktree.js +295 -0
  76. package/dist/worktree.js.map +1 -0
  77. package/package.json +63 -0
package/dist/cli.js ADDED
@@ -0,0 +1,42 @@
1
+ #!/usr/bin/env node
2
+ import { startServer } from "./index.js";
3
+ import { setupLaunchd, uninstallLaunchd } from "./setup-launchd.js";
4
+ const args = process.argv.slice(2);
5
+ // Check for "setup" subcommand
6
+ const subcommand = args.find((a) => !a.startsWith("-"));
7
+ function parseFlag(name) {
8
+ const idx = args.indexOf(`--${name}`);
9
+ if (idx === -1 || idx + 1 >= args.length)
10
+ return undefined;
11
+ return args[idx + 1];
12
+ }
13
+ function hasFlag(name) {
14
+ return args.includes(`--${name}`);
15
+ }
16
+ if (subcommand === "setup") {
17
+ // launchd setup subcommand
18
+ if (hasFlag("uninstall")) {
19
+ uninstallLaunchd();
20
+ }
21
+ else {
22
+ setupLaunchd({
23
+ port: parseFlag("port"),
24
+ host: parseFlag("host"),
25
+ apiKey: parseFlag("api-key"),
26
+ });
27
+ }
28
+ }
29
+ else {
30
+ // Server mode: set env vars from CLI flags, then start
31
+ const port = parseFlag("port");
32
+ const host = parseFlag("host");
33
+ const apiKey = parseFlag("api-key");
34
+ if (port)
35
+ process.env.BRIDGE_PORT = port;
36
+ if (host)
37
+ process.env.BRIDGE_HOST = host;
38
+ if (apiKey)
39
+ process.env.BRIDGE_API_KEY = apiKey;
40
+ startServer();
41
+ }
42
+ //# sourceMappingURL=cli.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"cli.js","sourceRoot":"","sources":["../src/cli.ts"],"names":[],"mappings":";AACA,OAAO,EAAE,WAAW,EAAE,MAAM,YAAY,CAAC;AACzC,OAAO,EAAE,YAAY,EAAE,gBAAgB,EAAE,MAAM,oBAAoB,CAAC;AAEpE,MAAM,IAAI,GAAG,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;AAEnC,+BAA+B;AAC/B,MAAM,UAAU,GAAG,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,UAAU,CAAC,GAAG,CAAC,CAAC,CAAC;AAExD,SAAS,SAAS,CAAC,IAAY;IAC7B,MAAM,GAAG,GAAG,IAAI,CAAC,OAAO,CAAC,KAAK,IAAI,EAAE,CAAC,CAAC;IACtC,IAAI,GAAG,KAAK,CAAC,CAAC,IAAI,GAAG,GAAG,CAAC,IAAI,IAAI,CAAC,MAAM;QAAE,OAAO,SAAS,CAAC;IAC3D,OAAO,IAAI,CAAC,GAAG,GAAG,CAAC,CAAC,CAAC;AACvB,CAAC;AAED,SAAS,OAAO,CAAC,IAAY;IAC3B,OAAO,IAAI,CAAC,QAAQ,CAAC,KAAK,IAAI,EAAE,CAAC,CAAC;AACpC,CAAC;AAED,IAAI,UAAU,KAAK,OAAO,EAAE,CAAC;IAC3B,2BAA2B;IAC3B,IAAI,OAAO,CAAC,WAAW,CAAC,EAAE,CAAC;QACzB,gBAAgB,EAAE,CAAC;IACrB,CAAC;SAAM,CAAC;QACN,YAAY,CAAC;YACX,IAAI,EAAE,SAAS,CAAC,MAAM,CAAC;YACvB,IAAI,EAAE,SAAS,CAAC,MAAM,CAAC;YACvB,MAAM,EAAE,SAAS,CAAC,SAAS,CAAC;SAC7B,CAAC,CAAC;IACL,CAAC;AACH,CAAC;KAAM,CAAC;IACN,uDAAuD;IACvD,MAAM,IAAI,GAAG,SAAS,CAAC,MAAM,CAAC,CAAC;IAC/B,MAAM,IAAI,GAAG,SAAS,CAAC,MAAM,CAAC,CAAC;IAC/B,MAAM,MAAM,GAAG,SAAS,CAAC,SAAS,CAAC,CAAC;IAEpC,IAAI,IAAI;QAAE,OAAO,CAAC,GAAG,CAAC,WAAW,GAAG,IAAI,CAAC;IACzC,IAAI,IAAI;QAAE,OAAO,CAAC,GAAG,CAAC,WAAW,GAAG,IAAI,CAAC;IACzC,IAAI,MAAM;QAAE,OAAO,CAAC,GAAG,CAAC,cAAc,GAAG,MAAM,CAAC;IAEhD,WAAW,EAAE,CAAC;AAChB,CAAC"}
@@ -0,0 +1,46 @@
1
+ import { EventEmitter } from "node:events";
2
+ import type { ServerMessage, ProcessStatus } from "./parser.js";
3
+ export interface CodexStartOptions {
4
+ threadId?: string;
5
+ approvalPolicy?: "never" | "on-request" | "on-failure" | "untrusted";
6
+ sandboxMode?: "read-only" | "workspace-write" | "danger-full-access";
7
+ model?: string;
8
+ modelReasoningEffort?: "minimal" | "low" | "medium" | "high" | "xhigh";
9
+ networkAccessEnabled?: boolean;
10
+ webSearchMode?: "disabled" | "cached" | "live";
11
+ }
12
+ export interface CodexProcessEvents {
13
+ message: [ServerMessage];
14
+ status: [ProcessStatus];
15
+ exit: [number | null];
16
+ }
17
+ export declare class CodexProcess extends EventEmitter<CodexProcessEvents> {
18
+ private codex;
19
+ private thread;
20
+ private _status;
21
+ private _threadId;
22
+ private stopped;
23
+ private startModel;
24
+ private inputResolve;
25
+ private pendingAbort;
26
+ get status(): ProcessStatus;
27
+ get isWaitingForInput(): boolean;
28
+ get sessionId(): string | null;
29
+ get isRunning(): boolean;
30
+ constructor();
31
+ start(projectPath: string, options?: CodexStartOptions): void;
32
+ stop(): void;
33
+ interrupt(): void;
34
+ sendInput(text: string): void;
35
+ sendInputWithImage(text: string, image: {
36
+ base64: string;
37
+ mimeType: string;
38
+ }): void;
39
+ private runInputLoop;
40
+ private processEvent;
41
+ private processItemStarted;
42
+ private processItemCompleted;
43
+ private setStatus;
44
+ private emitMessage;
45
+ private toSdkInput;
46
+ }
@@ -0,0 +1,420 @@
1
+ import { EventEmitter } from "node:events";
2
+ import { randomUUID } from "node:crypto";
3
+ import { tmpdir } from "node:os";
4
+ import { join } from "node:path";
5
+ import { rm, writeFile } from "node:fs/promises";
6
+ import { Codex } from "@openai/codex-sdk";
7
+ export class CodexProcess extends EventEmitter {
8
+ codex;
9
+ thread = null;
10
+ _status = "starting";
11
+ _threadId = null;
12
+ stopped = false;
13
+ startModel;
14
+ // User input channel
15
+ inputResolve = null;
16
+ pendingAbort = null;
17
+ get status() {
18
+ return this._status;
19
+ }
20
+ get isWaitingForInput() {
21
+ return this.inputResolve !== null;
22
+ }
23
+ get sessionId() {
24
+ return this._threadId;
25
+ }
26
+ get isRunning() {
27
+ return this.thread !== null;
28
+ }
29
+ constructor() {
30
+ super();
31
+ this.codex = new Codex();
32
+ }
33
+ start(projectPath, options) {
34
+ if (this.thread) {
35
+ this.stop();
36
+ }
37
+ this.stopped = false;
38
+ this._threadId = null;
39
+ const threadOpts = {
40
+ workingDirectory: projectPath,
41
+ approvalPolicy: options?.approvalPolicy ?? "never",
42
+ sandboxMode: options?.sandboxMode ?? "workspace-write",
43
+ networkAccessEnabled: options?.networkAccessEnabled ?? true,
44
+ skipGitRepoCheck: true,
45
+ ...(options?.model ? { model: options.model } : {}),
46
+ ...(options?.modelReasoningEffort ? { modelReasoningEffort: options.modelReasoningEffort } : {}),
47
+ ...(options?.webSearchMode ? { webSearchMode: options.webSearchMode } : {}),
48
+ };
49
+ console.log(`[codex-process] Starting (cwd: ${projectPath}, sandbox: ${threadOpts.sandboxMode}, approval: ${threadOpts.approvalPolicy}, model: ${threadOpts.model ?? "default"}, reasoning: ${threadOpts.modelReasoningEffort ?? "default"}, network: ${threadOpts.networkAccessEnabled}, webSearch: ${threadOpts.webSearchMode ?? "default"})`);
50
+ this.thread = options?.threadId
51
+ ? this.codex.resumeThread(options.threadId, threadOpts)
52
+ : this.codex.startThread(threadOpts);
53
+ this.setStatus("idle");
54
+ this.startModel = options?.model;
55
+ // Start input loop
56
+ this.runInputLoop().catch((err) => {
57
+ if (!this.stopped) {
58
+ console.error("[codex-process] Input loop error:", err);
59
+ this.emitMessage({
60
+ type: "error",
61
+ message: `Codex error: ${err instanceof Error ? err.message : String(err)}`,
62
+ });
63
+ }
64
+ this.setStatus("idle");
65
+ this.emit("exit", 1);
66
+ });
67
+ }
68
+ stop() {
69
+ this.stopped = true;
70
+ if (this.pendingAbort) {
71
+ this.pendingAbort.abort();
72
+ this.pendingAbort = null;
73
+ }
74
+ // Unblock pending input wait
75
+ if (this.inputResolve) {
76
+ this.inputResolve({ text: "" });
77
+ this.inputResolve = null;
78
+ }
79
+ this.thread = null;
80
+ this.setStatus("idle");
81
+ console.log("[codex-process] Stopped");
82
+ }
83
+ interrupt() {
84
+ if (this.pendingAbort) {
85
+ console.log("[codex-process] Interrupting current turn");
86
+ this.pendingAbort.abort();
87
+ }
88
+ }
89
+ sendInput(text) {
90
+ if (!this.inputResolve) {
91
+ console.error("[codex-process] No pending input resolver for sendInput");
92
+ return;
93
+ }
94
+ const resolve = this.inputResolve;
95
+ this.inputResolve = null;
96
+ resolve({ text });
97
+ }
98
+ sendInputWithImage(text, image) {
99
+ if (!this.inputResolve) {
100
+ console.error("[codex-process] No pending input resolver for sendInputWithImage");
101
+ return;
102
+ }
103
+ const resolve = this.inputResolve;
104
+ this.inputResolve = null;
105
+ resolve({
106
+ text,
107
+ image,
108
+ });
109
+ }
110
+ // ---- Private ----
111
+ async runInputLoop() {
112
+ while (!this.stopped) {
113
+ // Wait for user input
114
+ const pendingInput = await new Promise((resolve) => {
115
+ this.inputResolve = resolve;
116
+ });
117
+ if (this.stopped || !pendingInput.text || !this.thread)
118
+ break;
119
+ const { input, tempPaths } = await this.toSdkInput(pendingInput);
120
+ if (!input) {
121
+ continue;
122
+ }
123
+ // Execute turn
124
+ this.setStatus("running");
125
+ const controller = new AbortController();
126
+ this.pendingAbort = controller;
127
+ try {
128
+ const streamed = await this.thread.runStreamed(input, {
129
+ signal: controller.signal,
130
+ });
131
+ for await (const event of streamed.events) {
132
+ if (this.stopped)
133
+ break;
134
+ this.processEvent(event);
135
+ }
136
+ }
137
+ catch (err) {
138
+ if (!this.stopped) {
139
+ const msg = err instanceof Error ? err.message : String(err);
140
+ // Don't emit error for abort (user-initiated interrupt)
141
+ if (!controller.signal.aborted) {
142
+ this.emitMessage({ type: "error", message: msg });
143
+ }
144
+ this.emitMessage({
145
+ type: "result",
146
+ subtype: controller.signal.aborted ? "interrupted" : "error",
147
+ error: controller.signal.aborted ? undefined : msg,
148
+ sessionId: this._threadId ?? undefined,
149
+ });
150
+ }
151
+ }
152
+ finally {
153
+ for (const path of tempPaths) {
154
+ await rm(path, { force: true }).catch(() => { });
155
+ }
156
+ this.pendingAbort = null;
157
+ if (!this.stopped) {
158
+ this.setStatus("idle");
159
+ }
160
+ }
161
+ }
162
+ }
163
+ processEvent(event) {
164
+ switch (event.type) {
165
+ case "thread.started":
166
+ this._threadId = event.thread_id;
167
+ console.log(`[codex-process] Thread started: ${event.thread_id}`);
168
+ this.emitMessage({
169
+ type: "system",
170
+ subtype: "init",
171
+ sessionId: event.thread_id,
172
+ model: this.startModel ?? "codex",
173
+ });
174
+ break;
175
+ case "turn.started":
176
+ this.setStatus("running");
177
+ break;
178
+ case "item.started":
179
+ this.processItemStarted(event.item);
180
+ break;
181
+ case "item.completed":
182
+ this.processItemCompleted(event.item);
183
+ break;
184
+ case "item.updated":
185
+ // Not fired in current SDK version, but handle for future compatibility
186
+ this.processItemCompleted(event.item);
187
+ break;
188
+ case "turn.completed":
189
+ this.emitMessage({
190
+ type: "result",
191
+ subtype: "success",
192
+ sessionId: this._threadId ?? undefined,
193
+ inputTokens: event.usage.input_tokens,
194
+ cachedInputTokens: event.usage.cached_input_tokens,
195
+ outputTokens: event.usage.output_tokens,
196
+ });
197
+ break;
198
+ case "turn.failed":
199
+ this.emitMessage({
200
+ type: "result",
201
+ subtype: "error",
202
+ error: event.error.message,
203
+ sessionId: this._threadId ?? undefined,
204
+ });
205
+ break;
206
+ case "error":
207
+ this.emitMessage({ type: "error", message: event.message });
208
+ break;
209
+ }
210
+ }
211
+ processItemStarted(item) {
212
+ switch (item.type) {
213
+ case "command_execution":
214
+ // Emit tool_use for the command (shown before result)
215
+ this.emitMessage({
216
+ type: "assistant",
217
+ message: {
218
+ id: item.id,
219
+ role: "assistant",
220
+ content: [
221
+ {
222
+ type: "tool_use",
223
+ id: item.id,
224
+ name: "Bash",
225
+ input: { command: item.command },
226
+ },
227
+ ],
228
+ model: "codex",
229
+ },
230
+ });
231
+ break;
232
+ // Other item types: nothing to show on start
233
+ }
234
+ }
235
+ processItemCompleted(item) {
236
+ switch (item.type) {
237
+ case "agent_message":
238
+ this.emitMessage({
239
+ type: "assistant",
240
+ message: {
241
+ id: item.id,
242
+ role: "assistant",
243
+ content: [{ type: "text", text: item.text }],
244
+ model: "codex",
245
+ },
246
+ });
247
+ break;
248
+ case "reasoning":
249
+ this.emitMessage({ type: "thinking_delta", text: item.text });
250
+ break;
251
+ case "command_execution":
252
+ this.emitMessage({
253
+ type: "tool_result",
254
+ toolUseId: item.id,
255
+ content: item.aggregated_output || `exit code: ${item.exit_code}`,
256
+ toolName: "Bash",
257
+ });
258
+ break;
259
+ case "file_change":
260
+ // Emit tool_use first (for display)
261
+ this.emitMessage({
262
+ type: "assistant",
263
+ message: {
264
+ id: item.id,
265
+ role: "assistant",
266
+ content: [
267
+ {
268
+ type: "tool_use",
269
+ id: item.id,
270
+ name: "FileChange",
271
+ input: { changes: item.changes },
272
+ },
273
+ ],
274
+ model: "codex",
275
+ },
276
+ });
277
+ this.emitMessage({
278
+ type: "tool_result",
279
+ toolUseId: item.id,
280
+ content: item.changes
281
+ .map((c) => `${c.kind}: ${c.path}`)
282
+ .join("\n"),
283
+ toolName: "FileChange",
284
+ });
285
+ break;
286
+ case "mcp_tool_call": {
287
+ const toolName = `mcp:${item.server}/${item.tool}`;
288
+ // Emit tool_use first
289
+ this.emitMessage({
290
+ type: "assistant",
291
+ message: {
292
+ id: item.id,
293
+ role: "assistant",
294
+ content: [
295
+ {
296
+ type: "tool_use",
297
+ id: item.id,
298
+ name: toolName,
299
+ input: item.arguments,
300
+ },
301
+ ],
302
+ model: "codex",
303
+ },
304
+ });
305
+ this.emitMessage({
306
+ type: "tool_result",
307
+ toolUseId: item.id,
308
+ content: item.result
309
+ ? JSON.stringify(item.result)
310
+ : item.error?.message ?? "MCP call completed",
311
+ toolName,
312
+ });
313
+ break;
314
+ }
315
+ case "web_search":
316
+ this.emitMessage({
317
+ type: "assistant",
318
+ message: {
319
+ id: item.id,
320
+ role: "assistant",
321
+ content: [
322
+ {
323
+ type: "tool_use",
324
+ id: item.id,
325
+ name: "WebSearch",
326
+ input: { query: item.query },
327
+ },
328
+ ],
329
+ model: "codex",
330
+ },
331
+ });
332
+ this.emitMessage({
333
+ type: "tool_result",
334
+ toolUseId: item.id,
335
+ content: `Web search: ${item.query}`,
336
+ toolName: "WebSearch",
337
+ });
338
+ break;
339
+ case "todo_list":
340
+ this.emitMessage({
341
+ type: "assistant",
342
+ message: {
343
+ id: item.id,
344
+ role: "assistant",
345
+ content: [
346
+ {
347
+ type: "text",
348
+ text: item.items
349
+ .map((t) => `${t.completed ? "\u2705" : "\u2B1C"} ${t.text}`)
350
+ .join("\n"),
351
+ },
352
+ ],
353
+ model: "codex",
354
+ },
355
+ });
356
+ break;
357
+ case "error":
358
+ this.emitMessage({ type: "error", message: item.message });
359
+ break;
360
+ }
361
+ }
362
+ setStatus(status) {
363
+ if (this._status !== status) {
364
+ this._status = status;
365
+ this.emit("status", status);
366
+ this.emitMessage({ type: "status", status });
367
+ }
368
+ }
369
+ emitMessage(msg) {
370
+ this.emit("message", msg);
371
+ }
372
+ async toSdkInput(pendingInput) {
373
+ if (!pendingInput.image) {
374
+ return { input: pendingInput.text, tempPaths: [] };
375
+ }
376
+ const ext = extensionFromMime(pendingInput.image.mimeType);
377
+ if (!ext) {
378
+ this.emitMessage({
379
+ type: "error",
380
+ message: `Unsupported image mime type for Codex: ${pendingInput.image.mimeType}`,
381
+ });
382
+ return { input: null, tempPaths: [] };
383
+ }
384
+ let buffer;
385
+ try {
386
+ buffer = Buffer.from(pendingInput.image.base64, "base64");
387
+ }
388
+ catch {
389
+ this.emitMessage({
390
+ type: "error",
391
+ message: "Invalid base64 image data for Codex input",
392
+ });
393
+ return { input: null, tempPaths: [] };
394
+ }
395
+ const tempPath = join(tmpdir(), `ccpocket-codex-image-${randomUUID()}.${ext}`);
396
+ await writeFile(tempPath, buffer);
397
+ return {
398
+ input: [
399
+ { type: "text", text: pendingInput.text },
400
+ { type: "local_image", path: tempPath },
401
+ ],
402
+ tempPaths: [tempPath],
403
+ };
404
+ }
405
+ }
406
+ function extensionFromMime(mimeType) {
407
+ switch (mimeType) {
408
+ case "image/png":
409
+ return "png";
410
+ case "image/jpeg":
411
+ return "jpg";
412
+ case "image/webp":
413
+ return "webp";
414
+ case "image/gif":
415
+ return "gif";
416
+ default:
417
+ return null;
418
+ }
419
+ }
420
+ //# sourceMappingURL=codex-process.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"codex-process.js","sourceRoot":"","sources":["../src/codex-process.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,15 @@
1
+ import type { DebugTraceEvent } from "./parser.js";
2
+ export declare class DebugTraceStore {
3
+ private traceDir;
4
+ private bundleDir;
5
+ private writeChains;
6
+ constructor(rootDir?: string);
7
+ init(): Promise<void>;
8
+ getTraceFilePath(sessionId: string): string;
9
+ getBundleFilePath(sessionId: string, generatedAt: string): string;
10
+ saveBundleAtPath(path: string, bundle: Record<string, unknown>): void;
11
+ saveBundle(sessionId: string, generatedAt: string, bundle: Record<string, unknown>): string;
12
+ record(event: DebugTraceEvent): void;
13
+ flush(): Promise<void>;
14
+ private enqueue;
15
+ }
@@ -0,0 +1,78 @@
1
+ import { appendFile, mkdir, writeFile } from "node:fs/promises";
2
+ import { homedir } from "node:os";
3
+ import { dirname, join } from "node:path";
4
+ const DEFAULT_ROOT_DIR = join(homedir(), ".ccpocket", "debug");
5
+ const TRACE_DIRNAME = "traces";
6
+ const BUNDLE_DIRNAME = "bundles";
7
+ export class DebugTraceStore {
8
+ traceDir;
9
+ bundleDir;
10
+ writeChains = new Map();
11
+ constructor(rootDir = DEFAULT_ROOT_DIR) {
12
+ this.traceDir = join(rootDir, TRACE_DIRNAME);
13
+ this.bundleDir = join(rootDir, BUNDLE_DIRNAME);
14
+ }
15
+ async init() {
16
+ await mkdir(this.traceDir, { recursive: true });
17
+ await mkdir(this.bundleDir, { recursive: true });
18
+ }
19
+ getTraceFilePath(sessionId) {
20
+ return join(this.traceDir, `${sanitizeSegment(sessionId)}.jsonl`);
21
+ }
22
+ getBundleFilePath(sessionId, generatedAt) {
23
+ return join(this.bundleDir, `${sanitizeSegment(sessionId)}-${timestampToken(generatedAt)}.json`);
24
+ }
25
+ saveBundleAtPath(path, bundle) {
26
+ const body = JSON.stringify(bundle, null, 2);
27
+ this.enqueue(path, async () => {
28
+ await writeFile(path, body, "utf-8");
29
+ });
30
+ }
31
+ saveBundle(sessionId, generatedAt, bundle) {
32
+ const path = this.getBundleFilePath(sessionId, generatedAt);
33
+ this.saveBundleAtPath(path, bundle);
34
+ return path;
35
+ }
36
+ record(event) {
37
+ const path = this.getTraceFilePath(event.sessionId);
38
+ const line = `${JSON.stringify(event)}\n`;
39
+ this.enqueue(path, async () => {
40
+ await appendFile(path, line, "utf-8");
41
+ });
42
+ }
43
+ async flush() {
44
+ const pendingWrites = [...this.writeChains.values()];
45
+ await Promise.all(pendingWrites.map((p) => p.catch(() => { })));
46
+ }
47
+ enqueue(path, task) {
48
+ const previous = this.writeChains.get(path) ?? Promise.resolve();
49
+ const next = previous
50
+ .catch(() => { })
51
+ .then(async () => {
52
+ await mkdir(dirname(path), { recursive: true });
53
+ await task();
54
+ })
55
+ .finally(() => {
56
+ // Avoid unbounded growth: clear settled chain if no newer chain replaced it.
57
+ if (this.writeChains.get(path) === next) {
58
+ this.writeChains.delete(path);
59
+ }
60
+ });
61
+ this.writeChains.set(path, next);
62
+ void next.catch((err) => {
63
+ console.warn(`[debug-trace-store] Failed to write ${path}:`, err);
64
+ });
65
+ }
66
+ }
67
+ function sanitizeSegment(value) {
68
+ return value.replace(/[^a-zA-Z0-9._-]/g, "_");
69
+ }
70
+ function timestampToken(iso) {
71
+ const token = iso.replace(/[^0-9]/g, "");
72
+ if (token.length >= 17)
73
+ return token.slice(0, 17);
74
+ if (token.length >= 14)
75
+ return token.slice(0, 14);
76
+ return Date.now().toString();
77
+ }
78
+ //# sourceMappingURL=debug-trace-store.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"debug-trace-store.js","sourceRoot":"","sources":["../src/debug-trace-store.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,35 @@
1
+ /**
2
+ * Firebase Anonymous Auth client for Bridge Server.
3
+ *
4
+ * Uses the Firebase Auth REST API directly instead of the client SDK
5
+ * to avoid Node.js compatibility issues with the browser-oriented SDK.
6
+ *
7
+ * Each Bridge instance signs in anonymously and obtains:
8
+ * - A unique UID (used as bridgeId)
9
+ * - An ID token (used as Bearer token for Cloud Functions)
10
+ *
11
+ * Credentials are persisted to ~/.ccpocket/firebase-credentials.json
12
+ * so that Bridge restarts reuse the same UID instead of creating
13
+ * a new anonymous account each time.
14
+ */
15
+ export declare class FirebaseAuthClient {
16
+ private _uid;
17
+ private _idToken;
18
+ private _refreshToken;
19
+ private _expiresAt;
20
+ get uid(): string;
21
+ /**
22
+ * Initialize Firebase auth.
23
+ * Tries to restore a previous session from disk first; falls back to
24
+ * creating a new anonymous account if restoration fails.
25
+ */
26
+ initialize(): Promise<void>;
27
+ /**
28
+ * Returns a fresh Firebase ID token.
29
+ * Automatically refreshes if the token is expired or about to expire.
30
+ */
31
+ getIdToken(): Promise<string>;
32
+ private signUpAnonymously;
33
+ private restoreSession;
34
+ private refreshIdToken;
35
+ }