Files
mayfly-go/server/internal/sys/router/account.go
2024-01-21 22:52:20 +08:00

57 lines
1.6 KiB
Go

package router
import (
"mayfly-go/internal/sys/api"
"mayfly-go/pkg/biz"
"mayfly-go/pkg/ioc"
"mayfly-go/pkg/req"
"github.com/gin-gonic/gin"
)
func InitAccountRouter(router *gin.RouterGroup) {
account := router.Group("sys/accounts")
a := new(api.Account)
biz.ErrIsNil(ioc.Inject(a))
addAccountPermission := req.NewPermission("account:add")
reqs := [...]*req.Conf{
// 获取个人账号的权限资源信息
req.NewGet("/permissions", a.GetPermissions),
req.NewPost("/change-pwd", a.ChangePassword).DontNeedToken().Log(req.NewLogSave("用户修改密码")),
// 获取个人账号信息
req.NewGet("/self", a.AccountInfo),
// 更新个人账号信息
req.NewPut("/self", a.UpdateAccount),
/** 后台管理接口 **/
// 获取所有用户列表
req.NewGet("", a.Accounts),
req.NewPost("", a.SaveAccount).Log(req.NewLogSave("保存账号信息")).RequiredPermission(addAccountPermission),
req.NewPut("change-status/:id/:status", a.ChangeStatus).Log(req.NewLogSave("修改账号状态")).RequiredPermission(addAccountPermission),
req.NewPut(":id/reset-otp", a.ResetOtpSecret).Log(req.NewLogSave("重置OTP密钥")).RequiredPermission(addAccountPermission),
req.NewDelete(":id", a.DeleteAccount).Log(req.NewLogSave("删除账号")).RequiredPermissionCode("account:del"),
// 关联用户角色
req.NewPost("/roles", a.RelateRole).Log(req.NewLogSave("关联用户角色")).RequiredPermissionCode("account:saveRoles"),
// 获取用户角色
req.NewGet(":id/roles", a.AccountRoles),
// 获取用户资源列表
req.NewGet(":id/resources", a.AccountResources),
}
req.BatchSetGroup(account, reqs[:])
}