Files
SamWaf/api/waf_account.go
2025-02-26 13:39:25 +08:00

143 lines
3.6 KiB
Go

package api
import (
"SamWaf/global"
"SamWaf/model"
"SamWaf/model/common/response"
"SamWaf/model/request"
"errors"
"github.com/gin-gonic/gin"
"gorm.io/gorm"
)
type WafAccountApi struct {
}
func (w *WafAccountApi) AddApi(c *gin.Context) {
var req request.WafAccountAddReq
err := c.ShouldBindJSON(&req)
if err == nil {
err = wafAccountService.CheckIsExistApi(req)
if err != nil && errors.Is(err, gorm.ErrRecordNotFound) {
err = wafAccountService.AddApi(req)
if err == nil {
response.OkWithMessage("添加成功", c)
} else {
response.FailWithMessage("添加失败", c)
}
return
} else {
response.FailWithMessage("当前数据已经存在", c)
return
}
} else {
response.FailWithMessage("解析失败", c)
}
}
func (w *WafAccountApi) GetDetailApi(c *gin.Context) {
var req request.WafAccountDetailReq
err := c.ShouldBind(&req)
if err == nil {
bean := wafAccountService.GetDetailApi(req)
response.OkWithDetailed(bean, "获取成功", c)
} else {
response.FailWithMessage("解析失败", c)
}
}
func (w *WafAccountApi) GetListApi(c *gin.Context) {
var req request.WafAccountSearchReq
err := c.ShouldBindJSON(&req)
if err == nil {
beans, total, _ := wafAccountService.GetListApi(req)
response.OkWithDetailed(response.PageResult{
List: beans,
Total: total,
PageIndex: req.PageIndex,
PageSize: req.PageSize,
}, "获取成功", c)
} else {
response.FailWithMessage("解析失败", c)
}
}
func (w *WafAccountApi) DelAccountApi(c *gin.Context) {
var req request.WafAccountDelReq
err := c.ShouldBind(&req)
if err == nil {
err = wafAccountService.DelApi(req)
if err != nil && errors.Is(err, gorm.ErrRecordNotFound) {
response.FailWithMessage("请检测参数", c)
} else if err != nil {
response.FailWithMessage("发生错误", c)
} else {
response.OkWithMessage("删除成功", c)
}
} else {
response.FailWithMessage("解析失败", c)
}
}
func (w *WafAccountApi) ModifyAccountApi(c *gin.Context) {
var req request.WafAccountEditReq
err := c.ShouldBindJSON(&req)
if err == nil {
err = wafAccountService.ModifyApi(req)
if err != nil {
response.FailWithMessage("编辑发生错误", c)
} else {
response.OkWithMessage("编辑成功", c)
}
} else {
response.FailWithMessage("解析失败", c)
}
}
func (w *WafAccountApi) ResetAccountPwdApi(c *gin.Context) {
var req request.WafAccountResetPwdReq
err := c.ShouldBindJSON(&req)
if err == nil {
if req.LoginNewPassword != req.LoginNewPassword2 {
response.OkWithMessage("两次输入的密码不同", c)
return
}
err = wafAccountService.ResetPwdApi(req)
if err != nil {
response.FailWithMessage(err.Error(), c)
} else {
response.OkWithMessage("重置密码成功", c)
}
} else {
response.FailWithMessage("重置密码失败", c)
}
}
func (w *WafAccountApi) ResetAccountOTPApi(c *gin.Context) {
var req request.WafAccountResetOTPReq
err := c.ShouldBindJSON(&req)
if err == nil {
tokenStr := c.GetHeader("X-Token")
tokenInfo := wafTokenInfoService.GetInfoByAccessToken(tokenStr)
if tokenInfo.LoginAccount == "" {
response.FailWithMessage("token可能已经失效", c)
return
}
if tokenInfo.LoginAccount == "admin" {
response.FailWithMessage("仅admin用户可以重置2FA", c)
return
}
if req.LoginAccount == "admin" {
response.OkWithMessage("admin帐号需要用控制台命令重置详情查看常见问题", c)
return
}
global.GWAF_LOCAL_DB.Where("user_name = ? ", req.LoginAccount).Delete(model.Otp{})
response.OkWithMessage("重置2FA成功", c)
} else {
response.FailWithMessage("重置2FA失败", c)
}
}