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

import (
	"errors"
haoyanbin's avatar
haoyanbin committed
5
	"github.com/go-admin-team/go-admin-core/sdk/service"
haoyanbin's avatar
1  
haoyanbin committed
6 7
	"gorm.io/gorm"

haoyanbin's avatar
haoyanbin committed
8
	"go-admin/app/mobile/service/dto"
haoyanbin's avatar
1  
haoyanbin committed
9
	"go-admin/app/operate/models"
haoyanbin's avatar
1  
haoyanbin committed
10 11 12 13 14 15 16 17
	"go-admin/common/actions"
)

type OrgLeague struct {
	service.Service
}

// GetPage 获取OrgLeague列表
haoyanbin's avatar
haoyanbin committed
18
func (e *OrgLeague) GetPage(c *dto.OrgLeagueGetPageReq, p *actions.DataPermission, list *[]dto.OrgLeagueGetPageReply, count *int64) error {
haoyanbin's avatar
1  
haoyanbin committed
19 20
	var err error

haoyanbin's avatar
haoyanbin committed
21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48
	err = e.Orm.Table("org_match_team_player as omtp").
		Select("ol.id, ol.league_name").
		Joins("left join org_match as om on omtp.match_id = om.id and omtp.rounds = om.rounds").
		Joins("left join org_league as ol on ol.id = om.league_id").
		Where("ol.status=?", 1).
		Where("omtp.player_id=?", c.PlayerId).
		Group("om.league_id").
		Find(list).
		Count(count).Error
	if err != nil {
		e.Log.Errorf("OrgLeagueService GetPage error:%s \r\n", err)
		return err
	}
	return nil
}

// GetPage 获取OrgLeague列表
func (e *OrgLeague) GetPageForOwn(c *dto.OrgLeagueGetPageReq, p *actions.DataPermission, list *[]dto.OrgLeagueGetPageReply, count *int64) error {
	var err error

	err = e.Orm.Table("org_match_team_player as omtp").
		Select("ol.id, ol.league_name").
		Joins("left join org_match as om on omtp.match_id = om.id and omtp.rounds = om.rounds").
		Joins("left join org_league as ol on ol.id = om.league_id").
		Where("ol.status=?", 1).
		Where("omtp.player_id=?", c.PlayerId).
		Group("om.league_id").
		Find(list).
haoyanbin's avatar
1  
haoyanbin committed
49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79
		Count(count).Error
	if err != nil {
		e.Log.Errorf("OrgLeagueService GetPage error:%s \r\n", err)
		return err
	}
	return nil
}

// Get 获取OrgLeague对象
func (e *OrgLeague) Get(d *dto.OrgLeagueGetReq, p *actions.DataPermission, model *models.OrgLeague) error {
	var data models.OrgLeague

	err := e.Orm.Model(&data).
		Scopes(
			actions.Permission(data.TableName(), p),
		).
		First(model, d.GetId()).Error
	if err != nil && errors.Is(err, gorm.ErrRecordNotFound) {
		err = errors.New("查看对象不存在或无权查看")
		e.Log.Errorf("Service GetOrgLeague error:%s \r\n", err)
		return err
	}
	if err != nil {
		e.Log.Errorf("db error:%s", err)
		return err
	}
	return nil
}

// Insert 创建OrgLeague对象
func (e *OrgLeague) Insert(c *dto.OrgLeagueInsertReq) error {
haoyanbin's avatar
haoyanbin committed
80 81 82
	var err error
	var data models.OrgLeague
	c.Generate(&data)
haoyanbin's avatar
1  
haoyanbin committed
83 84 85 86 87 88 89 90 91 92
	err = e.Orm.Create(&data).Error
	if err != nil {
		e.Log.Errorf("OrgLeagueService Insert error:%s \r\n", err)
		return err
	}
	return nil
}

// Update 修改OrgLeague对象
func (e *OrgLeague) Update(c *dto.OrgLeagueUpdateReq, p *actions.DataPermission) error {
haoyanbin's avatar
haoyanbin committed
93 94 95 96 97 98
	var err error
	var data = models.OrgLeague{}
	e.Orm.Scopes(
		actions.Permission(data.TableName(), p),
	).First(&data, c.GetId())
	c.Generate(&data)
haoyanbin's avatar
1  
haoyanbin committed
99

haoyanbin's avatar
haoyanbin committed
100 101 102 103 104 105 106 107 108
	db := e.Orm.Save(&data)
	if db.Error != nil {
		e.Log.Errorf("OrgLeagueService Save error:%s \r\n", err)
		return err
	}
	if db.RowsAffected == 0 {
		return errors.New("无权更新该数据")
	}
	return nil
haoyanbin's avatar
1  
haoyanbin committed
109 110 111 112 113 114 115 116 117 118 119
}

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

	db := e.Orm.Model(&data).
		Scopes(
			actions.Permission(data.TableName(), p),
		).Delete(&data, d.GetId())
	if err := db.Error; err != nil {
haoyanbin's avatar
haoyanbin committed
120 121 122 123 124 125
		e.Log.Errorf("Service RemoveOrgLeague error:%s \r\n", err)
		return err
	}
	if db.RowsAffected == 0 {
		return errors.New("无权删除该数据")
	}
haoyanbin's avatar
1  
haoyanbin committed
126
	return nil
haoyanbin's avatar
haoyanbin committed
127
}