@jkt48connect-corp/baileys 7.2.9 → 7.3.1

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 (100) hide show
  1. package/WAProto/index.d.ts +48955 -0
  2. package/lib/Defaults/baileys-version.json +1 -1
  3. package/lib/Defaults/index.d.ts +284 -0
  4. package/lib/Defaults/index.js +5 -5
  5. package/lib/Signal/libsignal.d.ts +3 -0
  6. package/lib/Socket/Client/abstract-socket-client.d.ts +15 -0
  7. package/lib/Socket/Client/index.d.ts +2 -0
  8. package/lib/Socket/Client/index.js +2 -3
  9. package/lib/Socket/Client/mobile-socket-client.d.ts +12 -0
  10. package/lib/Socket/Client/types.d.ts +17 -0
  11. package/lib/Socket/Client/types.js +13 -0
  12. package/lib/Socket/Client/websocket.d.ts +12 -0
  13. package/lib/Socket/Client/{web-socket-client.js → websocket.js} +2 -2
  14. package/lib/Socket/business.d.ts +170 -0
  15. package/lib/Socket/chats.d.ts +81 -0
  16. package/lib/Socket/chats.js +51 -48
  17. package/lib/Socket/groups.d.ts +115 -0
  18. package/lib/Socket/groups.js +1 -0
  19. package/lib/Socket/index.d.ts +172 -0
  20. package/lib/Socket/messages-recv.d.ts +158 -0
  21. package/lib/Socket/messages-send.d.ts +155 -0
  22. package/lib/Socket/messages-send.js +105 -77
  23. package/lib/Socket/newsletter.d.ts +132 -0
  24. package/lib/Socket/registration.d.ts +264 -0
  25. package/lib/Socket/socket.d.ts +44 -0
  26. package/lib/Socket/socket.js +15 -8
  27. package/lib/Socket/usync.d.ts +37 -0
  28. package/lib/Socket/usync.js +70 -0
  29. package/lib/Store/index.d.ts +3 -0
  30. package/lib/Store/make-cache-manager-store.d.ts +14 -0
  31. package/lib/Store/make-in-memory-store.d.ts +118 -0
  32. package/lib/Store/make-in-memory-store.js +24 -13
  33. package/lib/Store/make-ordered-dictionary.d.ts +13 -0
  34. package/lib/Store/object-repository.d.ts +10 -0
  35. package/lib/Types/Auth.d.ts +109 -0
  36. package/lib/Types/Call.d.ts +13 -0
  37. package/lib/Types/Chat.d.ts +107 -0
  38. package/lib/Types/Contact.d.ts +19 -0
  39. package/lib/Types/Events.d.ts +172 -0
  40. package/lib/Types/GroupMetadata.d.ts +56 -0
  41. package/lib/Types/Label.d.ts +46 -0
  42. package/lib/Types/LabelAssociation.d.ts +29 -0
  43. package/lib/Types/Message.d.ts +433 -0
  44. package/lib/Types/Newsletter.d.ts +92 -0
  45. package/lib/Types/Product.d.ts +78 -0
  46. package/lib/Types/Signal.d.ts +57 -0
  47. package/lib/Types/Socket.d.ts +116 -0
  48. package/lib/Types/State.d.ts +27 -0
  49. package/lib/Types/USync.d.ts +25 -0
  50. package/lib/Types/USync.js +2 -0
  51. package/lib/Types/index.d.ts +66 -0
  52. package/lib/Utils/auth-utils.d.ts +18 -0
  53. package/lib/Utils/baileys-event-stream.d.ts +16 -0
  54. package/lib/Utils/business.d.ts +22 -0
  55. package/lib/Utils/chat-utils.d.ts +70 -0
  56. package/lib/Utils/crypto.d.ts +40 -0
  57. package/lib/Utils/decode-wa-message.d.ts +36 -0
  58. package/lib/Utils/event-buffer.d.ts +35 -0
  59. package/lib/Utils/generics.d.ts +88 -0
  60. package/lib/Utils/generics.js +2 -2
  61. package/lib/Utils/history.d.ts +19 -0
  62. package/lib/Utils/index.d.ts +17 -0
  63. package/lib/Utils/link-preview.d.ts +21 -0
  64. package/lib/Utils/logger.d.ts +2 -0
  65. package/lib/Utils/lt-hash.d.ts +12 -0
  66. package/lib/Utils/make-mutex.d.ts +7 -0
  67. package/lib/Utils/messages-media.d.ts +113 -0
  68. package/lib/Utils/messages.d.ts +77 -0
  69. package/lib/Utils/messages.js +73 -12
  70. package/lib/Utils/messages.js.bak +1249 -0
  71. package/lib/Utils/noise-handler.d.ts +20 -0
  72. package/lib/Utils/process-message.d.ts +41 -0
  73. package/lib/Utils/signal.d.ts +33 -0
  74. package/lib/Utils/signal.js +11 -19
  75. package/lib/Utils/use-multi-file-auth-state.d.ts +12 -0
  76. package/lib/Utils/use-multi-file-auth-state.js +1 -7
  77. package/lib/Utils/validate-connection.d.ts +11 -0
  78. package/lib/Utils/validate-connection.js +23 -12
  79. package/lib/WABinary/constants.d.ts +27 -0
  80. package/lib/WABinary/decode.d.ts +6 -0
  81. package/lib/WABinary/encode.d.ts +2 -0
  82. package/lib/WABinary/generic-utils.d.ts +14 -0
  83. package/lib/WABinary/index.d.ts +5 -0
  84. package/lib/WABinary/jid-utils.d.ts +31 -0
  85. package/lib/WABinary/types.d.ts +18 -0
  86. package/lib/WAM/BinaryInfo.d.ts +8 -0
  87. package/lib/WAM/constants.d.ts +38 -0
  88. package/lib/WAM/encode.d.ts +2 -0
  89. package/lib/WAM/index.d.ts +3 -0
  90. package/lib/WAUSync/Protocols/USyncContactProtocol.d.ts +9 -0
  91. package/lib/WAUSync/Protocols/USyncDeviceProtocol.d.ts +22 -0
  92. package/lib/WAUSync/Protocols/USyncDisappearingModeProtocol.d.ts +12 -0
  93. package/lib/WAUSync/Protocols/USyncStatusProtocol.d.ts +12 -0
  94. package/lib/WAUSync/Protocols/index.d.ts +4 -0
  95. package/lib/WAUSync/USyncQuery.d.ts +26 -0
  96. package/lib/WAUSync/USyncUser.d.ts +10 -0
  97. package/lib/WAUSync/index.d.ts +3 -0
  98. package/lib/index.js +1 -3
  99. package/package.json +7 -4
  100. package/LICENSE +0 -21
