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

com.github.binarywang.wxpay.bean.notify.WxPayPartnerRefundNotifyV3Result Maven / Gradle / Ivy

package com.github.binarywang.wxpay.bean.notify;

import com.google.gson.annotations.SerializedName;
import lombok.Data;
import lombok.NoArgsConstructor;

import java.io.Serializable;

/**
 * 微信支付服务商退款回调
 * 文档见:https://pay.weixin.qq.com/wiki/doc/apiv3_partner/apis/chapter4_1_11.shtml
 *
 * @author Pursuer
 * @version 1.0
 * @date 2023/3/2
 */
@Data
@NoArgsConstructor
public class WxPayPartnerRefundNotifyV3Result implements Serializable, WxPayBaseNotifyV3Result {
  private static final long serialVersionUID = -1L;
  /**
   * 源数据
   */
  private OriginNotifyResponse rawData;
  /**
   * 解密后的数据
   */
  private DecryptNotifyResult result;

  @Data
  @NoArgsConstructor
  public static class DecryptNotifyResult implements Serializable {
    private static final long serialVersionUID = -1L;
    /**
     * 
     * 字段名:服务商的商户号
     * 变量名:sub_mchid
     * 是否必填:是
     * 类型:string[1, 32]
     * 描述:
     *  服务商的商户号,由微信支付生成并下发。
     *  示例值:1230000109
     * 
*/ @SerializedName(value = "sp_mchid") private String spMchId; /** *
     * 字段名:子商户的商户号
     * 变量名:sub_mchid
     * 是否必填:是
     * 类型:string[1, 32]
     * 描述:
     *  子商户商户号,由微信支付生成并下发。
     *  示例值:1230000109
     * 
*/ @SerializedName(value = "sub_mchid") private String subMchId; /** *
     * 字段名:商户订单号
     * 变量名:out_trade_no
     * 是否必填:是
     * 类型:string[1,32]
     * 描述:
     *  返回的商户订单号
     *  示例值: 1217752501201407033233368018
     * 
*/ @SerializedName(value = "out_trade_no") private String outTradeNo; /** *
     * 字段名:微信支付订单号
     * 变量名:transaction_id
     * 是否必填:是
     * 类型:string[1,32]
     * 描述:
     *  微信支付订单号
     *  示例值: 1217752501201407033233368018
     * 
*/ @SerializedName(value = "transaction_id") private String transactionId; /** *
     * 字段名:商户退款单号
     * 变量名:out_refund_no
     * 是否必填:是
     * 类型:string[1,64]
     * 描述:
     *  商户退款单号
     *  示例值: 1217752501201407033233368018
     * 
*/ @SerializedName(value = "out_refund_no") private String outRefundNo; /** *
     * 字段名:微信支付退款号
     * 变量名:refund_id
     * 是否必填:是
     * 类型:string[1,32]
     * 描述:
     *  微信退款单号
     *  示例值: 1217752501201407033233368018
     * 
*/ @SerializedName(value = "refund_id") private String refundId; /** *
     * 字段名:退款状态
     * 变量名:refund_status
     * 是否必填:是
     * 类型:string[1,16]
     * 描述:
     *  退款状态,枚举值:
     *  SUCCESS:退款成功
     *  CLOSE:退款关闭
     *  ABNORMAL:退款异常,退款到银行发现用户的卡作废或者冻结了,导致原路退款银行卡失败,可前往【商户平台—>交易中心】,手动处理此笔退款
     *  示例值:SUCCESS
     * 
*/ @SerializedName(value = "refund_status") private String refundStatus; /** *
     * 字段名:退款成功时间
     * 变量名:success_time
     * 是否必填:否
     * 类型:string[1,64]
     * 描述:
     *  1、退款成功时间,遵循rfc3339标准格式,格式为YYYY-MM-DDTHH:mm:ss+TIMEZONE,YYYY-MM-DD表示年月日,T出现在字符串中,表示time元素的开头,HH:mm:ss表示时分秒,TIMEZONE表示时区(+08:00表示东八区时间,领先UTC 8小时,即北京时间)。例如:2015-05-20T13:29:35+08:00表示,北京时间2015年5月20日13点29分35秒。
     *  2、当退款状态为退款成功时返回此参数。
     *  示例值:2018-06-08T10:34:56+08:00
     * 
*/ @SerializedName(value = "success_time") private String successTime; /** *
     * 字段名:退款入账账户
     * 变量名:user_received_account
     * 是否必填:是
     * 类型:string[1,64]
     * 描述:
     *  取当前退款单的退款入账方。
     *  1、退回银行卡:{银行名称}{卡类型}{卡尾号}
     *  2、退回支付用户零钱: 支付用户零钱
     *  3、退还商户: 商户基本账户、商户结算银行账户
     *  4、退回支付用户零钱通:支付用户零钱通
     *  示例值:招商银行信用卡0403
     * 
*/ @SerializedName(value = "user_received_account") private String userReceivedAccount; /** *
     * 字段名:金额信息
     * 变量名:amount
     * 是否必填:是
     * 类型:object
     * 描述:
     *  金额信息
     * 
*/ @SerializedName(value = "amount") private Amount amount; } @Data @NoArgsConstructor public static class Amount implements Serializable { private static final long serialVersionUID = 1L; /** *
     * 字段名:订单金额
     * 变量名:total
     * 是否必填:是
     * 类型:int
     * 描述:
     *  订单总金额,单位为分,只能为整数,详见支付金额
     *  示例值:999
     * 
*/ @SerializedName(value = "total") private Integer total; /** *
     * 字段名:退款金额
     * 变量名:refund
     * 是否必填:是
     * 类型:int
     * 描述:
     *  退款金额,币种的最小单位,只能为整数,不能超过原订单支付金额,如果有使用券,后台会按比例退。
     *  示例值:999
     * 
*/ @SerializedName(value = "refund") private Integer refund; /** *
     * 字段名:用户支付金额
     * 变量名:payer_total
     * 是否必填:是
     * 类型:int
     * 描述:
     *  用户实际支付金额,单位为分,只能为整数,详见支付金额
     *  示例值:999
     * 
*/ @SerializedName(value = "payer_total") private Integer payerTotal; /** *
     * 字段名:用户退款金额
     * 变量名:payer_refund
     * 是否必填:是
     * 类型:int
     * 描述:
     *  退款给用户的金额,不包含所有优惠券金额
     *  示例值:999
     * 
*/ @SerializedName(value = "payer_refund") private Integer payerRefund; } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy