@zentrix/baileys 4.1.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.
- package/README.md +202 -0
- package/WAProto/index.js +169661 -0
- package/engine-requirements.js +10 -0
- package/lib/Defaults/baileys-version.json +3 -0
- package/lib/Defaults/index.d.ts +53 -0
- package/lib/Defaults/index.js +147 -0
- package/lib/Defaults/phonenumber-mcc.json +223 -0
- package/lib/Signal/Group/ciphertext-message.d.ts +9 -0
- package/lib/Signal/Group/ciphertext-message.js +15 -0
- package/lib/Signal/Group/group-session-builder.d.ts +14 -0
- package/lib/Signal/Group/group-session-builder.js +64 -0
- package/lib/Signal/Group/group_cipher.d.ts +17 -0
- package/lib/Signal/Group/group_cipher.js +96 -0
- package/lib/Signal/Group/index.d.ts +11 -0
- package/lib/Signal/Group/index.js +57 -0
- package/lib/Signal/Group/keyhelper.d.ts +10 -0
- package/lib/Signal/Group/keyhelper.js +55 -0
- package/lib/Signal/Group/queue-job.d.ts +1 -0
- package/lib/Signal/Group/queue-job.js +57 -0
- package/lib/Signal/Group/sender-chain-key.d.ts +13 -0
- package/lib/Signal/Group/sender-chain-key.js +34 -0
- package/lib/Signal/Group/sender-key-distribution-message.d.ts +16 -0
- package/lib/Signal/Group/sender-key-distribution-message.js +66 -0
- package/lib/Signal/Group/sender-key-message.d.ts +18 -0
- package/lib/Signal/Group/sender-key-message.js +69 -0
- package/lib/Signal/Group/sender-key-name.d.ts +17 -0
- package/lib/Signal/Group/sender-key-name.js +51 -0
- package/lib/Signal/Group/sender-key-record.d.ts +30 -0
- package/lib/Signal/Group/sender-key-record.js +53 -0
- package/lib/Signal/Group/sender-key-state.d.ts +38 -0
- package/lib/Signal/Group/sender-key-state.js +99 -0
- package/lib/Signal/Group/sender-message-key.d.ts +11 -0
- package/lib/Signal/Group/sender-message-key.js +29 -0
- package/lib/Signal/libsignal.d.ts +3 -0
- package/lib/Signal/libsignal.js +336 -0
- package/lib/Signal/lid-mapping.js +293 -0
- package/lib/Socket/Client/abstract-socket-client.d.ts +17 -0
- package/lib/Socket/Client/abstract-socket-client.js +13 -0
- package/lib/Socket/Client/index.d.ts +3 -0
- package/lib/Socket/Client/index.js +19 -0
- package/lib/Socket/Client/mobile-socket-client.d.ts +13 -0
- package/lib/Socket/Client/mobile-socket-client.js +65 -0
- package/lib/Socket/Client/web-socket-client.d.ts +12 -0
- package/lib/Socket/Client/web-socket-client.js +62 -0
- package/lib/Socket/business.d.ts +171 -0
- package/lib/Socket/business.js +260 -0
- package/lib/Socket/chats.d.ts +267 -0
- package/lib/Socket/chats.js +970 -0
- package/lib/Socket/groups.d.ts +115 -0
- package/lib/Socket/groups.js +334 -0
- package/lib/Socket/index.d.ts +173 -0
- package/lib/Socket/index.js +11 -0
- package/lib/Socket/luxu.d.ts +268 -0
- package/lib/Socket/luxu.js +591 -0
- package/lib/Socket/messages-recv.d.ts +161 -0
- package/lib/Socket/messages-recv.js +1126 -0
- package/lib/Socket/messages-send.d.ts +149 -0
- package/lib/Socket/messages-send.js +913 -0
- package/lib/Socket/newsletter.d.ts +134 -0
- package/lib/Socket/newsletter.js +315 -0
- package/lib/Socket/registration.d.ts +267 -0
- package/lib/Socket/registration.js +166 -0
- package/lib/Socket/socket.d.ts +43 -0
- package/lib/Socket/socket.js +688 -0
- package/lib/Socket/usync.d.ts +36 -0
- package/lib/Socket/usync.js +70 -0
- package/lib/Store/index.d.ts +3 -0
- package/lib/Store/index.js +10 -0
- package/lib/Store/make-cache-manager-store.d.ts +13 -0
- package/lib/Store/make-cache-manager-store.js +83 -0
- package/lib/Store/make-in-memory-store.d.ts +118 -0
- package/lib/Store/make-in-memory-store.js +427 -0
- package/lib/Store/make-ordered-dictionary.d.ts +13 -0
- package/lib/Store/make-ordered-dictionary.js +81 -0
- package/lib/Store/object-repository.d.ts +10 -0
- package/lib/Store/object-repository.js +27 -0
- package/lib/Types/Auth.d.ts +110 -0
- package/lib/Types/Auth.js +2 -0
- package/lib/Types/Call.d.ts +13 -0
- package/lib/Types/Call.js +2 -0
- package/lib/Types/Chat.d.ts +102 -0
- package/lib/Types/Chat.js +4 -0
- package/lib/Types/Contact.d.ts +19 -0
- package/lib/Types/Contact.js +2 -0
- package/lib/Types/Events.d.ts +157 -0
- package/lib/Types/Events.js +2 -0
- package/lib/Types/GroupMetadata.d.ts +55 -0
- package/lib/Types/GroupMetadata.js +2 -0
- package/lib/Types/Label.d.ts +35 -0
- package/lib/Types/Label.js +27 -0
- package/lib/Types/LabelAssociation.d.ts +29 -0
- package/lib/Types/LabelAssociation.js +9 -0
- package/lib/Types/Message.d.ts +273 -0
- package/lib/Types/Message.js +9 -0
- package/lib/Types/Newsletter.d.ts +103 -0
- package/lib/Types/Newsletter.js +38 -0
- package/lib/Types/Product.d.ts +78 -0
- package/lib/Types/Product.js +2 -0
- package/lib/Types/Signal.d.ts +57 -0
- package/lib/Types/Signal.js +2 -0
- package/lib/Types/Socket.d.ts +111 -0
- package/lib/Types/Socket.js +2 -0
- package/lib/Types/State.d.ts +27 -0
- package/lib/Types/State.js +2 -0
- package/lib/Types/USync.d.ts +25 -0
- package/lib/Types/USync.js +2 -0
- package/lib/Types/index.d.ts +57 -0
- package/lib/Types/index.js +42 -0
- package/lib/Utils/auth-utils.d.ts +18 -0
- package/lib/Utils/auth-utils.js +206 -0
- package/lib/Utils/baileys-event-stream.d.ts +16 -0
- package/lib/Utils/baileys-event-stream.js +63 -0
- package/lib/Utils/business.d.ts +22 -0
- package/lib/Utils/business.js +234 -0
- package/lib/Utils/chat-utils.d.ts +71 -0
- package/lib/Utils/chat-utils.js +729 -0
- package/lib/Utils/crypto.d.ts +41 -0
- package/lib/Utils/crypto.js +151 -0
- package/lib/Utils/decode-wa-message.d.ts +19 -0
- package/lib/Utils/decode-wa-message.js +243 -0
- package/lib/Utils/event-buffer.d.ts +35 -0
- package/lib/Utils/event-buffer.js +514 -0
- package/lib/Utils/generics.d.ts +92 -0
- package/lib/Utils/generics.js +423 -0
- package/lib/Utils/history.d.ts +15 -0
- package/lib/Utils/history.js +96 -0
- package/lib/Utils/identity-change-handler.js +68 -0
- package/lib/Utils/index.d.ts +17 -0
- package/lib/Utils/index.js +41 -0
- package/lib/Utils/link-preview.d.ts +21 -0
- package/lib/Utils/link-preview.js +93 -0
- package/lib/Utils/logger.d.ts +4 -0
- package/lib/Utils/logger.js +7 -0
- package/lib/Utils/lt-hash.d.ts +12 -0
- package/lib/Utils/lt-hash.js +51 -0
- package/lib/Utils/make-mutex.d.ts +7 -0
- package/lib/Utils/make-mutex.js +43 -0
- package/lib/Utils/message-retry-manager.js +192 -0
- package/lib/Utils/messages-media.d.ts +116 -0
- package/lib/Utils/messages-media.js +819 -0
- package/lib/Utils/messages.d.ts +77 -0
- package/lib/Utils/messages.js +816 -0
- package/lib/Utils/noise-handler.d.ts +21 -0
- package/lib/Utils/noise-handler.js +155 -0
- package/lib/Utils/offline-node-processor.js +55 -0
- package/lib/Utils/pre-key-manager.js +95 -0
- package/lib/Utils/process-message.d.ts +41 -0
- package/lib/Utils/process-message.js +321 -0
- package/lib/Utils/signal.d.ts +32 -0
- package/lib/Utils/signal.js +153 -0
- package/lib/Utils/stanza-ack.js +47 -0
- package/lib/Utils/tc-token-utils.js +173 -0
- package/lib/Utils/use-multi-file-auth-state.d.ts +13 -0
- package/lib/Utils/use-multi-file-auth-state.js +119 -0
- package/lib/Utils/validate-connection.d.ts +11 -0
- package/lib/Utils/validate-connection.js +229 -0
- package/lib/WABinary/constants.d.ts +30 -0
- package/lib/WABinary/constants.js +40 -0
- package/lib/WABinary/decode.d.ts +7 -0
- package/lib/WABinary/decode.js +252 -0
- package/lib/WABinary/encode.d.ts +3 -0
- package/lib/WABinary/encode.js +265 -0
- package/lib/WABinary/generic-utils.d.ts +17 -0
- package/lib/WABinary/generic-utils.js +198 -0
- package/lib/WABinary/index.d.ts +5 -0
- package/lib/WABinary/index.js +21 -0
- package/lib/WABinary/jid-utils.d.ts +31 -0
- package/lib/WABinary/jid-utils.js +138 -0
- package/lib/WABinary/types.d.ts +18 -0
- package/lib/WABinary/types.js +2 -0
- package/lib/WAM/BinaryInfo.d.ts +17 -0
- package/lib/WAM/BinaryInfo.js +13 -0
- package/lib/WAM/constants.d.ts +38 -0
- package/lib/WAM/constants.js +15350 -0
- package/lib/WAM/encode.d.ts +3 -0
- package/lib/WAM/encode.js +155 -0
- package/lib/WAM/index.d.ts +3 -0
- package/lib/WAM/index.js +19 -0
- package/lib/WAUSync/Protocols/USyncContactProtocol.d.ts +9 -0
- package/lib/WAUSync/Protocols/USyncContactProtocol.js +32 -0
- package/lib/WAUSync/Protocols/USyncDeviceProtocol.d.ts +22 -0
- package/lib/WAUSync/Protocols/USyncDeviceProtocol.js +57 -0
- package/lib/WAUSync/Protocols/USyncDisappearingModeProtocol.d.ts +12 -0
- package/lib/WAUSync/Protocols/USyncDisappearingModeProtocol.js +30 -0
- package/lib/WAUSync/Protocols/USyncStatusProtocol.d.ts +12 -0
- package/lib/WAUSync/Protocols/USyncStatusProtocol.js +42 -0
- package/lib/WAUSync/Protocols/UsyncBotProfileProtocol.d.ts +25 -0
- package/lib/WAUSync/Protocols/UsyncBotProfileProtocol.js +53 -0
- package/lib/WAUSync/Protocols/UsyncLIDProtocol.d.ts +8 -0
- package/lib/WAUSync/Protocols/UsyncLIDProtocol.js +24 -0
- package/lib/WAUSync/Protocols/index.d.ts +4 -0
- package/lib/WAUSync/Protocols/index.js +20 -0
- package/lib/WAUSync/USyncQuery.d.ts +28 -0
- package/lib/WAUSync/USyncQuery.js +89 -0
- package/lib/WAUSync/USyncUser.d.ts +12 -0
- package/lib/WAUSync/USyncUser.js +26 -0
- package/lib/WAUSync/index.js +19 -0
- package/lib/index.d.ts +12 -0
- package/lib/index.js +35 -0
- package/package.json +108 -0
|
@@ -0,0 +1,293 @@
|
|
|
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 WABinary_1 = require("../WABinary");
|
|
6
|
+
|
|
7
|
+
function isPnUser(jid) { return !!(jid?.endsWith('@s.whatsapp.net')); }
|
|
8
|
+
function isHostedPnUser(jid) { return !!(jid?.endsWith('@hosted')); }
|
|
9
|
+
function isLidUser(jid) { return !!(jid?.endsWith('@lid')); }
|
|
10
|
+
|
|
11
|
+
// WAJIDDomains equivalent
|
|
12
|
+
const WAJIDDomains = { WHATSAPP: 0, LID: 1, HOSTED: 128, HOSTED_LID: 129 };
|
|
13
|
+
|
|
14
|
+
class LIDMappingStore {
|
|
15
|
+
constructor(keys, logger, pnToLIDFunc) {
|
|
16
|
+
this.keys = keys;
|
|
17
|
+
this.logger = logger;
|
|
18
|
+
this.pnToLIDFunc = pnToLIDFunc;
|
|
19
|
+
this.mappingCache = new lru_cache_1.LRUCache({
|
|
20
|
+
ttl: 3 * 24 * 60 * 60 * 1000,
|
|
21
|
+
ttlAutopurge: true,
|
|
22
|
+
updateAgeOnGet: true
|
|
23
|
+
});
|
|
24
|
+
this.inflightLIDLookups = new Map();
|
|
25
|
+
this.inflightPNLookups = new Map();
|
|
26
|
+
}
|
|
27
|
+
|
|
28
|
+
async storeLIDPNMappings(pairs) {
|
|
29
|
+
if (pairs.length === 0) return;
|
|
30
|
+
|
|
31
|
+
const validatedPairs = [];
|
|
32
|
+
for (const { lid, pn } of pairs) {
|
|
33
|
+
if (!((isLidUser(lid) && isPnUser(pn)) || (isPnUser(lid) && isLidUser(pn)))) {
|
|
34
|
+
this.logger.warn(`Invalid LID-PN mapping: ${lid}, ${pn}`);
|
|
35
|
+
continue;
|
|
36
|
+
}
|
|
37
|
+
const lidDecoded = (0, WABinary_1.jidDecode)(lid);
|
|
38
|
+
const pnDecoded = (0, WABinary_1.jidDecode)(pn);
|
|
39
|
+
if (!lidDecoded || !pnDecoded) continue;
|
|
40
|
+
validatedPairs.push({ pnUser: pnDecoded.user, lidUser: lidDecoded.user });
|
|
41
|
+
}
|
|
42
|
+
|
|
43
|
+
if (validatedPairs.length === 0) return;
|
|
44
|
+
|
|
45
|
+
const cacheMissSet = new Set();
|
|
46
|
+
const existingMappings = new Map();
|
|
47
|
+
|
|
48
|
+
for (const { pnUser } of validatedPairs) {
|
|
49
|
+
const cached = this.mappingCache.get(`pn:${pnUser}`);
|
|
50
|
+
if (cached) {
|
|
51
|
+
existingMappings.set(pnUser, cached);
|
|
52
|
+
} else {
|
|
53
|
+
cacheMissSet.add(pnUser);
|
|
54
|
+
}
|
|
55
|
+
}
|
|
56
|
+
|
|
57
|
+
if (cacheMissSet.size > 0) {
|
|
58
|
+
const cacheMisses = [...cacheMissSet];
|
|
59
|
+
this.logger.trace(`Batch fetching ${cacheMisses.length} LID mappings from database`);
|
|
60
|
+
const stored = await this.keys.get('lid-mapping', cacheMisses);
|
|
61
|
+
for (const pnUser of cacheMisses) {
|
|
62
|
+
const existingLidUser = stored[pnUser];
|
|
63
|
+
if (existingLidUser) {
|
|
64
|
+
existingMappings.set(pnUser, existingLidUser);
|
|
65
|
+
this.mappingCache.set(`pn:${pnUser}`, existingLidUser);
|
|
66
|
+
this.mappingCache.set(`lid:${existingLidUser}`, pnUser);
|
|
67
|
+
}
|
|
68
|
+
}
|
|
69
|
+
}
|
|
70
|
+
|
|
71
|
+
const pairMap = {};
|
|
72
|
+
for (const { pnUser, lidUser } of validatedPairs) {
|
|
73
|
+
const existingLidUser = existingMappings.get(pnUser);
|
|
74
|
+
if (existingLidUser === lidUser) {
|
|
75
|
+
this.logger.debug({ pnUser, lidUser }, 'LID mapping already exists, skipping');
|
|
76
|
+
continue;
|
|
77
|
+
}
|
|
78
|
+
pairMap[pnUser] = lidUser;
|
|
79
|
+
}
|
|
80
|
+
|
|
81
|
+
if (Object.keys(pairMap).length === 0) return;
|
|
82
|
+
|
|
83
|
+
this.logger.trace({ pairMap }, `Storing ${Object.keys(pairMap).length} pn mappings`);
|
|
84
|
+
|
|
85
|
+
const batchData = {};
|
|
86
|
+
for (const [pnUser, lidUser] of Object.entries(pairMap)) {
|
|
87
|
+
batchData[pnUser] = lidUser;
|
|
88
|
+
batchData[`${lidUser}_reverse`] = pnUser;
|
|
89
|
+
}
|
|
90
|
+
|
|
91
|
+
await this.keys.transaction(async () => {
|
|
92
|
+
await this.keys.set({ 'lid-mapping': batchData });
|
|
93
|
+
}, 'lid-mapping');
|
|
94
|
+
|
|
95
|
+
for (const [pnUser, lidUser] of Object.entries(pairMap)) {
|
|
96
|
+
this.mappingCache.set(`pn:${pnUser}`, lidUser);
|
|
97
|
+
this.mappingCache.set(`lid:${lidUser}`, pnUser);
|
|
98
|
+
}
|
|
99
|
+
}
|
|
100
|
+
|
|
101
|
+
async getLIDForPN(pn) {
|
|
102
|
+
return (await this.getLIDsForPNs([pn]))?.[0]?.lid || null;
|
|
103
|
+
}
|
|
104
|
+
|
|
105
|
+
async getLIDsForPNs(pns) {
|
|
106
|
+
if (pns.length === 0) return null;
|
|
107
|
+
const sortedPns = [...new Set(pns)].sort();
|
|
108
|
+
const cacheKey = sortedPns.join(',');
|
|
109
|
+
const inflight = this.inflightLIDLookups.get(cacheKey);
|
|
110
|
+
if (inflight) {
|
|
111
|
+
this.logger.trace(`Coalescing getLIDsForPNs request for ${sortedPns.length} PNs`);
|
|
112
|
+
return inflight;
|
|
113
|
+
}
|
|
114
|
+
const promise = this._getLIDsForPNsImpl(pns);
|
|
115
|
+
this.inflightLIDLookups.set(cacheKey, promise);
|
|
116
|
+
try {
|
|
117
|
+
return await promise;
|
|
118
|
+
} finally {
|
|
119
|
+
this.inflightLIDLookups.delete(cacheKey);
|
|
120
|
+
}
|
|
121
|
+
}
|
|
122
|
+
|
|
123
|
+
async _getLIDsForPNsImpl(pns) {
|
|
124
|
+
const usyncFetch = {};
|
|
125
|
+
const successfulPairs = {};
|
|
126
|
+
const pending = [];
|
|
127
|
+
|
|
128
|
+
const addResolvedPair = (pn, decoded, lidUser) => {
|
|
129
|
+
const normalizedLidUser = lidUser.toString();
|
|
130
|
+
if (!normalizedLidUser) {
|
|
131
|
+
this.logger.warn(`Invalid or empty LID user for PN ${pn}: lidUser = "${lidUser}"`);
|
|
132
|
+
return false;
|
|
133
|
+
}
|
|
134
|
+
const pnDevice = decoded?.device !== undefined ? decoded.device : 0;
|
|
135
|
+
const deviceSpecificLid = `${normalizedLidUser}${pnDevice ? `:${pnDevice}` : ''}@${
|
|
136
|
+
decoded?.server === 'hosted' ? 'hosted.lid' : 'lid'
|
|
137
|
+
}`;
|
|
138
|
+
this.logger.trace(`getLIDForPN: ${pn} → ${deviceSpecificLid} (user mapping with device ${pnDevice})`);
|
|
139
|
+
successfulPairs[pn] = { lid: deviceSpecificLid, pn };
|
|
140
|
+
return true;
|
|
141
|
+
};
|
|
142
|
+
|
|
143
|
+
for (const pn of pns) {
|
|
144
|
+
if (!isPnUser(pn) && !isHostedPnUser(pn)) continue;
|
|
145
|
+
const decoded = (0, WABinary_1.jidDecode)(pn);
|
|
146
|
+
if (!decoded) continue;
|
|
147
|
+
const pnUser = decoded.user;
|
|
148
|
+
const cached = this.mappingCache.get(`pn:${pnUser}`);
|
|
149
|
+
if (cached && typeof cached === 'string') {
|
|
150
|
+
if (!addResolvedPair(pn, decoded, cached)) {
|
|
151
|
+
this.logger.warn(`Invalid entry for ${pn} (pair not resolved)`);
|
|
152
|
+
continue;
|
|
153
|
+
}
|
|
154
|
+
continue;
|
|
155
|
+
}
|
|
156
|
+
pending.push({ pn, pnUser, decoded });
|
|
157
|
+
}
|
|
158
|
+
|
|
159
|
+
if (pending.length) {
|
|
160
|
+
const pnUsers = [...new Set(pending.map(item => item.pnUser))];
|
|
161
|
+
const stored = await this.keys.get('lid-mapping', pnUsers);
|
|
162
|
+
for (const pnUser of pnUsers) {
|
|
163
|
+
const lidUser = stored[pnUser];
|
|
164
|
+
if (lidUser && typeof lidUser === 'string') {
|
|
165
|
+
this.mappingCache.set(`pn:${pnUser}`, lidUser);
|
|
166
|
+
this.mappingCache.set(`lid:${lidUser}`, pnUser);
|
|
167
|
+
}
|
|
168
|
+
}
|
|
169
|
+
|
|
170
|
+
for (const { pn, pnUser, decoded } of pending) {
|
|
171
|
+
const cached = this.mappingCache.get(`pn:${pnUser}`);
|
|
172
|
+
if (cached && typeof cached === 'string') {
|
|
173
|
+
if (!addResolvedPair(pn, decoded, cached)) {
|
|
174
|
+
this.logger.warn(`Invalid entry for ${pn} (pair not resolved)`);
|
|
175
|
+
continue;
|
|
176
|
+
}
|
|
177
|
+
} else {
|
|
178
|
+
this.logger.trace(`No LID mapping found for PN user ${pnUser}; batch getting from USync`);
|
|
179
|
+
const device = decoded?.device || 0;
|
|
180
|
+
let normalizedPn = (0, WABinary_1.jidNormalizedUser)(pn);
|
|
181
|
+
if (isHostedPnUser(normalizedPn)) {
|
|
182
|
+
normalizedPn = `${pnUser}@s.whatsapp.net`;
|
|
183
|
+
}
|
|
184
|
+
if (!usyncFetch[normalizedPn]) {
|
|
185
|
+
usyncFetch[normalizedPn] = [device];
|
|
186
|
+
} else {
|
|
187
|
+
usyncFetch[normalizedPn].push(device);
|
|
188
|
+
}
|
|
189
|
+
}
|
|
190
|
+
}
|
|
191
|
+
}
|
|
192
|
+
|
|
193
|
+
if (Object.keys(usyncFetch).length > 0) {
|
|
194
|
+
const result = await this.pnToLIDFunc?.(Object.keys(usyncFetch));
|
|
195
|
+
if (result && result.length > 0) {
|
|
196
|
+
await this.storeLIDPNMappings(result);
|
|
197
|
+
for (const pair of result) {
|
|
198
|
+
const pnDecoded = (0, WABinary_1.jidDecode)(pair.pn);
|
|
199
|
+
const pnUser = pnDecoded?.user;
|
|
200
|
+
if (!pnUser) continue;
|
|
201
|
+
const lidUser = (0, WABinary_1.jidDecode)(pair.lid)?.user;
|
|
202
|
+
if (!lidUser) continue;
|
|
203
|
+
for (const device of usyncFetch[pair.pn] || []) {
|
|
204
|
+
const deviceSpecificLid = `${lidUser}${device ? `:${device}` : ''}@${device === 99 ? 'hosted.lid' : 'lid'}`;
|
|
205
|
+
const deviceSpecificPn = `${pnUser}${device ? `:${device}` : ''}@${device === 99 ? 'hosted' : 's.whatsapp.net'}`;
|
|
206
|
+
successfulPairs[deviceSpecificPn] = { lid: deviceSpecificLid, pn: deviceSpecificPn };
|
|
207
|
+
}
|
|
208
|
+
}
|
|
209
|
+
} else {
|
|
210
|
+
this.logger.warn('USync fetch yielded no results for pending PNs');
|
|
211
|
+
}
|
|
212
|
+
}
|
|
213
|
+
|
|
214
|
+
const vals = Object.values(successfulPairs);
|
|
215
|
+
return vals.length > 0 ? vals : null;
|
|
216
|
+
}
|
|
217
|
+
|
|
218
|
+
async getPNForLID(lid) {
|
|
219
|
+
return (await this.getPNsForLIDs([lid]))?.[0]?.pn || null;
|
|
220
|
+
}
|
|
221
|
+
|
|
222
|
+
async getPNsForLIDs(lids) {
|
|
223
|
+
if (lids.length === 0) return null;
|
|
224
|
+
const sortedLids = [...new Set(lids)].sort();
|
|
225
|
+
const cacheKey = sortedLids.join(',');
|
|
226
|
+
const inflight = this.inflightPNLookups.get(cacheKey);
|
|
227
|
+
if (inflight) {
|
|
228
|
+
this.logger.trace(`Coalescing getPNsForLIDs request for ${sortedLids.length} LIDs`);
|
|
229
|
+
return inflight;
|
|
230
|
+
}
|
|
231
|
+
const promise = this._getPNsForLIDsImpl(lids);
|
|
232
|
+
this.inflightPNLookups.set(cacheKey, promise);
|
|
233
|
+
try {
|
|
234
|
+
return await promise;
|
|
235
|
+
} finally {
|
|
236
|
+
this.inflightPNLookups.delete(cacheKey);
|
|
237
|
+
}
|
|
238
|
+
}
|
|
239
|
+
|
|
240
|
+
async _getPNsForLIDsImpl(lids) {
|
|
241
|
+
const successfulPairs = {};
|
|
242
|
+
const pending = [];
|
|
243
|
+
|
|
244
|
+
const addResolvedPair = (lid, decoded, pnUser) => {
|
|
245
|
+
if (!pnUser || typeof pnUser !== 'string') return false;
|
|
246
|
+
const lidDevice = decoded?.device !== undefined ? decoded.device : 0;
|
|
247
|
+
const pnJid = `${pnUser}:${lidDevice}@${
|
|
248
|
+
decoded?.domainType === WAJIDDomains.HOSTED_LID ? 'hosted' : 's.whatsapp.net'
|
|
249
|
+
}`;
|
|
250
|
+
this.logger.trace(`Found reverse mapping: ${lid} → ${pnJid}`);
|
|
251
|
+
successfulPairs[lid] = { lid, pn: pnJid };
|
|
252
|
+
return true;
|
|
253
|
+
};
|
|
254
|
+
|
|
255
|
+
for (const lid of lids) {
|
|
256
|
+
if (!isLidUser(lid)) continue;
|
|
257
|
+
const decoded = (0, WABinary_1.jidDecode)(lid);
|
|
258
|
+
if (!decoded) continue;
|
|
259
|
+
const lidUser = decoded.user;
|
|
260
|
+
const cached = this.mappingCache.get(`lid:${lidUser}`);
|
|
261
|
+
if (cached && typeof cached === 'string') {
|
|
262
|
+
addResolvedPair(lid, decoded, cached);
|
|
263
|
+
continue;
|
|
264
|
+
}
|
|
265
|
+
pending.push({ lid, lidUser, decoded });
|
|
266
|
+
}
|
|
267
|
+
|
|
268
|
+
if (pending.length) {
|
|
269
|
+
const reverseKeys = [...new Set(pending.map(item => `${item.lidUser}_reverse`))];
|
|
270
|
+
const stored = await this.keys.get('lid-mapping', reverseKeys);
|
|
271
|
+
|
|
272
|
+
for (const { lid, lidUser, decoded } of pending) {
|
|
273
|
+
let pnUser = this.mappingCache.get(`lid:${lidUser}`);
|
|
274
|
+
if (!pnUser || typeof pnUser !== 'string') {
|
|
275
|
+
pnUser = stored[`${lidUser}_reverse`];
|
|
276
|
+
if (pnUser && typeof pnUser === 'string') {
|
|
277
|
+
this.mappingCache.set(`lid:${lidUser}`, pnUser);
|
|
278
|
+
this.mappingCache.set(`pn:${pnUser}`, lidUser);
|
|
279
|
+
}
|
|
280
|
+
}
|
|
281
|
+
if (pnUser && typeof pnUser === 'string') {
|
|
282
|
+
addResolvedPair(lid, decoded, pnUser);
|
|
283
|
+
} else {
|
|
284
|
+
this.logger.trace(`No reverse mapping found for LID user: ${lidUser}`);
|
|
285
|
+
}
|
|
286
|
+
}
|
|
287
|
+
}
|
|
288
|
+
|
|
289
|
+
const vals = Object.values(successfulPairs);
|
|
290
|
+
return vals.length ? vals : null;
|
|
291
|
+
}
|
|
292
|
+
}
|
|
293
|
+
exports.LIDMappingStore = LIDMappingStore;
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
/// <reference types="node" />
|
|
2
|
+
/// <reference types="node" />
|
|
3
|
+
import { EventEmitter } from 'events';
|
|
4
|
+
import { URL } from 'url';
|
|
5
|
+
import { SocketConfig } from '../../Types';
|
|
6
|
+
export declare abstract class AbstractSocketClient extends EventEmitter {
|
|
7
|
+
url: URL;
|
|
8
|
+
config: SocketConfig;
|
|
9
|
+
abstract get isOpen(): boolean;
|
|
10
|
+
abstract get isClosed(): boolean;
|
|
11
|
+
abstract get isClosing(): boolean;
|
|
12
|
+
abstract get isConnecting(): boolean;
|
|
13
|
+
constructor(url: URL, config: SocketConfig);
|
|
14
|
+
abstract connect(): Promise<void>;
|
|
15
|
+
abstract close(): Promise<void>;
|
|
16
|
+
abstract send(str: Uint8Array | string, cb?: (err?: Error) => void): boolean;
|
|
17
|
+
}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.AbstractSocketClient = void 0;
|
|
4
|
+
const events_1 = require("events");
|
|
5
|
+
class AbstractSocketClient extends events_1.EventEmitter {
|
|
6
|
+
constructor(url, config) {
|
|
7
|
+
super();
|
|
8
|
+
this.url = url;
|
|
9
|
+
this.config = config;
|
|
10
|
+
this.setMaxListeners(0);
|
|
11
|
+
}
|
|
12
|
+
}
|
|
13
|
+
exports.AbstractSocketClient = AbstractSocketClient;
|
|
@@ -0,0 +1,19 @@
|
|
|
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);
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
/// <reference types="node" />
|
|
2
|
+
import { Socket } from 'net';
|
|
3
|
+
import { AbstractSocketClient } from './abstract-socket-client';
|
|
4
|
+
export declare class MobileSocketClient extends AbstractSocketClient {
|
|
5
|
+
protected socket: Socket | null;
|
|
6
|
+
get isOpen(): boolean;
|
|
7
|
+
get isClosed(): boolean;
|
|
8
|
+
get isClosing(): boolean;
|
|
9
|
+
get isConnecting(): boolean;
|
|
10
|
+
connect(): Promise<void>;
|
|
11
|
+
close(): Promise<void>;
|
|
12
|
+
send(str: string | Uint8Array, cb?: (err?: Error) => void): boolean;
|
|
13
|
+
}
|
|
@@ -0,0 +1,65 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.MobileSocketClient = void 0;
|
|
4
|
+
const net_1 = require("net");
|
|
5
|
+
const abstract_socket_client_1 = require("./abstract-socket-client");
|
|
6
|
+
class MobileSocketClient extends abstract_socket_client_1.AbstractSocketClient {
|
|
7
|
+
constructor() {
|
|
8
|
+
super(...arguments);
|
|
9
|
+
this.socket = null;
|
|
10
|
+
}
|
|
11
|
+
get isOpen() {
|
|
12
|
+
var _a;
|
|
13
|
+
return ((_a = this.socket) === null || _a === void 0 ? void 0 : _a.readyState) === 'open';
|
|
14
|
+
}
|
|
15
|
+
get isClosed() {
|
|
16
|
+
var _a;
|
|
17
|
+
return this.socket === null || ((_a = this.socket) === null || _a === void 0 ? void 0 : _a.readyState) === 'closed';
|
|
18
|
+
}
|
|
19
|
+
get isClosing() {
|
|
20
|
+
var _a;
|
|
21
|
+
return this.socket === null || ((_a = this.socket) === null || _a === void 0 ? void 0 : _a.readyState) === 'closed';
|
|
22
|
+
}
|
|
23
|
+
get isConnecting() {
|
|
24
|
+
var _a;
|
|
25
|
+
return ((_a = this.socket) === null || _a === void 0 ? void 0 : _a.readyState) === 'opening';
|
|
26
|
+
}
|
|
27
|
+
async connect() {
|
|
28
|
+
var _a;
|
|
29
|
+
if (this.socket) {
|
|
30
|
+
return;
|
|
31
|
+
}
|
|
32
|
+
if (this.config.agent) {
|
|
33
|
+
throw new Error('There are not support for proxy agent for mobile connection');
|
|
34
|
+
}
|
|
35
|
+
else {
|
|
36
|
+
this.socket = (0, net_1.connect)({
|
|
37
|
+
host: this.url.hostname,
|
|
38
|
+
port: Number(this.url.port) || 443
|
|
39
|
+
});
|
|
40
|
+
}
|
|
41
|
+
this.socket.setMaxListeners(0);
|
|
42
|
+
const events = ['close', 'connect', 'data', 'drain', 'end', 'error', 'lookup', 'ready', 'timeout'];
|
|
43
|
+
for (const event of events) {
|
|
44
|
+
(_a = this.socket) === null || _a === void 0 ? void 0 : _a.on(event, (...args) => this.emit(event, ...args));
|
|
45
|
+
}
|
|
46
|
+
this.socket.on('data', (...args) => this.emit('message', ...args));
|
|
47
|
+
this.socket.on('ready', (...args) => this.emit('open', ...args));
|
|
48
|
+
}
|
|
49
|
+
async close() {
|
|
50
|
+
if (!this.socket) {
|
|
51
|
+
return;
|
|
52
|
+
}
|
|
53
|
+
return new Promise(resolve => {
|
|
54
|
+
this.socket.end(resolve);
|
|
55
|
+
this.socket = null;
|
|
56
|
+
});
|
|
57
|
+
}
|
|
58
|
+
send(str, cb) {
|
|
59
|
+
if (this.socket === null) {
|
|
60
|
+
return false;
|
|
61
|
+
}
|
|
62
|
+
return this.socket.write(str, undefined, cb);
|
|
63
|
+
}
|
|
64
|
+
}
|
|
65
|
+
exports.MobileSocketClient = MobileSocketClient;
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import WebSocket from 'ws';
|
|
2
|
+
import { AbstractSocketClient } from './abstract-socket-client';
|
|
3
|
+
export declare class WebSocketClient extends AbstractSocketClient {
|
|
4
|
+
protected socket: WebSocket | null;
|
|
5
|
+
get isOpen(): boolean;
|
|
6
|
+
get isClosed(): boolean;
|
|
7
|
+
get isClosing(): boolean;
|
|
8
|
+
get isConnecting(): boolean;
|
|
9
|
+
connect(): Promise<void>;
|
|
10
|
+
close(): Promise<void>;
|
|
11
|
+
send(str: string | Uint8Array, cb?: (err?: Error) => void): boolean;
|
|
12
|
+
}
|
|
@@ -0,0 +1,62 @@
|
|
|
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.WebSocketClient = void 0;
|
|
7
|
+
const ws_1 = __importDefault(require("ws"));
|
|
8
|
+
const Defaults_1 = require("../../Defaults");
|
|
9
|
+
const abstract_socket_client_1 = require("./abstract-socket-client");
|
|
10
|
+
class WebSocketClient extends abstract_socket_client_1.AbstractSocketClient {
|
|
11
|
+
constructor() {
|
|
12
|
+
super(...arguments);
|
|
13
|
+
this.socket = null;
|
|
14
|
+
}
|
|
15
|
+
get isOpen() {
|
|
16
|
+
var _a;
|
|
17
|
+
return ((_a = this.socket) === null || _a === void 0 ? void 0 : _a.readyState) === ws_1.default.OPEN;
|
|
18
|
+
}
|
|
19
|
+
get isClosed() {
|
|
20
|
+
var _a;
|
|
21
|
+
return this.socket === null || ((_a = this.socket) === null || _a === void 0 ? void 0 : _a.readyState) === ws_1.default.CLOSED;
|
|
22
|
+
}
|
|
23
|
+
get isClosing() {
|
|
24
|
+
var _a;
|
|
25
|
+
return this.socket === null || ((_a = this.socket) === null || _a === void 0 ? void 0 : _a.readyState) === ws_1.default.CLOSING;
|
|
26
|
+
}
|
|
27
|
+
get isConnecting() {
|
|
28
|
+
var _a;
|
|
29
|
+
return ((_a = this.socket) === null || _a === void 0 ? void 0 : _a.readyState) === ws_1.default.CONNECTING;
|
|
30
|
+
}
|
|
31
|
+
async connect() {
|
|
32
|
+
var _a, _b;
|
|
33
|
+
if (this.socket) {
|
|
34
|
+
return;
|
|
35
|
+
}
|
|
36
|
+
this.socket = new ws_1.default(this.url, {
|
|
37
|
+
origin: Defaults_1.DEFAULT_ORIGIN,
|
|
38
|
+
headers: (_a = this.config.options) === null || _a === void 0 ? void 0 : _a.headers,
|
|
39
|
+
handshakeTimeout: this.config.connectTimeoutMs,
|
|
40
|
+
timeout: this.config.connectTimeoutMs,
|
|
41
|
+
agent: this.config.agent,
|
|
42
|
+
});
|
|
43
|
+
this.socket.setMaxListeners(0);
|
|
44
|
+
const events = ['close', 'error', 'upgrade', 'message', 'open', 'ping', 'pong', 'unexpected-response'];
|
|
45
|
+
for (const event of events) {
|
|
46
|
+
(_b = this.socket) === null || _b === void 0 ? void 0 : _b.on(event, (...args) => this.emit(event, ...args));
|
|
47
|
+
}
|
|
48
|
+
}
|
|
49
|
+
async close() {
|
|
50
|
+
if (!this.socket) {
|
|
51
|
+
return;
|
|
52
|
+
}
|
|
53
|
+
this.socket.close();
|
|
54
|
+
this.socket = null;
|
|
55
|
+
}
|
|
56
|
+
send(str, cb) {
|
|
57
|
+
var _a;
|
|
58
|
+
(_a = this.socket) === null || _a === void 0 ? void 0 : _a.send(str, cb);
|
|
59
|
+
return Boolean(this.socket);
|
|
60
|
+
}
|
|
61
|
+
}
|
|
62
|
+
exports.WebSocketClient = WebSocketClient;
|