@lindorm/aes 0.1.3 → 0.2.0
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/CHANGELOG.md +20 -0
- package/dist/classes/AesKit.d.ts +2 -4
- package/dist/classes/AesKit.d.ts.map +1 -1
- package/dist/classes/AesKit.js +9 -17
- package/dist/classes/AesKit.js.map +1 -1
- package/dist/constants/version.d.ts +1 -1
- package/dist/constants/version.js +1 -1
- package/dist/index.d.ts +0 -1
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +0 -1
- package/dist/index.js.map +1 -1
- package/dist/types/aes-cipher.d.ts +2 -2
- package/dist/types/aes-cipher.d.ts.map +1 -1
- package/dist/types/aes-data.d.ts +10 -10
- package/dist/types/aes-data.d.ts.map +1 -1
- package/dist/types/aes-encryption-data.d.ts +10 -6
- package/dist/types/aes-encryption-data.d.ts.map +1 -1
- package/dist/types/aes-kit.d.ts +4 -6
- package/dist/types/aes-kit.d.ts.map +1 -1
- package/dist/types/curve.d.ts +4 -0
- package/dist/types/curve.d.ts.map +1 -0
- package/dist/types/curve.js +3 -0
- package/dist/types/curve.js.map +1 -0
- package/dist/types/index.d.ts +1 -0
- package/dist/types/index.d.ts.map +1 -1
- package/dist/types/index.js +1 -0
- package/dist/types/index.js.map +1 -1
- package/dist/types/private/aes-key-derivation.d.ts +2 -0
- package/dist/types/private/aes-key-derivation.d.ts.map +1 -0
- package/dist/types/private/aes-key-derivation.js +3 -0
- package/dist/types/private/aes-key-derivation.js.map +1 -0
- package/dist/types/private/aes-string.d.ts +18 -0
- package/dist/types/private/aes-string.d.ts.map +1 -0
- package/dist/types/private/aes-string.js +3 -0
- package/dist/types/private/aes-string.js.map +1 -0
- package/dist/types/{auth-tag.d.ts → private/auth-tag.d.ts} +7 -9
- package/dist/types/private/auth-tag.d.ts.map +1 -0
- package/dist/types/{auth-tag.js.map → private/auth-tag.js.map} +1 -1
- package/dist/types/private/content-encryption-key.d.ts +28 -0
- package/dist/types/private/content-encryption-key.d.ts.map +1 -0
- package/dist/types/private/content-encryption-key.js +3 -0
- package/dist/types/private/content-encryption-key.js.map +1 -0
- package/dist/types/private/index.d.ts +5 -0
- package/dist/types/private/index.d.ts.map +1 -0
- package/dist/{enums → types/private}/index.js +4 -4
- package/dist/types/private/index.js.map +1 -0
- package/dist/types/types.d.ts +3 -9
- package/dist/types/types.d.ts.map +1 -1
- package/dist/utils/private/aes-data/auth-tag-hmac.d.ts +5 -0
- package/dist/utils/private/aes-data/auth-tag-hmac.d.ts.map +1 -0
- package/dist/utils/private/aes-data/auth-tag-hmac.js +37 -0
- package/dist/utils/private/aes-data/auth-tag-hmac.js.map +1 -0
- package/dist/utils/private/aes-data/auth-tag.d.ts +5 -0
- package/dist/utils/private/aes-data/auth-tag.d.ts.map +1 -0
- package/dist/utils/private/aes-data/auth-tag.js +52 -0
- package/dist/utils/private/aes-data/auth-tag.js.map +1 -0
- package/dist/utils/private/aes-data/get-initialisation-vector.d.ts +4 -0
- package/dist/utils/private/aes-data/get-initialisation-vector.d.ts.map +1 -0
- package/dist/utils/private/{get-initialisation-vector.js → aes-data/get-initialisation-vector.js} +7 -7
- package/dist/utils/private/aes-data/get-initialisation-vector.js.map +1 -0
- package/dist/utils/private/aes-data/split-content-encryption-key.d.ts +9 -0
- package/dist/utils/private/aes-data/split-content-encryption-key.d.ts.map +1 -0
- package/dist/utils/private/aes-data/split-content-encryption-key.js +31 -0
- package/dist/utils/private/aes-data/split-content-encryption-key.js.map +1 -0
- package/dist/utils/private/aes-data.d.ts.map +1 -1
- package/dist/utils/private/aes-data.js +31 -24
- package/dist/utils/private/aes-data.js.map +1 -1
- package/dist/utils/private/calculate/calculate-aes-encryption.d.ts +4 -0
- package/dist/utils/private/calculate/calculate-aes-encryption.d.ts.map +1 -0
- package/dist/utils/private/calculate/calculate-aes-encryption.js +24 -0
- package/dist/utils/private/calculate/calculate-aes-encryption.js.map +1 -0
- package/dist/utils/private/calculate/calculate-content-encryption-key-size.d.ts +4 -0
- package/dist/utils/private/calculate/calculate-content-encryption-key-size.d.ts.map +1 -0
- package/dist/utils/private/calculate/calculate-content-encryption-key-size.js +24 -0
- package/dist/utils/private/calculate/calculate-content-encryption-key-size.js.map +1 -0
- package/dist/utils/private/calculate/calculate-key-wrap-encryption.d.ts +5 -0
- package/dist/utils/private/calculate/calculate-key-wrap-encryption.d.ts.map +1 -0
- package/dist/utils/private/calculate/calculate-key-wrap-encryption.js +23 -0
- package/dist/utils/private/calculate/calculate-key-wrap-encryption.js.map +1 -0
- package/dist/utils/private/calculate/calculate-key-wrap-size.d.ts +4 -0
- package/dist/utils/private/calculate/calculate-key-wrap-size.d.ts.map +1 -0
- package/dist/utils/private/calculate/calculate-key-wrap-size.js +24 -0
- package/dist/utils/private/calculate/calculate-key-wrap-size.js.map +1 -0
- package/dist/utils/private/calculate/calculate-pbkdf-hash.d.ts +4 -0
- package/dist/utils/private/calculate/calculate-pbkdf-hash.d.ts.map +1 -0
- package/dist/utils/private/calculate/calculate-pbkdf-hash.js +18 -0
- package/dist/utils/private/calculate/calculate-pbkdf-hash.js.map +1 -0
- package/dist/utils/private/calculate/calculate-rsa-oaep-hash.d.ts +4 -0
- package/dist/utils/private/calculate/calculate-rsa-oaep-hash.d.ts.map +1 -0
- package/dist/utils/private/calculate/calculate-rsa-oaep-hash.js +22 -0
- package/dist/utils/private/calculate/calculate-rsa-oaep-hash.js.map +1 -0
- package/dist/utils/private/decode-aes-string.d.ts.map +1 -1
- package/dist/utils/private/decode-aes-string.js +13 -11
- package/dist/utils/private/decode-aes-string.js.map +1 -1
- package/dist/utils/private/diffie-hellman/diffie-hellman-key-wrap.d.ts +4 -0
- package/dist/utils/private/diffie-hellman/diffie-hellman-key-wrap.d.ts.map +1 -0
- package/dist/utils/private/diffie-hellman/diffie-hellman-key-wrap.js +50 -0
- package/dist/utils/private/diffie-hellman/diffie-hellman-key-wrap.js.map +1 -0
- package/dist/utils/private/diffie-hellman/diffie-hellman.d.ts +4 -0
- package/dist/utils/private/diffie-hellman/diffie-hellman.d.ts.map +1 -0
- package/dist/utils/private/diffie-hellman/diffie-hellman.js +40 -0
- package/dist/utils/private/diffie-hellman/diffie-hellman.js.map +1 -0
- package/dist/utils/private/diffie-hellman/shared-secret.d.ts +13 -0
- package/dist/utils/private/diffie-hellman/shared-secret.d.ts.map +1 -0
- package/dist/utils/private/diffie-hellman/shared-secret.js +68 -0
- package/dist/utils/private/diffie-hellman/shared-secret.js.map +1 -0
- package/dist/utils/private/encode-aes-string.d.ts +1 -1
- package/dist/utils/private/encode-aes-string.d.ts.map +1 -1
- package/dist/utils/private/encode-aes-string.js +12 -9
- package/dist/utils/private/encode-aes-string.js.map +1 -1
- package/dist/utils/private/get-key/get-decryption-key.d.ts +3 -0
- package/dist/utils/private/get-key/get-decryption-key.d.ts.map +1 -0
- package/dist/utils/private/get-key/get-decryption-key.js +26 -0
- package/dist/utils/private/get-key/get-decryption-key.js.map +1 -0
- package/dist/utils/private/get-key/get-encryption-key.d.ts +3 -0
- package/dist/utils/private/get-key/get-encryption-key.d.ts.map +1 -0
- package/dist/utils/private/get-key/get-encryption-key.js +26 -0
- package/dist/utils/private/get-key/get-encryption-key.js.map +1 -0
- package/dist/utils/private/key-derivation/hkdf.d.ts +14 -0
- package/dist/utils/private/key-derivation/hkdf.d.ts.map +1 -0
- package/dist/utils/private/key-derivation/hkdf.js +12 -0
- package/dist/utils/private/key-derivation/hkdf.js.map +1 -0
- package/dist/utils/private/key-derivation/pbkdf.d.ts +17 -0
- package/dist/utils/private/key-derivation/pbkdf.d.ts.map +1 -0
- package/dist/utils/private/key-derivation/pbkdf.js +13 -0
- package/dist/utils/private/key-derivation/pbkdf.js.map +1 -0
- package/dist/utils/private/key-types/get-ec-keys.d.ts +4 -0
- package/dist/utils/private/key-types/get-ec-keys.d.ts.map +1 -0
- package/dist/utils/private/key-types/get-ec-keys.js +37 -0
- package/dist/utils/private/key-types/get-ec-keys.js.map +1 -0
- package/dist/utils/private/key-types/get-oct-keys.d.ts +4 -0
- package/dist/utils/private/key-types/get-oct-keys.d.ts.map +1 -0
- package/dist/utils/private/key-types/get-oct-keys.js +46 -0
- package/dist/utils/private/key-types/get-oct-keys.js.map +1 -0
- package/dist/utils/private/key-types/get-okp-keys.d.ts +4 -0
- package/dist/utils/private/key-types/get-okp-keys.d.ts.map +1 -0
- package/dist/utils/private/key-types/get-okp-keys.js +28 -0
- package/dist/utils/private/key-types/get-okp-keys.js.map +1 -0
- package/dist/utils/private/key-types/get-rsa-keys.d.ts +4 -0
- package/dist/utils/private/key-types/get-rsa-keys.d.ts.map +1 -0
- package/dist/utils/private/key-types/get-rsa-keys.js +58 -0
- package/dist/utils/private/key-types/get-rsa-keys.js.map +1 -0
- package/dist/utils/private/key-wrap/key-wrap.d.ts +16 -0
- package/dist/utils/private/key-wrap/key-wrap.d.ts.map +1 -0
- package/dist/utils/private/key-wrap/key-wrap.js +66 -0
- package/dist/utils/private/key-wrap/key-wrap.js.map +1 -0
- package/dist/utils/private/oct/get-oct-dir-keys.d.ts +4 -0
- package/dist/utils/private/oct/get-oct-dir-keys.d.ts.map +1 -0
- package/dist/utils/private/oct/get-oct-dir-keys.js +35 -0
- package/dist/utils/private/oct/get-oct-dir-keys.js.map +1 -0
- package/dist/utils/private/oct/get-oct-key-wrap-keys.d.ts +4 -0
- package/dist/utils/private/oct/get-oct-key-wrap-keys.d.ts.map +1 -0
- package/dist/utils/private/oct/get-oct-key-wrap-keys.js +55 -0
- package/dist/utils/private/oct/get-oct-key-wrap-keys.js.map +1 -0
- package/dist/utils/private/oct/get-oct-pbkdf-key-wrap-keys.d.ts +4 -0
- package/dist/utils/private/oct/get-oct-pbkdf-key-wrap-keys.d.ts.map +1 -0
- package/dist/utils/private/oct/get-oct-pbkdf-key-wrap-keys.js +60 -0
- package/dist/utils/private/oct/get-oct-pbkdf-key-wrap-keys.js.map +1 -0
- package/package.json +8 -5
- package/dist/enums/AesEncryption.d.ts +0 -9
- package/dist/enums/AesEncryption.d.ts.map +0 -1
- package/dist/enums/AesEncryption.js +0 -13
- package/dist/enums/AesEncryption.js.map +0 -1
- package/dist/enums/AesEncryptionKeyAlgorithm.d.ts +0 -9
- package/dist/enums/AesEncryptionKeyAlgorithm.d.ts.map +0 -1
- package/dist/enums/AesEncryptionKeyAlgorithm.js +0 -13
- package/dist/enums/AesEncryptionKeyAlgorithm.js.map +0 -1
- package/dist/enums/AesFormat.d.ts +0 -6
- package/dist/enums/AesFormat.d.ts.map +0 -1
- package/dist/enums/AesFormat.js +0 -10
- package/dist/enums/AesFormat.js.map +0 -1
- package/dist/enums/AesIntegrityHash.d.ts +0 -6
- package/dist/enums/AesIntegrityHash.d.ts.map +0 -1
- package/dist/enums/AesIntegrityHash.js +0 -10
- package/dist/enums/AesIntegrityHash.js.map +0 -1
- package/dist/enums/index.d.ts +0 -5
- package/dist/enums/index.d.ts.map +0 -1
- package/dist/enums/index.js.map +0 -1
- package/dist/types/auth-tag.d.ts.map +0 -1
- package/dist/utils/private/auth-tag-hmac.d.ts +0 -5
- package/dist/utils/private/auth-tag-hmac.d.ts.map +0 -1
- package/dist/utils/private/auth-tag-hmac.js +0 -25
- package/dist/utils/private/auth-tag-hmac.js.map +0 -1
- package/dist/utils/private/auth-tag.d.ts +0 -5
- package/dist/utils/private/auth-tag.d.ts.map +0 -1
- package/dist/utils/private/auth-tag.js +0 -58
- package/dist/utils/private/auth-tag.js.map +0 -1
- package/dist/utils/private/ec/get-ec-keys.d.ts +0 -21
- package/dist/utils/private/ec/get-ec-keys.d.ts.map +0 -1
- package/dist/utils/private/ec/get-ec-keys.js +0 -55
- package/dist/utils/private/ec/get-ec-keys.js.map +0 -1
- package/dist/utils/private/ec/get-key-curve.d.ts +0 -4
- package/dist/utils/private/ec/get-key-curve.d.ts.map +0 -1
- package/dist/utils/private/ec/get-key-curve.js +0 -37
- package/dist/utils/private/ec/get-key-curve.js.map +0 -1
- package/dist/utils/private/get-decryption-key.d.ts +0 -13
- package/dist/utils/private/get-decryption-key.d.ts.map +0 -1
- package/dist/utils/private/get-decryption-key.js +0 -33
- package/dist/utils/private/get-decryption-key.js.map +0 -1
- package/dist/utils/private/get-encryption-keys.d.ts +0 -16
- package/dist/utils/private/get-encryption-keys.d.ts.map +0 -1
- package/dist/utils/private/get-encryption-keys.js +0 -23
- package/dist/utils/private/get-encryption-keys.js.map +0 -1
- package/dist/utils/private/get-initialisation-vector.d.ts +0 -4
- package/dist/utils/private/get-initialisation-vector.d.ts.map +0 -1
- package/dist/utils/private/get-initialisation-vector.js.map +0 -1
- package/dist/utils/private/oct/get-oct-keys.d.ts +0 -14
- package/dist/utils/private/oct/get-oct-keys.d.ts.map +0 -1
- package/dist/utils/private/oct/get-oct-keys.js +0 -24
- package/dist/utils/private/oct/get-oct-keys.js.map +0 -1
- package/dist/utils/private/rsa/generate-encryption-key.d.ts +0 -4
- package/dist/utils/private/rsa/generate-encryption-key.d.ts.map +0 -1
- package/dist/utils/private/rsa/generate-encryption-key.js +0 -8
- package/dist/utils/private/rsa/generate-encryption-key.js.map +0 -1
- package/dist/utils/private/rsa/get-oaep-hash.d.ts +0 -3
- package/dist/utils/private/rsa/get-oaep-hash.d.ts.map +0 -1
- package/dist/utils/private/rsa/get-oaep-hash.js +0 -22
- package/dist/utils/private/rsa/get-oaep-hash.js.map +0 -1
- package/dist/utils/private/rsa/get-rsa-keys.d.ts +0 -21
- package/dist/utils/private/rsa/get-rsa-keys.d.ts.map +0 -1
- package/dist/utils/private/rsa/get-rsa-keys.js +0 -22
- package/dist/utils/private/rsa/get-rsa-keys.js.map +0 -1
- package/dist/utils/private/rsa/public-encryption-key.d.ts +0 -17
- package/dist/utils/private/rsa/public-encryption-key.d.ts.map +0 -1
- package/dist/utils/private/rsa/public-encryption-key.js +0 -56
- package/dist/utils/private/rsa/public-encryption-key.js.map +0 -1
- package/dist/utils/private/secret/calculate-secret-length.d.ts +0 -3
- package/dist/utils/private/secret/calculate-secret-length.d.ts.map +0 -1
- package/dist/utils/private/secret/calculate-secret-length.js +0 -21
- package/dist/utils/private/secret/calculate-secret-length.js.map +0 -1
- package/dist/utils/private/secret/create-key-derivation.d.ts +0 -10
- package/dist/utils/private/secret/create-key-derivation.d.ts.map +0 -1
- package/dist/utils/private/secret/create-key-derivation.js +0 -35
- package/dist/utils/private/secret/create-key-derivation.js.map +0 -1
- /package/dist/types/{auth-tag.js → private/auth-tag.js} +0 -0
|
@@ -0,0 +1,58 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports._getRsaDecryptionKey = exports._getRsaEncryptionKey = void 0;
|
|
4
|
+
const kryptos_1 = require("@lindorm/kryptos");
|
|
5
|
+
const constants_1 = require("constants");
|
|
6
|
+
const crypto_1 = require("crypto");
|
|
7
|
+
const errors_1 = require("../../../errors");
|
|
8
|
+
const calculate_content_encryption_key_size_1 = require("../calculate/calculate-content-encryption-key-size");
|
|
9
|
+
const calculate_rsa_oaep_hash_1 = require("../calculate/calculate-rsa-oaep-hash");
|
|
10
|
+
const _getRsaEncryptionKey = ({ encryption, kryptos, }) => {
|
|
11
|
+
if (!kryptos_1.Kryptos.isRsa(kryptos)) {
|
|
12
|
+
throw new errors_1.AesError("Invalid Kryptos instance");
|
|
13
|
+
}
|
|
14
|
+
if (kryptos.algorithm !== "RSA-OAEP" &&
|
|
15
|
+
kryptos.algorithm !== "RSA-OAEP-256" &&
|
|
16
|
+
kryptos.algorithm !== "RSA-OAEP-384" &&
|
|
17
|
+
kryptos.algorithm !== "RSA-OAEP-512") {
|
|
18
|
+
throw new errors_1.AesError("Invalid encryption key algorithm");
|
|
19
|
+
}
|
|
20
|
+
const keyLength = (0, calculate_content_encryption_key_size_1._calculateContentEncryptionKeySize)(encryption);
|
|
21
|
+
const contentEncryptionKey = (0, crypto_1.randomBytes)(keyLength);
|
|
22
|
+
const { publicKey } = kryptos.export("pem");
|
|
23
|
+
const publicEncryptionKey = (0, crypto_1.publicEncrypt)({
|
|
24
|
+
key: publicKey,
|
|
25
|
+
padding: constants_1.RSA_PKCS1_OAEP_PADDING,
|
|
26
|
+
oaepHash: (0, calculate_rsa_oaep_hash_1._calculateRsaOaepHash)(kryptos.algorithm),
|
|
27
|
+
}, contentEncryptionKey);
|
|
28
|
+
return { contentEncryptionKey, publicEncryptionKey };
|
|
29
|
+
};
|
|
30
|
+
exports._getRsaEncryptionKey = _getRsaEncryptionKey;
|
|
31
|
+
const _getRsaDecryptionKey = ({ kryptos, publicEncryptionKey, }) => {
|
|
32
|
+
if (!kryptos_1.Kryptos.isRsa(kryptos)) {
|
|
33
|
+
throw new errors_1.AesError("Invalid Kryptos instance");
|
|
34
|
+
}
|
|
35
|
+
if (!publicEncryptionKey) {
|
|
36
|
+
throw new errors_1.AesError("Missing publicEncryptionKey");
|
|
37
|
+
}
|
|
38
|
+
if (kryptos.algorithm !== "RSA-OAEP" &&
|
|
39
|
+
kryptos.algorithm !== "RSA-OAEP-256" &&
|
|
40
|
+
kryptos.algorithm !== "RSA-OAEP-384" &&
|
|
41
|
+
kryptos.algorithm !== "RSA-OAEP-512") {
|
|
42
|
+
throw new errors_1.AesError("Invalid encryption key algorithm", {
|
|
43
|
+
debug: { kryptos },
|
|
44
|
+
});
|
|
45
|
+
}
|
|
46
|
+
const { privateKey } = kryptos.export("pem");
|
|
47
|
+
if (!privateKey) {
|
|
48
|
+
throw new errors_1.AesError("Unable to decrypt AES without private key");
|
|
49
|
+
}
|
|
50
|
+
const contentEncryptionKey = (0, crypto_1.privateDecrypt)({
|
|
51
|
+
key: privateKey,
|
|
52
|
+
padding: constants_1.RSA_PKCS1_OAEP_PADDING,
|
|
53
|
+
oaepHash: (0, calculate_rsa_oaep_hash_1._calculateRsaOaepHash)(kryptos.algorithm),
|
|
54
|
+
}, publicEncryptionKey);
|
|
55
|
+
return { contentEncryptionKey };
|
|
56
|
+
};
|
|
57
|
+
exports._getRsaDecryptionKey = _getRsaDecryptionKey;
|
|
58
|
+
//# sourceMappingURL=get-rsa-keys.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"get-rsa-keys.js","sourceRoot":"","sources":["../../../../src/utils/private/key-types/get-rsa-keys.ts"],"names":[],"mappings":";;;AAAA,8CAA2C;AAC3C,yCAAmD;AACnD,mCAAoE;AACpE,4CAA2C;AAO3C,8GAAwG;AACxG,kFAA6E;AAEtE,MAAM,oBAAoB,GAAG,CAAC,EACnC,UAAU,EACV,OAAO,GACU,EAAmB,EAAE;IACtC,IAAI,CAAC,iBAAO,CAAC,KAAK,CAAC,OAAO,CAAC,EAAE,CAAC;QAC5B,MAAM,IAAI,iBAAQ,CAAC,0BAA0B,CAAC,CAAC;IACjD,CAAC;IAED,IACE,OAAO,CAAC,SAAS,KAAK,UAAU;QAChC,OAAO,CAAC,SAAS,KAAK,cAAc;QACpC,OAAO,CAAC,SAAS,KAAK,cAAc;QACpC,OAAO,CAAC,SAAS,KAAK,cAAc,EACpC,CAAC;QACD,MAAM,IAAI,iBAAQ,CAAC,kCAAkC,CAAC,CAAC;IACzD,CAAC;IAED,MAAM,SAAS,GAAG,IAAA,0EAAkC,EAAC,UAAU,CAAC,CAAC;IACjE,MAAM,oBAAoB,GAAG,IAAA,oBAAW,EAAC,SAAS,CAAC,CAAC;IAEpD,MAAM,EAAE,SAAS,EAAE,GAAG,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;IAE5C,MAAM,mBAAmB,GAAG,IAAA,sBAAa,EACvC;QACE,GAAG,EAAE,SAAS;QACd,OAAO,EAAE,kCAAsB;QAC/B,QAAQ,EAAE,IAAA,+CAAqB,EAAC,OAAO,CAAC,SAAS,CAAC;KACnD,EACD,oBAAoB,CACrB,CAAC;IAEF,OAAO,EAAE,oBAAoB,EAAE,mBAAmB,EAAE,CAAC;AACvD,CAAC,CAAC;AAhCW,QAAA,oBAAoB,wBAgC/B;AAEK,MAAM,oBAAoB,GAAG,CAAC,EACnC,OAAO,EACP,mBAAmB,GACD,EAAoB,EAAE;IACxC,IAAI,CAAC,iBAAO,CAAC,KAAK,CAAC,OAAO,CAAC,EAAE,CAAC;QAC5B,MAAM,IAAI,iBAAQ,CAAC,0BAA0B,CAAC,CAAC;IACjD,CAAC;IACD,IAAI,CAAC,mBAAmB,EAAE,CAAC;QACzB,MAAM,IAAI,iBAAQ,CAAC,6BAA6B,CAAC,CAAC;IACpD,CAAC;IAED,IACE,OAAO,CAAC,SAAS,KAAK,UAAU;QAChC,OAAO,CAAC,SAAS,KAAK,cAAc;QACpC,OAAO,CAAC,SAAS,KAAK,cAAc;QACpC,OAAO,CAAC,SAAS,KAAK,cAAc,EACpC,CAAC;QACD,MAAM,IAAI,iBAAQ,CAAC,kCAAkC,EAAE;YACrD,KAAK,EAAE,EAAE,OAAO,EAAE;SACnB,CAAC,CAAC;IACL,CAAC;IAED,MAAM,EAAE,UAAU,EAAE,GAAG,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;IAE7C,IAAI,CAAC,UAAU,EAAE,CAAC;QAChB,MAAM,IAAI,iBAAQ,CAAC,2CAA2C,CAAC,CAAC;IAClE,CAAC;IAED,MAAM,oBAAoB,GAAG,IAAA,uBAAc,EACzC;QACE,GAAG,EAAE,UAAU;QACf,OAAO,EAAE,kCAAsB;QAC/B,QAAQ,EAAE,IAAA,+CAAqB,EAAC,OAAO,CAAC,SAAS,CAAC;KACnD,EACD,mBAAmB,CACpB,CAAC;IAEF,OAAO,EAAE,oBAAoB,EAAE,CAAC;AAClC,CAAC,CAAC;AAtCW,QAAA,oBAAoB,wBAsC/B"}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
/// <reference types="node" />
|
|
2
|
+
import { IKryptos } from "@lindorm/kryptos";
|
|
3
|
+
type KeyWrapOptions = {
|
|
4
|
+
contentEncryptionKey: Buffer;
|
|
5
|
+
keyEncryptionKey: Buffer;
|
|
6
|
+
kryptos: IKryptos;
|
|
7
|
+
};
|
|
8
|
+
type KeyUnwrapOptions = {
|
|
9
|
+
keyEncryptionKey: Buffer;
|
|
10
|
+
kryptos: IKryptos;
|
|
11
|
+
wrappedKey: Buffer;
|
|
12
|
+
};
|
|
13
|
+
export declare const _aesKeyWrap: ({ contentEncryptionKey, keyEncryptionKey, kryptos, }: KeyWrapOptions) => Buffer;
|
|
14
|
+
export declare const _aesKeyUnwrap: ({ keyEncryptionKey, kryptos, wrappedKey, }: KeyUnwrapOptions) => Buffer;
|
|
15
|
+
export {};
|
|
16
|
+
//# sourceMappingURL=key-wrap.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"key-wrap.d.ts","sourceRoot":"","sources":["../../../../src/utils/private/key-wrap/key-wrap.ts"],"names":[],"mappings":";AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,kBAAkB,CAAC;AAO5C,KAAK,cAAc,GAAG;IACpB,oBAAoB,EAAE,MAAM,CAAC;IAC7B,gBAAgB,EAAE,MAAM,CAAC;IACzB,OAAO,EAAE,QAAQ,CAAC;CACnB,CAAC;AAEF,KAAK,gBAAgB,GAAG;IACtB,gBAAgB,EAAE,MAAM,CAAC;IACzB,OAAO,EAAE,QAAQ,CAAC;IAClB,UAAU,EAAE,MAAM,CAAC;CACpB,CAAC;AAEF,eAAO,MAAM,WAAW,yDAIrB,cAAc,KAAG,MA8BnB,CAAC;AAEF,eAAO,MAAM,aAAa,+CAIvB,gBAAgB,KAAG,MAmCrB,CAAC"}
|
|
@@ -0,0 +1,66 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports._aesKeyUnwrap = exports._aesKeyWrap = void 0;
|
|
4
|
+
const crypto_1 = require("crypto");
|
|
5
|
+
const calculate_key_wrap_encryption_1 = require("../calculate/calculate-key-wrap-encryption");
|
|
6
|
+
const AIV = "A6A6A6A6A6A6A6A6";
|
|
7
|
+
const BLOCK_SIZE = 8;
|
|
8
|
+
const _aesKeyWrap = ({ contentEncryptionKey, keyEncryptionKey, kryptos, }) => {
|
|
9
|
+
const algorithm = (0, calculate_key_wrap_encryption_1._calculateKeyWrapEncryption)(kryptos);
|
|
10
|
+
const n = contentEncryptionKey.length / BLOCK_SIZE;
|
|
11
|
+
let a = Buffer.from(AIV, "hex");
|
|
12
|
+
const r = [];
|
|
13
|
+
for (let i = 0; i < n; i++) {
|
|
14
|
+
r[i] = contentEncryptionKey.subarray(i * BLOCK_SIZE, (i + 1) * BLOCK_SIZE);
|
|
15
|
+
}
|
|
16
|
+
const cipher = (0, crypto_1.createCipheriv)(algorithm, keyEncryptionKey, null);
|
|
17
|
+
cipher.setAutoPadding(false);
|
|
18
|
+
for (let j = 0; j < 6; j++) {
|
|
19
|
+
for (let i = 0; i < n; i++) {
|
|
20
|
+
const b = Buffer.concat([a, r[i]]);
|
|
21
|
+
const encrypted = cipher.update(b);
|
|
22
|
+
a = encrypted.subarray(0, BLOCK_SIZE);
|
|
23
|
+
const t = n * j + i + 1;
|
|
24
|
+
const tBuffer = Buffer.alloc(BLOCK_SIZE);
|
|
25
|
+
tBuffer.writeUIntBE(t, 4, 4);
|
|
26
|
+
for (let k = 0; k < BLOCK_SIZE; k++) {
|
|
27
|
+
a[k] ^= tBuffer[k];
|
|
28
|
+
}
|
|
29
|
+
r[i] = encrypted.subarray(BLOCK_SIZE);
|
|
30
|
+
}
|
|
31
|
+
}
|
|
32
|
+
return Buffer.concat([a, ...r]);
|
|
33
|
+
};
|
|
34
|
+
exports._aesKeyWrap = _aesKeyWrap;
|
|
35
|
+
const _aesKeyUnwrap = ({ keyEncryptionKey, kryptos, wrappedKey, }) => {
|
|
36
|
+
const encryption = (0, calculate_key_wrap_encryption_1._calculateKeyWrapEncryption)(kryptos);
|
|
37
|
+
const n = wrappedKey.length / BLOCK_SIZE - 1;
|
|
38
|
+
let a = wrappedKey.subarray(0, BLOCK_SIZE);
|
|
39
|
+
const r = [];
|
|
40
|
+
for (let i = 0; i < n; i++) {
|
|
41
|
+
r[i] = wrappedKey.subarray((i + 1) * BLOCK_SIZE, (i + 2) * BLOCK_SIZE);
|
|
42
|
+
}
|
|
43
|
+
const decipher = (0, crypto_1.createDecipheriv)(encryption, keyEncryptionKey, null);
|
|
44
|
+
decipher.setAutoPadding(false);
|
|
45
|
+
for (let j = 5; j >= 0; j--) {
|
|
46
|
+
for (let i = n - 1; i >= 0; i--) {
|
|
47
|
+
const t = n * j + i + 1;
|
|
48
|
+
const tBuffer = Buffer.alloc(BLOCK_SIZE);
|
|
49
|
+
tBuffer.writeUIntBE(t, 4, 4);
|
|
50
|
+
const aXorT = Buffer.alloc(BLOCK_SIZE);
|
|
51
|
+
for (let k = 0; k < BLOCK_SIZE; k++) {
|
|
52
|
+
aXorT[k] = a[k] ^ tBuffer[k];
|
|
53
|
+
}
|
|
54
|
+
const b = Buffer.concat([aXorT, r[i]]);
|
|
55
|
+
const decrypted = decipher.update(b);
|
|
56
|
+
a = decrypted.subarray(0, BLOCK_SIZE);
|
|
57
|
+
r[i] = decrypted.subarray(BLOCK_SIZE);
|
|
58
|
+
}
|
|
59
|
+
}
|
|
60
|
+
if (!a.equals(Buffer.from(AIV, "hex"))) {
|
|
61
|
+
throw new Error("Integrity check failed");
|
|
62
|
+
}
|
|
63
|
+
return Buffer.concat(r);
|
|
64
|
+
};
|
|
65
|
+
exports._aesKeyUnwrap = _aesKeyUnwrap;
|
|
66
|
+
//# sourceMappingURL=key-wrap.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"key-wrap.js","sourceRoot":"","sources":["../../../../src/utils/private/key-wrap/key-wrap.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
import { CreateCekOptions, CreateCekResult, DecryptCekOptions, DecryptCekResult } from "../../../types/private";
|
|
2
|
+
export declare const _getOctDirEncryptionKey: ({ encryption, kryptos, }: CreateCekOptions) => CreateCekResult;
|
|
3
|
+
export declare const _getOctDirDecryptionKey: ({ encryption, kryptos, }: DecryptCekOptions) => DecryptCekResult;
|
|
4
|
+
//# sourceMappingURL=get-oct-dir-keys.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"get-oct-dir-keys.d.ts","sourceRoot":"","sources":["../../../../src/utils/private/oct/get-oct-dir-keys.ts"],"names":[],"mappings":"AAEA,OAAO,EACL,gBAAgB,EAChB,eAAe,EACf,iBAAiB,EACjB,gBAAgB,EACjB,MAAM,wBAAwB,CAAC;AAGhC,eAAO,MAAM,uBAAuB,6BAGjC,gBAAgB,KAAG,eAerB,CAAC;AAEF,eAAO,MAAM,uBAAuB,6BAGjC,iBAAiB,KAAG,gBAetB,CAAC"}
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports._getOctDirDecryptionKey = exports._getOctDirEncryptionKey = void 0;
|
|
4
|
+
const kryptos_1 = require("@lindorm/kryptos");
|
|
5
|
+
const errors_1 = require("../../../errors");
|
|
6
|
+
const calculate_content_encryption_key_size_1 = require("../calculate/calculate-content-encryption-key-size");
|
|
7
|
+
const _getOctDirEncryptionKey = ({ encryption, kryptos, }) => {
|
|
8
|
+
if (!kryptos_1.Kryptos.isOct(kryptos)) {
|
|
9
|
+
throw new errors_1.AesError("Invalid Kryptos", { debug: { kryptos: kryptos.toJSON() } });
|
|
10
|
+
}
|
|
11
|
+
const der = kryptos.export("der");
|
|
12
|
+
const keyLength = (0, calculate_content_encryption_key_size_1._calculateContentEncryptionKeySize)(encryption);
|
|
13
|
+
if (der.privateKey.length !== keyLength) {
|
|
14
|
+
throw new errors_1.AesError("Invalid key length", {
|
|
15
|
+
debug: { keyLength, privateKeyLength: der.privateKey.length },
|
|
16
|
+
});
|
|
17
|
+
}
|
|
18
|
+
return { contentEncryptionKey: der.privateKey };
|
|
19
|
+
};
|
|
20
|
+
exports._getOctDirEncryptionKey = _getOctDirEncryptionKey;
|
|
21
|
+
const _getOctDirDecryptionKey = ({ encryption, kryptos, }) => {
|
|
22
|
+
if (!kryptos_1.Kryptos.isOct(kryptos)) {
|
|
23
|
+
throw new errors_1.AesError("Invalid Kryptos", { debug: { kryptos: kryptos.toJSON() } });
|
|
24
|
+
}
|
|
25
|
+
const der = kryptos.export("der");
|
|
26
|
+
const keyLength = (0, calculate_content_encryption_key_size_1._calculateContentEncryptionKeySize)(encryption);
|
|
27
|
+
if (der.privateKey.length !== keyLength) {
|
|
28
|
+
throw new errors_1.AesError("Invalid key length", {
|
|
29
|
+
debug: { keyLength, privateKeyLength: der.privateKey.length },
|
|
30
|
+
});
|
|
31
|
+
}
|
|
32
|
+
return { contentEncryptionKey: der.privateKey };
|
|
33
|
+
};
|
|
34
|
+
exports._getOctDirDecryptionKey = _getOctDirDecryptionKey;
|
|
35
|
+
//# sourceMappingURL=get-oct-dir-keys.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"get-oct-dir-keys.js","sourceRoot":"","sources":["../../../../src/utils/private/oct/get-oct-dir-keys.ts"],"names":[],"mappings":";;;AAAA,8CAA2C;AAC3C,4CAA2C;AAO3C,8GAAwG;AAEjG,MAAM,uBAAuB,GAAG,CAAC,EACtC,UAAU,EACV,OAAO,GACU,EAAmB,EAAE;IACtC,IAAI,CAAC,iBAAO,CAAC,KAAK,CAAC,OAAO,CAAC,EAAE,CAAC;QAC5B,MAAM,IAAI,iBAAQ,CAAC,iBAAiB,EAAE,EAAE,KAAK,EAAE,EAAE,OAAO,EAAE,OAAO,CAAC,MAAM,EAAE,EAAE,EAAE,CAAC,CAAC;IAClF,CAAC;IAED,MAAM,GAAG,GAAG,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;IAClC,MAAM,SAAS,GAAG,IAAA,0EAAkC,EAAC,UAAU,CAAC,CAAC;IAEjE,IAAI,GAAG,CAAC,UAAU,CAAC,MAAM,KAAK,SAAS,EAAE,CAAC;QACxC,MAAM,IAAI,iBAAQ,CAAC,oBAAoB,EAAE;YACvC,KAAK,EAAE,EAAE,SAAS,EAAE,gBAAgB,EAAE,GAAG,CAAC,UAAU,CAAC,MAAM,EAAE;SAC9D,CAAC,CAAC;IACL,CAAC;IAED,OAAO,EAAE,oBAAoB,EAAE,GAAG,CAAC,UAAU,EAAE,CAAC;AAClD,CAAC,CAAC;AAlBW,QAAA,uBAAuB,2BAkBlC;AAEK,MAAM,uBAAuB,GAAG,CAAC,EACtC,UAAU,EACV,OAAO,GACW,EAAoB,EAAE;IACxC,IAAI,CAAC,iBAAO,CAAC,KAAK,CAAC,OAAO,CAAC,EAAE,CAAC;QAC5B,MAAM,IAAI,iBAAQ,CAAC,iBAAiB,EAAE,EAAE,KAAK,EAAE,EAAE,OAAO,EAAE,OAAO,CAAC,MAAM,EAAE,EAAE,EAAE,CAAC,CAAC;IAClF,CAAC;IAED,MAAM,GAAG,GAAG,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;IAClC,MAAM,SAAS,GAAG,IAAA,0EAAkC,EAAC,UAAU,CAAC,CAAC;IAEjE,IAAI,GAAG,CAAC,UAAU,CAAC,MAAM,KAAK,SAAS,EAAE,CAAC;QACxC,MAAM,IAAI,iBAAQ,CAAC,oBAAoB,EAAE;YACvC,KAAK,EAAE,EAAE,SAAS,EAAE,gBAAgB,EAAE,GAAG,CAAC,UAAU,CAAC,MAAM,EAAE;SAC9D,CAAC,CAAC;IACL,CAAC;IAED,OAAO,EAAE,oBAAoB,EAAE,GAAG,CAAC,UAAU,EAAE,CAAC;AAClD,CAAC,CAAC;AAlBW,QAAA,uBAAuB,2BAkBlC"}
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
import { CreateCekOptions, CreateCekResult, DecryptCekOptions, DecryptCekResult } from "../../../types/private";
|
|
2
|
+
export declare const _getOctKeyWrapEncryptionKey: ({ encryption, kryptos, }: CreateCekOptions) => CreateCekResult;
|
|
3
|
+
export declare const _getOctKeyWrapDecryptionKey: ({ hkdfSalt, kryptos, publicEncryptionKey, }: DecryptCekOptions) => DecryptCekResult;
|
|
4
|
+
//# sourceMappingURL=get-oct-key-wrap-keys.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"get-oct-key-wrap-keys.d.ts","sourceRoot":"","sources":["../../../../src/utils/private/oct/get-oct-key-wrap-keys.ts"],"names":[],"mappings":"AAGA,OAAO,EACL,gBAAgB,EAChB,eAAe,EACf,iBAAiB,EACjB,gBAAgB,EACjB,MAAM,wBAAwB,CAAC;AAMhC,eAAO,MAAM,2BAA2B,6BAGrC,gBAAgB,KAAG,eA0BrB,CAAC;AAEF,eAAO,MAAM,2BAA2B,gDAIrC,iBAAiB,KAAG,gBAuBtB,CAAC"}
|
|
@@ -0,0 +1,55 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports._getOctKeyWrapDecryptionKey = exports._getOctKeyWrapEncryptionKey = void 0;
|
|
4
|
+
const kryptos_1 = require("@lindorm/kryptos");
|
|
5
|
+
const crypto_1 = require("crypto");
|
|
6
|
+
const errors_1 = require("../../../errors");
|
|
7
|
+
const calculate_content_encryption_key_size_1 = require("../calculate/calculate-content-encryption-key-size");
|
|
8
|
+
const calculate_key_wrap_size_1 = require("../calculate/calculate-key-wrap-size");
|
|
9
|
+
const hkdf_1 = require("../key-derivation/hkdf");
|
|
10
|
+
const key_wrap_1 = require("../key-wrap/key-wrap");
|
|
11
|
+
const _getOctKeyWrapEncryptionKey = ({ encryption, kryptos, }) => {
|
|
12
|
+
if (!kryptos_1.Kryptos.isOct(kryptos)) {
|
|
13
|
+
throw new errors_1.AesError("Invalid Kryptos", { debug: { kryptos: kryptos.toJSON() } });
|
|
14
|
+
}
|
|
15
|
+
const der = kryptos.export("der");
|
|
16
|
+
const cekSize = (0, calculate_content_encryption_key_size_1._calculateContentEncryptionKeySize)(encryption);
|
|
17
|
+
const contentEncryptionKey = (0, crypto_1.randomBytes)(cekSize);
|
|
18
|
+
const { derivedKey, hkdfSalt } = (0, hkdf_1._hkdf)({
|
|
19
|
+
derivationKey: der.privateKey,
|
|
20
|
+
keyLength: (0, calculate_key_wrap_size_1._calculateKeyWrapSize)(kryptos.algorithm),
|
|
21
|
+
});
|
|
22
|
+
const publicEncryptionKey = (0, key_wrap_1._aesKeyWrap)({
|
|
23
|
+
contentEncryptionKey,
|
|
24
|
+
kryptos,
|
|
25
|
+
keyEncryptionKey: derivedKey,
|
|
26
|
+
});
|
|
27
|
+
return {
|
|
28
|
+
contentEncryptionKey,
|
|
29
|
+
hkdfSalt,
|
|
30
|
+
publicEncryptionKey,
|
|
31
|
+
};
|
|
32
|
+
};
|
|
33
|
+
exports._getOctKeyWrapEncryptionKey = _getOctKeyWrapEncryptionKey;
|
|
34
|
+
const _getOctKeyWrapDecryptionKey = ({ hkdfSalt, kryptos, publicEncryptionKey, }) => {
|
|
35
|
+
if (!kryptos_1.Kryptos.isOct(kryptos)) {
|
|
36
|
+
throw new errors_1.AesError("Invalid Kryptos", { debug: { kryptos: kryptos.toJSON() } });
|
|
37
|
+
}
|
|
38
|
+
if (!publicEncryptionKey) {
|
|
39
|
+
throw new errors_1.AesError("Missing publicEncryptionKey");
|
|
40
|
+
}
|
|
41
|
+
const der = kryptos.export("der");
|
|
42
|
+
const { derivedKey } = (0, hkdf_1._hkdf)({
|
|
43
|
+
derivationKey: der.privateKey,
|
|
44
|
+
hkdfSalt,
|
|
45
|
+
keyLength: (0, calculate_key_wrap_size_1._calculateKeyWrapSize)(kryptos.algorithm),
|
|
46
|
+
});
|
|
47
|
+
const unwrappedKey = (0, key_wrap_1._aesKeyUnwrap)({
|
|
48
|
+
keyEncryptionKey: derivedKey,
|
|
49
|
+
kryptos,
|
|
50
|
+
wrappedKey: publicEncryptionKey,
|
|
51
|
+
});
|
|
52
|
+
return { contentEncryptionKey: unwrappedKey };
|
|
53
|
+
};
|
|
54
|
+
exports._getOctKeyWrapDecryptionKey = _getOctKeyWrapDecryptionKey;
|
|
55
|
+
//# sourceMappingURL=get-oct-key-wrap-keys.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"get-oct-key-wrap-keys.js","sourceRoot":"","sources":["../../../../src/utils/private/oct/get-oct-key-wrap-keys.ts"],"names":[],"mappings":";;;AAAA,8CAA2C;AAC3C,mCAAqC;AACrC,4CAA2C;AAO3C,8GAAwG;AACxG,kFAA6E;AAC7E,iDAA+C;AAC/C,mDAAkE;AAE3D,MAAM,2BAA2B,GAAG,CAAC,EAC1C,UAAU,EACV,OAAO,GACU,EAAmB,EAAE;IACtC,IAAI,CAAC,iBAAO,CAAC,KAAK,CAAC,OAAO,CAAC,EAAE,CAAC;QAC5B,MAAM,IAAI,iBAAQ,CAAC,iBAAiB,EAAE,EAAE,KAAK,EAAE,EAAE,OAAO,EAAE,OAAO,CAAC,MAAM,EAAE,EAAE,EAAE,CAAC,CAAC;IAClF,CAAC;IAED,MAAM,GAAG,GAAG,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;IAElC,MAAM,OAAO,GAAG,IAAA,0EAAkC,EAAC,UAAU,CAAC,CAAC;IAC/D,MAAM,oBAAoB,GAAG,IAAA,oBAAW,EAAC,OAAO,CAAC,CAAC;IAElD,MAAM,EAAE,UAAU,EAAE,QAAQ,EAAE,GAAG,IAAA,YAAK,EAAC;QACrC,aAAa,EAAE,GAAG,CAAC,UAAU;QAC7B,SAAS,EAAE,IAAA,+CAAqB,EAAC,OAAO,CAAC,SAAS,CAAC;KACpD,CAAC,CAAC;IAEH,MAAM,mBAAmB,GAAG,IAAA,sBAAW,EAAC;QACtC,oBAAoB;QACpB,OAAO;QACP,gBAAgB,EAAE,UAAU;KAC7B,CAAC,CAAC;IAEH,OAAO;QACL,oBAAoB;QACpB,QAAQ;QACR,mBAAmB;KACpB,CAAC;AACJ,CAAC,CAAC;AA7BW,QAAA,2BAA2B,+BA6BtC;AAEK,MAAM,2BAA2B,GAAG,CAAC,EAC1C,QAAQ,EACR,OAAO,EACP,mBAAmB,GACD,EAAoB,EAAE;IACxC,IAAI,CAAC,iBAAO,CAAC,KAAK,CAAC,OAAO,CAAC,EAAE,CAAC;QAC5B,MAAM,IAAI,iBAAQ,CAAC,iBAAiB,EAAE,EAAE,KAAK,EAAE,EAAE,OAAO,EAAE,OAAO,CAAC,MAAM,EAAE,EAAE,EAAE,CAAC,CAAC;IAClF,CAAC;IACD,IAAI,CAAC,mBAAmB,EAAE,CAAC;QACzB,MAAM,IAAI,iBAAQ,CAAC,6BAA6B,CAAC,CAAC;IACpD,CAAC;IAED,MAAM,GAAG,GAAG,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;IAElC,MAAM,EAAE,UAAU,EAAE,GAAG,IAAA,YAAK,EAAC;QAC3B,aAAa,EAAE,GAAG,CAAC,UAAU;QAC7B,QAAQ;QACR,SAAS,EAAE,IAAA,+CAAqB,EAAC,OAAO,CAAC,SAAS,CAAC;KACpD,CAAC,CAAC;IAEH,MAAM,YAAY,GAAG,IAAA,wBAAa,EAAC;QACjC,gBAAgB,EAAE,UAAU;QAC5B,OAAO;QACP,UAAU,EAAE,mBAAmB;KAChC,CAAC,CAAC;IAEH,OAAO,EAAE,oBAAoB,EAAE,YAAY,EAAE,CAAC;AAChD,CAAC,CAAC;AA3BW,QAAA,2BAA2B,+BA2BtC"}
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
import { CreateCekOptions, CreateCekResult, DecryptCekOptions, DecryptCekResult } from "../../../types/private";
|
|
2
|
+
export declare const _getOctPbkdfKeyWrapEncryptionKey: ({ encryption, kryptos, }: CreateCekOptions) => CreateCekResult;
|
|
3
|
+
export declare const _getOctPbkdfKeyWrapDecryptionKey: ({ kryptos, pbkdfIterations, pbkdfSalt, publicEncryptionKey, }: DecryptCekOptions) => DecryptCekResult;
|
|
4
|
+
//# sourceMappingURL=get-oct-pbkdf-key-wrap-keys.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"get-oct-pbkdf-key-wrap-keys.d.ts","sourceRoot":"","sources":["../../../../src/utils/private/oct/get-oct-pbkdf-key-wrap-keys.ts"],"names":[],"mappings":"AAGA,OAAO,EACL,gBAAgB,EAChB,eAAe,EACf,iBAAiB,EACjB,gBAAgB,EACjB,MAAM,wBAAwB,CAAC;AAOhC,eAAO,MAAM,gCAAgC,6BAG1C,gBAAgB,KAAG,eA4BrB,CAAC;AAEF,eAAO,MAAM,gCAAgC,kEAK1C,iBAAiB,KAAG,gBAyBtB,CAAC"}
|
|
@@ -0,0 +1,60 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports._getOctPbkdfKeyWrapDecryptionKey = exports._getOctPbkdfKeyWrapEncryptionKey = void 0;
|
|
4
|
+
const kryptos_1 = require("@lindorm/kryptos");
|
|
5
|
+
const crypto_1 = require("crypto");
|
|
6
|
+
const errors_1 = require("../../../errors");
|
|
7
|
+
const calculate_content_encryption_key_size_1 = require("../calculate/calculate-content-encryption-key-size");
|
|
8
|
+
const calculate_key_wrap_size_1 = require("../calculate/calculate-key-wrap-size");
|
|
9
|
+
const calculate_pbkdf_hash_1 = require("../calculate/calculate-pbkdf-hash");
|
|
10
|
+
const pbkdf_1 = require("../key-derivation/pbkdf");
|
|
11
|
+
const key_wrap_1 = require("../key-wrap/key-wrap");
|
|
12
|
+
const _getOctPbkdfKeyWrapEncryptionKey = ({ encryption, kryptos, }) => {
|
|
13
|
+
if (!kryptos_1.Kryptos.isOct(kryptos)) {
|
|
14
|
+
throw new errors_1.AesError("Invalid Kryptos", { debug: { kryptos: kryptos.toJSON() } });
|
|
15
|
+
}
|
|
16
|
+
const der = kryptos.export("der");
|
|
17
|
+
const cekSize = (0, calculate_content_encryption_key_size_1._calculateContentEncryptionKeySize)(encryption);
|
|
18
|
+
const contentEncryptionKey = (0, crypto_1.randomBytes)(cekSize);
|
|
19
|
+
const { derivedKey, pbkdfIterations, pbkdfSalt } = (0, pbkdf_1._pbkdf)({
|
|
20
|
+
derivationKey: der.privateKey,
|
|
21
|
+
keyLength: (0, calculate_key_wrap_size_1._calculateKeyWrapSize)(kryptos.algorithm),
|
|
22
|
+
algorithm: (0, calculate_pbkdf_hash_1._calculatePbkdfAlgorithm)(kryptos),
|
|
23
|
+
});
|
|
24
|
+
const publicEncryptionKey = (0, key_wrap_1._aesKeyWrap)({
|
|
25
|
+
contentEncryptionKey,
|
|
26
|
+
kryptos,
|
|
27
|
+
keyEncryptionKey: derivedKey,
|
|
28
|
+
});
|
|
29
|
+
return {
|
|
30
|
+
contentEncryptionKey,
|
|
31
|
+
pbkdfIterations,
|
|
32
|
+
pbkdfSalt,
|
|
33
|
+
publicEncryptionKey,
|
|
34
|
+
};
|
|
35
|
+
};
|
|
36
|
+
exports._getOctPbkdfKeyWrapEncryptionKey = _getOctPbkdfKeyWrapEncryptionKey;
|
|
37
|
+
const _getOctPbkdfKeyWrapDecryptionKey = ({ kryptos, pbkdfIterations, pbkdfSalt, publicEncryptionKey, }) => {
|
|
38
|
+
if (!kryptos_1.Kryptos.isOct(kryptos)) {
|
|
39
|
+
throw new errors_1.AesError("Invalid Kryptos", { debug: { kryptos: kryptos.toJSON() } });
|
|
40
|
+
}
|
|
41
|
+
if (!publicEncryptionKey) {
|
|
42
|
+
throw new errors_1.AesError("Missing publicEncryptionKey");
|
|
43
|
+
}
|
|
44
|
+
const der = kryptos.export("der");
|
|
45
|
+
const { derivedKey } = (0, pbkdf_1._pbkdf)({
|
|
46
|
+
derivationKey: der.privateKey,
|
|
47
|
+
keyLength: (0, calculate_key_wrap_size_1._calculateKeyWrapSize)(kryptos.algorithm),
|
|
48
|
+
algorithm: (0, calculate_pbkdf_hash_1._calculatePbkdfAlgorithm)(kryptos),
|
|
49
|
+
pbkdfIterations,
|
|
50
|
+
pbkdfSalt,
|
|
51
|
+
});
|
|
52
|
+
const unwrappedKey = (0, key_wrap_1._aesKeyUnwrap)({
|
|
53
|
+
keyEncryptionKey: derivedKey,
|
|
54
|
+
kryptos,
|
|
55
|
+
wrappedKey: publicEncryptionKey,
|
|
56
|
+
});
|
|
57
|
+
return { contentEncryptionKey: unwrappedKey };
|
|
58
|
+
};
|
|
59
|
+
exports._getOctPbkdfKeyWrapDecryptionKey = _getOctPbkdfKeyWrapDecryptionKey;
|
|
60
|
+
//# sourceMappingURL=get-oct-pbkdf-key-wrap-keys.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"get-oct-pbkdf-key-wrap-keys.js","sourceRoot":"","sources":["../../../../src/utils/private/oct/get-oct-pbkdf-key-wrap-keys.ts"],"names":[],"mappings":";;;AAAA,8CAA2C;AAC3C,mCAAqC;AACrC,4CAA2C;AAO3C,8GAAwG;AACxG,kFAA6E;AAC7E,4EAA6E;AAC7E,mDAAiD;AACjD,mDAAkE;AAE3D,MAAM,gCAAgC,GAAG,CAAC,EAC/C,UAAU,EACV,OAAO,GACU,EAAmB,EAAE;IACtC,IAAI,CAAC,iBAAO,CAAC,KAAK,CAAC,OAAO,CAAC,EAAE,CAAC;QAC5B,MAAM,IAAI,iBAAQ,CAAC,iBAAiB,EAAE,EAAE,KAAK,EAAE,EAAE,OAAO,EAAE,OAAO,CAAC,MAAM,EAAE,EAAE,EAAE,CAAC,CAAC;IAClF,CAAC;IAED,MAAM,GAAG,GAAG,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;IAElC,MAAM,OAAO,GAAG,IAAA,0EAAkC,EAAC,UAAU,CAAC,CAAC;IAC/D,MAAM,oBAAoB,GAAG,IAAA,oBAAW,EAAC,OAAO,CAAC,CAAC;IAElD,MAAM,EAAE,UAAU,EAAE,eAAe,EAAE,SAAS,EAAE,GAAG,IAAA,cAAM,EAAC;QACxD,aAAa,EAAE,GAAG,CAAC,UAAU;QAC7B,SAAS,EAAE,IAAA,+CAAqB,EAAC,OAAO,CAAC,SAAS,CAAC;QACnD,SAAS,EAAE,IAAA,+CAAwB,EAAC,OAAO,CAAC;KAC7C,CAAC,CAAC;IAEH,MAAM,mBAAmB,GAAG,IAAA,sBAAW,EAAC;QACtC,oBAAoB;QACpB,OAAO;QACP,gBAAgB,EAAE,UAAU;KAC7B,CAAC,CAAC;IAEH,OAAO;QACL,oBAAoB;QACpB,eAAe;QACf,SAAS;QACT,mBAAmB;KACpB,CAAC;AACJ,CAAC,CAAC;AA/BW,QAAA,gCAAgC,oCA+B3C;AAEK,MAAM,gCAAgC,GAAG,CAAC,EAC/C,OAAO,EACP,eAAe,EACf,SAAS,EACT,mBAAmB,GACD,EAAoB,EAAE;IACxC,IAAI,CAAC,iBAAO,CAAC,KAAK,CAAC,OAAO,CAAC,EAAE,CAAC;QAC5B,MAAM,IAAI,iBAAQ,CAAC,iBAAiB,EAAE,EAAE,KAAK,EAAE,EAAE,OAAO,EAAE,OAAO,CAAC,MAAM,EAAE,EAAE,EAAE,CAAC,CAAC;IAClF,CAAC;IACD,IAAI,CAAC,mBAAmB,EAAE,CAAC;QACzB,MAAM,IAAI,iBAAQ,CAAC,6BAA6B,CAAC,CAAC;IACpD,CAAC;IAED,MAAM,GAAG,GAAG,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;IAElC,MAAM,EAAE,UAAU,EAAE,GAAG,IAAA,cAAM,EAAC;QAC5B,aAAa,EAAE,GAAG,CAAC,UAAU;QAC7B,SAAS,EAAE,IAAA,+CAAqB,EAAC,OAAO,CAAC,SAAS,CAAC;QACnD,SAAS,EAAE,IAAA,+CAAwB,EAAC,OAAO,CAAC;QAC5C,eAAe;QACf,SAAS;KACV,CAAC,CAAC;IAEH,MAAM,YAAY,GAAG,IAAA,wBAAa,EAAC;QACjC,gBAAgB,EAAE,UAAU;QAC5B,OAAO;QACP,UAAU,EAAE,mBAAmB;KAChC,CAAC,CAAC;IAEH,OAAO,EAAE,oBAAoB,EAAE,YAAY,EAAE,CAAC;AAChD,CAAC,CAAC;AA9BW,QAAA,gCAAgC,oCA8B3C"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@lindorm/aes",
|
|
3
|
-
"version": "0.
|
|
3
|
+
"version": "0.2.0",
|
|
4
4
|
"license": "AGPL-3.0-or-later",
|
|
5
5
|
"author": "Jonn Nilsson",
|
|
6
6
|
"repository": {
|
|
@@ -26,9 +26,12 @@
|
|
|
26
26
|
"update": "ncu -u"
|
|
27
27
|
},
|
|
28
28
|
"dependencies": {
|
|
29
|
-
"@lindorm/errors": "^0.1.
|
|
30
|
-
"@lindorm/is": "^0.1.
|
|
31
|
-
"@lindorm/kryptos": "^0.
|
|
29
|
+
"@lindorm/errors": "^0.1.5",
|
|
30
|
+
"@lindorm/is": "^0.1.5",
|
|
31
|
+
"@lindorm/kryptos": "^0.3.0"
|
|
32
32
|
},
|
|
33
|
-
"
|
|
33
|
+
"devDependencies": {
|
|
34
|
+
"@lindorm/types": "^0.1.4"
|
|
35
|
+
},
|
|
36
|
+
"gitHead": "677a485cb48b37f891f25a46f417b033cbfec9e2"
|
|
34
37
|
}
|
|
@@ -1,9 +0,0 @@
|
|
|
1
|
-
export declare enum AesEncryption {
|
|
2
|
-
AES_128_CBC = "aes-128-cbc",
|
|
3
|
-
AES_192_CBC = "aes-192-cbc",
|
|
4
|
-
AES_256_CBC = "aes-256-cbc",
|
|
5
|
-
AES_128_GCM = "aes-128-gcm",
|
|
6
|
-
AES_192_GCM = "aes-192-gcm",
|
|
7
|
-
AES_256_GCM = "aes-256-gcm"
|
|
8
|
-
}
|
|
9
|
-
//# sourceMappingURL=AesEncryption.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"AesEncryption.d.ts","sourceRoot":"","sources":["../../src/enums/AesEncryption.ts"],"names":[],"mappings":"AAAA,oBAAY,aAAa;IAEvB,WAAW,gBAAgB;IAC3B,WAAW,gBAAgB;IAC3B,WAAW,gBAAgB;IAG3B,WAAW,gBAAgB;IAC3B,WAAW,gBAAgB;IAC3B,WAAW,gBAAgB;CAC5B"}
|
|
@@ -1,13 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.AesEncryption = void 0;
|
|
4
|
-
var AesEncryption;
|
|
5
|
-
(function (AesEncryption) {
|
|
6
|
-
AesEncryption["AES_128_CBC"] = "aes-128-cbc";
|
|
7
|
-
AesEncryption["AES_192_CBC"] = "aes-192-cbc";
|
|
8
|
-
AesEncryption["AES_256_CBC"] = "aes-256-cbc";
|
|
9
|
-
AesEncryption["AES_128_GCM"] = "aes-128-gcm";
|
|
10
|
-
AesEncryption["AES_192_GCM"] = "aes-192-gcm";
|
|
11
|
-
AesEncryption["AES_256_GCM"] = "aes-256-gcm";
|
|
12
|
-
})(AesEncryption || (exports.AesEncryption = AesEncryption = {}));
|
|
13
|
-
//# sourceMappingURL=AesEncryption.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"AesEncryption.js","sourceRoot":"","sources":["../../src/enums/AesEncryption.ts"],"names":[],"mappings":";;;AAAA,IAAY,aAUX;AAVD,WAAY,aAAa;IAEvB,4CAA2B,CAAA;IAC3B,4CAA2B,CAAA;IAC3B,4CAA2B,CAAA;IAG3B,4CAA2B,CAAA;IAC3B,4CAA2B,CAAA;IAC3B,4CAA2B,CAAA;AAC7B,CAAC,EAVW,aAAa,6BAAb,aAAa,QAUxB"}
|
|
@@ -1,9 +0,0 @@
|
|
|
1
|
-
export declare enum AesEncryptionKeyAlgorithm {
|
|
2
|
-
ECDH_ES = "ECDH-ES",
|
|
3
|
-
RSA_OAEP = "RSA-OAEP",
|
|
4
|
-
RSA_OAEP_256 = "RSA-OAEP-256",
|
|
5
|
-
RSA_OAEP_384 = "RSA-OAEP-384",
|
|
6
|
-
RSA_OAEP_512 = "RSA-OAEP-512",
|
|
7
|
-
RSA_PRIVATE_KEY = "RSA-PRIVATE-KEY"
|
|
8
|
-
}
|
|
9
|
-
//# sourceMappingURL=AesEncryptionKeyAlgorithm.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"AesEncryptionKeyAlgorithm.d.ts","sourceRoot":"","sources":["../../src/enums/AesEncryptionKeyAlgorithm.ts"],"names":[],"mappings":"AAAA,oBAAY,yBAAyB;IAEnC,OAAO,YAAY;IAGnB,QAAQ,aAAa;IACrB,YAAY,iBAAiB;IAC7B,YAAY,iBAAiB;IAC7B,YAAY,iBAAiB;IAC7B,eAAe,oBAAoB;CACpC"}
|
|
@@ -1,13 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.AesEncryptionKeyAlgorithm = void 0;
|
|
4
|
-
var AesEncryptionKeyAlgorithm;
|
|
5
|
-
(function (AesEncryptionKeyAlgorithm) {
|
|
6
|
-
AesEncryptionKeyAlgorithm["ECDH_ES"] = "ECDH-ES";
|
|
7
|
-
AesEncryptionKeyAlgorithm["RSA_OAEP"] = "RSA-OAEP";
|
|
8
|
-
AesEncryptionKeyAlgorithm["RSA_OAEP_256"] = "RSA-OAEP-256";
|
|
9
|
-
AesEncryptionKeyAlgorithm["RSA_OAEP_384"] = "RSA-OAEP-384";
|
|
10
|
-
AesEncryptionKeyAlgorithm["RSA_OAEP_512"] = "RSA-OAEP-512";
|
|
11
|
-
AesEncryptionKeyAlgorithm["RSA_PRIVATE_KEY"] = "RSA-PRIVATE-KEY";
|
|
12
|
-
})(AesEncryptionKeyAlgorithm || (exports.AesEncryptionKeyAlgorithm = AesEncryptionKeyAlgorithm = {}));
|
|
13
|
-
//# sourceMappingURL=AesEncryptionKeyAlgorithm.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"AesEncryptionKeyAlgorithm.js","sourceRoot":"","sources":["../../src/enums/AesEncryptionKeyAlgorithm.ts"],"names":[],"mappings":";;;AAAA,IAAY,yBAUX;AAVD,WAAY,yBAAyB;IAEnC,gDAAmB,CAAA;IAGnB,kDAAqB,CAAA;IACrB,0DAA6B,CAAA;IAC7B,0DAA6B,CAAA;IAC7B,0DAA6B,CAAA;IAC7B,gEAAmC,CAAA;AACrC,CAAC,EAVW,yBAAyB,yCAAzB,yBAAyB,QAUpC"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"AesFormat.d.ts","sourceRoot":"","sources":["../../src/enums/AesFormat.ts"],"names":[],"mappings":"AAAA,oBAAY,SAAS;IACnB,MAAM,WAAW;IACjB,UAAU,cAAc;IACxB,GAAG,QAAQ;CACZ"}
|
package/dist/enums/AesFormat.js
DELETED
|
@@ -1,10 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.AesFormat = void 0;
|
|
4
|
-
var AesFormat;
|
|
5
|
-
(function (AesFormat) {
|
|
6
|
-
AesFormat["BASE64"] = "base64";
|
|
7
|
-
AesFormat["BASE64_URL"] = "base64url";
|
|
8
|
-
AesFormat["HEX"] = "hex";
|
|
9
|
-
})(AesFormat || (exports.AesFormat = AesFormat = {}));
|
|
10
|
-
//# sourceMappingURL=AesFormat.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"AesFormat.js","sourceRoot":"","sources":["../../src/enums/AesFormat.ts"],"names":[],"mappings":";;;AAAA,IAAY,SAIX;AAJD,WAAY,SAAS;IACnB,8BAAiB,CAAA;IACjB,qCAAwB,CAAA;IACxB,wBAAW,CAAA;AACb,CAAC,EAJW,SAAS,yBAAT,SAAS,QAIpB"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"AesIntegrityHash.d.ts","sourceRoot":"","sources":["../../src/enums/AesIntegrityHash.ts"],"names":[],"mappings":"AAAA,oBAAY,gBAAgB;IAC1B,MAAM,WAAW;IACjB,MAAM,WAAW;IACjB,MAAM,WAAW;CAClB"}
|
|
@@ -1,10 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.AesIntegrityHash = void 0;
|
|
4
|
-
var AesIntegrityHash;
|
|
5
|
-
(function (AesIntegrityHash) {
|
|
6
|
-
AesIntegrityHash["SHA256"] = "sha256";
|
|
7
|
-
AesIntegrityHash["SHA384"] = "sha384";
|
|
8
|
-
AesIntegrityHash["SHA512"] = "sha512";
|
|
9
|
-
})(AesIntegrityHash || (exports.AesIntegrityHash = AesIntegrityHash = {}));
|
|
10
|
-
//# sourceMappingURL=AesIntegrityHash.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"AesIntegrityHash.js","sourceRoot":"","sources":["../../src/enums/AesIntegrityHash.ts"],"names":[],"mappings":";;;AAAA,IAAY,gBAIX;AAJD,WAAY,gBAAgB;IAC1B,qCAAiB,CAAA;IACjB,qCAAiB,CAAA;IACjB,qCAAiB,CAAA;AACnB,CAAC,EAJW,gBAAgB,gCAAhB,gBAAgB,QAI3B"}
|
package/dist/enums/index.d.ts
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/enums/index.ts"],"names":[],"mappings":"AAAA,cAAc,iBAAiB,CAAC;AAChC,cAAc,6BAA6B,CAAC;AAC5C,cAAc,aAAa,CAAC;AAC5B,cAAc,oBAAoB,CAAC"}
|
package/dist/enums/index.js.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/enums/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,kDAAgC;AAChC,8DAA4C;AAC5C,8CAA4B;AAC5B,qDAAmC"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"auth-tag.d.ts","sourceRoot":"","sources":["../../src/types/auth-tag.ts"],"names":[],"mappings":";;AAAA,OAAO,EAAE,MAAM,EAAE,SAAS,EAAE,QAAQ,EAAE,WAAW,EAAE,MAAM,QAAQ,CAAC;AAClE,OAAO,EAAE,UAAU,EAAE,aAAa,EAAE,MAAM,SAAS,CAAC;AAEpD,MAAM,MAAM,iBAAiB,GAAG;IAC9B,MAAM,EAAE,MAAM,GAAG,SAAS,CAAC;IAC3B,OAAO,EAAE,MAAM,CAAC;IAChB,UAAU,EAAE,UAAU,CAAC;IACvB,aAAa,EAAE,MAAM,CAAC;IACtB,oBAAoB,EAAE,MAAM,CAAC;IAC7B,aAAa,CAAC,EAAE,aAAa,CAAC;CAC/B,CAAC;AAEF,MAAM,MAAM,iBAAiB,GAAG;IAC9B,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,OAAO,EAAE,MAAM,CAAC;IAChB,QAAQ,EAAE,QAAQ,GAAG,WAAW,CAAC;IACjC,aAAa,EAAE,MAAM,CAAC;IACtB,UAAU,EAAE,UAAU,CAAC;IACvB,oBAAoB,EAAE,MAAM,CAAC;IAC7B,aAAa,CAAC,EAAE,aAAa,CAAC;CAC/B,CAAC;AAEF,MAAM,MAAM,iBAAiB,GAAG;IAC9B,OAAO,EAAE,MAAM,CAAC;IAChB,aAAa,EAAE,MAAM,CAAC;IACtB,oBAAoB,EAAE,MAAM,CAAC;IAC7B,aAAa,EAAE,aAAa,CAAC;CAC9B,CAAC;AAEF,MAAM,MAAM,iBAAiB,GAAG,iBAAiB,GAAG;IAAE,OAAO,EAAE,MAAM,CAAA;CAAE,CAAC"}
|
|
@@ -1,5 +0,0 @@
|
|
|
1
|
-
/// <reference types="node" />
|
|
2
|
-
import { CreateHmacAuthTag, VerifyHmacAuthTag } from "../../types/auth-tag";
|
|
3
|
-
export declare const createHmacAuthTag: ({ content, encryptionKey, initialisationVector, integrityHash, }: CreateHmacAuthTag) => Buffer;
|
|
4
|
-
export declare const verifyHmacAuthTag: ({ authTag, content, encryptionKey, initialisationVector, integrityHash, }: VerifyHmacAuthTag) => void;
|
|
5
|
-
//# sourceMappingURL=auth-tag-hmac.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"auth-tag-hmac.d.ts","sourceRoot":"","sources":["../../../src/utils/private/auth-tag-hmac.ts"],"names":[],"mappings":";AAEA,OAAO,EAAE,iBAAiB,EAAE,iBAAiB,EAAE,MAAM,sBAAsB,CAAC;AAE5E,eAAO,MAAM,iBAAiB,qEAK3B,iBAAiB,KAAG,MAOtB,CAAC;AAEF,eAAO,MAAM,iBAAiB,8EAM3B,iBAAiB,KAAG,IAWtB,CAAC"}
|
|
@@ -1,25 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.verifyHmacAuthTag = exports.createHmacAuthTag = void 0;
|
|
4
|
-
const crypto_1 = require("crypto");
|
|
5
|
-
const errors_1 = require("../../errors");
|
|
6
|
-
const createHmacAuthTag = ({ content, encryptionKey, initialisationVector, integrityHash = "sha256", }) => {
|
|
7
|
-
const hmac = (0, crypto_1.createHmac)(integrityHash, encryptionKey);
|
|
8
|
-
hmac.update(initialisationVector);
|
|
9
|
-
hmac.update(content);
|
|
10
|
-
return hmac.digest();
|
|
11
|
-
};
|
|
12
|
-
exports.createHmacAuthTag = createHmacAuthTag;
|
|
13
|
-
const verifyHmacAuthTag = ({ authTag, content, encryptionKey, initialisationVector, integrityHash, }) => {
|
|
14
|
-
const generated = (0, exports.createHmacAuthTag)({
|
|
15
|
-
content,
|
|
16
|
-
encryptionKey,
|
|
17
|
-
initialisationVector,
|
|
18
|
-
integrityHash,
|
|
19
|
-
});
|
|
20
|
-
if (Buffer.compare(generated, authTag) === 0)
|
|
21
|
-
return;
|
|
22
|
-
throw new errors_1.AesError("Auth tag verification failed");
|
|
23
|
-
};
|
|
24
|
-
exports.verifyHmacAuthTag = verifyHmacAuthTag;
|
|
25
|
-
//# sourceMappingURL=auth-tag-hmac.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"auth-tag-hmac.js","sourceRoot":"","sources":["../../../src/utils/private/auth-tag-hmac.ts"],"names":[],"mappings":";;;AAAA,mCAAoC;AACpC,yCAAwC;AAGjC,MAAM,iBAAiB,GAAG,CAAC,EAChC,OAAO,EACP,aAAa,EACb,oBAAoB,EACpB,aAAa,GAAG,QAAQ,GACN,EAAU,EAAE;IAC9B,MAAM,IAAI,GAAG,IAAA,mBAAU,EAAC,aAAa,EAAE,aAAa,CAAC,CAAC;IAEtD,IAAI,CAAC,MAAM,CAAC,oBAAoB,CAAC,CAAC;IAClC,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC;IAErB,OAAO,IAAI,CAAC,MAAM,EAAE,CAAC;AACvB,CAAC,CAAC;AAZW,QAAA,iBAAiB,qBAY5B;AAEK,MAAM,iBAAiB,GAAG,CAAC,EAChC,OAAO,EACP,OAAO,EACP,aAAa,EACb,oBAAoB,EACpB,aAAa,GACK,EAAQ,EAAE;IAC5B,MAAM,SAAS,GAAG,IAAA,yBAAiB,EAAC;QAClC,OAAO;QACP,aAAa;QACb,oBAAoB;QACpB,aAAa;KACd,CAAC,CAAC;IAEH,IAAI,MAAM,CAAC,OAAO,CAAC,SAAS,EAAE,OAAO,CAAC,KAAK,CAAC;QAAE,OAAO;IAErD,MAAM,IAAI,iBAAQ,CAAC,8BAA8B,CAAC,CAAC;AACrD,CAAC,CAAC;AAjBW,QAAA,iBAAiB,qBAiB5B"}
|
|
@@ -1,5 +0,0 @@
|
|
|
1
|
-
/// <reference types="node" />
|
|
2
|
-
import { GetAuthTagOptions, SetAuthTagOptions } from "../../types/auth-tag";
|
|
3
|
-
export declare const _getAuthTag: ({ encryption: algorithm, cipher, content, encryptionKey, initialisationVector, integrityHash, }: GetAuthTagOptions) => Buffer | undefined;
|
|
4
|
-
export declare const _setAuthTag: ({ encryption: algorithm, authTag, content, decipher, decryptionKey, initialisationVector, integrityHash, }: SetAuthTagOptions) => void;
|
|
5
|
-
//# sourceMappingURL=auth-tag.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"auth-tag.d.ts","sourceRoot":"","sources":["../../../src/utils/private/auth-tag.ts"],"names":[],"mappings":";AAEA,OAAO,EAAE,iBAAiB,EAAE,iBAAiB,EAAE,MAAM,sBAAsB,CAAC;AAG5E,eAAO,MAAM,WAAW,oGAOrB,iBAAiB,KAAG,MAAM,GAAG,SAuB/B,CAAC;AAEF,eAAO,MAAM,WAAW,+GAQrB,iBAAiB,KAAG,IA6BtB,CAAC"}
|