Enforce registration rules

This commit is contained in:
Andinus 2020-03-27 21:21:03 +05:30
parent 3dee795567
commit 248dff015b
Signed by: andinus
GPG Key ID: B67D55D482A799FD
1 changed files with 17 additions and 4 deletions

View File

@ -1,7 +1,9 @@
package auth
import (
"errors"
"log"
"regexp"
"strings"
"tildegit.org/andinus/perseus/storage/sqlite3"
@ -10,13 +12,24 @@ import (
// Register takes in registration details and returns an error. If
// error doesn't equal nil then the registration was unsuccessful.
// regInfo should have username & password.
func Register(db *sqlite3.DB, regInfo map[string]string) error {
// uInfo should have username & password.
func Register(db *sqlite3.DB, uInfo map[string]string) error {
u := user.User{}
u.SetID(genID(64))
u.SetUsername(strings.ToLower(regInfo["username"]))
u.SetUsername(strings.ToLower(uInfo["username"]))
pass, err := hashPass(regInfo["password"])
// Validate username
re := regexp.MustCompile("^[a-z0-9]*$")
if !re.MatchString(u.Username()) {
return errors.New("auth/register.go: invalid username")
}
// Validate password
if len(uInfo["password"]) < 8 {
return errors.New("auth/register.go: password too short")
}
pass, err := hashPass(uInfo["password"])
if err != nil {
log.Printf("auth/register.go: %s\n",
"hashPass func failed")