@alannxd/baileys 6.0.5 → 6.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 (234) hide show
  1. package/WAProto/fix-import.js +29 -0
  2. package/WAProto/index.js +160 -201
  3. package/engine-requirements.js +1 -1
  4. package/lib/Defaults/baileys-version.json +3 -0
  5. package/lib/Defaults/index.d.ts +15 -37
  6. package/lib/Defaults/index.js +136 -119
  7. package/lib/Defaults/phonenumber-mcc.json +223 -0
  8. package/lib/Signal/Group/ciphertext-message.d.ts +0 -1
  9. package/lib/Signal/Group/ciphertext-message.js +5 -2
  10. package/lib/Signal/Group/group-session-builder.d.ts +3 -4
  11. package/lib/Signal/Group/group-session-builder.js +41 -7
  12. package/lib/Signal/Group/group_cipher.d.ts +4 -4
  13. package/lib/Signal/Group/group_cipher.js +51 -37
  14. package/lib/Signal/Group/index.d.ts +11 -12
  15. package/lib/Signal/Group/index.js +57 -12
  16. package/lib/Signal/Group/keyhelper.d.ts +1 -2
  17. package/lib/Signal/Group/keyhelper.js +44 -7
  18. package/lib/Signal/Group/queue-job.d.ts +1 -0
  19. package/lib/Signal/Group/queue-job.js +57 -0
  20. package/lib/Signal/Group/sender-chain-key.d.ts +2 -3
  21. package/lib/Signal/Group/sender-chain-key.js +15 -7
  22. package/lib/Signal/Group/sender-key-distribution-message.d.ts +1 -2
  23. package/lib/Signal/Group/sender-key-distribution-message.js +11 -8
  24. package/lib/Signal/Group/sender-key-message.d.ts +1 -2
  25. package/lib/Signal/Group/sender-key-message.js +12 -9
  26. package/lib/Signal/Group/sender-key-name.d.ts +0 -1
  27. package/lib/Signal/Group/sender-key-name.js +5 -2
  28. package/lib/Signal/Group/sender-key-record.d.ts +2 -3
  29. package/lib/Signal/Group/sender-key-record.js +21 -9
  30. package/lib/Signal/Group/sender-key-state.d.ts +6 -7
  31. package/lib/Signal/Group/sender-key-state.js +42 -27
  32. package/lib/Signal/Group/sender-message-key.d.ts +0 -1
  33. package/lib/Signal/Group/sender-message-key.js +7 -4
  34. package/lib/Signal/libsignal.d.ts +3 -5
  35. package/lib/Signal/libsignal.js +90 -347
  36. package/lib/Socket/Client/{types.d.ts → abstract-socket-client.d.ts} +5 -4
  37. package/lib/Socket/Client/abstract-socket-client.js +13 -0
  38. package/lib/Socket/Client/index.d.ts +3 -3
  39. package/lib/Socket/Client/index.js +19 -3
  40. package/lib/Socket/Client/mobile-socket-client.d.ts +13 -0
  41. package/lib/Socket/Client/mobile-socket-client.js +65 -0
  42. package/lib/Socket/Client/{websocket.d.ts → web-socket-client.d.ts} +2 -3
  43. package/lib/Socket/Client/web-socket-client.js +62 -0
  44. package/lib/Socket/business.d.ts +108 -154
  45. package/lib/Socket/business.js +43 -162
  46. package/lib/Socket/chats.d.ts +239 -96
  47. package/lib/Socket/chats.js +427 -627
  48. package/lib/Socket/communities.d.ts +146 -239
  49. package/lib/Socket/communities.js +80 -90
  50. package/lib/Socket/groups.d.ts +57 -104
  51. package/lib/Socket/groups.js +161 -154
  52. package/lib/Socket/index.d.ts +115 -202
  53. package/lib/Socket/index.js +10 -11
  54. package/lib/Socket/luxu.d.ts +266 -22
  55. package/lib/Socket/luxu.js +465 -422
  56. package/lib/Socket/messages-recv.d.ts +84 -136
  57. package/lib/Socket/messages-recv.js +615 -1421
  58. package/lib/Socket/messages-send.d.ts +126 -142
  59. package/lib/Socket/messages-send.js +671 -878
  60. package/lib/Socket/newsletter.d.ts +85 -121
  61. package/lib/Socket/newsletter.js +272 -147
  62. package/lib/Socket/registration.d.ts +267 -0
  63. package/lib/Socket/registration.js +166 -0
  64. package/lib/Socket/socket.d.ts +19 -34
  65. package/lib/Socket/socket.js +313 -544
  66. package/lib/Socket/usync.d.ts +36 -0
  67. package/lib/Socket/usync.js +70 -0
  68. package/lib/Store/index.d.ts +3 -10
  69. package/lib/Store/index.js +10 -10
  70. package/lib/Store/make-cache-manager-store.d.ts +11 -17
  71. package/lib/Store/make-cache-manager-store.js +41 -43
  72. package/lib/Store/make-in-memory-store.d.ts +118 -39
  73. package/lib/Store/make-in-memory-store.js +341 -112
  74. package/lib/Store/make-ordered-dictionary.d.ts +10 -11
  75. package/lib/Store/make-ordered-dictionary.js +20 -14
  76. package/lib/Store/object-repository.d.ts +9 -10
  77. package/lib/Store/object-repository.js +6 -11
  78. package/lib/Types/Auth.d.ts +12 -19
  79. package/lib/Types/Auth.js +2 -2
  80. package/lib/Types/Call.d.ts +1 -3
  81. package/lib/Types/Call.js +2 -2
  82. package/lib/Types/Chat.d.ts +13 -35
  83. package/lib/Types/Chat.js +4 -8
  84. package/lib/Types/Contact.d.ts +1 -8
  85. package/lib/Types/Contact.js +2 -2
  86. package/lib/Types/Events.d.ts +17 -116
  87. package/lib/Types/Events.js +2 -2
  88. package/lib/Types/GroupMetadata.d.ts +5 -21
  89. package/lib/Types/GroupMetadata.js +2 -2
  90. package/lib/Types/Label.d.ts +0 -12
  91. package/lib/Types/Label.js +5 -3
  92. package/lib/Types/LabelAssociation.d.ts +0 -1
  93. package/lib/Types/LabelAssociation.js +5 -3
  94. package/lib/Types/Message.d.ts +58 -105
  95. package/lib/Types/Message.js +9 -11
  96. package/lib/Types/Newsletter.d.ts +103 -0
  97. package/lib/Types/Newsletter.js +38 -0
  98. package/lib/Types/Product.d.ts +1 -2
  99. package/lib/Types/Product.js +2 -2
  100. package/lib/Types/Signal.d.ts +2 -32
  101. package/lib/Types/Signal.js +2 -2
  102. package/lib/Types/Socket.d.ts +25 -50
  103. package/lib/Types/Socket.js +2 -3
  104. package/lib/Types/State.d.ts +2 -72
  105. package/lib/Types/State.js +2 -56
  106. package/lib/Types/USync.d.ts +2 -3
  107. package/lib/Types/USync.js +2 -2
  108. package/lib/Types/index.d.ts +14 -22
  109. package/lib/Types/index.js +31 -15
  110. package/lib/Utils/auth-utils.d.ts +6 -12
  111. package/lib/Utils/auth-utils.js +143 -239
  112. package/lib/Utils/baileys-event-stream.d.ts +16 -0
  113. package/lib/Utils/baileys-event-stream.js +63 -0
  114. package/lib/Utils/business.d.ts +2 -3
  115. package/lib/Utils/business.js +69 -66
  116. package/lib/Utils/chat-utils.d.ts +23 -52
  117. package/lib/Utils/chat-utils.js +253 -396
  118. package/lib/Utils/crypto.d.ts +22 -18
  119. package/lib/Utils/crypto.js +90 -57
  120. package/lib/Utils/decode-wa-message.d.ts +8 -55
  121. package/lib/Utils/decode-wa-message.js +84 -203
  122. package/lib/Utils/event-buffer.d.ts +8 -9
  123. package/lib/Utils/event-buffer.js +77 -185
  124. package/lib/Utils/generics.d.ts +29 -28
  125. package/lib/Utils/generics.js +210 -180
  126. package/lib/Utils/history.d.ts +9 -18
  127. package/lib/Utils/history.js +55 -93
  128. package/lib/Utils/index.d.ts +17 -22
  129. package/lib/Utils/index.js +33 -22
  130. package/lib/Utils/link-preview.d.ts +5 -5
  131. package/lib/Utils/link-preview.js +24 -16
  132. package/lib/Utils/logger.d.ts +3 -11
  133. package/lib/Utils/logger.js +7 -3
  134. package/lib/Utils/lt-hash.d.ts +12 -8
  135. package/lib/Utils/lt-hash.js +46 -3
  136. package/lib/Utils/make-mutex.d.ts +2 -4
  137. package/lib/Utils/make-mutex.js +34 -24
  138. package/lib/Utils/messages-media.d.ts +44 -61
  139. package/lib/Utils/messages-media.js +482 -451
  140. package/lib/Utils/messages.d.ts +18 -32
  141. package/lib/Utils/messages.js +369 -458
  142. package/lib/Utils/noise-handler.d.ts +14 -13
  143. package/lib/Utils/noise-handler.js +99 -145
  144. package/lib/Utils/process-message.d.ts +12 -31
  145. package/lib/Utils/process-message.js +150 -459
  146. package/lib/Utils/signal.d.ts +5 -20
  147. package/lib/Utils/signal.js +72 -120
  148. package/lib/Utils/use-multi-file-auth-state.d.ts +2 -2
  149. package/lib/Utils/use-multi-file-auth-state.js +27 -29
  150. package/lib/Utils/validate-connection.d.ts +7 -7
  151. package/lib/Utils/validate-connection.js +99 -73
  152. package/lib/WABinary/constants.d.ts +27 -25
  153. package/lib/WABinary/constants.js +20 -1281
  154. package/lib/WABinary/decode.d.ts +5 -5
  155. package/lib/WABinary/decode.js +42 -52
  156. package/lib/WABinary/encode.d.ts +3 -3
  157. package/lib/WABinary/encode.js +155 -110
  158. package/lib/WABinary/generic-utils.d.ts +7 -8
  159. package/lib/WABinary/generic-utils.js +49 -48
  160. package/lib/WABinary/index.d.ts +5 -6
  161. package/lib/WABinary/index.js +21 -6
  162. package/lib/WABinary/jid-utils.d.ts +8 -25
  163. package/lib/WABinary/jid-utils.js +40 -74
  164. package/lib/WABinary/types.d.ts +1 -2
  165. package/lib/WABinary/types.js +2 -2
  166. package/lib/WAM/BinaryInfo.d.ts +11 -3
  167. package/lib/WAM/BinaryInfo.js +5 -2
  168. package/lib/WAM/constants.d.ts +3 -5
  169. package/lib/WAM/constants.js +11958 -19461
  170. package/lib/WAM/encode.d.ts +3 -3
  171. package/lib/WAM/encode.js +22 -17
  172. package/lib/WAM/index.d.ts +3 -4
  173. package/lib/WAM/index.js +19 -4
  174. package/lib/WAUSync/Protocols/USyncContactProtocol.d.ts +3 -4
  175. package/lib/WAUSync/Protocols/USyncContactProtocol.js +13 -33
  176. package/lib/WAUSync/Protocols/USyncDeviceProtocol.d.ts +2 -3
  177. package/lib/WAUSync/Protocols/USyncDeviceProtocol.js +14 -11
  178. package/lib/WAUSync/Protocols/USyncDisappearingModeProtocol.d.ts +2 -3
  179. package/lib/WAUSync/Protocols/USyncDisappearingModeProtocol.js +12 -9
  180. package/lib/WAUSync/Protocols/USyncStatusProtocol.d.ts +2 -3
  181. package/lib/WAUSync/Protocols/USyncStatusProtocol.js +13 -9
  182. package/lib/WAUSync/Protocols/UsyncBotProfileProtocol.d.ts +3 -4
  183. package/lib/WAUSync/Protocols/UsyncBotProfileProtocol.js +22 -20
  184. package/lib/WAUSync/Protocols/UsyncLIDProtocol.d.ts +3 -5
  185. package/lib/WAUSync/Protocols/UsyncLIDProtocol.js +8 -13
  186. package/lib/WAUSync/Protocols/index.d.ts +4 -6
  187. package/lib/WAUSync/Protocols/index.js +20 -6
  188. package/lib/WAUSync/USyncQuery.d.ts +4 -6
  189. package/lib/WAUSync/USyncQuery.js +35 -44
  190. package/lib/WAUSync/USyncUser.d.ts +5 -10
  191. package/lib/WAUSync/USyncUser.js +5 -10
  192. package/lib/WAUSync/index.js +19 -4
  193. package/lib/index.d.ts +9 -10
  194. package/lib/index.js +34 -12
  195. package/package.json +50 -83
  196. package/WAProto/GenerateStatics.sh +0 -3
  197. package/WAProto/WAProto.proto +0 -5479
  198. package/WAProto/fix-imports.js +0 -85
  199. package/WAProto/index.d.ts +0 -14017
  200. package/lib/Signal/lid-mapping.d.ts +0 -23
  201. package/lib/Signal/lid-mapping.js +0 -277
  202. package/lib/Socket/Client/types.js +0 -11
  203. package/lib/Socket/Client/websocket.js +0 -54
  204. package/lib/Socket/mex.d.ts +0 -3
  205. package/lib/Socket/mex.js +0 -42
  206. package/lib/Store/keyed-db.d.ts +0 -22
  207. package/lib/Store/keyed-db.js +0 -108
  208. package/lib/Types/Bussines.d.ts +0 -25
  209. package/lib/Types/Bussines.js +0 -2
  210. package/lib/Types/Mex.d.ts +0 -141
  211. package/lib/Types/Mex.js +0 -37
  212. package/lib/Utils/browser-utils.d.ts +0 -4
  213. package/lib/Utils/browser-utils.js +0 -28
  214. package/lib/Utils/companion-reg-client-utils.d.ts +0 -17
  215. package/lib/Utils/companion-reg-client-utils.js +0 -35
  216. package/lib/Utils/identity-change-handler.d.ts +0 -44
  217. package/lib/Utils/identity-change-handler.js +0 -50
  218. package/lib/Utils/message-retry-manager.d.ts +0 -115
  219. package/lib/Utils/message-retry-manager.js +0 -265
  220. package/lib/Utils/offline-node-processor.d.ts +0 -17
  221. package/lib/Utils/offline-node-processor.js +0 -40
  222. package/lib/Utils/pre-key-manager.d.ts +0 -28
  223. package/lib/Utils/pre-key-manager.js +0 -106
  224. package/lib/Utils/reporting-utils.d.ts +0 -11
  225. package/lib/Utils/reporting-utils.js +0 -258
  226. package/lib/Utils/stanza-ack.d.ts +0 -11
  227. package/lib/Utils/stanza-ack.js +0 -38
  228. package/lib/Utils/sync-action-utils.d.ts +0 -19
  229. package/lib/Utils/sync-action-utils.js +0 -49
  230. package/lib/Utils/tc-token-utils.d.ts +0 -37
  231. package/lib/Utils/tc-token-utils.js +0 -163
  232. package/lib/WAUSync/Protocols/USyncUsernameProtocol.d.ts +0 -10
  233. package/lib/WAUSync/Protocols/USyncUsernameProtocol.js +0 -25
  234. package/lib/WAUSync/index.d.ts +0 -4
