fonchain-artistinfo/cmd/internal/dao/artistinfo_artshow_video.go

137 lines
3.9 KiB
Go
Raw Normal View History

// Package dao -----------------------------
// @file : artistinfo_artshow.go
// @author : JJXu
// @contact : wavingbear@163.com
// @time : 2023/3/2 12:06
// -------------------------------------------
package dao
import (
2023-03-02 09:22:10 +00:00
"errors"
2023-03-28 05:51:44 +00:00
"github.com/fonchain/fonchain-artistinfo/cmd/model"
"github.com/fonchain/fonchain-artistinfo/pb/artistinfoArtshow"
db "github.com/fonchain/fonchain-artistinfo/pkg/db"
2023-03-02 09:22:10 +00:00
"gorm.io/gorm"
)
var ArtistinfoArtshowVideo = new(artistinfoArtshowVideo)
type artistinfoArtshowVideo struct{}
2023-03-03 07:28:55 +00:00
func (a artistinfoArtshowVideo) BatchCreateData(datas []model.ArtshowVideoRecord) error {
2023-03-02 09:22:10 +00:00
//return db.DB.Create(&datas).Error
tx := db.DB.Begin()
for _, v := range datas {
err := a.CreateData(&v, tx)
if err != nil {
return err
}
}
tx.Commit()
return nil
}
2023-03-03 07:28:55 +00:00
func (a artistinfoArtshowVideo) CreateData(data *model.ArtshowVideoRecord, tx ...*gorm.DB) error {
2023-03-02 09:22:10 +00:00
var txdb *gorm.DB
if tx != nil {
txdb = tx[0]
} else {
txdb = db.DB
}
2023-03-03 07:28:55 +00:00
var exist = model.ArtshowVideoRecord{}
2023-03-02 09:22:10 +00:00
db.DB.Where("artist_uid = ? AND status = 2", data.ArtistUid).Find(&exist)
if exist.ID != 0 {
return errors.New("数据已存在")
}
return txdb.Create(&data).Error
}
2023-03-03 07:28:55 +00:00
func (a artistinfoArtshowVideo) UpdateData(data *model.ArtshowVideoRecord) error {
2023-03-03 01:12:26 +00:00
return db.DB.Updates(&data).Error
}
func (a artistinfoArtshowVideo) DeletedData(id ...int64) (err error) {
if len(id) == 1 {
2023-03-03 07:28:55 +00:00
err = db.DB.Where("id = ?", id[0]).Delete(&model.ArtshowVideoRecord{}).Error
} else if len(id) > 0 {
2023-03-03 07:28:55 +00:00
err = db.DB.Where("id = ?", id).Delete(&model.ArtshowVideoRecord{}).Error
}
return err
}
2023-03-03 07:28:55 +00:00
func (a artistinfoArtshowVideo) GetData(id int64) (data *model.ArtshowVideoRecord, err error) {
err = db.DB.Where("id = ?", id).First(data).Error
return
}
2023-03-03 07:28:55 +00:00
func (a artistinfoArtshowVideo) GetDataList(req *artistinfoArtshow.GetArtshowVideoListRequst) (datas []model.ArtshowVideoRecord, total int64, err error) {
datas = []model.ArtshowVideoRecord{}
var tx = db.DB.Model(model.ArtshowVideoRecord{})
if req.ArtistUid != "" {
tx = tx.Where("artist_uid = ?", req.ArtistUid)
}
if req.LockTime != "" {
tx = tx.Where("lock_time = ?", req.LockTime)
}
if req.ArtistName != "" {
2023-03-28 05:51:44 +00:00
// tx = tx.Clauses(clause.Like{
// Column: "artist_name",
// Value: "%" + req.ArtistName + "%",
// })
var searchName = "%" + req.ArtistName + "%"
tx = tx.Where("artist_name LIKE ? OR artist_uid LIKE ?", searchName, searchName)
}
2023-03-02 09:22:10 +00:00
if req.Status != 0 {
tx = tx.Where("status = ?", req.Status)
}
//if req.VideoUrl != "" {
// tx = tx.Where("video_url = ?", req.VideoUrl)
//}
if req.AuditStatus != 0 {
tx = tx.Where("audit_status = ?", req.AuditStatus)
}
//if req.AuditMark1 != "" {
// tx = tx.Where("audit_mark1 = ?", req.AuditMark1)
//}
//if req.AuditMark2 != "" {
// tx = tx.Where("audit_mark2 = ?", req.AuditMark2)
//}
err = tx.Count(&total).Scopes(db.Pagination(req.Page, req.PageSize)).Find(&datas).Error
return
}
2023-03-03 01:12:26 +00:00
func (a artistinfoArtshowVideo) Audit(auditStatus model.AuditStatus, mark1, mark2 string, ids ...int64) (err error) {
tx := db.DB.Begin()
2023-03-03 07:28:55 +00:00
err = tx.Model(model.ArtshowVideoRecord{}).Where("id in ?", ids).Update("audit_status", auditStatus).Error
2023-03-03 01:12:26 +00:00
if err != nil {
return err
}
2023-03-03 07:28:55 +00:00
err = tx.Model(model.ArtshowVideoRecord{}).Where("id in ?", ids).Update("audit_mark1", mark1).Error
2023-03-03 01:12:26 +00:00
if err != nil {
return err
}
2023-03-03 07:28:55 +00:00
err = tx.Model(model.ArtshowVideoRecord{}).Where("id in ?", ids).Update("audit_mark2", mark2).Error
2023-03-03 01:12:26 +00:00
if err != nil {
return err
}
tx.Commit()
return
}
2023-03-03 07:28:55 +00:00
func (a artistinfoArtshowVideo) GetArtshowVideoDetail(in *artistinfoArtshow.GetArtshowVideoDetailRequest) (rep model.ArtshowVideoRecord, err error) {
var tx = db.DB.Model(model.ArtshowVideoRecord{})
//if in.ArtistUid != "" {
// tx = tx.Where("artist_uid =?", in.ArtistUid)
//}
//if in.LockTime != "" {
// tx = tx.Where("lock_time = ?", in.LockTime)
//}
//if in.Status != 0 {
// tx = tx.Where("status = ?", in.Status)
//}
if in.Id != 0 {
tx = tx.Where("id = ?", in.Id)
2023-03-03 01:12:26 +00:00
}
2023-03-03 07:28:55 +00:00
err = tx.First(&rep).Error
2023-03-03 01:12:26 +00:00
return
}