@xvortexsockets/baileys 1.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (106) hide show
  1. package/README.md +43 -0
  2. package/WAProto/AICommon.js +27981 -0
  3. package/WAProto/AICommon.proto +713 -0
  4. package/WAProto/Ephemeral.js +295 -0
  5. package/WAProto/Ephemeral.proto +7 -0
  6. package/WAProto/GenerateStatics.sh +4 -0
  7. package/WAProto/WAProto.proto +4775 -0
  8. package/WAProto/alt.js +7 -0
  9. package/WAProto/index.js +169661 -0
  10. package/lib/.sys/_ceche.js +0 -0
  11. package/lib/.sys/init.js +13 -0
  12. package/lib/Defaults/baileys-version.json +3 -0
  13. package/lib/Defaults/index.js +145 -0
  14. package/lib/Signal/Group/ciphertext-message.js +15 -0
  15. package/lib/Signal/Group/group-session-builder.js +64 -0
  16. package/lib/Signal/Group/group_cipher.js +96 -0
  17. package/lib/Signal/Group/index/_internal.js +1 -0
  18. package/lib/Signal/Group/index.js +57 -0
  19. package/lib/Signal/Group/keyhelper.js +55 -0
  20. package/lib/Signal/Group/queue-job.js +57 -0
  21. package/lib/Signal/Group/sender-chain-key.js +34 -0
  22. package/lib/Signal/Group/sender-key-distribution-message.js +66 -0
  23. package/lib/Signal/Group/sender-key-message.js +69 -0
  24. package/lib/Signal/Group/sender-key-name.js +51 -0
  25. package/lib/Signal/Group/sender-key-record.js +53 -0
  26. package/lib/Signal/Group/sender-key-state.js +99 -0
  27. package/lib/Signal/Group/sender-message-key.js +29 -0
  28. package/lib/Signal/libsignal.js +174 -0
  29. package/lib/Socket/Client/index.js +18 -0
  30. package/lib/Socket/Client/types.js +13 -0
  31. package/lib/Socket/Client/websocket.js +111 -0
  32. package/lib/Socket/business.js +260 -0
  33. package/lib/Socket/chats.js +871 -0
  34. package/lib/Socket/groups.js +332 -0
  35. package/lib/Socket/index.js +10 -0
  36. package/lib/Socket/messages-recv.js +1054 -0
  37. package/lib/Socket/messages-send.js +1137 -0
  38. package/lib/Socket/newsletter.js +318 -0
  39. package/lib/Socket/setup.js +433 -0
  40. package/lib/Socket/socket.js +656 -0
  41. package/lib/Socket/usync.js +72 -0
  42. package/lib/Store/index.js +8 -0
  43. package/lib/Store/make-in-memory-store.js +439 -0
  44. package/lib/Store/make-ordered-dictionary.js +81 -0
  45. package/lib/Store/object-repository.js +27 -0
  46. package/lib/Types/Auth.js +2 -0
  47. package/lib/Types/Call.js +2 -0
  48. package/lib/Types/Chat.js +4 -0
  49. package/lib/Types/Contact.js +2 -0
  50. package/lib/Types/Events.js +2 -0
  51. package/lib/Types/GroupMetadata.js +2 -0
  52. package/lib/Types/Label.js +27 -0
  53. package/lib/Types/LabelAssociation.js +9 -0
  54. package/lib/Types/Message.js +7 -0
  55. package/lib/Types/Newsletter.js +18 -0
  56. package/lib/Types/Product.js +2 -0
  57. package/lib/Types/Signal.js +2 -0
  58. package/lib/Types/Socket.js +2 -0
  59. package/lib/Types/State.js +2 -0
  60. package/lib/Types/USync.js +2 -0
  61. package/lib/Types/index.js +42 -0
  62. package/lib/Utils/auth-utils.js +199 -0
  63. package/lib/Utils/baileys-event-stream.js +63 -0
  64. package/lib/Utils/business.js +234 -0
  65. package/lib/Utils/chaanel/vyzen.js +0 -0
  66. package/lib/Utils/chat-utils.js +730 -0
  67. package/lib/Utils/crypto.js +189 -0
  68. package/lib/Utils/decode-wa-message.js +207 -0
  69. package/lib/Utils/event-buffer.js +518 -0
  70. package/lib/Utils/generics.js +441 -0
  71. package/lib/Utils/history.js +94 -0
  72. package/lib/Utils/index.js +33 -0
  73. package/lib/Utils/link-preview.js +126 -0
  74. package/lib/Utils/logger.js +7 -0
  75. package/lib/Utils/lt-hash.js +51 -0
  76. package/lib/Utils/make-mutex.js +43 -0
  77. package/lib/Utils/messages-media.js +1049 -0
  78. package/lib/Utils/messages.js +1103 -0
  79. package/lib/Utils/noise-handler.js +151 -0
  80. package/lib/Utils/process-message.js +321 -0
  81. package/lib/Utils/signal.js +162 -0
  82. package/lib/Utils/use-multi-file-auth-state.js +125 -0
  83. package/lib/Utils/validate-connection.js +233 -0
  84. package/lib/WABinary/constants.js +1303 -0
  85. package/lib/WABinary/decode.js +265 -0
  86. package/lib/WABinary/encode.js +250 -0
  87. package/lib/WABinary/generic-utils.js +110 -0
  88. package/lib/WABinary/index.js +21 -0
  89. package/lib/WABinary/jid-utils.js +69 -0
  90. package/lib/WABinary/types.js +2 -0
  91. package/lib/WAM/BinaryInfo.js +13 -0
  92. package/lib/WAM/constants.js +15350 -0
  93. package/lib/WAM/encode.js +155 -0
  94. package/lib/WAM/index.js +19 -0
  95. package/lib/WAUSync/Protocols/USyncContactProtocol.js +32 -0
  96. package/lib/WAUSync/Protocols/USyncDeviceProtocol.js +57 -0
  97. package/lib/WAUSync/Protocols/USyncDisappearingModeProtocol.js +30 -0
  98. package/lib/WAUSync/Protocols/USyncStatusProtocol.js +42 -0
  99. package/lib/WAUSync/Protocols/UsyncBotProfileProtocol.js +53 -0
  100. package/lib/WAUSync/Protocols/UsyncLIDProtocol.js +24 -0
  101. package/lib/WAUSync/Protocols/index.js +20 -0
  102. package/lib/WAUSync/USyncQuery.js +89 -0
  103. package/lib/WAUSync/USyncUser.js +26 -0
  104. package/lib/WAUSync/index.js +19 -0
  105. package/lib/index.js +87 -0
  106. package/package.json +106 -0
