woj-server/internal/service/user/create.go

42 lines
977 B
Go
Raw Normal View History

2022-09-08 22:00:25 +08:00
package user
import (
2023-07-14 21:47:11 +08:00
"git.0x7f.app/WOJ/woj-server/internal/e"
"git.0x7f.app/WOJ/woj-server/internal/model"
2022-09-08 22:00:25 +08:00
"go.uber.org/zap"
2022-09-17 09:23:36 +08:00
"golang.org/x/crypto/bcrypt"
2022-09-17 11:22:55 +08:00
"strings"
2022-09-08 22:00:25 +08:00
)
type CreateData struct {
2024-01-05 14:31:09 +08:00
Email string
NickName string
2024-01-02 23:39:09 +08:00
Password string
2022-09-08 22:00:25 +08:00
}
2022-09-20 14:15:21 +08:00
func (s *service) Create(data *CreateData) (*model.User, e.Status) {
2022-09-17 09:23:36 +08:00
hashed, err := bcrypt.GenerateFromPassword([]byte(data.Password), bcrypt.DefaultCost)
if err != nil {
s.log.Warn("BcryptError", zap.Error(err), zap.String("password", data.Password))
return nil, e.InternalError
2022-09-17 09:23:36 +08:00
}
user := &model.User{
2024-01-05 14:31:09 +08:00
Email: data.Email,
NickName: data.NickName,
2024-01-02 23:39:09 +08:00
Password: hashed,
2022-09-20 14:34:30 +08:00
Role: model.RoleGeneral,
2022-09-08 22:00:25 +08:00
IsEnabled: true,
}
2023-07-15 16:19:49 +08:00
err = s.db.Get().Create(user).Error
if err != nil && strings.Contains(err.Error(), "duplicate key") {
return nil, e.UserDuplicated
}
if err != nil {
s.log.Warn("DatabaseError", zap.Error(err), zap.Any("user", user))
return nil, e.DatabaseError
2022-09-08 22:00:25 +08:00
}
return user, e.Success
2022-09-08 22:00:25 +08:00
}