storj/satellite/console/validation.go

88 lines
2.0 KiB
Go
Raw Normal View History

2019-01-24 16:26:36 +00:00
// Copyright (C) 2019 Storj Labs, Inc.
2018-11-29 16:23:44 +00:00
// See LICENSE for copying information.
package console
2018-11-29 16:23:44 +00:00
import (
"strings"
2018-11-29 16:23:44 +00:00
"unicode"
"github.com/zeebo/errs"
)
const (
passMinLength = 6
passMinNumberCount = 1
passMinAZCount = 1
)
// ErrValidation validation related error class
var ErrValidation = errs.Class("validation error")
// validationError is slice of ErrValidation class errors
type validationErrors []error
// Add new ErrValidation err
func (validation *validationErrors) Add(format string, args ...interface{}) {
2018-11-30 13:04:59 +00:00
*validation = append(*validation, ErrValidation.New(format, args...))
2018-11-29 16:23:44 +00:00
}
// AddWrap adds new ErrValidation wrapped err
func (validation *validationErrors) AddWrap(err error) {
*validation = append(*validation, ErrValidation.Wrap(err))
}
// Combine returns combined validation errors
func (validation *validationErrors) Combine() error {
return errs.Combine(*validation...)
2018-11-29 16:23:44 +00:00
}
// countNumerics returns total number of digits in string
func countNumerics(s string) int {
total := 0
for _, r := range s {
if unicode.IsDigit(r) {
total++
}
}
return total
}
// countLetters returns total number of letters in string
func countLetters(s string) int {
total := 0
for _, r := range s {
if unicode.IsLetter(r) {
total++
}
}
return total
}
// validatePassword validates password
func validatePassword(pass string) error {
var errs validationErrors
if len(pass) < passMinLength {
errs.Add("password can't be less than %d characters", passMinLength)
}
if countNumerics(pass) < passMinNumberCount {
errs.Add("password should contain at least %d digits", passMinNumberCount)
}
if countLetters(pass) < passMinAZCount {
errs.Add("password should contain at least %d alphabetic characters", passMinAZCount)
}
return errs.Combine()
}
// normalizeEmail converts emails with different casing into equal strings
// Note: won't work with µıſͅςϐϑϕϖϰϱϵᲀᲁᲂᲃᲄᲅᲆᲇᲈẛι
func normalizeEmail(s string) string {
return strings.ToLower(s)
}