hyperf-chat/app/Middleware/WebSocketAuthMiddleware.php

48 lines
1.3 KiB
PHP
Raw Normal View History

2020-11-07 22:57:10 +08:00
<?php
declare(strict_types=1);
2020-12-26 21:33:40 +08:00
/**
* This is my open source code, please do not use it for commercial applications.
* For the full copyright and license information,
* please view the LICENSE file that was distributed with this source code
*
* @author Yuandong<837215079@qq.com>
* @link https://github.com/gzydong/hyperf-chat
*/
2020-11-07 22:57:10 +08:00
namespace App\Middleware;
use Hyperf\Di\Annotation\Inject;
use Psr\Container\ContainerInterface;
use Psr\Http\Message\ResponseInterface;
use Psr\Http\Server\MiddlewareInterface;
use Psr\Http\Message\ServerRequestInterface;
use Psr\Http\Server\RequestHandlerInterface;
2020-11-24 23:23:12 +08:00
/**
* WebSocket token 授权验证中间件
*
* @package App\Middleware
*/
2020-11-07 22:57:10 +08:00
class WebSocketAuthMiddleware implements MiddlewareInterface
{
/**
* @var ContainerInterface
*/
protected $container;
public function __construct(ContainerInterface $container)
{
$this->container = $container;
}
public function process(ServerRequestInterface $request, RequestHandlerInterface $handler): ResponseInterface
{
// 授权验证拦截握手请求并实现权限检查
2021-05-23 16:52:01 +08:00
if (auth('jwt')->guest()) {
2020-11-07 22:57:10 +08:00
return $this->container->get(\Hyperf\HttpServer\Contract\ResponseInterface::class)->raw('Forbidden');
}
return $handler->handle($request);
}
}