com.github.binarywang.wxpay.bean.result.WxPayRefundQueryResult Maven / Gradle / Ivy
package com.github.binarywang.wxpay.bean.result;
import com.google.common.collect.Lists;
import com.google.gson.JsonObject;
import com.google.gson.reflect.TypeToken;
import com.thoughtworks.xstream.annotations.XStreamAlias;
import lombok.*;
import me.chanjar.weixin.common.util.json.GsonParser;
import me.chanjar.weixin.common.util.json.WxGsonBuilder;
import org.apache.commons.lang3.StringUtils;
import org.w3c.dom.Document;
import java.io.Serializable;
import java.util.List;
/**
*
* 微信支付-退款查询返回结果
* Created by Binary Wang on 2016-11-24.
*
*
* @author Binary Wang
*/
@Data
@EqualsAndHashCode(callSuper = true)
@NoArgsConstructor
@XStreamAlias("xml")
public class WxPayRefundQueryResult extends BaseWxPayResult implements Serializable {
private static final long serialVersionUID = 5392369423225328754L;
/**
*
* 字段名:设备号.
* 变量名:device_info
* 是否必填:否
* 类型:String(32)
* 示例值:013467007045764
* 描述:终端设备号
*
*/
@XStreamAlias("device_info")
private String deviceInfo;
/**
*
* 字段名:微信订单号.
* 变量名:transaction_id
* 是否必填:是
* 类型:String(32)
* 示例值:1217752501201407033233368018
* 描述:微信订单号
*
*/
@XStreamAlias("transaction_id")
private String transactionId;
/**
*
* 字段名:商户订单号.
* 变量名:out_trade_no
* 是否必填:是
* 类型:String(32)
* 示例值:1217752501201407033233368018
* 描述:商户系统内部的订单号
*
*/
@XStreamAlias("out_trade_no")
private String outTradeNo;
/**
*
* 字段名:订单金额.
* 变量名:total_fee
* 是否必填:是
* 类型:Int
* 示例值:100
* 描述:订单总金额,单位为分,只能为整数,详见支付金额
*
*/
@XStreamAlias("total_fee")
private Integer totalFee;
/**
*
* 字段名:退款总金额.
* 变量名:refund_fee
* 是否必填:是
* 类型:Int
* 示例值:100
* 描述:各退款单的退款金额累加,单位为分,只能为整数,
*
*/
@XStreamAlias("refund_fee")
private Integer refundFee;
/**
*
* 字段名:代金券退款总金额.
* 变量名:coupon_refund_fee
* 是否必填:是
* 类型:Int
* 示例值:100
* 描述:各退款单的代金券退款金额累加,单位为分,只能为整数,
*
*/
@XStreamAlias("coupon_refund_fee")
private Integer couponRefundFee;
/**
*
* 字段名:用户退款金额.
* 变量名:cash_refund_fee
* 是否必填:是
* 类型:Int
* 示例值:100
* 描述:退款给用户的金额,不包含所有优惠券金额,单位为分,只能为整数,
*
*/
@XStreamAlias("cash_refund_fee")
private Integer cashRefundFee;
/**
*
* 字段名:应结订单金额.
* 变量名:settlement_total_fee
* 是否必填:否
* 类型:Int
* 示例值:100
* 描述:应结订单金额=订单金额-非充值代金券金额,应结订单金额<=订单金额。
*
*/
@XStreamAlias("settlement_total_fee")
private Integer settlementTotalFee;
/**
*
* 字段名:货币种类.
* 变量名:fee_type
* 是否必填:否
* 类型:String(8)
* 示例值:CNY
* 描述:订单金额货币类型,符合ISO 4217标准的三位字母代码,默认人民币:CNY,其他值列表详见货币类型
*
*/
@XStreamAlias("fee_type")
private String feeType;
/**
*
* 字段名:现金支付金额.
* 变量名:cash_fee
* 是否必填:是
* 类型:Int
* 示例值:100
* 描述:现金支付金额,单位为分,只能为整数,详见支付金额
*
*/
@XStreamAlias("cash_fee")
private Integer cashFee;
/**
*
* 字段名:退款笔数.
* 变量名:refund_count
* 是否必填:是
* 类型:Int
* 示例值:1
* 描述:退款记录数
*
*/
@XStreamAlias("refund_count")
private Integer refundCount;
private List refundRecords;
/**
* 营销详情.
*/
@XStreamAlias("promotion_detail")
private String promotionDetailString;
private List promotionDetails;
/**
* 组装生成营销详情信息.
*/
public void composePromotionDetails() {
if (StringUtils.isEmpty(this.promotionDetailString)) {
return;
}
JsonObject tmpJson = GsonParser.parse(this.promotionDetailString);
final List promotionDetail = WxGsonBuilder.create()
.fromJson(tmpJson.get("promotion_detail"),
new TypeToken>() {
}.getType()
);
this.setPromotionDetails(promotionDetail);
}
/**
* 组装生成退款记录属性的内容.
*/
public void composeRefundRecords() {
if (this.refundCount != null && this.refundCount > 0) {
this.refundRecords = Lists.newArrayList();
for (int i = 0; i < this.refundCount; i++) {
RefundRecord refundRecord = new RefundRecord();
this.refundRecords.add(refundRecord);
refundRecord.setOutRefundNo(this.getXmlValue("xml/out_refund_no_" + i));
refundRecord.setRefundId(this.getXmlValue("xml/refund_id_" + i));
refundRecord.setRefundChannel(this.getXmlValue("xml/refund_channel_" + i));
refundRecord.setRefundFee(this.getXmlValueAsInt("xml/refund_fee_" + i));
refundRecord.setSettlementRefundFee(this.getXmlValueAsInt("xml/settlement_refund_fee_" + i));
refundRecord.setCouponRefundFee(this.getXmlValueAsInt("xml/coupon_refund_fee_" + i));
refundRecord.setCouponRefundCount(this.getXmlValueAsInt("xml/coupon_refund_count_" + i));
refundRecord.setRefundStatus(this.getXmlValue("xml/refund_status_" + i));
refundRecord.setRefundRecvAccount(this.getXmlValue("xml/refund_recv_accout_" + i));
refundRecord.setRefundSuccessTime(this.getXmlValue("xml/refund_success_time_" + i));
if (refundRecord.getCouponRefundCount() == null || refundRecord.getCouponRefundCount() == 0) {
continue;
}
List coupons = Lists.newArrayList();
for (int j = 0; j < refundRecord.getCouponRefundCount(); j++) {
coupons.add(
new WxPayRefundCouponInfo(
this.getXmlValue("xml/coupon_refund_id_" + i + "_" + j),
this.getXmlValueAsInt("xml/coupon_refund_fee_" + i + "_" + j),
this.getXmlValue("xml/coupon_type_" + i + "_" + j)
)
);
}
refundRecord.setRefundCoupons(coupons);
}
}
}
/**
* 从XML结构中加载额外的熟悉
*
* @param d Document
*/
@Override
protected void loadXml(Document d) {
deviceInfo = readXmlString(d, "device_info");
transactionId = readXmlString(d, "transaction_id");
outTradeNo = readXmlString(d, "out_trade_no");
totalFee = readXmlInteger(d, "total_fee");
settlementTotalFee = readXmlInteger(d, "settlement_total_fee");
feeType = readXmlString(d, "fee_type");
cashFee = readXmlInteger(d, "cash_fee");
refundCount = readXmlInteger(d, "refund_count");
}
/**
* The type Refund record.
*/
@Data
@Builder(builderMethodName = "newBuilder")
@NoArgsConstructor
@AllArgsConstructor
public static class RefundRecord implements Serializable {
private static final long serialVersionUID=1L;
/**
*
* 字段名:商户退款单号.
* 变量名:out_refund_no_$n
* 是否必填:是
* 类型:String(32)
* 示例值:1217752501201407033233368018
* 描述:商户退款单号
*
*/
@XStreamAlias("out_refund_no")
private String outRefundNo;
/**
*
* 字段名:微信退款单号.
* 变量名:refund_id_$n
* 是否必填:是
* 类型:String(28)
* 示例值:1217752501201407033233368018
* 描述:微信退款单号
*
*/
@XStreamAlias("refund_id")
private String refundId;
/**
*
* 字段名:退款渠道.
* 变量名:refund_channel_$n
* 是否必填:否
* 类型:String(16)
* 示例值:ORIGINAL
* 描述:ORIGINAL—原路退款 BALANCE—退回到余额
*
*/
@XStreamAlias("refund_channel")
private String refundChannel;
/**
*
* 字段名:申请退款金额.
* 变量名:refund_fee_$n
* 是否必填:是
* 类型:Int
* 示例值:100
* 描述:退款总金额,单位为分,可以做部分退款
*
*/
@XStreamAlias("refund_fee")
private Integer refundFee;
/**
*
* 字段名:退款金额.
* 变量名:settlement_refund_fee_$n
* 是否必填:否
* 类型:Int
* 示例值:100
* 描述:退款金额=申请退款金额-非充值代金券退款金额,退款金额<=申请退款金额
*
*/
@XStreamAlias("settlement_refund_fee")
private Integer settlementRefundFee;
/**
*
* 字段名:退款资金来源.
* 变量名:refund_account
* 是否必填:否
* 类型:String(30)
* 示例值:REFUND_SOURCE_RECHARGE_FUNDS
* 描述:REFUND_SOURCE_RECHARGE_FUNDS---可用余额退款/基本账户, REFUND_SOURCE_UNSETTLED_FUNDS---未结算资金退款
*
*/
@XStreamAlias("refund_account")
private String refundAccount;
/**
*
* 字段名:代金券退款金额.
* 变量名:coupon_refund_fee_$n
* 是否必填:否
* 类型:Int
* 示例值:100
* 描述:代金券退款金额<=退款金额,退款金额-代金券或立减优惠退款金额为现金,说明详见代金券或立减优惠
*
*/
@XStreamAlias("coupon_refund_fee")
private Integer couponRefundFee;
/**
*
* 字段名:退款代金券使用数量.
* 变量名:coupon_refund_count_$n
* 是否必填:否
* 类型:Int
* 示例值:1
* 描述:退款代金券使用数量 ,$n为下标,从0开始编号
*
*/
@XStreamAlias("coupon_refund_count")
private Integer couponRefundCount;
private List refundCoupons;
/**
*
* 字段名:退款状态.
* 变量名:refund_status_$n
* 是否必填:是
* 类型:String(16)
* 示例值:SUCCESS
* 描述:退款状态:
* SUCCESS—退款成功,
* FAIL—退款失败,
* PROCESSING—退款处理中,
* CHANGE—转入代发,
* 退款到银行发现用户的卡作废或者冻结了,导致原路退款银行卡失败,资金回流到商户的现金帐号,需要商户人工干预,通过线下或者财付通转账的方式进行退款。
*
*/
@XStreamAlias("refund_status")
private String refundStatus;
/**
*
* 字段名:退款入账账户.
* 变量名:refund_recv_accout_$n
* 是否必填:是
* 类型:String(64)
* 示例值:招商银行信用卡0403
* 描述:取当前退款单的退款入账方,1)退回银行卡:{银行名称}{卡类型}{卡尾号},2)退回支付用户零钱:支付用户零钱
*
*/
@XStreamAlias("refund_recv_accout")
private String refundRecvAccount;
/**
*
* 字段名:退款成功时间.
* 变量名:refund_success_time_$n
* 是否必填:否
* 类型:String(20)
* 示例值:2016-07-25 15:26:26
* 描述:退款成功时间,当退款状态为退款成功时有返回。$n为下标,从0开始编号。
*
*/
@XStreamAlias("refund_success_time")
private String refundSuccessTime;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy