182 lines
4.4 KiB
Go
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
|
||
|
}
|