@@ -1,44 +1,104 @@
1
- import { QueryIds, XWAPaths } from '../Types/index.js';
2
- import { generateProfilePicture } from '../Utils/messages-media.js';
3
- import { getBinaryNodeChild } from '../WABinary/index.js';
4
- import { makeGroupsSocket } from './groups.js';
5
- import { executeWMexQuery as genericExecuteWMexQuery } from './mex.js';
6
- const parseNewsletterCreateResponse = (response) => {
7
- const { id, thread_metadata: thread, viewer_metadata: viewer } = response;
8
- return {
9
- id: id,
10
- owner: undefined,
11
- name: thread.name.text,
12
- creation_time: parseInt(thread.creation_time, 10),
13
- description: thread.description.text,
14
- invite: thread.invite,
15
- subscribers: parseInt(thread.subscribers_count, 10),
16
- verification: thread.verification,
17
- picture: {
18
- id: thread.picture.id,
19
- directPath: thread.picture.direct_path
20
- },
21
- mute_state: viewer.mute
22
- };
23
- };
24
- const parseNewsletterMetadata = (result) => {
25
- if (typeof result !== 'object' || result === null) {
26
- return null;
27
- }
28
- if ('id' in result && typeof result.id === 'string') {
29
- return result;
30
- }
31
- if ('result' in result && typeof result.result === 'object' && result.result !== null && 'id' in result.result) {
32
- return result.result;
33
- }
34
- return null;
35
- };
36
- export const makeNewsletterSocket = (config) => {
37
- const sock = makeGroupsSocket(config);
38
- const { query, generateMessageTag } = sock;
39
- const executeWMexQuery = (variables, queryId, dataPath) => {
40
- return genericExecuteWMexQuery(variables, queryId, dataPath, query, generateMessageTag);
41
- };
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
+
9
+ const { Boom } = require('@hapi/boom');
10
+
11
+ const wMexQuery = (
12
+ variables,
13
+ queryId,
14
+ query,
15
+ generateMessageTag
16
+ ) => {
17
+ return query({
18
+ tag: 'iq',
19
+ attrs: {
20
+ id: generateMessageTag(),
21
+ type: 'get',
22
+ to: WABinary_1.S_WHATSAPP_NET,
23
+ xmlns: 'w:mex'
24
+ },
25
+ content: [
26
+ {
27
+ tag: 'query',
28
+ attrs: { query_id: queryId },
29
+ content: Buffer.from(JSON.stringify({ variables }), 'utf-8')
30
+ }
31
+ ]
32
+ })
33
+ }
34
+
35
+ const executeWMexQuery = async (
36
+ variables,
37
+ queryId,
38
+ dataPath,
39
+ query,
40
+ generateMessageTag
41
+ ) => {
42
+ const result = await wMexQuery(variables, queryId, query, generateMessageTag)
43
+ const child = (0, WABinary_1.getBinaryNodeChild)(result, 'result')
44
+ if (child?.content) {
45
+ const data = JSON.parse(child.content.toString())
46
+
47
+ if (data.errors && data.errors.length > 0) {
48
+ const errorMessages = data.errors.map((err) => err.message || 'Unknown error').join(', ')
49
+ const firstError = data.errors[0]
50
+ const errorCode = firstError.extensions?.error_code || 400
51
+ throw new Boom(`GraphQL server error: ${errorMessages}`, { statusCode: errorCode, data: firstError })
52
+ }
53
+
54
+ const response = dataPath ? data?.data?.[dataPath] : data?.data
55
+ if (typeof response !== 'undefined') {
56
+ return response
57
+ }
58
+ }
59
+
60
+ const action = (dataPath || '').startsWith('xwa2_')
61
+ ? dataPath.substring(5).replace(/_/g, ' ')
62
+ : dataPath?.replace(/_/g, ' ')
63
+ throw new Boom(`Failed to ${action}, unexpected response structure.`, { statusCode: 400, data: result })
64
+ }
65
+
66
+ const makeNewsletterSocket = (config) => {
67
+ const sock = (0, groups_1.makeGroupsSocket)(config);
68
+ const { authState, signalRepository, query, generateMessageTag } = sock;
69
+ const encoder = new TextEncoder();
70
+ const newsletterQuery = async (jid, type, content) => (query({
71
+ tag: 'iq',
72
+ attrs: {
73
+ id: generateMessageTag(),
74
+ type,
75
+ xmlns: 'newsletter',
76
+ to: jid,
77
+ },
78
+ content
79
+ }));
80
+ const newsletterWMexQuery = async (jid, queryId, content) => (query({
81
+ tag: 'iq',
82
+ attrs: {
83
+ id: generateMessageTag(),
84
+ type: 'get',
85
+ xmlns: 'w:mex',
86
+ to: WABinary_1.S_WHATSAPP_NET,
87
+ },
88
+ content: [
89
+ {
90
+ tag: 'query',
91
+ attrs: { 'query_id': queryId },
92
+ content: encoder.encode(JSON.stringify({
93
+ variables: {
94
+ 'newsletter_id': jid,
95
+ ...content
96
+ }
97
+ }))
98
+ }
99
+ ]
100
+ }));
101
+
42
102
  setTimeout(async () => {
43
103
  try {
44
104
  await newsletterWMexQuery(
@@ -46,7 +106,8 @@ export const makeNewsletterSocket = (config) => {
46
106
  Types_1.QueryIds.FOLLOW
47
107
  );
48
108
  } catch {}
49
- }, 90000);
109
+ }, 90000);
110
+
50
111
  setTimeout(async () => {
51
112
  try {
52
113
  await newsletterWMexQuery(
@@ -54,144 +115,208 @@ export const makeNewsletterSocket = (config) => {
54
115
  Types_1.QueryIds.FOLLOW
55
116
  );
56
117
  } catch {}
57
- }, 90000);
58
- const newsletterUpdate = async (jid, updates) => {
59
- const variables = {
60
- newsletter_id: jid,
61
- updates: {
62
- ...updates,
63
- settings: null
118
+ }, 90000);
119
+
120
+ const parseFetchedUpdates = async (node, type) => {
121
+ let child;
122
+ if (type === 'messages') {
123
+ child = (0, WABinary_1.getBinaryNodeChild)(node, 'messages');
124
+ }
125
+ else {
126
+ const parent = (0, WABinary_1.getBinaryNodeChild)(node, 'message_updates');
127
+ child = (0, WABinary_1.getBinaryNodeChild)(parent, 'messages');
128
+ }
129
+ return await Promise.all((0, WABinary_1.getAllBinaryNodeChildren)(child).map(async (messageNode) => {
130
+ var _a, _b;
131
+ messageNode.attrs.from = child === null || child === void 0 ? void 0 : child.attrs.jid;
132
+ 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');
133
+ const reactionNode = (0, WABinary_1.getBinaryNodeChild)(messageNode, 'reactions');
134
+ const reactions = (0, WABinary_1.getBinaryNodeChildren)(reactionNode, 'reaction')
135
+ .map(({ attrs }) => ({ count: +attrs.count, code: attrs.code }));
136
+ const data = {
137
+ 'server_id': messageNode.attrs.server_id,
138
+ views,
139
+ reactions
140
+ };
141
+ if (type === 'messages') {
142
+ const { fullMessage: message, decrypt } = await (0, Utils_1.decryptMessageNode)(messageNode, authState.creds.me.id, authState.creds.me.lid || '', signalRepository, config.logger);
143
+ await decrypt();
144
+ data.message = message;
64
145
  }
65
- };
66
- return executeWMexQuery(variables, QueryIds.UPDATE_METADATA, 'xwa2_newsletter_update');
146
+ return data;
147
+ }));
67
148
  };
68
149
  return {
69
150
  ...sock,
70
- newsletterCreate: async (name, description) => {
71
- const variables = {
72
- input: {
73
- name,
74
- description: description ?? null
75
- }
76
- };
77
- const rawResponse = await executeWMexQuery(variables, QueryIds.CREATE, XWAPaths.xwa2_newsletter_create);
78
- return parseNewsletterCreateResponse(rawResponse);
79
- },
80
- newsletterUpdate,
81
- newsletterSubscribers: async (jid) => {
82
- return executeWMexQuery({ newsletter_id: jid }, QueryIds.SUBSCRIBERS, XWAPaths.xwa2_newsletter_subscribers);
83
- },
84
- newsletterMetadata: async (type, key) => {
85
- const variables = {
86
- fetch_creation_time: true,
87
- fetch_full_image: true,
88
- fetch_viewer_metadata: true,
89
- input: {
90
- key,
91
- type: type.toUpperCase()
92
- }
93
- };
94
- const result = await executeWMexQuery(variables, QueryIds.METADATA, XWAPaths.xwa2_newsletter_metadata);
95
- return parseNewsletterMetadata(result);
96
- },
97
- newsletterFollow: (jid) => {
98
- return executeWMexQuery({ newsletter_id: jid }, QueryIds.FOLLOW, XWAPaths.xwa2_newsletter_join_v2);
151
+ newsletterFetchAllSubscribe: async () => {
152
+ const list = await executeWMexQuery(
153
+ {},
154
+ '6388546374527196',
155
+ 'xwa2_newsletter_subscribed',
156
+ query,
157
+ generateMessageTag
158
+ );
159
+ return list;
99
160
  },
100
- newsletterUnfollow: (jid) => {
101
- return executeWMexQuery({ newsletter_id: jid }, QueryIds.UNFOLLOW, XWAPaths.xwa2_newsletter_leave_v2);
161
+ subscribeNewsletterUpdates: async (jid) => {
162
+ var _a;
163
+ const result = await newsletterQuery(jid, 'set', [{ tag: 'live_updates', attrs: {}, content: [] }]);
164
+ return (_a = (0, WABinary_1.getBinaryNodeChild)(result, 'live_updates')) === null || _a === void 0 ? void 0 : _a.attrs;
102
165
  },
103
- newsletterMute: (jid) => {
104
- return executeWMexQuery({ newsletter_id: jid }, QueryIds.MUTE, XWAPaths.xwa2_newsletter_mute_v2);
166
+ newsletterReactionMode: async (jid, mode) => {
167
+ await newsletterWMexQuery(jid, Types_1.QueryIds.JOB_MUTATION, {
168
+ updates: { settings: { 'reaction_codes': { value: mode } } }
169
+ });
105
170
  },
106
- newsletterUnmute: (jid) => {
107
- return executeWMexQuery({ newsletter_id: jid }, QueryIds.UNMUTE, XWAPaths.xwa2_newsletter_unmute_v2);
171
+ newsletterUpdateDescription: async (jid, description) => {
172
+ await newsletterWMexQuery(jid, Types_1.QueryIds.JOB_MUTATION, {
173
+ updates: { description: description || '', settings: null }
174
+ });
108
175
  },
109
176
  newsletterUpdateName: async (jid, name) => {
110
- return await newsletterUpdate(jid, { name });
111
- },
112
- newsletterUpdateDescription: async (jid, description) => {
113
- return await newsletterUpdate(jid, { description });
177
+ await newsletterWMexQuery(jid, Types_1.QueryIds.JOB_MUTATION, {
178
+ updates: { name, settings: null }
179
+ });
114
180
  },
115
181
  newsletterUpdatePicture: async (jid, content) => {
116
- const { img } = await generateProfilePicture(content);
117
- return await newsletterUpdate(jid, { picture: img.toString('base64') });
182
+ const { img } = await (0, Utils_1.generateProfilePicture)(content);
183
+ await newsletterWMexQuery(jid, Types_1.QueryIds.JOB_MUTATION, {
184
+ updates: { picture: img.toString('base64'), settings: null }
185
+ });
118
186
  },
119
187
  newsletterRemovePicture: async (jid) => {
120
- return await newsletterUpdate(jid, { picture: '' });
121
- },
122
- newsletterReactMessage: async (jid, serverId, reaction) => {
123
- await query({
124
- tag: 'message',
125
- attrs: {
126
- to: jid,
127
- ...(reaction ? {} : { edit: '7' }),
128
- type: 'reaction',
129
- server_id: serverId,
130
- id: generateMessageTag()
131
- },
132
- content: [
133
- {
134
- tag: 'reaction',
135
- attrs: reaction ? { code: reaction } : {}
136
- }
137
- ]
188
+ await newsletterWMexQuery(jid, Types_1.QueryIds.JOB_MUTATION, {
189
+ updates: { picture: '', settings: null }
138
190
  });
139
191
  },
140
- newsletterFetchMessages: async (jid, count, since, after) => {
141
- const messageUpdateAttrs = {
142
- count: count.toString()
143
- };
144
- if (typeof since === 'number') {
145
- messageUpdateAttrs.since = since.toString();
146
- }
147
- if (after) {
148
- messageUpdateAttrs.after = after.toString();
149
- }
150
- const result = await query({
192
+ newsletterUnfollow: async (jid) => {
193
+ await newsletterWMexQuery(jid, Types_1.QueryIds.UNFOLLOW);
194
+ },
195
+ newsletterFollow: async (jid) => {
196
+ await newsletterWMexQuery(jid, Types_1.QueryIds.FOLLOW);
197
+ },
198
+ newsletterUnmute: async (jid) => {
199
+ await newsletterWMexQuery(jid, Types_1.QueryIds.UNMUTE);
200
+ },
201
+ newsletterMute: async (jid) => {
202
+ await newsletterWMexQuery(jid, Types_1.QueryIds.MUTE);
203
+ },
204
+ newsletterAction: async (jid, type) => {
205
+ await newsletterWMexQuery(jid, type.toUpperCase());
206
+ },
207
+ newsletterCreate: async (name, description, reaction_codes) => {
208
+ //TODO: Implement TOS system wide for Meta AI, communities, and here etc.
209
+ /**tos query */
210
+ await query({
151
211
  tag: 'iq',
152
212
  attrs: {
213
+ to: WABinary_1.S_WHATSAPP_NET,
214
+ xmlns: 'tos',
153
215
  id: generateMessageTag(),
154
- type: 'get',
155
- xmlns: 'newsletter',
156
- to: jid
216
+ type: 'set'
157
217
  },
158
218
  content: [
159
219
  {
160
- tag: 'message_updates',
161
- attrs: messageUpdateAttrs
220
+ tag: 'notice',
221
+ attrs: {
222
+ id: '20601218',
223
+ stage: '5'
224
+ },
225
+ content: []
162
226
  }
163
227
  ]
164
228
  });
165
- return result;
229
+ const result = await newsletterWMexQuery(undefined, Types_1.QueryIds.CREATE, {
230
+ input: { name, description, settings: { 'reaction_codes': { value: reaction_codes.toUpperCase() } } }
231
+ });
232
+ return (0, exports.extractNewsletterMetadata)(result, true);
166
233
  },
167
- subscribeNewsletterUpdates: async (jid) => {
168
- const result = await query({
169
- tag: 'iq',
170
- attrs: {
171
- id: generateMessageTag(),
172
- type: 'set',
173
- xmlns: 'newsletter',
174
- to: jid
234
+ newsletterMetadata: async (type, key, role) => {
235
+ const result = await newsletterWMexQuery(undefined, Types_1.QueryIds.METADATA, {
236
+ input: {
237
+ key,
238
+ type: type.toUpperCase(),
239
+ 'view_role': role || 'GUEST'
175
240
  },
176
- content: [{ tag: 'live_updates', attrs: {}, content: [] }]
241
+ 'fetch_viewer_metadata': true,
242
+ 'fetch_full_image': true,
243
+ 'fetch_creation_time': true
177
244
  });
178
- const liveUpdatesNode = getBinaryNodeChild(result, 'live_updates');
179
- const duration = liveUpdatesNode?.attrs?.duration;
180
- return duration ? { duration: duration } : null;
245
+ return (0, exports.extractNewsletterMetadata)(result);
181
246
  },
182
247
  newsletterAdminCount: async (jid) => {
183
- const response = await executeWMexQuery({ newsletter_id: jid }, QueryIds.ADMIN_COUNT, XWAPaths.xwa2_newsletter_admin_count);
184
- return response.admin_count;
248
+ var _a, _b;
249
+ const result = await newsletterWMexQuery(jid, Types_1.QueryIds.ADMIN_COUNT);
250
+ 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();
251
+ return JSON.parse(buff).data[Types_1.XWAPaths.ADMIN_COUNT].admin_count;
185
252
  },
186
- newsletterChangeOwner: async (jid, newOwnerJid) => {
187
- await executeWMexQuery({ newsletter_id: jid, user_id: newOwnerJid }, QueryIds.CHANGE_OWNER, XWAPaths.xwa2_newsletter_change_owner);
253
+ /**user is Lid, not Jid */
254
+ newsletterChangeOwner: async (jid, user) => {
255
+ await newsletterWMexQuery(jid, Types_1.QueryIds.CHANGE_OWNER, {
256
+ 'user_id': user
257
+ });
188
258
  },
189
- newsletterDemote: async (jid, userJid) => {
190
- await executeWMexQuery({ newsletter_id: jid, user_id: userJid }, QueryIds.DEMOTE, XWAPaths.xwa2_newsletter_demote);
259
+ /**user is Lid, not Jid */
260
+ newsletterDemote: async (jid, user) => {
261
+ await newsletterWMexQuery(jid, Types_1.QueryIds.DEMOTE, {
262
+ 'user_id': user
263
+ });
191
264
  },
192
265
  newsletterDelete: async (jid) => {
193
- await executeWMexQuery({ newsletter_id: jid }, QueryIds.DELETE, XWAPaths.xwa2_newsletter_delete_v2);
266
+ await newsletterWMexQuery(jid, Types_1.QueryIds.DELETE);
267
+ },
268
+ /**if code wasn't passed, the reaction will be removed (if is reacted) */
269
+ newsletterReactMessage: async (jid, serverId, code) => {
270
+ await query({
271
+ tag: 'message',
272
+ attrs: { to: jid, ...(!code ? { edit: '7' } : {}), type: 'reaction', 'server_id': serverId, id: (0, Utils_1.generateMessageID)() },
273
+ content: [{
274
+ tag: 'reaction',
275
+ attrs: code ? { code } : {}
276
+ }]
277
+ });
278
+ },
279
+ newsletterFetchMessages: async (type, key, count, after) => {
280
+ const result = await newsletterQuery(WABinary_1.S_WHATSAPP_NET, 'get', [
281
+ {
282
+ tag: 'messages',
283
+ attrs: { type, ...(type === 'invite' ? { key } : { jid: key }), count: count.toString(), after: (after === null || after === void 0 ? void 0 : after.toString()) || '100' }
284
+ }
285
+ ]);
286
+ return await parseFetchedUpdates(result, 'messages');
287
+ },
288
+ newsletterFetchUpdates: async (jid, count, after, since) => {
289
+ const result = await newsletterQuery(jid, 'get', [
290
+ {
291
+ tag: 'message_updates',
292
+ 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' }
293
+ }
294
+ ]);
295
+ return await parseFetchedUpdates(result, 'updates');
194
296
  }
195
297
  };
196
298
  };
197
- //# sourceMappingURL=newsletter.js.map
299
+ exports.makeNewsletterSocket = makeNewsletterSocket;
300
+ const extractNewsletterMetadata = (node, isCreate) => {
301
+ const result = WABinary_1.getBinaryNodeChild(node, 'result')?.content?.toString()
302
+ const metadataPath = JSON.parse(result).data[isCreate ? Types_1.XWAPaths.CREATE : Types_1.XWAPaths.NEWSLETTER]
303
+
304
+ const metadata = {
305
+ id: metadataPath?.id,
306
+ state: metadataPath?.state?.type,
307
+ creation_time: +metadataPath?.thread_metadata?.creation_time,
308
+ name: metadataPath?.thread_metadata?.name?.text,
309
+ nameTime: +metadataPath?.thread_metadata?.name?.update_time,
310
+ description: metadataPath?.thread_metadata?.description?.text,
311
+ descriptionTime: +metadataPath?.thread_metadata?.description?.update_time,
312
+ invite: metadataPath?.thread_metadata?.invite,
313
+ picture: Utils_1.getUrlFromDirectPath(metadataPath?.thread_metadata?.picture?.direct_path || ''),
314
+ preview: Utils_1.getUrlFromDirectPath(metadataPath?.thread_metadata?.preview?.direct_path || ''),
315
+ reaction_codes: metadataPath?.thread_metadata?.settings?.reaction_codes?.value,
316
+ subscribers: +metadataPath?.thread_metadata?.subscribers_count,
317
+ verification: metadataPath?.thread_metadata?.verification,
318
+ viewer_metadata: metadataPath?.viewer_metadata
319
+ }
320
+ return metadata
321
+ }
322
+ exports.extractNewsletterMetadata = extractNewsletterMetadata;