shopxo/app/service/AdminPowerService.php
gongfuxiang 636daec54b v3.0
2023-08-27 16:59:15 +08:00

371 lines
14 KiB
PHP
Executable File

<?php
// +----------------------------------------------------------------------
// | ShopXO 国内领先企业级B2C免费开源电商系统
// +----------------------------------------------------------------------
// | Copyright (c) 2011~2099 http://shopxo.net All rights reserved.
// +----------------------------------------------------------------------
// | Licensed ( https://opensource.org/licenses/mit-license.php )
// +----------------------------------------------------------------------
// | Author: Devil
// +----------------------------------------------------------------------
namespace app\service;
use think\facade\Db;
use app\service\SystemService;
use app\service\AdminService;
use app\service\AdminRoleService;
/**
* 权限菜单服务层
* @author Devil
* @blog http://gong.gg/
* @version 0.0.1
* @datetime 2016-12-01T21:51:08+0800
*/
class AdminPowerService
{
/**
* 权限菜单列表
* @author Devil
* @blog http://gong.gg/
* @version 0.0.1
* @datetime 2016-12-06T21:31:53+0800
* @param [array] $params [输入参数]
*/
public static function PowerList($params = [])
{
$where = empty($params['where']) ? [] : $params['where'];
$field = empty($params['field']) ? '*' : $params['field'];
$order_by = empty($params['order_by']) ? 'id desc' : trim($params['order_by']);
// 获取权限菜单列表
$data = Db::name('Power')->field($field)->where($where)->order($order_by)->select()->toArray();
if(!empty($data))
{
foreach($data as &$v)
{
$v['item'] = Db::name('Power')->field($field)->where(['pid'=>$v['id']])->order($order_by)->select()->toArray();
}
}
return $data;
}
/**
* 权限菜单保存
* @author Devil
* @blog http://gong.gg/
* @version 1.0.0
* @datetime 2018-12-07T00:24:14+0800
* @param [array] $params [输入参数]
*/
public static function PowerSave($params = [])
{
// 请求参数
$p = [
[
'checked_type' => 'length',
'key_name' => 'name',
'checked_data' => '1,60',
'error_msg' => MyLang('common_service.power.form_item_name_message'),
],
[
'checked_type' => 'length',
'key_name' => 'icon',
'checked_data' => '60',
'is_checked' => 1,
'error_msg' => MyLang('common_service.power.form_item_icon_message'),
],
[
'checked_type' => 'in',
'key_name' => 'is_show',
'checked_data' => [0,1],
'error_msg' => MyLang('form_is_show_message'),
],
];
// 是否自定义url地址
if(empty($params['url']))
{
$p[] = [
'checked_type' => 'length',
'key_name' => 'control',
'checked_data' => '1,80',
'error_msg' => MyLang('common_service.power.form_item_control_message'),
];
$p[] = [
'checked_type' => 'length',
'key_name' => 'action',
'checked_data' => '1,80',
'error_msg' => MyLang('common_service.power.form_item_action_message'),
];
} else {
$p[] = [
'checked_type' => 'length',
'key_name' => 'url',
'checked_data' => '1,255',
'error_msg' => MyLang('common_service.power.form_item_url_message'),
];
}
$ret = ParamsChecked($params, $p);
if($ret !== true)
{
return DataReturn($ret, -1);
}
// 保存数据
$data = [
'pid' => isset($params['pid']) ? intval($params['pid']) : 0,
'sort' => isset($params['sort']) ? intval($params['sort']) : 0,
'icon' => isset($params['icon']) ? $params['icon'] : '',
'name' => $params['name'],
'control' => $params['control'],
'action' => $params['action'],
'url' => $params['url'],
'is_show' => isset($params['is_show']) ? intval($params['is_show']) : 0,
];
if(empty($params['id']))
{
$data['add_time'] = time();
if(Db::name('Power')->insertGetId($data) > 0)
{
return DataReturn(MyLang('insert_success'), 0);
}
return DataReturn(MyLang('insert_fail'), -100);
} else {
if(Db::name('Power')->where(['id'=>intval($params['id'])])->update($data) !== false)
{
return DataReturn(MyLang('update_success'), 0);
}
return DataReturn(MyLang('update_fail'), -100);
}
}
/**
* 权限菜单删除
* @author Devil
* @blog http://gong.gg/
* @version 1.0.0
* @datetime 2018-12-07T00:24:14+0800
* @param [array] $params [输入参数]
*/
public static function PowerDelete($params = [])
{
// 参数是否有误
if(empty($params['id']))
{
return DataReturn(MyLang('data_id_error_tips'), -1);
}
if(Db::name('Power')->delete(intval($params['id'])))
{
// 清除用户权限数据
self::PowerCacheDelete();
return DataReturn(MyLang('delete_success'), 0);
}
return DataReturn(MyLang('delete_fail'), -100);
}
/**
* 后台管理员权限缓存数据清除
* @author Devil
* @blog http://gong.gg/
* @version 0.0.1
* @datetime 2017-02-26T23:45:26+0800
*/
public static function PowerCacheDelete()
{
$admin = Db::name('Admin')->column('id');
if(!empty($admin))
{
foreach($admin as $id)
{
MyCache(SystemService::CacheKey('shopxo.cache_admin_left_menu_key').$id, null);
MyCache(SystemService::CacheKey('shopxo.cache_admin_power_key').$id, null);
MyCache(SystemService::CacheKey('shopxo.cache_admin_power_plugins_key').$id, null);
}
}
}
/**
* 管理员权限菜单初始化
* @author Devil
* @blog http://gong.gg/
* @version 1.0.0
* @date 2022-01-23
* @desc description
* @param [array] $admin [管理员信息]
* @param [boolean] $is_refresh [是否强制刷新]
*/
public static function PowerMenuInit($admin = [], $is_refresh = false)
{
// 不存在管理员信息则读取登录信息
if(empty($admin))
{
$admin = AdminService::LoginInfo();
}
// 基础参数
$admin_id = isset($admin['id']) ? intval($admin['id']) : 0;
$role_id = isset($admin['role_id']) ? intval($admin['role_id']) : 0;
// 读取缓存数据
$admin_left_menu = MyCache(SystemService::CacheKey('shopxo.cache_admin_left_menu_key').$admin_id);
$admin_power = MyCache(SystemService::CacheKey('shopxo.cache_admin_power_key').$admin_id);
$admin_plugins = MyCache(SystemService::CacheKey('shopxo.cache_admin_power_plugins_key').$admin_id);
// 缓存没数据则从数据库重新读取
if((($role_id > 0 || $admin_id == 1) && (empty($admin_left_menu) || empty($admin_power))) || $is_refresh || MyEnv('app_debug') || MyInput('lang') || MyC('common_data_is_use_cache') != 1)
{
// 获取一级数据、有数据,则处理子级数据
$admin_left_menu = self::AdminPowerMenuData($admin_id, $role_id);
if(!empty($admin_left_menu))
{
// 获取下级插件
$plugins_data = AdminRoleService::PluginsList();
// 语言数据
$lang = MyLang('admin_power_menu_list');
$temp_lang = [];
// 菜单权限
foreach($admin_left_menu as $k=>$v)
{
// 是否存在控制器和方法
if(!empty($v['control']) && !empty($v['action']))
{
// 权限
$key = strtolower($v['control'].'_'.$v['action']);
$admin_power[$key] = $v['name'];
// url、存在自定义url则不覆盖
if(empty($v['url']))
{
$admin_left_menu[$k]['url'] = MyUrl('admin/'.strtolower($v['control']).'/'.strtolower($v['action']));
}
// 语言处理
if(!empty($lang) && is_array($lang) && array_key_exists($key, $lang))
{
$temp_lang = $lang[$key];
$admin_left_menu[$k]['name'] = $temp_lang['name'];
}
}
// 获取子权限
$items = self::AdminPowerMenuData($admin_id, $role_id, $v['id']);
$is_show_parent = isset($v['is_show']) ? $v['is_show'] : 0;
if(!empty($items))
{
foreach($items as $ks=>$vs)
{
// 是否存在控制器和方法
if(!empty($vs['control']) && !empty($vs['action']))
{
// 权限
$key = strtolower($vs['control'].'_'.$vs['action']);
$admin_power[$key] = $vs['name'];
// url、存在自定义url则不覆盖
if(empty($vs['url']))
{
$items[$ks]['url'] = MyUrl('admin/'.strtolower($vs['control']).'/'.strtolower($vs['action']));
}
// 语言处理
if(!empty($temp_lang['item']) && is_array($temp_lang['item']) && array_key_exists($key, $temp_lang['item']))
{
$items[$ks]['name'] = $temp_lang['item'][$key];
}
}
// 是否显示视图
if(isset($vs['is_show']) && $vs['is_show'] == 0)
{
unset($items[$ks]);
}
}
}
// 一级菜单下的插件
if(!empty($plugins_data))
{
foreach($plugins_data as $pv)
{
if(!empty($pv['plugins_menu_control']) && strtolower($pv['plugins_menu_control']) == strtolower($v['control']))
{
$items[] = [
'id' => 'plugins-'.$pv['plugins'],
'name' => $pv['name'],
'url' => PluginsAdminUrl($pv['plugins'], 'admin', 'index'),
];
}
}
}
// 如果没有子级数据则不显示父级
if(empty($items))
{
unset($admin_left_menu[$k]);
} else {
// 子级
$admin_left_menu[$k]['items'] = $items;
}
}
// 插件权限
if($admin_id == 1 || $role_id == 1)
{
$admin_plugins = empty($plugins_data) ? [] : array_column($plugins_data, 'name', 'plugins');
} else {
$admin_plugins = Db::name('RolePlugins')->where(['role_id'=>$role_id])->column('name', 'plugins');
}
}
MyCache(SystemService::CacheKey('shopxo.cache_admin_left_menu_key').$admin_id, $admin_left_menu);
MyCache(SystemService::CacheKey('shopxo.cache_admin_power_key').$admin_id, $admin_power);
MyCache(SystemService::CacheKey('shopxo.cache_admin_power_plugins_key').$admin_id, $admin_plugins);
}
// 后台左侧菜单钩子
$hook_name = 'plugins_service_admin_menu_data';
MyEventTrigger($hook_name, [
'hook_name' => $hook_name,
'is_backend' => true,
'admin' => $admin,
'admin_left_menu' => &$admin_left_menu,
'admin_power' => &$admin_power,
'admin_plugins' => &$admin_plugins,
]);
// 返回菜单和权限数据
return [
'admin_left_menu' => $admin_left_menu,
'admin_power' => $admin_power,
'admin_plugins' => $admin_plugins,
];
}
/**
* 权限菜单读取
* @author Devil
* @blog http://gong.gg/
* @version 1.0.0
* @date 2023-02-01
* @desc description
* @param [int] $admin_id [管理员id]
* @param [int] $role_id [角色id]
* @param [int] $pid [父id]
*/
public static function AdminPowerMenuData($admin_id, $role_id, $pid = 0)
{
if($admin_id == 1 || $role_id == 1)
{
$field = 'id,name,control,action,url,is_show,icon';
$data = Db::name('Power')->where(['pid' => $pid])->field($field)->order('sort')->select()->toArray();
} else {
$field = 'p.id,p.name,p.control,p.action,p.url,p.is_show,p.icon';
$data = Db::name('Power')->alias('p')->join('role_power rp', 'p.id=rp.power_id')->where(['rp.role_id' => $role_id, 'p.pid' => $pid])->field($field)->order('p.sort')->select()->toArray();
}
return empty($data) ? [] : $data;
}
}
?>