From ae0594cfeb533896d1d382f4df9f1ccd1e502775 Mon Sep 17 00:00:00 2001 From: wenzl Date: Fri, 23 Feb 2018 16:28:56 +0800 Subject: [PATCH] fix golint --- pay/pay.go | 132 ++++++++++++++++++++++++------------------------- util/crypto.go | 4 +- 2 files changed, 68 insertions(+), 68 deletions(-) diff --git a/pay/pay.go b/pay/pay.go index b9995d8..6a8eec7 100644 --- a/pay/pay.go +++ b/pay/pay.go @@ -1,9 +1,10 @@ package pay import ( - "errors" "encoding/xml" - "fmt" + "errors" + "fmt" + "github.com/silenceper/wechat/context" "github.com/silenceper/wechat/util" ) @@ -15,65 +16,65 @@ type Pay struct { *context.Context } +// Params was NEEDED when request unifiedorder // 传入的参数,用于生成 prepay_id 的必需参数 -// PayParams was NEEDED when request unifiedorder -type PayParams struct { - TotalFee string - CreateIP string - Body string - OutTradeNo string - OpenID string +type Params struct { + TotalFee string + CreateIP string + Body string + OutTradeNo string + OpenID string } -// PayConfig 是传出用于 jsdk 用的参数 -type PayConfig struct { - Timestamp int64 - NonceStr string - PrePayID string - SignType string - Sign string +// Config 是传出用于 jsdk 用的参数 +type Config struct { + Timestamp int64 + NonceStr string + PrePayID string + SignType string + Sign string } // payResult 是 unifie order 接口的返回 type payResult struct { - ReturnCode string `xml:"return_code"` - ReturnMsg string `xml:"return_msg"` - AppID string `xml:"appid,omitempty"` - MchID string `xml:"mch_id,omitempty"` - NonceStr string `xml:"nonce_str,omitempty"` - Sign string `xml:"sign,omitempty"` - ResultCode string `xml:"result_code,omitempty"` - TradeType string `xml:"trade_type,omitempty"` - PrePayID string `xml:"prepay_id,omitempty"` - CodeURL string `xml:"code_url,omitempty"` - ErrCode string `xml:"err_code,omitempty"` - ErrCodeDes string `xml:"err_code_des,omitempty"` + ReturnCode string `xml:"return_code"` + ReturnMsg string `xml:"return_msg"` + AppID string `xml:"appid,omitempty"` + MchID string `xml:"mch_id,omitempty"` + NonceStr string `xml:"nonce_str,omitempty"` + Sign string `xml:"sign,omitempty"` + ResultCode string `xml:"result_code,omitempty"` + TradeType string `xml:"trade_type,omitempty"` + PrePayID string `xml:"prepay_id,omitempty"` + CodeURL string `xml:"code_url,omitempty"` + ErrCode string `xml:"err_code,omitempty"` + ErrCodeDes string `xml:"err_code_des,omitempty"` } //payRequest 接口请求参数 type payRequest struct { - AppID string `xml:"appid"` - MchID string `xml:"mch_id"` - DeviceInfo string `xml:"device_info,omitempty"` - NonceStr string `xml:"nonce_str"` - Sign string `xml:"sign"` - SignType string `xml:"sign_type,omitempty"` - Body string `xml:"body"` - Detail string `xml:"detail,omitempty"` - Attach string `xml:"attach,omitempty"` //附加数据 - OutTradeNo string `xml:"out_trade_no"` //商户订单号 - FeeType string `xml:"fee_type,omitempty"` //标价币种 - TotalFee string `xml:"total_fee"` //标价金额 - SpbillCreateIp string `xml:"spbill_create_ip"` //终端IP - TimeStart string `xml:"time_start,omitempty"` //交易起始时间 - TimeExpire string `xml:"time_expire,omitempty"` //交易结束时间 - GoodsTag string `xml:"goods_tag,omitempty"` //订单优惠标记 - NotifyUrl string `xml:"notify_url"` //通知地址 - TradeType string `xml:"trade_type"` //交易类型 - ProductId string `xml:"product_id,omitempty"` //商品ID - LimitPay string `xml:"limit_pay,omitempty"` // - OpenID string `xml:"openid,omitempty"` //用户标识 - SceneInfo string `xml:"scene_info,omitempty"` //场景信息 + AppID string `xml:"appid"` + MchID string `xml:"mch_id"` + DeviceInfo string `xml:"device_info,omitempty"` + NonceStr string `xml:"nonce_str"` + Sign string `xml:"sign"` + SignType string `xml:"sign_type,omitempty"` + Body string `xml:"body"` + Detail string `xml:"detail,omitempty"` + Attach string `xml:"attach,omitempty"` //附加数据 + OutTradeNo string `xml:"out_trade_no"` //商户订单号 + FeeType string `xml:"fee_type,omitempty"` //标价币种 + TotalFee string `xml:"total_fee"` //标价金额 + SpbillCreateIP string `xml:"spbill_create_ip"` //终端IP + TimeStart string `xml:"time_start,omitempty"` //交易起始时间 + TimeExpire string `xml:"time_expire,omitempty"` //交易结束时间 + GoodsTag string `xml:"goods_tag,omitempty"` //订单优惠标记 + NotifyURL string `xml:"notify_url"` //通知地址 + TradeType string `xml:"trade_type"` //交易类型 + ProductID string `xml:"product_id,omitempty"` //商品ID + LimitPay string `xml:"limit_pay,omitempty"` // + OpenID string `xml:"openid,omitempty"` //用户标识 + SceneInfo string `xml:"scene_info,omitempty"` //场景信息 } // NewPay return an instance of Pay package @@ -82,25 +83,25 @@ func NewPay(ctx *context.Context) *Pay { return &pay } -// PrePayId will request wechat merchant api and request for a pre payment order id -func (pcf *Pay) PrePayId(p *PayParams) (prePayID string, err error) { +// PrePayID will request wechat merchant api and request for a pre payment order id +func (pcf *Pay) PrePayID(p *Params) (prePayID string, err error) { nonceStr := util.RandomStr(32) tradeType := "JSAPI" template := "appid=%s&body=%s&mch_id=%s&nonce_str=%s¬ify_url=%s&openid=%s&out_trade_no=%s&spbill_create_ip=%s&total_fee=%s&trade_type=%s&key=%s" str := fmt.Sprintf(template, pcf.AppID, p.Body, pcf.PayMchID, nonceStr, pcf.PayNotifyURL, p.OpenID, p.OutTradeNo, p.CreateIP, p.TotalFee, tradeType, pcf.PayKey) sign := util.MD5Sum(str) request := payRequest{ - AppID: pcf.AppID, - MchID: pcf.PayMchID, - NonceStr: nonceStr, - Sign: sign, - Body: p.Body, - OutTradeNo: p.OutTradeNo, - TotalFee: p.TotalFee, - SpbillCreateIp: p.CreateIP, - NotifyUrl: pcf.PayNotifyURL, - TradeType: tradeType, - OpenID: p.OpenID, + AppID: pcf.AppID, + MchID: pcf.PayMchID, + NonceStr: nonceStr, + Sign: sign, + Body: p.Body, + OutTradeNo: p.OutTradeNo, + TotalFee: p.TotalFee, + SpbillCreateIP: p.CreateIP, + NotifyURL: pcf.PayNotifyURL, + TradeType: tradeType, + OpenID: p.OpenID, } rawRet, err := util.PostXML(payGateway, request) if err != nil { @@ -117,7 +118,6 @@ func (pcf *Pay) PrePayId(p *PayParams) (prePayID string, err error) { return payRet.PrePayID, nil } return "", errors.New(payRet.ErrCode + payRet.ErrCodeDes) - } else { - return "", errors.New("[msg : xmlUnmarshalError] [rawReturn : " + string(rawRet) + "] [params : " + str + "] [sign : " + sign + "]") } -} \ No newline at end of file + return "", errors.New("[msg : xmlUnmarshalError] [rawReturn : " + string(rawRet) + "] [params : " + str + "] [sign : " + sign + "]") +} diff --git a/util/crypto.go b/util/crypto.go index 98e2b4e..ce21e36 100644 --- a/util/crypto.go +++ b/util/crypto.go @@ -1,8 +1,8 @@ package util import ( - "bytes" "bufio" + "bytes" "crypto/aes" "crypto/cipher" "crypto/md5" @@ -186,7 +186,7 @@ func decodeNetworkByteOrder(orderBytes []byte) (n uint32) { uint32(orderBytes[3]) } -// 计算 32 位长度的 MD5 sum +// MD5Sum 计算 32 位长度的 MD5 sum func MD5Sum(txt string) (sum string) { h := md5.New() buf := bufio.NewWriterSize(h, 128)