This commit is contained in:
邹宗楠
2025-04-27 10:17:40 +08:00
parent cf38acc037
commit 1a5a3ffc29
14 changed files with 920 additions and 156 deletions

View 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"` // 签名
}