org_team_user.go 3.79 KB
Newer Older
haoyanbin's avatar
1  
haoyanbin committed
1 2 3 4
package service

import (
	"errors"
haoyanbin's avatar
haoyanbin committed
5
	"strconv"
haoyanbin's avatar
1  
haoyanbin committed
6

haoyanbin's avatar
1  
haoyanbin committed
7
	"github.com/go-admin-team/go-admin-core/sdk/service"
haoyanbin's avatar
1  
haoyanbin committed
8 9
	"gorm.io/gorm"

haoyanbin's avatar
1  
haoyanbin committed
10 11
	"go-admin/app/operate/models"
	"go-admin/app/operate/service/dto"
haoyanbin's avatar
1  
haoyanbin committed
12 13 14 15 16 17 18 19 20
	"go-admin/common/actions"
	cDto "go-admin/common/dto"
)

type OrgTeamUser struct {
	service.Service
}

// GetPage 获取OrgTeamUser列表
haoyanbin's avatar
1  
haoyanbin committed
21
func (e *OrgTeamUser) GetPage(c *dto.OrgTeamUserGetPageReq, p *actions.DataPermission, list *[]dto.OrgTeamUserGetPageReply, count *int64) error {
haoyanbin's avatar
1  
haoyanbin committed
22 23
	var err error
	var data models.OrgTeamUser
haoyanbin's avatar
1  
haoyanbin committed
24
	field := "otu.id, oc.club_name, ot.team_name, otu.name, otu.sex, sr.role_name, su.status"
haoyanbin's avatar
1  
haoyanbin committed
25

haoyanbin's avatar
1  
haoyanbin committed
26 27
	err = e.Orm.Table("org_team_user as otu").
		Select(field).
haoyanbin's avatar
1  
haoyanbin committed
28 29 30 31
		Joins("left join org_team as ot on otu.team_id=ot.id").
		Joins("left join org_club as oc on otu.club_id=oc.id").
		Joins("left join sys_user as su on otu.user_id=su.user_id").
		Joins("left join sys_role as sr on su.role_id=sr.role_id").
haoyanbin's avatar
1  
haoyanbin committed
32 33 34 35
		Scopes(
			cDto.MakeCondition(c.GetNeedSearch()),
			cDto.Paginate(c.GetPageSize(), c.GetPageIndex()),
			actions.Permission(data.TableName(), p),
haoyanbin's avatar
1  
haoyanbin committed
36
			cDto.PassDel("otu"),
haoyanbin's avatar
1  
haoyanbin committed
37 38 39 40 41 42 43 44 45 46 47
		).
		Find(list).Limit(-1).Offset(-1).
		Count(count).Error
	if err != nil {
		e.Log.Errorf("OrgTeamUserService GetPage error:%s \r\n", err)
		return err
	}
	return nil
}

// Get 获取OrgTeamUser对象
haoyanbin's avatar
1  
haoyanbin committed
48 49
func (e *OrgTeamUser) Get(d *dto.OrgTeamUserGetReq, p *actions.DataPermission, model *dto.OrgTeamUserGetReply) error {
	field := "otu.id,oc.club_name, otu.team_id, ot.team_name, otu.name, otu.sex, otu.user_img, otu.sign_img, sr.role_id, sr.role_name, su.username, su.status"
haoyanbin's avatar
1  
haoyanbin committed
50

haoyanbin's avatar
1  
haoyanbin committed
51 52
	err := e.Orm.Table("org_team_user as otu").
		Select(field).
haoyanbin's avatar
1  
haoyanbin committed
53 54 55 56
		Joins("left join org_team as ot on otu.team_id=ot.id").
		Joins("left join org_club as oc on otu.club_id=oc.id").
		Joins("left join sys_user as su on otu.user_id=su.user_id").
		Joins("left join sys_role as sr on su.role_id=sr.role_id").
haoyanbin's avatar
1  
haoyanbin committed
57 58 59 60 61 62 63 64 65 66 67 68 69 70 71
		First(model, d.GetId()).Error
	if err != nil && errors.Is(err, gorm.ErrRecordNotFound) {
		err = errors.New("查看对象不存在或无权查看")
		e.Log.Errorf("Service GetOrgTeamUser error:%s \r\n", err)
		return err
	}
	if err != nil {
		e.Log.Errorf("db error:%s", err)
		return err
	}
	return nil
}

