package main import ( "unicode/utf8" "github.com/satori/go.uuid" "golang.org/x/crypto/bcrypt" ) func getValidUsername(u string) (uuid.UUID, error) { uname, err := uuid.FromString(u) if err != nil { return uuid.UUID{}, err } return uname, nil } func validKey(k string) bool { kn := sanitizeString(k) if utf8.RuneCountInString(k) == 40 && utf8.RuneCountInString(kn) == 40 { // Correct length and all chars valid return true } return false } func validSubdomain(s string) bool { _, err := uuid.FromString(s) if err == nil { return true } return false } func validTXT(s string) bool { sn := sanitizeString(s) if utf8.RuneCountInString(s) == 43 && utf8.RuneCountInString(sn) == 43 { // 43 chars is the current LE auth key size, but not limited / defined by ACME return true } return false } func correctPassword(pw string, hash string) bool { if err := bcrypt.CompareHashAndPassword([]byte(hash), []byte(pw)); err == nil { return true } return false }