@react-grab/opencode 0.0.82 → 0.0.83
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/dist/cli.cjs +1 -1
- package/dist/cli.js +1 -1
- package/dist/client.cjs +54 -23
- package/dist/client.global.js +4 -3
- package/dist/client.js +54 -23
- package/dist/server.cjs +4 -2
- package/dist/server.js +4 -2
- package/package.json +4 -3
package/dist/cli.cjs
CHANGED
|
@@ -603,7 +603,7 @@ var import_picocolors = __toESM(require_picocolors());
|
|
|
603
603
|
var DEFAULT_PORT = 6567;
|
|
604
604
|
|
|
605
605
|
// src/cli.ts
|
|
606
|
-
var VERSION = "0.0.
|
|
606
|
+
var VERSION = "0.0.83";
|
|
607
607
|
var serverPath = path.join(__dirname, "server.cjs");
|
|
608
608
|
(0, import_cross_spawn.default)(process.execPath, [serverPath], {
|
|
609
609
|
detached: true,
|
package/dist/cli.js
CHANGED
|
@@ -601,7 +601,7 @@ var import_picocolors = __toESM(require_picocolors());
|
|
|
601
601
|
var DEFAULT_PORT = 6567;
|
|
602
602
|
|
|
603
603
|
// src/cli.ts
|
|
604
|
-
var VERSION = "0.0.
|
|
604
|
+
var VERSION = "0.0.83";
|
|
605
605
|
var serverPath = join(__dirname, "server.cjs");
|
|
606
606
|
(0, import_cross_spawn.default)(process.execPath, [serverPath], {
|
|
607
607
|
detached: true,
|
package/dist/client.cjs
CHANGED
|
@@ -1,29 +1,25 @@
|
|
|
1
1
|
'use strict';
|
|
2
2
|
|
|
3
|
-
//
|
|
4
|
-
var DEFAULT_PORT = 6567;
|
|
3
|
+
// ../utils/dist/client.js
|
|
5
4
|
var CONNECTION_CHECK_TTL_MS = 5e3;
|
|
6
|
-
|
|
7
|
-
// src/client.ts
|
|
8
|
-
var DEFAULT_SERVER_URL = `http://localhost:${DEFAULT_PORT}`;
|
|
9
5
|
var STORAGE_KEY = "react-grab:agent-sessions";
|
|
10
|
-
var
|
|
6
|
+
var parseSSEEvent = (eventBlock) => {
|
|
11
7
|
let eventType = "";
|
|
12
8
|
let data = "";
|
|
13
|
-
for (const line of
|
|
9
|
+
for (const line of eventBlock.split("\n")) {
|
|
14
10
|
if (line.startsWith("event:")) eventType = line.slice(6).trim();
|
|
15
11
|
else if (line.startsWith("data:")) data = line.slice(5).trim();
|
|
16
12
|
}
|
|
17
13
|
return { eventType, data };
|
|
18
14
|
};
|
|
19
|
-
|
|
20
|
-
const
|
|
21
|
-
const
|
|
22
|
-
let
|
|
15
|
+
async function* streamSSE(stream, signal) {
|
|
16
|
+
const reader = stream.getReader();
|
|
17
|
+
const decoder = new TextDecoder();
|
|
18
|
+
let buffer = "";
|
|
23
19
|
let aborted = false;
|
|
24
20
|
const onAbort = () => {
|
|
25
21
|
aborted = true;
|
|
26
|
-
|
|
22
|
+
reader.cancel().catch(() => {
|
|
27
23
|
});
|
|
28
24
|
};
|
|
29
25
|
signal.addEventListener("abort", onAbort);
|
|
@@ -32,18 +28,16 @@ var streamSSE = async function* (stream, signal) {
|
|
|
32
28
|
throw new DOMException("Aborted", "AbortError");
|
|
33
29
|
}
|
|
34
30
|
while (true) {
|
|
35
|
-
const result = await
|
|
31
|
+
const result = await reader.read();
|
|
36
32
|
if (aborted || signal.aborted) {
|
|
37
33
|
throw new DOMException("Aborted", "AbortError");
|
|
38
34
|
}
|
|
39
35
|
const { done, value } = result;
|
|
40
|
-
if (value)
|
|
41
|
-
let
|
|
42
|
-
while ((
|
|
43
|
-
const { eventType, data } =
|
|
44
|
-
|
|
45
|
-
);
|
|
46
|
-
textBuffer = textBuffer.slice(boundaryIndex + 2);
|
|
36
|
+
if (value) buffer += decoder.decode(value, { stream: true });
|
|
37
|
+
let boundary;
|
|
38
|
+
while ((boundary = buffer.indexOf("\n\n")) !== -1) {
|
|
39
|
+
const { eventType, data } = parseSSEEvent(buffer.slice(0, boundary));
|
|
40
|
+
buffer = buffer.slice(boundary + 2);
|
|
47
41
|
if (eventType === "done") return;
|
|
48
42
|
if (eventType === "error") throw new Error(data || "Agent error");
|
|
49
43
|
if (data) yield data;
|
|
@@ -53,12 +47,19 @@ var streamSSE = async function* (stream, signal) {
|
|
|
53
47
|
} finally {
|
|
54
48
|
signal.removeEventListener("abort", onAbort);
|
|
55
49
|
try {
|
|
56
|
-
|
|
50
|
+
reader.releaseLock();
|
|
57
51
|
} catch {
|
|
58
52
|
}
|
|
59
53
|
}
|
|
60
|
-
}
|
|
54
|
+
}
|
|
55
|
+
|
|
56
|
+
// src/constants.ts
|
|
57
|
+
var DEFAULT_PORT = 6567;
|
|
58
|
+
|
|
59
|
+
// src/client.ts
|
|
60
|
+
var DEFAULT_SERVER_URL = `http://localhost:${DEFAULT_PORT}`;
|
|
61
61
|
var streamFromServer = async function* (serverUrl, context, signal) {
|
|
62
|
+
const startTime = Date.now();
|
|
62
63
|
const sessionId = context.sessionId;
|
|
63
64
|
const handleAbort = () => {
|
|
64
65
|
if (sessionId) {
|
|
@@ -82,7 +83,37 @@ var streamFromServer = async function* (serverUrl, context, signal) {
|
|
|
82
83
|
if (!response.body) {
|
|
83
84
|
throw new Error("No response body");
|
|
84
85
|
}
|
|
85
|
-
|
|
86
|
+
const iterator = streamSSE(response.body, signal)[Symbol.asyncIterator]();
|
|
87
|
+
let done = false;
|
|
88
|
+
let pendingNext = iterator.next();
|
|
89
|
+
while (!done) {
|
|
90
|
+
const result = await Promise.race([
|
|
91
|
+
pendingNext.then((iteratorResult) => ({
|
|
92
|
+
type: "status",
|
|
93
|
+
iteratorResult
|
|
94
|
+
})),
|
|
95
|
+
new Promise(
|
|
96
|
+
(resolve) => setTimeout(() => resolve({ type: "timeout" }), 100)
|
|
97
|
+
)
|
|
98
|
+
]);
|
|
99
|
+
if (result.type === "timeout") {
|
|
100
|
+
const elapsedSeconds = (Date.now() - startTime) / 1e3;
|
|
101
|
+
yield `Working\u2026 ${elapsedSeconds.toFixed(1)}s`;
|
|
102
|
+
} else {
|
|
103
|
+
const iteratorResult = result.iteratorResult;
|
|
104
|
+
done = iteratorResult.done ?? false;
|
|
105
|
+
if (!done && iteratorResult.value) {
|
|
106
|
+
const status = iteratorResult.value;
|
|
107
|
+
if (status === "Completed successfully") {
|
|
108
|
+
const totalSeconds = ((Date.now() - startTime) / 1e3).toFixed(1);
|
|
109
|
+
yield `Completed in ${totalSeconds}s`;
|
|
110
|
+
} else {
|
|
111
|
+
yield status;
|
|
112
|
+
}
|
|
113
|
+
pendingNext = iterator.next();
|
|
114
|
+
}
|
|
115
|
+
}
|
|
116
|
+
}
|
|
86
117
|
} finally {
|
|
87
118
|
signal.removeEventListener("abort", handleAbort);
|
|
88
119
|
}
|
package/dist/client.global.js
CHANGED
|
@@ -1,4 +1,5 @@
|
|
|
1
|
-
var ReactGrabOpencode=(function(exports){'use strict';var m
|
|
2
|
-
`))
|
|
1
|
+
var ReactGrabOpencode=(function(exports){'use strict';var f=5e3,m="react-grab:agent-sessions",y=c=>{let e="",n="";for(let t of c.split(`
|
|
2
|
+
`))t.startsWith("event:")?e=t.slice(6).trim():t.startsWith("data:")&&(n=t.slice(5).trim());return {eventType:e,data:n}};async function*g(c,e){let n=c.getReader(),t=new TextDecoder,r="",o=false,i=()=>{o=true,n.cancel().catch(()=>{});};e.addEventListener("abort",i);try{if(e.aborted)throw new DOMException("Aborted","AbortError");for(;;){let a=await n.read();if(o||e.aborted)throw new DOMException("Aborted","AbortError");let{done:p,value:u}=a;u&&(r+=t.decode(u,{stream:!0}));let d;for(;(d=r.indexOf(`
|
|
3
3
|
|
|
4
|
-
`))!==-1;){let{eventType:
|
|
4
|
+
`))!==-1;){let{eventType:s,data:l}=y(r.slice(0,d));if(r=r.slice(d+2),s==="done")return;if(s==="error")throw new Error(l||"Agent error");l&&(yield l);}if(p)break}}finally{e.removeEventListener("abort",i);try{n.releaseLock();}catch{}}}var E=`http://localhost:${6567}`,A=async function*(c,e,n){let t=Date.now(),r=e.sessionId,o=()=>{r&&fetch(`${c}/abort/${r}`,{method:"POST"}).catch(()=>{});};n.addEventListener("abort",o);try{let i=await fetch(`${c}/agent`,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify(e),signal:n});if(!i.ok)throw new Error(`Server error: ${i.status}`);if(!i.body)throw new Error("No response body");let a=g(i.body,n)[Symbol.asyncIterator](),p=!1,u=a.next();for(;!p;){let d=await Promise.race([u.then(s=>({type:"status",iteratorResult:s})),new Promise(s=>setTimeout(()=>s({type:"timeout"}),100))]);if(d.type==="timeout")yield `Working\u2026 ${((Date.now()-t)/1e3).toFixed(1)}s`;else {let s=d.iteratorResult;if(p=s.done??!1,!p&&s.value){let l=s.value;l==="Completed successfully"?yield `Completed in ${((Date.now()-t)/1e3).toFixed(1)}s`:yield l,u=a.next();}}}}finally{n.removeEventListener("abort",o);}},O=(c={})=>{let{serverUrl:e=E,getOptions:n}=c,t=null,r=o=>({...n?.()??{},...o??{}});return {send:async function*(o,i){let a={...o,options:r(o.options)};yield*A(e,a,i);},resume:async function*(o,i,a){let p=a.getItem(m);if(!p)throw new Error("No sessions to resume");let d=JSON.parse(p)[o];if(!d)throw new Error(`Session ${o} not found`);let s=d.context,l={...s,options:r(s.options)};yield "Resuming...",yield*A(e,l,i);},supportsResume:true,supportsFollowUp:true,checkConnection:async()=>{let o=Date.now();if(t&&o-t.timestamp<f)return t.result;try{let a=(await fetch(`${e}/health`,{method:"GET"})).ok;return t={result:a,timestamp:o},a}catch{return t={result:false,timestamp:o},false}},undo:async()=>{try{await fetch(`${e}/undo`,{method:"POST"});}catch{}}}},S=async()=>{if(typeof window>"u")return;let c=O(),e=r=>{r.setAgent({provider:c,storage:sessionStorage});},n=window.__REACT_GRAB__;if(n){e(n);return}window.addEventListener("react-grab:init",r=>{e(r.detail);},{once:true});let t=window.__REACT_GRAB__;t&&e(t);};S();
|
|
5
|
+
exports.attachAgent=S;exports.createOpencodeAgentProvider=O;return exports;})({});
|
package/dist/client.js
CHANGED
|
@@ -1,27 +1,23 @@
|
|
|
1
|
-
//
|
|
2
|
-
var DEFAULT_PORT = 6567;
|
|
1
|
+
// ../utils/dist/client.js
|
|
3
2
|
var CONNECTION_CHECK_TTL_MS = 5e3;
|
|
4
|
-
|
|
5
|
-
// src/client.ts
|
|
6
|
-
var DEFAULT_SERVER_URL = `http://localhost:${DEFAULT_PORT}`;
|
|
7
3
|
var STORAGE_KEY = "react-grab:agent-sessions";
|
|
8
|
-
var
|
|
4
|
+
var parseSSEEvent = (eventBlock) => {
|
|
9
5
|
let eventType = "";
|
|
10
6
|
let data = "";
|
|
11
|
-
for (const line of
|
|
7
|
+
for (const line of eventBlock.split("\n")) {
|
|
12
8
|
if (line.startsWith("event:")) eventType = line.slice(6).trim();
|
|
13
9
|
else if (line.startsWith("data:")) data = line.slice(5).trim();
|
|
14
10
|
}
|
|
15
11
|
return { eventType, data };
|
|
16
12
|
};
|
|
17
|
-
|
|
18
|
-
const
|
|
19
|
-
const
|
|
20
|
-
let
|
|
13
|
+
async function* streamSSE(stream, signal) {
|
|
14
|
+
const reader = stream.getReader();
|
|
15
|
+
const decoder = new TextDecoder();
|
|
16
|
+
let buffer = "";
|
|
21
17
|
let aborted = false;
|
|
22
18
|
const onAbort = () => {
|
|
23
19
|
aborted = true;
|
|
24
|
-
|
|
20
|
+
reader.cancel().catch(() => {
|
|
25
21
|
});
|
|
26
22
|
};
|
|
27
23
|
signal.addEventListener("abort", onAbort);
|
|
@@ -30,18 +26,16 @@ var streamSSE = async function* (stream, signal) {
|
|
|
30
26
|
throw new DOMException("Aborted", "AbortError");
|
|
31
27
|
}
|
|
32
28
|
while (true) {
|
|
33
|
-
const result = await
|
|
29
|
+
const result = await reader.read();
|
|
34
30
|
if (aborted || signal.aborted) {
|
|
35
31
|
throw new DOMException("Aborted", "AbortError");
|
|
36
32
|
}
|
|
37
33
|
const { done, value } = result;
|
|
38
|
-
if (value)
|
|
39
|
-
let
|
|
40
|
-
while ((
|
|
41
|
-
const { eventType, data } =
|
|
42
|
-
|
|
43
|
-
);
|
|
44
|
-
textBuffer = textBuffer.slice(boundaryIndex + 2);
|
|
34
|
+
if (value) buffer += decoder.decode(value, { stream: true });
|
|
35
|
+
let boundary;
|
|
36
|
+
while ((boundary = buffer.indexOf("\n\n")) !== -1) {
|
|
37
|
+
const { eventType, data } = parseSSEEvent(buffer.slice(0, boundary));
|
|
38
|
+
buffer = buffer.slice(boundary + 2);
|
|
45
39
|
if (eventType === "done") return;
|
|
46
40
|
if (eventType === "error") throw new Error(data || "Agent error");
|
|
47
41
|
if (data) yield data;
|
|
@@ -51,12 +45,19 @@ var streamSSE = async function* (stream, signal) {
|
|
|
51
45
|
} finally {
|
|
52
46
|
signal.removeEventListener("abort", onAbort);
|
|
53
47
|
try {
|
|
54
|
-
|
|
48
|
+
reader.releaseLock();
|
|
55
49
|
} catch {
|
|
56
50
|
}
|
|
57
51
|
}
|
|
58
|
-
}
|
|
52
|
+
}
|
|
53
|
+
|
|
54
|
+
// src/constants.ts
|
|
55
|
+
var DEFAULT_PORT = 6567;
|
|
56
|
+
|
|
57
|
+
// src/client.ts
|
|
58
|
+
var DEFAULT_SERVER_URL = `http://localhost:${DEFAULT_PORT}`;
|
|
59
59
|
var streamFromServer = async function* (serverUrl, context, signal) {
|
|
60
|
+
const startTime = Date.now();
|
|
60
61
|
const sessionId = context.sessionId;
|
|
61
62
|
const handleAbort = () => {
|
|
62
63
|
if (sessionId) {
|
|
@@ -80,7 +81,37 @@ var streamFromServer = async function* (serverUrl, context, signal) {
|
|
|
80
81
|
if (!response.body) {
|
|
81
82
|
throw new Error("No response body");
|
|
82
83
|
}
|
|
83
|
-
|
|
84
|
+
const iterator = streamSSE(response.body, signal)[Symbol.asyncIterator]();
|
|
85
|
+
let done = false;
|
|
86
|
+
let pendingNext = iterator.next();
|
|
87
|
+
while (!done) {
|
|
88
|
+
const result = await Promise.race([
|
|
89
|
+
pendingNext.then((iteratorResult) => ({
|
|
90
|
+
type: "status",
|
|
91
|
+
iteratorResult
|
|
92
|
+
})),
|
|
93
|
+
new Promise(
|
|
94
|
+
(resolve) => setTimeout(() => resolve({ type: "timeout" }), 100)
|
|
95
|
+
)
|
|
96
|
+
]);
|
|
97
|
+
if (result.type === "timeout") {
|
|
98
|
+
const elapsedSeconds = (Date.now() - startTime) / 1e3;
|
|
99
|
+
yield `Working\u2026 ${elapsedSeconds.toFixed(1)}s`;
|
|
100
|
+
} else {
|
|
101
|
+
const iteratorResult = result.iteratorResult;
|
|
102
|
+
done = iteratorResult.done ?? false;
|
|
103
|
+
if (!done && iteratorResult.value) {
|
|
104
|
+
const status = iteratorResult.value;
|
|
105
|
+
if (status === "Completed successfully") {
|
|
106
|
+
const totalSeconds = ((Date.now() - startTime) / 1e3).toFixed(1);
|
|
107
|
+
yield `Completed in ${totalSeconds}s`;
|
|
108
|
+
} else {
|
|
109
|
+
yield status;
|
|
110
|
+
}
|
|
111
|
+
pendingNext = iterator.next();
|
|
112
|
+
}
|
|
113
|
+
}
|
|
114
|
+
}
|
|
84
115
|
} finally {
|
|
85
116
|
signal.removeEventListener("abort", handleAbort);
|
|
86
117
|
}
|
package/dist/server.cjs
CHANGED
|
@@ -7339,9 +7339,11 @@ var import_picocolors = __toESM(require_picocolors());
|
|
|
7339
7339
|
|
|
7340
7340
|
// src/constants.ts
|
|
7341
7341
|
var DEFAULT_PORT = 6567;
|
|
7342
|
-
|
|
7343
|
-
|
|
7342
|
+
|
|
7343
|
+
// ../utils/dist/server.js
|
|
7344
7344
|
var sleep = (ms) => new Promise((resolve) => setTimeout(resolve, ms));
|
|
7345
|
+
var VERSION = "0.0.83";
|
|
7346
|
+
var OPENCODE_SDK_PORT = 4096;
|
|
7345
7347
|
var opencodeInstance = null;
|
|
7346
7348
|
var sessionMap = /* @__PURE__ */ new Map();
|
|
7347
7349
|
var abortedSessions = /* @__PURE__ */ new Set();
|
package/dist/server.js
CHANGED
|
@@ -7328,9 +7328,11 @@ var import_picocolors = __toESM(require_picocolors());
|
|
|
7328
7328
|
|
|
7329
7329
|
// src/constants.ts
|
|
7330
7330
|
var DEFAULT_PORT = 6567;
|
|
7331
|
-
|
|
7332
|
-
|
|
7331
|
+
|
|
7332
|
+
// ../utils/dist/server.js
|
|
7333
7333
|
var sleep = (ms) => new Promise((resolve) => setTimeout(resolve, ms));
|
|
7334
|
+
var VERSION = "0.0.83";
|
|
7335
|
+
var OPENCODE_SDK_PORT = 4096;
|
|
7334
7336
|
var opencodeInstance = null;
|
|
7335
7337
|
var sessionMap = /* @__PURE__ */ new Map();
|
|
7336
7338
|
var abortedSessions = /* @__PURE__ */ new Set();
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@react-grab/opencode",
|
|
3
|
-
"version": "0.0.
|
|
3
|
+
"version": "0.0.83",
|
|
4
4
|
"type": "module",
|
|
5
5
|
"bin": {
|
|
6
6
|
"react-grab-opencode": "./dist/cli.cjs"
|
|
@@ -25,7 +25,8 @@
|
|
|
25
25
|
],
|
|
26
26
|
"devDependencies": {
|
|
27
27
|
"@types/cross-spawn": "^6.0.6",
|
|
28
|
-
"tsup": "^8.4.0"
|
|
28
|
+
"tsup": "^8.4.0",
|
|
29
|
+
"@react-grab/utils": "0.0.83"
|
|
29
30
|
},
|
|
30
31
|
"dependencies": {
|
|
31
32
|
"@hono/node-server": "^1.19.6",
|
|
@@ -34,7 +35,7 @@
|
|
|
34
35
|
"fkill": "^9.0.0",
|
|
35
36
|
"hono": "^4.0.0",
|
|
36
37
|
"picocolors": "^1.1.1",
|
|
37
|
-
"react-grab": "0.0.
|
|
38
|
+
"react-grab": "0.0.83"
|
|
38
39
|
},
|
|
39
40
|
"scripts": {
|
|
40
41
|
"dev": "tsup --watch",
|