@open-wa/wa-automate 4.33.6 → 4.34.0

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.
@@ -101,6 +101,7 @@ export declare class Client {
101
101
  */
102
102
  getConfig(): ConfigObject;
103
103
  private pup;
104
+ private responseWrap;
104
105
  /**
105
106
  * //////////////////////// LISTENERS
106
107
  */
@@ -1023,7 +1024,7 @@ export declare class Client {
1023
1024
  * @param {boolean} isHidden Whether or not the product is shown publicly in your catalog
1024
1025
  * @returns product object
1025
1026
  */
1026
- createNewProduct(name: string, price: number, currency: string, images: DataURL[], description: string, url?: string, internalId?: string, isHidden?: boolean): Promise<Product>;
1027
+ createNewProduct(name: string, price: number, currency: string, images: string[], description: string, url?: string, internalId?: string, isHidden?: boolean): Promise<Product>;
1027
1028
  /**
1028
1029
  * [REQUIRES AN INSIDERS LICENSE-KEY](https://gum.co/open-wa?tier=Insiders%20Program)
1029
1030
  *
@@ -487,36 +487,39 @@ class Client {
487
487
  if (_t && logging) {
488
488
  logging_1.log.info(`OUT ${invocation_id}: ${Date.now() - _t}ms`, { res });
489
489
  }
490
- if (this._createConfig.onError && typeof res == "string" && (res.startsWith("Error") || res.startsWith("ERROR"))) {
491
- const e = this._createConfig.onError;
492
- /**
493
- * Log error
494
- */
495
- if (e == model_1.OnError.LOG_AND_FALSE ||
496
- e == model_1.OnError.LOG_AND_STRING ||
497
- res.includes("get.openwa.dev"))
498
- console.error(res);
499
- /**
500
- * Return res
501
- */
502
- if (e == model_1.OnError.AS_STRING ||
503
- e == model_1.OnError.NOTHING ||
504
- e == model_1.OnError.LOG_AND_STRING)
505
- return res;
506
- /**
507
- * Return false
508
- */
509
- if (e == model_1.OnError.LOG_AND_FALSE ||
510
- e == model_1.OnError.RETURN_FALSE)
511
- return false;
512
- if (e == model_1.OnError.RETURN_ERROR)
513
- return new Error(res);
514
- if (e == model_1.OnError.THROW)
515
- throw new Error(res);
516
- }
517
- return res;
490
+ return this.responseWrap(res);
518
491
  });
519
492
  }
493
+ responseWrap(res) {
494
+ if (this._createConfig.onError && typeof res == "string" && (res.startsWith("Error") || res.startsWith("ERROR"))) {
495
+ const e = this._createConfig.onError;
496
+ /**
497
+ * Log error
498
+ */
499
+ if (e == model_1.OnError.LOG_AND_FALSE ||
500
+ e == model_1.OnError.LOG_AND_STRING ||
501
+ res.includes("get.openwa.dev"))
502
+ console.error(res);
503
+ /**
504
+ * Return res
505
+ */
506
+ if (e == model_1.OnError.AS_STRING ||
507
+ e == model_1.OnError.NOTHING ||
508
+ e == model_1.OnError.LOG_AND_STRING)
509
+ return res;
510
+ /**
511
+ * Return false
512
+ */
513
+ if (e == model_1.OnError.LOG_AND_FALSE ||
514
+ e == model_1.OnError.RETURN_FALSE)
515
+ return false;
516
+ if (e == model_1.OnError.RETURN_ERROR)
517
+ return new Error(res);
518
+ if (e == model_1.OnError.THROW)
519
+ throw new Error(res);
520
+ }
521
+ return res;
522
+ }
520
523
  /**
521
524
  * //////////////////////// LISTENERS
522
525
  */
