@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.
- package/dist/browser/index.cjs +9864 -0
- package/dist/browser/index.mjs +9811 -0
- package/dist/cjs/advanced-security-isomorphic.js +82 -0
- package/dist/cjs/advanced-security-isomorphic.js.map +1 -0
- package/dist/cjs/browser.js +25 -0
- package/dist/cjs/browser.js.map +1 -0
- package/dist/cjs/index.js +2 -0
- package/dist/cjs/index.js.map +1 -0
- package/dist/cjs/install-env.js +2 -0
- package/dist/cjs/install-env.js.map +1 -0
- package/dist/cjs/naylence/fame/factory-manifest.js +39 -0
- package/dist/cjs/naylence/fame/factory-manifest.js.map +1 -0
- package/dist/cjs/naylence/fame/security/cert/browser-csr.js +103 -0
- package/dist/cjs/naylence/fame/security/cert/browser-csr.js.map +1 -0
- package/dist/cjs/naylence/fame/security/cert/ca-server-cli.js +30 -0
- package/dist/cjs/naylence/fame/security/cert/ca-server-cli.js.map +1 -0
- package/dist/cjs/naylence/fame/security/cert/ca-server.js +223 -0
- package/dist/cjs/naylence/fame/security/cert/ca-server.js.map +1 -0
- package/dist/cjs/naylence/fame/security/cert/ca-service-client.js +585 -0
- package/dist/cjs/naylence/fame/security/cert/ca-service-client.js.map +1 -0
- package/dist/cjs/naylence/fame/security/cert/ca-service-factory.js +61 -0
- package/dist/cjs/naylence/fame/security/cert/ca-service-factory.js.map +1 -0
- package/dist/cjs/naylence/fame/security/cert/ca-types.js +39 -0
- package/dist/cjs/naylence/fame/security/cert/ca-types.js.map +1 -0
- package/dist/cjs/naylence/fame/security/cert/csr-types.js +2 -0
- package/dist/cjs/naylence/fame/security/cert/csr-types.js.map +1 -0
- package/dist/cjs/naylence/fame/security/cert/default-ca-service-factory.js +66 -0
- package/dist/cjs/naylence/fame/security/cert/default-ca-service-factory.js.map +1 -0
- package/dist/cjs/naylence/fame/security/cert/default-ca-service.js +364 -0
- package/dist/cjs/naylence/fame/security/cert/default-ca-service.js.map +1 -0
- package/dist/cjs/naylence/fame/security/cert/default-certificate-manager-factory.js +73 -0
- package/dist/cjs/naylence/fame/security/cert/default-certificate-manager-factory.js.map +1 -0
- package/dist/cjs/naylence/fame/security/cert/default-certificate-manager.js +815 -0
- package/dist/cjs/naylence/fame/security/cert/default-certificate-manager.js.map +1 -0
- package/dist/cjs/naylence/fame/security/cert/grants.js +2 -0
- package/dist/cjs/naylence/fame/security/cert/grants.js.map +1 -0
- package/dist/cjs/naylence/fame/security/cert/index.js +18 -0
- package/dist/cjs/naylence/fame/security/cert/index.js.map +1 -0
- package/dist/cjs/naylence/fame/security/cert/internal-ca-service.js +741 -0
- package/dist/cjs/naylence/fame/security/cert/internal-ca-service.js.map +1 -0
- package/dist/cjs/naylence/fame/security/cert/node-ed25519-csr.js +156 -0
- package/dist/cjs/naylence/fame/security/cert/node-ed25519-csr.js.map +1 -0
- package/dist/cjs/naylence/fame/security/cert/oid-constants.js +7 -0
- package/dist/cjs/naylence/fame/security/cert/oid-constants.js.map +1 -0
- package/dist/cjs/naylence/fame/security/cert/trust-store/anchor-utils.js +119 -0
- package/dist/cjs/naylence/fame/security/cert/trust-store/anchor-utils.js.map +1 -0
- package/dist/cjs/naylence/fame/security/cert/trust-store/browser-trust-store-provider-factory.js +82 -0
- package/dist/cjs/naylence/fame/security/cert/trust-store/browser-trust-store-provider-factory.js.map +1 -0
- package/dist/cjs/naylence/fame/security/cert/trust-store/env-provider.js +168 -0
- package/dist/cjs/naylence/fame/security/cert/trust-store/env-provider.js.map +1 -0
- package/dist/cjs/naylence/fame/security/cert/trust-store/fame-ca-certs-parser.js +257 -0
- package/dist/cjs/naylence/fame/security/cert/trust-store/fame-ca-certs-parser.js.map +1 -0
- package/dist/cjs/naylence/fame/security/cert/trust-store/http-bundle-provider.js +497 -0
- package/dist/cjs/naylence/fame/security/cert/trust-store/http-bundle-provider.js.map +1 -0
- package/dist/cjs/naylence/fame/security/cert/trust-store/http-signed-bundle-provider.js +2 -0
- package/dist/cjs/naylence/fame/security/cert/trust-store/http-signed-bundle-provider.js.map +1 -0
- package/dist/cjs/naylence/fame/security/cert/trust-store/node-trust-store-provider-factory.js +61 -0
- package/dist/cjs/naylence/fame/security/cert/trust-store/node-trust-store-provider-factory.js.map +1 -0
- package/dist/cjs/naylence/fame/security/cert/trust-store/static-bundle-provider.js +44 -0
- package/dist/cjs/naylence/fame/security/cert/trust-store/static-bundle-provider.js.map +1 -0
- package/dist/cjs/naylence/fame/security/cert/trust-store/trust-store-provider-factory.js +40 -0
- package/dist/cjs/naylence/fame/security/cert/trust-store/trust-store-provider-factory.js.map +1 -0
- package/dist/cjs/naylence/fame/security/cert/trust-store/trust-store-provider.js +2 -0
- package/dist/cjs/naylence/fame/security/cert/trust-store/trust-store-provider.js.map +1 -0
- package/dist/cjs/naylence/fame/security/cert/util.js +515 -0
- package/dist/cjs/naylence/fame/security/cert/util.js.map +1 -0
- package/dist/cjs/naylence/fame/security/encryption/channel/channel-encryption-manager-factory.js +85 -0
- package/dist/cjs/naylence/fame/security/encryption/channel/channel-encryption-manager-factory.js.map +1 -0
- package/dist/cjs/naylence/fame/security/encryption/channel/channel-encryption-manager.js +743 -0
- package/dist/cjs/naylence/fame/security/encryption/channel/channel-encryption-manager.js.map +1 -0
- package/dist/cjs/naylence/fame/security/encryption/channel/index.js +3 -0
- package/dist/cjs/naylence/fame/security/encryption/channel/index.js.map +1 -0
- package/dist/cjs/naylence/fame/security/encryption/composite-encryption-manager-factory.js +113 -0
- package/dist/cjs/naylence/fame/security/encryption/composite-encryption-manager-factory.js.map +1 -0
- package/dist/cjs/naylence/fame/security/encryption/composite-encryption-manager.js +321 -0
- package/dist/cjs/naylence/fame/security/encryption/composite-encryption-manager.js.map +1 -0
- package/dist/cjs/naylence/fame/security/encryption/default-secure-channel-manager-factory.js +53 -0
- package/dist/cjs/naylence/fame/security/encryption/default-secure-channel-manager-factory.js.map +1 -0
- package/dist/cjs/naylence/fame/security/encryption/default-secure-channel-manager.js +278 -0
- package/dist/cjs/naylence/fame/security/encryption/default-secure-channel-manager.js.map +1 -0
- package/dist/cjs/naylence/fame/security/encryption/encryption-manager-registry.js +167 -0
- package/dist/cjs/naylence/fame/security/encryption/encryption-manager-registry.js.map +1 -0
- package/dist/cjs/naylence/fame/security/encryption/index.js +7 -0
- package/dist/cjs/naylence/fame/security/encryption/index.js.map +1 -0
- package/dist/cjs/naylence/fame/security/encryption/sealed/index.js +3 -0
- package/dist/cjs/naylence/fame/security/encryption/sealed/index.js.map +1 -0
- package/dist/cjs/naylence/fame/security/encryption/sealed/x25519-encryption-manager-factory.js +82 -0
- package/dist/cjs/naylence/fame/security/encryption/sealed/x25519-encryption-manager-factory.js.map +1 -0
- package/dist/cjs/naylence/fame/security/encryption/sealed/x25519-encryption-manager.js +542 -0
- package/dist/cjs/naylence/fame/security/encryption/sealed/x25519-encryption-manager.js.map +1 -0
- package/dist/cjs/naylence/fame/security/index.js +6 -0
- package/dist/cjs/naylence/fame/security/index.js.map +1 -0
- package/dist/cjs/naylence/fame/security/keys/index.js +3 -0
- package/dist/cjs/naylence/fame/security/keys/index.js.map +1 -0
- package/dist/cjs/naylence/fame/security/keys/x5c-key-manager-factory.js +36 -0
- package/dist/cjs/naylence/fame/security/keys/x5c-key-manager-factory.js.map +1 -0
- package/dist/cjs/naylence/fame/security/keys/x5c-key-manager.js +405 -0
- package/dist/cjs/naylence/fame/security/keys/x5c-key-manager.js.map +1 -0
- package/dist/cjs/naylence/fame/security/register-advanced-security-factories.js +283 -0
- package/dist/cjs/naylence/fame/security/register-advanced-security-factories.js.map +1 -0
- package/dist/cjs/naylence/fame/security/signing/eddsa-envelope-signer-factory.js +34 -0
- package/dist/cjs/naylence/fame/security/signing/eddsa-envelope-signer-factory.js.map +1 -0
- package/dist/cjs/naylence/fame/security/signing/eddsa-envelope-verifier-factory.js +33 -0
- package/dist/cjs/naylence/fame/security/signing/eddsa-envelope-verifier-factory.js.map +1 -0
- package/dist/cjs/naylence/fame/security/signing/eddsa-envelope-verifier.js +189 -0
- package/dist/cjs/naylence/fame/security/signing/eddsa-envelope-verifier.js.map +1 -0
- package/dist/cjs/naylence/fame/stickiness/aft-helper.js +72 -0
- package/dist/cjs/naylence/fame/stickiness/aft-helper.js.map +1 -0
- package/dist/cjs/naylence/fame/stickiness/aft-load-balancer-stickiness-manager-factory.js +65 -0
- package/dist/cjs/naylence/fame/stickiness/aft-load-balancer-stickiness-manager-factory.js.map +1 -0
- package/dist/cjs/naylence/fame/stickiness/aft-load-balancer-stickiness-manager.js +447 -0
- package/dist/cjs/naylence/fame/stickiness/aft-load-balancer-stickiness-manager.js.map +1 -0
- package/dist/cjs/naylence/fame/stickiness/aft-model.js +54 -0
- package/dist/cjs/naylence/fame/stickiness/aft-model.js.map +1 -0
- package/dist/cjs/naylence/fame/stickiness/aft-replica-stickiness-manager-factory.js +50 -0
- package/dist/cjs/naylence/fame/stickiness/aft-replica-stickiness-manager-factory.js.map +1 -0
- package/dist/cjs/naylence/fame/stickiness/aft-replica-stickiness-manager.js +203 -0
- package/dist/cjs/naylence/fame/stickiness/aft-replica-stickiness-manager.js.map +1 -0
- package/dist/cjs/naylence/fame/stickiness/aft-signer.js +147 -0
- package/dist/cjs/naylence/fame/stickiness/aft-signer.js.map +1 -0
- package/dist/cjs/naylence/fame/stickiness/aft-utils.js +90 -0
- package/dist/cjs/naylence/fame/stickiness/aft-utils.js.map +1 -0
- package/dist/cjs/naylence/fame/stickiness/aft-verifier.js +290 -0
- package/dist/cjs/naylence/fame/stickiness/aft-verifier.js.map +1 -0
- package/dist/cjs/naylence/fame/stickiness/index.js +11 -0
- package/dist/cjs/naylence/fame/stickiness/index.js.map +1 -0
- package/dist/cjs/naylence/fame/stickiness/stickiness-mode.js +24 -0
- package/dist/cjs/naylence/fame/stickiness/stickiness-mode.js.map +1 -0
- package/dist/cjs/naylence/fame/welcome/advanced-welcome-service-factory.js +93 -0
- package/dist/cjs/naylence/fame/welcome/advanced-welcome-service-factory.js.map +1 -0
- package/dist/cjs/naylence/fame/welcome/advanced-welcome-service.js +212 -0
- package/dist/cjs/naylence/fame/welcome/advanced-welcome-service.js.map +1 -0
- package/dist/cjs/naylence/fame/welcome/index.js +3 -0
- package/dist/cjs/naylence/fame/welcome/index.js.map +1 -0
- package/dist/cjs/node.js +11 -0
- package/dist/cjs/node.js.map +1 -0
- package/dist/cjs/plugin.js +39 -0
- package/dist/cjs/plugin.js.map +1 -0
- package/dist/cjs/version.js +8 -0
- package/dist/cjs/version.js.map +1 -0
- package/dist/esm/advanced-security-isomorphic.js +82 -0
- package/dist/esm/advanced-security-isomorphic.js.map +1 -0
- package/dist/esm/browser.js +25 -0
- package/dist/esm/browser.js.map +1 -0
- package/dist/esm/index.js +2 -0
- package/dist/esm/index.js.map +1 -0
- package/dist/esm/install-env.js +2 -0
- package/dist/esm/install-env.js.map +1 -0
- package/dist/esm/naylence/fame/factory-manifest.js +39 -0
- package/dist/esm/naylence/fame/factory-manifest.js.map +1 -0
- package/dist/esm/naylence/fame/security/cert/browser-csr.js +103 -0
- package/dist/esm/naylence/fame/security/cert/browser-csr.js.map +1 -0
- package/dist/esm/naylence/fame/security/cert/ca-server-cli.js +30 -0
- package/dist/esm/naylence/fame/security/cert/ca-server-cli.js.map +1 -0
- package/dist/esm/naylence/fame/security/cert/ca-server.js +223 -0
- package/dist/esm/naylence/fame/security/cert/ca-server.js.map +1 -0
- package/dist/esm/naylence/fame/security/cert/ca-service-client.js +585 -0
- package/dist/esm/naylence/fame/security/cert/ca-service-client.js.map +1 -0
- package/dist/esm/naylence/fame/security/cert/ca-service-factory.js +61 -0
- package/dist/esm/naylence/fame/security/cert/ca-service-factory.js.map +1 -0
- package/dist/esm/naylence/fame/security/cert/ca-types.js +39 -0
- package/dist/esm/naylence/fame/security/cert/ca-types.js.map +1 -0
- package/dist/esm/naylence/fame/security/cert/csr-types.js +2 -0
- package/dist/esm/naylence/fame/security/cert/csr-types.js.map +1 -0
- package/dist/esm/naylence/fame/security/cert/default-ca-service-factory.js +66 -0
- package/dist/esm/naylence/fame/security/cert/default-ca-service-factory.js.map +1 -0
- package/dist/esm/naylence/fame/security/cert/default-ca-service.js +364 -0
- package/dist/esm/naylence/fame/security/cert/default-ca-service.js.map +1 -0
- package/dist/esm/naylence/fame/security/cert/default-certificate-manager-factory.js +73 -0
- package/dist/esm/naylence/fame/security/cert/default-certificate-manager-factory.js.map +1 -0
- package/dist/esm/naylence/fame/security/cert/default-certificate-manager.js +815 -0
- package/dist/esm/naylence/fame/security/cert/default-certificate-manager.js.map +1 -0
- package/dist/esm/naylence/fame/security/cert/grants.js +2 -0
- package/dist/esm/naylence/fame/security/cert/grants.js.map +1 -0
- package/dist/esm/naylence/fame/security/cert/index.js +18 -0
- package/dist/esm/naylence/fame/security/cert/index.js.map +1 -0
- package/dist/esm/naylence/fame/security/cert/internal-ca-service.js +741 -0
- package/dist/esm/naylence/fame/security/cert/internal-ca-service.js.map +1 -0
- package/dist/esm/naylence/fame/security/cert/node-ed25519-csr.js +156 -0
- package/dist/esm/naylence/fame/security/cert/node-ed25519-csr.js.map +1 -0
- package/dist/esm/naylence/fame/security/cert/oid-constants.js +7 -0
- package/dist/esm/naylence/fame/security/cert/oid-constants.js.map +1 -0
- package/dist/esm/naylence/fame/security/cert/trust-store/anchor-utils.js +119 -0
- package/dist/esm/naylence/fame/security/cert/trust-store/anchor-utils.js.map +1 -0
- package/dist/esm/naylence/fame/security/cert/trust-store/browser-trust-store-provider-factory.js +82 -0
- package/dist/esm/naylence/fame/security/cert/trust-store/browser-trust-store-provider-factory.js.map +1 -0
- package/dist/esm/naylence/fame/security/cert/trust-store/env-provider.js +168 -0
- package/dist/esm/naylence/fame/security/cert/trust-store/env-provider.js.map +1 -0
- package/dist/esm/naylence/fame/security/cert/trust-store/fame-ca-certs-parser.js +257 -0
- package/dist/esm/naylence/fame/security/cert/trust-store/fame-ca-certs-parser.js.map +1 -0
- package/dist/esm/naylence/fame/security/cert/trust-store/http-bundle-provider.js +497 -0
- package/dist/esm/naylence/fame/security/cert/trust-store/http-bundle-provider.js.map +1 -0
- package/dist/esm/naylence/fame/security/cert/trust-store/http-signed-bundle-provider.js +2 -0
- package/dist/esm/naylence/fame/security/cert/trust-store/http-signed-bundle-provider.js.map +1 -0
- package/dist/esm/naylence/fame/security/cert/trust-store/node-trust-store-provider-factory.js +61 -0
- package/dist/esm/naylence/fame/security/cert/trust-store/node-trust-store-provider-factory.js.map +1 -0
- package/dist/esm/naylence/fame/security/cert/trust-store/static-bundle-provider.js +44 -0
- package/dist/esm/naylence/fame/security/cert/trust-store/static-bundle-provider.js.map +1 -0
- package/dist/esm/naylence/fame/security/cert/trust-store/trust-store-provider-factory.js +40 -0
- package/dist/esm/naylence/fame/security/cert/trust-store/trust-store-provider-factory.js.map +1 -0
- package/dist/esm/naylence/fame/security/cert/trust-store/trust-store-provider.js +2 -0
- package/dist/esm/naylence/fame/security/cert/trust-store/trust-store-provider.js.map +1 -0
- package/dist/esm/naylence/fame/security/cert/util.js +515 -0
- package/dist/esm/naylence/fame/security/cert/util.js.map +1 -0
- package/dist/esm/naylence/fame/security/encryption/channel/channel-encryption-manager-factory.js +85 -0
- package/dist/esm/naylence/fame/security/encryption/channel/channel-encryption-manager-factory.js.map +1 -0
- package/dist/esm/naylence/fame/security/encryption/channel/channel-encryption-manager.js +743 -0
- package/dist/esm/naylence/fame/security/encryption/channel/channel-encryption-manager.js.map +1 -0
- package/dist/esm/naylence/fame/security/encryption/channel/index.js +3 -0
- package/dist/esm/naylence/fame/security/encryption/channel/index.js.map +1 -0
- package/dist/esm/naylence/fame/security/encryption/composite-encryption-manager-factory.js +113 -0
- package/dist/esm/naylence/fame/security/encryption/composite-encryption-manager-factory.js.map +1 -0
- package/dist/esm/naylence/fame/security/encryption/composite-encryption-manager.js +321 -0
- package/dist/esm/naylence/fame/security/encryption/composite-encryption-manager.js.map +1 -0
- package/dist/esm/naylence/fame/security/encryption/default-secure-channel-manager-factory.js +53 -0
- package/dist/esm/naylence/fame/security/encryption/default-secure-channel-manager-factory.js.map +1 -0
- package/dist/esm/naylence/fame/security/encryption/default-secure-channel-manager.js +278 -0
- package/dist/esm/naylence/fame/security/encryption/default-secure-channel-manager.js.map +1 -0
- package/dist/esm/naylence/fame/security/encryption/encryption-manager-registry.js +167 -0
- package/dist/esm/naylence/fame/security/encryption/encryption-manager-registry.js.map +1 -0
- package/dist/esm/naylence/fame/security/encryption/index.js +7 -0
- package/dist/esm/naylence/fame/security/encryption/index.js.map +1 -0
- package/dist/esm/naylence/fame/security/encryption/sealed/index.js +3 -0
- package/dist/esm/naylence/fame/security/encryption/sealed/index.js.map +1 -0
- package/dist/esm/naylence/fame/security/encryption/sealed/x25519-encryption-manager-factory.js +82 -0
- package/dist/esm/naylence/fame/security/encryption/sealed/x25519-encryption-manager-factory.js.map +1 -0
- package/dist/esm/naylence/fame/security/encryption/sealed/x25519-encryption-manager.js +542 -0
- package/dist/esm/naylence/fame/security/encryption/sealed/x25519-encryption-manager.js.map +1 -0
- package/dist/esm/naylence/fame/security/index.js +6 -0
- package/dist/esm/naylence/fame/security/index.js.map +1 -0
- package/dist/esm/naylence/fame/security/keys/index.js +3 -0
- package/dist/esm/naylence/fame/security/keys/index.js.map +1 -0
- package/dist/esm/naylence/fame/security/keys/x5c-key-manager-factory.js +36 -0
- package/dist/esm/naylence/fame/security/keys/x5c-key-manager-factory.js.map +1 -0
- package/dist/esm/naylence/fame/security/keys/x5c-key-manager.js +405 -0
- package/dist/esm/naylence/fame/security/keys/x5c-key-manager.js.map +1 -0
- package/dist/esm/naylence/fame/security/register-advanced-security-factories.js +283 -0
- package/dist/esm/naylence/fame/security/register-advanced-security-factories.js.map +1 -0
- package/dist/esm/naylence/fame/security/signing/eddsa-envelope-signer-factory.js +34 -0
- package/dist/esm/naylence/fame/security/signing/eddsa-envelope-signer-factory.js.map +1 -0
- package/dist/esm/naylence/fame/security/signing/eddsa-envelope-verifier-factory.js +33 -0
- package/dist/esm/naylence/fame/security/signing/eddsa-envelope-verifier-factory.js.map +1 -0
- package/dist/esm/naylence/fame/security/signing/eddsa-envelope-verifier.js +189 -0
- package/dist/esm/naylence/fame/security/signing/eddsa-envelope-verifier.js.map +1 -0
- package/dist/esm/naylence/fame/stickiness/aft-helper.js +72 -0
- package/dist/esm/naylence/fame/stickiness/aft-helper.js.map +1 -0
- package/dist/esm/naylence/fame/stickiness/aft-load-balancer-stickiness-manager-factory.js +65 -0
- package/dist/esm/naylence/fame/stickiness/aft-load-balancer-stickiness-manager-factory.js.map +1 -0
- package/dist/esm/naylence/fame/stickiness/aft-load-balancer-stickiness-manager.js +447 -0
- package/dist/esm/naylence/fame/stickiness/aft-load-balancer-stickiness-manager.js.map +1 -0
- package/dist/esm/naylence/fame/stickiness/aft-model.js +54 -0
- package/dist/esm/naylence/fame/stickiness/aft-model.js.map +1 -0
- package/dist/esm/naylence/fame/stickiness/aft-replica-stickiness-manager-factory.js +50 -0
- package/dist/esm/naylence/fame/stickiness/aft-replica-stickiness-manager-factory.js.map +1 -0
- package/dist/esm/naylence/fame/stickiness/aft-replica-stickiness-manager.js +203 -0
- package/dist/esm/naylence/fame/stickiness/aft-replica-stickiness-manager.js.map +1 -0
- package/dist/esm/naylence/fame/stickiness/aft-signer.js +147 -0
- package/dist/esm/naylence/fame/stickiness/aft-signer.js.map +1 -0
- package/dist/esm/naylence/fame/stickiness/aft-utils.js +90 -0
- package/dist/esm/naylence/fame/stickiness/aft-utils.js.map +1 -0
- package/dist/esm/naylence/fame/stickiness/aft-verifier.js +290 -0
- package/dist/esm/naylence/fame/stickiness/aft-verifier.js.map +1 -0
- package/dist/esm/naylence/fame/stickiness/index.js +11 -0
- package/dist/esm/naylence/fame/stickiness/index.js.map +1 -0
- package/dist/esm/naylence/fame/stickiness/stickiness-mode.js +24 -0
- package/dist/esm/naylence/fame/stickiness/stickiness-mode.js.map +1 -0
- package/dist/esm/naylence/fame/welcome/advanced-welcome-service-factory.js +93 -0
- package/dist/esm/naylence/fame/welcome/advanced-welcome-service-factory.js.map +1 -0
- package/dist/esm/naylence/fame/welcome/advanced-welcome-service.js +212 -0
- package/dist/esm/naylence/fame/welcome/advanced-welcome-service.js.map +1 -0
- package/dist/esm/naylence/fame/welcome/index.js +3 -0
- package/dist/esm/naylence/fame/welcome/index.js.map +1 -0
- package/dist/esm/node.js +11 -0
- package/dist/esm/node.js.map +1 -0
- package/dist/esm/plugin.js +39 -0
- package/dist/esm/plugin.js.map +1 -0
- package/dist/esm/version.js +8 -0
- package/dist/esm/version.js.map +1 -0
- package/dist/node/index.cjs +9855 -0
- package/dist/node/index.mjs +9800 -0
- package/dist/node/node.cjs +10139 -0
- package/dist/node/node.mjs +10046 -0
- package/dist/types/advanced-security-isomorphic.d.ts +24 -0
- package/dist/types/advanced-security-isomorphic.d.ts.map +1 -0
- package/dist/types/browser.d.ts +19 -0
- package/dist/types/browser.d.ts.map +1 -0
- package/dist/types/index.d.ts +2 -0
- package/dist/types/index.d.ts.map +1 -0
- package/dist/types/install-env.d.ts +3 -0
- package/dist/types/install-env.d.ts.map +1 -0
- package/dist/types/naylence/fame/factory-manifest.d.ts +11 -0
- package/dist/types/naylence/fame/factory-manifest.d.ts.map +1 -0
- package/dist/types/naylence/fame/security/cert/browser-csr.d.ts +9 -0
- package/dist/types/naylence/fame/security/cert/browser-csr.d.ts.map +1 -0
- package/dist/types/naylence/fame/security/cert/ca-server-cli.d.ts +3 -0
- package/dist/types/naylence/fame/security/cert/ca-server-cli.d.ts.map +1 -0
- package/dist/types/naylence/fame/security/cert/ca-server.d.ts +19 -0
- package/dist/types/naylence/fame/security/cert/ca-server.d.ts.map +1 -0
- package/dist/types/naylence/fame/security/cert/ca-service-client.d.ts +75 -0
- package/dist/types/naylence/fame/security/cert/ca-service-client.d.ts.map +1 -0
- package/dist/types/naylence/fame/security/cert/ca-service-factory.d.ts +43 -0
- package/dist/types/naylence/fame/security/cert/ca-service-factory.d.ts.map +1 -0
- package/dist/types/naylence/fame/security/cert/ca-types.d.ts +129 -0
- package/dist/types/naylence/fame/security/cert/ca-types.d.ts.map +1 -0
- package/dist/types/naylence/fame/security/cert/csr-types.d.ts +5 -0
- package/dist/types/naylence/fame/security/cert/csr-types.d.ts.map +1 -0
- package/dist/types/naylence/fame/security/cert/default-ca-service-factory.d.ts +55 -0
- package/dist/types/naylence/fame/security/cert/default-ca-service-factory.d.ts.map +1 -0
- package/dist/types/naylence/fame/security/cert/default-ca-service.d.ts +85 -0
- package/dist/types/naylence/fame/security/cert/default-ca-service.d.ts.map +1 -0
- package/dist/types/naylence/fame/security/cert/default-certificate-manager-factory.d.ts +25 -0
- package/dist/types/naylence/fame/security/cert/default-certificate-manager-factory.d.ts.map +1 -0
- package/dist/types/naylence/fame/security/cert/default-certificate-manager.d.ts +70 -0
- package/dist/types/naylence/fame/security/cert/default-certificate-manager.d.ts.map +1 -0
- package/dist/types/naylence/fame/security/cert/grants.d.ts +2 -0
- package/dist/types/naylence/fame/security/cert/grants.d.ts.map +1 -0
- package/dist/types/naylence/fame/security/cert/index.d.ts +19 -0
- package/dist/types/naylence/fame/security/cert/index.d.ts.map +1 -0
- package/dist/types/naylence/fame/security/cert/internal-ca-service.d.ts +129 -0
- package/dist/types/naylence/fame/security/cert/internal-ca-service.d.ts.map +1 -0
- package/dist/types/naylence/fame/security/cert/node-ed25519-csr.d.ts +9 -0
- package/dist/types/naylence/fame/security/cert/node-ed25519-csr.d.ts.map +1 -0
- package/dist/types/naylence/fame/security/cert/oid-constants.d.ts +7 -0
- package/dist/types/naylence/fame/security/cert/oid-constants.d.ts.map +1 -0
- package/dist/types/naylence/fame/security/cert/trust-store/anchor-utils.d.ts +12 -0
- package/dist/types/naylence/fame/security/cert/trust-store/anchor-utils.d.ts.map +1 -0
- package/dist/types/naylence/fame/security/cert/trust-store/browser-trust-store-provider-factory.d.ts +29 -0
- package/dist/types/naylence/fame/security/cert/trust-store/browser-trust-store-provider-factory.d.ts.map +1 -0
- package/dist/types/naylence/fame/security/cert/trust-store/env-provider.d.ts +7 -0
- package/dist/types/naylence/fame/security/cert/trust-store/env-provider.d.ts.map +1 -0
- package/dist/types/naylence/fame/security/cert/trust-store/fame-ca-certs-parser.d.ts +9 -0
- package/dist/types/naylence/fame/security/cert/trust-store/fame-ca-certs-parser.d.ts.map +1 -0
- package/dist/types/naylence/fame/security/cert/trust-store/http-bundle-provider.d.ts +35 -0
- package/dist/types/naylence/fame/security/cert/trust-store/http-bundle-provider.d.ts.map +1 -0
- package/dist/types/naylence/fame/security/cert/trust-store/http-signed-bundle-provider.d.ts +2 -0
- package/dist/types/naylence/fame/security/cert/trust-store/http-signed-bundle-provider.d.ts.map +1 -0
- package/dist/types/naylence/fame/security/cert/trust-store/node-trust-store-provider-factory.d.ts +23 -0
- package/dist/types/naylence/fame/security/cert/trust-store/node-trust-store-provider-factory.d.ts.map +1 -0
- package/dist/types/naylence/fame/security/cert/trust-store/static-bundle-provider.d.ts +15 -0
- package/dist/types/naylence/fame/security/cert/trust-store/static-bundle-provider.d.ts.map +1 -0
- package/dist/types/naylence/fame/security/cert/trust-store/trust-store-provider-factory.d.ts +28 -0
- package/dist/types/naylence/fame/security/cert/trust-store/trust-store-provider-factory.d.ts.map +1 -0
- package/dist/types/naylence/fame/security/cert/trust-store/trust-store-provider.d.ts +43 -0
- package/dist/types/naylence/fame/security/cert/trust-store/trust-store-provider.d.ts.map +1 -0
- package/dist/types/naylence/fame/security/cert/util.d.ts +25 -0
- package/dist/types/naylence/fame/security/cert/util.d.ts.map +1 -0
- package/dist/types/naylence/fame/security/encryption/channel/channel-encryption-manager-factory.d.ts +29 -0
- package/dist/types/naylence/fame/security/encryption/channel/channel-encryption-manager-factory.d.ts.map +1 -0
- package/dist/types/naylence/fame/security/encryption/channel/channel-encryption-manager.d.ts +51 -0
- package/dist/types/naylence/fame/security/encryption/channel/channel-encryption-manager.d.ts.map +1 -0
- package/dist/types/naylence/fame/security/encryption/channel/index.d.ts +3 -0
- package/dist/types/naylence/fame/security/encryption/channel/index.d.ts.map +1 -0
- package/dist/types/naylence/fame/security/encryption/composite-encryption-manager-factory.d.ts +32 -0
- package/dist/types/naylence/fame/security/encryption/composite-encryption-manager-factory.d.ts.map +1 -0
- package/dist/types/naylence/fame/security/encryption/composite-encryption-manager.d.ts +52 -0
- package/dist/types/naylence/fame/security/encryption/composite-encryption-manager.d.ts.map +1 -0
- package/dist/types/naylence/fame/security/encryption/default-secure-channel-manager-factory.d.ts +23 -0
- package/dist/types/naylence/fame/security/encryption/default-secure-channel-manager-factory.d.ts.map +1 -0
- package/dist/types/naylence/fame/security/encryption/default-secure-channel-manager.d.ts +37 -0
- package/dist/types/naylence/fame/security/encryption/default-secure-channel-manager.d.ts.map +1 -0
- package/dist/types/naylence/fame/security/encryption/encryption-manager-registry.d.ts +34 -0
- package/dist/types/naylence/fame/security/encryption/encryption-manager-registry.d.ts.map +1 -0
- package/dist/types/naylence/fame/security/encryption/index.d.ts +7 -0
- package/dist/types/naylence/fame/security/encryption/index.d.ts.map +1 -0
- package/dist/types/naylence/fame/security/encryption/sealed/index.d.ts +3 -0
- package/dist/types/naylence/fame/security/encryption/sealed/index.d.ts.map +1 -0
- package/dist/types/naylence/fame/security/encryption/sealed/x25519-encryption-manager-factory.d.ts +28 -0
- package/dist/types/naylence/fame/security/encryption/sealed/x25519-encryption-manager-factory.d.ts.map +1 -0
- package/dist/types/naylence/fame/security/encryption/sealed/x25519-encryption-manager.d.ts +43 -0
- package/dist/types/naylence/fame/security/encryption/sealed/x25519-encryption-manager.d.ts.map +1 -0
- package/dist/types/naylence/fame/security/index.d.ts +6 -0
- package/dist/types/naylence/fame/security/index.d.ts.map +1 -0
- package/dist/types/naylence/fame/security/keys/index.d.ts +3 -0
- package/dist/types/naylence/fame/security/keys/index.d.ts.map +1 -0
- package/dist/types/naylence/fame/security/keys/x5c-key-manager-factory.d.ts +19 -0
- package/dist/types/naylence/fame/security/keys/x5c-key-manager-factory.d.ts.map +1 -0
- package/dist/types/naylence/fame/security/keys/x5c-key-manager.d.ts +39 -0
- package/dist/types/naylence/fame/security/keys/x5c-key-manager.d.ts.map +1 -0
- package/dist/types/naylence/fame/security/register-advanced-security-factories.d.ts +8 -0
- package/dist/types/naylence/fame/security/register-advanced-security-factories.d.ts.map +1 -0
- package/dist/types/naylence/fame/security/signing/eddsa-envelope-signer-factory.d.ts +20 -0
- package/dist/types/naylence/fame/security/signing/eddsa-envelope-signer-factory.d.ts.map +1 -0
- package/dist/types/naylence/fame/security/signing/eddsa-envelope-verifier-factory.d.ts +21 -0
- package/dist/types/naylence/fame/security/signing/eddsa-envelope-verifier-factory.d.ts.map +1 -0
- package/dist/types/naylence/fame/security/signing/eddsa-envelope-verifier.d.ts +22 -0
- package/dist/types/naylence/fame/security/signing/eddsa-envelope-verifier.d.ts.map +1 -0
- package/dist/types/naylence/fame/stickiness/aft-helper.d.ts +29 -0
- package/dist/types/naylence/fame/stickiness/aft-helper.d.ts.map +1 -0
- package/dist/types/naylence/fame/stickiness/aft-load-balancer-stickiness-manager-factory.d.ts +25 -0
- package/dist/types/naylence/fame/stickiness/aft-load-balancer-stickiness-manager-factory.d.ts.map +1 -0
- package/dist/types/naylence/fame/stickiness/aft-load-balancer-stickiness-manager.d.ts +33 -0
- package/dist/types/naylence/fame/stickiness/aft-load-balancer-stickiness-manager.d.ts.map +1 -0
- package/dist/types/naylence/fame/stickiness/aft-model.d.ts +33 -0
- package/dist/types/naylence/fame/stickiness/aft-model.d.ts.map +1 -0
- package/dist/types/naylence/fame/stickiness/aft-replica-stickiness-manager-factory.d.ts +23 -0
- package/dist/types/naylence/fame/stickiness/aft-replica-stickiness-manager-factory.d.ts.map +1 -0
- package/dist/types/naylence/fame/stickiness/aft-replica-stickiness-manager.d.ts +31 -0
- package/dist/types/naylence/fame/stickiness/aft-replica-stickiness-manager.d.ts.map +1 -0
- package/dist/types/naylence/fame/stickiness/aft-signer.d.ts +55 -0
- package/dist/types/naylence/fame/stickiness/aft-signer.d.ts.map +1 -0
- package/dist/types/naylence/fame/stickiness/aft-utils.d.ts +4 -0
- package/dist/types/naylence/fame/stickiness/aft-utils.d.ts.map +1 -0
- package/dist/types/naylence/fame/stickiness/aft-verifier.d.ts +50 -0
- package/dist/types/naylence/fame/stickiness/aft-verifier.d.ts.map +1 -0
- package/dist/types/naylence/fame/stickiness/index.d.ts +15 -0
- package/dist/types/naylence/fame/stickiness/index.d.ts.map +1 -0
- package/dist/types/naylence/fame/stickiness/stickiness-mode.d.ts +7 -0
- package/dist/types/naylence/fame/stickiness/stickiness-mode.d.ts.map +1 -0
- package/dist/types/naylence/fame/welcome/advanced-welcome-service-factory.d.ts +21 -0
- package/dist/types/naylence/fame/welcome/advanced-welcome-service-factory.d.ts.map +1 -0
- package/dist/types/naylence/fame/welcome/advanced-welcome-service.d.ts +21 -0
- package/dist/types/naylence/fame/welcome/advanced-welcome-service.d.ts.map +1 -0
- package/dist/types/naylence/fame/welcome/index.d.ts +3 -0
- package/dist/types/naylence/fame/welcome/index.d.ts.map +1 -0
- package/dist/types/node.d.ts +11 -0
- package/dist/types/node.d.ts.map +1 -0
- package/dist/types/plugin.d.ts +11 -0
- package/dist/types/plugin.d.ts.map +1 -0
- package/dist/types/version.d.ts +6 -0
- package/dist/types/version.d.ts.map +1 -0
- package/package.json +1 -1
|
@@ -0,0 +1,290 @@
|
|
|
1
|
+
import { compactVerify, importJWK, importSPKI } from "jose";
|
|
2
|
+
import { getLogger } from "@naylence/runtime";
|
|
3
|
+
import { base64UrlDecode, utf8Decode } from "./aft-utils.js";
|
|
4
|
+
import { StickinessMode } from "./stickiness-mode.js";
|
|
5
|
+
const logger = getLogger("naylence.fame.stickiness.aft_verifier");
|
|
6
|
+
function decodeToken(token) {
|
|
7
|
+
const parts = token.split(".");
|
|
8
|
+
if (parts.length !== 3) {
|
|
9
|
+
return null;
|
|
10
|
+
}
|
|
11
|
+
const [headerB64, payloadB64] = parts;
|
|
12
|
+
if (!headerB64 || !payloadB64) {
|
|
13
|
+
return null;
|
|
14
|
+
}
|
|
15
|
+
try {
|
|
16
|
+
const headerJson = utf8Decode(base64UrlDecode(headerB64));
|
|
17
|
+
const payloadJson = utf8Decode(base64UrlDecode(payloadB64));
|
|
18
|
+
const headerData = JSON.parse(headerJson);
|
|
19
|
+
const payloadData = JSON.parse(payloadJson);
|
|
20
|
+
const header = {
|
|
21
|
+
alg: String(headerData.alg ?? ""),
|
|
22
|
+
kid: String(headerData.kid ?? ""),
|
|
23
|
+
};
|
|
24
|
+
const claims = {
|
|
25
|
+
sid: String(payloadData.sid ?? ""),
|
|
26
|
+
exp: Number(payloadData.exp ?? 0),
|
|
27
|
+
};
|
|
28
|
+
if (typeof payloadData.scp === "string" && payloadData.scp.length > 0) {
|
|
29
|
+
claims.scp = payloadData.scp;
|
|
30
|
+
}
|
|
31
|
+
if (typeof payloadData.client_sid === "string" &&
|
|
32
|
+
payloadData.client_sid.length > 0) {
|
|
33
|
+
claims.client_sid = payloadData.client_sid;
|
|
34
|
+
}
|
|
35
|
+
return { header, claims };
|
|
36
|
+
}
|
|
37
|
+
catch (error) {
|
|
38
|
+
logger.debug("aft_decoding_failed", {
|
|
39
|
+
error: error instanceof Error ? error.message : String(error),
|
|
40
|
+
});
|
|
41
|
+
return null;
|
|
42
|
+
}
|
|
43
|
+
}
|
|
44
|
+
class BaseAFTVerifier {
|
|
45
|
+
constructor(defaultTtlSec = 30) {
|
|
46
|
+
this.defaultTtlSec = defaultTtlSec;
|
|
47
|
+
}
|
|
48
|
+
async verify(token, expectedSid) {
|
|
49
|
+
const decoded = decodeToken(token);
|
|
50
|
+
if (!decoded) {
|
|
51
|
+
return {
|
|
52
|
+
valid: false,
|
|
53
|
+
trustLevel: "untrusted",
|
|
54
|
+
error: "Invalid token format - expected 3 parts",
|
|
55
|
+
};
|
|
56
|
+
}
|
|
57
|
+
const { header, claims } = decoded;
|
|
58
|
+
if (!header.alg || !header.kid) {
|
|
59
|
+
return {
|
|
60
|
+
valid: false,
|
|
61
|
+
trustLevel: "untrusted",
|
|
62
|
+
error: "Missing algorithm or key ID",
|
|
63
|
+
};
|
|
64
|
+
}
|
|
65
|
+
if (!claims.sid || !Number.isFinite(claims.exp)) {
|
|
66
|
+
return {
|
|
67
|
+
valid: false,
|
|
68
|
+
trustLevel: "untrusted",
|
|
69
|
+
error: "Token missing required claims",
|
|
70
|
+
};
|
|
71
|
+
}
|
|
72
|
+
const currentTime = Math.floor(Date.now() / 1000);
|
|
73
|
+
if (claims.exp <= currentTime) {
|
|
74
|
+
return {
|
|
75
|
+
valid: false,
|
|
76
|
+
sid: claims.sid,
|
|
77
|
+
exp: claims.exp,
|
|
78
|
+
scope: claims.scp ?? undefined,
|
|
79
|
+
clientSid: claims.client_sid ?? undefined,
|
|
80
|
+
trustLevel: "untrusted",
|
|
81
|
+
error: "Token expired",
|
|
82
|
+
};
|
|
83
|
+
}
|
|
84
|
+
if (expectedSid && claims.sid !== expectedSid) {
|
|
85
|
+
return {
|
|
86
|
+
valid: false,
|
|
87
|
+
sid: claims.sid,
|
|
88
|
+
exp: claims.exp,
|
|
89
|
+
scope: claims.scp ?? undefined,
|
|
90
|
+
clientSid: claims.client_sid ?? undefined,
|
|
91
|
+
trustLevel: "untrusted",
|
|
92
|
+
error: `SID mismatch: expected ${expectedSid}, got ${claims.sid}`,
|
|
93
|
+
};
|
|
94
|
+
}
|
|
95
|
+
let signatureValid = false;
|
|
96
|
+
try {
|
|
97
|
+
signatureValid = await this.verifySignature(token, header, claims);
|
|
98
|
+
}
|
|
99
|
+
catch (error) {
|
|
100
|
+
logger.debug("aft_signature_verification_failed", {
|
|
101
|
+
kid: header.kid,
|
|
102
|
+
algorithm: header.alg,
|
|
103
|
+
error: error instanceof Error ? error.message : String(error),
|
|
104
|
+
});
|
|
105
|
+
signatureValid = false;
|
|
106
|
+
}
|
|
107
|
+
if (!signatureValid) {
|
|
108
|
+
return {
|
|
109
|
+
valid: false,
|
|
110
|
+
sid: claims.sid,
|
|
111
|
+
exp: claims.exp,
|
|
112
|
+
scope: claims.scp ?? undefined,
|
|
113
|
+
clientSid: claims.client_sid ?? undefined,
|
|
114
|
+
trustLevel: "untrusted",
|
|
115
|
+
error: "Invalid signature",
|
|
116
|
+
};
|
|
117
|
+
}
|
|
118
|
+
const trustLevel = header.alg === "none" ? "low-trust" : "trusted";
|
|
119
|
+
return {
|
|
120
|
+
valid: true,
|
|
121
|
+
sid: claims.sid,
|
|
122
|
+
exp: claims.exp,
|
|
123
|
+
scope: claims.scp ?? undefined,
|
|
124
|
+
clientSid: claims.client_sid ?? undefined,
|
|
125
|
+
trustLevel,
|
|
126
|
+
};
|
|
127
|
+
}
|
|
128
|
+
}
|
|
129
|
+
export class StrictAFTVerifier extends BaseAFTVerifier {
|
|
130
|
+
constructor(keyProvider, defaultTtlSec = 30) {
|
|
131
|
+
super(defaultTtlSec);
|
|
132
|
+
this.keyProvider = keyProvider;
|
|
133
|
+
}
|
|
134
|
+
get securityLevel() {
|
|
135
|
+
return StickinessMode.STRICT;
|
|
136
|
+
}
|
|
137
|
+
async verifySignature(token, header) {
|
|
138
|
+
if (header.alg === "none") {
|
|
139
|
+
return false;
|
|
140
|
+
}
|
|
141
|
+
let keyRecord;
|
|
142
|
+
try {
|
|
143
|
+
keyRecord = await this.keyProvider.getKey(header.kid);
|
|
144
|
+
}
|
|
145
|
+
catch (error) {
|
|
146
|
+
logger.debug("aft_public_key_missing", {
|
|
147
|
+
kid: header.kid,
|
|
148
|
+
error: error instanceof Error ? error.message : String(error),
|
|
149
|
+
});
|
|
150
|
+
return false;
|
|
151
|
+
}
|
|
152
|
+
const key = await resolveVerificationKey(keyRecord, header.alg);
|
|
153
|
+
if (!key) {
|
|
154
|
+
return false;
|
|
155
|
+
}
|
|
156
|
+
try {
|
|
157
|
+
const { protectedHeader } = await compactVerify(token, key);
|
|
158
|
+
return protectedHeader.alg === header.alg;
|
|
159
|
+
}
|
|
160
|
+
catch (error) {
|
|
161
|
+
logger.debug("aft_jws_verification_failed", {
|
|
162
|
+
kid: header.kid,
|
|
163
|
+
algorithm: header.alg,
|
|
164
|
+
error: error instanceof Error ? error.message : String(error),
|
|
165
|
+
});
|
|
166
|
+
return false;
|
|
167
|
+
}
|
|
168
|
+
}
|
|
169
|
+
}
|
|
170
|
+
export class SignedOptionalAFTVerifier extends BaseAFTVerifier {
|
|
171
|
+
constructor(keyProvider, defaultTtlSec = 30) {
|
|
172
|
+
super(defaultTtlSec);
|
|
173
|
+
this.keyProvider = keyProvider;
|
|
174
|
+
}
|
|
175
|
+
get securityLevel() {
|
|
176
|
+
return StickinessMode.SIGNED_OPTIONAL;
|
|
177
|
+
}
|
|
178
|
+
async verifySignature(token, header) {
|
|
179
|
+
if (header.alg === "none") {
|
|
180
|
+
return true;
|
|
181
|
+
}
|
|
182
|
+
if (!this.keyProvider) {
|
|
183
|
+
return false;
|
|
184
|
+
}
|
|
185
|
+
let keyRecord;
|
|
186
|
+
try {
|
|
187
|
+
keyRecord = await this.keyProvider.getKey(header.kid);
|
|
188
|
+
}
|
|
189
|
+
catch (error) {
|
|
190
|
+
logger.debug("aft_public_key_missing", {
|
|
191
|
+
kid: header.kid,
|
|
192
|
+
error: error instanceof Error ? error.message : String(error),
|
|
193
|
+
});
|
|
194
|
+
return false;
|
|
195
|
+
}
|
|
196
|
+
const key = await resolveVerificationKey(keyRecord, header.alg);
|
|
197
|
+
if (!key) {
|
|
198
|
+
return false;
|
|
199
|
+
}
|
|
200
|
+
try {
|
|
201
|
+
const { protectedHeader } = await compactVerify(token, key);
|
|
202
|
+
return protectedHeader.alg === header.alg;
|
|
203
|
+
}
|
|
204
|
+
catch (error) {
|
|
205
|
+
logger.debug("aft_jws_verification_failed", {
|
|
206
|
+
kid: header.kid,
|
|
207
|
+
algorithm: header.alg,
|
|
208
|
+
error: error instanceof Error ? error.message : String(error),
|
|
209
|
+
});
|
|
210
|
+
return false;
|
|
211
|
+
}
|
|
212
|
+
}
|
|
213
|
+
}
|
|
214
|
+
export class SidOnlyAFTVerifier extends BaseAFTVerifier {
|
|
215
|
+
constructor(defaultTtlSec = 30) {
|
|
216
|
+
super(defaultTtlSec);
|
|
217
|
+
}
|
|
218
|
+
get securityLevel() {
|
|
219
|
+
return StickinessMode.SID_ONLY;
|
|
220
|
+
}
|
|
221
|
+
async verify(_token, _expectedSid) {
|
|
222
|
+
return {
|
|
223
|
+
valid: false,
|
|
224
|
+
trustLevel: "untrusted",
|
|
225
|
+
error: "SID-only mode ignores AFTs",
|
|
226
|
+
};
|
|
227
|
+
}
|
|
228
|
+
async verifySignature() {
|
|
229
|
+
return false;
|
|
230
|
+
}
|
|
231
|
+
}
|
|
232
|
+
async function resolveVerificationKey(keyRecord, algorithm) {
|
|
233
|
+
const jwkCandidate = keyRecord;
|
|
234
|
+
if (typeof jwkCandidate.kty === "string") {
|
|
235
|
+
try {
|
|
236
|
+
const key = await importJWK(jwkCandidate, algorithm);
|
|
237
|
+
return key;
|
|
238
|
+
}
|
|
239
|
+
catch (error) {
|
|
240
|
+
logger.debug("aft_jwk_import_failed", {
|
|
241
|
+
kid: keyRecord.kid,
|
|
242
|
+
algorithm,
|
|
243
|
+
error: error instanceof Error ? error.message : String(error),
|
|
244
|
+
});
|
|
245
|
+
}
|
|
246
|
+
}
|
|
247
|
+
let pem = null;
|
|
248
|
+
const record = keyRecord;
|
|
249
|
+
if (typeof record.public_key_pem === "string") {
|
|
250
|
+
pem = record.public_key_pem;
|
|
251
|
+
}
|
|
252
|
+
else if (typeof record.publicKeyPem === "string") {
|
|
253
|
+
pem = record.publicKeyPem;
|
|
254
|
+
}
|
|
255
|
+
if (typeof pem === "string" && pem.length > 0) {
|
|
256
|
+
try {
|
|
257
|
+
const key = await importSPKI(pem, algorithm);
|
|
258
|
+
return key;
|
|
259
|
+
}
|
|
260
|
+
catch (error) {
|
|
261
|
+
logger.debug("aft_spki_import_failed", {
|
|
262
|
+
kid: keyRecord.kid,
|
|
263
|
+
algorithm,
|
|
264
|
+
error: error instanceof Error ? error.message : String(error),
|
|
265
|
+
});
|
|
266
|
+
}
|
|
267
|
+
}
|
|
268
|
+
logger.debug("aft_verification_key_unavailable", {
|
|
269
|
+
kid: keyRecord.kid,
|
|
270
|
+
algorithm,
|
|
271
|
+
});
|
|
272
|
+
return null;
|
|
273
|
+
}
|
|
274
|
+
export function createAftVerifier(options) {
|
|
275
|
+
const { securityLevel, keyProvider, defaultTtlSec = 30 } = options;
|
|
276
|
+
switch (securityLevel) {
|
|
277
|
+
case StickinessMode.STRICT:
|
|
278
|
+
if (!keyProvider) {
|
|
279
|
+
throw new Error("StrictAFTVerifier requires a KeyProvider instance");
|
|
280
|
+
}
|
|
281
|
+
return new StrictAFTVerifier(keyProvider, defaultTtlSec);
|
|
282
|
+
case StickinessMode.SIGNED_OPTIONAL:
|
|
283
|
+
return new SignedOptionalAFTVerifier(keyProvider, defaultTtlSec);
|
|
284
|
+
case StickinessMode.SID_ONLY:
|
|
285
|
+
return new SidOnlyAFTVerifier(defaultTtlSec);
|
|
286
|
+
default:
|
|
287
|
+
throw new Error(`Unknown security level: ${securityLevel}`);
|
|
288
|
+
}
|
|
289
|
+
}
|
|
290
|
+
//# sourceMappingURL=aft-verifier.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"aft-verifier.js","sourceRoot":"","sources":["../../../../../src/naylence/fame/stickiness/aft-verifier.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
export { StickinessMode, normalizeStickinessMode } from "./stickiness-mode.js";
|
|
2
|
+
export { createAftPayload, serializeAftClaims, serializeAftHeader, } from "./aft-model.js";
|
|
3
|
+
export { base64UrlEncode, base64UrlDecode, utf8Decode } from "./aft-utils.js";
|
|
4
|
+
export { createAftSigner, UnsignedAFTSigner, SignedAFTSigner, NoAFTSigner, } from "./aft-signer.js";
|
|
5
|
+
export { AFTHelper, createAftHelper, DEFAULT_STICKINESS_SECURITY_LEVEL, } from "./aft-helper.js";
|
|
6
|
+
export { createAftVerifier, StrictAFTVerifier, SignedOptionalAFTVerifier, SidOnlyAFTVerifier, } from "./aft-verifier.js";
|
|
7
|
+
export { AFTLoadBalancerStickinessManager } from "./aft-load-balancer-stickiness-manager.js";
|
|
8
|
+
export { AFTLoadBalancerStickinessManagerFactory, FACTORY_META as AFT_LOAD_BALANCER_FACTORY_META, } from "./aft-load-balancer-stickiness-manager-factory.js";
|
|
9
|
+
export { AFTReplicaStickinessManager, createAftReplicaStickinessManager, } from "./aft-replica-stickiness-manager.js";
|
|
10
|
+
export { AFTReplicaStickinessManagerFactory, FACTORY_META as AFT_REPLICA_FACTORY_META, } from "./aft-replica-stickiness-manager-factory.js";
|
|
11
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../src/naylence/fame/stickiness/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,uBAAuB,EAAE,MAAM,sBAAsB,CAAC;AAE/E,OAAO,EACL,gBAAgB,EAChB,kBAAkB,EAClB,kBAAkB,GACnB,MAAM,gBAAgB,CAAC;AACxB,OAAO,EAAE,eAAe,EAAE,eAAe,EAAE,UAAU,EAAE,MAAM,gBAAgB,CAAC;AAE9E,OAAO,EACL,eAAe,EACf,iBAAiB,EACjB,eAAe,EACf,WAAW,GACZ,MAAM,iBAAiB,CAAC;AAEzB,OAAO,EACL,SAAS,EACT,eAAe,EACf,iCAAiC,GAClC,MAAM,iBAAiB,CAAC;AAEzB,OAAO,EACL,iBAAiB,EACjB,iBAAiB,EACjB,yBAAyB,EACzB,kBAAkB,GACnB,MAAM,mBAAmB,CAAC;AAC3B,OAAO,EAAE,gCAAgC,EAAE,MAAM,2CAA2C,CAAC;AAC7F,OAAO,EACL,uCAAuC,EACvC,YAAY,IAAI,8BAA8B,GAC/C,MAAM,mDAAmD,CAAC;AAC3D,OAAO,EACL,2BAA2B,EAC3B,iCAAiC,GAClC,MAAM,qCAAqC,CAAC;AAC7C,OAAO,EACL,kCAAkC,EAClC,YAAY,IAAI,wBAAwB,GACzC,MAAM,6CAA6C,CAAC"}
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
export var StickinessMode;
|
|
2
|
+
(function (StickinessMode) {
|
|
3
|
+
StickinessMode["STRICT"] = "strict";
|
|
4
|
+
StickinessMode["SIGNED_OPTIONAL"] = "signed-optional";
|
|
5
|
+
StickinessMode["SID_ONLY"] = "sid-only";
|
|
6
|
+
})(StickinessMode || (StickinessMode = {}));
|
|
7
|
+
export function normalizeStickinessMode(value) {
|
|
8
|
+
switch (value) {
|
|
9
|
+
case StickinessMode.STRICT:
|
|
10
|
+
case "strict":
|
|
11
|
+
return StickinessMode.STRICT;
|
|
12
|
+
case StickinessMode.SIGNED_OPTIONAL:
|
|
13
|
+
case "signed-optional":
|
|
14
|
+
case "signed_optional":
|
|
15
|
+
return StickinessMode.SIGNED_OPTIONAL;
|
|
16
|
+
case StickinessMode.SID_ONLY:
|
|
17
|
+
case "sid-only":
|
|
18
|
+
case "sid_only":
|
|
19
|
+
return StickinessMode.SID_ONLY;
|
|
20
|
+
default:
|
|
21
|
+
throw new Error(`Unknown stickiness mode: ${value}`);
|
|
22
|
+
}
|
|
23
|
+
}
|
|
24
|
+
//# sourceMappingURL=stickiness-mode.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"stickiness-mode.js","sourceRoot":"","sources":["../../../../../src/naylence/fame/stickiness/stickiness-mode.ts"],"names":[],"mappings":"AAAA,MAAM,CAAN,IAAY,cAIX;AAJD,WAAY,cAAc;IACxB,mCAAiB,CAAA;IACjB,qDAAmC,CAAA;IACnC,uCAAqB,CAAA;AACvB,CAAC,EAJW,cAAc,KAAd,cAAc,QAIzB;AAED,MAAM,UAAU,uBAAuB,CACrC,KAA8B;IAE9B,QAAQ,KAAK,EAAE,CAAC;QACd,KAAK,cAAc,CAAC,MAAM,CAAC;QAC3B,KAAK,QAAQ;YACX,OAAO,cAAc,CAAC,MAAM,CAAC;QAC/B,KAAK,cAAc,CAAC,eAAe,CAAC;QACpC,KAAK,iBAAiB,CAAC;QACvB,KAAK,iBAAiB;YACpB,OAAO,cAAc,CAAC,eAAe,CAAC;QACxC,KAAK,cAAc,CAAC,QAAQ,CAAC;QAC7B,KAAK,UAAU,CAAC;QAChB,KAAK,UAAU;YACb,OAAO,cAAc,CAAC,QAAQ,CAAC;QACjC;YACE,MAAM,IAAI,KAAK,CAAC,4BAA4B,KAAK,EAAE,CAAC,CAAC;IACzD,CAAC;AACH,CAAC"}
|
|
@@ -0,0 +1,93 @@
|
|
|
1
|
+
import { AuthorizerFactory, TokenIssuerFactory, NodePlacementStrategyFactory, TransportProvisionerFactory, WelcomeServiceFactory, WELCOME_SERVICE_FACTORY_BASE_TYPE, } from "@naylence/runtime";
|
|
2
|
+
import { AdvancedWelcomeService, } from "./advanced-welcome-service.js";
|
|
3
|
+
export const FACTORY_META = {
|
|
4
|
+
base: WELCOME_SERVICE_FACTORY_BASE_TYPE,
|
|
5
|
+
key: "AdvancedWelcomeService",
|
|
6
|
+
priority: 100,
|
|
7
|
+
isDefault: true,
|
|
8
|
+
};
|
|
9
|
+
export class AdvancedWelcomeServiceFactory extends WelcomeServiceFactory {
|
|
10
|
+
constructor() {
|
|
11
|
+
super(...arguments);
|
|
12
|
+
this.type = FACTORY_META.key;
|
|
13
|
+
this.isDefault = FACTORY_META.isDefault;
|
|
14
|
+
this.priority = FACTORY_META.priority;
|
|
15
|
+
}
|
|
16
|
+
async create(config, ...factoryArgs) {
|
|
17
|
+
const normalized = normalizeConfig(config);
|
|
18
|
+
// Crypto provider should be passed from upstream (node-welcome-server)
|
|
19
|
+
// Do not create it here - downstream components should use what's passed in factoryArgs
|
|
20
|
+
const placementStrategy = await NodePlacementStrategyFactory.createNodePlacementStrategy(normalized.placementConfig ?? null, factoryArgs.length > 0 ? { factoryArgs } : undefined);
|
|
21
|
+
const transportProvisioner = await TransportProvisionerFactory.createTransportProvisioner(normalized.transportConfig ?? null, factoryArgs.length > 0 ? { factoryArgs } : undefined);
|
|
22
|
+
const tokenIssuer = await TokenIssuerFactory.createTokenIssuer(normalized.tokenIssuerConfig ?? null, factoryArgs.length > 0 ? { factoryArgs } : undefined);
|
|
23
|
+
let authorizer = null;
|
|
24
|
+
if (normalized.authorizerConfig) {
|
|
25
|
+
authorizer =
|
|
26
|
+
(await AuthorizerFactory.createAuthorizer(normalized.authorizerConfig, {
|
|
27
|
+
factoryArgs,
|
|
28
|
+
})) ?? null;
|
|
29
|
+
}
|
|
30
|
+
const options = {
|
|
31
|
+
placementStrategy,
|
|
32
|
+
transportProvisioner,
|
|
33
|
+
tokenIssuer,
|
|
34
|
+
authorizer,
|
|
35
|
+
caServiceUrl: normalized.caServiceUrl,
|
|
36
|
+
};
|
|
37
|
+
if (normalized.ttlSec !== undefined) {
|
|
38
|
+
options.ttlSec = normalized.ttlSec;
|
|
39
|
+
}
|
|
40
|
+
return new AdvancedWelcomeService(options);
|
|
41
|
+
}
|
|
42
|
+
}
|
|
43
|
+
function normalizeConfig(config) {
|
|
44
|
+
if (!config) {
|
|
45
|
+
throw new Error("AdvancedWelcomeService requires configuration");
|
|
46
|
+
}
|
|
47
|
+
const source = config;
|
|
48
|
+
const ttlCandidate = typeof source.ttlSec === "number"
|
|
49
|
+
? source.ttlSec
|
|
50
|
+
: typeof source.ttl_sec === "number"
|
|
51
|
+
? source.ttl_sec
|
|
52
|
+
: undefined;
|
|
53
|
+
const caServiceUrlCandidate = typeof source.caServiceUrl === "string" &&
|
|
54
|
+
source.caServiceUrl.trim().length > 0
|
|
55
|
+
? source.caServiceUrl.trim()
|
|
56
|
+
: typeof source.ca_service_url === "string" &&
|
|
57
|
+
source.ca_service_url.trim().length > 0
|
|
58
|
+
? source.ca_service_url.trim()
|
|
59
|
+
: undefined;
|
|
60
|
+
if (!caServiceUrlCandidate) {
|
|
61
|
+
throw new Error("AdvancedWelcomeService configuration requires caServiceUrl");
|
|
62
|
+
}
|
|
63
|
+
const normalized = {
|
|
64
|
+
caServiceUrl: caServiceUrlCandidate,
|
|
65
|
+
};
|
|
66
|
+
if (source.placement !== undefined) {
|
|
67
|
+
normalized.placementConfig =
|
|
68
|
+
source.placement ?? null;
|
|
69
|
+
}
|
|
70
|
+
if (source.transport !== undefined) {
|
|
71
|
+
normalized.transportConfig =
|
|
72
|
+
source.transport ?? null;
|
|
73
|
+
}
|
|
74
|
+
const tokenIssuerConfig = source.tokenIssuer !== undefined
|
|
75
|
+
? source.tokenIssuer
|
|
76
|
+
: source.token_issuer !== undefined
|
|
77
|
+
? source.token_issuer
|
|
78
|
+
: undefined;
|
|
79
|
+
if (tokenIssuerConfig !== undefined) {
|
|
80
|
+
normalized.tokenIssuerConfig =
|
|
81
|
+
tokenIssuerConfig ?? null;
|
|
82
|
+
}
|
|
83
|
+
if (source.authorizer !== undefined) {
|
|
84
|
+
normalized.authorizerConfig =
|
|
85
|
+
source.authorizer ?? null;
|
|
86
|
+
}
|
|
87
|
+
if (ttlCandidate !== undefined && Number.isFinite(ttlCandidate)) {
|
|
88
|
+
normalized.ttlSec = ttlCandidate;
|
|
89
|
+
}
|
|
90
|
+
return normalized;
|
|
91
|
+
}
|
|
92
|
+
export default AdvancedWelcomeServiceFactory;
|
|
93
|
+
//# sourceMappingURL=advanced-welcome-service-factory.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"advanced-welcome-service-factory.js","sourceRoot":"","sources":["../../../../../src/naylence/fame/welcome/advanced-welcome-service-factory.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,212 @@
|
|
|
1
|
+
import { generateId, } from "@naylence/core";
|
|
2
|
+
import { HTTP_CONNECTION_GRANT_TYPE, color, AnsiColor, formatTimestamp, jsonDumps, validateHostLogicals, getLogger, } from "@naylence/runtime";
|
|
3
|
+
import { GRANT_PURPOSE_CA_SIGN } from "../security/cert/grants.js";
|
|
4
|
+
const logger = getLogger("naylence.fame.welcome.advanced_welcome_service");
|
|
5
|
+
const ENV_VAR_SHOW_ENVELOPES = "FAME_SHOW_ENVELOPES";
|
|
6
|
+
const DEFAULT_TTL_SEC = 3600;
|
|
7
|
+
const showEnvelopes = typeof process !== "undefined" &&
|
|
8
|
+
process.env?.[ENV_VAR_SHOW_ENVELOPES] === "true";
|
|
9
|
+
function nowUtc() {
|
|
10
|
+
return new Date();
|
|
11
|
+
}
|
|
12
|
+
function formatTimestampForConsole() {
|
|
13
|
+
return color(formatTimestamp(), AnsiColor.GRAY);
|
|
14
|
+
}
|
|
15
|
+
function prettyModel(value) {
|
|
16
|
+
try {
|
|
17
|
+
return jsonDumps(value);
|
|
18
|
+
}
|
|
19
|
+
catch (error) {
|
|
20
|
+
return String(error);
|
|
21
|
+
}
|
|
22
|
+
}
|
|
23
|
+
function coercePlacementMetadataValue(metadata, camelCaseKey, snakeCaseKey) {
|
|
24
|
+
if (!metadata) {
|
|
25
|
+
return undefined;
|
|
26
|
+
}
|
|
27
|
+
const record = metadata;
|
|
28
|
+
if (record[camelCaseKey] !== undefined) {
|
|
29
|
+
return record[camelCaseKey];
|
|
30
|
+
}
|
|
31
|
+
if (record[snakeCaseKey] !== undefined) {
|
|
32
|
+
return record[snakeCaseKey];
|
|
33
|
+
}
|
|
34
|
+
return undefined;
|
|
35
|
+
}
|
|
36
|
+
export class AdvancedWelcomeService {
|
|
37
|
+
constructor(options) {
|
|
38
|
+
this.placementStrategy = options.placementStrategy;
|
|
39
|
+
this.transportProvisioner = options.transportProvisioner;
|
|
40
|
+
this.tokenIssuer = options.tokenIssuer;
|
|
41
|
+
this.authorizer = options.authorizer ?? null;
|
|
42
|
+
this.caServiceUrl = options.caServiceUrl;
|
|
43
|
+
this.ttlSec =
|
|
44
|
+
typeof options.ttlSec === "number" && Number.isFinite(options.ttlSec)
|
|
45
|
+
? Math.max(0, options.ttlSec)
|
|
46
|
+
: DEFAULT_TTL_SEC;
|
|
47
|
+
logger.debug("initialized_advanced_welcome_service", {
|
|
48
|
+
ca_service_url: this.caServiceUrl,
|
|
49
|
+
ttl_sec: this.ttlSec,
|
|
50
|
+
});
|
|
51
|
+
}
|
|
52
|
+
async handleHello(hello, metadata) {
|
|
53
|
+
const fullMetadata = metadata
|
|
54
|
+
? { ...metadata }
|
|
55
|
+
: {};
|
|
56
|
+
const trimmedSystemId = typeof hello.systemId === "string" ? hello.systemId.trim() : "";
|
|
57
|
+
const systemId = trimmedSystemId.length > 0 ? trimmedSystemId : generateId();
|
|
58
|
+
const wasAssigned = trimmedSystemId.length === 0;
|
|
59
|
+
const normalizedHello = {
|
|
60
|
+
...hello,
|
|
61
|
+
systemId,
|
|
62
|
+
};
|
|
63
|
+
if (showEnvelopes) {
|
|
64
|
+
// eslint-disable-next-line no-console
|
|
65
|
+
console.log(`\n${formatTimestampForConsole()} - ${color("Received envelope 📨", AnsiColor.BLUE)}\n${prettyModel(normalizedHello)}`);
|
|
66
|
+
}
|
|
67
|
+
logger.debug("starting_hello_frame_processing", {
|
|
68
|
+
instanceId: normalizedHello.instanceId,
|
|
69
|
+
systemId,
|
|
70
|
+
logicals: normalizedHello.logicals,
|
|
71
|
+
capabilities: normalizedHello.capabilities,
|
|
72
|
+
ttlSec: this.ttlSec,
|
|
73
|
+
});
|
|
74
|
+
const now = nowUtc();
|
|
75
|
+
const expiry = new Date(now.getTime() + this.ttlSec * 1000);
|
|
76
|
+
if (normalizedHello.instanceId) {
|
|
77
|
+
if (fullMetadata.instanceId === undefined) {
|
|
78
|
+
fullMetadata.instanceId = normalizedHello.instanceId;
|
|
79
|
+
}
|
|
80
|
+
if (fullMetadata.instance_id === undefined) {
|
|
81
|
+
fullMetadata.instance_id = normalizedHello.instanceId;
|
|
82
|
+
}
|
|
83
|
+
}
|
|
84
|
+
logger.debug("system_id_assignment_completed", {
|
|
85
|
+
systemId,
|
|
86
|
+
wasAssigned,
|
|
87
|
+
});
|
|
88
|
+
if (normalizedHello.logicals?.length) {
|
|
89
|
+
logger.debug("validating_logicals_for_dns_compatibility", {
|
|
90
|
+
logicals: normalizedHello.logicals,
|
|
91
|
+
});
|
|
92
|
+
const [pathsValid, pathError] = validateHostLogicals(normalizedHello.logicals);
|
|
93
|
+
if (!pathsValid) {
|
|
94
|
+
logger.error("logical_validation_failed", {
|
|
95
|
+
error: pathError,
|
|
96
|
+
logicals: normalizedHello.logicals,
|
|
97
|
+
});
|
|
98
|
+
throw new Error(`Invalid logical format: ${pathError}`);
|
|
99
|
+
}
|
|
100
|
+
logger.debug("logicals_validation_successful");
|
|
101
|
+
}
|
|
102
|
+
logger.debug("requesting_node_placement", { systemId });
|
|
103
|
+
const placementResult = await this.placementStrategy.place(normalizedHello);
|
|
104
|
+
if (!placementResult.accept) {
|
|
105
|
+
logger.error("node_placement_rejected", {
|
|
106
|
+
systemId,
|
|
107
|
+
reason: placementResult.reason,
|
|
108
|
+
});
|
|
109
|
+
throw new Error(placementResult.reason || "Node not accepted");
|
|
110
|
+
}
|
|
111
|
+
const assignedPath = placementResult.assignedPath;
|
|
112
|
+
logger.debug("node_placement_accepted", {
|
|
113
|
+
systemId,
|
|
114
|
+
assignedPath,
|
|
115
|
+
targetPhysicalPath: placementResult.targetPhysicalPath ?? null,
|
|
116
|
+
targetSystemId: placementResult.targetSystemId ?? null,
|
|
117
|
+
});
|
|
118
|
+
const acceptedCapabilities = coercePlacementMetadataValue(placementResult.metadata, "acceptedCapabilities", "accepted_capabilities") ??
|
|
119
|
+
normalizedHello.capabilities ??
|
|
120
|
+
null;
|
|
121
|
+
const acceptedLogicals = coercePlacementMetadataValue(placementResult.metadata, "acceptedLogicals", "accepted_logicals") ??
|
|
122
|
+
normalizedHello.logicals ??
|
|
123
|
+
null;
|
|
124
|
+
logger.debug("processing_placement_result_metadata", {
|
|
125
|
+
acceptedCapabilities,
|
|
126
|
+
acceptedLogicals,
|
|
127
|
+
hasPlacementMetadata: placementResult.metadata !== undefined &&
|
|
128
|
+
placementResult.metadata !== null,
|
|
129
|
+
});
|
|
130
|
+
const connectionGrants = [];
|
|
131
|
+
const metadataInstanceId = (typeof fullMetadata.instanceId === "string" &&
|
|
132
|
+
fullMetadata.instanceId) ||
|
|
133
|
+
(typeof fullMetadata.instance_id === "string" &&
|
|
134
|
+
fullMetadata.instance_id) ||
|
|
135
|
+
normalizedHello.instanceId ||
|
|
136
|
+
generateId();
|
|
137
|
+
if (placementResult.targetSystemId) {
|
|
138
|
+
logger.debug("issuing_node_attach_token", {
|
|
139
|
+
systemId,
|
|
140
|
+
assignedPath,
|
|
141
|
+
});
|
|
142
|
+
const nodeAttachToken = await this.tokenIssuer.issue({
|
|
143
|
+
aud: placementResult.targetPhysicalPath,
|
|
144
|
+
system_id: systemId,
|
|
145
|
+
parent_path: placementResult.targetPhysicalPath,
|
|
146
|
+
assigned_path: placementResult.assignedPath,
|
|
147
|
+
accepted_logicals: acceptedLogicals,
|
|
148
|
+
instance_id: metadataInstanceId,
|
|
149
|
+
});
|
|
150
|
+
logger.debug("token_issued_successfully");
|
|
151
|
+
logger.debug("provisioning_transport", { systemId });
|
|
152
|
+
const transportInfo = await this.transportProvisioner.provision(placementResult, normalizedHello, fullMetadata, nodeAttachToken);
|
|
153
|
+
logger.debug("transport_provisioned_successfully", {
|
|
154
|
+
systemId,
|
|
155
|
+
directiveType: transportInfo.connectionGrant &&
|
|
156
|
+
typeof transportInfo.connectionGrant === "object"
|
|
157
|
+
? (transportInfo.connectionGrant.type ??
|
|
158
|
+
"Unknown")
|
|
159
|
+
: "Unknown",
|
|
160
|
+
});
|
|
161
|
+
connectionGrants.push(transportInfo.connectionGrant);
|
|
162
|
+
}
|
|
163
|
+
const caSignToken = await this.tokenIssuer.issue({
|
|
164
|
+
aud: "ca",
|
|
165
|
+
system_id: systemId,
|
|
166
|
+
assigned_path: assignedPath,
|
|
167
|
+
accepted_logicals: acceptedLogicals,
|
|
168
|
+
instance_id: metadataInstanceId,
|
|
169
|
+
});
|
|
170
|
+
const caGrant = {
|
|
171
|
+
type: HTTP_CONNECTION_GRANT_TYPE,
|
|
172
|
+
purpose: GRANT_PURPOSE_CA_SIGN,
|
|
173
|
+
url: this.caServiceUrl,
|
|
174
|
+
auth: {
|
|
175
|
+
type: "BearerTokenHeaderAuth",
|
|
176
|
+
tokenProvider: {
|
|
177
|
+
type: "StaticTokenProvider",
|
|
178
|
+
token: caSignToken,
|
|
179
|
+
},
|
|
180
|
+
},
|
|
181
|
+
};
|
|
182
|
+
connectionGrants.push(caGrant);
|
|
183
|
+
const welcomeFrame = {
|
|
184
|
+
type: "NodeWelcome",
|
|
185
|
+
systemId,
|
|
186
|
+
targetSystemId: placementResult.targetSystemId ?? undefined,
|
|
187
|
+
targetPhysicalPath: placementResult.targetPhysicalPath ?? undefined,
|
|
188
|
+
instanceId: normalizedHello.instanceId,
|
|
189
|
+
assignedPath,
|
|
190
|
+
acceptedCapabilities: acceptedCapabilities ?? undefined,
|
|
191
|
+
acceptedLogicals: acceptedLogicals ?? undefined,
|
|
192
|
+
rejectedLogicals: undefined,
|
|
193
|
+
connectionGrants,
|
|
194
|
+
metadata: Object.keys(fullMetadata).length > 0 ? fullMetadata : undefined,
|
|
195
|
+
expiresAt: expiry.toISOString(),
|
|
196
|
+
};
|
|
197
|
+
logger.debug("hello_frame_processing_completed_successfully", {
|
|
198
|
+
systemId,
|
|
199
|
+
assignedPath,
|
|
200
|
+
acceptedLogicals,
|
|
201
|
+
acceptedCapabilities,
|
|
202
|
+
expiresAt: welcomeFrame.expiresAt,
|
|
203
|
+
instanceId: normalizedHello.instanceId,
|
|
204
|
+
});
|
|
205
|
+
if (showEnvelopes) {
|
|
206
|
+
// eslint-disable-next-line no-console
|
|
207
|
+
console.log(`\n${formatTimestampForConsole()} - ${color("Sent envelope", AnsiColor.BLUE)} 🚀\n${prettyModel(welcomeFrame)}`);
|
|
208
|
+
}
|
|
209
|
+
return welcomeFrame;
|
|
210
|
+
}
|
|
211
|
+
}
|
|
212
|
+
//# sourceMappingURL=advanced-welcome-service.js.map
|