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

com.github.binarywang.wxpay.bean.result.WxPayRefundV3Result Maven / Gradle / Ivy

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

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

import java.io.Serializable;
import java.util.List;

/**
 * 
 * 微信支付-申请退款返回结果.
 * https://pay.weixin.qq.com/wiki/doc/apiv3/apis/chapter3_1_9.shtml
 * 
* * @author thinsstar */ @Data @NoArgsConstructor public class WxPayRefundV3Result implements Serializable { private static final long serialVersionUID = -1L; /** *
   * 字段名:微信支付退款号
   * 变量名:refund_id
   * 是否必填:是
   * 类型:string[1, 32]
   * 描述:
   *  微信支付退款号
   *  示例值:50000000382019052709732678859
   * 
*/ @SerializedName(value = "refund_id") private String refundId; /** *
   * 字段名:商户退款单号
   * 变量名:out_refund_no
   * 是否必填:是
   * 类型:string[1, 64]
   * 描述:
   *  商户系统内部的退款单号,商户系统内部唯一,只能是数字、大小写字母_-|*@ ,同一退款单号多次请求只退一笔。
   *  示例值:1217752501201407033233368018
   * 
*/ @SerializedName(value = "out_refund_no") private String outRefundNo; /** *
   * 字段名:微信支付订单号
   * 变量名:transaction_id
   * 是否必填:是
   * 类型:string[1, 32]
   * 描述:
   *  微信支付交易订单号
   *  示例值:1217752501201407033233368018
   * 
*/ @SerializedName(value = "transaction_id") private String transactionId; /** *
   * 字段名:商户订单号
   * 变量名:out_trade_no
   * 是否必填:是
   * 类型:string[1, 32]
   * 描述:
   *  原支付交易对应的商户订单号
   *  示例值:1217752501201407033233368018
   * 
*/ @SerializedName(value = "out_trade_no") private String outTradeNo; /** *
   * 字段名:退款渠道
   * 变量名:channel
   * 是否必填:是
   * 类型:string[1, 16]
   * 描述:
   *  枚举值:
   *  ORIGINAL—原路退款
   *  BALANCE—退回到余额
   *  OTHER_BALANCE—原账户异常退到其他余额账户
   *  OTHER_BANKCARD—原银行卡异常退到其他银行卡
   *  示例值:ORIGINAL
   * 
*/ @SerializedName(value = "channel") private String channel; /** *
   * 字段名:退款入账账户
   * 变量名:user_received_account
   * 是否必填:是
   * 类型:string[1, 64]
   * 描述:
   *  取当前退款单的退款入账方,有以下几种情况:
   *  1)退回银行卡:{银行名称}{卡类型}{卡尾号}
   *  2)退回支付用户零钱:支付用户零钱
   *  3)退还商户:商户基本账户商户结算银行账户
   *  4)退回支付用户零钱通:支付用户零钱通
   *  示例值:招商银行信用卡0403
   * 
*/ @SerializedName(value = "user_received_account") private String userReceivedAccount; /** *
   * 字段名:退款成功时间
   * 变量名:success_time
   * 是否必填:是
   * 类型:string[1, 64]
   * 描述:
   *  退款成功时间,当退款状态为退款成功时有返回。
   *  示例值:2020-12-01T16:18:12+08:00
   * 
*/ @SerializedName(value = "success_time") private String successTime; /** *
   * 字段名:退款创建时间
   * 变量名:create_time
   * 是否必填:是
   * 类型:string[1, 64]
   * 描述:
   *  退款受理时间
   *  示例值:2020-12-01T16:18:12+08:00
   * 
*/ @SerializedName(value = "create_time") private String createTime; /** *
   * 字段名:退款状态
   * 变量名:status
   * 是否必填:是
   * 类型:string[1, 32]
   * 描述:
   *  退款到银行发现用户的卡作废或者冻结了,导致原路退款银行卡失败,可前往商户平台(pay.weixin.qq.com)-交易中心,手动处理此笔退款。
   *  枚举值:
   *  SUCCESS:退款成功
   *  CLOSED:退款关闭
   *  PROCESSING:退款处理中
   *  ABNORMAL:退款异常
   *  示例值:SUCCESS
   * 
*/ @SerializedName(value = "status") private String status; /** *
   * 字段名:资金账户
   * 变量名:funds_account
   * 是否必填:否
   * 类型:string[1, 32]
   * 描述:
   *  退款所使用资金对应的资金账户类型
   *  枚举值:
   *  UNSETTLED : 未结算资金
   *  AVAILABLE : 可用余额
   *  UNAVAILABLE : 不可用余额
   *  OPERATION : 运营户
   *  BASIC : 基本账户(含可用余额和不可用余额)
   *  示例值:UNSETTLED
   * 
*/ @SerializedName(value = "funds_account") private String fundsAccount; /** *
   * 字段名:金额信息
   * 变量名:amount
   * 是否必填:是
   * 类型:object
   * 描述:
   *  金额详细信息
   * 
*/ @SerializedName(value = "amount") private Amount amount; /** *
   * 字段名:优惠退款信息
   * 变量名:promotion_detail
   * 是否必填:否
   * 类型:array
   * 描述:
   *  优惠退款信息
   * 
*/ @SerializedName(value = "promotion_detail") private List promotionDetail; @Data @NoArgsConstructor public static class Amount implements Serializable { private static final long serialVersionUID = 1L; /** *
     * 字段名:订单金额
     * 变量名:total
     * 是否必填:是
     * 类型:int
     * 描述:
     *  订单总金额,单位为分
     *  示例值:100
     * 
*/ @SerializedName(value = "total") private Integer total; /** *
     * 字段名:退款金额
     * 变量名:refund
     * 是否必填:是
     * 类型:int
     * 描述:
     *  退款标价金额,单位为分,可以做部分退款
     *  示例值:100
     * 
*/ @SerializedName(value = "refund") private Integer refund; /** *
     * 字段名:退款出资账户及金额
     * 变量名:from
     * 是否必填:否
     * 类型:array
     * 描述:
     *  退款出资的账户类型及金额信息
     * 
*/ @SerializedName(value = "from") private List from; /** *
     * 字段名:用户支付金额
     * 变量名:payer_total
     * 是否必填:是
     * 类型:int
     * 描述:
     *  现金支付金额,单位为分,只能为整数
     *  示例值:90
     * 
*/ @SerializedName(value = "payer_total") private Integer payerTotal; /** *
     * 字段名:用户退款金额
     * 变量名:payer_refund
     * 是否必填:是
     * 类型:int
     * 描述:
     *  退款给用户的金额,不包含所有优惠券金额
     *  示例值:90
     * 
*/ @SerializedName(value = "payer_refund") private Integer payerRefund; /** *
     * 字段名:应结退款金额
     * 变量名:settlement_refund
     * 是否必填:是
     * 类型:int
     * 描述:
     *  去掉非充值代金券退款金额后的退款金额,单位为分,退款金额=申请退款金额-非充值代金券退款金额,退款金额<=申请退款金额
     *  示例值:100
     * 
*/ @SerializedName(value = "settlement_refund") private Integer settlementRefund; /** *
     * 字段名:应结订单金额
     * 变量名:settlement_total
     * 是否必填:是
     * 类型:int
     * 描述:
     *  应结订单金额=订单金额-免充值代金券金额,应结订单金额<=订单金额,单位为分
     *  示例值:100
     * 
*/ @SerializedName(value = "settlement_total") private Integer settlementTotal; /** *
     * 字段名:优惠退款金额
     * 变量名:discount_refund
     * 是否必填:否
     * 类型:int
     * 描述:
     *  优惠退款金额<=退款金额,退款金额-代金券或立减优惠退款金额为现金,说明详见代金券或立减优惠,单位为分
     *  示例值:10
     * 
*/ @SerializedName(value = "discount_refund") private Integer discountRefund; /** *
     * 字段名:币类型
     * 变量名:currency
     * 是否必填:是
     * 类型:string[1, 16]
     * 描述:
     *  符合ISO 4217标准的三位字母代码,目前只支持人民币:CNY。
     *  示例值:CNY
     * 
*/ @SerializedName(value = "currency") private String currency; /** * 手续费退款金额 */ @SerializedName(value = "refund_fee") private Integer refundFee; } @Data @NoArgsConstructor public static class PromotionDetail implements Serializable { private static final long serialVersionUID = 1L; /** *
     * 字段名:券ID
     * 变量名:promotion_id
     * 是否必填:是
     * 类型:string[1, 32]
     * 描述:
     *  券或者立减优惠id
     *  示例值:109519
     * 
*/ @SerializedName(value = "promotion_id") private String promotionId; /** *
     * 字段名:优惠范围
     * 变量名:scope
     * 是否必填:是
     * 类型:string[1, 32]
     * 描述:
     *  枚举值:
     *  GLOBAL:全场代金券
     *  SINGLE:单品优惠
     *  示例值:SINGLE
     * 
*/ @SerializedName(value = "scope") private String scope; /** *
     * 字段名:优惠类型
     * 变量名:type
     * 是否必填:是
     * 类型:string[1, 32]
     * 描述:
     *  枚举值:
     *  COUPON:代金券,需要走结算资金的充值型代金券
     *  DISCOUNT:优惠券,不走结算资金的免充值型优惠券
     *  示例值:DISCOUNT
     * 
*/ @SerializedName(value = "type") private String type; /** *
     * 字段名:优惠券面额
     * 变量名:amount
     * 是否必填:是
     * 类型:int
     * 描述:
     *  用户享受优惠的金额(优惠券面额=微信出资金额+商家出资金额+其他出资方金额 ),单位为分
     *  示例值:5
     * 
*/ @SerializedName(value = "amount") private Integer amount; /** *
     * 字段名:优惠退款金额
     * 变量名:refund_amount
     * 是否必填:是
     * 类型:int
     * 描述:
     *  优惠退款金额<=退款金额,退款金额-代金券或立减优惠退款金额为用户支付的现金,说明详见代金券或立减优惠,单位为分
     *  示例值:100
     * 
*/ @SerializedName(value = "refund_amount") private Integer refundAmount; /** *
     * 字段名:商品列表
     * 变量名:goods_detail
     * 是否必填:否
     * 类型:array
     * 描述:
     *  优惠商品发生退款时返回商品信息
     * 
*/ @SerializedName(value = "goods_detail") private List goodsDetail; } @Data @NoArgsConstructor public static class From implements Serializable { private static final long serialVersionUID = 1L; /** *
     * 字段名:出资账户类型
     * 变量名:account
     * 是否必填:是
     * 类型:string[1, 32]
     * 描述:
     *  下面枚举值多选一。
     *  枚举值:
     *  AVAILABLE : 可用余额
     *  UNAVAILABLE : 不可用余额
     *  示例值:AVAILABLE
     * 
*/ @SerializedName(value = "account") private String account; /** *
     * 字段名:出资金额
     * 变量名:amount
     * 是否必填:是
     * 类型:int
     * 描述:
     *  对应账户出资金额
     *  示例值:444
     * 
*/ @SerializedName(value = "amount") private Integer amount; } @Data @NoArgsConstructor public static class GoodsDetail implements Serializable { private static final long serialVersionUID = 1L; /** *
     * 字段名:商户侧商品编码
     * 变量名:merchant_goods_id
     * 是否必填:是
     * 类型:string[1, 32]
     * 描述:
     *  由半角的大小写字母、数字、中划线、下划线中的一种或几种组成
     *  示例值:1217752501201407033233368018
     * 
*/ @SerializedName(value = "merchant_goods_id") private String merchantGoodsId; /** *
     * 字段名:微信侧商品编码
     * 变量名:wechatpay_goods_id
     * 是否必填:否
     * 类型:string[1, 32]
     * 描述:
     *  微信支付定义的统一商品编号(没有可不传)
     *  示例值:1001
     * 
*/ @SerializedName(value = "wechatpay_goods_id") private String wechatpayGoodsId; /** *
     * 字段名:商品名称
     * 变量名:goods_name
     * 是否必填:否
     * 类型:string[1, 256]
     * 描述:
     *  商品的实际名称
     *  示例值:iPhone6s 16G
     * 
*/ @SerializedName(value = "goods_name") private String goodsName; /** *
     * 字段名:商品单价
     * 变量名:unit_price
     * 是否必填:是
     * 类型:int
     * 描述:
     *  商品单价金额,单位为分
     *  示例值:528800
     * 
*/ @SerializedName(value = "unit_price") private Integer unitPrice; /** *
     * 字段名:商品退款金额
     * 变量名:refund_amount
     * 是否必填:是
     * 类型:int
     * 描述:
     *  商品退款金额,单位为分
     *  示例值:528800
     * 
*/ @SerializedName(value = "refund_amount") private Integer refundAmount; /** *
     * 字段名:商品退货数量
     * 变量名:refund_quantity
     * 是否必填:是
     * 类型:int
     * 描述:
     *  单品的退款数量,单位为分
     *  示例值:1
     * 
*/ @SerializedName(value = "refund_quantity") private Integer refundQuantity; } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy