68 lines
		
	
	
		
			1.9 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			68 lines
		
	
	
		
			1.9 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| package admin_user
 | |
| 
 | |
| import (
 | |
| 	"context"
 | |
| 
 | |
| 	"aedata-server/app/main/api/internal/svc"
 | |
| 	"aedata-server/app/main/api/internal/types"
 | |
| 	"aedata-server/common/ctxdata"
 | |
| 	"aedata-server/common/xerr"
 | |
| 
 | |
| 	"github.com/Masterminds/squirrel"
 | |
| 	"github.com/pkg/errors"
 | |
| 	"github.com/zeromicro/go-zero/core/logx"
 | |
| )
 | |
| 
 | |
| type AdminUserInfoLogic struct {
 | |
| 	logx.Logger
 | |
| 	ctx    context.Context
 | |
| 	svcCtx *svc.ServiceContext
 | |
| }
 | |
| 
 | |
| func NewAdminUserInfoLogic(ctx context.Context, svcCtx *svc.ServiceContext) *AdminUserInfoLogic {
 | |
| 	return &AdminUserInfoLogic{
 | |
| 		Logger: logx.WithContext(ctx),
 | |
| 		ctx:    ctx,
 | |
| 		svcCtx: svcCtx,
 | |
| 	}
 | |
| }
 | |
| 
 | |
| func (l *AdminUserInfoLogic) AdminUserInfo(req *types.AdminUserInfoReq) (resp *types.AdminUserInfoResp, err error) {
 | |
| 	userId, err := ctxdata.GetUidFromCtx(l.ctx)
 | |
| 	if err != nil {
 | |
| 		return nil, errors.Wrapf(xerr.NewErrCode(xerr.SERVER_COMMON_ERROR), "获取用户ID失败, %+v", err)
 | |
| 	}
 | |
| 
 | |
| 	user, err := l.svcCtx.AdminUserModel.FindOne(l.ctx, userId)
 | |
| 	if err != nil {
 | |
| 		return nil, errors.Wrapf(xerr.NewErrCode(xerr.SERVER_COMMON_ERROR), "获取用户ID信息失败, %+v", err)
 | |
| 	}
 | |
| 	// 获取权限
 | |
| 	adminUserRoleBuilder := l.svcCtx.AdminUserRoleModel.SelectBuilder().Where(squirrel.Eq{"user_id": user.Id})
 | |
| 	permissions, err := l.svcCtx.AdminUserRoleModel.FindAll(l.ctx, adminUserRoleBuilder, "role_id DESC")
 | |
| 	if err != nil {
 | |
| 		return nil, errors.Wrapf(xerr.NewErrMsg("获取权限失败"), "用户登录, 获取权限失败, 用户名: %s", user.Username)
 | |
| 	}
 | |
| 
 | |
| 	// 获取角色ID数组
 | |
| 	roleIds := make([]int64, 0)
 | |
| 	for _, permission := range permissions {
 | |
| 		roleIds = append(roleIds, permission.RoleId)
 | |
| 	}
 | |
| 
 | |
| 	// 获取角色名称
 | |
| 	roles := make([]string, 0)
 | |
| 	for _, roleId := range roleIds {
 | |
| 		role, err := l.svcCtx.AdminRoleModel.FindOne(l.ctx, roleId)
 | |
| 		if err != nil {
 | |
| 			continue
 | |
| 		}
 | |
| 		roles = append(roles, role.RoleCode)
 | |
| 	}
 | |
| 	return &types.AdminUserInfoResp{
 | |
| 		Username: user.Username,
 | |
| 		RealName: user.RealName,
 | |
| 		Roles:    roles,
 | |
| 	}, nil
 | |
| }
 |