| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232 | <?phpnamespace app\controller;use app\BaseController;use app\command\repair;use app\command\util;use app\model\ConfigModel;use app\model\FileModel;use app\model\HistoryModel;use app\model\LinkModel;use app\model\LinkStoreModel;use app\model\NoteModel;use app\model\SettingModel;use app\model\TabbarModel;use app\model\TokenModel;use app\model\UserModel;use app\model\UserSearchEngineModel;use DateInterval;use DatePeriod;use DateTime;use mysqli;use think\facade\Cache;use think\facade\Db;class Admin extends BaseController{    public function UserList(): \think\response\Json    {        $this->getAdmin();        $limit = $this->request->all('limit', 50);        $search = $this->request->post('search');        $sql = [];        if (isset($search['mail']) && mb_strlen($search['mail']) > 0) {            $sql[] = ['mail', 'like', "%$search[mail]%"];        }        if (isset($search['nickname']) && mb_strlen($search['nickname']) > 0) {            $sql[] = ["nickname","like","%$search[nickname]%"];        }        $user = UserModel::where($sql)->withoutField('password')->order($this->request->post('sort.prop', 'id'), $this->request->post('sort.order', 'desc'))->paginate($limit);        return $this->success('ok', $user);    }    function userUpdate(): \think\response\Json    {        $this->getAdmin();        is_demo_mode(true);        $id = $this->request->post('id');        $user = UserModel::where('id', $id)->find();        $data = $this->request->post();        if (!$user) {            $user = new UserModel();        }        //如果字段中的password有内容则md5加密后保存        if (isset($data['password']) && mb_strlen($data['password']) > 0) {            $data['password'] = md5($data['password']);        } else {            unset($data['password']);        }        $user->save($data);        return $this->success('保存成功');    }    //用户删除函数    function userDelete(): \think\response\Json    {        $this->getAdmin();        is_demo_mode(true);        $id = $this->request->post('id');        $user = UserModel::where('id', $id)->find();        if ($user) {//删除当前用户下的所有数据。            LinkModel::where("user_id", $user['id'])->delete();//删除标签            TabbarModel::where("user_id", $user['id'])->delete();//删除快捷图标            HistoryModel::where('user_id', $user['id'])->delete();//删除历史图标            ConfigModel::where('user_id', $user['id'])->delete();//删除配置信息            NoteModel::where('user_id', $user['id'])->delete();//删除笔记            UserSearchEngineModel::where('user_id', $user['id'])->delete();//删除自定义搜索引擎            TokenModel::where('user_id', $user['id'])->delete();//删除所有Token            $user->delete();//删除用户        }        return $this->success("删除完毕");    }    function export(): \think\response\Json    {        $this->getAdmin();        is_demo_mode(true);        $link = $this->request->post('link', []);        if ($link) {            $saveName = public_path() . 'static/exportsTabLink.json';            $status = file_put_contents($saveName, json_encode($link, true, JSON_UNESCAPED_UNICODE));            if ($status) {                $setting = new SettingModel();                if ($setting->find('defaultTab')) {                    $setting->update(['value' => 'static/exportsTabLink.json'], ['keys' => 'defaultTab']);                } else {                    $setting->save(['keys' => 'defaultTab', 'value' => 'static/exportsTabLink.json']);                }                Cache::delete('webConfig');                return $this->success('保存成功');            }        }        return $this->error('保存失败');    }    private function countFilesInDirectory($directory): int    {        $fileCount = 0;        // 获取目录中的文件和子目录        $files = scandir($directory);        foreach ($files as $file) {            // 排除"."和".."            if ($file != '.' && $file != '..') {                $filePath = $directory . '/' . $file;                // 如果是目录,则递归调用函数                if (is_dir($filePath)) {                    $fileCount += $this->countFilesInDirectory($filePath);                } else {                    // 如果是文件,则增加文件数量                    $fileCount++;                }            }        }        return $fileCount;    }    function xyCheck(): \think\response\Json    {        $this->getAdmin();        if(is_file(root_path() . 'xy.pem')){            if(file_get_contents(root_path().'xy.pem')===file_get_contents(config_path().'LICENSE.html')){                return $this->success("ok");            }        }        return $this->error("未找到证书文件",['license'=>file_get_contents(config_path().'LICENSE.html')]);    }    function xy(): \think\response\Json    {        $this->getAdmin();        file_put_contents(root_path()."xy.pem", file_get_contents(config_path().'LICENSE.html'));        return $this->success("ok");    }    function getServicesStatus(): \think\response\Json    {        $this->getAdmin();        $userNum = UserModel::count('id');        $linkNum = LinkStoreModel::count('id');        $redisNum = 0;        $fileNum = FileModel::field('id')->count("id");        $userWeekActive = 0;        if (Cache::get('userWeekActive')) {            $userWeekActive = Cache::get('userWeekActive');        } else {            $start = date('Y-m-d', strtotime('-7 days'));            $userWeekActive = UserModel::where('active',">", $start)->field("id,active")->count('id');            Cache::set('userWeekActive', $userWeekActive, 60);        }        return $this->success('ok', ['userNum' => $userNum, 'linkNum' => $linkNum, 'redisNum' => $redisNum, 'fileNum' => $fileNum,"userWeekActive"=>$userWeekActive]);    }    function getUserLine(): \think\response\Json    {        $this->getAdmin();        $result = UserModel::whereMonth('create_time');        $result = $result->field('DATE_FORMAT(create_time, "%Y-%m-%d") as time, count(id) as total');        $result = $result->group('time')->select();        return $this->success('ok', $this->render($result));    }    function getHotTab(): \think\response\Json    {        $this->getAdmin();        $list = LinkStoreModel::order('install_num', 'desc')->limit(30)->cache('hotTab', 60)->select()->toArray();        return $this->success('ok', $list);    }    private function render($arr): array    {        $info = [];        foreach ($arr as $key => $value) {            $info[$value['time']] = $value['total'];        }        $time = [];        $total = [];        //当月的第一天        $start = date('Y-m-01', strtotime(date('Y-m-d')));        //当月的最后一天        $end = date('Y-m-d', strtotime(date('Y-m-01') . ' +1 month -1 day'));        $start_date = new DateTime($start);        $end_date = new DateTime($end);        $interval = new DateInterval('P1D');        $dateRange = new DatePeriod($start_date, $interval, $end_date);        $ts = null;        foreach ($dateRange as $date) {            $ts = $date->format('Y-m-d');            $time[] = $ts;            if (isset($info[$ts])) {                $total[] = $info[$ts];            } else {                $total[] = 0;            }        }        // 判断是否需要添加最后一天的数据        if ($end_date->format('Y-m-d') != $ts) {            $time[] = $end_date->format('Y-m-d');            $total[] = isset($info[$end_date->format('Y-m-d')]) ? $info[$end_date->format('Y-m-d')] : 0;        }        return ['time' => $time, 'total' => $total, 'sum' => array_sum($total)];    }    function userLoginRecord(): \think\response\Json    {        $this->getAdmin();        $user_id = $this->request->post('user_id');        if ($user_id && !is_demo_mode()) {            $list = TokenModel::where("user_id", $user_id)->field('user_id,FROM_UNIXTIME(create_time) as create_time,user_agent,ip')->order('create_time', 'desc')->limit(100)->select()->toArray();            return $this->success('', $list);        }        return $this->success('', []);    }    function repair(): \think\response\Json    {        $this->getAdmin();        is_demo_mode(true);        repair::repair();        return $this->success("修复完毕");    }}
 |