@lindorm/aes 0.6.5 → 0.7.1

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 (264) hide show
  1. package/README.md +126 -231
  2. package/dist/classes/AesKit.d.ts +4 -4
  3. package/dist/classes/AesKit.d.ts.map +1 -1
  4. package/dist/classes/AesKit.js +29 -33
  5. package/dist/classes/AesKit.js.map +1 -1
  6. package/dist/classes/index.d.ts +1 -1
  7. package/dist/classes/index.d.ts.map +1 -1
  8. package/dist/classes/index.js +1 -17
  9. package/dist/classes/index.js.map +1 -1
  10. package/dist/errors/AesError.js +2 -6
  11. package/dist/errors/AesError.js.map +1 -1
  12. package/dist/errors/index.d.ts +1 -1
  13. package/dist/errors/index.d.ts.map +1 -1
  14. package/dist/errors/index.js +1 -17
  15. package/dist/errors/index.js.map +1 -1
  16. package/dist/index.d.ts +5 -6
  17. package/dist/index.d.ts.map +1 -1
  18. package/dist/index.js +5 -22
  19. package/dist/index.js.map +1 -1
  20. package/dist/interfaces/AesKit.d.ts +3 -3
  21. package/dist/interfaces/AesKit.d.ts.map +1 -1
  22. package/dist/interfaces/AesKit.js +1 -2
  23. package/dist/interfaces/index.d.ts +1 -1
  24. package/dist/interfaces/index.d.ts.map +1 -1
  25. package/dist/interfaces/index.js +1 -17
  26. package/dist/interfaces/index.js.map +1 -1
  27. package/dist/internal/constants/version.js +3 -6
  28. package/dist/internal/constants/version.js.map +1 -1
  29. package/dist/internal/types/aes-data.d.ts +4 -4
  30. package/dist/internal/types/aes-data.d.ts.map +1 -1
  31. package/dist/internal/types/aes-data.js +1 -2
  32. package/dist/internal/types/aes-key-derivation.js +1 -2
  33. package/dist/internal/types/auth-tag.d.ts +2 -2
  34. package/dist/internal/types/auth-tag.d.ts.map +1 -1
  35. package/dist/internal/types/auth-tag.js +1 -2
  36. package/dist/internal/types/auth-tag.js.map +1 -1
  37. package/dist/internal/types/content-encryption-key.d.ts +2 -2
  38. package/dist/internal/types/content-encryption-key.d.ts.map +1 -1
  39. package/dist/internal/types/content-encryption-key.js +1 -2
  40. package/dist/internal/types/key-wrap.d.ts +1 -1
  41. package/dist/internal/types/key-wrap.d.ts.map +1 -1
  42. package/dist/internal/types/key-wrap.js +1 -2
  43. package/dist/internal/types/prepared-encryption.d.ts +3 -3
  44. package/dist/internal/types/prepared-encryption.d.ts.map +1 -1
  45. package/dist/internal/types/prepared-encryption.js +1 -2
  46. package/dist/internal/utils/aes-header.d.ts +3 -3
  47. package/dist/internal/utils/aes-header.d.ts.map +1 -1
  48. package/dist/internal/utils/aes-header.js +22 -30
  49. package/dist/internal/utils/aes-header.js.map +1 -1
  50. package/dist/internal/utils/calculate/calculate-aes-encryption.d.ts +2 -2
  51. package/dist/internal/utils/calculate/calculate-aes-encryption.d.ts.map +1 -1
  52. package/dist/internal/utils/calculate/calculate-aes-encryption.js +4 -8
  53. package/dist/internal/utils/calculate/calculate-aes-encryption.js.map +1 -1
  54. package/dist/internal/utils/calculate/calculate-content-encryption-key-size.d.ts +2 -2
  55. package/dist/internal/utils/calculate/calculate-content-encryption-key-size.d.ts.map +1 -1
  56. package/dist/internal/utils/calculate/calculate-content-encryption-key-size.js +4 -8
  57. package/dist/internal/utils/calculate/calculate-content-encryption-key-size.js.map +1 -1
  58. package/dist/internal/utils/calculate/calculate-key-wrap-encryption.d.ts +1 -1
  59. package/dist/internal/utils/calculate/calculate-key-wrap-encryption.d.ts.map +1 -1
  60. package/dist/internal/utils/calculate/calculate-key-wrap-encryption.js +3 -7
  61. package/dist/internal/utils/calculate/calculate-key-wrap-encryption.js.map +1 -1
  62. package/dist/internal/utils/calculate/calculate-key-wrap-size.d.ts +2 -2
  63. package/dist/internal/utils/calculate/calculate-key-wrap-size.d.ts.map +1 -1
  64. package/dist/internal/utils/calculate/calculate-key-wrap-size.js +3 -7
  65. package/dist/internal/utils/calculate/calculate-key-wrap-size.js.map +1 -1
  66. package/dist/internal/utils/calculate/calculate-pbkdf-hash.d.ts +2 -2
  67. package/dist/internal/utils/calculate/calculate-pbkdf-hash.d.ts.map +1 -1
  68. package/dist/internal/utils/calculate/calculate-pbkdf-hash.js +3 -7
  69. package/dist/internal/utils/calculate/calculate-pbkdf-hash.js.map +1 -1
  70. package/dist/internal/utils/calculate/calculate-rsa-oaep-hash.d.ts +2 -2
  71. package/dist/internal/utils/calculate/calculate-rsa-oaep-hash.d.ts.map +1 -1
  72. package/dist/internal/utils/calculate/calculate-rsa-oaep-hash.js +3 -7
  73. package/dist/internal/utils/calculate/calculate-rsa-oaep-hash.js.map +1 -1
  74. package/dist/internal/utils/content.d.ts +1 -1
  75. package/dist/internal/utils/content.d.ts.map +1 -1
  76. package/dist/internal/utils/content.js +11 -17
  77. package/dist/internal/utils/content.js.map +1 -1
  78. package/dist/internal/utils/data/auth-tag-hmac.d.ts +1 -1
  79. package/dist/internal/utils/data/auth-tag-hmac.d.ts.map +1 -1
  80. package/dist/internal/utils/data/auth-tag-hmac.js +9 -14
  81. package/dist/internal/utils/data/auth-tag-hmac.js.map +1 -1
  82. package/dist/internal/utils/data/auth-tag.d.ts +1 -1
  83. package/dist/internal/utils/data/auth-tag.d.ts.map +1 -1
  84. package/dist/internal/utils/data/auth-tag.js +9 -14
  85. package/dist/internal/utils/data/auth-tag.js.map +1 -1
  86. package/dist/internal/utils/data/get-initialisation-vector.d.ts +1 -1
  87. package/dist/internal/utils/data/get-initialisation-vector.d.ts.map +1 -1
  88. package/dist/internal/utils/data/get-initialisation-vector.js +6 -10
  89. package/dist/internal/utils/data/get-initialisation-vector.js.map +1 -1
  90. package/dist/internal/utils/data/split-content-encryption-key.d.ts +1 -1
  91. package/dist/internal/utils/data/split-content-encryption-key.d.ts.map +1 -1
  92. package/dist/internal/utils/data/split-content-encryption-key.js +4 -8
  93. package/dist/internal/utils/data/split-content-encryption-key.js.map +1 -1
  94. package/dist/internal/utils/diffie-hellman/diffie-hellman-key-wrap.d.ts +1 -1
  95. package/dist/internal/utils/diffie-hellman/diffie-hellman-key-wrap.d.ts.map +1 -1
  96. package/dist/internal/utils/diffie-hellman/diffie-hellman-key-wrap.js +20 -25
  97. package/dist/internal/utils/diffie-hellman/diffie-hellman-key-wrap.js.map +1 -1
  98. package/dist/internal/utils/diffie-hellman/diffie-hellman.d.ts +1 -1
  99. package/dist/internal/utils/diffie-hellman/diffie-hellman.d.ts.map +1 -1
  100. package/dist/internal/utils/diffie-hellman/diffie-hellman.js +16 -21
  101. package/dist/internal/utils/diffie-hellman/diffie-hellman.js.map +1 -1
  102. package/dist/internal/utils/diffie-hellman/shared-secret.d.ts +3 -3
  103. package/dist/internal/utils/diffie-hellman/shared-secret.d.ts.map +1 -1
  104. package/dist/internal/utils/diffie-hellman/shared-secret.js +22 -27
  105. package/dist/internal/utils/diffie-hellman/shared-secret.js.map +1 -1
  106. package/dist/internal/utils/encoded-aes.d.ts +2 -2
  107. package/dist/internal/utils/encoded-aes.d.ts.map +1 -1
  108. package/dist/internal/utils/encoded-aes.js +18 -23
  109. package/dist/internal/utils/encoded-aes.js.map +1 -1
  110. package/dist/internal/utils/encrypt-content.d.ts +1 -1
  111. package/dist/internal/utils/encrypt-content.d.ts.map +1 -1
  112. package/dist/internal/utils/encrypt-content.js +14 -18
  113. package/dist/internal/utils/encrypt-content.js.map +1 -1
  114. package/dist/internal/utils/encrypt-encoded.d.ts +2 -2
  115. package/dist/internal/utils/encrypt-encoded.d.ts.map +1 -1
  116. package/dist/internal/utils/encrypt-encoded.js +15 -19
  117. package/dist/internal/utils/encrypt-encoded.js.map +1 -1
  118. package/dist/internal/utils/encrypt-serialised.d.ts +3 -3
  119. package/dist/internal/utils/encrypt-serialised.d.ts.map +1 -1
  120. package/dist/internal/utils/encrypt-serialised.js +20 -24
  121. package/dist/internal/utils/encrypt-serialised.js.map +1 -1
  122. package/dist/internal/utils/encrypt-tokenised.d.ts +2 -2
  123. package/dist/internal/utils/encrypt-tokenised.d.ts.map +1 -1
  124. package/dist/internal/utils/encrypt-tokenised.js +18 -22
  125. package/dist/internal/utils/encrypt-tokenised.js.map +1 -1
  126. package/dist/internal/utils/encryption.d.ts +3 -3
  127. package/dist/internal/utils/encryption.d.ts.map +1 -1
  128. package/dist/internal/utils/encryption.js +22 -27
  129. package/dist/internal/utils/encryption.js.map +1 -1
  130. package/dist/internal/utils/get-key/get-decryption-key.d.ts +1 -1
  131. package/dist/internal/utils/get-key/get-decryption-key.d.ts.map +1 -1
  132. package/dist/internal/utils/get-key/get-decryption-key.js +11 -15
  133. package/dist/internal/utils/get-key/get-decryption-key.js.map +1 -1
  134. package/dist/internal/utils/get-key/get-encryption-key.d.ts +1 -1
  135. package/dist/internal/utils/get-key/get-encryption-key.d.ts.map +1 -1
  136. package/dist/internal/utils/get-key/get-encryption-key.js +11 -15
  137. package/dist/internal/utils/get-key/get-encryption-key.js.map +1 -1
  138. package/dist/internal/utils/key-derivation/concat-kdf.d.ts +1 -1
  139. package/dist/internal/utils/key-derivation/concat-kdf.d.ts.map +1 -1
  140. package/dist/internal/utils/key-derivation/concat-kdf.js +3 -7
  141. package/dist/internal/utils/key-derivation/concat-kdf.js.map +1 -1
  142. package/dist/internal/utils/key-derivation/pbkdf.d.ts +1 -1
  143. package/dist/internal/utils/key-derivation/pbkdf.d.ts.map +1 -1
  144. package/dist/internal/utils/key-derivation/pbkdf.js +7 -11
  145. package/dist/internal/utils/key-derivation/pbkdf.js.map +1 -1
  146. package/dist/internal/utils/key-types/get-ec-keys.d.ts +1 -1
  147. package/dist/internal/utils/key-types/get-ec-keys.d.ts.map +1 -1
  148. package/dist/internal/utils/key-types/get-ec-keys.js +11 -16
  149. package/dist/internal/utils/key-types/get-ec-keys.js.map +1 -1
  150. package/dist/internal/utils/key-types/get-oct-keys.d.ts +1 -1
  151. package/dist/internal/utils/key-types/get-oct-keys.d.ts.map +1 -1
  152. package/dist/internal/utils/key-types/get-oct-keys.js +14 -19
  153. package/dist/internal/utils/key-types/get-oct-keys.js.map +1 -1
  154. package/dist/internal/utils/key-types/get-okp-keys.d.ts +1 -1
  155. package/dist/internal/utils/key-types/get-okp-keys.d.ts.map +1 -1
  156. package/dist/internal/utils/key-types/get-okp-keys.js +11 -16
  157. package/dist/internal/utils/key-types/get-okp-keys.js.map +1 -1
  158. package/dist/internal/utils/key-types/get-rsa-keys.d.ts +1 -1
  159. package/dist/internal/utils/key-types/get-rsa-keys.d.ts.map +1 -1
  160. package/dist/internal/utils/key-types/get-rsa-keys.js +24 -29
  161. package/dist/internal/utils/key-types/get-rsa-keys.js.map +1 -1
  162. package/dist/internal/utils/key-wrap/ecb-key-wrap.d.ts +1 -1
  163. package/dist/internal/utils/key-wrap/ecb-key-wrap.d.ts.map +1 -1
  164. package/dist/internal/utils/key-wrap/ecb-key-wrap.js +12 -17
  165. package/dist/internal/utils/key-wrap/ecb-key-wrap.js.map +1 -1
  166. package/dist/internal/utils/key-wrap/gcm-key-wrap.d.ts +1 -1
  167. package/dist/internal/utils/key-wrap/gcm-key-wrap.d.ts.map +1 -1
  168. package/dist/internal/utils/key-wrap/gcm-key-wrap.js +14 -19
  169. package/dist/internal/utils/key-wrap/gcm-key-wrap.js.map +1 -1
  170. package/dist/internal/utils/key-wrap/key-wrap.d.ts +1 -1
  171. package/dist/internal/utils/key-wrap/key-wrap.d.ts.map +1 -1
  172. package/dist/internal/utils/key-wrap/key-wrap.js +11 -16
  173. package/dist/internal/utils/key-wrap/key-wrap.js.map +1 -1
  174. package/dist/internal/utils/oct/get-oct-dir-keys.d.ts +1 -1
  175. package/dist/internal/utils/oct/get-oct-dir-keys.d.ts.map +1 -1
  176. package/dist/internal/utils/oct/get-oct-dir-keys.js +13 -18
  177. package/dist/internal/utils/oct/get-oct-dir-keys.js.map +1 -1
  178. package/dist/internal/utils/oct/get-oct-key-key-wrap.d.ts +1 -1
  179. package/dist/internal/utils/oct/get-oct-key-key-wrap.d.ts.map +1 -1
  180. package/dist/internal/utils/oct/get-oct-key-key-wrap.js +19 -24
  181. package/dist/internal/utils/oct/get-oct-key-key-wrap.js.map +1 -1
  182. package/dist/internal/utils/oct/get-oct-pbkdf-key-wrap-keys.d.ts +1 -1
  183. package/dist/internal/utils/oct/get-oct-pbkdf-key-wrap-keys.d.ts.map +1 -1
  184. package/dist/internal/utils/oct/get-oct-pbkdf-key-wrap-keys.js +25 -30
  185. package/dist/internal/utils/oct/get-oct-pbkdf-key-wrap-keys.js.map +1 -1
  186. package/dist/internal/utils/prepare-encryption.d.ts +1 -1
  187. package/dist/internal/utils/prepare-encryption.d.ts.map +1 -1
  188. package/dist/internal/utils/prepare-encryption.js +5 -9
  189. package/dist/internal/utils/prepare-encryption.js.map +1 -1
  190. package/dist/internal/utils/serialised-aes.d.ts +2 -2
  191. package/dist/internal/utils/serialised-aes.d.ts.map +1 -1
  192. package/dist/internal/utils/serialised-aes.js +19 -24
  193. package/dist/internal/utils/serialised-aes.js.map +1 -1
  194. package/dist/internal/utils/tokenised-aes.d.ts +2 -2
  195. package/dist/internal/utils/tokenised-aes.d.ts.map +1 -1
  196. package/dist/internal/utils/tokenised-aes.js +22 -27
  197. package/dist/internal/utils/tokenised-aes.js.map +1 -1
  198. package/dist/internal/utils/validate-version.js +8 -12
  199. package/dist/internal/utils/validate-version.js.map +1 -1
  200. package/dist/mocks/create-mock-aes-kit.d.ts +4 -0
  201. package/dist/mocks/create-mock-aes-kit.d.ts.map +1 -0
  202. package/dist/mocks/create-mock-aes-kit.js +81 -0
  203. package/dist/mocks/create-mock-aes-kit.js.map +1 -0
  204. package/dist/mocks/jest.d.ts +5 -0
  205. package/dist/mocks/jest.d.ts.map +1 -0
  206. package/dist/mocks/jest.js +4 -0
  207. package/dist/mocks/jest.js.map +1 -0
  208. package/dist/mocks/vitest.d.ts +6 -0
  209. package/dist/mocks/vitest.d.ts.map +1 -0
  210. package/dist/mocks/vitest.js +5 -0
  211. package/dist/mocks/vitest.js.map +1 -0
  212. package/dist/types/aes-decryption-data.d.ts +3 -3
  213. package/dist/types/aes-decryption-data.d.ts.map +1 -1
  214. package/dist/types/aes-decryption-data.js +1 -2
  215. package/dist/types/aes-encryption-data.d.ts +3 -3
  216. package/dist/types/aes-encryption-data.d.ts.map +1 -1
  217. package/dist/types/aes-encryption-data.js +1 -2
  218. package/dist/types/aes-kit.d.ts +1 -1
  219. package/dist/types/aes-kit.d.ts.map +1 -1
  220. package/dist/types/aes-kit.js +1 -2
  221. package/dist/types/content.d.ts +1 -1
  222. package/dist/types/content.d.ts.map +1 -1
  223. package/dist/types/content.js +1 -2
  224. package/dist/types/curve.js +1 -2
  225. package/dist/types/index.d.ts +7 -7
  226. package/dist/types/index.d.ts.map +1 -1
  227. package/dist/types/index.js +6 -22
  228. package/dist/types/index.js.map +1 -1
  229. package/dist/types/types.d.ts +1 -1
  230. package/dist/types/types.d.ts.map +1 -1
  231. package/dist/types/types.js +1 -2
  232. package/dist/utils/index.d.ts +2 -2
  233. package/dist/utils/index.d.ts.map +1 -1
  234. package/dist/utils/index.js +2 -18
  235. package/dist/utils/index.js.map +1 -1
  236. package/dist/utils/is-aes.d.ts +1 -1
  237. package/dist/utils/is-aes.d.ts.map +1 -1
  238. package/dist/utils/is-aes.js +4 -10
  239. package/dist/utils/is-aes.js.map +1 -1
  240. package/dist/utils/parse-aes.d.ts +1 -1
  241. package/dist/utils/parse-aes.d.ts.map +1 -1
  242. package/dist/utils/parse-aes.js +15 -19
  243. package/dist/utils/parse-aes.js.map +1 -1
  244. package/package.json +22 -23
  245. package/CHANGELOG.md +0 -165
  246. package/MERMAID.md +0 -155
  247. package/__tests__/INTEROP-RESULTS.md +0 -66
  248. package/__tests__/esm-smoke.test.ts +0 -15
  249. package/__tests__/fixtures/keys.ts +0 -60
  250. package/__tests__/helpers/buffer-utils.ts +0 -11
  251. package/__tests__/helpers/index.ts +0 -2
  252. package/__tests__/helpers/jwe-adapter.ts +0 -123
  253. package/__tests__/jose-jwe.test.ts +0 -463
  254. package/__tests__/noble-ciphers.test.ts +0 -208
  255. package/dist/mocks/index.d.ts +0 -2
  256. package/dist/mocks/index.d.ts.map +0 -1
  257. package/dist/mocks/index.js +0 -6
  258. package/dist/mocks/index.js.map +0 -1
  259. package/dist/mocks/mock-aes-kit.d.ts +0 -4
  260. package/dist/mocks/mock-aes-kit.d.ts.map +0 -1
  261. package/dist/mocks/mock-aes-kit.js +0 -74
  262. package/dist/mocks/mock-aes-kit.js.map +0 -1
  263. package/jest.config.interop.mjs +0 -24
  264. package/tsconfig.interop.json +0 -9
