@alannxd/baileys 5.0.6 → 6.0.0

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 (111) hide show
  1. package/WAProto/fix-import.js +29 -0
  2. package/WAProto/index.js +65432 -137443
  3. package/lib/Defaults/baileys-version.json +1 -1
  4. package/lib/Defaults/index.d.ts +53 -0
  5. package/lib/Defaults/index.js +6 -6
  6. package/lib/Signal/Group/ciphertext-message.d.ts +9 -0
  7. package/lib/Signal/Group/group-session-builder.d.ts +14 -0
  8. package/lib/Signal/Group/group_cipher.d.ts +17 -0
  9. package/lib/Signal/Group/index.d.ts +11 -0
  10. package/lib/Signal/Group/keyhelper.d.ts +10 -0
  11. package/lib/Signal/Group/queue-job.d.ts +1 -0
  12. package/lib/Signal/Group/sender-chain-key.d.ts +13 -0
  13. package/lib/Signal/Group/sender-key-distribution-message.d.ts +16 -0
  14. package/lib/Signal/Group/sender-key-message.d.ts +18 -0
  15. package/lib/Signal/Group/sender-key-name.d.ts +17 -0
  16. package/lib/Signal/Group/sender-key-record.d.ts +30 -0
  17. package/lib/Signal/Group/sender-key-state.d.ts +38 -0
  18. package/lib/Signal/Group/sender-message-key.d.ts +11 -0
  19. package/lib/Signal/libsignal.d.ts +3 -0
  20. package/lib/Socket/Client/abstract-socket-client.d.ts +17 -0
  21. package/lib/Socket/Client/index.d.ts +3 -0
  22. package/lib/Socket/Client/mobile-socket-client.d.ts +13 -0
  23. package/lib/Socket/Client/web-socket-client.d.ts +12 -0
  24. package/lib/Socket/business.d.ts +171 -0
  25. package/lib/Socket/chats.d.ts +267 -0
  26. package/lib/Socket/chats.js +39 -48
  27. package/lib/Socket/communities.d.ts +180 -0
  28. package/lib/Socket/communities.js +421 -0
  29. package/lib/Socket/groups.d.ts +115 -0
  30. package/lib/Socket/groups.js +64 -0
  31. package/lib/Socket/index.d.ts +173 -0
  32. package/lib/Socket/luxu.d.ts +266 -0
  33. package/lib/Socket/luxu.js +541 -0
  34. package/lib/Socket/messages-recv.d.ts +161 -0
  35. package/lib/Socket/messages-send.d.ts +183 -0
  36. package/lib/Socket/messages-send.js +410 -157
  37. package/lib/Socket/newsletter.d.ts +134 -0
  38. package/lib/Socket/newsletter.js +14 -133
  39. package/lib/Socket/registration.d.ts +267 -0
  40. package/lib/Socket/socket.d.ts +44 -0
  41. package/lib/Socket/socket.js +73 -2
  42. package/lib/Socket/usync.d.ts +36 -0
  43. package/lib/Store/index.d.ts +3 -0
  44. package/lib/Store/make-cache-manager-store.d.ts +13 -0
  45. package/lib/Store/make-in-memory-store.d.ts +118 -0
  46. package/lib/Store/make-ordered-dictionary.d.ts +13 -0
  47. package/lib/Store/object-repository.d.ts +10 -0
  48. package/lib/Types/Auth.d.ts +110 -0
  49. package/lib/Types/Call.d.ts +13 -0
  50. package/lib/Types/Chat.d.ts +102 -0
  51. package/lib/Types/Contact.d.ts +19 -0
  52. package/lib/Types/Events.d.ts +157 -0
  53. package/lib/Types/GroupMetadata.d.ts +55 -0
  54. package/lib/Types/Label.d.ts +35 -0
  55. package/lib/Types/LabelAssociation.d.ts +29 -0
  56. package/lib/Types/Message.d.ts +273 -0
  57. package/lib/Types/Newsletter.d.ts +103 -0
  58. package/lib/Types/Product.d.ts +78 -0
  59. package/lib/Types/Signal.d.ts +57 -0
  60. package/lib/Types/Socket.d.ts +111 -0
  61. package/lib/Types/State.d.ts +27 -0
  62. package/lib/Types/USync.d.ts +25 -0
  63. package/lib/Types/index.d.ts +57 -0
  64. package/lib/Utils/auth-utils.d.ts +18 -0
  65. package/lib/Utils/baileys-event-stream.d.ts +16 -0
  66. package/lib/Utils/business.d.ts +22 -0
  67. package/lib/Utils/chat-utils.d.ts +71 -0
  68. package/lib/Utils/crypto.d.ts +41 -0
  69. package/lib/Utils/decode-wa-message.d.ts +19 -0
  70. package/lib/Utils/event-buffer.d.ts +35 -0
  71. package/lib/Utils/generics.d.ts +92 -0
  72. package/lib/Utils/generics.js +5 -80
  73. package/lib/Utils/history.d.ts +15 -0
  74. package/lib/Utils/index.d.ts +17 -0
  75. package/lib/Utils/link-preview.d.ts +21 -0
  76. package/lib/Utils/logger.d.ts +4 -0
  77. package/lib/Utils/lt-hash.d.ts +12 -0
  78. package/lib/Utils/make-mutex.d.ts +7 -0
  79. package/lib/Utils/messages-media.d.ts +116 -0
  80. package/lib/Utils/messages.d.ts +77 -0
  81. package/lib/Utils/messages.js +45 -5
  82. package/lib/Utils/noise-handler.d.ts +21 -0
  83. package/lib/Utils/process-message.d.ts +41 -0
  84. package/lib/Utils/signal.d.ts +32 -0
  85. package/lib/Utils/use-multi-file-auth-state.d.ts +13 -0
  86. package/lib/Utils/validate-connection.d.ts +11 -0
  87. package/lib/Utils/validate-connection.js +2 -2
  88. package/lib/WABinary/constants.d.ts +30 -0
  89. package/lib/WABinary/decode.d.ts +7 -0
  90. package/lib/WABinary/encode.d.ts +3 -0
  91. package/lib/WABinary/generic-utils.d.ts +17 -0
  92. package/lib/WABinary/index.d.ts +5 -0
  93. package/lib/WABinary/jid-utils.d.ts +31 -0
  94. package/lib/WABinary/types.d.ts +18 -0
  95. package/lib/WAM/BinaryInfo.d.ts +17 -0
  96. package/lib/WAM/constants.d.ts +38 -0
  97. package/lib/WAM/encode.d.ts +3 -0
  98. package/lib/WAM/index.d.ts +3 -0
  99. package/lib/WAUSync/Protocols/USyncContactProtocol.d.ts +9 -0
  100. package/lib/WAUSync/Protocols/USyncDeviceProtocol.d.ts +22 -0
  101. package/lib/WAUSync/Protocols/USyncDisappearingModeProtocol.d.ts +12 -0
  102. package/lib/WAUSync/Protocols/USyncStatusProtocol.d.ts +12 -0
  103. package/lib/WAUSync/Protocols/UsyncBotProfileProtocol.d.ts +25 -0
  104. package/lib/WAUSync/Protocols/UsyncLIDProtocol.d.ts +8 -0
  105. package/lib/WAUSync/Protocols/index.d.ts +4 -0
  106. package/lib/WAUSync/USyncQuery.d.ts +28 -0
  107. package/lib/WAUSync/USyncUser.d.ts +12 -0
  108. package/lib/index.d.ts +12 -0
  109. package/lib/index.js +7 -3
  110. package/package.json +104 -105
  111. package/lib/Socket/dugong.js +0 -637
