crtl / slim-auth-middleware
Simple Middleware for custom authorization.
1.0.3
2018-10-23 11:43 UTC
Requires
- php: ^7.0
- slim/slim: ^3.0
This package is auto-updated.
Last update: 2025-03-24 05:17:56 UTC
README
This package provides a basic middleware to implement authorization of any type.
Installation
composer require crtl/slim-auth-middleware
Usage
The package already comes with a prebuild implementation for HTTP-Basic Authroziation.
<?php use Crtl\AuthorizationMiddleware\BasicAuthorization; $app = new \Slim\App(); $app->add( new BasicAuthorization([ BasicAuthorization::CONFIG_ENABLE => true, BasicAuthorization::CONFIG_USER => "secret", BasicAuthorization::CONFIG_SECRET => "password" ]) ); $app->get("/", function($request, $response) use ($app) { $body = $response->getBody(); $body->write("Authorized"); return $response->withBody($body), }); $app->run();
If the request is authorized the app will call the next middleware. Otherwise Crtl\AuthorizationMiddleware\AbstractAuthorization::getErrorResponse
will be called.
To implement a custom authorization just extend Crtl\AuthorizationMiddleware\AbstractAuthorization
and implement the
protected isAuthorized() : bool
method.
<?php class CustomAuthorization extends \Crtl\AuthorizationMiddleware\AbstractAuthorization{ protected function isAuthorized(): bool { /* @var \Psr\Http\Message\ResponseInterface $response */ $response = $this->response; /* @var \Psr\Http\Message\RequestInterface $request */ $request = $this->request; /* check if authorized */ return true; } }