@naylence/advanced-security 0.3.7-test.112 → 0.3.7-test.114

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 (421) hide show
  1. package/package.json +1 -1
  2. package/dist/browser/index.cjs +0 -9864
  3. package/dist/browser/index.mjs +0 -9811
  4. package/dist/cjs/advanced-security-isomorphic.js +0 -82
  5. package/dist/cjs/advanced-security-isomorphic.js.map +0 -1
  6. package/dist/cjs/browser.js +0 -25
  7. package/dist/cjs/browser.js.map +0 -1
  8. package/dist/cjs/index.js +0 -2
  9. package/dist/cjs/index.js.map +0 -1
  10. package/dist/cjs/install-env.js +0 -2
  11. package/dist/cjs/install-env.js.map +0 -1
  12. package/dist/cjs/naylence/fame/factory-manifest.js +0 -39
  13. package/dist/cjs/naylence/fame/factory-manifest.js.map +0 -1
  14. package/dist/cjs/naylence/fame/security/cert/browser-csr.js +0 -103
  15. package/dist/cjs/naylence/fame/security/cert/browser-csr.js.map +0 -1
  16. package/dist/cjs/naylence/fame/security/cert/ca-server-cli.js +0 -30
  17. package/dist/cjs/naylence/fame/security/cert/ca-server-cli.js.map +0 -1
  18. package/dist/cjs/naylence/fame/security/cert/ca-server.js +0 -223
  19. package/dist/cjs/naylence/fame/security/cert/ca-server.js.map +0 -1
  20. package/dist/cjs/naylence/fame/security/cert/ca-service-client.js +0 -585
  21. package/dist/cjs/naylence/fame/security/cert/ca-service-client.js.map +0 -1
  22. package/dist/cjs/naylence/fame/security/cert/ca-service-factory.js +0 -61
  23. package/dist/cjs/naylence/fame/security/cert/ca-service-factory.js.map +0 -1
  24. package/dist/cjs/naylence/fame/security/cert/ca-types.js +0 -39
  25. package/dist/cjs/naylence/fame/security/cert/ca-types.js.map +0 -1
  26. package/dist/cjs/naylence/fame/security/cert/csr-types.js +0 -2
  27. package/dist/cjs/naylence/fame/security/cert/csr-types.js.map +0 -1
  28. package/dist/cjs/naylence/fame/security/cert/default-ca-service-factory.js +0 -66
  29. package/dist/cjs/naylence/fame/security/cert/default-ca-service-factory.js.map +0 -1
  30. package/dist/cjs/naylence/fame/security/cert/default-ca-service.js +0 -364
  31. package/dist/cjs/naylence/fame/security/cert/default-ca-service.js.map +0 -1
  32. package/dist/cjs/naylence/fame/security/cert/default-certificate-manager-factory.js +0 -73
  33. package/dist/cjs/naylence/fame/security/cert/default-certificate-manager-factory.js.map +0 -1
  34. package/dist/cjs/naylence/fame/security/cert/default-certificate-manager.js +0 -815
  35. package/dist/cjs/naylence/fame/security/cert/default-certificate-manager.js.map +0 -1
  36. package/dist/cjs/naylence/fame/security/cert/grants.js +0 -2
  37. package/dist/cjs/naylence/fame/security/cert/grants.js.map +0 -1
  38. package/dist/cjs/naylence/fame/security/cert/index.js +0 -18
  39. package/dist/cjs/naylence/fame/security/cert/index.js.map +0 -1
  40. package/dist/cjs/naylence/fame/security/cert/internal-ca-service.js +0 -741
  41. package/dist/cjs/naylence/fame/security/cert/internal-ca-service.js.map +0 -1
  42. package/dist/cjs/naylence/fame/security/cert/node-ed25519-csr.js +0 -156
  43. package/dist/cjs/naylence/fame/security/cert/node-ed25519-csr.js.map +0 -1
  44. package/dist/cjs/naylence/fame/security/cert/oid-constants.js +0 -7
  45. package/dist/cjs/naylence/fame/security/cert/oid-constants.js.map +0 -1
  46. package/dist/cjs/naylence/fame/security/cert/trust-store/anchor-utils.js +0 -119
  47. package/dist/cjs/naylence/fame/security/cert/trust-store/anchor-utils.js.map +0 -1
  48. package/dist/cjs/naylence/fame/security/cert/trust-store/browser-trust-store-provider-factory.js +0 -82
  49. package/dist/cjs/naylence/fame/security/cert/trust-store/browser-trust-store-provider-factory.js.map +0 -1
  50. package/dist/cjs/naylence/fame/security/cert/trust-store/env-provider.js +0 -168
  51. package/dist/cjs/naylence/fame/security/cert/trust-store/env-provider.js.map +0 -1
  52. package/dist/cjs/naylence/fame/security/cert/trust-store/fame-ca-certs-parser.js +0 -257
  53. package/dist/cjs/naylence/fame/security/cert/trust-store/fame-ca-certs-parser.js.map +0 -1
  54. package/dist/cjs/naylence/fame/security/cert/trust-store/http-bundle-provider.js +0 -497
  55. package/dist/cjs/naylence/fame/security/cert/trust-store/http-bundle-provider.js.map +0 -1
  56. package/dist/cjs/naylence/fame/security/cert/trust-store/http-signed-bundle-provider.js +0 -2
  57. package/dist/cjs/naylence/fame/security/cert/trust-store/http-signed-bundle-provider.js.map +0 -1
  58. package/dist/cjs/naylence/fame/security/cert/trust-store/node-trust-store-provider-factory.js +0 -61
  59. package/dist/cjs/naylence/fame/security/cert/trust-store/node-trust-store-provider-factory.js.map +0 -1
  60. package/dist/cjs/naylence/fame/security/cert/trust-store/static-bundle-provider.js +0 -44
  61. package/dist/cjs/naylence/fame/security/cert/trust-store/static-bundle-provider.js.map +0 -1
  62. package/dist/cjs/naylence/fame/security/cert/trust-store/trust-store-provider-factory.js +0 -40
  63. package/dist/cjs/naylence/fame/security/cert/trust-store/trust-store-provider-factory.js.map +0 -1
  64. package/dist/cjs/naylence/fame/security/cert/trust-store/trust-store-provider.js +0 -2
  65. package/dist/cjs/naylence/fame/security/cert/trust-store/trust-store-provider.js.map +0 -1
  66. package/dist/cjs/naylence/fame/security/cert/util.js +0 -515
  67. package/dist/cjs/naylence/fame/security/cert/util.js.map +0 -1
  68. package/dist/cjs/naylence/fame/security/encryption/channel/channel-encryption-manager-factory.js +0 -85
  69. package/dist/cjs/naylence/fame/security/encryption/channel/channel-encryption-manager-factory.js.map +0 -1
  70. package/dist/cjs/naylence/fame/security/encryption/channel/channel-encryption-manager.js +0 -743
  71. package/dist/cjs/naylence/fame/security/encryption/channel/channel-encryption-manager.js.map +0 -1
  72. package/dist/cjs/naylence/fame/security/encryption/channel/index.js +0 -3
  73. package/dist/cjs/naylence/fame/security/encryption/channel/index.js.map +0 -1
  74. package/dist/cjs/naylence/fame/security/encryption/composite-encryption-manager-factory.js +0 -113
  75. package/dist/cjs/naylence/fame/security/encryption/composite-encryption-manager-factory.js.map +0 -1
  76. package/dist/cjs/naylence/fame/security/encryption/composite-encryption-manager.js +0 -321
  77. package/dist/cjs/naylence/fame/security/encryption/composite-encryption-manager.js.map +0 -1
  78. package/dist/cjs/naylence/fame/security/encryption/default-secure-channel-manager-factory.js +0 -53
  79. package/dist/cjs/naylence/fame/security/encryption/default-secure-channel-manager-factory.js.map +0 -1
  80. package/dist/cjs/naylence/fame/security/encryption/default-secure-channel-manager.js +0 -278
  81. package/dist/cjs/naylence/fame/security/encryption/default-secure-channel-manager.js.map +0 -1
  82. package/dist/cjs/naylence/fame/security/encryption/encryption-manager-registry.js +0 -167
  83. package/dist/cjs/naylence/fame/security/encryption/encryption-manager-registry.js.map +0 -1
  84. package/dist/cjs/naylence/fame/security/encryption/index.js +0 -7
  85. package/dist/cjs/naylence/fame/security/encryption/index.js.map +0 -1
  86. package/dist/cjs/naylence/fame/security/encryption/sealed/index.js +0 -3
  87. package/dist/cjs/naylence/fame/security/encryption/sealed/index.js.map +0 -1
  88. package/dist/cjs/naylence/fame/security/encryption/sealed/x25519-encryption-manager-factory.js +0 -82
  89. package/dist/cjs/naylence/fame/security/encryption/sealed/x25519-encryption-manager-factory.js.map +0 -1
  90. package/dist/cjs/naylence/fame/security/encryption/sealed/x25519-encryption-manager.js +0 -542
  91. package/dist/cjs/naylence/fame/security/encryption/sealed/x25519-encryption-manager.js.map +0 -1
  92. package/dist/cjs/naylence/fame/security/index.js +0 -6
  93. package/dist/cjs/naylence/fame/security/index.js.map +0 -1
  94. package/dist/cjs/naylence/fame/security/keys/index.js +0 -3
  95. package/dist/cjs/naylence/fame/security/keys/index.js.map +0 -1
  96. package/dist/cjs/naylence/fame/security/keys/x5c-key-manager-factory.js +0 -36
  97. package/dist/cjs/naylence/fame/security/keys/x5c-key-manager-factory.js.map +0 -1
  98. package/dist/cjs/naylence/fame/security/keys/x5c-key-manager.js +0 -405
  99. package/dist/cjs/naylence/fame/security/keys/x5c-key-manager.js.map +0 -1
  100. package/dist/cjs/naylence/fame/security/register-advanced-security-factories.js +0 -283
  101. package/dist/cjs/naylence/fame/security/register-advanced-security-factories.js.map +0 -1
  102. package/dist/cjs/naylence/fame/security/signing/eddsa-envelope-signer-factory.js +0 -34
  103. package/dist/cjs/naylence/fame/security/signing/eddsa-envelope-signer-factory.js.map +0 -1
  104. package/dist/cjs/naylence/fame/security/signing/eddsa-envelope-verifier-factory.js +0 -33
  105. package/dist/cjs/naylence/fame/security/signing/eddsa-envelope-verifier-factory.js.map +0 -1
  106. package/dist/cjs/naylence/fame/security/signing/eddsa-envelope-verifier.js +0 -189
  107. package/dist/cjs/naylence/fame/security/signing/eddsa-envelope-verifier.js.map +0 -1
  108. package/dist/cjs/naylence/fame/stickiness/aft-helper.js +0 -72
  109. package/dist/cjs/naylence/fame/stickiness/aft-helper.js.map +0 -1
  110. package/dist/cjs/naylence/fame/stickiness/aft-load-balancer-stickiness-manager-factory.js +0 -65
  111. package/dist/cjs/naylence/fame/stickiness/aft-load-balancer-stickiness-manager-factory.js.map +0 -1
  112. package/dist/cjs/naylence/fame/stickiness/aft-load-balancer-stickiness-manager.js +0 -447
  113. package/dist/cjs/naylence/fame/stickiness/aft-load-balancer-stickiness-manager.js.map +0 -1
  114. package/dist/cjs/naylence/fame/stickiness/aft-model.js +0 -54
  115. package/dist/cjs/naylence/fame/stickiness/aft-model.js.map +0 -1
  116. package/dist/cjs/naylence/fame/stickiness/aft-replica-stickiness-manager-factory.js +0 -50
  117. package/dist/cjs/naylence/fame/stickiness/aft-replica-stickiness-manager-factory.js.map +0 -1
  118. package/dist/cjs/naylence/fame/stickiness/aft-replica-stickiness-manager.js +0 -203
  119. package/dist/cjs/naylence/fame/stickiness/aft-replica-stickiness-manager.js.map +0 -1
  120. package/dist/cjs/naylence/fame/stickiness/aft-signer.js +0 -147
  121. package/dist/cjs/naylence/fame/stickiness/aft-signer.js.map +0 -1
  122. package/dist/cjs/naylence/fame/stickiness/aft-utils.js +0 -90
  123. package/dist/cjs/naylence/fame/stickiness/aft-utils.js.map +0 -1
  124. package/dist/cjs/naylence/fame/stickiness/aft-verifier.js +0 -290
  125. package/dist/cjs/naylence/fame/stickiness/aft-verifier.js.map +0 -1
  126. package/dist/cjs/naylence/fame/stickiness/index.js +0 -11
  127. package/dist/cjs/naylence/fame/stickiness/index.js.map +0 -1
  128. package/dist/cjs/naylence/fame/stickiness/stickiness-mode.js +0 -24
  129. package/dist/cjs/naylence/fame/stickiness/stickiness-mode.js.map +0 -1
  130. package/dist/cjs/naylence/fame/welcome/advanced-welcome-service-factory.js +0 -93
  131. package/dist/cjs/naylence/fame/welcome/advanced-welcome-service-factory.js.map +0 -1
  132. package/dist/cjs/naylence/fame/welcome/advanced-welcome-service.js +0 -212
  133. package/dist/cjs/naylence/fame/welcome/advanced-welcome-service.js.map +0 -1
  134. package/dist/cjs/naylence/fame/welcome/index.js +0 -3
  135. package/dist/cjs/naylence/fame/welcome/index.js.map +0 -1
  136. package/dist/cjs/node.js +0 -11
  137. package/dist/cjs/node.js.map +0 -1
  138. package/dist/cjs/plugin.js +0 -39
  139. package/dist/cjs/plugin.js.map +0 -1
  140. package/dist/cjs/version.js +0 -8
  141. package/dist/cjs/version.js.map +0 -1
  142. package/dist/esm/advanced-security-isomorphic.js +0 -82
  143. package/dist/esm/advanced-security-isomorphic.js.map +0 -1
  144. package/dist/esm/browser.js +0 -25
  145. package/dist/esm/browser.js.map +0 -1
  146. package/dist/esm/index.js +0 -2
  147. package/dist/esm/index.js.map +0 -1
  148. package/dist/esm/install-env.js +0 -2
  149. package/dist/esm/install-env.js.map +0 -1
  150. package/dist/esm/naylence/fame/factory-manifest.js +0 -39
  151. package/dist/esm/naylence/fame/factory-manifest.js.map +0 -1
  152. package/dist/esm/naylence/fame/security/cert/browser-csr.js +0 -103
  153. package/dist/esm/naylence/fame/security/cert/browser-csr.js.map +0 -1
  154. package/dist/esm/naylence/fame/security/cert/ca-server-cli.js +0 -30
  155. package/dist/esm/naylence/fame/security/cert/ca-server-cli.js.map +0 -1
  156. package/dist/esm/naylence/fame/security/cert/ca-server.js +0 -223
  157. package/dist/esm/naylence/fame/security/cert/ca-server.js.map +0 -1
  158. package/dist/esm/naylence/fame/security/cert/ca-service-client.js +0 -585
  159. package/dist/esm/naylence/fame/security/cert/ca-service-client.js.map +0 -1
  160. package/dist/esm/naylence/fame/security/cert/ca-service-factory.js +0 -61
  161. package/dist/esm/naylence/fame/security/cert/ca-service-factory.js.map +0 -1
  162. package/dist/esm/naylence/fame/security/cert/ca-types.js +0 -39
  163. package/dist/esm/naylence/fame/security/cert/ca-types.js.map +0 -1
  164. package/dist/esm/naylence/fame/security/cert/csr-types.js +0 -2
  165. package/dist/esm/naylence/fame/security/cert/csr-types.js.map +0 -1
  166. package/dist/esm/naylence/fame/security/cert/default-ca-service-factory.js +0 -66
  167. package/dist/esm/naylence/fame/security/cert/default-ca-service-factory.js.map +0 -1
  168. package/dist/esm/naylence/fame/security/cert/default-ca-service.js +0 -364
  169. package/dist/esm/naylence/fame/security/cert/default-ca-service.js.map +0 -1
  170. package/dist/esm/naylence/fame/security/cert/default-certificate-manager-factory.js +0 -73
  171. package/dist/esm/naylence/fame/security/cert/default-certificate-manager-factory.js.map +0 -1
  172. package/dist/esm/naylence/fame/security/cert/default-certificate-manager.js +0 -815
  173. package/dist/esm/naylence/fame/security/cert/default-certificate-manager.js.map +0 -1
  174. package/dist/esm/naylence/fame/security/cert/grants.js +0 -2
  175. package/dist/esm/naylence/fame/security/cert/grants.js.map +0 -1
  176. package/dist/esm/naylence/fame/security/cert/index.js +0 -18
  177. package/dist/esm/naylence/fame/security/cert/index.js.map +0 -1
  178. package/dist/esm/naylence/fame/security/cert/internal-ca-service.js +0 -741
  179. package/dist/esm/naylence/fame/security/cert/internal-ca-service.js.map +0 -1
  180. package/dist/esm/naylence/fame/security/cert/node-ed25519-csr.js +0 -156
  181. package/dist/esm/naylence/fame/security/cert/node-ed25519-csr.js.map +0 -1
  182. package/dist/esm/naylence/fame/security/cert/oid-constants.js +0 -7
  183. package/dist/esm/naylence/fame/security/cert/oid-constants.js.map +0 -1
  184. package/dist/esm/naylence/fame/security/cert/trust-store/anchor-utils.js +0 -119
  185. package/dist/esm/naylence/fame/security/cert/trust-store/anchor-utils.js.map +0 -1
  186. package/dist/esm/naylence/fame/security/cert/trust-store/browser-trust-store-provider-factory.js +0 -82
  187. package/dist/esm/naylence/fame/security/cert/trust-store/browser-trust-store-provider-factory.js.map +0 -1
  188. package/dist/esm/naylence/fame/security/cert/trust-store/env-provider.js +0 -168
  189. package/dist/esm/naylence/fame/security/cert/trust-store/env-provider.js.map +0 -1
  190. package/dist/esm/naylence/fame/security/cert/trust-store/fame-ca-certs-parser.js +0 -257
  191. package/dist/esm/naylence/fame/security/cert/trust-store/fame-ca-certs-parser.js.map +0 -1
  192. package/dist/esm/naylence/fame/security/cert/trust-store/http-bundle-provider.js +0 -497
  193. package/dist/esm/naylence/fame/security/cert/trust-store/http-bundle-provider.js.map +0 -1
  194. package/dist/esm/naylence/fame/security/cert/trust-store/http-signed-bundle-provider.js +0 -2
  195. package/dist/esm/naylence/fame/security/cert/trust-store/http-signed-bundle-provider.js.map +0 -1
  196. package/dist/esm/naylence/fame/security/cert/trust-store/node-trust-store-provider-factory.js +0 -61
  197. package/dist/esm/naylence/fame/security/cert/trust-store/node-trust-store-provider-factory.js.map +0 -1
  198. package/dist/esm/naylence/fame/security/cert/trust-store/static-bundle-provider.js +0 -44
  199. package/dist/esm/naylence/fame/security/cert/trust-store/static-bundle-provider.js.map +0 -1
  200. package/dist/esm/naylence/fame/security/cert/trust-store/trust-store-provider-factory.js +0 -40
  201. package/dist/esm/naylence/fame/security/cert/trust-store/trust-store-provider-factory.js.map +0 -1
  202. package/dist/esm/naylence/fame/security/cert/trust-store/trust-store-provider.js +0 -2
  203. package/dist/esm/naylence/fame/security/cert/trust-store/trust-store-provider.js.map +0 -1
  204. package/dist/esm/naylence/fame/security/cert/util.js +0 -515
  205. package/dist/esm/naylence/fame/security/cert/util.js.map +0 -1
  206. package/dist/esm/naylence/fame/security/encryption/channel/channel-encryption-manager-factory.js +0 -85
  207. package/dist/esm/naylence/fame/security/encryption/channel/channel-encryption-manager-factory.js.map +0 -1
  208. package/dist/esm/naylence/fame/security/encryption/channel/channel-encryption-manager.js +0 -743
  209. package/dist/esm/naylence/fame/security/encryption/channel/channel-encryption-manager.js.map +0 -1
  210. package/dist/esm/naylence/fame/security/encryption/channel/index.js +0 -3
  211. package/dist/esm/naylence/fame/security/encryption/channel/index.js.map +0 -1
  212. package/dist/esm/naylence/fame/security/encryption/composite-encryption-manager-factory.js +0 -113
  213. package/dist/esm/naylence/fame/security/encryption/composite-encryption-manager-factory.js.map +0 -1
  214. package/dist/esm/naylence/fame/security/encryption/composite-encryption-manager.js +0 -321
  215. package/dist/esm/naylence/fame/security/encryption/composite-encryption-manager.js.map +0 -1
  216. package/dist/esm/naylence/fame/security/encryption/default-secure-channel-manager-factory.js +0 -53
  217. package/dist/esm/naylence/fame/security/encryption/default-secure-channel-manager-factory.js.map +0 -1
  218. package/dist/esm/naylence/fame/security/encryption/default-secure-channel-manager.js +0 -278
  219. package/dist/esm/naylence/fame/security/encryption/default-secure-channel-manager.js.map +0 -1
  220. package/dist/esm/naylence/fame/security/encryption/encryption-manager-registry.js +0 -167
  221. package/dist/esm/naylence/fame/security/encryption/encryption-manager-registry.js.map +0 -1
  222. package/dist/esm/naylence/fame/security/encryption/index.js +0 -7
  223. package/dist/esm/naylence/fame/security/encryption/index.js.map +0 -1
  224. package/dist/esm/naylence/fame/security/encryption/sealed/index.js +0 -3
  225. package/dist/esm/naylence/fame/security/encryption/sealed/index.js.map +0 -1
  226. package/dist/esm/naylence/fame/security/encryption/sealed/x25519-encryption-manager-factory.js +0 -82
  227. package/dist/esm/naylence/fame/security/encryption/sealed/x25519-encryption-manager-factory.js.map +0 -1
  228. package/dist/esm/naylence/fame/security/encryption/sealed/x25519-encryption-manager.js +0 -542
  229. package/dist/esm/naylence/fame/security/encryption/sealed/x25519-encryption-manager.js.map +0 -1
  230. package/dist/esm/naylence/fame/security/index.js +0 -6
  231. package/dist/esm/naylence/fame/security/index.js.map +0 -1
  232. package/dist/esm/naylence/fame/security/keys/index.js +0 -3
  233. package/dist/esm/naylence/fame/security/keys/index.js.map +0 -1
  234. package/dist/esm/naylence/fame/security/keys/x5c-key-manager-factory.js +0 -36
  235. package/dist/esm/naylence/fame/security/keys/x5c-key-manager-factory.js.map +0 -1
  236. package/dist/esm/naylence/fame/security/keys/x5c-key-manager.js +0 -405
  237. package/dist/esm/naylence/fame/security/keys/x5c-key-manager.js.map +0 -1
  238. package/dist/esm/naylence/fame/security/register-advanced-security-factories.js +0 -283
  239. package/dist/esm/naylence/fame/security/register-advanced-security-factories.js.map +0 -1
  240. package/dist/esm/naylence/fame/security/signing/eddsa-envelope-signer-factory.js +0 -34
  241. package/dist/esm/naylence/fame/security/signing/eddsa-envelope-signer-factory.js.map +0 -1
  242. package/dist/esm/naylence/fame/security/signing/eddsa-envelope-verifier-factory.js +0 -33
  243. package/dist/esm/naylence/fame/security/signing/eddsa-envelope-verifier-factory.js.map +0 -1
  244. package/dist/esm/naylence/fame/security/signing/eddsa-envelope-verifier.js +0 -189
  245. package/dist/esm/naylence/fame/security/signing/eddsa-envelope-verifier.js.map +0 -1
  246. package/dist/esm/naylence/fame/stickiness/aft-helper.js +0 -72
  247. package/dist/esm/naylence/fame/stickiness/aft-helper.js.map +0 -1
  248. package/dist/esm/naylence/fame/stickiness/aft-load-balancer-stickiness-manager-factory.js +0 -65
  249. package/dist/esm/naylence/fame/stickiness/aft-load-balancer-stickiness-manager-factory.js.map +0 -1
  250. package/dist/esm/naylence/fame/stickiness/aft-load-balancer-stickiness-manager.js +0 -447
  251. package/dist/esm/naylence/fame/stickiness/aft-load-balancer-stickiness-manager.js.map +0 -1
  252. package/dist/esm/naylence/fame/stickiness/aft-model.js +0 -54
  253. package/dist/esm/naylence/fame/stickiness/aft-model.js.map +0 -1
  254. package/dist/esm/naylence/fame/stickiness/aft-replica-stickiness-manager-factory.js +0 -50
  255. package/dist/esm/naylence/fame/stickiness/aft-replica-stickiness-manager-factory.js.map +0 -1
  256. package/dist/esm/naylence/fame/stickiness/aft-replica-stickiness-manager.js +0 -203
  257. package/dist/esm/naylence/fame/stickiness/aft-replica-stickiness-manager.js.map +0 -1
  258. package/dist/esm/naylence/fame/stickiness/aft-signer.js +0 -147
  259. package/dist/esm/naylence/fame/stickiness/aft-signer.js.map +0 -1
  260. package/dist/esm/naylence/fame/stickiness/aft-utils.js +0 -90
  261. package/dist/esm/naylence/fame/stickiness/aft-utils.js.map +0 -1
  262. package/dist/esm/naylence/fame/stickiness/aft-verifier.js +0 -290
  263. package/dist/esm/naylence/fame/stickiness/aft-verifier.js.map +0 -1
  264. package/dist/esm/naylence/fame/stickiness/index.js +0 -11
  265. package/dist/esm/naylence/fame/stickiness/index.js.map +0 -1
  266. package/dist/esm/naylence/fame/stickiness/stickiness-mode.js +0 -24
  267. package/dist/esm/naylence/fame/stickiness/stickiness-mode.js.map +0 -1
  268. package/dist/esm/naylence/fame/welcome/advanced-welcome-service-factory.js +0 -93
  269. package/dist/esm/naylence/fame/welcome/advanced-welcome-service-factory.js.map +0 -1
  270. package/dist/esm/naylence/fame/welcome/advanced-welcome-service.js +0 -212
  271. package/dist/esm/naylence/fame/welcome/advanced-welcome-service.js.map +0 -1
  272. package/dist/esm/naylence/fame/welcome/index.js +0 -3
  273. package/dist/esm/naylence/fame/welcome/index.js.map +0 -1
  274. package/dist/esm/node.js +0 -11
  275. package/dist/esm/node.js.map +0 -1
  276. package/dist/esm/plugin.js +0 -39
  277. package/dist/esm/plugin.js.map +0 -1
  278. package/dist/esm/version.js +0 -8
  279. package/dist/esm/version.js.map +0 -1
  280. package/dist/node/index.cjs +0 -9855
  281. package/dist/node/index.mjs +0 -9800
  282. package/dist/node/node.cjs +0 -10139
  283. package/dist/node/node.mjs +0 -10046
  284. package/dist/types/advanced-security-isomorphic.d.ts +0 -24
  285. package/dist/types/advanced-security-isomorphic.d.ts.map +0 -1
  286. package/dist/types/browser.d.ts +0 -19
  287. package/dist/types/browser.d.ts.map +0 -1
  288. package/dist/types/index.d.ts +0 -2
  289. package/dist/types/index.d.ts.map +0 -1
  290. package/dist/types/install-env.d.ts +0 -3
  291. package/dist/types/install-env.d.ts.map +0 -1
  292. package/dist/types/naylence/fame/factory-manifest.d.ts +0 -11
  293. package/dist/types/naylence/fame/factory-manifest.d.ts.map +0 -1
  294. package/dist/types/naylence/fame/security/cert/browser-csr.d.ts +0 -9
  295. package/dist/types/naylence/fame/security/cert/browser-csr.d.ts.map +0 -1
  296. package/dist/types/naylence/fame/security/cert/ca-server-cli.d.ts +0 -3
  297. package/dist/types/naylence/fame/security/cert/ca-server-cli.d.ts.map +0 -1
  298. package/dist/types/naylence/fame/security/cert/ca-server.d.ts +0 -19
  299. package/dist/types/naylence/fame/security/cert/ca-server.d.ts.map +0 -1
  300. package/dist/types/naylence/fame/security/cert/ca-service-client.d.ts +0 -75
  301. package/dist/types/naylence/fame/security/cert/ca-service-client.d.ts.map +0 -1
  302. package/dist/types/naylence/fame/security/cert/ca-service-factory.d.ts +0 -43
  303. package/dist/types/naylence/fame/security/cert/ca-service-factory.d.ts.map +0 -1
  304. package/dist/types/naylence/fame/security/cert/ca-types.d.ts +0 -129
  305. package/dist/types/naylence/fame/security/cert/ca-types.d.ts.map +0 -1
  306. package/dist/types/naylence/fame/security/cert/csr-types.d.ts +0 -5
  307. package/dist/types/naylence/fame/security/cert/csr-types.d.ts.map +0 -1
  308. package/dist/types/naylence/fame/security/cert/default-ca-service-factory.d.ts +0 -55
  309. package/dist/types/naylence/fame/security/cert/default-ca-service-factory.d.ts.map +0 -1
  310. package/dist/types/naylence/fame/security/cert/default-ca-service.d.ts +0 -85
  311. package/dist/types/naylence/fame/security/cert/default-ca-service.d.ts.map +0 -1
  312. package/dist/types/naylence/fame/security/cert/default-certificate-manager-factory.d.ts +0 -25
  313. package/dist/types/naylence/fame/security/cert/default-certificate-manager-factory.d.ts.map +0 -1
  314. package/dist/types/naylence/fame/security/cert/default-certificate-manager.d.ts +0 -70
  315. package/dist/types/naylence/fame/security/cert/default-certificate-manager.d.ts.map +0 -1
  316. package/dist/types/naylence/fame/security/cert/grants.d.ts +0 -2
  317. package/dist/types/naylence/fame/security/cert/grants.d.ts.map +0 -1
  318. package/dist/types/naylence/fame/security/cert/index.d.ts +0 -19
  319. package/dist/types/naylence/fame/security/cert/index.d.ts.map +0 -1
  320. package/dist/types/naylence/fame/security/cert/internal-ca-service.d.ts +0 -129
  321. package/dist/types/naylence/fame/security/cert/internal-ca-service.d.ts.map +0 -1
  322. package/dist/types/naylence/fame/security/cert/node-ed25519-csr.d.ts +0 -9
  323. package/dist/types/naylence/fame/security/cert/node-ed25519-csr.d.ts.map +0 -1
  324. package/dist/types/naylence/fame/security/cert/oid-constants.d.ts +0 -7
  325. package/dist/types/naylence/fame/security/cert/oid-constants.d.ts.map +0 -1
  326. package/dist/types/naylence/fame/security/cert/trust-store/anchor-utils.d.ts +0 -12
  327. package/dist/types/naylence/fame/security/cert/trust-store/anchor-utils.d.ts.map +0 -1
  328. package/dist/types/naylence/fame/security/cert/trust-store/browser-trust-store-provider-factory.d.ts +0 -29
  329. package/dist/types/naylence/fame/security/cert/trust-store/browser-trust-store-provider-factory.d.ts.map +0 -1
  330. package/dist/types/naylence/fame/security/cert/trust-store/env-provider.d.ts +0 -7
  331. package/dist/types/naylence/fame/security/cert/trust-store/env-provider.d.ts.map +0 -1
  332. package/dist/types/naylence/fame/security/cert/trust-store/fame-ca-certs-parser.d.ts +0 -9
  333. package/dist/types/naylence/fame/security/cert/trust-store/fame-ca-certs-parser.d.ts.map +0 -1
  334. package/dist/types/naylence/fame/security/cert/trust-store/http-bundle-provider.d.ts +0 -35
  335. package/dist/types/naylence/fame/security/cert/trust-store/http-bundle-provider.d.ts.map +0 -1
  336. package/dist/types/naylence/fame/security/cert/trust-store/http-signed-bundle-provider.d.ts +0 -2
  337. package/dist/types/naylence/fame/security/cert/trust-store/http-signed-bundle-provider.d.ts.map +0 -1
  338. package/dist/types/naylence/fame/security/cert/trust-store/node-trust-store-provider-factory.d.ts +0 -23
  339. package/dist/types/naylence/fame/security/cert/trust-store/node-trust-store-provider-factory.d.ts.map +0 -1
  340. package/dist/types/naylence/fame/security/cert/trust-store/static-bundle-provider.d.ts +0 -15
  341. package/dist/types/naylence/fame/security/cert/trust-store/static-bundle-provider.d.ts.map +0 -1
  342. package/dist/types/naylence/fame/security/cert/trust-store/trust-store-provider-factory.d.ts +0 -28
  343. package/dist/types/naylence/fame/security/cert/trust-store/trust-store-provider-factory.d.ts.map +0 -1
  344. package/dist/types/naylence/fame/security/cert/trust-store/trust-store-provider.d.ts +0 -43
  345. package/dist/types/naylence/fame/security/cert/trust-store/trust-store-provider.d.ts.map +0 -1
  346. package/dist/types/naylence/fame/security/cert/util.d.ts +0 -25
  347. package/dist/types/naylence/fame/security/cert/util.d.ts.map +0 -1
  348. package/dist/types/naylence/fame/security/encryption/channel/channel-encryption-manager-factory.d.ts +0 -29
  349. package/dist/types/naylence/fame/security/encryption/channel/channel-encryption-manager-factory.d.ts.map +0 -1
  350. package/dist/types/naylence/fame/security/encryption/channel/channel-encryption-manager.d.ts +0 -51
  351. package/dist/types/naylence/fame/security/encryption/channel/channel-encryption-manager.d.ts.map +0 -1
  352. package/dist/types/naylence/fame/security/encryption/channel/index.d.ts +0 -3
  353. package/dist/types/naylence/fame/security/encryption/channel/index.d.ts.map +0 -1
  354. package/dist/types/naylence/fame/security/encryption/composite-encryption-manager-factory.d.ts +0 -32
  355. package/dist/types/naylence/fame/security/encryption/composite-encryption-manager-factory.d.ts.map +0 -1
  356. package/dist/types/naylence/fame/security/encryption/composite-encryption-manager.d.ts +0 -52
  357. package/dist/types/naylence/fame/security/encryption/composite-encryption-manager.d.ts.map +0 -1
  358. package/dist/types/naylence/fame/security/encryption/default-secure-channel-manager-factory.d.ts +0 -23
  359. package/dist/types/naylence/fame/security/encryption/default-secure-channel-manager-factory.d.ts.map +0 -1
  360. package/dist/types/naylence/fame/security/encryption/default-secure-channel-manager.d.ts +0 -37
  361. package/dist/types/naylence/fame/security/encryption/default-secure-channel-manager.d.ts.map +0 -1
  362. package/dist/types/naylence/fame/security/encryption/encryption-manager-registry.d.ts +0 -34
  363. package/dist/types/naylence/fame/security/encryption/encryption-manager-registry.d.ts.map +0 -1
  364. package/dist/types/naylence/fame/security/encryption/index.d.ts +0 -7
  365. package/dist/types/naylence/fame/security/encryption/index.d.ts.map +0 -1
  366. package/dist/types/naylence/fame/security/encryption/sealed/index.d.ts +0 -3
  367. package/dist/types/naylence/fame/security/encryption/sealed/index.d.ts.map +0 -1
  368. package/dist/types/naylence/fame/security/encryption/sealed/x25519-encryption-manager-factory.d.ts +0 -28
  369. package/dist/types/naylence/fame/security/encryption/sealed/x25519-encryption-manager-factory.d.ts.map +0 -1
  370. package/dist/types/naylence/fame/security/encryption/sealed/x25519-encryption-manager.d.ts +0 -43
  371. package/dist/types/naylence/fame/security/encryption/sealed/x25519-encryption-manager.d.ts.map +0 -1
  372. package/dist/types/naylence/fame/security/index.d.ts +0 -6
  373. package/dist/types/naylence/fame/security/index.d.ts.map +0 -1
  374. package/dist/types/naylence/fame/security/keys/index.d.ts +0 -3
  375. package/dist/types/naylence/fame/security/keys/index.d.ts.map +0 -1
  376. package/dist/types/naylence/fame/security/keys/x5c-key-manager-factory.d.ts +0 -19
  377. package/dist/types/naylence/fame/security/keys/x5c-key-manager-factory.d.ts.map +0 -1
  378. package/dist/types/naylence/fame/security/keys/x5c-key-manager.d.ts +0 -39
  379. package/dist/types/naylence/fame/security/keys/x5c-key-manager.d.ts.map +0 -1
  380. package/dist/types/naylence/fame/security/register-advanced-security-factories.d.ts +0 -8
  381. package/dist/types/naylence/fame/security/register-advanced-security-factories.d.ts.map +0 -1
  382. package/dist/types/naylence/fame/security/signing/eddsa-envelope-signer-factory.d.ts +0 -20
  383. package/dist/types/naylence/fame/security/signing/eddsa-envelope-signer-factory.d.ts.map +0 -1
  384. package/dist/types/naylence/fame/security/signing/eddsa-envelope-verifier-factory.d.ts +0 -21
  385. package/dist/types/naylence/fame/security/signing/eddsa-envelope-verifier-factory.d.ts.map +0 -1
  386. package/dist/types/naylence/fame/security/signing/eddsa-envelope-verifier.d.ts +0 -22
  387. package/dist/types/naylence/fame/security/signing/eddsa-envelope-verifier.d.ts.map +0 -1
  388. package/dist/types/naylence/fame/stickiness/aft-helper.d.ts +0 -29
  389. package/dist/types/naylence/fame/stickiness/aft-helper.d.ts.map +0 -1
  390. package/dist/types/naylence/fame/stickiness/aft-load-balancer-stickiness-manager-factory.d.ts +0 -25
  391. package/dist/types/naylence/fame/stickiness/aft-load-balancer-stickiness-manager-factory.d.ts.map +0 -1
  392. package/dist/types/naylence/fame/stickiness/aft-load-balancer-stickiness-manager.d.ts +0 -33
  393. package/dist/types/naylence/fame/stickiness/aft-load-balancer-stickiness-manager.d.ts.map +0 -1
  394. package/dist/types/naylence/fame/stickiness/aft-model.d.ts +0 -33
  395. package/dist/types/naylence/fame/stickiness/aft-model.d.ts.map +0 -1
  396. package/dist/types/naylence/fame/stickiness/aft-replica-stickiness-manager-factory.d.ts +0 -23
  397. package/dist/types/naylence/fame/stickiness/aft-replica-stickiness-manager-factory.d.ts.map +0 -1
  398. package/dist/types/naylence/fame/stickiness/aft-replica-stickiness-manager.d.ts +0 -31
  399. package/dist/types/naylence/fame/stickiness/aft-replica-stickiness-manager.d.ts.map +0 -1
  400. package/dist/types/naylence/fame/stickiness/aft-signer.d.ts +0 -55
  401. package/dist/types/naylence/fame/stickiness/aft-signer.d.ts.map +0 -1
  402. package/dist/types/naylence/fame/stickiness/aft-utils.d.ts +0 -4
  403. package/dist/types/naylence/fame/stickiness/aft-utils.d.ts.map +0 -1
  404. package/dist/types/naylence/fame/stickiness/aft-verifier.d.ts +0 -50
  405. package/dist/types/naylence/fame/stickiness/aft-verifier.d.ts.map +0 -1
  406. package/dist/types/naylence/fame/stickiness/index.d.ts +0 -15
  407. package/dist/types/naylence/fame/stickiness/index.d.ts.map +0 -1
  408. package/dist/types/naylence/fame/stickiness/stickiness-mode.d.ts +0 -7
  409. package/dist/types/naylence/fame/stickiness/stickiness-mode.d.ts.map +0 -1
  410. package/dist/types/naylence/fame/welcome/advanced-welcome-service-factory.d.ts +0 -21
  411. package/dist/types/naylence/fame/welcome/advanced-welcome-service-factory.d.ts.map +0 -1
  412. package/dist/types/naylence/fame/welcome/advanced-welcome-service.d.ts +0 -21
  413. package/dist/types/naylence/fame/welcome/advanced-welcome-service.d.ts.map +0 -1
  414. package/dist/types/naylence/fame/welcome/index.d.ts +0 -3
  415. package/dist/types/naylence/fame/welcome/index.d.ts.map +0 -1
  416. package/dist/types/node.d.ts +0 -11
  417. package/dist/types/node.d.ts.map +0 -1
  418. package/dist/types/plugin.d.ts +0 -11
  419. package/dist/types/plugin.d.ts.map +0 -1
  420. package/dist/types/version.d.ts +0 -6
  421. package/dist/types/version.d.ts.map +0 -1
