@naylence/advanced-security 0.3.5-test.101 → 0.3.5-test.104

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 (170) hide show
  1. package/dist/browser/index.js +17524 -12952
  2. package/dist/browser/index.js.map +1 -1
  3. package/dist/cjs/browser.js +1 -0
  4. package/dist/cjs/browser.js.map +1 -1
  5. package/dist/cjs/naylence/fame/factory-manifest.js +18 -0
  6. package/dist/cjs/naylence/fame/factory-manifest.js.map +1 -1
  7. package/dist/cjs/naylence/fame/security/cert/browser-csr.js +103 -0
  8. package/dist/cjs/naylence/fame/security/cert/browser-csr.js.map +1 -0
  9. package/dist/cjs/naylence/fame/security/cert/ca-server-cli.js +30 -0
  10. package/dist/cjs/naylence/fame/security/cert/ca-server-cli.js.map +1 -0
  11. package/dist/cjs/naylence/fame/security/cert/ca-server.js +171 -0
  12. package/dist/cjs/naylence/fame/security/cert/ca-server.js.map +1 -0
  13. package/dist/cjs/naylence/fame/security/cert/ca-service-client.js +331 -24
  14. package/dist/cjs/naylence/fame/security/cert/ca-service-client.js.map +1 -1
  15. package/dist/cjs/naylence/fame/security/cert/ca-types.js +8 -0
  16. package/dist/cjs/naylence/fame/security/cert/ca-types.js.map +1 -1
  17. package/dist/cjs/naylence/fame/security/cert/csr-types.js +2 -0
  18. package/dist/cjs/naylence/fame/security/cert/csr-types.js.map +1 -0
  19. package/dist/cjs/naylence/fame/security/cert/default-ca-service.js +102 -1
  20. package/dist/cjs/naylence/fame/security/cert/default-ca-service.js.map +1 -1
  21. package/dist/cjs/naylence/fame/security/cert/default-certificate-manager.js +242 -65
  22. package/dist/cjs/naylence/fame/security/cert/default-certificate-manager.js.map +1 -1
  23. package/dist/cjs/naylence/fame/security/cert/index.js +7 -1
  24. package/dist/cjs/naylence/fame/security/cert/index.js.map +1 -1
  25. package/dist/cjs/naylence/fame/security/cert/internal-ca-service.js +2 -5
  26. package/dist/cjs/naylence/fame/security/cert/internal-ca-service.js.map +1 -1
  27. package/dist/cjs/naylence/fame/security/cert/node-ed25519-csr.js +156 -0
  28. package/dist/cjs/naylence/fame/security/cert/node-ed25519-csr.js.map +1 -0
  29. package/dist/cjs/naylence/fame/security/cert/oid-constants.js +7 -0
  30. package/dist/cjs/naylence/fame/security/cert/oid-constants.js.map +1 -0
  31. package/dist/cjs/naylence/fame/security/cert/trust-store/anchor-utils.js +119 -0
  32. package/dist/cjs/naylence/fame/security/cert/trust-store/anchor-utils.js.map +1 -0
  33. package/dist/cjs/naylence/fame/security/cert/trust-store/browser-trust-store-provider-factory.js +82 -0
  34. package/dist/cjs/naylence/fame/security/cert/trust-store/browser-trust-store-provider-factory.js.map +1 -0
  35. package/dist/cjs/naylence/fame/security/cert/trust-store/env-provider.js +168 -0
  36. package/dist/cjs/naylence/fame/security/cert/trust-store/env-provider.js.map +1 -0
  37. package/dist/cjs/naylence/fame/security/cert/trust-store/fame-ca-certs-parser.js +257 -0
  38. package/dist/cjs/naylence/fame/security/cert/trust-store/fame-ca-certs-parser.js.map +1 -0
  39. package/dist/cjs/naylence/fame/security/cert/trust-store/http-bundle-provider.js +497 -0
  40. package/dist/cjs/naylence/fame/security/cert/trust-store/http-bundle-provider.js.map +1 -0
  41. package/dist/cjs/naylence/fame/security/cert/trust-store/http-signed-bundle-provider.js +2 -0
  42. package/dist/cjs/naylence/fame/security/cert/trust-store/http-signed-bundle-provider.js.map +1 -0
  43. package/dist/cjs/naylence/fame/security/cert/trust-store/node-trust-store-provider-factory.js +61 -0
  44. package/dist/cjs/naylence/fame/security/cert/trust-store/node-trust-store-provider-factory.js.map +1 -0
  45. package/dist/cjs/naylence/fame/security/cert/trust-store/static-bundle-provider.js +44 -0
  46. package/dist/cjs/naylence/fame/security/cert/trust-store/static-bundle-provider.js.map +1 -0
  47. package/dist/cjs/naylence/fame/security/cert/trust-store/trust-store-provider-factory.js +40 -0
  48. package/dist/cjs/naylence/fame/security/cert/trust-store/trust-store-provider-factory.js.map +1 -0
  49. package/dist/cjs/naylence/fame/security/cert/trust-store/trust-store-provider.js +2 -0
  50. package/dist/cjs/naylence/fame/security/cert/trust-store/trust-store-provider.js.map +1 -0
  51. package/dist/cjs/naylence/fame/security/cert/util.js +1 -2
  52. package/dist/cjs/naylence/fame/security/cert/util.js.map +1 -1
  53. package/dist/cjs/naylence/fame/security/register-advanced-security-factories.js +113 -23
  54. package/dist/cjs/naylence/fame/security/register-advanced-security-factories.js.map +1 -1
  55. package/dist/cjs/naylence/fame/security/signing/eddsa-envelope-verifier-factory.js +6 -0
  56. package/dist/cjs/naylence/fame/security/signing/eddsa-envelope-verifier-factory.js.map +1 -1
  57. package/dist/cjs/naylence/fame/security/signing/eddsa-envelope-verifier.js +43 -59
  58. package/dist/cjs/naylence/fame/security/signing/eddsa-envelope-verifier.js.map +1 -1
  59. package/dist/cjs/version.js +2 -2
  60. package/dist/esm/browser.js +1 -0
  61. package/dist/esm/browser.js.map +1 -1
  62. package/dist/esm/naylence/fame/factory-manifest.js +18 -0
  63. package/dist/esm/naylence/fame/factory-manifest.js.map +1 -1
  64. package/dist/esm/naylence/fame/security/cert/browser-csr.js +103 -0
  65. package/dist/esm/naylence/fame/security/cert/browser-csr.js.map +1 -0
  66. package/dist/esm/naylence/fame/security/cert/ca-server-cli.js +30 -0
  67. package/dist/esm/naylence/fame/security/cert/ca-server-cli.js.map +1 -0
  68. package/dist/esm/naylence/fame/security/cert/ca-server.js +35 -17
  69. package/dist/esm/naylence/fame/security/cert/ca-server.js.map +1 -1
  70. package/dist/esm/naylence/fame/security/cert/ca-service-client.js +331 -24
  71. package/dist/esm/naylence/fame/security/cert/ca-service-client.js.map +1 -1
  72. package/dist/esm/naylence/fame/security/cert/ca-types.js +8 -0
  73. package/dist/esm/naylence/fame/security/cert/ca-types.js.map +1 -1
  74. package/dist/esm/naylence/fame/security/cert/csr-types.js +2 -0
  75. package/dist/esm/naylence/fame/security/cert/csr-types.js.map +1 -0
  76. package/dist/esm/naylence/fame/security/cert/default-ca-service.js +102 -1
  77. package/dist/esm/naylence/fame/security/cert/default-ca-service.js.map +1 -1
  78. package/dist/esm/naylence/fame/security/cert/default-certificate-manager.js +242 -65
  79. package/dist/esm/naylence/fame/security/cert/default-certificate-manager.js.map +1 -1
  80. package/dist/esm/naylence/fame/security/cert/index.js +7 -1
  81. package/dist/esm/naylence/fame/security/cert/index.js.map +1 -1
  82. package/dist/esm/naylence/fame/security/cert/internal-ca-service.js +2 -5
  83. package/dist/esm/naylence/fame/security/cert/internal-ca-service.js.map +1 -1
  84. package/dist/esm/naylence/fame/security/cert/node-ed25519-csr.js +156 -0
  85. package/dist/esm/naylence/fame/security/cert/node-ed25519-csr.js.map +1 -0
  86. package/dist/esm/naylence/fame/security/cert/oid-constants.js +7 -0
  87. package/dist/esm/naylence/fame/security/cert/oid-constants.js.map +1 -0
  88. package/dist/esm/naylence/fame/security/cert/trust-store/anchor-utils.js +119 -0
  89. package/dist/esm/naylence/fame/security/cert/trust-store/anchor-utils.js.map +1 -0
  90. package/dist/esm/naylence/fame/security/cert/trust-store/browser-trust-store-provider-factory.js +82 -0
  91. package/dist/esm/naylence/fame/security/cert/trust-store/browser-trust-store-provider-factory.js.map +1 -0
  92. package/dist/esm/naylence/fame/security/cert/trust-store/env-provider.js +168 -0
  93. package/dist/esm/naylence/fame/security/cert/trust-store/env-provider.js.map +1 -0
  94. package/dist/esm/naylence/fame/security/cert/trust-store/fame-ca-certs-parser.js +257 -0
  95. package/dist/esm/naylence/fame/security/cert/trust-store/fame-ca-certs-parser.js.map +1 -0
  96. package/dist/esm/naylence/fame/security/cert/trust-store/http-bundle-provider.js +497 -0
  97. package/dist/esm/naylence/fame/security/cert/trust-store/http-bundle-provider.js.map +1 -0
  98. package/dist/esm/naylence/fame/security/cert/trust-store/http-signed-bundle-provider.js +2 -0
  99. package/dist/esm/naylence/fame/security/cert/trust-store/http-signed-bundle-provider.js.map +1 -0
  100. package/dist/esm/naylence/fame/security/cert/trust-store/node-trust-store-provider-factory.js +61 -0
  101. package/dist/esm/naylence/fame/security/cert/trust-store/node-trust-store-provider-factory.js.map +1 -0
  102. package/dist/esm/naylence/fame/security/cert/trust-store/static-bundle-provider.js +44 -0
  103. package/dist/esm/naylence/fame/security/cert/trust-store/static-bundle-provider.js.map +1 -0
  104. package/dist/esm/naylence/fame/security/cert/trust-store/trust-store-provider-factory.js +40 -0
  105. package/dist/esm/naylence/fame/security/cert/trust-store/trust-store-provider-factory.js.map +1 -0
  106. package/dist/esm/naylence/fame/security/cert/trust-store/trust-store-provider.js +2 -0
  107. package/dist/esm/naylence/fame/security/cert/trust-store/trust-store-provider.js.map +1 -0
  108. package/dist/esm/naylence/fame/security/cert/util.js +1 -2
  109. package/dist/esm/naylence/fame/security/cert/util.js.map +1 -1
  110. package/dist/esm/naylence/fame/security/register-advanced-security-factories.js +113 -23
  111. package/dist/esm/naylence/fame/security/register-advanced-security-factories.js.map +1 -1
  112. package/dist/esm/naylence/fame/security/signing/eddsa-envelope-verifier-factory.js +6 -0
  113. package/dist/esm/naylence/fame/security/signing/eddsa-envelope-verifier-factory.js.map +1 -1
  114. package/dist/esm/naylence/fame/security/signing/eddsa-envelope-verifier.js +43 -59
  115. package/dist/esm/naylence/fame/security/signing/eddsa-envelope-verifier.js.map +1 -1
  116. package/dist/esm/version.js +2 -2
  117. package/dist/types/browser.d.ts +2 -0
  118. package/dist/types/browser.d.ts.map +1 -1
  119. package/dist/types/naylence/fame/factory-manifest.d.ts +3 -1
  120. package/dist/types/naylence/fame/factory-manifest.d.ts.map +1 -1
  121. package/dist/types/naylence/fame/security/cert/browser-csr.d.ts +9 -0
  122. package/dist/types/naylence/fame/security/cert/browser-csr.d.ts.map +1 -0
  123. package/dist/types/naylence/fame/security/cert/ca-server-cli.d.ts +3 -0
  124. package/dist/types/naylence/fame/security/cert/ca-server-cli.d.ts.map +1 -0
  125. package/dist/types/naylence/fame/security/cert/ca-server.d.ts +2 -2
  126. package/dist/types/naylence/fame/security/cert/ca-server.d.ts.map +1 -1
  127. package/dist/types/naylence/fame/security/cert/ca-service-client.d.ts.map +1 -1
  128. package/dist/types/naylence/fame/security/cert/ca-types.d.ts +32 -0
  129. package/dist/types/naylence/fame/security/cert/ca-types.d.ts.map +1 -1
  130. package/dist/types/naylence/fame/security/cert/csr-types.d.ts +5 -0
  131. package/dist/types/naylence/fame/security/cert/csr-types.d.ts.map +1 -0
  132. package/dist/types/naylence/fame/security/cert/default-ca-service.d.ts +2 -1
  133. package/dist/types/naylence/fame/security/cert/default-ca-service.d.ts.map +1 -1
  134. package/dist/types/naylence/fame/security/cert/default-certificate-manager.d.ts +33 -1
  135. package/dist/types/naylence/fame/security/cert/default-certificate-manager.d.ts.map +1 -1
  136. package/dist/types/naylence/fame/security/cert/index.d.ts +9 -1
  137. package/dist/types/naylence/fame/security/cert/index.d.ts.map +1 -1
  138. package/dist/types/naylence/fame/security/cert/internal-ca-service.d.ts +0 -3
  139. package/dist/types/naylence/fame/security/cert/internal-ca-service.d.ts.map +1 -1
  140. package/dist/types/naylence/fame/security/cert/node-ed25519-csr.d.ts +9 -0
  141. package/dist/types/naylence/fame/security/cert/node-ed25519-csr.d.ts.map +1 -0
  142. package/dist/types/naylence/fame/security/cert/oid-constants.d.ts +7 -0
  143. package/dist/types/naylence/fame/security/cert/oid-constants.d.ts.map +1 -0
  144. package/dist/types/naylence/fame/security/cert/trust-store/anchor-utils.d.ts +12 -0
  145. package/dist/types/naylence/fame/security/cert/trust-store/anchor-utils.d.ts.map +1 -0
  146. package/dist/types/naylence/fame/security/cert/trust-store/browser-trust-store-provider-factory.d.ts +29 -0
  147. package/dist/types/naylence/fame/security/cert/trust-store/browser-trust-store-provider-factory.d.ts.map +1 -0
  148. package/dist/types/naylence/fame/security/cert/trust-store/env-provider.d.ts +7 -0
  149. package/dist/types/naylence/fame/security/cert/trust-store/env-provider.d.ts.map +1 -0
  150. package/dist/types/naylence/fame/security/cert/trust-store/fame-ca-certs-parser.d.ts +9 -0
  151. package/dist/types/naylence/fame/security/cert/trust-store/fame-ca-certs-parser.d.ts.map +1 -0
  152. package/dist/types/naylence/fame/security/cert/trust-store/http-bundle-provider.d.ts +35 -0
  153. package/dist/types/naylence/fame/security/cert/trust-store/http-bundle-provider.d.ts.map +1 -0
  154. package/dist/types/naylence/fame/security/cert/trust-store/http-signed-bundle-provider.d.ts +2 -0
  155. package/dist/types/naylence/fame/security/cert/trust-store/http-signed-bundle-provider.d.ts.map +1 -0
  156. package/dist/types/naylence/fame/security/cert/trust-store/node-trust-store-provider-factory.d.ts +23 -0
  157. package/dist/types/naylence/fame/security/cert/trust-store/node-trust-store-provider-factory.d.ts.map +1 -0
  158. package/dist/types/naylence/fame/security/cert/trust-store/static-bundle-provider.d.ts +15 -0
  159. package/dist/types/naylence/fame/security/cert/trust-store/static-bundle-provider.d.ts.map +1 -0
  160. package/dist/types/naylence/fame/security/cert/trust-store/trust-store-provider-factory.d.ts +28 -0
  161. package/dist/types/naylence/fame/security/cert/trust-store/trust-store-provider-factory.d.ts.map +1 -0
  162. package/dist/types/naylence/fame/security/cert/trust-store/trust-store-provider.d.ts +43 -0
  163. package/dist/types/naylence/fame/security/cert/trust-store/trust-store-provider.d.ts.map +1 -0
  164. package/dist/types/naylence/fame/security/cert/util.d.ts.map +1 -1
  165. package/dist/types/naylence/fame/security/register-advanced-security-factories.d.ts.map +1 -1
  166. package/dist/types/naylence/fame/security/signing/eddsa-envelope-verifier-factory.d.ts.map +1 -1
  167. package/dist/types/naylence/fame/security/signing/eddsa-envelope-verifier.d.ts +5 -0
  168. package/dist/types/naylence/fame/security/signing/eddsa-envelope-verifier.d.ts.map +1 -1
  169. package/dist/types/version.d.ts +1 -1
  170. package/package.json +9 -6
