| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140 |
- package service
- import (
- "context"
- "dashoo.cn/micro/app/dao"
- "dashoo.cn/micro/app/model"
- "dashoo.cn/opms_libary/myerrors"
- "github.com/gogf/gf/database/gdb"
- "github.com/gogf/gf/frame/g"
- "github.com/gogf/gf/util/gconv"
- )
- type PostService struct {
- *contextService
- Dao *dao.SysPostDao
- postRoleDao *dao.SysPostRoleDao
- }
- func NewPostService(ctx context.Context) (svc *PostService, err error) {
- svc = new(PostService)
- if svc.contextService, err = svc.Init(ctx); err != nil {
- return nil, err
- }
- svc.Dao = dao.NewSysPostDao(svc.Tenant)
- svc.postRoleDao = dao.NewSysPostRoleDao(svc.Tenant)
- return svc, nil
- }
- func (s *PostService) GetList(req *model.SysPostSearchParams) (total int, list []*model.SysPost, err error) {
- db := s.Dao.M
- if req != nil {
- if req.PostCode != "" {
- db = db.WhereLike(s.Dao.C.PostCode, req.PostCode)
- }
- if req.PostName != "" {
- db = db.WhereLike(s.Dao.C.PostName, req.PostName)
- }
- if req.Status != "" {
- db = db.Where(s.Dao.C.Status, req.Status)
- }
- }
- total, err = db.Count()
- if err != nil {
- g.Log().Error(err)
- err = myerrors.TipsError("获取总行数失败")
- }
- err = db.Page(req.GetPage()).OrderAsc(s.Dao.C.Sort).Scan(&list)
- if err != nil {
- g.Log().Error(err)
- err = myerrors.TipsError("获取数据失败")
- }
- return
- }
- func (s *PostService) GetEntity(id int64) (post *model.SysPostRes, err error) {
- post = new(model.SysPostRes)
- err = s.Dao.WherePri(id).Scan(&post.SysPost)
- if err != nil {
- return nil, err
- }
- result, err := s.postRoleDao.Fields(dao.SysPostRole.C.RoleId).WherePri(dao.SysPostRole.C.PostId, id).Array()
- if err != nil {
- return nil, err
- }
- post.RoleIds = gconv.Ints(result)
- return
- }
- // GetEntityNameByIds根据ID获取名称
- func (s *PostService) GetEntityNameByIds(ids []int) ([]string, error) {
- result, err := s.Dao.WhereIn(s.Dao.C.Id, ids).Fields(s.Dao.C.PostName).Array()
- return gconv.Strings(result), err
- }
- func (s *PostService) Create(params *model.SysPostReq) error {
- data := new(model.SysPost)
- if err := gconv.Struct(params, data); err != nil {
- return err
- }
- SetCreatedInfo(data, s.GetCxtUserId(), s.GetCxtUserName())
- err := s.Dao.Transaction(context.TODO(), func(ctx context.Context, tx *gdb.TX) error {
- lastId, err := s.Dao.TX(tx).InsertAndGetId(data)
- if err != nil {
- return err
- }
- err = s.AddPostRole(lastId, params.RoleIds, tx)
- return err
- })
- return err
- }
- // AddPostRole 添加岗位角色
- func (s *PostService) AddPostRole(postId int64, roleIds []int, tx *gdb.TX) (err error) {
- //删除旧岗位角色信息
- _, err = s.postRoleDao.TX(tx).Where(dao.SysPostRole.C.PostId, postId).Delete()
- if err != nil {
- return
- }
- if len(roleIds) == 0 {
- return
- }
- //添加岗位角色
- data := g.List{}
- for _, v := range roleIds {
- data = append(data, g.Map{
- dao.SysPostRole.C.PostId: postId,
- dao.SysPostRole.C.RoleId: v,
- })
- }
- _, err = s.postRoleDao.TX(tx).Data(data).Insert()
- if err != nil {
- return
- }
- return
- }
- func (s *PostService) UpdateById(params *model.UpdateSysPostReq) (err error) {
- data := new(model.SysPost)
- if err := gconv.Struct(params, data); err != nil {
- return err
- }
- SetUpdatedInfo(data, s.GetCxtUserId(), s.GetCxtUserName())
- err = s.Dao.Transaction(context.TODO(), func(ctx context.Context, tx *gdb.TX) error {
- _, err := s.Dao.FieldsEx(UpdateFieldEx...).WherePri(params.Id).Update(data)
- if err != nil {
- return err
- }
- err = s.AddPostRole(params.Id, params.RoleIds, tx)
- return err
- })
- return err
- }
- func (s *PostService) DeleteByIds(ids []int64) error {
- _, err := s.Dao.WhereIn(s.Dao.C.Id, ids).Delete()
- return err
- }
|