lyhDemo.php 2.6 KB
<?php
/**
 * @remark :
 * @name   :lyhDemo.php
 * @author :lyh
 * @method :post
 * @time   :2025/3/24 9:38
 */

namespace App\Console\Commands\LyhTest;

use App\Console\Commands\Domain\DomainInfo;
use App\Http\Logic\Aside\Project\ProjectLogic;
use App\Models\Ai\AiBlogAuthor;
use App\Models\Com\NoticeLog;
use App\Models\Project\AiBlogTask;
use App\Models\Project\DeployBuild;
use App\Models\Project\OnlineCheck;
use App\Models\Project\Project;
use App\Models\Project\ProjectAiSetting;
use App\Models\Visit\Visit;
use App\Models\WebSetting\WebSetting;
use App\Services\AiBlogService;
use App\Services\ProjectServer;
use Illuminate\Console\Command;
use Illuminate\Support\Facades\Artisan;
use Illuminate\Support\Facades\DB;

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

    /**
     * The console command description.
     *
     * @var string
     */
    protected $description = '更新路由';

    public function handle(){
        $projectIds = DB::table('gl_project_ai_setting_copy1')
            ->whereIn('mch_id', function ($query) {
                $query->select('mch_id')
                    ->from('gl_project_ai_setting')
                    ->groupBy('mch_id')
                    ->havingRaw('COUNT(*) > 1');
            })
            ->pluck('project_id');
        $projectIds[] = 811;
        $projectIds[] = 1367;
        $projectIds[] = 1370;
        $projectIds[] = 2201;
        $projectIds[] = 2260;
        $projectIds[] = 2259;

        $projectAiSettingModel = new ProjectAiSetting();
        $projectAiSettingModel->del(['project_id'=>['in',$projectIds]]);
        $projectModel = new Project();
        $logic = new ProjectLogic();
        $lists = $projectModel->list(['delete_status' => 0,'extend_type'=>0,'id'=>['in',$projectIds]], 'id', ['id']);
        foreach ($lists as $val) {
            //清空作者
            ProjectServer::useProject($val['id']);
            AiBlogAuthor::truncate();
            DB::disconnect('custom_mysql');
            //重新创建项目拉取作者
            $info = $logic->getProjectInfo($val['id']);
            echo date('Y-m-d H:i:s') . '开始--项目的id:'. $val['id'] . PHP_EOL;
            $logic->setAiBlog($info['id'],$info['main_lang_id'],$info['is_ai_blog'] ?? 0,
                $info['company']??"", $info['deploy_optimize']['company_en_name'] ?? '',
                $info['deploy_optimize']['company_en_description'] ?? '',$info['is_ai_video'] ?? 0,$info['is_related_video'] ?? 0);
        }
        return true;
    }

}