You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
186 lines
5.5 KiB
186 lines
5.5 KiB
<?php
|
|
// +----------------------------------------------------------------------
|
|
// | CRMEB [ CRMEB赋能开发者,助力企业发展 ]
|
|
// +----------------------------------------------------------------------
|
|
// | Copyright (c) 2016~2023 https://www.crmeb.com All rights reserved.
|
|
// +----------------------------------------------------------------------
|
|
// | Licensed CRMEB并不是自由软件,未经许可不能去掉CRMEB相关版权
|
|
// +----------------------------------------------------------------------
|
|
// | Author: CRMEB Team <admin@crmeb.com>
|
|
// +----------------------------------------------------------------------
|
|
namespace app\adminapi\controller\v1\system;
|
|
|
|
use think\facade\App;
|
|
use think\facade\Db;
|
|
use think\facade\Session;
|
|
use app\adminapi\controller\AuthController;
|
|
use app\services\system\SystemDatabackupServices;
|
|
|
|
|
|
/**
|
|
* 数据备份
|
|
* Class SystemDatabackup
|
|
* @package app\admin\controller\system
|
|
*
|
|
*/
|
|
class SystemDatabackup extends AuthController
|
|
{
|
|
/**
|
|
* 构造方法
|
|
* SystemDatabackup constructor.
|
|
* @param App $app
|
|
* @param SystemDatabackupServices $services
|
|
*/
|
|
public function __construct(App $app, SystemDatabackupServices $services)
|
|
{
|
|
parent::__construct($app);
|
|
$this->services = $services;
|
|
}
|
|
|
|
/**
|
|
* 获取数据库表
|
|
*/
|
|
public function index()
|
|
{
|
|
return app('json')->success($this->services->getDataList());
|
|
}
|
|
|
|
/**
|
|
* 查看表结构 详情
|
|
*/
|
|
public function read()
|
|
{
|
|
$tablename = request()->param('tablename', '', 'htmlspecialchars');
|
|
return app('json')->success($this->services->getRead($tablename));
|
|
}
|
|
|
|
/**
|
|
* 更新数据表或者表字段备注
|
|
* @return \think\Response
|
|
* @author 吴汐
|
|
* @email 442384644@qq.com
|
|
* @date 2023/04/11
|
|
*/
|
|
public function updateMark()
|
|
{
|
|
[$table, $field, $type, $mark, $is_field] = $this->request->postMore([
|
|
['table', ''],
|
|
['field', ''],
|
|
['type', ''],
|
|
['mark', ''],
|
|
['is_field', 0],
|
|
], true);
|
|
if ($is_field == 0) {
|
|
$sql = "ALTER TABLE $table COMMENT '$mark'";
|
|
} else {
|
|
$sql = "ALTER TABLE $table MODIFY COLUMN $field $type COMMENT '$mark'";
|
|
}
|
|
Db::execute($sql);
|
|
return app('json')->success(100024);
|
|
}
|
|
|
|
/**
|
|
* 优化表
|
|
*/
|
|
public function optimize()
|
|
{
|
|
$tables = $this->request->param('tables', '', 'htmlspecialchars');
|
|
$res = $this->services->getDbBackup()->optimize($tables);
|
|
return app('json')->success($res ? 100047 : 100048);
|
|
}
|
|
|
|
/**
|
|
* 修复表
|
|
*/
|
|
public function repair()
|
|
{
|
|
$tables = $this->request->param('tables', '', 'htmlspecialchars');
|
|
$res = $this->services->getDbBackup()->repair($tables);
|
|
return app('json')->success($res ? 100049 : 100050);
|
|
}
|
|
|
|
/**
|
|
* 备份表
|
|
*/
|
|
public function backup()
|
|
{
|
|
$tables = $this->request->param('tables', '', 'htmlspecialchars');
|
|
$data = $this->services->backup($tables);
|
|
return app('json')->success(100051);
|
|
}
|
|
|
|
/**
|
|
* 获取备份记录表
|
|
*/
|
|
public function fileList()
|
|
{
|
|
return app('json')->success($this->services->getBackup());
|
|
}
|
|
|
|
/**
|
|
* 删除备份记录表
|
|
*/
|
|
public function delFile()
|
|
{
|
|
$filename = intval(request()->post('filename'));
|
|
$files = $this->services->getDbBackup()->delFile($filename);
|
|
return app('json')->success(100002);
|
|
}
|
|
|
|
/**
|
|
* 导入备份记录表
|
|
*/
|
|
public function import()
|
|
{
|
|
[$part, $start, $time] = $this->request->postMore([
|
|
[['part', 'd'], 0],
|
|
[['start', 'd'], 0],
|
|
[['time', 'd'], 0],
|
|
], true);
|
|
$db = $this->services->getDbBackup();
|
|
if (is_numeric($time) && !$start) {
|
|
$list = $db->getFile('timeverif', $time);
|
|
if (is_array($list)) {
|
|
session::set('backup_list', $list);
|
|
return app('json')->success(400307, array('part' => 1, 'start' => 0));
|
|
} else {
|
|
return app('json')->fail(400308);
|
|
}
|
|
} else if (is_numeric($part) && is_numeric($start) && $part && $start) {
|
|
$list = session::get('backup_list');
|
|
$start = $db->setFile($list)->import($start);
|
|
if (false === $start) {
|
|
return app('json')->fail(400309);
|
|
} elseif (0 === $start) {
|
|
if (isset($list[++$part])) {
|
|
$data = array('part' => $part, 'start' => 0);
|
|
return app('json')->success(400310, $data);
|
|
} else {
|
|
session::delete('backup_list');
|
|
return app('json')->success(400311);
|
|
}
|
|
} else {
|
|
$data = array('part' => $part, 'start' => $start[0]);
|
|
if ($start[1]) {
|
|
$rate = floor(100 * ($start[0] / $start[1]));
|
|
return app('json')->success(400310, $data);
|
|
} else {
|
|
$data['gz'] = 1;
|
|
return app('json')->success(400310, $data);
|
|
}
|
|
}
|
|
} else {
|
|
return app('json')->fail(100100);
|
|
}
|
|
}
|
|
|
|
/**
|
|
* 下载备份记录表
|
|
*/
|
|
public function downloadFile()
|
|
{
|
|
$time = intval(request()->param('time'));
|
|
return app('json')->success(['key' => $this->services->getDbBackup()->downloadFile($time, 0, true)]);
|
|
}
|
|
|
|
}
|
|
|