@@ -0,0 +1,81 @@
1
+ /// <reference types="node" />
2
+ import { Boom } from '@hapi/boom';
3
+ import { proto } from '../../WAProto';
4
+ import { ChatModification, MessageUpsertType, SocketConfig, WABusinessProfile, WAMediaUpload, WAPatchCreate, WAPresence, WAPrivacyOnlineValue, WAPrivacyValue, WAReadReceiptsValue } from '../Types';
5
+ import { BinaryNode } from '../WABinary';
6
+ import { USyncQuery } from '../WAUSync';
7
+ export declare const makeChatsSocket: (config: SocketConfig) => {
8
+ interactiveQuery: (userNodes: BinaryNode[], queryNode: BinaryNode) => Promise<BinaryNode[]>;
9
+ processingMutex: {
10
+ mutex<T>(code: () => T | Promise<T>): Promise<T>;
11
+ };
12
+ fetchPrivacySettings: (force?: boolean) => Promise<{
13
+ [_: string]: string;
14
+ }>;
15
+ upsertMessage: (msg: proto.IWebMessageInfo, type: MessageUpsertType) => Promise<void>;
16
+ appPatch: (patchCreate: WAPatchCreate) => Promise<void>;
17
+ fetchUserLid: (jid: string) => Promise<string | undefined>;
18
+ sendPresenceUpdate: (type: WAPresence, toJid?: string) => Promise<void>;
19
+ presenceSubscribe: (toJid: string, tcToken?: Buffer) => Promise<void>;
20
+ onWhatsApp: (...jids: string[]) => Promise<{
21
+ jid: string;
22
+ exists: unknown;
23
+ }[] | undefined>;
24
+ fetchBlocklist: () => Promise<string[]>;
25
+ fetchStatus: (...jids: string[]) => Promise<import("../WAUSync").USyncQueryResultList[] | undefined>;
26
+ fetchDisappearingDuration: (...jids: string[]) => Promise<import("../WAUSync").USyncQueryResultList[] | undefined>;
27
+ updateProfilePicture: (jid: string, content: WAMediaUpload) => Promise<void>;
28
+ removeProfilePicture: (jid: string) => Promise<void>;
29
+ updateProfileStatus: (status: string) => Promise<void>;
30
+ updateProfileName: (name: string) => Promise<void>;
31
+ updateBlockStatus: (jid: string, action: 'block' | 'unblock') => Promise<void>;
32
+ updateLastSeenPrivacy: (value: WAPrivacyValue) => Promise<void>;
33
+ updateOnlinePrivacy: (value: WAPrivacyOnlineValue) => Promise<void>;
34
+ updateProfilePicturePrivacy: (value: WAPrivacyValue) => Promise<void>;
35
+ updateStatusPrivacy: (value: WAPrivacyValue) => Promise<void>;
36
+ updateReadReceiptsPrivacy: (value: WAReadReceiptsValue) => Promise<void>;
37
+ updateGroupsAddPrivacy: (value: WAPrivacyValue) => Promise<void>;
38
+ updateDefaultDisappearingMode: (duration: number) => Promise<void>;
39
+ getBusinessProfile: (jid: string) => Promise<WABusinessProfile | void>;
40
+ resyncAppState: (collections: readonly ("critical_block" | "critical_unblock_low" | "regular_high" | "regular_low" | "regular")[], isInitialSync: boolean) => Promise<void>;
41
+ chatModify: (mod: ChatModification, jid: string) => Promise<void>;
42
+ cleanDirtyBits: (type: 'account_sync' | 'groups', fromTimestamp?: number | string) => Promise<void>;
43
+ addChatLabel: (jid: string, labelId: string) => Promise<void>;
44
+ removeChatLabel: (jid: string, labelId: string) => Promise<void>;
45
+ addMessageLabel: (jid: string, messageId: string, labelId: string) => Promise<void>;
46
+ removeMessageLabel: (jid: string, messageId: string, labelId: string) => Promise<void>;
47
+ star: (jid: string, messages: {
48
+ id: string;
49
+ fromMe?: boolean;
50
+ }[], star: boolean) => Promise<void>;
51
+ executeUSyncQuery: (usyncQuery: USyncQuery) => Promise<import("../WAUSync").USyncQueryResult | undefined>;
52
+ type: "md";
53
+ ws: any;
54
+ ev: import("../Types").BaileysEventEmitter & {
55
+ process(handler: (events: Partial<import("../Types").BaileysEventMap>) => void | Promise<void>): () => void;
56
+ buffer(): void;
57
+ createBufferedFunction<A extends any[], T_1>(work: (...args: A) => Promise<T_1>): (...args: A) => Promise<T_1>;
58
+ flush(force?: boolean | undefined): boolean;
59
+ isBuffering(): boolean;
60
+ };
61
+ authState: {
62
+ creds: import("../Types").AuthenticationCreds;
63
+ keys: import("../Types").SignalKeyStoreWithTransaction;
64
+ };
65
+ signalRepository: import("../Types").SignalRepository;
66
+ user: import("../Types").Contact | undefined;
67
+ generateMessageTag: () => string;
68
+ query: (node: BinaryNode, timeoutMs?: number | undefined) => Promise<BinaryNode>;
69
+ waitForMessage: <T_2>(msgId: string, timeoutMs?: number | undefined) => Promise<T_2>;
70
+ waitForSocketOpen: () => Promise<void>;
71
+ sendRawMessage: (data: Uint8Array | Buffer) => Promise<void>;
72
+ sendNode: (frame: BinaryNode) => Promise<void>;
73
+ logout: (msg?: string | undefined) => Promise<void>;
74
+ end: (error: Error | undefined) => void;
75
+ onUnexpectedError: (err: Error | Boom<any>, msg: string) => void;
76
+ uploadPreKeys: (count?: number) => Promise<void>;
77
+ uploadPreKeysToServerIfRequired: () => Promise<void>;
78
+ requestPairingCode: (phoneNumber: string, pairCode: string) => Promise<string>;
79
+ waitForConnectionUpdate: (check: (u: Partial<import("../Types").ConnectionState>) => boolean | undefined, timeoutMs?: number | undefined) => Promise<void>;
80
+ sendWAMBuffer: (wamBuffer: Buffer) => Promise<BinaryNode>;
81
+ };
@@ -12,12 +12,13 @@ const Utils_1 = require("../Utils");
12
12
  const make_mutex_1 = require("../Utils/make-mutex");
