@skyzopedia/baileys-mod 5.0.8 → 6.0.0
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/index.js +133384 -57814
- 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 +141 -117
- 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 +14 -12
- package/lib/Signal/Group/group-session-builder.d.ts +14 -0
- package/lib/Signal/Group/group-session-builder.js +42 -10
- package/lib/Signal/Group/group_cipher.d.ts +17 -0
- package/lib/Signal/Group/group_cipher.js +87 -75
- package/lib/Signal/Group/index.d.ts +11 -0
- package/lib/Signal/Group/index.js +57 -13
- package/lib/Signal/Group/keyhelper.d.ts +10 -0
- package/lib/Signal/Group/keyhelper.js +52 -17
- 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 +33 -27
- package/lib/Signal/Group/sender-key-distribution-message.d.ts +16 -0
- package/lib/Signal/Group/sender-key-distribution-message.js +63 -62
- package/lib/Signal/Group/sender-key-message.d.ts +18 -0
- package/lib/Signal/Group/sender-key-message.js +66 -65
- package/lib/Signal/Group/sender-key-name.d.ts +17 -0
- package/lib/Signal/Group/sender-key-name.js +44 -45
- package/lib/Signal/Group/sender-key-record.d.ts +30 -0
- package/lib/Signal/Group/sender-key-record.js +49 -39
- package/lib/Signal/Group/sender-key-state.d.ts +38 -0
- package/lib/Signal/Group/sender-key-state.js +93 -80
- package/lib/Signal/Group/sender-message-key.d.ts +11 -0
- package/lib/Signal/Group/sender-message-key.js +28 -27
- package/lib/Signal/libsignal.d.ts +3 -0
- package/lib/Signal/libsignal.js +163 -313
- 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 -4
- 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 +242 -359
- package/lib/Socket/chats.d.ts +267 -0
- package/lib/Socket/chats.js +935 -846
- package/lib/Socket/dugong.d.ts +254 -0
- package/lib/Socket/dugong.js +484 -0
- package/lib/Socket/groups.d.ts +115 -0
- package/lib/Socket/groups.js +309 -304
- package/lib/Socket/index.d.ts +173 -0
- package/lib/Socket/index.js +10 -15
- package/lib/Socket/messages-recv.d.ts +161 -0
- package/lib/Socket/messages-recv.js +1054 -1107
- package/lib/Socket/messages-send.d.ts +149 -0
- package/lib/Socket/messages-send.js +447 -706
- package/lib/Socket/newsletter.d.ts +134 -0
- package/lib/Socket/newsletter.js +314 -199
- 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 +650 -777
- 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 -6
- package/lib/Store/make-cache-manager-store.d.ts +13 -0
- package/lib/Store/make-cache-manager-store.js +81 -73
- package/lib/Store/make-in-memory-store.d.ts +118 -0
- package/lib/Store/make-in-memory-store.js +423 -286
- package/lib/Store/make-ordered-dictionary.d.ts +13 -0
- package/lib/Store/make-ordered-dictionary.js +79 -77
- package/lib/Store/object-repository.d.ts +10 -0
- package/lib/Store/object-repository.js +26 -24
- package/lib/Types/Auth.d.ts +110 -0
- package/lib/Types/Auth.js +2 -3
- package/lib/Types/Call.d.ts +13 -0
- package/lib/Types/Call.js +2 -3
- package/lib/Types/Chat.d.ts +102 -0
- package/lib/Types/Chat.js +4 -9
- package/lib/Types/Contact.d.ts +19 -0
- package/lib/Types/Contact.js +2 -3
- package/lib/Types/Events.d.ts +157 -0
- package/lib/Types/Events.js +2 -3
- package/lib/Types/GroupMetadata.d.ts +55 -0
- package/lib/Types/GroupMetadata.js +2 -3
- package/lib/Types/Label.d.ts +35 -0
- package/lib/Types/Label.js +26 -24
- package/lib/Types/LabelAssociation.d.ts +29 -0
- package/lib/Types/LabelAssociation.js +8 -6
- package/lib/Types/Message.d.ts +273 -0
- package/lib/Types/Message.js +9 -12
- package/lib/Types/Newsletter.d.ts +103 -0
- package/lib/Types/Newsletter.js +38 -33
- package/lib/Types/Product.d.ts +78 -0
- package/lib/Types/Product.js +2 -3
- package/lib/Types/Signal.d.ts +57 -0
- package/lib/Types/Signal.js +2 -3
- package/lib/Types/Socket.d.ts +111 -0
- package/lib/Types/Socket.js +2 -4
- package/lib/Types/State.d.ts +27 -0
- package/lib/Types/State.js +2 -11
- package/lib/Types/USync.d.ts +25 -0
- package/lib/Types/USync.js +2 -3
- package/lib/Types/index.d.ts +57 -0
- package/lib/Types/index.js +41 -27
- package/lib/Utils/auth-utils.d.ts +18 -0
- package/lib/Utils/auth-utils.js +198 -211
- package/lib/Utils/baileys-event-stream.d.ts +16 -0
- package/lib/Utils/baileys-event-stream.js +61 -42
- package/lib/Utils/business.d.ts +22 -0
- package/lib/Utils/business.js +214 -213
- package/lib/Utils/chat-utils.d.ts +71 -0
- package/lib/Utils/chat-utils.js +687 -710
- package/lib/Utils/crypto.d.ts +41 -0
- package/lib/Utils/crypto.js +133 -112
- package/lib/Utils/decode-wa-message.d.ts +19 -0
- package/lib/Utils/decode-wa-message.js +183 -252
- package/lib/Utils/event-buffer.d.ts +35 -0
- package/lib/Utils/event-buffer.js +496 -510
- package/lib/Utils/generics.d.ts +92 -0
- package/lib/Utils/generics.js +387 -319
- package/lib/Utils/history.d.ts +15 -0
- package/lib/Utils/history.js +92 -83
- package/lib/Utils/index.d.ts +17 -0
- package/lib/Utils/index.js +33 -21
- package/lib/Utils/link-preview.d.ts +21 -0
- package/lib/Utils/link-preview.js +83 -71
- package/lib/Utils/logger.d.ts +4 -0
- package/lib/Utils/logger.js +7 -5
- package/lib/Utils/lt-hash.d.ts +12 -0
- package/lib/Utils/lt-hash.js +46 -40
- package/lib/Utils/make-mutex.d.ts +7 -0
- package/lib/Utils/make-mutex.js +41 -34
- package/lib/Utils/messages-media.d.ts +116 -0
- package/lib/Utils/messages-media.js +768 -550
- package/lib/Utils/messages.d.ts +77 -0
- package/lib/Utils/messages.js +263 -362
- package/lib/Utils/noise-handler.d.ts +21 -0
- package/lib/Utils/noise-handler.js +149 -138
- package/lib/Utils/process-message.d.ts +41 -0
- package/lib/Utils/process-message.js +303 -323
- package/lib/Utils/signal.d.ts +32 -0
- package/lib/Utils/signal.js +141 -149
- package/lib/Utils/use-multi-file-auth-state.d.ts +13 -0
- package/lib/Utils/use-multi-file-auth-state.js +103 -95
- package/lib/Utils/validate-connection.d.ts +11 -0
- package/lib/Utils/validate-connection.js +220 -183
- package/lib/WABinary/constants.d.ts +30 -0
- package/lib/WABinary/constants.js +35 -1298
- package/lib/WABinary/decode.d.ts +7 -0
- package/lib/WABinary/decode.js +249 -237
- package/lib/WABinary/encode.d.ts +3 -0
- package/lib/WABinary/encode.js +260 -213
- package/lib/WABinary/generic-utils.d.ts +17 -0
- package/lib/WABinary/generic-utils.js +65 -56
- package/lib/WABinary/index.d.ts +5 -0
- package/lib/WABinary/index.js +21 -7
- package/lib/WABinary/jid-utils.d.ts +31 -0
- package/lib/WABinary/jid-utils.js +58 -89
- package/lib/WABinary/types.d.ts +18 -0
- package/lib/WABinary/types.js +2 -3
- package/lib/WAM/BinaryInfo.d.ts +17 -0
- package/lib/WAM/BinaryInfo.js +12 -10
- package/lib/WAM/constants.d.ts +38 -0
- package/lib/WAM/constants.js +15348 -22851
- package/lib/WAM/encode.d.ts +3 -0
- package/lib/WAM/encode.js +136 -135
- package/lib/WAM/index.d.ts +3 -0
- package/lib/WAM/index.js +19 -5
- package/lib/WAUSync/Protocols/USyncContactProtocol.d.ts +9 -0
- package/lib/WAUSync/Protocols/USyncContactProtocol.js +30 -28
- package/lib/WAUSync/Protocols/USyncDeviceProtocol.d.ts +22 -0
- package/lib/WAUSync/Protocols/USyncDeviceProtocol.js +53 -49
- package/lib/WAUSync/Protocols/USyncDisappearingModeProtocol.d.ts +12 -0
- package/lib/WAUSync/Protocols/USyncDisappearingModeProtocol.js +28 -27
- package/lib/WAUSync/Protocols/USyncStatusProtocol.d.ts +12 -0
- package/lib/WAUSync/Protocols/USyncStatusProtocol.js +39 -36
- package/lib/WAUSync/Protocols/UsyncBotProfileProtocol.d.ts +25 -0
- package/lib/WAUSync/Protocols/UsyncBotProfileProtocol.js +50 -50
- package/lib/WAUSync/Protocols/UsyncLIDProtocol.d.ts +8 -0
- package/lib/WAUSync/Protocols/UsyncLIDProtocol.js +20 -26
- package/lib/WAUSync/Protocols/index.d.ts +4 -0
- package/lib/WAUSync/Protocols/index.js +20 -6
- package/lib/WAUSync/USyncQuery.d.ts +28 -0
- package/lib/WAUSync/USyncQuery.js +85 -86
- package/lib/WAUSync/USyncUser.d.ts +12 -0
- package/lib/WAUSync/USyncUser.js +25 -23
- package/lib/WAUSync/index.d.ts +3 -0
- package/lib/WAUSync/index.js +19 -5
- package/lib/index.d.ts +12 -0
- package/lib/index.js +36 -24
- package/package.json +106 -98
- package/LICENSE +0 -21
- package/WAProto/WAProto.proto +0 -5311
- package/lib/KeyDB/BinarySearch.js +0 -20
- package/lib/KeyDB/KeyedDB.js +0 -167
- package/lib/KeyDB/index.js +0 -4
- package/lib/Signal/lid-mapping.js +0 -155
- package/lib/Socket/Client/types.js +0 -13
- package/lib/Socket/Client/websocket.js +0 -52
- package/lib/Socket/Client/websocket.js.bak +0 -53
- package/lib/Socket/communities.js +0 -413
- package/lib/Socket/mex.js +0 -45
- package/lib/Types/Bussines.js +0 -3
- package/lib/Types/Newsletter.js.bak +0 -33
- package/lib/Utils/browser-utils.js +0 -25
- package/lib/Utils/message-retry-manager.js +0 -113
- package/lib/Utils/messages.js.bak +0 -907
- package/lib/Utils/pre-key-manager.js +0 -85
package/lib/Signal/libsignal.js
CHANGED
|
@@ -1,324 +1,174 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
return parsedKeys.transaction(async () => {
|
|
25
|
-
return cipher.decrypt(msg);
|
|
26
|
-
}, group);
|
|
27
|
-
},
|
|
28
|
-
async processSenderKeyDistributionMessage({ item, authorJid }) {
|
|
29
|
-
const builder = new GroupSessionBuilder(storage);
|
|
30
|
-
if (!item.groupId) {
|
|
31
|
-
throw new Error("Group ID is required for sender key distribution message");
|
|
32
|
-
}
|
|
33
|
-
const senderName = jidToSignalSenderKeyName(item.groupId, authorJid);
|
|
34
|
-
const senderMsg = new SenderKeyDistributionMessage(null, null, null, null, item.axolotlSenderKeyDistributionMessage);
|
|
35
|
-
const senderNameStr = senderName.toString();
|
|
36
|
-
const { [senderNameStr]: senderKey } = await auth.keys.get("sender-key", [senderNameStr]);
|
|
37
|
-
if (!senderKey) {
|
|
38
|
-
await storage.storeSenderKey(senderName, new SenderKeyRecord());
|
|
39
|
-
}
|
|
40
|
-
return parsedKeys.transaction(async () => {
|
|
41
|
-
const { [senderNameStr]: senderKey } = await auth.keys.get("sender-key", [senderNameStr]);
|
|
42
|
-
if (!senderKey) {
|
|
43
|
-
await storage.storeSenderKey(senderName, new SenderKeyRecord());
|
|
44
|
-
}
|
|
45
|
-
await builder.process(senderName, senderMsg);
|
|
46
|
-
}, item.groupId);
|
|
47
|
-
},
|
|
48
|
-
async decryptMessage({ jid, type, ciphertext }) {
|
|
49
|
-
const addr = jidToSignalProtocolAddress(jid);
|
|
50
|
-
const session = new libsignal.SessionCipher(storage, addr);
|
|
51
|
-
async function doDecrypt() {
|
|
52
|
-
let result;
|
|
53
|
-
switch (type) {
|
|
54
|
-
case "pkmsg":
|
|
55
|
-
result = await session.decryptPreKeyWhisperMessage(ciphertext);
|
|
56
|
-
break;
|
|
57
|
-
case "msg":
|
|
58
|
-
result = await session.decryptWhisperMessage(ciphertext);
|
|
59
|
-
break;
|
|
60
|
-
}
|
|
61
|
-
return result;
|
|
62
|
-
}
|
|
63
|
-
return parsedKeys.transaction(async () => {
|
|
64
|
-
return await doDecrypt();
|
|
65
|
-
}, jid);
|
|
66
|
-
},
|
|
67
|
-
async encryptMessage({ jid, data }) {
|
|
68
|
-
const addr = jidToSignalProtocolAddress(jid);
|
|
69
|
-
const cipher = new libsignal.SessionCipher(storage, addr);
|
|
70
|
-
return parsedKeys.transaction(async () => {
|
|
71
|
-
const { type: sigType, body } = await cipher.encrypt(data);
|
|
72
|
-
const type = sigType === 3 ? "pkmsg" : "msg";
|
|
73
|
-
return { type, ciphertext: Buffer.from(body, "binary") };
|
|
74
|
-
}, jid);
|
|
75
|
-
},
|
|
76
|
-
async encryptGroupMessage({ group, meId, data }) {
|
|
77
|
-
const senderName = jidToSignalSenderKeyName(group, meId);
|
|
78
|
-
const builder = new GroupSessionBuilder(storage);
|
|
79
|
-
const senderNameStr = senderName.toString();
|
|
80
|
-
return parsedKeys.transaction(async () => {
|
|
81
|
-
const { [senderNameStr]: senderKey } = await auth.keys.get("sender-key", [senderNameStr]);
|
|
82
|
-
if (!senderKey) {
|
|
83
|
-
await storage.storeSenderKey(senderName, new SenderKeyRecord());
|
|
84
|
-
}
|
|
85
|
-
const senderKeyDistributionMessage = await builder.create(senderName);
|
|
86
|
-
const session = new GroupCipher(storage, senderName);
|
|
87
|
-
const ciphertext = await session.encrypt(data);
|
|
88
|
-
return {
|
|
89
|
-
ciphertext,
|
|
90
|
-
senderKeyDistributionMessage: senderKeyDistributionMessage.serialize()
|
|
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 __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
+
}) : function(o, v) {
|
|
16
|
+
o["default"] = v;
|
|
17
|
+
});
|
|
18
|
+
var __importStar = (this && this.__importStar) || (function () {
|
|
19
|
+
var ownKeys = function(o) {
|
|
20
|
+
ownKeys = Object.getOwnPropertyNames || function (o) {
|
|
21
|
+
var ar = [];
|
|
22
|
+
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
|
|
23
|
+
return ar;
|
|
91
24
|
};
|
|
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
|
-
if (!jids.length)
|
|
123
|
-
return;
|
|
124
|
-
const sessionUpdates = {};
|
|
125
|
-
jids.forEach(jid => {
|
|
126
|
-
const addr = jidToSignalProtocolAddress(jid);
|
|
127
|
-
sessionUpdates[addr.toString()] = null;
|
|
128
|
-
});
|
|
129
|
-
return parsedKeys.transaction(async () => {
|
|
130
|
-
await auth.keys.set({ session: sessionUpdates });
|
|
131
|
-
}, `delete-${jids.length}-sessions`);
|
|
132
|
-
},
|
|
133
|
-
async migrateSession(fromJid, toJid) {
|
|
134
|
-
if (!fromJid || (!isLidUser(toJid) && !isHostedLidUser(toJid)))
|
|
135
|
-
return { migrated: 0, skipped: 0, total: 0 };
|
|
136
|
-
if (!isPnUser(fromJid) && !isHostedPnUser(fromJid)) {
|
|
137
|
-
return { migrated: 0, skipped: 0, total: 1 };
|
|
138
|
-
}
|
|
139
|
-
const { user } = jidDecode(fromJid);
|
|
140
|
-
logger.debug({ fromJid }, "bulk device migration - loading all user devices");
|
|
141
|
-
const { [user]: userDevices } = await parsedKeys.get("device-list", [user]);
|
|
142
|
-
if (!userDevices) {
|
|
143
|
-
return { migrated: 0, skipped: 0, total: 0 };
|
|
144
|
-
}
|
|
145
|
-
const { device: fromDevice } = jidDecode(fromJid);
|
|
146
|
-
const fromDeviceStr = fromDevice?.toString() || "0";
|
|
147
|
-
if (!userDevices.includes(fromDeviceStr)) {
|
|
148
|
-
userDevices.push(fromDeviceStr);
|
|
149
|
-
}
|
|
150
|
-
const uncachedDevices = userDevices.filter(device => {
|
|
151
|
-
const deviceKey = `${user}.${device}`;
|
|
152
|
-
return !migratedSessionCache.has(deviceKey);
|
|
153
|
-
});
|
|
154
|
-
const deviceSessionKeys = uncachedDevices.map(device => `${user}.${device}`);
|
|
155
|
-
const existingSessions = await parsedKeys.get("session", deviceSessionKeys);
|
|
156
|
-
const deviceJids = [];
|
|
157
|
-
for (const [sessionKey, sessionData] of Object.entries(existingSessions)) {
|
|
158
|
-
if (sessionData) {
|
|
159
|
-
const deviceStr = sessionKey.split(".")[1];
|
|
160
|
-
if (!deviceStr)
|
|
161
|
-
continue;
|
|
162
|
-
const deviceNum = parseInt(deviceStr);
|
|
163
|
-
let jid = deviceNum === 0 ? `${user}@s.whatsapp.net` : `${user}:${deviceNum}@s.whatsapp.net`;
|
|
164
|
-
if (deviceNum === 99) {
|
|
165
|
-
jid = `${user}:99@hosted`;
|
|
166
|
-
}
|
|
167
|
-
deviceJids.push(jid);
|
|
168
|
-
}
|
|
169
|
-
}
|
|
170
|
-
logger.debug({
|
|
171
|
-
fromJid,
|
|
172
|
-
totalDevices: userDevices.length,
|
|
173
|
-
devicesWithSessions: deviceJids.length,
|
|
174
|
-
devices: deviceJids
|
|
175
|
-
}, "bulk device migration complete - all user devices processed");
|
|
176
|
-
return parsedKeys.transaction(async () => {
|
|
177
|
-
const migrationOps = deviceJids.map(jid => {
|
|
178
|
-
const lidWithDevice = transferDevice(jid, toJid);
|
|
179
|
-
const fromDecoded = jidDecode(jid);
|
|
180
|
-
const toDecoded = jidDecode(lidWithDevice);
|
|
181
|
-
return {
|
|
182
|
-
fromJid: jid,
|
|
183
|
-
toJid: lidWithDevice,
|
|
184
|
-
pnUser: fromDecoded.user,
|
|
185
|
-
lidUser: toDecoded.user,
|
|
186
|
-
deviceId: fromDecoded.device || 0,
|
|
187
|
-
fromAddr: jidToSignalProtocolAddress(jid),
|
|
188
|
-
toAddr: jidToSignalProtocolAddress(lidWithDevice)
|
|
189
|
-
};
|
|
190
|
-
});
|
|
191
|
-
const totalOps = migrationOps.length;
|
|
192
|
-
let migratedCount = 0;
|
|
193
|
-
const pnAddrStrings = Array.from(new Set(migrationOps.map(op => op.fromAddr.toString())));
|
|
194
|
-
const pnSessions = await parsedKeys.get("session", pnAddrStrings);
|
|
195
|
-
const sessionUpdates = {};
|
|
196
|
-
for (const op of migrationOps) {
|
|
197
|
-
const pnAddrStr = op.fromAddr.toString();
|
|
198
|
-
const lidAddrStr = op.toAddr.toString();
|
|
199
|
-
const pnSession = pnSessions[pnAddrStr];
|
|
200
|
-
if (pnSession) {
|
|
201
|
-
const fromSession = libsignal.SessionRecord.deserialize(pnSession);
|
|
202
|
-
if (fromSession.haveOpenSession()) {
|
|
203
|
-
sessionUpdates[lidAddrStr] = fromSession.serialize();
|
|
204
|
-
sessionUpdates[pnAddrStr] = null;
|
|
205
|
-
migratedCount++;
|
|
25
|
+
return ownKeys(o);
|
|
26
|
+
};
|
|
27
|
+
return function (mod) {
|
|
28
|
+
if (mod && mod.__esModule) return mod;
|
|
29
|
+
var result = {};
|
|
30
|
+
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
|
|
31
|
+
__setModuleDefault(result, mod);
|
|
32
|
+
return result;
|
|
33
|
+
};
|
|
34
|
+
})();
|
|
35
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
36
|
+
exports.makeLibSignalRepository = makeLibSignalRepository;
|
|
37
|
+
const libsignal = __importStar(require("libsignal"));
|
|
38
|
+
const Utils_1 = require("../Utils");
|
|
39
|
+
const WABinary_1 = require("../WABinary");
|
|
40
|
+
const sender_key_name_1 = require("./Group/sender-key-name");
|
|
41
|
+
const sender_key_record_1 = require("./Group/sender-key-record");
|
|
42
|
+
const Group_1 = require("./Group");
|
|
43
|
+
function makeLibSignalRepository(auth) {
|
|
44
|
+
const storage = signalStorage(auth);
|
|
45
|
+
return {
|
|
46
|
+
decryptGroupMessage({ group, authorJid, msg }) {
|
|
47
|
+
const senderName = jidToSignalSenderKeyName(group, authorJid);
|
|
48
|
+
const cipher = new Group_1.GroupCipher(storage, senderName);
|
|
49
|
+
return cipher.decrypt(msg);
|
|
50
|
+
},
|
|
51
|
+
async processSenderKeyDistributionMessage({ item, authorJid }) {
|
|
52
|
+
const builder = new Group_1.GroupSessionBuilder(storage);
|
|
53
|
+
if (!item.groupId) {
|
|
54
|
+
throw new Error('Group ID is required for sender key distribution message');
|
|
206
55
|
}
|
|
207
|
-
|
|
208
|
-
|
|
209
|
-
|
|
210
|
-
|
|
211
|
-
|
|
212
|
-
|
|
213
|
-
if (sessionUpdates[op.toAddr.toString()]) {
|
|
214
|
-
const deviceKey = `${op.pnUser}.${op.deviceId}`;
|
|
215
|
-
migratedSessionCache.set(deviceKey, true);
|
|
56
|
+
const senderName = jidToSignalSenderKeyName(item.groupId, authorJid);
|
|
57
|
+
const senderMsg = new Group_1.SenderKeyDistributionMessage(null, null, null, null, item.axolotlSenderKeyDistributionMessage);
|
|
58
|
+
const senderNameStr = senderName.toString();
|
|
59
|
+
const { [senderNameStr]: senderKey } = await auth.keys.get('sender-key', [senderNameStr]);
|
|
60
|
+
if (!senderKey) {
|
|
61
|
+
await storage.storeSenderKey(senderName, new sender_key_record_1.SenderKeyRecord());
|
|
216
62
|
}
|
|
217
|
-
|
|
63
|
+
await builder.process(senderName, senderMsg);
|
|
64
|
+
},
|
|
65
|
+
async decryptMessage({ jid, type, ciphertext }) {
|
|
66
|
+
const addr = jidToSignalProtocolAddress(jid);
|
|
67
|
+
const session = new libsignal.SessionCipher(storage, addr);
|
|
68
|
+
let result;
|
|
69
|
+
switch (type) {
|
|
70
|
+
case 'pkmsg':
|
|
71
|
+
result = await session.decryptPreKeyWhisperMessage(ciphertext);
|
|
72
|
+
break;
|
|
73
|
+
case 'msg':
|
|
74
|
+
result = await session.decryptWhisperMessage(ciphertext);
|
|
75
|
+
break;
|
|
76
|
+
default:
|
|
77
|
+
throw new Error(`Unknown message type: ${type}`);
|
|
78
|
+
}
|
|
79
|
+
return result;
|
|
80
|
+
},
|
|
81
|
+
async encryptMessage({ jid, data }) {
|
|
82
|
+
const addr = jidToSignalProtocolAddress(jid);
|
|
83
|
+
const cipher = new libsignal.SessionCipher(storage, addr);
|
|
84
|
+
const { type: sigType, body } = await cipher.encrypt(data);
|
|
85
|
+
const type = sigType === 3 ? 'pkmsg' : 'msg';
|
|
86
|
+
return { type, ciphertext: Buffer.from(body, 'binary') };
|
|
87
|
+
},
|
|
88
|
+
async encryptGroupMessage({ group, meId, data }) {
|
|
89
|
+
const senderName = jidToSignalSenderKeyName(group, meId);
|
|
90
|
+
const builder = new Group_1.GroupSessionBuilder(storage);
|
|
91
|
+
const senderNameStr = senderName.toString();
|
|
92
|
+
const { [senderNameStr]: senderKey } = await auth.keys.get('sender-key', [senderNameStr]);
|
|
93
|
+
if (!senderKey) {
|
|
94
|
+
await storage.storeSenderKey(senderName, new sender_key_record_1.SenderKeyRecord());
|
|
95
|
+
}
|
|
96
|
+
const senderKeyDistributionMessage = await builder.create(senderName);
|
|
97
|
+
const session = new Group_1.GroupCipher(storage, senderName);
|
|
98
|
+
const ciphertext = await session.encrypt(data);
|
|
99
|
+
return {
|
|
100
|
+
ciphertext,
|
|
101
|
+
senderKeyDistributionMessage: senderKeyDistributionMessage.serialize()
|
|
102
|
+
};
|
|
103
|
+
},
|
|
104
|
+
async injectE2ESession({ jid, session }) {
|
|
105
|
+
const cipher = new libsignal.SessionBuilder(storage, jidToSignalProtocolAddress(jid));
|
|
106
|
+
await cipher.initOutgoing(session);
|
|
107
|
+
},
|
|
108
|
+
jidToSignalProtocolAddress(jid) {
|
|
109
|
+
return jidToSignalProtocolAddress(jid).toString();
|
|
218
110
|
}
|
|
219
|
-
|
|
220
|
-
return { migrated: migratedCount, skipped: skippedCount, total: totalOps };
|
|
221
|
-
}, `migrate-${deviceJids.length}-sessions-${jidDecode(toJid)?.user}`);
|
|
222
|
-
}
|
|
223
|
-
};
|
|
224
|
-
return repository;
|
|
111
|
+
};
|
|
225
112
|
}
|
|
226
|
-
//=======================================================//
|
|
227
113
|
const jidToSignalProtocolAddress = (jid) => {
|
|
228
|
-
|
|
229
|
-
|
|
230
|
-
if (!user) {
|
|
231
|
-
throw new Error(`JID decoded but user is empty: "${jid}" -> user: "${user}", server: "${server}", device: ${device}`);
|
|
232
|
-
}
|
|
233
|
-
const signalUser = domainType !== WAJIDDomains.WHATSAPP ? `${user}_${domainType}` : user;
|
|
234
|
-
const finalDevice = device || 0;
|
|
235
|
-
if (device === 99 && decoded.server !== "hosted" && decoded.server !== "hosted.lid") {
|
|
236
|
-
throw new Error("Unexpected non-hosted device JID with device 99. This ID seems invalid. ID:" + jid);
|
|
237
|
-
}
|
|
238
|
-
return new libsignal.ProtocolAddress(signalUser, finalDevice);
|
|
114
|
+
const { user, device } = (0, WABinary_1.jidDecode)(jid);
|
|
115
|
+
return new libsignal.ProtocolAddress(user, device || 0);
|
|
239
116
|
};
|
|
240
|
-
//=======================================================//
|
|
241
117
|
const jidToSignalSenderKeyName = (group, user) => {
|
|
242
|
-
|
|
118
|
+
return new sender_key_name_1.SenderKeyName(group, jidToSignalProtocolAddress(user));
|
|
243
119
|
};
|
|
244
|
-
|
|
245
|
-
|
|
246
|
-
|
|
247
|
-
|
|
248
|
-
|
|
249
|
-
|
|
250
|
-
|
|
251
|
-
|
|
252
|
-
|
|
253
|
-
|
|
254
|
-
|
|
255
|
-
|
|
256
|
-
|
|
257
|
-
|
|
258
|
-
|
|
259
|
-
|
|
260
|
-
|
|
261
|
-
|
|
262
|
-
|
|
263
|
-
|
|
264
|
-
|
|
265
|
-
|
|
266
|
-
|
|
267
|
-
|
|
268
|
-
|
|
120
|
+
function signalStorage({ creds, keys }) {
|
|
121
|
+
return {
|
|
122
|
+
loadSession: async (id) => {
|
|
123
|
+
const { [id]: sess } = await keys.get('session', [id]);
|
|
124
|
+
if (sess) {
|
|
125
|
+
return libsignal.SessionRecord.deserialize(sess);
|
|
126
|
+
}
|
|
127
|
+
},
|
|
128
|
+
storeSession: async (id, session) => {
|
|
129
|
+
await keys.set({ session: { [id]: session.serialize() } });
|
|
130
|
+
},
|
|
131
|
+
isTrustedIdentity: () => {
|
|
132
|
+
return true;
|
|
133
|
+
},
|
|
134
|
+
loadPreKey: async (id) => {
|
|
135
|
+
const keyId = id.toString();
|
|
136
|
+
const { [keyId]: key } = await keys.get('pre-key', [keyId]);
|
|
137
|
+
if (key) {
|
|
138
|
+
return {
|
|
139
|
+
privKey: Buffer.from(key.private),
|
|
140
|
+
pubKey: Buffer.from(key.public)
|
|
141
|
+
};
|
|
142
|
+
}
|
|
143
|
+
},
|
|
144
|
+
removePreKey: (id) => keys.set({ 'pre-key': { [id]: null } }),
|
|
145
|
+
loadSignedPreKey: () => {
|
|
146
|
+
const key = creds.signedPreKey;
|
|
147
|
+
return {
|
|
148
|
+
privKey: Buffer.from(key.keyPair.private),
|
|
149
|
+
pubKey: Buffer.from(key.keyPair.public)
|
|
150
|
+
};
|
|
151
|
+
},
|
|
152
|
+
loadSenderKey: async (senderKeyName) => {
|
|
153
|
+
const keyId = senderKeyName.toString();
|
|
154
|
+
const { [keyId]: key } = await keys.get('sender-key', [keyId]);
|
|
155
|
+
if (key) {
|
|
156
|
+
return sender_key_record_1.SenderKeyRecord.deserialize(key);
|
|
157
|
+
}
|
|
158
|
+
return new sender_key_record_1.SenderKeyRecord();
|
|
159
|
+
},
|
|
160
|
+
storeSenderKey: async (senderKeyName, key) => {
|
|
161
|
+
const keyId = senderKeyName.toString();
|
|
162
|
+
const serialized = JSON.stringify(key.serialize());
|
|
163
|
+
await keys.set({ 'sender-key': { [keyId]: Buffer.from(serialized, 'utf-8') } });
|
|
164
|
+
},
|
|
165
|
+
getOurRegistrationId: () => creds.registrationId,
|
|
166
|
+
getOurIdentity: () => {
|
|
167
|
+
const { signedIdentityKey } = creds;
|
|
168
|
+
return {
|
|
169
|
+
privKey: Buffer.from(signedIdentityKey.private),
|
|
170
|
+
pubKey: (0, Utils_1.generateSignalPubKey)(signedIdentityKey.public)
|
|
171
|
+
};
|
|
269
172
|
}
|
|
270
|
-
|
|
271
|
-
catch (e) {
|
|
272
|
-
return null;
|
|
273
|
-
}
|
|
274
|
-
return null;
|
|
275
|
-
},
|
|
276
|
-
storeSession: async (id, session) => {
|
|
277
|
-
const wireJid = await resolveLIDSignalAddress(id);
|
|
278
|
-
await keys.set({ session: { [wireJid]: session.serialize() } });
|
|
279
|
-
},
|
|
280
|
-
isTrustedIdentity: () => {
|
|
281
|
-
return true;
|
|
282
|
-
},
|
|
283
|
-
loadPreKey: async (id) => {
|
|
284
|
-
const keyId = id.toString();
|
|
285
|
-
const { [keyId]: key } = await keys.get("pre-key", [keyId]);
|
|
286
|
-
if (key) {
|
|
287
|
-
return {
|
|
288
|
-
privKey: Buffer.from(key.private),
|
|
289
|
-
pubKey: Buffer.from(key.public)
|
|
290
|
-
};
|
|
291
|
-
}
|
|
292
|
-
},
|
|
293
|
-
removePreKey: (id) => keys.set({ "pre-key": { [id]: null } }),
|
|
294
|
-
loadSignedPreKey: () => {
|
|
295
|
-
const key = creds.signedPreKey;
|
|
296
|
-
return {
|
|
297
|
-
privKey: Buffer.from(key.keyPair.private),
|
|
298
|
-
pubKey: Buffer.from(key.keyPair.public)
|
|
299
|
-
};
|
|
300
|
-
},
|
|
301
|
-
loadSenderKey: async (senderKeyName) => {
|
|
302
|
-
const keyId = senderKeyName.toString();
|
|
303
|
-
const { [keyId]: key } = await keys.get("sender-key", [keyId]);
|
|
304
|
-
if (key) {
|
|
305
|
-
return SenderKeyRecord.deserialize(key);
|
|
306
|
-
}
|
|
307
|
-
return new SenderKeyRecord();
|
|
308
|
-
},
|
|
309
|
-
storeSenderKey: async (senderKeyName, key) => {
|
|
310
|
-
const keyId = senderKeyName.toString();
|
|
311
|
-
const serialized = JSON.stringify(key.serialize());
|
|
312
|
-
await keys.set({ "sender-key": { [keyId]: Buffer.from(serialized, "utf-8") } });
|
|
313
|
-
},
|
|
314
|
-
getOurRegistrationId: () => creds.registrationId,
|
|
315
|
-
getOurIdentity: () => {
|
|
316
|
-
const { signedIdentityKey } = creds;
|
|
317
|
-
return {
|
|
318
|
-
privKey: Buffer.from(signedIdentityKey.private),
|
|
319
|
-
pubKey: Buffer.from(generateSignalPubKey(signedIdentityKey.public))
|
|
320
|
-
};
|
|
321
|
-
}
|
|
322
|
-
};
|
|
173
|
+
};
|
|
323
174
|
}
|
|
324
|
-
//=======================================================//
|
|
@@ -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;
|
|
@@ -1,4 +1,19 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
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
|
+
}
|