#region Apache License Version 2.0
/*----------------------------------------------------------------
Copyright 2023 Jeffrey Su & Suzhou Senparc Network Technology Co.,Ltd.
Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file
except in compliance with the License. You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software distributed under the
License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND,
either express or implied. See the License for the specific language governing permissions
and limitations under the License.
Detail: https://github.com/JeffreySu/WeiXinMPSDK/blob/master/license.md
----------------------------------------------------------------*/
#endregion Apache License Version 2.0
/*----------------------------------------------------------------
Copyright (C) 2023 Senparc
文件名:MarketingApis.Busifavor.cs
文件功能描述:微信支付V3营销工具接口
创建标识:Senparc - 20210922
修改标识:iwenli210 - 20211130
修改描述:修复PayV3营销工具商户券API
修改标识:Senparc - 20220106
修改描述:v0.6.8.2 MarketingApis.ModifyBusifavorStockInformationAsync 方法单独提取参数 stock_id
修改标识:Senparc - 20220107
修改描述:v0.6.8.3 MarketingApis.ModifyBusifavorStockBudgetAsync 方法单独提取参数 stock_id
----------------------------------------------------------------*/
using Senparc.Weixin.TenPayV3.Apis.Entities;
using Senparc.Weixin.TenPayV3.Apis.Marketing;
using System.Threading.Tasks;
namespace Senparc.Weixin.TenPayV3.Apis
{
///
/// 微信支付V3营销工具接口
/// https://pay.weixin.qq.com/wiki/doc/apiv3/apis/chapter3_1_1.shtml 下的【营销工具】所有接口 > 【商家券接口】
///
public partial class MarketingApis
{
#region 商家券接口
///
/// 创建商家券批次接口
/// 商户可以通过该接口创建商家券。微信支付生成商家券批次后并返回商家券批次号给到商户,商户可调用发券接口发放该批次商家券。
/// 更多详细请参考 https://pay.weixin.qq.com/wiki/doc/apiv3/apis/chapter9_2_1.shtml
///
/// 微信支付需要POST的Data数据
/// 超时时间,单位为ms
///
public async Task CreateBusifavorStockRequestDataAsync(CreateBusifavorStockRequestData data, int timeOut = Config.TIME_OUT)
{
var url = BasePayApis.GetPayApiUrl(Senparc.Weixin.Config.TenPayV3Host + "/{0}v3/marketing/busifavor/stocks");
TenPayApiRequest tenPayApiRequest = new(_tenpayV3Setting);
return await tenPayApiRequest.RequestAsync(url, data, timeOut);
}
///
/// 查询商家券批次详情接口
/// 商户可通过该接口查询已创建的商家券批次详情信息。
/// 更多详细请参考 https://pay.weixin.qq.com/wiki/doc/apiv3/apis/chapter9_2_2.shtml
///
/// 微信为每个商家券批次分配的唯一ID
/// 超时时间,单位为ms
///
public async Task QueryBusifavorStockAsync(string stock_id, int timeOut = Config.TIME_OUT)
{
var url = BasePayApis.GetPayApiUrl($"{Senparc.Weixin.Config.TenPayV3Host}/{{0}}v3/marketing/busifavor/stocks/{stock_id}");
TenPayApiRequest tenPayApiRequest = new(_tenpayV3Setting);
return await tenPayApiRequest.RequestAsync(url, null, timeOut, ApiRequestMethod.GET);
}
///
/// 核销商家券用户券详情接口
/// 在用户满足优惠门槛后,商户可通过该接口核销用户微信卡包中具体某一张商家券。
/// 更多详细请参考 https://pay.weixin.qq.com/wiki/doc/apiv3/apis/chapter9_2_3.shtml
///
/// 微信支付需要POST的Data数据
/// 超时时间,单位为ms
///
public async Task UseBusifavorCouponAsync(UseBusifavorCouponRequestData data, int timeOut = Config.TIME_OUT)
{
var url = BasePayApis.GetPayApiUrl(Senparc.Weixin.Config.TenPayV3Host + "/{0}v3/marketing/busifavor/coupons/use");
TenPayApiRequest tenPayApiRequest = new(_tenpayV3Setting);
return await tenPayApiRequest.RequestAsync(url, data, timeOut);
}
///
/// 根据过滤条件查询商家券用户券接口
/// 商户自定义筛选条件(如创建商户号、归属商户号、发放商户号等),查询指定微信用户卡包中满足对应条件的所有商家券信息。
/// 更多详细请参考 https://pay.weixin.qq.com/wiki/doc/apiv3/apis/chapter9_2_4.shtml
///
/// Openid信息,用户在appid下的唯一标识
/// 支持传入与当前调用接口商户号有绑定关系的appid。支持小程序appid与公众号appid
/// 微信为每个商家券批次分配的唯一ID,是否指定批次号查询
/// 券状态 枚举值:SENDED:可用 USED:已核销 EXPIRED:已过期,可为null
/// 批次创建方商户号,可为null
/// 批次归属商户号,可为null
/// 批次发放商户号,可为null
/// 分页页码 默认值0
/// 分页大小 默认值20
/// 超时时间,单位为ms
///
public async Task QueryBusifavorCouponsAsync(string openid, string appid, string stock_id, string coupon_state, string creator_merchant, string belong_merchant, string sender_merchant, int offset = 0, int limit = 20, int timeOut = Config.TIME_OUT)
{
var url = BasePayApis.GetPayApiUrl($"{Senparc.Weixin.Config.TenPayV3Host}/{{0}}v3/marketing/busifavor/users/{openid}/coupons?appid={appid}&offset={offset}&limit={limit}");
url += stock_id is not null ? $"&stock_id={stock_id}" : "";
url += coupon_state is not null ? $"&coupon_state={coupon_state}" : "";
url += creator_merchant is not null ? $"&creator_merchant={creator_merchant}" : "";
url += belong_merchant is not null ? $"&belong_merchant={belong_merchant}" : "";
url += sender_merchant is not null ? $"&sender_merchant={sender_merchant}" : "";
TenPayApiRequest tenPayApiRequest = new(_tenpayV3Setting);
return await tenPayApiRequest.RequestAsync(url, null, timeOut, ApiRequestMethod.GET);
}
///
/// 查询用户单张商家券详情接口
/// 商户可通过该接口查询微信用户卡包中某一张商家券的详情信息
/// 更多详细请参考 https://pay.weixin.qq.com/wiki/doc/apiv3/apis/chapter9_2_5.shtml
///
/// 券的唯一标识
/// 支持传入与当前调用接口商户号有绑定关系的appid。支持小程序appid与公众号appid
/// Openid信息,用户在appid下的唯一标识
/// 超时时间,单位为ms
///
public async Task QueryBusifavorCouponAsync(string coupon_code, string appid, string openid, int timeOut = Config.TIME_OUT)
{
var url = BasePayApis.GetPayApiUrl($"{Senparc.Weixin.Config.TenPayV3Host}/{{0}}v3/marketing/busifavor/users/{openid}/coupons/{coupon_code}/appids/{appid}");
TenPayApiRequest tenPayApiRequest = new(_tenpayV3Setting);
return await tenPayApiRequest.RequestAsync(url, null, timeOut, ApiRequestMethod.GET);
}
///
/// 上传预存code接口
/// 商家券的Code码可由微信后台随机分配,同时支持商户自定义。如商家已有自己的优惠券系统,可直接使用自定义模式。即商家预先向微信支付上传券Code,当券在发放时,微信支付自动从已导入的Code中随机取值(不能指定),派发给用户。
/// 更多详细请参考 https://pay.weixin.qq.com/wiki/doc/apiv3/apis/chapter9_2_6.shtml
///
/// 微信支付需要POST的Data数据
/// 超时时间,单位为ms
///
public async Task SetBusifavorCouponCodesAsync(SetBusifavorCouponCodesRequestData data, int timeOut = Config.TIME_OUT)
{
var url = BasePayApis.GetPayApiUrl($"{Senparc.Weixin.Config.TenPayV3Host}/{{0}}v3/marketing/busifavor/stocks/{data.stock_id}/couponcodes");
TenPayApiRequest tenPayApiRequest = new(_tenpayV3Setting);
return await tenPayApiRequest.RequestAsync(url, data, timeOut);
}
///
/// 设置商家券事件通知地址接口
/// 用于设置接收商家券相关事件通知的URL,可接收商家券相关的事件通知、包括发放通知等。需要设置接收通知的URL,并在商户平台开通营销事件推送的能力,即可接收到相关通知。
/// 更多详细请参考 https://pay.weixin.qq.com/wiki/doc/apiv3/apis/chapter9_2_7.shtml
///
/// 微信支付需要POST的Data数据
/// 超时时间,单位为ms
///
public async Task SetBusifavorSetNotifyUrlAsync(SetBusifavorSetNotifyUrlRequestData data, int timeOut = Config.TIME_OUT)
{
var url = BasePayApis.GetPayApiUrl($"{Senparc.Weixin.Config.TenPayV3Host}/{{0}}v3/marketing/busifavor/callbacks");
TenPayApiRequest tenPayApiRequest = new(_tenpayV3Setting);
return await tenPayApiRequest.RequestAsync(url, data, timeOut);
}
///
/// 查询商家券事件通知地址API
/// 通过调用此接口可查询设置的通知URL
/// 更多详细请参考 https://pay.weixin.qq.com/wiki/doc/apiv3/apis/chapter9_2_8.shtml
///
/// 微信支付商户的商户号,由微信支付生成并下发,不填默认查询调用方商户的通知URL
/// 超时时间,单位为ms
///
public async Task QueryBusifavorNotifyUrlAsync(string mchid, int timeOut = Config.TIME_OUT)
{
var url = BasePayApis.GetPayApiUrl($"{Senparc.Weixin.Config.TenPayV3Host}/{{0}}v3/marketing/busifavor/callbacks?mchid={mchid}");
TenPayApiRequest tenPayApiRequest = new(_tenpayV3Setting);
return await tenPayApiRequest.RequestAsync(url, null, timeOut, ApiRequestMethod.GET);
}
///
/// 关联订单信息接口
/// 将有效态(未核销)的商家券与订单信息关联,用于后续参与摇奖&返佣激励等操作的统计。
/// 更多详细请参考 https://pay.weixin.qq.com/wiki/doc/apiv3/apis/chapter9_2_9.shtml
///
/// 微信支付需要POST的Data数据
/// 超时时间,单位为ms
///
public async Task AssociateBusifavorAsync(AssociateBusifavorRequestData data, int timeOut = Config.TIME_OUT)
{
var url = BasePayApis.GetPayApiUrl($"{Senparc.Weixin.Config.TenPayV3Host}/{{0}}v3/marketing/busifavor/coupons/associate");
TenPayApiRequest tenPayApiRequest = new(_tenpayV3Setting);
return await tenPayApiRequest.RequestAsync(url, data, timeOut);
}
///
/// 关联订单信息接口
/// 将有效态(未核销)的商家券与订单信息关联,用于后续参与摇奖&返佣激励等操作的统计。
/// 更多详细请参考 https://pay.weixin.qq.com/wiki/doc/apiv3/apis/chapter9_2_9.shtml
///
/// 微信支付需要POST的Data数据
/// 超时时间,单位为ms
///
public async Task DisassociateBusifavorAsync(DisassociateBusifavorRequestData data, int timeOut = Config.TIME_OUT)
{
var url = BasePayApis.GetPayApiUrl($"{Senparc.Weixin.Config.TenPayV3Host}/{{0}}v3/marketing/busifavor/coupons/disassociate");
TenPayApiRequest tenPayApiRequest = new(_tenpayV3Setting);
return await tenPayApiRequest.RequestAsync(url, data, timeOut);
}
///
/// 修改批次预算接口
/// 商户可以通过该接口修改批次单天发放上限数量或者批次最大发放数量
/// 更多详细请参考 https://pay.weixin.qq.com/wiki/doc/apiv3/apis/chapter9_2_11.shtml
///
/// 批次号 path批次号示例值:98065001
/// 微信支付需要POST的Data数据
/// 超时时间,单位为ms
///
public async Task ModifyBusifavorStockBudgetAsync(string stock_id, ModifyBusifavorStockBudgetRequestData data, int timeOut = Config.TIME_OUT)
{
var url = BasePayApis.GetPayApiUrl($"{Senparc.Weixin.Config.TenPayV3Host}/{{0}}v3/marketing/busifavor/stocks/{stock_id}/budget");
TenPayApiRequest tenPayApiRequest = new(_tenpayV3Setting);
return await tenPayApiRequest.RequestAsync(url, data, timeOut, ApiRequestMethod.PATCH);
}
///
/// 修改商家券基本信息接口
/// 商户可以通过该接口修改商家券基本信息
/// 更多详细请参考 https://pay.weixin.qq.com/wiki/doc/apiv3/apis/chapter9_2_12.shtml
///
/// 批次号 path批次号示例值:101156451224
/// 微信支付需要POST的Data数据
/// 超时时间,单位为ms
///
public async Task ModifyBusifavorStockInformationAsync(string stock_id, ModifyBusifavorStockInformationRequestData data, int timeOut = Config.TIME_OUT)
{
var url = BasePayApis.GetPayApiUrl($"{Senparc.Weixin.Config.TenPayV3Host}/{{0}}v3/marketing/busifavor/stocks/{stock_id}");
TenPayApiRequest tenPayApiRequest = new(_tenpayV3Setting);
return await tenPayApiRequest.RequestAsync(url, data, timeOut, ApiRequestMethod.PATCH);
}
///
/// 申请退券接口
/// 商户可以在退款之后调用退券api,调用了该接口后,券在用户卡包内正常展示,用户可在有效期内正常使用该优惠券。
/// 若券过期状态下退款,可不用调用该退券api。
/// 更多详细请参考 https://pay.weixin.qq.com/wiki/doc/apiv3/apis/chapter9_2_13.shtml
///
/// 微信支付需要POST的Data数据
/// 超时时间,单位为ms
///
public async Task ReturnBusifavorCouponAsync(ReturnBusifavorCouponRequestData data, int timeOut = Config.TIME_OUT)
{
var url = BasePayApis.GetPayApiUrl($"{Senparc.Weixin.Config.TenPayV3Host}/{{0}}v3/marketing/busifavor/coupons/return");
TenPayApiRequest tenPayApiRequest = new(_tenpayV3Setting);
return await tenPayApiRequest.RequestAsync(url, data, timeOut);
}
///
/// 使券失效接口
/// 商户可通过该接口将单张领取后未核销的券进行失效处理,券失效后无法再被核销
/// 更多详细请参考 https://pay.weixin.qq.com/wiki/doc/apiv3/apis/chapter9_2_14.shtml
///
/// 微信支付需要POST的Data数据
/// 超时时间,单位为ms
///
public async Task DeactivateBusifavorCouponAsync(DeactivateBusifavorCouponRequestData data, int timeOut = Config.TIME_OUT)
{
var url = BasePayApis.GetPayApiUrl($"{Senparc.Weixin.Config.TenPayV3Host}/{{0}}v3/marketing/busifavor/coupons/deactivate");
TenPayApiRequest tenPayApiRequest = new(_tenpayV3Setting);
return await tenPayApiRequest.RequestAsync(url, data, timeOut);
}
///
/// 营销补差付款接口
/// 该API主要用于商户营销补贴场景,支持by单张券进行不同商户账户间的资金补差,从而提升财务结算、资金利用效率。
/// 更多详细请参考 https://pay.weixin.qq.com/wiki/doc/apiv3/apis/chapter9_2_16.shtml
///
/// 微信支付需要POST的Data数据
/// 超时时间,单位为ms
///
public async Task PayBusifavorReceiptsAsync(PayBusifavorReceiptsRequestData data, int timeOut = Config.TIME_OUT)
{
var url = BasePayApis.GetPayApiUrl($"{Senparc.Weixin.Config.TenPayV3Host}/{{0}}v3/marketing/busifavor/subsidy/pay-receipts");
TenPayApiRequest tenPayApiRequest = new(_tenpayV3Setting);
return await tenPayApiRequest.RequestAsync(url, data, timeOut);
}
///
/// 查询营销补差付款单详情API
/// 查询商家券营销补差付款单详情
/// 更多详细请参考 https://pay.weixin.qq.com/wiki/doc/apiv3/apis/chapter9_2_18.shtml
///
/// 补差付款唯一单号,由微信支付生成,仅在补差付款成功后有返回
/// 超时时间,单位为ms
///
public async Task QueryBusifavorPayReceiptsAsync(string subsidy_receipt_id, int timeOut = Config.TIME_OUT)
{
var url = BasePayApis.GetPayApiUrl($"{Senparc.Weixin.Config.TenPayV3Host}/{{0}}v3/marketing/busifavor/subsidy/pay-receipts/{subsidy_receipt_id}");
TenPayApiRequest tenPayApiRequest = new(_tenpayV3Setting);
return await tenPayApiRequest.RequestAsync(url, null, timeOut, ApiRequestMethod.GET);
}
#endregion
}
}