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

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 +9864 -0
  2. package/dist/browser/index.mjs +9811 -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 +283 -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 +283 -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 +9855 -0
  280. package/dist/node/index.mjs +9800 -0
  281. package/dist/node/node.cjs +10139 -0
  282. package/dist/node/node.mjs +10046 -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,815 @@
1
+ import { SigningMaterial } from "@naylence/core";
2
+ import { AuthInjectionStrategyFactory, getLogger, SigningConfigClass, } from "@naylence/runtime";
3
+ import { CAServiceClient, } from "./ca-service-client.js";
4
+ import { CertificateRequestError } from "./ca-types.js";
5
+ import { GRANT_PURPOSE_CA_SIGN } from "./grants.js";
6
+ import { validateJwkX5cCertificate } from "./util.js";
7
+ import { createEd25519CsrFromPem } from "./node-ed25519-csr.js";
8
+ import { TrustStoreProviderFactory } from "./trust-store/trust-store-provider-factory.js";
9
+ const logger = getLogger("naylence.fame.security.cert.default_certificate_manager");
10
+ const CONNECTION_GRANTS_CAMEL = "connectionGrants";
11
+ const CONNECTION_GRANTS_SNAKE = "connection_grants";
12
+ export class DefaultCertificateManager {
13
+ constructor(options = {}) {
14
+ this.priority = 1500;
15
+ this.node = null;
16
+ this.pendingWelcomeFrame = null;
17
+ this.signing = normalizeSigningConfig(options.signing ?? null);
18
+ this.securitySettings = options.securitySettings ?? null;
19
+ this.caServiceUrl = options.caServiceUrl ?? null;
20
+ this.cryptoProviderOverride =
21
+ options.cryptoProvider ?? options.crypto_provider ?? null;
22
+ this.certificateMaterialResolver = normalizeCertificateMaterialResolver(options.certificateMaterial ?? null);
23
+ this.trustStorePemResolver = normalizeTrustStorePemResolver(options.trustStorePem ?? null);
24
+ this.certificatePersistenceHook =
25
+ normalizeCertificatePersistenceHook(options.persistCertificateMaterial ?? null);
26
+ }
27
+ setSigning(signing) {
28
+ this.signing = normalizeSigningConfig(signing);
29
+ }
30
+ setSecuritySettings(securitySettings) {
31
+ this.securitySettings = securitySettings ?? null;
32
+ }
33
+ async onNodeStarted(node) {
34
+ this.node = node;
35
+ this.prepareProviderContext(node);
36
+ const requiresCertificate = this.requiresCertificates();
37
+ if (requiresCertificate) {
38
+ logger.debug("node_certificate_required_on_start", {
39
+ node_id: node.id,
40
+ physical_path: node.physicalPath,
41
+ has_parent: node.hasParent,
42
+ });
43
+ const fallbackWelcome = {
44
+ security_settings: this.securitySettings ?? undefined,
45
+ system_id: node.id,
46
+ assigned_path: node.physicalPath,
47
+ accepted_logicals: Array.from(node.acceptedLogicals),
48
+ };
49
+ const welcomeFrame = this.pendingWelcomeFrame ?? fallbackWelcome;
50
+ const success = await this.ensureCertificate(welcomeFrame, this.caServiceUrl ? { caServiceUrl: this.caServiceUrl } : undefined);
51
+ if (!success) {
52
+ logger.warning("node_certificate_unavailable_on_start", {
53
+ node_id: node.id,
54
+ physical_path: node.physicalPath,
55
+ message: "Certificate provisioning was requested but did not complete",
56
+ });
57
+ }
58
+ }
59
+ else {
60
+ this.pendingWelcomeFrame = null;
61
+ }
62
+ }
63
+ async onWelcome(welcomeFrame) {
64
+ const requiresCertificate = this.requiresCertificates(welcomeFrame);
65
+ if (!requiresCertificate) {
66
+ logger.debug("welcome_does_not_require_certificate", {
67
+ system_id: welcomeFrame.systemId ?? null,
68
+ });
69
+ this.pendingWelcomeFrame = null;
70
+ return;
71
+ }
72
+ const success = await this.ensureCertificate(welcomeFrame, this.caServiceUrl ? { caServiceUrl: this.caServiceUrl } : undefined);
73
+ if (success) {
74
+ return;
75
+ }
76
+ if (!this.node) {
77
+ logger.debug("certificate_provisioning_deferred_until_node_start", {
78
+ system_id: welcomeFrame.systemId ?? null,
79
+ assigned_path: welcomeFrame.assignedPath ?? null,
80
+ });
81
+ return;
82
+ }
83
+ const nodeId = welcomeFrame.systemId ?? "unknown";
84
+ logger.warning("certificate_provisioning_not_completed", {
85
+ node_id: nodeId,
86
+ assigned_path: welcomeFrame.assignedPath ?? null,
87
+ message: "Continuing without a provisioned certificate (development mode)",
88
+ });
89
+ }
90
+ async ensureCertificate(welcomeFrame, options) {
91
+ const requiresCertificate = this.requiresCertificates(welcomeFrame);
92
+ if (!requiresCertificate) {
93
+ this.pendingWelcomeFrame = null;
94
+ return true;
95
+ }
96
+ this.pendingWelcomeFrame = welcomeFrame;
97
+ const cryptoProvider = this.resolveCryptoProvider();
98
+ if (!cryptoProvider) {
99
+ if (!this.node) {
100
+ logger.debug("crypto_provider_pending_node_start", {
101
+ system_id: welcomeFrame.systemId ?? null,
102
+ assigned_path: welcomeFrame.assignedPath ?? null,
103
+ });
104
+ }
105
+ else {
106
+ logger.error("crypto_provider_unavailable_for_certificate", {
107
+ system_id: welcomeFrame.systemId ?? null,
108
+ assigned_path: welcomeFrame.assignedPath ?? null,
109
+ });
110
+ }
111
+ return false;
112
+ }
113
+ const nodeId = readFrameString(welcomeFrame, "systemId", "system_id") ??
114
+ (typeof cryptoProvider.signatureKeyId === "string"
115
+ ? cryptoProvider.signatureKeyId
116
+ : null);
117
+ if (await this.ensureExistingCertificateIsTrusted(cryptoProvider, nodeId)) {
118
+ this.pendingWelcomeFrame = null;
119
+ return true;
120
+ }
121
+ this.prepareProviderForWelcome(cryptoProvider, welcomeFrame);
122
+ const connectionGrants = readFrameValue(welcomeFrame, CONNECTION_GRANTS_CAMEL, CONNECTION_GRANTS_SNAKE);
123
+ const caSignGrant = this.getCaSignGrant(connectionGrants);
124
+ if (!caSignGrant) {
125
+ logger.warning("welcome_frame_missing_ca_sign_grant", {
126
+ system_id: nodeId,
127
+ grant_count: Array.isArray(connectionGrants)
128
+ ? connectionGrants.length
129
+ : 0,
130
+ });
131
+ }
132
+ let material = null;
133
+ if (caSignGrant) {
134
+ material = await this.requestCertificateFromCa(cryptoProvider, welcomeFrame, caSignGrant, options);
135
+ if (!material) {
136
+ logger.warning("ca_certificate_request_failed_falling_back_to_env", {
137
+ system_id: nodeId,
138
+ ca_service_url: options?.caServiceUrl ?? this.caServiceUrl ?? caSignGrant.url,
139
+ });
140
+ }
141
+ }
142
+ if (!material) {
143
+ material = await this.resolveCertificateMaterialFromInjectedSources(cryptoProvider, nodeId);
144
+ }
145
+ if (!material) {
146
+ logger.debug("attempting_certificate_resolution_from_environment", {
147
+ system_id: nodeId,
148
+ });
149
+ material = await resolveCertificateMaterialFromEnvironment();
150
+ }
151
+ if (!material) {
152
+ logger.warning("certificate_material_not_found", {
153
+ system_id: nodeId,
154
+ assigned_path: readFrameString(welcomeFrame, "assignedPath", "assigned_path"),
155
+ ca_service_url: options?.caServiceUrl ?? this.caServiceUrl,
156
+ });
157
+ return false;
158
+ }
159
+ const stored = await this.storeCertificateMaterial(cryptoProvider, material, nodeId);
160
+ if (!stored) {
161
+ logger.warning("certificate_storage_not_supported", {
162
+ system_id: nodeId,
163
+ });
164
+ return false;
165
+ }
166
+ const validated = await this.validateProviderCertificate(cryptoProvider, nodeId);
167
+ if (!validated) {
168
+ return false;
169
+ }
170
+ logger.debug("certificate_material_applied", {
171
+ system_id: nodeId,
172
+ has_chain: Boolean(material.certificateChainPem),
173
+ });
174
+ this.pendingWelcomeFrame = null;
175
+ return true;
176
+ }
177
+ requiresCertificates(welcomeFrame) {
178
+ const frameMaterial = welcomeFrame?.securitySettings?.signing_material ?? null;
179
+ if (frameMaterial === SigningMaterial.X509_CHAIN) {
180
+ return true;
181
+ }
182
+ if (this.securitySettings?.signing_material === SigningMaterial.X509_CHAIN) {
183
+ return true;
184
+ }
185
+ if (this.signing.signingMaterial === SigningMaterial.X509_CHAIN) {
186
+ return true;
187
+ }
188
+ return false;
189
+ }
190
+ prepareProviderContext(node) {
191
+ const provider = this.resolveCryptoProvider();
192
+ if (!provider) {
193
+ return;
194
+ }
195
+ const awareProvider = provider;
196
+ if (typeof awareProvider.setNodeContextFromNodeLike === "function") {
197
+ awareProvider.setNodeContextFromNodeLike(node);
198
+ return;
199
+ }
200
+ if (typeof awareProvider.setNodeContext === "function") {
201
+ awareProvider.setNodeContext(node.id, node.physicalPath, Array.from(node.acceptedLogicals), null);
202
+ }
203
+ }
204
+ prepareProviderForWelcome(provider, welcomeFrame) {
205
+ const logicals = Array.isArray(welcomeFrame.acceptedLogicals)
206
+ ? welcomeFrame.acceptedLogicals.filter((value) => typeof value === "string")
207
+ : [];
208
+ if (typeof provider.prepareForAttach === "function" &&
209
+ typeof welcomeFrame.systemId === "string") {
210
+ provider.prepareForAttach(welcomeFrame.systemId, typeof welcomeFrame.assignedPath === "string"
211
+ ? welcomeFrame.assignedPath
212
+ : undefined, logicals);
213
+ }
214
+ }
215
+ resolveCryptoProvider() {
216
+ // First check if we have a crypto provider override
217
+ if (this.cryptoProviderOverride) {
218
+ return this.cryptoProviderOverride;
219
+ }
220
+ // Otherwise, try to get from the node
221
+ const candidate = this.node?.cryptoProvider ?? null;
222
+ if (!candidate) {
223
+ return null;
224
+ }
225
+ return candidate;
226
+ }
227
+ async ensureExistingCertificateIsTrusted(provider, nodeId) {
228
+ if (!providerHasCertificate(provider)) {
229
+ return false;
230
+ }
231
+ const validated = await this.validateProviderCertificate(provider, nodeId);
232
+ if (!validated) {
233
+ logger.error("existing_certificate_validation_failed", {
234
+ node_id: nodeId,
235
+ });
236
+ return false;
237
+ }
238
+ logger.debug("existing_certificate_validated", {
239
+ node_id: nodeId,
240
+ });
241
+ return true;
242
+ }
243
+ async resolveCertificateMaterialFromInjectedSources(provider, nodeId) {
244
+ const providerMaterial = await this.resolveCertificateMaterialFromProvider(provider, nodeId);
245
+ if (providerMaterial) {
246
+ logger.debug("certificate_material_resolved_from_provider", {
247
+ system_id: nodeId,
248
+ });
249
+ return providerMaterial;
250
+ }
251
+ if (this.certificateMaterialResolver) {
252
+ try {
253
+ const material = await this.certificateMaterialResolver();
254
+ if (material) {
255
+ logger.debug("certificate_material_resolved_from_options", {
256
+ system_id: nodeId,
257
+ });
258
+ return material;
259
+ }
260
+ }
261
+ catch (error) {
262
+ logger.debug("certificate_material_option_resolution_failed", {
263
+ system_id: nodeId,
264
+ error: error instanceof Error ? error.message : String(error),
265
+ });
266
+ }
267
+ }
268
+ return null;
269
+ }
270
+ async resolveCertificateMaterialFromProvider(provider, nodeId) {
271
+ if (typeof provider.resolveCertificateMaterial !== "function") {
272
+ return null;
273
+ }
274
+ try {
275
+ const material = await provider.resolveCertificateMaterial();
276
+ return normalizeCertificateMaterial(material ?? null);
277
+ }
278
+ catch (error) {
279
+ logger.debug("provider_certificate_material_resolution_failed", {
280
+ system_id: nodeId,
281
+ error: error instanceof Error ? error.message : String(error),
282
+ });
283
+ return null;
284
+ }
285
+ }
286
+ getCaSignGrant(connectionGrants) {
287
+ if (!Array.isArray(connectionGrants)) {
288
+ return null;
289
+ }
290
+ for (const candidate of connectionGrants) {
291
+ if (!candidate || typeof candidate !== "object") {
292
+ continue;
293
+ }
294
+ const grantRecord = candidate;
295
+ const purpose = readRecordString(grantRecord, "purpose");
296
+ if (purpose !== GRANT_PURPOSE_CA_SIGN) {
297
+ continue;
298
+ }
299
+ const url = readRecordString(grantRecord, "url", "baseUrl", "base_url");
300
+ if (!url) {
301
+ logger.warning("ca_sign_grant_missing_url", {
302
+ grant_keys: Object.keys(grantRecord),
303
+ });
304
+ continue;
305
+ }
306
+ const authConfig = readGrantAuthConfig(grantRecord);
307
+ return {
308
+ url,
309
+ ...(authConfig ? { auth: authConfig } : {}),
310
+ };
311
+ }
312
+ return null;
313
+ }
314
+ async requestCertificateFromCa(provider, welcomeFrame, grant, options) {
315
+ const nodeId = readFrameString(welcomeFrame, "systemId", "system_id") ??
316
+ (typeof provider.signatureKeyId === "string"
317
+ ? provider.signatureKeyId
318
+ : null);
319
+ if (!nodeId) {
320
+ logger.warning("certificate_request_missing_node_id");
321
+ return null;
322
+ }
323
+ const physicalPath = readFrameString(welcomeFrame, "assignedPath", "assigned_path");
324
+ if (!physicalPath) {
325
+ logger.warning("certificate_request_missing_physical_path", {
326
+ node_id: nodeId,
327
+ });
328
+ return null;
329
+ }
330
+ const logicals = Array.isArray(welcomeFrame.acceptedLogicals)
331
+ ? welcomeFrame.acceptedLogicals.filter((value) => typeof value === "string")
332
+ : [];
333
+ const csrPem = await this.buildCertificateSigningRequest(provider, nodeId, physicalPath, logicals);
334
+ if (!csrPem) {
335
+ return null;
336
+ }
337
+ const caServiceUrl = options?.caServiceUrl ?? this.caServiceUrl ?? grant.url;
338
+ if (!caServiceUrl) {
339
+ logger.error("ca_service_url_unavailable", {
340
+ node_id: nodeId,
341
+ });
342
+ return null;
343
+ }
344
+ const connectionGrant = {
345
+ url: caServiceUrl,
346
+ };
347
+ let authStrategy = null;
348
+ try {
349
+ authStrategy = await this.createAuthStrategyForGrant(grant);
350
+ }
351
+ catch (error) {
352
+ logger.error("ca_sign_auth_strategy_creation_failed", {
353
+ node_id: nodeId,
354
+ error: error instanceof Error ? error.message : String(error),
355
+ });
356
+ return null;
357
+ }
358
+ const client = new CAServiceClient(connectionGrant);
359
+ try {
360
+ if (authStrategy) {
361
+ await authStrategy.apply(client);
362
+ }
363
+ const [certificatePem, certificateChainPem] = await client.requestCertificate(csrPem, nodeId, physicalPath, logicals);
364
+ logger.debug("certificate_received_from_ca_service", {
365
+ node_id: nodeId,
366
+ has_chain: Boolean(certificateChainPem),
367
+ ca_service_url: caServiceUrl,
368
+ });
369
+ return {
370
+ certificatePem,
371
+ certificateChainPem: certificateChainPem ?? null,
372
+ };
373
+ }
374
+ catch (error) {
375
+ if (error instanceof CertificateRequestError) {
376
+ logger.error("certificate_request_failed", {
377
+ node_id: nodeId,
378
+ error: error.message,
379
+ });
380
+ }
381
+ else {
382
+ logger.error("certificate_request_unhandled_error", {
383
+ node_id: nodeId,
384
+ error: error instanceof Error ? error.message : String(error),
385
+ });
386
+ }
387
+ return null;
388
+ }
389
+ finally {
390
+ if (authStrategy) {
391
+ try {
392
+ await authStrategy.cleanup();
393
+ }
394
+ catch (cleanupError) {
395
+ logger.debug("auth_strategy_cleanup_failed", {
396
+ error: cleanupError instanceof Error
397
+ ? cleanupError.message
398
+ : String(cleanupError),
399
+ });
400
+ }
401
+ }
402
+ }
403
+ }
404
+ async createAuthStrategyForGrant(grant) {
405
+ const authConfig = grant.auth ?? null;
406
+ if (!authConfig) {
407
+ return null;
408
+ }
409
+ const normalizedConfig = normalizeAuthConfig(authConfig);
410
+ if (!normalizedConfig) {
411
+ return null;
412
+ }
413
+ return AuthInjectionStrategyFactory.createAuthInjectionStrategy(normalizedConfig);
414
+ }
415
+ async validateProviderCertificate(provider, nodeId) {
416
+ const { pem: trustStorePem, reason } = await this.resolveTrustStorePemValue(provider, nodeId);
417
+ if (!trustStorePem) {
418
+ logger.error("trust_anchor_validation_failed", {
419
+ node_id: nodeId,
420
+ reason: reason ?? "trust_store_unavailable",
421
+ });
422
+ return false;
423
+ }
424
+ if (typeof provider.nodeJwk !== "function") {
425
+ logger.error("trust_anchor_validation_failed", {
426
+ node_id: nodeId,
427
+ reason: "crypto_provider_lacks_node_jwk",
428
+ });
429
+ return false;
430
+ }
431
+ let jwk;
432
+ try {
433
+ jwk = provider.nodeJwk() ?? null;
434
+ }
435
+ catch (error) {
436
+ logger.error("trust_anchor_validation_failed", {
437
+ node_id: nodeId,
438
+ reason: "node_jwk_retrieval_failed",
439
+ error: error instanceof Error ? error.message : String(error),
440
+ });
441
+ return false;
442
+ }
443
+ if (!jwk) {
444
+ logger.error("trust_anchor_validation_failed", {
445
+ node_id: nodeId,
446
+ reason: "node_jwk_missing",
447
+ });
448
+ return false;
449
+ }
450
+ const x5c = jwk.x5c;
451
+ if (!Array.isArray(x5c) ||
452
+ x5c.length === 0 ||
453
+ x5c.some((entry) => typeof entry !== "string")) {
454
+ logger.error("trust_anchor_validation_failed", {
455
+ node_id: nodeId,
456
+ reason: "invalid_certificate_chain",
457
+ });
458
+ return false;
459
+ }
460
+ try {
461
+ const result = validateJwkX5cCertificate({
462
+ jwk,
463
+ trustStorePem,
464
+ enforceNameConstraints: true,
465
+ strict: false,
466
+ });
467
+ if (!result.isValid) {
468
+ logger.error("trust_anchor_validation_failed", {
469
+ node_id: nodeId,
470
+ reason: result.error ?? "validation_failed",
471
+ });
472
+ return false;
473
+ }
474
+ logger.debug("certificate_chain_validation_successful", {
475
+ node_id: nodeId,
476
+ });
477
+ return true;
478
+ }
479
+ catch (error) {
480
+ logger.error("trust_anchor_validation_failed", {
481
+ node_id: nodeId,
482
+ reason: "validation_error",
483
+ error: error instanceof Error ? error.message : String(error),
484
+ });
485
+ return false;
486
+ }
487
+ }
488
+ async resolveTrustStorePemValue(provider, nodeId) {
489
+ const providerPem = await this.resolveTrustStorePemFromProvider(provider, nodeId);
490
+ if (providerPem) {
491
+ logger.debug("trust_store_resolved_from_provider", {
492
+ node_id: nodeId,
493
+ });
494
+ return { pem: providerPem };
495
+ }
496
+ if (this.trustStorePemResolver) {
497
+ try {
498
+ const pem = await this.trustStorePemResolver();
499
+ const normalized = normalizePemOrNull(pem);
500
+ if (normalized) {
501
+ logger.debug("trust_store_resolved_from_options", {
502
+ node_id: nodeId,
503
+ });
504
+ return { pem: normalized };
505
+ }
506
+ }
507
+ catch (error) {
508
+ logger.debug("trust_store_option_resolution_failed", {
509
+ node_id: nodeId,
510
+ error: error instanceof Error ? error.message : String(error),
511
+ });
512
+ }
513
+ }
514
+ const envPem = await resolveTrustStorePemFromEnvironment();
515
+ return {
516
+ pem: envPem,
517
+ reason: envPem ? undefined : "trust_store_provider_unconfigured",
518
+ };
519
+ }
520
+ async resolveTrustStorePemFromProvider(provider, nodeId) {
521
+ if (typeof provider.resolveTrustStorePem !== "function") {
522
+ return null;
523
+ }
524
+ try {
525
+ const pem = await provider.resolveTrustStorePem();
526
+ return normalizePemOrNull(pem);
527
+ }
528
+ catch (error) {
529
+ logger.debug("provider_trust_store_resolution_failed", {
530
+ node_id: nodeId,
531
+ error: error instanceof Error ? error.message : String(error),
532
+ });
533
+ return null;
534
+ }
535
+ }
536
+ async storeCertificateMaterial(provider, material, nodeId) {
537
+ let stored = false;
538
+ if (typeof provider.storeSignedCertificate === "function") {
539
+ try {
540
+ await provider.storeSignedCertificate(material.certificatePem, material.certificateChainPem);
541
+ stored = true;
542
+ }
543
+ catch (error) {
544
+ logger.warning("failed_to_store_certificate", {
545
+ error: error instanceof Error ? error.message : String(error),
546
+ });
547
+ }
548
+ }
549
+ const persistenceHooks = [];
550
+ if (typeof provider.persistSignedCertificate === "function") {
551
+ persistenceHooks.push((hookMaterial, context) => provider.persistSignedCertificate(hookMaterial, context));
552
+ }
553
+ if (this.certificatePersistenceHook) {
554
+ persistenceHooks.push(this.certificatePersistenceHook);
555
+ }
556
+ for (const hook of persistenceHooks) {
557
+ try {
558
+ await hook(material, { nodeId });
559
+ stored = true;
560
+ }
561
+ catch (error) {
562
+ logger.debug("certificate_persistence_hook_failed", {
563
+ node_id: nodeId,
564
+ error: error instanceof Error ? error.message : String(error),
565
+ });
566
+ }
567
+ }
568
+ return stored;
569
+ }
570
+ async buildCertificateSigningRequest(provider, nodeId, physicalPath, logicals) {
571
+ const trimmedPath = physicalPath.trim();
572
+ if (!trimmedPath) {
573
+ logger.warning("certificate_request_missing_physical_path", {
574
+ node_id: nodeId,
575
+ });
576
+ return null;
577
+ }
578
+ const pemSource = provider;
579
+ const privateKeyPem = pemSource.signingPrivatePem?.trim() ?? "";
580
+ const publicKeyPem = pemSource.signingPublicPem?.trim() ?? "";
581
+ if (!privateKeyPem || !publicKeyPem) {
582
+ logger.error("crypto_provider_missing_signing_material", {
583
+ node_id: nodeId,
584
+ has_private: Boolean(privateKeyPem),
585
+ has_public: Boolean(publicKeyPem),
586
+ });
587
+ return null;
588
+ }
589
+ const sanitizedLogicals = logicals.filter((value) => typeof value === "string" && value.trim().length > 0);
590
+ try {
591
+ const { csrPem } = await createEd25519CsrFromPem({
592
+ privateKeyPem,
593
+ publicKeyPem,
594
+ commonName: nodeId,
595
+ logicals: sanitizedLogicals,
596
+ });
597
+ return csrPem;
598
+ }
599
+ catch (error) {
600
+ logger.error("csr_generation_failed", {
601
+ node_id: nodeId,
602
+ error: error instanceof Error ? error.message : String(error),
603
+ });
604
+ return null;
605
+ }
606
+ }
607
+ }
608
+ function normalizeSigningConfig(value) {
609
+ if (value instanceof SigningConfigClass) {
610
+ return value;
611
+ }
612
+ if (value && typeof value === "object") {
613
+ return new SigningConfigClass(value);
614
+ }
615
+ return new SigningConfigClass();
616
+ }
617
+ function normalizeCertificateMaterial(material) {
618
+ if (!material) {
619
+ return null;
620
+ }
621
+ const certificatePem = normalizePemOrNull(material.certificatePem);
622
+ if (!certificatePem) {
623
+ return null;
624
+ }
625
+ const certificateChainPem = normalizePemOrNull(material.certificateChainPem ?? null);
626
+ return {
627
+ certificatePem,
628
+ certificateChainPem,
629
+ };
630
+ }
631
+ function normalizeCertificateMaterialResolver(source) {
632
+ if (!source) {
633
+ return null;
634
+ }
635
+ if (typeof source === "function") {
636
+ return async () => normalizeCertificateMaterial(await source());
637
+ }
638
+ const normalized = normalizeCertificateMaterial(source);
639
+ return normalized ? async () => normalized : null;
640
+ }
641
+ function normalizeTrustStorePemResolver(source) {
642
+ if (!source) {
643
+ return null;
644
+ }
645
+ if (typeof source === "function") {
646
+ return async () => normalizePemOrNull(await source());
647
+ }
648
+ const normalized = normalizePemOrNull(source);
649
+ return normalized ? async () => normalized : null;
650
+ }
651
+ function normalizeCertificatePersistenceHook(hook) {
652
+ if (!hook) {
653
+ return null;
654
+ }
655
+ return async (material, context) => {
656
+ await hook(material, context);
657
+ };
658
+ }
659
+ async function resolveCertificateMaterialFromEnvironment() {
660
+ const certificatePem = await resolvePemFromEnvironment("FAME_NODE_CERT_PEM", "FAME_NODE_CERT_FILE");
661
+ if (!certificatePem) {
662
+ return null;
663
+ }
664
+ const certificateChainPem = await resolvePemFromEnvironment("FAME_NODE_CERT_CHAIN_PEM", "FAME_NODE_CERT_CHAIN_FILE");
665
+ return {
666
+ certificatePem,
667
+ certificateChainPem,
668
+ };
669
+ }
670
+ async function resolvePemFromEnvironment(envVar, fileVar) {
671
+ if (!hasProcessEnv()) {
672
+ return null;
673
+ }
674
+ const inlineValue = process.env?.[envVar];
675
+ const inline = normalizePemOrNull(inlineValue ?? null);
676
+ if (inline) {
677
+ return inline;
678
+ }
679
+ const filePath = process.env?.[fileVar];
680
+ if (!filePath || filePath.trim().length === 0) {
681
+ return null;
682
+ }
683
+ if (!isNodeProcess()) {
684
+ logger.debug("pem_file_unavailable_in_browser", {
685
+ env_var: fileVar,
686
+ });
687
+ return null;
688
+ }
689
+ try {
690
+ const fs = await import("node:fs/promises");
691
+ const content = await fs.readFile(filePath, "utf8");
692
+ return normalizePemOrNull(content);
693
+ }
694
+ catch (error) {
695
+ logger.warning("failed_to_read_certificate_file", {
696
+ file: filePath,
697
+ error: error instanceof Error ? error.message : String(error),
698
+ });
699
+ return null;
700
+ }
701
+ }
702
+ function normalizePem(value) {
703
+ return value.replace(/\r/g, "").trim();
704
+ }
705
+ function normalizePemOrNull(value) {
706
+ if (!value) {
707
+ return null;
708
+ }
709
+ const normalized = normalizePem(value);
710
+ return normalized.length > 0 ? normalized : null;
711
+ }
712
+ function hasProcessEnv() {
713
+ return typeof process !== "undefined" && !!process?.env;
714
+ }
715
+ function isNodeProcess() {
716
+ return (typeof process !== "undefined" &&
717
+ typeof process.versions === "object" &&
718
+ typeof process.versions?.node === "string");
719
+ }
720
+ function providerHasCertificate(provider) {
721
+ if (typeof provider.hasCertificate === "function") {
722
+ try {
723
+ return Boolean(provider.hasCertificate());
724
+ }
725
+ catch (error) {
726
+ logger.debug("has_certificate_check_failed", {
727
+ error: error instanceof Error ? error.message : String(error),
728
+ });
729
+ }
730
+ }
731
+ if (typeof provider.nodeCertificatePem === "function") {
732
+ try {
733
+ return Boolean(provider.nodeCertificatePem());
734
+ }
735
+ catch (error) {
736
+ logger.debug("node_certificate_check_failed", {
737
+ error: error instanceof Error ? error.message : String(error),
738
+ });
739
+ }
740
+ }
741
+ return false;
742
+ }
743
+ function readFrameValue(frame, ...keys) {
744
+ const record = frame;
745
+ for (const key of keys) {
746
+ if (Object.prototype.hasOwnProperty.call(record, key)) {
747
+ const value = record[key];
748
+ if (value !== undefined && value !== null) {
749
+ return value;
750
+ }
751
+ }
752
+ }
753
+ return null;
754
+ }
755
+ function readFrameString(frame, ...keys) {
756
+ const value = readFrameValue(frame, ...keys);
757
+ if (typeof value === "string" && value.length > 0) {
758
+ return value;
759
+ }
760
+ return null;
761
+ }
762
+ function readRecordString(source, ...keys) {
763
+ for (const key of keys) {
764
+ const value = source[key];
765
+ if (typeof value === "string" && value.length > 0) {
766
+ return value;
767
+ }
768
+ }
769
+ return null;
770
+ }
771
+ function readGrantAuthConfig(source) {
772
+ const candidate = source.auth ??
773
+ source.authConfig ??
774
+ source.auth_config ??
775
+ source.authentication ??
776
+ source.authenticationConfig ??
777
+ source.authentication_config ??
778
+ null;
779
+ if (!candidate || typeof candidate !== "object") {
780
+ return null;
781
+ }
782
+ return candidate;
783
+ }
784
+ function normalizeAuthConfig(candidate) {
785
+ if (!candidate || typeof candidate !== "object") {
786
+ return null;
787
+ }
788
+ const normalized = candidate;
789
+ if (!normalized.type || typeof normalized.type !== "string") {
790
+ logger.warning("auth_strategy_missing_type", {
791
+ provided_keys: Object.keys(candidate),
792
+ });
793
+ return null;
794
+ }
795
+ return normalized;
796
+ }
797
+ async function resolveTrustStorePemFromEnvironment() {
798
+ try {
799
+ const provider = await TrustStoreProviderFactory.createTrustStoreProvider();
800
+ if (typeof provider.initialize === "function") {
801
+ await provider.initialize();
802
+ }
803
+ const pem = await provider.getTrustStorePem();
804
+ return normalizePemOrNull(pem);
805
+ }
806
+ catch (error) {
807
+ const message = error instanceof Error ? error.message : String(error);
808
+ logger.debug("trust_store_provider_resolution_failed", {
809
+ error: message,
810
+ });
811
+ return null;
812
+ }
813
+ }
814
+ export default DefaultCertificateManager;
815
+ //# sourceMappingURL=default-certificate-manager.js.map