63 lines
1.8 KiB
PHP
63 lines
1.8 KiB
PHP
<?php
|
|
// +----------------------------------------------------------------------
|
|
// | SentCMS [ WE CAN DO IT JUST THINK IT ]
|
|
// +----------------------------------------------------------------------
|
|
// | Copyright (c) 2013 http://www.tensent.cn All rights reserved.
|
|
// +----------------------------------------------------------------------
|
|
// | Author: molong <molong@tensent.cn> <http://www.tensent.cn>
|
|
// +----------------------------------------------------------------------
|
|
namespace app\middleware;
|
|
|
|
use think\facade\Cache;
|
|
use think\facade\Session;
|
|
use think\facade\View;
|
|
|
|
/**
|
|
* @title 后台中间件
|
|
*/
|
|
class AdminAuth {
|
|
|
|
protected $data = ['menu' => [], 'meta_title' => ''];
|
|
|
|
public function handle($request, \Closure $next) {
|
|
$user = Session::get('user');
|
|
|
|
if (Session::has('user') && $user['uid']) {
|
|
$request->user = $user;
|
|
if ($user['uid'] == 1) {
|
|
$request->isAdmin = true;
|
|
}
|
|
|
|
$this->getMenu($request); //设置菜单
|
|
return $next($request);
|
|
} else {
|
|
return redirect(url('admin.index/login'))->remember();
|
|
}
|
|
}
|
|
|
|
/**
|
|
* @title 显示菜单
|
|
*/
|
|
protected function getMenu($request) {
|
|
$list = [];
|
|
$current_controller = '/' . str_replace('.', '/', strtolower($request->controller()));
|
|
$current_url = $current_controller . '/' . strtolower($request->action());
|
|
$menu = Cache::get('menu');
|
|
if (!$menu) {
|
|
$res = (new \app\model\Menu())->where('is_menu', 1)->select();
|
|
foreach ($res as $key => $item) {
|
|
$menu[$item['id']] = $item->toArray();
|
|
}
|
|
Cache::set('menu', $menu);
|
|
}
|
|
foreach ($menu as $key => $value) {
|
|
if ($request->isAdmin || in_array($value['id'], array())) {
|
|
$list[$value['id']] = $value;
|
|
}
|
|
}
|
|
|
|
$menuList = list_to_tree($list);
|
|
$this->data['menu'] = $menuList;
|
|
View::assign($this->data);
|
|
}
|
|
} |