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
|
@@ -1,96 +1,84 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
};
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
1
|
+
//=======================================================//
|
|
2
|
+
import { decrypt, encrypt } from "libsignal-xeuka/src/crypto.js";
|
|
3
|
+
import { SenderKeyMessage } from "./sender-key-message.js";
|
|
4
|
+
import { SenderKeyRecord } from "./sender-key-record.js";
|
|
5
|
+
import { SenderKeyState } from "./sender-key-state.js";
|
|
6
|
+
import { SenderKeyName } from "./sender-key-name.js";
|
|
7
|
+
//=======================================================//
|
|
8
|
+
export class GroupCipher {
|
|
9
|
+
constructor(senderKeyStore, senderKeyName) {
|
|
10
|
+
this.senderKeyStore = senderKeyStore;
|
|
11
|
+
this.senderKeyName = senderKeyName;
|
|
12
|
+
}
|
|
13
|
+
async encrypt(paddedPlaintext) {
|
|
14
|
+
const record = await this.senderKeyStore.loadSenderKey(this.senderKeyName);
|
|
15
|
+
if (!record) {
|
|
16
|
+
throw new Error("No SenderKeyRecord found for encryption");
|
|
14
17
|
}
|
|
15
|
-
|
|
16
|
-
|
|
18
|
+
const senderKeyState = record.getSenderKeyState();
|
|
19
|
+
if (!senderKeyState) {
|
|
20
|
+
throw new Error("No session to encrypt message");
|
|
17
21
|
}
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
const senderKey = this.getSenderKey(senderKeyState, iteration === 0 ? 0 : iteration + 1);
|
|
30
|
-
const ciphertext = await this.getCipherText(senderKey.getIv(), senderKey.getCipherKey(), paddedPlaintext);
|
|
31
|
-
const senderKeyMessage = new sender_key_message_1.SenderKeyMessage(senderKeyState.getKeyId(), senderKey.getIteration(), ciphertext, senderKeyState.getSigningKeyPrivate());
|
|
32
|
-
await this.senderKeyStore.storeSenderKey(this.senderKeyName, record);
|
|
33
|
-
return senderKeyMessage.serialize();
|
|
34
|
-
});
|
|
22
|
+
const iteration = senderKeyState.getSenderChainKey().getIteration();
|
|
23
|
+
const senderKey = this.getSenderKey(senderKeyState, iteration === 0 ? 0 : iteration + 1);
|
|
24
|
+
const ciphertext = await this.getCipherText(senderKey.getIv(), senderKey.getCipherKey(), paddedPlaintext);
|
|
25
|
+
const senderKeyMessage = new SenderKeyMessage(senderKeyState.getKeyId(), senderKey.getIteration(), ciphertext, senderKeyState.getSigningKeyPrivate());
|
|
26
|
+
await this.senderKeyStore.storeSenderKey(this.senderKeyName, record);
|
|
27
|
+
return senderKeyMessage.serialize();
|
|
28
|
+
}
|
|
29
|
+
async decrypt(senderKeyMessageBytes) {
|
|
30
|
+
const record = await this.senderKeyStore.loadSenderKey(this.senderKeyName);
|
|
31
|
+
if (!record) {
|
|
32
|
+
throw new Error("No SenderKeyRecord found for decryption");
|
|
35
33
|
}
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
throw new Error('No SenderKeyRecord found for decryption');
|
|
41
|
-
}
|
|
42
|
-
const senderKeyMessage = new sender_key_message_1.SenderKeyMessage(null, null, null, null, senderKeyMessageBytes);
|
|
43
|
-
const senderKeyState = record.getSenderKeyState(senderKeyMessage.getKeyId());
|
|
44
|
-
if (!senderKeyState) {
|
|
45
|
-
throw new Error('No session found to decrypt message');
|
|
46
|
-
}
|
|
47
|
-
senderKeyMessage.verifySignature(senderKeyState.getSigningKeyPublic());
|
|
48
|
-
const senderKey = this.getSenderKey(senderKeyState, senderKeyMessage.getIteration());
|
|
49
|
-
const plaintext = await this.getPlainText(senderKey.getIv(), senderKey.getCipherKey(), senderKeyMessage.getCipherText());
|
|
50
|
-
await this.senderKeyStore.storeSenderKey(this.senderKeyName, record);
|
|
51
|
-
return plaintext;
|
|
52
|
-
});
|
|
34
|
+
const senderKeyMessage = new SenderKeyMessage(null, null, null, null, senderKeyMessageBytes);
|
|
35
|
+
const senderKeyState = record.getSenderKeyState(senderKeyMessage.getKeyId());
|
|
36
|
+
if (!senderKeyState) {
|
|
37
|
+
throw new Error("No session found to decrypt message");
|
|
53
38
|
}
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
39
|
+
senderKeyMessage.verifySignature(senderKeyState.getSigningKeyPublic());
|
|
40
|
+
const senderKey = this.getSenderKey(senderKeyState, senderKeyMessage.getIteration());
|
|
41
|
+
const plaintext = await this.getPlainText(senderKey.getIv(), senderKey.getCipherKey(), senderKeyMessage.getCipherText());
|
|
42
|
+
await this.senderKeyStore.storeSenderKey(this.senderKeyName, record);
|
|
43
|
+
return plaintext;
|
|
44
|
+
}
|
|
45
|
+
getSenderKey(senderKeyState, iteration) {
|
|
46
|
+
let senderChainKey = senderKeyState.getSenderChainKey();
|
|
47
|
+
if (senderChainKey.getIteration() > iteration) {
|
|
48
|
+
if (senderKeyState.hasSenderMessageKey(iteration)) {
|
|
49
|
+
const messageKey = senderKeyState.removeSenderMessageKey(iteration);
|
|
50
|
+
if (!messageKey) {
|
|
51
|
+
throw new Error("No sender message key found for iteration");
|
|
65
52
|
}
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
while (senderChainKey.getIteration() < iteration) {
|
|
70
|
-
senderKeyState.addSenderMessageKey(senderChainKey.getSenderMessageKey());
|
|
71
|
-
senderChainKey = senderChainKey.getNext();
|
|
72
|
-
}
|
|
73
|
-
senderKeyState.setSenderChainKey(senderChainKey.getNext());
|
|
74
|
-
return senderChainKey.getSenderMessageKey();
|
|
53
|
+
return messageKey;
|
|
54
|
+
}
|
|
55
|
+
throw new Error(`Received message with old counter: ${senderChainKey.getIteration()}, ${iteration}`);
|
|
75
56
|
}
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
return (0, crypto_1.decrypt)(key, ciphertext, iv);
|
|
79
|
-
}
|
|
80
|
-
catch (e) {
|
|
81
|
-
throw new Error('InvalidMessageException');
|
|
82
|
-
}
|
|
57
|
+
if (iteration - senderChainKey.getIteration() > 2000) {
|
|
58
|
+
throw new Error("Over 2000 messages into the future!");
|
|
83
59
|
}
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
60
|
+
while (senderChainKey.getIteration() < iteration) {
|
|
61
|
+
senderKeyState.addSenderMessageKey(senderChainKey.getSenderMessageKey());
|
|
62
|
+
senderChainKey = senderChainKey.getNext();
|
|
63
|
+
}
|
|
64
|
+
senderKeyState.setSenderChainKey(senderChainKey.getNext());
|
|
65
|
+
return senderChainKey.getSenderMessageKey();
|
|
66
|
+
}
|
|
67
|
+
async getPlainText(iv, key, ciphertext) {
|
|
68
|
+
try {
|
|
69
|
+
return decrypt(key, ciphertext, iv);
|
|
70
|
+
}
|
|
71
|
+
catch (e) {
|
|
72
|
+
throw new Error("InvalidMessageException");
|
|
73
|
+
}
|
|
74
|
+
}
|
|
75
|
+
async getCipherText(iv, key, plaintext) {
|
|
76
|
+
try {
|
|
77
|
+
return encrypt(key, plaintext, iv);
|
|
78
|
+
}
|
|
79
|
+
catch (e) {
|
|
80
|
+
throw new Error("InvalidMessageException");
|
|
94
81
|
}
|
|
82
|
+
}
|
|
95
83
|
}
|
|
96
|
-
|
|
84
|
+
//=======================================================//
|
|
@@ -1,57 +1,13 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
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;
|
|
24
|
-
};
|
|
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.keyhelper = exports.CiphertextMessage = exports.SenderChainKey = exports.SenderMessageKey = exports.SenderKeyMessage = exports.SenderKeyState = exports.GroupCipher = exports.SenderKeyName = exports.SenderKeyRecord = exports.SenderKeyDistributionMessage = exports.GroupSessionBuilder = void 0;
|
|
37
|
-
var group_session_builder_1 = require("./group-session-builder");
|
|
38
|
-
Object.defineProperty(exports, "GroupSessionBuilder", { enumerable: true, get: function () { return group_session_builder_1.GroupSessionBuilder; } });
|
|
39
|
-
var sender_key_distribution_message_1 = require("./sender-key-distribution-message");
|
|
40
|
-
Object.defineProperty(exports, "SenderKeyDistributionMessage", { enumerable: true, get: function () { return sender_key_distribution_message_1.SenderKeyDistributionMessage; } });
|
|
41
|
-
var sender_key_record_1 = require("./sender-key-record");
|
|
42
|
-
Object.defineProperty(exports, "SenderKeyRecord", { enumerable: true, get: function () { return sender_key_record_1.SenderKeyRecord; } });
|
|
43
|
-
var sender_key_name_1 = require("./sender-key-name");
|
|
44
|
-
Object.defineProperty(exports, "SenderKeyName", { enumerable: true, get: function () { return sender_key_name_1.SenderKeyName; } });
|
|
45
|
-
var group_cipher_1 = require("./group_cipher");
|
|
46
|
-
Object.defineProperty(exports, "GroupCipher", { enumerable: true, get: function () { return group_cipher_1.GroupCipher; } });
|
|
47
|
-
var sender_key_state_1 = require("./sender-key-state");
|
|
48
|
-
Object.defineProperty(exports, "SenderKeyState", { enumerable: true, get: function () { return sender_key_state_1.SenderKeyState; } });
|
|
49
|
-
var sender_key_message_1 = require("./sender-key-message");
|
|
50
|
-
Object.defineProperty(exports, "SenderKeyMessage", { enumerable: true, get: function () { return sender_key_message_1.SenderKeyMessage; } });
|
|
51
|
-
var sender_message_key_1 = require("./sender-message-key");
|
|
52
|
-
Object.defineProperty(exports, "SenderMessageKey", { enumerable: true, get: function () { return sender_message_key_1.SenderMessageKey; } });
|
|
53
|
-
var sender_chain_key_1 = require("./sender-chain-key");
|
|
54
|
-
Object.defineProperty(exports, "SenderChainKey", { enumerable: true, get: function () { return sender_chain_key_1.SenderChainKey; } });
|
|
55
|
-
var ciphertext_message_1 = require("./ciphertext-message");
|
|
56
|
-
Object.defineProperty(exports, "CiphertextMessage", { enumerable: true, get: function () { return ciphertext_message_1.CiphertextMessage; } });
|
|
57
|
-
exports.keyhelper = __importStar(require("./keyhelper"));
|
|
1
|
+
//=======================================================//
|
|
2
|
+
export { SenderKeyDistributionMessage } from "./sender-key-distribution-message.js";
|
|
3
|
+
export { GroupSessionBuilder } from "./group-session-builder.js";
|
|
4
|
+
export { CiphertextMessage } from "./ciphertext-message.js";
|
|
5
|
+
export { SenderKeyMessage } from "./sender-key-message.js";
|
|
6
|
+
export { SenderMessageKey } from "./sender-message-key.js";
|
|
7
|
+
export { SenderKeyRecord } from "./sender-key-record.js";
|
|
8
|
+
export { SenderKeyState } from "./sender-key-state.js";
|
|
9
|
+
export { SenderChainKey } from "./sender-chain-key.js";
|
|
10
|
+
export { SenderKeyName } from "./sender-key-name.js";
|
|
11
|
+
export { GroupCipher } from "./group_cipher.js";
|
|
12
|
+
export * as keyhelper from "./keyhelper.js";
|
|
13
|
+
//=======================================================//
|
|
@@ -1,55 +1,20 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
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;
|
|
24
|
-
};
|
|
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.generateSenderKey = generateSenderKey;
|
|
37
|
-
exports.generateSenderKeyId = generateSenderKeyId;
|
|
38
|
-
exports.generateSenderSigningKey = generateSenderSigningKey;
|
|
39
|
-
const nodeCrypto = __importStar(require("crypto"));
|
|
40
|
-
const curve_1 = require("libsignal/src/curve");
|
|
41
|
-
function generateSenderKey() {
|
|
42
|
-
return nodeCrypto.randomBytes(32);
|
|
1
|
+
//=======================================================//
|
|
2
|
+
import { generateKeyPair } from "libsignal-xeuka/src/curve.js";
|
|
3
|
+
import * as nodeCrypto from "crypto";
|
|
4
|
+
//=======================================================//
|
|
5
|
+
export function generateSenderKey() {
|
|
6
|
+
return nodeCrypto.randomBytes(32);
|
|
43
7
|
}
|
|
44
|
-
function generateSenderKeyId() {
|
|
45
|
-
|
|
8
|
+
export function generateSenderKeyId() {
|
|
9
|
+
return nodeCrypto.randomInt(2147483647);
|
|
46
10
|
}
|
|
47
|
-
function generateSenderSigningKey(key) {
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
11
|
+
export function generateSenderSigningKey(key) {
|
|
12
|
+
if (!key) {
|
|
13
|
+
key = generateKeyPair();
|
|
14
|
+
}
|
|
15
|
+
return {
|
|
16
|
+
public: Buffer.from(key.pubKey),
|
|
17
|
+
private: Buffer.from(key.privKey)
|
|
18
|
+
};
|
|
55
19
|
}
|
|
20
|
+
//=======================================================//
|
|
@@ -1,34 +1,28 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
getSeed() {
|
|
28
|
-
return this.chainKey;
|
|
29
|
-
}
|
|
30
|
-
getDerivative(seed, key) {
|
|
31
|
-
return (0, crypto_1.calculateMAC)(key, seed);
|
|
32
|
-
}
|
|
1
|
+
//=======================================================//
|
|
2
|
+
import { calculateMAC } from "libsignal-xeuka/src/crypto.js";
|
|
3
|
+
import { SenderMessageKey } from "./sender-message-key.js";
|
|
4
|
+
//=======================================================//
|
|
5
|
+
export class SenderChainKey {
|
|
6
|
+
constructor(iteration, chainKey) {
|
|
7
|
+
this.MESSAGE_KEY_SEED = Buffer.from([0x01]);
|
|
8
|
+
this.CHAIN_KEY_SEED = Buffer.from([0x02]);
|
|
9
|
+
this.iteration = iteration;
|
|
10
|
+
this.chainKey = Buffer.from(chainKey);
|
|
11
|
+
}
|
|
12
|
+
getIteration() {
|
|
13
|
+
return this.iteration;
|
|
14
|
+
}
|
|
15
|
+
getSenderMessageKey() {
|
|
16
|
+
return new SenderMessageKey(this.iteration, this.getDerivative(this.MESSAGE_KEY_SEED, this.chainKey));
|
|
17
|
+
}
|
|
18
|
+
getNext() {
|
|
19
|
+
return new SenderChainKey(this.iteration + 1, this.getDerivative(this.CHAIN_KEY_SEED, this.chainKey));
|
|
20
|
+
}
|
|
21
|
+
getSeed() {
|
|
22
|
+
return this.chainKey;
|
|
23
|
+
}
|
|
24
|
+
getDerivative(seed, key) {
|
|
25
|
+
return calculateMAC(key, seed);
|
|
26
|
+
}
|
|
33
27
|
}
|
|
34
|
-
|
|
28
|
+
//=======================================================//
|
|
@@ -1,66 +1,65 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
}
|
|
28
|
-
}
|
|
29
|
-
else {
|
|
30
|
-
const version = this.intsToByteHighAndLow(this.CURRENT_VERSION, this.CURRENT_VERSION);
|
|
31
|
-
this.id = id;
|
|
32
|
-
this.iteration = iteration;
|
|
33
|
-
this.chainKey = chainKey;
|
|
34
|
-
this.signatureKey = signatureKey;
|
|
35
|
-
const message = WAProto_1.proto.SenderKeyDistributionMessage.encode(WAProto_1.proto.SenderKeyDistributionMessage.create({
|
|
36
|
-
id,
|
|
37
|
-
iteration,
|
|
38
|
-
chainKey,
|
|
39
|
-
signingKey: this.signatureKey
|
|
40
|
-
})).finish();
|
|
41
|
-
this.serialized = Buffer.concat([Buffer.from([version]), message]);
|
|
42
|
-
}
|
|
1
|
+
//=======================================================//
|
|
2
|
+
import { CiphertextMessage } from "./ciphertext-message.js";
|
|
3
|
+
import { proto } from "../../../WAProto/index.js";
|
|
4
|
+
//=======================================================//
|
|
5
|
+
export class SenderKeyDistributionMessage extends CiphertextMessage {
|
|
6
|
+
constructor(id, iteration, chainKey, signatureKey, serialized) {
|
|
7
|
+
super();
|
|
8
|
+
if (serialized) {
|
|
9
|
+
try {
|
|
10
|
+
const message = serialized.slice(1);
|
|
11
|
+
const distributionMessage = proto.SenderKeyDistributionMessage.decode(message).toJSON();
|
|
12
|
+
this.serialized = serialized;
|
|
13
|
+
this.id = distributionMessage.id;
|
|
14
|
+
this.iteration = distributionMessage.iteration;
|
|
15
|
+
this.chainKey =
|
|
16
|
+
typeof distributionMessage.chainKey === "string"
|
|
17
|
+
? Buffer.from(distributionMessage.chainKey, "base64")
|
|
18
|
+
: distributionMessage.chainKey;
|
|
19
|
+
this.signatureKey =
|
|
20
|
+
typeof distributionMessage.signingKey === "string"
|
|
21
|
+
? Buffer.from(distributionMessage.signingKey, "base64")
|
|
22
|
+
: distributionMessage.signingKey;
|
|
23
|
+
}
|
|
24
|
+
catch (e) {
|
|
25
|
+
throw new Error(String(e));
|
|
26
|
+
}
|
|
43
27
|
}
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
return typeof this.chainKey === 'string' ? Buffer.from(this.chainKey, 'base64') : this.chainKey;
|
|
58
|
-
}
|
|
59
|
-
getSignatureKey() {
|
|
60
|
-
return typeof this.signatureKey === 'string' ? Buffer.from(this.signatureKey, 'base64') : this.signatureKey;
|
|
61
|
-
}
|
|
62
|
-
getId() {
|
|
63
|
-
return this.id;
|
|
28
|
+
else {
|
|
29
|
+
const version = this.intsToByteHighAndLow(this.CURRENT_VERSION, this.CURRENT_VERSION);
|
|
30
|
+
this.id = id;
|
|
31
|
+
this.iteration = iteration;
|
|
32
|
+
this.chainKey = chainKey;
|
|
33
|
+
this.signatureKey = signatureKey;
|
|
34
|
+
const message = proto.SenderKeyDistributionMessage.encode(proto.SenderKeyDistributionMessage.create({
|
|
35
|
+
id,
|
|
36
|
+
iteration,
|
|
37
|
+
chainKey,
|
|
38
|
+
signingKey: this.signatureKey
|
|
39
|
+
})).finish();
|
|
40
|
+
this.serialized = Buffer.concat([Buffer.from([version]), message]);
|
|
64
41
|
}
|
|
42
|
+
}
|
|
43
|
+
intsToByteHighAndLow(highValue, lowValue) {
|
|
44
|
+
return (((highValue << 4) | lowValue) & 0xff) % 256;
|
|
45
|
+
}
|
|
46
|
+
serialize() {
|
|
47
|
+
return this.serialized;
|
|
48
|
+
}
|
|
49
|
+
getType() {
|
|
50
|
+
return this.SENDERKEY_DISTRIBUTION_TYPE;
|
|
51
|
+
}
|
|
52
|
+
getIteration() {
|
|
53
|
+
return this.iteration;
|
|
54
|
+
}
|
|
55
|
+
getChainKey() {
|
|
56
|
+
return this.chainKey;
|
|
57
|
+
}
|
|
58
|
+
getSignatureKey() {
|
|
59
|
+
return this.signatureKey;
|
|
60
|
+
}
|
|
61
|
+
getId() {
|
|
62
|
+
return this.id;
|
|
63
|
+
}
|
|
65
64
|
}
|
|
66
|
-
|
|
65
|
+
//=======================================================//
|