@react-grab/gemini 0.0.81 → 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 +2 -6
- package/dist/cli.js +3 -6
- package/dist/client.cjs +39 -6
- package/dist/client.global.js +4 -3
- package/dist/client.js +39 -6
- package/dist/server.cjs +7 -8
- package/dist/server.js +7 -8
- package/package.json +5 -4
package/dist/cli.cjs
CHANGED
|
@@ -1,10 +1,8 @@
|
|
|
1
1
|
#!/usr/bin/env node
|
|
2
2
|
'use strict';
|
|
3
3
|
|
|
4
|
-
var url = require('url');
|
|
5
4
|
var path = require('path');
|
|
6
5
|
|
|
7
|
-
var _documentCurrentScript = typeof document !== 'undefined' ? document.currentScript : null;
|
|
8
6
|
var __create = Object.create;
|
|
9
7
|
var __defProp = Object.defineProperty;
|
|
10
8
|
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
@@ -605,10 +603,8 @@ var import_picocolors = __toESM(require_picocolors());
|
|
|
605
603
|
var DEFAULT_PORT = 8567;
|
|
606
604
|
|
|
607
605
|
// src/cli.ts
|
|
608
|
-
var VERSION = "0.0.
|
|
609
|
-
var
|
|
610
|
-
var __dirname$1 = path.dirname(__filename$1);
|
|
611
|
-
var serverPath = path.join(__dirname$1, "server.js");
|
|
606
|
+
var VERSION = "0.0.83";
|
|
607
|
+
var serverPath = path.join(__dirname, "server.cjs");
|
|
612
608
|
(0, import_cross_spawn.default)(process.execPath, [serverPath], {
|
|
613
609
|
detached: true,
|
|
614
610
|
stdio: "ignore"
|
package/dist/cli.js
CHANGED
|
@@ -1,6 +1,5 @@
|
|
|
1
1
|
#!/usr/bin/env node
|
|
2
|
-
import {
|
|
3
|
-
import { dirname, join } from 'path';
|
|
2
|
+
import { join } from 'path';
|
|
4
3
|
|
|
5
4
|
var __create = Object.create;
|
|
6
5
|
var __defProp = Object.defineProperty;
|
|
@@ -602,10 +601,8 @@ var import_picocolors = __toESM(require_picocolors());
|
|
|
602
601
|
var DEFAULT_PORT = 8567;
|
|
603
602
|
|
|
604
603
|
// src/cli.ts
|
|
605
|
-
var VERSION = "0.0.
|
|
606
|
-
var
|
|
607
|
-
var __dirname = dirname(__filename);
|
|
608
|
-
var serverPath = join(__dirname, "server.js");
|
|
604
|
+
var VERSION = "0.0.83";
|
|
605
|
+
var serverPath = join(__dirname, "server.cjs");
|
|
609
606
|
(0, import_cross_spawn.default)(process.execPath, [serverPath], {
|
|
610
607
|
detached: true,
|
|
611
608
|
stdio: "ignore"
|
package/dist/client.cjs
CHANGED
|
@@ -1,11 +1,7 @@
|
|
|
1
1
|
'use strict';
|
|
2
2
|
|
|
3
|
-
//
|
|
4
|
-
var DEFAULT_PORT = 8567;
|
|
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
6
|
var parseSSEEvent = (eventBlock) => {
|
|
11
7
|
let eventType = "";
|
|
@@ -56,7 +52,14 @@ async function* streamSSE(stream, signal) {
|
|
|
56
52
|
}
|
|
57
53
|
}
|
|
58
54
|
}
|
|
55
|
+
|
|
56
|
+
// src/constants.ts
|
|
57
|
+
var DEFAULT_PORT = 8567;
|
|
58
|
+
|
|
59
|
+
// src/client.ts
|
|
60
|
+
var DEFAULT_SERVER_URL = `http://localhost:${DEFAULT_PORT}`;
|
|
59
61
|
async function* streamFromServer(serverUrl, context, signal) {
|
|
62
|
+
const startTime = Date.now();
|
|
60
63
|
const sessionId = context.sessionId;
|
|
61
64
|
const handleAbort = () => {
|
|
62
65
|
if (sessionId) {
|
|
@@ -80,7 +83,37 @@ async function* streamFromServer(serverUrl, context, signal) {
|
|
|
80
83
|
if (!response.body) {
|
|
81
84
|
throw new Error("No response body");
|
|
82
85
|
}
|
|
83
|
-
|
|
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
|
+
}
|
|
84
117
|
} finally {
|
|
85
118
|
signal.removeEventListener("abort", handleAbort);
|
|
86
119
|
}
|
package/dist/client.global.js
CHANGED
|
@@ -1,4 +1,5 @@
|
|
|
1
|
-
var ReactGrabGemini=(function(exports){'use strict';var u
|
|
2
|
-
`))n.startsWith("event:")?t=n.slice(6).trim():n.startsWith("data:")&&(o=n.slice(5).trim());return {eventType:t,data:o}};async function*
|
|
1
|
+
var ReactGrabGemini=(function(exports){'use strict';var u=5e3,f="react-grab:agent-sessions",y=c=>{let t="",o="";for(let n of c.split(`
|
|
2
|
+
`))n.startsWith("event:")?t=n.slice(6).trim():n.startsWith("data:")&&(o=n.slice(5).trim());return {eventType:t,data:o}};async function*g(c,t){let o=c.getReader(),n=new TextDecoder,r="",e=false,i=()=>{e=true,o.cancel().catch(()=>{});};t.addEventListener("abort",i);try{if(t.aborted)throw new DOMException("Aborted","AbortError");for(;;){let a=await o.read();if(e||t.aborted)throw new DOMException("Aborted","AbortError");let{done:l,value:m}=a;m&&(r+=n.decode(m,{stream:!0}));let d;for(;(d=r.indexOf(`
|
|
3
3
|
|
|
4
|
-
`))!==-1;){let{eventType:
|
|
4
|
+
`))!==-1;){let{eventType:s,data:p}=y(r.slice(0,d));if(r=r.slice(d+2),s==="done")return;if(s==="error")throw new Error(p||"Agent error");p&&(yield p);}if(l)break}}finally{t.removeEventListener("abort",i);try{o.releaseLock();}catch{}}}var E=`http://localhost:${8567}`;async function*A(c,t,o){let n=Date.now(),r=t.sessionId,e=()=>{r&&fetch(`${c}/abort/${r}`,{method:"POST"}).catch(()=>{});};o.addEventListener("abort",e);try{let i=await fetch(`${c}/agent`,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify(t),signal:o});if(!i.ok)throw new Error(`Server error: ${i.status}`);if(!i.body)throw new Error("No response body");let a=g(i.body,o)[Symbol.asyncIterator](),l=!1,m=a.next();for(;!l;){let d=await Promise.race([m.then(s=>({type:"status",iteratorResult:s})),new Promise(s=>setTimeout(()=>s({type:"timeout"}),100))]);if(d.type==="timeout")yield `Working\u2026 ${((Date.now()-n)/1e3).toFixed(1)}s`;else {let s=d.iteratorResult;if(l=s.done??!1,!l&&s.value){let p=s.value;p==="Completed successfully"?yield `Completed in ${((Date.now()-n)/1e3).toFixed(1)}s`:yield p,m=a.next();}}}}finally{o.removeEventListener("abort",e);}}var b=(c={})=>{let{serverUrl:t=E,getOptions:o}=c,n=null,r=e=>({...o?.()??{},...e??{}});return {send:async function*(e,i){let a={...e,options:r(e.options)};yield*A(t,a,i);},resume:async function*(e,i,a){let l=a.getItem(f);if(!l)throw new Error("No sessions to resume");let d=JSON.parse(l)[e];if(!d)throw new Error(`Session ${e} not found`);let s=d.context,p={...s,options:r(s.options)};yield "Resuming...",yield*A(t,p,i);},supportsResume:true,supportsFollowUp:true,checkConnection:async()=>{let e=Date.now();if(n&&e-n.timestamp<u)return n.result;try{let a=(await fetch(`${t}/health`,{method:"GET"})).ok;return n={result:a,timestamp:e},a}catch{return n={result:false,timestamp:e},false}},abort:async e=>{try{await fetch(`${t}/abort/${e}`,{method:"POST"});}catch{}}}},h=async()=>{if(typeof window>"u")return;let c=b(),t=r=>{r.setAgent({provider:c,storage:sessionStorage});},o=window.__REACT_GRAB__;if(o){t(o);return}window.addEventListener("react-grab:init",r=>{t(r.detail);},{once:true});let n=window.__REACT_GRAB__;n&&t(n);};h();
|
|
5
|
+
exports.attachAgent=h;exports.createGeminiAgentProvider=b;return exports;})({});
|
package/dist/client.js
CHANGED
|
@@ -1,9 +1,5 @@
|
|
|
1
|
-
//
|
|
2
|
-
var DEFAULT_PORT = 8567;
|
|
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
4
|
var parseSSEEvent = (eventBlock) => {
|
|
9
5
|
let eventType = "";
|
|
@@ -54,7 +50,14 @@ async function* streamSSE(stream, signal) {
|
|
|
54
50
|
}
|
|
55
51
|
}
|
|
56
52
|
}
|
|
53
|
+
|
|
54
|
+
// src/constants.ts
|
|
55
|
+
var DEFAULT_PORT = 8567;
|
|
56
|
+
|
|
57
|
+
// src/client.ts
|
|
58
|
+
var DEFAULT_SERVER_URL = `http://localhost:${DEFAULT_PORT}`;
|
|
57
59
|
async function* streamFromServer(serverUrl, context, signal) {
|
|
60
|
+
const startTime = Date.now();
|
|
58
61
|
const sessionId = context.sessionId;
|
|
59
62
|
const handleAbort = () => {
|
|
60
63
|
if (sessionId) {
|
|
@@ -78,7 +81,37 @@ async function* streamFromServer(serverUrl, context, signal) {
|
|
|
78
81
|
if (!response.body) {
|
|
79
82
|
throw new Error("No response body");
|
|
80
83
|
}
|
|
81
|
-
|
|
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
|
+
}
|
|
82
115
|
} finally {
|
|
83
116
|
signal.removeEventListener("abort", handleAbort);
|
|
84
117
|
}
|
package/dist/server.cjs
CHANGED
|
@@ -5830,8 +5830,11 @@ var import_picocolors = __toESM(require_picocolors());
|
|
|
5830
5830
|
// src/constants.ts
|
|
5831
5831
|
var DEFAULT_PORT = 8567;
|
|
5832
5832
|
|
|
5833
|
+
// ../utils/dist/server.js
|
|
5834
|
+
var sleep = (ms) => new Promise((resolve) => setTimeout(resolve, ms));
|
|
5835
|
+
|
|
5833
5836
|
// src/server.ts
|
|
5834
|
-
var VERSION = "0.0.
|
|
5837
|
+
var VERSION = "0.0.83";
|
|
5835
5838
|
var geminiSessionMap = /* @__PURE__ */ new Map();
|
|
5836
5839
|
var activeProcesses = /* @__PURE__ */ new Map();
|
|
5837
5840
|
var parseStreamLine = (line) => {
|
|
@@ -5855,19 +5858,14 @@ var createServer = () => {
|
|
|
5855
5858
|
|
|
5856
5859
|
${content}`;
|
|
5857
5860
|
return streamSSE(context, async (stream2) => {
|
|
5858
|
-
const geminiArgs = [
|
|
5859
|
-
"--prompt",
|
|
5860
|
-
userPrompt,
|
|
5861
|
-
"--output-format",
|
|
5862
|
-
"stream-json",
|
|
5863
|
-
"--yolo"
|
|
5864
|
-
];
|
|
5861
|
+
const geminiArgs = ["--output-format", "stream-json", "--yolo"];
|
|
5865
5862
|
if (options?.model) {
|
|
5866
5863
|
geminiArgs.push("--model", options.model);
|
|
5867
5864
|
}
|
|
5868
5865
|
if (options?.includeDirectories) {
|
|
5869
5866
|
geminiArgs.push("--include-directories", options.includeDirectories);
|
|
5870
5867
|
}
|
|
5868
|
+
geminiArgs.push(userPrompt);
|
|
5871
5869
|
let geminiProcess;
|
|
5872
5870
|
let stderrBuffer = "";
|
|
5873
5871
|
try {
|
|
@@ -6012,6 +6010,7 @@ ${stderrContent}` : errorMessage;
|
|
|
6012
6010
|
var startServer = async (port = DEFAULT_PORT) => {
|
|
6013
6011
|
await fkill(`:${port}`, { force: true, silent: true }).catch(() => {
|
|
6014
6012
|
});
|
|
6013
|
+
await sleep(100);
|
|
6015
6014
|
const app = createServer();
|
|
6016
6015
|
serve({ fetch: app.fetch, port });
|
|
6017
6016
|
console.log(`${import_picocolors.default.magenta("\u269B")} ${import_picocolors.default.bold("React Grab")} ${import_picocolors.default.gray(VERSION)} ${import_picocolors.default.dim("(Gemini)")}`);
|
package/dist/server.js
CHANGED
|
@@ -5819,8 +5819,11 @@ var import_picocolors = __toESM(require_picocolors());
|
|
|
5819
5819
|
// src/constants.ts
|
|
5820
5820
|
var DEFAULT_PORT = 8567;
|
|
5821
5821
|
|
|
5822
|
+
// ../utils/dist/server.js
|
|
5823
|
+
var sleep = (ms) => new Promise((resolve) => setTimeout(resolve, ms));
|
|
5824
|
+
|
|
5822
5825
|
// src/server.ts
|
|
5823
|
-
var VERSION = "0.0.
|
|
5826
|
+
var VERSION = "0.0.83";
|
|
5824
5827
|
var geminiSessionMap = /* @__PURE__ */ new Map();
|
|
5825
5828
|
var activeProcesses = /* @__PURE__ */ new Map();
|
|
5826
5829
|
var parseStreamLine = (line) => {
|
|
@@ -5844,19 +5847,14 @@ var createServer = () => {
|
|
|
5844
5847
|
|
|
5845
5848
|
${content}`;
|
|
5846
5849
|
return streamSSE(context, async (stream2) => {
|
|
5847
|
-
const geminiArgs = [
|
|
5848
|
-
"--prompt",
|
|
5849
|
-
userPrompt,
|
|
5850
|
-
"--output-format",
|
|
5851
|
-
"stream-json",
|
|
5852
|
-
"--yolo"
|
|
5853
|
-
];
|
|
5850
|
+
const geminiArgs = ["--output-format", "stream-json", "--yolo"];
|
|
5854
5851
|
if (options?.model) {
|
|
5855
5852
|
geminiArgs.push("--model", options.model);
|
|
5856
5853
|
}
|
|
5857
5854
|
if (options?.includeDirectories) {
|
|
5858
5855
|
geminiArgs.push("--include-directories", options.includeDirectories);
|
|
5859
5856
|
}
|
|
5857
|
+
geminiArgs.push(userPrompt);
|
|
5860
5858
|
let geminiProcess;
|
|
5861
5859
|
let stderrBuffer = "";
|
|
5862
5860
|
try {
|
|
@@ -6001,6 +5999,7 @@ ${stderrContent}` : errorMessage;
|
|
|
6001
5999
|
var startServer = async (port = DEFAULT_PORT) => {
|
|
6002
6000
|
await fkill(`:${port}`, { force: true, silent: true }).catch(() => {
|
|
6003
6001
|
});
|
|
6002
|
+
await sleep(100);
|
|
6004
6003
|
const app = createServer();
|
|
6005
6004
|
serve({ fetch: app.fetch, port });
|
|
6006
6005
|
console.log(`${import_picocolors.default.magenta("\u269B")} ${import_picocolors.default.bold("React Grab")} ${import_picocolors.default.gray(VERSION)} ${import_picocolors.default.dim("(Gemini)")}`);
|
package/package.json
CHANGED
|
@@ -1,9 +1,9 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@react-grab/gemini",
|
|
3
|
-
"version": "0.0.
|
|
3
|
+
"version": "0.0.83",
|
|
4
4
|
"type": "module",
|
|
5
5
|
"bin": {
|
|
6
|
-
"react-grab-gemini": "./dist/cli.
|
|
6
|
+
"react-grab-gemini": "./dist/cli.cjs"
|
|
7
7
|
},
|
|
8
8
|
"exports": {
|
|
9
9
|
"./client": {
|
|
@@ -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",
|
|
@@ -33,7 +34,7 @@
|
|
|
33
34
|
"fkill": "^9.0.0",
|
|
34
35
|
"hono": "^4.0.0",
|
|
35
36
|
"picocolors": "^1.1.1",
|
|
36
|
-
"react-grab": "0.0.
|
|
37
|
+
"react-grab": "0.0.83"
|
|
37
38
|
},
|
|
38
39
|
"scripts": {
|
|
39
40
|
"dev": "tsup --watch",
|