@naylence/advanced-security 0.3.7 → 0.3.9

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 (292) hide show
  1. package/dist/browser/index.cjs +9884 -0
  2. package/dist/browser/index.mjs +9831 -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 +24 -5
  6. package/dist/cjs/browser.js.map +1 -1
  7. package/dist/cjs/index.js +1 -6
  8. package/dist/cjs/index.js.map +1 -1
  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 +19 -4
  12. package/dist/cjs/naylence/fame/factory-manifest.js.map +1 -1
  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 +340 -39
  20. package/dist/cjs/naylence/fame/security/cert/ca-service-client.js.map +1 -1
  21. package/dist/cjs/naylence/fame/security/cert/ca-service-factory.js +7 -11
  22. package/dist/cjs/naylence/fame/security/cert/ca-service-factory.js.map +1 -1
  23. package/dist/cjs/naylence/fame/security/cert/ca-types.js +10 -7
  24. package/dist/cjs/naylence/fame/security/cert/ca-types.js.map +1 -1
  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 +6 -10
  28. package/dist/cjs/naylence/fame/security/cert/default-ca-service-factory.js.map +1 -1
  29. package/dist/cjs/naylence/fame/security/cert/default-ca-service.js +151 -66
  30. package/dist/cjs/naylence/fame/security/cert/default-ca-service.js.map +1 -1
  31. package/dist/cjs/naylence/fame/security/cert/default-certificate-manager-factory.js +17 -19
  32. package/dist/cjs/naylence/fame/security/cert/default-certificate-manager-factory.js.map +1 -1
  33. package/dist/cjs/naylence/fame/security/cert/default-certificate-manager.js +250 -129
  34. package/dist/cjs/naylence/fame/security/cert/default-certificate-manager.js.map +1 -1
  35. package/dist/cjs/naylence/fame/security/cert/grants.js +1 -4
  36. package/dist/cjs/naylence/fame/security/cert/grants.js.map +1 -1
  37. package/dist/cjs/naylence/fame/security/cert/index.js +16 -50
  38. package/dist/cjs/naylence/fame/security/cert/index.js.map +1 -1
  39. package/dist/cjs/naylence/fame/security/cert/internal-ca-service.js +77 -123
  40. package/dist/cjs/naylence/fame/security/cert/internal-ca-service.js.map +1 -1
  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 +549 -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 +25 -30
  66. package/dist/cjs/naylence/fame/security/cert/util.js.map +1 -1
  67. package/dist/cjs/naylence/fame/security/encryption/channel/channel-encryption-manager-factory.js +10 -14
  68. package/dist/cjs/naylence/fame/security/encryption/channel/channel-encryption-manager-factory.js.map +1 -1
  69. package/dist/cjs/naylence/fame/security/encryption/channel/channel-encryption-manager.js +59 -48
  70. package/dist/cjs/naylence/fame/security/encryption/channel/channel-encryption-manager.js.map +1 -1
  71. package/dist/cjs/naylence/fame/security/encryption/channel/index.js +2 -7
  72. package/dist/cjs/naylence/fame/security/encryption/channel/index.js.map +1 -1
  73. package/dist/cjs/naylence/fame/security/encryption/composite-encryption-manager-factory.js +10 -14
  74. package/dist/cjs/naylence/fame/security/encryption/composite-encryption-manager-factory.js.map +1 -1
  75. package/dist/cjs/naylence/fame/security/encryption/composite-encryption-manager.js +7 -11
  76. package/dist/cjs/naylence/fame/security/encryption/composite-encryption-manager.js.map +1 -1
  77. package/dist/cjs/naylence/fame/security/encryption/default-secure-channel-manager-factory.js +7 -11
  78. package/dist/cjs/naylence/fame/security/encryption/default-secure-channel-manager-factory.js.map +1 -1
  79. package/dist/cjs/naylence/fame/security/encryption/default-secure-channel-manager.js +19 -23
  80. package/dist/cjs/naylence/fame/security/encryption/default-secure-channel-manager.js.map +1 -1
  81. package/dist/cjs/naylence/fame/security/encryption/encryption-manager-registry.js +9 -15
  82. package/dist/cjs/naylence/fame/security/encryption/encryption-manager-registry.js.map +1 -1
  83. package/dist/cjs/naylence/fame/security/encryption/index.js +6 -15
  84. package/dist/cjs/naylence/fame/security/encryption/index.js.map +1 -1
  85. package/dist/cjs/naylence/fame/security/encryption/sealed/index.js +2 -7
  86. package/dist/cjs/naylence/fame/security/encryption/sealed/index.js.map +1 -1
  87. package/dist/cjs/naylence/fame/security/encryption/sealed/x25519-encryption-manager-factory.js +8 -12
  88. package/dist/cjs/naylence/fame/security/encryption/sealed/x25519-encryption-manager-factory.js.map +1 -1
  89. package/dist/cjs/naylence/fame/security/encryption/sealed/x25519-encryption-manager.js +26 -30
  90. package/dist/cjs/naylence/fame/security/encryption/sealed/x25519-encryption-manager.js.map +1 -1
  91. package/dist/cjs/naylence/fame/security/index.js +5 -10
  92. package/dist/cjs/naylence/fame/security/index.js.map +1 -1
  93. package/dist/cjs/naylence/fame/security/keys/index.js +2 -8
  94. package/dist/cjs/naylence/fame/security/keys/index.js.map +1 -1
  95. package/dist/cjs/naylence/fame/security/keys/x5c-key-manager-factory.js +9 -13
  96. package/dist/cjs/naylence/fame/security/keys/x5c-key-manager-factory.js.map +1 -1
  97. package/dist/cjs/naylence/fame/security/keys/x5c-key-manager.js +17 -53
  98. package/dist/cjs/naylence/fame/security/keys/x5c-key-manager.js.map +1 -1
  99. package/dist/cjs/naylence/fame/security/register-advanced-security-factories.js +223 -68
  100. package/dist/cjs/naylence/fame/security/register-advanced-security-factories.js.map +1 -1
  101. package/dist/cjs/naylence/fame/security/signing/eddsa-envelope-signer-factory.js +6 -43
  102. package/dist/cjs/naylence/fame/security/signing/eddsa-envelope-signer-factory.js.map +1 -1
  103. package/dist/cjs/naylence/fame/security/signing/eddsa-envelope-verifier-factory.js +16 -13
  104. package/dist/cjs/naylence/fame/security/signing/eddsa-envelope-verifier-factory.js.map +1 -1
  105. package/dist/cjs/naylence/fame/security/signing/eddsa-envelope-verifier.js +69 -125
  106. package/dist/cjs/naylence/fame/security/signing/eddsa-envelope-verifier.js.map +1 -1
  107. package/dist/cjs/naylence/fame/stickiness/aft-helper.js +8 -13
  108. package/dist/cjs/naylence/fame/stickiness/aft-helper.js.map +1 -1
  109. package/dist/cjs/naylence/fame/stickiness/aft-load-balancer-stickiness-manager-factory.js +12 -16
  110. package/dist/cjs/naylence/fame/stickiness/aft-load-balancer-stickiness-manager-factory.js.map +1 -1
  111. package/dist/cjs/naylence/fame/stickiness/aft-load-balancer-stickiness-manager.js +10 -14
  112. package/dist/cjs/naylence/fame/stickiness/aft-load-balancer-stickiness-manager.js.map +1 -1
  113. package/dist/cjs/naylence/fame/stickiness/aft-model.js +6 -14
  114. package/dist/cjs/naylence/fame/stickiness/aft-model.js.map +1 -1
  115. package/dist/cjs/naylence/fame/stickiness/aft-replica-stickiness-manager-factory.js +12 -16
  116. package/dist/cjs/naylence/fame/stickiness/aft-replica-stickiness-manager-factory.js.map +1 -1
  117. package/dist/cjs/naylence/fame/stickiness/aft-replica-stickiness-manager.js +13 -18
  118. package/dist/cjs/naylence/fame/stickiness/aft-replica-stickiness-manager.js.map +1 -1
  119. package/dist/cjs/naylence/fame/stickiness/aft-signer.js +23 -30
  120. package/dist/cjs/naylence/fame/stickiness/aft-signer.js.map +1 -1
  121. package/dist/cjs/naylence/fame/stickiness/aft-utils.js +3 -8
  122. package/dist/cjs/naylence/fame/stickiness/aft-utils.js.map +1 -1
  123. package/dist/cjs/naylence/fame/stickiness/aft-verifier.js +21 -28
  124. package/dist/cjs/naylence/fame/stickiness/aft-verifier.js.map +1 -1
  125. package/dist/cjs/naylence/fame/stickiness/index.js +10 -39
  126. package/dist/cjs/naylence/fame/stickiness/index.js.map +1 -1
  127. package/dist/cjs/naylence/fame/stickiness/stickiness-mode.js +3 -7
  128. package/dist/cjs/naylence/fame/stickiness/stickiness-mode.js.map +1 -1
  129. package/dist/cjs/naylence/fame/welcome/advanced-welcome-service-factory.js +14 -18
  130. package/dist/cjs/naylence/fame/welcome/advanced-welcome-service-factory.js.map +1 -1
  131. package/dist/cjs/naylence/fame/welcome/advanced-welcome-service.js +14 -18
  132. package/dist/cjs/naylence/fame/welcome/advanced-welcome-service.js.map +1 -1
  133. package/dist/cjs/naylence/fame/welcome/index.js +2 -8
  134. package/dist/cjs/naylence/fame/welcome/index.js.map +1 -1
  135. package/dist/cjs/node.js +11 -0
  136. package/dist/cjs/node.js.map +1 -0
  137. package/dist/cjs/plugin.js +8 -10
  138. package/dist/cjs/plugin.js.map +1 -1
  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 +24 -2
  144. package/dist/esm/browser.js.map +1 -1
  145. package/dist/esm/index.js +1 -3
  146. package/dist/esm/index.js.map +1 -1
  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 +18 -0
  150. package/dist/esm/naylence/fame/factory-manifest.js.map +1 -1
  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 +87 -17
  156. package/dist/esm/naylence/fame/security/cert/ca-server.js.map +1 -1
  157. package/dist/esm/naylence/fame/security/cert/ca-service-client.js +331 -24
  158. package/dist/esm/naylence/fame/security/cert/ca-service-client.js.map +1 -1
  159. package/dist/esm/naylence/fame/security/cert/ca-types.js +8 -0
  160. package/dist/esm/naylence/fame/security/cert/ca-types.js.map +1 -1
  161. package/dist/esm/naylence/fame/security/cert/csr-types.js +2 -0
  162. package/dist/esm/naylence/fame/security/cert/csr-types.js.map +1 -0
  163. package/dist/esm/naylence/fame/security/cert/default-ca-service.js +123 -1
  164. package/dist/esm/naylence/fame/security/cert/default-ca-service.js.map +1 -1
  165. package/dist/esm/naylence/fame/security/cert/default-certificate-manager-factory.js +7 -5
  166. package/dist/esm/naylence/fame/security/cert/default-certificate-manager-factory.js.map +1 -1
  167. package/dist/esm/naylence/fame/security/cert/default-certificate-manager.js +229 -71
  168. package/dist/esm/naylence/fame/security/cert/default-certificate-manager.js.map +1 -1
  169. package/dist/esm/naylence/fame/security/cert/index.js +7 -1
  170. package/dist/esm/naylence/fame/security/cert/index.js.map +1 -1
  171. package/dist/esm/naylence/fame/security/cert/internal-ca-service.js +2 -5
  172. package/dist/esm/naylence/fame/security/cert/internal-ca-service.js.map +1 -1
  173. package/dist/esm/naylence/fame/security/cert/node-ed25519-csr.js +156 -0
  174. package/dist/esm/naylence/fame/security/cert/node-ed25519-csr.js.map +1 -0
  175. package/dist/esm/naylence/fame/security/cert/oid-constants.js +7 -0
  176. package/dist/esm/naylence/fame/security/cert/oid-constants.js.map +1 -0
  177. package/dist/esm/naylence/fame/security/cert/trust-store/anchor-utils.js +119 -0
  178. package/dist/esm/naylence/fame/security/cert/trust-store/anchor-utils.js.map +1 -0
  179. package/dist/esm/naylence/fame/security/cert/trust-store/browser-trust-store-provider-factory.js +82 -0
  180. package/dist/esm/naylence/fame/security/cert/trust-store/browser-trust-store-provider-factory.js.map +1 -0
  181. package/dist/esm/naylence/fame/security/cert/trust-store/env-provider.js +168 -0
  182. package/dist/esm/naylence/fame/security/cert/trust-store/env-provider.js.map +1 -0
  183. package/dist/esm/naylence/fame/security/cert/trust-store/fame-ca-certs-parser.js +257 -0
  184. package/dist/esm/naylence/fame/security/cert/trust-store/fame-ca-certs-parser.js.map +1 -0
  185. package/dist/esm/naylence/fame/security/cert/trust-store/http-bundle-provider.js +549 -0
  186. package/dist/esm/naylence/fame/security/cert/trust-store/http-bundle-provider.js.map +1 -0
  187. package/dist/esm/naylence/fame/security/cert/trust-store/http-signed-bundle-provider.js +2 -0
  188. package/dist/esm/naylence/fame/security/cert/trust-store/http-signed-bundle-provider.js.map +1 -0
  189. package/dist/esm/naylence/fame/security/cert/trust-store/node-trust-store-provider-factory.js +61 -0
  190. package/dist/esm/naylence/fame/security/cert/trust-store/node-trust-store-provider-factory.js.map +1 -0
  191. package/dist/esm/naylence/fame/security/cert/trust-store/static-bundle-provider.js +44 -0
  192. package/dist/esm/naylence/fame/security/cert/trust-store/static-bundle-provider.js.map +1 -0
  193. package/dist/esm/naylence/fame/security/cert/trust-store/trust-store-provider-factory.js +40 -0
  194. package/dist/esm/naylence/fame/security/cert/trust-store/trust-store-provider-factory.js.map +1 -0
  195. package/dist/esm/naylence/fame/security/cert/trust-store/trust-store-provider.js +2 -0
  196. package/dist/esm/naylence/fame/security/cert/trust-store/trust-store-provider.js.map +1 -0
  197. package/dist/esm/naylence/fame/security/cert/util.js +1 -2
  198. package/dist/esm/naylence/fame/security/cert/util.js.map +1 -1
  199. package/dist/esm/naylence/fame/security/encryption/channel/channel-encryption-manager.js +27 -12
  200. package/dist/esm/naylence/fame/security/encryption/channel/channel-encryption-manager.js.map +1 -1
  201. package/dist/esm/naylence/fame/security/keys/x5c-key-manager.js +1 -1
  202. package/dist/esm/naylence/fame/security/keys/x5c-key-manager.js.map +1 -1
  203. package/dist/esm/naylence/fame/security/register-advanced-security-factories.js +217 -26
  204. package/dist/esm/naylence/fame/security/register-advanced-security-factories.js.map +1 -1
  205. package/dist/esm/naylence/fame/security/signing/eddsa-envelope-signer-factory.js +1 -1
  206. package/dist/esm/naylence/fame/security/signing/eddsa-envelope-signer-factory.js.map +1 -1
  207. package/dist/esm/naylence/fame/security/signing/eddsa-envelope-verifier-factory.js +9 -2
  208. package/dist/esm/naylence/fame/security/signing/eddsa-envelope-verifier-factory.js.map +1 -1
  209. package/dist/esm/naylence/fame/security/signing/eddsa-envelope-verifier.js +44 -63
  210. package/dist/esm/naylence/fame/security/signing/eddsa-envelope-verifier.js.map +1 -1
  211. package/dist/esm/node.js +11 -0
  212. package/dist/esm/node.js.map +1 -0
  213. package/dist/esm/plugin.js +2 -0
  214. package/dist/esm/plugin.js.map +1 -1
  215. package/dist/esm/version.js +8 -0
  216. package/dist/esm/version.js.map +1 -0
  217. package/dist/node/index.cjs +9875 -0
  218. package/dist/node/index.mjs +9820 -0
  219. package/dist/node/node.cjs +10198 -0
  220. package/dist/node/node.mjs +10105 -0
  221. package/dist/types/advanced-security-isomorphic.d.ts +24 -0
  222. package/dist/types/advanced-security-isomorphic.d.ts.map +1 -0
  223. package/dist/types/browser.d.ts +18 -1
  224. package/dist/types/browser.d.ts.map +1 -1
  225. package/dist/types/index.d.ts +1 -3
  226. package/dist/types/index.d.ts.map +1 -1
  227. package/dist/types/install-env.d.ts +3 -0
  228. package/dist/types/install-env.d.ts.map +1 -0
  229. package/dist/types/naylence/fame/factory-manifest.d.ts +3 -1
  230. package/dist/types/naylence/fame/factory-manifest.d.ts.map +1 -1
  231. package/dist/types/naylence/fame/security/cert/browser-csr.d.ts +9 -0
  232. package/dist/types/naylence/fame/security/cert/browser-csr.d.ts.map +1 -0
  233. package/dist/types/naylence/fame/security/cert/ca-server-cli.d.ts +3 -0
  234. package/dist/types/naylence/fame/security/cert/ca-server-cli.d.ts.map +1 -0
  235. package/dist/types/naylence/fame/security/cert/ca-server.d.ts +2 -2
  236. package/dist/types/naylence/fame/security/cert/ca-server.d.ts.map +1 -1
  237. package/dist/types/naylence/fame/security/cert/ca-service-client.d.ts.map +1 -1
  238. package/dist/types/naylence/fame/security/cert/ca-types.d.ts +32 -0
  239. package/dist/types/naylence/fame/security/cert/ca-types.d.ts.map +1 -1
  240. package/dist/types/naylence/fame/security/cert/csr-types.d.ts +5 -0
  241. package/dist/types/naylence/fame/security/cert/csr-types.d.ts.map +1 -0
  242. package/dist/types/naylence/fame/security/cert/default-ca-service.d.ts +2 -1
  243. package/dist/types/naylence/fame/security/cert/default-ca-service.d.ts.map +1 -1
  244. package/dist/types/naylence/fame/security/cert/default-certificate-manager-factory.d.ts +2 -4
  245. package/dist/types/naylence/fame/security/cert/default-certificate-manager-factory.d.ts.map +1 -1
  246. package/dist/types/naylence/fame/security/cert/default-certificate-manager.d.ts +32 -0
  247. package/dist/types/naylence/fame/security/cert/default-certificate-manager.d.ts.map +1 -1
  248. package/dist/types/naylence/fame/security/cert/index.d.ts +9 -1
  249. package/dist/types/naylence/fame/security/cert/index.d.ts.map +1 -1
  250. package/dist/types/naylence/fame/security/cert/internal-ca-service.d.ts +0 -3
  251. package/dist/types/naylence/fame/security/cert/internal-ca-service.d.ts.map +1 -1
  252. package/dist/types/naylence/fame/security/cert/node-ed25519-csr.d.ts +9 -0
  253. package/dist/types/naylence/fame/security/cert/node-ed25519-csr.d.ts.map +1 -0
  254. package/dist/types/naylence/fame/security/cert/oid-constants.d.ts +7 -0
  255. package/dist/types/naylence/fame/security/cert/oid-constants.d.ts.map +1 -0
  256. package/dist/types/naylence/fame/security/cert/trust-store/anchor-utils.d.ts +12 -0
  257. package/dist/types/naylence/fame/security/cert/trust-store/anchor-utils.d.ts.map +1 -0
  258. package/dist/types/naylence/fame/security/cert/trust-store/browser-trust-store-provider-factory.d.ts +28 -0
  259. package/dist/types/naylence/fame/security/cert/trust-store/browser-trust-store-provider-factory.d.ts.map +1 -0
  260. package/dist/types/naylence/fame/security/cert/trust-store/env-provider.d.ts +7 -0
  261. package/dist/types/naylence/fame/security/cert/trust-store/env-provider.d.ts.map +1 -0
  262. package/dist/types/naylence/fame/security/cert/trust-store/fame-ca-certs-parser.d.ts +9 -0
  263. package/dist/types/naylence/fame/security/cert/trust-store/fame-ca-certs-parser.d.ts.map +1 -0
  264. package/dist/types/naylence/fame/security/cert/trust-store/http-bundle-provider.d.ts +37 -0
  265. package/dist/types/naylence/fame/security/cert/trust-store/http-bundle-provider.d.ts.map +1 -0
  266. package/dist/types/naylence/fame/security/cert/trust-store/http-signed-bundle-provider.d.ts +2 -0
  267. package/dist/types/naylence/fame/security/cert/trust-store/http-signed-bundle-provider.d.ts.map +1 -0
  268. package/dist/types/naylence/fame/security/cert/trust-store/node-trust-store-provider-factory.d.ts +22 -0
  269. package/dist/types/naylence/fame/security/cert/trust-store/node-trust-store-provider-factory.d.ts.map +1 -0
  270. package/dist/types/naylence/fame/security/cert/trust-store/static-bundle-provider.d.ts +15 -0
  271. package/dist/types/naylence/fame/security/cert/trust-store/static-bundle-provider.d.ts.map +1 -0
  272. package/dist/types/naylence/fame/security/cert/trust-store/trust-store-provider-factory.d.ts +28 -0
  273. package/dist/types/naylence/fame/security/cert/trust-store/trust-store-provider-factory.d.ts.map +1 -0
  274. package/dist/types/naylence/fame/security/cert/trust-store/trust-store-provider.d.ts +43 -0
  275. package/dist/types/naylence/fame/security/cert/trust-store/trust-store-provider.d.ts.map +1 -0
  276. package/dist/types/naylence/fame/security/cert/util.d.ts.map +1 -1
  277. package/dist/types/naylence/fame/security/encryption/channel/channel-encryption-manager.d.ts.map +1 -1
  278. package/dist/types/naylence/fame/security/register-advanced-security-factories.d.ts.map +1 -1
  279. package/dist/types/naylence/fame/security/signing/eddsa-envelope-signer-factory.d.ts +1 -2
  280. package/dist/types/naylence/fame/security/signing/eddsa-envelope-signer-factory.d.ts.map +1 -1
  281. package/dist/types/naylence/fame/security/signing/eddsa-envelope-verifier-factory.d.ts +2 -2
  282. package/dist/types/naylence/fame/security/signing/eddsa-envelope-verifier-factory.d.ts.map +1 -1
  283. package/dist/types/naylence/fame/security/signing/eddsa-envelope-verifier.d.ts +5 -0
  284. package/dist/types/naylence/fame/security/signing/eddsa-envelope-verifier.d.ts.map +1 -1
  285. package/dist/types/node.d.ts +11 -0
  286. package/dist/types/node.d.ts.map +1 -0
  287. package/dist/types/plugin.d.ts.map +1 -1
  288. package/dist/types/version.d.ts +6 -0
  289. package/dist/types/version.d.ts.map +1 -0
  290. package/package.json +88 -14
  291. package/dist/browser/index.js +0 -25070
  292. package/dist/browser/index.js.map +0 -1
