SystemDatabackup.php 5.5 KB

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