@neelegirl/baileys 1.5.2 → 1.5.3

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 (193) hide show
  1. package/LICENSE +21 -21
  2. package/README.md +195 -187
  3. package/WAProto/WAProto.proto +537 -236
  4. package/WAProto/index.d.ts +5971 -2388
  5. package/WAProto/index.js +17298 -6513
  6. package/lib/Defaults/baileys-version.json +3 -3
  7. package/lib/Defaults/index.d.ts +77 -67
  8. package/lib/Defaults/index.js +148 -136
  9. package/lib/Defaults/phonenumber-mcc.json +223 -223
  10. package/lib/Signal/WASignalGroup/GroupProtocol.js +1908 -1908
  11. package/lib/Signal/WASignalGroup/ciphertext-message.d.ts +9 -0
  12. package/lib/Signal/WASignalGroup/ciphertext-message.js +19 -0
  13. package/lib/Signal/WASignalGroup/ciphertext_message.js +15 -15
  14. package/lib/Signal/WASignalGroup/group-session-builder.d.ts +17 -0
  15. package/lib/Signal/WASignalGroup/group-session-builder.js +72 -0
  16. package/lib/Signal/WASignalGroup/group.proto +41 -41
  17. package/lib/Signal/WASignalGroup/group_cipher.d.ts +19 -0
  18. package/lib/Signal/WASignalGroup/group_cipher.js +101 -110
  19. package/lib/Signal/WASignalGroup/group_session_builder.js +45 -45
  20. package/lib/Signal/WASignalGroup/index.d.ts +11 -0
  21. package/lib/Signal/WASignalGroup/index.js +61 -6
  22. package/lib/Signal/WASignalGroup/keyhelper.d.ts +16 -0
  23. package/lib/Signal/WASignalGroup/keyhelper.js +58 -13
  24. package/lib/Signal/WASignalGroup/protobufs.js +2 -2
  25. package/lib/Signal/WASignalGroup/queue_job.js +68 -68
  26. package/lib/Signal/WASignalGroup/readme.md +5 -5
  27. package/lib/Signal/WASignalGroup/sender-chain-key.d.ts +14 -0
  28. package/lib/Signal/WASignalGroup/sender-chain-key.js +47 -0
  29. package/lib/Signal/WASignalGroup/sender-key-distribution-message.d.ts +17 -0
  30. package/lib/Signal/WASignalGroup/sender-key-distribution-message.js +71 -0
  31. package/lib/Signal/WASignalGroup/sender-key-message.d.ts +19 -0
  32. package/lib/Signal/WASignalGroup/sender-key-message.js +73 -0
  33. package/lib/Signal/WASignalGroup/sender-key-name.d.ts +19 -0
  34. package/lib/Signal/WASignalGroup/sender-key-name.js +59 -0
  35. package/lib/Signal/WASignalGroup/sender-key-record.d.ts +32 -0
  36. package/lib/Signal/WASignalGroup/sender-key-record.js +58 -0
  37. package/lib/Signal/WASignalGroup/sender-key-state.d.ts +44 -0
  38. package/lib/Signal/WASignalGroup/sender-key-state.js +147 -0
  39. package/lib/Signal/WASignalGroup/sender-message-key.d.ts +11 -0
  40. package/lib/Signal/WASignalGroup/sender-message-key.js +33 -0
  41. package/lib/Signal/WASignalGroup/sender_chain_key.js +49 -49
  42. package/lib/Signal/WASignalGroup/sender_key_distribution_message.js +77 -77
  43. package/lib/Signal/WASignalGroup/sender_key_message.js +91 -91
  44. package/lib/Signal/WASignalGroup/sender_key_name.js +69 -69
  45. package/lib/Signal/WASignalGroup/sender_key_record.js +55 -55
  46. package/lib/Signal/WASignalGroup/sender_key_state.js +128 -128
  47. package/lib/Signal/WASignalGroup/sender_message_key.js +38 -38
  48. package/lib/Signal/libsignal.d.ts +5 -1
  49. package/lib/Signal/libsignal.js +390 -161
  50. package/lib/Signal/lid-mapping.d.ts +28 -0
  51. package/lib/Signal/lid-mapping.js +184 -0
  52. package/lib/Socket/Client/abstract-socket-client.d.ts +15 -15
  53. package/lib/Socket/Client/abstract-socket-client.js +13 -13
  54. package/lib/Socket/Client/index.d.ts +2 -2
  55. package/lib/Socket/Client/mobile-socket-client.d.ts +12 -12
  56. package/lib/Socket/Client/mobile-socket-client.js +65 -65
  57. package/lib/Socket/Client/types.d.ts +1 -1
  58. package/lib/Socket/Client/websocket.d.ts +1 -1
  59. package/lib/Socket/business.d.ts +6 -6
  60. package/lib/Socket/business.js +152 -5
  61. package/lib/Socket/chats.d.ts +3 -4
  62. package/lib/Socket/chats.js +31 -26
  63. package/lib/Socket/communities.d.ts +223 -223
  64. package/lib/Socket/communities.js +432 -432
  65. package/lib/Socket/groups.d.ts +2 -4
  66. package/lib/Socket/groups.js +22 -14
  67. package/lib/Socket/index.d.ts +69 -69
  68. package/lib/Socket/index.js +3 -2
  69. package/lib/Socket/messages-recv.d.ts +3 -6
  70. package/lib/Socket/messages-recv.js +1449 -1707
  71. package/lib/Socket/messages-send.d.ts +2 -4
  72. package/lib/Socket/messages-send.js +617 -126
  73. package/lib/Socket/mex.d.ts +2 -2
  74. package/lib/Socket/mex.js +46 -46
  75. package/lib/Socket/newsletter.d.ts +2 -4
  76. package/lib/Socket/newsletter.js +294 -285
  77. package/lib/Socket/socket.js +318 -132
  78. package/lib/Socket/usync.js +3 -3
  79. package/lib/Store/index.d.ts +4 -4
  80. package/lib/Store/index.js +23 -23
  81. package/lib/Store/make-cache-manager-store.d.ts +13 -13
  82. package/lib/Store/make-cache-manager-store.js +89 -89
  83. package/lib/Store/make-in-memory-store.d.ts +122 -122
  84. package/lib/Store/make-in-memory-store.js +428 -428
  85. package/lib/Store/make-ordered-dictionary.d.ts +11 -11
  86. package/lib/Store/make-ordered-dictionary.js +85 -85
  87. package/lib/Store/object-repository.d.ts +9 -9
  88. package/lib/Store/object-repository.js +30 -30
  89. package/lib/Types/Auth.d.ts +5 -4
  90. package/lib/Types/Bussines.js +3 -0
  91. package/lib/Types/Bussiness.d.ts +28 -0
  92. package/lib/Types/Chat.d.ts +13 -8
  93. package/lib/Types/Contact.d.ts +4 -1
  94. package/lib/Types/Events.d.ts +13 -16
  95. package/lib/Types/GroupMetadata.d.ts +1 -1
  96. package/lib/Types/Message.d.ts +18 -7
  97. package/lib/Types/Message.js +7 -1
  98. package/lib/Types/MexUpdates.d.ts +8 -8
  99. package/lib/Types/MexUpdates.js +17 -17
  100. package/lib/Types/Newsletter.d.ts +1 -1
  101. package/lib/Types/Product.d.ts +1 -1
  102. package/lib/Types/Signal.d.ts +31 -1
  103. package/lib/Types/Socket.d.ts +34 -13
  104. package/lib/Types/State.d.ts +1 -1
  105. package/lib/Types/USync.d.ts +2 -2
  106. package/lib/Types/index.d.ts +16 -15
  107. package/lib/Types/index.js +4 -2
  108. package/lib/Utils/auth-utils.d.ts +20 -20
  109. package/lib/Utils/auth-utils.js +527 -204
  110. package/lib/Utils/baileys-event-stream.d.ts +17 -17
  111. package/lib/Utils/baileys-event-stream.js +69 -69
  112. package/lib/Utils/business.d.ts +28 -28
  113. package/lib/Utils/business.js +254 -254
  114. package/lib/Utils/chat-utils.d.ts +81 -81
  115. package/lib/Utils/chat-utils.js +808 -780
  116. package/lib/Utils/crypto.d.ts +55 -55
  117. package/lib/Utils/crypto.js +188 -178
  118. package/lib/Utils/decode-wa-message.d.ts +52 -40
  119. package/lib/Utils/decode-wa-message.js +322 -252
  120. package/lib/Utils/event-buffer.d.ts +38 -38
  121. package/lib/Utils/event-buffer.js +594 -564
  122. package/lib/Utils/generics.d.ts +131 -129
  123. package/lib/Utils/generics.js +629 -623
  124. package/lib/Utils/history.d.ts +22 -22
  125. package/lib/Utils/history.js +103 -109
  126. package/lib/Utils/index.d.ts +20 -19
  127. package/lib/Utils/index.js +39 -38
  128. package/lib/Utils/link-preview.d.ts +22 -22
  129. package/lib/Utils/link-preview.js +119 -119
  130. package/lib/Utils/logger.d.ts +13 -13
  131. package/lib/Utils/logger.js +7 -7
  132. package/lib/Utils/lt-hash.d.ts +13 -13
  133. package/lib/Utils/lt-hash.js +57 -57
  134. package/lib/Utils/make-mutex.d.ts +8 -8
  135. package/lib/Utils/make-mutex.js +48 -48
  136. package/lib/Utils/message-retry-manager.d.ts +88 -0
  137. package/lib/Utils/message-retry-manager.js +160 -0
  138. package/lib/Utils/messages-media.d.ts +134 -128
  139. package/lib/Utils/messages-media.js +868 -805
  140. package/lib/Utils/messages.d.ts +104 -102
  141. package/lib/Utils/messages.js +1744 -1578
  142. package/lib/Utils/noise-handler.d.ts +20 -19
  143. package/lib/Utils/noise-handler.js +164 -154
  144. package/lib/Utils/process-message.d.ts +48 -48
  145. package/lib/Utils/process-message.js +427 -428
  146. package/lib/Utils/signal.d.ts +41 -41
  147. package/lib/Utils/signal.js +165 -165
  148. package/lib/Utils/use-mongo-file-auth-state.d.ts +5 -5
  149. package/lib/Utils/use-mongo-file-auth-state.js +83 -83
  150. package/lib/Utils/use-multi-file-auth-state.d.ts +17 -17
  151. package/lib/Utils/use-multi-file-auth-state.js +237 -237
  152. package/lib/Utils/use-single-file-auth-state.d.ts +12 -12
  153. package/lib/Utils/use-single-file-auth-state.js +79 -79
  154. package/lib/Utils/validate-connection.d.ts +12 -12
  155. package/lib/Utils/validate-connection.js +219 -186
  156. package/lib/WABinary/constants.d.ts +29 -29
  157. package/lib/WABinary/constants.js +1315 -1315
  158. package/lib/WABinary/decode.d.ts +8 -8
  159. package/lib/WABinary/decode.js +287 -287
  160. package/lib/WABinary/encode.d.ts +2 -2
  161. package/lib/WABinary/encode.js +264 -264
  162. package/lib/WABinary/generic-utils.d.ts +27 -27
  163. package/lib/WABinary/generic-utils.js +141 -141
  164. package/lib/WABinary/index.d.ts +5 -5
  165. package/lib/WABinary/index.js +24 -24
  166. package/lib/WABinary/jid-utils.d.ts +58 -53
  167. package/lib/WABinary/jid-utils.js +103 -91
  168. package/lib/WABinary/types.d.ts +21 -21
  169. package/lib/WABinary/types.js +2 -2
  170. package/lib/WAM/BinaryInfo.d.ts +15 -15
  171. package/lib/WAM/BinaryInfo.js +16 -16
  172. package/lib/WAM/constants.d.ts +46 -46
  173. package/lib/WAM/constants.js +15370 -15370
  174. package/lib/WAM/encode.d.ts +2 -2
  175. package/lib/WAM/encode.js +163 -164
  176. package/lib/WAM/index.d.ts +3 -3
  177. package/lib/WAM/index.js +22 -22
  178. package/lib/WAUSync/Protocols/USyncBotProfileProtocol.d.ts +27 -27
  179. package/lib/WAUSync/Protocols/USyncBotProfileProtocol.js +68 -68
  180. package/lib/WAUSync/Protocols/USyncContactProtocol.d.ts +3 -3
  181. package/lib/WAUSync/Protocols/USyncDeviceProtocol.d.ts +2 -2
  182. package/lib/WAUSync/Protocols/USyncDisappearingModeProtocol.d.ts +2 -2
  183. package/lib/WAUSync/Protocols/USyncLIDProtocol.d.ts +9 -8
  184. package/lib/WAUSync/Protocols/USyncLIDProtocol.js +37 -29
  185. package/lib/WAUSync/Protocols/USyncStatusProtocol.d.ts +2 -2
  186. package/lib/WAUSync/Protocols/index.d.ts +6 -6
  187. package/lib/WAUSync/USyncQuery.d.ts +3 -3
  188. package/lib/WAUSync/index.d.ts +3 -3
  189. package/lib/index.d.ts +13 -13
  190. package/lib/index.js +33 -33
  191. package/package.json +96 -94
  192. package/lib/Socket/registration.d.ts +0 -266
  193. package/lib/Socket/registration.js +0 -166
