@alannxd/baileys 6.0.3 → 6.0.5
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/GenerateStatics.sh +3 -0
- package/WAProto/WAProto.proto +5479 -0
- package/WAProto/fix-imports.js +85 -0
- package/WAProto/index.d.ts +14017 -0
- package/WAProto/index.js +201 -160
- package/engine-requirements.js +1 -1
- package/lib/Defaults/index.d.ts +37 -15
- package/lib/Defaults/index.js +119 -136
- package/lib/Signal/Group/ciphertext-message.d.ts +1 -0
- package/lib/Signal/Group/ciphertext-message.js +2 -5
- package/lib/Signal/Group/group-session-builder.d.ts +4 -3
- package/lib/Signal/Group/group-session-builder.js +7 -41
- package/lib/Signal/Group/group_cipher.d.ts +4 -4
- package/lib/Signal/Group/group_cipher.js +37 -51
- package/lib/Signal/Group/index.d.ts +12 -11
- package/lib/Signal/Group/index.js +12 -57
- package/lib/Signal/Group/keyhelper.d.ts +2 -1
- package/lib/Signal/Group/keyhelper.js +7 -44
- package/lib/Signal/Group/sender-chain-key.d.ts +3 -2
- package/lib/Signal/Group/sender-chain-key.js +7 -15
- package/lib/Signal/Group/sender-key-distribution-message.d.ts +2 -1
- package/lib/Signal/Group/sender-key-distribution-message.js +8 -11
- package/lib/Signal/Group/sender-key-message.d.ts +2 -1
- package/lib/Signal/Group/sender-key-message.js +9 -12
- package/lib/Signal/Group/sender-key-name.d.ts +1 -0
- package/lib/Signal/Group/sender-key-name.js +2 -5
- package/lib/Signal/Group/sender-key-record.d.ts +3 -2
- package/lib/Signal/Group/sender-key-record.js +9 -21
- package/lib/Signal/Group/sender-key-state.d.ts +7 -6
- package/lib/Signal/Group/sender-key-state.js +27 -42
- package/lib/Signal/Group/sender-message-key.d.ts +1 -0
- package/lib/Signal/Group/sender-message-key.js +4 -7
- package/lib/Signal/libsignal.d.ts +5 -3
- package/lib/Signal/libsignal.js +347 -90
- package/lib/Signal/lid-mapping.d.ts +23 -0
- package/lib/Signal/lid-mapping.js +277 -0
- package/lib/Socket/Client/index.d.ts +3 -3
- package/lib/Socket/Client/index.js +3 -19
- package/lib/Socket/Client/{abstract-socket-client.d.ts → types.d.ts} +4 -5
- package/lib/Socket/Client/types.js +11 -0
- package/lib/Socket/Client/{web-socket-client.d.ts → websocket.d.ts} +3 -2
- package/lib/Socket/Client/websocket.js +54 -0
- package/lib/Socket/business.d.ts +154 -108
- package/lib/Socket/business.js +162 -43
- package/lib/Socket/chats.d.ts +96 -239
- package/lib/Socket/chats.js +627 -427
- package/lib/Socket/communities.d.ts +239 -146
- package/lib/Socket/communities.js +90 -80
- package/lib/Socket/groups.d.ts +104 -57
- package/lib/Socket/groups.js +154 -161
- package/lib/Socket/index.d.ts +202 -115
- package/lib/Socket/index.js +11 -10
- package/lib/Socket/luxu.d.ts +22 -266
- package/lib/Socket/luxu.js +422 -465
- package/lib/Socket/messages-recv.d.ts +136 -84
- package/lib/Socket/messages-recv.js +1421 -615
- package/lib/Socket/messages-send.d.ts +142 -126
- package/lib/Socket/messages-send.js +878 -671
- package/lib/Socket/mex.d.ts +3 -0
- package/lib/Socket/mex.js +42 -0
- package/lib/Socket/newsletter.d.ts +121 -85
- package/lib/Socket/newsletter.js +147 -272
- package/lib/Socket/socket.d.ts +34 -19
- package/lib/Socket/socket.js +544 -313
- package/lib/Store/index.d.ts +10 -3
- package/lib/Store/index.js +10 -10
- package/lib/Store/keyed-db.d.ts +22 -0
- package/lib/Store/keyed-db.js +108 -0
- package/lib/Store/make-cache-manager-store.d.ts +17 -11
- package/lib/Store/make-cache-manager-store.js +43 -41
- package/lib/Store/make-in-memory-store.d.ts +39 -118
- package/lib/Store/make-in-memory-store.js +112 -341
- package/lib/Store/make-ordered-dictionary.d.ts +11 -10
- package/lib/Store/make-ordered-dictionary.js +14 -20
- package/lib/Store/object-repository.d.ts +10 -9
- package/lib/Store/object-repository.js +11 -6
- package/lib/Types/Auth.d.ts +19 -12
- package/lib/Types/Auth.js +2 -2
- package/lib/Types/Bussines.d.ts +25 -0
- package/lib/Types/Bussines.js +2 -0
- package/lib/Types/Call.d.ts +3 -1
- package/lib/Types/Call.js +2 -2
- package/lib/Types/Chat.d.ts +35 -13
- package/lib/Types/Chat.js +8 -4
- package/lib/Types/Contact.d.ts +8 -1
- package/lib/Types/Contact.js +2 -2
- package/lib/Types/Events.d.ts +116 -17
- package/lib/Types/Events.js +2 -2
- package/lib/Types/GroupMetadata.d.ts +21 -5
- package/lib/Types/GroupMetadata.js +2 -2
- package/lib/Types/Label.d.ts +12 -0
- package/lib/Types/Label.js +3 -5
- package/lib/Types/LabelAssociation.d.ts +1 -0
- package/lib/Types/LabelAssociation.js +3 -5
- package/lib/Types/Message.d.ts +105 -58
- package/lib/Types/Message.js +11 -9
- package/lib/Types/Mex.d.ts +141 -0
- package/lib/Types/Mex.js +37 -0
- package/lib/Types/Product.d.ts +2 -1
- package/lib/Types/Product.js +2 -2
- package/lib/Types/Signal.d.ts +32 -2
- package/lib/Types/Signal.js +2 -2
- package/lib/Types/Socket.d.ts +50 -25
- package/lib/Types/Socket.js +3 -2
- package/lib/Types/State.d.ts +72 -2
- package/lib/Types/State.js +56 -2
- package/lib/Types/USync.d.ts +3 -2
- package/lib/Types/USync.js +2 -2
- package/lib/Types/index.d.ts +22 -14
- package/lib/Types/index.js +15 -31
- package/lib/Utils/auth-utils.d.ts +12 -6
- package/lib/Utils/auth-utils.js +239 -143
- package/lib/Utils/browser-utils.d.ts +4 -0
- package/lib/Utils/browser-utils.js +28 -0
- package/lib/Utils/business.d.ts +3 -2
- package/lib/Utils/business.js +66 -69
- package/lib/Utils/chat-utils.d.ts +52 -23
- package/lib/Utils/chat-utils.js +396 -253
- package/lib/Utils/companion-reg-client-utils.d.ts +17 -0
- package/lib/Utils/companion-reg-client-utils.js +35 -0
- package/lib/Utils/crypto.d.ts +18 -22
- package/lib/Utils/crypto.js +57 -90
- package/lib/Utils/decode-wa-message.d.ts +55 -8
- package/lib/Utils/decode-wa-message.js +203 -84
- package/lib/Utils/event-buffer.d.ts +9 -8
- package/lib/Utils/event-buffer.js +185 -77
- package/lib/Utils/generics.d.ts +28 -29
- package/lib/Utils/generics.js +180 -210
- package/lib/Utils/history.d.ts +18 -9
- package/lib/Utils/history.js +93 -55
- package/lib/Utils/identity-change-handler.d.ts +44 -0
- package/lib/Utils/identity-change-handler.js +50 -0
- package/lib/Utils/index.d.ts +22 -17
- package/lib/Utils/index.js +22 -33
- package/lib/Utils/link-preview.d.ts +5 -5
- package/lib/Utils/link-preview.js +16 -24
- package/lib/Utils/logger.d.ts +11 -3
- package/lib/Utils/logger.js +3 -7
- package/lib/Utils/lt-hash.d.ts +8 -12
- package/lib/Utils/lt-hash.js +3 -46
- package/lib/Utils/make-mutex.d.ts +4 -2
- package/lib/Utils/make-mutex.js +24 -34
- package/lib/Utils/message-retry-manager.d.ts +115 -0
- package/lib/Utils/message-retry-manager.js +265 -0
- package/lib/Utils/messages-media.d.ts +61 -44
- package/lib/Utils/messages-media.js +451 -482
- package/lib/Utils/messages.d.ts +32 -18
- package/lib/Utils/messages.js +458 -369
- package/lib/Utils/noise-handler.d.ts +13 -14
- package/lib/Utils/noise-handler.js +145 -99
- package/lib/Utils/offline-node-processor.d.ts +17 -0
- package/lib/Utils/offline-node-processor.js +40 -0
- package/lib/Utils/pre-key-manager.d.ts +28 -0
- package/lib/Utils/pre-key-manager.js +106 -0
- package/lib/Utils/process-message.d.ts +31 -12
- package/lib/Utils/process-message.js +459 -150
- package/lib/Utils/reporting-utils.d.ts +11 -0
- package/lib/Utils/reporting-utils.js +258 -0
- package/lib/Utils/signal.d.ts +20 -5
- package/lib/Utils/signal.js +120 -72
- package/lib/Utils/stanza-ack.d.ts +11 -0
- package/lib/Utils/stanza-ack.js +38 -0
- package/lib/Utils/sync-action-utils.d.ts +19 -0
- package/lib/Utils/sync-action-utils.js +49 -0
- package/lib/Utils/tc-token-utils.d.ts +37 -0
- package/lib/Utils/tc-token-utils.js +163 -0
- package/lib/Utils/use-multi-file-auth-state.d.ts +2 -2
- package/lib/Utils/use-multi-file-auth-state.js +29 -27
- package/lib/Utils/validate-connection.d.ts +7 -7
- package/lib/Utils/validate-connection.js +73 -99
- package/lib/WABinary/constants.d.ts +25 -27
- package/lib/WABinary/constants.js +1281 -20
- package/lib/WABinary/decode.d.ts +5 -5
- package/lib/WABinary/decode.js +52 -42
- package/lib/WABinary/encode.d.ts +3 -3
- package/lib/WABinary/encode.js +110 -155
- package/lib/WABinary/generic-utils.d.ts +8 -7
- package/lib/WABinary/generic-utils.js +48 -49
- package/lib/WABinary/index.d.ts +6 -5
- package/lib/WABinary/index.js +6 -21
- package/lib/WABinary/jid-utils.d.ts +25 -8
- package/lib/WABinary/jid-utils.js +74 -40
- package/lib/WABinary/types.d.ts +2 -1
- package/lib/WABinary/types.js +2 -2
- package/lib/WAM/BinaryInfo.d.ts +3 -11
- package/lib/WAM/BinaryInfo.js +2 -5
- package/lib/WAM/constants.d.ts +5 -3
- package/lib/WAM/constants.js +19071 -11568
- package/lib/WAM/encode.d.ts +3 -3
- package/lib/WAM/encode.js +17 -22
- package/lib/WAM/index.d.ts +4 -3
- package/lib/WAM/index.js +4 -19
- package/lib/WAUSync/Protocols/USyncContactProtocol.d.ts +4 -3
- package/lib/WAUSync/Protocols/USyncContactProtocol.js +33 -13
- package/lib/WAUSync/Protocols/USyncDeviceProtocol.d.ts +3 -2
- package/lib/WAUSync/Protocols/USyncDeviceProtocol.js +11 -14
- package/lib/WAUSync/Protocols/USyncDisappearingModeProtocol.d.ts +3 -2
- package/lib/WAUSync/Protocols/USyncDisappearingModeProtocol.js +9 -12
- package/lib/WAUSync/Protocols/USyncStatusProtocol.d.ts +3 -2
- package/lib/WAUSync/Protocols/USyncStatusProtocol.js +9 -13
- package/lib/WAUSync/Protocols/USyncUsernameProtocol.d.ts +10 -0
- package/lib/WAUSync/Protocols/USyncUsernameProtocol.js +25 -0
- package/lib/WAUSync/Protocols/UsyncBotProfileProtocol.d.ts +4 -3
- package/lib/WAUSync/Protocols/UsyncBotProfileProtocol.js +20 -22
- package/lib/WAUSync/Protocols/UsyncLIDProtocol.d.ts +5 -3
- package/lib/WAUSync/Protocols/UsyncLIDProtocol.js +13 -8
- package/lib/WAUSync/Protocols/index.d.ts +6 -4
- package/lib/WAUSync/Protocols/index.js +6 -20
- package/lib/WAUSync/USyncQuery.d.ts +6 -4
- package/lib/WAUSync/USyncQuery.js +44 -35
- package/lib/WAUSync/USyncUser.d.ts +10 -5
- package/lib/WAUSync/USyncUser.js +10 -5
- package/lib/WAUSync/index.d.ts +4 -0
- package/lib/WAUSync/index.js +4 -19
- package/lib/index.d.ts +10 -9
- package/lib/index.js +12 -34
- package/package.json +84 -53
- package/WAProto/fix-import.js +0 -29
- package/lib/Defaults/baileys-version.json +0 -3
- package/lib/Defaults/phonenumber-mcc.json +0 -223
- package/lib/Signal/Group/queue-job.d.ts +0 -1
- package/lib/Signal/Group/queue-job.js +0 -57
- package/lib/Socket/Client/abstract-socket-client.js +0 -13
- 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.js +0 -62
- package/lib/Socket/registration.d.ts +0 -267
- package/lib/Socket/registration.js +0 -166
- package/lib/Socket/usync.d.ts +0 -36
- package/lib/Socket/usync.js +0 -70
- package/lib/Types/Newsletter.d.ts +0 -103
- package/lib/Types/Newsletter.js +0 -38
- package/lib/Utils/baileys-event-stream.d.ts +0 -16
- package/lib/Utils/baileys-event-stream.js +0 -63
|
@@ -1,57 +1,12 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
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
|
+
export { GroupSessionBuilder } from './group-session-builder.js';
|
|
2
|
+
export { SenderKeyDistributionMessage } from './sender-key-distribution-message.js';
|
|
3
|
+
export { SenderKeyRecord } from './sender-key-record.js';
|
|
4
|
+
export { SenderKeyName } from './sender-key-name.js';
|
|
5
|
+
export { GroupCipher } from './group_cipher.js';
|
|
6
|
+
export { SenderKeyState } from './sender-key-state.js';
|
|
7
|
+
export { SenderKeyMessage } from './sender-key-message.js';
|
|
8
|
+
export { SenderMessageKey } from './sender-message-key.js';
|
|
9
|
+
export { SenderChainKey } from './sender-chain-key.js';
|
|
10
|
+
export { CiphertextMessage } from './ciphertext-message.js';
|
|
11
|
+
export * as keyhelper from './keyhelper.js';
|
|
12
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { generateKeyPair } from 'libsignal/src/curve';
|
|
1
|
+
import { generateKeyPair } from 'libsignal/src/curve.js';
|
|
2
2
|
type KeyPairType = ReturnType<typeof generateKeyPair>;
|
|
3
3
|
export declare function generateSenderKey(): Buffer;
|
|
4
4
|
export declare function generateSenderKeyId(): number;
|
|
@@ -8,3 +8,4 @@ export interface SigningKeyPair {
|
|
|
8
8
|
}
|
|
9
9
|
export declare function generateSenderSigningKey(key?: KeyPairType): SigningKeyPair;
|
|
10
10
|
export {};
|
|
11
|
+
//# sourceMappingURL=keyhelper.d.ts.map
|
|
@@ -1,55 +1,18 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
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() {
|
|
1
|
+
import * as nodeCrypto from 'crypto';
|
|
2
|
+
import { generateKeyPair } from 'libsignal/src/curve.js';
|
|
3
|
+
export function generateSenderKey() {
|
|
42
4
|
return nodeCrypto.randomBytes(32);
|
|
43
5
|
}
|
|
44
|
-
function generateSenderKeyId() {
|
|
6
|
+
export function generateSenderKeyId() {
|
|
45
7
|
return nodeCrypto.randomInt(2147483647);
|
|
46
8
|
}
|
|
47
|
-
function generateSenderSigningKey(key) {
|
|
9
|
+
export function generateSenderSigningKey(key) {
|
|
48
10
|
if (!key) {
|
|
49
|
-
key =
|
|
11
|
+
key = generateKeyPair();
|
|
50
12
|
}
|
|
51
13
|
return {
|
|
52
14
|
public: Buffer.from(key.pubKey),
|
|
53
15
|
private: Buffer.from(key.privKey)
|
|
54
16
|
};
|
|
55
17
|
}
|
|
18
|
+
//# sourceMappingURL=keyhelper.js.map
|
|
@@ -1,13 +1,14 @@
|
|
|
1
|
-
import { SenderMessageKey } from './sender-message-key';
|
|
1
|
+
import { SenderMessageKey } from './sender-message-key.js';
|
|
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: Uint8Array | Buffer);
|
|
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,25 +1,17 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
const crypto_1 = require("libsignal/src/crypto");
|
|
5
|
-
const sender_message_key_1 = require("./sender-message-key");
|
|
6
|
-
class SenderChainKey {
|
|
1
|
+
import { calculateMAC } from 'libsignal/src/crypto.js';
|
|
2
|
+
import { SenderMessageKey } from './sender-message-key.js';
|
|
3
|
+
export class SenderChainKey {
|
|
7
4
|
constructor(iteration, chainKey) {
|
|
8
5
|
this.MESSAGE_KEY_SEED = Buffer.from([0x01]);
|
|
9
6
|
this.CHAIN_KEY_SEED = Buffer.from([0x02]);
|
|
10
7
|
this.iteration = iteration;
|
|
11
|
-
|
|
12
|
-
this.chainKey = chainKey;
|
|
13
|
-
}
|
|
14
|
-
else {
|
|
15
|
-
this.chainKey = Buffer.from(chainKey || []);
|
|
16
|
-
}
|
|
8
|
+
this.chainKey = Buffer.from(chainKey);
|
|
17
9
|
}
|
|
18
10
|
getIteration() {
|
|
19
11
|
return this.iteration;
|
|
20
12
|
}
|
|
21
13
|
getSenderMessageKey() {
|
|
22
|
-
return new
|
|
14
|
+
return new SenderMessageKey(this.iteration, this.getDerivative(this.MESSAGE_KEY_SEED, this.chainKey));
|
|
23
15
|
}
|
|
24
16
|
getNext() {
|
|
25
17
|
return new SenderChainKey(this.iteration + 1, this.getDerivative(this.CHAIN_KEY_SEED, this.chainKey));
|
|
@@ -28,7 +20,7 @@ class SenderChainKey {
|
|
|
28
20
|
return this.chainKey;
|
|
29
21
|
}
|
|
30
22
|
getDerivative(seed, key) {
|
|
31
|
-
return
|
|
23
|
+
return calculateMAC(key, seed);
|
|
32
24
|
}
|
|
33
25
|
}
|
|
34
|
-
|
|
26
|
+
//# sourceMappingURL=sender-chain-key.js.map
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { CiphertextMessage } from './ciphertext-message';
|
|
1
|
+
import { CiphertextMessage } from './ciphertext-message.js';
|
|
2
2
|
export declare class SenderKeyDistributionMessage extends CiphertextMessage {
|
|
3
3
|
private readonly id;
|
|
4
4
|
private readonly iteration;
|
|
@@ -14,3 +14,4 @@ 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,15 +1,12 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
const WAProto_1 = require("../../../WAProto");
|
|
5
|
-
const ciphertext_message_1 = require("./ciphertext-message");
|
|
6
|
-
class SenderKeyDistributionMessage extends ciphertext_message_1.CiphertextMessage {
|
|
1
|
+
import { proto } from '../../../WAProto/index.js';
|
|
2
|
+
import { CiphertextMessage } from './ciphertext-message.js';
|
|
3
|
+
export class SenderKeyDistributionMessage extends CiphertextMessage {
|
|
7
4
|
constructor(id, iteration, chainKey, signatureKey, serialized) {
|
|
8
5
|
super();
|
|
9
6
|
if (serialized) {
|
|
10
7
|
try {
|
|
11
8
|
const message = serialized.slice(1);
|
|
12
|
-
const distributionMessage =
|
|
9
|
+
const distributionMessage = proto.SenderKeyDistributionMessage.decode(message).toJSON();
|
|
13
10
|
this.serialized = serialized;
|
|
14
11
|
this.id = distributionMessage.id;
|
|
15
12
|
this.iteration = distributionMessage.iteration;
|
|
@@ -32,7 +29,7 @@ class SenderKeyDistributionMessage extends ciphertext_message_1.CiphertextMessag
|
|
|
32
29
|
this.iteration = iteration;
|
|
33
30
|
this.chainKey = chainKey;
|
|
34
31
|
this.signatureKey = signatureKey;
|
|
35
|
-
const message =
|
|
32
|
+
const message = proto.SenderKeyDistributionMessage.encode(proto.SenderKeyDistributionMessage.create({
|
|
36
33
|
id,
|
|
37
34
|
iteration,
|
|
38
35
|
chainKey,
|
|
@@ -54,13 +51,13 @@ class SenderKeyDistributionMessage extends ciphertext_message_1.CiphertextMessag
|
|
|
54
51
|
return this.iteration;
|
|
55
52
|
}
|
|
56
53
|
getChainKey() {
|
|
57
|
-
return
|
|
54
|
+
return this.chainKey;
|
|
58
55
|
}
|
|
59
56
|
getSignatureKey() {
|
|
60
|
-
return
|
|
57
|
+
return this.signatureKey;
|
|
61
58
|
}
|
|
62
59
|
getId() {
|
|
63
60
|
return this.id;
|
|
64
61
|
}
|
|
65
62
|
}
|
|
66
|
-
|
|
63
|
+
//# sourceMappingURL=sender-key-distribution-message.js.map
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { CiphertextMessage } from './ciphertext-message';
|
|
1
|
+
import { CiphertextMessage } from './ciphertext-message.js';
|
|
2
2
|
export declare class SenderKeyMessage extends CiphertextMessage {
|
|
3
3
|
private readonly SIGNATURE_LENGTH;
|
|
4
4
|
private readonly messageVersion;
|
|
@@ -16,3 +16,4 @@ 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,10 +1,7 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
const WAProto_1 = require("../../../WAProto");
|
|
6
|
-
const ciphertext_message_1 = require("./ciphertext-message");
|
|
7
|
-
class SenderKeyMessage extends ciphertext_message_1.CiphertextMessage {
|
|
1
|
+
import { calculateSignature, verifySignature } from 'libsignal/src/curve.js';
|
|
2
|
+
import { proto } from '../../../WAProto/index.js';
|
|
3
|
+
import { CiphertextMessage } from './ciphertext-message.js';
|
|
4
|
+
export class SenderKeyMessage extends CiphertextMessage {
|
|
8
5
|
constructor(keyId, iteration, ciphertext, signatureKey, serialized) {
|
|
9
6
|
super();
|
|
10
7
|
this.SIGNATURE_LENGTH = 64;
|
|
@@ -12,7 +9,7 @@ class SenderKeyMessage extends ciphertext_message_1.CiphertextMessage {
|
|
|
12
9
|
const version = serialized[0];
|
|
13
10
|
const message = serialized.slice(1, serialized.length - this.SIGNATURE_LENGTH);
|
|
14
11
|
const signature = serialized.slice(-1 * this.SIGNATURE_LENGTH);
|
|
15
|
-
const senderKeyMessage =
|
|
12
|
+
const senderKeyMessage = proto.SenderKeyMessage.decode(message).toJSON();
|
|
16
13
|
this.serialized = serialized;
|
|
17
14
|
this.messageVersion = (version & 0xff) >> 4;
|
|
18
15
|
this.keyId = senderKeyMessage.id;
|
|
@@ -26,7 +23,7 @@ class SenderKeyMessage extends ciphertext_message_1.CiphertextMessage {
|
|
|
26
23
|
else {
|
|
27
24
|
const version = (((this.CURRENT_VERSION << 4) | this.CURRENT_VERSION) & 0xff) % 256;
|
|
28
25
|
const ciphertextBuffer = Buffer.from(ciphertext);
|
|
29
|
-
const message =
|
|
26
|
+
const message = proto.SenderKeyMessage.encode(proto.SenderKeyMessage.create({
|
|
30
27
|
id: keyId,
|
|
31
28
|
iteration: iteration,
|
|
32
29
|
ciphertext: ciphertextBuffer
|
|
@@ -52,12 +49,12 @@ class SenderKeyMessage extends ciphertext_message_1.CiphertextMessage {
|
|
|
52
49
|
verifySignature(signatureKey) {
|
|
53
50
|
const part1 = this.serialized.slice(0, this.serialized.length - this.SIGNATURE_LENGTH);
|
|
54
51
|
const part2 = this.serialized.slice(-1 * this.SIGNATURE_LENGTH);
|
|
55
|
-
const res =
|
|
52
|
+
const res = verifySignature(signatureKey, part1, part2);
|
|
56
53
|
if (!res)
|
|
57
54
|
throw new Error('Invalid signature!');
|
|
58
55
|
}
|
|
59
56
|
getSignature(signatureKey, serialized) {
|
|
60
|
-
return Buffer.from(
|
|
57
|
+
return Buffer.from(calculateSignature(signatureKey, serialized));
|
|
61
58
|
}
|
|
62
59
|
serialize() {
|
|
63
60
|
return this.serialized;
|
|
@@ -66,4 +63,4 @@ class SenderKeyMessage extends ciphertext_message_1.CiphertextMessage {
|
|
|
66
63
|
return 4;
|
|
67
64
|
}
|
|
68
65
|
}
|
|
69
|
-
|
|
66
|
+
//# sourceMappingURL=sender-key-message.js.map
|
|
@@ -1,6 +1,3 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.SenderKeyName = void 0;
|
|
4
1
|
function isNull(str) {
|
|
5
2
|
return str === null || str === '';
|
|
6
3
|
}
|
|
@@ -22,7 +19,7 @@ function hashCode(strKey) {
|
|
|
22
19
|
}
|
|
23
20
|
return hash;
|
|
24
21
|
}
|
|
25
|
-
class SenderKeyName {
|
|
22
|
+
export class SenderKeyName {
|
|
26
23
|
constructor(groupId, sender) {
|
|
27
24
|
this.groupId = groupId;
|
|
28
25
|
this.sender = sender;
|
|
@@ -48,4 +45,4 @@ class SenderKeyName {
|
|
|
48
45
|
return hashCode(this.groupId) ^ hashCode(this.sender.toString());
|
|
49
46
|
}
|
|
50
47
|
}
|
|
51
|
-
|
|
48
|
+
//# sourceMappingURL=sender-key-name.js.map
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { SenderKeyState } from './sender-key-state';
|
|
1
|
+
import { SenderKeyState } from './sender-key-state.js';
|
|
2
2
|
export interface SenderKeyStateStructure {
|
|
3
3
|
senderKeyId: number;
|
|
4
4
|
senderChainKey: {
|
|
@@ -26,5 +26,6 @@ export declare class SenderKeyRecord {
|
|
|
26
26
|
private: Uint8Array;
|
|
27
27
|
}): void;
|
|
28
28
|
serialize(): SenderKeyStateStructure[];
|
|
29
|
-
static deserialize(data: Uint8Array
|
|
29
|
+
static deserialize(data: Uint8Array): SenderKeyRecord;
|
|
30
30
|
}
|
|
31
|
+
//# sourceMappingURL=sender-key-record.d.ts.map
|
|
@@ -1,15 +1,12 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
const generics_1 = require("../../Utils/generics");
|
|
5
|
-
const sender_key_state_1 = require("./sender-key-state");
|
|
6
|
-
class SenderKeyRecord {
|
|
1
|
+
import { BufferJSON } from '../../Utils/generics.js';
|
|
2
|
+
import { SenderKeyState } from './sender-key-state.js';
|
|
3
|
+
export class SenderKeyRecord {
|
|
7
4
|
constructor(serialized) {
|
|
8
5
|
this.MAX_STATES = 5;
|
|
9
6
|
this.senderKeyStates = [];
|
|
10
7
|
if (serialized) {
|
|
11
8
|
for (const structure of serialized) {
|
|
12
|
-
this.senderKeyStates.push(new
|
|
9
|
+
this.senderKeyStates.push(new SenderKeyState(null, null, null, null, null, null, structure));
|
|
13
10
|
}
|
|
14
11
|
}
|
|
15
12
|
}
|
|
@@ -23,31 +20,22 @@ class SenderKeyRecord {
|
|
|
23
20
|
return this.senderKeyStates.find(state => state.getKeyId() === keyId);
|
|
24
21
|
}
|
|
25
22
|
addSenderKeyState(id, iteration, chainKey, signatureKey) {
|
|
26
|
-
this.senderKeyStates.push(new
|
|
23
|
+
this.senderKeyStates.push(new SenderKeyState(id, iteration, chainKey, null, signatureKey));
|
|
27
24
|
if (this.senderKeyStates.length > this.MAX_STATES) {
|
|
28
25
|
this.senderKeyStates.shift();
|
|
29
26
|
}
|
|
30
27
|
}
|
|
31
28
|
setSenderKeyState(id, iteration, chainKey, keyPair) {
|
|
32
29
|
this.senderKeyStates.length = 0;
|
|
33
|
-
this.senderKeyStates.push(new
|
|
30
|
+
this.senderKeyStates.push(new SenderKeyState(id, iteration, chainKey, keyPair));
|
|
34
31
|
}
|
|
35
32
|
serialize() {
|
|
36
33
|
return this.senderKeyStates.map(state => state.getStructure());
|
|
37
34
|
}
|
|
38
35
|
static deserialize(data) {
|
|
39
|
-
|
|
40
|
-
|
|
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
|
-
}
|
|
36
|
+
const str = Buffer.from(data).toString('utf-8');
|
|
37
|
+
const parsed = JSON.parse(str, BufferJSON.reviver);
|
|
50
38
|
return new SenderKeyRecord(parsed);
|
|
51
39
|
}
|
|
52
40
|
}
|
|
53
|
-
|
|
41
|
+
//# sourceMappingURL=sender-key-record.js.map
|
|
@@ -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.js';
|
|
2
|
+
import { SenderMessageKey } from './sender-message-key.js';
|
|
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, signatureKeyPair?: {
|
|
25
|
-
public: Uint8Array;
|
|
26
|
-
private: Uint8Array;
|
|
27
|
-
} | null, signatureKeyPublic?: Uint8Array | null, signatureKeyPrivate?: Uint8Array | null, senderKeyStateStructure?: SenderKeyStateStructure | null);
|
|
24
|
+
constructor(id?: number | null, iteration?: number | null, chainKey?: Uint8Array | null | string, signatureKeyPair?: {
|
|
25
|
+
public: Uint8Array | string;
|
|
26
|
+
private: Uint8Array | string;
|
|
27
|
+
} | null, signatureKeyPublic?: Uint8Array | string | null, signatureKeyPrivate?: Uint8Array | string | null, senderKeyStateStructure?: SenderKeyStateStructure | null);
|
|
28
28
|
getKeyId(): number;
|
|
29
29
|
getSenderChainKey(): SenderChainKey;
|
|
30
30
|
setSenderChainKey(chainKey: SenderChainKey): void;
|
|
@@ -36,3 +36,4 @@ export declare class SenderKeyState {
|
|
|
36
36
|
getStructure(): SenderKeyStateStructure;
|
|
37
37
|
}
|
|
38
38
|
export {};
|
|
39
|
+
//# sourceMappingURL=sender-key-state.d.ts.map
|
|
@@ -1,37 +1,31 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
const sender_chain_key_1 = require("./sender-chain-key");
|
|
5
|
-
const sender_message_key_1 = require("./sender-message-key");
|
|
6
|
-
class SenderKeyState {
|
|
1
|
+
import { SenderChainKey } from './sender-chain-key.js';
|
|
2
|
+
import { SenderMessageKey } from './sender-message-key.js';
|
|
3
|
+
export class SenderKeyState {
|
|
7
4
|
constructor(id, iteration, chainKey, signatureKeyPair, signatureKeyPublic, signatureKeyPrivate, senderKeyStateStructure) {
|
|
8
5
|
this.MAX_MESSAGE_KEYS = 2000;
|
|
9
6
|
if (senderKeyStateStructure) {
|
|
10
|
-
this.senderKeyStateStructure =
|
|
7
|
+
this.senderKeyStateStructure = {
|
|
8
|
+
...senderKeyStateStructure,
|
|
9
|
+
senderMessageKeys: Array.isArray(senderKeyStateStructure.senderMessageKeys)
|
|
10
|
+
? senderKeyStateStructure.senderMessageKeys
|
|
11
|
+
: []
|
|
12
|
+
};
|
|
11
13
|
}
|
|
12
14
|
else {
|
|
13
15
|
if (signatureKeyPair) {
|
|
14
16
|
signatureKeyPublic = signatureKeyPair.public;
|
|
15
17
|
signatureKeyPrivate = signatureKeyPair.private;
|
|
16
18
|
}
|
|
17
|
-
chainKey = typeof chainKey === 'string' ? Buffer.from(chainKey, 'base64') : chainKey;
|
|
18
|
-
const senderChainKeyStructure = {
|
|
19
|
-
iteration: iteration || 0,
|
|
20
|
-
seed: chainKey || Buffer.alloc(0)
|
|
21
|
-
};
|
|
22
|
-
const signingKeyStructure = {
|
|
23
|
-
public: typeof signatureKeyPublic === 'string'
|
|
24
|
-
? Buffer.from(signatureKeyPublic, 'base64')
|
|
25
|
-
: signatureKeyPublic || Buffer.alloc(0)
|
|
26
|
-
};
|
|
27
|
-
if (signatureKeyPrivate) {
|
|
28
|
-
signingKeyStructure.private =
|
|
29
|
-
typeof signatureKeyPrivate === 'string' ? Buffer.from(signatureKeyPrivate, 'base64') : signatureKeyPrivate;
|
|
30
|
-
}
|
|
31
19
|
this.senderKeyStateStructure = {
|
|
32
20
|
senderKeyId: id || 0,
|
|
33
|
-
senderChainKey:
|
|
34
|
-
|
|
21
|
+
senderChainKey: {
|
|
22
|
+
iteration: iteration || 0,
|
|
23
|
+
seed: Buffer.from(chainKey || [])
|
|
24
|
+
},
|
|
25
|
+
senderSigningKey: {
|
|
26
|
+
public: Buffer.from(signatureKeyPublic || []),
|
|
27
|
+
private: Buffer.from(signatureKeyPrivate || [])
|
|
28
|
+
},
|
|
35
29
|
senderMessageKeys: []
|
|
36
30
|
};
|
|
37
31
|
}
|
|
@@ -40,7 +34,7 @@ class SenderKeyState {
|
|
|
40
34
|
return this.senderKeyStateStructure.senderKeyId;
|
|
41
35
|
}
|
|
42
36
|
getSenderChainKey() {
|
|
43
|
-
return new
|
|
37
|
+
return new SenderChainKey(this.senderKeyStateStructure.senderChainKey.iteration, this.senderKeyStateStructure.senderChainKey.seed);
|
|
44
38
|
}
|
|
45
39
|
setSenderChainKey(chainKey) {
|
|
46
40
|
this.senderKeyStateStructure.senderChainKey = {
|
|
@@ -49,26 +43,17 @@ class SenderKeyState {
|
|
|
49
43
|
};
|
|
50
44
|
}
|
|
51
45
|
getSigningKeyPublic() {
|
|
52
|
-
const publicKey = this.senderKeyStateStructure.senderSigningKey.public;
|
|
53
|
-
if (publicKey
|
|
54
|
-
|
|
46
|
+
const publicKey = Buffer.from(this.senderKeyStateStructure.senderSigningKey.public);
|
|
47
|
+
if (publicKey.length === 32) {
|
|
48
|
+
const fixed = Buffer.alloc(33);
|
|
49
|
+
fixed[0] = 0x05;
|
|
50
|
+
publicKey.copy(fixed, 1);
|
|
51
|
+
return fixed;
|
|
55
52
|
}
|
|
56
|
-
|
|
57
|
-
return Buffer.from(publicKey, 'base64');
|
|
58
|
-
}
|
|
59
|
-
return Buffer.from(publicKey || []);
|
|
53
|
+
return publicKey;
|
|
60
54
|
}
|
|
61
55
|
getSigningKeyPrivate() {
|
|
62
56
|
const privateKey = this.senderKeyStateStructure.senderSigningKey.private;
|
|
63
|
-
if (!privateKey) {
|
|
64
|
-
return undefined;
|
|
65
|
-
}
|
|
66
|
-
if (privateKey instanceof Buffer) {
|
|
67
|
-
return privateKey;
|
|
68
|
-
}
|
|
69
|
-
else if (typeof privateKey === 'string') {
|
|
70
|
-
return Buffer.from(privateKey, 'base64');
|
|
71
|
-
}
|
|
72
57
|
return Buffer.from(privateKey || []);
|
|
73
58
|
}
|
|
74
59
|
hasSenderMessageKey(iteration) {
|
|
@@ -88,7 +73,7 @@ class SenderKeyState {
|
|
|
88
73
|
if (index !== -1) {
|
|
89
74
|
const messageKey = this.senderKeyStateStructure.senderMessageKeys[index];
|
|
90
75
|
this.senderKeyStateStructure.senderMessageKeys.splice(index, 1);
|
|
91
|
-
return new
|
|
76
|
+
return new SenderMessageKey(messageKey.iteration, messageKey.seed);
|
|
92
77
|
}
|
|
93
78
|
return null;
|
|
94
79
|
}
|
|
@@ -96,4 +81,4 @@ class SenderKeyState {
|
|
|
96
81
|
return this.senderKeyStateStructure;
|
|
97
82
|
}
|
|
98
83
|
}
|
|
99
|
-
|
|
84
|
+
//# sourceMappingURL=sender-key-state.js.map
|
|
@@ -1,10 +1,7 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
exports.SenderMessageKey = void 0;
|
|
4
|
-
const crypto_1 = require("libsignal/src/crypto");
|
|
5
|
-
class SenderMessageKey {
|
|
1
|
+
import { deriveSecrets } from 'libsignal/src/crypto.js';
|
|
2
|
+
export class SenderMessageKey {
|
|
6
3
|
constructor(iteration, seed) {
|
|
7
|
-
const derivative =
|
|
4
|
+
const derivative = deriveSecrets(seed, Buffer.alloc(32), Buffer.from('WhisperGroup'));
|
|
8
5
|
const keys = new Uint8Array(32);
|
|
9
6
|
keys.set(new Uint8Array(derivative[0].slice(16)));
|
|
10
7
|
keys.set(new Uint8Array(derivative[1].slice(0, 16)), 16);
|
|
@@ -26,4 +23,4 @@ class SenderMessageKey {
|
|
|
26
23
|
return this.seed;
|
|
27
24
|
}
|
|
28
25
|
}
|
|
29
|
-
|
|
26
|
+
//# sourceMappingURL=sender-message-key.js.map
|
|
@@ -1,3 +1,5 @@
|
|
|
1
|
-
import { SignalAuthState } from '../Types';
|
|
2
|
-
import {
|
|
3
|
-
|
|
1
|
+
import type { LIDMapping, SignalAuthState } from '../Types/index.js';
|
|
2
|
+
import type { SignalRepositoryWithLIDStore } from '../Types/Signal.js';
|
|
3
|
+
import type { ILogger } from '../Utils/logger.js';
|
|
4
|
+
export declare function makeLibSignalRepository(auth: SignalAuthState, logger: ILogger, pnToLIDFunc?: (jids: string[]) => Promise<LIDMapping[] | undefined>): SignalRepositoryWithLIDStore;
|
|
5
|
+
//# sourceMappingURL=libsignal.d.ts.map
|