gifted-baileys 1.5.4 → 1.5.5

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 (250) hide show
  1. package/LICENSE +1 -1
  2. package/WAProto/WAProto.proto +88 -969
  3. package/WAProto/index.d.ts +1256 -13195
  4. package/WAProto/index.js +74730 -125106
  5. package/package.json +9 -27
  6. package/src/Defaults/baileys-version.json +3 -0
  7. package/{lib → src}/Defaults/index.js +14 -7
  8. package/src/Defaults/index.ts +131 -0
  9. package/src/Signal/libsignal.js +180 -0
  10. package/src/Signal/libsignal.ts +141 -0
  11. package/src/Socket/Client/abstract-socket-client.ts +19 -0
  12. package/{lib → src}/Socket/Client/index.js +3 -2
  13. package/src/Socket/Client/index.ts +3 -0
  14. package/src/Socket/Client/mobile-socket-client.js +78 -0
  15. package/src/Socket/Client/mobile-socket-client.ts +66 -0
  16. package/src/Socket/Client/web-socket-client.js +75 -0
  17. package/src/Socket/Client/web-socket-client.ts +57 -0
  18. package/{lib → src}/Socket/business.js +33 -28
  19. package/src/Socket/business.ts +281 -0
  20. package/{lib → src}/Socket/chats.js +176 -174
  21. package/src/Socket/chats.ts +1030 -0
  22. package/{lib → src}/Socket/groups.js +68 -80
  23. package/src/Socket/groups.ts +356 -0
  24. package/{lib → src}/Socket/index.js +1 -4
  25. package/src/Socket/index.ts +13 -0
  26. package/{lib → src}/Socket/messages-recv.js +211 -378
  27. package/src/Socket/messages-recv.ts +985 -0
  28. package/{lib → src}/Socket/messages-send.js +177 -452
  29. package/src/Socket/messages-send.ts +871 -0
  30. package/{lib → src}/Socket/newsletter.js +98 -107
  31. package/src/Socket/newsletter.ts +282 -0
  32. package/{lib → src}/Socket/registration.js +48 -56
  33. package/src/Socket/registration.ts +250 -0
  34. package/{lib → src}/Socket/socket.js +77 -77
  35. package/src/Socket/socket.ts +777 -0
  36. package/src/Store/index.ts +3 -0
  37. package/{lib → src}/Store/make-cache-manager-store.js +34 -25
  38. package/src/Store/make-cache-manager-store.ts +100 -0
  39. package/{lib → src}/Store/make-in-memory-store.js +32 -36
  40. package/src/Store/make-in-memory-store.ts +475 -0
  41. package/src/Store/make-ordered-dictionary.ts +86 -0
  42. package/{lib → src}/Store/object-repository.js +1 -1
  43. package/src/Store/object-repository.ts +32 -0
  44. package/src/Tests/test.app-state-sync.js +204 -0
  45. package/src/Tests/test.app-state-sync.ts +207 -0
  46. package/src/Tests/test.event-buffer.js +270 -0
  47. package/src/Tests/test.event-buffer.ts +319 -0
  48. package/src/Tests/test.key-store.js +76 -0
  49. package/src/Tests/test.key-store.ts +92 -0
  50. package/src/Tests/test.libsignal.js +141 -0
  51. package/src/Tests/test.libsignal.ts +186 -0
  52. package/src/Tests/test.media-download.js +93 -0
  53. package/src/Tests/test.media-download.ts +76 -0
  54. package/src/Tests/test.messages.js +33 -0
  55. package/src/Tests/test.messages.ts +37 -0
  56. package/src/Tests/utils.js +34 -0
  57. package/src/Tests/utils.ts +36 -0
  58. package/src/Types/Auth.ts +113 -0
  59. package/src/Types/Call.ts +15 -0
  60. package/src/Types/Chat.ts +106 -0
  61. package/{lib/Types/Contact.d.ts → src/Types/Contact.ts} +9 -8
  62. package/src/Types/Events.ts +93 -0
  63. package/src/Types/GroupMetadata.ts +53 -0
  64. package/src/Types/Label.ts +36 -0
  65. package/{lib/Types/LabelAssociation.d.ts → src/Types/LabelAssociation.ts} +22 -16
  66. package/src/Types/Message.ts +288 -0
  67. package/src/Types/Newsletter.ts +98 -0
  68. package/src/Types/Product.ts +85 -0
  69. package/src/Types/Signal.ts +68 -0
  70. package/{lib/Types/Socket.d.ts → src/Types/Socket.ts} +68 -61
  71. package/src/Types/State.ts +29 -0
  72. package/src/Types/index.ts +59 -0
  73. package/{lib → src}/Utils/auth-utils.js +90 -73
  74. package/src/Utils/auth-utils.ts +222 -0
  75. package/src/Utils/baileys-event-stream.js +92 -0
  76. package/src/Utils/baileys-event-stream.ts +66 -0
  77. package/{lib → src}/Utils/business.js +43 -15
  78. package/src/Utils/business.ts +275 -0
  79. package/{lib → src}/Utils/chat-utils.js +94 -87
  80. package/src/Utils/chat-utils.ts +860 -0
  81. package/{lib → src}/Utils/crypto.js +2 -4
  82. package/src/Utils/crypto.ts +131 -0
  83. package/src/Utils/decode-wa-message.js +211 -0
  84. package/src/Utils/decode-wa-message.ts +228 -0
  85. package/{lib → src}/Utils/event-buffer.js +13 -4
  86. package/src/Utils/event-buffer.ts +613 -0
  87. package/{lib → src}/Utils/generics.js +86 -67
  88. package/src/Utils/generics.ts +434 -0
  89. package/{lib → src}/Utils/history.js +39 -13
  90. package/src/Utils/history.ts +112 -0
  91. package/src/Utils/index.ts +17 -0
  92. package/{lib → src}/Utils/link-preview.js +54 -17
  93. package/src/Utils/link-preview.ts +122 -0
  94. package/src/Utils/logger.ts +3 -0
  95. package/src/Utils/lt-hash.ts +61 -0
  96. package/{lib → src}/Utils/make-mutex.js +13 -4
  97. package/src/Utils/make-mutex.ts +44 -0
  98. package/{lib → src}/Utils/messages-media.js +255 -193
  99. package/src/Utils/messages-media.ts +847 -0
  100. package/{lib → src}/Utils/messages.js +118 -588
  101. package/src/Utils/messages.ts +956 -0
  102. package/src/Utils/noise-handler.ts +197 -0
  103. package/{lib → src}/Utils/process-message.js +30 -27
  104. package/src/Utils/process-message.ts +414 -0
  105. package/{lib → src}/Utils/signal.js +42 -25
  106. package/src/Utils/signal.ts +177 -0
  107. package/{lib → src}/Utils/use-multi-file-auth-state.js +28 -27
  108. package/src/Utils/use-multi-file-auth-state.ts +90 -0
  109. package/{lib → src}/Utils/validate-connection.js +9 -40
  110. package/src/Utils/validate-connection.ts +238 -0
  111. package/src/WABinary/constants.ts +42 -0
  112. package/src/WABinary/decode.ts +265 -0
  113. package/{lib → src}/WABinary/encode.js +10 -16
  114. package/src/WABinary/encode.ts +236 -0
  115. package/src/WABinary/generic-utils.ts +121 -0
  116. package/src/WABinary/index.ts +5 -0
  117. package/src/WABinary/jid-utils.ts +68 -0
  118. package/src/WABinary/types.ts +17 -0
  119. package/src/WAM/BinaryInfo.ts +12 -0
  120. package/src/WAM/constants.ts +15382 -0
  121. package/src/WAM/encode.ts +174 -0
  122. package/src/WAM/index.ts +3 -0
  123. package/{lib → src}/index.js +0 -1
  124. package/src/index.ts +13 -0
  125. package/lib/Defaults/baileys-version.json +0 -3
  126. package/lib/Defaults/index.d.ts +0 -284
  127. package/lib/Signal/libsignal.d.ts +0 -3
  128. package/lib/Signal/libsignal.js +0 -161
  129. package/lib/Socket/Client/abstract-socket-client.d.ts +0 -15
  130. package/lib/Socket/Client/index.d.ts +0 -2
  131. package/lib/Socket/Client/mobile-socket-client.d.ts +0 -12
  132. package/lib/Socket/Client/mobile-socket-client.js +0 -65
  133. package/lib/Socket/Client/types.d.ts +0 -17
  134. package/lib/Socket/Client/types.js +0 -13
  135. package/lib/Socket/Client/websocket.d.ts +0 -12
  136. package/lib/Socket/Client/websocket.js +0 -62
  137. package/lib/Socket/business.d.ts +0 -170
  138. package/lib/Socket/chats.d.ts +0 -81
  139. package/lib/Socket/groups.d.ts +0 -115
  140. package/lib/Socket/index.d.ts +0 -172
  141. package/lib/Socket/messages-recv.d.ts +0 -158
  142. package/lib/Socket/messages-send.d.ts +0 -155
  143. package/lib/Socket/newsletter.d.ts +0 -132
  144. package/lib/Socket/registration.d.ts +0 -264
  145. package/lib/Socket/socket.d.ts +0 -44
  146. package/lib/Socket/usync.d.ts +0 -37
  147. package/lib/Socket/usync.js +0 -70
  148. package/lib/Store/index.d.ts +0 -3
  149. package/lib/Store/make-cache-manager-store.d.ts +0 -14
  150. package/lib/Store/make-in-memory-store.d.ts +0 -118
  151. package/lib/Store/make-ordered-dictionary.d.ts +0 -13
  152. package/lib/Store/object-repository.d.ts +0 -10
  153. package/lib/Types/Auth.d.ts +0 -109
  154. package/lib/Types/Call.d.ts +0 -13
  155. package/lib/Types/Chat.d.ts +0 -107
  156. package/lib/Types/Events.d.ts +0 -172
  157. package/lib/Types/GroupMetadata.d.ts +0 -56
  158. package/lib/Types/Label.d.ts +0 -46
  159. package/lib/Types/Message.d.ts +0 -433
  160. package/lib/Types/Newsletter.d.ts +0 -92
  161. package/lib/Types/Product.d.ts +0 -78
  162. package/lib/Types/Signal.d.ts +0 -57
  163. package/lib/Types/State.d.ts +0 -27
  164. package/lib/Types/USync.d.ts +0 -25
  165. package/lib/Types/USync.js +0 -2
  166. package/lib/Types/index.d.ts +0 -66
  167. package/lib/Utils/auth-utils.d.ts +0 -18
  168. package/lib/Utils/baileys-event-stream.d.ts +0 -16
  169. package/lib/Utils/baileys-event-stream.js +0 -63
  170. package/lib/Utils/business.d.ts +0 -22
  171. package/lib/Utils/chat-utils.d.ts +0 -70
  172. package/lib/Utils/crypto.d.ts +0 -40
  173. package/lib/Utils/decode-wa-message.d.ts +0 -36
  174. package/lib/Utils/decode-wa-message.js +0 -226
  175. package/lib/Utils/event-buffer.d.ts +0 -35
  176. package/lib/Utils/generics.d.ts +0 -88
  177. package/lib/Utils/history.d.ts +0 -19
  178. package/lib/Utils/index.d.ts +0 -17
  179. package/lib/Utils/link-preview.d.ts +0 -21
  180. package/lib/Utils/logger.d.ts +0 -2
  181. package/lib/Utils/lt-hash.d.ts +0 -12
  182. package/lib/Utils/make-mutex.d.ts +0 -7
  183. package/lib/Utils/messages-media.d.ts +0 -113
  184. package/lib/Utils/messages.d.ts +0 -77
  185. package/lib/Utils/noise-handler.d.ts +0 -20
  186. package/lib/Utils/process-message.d.ts +0 -41
  187. package/lib/Utils/signal.d.ts +0 -33
  188. package/lib/Utils/use-multi-file-auth-state.d.ts +0 -12
  189. package/lib/Utils/validate-connection.d.ts +0 -11
  190. package/lib/WABinary/constants.d.ts +0 -27
  191. package/lib/WABinary/decode.d.ts +0 -6
  192. package/lib/WABinary/encode.d.ts +0 -2
  193. package/lib/WABinary/generic-utils.d.ts +0 -14
  194. package/lib/WABinary/index.d.ts +0 -5
  195. package/lib/WABinary/jid-utils.d.ts +0 -31
  196. package/lib/WABinary/types.d.ts +0 -18
  197. package/lib/WAM/BinaryInfo.d.ts +0 -8
  198. package/lib/WAM/constants.d.ts +0 -38
  199. package/lib/WAM/encode.d.ts +0 -2
  200. package/lib/WAM/index.d.ts +0 -3
  201. package/lib/WAUSync/Protocols/USyncContactProtocol.d.ts +0 -9
  202. package/lib/WAUSync/Protocols/USyncContactProtocol.js +0 -32
  203. package/lib/WAUSync/Protocols/USyncDeviceProtocol.d.ts +0 -22
  204. package/lib/WAUSync/Protocols/USyncDeviceProtocol.js +0 -57
  205. package/lib/WAUSync/Protocols/USyncDisappearingModeProtocol.d.ts +0 -12
  206. package/lib/WAUSync/Protocols/USyncDisappearingModeProtocol.js +0 -30
  207. package/lib/WAUSync/Protocols/USyncStatusProtocol.d.ts +0 -12
  208. package/lib/WAUSync/Protocols/USyncStatusProtocol.js +0 -42
  209. package/lib/WAUSync/Protocols/index.d.ts +0 -4
  210. package/lib/WAUSync/Protocols/index.js +0 -20
  211. package/lib/WAUSync/USyncQuery.d.ts +0 -26
  212. package/lib/WAUSync/USyncQuery.js +0 -79
  213. package/lib/WAUSync/USyncUser.d.ts +0 -10
  214. package/lib/WAUSync/USyncUser.js +0 -22
  215. package/lib/WAUSync/index.d.ts +0 -3
  216. package/lib/WAUSync/index.js +0 -19
  217. /package/{lib → src}/Defaults/phonenumber-mcc.json +0 -0
  218. /package/{lib → src}/Socket/Client/abstract-socket-client.js +0 -0
  219. /package/{lib → src}/Store/index.js +0 -0
  220. /package/{lib → src}/Store/make-ordered-dictionary.js +0 -0
  221. /package/{lib → src}/Types/Auth.js +0 -0
  222. /package/{lib → src}/Types/Call.js +0 -0
  223. /package/{lib → src}/Types/Chat.js +0 -0
  224. /package/{lib → src}/Types/Contact.js +0 -0
  225. /package/{lib → src}/Types/Events.js +0 -0
  226. /package/{lib → src}/Types/GroupMetadata.js +0 -0
  227. /package/{lib → src}/Types/Label.js +0 -0
  228. /package/{lib → src}/Types/LabelAssociation.js +0 -0
  229. /package/{lib → src}/Types/Message.js +0 -0
  230. /package/{lib → src}/Types/Newsletter.js +0 -0
  231. /package/{lib → src}/Types/Product.js +0 -0
  232. /package/{lib → src}/Types/Signal.js +0 -0
  233. /package/{lib → src}/Types/Socket.js +0 -0
  234. /package/{lib → src}/Types/State.js +0 -0
  235. /package/{lib → src}/Types/index.js +0 -0
  236. /package/{lib → src}/Utils/index.js +0 -0
  237. /package/{lib → src}/Utils/logger.js +0 -0
  238. /package/{lib → src}/Utils/lt-hash.js +0 -0
  239. /package/{lib → src}/Utils/noise-handler.js +0 -0
  240. /package/{lib → src}/WABinary/constants.js +0 -0
  241. /package/{lib → src}/WABinary/decode.js +0 -0
  242. /package/{lib → src}/WABinary/generic-utils.js +0 -0
  243. /package/{lib → src}/WABinary/index.js +0 -0
  244. /package/{lib → src}/WABinary/jid-utils.js +0 -0
  245. /package/{lib → src}/WABinary/types.js +0 -0
  246. /package/{lib → src}/WAM/BinaryInfo.js +0 -0
  247. /package/{lib → src}/WAM/constants.js +0 -0
  248. /package/{lib → src}/WAM/encode.js +0 -0
  249. /package/{lib → src}/WAM/index.js +0 -0
  250. /package/{lib → src}/gifted +0 -0