@@ -1223,10 +1226,9 @@ class Client {
1223
1226
  if (err.includes(res)) {
1224
1227
  let msg = res;
1225
1228
  if (res == err[1])
1226
- msg = `\n${res}. Unlock this feature and support open-wa by getting a license: ${yield this.link()}\n`;
1227
- console.error(msg);
1228
- if (this._createConfig.onError == model_1.OnError.THROW)
1229
- throw new errors_1.CustomError(errors_1.ERROR_NAME.SENDTEXT_FAILURE, msg);
1229
+ msg = `ERROR: ${res}. Unlock this feature and support open-wa by getting a license: ${yield this.link()}`;
1230
+ console.error(`\n${msg}\n`);
1231
+ return this.responseWrap(msg);
1230
1232
  }
1231
1233
  return (err.includes(res) ? false : res);
1232
1234
  });
@@ -2227,6 +2229,9 @@ class Client {
2227
2229
  */
2228
2230
  createNewProduct(name, price, currency, images, description, url, internalId, isHidden) {
2229
2231
  return __awaiter(this, void 0, void 0, function* () {
2232
+ if (!Array.isArray(images))
2233
+ images = [images];
2234
+ images = yield Promise.all(images.map(image => (0, tools_1.ensureDUrl)(image)));
2230
2235
  return yield this.pup(({ name, price, currency, images, description, url, internalId, isHidden }) => WAPI.createNewProduct(name, price, currency, images, description, url, internalId, isHidden), { name, price, currency, images, description, url, internalId, isHidden });
2231
2236
  });
2232
2237
  }
@@ -378,8 +378,6 @@ function create(config = {}) {
378
378
  config.skipBrokenMethodsCheck = true;
379
379
  // config.skipPatches = true;
380
380
  }
381
- debugInfo.NUM = yield waPage.evaluate(`(window.localStorage['last-wid'] || '').replace('@c.us','').replace(/"/g,"").slice(-4)`);
382
- debugInfo.NUM_HASH = (0, crypto_1.createHash)('md5').update(yield waPage.evaluate(`(window.localStorage['last-wid'] || '').replace('@c.us','').replace(/"/g,"")`), 'utf8').digest('hex');
383
381
  if (config === null || config === void 0 ? void 0 : config.hostNotificationLang) {
384
382
  yield waPage.evaluate(`window.hostlang="${config.hostNotificationLang}"`);
385
383
  }
@@ -388,6 +386,9 @@ function create(config = {}) {
388
386
  yield (0, patch_manager_1.getAndInjectLivePatch)(waPage, spinner, yield patchPromise, config, debugInfo);
389
387
  debugInfo.OW_KEY = yield waPage.evaluate(`window.o()`);
390
388
  }
389
+ const NUM = ((yield waPage.evaluate(`(window.moi() || "").replace('@c.us','').replace(/"/g,"")`)) || "");
390
+ debugInfo.NUM = NUM.slice(-4);
391
+ debugInfo.NUM_HASH = (0, crypto_1.createHash)('md5').update(NUM, 'utf8').digest('hex');
391
392
  if ((config === null || config === void 0 ? void 0 : config.skipBrokenMethodsCheck) !== true)
392
393
  yield (0, launch_checks_1.integrityCheck)(waPage, notifier, spinner, debugInfo);
393
394
  const LAUNCH_TIME_MS = Date.now() - START_TIME;
@@ -41,8 +41,11 @@ 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 currentQrCodes = {
45
- "latest": ""
44
+ const placeholders = {
45
+ "authenticated": "",
46
+ "loading": ""
47
+ }, currentQrCodes = {
48
+ "latest": placeholders.loading
46
49
  }, serverSockets = {};
47
50
  let io, express, app, gClient, PORT, server;
48
51
  const setUpApp = () => __awaiter(void 0, void 0, void 0, function* () {
@@ -74,8 +77,10 @@ function popup(config) {
74
77
  }
75
78
  }
76
79
  if (namespace === 'qr') {
77
- currentQrCodes[sessionId] = data;
78
- currentQrCodes['latest'] = data;
80
+ currentQrCodes['latest'] = currentQrCodes[sessionId] = data;
81
+ }
82
+ if ((data === null || data === void 0 ? void 0 : data.includes) && (data === null || data === void 0 ? void 0 : data.includes("Authenticated"))) {
83
+ currentQrCodes['latest'] = currentQrCodes[sessionId] = placeholders.authenticated;
79
84
  }
80
85
  if ((data === null || data === void 0 ? void 0 : data.includes) && (data === null || data === void 0 ? void 0 : data.includes("ready for account"))) {
81
86
  //@ts-ignore
@@ -10,9 +10,25 @@ export declare const timeout: (ms: any) => Promise<unknown>;
10
10
  */
11
11
  export declare const smartUserAgent: (ua: string, version?: string) => string;
12
12
  export declare const getConfigFromProcessEnv: any;
13
+ /**
14
+ * Remove the key from the object and return the rest of the object.
15
+ * @param {JsonObject} obj - The object to be filtered.
16
+ * @param {string} key - The key to discard.
17
+ * @returns The object without the key.
18
+ */
13
19
  export declare const without: any;
14
20
  export declare const camelize: (str: string) => string;
21
+ /**
22
+ * Check if a string is Base64
23
+ * @param str string
24
+ * @returns
25
+ */
15
26
  export declare const isBase64: (str: string) => boolean;
27
+ /**
28
+ * Check if a string is a DataURL
29
+ * @param s string
30
+ * @returns
31
+ */
16
32
  export declare const isDataURL: (s: string) => boolean;
17
33
  /**
18
34
  * @internal
@@ -26,9 +42,45 @@ export declare const getDUrl: (url: string, optionsOverride?: AxiosRequestConfig
26
42
  * Use this to extract the mime type from a [[DataURL]]
27
43
  */
28
44
  export declare const base64MimeType: (dUrl: DataURL) => string;
45
+ /**
46
+ * If process.send is defined, send the message three times
47
+ * @param {string} message - The message to send to the parent process.
48
+ * @returns Nothing.
49
+ */
29
50
  export declare const processSend: (message: string) => void;
51
+ /**
52
+ * Return the performance object if it is available, otherwise return the Date object
53
+ */
30
54
  export declare const perf: () => DateConstructor | import("perf_hooks").Performance;
55
+ /**
56
+ * Return the current time in milliseconds
57
+ */
31
58
  export declare const now: () => number;
59
+ /**
60
+ * `timePromise` returns a promise that resolves to the time it took to run the function passed to it
61
+ * @param fn - the function to be timed.
62
+ * @returns A string.
63
+ */
32
64
  export declare function timePromise(fn: () => Promise<any>): Promise<string>;
65
+ /**
66
+ * It sends a message to the parent process.
67
+ * @param {any} data - The data to be sent to the parent process.
68
+ * @returns Nothing.
69
+ */
33
70
  export declare const processSendData: (data?: any) => void;
71
+ /**
72
+ * It generates a link to the GitHub issue template for the current session
73
+ * @param {ConfigObject} config - the config object
74
+ * @param {SessionInfo} sessionInfo - The sessionInfo object from the CLI
75
+ * @param {any} extras - any
76
+ * @returns A link to the issue tracker for the current session.
77
+ */
34
78
  export declare const generateGHIssueLink: (config: ConfigObject, sessionInfo: SessionInfo, extras?: any) => string;
79
+ /**
80
+ * If the file is a DataURL, return it. If it's a file, convert it to a DataURL. If it's a URL,
81
+ * download it and convert it to a DataURL. If Base64, returns it.
82
+ * @param {string} file - The file to be converted to a DataURL.
83
+ * @param {AxiosRequestConfig} requestConfig - AxiosRequestConfig = {}
84
+ * @returns A DataURL
85
+ */
86
+ export declare const ensureDUrl: (file: string, requestConfig?: AxiosRequestConfig) => Promise<string>;
@@ -1,4 +1,23 @@
1
1
  "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });
5
+ }) : (function(o, m, k, k2) {
6
+ if (k2 === undefined) k2 = k;
7
+ o[k2] = m[k];
8
+ }));
9
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
10
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
11
+ }) : function(o, v) {
12
+ o["default"] = v;
13
+ });
14
+ var __importStar = (this && this.__importStar) || function (mod) {
15
+ if (mod && mod.__esModule) return mod;
16
+ var result = {};
17
+ if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
18
+ __setModuleDefault(result, mod);
19
+ return result;
20
+ };
2
21
  var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
