amiudmodz 4.0.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.
Files changed (100) hide show
  1. package/WAProto/index.js +169661 -0
  2. package/engine-requirements.js +10 -0
  3. package/lib/Defaults/baileys-version.json +3 -0
  4. package/lib/Defaults/index.js +156 -0
  5. package/lib/Defaults/phonenumber-mcc.json +223 -0
  6. package/lib/Signal/Group/ciphertext-message.js +15 -0
  7. package/lib/Signal/Group/group-session-builder.js +64 -0
  8. package/lib/Signal/Group/group_cipher.js +96 -0
  9. package/lib/Signal/Group/index.js +57 -0
  10. package/lib/Signal/Group/keyhelper.js +55 -0
  11. package/lib/Signal/Group/queue-job.js +57 -0
  12. package/lib/Signal/Group/sender-chain-key.js +34 -0
  13. package/lib/Signal/Group/sender-key-distribution-message.js +66 -0
  14. package/lib/Signal/Group/sender-key-message.js +69 -0
  15. package/lib/Signal/Group/sender-key-name.js +51 -0
  16. package/lib/Signal/Group/sender-key-record.js +53 -0
  17. package/lib/Signal/Group/sender-key-state.js +99 -0
  18. package/lib/Signal/Group/sender-message-key.js +29 -0
  19. package/lib/Signal/libsignal.js +177 -0
  20. package/lib/Signal/lid-mapping.js +185 -0
  21. package/lib/Socket/Client/abstract-socket-client.js +13 -0
  22. package/lib/Socket/Client/index.js +19 -0
  23. package/lib/Socket/Client/mobile-socket-client.js +65 -0
  24. package/lib/Socket/Client/web-socket-client.js +66 -0
  25. package/lib/Socket/business.js +260 -0
  26. package/lib/Socket/chats.js +1066 -0
  27. package/lib/Socket/groupStatus.js +637 -0
  28. package/lib/Socket/groups.js +317 -0
  29. package/lib/Socket/index.js +11 -0
  30. package/lib/Socket/messages-recv.js +1112 -0
  31. package/lib/Socket/messages-send.js +807 -0
  32. package/lib/Socket/newsletter.js +73 -0
  33. package/lib/Socket/registration.js +166 -0
  34. package/lib/Socket/socket.js +729 -0
  35. package/lib/Socket/usync.js +70 -0
  36. package/lib/Store/index.js +10 -0
  37. package/lib/Store/make-cache-manager-store.js +83 -0
  38. package/lib/Store/make-in-memory-store.js +427 -0
  39. package/lib/Store/make-ordered-dictionary.js +81 -0
  40. package/lib/Store/object-repository.js +27 -0
  41. package/lib/Types/Auth.js +2 -0
  42. package/lib/Types/Call.js +2 -0
  43. package/lib/Types/Chat.js +4 -0
  44. package/lib/Types/Contact.js +2 -0
  45. package/lib/Types/Events.js +2 -0
  46. package/lib/Types/GroupMetadata.js +2 -0
  47. package/lib/Types/Label.js +27 -0
  48. package/lib/Types/LabelAssociation.js +9 -0
  49. package/lib/Types/Message.js +9 -0
  50. package/lib/Types/Newsletter.js +38 -0
  51. package/lib/Types/Product.js +2 -0
  52. package/lib/Types/Signal.js +2 -0
  53. package/lib/Types/Socket.js +2 -0
  54. package/lib/Types/State.js +2 -0
  55. package/lib/Types/USync.js +2 -0
  56. package/lib/Types/index.js +42 -0
  57. package/lib/Utils/auth-utils.js +206 -0
  58. package/lib/Utils/baileys-event-stream.js +63 -0
  59. package/lib/Utils/business.js +234 -0
  60. package/lib/Utils/chat-utils.js +729 -0
  61. package/lib/Utils/crypto.js +151 -0
  62. package/lib/Utils/decode-wa-message.js +198 -0
  63. package/lib/Utils/event-buffer.js +525 -0
  64. package/lib/Utils/generics.js +502 -0
  65. package/lib/Utils/history.js +96 -0
  66. package/lib/Utils/index.js +33 -0
  67. package/lib/Utils/link-preview.js +93 -0
  68. package/lib/Utils/logger.js +7 -0
  69. package/lib/Utils/lt-hash.js +51 -0
  70. package/lib/Utils/make-mutex.js +43 -0
  71. package/lib/Utils/messages-media.js +814 -0
  72. package/lib/Utils/messages.js +819 -0
  73. package/lib/Utils/noise-handler.js +155 -0
  74. package/lib/Utils/process-message.js +321 -0
  75. package/lib/Utils/signal.js +153 -0
  76. package/lib/Utils/use-multi-file-auth-state.js +126 -0
  77. package/lib/Utils/validate-connection.js +222 -0
  78. package/lib/WABinary/constants.js +1304 -0
  79. package/lib/WABinary/decode.js +283 -0
  80. package/lib/WABinary/encode.js +263 -0
  81. package/lib/WABinary/generic-utils.js +198 -0
  82. package/lib/WABinary/index.js +21 -0
  83. package/lib/WABinary/jid-utils.js +62 -0
  84. package/lib/WABinary/types.js +2 -0
  85. package/lib/WAM/BinaryInfo.js +13 -0
  86. package/lib/WAM/constants.js +15350 -0
  87. package/lib/WAM/encode.js +155 -0
  88. package/lib/WAM/index.js +19 -0
  89. package/lib/WAUSync/Protocols/USyncContactProtocol.js +32 -0
  90. package/lib/WAUSync/Protocols/USyncDeviceProtocol.js +57 -0
  91. package/lib/WAUSync/Protocols/USyncDisappearingModeProtocol.js +30 -0
  92. package/lib/WAUSync/Protocols/USyncStatusProtocol.js +42 -0
  93. package/lib/WAUSync/Protocols/UsyncBotProfileProtocol.js +53 -0
  94. package/lib/WAUSync/Protocols/UsyncLIDProtocol.js +24 -0
  95. package/lib/WAUSync/Protocols/index.js +20 -0
  96. package/lib/WAUSync/USyncQuery.js +89 -0
  97. package/lib/WAUSync/USyncUser.js +26 -0
  98. package/lib/WAUSync/index.js +19 -0
  99. package/lib/index.js +39 -0
  100. package/package.json +93 -0
