@lindorm/aegis 0.2.6 → 0.3.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 (314) hide show
  1. package/CHANGELOG.md +31 -0
  2. package/dist/classes/Aegis.d.ts +29 -3
  3. package/dist/classes/Aegis.d.ts.map +1 -1
  4. package/dist/classes/Aegis.js +257 -45
  5. package/dist/classes/Aegis.js.map +1 -1
  6. package/dist/classes/CweKit.d.ts +14 -0
  7. package/dist/classes/CweKit.d.ts.map +1 -0
  8. package/dist/classes/CweKit.js +155 -0
  9. package/dist/classes/CweKit.js.map +1 -0
  10. package/dist/classes/CwsKit.d.ts +13 -0
  11. package/dist/classes/CwsKit.d.ts.map +1 -0
  12. package/dist/classes/CwsKit.js +131 -0
  13. package/dist/classes/CwsKit.js.map +1 -0
  14. package/dist/classes/CwtKit.d.ts +17 -0
  15. package/dist/classes/CwtKit.d.ts.map +1 -0
  16. package/dist/classes/CwtKit.js +162 -0
  17. package/dist/classes/CwtKit.js.map +1 -0
  18. package/dist/classes/JweKit.d.ts +5 -4
  19. package/dist/classes/JweKit.d.ts.map +1 -1
  20. package/dist/classes/JweKit.js +62 -53
  21. package/dist/classes/JweKit.js.map +1 -1
  22. package/dist/classes/JwsKit.d.ts +5 -2
  23. package/dist/classes/JwsKit.d.ts.map +1 -1
  24. package/dist/classes/JwsKit.js +43 -47
  25. package/dist/classes/JwsKit.js.map +1 -1
  26. package/dist/classes/JwtKit.d.ts +5 -2
  27. package/dist/classes/JwtKit.d.ts.map +1 -1
  28. package/dist/classes/JwtKit.js +48 -58
  29. package/dist/classes/JwtKit.js.map +1 -1
  30. package/dist/classes/SignatureKit.d.ts +12 -0
  31. package/dist/classes/SignatureKit.d.ts.map +1 -0
  32. package/dist/classes/SignatureKit.js +41 -0
  33. package/dist/classes/SignatureKit.js.map +1 -0
  34. package/dist/classes/index.d.ts +4 -0
  35. package/dist/classes/index.d.ts.map +1 -1
  36. package/dist/classes/index.js +4 -0
  37. package/dist/classes/index.js.map +1 -1
  38. package/dist/constants/private/cose.d.ts +20 -0
  39. package/dist/constants/private/cose.d.ts.map +1 -0
  40. package/dist/constants/private/cose.js +134 -0
  41. package/dist/constants/private/cose.js.map +1 -0
  42. package/dist/constants/private/format.d.ts.map +1 -1
  43. package/dist/constants/private/header.d.ts +3 -0
  44. package/dist/constants/private/header.d.ts.map +1 -0
  45. package/dist/constants/private/header.js +25 -0
  46. package/dist/constants/private/header.js.map +1 -0
  47. package/dist/constants/private/index.d.ts +2 -0
  48. package/dist/constants/private/index.d.ts.map +1 -1
  49. package/dist/constants/private/index.js +2 -0
  50. package/dist/constants/private/index.js.map +1 -1
  51. package/dist/errors/CoseEncryptError.d.ts +4 -0
  52. package/dist/errors/CoseEncryptError.d.ts.map +1 -0
  53. package/dist/errors/CoseEncryptError.js +8 -0
  54. package/dist/errors/CoseEncryptError.js.map +1 -0
  55. package/dist/errors/CoseSignError.d.ts +4 -0
  56. package/dist/errors/CoseSignError.d.ts.map +1 -0
  57. package/dist/errors/CoseSignError.js +8 -0
  58. package/dist/errors/CoseSignError.js.map +1 -0
  59. package/dist/errors/CwtError.d.ts +4 -0
  60. package/dist/errors/CwtError.d.ts.map +1 -0
  61. package/dist/errors/CwtError.js +8 -0
  62. package/dist/errors/CwtError.js.map +1 -0
  63. package/dist/errors/index.d.ts +3 -0
  64. package/dist/errors/index.d.ts.map +1 -1
  65. package/dist/errors/index.js +3 -0
  66. package/dist/errors/index.js.map +1 -1
  67. package/dist/index.d.ts +1 -0
  68. package/dist/index.d.ts.map +1 -1
  69. package/dist/index.js +1 -0
  70. package/dist/index.js.map +1 -1
  71. package/dist/interfaces/Aegis.d.ts +47 -0
  72. package/dist/interfaces/Aegis.d.ts.map +1 -0
  73. package/dist/{types/interfaces/aegis.js → interfaces/Aegis.js} +1 -1
  74. package/dist/interfaces/Aegis.js.map +1 -0
  75. package/dist/interfaces/CweKit.d.ts +6 -0
  76. package/dist/interfaces/CweKit.d.ts.map +1 -0
  77. package/dist/{types/interfaces/jwe-kit.js → interfaces/CweKit.js} +1 -1
  78. package/dist/interfaces/CweKit.js.map +1 -0
  79. package/dist/interfaces/CwsKit.d.ts +6 -0
  80. package/dist/interfaces/CwsKit.d.ts.map +1 -0
  81. package/dist/{types/interfaces/jws-kit.js → interfaces/CwsKit.js} +1 -1
  82. package/dist/interfaces/CwsKit.js.map +1 -0
  83. package/dist/interfaces/CwtKit.d.ts +7 -0
  84. package/dist/interfaces/CwtKit.d.ts.map +1 -0
  85. package/dist/{types/interfaces/jwt-kit.js → interfaces/CwtKit.js} +1 -1
  86. package/dist/interfaces/CwtKit.js.map +1 -0
  87. package/dist/interfaces/JweKit.d.ts +6 -0
  88. package/dist/interfaces/JweKit.d.ts.map +1 -0
  89. package/dist/interfaces/JweKit.js +3 -0
  90. package/dist/interfaces/JweKit.js.map +1 -0
  91. package/dist/interfaces/JwsKit.d.ts +6 -0
  92. package/dist/interfaces/JwsKit.d.ts.map +1 -0
  93. package/dist/interfaces/JwsKit.js +3 -0
  94. package/dist/interfaces/JwsKit.js.map +1 -0
  95. package/dist/interfaces/JwtKit.d.ts +7 -0
  96. package/dist/interfaces/JwtKit.d.ts.map +1 -0
  97. package/dist/interfaces/JwtKit.js +3 -0
  98. package/dist/interfaces/JwtKit.js.map +1 -0
  99. package/dist/interfaces/index.d.ts +8 -0
  100. package/dist/interfaces/index.d.ts.map +1 -0
  101. package/dist/interfaces/index.js +24 -0
  102. package/dist/interfaces/index.js.map +1 -0
  103. package/dist/mocks/create-mock-aegis.d.ts +1 -1
  104. package/dist/mocks/create-mock-aegis.d.ts.map +1 -1
  105. package/dist/mocks/create-mock-aegis.js +46 -2
  106. package/dist/mocks/create-mock-aegis.js.map +1 -1
  107. package/dist/types/aegis.d.ts +0 -1
  108. package/dist/types/aegis.d.ts.map +1 -1
  109. package/dist/types/cwe/cwe-decode.d.ts +14 -0
  110. package/dist/types/cwe/cwe-decode.d.ts.map +1 -0
  111. package/dist/types/cwe/cwe-decode.js +3 -0
  112. package/dist/types/cwe/cwe-decode.js.map +1 -0
  113. package/dist/types/cwe/cwe-decrypt.d.ts +15 -0
  114. package/dist/types/cwe/cwe-decrypt.d.ts.map +1 -0
  115. package/dist/types/cwe/cwe-decrypt.js +3 -0
  116. package/dist/types/cwe/cwe-decrypt.js.map +1 -0
  117. package/dist/types/cwe/cwe-encrypt.d.ts +10 -0
  118. package/dist/types/cwe/cwe-encrypt.d.ts.map +1 -0
  119. package/dist/types/cwe/cwe-encrypt.js +3 -0
  120. package/dist/types/cwe/cwe-encrypt.js.map +1 -0
  121. package/dist/types/cwe/cwe-kit.d.ts +9 -0
  122. package/dist/types/cwe/cwe-kit.d.ts.map +1 -0
  123. package/dist/types/cwe/cwe-kit.js +3 -0
  124. package/dist/types/cwe/cwe-kit.js.map +1 -0
  125. package/dist/types/cwe/index.d.ts +5 -0
  126. package/dist/types/cwe/index.d.ts.map +1 -0
  127. package/dist/types/cwe/index.js +21 -0
  128. package/dist/types/cwe/index.js.map +1 -0
  129. package/dist/types/cws/cws-decode.d.ts +9 -0
  130. package/dist/types/cws/cws-decode.d.ts.map +1 -0
  131. package/dist/types/cws/cws-decode.js +3 -0
  132. package/dist/types/cws/cws-decode.js.map +1 -0
  133. package/dist/types/cws/cws-kit.d.ts +8 -0
  134. package/dist/types/cws/cws-kit.d.ts.map +1 -0
  135. package/dist/types/cws/cws-kit.js +3 -0
  136. package/dist/types/cws/cws-kit.js.map +1 -0
  137. package/dist/types/cws/cws-parse.d.ts +14 -0
  138. package/dist/types/cws/cws-parse.d.ts.map +1 -0
  139. package/dist/types/cws/cws-parse.js +3 -0
  140. package/dist/types/cws/cws-parse.js.map +1 -0
  141. package/dist/types/cws/cws-sign.d.ts +12 -0
  142. package/dist/types/cws/cws-sign.d.ts.map +1 -0
  143. package/dist/types/cws/cws-sign.js +3 -0
  144. package/dist/types/cws/cws-sign.js.map +1 -0
  145. package/dist/types/cws/index.d.ts +5 -0
  146. package/dist/types/cws/index.d.ts.map +1 -0
  147. package/dist/types/cws/index.js +21 -0
  148. package/dist/types/cws/index.js.map +1 -0
  149. package/dist/types/cwt/cwt-claims.d.ts +3 -0
  150. package/dist/types/cwt/cwt-claims.d.ts.map +1 -0
  151. package/dist/types/cwt/cwt-claims.js +3 -0
  152. package/dist/types/cwt/cwt-claims.js.map +1 -0
  153. package/dist/types/cwt/cwt-decode.d.ts +10 -0
  154. package/dist/types/cwt/cwt-decode.d.ts.map +1 -0
  155. package/dist/types/cwt/cwt-decode.js +3 -0
  156. package/dist/types/cwt/cwt-decode.js.map +1 -0
  157. package/dist/types/cwt/cwt-kit.d.ts +3 -0
  158. package/dist/types/cwt/cwt-kit.d.ts.map +1 -0
  159. package/dist/types/cwt/cwt-kit.js +3 -0
  160. package/dist/types/cwt/cwt-kit.js.map +1 -0
  161. package/dist/types/cwt/cwt-parse.d.ts +15 -0
  162. package/dist/types/cwt/cwt-parse.d.ts.map +1 -0
  163. package/dist/types/cwt/cwt-parse.js +3 -0
  164. package/dist/types/cwt/cwt-parse.js.map +1 -0
  165. package/dist/types/cwt/cwt-sign.d.ts +14 -0
  166. package/dist/types/cwt/cwt-sign.d.ts.map +1 -0
  167. package/dist/types/cwt/cwt-sign.js +3 -0
  168. package/dist/types/cwt/cwt-sign.js.map +1 -0
  169. package/dist/types/cwt/cwt-validate.d.ts +3 -0
  170. package/dist/types/cwt/cwt-validate.d.ts.map +1 -0
  171. package/dist/types/cwt/cwt-validate.js +3 -0
  172. package/dist/types/cwt/cwt-validate.js.map +1 -0
  173. package/dist/types/cwt/cwt-verify.d.ts +3 -0
  174. package/dist/types/cwt/cwt-verify.d.ts.map +1 -0
  175. package/dist/types/cwt/cwt-verify.js +3 -0
  176. package/dist/types/cwt/cwt-verify.js.map +1 -0
  177. package/dist/types/cwt/index.d.ts +8 -0
  178. package/dist/types/cwt/index.d.ts.map +1 -0
  179. package/dist/types/cwt/index.js +24 -0
  180. package/dist/types/cwt/index.js.map +1 -0
  181. package/dist/types/header.d.ts +34 -11
  182. package/dist/types/header.d.ts.map +1 -1
  183. package/dist/types/index.d.ts +4 -1
  184. package/dist/types/index.d.ts.map +1 -1
  185. package/dist/types/index.js +4 -1
  186. package/dist/types/index.js.map +1 -1
  187. package/dist/types/jwe/jwe-decode.d.ts +1 -1
  188. package/dist/types/jwe/jwe-decode.d.ts.map +1 -1
  189. package/dist/types/jwe/jwe-decrypt.d.ts +2 -2
  190. package/dist/types/jwe/jwe-decrypt.d.ts.map +1 -1
  191. package/dist/types/jwe/jwe-encrypt.d.ts +2 -0
  192. package/dist/types/jwe/jwe-encrypt.d.ts.map +1 -1
  193. package/dist/types/jwe/jwe-kit.d.ts +0 -1
  194. package/dist/types/jwe/jwe-kit.d.ts.map +1 -1
  195. package/dist/types/jws/index.d.ts +1 -1
  196. package/dist/types/jws/index.d.ts.map +1 -1
  197. package/dist/types/jws/index.js +1 -1
  198. package/dist/types/jws/index.js.map +1 -1
  199. package/dist/types/jws/{jws-verify.d.ts → jws-parse.d.ts} +5 -5
  200. package/dist/types/jws/jws-parse.d.ts.map +1 -0
  201. package/dist/types/jws/jws-parse.js +3 -0
  202. package/dist/types/jws/jws-parse.js.map +1 -0
  203. package/dist/types/jws/jws-sign.d.ts +2 -0
  204. package/dist/types/jws/jws-sign.d.ts.map +1 -1
  205. package/dist/types/jwt/jwt-claims.d.ts +1 -1
  206. package/dist/types/jwt/jwt-claims.d.ts.map +1 -1
  207. package/dist/types/jwt/jwt-parse.d.ts +13 -0
  208. package/dist/types/jwt/jwt-parse.d.ts.map +1 -1
  209. package/dist/types/jwt/jwt-sign.d.ts +2 -0
  210. package/dist/types/jwt/jwt-sign.d.ts.map +1 -1
  211. package/dist/types/jwt/jwt-verify.d.ts +0 -15
  212. package/dist/types/jwt/jwt-verify.d.ts.map +1 -1
  213. package/dist/types/signature-kit.d.ts +9 -0
  214. package/dist/types/signature-kit.d.ts.map +1 -0
  215. package/dist/types/signature-kit.js +3 -0
  216. package/dist/types/signature-kit.js.map +1 -0
  217. package/dist/utils/private/auth-tag-length.d.ts +3 -0
  218. package/dist/utils/private/auth-tag-length.d.ts.map +1 -0
  219. package/dist/utils/private/auth-tag-length.js +21 -0
  220. package/dist/utils/private/auth-tag-length.js.map +1 -0
  221. package/dist/utils/private/cose/bstr.d.ts +4 -0
  222. package/dist/utils/private/cose/bstr.d.ts.map +1 -0
  223. package/dist/utils/private/cose/bstr.js +18 -0
  224. package/dist/utils/private/cose/bstr.js.map +1 -0
  225. package/dist/utils/private/cose/claims.d.ts +5 -0
  226. package/dist/utils/private/cose/claims.d.ts.map +1 -0
  227. package/dist/utils/private/cose/claims.js +35 -0
  228. package/dist/utils/private/cose/claims.js.map +1 -0
  229. package/dist/utils/private/cose/crit.d.ts +3 -0
  230. package/dist/utils/private/cose/crit.d.ts.map +1 -0
  231. package/dist/utils/private/cose/crit.js +43 -0
  232. package/dist/utils/private/cose/crit.js.map +1 -0
  233. package/dist/utils/private/cose/find.d.ts +5 -0
  234. package/dist/utils/private/cose/find.d.ts.map +1 -0
  235. package/dist/utils/private/cose/find.js +37 -0
  236. package/dist/utils/private/cose/find.js.map +1 -0
  237. package/dist/utils/private/cose/header.d.ts +5 -0
  238. package/dist/utils/private/cose/header.d.ts.map +1 -0
  239. package/dist/utils/private/cose/header.js +88 -0
  240. package/dist/utils/private/cose/header.js.map +1 -0
  241. package/dist/utils/private/cose/index.d.ts +3 -0
  242. package/dist/utils/private/cose/index.d.ts.map +1 -0
  243. package/dist/{types/interfaces → utils/private/cose}/index.js +2 -4
  244. package/dist/utils/private/cose/index.js.map +1 -0
  245. package/dist/utils/private/cose/key.d.ts +4 -0
  246. package/dist/utils/private/cose/key.d.ts.map +1 -0
  247. package/dist/utils/private/cose/key.js +82 -0
  248. package/dist/utils/private/cose/key.js.map +1 -0
  249. package/dist/utils/private/cose-sign-token.d.ts +10 -0
  250. package/dist/utils/private/cose-sign-token.d.ts.map +1 -0
  251. package/dist/utils/private/cose-sign-token.js +12 -0
  252. package/dist/utils/private/cose-sign-token.js.map +1 -0
  253. package/dist/utils/private/cose-signature.d.ts +16 -0
  254. package/dist/utils/private/cose-signature.d.ts.map +1 -0
  255. package/dist/utils/private/cose-signature.js +17 -0
  256. package/dist/utils/private/cose-signature.js.map +1 -0
  257. package/dist/utils/private/create-hash.d.ts.map +1 -1
  258. package/dist/utils/private/index.d.ts +6 -3
  259. package/dist/utils/private/index.d.ts.map +1 -1
  260. package/dist/utils/private/index.js +6 -3
  261. package/dist/utils/private/index.js.map +1 -1
  262. package/dist/utils/private/jose-header.d.ts +4 -0
  263. package/dist/utils/private/jose-header.d.ts.map +1 -0
  264. package/dist/utils/private/jose-header.js +51 -0
  265. package/dist/utils/private/jose-header.js.map +1 -0
  266. package/dist/utils/private/jose-signature.d.ts +10 -0
  267. package/dist/utils/private/jose-signature.d.ts.map +1 -0
  268. package/dist/utils/private/jose-signature.js +19 -0
  269. package/dist/utils/private/jose-signature.js.map +1 -0
  270. package/dist/utils/private/jwt-payload.d.ts +3 -2
  271. package/dist/utils/private/jwt-payload.d.ts.map +1 -1
  272. package/dist/utils/private/jwt-payload.js +16 -14
  273. package/dist/utils/private/jwt-payload.js.map +1 -1
  274. package/dist/utils/private/jwt-validate.d.ts.map +1 -1
  275. package/dist/utils/private/jwt-verify.d.ts.map +1 -1
  276. package/dist/utils/private/jwt-verify.js +1 -1
  277. package/dist/utils/private/jwt-verify.js.map +1 -1
  278. package/dist/utils/private/token-header.d.ts +2 -3
  279. package/dist/utils/private/token-header.d.ts.map +1 -1
  280. package/dist/utils/private/token-header.js +32 -104
  281. package/dist/utils/private/token-header.js.map +1 -1
  282. package/dist/utils/private/validate-value.d.ts.map +1 -1
  283. package/dist/utils/private/validate.d.ts.map +1 -1
  284. package/package.json +20 -18
  285. package/dist/types/interfaces/aegis.d.ts +0 -22
  286. package/dist/types/interfaces/aegis.d.ts.map +0 -1
  287. package/dist/types/interfaces/aegis.js.map +0 -1
  288. package/dist/types/interfaces/index.d.ts +0 -5
  289. package/dist/types/interfaces/index.d.ts.map +0 -1
  290. package/dist/types/interfaces/index.js.map +0 -1
  291. package/dist/types/interfaces/jwe-kit.d.ts +0 -7
  292. package/dist/types/interfaces/jwe-kit.d.ts.map +0 -1
  293. package/dist/types/interfaces/jwe-kit.js.map +0 -1
  294. package/dist/types/interfaces/jws-kit.d.ts +0 -6
  295. package/dist/types/interfaces/jws-kit.d.ts.map +0 -1
  296. package/dist/types/interfaces/jws-kit.js.map +0 -1
  297. package/dist/types/interfaces/jwt-kit.d.ts +0 -8
  298. package/dist/types/interfaces/jwt-kit.d.ts.map +0 -1
  299. package/dist/types/interfaces/jwt-kit.js.map +0 -1
  300. package/dist/types/jws/jws-verify.d.ts.map +0 -1
  301. package/dist/types/jws/jws-verify.js +0 -3
  302. package/dist/types/jws/jws-verify.js.map +0 -1
  303. package/dist/utils/private/create-token-signature.d.ts +0 -9
  304. package/dist/utils/private/create-token-signature.d.ts.map +0 -1
  305. package/dist/utils/private/create-token-signature.js +0 -42
  306. package/dist/utils/private/create-token-signature.js.map +0 -1
  307. package/dist/utils/private/token-type.d.ts +0 -3
  308. package/dist/utils/private/token-type.d.ts.map +0 -1
  309. package/dist/utils/private/token-type.js +0 -11
  310. package/dist/utils/private/token-type.js.map +0 -1
  311. package/dist/utils/private/verify-token-signature.d.ts +0 -3
  312. package/dist/utils/private/verify-token-signature.d.ts.map +0 -1
  313. package/dist/utils/private/verify-token-signature.js +0 -43
  314. package/dist/utils/private/verify-token-signature.js.map +0 -1
