@badzz88/baileys 7.1.2 → 8.0.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 (102) hide show
  1. package/engine-requirements.js +5 -4
  2. package/lib/Defaults/baileys-version.json +1 -1
  3. package/lib/Defaults/index.d.ts +53 -0
  4. package/lib/Signal/Group/ciphertext-message.d.ts +9 -0
  5. package/lib/Signal/Group/group-session-builder.d.ts +14 -0
  6. package/lib/Signal/Group/group_cipher.d.ts +17 -0
  7. package/lib/Signal/Group/index.d.ts +11 -0
  8. package/lib/Signal/Group/keyhelper.d.ts +10 -0
  9. package/lib/Signal/Group/queue-job.d.ts +1 -0
  10. package/lib/Signal/Group/sender-chain-key.d.ts +13 -0
  11. package/lib/Signal/Group/sender-key-distribution-message.d.ts +16 -0
  12. package/lib/Signal/Group/sender-key-message.d.ts +18 -0
  13. package/lib/Signal/Group/sender-key-name.d.ts +17 -0
  14. package/lib/Signal/Group/sender-key-record.d.ts +30 -0
  15. package/lib/Signal/Group/sender-key-state.d.ts +38 -0
  16. package/lib/Signal/Group/sender-message-key.d.ts +11 -0
  17. package/lib/Signal/libsignal.d.ts +3 -0
  18. package/lib/Socket/Client/abstract-socket-client.d.ts +17 -0
  19. package/lib/Socket/Client/index.d.ts +3 -0
  20. package/lib/Socket/Client/mobile-socket-client.d.ts +13 -0
  21. package/lib/Socket/Client/web-socket-client.d.ts +12 -0
  22. package/lib/Socket/business.d.ts +171 -0
  23. package/lib/Socket/chats.d.ts +267 -0
  24. package/lib/Socket/dugong.d.ts +254 -0
  25. package/lib/Socket/groups.d.ts +115 -0
  26. package/lib/Socket/groups.js +64 -1
  27. package/lib/Socket/index.d.ts +173 -0
  28. package/lib/Socket/messages-recv.d.ts +161 -0
  29. package/lib/Socket/messages-send.d.ts +149 -0
  30. package/lib/Socket/newsletter.d.ts +134 -0
  31. package/lib/Socket/newsletter.js +137 -49
  32. package/lib/Socket/registration.d.ts +267 -0
  33. package/lib/Socket/socket.d.ts +43 -0
  34. package/lib/Socket/usync.d.ts +36 -0
  35. package/lib/Store/index.d.ts +3 -0
  36. package/lib/Store/make-cache-manager-store.d.ts +13 -0
  37. package/lib/Store/make-in-memory-store.d.ts +118 -0
  38. package/lib/Store/make-ordered-dictionary.d.ts +13 -0
  39. package/lib/Store/object-repository.d.ts +10 -0
  40. package/lib/Types/Auth.d.ts +110 -0
  41. package/lib/Types/Call.d.ts +13 -0
  42. package/lib/Types/Chat.d.ts +102 -0
  43. package/lib/Types/Contact.d.ts +19 -0
  44. package/lib/Types/Events.d.ts +157 -0
  45. package/lib/Types/GroupMetadata.d.ts +55 -0
  46. package/lib/Types/Label.d.ts +35 -0
  47. package/lib/Types/LabelAssociation.d.ts +29 -0
  48. package/lib/Types/Message.d.ts +273 -0
  49. package/lib/Types/Newsletter.d.ts +103 -0
  50. package/lib/Types/Product.d.ts +78 -0
  51. package/lib/Types/Signal.d.ts +57 -0
  52. package/lib/Types/Socket.d.ts +111 -0
  53. package/lib/Types/State.d.ts +27 -0
  54. package/lib/Types/USync.d.ts +25 -0
  55. package/lib/Types/index.d.ts +57 -0
  56. package/lib/Utils/auth-utils.d.ts +18 -0
  57. package/lib/Utils/baileys-event-stream.d.ts +16 -0
  58. package/lib/Utils/business.d.ts +22 -0
  59. package/lib/Utils/chat-utils.d.ts +71 -0
  60. package/lib/Utils/crypto.d.ts +41 -0
  61. package/lib/Utils/decode-wa-message.d.ts +19 -0
  62. package/lib/Utils/event-buffer.d.ts +35 -0
  63. package/lib/Utils/generics.d.ts +92 -0
  64. package/lib/Utils/generics.js +80 -5
  65. package/lib/Utils/history.d.ts +15 -0
  66. package/lib/Utils/index.d.ts +17 -0
  67. package/lib/Utils/link-preview.d.ts +21 -0
  68. package/lib/Utils/logger.d.ts +4 -0
  69. package/lib/Utils/lt-hash.d.ts +12 -0
  70. package/lib/Utils/make-mutex.d.ts +7 -0
  71. package/lib/Utils/messages-media.d.ts +116 -0
  72. package/lib/Utils/messages.d.ts +77 -0
  73. package/lib/Utils/noise-handler.d.ts +21 -0
  74. package/lib/Utils/process-message.d.ts +41 -0
  75. package/lib/Utils/signal.d.ts +32 -0
  76. package/lib/Utils/use-multi-file-auth-state.d.ts +13 -0
  77. package/lib/Utils/validate-connection.d.ts +11 -0
  78. package/lib/Utils/validate-connection.js +2 -2
  79. package/lib/WABinary/constants.d.ts +30 -0
  80. package/lib/WABinary/decode.d.ts +7 -0
  81. package/lib/WABinary/encode.d.ts +3 -0
  82. package/lib/WABinary/generic-utils.d.ts +17 -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 +17 -0
  87. package/lib/WAM/constants.d.ts +38 -0
  88. package/lib/WAM/encode.d.ts +3 -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/UsyncBotProfileProtocol.d.ts +25 -0
  95. package/lib/WAUSync/Protocols/UsyncLIDProtocol.d.ts +8 -0
  96. package/lib/WAUSync/Protocols/index.d.ts +4 -0
  97. package/lib/WAUSync/USyncQuery.d.ts +28 -0
  98. package/lib/WAUSync/USyncUser.d.ts +12 -0
  99. package/lib/WAUSync/index.d.ts +3 -0
  100. package/lib/index.d.ts +12 -0
  101. package/lib/index.js +1 -1
  102. package/package.json +109 -102
