| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237 |
- package kaya
- import (
- "encoding/base64"
- "encoding/json"
- "fmt"
- "math"
- "net/http"
- "net/url"
- "strconv"
- "strings"
- "time"
- "bet24.com/servers/payment/shop"
- "bet24.com/log"
- "bet24.com/public"
- coreClient "bet24.com/servers/coreservice/client"
- "bet24.com/servers/payment/config"
- "bet24.com/servers/payment/db"
- "github.com/gin-gonic/gin"
- )
- // 下单
- func PayOrder(c *gin.Context) {
- obj := db.NewOrder(db.SP_Kaya_ORDER)
- if err := c.ShouldBind(&obj.In); err != nil {
- log.Debug("%s query params err %v", "kaya.PayOrder", err)
- c.String(http.StatusOK, "")
- return
- }
- obj.In.IpAddress = strings.Split(c.Request.RemoteAddr, ":")[0]
- //// 币种为空,根据ip获取
- //if obj.In.Currency == "" {
- // currency := shop.GetCurrencyRateByIp(obj.In.UserID, obj.In.IpAddress)
- // obj.In.Currency = currency
- //}
- // 获取产品信息
- item := shop.GetProduct(obj.In.ProductID)
- if item == nil {
- log.Error("%s query GetProduct productId=%s currency=%s is nil", "kaya.PayOrder", obj.In.ProductID, obj.In.Currency)
- c.String(http.StatusOK, "")
- return
- }
- //// 获取当前汇率信息
- //info := shop.GetExchangeRate(obj.In.Currency)
- //if info == nil {
- // log.Error("%s query GetExchangeRate obj.In.Currency=%s is nil", "kaya.PayOrder", obj.In.Currency)
- // c.String(http.StatusOK, "")
- // return
- //}
- //
- //// 计算价格
- //calPrice := info.Rate * item.Price
- //
- //// 检查价格是否篡改
- //if calPrice != obj.In.Price {
- // log.Error("%s obj.In.Price=%v info.Rate=%v calPrice=%v is invalid", "kaya.PayOrder", obj.In.Price, info.Rate, calPrice)
- // c.String(http.StatusOK, "")
- // return
- //}
- // 检查价格是否篡改
- if item.Price != obj.In.Price {
- log.Error("%s obj.In.Price=%v calPrice=%v is invalid", "kaya.PayOrder", obj.In.Price, item.Price)
- c.String(http.StatusOK, "")
- return
- }
- obj.DoAction(nil)
- if obj.Out.OrderID == "" {
- log.Debug("%s GenOrder fail obj.In=%+v", "kaya.PayOrder", obj.In)
- c.String(http.StatusOK, "")
- return
- }
- //请求payOrder的代码
- req := pay_req{
- MerchantCode: config.Server.KayaPay.MerchantCode,
- Method: "BT",
- OrderNum: obj.Out.OrderID,
- PayMoney: int(math.Ceil(obj.In.Price)),
- ProductDetail: obj.In.ProductID,
- Name: obj.In.Name,
- Email: obj.In.Email,
- Phone: obj.In.Tel,
- NotifyUrl: config.Server.KayaPay.Url_pay_notify,
- ExpiryPeriod: 30,
- DateTime: time.Now().Format(TIME_FORMAT),
- }
- params := url.Values{}
- params.Set("merchantCode", req.MerchantCode)
- params.Set("method", req.Method)
- params.Set("orderNum", req.OrderNum)
- params.Set("payMoney", strconv.Itoa(req.PayMoney))
- params.Set("productDetail", req.ProductDetail)
- params.Set("name", req.Name)
- params.Set("email", req.Email)
- params.Set("phone", req.Phone)
- params.Set("notifyUrl", req.NotifyUrl)
- params.Set("expiryPeriod", strconv.Itoa(req.ExpiryPeriod))
- params.Set("dateTime", req.DateTime)
- // 生成签名
- checkContent := createEncryptStr(params)
- // log.Debug("order.checkContent ==> %s", checkContent)
- // 商户请求我们接口时使用商户私钥对请求参数 进行加密
- mchPriKey := fmt.Sprintf(`-----BEGIN PRIVATE KEY-----
- %s
- -----END PRIVATE KEY-----
- `, config.Server.KayaPay.MCH_PRIVATE_KEY)
- if err := public.RSA.SetPrivateKey(mchPriKey); err != nil {
- log.Error("kaya.payOrder set private key :%v ==> %+v", err, params)
- return
- }
- // 私钥加密
- prienctypt, err := public.RSA.PriKeyENCTYPT([]byte(checkContent))
- if err != nil {
- log.Error("kaya.payOrder RSA.PriKeyENCTYPT err %v", err)
- return
- }
- req.Sign = base64.StdEncoding.EncodeToString(prienctypt)
- // log.Debug("kaya.payOrder req ==> %+v ", params)
- // POST请求
- buf, _ := json.Marshal(req)
- respBody := public.HttpPostByJson(config.Server.KayaPay.Url_pay_order, string(buf))
- log.Debug("kaya.payOrder req ==> %+v resp ==> %+v", params, respBody)
- var resp pay_resp
- if err := json.Unmarshal([]byte(respBody), &resp); err != nil {
- log.Error("kaya.payOrder json unmarshal req ==> %+v resp ==> %+v fail %v", params, respBody, err)
- return
- }
- // log.Debug("kaya.payOrder resp ==> %+v", resp)
- // 请求响应码,00000表示成功,其他失败
- if resp.PlatRespCode != RESP_CODE_SUCCESS {
- log.Error("kaya.payOrder post return resp fail ==> %+v", resp)
- return
- }
- c.String(http.StatusOK, "Success")
- return
- }
- // 回调通知
- func PayNotify(c *gin.Context) {
- var resp payNotify
- if err := c.ShouldBind(&resp); err != nil {
- log.Debug("%s query params err %v", "kaya.PayNotify", err)
- c.String(http.StatusOK, "")
- return
- }
- log.Debug("kaya.PayNotify resp ==> %+v", resp)
- params := url.Values{}
- params.Set("code", resp.Code)
- params.Set("email", resp.Email)
- params.Set("method", resp.Method)
- params.Set("msg", resp.Msg)
- params.Set("name", resp.Name)
- params.Set("orderNum", resp.OrderNum)
- params.Set("payFee", strconv.Itoa(resp.PayFee))
- params.Set("payMoney", strconv.Itoa(resp.PayMoney))
- params.Set("platOrderNum", resp.PlatOrderNum)
- params.Set("vaNumber", resp.VaNumber)
- // 生成签名
- checkContent := createEncryptStr(params)
- // log.Debug("kaya.PayNotify checkContent ==> %s", checkContent)
- // 商户使用 商户后台显示的平台公钥 进行解密
- platPubKey := fmt.Sprintf(`-----BEGIN PUBLIC KEY-----
- %s
- -----END PUBLIC KEY-----
- `, config.Server.KayaPay.PLAT_PUBLIC_KEY)
- if err := public.RSA.SetPublicKey(platPubKey); err != nil {
- log.Error("kaya.PayNotify set public key :%v ==> %+v", err, params)
- return
- }
- data, err := base64.StdEncoding.DecodeString(resp.PlatSign)
- if err != nil {
- log.Error("kaya.PayNotify base64.StdEncoding.DecodeString err %v", err)
- return
- }
- // 公钥解密
- pubdecrypt, err := public.RSA.PubKeyDECRYPT(data)
- if err != nil {
- log.Error("kaya.PayNotify RSA.PubKeyDECRYPT err %v", err)
- return
- }
- if checkContent != string(pubdecrypt) {
- log.Error("kaya.PayNotify 签名失败 ==> %+v", resp)
- return
- }
- log.Debug("kaya.PayNotify 签名成功")
- // 0-成功,其他失败
- if resp.Code != "00" {
- log.Error("kaya.PayNotify resp ==> %+v 失败", resp)
- return
- }
- // 数据库操作
- obj := db.NewNotify(db.SP_Kaya_NOTIFY)
- obj.In.OrderID = resp.OrderNum
- obj.In.TradeID = resp.PlatOrderNum
- //obj.In.Price = resp.PayMoney
- obj.DoAction(nil)
- //操作成功,给道具
- if obj.Out.RetCode == 1 {
- //充值
- resp := coreClient.Recharge(obj.Out.UserID, obj.Out.ProductID)
- log.Debug("%s 充值成功 %+v", "kaya.PayNotify", resp)
- }
- c.String(http.StatusOK, "success")
- return
- }
|