All Downloads are FREE. Search and download functionalities are using the official Maven repository.

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