createDeptLogic.go 2.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102
  1. package dept
  2. import (
  3. "context"
  4. "fmt"
  5. "time"
  6. "perms-system-server/internal/consts"
  7. authHelper "perms-system-server/internal/logic/auth"
  8. deptModel "perms-system-server/internal/model/dept"
  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. "github.com/zeromicro/go-zero/core/stores/sqlx"
  14. )
  15. type CreateDeptLogic struct {
  16. logx.Logger
  17. ctx context.Context
  18. svcCtx *svc.ServiceContext
  19. }
  20. func NewCreateDeptLogic(ctx context.Context, svcCtx *svc.ServiceContext) *CreateDeptLogic {
  21. return &CreateDeptLogic{
  22. Logger: logx.WithContext(ctx),
  23. ctx: ctx,
  24. svcCtx: svcCtx,
  25. }
  26. }
  27. // CreateDept 创建部门。在指定父部门下新建子部门,自动继承路径层级。仅超管可调用。
  28. func (l *CreateDeptLogic) CreateDept(req *types.CreateDeptReq) (resp *types.IdResp, err error) {
  29. if err := authHelper.RequireSuperAdmin(l.ctx); err != nil {
  30. return nil, err
  31. }
  32. if len(req.Name) > 64 {
  33. return nil, response.ErrBadRequest("部门名称长度不能超过64个字符")
  34. }
  35. if len(req.Remark) > 255 {
  36. return nil, response.ErrBadRequest("备注长度不能超过255个字符")
  37. }
  38. parentPath := "/"
  39. if req.ParentId > 0 {
  40. parent, err := l.svcCtx.SysDeptModel.FindOne(l.ctx, req.ParentId)
  41. if err != nil {
  42. return nil, response.ErrNotFound("父部门不存在")
  43. }
  44. parentPath = parent.Path
  45. }
  46. now := time.Now().Unix()
  47. var deptId int64
  48. deptType := req.DeptType
  49. if deptType == "" {
  50. deptType = consts.DeptTypeNormal
  51. } else if deptType != consts.DeptTypeNormal && deptType != consts.DeptTypeDev {
  52. return nil, response.ErrBadRequest("无效的部门类型")
  53. }
  54. err = l.svcCtx.SysDeptModel.TransactCtx(l.ctx, func(ctx context.Context, session sqlx.Session) error {
  55. if req.ParentId > 0 {
  56. var lockId int64
  57. lockQ := fmt.Sprintf("SELECT `id` FROM %s WHERE `id` = ? FOR SHARE", l.svcCtx.SysDeptModel.TableName())
  58. if err := session.QueryRowCtx(ctx, &lockId, lockQ, req.ParentId); err != nil {
  59. return response.ErrNotFound("父部门已被删除")
  60. }
  61. }
  62. result, err := l.svcCtx.SysDeptModel.InsertWithTx(ctx, session, &deptModel.SysDept{
  63. ParentId: req.ParentId,
  64. Name: req.Name,
  65. Path: parentPath,
  66. Sort: req.Sort,
  67. DeptType: deptType,
  68. Remark: req.Remark,
  69. Status: consts.StatusEnabled,
  70. CreateTime: now,
  71. UpdateTime: now,
  72. })
  73. if err != nil {
  74. return err
  75. }
  76. deptId, _ = result.LastInsertId()
  77. d, err := l.svcCtx.SysDeptModel.FindOneWithTx(ctx, session, deptId)
  78. if err != nil {
  79. return err
  80. }
  81. d.Path = fmt.Sprintf("%s%d/", parentPath, deptId)
  82. return l.svcCtx.SysDeptModel.UpdateWithTx(ctx, session, d)
  83. })
  84. if err != nil {
  85. return nil, err
  86. }
  87. return &types.IdResp{Id: deptId}, nil
  88. }