ServerConfigLogic.php 2.7 KB
<?php

namespace App\Http\Logic\Aside\Devops;



use App\Http\Logic\Aside\BaseLogic;
use App\Http\Logic\Aside\Project\ProjectLogic;
use App\Models\Devops\DevopsTask;
use App\Models\Project;
use App\Models\Devops\ServerConfig;
use App\Services\ProjectServer;
use Illuminate\Support\Facades\DB;

/**
 * Class ServerConfigLogic
 * @package App\Http\Logic\Aside
 * @author zbj
 * @date 2023/4/23
 */
class ServerConfigLogic extends BaseLogic
{
    public function __construct()
    {
        parent::__construct();

        $this->model = new ServerConfig();
    }


    public function save($param)
    {
        $project_logic = new ProjectLogic();
        $project = $project_logic->getCacheInfo($param['project_id']);
        if(!$project){
            $this->fail('项目不存在或者已经删除');
        }
        DB::beginTransaction();
        try {
            //保存配置
            $res = parent::save($param);

            //关联到项目
            $data['id'] = $param['project_id'];
            if ($param['type'] == ServerConfig::TYPE_SERVER) {
                $data['serve_id'] = $res['id'];
            }else{
                $data['mysql_id'] = $res['id'];
            }
            $project_logic->save($data);

            //初始化数据库
            if ($param['type'] == ServerConfig::TYPE_MYSQL) {
                //切换数据库配置
                $project = ProjectServer::useProject($param['project_id']);
                //创建数据库
                ProjectServer::createDatabase($project);
                //创建表
                ProjectServer::initTable($project);
            }

            DB::commit();
        } catch (\Exception $e) {
            DB::rollBack();
            $this->fail('保存失败');
        }
        return $this->success();
    }


    /**
     * 更新指定项目 数据库
     * @param $param
     * @return array
     * @author zbj
     * @date 2023/4/24
     */
    public function updateTable($param){
        $project = ProjectServer::useProject($param['project_id']);
        if(!$project){
            $this->fail('项目不存在或数据库未配置');
        }
        DB::connection('custom_mysql')->statement($param['sql']);
        return $this->success();
    }

    /**
     * 更新本地 数据库
     * @param $param
     * @return array
     * @author zbj
     * @date 2023/4/24
     */
    public function updateLocalTable($param){
        DB::statement($param['sql']);
        return $this->success();
    }

    /**
     * 更新所有项目 数据库
     * @param $param
     * @return array
     * @author zbj
     * @date 2023/4/24
     */
    public function updateAllTable($param){
        DevopsTask::addTask($param['sql']);
        return $this->success();
    }
}