QuickCrypto class

QuickCrypto provides a set of utility methods for cryptographic operations.

This class contains static methods for generating random bytes, hashing data, and performing other cryptographic operations commonly used in various applications.

Constructors

QuickCrypto()

Properties

hashCode int
The hash code for this object.
no setterinherited
runtimeType Type
A representation of the runtime type of the object.
no setterinherited

Methods

noSuchMethod(Invocation invocation) → dynamic
Invoked when a nonexistent method or property is accessed.
inherited
toString() String
A string representation of this object.
inherited

Operators

operator ==(Object other) bool
The equality operator.
inherited

Static Properties

blake2b160DigestSize int
Define the size of BLAKE2b-160 digests, which is 20 bytes (160 bits)
getter/setter pair
blake2b224DigestSize int
Define the size of BLAKE2b-224 digests, which is 28 bytes (224 bits)
getter/setter pair
blake2b256DigestSize int
Define the size of BLAKE2b-256 digests, which is 32 bytes (256 bits)
getter/setter pair
blake2b32DigestSize int
Define the size of BLAKE2b-32 digests, which is 4 bytes (32 bits)
getter/setter pair
blake2b40DigestSize int
Define the size of BLAKE2b-40 digests, which is 5 bytes (40 bits)
getter/setter pair
blake2b512DigestSize int
Define the size of BLAKE2b-512 digests, which is 64 bytes (512 bits)
getter/setter pair
sha256DigestSize int
Static property that defines the size of SHA-256 digests in bytes
no setter
sha3256DigestSize int
Define the size of SHA-3-256 digests, which is 32 bytes (256 bits)
no setter
sha512DeigestLength int
Gets the length of the SHA512 digest.
getter/setter pair

Static Methods

aesCbcDecrypt(List<int> key, List<int> data, {PaddingAlgorithm? paddingAlgorithm}) List<int>
Decrypt the input data using AES in Cipher Block Chaining (CBC) mode with the provided key. Optionally, specify the padding algorithm to be used.
aesCbcEncrypt(List<int> key, List<int> data, {PaddingAlgorithm? paddingAlgorithm}) List<int>
Encrypt the input data using AES in Cipher Block Chaining (CBC) mode with the provided key. Optionally, specify the padding algorithm to be used.
blake2b160Hash(List<int> data, {List<int>? key, List<int>? salt}) List<int>
Calculate the BLAKE2b-160 hash of the input data
blake2b224Hash(List<int> data, {List<int>? key, List<int>? salt}) List<int>
Calculate the BLAKE2b-224 hash of the input data
blake2b256Hash(List<int> data, {List<int>? key, List<int>? salt}) List<int>
Calculate the BLAKE2b-256 hash of the input data
blake2b32Hash(List<int> data, {List<int>? key, List<int>? salt}) List<int>
Calculate the BLAKE2b-32 hash of the input data
blake2b40Hash(List<int> data, {List<int>? key, List<int>? salt}) List<int>
Calculate the BLAKE2b-40 hash of the input data
blake2b512Hash(List<int> data, {List<int>? key, List<int>? salt}) List<int>
Calculate the BLAKE2b-512 hash of the input data
chaCha20Poly1305Decrypt({required List<int> key, required List<int> nonce, required List<int> cipherText, List<int>? assocData}) List<int>
Decrypt data using the ChaCha20-Poly1305 authenticated encryption algorithm. Requires a key, nonce, ciphertext, and optional associated data.
chaCha20Poly1305Encrypt({required List<int> key, required List<int> nonce, required List<int> plainText, List<int>? assocData}) List<int>
Encrypt data using the ChaCha20-Poly1305 authenticated encryption algorithm. Requires a key, nonce, plaintext, and optional associated data.
generateRandom([int size = 32, GenerateRandom? random]) List<int>
This function generates a random List
hash160(List<int> data) List<int>
Calculate the RIPEMD-160 hash of the SHA-256 hash of the input data
hmacsha256Hash(List<int> key, List<int> data) List<int>
Calculate the HMAC-SHA-256 hash of the input data using the provided key
hmacSha512Hash(List<int> key, List<int> data) List<int>
Calculate the HMAC-SHA-512 hash of the input data using the provided key
hmacSha512HashHalves(List<int> key, List<int> data) Tuple<List<int>, List<int>>
Calculate the HMAC-SHA-512 hash of the input data using the provided key and split the result into two halves. Return a tuple containing both halves
keccack256Hash(List<int> data) List<int>
Calculate the Keccak-256 hash of the input data
pbkdf2DeriveKey({required List<int> password, required List<int> salt, required int iterations, Hash hash()?, int? dklen}) List<int>
Derive a key from a password using PBKDF2 algorithm
ripemd160Hash(List<int> data) List<int>
Calculate the RIPEMD-160 hash of the input data
sha256DoubleHash(List<int> data) List<int>
Calculate the SHA-256 hash of the SHA-256 hash of the input data
sha256Hash(List<int> data) List<int>
Calculate the SHA-256 hash of the input data
sha3256Hash(List<int> data) List<int>
Calculate the SHA-3-256 hash of the input data
sha512256Hash(List<int> data) List<int>
Calculate the SHA-512/256 hash of the input data
sha512Hash(List<int> data) List<int>
Calculate the SHA-512 hash of the input data
sha512HashHalves(List<int> data) Tuple<List<int>, List<int>>
Computes the SHA512 hash of the input data and returns its halves.

Constants

chacha20Polu1305Keysize → const int
Define the key size for ChaCha20-Poly1305, which is 32 bytes
chacha20Polu1305Taglenght → const int
Define the tag length for ChaCha20-Poly1305, which is 16 bytes
hash160DigestSize → const int
Define the size of RIPEMD-160 digests, which is 20 bytes (160 bits)
hmacSha512DigestSize → const int
Define the size of HMAC-SHA-512 digests, which is 64 bytes (512 bits)