refactor: service module and dao module
This commit is contained in:
@@ -0,0 +1,60 @@
|
||||
package dao
|
||||
|
||||
import (
|
||||
"crm/global"
|
||||
"crm/models"
|
||||
"time"
|
||||
)
|
||||
|
||||
const (
|
||||
Read = 1 // 已读
|
||||
UnRead = 2 // 未读
|
||||
)
|
||||
|
||||
type NoticeDao struct {
|
||||
}
|
||||
|
||||
func NewNoticeDao() *NoticeDao {
|
||||
return &NoticeDao{}
|
||||
}
|
||||
|
||||
func (n *NoticeDao) Create(param *models.NoticeCreateParam) error {
|
||||
notice := models.Notice{
|
||||
Content: param.Content,
|
||||
Status: UnRead,
|
||||
Creator: param.Creator,
|
||||
Created: time.Now().Unix(),
|
||||
}
|
||||
return global.Db.Create(¬ice).Error
|
||||
}
|
||||
|
||||
func (n *NoticeDao) Update(param *models.NoticeUpdateParam) error {
|
||||
notice := models.Notice{
|
||||
Id: param.Id,
|
||||
Status: Read,
|
||||
Updated: time.Now().Unix(),
|
||||
}
|
||||
return global.Db.Model(¬ice).Updates(¬ice).Error
|
||||
}
|
||||
|
||||
func (n *NoticeDao) GetUnReadCountByUid(uid int64) (models.UnReadNotice, error) {
|
||||
var unRead models.UnReadNotice
|
||||
raw := "select count(*) from notice where status = 2 and creator = ?"
|
||||
if err := global.Db.Raw(raw, uid).Scan(&unRead.Count).Error; err != nil {
|
||||
return unRead, err
|
||||
}
|
||||
return unRead, nil
|
||||
}
|
||||
|
||||
func (n *NoticeDao) Delete(param *models.NoticeDeleteParam) error {
|
||||
return global.Db.Delete(&models.Notice{}, param.Ids).Error
|
||||
}
|
||||
|
||||
func (n *NoticeDao) GetList(uid int64) ([]*models.NoticeList, error) {
|
||||
noticeList := make([]*models.NoticeList, 0)
|
||||
db := global.Db.Table(NOTICE).Where("creator = ?", uid)
|
||||
if err := db.Order("status desc").Order("created desc").Find(¬iceList).Error; err != nil {
|
||||
return nil, err
|
||||
}
|
||||
return noticeList, nil
|
||||
}
|
||||
Reference in New Issue
Block a user