gemini-proxy-client 1.0.10 → 1.0.11
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/browser/manager.js +26 -21
- package/dist/cli.js +1 -1
- package/package.json +1 -1
package/dist/browser/manager.js
CHANGED
|
@@ -189,27 +189,31 @@ export class BrowserManager {
|
|
|
189
189
|
catch (e) {
|
|
190
190
|
// 忽略
|
|
191
191
|
}
|
|
192
|
-
//
|
|
193
|
-
|
|
194
|
-
|
|
195
|
-
|
|
196
|
-
|
|
197
|
-
|
|
198
|
-
|
|
199
|
-
|
|
200
|
-
|
|
201
|
-
|
|
202
|
-
|
|
203
|
-
|
|
204
|
-
|
|
205
|
-
|
|
192
|
+
// 直接使用 evaluate 在 iframe 中执行点击
|
|
193
|
+
// 这样可以绑过任何遮挡问题
|
|
194
|
+
try {
|
|
195
|
+
clicked = await frame.evaluate(() => {
|
|
196
|
+
const btn = document.querySelector('button[title="Connect WebSocket Proxy"]');
|
|
197
|
+
if (btn) {
|
|
198
|
+
// 使用 dispatchEvent 触发真实的点击事件
|
|
199
|
+
const clickEvent = new MouseEvent('click', {
|
|
200
|
+
bubbles: true,
|
|
201
|
+
cancelable: true,
|
|
202
|
+
view: window
|
|
203
|
+
});
|
|
204
|
+
btn.dispatchEvent(clickEvent);
|
|
205
|
+
return true;
|
|
206
206
|
}
|
|
207
|
+
return false;
|
|
208
|
+
});
|
|
209
|
+
if (clicked) {
|
|
210
|
+
console.log(chalk.green('✅ 点击了连接按钮'));
|
|
207
211
|
}
|
|
208
|
-
catch (btnErr) {
|
|
209
|
-
console.log(chalk.gray(` 点击失败: ${btnErr}`));
|
|
210
|
-
}
|
|
211
212
|
}
|
|
212
|
-
|
|
213
|
+
catch (e) {
|
|
214
|
+
console.log(chalk.gray(`evaluate 点击失败: ${e}`));
|
|
215
|
+
}
|
|
216
|
+
// 如果 dispatchEvent 失败,尝试直接调用 onclick
|
|
213
217
|
if (!clicked) {
|
|
214
218
|
try {
|
|
215
219
|
clicked = await frame.evaluate(() => {
|
|
@@ -221,11 +225,11 @@ export class BrowserManager {
|
|
|
221
225
|
return false;
|
|
222
226
|
});
|
|
223
227
|
if (clicked) {
|
|
224
|
-
console.log(chalk.green('✅ 点击了连接按钮 (
|
|
228
|
+
console.log(chalk.green('✅ 点击了连接按钮 (click())'));
|
|
225
229
|
}
|
|
226
230
|
}
|
|
227
231
|
catch (e) {
|
|
228
|
-
console.log(chalk.gray(`
|
|
232
|
+
console.log(chalk.gray(`click() 失败: ${e}`));
|
|
229
233
|
}
|
|
230
234
|
}
|
|
231
235
|
}
|
|
@@ -241,7 +245,7 @@ export class BrowserManager {
|
|
|
241
245
|
// 第四步:等待并验证连接成功(按钮文字变成 "Disconnect WS")
|
|
242
246
|
console.log(chalk.gray('等待 WebSocket 连接...'));
|
|
243
247
|
let connected = false;
|
|
244
|
-
for (let i = 0; i <
|
|
248
|
+
for (let i = 0; i < 15; i++) { // 最多等待 15 秒
|
|
245
249
|
await sleep(1000);
|
|
246
250
|
if (buildAppFrame) {
|
|
247
251
|
try {
|
|
@@ -249,6 +253,7 @@ export class BrowserManager {
|
|
|
249
253
|
const btn = document.querySelector('button[title="Connect WebSocket Proxy"], button[title="Disconnect WebSocket Proxy"]');
|
|
250
254
|
return btn?.textContent?.trim() || '';
|
|
251
255
|
});
|
|
256
|
+
console.log(chalk.gray(` 检测按钮文字: "${buttonText}"`));
|
|
252
257
|
if (buttonText.includes('Disconnect')) {
|
|
253
258
|
connected = true;
|
|
254
259
|
console.log(chalk.green('✅ WebSocket 连接成功!'));
|
package/dist/cli.js
CHANGED