Files

47 lines
1.5 KiB
PHP
Raw Permalink Normal View History

2025-11-07 09:56:20 +08:00
<?php
namespace plugin\admin\app\middleware;
use plugin\admin\api\Auth;
use ReflectionException;
use support\exception\BusinessException;
use Webman\Http\Request;
use Webman\Http\Response;
use Webman\MiddlewareInterface;
class AccessControl implements MiddlewareInterface
{
/**
* @param Request $request
* @param callable $handler
* @return Response
* @throws ReflectionException|BusinessException
*/
public function process(Request $request, callable $handler): Response
{
$controller = $request->controller;
$action = $request->action;
$request->controller_name = get_controller_name();
$request->action_name = get_action_name();
$code = 0;
$msg = '';
if (!Auth::canAccess($controller, $action, $code, $msg)) {
if ($request->expectsJson()) {
$response = json(['code' => $code, 'msg' => $msg, 'data' => []]);
} else {
if ($code === 401) {
2025-12-24 16:59:05 +08:00
$response = response('<script> if (self !== top) { parent.location = "'.admin_path().'"; }</script>',401);
//$response = response('',301, ['Location'=> admin_path().'/index/index']);
2025-11-07 09:56:20 +08:00
} else {
$request->app = '';
$request->plugin = 'admin';
$response = view('common/403')->withStatus(403);
}
}
2025-11-22 15:31:01 +08:00
return $response;
2025-11-07 09:56:20 +08:00
}
2025-11-22 15:31:01 +08:00
return $handler($request);
2025-11-07 09:56:20 +08:00
}
}