1
This commit is contained in:
282
platformapi/tonglianpayapi/tonglian_model.go
Normal file
282
platformapi/tonglianpayapi/tonglian_model.go
Normal file
@@ -0,0 +1,282 @@
|
||||
package tonglianpayapi
|
||||
|
||||
import (
|
||||
"crypto/md5"
|
||||
"fmt"
|
||||
"git.rosy.net.cn/baseapi/platformapi"
|
||||
"net/http"
|
||||
"sort"
|
||||
"strings"
|
||||
)
|
||||
|
||||
const (
|
||||
prodURL = "https://vsp.allinpay.com/apiweb"
|
||||
prodURL2 = "https://syb.allinpay.com/apiweb"
|
||||
sepcAction = "unitorder/pay"
|
||||
sepcAction2 = "h5unionpay/unionorder"
|
||||
|
||||
sigKey = "sign"
|
||||
PayTypeWxXcx = "W06"
|
||||
PayTypeWxCode = "W01"
|
||||
PayTypeZfbApp = "A03"
|
||||
PayTypeZfbQrcode = "A01"
|
||||
PayTypeZfbJS = "A02"
|
||||
PayTypeH5 = "H5"
|
||||
|
||||
ResponseCodeSuccess = "SUCCESS"
|
||||
ResponseCodeFail = "FAIL"
|
||||
)
|
||||
|
||||
type API struct {
|
||||
appID string
|
||||
cusID string
|
||||
appKey string
|
||||
|
||||
client *http.Client
|
||||
config *platformapi.APIConfig
|
||||
}
|
||||
|
||||
func New(appID, appKey, cusID string, config ...*platformapi.APIConfig) *API {
|
||||
curConfig := platformapi.DefAPIConfig
|
||||
if len(config) > 0 {
|
||||
curConfig = *config[0]
|
||||
}
|
||||
return &API{
|
||||
appID: appID,
|
||||
appKey: appKey,
|
||||
cusID: cusID,
|
||||
client: &http.Client{Timeout: curConfig.ClientTimeout},
|
||||
config: &curConfig,
|
||||
}
|
||||
}
|
||||
|
||||
func (a *API) signParam(params map[string]interface{}) (sig string) {
|
||||
var valueList []string
|
||||
for k, v := range params {
|
||||
if k != sigKey {
|
||||
if str := fmt.Sprint(v); str != "" {
|
||||
valueList = append(valueList, fmt.Sprintf("%s=%s", k, str))
|
||||
}
|
||||
}
|
||||
}
|
||||
valueList = append(valueList, fmt.Sprintf("key=%s", a.appKey))
|
||||
sort.Sort(sort.StringSlice(valueList))
|
||||
sig = strings.Join(valueList, "&")
|
||||
binSig := md5.Sum([]byte(sig))
|
||||
sig = fmt.Sprintf("%X", binSig)
|
||||
return sig
|
||||
}
|
||||
|
||||
type CreateUnitorderOrderParam struct {
|
||||
CusID string `json:"cusid"`
|
||||
AppID string `json:"appid"`
|
||||
Trxamt int `json:"trxamt"` //交易金额 单位为分
|
||||
Reqsn string `json:"reqsn"` //商户交易单号
|
||||
NotifyUrl string `json:"notifyUrl"` //接收微信支付异步通知回调地址,通知url必须为直接可访问的url,不能携带参数。
|
||||
Acct string `json:"acct"`
|
||||
PayType string `json:"paytype"`
|
||||
SubAppID string `json:"subAppID"`
|
||||
}
|
||||
|
||||
type CreateUnitOrderOrderResult struct {
|
||||
RetCode string `json:"retCode"`
|
||||
RetMsg string `json:"retMsg"`
|
||||
CusID string `json:"cusID"`
|
||||
AppID string `json:"appID"`
|
||||
TrxID string `json:"trxID"`
|
||||
ChnltrxID string `json:"chnltrxID"`
|
||||
Reqsn string `json:"reqsn"`
|
||||
RandomStr string `json:"randomStr"`
|
||||
TrxStatus string `json:"trxStatus"`
|
||||
FinTime string `json:"finTime"`
|
||||
ErrMsg string `json:"errMsg"`
|
||||
PayInfo string `json:"payInfo"`
|
||||
Sign string `json:"sign"`
|
||||
}
|
||||
|
||||
type PayInfo struct {
|
||||
AppID string `json:"appID"`
|
||||
TimeStamp string `json:"timeStamp"`
|
||||
NonceStr string `json:"nonceStr"`
|
||||
Package string `json:"package"`
|
||||
SignType string `json:"signType"`
|
||||
PaySign string `json:"paySign"`
|
||||
}
|
||||
|
||||
type PayRefundParam struct {
|
||||
CusID string `json:"cusid"`
|
||||
AppID string `json:"appid"`
|
||||
Trxamt int `json:"trxamt"` //交易金额 单位为分
|
||||
Reqsn string `json:"reqsn"` //商户交易单号
|
||||
OldReqsn string `json:"oldReqsn"`
|
||||
Remark string `json:"remark"`
|
||||
RandomStr string `json:"randomStr"`
|
||||
Sign string `json:"sign"`
|
||||
TrxID string `json:"trxID"`
|
||||
OldTrxID string `json:"oldTrxID"`
|
||||
}
|
||||
|
||||
type PayRefundResult struct {
|
||||
RetCode string `json:"retCode"`
|
||||
RetMsg string `json:"retMsg"`
|
||||
CusID string `json:"cusID"`
|
||||
AppID string `json:"appID"`
|
||||
TrxID string `json:"trxID"`
|
||||
Reqsn string `json:"reqsn"`
|
||||
TrxStatus string `json:"trxStatus"`
|
||||
FinTime string `json:"finTime"`
|
||||
ErrMsg string `json:"errMsg"`
|
||||
RandomStr string `json:"randomStr"`
|
||||
Sign string `json:"sign"`
|
||||
Fee string `json:"fee"`
|
||||
TrxCode string `json:"trxCode"`
|
||||
}
|
||||
|
||||
type CreateH5UnitorderOrderParam struct {
|
||||
Trxamt int `json:"trxamt"` //交易金额 单位为分
|
||||
Reqsn string `json:"reqsn"` //商户交易单号
|
||||
NotifyUrl string `json:"notifyUrl"` //接收微信支付异步通知回调地址,通知url必须为直接可访问的url,不能携带参数。
|
||||
Charset string `json:"charset"`
|
||||
Returl string `json:"returl"`
|
||||
Body string `json:"body"`
|
||||
}
|
||||
|
||||
// OnlinePayParam 扫码枪扫码支付参数
|
||||
type OnlinePayParam struct {
|
||||
//参数 参数名称 可空 备注
|
||||
Orgid string `json:"orgid"` // 集团/代理商商户号 是 共享集团号/代理商参数时必填
|
||||
Cusid string `json:"cusid"` // 商户号实际交易的商户号 否
|
||||
Appid string `json:"appid"` // 应用ID平台分配的APPID 否
|
||||
Version string `json:"version"` // 版本号接口版本号 可
|
||||
Randomstr string `json:"randomstr"` // 随机字符串 否 商户自行生成的随机字符串
|
||||
Trxamt string `json:"trxamt"` // 交易金额单位为分 否
|
||||
Reqsn string `json:"reqsn"` // 商户交易单号 否 保证商户平台唯一
|
||||
Body string `json:"body"` // 订单商品名称,为空则以商户名作为商品名称 是
|
||||
Remark string `json:"remark"` // 备注 是 禁止出现+,空格,/,?,%,#,&, = 这几类特殊符号
|
||||
Authcode string `json:"authcode"` // 支付授权码如微信, 支付宝, 银联的付款二维码 否
|
||||
LimitPay string `json:"limit_pay"` // 支付限制 no_credit--指定不能使用信用卡支付 是 32 暂时只对微信支付和支付宝, 支付宝支付有效, 仅支持no_credit
|
||||
GoodsTag string `json:"goods_tag"` // 订单优惠标记 订单优惠标记,用于区分订单是否可以享受优惠,字段内容在微信后台配置券时进行设置,说明详见代金券或立减优惠 是 只对微信支付有效
|
||||
Benefitdetail string `json:"benefitdetail"` // 优惠信息Benefitdetail的json字符串, 注意是String 填写格式详见附录5.8 是
|
||||
SubAppid string `json:"sub_appid"` // 微信子appid 微信小程序/微信公众号/APP的appid 是 只对微信支付有效
|
||||
Chnlstoreid string `json:"chnlstoreid"` // 渠道门店编号 商户在支付渠道端的门店编号 对于支付宝支付,支付宝门店编号 对于微信支付,微信门店编号
|
||||
Subbranch string `json:"subbranch"` // 门店号 是 4
|
||||
Idno string `json:"idno"` // 证件号实名交易必填.填了此字段就会验证证件号和姓名 是 暂只支持支付宝
|
||||
Extendparams string `json:"extendparams"` // 拓展参数 json字符串,注意是String一般用于渠道的活动参数填写 是 参考5.9拓展参数附录说明
|
||||
Truename string `json:"truename"` // 付款人真实姓名实名交易必填.填了此字段就会验证证件号和姓名 是 暂只支持支付宝
|
||||
Asinfo string `json:"asinfo"` // 分账信息 格式:cusid:type:amount cusid:type:amount… 其中 cusid:接收分账的通联商户号 type分账类型(01:按金额 02:按比率) 如果分账类型为02,则分账比率为0.5表示50%。如果分账类型为01,则分账金额以元为单位表示 是
|
||||
Fqnum string `json:"fqnum"` // 分期
|
||||
NotifyUrl string `json:"notify_url"` // 交易结果通知地址 接收交易结果的通知回调地址,通知url必须为直接可访问的url,不能携带参数。 https只支持默认端口 是
|
||||
Signtype string `json:"signtype"` /// 签名方式 是
|
||||
Unpid string `json:"unpid"` // 银联pid 仅支持代理商/服务商角色调用
|
||||
Sign string `json:"sign"` // 签名 详见安全规范 否
|
||||
Terminfo string `json:"terminfo"` // 终端信息终端信息的json字符串 详见附录5.10终端字段说明 否
|
||||
Operatorid string `json:"operatorid"` // 收银员号 是
|
||||
}
|
||||
type TerminfoBase struct {
|
||||
Termno string `json:"termno"` // 终端号 必填
|
||||
Devicetype string `json:"devicetype"` // 设备类型 必填
|
||||
Termsn string `json:"termsn"` // 终端序列号
|
||||
Encryptrandnum string `json:"encryptrandnum"` // 加密随机因子
|
||||
Secrettext string `json:"secrettext"` // 密文数据
|
||||
Appversion string `json:"appversion"` // 终端程序版本号
|
||||
Longitude string `json:"longitude"` // 经度 银联扫码必送
|
||||
Latitude string `json:"latitude"` // 纬度 银联扫码必送
|
||||
Deviceip string `json:"deviceip"` // 终端Ip 如微信支付宝交易经纬度未上送,该字段必送
|
||||
}
|
||||
|
||||
// OnlinePayResult 扫码枪支付返回参数
|
||||
type OnlinePayResult struct {
|
||||
Retcode string `json:"retcode"` // SUCCESS/FAIL
|
||||
Retmsg string `json:"retmsg"` // 返回码说明
|
||||
}
|
||||
type OnlinePayRetMsg struct {
|
||||
Cusid string `json:"cusid"` // 商户号实际交易的商户号 否
|
||||
Appid string `json:"appid"` // 应用ID平台分配的APPID 否
|
||||
Trxid string `json:"trxid"` // 收银宝平台的交易流水号
|
||||
Chnltrxid string `json:"chnltrxid"` // 例如微信,支付宝平台的交易单号
|
||||
Reqsn string `json:"reqsn"` // 商户的交易订单号
|
||||
Trxstatus string `json:"trxstatus"` // 交易的状态,
|
||||
Acct string `json:"acct"` // 微信支付-用户的微信openid支付宝支付-用户user_id
|
||||
Trxcode string `json:"trxcode"` // 交易类型
|
||||
Fintime string `json:"fintime"` // yyyyMMddHHmmss
|
||||
Errmsg string `json:"errmsg"` // 失败的原因说明
|
||||
Randomstr string `json:"randomstr"` // 随机生成的字符串
|
||||
Initamt string `json:"initamt"` // 原交易金额
|
||||
Trxamt string `json:"trxamt"` // 实际交易金额
|
||||
Fee string `json:"fee"` // 手续费
|
||||
Cmid string `json:"cmid"` // 渠道子商户号
|
||||
Chnlid string `json:"chnlid"` // 渠道号
|
||||
Chnldata string `json:"chnldata"` // 渠道信息
|
||||
Accttype string `json:"accttype"` // 借贷标识
|
||||
Sign string `json:"sign"` // 签名
|
||||
}
|
||||
|
||||
// PayTransactionStatusQuery 交易状态查询
|
||||
type PayTransactionStatusQuery struct {
|
||||
Orgid string `json:"orgid"` // 集团/代理商商户号 是 共享集团号/代理商参数时必填
|
||||
Cusid string `json:"cusid"` // 商户号实际交易的商户号 否
|
||||
Appid string `json:"appid"` // 应用ID平台分配的APPID 否
|
||||
Version string `json:"version"` // 版本号接口版本号 可
|
||||
Reqsn string `json:"reqsn"` // 商户交易单号 否 保证商户平台唯一
|
||||
Trxid string `json:"trxid"` // 收银宝平台的交易流水号
|
||||
Randomstr string `json:"randomstr"` // 随机字符串 否 商户自行生成的随机字符串
|
||||
Signtype string `json:"signtype"` /// 签名方式 是
|
||||
Sign string `json:"sign"` // 签名 详见安全规范 否
|
||||
}
|
||||
type PayTransactionStatusResult struct {
|
||||
Cusid string `json:"cusid"` // 商户号实际交易的商户号 否
|
||||
Appid string `json:"appid"` // 应用ID平台分配的APPID 否
|
||||
Trxid string `json:"trxid"` // 收银宝平台的交易流水号
|
||||
Chnltrxid string `json:"chnltrxid"` // 例如微信,支付宝平台的交易单号
|
||||
Reqsn string `json:"reqsn"` // 商户的交易订单号
|
||||
Trxcode string `json:"trxcode"` // 交易类型
|
||||
Trxamt string `json:"trxamt"` // 实际交易金额
|
||||
Trxstatus string `json:"trxstatus"` // 交易的状态,
|
||||
Acct string `json:"acct"` // 支付平台用户标识
|
||||
Fintime string `json:"fintime"` // yyyyMMddHHmmss
|
||||
Randomstr string `json:"randomstr"` // 随机生成的字符串
|
||||
Errmsg string `json:"errmsg"` // 失败的原因说明
|
||||
Cmid string `json:"cmid"` // 渠道子商户号
|
||||
Chnlid string `json:"chnlid"` // 渠道号
|
||||
Initamt string `json:"initamt"` // 原交易金额
|
||||
Fee string `json:"fee"` // 手续费
|
||||
Chnldata string `json:"chnldata"` // 渠道信息
|
||||
Accttype string `json:"accttype"` // 借贷标识
|
||||
Bankcode string `json:"bankcode"` // 所属银行
|
||||
Logonid string `json:"logonid"` // 买家账号
|
||||
Sign string `json:"sign"` // 签名
|
||||
}
|
||||
|
||||
// OnLineOrderRefundParam 订单退款参数
|
||||
type OnLineOrderRefundParam struct {
|
||||
Orgid string `json:"orgid"` // 集团/代理商商户号 是 共享集团号/代理商参数时必填
|
||||
Cusid string `json:"cusid"` // 商户号实际交易的商户号 否
|
||||
Appid string `json:"appid"` // 应用ID平台分配的APPID 否
|
||||
Version string `json:"version"` // 版本号接口版本号 可
|
||||
|
||||
Trxamt string `json:"trxamt"` // 交易金额单位为分 否
|
||||
Reqsn string `json:"reqsn"` // 商户交易单号 否 保证商户平台唯一
|
||||
Oldreqsn string `json:"oldreqsn"` // 原交易订单号 是
|
||||
Oldtrxid string `json:"oldtrxid"` // 原交易流水 是
|
||||
Remark string `json:"remark"` // 备注 是 禁止出现+,空格,/,?,%,#,&, = 这几类特殊符号
|
||||
Benefitdetail string `json:"benefitdetail"` // 优惠信息
|
||||
Randomstr string `json:"randomstr"` // 随机字符串 否 商户自行生成的随机字符串
|
||||
Signtype string `json:"signtype"` /// 签名方式 是
|
||||
Sign string `json:"sign"` // 签名 详见安全规范 否
|
||||
}
|
||||
type OnLineOrderRefundResult struct {
|
||||
Cusid string `json:"cusid"` // 商户号实际交易的商户号 否
|
||||
Appid string `json:"appid"` // 应用ID平台分配的APPID 否
|
||||
Trxid string `json:"trxid"` // 收银宝平台的交易流水号
|
||||
Reqsn string `json:"reqsn"` // 商户的交易订单号
|
||||
Trxstatus string `json:"trxstatus"` // 交易的状态,
|
||||
Fintime string `json:"fintime"` // yyyyMMddHHmmss
|
||||
Errmsg string `json:"errmsg"` // 失败的原因说明
|
||||
Fee string `json:"fee"` // 手续费
|
||||
Trxcode string `json:"trxcode"` // 交易类型
|
||||
Randomstr string `json:"randomstr"` // 随机生成的字符串
|
||||
Chnltrxid string `json:"chnltrxid"` // 例如微信,支付宝平台的交易单号
|
||||
Chnldata string `json:"chnldata"` // 渠道信息
|
||||
Bankcode string `json:"bankcode"` // 所属银行
|
||||
Sign string `json:"sign"` // 签名
|
||||
}
|
||||
Reference in New Issue
Block a user