@skyzopedia/baileys-mod 5.0.8 → 6.0.1
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/WAProto/index.js +133384 -57814
- package/engine-requirements.js +10 -0
- package/lib/Defaults/baileys-version.json +3 -0
- package/lib/Defaults/index.d.ts +53 -0
- package/lib/Defaults/index.js +141 -117
- package/lib/Defaults/phonenumber-mcc.json +223 -0
- package/lib/Signal/Group/ciphertext-message.d.ts +9 -0
- package/lib/Signal/Group/ciphertext-message.js +14 -12
- package/lib/Signal/Group/group-session-builder.d.ts +14 -0
- package/lib/Signal/Group/group-session-builder.js +42 -10
- package/lib/Signal/Group/group_cipher.d.ts +17 -0
- package/lib/Signal/Group/group_cipher.js +87 -75
- package/lib/Signal/Group/index.d.ts +11 -0
- package/lib/Signal/Group/index.js +57 -13
- package/lib/Signal/Group/keyhelper.d.ts +10 -0
- package/lib/Signal/Group/keyhelper.js +52 -17
- package/lib/Signal/Group/queue-job.d.ts +1 -0
- package/lib/Signal/Group/queue-job.js +57 -0
- package/lib/Signal/Group/sender-chain-key.d.ts +13 -0
- package/lib/Signal/Group/sender-chain-key.js +33 -27
- package/lib/Signal/Group/sender-key-distribution-message.d.ts +16 -0
- package/lib/Signal/Group/sender-key-distribution-message.js +63 -62
- package/lib/Signal/Group/sender-key-message.d.ts +18 -0
- package/lib/Signal/Group/sender-key-message.js +66 -65
- package/lib/Signal/Group/sender-key-name.d.ts +17 -0
- package/lib/Signal/Group/sender-key-name.js +44 -45
- package/lib/Signal/Group/sender-key-record.d.ts +30 -0
- package/lib/Signal/Group/sender-key-record.js +49 -39
- package/lib/Signal/Group/sender-key-state.d.ts +38 -0
- package/lib/Signal/Group/sender-key-state.js +93 -80
- package/lib/Signal/Group/sender-message-key.d.ts +11 -0
- package/lib/Signal/Group/sender-message-key.js +28 -27
- package/lib/Signal/libsignal.d.ts +3 -0
- package/lib/Signal/libsignal.js +163 -313
- package/lib/Socket/Client/abstract-socket-client.d.ts +17 -0
- package/lib/Socket/Client/abstract-socket-client.js +13 -0
- package/lib/Socket/Client/index.d.ts +3 -0
- package/lib/Socket/Client/index.js +19 -4
- package/lib/Socket/Client/mobile-socket-client.d.ts +13 -0
- package/lib/Socket/Client/mobile-socket-client.js +65 -0
- package/lib/Socket/Client/web-socket-client.d.ts +12 -0
- package/lib/Socket/Client/web-socket-client.js +62 -0
- package/lib/Socket/business.d.ts +171 -0
- package/lib/Socket/business.js +242 -359
- package/lib/Socket/chats.d.ts +267 -0
- package/lib/Socket/chats.js +935 -846
- package/lib/Socket/dugong.d.ts +254 -0
- package/lib/Socket/dugong.js +484 -0
- package/lib/Socket/groups.d.ts +115 -0
- package/lib/Socket/groups.js +309 -304
- package/lib/Socket/index.d.ts +173 -0
- package/lib/Socket/index.js +10 -15
- package/lib/Socket/messages-recv.d.ts +161 -0
- package/lib/Socket/messages-recv.js +1054 -1107
- package/lib/Socket/messages-send.d.ts +149 -0
- package/lib/Socket/messages-send.js +447 -706
- package/lib/Socket/newsletter.d.ts +134 -0
- package/lib/Socket/newsletter.js +314 -199
- package/lib/Socket/registration.d.ts +267 -0
- package/lib/Socket/registration.js +166 -0
- package/lib/Socket/socket.d.ts +43 -0
- package/lib/Socket/socket.js +650 -777
- package/lib/Socket/usync.d.ts +36 -0
- package/lib/Socket/usync.js +70 -0
- package/lib/Store/index.d.ts +3 -0
- package/lib/Store/index.js +10 -6
- package/lib/Store/make-cache-manager-store.d.ts +13 -0
- package/lib/Store/make-cache-manager-store.js +81 -73
- package/lib/Store/make-in-memory-store.d.ts +118 -0
- package/lib/Store/make-in-memory-store.js +423 -286
- package/lib/Store/make-ordered-dictionary.d.ts +13 -0
- package/lib/Store/make-ordered-dictionary.js +79 -77
- package/lib/Store/object-repository.d.ts +10 -0
- package/lib/Store/object-repository.js +26 -24
- package/lib/Types/Auth.d.ts +110 -0
- package/lib/Types/Auth.js +2 -3
- package/lib/Types/Call.d.ts +13 -0
- package/lib/Types/Call.js +2 -3
- package/lib/Types/Chat.d.ts +102 -0
- package/lib/Types/Chat.js +4 -9
- package/lib/Types/Contact.d.ts +19 -0
- package/lib/Types/Contact.js +2 -3
- package/lib/Types/Events.d.ts +157 -0
- package/lib/Types/Events.js +2 -3
- package/lib/Types/GroupMetadata.d.ts +55 -0
- package/lib/Types/GroupMetadata.js +2 -3
- package/lib/Types/Label.d.ts +35 -0
- package/lib/Types/Label.js +26 -24
- package/lib/Types/LabelAssociation.d.ts +29 -0
- package/lib/Types/LabelAssociation.js +8 -6
- package/lib/Types/Message.d.ts +273 -0
- package/lib/Types/Message.js +9 -12
- package/lib/Types/Newsletter.d.ts +103 -0
- package/lib/Types/Newsletter.js +38 -33
- package/lib/Types/Product.d.ts +78 -0
- package/lib/Types/Product.js +2 -3
- package/lib/Types/Signal.d.ts +57 -0
- package/lib/Types/Signal.js +2 -3
- package/lib/Types/Socket.d.ts +111 -0
- package/lib/Types/Socket.js +2 -4
- package/lib/Types/State.d.ts +27 -0
- package/lib/Types/State.js +2 -11
- package/lib/Types/USync.d.ts +25 -0
- package/lib/Types/USync.js +2 -3
- package/lib/Types/index.d.ts +57 -0
- package/lib/Types/index.js +41 -27
- package/lib/Utils/auth-utils.d.ts +18 -0
- package/lib/Utils/auth-utils.js +198 -211
- package/lib/Utils/baileys-event-stream.d.ts +16 -0
- package/lib/Utils/baileys-event-stream.js +61 -42
- package/lib/Utils/business.d.ts +22 -0
- package/lib/Utils/business.js +214 -213
- package/lib/Utils/chat-utils.d.ts +71 -0
- package/lib/Utils/chat-utils.js +687 -710
- package/lib/Utils/crypto.d.ts +41 -0
- package/lib/Utils/crypto.js +133 -112
- package/lib/Utils/decode-wa-message.d.ts +19 -0
- package/lib/Utils/decode-wa-message.js +183 -252
- package/lib/Utils/event-buffer.d.ts +35 -0
- package/lib/Utils/event-buffer.js +496 -510
- package/lib/Utils/generics.d.ts +92 -0
- package/lib/Utils/generics.js +392 -319
- package/lib/Utils/generics.js.bak +433 -0
- package/lib/Utils/history.d.ts +15 -0
- package/lib/Utils/history.js +92 -83
- package/lib/Utils/index.d.ts +17 -0
- package/lib/Utils/index.js +33 -21
- package/lib/Utils/link-preview.d.ts +21 -0
- package/lib/Utils/link-preview.js +83 -71
- package/lib/Utils/logger.d.ts +4 -0
- package/lib/Utils/logger.js +7 -5
- package/lib/Utils/lt-hash.d.ts +12 -0
- package/lib/Utils/lt-hash.js +46 -40
- package/lib/Utils/make-mutex.d.ts +7 -0
- package/lib/Utils/make-mutex.js +41 -34
- package/lib/Utils/messages-media.d.ts +116 -0
- package/lib/Utils/messages-media.js +768 -550
- package/lib/Utils/messages.d.ts +77 -0
- package/lib/Utils/messages.js +263 -362
- package/lib/Utils/noise-handler.d.ts +21 -0
- package/lib/Utils/noise-handler.js +149 -138
- package/lib/Utils/process-message.d.ts +41 -0
- package/lib/Utils/process-message.js +303 -323
- package/lib/Utils/signal.d.ts +32 -0
- package/lib/Utils/signal.js +141 -149
- package/lib/Utils/use-multi-file-auth-state.d.ts +13 -0
- package/lib/Utils/use-multi-file-auth-state.js +103 -95
- package/lib/Utils/validate-connection.d.ts +11 -0
- package/lib/Utils/validate-connection.js +214 -183
- package/lib/Utils/validate-connection.js.bak +237 -0
- package/lib/WABinary/constants.d.ts +30 -0
- package/lib/WABinary/constants.js +35 -1298
- package/lib/WABinary/decode.d.ts +7 -0
- package/lib/WABinary/decode.js +249 -237
- package/lib/WABinary/encode.d.ts +3 -0
- package/lib/WABinary/encode.js +260 -213
- package/lib/WABinary/generic-utils.d.ts +17 -0
- package/lib/WABinary/generic-utils.js +65 -56
- package/lib/WABinary/index.d.ts +5 -0
- package/lib/WABinary/index.js +21 -7
- package/lib/WABinary/jid-utils.d.ts +31 -0
- package/lib/WABinary/jid-utils.js +58 -89
- package/lib/WABinary/types.d.ts +18 -0
- package/lib/WABinary/types.js +2 -3
- package/lib/WAM/BinaryInfo.d.ts +17 -0
- package/lib/WAM/BinaryInfo.js +12 -10
- package/lib/WAM/constants.d.ts +38 -0
- package/lib/WAM/constants.js +15348 -22851
- package/lib/WAM/encode.d.ts +3 -0
- package/lib/WAM/encode.js +136 -135
- package/lib/WAM/index.d.ts +3 -0
- package/lib/WAM/index.js +19 -5
- package/lib/WAUSync/Protocols/USyncContactProtocol.d.ts +9 -0
- package/lib/WAUSync/Protocols/USyncContactProtocol.js +30 -28
- package/lib/WAUSync/Protocols/USyncDeviceProtocol.d.ts +22 -0
- package/lib/WAUSync/Protocols/USyncDeviceProtocol.js +53 -49
- package/lib/WAUSync/Protocols/USyncDisappearingModeProtocol.d.ts +12 -0
- package/lib/WAUSync/Protocols/USyncDisappearingModeProtocol.js +28 -27
- package/lib/WAUSync/Protocols/USyncStatusProtocol.d.ts +12 -0
- package/lib/WAUSync/Protocols/USyncStatusProtocol.js +39 -36
- package/lib/WAUSync/Protocols/UsyncBotProfileProtocol.d.ts +25 -0
- package/lib/WAUSync/Protocols/UsyncBotProfileProtocol.js +50 -50
- package/lib/WAUSync/Protocols/UsyncLIDProtocol.d.ts +8 -0
- package/lib/WAUSync/Protocols/UsyncLIDProtocol.js +20 -26
- package/lib/WAUSync/Protocols/index.d.ts +4 -0
- package/lib/WAUSync/Protocols/index.js +20 -6
- package/lib/WAUSync/USyncQuery.d.ts +28 -0
- package/lib/WAUSync/USyncQuery.js +85 -86
- package/lib/WAUSync/USyncUser.d.ts +12 -0
- package/lib/WAUSync/USyncUser.js +25 -23
- package/lib/WAUSync/index.d.ts +3 -0
- package/lib/WAUSync/index.js +19 -5
- package/lib/index.d.ts +12 -0
- package/lib/index.js +36 -24
- package/package.json +106 -98
- package/LICENSE +0 -21
- package/WAProto/WAProto.proto +0 -5311
- package/lib/KeyDB/BinarySearch.js +0 -20
- package/lib/KeyDB/KeyedDB.js +0 -167
- package/lib/KeyDB/index.js +0 -4
- package/lib/Signal/lid-mapping.js +0 -155
- package/lib/Socket/Client/types.js +0 -13
- package/lib/Socket/Client/websocket.js +0 -52
- package/lib/Socket/Client/websocket.js.bak +0 -53
- package/lib/Socket/communities.js +0 -413
- package/lib/Socket/mex.js +0 -45
- package/lib/Types/Bussines.js +0 -3
- package/lib/Types/Newsletter.js.bak +0 -33
- package/lib/Utils/browser-utils.js +0 -25
- package/lib/Utils/message-retry-manager.js +0 -113
- package/lib/Utils/messages.js.bak +0 -907
- package/lib/Utils/pre-key-manager.js +0 -85
package/lib/Utils/generics.js
CHANGED
|
@@ -1,355 +1,428 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
import { createHash, randomBytes } from "crypto";
|
|
5
|
-
import { proto } from "../../WAProto/index.js";
|
|
6
|
-
import { version } from "../Defaults/index.js"
|
|
7
|
-
import { sha256 } from "./crypto.js";
|
|
8
|
-
import { Boom } from "@hapi/boom";
|
|
9
|
-
//=======================================================//
|
|
10
|
-
export const BufferJSON = {
|
|
11
|
-
replacer: (k, value) => {
|
|
12
|
-
if (Buffer.isBuffer(value) || value instanceof Uint8Array || value?.type === "Buffer") {
|
|
13
|
-
return { type: "Buffer", data: Buffer.from(value?.data || value).toString("base64") };
|
|
14
|
-
}
|
|
15
|
-
return value;
|
|
16
|
-
},
|
|
17
|
-
reviver: (_, value) => {
|
|
18
|
-
if (typeof value === "object" && value !== null && value.type === "Buffer" && typeof value.data === "string") {
|
|
19
|
-
return Buffer.from(value.data, "base64");
|
|
20
|
-
}
|
|
21
|
-
if (typeof value === "object" && value !== null && !Array.isArray(value)) {
|
|
22
|
-
const keys = Object.keys(value);
|
|
23
|
-
if (keys.length > 0 && keys.every(k => !isNaN(parseInt(k, 10)))) {
|
|
24
|
-
const values = Object.values(value);
|
|
25
|
-
if (values.every(v => typeof v === "number")) {
|
|
26
|
-
return Buffer.from(values);
|
|
27
|
-
}
|
|
28
|
-
}
|
|
29
|
-
}
|
|
30
|
-
return value;
|
|
31
|
-
}
|
|
32
|
-
};
|
|
33
|
-
//=======================================================//
|
|
34
|
-
export const getKeyAuthor = (key, meId = "me") => (key?.fromMe ? meId : key?.participant || key?.remoteJid) || "";
|
|
35
|
-
export const writeRandomPadMax16 = (msg) => {
|
|
36
|
-
const pad = randomBytes(1);
|
|
37
|
-
const padLength = (pad[0] & 0x0f) + 1;
|
|
38
|
-
return Buffer.concat([msg, Buffer.alloc(padLength, padLength)]);
|
|
39
|
-
};
|
|
40
|
-
//=======================================================//
|
|
41
|
-
export const unpadRandomMax16 = (e) => {
|
|
42
|
-
const t = new Uint8Array(e);
|
|
43
|
-
if (0 === t.length) {
|
|
44
|
-
throw new Error("unpadPkcs7 given empty bytes");
|
|
45
|
-
}
|
|
46
|
-
var r = t[t.length - 1];
|
|
47
|
-
if (r > t.length) {
|
|
48
|
-
throw new Error(`unpad given ${t.length} bytes, but pad is ${r}`);
|
|
49
|
-
}
|
|
50
|
-
return new Uint8Array(t.buffer, t.byteOffset, t.length - r);
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
51
4
|
};
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.bytesToCrockford = exports.trimUndefined = exports.isWABusinessPlatform = exports.getCodeFromWSError = exports.getCallStatusFromNode = exports.getErrorCodeFromStreamError = exports.getStatusFromReceiptType = exports.generateMdTagPrefix = exports.fetchLatestWaWebVersion = exports.fetchLatestBaileysVersion = exports.printQRIfNecessaryListener = exports.bindWaitForConnectionUpdate = exports.bindWaitForEvent = exports.generateMessageID = exports.generateMessageIDV2 = exports.promiseTimeout = exports.delayCancellable = exports.delay = exports.debouncedTimeout = exports.unixTimestampSeconds = exports.toNumber = exports.encodeBigEndian = exports.generateRegistrationId = exports.encodeWAMessage = exports.unpadRandomMax16 = exports.writeRandomPadMax16 = exports.getKeyAuthor = exports.BufferJSON = exports.Browsers = void 0;
|
|
7
|
+
const boom_1 = require("@hapi/boom");
|
|
8
|
+
const axios_1 = __importDefault(require("axios"));
|
|
9
|
+
const crypto_1 = require("crypto");
|
|
10
|
+
const os_1 = require("os");
|
|
11
|
+
const fetch_1 = require("node-fetch")
|
|
12
|
+
const WAProto_1 = require("../../WAProto");
|
|
13
|
+
const baileys_version_json_1 = require("../Defaults/baileys-version.json");
|
|
14
|
+
const Types_1 = require("../Types");
|
|
15
|
+
const WABinary_1 = require("../WABinary");
|
|
16
|
+
const baileysVersion = [2, 3000, 1027934701]
|
|
17
|
+
const PLATFORM_MAP = {
|
|
18
|
+
'aix': 'AIX',
|
|
19
|
+
'darwin': 'Mac OS',
|
|
20
|
+
'win32': 'Windows',
|
|
21
|
+
'android': 'Android',
|
|
22
|
+
'freebsd': 'FreeBSD',
|
|
23
|
+
'openbsd': 'OpenBSD',
|
|
24
|
+
'sunos': 'Solaris',
|
|
25
|
+
'linux': undefined,
|
|
26
|
+
'haiku': undefined,
|
|
27
|
+
'cygwin': undefined,
|
|
28
|
+
'netbsd': undefined
|
|
57
29
|
};
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
30
|
+
|
|
31
|
+
const Browsers = {
|
|
32
|
+
iOS: (browser) => ["ios", browser, "18.2"],
|
|
33
|
+
ubuntu: (browser) => ['Ubuntu', browser, '22.04.4'],
|
|
34
|
+
macOS: (browser) => ['Mac OS', browser, '14.4.1'],
|
|
35
|
+
baileys: (browser) => ['Baileys', browser, '6.5.0'],
|
|
36
|
+
windows: (browser) => ['Windows', browser, '10.0.22631']
|
|
62
37
|
};
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
r >>>= 8;
|
|
70
|
-
}
|
|
71
|
-
return a;
|
|
38
|
+
|
|
39
|
+
exports.Browsers = Browsers
|
|
40
|
+
|
|
41
|
+
const getPlatformId = (browser) => {
|
|
42
|
+
const platformType = WAProto_1.proto.DeviceProps.PlatformType[browser.toUpperCase()];
|
|
43
|
+
return platformType ? platformType.toString() : '1'; //chrome
|
|
72
44
|
};
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
task = newTask || task;
|
|
81
|
-
intervalMs = newIntervalMs || intervalMs;
|
|
82
|
-
timeout && clearTimeout(timeout);
|
|
83
|
-
timeout = setTimeout(() => task?.(), intervalMs);
|
|
84
|
-
},
|
|
85
|
-
cancel: () => {
|
|
86
|
-
timeout && clearTimeout(timeout);
|
|
87
|
-
timeout = undefined;
|
|
45
|
+
exports.getPlatformId = getPlatformId;
|
|
46
|
+
exports.BufferJSON = {
|
|
47
|
+
replacer: (k, value) => {
|
|
48
|
+
if (Buffer.isBuffer(value) || value instanceof Uint8Array || (value === null || value === void 0 ? void 0 : value.type) === 'Buffer') {
|
|
49
|
+
return { type: 'Buffer', data: Buffer.from((value === null || value === void 0 ? void 0 : value.data) || value).toString('base64') };
|
|
50
|
+
}
|
|
51
|
+
return value;
|
|
88
52
|
},
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
const stack = new Error().stack;
|
|
97
|
-
let timeout;
|
|
98
|
-
let reject;
|
|
99
|
-
const delay = new Promise((resolve, _reject) => {
|
|
100
|
-
timeout = setTimeout(resolve, ms);
|
|
101
|
-
reject = _reject;
|
|
102
|
-
});
|
|
103
|
-
const cancel = () => {
|
|
104
|
-
clearTimeout(timeout);
|
|
105
|
-
reject(new Boom("Cancelled", {
|
|
106
|
-
statusCode: 500,
|
|
107
|
-
data: {
|
|
108
|
-
stack
|
|
109
|
-
}
|
|
110
|
-
}));
|
|
111
|
-
};
|
|
112
|
-
return { delay, cancel };
|
|
53
|
+
reviver: (_, value) => {
|
|
54
|
+
if (typeof value === 'object' && !!value && (value.buffer === true || value.type === 'Buffer')) {
|
|
55
|
+
const val = value.data || value.value;
|
|
56
|
+
return typeof val === 'string' ? Buffer.from(val, 'base64') : Buffer.from(val || []);
|
|
57
|
+
}
|
|
58
|
+
return value;
|
|
59
|
+
}
|
|
113
60
|
};
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
data.writeBigUInt64BE(BigInt(Math.floor(Date.now() / 1000)));
|
|
122
|
-
if (userId) {
|
|
123
|
-
const id = jidDecode(userId);
|
|
124
|
-
if (id?.user) {
|
|
125
|
-
data.write(id.user, 8);
|
|
126
|
-
data.write("@c.us", 8 + id.user.length);
|
|
61
|
+
const getKeyAuthor = (key, meId = 'me') => (((key === null || key === void 0 ? void 0 : key.fromMe) ? meId : (key === null || key === void 0 ? void 0 : key.participant) || (key === null || key === void 0 ? void 0 : key.remoteJid)) || '');
|
|
62
|
+
exports.getKeyAuthor = getKeyAuthor;
|
|
63
|
+
const writeRandomPadMax16 = (msg) => {
|
|
64
|
+
const pad = (0, crypto_1.randomBytes)(1);
|
|
65
|
+
pad[0] &= 0xf;
|
|
66
|
+
if (!pad[0]) {
|
|
67
|
+
pad[0] = 0xf;
|
|
127
68
|
}
|
|
128
|
-
|
|
129
|
-
const random = randomBytes(16);
|
|
130
|
-
random.copy(data, 28);
|
|
131
|
-
const hash = createHash("sha256").update(data).digest();
|
|
132
|
-
return "3EB0" + hash.toString("hex").toUpperCase().substring(0, 18);
|
|
69
|
+
return Buffer.concat([msg, Buffer.alloc(pad[0], pad[0])]);
|
|
133
70
|
};
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
|
|
137
|
-
|
|
138
|
-
|
|
139
|
-
let closeListener;
|
|
140
|
-
await promiseTimeout(timeoutMs, (resolve, reject) => {
|
|
141
|
-
closeListener = ({ connection, lastDisconnect }) => {
|
|
142
|
-
if (connection === "close") {
|
|
143
|
-
reject(lastDisconnect?.error || new Boom("Connection Closed", { statusCode: DisconnectReason.connectionClosed }));
|
|
144
|
-
}
|
|
145
|
-
};
|
|
146
|
-
ev.on("connection.update", closeListener);
|
|
147
|
-
listener = async (update) => {
|
|
148
|
-
if (await check(update)) {
|
|
149
|
-
resolve();
|
|
150
|
-
}
|
|
151
|
-
};
|
|
152
|
-
ev.on(event, listener);
|
|
153
|
-
}).finally(() => {
|
|
154
|
-
ev.off(event, listener);
|
|
155
|
-
ev.off("connection.update", closeListener);
|
|
156
|
-
});
|
|
157
|
-
};
|
|
158
|
-
}
|
|
159
|
-
export const bindWaitForConnectionUpdate = (ev) => bindWaitForEvent(ev, "connection.update");
|
|
160
|
-
//=======================================================//
|
|
161
|
-
export const fetchLatestBaileysVersion = async (options = {}) => {
|
|
162
|
-
const URL = "https://raw.githubusercontent.com/WhiskeySockets/Baileys/master/src/Defaults/index.ts";
|
|
163
|
-
try {
|
|
164
|
-
const response = await fetch(URL, {
|
|
165
|
-
dispatcher: options.dispatcher,
|
|
166
|
-
method: "GET",
|
|
167
|
-
headers: options.headers
|
|
168
|
-
});
|
|
169
|
-
if (!response.ok) {
|
|
170
|
-
throw new Boom(`Failed to fetch latest Baileys version: ${response.statusText}`, { statusCode: response.status });
|
|
71
|
+
exports.writeRandomPadMax16 = writeRandomPadMax16;
|
|
72
|
+
const unpadRandomMax16 = (e) => {
|
|
73
|
+
const t = new Uint8Array(e);
|
|
74
|
+
if (0 === t.length) {
|
|
75
|
+
throw new Error('unpadPkcs7 given empty bytes');
|
|
171
76
|
}
|
|
172
|
-
|
|
173
|
-
|
|
174
|
-
|
|
175
|
-
const versionMatch = versionLine.match(/const version = \[(\d+),\s*(\d+),\s*(\d+)\]/);
|
|
176
|
-
if (versionMatch) {
|
|
177
|
-
const version = [parseInt(versionMatch[1]), parseInt(versionMatch[2]), parseInt(versionMatch[3])];
|
|
178
|
-
return {
|
|
179
|
-
version,
|
|
180
|
-
isLatest: true
|
|
181
|
-
};
|
|
77
|
+
var r = t[t.length - 1];
|
|
78
|
+
if (r > t.length) {
|
|
79
|
+
throw new Error(`unpad given ${t.length} bytes, but pad is ${r}`);
|
|
182
80
|
}
|
|
183
|
-
|
|
184
|
-
|
|
81
|
+
return new Uint8Array(t.buffer, t.byteOffset, t.length - r);
|
|
82
|
+
};
|
|
83
|
+
exports.unpadRandomMax16 = unpadRandomMax16;
|
|
84
|
+
const encodeWAMessage = (message) => ((0, exports.writeRandomPadMax16)(WAProto_1.proto.Message.encode(message).finish()));
|
|
85
|
+
exports.encodeWAMessage = encodeWAMessage;
|
|
86
|
+
const generateRegistrationId = () => {
|
|
87
|
+
return Uint16Array.from((0, crypto_1.randomBytes)(2))[0] & 16383;
|
|
88
|
+
};
|
|
89
|
+
exports.generateRegistrationId = generateRegistrationId;
|
|
90
|
+
const encodeBigEndian = (e, t = 4) => {
|
|
91
|
+
let r = e;
|
|
92
|
+
const a = new Uint8Array(t);
|
|
93
|
+
for (let i = t - 1; i >= 0; i--) {
|
|
94
|
+
a[i] = 255 & r;
|
|
95
|
+
r >>>= 8;
|
|
185
96
|
}
|
|
186
|
-
|
|
187
|
-
|
|
97
|
+
return a;
|
|
98
|
+
};
|
|
99
|
+
exports.encodeBigEndian = encodeBigEndian;
|
|
100
|
+
const toNumber = (t) => ((typeof t === 'object' && t) ? ('toNumber' in t ? t.toNumber() : t.low) : t);
|
|
101
|
+
exports.toNumber = toNumber;
|
|
102
|
+
/** unix timestamp of a date in seconds */
|
|
103
|
+
const unixTimestampSeconds = (date = new Date()) => Math.floor(date.getTime() / 1000);
|
|
104
|
+
exports.unixTimestampSeconds = unixTimestampSeconds;
|
|
105
|
+
const debouncedTimeout = (intervalMs = 1000, task) => {
|
|
106
|
+
let timeout;
|
|
188
107
|
return {
|
|
189
|
-
|
|
190
|
-
|
|
191
|
-
|
|
108
|
+
start: (newIntervalMs, newTask) => {
|
|
109
|
+
task = newTask || task;
|
|
110
|
+
intervalMs = newIntervalMs || intervalMs;
|
|
111
|
+
timeout && clearTimeout(timeout);
|
|
112
|
+
timeout = setTimeout(() => task === null || task === void 0 ? void 0 : task(), intervalMs);
|
|
113
|
+
},
|
|
114
|
+
cancel: () => {
|
|
115
|
+
timeout && clearTimeout(timeout);
|
|
116
|
+
timeout = undefined;
|
|
117
|
+
},
|
|
118
|
+
setTask: (newTask) => task = newTask,
|
|
119
|
+
setInterval: (newInterval) => intervalMs = newInterval
|
|
192
120
|
};
|
|
193
|
-
}
|
|
194
121
|
};
|
|
195
|
-
|
|
196
|
-
|
|
197
|
-
|
|
198
|
-
|
|
199
|
-
|
|
200
|
-
|
|
201
|
-
|
|
202
|
-
const
|
|
203
|
-
|
|
204
|
-
|
|
205
|
-
method: "GET",
|
|
206
|
-
headers
|
|
122
|
+
exports.debouncedTimeout = debouncedTimeout;
|
|
123
|
+
const delay = (ms) => (0, exports.delayCancellable)(ms).delay;
|
|
124
|
+
exports.delay = delay;
|
|
125
|
+
const delayCancellable = (ms) => {
|
|
126
|
+
const stack = new Error().stack;
|
|
127
|
+
let timeout;
|
|
128
|
+
let reject;
|
|
129
|
+
const delay = new Promise((resolve, _reject) => {
|
|
130
|
+
timeout = setTimeout(resolve, ms);
|
|
131
|
+
reject = _reject;
|
|
207
132
|
});
|
|
208
|
-
|
|
209
|
-
|
|
133
|
+
const cancel = () => {
|
|
134
|
+
clearTimeout(timeout);
|
|
135
|
+
reject(new boom_1.Boom('Cancelled', {
|
|
136
|
+
statusCode: 500,
|
|
137
|
+
data: {
|
|
138
|
+
stack
|
|
139
|
+
}
|
|
140
|
+
}));
|
|
141
|
+
};
|
|
142
|
+
return { delay, cancel };
|
|
143
|
+
};
|
|
144
|
+
exports.delayCancellable = delayCancellable;
|
|
145
|
+
async function promiseTimeout(ms, promise) {
|
|
146
|
+
if (!ms) {
|
|
147
|
+
return new Promise(promise);
|
|
210
148
|
}
|
|
211
|
-
const
|
|
212
|
-
|
|
213
|
-
const
|
|
214
|
-
|
|
215
|
-
|
|
216
|
-
|
|
217
|
-
|
|
218
|
-
|
|
219
|
-
|
|
149
|
+
const stack = new Error().stack;
|
|
150
|
+
// Create a promise that rejects in <ms> milliseconds
|
|
151
|
+
const { delay, cancel } = (0, exports.delayCancellable)(ms);
|
|
152
|
+
const p = new Promise((resolve, reject) => {
|
|
153
|
+
delay
|
|
154
|
+
.then(() => reject(new boom_1.Boom('Timed Out', {
|
|
155
|
+
statusCode: Types_1.DisconnectReason.timedOut,
|
|
156
|
+
data: {
|
|
157
|
+
stack
|
|
158
|
+
}
|
|
159
|
+
})))
|
|
160
|
+
.catch(err => reject(err));
|
|
161
|
+
promise(resolve, reject);
|
|
162
|
+
})
|
|
163
|
+
.finally(cancel);
|
|
164
|
+
return p;
|
|
165
|
+
}
|
|
166
|
+
exports.promiseTimeout = promiseTimeout;
|
|
167
|
+
const generateMessageIDV2 = (userId) => {
|
|
168
|
+
const data = Buffer.alloc(8 + 20 + 16);
|
|
169
|
+
data.writeBigUInt64BE(BigInt(Math.floor(Date.now() / 1000)));
|
|
170
|
+
if (userId) {
|
|
171
|
+
const id = (0, WABinary_1.jidDecode)(userId);
|
|
172
|
+
if (id === null || id === void 0 ? void 0 : id.user) {
|
|
173
|
+
data.write(id.user, 8);
|
|
174
|
+
data.write('@c.us', 8 + id.user.length);
|
|
220
175
|
}
|
|
221
|
-
};
|
|
222
176
|
}
|
|
223
|
-
const
|
|
224
|
-
|
|
225
|
-
|
|
226
|
-
|
|
227
|
-
|
|
228
|
-
|
|
229
|
-
|
|
230
|
-
|
|
231
|
-
|
|
232
|
-
|
|
233
|
-
|
|
177
|
+
const random = (0, crypto_1.randomBytes)(16);
|
|
178
|
+
random.copy(data, 28);
|
|
179
|
+
const hash = (0, crypto_1.createHash)('sha256').update(data).digest();
|
|
180
|
+
return '3EB0' + hash.toString('hex').toUpperCase().substring(0, 18);
|
|
181
|
+
};
|
|
182
|
+
exports.generateMessageIDV2 = generateMessageIDV2;
|
|
183
|
+
// generate a random ID to attach to a message
|
|
184
|
+
const generateMessageID = () => 'ILSYM-' + (0, crypto_1.randomBytes)(6).toString('hex').toUpperCase();
|
|
185
|
+
exports.generateMessageID = generateMessageID;
|
|
186
|
+
function bindWaitForEvent(ev, event) {
|
|
187
|
+
return async (check, timeoutMs) => {
|
|
188
|
+
let listener;
|
|
189
|
+
let closeListener;
|
|
190
|
+
await (promiseTimeout(timeoutMs, (resolve, reject) => {
|
|
191
|
+
closeListener = ({ connection, lastDisconnect }) => {
|
|
192
|
+
if (connection === 'close') {
|
|
193
|
+
reject((lastDisconnect === null || lastDisconnect === void 0 ? void 0 : lastDisconnect.error)
|
|
194
|
+
|| new boom_1.Boom('Connection Closed', { statusCode: Types_1.DisconnectReason.connectionClosed }));
|
|
195
|
+
}
|
|
196
|
+
};
|
|
197
|
+
ev.on('connection.update', closeListener);
|
|
198
|
+
listener = (update) => {
|
|
199
|
+
if (check(update)) {
|
|
200
|
+
resolve();
|
|
201
|
+
}
|
|
202
|
+
};
|
|
203
|
+
ev.on(event, listener);
|
|
204
|
+
})
|
|
205
|
+
.finally(() => {
|
|
206
|
+
ev.off(event, listener);
|
|
207
|
+
ev.off('connection.update', closeListener);
|
|
208
|
+
}));
|
|
234
209
|
};
|
|
235
|
-
|
|
210
|
+
}
|
|
211
|
+
exports.bindWaitForEvent = bindWaitForEvent;
|
|
212
|
+
const bindWaitForConnectionUpdate = (ev) => bindWaitForEvent(ev, 'connection.update');
|
|
213
|
+
exports.bindWaitForConnectionUpdate = bindWaitForConnectionUpdate;
|
|
214
|
+
const printQRIfNecessaryListener = (ev, logger) => {
|
|
215
|
+
ev.on('connection.update', async ({ qr }) => {
|
|
216
|
+
if (qr) {
|
|
217
|
+
const QR = await import('qrcode-terminal')
|
|
218
|
+
.then(m => m.default || m)
|
|
219
|
+
.catch(() => {
|
|
220
|
+
logger.error('QR code terminal not added as dependency');
|
|
221
|
+
});
|
|
222
|
+
QR === null || QR === void 0 ? void 0 : QR.generate(qr, { small: true });
|
|
223
|
+
}
|
|
224
|
+
});
|
|
225
|
+
};
|
|
226
|
+
exports.printQRIfNecessaryListener = printQRIfNecessaryListener;
|
|
227
|
+
/**
|
|
228
|
+
* utility that fetches latest baileys version from the master branch.
|
|
229
|
+
* Use to ensure your WA connection is always on the latest version
|
|
230
|
+
*/
|
|
231
|
+
const fetchLatestWaWebVersion = async (options = {}) => {
|
|
232
|
+
try {
|
|
233
|
+
const defaultHeaders = {
|
|
234
|
+
'User-Agent':
|
|
235
|
+
'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/120.0.0.0 Safari/537.36',
|
|
236
|
+
'Accept': '*/*'
|
|
237
|
+
}
|
|
238
|
+
|
|
239
|
+
const headers = { ...defaultHeaders, ...options.headers }
|
|
240
|
+
|
|
241
|
+
const response = await fetch_1('https://web.whatsapp.com/sw.js', {
|
|
242
|
+
method: 'GET',
|
|
243
|
+
headers
|
|
244
|
+
})
|
|
245
|
+
|
|
246
|
+
if (!response.ok) {
|
|
247
|
+
throw new Error(`Failed to fetch sw.js: ${response.status} ${response.statusText}`)
|
|
248
|
+
}
|
|
249
|
+
|
|
250
|
+
const data = await response.text()
|
|
251
|
+
const regex = /"client_revision":\s*(\d+)/ // regex cukup begini untuk Node
|
|
252
|
+
const match = data.match(regex)
|
|
253
|
+
|
|
254
|
+
if (!match || !match[1]) {
|
|
255
|
+
return {
|
|
256
|
+
version: baileysVersion,
|
|
257
|
+
isLatest: false,
|
|
258
|
+
error: { message: 'Client revision not found' }
|
|
259
|
+
}
|
|
260
|
+
}
|
|
261
|
+
|
|
262
|
+
const clientRevision = match[1]
|
|
263
|
+
return {
|
|
264
|
+
version: [2, 3000, +clientRevision],
|
|
265
|
+
isLatest: true
|
|
266
|
+
}
|
|
267
|
+
} catch (error) {
|
|
268
|
+
return {
|
|
269
|
+
version: baileysVersion,
|
|
270
|
+
isLatest: false,
|
|
271
|
+
error
|
|
272
|
+
}
|
|
273
|
+
}
|
|
274
|
+
}
|
|
275
|
+
exports.fetchLatestWaWebVersion = fetchLatestWaWebVersion;
|
|
276
|
+
/**
|
|
277
|
+
* utility that fetches latest baileys version from the master branch.
|
|
278
|
+
* Use to ensure your WA connection is always on the latest version
|
|
279
|
+
*/
|
|
280
|
+
const fetchLatestBaileysVersion = async (options = {}) => {
|
|
281
|
+
const URL = 'https://raw.githubusercontent.com/kiuur/bails/master/src/Defaults/baileys-version.json';
|
|
282
|
+
try {
|
|
283
|
+
const result = await axios_1.default.get(URL, {
|
|
284
|
+
...options,
|
|
285
|
+
responseType: 'json'
|
|
286
|
+
});
|
|
287
|
+
return {
|
|
288
|
+
version: result.data.version,
|
|
289
|
+
isLatest: true
|
|
290
|
+
};
|
|
291
|
+
}
|
|
292
|
+
catch (error) {
|
|
293
|
+
return {
|
|
294
|
+
version: baileys_version_json_1.version,
|
|
295
|
+
isLatest: false,
|
|
296
|
+
error
|
|
297
|
+
};
|
|
298
|
+
}
|
|
236
299
|
};
|
|
237
|
-
|
|
238
|
-
|
|
239
|
-
|
|
240
|
-
|
|
300
|
+
exports.fetchLatestBaileysVersion = fetchLatestBaileysVersion;
|
|
301
|
+
/** unique message tag prefix for MD clients */
|
|
302
|
+
const generateMdTagPrefix = () => {
|
|
303
|
+
const bytes = (0, crypto_1.randomBytes)(4);
|
|
304
|
+
return `${bytes.readUInt16BE()}.${bytes.readUInt16BE(2)}-`;
|
|
241
305
|
};
|
|
242
|
-
|
|
306
|
+
exports.generateMdTagPrefix = generateMdTagPrefix;
|
|
243
307
|
const STATUS_MAP = {
|
|
244
|
-
|
|
245
|
-
|
|
246
|
-
|
|
247
|
-
"read-self": proto.WebMessageInfo.Status.READ
|
|
308
|
+
'played': WAProto_1.proto.WebMessageInfo.Status.PLAYED,
|
|
309
|
+
'read': WAProto_1.proto.WebMessageInfo.Status.READ,
|
|
310
|
+
'read-self': WAProto_1.proto.WebMessageInfo.Status.READ
|
|
248
311
|
};
|
|
249
|
-
|
|
250
|
-
|
|
251
|
-
|
|
252
|
-
|
|
253
|
-
|
|
254
|
-
|
|
255
|
-
|
|
312
|
+
/**
|
|
313
|
+
* Given a type of receipt, returns what the new status of the message should be
|
|
314
|
+
* @param type type from receipt
|
|
315
|
+
*/
|
|
316
|
+
const getStatusFromReceiptType = (type) => {
|
|
317
|
+
const status = STATUS_MAP[type];
|
|
318
|
+
if (typeof type === 'undefined') {
|
|
319
|
+
return WAProto_1.proto.WebMessageInfo.Status.DELIVERY_ACK;
|
|
320
|
+
}
|
|
321
|
+
return status;
|
|
256
322
|
};
|
|
257
|
-
|
|
323
|
+
exports.getStatusFromReceiptType = getStatusFromReceiptType;
|
|
258
324
|
const CODE_MAP = {
|
|
259
|
-
|
|
325
|
+
conflict: Types_1.DisconnectReason.connectionReplaced
|
|
260
326
|
};
|
|
261
|
-
|
|
262
|
-
|
|
263
|
-
|
|
264
|
-
|
|
265
|
-
|
|
266
|
-
|
|
267
|
-
reason =
|
|
268
|
-
|
|
269
|
-
|
|
270
|
-
|
|
271
|
-
|
|
272
|
-
|
|
327
|
+
/**
|
|
328
|
+
* Stream errors generally provide a reason, map that to a baileys DisconnectReason
|
|
329
|
+
* @param reason the string reason given, eg. "conflict"
|
|
330
|
+
*/
|
|
331
|
+
const getErrorCodeFromStreamError = (node) => {
|
|
332
|
+
const [reasonNode] = (0, WABinary_1.getAllBinaryNodeChildren)(node);
|
|
333
|
+
let reason = (reasonNode === null || reasonNode === void 0 ? void 0 : reasonNode.tag) || 'unknown';
|
|
334
|
+
const statusCode = +(node.attrs.code || CODE_MAP[reason] || Types_1.DisconnectReason.badSession);
|
|
335
|
+
if (statusCode === Types_1.DisconnectReason.restartRequired) {
|
|
336
|
+
reason = 'restart required';
|
|
337
|
+
}
|
|
338
|
+
return {
|
|
339
|
+
reason,
|
|
340
|
+
statusCode
|
|
341
|
+
};
|
|
273
342
|
};
|
|
274
|
-
|
|
275
|
-
|
|
276
|
-
|
|
277
|
-
|
|
278
|
-
|
|
279
|
-
|
|
280
|
-
|
|
281
|
-
|
|
282
|
-
|
|
283
|
-
|
|
284
|
-
|
|
285
|
-
|
|
286
|
-
|
|
287
|
-
|
|
288
|
-
|
|
289
|
-
|
|
290
|
-
|
|
291
|
-
|
|
292
|
-
|
|
293
|
-
|
|
294
|
-
|
|
295
|
-
|
|
296
|
-
|
|
297
|
-
|
|
298
|
-
|
|
299
|
-
|
|
300
|
-
|
|
343
|
+
exports.getErrorCodeFromStreamError = getErrorCodeFromStreamError;
|
|
344
|
+
const getCallStatusFromNode = ({ tag, attrs }) => {
|
|
345
|
+
let status;
|
|
346
|
+
switch (tag) {
|
|
347
|
+
case 'offer':
|
|
348
|
+
case 'offer_notice':
|
|
349
|
+
status = 'offer';
|
|
350
|
+
break;
|
|
351
|
+
case 'terminate':
|
|
352
|
+
if (attrs.reason === 'timeout') {
|
|
353
|
+
status = 'timeout';
|
|
354
|
+
}
|
|
355
|
+
else {
|
|
356
|
+
status = 'reject';
|
|
357
|
+
}
|
|
358
|
+
break;
|
|
359
|
+
case 'reject':
|
|
360
|
+
status = 'reject';
|
|
361
|
+
break;
|
|
362
|
+
case 'accept':
|
|
363
|
+
status = 'accept';
|
|
364
|
+
break;
|
|
365
|
+
default:
|
|
366
|
+
status = 'ringing';
|
|
367
|
+
break;
|
|
368
|
+
}
|
|
369
|
+
return status;
|
|
301
370
|
};
|
|
302
|
-
|
|
303
|
-
const UNEXPECTED_SERVER_CODE_TEXT =
|
|
304
|
-
|
|
305
|
-
|
|
306
|
-
|
|
307
|
-
|
|
308
|
-
|
|
309
|
-
|
|
371
|
+
exports.getCallStatusFromNode = getCallStatusFromNode;
|
|
372
|
+
const UNEXPECTED_SERVER_CODE_TEXT = 'Unexpected server response: ';
|
|
373
|
+
const getCodeFromWSError = (error) => {
|
|
374
|
+
var _a, _b, _c;
|
|
375
|
+
let statusCode = 500;
|
|
376
|
+
if ((_a = error === null || error === void 0 ? void 0 : error.message) === null || _a === void 0 ? void 0 : _a.includes(UNEXPECTED_SERVER_CODE_TEXT)) {
|
|
377
|
+
const code = +(error === null || error === void 0 ? void 0 : error.message.slice(UNEXPECTED_SERVER_CODE_TEXT.length));
|
|
378
|
+
if (!Number.isNaN(code) && code >= 400) {
|
|
379
|
+
statusCode = code;
|
|
380
|
+
}
|
|
381
|
+
}
|
|
382
|
+
else if (((_b = error === null || error === void 0 ? void 0 : error.code) === null || _b === void 0 ? void 0 : _b.startsWith('E'))
|
|
383
|
+
|| ((_c = error === null || error === void 0 ? void 0 : error.message) === null || _c === void 0 ? void 0 : _c.includes('timed out'))) { // handle ETIMEOUT, ENOTFOUND etc
|
|
384
|
+
statusCode = 408;
|
|
310
385
|
}
|
|
311
|
-
|
|
312
|
-
else if (
|
|
313
|
-
error?.code?.startsWith("E") ||
|
|
314
|
-
error?.message?.includes("timed out")) {
|
|
315
|
-
statusCode = 408;
|
|
316
|
-
}
|
|
317
|
-
return statusCode;
|
|
386
|
+
return statusCode;
|
|
318
387
|
};
|
|
319
|
-
|
|
320
|
-
|
|
321
|
-
|
|
388
|
+
exports.getCodeFromWSError = getCodeFromWSError;
|
|
389
|
+
/**
|
|
390
|
+
* Is the given platform WA business
|
|
391
|
+
* @param platform AuthenticationCreds.platform
|
|
392
|
+
*/
|
|
393
|
+
const isWABusinessPlatform = (platform) => {
|
|
394
|
+
return platform === 'smbi' || platform === 'smba';
|
|
322
395
|
};
|
|
323
|
-
|
|
324
|
-
|
|
325
|
-
|
|
326
|
-
|
|
327
|
-
|
|
396
|
+
exports.isWABusinessPlatform = isWABusinessPlatform;
|
|
397
|
+
function trimUndefined(obj) {
|
|
398
|
+
for (const key in obj) {
|
|
399
|
+
if (typeof obj[key] === 'undefined') {
|
|
400
|
+
delete obj[key];
|
|
401
|
+
}
|
|
328
402
|
}
|
|
329
|
-
|
|
330
|
-
return obj;
|
|
403
|
+
return obj;
|
|
331
404
|
}
|
|
332
|
-
|
|
333
|
-
const CROCKFORD_CHARACTERS =
|
|
334
|
-
|
|
335
|
-
|
|
336
|
-
|
|
337
|
-
|
|
338
|
-
|
|
339
|
-
|
|
340
|
-
|
|
341
|
-
|
|
342
|
-
|
|
343
|
-
|
|
405
|
+
exports.trimUndefined = trimUndefined;
|
|
406
|
+
const CROCKFORD_CHARACTERS = '123456789ABCDEFGHJKLMNPQRSTVWXYZ';
|
|
407
|
+
function bytesToCrockford(buffer) {
|
|
408
|
+
let value = 0;
|
|
409
|
+
let bitCount = 0;
|
|
410
|
+
const crockford = [];
|
|
411
|
+
for (let i = 0; i < buffer.length; i++) {
|
|
412
|
+
value = (value << 8) | (buffer[i] & 0xff);
|
|
413
|
+
bitCount += 8;
|
|
414
|
+
while (bitCount >= 5) {
|
|
415
|
+
crockford.push(CROCKFORD_CHARACTERS.charAt((value >>> (bitCount - 5)) & 31));
|
|
416
|
+
bitCount -= 5;
|
|
417
|
+
}
|
|
418
|
+
}
|
|
419
|
+
if (bitCount > 0) {
|
|
420
|
+
crockford.push(CROCKFORD_CHARACTERS.charAt((value << (5 - bitCount)) & 31));
|
|
344
421
|
}
|
|
345
|
-
|
|
346
|
-
if (bitCount > 0) {
|
|
347
|
-
crockford.push(CROCKFORD_CHARACTERS.charAt((value << (5 - bitCount)) & 31));
|
|
348
|
-
}
|
|
349
|
-
return crockford.join("");
|
|
422
|
+
return crockford.join('');
|
|
350
423
|
}
|
|
351
|
-
|
|
352
|
-
|
|
353
|
-
|
|
424
|
+
exports.bytesToCrockford = bytesToCrockford;
|
|
425
|
+
const encodeNewsletterMessage = (message) => {
|
|
426
|
+
return WAProto_1.proto.Message.encode(message).finish()
|
|
354
427
|
}
|
|
355
|
-
|
|
428
|
+
exports.encodeNewsletterMessage = encodeNewsletterMessage;
|