package com.dobbinsoft.fw.pay.service.pay; import com.dobbinsoft.fw.pay.model.entpay.*; import com.github.binarywang.wxpay.bean.entpay.EntPayBankQueryRequest; import com.github.binarywang.wxpay.exception.WxPayException; /** *
 *  企业付款相关服务类.
 * 
* */ public interface MatrixEntPayService { /** *
     * 企业付款API.
     * 企业付款业务是基于微信支付商户平台的资金管理能力,为了协助商户方便地实现企业向个人付款,针对部分有开发能力的商户,提供通过API完成企业付款的功能。
     * 比如目前的保险行业向客户退保、给付、理赔。
     * 企业付款将使用商户的可用余额,需确保可用余额充足。查看可用余额、充值、提现请登录商户平台“资金管理”https://pay.weixin.qq.com/进行操作。
     * 注意:与商户微信支付收款资金并非同一账户,需要单独充值。
     * 文档详见: https://pay.weixin.qq.com/wiki/doc/api/tools/mch_pay.php?chapter=14_2
     * 接口链接:https://api.mch.weixin.qq.com/mmpaymkttransfers/promotion/transfers
     * 
* * @param request 请求对象 * @return the ent pay result * @throws WxPayException the wx pay exception */ MatrixEntPayResult entPay(MatrixEntPayRequest request) throws WxPayException; /** *
     * 查询企业付款API.
     * 用于商户的企业付款操作进行结果查询,返回付款操作详细结果。
     * 文档详见:https://pay.weixin.qq.com/wiki/doc/api/tools/mch_pay.php?chapter=14_3
     * 接口链接:https://api.mch.weixin.qq.com/mmpaymkttransfers/gettransferinfo
     * 
* * @param partnerTradeNo 商户订单号 * @return the ent pay query result * @throws WxPayException the wx pay exception */ MatrixEntPayQueryResult queryEntPay(String partnerTradeNo) throws WxPayException; /** *
     * 查询企业付款API.
     * 用于商户的企业付款操作进行结果查询,返回付款操作详细结果。
     * 文档详见:https://pay.weixin.qq.com/wiki/doc/api/tools/mch_pay.php?chapter=14_3
     * 接口链接:https://api.mch.weixin.qq.com/mmpaymkttransfers/gettransferinfo
     * 
* * @return the ent pay query result * @throws WxPayException the wx pay exception */ MatrixEntPayQueryResult queryEntPay(MatrixEntPayQueryRequest request) throws WxPayException; /** *
     * 获取RSA加密公钥API.
     * RSA算法使用说明(非对称加密算法,算法采用RSA/ECB/OAEPPadding模式)
     * 1、 调用获取RSA公钥API获取RSA公钥,落地成本地文件,假设为public.pem
     * 2、 确定public.pem文件的存放路径,同时修改代码中文件的输入路径,加载RSA公钥
     * 3、 用标准的RSA加密库对敏感信息进行加密,选择RSA_PKCS1_OAEP_PADDING填充模式
     * (eg:Java的填充方式要选 " RSA/ECB/OAEPWITHSHA-1ANDMGF1PADDING")
     * 4、 得到进行rsa加密并转base64之后的密文
     * 5、 将密文传给微信侧相应字段,如付款接口(enc_bank_no/enc_true_name)
     *
     * 接口默认输出PKCS#1格式的公钥,商户需根据自己开发的语言选择公钥格式
     * 文档详见:https://pay.weixin.qq.com/wiki/doc/api/tools/mch_pay.php?chapter=24_7&index=4
     * 接口链接:https://fraud.mch.weixin.qq.com/risk/getpublickey
     * 
* * @return the public key * @throws WxPayException the wx pay exception */ String getPublicKey() throws WxPayException; /** * 企业付款到银行卡. *
     * 用于企业向微信用户银行卡付款
     * 目前支持接口API的方式向指定微信用户的银行卡付款。
     * 文档详见:https://pay.weixin.qq.com/wiki/doc/api/tools/mch_pay.php?chapter=24_2
     * 接口链接:https://api.mch.weixin.qq.com/mmpaysptrans/pay_bank
     * 
* * @param request 请求对象 * @return the ent pay bank result * @throws WxPayException the wx pay exception */ MatrixEntPayBankResult payBank(MatrixEntPayBankRequest request) throws WxPayException; /** * 企业付款到银行卡查询. *
     * 用于对商户企业付款到银行卡操作进行结果查询,返回付款操作详细结果。
     * 文档详见:https://pay.weixin.qq.com/wiki/doc/api/tools/mch_pay.php?chapter=24_3
     * 接口链接:https://api.mch.weixin.qq.com/mmpaysptrans/query_bank
     * 
* * @param partnerTradeNo 商户订单号 * @return the ent pay bank query result * @throws WxPayException the wx pay exception */ MatrixEntPayBankQueryResult queryPayBank(String partnerTradeNo) throws WxPayException; /** * 企业付款到银行卡查询. *
     * 用于对商户企业付款到银行卡操作进行结果查询,返回付款操作详细结果。
     * 文档详见:https://pay.weixin.qq.com/wiki/doc/api/tools/mch_pay.php?chapter=24_3
     * 接口链接:https://api.mch.weixin.qq.com/mmpaysptrans/query_bank
     * 
* * @return the ent pay bank query result * @throws WxPayException the wx pay exception */ MatrixEntPayBankQueryResult queryPayBank(EntPayBankQueryRequest request) throws WxPayException; }