| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170 |
- /*
- * @desc:部门管理
- * @company:云南奇讯科技有限公司
- * @Author: yixiaohu<yxh669@qq.com>
- * @Date: 2022/4/6 15:19
- */
- package service
- import (
- "context"
- "github.com/gogf/gf/v2/frame/g"
- "github.com/gogf/gf/v2/text/gstr"
- "github.com/gogf/gf/v2/util/gconv"
- "github.com/tiger1103/gfast/v3/api/v1/system"
- commonService "github.com/tiger1103/gfast/v3/internal/app/common/service"
- "github.com/tiger1103/gfast/v3/internal/app/system/consts"
- "github.com/tiger1103/gfast/v3/internal/app/system/model"
- "github.com/tiger1103/gfast/v3/internal/app/system/model/entity"
- "github.com/tiger1103/gfast/v3/internal/app/system/service/internal/dao"
- "github.com/tiger1103/gfast/v3/internal/app/system/service/internal/do"
- "github.com/tiger1103/gfast/v3/library/liberr"
- )
- type IDept interface {
- GetList(ctx context.Context, req *system.DeptSearchReq) (list []*entity.SysDept, err error)
- Add(ctx context.Context, req *system.DeptAddReq) (err error)
- Edit(ctx context.Context, req *system.DeptEditReq) (err error)
- GetFromCache(ctx context.Context) (list []*entity.SysDept, err error)
- Delete(ctx context.Context, id int64) (err error)
- GetListTree(pid int64, list []*entity.SysDept) (deptTree []*model.SysDeptTreeRes)
- FindSonByParentId(deptList []*entity.SysDept, deptId int64) []*entity.SysDept
- }
- var deptService = deptImpl{}
- func Dept() IDept {
- return IDept(&deptService)
- }
- type deptImpl struct {
- }
- func (s *deptImpl) GetList(ctx context.Context, req *system.DeptSearchReq) (list []*entity.SysDept, err error) {
- list, err = s.GetFromCache(ctx)
- if err != nil {
- return
- }
- rList := make([]*entity.SysDept, 0, len(list))
- if req.DeptName != "" || req.Status != "" {
- for _, v := range list {
- if req.DeptName != "" && !gstr.ContainsI(v.DeptName, req.DeptName) {
- continue
- }
- if req.Status != "" && v.Status != gconv.Uint(req.Status) {
- continue
- }
- rList = append(rList, v)
- }
- list = rList
- }
- return
- }
- func (s *deptImpl) GetFromCache(ctx context.Context) (list []*entity.SysDept, err error) {
- err = g.Try(func() {
- cache := commonService.Cache()
- //从缓存获取
- iList := cache.GetOrSetFuncLock(ctx, consts.CacheSysDept, func(ctx context.Context) (value interface{}, err error) {
- err = dao.SysDept.Ctx(ctx).Scan(&list)
- liberr.ErrIsNil(ctx, err, "获取部门列表失败")
- value = list
- return
- }, 0, consts.CacheSysAuthTag)
- if iList != nil {
- err = gconv.Struct(iList, &list)
- liberr.ErrIsNil(ctx, err)
- }
- })
- return
- }
- // Add 添加部门
- func (s *deptImpl) Add(ctx context.Context, req *system.DeptAddReq) (err error) {
- err = g.Try(func() {
- _, err = dao.SysDept.Ctx(ctx).Insert(do.SysDept{
- ParentId: req.ParentID,
- DeptName: req.DeptName,
- OrderNum: req.OrderNum,
- Leader: req.Leader,
- Phone: req.Phone,
- Email: req.Email,
- Status: req.Status,
- CreatedBy: Context().GetUserId(ctx),
- })
- liberr.ErrIsNil(ctx, err, "添加部门失败")
- // 删除缓存
- commonService.Cache().RemoveByTag(ctx, consts.CacheSysAuthTag)
- })
- return
- }
- // Edit 部门修改
- func (s *deptImpl) Edit(ctx context.Context, req *system.DeptEditReq) (err error) {
- err = g.Try(func() {
- _, err = dao.SysDept.Ctx(ctx).WherePri(req.DeptId).Update(do.SysDept{
- ParentId: req.ParentID,
- DeptName: req.DeptName,
- OrderNum: req.OrderNum,
- Leader: req.Leader,
- Phone: req.Phone,
- Email: req.Email,
- Status: req.Status,
- UpdatedBy: Context().GetUserId(ctx),
- })
- liberr.ErrIsNil(ctx, err, "修改部门失败")
- // 删除缓存
- commonService.Cache().RemoveByTag(ctx, consts.CacheSysAuthTag)
- })
- return
- }
- func (s *deptImpl) Delete(ctx context.Context, id int64) (err error) {
- err = g.Try(func() {
- var list []*entity.SysDept
- err = dao.SysDept.Ctx(ctx).Scan(&list)
- liberr.ErrIsNil(ctx, err, "不存在部门信息")
- children := s.FindSonByParentId(list, id)
- ids := make([]int64, 0, len(list))
- for _, v := range children {
- ids = append(ids, v.DeptId)
- }
- ids = append(ids, id)
- _, err = dao.SysDept.Ctx(ctx).Where(dao.SysDept.Columns().DeptId+" in (?)", ids).Delete()
- liberr.ErrIsNil(ctx, err, "删除部门失败")
- // 删除缓存
- commonService.Cache().RemoveByTag(ctx, consts.CacheSysAuthTag)
- })
- return
- }
- func (s *deptImpl) FindSonByParentId(deptList []*entity.SysDept, deptId int64) []*entity.SysDept {
- children := make([]*entity.SysDept, 0, len(deptList))
- for _, v := range deptList {
- if v.ParentId == deptId {
- children = append(children, v)
- fChildren := s.FindSonByParentId(deptList, v.DeptId)
- children = append(children, fChildren...)
- }
- }
- return children
- }
- // GetListTree 部门树形菜单
- func (s *deptImpl) GetListTree(pid int64, list []*entity.SysDept) (deptTree []*model.SysDeptTreeRes) {
- deptTree = make([]*model.SysDeptTreeRes, 0, len(list))
- for _, v := range list {
- if v.ParentId == pid {
- t := &model.SysDeptTreeRes{
- SysDept: v,
- }
- child := s.GetListTree(v.DeptId, list)
- if len(child) > 0 {
- t.Children = child
- }
- deptTree = append(deptTree, t)
- }
- }
- return
- }
|