@claude-studio/server 0.1.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -0,0 +1,20 @@
1
+ import type { ElementSelection } from "@claude-studio/shared";
2
+ interface StreamCallbacks {
3
+ onStreaming: (chunk: string) => void;
4
+ onToolUse: (tool: string, input: Record<string, unknown>) => void;
5
+ onComplete: (result: string, sessionId: string, cost: number, turns: number) => void;
6
+ onError: (error: string) => void;
7
+ }
8
+ export declare class ClaudeSessionManager {
9
+ private sessions;
10
+ executePrompt(clientId: string, params: {
11
+ route: string;
12
+ element: ElementSelection;
13
+ prompt: string;
14
+ }, callbacks: StreamCallbacks): Promise<void>;
15
+ executeRawPrompt(clientId: string, prompt: string, callbacks: StreamCallbacks): Promise<void>;
16
+ resetSession(clientId: string): void;
17
+ private runQuery;
18
+ }
19
+ export {};
20
+ //# sourceMappingURL=claude-session.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"claude-session.d.ts","sourceRoot":"","sources":["../src/claude-session.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,uBAAuB,CAAA;AAK7D,UAAU,eAAe;IACvB,WAAW,EAAE,CAAC,KAAK,EAAE,MAAM,KAAK,IAAI,CAAA;IACpC,SAAS,EAAE,CAAC,IAAI,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,KAAK,IAAI,CAAA;IACjE,UAAU,EAAE,CAAC,MAAM,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,KAAK,IAAI,CAAA;IACpF,OAAO,EAAE,CAAC,KAAK,EAAE,MAAM,KAAK,IAAI,CAAA;CACjC;AAED,qBAAa,oBAAoB;IAC/B,OAAO,CAAC,QAAQ,CAA4B;IAEtC,aAAa,CACjB,QAAQ,EAAE,MAAM,EAChB,MAAM,EAAE;QAAE,KAAK,EAAE,MAAM,CAAC;QAAC,OAAO,EAAE,gBAAgB,CAAC;QAAC,MAAM,EAAE,MAAM,CAAA;KAAE,EACpE,SAAS,EAAE,eAAe,GACzB,OAAO,CAAC,IAAI,CAAC;IAKV,gBAAgB,CACpB,QAAQ,EAAE,MAAM,EAChB,MAAM,EAAE,MAAM,EACd,SAAS,EAAE,eAAe,GACzB,OAAO,CAAC,IAAI,CAAC;IAIhB,YAAY,CAAC,QAAQ,EAAE,MAAM,GAAG,IAAI;YAItB,QAAQ;CA2DvB"}
@@ -0,0 +1,66 @@
1
+ import { query } from "@anthropic-ai/claude-agent-sdk";
2
+ import { buildPrompt } from "./prompt-builder.js";
3
+ import { config } from "./config.js";
4
+ import { log } from "./logger.js";
5
+ export class ClaudeSessionManager {
6
+ sessions = new Map(); // clientId → sessionId
7
+ async executePrompt(clientId, params, callbacks) {
8
+ const fullPrompt = buildPrompt(params);
9
+ await this.runQuery(clientId, fullPrompt, callbacks);
10
+ }
11
+ async executeRawPrompt(clientId, prompt, callbacks) {
12
+ await this.runQuery(clientId, prompt, callbacks);
13
+ }
14
+ resetSession(clientId) {
15
+ this.sessions.delete(clientId);
16
+ }
17
+ async runQuery(clientId, prompt, callbacks) {
18
+ const options = {
19
+ allowedTools: ["Read", "Edit", "MultiEdit", "Glob", "Grep", "Bash"],
20
+ permissionMode: "acceptEdits",
21
+ cwd: config.projectDir,
22
+ model: config.model,
23
+ maxTurns: config.maxTurns,
24
+ };
25
+ const existingSession = this.sessions.get(clientId);
26
+ if (existingSession) {
27
+ options.resume = existingSession;
28
+ }
29
+ log.dim("AI", `[${clientId.slice(0, 8)}] Query started${existingSession ? " (resuming)" : ""}`);
30
+ const TIMEOUT_MS = 300_000; // 5 minutes
31
+ let timedOut = false;
32
+ const timer = setTimeout(() => { timedOut = true; }, TIMEOUT_MS);
33
+ try {
34
+ for await (const msg of query({ prompt, options })) {
35
+ if (timedOut) {
36
+ log.error("AI", `[${clientId.slice(0, 8)}] Timed out after 5 minutes`);
37
+ callbacks.onError("Session timed out after 5 minutes");
38
+ break;
39
+ }
40
+ if (msg.type === "assistant") {
41
+ for (const block of msg.message?.content || []) {
42
+ if (block.type === "text") {
43
+ callbacks.onStreaming(block.text);
44
+ }
45
+ if (block.type === "tool_use") {
46
+ callbacks.onToolUse(block.name, block.input);
47
+ }
48
+ }
49
+ }
50
+ if (msg.type === "result") {
51
+ const result = msg;
52
+ this.sessions.set(clientId, result.session_id);
53
+ callbacks.onComplete(result.result_text || result.result || "", result.session_id, result.total_cost_usd || 0, result.num_turns || 0);
54
+ }
55
+ }
56
+ }
57
+ catch (err) {
58
+ log.error("AI", `[${clientId.slice(0, 8)}] Query failed: ${err instanceof Error ? err.message : String(err)}`);
59
+ callbacks.onError(err instanceof Error ? err.message : String(err));
60
+ }
61
+ finally {
62
+ clearTimeout(timer);
63
+ }
64
+ }
65
+ }
66
+ //# sourceMappingURL=claude-session.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"claude-session.js","sourceRoot":"","sources":["../src/claude-session.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,9 @@
1
+ import "dotenv/config";
2
+ export declare const config: {
3
+ readonly port: number;
4
+ readonly projectDir: string;
5
+ readonly model: string;
6
+ readonly maxBudgetUsd: number;
7
+ readonly maxTurns: number;
8
+ };
9
+ //# sourceMappingURL=config.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"config.d.ts","sourceRoot":"","sources":["../src/config.ts"],"names":[],"mappings":"AAAA,OAAO,eAAe,CAAA;AAEtB,eAAO,MAAM,MAAM;;;;;;CAMT,CAAA"}
package/dist/config.js ADDED
@@ -0,0 +1,9 @@
1
+ import "dotenv/config";
2
+ export const config = {
3
+ port: parseInt(process.env.PORT || "7281", 10),
4
+ projectDir: process.env.PROJECT_DIR || process.cwd(),
5
+ model: process.env.MODEL || "sonnet",
6
+ maxBudgetUsd: parseFloat(process.env.MAX_BUDGET_USD || "2.0"),
7
+ maxTurns: parseInt(process.env.MAX_TURNS || "15", 10),
8
+ };
9
+ //# sourceMappingURL=config.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"config.js","sourceRoot":"","sources":["../src/config.ts"],"names":[],"mappings":"AAAA,OAAO,eAAe,CAAA;AAEtB,MAAM,CAAC,MAAM,MAAM,GAAG;IACpB,IAAI,EAAE,QAAQ,CAAC,OAAO,CAAC,GAAG,CAAC,IAAI,IAAI,MAAM,EAAE,EAAE,CAAC;IAC9C,UAAU,EAAE,OAAO,CAAC,GAAG,CAAC,WAAW,IAAI,OAAO,CAAC,GAAG,EAAE;IACpD,KAAK,EAAE,OAAO,CAAC,GAAG,CAAC,KAAK,IAAI,QAAQ;IACpC,YAAY,EAAE,UAAU,CAAC,OAAO,CAAC,GAAG,CAAC,cAAc,IAAI,KAAK,CAAC;IAC7D,QAAQ,EAAE,QAAQ,CAAC,OAAO,CAAC,GAAG,CAAC,SAAS,IAAI,IAAI,EAAE,EAAE,CAAC;CAC7C,CAAA"}
@@ -0,0 +1,18 @@
1
+ import type { WebSocket } from "ws";
2
+ import type { ServerMessage } from "@claude-studio/shared";
3
+ interface Client {
4
+ id: string;
5
+ ws: WebSocket;
6
+ sessionId: string | null;
7
+ }
8
+ export declare class ConnectionManager {
9
+ private clients;
10
+ add(ws: WebSocket): string;
11
+ remove(clientId: string): void;
12
+ send(clientId: string, msg: ServerMessage): void;
13
+ getClient(clientId: string): Client | undefined;
14
+ setSessionId(clientId: string, sessionId: string): void;
15
+ get count(): number;
16
+ }
17
+ export {};
18
+ //# sourceMappingURL=connection-manager.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"connection-manager.d.ts","sourceRoot":"","sources":["../src/connection-manager.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,IAAI,CAAA;AACnC,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,uBAAuB,CAAA;AAG1D,UAAU,MAAM;IACd,EAAE,EAAE,MAAM,CAAA;IACV,EAAE,EAAE,SAAS,CAAA;IACb,SAAS,EAAE,MAAM,GAAG,IAAI,CAAA;CACzB;AAED,qBAAa,iBAAiB;IAC5B,OAAO,CAAC,OAAO,CAA4B;IAE3C,GAAG,CAAC,EAAE,EAAE,SAAS,GAAG,MAAM;IAM1B,MAAM,CAAC,QAAQ,EAAE,MAAM,GAAG,IAAI;IAI9B,IAAI,CAAC,QAAQ,EAAE,MAAM,EAAE,GAAG,EAAE,aAAa,GAAG,IAAI;IAOhD,SAAS,CAAC,QAAQ,EAAE,MAAM,GAAG,MAAM,GAAG,SAAS;IAI/C,YAAY,CAAC,QAAQ,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,GAAG,IAAI;IAKvD,IAAI,KAAK,IAAI,MAAM,CAElB;CACF"}
@@ -0,0 +1,31 @@
1
+ import { randomUUID } from "node:crypto";
2
+ import { serializeServerMessage } from "@claude-studio/shared";
3
+ export class ConnectionManager {
4
+ clients = new Map();
5
+ add(ws) {
6
+ const id = randomUUID();
7
+ this.clients.set(id, { id, ws, sessionId: null });
8
+ return id;
9
+ }
10
+ remove(clientId) {
11
+ this.clients.delete(clientId);
12
+ }
13
+ send(clientId, msg) {
14
+ const client = this.clients.get(clientId);
15
+ if (client && client.ws.readyState === 1) {
16
+ client.ws.send(serializeServerMessage(msg));
17
+ }
18
+ }
19
+ getClient(clientId) {
20
+ return this.clients.get(clientId);
21
+ }
22
+ setSessionId(clientId, sessionId) {
23
+ const client = this.clients.get(clientId);
24
+ if (client)
25
+ client.sessionId = sessionId;
26
+ }
27
+ get count() {
28
+ return this.clients.size;
29
+ }
30
+ }
31
+ //# sourceMappingURL=connection-manager.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"connection-manager.js","sourceRoot":"","sources":["../src/connection-manager.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,aAAa,CAAA;AAGxC,OAAO,EAAE,sBAAsB,EAAE,MAAM,uBAAuB,CAAA;AAQ9D,MAAM,OAAO,iBAAiB;IACpB,OAAO,GAAG,IAAI,GAAG,EAAkB,CAAA;IAE3C,GAAG,CAAC,EAAa;QACf,MAAM,EAAE,GAAG,UAAU,EAAE,CAAA;QACvB,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC,CAAA;QACjD,OAAO,EAAE,CAAA;IACX,CAAC;IAED,MAAM,CAAC,QAAgB;QACrB,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAA;IAC/B,CAAC;IAED,IAAI,CAAC,QAAgB,EAAE,GAAkB;QACvC,MAAM,MAAM,GAAG,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAA;QACzC,IAAI,MAAM,IAAI,MAAM,CAAC,EAAE,CAAC,UAAU,KAAK,CAAC,EAAE,CAAC;YACzC,MAAM,CAAC,EAAE,CAAC,IAAI,CAAC,sBAAsB,CAAC,GAAG,CAAC,CAAC,CAAA;QAC7C,CAAC;IACH,CAAC;IAED,SAAS,CAAC,QAAgB;QACxB,OAAO,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAA;IACnC,CAAC;IAED,YAAY,CAAC,QAAgB,EAAE,SAAiB;QAC9C,MAAM,MAAM,GAAG,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAA;QACzC,IAAI,MAAM;YAAE,MAAM,CAAC,SAAS,GAAG,SAAS,CAAA;IAC1C,CAAC;IAED,IAAI,KAAK;QACP,OAAO,IAAI,CAAC,OAAO,CAAC,IAAI,CAAA;IAC1B,CAAC;CACF"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":""}
package/dist/index.js ADDED
@@ -0,0 +1,26 @@
1
+ import express from "express";
2
+ import { createServer } from "node:http";
3
+ import { WebSocketServer } from "ws";
4
+ import { config } from "./config.js";
5
+ import { ConnectionManager } from "./connection-manager.js";
6
+ import { ClaudeSessionManager } from "./claude-session.js";
7
+ import { handleConnection } from "./ws-handler.js";
8
+ import { log } from "./logger.js";
9
+ const app = express();
10
+ const server = createServer(app);
11
+ const wss = new WebSocketServer({ server });
12
+ const connections = new ConnectionManager();
13
+ const claude = new ClaudeSessionManager();
14
+ app.get("/health", (_req, res) => {
15
+ res.json({ status: "ok", connections: connections.count });
16
+ });
17
+ wss.on("connection", (ws) => {
18
+ handleConnection(ws, connections, claude);
19
+ });
20
+ server.listen(config.port, () => {
21
+ log.info("SRV", `Listening on port ${config.port}`);
22
+ log.dim("SRV", `Health: http://localhost:${config.port}/health`);
23
+ log.dim("SRV", `WebSocket: ws://localhost:${config.port}`);
24
+ log.dim("SRV", `Project: ${config.projectDir}`);
25
+ });
26
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,OAAO,MAAM,SAAS,CAAA;AAC7B,OAAO,EAAE,YAAY,EAAE,MAAM,WAAW,CAAA;AACxC,OAAO,EAAE,eAAe,EAAE,MAAM,IAAI,CAAA;AACpC,OAAO,EAAE,MAAM,EAAE,MAAM,aAAa,CAAA;AACpC,OAAO,EAAE,iBAAiB,EAAE,MAAM,yBAAyB,CAAA;AAC3D,OAAO,EAAE,oBAAoB,EAAE,MAAM,qBAAqB,CAAA;AAC1D,OAAO,EAAE,gBAAgB,EAAE,MAAM,iBAAiB,CAAA;AAClD,OAAO,EAAE,GAAG,EAAE,MAAM,aAAa,CAAA;AAEjC,MAAM,GAAG,GAAG,OAAO,EAAE,CAAA;AACrB,MAAM,MAAM,GAAG,YAAY,CAAC,GAAG,CAAC,CAAA;AAChC,MAAM,GAAG,GAAG,IAAI,eAAe,CAAC,EAAE,MAAM,EAAE,CAAC,CAAA;AAC3C,MAAM,WAAW,GAAG,IAAI,iBAAiB,EAAE,CAAA;AAC3C,MAAM,MAAM,GAAG,IAAI,oBAAoB,EAAE,CAAA;AAEzC,GAAG,CAAC,GAAG,CAAC,SAAS,EAAE,CAAC,IAAI,EAAE,GAAG,EAAE,EAAE;IAC/B,GAAG,CAAC,IAAI,CAAC,EAAE,MAAM,EAAE,IAAI,EAAE,WAAW,EAAE,WAAW,CAAC,KAAK,EAAE,CAAC,CAAA;AAC5D,CAAC,CAAC,CAAA;AAEF,GAAG,CAAC,EAAE,CAAC,YAAY,EAAE,CAAC,EAAE,EAAE,EAAE;IAC1B,gBAAgB,CAAC,EAAE,EAAE,WAAW,EAAE,MAAM,CAAC,CAAA;AAC3C,CAAC,CAAC,CAAA;AAEF,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC,IAAI,EAAE,GAAG,EAAE;IAC9B,GAAG,CAAC,IAAI,CAAC,KAAK,EAAE,qBAAqB,MAAM,CAAC,IAAI,EAAE,CAAC,CAAA;IACnD,GAAG,CAAC,GAAG,CAAC,KAAK,EAAE,4BAA4B,MAAM,CAAC,IAAI,SAAS,CAAC,CAAA;IAChE,GAAG,CAAC,GAAG,CAAC,KAAK,EAAE,6BAA6B,MAAM,CAAC,IAAI,EAAE,CAAC,CAAA;IAC1D,GAAG,CAAC,GAAG,CAAC,KAAK,EAAE,YAAY,MAAM,CAAC,UAAU,EAAE,CAAC,CAAA;AACjD,CAAC,CAAC,CAAA"}
@@ -0,0 +1,8 @@
1
+ export declare const log: {
2
+ info: (prefix: string, message: string) => void;
3
+ event: (prefix: string, message: string) => void;
4
+ error: (prefix: string, message: string) => void;
5
+ success: (prefix: string, message: string) => void;
6
+ dim: (prefix: string, message: string) => void;
7
+ };
8
+ //# sourceMappingURL=logger.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"logger.d.ts","sourceRoot":"","sources":["../src/logger.ts"],"names":[],"mappings":"AAgBA,eAAO,MAAM,GAAG;mBACC,MAAM,WAAW,MAAM;oBACtB,MAAM,WAAW,MAAM;oBACvB,MAAM,WAAW,MAAM;sBACrB,MAAM,WAAW,MAAM;kBAC3B,MAAM,WAAW,MAAM;CACtC,CAAA"}
package/dist/logger.js ADDED
@@ -0,0 +1,21 @@
1
+ const RESET = "\x1b[0m";
2
+ const CYAN = "\x1b[36m";
3
+ const YELLOW = "\x1b[33m";
4
+ const RED = "\x1b[31m";
5
+ const GREEN = "\x1b[32m";
6
+ const GRAY = "\x1b[90m";
7
+ const BOLD = "\x1b[1m";
8
+ function timestamp() {
9
+ return new Date().toLocaleTimeString("en-US", { hour12: false });
10
+ }
11
+ function format(color, prefix, message) {
12
+ return `${GRAY}${timestamp()}${RESET} ${color}${BOLD}[${prefix}]${RESET} ${message}`;
13
+ }
14
+ export const log = {
15
+ info: (prefix, message) => console.log(format(CYAN, prefix, message)),
16
+ event: (prefix, message) => console.log(format(YELLOW, prefix, message)),
17
+ error: (prefix, message) => console.error(format(RED, prefix, message)),
18
+ success: (prefix, message) => console.log(format(GREEN, prefix, message)),
19
+ dim: (prefix, message) => console.log(format(GRAY, prefix, message)),
20
+ };
21
+ //# sourceMappingURL=logger.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"logger.js","sourceRoot":"","sources":["../src/logger.ts"],"names":[],"mappings":"AAAA,MAAM,KAAK,GAAG,SAAS,CAAA;AACvB,MAAM,IAAI,GAAG,UAAU,CAAA;AACvB,MAAM,MAAM,GAAG,UAAU,CAAA;AACzB,MAAM,GAAG,GAAG,UAAU,CAAA;AACtB,MAAM,KAAK,GAAG,UAAU,CAAA;AACxB,MAAM,IAAI,GAAG,UAAU,CAAA;AACvB,MAAM,IAAI,GAAG,SAAS,CAAA;AAEtB,SAAS,SAAS;IAChB,OAAO,IAAI,IAAI,EAAE,CAAC,kBAAkB,CAAC,OAAO,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE,CAAC,CAAA;AAClE,CAAC;AAED,SAAS,MAAM,CAAC,KAAa,EAAE,MAAc,EAAE,OAAe;IAC5D,OAAO,GAAG,IAAI,GAAG,SAAS,EAAE,GAAG,KAAK,IAAI,KAAK,GAAG,IAAI,IAAI,MAAM,IAAI,KAAK,IAAI,OAAO,EAAE,CAAA;AACtF,CAAC;AAED,MAAM,CAAC,MAAM,GAAG,GAAG;IACjB,IAAI,EAAE,CAAC,MAAc,EAAE,OAAe,EAAE,EAAE,CAAC,OAAO,CAAC,GAAG,CAAC,MAAM,CAAC,IAAI,EAAE,MAAM,EAAE,OAAO,CAAC,CAAC;IACrF,KAAK,EAAE,CAAC,MAAc,EAAE,OAAe,EAAE,EAAE,CAAC,OAAO,CAAC,GAAG,CAAC,MAAM,CAAC,MAAM,EAAE,MAAM,EAAE,OAAO,CAAC,CAAC;IACxF,KAAK,EAAE,CAAC,MAAc,EAAE,OAAe,EAAE,EAAE,CAAC,OAAO,CAAC,KAAK,CAAC,MAAM,CAAC,GAAG,EAAE,MAAM,EAAE,OAAO,CAAC,CAAC;IACvF,OAAO,EAAE,CAAC,MAAc,EAAE,OAAe,EAAE,EAAE,CAAC,OAAO,CAAC,GAAG,CAAC,MAAM,CAAC,KAAK,EAAE,MAAM,EAAE,OAAO,CAAC,CAAC;IACzF,GAAG,EAAE,CAAC,MAAc,EAAE,OAAe,EAAE,EAAE,CAAC,OAAO,CAAC,GAAG,CAAC,MAAM,CAAC,IAAI,EAAE,MAAM,EAAE,OAAO,CAAC,CAAC;CACrF,CAAA"}
@@ -0,0 +1,9 @@
1
+ import type { ElementSelection } from "@claude-studio/shared";
2
+ interface PromptInput {
3
+ route: string;
4
+ element: ElementSelection;
5
+ prompt: string;
6
+ }
7
+ export declare function buildPrompt({ route, element, prompt }: PromptInput): string;
8
+ export {};
9
+ //# sourceMappingURL=prompt-builder.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"prompt-builder.d.ts","sourceRoot":"","sources":["../src/prompt-builder.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,uBAAuB,CAAA;AAE7D,UAAU,WAAW;IACnB,KAAK,EAAE,MAAM,CAAA;IACb,OAAO,EAAE,gBAAgB,CAAA;IACzB,MAAM,EAAE,MAAM,CAAA;CACf;AAED,wBAAgB,WAAW,CAAC,EAAE,KAAK,EAAE,OAAO,EAAE,MAAM,EAAE,EAAE,WAAW,GAAG,MAAM,CA0B3E"}
@@ -0,0 +1,27 @@
1
+ export function buildPrompt({ route, element, prompt }) {
2
+ const attrs = Object.entries(element.attributes)
3
+ .map(([k, v]) => `${k}="${v}"`)
4
+ .join(", ");
5
+ return `The user is viewing their Next.js application at route: ${route}
6
+ They selected an element on the live page and want to make a change.
7
+
8
+ Selected element details:
9
+ - CSS Selector: ${element.cssSelector}
10
+ - Tag: <${element.tagName}> with classes: [${element.classList.join(", ")}]
11
+ - Element ID: ${element.id || "none"}
12
+ - Text content (first 200 chars): "${element.textContent}"
13
+ - HTML snippet (first 500 chars): ${element.outerHTML}
14
+ - Key attributes: ${attrs || "none"}
15
+ - Current computed styles: color=${element.computedStyles.color}, bg=${element.computedStyles.backgroundColor}, font-size=${element.computedStyles.fontSize}
16
+ - Parent chain: ${element.parentChain.join(" > ")}
17
+
18
+ User's instruction: "${prompt}"
19
+
20
+ Instructions for you:
21
+ 1. Use Grep and Glob to find the source file(s) that render this element. Look for matching text content, class names, and component structure. The route "${route}" maps to a Next.js page — check app/${route === "/" ? "" : route.slice(1)}/page.tsx or pages/${route}.tsx first.
22
+ 2. Read the relevant file(s) to understand the current code.
23
+ 3. Make the requested change using Edit. Be surgical — change only what's needed.
24
+ 4. If the change involves styles, prefer editing Tailwind classes or CSS modules over inline styles, matching the project's existing patterns.
25
+ 5. Do NOT create new files unless explicitly asked. Do NOT refactor unrelated code.`;
26
+ }
27
+ //# sourceMappingURL=prompt-builder.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"prompt-builder.js","sourceRoot":"","sources":["../src/prompt-builder.ts"],"names":[],"mappings":"AAQA,MAAM,UAAU,WAAW,CAAC,EAAE,KAAK,EAAE,OAAO,EAAE,MAAM,EAAe;IACjE,MAAM,KAAK,GAAG,MAAM,CAAC,OAAO,CAAC,OAAO,CAAC,UAAU,CAAC;SAC7C,GAAG,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,GAAG,CAAC,KAAK,CAAC,GAAG,CAAC;SAC9B,IAAI,CAAC,IAAI,CAAC,CAAA;IAEb,OAAO,2DAA2D,KAAK;;;;kBAIvD,OAAO,CAAC,WAAW;UAC3B,OAAO,CAAC,OAAO,oBAAoB,OAAO,CAAC,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC;gBACzD,OAAO,CAAC,EAAE,IAAI,MAAM;qCACC,OAAO,CAAC,WAAW;oCACpB,OAAO,CAAC,SAAS;oBACjC,KAAK,IAAI,MAAM;mCACA,OAAO,CAAC,cAAc,CAAC,KAAK,QAAQ,OAAO,CAAC,cAAc,CAAC,eAAe,eAAe,OAAO,CAAC,cAAc,CAAC,QAAQ;kBACzI,OAAO,CAAC,WAAW,CAAC,IAAI,CAAC,KAAK,CAAC;;uBAE1B,MAAM;;;6JAGgI,KAAK,wCAAwC,KAAK,KAAK,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC,sBAAsB,KAAK;;;;oFAIpL,CAAA;AACpF,CAAC"}
@@ -0,0 +1,5 @@
1
+ import type { WebSocket } from "ws";
2
+ import type { ConnectionManager } from "./connection-manager.js";
3
+ import type { ClaudeSessionManager } from "./claude-session.js";
4
+ export declare function handleConnection(ws: WebSocket, connections: ConnectionManager, claude: ClaudeSessionManager): void;
5
+ //# sourceMappingURL=ws-handler.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ws-handler.d.ts","sourceRoot":"","sources":["../src/ws-handler.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,IAAI,CAAA;AAEnC,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,yBAAyB,CAAA;AAChE,OAAO,KAAK,EAAE,oBAAoB,EAAE,MAAM,qBAAqB,CAAA;AAmC/D,wBAAgB,gBAAgB,CAAC,EAAE,EAAE,SAAS,EAAE,WAAW,EAAE,iBAAiB,EAAE,MAAM,EAAE,oBAAoB,GAAG,IAAI,CAqElH"}
@@ -0,0 +1,90 @@
1
+ import { parseClientMessage } from "@claude-studio/shared";
2
+ import { log } from "./logger.js";
3
+ function withLogging(clientId, callbacks) {
4
+ let streamStarted = false;
5
+ return {
6
+ onStreaming(chunk) {
7
+ if (!streamStarted) {
8
+ streamStarted = true;
9
+ log.dim("AI", `[${clientId.slice(0, 8)}] Streaming started`);
10
+ }
11
+ callbacks.onStreaming(chunk);
12
+ },
13
+ onToolUse(tool, input) {
14
+ log.event("AI", `[${clientId.slice(0, 8)}] Tool: ${tool} ${JSON.stringify(input).slice(0, 100)}`);
15
+ callbacks.onToolUse(tool, input);
16
+ },
17
+ onComplete(result, sessionId, cost, turns) {
18
+ log.success("AI", `[${clientId.slice(0, 8)}] Complete (${turns} turns, $${cost.toFixed(4)})`);
19
+ callbacks.onComplete(result, sessionId, cost, turns);
20
+ },
21
+ onError(error) {
22
+ log.error("AI", `[${clientId.slice(0, 8)}] Error: ${error}`);
23
+ callbacks.onError(error);
24
+ },
25
+ };
26
+ }
27
+ export function handleConnection(ws, connections, claude) {
28
+ const clientId = connections.add(ws);
29
+ const short = clientId.slice(0, 8);
30
+ log.info("WS", `Client connected: ${short}`);
31
+ connections.send(clientId, { type: "connected", clientId });
32
+ let alive = true;
33
+ ws.on("pong", () => { alive = true; });
34
+ const heartbeat = setInterval(() => {
35
+ if (!alive) {
36
+ log.dim("WS", `Heartbeat timeout, terminating: ${short}`);
37
+ ws.terminate();
38
+ return;
39
+ }
40
+ alive = false;
41
+ ws.ping();
42
+ }, 30_000);
43
+ ws.on("message", (data) => {
44
+ try {
45
+ const msg = parseClientMessage(data.toString());
46
+ switch (msg.type) {
47
+ case "ping":
48
+ connections.send(clientId, { type: "pong" });
49
+ break;
50
+ case "prompt":
51
+ log.event("AI", `[${short}] Prompt: "${msg.prompt}" → ${msg.element.cssSelector} on ${msg.route}`);
52
+ claude.executePrompt(clientId, {
53
+ route: msg.route,
54
+ element: msg.element,
55
+ prompt: msg.prompt,
56
+ }, withLogging(clientId, {
57
+ onStreaming: (chunk) => connections.send(clientId, { type: "ai_streaming", chunk }),
58
+ onToolUse: (tool, input) => connections.send(clientId, { type: "tool_use", tool, input }),
59
+ onComplete: (result, sessionId, cost, turns) => connections.send(clientId, { type: "ai_complete", result, sessionId, cost, turns }),
60
+ onError: (error) => connections.send(clientId, { type: "ai_error", error }),
61
+ }));
62
+ break;
63
+ case "raw_prompt":
64
+ log.event("AI", `[${short}] Raw prompt: "${msg.prompt}"`);
65
+ claude.executeRawPrompt(clientId, msg.prompt, withLogging(clientId, {
66
+ onStreaming: (chunk) => connections.send(clientId, { type: "ai_streaming", chunk }),
67
+ onToolUse: (tool, input) => connections.send(clientId, { type: "tool_use", tool, input }),
68
+ onComplete: (result, sessionId, cost, turns) => connections.send(clientId, { type: "ai_complete", result, sessionId, cost, turns }),
69
+ onError: (error) => connections.send(clientId, { type: "ai_error", error }),
70
+ }));
71
+ break;
72
+ case "reset_session":
73
+ log.info("WS", `[${short}] Session reset`);
74
+ claude.resetSession(clientId);
75
+ connections.send(clientId, { type: "session_reset", newSessionId: "reset" });
76
+ break;
77
+ }
78
+ }
79
+ catch (err) {
80
+ log.error("WS", `[${short}] Message error: ${err}`);
81
+ connections.send(clientId, { type: "ai_error", error: String(err) });
82
+ }
83
+ });
84
+ ws.on("close", () => {
85
+ log.info("WS", `Client disconnected: ${short}`);
86
+ clearInterval(heartbeat);
87
+ connections.remove(clientId);
88
+ });
89
+ }
90
+ //# sourceMappingURL=ws-handler.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ws-handler.js","sourceRoot":"","sources":["../src/ws-handler.ts"],"names":[],"mappings":"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"}
package/package.json ADDED
@@ -0,0 +1,31 @@
1
+ {
2
+ "name": "@claude-studio/server",
3
+ "version": "0.1.1",
4
+ "type": "module",
5
+ "publishConfig": {
6
+ "access": "public"
7
+ },
8
+ "main": "dist/index.js",
9
+ "exports": {
10
+ ".": "./dist/index.js"
11
+ },
12
+ "scripts": {
13
+ "dev": "tsx watch src/index.ts",
14
+ "build": "tsc",
15
+ "test": "vitest run"
16
+ },
17
+ "dependencies": {
18
+ "@anthropic-ai/claude-agent-sdk": "^0.2.90",
19
+ "@claude-studio/shared": "workspace:*",
20
+ "dotenv": "^16.0.0",
21
+ "express": "^4.0.0",
22
+ "ws": "^8.0.0"
23
+ },
24
+ "devDependencies": {
25
+ "@types/express": "^4.0.0",
26
+ "@types/ws": "^8.0.0",
27
+ "tsx": "^4.0.0",
28
+ "typescript": "^5.0.0",
29
+ "vitest": "^3.0.0"
30
+ }
31
+ }