130 lines
4.1 KiB
Go
130 lines
4.1 KiB
Go
package user
|
||
|
||
import (
|
||
"net/url"
|
||
"strings"
|
||
|
||
model "github.com/cloudreve/Cloudreve/v3/models"
|
||
"github.com/cloudreve/Cloudreve/v3/pkg/auth"
|
||
"github.com/cloudreve/Cloudreve/v3/pkg/email"
|
||
"github.com/cloudreve/Cloudreve/v3/pkg/hashid"
|
||
"github.com/cloudreve/Cloudreve/v3/pkg/serializer"
|
||
"github.com/cloudreve/Cloudreve/v3/pkg/util"
|
||
"github.com/gin-gonic/gin"
|
||
)
|
||
|
||
// UserRegisterService 管理用户注册的服务
|
||
type UserRegisterService struct {
|
||
//TODO 细致调整验证规则
|
||
UserName string `form:"userName" json:"userName" binding:"required,email"`
|
||
Password string `form:"Password" json:"Password" binding:"required,min=4,max=64"`
|
||
}
|
||
|
||
// Register 新用户注册
|
||
func (service *UserRegisterService) Register(c *gin.Context) serializer.Response {
|
||
// 相关设定
|
||
options := model.GetSettingByNames("email_active", "reg_captcha", "mail_domain_filter", "mail_domain_filter_list")
|
||
|
||
// 检查是否在邮件域黑名单里
|
||
if options["mail_domain_filter"] != "0" {
|
||
filterList := strings.Split(options["mail_domain_filter_list"], ",")
|
||
emailSplit := strings.Split(service.UserName, "@")
|
||
emailDomain := emailSplit[len(emailSplit)-1]
|
||
inList := util.ContainsString(filterList, emailDomain)
|
||
domainErr := serializer.Err(serializer.CodeEmailProviderBaned, "Email provider banned", nil)
|
||
if options["mail_domain_filter"] == "1" && !inList {
|
||
return domainErr
|
||
}
|
||
if options["mail_domain_filter"] == "2" && inList {
|
||
return domainErr
|
||
}
|
||
}
|
||
|
||
// 相关设定
|
||
isEmailRequired := model.IsTrueVal(options["email_active"])
|
||
defaultGroup := model.GetIntSetting("default_group", 2)
|
||
|
||
// 创建新的用户对象
|
||
user := model.NewUser()
|
||
user.Email = service.UserName
|
||
user.Nick = strings.Split(service.UserName, "@")[0]
|
||
user.SetPassword(service.Password)
|
||
user.Status = model.Active
|
||
if isEmailRequired {
|
||
user.Status = model.NotActivicated
|
||
}
|
||
user.GroupID = uint(defaultGroup)
|
||
userNotActivated := false
|
||
// 创建用户
|
||
if err := model.DB.Create(&user).Error; err != nil {
|
||
//检查已存在使用者是否尚未激活
|
||
expectedUser, err := model.GetUserByEmail(service.UserName)
|
||
if expectedUser.Status == model.NotActivicated {
|
||
userNotActivated = true
|
||
user = expectedUser
|
||
} else {
|
||
return serializer.Err(serializer.CodeEmailExisted, "Email already in use", err)
|
||
}
|
||
}
|
||
|
||
// 发送激活邮件
|
||
if isEmailRequired {
|
||
|
||
// 签名激活请求API
|
||
base := model.GetSiteURL()
|
||
userID := hashid.HashID(user.ID, hashid.UserID)
|
||
controller, _ := url.Parse("/api/v3/user/activate/" + userID)
|
||
activateURL, err := auth.SignURI(auth.General, base.ResolveReference(controller).String(), 86400)
|
||
if err != nil {
|
||
return serializer.Err(serializer.CodeEncryptError, "Failed to sign the activation link", err)
|
||
}
|
||
|
||
// 取得签名
|
||
credential := activateURL.Query().Get("sign")
|
||
|
||
// 生成对用户访问的激活地址
|
||
controller, _ = url.Parse("/activate")
|
||
finalURL := base.ResolveReference(controller)
|
||
queries := finalURL.Query()
|
||
queries.Add("id", userID)
|
||
queries.Add("sign", credential)
|
||
finalURL.RawQuery = queries.Encode()
|
||
|
||
// 返送激活邮件
|
||
title, body := email.NewActivationEmail(user.Email,
|
||
finalURL.String(),
|
||
)
|
||
if err := email.Send(user.Email, title, body); err != nil {
|
||
return serializer.Err(serializer.CodeFailedSendEmail, "Failed to send activation email", err)
|
||
}
|
||
if userNotActivated == true {
|
||
//原本在上面要抛出的DBErr,放来这边抛出
|
||
return serializer.Err(serializer.CodeEmailSent, "User is not activated, activation email has been resent", nil)
|
||
} else {
|
||
return serializer.Response{Code: 203}
|
||
}
|
||
}
|
||
|
||
return serializer.Response{}
|
||
}
|
||
|
||
// Activate 激活用户
|
||
func (service *SettingService) Activate(c *gin.Context) serializer.Response {
|
||
// 查找待激活用户
|
||
uid, _ := c.Get("object_id")
|
||
user, err := model.GetUserByID(uid.(uint))
|
||
if err != nil {
|
||
return serializer.Err(serializer.CodeUserNotFound, "User not fount", err)
|
||
}
|
||
|
||
// 检查状态
|
||
if user.Status != model.NotActivicated {
|
||
return serializer.Err(serializer.CodeUserCannotActivate, "This user cannot be activated", nil)
|
||
}
|
||
|
||
// 激活用户
|
||
user.SetStatus(model.Active)
|
||
|
||
return serializer.Response{Data: user.Email}
|
||
}
|