123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190 |
- <?php
- namespace app\adminapi\controller\v1\system;
- use app\adminapi\controller\AuthController;
- use app\models\system\SystemConfig;
- use \crmeb\services\MysqlBackupService as Backup;
- use crmeb\services\UtilService;
- use think\facade\Env;
- use think\facade\Session;
- use think\facade\Db;
- class SystemDatabackup extends AuthController
- {
-
- protected $DB;
- public function initialize()
- {
- parent::initialize();
- $config = array(
-
- 'compress' => 1,
-
- 'level' => 5,
- );
- $this->DB = new Backup($config);
- }
-
- public function index()
- {
- $db = $this->DB;
- $list = $db->dataList();
- $count = count($list);
- return $this->success(compact('count', 'list'));
- }
-
- public function read()
- {
- $database = Env::get("database.database");
- $tablename = request()->param('tablename', '', 'htmlspecialchars');
- $res = Db::query("select * from information_schema.columns where table_name = '" . $tablename . "' and table_schema = '" . $database . "'");
- $count = count($res);
- foreach ($res AS $key => $f) {
- $res[$key]['EXTRA'] = ($f['EXTRA'] == 'auto_increment' ? '是' : ' ');
- }
- return $this->success(['count' => $count, 'list' => $res]);
- }
-
- public function optimize()
- {
- $tables = $this->request->param('tables');
- $db = $this->DB;
- $res = $db->optimize($tables);
- return $this->success($res ? '优化成功' : '优化失败');
- }
-
- public function repair()
- {
- $tables = $this->request->param('tables');
- $db = $this->DB;
- $res = $db->repair($tables);
- return $this->success($res ? '修复成功' : '修复失败');
- }
-
- public function backup()
- {
- $tables = $this->request->param('tables');
- $tables = explode(',', $tables);
- $db = $this->DB;
- $data = '';
- foreach ($tables as $t) {
- $res = $db->backup($t, 0);
- if ($res == false && $res != 0) {
- $data .= $t . '|';
- }
- }
- return $this->success($data ? '备份失败' . $data : '备份成功');
- }
-
- public function fileList()
- {
- $db = $this->DB;
- $files = $db->fileList();
- $data = [];
- foreach ($files as $key => $t) {
- $data[$key]['filename'] = $t['filename'];
- $data[$key]['part'] = $t['part'];
- $data[$key]['size'] = $t['size'] . 'B';
- $data[$key]['compress'] = $t['compress'];
- $data[$key]['backtime'] = $key;
- $data[$key]['time'] = $t['time'];
- }
- krsort($data);
- return $this->success(['count' => count($data), 'list' => array_values($data)]);
- }
-
- public function delFile()
- {
- $filename = intval(request()->post('filename'));
- $files = $this->DB->delFile($filename);
- return $this->success('删除成功');
- }
-
- public function import()
- {
- [$part, $start, $time] = UtilService::postMore([
- [['part', 'd'], 0],
- [['start', 'd'], 0],
- [['time', 'd'], 0],
- ], null, true);
- $db = $this->DB;
- if (is_numeric($time) && !$start) {
- $list = $db->getFile('timeverif', $time);
- if (is_array($list)) {
- session::set('backup_list', $list);
- return $this->success('初始化完成!', array('part' => 1, 'start' => 0));
- } else {
- return $this->fail('备份文件可能已经损坏,请检查!');
- }
- } 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 $this->fail('还原数据出错!');
- } elseif (0 === $start) {
- if (isset($list[++$part])) {
- $data = array('part' => $part, 'start' => 0);
- return $this->success("正在还原...#{$part}", $data);
- } else {
- session::delete('backup_list');
- return $this->success('还原完成!');
- }
- } else {
- $data = array('part' => $part, 'start' => $start[0]);
- if ($start[1]) {
- $rate = floor(100 * ($start[0] / $start[1]));
- return $this->success("正在还原...#{$part}({$rate}%)", $data);
- } else {
- $data['gz'] = 1;
- return $this->success("正在还原...#{$part}", $data);
- }
- return $this->success("正在还原...#{$part}");
- }
- } else {
- return $this->fail('参数错误!');
- }
- }
-
- public function downloadFile()
- {
- $time = intval(request()->param('time'));
- $this->DB->downloadFile($time);
- }
- }
|