@tidecloak/js 0.9.11
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/LICENSE +334 -0
- package/README.md +294 -0
- package/dist/cjs/lib/tidecloak.js +1934 -0
- package/dist/cjs/lib/tidecloak.js.map +1 -0
- package/dist/cjs/modules/tide-js/Clients/ClientBase.js +213 -0
- package/dist/cjs/modules/tide-js/Clients/ClientBase.js.map +1 -0
- package/dist/cjs/modules/tide-js/Clients/NetworkClient.js +96 -0
- package/dist/cjs/modules/tide-js/Clients/NetworkClient.js.map +1 -0
- package/dist/cjs/modules/tide-js/Clients/NodeClient.js +491 -0
- package/dist/cjs/modules/tide-js/Clients/NodeClient.js.map +1 -0
- package/dist/cjs/modules/tide-js/Clients/PollingClient.js +87 -0
- package/dist/cjs/modules/tide-js/Clients/PollingClient.js.map +1 -0
- package/dist/cjs/modules/tide-js/Clients/VoucherClient.js +37 -0
- package/dist/cjs/modules/tide-js/Clients/VoucherClient.js.map +1 -0
- package/dist/cjs/modules/tide-js/Cryptide/Components/BaseComponent.js +180 -0
- package/dist/cjs/modules/tide-js/Cryptide/Components/BaseComponent.js.map +1 -0
- package/dist/cjs/modules/tide-js/Cryptide/Components/ComponentRegistry.js +30 -0
- package/dist/cjs/modules/tide-js/Cryptide/Components/ComponentRegistry.js.map +1 -0
- package/dist/cjs/modules/tide-js/Cryptide/Components/Schemes/AES/AESScheme.js +11 -0
- package/dist/cjs/modules/tide-js/Cryptide/Components/Schemes/AES/AESScheme.js.map +1 -0
- package/dist/cjs/modules/tide-js/Cryptide/Components/Schemes/BaseScheme.js +13 -0
- package/dist/cjs/modules/tide-js/Cryptide/Components/Schemes/BaseScheme.js.map +1 -0
- package/dist/cjs/modules/tide-js/Cryptide/Components/Schemes/Ed25519/Ed25519Components.js +166 -0
- package/dist/cjs/modules/tide-js/Cryptide/Components/Schemes/Ed25519/Ed25519Components.js.map +1 -0
- package/dist/cjs/modules/tide-js/Cryptide/Components/Schemes/Ed25519/Ed25519Scheme.js +41 -0
- package/dist/cjs/modules/tide-js/Cryptide/Components/Schemes/Ed25519/Ed25519Scheme.js.map +1 -0
- package/dist/cjs/modules/tide-js/Cryptide/Components/Schemes/SchemeRegistry.js +13 -0
- package/dist/cjs/modules/tide-js/Cryptide/Components/Schemes/SchemeRegistry.js.map +1 -0
- package/dist/cjs/modules/tide-js/Cryptide/Ed25519.js +535 -0
- package/dist/cjs/modules/tide-js/Cryptide/Ed25519.js.map +1 -0
- package/dist/cjs/modules/tide-js/Cryptide/Encryption/AES.js +109 -0
- package/dist/cjs/modules/tide-js/Cryptide/Encryption/AES.js.map +1 -0
- package/dist/cjs/modules/tide-js/Cryptide/Encryption/DH.js +53 -0
- package/dist/cjs/modules/tide-js/Cryptide/Encryption/DH.js.map +1 -0
- package/dist/cjs/modules/tide-js/Cryptide/Encryption/ElGamal.js +59 -0
- package/dist/cjs/modules/tide-js/Cryptide/Encryption/ElGamal.js.map +1 -0
- package/dist/cjs/modules/tide-js/Cryptide/Hashing/H2P.js +248 -0
- package/dist/cjs/modules/tide-js/Cryptide/Hashing/H2P.js.map +1 -0
- package/dist/cjs/modules/tide-js/Cryptide/Hashing/Hash.js +60 -0
- package/dist/cjs/modules/tide-js/Cryptide/Hashing/Hash.js.map +1 -0
- package/dist/cjs/modules/tide-js/Cryptide/Interpolation.js +107 -0
- package/dist/cjs/modules/tide-js/Cryptide/Interpolation.js.map +1 -0
- package/dist/cjs/modules/tide-js/Cryptide/Math.js +134 -0
- package/dist/cjs/modules/tide-js/Cryptide/Math.js.map +1 -0
- package/dist/cjs/modules/tide-js/Cryptide/Serialization.js +680 -0
- package/dist/cjs/modules/tide-js/Cryptide/Serialization.js.map +1 -0
- package/dist/cjs/modules/tide-js/Cryptide/Signing/BlindSig.js +56 -0
- package/dist/cjs/modules/tide-js/Cryptide/Signing/BlindSig.js.map +1 -0
- package/dist/cjs/modules/tide-js/Cryptide/Signing/EdDSA.js +84 -0
- package/dist/cjs/modules/tide-js/Cryptide/Signing/EdDSA.js.map +1 -0
- package/dist/cjs/modules/tide-js/Cryptide/Signing/TideSignature.js +102 -0
- package/dist/cjs/modules/tide-js/Cryptide/Signing/TideSignature.js.map +1 -0
- package/dist/cjs/modules/tide-js/Cryptide/TideKey.js +77 -0
- package/dist/cjs/modules/tide-js/Cryptide/TideKey.js.map +1 -0
- package/dist/cjs/modules/tide-js/Cryptide/TideMemoryObjects.js +34 -0
- package/dist/cjs/modules/tide-js/Cryptide/TideMemoryObjects.js.map +1 -0
- package/dist/cjs/modules/tide-js/Cryptide/index.js +74 -0
- package/dist/cjs/modules/tide-js/Cryptide/index.js.map +1 -0
- package/dist/cjs/modules/tide-js/Flow/AuthenticationFlows/dCMKAcceptAdminFlow.js +6 -0
- package/dist/cjs/modules/tide-js/Flow/AuthenticationFlows/dCMKAcceptAdminFlow.js.map +1 -0
- package/dist/cjs/modules/tide-js/Flow/AuthenticationFlows/dCMKPasswordFlow.js +138 -0
- package/dist/cjs/modules/tide-js/Flow/AuthenticationFlows/dCMKPasswordFlow.js.map +1 -0
- package/dist/cjs/modules/tide-js/Flow/AuthenticationFlows/dCMKPasswordlessFlow.js +83 -0
- package/dist/cjs/modules/tide-js/Flow/AuthenticationFlows/dCMKPasswordlessFlow.js.map +1 -0
- package/dist/cjs/modules/tide-js/Flow/AuthenticationFlows/dCVKAuthenticationFlow.js +3 -0
- package/dist/cjs/modules/tide-js/Flow/AuthenticationFlows/dCVKAuthenticationFlow.js.map +1 -0
- package/dist/cjs/modules/tide-js/Flow/DecryptionFlows/dVVKDecryptionFlow.js +58 -0
- package/dist/cjs/modules/tide-js/Flow/DecryptionFlows/dVVKDecryptionFlow.js.map +1 -0
- package/dist/cjs/modules/tide-js/Flow/EncryptionFlows/AuthorizedEncryptionFlow.js +180 -0
- package/dist/cjs/modules/tide-js/Flow/EncryptionFlows/AuthorizedEncryptionFlow.js.map +1 -0
- package/dist/cjs/modules/tide-js/Flow/SigningFlows/AuthorizedSigningFlow.js +49 -0
- package/dist/cjs/modules/tide-js/Flow/SigningFlows/AuthorizedSigningFlow.js.map +1 -0
- package/dist/cjs/modules/tide-js/Flow/SigningFlows/dTestVVkSigningFlow.js +70 -0
- package/dist/cjs/modules/tide-js/Flow/SigningFlows/dTestVVkSigningFlow.js.map +1 -0
- package/dist/cjs/modules/tide-js/Flow/SigningFlows/dVVKSigningFlow.js +73 -0
- package/dist/cjs/modules/tide-js/Flow/SigningFlows/dVVKSigningFlow.js.map +1 -0
- package/dist/cjs/modules/tide-js/Flow/SigningFlows/dVVKSigningFlow_DEPRECATED.js +67 -0
- package/dist/cjs/modules/tide-js/Flow/SigningFlows/dVVKSigningFlow_DEPRECATED.js.map +1 -0
- package/dist/cjs/modules/tide-js/Flow/SimulatorFlow.js +57 -0
- package/dist/cjs/modules/tide-js/Flow/SimulatorFlow.js.map +1 -0
- package/dist/cjs/modules/tide-js/Flow/VoucherFlows/VoucherFlow.js +51 -0
- package/dist/cjs/modules/tide-js/Flow/VoucherFlows/VoucherFlow.js.map +1 -0
- package/dist/cjs/modules/tide-js/Flow/dAccountRecoveryFlow.js +95 -0
- package/dist/cjs/modules/tide-js/Flow/dAccountRecoveryFlow.js.map +1 -0
- package/dist/cjs/modules/tide-js/Flow/dKeyGenerationFlow.js +219 -0
- package/dist/cjs/modules/tide-js/Flow/dKeyGenerationFlow.js.map +1 -0
- package/dist/cjs/modules/tide-js/Math/DecryptRequest.js +52 -0
- package/dist/cjs/modules/tide-js/Math/DecryptRequest.js.map +1 -0
- package/dist/cjs/modules/tide-js/Math/EncryptRequest.js +96 -0
- package/dist/cjs/modules/tide-js/Math/EncryptRequest.js.map +1 -0
- package/dist/cjs/modules/tide-js/Math/KeyAuthentication.js +222 -0
- package/dist/cjs/modules/tide-js/Math/KeyAuthentication.js.map +1 -0
- package/dist/cjs/modules/tide-js/Math/KeyDecryption.js +18 -0
- package/dist/cjs/modules/tide-js/Math/KeyDecryption.js.map +1 -0
- package/dist/cjs/modules/tide-js/Math/KeyGeneration.js +148 -0
- package/dist/cjs/modules/tide-js/Math/KeyGeneration.js.map +1 -0
- package/dist/cjs/modules/tide-js/Math/KeySigning.js +24 -0
- package/dist/cjs/modules/tide-js/Math/KeySigning.js.map +1 -0
- package/dist/cjs/modules/tide-js/Models/AdminAuthorization.js +83 -0
- package/dist/cjs/modules/tide-js/Models/AdminAuthorization.js.map +1 -0
- package/dist/cjs/modules/tide-js/Models/AuthRequest.js +66 -0
- package/dist/cjs/modules/tide-js/Models/AuthRequest.js.map +1 -0
- package/dist/cjs/modules/tide-js/Models/AuthorizationBuilder.js +61 -0
- package/dist/cjs/modules/tide-js/Models/AuthorizationBuilder.js.map +1 -0
- package/dist/cjs/modules/tide-js/Models/BaseTideRequest.js +106 -0
- package/dist/cjs/modules/tide-js/Models/BaseTideRequest.js.map +1 -0
- package/dist/cjs/modules/tide-js/Models/Cardano/CardanoTxBody.js +198 -0
- package/dist/cjs/modules/tide-js/Models/Cardano/CardanoTxBody.js.map +1 -0
- package/dist/cjs/modules/tide-js/Models/Datum.js +41 -0
- package/dist/cjs/modules/tide-js/Models/Datum.js.map +1 -0
- package/dist/cjs/modules/tide-js/Models/Doken.js +140 -0
- package/dist/cjs/modules/tide-js/Models/Doken.js.map +1 -0
- package/dist/cjs/modules/tide-js/Models/EnclaveEntry.js +50 -0
- package/dist/cjs/modules/tide-js/Models/EnclaveEntry.js.map +1 -0
- package/dist/cjs/modules/tide-js/Models/Infos/KeyInfo.js +49 -0
- package/dist/cjs/modules/tide-js/Models/Infos/KeyInfo.js.map +1 -0
- package/dist/cjs/modules/tide-js/Models/Infos/OrkInfo.js +53 -0
- package/dist/cjs/modules/tide-js/Models/Infos/OrkInfo.js.map +1 -0
- package/dist/cjs/modules/tide-js/Models/InitializationCertificate.js +35 -0
- package/dist/cjs/modules/tide-js/Models/InitializationCertificate.js.map +1 -0
- package/dist/cjs/modules/tide-js/Models/ModelRegistry.js +177 -0
- package/dist/cjs/modules/tide-js/Models/ModelRegistry.js.map +1 -0
- package/dist/cjs/modules/tide-js/Models/Responses/KeyAuth/Authenticate/AuthenticateResponse.js +34 -0
- package/dist/cjs/modules/tide-js/Models/Responses/KeyAuth/Authenticate/AuthenticateResponse.js.map +1 -0
- package/dist/cjs/modules/tide-js/Models/Responses/KeyAuth/Convert/CMKConvertResponse.js +36 -0
- package/dist/cjs/modules/tide-js/Models/Responses/KeyAuth/Convert/CMKConvertResponse.js.map +1 -0
- package/dist/cjs/modules/tide-js/Models/Responses/KeyAuth/Convert/ConvertRememberedResponse.js +36 -0
- package/dist/cjs/modules/tide-js/Models/Responses/KeyAuth/Convert/ConvertRememberedResponse.js.map +1 -0
- package/dist/cjs/modules/tide-js/Models/Responses/KeyAuth/Convert/DecryptedCMKConvertResponse.js +34 -0
- package/dist/cjs/modules/tide-js/Models/Responses/KeyAuth/Convert/DecryptedCMKConvertResponse.js.map +1 -0
- package/dist/cjs/modules/tide-js/Models/Responses/KeyAuth/Convert/DecryptedConvertRememberedResponse.js +37 -0
- package/dist/cjs/modules/tide-js/Models/Responses/KeyAuth/Convert/DecryptedConvertRememberedResponse.js.map +1 -0
- package/dist/cjs/modules/tide-js/Models/Responses/KeyAuth/Convert/DecryptedPrismConvertResponse.js +37 -0
- package/dist/cjs/modules/tide-js/Models/Responses/KeyAuth/Convert/DecryptedPrismConvertResponse.js.map +1 -0
- package/dist/cjs/modules/tide-js/Models/Responses/KeyAuth/Convert/PrismConvertResponse.js +36 -0
- package/dist/cjs/modules/tide-js/Models/Responses/KeyAuth/Convert/PrismConvertResponse.js.map +1 -0
- package/dist/cjs/modules/tide-js/Models/Responses/KeyGen/GenShard/DecryptedGenShardResponse.js +49 -0
- package/dist/cjs/modules/tide-js/Models/Responses/KeyGen/GenShard/DecryptedGenShardResponse.js.map +1 -0
- package/dist/cjs/modules/tide-js/Models/Responses/KeyGen/GenShard/GenShardResponse.js +34 -0
- package/dist/cjs/modules/tide-js/Models/Responses/KeyGen/GenShard/GenShardResponse.js.map +1 -0
- package/dist/cjs/modules/tide-js/Models/Responses/KeyGen/SetShard/DecryptedSetShardResponse.js +39 -0
- package/dist/cjs/modules/tide-js/Models/Responses/KeyGen/SetShard/DecryptedSetShardResponse.js.map +1 -0
- package/dist/cjs/modules/tide-js/Models/Responses/KeyGen/SetShard/SetShardResponse.js +31 -0
- package/dist/cjs/modules/tide-js/Models/Responses/KeyGen/SetShard/SetShardResponse.js.map +1 -0
- package/dist/cjs/modules/tide-js/Models/Responses/Reservation/ReservationConfirmation.js +26 -0
- package/dist/cjs/modules/tide-js/Models/Responses/Reservation/ReservationConfirmation.js.map +1 -0
- package/dist/cjs/modules/tide-js/Models/Responses/Vendor/VoucherResponse.js +41 -0
- package/dist/cjs/modules/tide-js/Models/Responses/Vendor/VoucherResponse.js.map +1 -0
- package/dist/cjs/modules/tide-js/Models/Rules/RuleSettingSignRequest.js +81 -0
- package/dist/cjs/modules/tide-js/Models/Rules/RuleSettingSignRequest.js.map +1 -0
- package/dist/cjs/modules/tide-js/Models/Rules/RuleSettings.js +28 -0
- package/dist/cjs/modules/tide-js/Models/Rules/RuleSettings.js.map +1 -0
- package/dist/cjs/modules/tide-js/Models/SerializedField.js +63 -0
- package/dist/cjs/modules/tide-js/Models/SerializedField.js.map +1 -0
- package/dist/cjs/modules/tide-js/Models/Transactions/CardanoTxBodySignRequest.js +57 -0
- package/dist/cjs/modules/tide-js/Models/Transactions/CardanoTxBodySignRequest.js.map +1 -0
- package/dist/cjs/modules/tide-js/Models/VendorData.js +36 -0
- package/dist/cjs/modules/tide-js/Models/VendorData.js.map +1 -0
- package/dist/cjs/modules/tide-js/Models/VendorSettings.js +26 -0
- package/dist/cjs/modules/tide-js/Models/VendorSettings.js.map +1 -0
- package/dist/cjs/modules/tide-js/RulesEngine/RuleEngineService.js +92 -0
- package/dist/cjs/modules/tide-js/RulesEngine/RuleEngineService.js.map +1 -0
- package/dist/cjs/modules/tide-js/RulesEngine/helperFunctions.js +78 -0
- package/dist/cjs/modules/tide-js/RulesEngine/helperFunctions.js.map +1 -0
- package/dist/cjs/modules/tide-js/RulesEngine/jsonHelpers.js +68 -0
- package/dist/cjs/modules/tide-js/RulesEngine/jsonHelpers.js.map +1 -0
- package/dist/cjs/modules/tide-js/RulesEngine/thresholdRules.js +106 -0
- package/dist/cjs/modules/tide-js/RulesEngine/thresholdRules.js.map +1 -0
- package/dist/cjs/modules/tide-js/Tests/AccountRecovery.js +58 -0
- package/dist/cjs/modules/tide-js/Tests/AccountRecovery.js.map +1 -0
- package/dist/cjs/modules/tide-js/Tests/Components.js +18 -0
- package/dist/cjs/modules/tide-js/Tests/Components.js.map +1 -0
- package/dist/cjs/modules/tide-js/Tests/Encryption.js +172 -0
- package/dist/cjs/modules/tide-js/Tests/Encryption.js.map +1 -0
- package/dist/cjs/modules/tide-js/Tests/KeyAuthentication.js +113 -0
- package/dist/cjs/modules/tide-js/Tests/KeyAuthentication.js.map +1 -0
- package/dist/cjs/modules/tide-js/Tests/KeyGeneration.js +222 -0
- package/dist/cjs/modules/tide-js/Tests/KeyGeneration.js.map +1 -0
- package/dist/cjs/modules/tide-js/Tests/StripeLicensing.js +41 -0
- package/dist/cjs/modules/tide-js/Tests/StripeLicensing.js.map +1 -0
- package/dist/cjs/modules/tide-js/Tests/TideKey.js +17 -0
- package/dist/cjs/modules/tide-js/Tests/TideKey.js.map +1 -0
- package/dist/cjs/modules/tide-js/Tests/Verifier.js +12 -0
- package/dist/cjs/modules/tide-js/Tests/Verifier.js.map +1 -0
- package/dist/cjs/modules/tide-js/Tests/index.js +43 -0
- package/dist/cjs/modules/tide-js/Tests/index.js.map +1 -0
- package/dist/cjs/modules/tide-js/Tools/Utils.js +285 -0
- package/dist/cjs/modules/tide-js/Tools/Utils.js.map +1 -0
- package/dist/cjs/modules/tide-js/index.js +71 -0
- package/dist/cjs/modules/tide-js/index.js.map +1 -0
- package/dist/cjs/src/IAMService.js +278 -0
- package/dist/cjs/src/IAMService.js.map +1 -0
- package/dist/cjs/src/index.js +19 -0
- package/dist/cjs/src/index.js.map +1 -0
- package/dist/esm/lib/tidecloak.js +1923 -0
- package/dist/esm/lib/tidecloak.js.map +1 -0
- package/dist/esm/modules/tide-js/Clients/ClientBase.js +210 -0
- package/dist/esm/modules/tide-js/Clients/ClientBase.js.map +1 -0
- package/dist/esm/modules/tide-js/Clients/NetworkClient.js +90 -0
- package/dist/esm/modules/tide-js/Clients/NetworkClient.js.map +1 -0
- package/dist/esm/modules/tide-js/Clients/NodeClient.js +485 -0
- package/dist/esm/modules/tide-js/Clients/NodeClient.js.map +1 -0
- package/dist/esm/modules/tide-js/Clients/PollingClient.js +81 -0
- package/dist/esm/modules/tide-js/Clients/PollingClient.js.map +1 -0
- package/dist/esm/modules/tide-js/Clients/VoucherClient.js +31 -0
- package/dist/esm/modules/tide-js/Clients/VoucherClient.js.map +1 -0
- package/dist/esm/modules/tide-js/Cryptide/Components/BaseComponent.js +169 -0
- package/dist/esm/modules/tide-js/Cryptide/Components/BaseComponent.js.map +1 -0
- package/dist/esm/modules/tide-js/Cryptide/Components/ComponentRegistry.js +24 -0
- package/dist/esm/modules/tide-js/Cryptide/Components/ComponentRegistry.js.map +1 -0
- package/dist/esm/modules/tide-js/Cryptide/Components/Schemes/AES/AESScheme.js +5 -0
- package/dist/esm/modules/tide-js/Cryptide/Components/Schemes/AES/AESScheme.js.map +1 -0
- package/dist/esm/modules/tide-js/Cryptide/Components/Schemes/BaseScheme.js +11 -0
- package/dist/esm/modules/tide-js/Cryptide/Components/Schemes/BaseScheme.js.map +1 -0
- package/dist/esm/modules/tide-js/Cryptide/Components/Schemes/Ed25519/Ed25519Components.js +157 -0
- package/dist/esm/modules/tide-js/Cryptide/Components/Schemes/Ed25519/Ed25519Components.js.map +1 -0
- package/dist/esm/modules/tide-js/Cryptide/Components/Schemes/Ed25519/Ed25519Scheme.js +36 -0
- package/dist/esm/modules/tide-js/Cryptide/Components/Schemes/Ed25519/Ed25519Scheme.js.map +1 -0
- package/dist/esm/modules/tide-js/Cryptide/Components/Schemes/SchemeRegistry.js +7 -0
- package/dist/esm/modules/tide-js/Cryptide/Components/Schemes/SchemeRegistry.js.map +1 -0
- package/dist/esm/modules/tide-js/Cryptide/Ed25519.js +523 -0
- package/dist/esm/modules/tide-js/Cryptide/Ed25519.js.map +1 -0
- package/dist/esm/modules/tide-js/Cryptide/Encryption/AES.js +102 -0
- package/dist/esm/modules/tide-js/Cryptide/Encryption/AES.js.map +1 -0
- package/dist/esm/modules/tide-js/Cryptide/Encryption/DH.js +49 -0
- package/dist/esm/modules/tide-js/Cryptide/Encryption/DH.js.map +1 -0
- package/dist/esm/modules/tide-js/Cryptide/Encryption/ElGamal.js +56 -0
- package/dist/esm/modules/tide-js/Cryptide/Encryption/ElGamal.js.map +1 -0
- package/dist/esm/modules/tide-js/Cryptide/Hashing/H2P.js +245 -0
- package/dist/esm/modules/tide-js/Cryptide/Hashing/H2P.js.map +1 -0
- package/dist/esm/modules/tide-js/Cryptide/Hashing/Hash.js +55 -0
- package/dist/esm/modules/tide-js/Cryptide/Hashing/Hash.js.map +1 -0
- package/dist/esm/modules/tide-js/Cryptide/Interpolation.js +97 -0
- package/dist/esm/modules/tide-js/Cryptide/Interpolation.js.map +1 -0
- package/dist/esm/modules/tide-js/Cryptide/Math.js +120 -0
- package/dist/esm/modules/tide-js/Cryptide/Math.js.map +1 -0
- package/dist/esm/modules/tide-js/Cryptide/Serialization.js +642 -0
- package/dist/esm/modules/tide-js/Cryptide/Serialization.js.map +1 -0
- package/dist/esm/modules/tide-js/Cryptide/Signing/BlindSig.js +50 -0
- package/dist/esm/modules/tide-js/Cryptide/Signing/BlindSig.js.map +1 -0
- package/dist/esm/modules/tide-js/Cryptide/Signing/EdDSA.js +79 -0
- package/dist/esm/modules/tide-js/Cryptide/Signing/EdDSA.js.map +1 -0
- package/dist/esm/modules/tide-js/Cryptide/Signing/TideSignature.js +91 -0
- package/dist/esm/modules/tide-js/Cryptide/Signing/TideSignature.js.map +1 -0
- package/dist/esm/modules/tide-js/Cryptide/TideKey.js +71 -0
- package/dist/esm/modules/tide-js/Cryptide/TideKey.js.map +1 -0
- package/dist/esm/modules/tide-js/Cryptide/TideMemoryObjects.js +30 -0
- package/dist/esm/modules/tide-js/Cryptide/TideMemoryObjects.js.map +1 -0
- package/dist/esm/modules/tide-js/Cryptide/index.js +34 -0
- package/dist/esm/modules/tide-js/Cryptide/index.js.map +1 -0
- package/dist/esm/modules/tide-js/Flow/AuthenticationFlows/dCMKAcceptAdminFlow.js +3 -0
- package/dist/esm/modules/tide-js/Flow/AuthenticationFlows/dCMKAcceptAdminFlow.js.map +1 -0
- package/dist/esm/modules/tide-js/Flow/AuthenticationFlows/dCMKPasswordFlow.js +132 -0
- package/dist/esm/modules/tide-js/Flow/AuthenticationFlows/dCMKPasswordFlow.js.map +1 -0
- package/dist/esm/modules/tide-js/Flow/AuthenticationFlows/dCMKPasswordlessFlow.js +77 -0
- package/dist/esm/modules/tide-js/Flow/AuthenticationFlows/dCMKPasswordlessFlow.js.map +1 -0
- package/dist/esm/modules/tide-js/Flow/AuthenticationFlows/dCVKAuthenticationFlow.js +2 -0
- package/dist/esm/modules/tide-js/Flow/AuthenticationFlows/dCVKAuthenticationFlow.js.map +1 -0
- package/dist/esm/modules/tide-js/Flow/DecryptionFlows/dVVKDecryptionFlow.js +52 -0
- package/dist/esm/modules/tide-js/Flow/DecryptionFlows/dVVKDecryptionFlow.js.map +1 -0
- package/dist/esm/modules/tide-js/Flow/EncryptionFlows/AuthorizedEncryptionFlow.js +174 -0
- package/dist/esm/modules/tide-js/Flow/EncryptionFlows/AuthorizedEncryptionFlow.js.map +1 -0
- package/dist/esm/modules/tide-js/Flow/SigningFlows/AuthorizedSigningFlow.js +43 -0
- package/dist/esm/modules/tide-js/Flow/SigningFlows/AuthorizedSigningFlow.js.map +1 -0
- package/dist/esm/modules/tide-js/Flow/SigningFlows/dTestVVkSigningFlow.js +64 -0
- package/dist/esm/modules/tide-js/Flow/SigningFlows/dTestVVkSigningFlow.js.map +1 -0
- package/dist/esm/modules/tide-js/Flow/SigningFlows/dVVKSigningFlow.js +67 -0
- package/dist/esm/modules/tide-js/Flow/SigningFlows/dVVKSigningFlow.js.map +1 -0
- package/dist/esm/modules/tide-js/Flow/SigningFlows/dVVKSigningFlow_DEPRECATED.js +61 -0
- package/dist/esm/modules/tide-js/Flow/SigningFlows/dVVKSigningFlow_DEPRECATED.js.map +1 -0
- package/dist/esm/modules/tide-js/Flow/SimulatorFlow.js +51 -0
- package/dist/esm/modules/tide-js/Flow/SimulatorFlow.js.map +1 -0
- package/dist/esm/modules/tide-js/Flow/VoucherFlows/VoucherFlow.js +45 -0
- package/dist/esm/modules/tide-js/Flow/VoucherFlows/VoucherFlow.js.map +1 -0
- package/dist/esm/modules/tide-js/Flow/dAccountRecoveryFlow.js +89 -0
- package/dist/esm/modules/tide-js/Flow/dAccountRecoveryFlow.js.map +1 -0
- package/dist/esm/modules/tide-js/Flow/dKeyGenerationFlow.js +213 -0
- package/dist/esm/modules/tide-js/Flow/dKeyGenerationFlow.js.map +1 -0
- package/dist/esm/modules/tide-js/Math/DecryptRequest.js +46 -0
- package/dist/esm/modules/tide-js/Math/DecryptRequest.js.map +1 -0
- package/dist/esm/modules/tide-js/Math/EncryptRequest.js +90 -0
- package/dist/esm/modules/tide-js/Math/EncryptRequest.js.map +1 -0
- package/dist/esm/modules/tide-js/Math/KeyAuthentication.js +211 -0
- package/dist/esm/modules/tide-js/Math/KeyAuthentication.js.map +1 -0
- package/dist/esm/modules/tide-js/Math/KeyDecryption.js +15 -0
- package/dist/esm/modules/tide-js/Math/KeyDecryption.js.map +1 -0
- package/dist/esm/modules/tide-js/Math/KeyGeneration.js +141 -0
- package/dist/esm/modules/tide-js/Math/KeyGeneration.js.map +1 -0
- package/dist/esm/modules/tide-js/Math/KeySigning.js +20 -0
- package/dist/esm/modules/tide-js/Math/KeySigning.js.map +1 -0
- package/dist/esm/modules/tide-js/Models/AdminAuthorization.js +79 -0
- package/dist/esm/modules/tide-js/Models/AdminAuthorization.js.map +1 -0
- package/dist/esm/modules/tide-js/Models/AuthRequest.js +63 -0
- package/dist/esm/modules/tide-js/Models/AuthRequest.js.map +1 -0
- package/dist/esm/modules/tide-js/Models/AuthorizationBuilder.js +55 -0
- package/dist/esm/modules/tide-js/Models/AuthorizationBuilder.js.map +1 -0
- package/dist/esm/modules/tide-js/Models/BaseTideRequest.js +103 -0
- package/dist/esm/modules/tide-js/Models/BaseTideRequest.js.map +1 -0
- package/dist/esm/modules/tide-js/Models/Cardano/CardanoTxBody.js +195 -0
- package/dist/esm/modules/tide-js/Models/Cardano/CardanoTxBody.js.map +1 -0
- package/dist/esm/modules/tide-js/Models/Datum.js +38 -0
- package/dist/esm/modules/tide-js/Models/Datum.js.map +1 -0
- package/dist/esm/modules/tide-js/Models/Doken.js +134 -0
- package/dist/esm/modules/tide-js/Models/Doken.js.map +1 -0
- package/dist/esm/modules/tide-js/Models/EnclaveEntry.js +44 -0
- package/dist/esm/modules/tide-js/Models/EnclaveEntry.js.map +1 -0
- package/dist/esm/modules/tide-js/Models/Infos/KeyInfo.js +43 -0
- package/dist/esm/modules/tide-js/Models/Infos/KeyInfo.js.map +1 -0
- package/dist/esm/modules/tide-js/Models/Infos/OrkInfo.js +50 -0
- package/dist/esm/modules/tide-js/Models/Infos/OrkInfo.js.map +1 -0
- package/dist/esm/modules/tide-js/Models/InitializationCertificate.js +32 -0
- package/dist/esm/modules/tide-js/Models/InitializationCertificate.js.map +1 -0
- package/dist/esm/modules/tide-js/Models/ModelRegistry.js +169 -0
- package/dist/esm/modules/tide-js/Models/ModelRegistry.js.map +1 -0
- package/dist/esm/modules/tide-js/Models/Responses/KeyAuth/Authenticate/AuthenticateResponse.js +31 -0
- package/dist/esm/modules/tide-js/Models/Responses/KeyAuth/Authenticate/AuthenticateResponse.js.map +1 -0
- package/dist/esm/modules/tide-js/Models/Responses/KeyAuth/Convert/CMKConvertResponse.js +33 -0
- package/dist/esm/modules/tide-js/Models/Responses/KeyAuth/Convert/CMKConvertResponse.js.map +1 -0
- package/dist/esm/modules/tide-js/Models/Responses/KeyAuth/Convert/ConvertRememberedResponse.js +33 -0
- package/dist/esm/modules/tide-js/Models/Responses/KeyAuth/Convert/ConvertRememberedResponse.js.map +1 -0
- package/dist/esm/modules/tide-js/Models/Responses/KeyAuth/Convert/DecryptedCMKConvertResponse.js +31 -0
- package/dist/esm/modules/tide-js/Models/Responses/KeyAuth/Convert/DecryptedCMKConvertResponse.js.map +1 -0
- package/dist/esm/modules/tide-js/Models/Responses/KeyAuth/Convert/DecryptedConvertRememberedResponse.js +34 -0
- package/dist/esm/modules/tide-js/Models/Responses/KeyAuth/Convert/DecryptedConvertRememberedResponse.js.map +1 -0
- package/dist/esm/modules/tide-js/Models/Responses/KeyAuth/Convert/DecryptedPrismConvertResponse.js +34 -0
- package/dist/esm/modules/tide-js/Models/Responses/KeyAuth/Convert/DecryptedPrismConvertResponse.js.map +1 -0
- package/dist/esm/modules/tide-js/Models/Responses/KeyAuth/Convert/PrismConvertResponse.js +33 -0
- package/dist/esm/modules/tide-js/Models/Responses/KeyAuth/Convert/PrismConvertResponse.js.map +1 -0
- package/dist/esm/modules/tide-js/Models/Responses/KeyGen/GenShard/DecryptedGenShardResponse.js +46 -0
- package/dist/esm/modules/tide-js/Models/Responses/KeyGen/GenShard/DecryptedGenShardResponse.js.map +1 -0
- package/dist/esm/modules/tide-js/Models/Responses/KeyGen/GenShard/GenShardResponse.js +31 -0
- package/dist/esm/modules/tide-js/Models/Responses/KeyGen/GenShard/GenShardResponse.js.map +1 -0
- package/dist/esm/modules/tide-js/Models/Responses/KeyGen/SetShard/DecryptedSetShardResponse.js +36 -0
- package/dist/esm/modules/tide-js/Models/Responses/KeyGen/SetShard/DecryptedSetShardResponse.js.map +1 -0
- package/dist/esm/modules/tide-js/Models/Responses/KeyGen/SetShard/SetShardResponse.js +28 -0
- package/dist/esm/modules/tide-js/Models/Responses/KeyGen/SetShard/SetShardResponse.js.map +1 -0
- package/dist/esm/modules/tide-js/Models/Responses/Reservation/ReservationConfirmation.js +23 -0
- package/dist/esm/modules/tide-js/Models/Responses/Reservation/ReservationConfirmation.js.map +1 -0
- package/dist/esm/modules/tide-js/Models/Responses/Vendor/VoucherResponse.js +38 -0
- package/dist/esm/modules/tide-js/Models/Responses/Vendor/VoucherResponse.js.map +1 -0
- package/dist/esm/modules/tide-js/Models/Rules/RuleSettingSignRequest.js +75 -0
- package/dist/esm/modules/tide-js/Models/Rules/RuleSettingSignRequest.js.map +1 -0
- package/dist/esm/modules/tide-js/Models/Rules/RuleSettings.js +25 -0
- package/dist/esm/modules/tide-js/Models/Rules/RuleSettings.js.map +1 -0
- package/dist/esm/modules/tide-js/Models/SerializedField.js +61 -0
- package/dist/esm/modules/tide-js/Models/SerializedField.js.map +1 -0
- package/dist/esm/modules/tide-js/Models/Transactions/CardanoTxBodySignRequest.js +51 -0
- package/dist/esm/modules/tide-js/Models/Transactions/CardanoTxBodySignRequest.js.map +1 -0
- package/dist/esm/modules/tide-js/Models/VendorData.js +30 -0
- package/dist/esm/modules/tide-js/Models/VendorData.js.map +1 -0
- package/dist/esm/modules/tide-js/Models/VendorSettings.js +23 -0
- package/dist/esm/modules/tide-js/Models/VendorSettings.js.map +1 -0
- package/dist/esm/modules/tide-js/RulesEngine/RuleEngineService.js +89 -0
- package/dist/esm/modules/tide-js/RulesEngine/RuleEngineService.js.map +1 -0
- package/dist/esm/modules/tide-js/RulesEngine/helperFunctions.js +69 -0
- package/dist/esm/modules/tide-js/RulesEngine/helperFunctions.js.map +1 -0
- package/dist/esm/modules/tide-js/RulesEngine/jsonHelpers.js +64 -0
- package/dist/esm/modules/tide-js/RulesEngine/jsonHelpers.js.map +1 -0
- package/dist/esm/modules/tide-js/RulesEngine/thresholdRules.js +100 -0
- package/dist/esm/modules/tide-js/RulesEngine/thresholdRules.js.map +1 -0
- package/dist/esm/modules/tide-js/Tests/AccountRecovery.js +52 -0
- package/dist/esm/modules/tide-js/Tests/AccountRecovery.js.map +1 -0
- package/dist/esm/modules/tide-js/Tests/Components.js +15 -0
- package/dist/esm/modules/tide-js/Tests/Components.js.map +1 -0
- package/dist/esm/modules/tide-js/Tests/Encryption.js +164 -0
- package/dist/esm/modules/tide-js/Tests/Encryption.js.map +1 -0
- package/dist/esm/modules/tide-js/Tests/KeyAuthentication.js +106 -0
- package/dist/esm/modules/tide-js/Tests/KeyAuthentication.js.map +1 -0
- package/dist/esm/modules/tide-js/Tests/KeyGeneration.js +213 -0
- package/dist/esm/modules/tide-js/Tests/KeyGeneration.js.map +1 -0
- package/dist/esm/modules/tide-js/Tests/StripeLicensing.js +34 -0
- package/dist/esm/modules/tide-js/Tests/StripeLicensing.js.map +1 -0
- package/dist/esm/modules/tide-js/Tests/TideKey.js +11 -0
- package/dist/esm/modules/tide-js/Tests/TideKey.js.map +1 -0
- package/dist/esm/modules/tide-js/Tests/Verifier.js +9 -0
- package/dist/esm/modules/tide-js/Tests/Verifier.js.map +1 -0
- package/dist/esm/modules/tide-js/Tests/index.js +37 -0
- package/dist/esm/modules/tide-js/Tests/index.js.map +1 -0
- package/dist/esm/modules/tide-js/Tools/Utils.js +273 -0
- package/dist/esm/modules/tide-js/Tools/Utils.js.map +1 -0
- package/dist/esm/modules/tide-js/index.js +27 -0
- package/dist/esm/modules/tide-js/index.js.map +1 -0
- package/dist/esm/src/IAMService.js +272 -0
- package/dist/esm/src/IAMService.js.map +1 -0
- package/dist/esm/src/index.js +8 -0
- package/dist/esm/src/index.js.map +1 -0
- package/dist/silent-check-sso.html +1 -0
- package/dist/types/lib/tidecloak.d.ts +36 -0
- package/dist/types/modules/tide-js/Clients/ClientBase.d.ts +72 -0
- package/dist/types/modules/tide-js/Clients/NetworkClient.d.ts +23 -0
- package/dist/types/modules/tide-js/Clients/NodeClient.d.ts +187 -0
- package/dist/types/modules/tide-js/Clients/PollingClient.d.ts +22 -0
- package/dist/types/modules/tide-js/Clients/VoucherClient.d.ts +12 -0
- package/dist/types/modules/tide-js/Cryptide/Components/BaseComponent.d.ts +59 -0
- package/dist/types/modules/tide-js/Cryptide/Components/ComponentRegistry.d.ts +19 -0
- package/dist/types/modules/tide-js/Cryptide/Components/Schemes/AES/AESScheme.d.ts +4 -0
- package/dist/types/modules/tide-js/Cryptide/Components/Schemes/BaseScheme.d.ts +10 -0
- package/dist/types/modules/tide-js/Cryptide/Components/Schemes/Ed25519/Ed25519Components.d.ts +51 -0
- package/dist/types/modules/tide-js/Cryptide/Components/Schemes/Ed25519/Ed25519Scheme.d.ts +10 -0
- package/dist/types/modules/tide-js/Cryptide/Components/Schemes/SchemeRegistry.d.ts +3 -0
- package/dist/types/modules/tide-js/Cryptide/Ed25519.d.ts +114 -0
- package/dist/types/modules/tide-js/Cryptide/Encryption/AES.d.ts +30 -0
- package/dist/types/modules/tide-js/Cryptide/Encryption/DH.d.ts +12 -0
- package/dist/types/modules/tide-js/Cryptide/Encryption/ElGamal.d.ts +20 -0
- package/dist/types/modules/tide-js/Cryptide/Hashing/H2P.d.ts +7 -0
- package/dist/types/modules/tide-js/Cryptide/Hashing/Hash.d.ts +16 -0
- package/dist/types/modules/tide-js/Cryptide/Interpolation.d.ts +47 -0
- package/dist/types/modules/tide-js/Cryptide/Math.d.ts +45 -0
- package/dist/types/modules/tide-js/Cryptide/Serialization.d.ts +195 -0
- package/dist/types/modules/tide-js/Cryptide/Signing/BlindSig.d.ts +32 -0
- package/dist/types/modules/tide-js/Cryptide/Signing/EdDSA.d.ts +24 -0
- package/dist/types/modules/tide-js/Cryptide/Signing/TideSignature.d.ts +50 -0
- package/dist/types/modules/tide-js/Cryptide/TideKey.d.ts +24 -0
- package/dist/types/modules/tide-js/Cryptide/TideMemoryObjects.d.ts +15 -0
- package/dist/types/modules/tide-js/Cryptide/index.d.ts +10 -0
- package/dist/types/modules/tide-js/Flow/AuthenticationFlows/dCMKAcceptAdminFlow.d.ts +2 -0
- package/dist/types/modules/tide-js/Flow/AuthenticationFlows/dCMKPasswordFlow.d.ts +64 -0
- package/dist/types/modules/tide-js/Flow/AuthenticationFlows/dCMKPasswordlessFlow.d.ts +37 -0
- package/dist/types/modules/tide-js/Flow/AuthenticationFlows/dCVKAuthenticationFlow.d.ts +1 -0
- package/dist/types/modules/tide-js/Flow/DecryptionFlows/dVVKDecryptionFlow.d.ts +31 -0
- package/dist/types/modules/tide-js/Flow/EncryptionFlows/AuthorizedEncryptionFlow.d.ts +75 -0
- package/dist/types/modules/tide-js/Flow/SigningFlows/AuthorizedSigningFlow.d.ts +51 -0
- package/dist/types/modules/tide-js/Flow/SigningFlows/dTestVVkSigningFlow.d.ts +25 -0
- package/dist/types/modules/tide-js/Flow/SigningFlows/dVVKSigningFlow.d.ts +32 -0
- package/dist/types/modules/tide-js/Flow/SigningFlows/dVVKSigningFlow_DEPRECATED.d.ts +30 -0
- package/dist/types/modules/tide-js/Flow/SimulatorFlow.d.ts +13 -0
- package/dist/types/modules/tide-js/Flow/VoucherFlows/VoucherFlow.d.ts +23 -0
- package/dist/types/modules/tide-js/Flow/dAccountRecoveryFlow.d.ts +41 -0
- package/dist/types/modules/tide-js/Flow/dKeyGenerationFlow.d.ts +104 -0
- package/dist/types/modules/tide-js/Math/DecryptRequest.d.ts +19 -0
- package/dist/types/modules/tide-js/Math/EncryptRequest.d.ts +57 -0
- package/dist/types/modules/tide-js/Math/KeyAuthentication.d.ts +95 -0
- package/dist/types/modules/tide-js/Math/KeyDecryption.d.ts +7 -0
- package/dist/types/modules/tide-js/Math/KeyGeneration.d.ts +42 -0
- package/dist/types/modules/tide-js/Math/KeySigning.d.ts +10 -0
- package/dist/types/modules/tide-js/Models/AdminAuthorization.d.ts +16 -0
- package/dist/types/modules/tide-js/Models/AuthRequest.d.ts +28 -0
- package/dist/types/modules/tide-js/Models/AuthorizationBuilder.d.ts +17 -0
- package/dist/types/modules/tide-js/Models/BaseTideRequest.d.ts +52 -0
- package/dist/types/modules/tide-js/Models/Cardano/CardanoTxBody.d.ts +16 -0
- package/dist/types/modules/tide-js/Models/Datum.d.ts +14 -0
- package/dist/types/modules/tide-js/Models/Doken.d.ts +52 -0
- package/dist/types/modules/tide-js/Models/EnclaveEntry.d.ts +22 -0
- package/dist/types/modules/tide-js/Models/Infos/KeyInfo.d.ts +30 -0
- package/dist/types/modules/tide-js/Models/Infos/OrkInfo.d.ts +24 -0
- package/dist/types/modules/tide-js/Models/InitializationCertificate.d.ts +21 -0
- package/dist/types/modules/tide-js/Models/ModelRegistry.d.ts +15 -0
- package/dist/types/modules/tide-js/Models/Responses/KeyAuth/Authenticate/AuthenticateResponse.d.ts +9 -0
- package/dist/types/modules/tide-js/Models/Responses/KeyAuth/Convert/CMKConvertResponse.d.ts +11 -0
- package/dist/types/modules/tide-js/Models/Responses/KeyAuth/Convert/ConvertRememberedResponse.d.ts +11 -0
- package/dist/types/modules/tide-js/Models/Responses/KeyAuth/Convert/DecryptedCMKConvertResponse.d.ts +9 -0
- package/dist/types/modules/tide-js/Models/Responses/KeyAuth/Convert/DecryptedConvertRememberedResponse.d.ts +11 -0
- package/dist/types/modules/tide-js/Models/Responses/KeyAuth/Convert/DecryptedPrismConvertResponse.d.ts +12 -0
- package/dist/types/modules/tide-js/Models/Responses/KeyAuth/Convert/PrismConvertResponse.d.ts +11 -0
- package/dist/types/modules/tide-js/Models/Responses/KeyGen/GenShard/DecryptedGenShardResponse.d.ts +18 -0
- package/dist/types/modules/tide-js/Models/Responses/KeyGen/GenShard/GenShardResponse.d.ts +10 -0
- package/dist/types/modules/tide-js/Models/Responses/KeyGen/SetShard/DecryptedSetShardResponse.d.ts +10 -0
- package/dist/types/modules/tide-js/Models/Responses/KeyGen/SetShard/SetShardResponse.d.ts +8 -0
- package/dist/types/modules/tide-js/Models/Responses/Reservation/ReservationConfirmation.d.ts +14 -0
- package/dist/types/modules/tide-js/Models/Responses/Vendor/VoucherResponse.d.ts +25 -0
- package/dist/types/modules/tide-js/Models/Rules/RuleSettingSignRequest.d.ts +39 -0
- package/dist/types/modules/tide-js/Models/Rules/RuleSettings.d.ts +12 -0
- package/dist/types/modules/tide-js/Models/SerializedField.d.ts +20 -0
- package/dist/types/modules/tide-js/Models/Transactions/CardanoTxBodySignRequest.d.ts +29 -0
- package/dist/types/modules/tide-js/Models/VendorData.d.ts +17 -0
- package/dist/types/modules/tide-js/Models/VendorSettings.d.ts +14 -0
- package/dist/types/modules/tide-js/RulesEngine/RuleEngineService.d.ts +25 -0
- package/dist/types/modules/tide-js/RulesEngine/helperFunctions.d.ts +7 -0
- package/dist/types/modules/tide-js/RulesEngine/jsonHelpers.d.ts +11 -0
- package/dist/types/modules/tide-js/RulesEngine/thresholdRules.d.ts +17 -0
- package/dist/types/modules/tide-js/Tests/AccountRecovery.d.ts +1 -0
- package/dist/types/modules/tide-js/Tests/Components.d.ts +1 -0
- package/dist/types/modules/tide-js/Tests/Encryption.d.ts +3 -0
- package/dist/types/modules/tide-js/Tests/KeyAuthentication.d.ts +2 -0
- package/dist/types/modules/tide-js/Tests/KeyGeneration.d.ts +4 -0
- package/dist/types/modules/tide-js/Tests/StripeLicensing.d.ts +2 -0
- package/dist/types/modules/tide-js/Tests/TideKey.d.ts +1 -0
- package/dist/types/modules/tide-js/Tests/Verifier.d.ts +1 -0
- package/dist/types/modules/tide-js/Tests/index.d.ts +32 -0
- package/dist/types/modules/tide-js/Tools/Utils.d.ts +34 -0
- package/dist/types/modules/tide-js/index.d.ts +8 -0
- package/dist/types/src/IAMService.d.ts +106 -0
- package/dist/types/src/index.d.ts +4 -0
- package/package.json +48 -0
- package/scripts/postinstall.js +43 -0
|
@@ -0,0 +1,69 @@
|
|
|
1
|
+
// helperFunctions.js (ESM)
|
|
2
|
+
export function isLessThan(value, ruleValue) {
|
|
3
|
+
const threshold = BigInt(ruleValue);
|
|
4
|
+
if (Array.isArray(value)) {
|
|
5
|
+
return BigInt(value.length) < threshold;
|
|
6
|
+
}
|
|
7
|
+
try {
|
|
8
|
+
return BigInt(value) < threshold;
|
|
9
|
+
}
|
|
10
|
+
catch (e) {
|
|
11
|
+
return false;
|
|
12
|
+
}
|
|
13
|
+
}
|
|
14
|
+
export function isGreaterThan(value, ruleValue) {
|
|
15
|
+
const threshold = BigInt(ruleValue);
|
|
16
|
+
if (Array.isArray(value)) {
|
|
17
|
+
return BigInt(value.length) > threshold;
|
|
18
|
+
}
|
|
19
|
+
try {
|
|
20
|
+
return BigInt(value) > threshold;
|
|
21
|
+
}
|
|
22
|
+
catch (e) {
|
|
23
|
+
return false;
|
|
24
|
+
}
|
|
25
|
+
}
|
|
26
|
+
export function isEqualTo(value, ruleValue) {
|
|
27
|
+
if (typeof value === "number" || typeof value === "bigint") {
|
|
28
|
+
try {
|
|
29
|
+
return BigInt(value) === BigInt(ruleValue);
|
|
30
|
+
}
|
|
31
|
+
catch (e) {
|
|
32
|
+
return false;
|
|
33
|
+
}
|
|
34
|
+
}
|
|
35
|
+
return String(value) === ruleValue;
|
|
36
|
+
}
|
|
37
|
+
export function filterValuesEqualTo(value, valueToExclude) {
|
|
38
|
+
return String(value) === valueToExclude;
|
|
39
|
+
}
|
|
40
|
+
export function filterValuesNotEqualTo(value, valueToKeep) {
|
|
41
|
+
return String(value) !== valueToKeep;
|
|
42
|
+
}
|
|
43
|
+
export function isTotalLessThan(elements, ruleValue) {
|
|
44
|
+
const threshold = BigInt(ruleValue);
|
|
45
|
+
let total = BigInt(0);
|
|
46
|
+
for (const el of elements) {
|
|
47
|
+
try {
|
|
48
|
+
total += BigInt(el);
|
|
49
|
+
}
|
|
50
|
+
catch (e) {
|
|
51
|
+
return false;
|
|
52
|
+
}
|
|
53
|
+
}
|
|
54
|
+
return total < threshold;
|
|
55
|
+
}
|
|
56
|
+
export function isTotalMoreThan(elements, ruleValue) {
|
|
57
|
+
const threshold = BigInt(ruleValue);
|
|
58
|
+
let total = BigInt(0);
|
|
59
|
+
for (const el of elements) {
|
|
60
|
+
try {
|
|
61
|
+
total += BigInt(el);
|
|
62
|
+
}
|
|
63
|
+
catch (e) {
|
|
64
|
+
return false;
|
|
65
|
+
}
|
|
66
|
+
}
|
|
67
|
+
return total > threshold;
|
|
68
|
+
}
|
|
69
|
+
//# sourceMappingURL=helperFunctions.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"helperFunctions.js","sourceRoot":"","sources":["../../../../../modules/tide-js/RulesEngine/helperFunctions.js"],"names":[],"mappings":"AAAA,2BAA2B;AAC3B,MAAM,UAAU,UAAU,CAAC,KAAK,EAAE,SAAS;IACvC,MAAM,SAAS,GAAG,MAAM,CAAC,SAAS,CAAC,CAAC;IACpC,IAAI,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE,CAAC;QACzB,OAAO,MAAM,CAAC,KAAK,CAAC,MAAM,CAAC,GAAG,SAAS,CAAC;IAC1C,CAAC;IACD,IAAI,CAAC;QACH,OAAO,MAAM,CAAC,KAAK,CAAC,GAAG,SAAS,CAAC;IACnC,CAAC;IAAC,OAAO,CAAC,EAAE,CAAC;QACX,OAAO,KAAK,CAAC;IACf,CAAC;AACH,CAAC;AAED,MAAM,UAAU,aAAa,CAAC,KAAK,EAAE,SAAS;IAC5C,MAAM,SAAS,GAAG,MAAM,CAAC,SAAS,CAAC,CAAC;IACpC,IAAI,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE,CAAC;QACzB,OAAO,MAAM,CAAC,KAAK,CAAC,MAAM,CAAC,GAAG,SAAS,CAAC;IAC1C,CAAC;IACD,IAAI,CAAC;QACH,OAAO,MAAM,CAAC,KAAK,CAAC,GAAG,SAAS,CAAC;IACnC,CAAC;IAAC,OAAO,CAAC,EAAE,CAAC;QACX,OAAO,KAAK,CAAC;IACf,CAAC;AACH,CAAC;AAED,MAAM,UAAU,SAAS,CAAC,KAAK,EAAE,SAAS;IACxC,IAAI,OAAO,KAAK,KAAK,QAAQ,IAAI,OAAO,KAAK,KAAK,QAAQ,EAAE,CAAC;QAC3D,IAAI,CAAC;YACH,OAAO,MAAM,CAAC,KAAK,CAAC,KAAK,MAAM,CAAC,SAAS,CAAC,CAAC;QAC7C,CAAC;QAAC,OAAO,CAAC,EAAE,CAAC;YACX,OAAO,KAAK,CAAC;QACf,CAAC;IACH,CAAC;IACD,OAAO,MAAM,CAAC,KAAK,CAAC,KAAK,SAAS,CAAC;AACrC,CAAC;AAED,MAAM,UAAU,mBAAmB,CAAC,KAAK,EAAE,cAAc;IACvD,OAAO,MAAM,CAAC,KAAK,CAAC,KAAK,cAAc,CAAC;AAC1C,CAAC;AAED,MAAM,UAAU,sBAAsB,CAAC,KAAK,EAAE,WAAW;IACvD,OAAO,MAAM,CAAC,KAAK,CAAC,KAAK,WAAW,CAAC;AACvC,CAAC;AAED,MAAM,UAAU,eAAe,CAAC,QAAQ,EAAE,SAAS;IACjD,MAAM,SAAS,GAAG,MAAM,CAAC,SAAS,CAAC,CAAC;IACpC,IAAI,KAAK,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;IACtB,KAAK,MAAM,EAAE,IAAI,QAAQ,EAAE,CAAC;QAC1B,IAAI,CAAC;YACH,KAAK,IAAI,MAAM,CAAC,EAAE,CAAC,CAAC;QACtB,CAAC;QAAC,OAAO,CAAC,EAAE,CAAC;YACX,OAAO,KAAK,CAAC;QACf,CAAC;IACH,CAAC;IACD,OAAO,KAAK,GAAG,SAAS,CAAC;AAC3B,CAAC;AAED,MAAM,UAAU,eAAe,CAAC,QAAQ,EAAE,SAAS;IACjD,MAAM,SAAS,GAAG,MAAM,CAAC,SAAS,CAAC,CAAC;IACpC,IAAI,KAAK,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;IACtB,KAAK,MAAM,EAAE,IAAI,QAAQ,EAAE,CAAC;QAC1B,IAAI,CAAC;YACH,KAAK,IAAI,MAAM,CAAC,EAAE,CAAC,CAAC;QACtB,CAAC;QAAC,OAAO,CAAC,EAAE,CAAC;YACX,OAAO,KAAK,CAAC;QACf,CAAC;IACH,CAAC;IACD,OAAO,KAAK,GAAG,SAAS,CAAC;AAC3B,CAAC"}
|
|
@@ -0,0 +1,64 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Recursively retrieves nested values from a JSON object
|
|
3
|
+
* using a dot-separated field path.
|
|
4
|
+
* Returns an array of values or null if the field path is not found.
|
|
5
|
+
*/
|
|
6
|
+
export function tryGetNestedValues(element, fieldPath) {
|
|
7
|
+
const keys = fieldPath.split(".");
|
|
8
|
+
let current = [element];
|
|
9
|
+
for (const key of keys) {
|
|
10
|
+
let next = [];
|
|
11
|
+
for (const obj of current) {
|
|
12
|
+
if (obj !== undefined && obj !== null) {
|
|
13
|
+
if (Array.isArray(obj)) {
|
|
14
|
+
for (const item of obj) {
|
|
15
|
+
if (item && typeof item === "object" && key in item) {
|
|
16
|
+
next.push(item[key]);
|
|
17
|
+
}
|
|
18
|
+
}
|
|
19
|
+
}
|
|
20
|
+
else if (typeof obj === "object" && key in obj) {
|
|
21
|
+
next.push(obj[key]);
|
|
22
|
+
}
|
|
23
|
+
}
|
|
24
|
+
}
|
|
25
|
+
if (next.length === 0)
|
|
26
|
+
return null;
|
|
27
|
+
current = next;
|
|
28
|
+
}
|
|
29
|
+
return current;
|
|
30
|
+
}
|
|
31
|
+
/**
|
|
32
|
+
* Applies filter conditions from the given rules onto the root JSON.
|
|
33
|
+
* Clones the JSON and filters out array items that match the filter criteria.
|
|
34
|
+
*/
|
|
35
|
+
export function applyFilterConditions(root, filters, filterEvaluators) {
|
|
36
|
+
const cloned = JSON.parse(JSON.stringify(root));
|
|
37
|
+
filters.forEach((rule) => {
|
|
38
|
+
const fieldParts = rule.field.split(".");
|
|
39
|
+
if (fieldParts.length < 2)
|
|
40
|
+
throw new Error("Invalid field path, expected at least two parts.");
|
|
41
|
+
const containerName = fieldParts[fieldParts.length - 2];
|
|
42
|
+
const key = fieldParts[fieldParts.length - 1];
|
|
43
|
+
if (!(containerName in cloned))
|
|
44
|
+
throw new Error(`Container ${containerName} not found in root`);
|
|
45
|
+
let items = cloned[containerName];
|
|
46
|
+
if (!Array.isArray(items))
|
|
47
|
+
throw new Error(`Expected ${containerName} to be an array.`);
|
|
48
|
+
rule.conditions.forEach((condition) => {
|
|
49
|
+
if (condition.method in filterEvaluators) {
|
|
50
|
+
const evaluator = filterEvaluators[condition.method];
|
|
51
|
+
const targetValue = condition.values[0];
|
|
52
|
+
items = items.filter((item) => {
|
|
53
|
+
if (!(key in item))
|
|
54
|
+
return false;
|
|
55
|
+
// If evaluator returns true then the item should be removed.
|
|
56
|
+
return !evaluator(item[key], targetValue);
|
|
57
|
+
});
|
|
58
|
+
}
|
|
59
|
+
});
|
|
60
|
+
cloned[containerName] = items;
|
|
61
|
+
});
|
|
62
|
+
return cloned;
|
|
63
|
+
}
|
|
64
|
+
//# sourceMappingURL=jsonHelpers.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"jsonHelpers.js","sourceRoot":"","sources":["../../../../../modules/tide-js/RulesEngine/jsonHelpers.js"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,100 @@
|
|
|
1
|
+
import RuleEngineService from "./RuleEngineService.js";
|
|
2
|
+
/**
|
|
3
|
+
* Process the rule settings for the specified key.
|
|
4
|
+
* A successful rule set is one where all of its conditions pass (filter rules are applied first, then non-filter).
|
|
5
|
+
* When multiple successful rule sets are found, if any include a rule with field "Outputs.Amount" that has
|
|
6
|
+
* a condition with method "TOTAL_LESS_THAN", we select the rule set whose condition value (converted to a number)
|
|
7
|
+
* is the lowest.
|
|
8
|
+
*
|
|
9
|
+
* @param {string} key - The key to select validation settings.
|
|
10
|
+
* @param {string} id - The substring that must be contained in the ruleSetId.
|
|
11
|
+
* @param {RuleSettings} ruleSettings - The rule settings object.
|
|
12
|
+
* @param {string} draftJson - The JSON string to evaluate.
|
|
13
|
+
* @returns {{ roles: string[], threshold: number }}
|
|
14
|
+
*/
|
|
15
|
+
export default function processThresholdRules(key, id, ruleSettings, draftJson) {
|
|
16
|
+
// Retrieve rule sets for the specified key.
|
|
17
|
+
const ruleSets = ruleSettings.validationSettings[key];
|
|
18
|
+
if (!ruleSets || ruleSets.length === 0) {
|
|
19
|
+
console.warn(`No rule sets found for key "${key}".`);
|
|
20
|
+
return { roles: [], threshold: 0 };
|
|
21
|
+
}
|
|
22
|
+
// Instantiate the rule engine.
|
|
23
|
+
const ruleEngine = new RuleEngineService();
|
|
24
|
+
let passingRuleSets = [];
|
|
25
|
+
// Loop through each rule set.
|
|
26
|
+
for (const ruleSet of ruleSets) {
|
|
27
|
+
// Only consider rule sets whose ruleSetId contains the specified substring.
|
|
28
|
+
if (ruleSet.ruleSetId && ruleSet.ruleSetId.includes(id)) {
|
|
29
|
+
// Evaluate the rule set.
|
|
30
|
+
// evaluateRules applies its filter rules first and then evaluates the remaining conditions.
|
|
31
|
+
if (ruleEngine.evaluateRules(ruleSet.rules, draftJson)) {
|
|
32
|
+
// A ruleset is successful if all of its rules pass.
|
|
33
|
+
// Get the threshold from outputs (if provided), converting to a number.
|
|
34
|
+
const threshold = (ruleSet.outputs && ruleSet.outputs["threshold"] !== undefined)
|
|
35
|
+
? Number(ruleSet.outputs["threshold"])
|
|
36
|
+
: 0;
|
|
37
|
+
// Derive the role by splitting the ruleSetId; use the last segment.
|
|
38
|
+
const parts = ruleSet.ruleSetId.split(".");
|
|
39
|
+
const role = parts[parts.length - 1];
|
|
40
|
+
passingRuleSets.push({ role, threshold, ruleSet });
|
|
41
|
+
}
|
|
42
|
+
}
|
|
43
|
+
}
|
|
44
|
+
// No rule set passed.
|
|
45
|
+
if (passingRuleSets.length === 0) {
|
|
46
|
+
throw new Error("No threshold rules passed");
|
|
47
|
+
}
|
|
48
|
+
// If multiple rule sets passed, try to find those that have a specific condition:
|
|
49
|
+
// the rule definition on field "Outputs.Amount" that includes a condition with method "TOTAL_LESS_THAN".
|
|
50
|
+
const passingWithTotalLessThan = passingRuleSets.filter(candidate => {
|
|
51
|
+
return candidate.ruleSet.rules.some(rule => rule.field === "Outputs.Amount" &&
|
|
52
|
+
rule.conditions && rule.conditions.some(cond => cond.method === "TOTAL_LESS_THAN"));
|
|
53
|
+
});
|
|
54
|
+
if (passingWithTotalLessThan.length > 0) {
|
|
55
|
+
// For each candidate, find the lowest processable value from its TOTAL_LESS_THAN condition.
|
|
56
|
+
const evaluatedCandidates = passingWithTotalLessThan.map(candidate => {
|
|
57
|
+
let processableValues = [];
|
|
58
|
+
candidate.ruleSet.rules.forEach(rule => {
|
|
59
|
+
// Only examine the rule if it applies to the field "Outputs.Amount".
|
|
60
|
+
if (rule.field === "Outputs.Amount" && rule.conditions) {
|
|
61
|
+
rule.conditions.forEach(cond => {
|
|
62
|
+
if (cond.method === "TOTAL_LESS_THAN" &&
|
|
63
|
+
Array.isArray(cond.values) &&
|
|
64
|
+
cond.values.length > 0) {
|
|
65
|
+
const numVal = Number(cond.values[0]);
|
|
66
|
+
if (!isNaN(numVal)) {
|
|
67
|
+
processableValues.push(numVal);
|
|
68
|
+
}
|
|
69
|
+
}
|
|
70
|
+
});
|
|
71
|
+
}
|
|
72
|
+
});
|
|
73
|
+
// Determine the lowest processable value for this candidate.
|
|
74
|
+
const minProcessableValue = processableValues.length > 0 ? Math.min(...processableValues) : Infinity;
|
|
75
|
+
return { candidate, minProcessableValue };
|
|
76
|
+
});
|
|
77
|
+
// Sort candidates by the lowest processable value.
|
|
78
|
+
evaluatedCandidates.sort((a, b) => a.minProcessableValue - b.minProcessableValue);
|
|
79
|
+
const selected = evaluatedCandidates[0].candidate;
|
|
80
|
+
const allowedRoles = evaluatedCandidates.map(c => c.candidate.role);
|
|
81
|
+
return {
|
|
82
|
+
roles: allowedRoles,
|
|
83
|
+
threshold: selected.threshold
|
|
84
|
+
};
|
|
85
|
+
}
|
|
86
|
+
else {
|
|
87
|
+
// Fallback: If no rule set has the specific TOTAL_LESS_THAN condition,
|
|
88
|
+
// ensure that all passing rule sets have the same output threshold.
|
|
89
|
+
const uniqueThresholds = new Set(passingRuleSets.map(rs => rs.threshold));
|
|
90
|
+
if (uniqueThresholds.size > 1) {
|
|
91
|
+
throw new Error("Conflicting thresholds found among passing rule sets.");
|
|
92
|
+
}
|
|
93
|
+
const roles = passingRuleSets.map(rs => rs.role);
|
|
94
|
+
return {
|
|
95
|
+
roles,
|
|
96
|
+
threshold: passingRuleSets[0].threshold
|
|
97
|
+
};
|
|
98
|
+
}
|
|
99
|
+
}
|
|
100
|
+
//# sourceMappingURL=thresholdRules.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"thresholdRules.js","sourceRoot":"","sources":["../../../../../modules/tide-js/RulesEngine/thresholdRules.js"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,52 @@
|
|
|
1
|
+
import OrkInfo from "../Models/Infos/OrkInfo.js";
|
|
2
|
+
import HashToPoint from "../Cryptide/Hashing/H2P.js";
|
|
3
|
+
import { HMAC_forHashing } from "../Cryptide/Hashing/Hash.js";
|
|
4
|
+
import { Serialization } from "../Cryptide/index.js";
|
|
5
|
+
import { Math } from "../Cryptide/index.js";
|
|
6
|
+
import dKeyGenerationFlow from "../Flow/dKeyGenerationFlow.js";
|
|
7
|
+
import dAccountRecoveryFlow from "../Flow/dAccountRecoveryFlow.js";
|
|
8
|
+
import { CurrentTime, Max } from "../Tools/Utils.js";
|
|
9
|
+
import EnclaveEntry from "../Models/EnclaveEntry.js";
|
|
10
|
+
import { CreateGPrismAuth } from "../Cryptide/Math.js";
|
|
11
|
+
import KeyInfo from "../Models/Infos/KeyInfo.js";
|
|
12
|
+
import PollingClient from "../Clients/PollingClient.js";
|
|
13
|
+
import { Point } from "../Cryptide/Ed25519.js";
|
|
14
|
+
export async function EmailRecovery() {
|
|
15
|
+
var orks;
|
|
16
|
+
const user = Date.now().toString();
|
|
17
|
+
const persona = "1";
|
|
18
|
+
const emails = ["testEmail1@doge.com"];
|
|
19
|
+
const password = "pass";
|
|
20
|
+
const gPass = await HashToPoint(password);
|
|
21
|
+
const uid = await Serialization.GetUID(user);
|
|
22
|
+
const sessKey = Math.GenSessKey();
|
|
23
|
+
const gSessKey = Math.GetPublic(sessKey);
|
|
24
|
+
let GK;
|
|
25
|
+
const create = async () => {
|
|
26
|
+
// create account first
|
|
27
|
+
const purpose = "NEW";
|
|
28
|
+
const { reservationConfirmation, activeOrks } = (await dKeyGenerationFlow.ReserveUID(uid, "http://localhost:3000/voucher/new", gSessKey));
|
|
29
|
+
orks = activeOrks.slice(0, Max);
|
|
30
|
+
const genFlow = new dKeyGenerationFlow(uid, "", orks, sessKey, gSessKey, purpose, "http://localhost:3000/voucher/new", emails);
|
|
31
|
+
const { gMultiplied, gK } = await genFlow.GenShard(2, [null, gPass], reservationConfirmation); // auths can be null if purpose is "new", for now...
|
|
32
|
+
const gPrismAuth = await CreateGPrismAuth(gMultiplied[1]);
|
|
33
|
+
GK = gK;
|
|
34
|
+
await genFlow.SetShard(gPrismAuth, "CMK");
|
|
35
|
+
await genFlow.Commit();
|
|
36
|
+
};
|
|
37
|
+
const recover = async () => {
|
|
38
|
+
const newPassword = "pass1";
|
|
39
|
+
const newgPass = await HashToPoint(newPassword);
|
|
40
|
+
const homeOrkUrl = "http://host.docker.internal:1001";
|
|
41
|
+
const pollingClient = new PollingClient(homeOrkUrl);
|
|
42
|
+
const signal = new AbortController().signal;
|
|
43
|
+
const recoveryFlow = new dAccountRecoveryFlow(uid, orks, sessKey, gSessKey, "http://localhost:3000/voucher/new");
|
|
44
|
+
const { channelId, status: startAccountRecoveryStatus } = await recoveryFlow.StartAccountRecovery(homeOrkUrl, pollingClient, signal);
|
|
45
|
+
await recoveryFlow.RetrieveEmailAuths(channelId, () => { }, pollingClient, signal);
|
|
46
|
+
await recoveryFlow.GenerateNewPrism(GK, newgPass, Point.BASE);
|
|
47
|
+
};
|
|
48
|
+
await create();
|
|
49
|
+
await recover();
|
|
50
|
+
console.log("EmailRecovery TEST SUCCESSFUL");
|
|
51
|
+
}
|
|
52
|
+
//# sourceMappingURL=AccountRecovery.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"AccountRecovery.js","sourceRoot":"","sources":["../../../../../modules/tide-js/Tests/AccountRecovery.js"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import { Ed25519PrivateComponent, Ed25519PublicComponent } from "../Cryptide/Components/Schemes/Ed25519/Ed25519Components.js";
|
|
2
|
+
import { Point } from "../Cryptide/Ed25519.js";
|
|
3
|
+
export async function Ed25519PublicDeserialization() {
|
|
4
|
+
const gComp = new Ed25519PublicComponent(Point.BASE);
|
|
5
|
+
const serial = gComp.Serialize().ToString();
|
|
6
|
+
console.log(serial);
|
|
7
|
+
const newG = Ed25519PublicComponent.DeserializeComponent(serial);
|
|
8
|
+
console.log(newG);
|
|
9
|
+
const one = new Ed25519PrivateComponent(BigInt(1));
|
|
10
|
+
const oserial = one.Serialize().ToString();
|
|
11
|
+
console.log(oserial);
|
|
12
|
+
const none = Ed25519PrivateComponent.DeserializeComponent(oserial);
|
|
13
|
+
console.log(none);
|
|
14
|
+
}
|
|
15
|
+
//# sourceMappingURL=Components.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Components.js","sourceRoot":"","sources":["../../../../../modules/tide-js/Tests/Components.js"],"names":[],"mappings":"AAAA,OAAO,EAAE,uBAAuB,EAAE,sBAAsB,EAAE,MAAM,6DAA6D,CAAC;AAC9H,OAAO,EAAE,KAAK,EAAE,MAAM,wBAAwB,CAAC;AAE/C,MAAM,CAAC,KAAK,UAAU,4BAA4B;IAC9C,MAAM,KAAK,GAAG,IAAI,sBAAsB,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;IACrD,MAAM,MAAM,GAAG,KAAK,CAAC,SAAS,EAAE,CAAC,QAAQ,EAAE,CAAC;IAC5C,OAAO,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC;IAEpB,MAAM,IAAI,GAAG,sBAAsB,CAAC,oBAAoB,CAAC,MAAM,CAAC,CAAC;IACjE,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC,CAAA;IAEjB,MAAM,GAAG,GAAG,IAAI,uBAAuB,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC;IACnD,MAAM,OAAO,GAAG,GAAG,CAAC,SAAS,EAAE,CAAC,QAAQ,EAAE,CAAA;IAC1C,OAAO,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC;IAErB,MAAM,IAAI,GAAG,uBAAuB,CAAC,oBAAoB,CAAC,OAAO,CAAC,CAAC;IACnE,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;AACtB,CAAC"}
|
|
@@ -0,0 +1,164 @@
|
|
|
1
|
+
import { SimulatorFlow, Utils } from "../index.js";
|
|
2
|
+
import { CreateGPrismAuth, GenSessKey, GetPublic, RandomBigInt } from "../Cryptide/Math.js";
|
|
3
|
+
import { base64ToBase64Url, base64ToBytes, BigIntToByteArray, Bytes2Hex, bytesToBase64, GetUID, Hex2Bytes, StringFromUint8Array, StringToUint8Array } from "../Cryptide/Serialization.js";
|
|
4
|
+
import dKeyGenerationFlow from "../Flow/dKeyGenerationFlow.js";
|
|
5
|
+
import NetworkClient from "../Clients/NetworkClient.js";
|
|
6
|
+
import AuthRequest from "../Models/AuthRequest.js";
|
|
7
|
+
import { CurrentTime, Max } from "../Tools/Utils.js";
|
|
8
|
+
import BaseTideRequest from "../Models/BaseTideRequest.js";
|
|
9
|
+
import dVVKSigningFlow from "../Flow/SigningFlows/dVVKSigningFlow.js";
|
|
10
|
+
import { Ed25519PrivateComponent, Ed25519PublicComponent } from "../Cryptide/Components/Schemes/Ed25519/Ed25519Components.js";
|
|
11
|
+
import { CreateAuthorizerPackage, CreateVRKPackage } from "../Cryptide/TideMemoryObjects.js";
|
|
12
|
+
import { AuthorizedEncryptionFlow } from "../Flow/EncryptionFlows/AuthorizedEncryptionFlow.js";
|
|
13
|
+
import { Point } from "../Cryptide/Ed25519.js";
|
|
14
|
+
export async function Get_Auth_By_JWT() {
|
|
15
|
+
const simClient = new NetworkClient();
|
|
16
|
+
const availableOrks = (await simClient.FindReservers("bl2ah"));
|
|
17
|
+
const orks = (await SimulatorFlow.FilterInactiveOrks(availableOrks)).slice(0, Max);
|
|
18
|
+
const v = window.localStorage.getItem("t");
|
|
19
|
+
const vals = JSON.parse(v);
|
|
20
|
+
const vvkId = vals.id;
|
|
21
|
+
const gVVK = Point.fromBase64(vals.pub);
|
|
22
|
+
const vrk = BigInt(vals.vrk);
|
|
23
|
+
const vrk_sig = base64ToBytes(vals.vrk_sig);
|
|
24
|
+
const authorizer = Hex2Bytes(vals.authorizer);
|
|
25
|
+
// Generate signed usercontext
|
|
26
|
+
const userContext = StringToUint8Array(JSON.stringify({
|
|
27
|
+
"realm_access": {
|
|
28
|
+
"roles": [
|
|
29
|
+
"_tide_dob.selfdecrypt",
|
|
30
|
+
"_tide_dob.selfencrypt",
|
|
31
|
+
"_tide_name.selfdecrypt",
|
|
32
|
+
"_tide_name.selfencrypt",
|
|
33
|
+
"_tide_other.selfencrypt"
|
|
34
|
+
]
|
|
35
|
+
}
|
|
36
|
+
}));
|
|
37
|
+
const userContextDraft = Serialization.CreateTideMemory(new Uint8Array([0]), 4 + 1 + 4 + userContext.length);
|
|
38
|
+
Serialization.WriteValue(userContextDraft, 1, userContext);
|
|
39
|
+
const userContextRequest = new BaseTideRequest("UserContext", "1", "VRK:1", userContextDraft);
|
|
40
|
+
userContextRequest.addAuthorizer(authorizer);
|
|
41
|
+
userContextRequest.addAuthorizerCertificate(vrk_sig);
|
|
42
|
+
userContextRequest.addAuthorization(base64ToBytes(await EdDSA.sign(await userContextRequest.dataToAuthorize(), vrk)));
|
|
43
|
+
userContextRequest.addRules(new Uint8Array());
|
|
44
|
+
userContextRequest.addRulesCert(new Uint8Array());
|
|
45
|
+
const sessKey = GenSessKey();
|
|
46
|
+
const gSessKey = GetPublic(sessKey);
|
|
47
|
+
const userContextSignFlow = new dVVKSigningFlow(vvkId, gVVK, orks, sessKey, gSessKey, "http://localhost:3000/voucher/new");
|
|
48
|
+
const userContextSig = (await userContextSignFlow.start(userContextRequest))[0];
|
|
49
|
+
// Generate signed jwt
|
|
50
|
+
let requestsedJwt = "eyJhbGciOiJFZERTQSIsInR5cCIgOiAiSldUIiwia2lkIiA6ICJVbnNrdGp5dlNabnhlbTBpaEYwNTQ2NjlEdHdFMjV0dkJ2Y1lSZVBVNUo0In0." + base64ToBase64Url(bytesToBase64(StringToUint8Array(JSON.stringify({
|
|
51
|
+
"realm_access": {
|
|
52
|
+
"roles": [
|
|
53
|
+
"_tide_dob.selfdecrypt",
|
|
54
|
+
"_tide_dob.selfencrypt",
|
|
55
|
+
"_tide_name.selfdecrypt",
|
|
56
|
+
"_tide_name.selfencrypt",
|
|
57
|
+
"_tide_other.selfencrypt"
|
|
58
|
+
]
|
|
59
|
+
},
|
|
60
|
+
// below is so the orks don't reject the jwt
|
|
61
|
+
"exp": CurrentTime() + 10000,
|
|
62
|
+
"sid": "testtttt",
|
|
63
|
+
"iat": CurrentTime()
|
|
64
|
+
}))));
|
|
65
|
+
const requestsedJwt_b = StringToUint8Array(requestsedJwt);
|
|
66
|
+
const jwtRequestDraft = Serialization.CreateTideMemory(userContext, 4 + userContext.length + 4 + userContextSig.length + 4 + requestsedJwt_b.length);
|
|
67
|
+
Serialization.WriteValue(jwtRequestDraft, 1, userContextSig);
|
|
68
|
+
Serialization.WriteValue(jwtRequestDraft, 2, requestsedJwt_b);
|
|
69
|
+
const jwtRequest = new BaseTideRequest("AccessToken", "1", "VRK:1", jwtRequestDraft, Serialization.CreateTideMemory(new Uint8Array(), 4)); // set dynamic data to 0 indicating no previous token auth
|
|
70
|
+
jwtRequest.addAuthorizer(authorizer);
|
|
71
|
+
jwtRequest.addAuthorizerCertificate(vrk_sig);
|
|
72
|
+
jwtRequest.addAuthorization(base64ToBytes(await EdDSA.sign(await jwtRequest.dataToAuthorize(), vrk)));
|
|
73
|
+
const jwtSigningFlow = new dVVKSigningFlow(vvkId, gVVK, orks, sessKey, gSessKey, "http://localhost:3000/voucher/new");
|
|
74
|
+
requestsedJwt = requestsedJwt + "." + base64ToBase64Url(bytesToBase64((await jwtSigningFlow.start(jwtRequest))[0]));
|
|
75
|
+
// store here for encrypt/decrypt
|
|
76
|
+
window.localStorage.setItem("e", JSON.stringify({
|
|
77
|
+
id: vvkId,
|
|
78
|
+
token: requestsedJwt
|
|
79
|
+
}));
|
|
80
|
+
console.log('SUCCESS. Feel free to test encryption and decryption');
|
|
81
|
+
}
|
|
82
|
+
export async function Encrypt() {
|
|
83
|
+
const e = JSON.parse(window.localStorage.getItem("e"));
|
|
84
|
+
const vvkId = e.id;
|
|
85
|
+
const token = e.token;
|
|
86
|
+
// Test encryption
|
|
87
|
+
console.time('Execution Time');
|
|
88
|
+
const encryptionFlow = new AuthorizedEncryptionFlow({
|
|
89
|
+
vendorId: vvkId,
|
|
90
|
+
token: token,
|
|
91
|
+
voucherURL: "http://localhost:3000/voucher/new"
|
|
92
|
+
});
|
|
93
|
+
const encrypted = await encryptionFlow.encrypt([
|
|
94
|
+
{
|
|
95
|
+
"data": StringToUint8Array("0"),
|
|
96
|
+
"tags": ["dob", "other"]
|
|
97
|
+
},
|
|
98
|
+
{
|
|
99
|
+
"data": StringToUint8Array("00000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000"),
|
|
100
|
+
"tags": ["dob"]
|
|
101
|
+
},
|
|
102
|
+
{
|
|
103
|
+
"data": StringToUint8Array("0"),
|
|
104
|
+
"tags": ["dob", "name"]
|
|
105
|
+
},
|
|
106
|
+
{
|
|
107
|
+
"data": StringToUint8Array("0"),
|
|
108
|
+
"tags": ["name"]
|
|
109
|
+
}
|
|
110
|
+
]);
|
|
111
|
+
console.timeEnd('Execution Time');
|
|
112
|
+
console.log(encrypted);
|
|
113
|
+
console.log("Encrypt TEST SUCCESSFUL");
|
|
114
|
+
}
|
|
115
|
+
export async function Decrypt() {
|
|
116
|
+
const e = JSON.parse(window.localStorage.getItem("e"));
|
|
117
|
+
const vvkId = e.id;
|
|
118
|
+
const token = e.token;
|
|
119
|
+
// encrypt first
|
|
120
|
+
const encryptionFlow = new AuthorizedEncryptionFlow({
|
|
121
|
+
vendorId: vvkId,
|
|
122
|
+
token: token,
|
|
123
|
+
voucherURL: "http://localhost:3000/voucher/new"
|
|
124
|
+
});
|
|
125
|
+
const encrypted = await encryptionFlow.encrypt([
|
|
126
|
+
{
|
|
127
|
+
"data": StringToUint8Array("a"),
|
|
128
|
+
"tags": ["dob"]
|
|
129
|
+
},
|
|
130
|
+
{
|
|
131
|
+
"data": StringToUint8Array("00000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000"),
|
|
132
|
+
"tags": ["dob"]
|
|
133
|
+
},
|
|
134
|
+
{
|
|
135
|
+
"data": StringToUint8Array("ab"),
|
|
136
|
+
"tags": ["dob", "name"]
|
|
137
|
+
},
|
|
138
|
+
{
|
|
139
|
+
"data": StringToUint8Array("abc"),
|
|
140
|
+
"tags": ["name"]
|
|
141
|
+
}
|
|
142
|
+
]);
|
|
143
|
+
// now decrypt
|
|
144
|
+
console.time('Execution Time');
|
|
145
|
+
const decrpytionFlow = new AuthorizedEncryptionFlow({
|
|
146
|
+
vendorId: vvkId,
|
|
147
|
+
token: token,
|
|
148
|
+
voucherURL: "http://localhost:3000/voucher/new"
|
|
149
|
+
});
|
|
150
|
+
const decrypted = await decrpytionFlow.decrypt([
|
|
151
|
+
{
|
|
152
|
+
"encrypted": encrypted[1],
|
|
153
|
+
"tags": ["dob"]
|
|
154
|
+
},
|
|
155
|
+
{
|
|
156
|
+
"encrypted": encrypted[3],
|
|
157
|
+
"tags": ["name"]
|
|
158
|
+
}
|
|
159
|
+
]);
|
|
160
|
+
console.timeEnd('Execution Time');
|
|
161
|
+
console.log(decrypted.map(d => StringFromUint8Array(d)));
|
|
162
|
+
console.log("Decryption SUCCESSFUL");
|
|
163
|
+
}
|
|
164
|
+
//# sourceMappingURL=Encryption.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Encryption.js","sourceRoot":"","sources":["../../../../../modules/tide-js/Tests/Encryption.js"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,106 @@
|
|
|
1
|
+
import OrkInfo from "../Models/Infos/OrkInfo.js";
|
|
2
|
+
import HashToPoint from "../Cryptide/Hashing/H2P.js";
|
|
3
|
+
import { Serialization } from "../Cryptide/index.js";
|
|
4
|
+
import { HMAC_forHashing } from "../Cryptide/Hashing/Hash.js";
|
|
5
|
+
import dCMKPasswordFlow from "../Flow/AuthenticationFlows/dCMKPasswordFlow.js";
|
|
6
|
+
import dCMKPasswordlessFlow from "../Flow/AuthenticationFlows/dCMKPasswordlessFlow.js";
|
|
7
|
+
import dKeyGenerationFlow from "../Flow/dKeyGenerationFlow.js";
|
|
8
|
+
import { Math } from "../Cryptide/index.js";
|
|
9
|
+
import { CreateGPrismAuth, GetPublic } from "../Cryptide/Math.js";
|
|
10
|
+
import EnclaveEntry from "../Models/EnclaveEntry.js";
|
|
11
|
+
import KeyInfo from "../Models/Infos/KeyInfo.js";
|
|
12
|
+
import NetworkClient from "../Clients/NetworkClient.js";
|
|
13
|
+
import { Max } from "../Tools/Utils.js";
|
|
14
|
+
export async function CMKAuth_Basic() {
|
|
15
|
+
// basic username, password test flow
|
|
16
|
+
var orks;
|
|
17
|
+
let i = 0;
|
|
18
|
+
while (i < 1) {
|
|
19
|
+
const user = Date.now().toString();
|
|
20
|
+
const persona = "1";
|
|
21
|
+
const emails = ["testEmail1@doge.com"];
|
|
22
|
+
const password = "pass";
|
|
23
|
+
const gPass = await HashToPoint(password);
|
|
24
|
+
const uid = await Serialization.GetUID(user);
|
|
25
|
+
const sessKey = Math.GenSessKey();
|
|
26
|
+
const gSessKey = Math.GetPublic(sessKey);
|
|
27
|
+
const sessID = "123ID";
|
|
28
|
+
const VRK = BigInt(123456789);
|
|
29
|
+
const gVRK = GetPublic(VRK);
|
|
30
|
+
let GK;
|
|
31
|
+
const create = async () => {
|
|
32
|
+
// create account first
|
|
33
|
+
const purpose = "NEW";
|
|
34
|
+
const { reservationConfirmation, activeOrks } = (await dKeyGenerationFlow.ReserveUID(uid, "http://localhost:3000/voucher/new", gSessKey));
|
|
35
|
+
orks = activeOrks.slice(0, Max);
|
|
36
|
+
const genFlow = new dKeyGenerationFlow(uid, gVRK.toBase64(), orks, sessKey, gSessKey, purpose, "http://host.docker.internal:3000/voucher/new", emails);
|
|
37
|
+
const { gMultiplied, gK } = await genFlow.GenShard(2, [null, gPass], reservationConfirmation); // auths can be null if purpose is "new", for now...
|
|
38
|
+
GK = gK;
|
|
39
|
+
const gPrismAuth = await CreateGPrismAuth(gMultiplied[1]);
|
|
40
|
+
await genFlow.SetShard(gPrismAuth.toBase64(), "CMK");
|
|
41
|
+
await genFlow.Commit();
|
|
42
|
+
};
|
|
43
|
+
const authenticate = async () => {
|
|
44
|
+
const keyInfo = await new NetworkClient("http://host.docker.internal:1001").GetKeyInfo(uid);
|
|
45
|
+
const dAuthFlow = new dCMKPasswordFlow(keyInfo, sessID, true, true, "http://host.docker.internal:3000/voucher/new");
|
|
46
|
+
await dAuthFlow.Convert(sessKey, gSessKey, gPass, GK, true);
|
|
47
|
+
await dAuthFlow.Authenticate(gSessKey); // gVRK can be anything for testing
|
|
48
|
+
};
|
|
49
|
+
await create();
|
|
50
|
+
await authenticate();
|
|
51
|
+
console.log("CMKAuth_Basic TEST SUCCESSFUL: " + i);
|
|
52
|
+
i++;
|
|
53
|
+
}
|
|
54
|
+
}
|
|
55
|
+
export async function CMKAuth_Remembered() {
|
|
56
|
+
// authentication flow, provided valid EnclaveEntry (no password required)
|
|
57
|
+
var orks;
|
|
58
|
+
let i = 0;
|
|
59
|
+
while (i < 1) {
|
|
60
|
+
const user = Date.now().toString();
|
|
61
|
+
const persona = "1";
|
|
62
|
+
const emails = ["testEmail1@doge.com"];
|
|
63
|
+
const password = "pass";
|
|
64
|
+
const gPass = await HashToPoint(password);
|
|
65
|
+
const uid = await Serialization.GetUID(user);
|
|
66
|
+
const sessKey = Math.GenSessKey();
|
|
67
|
+
const gSessKey = Math.GetPublic(sessKey);
|
|
68
|
+
const sessID = "123ID";
|
|
69
|
+
const VRK = BigInt(123456789);
|
|
70
|
+
const gVRK = GetPublic(VRK);
|
|
71
|
+
let GK;
|
|
72
|
+
let keyM;
|
|
73
|
+
const create = async () => {
|
|
74
|
+
// create account first
|
|
75
|
+
const purpose = "NEW";
|
|
76
|
+
const { reservationConfirmation, activeOrks } = (await dKeyGenerationFlow.ReserveUID(uid, "http://localhost:3000/voucher/new", gSessKey));
|
|
77
|
+
orks = activeOrks.slice(0, Max);
|
|
78
|
+
const genFlow = new dKeyGenerationFlow(uid, gVRK.toBase64(), orks, sessKey, gSessKey, purpose, "http://localhost:3000/voucher/new", emails);
|
|
79
|
+
const { gMultiplied, gK } = await genFlow.GenShard(2, [null, gPass], reservationConfirmation); // auths can be null if purpose is "new", for now...
|
|
80
|
+
GK = gK;
|
|
81
|
+
const gPrismAuth = await CreateGPrismAuth(gMultiplied[1]);
|
|
82
|
+
await genFlow.SetShard(gPrismAuth.toBase64(), "CMK");
|
|
83
|
+
await genFlow.Commit();
|
|
84
|
+
};
|
|
85
|
+
const authenticate = async () => {
|
|
86
|
+
const keyInfo = await new NetworkClient("http://localhost:1001").GetKeyInfo(uid);
|
|
87
|
+
const dAuthFlow = new dCMKPasswordFlow(keyInfo, sessID, true, true, "http://localhost:3000/voucher/new");
|
|
88
|
+
await dAuthFlow.Convert(sessKey, gSessKey, gPass, GK, true);
|
|
89
|
+
const { bitwise, expired, selfRequesti } = await dAuthFlow.Authenticate(gSessKey); // gVRK can be anything for testing
|
|
90
|
+
const userInfo = new KeyInfo(uid, GK, keyInfo.UserM, orks);
|
|
91
|
+
const auth = new EnclaveEntry(user, "1", BigInt(expired), userInfo, bitwise, selfRequesti, sessKey);
|
|
92
|
+
return auth;
|
|
93
|
+
};
|
|
94
|
+
const authenticateNoPassword = async (auth) => {
|
|
95
|
+
const noPassFlow = new dCMKPasswordlessFlow(sessID, auth, "http://localhost:3000/voucher/new");
|
|
96
|
+
await noPassFlow.ConvertRemembered();
|
|
97
|
+
await noPassFlow.AuthenticateRemembered(gSessKey);
|
|
98
|
+
};
|
|
99
|
+
await create();
|
|
100
|
+
const auth = await authenticate();
|
|
101
|
+
await authenticateNoPassword(auth);
|
|
102
|
+
console.log("CMKAuth_Remembered TEST SUCCESSFUL: " + i);
|
|
103
|
+
i++;
|
|
104
|
+
}
|
|
105
|
+
}
|
|
106
|
+
//# sourceMappingURL=KeyAuthentication.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"KeyAuthentication.js","sourceRoot":"","sources":["../../../../../modules/tide-js/Tests/KeyAuthentication.js"],"names":[],"mappings":"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"}
|