mirror of
https://github.com/ergochat/ergo.git
synced 2025-01-11 04:32:39 +01:00
Merge pull request #1804 from slingamn/pwvalidation
make `ergo genpasswd` warn for bad passwords
This commit is contained in:
commit
b478e93c11
4
ergo.go
4
ergo.go
@ -128,6 +128,10 @@ Options:
|
|||||||
} else {
|
} else {
|
||||||
password = getPassword()
|
password = getPassword()
|
||||||
}
|
}
|
||||||
|
if err := irc.ValidatePassphrase(password); err != nil {
|
||||||
|
log.Printf("WARNING: this password contains characters that may cause problems with your IRC client software.\n")
|
||||||
|
log.Printf("We strongly recommend choosing a different password.\n")
|
||||||
|
}
|
||||||
hash, err := bcrypt.GenerateFromPassword([]byte(password), bcrypt.MinCost)
|
hash, err := bcrypt.GenerateFromPassword([]byte(password), bcrypt.MinCost)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
log.Fatal("encoding error:", err.Error())
|
log.Fatal("encoding error:", err.Error())
|
||||||
|
@ -503,8 +503,8 @@ func registrationCallbackErrorText(config *Config, client *Client, err error) st
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// validatePassphrase checks whether a passphrase is allowed by our rules
|
// ValidatePassphrase checks whether a passphrase is allowed by our rules
|
||||||
func validatePassphrase(passphrase string) error {
|
func ValidatePassphrase(passphrase string) error {
|
||||||
// sanity check the length
|
// sanity check the length
|
||||||
if len(passphrase) == 0 || len(passphrase) > 300 {
|
if len(passphrase) == 0 || len(passphrase) > 300 {
|
||||||
return errAccountBadPassphrase
|
return errAccountBadPassphrase
|
||||||
@ -1122,7 +1122,7 @@ func (am *AccountManager) NsSendpass(client *Client, accountName string) (err er
|
|||||||
}
|
}
|
||||||
|
|
||||||
func (am *AccountManager) NsResetpass(client *Client, accountName, code, password string) (err error) {
|
func (am *AccountManager) NsResetpass(client *Client, accountName, code, password string) (err error) {
|
||||||
if validatePassphrase(password) != nil {
|
if ValidatePassphrase(password) != nil {
|
||||||
return errAccountBadPassphrase
|
return errAccountBadPassphrase
|
||||||
}
|
}
|
||||||
account, err := am.LoadAccount(accountName)
|
account, err := am.LoadAccount(accountName)
|
||||||
@ -2181,7 +2181,7 @@ func (ac *AccountCredentials) SetPassphrase(passphrase string, bcryptCost uint)
|
|||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
if validatePassphrase(passphrase) != nil {
|
if ValidatePassphrase(passphrase) != nil {
|
||||||
return errAccountBadPassphrase
|
return errAccountBadPassphrase
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user