- Fix issue with SHA-3 and using a combination of TEXT/UTF-16 input (thanks frostschutz!)
- Sped up SHA-3 implementation by adding little-endian capability to conversion functions
- Further sped up SHA-3 implementation by decomposing xor_64 function (thanks frostschutz!)
- Fixed incorrect results when using ArrayBuffers (thanks conref!)
- Added externs/sha.js for Google Closure Compiler users (thanks IvanRF!)
- Added support for the SHA-3 family of hashes (SHA3-224, SHA3-256, SHA3-384, SHA3-512, SHAKE128, and SHAKE256)
- Fixed bug with using ARRAYBUFFER as a HMAC key type
- Switched testing framework to Mocha and Chai
- Added ability to call
update
on hashes betweengetHash
andgetHMAC
calls - Added new input and output type, "ARRAYBUFFER" which is a JavaScript ArrayBuffer
- Now keeping smaller build files in NPM (thanks vogievetsky!)
- Fixed problem with hashing strings over 4 billion bits (thanks Eicar!)
- Fixed inability to have a blank "b64Pad" (thanks xlc!)
- Added file hashing test (thanks kofalt!)
- Fixed major issue with all hashes failing if raw input was a particular size (thanks treus!)
- Completely reworked API to support streaming inputs
- Exceptions now throw Errors instead of strings (thanks jclem!)
- Fixed issue with SHA-512 family of hashes failing is raw input was a particular size
This marks the last v1.X new feature release. The API is changing significantly with upcoming v2.0 to support streaming and it will be too difficult to support the older API style with new features.
- Added a BYTES input and output format that is a raw byte string
- Fixed broken AMD support (thanks drewcovi!)
- Fixed broken UTF-8 parsing on non-BMP Unicode characters
- Changed array references to remove warnings on Icedove
- Replaced "UTF16" encoding with "UTF16BE" (big endian) and "UTF16LE" (little endian) to remove confusion
- Changed Google Closure Compiler options to produce "strict" compatible code
- Added optional numRounds argument to getHash
- Note: this necessitated removing the hash result caching functionality
- Reduced file size by optimizing internal constants
- Removed charSize input and replaced with encoding to handle Unicode. NOTE:
Only Code points up to 0xFFFF are supported.
- charSize = 16 is effectively replaced by encoding = "UTF16"
- charSize = 8 was wrong in terms of handling UTF-8 and has been replaced by encoding = "UTF8"
- Changed method of referencing "window" to be compatible with WebWorkers, Node.js, and AMD (thanks piranna!)
- Readded v1.4 Safari patch to support older versions
- Fixed incorrect hash issue with Chrome x64 v25 (Dev channel), also provides stable patch to v1.4 Safari issue.
- Added new input type, TEXT, that is functionally identical to ASCII*
- Added new input type, B64, for base-64 encoded strings
- Added new input and output formatting parameters
getHash
andgetHMAC
take an optional parameter, outputFormatOpts, that is a hash list containing the keys "outputUpper" (boolean, only applicable to HEX output) and "b64Pad" (string, only applicable to Base-64 output) that have default values of false and "=", respectively- jsSHA constructor takes an optional parameter, charSize (8 or 16) that specifies the character width of the input (TEXT and ASCII input only)
- Modified comments to be Google Closure Compiler compliant
- Added a SUPPORTED_ALGS flag that, when used with the Google Closure Compiler,
will remove unused functions/function portions
- Removed all src/*_nice.js files as the SUPPORTED_ALGS flag renders them obsolete
- All production-ready files are now produced using the Google Closure Compiler with ADVANCED_OPTIMIZATIONS resulting in further reduced filesizes
- The SHA-1 only implementation now requires that that "SHA-1" be specified as the variant when using getHash and getHMAC
- Removed test/HMAC.py as new NIST tests made the need for it obsolete
- Significantly changed the test/test.html to make it easier to understand and to allow for easier adding of test cases
- Replaced previous error returning code with thrown exceptions
- Fix for 64-bit Safari issue (thanks Ron Garret and Chris Warren-Smith!)
- NOTE: While this fix works, it is merely a workaround for a WebKit JavaScript optimizer bug, see https://bugs.webkit.org/show_bug.cgi?id=88673 for more detail
* This library misused the term ASCII so input type of TEXT was added with the intention of deprecating ASCII
- Updated project URL to point to new GitHub repository
- Added a compressed version of sha.js
- Changed method of declaring objects/classes
- Moved non-instance specific variables and methods to class scope
- Removed logically correct but unneeded conditionals
- Added the HMAC algorithm for all supported hashes (using both ASCII and hex keys)
- As a result of adding HMAC, added support for hash input text to be hex (ASCII representation of hex)
- Added multiple variants of safeAdd functions, resulting in a significant performance gain
- Removed wrapper.js file
- Used a different JavaScript compressor resulting in smaller file sizes
- Fixed a base-64 encoding issue resulting from a missing capital 'X'
- Fixed an issue with incorrect hashes being generated when jsSHA ojbects were used to generate multiple hashes
- Made all functions/variables follow an object-orientated methodology
- Removed support for string hash output as the hash is rarely ASCII friendly
- Changed the interface to calculate hashes (see README)
- Made sha.js validate against JSLint using "Recommended" settings
- Initial public release