go-common/app/job/main/videoup/dao/message/dao.go

92 lines
2.6 KiB
Go
Raw Normal View History

2019-04-22 10:49:16 +00:00
package message
import (
"context"
"fmt"
"net/url"
"strconv"
"go-common/app/job/main/videoup/conf"
"go-common/library/log"
xhttp "go-common/library/net/http/blademaster"
"strings"
"time"
)
// Dao is message dao.
type Dao struct {
c *conf.Config
client *xhttp.Client
uri string
pushURI string
}
// New new a message dao.
func New(c *conf.Config) (d *Dao) {
d = &Dao{
c: c,
client: xhttp.NewClient(c.HTTPClient),
uri: c.Host.Message + "/api/notify/send.user.notify.do",
pushURI: c.Host.API + "/x/internal/push/single",
}
return
}
// Send send message to upper.
func (d *Dao) Send(c context.Context, mc, title, msg string, mid int64, ts int64) (err error) {
params := url.Values{}
source := strings.Split(mc, "_")
params.Set("type", "json")
params.Set("source", source[0])
params.Set("data_type", "4")
params.Set("mc", mc)
params.Set("title", title)
params.Set("context", msg)
params.Set("mid_list", strconv.FormatInt(mid, 10))
var res struct {
Code int `json:"code"`
}
if err = d.client.Post(c, d.uri, "", params, &res); err != nil {
log.Error("message url(%s) error(%v)", d.uri+"?"+params.Encode(), err)
return
}
log.Info("send.user.notify.do send mid(%d) message(%s) url(%s) code(%v)", mid, msg, d.uri+"?"+params.Encode(), res.Code)
if res.Code != 0 {
log.Error("message url(%s) error(%v)", d.uri+"?"+params.Encode(), res.Code)
err = fmt.Errorf("message send failed")
}
return
}
//PushMsg 发送推送消息给创作姬APP TODO deprecated
func (d *Dao) PushMsg(c context.Context, mid int64, title string, msg string) (err error) {
var res struct {
Code int `json:"code"`
Message string `json:"message"`
}
params := url.Values{}
params.Set("appkey", d.c.HTTPClient.Key)
params.Set("appsecret", d.c.HTTPClient.Secret)
params.Set("ts", strconv.FormatInt(time.Now().Unix(), 10))
params.Set("app_id", d.c.Host.Push.AppID)
params.Set("business_id", d.c.Host.Push.BusinessID)
params.Set("token", d.c.Host.Push.Token)
params.Set("link_type", "8")
params.Set("mid", strconv.FormatInt(mid, 10))
params.Set("alert_title", title)
params.Set("alert_body", msg)
log.Info("start send PushMsgurl(%s)", d.pushURI+"?"+params.Encode())
if err = d.client.Post(c, d.pushURI, "", params, &res); err != nil {
log.Error("message PushMsg error(%v), url(%s)", err, d.pushURI+"?"+params.Encode())
return
}
log.Info("after send PushMsgresponse(%v) url(%s)", res, d.pushURI+"?"+params.Encode())
if res.Code != 0 {
log.Info("message PushMsg response is failed, res message(%+v), url(%s)", res, d.pushURI+"?"+params.Encode())
err = fmt.Errorf("message PushMsg send failed")
}
return
}