SystemDatabackup.php 5.6 KB

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