86 lines
2.5 KiB
PHP
Executable File
86 lines
2.5 KiB
PHP
Executable File
<?php
|
|
// +----------------------------------------------------------------------
|
|
// | 宏驰云科技开发团队 版权所有 拥有最终解释权
|
|
// +----------------------------------------------------------------------
|
|
|
|
// | Author: HcyShop-kiki
|
|
// +----------------------------------------------------------------------
|
|
|
|
namespace app\common\command;
|
|
|
|
use app\common\logic\OrderLogLogic;
|
|
use app\common\model\Order;
|
|
use app\common\model\OrderLog;
|
|
use app\common\model\Pay;
|
|
use app\common\server\ConfigServer;
|
|
use think\console\Command;
|
|
use think\console\Input;
|
|
use think\console\Output;
|
|
use think\Db;
|
|
use think\facade\Hook;
|
|
use think\facade\Log;
|
|
|
|
/**
|
|
* 确认收货
|
|
* Class OrderFinish
|
|
* @package app\common\command
|
|
*/
|
|
class OrderFinish extends Command
|
|
{
|
|
protected function configure()
|
|
{
|
|
$this->setName('order_finish')
|
|
->setDescription('自动确认收货(待收货订单)');
|
|
}
|
|
|
|
protected function execute(Input $input, Output $output)
|
|
{
|
|
$now = time();
|
|
$config = ConfigServer::get('trading', 'order_finish', 0);
|
|
if($config == 0){
|
|
return true;
|
|
}
|
|
|
|
$finish_limit = $config * 24 * 60 * 60;
|
|
|
|
$orders = Db::name('order')
|
|
->where(['order_status' => Order::STATUS_WAIT_RECEIVE, 'pay_status' => Pay::ISPAID, 'del' => 0])
|
|
->where(Db::raw("shipping_time+$finish_limit < $now"))
|
|
->select();
|
|
if (empty($orders)){
|
|
return true;
|
|
}
|
|
|
|
Db::startTrans();
|
|
try{
|
|
foreach ($orders as $order){
|
|
Db::name('order')
|
|
->where(['id' => $order['id']])
|
|
->update([
|
|
'order_status' => Order::STATUS_FINISH,
|
|
'update_time' => $now,
|
|
'confirm_take_time' => $now,
|
|
]);
|
|
|
|
// 赠送成长值和积分
|
|
Hook::listen('give_reward', [
|
|
'order_id' => $order['id'],
|
|
'scene' => 4, //4=订单结算
|
|
]);
|
|
|
|
//订单日志
|
|
OrderLogLogic::record(
|
|
OrderLog::TYPE_SYSTEM,
|
|
OrderLog::SYSTEM_CONFIRM_ORDER,
|
|
$order['id'],
|
|
0,
|
|
OrderLog::SYSTEM_CONFIRM_ORDER
|
|
);
|
|
}
|
|
Db::commit();
|
|
} catch (\Exception $e){
|
|
Log::write('订单自动确认失败,失败原因:'.$e->getMessage());
|
|
Db::rollback();
|
|
}
|
|
}
|
|
} |