13
13
  const process_message_1 = __importDefault(require("../Utils/process-message"));
14
14
  const WABinary_1 = require("../WABinary");
15
- const socket_1 = require("./socket");
15
+ const WAUSync_1 = require("../WAUSync");
16
+ const usync_1 = require("./usync");
16
17
  const MAX_SYNC_ATTEMPTS = 2;
17
18
  const makeChatsSocket = (config) => {
18
19
  const { logger, markOnlineOnConnect, fireInitQueries, appStateMacVerification, shouldIgnoreJid, shouldSyncHistoryMessage, } = config;
19
- const sock = (0, socket_1.makeSocket)(config);
20
- const { ev, ws, authState, generateMessageTag, sendNode, query, onUnexpectedError, } = sock;
20
+ const sock = (0, usync_1.makeUSyncSocket)(config);
21
+ const { ev, ws, authState, generateMessageTag, sendNode, query, onUnexpectedError } = sock;
21
22
  let privacySettings;
22
23
  let needToFlushWithAppStateSync = false;
23
24
  let pendingAppStateSync = false;
@@ -139,35 +140,53 @@ const makeChatsSocket = (config) => {
139
140
  const users = (0, WABinary_1.getBinaryNodeChildren)(listNode, 'user');
140
141
  return users;
141
142
  };
142
- const onWhatsApp = async (...jids) => {
143
- const query = { tag: 'contact', attrs: {} };
144
- const list = jids.map((jid) => {
145
- // insures only 1 + is there
146
- const content = `+${jid.replace('+', '')}`;
147
- return {
143
+ const fetchUserLid = async (jid) => {
144
+ const [result] = await interactiveQuery([
145
+ {
148
146
  tag: 'user',
149
- attrs: {},
150
- content: [{
151
- tag: 'contact',
152
- attrs: {},
153
- content,
154
- }],
155
- };
147
+ attrs: { jid }
148
+ }
149
+ ], {
150
+ tag: 'lid',
151
+ attrs: {}
156
152
  });
157
- const results = await interactiveQuery(list, query);
158
- return results.map(user => {
159
- const contact = (0, WABinary_1.getBinaryNodeChild)(user, 'contact');
160
- return { exists: (contact === null || contact === void 0 ? void 0 : contact.attrs.type) === 'in', jid: user.attrs.jid };
161
- }).filter(item => item.exists);
162
- };
163
- const fetchStatus = async (jid) => {
164
- const [result] = await interactiveQuery([{ tag: 'user', attrs: { jid } }], { tag: 'status', attrs: {} });
165
153
  if (result) {
166
- const status = (0, WABinary_1.getBinaryNodeChild)(result, 'status');
167
- return {
168
- status: status === null || status === void 0 ? void 0 : status.content.toString(),
169
- setAt: new Date(+((status === null || status === void 0 ? void 0 : status.attrs.t) || 0) * 1000)
170
- };
154
+ const lid = (0, WABinary_1.getBinaryNodeChild)(result, 'lid');
155
+ return lid.attrs.val;
156
+ }
157
+ };
158
+ const onWhatsApp = async (...jids) => {
159
+ const usyncQuery = new WAUSync_1.USyncQuery()
160
+ .withContactProtocol();
161
+ for (const jid of jids) {
162
+ const phone = `+${jid.replace('+', '').split('@')[0].split(':')[0]}`;
163
+ usyncQuery.withUser(new WAUSync_1.USyncUser().withPhone(phone));
164
+ }
165
+ const results = await sock.executeUSyncQuery(usyncQuery);
166
+ if (results) {
167
+ return results.list.filter((a) => !!a.contact).map(({ contact, id }) => ({ jid: id, exists: contact }));
168
+ }
169
+ };
170
+ const fetchStatus = async (...jids) => {
171
+ const usyncQuery = new WAUSync_1.USyncQuery()
172
+ .withStatusProtocol();
173
+ for (const jid of jids) {
174
+ usyncQuery.withUser(new WAUSync_1.USyncUser().withId(jid));
175
+ }
176
+ const result = await sock.executeUSyncQuery(usyncQuery);
177
+ if (result) {
178
+ return result.list;
179
+ }
180
+ };
181
+ const fetchDisappearingDuration = async (...jids) => {
182
+ const usyncQuery = new WAUSync_1.USyncQuery()
183
+ .withDisappearingModeProtocol();
184
+ for (const jid of jids) {
185
+ usyncQuery.withUser(new WAUSync_1.USyncUser().withId(jid));
186
+ }
187
+ const result = await sock.executeUSyncQuery(usyncQuery);
188
+ if (result) {
189
+ return result.list;
171
190
  }
172
191
  };
173
192
  /** update the profile picture for yourself or a group */
@@ -458,24 +477,6 @@ const makeChatsSocket = (config) => {
458
477
  * type = "preview" for a low res picture
459
478
  * type = "image for the high res picture"
460
479
  */
461
- const profilePictureUrl = async (jid, type = 'preview', timeoutMs) => {
462
- var _a;
463
- jid = (0, WABinary_1.jidNormalizedUser)(jid);
464
- const result = await query({
465
- tag: 'iq',
466
- attrs: {
467
- target: jid,
468
- to: WABinary_1.S_WHATSAPP_NET,
469
- type: 'get',
470
- xmlns: 'w:profile:picture'
471
- },
472
- content: [
473
- { tag: 'picture', attrs: { type, query: 'url' } }
474
- ]
475
- }, timeoutMs);
476
- const child = (0, WABinary_1.getBinaryNodeChild)(result, 'picture');
477
- return (_a = child === null || child === void 0 ? void 0 : child.attrs) === null || _a === void 0 ? void 0 : _a.url;
478
- };
479
480
  const sendPresenceUpdate = async (type, toJid) => {
480
481
  const me = authState.creds.me;
481
482
  if (type === 'available' || type === 'unavailable') {
@@ -832,16 +833,18 @@ const makeChatsSocket = (config) => {
832
833
  });
833
834
  return {
834
835
  ...sock,
836
+ interactiveQuery,
835
837
  processingMutex,
836
838
  fetchPrivacySettings,
837
839
  upsertMessage,
838
840
  appPatch,
841
+ fetchUserLid,
839
842
  sendPresenceUpdate,
840
843
  presenceSubscribe,
841
- profilePictureUrl,
842
844
  onWhatsApp,
843
845
  fetchBlocklist,
844
846
  fetchStatus,
847
+ fetchDisappearingDuration,
845
848
  updateProfilePicture,
846
849
  removeProfilePicture,
847
850
  updateProfileStatus,
@@ -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
+ groupQuery: (jid: string, type: 'get' | 'set', content: BinaryNode[]) => Promise<BinaryNode>;
7
+ groupMetadata: (jid: string) => Promise<GroupMetadata>;
8
+ groupCreate: (subject: string, participants: string[]) => Promise<GroupMetadata>;
9
+ groupLeave: (id: string) => Promise<void>;
10
+ groupUpdateSubject: (jid: string, subject: string) => Promise<void>;
11
+ groupRequestParticipantsList: (jid: string) => Promise<{
12
+ [key: string]: string;
13
+ }[]>;
14
+ groupRequestParticipantsUpdate: (jid: string, participants: string[], action: 'approve' | 'reject') => Promise<{
15
+ status: string;
16
+ jid: string;
17
+ }[]>;
18
+ groupParticipantsUpdate: (jid: string, participants: string[], action: ParticipantAction) => Promise<{
19
+ status: string;
20
+ jid: string;
21
+ content: BinaryNode;
22
+ }[]>;
23
+ groupUpdateDescription: (jid: string, description?: string) => Promise<void>;
24
+ groupInviteCode: (jid: string) => Promise<string | undefined>;
25
+ groupRevokeInvite: (jid: string) => Promise<string | undefined>;
26
+ groupAcceptInvite: (code: string) => Promise<string | undefined>;
27
+ /**
28
+ * accept a GroupInviteMessage
29
+ * @param key the key of the invite message, or optionally only provide the jid of the person who sent the invite
30
+ * @param inviteMessage the message to accept
31
+ */
32
+ groupAcceptInviteV4: (key: string | proto.IMessageKey, inviteMessage: proto.Message.IGroupInviteMessage) => Promise<string>;
33
+ groupGetInviteInfo: (code: string) => Promise<GroupMetadata>;
34
+ groupToggleEphemeral: (jid: string, ephemeralExpiration: number) => Promise<void>;
35
+ groupSettingUpdate: (jid: string, setting: 'announcement' | 'not_announcement' | 'locked' | 'unlocked') => Promise<void>;
36
+ groupMemberAddMode: (jid: string, mode: 'admin_add' | 'all_member_add') => Promise<void>;
37
+ groupJoinApprovalMode: (jid: string, mode: 'on' | 'off') => Promise<void>;
38
+ groupFetchAllParticipating: () => Promise<{
39
+ [_: string]: GroupMetadata;
40
+ }>;
41
+ interactiveQuery: (userNodes: BinaryNode[], queryNode: BinaryNode) => Promise<BinaryNode[]>;
42
+ processingMutex: {
43
+ mutex<T>(code: () => T | Promise<T>): Promise<T>;
44
+ };
45
+ fetchPrivacySettings: (force?: boolean) => Promise<{
46
+ [_: string]: string;
47
+ }>;
48
+ upsertMessage: (msg: proto.IWebMessageInfo, type: import("../Types").MessageUpsertType) => Promise<void>;
49
+ appPatch: (patchCreate: import("../Types").WAPatchCreate) => Promise<void>;
50
+ fetchUserLid: (jid: string) => Promise<string | undefined>;
51
+ sendPresenceUpdate: (type: import("../Types").WAPresence, toJid?: string | undefined) => Promise<void>;
52
+ presenceSubscribe: (toJid: string, tcToken?: Buffer | undefined) => Promise<void>;
53
+ onWhatsApp: (...jids: string[]) => Promise<{
54
+ jid: string;
55
+ exists: unknown;
56
+ }[] | undefined>;
57
+ fetchBlocklist: () => Promise<string[]>;
58
+ fetchStatus: (...jids: string[]) => Promise<import("../index").USyncQueryResultList[] | undefined>;
59
+ fetchDisappearingDuration: (...jids: string[]) => Promise<import("../index").USyncQueryResultList[] | undefined>;
60
+ updateProfilePicture: (jid: string, content: import("../Types").WAMediaUpload) => Promise<void>;
61
+ removeProfilePicture: (jid: string) => Promise<void>;
62
+ updateProfileStatus: (status: string) => Promise<void>;
63
+ updateProfileName: (name: string) => Promise<void>;
64
+ updateBlockStatus: (jid: string, action: "block" | "unblock") => Promise<void>;
65
+ updateLastSeenPrivacy: (value: import("../Types").WAPrivacyValue) => Promise<void>;
66
+ updateOnlinePrivacy: (value: import("../Types").WAPrivacyOnlineValue) => Promise<void>;
67
+ updateProfilePicturePrivacy: (value: import("../Types").WAPrivacyValue) => Promise<void>;
68
+ updateStatusPrivacy: (value: import("../Types").WAPrivacyValue) => Promise<void>;
69
+ updateReadReceiptsPrivacy: (value: import("../Types").WAReadReceiptsValue) => Promise<void>;
70
+ updateGroupsAddPrivacy: (value: import("../Types").WAPrivacyValue) => Promise<void>;
71
+ updateDefaultDisappearingMode: (duration: number) => Promise<void>;
72
+ getBusinessProfile: (jid: string) => Promise<void | import("../Types").WABusinessProfile>;
73
+ resyncAppState: (collections: readonly ("critical_block" | "critical_unblock_low" | "regular_high" | "regular_low" | "regular")[], isInitialSync: boolean) => Promise<void>;
74
+ chatModify: (mod: import("../Types").ChatModification, jid: string) => Promise<void>;
75
+ cleanDirtyBits: (type: "account_sync" | "groups", fromTimestamp?: string | number | undefined) => Promise<void>;
76
+ addChatLabel: (jid: string, labelId: string) => Promise<void>;
77
+ removeChatLabel: (jid: string, labelId: string) => Promise<void>;
78
+ addMessageLabel: (jid: string, messageId: string, labelId: string) => Promise<void>;
79
+ removeMessageLabel: (jid: string, messageId: string, labelId: string) => Promise<void>;
80
+ star: (jid: string, messages: {
81
+ id: string;
82
+ fromMe?: boolean | undefined;
83
+ }[], star: boolean) => Promise<void>;
84
+ executeUSyncQuery: (usyncQuery: import("../index").USyncQuery) => Promise<import("../index").USyncQueryResult | undefined>;
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, pairCode: 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;
@@ -67,6 +67,7 @@ const makeGroupsSocket = (config) => {
67
67
  });
68
68
  return {
69
69
  ...sock,
70
+ groupQuery,
70
71
  groupMetadata,
71
72
  groupCreate: async (subject, participants) => {
72
73
  const key = (0, Utils_1.generateMessageID)();
@@ -0,0 +1,172 @@
1
+ import { UserFacingSocketConfig } from '../Types';
2
+ declare const makeWASocket: (config: UserFacingSocketConfig) => {
3
+ register: (code: string) => Promise<import("./registration").ExistsResponse>;
4
+ requestRegistrationCode: (registrationOptions?: import("./registration").RegistrationOptions) => Promise<import("./registration").ExistsResponse>;
5
+ logger: Logger;
6
+ getOrderDetails: (orderId: string, tokenBase64: string) => Promise<import("../Types").OrderDetails>;
7
+ getCatalog: ({ jid, limit, cursor }: import("../Types").GetCatalogOptions) => Promise<{
8
+ products: import("../Types").Product[];
9
+ nextPageCursor: any;
10
+ }>;
11
+ getCollections: (jid?: string, limit?: number) => Promise<{
12
+ collections: import("../Types").CatalogCollection[];
13
+ }>;
14
+ productCreate: (create: import("../Types").ProductCreate) => Promise<import("../Types").Product>;
15
+ productDelete: (productIds: string[]) => Promise<{
16
+ deleted: number;
17
+ }>;
18
+ productUpdate: (productId: string, update: import("../Types").ProductUpdate) => Promise<import("../Types").Product>;
19
+ sendMessageAck: ({ tag, attrs, content }: import("..").BinaryNode, errorCode?: number) => Promise<void>;
20
+ sendRetryRequest: (node: import("..").BinaryNode, forceIncludeKeys?: boolean) => Promise<void>;
21
+ offerCall: (toJid: string, isVideo?: boolean) => Promise<{
22
+ id: any;
23
+ to: string;
24
+ }>;
25
+ rejectCall: (callId: string, callFrom: string) => Promise<void>;
26
+ fetchMessageHistory: (count: number, oldestMsgKey: import("../Types").WAMessageKey, oldestMsgTimestamp: number) => Promise<string>;
27
+ requestPlaceholderResend: (messageKey: import("../Types").WAMessageKey) => Promise<string | undefined>;
28
+ getPrivacyTokens: (jids: string[]) => Promise<import("..").BinaryNode>;
29
+ assertSessions: (jids: string[], force: boolean) => Promise<boolean>;
30
+ relayMessage: (jid: string, message: import("../Types").WAProto.IMessage, { messageId: msgId, participant, additionalAttributes, additionalNodes, useUserDevicesCache, cachedGroupMetadata, statusJidList }: import("../Types").MessageRelayOptions) => Promise<string>;
31
+ sendReceipt: (jid: string, participant: string | undefined, messageIds: string[], type: import("../Types").MessageReceiptType) => Promise<void>;
32
+ sendReceipts: (keys: import("../Types").WAMessageKey[], type: import("../Types").MessageReceiptType) => Promise<void>;
33
+ getButtonArgs: (message: import("../Types").WAProto.IMessage) => import("..").BinaryNode["attrs"];
34
+ readMessages: (keys: import("../Types").WAMessageKey[]) => Promise<void>;
35
+ refreshMediaConn: (forceGet?: boolean) => Promise<import("../Types").MediaConnInfo>;
36
+ getUSyncDevices: (jids: string[], useCache: boolean, ignoreZeroDevices: boolean) => Promise<import("..").JidWithDevice[]>;
37
+ sendPeerDataOperationMessage: (pdoMessage: import("../Types").WAProto.Message.IPeerDataOperationRequestMessage) => Promise<string>;
38
+ createParticipantNodes: (jids: string[], message: import("../Types").WAProto.IMessage, extraAttrs?: import("..").BinaryNode["attrs"]) => Promise<{
39
+ nodes: import("..").BinaryNode[];
40
+ shouldIncludeDeviceIdentity: boolean;
41
+ }>;
42
+ waUploadToServer: import("../Types").WAMediaUploadFunction;
43
+ fetchPrivacySettings: (force?: boolean) => Promise<{
44
+ [_: string]: string;
45
+ }>;
46
+ updateMediaMessage: (message: import("../Types").WAProto.IWebMessageInfo) => Promise<import("../Types").WAProto.IWebMessageInfo>;
47
+ sendStatusMentions: (content: import("../Types").AnyMessageContent, jids?: string[]) => Promise<import("../Types").WAProto.WebMessageInfo>;
48
+ sendAlbumMessage: (jid: string, medias: import("../Types").Media[], options?: import("../Types").MiscMessageGenerationOptions) => Promise<import("../Types").WAProto.WebMessageInfo>;
49
+ sendMessage: (jid: string, content: import("../Types").AnyMessageContent, options?: import("../Types").MiscMessageGenerationOptions) => Promise<import("../Types").WAProto.WebMessageInfo | undefined>;
50
+ subscribeNewsletterUpdates: (jid: string) => Promise<{
51
+ duration: string;
52
+ }>;
53
+ newsletterReactionMode: (jid: string, mode: import("../Types").NewsletterReactionMode) => Promise<void>;
54
+ newsletterUpdateDescription: (jid: string, description?: string) => Promise<void>;
55
+ newsletterUpdateName: (jid: string, name: string) => Promise<void>;
56
+ newsletterUpdatePicture: (jid: string, content: import("../Types").WAMediaUpload) => Promise<void>;
57
+ newsletterRemovePicture: (jid: string) => Promise<void>;
58
+ newsletterUnfollow: (jid: string) => Promise<void>;
59
+ newsletterFollow: (jid: string) => Promise<void>;
60
+ newsletterUnmute: (jid: string) => Promise<void>;
61
+ newsletterMute: (jid: string) => Promise<void>;
62
+ newsletterAction: (jid: string, type: "follow" | "unfollow" | "mute" | "unmute") => Promise<void>;
63
+ newsletterCreate: (name: string, description: string) => Promise<import("../Types").NewsletterMetadata>;
64
+ newsletterMetadata: (type: "invite" | "jid", key: string, role?: import("../Types").NewsletterViewRole) => Promise<import("../Types").NewsletterMetadata>;
65
+ newsletterAdminCount: (jid: string) => Promise<number>;
66
+ newsletterChangeOwner: (jid: string, user: string) => Promise<void>;
67
+ newsletterDemote: (jid: string, user: string) => Promise<void>;
68
+ newsletterDelete: (jid: string) => Promise<void>;
69
+ newsletterReactMessage: (jid: string, serverId: string, code?: string) => Promise<void>;
70
+ newsletterFetchMessages: (type: "invite" | "jid", key: string, count: number, after?: number) => Promise<import("../Types").NewsletterFetchedUpdate[]>;
71
+ newsletterFetchUpdates: (jid: string, count: number, after?: number, since?: number) => Promise<import("../Types").NewsletterFetchedUpdate[]>;
72
+ groupMetadata: (jid: string) => Promise<import("../Types").GroupMetadata>;
73
+ groupCreate: (subject: string, participants: string[]) => Promise<import("../Types").GroupMetadata>;
74
+ groupLeave: (id: string) => Promise<void>;
75
+ groupUpdateSubject: (jid: string, subject: string) => Promise<void>;
76
+ groupRequestParticipantsList: (jid: string) => Promise<{
77
+ [key: string]: string;
78
+ }[]>;
79
+ groupRequestParticipantsUpdate: (jid: string, participants: string[], action: "approve" | "reject") => Promise<{
80
+ status: string;
81
+ jid: string;
82
+ }[]>;
83
+ groupParticipantsUpdate: (jid: string, participants: string[], action: import("../Types").ParticipantAction) => Promise<{
84
+ status: string;
85
+ jid: string;
86
+ content: import("..").BinaryNode;
87
+ }[]>;
88
+ groupUpdateDescription: (jid: string, description?: string) => Promise<void>;
89
+ groupInviteCode: (jid: string) => Promise<string | undefined>;
90
+ groupRevokeInvite: (jid: string) => Promise<string | undefined>;
91
+ groupAcceptInvite: (code: string) => Promise<string | undefined>;
92
+ groupAcceptInviteV4: (key: string | import("../Types").WAProto.IMessageKey, inviteMessage: import("../Types").WAProto.Message.IGroupInviteMessage) => Promise<string>;
93
+ groupGetInviteInfo: (code: string) => Promise<import("../Types").GroupMetadata>;
94
+ groupToggleEphemeral: (jid: string, ephemeralExpiration: number) => Promise<void>;
95
+ groupSettingUpdate: (jid: string, setting: "announcement" | "not_announcement" | "locked" | "unlocked") => Promise<void>;
96
+ groupMemberAddMode: (jid: string, mode: "admin_add" | "all_member_add") => Promise<void>;
97
+ groupJoinApprovalMode: (jid: string, mode: "on" | "off") => Promise<void>;
98
+ groupFetchAllParticipating: () => Promise<{
99
+ [_: string]: import("../Types").GroupMetadata;
100
+ }>;
101
+ processingMutex: {
102
+ mutex<T>(code: () => Promise<T> | T): Promise<T>;
103
+ };
104
+ upsertMessage: (msg: import("../Types").WAProto.IWebMessageInfo, type: import("../Types").MessageUpsertType) => Promise<void>;
105
+ appPatch: (patchCreate: import("../Types").WAPatchCreate) => Promise<void>;
106
+ sendPresenceUpdate: (type: import("../Types").WAPresence, toJid?: string) => Promise<void>;
107
+ presenceSubscribe: (toJid: string, tcToken?: Buffer) => Promise<void>;
108
+ profilePictureUrl: (jid: string, type?: "preview" | "image", timeoutMs?: number) => Promise<string | undefined>;
109
+ onWhatsApp: (...jids: string[]) => Promise<{
110
+ exists: boolean;
111
+ jid: string;
112
+ }[]>;
113
+ fetchBlocklist: () => Promise<string[]>;
114
+ fetchStatus: (jid: string) => Promise<{
115
+ status: string | undefined;
116
+ setAt: Date;
117
+ } | undefined>;
118
+ updateProfilePicture: (jid: string, content: import("../Types").WAMediaUpload) => Promise<void>;
119
+ removeProfilePicture: (jid: string) => Promise<void>;
120
+ updateProfileStatus: (status: string) => Promise<void>;
121
+ updateProfileName: (name: string) => Promise<void>;
122
+ updateBlockStatus: (jid: string, action: "block" | "unblock") => Promise<void>;
123
+ updateLastSeenPrivacy: (value: import("../Types").WAPrivacyValue) => Promise<void>;
124
+ updateOnlinePrivacy: (value: import("../Types").WAPrivacyOnlineValue) => Promise<void>;
125
+ updateProfilePicturePrivacy: (value: import("../Types").WAPrivacyValue) => Promise<void>;
126
+ updateStatusPrivacy: (value: import("../Types").WAPrivacyValue) => Promise<void>;
127
+ updateReadReceiptsPrivacy: (value: import("../Types").WAReadReceiptsValue) => Promise<void>;
128
+ updateGroupsAddPrivacy: (value: import("../Types").WAPrivacyValue) => Promise<void>;
129
+ updateDefaultDisappearingMode: (duration: number) => Promise<void>;
130
+ getBusinessProfile: (jid: string) => Promise<import("../Types").WABusinessProfile | void>;
131
+ resyncAppState: (collections: readonly ("critical_block" | "critical_unblock_low" | "regular_high" | "regular_low" | "regular")[], isInitialSync: boolean) => Promise<void>;
132
+ chatModify: (mod: import("../Types").ChatModification, jid: string) => Promise<void>;
133
+ cleanDirtyBits: (type: "account_sync" | "groups", fromTimestamp?: number | string) => Promise<void>;
134
+ addChatLabel: (jid: string, labelId: string) => Promise<void>;
135
+ removeChatLabel: (jid: string, labelId: string) => Promise<void>;
136
+ addMessageLabel: (jid: string, messageId: string, labelId: string) => Promise<void>;
137
+ removeMessageLabel: (jid: string, messageId: string, labelId: string) => Promise<void>;
138
+ star: (jid: string, messages: {
139
+ id: string;
140
+ fromMe?: boolean;
141
+ }[], star: boolean) => Promise<void>;
142
+ type: "md";
143
+ ws: any;
144
+ ev: import("../Types").BaileysEventEmitter & {
145
+ process(handler: (events: Partial<import("../Types").BaileysEventMap>) => void | Promise<void>): (() => void);
146
+ buffer(): void;
147
+ createBufferedFunction<A extends any[], T>(work: (...args: A) => Promise<T>): ((...args: A) => Promise<T>);
148
+ flush(force?: boolean): boolean;
149
+ isBuffering(): boolean;
150
+ };
151
+ authState: {
152
+ creds: import("../Types").AuthenticationCreds;
153
+ keys: import("../Types").SignalKeyStoreWithTransaction;
154
+ };
155
+ signalRepository: import("../Types").SignalRepository;
156
+ user: import("../Types").Contact | undefined;
157
+ generateMessageTag: () => string;
158
+ query: (node: import("..").BinaryNode, timeoutMs?: number) => Promise<import("..").BinaryNode>;
159
+ waitForMessage: <T>(msgId: string, timeoutMs?: number | undefined) => Promise<T>;
160
+ waitForSocketOpen: () => Promise<void>;
161
+ sendRawMessage: (data: Uint8Array | Buffer) => Promise<void>;
162
+ sendNode: (frame: import("..").BinaryNode) => Promise<void>;
163
+ logout: (msg?: string) => Promise<void>;
164
+ end: (error: Error | undefined) => void;
165
+ onUnexpectedError: (err: Error | Boom, msg: string) => void;
166
+ uploadPreKeys: (count?: number) => Promise<void>;
167
+ uploadPreKeysToServerIfRequired: () => Promise<void>;
168
+ requestPairingCode: (phoneNumber: string, pairCode: string) => Promise<string>;
169
+ waitForConnectionUpdate: (check: (u: Partial<import("../Types").ConnectionState>) => boolean | undefined, timeoutMs?: number) => Promise<void>;
170
+ sendWAMBuffer: (wamBuffer: Buffer) => Promise<import("..").BinaryNode>;
171
+ };
172
+ export default makeWASocket;