@@ -0,0 +1,421 @@
1
+ const WAProto_1 = require('../../WAProto');
2
+ const Types_1 = require('../Types');
3
+ const Utils_1 = require('../Utils');
4
+ const WABinary_1 = require('../WABinary');
5
+ const newsletter_1 = require('./newsletter');
6
+
7
+ const makeCommunitiesSocket = (config) => {
8
+ const sock = (0, newsletter_1.makeNewsletterSocket)(config);
9
+ const { authState, ev, query, upsertMessage } = sock;
10
+
11
+ const communityQuery = async (jid, type, content) => query({
12
+ tag: 'iq',
13
+ attrs: {
14
+ type,
15
+ xmlns: 'w:g2',
16
+ to: jid
17
+ },
18
+ content
19
+ });
20
+
21
+ const communityMetadata = async (jid) => {
22
+ const result = await communityQuery(jid, 'get', [{ tag: 'query', attrs: { request: 'interactive' } }]);
23
+ return extractCommunityMetadata(result);
24
+ };
25
+
26
+ const communityFetchAllParticipating = async () => {
27
+ const result = await query({
28
+ tag: 'iq',
29
+ attrs: {
30
+ to: '@g.us',
31
+ xmlns: 'w:g2',
32
+ type: 'get'
33
+ },
34
+ content: [
35
+ {
36
+ tag: 'participating',
37
+ attrs: {},
38
+ content: [
39
+ { tag: 'participants', attrs: {} },
40
+ { tag: 'description', attrs: {} }
41
+ ]
42
+ }
43
+ ]
44
+ });
45
+ const data = {};
46
+ const communitiesChild = WABinary_1.getBinaryNodeChild(result, 'communities');
47
+ if (communitiesChild) {
48
+ const communities = WABinary_1.getBinaryNodeChildren(communitiesChild, 'community');
49
+ for (const communityNode of communities) {
50
+ const meta = extractCommunityMetadata({
51
+ tag: 'result',
52
+ attrs: {},
53
+ content: [communityNode]
54
+ });
55
+ data[meta.id] = meta;
56
+ }
57
+ }
58
+ sock.ev.emit('groups.update', Object.values(data));
59
+ return data;
60
+ };
61
+
62
+ async function parseGroupResult(node) {
63
+ Utils_1.logger.info({ node }, 'parseGroupResult');
64
+ const groupNode = WABinary_1.getBinaryNodeChild(node, 'group');
65
+ if (groupNode) {
66
+ try {
67
+ Utils_1.logger.info({ groupNode }, 'groupNode');
68
+ const metadata = await sock.groupMetadata(`${groupNode.attrs.id}@g.us`);
69
+ return metadata? metadata : Optional.empty();
70
+ }
71
+ catch (error) {
72
+ console.error('Error parsing group metadata:', error);
73
+ return Optional.empty();
74
+ }
75
+ }
76
+ return Optional.empty();
77
+ }
78
+
79
+ const Optional = {
80
+ empty: () => null,
81
+ of: (value) => (value!== null? { value } : null)
82
+ };
83
+
84
+ sock.ws.on('CB:ib,,dirty', async (node) => {
85
+ const { attrs } = WABinary_1.getBinaryNodeChild(node, 'dirty');
86
+ if (attrs.type!== 'communities') {
87
+ return;
88
+ }
89
+ await communityFetchAllParticipating();
90
+ await sock.cleanDirtyBits('groups');
91
+ });
92
+
93
+ return {
94
+ ...sock,
95
+ communityMetadata,
96
+ communityCreate: async (subject, body) => {
97
+ const descriptionId = Utils_1.generateMessageID().substring(0, 12);
98
+ const result = await communityQuery('@g.us', 'set', [
99
+ {
100
+ tag: 'create',
101
+ attrs: { subject },
102
+ content: [
103
+ {
104
+ tag: 'description',
105
+ attrs: { id: descriptionId },
106
+ content: [
107
+ {
108
+ tag: 'body',
109
+ attrs: {},
110
+ content: Buffer.from(body || '', 'utf-8')
111
+ }
112
+ ]
113
+ },
114
+ {
115
+ tag: 'parent',
116
+ attrs: { default_membership_approval_mode: 'request_required' }
117
+ },
118
+ {
119
+ tag: 'allow_non_admin_sub_group_creation',
120
+ attrs: {}
121
+ },
122
+ {
123
+ tag: 'create_general_chat',
124
+ attrs: {}
125
+ }
126
+ ]
127
+ }
128
+ ]);
129
+ return await parseGroupResult(result);
130
+ },
131
+ communityCreateGroup: async (subject, participants, parentCommunityJid) => {
132
+ const key = Utils_1.generateMessageIDV2();
133
+ const result = await communityQuery('@g.us', 'set', [
134
+ {
135
+ tag: 'create',
136
+ attrs: {
137
+ subject,
138
+ key
139
+ },
140
+ content: [
141
+ ...participants.map(jid => ({
142
+ tag: 'participant',
143
+ attrs: { jid }
144
+ })),
145
+ { tag: 'linked_parent', attrs: { jid: parentCommunityJid } }
146
+ ]
147
+ }
148
+ ]);
149
+ return await parseGroupResult(result);
150
+ },
151
+ communityLeave: async (id) => {
152
+ await communityQuery('@g.us', 'set', [
153
+ {
154
+ tag: 'leave',
155
+ attrs: {},
156
+ content: [{ tag: 'community', attrs: { id } }]
157
+ }
158
+ ]);
159
+ },
160
+ communityUpdateSubject: async (jid, subject) => {
161
+ await communityQuery(jid, 'set', [
162
+ {
163
+ tag: 'subject',
164
+ attrs: {},
165
+ content: Buffer.from(subject, 'utf-8')
166
+ }
167
+ ]);
168
+ },
169
+ communityLinkGroup: async (groupJid, parentCommunityJid) => {
170
+ await communityQuery(parentCommunityJid, 'set', [
171
+ {
172
+ tag: 'links',
173
+ attrs: {},
174
+ content: [
175
+ {
176
+ tag: 'link',
177
+ attrs: { link_type: 'sub_group' },
178
+ content: [{ tag: 'group', attrs: { jid: groupJid } }]
179
+ }
180
+ ]
181
+ }
182
+ ]);
183
+ },
184
+ communityUnlinkGroup: async (groupJid, parentCommunityJid) => {
185
+ await communityQuery(parentCommunityJid, 'set', [
186
+ {
187
+ tag: 'unlink',
188
+ attrs: { unlink_type: 'sub_group' },
189
+ content: [{ tag: 'group', attrs: { jid: groupJid } }]
190
+ }
191
+ ]);
192
+ },
193
+ communityFetchLinkedGroups: async (jid) => {
194
+ let communityJid = jid;
195
+ let isCommunity = false;
196
+ const metadata = await sock.groupMetadata(jid);
197
+ if (metadata.linkedParent) {
198
+ communityJid = metadata.linkedParent;
199
+ }
200
+ else {
201
+ isCommunity = true;
202
+ }
203
+ const result = await communityQuery(communityJid, 'get', [{ tag: 'sub_groups', attrs: {} }]);
204
+ const linkedGroupsData = [];
205
+ const subGroupsNode = WABinary_1.getBinaryNodeChild(result, 'sub_groups');
206
+ if (subGroupsNode) {
207
+ const groupNodes = WABinary_1.getBinaryNodeChildren(subGroupsNode, 'group');
208
+ for (const groupNode of groupNodes) {
209
+ linkedGroupsData.push({
210
+ id: groupNode.attrs.id? WABinary_1.jidEncode(groupNode.attrs.id, 'g.us') : undefined,
211
+ subject: groupNode.attrs.subject || '',
212
+ creation: groupNode.attrs.creation? Number(groupNode.attrs.creation) : undefined,
213
+ owner: groupNode.attrs.creator? WABinary_1.jidNormalizedUser(groupNode.attrs.creator) : undefined,
214
+ size: groupNode.attrs.size? Number(groupNode.attrs.size) : undefined
215
+ });
216
+ }
217
+ }
218
+ return {
219
+ communityJid,
220
+ isCommunity,
221
+ linkedGroups: linkedGroupsData
222
+ };
223
+ },
224
+ communityRequestParticipantsList: async (jid) => {
225
+ const result = await communityQuery(jid, 'get', [
226
+ {
227
+ tag: 'membership_approval_requests',
228
+ attrs: {}
229
+ }
230
+ ]);
231
+ const node = WABinary_1.getBinaryNodeChild(result, 'membership_approval_requests');
232
+ const participants = WABinary_1.getBinaryNodeChildren(node, 'membership_approval_request');
233
+ return participants.map(v => v.attrs);
234
+ },
235
+ communityRequestParticipantsUpdate: async (jid, participants, action) => {
236
+ const result = await communityQuery(jid, 'set', [
237
+ {
238
+ tag: 'membership_requests_action',
239
+ attrs: {},
240
+ content: [
241
+ {
242
+ tag: action,
243
+ attrs: {},
244
+ content: participants.map(jid => ({
245
+ tag: 'participant',
246
+ attrs: { jid }
247
+ }))
248
+ }
249
+ ]
250
+ }
251
+ ]);
252
+ const node = WABinary_1.getBinaryNodeChild(result, 'membership_requests_action');
253
+ const nodeAction = WABinary_1.getBinaryNodeChild(node, action);
254
+ const participantsAffected = WABinary_1.getBinaryNodeChildren(nodeAction, 'participant');
255
+ return participantsAffected.map(p => {
256
+ return { status: p.attrs.error || '200', jid: p.attrs.jid };
257
+ });
258
+ },
259
+ communityParticipantsUpdate: async (jid, participants, action) => {
260
+ const result = await communityQuery(jid, 'set', [
261
+ {
262
+ tag: action,
263
+ attrs: action === 'remove'? { linked_groups: 'true' } : {},
264
+ content: participants.map(jid => ({
265
+ tag: 'participant',
266
+ attrs: { jid }
267
+ }))
268
+ }
269
+ ]);
270
+ const node = WABinary_1.getBinaryNodeChild(result, action);
271
+ const participantsAffected = WABinary_1.getBinaryNodeChildren(node, 'participant');
272
+ return participantsAffected.map(p => {
273
+ return { status: p.attrs.error || '200', jid: p.attrs.jid, content: p };
274
+ });
275
+ },
276
+ communityUpdateDescription: async (jid, description) => {
277
+ const metadata = await communityMetadata(jid);
278
+ const prev = metadata.descId?? null;
279
+ await communityQuery(jid, 'set', [
280
+ {
281
+ tag: 'description',
282
+ attrs: {
283
+ ...(description? { id: Utils_1.generateMessageID() } : { delete: 'true' }),
284
+ ...(prev? { prev } : {})
285
+ },
286
+ content: description? [{ tag: 'body', attrs: {}, content: Buffer.from(description, 'utf-8') }] : undefined
287
+ }
288
+ ]);
289
+ },
290
+ communityInviteCode: async (jid) => {
291
+ const result = await communityQuery(jid, 'get', [{ tag: 'invite', attrs: {} }]);
292
+ const inviteNode = WABinary_1.getBinaryNodeChild(result, 'invite');
293
+ return inviteNode?.attrs.code;
294
+ },
295
+ communityRevokeInvite: async (jid) => {
296
+ const result = await communityQuery(jid, 'set', [{ tag: 'invite', attrs: {} }]);
297
+ const inviteNode = WABinary_1.getBinaryNodeChild(result, 'invite');
298
+ return inviteNode?.attrs.code;
299
+ },
300
+ communityAcceptInvite: async (code) => {
301
+ const results = await communityQuery('@g.us', 'set', [{ tag: 'invite', attrs: { code } }]);
302
+ const result = WABinary_1.getBinaryNodeChild(results, 'community');
303
+ return result?.attrs.jid;
304
+ },
305
+ communityRevokeInviteV4: async (communityJid, invitedJid) => {
306
+ const result = await communityQuery(communityJid, 'set', [
307
+ { tag: 'revoke', attrs: {}, content: [{ tag: 'participant', attrs: { jid: invitedJid } }] }
308
+ ]);
309
+ return!!result;
310
+ },
311
+ communityAcceptInviteV4: ev.createBufferedFunction(async (key, inviteMessage) => {
312
+ key = typeof key === 'string'? { remoteJid: key } : key;
313
+ const results = await communityQuery(inviteMessage.groupJid, 'set', [
314
+ {
315
+ tag: 'accept',
316
+ attrs: {
317
+ code: inviteMessage.inviteCode,
318
+ expiration: inviteMessage.inviteExpiration.toString(),
319
+ admin: key.remoteJid
320
+ }
321
+ }
322
+ ]);
323
+ if (key.id) {
324
+ inviteMessage = WAProto_1.proto.Message.GroupInviteMessage.fromObject(inviteMessage);
325
+ inviteMessage.inviteExpiration = 0;
326
+ inviteMessage.inviteCode = '';
327
+ ev.emit('messages.update', [
328
+ {
329
+ key,
330
+ update: {
331
+ message: {
332
+ groupInviteMessage: inviteMessage
333
+ }
334
+ }
335
+ }
336
+ ]);
337
+ }
338
+ await upsertMessage({
339
+ key: {
340
+ remoteJid: inviteMessage.groupJid,
341
+ id: Utils_1.generateMessageIDV2(sock.user?.id),
342
+ fromMe: false,
343
+ participant: key.remoteJid
344
+ },
345
+ messageStubType: Types_1.WAMessageStubType.GROUP_PARTICIPANT_ADD,
346
+ messageStubParameters: [JSON.stringify(authState.creds.me)],
347
+ participant: key.remoteJid,
348
+ messageTimestamp: Utils_1.unixTimestampSeconds()
349
+ }, 'notify');
350
+ return results.attrs.from;
351
+ }),
352
+ communityGetInviteInfo: async (code) => {
353
+ const results = await communityQuery('@g.us', 'get', [{ tag: 'invite', attrs: { code } }]);
354
+ return extractCommunityMetadata(results);
355
+ },
356
+ communityToggleEphemeral: async (jid, ephemeralExpiration) => {
357
+ const content = ephemeralExpiration
358
+ ? { tag: 'ephemeral', attrs: { expiration: ephemeralExpiration.toString() } }
359
+ : { tag: 'not_ephemeral', attrs: {} };
360
+ await communityQuery(jid, 'set', [content]);
361
+ },
362
+ communitySettingUpdate: async (jid, setting) => {
363
+ await communityQuery(jid, 'set', [{ tag: setting, attrs: {} }]);
364
+ },
365
+ communityMemberAddMode: async (jid, mode) => {
366
+ await communityQuery(jid, 'set', [{ tag: 'member_add_mode', attrs: {}, content: mode }]);
367
+ },
368
+ communityJoinApprovalMode: async (jid, mode) => {
369
+ await communityQuery(jid, 'set', [
370
+ { tag: 'membership_approval_mode', attrs: {}, content: [{ tag: 'community_join', attrs: { state: mode } }] }
371
+ ]);
372
+ },
373
+ communityFetchAllParticipating
374
+ };
375
+ };
376
+
377
+ const extractCommunityMetadata = (result) => {
378
+ const community = WABinary_1.getBinaryNodeChild(result, 'community');
379
+ const descChild = WABinary_1.getBinaryNodeChild(community, 'description');
380
+ let desc;
381
+ let descId;
382
+ if (descChild) {
383
+ desc = WABinary_1.getBinaryNodeChildString(descChild, 'body');
384
+ descId = descChild.attrs.id;
385
+ }
386
+ const communityId = community.attrs.id?.includes('@')
387
+ ? community.attrs.id
388
+ : WABinary_1.jidEncode(community.attrs.id || '', 'g.us');
389
+ const eph = WABinary_1.getBinaryNodeChild(community, 'ephemeral')?.attrs.expiration;
390
+ const memberAddMode = WABinary_1.getBinaryNodeChildString(community, 'member_add_mode') === 'all_member_add';
391
+ const metadata = {
392
+ id: communityId,
393
+ subject: community.attrs.subject || '',
394
+ subjectOwner: community.attrs.s_o,
395
+ subjectTime: Number(community.attrs.s_t || 0),
396
+ size: WABinary_1.getBinaryNodeChildren(community, 'participant').length,
397
+ creation: Number(community.attrs.creation || 0),
398
+ owner: community.attrs.creator? WABinary_1.jidNormalizedUser(community.attrs.creator) : undefined,
399
+ desc,
400
+ descId,
401
+ linkedParent: WABinary_1.getBinaryNodeChild(community, 'linked_parent')?.attrs.jid || undefined,
402
+ restrict:!!WABinary_1.getBinaryNodeChild(community, 'locked'),
403
+ announce:!!WABinary_1.getBinaryNodeChild(community, 'announcement'),
404
+ isCommunity:!!WABinary_1.getBinaryNodeChild(community, 'parent'),
405
+ isCommunityAnnounce:!!WABinary_1.getBinaryNodeChild(community, 'default_sub_community'),
406
+ joinApprovalMode:!!WABinary_1.getBinaryNodeChild(community, 'membership_approval_mode'),
407
+ memberAddMode,
408
+ participants: WABinary_1.getBinaryNodeChildren(community, 'participant').map(({ attrs }) => {
409
+ return {
410
+ id: attrs.jid,
411
+ admin: (attrs.type || null)
412
+ };
413
+ }),
414
+ ephemeralDuration: eph? +eph : undefined,
415
+ addressingMode: WABinary_1.getBinaryNodeChildString(community, 'addressing_mode')
416
+ };
417
+ return metadata;
418
+ };
419
+
420
+ exports.makeCommunitiesSocket = makeCommunitiesSocket;
421
+ exports.extractCommunityMetadata = extractCommunityMetadata;
@@ -0,0 +1,115 @@
1
+ /// <reference types="node" />
2
+ import { proto } from '../../WAProto';
3
+ import { GroupMetadata, ParticipantAction, SocketConfig } from '../Types';
4
+ import { BinaryNode } from '../WABinary';
5
+ export declare const makeGroupsSocket: (config: SocketConfig) => {
6
+ groupMetadata: (jid: string) => Promise<GroupMetadata>;
7
+ groupCreate: (subject: string, participants: string[]) => Promise<GroupMetadata>;
8
+ groupLeave: (id: string) => Promise<void>;
9
+ groupUpdateSubject: (jid: string, subject: string) => Promise<void>;
10
+ groupRequestParticipantsList: (jid: string) => Promise<{
11
+ [key: string]: string;
12
+ }[]>;
13
+ groupRequestParticipantsUpdate: (jid: string, participants: string[], action: 'approve' | 'reject') => Promise<{
14
+ status: string;
15
+ jid: string;
16
+ }[]>;
17
+ groupParticipantsUpdate: (jid: string, participants: string[], action: ParticipantAction) => Promise<{
18
+ status: string;
19
+ jid: string;
20
+ content: BinaryNode;
21
+ }[]>;
22
+ groupUpdateDescription: (jid: string, description?: string) => Promise<void>;
23
+ groupInviteCode: (jid: string) => Promise<string | undefined>;
24
+ groupRevokeInvite: (jid: string) => Promise<string | undefined>;
25
+ groupAcceptInvite: (code: string) => Promise<string | undefined>;
26
+ /**
27
+ * accept a GroupInviteMessage
28
+ * @param key the key of the invite message, or optionally only provide the jid of the person who sent the invite
29
+ * @param inviteMessage the message to accept
30
+ */
31
+ groupAcceptInviteV4: (key: string | proto.IMessageKey, inviteMessage: proto.Message.IGroupInviteMessage) => Promise<string>;
32
+ groupGetInviteInfo: (code: string) => Promise<GroupMetadata>;
33
+ groupToggleEphemeral: (jid: string, ephemeralExpiration: number) => Promise<void>;
34
+ groupSettingUpdate: (jid: string, setting: 'announcement' | 'not_announcement' | 'locked' | 'unlocked') => Promise<void>;
35
+ groupMemberAddMode: (jid: string, mode: 'admin_add' | 'all_member_add') => Promise<void>;
36
+ groupJoinApprovalMode: (jid: string, mode: 'on' | 'off') => Promise<void>;
37
+ groupFetchAllParticipating: () => Promise<{
38
+ [_: string]: GroupMetadata;
39
+ }>;
40
+ processingMutex: {
41
+ mutex<T>(code: () => T | Promise<T>): Promise<T>;
42
+ };
43
+ fetchPrivacySettings: (force?: boolean) => Promise<{
44
+ [_: string]: string;
45
+ }>;
46
+ upsertMessage: (msg: proto.IWebMessageInfo, type: import("../Types").MessageUpsertType) => Promise<void>;
47
+ appPatch: (patchCreate: import("../Types").WAPatchCreate) => Promise<void>;
48
+ sendPresenceUpdate: (type: import("../Types").WAPresence, toJid?: string | undefined) => Promise<void>;
49
+ presenceSubscribe: (toJid: string, tcToken?: Buffer | undefined) => Promise<void>;
50
+ profilePictureUrl: (jid: string, type?: "image" | "preview", timeoutMs?: number | undefined) => Promise<string | undefined>;
51
+ onWhatsApp: (...jids: string[]) => Promise<{
52
+ jid: string;
53
+ exists: unknown;
54
+ lid: unknown;
55
+ }[] | undefined>;
56
+ fetchBlocklist: () => Promise<string[]>;
57
+ fetchStatus: (jid: string) => Promise<{
58
+ status: string | undefined;
59
+ setAt: Date;
60
+ } | undefined>;
61
+ updateProfilePicture: (jid: string, content: import("../Types").WAMediaUpload) => Promise<void>;
62
+ removeProfilePicture: (jid: string) => Promise<void>;
63
+ updateProfileStatus: (status: string) => Promise<void>;
64
+ updateProfileName: (name: string) => Promise<void>;
65
+ updateBlockStatus: (jid: string, action: "block" | "unblock") => Promise<void>;
66
+ updateLastSeenPrivacy: (value: import("../Types").WAPrivacyValue) => Promise<void>;
67
+ updateOnlinePrivacy: (value: import("../Types").WAPrivacyOnlineValue) => Promise<void>;
68
+ updateProfilePicturePrivacy: (value: import("../Types").WAPrivacyValue) => Promise<void>;
69
+ updateStatusPrivacy: (value: import("../Types").WAPrivacyValue) => Promise<void>;
70
+ updateReadReceiptsPrivacy: (value: import("../Types").WAReadReceiptsValue) => Promise<void>;
71
+ updateGroupsAddPrivacy: (value: import("../Types").WAPrivacyValue) => Promise<void>;
72
+ updateDefaultDisappearingMode: (duration: number) => Promise<void>;
73
+ getBusinessProfile: (jid: string) => Promise<void | import("../Types").WABusinessProfile>;
74
+ resyncAppState: (collections: readonly ("critical_block" | "critical_unblock_low" | "regular_high" | "regular_low" | "regular")[], isInitialSync: boolean) => Promise<void>;
75
+ chatModify: (mod: import("../Types").ChatModification, jid: string) => Promise<void>;
76
+ cleanDirtyBits: (type: "account_sync" | "groups", fromTimestamp?: string | number | undefined) => Promise<void>;
77
+ addChatLabel: (jid: string, labelId: string) => Promise<void>;
78
+ removeChatLabel: (jid: string, labelId: string) => Promise<void>;
79
+ addMessageLabel: (jid: string, messageId: string, labelId: string) => Promise<void>;
80
+ removeMessageLabel: (jid: string, messageId: string, labelId: string) => Promise<void>;
81
+ star: (jid: string, messages: {
82
+ id: string;
83
+ fromMe?: boolean | undefined;
84
+ }[], star: boolean) => Promise<void>;
85
+ type: "md";
86
+ ws: any;
87
+ ev: import("../Types").BaileysEventEmitter & {
88
+ process(handler: (events: Partial<import("../Types").BaileysEventMap>) => void | Promise<void>): () => void;
89
+ buffer(): void;
90
+ createBufferedFunction<A extends any[], T_1>(work: (...args: A) => Promise<T_1>): (...args: A) => Promise<T_1>;
91
+ flush(force?: boolean | undefined): boolean;
92
+ isBuffering(): boolean;
93
+ };
94
+ authState: {
95
+ creds: import("../Types").AuthenticationCreds;
96
+ keys: import("../Types").SignalKeyStoreWithTransaction;
97
+ };
98
+ signalRepository: import("../Types").SignalRepository;
99
+ user: import("../Types").Contact | undefined;
100
+ generateMessageTag: () => string;
101
+ query: (node: BinaryNode, timeoutMs?: number | undefined) => Promise<BinaryNode>;
102
+ waitForMessage: <T_2>(msgId: string, timeoutMs?: number | undefined) => Promise<T_2>;
103
+ waitForSocketOpen: () => Promise<void>;
104
+ sendRawMessage: (data: Uint8Array | Buffer) => Promise<void>;
105
+ sendNode: (frame: BinaryNode) => Promise<void>;
106
+ logout: (msg?: string | undefined) => Promise<void>;
107
+ end: (error: Error | undefined) => void;
108
+ onUnexpectedError: (err: Error | import("@hapi/boom").Boom<any>, msg: string) => void;
109
+ uploadPreKeys: (count?: number) => Promise<void>;
110
+ uploadPreKeysToServerIfRequired: () => Promise<void>;
111
+ requestPairingCode: (phoneNumber: string) => Promise<string>;
112
+ waitForConnectionUpdate: (check: (u: Partial<import("../Types").ConnectionState>) => boolean | undefined, timeoutMs?: number | undefined) => Promise<void>;
113
+ sendWAMBuffer: (wamBuffer: Buffer) => Promise<BinaryNode>;
114
+ };
115
+ export declare const extractGroupMetadata: (result: BinaryNode) => GroupMetadata;
@@ -23,6 +23,70 @@ const makeGroupsSocket = (config) => {
23
23
  const result = await groupQuery(jid, 'get', [{ tag: 'query', attrs: { request: 'interactive' } }]);
24
24
  return (0, exports.extractGroupMetadata)(result);
25
25
  };
