socketon 0.31.0 → 1.51.16

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