@@ -0,0 +1,82 @@
1
+ /**
2
+ * Isomorphic entry point for Naylence Advanced Security.
3
+ *
4
+ * Exposes browser-safe security helpers alongside the factory registrar while
5
+ * installing the shared dynamic importer shim used by Naylence plugins.
6
+ */
7
+ export { VERSION } from "./version.js";
8
+ export { validateJwkX5cCertificate, publicKeyFromX5c, } from "./naylence/fame/security/cert/util.js";
9
+ export { GRANT_PURPOSE_CA_SIGN } from "./naylence/fame/security/cert/grants.js";
10
+ export { createEd25519Csr, } from "./naylence/fame/security/cert/browser-csr.js";
11
+ export { CAServiceClient, ENV_VAR_FAME_CA_SERVICE_URL, extractCertificateInfo, formatCertificateInfo, } from "./naylence/fame/security/cert/ca-service-client.js";
12
+ export * from "./naylence/fame/security/encryption/index.js";
13
+ export { AdvancedEdDSAEnvelopeSignerFactory, FACTORY_META as ADVANCED_EDDSA_ENVELOPE_SIGNER_FACTORY_META, } from "./naylence/fame/security/signing/eddsa-envelope-signer-factory.js";
14
+ export { AdvancedEdDSAEnvelopeVerifierFactory, FACTORY_META as ADVANCED_EDDSA_ENVELOPE_VERIFIER_FACTORY_META, } from "./naylence/fame/security/signing/eddsa-envelope-verifier-factory.js";
15
+ export { EdDSAEnvelopeVerifier, } from "./naylence/fame/security/signing/eddsa-envelope-verifier.js";
16
+ export * from "./naylence/fame/security/keys/index.js";
17
+ export * from "./naylence/fame/stickiness/index.js";
18
+ export * from "./naylence/fame/welcome/index.js";
19
+ export { registerAdvancedSecurityFactories, } from "./naylence/fame/security/register-advanced-security-factories.js";
20
+ const pluginModulePromise = import("./plugin.js");
21
+ const globalScope = globalThis;
22
+ const FACTORY_MODULE_PREFIX = "@naylence/advanced-security/naylence/fame/";
23
+ const RUNTIME_LOADER_KEY = "__naylenceFactoryDynamicImporter";
24
+ const ADVANCED_SECURITY_LOADER_MARK = Symbol.for("__naylenceAdvancedSecurityLoader__");
25
+ const isAdvancedSecurityPluginSpecifier = (specifier) => specifier === "@naylence/advanced-security" ||
26
+ specifier === "@naylence/advanced-security/" ||
27
+ specifier === "@naylence/advanced-security/plugin" ||
28
+ specifier === "@naylence/advanced-security/plugin.js" ||
29
+ specifier === "@naylence/advanced-security/dist/esm/plugin.js";
30
+ const resolveFactoryModuleSpecifier = (specifier) => {
31
+ if (specifier.startsWith("../")) {
32
+ const relativePath = specifier.slice("../".length);
33
+ return `${FACTORY_MODULE_PREFIX}${relativePath}`;
34
+ }
35
+ if (specifier.startsWith("./")) {
36
+ const relativePath = specifier.slice("./".length);
37
+ return `${FACTORY_MODULE_PREFIX}${relativePath}`;
38
+ }
39
+ return null;
40
+ };
41
+ const isModuleNotFoundError = (error) => {
42
+ const message = error instanceof Error ? error.message : String(error);
43
+ return (message.includes("Cannot find module") ||
44
+ message.includes("ERR_MODULE_NOT_FOUND") ||
45
+ message.includes("Unknown file extension") ||
46
+ message.includes("Failed to fetch dynamically imported module") ||
47
+ message.includes("Failed to resolve module specifier") ||
48
+ message.includes("Importing a module script failed"));
49
+ };
50
+ const ensureAdvancedSecurityPluginLoader = () => {
51
+ const existing = Reflect.get(globalScope, RUNTIME_LOADER_KEY);
52
+ if (typeof existing === "function" &&
53
+ Reflect.get(existing, ADVANCED_SECURITY_LOADER_MARK)) {
54
+ return existing;
55
+ }
56
+ const fallbackLoader = typeof existing === "function" ? existing : undefined;
57
+ const loader = async (specifier) => {
58
+ if (isAdvancedSecurityPluginSpecifier(specifier)) {
59
+ return pluginModulePromise;
60
+ }
61
+ const remapped = resolveFactoryModuleSpecifier(specifier);
62
+ if (remapped) {
63
+ try {
64
+ return await import(/* @vite-ignore */ remapped);
65
+ }
66
+ catch (error) {
67
+ if (!fallbackLoader || !isModuleNotFoundError(error)) {
68
+ throw error;
69
+ }
70
+ }
71
+ }
72
+ if (fallbackLoader) {
73
+ return fallbackLoader(specifier);
74
+ }
75
+ return import(/* @vite-ignore */ specifier);
76
+ };
77
+ Reflect.set(loader, ADVANCED_SECURITY_LOADER_MARK, true);
78
+ Reflect.set(globalScope, RUNTIME_LOADER_KEY, loader);
79
+ return loader;
80
+ };
81
+ export const __advancedSecurityPluginLoader = ensureAdvancedSecurityPluginLoader();
82
+ //# sourceMappingURL=advanced-security-isomorphic.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"advanced-security-isomorphic.js","sourceRoot":"","sources":["../../src/advanced-security-isomorphic.ts"],"names":[],"mappings":"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"}
@@ -1,6 +1,25 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- const tslib_1 = require("tslib");
4
- // Browser-friendly entry point. Limit exports to APIs that are safe for browser usage.
5
- tslib_1.__exportStar(require("./index.js"), exports);
1
+ /**
2
+ * Browser-friendly entry point that exposes only modules compatible with
3
+ * runtimes lacking Node.js built-ins. Node-specific certificate authority
4
+ * helpers and Fastify bindings are intentionally excluded.
5
+ */
6
+ // Import and use the loader to ensure bundlers don't tree-shake it away
7
+ import { __advancedSecurityPluginLoader } from "./advanced-security-isomorphic.js";
8
+ // Mark as used so bundlers keep the import
9
+ if (typeof __advancedSecurityPluginLoader === "undefined") {
10
+ throw new Error("Advanced security plugin loader not initialized");
11
+ }
12
+ // Package version
13
+ export { VERSION } from './version.js';
14
+ export { validateJwkX5cCertificate, publicKeyFromX5c, } from "./naylence/fame/security/cert/util.js";
15
+ export { createEd25519Csr, } from "./naylence/fame/security/cert/browser-csr.js";
16
+ export { GRANT_PURPOSE_CA_SIGN } from "./naylence/fame/security/cert/grants.js";
17
+ export { CAServiceClient, ENV_VAR_FAME_CA_SERVICE_URL, extractCertificateInfo, formatCertificateInfo, } from "./naylence/fame/security/cert/ca-service-client.js";
18
+ export * from "./naylence/fame/security/encryption/index.js";
19
+ export { AdvancedEdDSAEnvelopeSignerFactory, FACTORY_META as ADVANCED_EDDSA_ENVELOPE_SIGNER_FACTORY_META, } from "./naylence/fame/security/signing/eddsa-envelope-signer-factory.js";
20
+ export { AdvancedEdDSAEnvelopeVerifierFactory, FACTORY_META as ADVANCED_EDDSA_ENVELOPE_VERIFIER_FACTORY_META, } from "./naylence/fame/security/signing/eddsa-envelope-verifier-factory.js";
21
+ export { EdDSAEnvelopeVerifier, } from "./naylence/fame/security/signing/eddsa-envelope-verifier.js";
22
+ export * from "./naylence/fame/security/keys/index.js";
23
+ export * from "./naylence/fame/stickiness/index.js";
24
+ export * from "./naylence/fame/welcome/index.js";
6
25
  //# sourceMappingURL=browser.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"browser.js","sourceRoot":"","sources":["../../src/browser.ts"],"names":[],"mappings":";;;AAAA,uFAAuF;AACvF,qDAA2B"}
