homebridge-melcloud-control 4.0.0-beta.536 → 4.0.0-beta.538

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 (2) hide show
  1. package/package.json +1 -1
  2. package/src/melcloud.js +50 -4
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "displayName": "MELCloud Control",
3
3
  "name": "homebridge-melcloud-control",
4
- "version": "4.0.0-beta.536",
4
+ "version": "4.0.0-beta.538",
5
5
  "description": "Homebridge plugin to control Mitsubishi Air Conditioner, Heat Pump and Energy Recovery Ventilation.",
6
6
  "license": "MIT",
7
7
  "author": "grzegorz914",
package/src/melcloud.js CHANGED
@@ -344,10 +344,56 @@ class MelCloud extends EventEmitter {
344
344
  ]
345
345
  });
346
346
 
347
- const context = await browser.newContext();
348
- const page = await context.newPage();
349
- await page.goto('about:blank');
350
- await context.clearCookies();
347
+ let page;
348
+ if (typeof browser.newPage === 'function') {
349
+ page = await browser.newPage();
350
+ } else {
351
+ // fallback: pages() exists in almost all versions
352
+ const pages = await browser.pages();
353
+ page = pages && pages.length ? pages[0] : await browser.newPage();
354
+ }
355
+
356
+ try {
357
+ // go to about:blank to ensure a clean origin
358
+ await page.goto('about:blank');
359
+
360
+ // prefer context-based clear if available
361
+ const pageContext = (typeof page.browserContext === 'function') ? page.browserContext() : (page.context ? page.context() : null);
362
+
363
+ if (pageContext && typeof pageContext.clearCookies === 'function') {
364
+ // modern API in some puppeteer versions
365
+ await pageContext.clearCookies();
366
+ } else {
367
+ // try CDP directly (works in most environments)
368
+ if (page._client && typeof page._client === 'function') {
369
+ const client = await page._client();
370
+ if (client && client.send) {
371
+ await client.send('Network.clearBrowserCookies');
372
+ } else if (page._client && page._client.send) {
373
+ // some versions expose _client directly as object
374
+ await page._client.send('Network.clearBrowserCookies');
375
+ } else {
376
+ // fallback to deleting cookies returned by page.cookies()
377
+ const cookies = await page.cookies();
378
+ if (cookies && cookies.length) {
379
+ await page.deleteCookie(...cookies).catch(() => { });
380
+ }
381
+ }
382
+ } else if (page._client && page._client.send) {
383
+ // older shape where _client is object
384
+ await page._client.send('Network.clearBrowserCookies');
385
+ } else {
386
+ // final fallback
387
+ const cookies = await page.cookies();
388
+ if (cookies && cookies.length) {
389
+ await page.deleteCookie(...cookies).catch(() => { });
390
+ }
391
+ }
392
+ }
393
+ } catch (clearErr) {
394
+ // nie przerywamy procesu logowania jeśli clear cookies nie zadziała, logujemy tylko warn
395
+ this.emit('warn', `Failed to clear cookies cleanly: ${clearErr.message}`);
396
+ }
351
397
  page.setDefaultTimeout(GLOBAL_TIMEOUT);
352
398
  page.setDefaultNavigationTimeout(GLOBAL_TIMEOUT);
353
399