You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
71 lines
1.6 KiB
71 lines
1.6 KiB
package user
|
|
|
|
import (
|
|
"errors"
|
|
"log"
|
|
|
|
"github.com/google/uuid"
|
|
"golang.org/x/crypto/bcrypt"
|
|
)
|
|
|
|
const (
|
|
BCRYPTCOST = 12
|
|
)
|
|
|
|
func (env *Env) createUser(username string, password string) (*User, error) {
|
|
var createdUser User
|
|
|
|
passwordByte := []byte(password)
|
|
createdHashBytes, err := bcrypt.GenerateFromPassword(passwordByte, BCRYPTCOST)
|
|
|
|
if err != nil {
|
|
return nil, errors.New("failed to generate bcrypt")
|
|
}
|
|
|
|
createdUser.Username = username
|
|
createdUser.PasswordBcrypt = string(createdHashBytes)
|
|
return &createdUser, nil
|
|
}
|
|
|
|
func (env *Env) registerUser(username string, password string) (*User, error) {
|
|
newUser, err := env.createUser(username, password)
|
|
|
|
if err != nil {
|
|
log.Println(err)
|
|
return nil, errors.New("failed to register user")
|
|
}
|
|
|
|
// Check existing username
|
|
var checkUser User
|
|
env.DB.Where(&User{Username: username}).First(&checkUser)
|
|
if checkUser.ID != uuid.Nil {
|
|
log.Println(err)
|
|
return nil, errors.New("user already exists")
|
|
}
|
|
|
|
err = env.DB.Create(newUser).Error
|
|
if err != nil {
|
|
log.Println(err)
|
|
return nil, errors.New("failed write to database")
|
|
}
|
|
|
|
return newUser, nil
|
|
}
|
|
|
|
func (env *Env) checkLogin(username string, password string) (*User, error) {
|
|
var currUser User
|
|
env.DB.Preload("Profile").Where(&User{Username: username}).First(&currUser)
|
|
|
|
// Prevent username enum by parsing password
|
|
if currUser.ID == uuid.Nil {
|
|
bcrypt.GenerateFromPassword([]byte{}, BCRYPTCOST)
|
|
return nil, errors.New("invalid username or password")
|
|
}
|
|
|
|
err := bcrypt.CompareHashAndPassword([]byte(currUser.PasswordBcrypt), []byte(password))
|
|
if err != nil {
|
|
return nil, errors.New("invalid username or password")
|
|
} else {
|
|
return &currUser, nil
|
|
}
|
|
}
|