mirror of
https://gitee.com/apiadmin/ApiAdmin.git
synced 2025-04-06 03:58:00 +08:00
modified 移植权限管理功能
This commit is contained in:
parent
4713621180
commit
7c37aefde7
277
app/controller/admin/Auth.php
Normal file
277
app/controller/admin/Auth.php
Normal file
@ -0,0 +1,277 @@
|
||||
<?php
|
||||
declare (strict_types=1);
|
||||
/**
|
||||
* 权限相关配置
|
||||
* @since 2018-02-06
|
||||
* @author zhaoxiang <zhaoxiang051405@gmail.com>
|
||||
*/
|
||||
|
||||
namespace app\controller\admin;
|
||||
|
||||
use app\model\AdminAuthGroup;
|
||||
use app\model\AdminAuthGroupAccess;
|
||||
use app\model\AdminAuthRule;
|
||||
use app\model\AdminMenu;
|
||||
use app\util\ReturnCode;
|
||||
use app\util\Tools;
|
||||
use think\Response;
|
||||
|
||||
class Auth extends Base {
|
||||
|
||||
/**
|
||||
* 获取权限组列表
|
||||
* @return Response
|
||||
* @throws \think\db\exception\DbException
|
||||
* @author zhaoxiang <zhaoxiang051405@gmail.com>
|
||||
*/
|
||||
public function index(): Response {
|
||||
$limit = $this->request->get('size', config('apiadmin.ADMIN_LIST_DEFAULT'));
|
||||
$start = $this->request->get('page', 1);
|
||||
$keywords = $this->request->get('keywords', '');
|
||||
$status = $this->request->get('status', '');
|
||||
|
||||
$obj = new AdminAuthGroup();
|
||||
if (strlen($status)) {
|
||||
$obj = $obj->where('status', $status);
|
||||
}
|
||||
if ($keywords) {
|
||||
$obj = $obj->whereLike('name', "%{$keywords}%");
|
||||
}
|
||||
|
||||
$listObj = $obj->order('id', 'DESC')->paginate(['page' => $start, 'list_rows' => $limit])->toArray();
|
||||
|
||||
return $this->buildSuccess([
|
||||
'list' => $listObj['data'],
|
||||
'count' => $listObj['total']
|
||||
]);
|
||||
}
|
||||
|
||||
/**
|
||||
* 获取全部已开放的可选组
|
||||
* @return Response
|
||||
* @throws \think\db\exception\DataNotFoundException
|
||||
* @throws \think\db\exception\DbException
|
||||
* @throws \think\db\exception\ModelNotFoundException
|
||||
* @author zhaoxiang <zhaoxiang051405@gmail.com>
|
||||
*/
|
||||
public function getGroups(): Response {
|
||||
$listInfo = (new AdminAuthGroup())->where(['status' => 1])->order('id', 'DESC')->select();
|
||||
$count = count($listInfo);
|
||||
$listInfo = Tools::buildArrFromObj($listInfo);
|
||||
|
||||
return $this->buildSuccess([
|
||||
'list' => $listInfo,
|
||||
'count' => $count
|
||||
]);
|
||||
}
|
||||
|
||||
/**
|
||||
* 获取组所在权限列表
|
||||
* @return Response
|
||||
* @throws \think\db\exception\DataNotFoundException
|
||||
* @throws \think\db\exception\DbException
|
||||
* @throws \think\db\exception\ModelNotFoundException
|
||||
* @author zhaoxiang <zhaoxiang051405@gmail.com>
|
||||
*/
|
||||
public function getRuleList(): Response {
|
||||
$groupId = $this->request->get('group_id', 0);
|
||||
|
||||
$list = (new AdminMenu)->order('sort', 'ASC')->select();
|
||||
$list = Tools::buildArrFromObj($list);
|
||||
$list = Tools::listToTree($list);
|
||||
|
||||
$rules = [];
|
||||
if ($groupId) {
|
||||
$rules = (new AdminAuthRule())->where(['group_id' => $groupId])->select();
|
||||
$rules = Tools::buildArrFromObj($rules);
|
||||
$rules = array_column($rules, 'url');
|
||||
}
|
||||
$newList = $this->buildList($list, $rules);
|
||||
|
||||
return $this->buildSuccess([
|
||||
'list' => $newList
|
||||
]);
|
||||
}
|
||||
|
||||
/**
|
||||
* 新增组
|
||||
* @return Response
|
||||
* @author zhaoxiang <zhaoxiang051405@gmail.com>
|
||||
*/
|
||||
public function add(): Response {
|
||||
$res = AdminAuthGroup::create([
|
||||
'name' => $this->request->post('name', ''),
|
||||
'description' => $this->request->post('description', '')
|
||||
]);
|
||||
if ($res === false) {
|
||||
return $this->buildFailed(ReturnCode::DB_SAVE_ERROR);
|
||||
}
|
||||
|
||||
return $this->buildSuccess();
|
||||
}
|
||||
|
||||
/**
|
||||
* 权限组状态编辑
|
||||
* @return Response
|
||||
* @author zhaoxiang <zhaoxiang051405@gmail.com>
|
||||
*/
|
||||
public function changeStatus(): Response {
|
||||
$id = $this->request->get('id');
|
||||
$status = $this->request->get('status');
|
||||
$res = AdminAuthGroup::update([
|
||||
'id' => $id,
|
||||
'status' => $status
|
||||
]);
|
||||
if ($res === false) {
|
||||
return $this->buildFailed(ReturnCode::DB_SAVE_ERROR);
|
||||
}
|
||||
|
||||
return $this->buildSuccess();
|
||||
}
|
||||
|
||||
/**
|
||||
* 编辑用户
|
||||
* @return Response
|
||||
* @author zhaoxiang <zhaoxiang051405@gmail.com>
|
||||
*/
|
||||
public function edit(): Response {
|
||||
$res = AdminAuthGroup::update([
|
||||
'id' => $this->request->post('id', 0),
|
||||
'name' => $this->request->post('name', ''),
|
||||
'description' => $this->request->post('description', '')
|
||||
]);
|
||||
if ($res === false) {
|
||||
return $this->buildFailed(ReturnCode::DB_SAVE_ERROR);
|
||||
}
|
||||
|
||||
return $this->buildSuccess();
|
||||
}
|
||||
|
||||
/**
|
||||
* 删除组
|
||||
* @return Response
|
||||
* @throws \think\db\exception\DataNotFoundException
|
||||
* @throws \think\db\exception\DbException
|
||||
* @throws \think\db\exception\ModelNotFoundException
|
||||
* @author zhaoxiang <zhaoxiang051405@gmail.com>
|
||||
*/
|
||||
public function del(): Response {
|
||||
$id = $this->request->get('id');
|
||||
if (!$id) {
|
||||
return $this->buildFailed(ReturnCode::EMPTY_PARAMS, '缺少必要参数');
|
||||
}
|
||||
|
||||
$listInfo = (new AdminAuthGroupAccess())->where('find_in_set("' . $id . '", `group_id`)')->select();
|
||||
if ($listInfo) {
|
||||
foreach ($listInfo as $value) {
|
||||
$oldGroupArr = explode(',', $value->group_id);
|
||||
$key = array_search($id, $oldGroupArr);
|
||||
unset($oldGroupArr[$key]);
|
||||
$newData = implode(',', $oldGroupArr);
|
||||
$value->group_id = $newData;
|
||||
$value->save();
|
||||
}
|
||||
}
|
||||
|
||||
AdminAuthGroup::destroy($id);
|
||||
AdminAuthRule::destroy(['group_id' => $id]);
|
||||
|
||||
return $this->buildSuccess();
|
||||
}
|
||||
|
||||
/**
|
||||
* 从指定组中删除指定用户
|
||||
* @return Response
|
||||
* @throws \think\db\exception\DataNotFoundException
|
||||
* @throws \think\db\exception\DbException
|
||||
* @throws \think\db\exception\ModelNotFoundException
|
||||
* @author zhaoxiang <zhaoxiang051405@gmail.com>
|
||||
*/
|
||||
public function delMember(): Response {
|
||||
$gid = $this->request->get('gid', 0);
|
||||
$uid = $this->request->get('uid', 0);
|
||||
if (!$gid || !$uid) {
|
||||
return $this->buildFailed(ReturnCode::EMPTY_PARAMS, '缺少必要参数');
|
||||
}
|
||||
$oldInfo = (new AdminAuthGroupAccess())->where('uid', $uid)->find()->toArray();
|
||||
$oldGroupArr = explode(',', $oldInfo['group_id']);
|
||||
$key = array_search($gid, $oldGroupArr);
|
||||
unset($oldGroupArr[$key]);
|
||||
$newData = implode(',', $oldGroupArr);
|
||||
$res = AdminAuthGroupAccess::update([
|
||||
'group_id' => $newData
|
||||
], [
|
||||
'uid' => $uid
|
||||
]);
|
||||
if ($res === false) {
|
||||
return $this->buildFailed(ReturnCode::DB_SAVE_ERROR);
|
||||
}
|
||||
|
||||
return $this->buildSuccess();
|
||||
}
|
||||
|
||||
/**
|
||||
* 构建适用前端的权限数据
|
||||
* @param $list
|
||||
* @param $rules
|
||||
* @return array
|
||||
* @author zhaoxiang <zhaoxiang051405@gmail.com>
|
||||
*/
|
||||
private function buildList($list, $rules): array {
|
||||
$newList = [];
|
||||
foreach ($list as $key => $value) {
|
||||
$newList[$key]['title'] = $value['title'];
|
||||
$newList[$key]['key'] = $value['url'];
|
||||
if (isset($value['children'])) {
|
||||
$newList[$key]['expand'] = true;
|
||||
$newList[$key]['children'] = $this->buildList($value['children'], $rules);
|
||||
} else {
|
||||
if (in_array($value['url'], $rules)) {
|
||||
$newList[$key]['checked'] = true;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
return $newList;
|
||||
}
|
||||
|
||||
/**
|
||||
* 编辑权限细节
|
||||
* @return Response
|
||||
* @throws \think\db\exception\DataNotFoundException
|
||||
* @throws \think\db\exception\DbException
|
||||
* @throws \think\db\exception\ModelNotFoundException
|
||||
* @author zhaoxiang <zhaoxiang051405@gmail.com>
|
||||
*/
|
||||
public function editRule(): Response {
|
||||
$id = $this->request->post('id', 0);
|
||||
$rules = $this->request->post('rules', []);
|
||||
if ($rules) {
|
||||
$needAdd = [];
|
||||
$has = (new AdminAuthRule())->where(['group_id' => $id])->select();
|
||||
$has = Tools::buildArrFromObj($has);
|
||||
$hasRule = array_column($has, 'url');
|
||||
$needDel = array_flip($hasRule);
|
||||
foreach ($rules as $key => $value) {
|
||||
if (!empty($value)) {
|
||||
if (!in_array($value, $hasRule)) {
|
||||
$data['url'] = $value;
|
||||
$data['group_id'] = $id;
|
||||
$needAdd[] = $data;
|
||||
} else {
|
||||
unset($needDel[$value]);
|
||||
}
|
||||
}
|
||||
}
|
||||
if (count($needAdd)) {
|
||||
(new AdminAuthRule())->saveAll($needAdd);
|
||||
}
|
||||
if (count($needDel)) {
|
||||
$urlArr = array_keys($needDel);
|
||||
(new AdminAuthRule())->whereIn('url', $urlArr)->where('group_id', $id)->delete();
|
||||
}
|
||||
}
|
||||
|
||||
return $this->buildSuccess();
|
||||
}
|
||||
}
|
@ -47,7 +47,7 @@ class User extends Base {
|
||||
}
|
||||
|
||||
$listObj = $obj->order('create_time', 'DESC')
|
||||
->paginate(['page' => $start, 'list_rows' => $limit], false)->each(function($item, $key) {
|
||||
->paginate(['page' => $start, 'list_rows' => $limit])->each(function($item, $key) {
|
||||
$item->userData;
|
||||
})->toArray();
|
||||
$listInfo = $listObj['data'];
|
||||
|
@ -106,13 +106,13 @@ class Tools {
|
||||
|
||||
/**
|
||||
* 将二维数组变成指定key
|
||||
* @param array $array
|
||||
* @param $array
|
||||
* @param string $keyName
|
||||
* @return array
|
||||
* @author zhaoxiang <zhaoxiang051405@gmail.com>
|
||||
*/
|
||||
public static function buildArrByNewKey(array $array, string $keyName = 'id'): array {
|
||||
$list = array();
|
||||
public static function buildArrByNewKey($array, string $keyName = 'id'): array {
|
||||
$list = [];
|
||||
foreach ($array as $item) {
|
||||
$list[$item[$keyName]] = $item;
|
||||
}
|
||||
@ -136,9 +136,9 @@ class Tools {
|
||||
string $child = 'children',
|
||||
string $root = '0'
|
||||
): array {
|
||||
$tree = array();
|
||||
$tree = [];
|
||||
if (is_array($list)) {
|
||||
$refer = array();
|
||||
$refer = [];
|
||||
foreach ($list as $key => $data) {
|
||||
$refer[$data[$pk]] = &$list[$key];
|
||||
}
|
||||
|
Loading…
x
Reference in New Issue
Block a user