98 lines
3.3 KiB
PHP
Executable File
98 lines
3.3 KiB
PHP
Executable File
<?php
|
||
// +----------------------------------------------------------------------
|
||
// | likeshop100%开源免费商用商城系统
|
||
// +----------------------------------------------------------------------
|
||
// | 欢迎阅读学习系统程序代码,建议反馈是我们前进的动力
|
||
// | 开源版本可自由商用,可去除界面版权logo
|
||
// | 商业版本务必购买商业授权,以免引起法律纠纷
|
||
// | 禁止对系统程序代码以任何目的,任何形式的再发布
|
||
// | gitee下载:https://gitee.com/likeshop_gitee
|
||
// | github下载:https://github.com/likeshop-github
|
||
// | 访问官网:https://www.likeshop.cn
|
||
// | 访问社区:https://home.likeshop.cn
|
||
// | 访问手册:http://doc.likeshop.cn
|
||
// | 微信公众号:likeshop技术社区
|
||
// | likeshop团队 版权所有 拥有最终解释权
|
||
// +----------------------------------------------------------------------
|
||
// | author: likeshopTeam
|
||
// +----------------------------------------------------------------------
|
||
|
||
namespace app\common\command;
|
||
|
||
|
||
use app\common\enum\notice\NoticeEnum;
|
||
use app\common\enum\OrderEnum;
|
||
use app\common\enum\OrderLogEnum;
|
||
use app\common\enum\PayEnum;
|
||
use app\common\enum\YesNoEnum;
|
||
use app\common\logic\OrderLogLogic;
|
||
use app\common\model\order\Order;
|
||
use app\common\model\order\OrderLog;
|
||
use app\common\service\ConfigService;
|
||
use think\console\Command;
|
||
use think\console\Input;
|
||
use think\console\Output;
|
||
use think\facade\Db;
|
||
use think\facade\Log;
|
||
|
||
/**
|
||
* 关闭超时待付款订单
|
||
* Class OrderClose
|
||
* @package app\common\command
|
||
*/
|
||
class OrderClose extends Command
|
||
{
|
||
|
||
protected function configure()
|
||
{
|
||
$this->setName('order_close')
|
||
->setDescription('系统关闭超时未付款订单');
|
||
}
|
||
|
||
protected function execute(Input $input, Output $output)
|
||
{
|
||
$now = time();
|
||
$ableClose = ConfigService::get('transaction', 'cancel_unpaid_orders',1);
|
||
$cancelTime = ConfigService::get('transaction', 'cancel_unpaid_orders_times',30) * 60;
|
||
|
||
if ($ableClose == YesNoEnum::NO) {
|
||
return true;
|
||
}
|
||
|
||
$orders = Order::with('order_goods')
|
||
->whereRaw("create_time+$cancelTime < $now")
|
||
->where(['order_status'=>OrderEnum::ORDER_STATUS_WAIT_PAY,'pay_status'=>PayEnum::UNPAID])
|
||
->select()
|
||
->toArray();
|
||
|
||
if (empty($orders)) {
|
||
return true;
|
||
}
|
||
|
||
Db::startTrans();
|
||
try{
|
||
foreach ($orders as $order) {
|
||
//更新订单状态
|
||
Order::update(['order_status' => OrderEnum::ORDER_STATUS_CLOSE,'cancel_time'=>time()], ['id' => $order['id']]);
|
||
|
||
//添加订单日志
|
||
(new OrderLogLogic())->record(OrderLogEnum::TYPE_SYSTEM,OrderLogEnum::SYSTEM_CANCEL_ORDER,$order['id'],0);
|
||
|
||
// 系统取消订单 - 通知买家
|
||
// event('Notice', [
|
||
// 'scene_id' => NoticeEnum::SYSTEM_CANCEL_ORDER_NOTICE,
|
||
// 'params' => [
|
||
// 'user_id' => $order['user_id'],
|
||
// 'order_id' => $order['id']
|
||
// ]
|
||
// ]);
|
||
}
|
||
|
||
Db::commit();
|
||
} catch(\Exception $e) {
|
||
Db::rollback();
|
||
Log::write('订单自动关闭失败,失败原因:' . $e->getMessage());
|
||
}
|
||
}
|
||
|
||
} |