// Insert 创建OrgTeamUser对象
func (e *OrgTeamUser) Insert(c *dto.OrgTeamUserInsertReq) error {
haoyanbin's avatar
1  
haoyanbin committed
72 73 74
	var err error
	var data models.OrgTeamUser
	c.Generate(&data)
haoyanbin's avatar
1  
haoyanbin committed
75 76 77 78 79
	err = e.Orm.Create(&data).Error
	if err != nil {
		e.Log.Errorf("OrgTeamUserService Insert error:%s \r\n", err)
		return err
	}
haoyanbin's avatar
haoyanbin committed
80 81

	c.Id = data.Id
haoyanbin's avatar
1  
haoyanbin committed
82 83 84 85 86
	return nil
}

// Update 修改OrgTeamUser对象
func (e *OrgTeamUser) Update(c *dto.OrgTeamUserUpdateReq, p *actions.DataPermission) error {
haoyanbin's avatar
1  
haoyanbin committed
87 88 89 90 91
	var err error
	var data = models.OrgTeamUser{}
	e.Orm.Scopes(
		actions.Permission(data.TableName(), p),
	).First(&data, c.GetId())
haoyanbin's avatar
haoyanbin committed
92
	userId := data.UserId
haoyanbin's avatar
1  
haoyanbin committed
93
	c.Generate(&data)
haoyanbin's avatar
haoyanbin committed
94
	db := e.Orm.Updates(&data)
haoyanbin's avatar
1  
haoyanbin committed
95 96 97 98 99 100 101
	if db.Error != nil {
		e.Log.Errorf("OrgTeamUserService Save error:%s \r\n", err)
		return err
	}
	if db.RowsAffected == 0 {
		return errors.New("无权更新该数据")
	}
haoyanbin's avatar
haoyanbin committed
102 103

	c.UserId = userId
haoyanbin's avatar
1  
haoyanbin committed
104
	return nil
haoyanbin's avatar
1  
haoyanbin committed
105 106 107 108 109 110 111 112 113 114 115
}

// Remove 删除OrgTeamUser
func (e *OrgTeamUser) Remove(d *dto.OrgTeamUserDeleteReq, p *actions.DataPermission) error {
	var data models.OrgTeamUser

	db := e.Orm.Model(&data).
		Scopes(
			actions.Permission(data.TableName(), p),
		).Delete(&data, d.GetId())
	if err := db.Error; err != nil {
haoyanbin's avatar
1  
haoyanbin committed
116 117 118 119 120 121
		e.Log.Errorf("Service RemoveOrgTeamUser error:%s \r\n", err)
		return err
	}
	if db.RowsAffected == 0 {
		return errors.New("无权删除该数据")
	}
haoyanbin's avatar
1  
haoyanbin committed
122
	return nil
haoyanbin's avatar
1  
haoyanbin committed
123
}
haoyanbin's avatar
haoyanbin committed
124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139

// GetPage 获取OrgTeamUser列表
func (e *OrgTeamUser) GetUserId(ids []int) (error, []int) {
	list := make([]models.OrgTeamUser, 0)
	field := "user_id"

	e.Orm.Select(field).Where("id IN(?)", ids).Find(&list)

	userIds := make([]int, 0)
	userid := 0
	for _, v := range list {
		userid, _ = strconv.Atoi(v.UserId)
		userIds = append(userIds, userid)
	}
	return nil, userIds
}