You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

187 lines
7.0 KiB

This file contains ambiguous Unicode characters!

This file contains ambiguous Unicode characters that may be confused with others in your current locale. If your use case is intentional and legitimate, you can safely ignore this warning. Use the Escape button to highlight these characters.

<?php
namespace App\Http\Controllers\Admin;
use App\Models\OperateLog;
use App\Models\Role;
use App\Models\RoleHasPermission;
use Illuminate\Http\Request;
use Illuminate\Support\Facades\DB;
class RoleController extends CommonController
{
/**
* @OA\Get(
* path="/api/admin/role",
* tags={"后台管理"},
* summary="获取角色",
* description="",
* @OA\Parameter(name="token", in="query", @OA\Schema(type="string"), required=true, description="token"),
* @OA\Response(
* response="200",
* description="获取角色"
* )
* )
*/
public function index()
{
$data = (new Role())->with("admin", "permissions")->orderBy("sortnumber")->get()->toArray();
foreach ($data as &$item) {
foreach ($item['permissions'] as &$permission) {
$has_auth_node_tags = RoleHasPermission::where('role_id', $item['id'])
->where('permission_id', $permission['id'])->value('auth_node_tags');
$permission['has_auth_node_tags'] = [];
if (!empty($has_auth_node_tags)) {
$permission['has_auth_node_tags'] = explode(',', $has_auth_node_tags);
}
}
}
return $this->success($data);
}
/**
* @OA\Get(
* path="/api/admin/role/show",
* tags={"后台管理"},
* summary="获取角色详情",
* description="",
* @OA\Parameter(name="id", in="query", @OA\Schema(type="string"), required=true, description="id"),
* @OA\Parameter(name="token", in="query", @OA\Schema(type="string"), required=true, description="token"),
* @OA\Response(
* response="200",
* description="获取角色"
* )
* )
*/
public function show()
{
$data = (new Role())->with("admin", "roleHasPermissions.permissions")->find(request()->id);
return $this->success($data);
}
/**
* @OA\Post(
* path="/api/admin/role/save",
* tags={"后台管理"},
* summary="保存角色",
* description="",
* @OA\Parameter(name="token", in="query", @OA\Schema(type="string"), required=true, description="token"),
* @OA\Parameter(name="id", in="query", @OA\Schema(type="integer"), description="菜单ID为空表示新增不为空表示更新"),
* @OA\Parameter(name="name", in="query", @OA\Schema(type="string"), required=true, description="名称"),
* @OA\Parameter(name="introduce", in="query", @OA\Schema(type="string"), required=true, description="说明"),
* @OA\Parameter(name="allow_level", in="query", @OA\Schema(type="string"), required=true, description="数据权限0全部1部分2自己"),
* @OA\Parameter(name="sortnumber", in="query", @OA\Schema(type="integer"), description="同级排序默认为0"),
* @OA\Response(
* response="200",
* description="保存角色"
* )
* )
*/
public function save()
{
if (request()->id) {
return $this->update();
} else {
return $this->store();
}
}
public function store()
{
DB::beginTransaction();
try {
$data = (new Role())->filterRequestColumns(request(), ["id"]);
$data["guard_name"] = $this->guardName;
$permission = Role::create($data);
DB::commit();
OperateLog::addLogs($this->getUser(), "新增角色[$permission->name]成功");
return $this->success($permission);
} catch (\Exception $exception) {
DB::rollBack();
OperateLog::addLogs($this->getUser(), "新增角色失败", $exception->getMessage());
return $this->fail([$exception->getCode(), $exception->getMessage()]);
}
}
public function update()
{
DB::beginTransaction();
try {
$model = Role::find(request()->id);
$data = $model->filterRequestColumns(request(), ["id"]);
$model->update($data);
DB::commit();
OperateLog::addLogs($this->getUser(), "更新角色[$model->name]成功");
return $this->success($model);
} catch (\Exception $exception) {
DB::rollBack();
OperateLog::addLogs($this->getUser(), "更新角色失败", $exception->getMessage());
return $this->fail([$exception->getCode(), $exception->getMessage()]);
}
}
/**
* @OA\Post(
* path="/api/admin/role/delete",
* tags={"后台管理"},
* summary="删除角色",
* description="",
* @OA\Parameter(name="token", in="query", @OA\Schema(type="string"), required=true, description="token"),
* @OA\Parameter(name="id", in="query", @OA\Schema(type="integer"), description="ID"),
* @OA\Response(
* response="200",
* description="删除角色"
* )
* )
*/
public function delete(Request $request)
{
$role = Role::find($request->id);
try {
$role->delete();
OperateLog::addLogs($this->getUser(), "删除角色[$role->name]成功");
return $this->success("删除成功");
} catch (\Exception $exception) {
OperateLog::addLogs($this->getUser(), "删除角色[$role->name]失败");
return $this->fail([$exception->getCode(), $exception->getMessage()]);
}
}
/**
* @OA\Post(
* path="/api/admin/role/set-permissions",
* tags={"后台管理"},
* summary="角色授权",
* description="",
* @OA\Parameter(name="token", in="query", @OA\Schema(type="string"), required=true, description="token"),
* @OA\Parameter(name="id", in="query", @OA\Schema(type="integer"), required=true, description="ID"),
* @OA\Parameter(name="permission_list", in="query", @OA\Schema(type="object"), required=true, description="二维数组形式,包括:permission_id权限idauth_node_tags英文逗号分隔的权限标示"),
* @OA\Response(
* response="200",
* description="角色授权"
* )
* )
*/
public function setPermissions(Request $request)
{
$all = request()->all();
DB::beginTransaction();
try {
$role = Role::find($all['id']);
if (isset($all['permission_list'])) {
$role->roleHasPermissions()->delete();
$role->roleHasPermissions()->createMany($all['permission_list']);
}
DB::commit();
OperateLog::addLogs($this->getUser(), "角色批量授权成功");
return $this->success("授权成功");
} catch (\Exception $exception) {
DB::rollBack();
// 加日志
OperateLog::addLogs($this->getUser(), "角色批量授权失败");
return $this->fail([$exception->getCode(), $exception->getMessage()]);
}
}
}