1
+ {"version":3,"file":"browser.js","sourceRoot":"","sources":["../../src/browser.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH,wEAAwE;AACxE,OAAO,EAAE,8BAA8B,EAAE,MAAM,mCAAmC,CAAC;AAEnF,2CAA2C;AAC3C,IAAI,OAAO,8BAA8B,KAAK,WAAW,EAAE,CAAC;IAC1D,MAAM,IAAI,KAAK,CAAC,iDAAiD,CAAC,CAAC;AACrE,CAAC;AAED,kBAAkB;AAClB,OAAO,EAAE,OAAO,EAAE,MAAM,cAAc,CAAC;AAEvC,OAAO,EACN,yBAAyB,EAGzB,gBAAgB,GAEhB,MAAM,uCAAuC,CAAC;AAC/C,OAAO,EACN,gBAAgB,GAEhB,MAAM,8CAA8C,CAAC;AAEtD,OAAO,EAAE,qBAAqB,EAAE,MAAM,yCAAyC,CAAC;AAChF,OAAO,EACN,eAAe,EAGf,2BAA2B,EAC3B,sBAAsB,EACtB,qBAAqB,GACrB,MAAM,oDAAoD,CAAC;AAE5D,cAAc,8CAA8C,CAAC;AAE7D,OAAO,EACN,kCAAkC,EAClC,YAAY,IAAI,2CAA2C,GAE3D,MAAM,mEAAmE,CAAC;AAC3E,OAAO,EACN,oCAAoC,EACpC,YAAY,IAAI,6CAA6C,GAE7D,MAAM,qEAAqE,CAAC;AAC7E,OAAO,EACN,qBAAqB,GAGrB,MAAM,6DAA6D,CAAC;AAErE,cAAc,wCAAwC,CAAC;AAEvD,cAAc,qCAAqC,CAAC;AACpD,cAAc,kCAAkC,CAAC"}
package/dist/cjs/index.js CHANGED
@@ -1,7 +1,2 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- const tslib_1 = require("tslib");
4
- tslib_1.__exportStar(require("./naylence/fame/security/index.js"), exports);
5
- tslib_1.__exportStar(require("./naylence/fame/stickiness/index.js"), exports);
6
- tslib_1.__exportStar(require("./naylence/fame/welcome/index.js"), exports);
1
+ export * from './advanced-security-isomorphic.js';
7
2
  //# sourceMappingURL=index.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":";;;AAAA,4EAAkD;AAClD,8EAAoD;AACpD,2EAAiD"}
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,mCAAmC,CAAC"}
@@ -0,0 +1,2 @@
1
+ import "@naylence/runtime/install-env";
2
+ //# sourceMappingURL=install-env.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"install-env.js","sourceRoot":"","sources":["../../src/install-env.ts"],"names":[],"mappings":"AAAA,OAAO,+BAA+B,CAAC"}
@@ -1,15 +1,14 @@
1
- "use strict";
2
1
  /**
3
2
  * AUTO-GENERATED FILE. DO NOT EDIT DIRECTLY.
4
3
  * Generated by scripts/generate-factory-manifest.mjs
5
4
  *
6
5
  * Provides the list of advanced security factory modules for registration.
7
6
  */
8
- Object.defineProperty(exports, "__esModule", { value: true });
9
- exports.MODULES = void 0;
10
- exports.MODULES = [
7
+ export const MODULES = [
11
8
  "./security/cert/default-ca-service-factory.js",
12
9
  "./security/cert/default-certificate-manager-factory.js",
10
+ "./security/cert/trust-store/browser-trust-store-provider-factory.js",
11
+ "./security/cert/trust-store/node-trust-store-provider-factory.js",
13
12
  "./security/encryption/channel/channel-encryption-manager-factory.js",
14
13
  "./security/encryption/composite-encryption-manager-factory.js",
15
14
  "./security/encryption/default-secure-channel-manager-factory.js",
@@ -21,4 +20,20 @@ exports.MODULES = [
21
20
  "./stickiness/aft-replica-stickiness-manager-factory.js",
22
21
  "./welcome/advanced-welcome-service-factory.js"
23
22
  ];
23
+ export const MODULE_LOADERS = {
24
+ "./security/cert/default-ca-service-factory.js": () => import("./security/cert/default-ca-service-factory.js"),
25
+ "./security/cert/default-certificate-manager-factory.js": () => import("./security/cert/default-certificate-manager-factory.js"),
26
+ "./security/cert/trust-store/browser-trust-store-provider-factory.js": () => import("./security/cert/trust-store/browser-trust-store-provider-factory.js"),
27
+ "./security/cert/trust-store/node-trust-store-provider-factory.js": () => import("./security/cert/trust-store/node-trust-store-provider-factory.js"),
28
+ "./security/encryption/channel/channel-encryption-manager-factory.js": () => import("./security/encryption/channel/channel-encryption-manager-factory.js"),
29
+ "./security/encryption/composite-encryption-manager-factory.js": () => import("./security/encryption/composite-encryption-manager-factory.js"),
30
+ "./security/encryption/default-secure-channel-manager-factory.js": () => import("./security/encryption/default-secure-channel-manager-factory.js"),
31
+ "./security/encryption/sealed/x25519-encryption-manager-factory.js": () => import("./security/encryption/sealed/x25519-encryption-manager-factory.js"),
32
+ "./security/keys/x5c-key-manager-factory.js": () => import("./security/keys/x5c-key-manager-factory.js"),
33
+ "./security/signing/eddsa-envelope-signer-factory.js": () => import("./security/signing/eddsa-envelope-signer-factory.js"),
34
+ "./security/signing/eddsa-envelope-verifier-factory.js": () => import("./security/signing/eddsa-envelope-verifier-factory.js"),
35
+ "./stickiness/aft-load-balancer-stickiness-manager-factory.js": () => import("./stickiness/aft-load-balancer-stickiness-manager-factory.js"),
36
+ "./stickiness/aft-replica-stickiness-manager-factory.js": () => import("./stickiness/aft-replica-stickiness-manager-factory.js"),
37
+ "./welcome/advanced-welcome-service-factory.js": () => import("./welcome/advanced-welcome-service-factory.js"),
38
+ };
24
39
  //# sourceMappingURL=factory-manifest.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"factory-manifest.js","sourceRoot":"","sources":["../../../../src/naylence/fame/factory-manifest.ts"],"names":[],"mappings":";AAAA;;;;;GAKG;;;AAEU,QAAA,OAAO,GAAG;IACrB,+CAA+C;IAC/C,wDAAwD;IACxD,qEAAqE;IACrE,+DAA+D;IAC/D,iEAAiE;IACjE,mEAAmE;IACnE,4CAA4C;IAC5C,qDAAqD;IACrD,uDAAuD;IACvD,8DAA8D;IAC9D,wDAAwD;IACxD,+CAA+C;CACvC,CAAC"}
1
+ {"version":3,"file":"factory-manifest.js","sourceRoot":"","sources":["../../../../src/naylence/fame/factory-manifest.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAEH,MAAM,CAAC,MAAM,OAAO,GAAG;IACrB,+CAA+C;IAC/C,wDAAwD;IACxD,qEAAqE;IACrE,kEAAkE;IAClE,qEAAqE;IACrE,+DAA+D;IAC/D,iEAAiE;IACjE,mEAAmE;IACnE,4CAA4C;IAC5C,qDAAqD;IACrD,uDAAuD;IACvD,8DAA8D;IAC9D,wDAAwD;IACxD,+CAA+C;CACvC,CAAC;AAKX,MAAM,CAAC,MAAM,cAAc,GAAmD;IAC5E,+CAA+C,EAAE,GAAG,EAAE,CAAC,MAAM,CAAC,+CAA+C,CAAC;IAC9G,wDAAwD,EAAE,GAAG,EAAE,CAAC,MAAM,CAAC,wDAAwD,CAAC;IAChI,qEAAqE,EAAE,GAAG,EAAE,CAAC,MAAM,CAAC,qEAAqE,CAAC;IAC1J,kEAAkE,EAAE,GAAG,EAAE,CAAC,MAAM,CAAC,kEAAkE,CAAC;IACpJ,qEAAqE,EAAE,GAAG,EAAE,CAAC,MAAM,CAAC,qEAAqE,CAAC;IAC1J,+DAA+D,EAAE,GAAG,EAAE,CAAC,MAAM,CAAC,+DAA+D,CAAC;IAC9I,iEAAiE,EAAE,GAAG,EAAE,CAAC,MAAM,CAAC,iEAAiE,CAAC;IAClJ,mEAAmE,EAAE,GAAG,EAAE,CAAC,MAAM,CAAC,mEAAmE,CAAC;IACtJ,4CAA4C,EAAE,GAAG,EAAE,CAAC,MAAM,CAAC,4CAA4C,CAAC;IACxG,qDAAqD,EAAE,GAAG,EAAE,CAAC,MAAM,CAAC,qDAAqD,CAAC;IAC1H,uDAAuD,EAAE,GAAG,EAAE,CAAC,MAAM,CAAC,uDAAuD,CAAC;IAC9H,8DAA8D,EAAE,GAAG,EAAE,CAAC,MAAM,CAAC,8DAA8D,CAAC;IAC5I,wDAAwD,EAAE,GAAG,EAAE,CAAC,MAAM,CAAC,wDAAwD,CAAC;IAChI,+CAA+C,EAAE,GAAG,EAAE,CAAC,MAAM,CAAC,+CAA+C,CAAC;CAC/G,CAAC"}
@@ -0,0 +1,103 @@
1
+ import { AsnConvert, OctetString } from "@peculiar/asn1-schema";
2
+ import { Attributes, CertificationRequest, CertificationRequestInfo, } from "@peculiar/asn1-csr";
3
+ import { AlgorithmIdentifier, Attribute, AttributeTypeAndValue, AttributeValue, Extension, Extensions, GeneralName, Name, RelativeDistinguishedName, SubjectAlternativeName, SubjectPublicKeyInfo, id_ce_subjectAltName, } from "@peculiar/asn1-x509";
4
+ const ED25519_OID = "1.3.101.112";
5
+ const OID_COMMON_NAME = "2.5.4.3";
6
+ const LOGICAL_URI_PREFIX = "naylence://";
7
+ function ensureSubtleCrypto() {
8
+ const instance = globalThis.crypto?.subtle;
9
+ if (!instance) {
10
+ throw new Error("WebCrypto subtle API is required to create a CSR");
11
+ }
12
+ return instance;
13
+ }
14
+ function buildSubject(commonName) {
15
+ if (!commonName || typeof commonName !== "string") {
16
+ throw new Error("commonName must be a non-empty string");
17
+ }
18
+ return new Name([
19
+ new RelativeDistinguishedName([
20
+ new AttributeTypeAndValue({
21
+ type: OID_COMMON_NAME,
22
+ value: new AttributeValue({ utf8String: commonName }),
23
+ }),
24
+ ]),
25
+ ]);
26
+ }
27
+ function arrayBufferToBase64(buffer) {
28
+ const bytes = new Uint8Array(buffer);
29
+ if (typeof globalThis.Buffer?.from === "function") {
30
+ return globalThis.Buffer.from(bytes).toString("base64");
31
+ }
32
+ let binary = "";
33
+ const chunkSize = 0x8000;
34
+ for (let offset = 0; offset < bytes.length; offset += chunkSize) {
35
+ const slice = bytes.subarray(offset, offset + chunkSize);
36
+ binary += String.fromCharCode(...slice);
37
+ }
38
+ if (typeof globalThis.btoa !== "function") {
39
+ throw new Error("Base64 encoding not available in this environment");
40
+ }
41
+ return globalThis.btoa(binary);
42
+ }
43
+ function derToPem(der, label) {
44
+ const base64 = arrayBufferToBase64(der);
45
+ const lines = [];
46
+ for (let index = 0; index < base64.length; index += 64) {
47
+ lines.push(base64.slice(index, index + 64));
48
+ }
49
+ return `-----BEGIN ${label}-----\n${lines.join("\n")}\n-----END ${label}-----\n`;
50
+ }
51
+ export async function createEd25519Csr(options) {
52
+ const subtle = ensureSubtleCrypto();
53
+ const { privateKey, publicKey, commonName } = options;
54
+ if (!(privateKey instanceof CryptoKey) || privateKey.type !== "private") {
55
+ throw new Error("privateKey must be a CryptoKey of type 'private'");
56
+ }
57
+ if (!(publicKey instanceof CryptoKey) || publicKey.type !== "public") {
58
+ throw new Error("publicKey must be a CryptoKey of type 'public'");
59
+ }
60
+ const subject = buildSubject(commonName);
61
+ const spkiDer = await subtle.exportKey("spki", publicKey);
62
+ const subjectPublicKeyInfo = AsnConvert.parse(spkiDer, SubjectPublicKeyInfo);
63
+ const attributes = new Attributes();
64
+ const sanitizedLogicals = Array.isArray(options.logicals)
65
+ ? options.logicals
66
+ .map((logical) => logical.trim())
67
+ .filter((logical) => logical.length > 0)
68
+ : [];
69
+ if (sanitizedLogicals.length > 0) {
70
+ const san = new SubjectAlternativeName(sanitizedLogicals.map((logical) => new GeneralName({
71
+ uniformResourceIdentifier: `${LOGICAL_URI_PREFIX}${logical}`,
72
+ })));
73
+ const extensions = new Extensions([
74
+ new Extension({
75
+ extnID: id_ce_subjectAltName,
76
+ critical: false,
77
+ extnValue: new OctetString(AsnConvert.serialize(san)),
78
+ }),
79
+ ]);
80
+ attributes.push(new Attribute({
81
+ type: "1.2.840.113549.1.9.14",
82
+ values: [AsnConvert.serialize(extensions)],
83
+ }));
84
+ }
85
+ const requestInfo = new CertificationRequestInfo({
86
+ subject,
87
+ subjectPKInfo: subjectPublicKeyInfo,
88
+ attributes,
89
+ });
90
+ const requestInfoDer = AsnConvert.serialize(requestInfo);
91
+ const signature = await subtle.sign("Ed25519", privateKey, requestInfoDer);
92
+ const certificationRequest = new CertificationRequest({
93
+ certificationRequestInfo: requestInfo,
94
+ signatureAlgorithm: new AlgorithmIdentifier({
95
+ algorithm: ED25519_OID,
96
+ }),
97
+ signature,
98
+ });
99
+ const csrDer = AsnConvert.serialize(certificationRequest);
100
+ const csrPem = derToPem(csrDer, "CERTIFICATE REQUEST");
101
+ return { csrPem, csrDer };
102
+ }
103
+ //# sourceMappingURL=browser-csr.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"browser-csr.js","sourceRoot":"","sources":["../../../../../../src/naylence/fame/security/cert/browser-csr.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,30 @@
1
+ #!/usr/bin/env node
2
+ import { pathToFileURL } from "node:url";
3
+ import { main } from "./ca-server.js";
4
+ function isDirectExecution() {
5
+ if (typeof process === "undefined") {
6
+ return false;
7
+ }
8
+ const entry = process.argv?.[1];
9
+ if (typeof entry !== "string" || entry.length === 0) {
10
+ return false;
11
+ }
12
+ const entryUrl = pathToFileURL(entry).href;
13
+ return import.meta.url === entryUrl;
14
+ }
15
+ function registerSignalHandlers() {
16
+ const handleShutdown = (signal) => {
17
+ console.log("[INFO] ca_server_shutting_down", { signal });
18
+ process.exit(0);
19
+ };
20
+ process.on("SIGTERM", () => handleShutdown("SIGTERM"));
21
+ process.on("SIGINT", () => handleShutdown("SIGINT"));
22
+ }
23
+ if (isDirectExecution()) {
24
+ registerSignalHandlers();
25
+ main().catch((error) => {
26
+ console.error("Fatal error:", error);
27
+ process.exit(1);
28
+ });
29
+ }
30
+ //# sourceMappingURL=ca-server-cli.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ca-server-cli.js","sourceRoot":"","sources":["../../../../../../src/naylence/fame/security/cert/ca-server-cli.ts"],"names":[],"mappings":";AACA,OAAO,EAAE,aAAa,EAAE,MAAM,UAAU,CAAC;AAEzC,OAAO,EAAE,IAAI,EAAE,MAAM,gBAAgB,CAAC;AAEtC,SAAS,iBAAiB;IACxB,IAAI,OAAO,OAAO,KAAK,WAAW,EAAE,CAAC;QACnC,OAAO,KAAK,CAAC;IACf,CAAC;IAED,MAAM,KAAK,GAAG,OAAO,CAAC,IAAI,EAAE,CAAC,CAAC,CAAC,CAAC;IAChC,IAAI,OAAO,KAAK,KAAK,QAAQ,IAAI,KAAK,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;QACpD,OAAO,KAAK,CAAC;IACf,CAAC;IAED,MAAM,QAAQ,GAAG,aAAa,CAAC,KAAK,CAAC,CAAC,IAAI,CAAC;IAC3C,OAAO,MAAM,CAAC,IAAI,CAAC,GAAG,KAAK,QAAQ,CAAC;AACtC,CAAC;AAED,SAAS,sBAAsB;IAC7B,MAAM,cAAc,GAAG,CAAC,MAAsB,EAAE,EAAE;QAChD,OAAO,CAAC,GAAG,CAAC,gCAAgC,EAAE,EAAE,MAAM,EAAE,CAAC,CAAC;QAC1D,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IAClB,CAAC,CAAC;IAEF,OAAO,CAAC,EAAE,CAAC,SAAS,EAAE,GAAG,EAAE,CAAC,cAAc,CAAC,SAAS,CAAC,CAAC,CAAC;IACvD,OAAO,CAAC,EAAE,CAAC,QAAQ,EAAE,GAAG,EAAE,CAAC,cAAc,CAAC,QAAQ,CAAC,CAAC,CAAC;AACvD,CAAC;AAED,IAAI,iBAAiB,EAAE,EAAE,CAAC;IACxB,sBAAsB,EAAE,CAAC;IAEzB,IAAI,EAAE,CAAC,KAAK,CAAC,CAAC,KAAK,EAAE,EAAE;QACrB,OAAO,CAAC,KAAK,CAAC,cAAc,EAAE,KAAK,CAAC,CAAC;QACrC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IAClB,CAAC,CAAC,CAAC;AACL,CAAC"}
@@ -0,0 +1,223 @@
1
+ /**
2
+ * CA Server - Certificate Authority HTTP endpoint
3
+ *
4
+ * Provides certificate issuance via HTTP using Fastify.
5
+ * Mirrors the Python ca_server.py implementation.
6
+ */
7
+ import { sha256 } from "@noble/hashes/sha256.js";
8
+ import Fastify from "fastify";
9
+ import { realpathSync } from "node:fs";
10
+ import { resolve } from "node:path";
11
+ import { CAServiceFactory } from "./ca-service-factory.js";
12
+ // Simple console logger for CA server
13
+ const logger = {
14
+ info: (event, meta) => {
15
+ console.log(`[INFO] ${event}`, meta || "");
16
+ },
17
+ warning: (event, meta) => {
18
+ console.warn(`[WARNING] ${event}`, meta || "");
19
+ },
20
+ error: (event, meta) => {
21
+ console.error(`[ERROR] ${event}`, meta || "");
22
+ },
23
+ debug: (event, meta) => {
24
+ const logLevel = (process.env.FAME_LOG_LEVEL || "info").toLowerCase();
25
+ if (logLevel === "debug" || logLevel === "trace") {
26
+ console.log(`[DEBUG] ${event}`, meta || "");
27
+ }
28
+ },
29
+ };
30
+ const ENV_VAR_FAME_APP_HOST = "FAME_APP_HOST";
31
+ const ENV_VAR_FAME_APP_PORT = "FAME_APP_PORT";
32
+ /**
33
+ * Create CA router with certificate signing endpoint.
34
+ * Mirrors Python's create_ca_router functionality.
35
+ */
36
+ function createCaRouter(fastify, caService, prefix = "/fame/v1/ca") {
37
+ // Certificate signing endpoint
38
+ fastify.post(`${prefix}/sign`, {
39
+ schema: {
40
+ body: {
41
+ type: "object",
42
+ required: ["csr_pem", "requester_id"],
43
+ properties: {
44
+ csr_pem: { type: "string" },
45
+ requester_id: { type: "string" },
46
+ physical_path: { type: "string" },
47
+ logicals: { type: "array", items: { type: "string" } },
48
+ },
49
+ },
50
+ },
51
+ }, async (request, reply) => {
52
+ try {
53
+ const csrRequest = request.body;
54
+ if (!csrRequest || !csrRequest.requester_id) {
55
+ return reply.status(400).send({
56
+ error: "invalid_request",
57
+ message: "CSR must include requester_id",
58
+ });
59
+ }
60
+ logger.debug("ca_cert_request_received", {
61
+ requester_id: csrRequest.requester_id,
62
+ physical_path: csrRequest.physical_path,
63
+ logicals: csrRequest.logicals,
64
+ });
65
+ // Authenticate if authorizer is configured
66
+ if (caService.authorizer) {
67
+ // TODO: Implement authentication when authorizer interface is defined
68
+ logger.warning("authentication_not_yet_implemented", {
69
+ authorizer_configured: true,
70
+ });
71
+ }
72
+ // Convert snake_case request to camelCase for TypeScript interface
73
+ const csrForService = {
74
+ csrPem: csrRequest.csr_pem,
75
+ requesterId: csrRequest.requester_id,
76
+ physicalPath: csrRequest.physical_path,
77
+ logicals: csrRequest.logicals,
78
+ };
79
+ // Issue certificate
80
+ const result = await caService.issueCertificate(csrForService);
81
+ const response = {
82
+ certificate_pem: result.certificatePem,
83
+ certificate_chain_pem: result.certificateChainPem,
84
+ expires_at: result.expiresAt,
85
+ };
86
+ return reply.send(response);
87
+ }
88
+ catch (error) {
89
+ logger.error("ca_cert_issuance_failed", {
90
+ error: error instanceof Error ? error.message : String(error),
91
+ });
92
+ return reply.status(500).send({
93
+ error: "issuance_failed",
94
+ message: error instanceof Error ? error.message : "Unknown error",
95
+ });
96
+ }
97
+ });
98
+ // Health check
99
+ fastify.get("/health", async () => {
100
+ return { status: "healthy", service: "ca-server" };
101
+ });
102
+ const trustBundlePath = "/.well-known/naylence/trust-bundle.json";
103
+ fastify.get(trustBundlePath, async (request, reply) => {
104
+ const bundle = await caService.getTrustBundle();
105
+ if (!bundle) {
106
+ return reply.status(404).send({
107
+ error: "trust_bundle_unavailable",
108
+ });
109
+ }
110
+ const payload = JSON.stringify(bundle);
111
+ const etag = `"${computeEtag(payload)}"`;
112
+ const requestEtag = request.headers["if-none-match"];
113
+ if (typeof requestEtag === "string" && requestEtag.replace(/W\//u, "") === etag.replace(/W\//u, "")) {
114
+ return reply
115
+ .status(304)
116
+ .header("ETag", etag)
117
+ .header("Cache-Control", trustBundleCacheControl())
118
+ .send();
119
+ }
120
+ return reply
121
+ .header("Content-Type", "application/json")
122
+ .header("Cache-Control", trustBundleCacheControl())
123
+ .header("ETag", etag)
124
+ .send(bundle);
125
+ });
126
+ }
127
+ /**
128
+ * Create Fastify application with CA service lifespan management.
129
+ * Mirrors Python's FastAPI lifespan pattern.
130
+ */
131
+ async function createApp() {
132
+ // Disable Fastify's built-in logger to avoid configuration conflicts
133
+ const fastify = Fastify({
134
+ logger: false,
135
+ });
136
+ // Register advanced security factories (including CA service factory)
137
+ const { registerAdvancedSecurityPluginFactories } = await import("../../../../plugin.js");
138
+ await registerAdvancedSecurityPluginFactories();
139
+ // Create CA service (mirrors Python's lifespan startup)
140
+ const caService = await CAServiceFactory.createCAService();
141
+ // Register CA router
142
+ createCaRouter(fastify, caService);
143
+ return { app: fastify, caService };
144
+ }
145
+ async function main() {
146
+ try {
147
+ const { app } = await createApp();
148
+ const host = process.env[ENV_VAR_FAME_APP_HOST] || "0.0.0.0";
149
+ const port = parseInt(process.env[ENV_VAR_FAME_APP_PORT] || "8098", 10);
150
+ await app.listen({ host, port });
151
+ logger.info("ca_server_started", { host, port });
152
+ console.log(`\nšŸ“ CA Server listening on http://${host}:${port}`);
153
+ console.log(`šŸ” Certificate endpoint: http://${host}:${port}/fame/v1/ca/sign\n`);
154
+ }
155
+ catch (error) {
156
+ logger.error("ca_server_startup_failed", {
157
+ error: error instanceof Error ? error.message : String(error),
158
+ });
159
+ process.exit(1);
160
+ }
161
+ }
162
+ export { createApp, main };
163
+ const isTopLevelInvocation = (() => {
164
+ if (typeof process === "undefined") {
165
+ return false;
166
+ }
167
+ const entry = process.argv[1] ?? null;
168
+ if (!entry) {
169
+ if (process.env.FAME_CA_DEBUG === "1") {
170
+ console.log("[CA DEBUG] missing process argv entry", JSON.stringify({ argv: process.argv }));
171
+ }
172
+ return false;
173
+ }
174
+ try {
175
+ const entryPath = resolveToRealPath(entry);
176
+ if (!entryPath) {
177
+ if (process.env.FAME_CA_DEBUG === "1") {
178
+ console.log("[CA DEBUG] failed to resolve entry path", JSON.stringify({ entry }));
179
+ }
180
+ return false;
181
+ }
182
+ if (process.env.FAME_CA_DEBUG === "1") {
183
+ console.log("[CA DEBUG] invocation check", JSON.stringify({
184
+ argv: process.argv,
185
+ entryPath,
186
+ }));
187
+ }
188
+ return /(?:^|[\\/])ca-server\.js$/u.test(entryPath);
189
+ }
190
+ catch (error) {
191
+ if (process.env.FAME_CA_DEBUG === "1") {
192
+ console.log("[CA DEBUG] invocation check error", JSON.stringify({ error: error instanceof Error ? error.message : String(error) }));
193
+ }
194
+ return false;
195
+ }
196
+ })();
197
+ if (isTopLevelInvocation) {
198
+ void main();
199
+ }
200
+ function computeEtag(payload) {
201
+ const encoder = new TextEncoder();
202
+ const digest = sha256(encoder.encode(payload));
203
+ return Array.from(digest)
204
+ .map((byte) => byte.toString(16).padStart(2, "0"))
205
+ .join("");
206
+ }
207
+ function trustBundleCacheControl() {
208
+ return "public, max-age=3600, stale-while-revalidate=86400";
209
+ }
210
+ function resolveToRealPath(pathLike) {
211
+ try {
212
+ return realpathSync(pathLike);
213
+ }
214
+ catch {
215
+ try {
216
+ return realpathSync.native?.(pathLike) ?? resolve(pathLike);
217
+ }
218
+ catch {
219
+ return resolve(pathLike);
220
+ }
221
+ }
222
+ }
223
+ //# sourceMappingURL=ca-server.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ca-server.js","sourceRoot":"","sources":["../../../../../../src/naylence/fame/security/cert/ca-server.ts"],"names":[],"mappings":"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"}