go-common/app/admin/main/usersuit/service/medal.go
2019-04-22 18:49:16 +08:00

329 lines
9.0 KiB
Go

package service
import (
"context"
"encoding/csv"
"fmt"
"io"
"mime/multipart"
"net/url"
"strconv"
"strings"
"github.com/pkg/errors"
"go-common/app/admin/main/usersuit/model"
accmdl "go-common/app/service/main/account/model"
"go-common/library/ecode"
"go-common/library/log"
"go-common/library/xstr"
)
// Medal medal .
func (s *Service) Medal(c context.Context) (res []*model.MedalInfo, err error) {
nps, err := s.d.Medal(c)
if err != nil {
log.Error("s.d.Medal error(%v)", err)
}
mgs, err := s.d.MedalGroup(c)
if err != nil {
log.Error("s.d.MedalGroup error(%v)", err)
}
res = make([]*model.MedalInfo, 0)
for _, np := range nps {
re := &model.MedalInfo{}
re.Medal = np
if _, ok := mgs[np.GID]; ok {
re.GroupName = mgs[np.GID].Name
if mgs[np.GID].PID != 0 {
re.ParentGroupName = mgs[mgs[np.GID].PID].Name
}
}
res = append(res, re)
}
return
}
// MedalView .
func (s *Service) MedalView(c context.Context, id int64) (res *model.MedalInfo, err error) {
res = &model.MedalInfo{}
res.Medal, err = s.d.MedalByID(c, id)
if err != nil {
log.Error("s.d.MedalByID(%d) error(%v)", id, err)
return
}
mgs, err := s.d.MedalGroup(c)
if err != nil {
log.Error("s.d.MedalGroup error(%v)", err)
return
}
if _, ok := mgs[res.Medal.GID]; ok {
res.GroupName = mgs[res.Medal.GID].Name
if _, ok1 := mgs[mgs[res.Medal.GID].PID]; ok && ok1 {
res.ParentGroupName = mgs[mgs[res.Medal.GID].PID].Name
}
}
return
}
func getImagePath(raw string) string {
uri, err := url.Parse(raw)
if err != nil {
return raw
}
return uri.Path
}
// AddMedal add medal .
func (s *Service) AddMedal(c context.Context, np *model.Medal) (err error) {
np.Image = getImagePath(np.Image)
np.ImageSmall = getImagePath(np.ImageSmall)
if _, err := s.d.AddMedal(c, np); err != nil {
log.Error("s.d.AddMedal error(%v)", err)
}
return
}
// UpMedal update medal .
func (s *Service) UpMedal(c context.Context, id int64, np *model.Medal) (err error) {
np.Image = getImagePath(np.Image)
np.ImageSmall = getImagePath(np.ImageSmall)
if _, err := s.d.UpMedal(c, id, np); err != nil {
log.Error("s.d.UpMedal error(%v)", err)
}
return
}
// MedalGroup medal group .
func (s *Service) MedalGroup(c context.Context) (res map[int64]*model.MedalGroup, err error) {
res, err = s.d.MedalGroup(c)
if err != nil {
log.Error("s.MedalGroup error(%v)", err)
}
return
}
// MedalGroupInfo medal group all info include parent group name .
func (s *Service) MedalGroupInfo(c context.Context) (res []*model.MedalGroup, err error) {
res, err = s.d.MedalGroupInfo(c)
if err != nil {
log.Error("s.MedalGroupInfo error(%v)", err)
}
return
}
// MedalGroupParent medal group all info include parent group name .
func (s *Service) MedalGroupParent(c context.Context) (res []*model.MedalGroup, err error) {
res, err = s.d.MedalGroupParent(c)
if err != nil {
log.Error("s.MedalGroupParent error(%v)", err)
}
return
}
// MedalGroupByGid nameplate by gid .
func (s *Service) MedalGroupByGid(c context.Context, id int64) (ng *model.MedalGroup, err error) {
if ng, err = s.d.MedalGroupByID(c, id); err != nil {
log.Error("s.MedalGroupByID error(%v)", err)
}
return
}
// MedalGroupAdd add medal group.
func (s *Service) MedalGroupAdd(c context.Context, ng *model.MedalGroup) (err error) {
if _, err := s.d.MedalGroupAdd(c, ng); err != nil {
log.Error("s.MedalGroupAdd error(%v)", err)
}
return
}
// MedalGroupUp update medal group.
func (s *Service) MedalGroupUp(c context.Context, id int64, ng *model.MedalGroup) (err error) {
if _, err := s.d.MedalGroupUp(c, id, ng); err != nil {
log.Error("s.MedalGroupUp error(%v)", err)
}
return
}
// MedalOwner medal onwer .
func (s *Service) MedalOwner(c context.Context, mid int64) (no []*model.MedalMemberMID, err error) {
if no, err = s.d.MedalOwner(c, mid); err != nil {
log.Error("s.d.MedalOwner error(%+v)", err)
}
return
}
// MedalOwnerAdd medal owner add .
func (s *Service) MedalOwnerAdd(c context.Context, mid, nid int64, title, msg string, oid int64) (err error) {
count, err := s.d.CountOwnerBYNidMid(c, mid, nid)
if count > 0 || err != nil {
err = ecode.MedalHasGet
return
}
if _, err = s.d.MedalOwnerAdd(c, mid, nid); err != nil {
log.Error("s.MedalOwnerAdd(mid:%d nid:%d) error(%v)", mid, nid, err)
return
}
if err = s.d.DelMedalOwnersCache(c, mid); err != nil {
log.Error("s.DelMedalOwnersCache(mid:%d) error(%v)", mid, err)
err = nil
}
var (
mids []int64
ismsg bool
action string
)
mids = append(mids, mid)
log.Error("MedalOwnerAdd title(%+v) msg(%+v)", title, msg)
if title != "" && msg != "" {
ismsg = true
if err = s.d.SendSysMsg(c, mids, title, msg, ""); err != nil {
log.Error("MedalOwnerAdd(mid:%d nid:%d title:%s msg:%s) SendSysMsg error(%+v)", mid, nid, title, msg, err)
err = nil
}
}
if oid > 0 {
mi, err := s.d.MedalByID(c, nid)
if err != nil {
log.Error("MedalByID(id:%d) error(%+v)", nid, err)
err = nil
}
action = fmt.Sprintf("激活勋章:%s,", mi.Name)
log.Error("MedalOwnerAdd ismsg(id:%d %+v) error(%+v)", nid, ismsg, err)
if ismsg {
action += fmt.Sprintf("并发送消息title:%s msg:%s", title, msg)
} else {
action += fmt.Sprintf("并没有发送消息")
}
s.d.AddMedalOperLog(c, oid, mid, nid, action)
}
return
}
// MedalOwnerAddList .
func (s *Service) MedalOwnerAddList(c context.Context, mid int64) (res []*model.MedalMemberAddList, err error) {
if res, err = s.d.MedalAddList(c, mid); err != nil {
log.Error("s.d.MedalOwnerAddList(%d) error(%v)", mid, err)
}
return
}
// MedalOwnerUpActivated update medal owner is_activated.
func (s *Service) MedalOwnerUpActivated(c context.Context, mid, nid int64) (err error) {
if _, err = s.d.MedalOwnerUpActivated(c, mid, nid); err != nil {
log.Error("s.d.UpMedalOwnerActivated(mid:%d nid:%d) error(%v)", mid, nid, err)
}
if _, err = s.d.MedalOwnerUpNotActivated(c, mid, nid); err != nil {
log.Error("s.d.UpMedalOwnerNotActivated(mid:%d nid:%d) error(%v)", mid, nid, err)
}
if err = s.d.SetMedalActivatedCache(c, mid, nid); err != nil {
log.Error("s.d.DelMedalActivatedCache(mid:%d nid:%d) error(%v)", mid, nid, err)
err = nil
}
s.addAsyn(func() {
if err = s.accNotify(context.Background(), mid, model.AccountNotifyUpdateMedal); err != nil {
log.Error("s.accNotify(%d) error(%+v)", mid, err)
return
}
})
return
}
// MedalOwnerDel update medal owner is_del .
func (s *Service) MedalOwnerDel(c context.Context, mid, nid int64, isDel int8, title, msg string) (err error) {
if _, err = s.d.MedalOwnerDel(c, mid, nid, isDel); err != nil {
log.Error("s.d.MedalOwnerDel error(%v)", err)
}
if err = s.d.DelMedalOwnersCache(c, mid); err != nil {
log.Error("s.d.DelMedalOwnersCache(%d) error(%v)", mid, err)
err = nil
}
var mids []int64
mids = append(mids, mid)
if title != "" && msg != "" {
if err = s.d.SendSysMsg(c, mids, title, msg, ""); err != nil {
log.Error("MedalOwnerDel(mid:%d nid:%d title:%s msg:%s) SendSysMsg error(%+v)", mid, nid, title, msg, err)
err = nil
}
}
return
}
// ReadCsv read csv file
func (s *Service) ReadCsv(f multipart.File, h *multipart.FileHeader) (rs [][]string, err error) {
r := csv.NewReader(f)
for {
record, err := r.Read()
if err == io.EOF {
break
}
if err != nil {
fmt.Println(err)
log.Error("upload question ReadCsv error(%v)", err)
}
if len(record) == 1 {
rs = append(rs, record)
}
}
return
}
// BatchAdd medal bacth add.
func (s *Service) BatchAdd(c context.Context, nid int64, f multipart.File, h *multipart.FileHeader) (msg string, err error) {
if h != nil && !strings.HasSuffix(h.Filename, ".csv") {
msg = "not csv file."
return
}
rs, err := s.ReadCsv(f, h)
if len(rs) == 0 || len(rs) > model.MaxCount {
msg = "file size count is 0 or more than " + strconv.FormatInt(model.MaxCount, 10)
return
}
for _, r := range rs {
mid, err := strconv.ParseInt(r[0], 10, 64)
if err == nil {
if err = s.MedalOwnerAdd(c, mid, nid, "", "", 0); err != nil {
log.Error("s.d.MedalOwnerAdd(mid:%d nid:%d) error(%v)", mid, nid, err)
}
}
}
return
}
// MedalOperlog medal operactlog .
func (s *Service) MedalOperlog(c context.Context, mid int64, pn, ps int) (opers []*model.MedalOperLog, pager *model.Pager, err error) {
var total int64
pager = &model.Pager{
PN: pn,
PS: ps,
}
if total, err = s.d.MedalOperationLogTotal(c, mid); err != nil {
err = errors.Wrap(err, "s.d.MedalOperationLogTotal()")
return
}
if total <= 0 {
return
}
pager.Total = total
var uids []int64
if opers, uids, err = s.d.MedalOperLog(c, mid, pn, ps); err != nil {
err = errors.Wrapf(err, "s.d.MedalOperLog(%d,%d,%d)", mid, pn, ps)
return
}
var accInfoMap map[int64]*accmdl.Info
if accInfoMap, err = s.fetchInfos(c, uids, _fetchInfoTimeout); err != nil {
log.Error("service.fetchInfos(%v, %v) error(%v)", xstr.JoinInts(uids), _fetchInfoTimeout, err)
err = nil
}
for _, v := range opers {
if accInfo, ok := accInfoMap[v.MID]; ok {
v.Action = fmt.Sprintf("给用户(%s) %s", accInfo.Name, v.Action)
}
if operName, ok := s.Managers[v.OID]; ok {
v.OperName = operName
}
}
return
}