package common import ( "crypto/sha1" "encoding/xml" "fmt" "hudongzhuanjia/controllers" "hudongzhuanjia/libs/filter" "hudongzhuanjia/logger" pay_service "hudongzhuanjia/services/pay" "hudongzhuanjia/utils/define" "os" "time" "go.uber.org/atomic" ) var Now = time.Now() type WeChatOauthCtl struct { controllers.BaseCtl } const token = "hd_oauth" // 验证服务器资源配置 func (t *WeChatOauthCtl) Oauth() { signature := t.MustGet("signature") timestamp := t.MustGet("timestamp") nonce := t.MustGet("nonce") echoStr := t.MustGet("echostr") tokenStr := fmt.Sprintf("%s%s%s", token, timestamp, nonce) s := fmt.Sprintf("%s", sha1.New().Sum([]byte(tokenStr))) if s == signature { t.OriginResponseWriter.Write([]byte(echoStr)) } t.OriginResponseWriter.Write([]byte("failed")) } func (t *WeChatOauthCtl) Checkin() { content, _ := t.Get("content") path, _ := os.Getwd() t.JSON(map[string]interface{}{ "success": "你好, tommy黄梓健", "version": Now, "wd": path, "content": filter.Replace(content), }) } // //func init() { // ticker := time.NewTicker(5 * time.Second) // go func() { // fmt.Println("循环查询订单数据") // for range ticker.C { // pay_service.BatchQuery() // } // }() // //} type CDATA struct { Text string `xml:",cdata"` } type CallbackParam struct { XMLName xml.Name `xml:"xml"` ReturnCode CDATA `xml:"return_code"` ReturnMsg CDATA `xml:"return_msg"` } var orderSuccessCounter = new(atomic.Int64) var orderFailedCounter = new(atomic.Int64) var refundSuccessCounter = new(atomic.Int64) var refundFailedCounter = new(atomic.Int64) func (t *WeChatOauthCtl) CallbackOrder() { //搜索支付的order表, 查找到某条记录 _, err := pay_service.NotifyOrder(t.Request.BODY) param := new(CallbackParam) if err != nil { logger.Error(err) orderFailedCounter.Add(1) logger.Error(fmt.Sprintf("call order失败微信响应次数: %v", orderFailedCounter.Load())) param.ReturnCode = CDATA{Text: define.CODE_FAIL} param.ReturnMsg = CDATA{Text: err.Error()} } else { orderSuccessCounter.Add(1) logger.Error(fmt.Sprintf("call order成功微信响应次数: %v", orderSuccessCounter.Load())) param.ReturnCode = CDATA{Text: define.CODE_SUCCESS} param.ReturnMsg = CDATA{Text: "OK"} } xmlRes, _ := xml.Marshal(param) if t.Request.OriginRequest.Method == "GET" { t.JSON(map[string]interface{}{ "time": time.Now(), "xml": param, }) return } t.XML(xmlRes) } func (t *WeChatOauthCtl) CallbackRefund() { _, err := pay_service.NotifyRefund(t.Request.BODY) param := new(CallbackParam) if err != nil { logger.Error(err) refundFailedCounter.Add(1) logger.Error(fmt.Sprintf("call refund失败微信响应次数: %v", refundFailedCounter.Load())) param.ReturnCode = CDATA{Text: define.CODE_FAIL} param.ReturnMsg = CDATA{Text: err.Error()} } else { refundSuccessCounter.Add(1) logger.Error(fmt.Sprintf("call refund成功微信响应次数: %v", refundSuccessCounter.Load())) param.ReturnCode = CDATA{Text: define.CODE_SUCCESS} param.ReturnMsg = CDATA{Text: "OK"} } xmlRes, _ := xml.Marshal(param) if t.Request.OriginRequest.Method == "GET" { t.JSON(map[string]interface{}{ "time": time.Now(), "xml": param, }) } t.XML(xmlRes) }