123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184 |
- package oppo
- import (
- "encoding/json"
- "io"
- "io/ioutil"
- "net/http"
- "net/url"
- "strconv"
- "strings"
- "time"
- "go-common/library/log"
- "go-common/library/stat"
- "go-common/library/stat/prom"
- )
- type Client struct {
- Auth *Auth
- HTTPClient *http.Client
- Stats stat.Stat
- Activity string
- }
- func NewClient(a *Auth, activity string, timeout time.Duration) *Client {
- return &Client{
- Auth: a,
- HTTPClient: &http.Client{Timeout: timeout},
- Stats: prom.HTTPClient,
- Activity: activity,
- }
- }
- func (c *Client) Message(m *Message) (response *Response, err error) {
- now := time.Now()
- if c.Stats != nil {
- defer func() {
- c.Stats.Timing(_apiMessage, int64(time.Since(now)/time.Millisecond))
- log.Info("oppo message stats timing: %v", int64(time.Since(now)/time.Millisecond))
- if err != nil {
- c.Stats.Incr(_apiMessage, "failed")
- }
- }()
- }
- params := url.Values{}
- params.Add("auth_token", c.Auth.Token)
- params.Add("title", m.Title)
- params.Add("content", m.Content)
- params.Add("click_action_type", strconv.Itoa(m.ActionType))
- params.Add("click_action_activity", c.Activity)
- params.Add("action_parameters", m.ActionParams)
- params.Add("off_line_ttl", strconv.Itoa(m.OfflineTTL))
- params.Add("call_back_url", m.CallbackURL)
- req, err := http.NewRequest(http.MethodPost, _apiMessage, strings.NewReader(params.Encode()))
- if err != nil {
- log.Error("http.NewRequest() error(%v)", err)
- return
- }
- req.Header.Set("Content-Type", "application/x-www-form-urlencoded")
- req.Header.Set("Connection", "Keep-Alive")
- res, err := c.HTTPClient.Do(req)
- if err != nil {
- log.Error("HTTPClient.Do() error(%v)", err)
- return
- }
- defer res.Body.Close()
- response = &Response{}
- bs, err := ioutil.ReadAll(res.Body)
- if err != nil {
- log.Error("ioutil.ReadAll() error(%v)", err)
- return
- } else if len(bs) == 0 {
- return
- }
- if e := json.Unmarshal(bs, &response); e != nil {
- if e != io.EOF {
- log.Error("json decode body(%s) error(%v)", string(bs), e)
- }
- }
- return
- }
- func (c *Client) Push(msgID string, tokens []string) (response *Response, err error) {
- now := time.Now()
- if c.Stats != nil {
- defer func() {
- c.Stats.Timing(_apiPushBroadcast, int64(time.Since(now)/time.Millisecond))
- log.Info("oppo push stats timing: %v", int64(time.Since(now)/time.Millisecond))
- if err != nil {
- c.Stats.Incr(_apiPushBroadcast, "failed")
- }
- }()
- }
- params := url.Values{}
- params.Add("auth_token", c.Auth.Token)
- params.Add("message_id", msgID)
- params.Add("target_type", _pushTypeToken)
- params.Add("registration_ids", strings.Join(tokens, ";"))
- req, err := http.NewRequest(http.MethodPost, _apiPushBroadcast, strings.NewReader(params.Encode()))
- if err != nil {
- log.Error("http.NewRequest() error(%v)", err)
- return
- }
- req.Header.Set("Content-Type", "application/x-www-form-urlencoded")
- req.Header.Set("Connection", "Keep-Alive")
- res, err := c.HTTPClient.Do(req)
- if err != nil {
- log.Error("HTTPClient.Do() error(%v)", err)
- return
- }
- defer res.Body.Close()
- response = &Response{}
- bs, err := ioutil.ReadAll(res.Body)
- if err != nil {
- log.Error("ioutil.ReadAll() error(%v)", err)
- return
- } else if len(bs) == 0 {
- return
- }
- if e := json.Unmarshal(bs, &response); e != nil {
- if e != io.EOF {
- log.Error("json decode body(%s) error(%v)", string(bs), e)
- }
- }
- return
- }
- func (c *Client) PushOne(m *Message, token string) (response *Response, err error) {
- now := time.Now()
- if c.Stats != nil {
- defer func() {
- c.Stats.Timing(_apiPushUnicast, int64(time.Since(now)/time.Millisecond))
- log.Info("oppo pushOne stats timing: %v", int64(time.Since(now)/time.Millisecond))
- if err != nil {
- c.Stats.Incr(_apiPushUnicast, "failed")
- }
- }()
- }
- m.ActionActivity = c.Activity
- params := url.Values{}
- msg, _ := json.Marshal(&struct {
- TargetType string `json:"target_type"`
- Token string `json:"registration_id"`
- Notification *Message `json:"notification"`
- }{
- TargetType: _pushTypeToken,
- Token: token,
- Notification: m,
- })
- params.Add("auth_token", c.Auth.Token)
- params.Add("message", string(msg))
- req, err := http.NewRequest(http.MethodPost, _apiPushUnicast, strings.NewReader(params.Encode()))
- if err != nil {
- log.Error("http.NewRequest() error(%v)", err)
- return
- }
- req.Header.Set("Content-Type", "application/x-www-form-urlencoded")
- req.Header.Set("Connection", "Keep-Alive")
- res, err := c.HTTPClient.Do(req)
- if err != nil {
- log.Error("HTTPClient.Do() error(%v)", err)
- return
- }
- defer res.Body.Close()
- response = &Response{}
- bs, err := ioutil.ReadAll(res.Body)
- if err != nil {
- log.Error("ioutil.ReadAll() error(%v)", err)
- return
- } else if len(bs) == 0 {
- return
- }
- if e := json.Unmarshal(bs, &response); e != nil {
- if e != io.EOF {
- log.Error("json decode body(%s) error(%v)", string(bs), e)
- }
- }
- return
- }
|