@queenanya/baileys 6.5.8

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 (149) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +960 -0
  3. package/WAProto/GenerateStatics.sh +4 -0
  4. package/WAProto/WAProto.proto +2879 -0
  5. package/WAProto/index.d.ts +32245 -0
  6. package/WAProto/index.js +87831 -0
  7. package/WASignalGroup/GroupProtocol.js +1697 -0
  8. package/WASignalGroup/ciphertext_message.js +16 -0
  9. package/WASignalGroup/group_cipher.js +120 -0
  10. package/WASignalGroup/group_session_builder.js +46 -0
  11. package/WASignalGroup/index.js +5 -0
  12. package/WASignalGroup/keyhelper.js +21 -0
  13. package/WASignalGroup/protobufs.js +3 -0
  14. package/WASignalGroup/queue_job.js +69 -0
  15. package/WASignalGroup/readme.md +6 -0
  16. package/WASignalGroup/sender_chain_key.js +50 -0
  17. package/WASignalGroup/sender_key_distribution_message.js +78 -0
  18. package/WASignalGroup/sender_key_message.js +92 -0
  19. package/WASignalGroup/sender_key_name.js +70 -0
  20. package/WASignalGroup/sender_key_record.js +56 -0
  21. package/WASignalGroup/sender_key_state.js +129 -0
  22. package/WASignalGroup/sender_message_key.js +39 -0
  23. package/lib/Defaults/baileys-version.json +3 -0
  24. package/lib/Defaults/index.d.ts +283 -0
  25. package/lib/Defaults/index.js +115 -0
  26. package/lib/Defaults/phonenumber-mcc.json +223 -0
  27. package/lib/Signal/libsignal.d.ts +3 -0
  28. package/lib/Signal/libsignal.js +152 -0
  29. package/lib/Socket/Client/abstract-socket-client.d.ts +17 -0
  30. package/lib/Socket/Client/abstract-socket-client.js +13 -0
  31. package/lib/Socket/Client/index.d.ts +3 -0
  32. package/lib/Socket/Client/index.js +19 -0
  33. package/lib/Socket/Client/mobile-socket-client.d.ts +13 -0
  34. package/lib/Socket/Client/mobile-socket-client.js +65 -0
  35. package/lib/Socket/Client/web-socket-client.d.ts +12 -0
  36. package/lib/Socket/Client/web-socket-client.js +62 -0
  37. package/lib/Socket/business.d.ts +126 -0
  38. package/lib/Socket/business.js +259 -0
  39. package/lib/Socket/chats.d.ts +75 -0
  40. package/lib/Socket/chats.js +842 -0
  41. package/lib/Socket/groups.d.ts +107 -0
  42. package/lib/Socket/groups.js +291 -0
  43. package/lib/Socket/index.d.ts +128 -0
  44. package/lib/Socket/index.js +10 -0
  45. package/lib/Socket/messages-recv.d.ts +115 -0
  46. package/lib/Socket/messages-recv.js +725 -0
  47. package/lib/Socket/messages-send.d.ts +112 -0
  48. package/lib/Socket/messages-send.js +660 -0
  49. package/lib/Socket/registration.d.ts +223 -0
  50. package/lib/Socket/registration.js +166 -0
  51. package/lib/Socket/socket.d.ts +42 -0
  52. package/lib/Socket/socket.js +587 -0
  53. package/lib/Store/index.d.ts +3 -0
  54. package/lib/Store/index.js +10 -0
  55. package/lib/Store/make-cache-manager-store.d.ts +14 -0
  56. package/lib/Store/make-cache-manager-store.js +83 -0
  57. package/lib/Store/make-in-memory-store.d.ts +117 -0
  58. package/lib/Store/make-in-memory-store.js +437 -0
  59. package/lib/Store/make-ordered-dictionary.d.ts +13 -0
  60. package/lib/Store/make-ordered-dictionary.js +81 -0
  61. package/lib/Store/object-repository.d.ts +10 -0
  62. package/lib/Store/object-repository.js +27 -0
  63. package/lib/Types/Auth.d.ts +108 -0
  64. package/lib/Types/Auth.js +2 -0
  65. package/lib/Types/Call.d.ts +12 -0
  66. package/lib/Types/Call.js +2 -0
  67. package/lib/Types/Chat.d.ts +102 -0
  68. package/lib/Types/Chat.js +4 -0
  69. package/lib/Types/Contact.d.ts +18 -0
  70. package/lib/Types/Contact.js +2 -0
  71. package/lib/Types/Events.d.ts +152 -0
  72. package/lib/Types/Events.js +2 -0
  73. package/lib/Types/GroupMetadata.d.ts +44 -0
  74. package/lib/Types/GroupMetadata.js +2 -0
  75. package/lib/Types/Label.d.ts +35 -0
  76. package/lib/Types/Label.js +27 -0
  77. package/lib/Types/LabelAssociation.d.ts +29 -0
  78. package/lib/Types/LabelAssociation.js +9 -0
  79. package/lib/Types/Message.d.ts +255 -0
  80. package/lib/Types/Message.js +9 -0
  81. package/lib/Types/Product.d.ts +78 -0
  82. package/lib/Types/Product.js +2 -0
  83. package/lib/Types/Signal.d.ts +57 -0
  84. package/lib/Types/Signal.js +2 -0
  85. package/lib/Types/Socket.d.ts +109 -0
  86. package/lib/Types/Socket.js +2 -0
  87. package/lib/Types/State.d.ts +27 -0
  88. package/lib/Types/State.js +2 -0
  89. package/lib/Types/index.d.ts +54 -0
  90. package/lib/Types/index.js +39 -0
  91. package/lib/Utils/auth-utils.d.ts +18 -0
  92. package/lib/Utils/auth-utils.js +204 -0
  93. package/lib/Utils/baileys-event-stream.d.ts +16 -0
  94. package/lib/Utils/baileys-event-stream.js +63 -0
  95. package/lib/Utils/business.d.ts +22 -0
  96. package/lib/Utils/business.js +234 -0
  97. package/lib/Utils/chat-utils.d.ts +71 -0
  98. package/lib/Utils/chat-utils.js +710 -0
  99. package/lib/Utils/crypto.d.ts +41 -0
  100. package/lib/Utils/crypto.js +151 -0
  101. package/lib/Utils/decode-wa-message.d.ts +19 -0
  102. package/lib/Utils/decode-wa-message.js +160 -0
  103. package/lib/Utils/event-buffer.d.ts +35 -0
  104. package/lib/Utils/event-buffer.js +514 -0
  105. package/lib/Utils/generics.d.ts +93 -0
  106. package/lib/Utils/generics.js +366 -0
  107. package/lib/Utils/history.d.ts +15 -0
  108. package/lib/Utils/history.js +91 -0
  109. package/lib/Utils/index.d.ts +17 -0
  110. package/lib/Utils/index.js +33 -0
  111. package/lib/Utils/link-preview.d.ts +21 -0
  112. package/lib/Utils/link-preview.js +93 -0
  113. package/lib/Utils/logger.d.ts +4 -0
  114. package/lib/Utils/logger.js +7 -0
  115. package/lib/Utils/lt-hash.d.ts +12 -0
  116. package/lib/Utils/lt-hash.js +51 -0
  117. package/lib/Utils/make-mutex.d.ts +7 -0
  118. package/lib/Utils/make-mutex.js +43 -0
  119. package/lib/Utils/messages-media.d.ts +107 -0
  120. package/lib/Utils/messages-media.js +680 -0
  121. package/lib/Utils/messages.d.ts +76 -0
  122. package/lib/Utils/messages.js +762 -0
  123. package/lib/Utils/noise-handler.d.ts +20 -0
  124. package/lib/Utils/noise-handler.js +142 -0
  125. package/lib/Utils/process-message.d.ts +41 -0
  126. package/lib/Utils/process-message.js +297 -0
  127. package/lib/Utils/signal.d.ts +32 -0
  128. package/lib/Utils/signal.js +151 -0
  129. package/lib/Utils/use-multi-file-auth-state.d.ts +12 -0
  130. package/lib/Utils/use-multi-file-auth-state.js +80 -0
  131. package/lib/Utils/validate-connection.d.ts +11 -0
  132. package/lib/Utils/validate-connection.js +187 -0
  133. package/lib/WABinary/constants.d.ts +27 -0
  134. package/lib/WABinary/constants.js +40 -0
  135. package/lib/WABinary/decode.d.ts +7 -0
  136. package/lib/WABinary/decode.js +252 -0
  137. package/lib/WABinary/encode.d.ts +3 -0
  138. package/lib/WABinary/encode.js +228 -0
  139. package/lib/WABinary/generic-utils.d.ts +15 -0
  140. package/lib/WABinary/generic-utils.js +110 -0
  141. package/lib/WABinary/index.d.ts +5 -0
  142. package/lib/WABinary/index.js +21 -0
  143. package/lib/WABinary/jid-utils.d.ts +27 -0
  144. package/lib/WABinary/jid-utils.js +56 -0
  145. package/lib/WABinary/types.d.ts +18 -0
  146. package/lib/WABinary/types.js +2 -0
  147. package/lib/index.d.ts +10 -0
  148. package/lib/index.js +29 -0
  149. package/package.json +113 -0