@@ -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',
@@ -314,4 +378,3 @@ const extractGroupMetadata = (result) => {
314
378
  return metadata;
315
379
  };
316
380
  exports.extractGroupMetadata = extractGroupMetadata;
317
-
@@ -0,0 +1,173 @@
1
+ /// <reference types="node" />
2
+ import { UserFacingSocketConfig } from '../Types';
3
+ declare const makeWASocket: (config: UserFacingSocketConfig) => {
4
+ register: (code: string) => Promise<import("./registration").ExistsResponse>;
5
+ requestRegistrationCode: (registrationOptions?: import("./registration").RegistrationOptions | undefined) => Promise<import("./registration").ExistsResponse>;
6
+ logger: import("pino").Logger<import("pino").LoggerOptions>;
7
+ getOrderDetails: (orderId: string, tokenBase64: string) => Promise<import("../Types").OrderDetails>;
8
+ getCatalog: ({ jid, limit, cursor }: import("../Types").GetCatalogOptions) => Promise<{
9
+ products: import("../Types").Product[];
10
+ nextPageCursor: string | undefined;
11
+ }>;
12
+ getCollections: (jid?: string | undefined, limit?: number) => Promise<{
13
+ collections: import("../Types").CatalogCollection[];
14
+ }>;
15
+ productCreate: (create: import("../Types").ProductCreate) => Promise<import("../Types").Product>;
16
+ productDelete: (productIds: string[]) => Promise<{
17
+ deleted: number;
18
+ }>;
19
+ productUpdate: (productId: string, update: import("../Types").ProductUpdate) => Promise<import("../Types").Product>;
20
+ sendMessageAck: ({ tag, attrs, content }: import("../index").BinaryNode) => Promise<void>;
21
+ sendRetryRequest: (node: import("../index").BinaryNode, forceIncludeKeys?: boolean) => Promise<void>;
22
+ offerCall: (toJid: string, isVideo?: boolean) => Promise<{
23
+ id: string;
24
+ to: string;
25
+ }>;
26
+ rejectCall: (callId: string, callFrom: string) => Promise<void>;
27
+ getPrivacyTokens: (jids: string[]) => Promise<import("../index").BinaryNode>;
28
+ assertSessions: (jids: string[], force: boolean) => Promise<boolean>;
29
+ relayMessage: (jid: string, message: import("../Types").WAProto.IMessage, { messageId: msgId, participant, additionalAttributes, additionalNodes, useUserDevicesCache, cachedGroupMetadata, statusJidList }: import("../Types").MessageRelayOptions) => Promise<string>;
30
+ sendReceipt: (jid: string, participant: string | undefined, messageIds: string[], type: import("../Types").MessageReceiptType) => Promise<void>;
31
+ sendReceipts: (keys: import("../Types").WAProto.IMessageKey[], type: import("../Types").MessageReceiptType) => Promise<void>;
32
+ getButtonArgs: (message: import("../Types").WAProto.IMessage) => {
33
+ [key: string]: string;
34
+ };
35
+ readMessages: (keys: import("../Types").WAProto.IMessageKey[]) => Promise<void>;
36
+ refreshMediaConn: (forceGet?: boolean) => Promise<import("../Types").MediaConnInfo>;
37
+ getUSyncDevices: (jids: string[], useCache: boolean, ignoreZeroDevices: boolean) => Promise<import("../index").JidWithDevice[]>;
38
+ createParticipantNodes: (jids: string[], message: import("../Types").WAProto.IMessage, extraAttrs?: {
39
+ [key: string]: string;
40
+ } | undefined) => Promise<{
41
+ nodes: import("../index").BinaryNode[];
42
+ shouldIncludeDeviceIdentity: boolean;
43
+ }>;
44
+ waUploadToServer: import("../Types").WAMediaUploadFunction;
45
+ fetchPrivacySettings: (force?: boolean) => Promise<{
46
+ [_: string]: string;
47
+ }>;
48
+ updateMediaMessage: (message: import("../Types").WAProto.IWebMessageInfo) => Promise<import("../Types").WAProto.IWebMessageInfo>;
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 | undefined) => 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: "mute" | "follow" | "unfollow" | "unmute") => Promise<void>;
63
+ newsletterCreate: (name: string, description: string, reaction_codes: string) => Promise<import("../Types").NewsletterMetadata>;
64
+ newsletterMetadata: (type: "invite" | "jid", key: string, role?: import("../Types").NewsletterViewRole | undefined) => 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 | undefined) => Promise<void>;
70
+ newsletterFetchMessages: (type: "invite" | "jid", key: string, count: number, after?: number | undefined) => Promise<import("../Types").NewsletterFetchedUpdate[]>;
71
+ newsletterFetchUpdates: (jid: string, count: number, after?: number | undefined, since?: number | undefined) => 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: "reject" | "approve") => 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("../index").BinaryNode;
87
+ }[]>;
88
+ groupUpdateDescription: (jid: string, description?: string | undefined) => 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" | "locked" | "not_announcement" | "unlocked") => Promise<void>;
96
+ groupMemberAddMode: (jid: string, mode: "all_member_add" | "admin_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: () => T | Promise<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 | undefined) => Promise<void>;
107
+ presenceSubscribe: (toJid: string, tcToken?: Buffer | undefined) => Promise<void>;
108
+ profilePictureUrl: (jid: string, type?: "image" | "preview", timeoutMs?: number | undefined) => Promise<string | undefined>;
109
+ onWhatsApp: (...jids: string[]) => Promise<{
110
+ jid: string;
111
+ exists: unknown;
112
+ lid: unknown;
113
+ }[] | undefined>;
114
+ fetchBlocklist: () => Promise<string[]>;
115
+ fetchStatus: (jid: string) => Promise<{
116
+ status: string | undefined;
117
+ setAt: Date;
118
+ } | undefined>;
119
+ updateProfilePicture: (jid: string, content: import("../Types").WAMediaUpload) => Promise<void>;
120
+ removeProfilePicture: (jid: string) => Promise<void>;
121
+ updateProfileStatus: (status: string) => Promise<void>;
122
+ updateProfileName: (name: string) => Promise<void>;
123
+ updateBlockStatus: (jid: string, action: "block" | "unblock") => Promise<void>;
124
+ updateLastSeenPrivacy: (value: import("../Types").WAPrivacyValue) => Promise<void>;
125
+ updateOnlinePrivacy: (value: import("../Types").WAPrivacyOnlineValue) => Promise<void>;
126
+ updateProfilePicturePrivacy: (value: import("../Types").WAPrivacyValue) => Promise<void>;
127
+ updateStatusPrivacy: (value: import("../Types").WAPrivacyValue) => Promise<void>;
128
+ updateReadReceiptsPrivacy: (value: import("../Types").WAReadReceiptsValue) => Promise<void>;
129
+ updateGroupsAddPrivacy: (value: import("../Types").WAPrivacyValue) => Promise<void>;
130
+ updateDefaultDisappearingMode: (duration: number) => Promise<void>;
131
+ getBusinessProfile: (jid: string) => Promise<void | import("../Types").WABusinessProfile>;
132
+ resyncAppState: (collections: readonly ("critical_block" | "critical_unblock_low" | "regular_high" | "regular_low" | "regular")[], isInitialSync: boolean) => Promise<void>;
133
+ chatModify: (mod: import("../Types").ChatModification, jid: string) => Promise<void>;
134
+ cleanDirtyBits: (type: "account_sync" | "groups", fromTimestamp?: string | number | undefined) => Promise<void>;
135
+ addChatLabel: (jid: string, labelId: string) => Promise<void>;
136
+ removeChatLabel: (jid: string, labelId: string) => Promise<void>;
137
+ addMessageLabel: (jid: string, messageId: string, labelId: string) => Promise<void>;
138
+ removeMessageLabel: (jid: string, messageId: string, labelId: string) => Promise<void>;
139
+ star: (jid: string, messages: {
140
+ id: string;
141
+ fromMe?: boolean | undefined;
142
+ }[], star: boolean) => Promise<void>;
143
+ type: "md";
144
+ ws: any;
145
+ ev: import("../Types").BaileysEventEmitter & {
146
+ process(handler: (events: Partial<import("../Types").BaileysEventMap>) => void | Promise<void>): () => void;
147
+ buffer(): void;
148
+ createBufferedFunction<A extends any[], T_1>(work: (...args: A) => Promise<T_1>): (...args: A) => Promise<T_1>;
149
+ flush(force?: boolean | undefined): boolean;
150
+ isBuffering(): boolean;
151
+ };
152
+ authState: {
153
+ creds: import("../Types").AuthenticationCreds;
154
+ keys: import("../Types").SignalKeyStoreWithTransaction;
155
+ };
156
+ signalRepository: import("../Types").SignalRepository;
157
+ user: import("../Types").Contact | undefined;
158
+ generateMessageTag: () => string;
159
+ query: (node: import("../index").BinaryNode, timeoutMs?: number | undefined) => Promise<import("../index").BinaryNode>;
160
+ waitForMessage: <T_2>(msgId: string, timeoutMs?: number | undefined) => Promise<T_2>;
161
+ waitForSocketOpen: () => Promise<void>;
162
+ sendRawMessage: (data: Uint8Array | Buffer) => Promise<void>;
163
+ sendNode: (frame: import("../index").BinaryNode) => Promise<void>;
164
+ logout: (msg?: string | undefined) => Promise<void>;
165
+ end: (error: Error | undefined) => void;
166
+ onUnexpectedError: (err: Error | import("@hapi/boom").Boom<any>, msg: string) => void;
167
+ uploadPreKeys: (count?: number) => Promise<void>;
168
+ uploadPreKeysToServerIfRequired: () => Promise<void>;
169
+ requestPairingCode: (phoneNumber: string) => Promise<string>;
170
+ waitForConnectionUpdate: (check: (u: Partial<import("../Types").ConnectionState>) => boolean | undefined, timeoutMs?: number | undefined) => Promise<void>;
171
+ sendWAMBuffer: (wamBuffer: Buffer) => Promise<import("../index").BinaryNode>;
172
+ };
173
+ export default makeWASocket;
@@ -0,0 +1,161 @@
1
+ import Long = require('long');
2
+ import { Boom } from '@hapi/boom';
3
+ import { proto } from '../../WAProto';
4
+ import { MessageReceiptType, MessageRelayOptions, SocketConfig, WAMessageKey } from '../Types';
5
+ import { BinaryNode } from '../WABinary';
6
+ export declare const makeMessagesRecvSocket: (config: SocketConfig) => {
7
+ sendMessageAck: ({ tag, attrs, content }: BinaryNode, errorCode?: number) => Promise<void>;
8
+ sendRetryRequest: (node: BinaryNode, forceIncludeKeys?: boolean) => Promise<void>;
9
+ rejectCall: (callId: string, callFrom: string) => Promise<void>;
10
+ offerCall: (toJid: string, isVideo?: boolean) => Promise<{
11
+ callId: string;
12
+ toJid: string;
13
+ isVideo: boolean;
14
+ }>;
15
+ fetchMessageHistory: (count: number, oldestMsgKey: WAMessageKey, oldestMsgTimestamp: number | Long) => Promise<string>;
16
+ requestPlaceholderResend: (messageKey: WAMessageKey) => Promise<string | undefined>;
17
+ getPrivacyTokens: (jids: string[]) => Promise<any>;
18
+ assertSessions: (jids: string[], force: boolean) => Promise<boolean>;
19
+ relayMessage: (jid: string, message: proto.IMessage, { messageId: msgId, participant, additionalAttributes, additionalNodes, useUserDevicesCache, useCachedGroupMetadata, statusJidList }: MessageRelayOptions) => Promise<string>;
20
+ sendReceipt: (jid: string, participant: string | undefined, messageIds: string[], type: MessageReceiptType) => Promise<void>;
21
+ sendReceipts: (keys: WAMessageKey[], type: MessageReceiptType) => Promise<void>;
22
+ readMessages: (keys: WAMessageKey[]) => Promise<void>;
23
+ refreshMediaConn: (forceGet?: boolean) => Promise<import("../Types").MediaConnInfo>;
24
+ waUploadToServer: import("../Types").WAMediaUploadFunction;
25
+ fetchPrivacySettings: (force?: boolean) => Promise<{
26
+ [_: string]: string;
27
+ }>;
28
+ getUSyncDevices: (jids: string[], useCache: boolean, ignoreZeroDevices: boolean) => Promise<import("../WABinary").JidWithDevice[]>;
29
+ createParticipantNodes: (jids: string[], message: proto.IMessage, extraAttrs?: BinaryNode["attrs"]) => Promise<{
30
+ nodes: BinaryNode[];
31
+ shouldIncludeDeviceIdentity: boolean;
32
+ }>;
33
+ sendPeerDataOperationMessage: (pdoMessage: proto.Message.IPeerDataOperationRequestMessage) => Promise<string>;
34
+ updateMediaMessage: (message: proto.IWebMessageInfo) => Promise<proto.IWebMessageInfo>;
35
+ sendMessage: (jid: string, content: import("../Types").AnyMessageContent, options?: import("../Types").MiscMessageGenerationOptions) => Promise<proto.WebMessageInfo>;
36
+ subscribeNewsletterUpdates: (jid: string) => Promise<{
37
+ duration: string;
38
+ }>;
39
+ newsletterReactionMode: (jid: string, mode: import("../Types").NewsletterReactionMode) => Promise<void>;
40
+ newsletterUpdateDescription: (jid: string, description?: string) => Promise<void>;
41
+ newsletterUpdateName: (jid: string, name: string) => Promise<void>;
42
+ newsletterUpdatePicture: (jid: string, content: import("../Types").WAMediaUpload) => Promise<void>;
43
+ newsletterRemovePicture: (jid: string) => Promise<void>;
44
+ newsletterUnfollow: (jid: string) => Promise<void>;
45
+ newsletterFollow: (jid: string) => Promise<void>;
46
+ newsletterUnmute: (jid: string) => Promise<void>;
47
+ newsletterMute: (jid: string) => Promise<void>;
48
+ newsletterCreate: (name: string, description?: string, picture?: import("../Types").WAMediaUpload) => Promise<import("../Types").NewsletterMetadata>;
49
+ newsletterMetadata: (type: "invite" | "jid", key: string, role?: import("../Types").NewsletterViewRole) => Promise<import("../Types").NewsletterMetadata>;
50
+ newsletterAdminCount: (jid: string) => Promise<number>;
51
+ newsletterChangeOwner: (jid: string, user: string) => Promise<void>;
52
+ newsletterDemote: (jid: string, user: string) => Promise<void>;
53
+ newsletterDelete: (jid: string) => Promise<void>;
54
+ newsletterReactMessage: (jid: string, server_id: string, code?: string) => Promise<void>;
55
+ newsletterFetchMessages: (type: "invite" | "jid", key: string, count: number, after?: number) => Promise<import("../Types").NewsletterFetchedUpdate[]>;
56
+ newsletterFetchUpdates: (jid: string, count: number, after?: number, since?: number) => Promise<import("../Types").NewsletterFetchedUpdate[]>;
57
+ groupQuery: (jid: string, type: "get" | "set", content: BinaryNode[]) => Promise<any>;
58
+ groupMetadata: (jid: string) => Promise<import("../Types").GroupMetadata>;
59
+ groupCreate: (subject: string, participants: string[]) => Promise<import("../Types").GroupMetadata>;
60
+ groupLeave: (id: string) => Promise<void>;
61
+ groupUpdateSubject: (jid: string, subject: string) => Promise<void>;
62
+ groupRequestParticipantsList: (jid: string) => Promise<{
63
+ [key: string]: string;
64
+ }[]>;
65
+ groupRequestParticipantsUpdate: (jid: string, participants: string[], action: "approve" | "reject") => Promise<{
66
+ status: string;
67
+ jid: string;
68
+ }[]>;
69
+ groupParticipantsUpdate: (jid: string, participants: string[], action: import("../Types").ParticipantAction) => Promise<{
70
+ status: string;
71
+ jid: string;
72
+ content: BinaryNode;
73
+ }[]>;
74
+ groupUpdateDescription: (jid: string, description?: string) => Promise<void>;
75
+ groupInviteCode: (jid: string) => Promise<string | undefined>;
76
+ groupRevokeInvite: (jid: string) => Promise<string | undefined>;
77
+ groupAcceptInvite: (code: string) => Promise<string | undefined>;
78
+ groupRevokeInviteV4: (groupJid: string, invitedJid: string) => Promise<boolean>;
79
+ groupAcceptInviteV4: (key: string | WAMessageKey, inviteMessage: proto.Message.IGroupInviteMessage) => Promise<any>;
80
+ groupGetInviteInfo: (code: string) => Promise<import("../Types").GroupMetadata>;
81
+ groupToggleEphemeral: (jid: string, ephemeralExpiration: number) => Promise<void>;
82
+ groupSettingUpdate: (jid: string, setting: "announcement" | "not_announcement" | "locked" | "unlocked") => Promise<void>;
83
+ groupMemberAddMode: (jid: string, mode: "admin_add" | "all_member_add") => Promise<void>;
84
+ groupJoinApprovalMode: (jid: string, mode: "on" | "off") => Promise<void>;
85
+ groupFetchAllParticipating: () => Promise<{
86
+ [_: string]: import("../Types").GroupMetadata;
87
+ }>;
88
+ getBotListV2: () => Promise<import("../Types").BotListInfo[]>;
89
+ processingMutex: {
90
+ mutex<T>(code: () => Promise<T> | T): Promise<T>;
91
+ };
92
+ upsertMessage: (msg: import("../Types").WAMessage, type: import("../Types").MessageUpsertType) => Promise<void>;
93
+ appPatch: (patchCreate: import("../Types").WAPatchCreate) => Promise<void>;
94
+ sendPresenceUpdate: (type: import("../Types").WAPresence, toJid?: string) => Promise<void>;
95
+ presenceSubscribe: (toJid: string, tcToken?: Buffer) => Promise<void>;
96
+ profilePictureUrl: (jid: string, type?: "preview" | "image", timeoutMs?: number) => Promise<string | undefined>;
97
+ onWhatsApp: (...jids: string[]) => Promise<{
98
+ jid: string;
99
+ exists: unknown;
100
+ lid: unknown;
101
+ }[] | undefined>;
102
+ fetchBlocklist: () => Promise<string[]>;
103
+ fetchDisappearingDuration: (...jids: string[]) => Promise<import("..").USyncQueryResultList[] | undefined>;
104
+ fetchStatus: (...jids: string[]) => Promise<import("..").USyncQueryResultList[] | undefined>;
105
+ updateProfilePicture: (jid: string, content: import("../Types").WAMediaUpload) => Promise<void>;
106
+ removeProfilePicture: (jid: string) => Promise<void>;
107
+ updateProfileStatus: (status: string) => Promise<void>;
108
+ updateProfileName: (name: string) => Promise<void>;
109
+ updateBlockStatus: (jid: string, action: "block" | "unblock") => Promise<void>;
110
+ updateCallPrivacy: (value: import("../Types").WAPrivacyCallValue) => Promise<void>;
111
+ updateMessagesPrivacy: (value: import("../Types").WAPrivacyMessagesValue) => Promise<void>;
112
+ updateLastSeenPrivacy: (value: import("../Types").WAPrivacyValue) => Promise<void>;
113
+ updateOnlinePrivacy: (value: import("../Types").WAPrivacyOnlineValue) => Promise<void>;
114
+ updateProfilePicturePrivacy: (value: import("../Types").WAPrivacyValue) => Promise<void>;
115
+ updateStatusPrivacy: (value: import("../Types").WAPrivacyValue) => Promise<void>;
116
+ updateReadReceiptsPrivacy: (value: import("../Types").WAReadReceiptsValue) => Promise<void>;
117
+ updateGroupsAddPrivacy: (value: import("../Types").WAPrivacyGroupAddValue) => Promise<void>;
118
+ updateDefaultDisappearingMode: (duration: number) => Promise<void>;
119
+ getBusinessProfile: (jid: string) => Promise<import("../Types").WABusinessProfile | void>;
120
+ resyncAppState: (collections: readonly ("critical_unblock_low" | "regular_high" | "regular_low" | "critical_block" | "regular")[], isInitialSync: boolean) => Promise<void>;
121
+ chatModify: (mod: import("../Types").ChatModification, jid: string) => Promise<void>;
122
+ cleanDirtyBits: (type: "account_sync" | "groups", fromTimestamp?: number | string) => Promise<void>;
123
+ addChatLabel: (jid: string, labelId: string) => Promise<void>;
124
+ removeChatLabel: (jid: string, labelId: string) => Promise<void>;
125
+ addMessageLabel: (jid: string, messageId: string, labelId: string) => Promise<void>;
126
+ removeMessageLabel: (jid: string, messageId: string, labelId: string) => Promise<void>;
127
+ star: (jid: string, messages: {
128
+ id: string;
129
+ fromMe?: boolean;
130
+ }[], star: boolean) => Promise<void>;
131
+ executeUSyncQuery: (usyncQuery: import("..").USyncQuery) => Promise<import("..").USyncQueryResult | undefined>;
132
+ type: "md";
133
+ ws: import("./Client").WebSocketClient;
134
+ ev: import("../Types").BaileysEventEmitter & {
135
+ process(handler: (events: Partial<import("../Types").BaileysEventMap>) => void | Promise<void>): (() => void);
136
+ buffer(): void;
137
+ createBufferedFunction<A extends any[], T>(work: (...args: A) => Promise<T>): ((...args: A) => Promise<T>);
138
+ flush(force?: boolean): boolean;
139
+ isBuffering(): boolean;
140
+ };
141
+ authState: {
142
+ creds: import("../Types").AuthenticationCreds;
143
+ keys: import("../Types").SignalKeyStoreWithTransaction;
144
+ };
145
+ signalRepository: import("../Types").SignalRepository;
146
+ user: import("../Types").Contact | undefined;
147
+ generateMessageTag: () => string;
148
+ query: (node: BinaryNode, timeoutMs?: number) => Promise<any>;
149
+ waitForMessage: <T>(msgId: string, timeoutMs?: number | undefined) => Promise<any>;
150
+ waitForSocketOpen: () => Promise<void>;
151
+ sendRawMessage: (data: Uint8Array | Buffer) => Promise<void>;
152
+ sendNode: (frame: BinaryNode) => Promise<void>;
153
+ logout: (msg?: string) => Promise<void>;
154
+ end: (error: Error | undefined) => void;
155
+ onUnexpectedError: (err: Error | Boom, msg: string) => void;
156
+ uploadPreKeys: (count?: number) => Promise<void>;
157
+ uploadPreKeysToServerIfRequired: () => Promise<void>;
158
+ requestPairingCode: (phoneNumber: any, pairKey?: string) => Promise<string>;
159
+ waitForConnectionUpdate: (check: (u: Partial<import("../Types").ConnectionState>) => Promise<boolean | undefined>, timeoutMs?: number) => Promise<void>;
160
+ sendWAMBuffer: (wamBuffer: Buffer) => Promise<any>;
161
+ };
@@ -0,0 +1,149 @@
1
+ /// <reference types="node" />
2
+ import { Boom } from '@hapi/boom';
3
+ import { proto } from '../../WAProto';
4
+ import { AnyMessageContent, MediaConnInfo, MessageReceiptType, MessageRelayOptions, MiscMessageGenerationOptions, SocketConfig, WAMessageKey } from '../Types';
5
+ import { BinaryNode, JidWithDevice } from '../WABinary';
6
+ export declare const makeMessagesSocket: (config: SocketConfig) => {
7
+ getPrivacyTokens: (jids: string[]) => Promise<BinaryNode>;
8
+ assertSessions: (jids: string[], force: boolean) => Promise<boolean>;
9
+ relayMessage: (jid: string, message: proto.IMessage, { messageId, participant, additionalAttributes, additionalNodes, useUserDevicesCache, cachedGroupMetadata, useCachedGroupMetadata, statusJidList }: MessageRelayOptions) => Promise<proto.WebMessageInfo>;
10
+ sendReceipt: (jid: string, participant: string | undefined, messageIds: string[], type: MessageReceiptType) => Promise<void>;
11
+ sendReceipts: (keys: WAMessageKey[], type: MessageReceiptType) => Promise<void>;
12
+ readMessages: (keys: WAMessageKey[]) => Promise<void>;
13
+ refreshMediaConn: (forceGet?: boolean) => Promise<MediaConnInfo>;
14
+ getUSyncDevices: (jids: string[], useCache: boolean, ignoreZeroDevices: boolean) => Promise<JidWithDevice[]>;
15
+ createParticipantNodes: (jids: string[], message: proto.IMessage, extraAttrs?: BinaryNode['attrs']) => Promise<{
16
+ nodes: BinaryNode[];
17
+ shouldIncludeDeviceIdentity: boolean;
18
+ }>;
19
+ waUploadToServer: import("../Types").WAMediaUploadFunction;
20
+ fetchPrivacySettings: (force?: boolean) => Promise<{
21
+ [_: string]: string;
22
+ }>;
23
+ sendPeerDataOperationMessage: (pdoMessage: proto.Message.IPeerDataOperationRequestMessage) => Promise<string>;
24
+ rahmi: any;
25
+ updateMediaMessage: (message: proto.IWebMessageInfo) => Promise<proto.IWebMessageInfo>;
26
+ sendMessage: (jid: string, content: AnyMessageContent, options?: MiscMessageGenerationOptions) => Promise<proto.WebMessageInfo | undefined>;
27
+ subscribeNewsletterUpdates: (jid: string) => Promise<{
28
+ duration: string;
29
+ }>;
30
+ newsletterReactionMode: (jid: string, mode: import("../Types").NewsletterReactionMode) => Promise<void>;
31
+ newsletterUpdateDescription: (jid: string, description?: string | undefined) => Promise<void>;
32
+ newsletterUpdateName: (jid: string, name: string) => Promise<void>;
33
+ newsletterUpdatePicture: (jid: string, content: import("../Types").WAMediaUpload) => Promise<void>;
34
+ newsletterRemovePicture: (jid: string) => Promise<void>;
35
+ newsletterUnfollow: (jid: string) => Promise<void>;
36
+ newsletterFollow: (jid: string) => Promise<void>;
37
+ newsletterUnmute: (jid: string) => Promise<void>;
38
+ newsletterMute: (jid: string) => Promise<void>;
39
+ newsletterAction: (jid: string, type: "mute" | "follow" | "unfollow" | "unmute") => Promise<void>;
40
+ newsletterCreate: (name: string, description: string, reaction_codes: string) => Promise<import("../Types").NewsletterMetadata>;
41
+ newsletterMetadata: (type: "invite" | "jid", key: string, role?: import("../Types").NewsletterViewRole | undefined) => Promise<import("../Types").NewsletterMetadata>;
42
+ newsletterAdminCount: (jid: string) => Promise<number>;
43
+ newsletterChangeOwner: (jid: string, user: string) => Promise<void>;
44
+ newsletterDemote: (jid: string, user: string) => Promise<void>;
45
+ newsletterDelete: (jid: string) => Promise<void>;
46
+ newsletterReactMessage: (jid: string, serverId: string, code?: string | undefined) => Promise<void>;
47
+ newsletterFetchMessages: (type: "invite" | "jid", key: string, count: number, after?: number | undefined) => Promise<import("../Types").NewsletterFetchedUpdate[]>;
48
+ newsletterFetchUpdates: (jid: string, count: number, after?: number | undefined, since?: number | undefined) => Promise<import("../Types").NewsletterFetchedUpdate[]>;
49
+ groupMetadata: (jid: string) => Promise<import("../Types").GroupMetadata>;
50
+ groupCreate: (subject: string, participants: string[]) => Promise<import("../Types").GroupMetadata>;
51
+ groupLeave: (id: string) => Promise<void>;
52
+ groupUpdateSubject: (jid: string, subject: string) => Promise<void>;
53
+ groupRequestParticipantsList: (jid: string) => Promise<{
54
+ [key: string]: string;
55
+ }[]>;
56
+ groupRequestParticipantsUpdate: (jid: string, participants: string[], action: "reject" | "approve") => Promise<{
57
+ status: string;
58
+ jid: string;
59
+ }[]>;
60
+ groupParticipantsUpdate: (jid: string, participants: string[], action: import("../Types").ParticipantAction) => Promise<{
61
+ status: string;
62
+ jid: string;
63
+ content: BinaryNode;
64
+ }[]>;
65
+ groupUpdateDescription: (jid: string, description?: string | undefined) => Promise<void>;
66
+ groupInviteCode: (jid: string) => Promise<string | undefined>;
67
+ groupRevokeInvite: (jid: string) => Promise<string | undefined>;
68
+ groupAcceptInvite: (code: string) => Promise<string | undefined>;
69
+ groupAcceptInviteV4: (key: string | proto.IMessageKey, inviteMessage: proto.Message.IGroupInviteMessage) => Promise<string>;
70
+ groupGetInviteInfo: (code: string) => Promise<import("../Types").GroupMetadata>;
71
+ groupToggleEphemeral: (jid: string, ephemeralExpiration: number) => Promise<void>;
72
+ groupSettingUpdate: (jid: string, setting: "announcement" | "locked" | "not_announcement" | "unlocked") => Promise<void>;
73
+ groupMemberAddMode: (jid: string, mode: "all_member_add" | "admin_add") => Promise<void>;
74
+ groupJoinApprovalMode: (jid: string, mode: "on" | "off") => Promise<void>;
75
+ groupFetchAllParticipating: () => Promise<{
76
+ [_: string]: import("../Types").GroupMetadata;
77
+ }>;
78
+ processingMutex: {
79
+ mutex<T>(code: () => T | Promise<T>): Promise<T>;
80
+ };
81
+ upsertMessage: (msg: proto.IWebMessageInfo, type: import("../Types").MessageUpsertType) => Promise<void>;
82
+ appPatch: (patchCreate: import("../Types").WAPatchCreate) => Promise<void>;
83
+ sendPresenceUpdate: (type: import("../Types").WAPresence, toJid?: string | undefined) => Promise<void>;
84
+ presenceSubscribe: (toJid: string, tcToken?: Buffer | undefined) => Promise<void>;
85
+ profilePictureUrl: (jid: string, type?: "image" | "preview", timeoutMs?: number | undefined) => Promise<string | undefined>;
86
+ onWhatsApp: (...jids: string[]) => Promise<{
87
+ jid: string;
88
+ exists: unknown;
89
+ lid: unknown;
90
+ }[] | undefined>;
91
+ fetchBlocklist: () => Promise<string[]>;
92
+ fetchStatus: (jid: string) => Promise<{
93
+ status: string | undefined;
94
+ setAt: Date;
95
+ } | undefined>;
96
+ updateProfilePicture: (jid: string, content: import("../Types").WAMediaUpload) => Promise<void>;
97
+ removeProfilePicture: (jid: string) => Promise<void>;
98
+ updateProfileStatus: (status: string) => Promise<void>;
99
+ updateProfileName: (name: string) => Promise<void>;
100
+ updateBlockStatus: (jid: string, action: "block" | "unblock") => Promise<void>;
101
+ updateLastSeenPrivacy: (value: import("../Types").WAPrivacyValue) => Promise<void>;
102
+ updateOnlinePrivacy: (value: import("../Types").WAPrivacyOnlineValue) => Promise<void>;
103
+ updateProfilePicturePrivacy: (value: import("../Types").WAPrivacyValue) => Promise<void>;
104
+ updateStatusPrivacy: (value: import("../Types").WAPrivacyValue) => Promise<void>;
105
+ updateReadReceiptsPrivacy: (value: import("../Types").WAReadReceiptsValue) => Promise<void>;
106
+ updateGroupsAddPrivacy: (value: import("../Types").WAPrivacyValue) => Promise<void>;
107
+ updateDefaultDisappearingMode: (duration: number) => Promise<void>;
108
+ getBusinessProfile: (jid: string) => Promise<void | import("../Types").WABusinessProfile>;
109
+ resyncAppState: (collections: readonly ("critical_block" | "critical_unblock_low" | "regular_high" | "regular_low" | "regular")[], isInitialSync: boolean) => Promise<void>;
110
+ chatModify: (mod: import("../Types").ChatModification, jid: string) => Promise<void>;
111
+ cleanDirtyBits: (type: "account_sync" | "groups", fromTimestamp?: string | number | undefined) => Promise<void>;
112
+ addChatLabel: (jid: string, labelId: string) => Promise<void>;
113
+ removeChatLabel: (jid: string, labelId: string) => Promise<void>;
114
+ addMessageLabel: (jid: string, messageId: string, labelId: string) => Promise<void>;
115
+ removeMessageLabel: (jid: string, messageId: string, labelId: string) => Promise<void>;
116
+ star: (jid: string, messages: {
117
+ id: string;
118
+ fromMe?: boolean | undefined;
119
+ }[], star: boolean) => Promise<void>;
120
+ type: "md";
121
+ ws: any;
122
+ ev: import("../Types").BaileysEventEmitter & {
123
+ process(handler: (events: Partial<import("../Types").BaileysEventMap>) => void | Promise<void>): () => void;
124
+ buffer(): void;
125
+ createBufferedFunction<A extends any[], T_1>(work: (...args: A) => Promise<T_1>): (...args: A) => Promise<T_1>;
126
+ flush(force?: boolean | undefined): boolean;
127
+ isBuffering(): boolean;
128
+ };
129
+ authState: {
130
+ creds: import("../Types").AuthenticationCreds;
131
+ keys: import("../Types").SignalKeyStoreWithTransaction;
132
+ };
133
+ signalRepository: import("../Types").SignalRepository;
134
+ user: import("../Types").Contact | undefined;
135
+ generateMessageTag: () => string;
136
+ query: (node: BinaryNode, timeoutMs?: number | undefined) => Promise<BinaryNode>;
137
+ waitForMessage: <T_2>(msgId: string, timeoutMs?: number | undefined) => Promise<T_2>;
138
+ waitForSocketOpen: () => Promise<void>;
139
+ sendRawMessage: (data: Uint8Array | Buffer) => Promise<void>;
140
+ sendNode: (frame: BinaryNode) => Promise<void>;
141
+ logout: (msg?: string | undefined) => Promise<void>;
142
+ end: (error: Error | undefined) => void;
143
+ onUnexpectedError: (err: Error | Boom<any>, msg: string) => void;
144
+ uploadPreKeys: (count?: number) => Promise<void>;
145
+ uploadPreKeysToServerIfRequired: () => Promise<void>;
146
+ requestPairingCode: (phoneNumber: string) => Promise<string>;
147
+ waitForConnectionUpdate: (check: (u: Partial<import("../Types").ConnectionState>) => boolean | undefined, timeoutMs?: number | undefined) => Promise<void>;
148
+ sendWAMBuffer: (wamBuffer: Buffer) => Promise<BinaryNode>;
149
+ };