poirot / authsystem
There is no license information available for the latest version (dev-devel) of this package.
Service Manager Container.
dev-devel
2019-07-16 19:26 UTC
Requires
- poirot/std: dev-devel
- poirot/storage: dev-devel
Suggests
- poirot/http: To Handle Request Aware Authentication Like Digest.
This package is auto-updated.
Last update: 2024-10-17 06:43:27 UTC
README
HTTP authentication using PSR-7 interfaces.
It uses PSR-7 interface implementation for request and response classes that will read the authentication request values and generates the necessary responses.
Separate classes implement the authentication of users from a file based database of user and password records.
It provides classes to check if the user is already logged in an authenticate him in case he isn't.
Overview usage sample
$request = new HttpRequest(new PhpServerRequestBuilder); $response = new HttpResponse(new PhpServerResponseBuilder); $lazyLoad = new LazyFulfillmentIdentity(['fulfillment_by' => 'username', 'data_provider' => new UserData]); $auth = new Authenticator\HttpSessionAuth([ 'identity' => $lazyLoad, 'request' => $request, 'response' => $response, ]); try { $credential = null; ## check user has authenticated login_user: $auth->authenticate($credential); echo 'Continue ...'; if (!$auth->isSignIn()) { $auth->signIn(); header('Location: '.$request->getUri()->getPath()->toString()); die(); } } catch (WrongCredentialException $e) { throw new \Exception('Invalid Username or Password.'); } catch (UserNotFoundException $e) { throw new \Exception('Invalid Username or Password.'); } catch (AuthenticationException $e) { if ($e->getAuthenticator() instanceof Authenticator\HttpSessionAuth) { ### handle login with satisfy request if ($request->plg()->methodType()->isPost()) { $credential = new UserPassCredential($request->plg()->phpServer()->getPost()); goto login_user; } ### challenge user with login form, redirection or etc. $response->setBody(' <form method="post" action="" enctype="application/x-www-form-urlencoded"> <input type="text" name="email"> <input type="password" name="password"> <input type="submit" value="send"> </form> <p>Please Login ...</p> '); } } ## run rest of program if ($auth->hasAuthenticated()) { $response->setBody("<h1>Hello User {$auth->identity()->getEmail()}</h1>"); } ### send response $response->flush();
TODO
- Aggregate Authenticator
- Aggregate Adapter
- Write Authentication Service Layer On Top Of Adapters For Application Dispatching Control