@lindorm/aes 0.5.5 → 0.6.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.
Files changed (165) hide show
  1. package/CHANGELOG.md +26 -0
  2. package/MERMAID.md +155 -0
  3. package/README.md +365 -199
  4. package/__tests__/INTEROP-RESULTS.md +66 -0
  5. package/__tests__/esm-smoke.test.ts +15 -0
  6. package/__tests__/fixtures/keys.ts +60 -0
  7. package/__tests__/helpers/buffer-utils.ts +11 -0
  8. package/__tests__/helpers/index.ts +2 -0
  9. package/__tests__/helpers/jwe-adapter.ts +117 -0
  10. package/__tests__/jose-jwe.test.ts +463 -0
  11. package/__tests__/noble-ciphers.test.ts +208 -0
  12. package/dist/classes/AesKit.d.ts +10 -8
  13. package/dist/classes/AesKit.d.ts.map +1 -1
  14. package/dist/classes/AesKit.js +73 -34
  15. package/dist/classes/AesKit.js.map +1 -1
  16. package/dist/constants/private/index.d.ts +0 -1
  17. package/dist/constants/private/index.d.ts.map +1 -1
  18. package/dist/constants/private/index.js +0 -1
  19. package/dist/constants/private/index.js.map +1 -1
  20. package/dist/constants/private/version.d.ts +3 -1
  21. package/dist/constants/private/version.d.ts.map +1 -1
  22. package/dist/constants/private/version.js +4 -2
  23. package/dist/constants/private/version.js.map +1 -1
  24. package/dist/interfaces/AesKit.d.ts +12 -7
  25. package/dist/interfaces/AesKit.d.ts.map +1 -1
  26. package/dist/mocks/mock-aes-kit.d.ts.map +1 -1
  27. package/dist/mocks/mock-aes-kit.js +12 -2
  28. package/dist/mocks/mock-aes-kit.js.map +1 -1
  29. package/dist/types/aes-decryption-data.d.ts +26 -17
  30. package/dist/types/aes-decryption-data.d.ts.map +1 -1
  31. package/dist/types/aes-encryption-data.d.ts +7 -17
  32. package/dist/types/aes-encryption-data.d.ts.map +1 -1
  33. package/dist/types/index.d.ts +1 -0
  34. package/dist/types/index.d.ts.map +1 -1
  35. package/dist/types/private/aes-data.d.ts.map +1 -1
  36. package/dist/types/private/aes-key-derivation.d.ts +1 -1
  37. package/dist/types/private/aes-key-derivation.d.ts.map +1 -1
  38. package/dist/types/private/auth-tag.d.ts +3 -0
  39. package/dist/types/private/auth-tag.d.ts.map +1 -1
  40. package/dist/types/private/content-encryption-key.d.ts +4 -2
  41. package/dist/types/private/content-encryption-key.d.ts.map +1 -1
  42. package/dist/types/private/index.d.ts +1 -1
  43. package/dist/types/private/index.d.ts.map +1 -1
  44. package/dist/types/private/index.js +1 -1
  45. package/dist/types/private/index.js.map +1 -1
  46. package/dist/types/private/prepared-encryption.d.ts +35 -0
  47. package/dist/types/private/prepared-encryption.d.ts.map +1 -0
  48. package/dist/types/private/{aes-string.js → prepared-encryption.js} +1 -1
  49. package/dist/types/private/prepared-encryption.js.map +1 -0
  50. package/dist/utils/is-aes.d.ts.map +1 -1
  51. package/dist/utils/is-aes.js +1 -5
  52. package/dist/utils/is-aes.js.map +1 -1
  53. package/dist/utils/parse-aes.js +3 -3
  54. package/dist/utils/parse-aes.js.map +1 -1
  55. package/dist/utils/private/aes-header.d.ts +42 -0
  56. package/dist/utils/private/aes-header.d.ts.map +1 -0
  57. package/dist/utils/private/aes-header.js +75 -0
  58. package/dist/utils/private/aes-header.js.map +1 -0
  59. package/dist/utils/private/calculate/calculate-content-encryption-key-size.js +3 -3
  60. package/dist/utils/private/calculate/calculate-key-wrap-encryption.d.ts.map +1 -1
  61. package/dist/utils/private/calculate/calculate-key-wrap-encryption.js +2 -1
  62. package/dist/utils/private/calculate/calculate-key-wrap-encryption.js.map +1 -1
  63. package/dist/utils/private/data/auth-tag-hmac.d.ts +2 -2
  64. package/dist/utils/private/data/auth-tag-hmac.d.ts.map +1 -1
  65. package/dist/utils/private/data/auth-tag-hmac.js +12 -4
  66. package/dist/utils/private/data/auth-tag-hmac.js.map +1 -1
  67. package/dist/utils/private/data/auth-tag.d.ts +2 -2
  68. package/dist/utils/private/data/auth-tag.d.ts.map +1 -1
  69. package/dist/utils/private/data/auth-tag.js +4 -2
  70. package/dist/utils/private/data/auth-tag.js.map +1 -1
  71. package/dist/utils/private/data/split-content-encryption-key.d.ts.map +1 -1
  72. package/dist/utils/private/data/split-content-encryption-key.js +6 -2
  73. package/dist/utils/private/data/split-content-encryption-key.js.map +1 -1
  74. package/dist/utils/private/diffie-hellman/diffie-hellman-key-wrap.d.ts +2 -2
  75. package/dist/utils/private/diffie-hellman/diffie-hellman-key-wrap.d.ts.map +1 -1
  76. package/dist/utils/private/diffie-hellman/diffie-hellman-key-wrap.js +12 -8
  77. package/dist/utils/private/diffie-hellman/diffie-hellman-key-wrap.js.map +1 -1
  78. package/dist/utils/private/diffie-hellman/diffie-hellman.d.ts +2 -2
  79. package/dist/utils/private/diffie-hellman/diffie-hellman.d.ts.map +1 -1
  80. package/dist/utils/private/diffie-hellman/diffie-hellman.js +12 -8
  81. package/dist/utils/private/diffie-hellman/diffie-hellman.js.map +1 -1
  82. package/dist/utils/private/diffie-hellman/shared-secret.d.ts.map +1 -1
  83. package/dist/utils/private/diffie-hellman/shared-secret.js +5 -1
  84. package/dist/utils/private/diffie-hellman/shared-secret.js.map +1 -1
  85. package/dist/utils/private/encoded-aes.d.ts +2 -2
  86. package/dist/utils/private/encoded-aes.d.ts.map +1 -1
  87. package/dist/utils/private/encoded-aes.js +86 -149
  88. package/dist/utils/private/encoded-aes.js.map +1 -1
  89. package/dist/utils/private/encrypt-content.d.ts +3 -0
  90. package/dist/utils/private/encrypt-content.d.ts.map +1 -0
  91. package/dist/utils/private/encrypt-content.js +35 -0
  92. package/dist/utils/private/encrypt-content.js.map +1 -0
  93. package/dist/utils/private/encrypt-encoded.d.ts +9 -0
  94. package/dist/utils/private/encrypt-encoded.d.ts.map +1 -0
  95. package/dist/utils/private/encrypt-encoded.js +53 -0
  96. package/dist/utils/private/encrypt-encoded.js.map +1 -0
  97. package/dist/utils/private/encrypt-serialised.d.ts +9 -0
  98. package/dist/utils/private/encrypt-serialised.d.ts.map +1 -0
  99. package/dist/utils/private/encrypt-serialised.js +48 -0
  100. package/dist/utils/private/encrypt-serialised.js.map +1 -0
  101. package/dist/utils/private/encrypt-tokenised.d.ts +9 -0
  102. package/dist/utils/private/encrypt-tokenised.d.ts.map +1 -0
  103. package/dist/utils/private/encrypt-tokenised.js +45 -0
  104. package/dist/utils/private/encrypt-tokenised.js.map +1 -0
  105. package/dist/utils/private/encryption.d.ts.map +1 -1
  106. package/dist/utils/private/encryption.js +27 -27
  107. package/dist/utils/private/encryption.js.map +1 -1
  108. package/dist/utils/private/index.d.ts +6 -0
  109. package/dist/utils/private/index.d.ts.map +1 -1
  110. package/dist/utils/private/index.js +6 -0
  111. package/dist/utils/private/index.js.map +1 -1
  112. package/dist/utils/private/key-derivation/concat-kdf.d.ts +14 -0
  113. package/dist/utils/private/key-derivation/concat-kdf.d.ts.map +1 -0
  114. package/dist/utils/private/key-derivation/concat-kdf.js +26 -0
  115. package/dist/utils/private/key-derivation/concat-kdf.js.map +1 -0
  116. package/dist/utils/private/key-derivation/index.d.ts +1 -1
  117. package/dist/utils/private/key-derivation/index.d.ts.map +1 -1
  118. package/dist/utils/private/key-derivation/index.js +1 -1
  119. package/dist/utils/private/key-derivation/index.js.map +1 -1
  120. package/dist/utils/private/key-derivation/pbkdf.d.ts +1 -0
  121. package/dist/utils/private/key-derivation/pbkdf.d.ts.map +1 -1
  122. package/dist/utils/private/key-derivation/pbkdf.js +13 -2
  123. package/dist/utils/private/key-derivation/pbkdf.js.map +1 -1
  124. package/dist/utils/private/key-wrap/ecb-key-wrap.d.ts.map +1 -1
  125. package/dist/utils/private/key-wrap/ecb-key-wrap.js +10 -3
  126. package/dist/utils/private/key-wrap/ecb-key-wrap.js.map +1 -1
  127. package/dist/utils/private/key-wrap/gcm-key-wrap.d.ts.map +1 -1
  128. package/dist/utils/private/key-wrap/gcm-key-wrap.js +6 -0
  129. package/dist/utils/private/key-wrap/gcm-key-wrap.js.map +1 -1
  130. package/dist/utils/private/oct/get-oct-key-key-wrap.d.ts +1 -1
  131. package/dist/utils/private/oct/get-oct-key-key-wrap.d.ts.map +1 -1
  132. package/dist/utils/private/oct/get-oct-key-key-wrap.js +7 -14
  133. package/dist/utils/private/oct/get-oct-key-key-wrap.js.map +1 -1
  134. package/dist/utils/private/oct/get-oct-pbkdf-key-wrap-keys.d.ts.map +1 -1
  135. package/dist/utils/private/oct/get-oct-pbkdf-key-wrap-keys.js +2 -0
  136. package/dist/utils/private/oct/get-oct-pbkdf-key-wrap-keys.js.map +1 -1
  137. package/dist/utils/private/prepare-encryption.d.ts +3 -0
  138. package/dist/utils/private/prepare-encryption.d.ts.map +1 -0
  139. package/dist/utils/private/prepare-encryption.js +27 -0
  140. package/dist/utils/private/prepare-encryption.js.map +1 -0
  141. package/dist/utils/private/serialised-aes.d.ts.map +1 -1
  142. package/dist/utils/private/serialised-aes.js +38 -46
  143. package/dist/utils/private/serialised-aes.js.map +1 -1
  144. package/dist/utils/private/tokenised-aes.d.ts +3 -3
  145. package/dist/utils/private/tokenised-aes.d.ts.map +1 -1
  146. package/dist/utils/private/tokenised-aes.js +73 -55
  147. package/dist/utils/private/tokenised-aes.js.map +1 -1
  148. package/dist/utils/private/validate-version.d.ts +2 -0
  149. package/dist/utils/private/validate-version.d.ts.map +1 -0
  150. package/dist/utils/private/validate-version.js +27 -0
  151. package/dist/utils/private/validate-version.js.map +1 -0
  152. package/jest.config.interop.mjs +24 -0
  153. package/package.json +16 -15
  154. package/tsconfig.interop.json +9 -0
  155. package/dist/constants/private/format.d.ts +0 -2
  156. package/dist/constants/private/format.d.ts.map +0 -1
  157. package/dist/constants/private/format.js +0 -5
  158. package/dist/constants/private/format.js.map +0 -1
  159. package/dist/types/private/aes-string.d.ts +0 -21
  160. package/dist/types/private/aes-string.d.ts.map +0 -1
  161. package/dist/types/private/aes-string.js.map +0 -1
  162. package/dist/utils/private/key-derivation/hkdf.d.ts +0 -13
  163. package/dist/utils/private/key-derivation/hkdf.d.ts.map +0 -1
  164. package/dist/utils/private/key-derivation/hkdf.js +0 -12
  165. package/dist/utils/private/key-derivation/hkdf.js.map +0 -1
