authelia/internal/configuration/validator
James Elliott 26369fff3d
[FEATURE] Support Argon2id password hasing and improved entropy (#679)
* [FEATURE] Support Argon2id Passwords

- Updated go module github.com/simia-tech/crypt
- Added Argon2id support for file based authentication backend
- Made it the default method
- Made it so backwards compatibility with SHA512 exists
- Force seeding of the random string generator used for salts to ensure they are all different
- Added command params to the authelia hash-password command
- Automatically remove {CRYPT} from hashes as they are updated
- Automatically change hashes when they are updated to the configured algorithm
- Made the hashing algorithm parameters completely configurable
- Added reasonably comprehensive test suites
- Updated docs
- Updated config template

* Adjust error output

* Fix unit test

* Add unit tests and argon2 version check

* Fix new unit tests

* Update docs, added tests

* Implement configurable values and more comprehensive testing

* Added cmd params to hash_password, updated docs, misc fixes

* More detailed error for cmd, fixed a typo

* Fixed cmd flag error, minor refactoring

* Requested Changes and Minor refactoring

* Increase entropy

* Update docs for entropy changes

* Refactor to reduce nesting and easier code maintenance

* Cleanup Errors (uniformity for the function call)

* Check salt length, fix docs

* Add Base64 string validation for argon2id

* Cleanup and Finalization
- Moved RandomString function from ./internal/authentication/password_hash.go to ./internal/utils/strings.go
- Added SplitStringToArrayOfStrings func that splits strings into an array with a fixed max string len
- Fixed an error in validator that would allow a zero salt length
- Added a test to verify the upstream crypt module supports our defined random salt chars
- Updated docs
- Removed unused "HashingAlgorithm" string type

* Update crypt go mod, support argon2id key length and major refactor

* Config Template Update, Final Tests

* Use schema defaults for hash-password cmd

* Iterations check

* Docs requested changes

* Test Coverage, suggested edits

* Wording edit

* Doc changes

* Default sanity changes

* Default sanity changes - docs

* CI Sanity changes

* Memory in MB
2020-03-06 12:38:02 +11:00
..
authentication.go [FEATURE] Support Argon2id password hasing and improved entropy (#679) 2020-03-06 12:38:02 +11:00
authentication_test.go [FEATURE] Support Argon2id password hasing and improved entropy (#679) 2020-03-06 12:38:02 +11:00
configuration.go [FEATURE] Add TLS support. (#677) 2020-03-03 18:18:25 +11:00
configuration_test.go [FEATURE] Add TLS support. (#677) 2020-03-03 18:18:25 +11:00
notifier.go Add validation for notifier configuration. 2020-01-22 10:15:25 +11:00
notifier_test.go Add validation for notifier configuration. 2020-01-22 10:15:25 +11:00
session.go Rename org from clems4ever to authelia 2019-12-24 13:14:52 +11:00
session_test.go Rename org from clems4ever to authelia 2019-12-24 13:14:52 +11:00
storage.go [FIX] Prevent crash when storage config is nil (#623) 2020-02-06 13:53:02 +11:00
storage_test.go [FIX] Prevent crash when storage config is nil (#623) 2020-02-06 13:53:02 +11:00
totp.go Rename org from clems4ever to authelia 2019-12-24 13:14:52 +11:00
totp_test.go Introduce viper in order to read secrets from env variables. 2020-01-22 10:15:25 +11:00