2020-12-04 16:00:55 +08:00
|
|
|
package users
|
|
|
|
|
|
|
|
|
|
import (
|
|
|
|
|
"github.com/TeaOSLab/EdgeAdmin/internal/web/actions/actionutils"
|
|
|
|
|
"github.com/TeaOSLab/EdgeAdmin/internal/web/actions/default/users/userutils"
|
2023-06-30 18:08:30 +08:00
|
|
|
"github.com/TeaOSLab/EdgeCommon/pkg/langs/codes"
|
2020-12-04 16:00:55 +08:00
|
|
|
"github.com/TeaOSLab/EdgeCommon/pkg/rpc/pb"
|
|
|
|
|
"github.com/iwind/TeaGo/actions"
|
|
|
|
|
"github.com/iwind/TeaGo/maps"
|
2022-07-24 16:14:38 +08:00
|
|
|
"github.com/xlzd/gotp"
|
2020-12-04 16:00:55 +08:00
|
|
|
)
|
|
|
|
|
|
|
|
|
|
type UpdateAction struct {
|
|
|
|
|
actionutils.ParentAction
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func (this *UpdateAction) Init() {
|
|
|
|
|
this.Nav("", "", "update")
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func (this *UpdateAction) RunGet(params struct {
|
|
|
|
|
UserId int64
|
|
|
|
|
}) {
|
|
|
|
|
err := userutils.InitUser(this.Parent(), params.UserId)
|
|
|
|
|
if err != nil {
|
|
|
|
|
this.ErrorPage(err)
|
|
|
|
|
return
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
userResp, err := this.RPC().UserRPC().FindEnabledUser(this.AdminContext(), &pb.FindEnabledUserRequest{UserId: params.UserId})
|
|
|
|
|
if err != nil {
|
|
|
|
|
this.ErrorPage(err)
|
|
|
|
|
return
|
|
|
|
|
}
|
2022-07-24 16:14:38 +08:00
|
|
|
var user = userResp.User
|
2020-12-04 16:00:55 +08:00
|
|
|
if user == nil {
|
|
|
|
|
this.NotFound("user", params.UserId)
|
|
|
|
|
return
|
|
|
|
|
}
|
|
|
|
|
|
2021-06-20 19:23:02 +08:00
|
|
|
// AccessKey数量
|
|
|
|
|
countAccessKeyResp, err := this.RPC().UserAccessKeyRPC().CountAllEnabledUserAccessKeys(this.AdminContext(), &pb.CountAllEnabledUserAccessKeysRequest{UserId: params.UserId})
|
|
|
|
|
if err != nil {
|
|
|
|
|
this.ErrorPage(err)
|
|
|
|
|
return
|
|
|
|
|
}
|
2022-07-24 16:14:38 +08:00
|
|
|
var countAccessKeys = countAccessKeyResp.Count
|
2021-06-20 19:23:02 +08:00
|
|
|
|
2022-07-24 09:57:26 +08:00
|
|
|
// 是否有实名认证
|
|
|
|
|
hasNewIndividualIdentity, hasNewEnterpriseIdentity, identityTag, err := userutils.CheckUserIdentity(this.RPC(), this.AdminContext(), params.UserId)
|
|
|
|
|
if err != nil {
|
|
|
|
|
this.ErrorPage(err)
|
|
|
|
|
return
|
|
|
|
|
}
|
|
|
|
|
|
2022-07-24 16:14:38 +08:00
|
|
|
// OTP认证
|
|
|
|
|
var otpLoginIsOn = false
|
|
|
|
|
if user.OtpLogin != nil {
|
|
|
|
|
otpLoginIsOn = user.OtpLogin.IsOn
|
|
|
|
|
}
|
|
|
|
|
|
2020-12-04 16:00:55 +08:00
|
|
|
this.Data["user"] = maps.Map{
|
2021-06-20 19:23:02 +08:00
|
|
|
"id": user.Id,
|
|
|
|
|
"username": user.Username,
|
|
|
|
|
"fullname": user.Fullname,
|
|
|
|
|
"email": user.Email,
|
|
|
|
|
"tel": user.Tel,
|
|
|
|
|
"remark": user.Remark,
|
|
|
|
|
"mobile": user.Mobile,
|
|
|
|
|
"isOn": user.IsOn,
|
|
|
|
|
"countAccessKeys": countAccessKeys,
|
2023-02-27 10:46:48 +08:00
|
|
|
"bandwidthAlgo": user.BandwidthAlgo,
|
2022-07-24 09:57:26 +08:00
|
|
|
|
|
|
|
|
// 实名认证
|
|
|
|
|
"hasNewIndividualIdentity": hasNewIndividualIdentity,
|
|
|
|
|
"hasNewEnterpriseIdentity": hasNewEnterpriseIdentity,
|
|
|
|
|
"identityTag": identityTag,
|
2022-07-24 16:14:38 +08:00
|
|
|
|
|
|
|
|
// otp
|
|
|
|
|
"otpLoginIsOn": otpLoginIsOn,
|
2020-12-04 16:00:55 +08:00
|
|
|
}
|
|
|
|
|
|
2020-12-16 15:49:15 +08:00
|
|
|
this.Data["clusterId"] = 0
|
2020-12-17 17:35:38 +08:00
|
|
|
if user.NodeCluster != nil {
|
|
|
|
|
this.Data["clusterId"] = user.NodeCluster.Id
|
2020-12-16 15:49:15 +08:00
|
|
|
}
|
|
|
|
|
|
2020-12-04 16:00:55 +08:00
|
|
|
this.Show()
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func (this *UpdateAction) RunPost(params struct {
|
2023-02-27 10:46:48 +08:00
|
|
|
UserId int64
|
|
|
|
|
Username string
|
|
|
|
|
Pass1 string
|
|
|
|
|
Pass2 string
|
|
|
|
|
Fullname string
|
|
|
|
|
Mobile string
|
|
|
|
|
Tel string
|
|
|
|
|
Email string
|
|
|
|
|
Remark string
|
|
|
|
|
IsOn bool
|
|
|
|
|
ClusterId int64
|
|
|
|
|
BandwidthAlgo string
|
2020-12-04 16:00:55 +08:00
|
|
|
|
2022-07-24 16:14:38 +08:00
|
|
|
// OTP
|
|
|
|
|
OtpOn bool
|
|
|
|
|
|
2020-12-04 16:00:55 +08:00
|
|
|
Must *actions.Must
|
|
|
|
|
CSRF *actionutils.CSRF
|
|
|
|
|
}) {
|
2023-06-30 18:08:30 +08:00
|
|
|
defer this.CreateLogInfo(codes.User_LogUpdateUser, params.UserId)
|
2020-12-04 16:00:55 +08:00
|
|
|
|
|
|
|
|
params.Must.
|
|
|
|
|
Field("username", params.Username).
|
|
|
|
|
Require("请输入用户名").
|
|
|
|
|
Match(`^[a-zA-Z0-9_]+$`, "用户名中只能含有英文、数字和下划线")
|
|
|
|
|
|
2020-12-15 11:53:05 +08:00
|
|
|
checkUsernameResp, err := this.RPC().UserRPC().CheckUserUsername(this.AdminContext(), &pb.CheckUserUsernameRequest{
|
2020-12-04 16:00:55 +08:00
|
|
|
UserId: params.UserId,
|
|
|
|
|
Username: params.Username,
|
|
|
|
|
})
|
|
|
|
|
if err != nil {
|
|
|
|
|
this.ErrorPage(err)
|
|
|
|
|
return
|
|
|
|
|
}
|
|
|
|
|
if checkUsernameResp.Exists {
|
|
|
|
|
this.FailField("username", "此用户名已经被占用,请换一个")
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if len(params.Pass1) > 0 {
|
|
|
|
|
params.Must.
|
|
|
|
|
Field("pass1", params.Pass1).
|
|
|
|
|
Require("请输入密码").
|
|
|
|
|
Field("pass2", params.Pass2).
|
|
|
|
|
Require("请再次输入确认密码").
|
|
|
|
|
Equal(params.Pass1, "两次输入的密码不一致")
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
params.Must.
|
|
|
|
|
Field("fullname", params.Fullname).
|
|
|
|
|
Require("请输入全名")
|
|
|
|
|
|
|
|
|
|
if len(params.Mobile) > 0 {
|
|
|
|
|
params.Must.
|
|
|
|
|
Field("mobile", params.Mobile).
|
|
|
|
|
Mobile("请输入正确的手机号")
|
|
|
|
|
}
|
|
|
|
|
if len(params.Email) > 0 {
|
|
|
|
|
params.Must.
|
|
|
|
|
Field("email", params.Email).
|
|
|
|
|
Email("请输入正确的电子邮箱")
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
_, err = this.RPC().UserRPC().UpdateUser(this.AdminContext(), &pb.UpdateUserRequest{
|
2020-12-17 15:50:44 +08:00
|
|
|
UserId: params.UserId,
|
|
|
|
|
Username: params.Username,
|
|
|
|
|
Password: params.Pass1,
|
|
|
|
|
Fullname: params.Fullname,
|
|
|
|
|
Mobile: params.Mobile,
|
|
|
|
|
Tel: params.Tel,
|
|
|
|
|
Email: params.Email,
|
|
|
|
|
Remark: params.Remark,
|
|
|
|
|
IsOn: params.IsOn,
|
|
|
|
|
NodeClusterId: params.ClusterId,
|
2023-02-27 10:46:48 +08:00
|
|
|
BandwidthAlgo: params.BandwidthAlgo,
|
2020-12-04 16:00:55 +08:00
|
|
|
})
|
|
|
|
|
if err != nil {
|
|
|
|
|
this.ErrorPage(err)
|
|
|
|
|
return
|
|
|
|
|
}
|
|
|
|
|
|
2022-07-24 16:14:38 +08:00
|
|
|
// 修改OTP
|
|
|
|
|
otpLoginResp, err := this.RPC().LoginRPC().FindEnabledLogin(this.AdminContext(), &pb.FindEnabledLoginRequest{
|
|
|
|
|
UserId: params.UserId,
|
|
|
|
|
Type: "otp",
|
|
|
|
|
})
|
|
|
|
|
if err != nil {
|
|
|
|
|
this.ErrorPage(err)
|
|
|
|
|
return
|
|
|
|
|
}
|
|
|
|
|
{
|
|
|
|
|
var otpLogin = otpLoginResp.Login
|
|
|
|
|
if params.OtpOn {
|
|
|
|
|
if otpLogin == nil {
|
|
|
|
|
otpLogin = &pb.Login{
|
|
|
|
|
Id: 0,
|
|
|
|
|
Type: "otp",
|
|
|
|
|
ParamsJSON: maps.Map{
|
|
|
|
|
"secret": gotp.RandomSecret(16), // TODO 改成可以设置secret长度
|
|
|
|
|
}.AsJSON(),
|
|
|
|
|
IsOn: true,
|
|
|
|
|
UserId: params.UserId,
|
|
|
|
|
}
|
|
|
|
|
} else {
|
|
|
|
|
// 如果已经有了,就覆盖,这样可以保留既有的参数
|
|
|
|
|
otpLogin.IsOn = true
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
_, err = this.RPC().LoginRPC().UpdateLogin(this.AdminContext(), &pb.UpdateLoginRequest{Login: otpLogin})
|
|
|
|
|
if err != nil {
|
|
|
|
|
this.ErrorPage(err)
|
|
|
|
|
return
|
|
|
|
|
}
|
|
|
|
|
} else {
|
|
|
|
|
_, err = this.RPC().LoginRPC().UpdateLogin(this.AdminContext(), &pb.UpdateLoginRequest{Login: &pb.Login{
|
|
|
|
|
Type: "otp",
|
|
|
|
|
IsOn: false,
|
|
|
|
|
UserId: params.UserId,
|
|
|
|
|
}})
|
|
|
|
|
if err != nil {
|
|
|
|
|
this.ErrorPage(err)
|
|
|
|
|
return
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2020-12-04 16:00:55 +08:00
|
|
|
this.Success()
|
|
|
|
|
}
|