@alannxd/baileys 6.0.5 → 6.0.6
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/WAProto/fix-import.js +29 -0
- package/WAProto/index.js +160 -201
- package/engine-requirements.js +1 -1
- package/lib/Defaults/baileys-version.json +3 -0
- package/lib/Defaults/index.d.ts +15 -37
- package/lib/Defaults/index.js +136 -119
- package/lib/Defaults/phonenumber-mcc.json +223 -0
- package/lib/Signal/Group/ciphertext-message.d.ts +0 -1
- package/lib/Signal/Group/ciphertext-message.js +5 -2
- package/lib/Signal/Group/group-session-builder.d.ts +3 -4
- package/lib/Signal/Group/group-session-builder.js +41 -7
- package/lib/Signal/Group/group_cipher.d.ts +4 -4
- package/lib/Signal/Group/group_cipher.js +51 -37
- package/lib/Signal/Group/index.d.ts +11 -12
- package/lib/Signal/Group/index.js +57 -12
- package/lib/Signal/Group/keyhelper.d.ts +1 -2
- package/lib/Signal/Group/keyhelper.js +44 -7
- 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 +2 -3
- package/lib/Signal/Group/sender-chain-key.js +15 -7
- package/lib/Signal/Group/sender-key-distribution-message.d.ts +1 -2
- package/lib/Signal/Group/sender-key-distribution-message.js +11 -8
- package/lib/Signal/Group/sender-key-message.d.ts +1 -2
- package/lib/Signal/Group/sender-key-message.js +12 -9
- package/lib/Signal/Group/sender-key-name.d.ts +0 -1
- package/lib/Signal/Group/sender-key-name.js +5 -2
- package/lib/Signal/Group/sender-key-record.d.ts +2 -3
- package/lib/Signal/Group/sender-key-record.js +21 -9
- package/lib/Signal/Group/sender-key-state.d.ts +6 -7
- package/lib/Signal/Group/sender-key-state.js +42 -27
- package/lib/Signal/Group/sender-message-key.d.ts +0 -1
- package/lib/Signal/Group/sender-message-key.js +7 -4
- package/lib/Signal/libsignal.d.ts +3 -5
- package/lib/Signal/libsignal.js +90 -347
- package/lib/Socket/Client/{types.d.ts → abstract-socket-client.d.ts} +5 -4
- package/lib/Socket/Client/abstract-socket-client.js +13 -0
- package/lib/Socket/Client/index.d.ts +3 -3
- package/lib/Socket/Client/index.js +19 -3
- 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/{websocket.d.ts → web-socket-client.d.ts} +2 -3
- package/lib/Socket/Client/web-socket-client.js +62 -0
- package/lib/Socket/business.d.ts +108 -154
- package/lib/Socket/business.js +43 -162
- package/lib/Socket/chats.d.ts +239 -96
- package/lib/Socket/chats.js +427 -627
- package/lib/Socket/communities.d.ts +146 -239
- package/lib/Socket/communities.js +80 -90
- package/lib/Socket/groups.d.ts +57 -104
- package/lib/Socket/groups.js +161 -154
- package/lib/Socket/index.d.ts +115 -202
- package/lib/Socket/index.js +10 -11
- package/lib/Socket/luxu.d.ts +266 -22
- package/lib/Socket/luxu.js +465 -422
- package/lib/Socket/messages-recv.d.ts +84 -136
- package/lib/Socket/messages-recv.js +615 -1421
- package/lib/Socket/messages-send.d.ts +126 -142
- package/lib/Socket/messages-send.js +671 -878
- package/lib/Socket/newsletter.d.ts +85 -121
- package/lib/Socket/newsletter.js +272 -147
- package/lib/Socket/registration.d.ts +267 -0
- package/lib/Socket/registration.js +166 -0
- package/lib/Socket/socket.d.ts +19 -34
- package/lib/Socket/socket.js +313 -544
- package/lib/Socket/usync.d.ts +36 -0
- package/lib/Socket/usync.js +70 -0
- package/lib/Store/index.d.ts +3 -10
- package/lib/Store/index.js +10 -10
- package/lib/Store/make-cache-manager-store.d.ts +11 -17
- package/lib/Store/make-cache-manager-store.js +41 -43
- package/lib/Store/make-in-memory-store.d.ts +118 -39
- package/lib/Store/make-in-memory-store.js +341 -112
- package/lib/Store/make-ordered-dictionary.d.ts +10 -11
- package/lib/Store/make-ordered-dictionary.js +20 -14
- package/lib/Store/object-repository.d.ts +9 -10
- package/lib/Store/object-repository.js +6 -11
- package/lib/Types/Auth.d.ts +12 -19
- package/lib/Types/Auth.js +2 -2
- package/lib/Types/Call.d.ts +1 -3
- package/lib/Types/Call.js +2 -2
- package/lib/Types/Chat.d.ts +13 -35
- package/lib/Types/Chat.js +4 -8
- package/lib/Types/Contact.d.ts +1 -8
- package/lib/Types/Contact.js +2 -2
- package/lib/Types/Events.d.ts +17 -116
- package/lib/Types/Events.js +2 -2
- package/lib/Types/GroupMetadata.d.ts +5 -21
- package/lib/Types/GroupMetadata.js +2 -2
- package/lib/Types/Label.d.ts +0 -12
- package/lib/Types/Label.js +5 -3
- package/lib/Types/LabelAssociation.d.ts +0 -1
- package/lib/Types/LabelAssociation.js +5 -3
- package/lib/Types/Message.d.ts +58 -105
- package/lib/Types/Message.js +9 -11
- package/lib/Types/Newsletter.d.ts +103 -0
- package/lib/Types/Newsletter.js +38 -0
- package/lib/Types/Product.d.ts +1 -2
- package/lib/Types/Product.js +2 -2
- package/lib/Types/Signal.d.ts +2 -32
- package/lib/Types/Signal.js +2 -2
- package/lib/Types/Socket.d.ts +25 -50
- package/lib/Types/Socket.js +2 -3
- package/lib/Types/State.d.ts +2 -72
- package/lib/Types/State.js +2 -56
- package/lib/Types/USync.d.ts +2 -3
- package/lib/Types/USync.js +2 -2
- package/lib/Types/index.d.ts +14 -22
- package/lib/Types/index.js +31 -15
- package/lib/Utils/auth-utils.d.ts +6 -12
- package/lib/Utils/auth-utils.js +143 -239
- 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 +2 -3
- package/lib/Utils/business.js +69 -66
- package/lib/Utils/chat-utils.d.ts +23 -52
- package/lib/Utils/chat-utils.js +253 -396
- package/lib/Utils/crypto.d.ts +22 -18
- package/lib/Utils/crypto.js +90 -57
- package/lib/Utils/decode-wa-message.d.ts +8 -55
- package/lib/Utils/decode-wa-message.js +84 -203
- package/lib/Utils/event-buffer.d.ts +8 -9
- package/lib/Utils/event-buffer.js +77 -185
- package/lib/Utils/generics.d.ts +29 -28
- package/lib/Utils/generics.js +210 -180
- package/lib/Utils/history.d.ts +9 -18
- package/lib/Utils/history.js +55 -93
- package/lib/Utils/index.d.ts +17 -22
- package/lib/Utils/index.js +33 -22
- package/lib/Utils/link-preview.d.ts +5 -5
- package/lib/Utils/link-preview.js +24 -16
- package/lib/Utils/logger.d.ts +3 -11
- package/lib/Utils/logger.js +7 -3
- package/lib/Utils/lt-hash.d.ts +12 -8
- package/lib/Utils/lt-hash.js +46 -3
- package/lib/Utils/make-mutex.d.ts +2 -4
- package/lib/Utils/make-mutex.js +34 -24
- package/lib/Utils/messages-media.d.ts +44 -61
- package/lib/Utils/messages-media.js +482 -451
- package/lib/Utils/messages.d.ts +18 -32
- package/lib/Utils/messages.js +369 -458
- package/lib/Utils/noise-handler.d.ts +14 -13
- package/lib/Utils/noise-handler.js +99 -145
- package/lib/Utils/process-message.d.ts +12 -31
- package/lib/Utils/process-message.js +150 -459
- package/lib/Utils/signal.d.ts +5 -20
- package/lib/Utils/signal.js +72 -120
- package/lib/Utils/use-multi-file-auth-state.d.ts +2 -2
- package/lib/Utils/use-multi-file-auth-state.js +27 -29
- package/lib/Utils/validate-connection.d.ts +7 -7
- package/lib/Utils/validate-connection.js +99 -73
- package/lib/WABinary/constants.d.ts +27 -25
- package/lib/WABinary/constants.js +20 -1281
- package/lib/WABinary/decode.d.ts +5 -5
- package/lib/WABinary/decode.js +42 -52
- package/lib/WABinary/encode.d.ts +3 -3
- package/lib/WABinary/encode.js +155 -110
- package/lib/WABinary/generic-utils.d.ts +7 -8
- package/lib/WABinary/generic-utils.js +49 -48
- package/lib/WABinary/index.d.ts +5 -6
- package/lib/WABinary/index.js +21 -6
- package/lib/WABinary/jid-utils.d.ts +8 -25
- package/lib/WABinary/jid-utils.js +40 -74
- package/lib/WABinary/types.d.ts +1 -2
- package/lib/WABinary/types.js +2 -2
- package/lib/WAM/BinaryInfo.d.ts +11 -3
- package/lib/WAM/BinaryInfo.js +5 -2
- package/lib/WAM/constants.d.ts +3 -5
- package/lib/WAM/constants.js +11958 -19461
- package/lib/WAM/encode.d.ts +3 -3
- package/lib/WAM/encode.js +22 -17
- package/lib/WAM/index.d.ts +3 -4
- package/lib/WAM/index.js +19 -4
- package/lib/WAUSync/Protocols/USyncContactProtocol.d.ts +3 -4
- package/lib/WAUSync/Protocols/USyncContactProtocol.js +13 -33
- package/lib/WAUSync/Protocols/USyncDeviceProtocol.d.ts +2 -3
- package/lib/WAUSync/Protocols/USyncDeviceProtocol.js +14 -11
- package/lib/WAUSync/Protocols/USyncDisappearingModeProtocol.d.ts +2 -3
- package/lib/WAUSync/Protocols/USyncDisappearingModeProtocol.js +12 -9
- package/lib/WAUSync/Protocols/USyncStatusProtocol.d.ts +2 -3
- package/lib/WAUSync/Protocols/USyncStatusProtocol.js +13 -9
- package/lib/WAUSync/Protocols/UsyncBotProfileProtocol.d.ts +3 -4
- package/lib/WAUSync/Protocols/UsyncBotProfileProtocol.js +22 -20
- package/lib/WAUSync/Protocols/UsyncLIDProtocol.d.ts +3 -5
- package/lib/WAUSync/Protocols/UsyncLIDProtocol.js +8 -13
- package/lib/WAUSync/Protocols/index.d.ts +4 -6
- package/lib/WAUSync/Protocols/index.js +20 -6
- package/lib/WAUSync/USyncQuery.d.ts +4 -6
- package/lib/WAUSync/USyncQuery.js +35 -44
- package/lib/WAUSync/USyncUser.d.ts +5 -10
- package/lib/WAUSync/USyncUser.js +5 -10
- package/lib/WAUSync/index.js +19 -4
- package/lib/index.d.ts +9 -10
- package/lib/index.js +34 -12
- package/package.json +50 -83
- package/WAProto/GenerateStatics.sh +0 -3
- package/WAProto/WAProto.proto +0 -5479
- package/WAProto/fix-imports.js +0 -85
- package/WAProto/index.d.ts +0 -14017
- package/lib/Signal/lid-mapping.d.ts +0 -23
- package/lib/Signal/lid-mapping.js +0 -277
- package/lib/Socket/Client/types.js +0 -11
- package/lib/Socket/Client/websocket.js +0 -54
- package/lib/Socket/mex.d.ts +0 -3
- package/lib/Socket/mex.js +0 -42
- package/lib/Store/keyed-db.d.ts +0 -22
- package/lib/Store/keyed-db.js +0 -108
- package/lib/Types/Bussines.d.ts +0 -25
- package/lib/Types/Bussines.js +0 -2
- package/lib/Types/Mex.d.ts +0 -141
- package/lib/Types/Mex.js +0 -37
- package/lib/Utils/browser-utils.d.ts +0 -4
- package/lib/Utils/browser-utils.js +0 -28
- package/lib/Utils/companion-reg-client-utils.d.ts +0 -17
- package/lib/Utils/companion-reg-client-utils.js +0 -35
- package/lib/Utils/identity-change-handler.d.ts +0 -44
- package/lib/Utils/identity-change-handler.js +0 -50
- package/lib/Utils/message-retry-manager.d.ts +0 -115
- package/lib/Utils/message-retry-manager.js +0 -265
- package/lib/Utils/offline-node-processor.d.ts +0 -17
- package/lib/Utils/offline-node-processor.js +0 -40
- package/lib/Utils/pre-key-manager.d.ts +0 -28
- package/lib/Utils/pre-key-manager.js +0 -106
- package/lib/Utils/reporting-utils.d.ts +0 -11
- package/lib/Utils/reporting-utils.js +0 -258
- package/lib/Utils/stanza-ack.d.ts +0 -11
- package/lib/Utils/stanza-ack.js +0 -38
- package/lib/Utils/sync-action-utils.d.ts +0 -19
- package/lib/Utils/sync-action-utils.js +0 -49
- package/lib/Utils/tc-token-utils.d.ts +0 -37
- package/lib/Utils/tc-token-utils.js +0 -163
- package/lib/WAUSync/Protocols/USyncUsernameProtocol.d.ts +0 -10
- package/lib/WAUSync/Protocols/USyncUsernameProtocol.js +0 -25
- package/lib/WAUSync/index.d.ts +0 -4
|
@@ -1,23 +0,0 @@
|
|
|
1
|
-
import type { LIDMapping, SignalKeyStoreWithTransaction } from '../Types/index.js';
|
|
2
|
-
import type { ILogger } from '../Utils/logger.js';
|
|
3
|
-
export declare class LIDMappingStore {
|
|
4
|
-
private readonly mappingCache;
|
|
5
|
-
private readonly keys;
|
|
6
|
-
private readonly logger;
|
|
7
|
-
private pnToLIDFunc?;
|
|
8
|
-
private readonly inflightLIDLookups;
|
|
9
|
-
private readonly inflightPNLookups;
|
|
10
|
-
constructor(keys: SignalKeyStoreWithTransaction, logger: ILogger, pnToLIDFunc?: (jids: string[]) => Promise<LIDMapping[] | undefined>);
|
|
11
|
-
storeLIDPNMappings(pairs: LIDMapping[]): Promise<void>;
|
|
12
|
-
getLIDForPN(pn: string): Promise<string | null>;
|
|
13
|
-
getLIDsForPNs(pns: string[]): Promise<LIDMapping[] | null>;
|
|
14
|
-
private _getLIDsForPNsImpl;
|
|
15
|
-
getPNForLID(lid: string): Promise<string | null>;
|
|
16
|
-
getPNsForLIDs(lids: string[]): Promise<LIDMapping[] | null>;
|
|
17
|
-
private _getPNsForLIDsImpl;
|
|
18
|
-
/**
|
|
19
|
-
* Close the cache and release resources
|
|
20
|
-
*/
|
|
21
|
-
close(): void;
|
|
22
|
-
}
|
|
23
|
-
//# sourceMappingURL=lid-mapping.d.ts.map
|
|
@@ -1,277 +0,0 @@
|
|
|
1
|
-
import { LRUCache } from 'lru-cache';
|
|
2
|
-
import { isHostedPnUser, isLidUser, isPnUser, jidDecode, jidNormalizedUser, WAJIDDomains } from '../WABinary/index.js';
|
|
3
|
-
export class LIDMappingStore {
|
|
4
|
-
constructor(keys, logger, pnToLIDFunc) {
|
|
5
|
-
this.mappingCache = new LRUCache({
|
|
6
|
-
ttl: 3 * 24 * 60 * 60 * 1000, // 7 days
|
|
7
|
-
ttlAutopurge: true,
|
|
8
|
-
updateAgeOnGet: true
|
|
9
|
-
});
|
|
10
|
-
this.inflightLIDLookups = new Map();
|
|
11
|
-
this.inflightPNLookups = new Map();
|
|
12
|
-
this.keys = keys;
|
|
13
|
-
this.pnToLIDFunc = pnToLIDFunc;
|
|
14
|
-
this.logger = logger;
|
|
15
|
-
}
|
|
16
|
-
async storeLIDPNMappings(pairs) {
|
|
17
|
-
if (pairs.length === 0)
|
|
18
|
-
return;
|
|
19
|
-
const validatedPairs = [];
|
|
20
|
-
for (const { lid, pn } of pairs) {
|
|
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 });
|
|
30
|
-
}
|
|
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);
|
|
54
|
-
}
|
|
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);
|
|
81
|
-
}
|
|
82
|
-
}
|
|
83
|
-
async getLIDForPN(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;
|
|
95
|
-
}
|
|
96
|
-
const promise = this._getLIDsForPNsImpl(pns);
|
|
97
|
-
this.inflightLIDLookups.set(cacheKey, promise);
|
|
98
|
-
try {
|
|
99
|
-
return await promise;
|
|
100
|
-
}
|
|
101
|
-
finally {
|
|
102
|
-
this.inflightLIDLookups.delete(cacheKey);
|
|
103
|
-
}
|
|
104
|
-
}
|
|
105
|
-
async _getLIDsForPNsImpl(pns) {
|
|
106
|
-
const usyncFetch = {};
|
|
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
|
-
};
|
|
122
|
-
for (const pn of pns) {
|
|
123
|
-
if (!isPnUser(pn) && !isHostedPnUser(pn))
|
|
124
|
-
continue;
|
|
125
|
-
const decoded = jidDecode(pn);
|
|
126
|
-
if (!decoded)
|
|
127
|
-
continue;
|
|
128
|
-
const pnUser = decoded.user;
|
|
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)`);
|
|
154
|
-
continue;
|
|
155
|
-
}
|
|
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
|
-
}
|
|
171
|
-
}
|
|
172
|
-
}
|
|
173
|
-
if (Object.keys(usyncFetch).length > 0) {
|
|
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 };
|
|
190
|
-
}
|
|
191
|
-
}
|
|
192
|
-
}
|
|
193
|
-
else {
|
|
194
|
-
this.logger.warn('USync fetch yielded no results for pending PNs');
|
|
195
|
-
}
|
|
196
|
-
}
|
|
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;
|
|
201
|
-
}
|
|
202
|
-
async getPNsForLIDs(lids) {
|
|
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
|
-
};
|
|
234
|
-
for (const lid of lids) {
|
|
235
|
-
if (!isLidUser(lid))
|
|
236
|
-
continue;
|
|
237
|
-
const decoded = jidDecode(lid);
|
|
238
|
-
if (!decoded)
|
|
239
|
-
continue;
|
|
240
|
-
const lidUser = decoded.user;
|
|
241
|
-
const cached = this.mappingCache.get(`lid:${lidUser}`);
|
|
242
|
-
if (cached && typeof cached === 'string') {
|
|
243
|
-
addResolvedPair(lid, decoded, cached);
|
|
244
|
-
continue;
|
|
245
|
-
}
|
|
246
|
-
pending.push({ lid, lidUser, decoded });
|
|
247
|
-
}
|
|
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`];
|
|
255
|
-
if (pnUser && typeof pnUser === 'string') {
|
|
256
|
-
this.mappingCache.set(`lid:${lidUser}`, pnUser);
|
|
257
|
-
this.mappingCache.set(`pn:${pnUser}`, lidUser);
|
|
258
|
-
}
|
|
259
|
-
}
|
|
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
|
-
}
|
|
267
|
-
}
|
|
268
|
-
return Object.values(successfulPairs).length ? Object.values(successfulPairs) : null;
|
|
269
|
-
}
|
|
270
|
-
/**
|
|
271
|
-
* Close the cache and release resources
|
|
272
|
-
*/
|
|
273
|
-
close() {
|
|
274
|
-
this.mappingCache.clear();
|
|
275
|
-
}
|
|
276
|
-
}
|
|
277
|
-
//# sourceMappingURL=lid-mapping.js.map
|
|
@@ -1,11 +0,0 @@
|
|
|
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
|
-
}
|
|
11
|
-
//# sourceMappingURL=types.js.map
|
|
@@ -1,54 +0,0 @@
|
|
|
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
|
-
}
|
|
54
|
-
//# sourceMappingURL=websocket.js.map
|
package/lib/Socket/mex.d.ts
DELETED
|
@@ -1,3 +0,0 @@
|
|
|
1
|
-
import type { BinaryNode } from '../WABinary/index.js';
|
|
2
|
-
export declare const executeWMexQuery: <T>(variables: Record<string, unknown>, queryId: string, dataPath: string, query: (node: BinaryNode) => Promise<BinaryNode>, generateMessageTag: () => string) => Promise<T>;
|
|
3
|
-
//# sourceMappingURL=mex.d.ts.map
|
package/lib/Socket/mex.js
DELETED
|
@@ -1,42 +0,0 @@
|
|
|
1
|
-
import { Boom } from '@hapi/boom';
|
|
2
|
-
import { getBinaryNodeChild, S_WHATSAPP_NET } from '../WABinary/index.js';
|
|
3
|
-
const wMexQuery = (variables, queryId, query, generateMessageTag) => {
|
|
4
|
-
return query({
|
|
5
|
-
tag: 'iq',
|
|
6
|
-
attrs: {
|
|
7
|
-
id: generateMessageTag(),
|
|
8
|
-
type: 'get',
|
|
9
|
-
to: S_WHATSAPP_NET,
|
|
10
|
-
xmlns: 'w:mex'
|
|
11
|
-
},
|
|
12
|
-
content: [
|
|
13
|
-
{
|
|
14
|
-
tag: 'query',
|
|
15
|
-
attrs: { query_id: queryId },
|
|
16
|
-
content: Buffer.from(JSON.stringify({ variables }), 'utf-8')
|
|
17
|
-
}
|
|
18
|
-
]
|
|
19
|
-
});
|
|
20
|
-
};
|
|
21
|
-
export const executeWMexQuery = async (variables, queryId, dataPath, query, generateMessageTag) => {
|
|
22
|
-
const result = await wMexQuery(variables, queryId, query, generateMessageTag);
|
|
23
|
-
const child = getBinaryNodeChild(result, 'result');
|
|
24
|
-
if (child?.content) {
|
|
25
|
-
const data = JSON.parse(child.content.toString());
|
|
26
|
-
if (data.errors && data.errors.length > 0) {
|
|
27
|
-
const errorMessages = data.errors.map((err) => err.message || 'Unknown error').join(', ');
|
|
28
|
-
const firstError = data.errors[0];
|
|
29
|
-
const errorCode = firstError.extensions?.error_code || 400;
|
|
30
|
-
throw new Boom(`GraphQL server error: ${errorMessages}`, { statusCode: errorCode, data: firstError });
|
|
31
|
-
}
|
|
32
|
-
const response = dataPath ? data?.data?.[dataPath] : data?.data;
|
|
33
|
-
if (typeof response !== 'undefined') {
|
|
34
|
-
return response;
|
|
35
|
-
}
|
|
36
|
-
}
|
|
37
|
-
const action = (dataPath || '').startsWith('xwa2_')
|
|
38
|
-
? dataPath.substring(5).replace(/_/g, ' ')
|
|
39
|
-
: dataPath?.replace(/_/g, ' ');
|
|
40
|
-
throw new Boom(`Failed to ${action}, unexpected response structure.`, { statusCode: 400, data: result });
|
|
41
|
-
};
|
|
42
|
-
//# sourceMappingURL=mex.js.map
|
package/lib/Store/keyed-db.d.ts
DELETED
|
@@ -1,22 +0,0 @@
|
|
|
1
|
-
declare class KeyedDB<T> {
|
|
2
|
-
private _compare: (a: string, b: string) => number;
|
|
3
|
-
private _idGetter: (item: T) => string;
|
|
4
|
-
private _array: T[];
|
|
5
|
-
private _dict: { [id: string]: T };
|
|
6
|
-
constructor(compareFn: (a: string, b: string) => number, idGetter: (item: T) => string);
|
|
7
|
-
get length(): number;
|
|
8
|
-
get(id: string): T | undefined;
|
|
9
|
-
insert(entry: T, mode?: 'insert'): boolean;
|
|
10
|
-
insertIfAbsent(...entries: T[]): T[];
|
|
11
|
-
upsert(...entries: T[]): T[];
|
|
12
|
-
update(id: string, updater: (item: T) => void): boolean;
|
|
13
|
-
updateAssign(id: string, update: Partial<T>): boolean;
|
|
14
|
-
deleteById(id: string): boolean;
|
|
15
|
-
clear(): void;
|
|
16
|
-
all(): T[];
|
|
17
|
-
filter(predicate: (item: T) => boolean): void;
|
|
18
|
-
count(): number;
|
|
19
|
-
toJSON(): T[];
|
|
20
|
-
fromJSON(array: T[]): void;
|
|
21
|
-
}
|
|
22
|
-
export default KeyedDB;
|
package/lib/Store/keyed-db.js
DELETED
|
@@ -1,108 +0,0 @@
|
|
|
1
|
-
export default class KeyedDB {
|
|
2
|
-
constructor(compareFn, idGetter) {
|
|
3
|
-
if (typeof compareFn !== "function" || typeof idGetter !== "function") {
|
|
4
|
-
throw new Error("KeyedDB requires compare and idGetter functions");
|
|
5
|
-
}
|
|
6
|
-
this._compare = compareFn;
|
|
7
|
-
this._idGetter = idGetter;
|
|
8
|
-
this._array = [];
|
|
9
|
-
this._dict = {};
|
|
10
|
-
}
|
|
11
|
-
get length() {
|
|
12
|
-
return this._array.length;
|
|
13
|
-
}
|
|
14
|
-
get(id) {
|
|
15
|
-
return this._dict[id];
|
|
16
|
-
}
|
|
17
|
-
insert(entry, mode = "insert") {
|
|
18
|
-
const id = this._idGetter(entry);
|
|
19
|
-
const existing = this._dict[id];
|
|
20
|
-
if (existing && mode === "insert") {
|
|
21
|
-
return false;
|
|
22
|
-
}
|
|
23
|
-
this._dict[id] = entry;
|
|
24
|
-
let inserted = false;
|
|
25
|
-
for (let i = 0; i < this._array.length; i++) {
|
|
26
|
-
const cmp = this._compare(this._idGetter(this._array[i]), id);
|
|
27
|
-
if (cmp < 0) {
|
|
28
|
-
this._array.splice(i, 0, entry);
|
|
29
|
-
inserted = true;
|
|
30
|
-
break;
|
|
31
|
-
}
|
|
32
|
-
}
|
|
33
|
-
if (!inserted) this._array.push(entry);
|
|
34
|
-
return true;
|
|
35
|
-
}
|
|
36
|
-
insertIfAbsent(...entries) {
|
|
37
|
-
const added = [];
|
|
38
|
-
for (const entry of entries) {
|
|
39
|
-
if (!this._dict[this._idGetter(entry)]) {
|
|
40
|
-
this.insert(entry);
|
|
41
|
-
added.push(entry);
|
|
42
|
-
}
|
|
43
|
-
}
|
|
44
|
-
return added;
|
|
45
|
-
}
|
|
46
|
-
upsert(...entries) {
|
|
47
|
-
const added = [];
|
|
48
|
-
for (const entry of entries) {
|
|
49
|
-
const id = this._idGetter(entry);
|
|
50
|
-
if (this._dict[id]) {
|
|
51
|
-
const idx = this._array.findIndex(e => this._idGetter(e) === id);
|
|
52
|
-
if (idx >= 0) this._array[idx] = entry;
|
|
53
|
-
this._dict[id] = entry;
|
|
54
|
-
} else {
|
|
55
|
-
this.insert(entry);
|
|
56
|
-
added.push(entry);
|
|
57
|
-
}
|
|
58
|
-
}
|
|
59
|
-
return added;
|
|
60
|
-
}
|
|
61
|
-
update(id, updater) {
|
|
62
|
-
const item = this._dict[id];
|
|
63
|
-
if (!item) return false;
|
|
64
|
-
updater(item);
|
|
65
|
-
const idx = this._array.findIndex(e => this._idGetter(e) === id);
|
|
66
|
-
if (idx >= 0) this._array[idx] = item;
|
|
67
|
-
return true;
|
|
68
|
-
}
|
|
69
|
-
updateAssign(id, update) {
|
|
70
|
-
const item = this._dict[id];
|
|
71
|
-
if (!item) return false;
|
|
72
|
-
Object.assign(item, update);
|
|
73
|
-
const idx = this._array.findIndex(e => this._idGetter(e) === id);
|
|
74
|
-
if (idx >= 0) this._array[idx] = item;
|
|
75
|
-
return true;
|
|
76
|
-
}
|
|
77
|
-
deleteById(id) {
|
|
78
|
-
if (!this._dict[id]) return false;
|
|
79
|
-
delete this._dict[id];
|
|
80
|
-
const idx = this._array.findIndex(e => this._idGetter(e) === id);
|
|
81
|
-
if (idx >= 0) this._array.splice(idx, 1);
|
|
82
|
-
return true;
|
|
83
|
-
}
|
|
84
|
-
clear() {
|
|
85
|
-
this._array = [];
|
|
86
|
-
this._dict = {};
|
|
87
|
-
}
|
|
88
|
-
all() {
|
|
89
|
-
return [...this._array];
|
|
90
|
-
}
|
|
91
|
-
filter(predicate) {
|
|
92
|
-
this._array = this._array.filter(predicate);
|
|
93
|
-
this._dict = {};
|
|
94
|
-
for (const entry of this._array) {
|
|
95
|
-
this._dict[this._idGetter(entry)] = entry;
|
|
96
|
-
}
|
|
97
|
-
}
|
|
98
|
-
count() {
|
|
99
|
-
return this._array.length;
|
|
100
|
-
}
|
|
101
|
-
toJSON() {
|
|
102
|
-
return this._array;
|
|
103
|
-
}
|
|
104
|
-
fromJSON(array) {
|
|
105
|
-
this.clear();
|
|
106
|
-
for (const entry of array) this.insert(entry);
|
|
107
|
-
}
|
|
108
|
-
}
|
package/lib/Types/Bussines.d.ts
DELETED
|
@@ -1,25 +0,0 @@
|
|
|
1
|
-
import type { proto } from '../../WAProto';
|
|
2
|
-
export type DayOfWeekBussines = 'sun' | 'mon' | 'tue' | 'wed' | 'thu' | 'fri' | 'sat';
|
|
3
|
-
export type HoursDay = {
|
|
4
|
-
day: DayOfWeekBussines;
|
|
5
|
-
mode: 'specific_hours';
|
|
6
|
-
openTimeInMinutes: string;
|
|
7
|
-
closeTimeInMinutes: string;
|
|
8
|
-
} | {
|
|
9
|
-
day: DayOfWeekBussines;
|
|
10
|
-
mode: 'open_24h' | 'appointment_only';
|
|
11
|
-
};
|
|
12
|
-
export type UpdateBussinesProfileProps = {
|
|
13
|
-
address?: string;
|
|
14
|
-
websites?: string[];
|
|
15
|
-
email?: string;
|
|
16
|
-
description?: string;
|
|
17
|
-
hours?: {
|
|
18
|
-
timezone: string;
|
|
19
|
-
days: HoursDay[];
|
|
20
|
-
};
|
|
21
|
-
};
|
|
22
|
-
export type QuickReplyAction = proto.SyncActionValue.IQuickReplyAction & {
|
|
23
|
-
timestamp?: string;
|
|
24
|
-
};
|
|
25
|
-
//# sourceMappingURL=Bussines.d.ts.map
|
package/lib/Types/Bussines.js
DELETED