@@ -1,405 +0,0 @@
1
- import { DeliveryOriginType, DefaultKeyManager, getKeyStore, getLogger, currentTraceId, validateJwkComplete, JWKValidationError, TaskSpawner, } from "@naylence/runtime";
2
- import { validateJwkX5cCertificate, } from "../cert/util.js";
3
- const logger = getLogger("naylence.fame.security.keys.x5c_key_manager");
4
- let x509ModulePromise = null;
5
- async function loadX509Module() {
6
- if (!x509ModulePromise) {
7
- x509ModulePromise = import("@peculiar/x509")
8
- .then((mod) => {
9
- if (mod && typeof mod.X509Certificate === "function") {
10
- return { X509Certificate: mod.X509Certificate };
11
- }
12
- return null;
13
- })
14
- .catch((error) => {
15
- logger.warning("certificate_module_unavailable", {
16
- error: error instanceof Error ? error.message : String(error),
17
- });
18
- return null;
19
- });
20
- }
21
- return x509ModulePromise;
22
- }
23
- function decodeBase64Cert(value) {
24
- if (typeof Buffer !== "undefined") {
25
- return Buffer.from(value, "base64");
26
- }
27
- const binary = atob(value);
28
- const bytes = new Uint8Array(binary.length);
29
- for (let i = 0; i < binary.length; i += 1) {
30
- bytes[i] = binary.charCodeAt(i);
31
- }
32
- return bytes;
33
- }
34
- export class X5CKeyManager extends TaskSpawner {
35
- constructor({ keyStore = null, certPurgeIntervalSeconds = 3600, } = {}) {
36
- super();
37
- this.priority = 1000;
38
- this.purgeTask = null;
39
- this.keyStore = keyStore ?? getKeyStore();
40
- this.inner = new DefaultKeyManager({ keyStore: this.keyStore });
41
- this.certPurgeInterval = certPurgeIntervalSeconds;
42
- }
43
- async onNodeStarted(node) {
44
- await this.inner.onNodeStarted(node);
45
- this.startPurgeLoop();
46
- logger.debug("x5c_key_manager_started", {
47
- cert_purge_interval: this.certPurgeInterval,
48
- });
49
- }
50
- async onNodeStopped(node) {
51
- logger.debug("x5c_key_manager_stopping");
52
- await this.shutdownTasks({ gracePeriod: 500, joinTimeout: 500 });
53
- this.purgeTask = null;
54
- await this.inner.onNodeStopped(node);
55
- logger.debug("x5c_key_manager_stopped");
56
- }
57
- async getKey(kid) {
58
- return this.inner.getKey(kid);
59
- }
60
- async hasKey(kid) {
61
- return this.inner.hasKey(kid);
62
- }
63
- async addKeys(options) {
64
- const { keys, sid, physicalPath, systemId, origin, skipSidValidation = false, } = options;
65
- const trustStore = resolveTrustStorePath();
66
- const enforceNameConstraints = true;
67
- const validKeys = [];
68
- let rejectedCount = 0;
69
- for (const key of keys) {
70
- try {
71
- validateJwkComplete(key);
72
- if (Array.isArray(key.x5c) && trustStore) {
73
- const validationResult = validateJwkX5cCertificateWrapper({
74
- jwk: key,
75
- trustStore,
76
- enforceNameConstraints,
77
- origin,
78
- systemId,
79
- physicalPath,
80
- });
81
- if (!validationResult.accepted) {
82
- rejectedCount += 1;
83
- if (validationResult.skip) {
84
- continue;
85
- }
86
- }
87
- }
88
- validKeys.push(key);
89
- }
90
- catch (error) {
91
- if (error instanceof JWKValidationError) {
92
- logger.warning("rejected_invalid_jwk_in_announce", {
93
- kid: typeof key?.kid === "string" ? key.kid : "unknown",
94
- from_system_id: systemId,
95
- from_physical_path: physicalPath,
96
- error: error.message,
97
- });
98
- rejectedCount += 1;
99
- continue;
100
- }
101
- throw error;
102
- }
103
- }
104
- if (validKeys.length === 0) {
105
- logger.warning("no_valid_keys_in_announce", {
106
- from_system_id: systemId,
107
- from_physical_path: physicalPath,
108
- total_keys: keys.length,
109
- rejected_count: rejectedCount,
110
- });
111
- return;
112
- }
113
- logger.debug("adding_keys", {
114
- key_ids: validKeys.map((key) => typeof key?.kid === "string" ? key.kid : "unknown"),
115
- source_system_id: systemId,
116
- from_physical_path: physicalPath,
117
- trace_id: currentTraceId(),
118
- origin,
119
- valid_count: validKeys.length,
120
- rejected_count: rejectedCount,
121
- });
122
- const hasEncryptionKeys = validKeys.some((key) => typeof key?.use === "string" && key.use === "enc");
123
- if (hasEncryptionKeys) {
124
- logger.debug("checking_for_old_encryption_keys_to_remove", {
125
- physical_path: physicalPath,
126
- origin,
127
- new_enc_keys: validKeys
128
- .filter((key) => typeof key?.use === "string" && key.use === "enc")
129
- .map((key) => (typeof key?.kid === "string" ? key.kid : "unknown")),
130
- });
131
- try {
132
- const grouped = await this.keyStore.getKeysGroupedByPath();
133
- const existingEncKeyIds = new Set();
134
- const pathsWithOldKeys = [];
135
- const physicalPathSuffix = `@${physicalPath}`;
136
- for (const [path, records] of Object.entries(grouped)) {
137
- if (path !== physicalPath && !path.endsWith(physicalPathSuffix)) {
138
- continue;
139
- }
140
- const encKeysAtPath = records.filter((record) => typeof record?.use === "string" && record.use === "enc");
141
- if (encKeysAtPath.length === 0) {
142
- continue;
143
- }
144
- pathsWithOldKeys.push(path);
145
- for (const record of encKeysAtPath) {
146
- if (typeof record?.kid === "string") {
147
- existingEncKeyIds.add(record.kid);
148
- }
149
- }
150
- }
151
- if (existingEncKeyIds.size > 0) {
152
- logger.debug("found_existing_encryption_keys_across_paths", {
153
- physical_path: physicalPath,
154
- paths_checked: pathsWithOldKeys,
155
- existing_enc_key_ids: Array.from(existingEncKeyIds),
156
- });
157
- const newEncKeyIds = new Set(validKeys
158
- .filter((key) => typeof key?.use === "string" && key.use === "enc")
159
- .map((key) => (typeof key?.kid === "string" ? key.kid : ""))
160
- .filter((kid) => kid.length > 0));
161
- const keysToRemove = Array.from(existingEncKeyIds).filter((kid) => !newEncKeyIds.has(kid));
162
- if (keysToRemove.length > 0) {
163
- logger.info("removing_old_encryption_keys_for_key_rotation", {
164
- physical_path: physicalPath,
165
- paths_with_old_keys: pathsWithOldKeys,
166
- old_key_ids: keysToRemove,
167
- new_key_ids: Array.from(newEncKeyIds),
168
- origin,
169
- });
170
- for (const kid of keysToRemove) {
171
- await this.keyStore.removeKey(kid);
172
- logger.debug("removed_old_encryption_key_from_all_paths", {
173
- kid,
174
- });
175
- }
176
- }
177
- }
178
- }
179
- catch (error) {
180
- logger.warning("failed_to_remove_old_encryption_keys", {
181
- physical_path: physicalPath,
182
- error: error instanceof Error ? error.message : String(error),
183
- origin,
184
- });
185
- }
186
- }
187
- const addKeyOptions = {
188
- keys: validKeys,
189
- physicalPath,
190
- systemId,
191
- origin,
192
- };
193
- if (skipSidValidation) {
194
- addKeyOptions.skipSidValidation = true;
195
- }
196
- if (typeof sid === "string") {
197
- addKeyOptions.sid = sid;
198
- }
199
- await this.inner.addKeys(addKeyOptions);
200
- }
201
- async announceKeysToUpstream() {
202
- await this.inner.announceKeysToUpstream();
203
- }
204
- async handleKeyRequest(options) {
205
- await this.inner.handleKeyRequest(options);
206
- }
207
- async removeKeysForPath(physicalPath) {
208
- return this.inner.removeKeysForPath(physicalPath);
209
- }
210
- async getKeysForPath(physicalPath) {
211
- return this.inner.getKeysForPath(physicalPath);
212
- }
213
- async purgeExpiredCertificates() {
214
- logger.debug("certificate_purge_starting");
215
- const module = await loadX509Module();
216
- if (!module) {
217
- logger.warning("certificate_purge_skipped", {
218
- reason: "x509_module_unavailable",
219
- });
220
- return 0;
221
- }
222
- const now = new Date();
223
- const keysGrouped = await this.keyStore.getKeysGroupedByPath();
224
- const keysToRemove = [];
225
- for (const keys of Object.values(keysGrouped)) {
226
- for (const key of keys) {
227
- const chain = key.x5c;
228
- if (!Array.isArray(chain) || chain.length === 0) {
229
- continue;
230
- }
231
- const [leaf] = chain;
232
- if (typeof leaf !== "string") {
233
- continue;
234
- }
235
- try {
236
- const raw = decodeBase64Cert(leaf);
237
- const cert = new module.X509Certificate(raw);
238
- const expiration = cert.notAfter;
239
- if (expiration && expiration.getTime() < now.getTime()) {
240
- logger.debug("expired_certificate_found", {
241
- kid: typeof key.kid === "string" ? key.kid : "unknown",
242
- physical_path: typeof key.physical_path === "string"
243
- ? key.physical_path
244
- : "unknown",
245
- expired_at: expiration.toISOString(),
246
- });
247
- if (typeof key.kid === "string") {
248
- const removal = {
249
- kid: key.kid,
250
- };
251
- if (typeof key.physical_path === "string") {
252
- removal.physicalPath = key.physical_path;
253
- }
254
- keysToRemove.push(removal);
255
- }
256
- }
257
- }
258
- catch (error) {
259
- logger.warning("certificate_parsing_failed_during_purge", {
260
- kid: typeof key.kid === "string" ? key.kid : "unknown",
261
- error: error instanceof Error ? error.message : String(error),
262
- message: "Could not parse certificate for expiry check",
263
- });
264
- }
265
- }
266
- }
267
- let purgedCount = 0;
268
- for (const keyInfo of keysToRemove) {
269
- try {
270
- const removed = await this.keyStore.removeKey(keyInfo.kid);
271
- if (removed) {
272
- purgedCount += 1;
273
- logger.debug("expired_certificate_purged", {
274
- kid: keyInfo.kid,
275
- physical_path: keyInfo.physicalPath ?? "unknown",
276
- });
277
- }
278
- }
279
- catch (error) {
280
- logger.error("certificate_purge_failed", {
281
- kid: keyInfo.kid,
282
- error: error instanceof Error ? error.message : String(error),
283
- });
284
- }
285
- }
286
- logger.debug("certificate_purge_completed", {
287
- purged_count: purgedCount,
288
- });
289
- return purgedCount;
290
- }
291
- startPurgeLoop() {
292
- if (this.purgeTask) {
293
- return;
294
- }
295
- this.purgeTask = this.spawn(async (signal) => {
296
- logger.debug("certificate_purge_loop_started", {
297
- interval_seconds: this.certPurgeInterval,
298
- });
299
- try {
300
- while (!signal?.aborted) {
301
- const waitPromise = new Promise((resolve) => {
302
- const timeout = setTimeout(() => resolve(), this.certPurgeInterval * 1000);
303
- if (signal) {
304
- signal.addEventListener("abort", () => {
305
- clearTimeout(timeout);
306
- resolve();
307
- }, { once: true });
308
- }
309
- });
310
- await waitPromise;
311
- if (signal?.aborted) {
312
- break;
313
- }
314
- try {
315
- const purged = await this.purgeExpiredCertificates();
316
- if (purged > 0) {
317
- logger.debug("certificate_purge_cycle_completed", {
318
- purged_count: purged,
319
- });
320
- }
321
- }
322
- catch (error) {
323
- logger.error("certificate_purge_cycle_failed", {
324
- error: error instanceof Error ? error.message : String(error),
325
- });
326
- }
327
- }
328
- }
329
- catch (error) {
330
- if (signal?.aborted) {
331
- logger.debug("certificate_purge_loop_cancelled");
332
- }
333
- else {
334
- logger.error("certificate_purge_loop_failed", {
335
- error: error instanceof Error ? error.message : String(error),
336
- });
337
- }
338
- }
339
- finally {
340
- logger.debug("certificate_purge_loop_stopped");
341
- }
342
- }, { name: "cert-purge" });
343
- }
344
- }
345
- function validateJwkX5cCertificateWrapper(options) {
346
- const { jwk, trustStore, enforceNameConstraints, origin, systemId, physicalPath, } = options;
347
- let result;
348
- try {
349
- result = validateJwkX5cCertificate({
350
- jwk,
351
- trustStorePem: trustStore,
352
- enforceNameConstraints,
353
- strict: false,
354
- });
355
- }
356
- catch (error) {
357
- logger.warning("rejected_key_due_to_certificate_validation_failure", {
358
- kid: typeof jwk.kid === "string" ? jwk.kid : "unknown",
359
- from_system_id: systemId,
360
- from_physical_path: physicalPath,
361
- origin,
362
- error: error instanceof Error ? error.message : String(error),
363
- scenario: "node_attach",
364
- });
365
- return {
366
- accepted: false,
367
- skip: origin === DeliveryOriginType.DOWNSTREAM ||
368
- origin === DeliveryOriginType.UPSTREAM,
369
- };
370
- }
371
- if (result.isValid) {
372
- return { accepted: true, skip: false };
373
- }
374
- logger.warning("rejected_key_due_to_certificate_validation_failure", {
375
- kid: typeof jwk.kid === "string" ? jwk.kid : "unknown",
376
- from_system_id: systemId,
377
- from_physical_path: physicalPath,
378
- origin,
379
- error: result.error ?? "unknown",
380
- scenario: "node_attach",
381
- });
382
- return {
383
- accepted: false,
384
- skip: origin === DeliveryOriginType.DOWNSTREAM ||
385
- origin === DeliveryOriginType.UPSTREAM,
386
- };
387
- }
388
- function resolveTrustStorePath() {
389
- try {
390
- if (typeof process === "undefined" || !process.env) {
391
- return null;
392
- }
393
- if (process.env.FAME_TRUST_STORE_PATH) {
394
- return process.env.FAME_TRUST_STORE_PATH;
395
- }
396
- return process.env.FAME_CA_CERT_FILE ?? null;
397
- }
398
- catch (error) {
399
- logger.debug("trust_store_resolution_failed", {
400
- error: error instanceof Error ? error.message : String(error),
401
- });
402
- return null;
403
- }
404
- }
405
- //# sourceMappingURL=x5c-key-manager.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"x5c-key-manager.js","sourceRoot":"","sources":["../../../../../../src/naylence/fame/security/keys/x5c-key-manager.ts"],"names":[],"mappings":"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"}