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