coupon-admin/app/controller/api/Coupon.php

1060 lines
43 KiB
PHP
Raw Normal View History

<?php
namespace app\controller\api;
use app\exception\RepositoryException;
2021-12-09 10:26:25 +00:00
use app\model\Account;
2021-12-13 11:09:16 +00:00
use app\model\Coupon as CouponModel;
use app\model\CouponBill;
2021-12-06 10:56:23 +00:00
use app\model\CouponMain;
2022-01-14 10:21:18 +00:00
use app\model\CouponType as CouponTypeModel;
2021-12-13 11:09:16 +00:00
use app\model\Deduction;
use app\model\Redpack;
2021-12-16 02:34:06 +00:00
use app\model\Business as BusinessModel;
2021-12-08 10:15:47 +00:00
use app\model\Score;
2021-12-14 09:34:27 +00:00
use app\model\UsingRule;
2021-12-06 10:56:23 +00:00
use app\repository\AccountRepository;
2021-12-13 11:09:16 +00:00
use app\repository\BusinessRepository;
use app\repository\CouponRepository;
2021-12-13 11:09:16 +00:00
use app\service\wx\WechatPay;
2021-12-09 10:26:25 +00:00
use app\validate\CouponRelease;
use app\validate\CouponUsingRule;
2021-12-13 11:09:16 +00:00
2021-12-06 10:56:23 +00:00
use think\Exception;
2021-12-09 10:26:25 +00:00
use think\facade\Config;
2021-12-06 10:56:23 +00:00
use think\facade\Db;
use think\facade\Log;
/**
* 优惠卷相关
* Class Coupon
* @package app\controller\api
*/
class Coupon extends Base
{
2021-12-09 10:26:25 +00:00
protected $noNeedLogin = [];
/**
* 我的优惠卷列表
*
* type in ['', 'notUsed', 'normal', 'used']
*/
2021-12-08 10:15:47 +00:00
public function getCouponList()
{
$page = $this->request->param('page/d', 1);
$size = $this->request->param('size/d', 10);
2022-02-08 02:18:44 +00:00
//$type = $this->request->param('type', '');
$page = $page < 1 ? 1 : $page;
$size = $size < 1 ? 10 : $size;
$accountCode = $this->request->user['user_code'] ?? '';
try {
$whereMap = [];
2022-02-08 06:37:31 +00:00
$sortOrder = ['is_verificated'=>'asc','id' => 'desc'];
2021-12-08 10:15:47 +00:00
$fields = [
'id',
'is_verificated as isVerificated',
2021-12-20 02:14:32 +00:00
'type_name',
2021-12-08 10:15:47 +00:00
'money',
'name as couponName',
2021-12-20 02:24:29 +00:00
'business_code',
2021-12-08 10:15:47 +00:00
'business_code as businessCode',
2021-12-20 02:24:29 +00:00
'coupon_id',
2021-12-08 10:15:47 +00:00
'end_time as endTime',
'consumer_name as consumerName',
'verificate_time as verificateTime',
'(end_time > NOW()) as sort_weight'];
$whereMap[] = ['consumer_code', '=', $accountCode];
2022-01-27 03:21:35 +00:00
2022-01-27 03:16:02 +00:00
// switch ($type) {
// case 'all':
// // 全部持有优惠券
// $sortOrder = ['sort_weight' => 'desc', 'end_time' => 'asc'];
// break;
// case 'notUsed':
// // 未使用(包含已过期)
// $whereMap[] = ['is_verificated', '=', self::BOOL_FALSE];
// $sortOrder = ['sort_weight' => 'desc', 'end_time' => 'asc'];
// break;
// case 'normal':
// // 未使用且未过期
// $whereMap[] = ['is_verificated', '=', self::BOOL_FALSE];
// $whereMap[] = ['end_time', '> TIME', date('Y-m-d H:i:s')];
// break;
// case 'used':
// // 已使用
// $whereMap[] = ['is_verificated', '=', self::BOOL_TRUE];
// $sortOrder = ['verificate_time' => 'desc'];
// break;
// }
2021-12-08 10:15:47 +00:00
$res = CouponRepository::getInstance()->findList($whereMap, $fields, $page, $size,function ($q){
2022-02-08 02:27:50 +00:00
return $q->with([
2022-02-08 02:30:13 +00:00
"couponMain" => function ($q) {
$q->field("id,name,image_url,type_name");
},
2022-02-08 02:27:50 +00:00
"scoreModel",
"business" => function ($q) {
$q->field("code,id,business_name,business_subtitle");
}
])
2022-01-27 03:16:02 +00:00
->where(function ($q){
$notUsedWhereMap = [];//未过期 未使用
$notUsedWhereMap[] = ['is_verificated', '=', self::BOOL_FALSE];
$notUsedWhereMap[] = ['end_time', '> TIME', date('Y-m-d H:i:s')];
$usedWhereMap = [];//已使用 7天内
$usedWhereMap[] = ['is_verificated', '=', self::BOOL_TRUE];
$usedWhereMap[] = ['verificate_time', '> TIME', date('Y-m-d H:i:s',time() - (7 * 86400)) ];
$beOverdueWhereMap = [];//未使用 已过期7天内
$beOverdueWhereMap[] = ['is_verificated', '=', self::BOOL_FALSE];
$beOverdueWhereMap[] = ['end_time', '> TIME', date('Y-m-d H:i:s',time() - (7 * 86400))];;
$q->whereOr(function ($q)use($notUsedWhereMap){
$q->where($notUsedWhereMap);
})//未使用未过期
->whereOr(function ($q)use($usedWhereMap){
$q->where($usedWhereMap);
})//已使用 7天内
->whereOr(function ($q)use($usedWhereMap){
$q->where($usedWhereMap);
});//已过期
})
//->fetchSql(true)
;
2021-12-08 10:15:47 +00:00
}, $sortOrder);
2022-01-27 03:16:02 +00:00
2021-12-20 02:14:32 +00:00
$time = time();
$res['list'] ->each(function ($item) use($time){
2022-01-20 05:56:21 +00:00
//重置优惠券名称
2021-12-08 10:15:47 +00:00
if(isset($item->couponMain) && $item->couponMain){
$item->couponName = $item->couponMain->name;
2021-12-20 02:36:03 +00:00
$item->image_url = $this->request->domain() . $item->couponMain->image_url;
2021-12-20 02:24:29 +00:00
}else{
2021-12-20 02:36:03 +00:00
$item->image_url = $this->request->domain() . '';
2021-12-08 10:15:47 +00:00
}
//是否已经打分过了
if(isset($item->scoreModel) && $item->scoreModel){
$item->scored = true;
$item->score = $item->scoreModel->score;
}else{
$item->scored = false;
$item->score = Score::COMMON_OFF;
}
2021-12-20 02:14:32 +00:00
2021-12-20 02:24:29 +00:00
//到期状态
2022-02-08 02:18:44 +00:00
//$expirationStr = '';
$status = CouponModel::status_success;//默认未使用
$endTime = strtotime($item->endTime);
2021-12-20 02:14:32 +00:00
$ExpirationTime = abs(($endTime - $time) / 86400);
if (($endTime > $time) ) {
2022-02-08 02:18:44 +00:00
$expirationStr = "还有".ceil($ExpirationTime)."天过期";
2021-12-20 02:14:32 +00:00
} else {
2022-02-08 02:18:44 +00:00
$status = CouponModel::status_be_overdue;
$expirationStr = "已过期" . ceil($ExpirationTime) . "";
2021-12-20 02:14:32 +00:00
}
2022-02-08 02:18:44 +00:00
$item->expirationStr = $expirationStr;
if($item->isVerificated == CouponModel::is_verificated_on){
$status = CouponModel::status_used;
}
$item->status = $status;
2021-12-20 02:14:32 +00:00
2021-12-20 02:24:29 +00:00
//商家简称
if(!empty($item->business)){
$item->business_subtitle = $item->business->business_subtitle;
}else{
$item->business_subtitle = '';
}
//图片
if(!empty($item->business)){
$item->business_subtitle = $item->business->business_subtitle;
}else{
$item->business_subtitle = '';
}
2021-12-08 10:15:47 +00:00
});
$res['list'] = multiTwoArrayKeysExcludeFilter($res['list']->toArray(), ['sort_weight']);
return $this->json(0, 'success', $res);
} catch (RepositoryException | \Exception $e) {
return $this->json(5001, '优惠卷查询失败!');
}
2021-12-06 10:56:23 +00:00
}
2021-12-13 11:09:16 +00:00
/**
2021-12-20 06:25:02 +00:00
* 我的优惠卷列表 指定商家 未验证
2021-12-13 11:09:16 +00:00
*
*/
public function getCouponListByBusinessCode()
{
$page = $this->request->param('page/d', 1);
$size = $this->request->param('size/d', 10);
$businessCode = $this->request->param('business_code/s', '');
2022-02-08 02:18:44 +00:00
$page = $page < 1 ? 1 : $page;
$size = $size < 1 ? 10 : $size;
2021-12-13 11:09:16 +00:00
$accountCode = $this->request->user['user_code'] ?? '';
2022-02-08 02:18:44 +00:00
$time = time();
2021-12-13 11:09:16 +00:00
try {
$whereMap = [];
$fields = [
'id',
2022-02-08 02:03:36 +00:00
'coupon_id',
'business_code',
2021-12-13 11:09:16 +00:00
'is_verificated as isVerificated',
'money',
'name as couponName',
'business_code as businessCode',
'end_time as endTime',
'consumer_name as consumerName',
'verificate_time as verificateTime',
'(end_time > NOW()) as sort_weight'];
$whereMap[] = ['consumer_code', '=', $accountCode];
$whereMap[] = ['business_code', '=', $businessCode];
2021-12-20 06:25:02 +00:00
$whereMap[] = ['is_verificated', '=', CouponModel::is_verificated_off];
2021-12-22 05:53:57 +00:00
$whereMap[] = ['end_time', '> TIME', date("Y-m-d H:i:s")];
2021-12-13 11:09:16 +00:00
$sortOrder = ['sort_weight' => 'desc', 'end_time' => 'asc'];
$res = CouponRepository::getInstance()->findList($whereMap, $fields, $page, $size,function ($q){
2022-02-08 02:03:36 +00:00
return $q->with(
[
"couponMain" => function ($q) {
2022-02-08 02:36:24 +00:00
$q->field("id,name,image_url,type_name");
2022-02-08 02:03:36 +00:00
},
"scoreModel",
"business" => function ($q) {
2022-02-08 02:27:50 +00:00
$q->field("id,code,business_name,business_subtitle");
2022-02-08 02:03:36 +00:00
}
]);
2021-12-13 11:09:16 +00:00
}, $sortOrder);
2022-02-08 02:18:44 +00:00
$res['list'] ->each(function ($item) use($time){
2022-02-08 02:27:50 +00:00
2021-12-20 06:51:13 +00:00
//重置过期时间
2021-12-20 06:53:01 +00:00
$item->endTimeText = date("Y-m-d",strtotime($item->endTime));
2022-02-08 02:18:44 +00:00
$status = CouponModel::status_success;//默认未使用
$endTime = strtotime($item->endTime);
$ExpirationTime = abs(($endTime - $time) / 86400);
if (($endTime > $time) ) {
$expirationStr = "还有".ceil($ExpirationTime)."天过期";
} else {
$status = CouponModel::status_be_overdue;
$expirationStr = "已过期" . ceil($ExpirationTime) . "";
}
$item->expirationStr = $expirationStr;
if($item->isVerificated == CouponModel::is_verificated_on){
$status = CouponModel::status_used;
}
$item->status = $status;
//重置优惠券名称
if(isset($item->couponMain) && $item->couponMain){
$item->couponName = $item->couponMain->name;
$item->image_url = $this->request->domain() . $item->couponMain->image_url;
}else{
$item->image_url = $this->request->domain() . '';
}
2021-12-13 11:09:16 +00:00
});
$res['list'] = multiTwoArrayKeysExcludeFilter($res['list']->toArray(), ['sort_weight']);
return $this->json(0, 'success', $res);
} catch (RepositoryException | \Exception $e) {
return $this->json(5001, '优惠卷查询失败!');
}
}
2021-12-06 10:56:23 +00:00
/**
2022-01-20 05:56:21 +00:00
* 领取优惠券
2021-12-06 10:56:23 +00:00
* */
public function receiveCoupon()
{
$accountId = $this->request->user['user_id'] ?? 0;
$lat = input("lat/f",0);
$lng = input("lng/f",0);
$account = AccountRepository::getInstance()->findById($accountId, [], function ($q) {
return $q->with(['business', 'parent']);
});
if(empty($account)){
return $this->json(6001,"无效的用户");
}
if ($lat <= 0 || $lng <= 0) {
return $this->json(4001, "请授权定位");
}
$couponMainId = input("couponId/d", 0);
$couponMain = CouponMain::findOne(["id" => $couponMainId],[],function ($q){
//执行领取 开启锁
return $q->with("business")->lock(true);
});
2021-12-20 08:13:30 +00:00
if(!isset($couponMain->business)||empty($couponMain->business)){
2022-01-20 05:56:21 +00:00
return $this->json(4001, "优惠券所属商家不存在");
2021-12-20 08:13:30 +00:00
}
if($couponMain->business->enable != BusinessModel::COMMON_OFF){
return $this->json(4001, "商家已禁用");
}
2021-12-06 10:56:23 +00:00
2021-12-16 06:03:35 +00:00
try {
2022-01-20 05:56:21 +00:00
//检查优惠券状态
2021-12-16 06:03:35 +00:00
CouponRepository::getInstance()->checkCouponMainReceiveStatus($couponMain);
}catch (RepositoryException $e){
return $this->json(4001,$e->getMessage());
2021-12-06 10:56:23 +00:00
}
2021-12-16 06:03:35 +00:00
2021-12-06 10:56:23 +00:00
try {
//检查是否可以领取 0可领取 1已领取
2021-12-14 09:34:27 +00:00
AccountRepository::getInstance()->getCouponReceiveStatusText($account,$couponMain);//领取状态
2021-12-06 10:56:23 +00:00
}catch (RepositoryException $e){
return $this->json(4001,$e->getMessage());
}
//检查通过 执行领取
$time = time();
Db::startTrans();
try {
//写入领取记录
$data = [
"coupon_id" =>$couponMain->id,
"name" =>$couponMain->name,
"type_id" =>$couponMain->type,
"type_name" =>$couponMain->type_name,
"business_code" =>$couponMain->business_code,
"business_name" =>$couponMain->business?$couponMain->business->business_name:'',
"consumer_code" =>$account->user_code,
"consumer_name" =>$account->nick_name,
"money" => $couponMain->money,
"content" => createUuid(),//未知作用
"received_time" => date("Y-m-d H:i:s",$time),
"lat" => $lat,
"lng" => $lng,
"end_time" => date($couponMain->end_time . " 00:00:00"),
"edition" => couponMain::COMMON_ON,//版本 未知作用
"is_verificated" => couponMain::COMMON_OFF,//版本 未知作用
];
CouponRepository::getInstance()->receiveCoupon($data);
2021-12-14 09:34:27 +00:00
$couponMain->save(["received_count"=>Db::raw("received_count + 1")]);
2021-12-06 10:56:23 +00:00
Db::commit();
return $this->json();
}catch (RepositoryException $e){
2022-01-20 05:56:21 +00:00
Log::error("优惠券领取失败RepositoryException:".$e->getMessage());
2021-12-06 10:56:23 +00:00
Db::rollback();
return $this->json(5001,"领取失败");
}catch (Exception $e){
2022-01-20 05:56:21 +00:00
Log::error("优惠券领取失败:".$e->getMessage());
2021-12-06 10:56:23 +00:00
Db::rollback();
return $this->json(5001,"领取失败");
}
}
2021-12-09 10:26:25 +00:00
2021-12-13 11:09:16 +00:00
/**
2022-01-20 05:56:21 +00:00
* 核验优惠券 程序----核心操作----
2021-12-13 11:09:16 +00:00
* */
public function verification()
{
2022-01-17 02:38:53 +00:00
$accountId = $this->request->user['user_id'] ?? 0;
$lat = input("lat/f",0);
$lng = input("lng/f",0);
$couponId = input("couponId/d",0);
$userTimeStamp = input("userTimeStamp/d",0);
$account = AccountRepository::getInstance()->findById($accountId, [], function ($q) {
2021-12-13 11:09:16 +00:00
return $q->with(['business', 'parent']);
});
$time = time();
if(empty($account)){
return $this->json(6001,"无效的用户");
}
if ($lat <= 0 || $lng <= 0) {
return $this->json(4001, "请授权定位");
}
$coupon = CouponRepository::getInstance()->findById($couponId,[],function ($q){
2021-12-14 09:34:27 +00:00
return $q->with(["couponMain","redpack"]);
2021-12-13 11:09:16 +00:00
});
2021-12-20 03:30:57 +00:00
if(empty($coupon)){
2022-01-20 05:56:21 +00:00
return $this->json(4001, "优惠券不存在");
2021-12-20 03:30:57 +00:00
}
2021-12-13 11:09:16 +00:00
if($coupon->consumer_code != $account->user_code ){
return $this->json(4001, "参数错误");
}
2021-12-20 03:30:57 +00:00
if($coupon->is_verificated != CouponModel::is_verificated_off){
2022-01-20 05:56:21 +00:00
return $this->json(4001, "优惠券验证");
2021-12-13 11:09:16 +00:00
}
if($coupon->status != CouponMain::status_on){
2022-01-20 05:56:21 +00:00
return $this->json(4001, "优惠券已停用");
2021-12-13 11:09:16 +00:00
}
if($coupon->on_shelf != CouponMain::on_shelf_on){
2022-01-20 05:56:21 +00:00
return $this->json(4001, "优惠券下架");
2021-12-13 11:09:16 +00:00
}
2021-12-14 09:34:27 +00:00
if(!isset($coupon->couponMain) || empty($coupon->couponMain)){
2022-01-20 05:56:21 +00:00
return $this->json(4001, "商家优惠券信息错误");
2021-12-13 11:09:16 +00:00
}
2021-12-20 07:53:05 +00:00
if(strtotime($coupon->couponMain->end_time) < $time){
2022-01-20 05:56:21 +00:00
return $this->json(4001, "优惠券已过期");
2021-12-14 09:34:27 +00:00
}
2022-01-19 05:40:46 +00:00
//$usingRule = UsingRule::findOne(["coupon_id"=>$coupon->couponMain->id]);
//if(empty($usingRule)){
2022-01-20 05:56:21 +00:00
// return $this->json(4001, "商家优惠券使用规则信息错误");
2022-01-19 05:40:46 +00:00
//}
2021-12-13 11:09:16 +00:00
2021-12-14 09:34:27 +00:00
//一天的开始时间
2022-01-19 05:40:46 +00:00
//if(strtotime(date("Y-m-d " . $usingRule->day_start_time)) > $time){
// return $this->json(4001, "请在当天{$usingRule->day_start_time}-{$usingRule->day_start_time}使用");
//}
2021-12-14 09:34:27 +00:00
//一天的结束时间
2022-01-19 05:40:46 +00:00
//if(strtotime(date("Y-m-d ".$usingRule->day_end_time)) < $time){
// return $this->json(4001, "请在当天{$usingRule->day_start_time}-{$usingRule->day_start_time}使用");
//}
2021-12-15 07:04:20 +00:00
2021-12-20 07:53:05 +00:00
//使用周期 周一到周天
2022-01-19 05:40:46 +00:00
//$newW = date("w");
//if(!in_array($newW,$usingRule->cycle)){
// return $this->json(4001, "请在".encodeCouponCycle($usingRule->cycle)."使用");
//}
2021-12-20 07:53:05 +00:00
2022-01-17 02:38:53 +00:00
2021-12-15 07:04:20 +00:00
Config::load('extra/wechat', 'wechat');
2022-01-17 02:38:53 +00:00
$signDistance = config('wechat.signDistance') ?? 0;
$signTimeStamp = config('wechat.signTimeStamp') ?? 0;
$msectime = msectime();//毫秒时间戳
2021-12-16 02:34:06 +00:00
2022-01-17 02:38:53 +00:00
//签到距离
2021-12-15 07:04:20 +00:00
if($signDistance > 0 ){
2021-12-20 06:44:40 +00:00
$distance = get_distance($coupon->couponMain->lat,$coupon->couponMain->lng,$lat,$lng);
2021-12-20 03:30:57 +00:00
if($distance > $signDistance){
2021-12-20 06:44:40 +00:00
if ($distance >= 1000) {
2021-12-20 06:46:19 +00:00
$distanceText = round($distance / 1000, 2) . "千米";
2021-12-20 06:44:40 +00:00
} else {
2021-12-20 06:46:19 +00:00
$distanceText = $distance . "";
2021-12-20 06:44:40 +00:00
}
2022-02-08 06:32:23 +00:00
return $this->json(4001, "您距离商家位置距离超过规定距离");
2021-12-15 07:04:20 +00:00
}
}
2022-01-17 02:38:53 +00:00
//签到时间戳
if($signTimeStamp > 0 ){
if(abs($userTimeStamp - $msectime) > $signTimeStamp){
//.abs($userTimeStamp - $msectime)
return $this->json(4001, "时间戳验证失败");
}
}
2021-12-20 06:44:40 +00:00
2021-12-13 11:09:16 +00:00
$business = BusinessRepository::getInstance()->getModel()->with(["agency"])->where(["code"=>$coupon->couponMain->business_code])->lock(true)->find();
if(empty($business)){
return $this->json(4001, "商家不存在");
}
2021-12-20 08:13:30 +00:00
if($business->enable != BusinessModel::COMMON_OFF){
return $this->json(4001, "商家已禁用");
}
2021-12-13 11:09:16 +00:00
if($business->balance < $coupon->couponMain->deduction_money){
return $this->json(4001, "商家余额不足");
}
//开始数据操作
Db::startTrans();
try {
2022-01-20 05:56:21 +00:00
// 1. 修改优惠券状态
2021-12-13 11:09:16 +00:00
$coupon->save([
2021-12-14 09:34:27 +00:00
"is_verificated" => CouponModel::is_verificated_on,
"used_time" => date("Y-m-d H:i:s" ,$time),
"verificate_time" => date("Y-m-d H:i:s" ,$time),
2021-12-13 11:09:16 +00:00
]);
2021-12-14 09:34:27 +00:00
$coupon->couponMain->save([
"verification_count" => Db::raw("verification_count + 1"),//已验证数量+1
"using_count" => Db::raw("using_count - 1"),//进行中数量-1
]);
2022-02-08 06:32:23 +00:00
$deductionMoney = $coupon->couponMain->deduction_money;
2021-12-13 11:09:16 +00:00
2021-12-16 02:34:06 +00:00
//可分配金额 如果是普通商家
2021-12-20 05:57:57 +00:00
if($business->model == BusinessModel::model_ordinary) {
2021-12-16 02:34:06 +00:00
$agencyMoney = (($deductionMoney/100) * $coupon->couponMain->commission_agency);
$adminMoney = (($deductionMoney/100) * $coupon->couponMain->commission_admin);
$consumerMoney = (($deductionMoney/100) * $coupon->couponMain->commission_consumer);
$agencyMoney = round($agencyMoney,2); //四舍五入 精确到分
$adminMoney = round($adminMoney,2); //四舍五入 精确到分
$consumerMoney = round($consumerMoney,2); //四舍五入 精确到分
}else{
$adminMoney = 0;
$consumerMoney = round($deductionMoney,2) ;
2021-12-20 03:30:57 +00:00
$agencyMoney = 0; //四舍五入 精确到分
2021-12-16 02:34:06 +00:00
}
2022-01-20 05:56:21 +00:00
// 2. 写入优惠券流水
2021-12-13 11:09:16 +00:00
$couponBillData = [
2021-12-20 03:30:57 +00:00
"coupon_main_id" => $coupon->couponMain->id,
"coupon_id" => $coupon->id,
"user_code" => $account->user_code,
2021-12-20 07:02:52 +00:00
"business_code" => $business->code,
2021-12-20 03:30:57 +00:00
"agency_code" => $business->agency_code,
"commission_agency" => $coupon->couponMain->commission_agency,
"commission_admin" => $coupon->couponMain->commission_admin,
"commission_consumer" => $coupon->couponMain->commission_consumer,
"money" => $coupon->couponMain->money,
"agency_money" => $agencyMoney,
"admin_money" => $adminMoney,
"consumer_money" => $consumerMoney,
"lat" => $lat,
"lng" => $lng,
2021-12-20 06:12:58 +00:00
"create_time" => date("Y-m-d H:i:s" ,$time),
2021-12-13 11:09:16 +00:00
];
$couponBill = CouponBill::create($couponBillData);
// 3. 写入商家扣费记录
$deductionData = [
2021-12-14 09:34:27 +00:00
"money" => $deductionMoney,
2021-12-20 09:53:03 +00:00
"user_code" => $account->user_code,
2021-12-14 09:34:27 +00:00
"business_code" => $business->code,
"business_name" => $business->business_name,
"balance" => $business->balance - $deductionMoney,
2022-01-20 05:56:21 +00:00
"reason" => sprintf("[%s]验证优惠券[%s]扣除[%s]",$account->nick_name, $coupon->couponMain->name,$deductionMoney),
2021-12-14 09:34:27 +00:00
"coupon_main_id" => $coupon->couponMain->id,
"coupon_id" => $coupon->id,
"bill_id" => $couponBill->id,
"create_time" => date("Y-m-d H:i:s",$time),
2021-12-13 11:09:16 +00:00
];
Deduction::create($deductionData);
//4. 商家扣钱
2021-12-23 08:30:22 +00:00
$business->save(["balance"=>Db::raw("balance - " . $deductionMoney)]);
2021-12-13 11:09:16 +00:00
//5. 渠道商加钱
2021-12-14 09:34:27 +00:00
if(isset($business->agency) && $business->agency){
2021-12-13 11:09:16 +00:00
$business->agency->inc("balance",$agencyMoney)->update();
}
2021-12-14 09:34:27 +00:00
//6. 用户提现到零钱 写入红包记录
if($consumerMoney > 0){
$payment = WechatPay::getInstance();
//如果付款过一次了 就查询付款状态
2021-12-20 03:30:57 +00:00
if(isset($coupon->redpack) && $coupon->redpack){
2022-02-08 06:32:23 +00:00
$mch_billno = $coupon->redpack->mch_billno;
// $result = $payment->transfer->queryBalanceOrder($coupon->redpack->mch_billno);
// //var_dump($result);
// //企业付款成功
// if(isset($result["status"]) && $result["status"]=="SUCCESS"){
// Db::commit();
// return $this->json(
// 0,
// "优惠券签到使用成功,您获得{$consumerMoney}元红包,已存入您的零钱",
// [
// "redpack" =>$consumerMoney
// ]);
// }
// Log::info("查询企业付款失败:".json_encode($result,JSON_UNESCAPED_UNICODE));
2021-12-14 09:34:27 +00:00
}else{
2021-12-20 03:30:57 +00:00
$mch_billno = createUuid();
2021-12-14 09:34:27 +00:00
}
2021-12-13 11:09:16 +00:00
2022-02-08 06:32:23 +00:00
$amount = $consumerMoney * 100;
$toBalanceData = [
'partner_trade_no' => $mch_billno,// 商户订单号,需保持唯一性(只能是字母或者数字,不能包含有符号)
'openid' => $account->open_id,
'check_name' => 'NO_CHECK',// NO_CHECK不校验真实姓名, FORCE_CHECK强校验真实姓名
'amount' => $amount, //单位为分不小于100
'desc' => '验证优惠券签到',
];
// 写入红包
$redpackData = [
"coupon_id" =>$coupon->id,
"mch_billno" =>$mch_billno,
"openid" =>$account->open_id,
"user_code" =>$account->user_code,
"money" =>$amount,
"create_time" => date("Y-m-d H:i:s",$time),
"pay_time" => '0000-00-00 00:00:00',
];
$redpack = Redpack::create($redpackData);
//发起支付
$result = $payment->transfer->toBalance($toBalanceData);
//var_dump($result);
//付款成功才提交!!!!!伪装成功
if(isset($result['payment_no']) ){
$redpack->pay_time = date("Y-m-d H:i:s",$time);
$redpack->save();
Db::commit();
return $this->json(
0,
"优惠券签到使用成功,您获得{$consumerMoney}元红包,已存入您的零钱",
[
"redpack" =>$consumerMoney
]);
}
Log::info("企业发起付款失败:" . json_encode($result,JSON_UNESCAPED_UNICODE));
2021-12-14 09:34:27 +00:00
//默认回滚
Db::rollback();
2022-02-08 02:50:50 +00:00
return $this->json(5003, "验证失败,发放红包失败");
2021-12-14 09:34:27 +00:00
}
Db::commit();
return $this->json();
2021-12-13 11:09:16 +00:00
}catch (RepositoryException $e){
Db::rollback();
2021-12-14 09:34:27 +00:00
return $this->json(5001, "Repository服务器错误");
2021-12-13 11:09:16 +00:00
}catch (\Exception $e){
2022-02-08 06:32:23 +00:00
echo $e->getMessage();
2021-12-13 11:09:16 +00:00
Db::rollback();
return $this->json(5002, "服务器错误");
}
}
2021-12-09 10:26:25 +00:00
/**
2022-01-20 05:56:21 +00:00
* 发布优惠券
2021-12-09 10:26:25 +00:00
* */
public function add()
{
$accountId = $this->request->user['user_id'] ?? 0;
$account = AccountRepository::getInstance()->findById($accountId, [], function ($q) {
return $q->with(['business'=>function($q){
$q->lock(true);
}, 'parent']);
});
if(empty($account)){
return $this->json(6001,"登录失效");
}
if ($account->type == Account::type_consumer) {
return $this->json(4001, "您不是商家");
}
if (!isset($account->business) || empty($account->business)) {
return $this->json(4001, "商家信息错误");
}
2021-12-20 08:13:30 +00:00
if($account->business->enable != BusinessModel::COMMON_OFF){
return $this->json(4001, "商家已禁用");
}
2021-12-09 10:26:25 +00:00
$data = input();
Config::load("extra/distribution_proportion","distribution_proportion");
$distributionProportion = config("distribution_proportion");
$totalC = $distributionProportion['agency'] + $distributionProportion['admin'] + $distributionProportion['consumer'];
if ($totalC != 100) {
2021-12-16 02:34:06 +00:00
return $this->json(4002, "系统设置分配比例总和不等于100,不能发布");
}
//持有限量
Config::load("extra/wechat","wechat");
$hasCouponMax = config("wechat.hasCouponMax")??0;
if ($hasCouponMax > 0) {
$hasCouponCount = CouponRepository::getInstance()->getBusinessOnShelfOnCount($account->business->code);
if ($hasCouponCount > $hasCouponMax) {
2022-01-20 05:56:21 +00:00
return $this->json(4001, "商家持有商家优惠券不能超过{$hasCouponMax}");
2021-12-16 02:34:06 +00:00
}
2021-12-09 10:26:25 +00:00
}
2022-01-14 10:21:18 +00:00
2022-01-20 05:56:21 +00:00
//验证通过 不管是商家还是工作人员 都可以发布优惠券
2021-12-09 10:26:25 +00:00
$couponMain = [
"name" => $data['name'] ?? '',
"business_code" => $account->business->code,
2022-01-19 05:40:46 +00:00
//"money" => $data['money'] ?? 0,
2021-12-09 10:26:25 +00:00
"type" => $data['type'] ?? 0,
"count" => $data['count'] ?? 0,
"type_name" => $data['type_name'] ?? '',
"start_time" => $data['start_time'] ?? '',
"end_time" => $data['end_time'] ?? '',
"deduction_money" => $data['deduction_money'] ?? '',
"image_url" => $data['image_url'] ?? '',
"intro" => $data['intro'] ?? '',
2021-12-23 03:34:44 +00:00
"content" => $data['content'] ?? '',
2021-12-13 07:57:27 +00:00
"white_list" => $data['white_list'] ?? '',
2021-12-09 10:26:25 +00:00
"status" => CouponMain::status_on,
"on_shelf" => CouponMain::on_shelf_off,//默认下架 后台审核上架
2022-02-08 06:32:23 +00:00
"on_screen" => CouponMain::on_screen_yes,
2021-12-09 10:26:25 +00:00
"commission_agency" => $distributionProportion['agency'],
"commission_admin" => $distributionProportion['admin'],
"commission_consumer" => $distributionProportion['consumer'],
];
2022-01-19 05:40:46 +00:00
//$usingRule = input("using_rule/a");
2021-12-09 10:26:25 +00:00
$validate = new CouponRelease();
2021-12-16 02:34:06 +00:00
//普通商家要验证扣除金额
if (!$validate->scene($account->business["model"] == BusinessModel::model_ordinary ? "ordinary" : "")->check($couponMain)) {
2021-12-09 10:26:25 +00:00
return $this->json(4001, $validate->getError());
}
2022-01-19 05:40:46 +00:00
//$usingRuleValidate = new CouponUsingRule();
//if (!$usingRuleValidate->check($usingRule)) {
// return $this->json(4001, $usingRuleValidate->getError());
//}
2021-12-15 07:04:20 +00:00
2022-01-14 10:21:18 +00:00
//检查类型
if(CouponTypeModel::checkType($couponMain['type']) !== true){
2022-01-20 05:56:21 +00:00
return $this->json(4001, '优惠券类型不存在');
2022-01-14 10:21:18 +00:00
}
2022-01-20 12:12:22 +00:00
$type = CouponRepository::getInstance()->getCouponTypeAll();
$type = array_column($type->toArray(), null, "id");
$data['type_name'] = $type[$data['type']]['name'];
2022-01-14 10:21:18 +00:00
2021-12-09 10:26:25 +00:00
//验证通过
2021-12-16 05:37:55 +00:00
$couponMain['business_type'] = $account->business['type'];
$couponMain['business_name'] = $account->business['business_name'];
$couponMain['lng'] = $account->business['lng'];
$couponMain['lat'] = $account->business['lat'];
$couponMain['business_circle_id'] = $account->business['business_circle_id'];
$couponMain['create_time'] = date("Y-m-d H:i:s");
2021-12-09 10:26:25 +00:00
//保留两位小数
2022-01-20 06:09:20 +00:00
$couponMain['deduction_money'] = floor($couponMain['deduction_money'] * 100) / 100;
$totalMoney = $couponMain['deduction_money'] * $couponMain['count'];
2021-12-09 10:26:25 +00:00
2022-02-08 06:32:23 +00:00
//检测消费者部分是否最少1元
$consumerMoney = ($data['commission_consumer']/100) * $data['deduction_money'];
if ($consumerMoney != 0 && $consumerMoney < CouponMain::min_consumer_money) {
return $this->json(4002, "消费者红包最低" . CouponMain::min_consumer_money . "");
}
2022-01-20 05:56:21 +00:00
//未领取的优惠券
2021-12-14 09:34:27 +00:00
$NotClaimedMoney = CouponRepository::getInstance()->getBusinessNotClaimedCoupon($account->business["code"]);
2021-12-16 02:34:06 +00:00
if($account->business["model"] == BusinessModel::model_ordinary) {
if ($account->business["balance"] < ($totalMoney + $NotClaimedMoney)) {
return $this->json(4001, '商家余额不足');
}
2021-12-09 10:26:25 +00:00
}
Db::startTrans();
try {
2022-01-19 05:40:46 +00:00
//CouponRepository::getInstance()->releaseCouponMain($couponMain, $totalMoney, $usingRule);
CouponRepository::getInstance()->releaseCouponMain($couponMain);
2021-12-09 10:26:25 +00:00
Db::commit();
return $this->json();
} catch (RepositoryException $e) {
Db::rollback();
return $this->json(5001, "发布失败" . $e->getMessage());
} catch (\think\Exception $e) {
Db::rollback();
return $this->json(5002, "发布失败" . $e->getMessage());
}
}
2021-12-13 07:57:27 +00:00
/**
2022-01-20 05:56:21 +00:00
* 修改优惠券
2021-12-13 07:57:27 +00:00
* */
public function edit()
{
2021-12-29 02:42:17 +00:00
$accountId = $this->request->user['user_id'] ?? 0;
$couponMainId = input("couponMainId/d");
$account = AccountRepository::getInstance()->findById($accountId, [], function ($q) {
2021-12-13 07:57:27 +00:00
return $q->with(['business'=>function($q){
$q->lock(true);
}, 'parent']);
});
if(empty($account)){
return $this->json(6001,"登录失效");
}
if ($account->type == Account::type_consumer) {
return $this->json(4001, "您不是商家");
}
if (!isset($account->business) || empty($account->business)) {
return $this->json(4001, "商家信息错误");
}
2022-01-19 05:40:46 +00:00
$couponMain = CouponMain::findById($couponMainId,[]);
2021-12-13 07:57:27 +00:00
if (empty($couponMain)) {
2022-01-20 05:56:21 +00:00
return $this->json(4001, "优惠券不存在");
2021-12-13 07:57:27 +00:00
}
2022-01-19 05:40:46 +00:00
//if (!isset($couponMain->usingRule)||empty($couponMain->usingRule)) {
2022-01-20 05:56:21 +00:00
// return $this->json(4001, "优惠券信息错误");
2022-01-19 05:40:46 +00:00
//}
2021-12-13 07:57:27 +00:00
$data = input();
2022-01-20 05:56:21 +00:00
//验证通过 不管是商家还是工作人员 都可以修改优惠券 只能修改指定字段
2021-12-13 07:57:27 +00:00
$couponMainData = [
"name" => $data['name'] ?? '',
"type" => $data['type'] ?? 0,
"type_name" => $data['type_name'] ?? '',
"start_time" => $data['start_time'] ?? '',
"end_time" => $data['end_time'] ?? '',
"image_url" => $data['image_url'] ?? '',
"intro" => $data['intro'] ?? '',
2021-12-23 07:57:44 +00:00
"content" => $data['content'] ?? '',
2021-12-13 07:57:27 +00:00
"white_list" => $data['white_list'] ?? '',
2022-01-20 05:56:21 +00:00
"on_screen" => $data['on_screen'] ?? 1,
2021-12-13 07:57:27 +00:00
];
2022-01-19 05:40:46 +00:00
//$usingRule = input("using_rule/a");
2021-12-13 07:57:27 +00:00
$validate = new CouponRelease();
if (!$validate->scene("api_edit")->check($couponMainData)) {
return $this->json(4001, $validate->getError());
}
2022-01-19 05:40:46 +00:00
//$usingRuleValidate = new CouponUsingRule();
//if (!$usingRuleValidate->check($usingRule)) {
// return $this->json(4001, $usingRuleValidate->getError());
//}
2021-12-13 07:57:27 +00:00
2022-01-14 10:21:18 +00:00
//检查类型
if(CouponTypeModel::checkType($couponMainData['type']) !== true){
2022-01-20 05:56:21 +00:00
return $this->json(4001, '优惠券类型不存在');
2022-01-14 10:21:18 +00:00
}
2022-01-20 12:12:22 +00:00
$type = CouponRepository::getInstance()->getCouponTypeAll();
$type = array_column($type->toArray(), null, "id");
$couponMainData['type_name'] = $type[$data['type']]['name'];
2021-12-13 07:57:27 +00:00
//验证通过
Db::startTrans();
try {
$couponMain->save($couponMainData);
2022-01-19 05:40:46 +00:00
//$couponMain->usingRule->save($usingRule);
2021-12-22 05:53:57 +00:00
CouponRepository::getInstance()->getModel()->where("coupon_id",$couponMain->id)->update(["end_time"=>$couponMainData["end_time"]." 00:00:00"]);
2021-12-13 07:57:27 +00:00
Db::commit();
return $this->json();
} catch (RepositoryException $e) {
Db::rollback();
return $this->json(5001, "修改失败失败" );
} catch (\think\Exception $e) {
Db::rollback();
return $this->json(5002, "修改失败500" );
}
}
2021-12-09 10:26:25 +00:00
/**
2022-01-20 05:56:21 +00:00
* 商家管理优惠券
2021-12-09 10:26:25 +00:00
* */
public function getPageList()
{
$accountId = $this->request->user['user_id'] ?? 0;
$account = AccountRepository::getInstance()->findById($accountId, [], function ($q) {
return $q->with(['business', 'parent']);
});
if(empty($account)){
return $this->json(6001,"登录失效");
}
if ($account->type == Account::type_consumer) {
return $this->json(4001, "您不是商家");
}
if (!isset($account->business) || empty($account->business)) {
return $this->json(4001, "商家信息错误");
}
$page = $this->request->param('page/d', 1);
$size = $this->request->param('rows/d', 10);
$page = $page < 1 ? 1 : $page;
$size = $size < 1 ? 10 : $size;
$keyword = $this->request->param('key/s',"");
$businessCode = $account->business_code;
try {
$whereMap = [];
$sortOrder = ['sort' => 'desc'];
$whereMap[] = ["business_code" ,"=", $businessCode ];
if(!empty($keyword)){
$whereMap[] = ["name" ,"like", "%{$keyword}%" ];
}
$res = CouponRepository::getInstance(new CouponMain())->findList($whereMap, [], $page, $size,function ($q){
2022-01-19 05:40:46 +00:00
return $q->with(["couponType"]);
2021-12-09 10:26:25 +00:00
}, $sortOrder);
$time = time();
$res['list'] ->each(function ($item) use($time){
//已使用张数
$item->usingCount = CouponRepository::getInstance()->getCouponMainUsingCount($item->id);
if($item->on_shelf === 0 && strtotime($item->start_time) <= $time && strtotime($item->end_time) >= $time){
2021-12-09 10:26:25 +00:00
$item->conduct = true;
}else{
$item->conduct = false;
}
});
2021-12-23 07:02:41 +00:00
return $this->json(0, 'success', $res);
2021-12-09 10:26:25 +00:00
} catch (RepositoryException | \Exception $e) {
echo $e->getMessage();
return $this->json(5001, '优惠卷查询失败!');
}
}
/**
2022-01-20 05:56:21 +00:00
* 优惠券的领取 使用记录列表
2021-12-09 10:26:25 +00:00
* */
public function getShopCouponList()
{
$accountId = $this->request->user['user_id'] ?? 0;
2021-12-23 03:02:00 +00:00
$keyword = input("key/s");
2021-12-09 10:26:25 +00:00
$account = AccountRepository::getInstance()->findById($accountId, [], function ($q) {
return $q->with(['business', 'parent']);
});
if(empty($account)){
return $this->json(6001,"登录失效");
}
if ($account->type == Account::type_consumer) {
return $this->json(4001, "您不是商家");
}
if (!isset($account->business) || empty($account->business)) {
return $this->json(4001, "商家信息错误");
}
$couponMainId = input("couponId/d");
$couponMain = CouponMain::findById($couponMainId);
if(empty($couponMain)){
2022-01-20 05:56:21 +00:00
return $this->json(4001, "优惠券不存在");
2021-12-09 10:26:25 +00:00
}
if($couponMain->business_code != $account->business->code){
2022-01-20 05:56:21 +00:00
return $this->json(4001, "优惠券参数信息错误");
2021-12-09 10:26:25 +00:00
}
$page = $this->request->param('page/d', 1);
$size = $this->request->param('rows/d', 10);
$type = $this->request->param('type/s', 10);
$page = $page < 1 ? 1 : $page;
$size = $size < 1 ? 10 : $size;
$sortOrder = ["id"=>"desc"];
$whereMap = [
["coupon_id","=",$couponMainId]
];
2021-12-23 03:02:00 +00:00
if(!empty($keyword)){
$whereMap[] = ["consumer_name", "like", "%{$keyword}%"];
}
2021-12-09 10:26:25 +00:00
switch ($type) {
case 'all':
2022-01-20 05:56:21 +00:00
// 全部持有优惠券
2021-12-09 10:26:25 +00:00
$sortOrder = [ 'end_time' => 'asc'];
break;
case 'notUsed':
// 未使用(包含已过期)
$whereMap[] = ['is_verificated', '=', self::BOOL_FALSE];
$sortOrder = ['end_time' => 'asc'];
break;
case 'normal':
// 未使用且未过期
$whereMap[] = ['is_verificated', '=', self::BOOL_FALSE];
$whereMap[] = ['end_time', '< TIME', date('Y-m-d H:i:s')];
break;
case 'used':
// 已使用
$whereMap[] = ['is_verificated', '=', self::BOOL_TRUE];
$sortOrder = ['verificate_time' => 'desc'];
break;
}
2021-12-23 03:02:00 +00:00
$field = ["is_verificated","received_time","verificate_time","consumer_code","consumer_name"];
2021-12-09 10:26:25 +00:00
$data = CouponRepository::getInstance()->findList($whereMap,$field,$page,$size,function($q){
2021-12-10 10:25:14 +00:00
return $q->withjoin(["account"=>function($q){
2021-12-09 10:26:25 +00:00
$q->field(["nick_name","avatar_url","gender","user_code"]);
}]);
},$sortOrder);
2021-12-10 10:25:14 +00:00
//所有
$data["allNum"] = CouponRepository::getInstance()->getModel()->where(["coupon_id"=>$couponMainId])->count();
2021-12-09 10:26:25 +00:00
//未使用
$data["unUsedNum"] = CouponRepository::getInstance()->getModel()->where(['is_verificated' => self::BOOL_FALSE,"coupon_id"=>$couponMainId])->count();
2021-12-10 10:25:14 +00:00
//已使用
2021-12-09 10:26:25 +00:00
$data["usedNum"] = CouponRepository::getInstance()->getModel()->where(['is_verificated' => self::BOOL_TRUE ,"coupon_id"=>$couponMainId])->count();
return $this->json(0,"success",$data);
}
2021-12-13 07:57:27 +00:00
/**
2022-01-20 05:56:21 +00:00
* 获取优惠券详情
2021-12-13 07:57:27 +00:00
* */
public function getCouponMainInfo()
{
$couponMainId = input("couponMainId/d");
$couponMain = CouponMain::findById($couponMainId,[],function ($q){
2022-01-19 05:40:46 +00:00
return $q->with(["business"=>function($q){
2021-12-17 03:41:27 +00:00
$q->field("code,business_subtitle");
}]);
2021-12-13 07:57:27 +00:00
});
if(empty($couponMain)){
2022-01-20 05:56:21 +00:00
return $this->json(4001,"优惠券不存在");
2021-12-13 07:57:27 +00:00
}
return $this->json(0,"success",$couponMain->toArray());
}
2021-12-14 09:34:27 +00:00
/**
2022-01-20 05:56:21 +00:00
* 已使用优惠券 评分
2021-12-14 09:34:27 +00:00
* */
public function score()
{
$accountId = $this->request->user['user_id'] ?? 0;
$couponId = input("couponId/d",0);
$score = input("score/d",5);
if($score > 5|| $score <= 0){
return $this->json(4001, "参数错误");
}
$account = AccountRepository::getInstance()->findById($accountId, [], function ($q) {
return $q->with(['business', 'parent']);
});
if(empty($account)){
return $this->json(6001,"无效的用户");
}
$coupon = CouponRepository::getInstance()->findById($couponId,[],function ($q){
return $q->with(["scoreModel"]);
});
if($coupon->consumer_code != $account->user_code ){
return $this->json(4001, "参数错误");
}
if(isset($score->scoreModel) && $score->scoreModel){
return $this->json(4001, "已经评论过了");
}
try {
$coupon->scoreModel()->save([
"user_code"=>$account->user_code,
"business_code"=>$coupon->business_code,
"score"=>$score,
"coupon_id"=>$coupon->id,
"create_time"=>date("Y-m-d H:i:s"),
]);
return $this->json();
}catch (RepositoryException| \Exception $e){
return $this->json(4001, "评分失败");
}
}
}