Nous fournissons ici le squelette d’un tel code, en PHP, pour le flux Autorisation via un code (Authorization Code Grant).
Tous les cas non conformes ne sont pas traités, mais cependant le code est fonctionnel.
PHP
- <?php
- /*
- Autorisation avec OAuth Server by DnC
- Retour de OAuth authorize.
- Ce fichier doit être installé du côté de l'application cliente.
- Il correspond au Point d’extrémité de redirection, ou URI de
- retour à l’application cliente (Redirection Endpoint).
- Auteur : Bertrand degoy
- Copyright (c) 2016 DnC
- */
- //*
- }
- //*/
- // Code d'autorisation (Authorization code) retourné par le serveur
- $authcode = $_GET['code'];
- if ( $sanitized_authcode === $authcode ) {
- // Demander un jeton d'accès pour l'application
- $jeton = '';
- $url = 'http://oa.dnc.global/oauth/token.php';
- 'grant_type' => 'authorization_code',
- 'code' => $sanitized_authcode,
- 'client_id' => 'XXXXXXX',
- 'client_secret' => 'XXXXXXXXXXXXXX',
- );
- switch( (int)$http_code ) {
- case 200 :
- if ( $result['access_token'] ) {
- $token = $result['access_token'];
- if ( $sanitized_token === $token ) {
- $jeton = $token;
- } else {
- // Jeton d'accès corrompu
- }
- } else {
- // Application non autorisée
- }
- if ( $result['refresh_token'] ) {
- $refresh_token = $result['refresh_token'];
- if ( $sanitized_rtoken === $refresh_token ) {
- $rejeton = $refresh_token;
- } else {
- // Jeton de rafraîchissement corrompu
- }
- } else {
- // Application non autorisée
- }
- // Ici, il serait bon de vérifier le jeton, par introspection par exemple.
- ...
- // Succès, mémoriser les jetons dans la session de l'application
- $_SESSION['oauth_access_token'] = $jeton;
- $_SESSION['oauth_refresh_token'] = $rejeton;
- if ( $oauth_again = $_SESSION['oauth_again'] ) {
- // Reprendre où nous en étions avant l'interruption
- exit;
- }
- }
- break;
- case 401 :
- // Accès non autorisé : problème avec CORS ?
- break;
- case 405 :
- // Requête invalide
- break;
- case 400 :
- // URL non trouvée ou Accès non autorisé
- default:
- break;
- }
- // Lire l'erreur
- echo $msg['error']; //DEBUG
- }
- }
- } else {
- // Code d'autorisation corrompu
- }
- ?>
Ceci n’est qu’un exemple très incomplet. Il est important de noter que le jeton ne sert à rien, puisque nous ne le validons pas. La seule chose que nous apprend cette procédure est que l’application est autorisée, à condition toutefois que la réponse ne soit pas falsifiée. La sécurité repose sur l’intégrité de la liaison application-serveur.