Compare commits
4 Commits
20250806-0
...
20250806-1
| Author | SHA1 | Date | |
|---|---|---|---|
| eb0ce8a347 | |||
| edf270a6ce | |||
| c4c154cbb9 | |||
| ff36733005 |
46
app/Cron/Coupon/UserCouponTask.php
Normal file
46
app/Cron/Coupon/UserCouponTask.php
Normal file
@@ -0,0 +1,46 @@
|
||||
<?php
|
||||
/**
|
||||
* This crontab file is part of item.
|
||||
*
|
||||
* @author ctexthuang
|
||||
* @contact ctexthuang@qq.com
|
||||
*/
|
||||
|
||||
declare(strict_types=1);
|
||||
|
||||
namespace App\Cron\Coupon;
|
||||
|
||||
use App\Constants\Common\CouponCode;
|
||||
use App\Lib\Log;
|
||||
use App\Model\UserCoupon;
|
||||
use Exception;
|
||||
use Hyperf\Crontab\Annotation\Crontab;
|
||||
use Hyperf\Di\Annotation\Inject;
|
||||
|
||||
#[Crontab(rule: "* * * * *", name: "UserCouponTask", singleton: true , callback: "execute", memo: "每秒执行优惠券过期")]
|
||||
class UserCouponTask
|
||||
{
|
||||
/**
|
||||
* @var Log
|
||||
*/
|
||||
#[Inject]
|
||||
protected Log $log;
|
||||
|
||||
/**
|
||||
* @var UserCoupon
|
||||
*/
|
||||
#[Inject]
|
||||
protected UserCoupon $userCouponModel;
|
||||
|
||||
public function execute()
|
||||
{
|
||||
try {
|
||||
$this->userCouponModel
|
||||
->whereTime('validity_end_time', '>', date('Y-m-d H:i:s'))
|
||||
->where('status', CouponCode::COUPON_STATUS_UNUSED)
|
||||
->update(['status' => CouponCode::COUPON_STATUS_EXPIRE]);
|
||||
}catch (Exception $e){
|
||||
$this->log->error(__CLASS__.$e->getMessage());
|
||||
}
|
||||
}
|
||||
}
|
||||
@@ -40,8 +40,8 @@ class UserCoupon extends Model
|
||||
*/
|
||||
protected array $casts = ['id' => 'integer', 'coupon_template_id' => 'integer', 'coupon_dispense_id' => 'integer', 'user_id' => 'integer', 'status' => 'integer'];
|
||||
|
||||
const string CREATED_AT = 'created_time';
|
||||
const string UPDATED_AT = 'updated_time';
|
||||
const string CREATED_AT = 'create_time';
|
||||
const string UPDATED_AT = 'update_time';
|
||||
|
||||
public function getReceiveCountByUserIds(int $user_id,array $couponIdArr): array
|
||||
{
|
||||
|
||||
@@ -63,7 +63,7 @@ class YlyPrintService implements PrintOrderInterface
|
||||
* @var Log
|
||||
*/
|
||||
#[Inject]
|
||||
private Log $log;
|
||||
protected Log $log;
|
||||
|
||||
/**
|
||||
* @return void
|
||||
|
||||
@@ -33,8 +33,10 @@ trait CouponTrait
|
||||
$couponInfo = $this->userCouponModel->where('id', $orderInfo->coupon_id)->where('user_id',$orderInfo->user_id)->first();
|
||||
|
||||
if (empty($couponInfo)) return;
|
||||
if ($couponInfo->status != CouponCode::COUPON_STATUS_USED) return;
|
||||
|
||||
$couponInfo->status = CouponCode::COUPON_STATUS_UNUSED;
|
||||
$couponInfo->use_time = null;
|
||||
|
||||
if (date('Y-m-d H:i:s') > $couponInfo->validity_end_time) $couponInfo->status = CouponCode::COUPON_STATUS_EXPIRE;
|
||||
|
||||
|
||||
Reference in New Issue
Block a user