@paperclipai/adapter-cursor-cloud 0.3.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (57) hide show
  1. package/dist/cli/format-event.d.ts +2 -0
  2. package/dist/cli/format-event.d.ts.map +1 -0
  3. package/dist/cli/format-event.js +42 -0
  4. package/dist/cli/format-event.js.map +1 -0
  5. package/dist/cli/index.d.ts +2 -0
  6. package/dist/cli/index.d.ts.map +1 -0
  7. package/dist/cli/index.js +2 -0
  8. package/dist/cli/index.js.map +1 -0
  9. package/dist/index.d.ts +4 -0
  10. package/dist/index.d.ts.map +1 -0
  11. package/dist/index.js +34 -0
  12. package/dist/index.js.map +1 -0
  13. package/dist/server/execute.d.ts +3 -0
  14. package/dist/server/execute.d.ts.map +1 -0
  15. package/dist/server/execute.js +524 -0
  16. package/dist/server/execute.js.map +1 -0
  17. package/dist/server/execute.test.d.ts +2 -0
  18. package/dist/server/execute.test.d.ts.map +1 -0
  19. package/dist/server/execute.test.js +305 -0
  20. package/dist/server/execute.test.js.map +1 -0
  21. package/dist/server/index.d.ts +6 -0
  22. package/dist/server/index.d.ts.map +1 -0
  23. package/dist/server/index.js +68 -0
  24. package/dist/server/index.js.map +1 -0
  25. package/dist/server/session.d.ts +3 -0
  26. package/dist/server/session.d.ts.map +1 -0
  27. package/dist/server/session.js +61 -0
  28. package/dist/server/session.js.map +1 -0
  29. package/dist/server/session.test.d.ts +2 -0
  30. package/dist/server/session.test.d.ts.map +1 -0
  31. package/dist/server/session.test.js +28 -0
  32. package/dist/server/session.test.js.map +1 -0
  33. package/dist/server/test.d.ts +3 -0
  34. package/dist/server/test.d.ts.map +1 -0
  35. package/dist/server/test.js +111 -0
  36. package/dist/server/test.js.map +1 -0
  37. package/dist/ui/build-config.d.ts +3 -0
  38. package/dist/ui/build-config.d.ts.map +1 -0
  39. package/dist/ui/build-config.js +72 -0
  40. package/dist/ui/build-config.js.map +1 -0
  41. package/dist/ui/build-config.test.d.ts +2 -0
  42. package/dist/ui/build-config.test.d.ts.map +1 -0
  43. package/dist/ui/build-config.test.js +76 -0
  44. package/dist/ui/build-config.test.js.map +1 -0
  45. package/dist/ui/index.d.ts +3 -0
  46. package/dist/ui/index.d.ts.map +1 -0
  47. package/dist/ui/index.js +3 -0
  48. package/dist/ui/index.js.map +1 -0
  49. package/dist/ui/parse-stdout.d.ts +3 -0
  50. package/dist/ui/parse-stdout.d.ts.map +1 -0
  51. package/dist/ui/parse-stdout.js +173 -0
  52. package/dist/ui/parse-stdout.js.map +1 -0
  53. package/dist/ui/parse-stdout.test.d.ts +2 -0
  54. package/dist/ui/parse-stdout.test.d.ts.map +1 -0
  55. package/dist/ui/parse-stdout.test.js +119 -0
  56. package/dist/ui/parse-stdout.test.js.map +1 -0
  57. package/package.json +61 -0
