@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.
- package/dist/api/Client.d.ts +2 -1
- package/dist/api/Client.js +37 -32
- package/dist/controllers/initializer.js +3 -2
- package/dist/controllers/popup/index.js +9 -4
- package/dist/utils/tools.d.ts +52 -0
- package/dist/utils/tools.js +92 -1
- package/package.json +1 -1
package/dist/api/Client.d.ts
CHANGED
@@ -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:
|
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
|
*
|
package/dist/api/Client.js
CHANGED
@@ -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
|
-
|
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 =
|
1227
|
-
console.error(msg);
|
1228
|
-
|
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
|
45
|
-
"
|
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
|
-
|
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
|
package/dist/utils/tools.d.ts
CHANGED
@@ -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>;
|
package/dist/utils/tools.js
CHANGED
@@ -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