ServerConfigLogic.php
2.8 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
<?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\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();
errorLog('项目运维服务配置保存失败', $param, $e);
$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();
}
}