CleanupBackupController.php 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328
  1. <?php
  2. namespace App\Module\Cleanup\AdminControllers;
  3. use App\Module\Cleanup\Models\CleanupBackup;
  4. use App\Module\Cleanup\Repositories\CleanupBackupRepository;
  5. use App\Module\Cleanup\Enums\BACKUP_TYPE;
  6. use App\Module\Cleanup\Enums\COMPRESSION_TYPE;
  7. use App\Module\Cleanup\Enums\BACKUP_STATUS;
  8. use UCore\DcatAdmin\AdminController;
  9. use Dcat\Admin\Form;
  10. use Dcat\Admin\Grid;
  11. use Dcat\Admin\Show;
  12. use Dcat\Admin\Layout\Content;
  13. use Spatie\RouteAttributes\Attributes\Resource;
  14. /**
  15. * 备份管理控制器
  16. *
  17. * 路由:/admin/cleanup/backups
  18. */
  19. #[Resource('cleanup/backups', names: 'dcat.admin.cleanup.backups')]
  20. class CleanupBackupController extends AdminController
  21. {
  22. /**
  23. * 页面标题
  24. */
  25. protected $title = '备份管理';
  26. /**
  27. * 数据仓库
  28. */
  29. protected function repository()
  30. {
  31. return CleanupBackupRepository::class;
  32. }
  33. /**
  34. * 列表页面
  35. */
  36. protected function grid(): Grid
  37. {
  38. return Grid::make(new CleanupBackupRepository(), function (Grid $grid) {
  39. // 基础设置
  40. $grid->column('id', 'ID')->sortable();
  41. $grid->column('backup_name', '备份名称')->sortable();
  42. // 关联信息
  43. $grid->column('plan.plan_name', '关联计划')->sortable();
  44. $grid->column('task.task_name', '关联任务')->sortable();
  45. // 备份类型
  46. $grid->column('backup_type', '备份类型')->using([
  47. 1 => 'SQL',
  48. 2 => 'JSON',
  49. 3 => 'CSV',
  50. ])->label([
  51. 1 => 'primary',
  52. 2 => 'info',
  53. 3 => 'warning',
  54. ])->sortable();
  55. // 压缩类型
  56. $grid->column('compression_type', '压缩类型')->using([
  57. 1 => '无压缩',
  58. 2 => 'GZIP',
  59. 3 => 'ZIP',
  60. ])->sortable();
  61. // 备份状态
  62. $grid->column('backup_status', '备份状态')->using([
  63. 1 => '进行中',
  64. 2 => '已完成',
  65. 3 => '已失败',
  66. ])->label([
  67. 1 => 'info',
  68. 2 => 'success',
  69. 3 => 'danger',
  70. ])->sortable();
  71. // 大小信息
  72. $grid->column('backup_size', '备份大小')->display(function ($value) {
  73. return \App\Module\Cleanup\Helpers\FormatHelper::formatBytes($value);
  74. })->sortable();
  75. $grid->column('original_size', '原始大小')->display(function ($value) {
  76. return \App\Module\Cleanup\Helpers\FormatHelper::formatBytes($value);
  77. })->sortable();
  78. // 统计信息
  79. $grid->column('tables_count', '表数量')->sortable();
  80. $grid->column('records_count', '记录数量')->display(function ($value) {
  81. return number_format($value);
  82. })->sortable();
  83. // 时间信息
  84. $grid->column('started_at', '开始时间')->sortable();
  85. $grid->column('completed_at', '完成时间')->sortable();
  86. $grid->column('expires_at', '过期时间')->sortable();
  87. // 筛选器
  88. $grid->filter(function (Grid\Filter $filter) {
  89. $filter->equal('backup_type', '备份类型')->select([
  90. 1 => 'SQL',
  91. 2 => 'JSON',
  92. 3 => 'CSV',
  93. ]);
  94. $filter->equal('compression_type', '压缩类型')->select([
  95. 1 => '无压缩',
  96. 2 => 'GZIP',
  97. 3 => 'ZIP',
  98. ]);
  99. $filter->equal('backup_status', '备份状态')->select([
  100. 1 => '进行中',
  101. 2 => '已完成',
  102. 3 => '已失败',
  103. ]);
  104. $filter->equal('plan_id', '关联计划')->select(
  105. \App\Module\Cleanup\Models\CleanupPlan::pluck('plan_name', 'id')->toArray()
  106. );
  107. $filter->like('backup_name', '备份名称');
  108. $filter->between('backup_size', '备份大小');
  109. $filter->between('created_at', '创建时间')->datetime();
  110. $filter->between('expires_at', '过期时间')->datetime();
  111. });
  112. // 行操作
  113. $grid->actions(function (Grid\Displayers\Actions $actions) {
  114. $row = $actions->row;
  115. if ($row->backup_status == 2) { // 已完成
  116. $actions->append(new \App\Module\Cleanup\AdminControllers\Actions\DownloadBackupAction());
  117. $actions->append(new \App\Module\Cleanup\AdminControllers\Actions\RestoreBackupAction());
  118. }
  119. $actions->append(new \App\Module\Cleanup\AdminControllers\Actions\ViewBackupFilesAction());
  120. if ($row->backup_status != 1) { // 非进行中状态可以删除
  121. $actions->append(new \App\Module\Cleanup\AdminControllers\Actions\DeleteBackupAction());
  122. }
  123. });
  124. // 批量操作
  125. $grid->batchActions([
  126. new \App\Module\Cleanup\AdminControllers\Actions\BatchDeleteBackupAction(),
  127. ]);
  128. // 工具栏
  129. $grid->tools([
  130. new \App\Module\Cleanup\AdminControllers\Actions\CleanExpiredBackupsAction(),
  131. ]);
  132. // 设置每页显示数量
  133. $grid->paginate(20);
  134. // 默认排序
  135. $grid->model()->orderBy('created_at', 'desc');
  136. });
  137. }
  138. /**
  139. * 详情页面
  140. */
  141. protected function detail($id): Show
  142. {
  143. return Show::make($id, new CleanupBackupRepository(), function (Show $show) {
  144. $show->field('id', 'ID');
  145. $show->field('backup_name', '备份名称');
  146. $show->field('plan.plan_name', '关联计划');
  147. $show->field('task.task_name', '关联任务');
  148. $show->field('backup_type', '备份类型')->using([
  149. 1 => 'SQL',
  150. 2 => 'JSON',
  151. 3 => 'CSV',
  152. ]);
  153. $show->field('compression_type', '压缩类型')->using([
  154. 1 => '无压缩',
  155. 2 => 'GZIP',
  156. 3 => 'ZIP',
  157. ]);
  158. $show->field('backup_status', '备份状态')->using([
  159. 1 => '进行中',
  160. 2 => '已完成',
  161. 3 => '已失败',
  162. ]);
  163. $show->field('backup_path', '备份路径');
  164. // 大小信息
  165. $show->field('backup_size', '备份大小')->display(function ($value) {
  166. return \App\Module\Cleanup\Helpers\FormatHelper::formatBytes($value);
  167. });
  168. $show->field('original_size', '原始大小')->display(function ($value) {
  169. return \App\Module\Cleanup\Helpers\FormatHelper::formatBytes($value);
  170. });
  171. // 统计信息
  172. $show->field('tables_count', '表数量');
  173. $show->field('records_count', '记录数量')->display(function ($value) {
  174. return number_format($value);
  175. });
  176. $show->field('backup_hash', '备份哈希');
  177. $show->field('backup_config', '备份配置')->json();
  178. // 时间信息
  179. $show->field('started_at', '开始时间');
  180. $show->field('completed_at', '完成时间');
  181. $show->field('expires_at', '过期时间');
  182. $show->field('error_message', '错误信息');
  183. $show->field('created_by', '创建者ID');
  184. $show->field('created_at', '创建时间');
  185. $show->field('updated_at', '更新时间');
  186. // 显示备份文件
  187. $show->relation('files', '备份文件', function ($model) {
  188. $grid = new Grid(new \App\Module\Cleanup\Models\CleanupBackupFile());
  189. $grid->model()->where('backup_id', $model->id);
  190. $grid->column('table_name', '表名');
  191. $grid->column('file_name', '文件名');
  192. $grid->column('file_size', '文件大小')->display(function ($value) {
  193. return \App\Module\Cleanup\Helpers\FormatHelper::formatBytes($value);
  194. });
  195. $grid->column('backup_type', '备份类型')->using([
  196. 1 => 'SQL',
  197. 2 => 'JSON',
  198. 3 => 'CSV',
  199. ]);
  200. $grid->column('compression_type', '压缩类型')->using([
  201. 1 => '无压缩',
  202. 2 => 'GZIP',
  203. 3 => 'ZIP',
  204. ]);
  205. $grid->column('created_at', '创建时间');
  206. $grid->disableActions();
  207. $grid->disableCreateButton();
  208. $grid->disableFilter();
  209. $grid->disablePagination();
  210. return $grid;
  211. });
  212. // 显示SQL备份内容(如果是SQL备份)
  213. if ($show->getModel()->backup_type == 1) {
  214. $show->relation('sqlBackups', 'SQL备份内容', function ($model) {
  215. $grid = new Grid(new \App\Module\Cleanup\Models\CleanupSqlBackup());
  216. $grid->model()->where('backup_id', $model->id);
  217. $grid->column('table_name', '表名');
  218. $grid->column('records_count', '记录数量')->display(function ($value) {
  219. return number_format($value);
  220. });
  221. $grid->column('content_size', '内容大小')->display(function ($value) {
  222. return \App\Module\Cleanup\Helpers\FormatHelper::formatBytes($value);
  223. });
  224. $grid->column('created_at', '创建时间');
  225. $grid->disableActions();
  226. $grid->disableCreateButton();
  227. $grid->disableFilter();
  228. $grid->disablePagination();
  229. return $grid;
  230. });
  231. }
  232. });
  233. }
  234. /**
  235. * 表单(只读,备份不允许手动创建/编辑)
  236. */
  237. protected function form(): Form
  238. {
  239. return Form::make(new CleanupBackupRepository(), function (Form $form) {
  240. $form->display('id', 'ID');
  241. $form->display('backup_name', '备份名称');
  242. $form->display('plan.plan_name', '关联计划');
  243. $form->display('task.task_name', '关联任务');
  244. $form->display('backup_type', '备份类型')->using([
  245. 1 => 'SQL',
  246. 2 => 'JSON',
  247. 3 => 'CSV',
  248. ]);
  249. $form->display('compression_type', '压缩类型')->using([
  250. 1 => '无压缩',
  251. 2 => 'GZIP',
  252. 3 => 'ZIP',
  253. ]);
  254. $form->display('backup_status', '备份状态')->using([
  255. 1 => '进行中',
  256. 2 => '已完成',
  257. 3 => '已失败',
  258. ]);
  259. $form->display('backup_path', '备份路径');
  260. $form->display('backup_size', '备份大小');
  261. $form->display('original_size', '原始大小');
  262. $form->display('tables_count', '表数量');
  263. $form->display('records_count', '记录数量');
  264. $form->display('backup_hash', '备份哈希');
  265. $form->display('started_at', '开始时间');
  266. $form->display('completed_at', '完成时间');
  267. $form->display('expires_at', '过期时间');
  268. $form->display('error_message', '错误信息');
  269. $form->display('created_at', '创建时间');
  270. $form->display('updated_at', '更新时间');
  271. // 禁用所有操作
  272. $form->disableCreatingCheck();
  273. $form->disableEditingCheck();
  274. $form->disableViewCheck();
  275. });
  276. }
  277. }