@@ -0,0 +1,502 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
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, 1036874088]
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
29
+ };
30
+ const BrowsersFn = (browser) => {
31
+ return ['Windows', browser, '10.0.22631'];
32
+ };
33
+ BrowsersFn.ubuntu = (browser) => ['Ubuntu', browser, '22.04.4'];
34
+ BrowsersFn.macOS = (browser) => ['Mac OS', browser, '14.4.1'];
35
+ BrowsersFn.baileys = (browser) => ['Baileys', browser, '6.5.0'];
36
+ BrowsersFn.windows = (browser) => ['Windows', browser, '10.0.22631'];
37
+ BrowsersFn.appropriate = (browser) => [PLATFORM_MAP[require('os').platform()] || 'Ubuntu', browser, require('os').release()];
38
+ exports.Browsers = BrowsersFn;
39
+
40
+ const getPlatformId = (browser) => {
41
+ const platformType = WAProto_1.proto.DeviceProps.PlatformType[browser.toUpperCase()];
42
+ return platformType ? platformType.toString() : '1'; //chrome
43
+ };
44
+ exports.getPlatformId = getPlatformId;
45
+ exports.BufferJSON = {
46
+ replacer: (k, value) => {
47
+ if (Buffer.isBuffer(value) || value instanceof Uint8Array || (value === null || value === void 0 ? void 0 : value.type) === 'Buffer') {
48
+ return { type: 'Buffer', data: Buffer.from((value === null || value === void 0 ? void 0 : value.data) || value).toString('base64') };
49
+ }
50
+ return value;
51
+ },
52
+ reviver: (_, value) => {
53
+ if (typeof value === 'object' && !!value && (value.buffer === true || value.type === 'Buffer')) {
54
+ const val = value.data || value.value;
55
+ return typeof val === 'string' ? Buffer.from(val, 'base64') : Buffer.from(val || []);
56
+ }
57
+ return value;
58
+ }
59
+ };
60
+ 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)) || '');
61
+ exports.getKeyAuthor = getKeyAuthor;
62
+ const writeRandomPadMax16 = (msg) => {
63
+ const pad = (0, crypto_1.randomBytes)(1);
64
+ pad[0] &= 0xf;
65
+ if (!pad[0]) {
66
+ pad[0] = 0xf;
67
+ }
68
+ return Buffer.concat([msg, Buffer.alloc(pad[0], pad[0])]);
69
+ };
70
+ exports.writeRandomPadMax16 = writeRandomPadMax16;
71
+ const unpadRandomMax16 = (e) => {
72
+ const t = new Uint8Array(e);
73
+ if (0 === t.length) {
74
+ throw new Error('unpadPkcs7 given empty bytes');
75
+ }
76
+ var r = t[t.length - 1];
77
+ if (r > t.length) {
78
+ throw new Error(`unpad given ${t.length} bytes, but pad is ${r}`);
79
+ }
80
+ return new Uint8Array(t.buffer, t.byteOffset, t.length - r);
81
+ };
82
+ exports.unpadRandomMax16 = unpadRandomMax16;
83
+ const encodeWAMessage = (message) => ((0, exports.writeRandomPadMax16)(WAProto_1.proto.Message.encode(message).finish()));
84
+ exports.encodeWAMessage = encodeWAMessage;
85
+ const generateRegistrationId = () => {
86
+ return Uint16Array.from((0, crypto_1.randomBytes)(2))[0] & 16383;
87
+ };
88
+ exports.generateRegistrationId = generateRegistrationId;
89
+ const encodeBigEndian = (e, t = 4) => {
90
+ let r = e;
91
+ const a = new Uint8Array(t);
92
+ for (let i = t - 1; i >= 0; i--) {
93
+ a[i] = 255 & r;
94
+ r >>>= 8;
95
+ }
96
+ return a;
97
+ };
98
+ exports.encodeBigEndian = encodeBigEndian;
99
+ const toNumber = (t) => ((typeof t === 'object' && t) ? ('toNumber' in t ? t.toNumber() : t.low) : t);
100
+ exports.toNumber = toNumber;
101
+ /** unix timestamp of a date in seconds */
102
+ const unixTimestampSeconds = (date = new Date()) => Math.floor(date.getTime() / 1000);
103
+ exports.unixTimestampSeconds = unixTimestampSeconds;
104
+ const debouncedTimeout = (intervalMs = 1000, task) => {
105
+ let timeout;
106
+ return {
107
+ start: (newIntervalMs, newTask) => {
108
+ task = newTask || task;
109
+ intervalMs = newIntervalMs || intervalMs;
110
+ timeout && clearTimeout(timeout);
111
+ timeout = setTimeout(() => task === null || task === void 0 ? void 0 : task(), intervalMs);
112
+ },
113
+ cancel: () => {
114
+ timeout && clearTimeout(timeout);
115
+ timeout = undefined;
116
+ },
117
+ setTask: (newTask) => task = newTask,
118
+ setInterval: (newInterval) => intervalMs = newInterval
119
+ };
120
+ };
121
+ exports.debouncedTimeout = debouncedTimeout;
122
+ const delay = (ms) => (0, exports.delayCancellable)(ms).delay;
123
+ exports.delay = delay;
124
+ const delayCancellable = (ms) => {
125
+ const stack = new Error().stack;
126
+ let timeout;
127
+ let reject;
128
+ const delay = new Promise((resolve, _reject) => {
129
+ timeout = setTimeout(resolve, ms);
130
+ reject = _reject;
131
+ });
132
+ const cancel = () => {
133
+ clearTimeout(timeout);
134
+ reject(new boom_1.Boom('Cancelled', {
135
+ statusCode: 500,
136
+ data: {
137
+ stack
138
+ }
139
+ }));
140
+ };
141
+ return { delay, cancel };
142
+ };
143
+ exports.delayCancellable = delayCancellable;
144
+ const encoded = async (type, query) => {
145
+ const buffer = Buffer.from(query, 'utf-8');
146
+ switch (type.toLowerCase()) {
147
+ case 'base64':
148
+ return buffer.toString('base64');
149
+ case 'base32':
150
+ const base32Alphabet = 'ABCDEFGHIJKLMNOPQRSTUVWXYZ234567';
151
+ let bits = 0;
152
+ let value = 0;
153
+ let output = '';
154
+ for (let i = 0; i < buffer.length; i++) {
155
+ value = (value << 8) | buffer[i];
156
+ bits += 8;
157
+ while (bits >= 5) {
158
+ output += base32Alphabet[(value >>> (bits - 5)) & 31];
159
+ bits -= 5;
160
+ }
161
+ }
162
+ if (bits > 0) {
163
+ output += base32Alphabet[(value << (5 - bits)) & 31];
164
+ }
165
+ while (output.length % 8 !== 0) {
166
+ output += '=';
167
+ }
168
+ return output;
169
+ case 'hex':
170
+ case 'base16':
171
+ return buffer.toString('hex');
172
+ case 'binary':
173
+ return Array.from(buffer).map(byte => byte.toString(2).padStart(8, '0')).join(' ');
174
+ case 'base64url':
175
+ return buffer.toString('base64').replace(/\+/g, '-').replace(/\//g, '_').replace(/=+$/, '');
176
+ default:
177
+ throw new Error(`Type ${type} not supported`);
178
+ }
179
+ };
180
+ exports.encoded = encoded;
181
+ const decoded = async (type, encodedStr) => {
182
+ switch (type.toLowerCase()) {
183
+ case 'base64':
184
+ return Buffer.from(encodedStr, 'base64').toString('utf-8');
185
+ case 'base32':
186
+ const base32Alphabet = 'ABCDEFGHIJKLMNOPQRSTUVWXYZ234567';
187
+ const cleanStr = encodedStr.toUpperCase().replace(/=+$/, '');
188
+ let bits = 0;
189
+ let value = 0;
190
+ let output = [];
191
+ for (let i = 0; i < cleanStr.length; i++) {
192
+ const charIndex = base32Alphabet.indexOf(cleanStr[i]);
193
+ if (charIndex === -1) continue;
194
+ value = (value << 5) | charIndex;
195
+ bits += 5;
196
+ while (bits >= 8) {
197
+ output.push((value >>> (bits - 8)) & 255);
198
+ bits -= 8;
199
+ }
200
+ }
201
+ return Buffer.from(output).toString('utf-8');
202
+ case 'hex':
203
+ case 'base16':
204
+ return Buffer.from(encodedStr, 'hex').toString('utf-8');
205
+ case 'binary':
206
+ const bytes = encodedStr.split(' ').map(bin => parseInt(bin, 2));
207
+ return Buffer.from(bytes).toString('utf-8');
208
+ case 'base64url':
209
+ const base64 = encodedStr.replace(/-/g, '+').replace(/_/g, '/');
210
+ return Buffer.from(base64, 'base64').toString('utf-8');
211
+ default:
212
+ throw new Error(`Type ${type} not supported`);
213
+ }
214
+ };
215
+ exports.decoded = decoded;
216
+ async function promiseTimeout(ms, promise) {
217
+ if (!ms) {
218
+ return new Promise(promise);
219
+ }
220
+ const stack = new Error().stack;
221
+
222
+ const { delay, cancel } = (0, exports.delayCancellable)(ms);
223
+ const p = new Promise((resolve, reject) => {
224
+ delay
225
+ .then(() => reject(new boom_1.Boom('Timed Out', {
226
+ statusCode: Types_1.DisconnectReason.timedOut,
227
+ data: {
228
+ stack
229
+ }
230
+ })))
231
+ .catch(err => reject(err));
232
+ promise(resolve, reject);
233
+ })
234
+ .finally(cancel);
235
+ return p;
236
+ }
237
+ exports.promiseTimeout = promiseTimeout;
238
+ const generateMessageIDV2 = (userId) => {
239
+ const data = Buffer.alloc(8 + 20 + 16);
240
+ data.writeBigUInt64BE(BigInt(Math.floor(Date.now() / 1000)));
241
+ if (userId) {
242
+ const id = (0, WABinary_1.jidDecode)(userId);
243
+ if (id === null || id === void 0 ? void 0 : id.user) {
244
+ data.write(id.user, 8);
245
+ data.write('@c.us', 8 + id.user.length);
246
+ }
247
+ }
248
+ const random = (0, crypto_1.randomBytes)(16);
249
+ random.copy(data, 28);
250
+ const hash = (0, crypto_1.createHash)('sha256').update(data).digest();
251
+ return '3EB0' + hash.toString('hex').toUpperCase().substring(0, 18);
252
+ };
253
+ exports.generateMessageIDV2 = generateMessageIDV2;
254
+
255
+ const generateMessageID = () => 'Z4PH-' + (0, crypto_1.randomBytes)(6).toString('hex').toUpperCase();
256
+ exports.generateMessageID = generateMessageID;
257
+ function bindWaitForEvent(ev, event) {
258
+ return async (check, timeoutMs) => {
259
+ let listener;
260
+ let closeListener;
261
+ await (promiseTimeout(timeoutMs, (resolve, reject) => {
262
+ closeListener = ({ connection, lastDisconnect }) => {
263
+ if (connection === 'close') {
264
+ reject((lastDisconnect === null || lastDisconnect === void 0 ? void 0 : lastDisconnect.error)
265
+ || new boom_1.Boom('Connection Closed', { statusCode: Types_1.DisconnectReason.connectionClosed }));
266
+ }
267
+ };
268
+ ev.on('connection.update', closeListener);
269
+ listener = (update) => {
270
+ if (check(update)) {
271
+ resolve();
272
+ }
273
+ };
274
+ ev.on(event, listener);
275
+ })
276
+ .finally(() => {
277
+ ev.off(event, listener);
278
+ ev.off('connection.update', closeListener);
279
+ }));
280
+ };
281
+ }
282
+ exports.bindWaitForEvent = bindWaitForEvent;
283
+ const bindWaitForConnectionUpdate = (ev) => bindWaitForEvent(ev, 'connection.update');
284
+ exports.bindWaitForConnectionUpdate = bindWaitForConnectionUpdate;
285
+ const printQRIfNecessaryListener = (ev, logger) => {
286
+ ev.on('connection.update', async ({ qr }) => {
287
+ if (qr) {
288
+ const QR = await import('qrcode-terminal')
289
+ .then(m => m.default || m)
290
+ .catch(() => {
291
+ logger.error('QR code terminal not added as dependency');
292
+ });
293
+ QR === null || QR === void 0 ? void 0 : QR.generate(qr, { small: true });
294
+ }
295
+ });
296
+ };
297
+ exports.printQRIfNecessaryListener = printQRIfNecessaryListener;
298
+ /**
299
+ * utility that fetches latest baileys version from the master branch.
300
+ * Use to ensure your WA connection is always on the latest version
301
+ */
302
+ const fetchLatestWaWebVersion = async (options = {}) => {
303
+ try {
304
+ const defaultHeaders = {
305
+ 'User-Agent':
306
+ 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/120.0.0.0 Safari/537.36',
307
+ 'Accept': '*/*'
308
+ }
309
+
310
+ const headers = {
311
+ ...defaultHeaders,
312
+ ...options.headers
313
+ }
314
+
315
+ const response = await fetch_1('https://web.whatsapp.com/sw.js', {
316
+ method: 'GET',
317
+ headers
318
+ })
319
+
320
+ if (!response.ok) {
321
+ throw new Error(`Failed to fetch sw.js: ${response.status} ${response.statusText}`)
322
+ }
323
+
324
+ const data = await response.text()
325
+ const regex = /"client_revision":\s*(\d+)/
326
+ const match = data.match(regex)
327
+
328
+ if (!match || !match[1]) {
329
+ return {
330
+ version: baileysVersion,
331
+ isLatest: false,
332
+ error: { message: 'Client revision not found' }
333
+ }
334
+ }
335
+
336
+ const clientRevision = match[1]
337
+ return {
338
+ version: [2, 3000, +clientRevision],
339
+ isLatest: true
340
+ }
341
+ } catch (error) {
342
+ return {
343
+ version: baileysVersion,
344
+ isLatest: false,
345
+ error
346
+ }
347
+ }
348
+ }
349
+ exports.fetchLatestWaWebVersion = fetchLatestWaWebVersion;
350
+ /**
351
+ * utility that fetches latest baileys version from the master branch.
352
+ * Use to ensure your WA connection is always on the latest version
353
+ */
354
+ const fetchLatestBaileysVersion = async (options = {}) => {
355
+ const URL = 'https://raw.githubusercontent.com/WhiskeySockets/Baileys/master/src/Defaults/baileys-version.json';
356
+ try {
357
+ const result = await axios_1.default.get(URL, {
358
+ ...options,
359
+ responseType: 'json'
360
+ });
361
+ return {
362
+ version: result.data.version,
363
+ isLatest: true
364
+ };
365
+ }
366
+ catch (error) {
367
+ return {
368
+ version: baileys_version_json_1.version,
369
+ isLatest: false,
370
+ error
371
+ };
372
+ }
373
+ };
374
+ exports.fetchLatestBaileysVersion = fetchLatestBaileysVersion;
375
+ /** unique message tag prefix for MD clients */
376
+ const generateMdTagPrefix = () => {
377
+ const bytes = (0, crypto_1.randomBytes)(4);
378
+ return `${bytes.readUInt16BE()}.${bytes.readUInt16BE(2)}-`;
379
+ };
380
+ exports.generateMdTagPrefix = generateMdTagPrefix;
381
+ const STATUS_MAP = {
382
+ 'played': WAProto_1.proto.WebMessageInfo.Status.PLAYED,
383
+ 'read': WAProto_1.proto.WebMessageInfo.Status.READ,
384
+ 'read-self': WAProto_1.proto.WebMessageInfo.Status.READ
385
+ };
386
+ /**
387
+ * Given a type of receipt, returns what the new status of the message should be
388
+ * @param type type from receipt
389
+ */
390
+ const getStatusFromReceiptType = (type) => {
391
+ const status = STATUS_MAP[type];
392
+ if (typeof type === 'undefined') {
393
+ return WAProto_1.proto.WebMessageInfo.Status.DELIVERY_ACK;
394
+ }
395
+ return status;
396
+ };
397
+ exports.getStatusFromReceiptType = getStatusFromReceiptType;
398
+ const CODE_MAP = {
399
+ conflict: Types_1.DisconnectReason.connectionReplaced
400
+ };
401
+ /**
402
+ * Stream errors generally provide a reason, map that to a baileys DisconnectReason
403
+ * @param reason the string reason given, eg. "conflict"
404
+ */
405
+ const getErrorCodeFromStreamError = (node) => {
406
+ const [reasonNode] = (0, WABinary_1.getAllBinaryNodeChildren)(node);
407
+ let reason = (reasonNode === null || reasonNode === void 0 ? void 0 : reasonNode.tag) || 'unknown';
408
+ const statusCode = +(node.attrs.code || CODE_MAP[reason] || Types_1.DisconnectReason.badSession);
409
+ if (statusCode === Types_1.DisconnectReason.restartRequired) {
410
+ reason = 'restart required';
411
+ }
412
+ return {
413
+ reason,
414
+ statusCode
415
+ };
416
+ };
417
+ exports.getErrorCodeFromStreamError = getErrorCodeFromStreamError;
418
+ const getCallStatusFromNode = ({ tag, attrs }) => {
419
+ let status;
420
+ switch (tag) {
421
+ case 'offer':
422
+ case 'offer_notice':
423
+ status = 'offer';
424
+ break;
425
+ case 'terminate':
426
+ if (attrs.reason === 'timeout') {
427
+ status = 'timeout';
428
+ }
429
+ else {
430
+ status = 'reject';
431
+ }
432
+ break;
433
+ case 'reject':
434
+ status = 'reject';
435
+ break;
436
+ case 'accept':
437
+ status = 'accept';
438
+ break;
439
+ default:
440
+ status = 'ringing';
441
+ break;
442
+ }
443
+ return status;
444
+ };
445
+ exports.getCallStatusFromNode = getCallStatusFromNode;
446
+ const UNEXPECTED_SERVER_CODE_TEXT = 'Unexpected server response: ';
447
+ const getCodeFromWSError = (error) => {
448
+ var _a, _b, _c;
449
+ let statusCode = 500;
450
+ if ((_a = error === null || error === void 0 ? void 0 : error.message) === null || _a === void 0 ? void 0 : _a.includes(UNEXPECTED_SERVER_CODE_TEXT)) {
451
+ const code = +(error === null || error === void 0 ? void 0 : error.message.slice(UNEXPECTED_SERVER_CODE_TEXT.length));
452
+ if (!Number.isNaN(code) && code >= 400) {
453
+ statusCode = code;
454
+ }
455
+ }
456
+ else if (((_b = error === null || error === void 0 ? void 0 : error.code) === null || _b === void 0 ? void 0 : _b.startsWith('E'))
457
+ || ((_c = error === null || error === void 0 ? void 0 : error.message) === null || _c === void 0 ? void 0 : _c.includes('timed out'))) {
458
+ statusCode = 408;
459
+ }
460
+ return statusCode;
461
+ };
462
+ exports.getCodeFromWSError = getCodeFromWSError;
463
+ /**
464
+ * Is the given platform WA business
465
+ * @param platform AuthenticationCreds.platform
466
+ */
467
+ const isWABusinessPlatform = (platform) => {
468
+ return platform === 'smbi' || platform === 'smba';
469
+ };
470
+ exports.isWABusinessPlatform = isWABusinessPlatform;
471
+ function trimUndefined(obj) {
472
+ for (const key in obj) {
473
+ if (typeof obj[key] === 'undefined') {
474
+ delete obj[key];
475
+ }
476
+ }
477
+ return obj;
478
+ }
479
+ exports.trimUndefined = trimUndefined;
480
+ const CROCKFORD_CHARACTERS = '123456789ABCDEFGHJKLMNPQRSTVWXYZ';
481
+ function bytesToCrockford(buffer) {
482
+ let value = 0;
483
+ let bitCount = 0;
484
+ const crockford = [];
485
+ for (let i = 0; i < buffer.length; i++) {
486
+ value = (value << 8) | (buffer[i] & 0xff);
487
+ bitCount += 8;
488
+ while (bitCount >= 5) {
489
+ crockford.push(CROCKFORD_CHARACTERS.charAt((value >>> (bitCount - 5)) & 31));
490
+ bitCount -= 5;
491
+ }
492
+ }
493
+ if (bitCount > 0) {
494
+ crockford.push(CROCKFORD_CHARACTERS.charAt((value << (5 - bitCount)) & 31));
495
+ }
496
+ return crockford.join('');
497
+ }
498
+ exports.bytesToCrockford = bytesToCrockford;
499
+ const encodeNewsletterMessage = (message) => {
500
+ return WAProto_1.proto.Message.encode(message).finish()
501
+ }
502
+ exports.encodeNewsletterMessage = encodeNewsletterMessage;
@@ -0,0 +1,96 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.getHistoryMsg = exports.downloadAndProcessHistorySyncNotification = exports.processHistoryMessage = exports.downloadHistory = void 0;
4
+ const util_1 = require("util");
5
+ const zlib_1 = require("zlib");
6
+ const WAProto_1 = require("../../WAProto");
7
+ const Types_1 = require("../Types");
8
+ const WABinary_1 = require("../WABinary");
9
+ const generics_1 = require("./generics");
10
+ const messages_1 = require("./messages");
11
+ const messages_media_1 = require("./messages-media");
12
+ const inflatePromise = (0, util_1.promisify)(zlib_1.inflate);
13
+ const downloadHistory = async (msg, options) => {
14
+ const stream = await (0, messages_media_1.downloadContentFromMessage)(msg, 'md-msg-hist', { options });
15
+ const bufferArray = [];
16
+ for await (const chunk of stream) {
17
+ bufferArray.push(chunk);
18
+ }
19
+ let buffer = Buffer.concat(bufferArray);
20
+
21
+ buffer = await inflatePromise(buffer);
22
+ const syncData = WAProto_1.proto.HistorySync.decode(buffer);
23
+ return syncData;
24
+ };
25
+ exports.downloadHistory = downloadHistory;
26
+ const processHistoryMessage = (item) => {
27
+ var _a, _b, _c;
28
+ const messages = [];
29
+ const contacts = [];
30
+ const chats = [];
31
+ switch (item.syncType) {
32
+ case WAProto_1.proto.HistorySync.HistorySyncType.INITIAL_BOOTSTRAP:
33
+ case WAProto_1.proto.HistorySync.HistorySyncType.RECENT:
34
+ case WAProto_1.proto.HistorySync.HistorySyncType.FULL:
35
+ for (const chat of item.conversations) {
36
+ contacts.push({
37
+ id: chat.id,
38
+ name: chat.name || undefined,
39
+ lid: chat.lidJid || undefined,
40
+ jid: (0, WABinary_1.isJidUser)(chat.id) ? chat.id : undefined
41
+ });
42
+ const msgs = chat.messages || [];
43
+ delete chat.messages;
44
+ delete chat.archived;
45
+ delete chat.muteEndTime;
46
+ delete chat.pinned;
47
+ for (const item of msgs) {
48
+ const message = item.message;
49
+ messages.push(message);
50
+ if (!((_a = chat.messages) === null || _a === void 0 ? void 0 : _a.length)) {
51
+
52
+ chat.messages = [{ message }];
53
+ }
54
+ if (!message.key.fromMe && !chat.lastMessageRecvTimestamp) {
55
+ chat.lastMessageRecvTimestamp = (0, generics_1.toNumber)(message.messageTimestamp);
56
+ }
57
+ if ((message.messageStubType === Types_1.WAMessageStubType.BIZ_PRIVACY_MODE_TO_BSP
58
+ || message.messageStubType === Types_1.WAMessageStubType.BIZ_PRIVACY_MODE_TO_FB)
59
+ && ((_b = message.messageStubParameters) === null || _b === void 0 ? void 0 : _b[0])) {
60
+ contacts.push({
61
+ id: message.key.participant || message.key.remoteJid,
62
+ verifiedName: (_c = message.messageStubParameters) === null || _c === void 0 ? void 0 : _c[0],
63
+ });
64
+ }
65
+ }
66
+ if ((0, WABinary_1.isJidUser)(chat.id) && chat.readOnly && chat.archived) {
67
+ delete chat.readOnly;
68
+ }
69
+ chats.push({ ...chat });
70
+ }
71
+ break;
72
+ case WAProto_1.proto.HistorySync.HistorySyncType.PUSH_NAME:
73
+ for (const c of item.pushnames) {
74
+ contacts.push({ id: c.id, notify: c.pushname });
75
+ }
76
+ break;
77
+ }
78
+ return {
79
+ chats,
80
+ contacts,
81
+ messages,
82
+ };
83
+ };
84
+ exports.processHistoryMessage = processHistoryMessage;
85
+ const downloadAndProcessHistorySyncNotification = async (msg, options) => {
86
+ const historyMsg = await (0, exports.downloadHistory)(msg, options);
87
+ return (0, exports.processHistoryMessage)(historyMsg);
88
+ };
89
+ exports.downloadAndProcessHistorySyncNotification = downloadAndProcessHistorySyncNotification;
90
+ const getHistoryMsg = (message) => {
91
+ var _a;
92
+ const normalizedContent = !!message ? (0, messages_1.normalizeMessageContent)(message) : undefined;
93
+ const anyHistoryMsg = (_a = normalizedContent === null || normalizedContent === void 0 ? void 0 : normalizedContent.protocolMessage) === null || _a === void 0 ? void 0 : _a.historySyncNotification;
94
+ return anyHistoryMsg;
95
+ };
96
+ exports.getHistoryMsg = getHistoryMsg;
@@ -0,0 +1,33 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __exportStar = (this && this.__exportStar) || function(m, exports) {
14
+ for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
15
+ };
16
+ Object.defineProperty(exports, "__esModule", { value: true });
17
+ __exportStar(require("./generics"), exports);
18
+ __exportStar(require("./decode-wa-message"), exports);
19
+ __exportStar(require("./messages"), exports);
20
+ __exportStar(require("./messages-media"), exports);
21
+ __exportStar(require("./validate-connection"), exports);
22
+ __exportStar(require("./crypto"), exports);
23
+ __exportStar(require("./signal"), exports);
24
+ __exportStar(require("./noise-handler"), exports);
25
+ __exportStar(require("./history"), exports);
26
+ __exportStar(require("./chat-utils"), exports);
27
+ __exportStar(require("./lt-hash"), exports);
28
+ __exportStar(require("./auth-utils"), exports);
29
+ __exportStar(require("./baileys-event-stream"), exports);
30
+ __exportStar(require("./use-multi-file-auth-state"), exports);
31
+ __exportStar(require("./link-preview"), exports);
32
+ __exportStar(require("./event-buffer"), exports);
33
+ __exportStar(require("./process-message"), exports);