SystemDatabackup.php 6.1 KB

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