@@ -6,6 +6,7 @@
6
6
  // Package version
7
7
  export { VERSION } from './version.js';
8
8
  export { validateJwkX5cCertificate, publicKeyFromX5c, } from "./naylence/fame/security/cert/util.js";
9
+ export { createEd25519Csr, } from "./naylence/fame/security/cert/browser-csr.js";
9
10
  export { GRANT_PURPOSE_CA_SIGN } from "./naylence/fame/security/cert/grants.js";
10
11
  export { CAServiceClient, ENV_VAR_FAME_CA_SERVICE_URL, extractCertificateInfo, formatCertificateInfo, } from "./naylence/fame/security/cert/ca-service-client.js";
11
12
  export * from "./naylence/fame/security/encryption/index.js";
@@ -1 +1 @@
1
- {"version":3,"file":"browser.js","sourceRoot":"","sources":["../../src/browser.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH,kBAAkB;AAClB,OAAO,EAAE,OAAO,EAAE,MAAM,cAAc,CAAC;AAEvC,OAAO,EACN,yBAAyB,EAGzB,gBAAgB,GAEhB,MAAM,uCAAuC,CAAC;AAC/C,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,OAAO,EACN,iCAAiC,GAEjC,MAAM,kEAAkE,CAAC;AAE1E,cAAc,qCAAqC,CAAC;AACpD,cAAc,kCAAkC,CAAC"}
1
+ {"version":3,"file":"browser.js","sourceRoot":"","sources":["../../src/browser.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH,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,OAAO,EACN,iCAAiC,GAEjC,MAAM,kEAAkE,CAAC;AAE1E,cAAc,qCAAqC,CAAC;AACpD,cAAc,kCAAkC,CAAC"}
@@ -7,6 +7,8 @@
7
7
  export const MODULES = [
8
8
  "./security/cert/default-ca-service-factory.js",
9
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",
10
12
  "./security/encryption/channel/channel-encryption-manager-factory.js",
11
13
  "./security/encryption/composite-encryption-manager-factory.js",
12
14
  "./security/encryption/default-secure-channel-manager-factory.js",
@@ -18,4 +20,20 @@ export const MODULES = [
18
20
  "./stickiness/aft-replica-stickiness-manager-factory.js",
19
21
  "./welcome/advanced-welcome-service-factory.js"
20
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
+ };
21
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;AAEH,MAAM,CAAC,MAAM,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,171 @@
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 { CAServiceFactory } from "./ca-service-factory.js";
10
+ // Simple console logger for CA server
11
+ const logger = {
12
+ info: (event, meta) => {
13
+ console.log(`[INFO] ${event}`, meta || "");
14
+ },
15
+ warning: (event, meta) => {
16
+ console.warn(`[WARNING] ${event}`, meta || "");
17
+ },
18
+ error: (event, meta) => {
19
+ console.error(`[ERROR] ${event}`, meta || "");
20
+ },
21
+ debug: (event, meta) => {
22
+ const logLevel = (process.env.FAME_LOG_LEVEL || "info").toLowerCase();
23
+ if (logLevel === "debug" || logLevel === "trace") {
24
+ console.log(`[DEBUG] ${event}`, meta || "");
25
+ }
26
+ },
27
+ };
28
+ const ENV_VAR_FAME_APP_HOST = "FAME_APP_HOST";
29
+ const ENV_VAR_FAME_APP_PORT = "FAME_APP_PORT";
30
+ /**
31
+ * Create CA router with certificate signing endpoint.
32
+ * Mirrors Python's create_ca_router functionality.
33
+ */
34
+ function createCaRouter(fastify, caService, prefix = "/fame/v1/ca") {
35
+ // Certificate signing endpoint
36
+ fastify.post(`${prefix}/sign`, {
37
+ schema: {
38
+ body: {
39
+ type: "object",
40
+ required: ["csr_pem", "requester_id"],
41
+ properties: {
42
+ csr_pem: { type: "string" },
43
+ requester_id: { type: "string" },
44
+ physical_path: { type: "string" },
45
+ logicals: { type: "array", items: { type: "string" } },
46
+ },
47
+ },
48
+ },
49
+ }, async (request, reply) => {
50
+ try {
51
+ const csrRequest = request.body;
52
+ if (!csrRequest || !csrRequest.requester_id) {
53
+ return reply.status(400).send({
54
+ error: "invalid_request",
55
+ message: "CSR must include requester_id",
56
+ });
57
+ }
58
+ logger.debug("ca_cert_request_received", {
59
+ requester_id: csrRequest.requester_id,
60
+ physical_path: csrRequest.physical_path,
61
+ logicals: csrRequest.logicals,
62
+ });
63
+ // Authenticate if authorizer is configured
64
+ if (caService.authorizer) {
65
+ // TODO: Implement authentication when authorizer interface is defined
66
+ logger.warning("authentication_not_yet_implemented", {
67
+ authorizer_configured: true,
68
+ });
69
+ }
70
+ // Convert snake_case request to camelCase for TypeScript interface
71
+ const csrForService = {
72
+ csrPem: csrRequest.csr_pem,
73
+ requesterId: csrRequest.requester_id,
74
+ physicalPath: csrRequest.physical_path,
75
+ logicals: csrRequest.logicals,
76
+ };
77
+ // Issue certificate
78
+ const result = await caService.issueCertificate(csrForService);
79
+ const response = {
80
+ certificate_pem: result.certificatePem,
81
+ certificate_chain_pem: result.certificateChainPem,
82
+ expires_at: result.expiresAt,
83
+ };
84
+ return reply.send(response);
85
+ }
86
+ catch (error) {
87
+ logger.error("ca_cert_issuance_failed", {
88
+ error: error instanceof Error ? error.message : String(error),
89
+ });
90
+ return reply.status(500).send({
91
+ error: "issuance_failed",
92
+ message: error instanceof Error ? error.message : "Unknown error",
93
+ });
94
+ }
95
+ });
96
+ // Health check
97
+ fastify.get("/health", async () => {
98
+ return { status: "healthy", service: "ca-server" };
99
+ });
100
+ const trustBundlePath = "/.well-known/naylence/trust-bundle.json";
101
+ fastify.get(trustBundlePath, async (request, reply) => {
102
+ const bundle = await caService.getTrustBundle();
103
+ if (!bundle) {
104
+ return reply.status(404).send({
105
+ error: "trust_bundle_unavailable",
106
+ });
107
+ }
108
+ const payload = JSON.stringify(bundle);
109
+ const etag = `"${computeEtag(payload)}"`;
110
+ const requestEtag = request.headers["if-none-match"];
111
+ if (typeof requestEtag === "string" && requestEtag.replace(/W\//u, "") === etag.replace(/W\//u, "")) {
112
+ return reply
113
+ .status(304)
114
+ .header("ETag", etag)
115
+ .header("Cache-Control", trustBundleCacheControl())
116
+ .send();
117
+ }
118
+ return reply
119
+ .header("Content-Type", "application/json")
120
+ .header("Cache-Control", trustBundleCacheControl())
121
+ .header("ETag", etag)
122
+ .send(bundle);
123
+ });
124
+ }
125
+ /**
126
+ * Create Fastify application with CA service lifespan management.
127
+ * Mirrors Python's FastAPI lifespan pattern.
128
+ */
129
+ async function createApp() {
130
+ // Disable Fastify's built-in logger to avoid configuration conflicts
131
+ const fastify = Fastify({
132
+ logger: false,
133
+ });
134
+ // Register advanced security factories (including CA service factory)
135
+ const { registerAdvancedSecurityPluginFactories } = await import("../../../../plugin.js");
136
+ await registerAdvancedSecurityPluginFactories();
137
+ // Create CA service (mirrors Python's lifespan startup)
138
+ const caService = await CAServiceFactory.createCAService();
139
+ // Register CA router
140
+ createCaRouter(fastify, caService);
141
+ return { app: fastify, caService };
142
+ }
143
+ async function main() {
144
+ try {
145
+ const { app } = await createApp();
146
+ const host = process.env[ENV_VAR_FAME_APP_HOST] || "0.0.0.0";
147
+ const port = parseInt(process.env[ENV_VAR_FAME_APP_PORT] || "8098", 10);
148
+ await app.listen({ host, port });
149
+ logger.info("ca_server_started", { host, port });
150
+ console.log(`\nšŸ“ CA Server listening on http://${host}:${port}`);
151
+ console.log(`šŸ” Certificate endpoint: http://${host}:${port}/fame/v1/ca/sign\n`);
152
+ }
153
+ catch (error) {
154
+ logger.error("ca_server_startup_failed", {
155
+ error: error instanceof Error ? error.message : String(error),
156
+ });
157
+ process.exit(1);
158
+ }
159
+ }
160
+ export { createApp, main };
161
+ function computeEtag(payload) {
162
+ const encoder = new TextEncoder();
163
+ const digest = sha256(encoder.encode(payload));
164
+ return Array.from(digest)
165
+ .map((byte) => byte.toString(16).padStart(2, "0"))
166
+ .join("");
167
+ }
168
+ function trustBundleCacheControl() {
169
+ return "public, max-age=3600, stale-while-revalidate=86400";
170
+ }
171
+ //# 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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"}