TaoLer/app/common/controller/AdminController.php

213 lines
6.8 KiB
PHP
Raw Normal View History

2020-01-01 13:17:19 +08:00
<?php
2022-08-02 20:48:54 +08:00
/*
* @Author: TaoLer <alipay_tao@qq.com>
* @Date: 2021-12-06 16:04:50
2022-08-02 21:13:36 +08:00
* @LastEditTime: 2022-05-17 11:15:46
2022-08-02 20:48:54 +08:00
* @LastEditors: TaoLer
2022-08-02 21:13:36 +08:00
* @Description: 后台控制器设置
2022-08-02 20:48:54 +08:00
* @FilePath: \TaoLer\app\common\controller\AdminController.php
* Copyright (c) 2020~2022 https://www.aieok.com All rights reserved.
*/
2020-01-01 13:17:19 +08:00
declare (strict_types = 1);
namespace app\common\controller;
use think\facade\Session;
use think\facade\View;
use think\facade\Db;
2020-02-12 17:20:07 +08:00
use taoser\think\Auth;
2020-03-05 20:15:01 +08:00
use taoler\com\Files;
2023-03-16 22:40:15 +08:00
use think\facade\Lang;
2020-01-01 13:17:19 +08:00
/**
* 控制器基础类
*/
2021-07-16 17:42:07 +08:00
class AdminController extends \app\BaseController
2020-01-01 13:17:19 +08:00
{
2023-03-16 22:40:15 +08:00
protected $aid = '';
2023-05-05 11:58:42 +08:00
protected $appName = '';
2021-12-15 15:46:04 +08:00
/**
* 初始化菜单
*/
2020-01-01 13:17:19 +08:00
protected function initialize()
{
//权限auth检查
2021-12-15 15:46:04 +08:00
$this->aid = Session::get('admin_id');
//系统配置
2023-05-05 11:58:42 +08:00
$sys = $this->getSystem();
$syscy = $sys['clevel'] ? Lang::get('Authorized') : Lang::get('Free version');
$runTime = $this->getRunTime();
View::assign(['domain'=>$this->getDomain(),'insurl'=>$sys['domain'],'syscy'=>$syscy,'clevel'=>$sys['clevel'],'runTime'=>$runTime]);
2020-01-01 13:17:19 +08:00
}
2023-03-16 22:40:15 +08:00
/**
* 菜单无限极分类
*
* @param array $data 包含有pid的rule权限数组
* @param integer $pId 父ID
* @return array
*/
public function getRuleTree(array $data, int $pId = 0): array
{
// 递归
$tree = [];
foreach ($data as $k => $v) {
//第一次遍历,找到父节点为根节点的节点 也就是pid=0的节点
if ($v['pid'] == $pId) {
$child = $this->getRuleTree($data, $v['id']);
// 有子类
if(!empty($child)) {
// foreach($child as $m => $n) {
// $v['children'][$m] = $n;
// //$v['children'][$m]['type'] = 1;
// //$v['children'][$m]['openType'] = '_iframe';
// }
$v['type'] = $v['pid'] == 0 ? 0 : $v['ismenu'];
$v['children'] = $child;
} else {
// 没有子菜单type=1
$v['type'] = 1;
$v['openType'] = '_iframe';
}
//把数组放到$tree中
$tree[] = $v;
//把这个节点从数组中移除,减少后续递归消耗
unset($data[$k]);
}
}
return $tree;
}
2020-01-01 13:17:19 +08:00
/**
* 获取侧边栏菜单
*/
protected function getMenu()
{
$menu = [];
2022-04-17 17:09:19 +08:00
$admin_id = $this->aid;
2020-01-01 13:17:19 +08:00
$auth = new Auth();
2023-03-16 22:30:36 +08:00
$auth_rule_list = Db::name('auth_rule')->where(['status'=> 1, 'ismenu'=>1, 'delete_time'=> 0])->select();
2020-01-01 13:17:19 +08:00
foreach ($auth_rule_list as $value) {
if ($auth->check($value['name'], $admin_id) || $admin_id == 1) {
2022-04-17 17:09:19 +08:00
// 查询是否设置映射
// $map = array_search('admin',config('app.app_map'));
// //dump($map,$value);
// //stripos($value);
// if($map){
// $menu[] = strtr($value,'admin',$map);
// } else {
// $menu[] = $value;
// }
//dump($menu);
2020-01-01 13:17:19 +08:00
$menu[] = $value;
}
}
2022-11-25 22:44:04 +08:00
return !empty($menu) ? getTree($menu) : [];
2020-01-01 13:17:19 +08:00
}
/**
* 获取角色菜单
* $type 1 admin后端权限,2 index前端权限
2020-01-01 13:17:19 +08:00
*/
2023-03-16 22:40:15 +08:00
protected function getRoleMenu($type)
2020-01-01 13:17:19 +08:00
{
$menu = [];
2023-03-16 22:40:15 +08:00
$auth_rule_list = Db::name('auth_rule')->field('id,pid,title,sort,level')->where(['delete_time'=> 0, 'status'=> 1,'type'=> $type])->select()->toArray();
// 排序
$cmf_arr = array_column($auth_rule_list, 'sort');
array_multisort($cmf_arr, SORT_ASC, $auth_rule_list);
2020-01-01 13:17:19 +08:00
foreach ($auth_rule_list as $value) {
2023-03-16 22:40:15 +08:00
$menu[] = [
'id' => $value['id'],
'pid' => $value['pid'],
'title' => Lang::get($value['title']),
'level' => $value['level']
];
2020-01-01 13:17:19 +08:00
}
2022-11-25 22:44:04 +08:00
return !empty($menu) ? getTree($menu) : [];
2020-01-01 13:17:19 +08:00
}
2020-03-05 20:15:01 +08:00
//清除缓存Cache
public function clearSysCache()
2021-07-16 17:42:07 +08:00
{
//清理缓存
$atemp = str_replace('\\',"/",app()->getRootPath().'runtime/admin/temp/');
$itemp = str_replace('\\',"/",app()->getRootPath().'runtime/index/temp/');
$cache = str_replace('\\',"/",app()->getRootPath().'runtime/cache/');
Files::delDirAndFile($atemp);
Files::delDirAndFile($itemp);
Files::delDirAndFile($cache);
return true;
2020-03-05 20:15:01 +08:00
}
2023-03-16 22:40:15 +08:00
2023-05-05 11:58:42 +08:00
/**
* 获取路由
* @param int $aid
* @param string $appName
* @param string $ename
* @return string|void
*/
protected function getArticleUrl(int $aid, string $appName = 'index', string $ename = '' )
{
// admin管理后台 解析非admin应用路由
//$appName = app('http')->getName();
$articleUrl = (string) url('article_detail', ['id' => $aid]);
// 详情动态路由,$aid, $ename
if(config('taoler.url_rewrite.article_as') == '<ename>/'){
$articleUrl = (string) url('article_detail', ['id' => (int) $aid, 'ename'=> $ename]);
}
// 判断应用是否绑定域名
$app_bind = array_search($appName, config('app.domain_bind'));
// 判断应用是否域名映射
$app_map = array_search($appName, config('app.app_map'));
// 判断admin应用是否绑定域名
$bind_admin = array_search('admin',config('app.domain_bind'));
// 判断admin应用是否域名映射
$map_admin = array_search('admin',config('app.app_map'));
//1.admin绑定了域名
if($bind_admin) {
// 1.应用绑定了域名
if($app_bind) {
return $this->getDomain() . $articleUrl;
}
// 2.应用进行了映射
if($app_map){
return $this->getDomain() . '/' . $appName . $articleUrl;
}
// 3.应用未绑定域名也未进行映射
return $this->getDomain() . '/' . $appName . $articleUrl;
}
//2.admin进行了映射
if($map_admin) {
// 1.应用绑定了域名
if($app_bind) {
return $this->getDomain() . str_replace($map_admin, '', $articleUrl);;
}
// 2.应用进行了映射
if($app_map){
return $this->getDomain() . str_replace($map_admin, $app_map, $articleUrl);
}
// 3.应用未绑定域名也未进行映射
return $this->getDomain() . str_replace($map_admin, $appName, $articleUrl);
}
//3.admin未绑定域名也未映射
return str_replace('admin', $appName, $articleUrl);
}
2023-03-16 22:40:15 +08:00
2020-01-01 13:17:19 +08:00
}