SystemDatabackup.php 5.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186
  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, $is_field] = $this->request->postMore([
  61. ['table', ''],
  62. ['field', ''],
  63. ['type', ''],
  64. ['mark', ''],
  65. ['is_field', 0],
  66. ], true);
  67. if ($is_field == 0) {
  68. $sql = "ALTER TABLE $table COMMENT '$mark'";
  69. } else {
  70. $sql = "ALTER TABLE $table MODIFY COLUMN $field $type COMMENT '$mark'";
  71. }
  72. Db::execute($sql);
  73. return app('json')->success(100024);
  74. }
  75. /**
  76. * 优化表
  77. */
  78. public function optimize()
  79. {
  80. $tables = $this->request->param('tables', '', 'htmlspecialchars');
  81. $res = $this->services->getDbBackup()->optimize($tables);
  82. return app('json')->success($res ? 100047 : 100048);
  83. }
  84. /**
  85. * 修复表
  86. */
  87. public function repair()
  88. {
  89. $tables = $this->request->param('tables', '', 'htmlspecialchars');
  90. $res = $this->services->getDbBackup()->repair($tables);
  91. return app('json')->success($res ? 100049 : 100050);
  92. }
  93. /**
  94. * 备份表
  95. */
  96. public function backup()
  97. {
  98. $tables = $this->request->param('tables', '', 'htmlspecialchars');
  99. $data = $this->services->backup($tables);
  100. return app('json')->success(100051);
  101. }
  102. /**
  103. * 获取备份记录表
  104. */
  105. public function fileList()
  106. {
  107. return app('json')->success($this->services->getBackup());
  108. }
  109. /**
  110. * 删除备份记录表
  111. */
  112. public function delFile()
  113. {
  114. $filename = intval(request()->post('filename'));
  115. $files = $this->services->getDbBackup()->delFile($filename);
  116. return app('json')->success(100002);
  117. }
  118. /**
  119. * 导入备份记录表
  120. */
  121. public function import()
  122. {
  123. [$part, $start, $time] = $this->request->postMore([
  124. [['part', 'd'], 0],
  125. [['start', 'd'], 0],
  126. [['time', 'd'], 0],
  127. ], true);
  128. $db = $this->services->getDbBackup();
  129. if (is_numeric($time) && !$start) {
  130. $list = $db->getFile('timeverif', $time);
  131. if (is_array($list)) {
  132. session::set('backup_list', $list);
  133. return app('json')->success(400307, array('part' => 1, 'start' => 0));
  134. } else {
  135. return app('json')->fail(400308);
  136. }
  137. } else if (is_numeric($part) && is_numeric($start) && $part && $start) {
  138. $list = session::get('backup_list');
  139. $start = $db->setFile($list)->import($start);
  140. if (false === $start) {
  141. return app('json')->fail(400309);
  142. } elseif (0 === $start) {
  143. if (isset($list[++$part])) {
  144. $data = array('part' => $part, 'start' => 0);
  145. return app('json')->success(400310, $data);
  146. } else {
  147. session::delete('backup_list');
  148. return app('json')->success(400311);
  149. }
  150. } else {
  151. $data = array('part' => $part, 'start' => $start[0]);
  152. if ($start[1]) {
  153. $rate = floor(100 * ($start[0] / $start[1]));
  154. return app('json')->success(400310, $data);
  155. } else {
  156. $data['gz'] = 1;
  157. return app('json')->success(400310, $data);
  158. }
  159. }
  160. } else {
  161. return app('json')->fail(100100);
  162. }
  163. }
  164. /**
  165. * 下载备份记录表
  166. */
  167. public function downloadFile()
  168. {
  169. $time = intval(request()->param('time'));
  170. return app('json')->success(['key' => $this->services->getDbBackup()->downloadFile($time, 0, true)]);
  171. }
  172. }