@lindorm/aes 0.5.4 → 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 +30 -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 +6 -3
  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,173 +1,110 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.parseEncodedAesString = exports.createEncodedAesString = void 0;
4
+ const b64_1 = require("@lindorm/b64");
5
+ const errors_1 = require("../../errors");
6
+ const aes_header_1 = require("./aes-header");
7
+ const getIvSize = (enc) => (enc.includes("GCM") ? 12 : 16);
8
+ const getTagSize = (enc) => {
9
+ if (enc.includes("GCM"))
10
+ return 16;
11
+ if (enc === "A128CBC-HS256")
12
+ return 16;
13
+ if (enc === "A192CBC-HS384")
14
+ return 24;
15
+ if (enc === "A256CBC-HS512")
16
+ return 32;
17
+ return 16;
18
+ };
4
19
  const createEncodedAesString = (data) => {
20
+ const header = (0, aes_header_1.buildAesHeader)({
21
+ algorithm: data.algorithm,
22
+ contentType: data.contentType,
23
+ encryption: data.encryption,
24
+ keyId: data.keyId,
25
+ pbkdfIterations: data.pbkdfIterations,
26
+ pbkdfSalt: data.pbkdfSalt,
27
+ publicEncryptionIv: data.publicEncryptionIv,
28
+ publicEncryptionJwk: data.publicEncryptionJwk,
29
+ publicEncryptionTag: data.publicEncryptionTag,
30
+ });
31
+ const headerJson = Buffer.from(JSON.stringify(header), "utf8");
5
32
  const buffers = [];
6
- const version = Buffer.from(data.version.toString());
7
- buffers.push(Buffer.from([version.length]), version);
8
- const keyId = Buffer.from(data.keyId);
9
- buffers.push(Buffer.from([keyId.length]), keyId);
10
- const algorithm = Buffer.from(data.algorithm);
11
- buffers.push(Buffer.from([algorithm.length]), algorithm);
12
- const encryption = Buffer.from(data.encryption);
13
- buffers.push(Buffer.from([encryption.length]), encryption);
14
- const contentType = Buffer.from(data.contentType);
15
- buffers.push(Buffer.from([contentType.length]), contentType);
16
- buffers.push(Buffer.from([data.authTag.length]), data.authTag);
17
- buffers.push(Buffer.from([data.initialisationVector.length]), data.initialisationVector);
18
- const optionalFields = [];
19
- if (data.hkdfSalt) {
20
- optionalFields.push(Buffer.from([1]));
21
- optionalFields.push(Buffer.from([data.hkdfSalt.length]), data.hkdfSalt);
22
- }
23
- else {
24
- optionalFields.push(Buffer.from([0]));
25
- }
26
- if (data.pbkdfSalt) {
27
- const pbkdfIterations = Buffer.alloc(4);
28
- pbkdfIterations.writeUInt32BE(data.pbkdfIterations || 0);
29
- optionalFields.push(Buffer.from([1]));
30
- optionalFields.push(pbkdfIterations);
31
- }
32
- else {
33
- optionalFields.push(Buffer.from([0]));
34
- }
35
- if (data.pbkdfSalt) {
36
- optionalFields.push(Buffer.from([1]));
37
- optionalFields.push(Buffer.from([data.pbkdfSalt.length]), data.pbkdfSalt);
38
- }
39
- else {
40
- optionalFields.push(Buffer.from([0]));
41
- }
42
- if (data.publicEncryptionIv) {
43
- optionalFields.push(Buffer.from([1]));
44
- optionalFields.push(Buffer.from([data.publicEncryptionIv.length]), data.publicEncryptionIv);
45
- }
46
- else {
47
- optionalFields.push(Buffer.from([0]));
48
- }
49
- const publicEncryptionJwkStr = data.publicEncryptionJwk
50
- ? JSON.stringify(data.publicEncryptionJwk)
51
- : "";
52
- if (publicEncryptionJwkStr.length > 0) {
53
- optionalFields.push(Buffer.from([1]));
54
- optionalFields.push(Buffer.from([publicEncryptionJwkStr.length]), Buffer.from(publicEncryptionJwkStr));
55
- }
56
- else {
57
- optionalFields.push(Buffer.from([0]));
58
- }
33
+ const headerLength = Buffer.alloc(2);
34
+ headerLength.writeUInt16BE(headerJson.length);
35
+ buffers.push(headerLength, headerJson);
36
+ const cekLength = data.publicEncryptionKey?.length ?? 0;
37
+ const cekLengthBuf = Buffer.alloc(2);
38
+ cekLengthBuf.writeUInt16BE(cekLength);
39
+ buffers.push(cekLengthBuf);
59
40
  if (data.publicEncryptionKey) {
60
- optionalFields.push(Buffer.from([1]));
61
- const keyLength = Buffer.alloc(4);
62
- keyLength.writeUInt32BE(data.publicEncryptionKey.length);
63
- optionalFields.push(keyLength, data.publicEncryptionKey);
64
- }
65
- else {
66
- optionalFields.push(Buffer.from([0]));
67
- }
68
- if (data.publicEncryptionTag) {
69
- optionalFields.push(Buffer.from([1]));
70
- optionalFields.push(Buffer.from([data.publicEncryptionTag.length]), data.publicEncryptionTag);
41
+ buffers.push(data.publicEncryptionKey);
71
42
  }
72
- else {
73
- optionalFields.push(Buffer.from([0]));
74
- }
75
- const optionalFieldsLength = Buffer.alloc(4);
76
- optionalFieldsLength.writeUInt32BE(Buffer.concat(optionalFields).length);
77
- buffers.push(optionalFieldsLength, ...optionalFields);
43
+ buffers.push(data.initialisationVector);
44
+ buffers.push(data.authTag);
78
45
  buffers.push(data.content);
79
- return Buffer.concat(buffers).toString("base64url");
46
+ return b64_1.B64.encode(Buffer.concat(buffers), "b64u");
80
47
  };