@@ -1,286 +1,295 @@
1
- "use strict"
2
-
3
- Object.defineProperty(exports, "__esModule", { value: true })
4
-
5
- const Types_1 = require("../Types")
6
- const Utils_1 = require("../Utils")
7
- const WABinary_1 = require("../WABinary")
8
- const groups_1 = require("./groups")
9
-
10
- const makeNewsletterSocket = (config) => {
11
- const Neele = groups_1.makeGroupsSocket(config)
12
- const { authState, signalRepository, query, generateMessageTag } = Neele
13
- const encoder = new TextEncoder()
14
-
15
- const newsletterQuery = async (jid, type, content) => (query({
16
- tag: 'iq',
17
- attrs: {
18
- id: generateMessageTag(),
19
- type,
20
- xmlns: 'newsletter',
21
- to: jid,
22
- },
23
- content
24
- }))
25
-
26
- const newsletterWMexQuery = async (jid, queryId, content) => (query({
27
- tag: 'iq',
28
- attrs: {
29
- id: generateMessageTag(),
30
- type: 'get',
31
- xmlns: 'w:mex',
32
- to: WABinary_1.S_WHATSAPP_NET,
33
- },
34
- content: [
35
- {
36
- tag: 'query',
37
- attrs: { 'query_id': queryId },
38
- content: encoder.encode(JSON.stringify({
39
- variables: {
40
- 'newsletter_id': jid,
41
- ...content
42
- }
43
- }))
44
- }
45
- ]
46
- }))
47
-
48
- const parseFetchedUpdates = async (node, type) => {
49
- let child
50
- if (type === 'messages') {
51
- child = WABinary_1.getBinaryNodeChild(node, 'messages')
52
- }
53
-
54
- else {
55
- const parent = WABinary_1.getBinaryNodeChild(node, 'message_updates')
56
- child = WABinary_1.getBinaryNodeChild(parent, 'messages')
57
- }
58
-
59
- return await Promise.all(WABinary_1.getAllBinaryNodeChildren(child).map(async (messageNode) => {
60
- messageNode.attrs.from = child?.attrs.jid
61
-
62
- const views = parseInt(WABinary_1.getBinaryNodeChild(messageNode, 'views_count')?.attrs?.count || '0')
63
- const reactionNode = WABinary_1.getBinaryNodeChild(messageNode, 'reactions')
64
- const reactions = WABinary_1.getBinaryNodeChildren(reactionNode, 'reaction')
65
- .map(({ attrs }) => ({ count: +attrs.count, code: attrs.code }))
66
-
67
- const data = {
68
- 'server_id': messageNode.attrs.server_id,
69
- views,
70
- reactions
71
- }
72
-
73
- if (type === 'messages') {
74
- const { fullMessage: message, decrypt } = await Utils_1.decryptMessageNode(messageNode, authState.creds.me.id, authState.creds.me.lid || '', signalRepository, config.logger)
75
- await decrypt()
76
- data.message = message
77
- }
78
-
79
- return data
80
- }))
81
- }
82
-
83
- const newsletterMetadata = async (type, key, role) => {
84
- const result = await newsletterWMexQuery(undefined, Types_1.QueryIds.METADATA, {
85
- input: {
86
- key,
87
- type: type.toUpperCase(),
88
- view_role: role || 'GUEST'
89
- },
90
- fetch_viewer_metadata: true,
91
- fetch_full_image: true,
92
- fetch_creation_time: true
93
- })
94
-
95
- return extractNewsletterMetadata(result)
96
- }
97
-
98
- return {
99
- ...Neele,
100
- newsletterQuery,
101
- newsletterWMexQuery,
102
- subscribeNewsletterUpdates: async (jid) => {
103
- const result = await newsletterQuery(jid, 'set', [{ tag: 'live_updates', attrs: {}, content: [] }])
104
-
105
- return WABinary_1.getBinaryNodeChild(result, 'live_updates')?.attrs
106
- },
107
- newsletterReactionMode: async (jid, mode) => {
108
- await newsletterWMexQuery(jid, Types_1.QueryIds.JOB_MUTATION, {
109
- updates: { settings: { 'reaction_codes': { value: mode } } }
110
- })
111
- },
112
- newsletterUpdateDescription: async (jid, description) => {
113
- await newsletterWMexQuery(jid, Types_1.QueryIds.JOB_MUTATION, {
114
- updates: { description: description || '', settings: null }
115
- })
116
- },
117
- newsletterUpdateName: async (jid, name) => {
118
- await newsletterWMexQuery(jid, Types_1.QueryIds.JOB_MUTATION, {
119
- updates: { name, settings: null }
120
- })
121
- },
122
- newsletterUpdatePicture: async (jid, content) => {
123
- const { img } = await Utils_1.generateProfilePicture(content)
124
-
125
- await newsletterWMexQuery(jid, Types_1.QueryIds.JOB_MUTATION, {
126
- updates: { picture: img.toString('base64'), settings: null }
127
- })
128
- },
129
- newsletterRemovePicture: async (jid) => {
130
- await newsletterWMexQuery(jid, Types_1.QueryIds.JOB_MUTATION, {
131
- updates: { picture: '', settings: null }
132
- })
133
- },
134
- newsletterUnfollow: async (jid) => {
135
- await newsletterWMexQuery(jid, Types_1.QueryIds.UNFOLLOW)
136
- },
137
- newsletterFollow: async (jid) => {
138
- await newsletterWMexQuery(jid, Types_1.QueryIds.FOLLOW)
139
- },
140
- newsletterUnmute: async (jid) => {
141
- await newsletterWMexQuery(jid, Types_1.QueryIds.UNMUTE)
142
- },
143
- newsletterMute: async (jid) => {
144
- await newsletterWMexQuery(jid, Types_1.QueryIds.MUTE)
145
- },
146
- newsletterAction: async (jid, type) => {
147
- await newsletterWMexQuery(jid, Types_1.QueryIds[type.toUpperCase()])
148
- },
149
- newsletterCreate: async (name, description, picture) => {
150
- //TODO: Implement TOS system wide for Meta AI, communities, and here etc.
151
- /**tos query */
152
- await query({
153
- tag: 'iq',
154
- attrs: {
155
- to: WABinary_1.S_WHATSAPP_NET,
156
- xmlns: 'tos',
157
- id: generateMessageTag(),
158
- type: 'set'
159
- },
160
- content: [
161
- {
162
- tag: 'notice',
163
- attrs: {
164
- id: '20601218',
165
- stage: '5'
166
- },
167
- content: []
168
- }
169
- ]
170
- })
171
-
172
- const result = await newsletterWMexQuery(undefined, Types_1.QueryIds.CREATE, {
173
- input: {
174
- name,
175
- description: description || null,
176
- picture: picture ? (await Utils_1.generateProfilePicture(picture)).img.toString('base64') : null,
177
- settings: {
178
- reaction_codes: {
179
- value: 'ALL'
180
- }
181
- }
182
- }
183
- })
184
-
185
- return extractNewsletterMetadata(result, true)
186
- },
187
- newsletterMetadata,
188
- newsletterFetchAllParticipating: async () => {
189
- const data = {}
190
-
191
- const result = await newsletterWMexQuery(undefined, Types_1.QueryIds.SUBSCRIBED)
192
- const child = JSON.parse(WABinary_1.getBinaryNodeChild(result, 'result')?.content?.toString())
193
- const newsletters = child.data[Types_1.XWAPaths.SUBSCRIBED]
194
-
195
- for (const i of newsletters) {
196
- if (!WABinary_1.isJidNewsletter(i.id)) {
197
- continue
198
- }
199
-
200
- const metadata = await newsletterMetadata('JID', i.id)
201
- data[metadata.id] = metadata
202
- }
203
-
204
- return data
205
- },
206
- newsletterAdminCount: async (jid) => {
207
- const result = await newsletterWMexQuery(jid, Types_1.QueryIds.ADMIN_COUNT)
208
- const buff = WABinary_1.getBinaryNodeChild(result, 'result')?.content?.toString()
209
-
210
- return JSON.parse(buff).data[Types_1.XWAPaths.ADMIN_COUNT].admin_count
211
- },
212
- newsletterChangeOwner: async (jid, userLid) => {
213
- await newsletterWMexQuery(jid, Types_1.QueryIds.CHANGE_OWNER, {
214
- user_id: userLid
215
- })
216
- },
217
- newsletterDemote: async (jid, userLid) => {
218
- await newsletterWMexQuery(jid, Types_1.QueryIds.DEMOTE, {
219
- user_id: userLid
220
- })
221
- },
222
- newsletterDelete: async (jid) => {
223
- await newsletterWMexQuery(jid, Types_1.QueryIds.DELETE)
224
- },
225
- /**if code wasn't passed, the reaction will be removed (if is reacted) */
226
- newsletterReactMessage: async (jid, serverId, code) => {
227
- await query({
228
- tag: 'message',
229
- attrs: { to: jid, ...(!code ? { edit: '7' } : {}), type: 'reaction', server_id: serverId, id: Utils_1.generateMessageID() },
230
- content: [{
231
- tag: 'reaction',
232
- attrs: code ? { code } : {}
233
- }]
234
- })
235
- },
236
- newsletterFetchMessages: async (type, key, count, after) => {
237
- const result = await newsletterQuery(WABinary_1.S_WHATSAPP_NET, 'get', [
238
- {
239
- tag: 'messages',
240
- attrs: { type, ...(type === 'invite' ? { key } : { jid: key }), count: count.toString(), after: after?.toString() || '100' }
241
- }
242
- ])
243
-
244
- return await parseFetchedUpdates(result, 'messages')
245
- },
246
- newsletterFetchUpdates: async (jid, count, after, since) => {
247
- const result = await newsletterQuery(jid, 'get', [
248
- {
249
- tag: 'message_updates',
250
- attrs: { count: count.toString(), after: after?.toString() || '100', since: since?.toString() || '0' }
251
- }
252
- ])
253
-
254
- return await parseFetchedUpdates(result, 'updates')
255
- }
256
- }
257
- }
258
-
259
- const extractNewsletterMetadata = (node, isCreate) => {
260
- const result = WABinary_1.getBinaryNodeChild(node, 'result')?.content?.toString()
261
- const metadataPath = JSON.parse(result).data[isCreate ? Types_1.XWAPaths.CREATE : Types_1.XWAPaths.NEWSLETTER]
262
-
263
- const metadata = {
264
- id: metadataPath.id,
265
- state: metadataPath.state.type,
266
- creation_time: +metadataPath.thread_metadata.creation_time,
267
- name: metadataPath.thread_metadata.name.text,
268
- nameTime: +metadataPath.thread_metadata.name.update_time,
269
- description: metadataPath.thread_metadata.description.text,
270
- descriptionTime: +metadataPath.thread_metadata.description.update_time,
271
- invite: metadataPath.thread_metadata.invite,
272
- handle: metadataPath.thread_metadata.handle,
273
- picture: Utils_1.getUrlFromDirectPath(metadataPath.thread_metadata.picture?.direct_path || ''),
274
- preview: Utils_1.getUrlFromDirectPath(metadataPath.thread_metadata.preview?.direct_path || ''),
275
- reaction_codes: metadataPath.thread_metadata?.settings?.reaction_codes?.value,
276
- subscribers: +metadataPath.thread_metadata.subscribers_count,
277
- verification: metadataPath.thread_metadata.verification,
278
- viewer_metadata: metadataPath.viewer_metadata
279
- }
280
- return metadata
281
- }
282
-
283
- module.exports = {
284
- makeNewsletterSocket,
285
- extractNewsletterMetadata
1
+ "use strict"
2
+
3
+ Object.defineProperty(exports, "__esModule", { value: true })
4
+
5
+ const Types_1 = require("../Types")
6
+ const Utils_1 = require("../Utils")
7
+ const WABinary_1 = require("../WABinary")
8
+ const groups_1 = require("./groups")
9
+
10
+ const makeNewsletterSocket = (config) => {
11
+ const baron = groups_1.makeGroupsSocket(config)
12
+ const { authState, signalRepository, query, generateMessageTag } = baron
13
+ const encoder = new TextEncoder()
14
+
15
+ const newsletterQuery = async (jid, type, content) => (query({
16
+ tag: 'iq',
17
+ attrs: {
18
+ id: generateMessageTag(),
19
+ type,
20
+ xmlns: 'newsletter',
21
+ to: jid,
22
+ },
23
+ content
24
+ }))
25
+
26
+ const newsletterWMexQuery = async (jid, queryId, content) => (query({
27
+ tag: 'iq',
28
+ attrs: {
29
+ id: generateMessageTag(),
30
+ type: 'get',
31
+ xmlns: 'w:mex',
32
+ to: WABinary_1.S_WHATSAPP_NET,
33
+ },
34
+ content: [
35
+ {
36
+ tag: 'query',
37
+ attrs: { 'query_id': queryId },
38
+ content: encoder.encode(JSON.stringify({
39
+ variables: {
40
+ 'newsletter_id': jid,
41
+ ...content
42
+ }
43
+ }))
44
+ }
45
+ ]
46
+ }))
47
+
48
+ const parseFetchedUpdates = async (node, type) => {
49
+ let child
50
+ if (type === 'messages') {
51
+ child = WABinary_1.getBinaryNodeChild(node, 'messages')
52
+ }
53
+
54
+ else {
55
+ const parent = WABinary_1.getBinaryNodeChild(node, 'message_updates')
56
+ child = WABinary_1.getBinaryNodeChild(parent, 'messages')
57
+ }
58
+
59
+ return await Promise.all(WABinary_1.getAllBinaryNodeChildren(child).map(async (messageNode) => {
60
+ messageNode.attrs.from = child?.attrs.jid
61
+
62
+ const views = parseInt(WABinary_1.getBinaryNodeChild(messageNode, 'views_count')?.attrs?.count || '0')
63
+ const reactionNode = WABinary_1.getBinaryNodeChild(messageNode, 'reactions')
64
+ const reactions = WABinary_1.getBinaryNodeChildren(reactionNode, 'reaction')
65
+ .map(({ attrs }) => ({ count: +attrs.count, code: attrs.code }))
66
+
67
+ const data = {
68
+ 'server_id': messageNode.attrs.server_id,
69
+ views,
70
+ reactions
71
+ }
72
+
73
+ if (type === 'messages') {
74
+ const { fullMessage: message, decrypt } = await Utils_1.decryptMessageNode(messageNode, authState.creds.me.id, authState.creds.me.lid || '', signalRepository, config.logger)
75
+ await decrypt()
76
+ data.message = message
77
+ }
78
+
79
+ return data
80
+ }))
81
+ }
82
+
83
+ const newsletterMetadata = async (type, key, role) => {
84
+ const result = await newsletterWMexQuery(undefined, Types_1.QueryIds.METADATA, {
85
+ input: {
86
+ key,
87
+ type: type.toUpperCase(),
88
+ view_role: role || 'GUEST'
89
+ },
90
+ fetch_viewer_metadata: true,
91
+ fetch_full_image: true,
92
+ fetch_creation_time: true
93
+ })
94
+
95
+ return extractNewsletterMetadata(result)
96
+ }
97
+
98
+ return {
99
+ ...baron,
100
+ newsletterQuery,
101
+ newsletterWMexQuery,
102
+ subscribeNewsletterUpdates: async (jid) => {
103
+ const result = await newsletterQuery(jid, 'set', [{ tag: 'live_updates', attrs: {}, content: [] }])
104
+
105
+ return WABinary_1.getBinaryNodeChild(result, 'live_updates')?.attrs
106
+ },
107
+ newsletterReactionMode: async (jid, mode) => {
108
+ await newsletterWMexQuery(jid, Types_1.QueryIds.JOB_MUTATION, {
109
+ updates: { settings: { 'reaction_codes': { value: mode } } }
110
+ })
111
+ },
112
+ newsletterUpdateDescription: async (jid, description) => {
113
+ await newsletterWMexQuery(jid, Types_1.QueryIds.JOB_MUTATION, {
114
+ updates: { description: description || '', settings: null }
115
+ })
116
+ },
117
+ newsletterUpdateName: async (jid, name) => {
118
+ await newsletterWMexQuery(jid, Types_1.QueryIds.JOB_MUTATION, {
119
+ updates: { name, settings: null }
120
+ })
121
+ },
122
+ newsletterUpdatePicture: async (jid, content) => {
123
+ const { img } = await Utils_1.generateProfilePicture(content)
124
+
125
+ await newsletterWMexQuery(jid, Types_1.QueryIds.JOB_MUTATION, {
126
+ updates: { picture: img.toString('base64'), settings: null }
127
+ })
128
+ },
129
+ newsletterRemovePicture: async (jid) => {
130
+ await newsletterWMexQuery(jid, Types_1.QueryIds.JOB_MUTATION, {
131
+ updates: { picture: '', settings: null }
132
+ })
133
+ },
134
+ newsletterUnfollow: async (jid) => {
135
+ await newsletterWMexQuery(jid, Types_1.QueryIds.UNFOLLOW)
136
+ },
137
+ newsletterFollow: async (jid) => {
138
+ await newsletterWMexQuery(jid, Types_1.QueryIds.FOLLOW)
139
+ },
140
+ newsletterUnmute: async (jid) => {
141
+ await newsletterWMexQuery(jid, Types_1.QueryIds.UNMUTE)
142
+ },
143
+ newsletterMute: async (jid) => {
144
+ await newsletterWMexQuery(jid, Types_1.QueryIds.MUTE)
145
+ },
146
+ newsletterAction: async (jid, type) => {
147
+ await newsletterWMexQuery(jid, Types_1.QueryIds[type.toUpperCase()])
148
+ },
149
+ newsletterCreate: async (name, description, picture) => {
150
+ //TODO: Implement TOS system wide for Meta AI, communities, and here etc.
151
+ /**tos query */
152
+ await query({
153
+ tag: 'iq',
154
+ attrs: {
155
+ to: WABinary_1.S_WHATSAPP_NET,
156
+ xmlns: 'tos',
157
+ id: generateMessageTag(),
158
+ type: 'set'
159
+ },
160
+ content: [
161
+ {
162
+ tag: 'notice',
163
+ attrs: {
164
+ id: '20601218',
165
+ stage: '5'
166
+ },
167
+ content: []
168
+ }
169
+ ]
170
+ })
171
+
172
+ const result = await newsletterWMexQuery(undefined, Types_1.QueryIds.CREATE, {
173
+ input: {
174
+ name,
175
+ description: description || null,
176
+ picture: picture ? (await Utils_1.generateProfilePicture(picture)).img.toString('base64') : null,
177
+ settings: {
178
+ reaction_codes: {
179
+ value: 'ALL'
180
+ }
181
+ }
182
+ }
183
+ })
184
+
185
+ return extractNewsletterMetadata(result, true)
186
+ },
187
+ newsletterMetadata,
188
+ newsletterFetchAllParticipating: async () => {
189
+ const data = {}
190
+
191
+ const result = await newsletterWMexQuery(undefined, Types_1.QueryIds.SUBSCRIBED)
192
+ const child = JSON.parse(WABinary_1.getBinaryNodeChild(result, 'result')?.content?.toString())
193
+ const newsletters = child.data[Types_1.XWAPaths.SUBSCRIBED]
194
+
195
+ for (const i of newsletters) {
196
+ if (!WABinary_1.isJidNewsletter(i.id)) {
197
+ continue
198
+ }
199
+
200
+ const metadata = await newsletterMetadata('JID', i.id)
201
+ data[metadata.id] = metadata
202
+ }
203
+
204
+ return data
205
+ },
206
+ newsletterFetchAllParticipating: async () => {
207
+ const result = await newsletterWMexQuery(undefined, Types_1.QueryIds.SUBSCRIBED)
208
+ const child = JSON.parse(WABinary_1.getBinaryNodeChild(result, 'result')?.content?.toString())
209
+ const newsletters = child.data[Types_1.XWAPaths.SUBSCRIBED] || []
210
+
211
+ const data = {}
212
+
213
+ for (const { id } of newsletters) {
214
+ if (!WABinary_1.isJidNewsletter(id)) continue
215
+ const metadata = await newsletterMetadata('JID', id)
216
+ data[metadata.id] = metadata
217
+ }
218
+
219
+ return data
220
+ },
221
+ newsletterChangeOwner: async (jid, userLid) => {
222
+ await newsletterWMexQuery(jid, Types_1.QueryIds.CHANGE_OWNER, {
223
+ user_id: userLid
224
+ })
225
+ },
226
+ newsletterDemote: async (jid, userLid) => {
227
+ await newsletterWMexQuery(jid, Types_1.QueryIds.DEMOTE, {
228
+ user_id: userLid
229
+ })
230
+ },
231
+ newsletterDelete: async (jid) => {
232
+ await newsletterWMexQuery(jid, Types_1.QueryIds.DELETE)
233
+ },
234
+ /**if code wasn't passed, the reaction will be removed (if is reacted) */
235
+ newsletterReactMessage: async (jid, serverId, code) => {
236
+ await query({
237
+ tag: 'message',
238
+ attrs: { to: jid, ...(!code ? { edit: '7' } : {}), type: 'reaction', server_id: serverId, id: Utils_1.generateMessageID() },
239
+ content: [{
240
+ tag: 'reaction',
241
+ attrs: code ? { code } : {}
242
+ }]
243
+ })
244
+ },
245
+ newsletterFetchMessages: async (type, key, count, after) => {
246
+ const result = await newsletterQuery(WABinary_1.S_WHATSAPP_NET, 'get', [
247
+ {
248
+ tag: 'messages',
249
+ attrs: { type, ...(type === 'invite' ? { key } : { jid: key }), count: count.toString(), after: after?.toString() || '100' }
250
+ }
251
+ ])
252
+
253
+ return await parseFetchedUpdates(result, 'messages')
254
+ },
255
+ newsletterFetchUpdates: async (jid, count, after, since) => {
256
+ const result = await newsletterQuery(jid, 'get', [
257
+ {
258
+ tag: 'message_updates',
259
+ attrs: { count: count.toString(), after: after?.toString() || '100', since: since?.toString() || '0' }
260
+ }
261
+ ])
262
+
263
+ return await parseFetchedUpdates(result, 'updates')
264
+ }
265
+ }
266
+ }
267
+
268
+ const extractNewsletterMetadata = (node, isCreate) => {
269
+ const result = WABinary_1.getBinaryNodeChild(node, 'result')?.content?.toString()
270
+ const metadataPath = JSON.parse(result).data[isCreate ? Types_1.XWAPaths.CREATE : Types_1.XWAPaths.NEWSLETTER]
271
+
272
+ const metadata = {
273
+ id: metadataPath?.id,
274
+ state: metadataPath?.state?.type,
275
+ creation_time: +metadataPath?.thread_metadata?.creation_time,
276
+ name: metadataPath?.thread_metadata?.name?.text,
277
+ nameTime: +metadataPath?.thread_metadata?.name?.update_time,
278
+ description: metadataPath?.thread_metadata?.description?.text,
279
+ descriptionTime: +metadataPath?.thread_metadata?.description?.update_time,
280
+ invite: metadataPath?.thread_metadata?.invite,
281
+ handle: metadataPath?.thread_metadata?.handle,
282
+ picture: Utils_1.getUrlFromDirectPath(metadataPath?.thread_metadata?.picture?.direct_path || ''),
283
+ preview: Utils_1.getUrlFromDirectPath(metadataPath?.thread_metadata?.preview?.direct_path || ''),
284
+ reaction_codes: metadataPath?.thread_metadata?.settings?.reaction_codes?.value,
285
+ subscribers: +metadataPath?.thread_metadata?.subscribers_count,
286
+ verification: metadataPath?.thread_metadata?.verification,
287
+ viewer_metadata: metadataPath?.viewer_metadata
288
+ }
289
+ return metadata
290
+ }
291
+
292
+ module.exports = {
293
+ makeNewsletterSocket,
294
+ extractNewsletterMetadata
286
295
  }