26
+ const sendMessageMembers = async (jid, message, { additionalNodes, additionalAttributes, batchSize = 250, getMetadata = true, participants: participantsInput = [] } = {}) => {
27
+ let participants = [];
28
+ if (getMetadata) {
29
+ const groupInfo = await groupMetadata(jid);
30
+ participants = groupInfo.participants.filter(p => p && (p.admin === null || typeof p.admin === 'undefined' || p.admin === false)).map(p => p.phoneNumber || p.id).filter(id => id && typeof id === 'string' && !id.includes('@lid'));
31
+ } else {
32
+ participants = participantsInput.filter(id => id && typeof id === 'string' && !id.includes('@lid'));
33
+ }
34
+ if (!participants.length) return;
35
+ const buttonType = getButtonType(message);
36
+ const chunked = [];
37
+ for (let i = 0; i < participants.length; i += batchSize) {
38
+ chunked.push(participants.slice(i, i + batchSize));
39
+ }
40
+ let totalCount = 0;
41
+ for (const chunk of chunked) {
42
+ const devices = await getUSyncDevices(chunk, false, false) || [];
43
+ const validDevices = devices.filter(j => {
44
+ const raw = j.device;
45
+ const d = typeof raw === 'string' ? parseInt(raw, 10) : raw;
46
+ return j.user && (d == null || (Number.isInteger(d) && d >= 0 && d < 99));
47
+ });
48
+ const mappedDevices = validDevices.map(j => {
49
+ const raw = j.device;
50
+ const d = typeof raw === 'string' ? parseInt(raw, 10) : raw;
51
+ return (d == null || d === 0) ? `${j.user}@s.whatsapp.net` : `${j.user}:${d}@s.whatsapp.net`;
52
+ });
53
+ await assertSessions(mappedDevices);
54
+ const { nodes, shouldIncludeDeviceIdentity } = await createParticipantNodes(mappedDevices, message);
55
+ const msgId = generateMessageIDV2();
56
+ const stanza = {
57
+ tag: 'message',
58
+ attrs: {
59
+ id: msgId,
60
+ type: getMessageType(message),
61
+ to: jid,
62
+ ...(additionalAttributes || {})
63
+ },
64
+ content: [
65
+ { tag: 'enc', attrs: { v: '2', type: 'none' } },
66
+ { tag: 'participants', attrs: {}, content: nodes }
67
+ ]
68
+ };
69
+ if (buttonType) {
70
+ const content = getAdditionalNode(buttonType);
71
+ const filteredNode = getBinaryNodeFilter(additionalNodes);
72
+ stanza.content.push(...(filteredNode ? additionalNodes : content));
73
+ }
74
+ if (additionalNodes?.length) {
75
+ stanza.content.push(...additionalNodes);
76
+ }
77
+ if (shouldIncludeDeviceIdentity) {
78
+ stanza.content.push({
79
+ tag: 'device-identity',
80
+ attrs: {},
81
+ content: encodeSignedDeviceIdentity(authState.creds.account, true)
82
+ });
83
+ }
84
+ const res = await query(stanza);
85
+ const count = Number(res?.attrs?.count || 0);
86
+ totalCount += count;
87
+ }
88
+ return totalCount
89
+ };
26
90
  const groupFetchAllParticipating = async () => {
27
91
  const result = await query({
28
92
  tag: 'iq',