@sixcore/baileys 1.0.0 → 1.0.1
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 +14270 -302
- package/jessica.js +91 -0
- package/lib/Defaults/baileys-version.json +1 -1
- package/lib/Defaults/index.js +117 -79
- 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 +15 -0
- package/lib/Signal/Group/group-session-builder.d.ts +14 -0
- package/lib/Signal/Group/group-session-builder.js +64 -0
- package/lib/Signal/Group/group_cipher.d.ts +17 -0
- package/lib/Signal/Group/group_cipher.js +96 -0
- package/lib/Signal/Group/index.d.ts +11 -0
- package/lib/Signal/Group/index.js +57 -0
- package/lib/Signal/Group/keyhelper.d.ts +10 -0
- package/lib/Signal/Group/keyhelper.js +55 -0
- 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 +34 -0
- package/lib/Signal/Group/sender-key-distribution-message.d.ts +16 -0
- package/lib/Signal/Group/sender-key-distribution-message.js +66 -0
- package/lib/Signal/Group/sender-key-message.d.ts +18 -0
- package/lib/Signal/Group/sender-key-message.js +69 -0
- package/lib/Signal/Group/sender-key-name.d.ts +17 -0
- package/lib/Signal/Group/sender-key-name.js +51 -0
- package/lib/Signal/Group/sender-key-record.d.ts +30 -0
- package/lib/Signal/Group/sender-key-record.js +53 -0
- package/lib/Signal/Group/sender-key-state.d.ts +38 -0
- package/lib/Signal/Group/sender-key-state.js +99 -0
- package/lib/Signal/Group/sender-message-key.d.ts +11 -0
- package/{WASignalGroup/sender_message_key.js → lib/Signal/Group/sender-message-key.js} +6 -16
- package/lib/Signal/libsignal.js +51 -29
- package/lib/Socket/business.d.ts +43 -42
- package/lib/Socket/chats.d.ts +222 -36
- package/lib/Socket/chats.js +173 -153
- package/lib/Socket/dugong.d.ts +254 -0
- package/lib/Socket/dugong.js +484 -0
- package/lib/Socket/groups.d.ts +7 -7
- package/lib/Socket/groups.js +37 -35
- package/lib/Socket/index.d.ts +52 -51
- package/lib/Socket/index.js +1 -0
- package/lib/Socket/messages-recv.d.ts +37 -34
- package/lib/Socket/messages-recv.js +175 -37
- package/lib/Socket/messages-send.d.ts +12 -18
- package/lib/Socket/messages-send.js +396 -574
- package/lib/Socket/newsletter.d.ts +28 -26
- package/lib/Socket/newsletter.js +123 -25
- package/lib/Socket/registration.d.ts +52 -49
- package/lib/Socket/registration.js +7 -7
- package/lib/Socket/socket.d.ts +0 -1
- package/lib/Socket/socket.js +49 -27
- package/lib/Socket/usync.d.ts +10 -11
- package/lib/Store/make-cache-manager-store.d.ts +1 -2
- package/lib/Store/make-in-memory-store.d.ts +2 -2
- package/lib/Store/make-in-memory-store.js +1 -5
- package/lib/Store/make-ordered-dictionary.js +2 -2
- package/lib/Types/Auth.d.ts +1 -0
- package/lib/Types/Call.d.ts +1 -1
- package/lib/Types/Chat.d.ts +7 -12
- package/lib/Types/Events.d.ts +2 -17
- package/lib/Types/GroupMetadata.d.ts +2 -3
- package/lib/Types/Label.d.ts +0 -11
- package/lib/Types/Label.js +1 -1
- package/lib/Types/LabelAssociation.js +1 -1
- package/lib/Types/Message.d.ts +10 -170
- package/lib/Types/Newsletter.d.ts +97 -86
- package/lib/Types/Newsletter.js +38 -32
- package/lib/Types/Socket.d.ts +2 -7
- package/lib/Types/index.d.ts +0 -9
- package/lib/Types/index.js +1 -1
- package/lib/Utils/auth-utils.js +14 -35
- package/lib/Utils/business.d.ts +1 -1
- package/lib/Utils/business.js +2 -2
- package/lib/Utils/chat-utils.d.ts +12 -11
- package/lib/Utils/chat-utils.js +36 -52
- package/lib/Utils/crypto.d.ts +16 -15
- package/lib/Utils/crypto.js +26 -74
- package/lib/Utils/decode-wa-message.d.ts +0 -17
- package/lib/Utils/decode-wa-message.js +17 -53
- package/lib/Utils/event-buffer.js +7 -10
- package/lib/Utils/generics.d.ts +17 -13
- package/lib/Utils/generics.js +79 -58
- package/lib/Utils/history.d.ts +2 -6
- package/lib/Utils/history.js +6 -4
- package/lib/Utils/logger.d.ts +3 -1
- package/lib/Utils/lt-hash.js +12 -12
- package/lib/Utils/make-mutex.d.ts +2 -2
- package/lib/Utils/messages-media.d.ts +28 -25
- package/lib/Utils/messages-media.js +733 -557
- package/lib/Utils/messages.js +68 -473
- package/lib/Utils/noise-handler.d.ts +5 -4
- package/lib/Utils/noise-handler.js +14 -19
- package/lib/Utils/process-message.d.ts +5 -5
- package/lib/Utils/process-message.js +23 -75
- package/lib/Utils/signal.d.ts +1 -2
- package/lib/Utils/signal.js +26 -32
- package/lib/Utils/use-multi-file-auth-state.d.ts +1 -0
- package/lib/Utils/use-multi-file-auth-state.js +66 -242
- package/lib/Utils/validate-connection.d.ts +1 -1
- package/lib/Utils/validate-connection.js +88 -64
- package/lib/WABinary/constants.d.ts +27 -24
- package/lib/WABinary/decode.d.ts +2 -1
- package/lib/WABinary/decode.js +11 -23
- package/lib/WABinary/encode.d.ts +2 -1
- package/lib/WABinary/encode.js +147 -134
- package/lib/WABinary/generic-utils.d.ts +5 -2
- package/lib/WABinary/generic-utils.js +125 -37
- package/lib/WABinary/jid-utils.d.ts +1 -1
- package/lib/WAM/BinaryInfo.d.ts +11 -2
- package/lib/WAM/encode.d.ts +2 -1
- package/lib/WAUSync/Protocols/USyncStatusProtocol.js +3 -3
- package/lib/WAUSync/USyncUser.d.ts +2 -0
- package/lib/index.d.ts +12 -0
- package/lib/index.js +64 -1
- package/package.json +113 -51
- package/WAProto/GenerateStatics.sh +0 -4
- package/WAProto/WAProto.proto +0 -4357
- package/WAProto/index.d.ts +0 -50383
- package/WASignalGroup/GroupProtocol.js +0 -1697
- package/WASignalGroup/ciphertext_message.js +0 -16
- package/WASignalGroup/generate-proto.sh +0 -1
- package/WASignalGroup/group.proto +0 -42
- package/WASignalGroup/group_cipher.js +0 -120
- package/WASignalGroup/group_session_builder.js +0 -46
- package/WASignalGroup/index.js +0 -5
- package/WASignalGroup/keyhelper.js +0 -21
- package/WASignalGroup/protobufs.js +0 -3
- package/WASignalGroup/queue_job.js +0 -69
- package/WASignalGroup/sender_chain_key.js +0 -50
- package/WASignalGroup/sender_key_distribution_message.js +0 -78
- package/WASignalGroup/sender_key_message.js +0 -92
- package/WASignalGroup/sender_key_name.js +0 -70
- package/WASignalGroup/sender_key_record.js +0 -56
- package/WASignalGroup/sender_key_state.js +0 -129
- package/lib/Utils/use-single-file-auth-state.d.ts +0 -12
- package/lib/Utils/use-single-file-auth-state.js +0 -75
- package/src/Defaults/baileys-version.json +0 -3
- package/src/Defaults/index.ts +0 -133
- package/src/Signal/Group/ciphertext-message.ts +0 -9
- package/src/Signal/Group/group-session-builder.ts +0 -56
- package/src/Signal/Group/group_cipher.ts +0 -117
- package/src/Signal/Group/index.ts +0 -11
- package/src/Signal/Group/keyhelper.ts +0 -28
- package/src/Signal/Group/sender-chain-key.ts +0 -34
- package/src/Signal/Group/sender-key-distribution-message.ts +0 -95
- package/src/Signal/Group/sender-key-message.ts +0 -96
- package/src/Signal/Group/sender-key-name.ts +0 -66
- package/src/Signal/Group/sender-key-record.ts +0 -69
- package/src/Signal/Group/sender-key-state.ts +0 -134
- package/src/Signal/Group/sender-message-key.ts +0 -36
- package/src/Signal/libsignal.ts +0 -447
- package/src/Signal/lid-mapping.ts +0 -209
- package/src/Socket/Client/index.ts +0 -2
- package/src/Socket/Client/types.ts +0 -22
- package/src/Socket/Client/websocket.ts +0 -56
- package/src/Socket/business.ts +0 -421
- package/src/Socket/chats.ts +0 -1223
- package/src/Socket/communities.ts +0 -477
- package/src/Socket/groups.ts +0 -361
- package/src/Socket/index.ts +0 -22
- package/src/Socket/messages-recv.ts +0 -1563
- package/src/Socket/messages-send.ts +0 -1210
- package/src/Socket/mex.ts +0 -58
- package/src/Socket/newsletter.ts +0 -229
- package/src/Socket/socket.ts +0 -1072
- package/src/Types/Auth.ts +0 -115
- package/src/Types/Bussines.ts +0 -20
- package/src/Types/Call.ts +0 -14
- package/src/Types/Chat.ts +0 -138
- package/src/Types/Contact.ts +0 -24
- package/src/Types/Events.ts +0 -132
- package/src/Types/GroupMetadata.ts +0 -70
- package/src/Types/Label.ts +0 -48
- package/src/Types/LabelAssociation.ts +0 -35
- package/src/Types/Message.ts +0 -424
- package/src/Types/Newsletter.ts +0 -98
- package/src/Types/Product.ts +0 -85
- package/src/Types/Signal.ts +0 -76
- package/src/Types/Socket.ts +0 -150
- package/src/Types/State.ts +0 -43
- package/src/Types/USync.ts +0 -27
- package/src/Types/globals.d.ts +0 -8
- package/src/Types/index.ts +0 -67
- package/src/Utils/auth-utils.ts +0 -331
- package/src/Utils/browser-utils.ts +0 -31
- package/src/Utils/business.ts +0 -286
- package/src/Utils/chat-utils.ts +0 -933
- package/src/Utils/crypto.ts +0 -184
- package/src/Utils/decode-wa-message.ts +0 -355
- package/src/Utils/event-buffer.ts +0 -662
- package/src/Utils/generics.ts +0 -470
- package/src/Utils/history.ts +0 -114
- package/src/Utils/index.ts +0 -18
- package/src/Utils/link-preview.ts +0 -111
- package/src/Utils/logger.ts +0 -13
- package/src/Utils/lt-hash.ts +0 -65
- package/src/Utils/make-mutex.ts +0 -45
- package/src/Utils/message-retry-manager.ts +0 -229
- package/src/Utils/messages-media.ts +0 -820
- package/src/Utils/messages.ts +0 -1137
- package/src/Utils/noise-handler.ts +0 -192
- package/src/Utils/pre-key-manager.ts +0 -126
- package/src/Utils/process-message.ts +0 -622
- package/src/Utils/signal.ts +0 -214
- package/src/Utils/use-multi-file-auth-state.ts +0 -136
- package/src/Utils/validate-connection.ts +0 -253
- package/src/WABinary/constants.ts +0 -1305
- package/src/WABinary/decode.ts +0 -281
- package/src/WABinary/encode.ts +0 -253
- package/src/WABinary/generic-utils.ts +0 -127
- package/src/WABinary/index.ts +0 -5
- package/src/WABinary/jid-utils.ts +0 -128
- package/src/WABinary/types.ts +0 -17
- package/src/WAM/BinaryInfo.ts +0 -12
- package/src/WAM/constants.ts +0 -22889
- package/src/WAM/encode.ts +0 -169
- package/src/WAM/index.ts +0 -3
- package/src/WAUSync/Protocols/USyncContactProtocol.ts +0 -32
- package/src/WAUSync/Protocols/USyncDeviceProtocol.ts +0 -78
- package/src/WAUSync/Protocols/USyncDisappearingModeProtocol.ts +0 -35
- package/src/WAUSync/Protocols/USyncStatusProtocol.ts +0 -44
- package/src/WAUSync/Protocols/UsyncBotProfileProtocol.ts +0 -76
- package/src/WAUSync/Protocols/UsyncLIDProtocol.ts +0 -33
- package/src/WAUSync/Protocols/index.ts +0 -4
- package/src/WAUSync/USyncQuery.ts +0 -133
- package/src/WAUSync/USyncUser.ts +0 -32
- package/src/WAUSync/index.ts +0 -3
- package/src/index.ts +0 -13
|
@@ -1,129 +0,0 @@
|
|
|
1
|
-
const SenderChainKey = require('./sender_chain_key');
|
|
2
|
-
const SenderMessageKey = require('./sender_message_key');
|
|
3
|
-
|
|
4
|
-
const protobufs = require('./protobufs');
|
|
5
|
-
|
|
6
|
-
class SenderKeyState {
|
|
7
|
-
MAX_MESSAGE_KEYS = 2000;
|
|
8
|
-
|
|
9
|
-
constructor(
|
|
10
|
-
id = null,
|
|
11
|
-
iteration = null,
|
|
12
|
-
chainKey = null,
|
|
13
|
-
signatureKeyPair = null,
|
|
14
|
-
signatureKeyPublic = null,
|
|
15
|
-
signatureKeyPrivate = null,
|
|
16
|
-
senderKeyStateStructure = null
|
|
17
|
-
) {
|
|
18
|
-
if (senderKeyStateStructure) {
|
|
19
|
-
this.senderKeyStateStructure = senderKeyStateStructure;
|
|
20
|
-
} else {
|
|
21
|
-
if (signatureKeyPair) {
|
|
22
|
-
signatureKeyPublic = signatureKeyPair.public;
|
|
23
|
-
signatureKeyPrivate = signatureKeyPair.private;
|
|
24
|
-
}
|
|
25
|
-
|
|
26
|
-
chainKey = typeof chainKey === 'string' ? Buffer.from(chainKey, 'base64') : chainKey;
|
|
27
|
-
this.senderKeyStateStructure = protobufs.SenderKeyStateStructure.create();
|
|
28
|
-
const senderChainKeyStructure = protobufs.SenderChainKey.create();
|
|
29
|
-
senderChainKeyStructure.iteration = iteration;
|
|
30
|
-
senderChainKeyStructure.seed = chainKey;
|
|
31
|
-
this.senderKeyStateStructure.senderChainKey = senderChainKeyStructure;
|
|
32
|
-
|
|
33
|
-
const signingKeyStructure = protobufs.SenderSigningKey.create();
|
|
34
|
-
signingKeyStructure.public =
|
|
35
|
-
typeof signatureKeyPublic === 'string' ?
|
|
36
|
-
Buffer.from(signatureKeyPublic, 'base64') :
|
|
37
|
-
signatureKeyPublic;
|
|
38
|
-
if (signatureKeyPrivate) {
|
|
39
|
-
signingKeyStructure.private =
|
|
40
|
-
typeof signatureKeyPrivate === 'string' ?
|
|
41
|
-
Buffer.from(signatureKeyPrivate, 'base64') :
|
|
42
|
-
signatureKeyPrivate;
|
|
43
|
-
}
|
|
44
|
-
this.senderKeyStateStructure.senderKeyId = id;
|
|
45
|
-
this.senderChainKey = senderChainKeyStructure;
|
|
46
|
-
this.senderKeyStateStructure.senderSigningKey = signingKeyStructure;
|
|
47
|
-
}
|
|
48
|
-
this.senderKeyStateStructure.senderMessageKeys =
|
|
49
|
-
this.senderKeyStateStructure.senderMessageKeys || [];
|
|
50
|
-
}
|
|
51
|
-
|
|
52
|
-
SenderKeyState(senderKeyStateStructure) {
|
|
53
|
-
this.senderKeyStateStructure = senderKeyStateStructure;
|
|
54
|
-
}
|
|
55
|
-
|
|
56
|
-
getKeyId() {
|
|
57
|
-
return this.senderKeyStateStructure.senderKeyId;
|
|
58
|
-
}
|
|
59
|
-
|
|
60
|
-
getSenderChainKey() {
|
|
61
|
-
return new SenderChainKey(
|
|
62
|
-
this.senderKeyStateStructure.senderChainKey.iteration,
|
|
63
|
-
this.senderKeyStateStructure.senderChainKey.seed
|
|
64
|
-
);
|
|
65
|
-
}
|
|
66
|
-
|
|
67
|
-
setSenderChainKey(chainKey) {
|
|
68
|
-
const senderChainKeyStructure = protobufs.SenderChainKey.create({
|
|
69
|
-
iteration: chainKey.getIteration(),
|
|
70
|
-
seed: chainKey.getSeed(),
|
|
71
|
-
});
|
|
72
|
-
this.senderKeyStateStructure.senderChainKey = senderChainKeyStructure;
|
|
73
|
-
}
|
|
74
|
-
|
|
75
|
-
getSigningKeyPublic() {
|
|
76
|
-
return typeof this.senderKeyStateStructure.senderSigningKey.public === 'string' ?
|
|
77
|
-
Buffer.from(this.senderKeyStateStructure.senderSigningKey.public, 'base64') :
|
|
78
|
-
this.senderKeyStateStructure.senderSigningKey.public;
|
|
79
|
-
}
|
|
80
|
-
|
|
81
|
-
getSigningKeyPrivate() {
|
|
82
|
-
return typeof this.senderKeyStateStructure.senderSigningKey.private === 'string' ?
|
|
83
|
-
Buffer.from(this.senderKeyStateStructure.senderSigningKey.private, 'base64') :
|
|
84
|
-
this.senderKeyStateStructure.senderSigningKey.private;
|
|
85
|
-
}
|
|
86
|
-
|
|
87
|
-
hasSenderMessageKey(iteration) {
|
|
88
|
-
const list = this.senderKeyStateStructure.senderMessageKeys;
|
|
89
|
-
for (let o = 0; o < list.length; o++) {
|
|
90
|
-
const senderMessageKey = list[o];
|
|
91
|
-
if (senderMessageKey.iteration === iteration) return true;
|
|
92
|
-
}
|
|
93
|
-
return false;
|
|
94
|
-
}
|
|
95
|
-
|
|
96
|
-
addSenderMessageKey(senderMessageKey) {
|
|
97
|
-
const senderMessageKeyStructure = protobufs.SenderKeyStateStructure.create({
|
|
98
|
-
iteration: senderMessageKey.getIteration(),
|
|
99
|
-
seed: senderMessageKey.getSeed(),
|
|
100
|
-
});
|
|
101
|
-
this.senderKeyStateStructure.senderMessageKeys.push(senderMessageKeyStructure);
|
|
102
|
-
|
|
103
|
-
if (this.senderKeyStateStructure.senderMessageKeys.length > this.MAX_MESSAGE_KEYS) {
|
|
104
|
-
this.senderKeyStateStructure.senderMessageKeys.shift();
|
|
105
|
-
}
|
|
106
|
-
}
|
|
107
|
-
|
|
108
|
-
removeSenderMessageKey(iteration) {
|
|
109
|
-
let result = null;
|
|
110
|
-
|
|
111
|
-
this.senderKeyStateStructure.senderMessageKeys = this.senderKeyStateStructure.senderMessageKeys.filter(
|
|
112
|
-
senderMessageKey => {
|
|
113
|
-
if (senderMessageKey.iteration === iteration) result = senderMessageKey;
|
|
114
|
-
return senderMessageKey.iteration !== iteration;
|
|
115
|
-
}
|
|
116
|
-
);
|
|
117
|
-
|
|
118
|
-
if (result != null) {
|
|
119
|
-
return new SenderMessageKey(result.iteration, result.seed);
|
|
120
|
-
}
|
|
121
|
-
return null;
|
|
122
|
-
}
|
|
123
|
-
|
|
124
|
-
getStructure() {
|
|
125
|
-
return this.senderKeyStateStructure;
|
|
126
|
-
}
|
|
127
|
-
}
|
|
128
|
-
|
|
129
|
-
module.exports = SenderKeyState;
|
|
@@ -1,12 +0,0 @@
|
|
|
1
|
-
import type { Logger } from 'pino';
|
|
2
|
-
import type { AuthenticationState } from '../Types';
|
|
3
|
-
/**
|
|
4
|
-
* @deprecated use multi file auth state instead please
|
|
5
|
-
* stores the full authentication state in a single JSON file
|
|
6
|
-
*
|
|
7
|
-
* DO NOT USE IN A PROD ENVIRONMENT, only meant to serve as an example
|
|
8
|
-
* */
|
|
9
|
-
export declare const useSingleFileAuthState: (filename: string, logger?: Logger) => {
|
|
10
|
-
state: AuthenticationState;
|
|
11
|
-
saveState: () => void;
|
|
12
|
-
};
|
|
@@ -1,75 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.useSingleFileAuthState = void 0;
|
|
4
|
-
const WAProto_1 = require("../../WAProto");
|
|
5
|
-
const auth_utils_1 = require("./auth-utils");
|
|
6
|
-
const generics_1 = require("./generics");
|
|
7
|
-
// useless key map only there to maintain backwards compatibility
|
|
8
|
-
// do not use in your own systems please
|
|
9
|
-
const KEY_MAP = {
|
|
10
|
-
'pre-key': 'preKeys',
|
|
11
|
-
'session': 'sessions',
|
|
12
|
-
'sender-key': 'senderKeys',
|
|
13
|
-
'app-state-sync-key': 'appStateSyncKeys',
|
|
14
|
-
'app-state-sync-version': 'appStateVersions',
|
|
15
|
-
'sender-key-memory': 'senderKeyMemory'
|
|
16
|
-
};
|
|
17
|
-
/**
|
|
18
|
-
* @deprecated use multi file auth state instead please
|
|
19
|
-
* stores the full authentication state in a single JSON file
|
|
20
|
-
*
|
|
21
|
-
* DO NOT USE IN A PROD ENVIRONMENT, only meant to serve as an example
|
|
22
|
-
* */
|
|
23
|
-
const useSingleFileAuthState = (filename, logger) => {
|
|
24
|
-
// require fs here so that in case "fs" is not available -- the app does not crash
|
|
25
|
-
const { readFileSync, writeFileSync, existsSync } = require('fs');
|
|
26
|
-
let creds;
|
|
27
|
-
let keys = {};
|
|
28
|
-
// save the authentication state to a file
|
|
29
|
-
const saveState = () => {
|
|
30
|
-
logger && logger.trace('saving auth state');
|
|
31
|
-
writeFileSync(filename,
|
|
32
|
-
// BufferJSON replacer utility saves buffers nicely
|
|
33
|
-
JSON.stringify({ creds, keys }, generics_1.BufferJSON.replacer, 2));
|
|
34
|
-
};
|
|
35
|
-
if (existsSync(filename)) {
|
|
36
|
-
const result = JSON.parse(readFileSync(filename, { encoding: 'utf-8' }), generics_1.BufferJSON.reviver);
|
|
37
|
-
creds = result.creds;
|
|
38
|
-
keys = result.keys;
|
|
39
|
-
}
|
|
40
|
-
else {
|
|
41
|
-
creds = (0, auth_utils_1.initAuthCreds)();
|
|
42
|
-
keys = {};
|
|
43
|
-
}
|
|
44
|
-
return {
|
|
45
|
-
state: {
|
|
46
|
-
creds,
|
|
47
|
-
keys: {
|
|
48
|
-
get: (type, ids) => {
|
|
49
|
-
const key = KEY_MAP[type];
|
|
50
|
-
return ids.reduce((dict, id) => {
|
|
51
|
-
var _a;
|
|
52
|
-
let value = (_a = keys[key]) === null || _a === void 0 ? void 0 : _a[id];
|
|
53
|
-
if (value) {
|
|
54
|
-
if (type === 'app-state-sync-key') {
|
|
55
|
-
value = WAProto_1.proto.Message.AppStateSyncKeyData.fromObject(value);
|
|
56
|
-
}
|
|
57
|
-
dict[id] = value;
|
|
58
|
-
}
|
|
59
|
-
return dict;
|
|
60
|
-
}, {});
|
|
61
|
-
},
|
|
62
|
-
set: (data) => {
|
|
63
|
-
for (const _key in data) {
|
|
64
|
-
const key = KEY_MAP[_key];
|
|
65
|
-
keys[key] = keys[key] || {};
|
|
66
|
-
Object.assign(keys[key], data[_key]);
|
|
67
|
-
}
|
|
68
|
-
saveState();
|
|
69
|
-
}
|
|
70
|
-
}
|
|
71
|
-
},
|
|
72
|
-
saveState
|
|
73
|
-
};
|
|
74
|
-
};
|
|
75
|
-
exports.useSingleFileAuthState = useSingleFileAuthState;
|
package/src/Defaults/index.ts
DELETED
|
@@ -1,133 +0,0 @@
|
|
|
1
|
-
import { proto } from '../../WAProto/index.js'
|
|
2
|
-
import { makeLibSignalRepository } from '../Signal/libsignal'
|
|
3
|
-
import type { AuthenticationState, SocketConfig, WAVersion } from '../Types'
|
|
4
|
-
import { Browsers } from '../Utils/browser-utils'
|
|
5
|
-
import logger from '../Utils/logger'
|
|
6
|
-
|
|
7
|
-
const version = [2, 3000, 1027934701]
|
|
8
|
-
|
|
9
|
-
export const UNAUTHORIZED_CODES = [401, 403, 419]
|
|
10
|
-
|
|
11
|
-
export const DEFAULT_ORIGIN = 'https://web.whatsapp.com'
|
|
12
|
-
export const CALL_VIDEO_PREFIX = 'https://call.whatsapp.com/video/'
|
|
13
|
-
export const CALL_AUDIO_PREFIX = 'https://call.whatsapp.com/voice/'
|
|
14
|
-
export const DEF_CALLBACK_PREFIX = 'CB:'
|
|
15
|
-
export const DEF_TAG_PREFIX = 'TAG:'
|
|
16
|
-
export const PHONE_CONNECTION_CB = 'CB:Pong'
|
|
17
|
-
|
|
18
|
-
export const WA_ADV_ACCOUNT_SIG_PREFIX = Buffer.from([6, 0])
|
|
19
|
-
export const WA_ADV_DEVICE_SIG_PREFIX = Buffer.from([6, 1])
|
|
20
|
-
export const WA_ADV_HOSTED_ACCOUNT_SIG_PREFIX = Buffer.from([6, 5])
|
|
21
|
-
export const WA_ADV_HOSTED_DEVICE_SIG_PREFIX = Buffer.from([6, 6])
|
|
22
|
-
|
|
23
|
-
export const WA_DEFAULT_EPHEMERAL = 7 * 24 * 60 * 60
|
|
24
|
-
|
|
25
|
-
export const NOISE_MODE = 'Noise_XX_25519_AESGCM_SHA256\0\0\0\0'
|
|
26
|
-
export const DICT_VERSION = 3
|
|
27
|
-
export const KEY_BUNDLE_TYPE = Buffer.from([5])
|
|
28
|
-
export const NOISE_WA_HEADER = Buffer.from([87, 65, 6, DICT_VERSION]) // last is "DICT_VERSION"
|
|
29
|
-
/** from: https://stackoverflow.com/questions/3809401/what-is-a-good-regular-expression-to-match-a-url */
|
|
30
|
-
export const URL_REGEX = /https:\/\/(?![^:@\/\s]+:[^:@\/\s]+@)[a-zA-Z0-9.-]+\.[a-zA-Z]{2,}(:\d+)?(\/[^\s]*)?/g
|
|
31
|
-
|
|
32
|
-
// TODO: Add WA root CA
|
|
33
|
-
export const WA_CERT_DETAILS = {
|
|
34
|
-
SERIAL: 0
|
|
35
|
-
}
|
|
36
|
-
|
|
37
|
-
export const PROCESSABLE_HISTORY_TYPES = [
|
|
38
|
-
proto.HistorySync.HistorySyncType.INITIAL_BOOTSTRAP,
|
|
39
|
-
proto.HistorySync.HistorySyncType.PUSH_NAME,
|
|
40
|
-
proto.HistorySync.HistorySyncType.RECENT,
|
|
41
|
-
proto.HistorySync.HistorySyncType.FULL,
|
|
42
|
-
proto.HistorySync.HistorySyncType.ON_DEMAND,
|
|
43
|
-
proto.HistorySync.HistorySyncType.NON_BLOCKING_DATA,
|
|
44
|
-
proto.HistorySync.HistorySyncType.INITIAL_STATUS_V3
|
|
45
|
-
]
|
|
46
|
-
|
|
47
|
-
export const DEFAULT_CONNECTION_CONFIG: SocketConfig = {
|
|
48
|
-
version: version as WAVersion,
|
|
49
|
-
browser: Browsers.macOS('Chrome'),
|
|
50
|
-
waWebSocketUrl: 'wss://web.whatsapp.com/ws/chat',
|
|
51
|
-
connectTimeoutMs: 20_000,
|
|
52
|
-
keepAliveIntervalMs: 30_000,
|
|
53
|
-
logger: logger.child({ class: 'baileys' }),
|
|
54
|
-
emitOwnEvents: true,
|
|
55
|
-
defaultQueryTimeoutMs: 60_000,
|
|
56
|
-
customUploadHosts: [],
|
|
57
|
-
retryRequestDelayMs: 250,
|
|
58
|
-
maxMsgRetryCount: 5,
|
|
59
|
-
fireInitQueries: true,
|
|
60
|
-
auth: undefined as unknown as AuthenticationState,
|
|
61
|
-
markOnlineOnConnect: true,
|
|
62
|
-
syncFullHistory: true,
|
|
63
|
-
patchMessageBeforeSending: msg => msg,
|
|
64
|
-
shouldSyncHistoryMessage: () => true,
|
|
65
|
-
shouldIgnoreJid: () => false,
|
|
66
|
-
linkPreviewImageThumbnailWidth: 192,
|
|
67
|
-
transactionOpts: { maxCommitRetries: 10, delayBetweenTriesMs: 3000 },
|
|
68
|
-
generateHighQualityLinkPreview: false,
|
|
69
|
-
enableAutoSessionRecreation: true,
|
|
70
|
-
enableRecentMessageCache: true,
|
|
71
|
-
options: {},
|
|
72
|
-
appStateMacVerification: {
|
|
73
|
-
patch: false,
|
|
74
|
-
snapshot: false
|
|
75
|
-
},
|
|
76
|
-
countryCode: 'US',
|
|
77
|
-
getMessage: async () => undefined,
|
|
78
|
-
cachedGroupMetadata: async () => undefined,
|
|
79
|
-
makeSignalRepository: makeLibSignalRepository
|
|
80
|
-
}
|
|
81
|
-
|
|
82
|
-
export const MEDIA_PATH_MAP: { [T in MediaType]?: string } = {
|
|
83
|
-
image: '/mms/image',
|
|
84
|
-
video: '/mms/video',
|
|
85
|
-
document: '/mms/document',
|
|
86
|
-
audio: '/mms/audio',
|
|
87
|
-
sticker: '/mms/image',
|
|
88
|
-
'thumbnail-link': '/mms/image',
|
|
89
|
-
'product-catalog-image': '/product/image',
|
|
90
|
-
'md-app-state': '',
|
|
91
|
-
'md-msg-hist': '/mms/md-app-state',
|
|
92
|
-
'biz-cover-photo': '/pps/biz-cover-photo'
|
|
93
|
-
}
|
|
94
|
-
|
|
95
|
-
export const MEDIA_HKDF_KEY_MAPPING = {
|
|
96
|
-
audio: 'Audio',
|
|
97
|
-
document: 'Document',
|
|
98
|
-
gif: 'Video',
|
|
99
|
-
image: 'Image',
|
|
100
|
-
ppic: '',
|
|
101
|
-
product: 'Image',
|
|
102
|
-
ptt: 'Audio',
|
|
103
|
-
sticker: 'Image',
|
|
104
|
-
video: 'Video',
|
|
105
|
-
'thumbnail-document': 'Document Thumbnail',
|
|
106
|
-
'thumbnail-image': 'Image Thumbnail',
|
|
107
|
-
'thumbnail-video': 'Video Thumbnail',
|
|
108
|
-
'thumbnail-link': 'Link Thumbnail',
|
|
109
|
-
'md-msg-hist': 'History',
|
|
110
|
-
'md-app-state': 'App State',
|
|
111
|
-
'product-catalog-image': '',
|
|
112
|
-
'payment-bg-image': 'Payment Background',
|
|
113
|
-
ptv: 'Video',
|
|
114
|
-
'biz-cover-photo': 'Image'
|
|
115
|
-
}
|
|
116
|
-
|
|
117
|
-
export type MediaType = keyof typeof MEDIA_HKDF_KEY_MAPPING
|
|
118
|
-
|
|
119
|
-
export const MEDIA_KEYS = Object.keys(MEDIA_PATH_MAP) as MediaType[]
|
|
120
|
-
|
|
121
|
-
export const MIN_PREKEY_COUNT = 5
|
|
122
|
-
|
|
123
|
-
export const INITIAL_PREKEY_COUNT = 812
|
|
124
|
-
|
|
125
|
-
export const UPLOAD_TIMEOUT = 30000 // 30 seconds
|
|
126
|
-
export const MIN_UPLOAD_INTERVAL = 5000 // 5 seconds minimum between uploads
|
|
127
|
-
|
|
128
|
-
export const DEFAULT_CACHE_TTLS = {
|
|
129
|
-
SIGNAL_STORE: 5 * 60, // 5 minutes
|
|
130
|
-
MSG_RETRY: 60 * 60, // 1 hour
|
|
131
|
-
CALL_OFFER: 5 * 60, // 5 minutes
|
|
132
|
-
USER_DEVICES: 5 * 60 // 5 minutes
|
|
133
|
-
}
|
|
@@ -1,9 +0,0 @@
|
|
|
1
|
-
export class CiphertextMessage {
|
|
2
|
-
readonly UNSUPPORTED_VERSION: number = 1
|
|
3
|
-
readonly CURRENT_VERSION: number = 3
|
|
4
|
-
readonly WHISPER_TYPE: number = 2
|
|
5
|
-
readonly PREKEY_TYPE: number = 3
|
|
6
|
-
readonly SENDERKEY_TYPE: number = 4
|
|
7
|
-
readonly SENDERKEY_DISTRIBUTION_TYPE: number = 5
|
|
8
|
-
readonly ENCRYPTED_MESSAGE_OVERHEAD: number = 53
|
|
9
|
-
}
|
|
@@ -1,56 +0,0 @@
|
|
|
1
|
-
import * as keyhelper from './keyhelper'
|
|
2
|
-
import { SenderKeyDistributionMessage } from './sender-key-distribution-message'
|
|
3
|
-
import { SenderKeyName } from './sender-key-name'
|
|
4
|
-
import { SenderKeyRecord } from './sender-key-record'
|
|
5
|
-
|
|
6
|
-
interface SenderKeyStore {
|
|
7
|
-
loadSenderKey(senderKeyName: SenderKeyName): Promise<SenderKeyRecord>
|
|
8
|
-
storeSenderKey(senderKeyName: SenderKeyName, record: SenderKeyRecord): Promise<void>
|
|
9
|
-
}
|
|
10
|
-
|
|
11
|
-
export class GroupSessionBuilder {
|
|
12
|
-
private readonly senderKeyStore: SenderKeyStore
|
|
13
|
-
|
|
14
|
-
constructor(senderKeyStore: SenderKeyStore) {
|
|
15
|
-
this.senderKeyStore = senderKeyStore
|
|
16
|
-
}
|
|
17
|
-
|
|
18
|
-
public async process(
|
|
19
|
-
senderKeyName: SenderKeyName,
|
|
20
|
-
senderKeyDistributionMessage: SenderKeyDistributionMessage
|
|
21
|
-
): Promise<void> {
|
|
22
|
-
const senderKeyRecord = await this.senderKeyStore.loadSenderKey(senderKeyName)
|
|
23
|
-
senderKeyRecord.addSenderKeyState(
|
|
24
|
-
senderKeyDistributionMessage.getId(),
|
|
25
|
-
senderKeyDistributionMessage.getIteration(),
|
|
26
|
-
senderKeyDistributionMessage.getChainKey(),
|
|
27
|
-
senderKeyDistributionMessage.getSignatureKey()
|
|
28
|
-
)
|
|
29
|
-
await this.senderKeyStore.storeSenderKey(senderKeyName, senderKeyRecord)
|
|
30
|
-
}
|
|
31
|
-
|
|
32
|
-
public async create(senderKeyName: SenderKeyName): Promise<SenderKeyDistributionMessage> {
|
|
33
|
-
const senderKeyRecord = await this.senderKeyStore.loadSenderKey(senderKeyName)
|
|
34
|
-
|
|
35
|
-
if (senderKeyRecord.isEmpty()) {
|
|
36
|
-
const keyId = keyhelper.generateSenderKeyId()
|
|
37
|
-
const senderKey = keyhelper.generateSenderKey()
|
|
38
|
-
const signingKey = keyhelper.generateSenderSigningKey()
|
|
39
|
-
|
|
40
|
-
senderKeyRecord.setSenderKeyState(keyId, 0, senderKey, signingKey)
|
|
41
|
-
await this.senderKeyStore.storeSenderKey(senderKeyName, senderKeyRecord)
|
|
42
|
-
}
|
|
43
|
-
|
|
44
|
-
const state = senderKeyRecord.getSenderKeyState()
|
|
45
|
-
if (!state) {
|
|
46
|
-
throw new Error('No session state available')
|
|
47
|
-
}
|
|
48
|
-
|
|
49
|
-
return new SenderKeyDistributionMessage(
|
|
50
|
-
state.getKeyId(),
|
|
51
|
-
state.getSenderChainKey().getIteration(),
|
|
52
|
-
state.getSenderChainKey().getSeed(),
|
|
53
|
-
state.getSigningKeyPublic()
|
|
54
|
-
)
|
|
55
|
-
}
|
|
56
|
-
}
|
|
@@ -1,117 +0,0 @@
|
|
|
1
|
-
import { decrypt, encrypt } from 'libsignal/src/crypto'
|
|
2
|
-
import { SenderKeyMessage } from './sender-key-message'
|
|
3
|
-
import { SenderKeyName } from './sender-key-name'
|
|
4
|
-
import { SenderKeyRecord } from './sender-key-record'
|
|
5
|
-
import { SenderKeyState } from './sender-key-state'
|
|
6
|
-
|
|
7
|
-
export interface SenderKeyStore {
|
|
8
|
-
loadSenderKey(senderKeyName: SenderKeyName): Promise<SenderKeyRecord>
|
|
9
|
-
|
|
10
|
-
storeSenderKey(senderKeyName: SenderKeyName, record: SenderKeyRecord): Promise<void>
|
|
11
|
-
}
|
|
12
|
-
|
|
13
|
-
export class GroupCipher {
|
|
14
|
-
private readonly senderKeyStore: SenderKeyStore
|
|
15
|
-
private readonly senderKeyName: SenderKeyName
|
|
16
|
-
|
|
17
|
-
constructor(senderKeyStore: SenderKeyStore, senderKeyName: SenderKeyName) {
|
|
18
|
-
this.senderKeyStore = senderKeyStore
|
|
19
|
-
this.senderKeyName = senderKeyName
|
|
20
|
-
}
|
|
21
|
-
|
|
22
|
-
public async encrypt(paddedPlaintext: Uint8Array): Promise<Uint8Array> {
|
|
23
|
-
const record = await this.senderKeyStore.loadSenderKey(this.senderKeyName)
|
|
24
|
-
if (!record) {
|
|
25
|
-
throw new Error('No SenderKeyRecord found for encryption')
|
|
26
|
-
}
|
|
27
|
-
|
|
28
|
-
const senderKeyState = record.getSenderKeyState()
|
|
29
|
-
if (!senderKeyState) {
|
|
30
|
-
throw new Error('No session to encrypt message')
|
|
31
|
-
}
|
|
32
|
-
|
|
33
|
-
const iteration = senderKeyState.getSenderChainKey().getIteration()
|
|
34
|
-
const senderKey = this.getSenderKey(senderKeyState, iteration === 0 ? 0 : iteration + 1)
|
|
35
|
-
|
|
36
|
-
const ciphertext = await this.getCipherText(senderKey.getIv(), senderKey.getCipherKey(), paddedPlaintext)
|
|
37
|
-
|
|
38
|
-
const senderKeyMessage = new SenderKeyMessage(
|
|
39
|
-
senderKeyState.getKeyId(),
|
|
40
|
-
senderKey.getIteration(),
|
|
41
|
-
ciphertext,
|
|
42
|
-
senderKeyState.getSigningKeyPrivate()
|
|
43
|
-
)
|
|
44
|
-
|
|
45
|
-
await this.senderKeyStore.storeSenderKey(this.senderKeyName, record)
|
|
46
|
-
return senderKeyMessage.serialize()
|
|
47
|
-
}
|
|
48
|
-
|
|
49
|
-
public async decrypt(senderKeyMessageBytes: Uint8Array): Promise<Uint8Array> {
|
|
50
|
-
const record = await this.senderKeyStore.loadSenderKey(this.senderKeyName)
|
|
51
|
-
if (!record) {
|
|
52
|
-
throw new Error('No SenderKeyRecord found for decryption')
|
|
53
|
-
}
|
|
54
|
-
|
|
55
|
-
const senderKeyMessage = new SenderKeyMessage(null, null, null, null, senderKeyMessageBytes)
|
|
56
|
-
const senderKeyState = record.getSenderKeyState(senderKeyMessage.getKeyId())
|
|
57
|
-
if (!senderKeyState) {
|
|
58
|
-
throw new Error('No session found to decrypt message')
|
|
59
|
-
}
|
|
60
|
-
|
|
61
|
-
senderKeyMessage.verifySignature(senderKeyState.getSigningKeyPublic())
|
|
62
|
-
const senderKey = this.getSenderKey(senderKeyState, senderKeyMessage.getIteration())
|
|
63
|
-
|
|
64
|
-
const plaintext = await this.getPlainText(
|
|
65
|
-
senderKey.getIv(),
|
|
66
|
-
senderKey.getCipherKey(),
|
|
67
|
-
senderKeyMessage.getCipherText()
|
|
68
|
-
)
|
|
69
|
-
|
|
70
|
-
await this.senderKeyStore.storeSenderKey(this.senderKeyName, record)
|
|
71
|
-
return plaintext
|
|
72
|
-
}
|
|
73
|
-
|
|
74
|
-
private getSenderKey(senderKeyState: SenderKeyState, iteration: number) {
|
|
75
|
-
let senderChainKey = senderKeyState.getSenderChainKey()
|
|
76
|
-
if (senderChainKey.getIteration() > iteration) {
|
|
77
|
-
if (senderKeyState.hasSenderMessageKey(iteration)) {
|
|
78
|
-
const messageKey = senderKeyState.removeSenderMessageKey(iteration)
|
|
79
|
-
if (!messageKey) {
|
|
80
|
-
throw new Error('No sender message key found for iteration')
|
|
81
|
-
}
|
|
82
|
-
|
|
83
|
-
return messageKey
|
|
84
|
-
}
|
|
85
|
-
|
|
86
|
-
throw new Error(`Received message with old counter: ${senderChainKey.getIteration()}, ${iteration}`)
|
|
87
|
-
}
|
|
88
|
-
|
|
89
|
-
if (iteration - senderChainKey.getIteration() > 2000) {
|
|
90
|
-
throw new Error('Over 2000 messages into the future!')
|
|
91
|
-
}
|
|
92
|
-
|
|
93
|
-
while (senderChainKey.getIteration() < iteration) {
|
|
94
|
-
senderKeyState.addSenderMessageKey(senderChainKey.getSenderMessageKey())
|
|
95
|
-
senderChainKey = senderChainKey.getNext()
|
|
96
|
-
}
|
|
97
|
-
|
|
98
|
-
senderKeyState.setSenderChainKey(senderChainKey.getNext())
|
|
99
|
-
return senderChainKey.getSenderMessageKey()
|
|
100
|
-
}
|
|
101
|
-
|
|
102
|
-
private async getPlainText(iv: Uint8Array, key: Uint8Array, ciphertext: Uint8Array): Promise<Uint8Array> {
|
|
103
|
-
try {
|
|
104
|
-
return decrypt(key, ciphertext, iv)
|
|
105
|
-
} catch (e) {
|
|
106
|
-
throw new Error('InvalidMessageException')
|
|
107
|
-
}
|
|
108
|
-
}
|
|
109
|
-
|
|
110
|
-
private async getCipherText(iv: Uint8Array, key: Uint8Array, plaintext: Uint8Array): Promise<Buffer> {
|
|
111
|
-
try {
|
|
112
|
-
return encrypt(key, plaintext, iv)
|
|
113
|
-
} catch (e) {
|
|
114
|
-
throw new Error('InvalidMessageException')
|
|
115
|
-
}
|
|
116
|
-
}
|
|
117
|
-
}
|
|
@@ -1,11 +0,0 @@
|
|
|
1
|
-
export { GroupSessionBuilder } from './group-session-builder'
|
|
2
|
-
export { SenderKeyDistributionMessage } from './sender-key-distribution-message'
|
|
3
|
-
export { SenderKeyRecord } from './sender-key-record'
|
|
4
|
-
export { SenderKeyName } from './sender-key-name'
|
|
5
|
-
export { GroupCipher } from './group_cipher'
|
|
6
|
-
export { SenderKeyState } from './sender-key-state'
|
|
7
|
-
export { SenderKeyMessage } from './sender-key-message'
|
|
8
|
-
export { SenderMessageKey } from './sender-message-key'
|
|
9
|
-
export { SenderChainKey } from './sender-chain-key'
|
|
10
|
-
export { CiphertextMessage } from './ciphertext-message'
|
|
11
|
-
export * as keyhelper from './keyhelper'
|
|
@@ -1,28 +0,0 @@
|
|
|
1
|
-
import * as nodeCrypto from 'crypto'
|
|
2
|
-
import { generateKeyPair } from 'libsignal/src/curve'
|
|
3
|
-
|
|
4
|
-
type KeyPairType = ReturnType<typeof generateKeyPair>
|
|
5
|
-
|
|
6
|
-
export function generateSenderKey(): Buffer {
|
|
7
|
-
return nodeCrypto.randomBytes(32)
|
|
8
|
-
}
|
|
9
|
-
|
|
10
|
-
export function generateSenderKeyId(): number {
|
|
11
|
-
return nodeCrypto.randomInt(2147483647)
|
|
12
|
-
}
|
|
13
|
-
|
|
14
|
-
export interface SigningKeyPair {
|
|
15
|
-
public: Buffer
|
|
16
|
-
private: Buffer
|
|
17
|
-
}
|
|
18
|
-
|
|
19
|
-
export function generateSenderSigningKey(key?: KeyPairType): SigningKeyPair {
|
|
20
|
-
if (!key) {
|
|
21
|
-
key = generateKeyPair()
|
|
22
|
-
}
|
|
23
|
-
|
|
24
|
-
return {
|
|
25
|
-
public: Buffer.from(key.pubKey),
|
|
26
|
-
private: Buffer.from(key.privKey)
|
|
27
|
-
}
|
|
28
|
-
}
|
|
@@ -1,34 +0,0 @@
|
|
|
1
|
-
import { calculateMAC } from 'libsignal/src/crypto'
|
|
2
|
-
import { SenderMessageKey } from './sender-message-key'
|
|
3
|
-
|
|
4
|
-
export class SenderChainKey {
|
|
5
|
-
private readonly MESSAGE_KEY_SEED: Uint8Array = Buffer.from([0x01])
|
|
6
|
-
private readonly CHAIN_KEY_SEED: Uint8Array = Buffer.from([0x02])
|
|
7
|
-
private readonly iteration: number
|
|
8
|
-
private readonly chainKey: Buffer
|
|
9
|
-
|
|
10
|
-
constructor(iteration: number, chainKey: Uint8Array | Buffer) {
|
|
11
|
-
this.iteration = iteration
|
|
12
|
-
this.chainKey = Buffer.from(chainKey)
|
|
13
|
-
}
|
|
14
|
-
|
|
15
|
-
public getIteration(): number {
|
|
16
|
-
return this.iteration
|
|
17
|
-
}
|
|
18
|
-
|
|
19
|
-
public getSenderMessageKey(): SenderMessageKey {
|
|
20
|
-
return new SenderMessageKey(this.iteration, this.getDerivative(this.MESSAGE_KEY_SEED, this.chainKey))
|
|
21
|
-
}
|
|
22
|
-
|
|
23
|
-
public getNext(): SenderChainKey {
|
|
24
|
-
return new SenderChainKey(this.iteration + 1, this.getDerivative(this.CHAIN_KEY_SEED, this.chainKey))
|
|
25
|
-
}
|
|
26
|
-
|
|
27
|
-
public getSeed(): Uint8Array {
|
|
28
|
-
return this.chainKey
|
|
29
|
-
}
|
|
30
|
-
|
|
31
|
-
private getDerivative(seed: Uint8Array, key: Buffer): Uint8Array {
|
|
32
|
-
return calculateMAC(key, seed)
|
|
33
|
-
}
|
|
34
|
-
}
|