@open-wa/wa-automate 4.35.10 → 4.35.13

Sign up to get free protection for your applications and to get access to all the features.
@@ -453,6 +453,10 @@ export declare class Client {
453
453
  * @returns `Promise<LiveLocationChangedEvent []>` | boolean
454
454
  */
455
455
  forceUpdateLiveLocation(chatId: ChatId): Promise<LiveLocationChangedEvent[] | boolean>;
456
+ /**
457
+ * Test the button commands on MD accounts with an insiders key. This is a temporary feature to help fix issue #2658
458
+ */
459
+ testButtons(chatId: ChatId): Promise<any>;
456
460
  private link;
457
461
  /**
458
462
  * Sends a text message to given chat
@@ -701,6 +705,11 @@ export declare class Client {
701
705
  * @returns `Promise<DataURL>`
702
706
  */
703
707
  getSnapshot(chatId?: ChatId): Promise<DataURL>;
708
+ /**
709
+ * Returns some metrics of the session/page.
710
+ * @returns `Promise<any>`
711
+ */
712
+ metrics(): Promise<any>;
704
713
  /**
705
714
  * Returns an array of group ids where the host account is admin
706
715
  */
@@ -1197,6 +1197,14 @@ class Client {
1197
1197
  return yield this.pup(({ chatId }) => WAPI.forceUpdateLiveLocation(chatId), { chatId });
1198
1198
  });
1199
1199
  }
1200
+ /**
1201
+ * Test the button commands on MD accounts with an insiders key. This is a temporary feature to help fix issue #2658
1202
+ */
1203
+ testButtons(chatId) {
1204
+ return __awaiter(this, void 0, void 0, function* () {
1205
+ return yield this.pup(({ chatId }) => WAPI.testButtons(chatId), { chatId });
1206
+ });
1207
+ }
1200
1208
  link(params) {
1201
1209
  var _a;
1202
1210
  return __awaiter(this, void 0, void 0, function* () {
@@ -1705,6 +1713,19 @@ class Client {
1705
1713
  return `data:image/png;base64,${screenshot}`;
1706
1714
  });
1707
1715
  }
1716
+ /**
1717
+ * Returns some metrics of the session/page.
1718
+ * @returns `Promise<any>`
1719
+ */
1720
+ metrics() {
1721
+ return __awaiter(this, void 0, void 0, function* () {
1722
+ const metrics = yield this._page.metrics();
1723
+ const sessionMetrics = yield this.pup(() => WAPI.launchMetrics());
1724
+ const res = Object.assign(Object.assign({}, (metrics || {})), (sessionMetrics || {}));
1725
+ logging_1.log.info("Metrics:", res);
1726
+ return res;
1727
+ });
1728
+ }
1708
1729
  /**
1709
1730
  * Returns an array of group ids where the host account is admin
1710
1731
  */
@@ -33,6 +33,7 @@ const puppeteerConfig = {
33
33
  '--disable-histogram-customizer',
34
34
  '--disable-gl-extensions',
35
35
  '--disable-composited-antialiasing',
36
+ '--disable-session-crashed-bubble',
36
37
  '--disable-canvas-aa',
37
38
  '--disable-3d-apis',
38
39
  '--disable-accelerated-2d-canvas',
@@ -41,6 +41,7 @@ const get_port_1 = __importDefault(require("get-port"));
41
41
  const command_exists_1 = __importDefault(require("command-exists"));
42
42
  const http_1 = __importDefault(require("http"));
43
43
  const tools_1 = require("../../utils/tools");
44
+ const logging_1 = require("../../logging/logging");
44
45
  const placeholders = {
45
46
  "authenticated": "",
46
47
  "loading": ""
@@ -66,7 +67,8 @@ const setUpApp = () => __awaiter(void 0, void 0, void 0, function* () {
66
67
  function popup(config) {
67
68
  return __awaiter(this, void 0, void 0, function* () {
68
69
  yield setUpApp();
69
- const preferredPort = config.popup;
70
+ const _p = process.env.PORT || config.port;
71
+ const preferredPort = typeof config.popup === "boolean" && config.popup && _p ? Number(_p) : config.popup;
70
72
  const popupListener = events_1.ev.on('**', (data, sessionId, namespace) => __awaiter(this, void 0, void 0, function* () {
71
73
  if (namespace === null || namespace === void 0 ? void 0 : namespace.includes("sessionData"))
72
74
  return;
@@ -94,6 +96,7 @@ function popup(config) {
94
96
  if (server)
95
97
  return `http://localhost:${PORT}`;
96
98
  PORT = yield (0, get_port_1.default)({ host: 'localhost', port: typeof preferredPort == 'number' ? [preferredPort, 7000, 7001, 7002] : [7000, 7001, 7002] });
99
+ logging_1.log.info(`popup port set to ${PORT}`);
97
100
  server = http_1.default.createServer(app);
98
101
  if (!(config === null || config === void 0 ? void 0 : config.qrPopUpOnly)) {
99
102
  io = new socket_io_1.Server(server);
@@ -122,7 +125,7 @@ function popup(config) {
122
125
  arguments: ['--incognito']
123
126
  }, allowNonzeroExitCode: true }).catch(() => { return; });
124
127
  else
125
- return "NA";
128
+ return `http://localhost:${PORT}`;
126
129
  }
127
130
  else
128
131
  return `http://localhost:${PORT}${(config === null || config === void 0 ? void 0 : config.qrPopUpOnly) ? '/qr' : ''}`;
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@open-wa/wa-automate",
3
- "version": "4.35.10",
3
+ "version": "4.35.13",
4
4
  "licenseCheckUrl": "https://funcs.openwa.dev/license-check",
5
5
  "brokenMethodReportUrl": "https://funcs.openwa.dev/report-bm",
6
6
  "patches": "https://cdn.openwa.dev/patches.json",
@@ -153,7 +153,7 @@
153
153
  "qrcode-terminal": "^0.12.0",
154
154
  "qs": "^6.10.1",
155
155
  "rxjs": "^7.0.0",
156
- "socket.io": "^4.0.1",
156
+ "socket.io": "^4.4.1",
157
157
  "socket.io-client": "^4.1.1",
158
158
  "spinnies": "^0.5.1",
159
159
  "swagger-stats": "^0.99.1",