violetics 7.0.0-alpha → 7.0.2-alpha

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 (114) hide show
  1. package/LICENSE +3 -2
  2. package/README.md +1001 -232
  3. package/WAProto/index.js +75379 -142631
  4. package/engine-requirements.js +11 -8
  5. package/lib/Defaults/index.js +132 -144
  6. package/lib/Signal/Group/ciphertext-message.js +2 -6
  7. package/lib/Signal/Group/group-session-builder.js +7 -42
  8. package/lib/Signal/Group/group_cipher.js +37 -52
  9. package/lib/Signal/Group/index.js +11 -57
  10. package/lib/Signal/Group/keyhelper.js +7 -45
  11. package/lib/Signal/Group/sender-chain-key.js +7 -16
  12. package/lib/Signal/Group/sender-key-distribution-message.js +8 -12
  13. package/lib/Signal/Group/sender-key-message.js +9 -13
  14. package/lib/Signal/Group/sender-key-name.js +2 -6
  15. package/lib/Signal/Group/sender-key-record.js +9 -22
  16. package/lib/Signal/Group/sender-key-state.js +27 -43
  17. package/lib/Signal/Group/sender-message-key.js +4 -8
  18. package/lib/Signal/libsignal.js +319 -94
  19. package/lib/Signal/lid-mapping.js +224 -139
  20. package/lib/Socket/Client/index.js +2 -19
  21. package/lib/Socket/Client/types.js +10 -0
  22. package/lib/Socket/Client/websocket.js +53 -0
  23. package/lib/Socket/business.js +162 -44
  24. package/lib/Socket/chats.js +477 -442
  25. package/lib/Socket/communities.js +430 -0
  26. package/lib/Socket/groups.js +110 -99
  27. package/lib/Socket/index.js +10 -10
  28. package/lib/Socket/messages-recv.js +878 -552
  29. package/lib/Socket/messages-send.js +859 -428
  30. package/lib/Socket/mex.js +41 -0
  31. package/lib/Socket/newsletter.js +195 -390
  32. package/lib/Socket/socket.js +463 -289
  33. package/lib/Store/index.js +3 -10
  34. package/lib/Store/make-in-memory-store.js +73 -79
  35. package/lib/Store/make-ordered-dictionary.js +4 -7
  36. package/lib/Store/object-repository.js +2 -6
  37. package/lib/Types/Auth.js +1 -2
  38. package/lib/Types/Bussines.js +1 -0
  39. package/lib/Types/Call.js +1 -2
  40. package/lib/Types/Chat.js +7 -4
  41. package/lib/Types/Contact.js +1 -2
  42. package/lib/Types/Events.js +1 -2
  43. package/lib/Types/GroupMetadata.js +1 -2
  44. package/lib/Types/Label.js +2 -5
  45. package/lib/Types/LabelAssociation.js +2 -5
  46. package/lib/Types/Message.js +17 -9
  47. package/lib/Types/Newsletter.js +33 -38
  48. package/lib/Types/Product.js +1 -2
  49. package/lib/Types/Signal.js +1 -2
  50. package/lib/Types/Socket.js +2 -2
  51. package/lib/Types/State.js +12 -2
  52. package/lib/Types/USync.js +1 -2
  53. package/lib/Types/index.js +14 -31
  54. package/lib/Utils/auth-utils.js +228 -145
  55. package/lib/Utils/browser-utils.js +28 -0
  56. package/lib/Utils/business.js +66 -70
  57. package/lib/Utils/chat-utils.js +331 -249
  58. package/lib/Utils/crypto.js +57 -91
  59. package/lib/Utils/decode-wa-message.js +168 -84
  60. package/lib/Utils/event-buffer.js +138 -80
  61. package/lib/Utils/generics.js +180 -297
  62. package/lib/Utils/history.js +83 -49
  63. package/lib/Utils/identity-change-handler.js +48 -0
  64. package/lib/Utils/index.js +19 -33
  65. package/lib/Utils/link-preview.js +14 -23
  66. package/lib/Utils/logger.js +2 -7
  67. package/lib/Utils/lt-hash.js +2 -46
  68. package/lib/Utils/make-mutex.js +24 -35
  69. package/lib/Utils/message-retry-manager.js +224 -0
  70. package/lib/Utils/messages-media.js +501 -496
  71. package/lib/Utils/messages.js +1428 -362
  72. package/lib/Utils/noise-handler.js +145 -100
  73. package/lib/Utils/pre-key-manager.js +105 -0
  74. package/lib/Utils/process-message.js +356 -150
  75. package/lib/Utils/reporting-utils.js +257 -0
  76. package/lib/Utils/signal.js +78 -73
  77. package/lib/Utils/sync-action-utils.js +47 -0
  78. package/lib/Utils/tc-token-utils.js +17 -0
  79. package/lib/Utils/use-multi-file-auth-state.js +32 -34
  80. package/lib/Utils/validate-connection.js +91 -107
  81. package/lib/WABinary/constants.js +1300 -1304
  82. package/lib/WABinary/decode.js +26 -48
  83. package/lib/WABinary/encode.js +109 -155
  84. package/lib/WABinary/generic-utils.js +161 -149
  85. package/lib/WABinary/index.js +5 -21
  86. package/lib/WABinary/jid-utils.js +73 -40
  87. package/lib/WABinary/types.js +1 -2
  88. package/lib/WAM/BinaryInfo.js +2 -6
  89. package/lib/WAM/constants.js +19070 -11568
  90. package/lib/WAM/encode.js +17 -23
  91. package/lib/WAM/index.js +3 -19
  92. package/lib/WAUSync/Protocols/USyncContactProtocol.js +8 -12
  93. package/lib/WAUSync/Protocols/USyncDeviceProtocol.js +11 -15
  94. package/lib/WAUSync/Protocols/USyncDisappearingModeProtocol.js +9 -13
  95. package/lib/WAUSync/Protocols/USyncStatusProtocol.js +9 -14
  96. package/lib/WAUSync/Protocols/UsyncBotProfileProtocol.js +20 -23
  97. package/lib/WAUSync/Protocols/UsyncLIDProtocol.js +13 -9
  98. package/lib/WAUSync/Protocols/index.js +4 -20
  99. package/lib/WAUSync/USyncQuery.js +40 -36
  100. package/lib/WAUSync/USyncUser.js +2 -6
  101. package/lib/WAUSync/index.js +3 -19
  102. package/lib/index.js +11 -44
  103. package/package.json +75 -108
  104. package/lib/Defaults/baileys-version.json +0 -3
  105. package/lib/Defaults/phonenumber-mcc.json +0 -223
  106. package/lib/Signal/Group/queue-job.js +0 -57
  107. package/lib/Socket/Client/abstract-socket-client.js +0 -13
  108. package/lib/Socket/Client/mobile-socket-client.js +0 -65
  109. package/lib/Socket/Client/web-socket-client.js +0 -111
  110. package/lib/Socket/groupStatus.js +0 -637
  111. package/lib/Socket/registration.js +0 -166
  112. package/lib/Socket/usync.js +0 -70
  113. package/lib/Store/make-cache-manager-store.js +0 -83
  114. package/lib/Utils/baileys-event-stream.js +0 -63
