停车场管理系统
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.
 
 

80 lines
2.0 KiB

<?php
namespace App\Http\Middleware;
use App\Models\AdminRoleUsers;
use App\Services\AdminMenuService;
use App\Services\ApiResponseService;
use Closure;
use Illuminate\Http\Request;
use Illuminate\Support\Facades\Auth;
use Psr\SimpleCache\InvalidArgumentException;
use Symfony\Component\HttpFoundation\Response;
class CheckPermission
{
/**
* @param Request $request
* @param Closure $next
* @return Response
* @throws InvalidArgumentException
*/
public function handle(Request $request, Closure $next): Response
{
if (Auth::guard('sanctum')->check()) {
$action = $request->route()->getCompiled()->getStaticPrefix();
$user = Auth::guard('sanctum')->user();
$user_id = $user->id;
$uriArr = AdminMenuService::auth($user_id);
if ($this->passedOrNot($action, $uriArr)) {
return (new ApiResponseService())->error(
__('middleware.check.user_auth'),
400
);
}
}
return $next($request);
}
/**
* @param $action
* @param $uriArr
* @return bool
*/
protected function passedOrNot($action, $uriArr): bool
{
$characters = '/api/admin/';
$action = ltrim($action, $characters);
if (in_array($action, $uriArr)) {
return false;
}
$methodArr = ['create', 'edit'];
$actionArr = explode('/', trim($action));
$method = $actionArr[1] ?? '';
$newAction = $actionArr[0] ?? '';
// 特殊
if (in_array($newAction, ['logout', 'me'])) {
return false;
}
// 特殊
if (in_array($method, ['rule', 'import'])) {
return false;
}
if ($method == $methodArr[0]) {
$newAction .= '/store';
} elseif($method == $methodArr[1]) {
$newAction .= '/update';
}
if (in_array($newAction, $uriArr)) {
return false;
}
return true;
}
}