@@ -1,4 +1,13 @@
1
1
  "use strict";
2
+ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
3
+ function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
4
+ return new (P || (P = Promise))(function (resolve, reject) {
5
+ function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
6
+ function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
7
+ function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
8
+ step((generator = generator.apply(thisArg, _arguments || [])).next());
9
+ });
10
+ };
2
11
  Object.defineProperty(exports, "__esModule", { value: true });
3
12
  exports.extractNewsletterMetadata = exports.makeNewsletterSocket = void 0;
4
13
  const Types_1 = require("../Types");
@@ -9,38 +18,39 @@ const makeNewsletterSocket = (config) => {
9
18
  const sock = (0, groups_1.makeGroupsSocket)(config);
10
19
  const { authState, signalRepository, query, generateMessageTag } = sock;
11
20
  const encoder = new TextEncoder();
12
- const newsletterQuery = async (jid, type, content) => (query({
13
- tag: 'iq',
14
- attrs: {
15
- id: generateMessageTag(),
16
- type,
17
- xmlns: 'newsletter',
18
- to: jid,
19
- },
20
- content
21
- }));
22
- const newsletterWMexQuery = async (jid, queryId, content) => (query({
23
- tag: 'iq',
24
- attrs: {
25
- id: generateMessageTag(),
26
- type: 'get',
27
- xmlns: 'w:mex',
28
- to: WABinary_1.S_WHATSAPP_NET,
29
- },
30
- content: [
31
- {
32
- tag: 'query',
33
- attrs: { 'query_id': queryId },
34
- content: encoder.encode(JSON.stringify({
35
- variables: {
36
- 'newsletter_id': jid,
37
- ...content
38
- }
39
- }))
40
- }
41
- ]
42
- }));
43
- const parseFetchedUpdates = async (node, type) => {
21
+ const newsletterQuery = (jid, type, content) => __awaiter(void 0, void 0, void 0, function* () {
22
+ return (query({
23
+ tag: 'iq',
24
+ attrs: {
25
+ id: generateMessageTag(),
26
+ type,
27
+ xmlns: 'newsletter',
28
+ to: jid,
29
+ },
30
+ content
31
+ }));
32
+ });
33
+ const newsletterWMexQuery = (jid, queryId, content) => __awaiter(void 0, void 0, void 0, function* () {
34
+ return (query({
35
+ tag: 'iq',
36
+ attrs: {
37
+ id: generateMessageTag(),
38
+ type: 'get',
39
+ xmlns: 'w:mex',
40
+ to: WABinary_1.S_WHATSAPP_NET,
41
+ },
42
+ content: [
43
+ {
44
+ tag: 'query',
45
+ attrs: { 'query_id': queryId },
46
+ content: encoder.encode(JSON.stringify({
47
+ variables: Object.assign({ 'newsletter_id': jid }, content)
48
+ }))
49
+ }
50
+ ]
51
+ }));
52
+ });
53
+ const parseFetchedUpdates = (node, type) => __awaiter(void 0, void 0, void 0, function* () {
44
54
  let child;
45
55
  if (type === 'messages') {
46
56
  child = (0, WABinary_1.getBinaryNodeChild)(node, 'messages');
@@ -49,7 +59,7 @@ const makeNewsletterSocket = (config) => {
49
59
  const parent = (0, WABinary_1.getBinaryNodeChild)(node, 'message_updates');
50
60
  child = (0, WABinary_1.getBinaryNodeChild)(parent, 'messages');
51
61
  }
52
- return await Promise.all((0, WABinary_1.getAllBinaryNodeChildren)(child).map(async (messageNode) => {
62
+ return yield Promise.all((0, WABinary_1.getAllBinaryNodeChildren)(child).map((messageNode) => __awaiter(void 0, void 0, void 0, function* () {
53
63
  var _a, _b;
54
64
  messageNode.attrs.from = child === null || child === void 0 ? void 0 : child.attrs.jid;
55
65
  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');
@@ -62,65 +72,52 @@ const makeNewsletterSocket = (config) => {
62
72
  reactions
63
73
  };
64
74
  if (type === 'messages') {
65
- const { fullMessage: message, decrypt } = await (0, Utils_1.decryptMessageNode)(messageNode, authState.creds.me.id, authState.creds.me.lid || '', signalRepository, config.logger);
66
- await decrypt();
75
+ const { fullMessage: message, decrypt } = yield (0, Utils_1.decryptMessageNode)(messageNode, authState.creds.me.id, authState.creds.me.lid || '', signalRepository, config.logger);
76
+ yield decrypt();
67
77
  data.message = message;
68
78
  }
69
79
  return data;
70
- }));
71
- };
72
- return {
73
- ...sock,
74
- subscribeNewsletterUpdates: async (jid) => {
80
+ })));
81
+ });
82
+ return Object.assign(Object.assign({}, sock), { subscribeNewsletterUpdates: (jid) => __awaiter(void 0, void 0, void 0, function* () {
75
83
  var _a;
76
- const result = await newsletterQuery(jid, 'set', [{ tag: 'live_updates', attrs: {}, content: [] }]);
84
+ const result = yield newsletterQuery(jid, 'set', [{ tag: 'live_updates', attrs: {}, content: [] }]);
77
85
  return (_a = (0, WABinary_1.getBinaryNodeChild)(result, 'live_updates')) === null || _a === void 0 ? void 0 : _a.attrs;
78
- },
79
- newsletterReactionMode: async (jid, mode) => {
80
- await newsletterWMexQuery(jid, Types_1.QueryIds.JOB_MUTATION, {
86
+ }), newsletterReactionMode: (jid, mode) => __awaiter(void 0, void 0, void 0, function* () {
87
+ yield newsletterWMexQuery(jid, Types_1.QueryIds.JOB_MUTATION, {
81
88
  updates: { settings: { 'reaction_codes': { value: mode } } }
82
89
  });
83
- },
84
- newsletterUpdateDescription: async (jid, description) => {
85
- await newsletterWMexQuery(jid, Types_1.QueryIds.JOB_MUTATION, {
90
+ }), newsletterUpdateDescription: (jid, description) => __awaiter(void 0, void 0, void 0, function* () {
91
+ yield newsletterWMexQuery(jid, Types_1.QueryIds.JOB_MUTATION, {
86
92
  updates: { description: description || '', settings: null }
87
93
  });
88
- },
89
- newsletterUpdateName: async (jid, name) => {
90
- await newsletterWMexQuery(jid, Types_1.QueryIds.JOB_MUTATION, {
94
+ }), newsletterUpdateName: (jid, name) => __awaiter(void 0, void 0, void 0, function* () {
95
+ yield newsletterWMexQuery(jid, Types_1.QueryIds.JOB_MUTATION, {
91
96
  updates: { name, settings: null }
92
97
  });
93
- },
94
- newsletterUpdatePicture: async (jid, content) => {
95
- const { img } = await (0, Utils_1.generateProfilePicture)(content);
96
- await newsletterWMexQuery(jid, Types_1.QueryIds.JOB_MUTATION, {
98
+ }), newsletterUpdatePicture: (jid, content) => __awaiter(void 0, void 0, void 0, function* () {
99
+ const { img } = yield (0, Utils_1.generateProfilePicture)(content);
100
+ yield newsletterWMexQuery(jid, Types_1.QueryIds.JOB_MUTATION, {
97
101
  updates: { picture: img.toString('base64'), settings: null }
98
102
  });
99
- },
100
- newsletterRemovePicture: async (jid) => {
101
- await newsletterWMexQuery(jid, Types_1.QueryIds.JOB_MUTATION, {
103
+ }), newsletterRemovePicture: (jid) => __awaiter(void 0, void 0, void 0, function* () {
104
+ yield newsletterWMexQuery(jid, Types_1.QueryIds.JOB_MUTATION, {
102
105
  updates: { picture: '', settings: null }
103
106
  });
104
- },
105
- newsletterUnfollow: async (jid) => {
106
- await newsletterWMexQuery(jid, Types_1.QueryIds.UNFOLLOW);
107
- },
108
- newsletterFollow: async (jid) => {
109
- await newsletterWMexQuery(jid, Types_1.QueryIds.FOLLOW);
110
- },
111
- newsletterUnmute: async (jid) => {
112
- await newsletterWMexQuery(jid, Types_1.QueryIds.UNMUTE);
113
- },
114
- newsletterMute: async (jid) => {
115
- await newsletterWMexQuery(jid, Types_1.QueryIds.MUTE);
116
- },
117
- newsletterAction: async (jid, type) => {
118
- await newsletterWMexQuery(jid, Types_1.QueryIds[type.toUpperCase()]);
119
- },
120
- newsletterCreate: async (name, description) => {
107
+ }), newsletterUnfollow: (jid) => __awaiter(void 0, void 0, void 0, function* () {
108
+ yield newsletterWMexQuery(jid, Types_1.QueryIds.UNFOLLOW);
109
+ }), newsletterFollow: (jid) => __awaiter(void 0, void 0, void 0, function* () {
110
+ yield newsletterWMexQuery(jid, Types_1.QueryIds.FOLLOW);
111
+ }), newsletterUnmute: (jid) => __awaiter(void 0, void 0, void 0, function* () {
112
+ yield newsletterWMexQuery(jid, Types_1.QueryIds.UNMUTE);
113
+ }), newsletterMute: (jid) => __awaiter(void 0, void 0, void 0, function* () {
114
+ yield newsletterWMexQuery(jid, Types_1.QueryIds.MUTE);
115
+ }), newsletterAction: (jid, type) => __awaiter(void 0, void 0, void 0, function* () {
116
+ yield newsletterWMexQuery(jid, type.toUpperCase());
117
+ }), newsletterCreate: (name, description, reaction_codes) => __awaiter(void 0, void 0, void 0, function* () {
121
118
  //TODO: Implement TOS system wide for Meta AI, communities, and here etc.
122
119
  /**tos query */
123
- await query({
120
+ yield query({
124
121
  tag: 'iq',
125
122
  attrs: {
126
123
  to: WABinary_1.S_WHATSAPP_NET,
@@ -139,13 +136,12 @@ const makeNewsletterSocket = (config) => {
139
136
  }
140
137
  ]
141
138
  });
142
- const result = await newsletterWMexQuery(undefined, Types_1.QueryIds.CREATE, {
143
- input: { name, description, settings: null }
139
+ const result = yield newsletterWMexQuery(undefined, Types_1.QueryIds.CREATE, {
140
+ input: { name, description, settings: { 'reaction_codes': { value: reaction_codes.toUpperCase() } } }
144
141
  });
145
142
  return (0, exports.extractNewsletterMetadata)(result, true);
146
- },
147
- newsletterMetadata: async (type, key, role) => {
148
- const result = await newsletterWMexQuery(undefined, Types_1.QueryIds.METADATA, {
143
+ }), newsletterMetadata: (type, key, role) => __awaiter(void 0, void 0, void 0, function* () {
144
+ const result = yield newsletterWMexQuery(undefined, Types_1.QueryIds.METADATA, {
149
145
  input: {
150
146
  key,
151
147
  type: type.toUpperCase(),
@@ -156,58 +152,53 @@ const makeNewsletterSocket = (config) => {
156
152
  'fetch_creation_time': true
157
153
  });
158
154
  return (0, exports.extractNewsletterMetadata)(result);
159
- },
160
- newsletterAdminCount: async (jid) => {
155
+ }), newsletterAdminCount: (jid) => __awaiter(void 0, void 0, void 0, function* () {
161
156
  var _a, _b;
162
- const result = await newsletterWMexQuery(jid, Types_1.QueryIds.ADMIN_COUNT);
157
+ const result = yield newsletterWMexQuery(jid, Types_1.QueryIds.ADMIN_COUNT);
163
158
  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();
164
159
  return JSON.parse(buff).data[Types_1.XWAPaths.ADMIN_COUNT].admin_count;
165
- },
160
+ }),
166
161
  /**user is Lid, not Jid */
167
- newsletterChangeOwner: async (jid, user) => {
168
- await newsletterWMexQuery(jid, Types_1.QueryIds.CHANGE_OWNER, {
162
+ newsletterChangeOwner: (jid, user) => __awaiter(void 0, void 0, void 0, function* () {
163
+ yield newsletterWMexQuery(jid, Types_1.QueryIds.CHANGE_OWNER, {
169
164
  'user_id': user
170
165
  });
171
- },
166
+ }),
172
167
  /**user is Lid, not Jid */
173
- newsletterDemote: async (jid, user) => {
174
- await newsletterWMexQuery(jid, Types_1.QueryIds.DEMOTE, {
168
+ newsletterDemote: (jid, user) => __awaiter(void 0, void 0, void 0, function* () {
169
+ yield newsletterWMexQuery(jid, Types_1.QueryIds.DEMOTE, {
175
170
  'user_id': user
176
171
  });
177
- },
178
- newsletterDelete: async (jid) => {
179
- await newsletterWMexQuery(jid, Types_1.QueryIds.DELETE);
180
- },
172
+ }), newsletterDelete: (jid) => __awaiter(void 0, void 0, void 0, function* () {
173
+ yield newsletterWMexQuery(jid, Types_1.QueryIds.DELETE);
174
+ }),
181
175
  /**if code wasn't passed, the reaction will be removed (if is reacted) */
182
- newsletterReactMessage: async (jid, serverId, code) => {
183
- await query({
176
+ newsletterReactMessage: (jid, serverId, code) => __awaiter(void 0, void 0, void 0, function* () {
177
+ yield query({
184
178
  tag: 'message',
185
- attrs: { to: jid, ...(!code ? { edit: '7' } : {}), type: 'reaction', 'server_id': serverId, id: (0, Utils_1.generateMessageID)() },
179
+ attrs: Object.assign(Object.assign({ to: jid }, (!code ? { edit: '7' } : {})), { type: 'reaction', 'server_id': serverId, id: (0, Utils_1.generateMessageID)() }),
186
180
  content: [{
187
181
  tag: 'reaction',
188
182
  attrs: code ? { code } : {}
189
183
  }]
190
184
  });
191
- },
192
- newsletterFetchMessages: async (type, key, count, after) => {
193
- const result = await newsletterQuery(WABinary_1.S_WHATSAPP_NET, 'get', [
185
+ }), newsletterFetchMessages: (type, key, count, after) => __awaiter(void 0, void 0, void 0, function* () {
186
+ const result = yield newsletterQuery(WABinary_1.S_WHATSAPP_NET, 'get', [
194
187
  {
195
188
  tag: 'messages',
196
- attrs: { type, ...(type === 'invite' ? { key } : { jid: key }), count: count.toString(), after: (after === null || after === void 0 ? void 0 : after.toString()) || '100' }
189
+ attrs: Object.assign(Object.assign({ type }, (type === 'invite' ? { key } : { jid: key })), { count: count.toString(), after: (after === null || after === void 0 ? void 0 : after.toString()) || '100' })
197
190
  }
198
191
  ]);
199
- return await parseFetchedUpdates(result, 'messages');
200
- },
201
- newsletterFetchUpdates: async (jid, count, after, since) => {
202
- const result = await newsletterQuery(jid, 'get', [
192
+ return yield parseFetchedUpdates(result, 'messages');
193
+ }), newsletterFetchUpdates: (jid, count, after, since) => __awaiter(void 0, void 0, void 0, function* () {
194
+ const result = yield newsletterQuery(jid, 'get', [
203
195
  {
204
196
  tag: 'message_updates',
205
197
  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' }
206
198
  }
207
199
  ]);
208
- return await parseFetchedUpdates(result, 'updates');
209
- }
210
- };
200
+ return yield parseFetchedUpdates(result, 'updates');
201
+ }) });
211
202
  };
212
203
  exports.makeNewsletterSocket = makeNewsletterSocket;
213
204
  const extractNewsletterMetadata = (node, isCreate) => {
@@ -0,0 +1,282 @@
1
+ import { NewsletterFetchedUpdate, NewsletterMetadata, NewsletterReaction, NewsletterReactionMode, NewsletterViewRole, QueryIds, SocketConfig, WAMediaUpload, XWAPaths } from '../Types'
2
+ import { decryptMessageNode, generateMessageID, generateProfilePicture } from '../Utils'
3
+ import { BinaryNode, getAllBinaryNodeChildren, getBinaryNodeChild, getBinaryNodeChildren, S_WHATSAPP_NET } from '../WABinary'
4
+ import { makeGroupsSocket } from './groups'
5
+
6
+ export const makeNewsletterSocket = (config: SocketConfig) => {
7
+ const sock = makeGroupsSocket(config)
8
+ const { authState, signalRepository, query, generateMessageTag } = sock
9
+
10
+ const encoder = new TextEncoder()
11
+
12
+ const newsletterQuery = async(jid: string, type: 'get' | 'set', content: BinaryNode[]) => (
13
+ query({
14
+ tag: 'iq',
15
+ attrs: {
16
+ id: generateMessageTag(),
17
+ type,
18
+ xmlns: 'newsletter',
19
+ to: jid,
20
+ },
21
+ content
22
+ })
23
+ )
24
+
25
+ const newsletterWMexQuery = async(jid: string | undefined, queryId: QueryIds, content?: object) => (
26
+ query({
27
+ tag: 'iq',
28
+ attrs: {
29
+ id: generateMessageTag(),
30
+ type: 'get',
31
+ xmlns: 'w:mex',
32
+ to: S_WHATSAPP_NET,
33
+ },
34
+ content: [
35
+ {
36
+ tag: 'query',
37
+ attrs: { 'query_id': queryId },
38
+ content: encoder.encode(
39
+ JSON.stringify({
40
+ variables: {
41
+ 'newsletter_id': jid,
42
+ ...content
43
+ }
44
+ })
45
+ )
46
+ }
47
+ ]
48
+ })
49
+ )
50
+
51
+ const parseFetchedUpdates = async(node: BinaryNode, type: 'messages' | 'updates') => {
52
+ let child
53
+
54
+ if(type === 'messages') {
55
+ child = getBinaryNodeChild(node, 'messages')
56
+ } else {
57
+ const parent = getBinaryNodeChild(node, 'message_updates')
58
+ child = getBinaryNodeChild(parent, 'messages')
59
+ }
60
+
61
+ return await Promise.all(getAllBinaryNodeChildren(child).map(async messageNode => {
62
+ messageNode.attrs.from = child?.attrs.jid as string
63
+
64
+ const views = parseInt(getBinaryNodeChild(messageNode, 'views_count')?.attrs?.count || '0')
65
+ const reactionNode = getBinaryNodeChild(messageNode, 'reactions')
66
+ const reactions = getBinaryNodeChildren(reactionNode, 'reaction')
67
+ .map(({ attrs }) => ({ count: +attrs.count, code: attrs.code } as NewsletterReaction))
68
+
69
+ const data: NewsletterFetchedUpdate = {
70
+ 'server_id': messageNode.attrs.server_id,
71
+ views,
72
+ reactions
73
+ }
74
+
75
+ if(type === 'messages') {
76
+ const { fullMessage: message, decrypt } = await decryptMessageNode(
77
+ messageNode,
78
+ authState.creds.me!.id,
79
+ authState.creds.me!.lid || '',
80
+ signalRepository,
81
+ config.logger
82
+ )
83
+
84
+ await decrypt()
85
+
86
+ data.message = message
87
+ }
88
+
89
+ return data
90
+ }))
91
+ }
92
+
93
+ return {
94
+ ...sock,
95
+ subscribeNewsletterUpdates: async(jid: string) => {
96
+ const result = await newsletterQuery(jid, 'set', [{ tag: 'live_updates', attrs: {}, content: [] }])
97
+
98
+ return getBinaryNodeChild(result, 'live_updates')?.attrs as {duration: string}
99
+ },
100
+
101
+ newsletterReactionMode: async(jid: string, mode: NewsletterReactionMode) => {
102
+ await newsletterWMexQuery(jid, QueryIds.JOB_MUTATION, {
103
+ updates: { settings: { 'reaction_codes': { value: mode } } }
104
+ })
105
+ },
106
+
107
+ newsletterUpdateDescription: async(jid: string, description?: string) => {
108
+ await newsletterWMexQuery(jid, QueryIds.JOB_MUTATION, {
109
+ updates: { description: description || '', settings: null }
110
+ })
111
+ },
112
+
113
+ newsletterUpdateName: async(jid: string, name: string) => {
114
+ await newsletterWMexQuery(jid, QueryIds.JOB_MUTATION, {
115
+ updates: { name, settings: null }
116
+ })
117
+ },
118
+
119
+ newsletterUpdatePicture: async(jid: string, content: WAMediaUpload) => {
120
+ const { img } = await generateProfilePicture(content)
121
+
122
+ await newsletterWMexQuery(jid, QueryIds.JOB_MUTATION, {
123
+ updates: { picture: img.toString('base64'), settings: null }
124
+ })
125
+ },
126
+
127
+ newsletterRemovePicture: async(jid: string) => {
128
+ await newsletterWMexQuery(jid, QueryIds.JOB_MUTATION, {
129
+ updates: { picture: '', settings: null }
130
+ })
131
+ },
132
+
133
+ newsletterUnfollow: async(jid: string) => {
134
+ await newsletterWMexQuery(jid, QueryIds.UNFOLLOW)
135
+ },
136
+
137
+ newsletterFollow: async(jid: string) => {
138
+ await newsletterWMexQuery(jid, QueryIds.FOLLOW)
139
+ },
140
+
141
+ newsletterUnmute: async(jid: string) => {
142
+ await newsletterWMexQuery(jid, QueryIds.UNMUTE)
143
+ },
144
+
145
+ newsletterMute: async(jid: string) => {
146
+ await newsletterWMexQuery(jid, QueryIds.MUTE)
147
+ },
148
+
149
+ newsletterAction: async(jid: string, type: 'follow' | 'unfollow' | 'mute' | 'unmute') => {
150
+ await newsletterWMexQuery(jid, type.toUpperCase() as QueryIds)
151
+ },
152
+
153
+ newsletterCreate: async(name: string, description: string, reaction_codes: string) => {
154
+ //TODO: Implement TOS system wide for Meta AI, communities, and here etc.
155
+ /**tos query */
156
+ await query({
157
+ tag: 'iq',
158
+ attrs: {
159
+ to: S_WHATSAPP_NET,
160
+ xmlns: 'tos',
161
+ id: generateMessageTag(),
162
+ type: 'set'
163
+ },
164
+ content: [
165
+ {
166
+ tag: 'notice',
167
+ attrs: {
168
+ id: '20601218',
169
+ stage: '5'
170
+ },
171
+ content: []
172
+ }
173
+ ]
174
+ })
175
+ const result = await newsletterWMexQuery(undefined, QueryIds.CREATE, {
176
+ input: { name, description, settings: { 'reaction_codes': { value: reaction_codes.toUpperCase() } } }
177
+ })
178
+
179
+ return extractNewsletterMetadata(result, true)
180
+ },
181
+
182
+ newsletterMetadata: async(type: 'invite' | 'jid', key: string, role?: NewsletterViewRole) => {
183
+ const result = await newsletterWMexQuery(undefined, QueryIds.METADATA, {
184
+ input: {
185
+ key,
186
+ type: type.toUpperCase(),
187
+ 'view_role': role || 'GUEST'
188
+ },
189
+ 'fetch_viewer_metadata': true,
190
+ 'fetch_full_image': true,
191
+ 'fetch_creation_time': true
192
+ })
193
+
194
+ return extractNewsletterMetadata(result)
195
+ },
196
+
197
+ newsletterAdminCount: async(jid: string) => {
198
+ const result = await newsletterWMexQuery(jid, QueryIds.ADMIN_COUNT)
199
+
200
+ const buff = getBinaryNodeChild(result, 'result')?.content?.toString()
201
+
202
+ return JSON.parse(buff!).data[XWAPaths.ADMIN_COUNT].admin_count as number
203
+ },
204
+
205
+ /**user is Lid, not Jid */
206
+ newsletterChangeOwner: async(jid: string, user: string) => {
207
+ await newsletterWMexQuery(jid, QueryIds.CHANGE_OWNER, {
208
+ 'user_id': user
209
+ })
210
+ },
211
+
212
+ /**user is Lid, not Jid */
213
+ newsletterDemote: async(jid: string, user: string) => {
214
+ await newsletterWMexQuery(jid, QueryIds.DEMOTE, {
215
+ 'user_id': user
216
+ })
217
+ },
218
+
219
+ newsletterDelete: async(jid: string) => {
220
+ await newsletterWMexQuery(jid, QueryIds.DELETE)
221
+ },
222
+
223
+ /**if code wasn't passed, the reaction will be removed (if is reacted) */
224
+ newsletterReactMessage: async(jid: string, serverId: string, code?: string) => {
225
+ await query({
226
+ tag: 'message',
227
+ attrs: { to: jid, ...(!code ? { edit: '7' } : {}), type: 'reaction', 'server_id': serverId, id: generateMessageID() },
228
+ content: [{
229
+ tag: 'reaction',
230
+ attrs: code ? { code } : {}
231
+ }]
232
+ })
233
+ },
234
+
235
+ newsletterFetchMessages: async(type: 'invite' | 'jid', key: string, count: number, after?: number) => {
236
+ const result = await newsletterQuery(S_WHATSAPP_NET, 'get', [
237
+ {
238
+ tag: 'messages',
239
+ attrs: { type, ...(type === 'invite' ? { key } : { jid: key }), count: count.toString(), after: after?.toString() || '100' }
240
+ }
241
+ ])
242
+
243
+ return await parseFetchedUpdates(result, 'messages')
244
+ },
245
+
246
+ newsletterFetchUpdates: async(jid: string, count: number, after?: number, since?: number) => {
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
+ export const extractNewsletterMetadata = (node: BinaryNode, isCreate?: boolean) => {
260
+ const result = getBinaryNodeChild(node, 'result')?.content?.toString()
261
+ const metadataPath = JSON.parse(result!).data[isCreate ? XWAPaths.CREATE : XWAPaths.NEWSLETTER]
262
+
263
+ const metadata: NewsletterMetadata = {
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: metadataPath.thread_metadata.picture?.direct_path || null,
274
+ preview: metadataPath.thread_metadata.preview?.direct_path || null,
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
+
281
+ return metadata
282
+ }