@@ -1,185 +1,270 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.LIDMappingStore = void 0;
4
- const lru_cache_1 = require("lru-cache");
5
- const jid_utils_1 = require("../WABinary/jid-utils");
6
-
7
- class LIDMappingStore {
1
+ import { LRUCache } from 'lru-cache';
2
+ import { isHostedPnUser, isLidUser, isPnUser, jidDecode, jidNormalizedUser, WAJIDDomains } from '../WABinary/index.js';
3
+ export class LIDMappingStore {
8
4
  constructor(keys, logger, pnToLIDFunc) {
9
- this.mappingCache = new lru_cache_1.LRUCache({
10
- ttl: 3 * 24 * 60 * 60 * 1000,
5
+ this.mappingCache = new LRUCache({
6
+ ttl: 3 * 24 * 60 * 60 * 1000, // 7 days
11
7
  ttlAutopurge: true,
12
8
  updateAgeOnGet: true
13
9
  });
14
10
  this.inflightLIDLookups = new Map();
15
11
  this.inflightPNLookups = new Map();
16
12
  this.keys = keys;
17
- this.logger = logger;
18
13
  this.pnToLIDFunc = pnToLIDFunc;
14
+ this.logger = logger;
19
15
  }
20
-
21
16
  async storeLIDPNMappings(pairs) {
22
- const pairMap = {};
17
+ if (pairs.length === 0)
18
+ return;
19
+ const validatedPairs = [];
23
20
  for (const { lid, pn } of pairs) {
24
- if (!lid || !pn) continue;
25
- const lidDecoded = (0, jid_utils_1.jidDecode)(lid);
26
- const pnDecoded = (0, jid_utils_1.jidDecode)(pn);
27
- if (!lidDecoded || !pnDecoded) continue;
28
- const pnUser = pnDecoded.user;
29
- const lidUser = lidDecoded.user;
30
- if (!pnUser || !lidUser || typeof pnUser !== 'string' || typeof lidUser !== 'string') continue;
31
- const existingLidUser = this.mappingCache.get(`pn:${pnUser}`);
32
- if (existingLidUser === lidUser) continue;
33
- pairMap[pnUser] = lidUser;
21
+ if (!((isLidUser(lid) && isPnUser(pn)) || (isPnUser(lid) && isLidUser(pn)))) {
22
+ this.logger.warn(`Invalid LID-PN mapping: ${lid}, ${pn}`);
23
+ continue;
24
+ }
25
+ const lidDecoded = jidDecode(lid);
26
+ const pnDecoded = jidDecode(pn);
27
+ if (!lidDecoded || !pnDecoded)
28
+ continue;
29
+ validatedPairs.push({ pnUser: pnDecoded.user, lidUser: lidDecoded.user });
34
30
  }
35
- if (Object.keys(pairMap).length === 0) return;
36
- try {
37
- await this.keys.transaction(async () => {
38
- for (const [pnUser, lidUser] of Object.entries(pairMap)) {
39
- await this.keys.set({
40
- 'lid-mapping': {
41
- [`pn:${pnUser}`]: lidUser,
42
- [`lid:${lidUser}`]: pnUser
43
- }
44
- });
45
- this.mappingCache.set(`pn:${pnUser}`, lidUser);
46
- this.mappingCache.set(`lid:${lidUser}`, pnUser);
31
+ if (validatedPairs.length === 0)
32
+ return;
33
+ const cacheMissSet = new Set();
34
+ const existingMappings = new Map();
35
+ for (const { pnUser } of validatedPairs) {
36
+ const cached = this.mappingCache.get(`pn:${pnUser}`);
37
+ if (cached) {
38
+ existingMappings.set(pnUser, cached);
39
+ }
40
+ else {
41
+ cacheMissSet.add(pnUser);
42
+ }
43
+ }
44
+ if (cacheMissSet.size > 0) {
45
+ const cacheMisses = [...cacheMissSet];
46
+ this.logger.trace(`Batch fetching ${cacheMisses.length} LID mappings from database`);
47
+ const stored = await this.keys.get('lid-mapping', cacheMisses);
48
+ for (const pnUser of cacheMisses) {
49
+ const existingLidUser = stored[pnUser];
50
+ if (existingLidUser) {
51
+ existingMappings.set(pnUser, existingLidUser);
52
+ this.mappingCache.set(`pn:${pnUser}`, existingLidUser);
53
+ this.mappingCache.set(`lid:${existingLidUser}`, pnUser);
47
54
  }
48
- }, 'lid-mapping');
49
- } catch (e) {
50
- if (this.logger) this.logger.warn({ e }, 'failed to store LID-PN mappings');
55
+ }
56
+ }
57
+ const pairMap = {};
58
+ for (const { pnUser, lidUser } of validatedPairs) {
59
+ const existingLidUser = existingMappings.get(pnUser);
60
+ if (existingLidUser === lidUser) {
61
+ this.logger.debug({ pnUser, lidUser }, 'LID mapping already exists, skipping');
62
+ continue;
63
+ }
64
+ pairMap[pnUser] = lidUser;
65
+ }
66
+ if (Object.keys(pairMap).length === 0)
67
+ return;
68
+ this.logger.trace({ pairMap }, `Storing ${Object.keys(pairMap).length} pn mappings`);
69
+ const batchData = {};
70
+ for (const [pnUser, lidUser] of Object.entries(pairMap)) {
71
+ batchData[pnUser] = lidUser;
72
+ batchData[`${lidUser}_reverse`] = pnUser;
73
+ }
74
+ await this.keys.transaction(async () => {
75
+ await this.keys.set({ 'lid-mapping': batchData });
76
+ }, 'lid-mapping');
77
+ // Update cache after successful DB write
78
+ for (const [pnUser, lidUser] of Object.entries(pairMap)) {
79
+ this.mappingCache.set(`pn:${pnUser}`, lidUser);
80
+ this.mappingCache.set(`lid:${lidUser}`, pnUser);
51
81
  }
52
82
  }
53
-
54
83
  async getLIDForPN(pn) {
55
- if (!pn) return null;
56
- if (this.inflightPNLookups.has(pn)) {
57
- return this.inflightPNLookups.get(pn);
84
+ return (await this.getLIDsForPNs([pn]))?.[0]?.lid || null;
85
+ }
86
+ async getLIDsForPNs(pns) {
87
+ if (pns.length === 0)
88
+ return null;
89
+ const sortedPns = [...new Set(pns)].sort();
90
+ const cacheKey = sortedPns.join(',');
91
+ const inflight = this.inflightLIDLookups.get(cacheKey);
92
+ if (inflight) {
93
+ this.logger.trace(`Coalescing getLIDsForPNs request for ${sortedPns.length} PNs`);
94
+ return inflight;
58
95
  }
59
- const promise = this.getLIDsForPNs([pn]).then(r => r?.[0]?.lid || null);
60
- this.inflightPNLookups.set(pn, promise);
96
+ const promise = this._getLIDsForPNsImpl(pns);
97
+ this.inflightLIDLookups.set(cacheKey, promise);
61
98
  try {
62
99
  return await promise;
63
- } finally {
64
- this.inflightPNLookups.delete(pn);
100
+ }
101
+ finally {
102
+ this.inflightLIDLookups.delete(cacheKey);
65
103
  }
66
104
  }
67
-
68
- async getLIDsForPNs(pns) {
105
+ async _getLIDsForPNsImpl(pns) {
69
106
  const usyncFetch = {};
70
107
  const successfulPairs = {};
108
+ const pending = [];
109
+ const addResolvedPair = (pn, decoded, lidUser) => {
110
+ const normalizedLidUser = lidUser.toString();
111
+ if (!normalizedLidUser) {
112
+ this.logger.warn(`Invalid or empty LID user for PN ${pn}: lidUser = "${lidUser}"`);
113
+ return false;
114
+ }
115
+ // Push the PN device ID to the LID to maintain device separation
116
+ const pnDevice = decoded.device !== undefined ? decoded.device : 0;
117
+ const deviceSpecificLid = `${normalizedLidUser}${!!pnDevice ? `:${pnDevice}` : ``}@${decoded.server === 'hosted' ? 'hosted.lid' : 'lid'}`;
118
+ this.logger.trace(`getLIDForPN: ${pn} → ${deviceSpecificLid} (user mapping with device ${pnDevice})`);
119
+ successfulPairs[pn] = { lid: deviceSpecificLid, pn };
120
+ return true;
121
+ };
71
122
  for (const pn of pns) {
72
- if (!pn) continue;
73
- const decoded = (0, jid_utils_1.jidDecode)(pn);
74
- if (!decoded?.user) continue;
123
+ if (!isPnUser(pn) && !isHostedPnUser(pn))
124
+ continue;
125
+ const decoded = jidDecode(pn);
126
+ if (!decoded)
127
+ continue;
75
128
  const pnUser = decoded.user;
76
- let lidUser = this.mappingCache.get(`pn:${pnUser}`);
77
- if (!lidUser) {
78
- try {
79
- const stored = await this.keys.get('lid-mapping', [`pn:${pnUser}`]);
80
- lidUser = stored[`pn:${pnUser}`];
81
- if (lidUser) {
82
- this.mappingCache.set(`pn:${pnUser}`, lidUser);
83
- this.mappingCache.set(`lid:${lidUser}`, pnUser);
84
- } else {
85
- const device = decoded.device || 0;
86
- const normalizedPn = `${pnUser}@s.whatsapp.net`;
87
- if (!usyncFetch[normalizedPn]) {
88
- usyncFetch[normalizedPn] = [device];
89
- } else {
90
- usyncFetch[normalizedPn].push(device);
91
- }
129
+ const cached = this.mappingCache.get(`pn:${pnUser}`);
130
+ if (cached && typeof cached === 'string') {
131
+ if (!addResolvedPair(pn, decoded, cached)) {
132
+ this.logger.warn(`Invalid entry for ${pn} (pair not resolved)`);
133
+ continue;
134
+ }
135
+ continue;
136
+ }
137
+ pending.push({ pn, pnUser, decoded });
138
+ }
139
+ if (pending.length) {
140
+ const pnUsers = [...new Set(pending.map(item => item.pnUser))];
141
+ const stored = await this.keys.get('lid-mapping', pnUsers);
142
+ for (const pnUser of pnUsers) {
143
+ const lidUser = stored[pnUser];
144
+ if (lidUser && typeof lidUser === 'string') {
145
+ this.mappingCache.set(`pn:${pnUser}`, lidUser);
146
+ this.mappingCache.set(`lid:${lidUser}`, pnUser);
147
+ }
148
+ }
149
+ for (const { pn, pnUser, decoded } of pending) {
150
+ const cached = this.mappingCache.get(`pn:${pnUser}`);
151
+ if (cached && typeof cached === 'string') {
152
+ if (!addResolvedPair(pn, decoded, cached)) {
153
+ this.logger.warn(`Invalid entry for ${pn} (pair not resolved)`);
92
154
  continue;
93
155
  }
94
- } catch (e) { continue; }
156
+ }
157
+ else {
158
+ this.logger.trace(`No LID mapping found for PN user ${pnUser}; batch getting from USync`);
159
+ const device = decoded.device || 0;
160
+ let normalizedPn = jidNormalizedUser(pn);
161
+ if (isHostedPnUser(normalizedPn)) {
162
+ normalizedPn = `${pnUser}@s.whatsapp.net`;
163
+ }
164
+ if (!usyncFetch[normalizedPn]) {
165
+ usyncFetch[normalizedPn] = [device];
166
+ }
167
+ else {
168
+ usyncFetch[normalizedPn]?.push(device);
169
+ }
170
+ }
95
171
  }
96
- if (typeof lidUser !== 'string' || !lidUser) continue;
97
- const pnDevice = decoded.device || 0;
98
- const deviceSpecificLid = `${lidUser}${pnDevice ? `:${pnDevice}` : ''}@lid`;
99
- successfulPairs[pn] = { lid: deviceSpecificLid, pn };
100
172
  }
101
173
  if (Object.keys(usyncFetch).length > 0) {
102
- try {
103
- const result = await this.pnToLIDFunc?.(Object.keys(usyncFetch));
104
- if (result && result.length > 0) {
105
- await this.storeLIDPNMappings(result);
106
- for (const pair of result) {
107
- const pnDecoded = (0, jid_utils_1.jidDecode)(pair.pn);
108
- const pnUser = pnDecoded?.user;
109
- if (!pnUser) continue;
110
- const lidUser = (0, jid_utils_1.jidDecode)(pair.lid)?.user;
111
- if (!lidUser) continue;
112
- for (const device of (usyncFetch[pair.pn] || [])) {
113
- const deviceSpecificLid = `${lidUser}${device ? `:${device}` : ''}@lid`;
114
- const deviceSpecificPn = `${pnUser}${device ? `:${device}` : ''}@s.whatsapp.net`;
115
- successfulPairs[deviceSpecificPn] = { lid: deviceSpecificLid, pn: deviceSpecificPn };
116
- }
174
+ const result = await this.pnToLIDFunc?.(Object.keys(usyncFetch)); // this function already adds LIDs to mapping
175
+ if (result && result.length > 0) {
176
+ await this.storeLIDPNMappings(result);
177
+ for (const pair of result) {
178
+ const pnDecoded = jidDecode(pair.pn);
179
+ const pnUser = pnDecoded?.user;
180
+ if (!pnUser)
181
+ continue;
182
+ const lidUser = jidDecode(pair.lid)?.user;
183
+ if (!lidUser)
184
+ continue;
185
+ for (const device of usyncFetch[pair.pn]) {
186
+ const deviceSpecificLid = `${lidUser}${!!device ? `:${device}` : ``}@${device === 99 ? 'hosted.lid' : 'lid'}`;
187
+ this.logger.trace(`getLIDForPN: USYNC success for ${pair.pn} ${deviceSpecificLid} (user mapping with device ${device})`);
188
+ const deviceSpecificPn = `${pnUser}${!!device ? `:${device}` : ``}@${device === 99 ? 'hosted' : 's.whatsapp.net'}`;
189
+ successfulPairs[deviceSpecificPn] = { lid: deviceSpecificLid, pn: deviceSpecificPn };
117
190
  }
118
- } else {
119
- return null;
120
191
  }
121
- } catch (e) {
122
- return null;
192
+ }
193
+ else {
194
+ this.logger.warn('USync fetch yielded no results for pending PNs');
123
195
  }
124
196
  }
125
- return Object.values(successfulPairs);
197
+ return Object.values(successfulPairs).length > 0 ? Object.values(successfulPairs) : null;
198
+ }
199
+ async getPNForLID(lid) {
200
+ return (await this.getPNsForLIDs([lid]))?.[0]?.pn || null;
126
201
  }
127
-
128
202
  async getPNsForLIDs(lids) {
129
- const result = [];
130
- const missingLids = [];
203
+ if (lids.length === 0)
204
+ return null;
205
+ const sortedLids = [...new Set(lids)].sort();
206
+ const cacheKey = sortedLids.join(',');
207
+ const inflight = this.inflightPNLookups.get(cacheKey);
208
+ if (inflight) {
209
+ this.logger.trace(`Coalescing getPNsForLIDs request for ${sortedLids.length} LIDs`);
210
+ return inflight;
211
+ }
212
+ const promise = this._getPNsForLIDsImpl(lids);
213
+ this.inflightPNLookups.set(cacheKey, promise);
214
+ try {
215
+ return await promise;
216
+ }
217
+ finally {
218
+ this.inflightPNLookups.delete(cacheKey);
219
+ }
220
+ }
221
+ async _getPNsForLIDsImpl(lids) {
222
+ const successfulPairs = {};
223
+ const pending = [];
224
+ const addResolvedPair = (lid, decoded, pnUser) => {
225
+ if (!pnUser || typeof pnUser !== 'string') {
226
+ return false;
227
+ }
228
+ const lidDevice = decoded.device !== undefined ? decoded.device : 0;
229
+ const pnJid = `${pnUser}:${lidDevice}@${decoded.domainType === WAJIDDomains.HOSTED_LID ? 'hosted' : 's.whatsapp.net'}`;
230
+ this.logger.trace(`Found reverse mapping: ${lid} → ${pnJid}`);
231
+ successfulPairs[lid] = { lid, pn: pnJid };
232
+ return true;
233
+ };
131
234
  for (const lid of lids) {
132
- if (!lid) continue;
133
- const decoded = (0, jid_utils_1.jidDecode)(lid);
134
- if (!decoded?.user) continue;
235
+ if (!isLidUser(lid))
236
+ continue;
237
+ const decoded = jidDecode(lid);
238
+ if (!decoded)
239
+ continue;
135
240
  const lidUser = decoded.user;
136
- const pnUser = this.mappingCache.get(`lid:${lidUser}`);
137
- if (!pnUser || typeof pnUser !== 'string') {
138
- missingLids.push(lidUser);
139
- } else {
140
- const lidDevice = decoded.device || 0;
141
- const pnJid = `${pnUser}${lidDevice ? `:${lidDevice}` : ''}@s.whatsapp.net`;
142
- result.push({ lid, pn: pnJid });
241
+ const cached = this.mappingCache.get(`lid:${lidUser}`);
242
+ if (cached && typeof cached === 'string') {
243
+ addResolvedPair(lid, decoded, cached);
244
+ continue;
143
245
  }
246
+ pending.push({ lid, lidUser, decoded });
144
247
  }
145
- if (missingLids.length > 0) {
146
- try {
147
- const dbKeys = missingLids.map(l => `lid:${l}`);
148
- const stored = await this.keys.get('lid-mapping', dbKeys);
149
- for (const lidUser of missingLids) {
150
- const pnUser = stored[`lid:${lidUser}`];
248
+ if (pending.length) {
249
+ const reverseKeys = [...new Set(pending.map(item => `${item.lidUser}_reverse`))];
250
+ const stored = await this.keys.get('lid-mapping', reverseKeys);
251
+ for (const { lid, lidUser, decoded } of pending) {
252
+ let pnUser = this.mappingCache.get(`lid:${lidUser}`);
253
+ if (!pnUser || typeof pnUser !== 'string') {
254
+ pnUser = stored[`${lidUser}_reverse`];
151
255
  if (pnUser && typeof pnUser === 'string') {
152
256
  this.mappingCache.set(`lid:${lidUser}`, pnUser);
153
- for (const lid of lids) {
154
- if (lid.startsWith(lidUser)) {
155
- const decoded = (0, jid_utils_1.jidDecode)(lid);
156
- if (decoded) {
157
- const lidDevice = decoded.device || 0;
158
- const pnJid = `${pnUser}${lidDevice ? `:${lidDevice}` : ''}@s.whatsapp.net`;
159
- result.push({ lid, pn: pnJid });
160
- }
161
- }
162
- }
257
+ this.mappingCache.set(`pn:${pnUser}`, lidUser);
163
258
  }
164
259
  }
165
- } catch (e) {}
166
- }
167
- return result;
168
- }
169
-
170
- async getPNForLID(lid) {
171
- if (!lid) return null;
172
- if (this.inflightLIDLookups.has(lid)) {
173
- return this.inflightLIDLookups.get(lid);
174
- }
175
- const promise = this.getPNsForLIDs([lid]).then(r => r?.[0]?.pn || null);
176
- this.inflightLIDLookups.set(lid, promise);
177
- try {
178
- return await promise;
179
- } finally {
180
- this.inflightLIDLookups.delete(lid);
260
+ if (pnUser && typeof pnUser === 'string') {
261
+ addResolvedPair(lid, decoded, pnUser);
262
+ }
263
+ else {
264
+ this.logger.trace(`No reverse mapping found for LID user: ${lidUser}`);
265
+ }
266
+ }
181
267
  }
268
+ return Object.values(successfulPairs).length ? Object.values(successfulPairs) : null;
182
269
  }
183
- }
184
-
185
- exports.LIDMappingStore = LIDMappingStore;
270
+ }
@@ -1,19 +1,2 @@
1
- "use strict";
2
- var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
- if (k2 === undefined) k2 = k;
4
- var desc = Object.getOwnPropertyDescriptor(m, k);
5
- if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
- desc = { enumerable: true, get: function() { return m[k]; } };
7
- }
8
- Object.defineProperty(o, k2, desc);
9
- }) : (function(o, m, k, k2) {
10
- if (k2 === undefined) k2 = k;
11
- o[k2] = m[k];
12
- }));
13
- var __exportStar = (this && this.__exportStar) || function(m, exports) {
14
- for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
15
- };
16
- Object.defineProperty(exports, "__esModule", { value: true });
17
- __exportStar(require("./abstract-socket-client"), exports);
18
- __exportStar(require("./mobile-socket-client"), exports);
19
- __exportStar(require("./web-socket-client"), exports);
1
+ export * from './types.js';
2
+ export * from './websocket.js';
@@ -0,0 +1,10 @@
1
+ import { EventEmitter } from 'events';
2
+ import { URL } from 'url';
3
+ export class AbstractSocketClient extends EventEmitter {
4
+ constructor(url, config) {
5
+ super();
6
+ this.url = url;
7
+ this.config = config;
8
+ this.setMaxListeners(0);
9
+ }
10
+ }
@@ -0,0 +1,53 @@
1
+ import WebSocket from 'ws';
2
+ import { DEFAULT_ORIGIN } from '../../Defaults/index.js';
3
+ import { AbstractSocketClient } from './types.js';
4
+ export class WebSocketClient extends AbstractSocketClient {
5
+ constructor() {
6
+ super(...arguments);
7
+ this.socket = null;
8
+ }
9
+ get isOpen() {
10
+ return this.socket?.readyState === WebSocket.OPEN;
11
+ }
12
+ get isClosed() {
13
+ return this.socket === null || this.socket?.readyState === WebSocket.CLOSED;
14
+ }
15
+ get isClosing() {
16
+ return this.socket === null || this.socket?.readyState === WebSocket.CLOSING;
17
+ }
18
+ get isConnecting() {
19
+ return this.socket?.readyState === WebSocket.CONNECTING;
20
+ }
21
+ connect() {
22
+ if (this.socket) {
23
+ return;
24
+ }
25
+ this.socket = new WebSocket(this.url, {
26
+ origin: DEFAULT_ORIGIN,
27
+ headers: this.config.options?.headers,
28
+ handshakeTimeout: this.config.connectTimeoutMs,
29
+ timeout: this.config.connectTimeoutMs,
30
+ agent: this.config.agent
31
+ });
32
+ this.socket.setMaxListeners(0);
33
+ const events = ['close', 'error', 'upgrade', 'message', 'open', 'ping', 'pong', 'unexpected-response'];
34
+ for (const event of events) {
35
+ this.socket?.on(event, (...args) => this.emit(event, ...args));
36
+ }
37
+ }
38
+ async close() {
39
+ if (!this.socket) {
40
+ return;
41
+ }
42
+ const closePromise = new Promise(resolve => {
43
+ this.socket?.once('close', resolve);
44
+ });
45
+ this.socket.close();
46
+ await closePromise;
47
+ this.socket = null;
48
+ }
49
+ send(str, cb) {
50
+ this.socket?.send(str, cb);
51
+ return Boolean(this.socket);
52
+ }
53
+ }