81
48
  exports.createEncodedAesString = createEncodedAesString;
82
49
  const parseEncodedAesString = (encoded) => {
83
- const buffer = Buffer.from(encoded, "base64url");
50
+ const buffer = b64_1.B64.toBuffer(encoded, "b64u");
84
51
  let offset = 0;
85
- const readFieldWithLength = () => {
86
- const length = buffer.readUInt8(offset);
87
- offset += 1;
88
- const field = buffer.subarray(offset, offset + length);
89
- offset += length;
90
- return field;
91
- };
92
- const readOptionalFieldWithLength = () => {
93
- const exists = buffer.readUInt8(offset);
94
- offset += 1;
95
- if (exists === 0)
96
- return undefined;
97
- const length = buffer.readUInt8(offset);
98
- offset += 1;
99
- const field = buffer.subarray(offset, offset + length);
100
- offset += length;
101
- return field;
102
- };
103
- const readOptionalFieldWithLargeLength = () => {
104
- const exists = buffer.readUInt8(offset);
105
- offset += 1;
106
- if (exists === 0)
107
- return undefined;
108
- const length = buffer.readUInt32BE(offset);
109
- offset += 4;
110
- const field = buffer.subarray(offset, offset + length);
111
- offset += length;
112
- return field;
113
- };
114
- const versionLength = buffer.readUInt8(offset);
115
- offset += 1;
116
- const version = parseInt(buffer.subarray(offset, offset + versionLength).toString(), 10);
117
- offset += versionLength;
118
- const keyId = readFieldWithLength().toString();
119
- const algorithm = readFieldWithLength().toString();
120
- const encryption = readFieldWithLength().toString();
121
- const contentType = readFieldWithLength().toString();
122
- const authTag = readFieldWithLength();
123
- const initialisationVector = readFieldWithLength();
124
- const optionalFieldsLength = buffer.readUInt32BE(offset);
125
- offset += 4;
126
- const optionalFieldsStart = offset;
127
- const hkdfSalt = readOptionalFieldWithLength();
128
- let pbkdfIterations;
129
- const pbkdfIterationsExists = buffer.readUInt8(offset);
130
- offset += 1;
131
- if (pbkdfIterationsExists === 1) {
132
- pbkdfIterations = buffer.readUInt32BE(offset);
133
- offset += 4;
134
- }
135
- const pbkdfSalt = readOptionalFieldWithLength();
136
- const publicEncryptionIv = readOptionalFieldWithLength();
137
- let publicEncryptionJwk;
138
- const publicEncryptionJwkBuffer = readOptionalFieldWithLength();
139
- if (publicEncryptionJwkBuffer) {
140
- const jwkString = publicEncryptionJwkBuffer.toString();
141
- try {
142
- publicEncryptionJwk = JSON.parse(jwkString);
143
- }
144
- catch {
145
- throw new SyntaxError(`Invalid JSON in publicEncryptionJwk: ${jwkString}`);
52
+ if (offset + 2 > buffer.length) {
53
+ throw new errors_1.AesError("Unexpected end of encoded AES data: missing header length");
54
+ }
55
+ const headerJsonLength = buffer.readUInt16BE(offset);
56
+ offset += 2;
57
+ if (offset + headerJsonLength > buffer.length) {
58
+ throw new errors_1.AesError("Unexpected end of encoded AES data: header exceeds buffer");
59
+ }
60
+ const headerJsonBytes = buffer.subarray(offset, offset + headerJsonLength);
61
+ offset += headerJsonLength;
62
+ const headerB64 = b64_1.B64.encode(headerJsonBytes, "b64u");
63
+ const decodedHeader = (0, aes_header_1.decodeAesHeader)(headerB64);
64
+ const params = (0, aes_header_1.headerToDecryptionParams)(decodedHeader);
65
+ const aad = (0, aes_header_1.computeAad)(headerB64);
66
+ if (offset + 2 > buffer.length) {
67
+ throw new errors_1.AesError("Unexpected end of encoded AES data: missing CEK length");
68
+ }
69
+ const cekLength = buffer.readUInt16BE(offset);
70
+ offset += 2;
71
+ let publicEncryptionKey;
72
+ if (cekLength > 0) {
73
+ if (offset + cekLength > buffer.length) {
74
+ throw new errors_1.AesError("Unexpected end of encoded AES data: CEK exceeds buffer");
146
75
  }
76
+ publicEncryptionKey = buffer.subarray(offset, offset + cekLength);
77
+ offset += cekLength;
78
+ }
79
+ const ivSize = getIvSize(params.encryption);
80
+ if (offset + ivSize > buffer.length) {
81
+ throw new errors_1.AesError("Unexpected end of encoded AES data: IV exceeds buffer");
147
82
  }
148
- const publicEncryptionKey = readOptionalFieldWithLargeLength();
149
- const publicEncryptionTag = readOptionalFieldWithLength();
150
- const optionalFieldsEnd = offset;
151
- if (optionalFieldsEnd - optionalFieldsStart !== optionalFieldsLength) {
152
- throw new Error("Optional fields length mismatch");
83
+ const initialisationVector = buffer.subarray(offset, offset + ivSize);
84
+ offset += ivSize;
85
+ const tagSize = getTagSize(params.encryption);
86
+ if (offset + tagSize > buffer.length) {
87
+ throw new errors_1.AesError("Unexpected end of encoded AES data: tag exceeds buffer");
153
88
  }
89
+ const authTag = buffer.subarray(offset, offset + tagSize);
90
+ offset += tagSize;
154
91
  const content = buffer.subarray(offset);
155
92
  return {
156
- algorithm,
93
+ aad,
94
+ algorithm: params.algorithm,
157
95
  authTag,
158
96
  content,
159
- contentType,
160
- encryption,
161
- hkdfSalt,
97
+ contentType: params.contentType,
98
+ encryption: params.encryption,
162
99
  initialisationVector,
163
- keyId,
164
- pbkdfIterations,
165
- pbkdfSalt,
166
- publicEncryptionIv,
167
- publicEncryptionJwk,
100
+ keyId: params.keyId,
101
+ pbkdfIterations: params.pbkdfIterations,
102
+ pbkdfSalt: params.pbkdfSalt,
103
+ publicEncryptionIv: params.publicEncryptionIv,
104
+ publicEncryptionJwk: params.publicEncryptionJwk,
168
105
  publicEncryptionKey,
169
- publicEncryptionTag,
170
- version,
106
+ publicEncryptionTag: params.publicEncryptionTag,
107
+ version: params.version,
171
108
  };
172
109
  };
173
110
  exports.parseEncodedAesString = parseEncodedAesString;
@@ -1 +1 @@
1
- {"version":3,"file":"encoded-aes.js","sourceRoot":"","sources":["../../../src/utils/private/encoded-aes.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"encoded-aes.js","sourceRoot":"","sources":["../../../src/utils/private/encoded-aes.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,3 @@
1
+ import { EncryptContentOptions, EncryptContentResult } from "../../types/private";
2
+ export declare const encryptAesContent: (options: EncryptContentOptions) => EncryptContentResult;
3
+ //# sourceMappingURL=encrypt-content.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"encrypt-content.d.ts","sourceRoot":"","sources":["../../../src/utils/private/encrypt-content.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,qBAAqB,EAAE,oBAAoB,EAAE,MAAM,qBAAqB,CAAC;AASlF,eAAO,MAAM,iBAAiB,GAC5B,SAAS,qBAAqB,KAC7B,oBAuCF,CAAC"}
@@ -0,0 +1,35 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.encryptAesContent = void 0;
4
+ const crypto_1 = require("crypto");
5
+ const calculate_1 = require("./calculate");
6
+ const content_1 = require("./content");
7
+ const data_1 = require("./data");
8
+ const encryptAesContent = (options) => {
9
+ const { aad, contentEncryptionKey, data, encryption } = options;
10
+ const { encryptionKey, hashKey } = (0, data_1.splitContentEncryptionKey)(encryption, contentEncryptionKey);
11
+ const aesEncryption = (0, calculate_1.calculateAesEncryption)(encryption);
12
+ const initialisationVector = options.initialisationVector ?? (0, data_1.getInitialisationVector)(encryption);
13
+ const isGcm = encryption.includes("GCM");
14
+ const cipherOptions = isGcm
15
+ ? { authTagLength: 16 }
16
+ : undefined;
17
+ const cipher = (0, crypto_1.createCipheriv)(aesEncryption, encryptionKey, initialisationVector, cipherOptions);
18
+ if (isGcm && aad) {
19
+ cipher.setAAD(aad);
20
+ }
21
+ const contentType = (0, content_1.calculateContentType)(data);
22
+ const buffer = (0, content_1.contentToBuffer)(data, contentType);
23
+ const content = Buffer.concat([cipher.update(buffer), cipher.final()]);
24
+ const authTag = (0, data_1.createAuthTag)({
25
+ aad,
26
+ cipher,
27
+ content,
28
+ hashKey,
29
+ encryption,
30
+ initialisationVector,
31
+ });
32
+ return { authTag, content, contentType, initialisationVector };
33
+ };
34
+ exports.encryptAesContent = encryptAesContent;
35
+ //# sourceMappingURL=encrypt-content.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"encrypt-content.js","sourceRoot":"","sources":["../../../src/utils/private/encrypt-content.ts"],"names":[],"mappings":";;;AAAA,mCAAqE;AAErE,2CAAqD;AACrD,uCAAkE;AAClE,iCAIgB;AAET,MAAM,iBAAiB,GAAG,CAC/B,OAA8B,EACR,EAAE;IACxB,MAAM,EAAE,GAAG,EAAE,oBAAoB,EAAE,IAAI,EAAE,UAAU,EAAE,GAAG,OAAO,CAAC;IAEhE,MAAM,EAAE,aAAa,EAAE,OAAO,EAAE,GAAG,IAAA,gCAAyB,EAC1D,UAAU,EACV,oBAAoB,CACrB,CAAC;IACF,MAAM,aAAa,GAAG,IAAA,kCAAsB,EAAC,UAAU,CAAC,CAAC;IACzD,MAAM,oBAAoB,GACxB,OAAO,CAAC,oBAAoB,IAAI,IAAA,8BAAuB,EAAC,UAAU,CAAC,CAAC;IACtE,MAAM,KAAK,GAAG,UAAU,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;IACzC,MAAM,aAAa,GAAiC,KAAK;QACvD,CAAC,CAAC,EAAE,aAAa,EAAE,EAAE,EAAE;QACvB,CAAC,CAAC,SAAS,CAAC;IACd,MAAM,MAAM,GAAG,IAAA,uBAAc,EAC3B,aAAa,EACb,aAAa,EACb,oBAAoB,EACpB,aAAiC,CAClC,CAAC;IAEF,IAAI,KAAK,IAAI,GAAG,EAAE,CAAC;QAChB,MAAoB,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC;IACpC,CAAC;IAED,MAAM,WAAW,GAAG,IAAA,8BAAoB,EAAC,IAAI,CAAC,CAAC;IAC/C,MAAM,MAAM,GAAG,IAAA,yBAAe,EAAC,IAAI,EAAE,WAAW,CAAC,CAAC;IAClD,MAAM,OAAO,GAAG,MAAM,CAAC,MAAM,CAAC,CAAC,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC,EAAE,MAAM,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC;IAEvE,MAAM,OAAO,GAAG,IAAA,oBAAa,EAAC;QAC5B,GAAG;QACH,MAAM;QACN,OAAO;QACP,OAAO;QACP,UAAU;QACV,oBAAoB;KACrB,CAAC,CAAC;IAEH,OAAO,EAAE,OAAO,EAAE,OAAO,EAAE,WAAW,EAAE,oBAAoB,EAAE,CAAC;AACjE,CAAC,CAAC;AAzCW,QAAA,iBAAiB,qBAyC5B"}
@@ -0,0 +1,9 @@
1
+ import { IKryptos, KryptosEncryption } from "@lindorm/kryptos";
2
+ import { AesContent } from "../../types";
3
+ export type EncryptEncodedOptions = {
4
+ data: AesContent;
5
+ encryption: KryptosEncryption;
6
+ kryptos: IKryptos;
7
+ };
8
+ export declare const encryptEncoded: (options: EncryptEncodedOptions) => string;
9
+ //# sourceMappingURL=encrypt-encoded.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"encrypt-encoded.d.ts","sourceRoot":"","sources":["../../../src/utils/private/encrypt-encoded.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,QAAQ,EAAE,iBAAiB,EAAE,MAAM,kBAAkB,CAAC;AAC/D,OAAO,EAAE,UAAU,EAAE,MAAM,aAAa,CAAC;AAOzC,MAAM,MAAM,qBAAqB,GAAG;IAClC,IAAI,EAAE,UAAU,CAAC;IACjB,UAAU,EAAE,iBAAiB,CAAC;IAC9B,OAAO,EAAE,QAAQ,CAAC;CACnB,CAAC;AAEF,eAAO,MAAM,cAAc,GAAI,SAAS,qBAAqB,KAAG,MAgE/D,CAAC"}
@@ -0,0 +1,53 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.encryptEncoded = void 0;
4
+ const b64_1 = require("@lindorm/b64");
5
+ const aes_header_1 = require("./aes-header");
6
+ const content_1 = require("./content");
7
+ const data_1 = require("./data");
8
+ const encrypt_content_1 = require("./encrypt-content");
9
+ const get_key_1 = require("./get-key");
10
+ const encryptEncoded = (options) => {
11
+ const { data, encryption, kryptos } = options;
12
+ const keyResult = (0, get_key_1.getEncryptionKey)({ encryption, kryptos });
13
+ const initialisationVector = (0, data_1.getInitialisationVector)(encryption);
14
+ const contentType = (0, content_1.calculateContentType)(data);
15
+ const header = (0, aes_header_1.buildAesHeader)({
16
+ algorithm: kryptos.algorithm,
17
+ contentType,
18
+ encryption,
19
+ keyId: kryptos.id,
20
+ pbkdfIterations: keyResult.pbkdfIterations,
21
+ pbkdfSalt: keyResult.pbkdfSalt,
22
+ publicEncryptionIv: keyResult.publicEncryptionIv,
23
+ publicEncryptionJwk: keyResult.publicEncryptionJwk,
24
+ publicEncryptionTag: keyResult.publicEncryptionTag,
25
+ });
26
+ const headerJson = Buffer.from(JSON.stringify(header), "utf8");
27
+ const headerB64 = b64_1.B64.encode(headerJson, "b64u");
28
+ const aad = (0, aes_header_1.computeAad)(headerB64);
29
+ const { authTag, content } = (0, encrypt_content_1.encryptAesContent)({
30
+ aad,
31
+ contentEncryptionKey: keyResult.contentEncryptionKey,
32
+ data,
33
+ encryption,
34
+ initialisationVector,
35
+ });
36
+ const buffers = [];
37
+ const headerLength = Buffer.alloc(2);
38
+ headerLength.writeUInt16BE(headerJson.length);
39
+ buffers.push(headerLength, headerJson);
40
+ const cekLength = keyResult.publicEncryptionKey?.length ?? 0;
41
+ const cekLengthBuf = Buffer.alloc(2);
42
+ cekLengthBuf.writeUInt16BE(cekLength);
43
+ buffers.push(cekLengthBuf);
44
+ if (keyResult.publicEncryptionKey) {
45
+ buffers.push(keyResult.publicEncryptionKey);
46
+ }
47
+ buffers.push(initialisationVector);
48
+ buffers.push(authTag);
49
+ buffers.push(content);
50
+ return b64_1.B64.encode(Buffer.concat(buffers), "b64u");
51
+ };
52
+ exports.encryptEncoded = encryptEncoded;
53
+ //# sourceMappingURL=encrypt-encoded.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"encrypt-encoded.js","sourceRoot":"","sources":["../../../src/utils/private/encrypt-encoded.ts"],"names":[],"mappings":";;;AAAA,sCAAmC;AAGnC,6CAA0D;AAC1D,uCAAiD;AACjD,iCAAiD;AACjD,uDAAsD;AACtD,uCAA6C;AAQtC,MAAM,cAAc,GAAG,CAAC,OAA8B,EAAU,EAAE;IACvE,MAAM,EAAE,IAAI,EAAE,UAAU,EAAE,OAAO,EAAE,GAAG,OAAO,CAAC;IAG9C,MAAM,SAAS,GAAG,IAAA,0BAAgB,EAAC,EAAE,UAAU,EAAE,OAAO,EAAE,CAAC,CAAC;IAG5D,MAAM,oBAAoB,GAAG,IAAA,8BAAuB,EAAC,UAAU,CAAC,CAAC;IAGjE,MAAM,WAAW,GAAG,IAAA,8BAAoB,EAAC,IAAI,CAAC,CAAC;IAC/C,MAAM,MAAM,GAAG,IAAA,2BAAc,EAAC;QAC5B,SAAS,EAAE,OAAO,CAAC,SAAS;QAC5B,WAAW;QACX,UAAU;QACV,KAAK,EAAE,OAAO,CAAC,EAAE;QACjB,eAAe,EAAE,SAAS,CAAC,eAAe;QAC1C,SAAS,EAAE,SAAS,CAAC,SAAS;QAC9B,kBAAkB,EAAE,SAAS,CAAC,kBAAkB;QAChD,mBAAmB,EAAE,SAAS,CAAC,mBAAmB;QAClD,mBAAmB,EAAE,SAAS,CAAC,mBAAmB;KACnD,CAAC,CAAC;IACH,MAAM,UAAU,GAAG,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,EAAE,MAAM,CAAC,CAAC;IAG/D,MAAM,SAAS,GAAG,SAAG,CAAC,MAAM,CAAC,UAAU,EAAE,MAAM,CAAC,CAAC;IACjD,MAAM,GAAG,GAAG,IAAA,uBAAU,EAAC,SAAS,CAAC,CAAC;IAGlC,MAAM,EAAE,OAAO,EAAE,OAAO,EAAE,GAAG,IAAA,mCAAiB,EAAC;QAC7C,GAAG;QACH,oBAAoB,EAAE,SAAS,CAAC,oBAAoB;QACpD,IAAI;QACJ,UAAU;QACV,oBAAoB;KACrB,CAAC,CAAC;IAGH,MAAM,OAAO,GAAa,EAAE,CAAC;IAG7B,MAAM,YAAY,GAAG,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;IACrC,YAAY,CAAC,aAAa,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC;IAC9C,OAAO,CAAC,IAAI,CAAC,YAAY,EAAE,UAAU,CAAC,CAAC;IAGvC,MAAM,SAAS,GAAG,SAAS,CAAC,mBAAmB,EAAE,MAAM,IAAI,CAAC,CAAC;IAC7D,MAAM,YAAY,GAAG,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;IACrC,YAAY,CAAC,aAAa,CAAC,SAAS,CAAC,CAAC;IACtC,OAAO,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;IAC3B,IAAI,SAAS,CAAC,mBAAmB,EAAE,CAAC;QAClC,OAAO,CAAC,IAAI,CAAC,SAAS,CAAC,mBAAmB,CAAC,CAAC;IAC9C,CAAC;IAGD,OAAO,CAAC,IAAI,CAAC,oBAAoB,CAAC,CAAC;IAGnC,OAAO,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;IAGtB,OAAO,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;IAEtB,OAAO,SAAG,CAAC,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC,OAAO,CAAC,EAAE,MAAM,CAAC,CAAC;AACpD,CAAC,CAAC;AAhEW,QAAA,cAAc,kBAgEzB"}
@@ -0,0 +1,9 @@
1
+ import { IKryptos, KryptosEncryption } from "@lindorm/kryptos";
2
+ import { AesContent, SerialisedAesEncryption } from "../../types";
3
+ export type EncryptSerialisedOptions = {
4
+ data: AesContent;
5
+ encryption: KryptosEncryption;
6
+ kryptos: IKryptos;
7
+ };
8
+ export declare const encryptSerialised: (options: EncryptSerialisedOptions) => SerialisedAesEncryption;
9
+ //# sourceMappingURL=encrypt-serialised.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"encrypt-serialised.d.ts","sourceRoot":"","sources":["../../../src/utils/private/encrypt-serialised.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,QAAQ,EAAE,iBAAiB,EAAE,MAAM,kBAAkB,CAAC;AAE/D,OAAO,EAAE,UAAU,EAAE,uBAAuB,EAAE,MAAM,aAAa,CAAC;AAOlE,MAAM,MAAM,wBAAwB,GAAG;IACrC,IAAI,EAAE,UAAU,CAAC;IACjB,UAAU,EAAE,iBAAiB,CAAC;IAC9B,OAAO,EAAE,QAAQ,CAAC;CACnB,CAAC;AAEF,eAAO,MAAM,iBAAiB,GAC5B,SAAS,wBAAwB,KAChC,uBA+CF,CAAC"}
@@ -0,0 +1,48 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.encryptSerialised = void 0;
4
+ const b64_1 = require("@lindorm/b64");
5
+ const private_1 = require("../../constants/private");
6
+ const aes_header_1 = require("./aes-header");
7
+ const content_1 = require("./content");
8
+ const data_1 = require("./data");
9
+ const encrypt_content_1 = require("./encrypt-content");
10
+ const get_key_1 = require("./get-key");
11
+ const encryptSerialised = (options) => {
12
+ const { data, encryption, kryptos } = options;
13
+ const keyResult = (0, get_key_1.getEncryptionKey)({ encryption, kryptos });
14
+ const initialisationVector = (0, data_1.getInitialisationVector)(encryption);
15
+ const contentType = (0, content_1.calculateContentType)(data);
16
+ const header = (0, aes_header_1.buildAesHeader)({
17
+ algorithm: kryptos.algorithm,
18
+ contentType,
19
+ encryption,
20
+ keyId: kryptos.id,
21
+ pbkdfIterations: keyResult.pbkdfIterations,
22
+ pbkdfSalt: keyResult.pbkdfSalt,
23
+ publicEncryptionIv: keyResult.publicEncryptionIv,
24
+ publicEncryptionJwk: keyResult.publicEncryptionJwk,
25
+ publicEncryptionTag: keyResult.publicEncryptionTag,
26
+ });
27
+ const headerB64 = (0, aes_header_1.encodeAesHeader)(header);
28
+ const aad = (0, aes_header_1.computeAad)(headerB64);
29
+ const { authTag, content } = (0, encrypt_content_1.encryptAesContent)({
30
+ aad,
31
+ contentEncryptionKey: keyResult.contentEncryptionKey,
32
+ data,
33
+ encryption,
34
+ initialisationVector,
35
+ });
36
+ return {
37
+ cek: keyResult.publicEncryptionKey
38
+ ? b64_1.B64.encode(keyResult.publicEncryptionKey, "b64u")
39
+ : undefined,
40
+ ciphertext: b64_1.B64.encode(content, "b64u"),
41
+ header: headerB64,
42
+ iv: b64_1.B64.encode(initialisationVector, "b64u"),
43
+ tag: b64_1.B64.encode(authTag, "b64u"),
44
+ v: private_1.AES_FORMAT_VERSION,
45
+ };
46
+ };
47
+ exports.encryptSerialised = encryptSerialised;
48
+ //# sourceMappingURL=encrypt-serialised.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"encrypt-serialised.js","sourceRoot":"","sources":["../../../src/utils/private/encrypt-serialised.ts"],"names":[],"mappings":";;;AAAA,sCAAmC;AAEnC,qDAA6D;AAE7D,6CAA2E;AAC3E,uCAAiD;AACjD,iCAAiD;AACjD,uDAAsD;AACtD,uCAA6C;AAQtC,MAAM,iBAAiB,GAAG,CAC/B,OAAiC,EACR,EAAE;IAC3B,MAAM,EAAE,IAAI,EAAE,UAAU,EAAE,OAAO,EAAE,GAAG,OAAO,CAAC;IAG9C,MAAM,SAAS,GAAG,IAAA,0BAAgB,EAAC,EAAE,UAAU,EAAE,OAAO,EAAE,CAAC,CAAC;IAG5D,MAAM,oBAAoB,GAAG,IAAA,8BAAuB,EAAC,UAAU,CAAC,CAAC;IAGjE,MAAM,WAAW,GAAG,IAAA,8BAAoB,EAAC,IAAI,CAAC,CAAC;IAC/C,MAAM,MAAM,GAAG,IAAA,2BAAc,EAAC;QAC5B,SAAS,EAAE,OAAO,CAAC,SAAS;QAC5B,WAAW;QACX,UAAU;QACV,KAAK,EAAE,OAAO,CAAC,EAAE;QACjB,eAAe,EAAE,SAAS,CAAC,eAAe;QAC1C,SAAS,EAAE,SAAS,CAAC,SAAS;QAC9B,kBAAkB,EAAE,SAAS,CAAC,kBAAkB;QAChD,mBAAmB,EAAE,SAAS,CAAC,mBAAmB;QAClD,mBAAmB,EAAE,SAAS,CAAC,mBAAmB;KACnD,CAAC,CAAC;IACH,MAAM,SAAS,GAAG,IAAA,4BAAe,EAAC,MAAM,CAAC,CAAC;IAG1C,MAAM,GAAG,GAAG,IAAA,uBAAU,EAAC,SAAS,CAAC,CAAC;IAGlC,MAAM,EAAE,OAAO,EAAE,OAAO,EAAE,GAAG,IAAA,mCAAiB,EAAC;QAC7C,GAAG;QACH,oBAAoB,EAAE,SAAS,CAAC,oBAAoB;QACpD,IAAI;QACJ,UAAU;QACV,oBAAoB;KACrB,CAAC,CAAC;IAGH,OAAO;QACL,GAAG,EAAE,SAAS,CAAC,mBAAmB;YAChC,CAAC,CAAC,SAAG,CAAC,MAAM,CAAC,SAAS,CAAC,mBAAmB,EAAE,MAAM,CAAC;YACnD,CAAC,CAAC,SAAS;QACb,UAAU,EAAE,SAAG,CAAC,MAAM,CAAC,OAAO,EAAE,MAAM,CAAC;QACvC,MAAM,EAAE,SAAS;QACjB,EAAE,EAAE,SAAG,CAAC,MAAM,CAAC,oBAAoB,EAAE,MAAM,CAAC;QAC5C,GAAG,EAAE,SAAG,CAAC,MAAM,CAAC,OAAO,EAAE,MAAM,CAAC;QAChC,CAAC,EAAE,4BAAkB;KACtB,CAAC;AACJ,CAAC,CAAC;AAjDW,QAAA,iBAAiB,qBAiD5B"}
@@ -0,0 +1,9 @@
1
+ import { IKryptos, KryptosEncryption } from "@lindorm/kryptos";
2
+ import { AesContent } from "../../types";
3
+ export type EncryptTokenisedOptions = {
4
+ data: AesContent;
5
+ encryption: KryptosEncryption;
6
+ kryptos: IKryptos;
7
+ };
8
+ export declare const encryptTokenised: (options: EncryptTokenisedOptions) => string;
9
+ //# sourceMappingURL=encrypt-tokenised.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"encrypt-tokenised.d.ts","sourceRoot":"","sources":["../../../src/utils/private/encrypt-tokenised.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,QAAQ,EAAE,iBAAiB,EAAE,MAAM,kBAAkB,CAAC;AAC/D,OAAO,EAAE,UAAU,EAAE,MAAM,aAAa,CAAC;AAOzC,MAAM,MAAM,uBAAuB,GAAG;IACpC,IAAI,EAAE,UAAU,CAAC;IACjB,UAAU,EAAE,iBAAiB,CAAC;IAC9B,OAAO,EAAE,QAAQ,CAAC;CACnB,CAAC;AAEF,eAAO,MAAM,gBAAgB,GAAI,SAAS,uBAAuB,KAAG,MA+CnE,CAAC"}
@@ -0,0 +1,45 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.encryptTokenised = void 0;
4
+ const b64_1 = require("@lindorm/b64");
5
+ const aes_header_1 = require("./aes-header");
6
+ const content_1 = require("./content");
7
+ const data_1 = require("./data");
8
+ const encrypt_content_1 = require("./encrypt-content");
9
+ const get_key_1 = require("./get-key");
10
+ const encryptTokenised = (options) => {
11
+ const { data, encryption, kryptos } = options;
12
+ const keyResult = (0, get_key_1.getEncryptionKey)({ encryption, kryptos });
13
+ const initialisationVector = (0, data_1.getInitialisationVector)(encryption);
14
+ const contentType = (0, content_1.calculateContentType)(data);
15
+ const header = (0, aes_header_1.buildAesHeader)({
16
+ algorithm: kryptos.algorithm,
17
+ contentType,
18
+ encryption,
19
+ keyId: kryptos.id,
20
+ pbkdfIterations: keyResult.pbkdfIterations,
21
+ pbkdfSalt: keyResult.pbkdfSalt,
22
+ publicEncryptionIv: keyResult.publicEncryptionIv,
23
+ publicEncryptionJwk: keyResult.publicEncryptionJwk,
24
+ publicEncryptionTag: keyResult.publicEncryptionTag,
25
+ });
26
+ const headerB64 = (0, aes_header_1.encodeAesHeader)(header);
27
+ const aad = (0, aes_header_1.computeAad)(headerB64);
28
+ const { authTag, content } = (0, encrypt_content_1.encryptAesContent)({
29
+ aad,
30
+ contentEncryptionKey: keyResult.contentEncryptionKey,
31
+ data,
32
+ encryption,
33
+ initialisationVector,
34
+ });
35
+ const ivB64 = b64_1.B64.encode(initialisationVector, "b64u");
36
+ const tagB64 = b64_1.B64.encode(authTag, "b64u");
37
+ const ciphertextB64 = b64_1.B64.encode(content, "b64u");
38
+ if (keyResult.publicEncryptionKey) {
39
+ const cekB64 = b64_1.B64.encode(keyResult.publicEncryptionKey, "b64u");
40
+ return `aes:${headerB64}$${cekB64}$${ivB64}$${tagB64}$${ciphertextB64}`;
41
+ }
42
+ return `aes:${headerB64}$${ivB64}$${tagB64}$${ciphertextB64}`;
43
+ };
44
+ exports.encryptTokenised = encryptTokenised;
45
+ //# sourceMappingURL=encrypt-tokenised.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"encrypt-tokenised.js","sourceRoot":"","sources":["../../../src/utils/private/encrypt-tokenised.ts"],"names":[],"mappings":";;;AAAA,sCAAmC;AAGnC,6CAA2E;AAC3E,uCAAiD;AACjD,iCAAiD;AACjD,uDAAsD;AACtD,uCAA6C;AAQtC,MAAM,gBAAgB,GAAG,CAAC,OAAgC,EAAU,EAAE;IAC3E,MAAM,EAAE,IAAI,EAAE,UAAU,EAAE,OAAO,EAAE,GAAG,OAAO,CAAC;IAG9C,MAAM,SAAS,GAAG,IAAA,0BAAgB,EAAC,EAAE,UAAU,EAAE,OAAO,EAAE,CAAC,CAAC;IAG5D,MAAM,oBAAoB,GAAG,IAAA,8BAAuB,EAAC,UAAU,CAAC,CAAC;IAGjE,MAAM,WAAW,GAAG,IAAA,8BAAoB,EAAC,IAAI,CAAC,CAAC;IAC/C,MAAM,MAAM,GAAG,IAAA,2BAAc,EAAC;QAC5B,SAAS,EAAE,OAAO,CAAC,SAAS;QAC5B,WAAW;QACX,UAAU;QACV,KAAK,EAAE,OAAO,CAAC,EAAE;QACjB,eAAe,EAAE,SAAS,CAAC,eAAe;QAC1C,SAAS,EAAE,SAAS,CAAC,SAAS;QAC9B,kBAAkB,EAAE,SAAS,CAAC,kBAAkB;QAChD,mBAAmB,EAAE,SAAS,CAAC,mBAAmB;QAClD,mBAAmB,EAAE,SAAS,CAAC,mBAAmB;KACnD,CAAC,CAAC;IACH,MAAM,SAAS,GAAG,IAAA,4BAAe,EAAC,MAAM,CAAC,CAAC;IAG1C,MAAM,GAAG,GAAG,IAAA,uBAAU,EAAC,SAAS,CAAC,CAAC;IAGlC,MAAM,EAAE,OAAO,EAAE,OAAO,EAAE,GAAG,IAAA,mCAAiB,EAAC;QAC7C,GAAG;QACH,oBAAoB,EAAE,SAAS,CAAC,oBAAoB;QACpD,IAAI;QACJ,UAAU;QACV,oBAAoB;KACrB,CAAC,CAAC;IAGH,MAAM,KAAK,GAAG,SAAG,CAAC,MAAM,CAAC,oBAAoB,EAAE,MAAM,CAAC,CAAC;IACvD,MAAM,MAAM,GAAG,SAAG,CAAC,MAAM,CAAC,OAAO,EAAE,MAAM,CAAC,CAAC;IAC3C,MAAM,aAAa,GAAG,SAAG,CAAC,MAAM,CAAC,OAAO,EAAE,MAAM,CAAC,CAAC;IAElD,IAAI,SAAS,CAAC,mBAAmB,EAAE,CAAC;QAClC,MAAM,MAAM,GAAG,SAAG,CAAC,MAAM,CAAC,SAAS,CAAC,mBAAmB,EAAE,MAAM,CAAC,CAAC;QACjE,OAAO,OAAO,SAAS,IAAI,MAAM,IAAI,KAAK,IAAI,MAAM,IAAI,aAAa,EAAE,CAAC;IAC1E,CAAC;IAED,OAAO,OAAO,SAAS,IAAI,KAAK,IAAI,MAAM,IAAI,aAAa,EAAE,CAAC;AAChE,CAAC,CAAC;AA/CW,QAAA,gBAAgB,oBA+C3B"}
@@ -1 +1 @@
1
- {"version":3,"file":"encryption.d.ts","sourceRoot":"","sources":["../../../src/utils/private/encryption.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,UAAU,EAAE,mBAAmB,EAAE,MAAM,aAAa,CAAC;AAC9D,OAAO,EACL,2BAA2B,EAC3B,2BAA2B,EAC5B,MAAM,qBAAqB,CAAC;AAW7B,eAAO,MAAM,UAAU,GAAI,SAAS,2BAA2B,KAAG,mBAuDjE,CAAC;AAEF,eAAO,MAAM,UAAU,GAAI,CAAC,SAAS,UAAU,GAAG,MAAM,EACtD,SAAS,2BAA2B,KACnC,CAiDF,CAAC"}
1
+ {"version":3,"file":"encryption.d.ts","sourceRoot":"","sources":["../../../src/utils/private/encryption.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,UAAU,EAAE,mBAAmB,EAAE,MAAM,aAAa,CAAC;AAC9D,OAAO,EACL,2BAA2B,EAC3B,2BAA2B,EAC5B,MAAM,qBAAqB,CAAC;AAO7B,eAAO,MAAM,UAAU,GAAI,SAAS,2BAA2B,KAAG,mBA4BjE,CAAC;AAEF,eAAO,MAAM,UAAU,GAAI,CAAC,SAAS,UAAU,GAAG,MAAM,EACtD,SAAS,2BAA2B,KACnC,CAkEF,CAAC"}