2020-01-01 13:17:19 +08:00
|
|
|
<?php
|
|
|
|
namespace app\admin\controller;
|
|
|
|
|
|
|
|
use app\common\controller\AdminController;
|
|
|
|
use think\facade\View;
|
|
|
|
use think\facade\Db;
|
|
|
|
use think\facade\Session;
|
|
|
|
use think\facade\Request;
|
2021-02-01 15:51:32 +08:00
|
|
|
use think\facade\Cache;
|
2021-07-07 17:40:43 +08:00
|
|
|
use think\facade\Lang;
|
2020-01-01 13:17:19 +08:00
|
|
|
use app\admin\model\Admin;
|
|
|
|
use app\admin\model\Article;
|
2021-02-01 15:51:32 +08:00
|
|
|
use app\admin\model\Cunsult;
|
2020-05-14 12:33:10 +08:00
|
|
|
use think\facade\Config;
|
2021-02-01 15:51:32 +08:00
|
|
|
use taoler\com\Api;
|
2022-08-02 21:13:36 +08:00
|
|
|
use taoser\SetArr;
|
2020-01-01 13:17:19 +08:00
|
|
|
|
|
|
|
class Index extends AdminController
|
|
|
|
{
|
2021-03-17 18:02:11 +08:00
|
|
|
/*
|
2020-01-01 13:17:19 +08:00
|
|
|
protected function initialize()
|
|
|
|
{
|
|
|
|
parent::initialize();
|
2021-03-17 18:02:11 +08:00
|
|
|
}
|
|
|
|
*/
|
|
|
|
public function __construct()
|
|
|
|
{
|
2021-03-19 14:38:06 +08:00
|
|
|
//控制器初始化显示左侧导航菜单
|
2021-03-18 16:21:27 +08:00
|
|
|
parent::initialize();
|
|
|
|
|
2021-03-17 18:02:11 +08:00
|
|
|
$this->sys_version = Config::get('taoler.version');
|
2021-03-19 18:45:40 +08:00
|
|
|
$this->pn = Config::get('taoler.appname');
|
2021-03-19 14:38:06 +08:00
|
|
|
$this->sys = $this->getSystem();
|
|
|
|
$this->domain = $this->getHttpUrl($this->sys['domain']);
|
2021-03-17 18:02:11 +08:00
|
|
|
$this->api = $this->sys['api_url'];
|
2021-02-01 15:51:32 +08:00
|
|
|
if(empty($this->api)){
|
2021-03-17 18:02:11 +08:00
|
|
|
$baseUrl = $this->sys['base_url'];
|
2021-02-01 15:51:32 +08:00
|
|
|
$this->api = strstr($baseUrl,'/v',true);
|
|
|
|
}
|
2021-03-18 16:21:27 +08:00
|
|
|
|
2021-03-17 18:02:11 +08:00
|
|
|
}
|
|
|
|
|
2020-01-01 13:17:19 +08:00
|
|
|
|
|
|
|
public function index()
|
|
|
|
{
|
|
|
|
return View::fetch('index');
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
public function set()
|
|
|
|
{
|
|
|
|
return view();
|
|
|
|
}
|
|
|
|
|
2020-05-14 11:09:26 +08:00
|
|
|
public function message()
|
|
|
|
{
|
2020-01-01 13:17:19 +08:00
|
|
|
return view();
|
|
|
|
}
|
|
|
|
|
2021-03-17 18:02:11 +08:00
|
|
|
public function home()
|
|
|
|
{
|
2021-11-03 17:23:20 +08:00
|
|
|
// 评论、帖子状态
|
2021-06-09 14:48:38 +08:00
|
|
|
$comm = Db::name('comment')->field('id')->where(['delete_time'=>0,'status'=>0])->select();
|
|
|
|
$forum = Db::name('article')->field('id')->where(['delete_time'=>0,'status'=>0])->select();
|
|
|
|
$comms = count($comm);
|
|
|
|
$forums = count($forum);
|
2021-07-22 10:39:09 +08:00
|
|
|
|
2021-11-03 17:23:20 +08:00
|
|
|
// 用户注册数据
|
2021-07-22 10:39:09 +08:00
|
|
|
$monthTime = Cache::get('monthTime');
|
|
|
|
if(!$monthTime){
|
|
|
|
$time = Db::name('user')->where('delete_time',0)->whereMonth('create_time')->order('create_time','asc')->column('create_time');
|
|
|
|
$monthTime = [];//当月有注册的日期
|
|
|
|
foreach($time as $v){//
|
|
|
|
$data = date('m-d',$v);
|
|
|
|
if(!in_array($data,$monthTime)){
|
|
|
|
$monthTime[] = $data;
|
|
|
|
};
|
|
|
|
}
|
|
|
|
$userDayCount = [];//每天注册用户数
|
|
|
|
foreach($monthTime as $d){
|
|
|
|
$userArr = Db::name('user')->whereDay('create_time',date("Y").'-'.$d)->select();
|
|
|
|
$userDayCount[] = count($userArr);
|
|
|
|
}
|
|
|
|
|
|
|
|
$monthTime = implode(',',$monthTime); //数组转字符串
|
|
|
|
$monthUserCount = implode(',',$userDayCount);
|
|
|
|
Cache::set('monthTime',$monthTime,3600);
|
|
|
|
Cache::set('monthUserCount',$monthUserCount,3600);
|
|
|
|
}
|
|
|
|
|
2021-07-16 17:42:07 +08:00
|
|
|
|
2021-07-22 10:54:03 +08:00
|
|
|
View::assign(['comms'=>$comms,'forums'=>$forums,'monthTime'=>$monthTime,'monthUserCount'=>Cache::get('monthUserCount')]);
|
2020-01-01 13:17:19 +08:00
|
|
|
return View::fetch();
|
|
|
|
}
|
2020-05-14 11:09:26 +08:00
|
|
|
|
2021-11-03 17:23:20 +08:00
|
|
|
//版本检测
|
|
|
|
public function getVersion(){
|
|
|
|
|
|
|
|
$verCheck = Api::urlPost($this->sys['upcheck_url'],['pn'=>$this->pn,'ver'=>$this->sys_version]);
|
|
|
|
if($verCheck->code !== -1){
|
|
|
|
$versions = $verCheck->code ? "<span style='color:red'>有{$verCheck->up_num}个版本需更新,当前可更新至{$verCheck->version}</span>" : $verCheck->msg;
|
|
|
|
return $versions;
|
|
|
|
} else {
|
|
|
|
return lang('No new messages');
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-05-14 11:09:26 +08:00
|
|
|
//本周发帖
|
2020-02-25 15:40:06 +08:00
|
|
|
public function forums()
|
|
|
|
{
|
|
|
|
$forumList = Db::name('article')
|
|
|
|
->alias('a')
|
|
|
|
->join('user u','a.user_id = u.id')
|
|
|
|
->join('cate c','a.cate_id = c.id')
|
2022-08-02 21:13:36 +08:00
|
|
|
->field('a.id as aid,title,name,ename,catename,pv')
|
2021-10-12 16:55:44 +08:00
|
|
|
->where('a.delete_time',0)
|
2020-02-25 15:40:06 +08:00
|
|
|
->whereWeek('a.create_time')
|
|
|
|
->order('a.create_time', 'desc')
|
|
|
|
->paginate(10);
|
|
|
|
$res = [];
|
|
|
|
$count = $forumList->total();
|
|
|
|
if($count){
|
|
|
|
$res['code'] = 0;
|
|
|
|
$res['msg'] = '';
|
|
|
|
$res['count'] = $count;
|
|
|
|
foreach($forumList as $k=>$v){
|
2022-08-02 18:46:05 +08:00
|
|
|
//$url = (string) str_replace("admin","index",$this->domain.url('article/detail',['id'=>$v['aid']]));
|
2022-08-02 21:13:36 +08:00
|
|
|
$url = $this->getRouteUrl($v['aid'],$v['ename']);
|
2021-10-12 16:52:51 +08:00
|
|
|
$res['data'][]= ['id'=>$url,'title'=>htmlspecialchars($v['title']),'name'=>$v['name'],'catename'=>$v['catename'],'pv'=>$v['pv']];
|
2020-02-25 15:40:06 +08:00
|
|
|
}
|
|
|
|
} else {
|
|
|
|
$res = ['code'=>-1,'msg'=>'本周还没有发帖!'];
|
|
|
|
}
|
|
|
|
return json($res);
|
|
|
|
}
|
|
|
|
|
2020-05-14 11:09:26 +08:00
|
|
|
//本周评论
|
2020-02-25 15:40:06 +08:00
|
|
|
public function replys()
|
|
|
|
{
|
2021-11-03 17:23:20 +08:00
|
|
|
if(Request::isAjax()){
|
2020-02-25 15:40:06 +08:00
|
|
|
|
|
|
|
$replys = Db::name('comment')
|
|
|
|
->alias('a')
|
|
|
|
->join('user u','a.user_id = u.id')
|
|
|
|
->join('article c','a.article_id = c.id')
|
2022-08-02 21:13:36 +08:00
|
|
|
->join('cate ca','c.cate_id = ca.id')
|
|
|
|
->field('a.content as content,title,c.id as cid,name,ename')
|
2021-10-12 16:55:44 +08:00
|
|
|
->where('c.delete_time',0)
|
2020-02-25 15:40:06 +08:00
|
|
|
->whereWeek('a.create_time')
|
|
|
|
->order('a.create_time', 'desc')
|
|
|
|
->paginate(10);
|
|
|
|
|
|
|
|
$count = $replys->total();
|
|
|
|
$res = [];
|
|
|
|
if ($count) {
|
|
|
|
$res = ['code'=>0,'msg'=>'','count'=>$count];
|
|
|
|
foreach($replys as $k => $v){
|
2022-08-02 21:13:36 +08:00
|
|
|
$res['data'][] = ['content'=>htmlspecialchars($v['content']),'title'=>htmlspecialchars($v['title']),'cid'=>$this->getRouteUrl($v['cid'],$v['ename']),'name'=>$v['name']];
|
2020-02-25 15:40:06 +08:00
|
|
|
}
|
|
|
|
} else {
|
|
|
|
$res = ['code'=>-1,'msg'=>'本周还没评论'];
|
|
|
|
}
|
|
|
|
return json($res);
|
2021-11-03 17:23:20 +08:00
|
|
|
}
|
2020-02-25 15:40:06 +08:00
|
|
|
}
|
|
|
|
|
2021-02-01 15:51:32 +08:00
|
|
|
//动态信息
|
|
|
|
public function news()
|
|
|
|
{
|
2021-12-15 15:46:04 +08:00
|
|
|
$data = Request::only(['page', 'limit']);
|
|
|
|
$url = $this->api.'/v1/news?'.'page='.$data['page'].'&'.'limit='.$data['limit'];
|
|
|
|
$news = Cache::get('news'.$data['page'].'_'.$data['limit']);
|
|
|
|
if(empty($news)){
|
2021-02-01 15:51:32 +08:00
|
|
|
$news = Api::urlGet($url);
|
2021-12-15 15:46:04 +08:00
|
|
|
if($news->code == 0){
|
|
|
|
Cache::set('news'.$data['page'].'_'.$data['limit'],$news,600);
|
|
|
|
}
|
2021-02-01 15:51:32 +08:00
|
|
|
}
|
2021-12-15 15:46:04 +08:00
|
|
|
return $news;
|
2021-02-01 15:51:32 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
//提交反馈
|
|
|
|
public function cunsult()
|
|
|
|
{
|
|
|
|
$url = $this->api.'/v1/reply';
|
|
|
|
//$mail = Db::name('system')->where('id',1)->value('auth_mail'); // bug邮件发送
|
|
|
|
if(Request::isAjax()){
|
2021-03-19 14:38:06 +08:00
|
|
|
$data = Request::only(['type','title','content','post']);
|
2021-02-01 15:51:32 +08:00
|
|
|
$apiRes = Api::urlPost($url,$data);
|
2021-03-19 14:38:06 +08:00
|
|
|
$data['poster'] = Session::get('admin_id');
|
|
|
|
unset($data['post']);
|
2021-02-01 15:51:32 +08:00
|
|
|
if($apiRes){
|
|
|
|
$res = Cunsult::create($data);
|
|
|
|
if($res->id){
|
|
|
|
//$result = mailto($mail,$data['title'],'我的问题类型是'.$data['type'].$data['content']);
|
|
|
|
$res = ['code'=>0,'msg'=>$apiRes->msg];
|
|
|
|
} else {
|
|
|
|
$res = ['code'=>0,'msg'=>$apiRes->msg];
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
$res = ['code'=>-1,'msg'=>'失败,请稍后再试提交...'];
|
|
|
|
}
|
|
|
|
return json($res);
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
//问题和反馈
|
|
|
|
public function reply()
|
|
|
|
{
|
|
|
|
if(Request::isAjax()) {
|
|
|
|
|
|
|
|
$replys = Db::name('cunsult')
|
|
|
|
->whereWeek('create_time')
|
|
|
|
->order('create_time', 'desc')
|
|
|
|
->paginate(10);
|
|
|
|
|
|
|
|
$count = $replys->total();
|
|
|
|
$res = [];
|
|
|
|
if ($count) {
|
|
|
|
$res = ['code'=>0,'msg'=>'','count'=>$count];
|
|
|
|
foreach($replys as $k => $v){
|
|
|
|
$res['data'][] = ['id'=>$v['id'],'content'=>$v['content'],'title'=>$v['title'],'time'=>Date('Y-m-d',$v['create_time'])];
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
$res = ['code'=>-1,'msg'=>'本周还没问题'];
|
|
|
|
}
|
|
|
|
return json($res);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
//删除反馈
|
|
|
|
public function delReply()
|
|
|
|
{
|
|
|
|
if(Request::isAjax()){
|
|
|
|
$res = Db::name('cunsult')->delete(input('id'));
|
|
|
|
|
|
|
|
if($res){
|
|
|
|
$res = ['code'=>0,'msg'=>'删除成功!'];
|
|
|
|
}else{
|
|
|
|
$res = ['code'=>-1,'msg'=>'删除失败!'];
|
|
|
|
}
|
|
|
|
return json($res);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-08-02 21:13:36 +08:00
|
|
|
// 系统调试
|
|
|
|
public function sysSys()
|
|
|
|
{
|
|
|
|
$status = input('status');
|
2020-01-01 13:17:19 +08:00
|
|
|
|
2022-08-02 21:13:36 +08:00
|
|
|
//打开调试
|
|
|
|
$env = root_path().'.env';
|
|
|
|
$app = config_path().'app.php';
|
|
|
|
|
|
|
|
if(file_exists($env)){
|
|
|
|
$str = file_get_contents($env);
|
|
|
|
$appStr = file_get_contents($app);
|
|
|
|
$patk = '/APP_DEBUG[^\r?\n]*/';
|
|
|
|
$appPatk = '/'.'exception_tmpl'.'[^\r?\n]*/';
|
|
|
|
if($status == 'true'){
|
|
|
|
$reps = 'APP_DEBUG = true';
|
|
|
|
$appArr = "exception_tmpl' => app()->getThinkPath() . 'tpl/think_exception.tpl',";
|
|
|
|
} else {
|
|
|
|
$reps = 'APP_DEBUG = false';
|
|
|
|
$appArr = "exception_tmpl' => app()->getAppPath() . '404.html',";
|
|
|
|
}
|
|
|
|
$str = preg_replace($patk, $reps, $str);
|
|
|
|
file_put_contents($env, $str);
|
|
|
|
|
|
|
|
$appStr = preg_replace($appPatk, $appArr, $appStr);
|
|
|
|
$res = file_put_contents($app, $appStr) ? true : false;
|
|
|
|
if($res == true){
|
|
|
|
return json(['code'=>0,'msg'=>'设置成功']);
|
|
|
|
} else {
|
|
|
|
return json(['code'=>-1,'msg'=>'开启失败']);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
2020-01-01 13:17:19 +08:00
|
|
|
|
2021-11-03 17:23:20 +08:00
|
|
|
public function layout(){
|
2020-01-01 13:17:19 +08:00
|
|
|
return view();
|
|
|
|
}
|
|
|
|
}
|