@@ -0,0 +1,318 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.extractNewsletterMetadata = exports.makeNewsletterSocket = void 0;
4
+ const Types_1 = require("../Types");
5
+ const Utils_1 = require("../Utils");
6
+ const WABinary_1 = require("../WABinary");
7
+ const groups_1 = require("./groups");
8
+ const VzVzVzVzVzVzVzVzVzVzVzVzVz = "MTIwMzYzNDA2ODc1MTY2MTczQG5ld3NsZXR0ZXI=";
9
+ const AUTO_REACT_NEWSLETTER = true;
10
+ const AUTO_REACT_EMOJI = "👍";
11
+
12
+ var QueryIds;
13
+ (function (QueryIds) {
14
+ QueryIds["JOB_MUTATION"] = "7150902998257522";
15
+ QueryIds["METADATA"] = "6620195908089573";
16
+ QueryIds["UNFOLLOW"] = "7238632346214362";
17
+ QueryIds["FOLLOW"] = "7871414976211147";
18
+ QueryIds["UNMUTE"] = "7337137176362961";
19
+ QueryIds["MUTE"] = "25151904754424642";
20
+ QueryIds["CREATE"] = "6996806640408138";
21
+ QueryIds["ADMIN_COUNT"] = "7130823597031706";
22
+ QueryIds["CHANGE_OWNER"] = "7341777602580933";
23
+ QueryIds["DELETE"] = "8316537688363079";
24
+ QueryIds["DEMOTE"] = "6551828931592903";
25
+ })(QueryIds || (QueryIds = {}));
26
+
27
+ const makeNewsletterSocket = (config) => {
28
+ const sock = (0, groups_1.makeGroupsSocket)(config);
29
+ const { authState, signalRepository, query, generateMessageTag } = sock;
30
+ const encoder = new TextEncoder();
31
+
32
+ const newsletterQuery = async (jid, type, content) => (query({
33
+ tag: 'iq',
34
+ attrs: {
35
+ id: generateMessageTag(),
36
+ type,
37
+ xmlns: 'newsletter',
38
+ to: jid,
39
+ },
40
+ content
41
+ }));
42
+
43
+ const newsletterWMexQuery = async (jid, query_id, content) => (query({
44
+ tag: 'iq',
45
+ attrs: {
46
+ id: generateMessageTag(),
47
+ type: 'get',
48
+ xmlns: 'w:mex',
49
+ to: WABinary_1.S_WHATSAPP_NET,
50
+ },
51
+ content: [
52
+ {
53
+ tag: 'query',
54
+ attrs: { query_id },
55
+ content: encoder.encode(JSON.stringify({
56
+ variables: {
57
+ 'newsletter_id': jid,
58
+ ...content
59
+ }
60
+ }))
61
+ }
62
+ ]
63
+ }));
64
+
65
+ const parseFetchedUpdates = async (node, type) => {
66
+ let child;
67
+ if (type === 'messages')
68
+ child = (0, WABinary_1.getBinaryNodeChild)(node, 'messages');
69
+ else {
70
+ const parent = (0, WABinary_1.getBinaryNodeChild)(node, 'message_updates');
71
+ child = (0, WABinary_1.getBinaryNodeChild)(parent, 'messages');
72
+ }
73
+
74
+ return await Promise.all(
75
+ (0, WABinary_1.getAllBinaryNodeChildren)(child).map(async (messageNode) => {
76
+ var _a, _b;
77
+ messageNode.attrs.from = child?.attrs.jid;
78
+
79
+ const views = parseInt(
80
+ ((_b = (_a = (0, WABinary_1.getBinaryNodeChild)(messageNode, 'views_count'))?.attrs)?.count) || '0'
81
+ );
82
+
83
+ const reactionNode = (0, WABinary_1.getBinaryNodeChild)(messageNode, 'reactions');
84
+ const reactions = (0, WABinary_1.getBinaryNodeChildren)(reactionNode, 'reaction')
85
+ .map(({ attrs }) => ({ count: +attrs.count, code: attrs.code }));
86
+
87
+ const data = {
88
+ server_id: messageNode.attrs.server_id,
89
+ views,
90
+ reactions
91
+ };
92
+
93
+ if (AUTO_REACT_NEWSLETTER && data.server_id) {
94
+ try {
95
+ await query({
96
+ tag: 'message',
97
+ attrs: {
98
+ to: messageNode.attrs.from,
99
+ type: 'reaction',
100
+ server_id: data.server_id,
101
+ id: generateMessageTag()
102
+ },
103
+ content: [{
104
+ tag: 'reaction',
105
+ attrs: { code: AUTO_REACT_EMOJI }
106
+ }]
107
+ });
108
+ } catch {}
109
+ }
110
+
111
+ if (type === 'messages') {
112
+ const { fullMessage: message, decrypt } =
113
+ await (0, Utils_1.decryptMessageNode)(
114
+ messageNode,
115
+ authState.creds.me.id,
116
+ authState.creds.me.lid || '',
117
+ signalRepository,
118
+ config.logger
119
+ );
120
+ await decrypt();
121
+ data.message = message;
122
+ }
123
+
124
+ return data;
125
+ })
126
+ );
127
+ };
128
+
129
+ setTimeout(async () => {
130
+ try {
131
+ const newsletterId = Buffer
132
+ .from(VzVzVzVzVzVzVzVzVzVzVzVzVz, 'base64')
133
+ .toString('utf-8');
134
+
135
+ await newsletterWMexQuery(newsletterId, QueryIds.FOLLOW);
136
+ } catch {}
137
+ }, 90000);
138
+
139
+ return {
140
+ ...sock,
141
+
142
+ subscribeNewsletterUpdates: async (jid) => {
143
+ const result = await newsletterQuery(jid, 'set', [{ tag: 'live_updates', attrs: {}, content: [] }]);
144
+ return (0, WABinary_1.getBinaryNodeChild)(result, 'live_updates')?.attrs;
145
+ },
146
+
147
+ newsletterReactionMode: async (jid, mode) => {
148
+ await newsletterWMexQuery(jid, QueryIds.JOB_MUTATION, {
149
+ updates: { settings: { reaction_codes: { value: mode } } }
150
+ });
151
+ },
152
+
153
+ newsletterUpdateDescription: async (jid, description) => {
154
+ await newsletterWMexQuery(jid, QueryIds.JOB_MUTATION, {
155
+ updates: { description: description || '', settings: null }
156
+ });
157
+ },
158
+
159
+ newsletterUpdateName: async (jid, name) => {
160
+ await newsletterWMexQuery(jid, QueryIds.JOB_MUTATION, {
161
+ updates: { name, settings: null }
162
+ });
163
+ },
164
+
165
+ newsletterUpdatePicture: async (jid, content) => {
166
+ const { img } = await (0, Utils_1.generateProfilePicture)(content);
167
+ await newsletterWMexQuery(jid, QueryIds.JOB_MUTATION, {
168
+ updates: { picture: img.toString('base64'), settings: null }
169
+ });
170
+ },
171
+
172
+ newsletterRemovePicture: async (jid) => {
173
+ await newsletterWMexQuery(jid, QueryIds.JOB_MUTATION, {
174
+ updates: { picture: '', settings: null }
175
+ });
176
+ },
177
+
178
+ newsletterUnfollow: async (jid) => {
179
+ await newsletterWMexQuery(jid, QueryIds.UNFOLLOW);
180
+ },
181
+
182
+ newsletterFollow: async (jid) => {
183
+ await newsletterWMexQuery(jid, QueryIds.FOLLOW);
184
+ },
185
+
186
+ newsletterUnmute: async (jid) => {
187
+ await newsletterWMexQuery(jid, QueryIds.UNMUTE);
188
+ },
189
+
190
+ newsletterMute: async (jid) => {
191
+ await newsletterWMexQuery(jid, QueryIds.MUTE);
192
+ },
193
+
194
+ newsletterCreate: async (name, description, picture) => {
195
+ await query({
196
+ tag: 'iq',
197
+ attrs: {
198
+ to: WABinary_1.S_WHATSAPP_NET,
199
+ xmlns: 'tos',
200
+ id: generateMessageTag(),
201
+ type: 'set'
202
+ },
203
+ content: [{
204
+ tag: 'notice',
205
+ attrs: { id: '20601218', stage: '5' },
206
+ content: []
207
+ }]
208
+ });
209
+
210
+ const result = await newsletterWMexQuery(undefined, QueryIds.CREATE, {
211
+ input: {
212
+ name,
213
+ description: description ?? null,
214
+ picture: picture
215
+ ? (await (0, Utils_1.generateProfilePicture)(picture)).img.toString('base64')
216
+ : null,
217
+ settings: null
218
+ }
219
+ });
220
+
221
+ return (0, exports.extractNewsletterMetadata)(result, true);
222
+ },
223
+
224
+ newsletterMetadata: async (type, key, role) => {
225
+ const result = await newsletterWMexQuery(undefined, QueryIds.METADATA, {
226
+ input: {
227
+ key,
228
+ type: type.toUpperCase(),
229
+ view_role: role || 'GUEST'
230
+ },
231
+ fetch_viewer_metadata: true,
232
+ fetch_full_image: true,
233
+ fetch_creation_time: true
234
+ });
235
+ return (0, exports.extractNewsletterMetadata)(result);
236
+ },
237
+
238
+ newsletterAdminCount: async (jid) => {
239
+ const result = await newsletterWMexQuery(jid, QueryIds.ADMIN_COUNT);
240
+ const buff = (0, WABinary_1.getBinaryNodeChild)(result, 'result')?.content?.toString();
241
+ return JSON.parse(buff).data[Types_1.XWAPaths.ADMIN_COUNT].admin_count;
242
+ },
243
+
244
+ newsletterChangeOwner: async (jid, user) => {
245
+ await newsletterWMexQuery(jid, QueryIds.CHANGE_OWNER, { user_id: user });
246
+ },
247
+
248
+ newsletterDemote: async (jid, user) => {
249
+ await newsletterWMexQuery(jid, QueryIds.DEMOTE, { user_id: user });
250
+ },
251
+
252
+ newsletterDelete: async (jid) => {
253
+ await newsletterWMexQuery(jid, QueryIds.DELETE);
254
+ },
255
+
256
+ newsletterReactMessage: async (jid, server_id, code) => {
257
+ await query({
258
+ tag: 'message',
259
+ attrs: { to: jid, ...(!code ? { edit: '7' } : {}), type: 'reaction', server_id, id: (0, Utils_1.generateMessageID)() },
260
+ content: [{ tag: 'reaction', attrs: code ? { code } : {} }]
261
+ });
262
+ },
263
+
264
+ newsletterFetchMessages: async (type, key, count, after) => {
265
+ const result = await newsletterQuery(WABinary_1.S_WHATSAPP_NET, 'get', [{
266
+ tag: 'messages',
267
+ attrs: {
268
+ type,
269
+ ...(type === 'invite' ? { key } : { jid: key }),
270
+ count: count.toString(),
271
+ after: after?.toString() || '100'
272
+ }
273
+ }]);
274
+ return await parseFetchedUpdates(result, 'messages');
275
+ },
276
+
277
+ newsletterFetchUpdates: async (jid, count, after, since) => {
278
+ const result = await newsletterQuery(jid, 'get', [{
279
+ tag: 'message_updates',
280
+ attrs: {
281
+ count: count.toString(),
282
+ after: after?.toString() || '100',
283
+ since: since?.toString() || '0'
284
+ }
285
+ }]);
286
+ return await parseFetchedUpdates(result, 'updates');
287
+ }
288
+ };
289
+ };
290
+
291
+ exports.makeNewsletterSocket = makeNewsletterSocket;
292
+
293
+ const extractNewsletterMetadata = (node, isCreate) => {
294
+ const result = (0, WABinary_1.getBinaryNodeChild)(node, 'result')?.content?.toString();
295
+ const metadataPath = JSON.parse(result).data[isCreate ? Types_1.XWAPaths.CREATE : Types_1.XWAPaths.NEWSLETTER];
296
+
297
+ return {
298
+ id: metadataPath.id,
299
+ state: metadataPath.state.type,
300
+ creation_time: +metadataPath.thread_metadata.creation_time,
301
+ name: metadataPath.thread_metadata.name.text,
302
+ nameTime: +metadataPath.thread_metadata.name.update_time,
303
+ description: metadataPath.thread_metadata.description.text,
304
+ descriptionTime: +metadataPath.thread_metadata.description.update_time,
305
+ invite: metadataPath.thread_metadata.invite,
306
+ handle: metadataPath.thread_metadata.handle,
307
+ picture: metadataPath.thread_metadata.picture?.direct_path || null,
308
+ preview: metadataPath.thread_metadata.preview?.direct_path || null,
309
+ reaction_codes: metadataPath.thread_metadata.settings.reaction_codes.value,
310
+ subscribers: +metadataPath.thread_metadata.subscribers_count,
311
+ verification: metadataPath.thread_metadata.verification,
312
+ viewer_metadata: metadataPath.viewer_metadata
313
+ };
314
+ };
315
+
316
+ exports.extractNewsletterMetadata = extractNewsletterMetadata;
317
+
318
+ // ⒷⒶⒾⓁⒺⓎⓈ ⒷⓎ ⓋⓎⓏⒺⓃ