PHP Classes

File: login_with_microsoft_openid_connect.php

Recommend this page to a friend!
  Classes of Manuel Lemos   PHP OAuth Library   login_with_microsoft_openid_connect.php   Download  
File: login_with_microsoft_openid_connect.php
Role: Example script
Content type: text/plain
Description: Example of logging in with Microsoft OpenID Connect
Class: PHP OAuth Library
Authorize and access APIs using OAuth
Author: By
Last change:
Date: 7 years ago
Size: 2,551 bytes
 

Contents

Class file image Download
<?php
/*
 * login_with_microsoft_openid_connect.php
 *
 * @(#) $Id: login_with_microsoft_openid_connect.php,v 1.2 2017/02/24 11:47:59 mlemos Exp $
 *
 */

    /*
     * Get the http.php file from http://www.phpclasses.org/httpclient
     */
   
require('http.php');
    require(
'oauth_client.php');

   
$client = new oauth_client_class;
   
$client->server = 'MicrosoftOpenIDConnect';
   
$client->debug = true;
   
$client->debug_http = true;
   
$client->redirect_uri = 'https://'.$_SERVER['HTTP_HOST'].
       
dirname(strtok($_SERVER['REQUEST_URI'],'?')).'/login_with_microsoft_openid_connect.php';

   
$client->client_id = ''; $application_line = __LINE__;
   
$client->client_secret = '';

    if(
strlen($client->client_id) == 0
   
|| strlen($client->client_secret) == 0)
        die(
'Please go to Microsoft App Registration Portal '.
           
'https://apps.dev.microsoft.com/ and create a new'.
           
'application, and in the line '.$application_line.
           
' set the client_id to Client ID and client_secret with Client secret. '.
           
'The callback URL must be '.$client->redirect_uri.' but make sure '.
           
'the domain is valid and can be resolved by a public DNS.');

   
/* API permissions
     *
     * The access token will be empty if the requested scopes
     * are from OpenID only and not of any API.
     */
   
$client->scope = 'openid email profile';
   
session_start();
    if((
$success = $client->Initialize()))
    {
        if((
$success = $client->Process()))
        {
            if(
strlen($client->authorization_error))
            {
               
$client->error = $client->authorization_error;
               
$success = false;
            }
            elseif(
strlen($client->access_token))
            {
               
/*
                 * Call any APIs from here
                 */

                /*
                $success = $client->CallAPI(
                    'https://apis.live.net/v5.0/me',
                    'GET', array(), array('FailOnAccessError'=>true), $user);
                 */
           
}
        }
       
$success = $client->Finalize($success);
    }
    if(
$client->exit)
        exit;
    if(
$success)
    {
?>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
<head>
<title>Microsoft OpenID Connect OAuth client results</title>
</head>
<body>
<?php
       
echo '<h1>', HtmlSpecialChars($client->id_token->name),
           
' you have logged in successfully with Microsoft OpenID Connect!</h1>';
        echo
'<pre>', HtmlSpecialChars(print_r($client->id_token, 1)), '</pre>';
?>
</body>
</html>
<?php
   
}
    else
    {
       
$client->ResetAccessToken();
?>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
<head>
<title>OAuth client error</title>
</head>
<body>
<h1>OAuth client error</h1>
<pre>Error: <?php echo HtmlSpecialChars($client->error); ?></pre>
</body>
</html>
<?php
   
}

?>