socketon 1.31.2-rc → 1.51.16
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +313 -159
- package/WAProto/WAProto.proto +5311 -0
- package/WAProto/index.js +65801 -141371
- package/lib/Defaults/index.js +117 -141
- package/lib/KeyDB/BinarySearch.js +20 -0
- package/lib/KeyDB/KeyedDB.js +167 -0
- package/lib/KeyDB/index.js +4 -0
- package/lib/Signal/Group/ciphertext-message.js +12 -14
- package/lib/Signal/Group/group-session-builder.js +10 -42
- package/lib/Signal/Group/group_cipher.js +75 -87
- package/lib/Signal/Group/index.js +13 -57
- package/lib/Signal/Group/keyhelper.js +17 -52
- package/lib/Signal/Group/sender-chain-key.js +27 -33
- package/lib/Signal/Group/sender-key-distribution-message.js +62 -63
- package/lib/Signal/Group/sender-key-message.js +65 -66
- package/lib/Signal/Group/sender-key-name.js +45 -44
- package/lib/Signal/Group/sender-key-record.js +39 -49
- package/lib/Signal/Group/sender-key-state.js +80 -93
- package/lib/Signal/Group/sender-message-key.js +27 -28
- package/lib/Signal/libsignal.js +313 -163
- package/lib/Signal/lid-mapping.js +155 -0
- package/lib/Socket/Client/index.js +4 -19
- package/lib/Socket/Client/types.js +13 -0
- package/lib/Socket/Client/websocket.js +52 -0
- package/lib/Socket/Client/websocket.js.bak +53 -0
- package/lib/Socket/business.js +359 -242
- package/lib/Socket/chats.js +846 -935
- package/lib/Socket/communities.js +413 -0
- package/lib/Socket/groups.js +304 -309
- package/lib/Socket/index.js +15 -10
- package/lib/Socket/messages-recv.js +1107 -1054
- package/lib/Socket/messages-send.js +639 -448
- package/lib/Socket/mex.js +45 -0
- package/lib/Socket/newsletter.js +240 -324
- package/lib/Socket/socket.js +794 -651
- package/lib/Socket/socketon.js +402 -0
- package/lib/Store/index.js +6 -10
- package/lib/Store/make-cache-manager-store.js +73 -81
- package/lib/Store/make-in-memory-store.js +286 -423
- package/lib/Store/make-ordered-dictionary.js +77 -79
- package/lib/Store/object-repository.js +24 -26
- package/lib/Types/Auth.js +3 -2
- package/lib/Types/Bussines.js +3 -0
- package/lib/Types/Call.js +3 -2
- package/lib/Types/Chat.js +9 -4
- package/lib/Types/Contact.js +3 -2
- package/lib/Types/Events.js +3 -2
- package/lib/Types/GroupMetadata.js +3 -2
- package/lib/Types/Label.js +24 -26
- package/lib/Types/LabelAssociation.js +6 -8
- package/lib/Types/Message.js +12 -9
- package/lib/Types/Newsletter.js +33 -38
- package/lib/Types/Newsletter.js.bak +33 -0
- package/lib/Types/Product.js +3 -2
- package/lib/Types/Signal.js +3 -2
- package/lib/Types/Socket.js +4 -2
- package/lib/Types/State.js +11 -2
- package/lib/Types/USync.js +3 -2
- package/lib/Types/index.js +27 -41
- package/lib/Utils/auth-utils.js +211 -198
- package/lib/Utils/baileys-event-stream.js +42 -61
- package/lib/Utils/browser-utils.js +25 -0
- package/lib/Utils/business.js +213 -214
- package/lib/Utils/chat-utils.js +710 -687
- package/lib/Utils/crypto.js +112 -133
- package/lib/Utils/decode-wa-message.js +252 -183
- package/lib/Utils/decode-wa-message.js.bak +267 -0
- package/lib/Utils/event-buffer.js +510 -496
- package/lib/Utils/generics.js +319 -392
- package/lib/Utils/history.js +83 -92
- package/lib/Utils/index.js +21 -33
- package/lib/Utils/link-preview.js +71 -83
- package/lib/Utils/logger.js +5 -7
- package/lib/Utils/lt-hash.js +40 -46
- package/lib/Utils/make-mutex.js +34 -41
- package/lib/Utils/message-retry-manager.js +113 -0
- package/lib/Utils/messages-media.js +550 -768
- package/lib/Utils/messages.js +354 -263
- package/lib/Utils/noise-handler.js +138 -149
- package/lib/Utils/pre-key-manager.js +85 -0
- package/lib/Utils/process-message.js +323 -303
- package/lib/Utils/signal.js +149 -141
- package/lib/Utils/use-multi-file-auth-state.js +95 -103
- package/lib/Utils/validate-connection.js +183 -214
- package/lib/WABinary/constants.js +1298 -35
- package/lib/WABinary/decode.js +237 -249
- package/lib/WABinary/encode.js +213 -260
- package/lib/WABinary/generic-utils.js +56 -65
- package/lib/WABinary/index.js +7 -21
- package/lib/WABinary/jid-utils.js +89 -58
- package/lib/WABinary/types.js +3 -2
- package/lib/WAM/BinaryInfo.js +10 -12
- package/lib/WAM/constants.js +22851 -15348
- package/lib/WAM/encode.js +135 -136
- package/lib/WAM/index.js +5 -19
- package/lib/WAUSync/Protocols/USyncContactProtocol.js +28 -30
- package/lib/WAUSync/Protocols/USyncDeviceProtocol.js +49 -53
- package/lib/WAUSync/Protocols/USyncDisappearingModeProtocol.js +27 -28
- package/lib/WAUSync/Protocols/USyncStatusProtocol.js +36 -39
- package/lib/WAUSync/Protocols/UsyncBotProfileProtocol.js +50 -50
- package/lib/WAUSync/Protocols/UsyncLIDProtocol.js +26 -20
- package/lib/WAUSync/Protocols/index.js +6 -20
- package/lib/WAUSync/USyncQuery.js +86 -85
- package/lib/WAUSync/USyncUser.js +23 -25
- package/lib/WAUSync/index.js +5 -19
- package/lib/index.js +27 -35
- package/package.json +85 -95
- package/engine-requirements.js +0 -10
- package/lib/Defaults/baileys-version.json +0 -3
- package/lib/Defaults/index.d.ts +0 -53
- package/lib/Defaults/phonenumber-mcc.json +0 -223
- package/lib/Signal/Group/ciphertext-message.d.ts +0 -9
- package/lib/Signal/Group/group-session-builder.d.ts +0 -14
- package/lib/Signal/Group/group_cipher.d.ts +0 -17
- package/lib/Signal/Group/index.d.ts +0 -11
- package/lib/Signal/Group/keyhelper.d.ts +0 -10
- package/lib/Signal/Group/queue-job.d.ts +0 -1
- package/lib/Signal/Group/queue-job.js +0 -57
- package/lib/Signal/Group/sender-chain-key.d.ts +0 -13
- package/lib/Signal/Group/sender-key-distribution-message.d.ts +0 -16
- package/lib/Signal/Group/sender-key-message.d.ts +0 -18
- package/lib/Signal/Group/sender-key-name.d.ts +0 -17
- package/lib/Signal/Group/sender-key-record.d.ts +0 -30
- package/lib/Signal/Group/sender-key-state.d.ts +0 -38
- package/lib/Signal/Group/sender-message-key.d.ts +0 -11
- package/lib/Signal/libsignal.d.ts +0 -3
- package/lib/Socket/Client/abstract-socket-client.d.ts +0 -17
- package/lib/Socket/Client/abstract-socket-client.js +0 -13
- package/lib/Socket/Client/index.d.ts +0 -3
- package/lib/Socket/Client/mobile-socket-client.d.ts +0 -13
- package/lib/Socket/Client/mobile-socket-client.js +0 -65
- package/lib/Socket/Client/web-socket-client.d.ts +0 -12
- package/lib/Socket/Client/web-socket-client.js +0 -62
- package/lib/Socket/business.d.ts +0 -171
- package/lib/Socket/chats.d.ts +0 -267
- package/lib/Socket/dugong.d.ts +0 -254
- package/lib/Socket/dugong.js +0 -484
- package/lib/Socket/groups.d.ts +0 -115
- package/lib/Socket/index.d.ts +0 -173
- package/lib/Socket/messages-recv.d.ts +0 -161
- package/lib/Socket/messages-send.d.ts +0 -149
- package/lib/Socket/newsletter.d.ts +0 -134
- package/lib/Socket/registration.d.ts +0 -267
- package/lib/Socket/registration.js +0 -166
- package/lib/Socket/socket.d.ts +0 -43
- package/lib/Socket/usync.d.ts +0 -36
- package/lib/Socket/usync.js +0 -70
- package/lib/Store/index.d.ts +0 -3
- package/lib/Store/make-cache-manager-store.d.ts +0 -13
- package/lib/Store/make-in-memory-store.d.ts +0 -118
- package/lib/Store/make-ordered-dictionary.d.ts +0 -13
- package/lib/Store/object-repository.d.ts +0 -10
- package/lib/Types/Auth.d.ts +0 -110
- package/lib/Types/Call.d.ts +0 -13
- package/lib/Types/Chat.d.ts +0 -102
- package/lib/Types/Contact.d.ts +0 -19
- package/lib/Types/Events.d.ts +0 -157
- package/lib/Types/GroupMetadata.d.ts +0 -55
- package/lib/Types/Label.d.ts +0 -35
- package/lib/Types/LabelAssociation.d.ts +0 -29
- package/lib/Types/Message.d.ts +0 -273
- package/lib/Types/Newsletter.d.ts +0 -103
- package/lib/Types/Product.d.ts +0 -78
- package/lib/Types/Signal.d.ts +0 -57
- package/lib/Types/Socket.d.ts +0 -111
- package/lib/Types/State.d.ts +0 -27
- package/lib/Types/USync.d.ts +0 -25
- package/lib/Types/index.d.ts +0 -57
- package/lib/Utils/auth-utils.d.ts +0 -18
- package/lib/Utils/baileys-event-stream.d.ts +0 -16
- package/lib/Utils/business.d.ts +0 -22
- package/lib/Utils/chat-utils.d.ts +0 -71
- package/lib/Utils/crypto.d.ts +0 -41
- package/lib/Utils/decode-wa-message.d.ts +0 -19
- package/lib/Utils/event-buffer.d.ts +0 -35
- package/lib/Utils/generics.d.ts +0 -92
- package/lib/Utils/generics.js.bak +0 -433
- package/lib/Utils/history.d.ts +0 -15
- package/lib/Utils/index.d.ts +0 -17
- package/lib/Utils/link-preview.d.ts +0 -21
- package/lib/Utils/logger.d.ts +0 -4
- package/lib/Utils/lt-hash.d.ts +0 -12
- package/lib/Utils/make-mutex.d.ts +0 -7
- package/lib/Utils/messages-media.d.ts +0 -116
- package/lib/Utils/messages.d.ts +0 -77
- package/lib/Utils/noise-handler.d.ts +0 -21
- package/lib/Utils/process-message.d.ts +0 -41
- package/lib/Utils/signal.d.ts +0 -32
- package/lib/Utils/use-multi-file-auth-state.d.ts +0 -13
- package/lib/Utils/validate-connection.d.ts +0 -11
- package/lib/Utils/validate-connection.js.bak +0 -237
- package/lib/WABinary/constants.d.ts +0 -30
- package/lib/WABinary/decode.d.ts +0 -7
- package/lib/WABinary/encode.d.ts +0 -3
- package/lib/WABinary/generic-utils.d.ts +0 -17
- package/lib/WABinary/index.d.ts +0 -5
- package/lib/WABinary/jid-utils.d.ts +0 -31
- package/lib/WABinary/types.d.ts +0 -18
- package/lib/WAM/BinaryInfo.d.ts +0 -17
- package/lib/WAM/constants.d.ts +0 -38
- package/lib/WAM/encode.d.ts +0 -3
- package/lib/WAM/index.d.ts +0 -3
- package/lib/WAUSync/Protocols/USyncContactProtocol.d.ts +0 -9
- package/lib/WAUSync/Protocols/USyncDeviceProtocol.d.ts +0 -22
- package/lib/WAUSync/Protocols/USyncDisappearingModeProtocol.d.ts +0 -12
- package/lib/WAUSync/Protocols/USyncStatusProtocol.d.ts +0 -12
- package/lib/WAUSync/Protocols/UsyncBotProfileProtocol.d.ts +0 -25
- package/lib/WAUSync/Protocols/UsyncLIDProtocol.d.ts +0 -8
- package/lib/WAUSync/Protocols/index.d.ts +0 -4
- package/lib/WAUSync/USyncQuery.d.ts +0 -28
- package/lib/WAUSync/USyncUser.d.ts +0 -12
- package/lib/WAUSync/index.d.ts +0 -3
- package/lib/index.d.ts +0 -12
package/lib/Utils/crypto.js
CHANGED
|
@@ -1,151 +1,130 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
1
|
+
//=======================================================//
|
|
2
|
+
import { createCipheriv, createDecipheriv, createHash, createHmac, randomBytes } from "crypto";
|
|
3
|
+
import { KEY_BUNDLE_TYPE } from "../Defaults/index.js";
|
|
4
|
+
import * as curve from "libsignal-xeuka/src/curve.js";
|
|
5
|
+
//=======================================================//
|
|
6
|
+
const { subtle } = globalThis.crypto;
|
|
7
|
+
export const generateSignalPubKey = (pubKey) => pubKey.length === 33 ? pubKey : Buffer.concat([KEY_BUNDLE_TYPE, pubKey]);
|
|
8
|
+
export const Curve = {
|
|
9
|
+
generateKeyPair: () => {
|
|
10
|
+
const { pubKey, privKey } = curve.generateKeyPair();
|
|
11
|
+
return {
|
|
12
|
+
private: Buffer.from(privKey),
|
|
13
|
+
public: Buffer.from(pubKey.slice(1))
|
|
14
|
+
};
|
|
15
|
+
},
|
|
16
|
+
sharedKey: (privateKey, publicKey) => {
|
|
17
|
+
const shared = curve.calculateAgreement(generateSignalPubKey(publicKey), privateKey);
|
|
18
|
+
return Buffer.from(shared);
|
|
19
|
+
},
|
|
20
|
+
sign: (privateKey, buf) => curve.calculateSignature(privateKey, buf),
|
|
21
|
+
verify: (pubKey, message, signature) => {
|
|
22
|
+
try {
|
|
23
|
+
curve.verifySignature(generateSignalPubKey(pubKey), message, signature);
|
|
24
|
+
return true;
|
|
7
25
|
}
|
|
8
|
-
|
|
9
|
-
|
|
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 (mod) {
|
|
19
|
-
if (mod && mod.__esModule) return mod;
|
|
20
|
-
var result = {};
|
|
21
|
-
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
|
|
22
|
-
__setModuleDefault(result, mod);
|
|
23
|
-
return result;
|
|
24
|
-
};
|
|
25
|
-
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
26
|
-
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
27
|
-
};
|
|
28
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
29
|
-
exports.derivePairingCodeKey = exports.hkdf = exports.md5 = exports.sha256 = exports.hmacSign = exports.aesEncrypWithIV = exports.aesEncrypt = exports.aesDecryptWithIV = exports.aesDecrypt = exports.aesDecryptCTR = exports.aesEncryptCTR = exports.aesDecryptGCM = exports.aesEncryptGCM = exports.signedKeyPair = exports.Curve = exports.generateSignalPubKey = void 0;
|
|
30
|
-
const crypto_1 = require("crypto");
|
|
31
|
-
const futoin_hkdf_1 = __importDefault(require("futoin-hkdf"));
|
|
32
|
-
const libsignal = __importStar(require("libsignal"));
|
|
33
|
-
const Defaults_1 = require("../Defaults");
|
|
34
|
-
/** prefix version byte to the pub keys, required for some curve crypto functions */
|
|
35
|
-
const generateSignalPubKey = (pubKey) => (pubKey.length === 33
|
|
36
|
-
? pubKey
|
|
37
|
-
: Buffer.concat([Defaults_1.KEY_BUNDLE_TYPE, pubKey]));
|
|
38
|
-
exports.generateSignalPubKey = generateSignalPubKey;
|
|
39
|
-
exports.Curve = {
|
|
40
|
-
generateKeyPair: () => {
|
|
41
|
-
const { pubKey, privKey } = libsignal.curve.generateKeyPair();
|
|
42
|
-
return {
|
|
43
|
-
private: Buffer.from(privKey),
|
|
44
|
-
// remove version byte
|
|
45
|
-
public: Buffer.from(pubKey.slice(1))
|
|
46
|
-
};
|
|
47
|
-
},
|
|
48
|
-
sharedKey: (privateKey, publicKey) => {
|
|
49
|
-
const shared = libsignal.curve.calculateAgreement((0, exports.generateSignalPubKey)(publicKey), privateKey);
|
|
50
|
-
return Buffer.from(shared);
|
|
51
|
-
},
|
|
52
|
-
sign: (privateKey, buf) => (libsignal.curve.calculateSignature(privateKey, buf)),
|
|
53
|
-
verify: (pubKey, message, signature) => {
|
|
54
|
-
try {
|
|
55
|
-
libsignal.curve.verifySignature((0, exports.generateSignalPubKey)(pubKey), message, signature);
|
|
56
|
-
return true;
|
|
57
|
-
}
|
|
58
|
-
catch (error) {
|
|
59
|
-
return false;
|
|
60
|
-
}
|
|
26
|
+
catch (error) {
|
|
27
|
+
return false;
|
|
61
28
|
}
|
|
29
|
+
}
|
|
62
30
|
};
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
31
|
+
//=======================================================//
|
|
32
|
+
export const signedKeyPair = (identityKeyPair, keyId) => {
|
|
33
|
+
const preKey = Curve.generateKeyPair();
|
|
34
|
+
const pubKey = generateSignalPubKey(preKey.public);
|
|
35
|
+
const signature = Curve.sign(identityKeyPair.private, pubKey);
|
|
36
|
+
return { keyPair: preKey, signature, keyId };
|
|
68
37
|
};
|
|
69
|
-
|
|
38
|
+
//=======================================================//
|
|
70
39
|
const GCM_TAG_LENGTH = 128 >> 3;
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
function aesEncryptGCM(plaintext, key, iv, additionalData) {
|
|
76
|
-
const cipher = (0, crypto_1.createCipheriv)('aes-256-gcm', key, iv);
|
|
77
|
-
cipher.setAAD(additionalData);
|
|
78
|
-
return Buffer.concat([cipher.update(plaintext), cipher.final(), cipher.getAuthTag()]);
|
|
40
|
+
export function aesEncryptGCM(plaintext, key, iv, additionalData) {
|
|
41
|
+
const cipher = createCipheriv("aes-256-gcm", key, iv);
|
|
42
|
+
cipher.setAAD(additionalData);
|
|
43
|
+
return Buffer.concat([cipher.update(plaintext), cipher.final(), cipher.getAuthTag()]);
|
|
79
44
|
}
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
const enc = ciphertext.slice(0, ciphertext.length - GCM_TAG_LENGTH);
|
|
89
|
-
const tag = ciphertext.slice(ciphertext.length - GCM_TAG_LENGTH);
|
|
90
|
-
// set additional data
|
|
91
|
-
decipher.setAAD(additionalData);
|
|
92
|
-
decipher.setAuthTag(tag);
|
|
93
|
-
return Buffer.concat([decipher.update(enc), decipher.final()]);
|
|
45
|
+
//=======================================================//
|
|
46
|
+
export function aesDecryptGCM(ciphertext, key, iv, additionalData) {
|
|
47
|
+
const decipher = createDecipheriv("aes-256-gcm", key, iv);
|
|
48
|
+
const enc = ciphertext.slice(0, ciphertext.length - GCM_TAG_LENGTH);
|
|
49
|
+
const tag = ciphertext.slice(ciphertext.length - GCM_TAG_LENGTH);
|
|
50
|
+
decipher.setAAD(additionalData);
|
|
51
|
+
decipher.setAuthTag(tag);
|
|
52
|
+
return Buffer.concat([decipher.update(enc), decipher.final()]);
|
|
94
53
|
}
|
|
95
|
-
|
|
96
|
-
function aesEncryptCTR(plaintext, key, iv) {
|
|
97
|
-
|
|
98
|
-
|
|
54
|
+
//=======================================================//
|
|
55
|
+
export function aesEncryptCTR(plaintext, key, iv) {
|
|
56
|
+
const cipher = createCipheriv("aes-256-ctr", key, iv);
|
|
57
|
+
return Buffer.concat([cipher.update(plaintext), cipher.final()]);
|
|
99
58
|
}
|
|
100
|
-
|
|
101
|
-
function aesDecryptCTR(ciphertext, key, iv) {
|
|
102
|
-
|
|
103
|
-
|
|
59
|
+
//=======================================================//
|
|
60
|
+
export function aesDecryptCTR(ciphertext, key, iv) {
|
|
61
|
+
const decipher = createDecipheriv("aes-256-ctr", key, iv);
|
|
62
|
+
return Buffer.concat([decipher.update(ciphertext), decipher.final()]);
|
|
104
63
|
}
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
return aesDecryptWithIV(buffer.slice(16, buffer.length), key, buffer.slice(0, 16));
|
|
64
|
+
//=======================================================//
|
|
65
|
+
export function aesDecrypt(buffer, key) {
|
|
66
|
+
return aesDecryptWithIV(buffer.slice(16, buffer.length), key, buffer.slice(0, 16));
|
|
109
67
|
}
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
return Buffer.concat([aes.update(buffer), aes.final()]);
|
|
68
|
+
//=======================================================//
|
|
69
|
+
export function aesDecryptWithIV(buffer, key, IV) {
|
|
70
|
+
const aes = createDecipheriv("aes-256-cbc", key, IV);
|
|
71
|
+
return Buffer.concat([aes.update(buffer), aes.final()]);
|
|
115
72
|
}
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
return Buffer.concat([IV, aes.update(buffer), aes.final()]); // prefix IV to the buffer
|
|
73
|
+
//=======================================================//
|
|
74
|
+
export function aesEncrypt(buffer, key) {
|
|
75
|
+
const IV = randomBytes(16);
|
|
76
|
+
const aes = createCipheriv("aes-256-cbc", key, IV);
|
|
77
|
+
return Buffer.concat([IV, aes.update(buffer), aes.final()]);
|
|
122
78
|
}
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
return Buffer.concat([aes.update(buffer), aes.final()]); // prefix IV to the buffer
|
|
79
|
+
//=======================================================//
|
|
80
|
+
export function aesEncrypWithIV(buffer, key, IV) {
|
|
81
|
+
const aes = createCipheriv("aes-256-cbc", key, IV);
|
|
82
|
+
return Buffer.concat([aes.update(buffer), aes.final()]);
|
|
128
83
|
}
|
|
129
|
-
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
return (0, crypto_1.createHmac)(variant, key).update(buffer).digest();
|
|
84
|
+
//=======================================================//
|
|
85
|
+
export function hmacSign(buffer, key, variant = "sha256") {
|
|
86
|
+
return createHmac(variant, key).update(buffer).digest();
|
|
133
87
|
}
|
|
134
|
-
|
|
135
|
-
function sha256(buffer) {
|
|
136
|
-
|
|
88
|
+
//=======================================================//
|
|
89
|
+
export function sha256(buffer) {
|
|
90
|
+
return createHash("sha256").update(buffer).digest();
|
|
137
91
|
}
|
|
138
|
-
|
|
139
|
-
function md5(buffer) {
|
|
140
|
-
|
|
92
|
+
//=======================================================//
|
|
93
|
+
export function md5(buffer) {
|
|
94
|
+
return createHash("md5").update(buffer).digest();
|
|
141
95
|
}
|
|
142
|
-
|
|
143
|
-
|
|
144
|
-
|
|
145
|
-
|
|
96
|
+
//=======================================================//
|
|
97
|
+
export async function hkdf(buffer, expandedLength, info) {
|
|
98
|
+
const inputKeyMaterial = new Uint8Array(buffer instanceof Uint8Array ? buffer : new Uint8Array(buffer));
|
|
99
|
+
const salt = info.salt ? new Uint8Array(info.salt) : new Uint8Array(0);
|
|
100
|
+
const infoBytes = info.info ? new TextEncoder().encode(info.info) : new Uint8Array(0);
|
|
101
|
+
const importedKey = await subtle.importKey("raw", inputKeyMaterial, { name: "HKDF" }, false, [
|
|
102
|
+
"deriveBits"
|
|
103
|
+
]);
|
|
104
|
+
const derivedBits = await subtle.deriveBits({
|
|
105
|
+
name: "HKDF",
|
|
106
|
+
hash: "SHA-256",
|
|
107
|
+
salt: salt,
|
|
108
|
+
info: infoBytes
|
|
109
|
+
}, importedKey, expandedLength * 8
|
|
110
|
+
);
|
|
111
|
+
return Buffer.from(derivedBits);
|
|
146
112
|
}
|
|
147
|
-
|
|
148
|
-
function derivePairingCodeKey(pairingCode, salt) {
|
|
149
|
-
|
|
113
|
+
//=======================================================//
|
|
114
|
+
export async function derivePairingCodeKey(pairingCode, salt) {
|
|
115
|
+
const encoder = new TextEncoder();
|
|
116
|
+
const pairingCodeBuffer = encoder.encode(pairingCode);
|
|
117
|
+
const saltBuffer = new Uint8Array(salt instanceof Uint8Array ? salt : new Uint8Array(salt));
|
|
118
|
+
const keyMaterial = await subtle.importKey("raw", pairingCodeBuffer, { name: "PBKDF2" }, false, [
|
|
119
|
+
"deriveBits"
|
|
120
|
+
]);
|
|
121
|
+
const derivedBits = await subtle.deriveBits({
|
|
122
|
+
name: "PBKDF2",
|
|
123
|
+
salt: saltBuffer,
|
|
124
|
+
iterations: 2 << 16,
|
|
125
|
+
hash: "SHA-256"
|
|
126
|
+
}, keyMaterial, 32 * 8
|
|
127
|
+
);
|
|
128
|
+
return Buffer.from(derivedBits);
|
|
150
129
|
}
|
|
151
|
-
|
|
130
|
+
//=======================================================//
|