@@ -0,0 +1,107 @@
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
+ groupFetchAllParticipating: () => Promise<{
36
+ [_: string]: GroupMetadata;
37
+ }>;
38
+ processingMutex: {
39
+ mutex<T>(code: () => T | Promise<T>): Promise<T>;
40
+ };
41
+ fetchPrivacySettings: (force?: boolean) => Promise<{
42
+ [_: string]: string;
43
+ }>;
44
+ upsertMessage: (msg: proto.IWebMessageInfo, type: import("../Types").MessageUpsertType) => Promise<void>;
45
+ appPatch: (patchCreate: import("../Types").WAPatchCreate) => Promise<void>;
46
+ sendPresenceUpdate: (type: import("../Types").WAPresence, toJid?: string | undefined) => Promise<void>;
47
+ presenceSubscribe: (toJid: string, tcToken?: Buffer | undefined) => Promise<void>;
48
+ profilePictureUrl: (jid: string, type?: "image" | "preview", timeoutMs?: number | undefined) => Promise<string | undefined>;
49
+ onWhatsApp: (...jids: string[]) => Promise<{
50
+ exists: boolean;
51
+ jid: string;
52
+ }[]>;
53
+ fetchBlocklist: () => Promise<string[]>;
54
+ fetchStatus: (jid: string) => Promise<{
55
+ status: string | undefined;
56
+ setAt: Date;
57
+ } | undefined>;
58
+ updateProfilePicture: (jid: string, content: import("../Types").WAMediaUpload) => Promise<void>;
59
+ removeProfilePicture: (jid: string) => Promise<void>;
60
+ updateProfileStatus: (status: string) => Promise<void>;
61
+ updateProfileName: (name: string) => Promise<void>;
62
+ updateBlockStatus: (jid: string, action: "block" | "unblock") => Promise<void>;
63
+ updateLastSeenPrivacy: (value: import("../Types").WAPrivacyValue) => Promise<void>;
64
+ updateOnlinePrivacy: (value: import("../Types").WAPrivacyOnlineValue) => Promise<void>;
65
+ updateProfilePicturePrivacy: (value: import("../Types").WAPrivacyValue) => Promise<void>;
66
+ updateStatusPrivacy: (value: import("../Types").WAPrivacyValue) => Promise<void>;
67
+ updateReadReceiptsPrivacy: (value: import("../Types").WAReadReceiptsValue) => Promise<void>;
68
+ updateGroupsAddPrivacy: (value: import("../Types").WAPrivacyValue) => Promise<void>;
69
+ updateDefaultDisappearingMode: (duration: number) => Promise<void>;
70
+ getBusinessProfile: (jid: string) => Promise<void | import("../Types").WABusinessProfile>;
71
+ resyncAppState: (collections: readonly ("critical_block" | "critical_unblock_low" | "regular_high" | "regular_low" | "regular")[], isInitialSync: boolean) => Promise<void>;
72
+ chatModify: (mod: import("../Types").ChatModification, jid: string) => Promise<void>;
73
+ cleanDirtyBits: (type: "account_sync" | "groups", fromTimestamp?: string | number | undefined) => Promise<void>;
74
+ addChatLabel: (jid: string, labelId: string) => Promise<void>;
75
+ removeChatLabel: (jid: string, labelId: string) => Promise<void>;
76
+ addMessageLabel: (jid: string, messageId: string, labelId: string) => Promise<void>;
77
+ removeMessageLabel: (jid: string, messageId: string, labelId: string) => Promise<void>;
78
+ type: "md";
79
+ ws: any;
80
+ ev: import("../Types").BaileysEventEmitter & {
81
+ process(handler: (events: Partial<import("../Types").BaileysEventMap>) => void | Promise<void>): () => void;
82
+ buffer(): void;
83
+ createBufferedFunction<A extends any[], T_1>(work: (...args: A) => Promise<T_1>): (...args: A) => Promise<T_1>;
84
+ flush(force?: boolean | undefined): boolean;
85
+ isBuffering(): boolean;
86
+ };
87
+ authState: {
88
+ creds: import("../Types").AuthenticationCreds;
89
+ keys: import("../Types").SignalKeyStoreWithTransaction;
90
+ };
91
+ signalRepository: import("../Types").SignalRepository;
92
+ user: import("../Types").Contact | undefined;
93
+ generateMessageTag: () => string;
94
+ query: (node: BinaryNode, timeoutMs?: number | undefined) => Promise<BinaryNode>;
95
+ waitForMessage: <T_2>(msgId: string, timeoutMs?: number | undefined) => Promise<T_2>;
96
+ waitForSocketOpen: () => Promise<void>;
97
+ sendRawMessage: (data: Uint8Array | Buffer) => Promise<void>;
98
+ sendNode: (frame: BinaryNode) => Promise<void>;
99
+ logout: (msg?: string | undefined) => Promise<void>;
100
+ end: (error: Error | undefined) => void;
101
+ onUnexpectedError: (err: Error | import("@hapi/boom").Boom<any>, msg: string) => void;
102
+ uploadPreKeys: (count?: number) => Promise<void>;
103
+ uploadPreKeysToServerIfRequired: () => Promise<void>;
104
+ requestPairingCode: (phoneNumber: string) => Promise<string>;
105
+ waitForConnectionUpdate: (check: (u: Partial<import("../Types").ConnectionState>) => boolean | undefined, timeoutMs?: number | undefined) => Promise<void>;
106
+ };
107
+ export declare const extractGroupMetadata: (result: BinaryNode) => GroupMetadata;
@@ -0,0 +1,291 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.extractGroupMetadata = exports.makeGroupsSocket = void 0;
4
+ const WAProto_1 = require("../../WAProto");
5
+ const Types_1 = require("../Types");
6
+ const Utils_1 = require("../Utils");
7
+ const WABinary_1 = require("../WABinary");
8
+ const chats_1 = require("./chats");
9
+ const makeGroupsSocket = (config) => {
10
+ const sock = (0, chats_1.makeChatsSocket)(config);
11
+ const { authState, ev, query, upsertMessage } = sock;
12
+ const groupQuery = async (jid, type, content) => (query({
13
+ tag: 'iq',
14
+ attrs: {
15
+ type,
16
+ xmlns: 'w:g2',
17
+ to: jid,
18
+ },
19
+ content
20
+ }));
21
+ const groupMetadata = async (jid) => {
22
+ const result = await groupQuery(jid, 'get', [{ tag: 'query', attrs: { request: 'interactive' } }]);
23
+ return (0, exports.extractGroupMetadata)(result);
24
+ };
25
+ const groupFetchAllParticipating = async () => {
26
+ const result = await query({
27
+ tag: 'iq',
28
+ attrs: {
29
+ to: '@g.us',
30
+ xmlns: 'w:g2',
31
+ type: 'get',
32
+ },
33
+ content: [
34
+ {
35
+ tag: 'participating',
36
+ attrs: {},
37
+ content: [
38
+ { tag: 'participants', attrs: {} },
39
+ { tag: 'description', attrs: {} }
40
+ ]
41
+ }
42
+ ]
43
+ });
44
+ const data = {};
45
+ const groupsChild = (0, WABinary_1.getBinaryNodeChild)(result, 'groups');
46
+ if (groupsChild) {
47
+ const groups = (0, WABinary_1.getBinaryNodeChildren)(groupsChild, 'group');
48
+ for (const groupNode of groups) {
49
+ const meta = (0, exports.extractGroupMetadata)({
50
+ tag: 'result',
51
+ attrs: {},
52
+ content: [groupNode]
53
+ });
54
+ data[meta.id] = meta;
55
+ }
56
+ }
57
+ sock.ev.emit('groups.update', Object.values(data));
58
+ return data;
59
+ };
60
+ sock.ws.on('CB:ib,,dirty', async (node) => {
61
+ const { attrs } = (0, WABinary_1.getBinaryNodeChild)(node, 'dirty');
62
+ if (attrs.type !== 'groups') {
63
+ return;
64
+ }
65
+ await groupFetchAllParticipating();
66
+ await sock.cleanDirtyBits('groups');
67
+ });
68
+ return {
69
+ ...sock,
70
+ groupMetadata,
71
+ groupCreate: async (subject, participants) => {
72
+ const key = (0, Utils_1.generateMessageID)();
73
+ const result = await groupQuery('@g.us', 'set', [
74
+ {
75
+ tag: 'create',
76
+ attrs: {
77
+ subject,
78
+ key
79
+ },
80
+ content: participants.map(jid => ({
81
+ tag: 'participant',
82
+ attrs: { jid }
83
+ }))
84
+ }
85
+ ]);
86
+ return (0, exports.extractGroupMetadata)(result);
87
+ },
88
+ groupLeave: async (id) => {
89
+ await groupQuery('@g.us', 'set', [
90
+ {
91
+ tag: 'leave',
92
+ attrs: {},
93
+ content: [
94
+ { tag: 'group', attrs: { id } }
95
+ ]
96
+ }
97
+ ]);
98
+ },
99
+ groupUpdateSubject: async (jid, subject) => {
100
+ await groupQuery(jid, 'set', [
101
+ {
102
+ tag: 'subject',
103
+ attrs: {},
104
+ content: Buffer.from(subject, 'utf-8')
105
+ }
106
+ ]);
107
+ },
108
+ groupRequestParticipantsList: async (jid) => {
109
+ const result = await groupQuery(jid, 'get', [
110
+ {
111
+ tag: 'membership_approval_requests',
112
+ attrs: {}
113
+ }
114
+ ]);
115
+ const node = (0, WABinary_1.getBinaryNodeChild)(result, 'membership_approval_requests');
116
+ const participants = (0, WABinary_1.getBinaryNodeChildren)(node, 'membership_approval_request');
117
+ return participants.map(v => v.attrs);
118
+ },
119
+ groupRequestParticipantsUpdate: async (jid, participants, action) => {
120
+ const result = await groupQuery(jid, 'set', [{
121
+ tag: 'membership_requests_action',
122
+ attrs: {},
123
+ content: [
124
+ {
125
+ tag: action,
126
+ attrs: {},
127
+ content: participants.map(jid => ({
128
+ tag: 'participant',
129
+ attrs: { jid }
130
+ }))
131
+ }
132
+ ]
133
+ }]);
134
+ const node = (0, WABinary_1.getBinaryNodeChild)(result, 'membership_requests_action');
135
+ const nodeAction = (0, WABinary_1.getBinaryNodeChild)(node, action);
136
+ const participantsAffected = (0, WABinary_1.getBinaryNodeChildren)(nodeAction, 'participant');
137
+ return participantsAffected.map(p => {
138
+ return { status: p.attrs.error || '200', jid: p.attrs.jid };
139
+ });
140
+ },
141
+ groupParticipantsUpdate: async (jid, participants, action) => {
142
+ const result = await groupQuery(jid, 'set', [
143
+ {
144
+ tag: action,
145
+ attrs: {},
146
+ content: participants.map(jid => ({
147
+ tag: 'participant',
148
+ attrs: { jid }
149
+ }))
150
+ }
151
+ ]);
152
+ const node = (0, WABinary_1.getBinaryNodeChild)(result, action);
153
+ const participantsAffected = (0, WABinary_1.getBinaryNodeChildren)(node, 'participant');
154
+ return participantsAffected.map(p => {
155
+ return { status: p.attrs.error || '200', jid: p.attrs.jid, content: p };
156
+ });
157
+ },
158
+ groupUpdateDescription: async (jid, description) => {
159
+ var _a;
160
+ const metadata = await groupMetadata(jid);
161
+ const prev = (_a = metadata.descId) !== null && _a !== void 0 ? _a : null;
162
+ await groupQuery(jid, 'set', [
163
+ {
164
+ tag: 'description',
165
+ attrs: {
166
+ ...(description ? { id: (0, Utils_1.generateMessageID)() } : { delete: 'true' }),
167
+ ...(prev ? { prev } : {})
168
+ },
169
+ content: description ? [
170
+ { tag: 'body', attrs: {}, content: Buffer.from(description, 'utf-8') }
171
+ ] : undefined
172
+ }
173
+ ]);
174
+ },
175
+ groupInviteCode: async (jid) => {
176
+ const result = await groupQuery(jid, 'get', [{ tag: 'invite', attrs: {} }]);
177
+ const inviteNode = (0, WABinary_1.getBinaryNodeChild)(result, 'invite');
178
+ return inviteNode === null || inviteNode === void 0 ? void 0 : inviteNode.attrs.code;
179
+ },
180
+ groupRevokeInvite: async (jid) => {
181
+ const result = await groupQuery(jid, 'set', [{ tag: 'invite', attrs: {} }]);
182
+ const inviteNode = (0, WABinary_1.getBinaryNodeChild)(result, 'invite');
183
+ return inviteNode === null || inviteNode === void 0 ? void 0 : inviteNode.attrs.code;
184
+ },
185
+ groupAcceptInvite: async (code) => {
186
+ const results = await groupQuery('@g.us', 'set', [{ tag: 'invite', attrs: { code } }]);
187
+ const result = (0, WABinary_1.getBinaryNodeChild)(results, 'group');
188
+ return result === null || result === void 0 ? void 0 : result.attrs.jid;
189
+ },
190
+ /**
191
+ * accept a GroupInviteMessage
192
+ * @param key the key of the invite message, or optionally only provide the jid of the person who sent the invite
193
+ * @param inviteMessage the message to accept
194
+ */
195
+ groupAcceptInviteV4: ev.createBufferedFunction(async (key, inviteMessage) => {
196
+ key = typeof key === 'string' ? { remoteJid: key } : key;
197
+ const results = await groupQuery(inviteMessage.groupJid, 'set', [{
198
+ tag: 'accept',
199
+ attrs: {
200
+ code: inviteMessage.inviteCode,
201
+ expiration: inviteMessage.inviteExpiration.toString(),
202
+ admin: key.remoteJid
203
+ }
204
+ }]);
205
+ // if we have the full message key
206
+ // update the invite message to be expired
207
+ if (key.id) {
208
+ // create new invite message that is expired
209
+ inviteMessage = WAProto_1.proto.Message.GroupInviteMessage.fromObject(inviteMessage);
210
+ inviteMessage.inviteExpiration = 0;
211
+ inviteMessage.inviteCode = '';
212
+ ev.emit('messages.update', [
213
+ {
214
+ key,
215
+ update: {
216
+ message: {
217
+ groupInviteMessage: inviteMessage
218
+ }
219
+ }
220
+ }
221
+ ]);
222
+ }
223
+ // generate the group add message
224
+ await upsertMessage({
225
+ key: {
226
+ remoteJid: inviteMessage.groupJid,
227
+ id: (0, Utils_1.generateMessageID)(),
228
+ fromMe: false,
229
+ participant: key.remoteJid,
230
+ },
231
+ messageStubType: Types_1.WAMessageStubType.GROUP_PARTICIPANT_ADD,
232
+ messageStubParameters: [
233
+ authState.creds.me.id
234
+ ],
235
+ participant: key.remoteJid,
236
+ messageTimestamp: (0, Utils_1.unixTimestampSeconds)()
237
+ }, 'notify');
238
+ return results.attrs.from;
239
+ }),
240
+ groupGetInviteInfo: async (code) => {
241
+ const results = await groupQuery('@g.us', 'get', [{ tag: 'invite', attrs: { code } }]);
242
+ return (0, exports.extractGroupMetadata)(results);
243
+ },
244
+ groupToggleEphemeral: async (jid, ephemeralExpiration) => {
245
+ const content = ephemeralExpiration ?
246
+ { tag: 'ephemeral', attrs: { expiration: ephemeralExpiration.toString() } } :
247
+ { tag: 'not_ephemeral', attrs: {} };
248
+ await groupQuery(jid, 'set', [content]);
249
+ },
250
+ groupSettingUpdate: async (jid, setting) => {
251
+ await groupQuery(jid, 'set', [{ tag: setting, attrs: {} }]);
252
+ },
253
+ groupFetchAllParticipating
254
+ };
255
+ };
256
+ exports.makeGroupsSocket = makeGroupsSocket;
257
+ const extractGroupMetadata = (result) => {
258
+ var _a;
259
+ const group = (0, WABinary_1.getBinaryNodeChild)(result, 'group');
260
+ const descChild = (0, WABinary_1.getBinaryNodeChild)(group, 'description');
261
+ let desc;
262
+ let descId;
263
+ if (descChild) {
264
+ desc = (0, WABinary_1.getBinaryNodeChildString)(descChild, 'body');
265
+ descId = descChild.attrs.id;
266
+ }
267
+ const groupId = group.attrs.id.includes('@') ? group.attrs.id : (0, WABinary_1.jidEncode)(group.attrs.id, 'g.us');
268
+ const eph = (_a = (0, WABinary_1.getBinaryNodeChild)(group, 'ephemeral')) === null || _a === void 0 ? void 0 : _a.attrs.expiration;
269
+ const metadata = {
270
+ id: groupId,
271
+ subject: group.attrs.subject,
272
+ subjectOwner: group.attrs.s_o,
273
+ subjectTime: +group.attrs.s_t,
274
+ size: +group.attrs.size,
275
+ creation: +group.attrs.creation,
276
+ owner: group.attrs.creator ? (0, WABinary_1.jidNormalizedUser)(group.attrs.creator) : undefined,
277
+ desc,
278
+ descId,
279
+ restrict: !!(0, WABinary_1.getBinaryNodeChild)(group, 'locked'),
280
+ announce: !!(0, WABinary_1.getBinaryNodeChild)(group, 'announcement'),
281
+ participants: (0, WABinary_1.getBinaryNodeChildren)(group, 'participant').map(({ attrs }) => {
282
+ return {
283
+ id: attrs.jid,
284
+ admin: (attrs.type || null),
285
+ };
286
+ }),
287
+ ephemeralDuration: eph ? +eph : undefined
288
+ };
289
+ return metadata;
290
+ };
291
+ exports.extractGroupMetadata = extractGroupMetadata;
@@ -0,0 +1,128 @@
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
+ 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: string | undefined;
10
+ }>;
11
+ getCollections: (jid?: string | undefined, 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 }: import("../index").BinaryNode) => Promise<void>;
20
+ sendRetryRequest: (node: import("../index").BinaryNode, forceIncludeKeys?: boolean) => Promise<void>;
21
+ rejectCall: (callId: string, callFrom: string) => Promise<void>;
22
+ getPrivacyTokens: (jids: string[]) => Promise<import("../index").BinaryNode>;
23
+ assertSessions: (jids: string[], force: boolean) => Promise<boolean>;
24
+ relayMessage: (jid: string, message: import("../Types").WAProto.IMessage, { messageId: msgId, participant, additionalAttributes, useUserDevicesCache, cachedGroupMetadata, statusJidList }: import("../Types").MessageRelayOptions) => Promise<string>;
25
+ sendReceipt: (jid: string, participant: string | undefined, messageIds: string[], type: import("../Types").MessageReceiptType) => Promise<void>;
26
+ sendReceipts: (keys: import("../Types").WAProto.IMessageKey[], type: import("../Types").MessageReceiptType) => Promise<void>;
27
+ readMessages: (keys: import("../Types").WAProto.IMessageKey[]) => Promise<void>;
28
+ refreshMediaConn: (forceGet?: boolean) => Promise<import("../Types").MediaConnInfo>;
29
+ waUploadToServer: import("../Types").WAMediaUploadFunction;
30
+ fetchPrivacySettings: (force?: boolean) => Promise<{
31
+ [_: string]: string;
32
+ }>;
33
+ updateMediaMessage: (message: import("../Types").WAProto.IWebMessageInfo) => Promise<import("../Types").WAProto.IWebMessageInfo>;
34
+ sendMessage: (jid: string, content: import("../Types").AnyMessageContent, options?: import("../Types").MiscMessageGenerationOptions) => Promise<import("../Types").WAProto.WebMessageInfo | undefined>;
35
+ groupMetadata: (jid: string) => Promise<import("../Types").GroupMetadata>;
36
+ groupCreate: (subject: string, participants: string[]) => Promise<import("../Types").GroupMetadata>;
37
+ groupLeave: (id: string) => Promise<void>;
38
+ groupUpdateSubject: (jid: string, subject: string) => Promise<void>;
39
+ groupRequestParticipantsList: (jid: string) => Promise<{
40
+ [key: string]: string;
41
+ }[]>;
42
+ groupRequestParticipantsUpdate: (jid: string, participants: string[], action: "reject" | "approve") => Promise<{
43
+ status: string;
44
+ jid: string;
45
+ }[]>;
46
+ groupParticipantsUpdate: (jid: string, participants: string[], action: import("../Types").ParticipantAction) => Promise<{
47
+ status: string;
48
+ jid: string;
49
+ content: import("../index").BinaryNode;
50
+ }[]>;
51
+ groupUpdateDescription: (jid: string, description?: string | undefined) => Promise<void>;
52
+ groupInviteCode: (jid: string) => Promise<string | undefined>;
53
+ groupRevokeInvite: (jid: string) => Promise<string | undefined>;
54
+ groupAcceptInvite: (code: string) => Promise<string | undefined>;
55
+ groupAcceptInviteV4: (key: string | import("../Types").WAProto.IMessageKey, inviteMessage: import("../Types").WAProto.Message.IGroupInviteMessage) => Promise<string>;
56
+ groupGetInviteInfo: (code: string) => Promise<import("../Types").GroupMetadata>;
57
+ groupToggleEphemeral: (jid: string, ephemeralExpiration: number) => Promise<void>;
58
+ groupSettingUpdate: (jid: string, setting: "announcement" | "locked" | "not_announcement" | "unlocked") => Promise<void>;
59
+ groupFetchAllParticipating: () => Promise<{
60
+ [_: string]: import("../Types").GroupMetadata;
61
+ }>;
62
+ processingMutex: {
63
+ mutex<T>(code: () => T | Promise<T>): Promise<T>;
64
+ };
65
+ upsertMessage: (msg: import("../Types").WAProto.IWebMessageInfo, type: import("../Types").MessageUpsertType) => Promise<void>;
66
+ appPatch: (patchCreate: import("../Types").WAPatchCreate) => Promise<void>;
67
+ sendPresenceUpdate: (type: import("../Types").WAPresence, toJid?: string | undefined) => Promise<void>;
68
+ presenceSubscribe: (toJid: string, tcToken?: Buffer | undefined) => Promise<void>;
69
+ profilePictureUrl: (jid: string, type?: "image" | "preview", timeoutMs?: number | undefined) => Promise<string | undefined>;
70
+ onWhatsApp: (...jids: string[]) => Promise<{
71
+ exists: boolean;
72
+ jid: string;
73
+ }[]>;
74
+ fetchBlocklist: () => Promise<string[]>;
75
+ fetchStatus: (jid: string) => Promise<{
76
+ status: string | undefined;
77
+ setAt: Date;
78
+ } | undefined>;
79
+ updateProfilePicture: (jid: string, content: import("../Types").WAMediaUpload) => Promise<void>;
80
+ removeProfilePicture: (jid: string) => Promise<void>;
81
+ updateProfileStatus: (status: string) => Promise<void>;
82
+ updateProfileName: (name: string) => Promise<void>;
83
+ updateBlockStatus: (jid: string, action: "block" | "unblock") => Promise<void>;
84
+ updateLastSeenPrivacy: (value: import("../Types").WAPrivacyValue) => Promise<void>;
85
+ updateOnlinePrivacy: (value: import("../Types").WAPrivacyOnlineValue) => Promise<void>;
86
+ updateProfilePicturePrivacy: (value: import("../Types").WAPrivacyValue) => Promise<void>;
87
+ updateStatusPrivacy: (value: import("../Types").WAPrivacyValue) => Promise<void>;
88
+ updateReadReceiptsPrivacy: (value: import("../Types").WAReadReceiptsValue) => Promise<void>;
89
+ updateGroupsAddPrivacy: (value: import("../Types").WAPrivacyValue) => Promise<void>;
90
+ updateDefaultDisappearingMode: (duration: number) => Promise<void>;
91
+ getBusinessProfile: (jid: string) => Promise<void | import("../Types").WABusinessProfile>;
92
+ resyncAppState: (collections: readonly ("critical_block" | "critical_unblock_low" | "regular_high" | "regular_low" | "regular")[], isInitialSync: boolean) => Promise<void>;
93
+ chatModify: (mod: import("../Types").ChatModification, jid: string) => Promise<void>;
94
+ cleanDirtyBits: (type: "account_sync" | "groups", fromTimestamp?: string | number | undefined) => Promise<void>;
95
+ addChatLabel: (jid: string, labelId: string) => Promise<void>;
96
+ removeChatLabel: (jid: string, labelId: string) => Promise<void>;
97
+ addMessageLabel: (jid: string, messageId: string, labelId: string) => Promise<void>;
98
+ removeMessageLabel: (jid: string, messageId: string, labelId: string) => Promise<void>;
99
+ type: "md";
100
+ ws: any;
101
+ ev: import("../Types").BaileysEventEmitter & {
102
+ process(handler: (events: Partial<import("../Types").BaileysEventMap>) => void | Promise<void>): () => void;
103
+ buffer(): void;
104
+ createBufferedFunction<A extends any[], T_1>(work: (...args: A) => Promise<T_1>): (...args: A) => Promise<T_1>;
105
+ flush(force?: boolean | undefined): boolean;
106
+ isBuffering(): boolean;
107
+ };
108
+ authState: {
109
+ creds: import("../Types").AuthenticationCreds;
110
+ keys: import("../Types").SignalKeyStoreWithTransaction;
111
+ };
112
+ signalRepository: import("../Types").SignalRepository;
113
+ user: import("../Types").Contact | undefined;
114
+ generateMessageTag: () => string;
115
+ query: (node: import("../index").BinaryNode, timeoutMs?: number | undefined) => Promise<import("../index").BinaryNode>;
116
+ waitForMessage: <T_2>(msgId: string, timeoutMs?: number | undefined) => Promise<T_2>;
117
+ waitForSocketOpen: () => Promise<void>;
118
+ sendRawMessage: (data: Uint8Array | Buffer) => Promise<void>;
119
+ sendNode: (frame: import("../index").BinaryNode) => Promise<void>;
120
+ logout: (msg?: string | undefined) => Promise<void>;
121
+ end: (error: Error | undefined) => void;
122
+ onUnexpectedError: (err: Error | import("@hapi/boom").Boom<any>, msg: string) => void;
123
+ uploadPreKeys: (count?: number) => Promise<void>;
124
+ uploadPreKeysToServerIfRequired: () => Promise<void>;
125
+ requestPairingCode: (phoneNumber: string) => Promise<string>;
126
+ waitForConnectionUpdate: (check: (u: Partial<import("../Types").ConnectionState>) => boolean | undefined, timeoutMs?: number | undefined) => Promise<void>;
127
+ };
128
+ export default makeWASocket;
@@ -0,0 +1,10 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ const Defaults_1 = require("../Defaults");
4
+ const registration_1 = require("./registration");
5
+ // export the last socket layer
6
+ const makeWASocket = (config) => ((0, registration_1.makeRegistrationSocket)({
7
+ ...Defaults_1.DEFAULT_CONNECTION_CONFIG,
8
+ ...config
9
+ }));
10
+ exports.default = makeWASocket;
@@ -0,0 +1,115 @@
1
+ /// <reference types="node" />
2
+ import { Boom } from '@hapi/boom';
3
+ import { proto } from '../../WAProto';
4
+ import { MessageReceiptType, MessageRelayOptions, SocketConfig } from '../Types';
5
+ import { BinaryNode } from '../WABinary';
6
+ export declare const makeMessagesRecvSocket: (config: SocketConfig) => {
7
+ sendMessageAck: ({ tag, attrs }: BinaryNode) => Promise<void>;
8
+ sendRetryRequest: (node: BinaryNode, forceIncludeKeys?: boolean) => Promise<void>;
9
+ rejectCall: (callId: string, callFrom: string) => Promise<void>;
10
+ getPrivacyTokens: (jids: string[]) => Promise<BinaryNode>;
11
+ assertSessions: (jids: string[], force: boolean) => Promise<boolean>;
12
+ relayMessage: (jid: string, message: proto.IMessage, { messageId: msgId, participant, additionalAttributes, useUserDevicesCache, cachedGroupMetadata, statusJidList }: MessageRelayOptions) => Promise<string>;
13
+ sendReceipt: (jid: string, participant: string | undefined, messageIds: string[], type: MessageReceiptType) => Promise<void>;
14
+ sendReceipts: (keys: proto.IMessageKey[], type: MessageReceiptType) => Promise<void>;
15
+ readMessages: (keys: proto.IMessageKey[]) => Promise<void>;
16
+ refreshMediaConn: (forceGet?: boolean) => Promise<import("../Types").MediaConnInfo>;
17
+ waUploadToServer: import("../Types").WAMediaUploadFunction;
18
+ fetchPrivacySettings: (force?: boolean) => Promise<{
19
+ [_: string]: string;
20
+ }>;
21
+ updateMediaMessage: (message: proto.IWebMessageInfo) => Promise<proto.IWebMessageInfo>;
22
+ sendMessage: (jid: string, content: import("../Types").AnyMessageContent, options?: import("../Types").MiscMessageGenerationOptions) => Promise<proto.WebMessageInfo | undefined>;
23
+ groupMetadata: (jid: string) => Promise<import("../Types").GroupMetadata>;
24
+ groupCreate: (subject: string, participants: string[]) => Promise<import("../Types").GroupMetadata>;
25
+ groupLeave: (id: string) => Promise<void>;
26
+ groupUpdateSubject: (jid: string, subject: string) => Promise<void>;
27
+ groupRequestParticipantsList: (jid: string) => Promise<{
28
+ [key: string]: string;
29
+ }[]>;
30
+ groupRequestParticipantsUpdate: (jid: string, participants: string[], action: "reject" | "approve") => Promise<{
31
+ status: string;
32
+ jid: string;
33
+ }[]>;
34
+ groupParticipantsUpdate: (jid: string, participants: string[], action: import("../Types").ParticipantAction) => Promise<{
35
+ status: string;
36
+ jid: string;
37
+ content: BinaryNode;
38
+ }[]>;
39
+ groupUpdateDescription: (jid: string, description?: string | undefined) => Promise<void>;
40
+ groupInviteCode: (jid: string) => Promise<string | undefined>;
41
+ groupRevokeInvite: (jid: string) => Promise<string | undefined>;
42
+ groupAcceptInvite: (code: string) => Promise<string | undefined>;
43
+ groupAcceptInviteV4: (key: string | proto.IMessageKey, inviteMessage: proto.Message.IGroupInviteMessage) => Promise<string>;
44
+ groupGetInviteInfo: (code: string) => Promise<import("../Types").GroupMetadata>;
45
+ groupToggleEphemeral: (jid: string, ephemeralExpiration: number) => Promise<void>;
46
+ groupSettingUpdate: (jid: string, setting: "announcement" | "locked" | "not_announcement" | "unlocked") => Promise<void>;
47
+ groupFetchAllParticipating: () => Promise<{
48
+ [_: string]: import("../Types").GroupMetadata;
49
+ }>;
50
+ processingMutex: {
51
+ mutex<T>(code: () => T | Promise<T>): Promise<T>;
52
+ };
53
+ upsertMessage: (msg: proto.IWebMessageInfo, type: import("../Types").MessageUpsertType) => Promise<void>;
54
+ appPatch: (patchCreate: import("../Types").WAPatchCreate) => Promise<void>;
55
+ sendPresenceUpdate: (type: import("../Types").WAPresence, toJid?: string | undefined) => Promise<void>;
56
+ presenceSubscribe: (toJid: string, tcToken?: Buffer | undefined) => Promise<void>;
57
+ profilePictureUrl: (jid: string, type?: "image" | "preview", timeoutMs?: number | undefined) => Promise<string | undefined>;
58
+ onWhatsApp: (...jids: string[]) => Promise<{
59
+ exists: boolean;
60
+ jid: string;
61
+ }[]>;
62
+ fetchBlocklist: () => Promise<string[]>;
63
+ fetchStatus: (jid: string) => Promise<{
64
+ status: string | undefined;
65
+ setAt: Date;
66
+ } | undefined>;
67
+ updateProfilePicture: (jid: string, content: import("../Types").WAMediaUpload) => Promise<void>;
68
+ removeProfilePicture: (jid: string) => Promise<void>;
69
+ updateProfileStatus: (status: string) => Promise<void>;
70
+ updateProfileName: (name: string) => Promise<void>;
71
+ updateBlockStatus: (jid: string, action: "block" | "unblock") => Promise<void>;
72
+ updateLastSeenPrivacy: (value: import("../Types").WAPrivacyValue) => Promise<void>;
73
+ updateOnlinePrivacy: (value: import("../Types").WAPrivacyOnlineValue) => Promise<void>;
74
+ updateProfilePicturePrivacy: (value: import("../Types").WAPrivacyValue) => Promise<void>;
75
+ updateStatusPrivacy: (value: import("../Types").WAPrivacyValue) => Promise<void>;
76
+ updateReadReceiptsPrivacy: (value: import("../Types").WAReadReceiptsValue) => Promise<void>;
77
+ updateGroupsAddPrivacy: (value: import("../Types").WAPrivacyValue) => Promise<void>;
78
+ updateDefaultDisappearingMode: (duration: number) => Promise<void>;
79
+ getBusinessProfile: (jid: string) => Promise<void | import("../Types").WABusinessProfile>;
80
+ resyncAppState: (collections: readonly ("critical_block" | "critical_unblock_low" | "regular_high" | "regular_low" | "regular")[], isInitialSync: boolean) => Promise<void>;
81
+ chatModify: (mod: import("../Types").ChatModification, jid: string) => Promise<void>;
82
+ cleanDirtyBits: (type: "account_sync" | "groups", fromTimestamp?: string | number | undefined) => Promise<void>;
83
+ addChatLabel: (jid: string, labelId: string) => Promise<void>;
84
+ removeChatLabel: (jid: string, labelId: string) => Promise<void>;
85
+ addMessageLabel: (jid: string, messageId: string, labelId: string) => Promise<void>;
86
+ removeMessageLabel: (jid: string, messageId: string, labelId: string) => Promise<void>;
87
+ type: "md";
88
+ ws: any;
89
+ ev: import("../Types").BaileysEventEmitter & {
90
+ process(handler: (events: Partial<import("../Types").BaileysEventMap>) => void | Promise<void>): () => void;
91
+ buffer(): void;
92
+ createBufferedFunction<A extends any[], T_1>(work: (...args: A) => Promise<T_1>): (...args: A) => Promise<T_1>;
93
+ flush(force?: boolean | undefined): boolean;
94
+ isBuffering(): boolean;
95
+ };
96
+ authState: {
97
+ creds: import("../Types").AuthenticationCreds;
98
+ keys: import("../Types").SignalKeyStoreWithTransaction;
99
+ };
100
+ signalRepository: import("../Types").SignalRepository;
101
+ user: import("../Types").Contact | undefined;
102
+ generateMessageTag: () => string;
103
+ query: (node: BinaryNode, timeoutMs?: number | undefined) => Promise<BinaryNode>;
104
+ waitForMessage: <T_2>(msgId: string, timeoutMs?: number | undefined) => Promise<T_2>;
105
+ waitForSocketOpen: () => Promise<void>;
106
+ sendRawMessage: (data: Uint8Array | Buffer) => Promise<void>;
107
+ sendNode: (frame: BinaryNode) => Promise<void>;
108
+ logout: (msg?: string | undefined) => Promise<void>;
109
+ end: (error: Error | undefined) => void;
110
+ onUnexpectedError: (err: Error | Boom<any>, msg: string) => void;
111
+ uploadPreKeys: (count?: number) => Promise<void>;
112
+ uploadPreKeysToServerIfRequired: () => Promise<void>;
113
+ requestPairingCode: (phoneNumber: string) => Promise<string>;
114
+ waitForConnectionUpdate: (check: (u: Partial<import("../Types").ConnectionState>) => boolean | undefined, timeoutMs?: number | undefined) => Promise<void>;
115
+ };