admin/plugin/admin/app/middleware/AccessControl.php
2022-09-07 10:24:59 +08:00

33 lines
986 B
PHP

<?php
namespace plugin\admin\app\middleware;
use plugin\admin\app\Admin;
use Webman\MiddlewareInterface;
use Webman\Http\Response;
use Webman\Http\Request;
class AccessControl implements MiddlewareInterface
{
public function process(Request $request, callable $handler): Response
{
$controller = $request->controller;
$action = $request->action;
$code = 0;
$msg = '';
if (!Admin::canAccess($controller, $action, $code, $msg)) {
$response = json(['code' => $code, 'message' => $msg, 'type' => 'error']);
} else {
$response = $request->method() == 'OPTIONS' ? response('') : $handler($request);
}
return $response->withHeaders([
'Access-Control-Allow-Credentials' => 'true',
'Access-Control-Allow-Origin' => $request->header('Origin', '*'),
'Access-Control-Allow-Methods' => '*',
'Access-Control-Allow-Headers' => '*',
]);
}
}