supunmd-bail 2.0.2 → 2.1.3
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/LICENSE +1 -1
- package/README.md +2 -2
- package/WAProto/index.js +130529 -45236
- package/engine-requirements.js +1 -1
- package/lib/Defaults/baileys-version.json +1 -1
- package/lib/Defaults/index.d.ts +9 -18
- package/lib/Defaults/index.js +136 -104
- package/lib/Defaults/phonenumber-mcc.json +223 -0
- package/lib/Signal/Group/ciphertext-message.d.ts +0 -1
- package/lib/Signal/Group/ciphertext-message.js +5 -2
- package/lib/Signal/Group/group-session-builder.d.ts +3 -4
- package/lib/Signal/Group/group-session-builder.js +41 -7
- package/lib/Signal/Group/group_cipher.d.ts +4 -4
- package/lib/Signal/Group/group_cipher.js +51 -37
- package/lib/Signal/Group/index.d.ts +11 -12
- package/lib/Signal/Group/index.js +57 -12
- package/lib/Signal/Group/keyhelper.d.ts +1 -2
- package/lib/Signal/Group/keyhelper.js +44 -7
- package/lib/Signal/Group/queue-job.d.ts +0 -1
- package/lib/Signal/Group/queue-job.js +5 -2
- package/lib/Signal/Group/sender-chain-key.d.ts +2 -3
- package/lib/Signal/Group/sender-chain-key.js +15 -7
- package/lib/Signal/Group/sender-key-distribution-message.d.ts +1 -2
- package/lib/Signal/Group/sender-key-distribution-message.js +11 -8
- package/lib/Signal/Group/sender-key-message.d.ts +1 -2
- package/lib/Signal/Group/sender-key-message.js +12 -9
- package/lib/Signal/Group/sender-key-name.d.ts +0 -1
- package/lib/Signal/Group/sender-key-name.js +5 -2
- package/lib/Signal/Group/sender-key-record.d.ts +2 -3
- package/lib/Signal/Group/sender-key-record.js +21 -9
- package/lib/Signal/Group/sender-key-state.d.ts +6 -7
- package/lib/Signal/Group/sender-key-state.js +42 -27
- package/lib/Signal/Group/sender-message-key.d.ts +0 -1
- package/lib/Signal/Group/sender-message-key.js +7 -4
- package/lib/Signal/libsignal.d.ts +3 -5
- package/lib/Signal/libsignal.js +90 -258
- package/lib/Socket/Client/{types.d.ts → abstract-socket-client.d.ts} +3 -2
- package/lib/Socket/Client/abstract-socket-client.js +13 -0
- package/lib/Socket/Client/index.d.ts +3 -3
- package/lib/Socket/Client/index.js +19 -3
- package/lib/Socket/Client/mobile-socket-client.d.ts +13 -0
- package/lib/Socket/Client/mobile-socket-client.js +65 -0
- package/lib/Socket/Client/{websocket.d.ts → web-socket-client.d.ts} +1 -2
- package/lib/Socket/Client/web-socket-client.js +62 -0
- package/lib/Socket/business.d.ts +108 -125
- package/lib/Socket/business.js +43 -159
- package/lib/Socket/chats.d.ts +239 -70
- package/lib/Socket/chats.js +384 -363
- package/lib/Socket/dugong.d.ts +254 -0
- package/lib/Socket/dugong.js +484 -0
- package/lib/Socket/groups.d.ts +56 -78
- package/lib/Socket/groups.js +96 -106
- package/lib/Socket/index.d.ts +115 -173
- package/lib/Socket/index.js +10 -17
- package/lib/Socket/messages-recv.d.ts +79 -91
- package/lib/Socket/messages-recv.js +521 -639
- package/lib/Socket/messages-send.d.ts +91 -111
- package/lib/Socket/messages-send.js +438 -599
- package/lib/Socket/newsletter.d.ts +84 -97
- package/lib/Socket/newsletter.js +1 -181
- package/lib/Socket/registration.d.ts +267 -0
- package/lib/Socket/registration.js +166 -0
- package/lib/Socket/socket.d.ts +18 -26
- package/lib/Socket/socket.js +230 -448
- package/lib/Socket/usync.d.ts +16 -17
- package/lib/Socket/usync.js +26 -19
- package/lib/Store/index.d.ts +3 -0
- package/lib/Store/index.js +10 -0
- package/lib/Store/make-cache-manager-store.d.ts +13 -0
- package/lib/Store/make-cache-manager-store.js +83 -0
- package/lib/Store/make-in-memory-store.d.ts +118 -0
- package/lib/Store/make-in-memory-store.js +427 -0
- package/lib/Store/make-ordered-dictionary.d.ts +13 -0
- package/lib/Store/make-ordered-dictionary.js +81 -0
- package/lib/Store/object-repository.d.ts +10 -0
- package/lib/Store/object-repository.js +27 -0
- package/lib/Types/Auth.d.ts +12 -13
- package/lib/Types/Auth.js +2 -2
- package/lib/Types/Call.d.ts +1 -2
- package/lib/Types/Call.js +2 -2
- package/lib/Types/Chat.d.ts +13 -34
- package/lib/Types/Chat.js +4 -8
- package/lib/Types/Contact.d.ts +1 -6
- package/lib/Types/Contact.js +2 -2
- package/lib/Types/Events.d.ts +15 -60
- package/lib/Types/Events.js +2 -2
- package/lib/Types/GroupMetadata.d.ts +5 -17
- package/lib/Types/GroupMetadata.js +2 -2
- package/lib/Types/Label.d.ts +0 -12
- package/lib/Types/Label.js +5 -3
- package/lib/Types/LabelAssociation.d.ts +0 -1
- package/lib/Types/LabelAssociation.js +5 -3
- package/lib/Types/Message.d.ts +54 -84
- package/lib/Types/Message.js +9 -11
- package/lib/Types/Newsletter.d.ts +98 -130
- package/lib/Types/Newsletter.js +38 -31
- package/lib/Types/Product.d.ts +1 -2
- package/lib/Types/Product.js +2 -2
- package/lib/Types/Signal.d.ts +1 -20
- package/lib/Types/Signal.js +2 -2
- package/lib/Types/Socket.d.ts +25 -47
- package/lib/Types/Socket.js +2 -3
- package/lib/Types/State.d.ts +2 -14
- package/lib/Types/State.js +2 -13
- package/lib/Types/USync.d.ts +2 -3
- package/lib/Types/USync.js +2 -2
- package/lib/Types/index.d.ts +14 -22
- package/lib/Types/index.js +31 -15
- package/lib/Utils/auth-utils.d.ts +6 -7
- package/lib/Utils/auth-utils.js +148 -199
- package/lib/Utils/baileys-event-stream.d.ts +1 -2
- package/lib/Utils/baileys-event-stream.js +22 -15
- package/lib/Utils/business.d.ts +2 -3
- package/lib/Utils/business.js +69 -66
- package/lib/Utils/chat-utils.d.ts +22 -21
- package/lib/Utils/chat-utils.js +226 -260
- package/lib/Utils/crypto.d.ts +19 -19
- package/lib/Utils/crypto.js +86 -77
- package/lib/Utils/decode-wa-message.d.ts +8 -37
- package/lib/Utils/decode-wa-message.js +83 -164
- package/lib/Utils/event-buffer.d.ts +8 -7
- package/lib/Utils/event-buffer.js +76 -110
- package/lib/Utils/generics.d.ts +29 -27
- package/lib/Utils/generics.js +210 -168
- package/lib/Utils/history.d.ts +8 -12
- package/lib/Utils/history.js +46 -34
- package/lib/Utils/index.d.ts +17 -20
- package/lib/Utils/index.js +33 -20
- package/lib/Utils/link-preview.d.ts +5 -5
- package/lib/Utils/link-preview.js +22 -14
- package/lib/Utils/logger.d.ts +3 -11
- package/lib/Utils/logger.js +7 -3
- package/lib/Utils/lt-hash.d.ts +8 -9
- package/lib/Utils/lt-hash.js +28 -25
- package/lib/Utils/make-mutex.d.ts +2 -3
- package/lib/Utils/make-mutex.js +10 -7
- package/lib/Utils/messages-media.d.ts +44 -42
- package/lib/Utils/messages-media.js +475 -319
- package/lib/Utils/messages.d.ts +18 -17
- package/lib/Utils/messages.js +259 -383
- package/lib/Utils/noise-handler.d.ts +15 -14
- package/lib/Utils/noise-handler.js +38 -30
- package/lib/Utils/process-message.d.ts +13 -14
- package/lib/Utils/process-message.js +147 -239
- package/lib/Utils/signal.d.ts +5 -7
- package/lib/Utils/signal.js +72 -78
- package/lib/Utils/use-multi-file-auth-state.d.ts +2 -2
- package/lib/Utils/use-multi-file-auth-state.js +27 -29
- package/lib/Utils/validate-connection.d.ts +7 -7
- package/lib/Utils/validate-connection.js +106 -72
- package/lib/WABinary/constants.d.ts +27 -25
- package/lib/WABinary/constants.js +20 -1281
- package/lib/WABinary/decode.d.ts +5 -5
- package/lib/WABinary/decode.js +42 -28
- package/lib/WABinary/encode.d.ts +3 -3
- package/lib/WABinary/encode.js +154 -105
- package/lib/WABinary/generic-utils.d.ts +7 -5
- package/lib/WABinary/generic-utils.js +63 -56
- package/lib/WABinary/index.d.ts +5 -6
- package/lib/WABinary/index.js +21 -6
- package/lib/WABinary/jid-utils.d.ts +8 -25
- package/lib/WABinary/jid-utils.js +40 -74
- package/lib/WABinary/types.d.ts +1 -2
- package/lib/WABinary/types.js +2 -2
- package/lib/WAM/BinaryInfo.d.ts +11 -3
- package/lib/WAM/BinaryInfo.js +5 -2
- package/lib/WAM/constants.d.ts +3 -5
- package/lib/WAM/constants.js +11958 -19461
- package/lib/WAM/encode.d.ts +3 -3
- package/lib/WAM/encode.js +22 -17
- package/lib/WAM/index.d.ts +3 -4
- package/lib/WAM/index.js +19 -4
- package/lib/WAUSync/Protocols/USyncContactProtocol.d.ts +3 -4
- package/lib/WAUSync/Protocols/USyncContactProtocol.js +11 -8
- package/lib/WAUSync/Protocols/USyncDeviceProtocol.d.ts +2 -3
- package/lib/WAUSync/Protocols/USyncDeviceProtocol.js +14 -11
- package/lib/WAUSync/Protocols/USyncDisappearingModeProtocol.d.ts +2 -3
- package/lib/WAUSync/Protocols/USyncDisappearingModeProtocol.js +12 -9
- package/lib/WAUSync/Protocols/USyncStatusProtocol.d.ts +2 -3
- package/lib/WAUSync/Protocols/USyncStatusProtocol.js +13 -9
- package/lib/WAUSync/Protocols/UsyncBotProfileProtocol.d.ts +3 -4
- package/lib/WAUSync/Protocols/UsyncBotProfileProtocol.js +22 -20
- package/lib/WAUSync/Protocols/UsyncLIDProtocol.d.ts +3 -5
- package/lib/WAUSync/Protocols/UsyncLIDProtocol.js +8 -13
- package/lib/WAUSync/Protocols/index.d.ts +4 -5
- package/lib/WAUSync/Protocols/index.js +20 -5
- package/lib/WAUSync/USyncQuery.d.ts +4 -5
- package/lib/WAUSync/USyncQuery.js +35 -40
- package/lib/WAUSync/USyncUser.d.ts +5 -6
- package/lib/WAUSync/USyncUser.js +5 -2
- package/lib/WAUSync/index.d.ts +3 -4
- package/lib/WAUSync/index.js +19 -4
- package/lib/index.d.ts +9 -19
- package/lib/index.js +1 -36
- package/package.json +109 -103
- package/WAProto/GenerateStatics.sh +0 -3
- package/WAProto/WAProto.proto +0 -5519
- package/WAProto/fix-imports.js +0 -29
- package/WAProto/index.d.ts +0 -11969
- package/lib/Signal/lid-mapping.d.ts +0 -23
- package/lib/Signal/lid-mapping.js +0 -171
- package/lib/Socket/Client/types.js +0 -11
- package/lib/Socket/Client/websocket.js +0 -50
- package/lib/Socket/communities.d.ts +0 -244
- package/lib/Socket/communities.js +0 -431
- package/lib/Socket/mex.d.ts +0 -3
- package/lib/Socket/mex.js +0 -42
- package/lib/Types/Bussines.d.ts +0 -25
- package/lib/Types/Bussines.js +0 -2
- package/lib/Utils/browser-utils.d.ts +0 -4
- package/lib/Utils/browser-utils.js +0 -28
- package/lib/Utils/message-retry-manager.d.ts +0 -82
- package/lib/Utils/message-retry-manager.js +0 -149
- package/lib/Utils/pre-key-manager.d.ts +0 -28
- package/lib/Utils/pre-key-manager.js +0 -106
- /package/lib/{supun → supunmd} +0 -0
|
@@ -1,44 +1,55 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.GroupCipher = void 0;
|
|
7
|
+
const crypto_1 = require("libsignal/src/crypto");
|
|
8
|
+
const queue_job_1 = __importDefault(require("./queue-job"));
|
|
9
|
+
const sender_key_message_1 = require("./sender-key-message");
|
|
10
|
+
class GroupCipher {
|
|
7
11
|
constructor(senderKeyStore, senderKeyName) {
|
|
8
12
|
this.senderKeyStore = senderKeyStore;
|
|
9
13
|
this.senderKeyName = senderKeyName;
|
|
10
14
|
}
|
|
15
|
+
queueJob(awaitable) {
|
|
16
|
+
return (0, queue_job_1.default)(this.senderKeyName.toString(), awaitable);
|
|
17
|
+
}
|
|
11
18
|
async encrypt(paddedPlaintext) {
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
19
|
+
return await this.queueJob(async () => {
|
|
20
|
+
const record = await this.senderKeyStore.loadSenderKey(this.senderKeyName);
|
|
21
|
+
if (!record) {
|
|
22
|
+
throw new Error('No SenderKeyRecord found for encryption');
|
|
23
|
+
}
|
|
24
|
+
const senderKeyState = record.getSenderKeyState();
|
|
25
|
+
if (!senderKeyState) {
|
|
26
|
+
throw new Error('No session to encrypt message');
|
|
27
|
+
}
|
|
28
|
+
const iteration = senderKeyState.getSenderChainKey().getIteration();
|
|
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
|
+
});
|
|
26
35
|
}
|
|
27
36
|
async decrypt(senderKeyMessageBytes) {
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
37
|
+
return await this.queueJob(async () => {
|
|
38
|
+
const record = await this.senderKeyStore.loadSenderKey(this.senderKeyName);
|
|
39
|
+
if (!record) {
|
|
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
|
+
});
|
|
42
53
|
}
|
|
43
54
|
getSenderKey(senderKeyState, iteration) {
|
|
44
55
|
let senderChainKey = senderKeyState.getSenderChainKey();
|
|
@@ -64,7 +75,7 @@ export class GroupCipher {
|
|
|
64
75
|
}
|
|
65
76
|
async getPlainText(iv, key, ciphertext) {
|
|
66
77
|
try {
|
|
67
|
-
return decrypt(key, ciphertext, iv);
|
|
78
|
+
return (0, crypto_1.decrypt)(key, ciphertext, iv);
|
|
68
79
|
}
|
|
69
80
|
catch (e) {
|
|
70
81
|
throw new Error('InvalidMessageException');
|
|
@@ -72,11 +83,14 @@ export class GroupCipher {
|
|
|
72
83
|
}
|
|
73
84
|
async getCipherText(iv, key, plaintext) {
|
|
74
85
|
try {
|
|
75
|
-
|
|
86
|
+
const ivBuffer = typeof iv === 'string' ? Buffer.from(iv, 'base64') : iv;
|
|
87
|
+
const keyBuffer = typeof key === 'string' ? Buffer.from(key, 'base64') : key;
|
|
88
|
+
const plaintextBuffer = typeof plaintext === 'string' ? Buffer.from(plaintext) : plaintext;
|
|
89
|
+
return (0, crypto_1.encrypt)(keyBuffer, plaintextBuffer, ivBuffer);
|
|
76
90
|
}
|
|
77
91
|
catch (e) {
|
|
78
92
|
throw new Error('InvalidMessageException');
|
|
79
93
|
}
|
|
80
94
|
}
|
|
81
95
|
}
|
|
82
|
-
|
|
96
|
+
exports.GroupCipher = GroupCipher;
|
|
@@ -1,12 +1,11 @@
|
|
|
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
|
|
12
|
-
//# sourceMappingURL=index.d.ts.map
|
|
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,12 +1,57 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
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;
|
|
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,4 +1,4 @@
|
|
|
1
|
-
import { generateKeyPair } from 'libsignal/src/curve
|
|
1
|
+
import { generateKeyPair } from 'libsignal/src/curve';
|
|
2
2
|
type KeyPairType = ReturnType<typeof generateKeyPair>;
|
|
3
3
|
export declare function generateSenderKey(): Buffer;
|
|
4
4
|
export declare function generateSenderKeyId(): number;
|
|
@@ -8,4 +8,3 @@ export interface SigningKeyPair {
|
|
|
8
8
|
}
|
|
9
9
|
export declare function generateSenderSigningKey(key?: KeyPairType): SigningKeyPair;
|
|
10
10
|
export {};
|
|
11
|
-
//# sourceMappingURL=keyhelper.d.ts.map
|
|
@@ -1,18 +1,55 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
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;
|
|
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() {
|
|
4
42
|
return nodeCrypto.randomBytes(32);
|
|
5
43
|
}
|
|
6
|
-
|
|
44
|
+
function generateSenderKeyId() {
|
|
7
45
|
return nodeCrypto.randomInt(2147483647);
|
|
8
46
|
}
|
|
9
|
-
|
|
47
|
+
function generateSenderSigningKey(key) {
|
|
10
48
|
if (!key) {
|
|
11
|
-
key = generateKeyPair();
|
|
49
|
+
key = (0, curve_1.generateKeyPair)();
|
|
12
50
|
}
|
|
13
51
|
return {
|
|
14
52
|
public: Buffer.from(key.pubKey),
|
|
15
53
|
private: Buffer.from(key.privKey)
|
|
16
54
|
};
|
|
17
55
|
}
|
|
18
|
-
//# sourceMappingURL=keyhelper.js.map
|
|
@@ -1,7 +1,11 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.default = queueJob;
|
|
1
4
|
const _queueAsyncBuckets = new Map();
|
|
2
5
|
const _gcLimit = 10000;
|
|
3
6
|
async function _asyncQueueExecutor(queue, cleanup) {
|
|
4
7
|
let offt = 0;
|
|
8
|
+
// eslint-disable-next-line no-constant-condition
|
|
5
9
|
while (true) {
|
|
6
10
|
const limit = Math.min(queue.length, _gcLimit);
|
|
7
11
|
for (let i = offt; i < limit; i++) {
|
|
@@ -28,7 +32,7 @@ async function _asyncQueueExecutor(queue, cleanup) {
|
|
|
28
32
|
}
|
|
29
33
|
cleanup();
|
|
30
34
|
}
|
|
31
|
-
|
|
35
|
+
function queueJob(bucket, awaitable) {
|
|
32
36
|
// Skip name assignment since it's readonly in strict mode
|
|
33
37
|
if (typeof bucket !== 'string') {
|
|
34
38
|
console.warn('Unhandled bucket type (for naming):', typeof bucket, bucket);
|
|
@@ -51,4 +55,3 @@ export default function queueJob(bucket, awaitable) {
|
|
|
51
55
|
}
|
|
52
56
|
return job;
|
|
53
57
|
}
|
|
54
|
-
//# sourceMappingURL=queue-job.js.map
|
|
@@ -1,14 +1,13 @@
|
|
|
1
|
-
import { SenderMessageKey } from './sender-message-key
|
|
1
|
+
import { SenderMessageKey } from './sender-message-key';
|
|
2
2
|
export declare class SenderChainKey {
|
|
3
3
|
private readonly MESSAGE_KEY_SEED;
|
|
4
4
|
private readonly CHAIN_KEY_SEED;
|
|
5
5
|
private readonly iteration;
|
|
6
6
|
private readonly chainKey;
|
|
7
|
-
constructor(iteration: number, chainKey:
|
|
7
|
+
constructor(iteration: number, chainKey: any);
|
|
8
8
|
getIteration(): number;
|
|
9
9
|
getSenderMessageKey(): SenderMessageKey;
|
|
10
10
|
getNext(): SenderChainKey;
|
|
11
11
|
getSeed(): Uint8Array;
|
|
12
12
|
private getDerivative;
|
|
13
13
|
}
|
|
14
|
-
//# sourceMappingURL=sender-chain-key.d.ts.map
|
|
@@ -1,17 +1,25 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.SenderChainKey = void 0;
|
|
4
|
+
const crypto_1 = require("libsignal/src/crypto");
|
|
5
|
+
const sender_message_key_1 = require("./sender-message-key");
|
|
6
|
+
class SenderChainKey {
|
|
4
7
|
constructor(iteration, chainKey) {
|
|
5
8
|
this.MESSAGE_KEY_SEED = Buffer.from([0x01]);
|
|
6
9
|
this.CHAIN_KEY_SEED = Buffer.from([0x02]);
|
|
7
10
|
this.iteration = iteration;
|
|
8
|
-
|
|
11
|
+
if (chainKey instanceof Buffer) {
|
|
12
|
+
this.chainKey = chainKey;
|
|
13
|
+
}
|
|
14
|
+
else {
|
|
15
|
+
this.chainKey = Buffer.from(chainKey || []);
|
|
16
|
+
}
|
|
9
17
|
}
|
|
10
18
|
getIteration() {
|
|
11
19
|
return this.iteration;
|
|
12
20
|
}
|
|
13
21
|
getSenderMessageKey() {
|
|
14
|
-
return new SenderMessageKey(this.iteration, this.getDerivative(this.MESSAGE_KEY_SEED, this.chainKey));
|
|
22
|
+
return new sender_message_key_1.SenderMessageKey(this.iteration, this.getDerivative(this.MESSAGE_KEY_SEED, this.chainKey));
|
|
15
23
|
}
|
|
16
24
|
getNext() {
|
|
17
25
|
return new SenderChainKey(this.iteration + 1, this.getDerivative(this.CHAIN_KEY_SEED, this.chainKey));
|
|
@@ -20,7 +28,7 @@ export class SenderChainKey {
|
|
|
20
28
|
return this.chainKey;
|
|
21
29
|
}
|
|
22
30
|
getDerivative(seed, key) {
|
|
23
|
-
return calculateMAC(key, seed);
|
|
31
|
+
return (0, crypto_1.calculateMAC)(key, seed);
|
|
24
32
|
}
|
|
25
33
|
}
|
|
26
|
-
|
|
34
|
+
exports.SenderChainKey = SenderChainKey;
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { CiphertextMessage } from './ciphertext-message
|
|
1
|
+
import { CiphertextMessage } from './ciphertext-message';
|
|
2
2
|
export declare class SenderKeyDistributionMessage extends CiphertextMessage {
|
|
3
3
|
private readonly id;
|
|
4
4
|
private readonly iteration;
|
|
@@ -14,4 +14,3 @@ export declare class SenderKeyDistributionMessage extends CiphertextMessage {
|
|
|
14
14
|
getSignatureKey(): Uint8Array;
|
|
15
15
|
getId(): number;
|
|
16
16
|
}
|
|
17
|
-
//# sourceMappingURL=sender-key-distribution-message.d.ts.map
|
|
@@ -1,12 +1,15 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.SenderKeyDistributionMessage = void 0;
|
|
4
|
+
const WAProto_1 = require("../../../WAProto");
|
|
5
|
+
const ciphertext_message_1 = require("./ciphertext-message");
|
|
6
|
+
class SenderKeyDistributionMessage extends ciphertext_message_1.CiphertextMessage {
|
|
4
7
|
constructor(id, iteration, chainKey, signatureKey, serialized) {
|
|
5
8
|
super();
|
|
6
9
|
if (serialized) {
|
|
7
10
|
try {
|
|
8
11
|
const message = serialized.slice(1);
|
|
9
|
-
const distributionMessage = proto.SenderKeyDistributionMessage.decode(message).toJSON();
|
|
12
|
+
const distributionMessage = WAProto_1.proto.SenderKeyDistributionMessage.decode(message).toJSON();
|
|
10
13
|
this.serialized = serialized;
|
|
11
14
|
this.id = distributionMessage.id;
|
|
12
15
|
this.iteration = distributionMessage.iteration;
|
|
@@ -29,7 +32,7 @@ export class SenderKeyDistributionMessage extends CiphertextMessage {
|
|
|
29
32
|
this.iteration = iteration;
|
|
30
33
|
this.chainKey = chainKey;
|
|
31
34
|
this.signatureKey = signatureKey;
|
|
32
|
-
const message = proto.SenderKeyDistributionMessage.encode(proto.SenderKeyDistributionMessage.create({
|
|
35
|
+
const message = WAProto_1.proto.SenderKeyDistributionMessage.encode(WAProto_1.proto.SenderKeyDistributionMessage.create({
|
|
33
36
|
id,
|
|
34
37
|
iteration,
|
|
35
38
|
chainKey,
|
|
@@ -51,13 +54,13 @@ export class SenderKeyDistributionMessage extends CiphertextMessage {
|
|
|
51
54
|
return this.iteration;
|
|
52
55
|
}
|
|
53
56
|
getChainKey() {
|
|
54
|
-
return this.chainKey;
|
|
57
|
+
return typeof this.chainKey === 'string' ? Buffer.from(this.chainKey, 'base64') : this.chainKey;
|
|
55
58
|
}
|
|
56
59
|
getSignatureKey() {
|
|
57
|
-
return this.signatureKey;
|
|
60
|
+
return typeof this.signatureKey === 'string' ? Buffer.from(this.signatureKey, 'base64') : this.signatureKey;
|
|
58
61
|
}
|
|
59
62
|
getId() {
|
|
60
63
|
return this.id;
|
|
61
64
|
}
|
|
62
65
|
}
|
|
63
|
-
|
|
66
|
+
exports.SenderKeyDistributionMessage = SenderKeyDistributionMessage;
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { CiphertextMessage } from './ciphertext-message
|
|
1
|
+
import { CiphertextMessage } from './ciphertext-message';
|
|
2
2
|
export declare class SenderKeyMessage extends CiphertextMessage {
|
|
3
3
|
private readonly SIGNATURE_LENGTH;
|
|
4
4
|
private readonly messageVersion;
|
|
@@ -16,4 +16,3 @@ export declare class SenderKeyMessage extends CiphertextMessage {
|
|
|
16
16
|
serialize(): Uint8Array;
|
|
17
17
|
getType(): number;
|
|
18
18
|
}
|
|
19
|
-
//# sourceMappingURL=sender-key-message.d.ts.map
|
|
@@ -1,7 +1,10 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.SenderKeyMessage = void 0;
|
|
4
|
+
const curve_1 = require("libsignal/src/curve");
|
|
5
|
+
const WAProto_1 = require("../../../WAProto");
|
|
6
|
+
const ciphertext_message_1 = require("./ciphertext-message");
|
|
7
|
+
class SenderKeyMessage extends ciphertext_message_1.CiphertextMessage {
|
|
5
8
|
constructor(keyId, iteration, ciphertext, signatureKey, serialized) {
|
|
6
9
|
super();
|
|
7
10
|
this.SIGNATURE_LENGTH = 64;
|
|
@@ -9,7 +12,7 @@ export class SenderKeyMessage extends CiphertextMessage {
|
|
|
9
12
|
const version = serialized[0];
|
|
10
13
|
const message = serialized.slice(1, serialized.length - this.SIGNATURE_LENGTH);
|
|
11
14
|
const signature = serialized.slice(-1 * this.SIGNATURE_LENGTH);
|
|
12
|
-
const senderKeyMessage = proto.SenderKeyMessage.decode(message).toJSON();
|
|
15
|
+
const senderKeyMessage = WAProto_1.proto.SenderKeyMessage.decode(message).toJSON();
|
|
13
16
|
this.serialized = serialized;
|
|
14
17
|
this.messageVersion = (version & 0xff) >> 4;
|
|
15
18
|
this.keyId = senderKeyMessage.id;
|
|
@@ -23,7 +26,7 @@ export class SenderKeyMessage extends CiphertextMessage {
|
|
|
23
26
|
else {
|
|
24
27
|
const version = (((this.CURRENT_VERSION << 4) | this.CURRENT_VERSION) & 0xff) % 256;
|
|
25
28
|
const ciphertextBuffer = Buffer.from(ciphertext);
|
|
26
|
-
const message = proto.SenderKeyMessage.encode(proto.SenderKeyMessage.create({
|
|
29
|
+
const message = WAProto_1.proto.SenderKeyMessage.encode(WAProto_1.proto.SenderKeyMessage.create({
|
|
27
30
|
id: keyId,
|
|
28
31
|
iteration: iteration,
|
|
29
32
|
ciphertext: ciphertextBuffer
|
|
@@ -49,12 +52,12 @@ export class SenderKeyMessage extends CiphertextMessage {
|
|
|
49
52
|
verifySignature(signatureKey) {
|
|
50
53
|
const part1 = this.serialized.slice(0, this.serialized.length - this.SIGNATURE_LENGTH);
|
|
51
54
|
const part2 = this.serialized.slice(-1 * this.SIGNATURE_LENGTH);
|
|
52
|
-
const res = verifySignature(signatureKey, part1, part2);
|
|
55
|
+
const res = (0, curve_1.verifySignature)(signatureKey, part1, part2);
|
|
53
56
|
if (!res)
|
|
54
57
|
throw new Error('Invalid signature!');
|
|
55
58
|
}
|
|
56
59
|
getSignature(signatureKey, serialized) {
|
|
57
|
-
return Buffer.from(calculateSignature(signatureKey, serialized));
|
|
60
|
+
return Buffer.from((0, curve_1.calculateSignature)(signatureKey, serialized));
|
|
58
61
|
}
|
|
59
62
|
serialize() {
|
|
60
63
|
return this.serialized;
|
|
@@ -63,4 +66,4 @@ export class SenderKeyMessage extends CiphertextMessage {
|
|
|
63
66
|
return 4;
|
|
64
67
|
}
|
|
65
68
|
}
|
|
66
|
-
|
|
69
|
+
exports.SenderKeyMessage = SenderKeyMessage;
|
|
@@ -1,3 +1,6 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.SenderKeyName = void 0;
|
|
1
4
|
function isNull(str) {
|
|
2
5
|
return str === null || str === '';
|
|
3
6
|
}
|
|
@@ -19,7 +22,7 @@ function hashCode(strKey) {
|
|
|
19
22
|
}
|
|
20
23
|
return hash;
|
|
21
24
|
}
|
|
22
|
-
|
|
25
|
+
class SenderKeyName {
|
|
23
26
|
constructor(groupId, sender) {
|
|
24
27
|
this.groupId = groupId;
|
|
25
28
|
this.sender = sender;
|
|
@@ -45,4 +48,4 @@ export class SenderKeyName {
|
|
|
45
48
|
return hashCode(this.groupId) ^ hashCode(this.sender.toString());
|
|
46
49
|
}
|
|
47
50
|
}
|
|
48
|
-
|
|
51
|
+
exports.SenderKeyName = SenderKeyName;
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { SenderKeyState } from './sender-key-state
|
|
1
|
+
import { SenderKeyState } from './sender-key-state';
|
|
2
2
|
export interface SenderKeyStateStructure {
|
|
3
3
|
senderKeyId: number;
|
|
4
4
|
senderChainKey: {
|
|
@@ -26,6 +26,5 @@ export declare class SenderKeyRecord {
|
|
|
26
26
|
private: Uint8Array;
|
|
27
27
|
}): void;
|
|
28
28
|
serialize(): SenderKeyStateStructure[];
|
|
29
|
-
static deserialize(data: Uint8Array): SenderKeyRecord;
|
|
29
|
+
static deserialize(data: Uint8Array | string | SenderKeyStateStructure[]): SenderKeyRecord;
|
|
30
30
|
}
|
|
31
|
-
//# sourceMappingURL=sender-key-record.d.ts.map
|
|
@@ -1,12 +1,15 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.SenderKeyRecord = void 0;
|
|
4
|
+
const generics_1 = require("../../Utils/generics");
|
|
5
|
+
const sender_key_state_1 = require("./sender-key-state");
|
|
6
|
+
class SenderKeyRecord {
|
|
4
7
|
constructor(serialized) {
|
|
5
8
|
this.MAX_STATES = 5;
|
|
6
9
|
this.senderKeyStates = [];
|
|
7
10
|
if (serialized) {
|
|
8
11
|
for (const structure of serialized) {
|
|
9
|
-
this.senderKeyStates.push(new SenderKeyState(null, null, null, null, null, null, structure));
|
|
12
|
+
this.senderKeyStates.push(new sender_key_state_1.SenderKeyState(null, null, null, null, null, null, structure));
|
|
10
13
|
}
|
|
11
14
|
}
|
|
12
15
|
}
|
|
@@ -20,22 +23,31 @@ export class SenderKeyRecord {
|
|
|
20
23
|
return this.senderKeyStates.find(state => state.getKeyId() === keyId);
|
|
21
24
|
}
|
|
22
25
|
addSenderKeyState(id, iteration, chainKey, signatureKey) {
|
|
23
|
-
this.senderKeyStates.push(new SenderKeyState(id, iteration, chainKey, null, signatureKey));
|
|
26
|
+
this.senderKeyStates.push(new sender_key_state_1.SenderKeyState(id, iteration, chainKey, null, signatureKey));
|
|
24
27
|
if (this.senderKeyStates.length > this.MAX_STATES) {
|
|
25
28
|
this.senderKeyStates.shift();
|
|
26
29
|
}
|
|
27
30
|
}
|
|
28
31
|
setSenderKeyState(id, iteration, chainKey, keyPair) {
|
|
29
32
|
this.senderKeyStates.length = 0;
|
|
30
|
-
this.senderKeyStates.push(new SenderKeyState(id, iteration, chainKey, keyPair));
|
|
33
|
+
this.senderKeyStates.push(new sender_key_state_1.SenderKeyState(id, iteration, chainKey, keyPair));
|
|
31
34
|
}
|
|
32
35
|
serialize() {
|
|
33
36
|
return this.senderKeyStates.map(state => state.getStructure());
|
|
34
37
|
}
|
|
35
38
|
static deserialize(data) {
|
|
36
|
-
|
|
37
|
-
|
|
39
|
+
let parsed;
|
|
40
|
+
if (typeof data === 'string') {
|
|
41
|
+
parsed = JSON.parse(data, generics_1.BufferJSON.reviver);
|
|
42
|
+
}
|
|
43
|
+
else if (data instanceof Uint8Array) {
|
|
44
|
+
const str = Buffer.from(data).toString('utf-8');
|
|
45
|
+
parsed = JSON.parse(str, generics_1.BufferJSON.reviver);
|
|
46
|
+
}
|
|
47
|
+
else {
|
|
48
|
+
parsed = data;
|
|
49
|
+
}
|
|
38
50
|
return new SenderKeyRecord(parsed);
|
|
39
51
|
}
|
|
40
52
|
}
|
|
41
|
-
|
|
53
|
+
exports.SenderKeyRecord = SenderKeyRecord;
|
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
import { SenderChainKey } from './sender-chain-key
|
|
2
|
-
import { SenderMessageKey } from './sender-message-key
|
|
1
|
+
import { SenderChainKey } from './sender-chain-key';
|
|
2
|
+
import { SenderMessageKey } from './sender-message-key';
|
|
3
3
|
interface SenderChainKeyStructure {
|
|
4
4
|
iteration: number;
|
|
5
5
|
seed: Uint8Array;
|
|
@@ -21,10 +21,10 @@ interface SenderKeyStateStructure {
|
|
|
21
21
|
export declare class SenderKeyState {
|
|
22
22
|
private readonly MAX_MESSAGE_KEYS;
|
|
23
23
|
private readonly senderKeyStateStructure;
|
|
24
|
-
constructor(id?: number | null, iteration?: number | null, chainKey?: Uint8Array | null
|
|
25
|
-
public: Uint8Array
|
|
26
|
-
private: Uint8Array
|
|
27
|
-
} | null, signatureKeyPublic?: Uint8Array |
|
|
24
|
+
constructor(id?: number | null, iteration?: number | null, chainKey?: Uint8Array | null, signatureKeyPair?: {
|
|
25
|
+
public: Uint8Array;
|
|
26
|
+
private: Uint8Array;
|
|
27
|
+
} | null, signatureKeyPublic?: Uint8Array | null, signatureKeyPrivate?: Uint8Array | null, senderKeyStateStructure?: SenderKeyStateStructure | null);
|
|
28
28
|
getKeyId(): number;
|
|
29
29
|
getSenderChainKey(): SenderChainKey;
|
|
30
30
|
setSenderChainKey(chainKey: SenderChainKey): void;
|
|
@@ -36,4 +36,3 @@ export declare class SenderKeyState {
|
|
|
36
36
|
getStructure(): SenderKeyStateStructure;
|
|
37
37
|
}
|
|
38
38
|
export {};
|
|
39
|
-
//# sourceMappingURL=sender-key-state.d.ts.map
|