@@ -1 +1 @@
1
- {"version":3,"file":"AesKit.d.ts","sourceRoot":"","sources":["../../src/classes/AesKit.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAqB,MAAM,kBAAkB,CAAC;AAE/D,OAAO,EAAE,OAAO,EAAE,MAAM,eAAe,CAAC;AACxC,OAAO,EACL,UAAU,EACV,cAAc,EACd,mBAAmB,EAEnB,mBAAmB,EACnB,aAAa,EACb,uBAAuB,EACvB,uBAAuB,EACxB,MAAM,UAAU,CAAC;AAWlB,qBAAa,MAAO,YAAW,OAAO;IACpC,OAAO,CAAC,QAAQ,CAAC,UAAU,CAAoB;IAC/C,SAAgB,OAAO,EAAE,QAAQ,CAAC;gBAEf,OAAO,EAAE,aAAa;IAKlC,OAAO,CAAC,IAAI,EAAE,UAAU,EAAE,IAAI,CAAC,EAAE,SAAS,GAAG,MAAM;IACnD,OAAO,CAAC,IAAI,EAAE,UAAU,EAAE,IAAI,EAAE,QAAQ,GAAG,mBAAmB;IAC9D,OAAO,CAAC,IAAI,EAAE,UAAU,EAAE,IAAI,EAAE,YAAY,GAAG,uBAAuB;IACtE,OAAO,CAAC,IAAI,EAAE,UAAU,EAAE,IAAI,EAAE,WAAW,GAAG,MAAM;IA6CpD,OAAO,CAAC,CAAC,SAAS,UAAU,GAAG,MAAM,EAC1C,IAAI,EAAE,mBAAmB,GAAG,uBAAuB,GAAG,MAAM,GAC3D,CAAC;IAIG,MAAM,CACX,KAAK,EAAE,MAAM,EACb,IAAI,EAAE,mBAAmB,GAAG,uBAAuB,GAAG,MAAM,GAC3D,OAAO;IAIH,MAAM,CACX,KAAK,EAAE,MAAM,EACb,IAAI,EAAE,mBAAmB,GAAG,uBAAuB,GAAG,MAAM,GAC3D,IAAI;WAOO,WAAW,CAAC,KAAK,EAAE,GAAG,GAAG,cAAc;WAIvC,cAAc,CAAC,KAAK,EAAE,GAAG,GAAG,KAAK,IAAI,MAAM;WAI3C,KAAK,CACjB,IAAI,EAAE,mBAAmB,GAAG,uBAAuB,GAAG,MAAM,GAC3D,mBAAmB;CAGvB"}
1
+ {"version":3,"file":"AesKit.d.ts","sourceRoot":"","sources":["../../src/classes/AesKit.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,QAAQ,EAAqB,MAAM,kBAAkB,CAAC;AAE/D,OAAO,EAAE,mBAAmB,EAAE,OAAO,EAAE,MAAM,eAAe,CAAC;AAC7D,OAAO,EACL,UAAU,EACV,cAAc,EACd,mBAAmB,EAEnB,mBAAmB,EACnB,aAAa,EACb,uBAAuB,EACvB,uBAAuB,EACxB,MAAM,UAAU,CAAC;AAClB,OAAO,EAAE,kBAAkB,EAAE,MAAM,kBAAkB,CAAC;AAQtD,qBAAa,MAAO,YAAW,OAAO;IACpC,OAAO,CAAC,QAAQ,CAAC,UAAU,CAAoB;IAC/C,SAAgB,OAAO,EAAE,QAAQ,CAAC;gBAEf,OAAO,EAAE,aAAa;IAKlC,OAAO,CACZ,IAAI,EAAE,UAAU,EAChB,IAAI,CAAC,EAAE,SAAS,EAChB,OAAO,CAAC,EAAE,mBAAmB,GAC5B,MAAM;IACF,OAAO,CACZ,IAAI,EAAE,UAAU,EAChB,IAAI,EAAE,QAAQ,EACd,OAAO,CAAC,EAAE,mBAAmB,GAC5B,mBAAmB;IACf,OAAO,CACZ,IAAI,EAAE,UAAU,EAChB,IAAI,EAAE,YAAY,EAClB,OAAO,CAAC,EAAE,mBAAmB,GAC5B,uBAAuB;IACnB,OAAO,CACZ,IAAI,EAAE,UAAU,EAChB,IAAI,EAAE,WAAW,EACjB,OAAO,CAAC,EAAE,mBAAmB,GAC5B,MAAM;IA6CF,OAAO,CAAC,CAAC,SAAS,UAAU,GAAG,MAAM,EAC1C,IAAI,EAAE,mBAAmB,GAAG,uBAAuB,GAAG,MAAM,EAC5D,OAAO,CAAC,EAAE,mBAAmB,GAC5B,CAAC;IAqBG,MAAM,CACX,KAAK,EAAE,UAAU,EACjB,IAAI,EAAE,mBAAmB,GAAG,uBAAuB,GAAG,MAAM,EAC5D,OAAO,CAAC,EAAE,mBAAmB,GAC5B,OAAO;IAQH,MAAM,CACX,KAAK,EAAE,UAAU,EACjB,IAAI,EAAE,mBAAmB,GAAG,uBAAuB,GAAG,MAAM,EAC5D,OAAO,CAAC,EAAE,mBAAmB,GAC5B,IAAI;IAKA,iBAAiB,IAAI,kBAAkB;WAWhC,WAAW,CAAC,KAAK,EAAE,GAAG,GAAG,cAAc;WAIvC,cAAc,CAAC,KAAK,EAAE,GAAG,GAAG,KAAK,IAAI,MAAM;WAI3C,KAAK,CACjB,IAAI,EAAE,mBAAmB,GAAG,uBAAuB,GAAG,MAAM,GAC3D,mBAAmB;CAGvB"}
@@ -1,10 +1,14 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.AesKit = void 0;
4
+ const is_1 = require("@lindorm/is");
4
5
  const errors_1 = require("../errors");
5
6
  const utils_1 = require("../utils");
6
7
  const private_1 = require("../utils/private");
7
8
  const content_1 = require("../utils/private/content");
9
+ const encrypt_encoded_1 = require("../utils/private/encrypt-encoded");
10
+ const encrypt_serialised_1 = require("../utils/private/encrypt-serialised");
11
+ const encrypt_tokenised_1 = require("../utils/private/encrypt-tokenised");
8
12
  class AesKit {
9
13
  encryption;
10
14
  kryptos;
@@ -12,47 +16,82 @@ class AesKit {
12
16
  this.kryptos = options.kryptos;
13
17
  this.encryption = options.encryption ?? options.kryptos.encryption ?? "A256GCM";
14
18
  }
15
- encrypt(data, mode = "encoded") {
16
- switch (mode) {
17
- case "encoded":
18
- return (0, private_1.createEncodedAesString)((0, private_1.encryptAes)({
19
- data,
20
- encryption: this.encryption,
21
- kryptos: this.kryptos,
22
- }));
23
- case "record":
24
- return (0, private_1.encryptAes)({
25
- data,
26
- encryption: this.encryption,
27
- kryptos: this.kryptos,
28
- });
29
- case "serialised":
30
- return (0, private_1.createSerialisedAesRecord)((0, private_1.encryptAes)({
31
- data,
32
- encryption: this.encryption,
33
- kryptos: this.kryptos,
34
- }));
35
- case "tokenised":
36
- return (0, private_1.createTokenisedAesString)((0, private_1.encryptAes)({
37
- data,
38
- encryption: this.encryption,
39
- kryptos: this.kryptos,
40
- }));
41
- default:
42
- throw new errors_1.AesError("Invalid encryption mode");
19
+ encrypt(data, mode = "encoded", _options) {
20
+ try {
21
+ switch (mode) {
22
+ case "encoded":
23
+ return (0, encrypt_encoded_1.encryptEncoded)({
24
+ data,
25
+ encryption: this.encryption,
26
+ kryptos: this.kryptos,
27
+ });
28
+ case "record":
29
+ return (0, private_1.encryptAes)({
30
+ data,
31
+ encryption: this.encryption,
32
+ kryptos: this.kryptos,
33
+ });
34
+ case "serialised":
35
+ return (0, encrypt_serialised_1.encryptSerialised)({
36
+ data,
37
+ encryption: this.encryption,
38
+ kryptos: this.kryptos,
39
+ });
40
+ case "tokenised":
41
+ return (0, encrypt_tokenised_1.encryptTokenised)({
42
+ data,
43
+ encryption: this.encryption,
44
+ kryptos: this.kryptos,
45
+ });
46
+ default:
47
+ throw new errors_1.AesError("Invalid encryption mode");
48
+ }
49
+ }
50
+ catch (error) {
51
+ if (error instanceof errors_1.AesError)
52
+ throw error;
53
+ throw new errors_1.AesError("AES encryption failed", { error: error });
43
54
  }
44
55
  }
45
- decrypt(data) {
46
- return (0, private_1.decryptAes)({ ...(0, utils_1.parseAes)(data), kryptos: this.kryptos });
56
+ decrypt(data, options) {
57
+ try {
58
+ const parsed = (0, utils_1.parseAes)(data);
59
+ const aad = parsed.aad ?? options?.aad;
60
+ return (0, private_1.decryptAes)({
61
+ ...parsed,
62
+ aad,
63
+ kryptos: this.kryptos,
64
+ });
65
+ }
66
+ catch (error) {
67
+ if (error instanceof errors_1.AesError)
68
+ throw error;
69
+ throw new errors_1.AesError("AES decryption failed", { error: error });
70
+ }
47
71
  }
48
- verify(input, data) {
49
- return this.decrypt(data) === input;
72
+ verify(input, data, options) {
73
+ try {
74
+ return (0, is_1.isEqual)(input, this.decrypt(data, options));
75
+ }
76
+ catch (_error) {
77
+ return false;
78
+ }
50
79
  }
51
- assert(input, data) {
52
- if (this.verify(input, data))
80
+ assert(input, data, options) {
81
+ if (this.verify(input, data, options))
53
82
  return;
54
83
  throw new errors_1.AesError("Invalid AES cipher");
55
84
  }
85
+ prepareEncryption() {
86
+ try {
87
+ return (0, private_1.prepareAesEncryption)({ encryption: this.encryption, kryptos: this.kryptos });
88
+ }
89
+ catch (error) {
90
+ if (error instanceof errors_1.AesError)
91
+ throw error;
92
+ throw new errors_1.AesError("AES prepare encryption failed", { error: error });
93
+ }
94
+ }
56
95
  static contentType(input) {
57
96
  return (0, content_1.calculateContentType)(input);
58
97
  }
@@ -1 +1 @@
1
- {"version":3,"file":"AesKit.js","sourceRoot":"","sources":["../../src/classes/AesKit.ts"],"names":[],"mappings":";;;AACA,sCAAqC;AAYrC,oCAAoD;AACpD,8CAM0B;AAC1B,sDAAgE;AAEhE,MAAa,MAAM;IACA,UAAU,CAAoB;IAC/B,OAAO,CAAW;IAElC,YAAmB,OAAsB;QACvC,IAAI,CAAC,OAAO,GAAG,OAAO,CAAC,OAAO,CAAC;QAC/B,IAAI,CAAC,UAAU,GAAG,OAAO,CAAC,UAAU,IAAI,OAAO,CAAC,OAAO,CAAC,UAAU,IAAI,SAAS,CAAC;IAClF,CAAC;IAMM,OAAO,CACZ,IAAgB,EAChB,OAA0B,SAAS;QAEnC,QAAQ,IAAI,EAAE,CAAC;YACb,KAAK,SAAS;gBACZ,OAAO,IAAA,gCAAsB,EAC3B,IAAA,oBAAU,EAAC;oBACT,IAAI;oBACJ,UAAU,EAAE,IAAI,CAAC,UAAU;oBAC3B,OAAO,EAAE,IAAI,CAAC,OAAO;iBACtB,CAAC,CACH,CAAC;YAEJ,KAAK,QAAQ;gBACX,OAAO,IAAA,oBAAU,EAAC;oBAChB,IAAI;oBACJ,UAAU,EAAE,IAAI,CAAC,UAAU;oBAC3B,OAAO,EAAE,IAAI,CAAC,OAAO;iBACtB,CAAC,CAAC;YAEL,KAAK,YAAY;gBACf,OAAO,IAAA,mCAAyB,EAC9B,IAAA,oBAAU,EAAC;oBACT,IAAI;oBACJ,UAAU,EAAE,IAAI,CAAC,UAAU;oBAC3B,OAAO,EAAE,IAAI,CAAC,OAAO;iBACtB,CAAC,CACH,CAAC;YAEJ,KAAK,WAAW;gBACd,OAAO,IAAA,kCAAwB,EAC7B,IAAA,oBAAU,EAAC;oBACT,IAAI;oBACJ,UAAU,EAAE,IAAI,CAAC,UAAU;oBAC3B,OAAO,EAAE,IAAI,CAAC,OAAO;iBACtB,CAAC,CACH,CAAC;YAEJ;gBACE,MAAM,IAAI,iBAAQ,CAAC,yBAAyB,CAAC,CAAC;QAClD,CAAC;IACH,CAAC;IAEM,OAAO,CACZ,IAA4D;QAE5D,OAAO,IAAA,oBAAU,EAAI,EAAE,GAAG,IAAA,gBAAQ,EAAC,IAAI,CAAC,EAAE,OAAO,EAAE,IAAI,CAAC,OAAO,EAAE,CAAC,CAAC;IACrE,CAAC;IAEM,MAAM,CACX,KAAa,EACb,IAA4D;QAE5D,OAAO,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,KAAK,KAAK,CAAC;IACtC,CAAC;IAEM,MAAM,CACX,KAAa,EACb,IAA4D;QAE5D,IAAI,IAAI,CAAC,MAAM,CAAC,KAAK,EAAE,IAAI,CAAC;YAAE,OAAO;QACrC,MAAM,IAAI,iBAAQ,CAAC,oBAAoB,CAAC,CAAC;IAC3C,CAAC;IAIM,MAAM,CAAC,WAAW,CAAC,KAAU;QAClC,OAAO,IAAA,8BAAoB,EAAC,KAAK,CAAC,CAAC;IACrC,CAAC;IAEM,MAAM,CAAC,cAAc,CAAC,KAAU;QACrC,OAAO,IAAA,sBAAc,EAAC,KAAK,CAAC,CAAC;IAC/B,CAAC;IAEM,MAAM,CAAC,KAAK,CACjB,IAA4D;QAE5D,OAAO,IAAA,gBAAQ,EAAC,IAAI,CAAC,CAAC;IACxB,CAAC;CACF;AA7FD,wBA6FC"}
1
+ {"version":3,"file":"AesKit.js","sourceRoot":"","sources":["../../src/classes/AesKit.ts"],"names":[],"mappings":"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"}
@@ -1,3 +1,2 @@
1
- export * from "./format";
2
1
  export * from "./version";
3
2
  //# sourceMappingURL=index.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/constants/private/index.ts"],"names":[],"mappings":"AAAA,cAAc,UAAU,CAAC;AACzB,cAAc,WAAW,CAAC"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/constants/private/index.ts"],"names":[],"mappings":"AAAA,cAAc,WAAW,CAAC"}
@@ -14,6 +14,5 @@ var __exportStar = (this && this.__exportStar) || function(m, exports) {
14
14
  for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
15
15
  };
16
16
  Object.defineProperty(exports, "__esModule", { value: true });
17
- __exportStar(require("./format"), exports);
18
17
  __exportStar(require("./version"), exports);
19
18
  //# sourceMappingURL=index.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/constants/private/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,2CAAyB;AACzB,4CAA0B"}
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/constants/private/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,4CAA0B"}
@@ -1,2 +1,4 @@
1
- export declare const LATEST_AES_VERSION = 10;
1
+ export declare const AES_FORMAT_VERSION = "1.0";
2
+ export declare const AES_FORMAT_MAJOR = 1;
3
+ export declare const LATEST_AES_VERSION = "1.0";
2
4
  //# sourceMappingURL=version.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"version.d.ts","sourceRoot":"","sources":["../../../src/constants/private/version.ts"],"names":[],"mappings":"AAAA,eAAO,MAAM,kBAAkB,KAAK,CAAC"}
1
+ {"version":3,"file":"version.d.ts","sourceRoot":"","sources":["../../../src/constants/private/version.ts"],"names":[],"mappings":"AAAA,eAAO,MAAM,kBAAkB,QAAQ,CAAC;AACxC,eAAO,MAAM,gBAAgB,IAAI,CAAC;AAClC,eAAO,MAAM,kBAAkB,QAAqB,CAAC"}
@@ -1,5 +1,7 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.LATEST_AES_VERSION = void 0;
4
- exports.LATEST_AES_VERSION = 10;
3
+ exports.LATEST_AES_VERSION = exports.AES_FORMAT_MAJOR = exports.AES_FORMAT_VERSION = void 0;
4
+ exports.AES_FORMAT_VERSION = "1.0";
5
+ exports.AES_FORMAT_MAJOR = 1;
6
+ exports.LATEST_AES_VERSION = exports.AES_FORMAT_VERSION;
5
7
  //# sourceMappingURL=version.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"version.js","sourceRoot":"","sources":["../../../src/constants/private/version.ts"],"names":[],"mappings":";;;AAAa,QAAA,kBAAkB,GAAG,EAAE,CAAC"}
1
+ {"version":3,"file":"version.js","sourceRoot":"","sources":["../../../src/constants/private/version.ts"],"names":[],"mappings":";;;AAAa,QAAA,kBAAkB,GAAG,KAAK,CAAC;AAC3B,QAAA,gBAAgB,GAAG,CAAC,CAAC;AACrB,QAAA,kBAAkB,GAAG,0BAAkB,CAAC"}
@@ -1,13 +1,18 @@
1
1
  import { IKryptos } from "@lindorm/kryptos";
2
2
  import { AesContent, AesDecryptionRecord, AesEncryptionRecord, SerialisedAesDecryption, SerialisedAesEncryption } from "../types";
3
+ import { PreparedEncryption } from "../types/private";
4
+ export type AesOperationOptions = {
5
+ aad?: Buffer;
6
+ };
3
7
  export interface IAesKit {
4
8
  kryptos: IKryptos;
5
- encrypt(content: AesContent, mode?: "encoded"): string;
6
- encrypt(content: AesContent, mode: "record"): AesEncryptionRecord;
7
- encrypt(content: AesContent, mode: "serialised"): SerialisedAesEncryption;
8
- encrypt(content: AesContent, mode: "tokenised"): string;
9
- decrypt<T extends AesContent = string>(data: AesDecryptionRecord | SerialisedAesDecryption | string): T;
10
- verify(input: string, data: AesDecryptionRecord | SerialisedAesDecryption | string): boolean;
11
- assert(input: string, data: AesDecryptionRecord | SerialisedAesDecryption | string): void;
9
+ encrypt(content: AesContent, mode?: "encoded", options?: AesOperationOptions): string;
10
+ encrypt(content: AesContent, mode: "record", options?: AesOperationOptions): AesEncryptionRecord;
11
+ encrypt(content: AesContent, mode: "serialised", options?: AesOperationOptions): SerialisedAesEncryption;
12
+ encrypt(content: AesContent, mode: "tokenised", options?: AesOperationOptions): string;
13
+ decrypt<T extends AesContent = string>(data: AesDecryptionRecord | SerialisedAesDecryption | string, options?: AesOperationOptions): T;
14
+ verify(input: AesContent, data: AesDecryptionRecord | SerialisedAesDecryption | string, options?: AesOperationOptions): boolean;
15
+ assert(input: AesContent, data: AesDecryptionRecord | SerialisedAesDecryption | string, options?: AesOperationOptions): void;
16
+ prepareEncryption(): PreparedEncryption;
12
17
  }
13
18
  //# sourceMappingURL=AesKit.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"AesKit.d.ts","sourceRoot":"","sources":["../../src/interfaces/AesKit.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,kBAAkB,CAAC;AAC5C,OAAO,EACL,UAAU,EACV,mBAAmB,EACnB,mBAAmB,EACnB,uBAAuB,EACvB,uBAAuB,EACxB,MAAM,UAAU,CAAC;AAElB,MAAM,WAAW,OAAO;IACtB,OAAO,EAAE,QAAQ,CAAC;IAElB,OAAO,CAAC,OAAO,EAAE,UAAU,EAAE,IAAI,CAAC,EAAE,SAAS,GAAG,MAAM,CAAC;IACvD,OAAO,CAAC,OAAO,EAAE,UAAU,EAAE,IAAI,EAAE,QAAQ,GAAG,mBAAmB,CAAC;IAClE,OAAO,CAAC,OAAO,EAAE,UAAU,EAAE,IAAI,EAAE,YAAY,GAAG,uBAAuB,CAAC;IAC1E,OAAO,CAAC,OAAO,EAAE,UAAU,EAAE,IAAI,EAAE,WAAW,GAAG,MAAM,CAAC;IAExD,OAAO,CAAC,CAAC,SAAS,UAAU,GAAG,MAAM,EACnC,IAAI,EAAE,mBAAmB,GAAG,uBAAuB,GAAG,MAAM,GAC3D,CAAC,CAAC;IACL,MAAM,CACJ,KAAK,EAAE,MAAM,EACb,IAAI,EAAE,mBAAmB,GAAG,uBAAuB,GAAG,MAAM,GAC3D,OAAO,CAAC;IACX,MAAM,CACJ,KAAK,EAAE,MAAM,EACb,IAAI,EAAE,mBAAmB,GAAG,uBAAuB,GAAG,MAAM,GAC3D,IAAI,CAAC;CACT"}
1
+ {"version":3,"file":"AesKit.d.ts","sourceRoot":"","sources":["../../src/interfaces/AesKit.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,kBAAkB,CAAC;AAC5C,OAAO,EACL,UAAU,EACV,mBAAmB,EACnB,mBAAmB,EACnB,uBAAuB,EACvB,uBAAuB,EACxB,MAAM,UAAU,CAAC;AAClB,OAAO,EAAE,kBAAkB,EAAE,MAAM,kBAAkB,CAAC;AAEtD,MAAM,MAAM,mBAAmB,GAAG;IAChC,GAAG,CAAC,EAAE,MAAM,CAAC;CACd,CAAC;AAEF,MAAM,WAAW,OAAO;IACtB,OAAO,EAAE,QAAQ,CAAC;IAElB,OAAO,CAAC,OAAO,EAAE,UAAU,EAAE,IAAI,CAAC,EAAE,SAAS,EAAE,OAAO,CAAC,EAAE,mBAAmB,GAAG,MAAM,CAAC;IACtF,OAAO,CACL,OAAO,EAAE,UAAU,EACnB,IAAI,EAAE,QAAQ,EACd,OAAO,CAAC,EAAE,mBAAmB,GAC5B,mBAAmB,CAAC;IACvB,OAAO,CACL,OAAO,EAAE,UAAU,EACnB,IAAI,EAAE,YAAY,EAClB,OAAO,CAAC,EAAE,mBAAmB,GAC5B,uBAAuB,CAAC;IAC3B,OAAO,CAAC,OAAO,EAAE,UAAU,EAAE,IAAI,EAAE,WAAW,EAAE,OAAO,CAAC,EAAE,mBAAmB,GAAG,MAAM,CAAC;IAEvF,OAAO,CAAC,CAAC,SAAS,UAAU,GAAG,MAAM,EACnC,IAAI,EAAE,mBAAmB,GAAG,uBAAuB,GAAG,MAAM,EAC5D,OAAO,CAAC,EAAE,mBAAmB,GAC5B,CAAC,CAAC;IACL,MAAM,CACJ,KAAK,EAAE,UAAU,EACjB,IAAI,EAAE,mBAAmB,GAAG,uBAAuB,GAAG,MAAM,EAC5D,OAAO,CAAC,EAAE,mBAAmB,GAC5B,OAAO,CAAC;IACX,MAAM,CACJ,KAAK,EAAE,UAAU,EACjB,IAAI,EAAE,mBAAmB,GAAG,uBAAuB,GAAG,MAAM,EAC5D,OAAO,CAAC,EAAE,mBAAmB,GAC5B,IAAI,CAAC;IAER,iBAAiB,IAAI,kBAAkB,CAAC;CACzC"}
@@ -1 +1 @@
1
- {"version":3,"file":"mock-aes-kit.d.ts","sourceRoot":"","sources":["../../src/mocks/mock-aes-kit.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,OAAO,EAAE,MAAM,eAAe,CAAC;AAExC,eAAO,MAAM,gBAAgB,QAAO,OAiBlC,CAAC"}
1
+ {"version":3,"file":"mock-aes-kit.d.ts","sourceRoot":"","sources":["../../src/mocks/mock-aes-kit.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,OAAO,EAAE,MAAM,eAAe,CAAC;AAExC,eAAO,MAAM,gBAAgB,QAAO,OA2BlC,CAAC"}
@@ -6,14 +6,24 @@ const createMockAesKit = () => ({
6
6
  kryptos: (0, kryptos_1.createMockKryptos)(),
7
7
  decrypt: jest
8
8
  .fn()
9
- .mockImplementation((data) => Buffer.from(JSON.stringify(data), "base64").toString()),
9
+ .mockImplementation((data, _options) => Buffer.from(JSON.stringify(data), "base64").toString()),
10
10
  encrypt: jest
11
11
  .fn()
12
- .mockImplementation((data, mode) => mode === "cipher"
12
+ .mockImplementation((data, mode, _options) => mode === "encoded"
13
13
  ? Buffer.from(data).toString("base64")
14
14
  : { content: Buffer.from(data).toString("base64") }),
15
15
  assert: jest.fn(),
16
16
  verify: jest.fn().mockReturnValue(true),
17
+ prepareEncryption: jest.fn().mockReturnValue({
18
+ headerParams: {},
19
+ publicEncryptionKey: undefined,
20
+ encrypt: jest.fn().mockReturnValue({
21
+ authTag: Buffer.alloc(16),
22
+ content: Buffer.alloc(0),
23
+ contentType: "text/plain",
24
+ initialisationVector: Buffer.alloc(12),
25
+ }),
26
+ }),
17
27
  });
18
28
  exports.createMockAesKit = createMockAesKit;
19
29
  //# sourceMappingURL=mock-aes-kit.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"mock-aes-kit.js","sourceRoot":"","sources":["../../src/mocks/mock-aes-kit.ts"],"names":[],"mappings":";;;AAAA,8CAAqD;AAI9C,MAAM,gBAAgB,GAAG,GAAY,EAAE,CAAC,CAAC;IAC9C,OAAO,EAAE,IAAA,2BAAiB,GAAE;IAE5B,OAAO,EAAE,IAAI;SACV,EAAE,EAAE;SACJ,kBAAkB,CAAC,CAAC,IAAmB,EAAE,EAAE,CAC1C,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,EAAE,QAAQ,CAAC,CAAC,QAAQ,EAAE,CACvD;IACH,OAAO,EAAE,IAAI;SACV,EAAE,EAAE;SACJ,kBAAkB,CAAC,CAAC,IAAY,EAAE,IAAS,EAAE,EAAE,CAC9C,IAAI,KAAK,QAAQ;QACf,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,QAAQ,CAAC,QAAQ,CAAC;QACtC,CAAC,CAAC,EAAE,OAAO,EAAE,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,QAAQ,CAAC,QAAQ,CAAC,EAAE,CACtD;IACH,MAAM,EAAE,IAAI,CAAC,EAAE,EAAE;IACjB,MAAM,EAAE,IAAI,CAAC,EAAE,EAAE,CAAC,eAAe,CAAC,IAAI,CAAC;CACxC,CAAC,CAAC;AAjBU,QAAA,gBAAgB,oBAiB1B"}
1
+ {"version":3,"file":"mock-aes-kit.js","sourceRoot":"","sources":["../../src/mocks/mock-aes-kit.ts"],"names":[],"mappings":";;;AAAA,8CAAqD;AAI9C,MAAM,gBAAgB,GAAG,GAAY,EAAE,CAAC,CAAC;IAC9C,OAAO,EAAE,IAAA,2BAAiB,GAAE;IAE5B,OAAO,EAAE,IAAI;SACV,EAAE,EAAE;SACJ,kBAAkB,CAAC,CAAC,IAAmB,EAAE,QAAc,EAAE,EAAE,CAC1D,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,EAAE,QAAQ,CAAC,CAAC,QAAQ,EAAE,CACvD;IACH,OAAO,EAAE,IAAI;SACV,EAAE,EAAE;SACJ,kBAAkB,CAAC,CAAC,IAAY,EAAE,IAAS,EAAE,QAAc,EAAE,EAAE,CAC9D,IAAI,KAAK,SAAS;QAChB,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,QAAQ,CAAC,QAAQ,CAAC;QACtC,CAAC,CAAC,EAAE,OAAO,EAAE,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,QAAQ,CAAC,QAAQ,CAAC,EAAE,CACtD;IACH,MAAM,EAAE,IAAI,CAAC,EAAE,EAAE;IACjB,MAAM,EAAE,IAAI,CAAC,EAAE,EAAE,CAAC,eAAe,CAAC,IAAI,CAAC;IACvC,iBAAiB,EAAE,IAAI,CAAC,EAAE,EAAE,CAAC,eAAe,CAAC;QAC3C,YAAY,EAAE,EAAE;QAChB,mBAAmB,EAAE,SAAS;QAC9B,OAAO,EAAE,IAAI,CAAC,EAAE,EAAE,CAAC,eAAe,CAAC;YACjC,OAAO,EAAE,MAAM,CAAC,KAAK,CAAC,EAAE,CAAC;YACzB,OAAO,EAAE,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC;YACxB,WAAW,EAAE,YAAY;YACzB,oBAAoB,EAAE,MAAM,CAAC,KAAK,CAAC,EAAE,CAAC;SACvC,CAAC;KACH,CAAC;CACH,CAAC,CAAC;AA3BU,QAAA,gBAAgB,oBA2B1B"}
@@ -3,16 +3,17 @@ import { AesContent, AesContentType } from "./content";
3
3
  import { PublicEncryptionJwk } from "./types";
4
4
  export type AesEncryptionMode = "encoded" | "record" | "serialised" | "tokenised";
5
5
  export type AesEncryptionOptions = {
6
+ aad?: Buffer;
6
7
  data: AesContent;
7
8
  encryption?: KryptosEncryption;
8
9
  };
9
10
  export type AesDecryptionRecord = {
11
+ aad?: Buffer;
10
12
  algorithm?: KryptosAlgorithm;
11
13
  authTag?: Buffer;
12
14
  content: Buffer;
13
15
  contentType?: AesContentType;
14
16
  encryption: KryptosEncryption;
15
- hkdfSalt?: Buffer;
16
17
  initialisationVector: Buffer;
17
18
  keyId?: string;
18
19
  pbkdfIterations?: number;
@@ -21,23 +22,31 @@ export type AesDecryptionRecord = {
21
22
  publicEncryptionJwk?: PublicEncryptionJwk;
22
23
  publicEncryptionKey?: Buffer;
23
24
  publicEncryptionTag?: Buffer;
24
- version?: number;
25
+ version?: string;
25
26
  };
26
- export type SerialisedAesDecryption = {
27
- algorithm?: KryptosAlgorithm;
28
- authTag?: string;
29
- content: string;
30
- contentType?: AesContentType;
27
+ export type ParsedAesDecryptionRecord = {
28
+ aad: Buffer;
29
+ algorithm: KryptosAlgorithm;
30
+ authTag: Buffer;
31
+ content: Buffer;
32
+ contentType: AesContentType;
31
33
  encryption: KryptosEncryption;
32
- hkdfSalt?: string;
33
- initialisationVector: string;
34
- keyId?: string;
35
- pbkdfIterations?: number;
36
- pbkdfSalt?: string;
37
- publicEncryptionIv?: string;
38
- publicEncryptionJwk?: PublicEncryptionJwk;
39
- publicEncryptionKey?: string;
40
- publicEncryptionTag?: string;
41
- version?: number;
34
+ initialisationVector: Buffer;
35
+ keyId: string;
36
+ pbkdfIterations: number | undefined;
37
+ pbkdfSalt: Buffer | undefined;
38
+ publicEncryptionIv: Buffer | undefined;
39
+ publicEncryptionJwk: PublicEncryptionJwk | undefined;
40
+ publicEncryptionKey: Buffer | undefined;
41
+ publicEncryptionTag: Buffer | undefined;
42
+ version: string;
43
+ };
44
+ export type SerialisedAesDecryption = {
45
+ cek?: string;
46
+ ciphertext: string;
47
+ header: string;
48
+ iv: string;
49
+ tag: string;
50
+ v: string;
42
51
  };
43
52
  //# sourceMappingURL=aes-decryption-data.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"aes-decryption-data.d.ts","sourceRoot":"","sources":["../../src/types/aes-decryption-data.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,gBAAgB,EAAE,iBAAiB,EAAE,MAAM,kBAAkB,CAAC;AACvE,OAAO,EAAE,UAAU,EAAE,cAAc,EAAE,MAAM,WAAW,CAAC;AACvD,OAAO,EAAE,mBAAmB,EAAE,MAAM,SAAS,CAAC;AAE9C,MAAM,MAAM,iBAAiB,GAAG,SAAS,GAAG,QAAQ,GAAG,YAAY,GAAG,WAAW,CAAC;AAElF,MAAM,MAAM,oBAAoB,GAAG;IACjC,IAAI,EAAE,UAAU,CAAC;IACjB,UAAU,CAAC,EAAE,iBAAiB,CAAC;CAChC,CAAC;AAEF,MAAM,MAAM,mBAAmB,GAAG;IAChC,SAAS,CAAC,EAAE,gBAAgB,CAAC;IAC7B,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,OAAO,EAAE,MAAM,CAAC;IAChB,WAAW,CAAC,EAAE,cAAc,CAAC;IAC7B,UAAU,EAAE,iBAAiB,CAAC;IAC9B,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,oBAAoB,EAAE,MAAM,CAAC;IAC7B,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,eAAe,CAAC,EAAE,MAAM,CAAC;IACzB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,kBAAkB,CAAC,EAAE,MAAM,CAAC;IAC5B,mBAAmB,CAAC,EAAE,mBAAmB,CAAC;IAC1C,mBAAmB,CAAC,EAAE,MAAM,CAAC;IAC7B,mBAAmB,CAAC,EAAE,MAAM,CAAC;IAC7B,OAAO,CAAC,EAAE,MAAM,CAAC;CAClB,CAAC;AAEF,MAAM,MAAM,uBAAuB,GAAG;IACpC,SAAS,CAAC,EAAE,gBAAgB,CAAC;IAC7B,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,OAAO,EAAE,MAAM,CAAC;IAChB,WAAW,CAAC,EAAE,cAAc,CAAC;IAC7B,UAAU,EAAE,iBAAiB,CAAC;IAC9B,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,oBAAoB,EAAE,MAAM,CAAC;IAC7B,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,eAAe,CAAC,EAAE,MAAM,CAAC;IACzB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,kBAAkB,CAAC,EAAE,MAAM,CAAC;IAC5B,mBAAmB,CAAC,EAAE,mBAAmB,CAAC;IAC1C,mBAAmB,CAAC,EAAE,MAAM,CAAC;IAC7B,mBAAmB,CAAC,EAAE,MAAM,CAAC;IAC7B,OAAO,CAAC,EAAE,MAAM,CAAC;CAClB,CAAC"}
1
+ {"version":3,"file":"aes-decryption-data.d.ts","sourceRoot":"","sources":["../../src/types/aes-decryption-data.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,gBAAgB,EAAE,iBAAiB,EAAE,MAAM,kBAAkB,CAAC;AACvE,OAAO,EAAE,UAAU,EAAE,cAAc,EAAE,MAAM,WAAW,CAAC;AACvD,OAAO,EAAE,mBAAmB,EAAE,MAAM,SAAS,CAAC;AAE9C,MAAM,MAAM,iBAAiB,GAAG,SAAS,GAAG,QAAQ,GAAG,YAAY,GAAG,WAAW,CAAC;AAElF,MAAM,MAAM,oBAAoB,GAAG;IACjC,GAAG,CAAC,EAAE,MAAM,CAAC;IACb,IAAI,EAAE,UAAU,CAAC;IACjB,UAAU,CAAC,EAAE,iBAAiB,CAAC;CAChC,CAAC;AAEF,MAAM,MAAM,mBAAmB,GAAG;IAChC,GAAG,CAAC,EAAE,MAAM,CAAC;IACb,SAAS,CAAC,EAAE,gBAAgB,CAAC;IAC7B,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,OAAO,EAAE,MAAM,CAAC;IAChB,WAAW,CAAC,EAAE,cAAc,CAAC;IAC7B,UAAU,EAAE,iBAAiB,CAAC;IAC9B,oBAAoB,EAAE,MAAM,CAAC;IAC7B,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,eAAe,CAAC,EAAE,MAAM,CAAC;IACzB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,kBAAkB,CAAC,EAAE,MAAM,CAAC;IAC5B,mBAAmB,CAAC,EAAE,mBAAmB,CAAC;IAC1C,mBAAmB,CAAC,EAAE,MAAM,CAAC;IAC7B,mBAAmB,CAAC,EAAE,MAAM,CAAC;IAC7B,OAAO,CAAC,EAAE,MAAM,CAAC;CAClB,CAAC;AAOF,MAAM,MAAM,yBAAyB,GAAG;IACtC,GAAG,EAAE,MAAM,CAAC;IACZ,SAAS,EAAE,gBAAgB,CAAC;IAC5B,OAAO,EAAE,MAAM,CAAC;IAChB,OAAO,EAAE,MAAM,CAAC;IAChB,WAAW,EAAE,cAAc,CAAC;IAC5B,UAAU,EAAE,iBAAiB,CAAC;IAC9B,oBAAoB,EAAE,MAAM,CAAC;IAC7B,KAAK,EAAE,MAAM,CAAC;IACd,eAAe,EAAE,MAAM,GAAG,SAAS,CAAC;IACpC,SAAS,EAAE,MAAM,GAAG,SAAS,CAAC;IAC9B,kBAAkB,EAAE,MAAM,GAAG,SAAS,CAAC;IACvC,mBAAmB,EAAE,mBAAmB,GAAG,SAAS,CAAC;IACrD,mBAAmB,EAAE,MAAM,GAAG,SAAS,CAAC;IACxC,mBAAmB,EAAE,MAAM,GAAG,SAAS,CAAC;IACxC,OAAO,EAAE,MAAM,CAAC;CACjB,CAAC;AAEF,MAAM,MAAM,uBAAuB,GAAG;IACpC,GAAG,CAAC,EAAE,MAAM,CAAC;IACb,UAAU,EAAE,MAAM,CAAC;IACnB,MAAM,EAAE,MAAM,CAAC;IACf,EAAE,EAAE,MAAM,CAAC;IACX,GAAG,EAAE,MAAM,CAAC;IACZ,CAAC,EAAE,MAAM,CAAC;CACX,CAAC"}
@@ -7,7 +7,6 @@ export type AesEncryptionRecord = {
7
7
  content: Buffer;
8
8
  contentType: AesContentType;
9
9
  encryption: KryptosEncryption;
10
- hkdfSalt: Buffer | undefined;
11
10
  initialisationVector: Buffer;
12
11
  keyId: string;
13
12
  pbkdfIterations: number | undefined;
@@ -16,23 +15,14 @@ export type AesEncryptionRecord = {
16
15
  publicEncryptionJwk: PublicEncryptionJwk | undefined;
17
16
  publicEncryptionKey: Buffer | undefined;
18
17
  publicEncryptionTag: Buffer | undefined;
19
- version: number;
18
+ version: string;
20
19
  };
21
20
  export type SerialisedAesEncryption = {
22
- algorithm: KryptosAlgorithm;
23
- authTag: string;
24
- content: string;
25
- contentType: AesContentType;
26
- encryption: KryptosEncryption;
27
- hkdfSalt: string | undefined;
28
- initialisationVector: string;
29
- keyId: string;
30
- pbkdfIterations: number | undefined;
31
- pbkdfSalt: string | undefined;
32
- publicEncryptionIv: string | undefined;
33
- publicEncryptionJwk: PublicEncryptionJwk | undefined;
34
- publicEncryptionKey: string | undefined;
35
- publicEncryptionTag: string | undefined;
36
- version: number;
21
+ cek: string | undefined;
22
+ ciphertext: string;
23
+ header: string;
24
+ iv: string;
25
+ tag: string;
26
+ v: string;
37
27
  };
38
28
  //# sourceMappingURL=aes-encryption-data.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"aes-encryption-data.d.ts","sourceRoot":"","sources":["../../src/types/aes-encryption-data.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,gBAAgB,EAAE,iBAAiB,EAAE,MAAM,kBAAkB,CAAC;AACvE,OAAO,EAAE,cAAc,EAAE,MAAM,WAAW,CAAC;AAC3C,OAAO,EAAE,mBAAmB,EAAE,MAAM,SAAS,CAAC;AAE9C,MAAM,MAAM,mBAAmB,GAAG;IAChC,SAAS,EAAE,gBAAgB,CAAC;IAC5B,OAAO,EAAE,MAAM,CAAC;IAChB,OAAO,EAAE,MAAM,CAAC;IAChB,WAAW,EAAE,cAAc,CAAC;IAC5B,UAAU,EAAE,iBAAiB,CAAC;IAC9B,QAAQ,EAAE,MAAM,GAAG,SAAS,CAAC;IAC7B,oBAAoB,EAAE,MAAM,CAAC;IAC7B,KAAK,EAAE,MAAM,CAAC;IACd,eAAe,EAAE,MAAM,GAAG,SAAS,CAAC;IACpC,SAAS,EAAE,MAAM,GAAG,SAAS,CAAC;IAC9B,kBAAkB,EAAE,MAAM,GAAG,SAAS,CAAC;IACvC,mBAAmB,EAAE,mBAAmB,GAAG,SAAS,CAAC;IACrD,mBAAmB,EAAE,MAAM,GAAG,SAAS,CAAC;IACxC,mBAAmB,EAAE,MAAM,GAAG,SAAS,CAAC;IACxC,OAAO,EAAE,MAAM,CAAC;CACjB,CAAC;AAEF,MAAM,MAAM,uBAAuB,GAAG;IACpC,SAAS,EAAE,gBAAgB,CAAC;IAC5B,OAAO,EAAE,MAAM,CAAC;IAChB,OAAO,EAAE,MAAM,CAAC;IAChB,WAAW,EAAE,cAAc,CAAC;IAC5B,UAAU,EAAE,iBAAiB,CAAC;IAC9B,QAAQ,EAAE,MAAM,GAAG,SAAS,CAAC;IAC7B,oBAAoB,EAAE,MAAM,CAAC;IAC7B,KAAK,EAAE,MAAM,CAAC;IACd,eAAe,EAAE,MAAM,GAAG,SAAS,CAAC;IACpC,SAAS,EAAE,MAAM,GAAG,SAAS,CAAC;IAC9B,kBAAkB,EAAE,MAAM,GAAG,SAAS,CAAC;IACvC,mBAAmB,EAAE,mBAAmB,GAAG,SAAS,CAAC;IACrD,mBAAmB,EAAE,MAAM,GAAG,SAAS,CAAC;IACxC,mBAAmB,EAAE,MAAM,GAAG,SAAS,CAAC;IACxC,OAAO,EAAE,MAAM,CAAC;CACjB,CAAC"}
1
+ {"version":3,"file":"aes-encryption-data.d.ts","sourceRoot":"","sources":["../../src/types/aes-encryption-data.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,gBAAgB,EAAE,iBAAiB,EAAE,MAAM,kBAAkB,CAAC;AACvE,OAAO,EAAE,cAAc,EAAE,MAAM,WAAW,CAAC;AAC3C,OAAO,EAAE,mBAAmB,EAAE,MAAM,SAAS,CAAC;AAE9C,MAAM,MAAM,mBAAmB,GAAG;IAChC,SAAS,EAAE,gBAAgB,CAAC;IAC5B,OAAO,EAAE,MAAM,CAAC;IAChB,OAAO,EAAE,MAAM,CAAC;IAChB,WAAW,EAAE,cAAc,CAAC;IAC5B,UAAU,EAAE,iBAAiB,CAAC;IAC9B,oBAAoB,EAAE,MAAM,CAAC;IAC7B,KAAK,EAAE,MAAM,CAAC;IACd,eAAe,EAAE,MAAM,GAAG,SAAS,CAAC;IACpC,SAAS,EAAE,MAAM,GAAG,SAAS,CAAC;IAC9B,kBAAkB,EAAE,MAAM,GAAG,SAAS,CAAC;IACvC,mBAAmB,EAAE,mBAAmB,GAAG,SAAS,CAAC;IACrD,mBAAmB,EAAE,MAAM,GAAG,SAAS,CAAC;IACxC,mBAAmB,EAAE,MAAM,GAAG,SAAS,CAAC;IACxC,OAAO,EAAE,MAAM,CAAC;CACjB,CAAC;AAEF,MAAM,MAAM,uBAAuB,GAAG;IACpC,GAAG,EAAE,MAAM,GAAG,SAAS,CAAC;IACxB,UAAU,EAAE,MAAM,CAAC;IACnB,MAAM,EAAE,MAAM,CAAC;IACf,EAAE,EAAE,MAAM,CAAC;IACX,GAAG,EAAE,MAAM,CAAC;IACZ,CAAC,EAAE,MAAM,CAAC;CACX,CAAC"}
@@ -4,4 +4,5 @@ export * from "./aes-kit";
4
4
  export * from "./content";
5
5
  export * from "./curve";
6
6
  export * from "./types";
7
+ export type { EncryptContentResult, PreparedEncryption, PreparedEncryptionHeaderParams, } from "./private/prepared-encryption";
7
8
  //# sourceMappingURL=index.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/types/index.ts"],"names":[],"mappings":"AAAA,cAAc,uBAAuB,CAAC;AACtC,cAAc,uBAAuB,CAAC;AACtC,cAAc,WAAW,CAAC;AAC1B,cAAc,WAAW,CAAC;AAC1B,cAAc,SAAS,CAAC;AACxB,cAAc,SAAS,CAAC"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/types/index.ts"],"names":[],"mappings":"AAAA,cAAc,uBAAuB,CAAC;AACtC,cAAc,uBAAuB,CAAC;AACtC,cAAc,WAAW,CAAC;AAC1B,cAAc,WAAW,CAAC;AAC1B,cAAc,SAAS,CAAC;AACxB,cAAc,SAAS,CAAC;AAExB,YAAY,EACV,oBAAoB,EACpB,kBAAkB,EAClB,8BAA8B,GAC/B,MAAM,+BAA+B,CAAC"}
@@ -1 +1 @@
1
- {"version":3,"file":"aes-data.d.ts","sourceRoot":"","sources":["../../../src/types/private/aes-data.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,kBAAkB,CAAC;AAC5C,OAAO,EACL,mBAAmB,EACnB,oBAAoB,EACpB,uBAAuB,EACxB,MAAM,wBAAwB,CAAC;AAEhC,MAAM,MAAM,2BAA2B,GAAG,oBAAoB,GAAG;IAAE,OAAO,EAAE,QAAQ,CAAA;CAAE,CAAC;AAEvF,MAAM,MAAM,2BAA2B,GAAG,mBAAmB,GAAG;IAAE,OAAO,EAAE,QAAQ,CAAA;CAAE,CAAC;AAEtF,MAAM,MAAM,qCAAqC,GAAG,uBAAuB,GAAG;IAC5E,OAAO,EAAE,QAAQ,CAAC;CACnB,CAAC"}
1
+ {"version":3,"file":"aes-data.d.ts","sourceRoot":"","sources":["../../../src/types/private/aes-data.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,kBAAkB,CAAC;AAC5C,OAAO,EACL,mBAAmB,EACnB,oBAAoB,EACpB,uBAAuB,EACxB,MAAM,wBAAwB,CAAC;AAEhC,MAAM,MAAM,2BAA2B,GAAG,oBAAoB,GAAG;IAAE,OAAO,EAAE,QAAQ,CAAA;CAAE,CAAC;AAEvF,MAAM,MAAM,2BAA2B,GAAG,mBAAmB,GAAG;IAC9D,OAAO,EAAE,QAAQ,CAAC;CACnB,CAAC;AAEF,MAAM,MAAM,qCAAqC,GAAG,uBAAuB,GAAG;IAC5E,OAAO,EAAE,QAAQ,CAAC;CACnB,CAAC"}
@@ -1,2 +1,2 @@
1
- export type AesKeyDerivation = "dir" | "hkdf" | "pbkdf2";
1
+ export type AesKeyDerivation = "dir" | "pbkdf2";
2
2
  //# sourceMappingURL=aes-key-derivation.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"aes-key-derivation.d.ts","sourceRoot":"","sources":["../../../src/types/private/aes-key-derivation.ts"],"names":[],"mappings":"AAAA,MAAM,MAAM,gBAAgB,GAAG,KAAK,GAAG,MAAM,GAAG,QAAQ,CAAC"}
1
+ {"version":3,"file":"aes-key-derivation.d.ts","sourceRoot":"","sources":["../../../src/types/private/aes-key-derivation.ts"],"names":[],"mappings":"AAAA,MAAM,MAAM,gBAAgB,GAAG,KAAK,GAAG,QAAQ,CAAC"}
@@ -1,6 +1,7 @@
1
1
  import { KryptosEncryption } from "@lindorm/kryptos";
2
2
  import { CipherGCM, Cipheriv, DecipherGCM, Decipheriv } from "crypto";
3
3
  export type GetAuthTagOptions = {
4
+ aad?: Buffer;
4
5
  cipher: Cipheriv | CipherGCM;
5
6
  content: Buffer;
6
7
  hashKey: Buffer;
@@ -8,6 +9,7 @@ export type GetAuthTagOptions = {
8
9
  initialisationVector: Buffer;
9
10
  };
10
11
  export type SetAuthTagOptions = {
12
+ aad?: Buffer;
11
13
  authTag?: Buffer;
12
14
  content: Buffer;
13
15
  hashKey: Buffer;
@@ -16,6 +18,7 @@ export type SetAuthTagOptions = {
16
18
  initialisationVector: Buffer;
17
19
  };
18
20
  export type CreateHmacAuthTag = {
21
+ aad?: Buffer;
19
22
  content: Buffer;
20
23
  encryption: KryptosEncryption;
21
24
  hashKey: Buffer;
@@ -1 +1 @@
1
- {"version":3,"file":"auth-tag.d.ts","sourceRoot":"","sources":["../../../src/types/private/auth-tag.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,iBAAiB,EAAE,MAAM,kBAAkB,CAAC;AACrD,OAAO,EAAE,SAAS,EAAE,QAAQ,EAAE,WAAW,EAAE,UAAU,EAAE,MAAM,QAAQ,CAAC;AAEtE,MAAM,MAAM,iBAAiB,GAAG;IAC9B,MAAM,EAAE,QAAQ,GAAG,SAAS,CAAC;IAC7B,OAAO,EAAE,MAAM,CAAC;IAChB,OAAO,EAAE,MAAM,CAAC;IAChB,UAAU,EAAE,iBAAiB,CAAC;IAC9B,oBAAoB,EAAE,MAAM,CAAC;CAC9B,CAAC;AAEF,MAAM,MAAM,iBAAiB,GAAG;IAC9B,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,OAAO,EAAE,MAAM,CAAC;IAChB,OAAO,EAAE,MAAM,CAAC;IAChB,QAAQ,EAAE,UAAU,GAAG,WAAW,CAAC;IACnC,UAAU,EAAE,iBAAiB,CAAC;IAC9B,oBAAoB,EAAE,MAAM,CAAC;CAC9B,CAAC;AAEF,MAAM,MAAM,iBAAiB,GAAG;IAC9B,OAAO,EAAE,MAAM,CAAC;IAChB,UAAU,EAAE,iBAAiB,CAAC;IAC9B,OAAO,EAAE,MAAM,CAAC;IAChB,oBAAoB,EAAE,MAAM,CAAC;CAC9B,CAAC;AAEF,MAAM,MAAM,iBAAiB,GAAG,iBAAiB,GAAG;IAAE,OAAO,EAAE,MAAM,CAAA;CAAE,CAAC"}
1
+ {"version":3,"file":"auth-tag.d.ts","sourceRoot":"","sources":["../../../src/types/private/auth-tag.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,iBAAiB,EAAE,MAAM,kBAAkB,CAAC;AACrD,OAAO,EAAE,SAAS,EAAE,QAAQ,EAAE,WAAW,EAAE,UAAU,EAAE,MAAM,QAAQ,CAAC;AAEtE,MAAM,MAAM,iBAAiB,GAAG;IAC9B,GAAG,CAAC,EAAE,MAAM,CAAC;IACb,MAAM,EAAE,QAAQ,GAAG,SAAS,CAAC;IAC7B,OAAO,EAAE,MAAM,CAAC;IAChB,OAAO,EAAE,MAAM,CAAC;IAChB,UAAU,EAAE,iBAAiB,CAAC;IAC9B,oBAAoB,EAAE,MAAM,CAAC;CAC9B,CAAC;AAEF,MAAM,MAAM,iBAAiB,GAAG;IAC9B,GAAG,CAAC,EAAE,MAAM,CAAC;IACb,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,OAAO,EAAE,MAAM,CAAC;IAChB,OAAO,EAAE,MAAM,CAAC;IAChB,QAAQ,EAAE,UAAU,GAAG,WAAW,CAAC;IACnC,UAAU,EAAE,iBAAiB,CAAC;IAC9B,oBAAoB,EAAE,MAAM,CAAC;CAC9B,CAAC;AAEF,MAAM,MAAM,iBAAiB,GAAG;IAC9B,GAAG,CAAC,EAAE,MAAM,CAAC;IACb,OAAO,EAAE,MAAM,CAAC;IAChB,UAAU,EAAE,iBAAiB,CAAC;IAC9B,OAAO,EAAE,MAAM,CAAC;IAChB,oBAAoB,EAAE,MAAM,CAAC;CAC9B,CAAC;AAEF,MAAM,MAAM,iBAAiB,GAAG,iBAAiB,GAAG;IAAE,OAAO,EAAE,MAAM,CAAA;CAAE,CAAC"}
@@ -1,12 +1,13 @@
1
1
  import { IKryptos, KryptosEncryption } from "@lindorm/kryptos";
2
2
  import { PublicEncryptionJwk } from "../types";
3
3
  export type CreateCekOptions = {
4
+ apu?: Buffer;
5
+ apv?: Buffer;
4
6
  encryption: KryptosEncryption;
5
7
  kryptos: IKryptos;
6
8
  };
7
9
  export type CreateCekResult = {
8
10
  contentEncryptionKey: Buffer;
9
- hkdfSalt?: Buffer;
10
11
  pbkdfIterations?: number;
11
12
  pbkdfSalt?: Buffer;
12
13
  publicEncryptionIv?: Buffer;
@@ -15,8 +16,9 @@ export type CreateCekResult = {
15
16
  publicEncryptionTag?: Buffer;
16
17
  };
17
18
  export type DecryptCekOptions = {
19
+ apu?: Buffer;
20
+ apv?: Buffer;
18
21
  encryption: KryptosEncryption;
19
- hkdfSalt?: Buffer;
20
22
  kryptos: IKryptos;
21
23
  pbkdfIterations?: number;
22
24
  pbkdfSalt?: Buffer;
@@ -1 +1 @@
1
- {"version":3,"file":"content-encryption-key.d.ts","sourceRoot":"","sources":["../../../src/types/private/content-encryption-key.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,iBAAiB,EAAE,MAAM,kBAAkB,CAAC;AAC/D,OAAO,EAAE,mBAAmB,EAAE,MAAM,UAAU,CAAC;AAE/C,MAAM,MAAM,gBAAgB,GAAG;IAC7B,UAAU,EAAE,iBAAiB,CAAC;IAC9B,OAAO,EAAE,QAAQ,CAAC;CACnB,CAAC;AAEF,MAAM,MAAM,eAAe,GAAG;IAC5B,oBAAoB,EAAE,MAAM,CAAC;IAC7B,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,eAAe,CAAC,EAAE,MAAM,CAAC;IACzB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,kBAAkB,CAAC,EAAE,MAAM,CAAC;IAC5B,mBAAmB,CAAC,EAAE,mBAAmB,CAAC;IAC1C,mBAAmB,CAAC,EAAE,MAAM,CAAC;IAC7B,mBAAmB,CAAC,EAAE,MAAM,CAAC;CAC9B,CAAC;AAEF,MAAM,MAAM,iBAAiB,GAAG;IAC9B,UAAU,EAAE,iBAAiB,CAAC;IAC9B,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,OAAO,EAAE,QAAQ,CAAC;IAClB,eAAe,CAAC,EAAE,MAAM,CAAC;IACzB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,kBAAkB,CAAC,EAAE,MAAM,CAAC;IAC5B,mBAAmB,CAAC,EAAE,mBAAmB,CAAC;IAC1C,mBAAmB,CAAC,EAAE,MAAM,CAAC;IAC7B,mBAAmB,CAAC,EAAE,MAAM,CAAC;CAC9B,CAAC;AAEF,MAAM,MAAM,gBAAgB,GAAG;IAC7B,oBAAoB,EAAE,MAAM,CAAC;CAC9B,CAAC"}
1
+ {"version":3,"file":"content-encryption-key.d.ts","sourceRoot":"","sources":["../../../src/types/private/content-encryption-key.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,iBAAiB,EAAE,MAAM,kBAAkB,CAAC;AAC/D,OAAO,EAAE,mBAAmB,EAAE,MAAM,UAAU,CAAC;AAE/C,MAAM,MAAM,gBAAgB,GAAG;IAC7B,GAAG,CAAC,EAAE,MAAM,CAAC;IACb,GAAG,CAAC,EAAE,MAAM,CAAC;IACb,UAAU,EAAE,iBAAiB,CAAC;IAC9B,OAAO,EAAE,QAAQ,CAAC;CACnB,CAAC;AAEF,MAAM,MAAM,eAAe,GAAG;IAC5B,oBAAoB,EAAE,MAAM,CAAC;IAC7B,eAAe,CAAC,EAAE,MAAM,CAAC;IACzB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,kBAAkB,CAAC,EAAE,MAAM,CAAC;IAC5B,mBAAmB,CAAC,EAAE,mBAAmB,CAAC;IAC1C,mBAAmB,CAAC,EAAE,MAAM,CAAC;IAC7B,mBAAmB,CAAC,EAAE,MAAM,CAAC;CAC9B,CAAC;AAEF,MAAM,MAAM,iBAAiB,GAAG;IAC9B,GAAG,CAAC,EAAE,MAAM,CAAC;IACb,GAAG,CAAC,EAAE,MAAM,CAAC;IACb,UAAU,EAAE,iBAAiB,CAAC;IAC9B,OAAO,EAAE,QAAQ,CAAC;IAClB,eAAe,CAAC,EAAE,MAAM,CAAC;IACzB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,kBAAkB,CAAC,EAAE,MAAM,CAAC;IAC5B,mBAAmB,CAAC,EAAE,mBAAmB,CAAC;IAC1C,mBAAmB,CAAC,EAAE,MAAM,CAAC;IAC7B,mBAAmB,CAAC,EAAE,MAAM,CAAC;CAC9B,CAAC;AAEF,MAAM,MAAM,gBAAgB,GAAG;IAC7B,oBAAoB,EAAE,MAAM,CAAC;CAC9B,CAAC"}
@@ -1,7 +1,7 @@
1
1
  export * from "./aes-data";
2
2
  export * from "./aes-key-derivation";
3
- export * from "./aes-string";
4
3
  export * from "./auth-tag";
5
4
  export * from "./content-encryption-key";
6
5
  export * from "./key-wrap";
6
+ export * from "./prepared-encryption";
7
7
  //# sourceMappingURL=index.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/types/private/index.ts"],"names":[],"mappings":"AAAA,cAAc,YAAY,CAAC;AAC3B,cAAc,sBAAsB,CAAC;AACrC,cAAc,cAAc,CAAC;AAC7B,cAAc,YAAY,CAAC;AAC3B,cAAc,0BAA0B,CAAC;AACzC,cAAc,YAAY,CAAC"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/types/private/index.ts"],"names":[],"mappings":"AAAA,cAAc,YAAY,CAAC;AAC3B,cAAc,sBAAsB,CAAC;AACrC,cAAc,YAAY,CAAC;AAC3B,cAAc,0BAA0B,CAAC;AACzC,cAAc,YAAY,CAAC;AAC3B,cAAc,uBAAuB,CAAC"}
@@ -16,8 +16,8 @@ var __exportStar = (this && this.__exportStar) || function(m, exports) {
16
16
  Object.defineProperty(exports, "__esModule", { value: true });
17
17
  __exportStar(require("./aes-data"), exports);
18
18
  __exportStar(require("./aes-key-derivation"), exports);
19
- __exportStar(require("./aes-string"), exports);
20
19
  __exportStar(require("./auth-tag"), exports);
21
20
  __exportStar(require("./content-encryption-key"), exports);
22
21
  __exportStar(require("./key-wrap"), exports);
22
+ __exportStar(require("./prepared-encryption"), exports);
23
23
  //# sourceMappingURL=index.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/types/private/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,6CAA2B;AAC3B,uDAAqC;AACrC,+CAA6B;AAC7B,6CAA2B;AAC3B,2DAAyC;AACzC,6CAA2B"}
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/types/private/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,6CAA2B;AAC3B,uDAAqC;AACrC,6CAA2B;AAC3B,2DAAyC;AACzC,6CAA2B;AAC3B,wDAAsC"}
@@ -0,0 +1,35 @@
1
+ import { IKryptos, KryptosEncryption } from "@lindorm/kryptos";
2
+ import { AesContent, AesContentType } from "../content";
3
+ import { PublicEncryptionJwk } from "../types";
4
+ export type PrepareEncryptionOptions = {
5
+ encryption?: KryptosEncryption;
6
+ kryptos: IKryptos;
7
+ };
8
+ export type EncryptContentOptions = {
9
+ aad?: Buffer;
10
+ contentEncryptionKey: Buffer;
11
+ data: AesContent;
12
+ encryption: KryptosEncryption;
13
+ initialisationVector?: Buffer;
14
+ };
15
+ export type EncryptContentResult = {
16
+ authTag: Buffer;
17
+ content: Buffer;
18
+ contentType: AesContentType;
19
+ initialisationVector: Buffer;
20
+ };
21
+ export type PreparedEncryptionHeaderParams = {
22
+ publicEncryptionJwk?: PublicEncryptionJwk;
23
+ pbkdfIterations?: number;
24
+ pbkdfSalt?: Buffer;
25
+ publicEncryptionIv?: Buffer;
26
+ publicEncryptionTag?: Buffer;
27
+ };
28
+ export type PreparedEncryption = {
29
+ headerParams: PreparedEncryptionHeaderParams;
30
+ publicEncryptionKey?: Buffer;
31
+ encrypt(data: AesContent, options?: {
32
+ aad?: Buffer;
33
+ }): EncryptContentResult;
34
+ };
35
+ //# sourceMappingURL=prepared-encryption.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"prepared-encryption.d.ts","sourceRoot":"","sources":["../../../src/types/private/prepared-encryption.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,iBAAiB,EAAE,MAAM,kBAAkB,CAAC;AAC/D,OAAO,EAAE,UAAU,EAAE,cAAc,EAAE,MAAM,YAAY,CAAC;AACxD,OAAO,EAAE,mBAAmB,EAAE,MAAM,UAAU,CAAC;AAE/C,MAAM,MAAM,wBAAwB,GAAG;IACrC,UAAU,CAAC,EAAE,iBAAiB,CAAC;IAC/B,OAAO,EAAE,QAAQ,CAAC;CACnB,CAAC;AAEF,MAAM,MAAM,qBAAqB,GAAG;IAClC,GAAG,CAAC,EAAE,MAAM,CAAC;IACb,oBAAoB,EAAE,MAAM,CAAC;IAC7B,IAAI,EAAE,UAAU,CAAC;IACjB,UAAU,EAAE,iBAAiB,CAAC;IAC9B,oBAAoB,CAAC,EAAE,MAAM,CAAC;CAC/B,CAAC;AAEF,MAAM,MAAM,oBAAoB,GAAG;IACjC,OAAO,EAAE,MAAM,CAAC;IAChB,OAAO,EAAE,MAAM,CAAC;IAChB,WAAW,EAAE,cAAc,CAAC;IAC5B,oBAAoB,EAAE,MAAM,CAAC;CAC9B,CAAC;AAEF,MAAM,MAAM,8BAA8B,GAAG;IAC3C,mBAAmB,CAAC,EAAE,mBAAmB,CAAC;IAC1C,eAAe,CAAC,EAAE,MAAM,CAAC;IACzB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,kBAAkB,CAAC,EAAE,MAAM,CAAC;IAC5B,mBAAmB,CAAC,EAAE,MAAM,CAAC;CAC9B,CAAC;AAEF,MAAM,MAAM,kBAAkB,GAAG;IAC/B,YAAY,EAAE,8BAA8B,CAAC;IAC7C,mBAAmB,CAAC,EAAE,MAAM,CAAC;IAC7B,OAAO,CAAC,IAAI,EAAE,UAAU,EAAE,OAAO,CAAC,EAAE;QAAE,GAAG,CAAC,EAAE,MAAM,CAAA;KAAE,GAAG,oBAAoB,CAAC;CAC7E,CAAC"}
@@ -1,3 +1,3 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- //# sourceMappingURL=aes-string.js.map
3
+ //# sourceMappingURL=prepared-encryption.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"prepared-encryption.js","sourceRoot":"","sources":["../../../src/types/private/prepared-encryption.ts"],"names":[],"mappings":""}
@@ -1 +1 @@
1
- {"version":3,"file":"is-aes.d.ts","sourceRoot":"","sources":["../../src/utils/is-aes.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,mBAAmB,EAAE,uBAAuB,EAAE,MAAM,UAAU,CAAC;AAExE,eAAO,MAAM,eAAe,GAC1B,MAAM,mBAAmB,GAAG,uBAAuB,KAClD,IAAI,IAAI,mBAAmE,CAAC;AAE/E,eAAO,MAAM,mBAAmB,GAC9B,SAAS,mBAAmB,GAAG,uBAAuB,KACrD,OAAO,IAAI,uBACqC,CAAC;AAEpD,eAAO,MAAM,cAAc,GAAI,QAAQ,MAAM,KAAG,OAKvB,CAAC"}
1
+ {"version":3,"file":"is-aes.d.ts","sourceRoot":"","sources":["../../src/utils/is-aes.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,mBAAmB,EAAE,uBAAuB,EAAE,MAAM,UAAU,CAAC;AAExE,eAAO,MAAM,eAAe,GAC1B,MAAM,mBAAmB,GAAG,uBAAuB,KAClD,IAAI,IAAI,mBAAmE,CAAC;AAE/E,eAAO,MAAM,mBAAmB,GAC9B,SAAS,mBAAmB,GAAG,uBAAuB,KACrD,OAAO,IAAI,uBACqC,CAAC;AAEpD,eAAO,MAAM,cAAc,GAAI,QAAQ,MAAM,KAAG,OACD,CAAC"}
@@ -6,10 +6,6 @@ const isAesBufferData = (data) => Object.values(data).some((x) => (0, is_1.isBuf
6
6
  exports.isAesBufferData = isAesBufferData;
7
7
  const isAesSerialisedData = (options) => Object.values(options).every((x) => !(0, is_1.isBuffer)(x));
8
8
  exports.isAesSerialisedData = isAesSerialisedData;
9
- const isAesTokenised = (string) => (0, is_1.isString)(string) &&
10
- string.startsWith("$") &&
11
- string.endsWith("$") &&
12
- string.includes("v=") &&
13
- string.includes("alg=");
9
+ const isAesTokenised = (string) => (0, is_1.isString)(string) && string.startsWith("aes:");
14
10
  exports.isAesTokenised = isAesTokenised;
15
11
  //# sourceMappingURL=is-aes.js.map