@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
package/lib/Utils/auth-utils.js
CHANGED
|
@@ -1,290 +1,189 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
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.initAuthCreds = exports.addTransactionCapability = exports.makeCacheableSignalKeyStore = void 0;
|
|
7
|
+
const crypto_1 = require("crypto");
|
|
8
|
+
const node_cache_1 = __importDefault(require("node-cache"));
|
|
9
|
+
const uuid_1 = require("uuid");
|
|
10
|
+
const Defaults_1 = require("../Defaults");
|
|
11
|
+
const crypto_2 = require("./crypto");
|
|
12
|
+
const generics_1 = require("./generics");
|
|
11
13
|
/**
|
|
12
14
|
* Adds caching capability to a SignalKeyStore
|
|
13
15
|
* @param store the store to add caching to
|
|
14
16
|
* @param logger to log trace events
|
|
15
17
|
* @param _cache cache store to use
|
|
16
18
|
*/
|
|
17
|
-
|
|
18
|
-
const cache = _cache ||
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
});
|
|
24
|
-
// Mutex for protecting cache operations
|
|
25
|
-
const cacheMutex = new Mutex();
|
|
19
|
+
function makeCacheableSignalKeyStore(store, logger, _cache) {
|
|
20
|
+
const cache = _cache || new node_cache_1.default({
|
|
21
|
+
stdTTL: Defaults_1.DEFAULT_CACHE_TTLS.SIGNAL_STORE,
|
|
22
|
+
useClones: false,
|
|
23
|
+
deleteOnExpire: true,
|
|
24
|
+
});
|
|
26
25
|
function getUniqueId(type, id) {
|
|
27
26
|
return `${type}.${id}`;
|
|
28
27
|
}
|
|
29
28
|
return {
|
|
30
29
|
async get(type, ids) {
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
data[id] = item;
|
|
38
|
-
}
|
|
39
|
-
else {
|
|
40
|
-
idsToFetch.push(id);
|
|
41
|
-
}
|
|
30
|
+
const data = {};
|
|
31
|
+
const idsToFetch = [];
|
|
32
|
+
for (const id of ids) {
|
|
33
|
+
const item = cache.get(getUniqueId(type, id));
|
|
34
|
+
if (typeof item !== 'undefined') {
|
|
35
|
+
data[id] = item;
|
|
42
36
|
}
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
37
|
+
else {
|
|
38
|
+
idsToFetch.push(id);
|
|
39
|
+
}
|
|
40
|
+
}
|
|
41
|
+
if (idsToFetch.length) {
|
|
42
|
+
logger.trace({ items: idsToFetch.length }, 'loading from store');
|
|
43
|
+
const fetched = await store.get(type, idsToFetch);
|
|
44
|
+
for (const id of idsToFetch) {
|
|
45
|
+
const item = fetched[id];
|
|
46
|
+
if (item) {
|
|
47
|
+
data[id] = item;
|
|
48
|
+
cache.set(getUniqueId(type, id), item);
|
|
53
49
|
}
|
|
54
50
|
}
|
|
55
|
-
|
|
56
|
-
|
|
51
|
+
}
|
|
52
|
+
return data;
|
|
57
53
|
},
|
|
58
54
|
async set(data) {
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
for (const
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
keys += 1;
|
|
65
|
-
}
|
|
55
|
+
let keys = 0;
|
|
56
|
+
for (const type in data) {
|
|
57
|
+
for (const id in data[type]) {
|
|
58
|
+
cache.set(getUniqueId(type, id), data[type][id]);
|
|
59
|
+
keys += 1;
|
|
66
60
|
}
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
61
|
+
}
|
|
62
|
+
logger.trace({ keys }, 'updated cache');
|
|
63
|
+
await store.set(data);
|
|
70
64
|
},
|
|
71
65
|
async clear() {
|
|
72
|
-
|
|
73
|
-
|
|
66
|
+
var _a;
|
|
67
|
+
cache.flushAll();
|
|
68
|
+
await ((_a = store.clear) === null || _a === void 0 ? void 0 : _a.call(store));
|
|
74
69
|
}
|
|
75
70
|
};
|
|
76
71
|
}
|
|
72
|
+
exports.makeCacheableSignalKeyStore = makeCacheableSignalKeyStore;
|
|
77
73
|
/**
|
|
78
|
-
* Adds DB
|
|
79
|
-
*
|
|
74
|
+
* Adds DB like transaction capability (https://en.wikipedia.org/wiki/Database_transaction) to the SignalKeyStore,
|
|
75
|
+
* this allows batch read & write operations & improves the performance of the lib
|
|
80
76
|
* @param state the key store to apply this capability to
|
|
81
77
|
* @param logger logger to log events
|
|
82
78
|
* @returns SignalKeyStore with transaction capability
|
|
83
79
|
*/
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
//
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
// Pre-key manager for specialized operations
|
|
92
|
-
const preKeyManager = new PreKeyManager(state, logger);
|
|
93
|
-
/**
|
|
94
|
-
* Get or create a queue for a specific key type
|
|
95
|
-
*/
|
|
96
|
-
function getQueue(key) {
|
|
97
|
-
if (!keyQueues.has(key)) {
|
|
98
|
-
keyQueues.set(key, new PQueue({ concurrency: 1 }));
|
|
99
|
-
}
|
|
100
|
-
return keyQueues.get(key);
|
|
101
|
-
}
|
|
102
|
-
/**
|
|
103
|
-
* Get or create a transaction mutex
|
|
104
|
-
*/
|
|
105
|
-
function getTxMutex(key) {
|
|
106
|
-
if (!txMutexes.has(key)) {
|
|
107
|
-
txMutexes.set(key, new Mutex());
|
|
108
|
-
txMutexRefCounts.set(key, 0);
|
|
109
|
-
}
|
|
110
|
-
return txMutexes.get(key);
|
|
111
|
-
}
|
|
112
|
-
/**
|
|
113
|
-
* Acquire a reference to a transaction mutex
|
|
114
|
-
*/
|
|
115
|
-
function acquireTxMutexRef(key) {
|
|
116
|
-
const count = txMutexRefCounts.get(key) ?? 0;
|
|
117
|
-
txMutexRefCounts.set(key, count + 1);
|
|
118
|
-
}
|
|
119
|
-
/**
|
|
120
|
-
* Release a reference to a transaction mutex and cleanup if no longer needed
|
|
121
|
-
*/
|
|
122
|
-
function releaseTxMutexRef(key) {
|
|
123
|
-
const count = (txMutexRefCounts.get(key) ?? 1) - 1;
|
|
124
|
-
txMutexRefCounts.set(key, count);
|
|
125
|
-
// Cleanup if no more references and mutex is not locked
|
|
126
|
-
if (count <= 0) {
|
|
127
|
-
const mutex = txMutexes.get(key);
|
|
128
|
-
if (mutex && !mutex.isLocked()) {
|
|
129
|
-
txMutexes.delete(key);
|
|
130
|
-
txMutexRefCounts.delete(key);
|
|
131
|
-
}
|
|
132
|
-
}
|
|
133
|
-
}
|
|
134
|
-
/**
|
|
135
|
-
* Check if currently in a transaction
|
|
136
|
-
*/
|
|
137
|
-
function isInTransaction() {
|
|
138
|
-
return !!txStorage.getStore();
|
|
139
|
-
}
|
|
140
|
-
/**
|
|
141
|
-
* Commit transaction with retries
|
|
142
|
-
*/
|
|
143
|
-
async function commitWithRetry(mutations) {
|
|
144
|
-
if (Object.keys(mutations).length === 0) {
|
|
145
|
-
logger.trace('no mutations in transaction');
|
|
146
|
-
return;
|
|
147
|
-
}
|
|
148
|
-
logger.trace('committing transaction');
|
|
149
|
-
for (let attempt = 0; attempt < maxCommitRetries; attempt++) {
|
|
150
|
-
try {
|
|
151
|
-
await state.set(mutations);
|
|
152
|
-
logger.trace({ mutationCount: Object.keys(mutations).length }, 'committed transaction');
|
|
153
|
-
return;
|
|
154
|
-
}
|
|
155
|
-
catch (error) {
|
|
156
|
-
const retriesLeft = maxCommitRetries - attempt - 1;
|
|
157
|
-
logger.warn(`failed to commit mutations, retries left=${retriesLeft}`);
|
|
158
|
-
if (retriesLeft === 0) {
|
|
159
|
-
throw error;
|
|
160
|
-
}
|
|
161
|
-
await delay(delayBetweenTriesMs);
|
|
162
|
-
}
|
|
163
|
-
}
|
|
164
|
-
}
|
|
80
|
+
const addTransactionCapability = (state, logger, { maxCommitRetries, delayBetweenTriesMs }) => {
|
|
81
|
+
// number of queries made to the DB during the transaction
|
|
82
|
+
// only there for logging purposes
|
|
83
|
+
let dbQueriesInTransaction = 0;
|
|
84
|
+
let transactionCache = {};
|
|
85
|
+
let mutations = {};
|
|
86
|
+
let transactionsInProgress = 0;
|
|
165
87
|
return {
|
|
166
88
|
get: async (type, ids) => {
|
|
167
|
-
|
|
168
|
-
|
|
169
|
-
|
|
170
|
-
|
|
171
|
-
|
|
172
|
-
|
|
173
|
-
|
|
174
|
-
|
|
175
|
-
|
|
176
|
-
|
|
177
|
-
|
|
178
|
-
const fetched = await getTxMutex(type).runExclusive(() => state.get(type, missing));
|
|
179
|
-
// Update cache
|
|
180
|
-
ctx.cache[type] = ctx.cache[type] || {};
|
|
181
|
-
Object.assign(ctx.cache[type], fetched);
|
|
182
|
-
}
|
|
183
|
-
// Return requested ids from cache
|
|
184
|
-
const result = {};
|
|
185
|
-
for (const id of ids) {
|
|
186
|
-
const value = ctx.cache[type]?.[id];
|
|
187
|
-
if (value !== undefined && value !== null) {
|
|
188
|
-
result[id] = value;
|
|
89
|
+
if (isInTransaction()) {
|
|
90
|
+
const dict = transactionCache[type];
|
|
91
|
+
const idsRequiringFetch = dict
|
|
92
|
+
? ids.filter(item => typeof dict[item] === 'undefined')
|
|
93
|
+
: ids;
|
|
94
|
+
// only fetch if there are any items to fetch
|
|
95
|
+
if (idsRequiringFetch.length) {
|
|
96
|
+
dbQueriesInTransaction += 1;
|
|
97
|
+
const result = await state.get(type, idsRequiringFetch);
|
|
98
|
+
transactionCache[type] || (transactionCache[type] = {});
|
|
99
|
+
Object.assign(transactionCache[type], result);
|
|
189
100
|
}
|
|
101
|
+
return ids.reduce((dict, id) => {
|
|
102
|
+
var _a;
|
|
103
|
+
const value = (_a = transactionCache[type]) === null || _a === void 0 ? void 0 : _a[id];
|
|
104
|
+
if (value) {
|
|
105
|
+
dict[id] = value;
|
|
106
|
+
}
|
|
107
|
+
return dict;
|
|
108
|
+
}, {});
|
|
109
|
+
}
|
|
110
|
+
else {
|
|
111
|
+
return state.get(type, ids);
|
|
190
112
|
}
|
|
191
|
-
return result;
|
|
192
113
|
},
|
|
193
|
-
set:
|
|
194
|
-
|
|
195
|
-
|
|
196
|
-
|
|
197
|
-
|
|
198
|
-
|
|
199
|
-
|
|
200
|
-
|
|
201
|
-
if (type === 'pre-key') {
|
|
202
|
-
await preKeyManager.validateDeletions(data, type);
|
|
203
|
-
}
|
|
114
|
+
set: data => {
|
|
115
|
+
if (isInTransaction()) {
|
|
116
|
+
logger.trace({ types: Object.keys(data) }, 'caching in transaction');
|
|
117
|
+
for (const key in data) {
|
|
118
|
+
transactionCache[key] = transactionCache[key] || {};
|
|
119
|
+
Object.assign(transactionCache[key], data[key]);
|
|
120
|
+
mutations[key] = mutations[key] || {};
|
|
121
|
+
Object.assign(mutations[key], data[key]);
|
|
204
122
|
}
|
|
205
|
-
// Write all data in parallel
|
|
206
|
-
await Promise.all(types.map(type => getQueue(type).add(async () => {
|
|
207
|
-
const typeData = { [type]: data[type] };
|
|
208
|
-
await state.set(typeData);
|
|
209
|
-
})));
|
|
210
|
-
return;
|
|
211
123
|
}
|
|
212
|
-
|
|
213
|
-
|
|
214
|
-
for (const key_ in data) {
|
|
215
|
-
const key = key_;
|
|
216
|
-
// Ensure structures exist
|
|
217
|
-
ctx.cache[key] = ctx.cache[key] || {};
|
|
218
|
-
ctx.mutations[key] = ctx.mutations[key] || {};
|
|
219
|
-
// Special handling for pre-keys
|
|
220
|
-
if (key === 'pre-key') {
|
|
221
|
-
await preKeyManager.processOperations(data, key, ctx.cache, ctx.mutations, true);
|
|
222
|
-
}
|
|
223
|
-
else {
|
|
224
|
-
// Normal key types
|
|
225
|
-
Object.assign(ctx.cache[key], data[key]);
|
|
226
|
-
Object.assign(ctx.mutations[key], data[key]);
|
|
227
|
-
}
|
|
124
|
+
else {
|
|
125
|
+
return state.set(data);
|
|
228
126
|
}
|
|
229
127
|
},
|
|
230
128
|
isInTransaction,
|
|
231
|
-
|
|
232
|
-
|
|
233
|
-
|
|
234
|
-
if (
|
|
235
|
-
logger.trace('
|
|
236
|
-
return work();
|
|
129
|
+
async transaction(work) {
|
|
130
|
+
let result;
|
|
131
|
+
transactionsInProgress += 1;
|
|
132
|
+
if (transactionsInProgress === 1) {
|
|
133
|
+
logger.trace('entering transaction');
|
|
237
134
|
}
|
|
238
|
-
// New transaction - acquire mutex and create context
|
|
239
|
-
const mutex = getTxMutex(key);
|
|
240
|
-
acquireTxMutexRef(key);
|
|
241
135
|
try {
|
|
242
|
-
|
|
243
|
-
|
|
244
|
-
|
|
245
|
-
|
|
246
|
-
|
|
247
|
-
|
|
248
|
-
|
|
249
|
-
|
|
250
|
-
|
|
251
|
-
|
|
252
|
-
|
|
253
|
-
|
|
254
|
-
|
|
136
|
+
result = await work();
|
|
137
|
+
// commit if this is the outermost transaction
|
|
138
|
+
if (transactionsInProgress === 1) {
|
|
139
|
+
if (Object.keys(mutations).length) {
|
|
140
|
+
logger.trace('committing transaction');
|
|
141
|
+
// retry mechanism to ensure we've some recovery
|
|
142
|
+
// in case a transaction fails in the first attempt
|
|
143
|
+
let tries = maxCommitRetries;
|
|
144
|
+
while (tries) {
|
|
145
|
+
tries -= 1;
|
|
146
|
+
try {
|
|
147
|
+
await state.set(mutations);
|
|
148
|
+
logger.trace({ dbQueriesInTransaction }, 'committed transaction');
|
|
149
|
+
break;
|
|
150
|
+
}
|
|
151
|
+
catch (error) {
|
|
152
|
+
logger.warn(`failed to commit ${Object.keys(mutations).length} mutations, tries left=${tries}`);
|
|
153
|
+
await (0, generics_1.delay)(delayBetweenTriesMs);
|
|
154
|
+
}
|
|
155
|
+
}
|
|
255
156
|
}
|
|
256
|
-
|
|
257
|
-
logger.
|
|
258
|
-
throw error;
|
|
157
|
+
else {
|
|
158
|
+
logger.trace('no mutations in transaction');
|
|
259
159
|
}
|
|
260
|
-
}
|
|
160
|
+
}
|
|
261
161
|
}
|
|
262
162
|
finally {
|
|
263
|
-
|
|
163
|
+
transactionsInProgress -= 1;
|
|
164
|
+
if (transactionsInProgress === 0) {
|
|
165
|
+
transactionCache = {};
|
|
166
|
+
mutations = {};
|
|
167
|
+
dbQueriesInTransaction = 0;
|
|
168
|
+
}
|
|
264
169
|
}
|
|
170
|
+
return result;
|
|
265
171
|
}
|
|
266
172
|
};
|
|
267
|
-
|
|
268
|
-
|
|
269
|
-
* Returns the authenticated user's JID, or throws a Boom-401 if creds are not yet authenticated.
|
|
270
|
-
* Use this anywhere we'd otherwise reach for `creds.me!.id` to fail fast with a descriptive error.
|
|
271
|
-
*/
|
|
272
|
-
export const assertMeId = (creds) => {
|
|
273
|
-
const id = creds.me?.id;
|
|
274
|
-
if (!id) {
|
|
275
|
-
throw new Boom('Cannot proceed: socket is not authenticated yet (creds.me.id is missing)', { statusCode: 401 });
|
|
173
|
+
function isInTransaction() {
|
|
174
|
+
return transactionsInProgress > 0;
|
|
276
175
|
}
|
|
277
|
-
return id;
|
|
278
176
|
};
|
|
279
|
-
|
|
280
|
-
|
|
177
|
+
exports.addTransactionCapability = addTransactionCapability;
|
|
178
|
+
const initAuthCreds = () => {
|
|
179
|
+
const identityKey = crypto_2.Curve.generateKeyPair();
|
|
281
180
|
return {
|
|
282
|
-
noiseKey: Curve.generateKeyPair(),
|
|
283
|
-
pairingEphemeralKeyPair: Curve.generateKeyPair(),
|
|
181
|
+
noiseKey: crypto_2.Curve.generateKeyPair(),
|
|
182
|
+
pairingEphemeralKeyPair: crypto_2.Curve.generateKeyPair(),
|
|
284
183
|
signedIdentityKey: identityKey,
|
|
285
|
-
signedPreKey: signedKeyPair(identityKey, 1),
|
|
286
|
-
registrationId: generateRegistrationId(),
|
|
287
|
-
advSecretKey: randomBytes(32).toString('base64'),
|
|
184
|
+
signedPreKey: (0, crypto_2.signedKeyPair)(identityKey, 1),
|
|
185
|
+
registrationId: (0, generics_1.generateRegistrationId)(),
|
|
186
|
+
advSecretKey: (0, crypto_1.randomBytes)(32).toString('base64'),
|
|
288
187
|
processedHistoryMessages: [],
|
|
289
188
|
nextPreKeyId: 1,
|
|
290
189
|
firstUnuploadedPreKeyId: 1,
|
|
@@ -292,11 +191,16 @@ export const initAuthCreds = () => {
|
|
|
292
191
|
accountSettings: {
|
|
293
192
|
unarchiveChats: false
|
|
294
193
|
},
|
|
194
|
+
// mobile creds
|
|
195
|
+
deviceId: Buffer.from((0, uuid_1.v4)().replace(/-/g, ''), 'hex').toString('base64url'),
|
|
196
|
+
phoneId: (0, uuid_1.v4)(),
|
|
197
|
+
identityId: (0, crypto_1.randomBytes)(20),
|
|
295
198
|
registered: false,
|
|
199
|
+
backupToken: (0, crypto_1.randomBytes)(20),
|
|
200
|
+
registration: {},
|
|
296
201
|
pairingCode: undefined,
|
|
297
202
|
lastPropHash: undefined,
|
|
298
203
|
routingInfo: undefined,
|
|
299
|
-
additionalData: undefined
|
|
300
204
|
};
|
|
301
205
|
};
|
|
302
|
-
|
|
206
|
+
exports.initAuthCreds = initAuthCreds;
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import type { BaileysEventEmitter } from '../Types';
|
|
2
|
+
/**
|
|
3
|
+
* Captures events from a baileys event emitter & stores them in a file
|
|
4
|
+
* @param ev The event emitter to read events from
|
|
5
|
+
* @param filename File to save to
|
|
6
|
+
*/
|
|
7
|
+
export declare const captureEventStream: (ev: BaileysEventEmitter, filename: string) => void;
|
|
8
|
+
/**
|
|
9
|
+
* Read event file and emit events from there
|
|
10
|
+
* @param filename filename containing event data
|
|
11
|
+
* @param delayIntervalMs delay between each event emit
|
|
12
|
+
*/
|
|
13
|
+
export declare const readAndEmitEventStream: (filename: string, delayIntervalMs?: number) => {
|
|
14
|
+
ev: BaileysEventEmitter;
|
|
15
|
+
task: Promise<void>;
|
|
16
|
+
};
|
|
@@ -0,0 +1,63 @@
|
|
|
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.readAndEmitEventStream = exports.captureEventStream = void 0;
|
|
7
|
+
const events_1 = __importDefault(require("events"));
|
|
8
|
+
const fs_1 = require("fs");
|
|
9
|
+
const promises_1 = require("fs/promises");
|
|
10
|
+
const readline_1 = require("readline");
|
|
11
|
+
const generics_1 = require("./generics");
|
|
12
|
+
const make_mutex_1 = require("./make-mutex");
|
|
13
|
+
/**
|
|
14
|
+
* Captures events from a baileys event emitter & stores them in a file
|
|
15
|
+
* @param ev The event emitter to read events from
|
|
16
|
+
* @param filename File to save to
|
|
17
|
+
*/
|
|
18
|
+
const captureEventStream = (ev, filename) => {
|
|
19
|
+
const oldEmit = ev.emit;
|
|
20
|
+
// write mutex so data is appended in order
|
|
21
|
+
const writeMutex = (0, make_mutex_1.makeMutex)();
|
|
22
|
+
// monkey patch eventemitter to capture all events
|
|
23
|
+
ev.emit = function (...args) {
|
|
24
|
+
const content = JSON.stringify({ timestamp: Date.now(), event: args[0], data: args[1] }) + '\n';
|
|
25
|
+
const result = oldEmit.apply(ev, args);
|
|
26
|
+
writeMutex.mutex(async () => {
|
|
27
|
+
await (0, promises_1.writeFile)(filename, content, { flag: 'a' });
|
|
28
|
+
});
|
|
29
|
+
return result;
|
|
30
|
+
};
|
|
31
|
+
};
|
|
32
|
+
exports.captureEventStream = captureEventStream;
|
|
33
|
+
/**
|
|
34
|
+
* Read event file and emit events from there
|
|
35
|
+
* @param filename filename containing event data
|
|
36
|
+
* @param delayIntervalMs delay between each event emit
|
|
37
|
+
*/
|
|
38
|
+
const readAndEmitEventStream = (filename, delayIntervalMs = 0) => {
|
|
39
|
+
const ev = new events_1.default();
|
|
40
|
+
const fireEvents = async () => {
|
|
41
|
+
// from: https://stackoverflow.com/questions/6156501/read-a-file-one-line-at-a-time-in-node-js
|
|
42
|
+
const fileStream = (0, fs_1.createReadStream)(filename);
|
|
43
|
+
const rl = (0, readline_1.createInterface)({
|
|
44
|
+
input: fileStream,
|
|
45
|
+
crlfDelay: Infinity
|
|
46
|
+
});
|
|
47
|
+
// Note: we use the crlfDelay option to recognize all instances of CR LF
|
|
48
|
+
// ('\r\n') in input.txt as a single line break.
|
|
49
|
+
for await (const line of rl) {
|
|
50
|
+
if (line) {
|
|
51
|
+
const { event, data } = JSON.parse(line);
|
|
52
|
+
ev.emit(event, data);
|
|
53
|
+
delayIntervalMs && await (0, generics_1.delay)(delayIntervalMs);
|
|
54
|
+
}
|
|
55
|
+
}
|
|
56
|
+
fileStream.close();
|
|
57
|
+
};
|
|
58
|
+
return {
|
|
59
|
+
ev,
|
|
60
|
+
task: fireEvents()
|
|
61
|
+
};
|
|
62
|
+
};
|
|
63
|
+
exports.readAndEmitEventStream = readAndEmitEventStream;
|
package/lib/Utils/business.d.ts
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
import
|
|
2
|
-
import {
|
|
1
|
+
import { CatalogCollection, OrderDetails, Product, ProductCreate, ProductUpdate, WAMediaUpload, WAMediaUploadFunction } from '../Types';
|
|
2
|
+
import { BinaryNode } from '../WABinary';
|
|
3
3
|
export declare const parseCatalogNode: (node: BinaryNode) => {
|
|
4
4
|
products: Product[];
|
|
5
5
|
nextPageCursor: string | undefined;
|
|
@@ -20,4 +20,3 @@ export declare function uploadingNecessaryImagesOfProduct<T extends ProductUpdat
|
|
|
20
20
|
export declare const uploadingNecessaryImages: (images: WAMediaUpload[], waUploadToServer: WAMediaUploadFunction, timeoutMs?: number) => Promise<{
|
|
21
21
|
url: string;
|
|
22
22
|
}[]>;
|
|
23
|
-
//# sourceMappingURL=business.d.ts.map
|