bilibili-backup/app/admin/main/apm/dao/need.go
2019-04-22 02:59:20 +00:00

182 lines
4.4 KiB
Go

package dao
import (
"fmt"
"go-common/app/admin/main/apm/model/need"
"go-common/library/log"
"github.com/pkg/errors"
)
const (
_tableNeed = "needs"
_tableLike = "user_likes"
_addCountsSQL = "UPDATE needs SET like_counts=like_counts+?,dislike_counts=dislike_counts+? WHERE id=?"
)
//NeedInfoAdd add need info
func (d *Dao) NeedInfoAdd(r *need.NAddReq, username string) (err error) {
ni := &need.NInfo{
Title: r.Title,
Content: r.Content,
Reporter: username,
Status: 1,
}
if err = d.DB.Create(&ni).Error; err != nil {
err = errors.WithStack(err)
return
}
return
}
//NeedInfoList all need info
func (d *Dao) NeedInfoList(arg *need.NListReq) (res []*need.NInfo, err error) {
where := d.needInfoCondition(arg)
if err = d.DB.Table(_tableNeed).Where(where).Order("id DESC").Offset((arg.Pn - 1) * arg.Ps).Limit(arg.Ps).Find(&res).Error; err != nil {
err = errors.WithStack(err)
log.Error("NeedInfoList:%s", err)
return
}
return
}
//NeedInfoCount need info count
func (d *Dao) NeedInfoCount(arg *need.NListReq) (count int64, err error) {
where := d.needInfoCondition(arg)
if err = d.DB.Table(_tableNeed).Where(where).Count(&count).Error; err != nil {
log.Error("NeedInfoCount:%s", err)
return
}
return
}
//needInfoCondition is
func (d *Dao) needInfoCondition(arg *need.NListReq) (where string) {
where = "status !=5"
if arg.Status > 0 {
where += fmt.Sprintf(" and `status`='%d'", arg.Status)
}
if arg.Reporter != "" {
where += fmt.Sprintf(" and `reporter`='%s'", arg.Reporter)
}
return where
}
// GetNeedInfo is
func (d *Dao) GetNeedInfo(id int64) (r *need.NInfo, err error) {
r = &need.NInfo{}
if err = d.DB.Table(_tableNeed).Where("id=?", id).Find(r).Error; err != nil {
log.Error("GetNeedInfo:%s", err)
return
}
return
}
//NeedInfoEdit is
func (d *Dao) NeedInfoEdit(arg *need.NEditReq) (err error) {
if err = d.DB.Table(_tableNeed).Where("id=?", arg.ID).Updates(map[string]interface{}{"content": arg.Content, "title": arg.Title}).Error; err != nil {
log.Error("NeedInfoEdit:%s", err)
return
}
return
}
//NeedVerify is
func (d *Dao) NeedVerify(r *need.NVerifyReq) (err error) {
tx := d.DB.Begin()
if err = d.DB.Table(_tableNeed).Where("id=?", r.ID).Update("status", r.Status).Error; err != nil {
log.Error("NeedVerify:%s", err)
tx.Rollback()
return
}
tx.Commit()
return
}
//LikeCountsStats thumbsup counts
func (d *Dao) LikeCountsStats(r *need.Likereq, like, dislike int) (err error) {
tx := d.DB.Begin()
if err = d.DB.Exec(_addCountsSQL, like, dislike, r.ReqID).Error; err != nil {
err = errors.WithStack(err)
log.Error("LikeCountsStats:%s", err)
tx.Rollback()
return
}
tx.Commit()
return
}
//GetVoteInfo is
func (d *Dao) GetVoteInfo(r *need.Likereq, username string) (u *need.UserLikes, err error) {
u = &need.UserLikes{}
if err = d.DB.Table(_tableLike).Where("req_id=? and `user`=?", r.ReqID, username).Find(u).Error; err != nil {
err = errors.WithStack(err)
return
}
return
}
//UpdateVoteInfo is
func (d *Dao) UpdateVoteInfo(r *need.Likereq, username string) (err error) {
if err = d.DB.Table(_tableLike).Where("req_id=? and `user`=?", r.ReqID, username).Update("like_type", r.LikeType).Error; err != nil {
err = errors.WithStack(err)
log.Error("UpdateVoteInfo:%s", err)
return
}
return
}
//AddVoteInfo is
func (d *Dao) AddVoteInfo(r *need.Likereq, username string) (err error) {
ul := &need.UserLikes{
ReqID: r.ReqID,
User: username,
LikeType: r.LikeType,
}
if err = d.DB.Create(&ul).Error; err != nil {
err = errors.WithStack(err)
return
}
return
}
//voteInfoCondition is
func (d *Dao) voteInfoCondition(arg *need.Likereq) (where string) {
where = " like_type != 0 "
if arg.ReqID > 0 {
where += fmt.Sprintf(" and `req_id`='%d'", arg.ReqID)
}
if arg.LikeType > 0 {
where += fmt.Sprintf(" and `like_type`='%d'", arg.LikeType)
}
return where
}
//VoteInfoList is vote info
func (d *Dao) VoteInfoList(arg *need.Likereq) (res []*need.UserLikes, err error) {
where := d.voteInfoCondition(arg)
if err = d.DB.Table(_tableLike).Where(where).Find(&res).Error; err != nil {
err = errors.WithStack(err)
log.Error("VoteInfoList:%s", err)
return
}
return
}
//VoteInfoCounts vote info count
func (d *Dao) VoteInfoCounts(arg *need.Likereq) (count int64, err error) {
where := d.voteInfoCondition(arg)
if err = d.DB.Table(_tableLike).Where(where).Count(&count).Error; err != nil {
log.Error("VoteInfoCount:%s", err)
return
}
return
}