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
|
2022-10-22 17:38:39 +08:00
|
|
|
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 {
|
2022-10-22 17:38:39 +08:00
|
|
|
s.log.Warn("BcryptError", zap.Error(err), zap.String("password", data.Password))
|
2022-09-17 18:10:06 +08:00
|
|
|
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,
|
2022-10-22 17:38:39 +08:00
|
|
|
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
|
2022-10-22 17:38:39 +08:00
|
|
|
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))
|
2022-09-17 18:10:06 +08:00
|
|
|
return nil, e.DatabaseError
|
2022-09-08 22:00:25 +08:00
|
|
|
}
|
2022-09-17 18:10:06 +08:00
|
|
|
return user, e.Success
|
2022-09-08 22:00:25 +08:00
|
|
|
}
|