@baileys-md/baileys 11.0.3 → 11.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (122) hide show
  1. package/LICENSE +1 -1
  2. package/README.md +1 -1
  3. package/WAProto/index.js +4182 -13516
  4. package/WASignalGroup/GroupProtocol.js +1697 -0
  5. package/WASignalGroup/ciphertext_message.js +16 -0
  6. package/WASignalGroup/group_cipher.js +120 -0
  7. package/WASignalGroup/group_session_builder.js +46 -0
  8. package/WASignalGroup/index.js +5 -0
  9. package/WASignalGroup/keyhelper.js +21 -0
  10. package/WASignalGroup/protobufs.js +3 -0
  11. package/WASignalGroup/queue_job.js +69 -0
  12. package/WASignalGroup/sender_chain_key.js +50 -0
  13. package/WASignalGroup/sender_key_distribution_message.js +78 -0
  14. package/WASignalGroup/sender_key_message.js +92 -0
  15. package/WASignalGroup/sender_key_name.js +70 -0
  16. package/WASignalGroup/sender_key_record.js +56 -0
  17. package/WASignalGroup/sender_key_state.js +129 -0
  18. package/{lib/Signal/Group/sender-message-key.js → WASignalGroup/sender_message_key.js} +16 -4
  19. package/lib/Defaults/baileys-version.json +3 -0
  20. package/lib/Defaults/index.js +71 -52
  21. package/lib/Defaults/{phonenumber-mcc.js → phonenumber-mcc.json} +1 -1
  22. package/lib/Signal/libsignal.js +61 -41
  23. package/lib/Socket/Client/abstract-socket-client.js +13 -0
  24. package/lib/Socket/Client/index.js +19 -3
  25. package/lib/Socket/Client/mobile-socket-client.js +65 -0
  26. package/lib/Socket/Client/web-socket-client.js +62 -0
  27. package/lib/Socket/business.js +42 -37
  28. package/lib/Socket/chats.js +187 -194
  29. package/lib/Socket/groups.js +90 -87
  30. package/lib/Socket/index.js +8 -7
  31. package/lib/Socket/messages-recv.js +335 -360
  32. package/lib/Socket/messages-send.js +279 -156
  33. package/lib/Socket/newsletter.js +213 -144
  34. package/lib/Socket/registration.js +166 -0
  35. package/lib/Socket/socket.js +161 -128
  36. package/lib/Socket/usync.js +26 -19
  37. package/lib/Store/index.js +8 -0
  38. package/lib/Store/make-cache-manager-store.js +83 -0
  39. package/lib/{Utils → Store}/make-in-memory-store.js +27 -19
  40. package/lib/Store/make-mongo-store.js +567 -0
  41. package/lib/{Utils → Store}/make-ordered-dictionary.js +5 -2
  42. package/lib/{Utils → Store}/object-repository.js +4 -1
  43. package/lib/Types/Auth.js +2 -2
  44. package/lib/Types/Call.js +2 -2
  45. package/lib/Types/Chat.js +4 -8
  46. package/lib/Types/Contact.js +2 -2
  47. package/lib/Types/Events.js +2 -2
  48. package/lib/Types/GroupMetadata.js +2 -2
  49. package/lib/Types/Label.js +5 -3
  50. package/lib/Types/LabelAssociation.js +5 -3
  51. package/lib/Types/Message.js +7 -7
  52. package/lib/Types/Newsletter.js +17 -30
  53. package/lib/Types/Product.js +2 -2
  54. package/lib/Types/Signal.js +2 -2
  55. package/lib/Types/Socket.js +2 -3
  56. package/lib/Types/State.js +2 -2
  57. package/lib/Types/USync.js +2 -2
  58. package/lib/Types/index.js +31 -15
  59. package/lib/Utils/auth-utils.js +47 -31
  60. package/lib/Utils/baileys-event-stream.js +22 -15
  61. package/lib/Utils/business.js +69 -66
  62. package/lib/Utils/chat-utils.js +195 -200
  63. package/lib/Utils/crypto.js +85 -70
  64. package/lib/Utils/decode-wa-message.js +51 -46
  65. package/lib/Utils/event-buffer.js +46 -36
  66. package/lib/Utils/generics.js +188 -116
  67. package/lib/Utils/history.js +46 -37
  68. package/lib/Utils/index.js +33 -19
  69. package/lib/Utils/link-preview.js +55 -14
  70. package/lib/Utils/logger.js +7 -3
  71. package/lib/Utils/lt-hash.js +26 -23
  72. package/lib/Utils/make-mutex.js +10 -7
  73. package/lib/Utils/messages-media.js +368 -239
  74. package/lib/Utils/messages.js +510 -278
  75. package/lib/Utils/noise-handler.js +31 -22
  76. package/lib/Utils/process-message.js +148 -144
  77. package/lib/Utils/signal.js +64 -71
  78. package/lib/Utils/use-multi-file-auth-state.js +32 -14
  79. package/lib/Utils/validate-connection.js +115 -72
  80. package/lib/WABinary/constants.js +20 -1281
  81. package/lib/WABinary/decode.js +52 -15
  82. package/lib/WABinary/encode.js +48 -14
  83. package/lib/WABinary/generic-utils.js +39 -31
  84. package/lib/WABinary/index.js +21 -6
  85. package/lib/WABinary/jid-utils.js +40 -23
  86. package/lib/WABinary/types.js +2 -2
  87. package/lib/WAM/BinaryInfo.js +5 -2
  88. package/lib/WAM/constants.js +2366 -2257
  89. package/lib/WAM/encode.js +21 -17
  90. package/lib/WAM/index.js +19 -4
  91. package/lib/WAUSync/Protocols/USyncContactProtocol.js +11 -8
  92. package/lib/WAUSync/Protocols/USyncDeviceProtocol.js +14 -11
  93. package/lib/WAUSync/Protocols/USyncDisappearingModeProtocol.js +12 -9
  94. package/lib/WAUSync/Protocols/USyncStatusProtocol.js +13 -9
  95. package/lib/WAUSync/Protocols/UsyncBotProfileProtocol.js +22 -20
  96. package/lib/WAUSync/Protocols/UsyncLIDProtocol.js +6 -3
  97. package/lib/WAUSync/Protocols/index.js +20 -5
  98. package/lib/WAUSync/USyncQuery.js +32 -34
  99. package/lib/WAUSync/USyncUser.js +5 -2
  100. package/lib/WAUSync/index.js +19 -4
  101. package/lib/index.js +33 -11
  102. package/package.json +61 -21
  103. package/WAProto/GenerateStatics.sh +0 -3
  104. package/WAProto/WAProto.proto +0 -4633
  105. package/WAProto/fix-imports.js +0 -29
  106. package/lib/Defaults/baileys-version.js +0 -1
  107. package/lib/Signal/Group/ciphertext-message.js +0 -12
  108. package/lib/Signal/Group/group-session-builder.js +0 -30
  109. package/lib/Signal/Group/group_cipher.js +0 -94
  110. package/lib/Signal/Group/index.js +0 -12
  111. package/lib/Signal/Group/keyhelper.js +0 -19
  112. package/lib/Signal/Group/queue-job.js +0 -54
  113. package/lib/Signal/Group/sender-chain-key.js +0 -32
  114. package/lib/Signal/Group/sender-key-distribution-message.js +0 -63
  115. package/lib/Signal/Group/sender-key-message.js +0 -67
  116. package/lib/Signal/Group/sender-key-name.js +0 -48
  117. package/lib/Signal/Group/sender-key-record.js +0 -50
  118. package/lib/Signal/Group/sender-key-state.js +0 -96
  119. package/lib/Socket/Client/types.js +0 -11
  120. package/lib/Socket/Client/websocket.js +0 -50
  121. package/lib/Socket/communities.js +0 -351
  122. package/lib/Socket/mex.js +0 -42
