- Support for MD2:
md2
,md2sum
- Moves random generators outside of the base package;
import 'package:hashlib/random.dart';
- Introduces UUID generators. Example:
uuid.v4()
- Ensure seed uniqueness in
RandomGenerators
across Isolates
- Exports hashlib_codecs from current package;
import 'package:hashlib/codecs.dart';
- Modifies
Poly1305
interface:poly1305
is now available as the builder.
- Modifies
MACHash
andMACHashBase
interfaces for better accessibility.
- Fixes issue in
shake128generator
andshake256generator
: wrong bytes sequence after 168th and 136th. - Fixes
number
for 64-bit integer output inHashDigest
- Fixes
oct
for octal string outupt inHashDigest
- Bump version for
hashlib_codecs
- [Breaking Changes]:
- Refactors
HashBase
andMACHashBase
- Renames
argon2verify
->argon2Verify
- Renames
poly1305
->poly1305auth
, and removespoly1305pair
- Removes for
tuneArgon2Security
. It has been moved to examples folder. - Interfaces for
hmac
,pbkdf2
,Blake2bMAC
andBLAKE2sMAC
- Duration for period in
TOTP
.
- Refactors
- Expose infinite generator methods for SHAKE
shake128generator
shake256generator
- Generalize the random seed list generation to support web
- Expose methods to get padded string value from TOTP:
valueString
streamString
- Improve support for random generator
HashlibRandom
class for generating random number, bool, strings etc.- Refactor
KeccakRandom
to be available asHashlibRandom.keccak
- [Breaking Changes]:
- Remove all deprecated string extension
- Remove
consume
, usebind
instead. consumeAs
is renamed tostringStraem
.- Introduced
byteStream
- Adds
fillNumbers
to fill List with random integers. - Use secure random generator by default
- Fix import issue for web platform.
- Implement BCrypt algorithm.
- New class:
Bcrypt
- New methods:
bcrypt
,bcryptSalt
,bcryptVerify
,bcryptDigest
- New class:
- Convert all asUint...List to Uint...List.view
- Refactor:
Argon2.fromEncoded
will now acceptCryptData
only. - New method:
Argon2Context.fromEncoded
acceptingCryptData
.
- Update Argon2 interface:
- Paramters
salt
andhashLength
are now optional. - If absent,
salt
is generated using default random generator. - Default hash length is now 32 instead of 24.
- Extracts method
Argon2Security.optimize
->tuneArgon2Security
- Paramters
- Put deprecation message on string extensions
- Update benchmarks
- Implement SM3 algorithm.
- New constant:
sm3
- New method:
sm3sum
- New constant:
- Expose
currentTime
inTOTP
- Implement MD4 algorithm.
- New constant:
md4
- New method:
md4sum
- New constant:
- Accept random number generator input in the following method parameters:
randomBytes
fillRandom
- Adds new method to generate 32-bit random numbers:
randomNumbers
- Adds
KeccakRandom
as proof of concept random number generator.
- Expose
Poly1305Sink
to public.
- Breaking changes on public methods:
- renames
poly1305
->poly1305pair
- renames
poly1305auth
->poly1305
- accepts 16 bytes key for
poly1305
- renames
- Refactor
Poly1305
class structure. Breaking changes:- renames
Poly1305.auth
->Poly1305.pair
- removes getter
secret
(key
contains both keypair).
- renames
- Refactor benchmark calculation.
- Optimize
HMAC
runtime. - Refactor
Argon2
class structure. Breaking changes:- renames variable:
lanes
toparallelism
- renames variable:
passes
toiterations
- renames variable:
- Bump version of the hashlib_codecs
- Breaking: The
HashDigest.base32
andHashDigest.base64
will have padding by default. - Bump version of the hashlib_codecs
- Move codecs to separate package: hashlib_codecs
- Support BigInt conversion in
HashDigest
- Renames
remainder
->number
- Adds
bigInt
method to getBigInt
from bytes
- Renames
- Throws
FormatException
for invalid characters in codecs - Adds
base2
codes. New methods:fromBinary
toBinary
- Export codecs
- Update documentation
- Truncate seed to 32-bit integer for xxh32
- Export a few additional clases
BlockHashBase
BlockHashSink
HashBase
HashDigestSink
HashDigest
Argon2HashDigest
BlockHashRegistry
HashRegistry
Uint8Codec
- Optimize Poly1305 implementation (30x improvement in hashrate)
- Optimize scrypt implementation (10x improvement in runtime)
- RIPEMD algorithm series. New hash functions:
ripemd128
,ripemd128sum
ripemd160
,ripemd160sum
ripemd256
,ripemd256sum
ripemd320
,ripemd320sum
- Codecs are now able to handle padding characters
- Adds support for
Poly1305
MAC generation: #5- New class:
Poly1305
- New methods:
poly1305
,poly1305auth
- New class:
- Adds support for OTP generation:
- Name all hash algorithms and a registry to loopup algorithms by name.
BlockHashRegistry
- for block hash algorithmsHashRegistry
- for all hash algorithms
- Adds random byte generator:
randomBytes
method returns aList<int>
fillRandom
method fills aByteBuffer
with random values
- New default instances for
Shake128
:shake128_128
shake128_160
shake128_224
shake128_256
shake128_384
shake128_512
- New default instances for
Shake256
:shake256_128
shake256_160
shake256_224
shake256_256
shake256_384
shake256_512
- Adds two new methods to
MACHashBase
:sign
: generates a tag from a messageverify
: verifies if a message and tag matches
- Updates
HashDigest
- Adds
isEqual
to match it with otherHashDigest
,String
,TypedData
,ByteBuffer
,List<int>
,Iterable<int>
- Use custom equality check
- Adds
- Extracts few methods from utils and create codecs:
- Available:
ASCIICodec
B16Codec
B32Codec
B64Codec
B64URLCodec
- New or transferred methods:
toAscii
fromAscii
toHex
fromHex
toBase32
fromBase32
toBase64
fromBase64
toBase64Url
fromBase64Url
- New constants:
ascii
base16
base16lower
base32
base32lower
base64
base64url
- Available:
- New example:
otpauth_parser.dart
. It can decode migration string from Google Authenticator and parse any valid otpauth string. - Updates benchmarks
- Adds SCRYPT:
- New class:
Scrypt
- New method:
scrypt
- New class:
- Changes in
PBKDF2
and extensions:- parameter type of
keyLength
- use default iterations = 1000
- adds validation in the constructor
- adds global
pbkdf2
function
- parameter type of
- Improves
dart run
using@pragma('vm:prefer-inline')
- Adds new methods:
crc64sum
xxh64sum
xxh3sum
xxh128sum
- Removes methods:
xxh128code
- Adds xxHash64
- New class:
XXHash64
- New constants:
xxh64
,xxh64code
- String extension:
xxh64code
- New class:
- Adds xxHash32
- New class:
XXHash32
- New constants:
xxh32
,xxh32code
- String extension:
xxh32code
- New class:
- Adds XXH3-64
- New class:
XXH3
- New constants:
xxh3
,xxh3code
- String extension:
xxh3code
- New class:
- Adds XXH3-128
- New class:
XXH128
- New constants:
xxh128
,xxh128code
- String extension:
xxh128code
- New class:
- Internal changes:
- Removes the parameters from
$finalize
method inBlockHash
- Uses
>>>
instead of>>
- Removes the parameters from
- Uses Hash Rate instead of Runtime for benchmarks
- Renames
Argon2Security.small
->Argon2Security.little
- Adds
Argon2Security.optimize
method to find optimal parameters for a desired runtime. - Define
KeyDerivator
and extend it forArgon2
- Modify internal structure of
Argon2
to make it faster. - Implement
reset
functionality for all hash sinks. - Define and use
BlockHashBase
for some algorithms. - Renames
BlockHash
->BlockHashSink
- Replaces the RFC links to ietf domain.
- Adds
PBKDF2
key derivator. - Adds extension to
HMAC
to createPBKDF2
instance. - Define
MACHashBase
andMACSinkBase
for Message Authentication Code generators. - Reset features for
crc16
,crc32
,crc64
,alder32
, andhmac
internal sinks. - Enhance
blake2b
andblake2s
for MAC generation - Breaking change:
- Accept number of bytes instead of bits for
Blake2b
andBlake2s
- Removes all
Blake2b.of##
andBlake2s.of##
methods
- Accept number of bytes instead of bits for
- Fixes enum name getter usage issue for Dart < 2.15.0
- Optimize Argon2 (Now it is 6 times faster than 1.5.0)
- Support for Argon2 in Node platform (TODO: requires optimization)
- Renames
Argon2Context
->Argon2
with the following change:convert()
will generate password hash and return anArgon2HashDigest
encode()
will generate password hash and return argon2 encoded string.toInstance()
is renamed toinstance
to get a singleton instance.- The method
encode()
is renamed toconvert()
inside theinstance
.
- Adds
Argon2Security
exposing some default parameter choices which can be used with these quick access functions:argon2d
argon2i
argon2id
- Argon2 will now return the
Argon2HashDigest
, containing a few changes overHashDigest
:encoded()
will return the argon2 hash as encoded format.toString()
will return the encoded hash instead of the password hash.
- Implement custom
toBase64
andfromBase64
in utils for faster conversion without padding. - Changes to
HashDigest
:- merge
base64
andbase64url
methods into one. - uses custom base64 conversion that does not include
=
padding. - removes
lantin1
- merge
- Fixes issues with web platform
- Adds web support to
blake2b
- Adds Argon2, the Password Hashing Competition winner.
- Modifies the internal structure for better accessibility
- Fixes stream binding issue in
HashBase
- Removes a lot of string extensions. Remaining ones are:
sha512digest
sha256digest
sha224digest
sha3_512digest
sha3_384digest
sha3_256digest
sha3_224digest
sha1digest
md5digest
crc32code
- Accepts file input in
HashBase
- Accepts
salt
andpersonalization
values withBlake2s
andBlake2b
- Reduces memory overhead by utilizing the buffer in all
BlockHash
- Fixes broken sha512 hash fo web VM
- New features:
blake2s
blake2b
- New features available:
crc16
crc32
crc64
alder32
- Adds
String
extensions for convenient use all algorithms. - Renames functions:
sha512sum224
->sha512t224sum
sha512sum256
->sha512t256sum
- Renames function for
HashBase
:HashBase.stream
->HashBase.consume
HashBase.stringString
->HashBase.consumeAs
- Modifies the internal
HashDigestSink
:- Implements
ByteConversionSink
instead of extendingSink<List<int>>
- Use
addSlice
instead ofadd
- Implements
- Improves performance of some algorithms
- First release