mirror of
https://github.com/flarum/core.git
synced 2025-07-14 05:16:24 +02:00
This finally adopts the new standardized interfaces instead of the work-in-progress ones with the `Interop\` prefix. Since we have now updated to PHP 7.1, we can also use Stratigility 3.0 as the middleware dispatcher.
66 lines
1.8 KiB
PHP
66 lines
1.8 KiB
PHP
<?php
|
|
|
|
/*
|
|
* This file is part of Flarum.
|
|
*
|
|
* (c) Toby Zerner <toby.zerner@gmail.com>
|
|
*
|
|
* For the full copyright and license information, please view the LICENSE
|
|
* file that was distributed with this source code.
|
|
*/
|
|
|
|
namespace Flarum\Http\Middleware;
|
|
|
|
use Flarum\Api\ApiKey;
|
|
use Flarum\Http\AccessToken;
|
|
use Flarum\User\User;
|
|
use Psr\Http\Message\ResponseInterface as Response;
|
|
use Psr\Http\Message\ServerRequestInterface as Request;
|
|
use Psr\Http\Server\MiddlewareInterface as Middleware;
|
|
use Psr\Http\Server\RequestHandlerInterface as Handler;
|
|
|
|
class AuthenticateWithHeader implements Middleware
|
|
{
|
|
const TOKEN_PREFIX = 'Token ';
|
|
|
|
public function process(Request $request, Handler $handler): Response
|
|
{
|
|
$headerLine = $request->getHeaderLine('authorization');
|
|
|
|
$parts = explode(';', $headerLine);
|
|
|
|
if (isset($parts[0]) && starts_with($parts[0], self::TOKEN_PREFIX)) {
|
|
$id = substr($parts[0], strlen(self::TOKEN_PREFIX));
|
|
|
|
if (isset($parts[1])) {
|
|
if ($key = ApiKey::find($id)) {
|
|
$actor = $this->getUser($parts[1]);
|
|
|
|
$request = $request->withAttribute('apiKey', $key);
|
|
$request = $request->withAttribute('bypassFloodgate', true);
|
|
}
|
|
} elseif ($token = AccessToken::find($id)) {
|
|
$token->touch();
|
|
|
|
$actor = $token->user;
|
|
}
|
|
|
|
if (isset($actor)) {
|
|
$request = $request->withAttribute('actor', $actor);
|
|
$request = $request->withoutAttribute('session');
|
|
}
|
|
}
|
|
|
|
return $handler->handle($request);
|
|
}
|
|
|
|
private function getUser($string)
|
|
{
|
|
$parts = explode('=', trim($string));
|
|
|
|
if (isset($parts[0]) && $parts[0] === 'userId') {
|
|
return User::find($parts[1]);
|
|
}
|
|
}
|
|
}
|