Files
baseapi/platformapi/mtwmapi/callback.go
2019-04-15 12:41:55 +08:00

101 lines
2.8 KiB
Go
Raw Blame History

This file contains ambiguous Unicode characters
This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.
package mtwmapi
import (
"net/http"
"net/url"
"strings"
"time"
"git.rosy.net.cn/baseapi"
"git.rosy.net.cn/baseapi/utils"
)
const (
MsgPoiStatusOpened = 121 // 121=营业
MsgPoiStatusClosed = 120 // 120=休息
MsgPoiStatusOnline = 18 // 18=上线
MsgPoiStatusOffline = 19 // 19=下线
)
const (
MsgTypeWaybillStatus = "waybillStatus"
MsgTypeNewOrder = "newOrder"
MsgTypeOrderAccepted = "orderAccepted"
MsgTypeOrderFinished = "orderFinished"
MsgTypeOrderFinancial = "orderFinancial"
MsgTypeOrderCanceled = "orderCanceled"
MsgTypeUserUrgeOrder = "userUrgeOrder"
MsgTypePrivateNumberDowngrade = "numberDowngrade"
MsgTypeOrderModified = "orderModified" // 这个不是订单调整,是订单信息(地址、联系人等)变化后推送的消息
MsgTypeOrderRefund = "orderRefund"
MsgTypeOrderPartialRefund = "orderPartialRefund"
MsgTypeOrderFinishedPickup = "orderFinishedPickup"
MsgTypeStoreStatusChanged = "storeStatusChanged"
)
type CallbackResponse struct {
Data string `json:"data"`
}
// !!!特别注意Data中的数据
type CallbackMsg struct {
Data url.Values
Cmd string
}
var (
SuccessResponse = &CallbackResponse{Data: "ok"}
SignatureIsNotOk = &CallbackResponse{Data: "sign failed"}
)
func Err2CallbackResponse(err error, data string) *CallbackResponse {
if err == nil {
return SuccessResponse
}
if data == "" {
data = err.Error()
}
return &CallbackResponse{
Data: data,
}
}
func (a *API) GetCallbackMsg(request *http.Request) (msg *CallbackMsg, callbackResponse *CallbackResponse) {
err := request.ParseForm()
if err == nil {
data := utils.URLValues2Map(request.Form)
if dataSign, ok := data[signKey]; ok {
fullURL := strings.TrimRight(a.callbackURL+request.URL.Path, "/")
sign := a.signParams(fullURL+"?", data)
if sign != dataSign.(string) {
baseapi.SugarLogger.Debugf("mtwm GetCallbackMsg my sign:%v, data sign:%v", sign, dataSign.(string))
callbackResponse = SignatureIsNotOk
} else {
cmd := strings.Trim(request.URL.EscapedPath(), "/")
cmd = cmd[strings.LastIndex(cmd, "/")+1:]
msg = &CallbackMsg{
Cmd: cmd,
}
msg.Data = make(url.Values)
for k, v := range data {
// 美团外卖的用户催单信息的timestamp是毫秒其它的事件是秒统一归一化为秒
if cmd == MsgTypeUserUrgeOrder && k == "timestamp" {
intV := utils.Str2Int64(v.(string))
if intV > time.Now().Unix()*2 {
v = utils.Int64ToStr(intV / 1000)
}
}
msg.Data.Set(k, v.(string))
}
}
} else {
callbackResponse = SuccessResponse // 美团外卖PING消息没有sign
}
} else {
baseapi.SugarLogger.Warnf("mtwm GetCallbackMsg ParseForm failed with error:%v", err)
callbackResponse = Err2CallbackResponse(err, "")
}
return msg, callbackResponse
}