Changelog for base64-0.4.2.3
Revision history for base64
0.4.2.3
- Minor release for stackage, limiting memory usage in test suites.
- Transition to Github Actions CI
0.4.2.2
- Add
NFData
,Exception
, andGeneric
instances forBase64Error
+@since
annotations for new instances. (#28) - Doc improvements and add
-XTrustworty
and-XSafe
annotations where needed. (#27) - Improve URL canonicity validation and correctness checking (now supports correct checking for unpadded Base64url) (#26)
- Fixed perf regressions in decode
- Test coverage is at 98%
0.4.2.1
-
Security fix: reject non-canonical base64 encoded values - (#25)
-
Perf improvements
0.4.2
- Added support for
Data.ByteString.Short
,Data.ByteString.Lazy
,Data.Text.Short
, andData.Text.Lazy
. (#17) - Optimize decode algorithm (now beats
base64-bytestring
in every category!) - (#13) - Use
decodeLatin1
when decoding to text, so that functions are total - (#13) - Added
decodeWith*
variants and aBase64Error
type to handle decoding errors when decoding base64 values - (#13) - Improved error reporting: all offsets are now precisely accurate. - (#13)
- Validations added to head, rejecting invalid corner cases (such as bytestrings of length
l == 1 mod 4
, which are never correct) - (#16) - Added
decodeBase64Padded
for symmetry - (#13)
0.4.1 -- 2020-02-04
- Optimize loops for 32-bit and 64-bit architectures
- Restructure project to be more amenable to swapping head/tail/loops
- Fix module header alignment
0.4.0 -- 2020-01-26
-
With this major version release, we remove the redundant
encodeBase64Unpadded
anddecodeBase64Unpadded
functions fromBase64.hs
. This is for two reasons:- There is no reason for them to exist, since all std base64 is expected to be padded (in contrast to base64url)
- it was literally redundant with
decodeBase64
.
-
Use a specialized
Bool
type to give better visual cues regarding which functions add padding
0.3.1.1 -- 2020-01-15
- Make sure benchmark code builds
0.3.1.0 -- 2020-01-08
- Bug fix for
isBase64
andisBase64Url
- wrong alphabet was used - Added
isValidBase64
andisValidBase64Url
for alphabet conformity. TheisBase64*
functions now tell if it's correct base64 now in the sense that it's decodable and valid. - Dropped Cabal version to 2.0 for backcompat with Stack
- Better documentation
0.3.0.0 -- 2020-01-07
- After a discussion with lexilambda, we're making 'encodeBase64' be
ByteString -> Text
by default, offeringByteString -> ByteString
as a secondary format. - Add
decodeBase64Lenient
to the API for phadej - Fix unpadded decoding bug where garbage was appended to the end of garbage inputs. A cleaner way to do this is to simply encode as Base64 with padding and then strip padding chars until I come up with a workflow specific to unpadded inputs (I used to have this, so I'll have to dig it up)
- Added
isBase64
andisBase64Url
to the API - Performance is stable
0.2.0.0 -- 2020-01-05
- After a discussion with phadej, we're doing away with the flags, and splitting the optics out into their own separate library
- Removed unnecessary inline pragmas
0.1.0.0 -- 2020-01-05
- Do away with the typeclasses, and just provide prisms + synonyms
- Continued performance improvements to decoding
- Corrected benchmarks
0.0.1.0 -- 2020-01-03
- First version. Released on an unsuspecting world.
- Preliminary release