@@ -0,0 +1,111 @@
1
+ import { Cursor } from "@cursor/sdk";
2
+ import { asString, parseObject } from "@paperclipai/adapter-utils/server-utils";
3
+ function summarizeStatus(checks) {
4
+ if (checks.some((check) => check.level === "error"))
5
+ return "fail";
6
+ if (checks.some((check) => check.level === "warn"))
7
+ return "warn";
8
+ return "pass";
9
+ }
10
+ function asStringEnvMap(value) {
11
+ const parsed = parseObject(value);
12
+ const env = {};
13
+ for (const [key, entry] of Object.entries(parsed)) {
14
+ if (typeof entry === "string") {
15
+ env[key] = entry;
16
+ }
17
+ else if (typeof entry === "object" && entry !== null && !Array.isArray(entry)) {
18
+ const rec = entry;
19
+ if (rec.type === "plain" && typeof rec.value === "string")
20
+ env[key] = rec.value;
21
+ }
22
+ }
23
+ return env;
24
+ }
25
+ function looksLikeRepoUrl(value) {
26
+ return /^(https?:\/\/|git@)/i.test(value.trim());
27
+ }
28
+ export async function testEnvironment(ctx) {
29
+ const checks = [];
30
+ const config = parseObject(ctx.config);
31
+ const env = asStringEnvMap(config.env);
32
+ const apiKey = asString(env.CURSOR_API_KEY, "").trim();
33
+ const repoUrl = asString(config.repoUrl, "").trim();
34
+ const model = asString(config.model, "").trim();
35
+ if (!apiKey) {
36
+ checks.push({
37
+ code: "cursor_cloud_api_key_missing",
38
+ level: "error",
39
+ message: "CURSOR_API_KEY is required.",
40
+ hint: "Add CURSOR_API_KEY under environment variables for this adapter.",
41
+ });
42
+ }
43
+ if (!repoUrl) {
44
+ checks.push({
45
+ code: "cursor_cloud_repo_missing",
46
+ level: "error",
47
+ message: "repoUrl is required.",
48
+ hint: "Set the repository URL Cursor should open for this agent.",
49
+ });
50
+ }
51
+ else if (!looksLikeRepoUrl(repoUrl)) {
52
+ checks.push({
53
+ code: "cursor_cloud_repo_invalid",
54
+ level: "error",
55
+ message: "repoUrl must be an http(s) or git SSH repository URL.",
56
+ detail: repoUrl,
57
+ });
58
+ }
59
+ else {
60
+ checks.push({
61
+ code: "cursor_cloud_repo_present",
62
+ level: "info",
63
+ message: `Repository configured: ${repoUrl}`,
64
+ });
65
+ }
66
+ if (apiKey) {
67
+ try {
68
+ const me = await Cursor.me({ apiKey });
69
+ checks.push({
70
+ code: "cursor_cloud_auth_ok",
71
+ level: "info",
72
+ message: "Cursor API key is valid.",
73
+ detail: me.userEmail ? `Authenticated as ${me.userEmail}.` : `API key: ${me.apiKeyName}`,
74
+ });
75
+ }
76
+ catch (err) {
77
+ checks.push({
78
+ code: "cursor_cloud_auth_failed",
79
+ level: "error",
80
+ message: err instanceof Error ? err.message : "Failed to validate Cursor API key.",
81
+ });
82
+ }
83
+ }
84
+ if (apiKey && model) {
85
+ try {
86
+ const models = await Cursor.models.list({ apiKey });
87
+ const match = models.find((entry) => entry.id === model);
88
+ checks.push({
89
+ code: match ? "cursor_cloud_model_ok" : "cursor_cloud_model_unknown",
90
+ level: match ? "info" : "warn",
91
+ message: match
92
+ ? `Model "${model}" is available to the authenticated Cursor account.`
93
+ : `Model "${model}" was not found in the authenticated Cursor model list.`,
94
+ });
95
+ }
96
+ catch (err) {
97
+ checks.push({
98
+ code: "cursor_cloud_model_probe_failed",
99
+ level: "warn",
100
+ message: err instanceof Error ? err.message : "Failed to validate model availability.",
101
+ });
102
+ }
103
+ }
104
+ return {
105
+ adapterType: ctx.adapterType,
106
+ status: summarizeStatus(checks),
107
+ checks,
108
+ testedAt: new Date().toISOString(),
109
+ };
110
+ }
111
+ //# sourceMappingURL=test.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"test.js","sourceRoot":"","sources":["../../src/server/test.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,3 @@
1
+ import type { CreateConfigValues } from "@paperclipai/adapter-utils";
2
+ export declare function buildCursorCloudConfig(values: CreateConfigValues): Record<string, unknown>;
3
+ //# sourceMappingURL=build-config.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"build-config.d.ts","sourceRoot":"","sources":["../../src/ui/build-config.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,4BAA4B,CAAC;AA6CrE,wBAAgB,sBAAsB,CAAC,MAAM,EAAE,kBAAkB,GAAG,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAqB1F"}
@@ -0,0 +1,72 @@
1
+ function parseEnvVars(text) {
2
+ const env = {};
3
+ for (const line of text.split(/\r?\n/)) {
4
+ const trimmed = line.trim();
5
+ if (!trimmed || trimmed.startsWith("#"))
6
+ continue;
7
+ const eq = trimmed.indexOf("=");
8
+ if (eq <= 0)
9
+ continue;
10
+ const key = trimmed.slice(0, eq).trim();
11
+ const value = trimmed.slice(eq + 1);
12
+ if (!/^[A-Za-z_][A-Za-z0-9_]*$/.test(key))
13
+ continue;
14
+ env[key] = value;
15
+ }
16
+ return env;
17
+ }
18
+ function parseEnvBindings(bindings) {
19
+ if (typeof bindings !== "object" || bindings === null || Array.isArray(bindings))
20
+ return {};
21
+ const env = {};
22
+ for (const [key, raw] of Object.entries(bindings)) {
23
+ if (!/^[A-Za-z_][A-Za-z0-9_]*$/.test(key))
24
+ continue;
25
+ if (typeof raw === "string") {
26
+ env[key] = { type: "plain", value: raw };
27
+ continue;
28
+ }
29
+ if (typeof raw !== "object" || raw === null || Array.isArray(raw))
30
+ continue;
31
+ const rec = raw;
32
+ if (rec.type === "plain" && typeof rec.value === "string") {
33
+ env[key] = { type: "plain", value: rec.value };
34
+ continue;
35
+ }
36
+ if (rec.type === "secret_ref" && typeof rec.secretId === "string") {
37
+ env[key] = {
38
+ type: "secret_ref",
39
+ secretId: rec.secretId,
40
+ ...(typeof rec.version === "number" || rec.version === "latest"
41
+ ? { version: rec.version }
42
+ : {}),
43
+ };
44
+ }
45
+ }
46
+ return env;
47
+ }
48
+ export function buildCursorCloudConfig(values) {
49
+ const config = {
50
+ ...(values.adapterSchemaValues ?? {}),
51
+ };
52
+ if (values.instructionsFilePath)
53
+ config.instructionsFilePath = values.instructionsFilePath;
54
+ if (values.promptTemplate)
55
+ config.promptTemplate = values.promptTemplate;
56
+ if (values.bootstrapPrompt)
57
+ config.bootstrapPromptTemplate = values.bootstrapPrompt;
58
+ if (values.model?.trim())
59
+ config.model = values.model.trim();
60
+ const env = parseEnvBindings(values.envBindings);
61
+ const legacy = parseEnvVars(values.envVars);
62
+ for (const [key, value] of Object.entries(legacy)) {
63
+ if (!Object.prototype.hasOwnProperty.call(env, key)) {
64
+ env[key] = { type: "plain", value };
65
+ }
66
+ }
67
+ if (Object.keys(env).length > 0) {
68
+ config.env = env;
69
+ }
70
+ return config;
71
+ }
72
+ //# sourceMappingURL=build-config.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"build-config.js","sourceRoot":"","sources":["../../src/ui/build-config.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=build-config.test.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"build-config.test.d.ts","sourceRoot":"","sources":["../../src/ui/build-config.test.ts"],"names":[],"mappings":""}
@@ -0,0 +1,76 @@
1
+ import { describe, expect, it } from "vitest";
2
+ import { buildCursorCloudConfig } from "./build-config.js";
3
+ function makeValues(overrides = {}) {
4
+ return {
5
+ adapterType: "cursor_cloud",
6
+ cwd: "",
7
+ instructionsFilePath: "",
8
+ promptTemplate: "",
9
+ model: "",
10
+ thinkingEffort: "",
11
+ chrome: false,
12
+ dangerouslySkipPermissions: false,
13
+ search: false,
14
+ fastMode: false,
15
+ dangerouslyBypassSandbox: false,
16
+ command: "",
17
+ args: "",
18
+ extraArgs: "",
19
+ envVars: "",
20
+ envBindings: {},
21
+ url: "",
22
+ bootstrapPrompt: "",
23
+ payloadTemplateJson: "",
24
+ workspaceStrategyType: "project_primary",
25
+ workspaceBaseRef: "",
26
+ workspaceBranchTemplate: "",
27
+ worktreeParentDir: "",
28
+ runtimeServicesJson: "",
29
+ maxTurnsPerRun: 1000,
30
+ heartbeatEnabled: false,
31
+ intervalSec: 300,
32
+ adapterSchemaValues: {},
33
+ ...overrides,
34
+ };
35
+ }
36
+ describe("buildCursorCloudConfig", () => {
37
+ it("persists schema values and top-level prompt fields", () => {
38
+ const config = buildCursorCloudConfig(makeValues({
39
+ instructionsFilePath: ".cursor/AGENTS.md",
40
+ promptTemplate: "hello {{agent.name}}",
41
+ bootstrapPrompt: "bootstrap",
42
+ model: "gpt-5.4",
43
+ adapterSchemaValues: {
44
+ repoUrl: "https://github.com/paperclipai/paperclip.git",
45
+ runtimeEnvType: "pool",
46
+ runtimeEnvName: "trusted-workers",
47
+ autoCreatePR: true,
48
+ },
49
+ }));
50
+ expect(config).toMatchObject({
51
+ instructionsFilePath: ".cursor/AGENTS.md",
52
+ promptTemplate: "hello {{agent.name}}",
53
+ bootstrapPromptTemplate: "bootstrap",
54
+ model: "gpt-5.4",
55
+ repoUrl: "https://github.com/paperclipai/paperclip.git",
56
+ runtimeEnvType: "pool",
57
+ runtimeEnvName: "trusted-workers",
58
+ autoCreatePR: true,
59
+ });
60
+ });
61
+ it("merges structured env bindings over legacy envVars text", () => {
62
+ const config = buildCursorCloudConfig(makeValues({
63
+ envVars: ["CURSOR_API_KEY=legacy-key", "PLAIN=value", "INVALID KEY=nope"].join("\n"),
64
+ envBindings: {
65
+ CURSOR_API_KEY: { type: "secret_ref", secretId: "secret-1", version: "latest" },
66
+ STRUCTURED_ONLY: "from-binding",
67
+ },
68
+ }));
69
+ expect(config.env).toEqual({
70
+ CURSOR_API_KEY: { type: "secret_ref", secretId: "secret-1", version: "latest" },
71
+ PLAIN: { type: "plain", value: "value" },
72
+ STRUCTURED_ONLY: { type: "plain", value: "from-binding" },
73
+ });
74
+ });
75
+ });
76
+ //# sourceMappingURL=build-config.test.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"build-config.test.js","sourceRoot":"","sources":["../../src/ui/build-config.test.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,EAAE,EAAE,EAAE,MAAM,QAAQ,CAAC;AAE9C,OAAO,EAAE,sBAAsB,EAAE,MAAM,mBAAmB,CAAC;AAE3D,SAAS,UAAU,CAAC,YAAyC,EAAE;IAC7D,OAAO;QACL,WAAW,EAAE,cAAc;QAC3B,GAAG,EAAE,EAAE;QACP,oBAAoB,EAAE,EAAE;QACxB,cAAc,EAAE,EAAE;QAClB,KAAK,EAAE,EAAE;QACT,cAAc,EAAE,EAAE;QAClB,MAAM,EAAE,KAAK;QACb,0BAA0B,EAAE,KAAK;QACjC,MAAM,EAAE,KAAK;QACb,QAAQ,EAAE,KAAK;QACf,wBAAwB,EAAE,KAAK;QAC/B,OAAO,EAAE,EAAE;QACX,IAAI,EAAE,EAAE;QACR,SAAS,EAAE,EAAE;QACb,OAAO,EAAE,EAAE;QACX,WAAW,EAAE,EAAE;QACf,GAAG,EAAE,EAAE;QACP,eAAe,EAAE,EAAE;QACnB,mBAAmB,EAAE,EAAE;QACvB,qBAAqB,EAAE,iBAAiB;QACxC,gBAAgB,EAAE,EAAE;QACpB,uBAAuB,EAAE,EAAE;QAC3B,iBAAiB,EAAE,EAAE;QACrB,mBAAmB,EAAE,EAAE;QACvB,cAAc,EAAE,IAAI;QACpB,gBAAgB,EAAE,KAAK;QACvB,WAAW,EAAE,GAAG;QAChB,mBAAmB,EAAE,EAAE;QACvB,GAAG,SAAS;KACb,CAAC;AACJ,CAAC;AAED,QAAQ,CAAC,wBAAwB,EAAE,GAAG,EAAE;IACtC,EAAE,CAAC,oDAAoD,EAAE,GAAG,EAAE;QAC5D,MAAM,MAAM,GAAG,sBAAsB,CACnC,UAAU,CAAC;YACT,oBAAoB,EAAE,mBAAmB;YACzC,cAAc,EAAE,sBAAsB;YACtC,eAAe,EAAE,WAAW;YAC5B,KAAK,EAAE,SAAS;YAChB,mBAAmB,EAAE;gBACnB,OAAO,EAAE,8CAA8C;gBACvD,cAAc,EAAE,MAAM;gBACtB,cAAc,EAAE,iBAAiB;gBACjC,YAAY,EAAE,IAAI;aACnB;SACF,CAAC,CACH,CAAC;QAEF,MAAM,CAAC,MAAM,CAAC,CAAC,aAAa,CAAC;YAC3B,oBAAoB,EAAE,mBAAmB;YACzC,cAAc,EAAE,sBAAsB;YACtC,uBAAuB,EAAE,WAAW;YACpC,KAAK,EAAE,SAAS;YAChB,OAAO,EAAE,8CAA8C;YACvD,cAAc,EAAE,MAAM;YACtB,cAAc,EAAE,iBAAiB;YACjC,YAAY,EAAE,IAAI;SACnB,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,yDAAyD,EAAE,GAAG,EAAE;QACjE,MAAM,MAAM,GAAG,sBAAsB,CACnC,UAAU,CAAC;YACT,OAAO,EAAE,CAAC,2BAA2B,EAAE,aAAa,EAAE,kBAAkB,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC;YACpF,WAAW,EAAE;gBACX,cAAc,EAAE,EAAE,IAAI,EAAE,YAAY,EAAE,QAAQ,EAAE,UAAU,EAAE,OAAO,EAAE,QAAQ,EAAE;gBAC/E,eAAe,EAAE,cAAc;aAChC;SACF,CAAC,CACH,CAAC;QAEF,MAAM,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,OAAO,CAAC;YACzB,cAAc,EAAE,EAAE,IAAI,EAAE,YAAY,EAAE,QAAQ,EAAE,UAAU,EAAE,OAAO,EAAE,QAAQ,EAAE;YAC/E,KAAK,EAAE,EAAE,IAAI,EAAE,OAAO,EAAE,KAAK,EAAE,OAAO,EAAE;YACxC,eAAe,EAAE,EAAE,IAAI,EAAE,OAAO,EAAE,KAAK,EAAE,cAAc,EAAE;SAC1D,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
@@ -0,0 +1,3 @@
1
+ export { buildCursorCloudConfig } from "./build-config.js";
2
+ export { parseCursorCloudStdoutLine } from "./parse-stdout.js";
3
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/ui/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,sBAAsB,EAAE,MAAM,mBAAmB,CAAC;AAC3D,OAAO,EAAE,0BAA0B,EAAE,MAAM,mBAAmB,CAAC"}
@@ -0,0 +1,3 @@
1
+ export { buildCursorCloudConfig } from "./build-config.js";
2
+ export { parseCursorCloudStdoutLine } from "./parse-stdout.js";
3
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/ui/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,sBAAsB,EAAE,MAAM,mBAAmB,CAAC;AAC3D,OAAO,EAAE,0BAA0B,EAAE,MAAM,mBAAmB,CAAC"}
@@ -0,0 +1,3 @@
1
+ import type { TranscriptEntry } from "@paperclipai/adapter-utils";
2
+ export declare function parseCursorCloudStdoutLine(line: string, ts: string): TranscriptEntry[];
3
+ //# sourceMappingURL=parse-stdout.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"parse-stdout.d.ts","sourceRoot":"","sources":["../../src/ui/parse-stdout.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,4BAA4B,CAAC;AA2IlE,wBAAgB,0BAA0B,CAAC,IAAI,EAAE,MAAM,EAAE,EAAE,EAAE,MAAM,GAAG,eAAe,EAAE,CA8CtF"}
@@ -0,0 +1,173 @@
1
+ function safeJsonParse(text) {
2
+ try {
3
+ return JSON.parse(text);
4
+ }
5
+ catch {
6
+ return null;
7
+ }
8
+ }
9
+ function asRecord(value) {
10
+ if (typeof value !== "object" || value === null || Array.isArray(value))
11
+ return null;
12
+ return value;
13
+ }
14
+ function asString(value, fallback = "") {
15
+ return typeof value === "string" ? value : fallback;
16
+ }
17
+ function stringifyUnknown(value) {
18
+ if (typeof value === "string")
19
+ return value;
20
+ if (value === null || value === undefined)
21
+ return "";
22
+ try {
23
+ return JSON.stringify(value, null, 2);
24
+ }
25
+ catch {
26
+ return String(value);
27
+ }
28
+ }
29
+ function parseAssistantMessage(message, ts) {
30
+ const content = Array.isArray(message.content) ? message.content : [];
31
+ const entries = [];
32
+ for (const partRaw of content) {
33
+ const part = asRecord(partRaw);
34
+ if (!part)
35
+ continue;
36
+ const type = asString(part.type).trim();
37
+ if (type === "text") {
38
+ const text = asString(part.text).trim();
39
+ if (text)
40
+ entries.push({ kind: "assistant", ts, text });
41
+ continue;
42
+ }
43
+ if (type === "tool_use") {
44
+ entries.push({
45
+ kind: "tool_call",
46
+ ts,
47
+ name: asString(part.name, "tool"),
48
+ toolUseId: asString(part.id) || undefined,
49
+ input: part.input ?? {},
50
+ });
51
+ }
52
+ }
53
+ return entries;
54
+ }
55
+ function parseSdkMessage(messageRaw, ts) {
56
+ const message = asRecord(messageRaw);
57
+ if (!message)
58
+ return [];
59
+ const type = asString(message.type);
60
+ if (type === "assistant") {
61
+ const body = asRecord(message.message);
62
+ return body ? parseAssistantMessage(body, ts) : [];
63
+ }
64
+ if (type === "user") {
65
+ const body = asRecord(message.message);
66
+ const content = Array.isArray(body?.content) ? body.content : [];
67
+ const text = content
68
+ .map((entry) => asRecord(entry))
69
+ .filter((entry) => Boolean(entry))
70
+ .map((entry) => asString(entry.text).trim())
71
+ .filter(Boolean)
72
+ .join("\n");
73
+ return text ? [{ kind: "user", ts, text }] : [];
74
+ }
75
+ if (type === "thinking") {
76
+ const text = asString(message.text).trim();
77
+ return text ? [{ kind: "thinking", ts, text }] : [];
78
+ }
79
+ if (type === "tool_call") {
80
+ const toolUseId = asString(message.call_id, asString(message.id, "tool_call"));
81
+ const status = asString(message.status).toLowerCase();
82
+ if (status === "running") {
83
+ return [{
84
+ kind: "tool_call",
85
+ ts,
86
+ name: asString(message.name, "tool"),
87
+ toolUseId,
88
+ input: message.args ?? {},
89
+ }];
90
+ }
91
+ if (status === "completed" || status === "error") {
92
+ return [{
93
+ kind: "tool_result",
94
+ ts,
95
+ toolUseId,
96
+ toolName: asString(message.name, "tool"),
97
+ content: stringifyUnknown(message.result ?? message.args ?? {}),
98
+ isError: status === "error",
99
+ }];
100
+ }
101
+ return [];
102
+ }
103
+ if (type === "tool_result") {
104
+ const toolUseId = asString(message.call_id, asString(message.id, "tool_result"));
105
+ const isError = message.is_error === true ||
106
+ asString(message.status).toLowerCase() === "error";
107
+ return [{
108
+ kind: "tool_result",
109
+ ts,
110
+ toolUseId,
111
+ toolName: asString(message.name, "tool"),
112
+ content: stringifyUnknown(message.result ?? message.content ?? message.output ?? {}),
113
+ isError,
114
+ }];
115
+ }
116
+ if (type === "status") {
117
+ const status = asString(message.status);
118
+ const statusMessage = asString(message.message);
119
+ return [{
120
+ kind: "system",
121
+ ts,
122
+ text: `status: ${status}${statusMessage ? ` - ${statusMessage}` : ""}`,
123
+ }];
124
+ }
125
+ if (type === "task") {
126
+ const text = asString(message.text).trim();
127
+ return text ? [{ kind: "system", ts, text }] : [];
128
+ }
129
+ return [];
130
+ }
131
+ export function parseCursorCloudStdoutLine(line, ts) {
132
+ const parsed = asRecord(safeJsonParse(line));
133
+ if (!parsed) {
134
+ return [{ kind: "stdout", ts, text: line }];
135
+ }
136
+ const type = asString(parsed.type);
137
+ if (type === "cursor_cloud.init") {
138
+ const sessionId = asString(parsed.sessionId, asString(parsed.agentId));
139
+ return [{
140
+ kind: "init",
141
+ ts,
142
+ model: asString(parsed.model, "cursor_cloud"),
143
+ sessionId,
144
+ }];
145
+ }
146
+ if (type === "cursor_cloud.status") {
147
+ return [{
148
+ kind: "system",
149
+ ts,
150
+ text: `${asString(parsed.status, "status")}${parsed.message ? `: ${asString(parsed.message)}` : ""}`,
151
+ }];
152
+ }
153
+ if (type === "cursor_cloud.message") {
154
+ return parseSdkMessage(parsed.message, ts);
155
+ }
156
+ if (type === "cursor_cloud.result") {
157
+ const status = asString(parsed.status, "error");
158
+ return [{
159
+ kind: "result",
160
+ ts,
161
+ text: asString(parsed.result),
162
+ inputTokens: 0,
163
+ outputTokens: 0,
164
+ cachedTokens: 0,
165
+ costUsd: 0,
166
+ subtype: status,
167
+ isError: status !== "finished",
168
+ errors: parsed.error ? [asString(parsed.error)] : [],
169
+ }];
170
+ }
171
+ return [{ kind: "stdout", ts, text: line }];
172
+ }
173
+ //# sourceMappingURL=parse-stdout.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"parse-stdout.js","sourceRoot":"","sources":["../../src/ui/parse-stdout.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=parse-stdout.test.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"parse-stdout.test.d.ts","sourceRoot":"","sources":["../../src/ui/parse-stdout.test.ts"],"names":[],"mappings":""}
@@ -0,0 +1,119 @@
1
+ import { describe, expect, it } from "vitest";
2
+ import { parseCursorCloudStdoutLine } from "./parse-stdout.js";
3
+ const ts = "2026-05-10T05:10:00.000Z";
4
+ describe("parseCursorCloudStdoutLine", () => {
5
+ it("parses init and status events", () => {
6
+ expect(parseCursorCloudStdoutLine(JSON.stringify({ type: "cursor_cloud.init", sessionId: "agent-123", model: "gpt-5.4" }), ts)).toEqual([{ kind: "init", ts, sessionId: "agent-123", model: "gpt-5.4" }]);
7
+ expect(parseCursorCloudStdoutLine(JSON.stringify({ type: "cursor_cloud.status", status: "running", message: "Reattached" }), ts)).toEqual([{ kind: "system", ts, text: "running: Reattached" }]);
8
+ });
9
+ it("parses assistant text and tool lifecycle SDK messages", () => {
10
+ const assistantLine = JSON.stringify({
11
+ type: "cursor_cloud.message",
12
+ message: {
13
+ type: "assistant",
14
+ message: {
15
+ content: [
16
+ { type: "text", text: "Working on it." },
17
+ { type: "tool_use", id: "tool-1", name: "read_file", input: { path: "README.md" } },
18
+ ],
19
+ },
20
+ },
21
+ });
22
+ expect(parseCursorCloudStdoutLine(assistantLine, ts)).toEqual([
23
+ { kind: "assistant", ts, text: "Working on it." },
24
+ { kind: "tool_call", ts, name: "read_file", toolUseId: "tool-1", input: { path: "README.md" } },
25
+ ]);
26
+ const toolStartLine = JSON.stringify({
27
+ type: "cursor_cloud.message",
28
+ message: {
29
+ type: "tool_call",
30
+ id: "call-1",
31
+ name: "bash",
32
+ status: "running",
33
+ args: { command: "pwd" },
34
+ },
35
+ });
36
+ expect(parseCursorCloudStdoutLine(toolStartLine, ts)).toEqual([
37
+ { kind: "tool_call", ts, name: "bash", toolUseId: "call-1", input: { command: "pwd" } },
38
+ ]);
39
+ const toolEndLine = JSON.stringify({
40
+ type: "cursor_cloud.message",
41
+ message: {
42
+ type: "tool_call",
43
+ id: "call-1",
44
+ name: "bash",
45
+ status: "completed",
46
+ result: { stdout: "/repo" },
47
+ },
48
+ });
49
+ expect(parseCursorCloudStdoutLine(toolEndLine, ts)).toEqual([
50
+ {
51
+ kind: "tool_result",
52
+ ts,
53
+ toolUseId: "call-1",
54
+ toolName: "bash",
55
+ content: JSON.stringify({ stdout: "/repo" }, null, 2),
56
+ isError: false,
57
+ },
58
+ ]);
59
+ });
60
+ it("parses standalone tool_result SDK messages", () => {
61
+ const line = JSON.stringify({
62
+ type: "cursor_cloud.message",
63
+ message: {
64
+ type: "tool_result",
65
+ call_id: "call-9",
66
+ name: "read_file",
67
+ result: { contents: "file body" },
68
+ },
69
+ });
70
+ expect(parseCursorCloudStdoutLine(line, ts)).toEqual([
71
+ {
72
+ kind: "tool_result",
73
+ ts,
74
+ toolUseId: "call-9",
75
+ toolName: "read_file",
76
+ content: JSON.stringify({ contents: "file body" }, null, 2),
77
+ isError: false,
78
+ },
79
+ ]);
80
+ const errorLine = JSON.stringify({
81
+ type: "cursor_cloud.message",
82
+ message: {
83
+ type: "tool_result",
84
+ call_id: "call-10",
85
+ name: "bash",
86
+ is_error: true,
87
+ content: "exit 1",
88
+ },
89
+ });
90
+ expect(parseCursorCloudStdoutLine(errorLine, ts)).toEqual([
91
+ {
92
+ kind: "tool_result",
93
+ ts,
94
+ toolUseId: "call-10",
95
+ toolName: "bash",
96
+ content: "exit 1",
97
+ isError: true,
98
+ },
99
+ ]);
100
+ });
101
+ it("parses result events and preserves unknown lines as stdout", () => {
102
+ expect(parseCursorCloudStdoutLine(JSON.stringify({ type: "cursor_cloud.result", status: "finished", result: "Done", model: "gpt-5.4" }), ts)).toEqual([
103
+ {
104
+ kind: "result",
105
+ ts,
106
+ text: "Done",
107
+ inputTokens: 0,
108
+ outputTokens: 0,
109
+ cachedTokens: 0,
110
+ costUsd: 0,
111
+ subtype: "finished",
112
+ isError: false,
113
+ errors: [],
114
+ },
115
+ ]);
116
+ expect(parseCursorCloudStdoutLine("plain text", ts)).toEqual([{ kind: "stdout", ts, text: "plain text" }]);
117
+ });
118
+ });
119
+ //# sourceMappingURL=parse-stdout.test.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"parse-stdout.test.js","sourceRoot":"","sources":["../../src/ui/parse-stdout.test.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,EAAE,EAAE,EAAE,MAAM,QAAQ,CAAC;AAC9C,OAAO,EAAE,0BAA0B,EAAE,MAAM,mBAAmB,CAAC;AAE/D,MAAM,EAAE,GAAG,0BAA0B,CAAC;AAEtC,QAAQ,CAAC,4BAA4B,EAAE,GAAG,EAAE;IAC1C,EAAE,CAAC,+BAA+B,EAAE,GAAG,EAAE;QACvC,MAAM,CACJ,0BAA0B,CACxB,IAAI,CAAC,SAAS,CAAC,EAAE,IAAI,EAAE,mBAAmB,EAAE,SAAS,EAAE,WAAW,EAAE,KAAK,EAAE,SAAS,EAAE,CAAC,EACvF,EAAE,CACH,CACF,CAAC,OAAO,CAAC,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,EAAE,EAAE,SAAS,EAAE,WAAW,EAAE,KAAK,EAAE,SAAS,EAAE,CAAC,CAAC,CAAC;QAE5E,MAAM,CACJ,0BAA0B,CACxB,IAAI,CAAC,SAAS,CAAC,EAAE,IAAI,EAAE,qBAAqB,EAAE,MAAM,EAAE,SAAS,EAAE,OAAO,EAAE,YAAY,EAAE,CAAC,EACzF,EAAE,CACH,CACF,CAAC,OAAO,CAAC,CAAC,EAAE,IAAI,EAAE,QAAQ,EAAE,EAAE,EAAE,IAAI,EAAE,qBAAqB,EAAE,CAAC,CAAC,CAAC;IACnE,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,uDAAuD,EAAE,GAAG,EAAE;QAC/D,MAAM,aAAa,GAAG,IAAI,CAAC,SAAS,CAAC;YACnC,IAAI,EAAE,sBAAsB;YAC5B,OAAO,EAAE;gBACP,IAAI,EAAE,WAAW;gBACjB,OAAO,EAAE;oBACP,OAAO,EAAE;wBACP,EAAE,IAAI,EAAE,MAAM,EAAE,IAAI,EAAE,gBAAgB,EAAE;wBACxC,EAAE,IAAI,EAAE,UAAU,EAAE,EAAE,EAAE,QAAQ,EAAE,IAAI,EAAE,WAAW,EAAE,KAAK,EAAE,EAAE,IAAI,EAAE,WAAW,EAAE,EAAE;qBACpF;iBACF;aACF;SACF,CAAC,CAAC;QACH,MAAM,CAAC,0BAA0B,CAAC,aAAa,EAAE,EAAE,CAAC,CAAC,CAAC,OAAO,CAAC;YAC5D,EAAE,IAAI,EAAE,WAAW,EAAE,EAAE,EAAE,IAAI,EAAE,gBAAgB,EAAE;YACjD,EAAE,IAAI,EAAE,WAAW,EAAE,EAAE,EAAE,IAAI,EAAE,WAAW,EAAE,SAAS,EAAE,QAAQ,EAAE,KAAK,EAAE,EAAE,IAAI,EAAE,WAAW,EAAE,EAAE;SAChG,CAAC,CAAC;QAEH,MAAM,aAAa,GAAG,IAAI,CAAC,SAAS,CAAC;YACnC,IAAI,EAAE,sBAAsB;YAC5B,OAAO,EAAE;gBACP,IAAI,EAAE,WAAW;gBACjB,EAAE,EAAE,QAAQ;gBACZ,IAAI,EAAE,MAAM;gBACZ,MAAM,EAAE,SAAS;gBACjB,IAAI,EAAE,EAAE,OAAO,EAAE,KAAK,EAAE;aACzB;SACF,CAAC,CAAC;QACH,MAAM,CAAC,0BAA0B,CAAC,aAAa,EAAE,EAAE,CAAC,CAAC,CAAC,OAAO,CAAC;YAC5D,EAAE,IAAI,EAAE,WAAW,EAAE,EAAE,EAAE,IAAI,EAAE,MAAM,EAAE,SAAS,EAAE,QAAQ,EAAE,KAAK,EAAE,EAAE,OAAO,EAAE,KAAK,EAAE,EAAE;SACxF,CAAC,CAAC;QAEH,MAAM,WAAW,GAAG,IAAI,CAAC,SAAS,CAAC;YACjC,IAAI,EAAE,sBAAsB;YAC5B,OAAO,EAAE;gBACP,IAAI,EAAE,WAAW;gBACjB,EAAE,EAAE,QAAQ;gBACZ,IAAI,EAAE,MAAM;gBACZ,MAAM,EAAE,WAAW;gBACnB,MAAM,EAAE,EAAE,MAAM,EAAE,OAAO,EAAE;aAC5B;SACF,CAAC,CAAC;QACH,MAAM,CAAC,0BAA0B,CAAC,WAAW,EAAE,EAAE,CAAC,CAAC,CAAC,OAAO,CAAC;YAC1D;gBACE,IAAI,EAAE,aAAa;gBACnB,EAAE;gBACF,SAAS,EAAE,QAAQ;gBACnB,QAAQ,EAAE,MAAM;gBAChB,OAAO,EAAE,IAAI,CAAC,SAAS,CAAC,EAAE,MAAM,EAAE,OAAO,EAAE,EAAE,IAAI,EAAE,CAAC,CAAC;gBACrD,OAAO,EAAE,KAAK;aACf;SACF,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,4CAA4C,EAAE,GAAG,EAAE;QACpD,MAAM,IAAI,GAAG,IAAI,CAAC,SAAS,CAAC;YAC1B,IAAI,EAAE,sBAAsB;YAC5B,OAAO,EAAE;gBACP,IAAI,EAAE,aAAa;gBACnB,OAAO,EAAE,QAAQ;gBACjB,IAAI,EAAE,WAAW;gBACjB,MAAM,EAAE,EAAE,QAAQ,EAAE,WAAW,EAAE;aAClC;SACF,CAAC,CAAC;QACH,MAAM,CAAC,0BAA0B,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC,CAAC,OAAO,CAAC;YACnD;gBACE,IAAI,EAAE,aAAa;gBACnB,EAAE;gBACF,SAAS,EAAE,QAAQ;gBACnB,QAAQ,EAAE,WAAW;gBACrB,OAAO,EAAE,IAAI,CAAC,SAAS,CAAC,EAAE,QAAQ,EAAE,WAAW,EAAE,EAAE,IAAI,EAAE,CAAC,CAAC;gBAC3D,OAAO,EAAE,KAAK;aACf;SACF,CAAC,CAAC;QAEH,MAAM,SAAS,GAAG,IAAI,CAAC,SAAS,CAAC;YAC/B,IAAI,EAAE,sBAAsB;YAC5B,OAAO,EAAE;gBACP,IAAI,EAAE,aAAa;gBACnB,OAAO,EAAE,SAAS;gBAClB,IAAI,EAAE,MAAM;gBACZ,QAAQ,EAAE,IAAI;gBACd,OAAO,EAAE,QAAQ;aAClB;SACF,CAAC,CAAC;QACH,MAAM,CAAC,0BAA0B,CAAC,SAAS,EAAE,EAAE,CAAC,CAAC,CAAC,OAAO,CAAC;YACxD;gBACE,IAAI,EAAE,aAAa;gBACnB,EAAE;gBACF,SAAS,EAAE,SAAS;gBACpB,QAAQ,EAAE,MAAM;gBAChB,OAAO,EAAE,QAAQ;gBACjB,OAAO,EAAE,IAAI;aACd;SACF,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,4DAA4D,EAAE,GAAG,EAAE;QACpE,MAAM,CACJ,0BAA0B,CACxB,IAAI,CAAC,SAAS,CAAC,EAAE,IAAI,EAAE,qBAAqB,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM,EAAE,MAAM,EAAE,KAAK,EAAE,SAAS,EAAE,CAAC,EACrG,EAAE,CACH,CACF,CAAC,OAAO,CAAC;YACR;gBACE,IAAI,EAAE,QAAQ;gBACd,EAAE;gBACF,IAAI,EAAE,MAAM;gBACZ,WAAW,EAAE,CAAC;gBACd,YAAY,EAAE,CAAC;gBACf,YAAY,EAAE,CAAC;gBACf,OAAO,EAAE,CAAC;gBACV,OAAO,EAAE,UAAU;gBACnB,OAAO,EAAE,KAAK;gBACd,MAAM,EAAE,EAAE;aACX;SACF,CAAC,CAAC;QAEH,MAAM,CAAC,0BAA0B,CAAC,YAAY,EAAE,EAAE,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,EAAE,IAAI,EAAE,QAAQ,EAAE,EAAE,EAAE,IAAI,EAAE,YAAY,EAAE,CAAC,CAAC,CAAC;IAC7G,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}