@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.
Files changed (212) hide show
  1. package/WAProto/index.js +133384 -57814
  2. package/engine-requirements.js +10 -0
  3. package/lib/Defaults/baileys-version.json +3 -0
  4. package/lib/Defaults/index.d.ts +53 -0
  5. package/lib/Defaults/index.js +141 -117
  6. package/lib/Defaults/phonenumber-mcc.json +223 -0
  7. package/lib/Signal/Group/ciphertext-message.d.ts +9 -0
  8. package/lib/Signal/Group/ciphertext-message.js +14 -12
  9. package/lib/Signal/Group/group-session-builder.d.ts +14 -0
  10. package/lib/Signal/Group/group-session-builder.js +42 -10
  11. package/lib/Signal/Group/group_cipher.d.ts +17 -0
  12. package/lib/Signal/Group/group_cipher.js +87 -75
  13. package/lib/Signal/Group/index.d.ts +11 -0
  14. package/lib/Signal/Group/index.js +57 -13
  15. package/lib/Signal/Group/keyhelper.d.ts +10 -0
  16. package/lib/Signal/Group/keyhelper.js +52 -17
  17. package/lib/Signal/Group/queue-job.d.ts +1 -0
  18. package/lib/Signal/Group/queue-job.js +57 -0
  19. package/lib/Signal/Group/sender-chain-key.d.ts +13 -0
  20. package/lib/Signal/Group/sender-chain-key.js +33 -27
  21. package/lib/Signal/Group/sender-key-distribution-message.d.ts +16 -0
  22. package/lib/Signal/Group/sender-key-distribution-message.js +63 -62
  23. package/lib/Signal/Group/sender-key-message.d.ts +18 -0
  24. package/lib/Signal/Group/sender-key-message.js +66 -65
  25. package/lib/Signal/Group/sender-key-name.d.ts +17 -0
  26. package/lib/Signal/Group/sender-key-name.js +44 -45
  27. package/lib/Signal/Group/sender-key-record.d.ts +30 -0
  28. package/lib/Signal/Group/sender-key-record.js +49 -39
  29. package/lib/Signal/Group/sender-key-state.d.ts +38 -0
  30. package/lib/Signal/Group/sender-key-state.js +93 -80
  31. package/lib/Signal/Group/sender-message-key.d.ts +11 -0
  32. package/lib/Signal/Group/sender-message-key.js +28 -27
  33. package/lib/Signal/libsignal.d.ts +3 -0
  34. package/lib/Signal/libsignal.js +163 -313
  35. package/lib/Socket/Client/abstract-socket-client.d.ts +17 -0
  36. package/lib/Socket/Client/abstract-socket-client.js +13 -0
  37. package/lib/Socket/Client/index.d.ts +3 -0
  38. package/lib/Socket/Client/index.js +19 -4
  39. package/lib/Socket/Client/mobile-socket-client.d.ts +13 -0
  40. package/lib/Socket/Client/mobile-socket-client.js +65 -0
  41. package/lib/Socket/Client/web-socket-client.d.ts +12 -0
  42. package/lib/Socket/Client/web-socket-client.js +62 -0
  43. package/lib/Socket/business.d.ts +171 -0
  44. package/lib/Socket/business.js +242 -359
  45. package/lib/Socket/chats.d.ts +267 -0
  46. package/lib/Socket/chats.js +935 -846
  47. package/lib/Socket/dugong.d.ts +254 -0
  48. package/lib/Socket/dugong.js +484 -0
  49. package/lib/Socket/groups.d.ts +115 -0
  50. package/lib/Socket/groups.js +309 -304
  51. package/lib/Socket/index.d.ts +173 -0
  52. package/lib/Socket/index.js +10 -15
  53. package/lib/Socket/messages-recv.d.ts +161 -0
  54. package/lib/Socket/messages-recv.js +1054 -1107
  55. package/lib/Socket/messages-send.d.ts +149 -0
  56. package/lib/Socket/messages-send.js +447 -706
  57. package/lib/Socket/newsletter.d.ts +134 -0
  58. package/lib/Socket/newsletter.js +314 -199
  59. package/lib/Socket/registration.d.ts +267 -0
  60. package/lib/Socket/registration.js +166 -0
  61. package/lib/Socket/socket.d.ts +43 -0
  62. package/lib/Socket/socket.js +650 -777
  63. package/lib/Socket/usync.d.ts +36 -0
  64. package/lib/Socket/usync.js +70 -0
  65. package/lib/Store/index.d.ts +3 -0
  66. package/lib/Store/index.js +10 -6
  67. package/lib/Store/make-cache-manager-store.d.ts +13 -0
  68. package/lib/Store/make-cache-manager-store.js +81 -73
  69. package/lib/Store/make-in-memory-store.d.ts +118 -0
  70. package/lib/Store/make-in-memory-store.js +423 -286
  71. package/lib/Store/make-ordered-dictionary.d.ts +13 -0
  72. package/lib/Store/make-ordered-dictionary.js +79 -77
  73. package/lib/Store/object-repository.d.ts +10 -0
  74. package/lib/Store/object-repository.js +26 -24
  75. package/lib/Types/Auth.d.ts +110 -0
  76. package/lib/Types/Auth.js +2 -3
  77. package/lib/Types/Call.d.ts +13 -0
  78. package/lib/Types/Call.js +2 -3
  79. package/lib/Types/Chat.d.ts +102 -0
  80. package/lib/Types/Chat.js +4 -9
  81. package/lib/Types/Contact.d.ts +19 -0
  82. package/lib/Types/Contact.js +2 -3
  83. package/lib/Types/Events.d.ts +157 -0
  84. package/lib/Types/Events.js +2 -3
  85. package/lib/Types/GroupMetadata.d.ts +55 -0
  86. package/lib/Types/GroupMetadata.js +2 -3
  87. package/lib/Types/Label.d.ts +35 -0
  88. package/lib/Types/Label.js +26 -24
  89. package/lib/Types/LabelAssociation.d.ts +29 -0
  90. package/lib/Types/LabelAssociation.js +8 -6
  91. package/lib/Types/Message.d.ts +273 -0
  92. package/lib/Types/Message.js +9 -12
  93. package/lib/Types/Newsletter.d.ts +103 -0
  94. package/lib/Types/Newsletter.js +38 -33
  95. package/lib/Types/Product.d.ts +78 -0
  96. package/lib/Types/Product.js +2 -3
  97. package/lib/Types/Signal.d.ts +57 -0
  98. package/lib/Types/Signal.js +2 -3
  99. package/lib/Types/Socket.d.ts +111 -0
  100. package/lib/Types/Socket.js +2 -4
  101. package/lib/Types/State.d.ts +27 -0
  102. package/lib/Types/State.js +2 -11
  103. package/lib/Types/USync.d.ts +25 -0
  104. package/lib/Types/USync.js +2 -3
  105. package/lib/Types/index.d.ts +57 -0
  106. package/lib/Types/index.js +41 -27
  107. package/lib/Utils/auth-utils.d.ts +18 -0
  108. package/lib/Utils/auth-utils.js +198 -211
  109. package/lib/Utils/baileys-event-stream.d.ts +16 -0
  110. package/lib/Utils/baileys-event-stream.js +61 -42
  111. package/lib/Utils/business.d.ts +22 -0
  112. package/lib/Utils/business.js +214 -213
  113. package/lib/Utils/chat-utils.d.ts +71 -0
  114. package/lib/Utils/chat-utils.js +687 -710
  115. package/lib/Utils/crypto.d.ts +41 -0
  116. package/lib/Utils/crypto.js +133 -112
  117. package/lib/Utils/decode-wa-message.d.ts +19 -0
  118. package/lib/Utils/decode-wa-message.js +183 -252
  119. package/lib/Utils/event-buffer.d.ts +35 -0
  120. package/lib/Utils/event-buffer.js +496 -510
  121. package/lib/Utils/generics.d.ts +92 -0
  122. package/lib/Utils/generics.js +392 -319
  123. package/lib/Utils/generics.js.bak +433 -0
  124. package/lib/Utils/history.d.ts +15 -0
  125. package/lib/Utils/history.js +92 -83
  126. package/lib/Utils/index.d.ts +17 -0
  127. package/lib/Utils/index.js +33 -21
  128. package/lib/Utils/link-preview.d.ts +21 -0
  129. package/lib/Utils/link-preview.js +83 -71
  130. package/lib/Utils/logger.d.ts +4 -0
  131. package/lib/Utils/logger.js +7 -5
  132. package/lib/Utils/lt-hash.d.ts +12 -0
  133. package/lib/Utils/lt-hash.js +46 -40
  134. package/lib/Utils/make-mutex.d.ts +7 -0
  135. package/lib/Utils/make-mutex.js +41 -34
  136. package/lib/Utils/messages-media.d.ts +116 -0
  137. package/lib/Utils/messages-media.js +768 -550
  138. package/lib/Utils/messages.d.ts +77 -0
  139. package/lib/Utils/messages.js +263 -362
  140. package/lib/Utils/noise-handler.d.ts +21 -0
  141. package/lib/Utils/noise-handler.js +149 -138
  142. package/lib/Utils/process-message.d.ts +41 -0
  143. package/lib/Utils/process-message.js +303 -323
  144. package/lib/Utils/signal.d.ts +32 -0
  145. package/lib/Utils/signal.js +141 -149
  146. package/lib/Utils/use-multi-file-auth-state.d.ts +13 -0
  147. package/lib/Utils/use-multi-file-auth-state.js +103 -95
  148. package/lib/Utils/validate-connection.d.ts +11 -0
  149. package/lib/Utils/validate-connection.js +214 -183
  150. package/lib/Utils/validate-connection.js.bak +237 -0
  151. package/lib/WABinary/constants.d.ts +30 -0
  152. package/lib/WABinary/constants.js +35 -1298
  153. package/lib/WABinary/decode.d.ts +7 -0
  154. package/lib/WABinary/decode.js +249 -237
  155. package/lib/WABinary/encode.d.ts +3 -0
  156. package/lib/WABinary/encode.js +260 -213
  157. package/lib/WABinary/generic-utils.d.ts +17 -0
  158. package/lib/WABinary/generic-utils.js +65 -56
  159. package/lib/WABinary/index.d.ts +5 -0
  160. package/lib/WABinary/index.js +21 -7
  161. package/lib/WABinary/jid-utils.d.ts +31 -0
  162. package/lib/WABinary/jid-utils.js +58 -89
  163. package/lib/WABinary/types.d.ts +18 -0
  164. package/lib/WABinary/types.js +2 -3
  165. package/lib/WAM/BinaryInfo.d.ts +17 -0
  166. package/lib/WAM/BinaryInfo.js +12 -10
  167. package/lib/WAM/constants.d.ts +38 -0
  168. package/lib/WAM/constants.js +15348 -22851
  169. package/lib/WAM/encode.d.ts +3 -0
  170. package/lib/WAM/encode.js +136 -135
  171. package/lib/WAM/index.d.ts +3 -0
  172. package/lib/WAM/index.js +19 -5
  173. package/lib/WAUSync/Protocols/USyncContactProtocol.d.ts +9 -0
  174. package/lib/WAUSync/Protocols/USyncContactProtocol.js +30 -28
  175. package/lib/WAUSync/Protocols/USyncDeviceProtocol.d.ts +22 -0
  176. package/lib/WAUSync/Protocols/USyncDeviceProtocol.js +53 -49
  177. package/lib/WAUSync/Protocols/USyncDisappearingModeProtocol.d.ts +12 -0
  178. package/lib/WAUSync/Protocols/USyncDisappearingModeProtocol.js +28 -27
  179. package/lib/WAUSync/Protocols/USyncStatusProtocol.d.ts +12 -0
  180. package/lib/WAUSync/Protocols/USyncStatusProtocol.js +39 -36
  181. package/lib/WAUSync/Protocols/UsyncBotProfileProtocol.d.ts +25 -0
  182. package/lib/WAUSync/Protocols/UsyncBotProfileProtocol.js +50 -50
  183. package/lib/WAUSync/Protocols/UsyncLIDProtocol.d.ts +8 -0
  184. package/lib/WAUSync/Protocols/UsyncLIDProtocol.js +20 -26
  185. package/lib/WAUSync/Protocols/index.d.ts +4 -0
  186. package/lib/WAUSync/Protocols/index.js +20 -6
  187. package/lib/WAUSync/USyncQuery.d.ts +28 -0
  188. package/lib/WAUSync/USyncQuery.js +85 -86
  189. package/lib/WAUSync/USyncUser.d.ts +12 -0
  190. package/lib/WAUSync/USyncUser.js +25 -23
  191. package/lib/WAUSync/index.d.ts +3 -0
  192. package/lib/WAUSync/index.js +19 -5
  193. package/lib/index.d.ts +12 -0
  194. package/lib/index.js +36 -24
  195. package/package.json +106 -98
  196. package/LICENSE +0 -21
  197. package/WAProto/WAProto.proto +0 -5311
  198. package/lib/KeyDB/BinarySearch.js +0 -20
  199. package/lib/KeyDB/KeyedDB.js +0 -167
  200. package/lib/KeyDB/index.js +0 -4
  201. package/lib/Signal/lid-mapping.js +0 -155
  202. package/lib/Socket/Client/types.js +0 -13
  203. package/lib/Socket/Client/websocket.js +0 -52
  204. package/lib/Socket/Client/websocket.js.bak +0 -53
  205. package/lib/Socket/communities.js +0 -413
  206. package/lib/Socket/mex.js +0 -45
  207. package/lib/Types/Bussines.js +0 -3
  208. package/lib/Types/Newsletter.js.bak +0 -33
  209. package/lib/Utils/browser-utils.js +0 -25
  210. package/lib/Utils/message-retry-manager.js +0 -113
  211. package/lib/Utils/messages.js.bak +0 -907
  212. package/lib/Utils/pre-key-manager.js +0 -85
