SystemDatabackup.php 5.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185
  1. <?php
  2. // +----------------------------------------------------------------------
  3. // | CRMEB [ CRMEB赋能开发者,助力企业发展 ]
  4. // +----------------------------------------------------------------------
  5. // | Copyright (c) 2016~2023 https://www.crmeb.com All rights reserved.
  6. // +----------------------------------------------------------------------
  7. // | Licensed CRMEB并不是自由软件,未经许可不能去掉CRMEB相关版权
  8. // +----------------------------------------------------------------------
  9. // | Author: CRMEB Team <admin@crmeb.com>
  10. // +----------------------------------------------------------------------
  11. namespace app\adminapi\controller\v1\system;
  12. use think\facade\App;
  13. use think\facade\Db;
  14. use think\facade\Session;
  15. use app\adminapi\controller\AuthController;
  16. use app\services\system\SystemDatabackupServices;
  17. /**
  18. * 数据备份
  19. * Class SystemDatabackup
  20. * @package app\admin\controller\system
  21. *
  22. */
  23. class SystemDatabackup extends AuthController
  24. {
  25. /**
  26. * 构造方法
  27. * SystemDatabackup constructor.
  28. * @param App $app
  29. * @param SystemDatabackupServices $services
  30. */
  31. public function __construct(App $app, SystemDatabackupServices $services)
  32. {
  33. parent::__construct($app);
  34. $this->services = $services;
  35. }
  36. /**
  37. * 获取数据库表
  38. */
  39. public function index()
  40. {
  41. return app('json')->success($this->services->getDataList());
  42. }
  43. /**
  44. * 查看表结构 详情
  45. */
  46. public function read()
  47. {
  48. $tablename = request()->param('tablename', '', 'htmlspecialchars');
  49. return app('json')->success($this->services->getRead($tablename));
  50. }
  51. /**
  52. * 更新数据表或者表字段备注
  53. * @return \think\Response
  54. * @author 吴汐
  55. * @email 442384644@qq.com
  56. * @date 2023/04/11
  57. */
  58. public function updateMark()
  59. {
  60. [$table, $field, $type, $mark] = $this->request->postMore([
  61. ['table', ''],
  62. ['field', ''],
  63. ['type', ''],
  64. ['mark', ''],
  65. ], true);
  66. if ($field == '') {
  67. $sql = "ALTER TABLE $table COMMENT '$mark'";
  68. } else {
  69. $sql = "ALTER TABLE $table MODIFY COLUMN $field $type COMMENT '$mark'";
  70. }
  71. Db::execute($sql);
  72. return app('json')->success(100024);
  73. }
  74. /**
  75. * 优化表
  76. */
  77. public function optimize()
  78. {
  79. $tables = $this->request->param('tables', '', 'htmlspecialchars');
  80. $res = $this->services->getDbBackup()->optimize($tables);
  81. return app('json')->success($res ? 100047 : 100048);
  82. }
  83. /**
  84. * 修复表
  85. */
  86. public function repair()
  87. {
  88. $tables = $this->request->param('tables', '', 'htmlspecialchars');
  89. $res = $this->services->getDbBackup()->repair($tables);
  90. return app('json')->success($res ? 100049 : 100050);
  91. }
  92. /**
  93. * 备份表
  94. */
  95. public function backup()
  96. {
  97. $tables = $this->request->param('tables', '', 'htmlspecialchars');
  98. $data = $this->services->backup($tables);
  99. return app('json')->success(100051);
  100. }
  101. /**
  102. * 获取备份记录表
  103. */
  104. public function fileList()
  105. {
  106. return app('json')->success($this->services->getBackup());
  107. }
  108. /**
  109. * 删除备份记录表
  110. */
  111. public function delFile()
  112. {
  113. $filename = intval(request()->post('filename'));
  114. $files = $this->services->getDbBackup()->delFile($filename);
  115. return app('json')->success(100002);
  116. }
  117. /**
  118. * 导入备份记录表
  119. */
  120. public function import()
  121. {
  122. [$part, $start, $time] = $this->request->postMore([
  123. [['part', 'd'], 0],
  124. [['start', 'd'], 0],
  125. [['time', 'd'], 0],
  126. ], true);
  127. $db = $this->services->getDbBackup();
  128. if (is_numeric($time) && !$start) {
  129. $list = $db->getFile('timeverif', $time);
  130. if (is_array($list)) {
  131. session::set('backup_list', $list);
  132. return app('json')->success(400307, array('part' => 1, 'start' => 0));
  133. } else {
  134. return app('json')->fail(400308);
  135. }
  136. } else if (is_numeric($part) && is_numeric($start) && $part && $start) {
  137. $list = session::get('backup_list');
  138. $start = $db->setFile($list)->import($start);
  139. if (false === $start) {
  140. return app('json')->fail(400309);
  141. } elseif (0 === $start) {
  142. if (isset($list[++$part])) {
  143. $data = array('part' => $part, 'start' => 0);
  144. return app('json')->success(400310, $data);
  145. } else {
  146. session::delete('backup_list');
  147. return app('json')->success(400311);
  148. }
  149. } else {
  150. $data = array('part' => $part, 'start' => $start[0]);
  151. if ($start[1]) {
  152. $rate = floor(100 * ($start[0] / $start[1]));
  153. return app('json')->success(400310, $data);
  154. } else {
  155. $data['gz'] = 1;
  156. return app('json')->success(400310, $data);
  157. }
  158. }
  159. } else {
  160. return app('json')->fail(100100);
  161. }
  162. }
  163. /**
  164. * 下载备份记录表
  165. */
  166. public function downloadFile()
  167. {
  168. $time = intval(request()->param('time'));
  169. return app('json')->success(['key' => $this->services->getDbBackup()->downloadFile($time, 0, true)]);
  170. }
  171. }