100 lines
2.7 KiB
Go
100 lines
2.7 KiB
Go
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"
|
||
|
||
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
|
||
}
|