@@ -1,208 +0,0 @@
1
- import { createCipheriv, randomBytes } from "crypto";
2
- import { gcm, cbc, aeskw } from "@noble/ciphers/aes";
3
- import { encryptAes, decryptAes } from "../src/utils/private/encryption";
4
- import { ecbKeyWrap, ecbKeyUnwrap } from "../src/utils/private/key-wrap/ecb-key-wrap";
5
- import { toUint8Array, toBuffer } from "./helpers/buffer-utils";
6
- import {
7
- RAW_KEY_128,
8
- RAW_KEY_192,
9
- RAW_KEY_256,
10
- RAW_KEY_256_CBC,
11
- RAW_KEY_384_CBC,
12
- RAW_KEY_512_CBC,
13
- KEK_128,
14
- KEK_192,
15
- KEK_256,
16
- createOctKryptos,
17
- } from "./fixtures/keys";
18
-
19
- const GCM_TAG_LENGTH = 16;
20
- const GCM_IV_LENGTH = 12;
21
- const AES_BLOCK_SIZE = 16;
22
-
23
- // ---------------------------------------------------------------------------
24
- // 3.1 AES-GCM Cross-Reference
25
- // ---------------------------------------------------------------------------
26
-
27
- describe("AES-GCM cross-reference with @noble/ciphers", () => {
28
- describe.each([
29
- { name: "A128GCM", key: RAW_KEY_128, encryption: "A128GCM" as const },
30
- { name: "A192GCM", key: RAW_KEY_192, encryption: "A192GCM" as const },
31
- { name: "A256GCM", key: RAW_KEY_256, encryption: "A256GCM" as const },
32
- ])("$name", ({ key, encryption }) => {
33
- const plaintext = "test plaintext";
34
-
35
- test("our encryptAes -> noble gcm decrypt", () => {
36
- const kryptos = createOctKryptos(key, "dir", encryption);
37
-
38
- const record = encryptAes({ data: plaintext, encryption, kryptos });
39
-
40
- const iv = toUint8Array(record.initialisationVector);
41
- const ciphertext = toUint8Array(record.content);
42
- const tag = toUint8Array(record.authTag);
43
-
44
- // noble expects ciphertext || tag concatenated
45
- const ciphertextWithTag = new Uint8Array(ciphertext.length + tag.length);
46
- ciphertextWithTag.set(ciphertext, 0);
47
- ciphertextWithTag.set(tag, ciphertext.length);
48
-
49
- const decrypted = gcm(toUint8Array(key), iv).decrypt(ciphertextWithTag);
50
- const result = new TextDecoder().decode(decrypted);
51
-
52
- expect(result).toBe(plaintext);
53
- });
54
-
55
- test("noble gcm encrypt -> our decryptAes", () => {
56
- const kryptos = createOctKryptos(key, "dir", encryption);
57
- const iv = randomBytes(GCM_IV_LENGTH);
58
- const plaintextBytes = new TextEncoder().encode(plaintext);
59
-
60
- const encrypted = gcm(toUint8Array(key), toUint8Array(iv)).encrypt(plaintextBytes);
61
-
62
- // noble returns ciphertext || tag (last 16 bytes are the auth tag)
63
- const ciphertext = toBuffer(encrypted.slice(0, -GCM_TAG_LENGTH));
64
- const authTag = toBuffer(encrypted.slice(-GCM_TAG_LENGTH));
65
-
66
- const result = decryptAes({
67
- content: ciphertext,
68
- authTag,
69
- initialisationVector: iv,
70
- encryption,
71
- contentType: "text/plain",
72
- kryptos,
73
- });
74
-
75
- expect(result).toBe(plaintext);
76
- });
77
-
78
- test("byte-identical ciphertext with pinned IV", () => {
79
- const iv = Buffer.alloc(GCM_IV_LENGTH, 0xab);
80
- const plaintextBytes = Buffer.from(plaintext, "utf8");
81
-
82
- // Our side: raw Node.js createCipheriv
83
- const cipher = createCipheriv(
84
- `aes-${key.length * 8}-gcm` as "aes-128-gcm" | "aes-192-gcm" | "aes-256-gcm",
85
- key,
86
- iv,
87
- { authTagLength: GCM_TAG_LENGTH },
88
- );
89
- const ourCiphertext = Buffer.concat([
90
- cipher.update(plaintextBytes),
91
- cipher.final(),
92
- ]);
93
- const ourTag = cipher.getAuthTag();
94
-
95
- // Noble side
96
- const nobleResult = gcm(toUint8Array(key), toUint8Array(iv)).encrypt(
97
- toUint8Array(plaintextBytes),
98
- );
99
- const nobleCiphertext = nobleResult.slice(0, -GCM_TAG_LENGTH);
100
- const nobleTag = nobleResult.slice(-GCM_TAG_LENGTH);
101
-
102
- expect(ourCiphertext.equals(toBuffer(nobleCiphertext))).toBe(true);
103
- expect(ourTag.equals(toBuffer(nobleTag))).toBe(true);
104
- });
105
- });
106
- });
107
-
108
- // ---------------------------------------------------------------------------
109
- // 3.2 AES-KW (RFC 3394) Cross-Reference
110
- // ---------------------------------------------------------------------------
111
-
112
- describe("AES-KW cross-reference with @noble/ciphers", () => {
113
- describe.each([
114
- { name: "A128KW", kek: KEK_128, algorithm: "A128KW" as const },
115
- { name: "A192KW", kek: KEK_192, algorithm: "A192KW" as const },
116
- { name: "A256KW", kek: KEK_256, algorithm: "A256KW" as const },
117
- ])("$name", ({ kek, algorithm }) => {
118
- // CEK to wrap: 32 bytes (suitable for A256GCM)
119
- const cek = randomBytes(32);
120
-
121
- test("our ecbKeyWrap -> noble aeskw decrypt", () => {
122
- const kryptos = createOctKryptos(kek, algorithm);
123
-
124
- const { publicEncryptionKey } = ecbKeyWrap({
125
- contentEncryptionKey: cek,
126
- keyEncryptionKey: kek,
127
- kryptos,
128
- });
129
-
130
- const unwrapped = aeskw(toUint8Array(kek)).decrypt(
131
- toUint8Array(publicEncryptionKey),
132
- );
133
-
134
- expect(cek.equals(toBuffer(unwrapped))).toBe(true);
135
- });
136
-
137
- test("noble aeskw encrypt -> our ecbKeyUnwrap", () => {
138
- const kryptos = createOctKryptos(kek, algorithm);
139
-
140
- const wrapped = aeskw(toUint8Array(kek)).encrypt(toUint8Array(cek));
141
-
142
- const { contentEncryptionKey } = ecbKeyUnwrap({
143
- keyEncryptionKey: kek,
144
- kryptos,
145
- publicEncryptionKey: toBuffer(wrapped),
146
- });
147
-
148
- expect(cek.equals(contentEncryptionKey)).toBe(true);
149
- });
150
-
151
- test("byte-identical wrapped key (deterministic)", () => {
152
- const kryptos = createOctKryptos(kek, algorithm);
153
-
154
- const { publicEncryptionKey } = ecbKeyWrap({
155
- contentEncryptionKey: cek,
156
- keyEncryptionKey: kek,
157
- kryptos,
158
- });
159
-
160
- const nobleWrapped = aeskw(toUint8Array(kek)).encrypt(toUint8Array(cek));
161
-
162
- expect(publicEncryptionKey.equals(toBuffer(nobleWrapped))).toBe(true);
163
- });
164
- });
165
- });
166
-
167
- // ---------------------------------------------------------------------------
168
- // 3.3 AES-CBC Raw Cross-Reference
169
- // ---------------------------------------------------------------------------
170
-
171
- describe("AES-CBC raw cross-reference with @noble/ciphers", () => {
172
- describe.each([
173
- {
174
- name: "A128CBC",
175
- // A128CBC-HS256: 32B CEK -> first 16B = HMAC key, last 16B = AES-128-CBC key
176
- encKey: RAW_KEY_256_CBC.subarray(16),
177
- nodeCipher: "aes-128-cbc" as const,
178
- },
179
- {
180
- name: "A192CBC",
181
- // A192CBC-HS384: 48B CEK -> first 24B = HMAC key, last 24B = AES-192-CBC key
182
- encKey: RAW_KEY_384_CBC.subarray(24),
183
- nodeCipher: "aes-192-cbc" as const,
184
- },
185
- {
186
- name: "A256CBC",
187
- // A256CBC-HS512: 64B CEK -> first 32B = HMAC key, last 32B = AES-256-CBC key
188
- encKey: RAW_KEY_512_CBC.subarray(32),
189
- nodeCipher: "aes-256-cbc" as const,
190
- },
191
- ])("$name", ({ encKey, nodeCipher }) => {
192
- test("byte-identical ciphertext (PKCS7 padding)", () => {
193
- const iv = Buffer.alloc(AES_BLOCK_SIZE, 0xcd);
194
- const plaintext = Buffer.from("cross-reference CBC test", "utf8");
195
-
196
- // Our side: raw Node.js createCipheriv
197
- const cipher = createCipheriv(nodeCipher, encKey, iv);
198
- const ourCiphertext = Buffer.concat([cipher.update(plaintext), cipher.final()]);
199
-
200
- // Noble side
201
- const nobleCiphertext = cbc(toUint8Array(encKey), toUint8Array(iv)).encrypt(
202
- toUint8Array(plaintext),
203
- );
204
-
205
- expect(ourCiphertext.equals(toBuffer(nobleCiphertext))).toBe(true);
206
- });
207
- });
208
- });
@@ -1,2 +0,0 @@
1
- export { createMockAesKit, type MockAesKit } from "./mock-aes-kit";
2
- //# sourceMappingURL=index.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/mocks/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,gBAAgB,EAAE,KAAK,UAAU,EAAE,MAAM,gBAAgB,CAAC"}
@@ -1,6 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.createMockAesKit = void 0;
4
- var mock_aes_kit_1 = require("./mock-aes-kit");
5
- Object.defineProperty(exports, "createMockAesKit", { enumerable: true, get: function () { return mock_aes_kit_1.createMockAesKit; } });
6
- //# sourceMappingURL=index.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/mocks/index.ts"],"names":[],"mappings":";;;AAAA,+CAAmE;AAA1D,gHAAA,gBAAgB,OAAA"}
@@ -1,4 +0,0 @@
1
- import { IAesKit } from "../interfaces";
2
- export type MockAesKit = jest.Mocked<IAesKit>;
3
- export declare const createMockAesKit: () => MockAesKit;
4
- //# sourceMappingURL=mock-aes-kit.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"mock-aes-kit.d.ts","sourceRoot":"","sources":["../../src/mocks/mock-aes-kit.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,OAAO,EAAE,MAAM,eAAe,CAAC;AAGxC,MAAM,MAAM,UAAU,GAAG,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC;AAQ9C,eAAO,MAAM,gBAAgB,QAAO,UAwElC,CAAC"}
@@ -1,74 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.createMockAesKit = void 0;
4
- const kryptos_1 = require("@lindorm/kryptos");
5
- const encode = (data) => Buffer.from(JSON.stringify(data)).toString("base64url");
6
- const decode = (encoded) => JSON.parse(Buffer.from(encoded, "base64url").toString());
7
- const createMockAesKit = () => ({
8
- kryptos: (0, kryptos_1.createMockKryptos)(),
9
- encrypt: jest.fn().mockImplementation((data, mode) => {
10
- const encoded = encode(data);
11
- switch (mode) {
12
- case "tokenised":
13
- return `aes:${encoded}`;
14
- case "serialised":
15
- return {
16
- cek: undefined,
17
- ciphertext: encoded,
18
- header: encode({ alg: "dir", enc: "A256GCM", cty: "text/plain" }),
19
- iv: "mock_iv",
20
- tag: "mock_tag",
21
- v: "1",
22
- };
23
- case "record":
24
- return {
25
- algorithm: "dir",
26
- authTag: Buffer.from("mock_tag"),
27
- content: Buffer.from(encoded),
28
- contentType: "text/plain",
29
- encryption: "A256GCM",
30
- initialisationVector: Buffer.from("mock_iv"),
31
- keyId: "mock_key_id",
32
- pbkdfIterations: undefined,
33
- pbkdfSalt: undefined,
34
- publicEncryptionIv: undefined,
35
- publicEncryptionJwk: undefined,
36
- publicEncryptionKey: undefined,
37
- publicEncryptionTag: undefined,
38
- version: "1",
39
- };
40
- case "encoded":
41
- default:
42
- return encoded;
43
- }
44
- }),
45
- decrypt: jest.fn().mockImplementation((data) => {
46
- if (typeof data === "string") {
47
- if (data.startsWith("aes:")) {
48
- return decode(data.slice(4));
49
- }
50
- return decode(data);
51
- }
52
- if (data.ciphertext) {
53
- return decode(data.ciphertext);
54
- }
55
- if (Buffer.isBuffer(data.content)) {
56
- return decode(data.content.toString());
57
- }
58
- return data;
59
- }),
60
- assert: jest.fn(),
61
- verify: jest.fn().mockReturnValue(true),
62
- prepareEncryption: jest.fn().mockReturnValue({
63
- headerParams: {},
64
- publicEncryptionKey: undefined,
65
- encrypt: jest.fn().mockReturnValue({
66
- authTag: Buffer.alloc(16),
67
- content: Buffer.alloc(0),
68
- contentType: "text/plain",
69
- initialisationVector: Buffer.alloc(12),
70
- }),
71
- }),
72
- });
73
- exports.createMockAesKit = createMockAesKit;
74
- //# sourceMappingURL=mock-aes-kit.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"mock-aes-kit.js","sourceRoot":"","sources":["../../src/mocks/mock-aes-kit.ts"],"names":[],"mappings":"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"}
@@ -1,24 +0,0 @@
1
- import base from "../../jest.config.base.mjs";
2
- import packageJson from "./package.json" with { type: "json" };
3
-
4
- export default {
5
- ...base,
6
- displayName: `${packageJson.name}/interop`,
7
- roots: ["<rootDir>/__tests__"],
8
- extensionsToTreatAsEsm: [".ts"],
9
- moduleNameMapper: {
10
- "^(\\.{1,2}/.*)\\.js$": "$1",
11
- },
12
- transform: {
13
- "^.+\\.tsx?$": [
14
- "ts-jest",
15
- {
16
- useESM: true,
17
- tsconfig: "tsconfig.interop.json",
18
- },
19
- ],
20
- },
21
- transformIgnorePatterns: ["node_modules/(?!(@noble/ciphers|jose)/)"],
22
- collectCoverageFrom: [],
23
- coverageThreshold: {},
24
- };
@@ -1,9 +0,0 @@
1
- {
2
- "extends": "../../tsconfig.json",
3
- "compilerOptions": {
4
- "module": "esnext",
5
- "moduleResolution": "node",
6
- "rootDir": "."
7
- },
8
- "include": ["__tests__/**/*", "src/**/*"]
9
- }