package/CHANGELOG.md CHANGED
@@ -3,6 +3,37 @@
3
3
  All notable changes to this project will be documented in this file.
4
4
  See [Conventional Commits](https://conventionalcommits.org) for commit guidelines.
5
5
 
6
+ ## [0.3.1](https://github.com/lindorm-io/monorepo/compare/@lindorm/aegis@0.3.0...@lindorm/aegis@0.3.1) (2025-06-24)
7
+
8
+ **Note:** Version bump only for package @lindorm/aegis
9
+
10
+ # [0.3.0](https://github.com/lindorm-io/monorepo/compare/@lindorm/aegis@0.2.6...@lindorm/aegis@0.3.0) (2025-06-17)
11
+
12
+ ### Bug Fixes
13
+
14
+ - add missing header options to sign and encrypt ([d0007e7](https://github.com/lindorm-io/monorepo/commit/d0007e70c0afcf5945b223b27e7b8c02c07b3109))
15
+ - add missing jwt options for verify ([c5b9439](https://github.com/lindorm-io/monorepo/commit/c5b9439b41a7de541e966c350102b7cffde389b5))
16
+ - add optional key filter for aegis ([49a6d75](https://github.com/lindorm-io/monorepo/commit/49a6d75a89f435c40389fbee00840c011e369b00))
17
+ - align with kryptos changes ([206eb38](https://github.com/lindorm-io/monorepo/commit/206eb38ae2a03b14973e706035c87a953cc753af))
18
+ - amend bugs ([a68a77a](https://github.com/lindorm-io/monorepo/commit/a68a77a811ddfe33a0b487cd84cda6a18d3054b6))
19
+ - amend errors in mock ([4e80b28](https://github.com/lindorm-io/monorepo/commit/4e80b28e2bd35ae7ae43da9d3b480bae935aef08))
20
+ - handle correct typing ([630fa33](https://github.com/lindorm-io/monorepo/commit/630fa332c16557fa5f16c3cc673af563d5ea4e24))
21
+ - improve content type method ([d12f1fd](https://github.com/lindorm-io/monorepo/commit/d12f1fd4484c5e6b1becbdd72feed010d2c5cd98))
22
+ - merge domain with issuer for ease of understanding ([9123cc2](https://github.com/lindorm-io/monorepo/commit/9123cc2ede63962a5c226a9bed0d0541001384d9))
23
+ - minor improvements ([0f7db68](https://github.com/lindorm-io/monorepo/commit/0f7db68cddefce258434258ea9f6c0d5f5ba4fc4))
24
+ - rename kits ([da103bf](https://github.com/lindorm-io/monorepo/commit/da103bf21fc25f3477dd9b70a851e4bca5758283))
25
+ - update types and fallback to amphora issuer ([8130b45](https://github.com/lindorm-io/monorepo/commit/8130b45bc7a1c2080e029e6e2efc8c58a65f1d7e))
26
+
27
+ ### Features
28
+
29
+ - add aegis aes and improve key methods ([ac1800e](https://github.com/lindorm-io/monorepo/commit/ac1800e65f1e9fc82814bb84793678f8c3fd1f8d))
30
+ - add decode and verify to aegis ([bd6c9c3](https://github.com/lindorm-io/monorepo/commit/bd6c9c3b041eb0ed398d01f8d52b44e74cbad429))
31
+ - add signature kit ([ca99771](https://github.com/lindorm-io/monorepo/commit/ca99771955b69a41a1add2cbad6a9512783f54ab))
32
+ - add static token parsing to aegis ([2b8803c](https://github.com/lindorm-io/monorepo/commit/2b8803c189ce2bc97fe49c977e6fbb58cace13f7))
33
+ - implement cose-encrypt kit ([5f94faf](https://github.com/lindorm-io/monorepo/commit/5f94fafc28ab737b02cb3e7566da0d5c827d8c1a))
34
+ - implement cose-sign kit ([fd92fa3](https://github.com/lindorm-io/monorepo/commit/fd92fa346401de76967f5d3c0cc5fd6531e4b4bd))
35
+ - introduce cwt to aegis ([40a7efa](https://github.com/lindorm-io/monorepo/commit/40a7efa1ce2907c0e4671d20cd9d9fb457a346db))
36
+
6
37
  ## [0.2.6](https://github.com/lindorm-io/monorepo/compare/@lindorm/aegis@0.2.5...@lindorm/aegis@0.2.6) (2025-01-28)
7
38
 
8
39
  **Note:** Version bump only for package @lindorm/aegis
@@ -1,17 +1,43 @@
1
- import { AegisOptions, IAegis, IAegisJwe, IAegisJws, IAegisJwt } from "../types";
1
+ import { IAegis, IAegisAes, IAegisCwe, IAegisCws, IAegisCwt, IAegisJwe, IAegisJws, IAegisJwt } from "../interfaces";
2
+ import { AegisOptions, DecodedCwe, DecodedCws, DecodedCwt, DecodedJwe, DecodedJws, DecodedJwt, ParsedCws, ParsedCwt, ParsedJws, ParsedJwt, TokenHeaderClaims, VerifyJwtOptions } from "../types";
2
3
  export declare class Aegis implements IAegis {
4
+ readonly issuer: string | null;
3
5
  private readonly amphora;
4
6
  private readonly clockTolerance;
5
7
  private readonly encAlgorithm;
6
8
  private readonly encryption;
7
- private readonly issuer;
8
- private readonly kryptosMayOverrideEncryption;
9
9
  private readonly logger;
10
10
  private readonly sigAlgorithm;
11
11
  constructor(options: AegisOptions);
12
+ get aes(): IAegisAes;
13
+ get cwe(): IAegisCwe;
14
+ get cws(): IAegisCws;
15
+ get cwt(): IAegisCwt;
12
16
  get jwe(): IAegisJwe;
13
17
  get jws(): IAegisJws;
14
18
  get jwt(): IAegisJwt;
19
+ verify<T extends ParsedJwt | ParsedJws<any> | ParsedCwt | ParsedCws<any>>(token: string, options?: VerifyJwtOptions): Promise<T>;
20
+ static header(token: string): TokenHeaderClaims;
21
+ static isJwe(jwe: string): boolean;
22
+ static isJws(jws: string): boolean;
23
+ static isJwt(jwt: string): boolean;
24
+ static isCwe(cose: string): boolean;
25
+ static isCws(cose: string): boolean;
26
+ static isCwt(cwt: string): boolean;
27
+ static decode<T extends DecodedJwe | DecodedJws | DecodedJwt | DecodedCwt | DecodedCwe | DecodedCws<any>>(token: string): T;
28
+ static parse<T extends ParsedJwt | ParsedJws<any> | ParsedCwt | ParsedCws<any>>(token: string): T;
29
+ private aesKit;
30
+ private aesEncrypt;
31
+ private aesDecrypt;
32
+ private coseEncryptKit;
33
+ private coseEncrypt;
34
+ private coseDecrypt;
35
+ private coseSignKit;
36
+ private coseSign;
37
+ private coseVerify;
38
+ private cwtKit;
39
+ private cwtSign;
40
+ private cwtVerify;
15
41
  private jweKit;
16
42
  private jweEncrypt;
17
43
  private jweDecrypt;
@@ -1 +1 @@
1
- {"version":3,"file":"Aegis.d.ts","sourceRoot":"","sources":["../../src/classes/Aegis.ts"],"names":[],"mappings":"AAUA,OAAO,EACL,YAAY,EAGZ,MAAM,EACN,SAAS,EACT,SAAS,EACT,SAAS,EAWV,MAAM,UAAU,CAAC;AAKlB,qBAAa,KAAM,YAAW,MAAM;IAClC,OAAO,CAAC,QAAQ,CAAC,OAAO,CAAW;IACnC,OAAO,CAAC,QAAQ,CAAC,cAAc,CAAS;IACxC,OAAO,CAAC,QAAQ,CAAC,YAAY,CAAkC;IAC/D,OAAO,CAAC,QAAQ,CAAC,UAAU,CAAoB;IAC/C,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAqB;IAC5C,OAAO,CAAC,QAAQ,CAAC,4BAA4B,CAAU;IACvD,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAU;IACjC,OAAO,CAAC,QAAQ,CAAC,YAAY,CAAkC;gBAE5C,OAAO,EAAE,YAAY;IAYxC,IAAW,GAAG,IAAI,SAAS,CAK1B;IAED,IAAW,GAAG,IAAI,SAAS,CAK1B;IAED,IAAW,GAAG,IAAI,SAAS,CAK1B;YAIa,MAAM;YAWN,UAAU;YAQV,UAAU;YAOV,MAAM;YAMN,OAAO;YAQP,SAAS;YAOT,MAAM;YAWN,OAAO;YAQP,SAAS;YAUT,UAAU;YAaV,UAAU;CAazB"}
1
+ {"version":3,"file":"Aegis.d.ts","sourceRoot":"","sources":["../../src/classes/Aegis.ts"],"names":[],"mappings":"AAkBA,OAAO,EACL,MAAM,EACN,SAAS,EACT,SAAS,EACT,SAAS,EACT,SAAS,EACT,SAAS,EACT,SAAS,EACT,SAAS,EACV,MAAM,eAAe,CAAC;AACvB,OAAO,EACL,YAAY,EAIZ,UAAU,EACV,UAAU,EACV,UAAU,EACV,UAAU,EACV,UAAU,EACV,UAAU,EAOV,SAAS,EACT,SAAS,EACT,SAAS,EACT,SAAS,EAYT,iBAAiB,EAEjB,gBAAgB,EACjB,MAAM,UAAU,CAAC;AA2BlB,qBAAa,KAAM,YAAW,MAAM;IAClC,SAAgB,MAAM,EAAE,MAAM,GAAG,IAAI,CAAC;IAEtC,OAAO,CAAC,QAAQ,CAAC,OAAO,CAAW;IACnC,OAAO,CAAC,QAAQ,CAAC,cAAc,CAAS;IACxC,OAAO,CAAC,QAAQ,CAAC,YAAY,CAAkC;IAC/D,OAAO,CAAC,QAAQ,CAAC,UAAU,CAAoB;IAC/C,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAU;IACjC,OAAO,CAAC,QAAQ,CAAC,YAAY,CAAkC;gBAE5C,OAAO,EAAE,YAAY;IAWxC,IAAW,GAAG,IAAI,SAAS,CAK1B;IAED,IAAW,GAAG,IAAI,SAAS,CAK1B;IAED,IAAW,GAAG,IAAI,SAAS,CAK1B;IAED,IAAW,GAAG,IAAI,SAAS,CAK1B;IAED,IAAW,GAAG,IAAI,SAAS,CAK1B;IAED,IAAW,GAAG,IAAI,SAAS,CAK1B;IAED,IAAW,GAAG,IAAI,SAAS,CAK1B;IAEY,MAAM,CAAC,CAAC,SAAS,SAAS,GAAG,SAAS,CAAC,GAAG,CAAC,GAAG,SAAS,GAAG,SAAS,CAAC,GAAG,CAAC,EACnF,KAAK,EAAE,MAAM,EACb,OAAO,CAAC,EAAE,gBAAgB,GACzB,OAAO,CAAC,CAAC,CAAC;WA0BC,MAAM,CAAC,KAAK,EAAE,MAAM,GAAG,iBAAiB;WAKxC,KAAK,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO;WAI3B,KAAK,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO;WAI3B,KAAK,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO;WAI3B,KAAK,CAAC,IAAI,EAAE,MAAM,GAAG,OAAO;WAI5B,KAAK,CAAC,IAAI,EAAE,MAAM,GAAG,OAAO;WAI5B,KAAK,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO;WAI3B,MAAM,CAClB,CAAC,SACG,UAAU,GACV,UAAU,GACV,UAAU,GACV,UAAU,GACV,UAAU,GACV,UAAU,CAAC,GAAG,CAAC,EACnB,KAAK,EAAE,MAAM,GAAG,CAAC;WAsBL,KAAK,CAAC,CAAC,SAAS,SAAS,GAAG,SAAS,CAAC,GAAG,CAAC,GAAG,SAAS,GAAG,SAAS,CAAC,GAAG,CAAC,EACnF,KAAK,EAAE,MAAM,GACZ,CAAC;YAkBU,MAAM;YAMN,UAAU;YASV,UAAU;YAYV,cAAc;YAUd,WAAW;YASX,WAAW;YAaX,WAAW;YASX,QAAQ;YASR,UAAU;YAeV,MAAM;YAWN,OAAO;YASP,SAAS;YAgBT,MAAM;YAUN,UAAU;YASV,UAAU;YAaV,MAAM;YAMN,OAAO;YASP,SAAS;YAaT,MAAM;YAWN,OAAO;YASP,SAAS;YAgBT,UAAU;YA8BV,UAAU;CAqBzB"}
@@ -1,28 +1,56 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.Aegis = void 0;
4
+ const aes_1 = require("@lindorm/aes");
5
+ const errors_1 = require("../errors");
6
+ const private_1 = require("../utils/private");
7
+ const CweKit_1 = require("./CweKit");
8
+ const CwsKit_1 = require("./CwsKit");
9
+ const CwtKit_1 = require("./CwtKit");
4
10
  const JweKit_1 = require("./JweKit");
5
11
  const JwsKit_1 = require("./JwsKit");
6
12
  const JwtKit_1 = require("./JwtKit");
7
13
  class Aegis {
14
+ issuer;
8
15
  amphora;
9
16
  clockTolerance;
10
17
  encAlgorithm;
11
18
  encryption;
12
- issuer;
13
- kryptosMayOverrideEncryption;
14
19
  logger;
15
20
  sigAlgorithm;
16
21
  constructor(options) {
17
22
  this.logger = options.logger.child(["AegisKit"]);
18
23
  this.amphora = options.amphora;
19
- this.issuer = options.issuer;
24
+ this.issuer = options.issuer ?? this.amphora.domain;
20
25
  this.clockTolerance = options.clockTolerance ?? 0;
21
26
  this.encAlgorithm = options.encAlgorithm;
22
27
  this.encryption = options.encryption ?? "A256GCM";
23
- this.kryptosMayOverrideEncryption = options.kryptosMayOverrideEncryption ?? true;
24
28
  this.sigAlgorithm = options.sigAlgorithm;
25
29
  }
30
+ get aes() {
31
+ return {
32
+ encrypt: this.aesEncrypt.bind(this),
33
+ decrypt: this.aesDecrypt.bind(this),
34
+ };
35
+ }
36
+ get cwe() {
37
+ return {
38
+ encrypt: this.coseEncrypt.bind(this),
39
+ decrypt: this.coseDecrypt.bind(this),
40
+ };
41
+ }
42
+ get cws() {
43
+ return {
44
+ sign: this.coseSign.bind(this),
45
+ verify: this.coseVerify.bind(this),
46
+ };
47
+ }
48
+ get cwt() {
49
+ return {
50
+ sign: this.cwtSign.bind(this),
51
+ verify: this.cwtVerify.bind(this),
52
+ };
53
+ }
26
54
  get jwe() {
27
55
  return {
28
56
  encrypt: this.jweEncrypt.bind(this),
@@ -41,71 +69,255 @@ class Aegis {
41
69
  verify: this.jwtVerify.bind(this),
42
70
  };
43
71
  }
44
- async jweKit(operation) {
45
- const kryptos = await this.kryptosEnc(operation);
72
+ async verify(token, options) {
73
+ if (Aegis.isJwt(token)) {
74
+ return (await this.jwtVerify(token, options));
75
+ }
76
+ if (Aegis.isJwe(token)) {
77
+ const decrypt = await this.jweDecrypt(token);
78
+ return (await this.verify(decrypt.payload));
79
+ }
80
+ if (Aegis.isJws(token)) {
81
+ return (await this.jwsVerify(token));
82
+ }
83
+ if (Aegis.isCwt(token)) {
84
+ return (await this.cwtVerify(token, options));
85
+ }
86
+ if (Aegis.isCwe(token)) {
87
+ const decrypt = await this.coseDecrypt(token);
88
+ return (await this.verify(decrypt.payload));
89
+ }
90
+ if (Aegis.isCws(token)) {
91
+ return (await this.coseVerify(token));
92
+ }
93
+ throw new errors_1.AegisError("Invalid token type", { debug: { token } });
94
+ }
95
+ static header(token) {
96
+ const [header] = token.split(".");
97
+ return (0, private_1.decodeJoseHeader)(header);
98
+ }
99
+ static isJwe(jwe) {
100
+ return JweKit_1.JweKit.isJwe(jwe);
101
+ }
102
+ static isJws(jws) {
103
+ return JwsKit_1.JwsKit.isJws(jws);
104
+ }
105
+ static isJwt(jwt) {
106
+ return JwtKit_1.JwtKit.isJwt(jwt);
107
+ }
108
+ static isCwe(cose) {
109
+ return CweKit_1.CweKit.isCwe(cose);
110
+ }
111
+ static isCws(cose) {
112
+ return CwsKit_1.CwsKit.isCws(cose);
113
+ }
114
+ static isCwt(cwt) {
115
+ return CwtKit_1.CwtKit.isCwt(cwt);
116
+ }
117
+ static decode(token) {
118
+ if (Aegis.isJwe(token)) {
119
+ return JweKit_1.JweKit.decode(token);
120
+ }
121
+ if (Aegis.isJws(token)) {
122
+ return JwsKit_1.JwsKit.decode(token);
123
+ }
124
+ if (Aegis.isJwt(token)) {
125
+ return JwtKit_1.JwtKit.decode(token);
126
+ }
127
+ if (Aegis.isCwt(token)) {
128
+ return CwtKit_1.CwtKit.decode(token);
129
+ }
130
+ if (Aegis.isCwe(token)) {
131
+ return CweKit_1.CweKit.decode(token);
132
+ }
133
+ if (Aegis.isCws(token)) {
134
+ return CwsKit_1.CwsKit.decode(token);
135
+ }
136
+ throw new errors_1.AegisError("Invalid token type", { debug: { token } });
137
+ }
138
+ static parse(token) {
139
+ if (Aegis.isJwt(token)) {
140
+ return JwtKit_1.JwtKit.parse(token);
141
+ }
142
+ if (Aegis.isJws(token)) {
143
+ return JwsKit_1.JwsKit.parse(token);
144
+ }
145
+ if (Aegis.isCwt(token)) {
146
+ return CwtKit_1.CwtKit.parse(token);
147
+ }
148
+ if (Aegis.isCws(token)) {
149
+ return CwsKit_1.CwsKit.parse(token);
150
+ }
151
+ throw new errors_1.AegisError("Invalid token type", { debug: { token } });
152
+ }
153
+ async aesKit(options = {}) {
154
+ const kryptos = await this.kryptosEnc(options);
155
+ return new aes_1.AesKit({ encryption: this.encryption, kryptos });
156
+ }
157
+ async aesEncrypt(data, mode = "encoded") {
158
+ const kit = await this.aesKit({ encrypt: true });
159
+ return kit.encrypt(data, mode);
160
+ }
161
+ async aesDecrypt(data) {
162
+ const parsed = aes_1.AesKit.parse(data);
163
+ const kit = await this.aesKit({ id: parsed.keyId, algorithm: parsed.algorithm });
164
+ return kit.decrypt(data);
165
+ }
166
+ async coseEncryptKit(options = {}) {
167
+ const kryptos = await this.kryptosEnc(options);
168
+ return new CweKit_1.CweKit({
169
+ encryption: this.encryption,
170
+ kryptos,
171
+ logger: this.logger,
172
+ });
173
+ }
174
+ async coseEncrypt(data, options = {}) {
175
+ const kit = await this.coseEncryptKit({ encrypt: true });
176
+ return kit.encrypt(data, options);
177
+ }
178
+ async coseDecrypt(token) {
179
+ const decode = CweKit_1.CweKit.decode(token);
180
+ const kit = await this.coseEncryptKit({
181
+ id: decode.recipient.unprotected.kid,
182
+ algorithm: decode.protected.alg,
183
+ });
184
+ return kit.decrypt(token);
185
+ }
186
+ async coseSignKit(options = {}) {
187
+ const kryptos = await this.kryptosSig(options);
188
+ return new CwsKit_1.CwsKit({
189
+ kryptos,
190
+ logger: this.logger,
191
+ });
192
+ }
193
+ async coseSign(content, options = {}) {
194
+ const kit = await this.coseSignKit({ sign: true });
195
+ return kit.sign(content, options);
196
+ }
197
+ async coseVerify(token) {
198
+ const decode = CwsKit_1.CwsKit.decode(token);
199
+ const kit = await this.coseSignKit({
200
+ id: decode.unprotected.kid,
201
+ algorithm: decode.protected.alg,
202
+ });
203
+ return kit.verify(token);
204
+ }
205
+ async cwtKit(options = {}) {
206
+ const kryptos = await this.kryptosSig(options);
207
+ return new CwtKit_1.CwtKit({
208
+ clockTolerance: this.clockTolerance,
209
+ issuer: this.issuer ?? undefined,
210
+ kryptos,
211
+ logger: this.logger,
212
+ });
213
+ }
214
+ async cwtSign(content, options = {}) {
215
+ const kit = await this.cwtKit({ sign: true });
216
+ return kit.sign(content, options);
217
+ }
218
+ async cwtVerify(cwt, verify = {}) {
219
+ const decode = CwtKit_1.CwtKit.decode(cwt);
220
+ const kit = await this.cwtKit({
221
+ id: decode.unprotected.kid,
222
+ algorithm: decode.protected.alg,
223
+ });
224
+ return kit.verify(cwt, verify);
225
+ }
226
+ async jweKit(options = {}) {
227
+ const kryptos = await this.kryptosEnc(options);
46
228
  return new JweKit_1.JweKit({
47
229
  encryption: this.encryption,
48
230
  kryptos,
49
- kryptosMayOverrideEncryption: this.kryptosMayOverrideEncryption,
50
231
  logger: this.logger,
51
232
  });
52
233
  }
53
- async jweEncrypt(data, options) {
54
- const jweKit = await this.jweKit("encrypt");
55
- return jweKit.encrypt(data, options);
234
+ async jweEncrypt(data, options = {}) {
235
+ const kit = await this.jweKit({ encrypt: true });
236
+ return kit.encrypt(data, options);
56
237
  }
57
238
  async jweDecrypt(jwe) {
58
- const jweKit = await this.jweKit("decrypt");
59
- return jweKit.decrypt(jwe);
239
+ const decode = JweKit_1.JweKit.decode(jwe);
240
+ const kit = await this.jweKit({
241
+ id: decode.header.kid,
242
+ algorithm: decode.header.alg,
243
+ });
244
+ return kit.decrypt(jwe);
60
245
  }
61
- async jwsKit(operation) {
62
- const kryptos = await this.kryptosSig(operation);
246
+ async jwsKit(options = {}) {
247
+ const kryptos = await this.kryptosSig(options);
63
248
  return new JwsKit_1.JwsKit({ kryptos, logger: this.logger });
64
249
  }
65
- async jwsSign(data, options) {
66
- const jwsKit = await this.jwsKit("sign");
67
- return jwsKit.sign(data, options);
250
+ async jwsSign(data, options = {}) {
251
+ const kit = await this.jwsKit({ sign: true });
252
+ return kit.sign(data, options);
68
253
  }
69
254
  async jwsVerify(jws) {
70
- const jwsKit = await this.jwsKit("verify");
71
- return jwsKit.verify(jws);
255
+ const decode = JwsKit_1.JwsKit.decode(jws);
256
+ const kit = await this.jwsKit({
257
+ id: decode.header.kid,
258
+ algorithm: decode.header.alg,
259
+ });
260
+ return kit.verify(jws);
72
261
  }
73
- async jwtKit(operation) {
74
- const kryptos = await this.kryptosSig(operation);
262
+ async jwtKit(options = {}) {
263
+ const kryptos = await this.kryptosSig(options);
75
264
  return new JwtKit_1.JwtKit({
76
265
  clockTolerance: this.clockTolerance,
77
- issuer: this.issuer,
266
+ issuer: this.issuer ?? undefined,
78
267
  kryptos,
79
268
  logger: this.logger,
80
269
  });
81
270
  }
82
- async jwtSign(content, options) {
83
- const jwtKit = await this.jwtKit("sign");
84
- return jwtKit.sign(content, options);
271
+ async jwtSign(content, options = {}) {
272
+ const kit = await this.jwtKit({ sign: true });
273
+ return kit.sign(content, options);
85
274
  }
86
- async jwtVerify(jwt, verify) {
87
- const jwtKit = await this.jwtKit("verify");
88
- return jwtKit.verify(jwt, verify);
89
- }
90
- async kryptosEnc(operation) {
91
- const kryptos = await this.amphora.find({
92
- algorithm: this.encAlgorithm,
93
- issuer: this.issuer,
94
- operation,
95
- use: "enc",
275
+ async jwtVerify(jwt, verify = {}) {
276
+ const decode = JwtKit_1.JwtKit.decode(jwt);
277
+ const kit = await this.jwtKit({
278
+ id: decode.header.kid,
279
+ algorithm: decode.header.alg,
96
280
  });
97
- this.logger.silly("Kryptos found", { kryptos: kryptos.toJSON() });
281
+ return kit.verify(jwt, verify);
282
+ }
283
+ async kryptosEnc(options = {}) {
284
+ const query = options.encrypt
285
+ ? {
286
+ $or: [
287
+ { operations: ["encrypt"] },
288
+ { operations: ["deriveKey"] },
289
+ { operations: ["wrapKey"] },
290
+ ],
291
+ algorithm: this.encAlgorithm,
292
+ issuer: this.issuer ?? undefined,
293
+ ...(options.keyFilter ? { purpose: options.keyFilter.purpose } : {}),
294
+ }
295
+ : {
296
+ $or: [
297
+ { operations: ["decrypt"] },
298
+ { operations: ["deriveKey"] },
299
+ { operations: ["unwrapKey"] },
300
+ ],
301
+ algorithm: options.algorithm ?? this.encAlgorithm,
302
+ };
303
+ const kryptos = await this.amphora.find(options.id ? { id: options.id } : { ...query, use: "enc" });
304
+ this.logger.debug("Kryptos found", { kryptos: kryptos.toJSON() });
98
305
  return kryptos;
99
306
  }
100
- async kryptosSig(operation) {
101
- const kryptos = await this.amphora.find({
102
- algorithm: this.sigAlgorithm,
103
- issuer: this.issuer,
104
- operation,
105
- private: true,
106
- use: "sig",
107
- });
108
- this.logger.silly("Kryptos found", { kryptos: kryptos.toJSON() });
307
+ async kryptosSig(options = {}) {
308
+ const query = options.sign
309
+ ? {
310
+ algorithm: this.encAlgorithm,
311
+ issuer: this.issuer ?? undefined,
312
+ operations: ["sign"],
313
+ ...(options.keyFilter ? { purpose: options.keyFilter.purpose } : {}),
314
+ }
315
+ : {
316
+ algorithm: options.algorithm ?? this.sigAlgorithm,
317
+ operations: ["verify"],
318
+ };
319
+ const kryptos = await this.amphora.find(options.id ? { id: options.id } : { ...query, use: "sig" });
320
+ this.logger.debug("Kryptos found", { kryptos: kryptos.toJSON() });
109
321
  return kryptos;
110
322
  }
111
323
  }
@@ -1 +1 @@
1
- {"version":3,"file":"Aegis.js","sourceRoot":"","sources":["../../src/classes/Aegis.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"Aegis.js","sourceRoot":"","sources":["../../src/classes/Aegis.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,14 @@
1
+ import { ICweKit } from "../interfaces";
2
+ import { CweContent, CweEncryptOptions, CweKitOptions, DecodedCwe, DecryptedCwe, EncryptedCwe } from "../types";
3
+ export declare class CweKit implements ICweKit {
4
+ private readonly encryption;
5
+ private readonly logger;
6
+ private readonly kryptos;
7
+ constructor(options: CweKitOptions);
8
+ encrypt(data: CweContent, options?: CweEncryptOptions): EncryptedCwe;
9
+ decrypt<T extends CweContent = string>(token: CweContent): DecryptedCwe<T>;
10
+ static isCwe(token: Buffer | string): boolean;
11
+ static decode(token: CweContent): DecodedCwe;
12
+ private contentType;
13
+ }
14
+ //# sourceMappingURL=CweKit.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"CweKit.d.ts","sourceRoot":"","sources":["../../src/classes/CweKit.ts"],"names":[],"mappings":"AAOA,OAAO,EAAE,OAAO,EAAE,MAAM,eAAe,CAAC;AACxC,OAAO,EACL,UAAU,EACV,iBAAiB,EACjB,aAAa,EACb,UAAU,EACV,YAAY,EAEZ,YAAY,EACb,MAAM,UAAU,CAAC;AASlB,qBAAa,MAAO,YAAW,OAAO;IACpC,OAAO,CAAC,QAAQ,CAAC,UAAU,CAAoB;IAC/C,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAU;IACjC,OAAO,CAAC,QAAQ,CAAC,OAAO,CAAW;gBAEhB,OAAO,EAAE,aAAa;IAMlC,OAAO,CAAC,IAAI,EAAE,UAAU,EAAE,OAAO,GAAE,iBAAsB,GAAG,YAAY;IA+DxE,OAAO,CAAC,CAAC,SAAS,UAAU,GAAG,MAAM,EAAE,KAAK,EAAE,UAAU,GAAG,YAAY,CAAC,CAAC,CAAC;WA0EnE,KAAK,CAAC,KAAK,EAAE,MAAM,GAAG,MAAM,GAAG,OAAO;WAStC,MAAM,CAAC,KAAK,EAAE,UAAU,GAAG,UAAU;IAgCnD,OAAO,CAAC,WAAW;CAMpB"}
@@ -0,0 +1,155 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.CweKit = void 0;
4
+ const aes_1 = require("@lindorm/aes");
5
+ const is_1 = require("@lindorm/is");
6
+ const cbor_1 = require("cbor");
7
+ const crypto_1 = require("crypto");
8
+ const errors_1 = require("../errors");
9
+ const private_1 = require("../utils/private");
10
+ class CweKit {
11
+ encryption;
12
+ logger;
13
+ kryptos;
14
+ constructor(options) {
15
+ this.logger = options.logger.child(["CoseEncryptKit"]);
16
+ this.kryptos = options.kryptos;
17
+ this.encryption = options.encryption ?? options.kryptos.encryption ?? "A256GCM";
18
+ }
19
+ encrypt(data, options = {}) {
20
+ const kit = new aes_1.AesKit({ encryption: this.encryption, kryptos: this.kryptos });
21
+ this.logger.debug("Encrypting token", { options });
22
+ const objectId = options.objectId ?? (0, crypto_1.randomBytes)(20).toString("base64url");
23
+ const { authTag, content, hkdfSalt, initialisationVector, pbkdfIterations, pbkdfSalt, publicEncryptionIv, publicEncryptionJwk, publicEncryptionKey, publicEncryptionTag, } = kit.encrypt(data, "record");
24
+ const protectedHeader = (0, private_1.mapCoseHeader)((0, private_1.mapTokenHeader)({
25
+ algorithm: this.kryptos.algorithm,
26
+ contentType: this.contentType(data),
27
+ headerType: "application/cose; cose-type=cose-encrypt",
28
+ }));
29
+ const protectedCbor = (0, cbor_1.encode)(protectedHeader);
30
+ const unprotectedHeader = (0, private_1.mapCoseHeader)((0, private_1.mapTokenHeader)({
31
+ ...(options.header ?? {}),
32
+ initialisationVector,
33
+ objectId,
34
+ }));
35
+ const ciphertext = Buffer.concat([content, authTag]);
36
+ const recipientHeader = (0, private_1.mapCoseHeader)((0, private_1.mapTokenHeader)({
37
+ encryption: this.encryption,
38
+ hkdfSalt,
39
+ initialisationVector: publicEncryptionIv,
40
+ jwksUri: this.kryptos.jwksUri ?? undefined,
41
+ keyId: this.kryptos.id,
42
+ pbkdfIterations,
43
+ pbkdfSalt,
44
+ publicEncryptionJwk,
45
+ publicEncryptionTag,
46
+ }));
47
+ const recipientPublicKey = publicEncryptionKey ?? null;
48
+ const recipients = [[(0, cbor_1.encode)({}), recipientHeader, recipientPublicKey]];
49
+ const buffer = (0, cbor_1.encode)([protectedCbor, unprotectedHeader, ciphertext, recipients]);
50
+ const token = buffer.toString("base64url");
51
+ this.logger.debug("Token encrypted", { token });
52
+ return { buffer, token };
53
+ }
54
+ decrypt(token) {
55
+ const kit = new aes_1.AesKit({ encryption: this.encryption, kryptos: this.kryptos });
56
+ this.logger.debug("Decrypting token", { token });
57
+ const decoded = CweKit.decode(token);
58
+ if (this.kryptos.algorithm !== decoded.protected.alg) {
59
+ throw new errors_1.CoseEncryptError("Invalid token", {
60
+ debug: {
61
+ expect: this.kryptos.algorithm,
62
+ actual: decoded.protected.alg,
63
+ },
64
+ });
65
+ }
66
+ if (decoded.recipient.unprotected.enc !== this.encryption) {
67
+ throw new errors_1.CoseEncryptError("Unexpected encryption", {
68
+ debug: {
69
+ expect: this.encryption,
70
+ actual: decoded.recipient.unprotected.enc,
71
+ },
72
+ });
73
+ }
74
+ const hkdfSalt = decoded.recipient.unprotected.hkdf_salt;
75
+ const initialisationVector = decoded.unprotected.iv;
76
+ const pbkdfIterations = decoded.recipient.unprotected.p2c;
77
+ const pbkdfSalt = decoded.recipient.unprotected.p2s;
78
+ const publicEncryptionIv = decoded.recipient.unprotected.iv;
79
+ const publicEncryptionJwk = decoded.recipient.unprotected.epk;
80
+ const publicEncryptionTag = decoded.recipient.unprotected.tag;
81
+ const publicEncryptionKey = decoded.recipient.publicEncryptionKey;
82
+ if (!initialisationVector) {
83
+ throw new errors_1.CoseEncryptError("Missing iv");
84
+ }
85
+ const header = (0, private_1.parseTokenHeader)({
86
+ ...decoded.protected,
87
+ enc: decoded.recipient.unprotected.enc,
88
+ epk: decoded.recipient.unprotected.epk,
89
+ jku: decoded.recipient.unprotected.jku,
90
+ kid: decoded.recipient.unprotected.kid,
91
+ oid: decoded.unprotected.oid,
92
+ });
93
+ const payload = kit.decrypt({
94
+ authTag: decoded.authTag,
95
+ content: decoded.content,
96
+ contentType: decoded.protected.cty ?? "text/plain",
97
+ encryption: this.encryption,
98
+ hkdfSalt,
99
+ initialisationVector,
100
+ pbkdfIterations,
101
+ pbkdfSalt,
102
+ publicEncryptionIv,
103
+ publicEncryptionJwk,
104
+ publicEncryptionKey,
105
+ publicEncryptionTag,
106
+ });
107
+ this.logger.debug("Token decrypted");
108
+ return {
109
+ decoded,
110
+ header,
111
+ payload,
112
+ token: (0, is_1.isString)(token) ? token : token.toString("base64url"),
113
+ };
114
+ }
115
+ static isCwe(token) {
116
+ try {
117
+ const decode = CweKit.decode(token);
118
+ return decode.protected.typ === "application/cose; cose-type=cose-encrypt";
119
+ }
120
+ catch {
121
+ return false;
122
+ }
123
+ }
124
+ static decode(token) {
125
+ const [protectedCbor, unprotectedCose, ciphertext, recipients] = (0, cbor_1.decode)((0, is_1.isBuffer)(token) ? token : Buffer.from(token, "base64url"));
126
+ const protectedDict = (0, private_1.decodeCoseHeader)((0, cbor_1.decode)(protectedCbor));
127
+ const unprotectedDict = (0, private_1.decodeCoseHeader)(unprotectedCose);
128
+ const [recipient] = recipients;
129
+ const [_, recipientHeader, publicEncryptionKey] = recipient;
130
+ const recipientDict = (0, private_1.decodeCoseHeader)(recipientHeader);
131
+ const length = (0, private_1.authTagLength)(recipientDict.enc);
132
+ const authTag = ciphertext.slice(-length);
133
+ const content = ciphertext.slice(0, -length);
134
+ return {
135
+ protected: protectedDict,
136
+ unprotected: unprotectedDict,
137
+ recipient: {
138
+ unprotected: recipientDict,
139
+ initialisationVector: recipientDict.iv,
140
+ publicEncryptionKey,
141
+ },
142
+ initialisationVector: unprotectedDict.iv,
143
+ content,
144
+ authTag,
145
+ };
146
+ }
147
+ contentType(input) {
148
+ if ((0, is_1.isBuffer)(input)) {
149
+ return "application/octet-stream";
150
+ }
151
+ return "text/plain";
152
+ }
153
+ }
154
+ exports.CweKit = CweKit;
155
+ //# sourceMappingURL=CweKit.js.map