createRoleLogic.go 1.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960
  1. package role
  2. import (
  3. "context"
  4. "strings"
  5. "time"
  6. "perms-system-server/internal/consts"
  7. authHelper "perms-system-server/internal/logic/auth"
  8. roleModel "perms-system-server/internal/model/role"
  9. "perms-system-server/internal/response"
  10. "perms-system-server/internal/svc"
  11. "perms-system-server/internal/types"
  12. "github.com/zeromicro/go-zero/core/logx"
  13. )
  14. type CreateRoleLogic struct {
  15. logx.Logger
  16. ctx context.Context
  17. svcCtx *svc.ServiceContext
  18. }
  19. func NewCreateRoleLogic(ctx context.Context, svcCtx *svc.ServiceContext) *CreateRoleLogic {
  20. return &CreateRoleLogic{
  21. Logger: logx.WithContext(ctx),
  22. ctx: ctx,
  23. svcCtx: svcCtx,
  24. }
  25. }
  26. func (l *CreateRoleLogic) CreateRole(req *types.CreateRoleReq) (resp *types.IdResp, err error) {
  27. if err := authHelper.RequireProductAdminFor(l.ctx, req.ProductCode); err != nil {
  28. return nil, err
  29. }
  30. if req.PermsLevel < 1 || req.PermsLevel > 999 {
  31. return nil, response.ErrBadRequest("权限级别必须在 1-999 之间")
  32. }
  33. now := time.Now().Unix()
  34. result, err := l.svcCtx.SysRoleModel.Insert(l.ctx, &roleModel.SysRole{
  35. ProductCode: req.ProductCode,
  36. Name: req.Name,
  37. Remark: req.Remark,
  38. Status: consts.StatusEnabled,
  39. PermsLevel: req.PermsLevel,
  40. CreateTime: now,
  41. UpdateTime: now,
  42. })
  43. if err != nil {
  44. if strings.Contains(err.Error(), "1062") || strings.Contains(err.Error(), "Duplicate entry") {
  45. return nil, response.ErrConflict("该产品下角色名已存在")
  46. }
  47. return nil, err
  48. }
  49. id, _ := result.LastInsertId()
  50. return &types.IdResp{Id: id}, nil
  51. }