UpdateProjectTdk.php 3.0 KB
<?php
/**
 * @remark :
 * @name   :UpdateProjectTdk.php
 * @author :lyh
 * @method :post
 * @time   :2025/7/2 11:11
 */

namespace App\Console\Commands\Tdk;

use App\Models\Com\NoticeLog;
use Illuminate\Console\Command;
use Illuminate\Support\Facades\Redis;
use PhpOffice\PhpSpreadsheet\IOFactory;

class UpdateProjectTdk extends Command
{
    /**
     * The name and signature of the console command.
     *
     * @var string
     */
    protected $signature = 'update_project_tdk';

    /**
     * The console command description.
     *
     * @var string
     */
    protected $description = '根据给定的文件更新项目的tdk';


    public function handle(){
        $noticeLogModel = new NoticeLog();
        while (true){
            $task_id = $this->getTaskId();
            if(empty($task_id)){
                sleep(30);
                continue;
            }
            $info = $noticeLogModel->read(['id'=>$task_id]);
            if($info === false){
                echo 'start--'.PHP_EOL;
                $project_id = $info['data']['project_id'] ?? 0;
                if(empty($project_id)){
                    dd(4444);
                    echo date('Y-m-d H:i:s').'未获取到项目id.'.PHP_EOL;
                    $noticeLogModel->edit(['status'=>$noticeLogModel::STATUS_FAIL],['id'=>$task_id]);
                    continue;
                }
                $url = $info['data']['url'] ?? '';
                if(empty($url)){
                    dd(33333);
                    echo date('Y-m-d H:i:s').'未获取到项目更新文件.项目id为:'.$project_id.PHP_EOL;
                    //未获取到文件,跳过
                    $noticeLogModel->edit(['status'=>$noticeLogModel::STATUS_SUCCESS],['id'=>$task_id]);
                    continue;
                }
                if (!file_exists($url)) {
                    dd(222222);
                    continue;
                }
                dd($url);
                // 载入 Excel
                $spreadsheet = IOFactory::load($url);
                $sheet = $spreadsheet->getActiveSheet();
                $rows = $sheet->toArray();
                dd($rows);
                // 假设第一行是表头
                $header = $rows[0];
                $dataRows = array_slice($rows, 1);
            }
        }
        return true;
    }

    /**
     * @remark :获取任务id
     * @name   :getTaskId
     * @author :lyh
     * @method :post
     * @time   :2025/7/2 11:19
     */
    public function getTaskId()
    {
        $task_id = Redis::rpop('update_project_tdk_task');
        if (empty($task_id)) {
            $noticeLogModel = new NoticeLog();
            $ids = $noticeLogModel->selectField(['status'=>$noticeLogModel::STATUS_PENDING,'type'=>$noticeLogModel::TYPE_UPDATE_PROJECT_TDK],'id');
             if(!empty($ids)){
                foreach ($ids as $id) {
                    Redis::lpush('update_project_tdk_task', $id);
                }
            }
            $task_id = Redis::rpop('update_project_tdk_task');
        }
        return $task_id;
    }
}