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

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/dist/browser/index.cjs +9867 -0
  2. package/dist/browser/index.mjs +9814 -0
  3. package/dist/cjs/advanced-security-isomorphic.js +82 -0
  4. package/dist/cjs/advanced-security-isomorphic.js.map +1 -0
  5. package/dist/cjs/browser.js +25 -0
  6. package/dist/cjs/browser.js.map +1 -0
  7. package/dist/cjs/index.js +2 -0
  8. package/dist/cjs/index.js.map +1 -0
  9. package/dist/cjs/install-env.js +2 -0
  10. package/dist/cjs/install-env.js.map +1 -0
  11. package/dist/cjs/naylence/fame/factory-manifest.js +39 -0
  12. package/dist/cjs/naylence/fame/factory-manifest.js.map +1 -0
  13. package/dist/cjs/naylence/fame/security/cert/browser-csr.js +103 -0
  14. package/dist/cjs/naylence/fame/security/cert/browser-csr.js.map +1 -0
  15. package/dist/cjs/naylence/fame/security/cert/ca-server-cli.js +30 -0
  16. package/dist/cjs/naylence/fame/security/cert/ca-server-cli.js.map +1 -0
  17. package/dist/cjs/naylence/fame/security/cert/ca-server.js +223 -0
  18. package/dist/cjs/naylence/fame/security/cert/ca-server.js.map +1 -0
  19. package/dist/cjs/naylence/fame/security/cert/ca-service-client.js +585 -0
  20. package/dist/cjs/naylence/fame/security/cert/ca-service-client.js.map +1 -0
  21. package/dist/cjs/naylence/fame/security/cert/ca-service-factory.js +61 -0
  22. package/dist/cjs/naylence/fame/security/cert/ca-service-factory.js.map +1 -0
  23. package/dist/cjs/naylence/fame/security/cert/ca-types.js +39 -0
  24. package/dist/cjs/naylence/fame/security/cert/ca-types.js.map +1 -0
  25. package/dist/cjs/naylence/fame/security/cert/csr-types.js +2 -0
  26. package/dist/cjs/naylence/fame/security/cert/csr-types.js.map +1 -0
  27. package/dist/cjs/naylence/fame/security/cert/default-ca-service-factory.js +66 -0
  28. package/dist/cjs/naylence/fame/security/cert/default-ca-service-factory.js.map +1 -0
  29. package/dist/cjs/naylence/fame/security/cert/default-ca-service.js +364 -0
  30. package/dist/cjs/naylence/fame/security/cert/default-ca-service.js.map +1 -0
  31. package/dist/cjs/naylence/fame/security/cert/default-certificate-manager-factory.js +73 -0
  32. package/dist/cjs/naylence/fame/security/cert/default-certificate-manager-factory.js.map +1 -0
  33. package/dist/cjs/naylence/fame/security/cert/default-certificate-manager.js +815 -0
  34. package/dist/cjs/naylence/fame/security/cert/default-certificate-manager.js.map +1 -0
  35. package/dist/cjs/naylence/fame/security/cert/grants.js +2 -0
  36. package/dist/cjs/naylence/fame/security/cert/grants.js.map +1 -0
  37. package/dist/cjs/naylence/fame/security/cert/index.js +18 -0
  38. package/dist/cjs/naylence/fame/security/cert/index.js.map +1 -0
  39. package/dist/cjs/naylence/fame/security/cert/internal-ca-service.js +741 -0
  40. package/dist/cjs/naylence/fame/security/cert/internal-ca-service.js.map +1 -0
  41. package/dist/cjs/naylence/fame/security/cert/node-ed25519-csr.js +156 -0
  42. package/dist/cjs/naylence/fame/security/cert/node-ed25519-csr.js.map +1 -0
  43. package/dist/cjs/naylence/fame/security/cert/oid-constants.js +7 -0
  44. package/dist/cjs/naylence/fame/security/cert/oid-constants.js.map +1 -0
  45. package/dist/cjs/naylence/fame/security/cert/trust-store/anchor-utils.js +119 -0
  46. package/dist/cjs/naylence/fame/security/cert/trust-store/anchor-utils.js.map +1 -0
  47. package/dist/cjs/naylence/fame/security/cert/trust-store/browser-trust-store-provider-factory.js +82 -0
  48. package/dist/cjs/naylence/fame/security/cert/trust-store/browser-trust-store-provider-factory.js.map +1 -0
  49. package/dist/cjs/naylence/fame/security/cert/trust-store/env-provider.js +168 -0
  50. package/dist/cjs/naylence/fame/security/cert/trust-store/env-provider.js.map +1 -0
  51. package/dist/cjs/naylence/fame/security/cert/trust-store/fame-ca-certs-parser.js +257 -0
  52. package/dist/cjs/naylence/fame/security/cert/trust-store/fame-ca-certs-parser.js.map +1 -0
  53. package/dist/cjs/naylence/fame/security/cert/trust-store/http-bundle-provider.js +497 -0
  54. package/dist/cjs/naylence/fame/security/cert/trust-store/http-bundle-provider.js.map +1 -0
  55. package/dist/cjs/naylence/fame/security/cert/trust-store/http-signed-bundle-provider.js +2 -0
  56. package/dist/cjs/naylence/fame/security/cert/trust-store/http-signed-bundle-provider.js.map +1 -0
  57. package/dist/cjs/naylence/fame/security/cert/trust-store/node-trust-store-provider-factory.js +61 -0
  58. package/dist/cjs/naylence/fame/security/cert/trust-store/node-trust-store-provider-factory.js.map +1 -0
  59. package/dist/cjs/naylence/fame/security/cert/trust-store/static-bundle-provider.js +44 -0
  60. package/dist/cjs/naylence/fame/security/cert/trust-store/static-bundle-provider.js.map +1 -0
  61. package/dist/cjs/naylence/fame/security/cert/trust-store/trust-store-provider-factory.js +40 -0
  62. package/dist/cjs/naylence/fame/security/cert/trust-store/trust-store-provider-factory.js.map +1 -0
  63. package/dist/cjs/naylence/fame/security/cert/trust-store/trust-store-provider.js +2 -0
  64. package/dist/cjs/naylence/fame/security/cert/trust-store/trust-store-provider.js.map +1 -0
  65. package/dist/cjs/naylence/fame/security/cert/util.js +515 -0
  66. package/dist/cjs/naylence/fame/security/cert/util.js.map +1 -0
  67. package/dist/cjs/naylence/fame/security/encryption/channel/channel-encryption-manager-factory.js +85 -0
  68. package/dist/cjs/naylence/fame/security/encryption/channel/channel-encryption-manager-factory.js.map +1 -0
  69. package/dist/cjs/naylence/fame/security/encryption/channel/channel-encryption-manager.js +743 -0
  70. package/dist/cjs/naylence/fame/security/encryption/channel/channel-encryption-manager.js.map +1 -0
  71. package/dist/cjs/naylence/fame/security/encryption/channel/index.js +3 -0
  72. package/dist/cjs/naylence/fame/security/encryption/channel/index.js.map +1 -0
  73. package/dist/cjs/naylence/fame/security/encryption/composite-encryption-manager-factory.js +113 -0
  74. package/dist/cjs/naylence/fame/security/encryption/composite-encryption-manager-factory.js.map +1 -0
  75. package/dist/cjs/naylence/fame/security/encryption/composite-encryption-manager.js +321 -0
  76. package/dist/cjs/naylence/fame/security/encryption/composite-encryption-manager.js.map +1 -0
  77. package/dist/cjs/naylence/fame/security/encryption/default-secure-channel-manager-factory.js +53 -0
  78. package/dist/cjs/naylence/fame/security/encryption/default-secure-channel-manager-factory.js.map +1 -0
  79. package/dist/cjs/naylence/fame/security/encryption/default-secure-channel-manager.js +278 -0
  80. package/dist/cjs/naylence/fame/security/encryption/default-secure-channel-manager.js.map +1 -0
  81. package/dist/cjs/naylence/fame/security/encryption/encryption-manager-registry.js +167 -0
  82. package/dist/cjs/naylence/fame/security/encryption/encryption-manager-registry.js.map +1 -0
  83. package/dist/cjs/naylence/fame/security/encryption/index.js +7 -0
  84. package/dist/cjs/naylence/fame/security/encryption/index.js.map +1 -0
  85. package/dist/cjs/naylence/fame/security/encryption/sealed/index.js +3 -0
  86. package/dist/cjs/naylence/fame/security/encryption/sealed/index.js.map +1 -0
  87. package/dist/cjs/naylence/fame/security/encryption/sealed/x25519-encryption-manager-factory.js +82 -0
  88. package/dist/cjs/naylence/fame/security/encryption/sealed/x25519-encryption-manager-factory.js.map +1 -0
  89. package/dist/cjs/naylence/fame/security/encryption/sealed/x25519-encryption-manager.js +542 -0
  90. package/dist/cjs/naylence/fame/security/encryption/sealed/x25519-encryption-manager.js.map +1 -0
  91. package/dist/cjs/naylence/fame/security/index.js +6 -0
  92. package/dist/cjs/naylence/fame/security/index.js.map +1 -0
  93. package/dist/cjs/naylence/fame/security/keys/index.js +3 -0
  94. package/dist/cjs/naylence/fame/security/keys/index.js.map +1 -0
  95. package/dist/cjs/naylence/fame/security/keys/x5c-key-manager-factory.js +36 -0
  96. package/dist/cjs/naylence/fame/security/keys/x5c-key-manager-factory.js.map +1 -0
  97. package/dist/cjs/naylence/fame/security/keys/x5c-key-manager.js +405 -0
  98. package/dist/cjs/naylence/fame/security/keys/x5c-key-manager.js.map +1 -0
  99. package/dist/cjs/naylence/fame/security/register-advanced-security-factories.js +286 -0
  100. package/dist/cjs/naylence/fame/security/register-advanced-security-factories.js.map +1 -0
  101. package/dist/cjs/naylence/fame/security/signing/eddsa-envelope-signer-factory.js +34 -0
  102. package/dist/cjs/naylence/fame/security/signing/eddsa-envelope-signer-factory.js.map +1 -0
  103. package/dist/cjs/naylence/fame/security/signing/eddsa-envelope-verifier-factory.js +33 -0
  104. package/dist/cjs/naylence/fame/security/signing/eddsa-envelope-verifier-factory.js.map +1 -0
  105. package/dist/cjs/naylence/fame/security/signing/eddsa-envelope-verifier.js +189 -0
  106. package/dist/cjs/naylence/fame/security/signing/eddsa-envelope-verifier.js.map +1 -0
  107. package/dist/cjs/naylence/fame/stickiness/aft-helper.js +72 -0
  108. package/dist/cjs/naylence/fame/stickiness/aft-helper.js.map +1 -0
  109. package/dist/cjs/naylence/fame/stickiness/aft-load-balancer-stickiness-manager-factory.js +65 -0
  110. package/dist/cjs/naylence/fame/stickiness/aft-load-balancer-stickiness-manager-factory.js.map +1 -0
  111. package/dist/cjs/naylence/fame/stickiness/aft-load-balancer-stickiness-manager.js +447 -0
  112. package/dist/cjs/naylence/fame/stickiness/aft-load-balancer-stickiness-manager.js.map +1 -0
  113. package/dist/cjs/naylence/fame/stickiness/aft-model.js +54 -0
  114. package/dist/cjs/naylence/fame/stickiness/aft-model.js.map +1 -0
  115. package/dist/cjs/naylence/fame/stickiness/aft-replica-stickiness-manager-factory.js +50 -0
  116. package/dist/cjs/naylence/fame/stickiness/aft-replica-stickiness-manager-factory.js.map +1 -0
  117. package/dist/cjs/naylence/fame/stickiness/aft-replica-stickiness-manager.js +203 -0
  118. package/dist/cjs/naylence/fame/stickiness/aft-replica-stickiness-manager.js.map +1 -0
  119. package/dist/cjs/naylence/fame/stickiness/aft-signer.js +147 -0
  120. package/dist/cjs/naylence/fame/stickiness/aft-signer.js.map +1 -0
  121. package/dist/cjs/naylence/fame/stickiness/aft-utils.js +90 -0
  122. package/dist/cjs/naylence/fame/stickiness/aft-utils.js.map +1 -0
  123. package/dist/cjs/naylence/fame/stickiness/aft-verifier.js +290 -0
  124. package/dist/cjs/naylence/fame/stickiness/aft-verifier.js.map +1 -0
  125. package/dist/cjs/naylence/fame/stickiness/index.js +11 -0
  126. package/dist/cjs/naylence/fame/stickiness/index.js.map +1 -0
  127. package/dist/cjs/naylence/fame/stickiness/stickiness-mode.js +24 -0
  128. package/dist/cjs/naylence/fame/stickiness/stickiness-mode.js.map +1 -0
  129. package/dist/cjs/naylence/fame/welcome/advanced-welcome-service-factory.js +93 -0
  130. package/dist/cjs/naylence/fame/welcome/advanced-welcome-service-factory.js.map +1 -0
  131. package/dist/cjs/naylence/fame/welcome/advanced-welcome-service.js +212 -0
  132. package/dist/cjs/naylence/fame/welcome/advanced-welcome-service.js.map +1 -0
  133. package/dist/cjs/naylence/fame/welcome/index.js +3 -0
  134. package/dist/cjs/naylence/fame/welcome/index.js.map +1 -0
  135. package/dist/cjs/node.js +11 -0
  136. package/dist/cjs/node.js.map +1 -0
  137. package/dist/cjs/plugin.js +39 -0
  138. package/dist/cjs/plugin.js.map +1 -0
  139. package/dist/cjs/version.js +8 -0
  140. package/dist/cjs/version.js.map +1 -0
  141. package/dist/esm/advanced-security-isomorphic.js +82 -0
  142. package/dist/esm/advanced-security-isomorphic.js.map +1 -0
  143. package/dist/esm/browser.js +25 -0
  144. package/dist/esm/browser.js.map +1 -0
  145. package/dist/esm/index.js +2 -0
  146. package/dist/esm/index.js.map +1 -0
  147. package/dist/esm/install-env.js +2 -0
  148. package/dist/esm/install-env.js.map +1 -0
  149. package/dist/esm/naylence/fame/factory-manifest.js +39 -0
  150. package/dist/esm/naylence/fame/factory-manifest.js.map +1 -0
  151. package/dist/esm/naylence/fame/security/cert/browser-csr.js +103 -0
  152. package/dist/esm/naylence/fame/security/cert/browser-csr.js.map +1 -0
  153. package/dist/esm/naylence/fame/security/cert/ca-server-cli.js +30 -0
  154. package/dist/esm/naylence/fame/security/cert/ca-server-cli.js.map +1 -0
  155. package/dist/esm/naylence/fame/security/cert/ca-server.js +223 -0
  156. package/dist/esm/naylence/fame/security/cert/ca-server.js.map +1 -0
  157. package/dist/esm/naylence/fame/security/cert/ca-service-client.js +585 -0
  158. package/dist/esm/naylence/fame/security/cert/ca-service-client.js.map +1 -0
  159. package/dist/esm/naylence/fame/security/cert/ca-service-factory.js +61 -0
  160. package/dist/esm/naylence/fame/security/cert/ca-service-factory.js.map +1 -0
  161. package/dist/esm/naylence/fame/security/cert/ca-types.js +39 -0
  162. package/dist/esm/naylence/fame/security/cert/ca-types.js.map +1 -0
  163. package/dist/esm/naylence/fame/security/cert/csr-types.js +2 -0
  164. package/dist/esm/naylence/fame/security/cert/csr-types.js.map +1 -0
  165. package/dist/esm/naylence/fame/security/cert/default-ca-service-factory.js +66 -0
  166. package/dist/esm/naylence/fame/security/cert/default-ca-service-factory.js.map +1 -0
  167. package/dist/esm/naylence/fame/security/cert/default-ca-service.js +364 -0
  168. package/dist/esm/naylence/fame/security/cert/default-ca-service.js.map +1 -0
  169. package/dist/esm/naylence/fame/security/cert/default-certificate-manager-factory.js +73 -0
  170. package/dist/esm/naylence/fame/security/cert/default-certificate-manager-factory.js.map +1 -0
  171. package/dist/esm/naylence/fame/security/cert/default-certificate-manager.js +815 -0
  172. package/dist/esm/naylence/fame/security/cert/default-certificate-manager.js.map +1 -0
  173. package/dist/esm/naylence/fame/security/cert/grants.js +2 -0
  174. package/dist/esm/naylence/fame/security/cert/grants.js.map +1 -0
  175. package/dist/esm/naylence/fame/security/cert/index.js +18 -0
  176. package/dist/esm/naylence/fame/security/cert/index.js.map +1 -0
  177. package/dist/esm/naylence/fame/security/cert/internal-ca-service.js +741 -0
  178. package/dist/esm/naylence/fame/security/cert/internal-ca-service.js.map +1 -0
  179. package/dist/esm/naylence/fame/security/cert/node-ed25519-csr.js +156 -0
  180. package/dist/esm/naylence/fame/security/cert/node-ed25519-csr.js.map +1 -0
  181. package/dist/esm/naylence/fame/security/cert/oid-constants.js +7 -0
  182. package/dist/esm/naylence/fame/security/cert/oid-constants.js.map +1 -0
  183. package/dist/esm/naylence/fame/security/cert/trust-store/anchor-utils.js +119 -0
  184. package/dist/esm/naylence/fame/security/cert/trust-store/anchor-utils.js.map +1 -0
  185. package/dist/esm/naylence/fame/security/cert/trust-store/browser-trust-store-provider-factory.js +82 -0
  186. package/dist/esm/naylence/fame/security/cert/trust-store/browser-trust-store-provider-factory.js.map +1 -0
  187. package/dist/esm/naylence/fame/security/cert/trust-store/env-provider.js +168 -0
  188. package/dist/esm/naylence/fame/security/cert/trust-store/env-provider.js.map +1 -0
  189. package/dist/esm/naylence/fame/security/cert/trust-store/fame-ca-certs-parser.js +257 -0
  190. package/dist/esm/naylence/fame/security/cert/trust-store/fame-ca-certs-parser.js.map +1 -0
  191. package/dist/esm/naylence/fame/security/cert/trust-store/http-bundle-provider.js +497 -0
  192. package/dist/esm/naylence/fame/security/cert/trust-store/http-bundle-provider.js.map +1 -0
  193. package/dist/esm/naylence/fame/security/cert/trust-store/http-signed-bundle-provider.js +2 -0
  194. package/dist/esm/naylence/fame/security/cert/trust-store/http-signed-bundle-provider.js.map +1 -0
  195. package/dist/esm/naylence/fame/security/cert/trust-store/node-trust-store-provider-factory.js +61 -0
  196. package/dist/esm/naylence/fame/security/cert/trust-store/node-trust-store-provider-factory.js.map +1 -0
  197. package/dist/esm/naylence/fame/security/cert/trust-store/static-bundle-provider.js +44 -0
  198. package/dist/esm/naylence/fame/security/cert/trust-store/static-bundle-provider.js.map +1 -0
  199. package/dist/esm/naylence/fame/security/cert/trust-store/trust-store-provider-factory.js +40 -0
  200. package/dist/esm/naylence/fame/security/cert/trust-store/trust-store-provider-factory.js.map +1 -0
  201. package/dist/esm/naylence/fame/security/cert/trust-store/trust-store-provider.js +2 -0
  202. package/dist/esm/naylence/fame/security/cert/trust-store/trust-store-provider.js.map +1 -0
  203. package/dist/esm/naylence/fame/security/cert/util.js +515 -0
  204. package/dist/esm/naylence/fame/security/cert/util.js.map +1 -0
  205. package/dist/esm/naylence/fame/security/encryption/channel/channel-encryption-manager-factory.js +85 -0
  206. package/dist/esm/naylence/fame/security/encryption/channel/channel-encryption-manager-factory.js.map +1 -0
  207. package/dist/esm/naylence/fame/security/encryption/channel/channel-encryption-manager.js +743 -0
  208. package/dist/esm/naylence/fame/security/encryption/channel/channel-encryption-manager.js.map +1 -0
  209. package/dist/esm/naylence/fame/security/encryption/channel/index.js +3 -0
  210. package/dist/esm/naylence/fame/security/encryption/channel/index.js.map +1 -0
  211. package/dist/esm/naylence/fame/security/encryption/composite-encryption-manager-factory.js +113 -0
  212. package/dist/esm/naylence/fame/security/encryption/composite-encryption-manager-factory.js.map +1 -0
  213. package/dist/esm/naylence/fame/security/encryption/composite-encryption-manager.js +321 -0
  214. package/dist/esm/naylence/fame/security/encryption/composite-encryption-manager.js.map +1 -0
  215. package/dist/esm/naylence/fame/security/encryption/default-secure-channel-manager-factory.js +53 -0
  216. package/dist/esm/naylence/fame/security/encryption/default-secure-channel-manager-factory.js.map +1 -0
  217. package/dist/esm/naylence/fame/security/encryption/default-secure-channel-manager.js +278 -0
  218. package/dist/esm/naylence/fame/security/encryption/default-secure-channel-manager.js.map +1 -0
  219. package/dist/esm/naylence/fame/security/encryption/encryption-manager-registry.js +167 -0
  220. package/dist/esm/naylence/fame/security/encryption/encryption-manager-registry.js.map +1 -0
  221. package/dist/esm/naylence/fame/security/encryption/index.js +7 -0
  222. package/dist/esm/naylence/fame/security/encryption/index.js.map +1 -0
  223. package/dist/esm/naylence/fame/security/encryption/sealed/index.js +3 -0
  224. package/dist/esm/naylence/fame/security/encryption/sealed/index.js.map +1 -0
  225. package/dist/esm/naylence/fame/security/encryption/sealed/x25519-encryption-manager-factory.js +82 -0
  226. package/dist/esm/naylence/fame/security/encryption/sealed/x25519-encryption-manager-factory.js.map +1 -0
  227. package/dist/esm/naylence/fame/security/encryption/sealed/x25519-encryption-manager.js +542 -0
  228. package/dist/esm/naylence/fame/security/encryption/sealed/x25519-encryption-manager.js.map +1 -0
  229. package/dist/esm/naylence/fame/security/index.js +6 -0
  230. package/dist/esm/naylence/fame/security/index.js.map +1 -0
  231. package/dist/esm/naylence/fame/security/keys/index.js +3 -0
  232. package/dist/esm/naylence/fame/security/keys/index.js.map +1 -0
  233. package/dist/esm/naylence/fame/security/keys/x5c-key-manager-factory.js +36 -0
  234. package/dist/esm/naylence/fame/security/keys/x5c-key-manager-factory.js.map +1 -0
  235. package/dist/esm/naylence/fame/security/keys/x5c-key-manager.js +405 -0
  236. package/dist/esm/naylence/fame/security/keys/x5c-key-manager.js.map +1 -0
  237. package/dist/esm/naylence/fame/security/register-advanced-security-factories.js +286 -0
  238. package/dist/esm/naylence/fame/security/register-advanced-security-factories.js.map +1 -0
  239. package/dist/esm/naylence/fame/security/signing/eddsa-envelope-signer-factory.js +34 -0
  240. package/dist/esm/naylence/fame/security/signing/eddsa-envelope-signer-factory.js.map +1 -0
  241. package/dist/esm/naylence/fame/security/signing/eddsa-envelope-verifier-factory.js +33 -0
  242. package/dist/esm/naylence/fame/security/signing/eddsa-envelope-verifier-factory.js.map +1 -0
  243. package/dist/esm/naylence/fame/security/signing/eddsa-envelope-verifier.js +189 -0
  244. package/dist/esm/naylence/fame/security/signing/eddsa-envelope-verifier.js.map +1 -0
  245. package/dist/esm/naylence/fame/stickiness/aft-helper.js +72 -0
  246. package/dist/esm/naylence/fame/stickiness/aft-helper.js.map +1 -0
  247. package/dist/esm/naylence/fame/stickiness/aft-load-balancer-stickiness-manager-factory.js +65 -0
  248. package/dist/esm/naylence/fame/stickiness/aft-load-balancer-stickiness-manager-factory.js.map +1 -0
  249. package/dist/esm/naylence/fame/stickiness/aft-load-balancer-stickiness-manager.js +447 -0
  250. package/dist/esm/naylence/fame/stickiness/aft-load-balancer-stickiness-manager.js.map +1 -0
  251. package/dist/esm/naylence/fame/stickiness/aft-model.js +54 -0
  252. package/dist/esm/naylence/fame/stickiness/aft-model.js.map +1 -0
  253. package/dist/esm/naylence/fame/stickiness/aft-replica-stickiness-manager-factory.js +50 -0
  254. package/dist/esm/naylence/fame/stickiness/aft-replica-stickiness-manager-factory.js.map +1 -0
  255. package/dist/esm/naylence/fame/stickiness/aft-replica-stickiness-manager.js +203 -0
  256. package/dist/esm/naylence/fame/stickiness/aft-replica-stickiness-manager.js.map +1 -0
  257. package/dist/esm/naylence/fame/stickiness/aft-signer.js +147 -0
  258. package/dist/esm/naylence/fame/stickiness/aft-signer.js.map +1 -0
  259. package/dist/esm/naylence/fame/stickiness/aft-utils.js +90 -0
  260. package/dist/esm/naylence/fame/stickiness/aft-utils.js.map +1 -0
  261. package/dist/esm/naylence/fame/stickiness/aft-verifier.js +290 -0
  262. package/dist/esm/naylence/fame/stickiness/aft-verifier.js.map +1 -0
  263. package/dist/esm/naylence/fame/stickiness/index.js +11 -0
  264. package/dist/esm/naylence/fame/stickiness/index.js.map +1 -0
  265. package/dist/esm/naylence/fame/stickiness/stickiness-mode.js +24 -0
  266. package/dist/esm/naylence/fame/stickiness/stickiness-mode.js.map +1 -0
  267. package/dist/esm/naylence/fame/welcome/advanced-welcome-service-factory.js +93 -0
  268. package/dist/esm/naylence/fame/welcome/advanced-welcome-service-factory.js.map +1 -0
  269. package/dist/esm/naylence/fame/welcome/advanced-welcome-service.js +212 -0
  270. package/dist/esm/naylence/fame/welcome/advanced-welcome-service.js.map +1 -0
  271. package/dist/esm/naylence/fame/welcome/index.js +3 -0
  272. package/dist/esm/naylence/fame/welcome/index.js.map +1 -0
  273. package/dist/esm/node.js +11 -0
  274. package/dist/esm/node.js.map +1 -0
  275. package/dist/esm/plugin.js +39 -0
  276. package/dist/esm/plugin.js.map +1 -0
  277. package/dist/esm/version.js +8 -0
  278. package/dist/esm/version.js.map +1 -0
  279. package/dist/node/index.cjs +9858 -0
  280. package/dist/node/index.mjs +9803 -0
  281. package/dist/node/node.cjs +10142 -0
  282. package/dist/node/node.mjs +10049 -0
  283. package/dist/types/advanced-security-isomorphic.d.ts +24 -0
  284. package/dist/types/advanced-security-isomorphic.d.ts.map +1 -0
  285. package/dist/types/browser.d.ts +19 -0
  286. package/dist/types/browser.d.ts.map +1 -0
  287. package/dist/types/index.d.ts +2 -0
  288. package/dist/types/index.d.ts.map +1 -0
  289. package/dist/types/install-env.d.ts +3 -0
  290. package/dist/types/install-env.d.ts.map +1 -0
  291. package/dist/types/naylence/fame/factory-manifest.d.ts +11 -0
  292. package/dist/types/naylence/fame/factory-manifest.d.ts.map +1 -0
  293. package/dist/types/naylence/fame/security/cert/browser-csr.d.ts +9 -0
  294. package/dist/types/naylence/fame/security/cert/browser-csr.d.ts.map +1 -0
  295. package/dist/types/naylence/fame/security/cert/ca-server-cli.d.ts +3 -0
  296. package/dist/types/naylence/fame/security/cert/ca-server-cli.d.ts.map +1 -0
  297. package/dist/types/naylence/fame/security/cert/ca-server.d.ts +19 -0
  298. package/dist/types/naylence/fame/security/cert/ca-server.d.ts.map +1 -0
  299. package/dist/types/naylence/fame/security/cert/ca-service-client.d.ts +75 -0
  300. package/dist/types/naylence/fame/security/cert/ca-service-client.d.ts.map +1 -0
  301. package/dist/types/naylence/fame/security/cert/ca-service-factory.d.ts +43 -0
  302. package/dist/types/naylence/fame/security/cert/ca-service-factory.d.ts.map +1 -0
  303. package/dist/types/naylence/fame/security/cert/ca-types.d.ts +129 -0
  304. package/dist/types/naylence/fame/security/cert/ca-types.d.ts.map +1 -0
  305. package/dist/types/naylence/fame/security/cert/csr-types.d.ts +5 -0
  306. package/dist/types/naylence/fame/security/cert/csr-types.d.ts.map +1 -0
  307. package/dist/types/naylence/fame/security/cert/default-ca-service-factory.d.ts +55 -0
  308. package/dist/types/naylence/fame/security/cert/default-ca-service-factory.d.ts.map +1 -0
  309. package/dist/types/naylence/fame/security/cert/default-ca-service.d.ts +85 -0
  310. package/dist/types/naylence/fame/security/cert/default-ca-service.d.ts.map +1 -0
  311. package/dist/types/naylence/fame/security/cert/default-certificate-manager-factory.d.ts +25 -0
  312. package/dist/types/naylence/fame/security/cert/default-certificate-manager-factory.d.ts.map +1 -0
  313. package/dist/types/naylence/fame/security/cert/default-certificate-manager.d.ts +70 -0
  314. package/dist/types/naylence/fame/security/cert/default-certificate-manager.d.ts.map +1 -0
  315. package/dist/types/naylence/fame/security/cert/grants.d.ts +2 -0
  316. package/dist/types/naylence/fame/security/cert/grants.d.ts.map +1 -0
  317. package/dist/types/naylence/fame/security/cert/index.d.ts +19 -0
  318. package/dist/types/naylence/fame/security/cert/index.d.ts.map +1 -0
  319. package/dist/types/naylence/fame/security/cert/internal-ca-service.d.ts +129 -0
  320. package/dist/types/naylence/fame/security/cert/internal-ca-service.d.ts.map +1 -0
  321. package/dist/types/naylence/fame/security/cert/node-ed25519-csr.d.ts +9 -0
  322. package/dist/types/naylence/fame/security/cert/node-ed25519-csr.d.ts.map +1 -0
  323. package/dist/types/naylence/fame/security/cert/oid-constants.d.ts +7 -0
  324. package/dist/types/naylence/fame/security/cert/oid-constants.d.ts.map +1 -0
  325. package/dist/types/naylence/fame/security/cert/trust-store/anchor-utils.d.ts +12 -0
  326. package/dist/types/naylence/fame/security/cert/trust-store/anchor-utils.d.ts.map +1 -0
  327. package/dist/types/naylence/fame/security/cert/trust-store/browser-trust-store-provider-factory.d.ts +29 -0
  328. package/dist/types/naylence/fame/security/cert/trust-store/browser-trust-store-provider-factory.d.ts.map +1 -0
  329. package/dist/types/naylence/fame/security/cert/trust-store/env-provider.d.ts +7 -0
  330. package/dist/types/naylence/fame/security/cert/trust-store/env-provider.d.ts.map +1 -0
  331. package/dist/types/naylence/fame/security/cert/trust-store/fame-ca-certs-parser.d.ts +9 -0
  332. package/dist/types/naylence/fame/security/cert/trust-store/fame-ca-certs-parser.d.ts.map +1 -0
  333. package/dist/types/naylence/fame/security/cert/trust-store/http-bundle-provider.d.ts +35 -0
  334. package/dist/types/naylence/fame/security/cert/trust-store/http-bundle-provider.d.ts.map +1 -0
  335. package/dist/types/naylence/fame/security/cert/trust-store/http-signed-bundle-provider.d.ts +2 -0
  336. package/dist/types/naylence/fame/security/cert/trust-store/http-signed-bundle-provider.d.ts.map +1 -0
  337. package/dist/types/naylence/fame/security/cert/trust-store/node-trust-store-provider-factory.d.ts +23 -0
  338. package/dist/types/naylence/fame/security/cert/trust-store/node-trust-store-provider-factory.d.ts.map +1 -0
  339. package/dist/types/naylence/fame/security/cert/trust-store/static-bundle-provider.d.ts +15 -0
  340. package/dist/types/naylence/fame/security/cert/trust-store/static-bundle-provider.d.ts.map +1 -0
  341. package/dist/types/naylence/fame/security/cert/trust-store/trust-store-provider-factory.d.ts +28 -0
  342. package/dist/types/naylence/fame/security/cert/trust-store/trust-store-provider-factory.d.ts.map +1 -0
  343. package/dist/types/naylence/fame/security/cert/trust-store/trust-store-provider.d.ts +43 -0
  344. package/dist/types/naylence/fame/security/cert/trust-store/trust-store-provider.d.ts.map +1 -0
  345. package/dist/types/naylence/fame/security/cert/util.d.ts +25 -0
  346. package/dist/types/naylence/fame/security/cert/util.d.ts.map +1 -0
  347. package/dist/types/naylence/fame/security/encryption/channel/channel-encryption-manager-factory.d.ts +29 -0
  348. package/dist/types/naylence/fame/security/encryption/channel/channel-encryption-manager-factory.d.ts.map +1 -0
  349. package/dist/types/naylence/fame/security/encryption/channel/channel-encryption-manager.d.ts +51 -0
  350. package/dist/types/naylence/fame/security/encryption/channel/channel-encryption-manager.d.ts.map +1 -0
  351. package/dist/types/naylence/fame/security/encryption/channel/index.d.ts +3 -0
  352. package/dist/types/naylence/fame/security/encryption/channel/index.d.ts.map +1 -0
  353. package/dist/types/naylence/fame/security/encryption/composite-encryption-manager-factory.d.ts +32 -0
  354. package/dist/types/naylence/fame/security/encryption/composite-encryption-manager-factory.d.ts.map +1 -0
  355. package/dist/types/naylence/fame/security/encryption/composite-encryption-manager.d.ts +52 -0
  356. package/dist/types/naylence/fame/security/encryption/composite-encryption-manager.d.ts.map +1 -0
  357. package/dist/types/naylence/fame/security/encryption/default-secure-channel-manager-factory.d.ts +23 -0
  358. package/dist/types/naylence/fame/security/encryption/default-secure-channel-manager-factory.d.ts.map +1 -0
  359. package/dist/types/naylence/fame/security/encryption/default-secure-channel-manager.d.ts +37 -0
  360. package/dist/types/naylence/fame/security/encryption/default-secure-channel-manager.d.ts.map +1 -0
  361. package/dist/types/naylence/fame/security/encryption/encryption-manager-registry.d.ts +34 -0
  362. package/dist/types/naylence/fame/security/encryption/encryption-manager-registry.d.ts.map +1 -0
  363. package/dist/types/naylence/fame/security/encryption/index.d.ts +7 -0
  364. package/dist/types/naylence/fame/security/encryption/index.d.ts.map +1 -0
  365. package/dist/types/naylence/fame/security/encryption/sealed/index.d.ts +3 -0
  366. package/dist/types/naylence/fame/security/encryption/sealed/index.d.ts.map +1 -0
  367. package/dist/types/naylence/fame/security/encryption/sealed/x25519-encryption-manager-factory.d.ts +28 -0
  368. package/dist/types/naylence/fame/security/encryption/sealed/x25519-encryption-manager-factory.d.ts.map +1 -0
  369. package/dist/types/naylence/fame/security/encryption/sealed/x25519-encryption-manager.d.ts +43 -0
  370. package/dist/types/naylence/fame/security/encryption/sealed/x25519-encryption-manager.d.ts.map +1 -0
  371. package/dist/types/naylence/fame/security/index.d.ts +6 -0
  372. package/dist/types/naylence/fame/security/index.d.ts.map +1 -0
  373. package/dist/types/naylence/fame/security/keys/index.d.ts +3 -0
  374. package/dist/types/naylence/fame/security/keys/index.d.ts.map +1 -0
  375. package/dist/types/naylence/fame/security/keys/x5c-key-manager-factory.d.ts +19 -0
  376. package/dist/types/naylence/fame/security/keys/x5c-key-manager-factory.d.ts.map +1 -0
  377. package/dist/types/naylence/fame/security/keys/x5c-key-manager.d.ts +39 -0
  378. package/dist/types/naylence/fame/security/keys/x5c-key-manager.d.ts.map +1 -0
  379. package/dist/types/naylence/fame/security/register-advanced-security-factories.d.ts +8 -0
  380. package/dist/types/naylence/fame/security/register-advanced-security-factories.d.ts.map +1 -0
  381. package/dist/types/naylence/fame/security/signing/eddsa-envelope-signer-factory.d.ts +20 -0
  382. package/dist/types/naylence/fame/security/signing/eddsa-envelope-signer-factory.d.ts.map +1 -0
  383. package/dist/types/naylence/fame/security/signing/eddsa-envelope-verifier-factory.d.ts +21 -0
  384. package/dist/types/naylence/fame/security/signing/eddsa-envelope-verifier-factory.d.ts.map +1 -0
  385. package/dist/types/naylence/fame/security/signing/eddsa-envelope-verifier.d.ts +22 -0
  386. package/dist/types/naylence/fame/security/signing/eddsa-envelope-verifier.d.ts.map +1 -0
  387. package/dist/types/naylence/fame/stickiness/aft-helper.d.ts +29 -0
  388. package/dist/types/naylence/fame/stickiness/aft-helper.d.ts.map +1 -0
  389. package/dist/types/naylence/fame/stickiness/aft-load-balancer-stickiness-manager-factory.d.ts +25 -0
  390. package/dist/types/naylence/fame/stickiness/aft-load-balancer-stickiness-manager-factory.d.ts.map +1 -0
  391. package/dist/types/naylence/fame/stickiness/aft-load-balancer-stickiness-manager.d.ts +33 -0
  392. package/dist/types/naylence/fame/stickiness/aft-load-balancer-stickiness-manager.d.ts.map +1 -0
  393. package/dist/types/naylence/fame/stickiness/aft-model.d.ts +33 -0
  394. package/dist/types/naylence/fame/stickiness/aft-model.d.ts.map +1 -0
  395. package/dist/types/naylence/fame/stickiness/aft-replica-stickiness-manager-factory.d.ts +23 -0
  396. package/dist/types/naylence/fame/stickiness/aft-replica-stickiness-manager-factory.d.ts.map +1 -0
  397. package/dist/types/naylence/fame/stickiness/aft-replica-stickiness-manager.d.ts +31 -0
  398. package/dist/types/naylence/fame/stickiness/aft-replica-stickiness-manager.d.ts.map +1 -0
  399. package/dist/types/naylence/fame/stickiness/aft-signer.d.ts +55 -0
  400. package/dist/types/naylence/fame/stickiness/aft-signer.d.ts.map +1 -0
  401. package/dist/types/naylence/fame/stickiness/aft-utils.d.ts +4 -0
  402. package/dist/types/naylence/fame/stickiness/aft-utils.d.ts.map +1 -0
  403. package/dist/types/naylence/fame/stickiness/aft-verifier.d.ts +50 -0
  404. package/dist/types/naylence/fame/stickiness/aft-verifier.d.ts.map +1 -0
  405. package/dist/types/naylence/fame/stickiness/index.d.ts +15 -0
  406. package/dist/types/naylence/fame/stickiness/index.d.ts.map +1 -0
  407. package/dist/types/naylence/fame/stickiness/stickiness-mode.d.ts +7 -0
  408. package/dist/types/naylence/fame/stickiness/stickiness-mode.d.ts.map +1 -0
  409. package/dist/types/naylence/fame/welcome/advanced-welcome-service-factory.d.ts +21 -0
  410. package/dist/types/naylence/fame/welcome/advanced-welcome-service-factory.d.ts.map +1 -0
  411. package/dist/types/naylence/fame/welcome/advanced-welcome-service.d.ts +21 -0
  412. package/dist/types/naylence/fame/welcome/advanced-welcome-service.d.ts.map +1 -0
  413. package/dist/types/naylence/fame/welcome/index.d.ts +3 -0
  414. package/dist/types/naylence/fame/welcome/index.d.ts.map +1 -0
  415. package/dist/types/node.d.ts +11 -0
  416. package/dist/types/node.d.ts.map +1 -0
  417. package/dist/types/plugin.d.ts +11 -0
  418. package/dist/types/plugin.d.ts.map +1 -0
  419. package/dist/types/version.d.ts +6 -0
  420. package/dist/types/version.d.ts.map +1 -0
  421. package/package.json +1 -1
@@ -0,0 +1,405 @@
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: 200, joinTimeout: 100 });
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
@@ -0,0 +1 @@
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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"}