@@ -1,179 +1,248 @@
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 { executeWMexQuery as genericExecuteWMexQuery } from './mex.js';
5
- const parseNewsletterCreateResponse = (response) => {
6
- const { id, thread_metadata: thread, viewer_metadata: viewer } = response;
7
- return {
8
- id: id,
9
- owner: undefined,
10
- name: thread.name.text,
11
- creation_time: parseInt(thread.creation_time, 10),
12
- description: thread.description.text,
13
- invite: thread.invite,
14
- subscribers: parseInt(thread.subscribers_count, 10),
15
- verification: thread.verification,
16
- picture: {
17
- id: thread.picture.id,
18
- directPath: thread.picture.direct_path
19
- },
20
- mute_state: viewer.mute
21
- };
22
- };
23
- const parseNewsletterMetadata = (result) => {
24
- if (typeof result !== 'object' || result === null) {
25
- return null;
26
- }
27
- if ('id' in result && typeof result.id === 'string') {
28
- return result;
29
- }
30
- if ('result' in result && typeof result.result === 'object' && result.result !== null && 'id' in result.result) {
31
- return result.result;
32
- }
33
- return null;
34
- };
35
- export const makeNewsletterSocket = (sock) => {
36
- const { query, generateMessageTag } = sock;
37
- const executeWMexQuery = (variables, queryId, dataPath) => {
38
- return genericExecuteWMexQuery(variables, queryId, dataPath, query, generateMessageTag);
39
- };
40
- const newsletterUpdate = async (jid, updates) => {
41
- const variables = {
42
- newsletter_id: jid,
43
- updates: {
44
- ...updates,
45
- settings: null
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
+ var QueryIds;
9
+ (function (QueryIds) {
10
+ QueryIds["JOB_MUTATION"] = "7150902998257522";
11
+ QueryIds["METADATA"] = "6620195908089573";
12
+ QueryIds["UNFOLLOW"] = "7238632346214362";
13
+ QueryIds["FOLLOW"] = "7871414976211147";
14
+ QueryIds["UNMUTE"] = "7337137176362961";
15
+ QueryIds["MUTE"] = "25151904754424642";
16
+ QueryIds["CREATE"] = "6996806640408138";
17
+ QueryIds["ADMIN_COUNT"] = "7130823597031706";
18
+ QueryIds["CHANGE_OWNER"] = "7341777602580933";
19
+ QueryIds["DELETE"] = "8316537688363079";
20
+ QueryIds["DEMOTE"] = "6551828931592903";
21
+ })(QueryIds || (QueryIds = {}));
22
+ const makeNewsletterSocket = (config) => {
23
+ const sock = (0, groups_1.makeGroupsSocket)(config);
24
+ const { authState, signalRepository, query, generateMessageTag } = sock;
25
+ const encoder = new TextEncoder();
26
+ const newsletterQuery = async (jid, type, content) => (query({
27
+ tag: 'iq',
28
+ attrs: {
29
+ id: generateMessageTag(),
30
+ type,
31
+ xmlns: 'newsletter',
32
+ to: jid,
33
+ },
34
+ content
35
+ }));
36
+ const newsletterWMexQuery = async (jid, query_id, content) => (query({
37
+ tag: 'iq',
38
+ attrs: {
39
+ id: generateMessageTag(),
40
+ type: 'get',
41
+ xmlns: 'w:mex',
42
+ to: WABinary_1.S_WHATSAPP_NET,
43
+ },
44
+ content: [
45
+ {
46
+ tag: 'query',
47
+ attrs: { query_id },
48
+ content: encoder.encode(JSON.stringify({ variables: { newsletter_id: jid, ...content } }))
46
49
  }
47
- };
48
- return executeWMexQuery(variables, QueryIds.UPDATE_METADATA, 'xwa2_newsletter_update');
50
+ ]
51
+ }));
52
+ const parseFetchedUpdates = async (node, type) => {
53
+ let child;
54
+ if (type === 'messages')
55
+ child = (0, WABinary_1.getBinaryNodeChild)(node, 'messages');
56
+ else {
57
+ const parent = (0, WABinary_1.getBinaryNodeChild)(node, 'message_updates');
58
+ child = (0, WABinary_1.getBinaryNodeChild)(parent, 'messages');
59
+ }
60
+ return await Promise.all((0, WABinary_1.getAllBinaryNodeChildren)(child).map(async (messageNode) => {
61
+ var _a, _b;
62
+ messageNode.attrs.from = child === null || child === void 0 ? void 0 : child.attrs.jid;
63
+ const views = (_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;
64
+ const reactionNode = (0, WABinary_1.getBinaryNodeChild)(messageNode, 'reactions');
65
+ const reactions = (0, WABinary_1.getBinaryNodeChildren)(reactionNode, 'reaction')
66
+ .map(({ attrs }) => ({ count: +attrs.count, code: attrs.code }));
67
+ let data;
68
+ if (type === 'messages') {
69
+ const { fullMessage: message, decrypt } = await (0, Utils_1.decryptMessageNode)(messageNode, authState.creds.me.id, authState.creds.me.lid || '', signalRepository, config.logger);
70
+ await decrypt();
71
+ data = {
72
+ server_id: messageNode.attrs.server_id,
73
+ views: views ? +views : undefined,
74
+ reactions,
75
+ message
76
+ };
77
+ return data;
78
+ }
79
+ else {
80
+ data = {
81
+ server_id: messageNode.attrs.server_id,
82
+ views: views ? +views : undefined,
83
+ reactions
84
+ };
85
+ return data;
86
+ }
87
+ }));
49
88
  };
50
89
  return {
51
90
  ...sock,
52
- newsletterCreate: async (name, description) => {
53
- const variables = {
54
- input: {
55
- name,
56
- description: description ?? null
57
- }
58
- };
59
- const rawResponse = await executeWMexQuery(variables, QueryIds.CREATE, XWAPaths.xwa2_newsletter_create);
60
- return parseNewsletterCreateResponse(rawResponse);
61
- },
62
- newsletterUpdate,
63
- newsletterSubscribers: async (jid) => {
64
- return executeWMexQuery({ newsletter_id: jid }, QueryIds.SUBSCRIBERS, XWAPaths.xwa2_newsletter_subscribers);
91
+ subscribeNewsletterUpdates: async (jid) => {
92
+ var _a;
93
+ const result = await newsletterQuery(jid, 'set', [{ tag: 'live_updates', attrs: {}, content: [] }]);
94
+ return (_a = (0, WABinary_1.getBinaryNodeChild)(result, 'live_updates')) === null || _a === void 0 ? void 0 : _a.attrs;
65
95
  },
66
- newsletterMetadata: async (type, key) => {
67
- const variables = {
68
- fetch_creation_time: true,
69
- fetch_full_image: true,
70
- fetch_viewer_metadata: true,
71
- input: {
72
- key,
73
- type: type.toUpperCase()
74
- }
75
- };
76
- const result = await executeWMexQuery(variables, QueryIds.METADATA, XWAPaths.xwa2_newsletter_metadata);
77
- return parseNewsletterMetadata(result);
96
+ newsletterReactionMode: async (jid, mode) => {
97
+ await newsletterWMexQuery(jid, QueryIds.JOB_MUTATION, {
98
+ updates: { settings: { reaction_codes: { value: mode } } }
99
+ });
78
100
  },
79
- newsletterFollow: (jid) => {
80
- return executeWMexQuery({ newsletter_id: jid }, QueryIds.FOLLOW, XWAPaths.xwa2_newsletter_follow);
101
+ newsletterUpdateDescription: async (jid, description) => {
102
+ await newsletterWMexQuery(jid, QueryIds.JOB_MUTATION, {
103
+ updates: { description: description || '', settings: null }
104
+ });
81
105
  },
82
- newsletterUnfollow: (jid) => {
83
- return executeWMexQuery({ newsletter_id: jid }, QueryIds.UNFOLLOW, XWAPaths.xwa2_newsletter_unfollow);
106
+ newsletterUpdateName: async (jid, name) => {
107
+ await newsletterWMexQuery(jid, QueryIds.JOB_MUTATION, {
108
+ updates: { name, settings: null }
109
+ });
84
110
  },
85
- newsletterMute: (jid) => {
86
- return executeWMexQuery({ newsletter_id: jid }, QueryIds.MUTE, XWAPaths.xwa2_newsletter_mute_v2);
111
+ newsletterUpdatePicture: async (jid, content) => {
112
+ const { img } = await (0, Utils_1.generateProfilePicture)(content);
113
+ await newsletterWMexQuery(jid, QueryIds.JOB_MUTATION, {
114
+ updates: { picture: img.toString('base64'), settings: null }
115
+ });
87
116
  },
88
- newsletterUnmute: (jid) => {
89
- return executeWMexQuery({ newsletter_id: jid }, QueryIds.UNMUTE, XWAPaths.xwa2_newsletter_unmute_v2);
117
+ newsletterRemovePicture: async (jid) => {
118
+ await newsletterWMexQuery(jid, QueryIds.JOB_MUTATION, {
119
+ updates: { picture: '', settings: null }
120
+ });
90
121
  },
91
- newsletterUpdateName: async (jid, name) => {
92
- return await newsletterUpdate(jid, { name });
122
+ newsletterUnfollow: async (jid) => {
123
+ await newsletterWMexQuery(jid, QueryIds.UNFOLLOW);
93
124
  },
94
- newsletterUpdateDescription: async (jid, description) => {
95
- return await newsletterUpdate(jid, { description });
125
+ newsletterFollow: async (jid) => {
126
+ await newsletterWMexQuery(jid, QueryIds.FOLLOW);
96
127
  },
97
- newsletterUpdatePicture: async (jid, content) => {
98
- const { img } = await generateProfilePicture(content);
99
- return await newsletterUpdate(jid, { picture: img.toString('base64') });
128
+ newsletterUnmute: async (jid) => {
129
+ await newsletterWMexQuery(jid, QueryIds.UNMUTE);
100
130
  },
101
- newsletterRemovePicture: async (jid) => {
102
- return await newsletterUpdate(jid, { picture: '' });
131
+ newsletterMute: async (jid) => {
132
+ await newsletterWMexQuery(jid, QueryIds.MUTE);
103
133
  },
104
- newsletterReactMessage: async (jid, serverId, reaction) => {
134
+ newsletterCreate: async (name, description) => {
105
135
  await query({
106
- tag: 'message',
107
- attrs: {
108
- to: jid,
109
- ...(reaction ? {} : { edit: '7' }),
110
- type: 'reaction',
111
- server_id: serverId,
112
- id: generateMessageTag()
113
- },
114
- content: [
115
- {
116
- tag: 'reaction',
117
- attrs: reaction ? { code: reaction } : {}
118
- }
119
- ]
120
- });
121
- },
122
- newsletterFetchMessages: async (jid, count, since, after) => {
123
- const messageUpdateAttrs = {
124
- count: count.toString()
125
- };
126
- if (typeof since === 'number') {
127
- messageUpdateAttrs.since = since.toString();
128
- }
129
- if (after) {
130
- messageUpdateAttrs.after = after.toString();
131
- }
132
- const result = await query({
133
136
  tag: 'iq',
134
137
  attrs: {
138
+ to: WABinary_1.S_WHATSAPP_NET,
139
+ xmlns: 'tos',
135
140
  id: generateMessageTag(),
136
- type: 'get',
137
- xmlns: 'newsletter',
138
- to: jid
141
+ type: 'set'
139
142
  },
140
143
  content: [
141
144
  {
142
- tag: 'message_updates',
143
- attrs: messageUpdateAttrs
145
+ tag: 'notice',
146
+ attrs: {
147
+ id: '20601218',
148
+ stage: '5'
149
+ },
150
+ content: []
144
151
  }
145
152
  ]
146
153
  });
147
- return result;
154
+ const result = await newsletterWMexQuery(undefined, QueryIds.CREATE, {
155
+ input: { name, description }
156
+ });
157
+ return (0, exports.extractNewsletterMetadata)(result, true);
148
158
  },
149
- subscribeNewsletterUpdates: async (jid) => {
150
- const result = await query({
151
- tag: 'iq',
152
- attrs: {
153
- id: generateMessageTag(),
154
- type: 'set',
155
- xmlns: 'newsletter',
156
- to: jid
159
+ newsletterMetadata: async (type, key, role) => {
160
+ const result = await newsletterWMexQuery(undefined, QueryIds.METADATA, {
161
+ input: {
162
+ key,
163
+ type: type.toUpperCase(),
164
+ view_role: role || 'GUEST'
157
165
  },
158
- content: [{ tag: 'live_updates', attrs: {}, content: [] }]
166
+ fetch_viewer_metadata: true,
167
+ fetch_full_image: true,
168
+ fetch_creation_time: true
159
169
  });
160
- const liveUpdatesNode = getBinaryNodeChild(result, 'live_updates');
161
- const duration = liveUpdatesNode?.attrs?.duration;
162
- return duration ? { duration: duration } : null;
170
+ return (0, exports.extractNewsletterMetadata)(result);
163
171
  },
164
172
  newsletterAdminCount: async (jid) => {
165
- const response = await executeWMexQuery({ newsletter_id: jid }, QueryIds.ADMIN_COUNT, XWAPaths.xwa2_newsletter_admin_count);
166
- return response.admin_count;
167
- },
168
- newsletterChangeOwner: async (jid, newOwnerJid) => {
169
- await executeWMexQuery({ newsletter_id: jid, user_id: newOwnerJid }, QueryIds.CHANGE_OWNER, XWAPaths.xwa2_newsletter_change_owner);
173
+ var _a, _b;
174
+ const result = await newsletterWMexQuery(jid, QueryIds.ADMIN_COUNT);
175
+ 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();
176
+ return JSON.parse(buff).data[Types_1.XWAPaths.ADMIN_COUNT].admin_count;
177
+ },
178
+ /**user is Lid, not Jid */
179
+ newsletterChangeOwner: async (jid, user) => {
180
+ await newsletterWMexQuery(jid, QueryIds.CHANGE_OWNER, {
181
+ user_id: user
182
+ });
170
183
  },
171
- newsletterDemote: async (jid, userJid) => {
172
- await executeWMexQuery({ newsletter_id: jid, user_id: userJid }, QueryIds.DEMOTE, XWAPaths.xwa2_newsletter_demote);
184
+ /**user is Lid, not Jid */
185
+ newsletterDemote: async (jid, user) => {
186
+ await newsletterWMexQuery(jid, QueryIds.DEMOTE, {
187
+ user_id: user
188
+ });
173
189
  },
174
190
  newsletterDelete: async (jid) => {
175
- await executeWMexQuery({ newsletter_id: jid }, QueryIds.DELETE, XWAPaths.xwa2_newsletter_delete_v2);
191
+ await newsletterWMexQuery(jid, QueryIds.DELETE);
192
+ },
193
+ /**if code wasn't passed, the reaction will be removed (if is reacted) */
194
+ newsletterReactMessage: async (jid, server_id, code) => {
195
+ await query({
196
+ tag: 'message',
197
+ attrs: { to: jid, ...(!code ? { edit: '7' } : {}), type: 'reaction', server_id, id: (0, Utils_1.generateMessageID)() },
198
+ content: [{
199
+ tag: 'reaction',
200
+ attrs: code ? { code } : {}
201
+ }]
202
+ });
203
+ },
204
+ newsletterFetchMessages: async (type, key, count, after) => {
205
+ const result = await newsletterQuery(WABinary_1.S_WHATSAPP_NET, 'get', [
206
+ {
207
+ tag: 'messages',
208
+ attrs: { type, ...(type === 'invite' ? { key } : { jid: key }), count: count.toString(), after: (after === null || after === void 0 ? void 0 : after.toString()) || '100' }
209
+ }
210
+ ]);
211
+ return await parseFetchedUpdates(result, 'messages');
212
+ },
213
+ newsletterFetchUpdates: async (jid, count, after, since) => {
214
+ const result = await newsletterQuery(jid, 'get', [
215
+ {
216
+ tag: 'message_updates',
217
+ 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' }
218
+ }
219
+ ]);
220
+ return await parseFetchedUpdates(result, 'updates');
176
221
  }
177
222
  };
178
223
  };
179
- //# sourceMappingURL=newsletter.js.map
224
+ exports.makeNewsletterSocket = makeNewsletterSocket;
225
+ const extractNewsletterMetadata = (node, isCreate) => {
226
+ var _a, _b, _c, _d;
227
+ const result = (_b = (_a = (0, WABinary_1.getBinaryNodeChild)(node, 'result')) === null || _a === void 0 ? void 0 : _a.content) === null || _b === void 0 ? void 0 : _b.toString();
228
+ const metadataPath = JSON.parse(result).data[isCreate ? Types_1.XWAPaths.CREATE : Types_1.XWAPaths.NEWSLETTER];
229
+ const metadata = {
230
+ id: metadataPath.id,
231
+ state: metadataPath.state.type,
232
+ creation_time: +metadataPath.thread_metadata.creation_time,
233
+ name: metadataPath.thread_metadata.name.text,
234
+ nameTime: +metadataPath.thread_metadata.name.update_time,
235
+ description: metadataPath.thread_metadata.description.text,
236
+ descriptionTime: +metadataPath.thread_metadata.description.update_time,
237
+ invite: metadataPath.thread_metadata.invite,
238
+ handle: metadataPath.thread_metadata.handle,
239
+ picture: ((_c = metadataPath.thread_metadata.picture) === null || _c === void 0 ? void 0 : _c.direct_path) || null,
240
+ preview: ((_d = metadataPath.thread_metadata.preview) === null || _d === void 0 ? void 0 : _d.direct_path) || null,
241
+ reaction_codes: metadataPath.thread_metadata.settings.reaction_codes.value,
242
+ subscribers: +metadataPath.thread_metadata.subscribers_count,
243
+ verification: metadataPath.thread_metadata.verification,
244
+ viewer_metadata: metadataPath.viewer_metadata
245
+ };
246
+ return metadata;
247
+ };
248
+ exports.extractNewsletterMetadata = extractNewsletterMetadata;
@@ -0,0 +1,166 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.makeRegistrationSocket = void 0;
7
+ exports.registrationParams = registrationParams;
8
+ exports.mobileRegisterCode = mobileRegisterCode;
9
+ exports.mobileRegisterExists = mobileRegisterExists;
10
+ exports.mobileRegister = mobileRegister;
11
+ exports.mobileRegisterEncrypt = mobileRegisterEncrypt;
12
+ exports.mobileRegisterFetch = mobileRegisterFetch;
13
+ /* eslint-disable camelcase */
14
+ const axios_1 = __importDefault(require("axios"));
15
+ const Defaults_1 = require("../Defaults");
16
+ const crypto_1 = require("../Utils/crypto");
17
+ const WABinary_1 = require("../WABinary");
18
+ const business_1 = require("./business");
19
+ function urlencode(str) {
20
+ return str.replace(/-/g, '%2d').replace(/_/g, '%5f').replace(/~/g, '%7e');
21
+ }
22
+ const validRegistrationOptions = (config) => (config === null || config === void 0 ? void 0 : config.phoneNumberCountryCode) &&
23
+ config.phoneNumberNationalNumber &&
24
+ config.phoneNumberMobileCountryCode;
25
+ const makeRegistrationSocket = (config) => {
26
+ const sock = (0, business_1.makeBusinessSocket)(config);
27
+ const register = async (code) => {
28
+ if (!validRegistrationOptions(config.auth.creds.registration)) {
29
+ throw new Error('please specify the registration options');
30
+ }
31
+ const result = await mobileRegister({ ...sock.authState.creds, ...sock.authState.creds.registration, code }, config.options);
32
+ sock.authState.creds.me = {
33
+ id: (0, WABinary_1.jidEncode)(result.login, 's.whatsapp.net'),
34
+ name: '~'
35
+ };
36
+ sock.authState.creds.registered = true;
37
+ sock.ev.emit('creds.update', sock.authState.creds);
38
+ return result;
39
+ };
40
+ const requestRegistrationCode = async (registrationOptions) => {
41
+ registrationOptions = registrationOptions || config.auth.creds.registration;
42
+ if (!validRegistrationOptions(registrationOptions)) {
43
+ throw new Error('Invalid registration options');
44
+ }
45
+ sock.authState.creds.registration = registrationOptions;
46
+ sock.ev.emit('creds.update', sock.authState.creds);
47
+ return mobileRegisterCode({ ...config.auth.creds, ...registrationOptions }, config.options);
48
+ };
49
+ return {
50
+ ...sock,
51
+ register,
52
+ requestRegistrationCode,
53
+ };
54
+ };
55
+ exports.makeRegistrationSocket = makeRegistrationSocket;
56
+ function convertBufferToUrlHex(buffer) {
57
+ var id = '';
58
+ buffer.forEach((x) => {
59
+ // encode random identity_id buffer as percentage url encoding
60
+ id += `%${x.toString(16).padStart(2, '0').toLowerCase()}`;
61
+ });
62
+ return id;
63
+ }
64
+ function registrationParams(params) {
65
+ const e_regid = Buffer.alloc(4);
66
+ e_regid.writeInt32BE(params.registrationId);
67
+ const e_skey_id = Buffer.alloc(3);
68
+ e_skey_id.writeInt16BE(params.signedPreKey.keyId);
69
+ params.phoneNumberCountryCode = params.phoneNumberCountryCode.replace('+', '').trim();
70
+ params.phoneNumberNationalNumber = params.phoneNumberNationalNumber.replace(/[/-\s)(]/g, '').trim();
71
+ return {
72
+ cc: params.phoneNumberCountryCode,
73
+ in: params.phoneNumberNationalNumber,
74
+ Rc: '0',
75
+ lg: 'en',
76
+ lc: 'GB',
77
+ mistyped: '6',
78
+ authkey: Buffer.from(params.noiseKey.public).toString('base64url'),
79
+ e_regid: e_regid.toString('base64url'),
80
+ e_keytype: 'BQ',
81
+ e_ident: Buffer.from(params.signedIdentityKey.public).toString('base64url'),
82
+ // e_skey_id: e_skey_id.toString('base64url'),
83
+ e_skey_id: 'AAAA',
84
+ e_skey_val: Buffer.from(params.signedPreKey.keyPair.public).toString('base64url'),
85
+ e_skey_sig: Buffer.from(params.signedPreKey.signature).toString('base64url'),
86
+ fdid: params.phoneId,
87
+ network_ratio_type: '1',
88
+ expid: params.deviceId,
89
+ simnum: '1',
90
+ hasinrc: '1',
91
+ pid: Math.floor(Math.random() * 1000).toString(),
92
+ id: convertBufferToUrlHex(params.identityId),
93
+ backup_token: convertBufferToUrlHex(params.backupToken),
94
+ token: (0, crypto_1.md5)(Buffer.concat([Defaults_1.MOBILE_TOKEN, Buffer.from(params.phoneNumberNationalNumber)])).toString('hex'),
95
+ fraud_checkpoint_code: params.captcha,
96
+ };
97
+ }
98
+ /**
99
+ * Requests a registration code for the given phone number.
100
+ */
101
+ function mobileRegisterCode(params, fetchOptions) {
102
+ return mobileRegisterFetch('/code', {
103
+ params: {
104
+ ...registrationParams(params),
105
+ mcc: `${params.phoneNumberMobileCountryCode}`.padStart(3, '0'),
106
+ mnc: `${params.phoneNumberMobileNetworkCode || '001'}`.padStart(3, '0'),
107
+ sim_mcc: '000',
108
+ sim_mnc: '000',
109
+ method: (params === null || params === void 0 ? void 0 : params.method) || 'sms',
110
+ reason: '',
111
+ hasav: '1'
112
+ },
113
+ ...fetchOptions,
114
+ });
115
+ }
116
+ function mobileRegisterExists(params, fetchOptions) {
117
+ return mobileRegisterFetch('/exist', {
118
+ params: registrationParams(params),
119
+ ...fetchOptions
120
+ });
121
+ }
122
+ /**
123
+ * Registers the phone number on whatsapp with the received OTP code.
124
+ */
125
+ async function mobileRegister(params, fetchOptions) {
126
+ //const result = await mobileRegisterFetch(`/reg_onboard_abprop?cc=${params.phoneNumberCountryCode}&in=${params.phoneNumberNationalNumber}&rc=0`)
127
+ return mobileRegisterFetch('/register', {
128
+ params: { ...registrationParams(params), code: params.code.replace('-', '') },
129
+ ...fetchOptions,
130
+ });
131
+ }
132
+ /**
133
+ * Encrypts the given string as AEAD aes-256-gcm with the public whatsapp key and a random keypair.
134
+ */
135
+ function mobileRegisterEncrypt(data) {
136
+ const keypair = crypto_1.Curve.generateKeyPair();
137
+ const key = crypto_1.Curve.sharedKey(keypair.private, Defaults_1.REGISTRATION_PUBLIC_KEY);
138
+ const buffer = (0, crypto_1.aesEncryptGCM)(Buffer.from(data), new Uint8Array(key), Buffer.alloc(12), Buffer.alloc(0));
139
+ return Buffer.concat([Buffer.from(keypair.public), buffer]).toString('base64url');
140
+ }
141
+ async function mobileRegisterFetch(path, opts = {}) {
142
+ let url = `${Defaults_1.MOBILE_REGISTRATION_ENDPOINT}${path}`;
143
+ if (opts.params) {
144
+ const parameter = [];
145
+ for (const param in opts.params) {
146
+ if (opts.params[param] !== null && opts.params[param] !== undefined) {
147
+ parameter.push(param + '=' + urlencode(opts.params[param]));
148
+ }
149
+ }
150
+ url += `?${parameter.join('&')}`;
151
+ delete opts.params;
152
+ }
153
+ if (!opts.headers) {
154
+ opts.headers = {};
155
+ }
156
+ opts.headers['User-Agent'] = Defaults_1.MOBILE_USERAGENT;
157
+ const response = await (0, axios_1.default)(url, opts);
158
+ var json = response.data;
159
+ if (response.status > 300 || json.reason) {
160
+ throw json;
161
+ }
162
+ if (json.status && !['ok', 'sent'].includes(json.status)) {
163
+ throw json;
164
+ }
165
+ return json;
166
+ }