password
Hashing and checking of passwords
https://github.com/cdepillabout/password/tree/master/password#readme
| LTS Haskell 24.16: | 3.1.0.1 | 
| Stackage Nightly 2025-10-23: | 3.1.0.1 | 
| Latest on Hackage: | 3.1.0.1 | 
BSD-3-Clause licensed by Dennis Gosnell, Felix Paulusma
Maintained by [email protected], [email protected]
This version can be pinned in stack with:
password-3.1.0.1@sha256:2ebc0084dbe8ff1c8ae333f0669229b5bcfcec270e8d1b5989944c9221d128a7,6126Module documentation for 3.1.0.1
- Data- Data.Password
 
Depends on 8 packages(full list with versions):
password
This library provides functions for working with passwords and password hashes in Haskell.
Currently supports the following algorithms:
- PBKDF2
- bcrypt
- scrypt
- Argon2
Also, see the password-instances package for instances for common typeclasses.
Changes
Changelog for password
3.1.0.1
- Redo the conditionals in the password.cabalfile so that the scrypt library is only included as a test dependency onx86_64. This generally shouldn’t affect users of thepasswordlibrary. Thanks to @sternenseemann #85
3.1.0.0
- Switched default cryptographic backend library from cryptonitetocrypton. Thecryptonflag is now a no-op, and thecryptoniteflag is needed to build thepasswordlibrary using thecryptonitelibrary. Thanks to @Vlix #81
3.0.4.0
- Support base64package up to and includingbase64-1.0.
- Added the Cabal flags cryptonandcryptoniteto choose which dependency to build with. Right now the default iscryptoniteand settingcryptonchanges it tocrypton. Setting thecryptoniteflag does nothing at the moment, but will replace thecryptonflag in a future major release, so if you want to keep using thecryptonitepackage you should start building with this flag. When the flags get switched thecryptonpackage will be the default and thecryptonflag will turn into a no-op, and you’ll have to supply thecryptoniteflag to build with thecryptonitepackage. Thanks to @Vlix #74
3.0.3.0
- Added bcryptdefaultParamsused byhashPasswordThanks to @blackheaven #70
3.0.2.2
3.0.2.1
- Add Cabal flags to control which hashing algorithms are exported. These flags are
argon2,bcrypt,pbkdf2, andscrypt. Each flag is enabled by default - disabling it will elide the corresponding module from the library. This allows downstream packagers to disable hashing algorithms which aren’t supported on certain platforms. Thanks to @ivanbakel #63
3.0.2.0
- Add extractParamsonPasswordHashs Thanks to @blackheaven #61
3.0.1.0
3.0.0.0
- Split the main datatypes module (Data.Password) into a separate package:password-types. The new package just containsPassword,PasswordHash,Saltand their helper functions/instances.
- Adjusted entire passwordpackage to use theData.Password.Typesfrom this newpassword-types. Thanks to @Vlix #40
- Argon2: fixed the producing and checking of Argon2 hashes. The base64 padding is removed when producing hashes and when checking hashes it will accept hashes with or without padding. #45
2.1.1.0
- Fixed homepagelinks in the.cabalfiles. #34 Thanks to @Radicalautistt
- Updated the defaultPasswordPolicyand documentation of theData.Password.Validatemodule using information about research done on “memorized secrets” (i.e. passwords) by the NIST. [#31] https://github.com/cdepillabout/password/pull/31 Thanks to @agentultra for pointing out the research and starting the PR. #39 Thanks to @Vlix for updating the rest of the documentation.
- Small spelling and other documentation fixes.
2.1.0.0
- A new Validatemodule has been added to dictate policies that passwords should adhere to and the necessary API to verify that they do. #26 Huge thanks to @HirotoShioi for picking up the task of adding this functionality and doing most of the groundwork. #27 Thanks to @Vlix for finishing up the API and documentation.
2.0.1.1
- Fixed cross-module links in the haddocks. #19 Thanks to @TristanCacqueray for fixing this.
2.0.1.0
- Switched checking hashes to using Data.ByteArray.constEq, instead of the default(==)method ofByteString. This is to make it more secure against timing attacks. #16 Thanks to @maralorn for bringing this up.
2.0.0.1
- Fixed README markdown for hackage.
2.0.0.0
- Complete overhaul of the library to include hashing and checking
passwords with not just scrypt, but alsoPBKDF2,bcryptandArgon2. #8
- cryptoniteis now used as a dependency, instead of the- scryptpackage. #8
- Done away with abbreviating “password” (Pass/pass->Password/password) #8
- Removed unsafeShowPasswordTextand changedunsafeShowPasswordto bePassword -> Text. (Anyone who needs it to be aStringknows where to findData.Text.unpack) #8
- GHC versions < 8.2 are no longer actively supported. (Tested to work for GHC 8.2.2)
1.0.0.0
- hashPassWithSalthas switched function arguments for better currying. #6 Although be warned that multiple passwords should not be hashed with the same salt.
- Removed Readinstance fromPassand addedShowinstance. #6 See #5 for justification of this.
- newSaltis now- MonadIO minstead of- IO. #6
- PassCheckSucchas been renamed to- PassCheckSuccess. #6
- Hide data constructor from Passand add themkPassfunction to construct aPass. #6
- Thanks to Felix Paulusma (@Vlix) for the above changes!
0.1.0.1
- Small fix to make sure the doctests build with stack. #3
0.1.0.0
- Initial version.
