Compare commits
No commits in common. "main" and "v1.0.22" have entirely different histories.
|
|
@ -24,7 +24,6 @@ const (
|
||||||
LKL_ACCOUNT_BALANCE_QUERY_URL = "/v2/laep/industry/ewalletBalanceQuery"
|
LKL_ACCOUNT_BALANCE_QUERY_URL = "/v2/laep/industry/ewalletBalanceQuery"
|
||||||
// LKL_ACCOUNT_WITHDRAW_URL 拉卡拉账户提现
|
// LKL_ACCOUNT_WITHDRAW_URL 拉卡拉账户提现
|
||||||
LKL_ACCOUNT_WITHDRAW_URL = "/v2/laep/industry/ewalletWithdrawD1"
|
LKL_ACCOUNT_WITHDRAW_URL = "/v2/laep/industry/ewalletWithdrawD1"
|
||||||
LKL_SPLIT_LEDGER_FALLBACK_URL = "/v3/sacs/fallback"
|
|
||||||
)
|
)
|
||||||
|
|
||||||
const (
|
const (
|
||||||
|
|
@ -57,8 +56,6 @@ const (
|
||||||
LKL_EC_APPLY_MANUAL = "/v3/mms/open_api/ec/apply_manual"
|
LKL_EC_APPLY_MANUAL = "/v3/mms/open_api/ec/apply_manual"
|
||||||
// LKL_EC_QMA_STATUS 拉卡拉商户电子合同人工复核结果查询
|
// LKL_EC_QMA_STATUS 拉卡拉商户电子合同人工复核结果查询
|
||||||
LKL_EC_QMA_STATUS = "/v3/mms/open_api/ec/qma_status"
|
LKL_EC_QMA_STATUS = "/v3/mms/open_api/ec/qma_status"
|
||||||
LKL_QUERY_SUB_MER_INFO_URL = "/v2/mms/openApi/querySubMerInfo"
|
|
||||||
LKL_MRCH_AUTH_STATE_QUERY_URL = "/v2/mms/sme/mrchAuthStateQuery"
|
|
||||||
)
|
)
|
||||||
|
|
||||||
// unifiedReturn 统一退货API地址
|
// unifiedReturn 统一退货API地址
|
||||||
|
|
|
||||||
|
|
@ -205,48 +205,3 @@ func (t *MerService[T]) ReconsiderSubmitTest(req *model.ReConfSubmitRequestData)
|
||||||
}
|
}
|
||||||
return respBody, nil
|
return respBody, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func (t *MerService[T]) QuerySubMerInfo(req *model.QuerySubMerInfoReqData) (*T, error) {
|
|
||||||
// 构建请求参数
|
|
||||||
url := consts.BASE_URL + consts.LKL_QUERY_SUB_MER_INFO_URL
|
|
||||||
md5, err := gmd5.Encrypt(gconv.String(time.Now().Unix()))
|
|
||||||
if err != nil {
|
|
||||||
return nil, fmt.Errorf("创建ReqId失败")
|
|
||||||
}
|
|
||||||
// 构建BaseModel请求
|
|
||||||
baseReq := model.QuerySubMerInfoRequest{
|
|
||||||
ReqData: req,
|
|
||||||
ReqId: md5,
|
|
||||||
Timestamp: time.Now().Unix(),
|
|
||||||
Ver: "1.0",
|
|
||||||
}
|
|
||||||
|
|
||||||
// 发送请求
|
|
||||||
respBody, err := t.client.DoRequest(url, baseReq)
|
|
||||||
if err != nil {
|
|
||||||
return nil, err
|
|
||||||
}
|
|
||||||
return respBody, nil
|
|
||||||
}
|
|
||||||
func (t *MerService[T]) MrchAuthStateQuery(req *model.MrchAuthStateQueryReqData) (*T, error) {
|
|
||||||
// 构建请求参数
|
|
||||||
url := consts.BASE_URL + consts.LKL_MRCH_AUTH_STATE_QUERY_URL
|
|
||||||
md5, err := gmd5.Encrypt(gconv.String(time.Now().Unix()))
|
|
||||||
if err != nil {
|
|
||||||
return nil, fmt.Errorf("创建ReqId失败")
|
|
||||||
}
|
|
||||||
// 构建BaseModel请求
|
|
||||||
baseReq := model.MrchAuthStateQueryRequest{
|
|
||||||
ReqData: req,
|
|
||||||
ReqId: md5,
|
|
||||||
Timestamp: time.Now().Unix(),
|
|
||||||
Ver: "1.0",
|
|
||||||
}
|
|
||||||
|
|
||||||
// 发送请求
|
|
||||||
respBody, err := t.client.DoRequest(url, baseReq)
|
|
||||||
if err != nil {
|
|
||||||
return nil, err
|
|
||||||
}
|
|
||||||
return respBody, nil
|
|
||||||
}
|
|
||||||
|
|
|
||||||
|
|
@ -153,11 +153,6 @@ func (s *SDK[T]) OrderSplitLedgerTest(req *model.OrderSplitLedgerReqData) (*T, e
|
||||||
return s.SplitLedger.OrderSplitLedgerTest(req)
|
return s.SplitLedger.OrderSplitLedgerTest(req)
|
||||||
}
|
}
|
||||||
|
|
||||||
// OrderSplitLedgerFallback 订单分账回退
|
|
||||||
func (s *SDK[T]) OrderSplitLedgerFallback(req *model.OrderSplitLedgerFallbackReqData) (*T, error) {
|
|
||||||
return s.SplitLedger.OrderSplitLedgerFallback(req)
|
|
||||||
}
|
|
||||||
|
|
||||||
// TradeQuery 交易查询
|
// TradeQuery 交易查询
|
||||||
func (s *SDK[T]) TradeQuery(req *model.TradeQueryReqData) (*T, error) {
|
func (s *SDK[T]) TradeQuery(req *model.TradeQueryReqData) (*T, error) {
|
||||||
return s.Trade.TradeQuery(req)
|
return s.Trade.TradeQuery(req)
|
||||||
|
|
@ -242,11 +237,3 @@ func (s *SDK[T]) ECQmaStatus(req *ecQmaStatus.ECQmaStatusRequestData) (*ecQmaSta
|
||||||
func (s *SDK[T]) ECQmaStatusTest(req *ecQmaStatus.ECQmaStatusRequestData) (*ecQmaStatus.ECQmaStatusResponse, error) {
|
func (s *SDK[T]) ECQmaStatusTest(req *ecQmaStatus.ECQmaStatusRequestData) (*ecQmaStatus.ECQmaStatusResponse, error) {
|
||||||
return s.ECPeQmaStatus.ECQmaStatusTest(req)
|
return s.ECPeQmaStatus.ECQmaStatusTest(req)
|
||||||
}
|
}
|
||||||
|
|
||||||
func (s *SDK[T]) QuerySubMerInfo(req *model.QuerySubMerInfoReqData) (*T, error) {
|
|
||||||
return s.Merchant.QuerySubMerInfo(req)
|
|
||||||
}
|
|
||||||
|
|
||||||
func (s *SDK[T]) MrchAuthStateQuery(req *model.MrchAuthStateQueryReqData) (*T, error) {
|
|
||||||
return s.Merchant.MrchAuthStateQuery(req)
|
|
||||||
}
|
|
||||||
|
|
|
||||||
|
|
@ -137,22 +137,3 @@ func (s *SplitLedgerService[T]) OrderSplitLedgerTest(req *model.OrderSplitLedger
|
||||||
}
|
}
|
||||||
return respBody, nil
|
return respBody, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func (s *SplitLedgerService[T]) OrderSplitLedgerFallback(req *model.OrderSplitLedgerFallbackReqData) (*T, error) {
|
|
||||||
// 构建请求参数
|
|
||||||
url := consts.BASE_URL + consts.LKL_SPLIT_LEDGER_FALLBACK_URL
|
|
||||||
|
|
||||||
// 构建BaseModel请求
|
|
||||||
baseReq := model.OrderSplitLedgerFallbackRequest{
|
|
||||||
ReqTime: time.Now().Format("20060102150405"),
|
|
||||||
Version: "3.0",
|
|
||||||
ReqData: req,
|
|
||||||
}
|
|
||||||
|
|
||||||
// 发送请求
|
|
||||||
respBody, err := s.client.DoRequest(url, baseReq)
|
|
||||||
if err != nil {
|
|
||||||
return nil, err
|
|
||||||
}
|
|
||||||
return respBody, nil
|
|
||||||
}
|
|
||||||
|
|
|
||||||
|
|
@ -35,30 +35,30 @@ type BalanceQueryReqData struct {
|
||||||
// 包含响应状态码、消息和业务数据
|
// 包含响应状态码、消息和业务数据
|
||||||
type BalanceQueryResponse struct {
|
type BalanceQueryResponse struct {
|
||||||
// 响应状态码,000000
|
// 响应状态码,000000
|
||||||
Code string `json:"retCode"`
|
Code string `json:"code"`
|
||||||
// 响应消息
|
// 响应消息
|
||||||
Msg string `json:"retMsg"`
|
Msg string `json:"msg"`
|
||||||
// 响应业务数据,当code为SACS0000时返回
|
// 响应业务数据,当code为SACS0000时返回
|
||||||
RespData *BalanceQueryRespData `json:"respData"`
|
RespData *BalanceQueryRespData `json:"resp_data"`
|
||||||
}
|
}
|
||||||
|
|
||||||
// BalanceQueryRespData 余额查询响应业务数据结构体
|
// BalanceQueryRespData 余额查询响应业务数据结构体
|
||||||
// 包含余额查询返回的具体账户信息
|
// 包含余额查询返回的具体账户信息
|
||||||
type BalanceQueryRespData struct {
|
type BalanceQueryRespData struct {
|
||||||
// 账号,必传
|
// 账号,必传
|
||||||
PayNo string `json:"payNo"`
|
PayNo string `json:"pay_no"`
|
||||||
// 账户类型,必传
|
// 账户类型,必传
|
||||||
PayType string `json:"payType"`
|
PayType string `json:"pay_type"`
|
||||||
// 账户状态,必传,取值说明:CLOSE销户,NORMAL正常,FREEZE冻结,STOPAY止付
|
// 账户状态,必传,取值说明:CLOSE销户,NORMAL正常,FREEZE冻结,STOPAY止付
|
||||||
AcctSt string `json:"acctSt"`
|
AcctSt string `json:"acct_st"`
|
||||||
// 预付余额(单位元),必传
|
// 预付余额(单位元),必传
|
||||||
ForceBalance string `json:"forceBalance"`
|
ForceBalance string `json:"force_balance"`
|
||||||
// 上日余额(单位元)-该字段已废弃使用,必传
|
// 上日余额(单位元)-该字段已废弃使用,必传
|
||||||
HisBalance string `json:"hisBalance"`
|
HisBalance string `json:"his_balance"`
|
||||||
// 实时余额(单位元),必传
|
// 实时余额(单位元),必传
|
||||||
ReBalance string `json:"reBalance"`
|
ReBalance string `json:"re_balance"`
|
||||||
// 当前可用余额(单位元),必传
|
// 当前可用余额(单位元),必传
|
||||||
CuBalance string `json:"cuBalance"`
|
CuBalance string `json:"cu_balance"`
|
||||||
}
|
}
|
||||||
|
|
||||||
// SuccessOrFail 判断余额查询请求是否成功
|
// SuccessOrFail 判断余额查询请求是否成功
|
||||||
|
|
|
||||||
|
|
@ -1,29 +0,0 @@
|
||||||
package model
|
|
||||||
|
|
||||||
type MrchAuthStateQueryRequest struct {
|
|
||||||
ReqData *MrchAuthStateQueryReqData `json:"reqData"`
|
|
||||||
Ver string `json:"ver"`
|
|
||||||
Timestamp int64 `json:"timestamp"`
|
|
||||||
ReqId string `json:"reqId"`
|
|
||||||
}
|
|
||||||
|
|
||||||
type MrchAuthStateQueryReqData struct {
|
|
||||||
TradeMode string `json:"tradeMode" dc:"交易模式"`
|
|
||||||
SubMerchantId string `json:"subMerchantId" dc:"子商户号"`
|
|
||||||
MerchantNo string `json:"merchantNo" dc:"商户号"`
|
|
||||||
}
|
|
||||||
|
|
||||||
type MrchAuthStateQueryResponse struct {
|
|
||||||
RetCode string `json:"retCode"`
|
|
||||||
RetMsg string `json:"retMsg"`
|
|
||||||
RespData *MrchAuthStateQueryRespData `json:"respData"`
|
|
||||||
}
|
|
||||||
|
|
||||||
type MrchAuthStateQueryRespData struct {
|
|
||||||
SubMerchantId string `json:"subMerchantId"`
|
|
||||||
CheckResult string `json:"checkResult"`
|
|
||||||
}
|
|
||||||
|
|
||||||
func (t *MrchAuthStateQueryResponse) SuccessOrFail() bool {
|
|
||||||
return t.RetCode == "000000"
|
|
||||||
}
|
|
||||||
|
|
@ -1,40 +0,0 @@
|
||||||
package model
|
|
||||||
|
|
||||||
type OrderSplitLedgerFallbackRequest struct {
|
|
||||||
ReqData *OrderSplitLedgerFallbackReqData `json:"req_data"` // 请求业务数据
|
|
||||||
Version string `json:"version"` // 接口版本号
|
|
||||||
ReqTime string `json:"req_time"` // 请求时间,格式为yyyyMMddHHmmss
|
|
||||||
}
|
|
||||||
|
|
||||||
type OrderSplitLedgerFallbackReqData struct {
|
|
||||||
MerchantNo string `json:"merchant_no"` // 商户号,必传,长度32
|
|
||||||
OriginSeparateNo string `json:"origin_separate_no"` // 原分账单号,必传,长度32
|
|
||||||
OutSeparateNo string `json:"out_separate_no"` // 外部分账单号,必传,长度32
|
|
||||||
OriginOutSeparateNo string `json:"origin_out_separate_no"` // 原外部分账单号,必传,长度32
|
|
||||||
FallbackReason string `json:"fallback_reason"` // 回退原因,必传,长度255
|
|
||||||
TotalAmt string `json:"total_amt"` // 总金额,必传,长度15
|
|
||||||
OriginRecvDatas []*OrderSplitLedgerOriginRecvDatas `json:"origin_recv_datas"` // 原分账接收数据,必传,数组长度1-100
|
|
||||||
}
|
|
||||||
|
|
||||||
type OrderSplitLedgerOriginRecvDatas struct {
|
|
||||||
RecvNo string `json:"recv_no"` // 原分账接收号,必传,长度32
|
|
||||||
Amt string `json:"amt"` // 原分账接收金额,必传,长度15
|
|
||||||
}
|
|
||||||
|
|
||||||
type OrderSplitLedgerFallbackResponse struct {
|
|
||||||
Msg string `json:"msg"` // 消息
|
|
||||||
RespTime string `json:"resp_time"` // 响应时间
|
|
||||||
Code string `json:"code"` // 响应码 SACS0000表示成功
|
|
||||||
RespData struct {
|
|
||||||
OutSeparateNo string `json:"out_separate_no"` // 外部分账单号,必传,长度32
|
|
||||||
TotalAmt string `json:"total_amt"` // 总金额,必传,长度15
|
|
||||||
OriginOutSeparateNo string `json:"origin_out_separate_no"` // 原外部分账单号,必传,长度32
|
|
||||||
OriginSeparateNo string `json:"origin_separate_no"` // 原分账单号,必传,长度32
|
|
||||||
Status string `json:"status"` // 状态,必传,长度1
|
|
||||||
SeparateNo string `json:"separate_no"` // 分账单号,必传,长度32
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func (s *OrderSplitLedgerFallbackResponse) SuccessOrFail() bool {
|
|
||||||
return s.Code == "SACS0000"
|
|
||||||
}
|
|
||||||
|
|
@ -27,7 +27,6 @@ type PreorderReqData struct {
|
||||||
Location string `json:"location"` // 纬度,经度,商户终端的地理位置,银联二维码交易必填,整体格式:纬度,经度,+表示北纬、东经,-表示南纬、西经。经度格式:1位正负号+3位整数+1位小数点+5位小数;纬度格式:1位正负号+2位整数+1位小数点+6位小数;举例:+31.221345,+121.12345,String(32)
|
Location string `json:"location"` // 纬度,经度,商户终端的地理位置,银联二维码交易必填,整体格式:纬度,经度,+表示北纬、东经,-表示南纬、西经。经度格式:1位正负号+3位整数+1位小数点+5位小数;纬度格式:1位正负号+2位整数+1位小数点+6位小数;举例:+31.221345,+121.12345,String(32)
|
||||||
} `json:"location_info"` // 地址位置信息,Object
|
} `json:"location_info"` // 地址位置信息,Object
|
||||||
Subject string `json:"subject"` // 订单标题,用于简单描述订单或商品主题,传输给账户端(账户端控制,实际最多42个字节),微信支付必送,String(42)
|
Subject string `json:"subject"` // 订单标题,用于简单描述订单或商品主题,传输给账户端(账户端控制,实际最多42个字节),微信支付必送,String(42)
|
||||||
AccBusiFields *AccBusiFields `json:"acc_busi_fields"` // 账户业务字段,Object
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func NewPreorder(param *PreorderReqData) *Preorder {
|
func NewPreorder(param *PreorderReqData) *Preorder {
|
||||||
|
|
|
||||||
|
|
@ -33,9 +33,9 @@ type QueryLedgerMerReqData struct {
|
||||||
// 包含响应状态码、消息和业务数据
|
// 包含响应状态码、消息和业务数据
|
||||||
type QueryLedgerMerResponse struct {
|
type QueryLedgerMerResponse struct {
|
||||||
// 响应状态码,000000表示成功
|
// 响应状态码,000000表示成功
|
||||||
RetCode string `json:"retCode"`
|
Code string `json:"code"`
|
||||||
// 响应消息
|
// 响应消息
|
||||||
RetMsg string `json:"retMsg"`
|
Msg string `json:"msg"`
|
||||||
// 响应业务数据,当code为000000时返回
|
// 响应业务数据,当code为000000时返回
|
||||||
RespData *QueryLedgerMerRespData `json:"respData"`
|
RespData *QueryLedgerMerRespData `json:"respData"`
|
||||||
}
|
}
|
||||||
|
|
@ -52,7 +52,7 @@ type QueryLedgerMerRespData struct {
|
||||||
// 银联商户号
|
// 银联商户号
|
||||||
MerCupNo string `json:"merCupNo"`
|
MerCupNo string `json:"merCupNo"`
|
||||||
// 最低分账比例(百分比,支持2位精度),取值说明:70或70.50
|
// 最低分账比例(百分比,支持2位精度),取值说明:70或70.50
|
||||||
SplitLowestRatio float64 `json:"splitLowestRatio"`
|
SplitLowestRatio string `json:"splitLowestRatio"`
|
||||||
// 商户分账状态,取值说明:VALID启用,INVALID禁用
|
// 商户分账状态,取值说明:VALID启用,INVALID禁用
|
||||||
SplitStatus string `json:"splitStatus"`
|
SplitStatus string `json:"splitStatus"`
|
||||||
// 分账范围,取值说明:ALL:全部交易分账(商户所有交易默认待分账),MARK:标记交易分账(只有带分账标识交易待分账,其余交易正常结算),默认:MARK
|
// 分账范围,取值说明:ALL:全部交易分账(商户所有交易默认待分账),MARK:标记交易分账(只有带分账标识交易待分账,其余交易正常结算),默认:MARK
|
||||||
|
|
@ -86,5 +86,5 @@ type BindRelation struct {
|
||||||
// 成功条件:响应码为000000
|
// 成功条件:响应码为000000
|
||||||
// 返回值:true表示成功,false表示失败
|
// 返回值:true表示成功,false表示失败
|
||||||
func (resp *QueryLedgerMerResponse) SuccessOrFail() bool {
|
func (resp *QueryLedgerMerResponse) SuccessOrFail() bool {
|
||||||
return resp.RetCode == "000000"
|
return resp.Code == "000000"
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -1,50 +0,0 @@
|
||||||
package model
|
|
||||||
|
|
||||||
type QuerySubMerInfoRequest struct {
|
|
||||||
ReqData *QuerySubMerInfoReqData `json:"reqData"`
|
|
||||||
Ver string `json:"ver"`
|
|
||||||
Timestamp int64 `json:"timestamp"`
|
|
||||||
ReqId string `json:"reqId"`
|
|
||||||
}
|
|
||||||
|
|
||||||
type QuerySubMerInfoReqData struct {
|
|
||||||
Version string `json:"version" dc:"接口版本号"`
|
|
||||||
OrderNo string `json:"orderNo" dc:"订单编号,保证唯一"`
|
|
||||||
OrgCode string `json:"orgCode" dc:"机构代码"`
|
|
||||||
MerInnerNo string `json:"merInnerNo" dc:"拉卡拉内部商户号和银联商户号必须传一个,都送以内部商户号为准。"`
|
|
||||||
MerCupNo string `json:"merCupNo" dc:"拉卡拉内部商户号和银联商户号必须传一个,都送以内部商户号为准。"`
|
|
||||||
RegisterChannel string `json:"registerChannel" dc:"报备渠道"`
|
|
||||||
RegisterType string `json:"registerType" dc:"报备类型"`
|
|
||||||
RegisterStatus string `json:"registerStatus" dc:"报备状态 SUCCESS:成功;FAIL:失败"`
|
|
||||||
SubMchId string `json:"subMchId" dc:"子商户号"`
|
|
||||||
}
|
|
||||||
|
|
||||||
type QuerySubMerInfoResponse struct {
|
|
||||||
RetCode string `json:"retCode"`
|
|
||||||
RetMsg string `json:"retMsg"`
|
|
||||||
RespData *QuerySubMerInfoRespData `json:"respData"`
|
|
||||||
}
|
|
||||||
|
|
||||||
type QuerySubMerInfoRespData struct {
|
|
||||||
OrgCode string `json:"orgCode"`
|
|
||||||
OrderNo string `json:"orderNo"`
|
|
||||||
List []*RegisterList `json:"list"`
|
|
||||||
}
|
|
||||||
type RegisterList struct {
|
|
||||||
MerInnerNo string `json:"merInnerNo" dc:"内部商户号"`
|
|
||||||
SubMchId string `json:"subMchId" dc:"子商户号"`
|
|
||||||
SubMchIdBank string `json:"subMchIdBank" dc:"交易子商户号"`
|
|
||||||
DcWalletId string `json:"dcWalletId" dc:"数币钱包ID"`
|
|
||||||
ChannelId string `json:"channelId" dc:"渠道号"`
|
|
||||||
ReceOrgNo string `json:"receOrgNo" dc:"从业机构号"`
|
|
||||||
RegisterChannel string `json:"registerChannel" dc:"报备渠道"`
|
|
||||||
RegisterType string `json:"registerType" dc:"报备类型"`
|
|
||||||
RegisterTm string `json:"registerTm" dc:"报备时间"`
|
|
||||||
RegisterStatus string `json:"registerStatus" dc:"报备状态"`
|
|
||||||
ResultCode string `json:"resultCode" dc:"结果返回码"`
|
|
||||||
ResultMessage string `json:"resultMessage" dc:"结果描述"`
|
|
||||||
}
|
|
||||||
|
|
||||||
func (t *QuerySubMerInfoResponse) SuccessOrFail() bool {
|
|
||||||
return t.RetCode == "000000"
|
|
||||||
}
|
|
||||||
|
|
@ -69,5 +69,5 @@ type TradeQueryResponse struct {
|
||||||
}
|
}
|
||||||
|
|
||||||
func (t *TradeQueryResponse) SuccessOrFail() bool {
|
func (t *TradeQueryResponse) SuccessOrFail() bool {
|
||||||
return t.Code == "BBS00000"
|
return t.Code == "000000"
|
||||||
}
|
}
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue