đ Policier JWT Auth
Installationâ
Policier permet de valider la demande via JWT
Pour installer la stratégie d'installation, vous devez utiliser composer
(gestionnaire de paquets PHP) comme ceci.
composer require bowphp/policier
Configurationâ
Vous pouvez regarder toutes les options de configuration ici.
return [
/**
* Heure d'expiration du token
*/
"exp" => 3600,
/**
* Le token est utilisable aprĂšs cette heure
*/
"nbf" => 60,
/**
* Le token Ă©tait Ă©mis
*/
"iat" => 60,
/**
* Configure l'Ă©metteur
*/
"iss" => "localhost",
/**
* Configure le public
*/
"aud" => "localhost",
/**
* Algorithme de hachage utilisé
*
* HS256, HS384, HS512, RS256, RS384, RS512, ES256, ES384, ES512,
*/
"alg" => "HS512",
/**
* Votre Signature, ce champs est obligatoire pour les autres type de hachage sauf RSA
*/
'signkey' => null,
/**
* Signature en utilisant votre RSA, ce chargera automatique si la clé de hashage est de type RSA
*/
"keychain" => [
/**
* Chemin vers votre clé privée
*/
"private" => null,
/**
* Chemin vers votre clé publique
*/
"public" => null
]
];
Utilisationâ
Policier est trĂšs simple d'utilisation et possĂšde une API claire. La configuration retourne une singleton.
use Policier\Policier;
$configure = require "/path/to/config/file.php";
$policier = Policier::configure($configure);
Vous pouvez aussi faire comme ceci:
use Policier\Policier;
$configure = require "/path/to/config/file.php";
Policier::configure($configure);
$policier = Policier::getInstance();
AprĂšs la configuration, vous pouvez utiliser le helper policier
:
policier($action, ...$args);
La valeur d'action doit ĂȘtre l'une de ces valeurs: encode
, decode
, parse
, verify
, validate
.
Mise Ă jour ou RĂ©cupĂ©ration de la configurationâ
Mise Ă jour de la Configurationâ
Vous pouvez mettre à jour la configuration de base avec la méthode setConfig
:
$policier->setConfig('exp', time() + 72000);
RĂ©cupĂ©ration de la Configurationâ
Vous pouvez également obtenir les informations de configuration avec la méthode getConfig
:
$policier->getConfig('exp');
Encoder un Tokenâ
Encoder rapidement un token:
$id = uniqid();
$claims = [
"name" => "Franck",
"nickname" => "papac",
"logged" => true
];
$token = $policier->encode($id, $claims);
$token->expireIn(); // Expired In
$token->getToken(); // Token value
echo $token;
//=> eyJ0eX...OiJKV1.eyJpc3Mi...OiJsb2.l7v0bS0r...qnK1IeR
$token
est une instance de Policier\Token
et implémente la méthode magique __toString
. Vous pouvez obtenir l'heure d'expiration avec expiredIn
et getToken
pour prendre la valeur du token.
Via l'assistant:
policier('encode', $id, $claims);
DĂ©coder un Tokenâ
MĂȘme chose pour le dĂ©codage de token:
$result = $policier->decode($token);
$result['headers'];
echo $result['claims']['name'];
//=> Franck
Via l'assistant:
policier('decode', $token);
Transformer un Tokenâ
$token = $policier->parse($token);
$token->hasHeader("old") // VĂ©rifier si l'en-tĂȘte existe
$token->getHeader("alg", $default = null); // Obtenez un en-tĂȘte
$token->getHeaders(); // Obtenir tous les en-tĂȘtes
$token->hasClaim("name") // Vérifier si la réclamation existe
$token->getClaim("name", $default = null); // Obtenez une réclamation
$token->getClaims(); // Obtenez toutes les réclamations
$token->isExpired(); // Vérifier si le token a expiré
echo $token->getClaim("name");
//=> Franck
Via l'assistant:
policier('parse', $token);
VĂ©rifier un Tokenâ
VĂ©rifier si le jeton est valide avec tous les attributs JWT.
$verified = $policier->verify($token);
if ($verified) {
echo "Token est valide";
} else {
echo "Token n'est pas valide";
}
Via l'assistant:
policier('verify', $token);
Valider un Tokenâ
Validez le jeton avec les informations de réclamation et les informations exp
.
$claims = [
"name" => "Franck",
"nickname" => "papac",
"logged" => true
];
$validated = $policier->validate($token, $claims);
if ($validated) {
echo "Les informations sont valides";
} else {
echo "Les informations ne sont pas valides";
}
Via l'assistant:
$claims = [
"name" => "Franck",
"nickname" => "papac",
"logged" => true
];
policier('validate', $token, $claims);
Bow Framework et Policierâ
Si vous utilisez Bow Framework, vous pouvez utiliser le plugin de configuration Policier\Bow\PolicierConfiguration::class
et le middleware Policier\Bow\PolicierMiddleware::class
.
Relier la configuration sur app\Kernel.php
:
public function middlewares()
{
return [
...
'policier' => \Policier\Bow\PolicierMiddleware::class,
...
];
}
public function configurations()
{
return [
...
\Policier\Bow\PolicierConfiguration::class,
...
];
}
Utilisez le middleware:
$app->get('/api', function () {
$token = policier()->getToken();
})->middleware('policier');
Le token a été analysé dans l'instance de Policier dans le processus middleware via la méthode plug
. AprÚs l'exécution du middleware, vous pouvez:
- Obtenez le token avec
getToken
- DĂ©coder le token avec
getDecodeToken
- Analyser le token avec
getParsedToken
Personnalisation du Middlewareâ
Notez que vous pouvez créer un autre middleware qui étendra le middleware par defaut Policier\Bow\PolicierMiddleware::class
. Ce qui vous donne la possibilité de changer les messages d'erreur en surchargant les methodes getUnauthorizedMessage
, getExpirateMessage
, getExpirateCode
et getUnauthorizedCode
.
php bow add:middleware CustomPolicierMiddleware
Et ensuite vous pouvez faire ceci:
use Bow\Http\Request;
use Policier\Bow\PolicierMiddleware;
class CustomPolicierMiddleware extends PolicierMiddleware
{
/**
* Obtenir le message d'erreur
*
* @return array
*/
public function getUnauthorizedMessage()
{
return [
'message' => 'unauthorized',
'error' => true
];
}
/**
* Obtenir le message d'expiration du token
*
* @return array
*/
public function getExpirationMessage()
{
return [
'message' => 'token is expired',
'expired' => true,
'error' => true
];
}
/**
* Obtenir le code de réponse non autorisé
*
* @return int
*/
public function getUnauthorizedStatusCode()
{
return 403;
}
/**
* Obtenir le code de réponse
*
* @return int
*/
public function getExpirationStatusCode()
{
return 403;
}
}
Publier le middlewareâ
Pour publier le middleware personnalisé et écraser celui par defaut de Policier c'est trÚs simple, il suffit seulement d'ajouter le middleware dans le fichier app/Kernel/Loader.php
avec la clé api
.
public function middlewares()
{
return [
...
'policier' => \App\Middleware\CustomPolicierMiddleware::class,
...
];
}
Il manque quelque chose ?
Si vous rencontrez des problÚmes avec la documentation ou si vous avez des suggestions pour améliorer la documentation ou le projet en général, veuillez déposer une issue pour nous, ou envoyer un tweet mentionnant le compte Twitter @bowframework ou sur directement sur le github.