socketon 1.31.2-rc → 1.51.16
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 +313 -159
- package/WAProto/WAProto.proto +5311 -0
- package/WAProto/index.js +65801 -141371
- package/lib/Defaults/index.js +117 -141
- package/lib/KeyDB/BinarySearch.js +20 -0
- package/lib/KeyDB/KeyedDB.js +167 -0
- package/lib/KeyDB/index.js +4 -0
- package/lib/Signal/Group/ciphertext-message.js +12 -14
- package/lib/Signal/Group/group-session-builder.js +10 -42
- package/lib/Signal/Group/group_cipher.js +75 -87
- package/lib/Signal/Group/index.js +13 -57
- package/lib/Signal/Group/keyhelper.js +17 -52
- package/lib/Signal/Group/sender-chain-key.js +27 -33
- package/lib/Signal/Group/sender-key-distribution-message.js +62 -63
- package/lib/Signal/Group/sender-key-message.js +65 -66
- package/lib/Signal/Group/sender-key-name.js +45 -44
- package/lib/Signal/Group/sender-key-record.js +39 -49
- package/lib/Signal/Group/sender-key-state.js +80 -93
- package/lib/Signal/Group/sender-message-key.js +27 -28
- package/lib/Signal/libsignal.js +313 -163
- package/lib/Signal/lid-mapping.js +155 -0
- package/lib/Socket/Client/index.js +4 -19
- package/lib/Socket/Client/types.js +13 -0
- package/lib/Socket/Client/websocket.js +52 -0
- package/lib/Socket/Client/websocket.js.bak +53 -0
- package/lib/Socket/business.js +359 -242
- package/lib/Socket/chats.js +846 -935
- package/lib/Socket/communities.js +413 -0
- package/lib/Socket/groups.js +304 -309
- package/lib/Socket/index.js +15 -10
- package/lib/Socket/messages-recv.js +1107 -1054
- package/lib/Socket/messages-send.js +639 -448
- package/lib/Socket/mex.js +45 -0
- package/lib/Socket/newsletter.js +240 -324
- package/lib/Socket/socket.js +794 -651
- package/lib/Socket/socketon.js +402 -0
- package/lib/Store/index.js +6 -10
- package/lib/Store/make-cache-manager-store.js +73 -81
- package/lib/Store/make-in-memory-store.js +286 -423
- package/lib/Store/make-ordered-dictionary.js +77 -79
- package/lib/Store/object-repository.js +24 -26
- package/lib/Types/Auth.js +3 -2
- package/lib/Types/Bussines.js +3 -0
- package/lib/Types/Call.js +3 -2
- package/lib/Types/Chat.js +9 -4
- package/lib/Types/Contact.js +3 -2
- package/lib/Types/Events.js +3 -2
- package/lib/Types/GroupMetadata.js +3 -2
- package/lib/Types/Label.js +24 -26
- package/lib/Types/LabelAssociation.js +6 -8
- package/lib/Types/Message.js +12 -9
- package/lib/Types/Newsletter.js +33 -38
- package/lib/Types/Newsletter.js.bak +33 -0
- package/lib/Types/Product.js +3 -2
- package/lib/Types/Signal.js +3 -2
- package/lib/Types/Socket.js +4 -2
- package/lib/Types/State.js +11 -2
- package/lib/Types/USync.js +3 -2
- package/lib/Types/index.js +27 -41
- package/lib/Utils/auth-utils.js +211 -198
- package/lib/Utils/baileys-event-stream.js +42 -61
- package/lib/Utils/browser-utils.js +25 -0
- package/lib/Utils/business.js +213 -214
- package/lib/Utils/chat-utils.js +710 -687
- package/lib/Utils/crypto.js +112 -133
- package/lib/Utils/decode-wa-message.js +252 -183
- package/lib/Utils/decode-wa-message.js.bak +267 -0
- package/lib/Utils/event-buffer.js +510 -496
- package/lib/Utils/generics.js +319 -392
- package/lib/Utils/history.js +83 -92
- package/lib/Utils/index.js +21 -33
- package/lib/Utils/link-preview.js +71 -83
- package/lib/Utils/logger.js +5 -7
- package/lib/Utils/lt-hash.js +40 -46
- package/lib/Utils/make-mutex.js +34 -41
- package/lib/Utils/message-retry-manager.js +113 -0
- package/lib/Utils/messages-media.js +550 -768
- package/lib/Utils/messages.js +354 -263
- package/lib/Utils/noise-handler.js +138 -149
- package/lib/Utils/pre-key-manager.js +85 -0
- package/lib/Utils/process-message.js +323 -303
- package/lib/Utils/signal.js +149 -141
- package/lib/Utils/use-multi-file-auth-state.js +95 -103
- package/lib/Utils/validate-connection.js +183 -214
- package/lib/WABinary/constants.js +1298 -35
- package/lib/WABinary/decode.js +237 -249
- package/lib/WABinary/encode.js +213 -260
- package/lib/WABinary/generic-utils.js +56 -65
- package/lib/WABinary/index.js +7 -21
- package/lib/WABinary/jid-utils.js +89 -58
- package/lib/WABinary/types.js +3 -2
- package/lib/WAM/BinaryInfo.js +10 -12
- package/lib/WAM/constants.js +22851 -15348
- package/lib/WAM/encode.js +135 -136
- package/lib/WAM/index.js +5 -19
- package/lib/WAUSync/Protocols/USyncContactProtocol.js +28 -30
- package/lib/WAUSync/Protocols/USyncDeviceProtocol.js +49 -53
- package/lib/WAUSync/Protocols/USyncDisappearingModeProtocol.js +27 -28
- package/lib/WAUSync/Protocols/USyncStatusProtocol.js +36 -39
- package/lib/WAUSync/Protocols/UsyncBotProfileProtocol.js +50 -50
- package/lib/WAUSync/Protocols/UsyncLIDProtocol.js +26 -20
- package/lib/WAUSync/Protocols/index.js +6 -20
- package/lib/WAUSync/USyncQuery.js +86 -85
- package/lib/WAUSync/USyncUser.js +23 -25
- package/lib/WAUSync/index.js +5 -19
- package/lib/index.js +27 -35
- package/package.json +85 -95
- package/engine-requirements.js +0 -10
- package/lib/Defaults/baileys-version.json +0 -3
- package/lib/Defaults/index.d.ts +0 -53
- package/lib/Defaults/phonenumber-mcc.json +0 -223
- package/lib/Signal/Group/ciphertext-message.d.ts +0 -9
- package/lib/Signal/Group/group-session-builder.d.ts +0 -14
- package/lib/Signal/Group/group_cipher.d.ts +0 -17
- package/lib/Signal/Group/index.d.ts +0 -11
- package/lib/Signal/Group/keyhelper.d.ts +0 -10
- package/lib/Signal/Group/queue-job.d.ts +0 -1
- package/lib/Signal/Group/queue-job.js +0 -57
- package/lib/Signal/Group/sender-chain-key.d.ts +0 -13
- package/lib/Signal/Group/sender-key-distribution-message.d.ts +0 -16
- package/lib/Signal/Group/sender-key-message.d.ts +0 -18
- package/lib/Signal/Group/sender-key-name.d.ts +0 -17
- package/lib/Signal/Group/sender-key-record.d.ts +0 -30
- package/lib/Signal/Group/sender-key-state.d.ts +0 -38
- package/lib/Signal/Group/sender-message-key.d.ts +0 -11
- package/lib/Signal/libsignal.d.ts +0 -3
- package/lib/Socket/Client/abstract-socket-client.d.ts +0 -17
- package/lib/Socket/Client/abstract-socket-client.js +0 -13
- package/lib/Socket/Client/index.d.ts +0 -3
- package/lib/Socket/Client/mobile-socket-client.d.ts +0 -13
- package/lib/Socket/Client/mobile-socket-client.js +0 -65
- package/lib/Socket/Client/web-socket-client.d.ts +0 -12
- package/lib/Socket/Client/web-socket-client.js +0 -62
- package/lib/Socket/business.d.ts +0 -171
- package/lib/Socket/chats.d.ts +0 -267
- package/lib/Socket/dugong.d.ts +0 -254
- package/lib/Socket/dugong.js +0 -484
- package/lib/Socket/groups.d.ts +0 -115
- package/lib/Socket/index.d.ts +0 -173
- package/lib/Socket/messages-recv.d.ts +0 -161
- package/lib/Socket/messages-send.d.ts +0 -149
- package/lib/Socket/newsletter.d.ts +0 -134
- package/lib/Socket/registration.d.ts +0 -267
- package/lib/Socket/registration.js +0 -166
- package/lib/Socket/socket.d.ts +0 -43
- package/lib/Socket/usync.d.ts +0 -36
- package/lib/Socket/usync.js +0 -70
- package/lib/Store/index.d.ts +0 -3
- package/lib/Store/make-cache-manager-store.d.ts +0 -13
- package/lib/Store/make-in-memory-store.d.ts +0 -118
- package/lib/Store/make-ordered-dictionary.d.ts +0 -13
- package/lib/Store/object-repository.d.ts +0 -10
- package/lib/Types/Auth.d.ts +0 -110
- package/lib/Types/Call.d.ts +0 -13
- package/lib/Types/Chat.d.ts +0 -102
- package/lib/Types/Contact.d.ts +0 -19
- package/lib/Types/Events.d.ts +0 -157
- package/lib/Types/GroupMetadata.d.ts +0 -55
- package/lib/Types/Label.d.ts +0 -35
- package/lib/Types/LabelAssociation.d.ts +0 -29
- package/lib/Types/Message.d.ts +0 -273
- package/lib/Types/Newsletter.d.ts +0 -103
- package/lib/Types/Product.d.ts +0 -78
- package/lib/Types/Signal.d.ts +0 -57
- package/lib/Types/Socket.d.ts +0 -111
- package/lib/Types/State.d.ts +0 -27
- package/lib/Types/USync.d.ts +0 -25
- package/lib/Types/index.d.ts +0 -57
- package/lib/Utils/auth-utils.d.ts +0 -18
- package/lib/Utils/baileys-event-stream.d.ts +0 -16
- package/lib/Utils/business.d.ts +0 -22
- package/lib/Utils/chat-utils.d.ts +0 -71
- package/lib/Utils/crypto.d.ts +0 -41
- package/lib/Utils/decode-wa-message.d.ts +0 -19
- package/lib/Utils/event-buffer.d.ts +0 -35
- package/lib/Utils/generics.d.ts +0 -92
- package/lib/Utils/generics.js.bak +0 -433
- package/lib/Utils/history.d.ts +0 -15
- package/lib/Utils/index.d.ts +0 -17
- package/lib/Utils/link-preview.d.ts +0 -21
- package/lib/Utils/logger.d.ts +0 -4
- package/lib/Utils/lt-hash.d.ts +0 -12
- package/lib/Utils/make-mutex.d.ts +0 -7
- package/lib/Utils/messages-media.d.ts +0 -116
- package/lib/Utils/messages.d.ts +0 -77
- package/lib/Utils/noise-handler.d.ts +0 -21
- package/lib/Utils/process-message.d.ts +0 -41
- package/lib/Utils/signal.d.ts +0 -32
- package/lib/Utils/use-multi-file-auth-state.d.ts +0 -13
- package/lib/Utils/validate-connection.d.ts +0 -11
- package/lib/Utils/validate-connection.js.bak +0 -237
- package/lib/WABinary/constants.d.ts +0 -30
- package/lib/WABinary/decode.d.ts +0 -7
- package/lib/WABinary/encode.d.ts +0 -3
- package/lib/WABinary/generic-utils.d.ts +0 -17
- package/lib/WABinary/index.d.ts +0 -5
- package/lib/WABinary/jid-utils.d.ts +0 -31
- package/lib/WABinary/types.d.ts +0 -18
- package/lib/WAM/BinaryInfo.d.ts +0 -17
- package/lib/WAM/constants.d.ts +0 -38
- package/lib/WAM/encode.d.ts +0 -3
- package/lib/WAM/index.d.ts +0 -3
- package/lib/WAUSync/Protocols/USyncContactProtocol.d.ts +0 -9
- package/lib/WAUSync/Protocols/USyncDeviceProtocol.d.ts +0 -22
- package/lib/WAUSync/Protocols/USyncDisappearingModeProtocol.d.ts +0 -12
- package/lib/WAUSync/Protocols/USyncStatusProtocol.d.ts +0 -12
- package/lib/WAUSync/Protocols/UsyncBotProfileProtocol.d.ts +0 -25
- package/lib/WAUSync/Protocols/UsyncLIDProtocol.d.ts +0 -8
- package/lib/WAUSync/Protocols/index.d.ts +0 -4
- package/lib/WAUSync/USyncQuery.d.ts +0 -28
- package/lib/WAUSync/USyncUser.d.ts +0 -12
- package/lib/WAUSync/index.d.ts +0 -3
- package/lib/index.d.ts +0 -12
package/lib/Utils/auth-utils.js
CHANGED
|
@@ -1,206 +1,219 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
};
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
*/
|
|
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,
|
|
1
|
+
//=======================================================//
|
|
2
|
+
import { delay, generateRegistrationId } from "./generics.js";
|
|
3
|
+
import { DEFAULT_CACHE_TTLS } from "../Defaults/index.js";
|
|
4
|
+
import { PreKeyManager } from "./pre-key-manager.js";
|
|
5
|
+
import { Curve, signedKeyPair } from "./crypto.js";
|
|
6
|
+
import { AsyncLocalStorage } from "async_hooks";
|
|
7
|
+
import NodeCache from "@cacheable/node-cache";
|
|
8
|
+
import { randomBytes } from "crypto";
|
|
9
|
+
import { Mutex } from "async-mutex";
|
|
10
|
+
import PQueue from "p-queue";
|
|
11
|
+
//=======================================================//
|
|
12
|
+
export function makeCacheableSignalKeyStore(store, logger, _cache) {
|
|
13
|
+
const cache = _cache ||
|
|
14
|
+
new NodeCache({
|
|
15
|
+
stdTTL: DEFAULT_CACHE_TTLS.SIGNAL_STORE,
|
|
16
|
+
useClones: false,
|
|
17
|
+
deleteOnExpire: true
|
|
24
18
|
});
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
}
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
}
|
|
52
|
-
return data;
|
|
53
|
-
},
|
|
54
|
-
async set(data) {
|
|
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;
|
|
60
|
-
}
|
|
19
|
+
const cacheMutex = new Mutex();
|
|
20
|
+
function getUniqueId(type, id) {
|
|
21
|
+
return `${type}.${id}`;
|
|
22
|
+
}
|
|
23
|
+
return {
|
|
24
|
+
async get(type, ids) {
|
|
25
|
+
return cacheMutex.runExclusive(async () => {
|
|
26
|
+
const data = {};
|
|
27
|
+
const idsToFetch = [];
|
|
28
|
+
for (const id of ids) {
|
|
29
|
+
const item = (await cache.get(getUniqueId(type, id)));
|
|
30
|
+
if (typeof item !== "undefined") {
|
|
31
|
+
data[id] = item;
|
|
32
|
+
}
|
|
33
|
+
else {
|
|
34
|
+
idsToFetch.push(id);
|
|
35
|
+
}
|
|
36
|
+
}
|
|
37
|
+
if (idsToFetch.length) {
|
|
38
|
+
logger?.trace({ items: idsToFetch.length }, "loading from store");
|
|
39
|
+
const fetched = await store.get(type, idsToFetch);
|
|
40
|
+
for (const id of idsToFetch) {
|
|
41
|
+
const item = fetched[id];
|
|
42
|
+
if (item) {
|
|
43
|
+
data[id] = item;
|
|
44
|
+
cache.set(getUniqueId(type, id), item);
|
|
61
45
|
}
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
46
|
+
}
|
|
47
|
+
}
|
|
48
|
+
return data;
|
|
49
|
+
});
|
|
50
|
+
},
|
|
51
|
+
async set(data) {
|
|
52
|
+
return cacheMutex.runExclusive(async () => {
|
|
53
|
+
let keys = 0;
|
|
54
|
+
for (const type in data) {
|
|
55
|
+
for (const id in data[type]) {
|
|
56
|
+
await cache.set(getUniqueId(type, id), data[type][id]);
|
|
57
|
+
keys += 1;
|
|
58
|
+
}
|
|
69
59
|
}
|
|
70
|
-
|
|
60
|
+
logger?.trace({ keys }, "updated cache");
|
|
61
|
+
await store.set(data);
|
|
62
|
+
});
|
|
63
|
+
},
|
|
64
|
+
async clear() {
|
|
65
|
+
await cache.flushAll();
|
|
66
|
+
await store.clear?.();
|
|
67
|
+
}
|
|
68
|
+
};
|
|
71
69
|
}
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
}
|
|
128
|
-
|
|
129
|
-
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
|
|
137
|
-
|
|
138
|
-
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
|
|
142
|
-
|
|
143
|
-
|
|
144
|
-
|
|
145
|
-
|
|
146
|
-
|
|
147
|
-
|
|
148
|
-
|
|
149
|
-
|
|
150
|
-
|
|
151
|
-
|
|
152
|
-
|
|
153
|
-
|
|
154
|
-
|
|
155
|
-
|
|
156
|
-
|
|
157
|
-
|
|
158
|
-
|
|
159
|
-
|
|
160
|
-
|
|
161
|
-
|
|
162
|
-
|
|
163
|
-
|
|
164
|
-
|
|
165
|
-
|
|
166
|
-
|
|
167
|
-
|
|
168
|
-
|
|
169
|
-
|
|
170
|
-
|
|
70
|
+
//=======================================================//
|
|
71
|
+
export const addTransactionCapability = (state, logger, { maxCommitRetries, delayBetweenTriesMs }) => {
|
|
72
|
+
const txStorage = new AsyncLocalStorage();
|
|
73
|
+
const keyQueues = new Map();
|
|
74
|
+
const txMutexes = new Map();
|
|
75
|
+
const preKeyManager = new PreKeyManager(state, logger);
|
|
76
|
+
function getQueue(key) {
|
|
77
|
+
if (!keyQueues.has(key)) {
|
|
78
|
+
keyQueues.set(key, new PQueue({ concurrency: 1 }));
|
|
79
|
+
}
|
|
80
|
+
return keyQueues.get(key);
|
|
81
|
+
}
|
|
82
|
+
function getTxMutex(key) {
|
|
83
|
+
if (!txMutexes.has(key)) {
|
|
84
|
+
txMutexes.set(key, new Mutex());
|
|
85
|
+
}
|
|
86
|
+
return txMutexes.get(key);
|
|
87
|
+
}
|
|
88
|
+
function isInTransaction() {
|
|
89
|
+
return !!txStorage.getStore();
|
|
90
|
+
}
|
|
91
|
+
async function commitWithRetry(mutations) {
|
|
92
|
+
if (Object.keys(mutations).length === 0) {
|
|
93
|
+
logger.trace("no mutations in transaction");
|
|
94
|
+
return;
|
|
95
|
+
}
|
|
96
|
+
logger.trace("committing transaction");
|
|
97
|
+
for (let attempt = 0; attempt < maxCommitRetries; attempt++) {
|
|
98
|
+
try {
|
|
99
|
+
await state.set(mutations);
|
|
100
|
+
logger.trace({ mutationCount: Object.keys(mutations).length }, "committed transaction");
|
|
101
|
+
return;
|
|
102
|
+
}
|
|
103
|
+
catch (error) {
|
|
104
|
+
const retriesLeft = maxCommitRetries - attempt - 1;
|
|
105
|
+
logger.warn(`failed to commit mutations, retries left=${retriesLeft}`);
|
|
106
|
+
if (retriesLeft === 0) {
|
|
107
|
+
throw error;
|
|
108
|
+
}
|
|
109
|
+
await delay(delayBetweenTriesMs);
|
|
110
|
+
}
|
|
111
|
+
}
|
|
112
|
+
}
|
|
113
|
+
return {
|
|
114
|
+
get: async (type, ids) => {
|
|
115
|
+
const ctx = txStorage.getStore();
|
|
116
|
+
if (!ctx) {
|
|
117
|
+
return state.get(type, ids);
|
|
118
|
+
}
|
|
119
|
+
const cached = ctx.cache[type] || {};
|
|
120
|
+
const missing = ids.filter(id => !(id in cached));
|
|
121
|
+
if (missing.length > 0) {
|
|
122
|
+
ctx.dbQueries++;
|
|
123
|
+
logger.trace({ type, count: missing.length }, "fetching missing keys in transaction");
|
|
124
|
+
const fetched = await getTxMutex(type).runExclusive(() => state.get(type, missing));
|
|
125
|
+
ctx.cache[type] = ctx.cache[type] || {};
|
|
126
|
+
Object.assign(ctx.cache[type], fetched);
|
|
127
|
+
}
|
|
128
|
+
const result = {};
|
|
129
|
+
for (const id of ids) {
|
|
130
|
+
const value = ctx.cache[type]?.[id];
|
|
131
|
+
if (value !== undefined && value !== null) {
|
|
132
|
+
result[id] = value;
|
|
133
|
+
}
|
|
134
|
+
}
|
|
135
|
+
return result;
|
|
136
|
+
},
|
|
137
|
+
set: async (data) => {
|
|
138
|
+
const ctx = txStorage.getStore();
|
|
139
|
+
if (!ctx) {
|
|
140
|
+
const types = Object.keys(data);
|
|
141
|
+
for (const type_ of types) {
|
|
142
|
+
const type = type_;
|
|
143
|
+
if (type === "pre-key") {
|
|
144
|
+
await preKeyManager.validateDeletions(data, type);
|
|
145
|
+
}
|
|
146
|
+
}
|
|
147
|
+
await Promise.all(types.map(type => getQueue(type).add(async () => {
|
|
148
|
+
const typeData = { [type]: data[type] };
|
|
149
|
+
await state.set(typeData);
|
|
150
|
+
})));
|
|
151
|
+
return;
|
|
152
|
+
}
|
|
153
|
+
logger.trace({ types: Object.keys(data) }, "caching in transaction");
|
|
154
|
+
for (const key_ in data) {
|
|
155
|
+
const key = key_;
|
|
156
|
+
ctx.cache[key] = ctx.cache[key] || {};
|
|
157
|
+
ctx.mutations[key] = ctx.mutations[key] || {};
|
|
158
|
+
if (key === "pre-key") {
|
|
159
|
+
await preKeyManager.processOperations(data, key, ctx.cache, ctx.mutations, true);
|
|
160
|
+
}
|
|
161
|
+
else {
|
|
162
|
+
Object.assign(ctx.cache[key], data[key]);
|
|
163
|
+
Object.assign(ctx.mutations[key], data[key]);
|
|
164
|
+
}
|
|
165
|
+
}
|
|
166
|
+
},
|
|
167
|
+
isInTransaction,
|
|
168
|
+
transaction: async (work, key) => {
|
|
169
|
+
const existing = txStorage.getStore();
|
|
170
|
+
if (existing) {
|
|
171
|
+
logger.trace("reusing existing transaction context");
|
|
172
|
+
return work();
|
|
173
|
+
}
|
|
174
|
+
return getTxMutex(key).runExclusive(async () => {
|
|
175
|
+
const ctx = {
|
|
176
|
+
cache: {},
|
|
177
|
+
mutations: {},
|
|
178
|
+
dbQueries: 0
|
|
179
|
+
};
|
|
180
|
+
logger.trace("entering transaction");
|
|
181
|
+
try {
|
|
182
|
+
const result = await txStorage.run(ctx, work);
|
|
183
|
+
await commitWithRetry(ctx.mutations);
|
|
184
|
+
logger.trace({ dbQueries: ctx.dbQueries }, "transaction completed");
|
|
185
|
+
return result;
|
|
186
|
+
}
|
|
187
|
+
catch (error) {
|
|
188
|
+
logger.error({ error }, "transaction failed, rolling back");
|
|
189
|
+
throw error;
|
|
171
190
|
}
|
|
172
|
-
|
|
173
|
-
function isInTransaction() {
|
|
174
|
-
return transactionsInProgress > 0;
|
|
191
|
+
});
|
|
175
192
|
}
|
|
193
|
+
};
|
|
176
194
|
};
|
|
177
|
-
|
|
178
|
-
const initAuthCreds = () => {
|
|
179
|
-
|
|
180
|
-
|
|
181
|
-
|
|
182
|
-
|
|
183
|
-
|
|
184
|
-
|
|
185
|
-
|
|
186
|
-
|
|
187
|
-
|
|
188
|
-
|
|
189
|
-
|
|
190
|
-
|
|
191
|
-
|
|
192
|
-
|
|
193
|
-
|
|
194
|
-
|
|
195
|
-
|
|
196
|
-
|
|
197
|
-
|
|
198
|
-
|
|
199
|
-
|
|
200
|
-
registration: {},
|
|
201
|
-
pairingCode: undefined,
|
|
202
|
-
lastPropHash: undefined,
|
|
203
|
-
routingInfo: undefined,
|
|
204
|
-
};
|
|
195
|
+
//=======================================================//
|
|
196
|
+
export const initAuthCreds = () => {
|
|
197
|
+
const identityKey = Curve.generateKeyPair();
|
|
198
|
+
return {
|
|
199
|
+
"noiseKey": Curve.generateKeyPair(),
|
|
200
|
+
"pairingEphemeralKeyPair": Curve.generateKeyPair(),
|
|
201
|
+
"signedIdentityKey": identityKey,
|
|
202
|
+
"signedPreKey": signedKeyPair(identityKey, 1),
|
|
203
|
+
"registrationId": generateRegistrationId(),
|
|
204
|
+
"advSecretKey": randomBytes(32).toString("base64"),
|
|
205
|
+
"processedHistoryMessages": [],
|
|
206
|
+
"nextPreKeyId": 1,
|
|
207
|
+
"firstUnuploadedPreKeyId": 1,
|
|
208
|
+
"accountSyncCounter": 0,
|
|
209
|
+
"accountSettings": {
|
|
210
|
+
"unarchiveChats": false
|
|
211
|
+
},
|
|
212
|
+
"registered": false,
|
|
213
|
+
"pairingCode": undefined,
|
|
214
|
+
"lastPropHash": undefined,
|
|
215
|
+
"routingInfo": undefined,
|
|
216
|
+
"additionalData": undefined
|
|
217
|
+
};
|
|
205
218
|
};
|
|
206
|
-
|
|
219
|
+
//=======================================================//
|
|
@@ -1,63 +1,44 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
1
|
+
//=======================================================//
|
|
2
|
+
import { makeMutex } from "./make-mutex.js";
|
|
3
|
+
import { createInterface } from "readline";
|
|
4
|
+
import { writeFile } from "fs/promises";
|
|
5
|
+
import { delay } from "./generics.js";
|
|
6
|
+
import { createReadStream } from "fs";
|
|
7
|
+
import EventEmitter from "events";
|
|
8
|
+
//=======================================================//
|
|
9
|
+
export const captureEventStream = (ev, filename) => {
|
|
10
|
+
const oldEmit = ev.emit;
|
|
11
|
+
const writeMutex = makeMutex();
|
|
12
|
+
ev.emit = function (...args) {
|
|
13
|
+
const content = JSON.stringify({ timestamp: Date.now(), event: args[0], data: args[1] }) + "\n";
|
|
14
|
+
const result = oldEmit.apply(ev, args);
|
|
15
|
+
writeMutex.mutex(async () => {
|
|
16
|
+
await writeFile(filename, content, { flag: "a" });
|
|
17
|
+
});
|
|
18
|
+
return result;
|
|
19
|
+
};
|
|
4
20
|
};
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
const
|
|
8
|
-
const
|
|
9
|
-
const
|
|
10
|
-
const
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
await (0, promises_1.writeFile)(filename, content, { flag: 'a' });
|
|
28
|
-
});
|
|
29
|
-
return result;
|
|
30
|
-
};
|
|
21
|
+
//=======================================================//
|
|
22
|
+
export const readAndEmitEventStream = (filename, delayIntervalMs = 0) => {
|
|
23
|
+
const ev = new EventEmitter();
|
|
24
|
+
const fireEvents = async () => {
|
|
25
|
+
const fileStream = createReadStream(filename);
|
|
26
|
+
const rl = createInterface({
|
|
27
|
+
input: fileStream,
|
|
28
|
+
crlfDelay: Infinity
|
|
29
|
+
});
|
|
30
|
+
for await (const line of rl) {
|
|
31
|
+
if (line) {
|
|
32
|
+
const { event, data } = JSON.parse(line);
|
|
33
|
+
ev.emit(event, data);
|
|
34
|
+
delayIntervalMs && (await delay(delayIntervalMs));
|
|
35
|
+
}
|
|
36
|
+
}
|
|
37
|
+
fileStream.close();
|
|
38
|
+
};
|
|
39
|
+
return {
|
|
40
|
+
ev,
|
|
41
|
+
task: fireEvents()
|
|
42
|
+
};
|
|
31
43
|
};
|
|
32
|
-
|
|
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;
|
|
44
|
+
//=======================================================//
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
//=======================================================//
|
|
2
|
+
import { proto } from "../../WAProto/index.js";
|
|
3
|
+
import { platform, release } from "os";
|
|
4
|
+
//=======================================================//
|
|
5
|
+
const PLATFORM_MAP = {
|
|
6
|
+
'Chrome': '49',
|
|
7
|
+
'Edge': '50',
|
|
8
|
+
'Firefox': '51',
|
|
9
|
+
'Opera': '53',
|
|
10
|
+
'Safari': '54'
|
|
11
|
+
};
|
|
12
|
+
//=======================================================//
|
|
13
|
+
export const Browsers = {
|
|
14
|
+
iOS: (browser) => ["ios", browser, "18.2"],
|
|
15
|
+
ubuntu: (browser) => ['Ubuntu', browser, '22.04.4'],
|
|
16
|
+
macOS: (browser) => ['Mac OS', browser, '14.4.1'],
|
|
17
|
+
baileys: (browser) => ['Baileys', browser, '6.5.0'],
|
|
18
|
+
windows: (browser) => ['Windows', browser, '10.0.22631']
|
|
19
|
+
};
|
|
20
|
+
//=======================================================//
|
|
21
|
+
export const getPlatformId = (browser) => {
|
|
22
|
+
const platformType = proto.DeviceProps.PlatformType[browser.toUpperCase()];
|
|
23
|
+
return platformType ? platformType.toString() : "1";
|
|
24
|
+
};
|
|
25
|
+
//=======================================================//
|