3
22
  function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
4
23
  return new (P || (P = Promise))(function (resolve, reject) {
@@ -23,7 +42,12 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
23
42
  return (mod && mod.__esModule) ? mod : { "default": mod };
24
43
  };
25
44
  Object.defineProperty(exports, "__esModule", { value: true });
26
- exports.generateGHIssueLink = exports.processSendData = exports.timePromise = exports.now = exports.perf = exports.processSend = exports.base64MimeType = exports.getDUrl = exports.isDataURL = exports.isBase64 = exports.camelize = exports.without = exports.getConfigFromProcessEnv = exports.smartUserAgent = exports.timeout = void 0;
45
+ exports.ensureDUrl = exports.generateGHIssueLink = exports.processSendData = exports.timePromise = exports.now = exports.perf = exports.processSend = exports.base64MimeType = exports.getDUrl = exports.isDataURL = exports.isBase64 = exports.camelize = exports.without = exports.getConfigFromProcessEnv = exports.smartUserAgent = exports.timeout = void 0;
46
+ const fs = __importStar(require("fs"));
47
+ const path = __importStar(require("path"));
48
+ const datauri_1 = __importDefault(require("datauri"));
49
+ const is_url_superb_1 = __importDefault(require("is-url-superb"));
50
+ const model_1 = require("../api/model");
27
51
  const axios_1 = __importDefault(require("axios"));
28
52
  const child_process_1 = require("child_process");
29
53
  const perf_hooks_1 = require("perf_hooks");
@@ -60,6 +84,12 @@ const getConfigFromProcessEnv = (json) => {
60
84
  return output;
61
85
  };
62
86
  exports.getConfigFromProcessEnv = getConfigFromProcessEnv;
87
+ /**
88
+ * Remove the key from the object and return the rest of the object.
89
+ * @param {JsonObject} obj - The object to be filtered.
90
+ * @param {string} key - The key to discard.
91
+ * @returns The object without the key.
92
+ */
63
93
  const without = (obj, key) => {
64
94
  const _a = obj,
65
95
  // eslint-disable-next-line @typescript-eslint/no-unused-vars
@@ -79,6 +109,11 @@ const camelize = (str) => {
79
109
  return capitalString;
80
110
  };
81
111
  exports.camelize = camelize;
112
+ /**
113
+ * Check if a string is Base64
114
+ * @param str string
115
+ * @returns
116
+ */
82
117
  const isBase64 = (str) => {
83
118
  const len = str.length;
84
119
  if (!len || len % 4 !== 0 || /[^A-Z0-9+/=]/i.test(str)) {
@@ -90,6 +125,11 @@ const isBase64 = (str) => {
90
125
  (firstPaddingChar === len - 2 && str[len - 1] === '='));
91
126
  };
92
127
  exports.isBase64 = isBase64;
128
+ /**
129
+ * Check if a string is a DataURL
130
+ * @param s string
131
+ * @returns
132
+ */
93
133
  const isDataURL = (s) => !!s.match(/^data:((?:\w+\/(?:(?!;).)+)?)((?:;[\w\W]*?[^;])*),(.+)$/g);
94
134
  exports.isDataURL = isDataURL;
95
135
  /**
@@ -129,6 +169,11 @@ const base64MimeType = (dUrl) => {
129
169
  return result;
130
170
  };
131
171
  exports.base64MimeType = base64MimeType;
172
+ /**
173
+ * If process.send is defined, send the message three times
174
+ * @param {string} message - The message to send to the parent process.
175
+ * @returns Nothing.
176
+ */
132
177
  const processSend = (message) => {
133
178
  if (process.send) {
134
179
  process.send(message);
@@ -138,10 +183,21 @@ const processSend = (message) => {
138
183
  return;
139
184
  };
140
185
  exports.processSend = processSend;
186
+ /**
187
+ * Return the performance object if it is available, otherwise return the Date object
188
+ */
141
189
  const perf = () => perf_hooks_1.performance || Date;
142
190
  exports.perf = perf;
191
+ /**
192
+ * Return the current time in milliseconds
193
+ */
143
194
  const now = () => (0, exports.perf)().now();
144
195
  exports.now = now;
196
+ /**
197
+ * `timePromise` returns a promise that resolves to the time it took to run the function passed to it
198
+ * @param fn - the function to be timed.
199
+ * @returns A string.
200
+ */
145
201
  function timePromise(fn) {
146
202
  return __awaiter(this, void 0, void 0, function* () {
147
203
  const start = (0, exports.now)();
@@ -150,6 +206,11 @@ function timePromise(fn) {
150
206
  });
151
207
  }
152
208
  exports.timePromise = timePromise;
209
+ /**
210
+ * It sends a message to the parent process.
211
+ * @param {any} data - The data to be sent to the parent process.
212
+ * @returns Nothing.
213
+ */
153
214
  const processSendData = (data = {}) => {
154
215
  process.send({
155
216
  type: 'process:msg',
@@ -158,6 +219,13 @@ const processSendData = (data = {}) => {
158
219
  return;
159
220
  };
160
221
  exports.processSendData = processSendData;
222
+ /**
223
+ * It generates a link to the GitHub issue template for the current session
224
+ * @param {ConfigObject} config - the config object
225
+ * @param {SessionInfo} sessionInfo - The sessionInfo object from the CLI
226
+ * @param {any} extras - any
227
+ * @returns A link to the issue tracker for the current session.
228
+ */
161
229
  const generateGHIssueLink = (config, sessionInfo, extras = {}) => {
162
230
  const npm_ver = (0, child_process_1.execSync)('npm -v');
163
231
  const labels = [];
@@ -180,3 +248,26 @@ const generateGHIssueLink = (config, sessionInfo, extras = {}) => {
180
248
  return `https://github.com/open-wa/wa-automate-nodejs/issues/new?${Object.keys(qp).map(k => `${k}=${qp[k]}`).join('&')}`;
181
249
  };
182
250
  exports.generateGHIssueLink = generateGHIssueLink;
251
+ /**
252
+ * If the file is a DataURL, return it. If it's a file, convert it to a DataURL. If it's a URL,
253
+ * download it and convert it to a DataURL. If Base64, returns it.
254
+ * @param {string} file - The file to be converted to a DataURL.
255
+ * @param {AxiosRequestConfig} requestConfig - AxiosRequestConfig = {}
256
+ * @returns A DataURL
257
+ */
258
+ const ensureDUrl = (file, requestConfig = {}) => __awaiter(void 0, void 0, void 0, function* () {
259
+ if (!(0, exports.isDataURL)(file) && !(0, exports.isBase64)(file)) {
260
+ //must be a file then
261
+ const relativePath = path.join(path.resolve(process.cwd(), file || ''));
262
+ if (fs.existsSync(file) || fs.existsSync(relativePath)) {
263
+ file = yield (0, datauri_1.default)(fs.existsSync(file) ? file : relativePath);
264
+ }
265
+ else if ((0, is_url_superb_1.default)(file)) {
266
+ file = yield (0, exports.getDUrl)(file, requestConfig);
267
+ }
268
+ else
269
+ throw new model_1.CustomError(model_1.ERROR_NAME.FILE_NOT_FOUND, 'Cannot find file. Make sure the file reference is relative, a valid URL or a valid DataURL');
270
+ }
271
+ return file;
272
+ });
273
+ exports.ensureDUrl = ensureDUrl;
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@open-wa/wa-automate",
3
- "version": "4.33.6",
3
+ "version": "4.34.0",
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",