'本地服务器存储', 'qiniu' => '七牛云对象存储', 'upyun' => '又拍云USS存储', 'alioss' => '阿里云OSS存储', 'txcos' => '腾讯云COS存储' ]; /** * 系统文件管理 * @auth true * @menu true * @throws \think\db\exception\DataNotFoundException * @throws \think\db\exception\DbException * @throws \think\db\exception\ModelNotFoundException */ public function index() { SystemFile::mQuery()->layTable(function () { $this->title = '系统文件管理'; $this->xexts = SystemFile::mk()->distinct()->column('xext'); }, function (QueryHelper $query) { $query->like('name,hash,xext')->equal('type')->dateBetween('create_at'); $query->where(['issafe' => 0, 'status' => 2, 'uuid' => AdminService::getUserId()]); }); } /** * 数据列表处理 * @param array $data * @return void */ protected function _page_filter(array &$data) { foreach ($data as &$vo) { $vo['ctype'] = $this->types[$vo['type']] ?? $vo['type']; } } /** * 删除系统文件 * @auth true * @return void */ public function remove() { SystemFile::mDelete(); } /** * 清理重复文件 * @auth true * @return void */ public function distinct() { $map = ['uuid' => AdminService::getUserId()]; $db1 = SystemFile::mk()->fieldRaw('max(id) id')->where($map)->group('type,hash'); $db2 = $this->app->db->table($db1->buildSql())->alias('dt')->field('id'); SystemFile::mk()->whereRaw("id not in {$db2->buildSql()}")->delete(); $this->success('清理重复文件记录'); } }