This commit is contained in:
Dave M. 2023-11-03 12:46:28 +00:00
commit 1559ceb248
8 changed files with 143 additions and 1 deletions

View File

@ -0,0 +1,11 @@
<?php
namespace Ulmus\User\Authorize;
use Psr\Http\Message\ServerRequestInterface;
use Ulmus\User\Entity\UserInterface;
interface AuthorizeMethodInterface
{
public function connect(ServerRequestInterface $request) : UserInterface|false;
}

View File

@ -0,0 +1,34 @@
<?php
namespace Ulmus\User\Authorize;
use Psr\Http\Message\ServerRequestInterface;
use Ulmus\User\Entity\UserInterface;
class BasicAuthentication implements AuthorizeMethodInterface
{
public function connect(ServerRequestInterface $request): UserInterface|false
{
if ( null === $auth = $request->getHeader('Authorization') ) {
list($method, $userPass) = explode(' ', $auth, 2) + [ null, null ];
if (! $method ) {
throw new \InvalidArgumentException("An authentication method must be provided");
}
elseif (! $userPass ) {
throw new \InvalidArgumentException("A base64-encoded 'user:password' value must be provided");
}
return false;
}
return false;
}
protected function basicMethod(string $header) : UserInterface|false
{
}
}

View File

@ -0,0 +1,16 @@
<?php
namespace Ulmus\User\Common;
enum AuthorizeEnum : string
{
case Basic = "basic";
case Token = "token";
# case Bearer = "bearer";
# case Custom = "custom";
# case Digest = "digest";
# case Key = "key";
# case Ntlm = "ntlm";
# case Negotiate = "negotiate";
}

View File

@ -0,0 +1,8 @@
<?php
namespace Ulmus\User\Entity;
interface UserInterface
{
public function __toString() : string;
}

View File

@ -37,7 +37,7 @@ class Authenticate {
{
$logUser = function(? int $id) use ($repository) {
if ( $id === null || null === ( $user = $repository->loadFromPk($id) ) ) {
throw new \Exception("User not found.");
throw new \InvalidArgumentException(sprintf("User having id '%s' was not found.", $id));
}
$user->logged = true;

18
src/Lib/Authorize.php Normal file
View File

@ -0,0 +1,18 @@
<?php
namespace Ulmus\User\Lib;
use Ulmus\User\Entity\User;
class Authorize extends Authenticate
{
public function rememberMe(\Ulmus\Repository $repository) : ? User
{
return null;
}
public function authorize(\Ulmus\Repository $repository, array $userLogin, string $password) : User
{
}
}

View File

@ -0,0 +1,29 @@
<?php
namespace Ulmus\User\Middleware;
use Psr\Http\{
Message\ResponseInterface,
Message\ServerRequestInterface,
Server\MiddlewareInterface,
Server\RequestHandlerInterface
};
use Ulmus\User\Authorize\AuthorizeMethodInterface;
use Ulmus\User\Common\AuthorizeEnum;
class AuthorizeMiddleware implements MiddlewareInterface
{
public function __construct(
protected AuthorizeMethodInterface $method,
protected ResponseInterface $loginFailed,
) { }
public function process(ServerRequestInterface $request, RequestHandlerInterface $handler): ResponseInterface
{
if ( false ) {
return $this->loginFailed;
}
return $handler->handle($request);
}
}

View File

@ -0,0 +1,26 @@
<?php
namespace Ulmus\User\Middleware;
use Psr\Http\{
Message\ResponseInterface,
Message\ServerRequestInterface,
Server\MiddlewareInterface,
Server\RequestHandlerInterface
};
class AuthorizeMiddleware implements MiddlewareInterface
{
public function __construct(
protected ResponseInterface $loginFailed
) { }
public function process(ServerRequestInterface $request, RequestHandlerInterface $handler): ResponseInterface
{
if ( false ) {
return $this->loginFailed;
}
return $handler->handle($request);
}
}