Crypto
Provides a comprehensive interface for cryptographic operations. This class serves as a central point for accessing various cryptographic functionalities including algorithm retrieval, key generation, and cipher operations.
Constructors
new Crypto()
new Crypto():
Crypto
Create a new instance of the Crypto class.
Initializes a new Crypto object. This constructor doesn't take any parameters as it sets up the internal state needed to perform cryptographic operations. Each instance provides access to the full range of cryptographic functionalities.
Returns
Methods
getAsymmetricAlgorithmByName()
getAsymmetricAlgorithmByName(
name
):AsymmetricAlgorithm
Get an asymmetric algorithm by name.
This function retrieves an asymmetric algorithm by its name.
Parameters
name
string
The name of the asymmetric algorithm.
Returns
The requested asymmetric algorithm.
Throws
InvalidArgumentError If the algorithm name is invalid.
getDigestAlgorithmByName()
getDigestAlgorithmByName(
name
):DigestAlgorithm
Get a digest algorithm by name.
This function retrieves a digest algorithm based on its name. If the algorithm with the given name is supported, it returns the requested algorithm.
Parameters
name
string
The name of the algorithm.
Returns
The requested digest algorithm.
Throws
InvalidArgumentError If the algorithm name is invalid.
getEccCurveByName()
getEccCurveByName(
name
):EccCurve
Get an elliptic-curve cryptography (ECC) curve by name.
This function retrieves an elliptic-curve cryptography curve by its name.
Parameters
name
string
The name of the ECC curve.
Returns
The requested ECC curve.
Throws
InvalidArgumentError If the curve name is invalid.
getRandom()
getRandom(
length
):Promise
<number
[]>
Generate random data.
Parameters
length
number
The length in bytes of the random data to generate.
Returns
Promise
<number
[]>
A promise resolving to an array of random bytes.
Throws
InvalidArgumentError If the length is invalid.
Throws
SecurityError If the random data generation fails.
getSupportedAsymmetricCipherAlgorithms()
getSupportedAsymmetricCipherAlgorithms():
AsymmetricAlgorithm
[]
Get supported asymmetric cipher algorithms.
This function retrieves a list of all the supported asymmetric cipher algorithms.
Returns
An array of the supported asymmetric cipher algorithms.
getSupportedDigestAlgorithms()
getSupportedDigestAlgorithms():
DigestAlgorithm
[]
List all the supported digest algorithms.
This function returns an array of the supported digest algorithms. Users can iterate over this array to obtain information about each supported digest algorithm.
Returns
An array of the supported digest algorithms.
getSupportedEccCurves()
getSupportedEccCurves():
EccCurve
[]
List the supported elliptic-curve cryptography (ECC) curves.
This function returns an array of all the supported elliptic-curve cryptography curves.
Returns
EccCurve
[]
An array of the supported ECC curves.
getSupportedSignatureAlgorithms()
getSupportedSignatureAlgorithms():
AsymmetricAlgorithm
[]
List the supported signature algorithms.
This function returns an array of all the supported signature algorithms.
Returns
An array of the supported signature algorithms.
getSupportedSymmetricAlgorithms()
getSupportedSymmetricAlgorithms():
SymmetricAlgorithm
[]
List all the supported symmetric algorithms.
This function provides a list of all the symmetric algorithms that are available in the system. The caller can use this list to determine which symmetric algorithms are supported.
Returns
An array of the supported symmetric algorithms.
getSymmetricAlgorithmByName()
getSymmetricAlgorithmByName(
name
):SymmetricAlgorithm
Get a symmetric algorithm by name.
This function retrieves a symmetric algorithm based on its name. The name parameter specifies the name of the algorithm to retrieve.
Parameters
name
string
The name of the symmetric algorithm to retrieve.
Returns
The requested symmetric algorithm.
Throws
InvalidArgumentError If the algorithm name is invalid.
getWrappingSchemeByName()
getWrappingSchemeByName(
name
):WrappingScheme
Get a wrapping scheme by name.
This function retrieves a wrapping scheme by its name.
Parameters
name
string
The name of the wrapping scheme.
Returns
The requested wrapping scheme.
Throws
InvalidArgumentError If the scheme name is invalid.
makeAsymmetricCipherContextBuilder()
makeAsymmetricCipherContextBuilder(
algorithm
):AsymmetricCipherContextBuilder
Create a builder for asymmetric cipher contexts.
This function creates an object that can be used to build cipher contexts using asymmetric cryptography.
Parameters
algorithm
The asymmetric algorithm to be used.
Returns
AsymmetricCipherContextBuilder
A new builder for asymmetric cipher contexts.
Throws
InvalidArgumentError If the given algorithm is not supported.
makeAsymmetricKeyBuilder()
makeAsymmetricKeyBuilder():
AsymmetricKeyBuilder
Create a builder for asymmetric keys.
This function creates an object that can be used to build asymmetric keys.
Returns
A new asymmetric key builder object.
makeCbcCipherContextBuilder()
makeCbcCipherContextBuilder(
algorithm
):CbcContextBuilder
Create a builder for cipher contexts in CBC mode.
This function creates an object that can be used to build a cipher context in CBC mode.
Parameters
algorithm
The symmetric algorithm to use.
Returns
A new CBC cipher context builder.
Throws
InvalidArgumentError If the algorithm is invalid.
makeCtrCipherContextBuilder()
makeCtrCipherContextBuilder(
algorithm
):CtrContextBuilder
Create a builder for a cipher context in CTR (Counter) mode.
This function creates an object that can be used to build a cipher context in CTR mode.
Parameters
algorithm
The symmetric algorithm to use.
Returns
A new CTR cipher context builder.
Throws
InvalidArgumentError If the algorithm is invalid.
makeDiffieHellmanKeyBuilder()
makeDiffieHellmanKeyBuilder():
DiffieHellmanKeyBuilder
Create a builder for Diffie-Hellman keys.
This function creates an object that can be used to build Diffie-Hellman keys.
Returns
A new Diffie-Hellman key builder object.
makeDigestContextBuilder()
makeDigestContextBuilder():
DigestContextBuilder
Create a builder for digest (hash) contexts.
This function creates an object that can be used to build digest contexts
Returns
A new builder for digest contexts.
makeEccKeyBuilder()
makeEccKeyBuilder():
EccKeyBuilder
Create a builder for elliptic-curve cryptography (ECC) keys.
This function creates an object that can be used to build ECC keys.
Returns
A new ECC key builder object.
makeEcdhContextBuilder()
makeEcdhContextBuilder():
EcdhContextBuilder
Create a builder for ECDH key exchange contexts.
This function creates an object that can be used to build ECDH key exchange contexts.
Returns
A new builder for ECDH key exchange contexts.
makeGcmCipherContextBuilder()
makeGcmCipherContextBuilder(
algorithm
):GcmContextBuilder
Create a builder for cipher contexts in GCM mode.
This function creates an object that can be used to build a cipher context in GCM mode.
Parameters
algorithm
The symmetric algorithm to use.
Returns
A new GCM cipher context builder.
Throws
InvalidArgumentError If the algorithm is invalid.
makeHkdfContextBuilder()
makeHkdfContextBuilder():
HkdfContextBuilder
Create a builder for HKDF key derivation contexts.
This function creates an object that can be used to build HKDF key derivation contexts.
Returns
A new builder for HKDF key derivation contexts.
makeHmacContextBuilder()
makeHmacContextBuilder():
HmacContextBuilder
Create a builder for HMAC (Hash-based Message Authentication Code) contexts.
This function creates an object that can be used to build HMAC contexts.
Returns
A new builder for HMAC contexts.
makePbkdf2ContextBuilder()
makePbkdf2ContextBuilder():
Pbkdf2ContextBuilder
Create a builder for PBKDF2 key derivation contexts.
This function creates an object that can be used to build PBKDF2 key derivation contexts.
Returns
A new builder for PBKDF2 key derivation contexts.
makeRsaKeyBuilder()
makeRsaKeyBuilder():
RsaKeyBuilder
Create a builder for RSA keys.
This function creates an object that can be used to build RSA keys.
Returns
A new RSA key builder object.
makeRsaOaepCipherContextBuilder()
makeRsaOaepCipherContextBuilder(
digestAlgorithm
):RsaOaepContextBuilder
Create a builder for RSA-OAEP cipher contexts.
This function creates an object that can be used to build RSA-OAEP cipher contexts for asymmetric cryptography.
Parameters
digestAlgorithm
The digest algorithm to be used.
Returns
A new builder for RSA-OAEP cipher contexts.
Throws
InvalidArgumentError If the digest algorithm is invalid.
makeRsaOaepKeyBuilder()
makeRsaOaepKeyBuilder():
RsaOaepKeyBuilder
Creates a builder for RSA-OAEP keys.
This function creates an object that can be used to build RSA-OAEP keys.
Returns
A new RSA-OAEP key builder object.
makeRsassaPkcs1ContextBuilder()
makeRsassaPkcs1ContextBuilder():
RsassaPkcs1ContextBuilder
Create a builder for an RSASSA-PKCS1-v1_5 signature context.
This function creates an object that can be used to build an RSASSA-PKCS1-v1_5 signature context.
Returns
A new builder for RSASSA-PKCS1-v1_5 signature contexts.
makeRsassaPssContextBuilder()
makeRsassaPssContextBuilder():
RsassaPssContextBuilder
Create a builder for an RSASSA-PSS signature context.
This function creates an object that can be used to build an RSASSA-PSS signature context.
Returns
A new builder for RSASSA-PSS signature contexts.
makeSignatureContextBuilder()
makeSignatureContextBuilder():
SignatureContextBuilder
Create a builder for a signature context.
This function creates an object that can be used to build a signature context.
Returns
A new signature context builder.
makeSymmetricKeyBuilder()
makeSymmetricKeyBuilder():
SymmetricKeyBuilder
Create a builder for symmetric keys.
This function creates an object that can be used to build symmetric keys.
Returns
A new symmetric key builder object.
getMajorVersion()
static
getMajorVersion():number
Retrieve the major version of the KeplerCrypto Turbo Module.
Returns
number
The major version number.
getMinorVersion()
static
getMinorVersion():number
Retrieve the minor version of the KeplerCrypto Turbo Module.
Returns
number
The minor version number.
getPatchVersion()
static
getPatchVersion():number
Retrieve the patch version of the KeplerCrypto Turbo Module.
Returns
number
The patch version number.
Last updated: Sep 30, 2025