@cloudflare/sandbox 0.0.3 → 0.0.5
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 +14 -0
- package/README.md +2 -0
- package/container_src/index.ts +8 -2
- package/dist/{chunk-N6VMTCTA.js → chunk-7EXU5SAL.js} +19 -4
- package/dist/chunk-7EXU5SAL.js.map +1 -0
- package/dist/client.js +1 -1
- package/dist/index.js +1 -1
- package/package.json +5 -3
- package/src/client.ts +24 -3
- package/dist/chunk-N6VMTCTA.js.map +0 -1
package/CHANGELOG.md
CHANGED
|
@@ -1,5 +1,19 @@
|
|
|
1
1
|
# @cloudflare/sandbox
|
|
2
2
|
|
|
3
|
+
## 0.0.5
|
|
4
|
+
|
|
5
|
+
### Patch Changes
|
|
6
|
+
|
|
7
|
+
- [#5](https://github.com/cloudflare/sandbox-sdk/pull/5) [`7c15b81`](https://github.com/cloudflare/sandbox-sdk/commit/7c15b817899e4d9e1f25747aaf439e5e9e880d15) Thanks [@ghostwriternr](https://github.com/ghostwriternr)! - Make package ready for deployment
|
|
8
|
+
|
|
9
|
+
## 0.0.4
|
|
10
|
+
|
|
11
|
+
### Patch Changes
|
|
12
|
+
|
|
13
|
+
- [`c0d9d33`](https://github.com/cloudflare/sandbox-sdk/commit/c0d9d3396badee1eab45e6b4a73d48957f31409b) Thanks [@threepointone](https://github.com/threepointone)! - actually work
|
|
14
|
+
|
|
15
|
+
- [`444d2da`](https://github.com/cloudflare/sandbox-sdk/commit/444d2dafde9a0f190e50c879b0e768da1b289b51) Thanks [@threepointone](https://github.com/threepointone)! - add experimental label
|
|
16
|
+
|
|
3
17
|
## 0.0.3
|
|
4
18
|
|
|
5
19
|
### Patch Changes
|
package/README.md
CHANGED
|
@@ -1,5 +1,7 @@
|
|
|
1
1
|
## @cloudflare/sandbox
|
|
2
2
|
|
|
3
|
+
> **⚠️ Experimental** - This library is currently experimental and we're actively seeking feedback. Please try it out and let us know what you think!
|
|
4
|
+
|
|
3
5
|
A library to spin up a sandboxed environment.
|
|
4
6
|
|
|
5
7
|
First, setup your wrangler.json to use the sandbox:
|
package/container_src/index.ts
CHANGED
|
@@ -84,6 +84,8 @@ const server = serve({
|
|
|
84
84
|
const url = new URL(req.url);
|
|
85
85
|
const pathname = url.pathname;
|
|
86
86
|
|
|
87
|
+
console.log(`[Container] Incoming ${req.method} request to ${pathname}`);
|
|
88
|
+
|
|
87
89
|
// Handle CORS
|
|
88
90
|
const corsHeaders = {
|
|
89
91
|
"Access-Control-Allow-Headers": "Content-Type, Authorization",
|
|
@@ -93,11 +95,13 @@ const server = serve({
|
|
|
93
95
|
|
|
94
96
|
// Handle preflight requests
|
|
95
97
|
if (req.method === "OPTIONS") {
|
|
98
|
+
console.log(`[Container] Handling CORS preflight for ${pathname}`);
|
|
96
99
|
return new Response(null, { headers: corsHeaders, status: 200 });
|
|
97
100
|
}
|
|
98
101
|
|
|
99
102
|
try {
|
|
100
103
|
// Handle different routes
|
|
104
|
+
console.log(`[Container] Processing ${req.method} ${pathname}`);
|
|
101
105
|
switch (pathname) {
|
|
102
106
|
case "/":
|
|
103
107
|
return new Response("Hello from Bun server! 🚀", {
|
|
@@ -352,13 +356,14 @@ const server = serve({
|
|
|
352
356
|
break;
|
|
353
357
|
|
|
354
358
|
default:
|
|
359
|
+
console.log(`[Container] Route not found: ${pathname}`);
|
|
355
360
|
return new Response("Not Found", {
|
|
356
361
|
headers: corsHeaders,
|
|
357
362
|
status: 404,
|
|
358
363
|
});
|
|
359
364
|
}
|
|
360
365
|
} catch (error) {
|
|
361
|
-
console.error(
|
|
366
|
+
console.error(`[Container] Error handling ${req.method} ${pathname}:`, error);
|
|
362
367
|
return new Response(
|
|
363
368
|
JSON.stringify({
|
|
364
369
|
error: "Internal server error",
|
|
@@ -374,6 +379,7 @@ const server = serve({
|
|
|
374
379
|
);
|
|
375
380
|
}
|
|
376
381
|
},
|
|
382
|
+
hostname: "0.0.0.0",
|
|
377
383
|
port: 3000,
|
|
378
384
|
} as any);
|
|
379
385
|
|
|
@@ -2874,7 +2880,7 @@ function executeMoveFile(
|
|
|
2874
2880
|
});
|
|
2875
2881
|
}
|
|
2876
2882
|
|
|
2877
|
-
console.log(`🚀 Bun server running on http://
|
|
2883
|
+
console.log(`🚀 Bun server running on http://0.0.0.0:${server.port}`);
|
|
2878
2884
|
console.log(`📡 HTTP API endpoints available:`);
|
|
2879
2885
|
console.log(` POST /api/session/create - Create a new session`);
|
|
2880
2886
|
console.log(` GET /api/session/list - List all sessions`);
|
|
@@ -10,10 +10,25 @@ var HttpClient = class {
|
|
|
10
10
|
this.baseUrl = this.options.baseUrl;
|
|
11
11
|
}
|
|
12
12
|
async doFetch(path, options) {
|
|
13
|
-
|
|
14
|
-
|
|
13
|
+
const url = this.options.stub ? `stub:${path}` : `${this.baseUrl}${path}`;
|
|
14
|
+
const method = options?.method || "GET";
|
|
15
|
+
console.log(`[HTTP Client] Making ${method} request to ${url}`);
|
|
16
|
+
try {
|
|
17
|
+
let response;
|
|
18
|
+
if (this.options.stub) {
|
|
19
|
+
response = await this.options.stub.containerFetch(path, options, this.options.port);
|
|
20
|
+
} else {
|
|
21
|
+
response = await fetch(this.baseUrl + path, options);
|
|
22
|
+
}
|
|
23
|
+
console.log(`[HTTP Client] Response: ${response.status} ${response.statusText}`);
|
|
24
|
+
if (!response.ok) {
|
|
25
|
+
console.error(`[HTTP Client] Request failed: ${method} ${url} - ${response.status} ${response.statusText}`);
|
|
26
|
+
}
|
|
27
|
+
return response;
|
|
28
|
+
} catch (error) {
|
|
29
|
+
console.error(`[HTTP Client] Request error: ${method} ${url}`, error);
|
|
30
|
+
throw error;
|
|
15
31
|
}
|
|
16
|
-
return fetch(this.baseUrl + path, options);
|
|
17
32
|
}
|
|
18
33
|
// Public methods to set event handlers
|
|
19
34
|
setOnOutput(handler) {
|
|
@@ -1338,4 +1353,4 @@ export {
|
|
|
1338
1353
|
quickMoveFile,
|
|
1339
1354
|
quickMoveFileStream
|
|
1340
1355
|
};
|
|
1341
|
-
//# sourceMappingURL=chunk-
|
|
1356
|
+
//# sourceMappingURL=chunk-7EXU5SAL.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/client.ts"],"sourcesContent":["import type { DurableObject } from \"cloudflare:workers\";\nimport type { Sandbox } from \"./index\";\n\ninterface ExecuteRequest {\n command: string;\n args?: string[];\n}\n\nexport interface ExecuteResponse {\n success: boolean;\n stdout: string;\n stderr: string;\n exitCode: number;\n command: string;\n args: string[];\n timestamp: string;\n}\n\ninterface SessionResponse {\n sessionId: string;\n message: string;\n timestamp: string;\n}\n\ninterface SessionListResponse {\n sessions: Array<{\n sessionId: string;\n hasActiveProcess: boolean;\n createdAt: string;\n }>;\n count: number;\n timestamp: string;\n}\n\ninterface CommandsResponse {\n availableCommands: string[];\n timestamp: string;\n}\n\ninterface GitCheckoutRequest {\n repoUrl: string;\n branch?: string;\n targetDir?: string;\n sessionId?: string;\n}\n\nexport interface GitCheckoutResponse {\n success: boolean;\n stdout: string;\n stderr: string;\n exitCode: number;\n repoUrl: string;\n branch: string;\n targetDir: string;\n timestamp: string;\n}\n\ninterface MkdirRequest {\n path: string;\n recursive?: boolean;\n sessionId?: string;\n}\n\nexport interface MkdirResponse {\n success: boolean;\n stdout: string;\n stderr: string;\n exitCode: number;\n path: string;\n recursive: boolean;\n timestamp: string;\n}\n\ninterface WriteFileRequest {\n path: string;\n content: string;\n encoding?: string;\n sessionId?: string;\n}\n\nexport interface WriteFileResponse {\n success: boolean;\n exitCode: number;\n path: string;\n timestamp: string;\n}\n\ninterface ReadFileRequest {\n path: string;\n encoding?: string;\n sessionId?: string;\n}\n\nexport interface ReadFileResponse {\n success: boolean;\n exitCode: number;\n path: string;\n content: string;\n timestamp: string;\n}\n\ninterface DeleteFileRequest {\n path: string;\n sessionId?: string;\n}\n\nexport interface DeleteFileResponse {\n success: boolean;\n exitCode: number;\n path: string;\n timestamp: string;\n}\n\ninterface RenameFileRequest {\n oldPath: string;\n newPath: string;\n sessionId?: string;\n}\n\nexport interface RenameFileResponse {\n success: boolean;\n exitCode: number;\n oldPath: string;\n newPath: string;\n timestamp: string;\n}\n\ninterface MoveFileRequest {\n sourcePath: string;\n destinationPath: string;\n sessionId?: string;\n}\n\nexport interface MoveFileResponse {\n success: boolean;\n exitCode: number;\n sourcePath: string;\n destinationPath: string;\n timestamp: string;\n}\n\ninterface PingResponse {\n message: string;\n timestamp: string;\n}\n\ninterface StreamEvent {\n type: \"command_start\" | \"output\" | \"command_complete\" | \"error\";\n command?: string;\n args?: string[];\n stream?: \"stdout\" | \"stderr\";\n data?: string;\n message?: string;\n path?: string;\n oldPath?: string;\n newPath?: string;\n sourcePath?: string;\n destinationPath?: string;\n content?: string;\n success?: boolean;\n exitCode?: number;\n stdout?: string;\n stderr?: string;\n error?: string;\n timestamp?: string;\n}\n\ninterface HttpClientOptions {\n stub?: Sandbox;\n baseUrl?: string;\n port?: number;\n onCommandStart?: (command: string, args: string[]) => void;\n onOutput?: (\n stream: \"stdout\" | \"stderr\",\n data: string,\n command: string\n ) => void;\n onCommandComplete?: (\n success: boolean,\n exitCode: number,\n stdout: string,\n stderr: string,\n command: string,\n args: string[]\n ) => void;\n onError?: (error: string, command?: string, args?: string[]) => void;\n onStreamEvent?: (event: StreamEvent) => void;\n}\n\nexport class HttpClient {\n private baseUrl: string;\n private options: HttpClientOptions;\n private sessionId: string | null = null;\n\n constructor(options: HttpClientOptions = {}) {\n this.options = {\n ...options,\n };\n this.baseUrl = this.options.baseUrl!;\n }\n\n private async doFetch(\n path: string,\n options?: RequestInit\n ): Promise<Response> {\n const url = this.options.stub ? `stub:${path}` : `${this.baseUrl}${path}`;\n const method = options?.method || \"GET\";\n\n console.log(`[HTTP Client] Making ${method} request to ${url}`);\n\n try {\n let response: Response;\n\n if (this.options.stub) {\n response = await this.options.stub.containerFetch(path, options, this.options.port);\n } else {\n response = await fetch(this.baseUrl + path, options);\n }\n\n console.log(`[HTTP Client] Response: ${response.status} ${response.statusText}`);\n\n if (!response.ok) {\n console.error(`[HTTP Client] Request failed: ${method} ${url} - ${response.status} ${response.statusText}`);\n }\n\n return response;\n } catch (error) {\n console.error(`[HTTP Client] Request error: ${method} ${url}`, error);\n throw error;\n }\n }\n // Public methods to set event handlers\n setOnOutput(\n handler: (\n stream: \"stdout\" | \"stderr\",\n data: string,\n command: string\n ) => void\n ): void {\n this.options.onOutput = handler;\n }\n\n setOnCommandComplete(\n handler: (\n success: boolean,\n exitCode: number,\n stdout: string,\n stderr: string,\n command: string,\n args: string[]\n ) => void\n ): void {\n this.options.onCommandComplete = handler;\n }\n\n setOnStreamEvent(handler: (event: StreamEvent) => void): void {\n this.options.onStreamEvent = handler;\n }\n\n // Public getter methods\n getOnOutput():\n | ((stream: \"stdout\" | \"stderr\", data: string, command: string) => void)\n | undefined {\n return this.options.onOutput;\n }\n\n getOnCommandComplete():\n | ((\n success: boolean,\n exitCode: number,\n stdout: string,\n stderr: string,\n command: string,\n args: string[]\n ) => void)\n | undefined {\n return this.options.onCommandComplete;\n }\n\n getOnStreamEvent(): ((event: StreamEvent) => void) | undefined {\n return this.options.onStreamEvent;\n }\n\n async createSession(): Promise<string> {\n try {\n const response = await this.doFetch(`/api/session/create`, {\n headers: {\n \"Content-Type\": \"application/json\",\n },\n method: \"POST\",\n });\n\n if (!response.ok) {\n throw new Error(`HTTP error! status: ${response.status}`);\n }\n\n const data: SessionResponse = await response.json();\n this.sessionId = data.sessionId;\n console.log(`[HTTP Client] Created session: ${this.sessionId}`);\n return this.sessionId;\n } catch (error) {\n console.error(\"[HTTP Client] Error creating session:\", error);\n throw error;\n }\n }\n\n async listSessions(): Promise<SessionListResponse> {\n try {\n const response = await this.doFetch(`/api/session/list`, {\n headers: {\n \"Content-Type\": \"application/json\",\n },\n method: \"GET\",\n });\n\n if (!response.ok) {\n throw new Error(`HTTP error! status: ${response.status}`);\n }\n\n const data: SessionListResponse = await response.json();\n console.log(`[HTTP Client] Listed ${data.count} sessions`);\n return data;\n } catch (error) {\n console.error(\"[HTTP Client] Error listing sessions:\", error);\n throw error;\n }\n }\n\n async execute(\n command: string,\n args: string[] = [],\n sessionId?: string\n ): Promise<ExecuteResponse> {\n try {\n const targetSessionId = sessionId || this.sessionId;\n\n const response = await this.doFetch(`/api/execute`, {\n body: JSON.stringify({\n args,\n command,\n sessionId: targetSessionId,\n }),\n headers: {\n \"Content-Type\": \"application/json\",\n },\n method: \"POST\",\n });\n\n if (!response.ok) {\n const errorData = (await response.json().catch(() => ({}))) as {\n error?: string;\n };\n throw new Error(\n errorData.error || `HTTP error! status: ${response.status}`\n );\n }\n\n const data: ExecuteResponse = await response.json();\n console.log(\n `[HTTP Client] Command executed: ${command}, Success: ${data.success}`\n );\n\n // Call the callback if provided\n this.options.onCommandComplete?.(\n data.success,\n data.exitCode,\n data.stdout,\n data.stderr,\n data.command,\n data.args\n );\n\n return data;\n } catch (error) {\n console.error(\"[HTTP Client] Error executing command:\", error);\n this.options.onError?.(\n error instanceof Error ? error.message : \"Unknown error\",\n command,\n args\n );\n throw error;\n }\n }\n\n async executeStream(\n command: string,\n args: string[] = [],\n sessionId?: string\n ): Promise<void> {\n try {\n const targetSessionId = sessionId || this.sessionId;\n\n const response = await this.doFetch(`/api/execute/stream`, {\n body: JSON.stringify({\n args,\n command,\n sessionId: targetSessionId,\n }),\n headers: {\n \"Content-Type\": \"application/json\",\n },\n method: \"POST\",\n });\n\n if (!response.ok) {\n const errorData = (await response.json().catch(() => ({}))) as {\n error?: string;\n };\n throw new Error(\n errorData.error || `HTTP error! status: ${response.status}`\n );\n }\n\n if (!response.body) {\n throw new Error(\"No response body for streaming request\");\n }\n\n const reader = response.body.getReader();\n const decoder = new TextDecoder();\n\n try {\n while (true) {\n const { done, value } = await reader.read();\n\n if (done) {\n break;\n }\n\n const chunk = decoder.decode(value, { stream: true });\n const lines = chunk.split(\"\\n\");\n\n for (const line of lines) {\n if (line.startsWith(\"data: \")) {\n try {\n const eventData = line.slice(6); // Remove 'data: ' prefix\n const event: StreamEvent = JSON.parse(eventData);\n\n console.log(`[HTTP Client] Stream event: ${event.type}`);\n this.options.onStreamEvent?.(event);\n\n switch (event.type) {\n case \"command_start\":\n console.log(\n `[HTTP Client] Command started: ${\n event.command\n } ${event.args?.join(\" \")}`\n );\n this.options.onCommandStart?.(\n event.command!,\n event.args || []\n );\n break;\n\n case \"output\":\n console.log(`[${event.stream}] ${event.data}`);\n this.options.onOutput?.(\n event.stream!,\n event.data!,\n event.command!\n );\n break;\n\n case \"command_complete\":\n console.log(\n `[HTTP Client] Command completed: ${event.command}, Success: ${event.success}, Exit code: ${event.exitCode}`\n );\n this.options.onCommandComplete?.(\n event.success!,\n event.exitCode!,\n event.stdout!,\n event.stderr!,\n event.command!,\n event.args || []\n );\n break;\n\n case \"error\":\n console.error(\n `[HTTP Client] Command error: ${event.error}`\n );\n this.options.onError?.(\n event.error!,\n event.command,\n event.args\n );\n break;\n }\n } catch (parseError) {\n console.warn(\n \"[HTTP Client] Failed to parse stream event:\",\n parseError\n );\n }\n }\n }\n }\n } finally {\n reader.releaseLock();\n }\n } catch (error) {\n console.error(\"[HTTP Client] Error in streaming execution:\", error);\n this.options.onError?.(\n error instanceof Error ? error.message : \"Unknown error\",\n command,\n args\n );\n throw error;\n }\n }\n\n async gitCheckout(\n repoUrl: string,\n branch: string = \"main\",\n targetDir?: string,\n sessionId?: string\n ): Promise<GitCheckoutResponse> {\n try {\n const targetSessionId = sessionId || this.sessionId;\n\n const response = await this.doFetch(`/api/git/checkout`, {\n body: JSON.stringify({\n branch,\n repoUrl,\n sessionId: targetSessionId,\n targetDir,\n }),\n headers: {\n \"Content-Type\": \"application/json\",\n },\n method: \"POST\",\n });\n\n if (!response.ok) {\n const errorData = (await response.json().catch(() => ({}))) as {\n error?: string;\n };\n throw new Error(\n errorData.error || `HTTP error! status: ${response.status}`\n );\n }\n\n const data: GitCheckoutResponse = await response.json();\n console.log(\n `[HTTP Client] Git checkout completed: ${repoUrl}, Success: ${data.success}, Target: ${data.targetDir}`\n );\n\n return data;\n } catch (error) {\n console.error(\"[HTTP Client] Error in git checkout:\", error);\n throw error;\n }\n }\n\n async gitCheckoutStream(\n repoUrl: string,\n branch: string = \"main\",\n targetDir?: string,\n sessionId?: string\n ): Promise<void> {\n try {\n const targetSessionId = sessionId || this.sessionId;\n\n const response = await this.doFetch(`/api/git/checkout/stream`, {\n body: JSON.stringify({\n branch,\n repoUrl,\n sessionId: targetSessionId,\n targetDir,\n }),\n headers: {\n \"Content-Type\": \"application/json\",\n },\n method: \"POST\",\n });\n\n if (!response.ok) {\n const errorData = (await response.json().catch(() => ({}))) as {\n error?: string;\n };\n throw new Error(\n errorData.error || `HTTP error! status: ${response.status}`\n );\n }\n\n if (!response.body) {\n throw new Error(\"No response body for streaming request\");\n }\n\n const reader = response.body.getReader();\n const decoder = new TextDecoder();\n\n try {\n while (true) {\n const { done, value } = await reader.read();\n\n if (done) {\n break;\n }\n\n const chunk = decoder.decode(value, { stream: true });\n const lines = chunk.split(\"\\n\");\n\n for (const line of lines) {\n if (line.startsWith(\"data: \")) {\n try {\n const eventData = line.slice(6); // Remove 'data: ' prefix\n const event: StreamEvent = JSON.parse(eventData);\n\n console.log(\n `[HTTP Client] Git checkout stream event: ${event.type}`\n );\n this.options.onStreamEvent?.(event);\n\n switch (event.type) {\n case \"command_start\":\n console.log(\n `[HTTP Client] Git checkout started: ${\n event.command\n } ${event.args?.join(\" \")}`\n );\n this.options.onCommandStart?.(\n event.command!,\n event.args || []\n );\n break;\n\n case \"output\":\n console.log(`[${event.stream}] ${event.data}`);\n this.options.onOutput?.(\n event.stream!,\n event.data!,\n event.command!\n );\n break;\n\n case \"command_complete\":\n console.log(\n `[HTTP Client] Git checkout completed: ${event.command}, Success: ${event.success}, Exit code: ${event.exitCode}`\n );\n this.options.onCommandComplete?.(\n event.success!,\n event.exitCode!,\n event.stdout!,\n event.stderr!,\n event.command!,\n event.args || []\n );\n break;\n\n case \"error\":\n console.error(\n `[HTTP Client] Git checkout error: ${event.error}`\n );\n this.options.onError?.(\n event.error!,\n event.command,\n event.args\n );\n break;\n }\n } catch (parseError) {\n console.warn(\n \"[HTTP Client] Failed to parse git checkout stream event:\",\n parseError\n );\n }\n }\n }\n }\n } finally {\n reader.releaseLock();\n }\n } catch (error) {\n console.error(\"[HTTP Client] Error in streaming git checkout:\", error);\n this.options.onError?.(\n error instanceof Error ? error.message : \"Unknown error\",\n \"git clone\",\n [branch, repoUrl, targetDir || \"\"]\n );\n throw error;\n }\n }\n\n async mkdir(\n path: string,\n recursive: boolean = false,\n sessionId?: string\n ): Promise<MkdirResponse> {\n try {\n const targetSessionId = sessionId || this.sessionId;\n\n const response = await this.doFetch(`/api/mkdir`, {\n body: JSON.stringify({\n path,\n recursive,\n sessionId: targetSessionId,\n }),\n headers: {\n \"Content-Type\": \"application/json\",\n },\n method: \"POST\",\n });\n\n if (!response.ok) {\n const errorData = (await response.json().catch(() => ({}))) as {\n error?: string;\n };\n throw new Error(\n errorData.error || `HTTP error! status: ${response.status}`\n );\n }\n\n const data: MkdirResponse = await response.json();\n console.log(\n `[HTTP Client] Directory created: ${path}, Success: ${data.success}, Recursive: ${data.recursive}`\n );\n\n return data;\n } catch (error) {\n console.error(\"[HTTP Client] Error creating directory:\", error);\n throw error;\n }\n }\n\n async mkdirStream(\n path: string,\n recursive: boolean = false,\n sessionId?: string\n ): Promise<void> {\n try {\n const targetSessionId = sessionId || this.sessionId;\n\n const response = await this.doFetch(`/api/mkdir/stream`, {\n body: JSON.stringify({\n path,\n recursive,\n sessionId: targetSessionId,\n }),\n headers: {\n \"Content-Type\": \"application/json\",\n },\n method: \"POST\",\n });\n\n if (!response.ok) {\n const errorData = (await response.json().catch(() => ({}))) as {\n error?: string;\n };\n throw new Error(\n errorData.error || `HTTP error! status: ${response.status}`\n );\n }\n\n if (!response.body) {\n throw new Error(\"No response body for streaming request\");\n }\n\n const reader = response.body.getReader();\n const decoder = new TextDecoder();\n\n try {\n while (true) {\n const { done, value } = await reader.read();\n\n if (done) {\n break;\n }\n\n const chunk = decoder.decode(value, { stream: true });\n const lines = chunk.split(\"\\n\");\n\n for (const line of lines) {\n if (line.startsWith(\"data: \")) {\n try {\n const eventData = line.slice(6); // Remove 'data: ' prefix\n const event: StreamEvent = JSON.parse(eventData);\n\n console.log(`[HTTP Client] Mkdir stream event: ${event.type}`);\n this.options.onStreamEvent?.(event);\n\n switch (event.type) {\n case \"command_start\":\n console.log(\n `[HTTP Client] Mkdir started: ${\n event.command\n } ${event.args?.join(\" \")}`\n );\n this.options.onCommandStart?.(\n event.command!,\n event.args || []\n );\n break;\n\n case \"output\":\n console.log(`[${event.stream}] ${event.data}`);\n this.options.onOutput?.(\n event.stream!,\n event.data!,\n event.command!\n );\n break;\n\n case \"command_complete\":\n console.log(\n `[HTTP Client] Mkdir completed: ${event.command}, Success: ${event.success}, Exit code: ${event.exitCode}`\n );\n this.options.onCommandComplete?.(\n event.success!,\n event.exitCode!,\n event.stdout!,\n event.stderr!,\n event.command!,\n event.args || []\n );\n break;\n\n case \"error\":\n console.error(`[HTTP Client] Mkdir error: ${event.error}`);\n this.options.onError?.(\n event.error!,\n event.command,\n event.args\n );\n break;\n }\n } catch (parseError) {\n console.warn(\n \"[HTTP Client] Failed to parse mkdir stream event:\",\n parseError\n );\n }\n }\n }\n }\n } finally {\n reader.releaseLock();\n }\n } catch (error) {\n console.error(\"[HTTP Client] Error in streaming mkdir:\", error);\n this.options.onError?.(\n error instanceof Error ? error.message : \"Unknown error\",\n \"mkdir\",\n recursive ? [\"-p\", path] : [path]\n );\n throw error;\n }\n }\n\n async writeFile(\n path: string,\n content: string,\n encoding: string = \"utf-8\",\n sessionId?: string\n ): Promise<WriteFileResponse> {\n try {\n const targetSessionId = sessionId || this.sessionId;\n\n const response = await this.doFetch(`/api/write`, {\n body: JSON.stringify({\n content,\n encoding,\n path,\n sessionId: targetSessionId,\n }),\n headers: {\n \"Content-Type\": \"application/json\",\n },\n method: \"POST\",\n });\n\n if (!response.ok) {\n const errorData = (await response.json().catch(() => ({}))) as {\n error?: string;\n };\n throw new Error(\n errorData.error || `HTTP error! status: ${response.status}`\n );\n }\n\n const data: WriteFileResponse = await response.json();\n console.log(\n `[HTTP Client] File written: ${path}, Success: ${data.success}`\n );\n\n return data;\n } catch (error) {\n console.error(\"[HTTP Client] Error writing file:\", error);\n throw error;\n }\n }\n\n async writeFileStream(\n path: string,\n content: string,\n encoding: string = \"utf-8\",\n sessionId?: string\n ): Promise<void> {\n try {\n const targetSessionId = sessionId || this.sessionId;\n\n const response = await this.doFetch(`/api/write/stream`, {\n body: JSON.stringify({\n content,\n encoding,\n path,\n sessionId: targetSessionId,\n }),\n headers: {\n \"Content-Type\": \"application/json\",\n },\n method: \"POST\",\n });\n\n if (!response.ok) {\n const errorData = (await response.json().catch(() => ({}))) as {\n error?: string;\n };\n throw new Error(\n errorData.error || `HTTP error! status: ${response.status}`\n );\n }\n\n if (!response.body) {\n throw new Error(\"No response body for streaming request\");\n }\n\n const reader = response.body.getReader();\n const decoder = new TextDecoder();\n\n try {\n while (true) {\n const { done, value } = await reader.read();\n\n if (done) {\n break;\n }\n\n const chunk = decoder.decode(value, { stream: true });\n const lines = chunk.split(\"\\n\");\n\n for (const line of lines) {\n if (line.startsWith(\"data: \")) {\n try {\n const eventData = line.slice(6); // Remove 'data: ' prefix\n const event: StreamEvent = JSON.parse(eventData);\n\n console.log(\n `[HTTP Client] Write file stream event: ${event.type}`\n );\n this.options.onStreamEvent?.(event);\n\n switch (event.type) {\n case \"command_start\":\n console.log(\n `[HTTP Client] Write file started: ${event.path}`\n );\n this.options.onCommandStart?.(\"write\", [\n path,\n content,\n encoding,\n ]);\n break;\n\n case \"output\":\n console.log(`[output] ${event.message}`);\n this.options.onOutput?.(\"stdout\", event.message!, \"write\");\n break;\n\n case \"command_complete\":\n console.log(\n `[HTTP Client] Write file completed: ${event.path}, Success: ${event.success}`\n );\n this.options.onCommandComplete?.(\n event.success!,\n 0,\n \"\",\n \"\",\n \"write\",\n [path, content, encoding]\n );\n break;\n\n case \"error\":\n console.error(\n `[HTTP Client] Write file error: ${event.error}`\n );\n this.options.onError?.(event.error!, \"write\", [\n path,\n content,\n encoding,\n ]);\n break;\n }\n } catch (parseError) {\n console.warn(\n \"[HTTP Client] Failed to parse write file stream event:\",\n parseError\n );\n }\n }\n }\n }\n } finally {\n reader.releaseLock();\n }\n } catch (error) {\n console.error(\"[HTTP Client] Error in streaming write file:\", error);\n this.options.onError?.(\n error instanceof Error ? error.message : \"Unknown error\",\n \"write\",\n [path, content, encoding]\n );\n throw error;\n }\n }\n\n async readFile(\n path: string,\n encoding: string = \"utf-8\",\n sessionId?: string\n ): Promise<ReadFileResponse> {\n try {\n const targetSessionId = sessionId || this.sessionId;\n\n const response = await this.doFetch(`/api/read`, {\n body: JSON.stringify({\n encoding,\n path,\n sessionId: targetSessionId,\n }),\n headers: {\n \"Content-Type\": \"application/json\",\n },\n method: \"POST\",\n });\n\n if (!response.ok) {\n const errorData = (await response.json().catch(() => ({}))) as {\n error?: string;\n };\n throw new Error(\n errorData.error || `HTTP error! status: ${response.status}`\n );\n }\n\n const data: ReadFileResponse = await response.json();\n console.log(\n `[HTTP Client] File read: ${path}, Success: ${data.success}, Content length: ${data.content.length}`\n );\n\n return data;\n } catch (error) {\n console.error(\"[HTTP Client] Error reading file:\", error);\n throw error;\n }\n }\n\n async readFileStream(\n path: string,\n encoding: string = \"utf-8\",\n sessionId?: string\n ): Promise<void> {\n try {\n const targetSessionId = sessionId || this.sessionId;\n\n const response = await this.doFetch(`/api/read/stream`, {\n body: JSON.stringify({\n encoding,\n path,\n sessionId: targetSessionId,\n }),\n headers: {\n \"Content-Type\": \"application/json\",\n },\n method: \"POST\",\n });\n\n if (!response.ok) {\n const errorData = (await response.json().catch(() => ({}))) as {\n error?: string;\n };\n throw new Error(\n errorData.error || `HTTP error! status: ${response.status}`\n );\n }\n\n if (!response.body) {\n throw new Error(\"No response body for streaming request\");\n }\n\n const reader = response.body.getReader();\n const decoder = new TextDecoder();\n\n try {\n while (true) {\n const { done, value } = await reader.read();\n\n if (done) {\n break;\n }\n\n const chunk = decoder.decode(value, { stream: true });\n const lines = chunk.split(\"\\n\");\n\n for (const line of lines) {\n if (line.startsWith(\"data: \")) {\n try {\n const eventData = line.slice(6); // Remove 'data: ' prefix\n const event: StreamEvent = JSON.parse(eventData);\n\n console.log(\n `[HTTP Client] Read file stream event: ${event.type}`\n );\n this.options.onStreamEvent?.(event);\n\n switch (event.type) {\n case \"command_start\":\n console.log(\n `[HTTP Client] Read file started: ${event.path}`\n );\n this.options.onCommandStart?.(\"read\", [path, encoding]);\n break;\n\n case \"command_complete\":\n console.log(\n `[HTTP Client] Read file completed: ${\n event.path\n }, Success: ${event.success}, Content length: ${\n event.content?.length || 0\n }`\n );\n this.options.onCommandComplete?.(\n event.success!,\n 0,\n event.content || \"\",\n \"\",\n \"read\",\n [path, encoding]\n );\n break;\n\n case \"error\":\n console.error(\n `[HTTP Client] Read file error: ${event.error}`\n );\n this.options.onError?.(event.error!, \"read\", [\n path,\n encoding,\n ]);\n break;\n }\n } catch (parseError) {\n console.warn(\n \"[HTTP Client] Failed to parse read file stream event:\",\n parseError\n );\n }\n }\n }\n }\n } finally {\n reader.releaseLock();\n }\n } catch (error) {\n console.error(\"[HTTP Client] Error in streaming read file:\", error);\n this.options.onError?.(\n error instanceof Error ? error.message : \"Unknown error\",\n \"read\",\n [path, encoding]\n );\n throw error;\n }\n }\n\n async deleteFile(\n path: string,\n sessionId?: string\n ): Promise<DeleteFileResponse> {\n try {\n const targetSessionId = sessionId || this.sessionId;\n\n const response = await this.doFetch(`/api/delete`, {\n body: JSON.stringify({\n path,\n sessionId: targetSessionId,\n }),\n headers: {\n \"Content-Type\": \"application/json\",\n },\n method: \"POST\",\n });\n\n if (!response.ok) {\n const errorData = (await response.json().catch(() => ({}))) as {\n error?: string;\n };\n throw new Error(\n errorData.error || `HTTP error! status: ${response.status}`\n );\n }\n\n const data: DeleteFileResponse = await response.json();\n console.log(\n `[HTTP Client] File deleted: ${path}, Success: ${data.success}`\n );\n\n return data;\n } catch (error) {\n console.error(\"[HTTP Client] Error deleting file:\", error);\n throw error;\n }\n }\n\n async deleteFileStream(path: string, sessionId?: string): Promise<void> {\n try {\n const targetSessionId = sessionId || this.sessionId;\n\n const response = await this.doFetch(`/api/delete/stream`, {\n body: JSON.stringify({\n path,\n sessionId: targetSessionId,\n }),\n headers: {\n \"Content-Type\": \"application/json\",\n },\n method: \"POST\",\n });\n\n if (!response.ok) {\n const errorData = (await response.json().catch(() => ({}))) as {\n error?: string;\n };\n throw new Error(\n errorData.error || `HTTP error! status: ${response.status}`\n );\n }\n\n if (!response.body) {\n throw new Error(\"No response body for streaming request\");\n }\n\n const reader = response.body.getReader();\n const decoder = new TextDecoder();\n\n try {\n while (true) {\n const { done, value } = await reader.read();\n\n if (done) {\n break;\n }\n\n const chunk = decoder.decode(value, { stream: true });\n const lines = chunk.split(\"\\n\");\n\n for (const line of lines) {\n if (line.startsWith(\"data: \")) {\n try {\n const eventData = line.slice(6); // Remove 'data: ' prefix\n const event: StreamEvent = JSON.parse(eventData);\n\n console.log(\n `[HTTP Client] Delete file stream event: ${event.type}`\n );\n this.options.onStreamEvent?.(event);\n\n switch (event.type) {\n case \"command_start\":\n console.log(\n `[HTTP Client] Delete file started: ${event.path}`\n );\n this.options.onCommandStart?.(\"delete\", [path]);\n break;\n\n case \"command_complete\":\n console.log(\n `[HTTP Client] Delete file completed: ${event.path}, Success: ${event.success}`\n );\n this.options.onCommandComplete?.(\n event.success!,\n 0,\n \"\",\n \"\",\n \"delete\",\n [path]\n );\n break;\n\n case \"error\":\n console.error(\n `[HTTP Client] Delete file error: ${event.error}`\n );\n this.options.onError?.(event.error!, \"delete\", [path]);\n break;\n }\n } catch (parseError) {\n console.warn(\n \"[HTTP Client] Failed to parse delete file stream event:\",\n parseError\n );\n }\n }\n }\n }\n } finally {\n reader.releaseLock();\n }\n } catch (error) {\n console.error(\"[HTTP Client] Error in streaming delete file:\", error);\n this.options.onError?.(\n error instanceof Error ? error.message : \"Unknown error\",\n \"delete\",\n [path]\n );\n throw error;\n }\n }\n\n async renameFile(\n oldPath: string,\n newPath: string,\n sessionId?: string\n ): Promise<RenameFileResponse> {\n try {\n const targetSessionId = sessionId || this.sessionId;\n\n const response = await this.doFetch(`/api/rename`, {\n body: JSON.stringify({\n newPath,\n oldPath,\n sessionId: targetSessionId,\n }),\n headers: {\n \"Content-Type\": \"application/json\",\n },\n method: \"POST\",\n });\n\n if (!response.ok) {\n const errorData = (await response.json().catch(() => ({}))) as {\n error?: string;\n };\n throw new Error(\n errorData.error || `HTTP error! status: ${response.status}`\n );\n }\n\n const data: RenameFileResponse = await response.json();\n console.log(\n `[HTTP Client] File renamed: ${oldPath} -> ${newPath}, Success: ${data.success}`\n );\n\n return data;\n } catch (error) {\n console.error(\"[HTTP Client] Error renaming file:\", error);\n throw error;\n }\n }\n\n async renameFileStream(\n oldPath: string,\n newPath: string,\n sessionId?: string\n ): Promise<void> {\n try {\n const targetSessionId = sessionId || this.sessionId;\n\n const response = await this.doFetch(`/api/rename/stream`, {\n body: JSON.stringify({\n newPath,\n oldPath,\n sessionId: targetSessionId,\n }),\n headers: {\n \"Content-Type\": \"application/json\",\n },\n method: \"POST\",\n });\n\n if (!response.ok) {\n const errorData = (await response.json().catch(() => ({}))) as {\n error?: string;\n };\n throw new Error(\n errorData.error || `HTTP error! status: ${response.status}`\n );\n }\n\n if (!response.body) {\n throw new Error(\"No response body for streaming request\");\n }\n\n const reader = response.body.getReader();\n const decoder = new TextDecoder();\n\n try {\n while (true) {\n const { done, value } = await reader.read();\n\n if (done) {\n break;\n }\n\n const chunk = decoder.decode(value, { stream: true });\n const lines = chunk.split(\"\\n\");\n\n for (const line of lines) {\n if (line.startsWith(\"data: \")) {\n try {\n const eventData = line.slice(6); // Remove 'data: ' prefix\n const event: StreamEvent = JSON.parse(eventData);\n\n console.log(\n `[HTTP Client] Rename file stream event: ${event.type}`\n );\n this.options.onStreamEvent?.(event);\n\n switch (event.type) {\n case \"command_start\":\n console.log(\n `[HTTP Client] Rename file started: ${event.oldPath} -> ${event.newPath}`\n );\n this.options.onCommandStart?.(\"rename\", [oldPath, newPath]);\n break;\n\n case \"command_complete\":\n console.log(\n `[HTTP Client] Rename file completed: ${event.oldPath} -> ${event.newPath}, Success: ${event.success}`\n );\n this.options.onCommandComplete?.(\n event.success!,\n 0,\n \"\",\n \"\",\n \"rename\",\n [oldPath, newPath]\n );\n break;\n\n case \"error\":\n console.error(\n `[HTTP Client] Rename file error: ${event.error}`\n );\n this.options.onError?.(event.error!, \"rename\", [\n oldPath,\n newPath,\n ]);\n break;\n }\n } catch (parseError) {\n console.warn(\n \"[HTTP Client] Failed to parse rename file stream event:\",\n parseError\n );\n }\n }\n }\n }\n } finally {\n reader.releaseLock();\n }\n } catch (error) {\n console.error(\"[HTTP Client] Error in streaming rename file:\", error);\n this.options.onError?.(\n error instanceof Error ? error.message : \"Unknown error\",\n \"rename\",\n [oldPath, newPath]\n );\n throw error;\n }\n }\n\n async moveFile(\n sourcePath: string,\n destinationPath: string,\n sessionId?: string\n ): Promise<MoveFileResponse> {\n try {\n const targetSessionId = sessionId || this.sessionId;\n\n const response = await this.doFetch(`/api/move`, {\n body: JSON.stringify({\n destinationPath,\n sessionId: targetSessionId,\n sourcePath,\n }),\n headers: {\n \"Content-Type\": \"application/json\",\n },\n method: \"POST\",\n });\n\n if (!response.ok) {\n const errorData = (await response.json().catch(() => ({}))) as {\n error?: string;\n };\n throw new Error(\n errorData.error || `HTTP error! status: ${response.status}`\n );\n }\n\n const data: MoveFileResponse = await response.json();\n console.log(\n `[HTTP Client] File moved: ${sourcePath} -> ${destinationPath}, Success: ${data.success}`\n );\n\n return data;\n } catch (error) {\n console.error(\"[HTTP Client] Error moving file:\", error);\n throw error;\n }\n }\n\n async moveFileStream(\n sourcePath: string,\n destinationPath: string,\n sessionId?: string\n ): Promise<void> {\n try {\n const targetSessionId = sessionId || this.sessionId;\n\n const response = await this.doFetch(`/api/move/stream`, {\n body: JSON.stringify({\n destinationPath,\n sessionId: targetSessionId,\n sourcePath,\n }),\n headers: {\n \"Content-Type\": \"application/json\",\n },\n method: \"POST\",\n });\n\n if (!response.ok) {\n const errorData = (await response.json().catch(() => ({}))) as {\n error?: string;\n };\n throw new Error(\n errorData.error || `HTTP error! status: ${response.status}`\n );\n }\n\n if (!response.body) {\n throw new Error(\"No response body for streaming request\");\n }\n\n const reader = response.body.getReader();\n const decoder = new TextDecoder();\n\n try {\n while (true) {\n const { done, value } = await reader.read();\n\n if (done) {\n break;\n }\n\n const chunk = decoder.decode(value, { stream: true });\n const lines = chunk.split(\"\\n\");\n\n for (const line of lines) {\n if (line.startsWith(\"data: \")) {\n try {\n const eventData = line.slice(6); // Remove 'data: ' prefix\n const event: StreamEvent = JSON.parse(eventData);\n\n console.log(\n `[HTTP Client] Move file stream event: ${event.type}`\n );\n this.options.onStreamEvent?.(event);\n\n switch (event.type) {\n case \"command_start\":\n console.log(\n `[HTTP Client] Move file started: ${event.sourcePath} -> ${event.destinationPath}`\n );\n this.options.onCommandStart?.(\"move\", [\n sourcePath,\n destinationPath,\n ]);\n break;\n\n case \"command_complete\":\n console.log(\n `[HTTP Client] Move file completed: ${event.sourcePath} -> ${event.destinationPath}, Success: ${event.success}`\n );\n this.options.onCommandComplete?.(\n event.success!,\n 0,\n \"\",\n \"\",\n \"move\",\n [sourcePath, destinationPath]\n );\n break;\n\n case \"error\":\n console.error(\n `[HTTP Client] Move file error: ${event.error}`\n );\n this.options.onError?.(event.error!, \"move\", [\n sourcePath,\n destinationPath,\n ]);\n break;\n }\n } catch (parseError) {\n console.warn(\n \"[HTTP Client] Failed to parse move file stream event:\",\n parseError\n );\n }\n }\n }\n }\n } finally {\n reader.releaseLock();\n }\n } catch (error) {\n console.error(\"[HTTP Client] Error in streaming move file:\", error);\n this.options.onError?.(\n error instanceof Error ? error.message : \"Unknown error\",\n \"move\",\n [sourcePath, destinationPath]\n );\n throw error;\n }\n }\n\n async ping(): Promise<string> {\n try {\n const response = await this.doFetch(`/api/ping`, {\n headers: {\n \"Content-Type\": \"application/json\",\n },\n method: \"GET\",\n });\n\n if (!response.ok) {\n throw new Error(`HTTP error! status: ${response.status}`);\n }\n\n const data: PingResponse = await response.json();\n console.log(`[HTTP Client] Ping response: ${data.message}`);\n return data.timestamp;\n } catch (error) {\n console.error(\"[HTTP Client] Error pinging server:\", error);\n throw error;\n }\n }\n\n async getCommands(): Promise<string[]> {\n try {\n const response = await fetch(`${this.baseUrl}/api/commands`, {\n headers: {\n \"Content-Type\": \"application/json\",\n },\n method: \"GET\",\n });\n\n if (!response.ok) {\n throw new Error(`HTTP error! status: ${response.status}`);\n }\n\n const data: CommandsResponse = await response.json();\n console.log(\n `[HTTP Client] Available commands: ${data.availableCommands.length}`\n );\n return data.availableCommands;\n } catch (error) {\n console.error(\"[HTTP Client] Error getting commands:\", error);\n throw error;\n }\n }\n\n getSessionId(): string | null {\n return this.sessionId;\n }\n\n setSessionId(sessionId: string): void {\n this.sessionId = sessionId;\n }\n\n clearSession(): void {\n this.sessionId = null;\n }\n}\n\n// Example usage and utility functions\nexport function createClient(options?: HttpClientOptions): HttpClient {\n return new HttpClient(options);\n}\n\n// Convenience function for quick command execution\nexport async function quickExecute(\n command: string,\n args: string[] = [],\n options?: HttpClientOptions\n): Promise<ExecuteResponse> {\n const client = createClient(options);\n await client.createSession();\n\n try {\n return await client.execute(command, args);\n } finally {\n client.clearSession();\n }\n}\n\n// Convenience function for quick streaming command execution\nexport async function quickExecuteStream(\n command: string,\n args: string[] = [],\n options?: HttpClientOptions\n): Promise<void> {\n const client = createClient(options);\n await client.createSession();\n\n try {\n await client.executeStream(command, args);\n } finally {\n client.clearSession();\n }\n}\n\n// Convenience function for quick git checkout\nexport async function quickGitCheckout(\n repoUrl: string,\n branch: string = \"main\",\n targetDir?: string,\n options?: HttpClientOptions\n): Promise<GitCheckoutResponse> {\n const client = createClient(options);\n await client.createSession();\n\n try {\n return await client.gitCheckout(repoUrl, branch, targetDir);\n } finally {\n client.clearSession();\n }\n}\n\n// Convenience function for quick directory creation\nexport async function quickMkdir(\n path: string,\n recursive: boolean = false,\n options?: HttpClientOptions\n): Promise<MkdirResponse> {\n const client = createClient(options);\n await client.createSession();\n\n try {\n return await client.mkdir(path, recursive);\n } finally {\n client.clearSession();\n }\n}\n\n// Convenience function for quick streaming git checkout\nexport async function quickGitCheckoutStream(\n repoUrl: string,\n branch: string = \"main\",\n targetDir?: string,\n options?: HttpClientOptions\n): Promise<void> {\n const client = createClient(options);\n await client.createSession();\n\n try {\n await client.gitCheckoutStream(repoUrl, branch, targetDir);\n } finally {\n client.clearSession();\n }\n}\n\n// Convenience function for quick streaming directory creation\nexport async function quickMkdirStream(\n path: string,\n recursive: boolean = false,\n options?: HttpClientOptions\n): Promise<void> {\n const client = createClient(options);\n await client.createSession();\n\n try {\n await client.mkdirStream(path, recursive);\n } finally {\n client.clearSession();\n }\n}\n\n// Convenience function for quick file writing\nexport async function quickWriteFile(\n path: string,\n content: string,\n encoding: string = \"utf-8\",\n options?: HttpClientOptions\n): Promise<WriteFileResponse> {\n const client = createClient(options);\n await client.createSession();\n\n try {\n return await client.writeFile(path, content, encoding);\n } finally {\n client.clearSession();\n }\n}\n\n// Convenience function for quick streaming file writing\nexport async function quickWriteFileStream(\n path: string,\n content: string,\n encoding: string = \"utf-8\",\n options?: HttpClientOptions\n): Promise<void> {\n const client = createClient(options);\n await client.createSession();\n\n try {\n await client.writeFileStream(path, content, encoding);\n } finally {\n client.clearSession();\n }\n}\n\n// Convenience function for quick file reading\nexport async function quickReadFile(\n path: string,\n encoding: string = \"utf-8\",\n options?: HttpClientOptions\n): Promise<ReadFileResponse> {\n const client = createClient(options);\n await client.createSession();\n\n try {\n return await client.readFile(path, encoding);\n } finally {\n client.clearSession();\n }\n}\n\n// Convenience function for quick streaming file reading\nexport async function quickReadFileStream(\n path: string,\n encoding: string = \"utf-8\",\n options?: HttpClientOptions\n): Promise<void> {\n const client = createClient(options);\n await client.createSession();\n\n try {\n await client.readFileStream(path, encoding);\n } finally {\n client.clearSession();\n }\n}\n\n// Convenience function for quick file deletion\nexport async function quickDeleteFile(\n path: string,\n options?: HttpClientOptions\n): Promise<DeleteFileResponse> {\n const client = createClient(options);\n await client.createSession();\n\n try {\n return await client.deleteFile(path);\n } finally {\n client.clearSession();\n }\n}\n\n// Convenience function for quick streaming file deletion\nexport async function quickDeleteFileStream(\n path: string,\n options?: HttpClientOptions\n): Promise<void> {\n const client = createClient(options);\n await client.createSession();\n\n try {\n await client.deleteFileStream(path);\n } finally {\n client.clearSession();\n }\n}\n\n// Convenience function for quick file renaming\nexport async function quickRenameFile(\n oldPath: string,\n newPath: string,\n options?: HttpClientOptions\n): Promise<RenameFileResponse> {\n const client = createClient(options);\n await client.createSession();\n\n try {\n return await client.renameFile(oldPath, newPath);\n } finally {\n client.clearSession();\n }\n}\n\n// Convenience function for quick streaming file renaming\nexport async function quickRenameFileStream(\n oldPath: string,\n newPath: string,\n options?: HttpClientOptions\n): Promise<void> {\n const client = createClient(options);\n await client.createSession();\n\n try {\n await client.renameFileStream(oldPath, newPath);\n } finally {\n client.clearSession();\n }\n}\n\n// Convenience function for quick file moving\nexport async function quickMoveFile(\n sourcePath: string,\n destinationPath: string,\n options?: HttpClientOptions\n): Promise<MoveFileResponse> {\n const client = createClient(options);\n await client.createSession();\n\n try {\n return await client.moveFile(sourcePath, destinationPath);\n } finally {\n client.clearSession();\n }\n}\n\n// Convenience function for quick streaming file moving\nexport async function quickMoveFileStream(\n sourcePath: string,\n destinationPath: string,\n options?: HttpClientOptions\n): Promise<void> {\n const client = createClient(options);\n await client.createSession();\n\n try {\n await client.moveFileStream(sourcePath, destinationPath);\n } finally {\n client.clearSession();\n }\n}\n"],"mappings":"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","names":[]}
|
package/dist/client.js
CHANGED
package/dist/index.js
CHANGED
package/package.json
CHANGED
|
@@ -1,13 +1,13 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@cloudflare/sandbox",
|
|
3
|
-
"version": "0.0.
|
|
3
|
+
"version": "0.0.5",
|
|
4
4
|
"repository": {
|
|
5
5
|
"type": "git",
|
|
6
6
|
"url": "https://github.com/cloudflare/sandbox-sdk"
|
|
7
7
|
},
|
|
8
8
|
"description": "A sandboxed environment for running commands",
|
|
9
9
|
"dependencies": {
|
|
10
|
-
"@cloudflare/containers": "^0.0.
|
|
10
|
+
"@cloudflare/containers": "^0.0.13"
|
|
11
11
|
},
|
|
12
12
|
"tags": [
|
|
13
13
|
"sandbox",
|
|
@@ -17,7 +17,9 @@
|
|
|
17
17
|
"durable objects"
|
|
18
18
|
],
|
|
19
19
|
"scripts": {
|
|
20
|
-
"build": "tsup src/*.ts --outDir dist --dts --sourcemap --format esm"
|
|
20
|
+
"build": "rm -rf dist && tsup src/*.ts --outDir dist --dts --sourcemap --format esm",
|
|
21
|
+
"docker:build": "docker build -t ghostwriternr/cloudflare-sandbox:$npm_package_version .",
|
|
22
|
+
"docker:publish": "docker push docker.io/ghostwriternr/cloudflare-sandbox:$npm_package_version"
|
|
21
23
|
},
|
|
22
24
|
"exports": {
|
|
23
25
|
".": {
|
package/src/client.ts
CHANGED
|
@@ -203,10 +203,31 @@ export class HttpClient {
|
|
|
203
203
|
path: string,
|
|
204
204
|
options?: RequestInit
|
|
205
205
|
): Promise<Response> {
|
|
206
|
-
|
|
207
|
-
|
|
206
|
+
const url = this.options.stub ? `stub:${path}` : `${this.baseUrl}${path}`;
|
|
207
|
+
const method = options?.method || "GET";
|
|
208
|
+
|
|
209
|
+
console.log(`[HTTP Client] Making ${method} request to ${url}`);
|
|
210
|
+
|
|
211
|
+
try {
|
|
212
|
+
let response: Response;
|
|
213
|
+
|
|
214
|
+
if (this.options.stub) {
|
|
215
|
+
response = await this.options.stub.containerFetch(path, options, this.options.port);
|
|
216
|
+
} else {
|
|
217
|
+
response = await fetch(this.baseUrl + path, options);
|
|
218
|
+
}
|
|
219
|
+
|
|
220
|
+
console.log(`[HTTP Client] Response: ${response.status} ${response.statusText}`);
|
|
221
|
+
|
|
222
|
+
if (!response.ok) {
|
|
223
|
+
console.error(`[HTTP Client] Request failed: ${method} ${url} - ${response.status} ${response.statusText}`);
|
|
224
|
+
}
|
|
225
|
+
|
|
226
|
+
return response;
|
|
227
|
+
} catch (error) {
|
|
228
|
+
console.error(`[HTTP Client] Request error: ${method} ${url}`, error);
|
|
229
|
+
throw error;
|
|
208
230
|
}
|
|
209
|
-
return fetch(this.baseUrl + path, options);
|
|
210
231
|
}
|
|
211
232
|
// Public methods to set event handlers
|
|
212
233
|
setOnOutput(
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/client.ts"],"sourcesContent":["import type { DurableObject } from \"cloudflare:workers\";\nimport type { Sandbox } from \"./index\";\n\ninterface ExecuteRequest {\n command: string;\n args?: string[];\n}\n\nexport interface ExecuteResponse {\n success: boolean;\n stdout: string;\n stderr: string;\n exitCode: number;\n command: string;\n args: string[];\n timestamp: string;\n}\n\ninterface SessionResponse {\n sessionId: string;\n message: string;\n timestamp: string;\n}\n\ninterface SessionListResponse {\n sessions: Array<{\n sessionId: string;\n hasActiveProcess: boolean;\n createdAt: string;\n }>;\n count: number;\n timestamp: string;\n}\n\ninterface CommandsResponse {\n availableCommands: string[];\n timestamp: string;\n}\n\ninterface GitCheckoutRequest {\n repoUrl: string;\n branch?: string;\n targetDir?: string;\n sessionId?: string;\n}\n\nexport interface GitCheckoutResponse {\n success: boolean;\n stdout: string;\n stderr: string;\n exitCode: number;\n repoUrl: string;\n branch: string;\n targetDir: string;\n timestamp: string;\n}\n\ninterface MkdirRequest {\n path: string;\n recursive?: boolean;\n sessionId?: string;\n}\n\nexport interface MkdirResponse {\n success: boolean;\n stdout: string;\n stderr: string;\n exitCode: number;\n path: string;\n recursive: boolean;\n timestamp: string;\n}\n\ninterface WriteFileRequest {\n path: string;\n content: string;\n encoding?: string;\n sessionId?: string;\n}\n\nexport interface WriteFileResponse {\n success: boolean;\n exitCode: number;\n path: string;\n timestamp: string;\n}\n\ninterface ReadFileRequest {\n path: string;\n encoding?: string;\n sessionId?: string;\n}\n\nexport interface ReadFileResponse {\n success: boolean;\n exitCode: number;\n path: string;\n content: string;\n timestamp: string;\n}\n\ninterface DeleteFileRequest {\n path: string;\n sessionId?: string;\n}\n\nexport interface DeleteFileResponse {\n success: boolean;\n exitCode: number;\n path: string;\n timestamp: string;\n}\n\ninterface RenameFileRequest {\n oldPath: string;\n newPath: string;\n sessionId?: string;\n}\n\nexport interface RenameFileResponse {\n success: boolean;\n exitCode: number;\n oldPath: string;\n newPath: string;\n timestamp: string;\n}\n\ninterface MoveFileRequest {\n sourcePath: string;\n destinationPath: string;\n sessionId?: string;\n}\n\nexport interface MoveFileResponse {\n success: boolean;\n exitCode: number;\n sourcePath: string;\n destinationPath: string;\n timestamp: string;\n}\n\ninterface PingResponse {\n message: string;\n timestamp: string;\n}\n\ninterface StreamEvent {\n type: \"command_start\" | \"output\" | \"command_complete\" | \"error\";\n command?: string;\n args?: string[];\n stream?: \"stdout\" | \"stderr\";\n data?: string;\n message?: string;\n path?: string;\n oldPath?: string;\n newPath?: string;\n sourcePath?: string;\n destinationPath?: string;\n content?: string;\n success?: boolean;\n exitCode?: number;\n stdout?: string;\n stderr?: string;\n error?: string;\n timestamp?: string;\n}\n\ninterface HttpClientOptions {\n stub?: Sandbox;\n baseUrl?: string;\n port?: number;\n onCommandStart?: (command: string, args: string[]) => void;\n onOutput?: (\n stream: \"stdout\" | \"stderr\",\n data: string,\n command: string\n ) => void;\n onCommandComplete?: (\n success: boolean,\n exitCode: number,\n stdout: string,\n stderr: string,\n command: string,\n args: string[]\n ) => void;\n onError?: (error: string, command?: string, args?: string[]) => void;\n onStreamEvent?: (event: StreamEvent) => void;\n}\n\nexport class HttpClient {\n private baseUrl: string;\n private options: HttpClientOptions;\n private sessionId: string | null = null;\n\n constructor(options: HttpClientOptions = {}) {\n this.options = {\n ...options,\n };\n this.baseUrl = this.options.baseUrl!;\n }\n\n private async doFetch(\n path: string,\n options?: RequestInit\n ): Promise<Response> {\n if (this.options.stub) {\n return this.options.stub.containerFetch(path, options, this.options.port);\n }\n return fetch(this.baseUrl + path, options);\n }\n // Public methods to set event handlers\n setOnOutput(\n handler: (\n stream: \"stdout\" | \"stderr\",\n data: string,\n command: string\n ) => void\n ): void {\n this.options.onOutput = handler;\n }\n\n setOnCommandComplete(\n handler: (\n success: boolean,\n exitCode: number,\n stdout: string,\n stderr: string,\n command: string,\n args: string[]\n ) => void\n ): void {\n this.options.onCommandComplete = handler;\n }\n\n setOnStreamEvent(handler: (event: StreamEvent) => void): void {\n this.options.onStreamEvent = handler;\n }\n\n // Public getter methods\n getOnOutput():\n | ((stream: \"stdout\" | \"stderr\", data: string, command: string) => void)\n | undefined {\n return this.options.onOutput;\n }\n\n getOnCommandComplete():\n | ((\n success: boolean,\n exitCode: number,\n stdout: string,\n stderr: string,\n command: string,\n args: string[]\n ) => void)\n | undefined {\n return this.options.onCommandComplete;\n }\n\n getOnStreamEvent(): ((event: StreamEvent) => void) | undefined {\n return this.options.onStreamEvent;\n }\n\n async createSession(): Promise<string> {\n try {\n const response = await this.doFetch(`/api/session/create`, {\n headers: {\n \"Content-Type\": \"application/json\",\n },\n method: \"POST\",\n });\n\n if (!response.ok) {\n throw new Error(`HTTP error! status: ${response.status}`);\n }\n\n const data: SessionResponse = await response.json();\n this.sessionId = data.sessionId;\n console.log(`[HTTP Client] Created session: ${this.sessionId}`);\n return this.sessionId;\n } catch (error) {\n console.error(\"[HTTP Client] Error creating session:\", error);\n throw error;\n }\n }\n\n async listSessions(): Promise<SessionListResponse> {\n try {\n const response = await this.doFetch(`/api/session/list`, {\n headers: {\n \"Content-Type\": \"application/json\",\n },\n method: \"GET\",\n });\n\n if (!response.ok) {\n throw new Error(`HTTP error! status: ${response.status}`);\n }\n\n const data: SessionListResponse = await response.json();\n console.log(`[HTTP Client] Listed ${data.count} sessions`);\n return data;\n } catch (error) {\n console.error(\"[HTTP Client] Error listing sessions:\", error);\n throw error;\n }\n }\n\n async execute(\n command: string,\n args: string[] = [],\n sessionId?: string\n ): Promise<ExecuteResponse> {\n try {\n const targetSessionId = sessionId || this.sessionId;\n\n const response = await this.doFetch(`/api/execute`, {\n body: JSON.stringify({\n args,\n command,\n sessionId: targetSessionId,\n }),\n headers: {\n \"Content-Type\": \"application/json\",\n },\n method: \"POST\",\n });\n\n if (!response.ok) {\n const errorData = (await response.json().catch(() => ({}))) as {\n error?: string;\n };\n throw new Error(\n errorData.error || `HTTP error! status: ${response.status}`\n );\n }\n\n const data: ExecuteResponse = await response.json();\n console.log(\n `[HTTP Client] Command executed: ${command}, Success: ${data.success}`\n );\n\n // Call the callback if provided\n this.options.onCommandComplete?.(\n data.success,\n data.exitCode,\n data.stdout,\n data.stderr,\n data.command,\n data.args\n );\n\n return data;\n } catch (error) {\n console.error(\"[HTTP Client] Error executing command:\", error);\n this.options.onError?.(\n error instanceof Error ? error.message : \"Unknown error\",\n command,\n args\n );\n throw error;\n }\n }\n\n async executeStream(\n command: string,\n args: string[] = [],\n sessionId?: string\n ): Promise<void> {\n try {\n const targetSessionId = sessionId || this.sessionId;\n\n const response = await this.doFetch(`/api/execute/stream`, {\n body: JSON.stringify({\n args,\n command,\n sessionId: targetSessionId,\n }),\n headers: {\n \"Content-Type\": \"application/json\",\n },\n method: \"POST\",\n });\n\n if (!response.ok) {\n const errorData = (await response.json().catch(() => ({}))) as {\n error?: string;\n };\n throw new Error(\n errorData.error || `HTTP error! status: ${response.status}`\n );\n }\n\n if (!response.body) {\n throw new Error(\"No response body for streaming request\");\n }\n\n const reader = response.body.getReader();\n const decoder = new TextDecoder();\n\n try {\n while (true) {\n const { done, value } = await reader.read();\n\n if (done) {\n break;\n }\n\n const chunk = decoder.decode(value, { stream: true });\n const lines = chunk.split(\"\\n\");\n\n for (const line of lines) {\n if (line.startsWith(\"data: \")) {\n try {\n const eventData = line.slice(6); // Remove 'data: ' prefix\n const event: StreamEvent = JSON.parse(eventData);\n\n console.log(`[HTTP Client] Stream event: ${event.type}`);\n this.options.onStreamEvent?.(event);\n\n switch (event.type) {\n case \"command_start\":\n console.log(\n `[HTTP Client] Command started: ${\n event.command\n } ${event.args?.join(\" \")}`\n );\n this.options.onCommandStart?.(\n event.command!,\n event.args || []\n );\n break;\n\n case \"output\":\n console.log(`[${event.stream}] ${event.data}`);\n this.options.onOutput?.(\n event.stream!,\n event.data!,\n event.command!\n );\n break;\n\n case \"command_complete\":\n console.log(\n `[HTTP Client] Command completed: ${event.command}, Success: ${event.success}, Exit code: ${event.exitCode}`\n );\n this.options.onCommandComplete?.(\n event.success!,\n event.exitCode!,\n event.stdout!,\n event.stderr!,\n event.command!,\n event.args || []\n );\n break;\n\n case \"error\":\n console.error(\n `[HTTP Client] Command error: ${event.error}`\n );\n this.options.onError?.(\n event.error!,\n event.command,\n event.args\n );\n break;\n }\n } catch (parseError) {\n console.warn(\n \"[HTTP Client] Failed to parse stream event:\",\n parseError\n );\n }\n }\n }\n }\n } finally {\n reader.releaseLock();\n }\n } catch (error) {\n console.error(\"[HTTP Client] Error in streaming execution:\", error);\n this.options.onError?.(\n error instanceof Error ? error.message : \"Unknown error\",\n command,\n args\n );\n throw error;\n }\n }\n\n async gitCheckout(\n repoUrl: string,\n branch: string = \"main\",\n targetDir?: string,\n sessionId?: string\n ): Promise<GitCheckoutResponse> {\n try {\n const targetSessionId = sessionId || this.sessionId;\n\n const response = await this.doFetch(`/api/git/checkout`, {\n body: JSON.stringify({\n branch,\n repoUrl,\n sessionId: targetSessionId,\n targetDir,\n }),\n headers: {\n \"Content-Type\": \"application/json\",\n },\n method: \"POST\",\n });\n\n if (!response.ok) {\n const errorData = (await response.json().catch(() => ({}))) as {\n error?: string;\n };\n throw new Error(\n errorData.error || `HTTP error! status: ${response.status}`\n );\n }\n\n const data: GitCheckoutResponse = await response.json();\n console.log(\n `[HTTP Client] Git checkout completed: ${repoUrl}, Success: ${data.success}, Target: ${data.targetDir}`\n );\n\n return data;\n } catch (error) {\n console.error(\"[HTTP Client] Error in git checkout:\", error);\n throw error;\n }\n }\n\n async gitCheckoutStream(\n repoUrl: string,\n branch: string = \"main\",\n targetDir?: string,\n sessionId?: string\n ): Promise<void> {\n try {\n const targetSessionId = sessionId || this.sessionId;\n\n const response = await this.doFetch(`/api/git/checkout/stream`, {\n body: JSON.stringify({\n branch,\n repoUrl,\n sessionId: targetSessionId,\n targetDir,\n }),\n headers: {\n \"Content-Type\": \"application/json\",\n },\n method: \"POST\",\n });\n\n if (!response.ok) {\n const errorData = (await response.json().catch(() => ({}))) as {\n error?: string;\n };\n throw new Error(\n errorData.error || `HTTP error! status: ${response.status}`\n );\n }\n\n if (!response.body) {\n throw new Error(\"No response body for streaming request\");\n }\n\n const reader = response.body.getReader();\n const decoder = new TextDecoder();\n\n try {\n while (true) {\n const { done, value } = await reader.read();\n\n if (done) {\n break;\n }\n\n const chunk = decoder.decode(value, { stream: true });\n const lines = chunk.split(\"\\n\");\n\n for (const line of lines) {\n if (line.startsWith(\"data: \")) {\n try {\n const eventData = line.slice(6); // Remove 'data: ' prefix\n const event: StreamEvent = JSON.parse(eventData);\n\n console.log(\n `[HTTP Client] Git checkout stream event: ${event.type}`\n );\n this.options.onStreamEvent?.(event);\n\n switch (event.type) {\n case \"command_start\":\n console.log(\n `[HTTP Client] Git checkout started: ${\n event.command\n } ${event.args?.join(\" \")}`\n );\n this.options.onCommandStart?.(\n event.command!,\n event.args || []\n );\n break;\n\n case \"output\":\n console.log(`[${event.stream}] ${event.data}`);\n this.options.onOutput?.(\n event.stream!,\n event.data!,\n event.command!\n );\n break;\n\n case \"command_complete\":\n console.log(\n `[HTTP Client] Git checkout completed: ${event.command}, Success: ${event.success}, Exit code: ${event.exitCode}`\n );\n this.options.onCommandComplete?.(\n event.success!,\n event.exitCode!,\n event.stdout!,\n event.stderr!,\n event.command!,\n event.args || []\n );\n break;\n\n case \"error\":\n console.error(\n `[HTTP Client] Git checkout error: ${event.error}`\n );\n this.options.onError?.(\n event.error!,\n event.command,\n event.args\n );\n break;\n }\n } catch (parseError) {\n console.warn(\n \"[HTTP Client] Failed to parse git checkout stream event:\",\n parseError\n );\n }\n }\n }\n }\n } finally {\n reader.releaseLock();\n }\n } catch (error) {\n console.error(\"[HTTP Client] Error in streaming git checkout:\", error);\n this.options.onError?.(\n error instanceof Error ? error.message : \"Unknown error\",\n \"git clone\",\n [branch, repoUrl, targetDir || \"\"]\n );\n throw error;\n }\n }\n\n async mkdir(\n path: string,\n recursive: boolean = false,\n sessionId?: string\n ): Promise<MkdirResponse> {\n try {\n const targetSessionId = sessionId || this.sessionId;\n\n const response = await this.doFetch(`/api/mkdir`, {\n body: JSON.stringify({\n path,\n recursive,\n sessionId: targetSessionId,\n }),\n headers: {\n \"Content-Type\": \"application/json\",\n },\n method: \"POST\",\n });\n\n if (!response.ok) {\n const errorData = (await response.json().catch(() => ({}))) as {\n error?: string;\n };\n throw new Error(\n errorData.error || `HTTP error! status: ${response.status}`\n );\n }\n\n const data: MkdirResponse = await response.json();\n console.log(\n `[HTTP Client] Directory created: ${path}, Success: ${data.success}, Recursive: ${data.recursive}`\n );\n\n return data;\n } catch (error) {\n console.error(\"[HTTP Client] Error creating directory:\", error);\n throw error;\n }\n }\n\n async mkdirStream(\n path: string,\n recursive: boolean = false,\n sessionId?: string\n ): Promise<void> {\n try {\n const targetSessionId = sessionId || this.sessionId;\n\n const response = await this.doFetch(`/api/mkdir/stream`, {\n body: JSON.stringify({\n path,\n recursive,\n sessionId: targetSessionId,\n }),\n headers: {\n \"Content-Type\": \"application/json\",\n },\n method: \"POST\",\n });\n\n if (!response.ok) {\n const errorData = (await response.json().catch(() => ({}))) as {\n error?: string;\n };\n throw new Error(\n errorData.error || `HTTP error! status: ${response.status}`\n );\n }\n\n if (!response.body) {\n throw new Error(\"No response body for streaming request\");\n }\n\n const reader = response.body.getReader();\n const decoder = new TextDecoder();\n\n try {\n while (true) {\n const { done, value } = await reader.read();\n\n if (done) {\n break;\n }\n\n const chunk = decoder.decode(value, { stream: true });\n const lines = chunk.split(\"\\n\");\n\n for (const line of lines) {\n if (line.startsWith(\"data: \")) {\n try {\n const eventData = line.slice(6); // Remove 'data: ' prefix\n const event: StreamEvent = JSON.parse(eventData);\n\n console.log(`[HTTP Client] Mkdir stream event: ${event.type}`);\n this.options.onStreamEvent?.(event);\n\n switch (event.type) {\n case \"command_start\":\n console.log(\n `[HTTP Client] Mkdir started: ${\n event.command\n } ${event.args?.join(\" \")}`\n );\n this.options.onCommandStart?.(\n event.command!,\n event.args || []\n );\n break;\n\n case \"output\":\n console.log(`[${event.stream}] ${event.data}`);\n this.options.onOutput?.(\n event.stream!,\n event.data!,\n event.command!\n );\n break;\n\n case \"command_complete\":\n console.log(\n `[HTTP Client] Mkdir completed: ${event.command}, Success: ${event.success}, Exit code: ${event.exitCode}`\n );\n this.options.onCommandComplete?.(\n event.success!,\n event.exitCode!,\n event.stdout!,\n event.stderr!,\n event.command!,\n event.args || []\n );\n break;\n\n case \"error\":\n console.error(`[HTTP Client] Mkdir error: ${event.error}`);\n this.options.onError?.(\n event.error!,\n event.command,\n event.args\n );\n break;\n }\n } catch (parseError) {\n console.warn(\n \"[HTTP Client] Failed to parse mkdir stream event:\",\n parseError\n );\n }\n }\n }\n }\n } finally {\n reader.releaseLock();\n }\n } catch (error) {\n console.error(\"[HTTP Client] Error in streaming mkdir:\", error);\n this.options.onError?.(\n error instanceof Error ? error.message : \"Unknown error\",\n \"mkdir\",\n recursive ? [\"-p\", path] : [path]\n );\n throw error;\n }\n }\n\n async writeFile(\n path: string,\n content: string,\n encoding: string = \"utf-8\",\n sessionId?: string\n ): Promise<WriteFileResponse> {\n try {\n const targetSessionId = sessionId || this.sessionId;\n\n const response = await this.doFetch(`/api/write`, {\n body: JSON.stringify({\n content,\n encoding,\n path,\n sessionId: targetSessionId,\n }),\n headers: {\n \"Content-Type\": \"application/json\",\n },\n method: \"POST\",\n });\n\n if (!response.ok) {\n const errorData = (await response.json().catch(() => ({}))) as {\n error?: string;\n };\n throw new Error(\n errorData.error || `HTTP error! status: ${response.status}`\n );\n }\n\n const data: WriteFileResponse = await response.json();\n console.log(\n `[HTTP Client] File written: ${path}, Success: ${data.success}`\n );\n\n return data;\n } catch (error) {\n console.error(\"[HTTP Client] Error writing file:\", error);\n throw error;\n }\n }\n\n async writeFileStream(\n path: string,\n content: string,\n encoding: string = \"utf-8\",\n sessionId?: string\n ): Promise<void> {\n try {\n const targetSessionId = sessionId || this.sessionId;\n\n const response = await this.doFetch(`/api/write/stream`, {\n body: JSON.stringify({\n content,\n encoding,\n path,\n sessionId: targetSessionId,\n }),\n headers: {\n \"Content-Type\": \"application/json\",\n },\n method: \"POST\",\n });\n\n if (!response.ok) {\n const errorData = (await response.json().catch(() => ({}))) as {\n error?: string;\n };\n throw new Error(\n errorData.error || `HTTP error! status: ${response.status}`\n );\n }\n\n if (!response.body) {\n throw new Error(\"No response body for streaming request\");\n }\n\n const reader = response.body.getReader();\n const decoder = new TextDecoder();\n\n try {\n while (true) {\n const { done, value } = await reader.read();\n\n if (done) {\n break;\n }\n\n const chunk = decoder.decode(value, { stream: true });\n const lines = chunk.split(\"\\n\");\n\n for (const line of lines) {\n if (line.startsWith(\"data: \")) {\n try {\n const eventData = line.slice(6); // Remove 'data: ' prefix\n const event: StreamEvent = JSON.parse(eventData);\n\n console.log(\n `[HTTP Client] Write file stream event: ${event.type}`\n );\n this.options.onStreamEvent?.(event);\n\n switch (event.type) {\n case \"command_start\":\n console.log(\n `[HTTP Client] Write file started: ${event.path}`\n );\n this.options.onCommandStart?.(\"write\", [\n path,\n content,\n encoding,\n ]);\n break;\n\n case \"output\":\n console.log(`[output] ${event.message}`);\n this.options.onOutput?.(\"stdout\", event.message!, \"write\");\n break;\n\n case \"command_complete\":\n console.log(\n `[HTTP Client] Write file completed: ${event.path}, Success: ${event.success}`\n );\n this.options.onCommandComplete?.(\n event.success!,\n 0,\n \"\",\n \"\",\n \"write\",\n [path, content, encoding]\n );\n break;\n\n case \"error\":\n console.error(\n `[HTTP Client] Write file error: ${event.error}`\n );\n this.options.onError?.(event.error!, \"write\", [\n path,\n content,\n encoding,\n ]);\n break;\n }\n } catch (parseError) {\n console.warn(\n \"[HTTP Client] Failed to parse write file stream event:\",\n parseError\n );\n }\n }\n }\n }\n } finally {\n reader.releaseLock();\n }\n } catch (error) {\n console.error(\"[HTTP Client] Error in streaming write file:\", error);\n this.options.onError?.(\n error instanceof Error ? error.message : \"Unknown error\",\n \"write\",\n [path, content, encoding]\n );\n throw error;\n }\n }\n\n async readFile(\n path: string,\n encoding: string = \"utf-8\",\n sessionId?: string\n ): Promise<ReadFileResponse> {\n try {\n const targetSessionId = sessionId || this.sessionId;\n\n const response = await this.doFetch(`/api/read`, {\n body: JSON.stringify({\n encoding,\n path,\n sessionId: targetSessionId,\n }),\n headers: {\n \"Content-Type\": \"application/json\",\n },\n method: \"POST\",\n });\n\n if (!response.ok) {\n const errorData = (await response.json().catch(() => ({}))) as {\n error?: string;\n };\n throw new Error(\n errorData.error || `HTTP error! status: ${response.status}`\n );\n }\n\n const data: ReadFileResponse = await response.json();\n console.log(\n `[HTTP Client] File read: ${path}, Success: ${data.success}, Content length: ${data.content.length}`\n );\n\n return data;\n } catch (error) {\n console.error(\"[HTTP Client] Error reading file:\", error);\n throw error;\n }\n }\n\n async readFileStream(\n path: string,\n encoding: string = \"utf-8\",\n sessionId?: string\n ): Promise<void> {\n try {\n const targetSessionId = sessionId || this.sessionId;\n\n const response = await this.doFetch(`/api/read/stream`, {\n body: JSON.stringify({\n encoding,\n path,\n sessionId: targetSessionId,\n }),\n headers: {\n \"Content-Type\": \"application/json\",\n },\n method: \"POST\",\n });\n\n if (!response.ok) {\n const errorData = (await response.json().catch(() => ({}))) as {\n error?: string;\n };\n throw new Error(\n errorData.error || `HTTP error! status: ${response.status}`\n );\n }\n\n if (!response.body) {\n throw new Error(\"No response body for streaming request\");\n }\n\n const reader = response.body.getReader();\n const decoder = new TextDecoder();\n\n try {\n while (true) {\n const { done, value } = await reader.read();\n\n if (done) {\n break;\n }\n\n const chunk = decoder.decode(value, { stream: true });\n const lines = chunk.split(\"\\n\");\n\n for (const line of lines) {\n if (line.startsWith(\"data: \")) {\n try {\n const eventData = line.slice(6); // Remove 'data: ' prefix\n const event: StreamEvent = JSON.parse(eventData);\n\n console.log(\n `[HTTP Client] Read file stream event: ${event.type}`\n );\n this.options.onStreamEvent?.(event);\n\n switch (event.type) {\n case \"command_start\":\n console.log(\n `[HTTP Client] Read file started: ${event.path}`\n );\n this.options.onCommandStart?.(\"read\", [path, encoding]);\n break;\n\n case \"command_complete\":\n console.log(\n `[HTTP Client] Read file completed: ${\n event.path\n }, Success: ${event.success}, Content length: ${\n event.content?.length || 0\n }`\n );\n this.options.onCommandComplete?.(\n event.success!,\n 0,\n event.content || \"\",\n \"\",\n \"read\",\n [path, encoding]\n );\n break;\n\n case \"error\":\n console.error(\n `[HTTP Client] Read file error: ${event.error}`\n );\n this.options.onError?.(event.error!, \"read\", [\n path,\n encoding,\n ]);\n break;\n }\n } catch (parseError) {\n console.warn(\n \"[HTTP Client] Failed to parse read file stream event:\",\n parseError\n );\n }\n }\n }\n }\n } finally {\n reader.releaseLock();\n }\n } catch (error) {\n console.error(\"[HTTP Client] Error in streaming read file:\", error);\n this.options.onError?.(\n error instanceof Error ? error.message : \"Unknown error\",\n \"read\",\n [path, encoding]\n );\n throw error;\n }\n }\n\n async deleteFile(\n path: string,\n sessionId?: string\n ): Promise<DeleteFileResponse> {\n try {\n const targetSessionId = sessionId || this.sessionId;\n\n const response = await this.doFetch(`/api/delete`, {\n body: JSON.stringify({\n path,\n sessionId: targetSessionId,\n }),\n headers: {\n \"Content-Type\": \"application/json\",\n },\n method: \"POST\",\n });\n\n if (!response.ok) {\n const errorData = (await response.json().catch(() => ({}))) as {\n error?: string;\n };\n throw new Error(\n errorData.error || `HTTP error! status: ${response.status}`\n );\n }\n\n const data: DeleteFileResponse = await response.json();\n console.log(\n `[HTTP Client] File deleted: ${path}, Success: ${data.success}`\n );\n\n return data;\n } catch (error) {\n console.error(\"[HTTP Client] Error deleting file:\", error);\n throw error;\n }\n }\n\n async deleteFileStream(path: string, sessionId?: string): Promise<void> {\n try {\n const targetSessionId = sessionId || this.sessionId;\n\n const response = await this.doFetch(`/api/delete/stream`, {\n body: JSON.stringify({\n path,\n sessionId: targetSessionId,\n }),\n headers: {\n \"Content-Type\": \"application/json\",\n },\n method: \"POST\",\n });\n\n if (!response.ok) {\n const errorData = (await response.json().catch(() => ({}))) as {\n error?: string;\n };\n throw new Error(\n errorData.error || `HTTP error! status: ${response.status}`\n );\n }\n\n if (!response.body) {\n throw new Error(\"No response body for streaming request\");\n }\n\n const reader = response.body.getReader();\n const decoder = new TextDecoder();\n\n try {\n while (true) {\n const { done, value } = await reader.read();\n\n if (done) {\n break;\n }\n\n const chunk = decoder.decode(value, { stream: true });\n const lines = chunk.split(\"\\n\");\n\n for (const line of lines) {\n if (line.startsWith(\"data: \")) {\n try {\n const eventData = line.slice(6); // Remove 'data: ' prefix\n const event: StreamEvent = JSON.parse(eventData);\n\n console.log(\n `[HTTP Client] Delete file stream event: ${event.type}`\n );\n this.options.onStreamEvent?.(event);\n\n switch (event.type) {\n case \"command_start\":\n console.log(\n `[HTTP Client] Delete file started: ${event.path}`\n );\n this.options.onCommandStart?.(\"delete\", [path]);\n break;\n\n case \"command_complete\":\n console.log(\n `[HTTP Client] Delete file completed: ${event.path}, Success: ${event.success}`\n );\n this.options.onCommandComplete?.(\n event.success!,\n 0,\n \"\",\n \"\",\n \"delete\",\n [path]\n );\n break;\n\n case \"error\":\n console.error(\n `[HTTP Client] Delete file error: ${event.error}`\n );\n this.options.onError?.(event.error!, \"delete\", [path]);\n break;\n }\n } catch (parseError) {\n console.warn(\n \"[HTTP Client] Failed to parse delete file stream event:\",\n parseError\n );\n }\n }\n }\n }\n } finally {\n reader.releaseLock();\n }\n } catch (error) {\n console.error(\"[HTTP Client] Error in streaming delete file:\", error);\n this.options.onError?.(\n error instanceof Error ? error.message : \"Unknown error\",\n \"delete\",\n [path]\n );\n throw error;\n }\n }\n\n async renameFile(\n oldPath: string,\n newPath: string,\n sessionId?: string\n ): Promise<RenameFileResponse> {\n try {\n const targetSessionId = sessionId || this.sessionId;\n\n const response = await this.doFetch(`/api/rename`, {\n body: JSON.stringify({\n newPath,\n oldPath,\n sessionId: targetSessionId,\n }),\n headers: {\n \"Content-Type\": \"application/json\",\n },\n method: \"POST\",\n });\n\n if (!response.ok) {\n const errorData = (await response.json().catch(() => ({}))) as {\n error?: string;\n };\n throw new Error(\n errorData.error || `HTTP error! status: ${response.status}`\n );\n }\n\n const data: RenameFileResponse = await response.json();\n console.log(\n `[HTTP Client] File renamed: ${oldPath} -> ${newPath}, Success: ${data.success}`\n );\n\n return data;\n } catch (error) {\n console.error(\"[HTTP Client] Error renaming file:\", error);\n throw error;\n }\n }\n\n async renameFileStream(\n oldPath: string,\n newPath: string,\n sessionId?: string\n ): Promise<void> {\n try {\n const targetSessionId = sessionId || this.sessionId;\n\n const response = await this.doFetch(`/api/rename/stream`, {\n body: JSON.stringify({\n newPath,\n oldPath,\n sessionId: targetSessionId,\n }),\n headers: {\n \"Content-Type\": \"application/json\",\n },\n method: \"POST\",\n });\n\n if (!response.ok) {\n const errorData = (await response.json().catch(() => ({}))) as {\n error?: string;\n };\n throw new Error(\n errorData.error || `HTTP error! status: ${response.status}`\n );\n }\n\n if (!response.body) {\n throw new Error(\"No response body for streaming request\");\n }\n\n const reader = response.body.getReader();\n const decoder = new TextDecoder();\n\n try {\n while (true) {\n const { done, value } = await reader.read();\n\n if (done) {\n break;\n }\n\n const chunk = decoder.decode(value, { stream: true });\n const lines = chunk.split(\"\\n\");\n\n for (const line of lines) {\n if (line.startsWith(\"data: \")) {\n try {\n const eventData = line.slice(6); // Remove 'data: ' prefix\n const event: StreamEvent = JSON.parse(eventData);\n\n console.log(\n `[HTTP Client] Rename file stream event: ${event.type}`\n );\n this.options.onStreamEvent?.(event);\n\n switch (event.type) {\n case \"command_start\":\n console.log(\n `[HTTP Client] Rename file started: ${event.oldPath} -> ${event.newPath}`\n );\n this.options.onCommandStart?.(\"rename\", [oldPath, newPath]);\n break;\n\n case \"command_complete\":\n console.log(\n `[HTTP Client] Rename file completed: ${event.oldPath} -> ${event.newPath}, Success: ${event.success}`\n );\n this.options.onCommandComplete?.(\n event.success!,\n 0,\n \"\",\n \"\",\n \"rename\",\n [oldPath, newPath]\n );\n break;\n\n case \"error\":\n console.error(\n `[HTTP Client] Rename file error: ${event.error}`\n );\n this.options.onError?.(event.error!, \"rename\", [\n oldPath,\n newPath,\n ]);\n break;\n }\n } catch (parseError) {\n console.warn(\n \"[HTTP Client] Failed to parse rename file stream event:\",\n parseError\n );\n }\n }\n }\n }\n } finally {\n reader.releaseLock();\n }\n } catch (error) {\n console.error(\"[HTTP Client] Error in streaming rename file:\", error);\n this.options.onError?.(\n error instanceof Error ? error.message : \"Unknown error\",\n \"rename\",\n [oldPath, newPath]\n );\n throw error;\n }\n }\n\n async moveFile(\n sourcePath: string,\n destinationPath: string,\n sessionId?: string\n ): Promise<MoveFileResponse> {\n try {\n const targetSessionId = sessionId || this.sessionId;\n\n const response = await this.doFetch(`/api/move`, {\n body: JSON.stringify({\n destinationPath,\n sessionId: targetSessionId,\n sourcePath,\n }),\n headers: {\n \"Content-Type\": \"application/json\",\n },\n method: \"POST\",\n });\n\n if (!response.ok) {\n const errorData = (await response.json().catch(() => ({}))) as {\n error?: string;\n };\n throw new Error(\n errorData.error || `HTTP error! status: ${response.status}`\n );\n }\n\n const data: MoveFileResponse = await response.json();\n console.log(\n `[HTTP Client] File moved: ${sourcePath} -> ${destinationPath}, Success: ${data.success}`\n );\n\n return data;\n } catch (error) {\n console.error(\"[HTTP Client] Error moving file:\", error);\n throw error;\n }\n }\n\n async moveFileStream(\n sourcePath: string,\n destinationPath: string,\n sessionId?: string\n ): Promise<void> {\n try {\n const targetSessionId = sessionId || this.sessionId;\n\n const response = await this.doFetch(`/api/move/stream`, {\n body: JSON.stringify({\n destinationPath,\n sessionId: targetSessionId,\n sourcePath,\n }),\n headers: {\n \"Content-Type\": \"application/json\",\n },\n method: \"POST\",\n });\n\n if (!response.ok) {\n const errorData = (await response.json().catch(() => ({}))) as {\n error?: string;\n };\n throw new Error(\n errorData.error || `HTTP error! status: ${response.status}`\n );\n }\n\n if (!response.body) {\n throw new Error(\"No response body for streaming request\");\n }\n\n const reader = response.body.getReader();\n const decoder = new TextDecoder();\n\n try {\n while (true) {\n const { done, value } = await reader.read();\n\n if (done) {\n break;\n }\n\n const chunk = decoder.decode(value, { stream: true });\n const lines = chunk.split(\"\\n\");\n\n for (const line of lines) {\n if (line.startsWith(\"data: \")) {\n try {\n const eventData = line.slice(6); // Remove 'data: ' prefix\n const event: StreamEvent = JSON.parse(eventData);\n\n console.log(\n `[HTTP Client] Move file stream event: ${event.type}`\n );\n this.options.onStreamEvent?.(event);\n\n switch (event.type) {\n case \"command_start\":\n console.log(\n `[HTTP Client] Move file started: ${event.sourcePath} -> ${event.destinationPath}`\n );\n this.options.onCommandStart?.(\"move\", [\n sourcePath,\n destinationPath,\n ]);\n break;\n\n case \"command_complete\":\n console.log(\n `[HTTP Client] Move file completed: ${event.sourcePath} -> ${event.destinationPath}, Success: ${event.success}`\n );\n this.options.onCommandComplete?.(\n event.success!,\n 0,\n \"\",\n \"\",\n \"move\",\n [sourcePath, destinationPath]\n );\n break;\n\n case \"error\":\n console.error(\n `[HTTP Client] Move file error: ${event.error}`\n );\n this.options.onError?.(event.error!, \"move\", [\n sourcePath,\n destinationPath,\n ]);\n break;\n }\n } catch (parseError) {\n console.warn(\n \"[HTTP Client] Failed to parse move file stream event:\",\n parseError\n );\n }\n }\n }\n }\n } finally {\n reader.releaseLock();\n }\n } catch (error) {\n console.error(\"[HTTP Client] Error in streaming move file:\", error);\n this.options.onError?.(\n error instanceof Error ? error.message : \"Unknown error\",\n \"move\",\n [sourcePath, destinationPath]\n );\n throw error;\n }\n }\n\n async ping(): Promise<string> {\n try {\n const response = await this.doFetch(`/api/ping`, {\n headers: {\n \"Content-Type\": \"application/json\",\n },\n method: \"GET\",\n });\n\n if (!response.ok) {\n throw new Error(`HTTP error! status: ${response.status}`);\n }\n\n const data: PingResponse = await response.json();\n console.log(`[HTTP Client] Ping response: ${data.message}`);\n return data.timestamp;\n } catch (error) {\n console.error(\"[HTTP Client] Error pinging server:\", error);\n throw error;\n }\n }\n\n async getCommands(): Promise<string[]> {\n try {\n const response = await fetch(`${this.baseUrl}/api/commands`, {\n headers: {\n \"Content-Type\": \"application/json\",\n },\n method: \"GET\",\n });\n\n if (!response.ok) {\n throw new Error(`HTTP error! status: ${response.status}`);\n }\n\n const data: CommandsResponse = await response.json();\n console.log(\n `[HTTP Client] Available commands: ${data.availableCommands.length}`\n );\n return data.availableCommands;\n } catch (error) {\n console.error(\"[HTTP Client] Error getting commands:\", error);\n throw error;\n }\n }\n\n getSessionId(): string | null {\n return this.sessionId;\n }\n\n setSessionId(sessionId: string): void {\n this.sessionId = sessionId;\n }\n\n clearSession(): void {\n this.sessionId = null;\n }\n}\n\n// Example usage and utility functions\nexport function createClient(options?: HttpClientOptions): HttpClient {\n return new HttpClient(options);\n}\n\n// Convenience function for quick command execution\nexport async function quickExecute(\n command: string,\n args: string[] = [],\n options?: HttpClientOptions\n): Promise<ExecuteResponse> {\n const client = createClient(options);\n await client.createSession();\n\n try {\n return await client.execute(command, args);\n } finally {\n client.clearSession();\n }\n}\n\n// Convenience function for quick streaming command execution\nexport async function quickExecuteStream(\n command: string,\n args: string[] = [],\n options?: HttpClientOptions\n): Promise<void> {\n const client = createClient(options);\n await client.createSession();\n\n try {\n await client.executeStream(command, args);\n } finally {\n client.clearSession();\n }\n}\n\n// Convenience function for quick git checkout\nexport async function quickGitCheckout(\n repoUrl: string,\n branch: string = \"main\",\n targetDir?: string,\n options?: HttpClientOptions\n): Promise<GitCheckoutResponse> {\n const client = createClient(options);\n await client.createSession();\n\n try {\n return await client.gitCheckout(repoUrl, branch, targetDir);\n } finally {\n client.clearSession();\n }\n}\n\n// Convenience function for quick directory creation\nexport async function quickMkdir(\n path: string,\n recursive: boolean = false,\n options?: HttpClientOptions\n): Promise<MkdirResponse> {\n const client = createClient(options);\n await client.createSession();\n\n try {\n return await client.mkdir(path, recursive);\n } finally {\n client.clearSession();\n }\n}\n\n// Convenience function for quick streaming git checkout\nexport async function quickGitCheckoutStream(\n repoUrl: string,\n branch: string = \"main\",\n targetDir?: string,\n options?: HttpClientOptions\n): Promise<void> {\n const client = createClient(options);\n await client.createSession();\n\n try {\n await client.gitCheckoutStream(repoUrl, branch, targetDir);\n } finally {\n client.clearSession();\n }\n}\n\n// Convenience function for quick streaming directory creation\nexport async function quickMkdirStream(\n path: string,\n recursive: boolean = false,\n options?: HttpClientOptions\n): Promise<void> {\n const client = createClient(options);\n await client.createSession();\n\n try {\n await client.mkdirStream(path, recursive);\n } finally {\n client.clearSession();\n }\n}\n\n// Convenience function for quick file writing\nexport async function quickWriteFile(\n path: string,\n content: string,\n encoding: string = \"utf-8\",\n options?: HttpClientOptions\n): Promise<WriteFileResponse> {\n const client = createClient(options);\n await client.createSession();\n\n try {\n return await client.writeFile(path, content, encoding);\n } finally {\n client.clearSession();\n }\n}\n\n// Convenience function for quick streaming file writing\nexport async function quickWriteFileStream(\n path: string,\n content: string,\n encoding: string = \"utf-8\",\n options?: HttpClientOptions\n): Promise<void> {\n const client = createClient(options);\n await client.createSession();\n\n try {\n await client.writeFileStream(path, content, encoding);\n } finally {\n client.clearSession();\n }\n}\n\n// Convenience function for quick file reading\nexport async function quickReadFile(\n path: string,\n encoding: string = \"utf-8\",\n options?: HttpClientOptions\n): Promise<ReadFileResponse> {\n const client = createClient(options);\n await client.createSession();\n\n try {\n return await client.readFile(path, encoding);\n } finally {\n client.clearSession();\n }\n}\n\n// Convenience function for quick streaming file reading\nexport async function quickReadFileStream(\n path: string,\n encoding: string = \"utf-8\",\n options?: HttpClientOptions\n): Promise<void> {\n const client = createClient(options);\n await client.createSession();\n\n try {\n await client.readFileStream(path, encoding);\n } finally {\n client.clearSession();\n }\n}\n\n// Convenience function for quick file deletion\nexport async function quickDeleteFile(\n path: string,\n options?: HttpClientOptions\n): Promise<DeleteFileResponse> {\n const client = createClient(options);\n await client.createSession();\n\n try {\n return await client.deleteFile(path);\n } finally {\n client.clearSession();\n }\n}\n\n// Convenience function for quick streaming file deletion\nexport async function quickDeleteFileStream(\n path: string,\n options?: HttpClientOptions\n): Promise<void> {\n const client = createClient(options);\n await client.createSession();\n\n try {\n await client.deleteFileStream(path);\n } finally {\n client.clearSession();\n }\n}\n\n// Convenience function for quick file renaming\nexport async function quickRenameFile(\n oldPath: string,\n newPath: string,\n options?: HttpClientOptions\n): Promise<RenameFileResponse> {\n const client = createClient(options);\n await client.createSession();\n\n try {\n return await client.renameFile(oldPath, newPath);\n } finally {\n client.clearSession();\n }\n}\n\n// Convenience function for quick streaming file renaming\nexport async function quickRenameFileStream(\n oldPath: string,\n newPath: string,\n options?: HttpClientOptions\n): Promise<void> {\n const client = createClient(options);\n await client.createSession();\n\n try {\n await client.renameFileStream(oldPath, newPath);\n } finally {\n client.clearSession();\n }\n}\n\n// Convenience function for quick file moving\nexport async function quickMoveFile(\n sourcePath: string,\n destinationPath: string,\n options?: HttpClientOptions\n): Promise<MoveFileResponse> {\n const client = createClient(options);\n await client.createSession();\n\n try {\n return await client.moveFile(sourcePath, destinationPath);\n } finally {\n client.clearSession();\n }\n}\n\n// Convenience function for quick streaming file moving\nexport async function quickMoveFileStream(\n sourcePath: string,\n destinationPath: string,\n options?: HttpClientOptions\n): Promise<void> {\n const client = createClient(options);\n await client.createSession();\n\n try {\n await client.moveFileStream(sourcePath, destinationPath);\n } finally {\n client.clearSession();\n }\n}\n"],"mappings":"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","names":[]}
|