@@ -1,355 +1,428 @@
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") };
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
- export const generateParticipantHashV2 = (participants) => {
54
- participants.sort();
55
- const sha256Hash = sha256(Buffer.from(participants.join(""))).toString("base64");
56
- return "2:" + sha256Hash.slice(0, 6);
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
- export const encodeWAMessage = (message) => writeRandomPadMax16(proto.Message.encode(message).finish());
60
- export const generateRegistrationId = () => {
61
- return Uint16Array.from(randomBytes(2))[0] & 16383;
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
- 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;
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
- 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);
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
- setTask: (newTask) => (task = newTask),
90
- setInterval: (newInterval) => (intervalMs = newInterval)
91
- };
92
- };
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 };
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
- 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);
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
- 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 });
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
- 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
- };
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
- else {
184
- throw new Error("Could not parse version from Defaults/index.ts");
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
- catch (error) {
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
- version: version,
190
- isLatest: false,
191
- error
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
- 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"
201
- };
202
- const headers = { ...defaultHeaders, ...options.headers };
203
- const response = await fetch("https://web.whatsapp.com/sw.js", {
204
- ...options,
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
- if (!response.ok) {
209
- throw new Boom(`Failed to fetch sw.js: ${response.statusText}`, { statusCode: response.status });
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 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"
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 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
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
- export const generateMdTagPrefix = () => {
239
- const bytes = randomBytes(4);
240
- return `${bytes.readUInt16BE()}.${bytes.readUInt16BE(2)}-`;
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
- "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
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
- 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;
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
- conflict: DisconnectReason.connectionReplaced
325
+ conflict: Types_1.DisconnectReason.connectionReplaced
260
326
  };
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
- };
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
- 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;
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 = "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;
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
- export const isWABusinessPlatform = (platform) => {
321
- return platform === "smbi" || platform === "smba";
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
- export function trimUndefined(obj) {
325
- for (const key in obj) {
326
- if (typeof obj[key] === "undefined") {
327
- delete obj[key];
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 = "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;
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
- export function encodeNewsletterMessage(message) {
353
- return proto.Message.encode(message).finish();
424
+ exports.bytesToCrockford = bytesToCrockford;
425
+ const encodeNewsletterMessage = (message) => {
426
+ return WAProto_1.proto.Message.encode(message).finish()
354
427
  }
355
- //=======================================================//
428
+ exports.encodeNewsletterMessage = encodeNewsletterMessage;