0
0
mirror of https://github.com/PHPMailer/PHPMailer.git synced 2024-09-20 01:52:15 +02:00
PHPMailer/get_oauth_token.php

145 lines
4.8 KiB
PHP
Raw Normal View History

<?php
/**
2016-04-07 11:33:03 +02:00
* PHPMailer - PHP email creation and transport class.
* PHP Version 5.5
* @package PHPMailer
* @see https://github.com/PHPMailer/PHPMailer/ The PHPMailer GitHub project
2016-04-07 11:33:03 +02:00
* @author Marcus Bointon (Synchro/coolbru) <phpmailer@synchromedia.co.uk>
* @author Jim Jagielski (jimjag) <jimjag@gmail.com>
* @author Andy Prevost (codeworxtech) <codeworxtech@users.sourceforge.net>
* @author Brent R. Matzelle (original founder)
* @copyright 2012 - 2016 Marcus Bointon
* @copyright 2010 - 2012 Jim Jagielski
* @copyright 2004 - 2009 Andy Prevost
* @license http://www.gnu.org/copyleft/lesser.html GNU Lesser General Public License
* @note This program is distributed in the hope that it will be useful - WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE.
*/
/**
* Get an OAuth2 token from an OAuth2 provider.
* * Install this script on your server so that it's accessible
* as [https/http]://<yourdomain>/<folder>/get_oauth_token.php
2016-04-07 11:33:03 +02:00
* e.g.: http://localhost/phpmailer/get_oauth_token.php
* * Ensure dependencies are installed with 'composer install'
2016-04-07 11:33:03 +02:00
* * Set up an app in your Google/Yahoo/Microsoft account
* * Set the script address as the app's redirect URL
2016-04-07 11:33:03 +02:00
* If no refresh token is obtained when running this file,
* revoke access to your app and run the script again.
*/
2016-04-07 11:33:03 +02:00
namespace PHPMailer\PHPMailer;
2016-04-21 12:51:31 +02:00
/**
* Aliases for League Provider Classes
* Make sure you have added these to your composer.json and run `composer install`
* Plenty to choose from here:
* @see http://oauth2-client.thephpleague.com/providers/thirdparty/
2016-04-21 12:51:31 +02:00
*/
// @see https://github.com/thephpleague/oauth2-google
2016-04-07 11:33:03 +02:00
use League\OAuth2\Client\Provider\Google;
// @see https://packagist.org/packages/hayageek/oauth2-yahoo
2016-04-07 11:33:03 +02:00
use Hayageek\OAuth2\Client\Provider\Yahoo;
// @see https://github.com/stevenmaguire/oauth2-microsoft
2016-04-07 11:33:03 +02:00
use Stevenmaguire\OAuth2\Client\Provider\Microsoft;
if (!isset($_GET['code']) && !isset($_GET['provider'])) {
?>
<html>
<body>Select Provider:<br/>
<a href='?provider=Google'>Google</a><br/>
<a href='?provider=Yahoo'>Yahoo</a><br/>
<a href='?provider=Microsoft'>Microsoft/Outlook/Hotmail/Live/Office365</a><br/>
</body>
2016-08-31 10:26:06 +02:00
</html>
2016-04-07 11:33:03 +02:00
<?php
exit;
}
require 'vendor/autoload.php';
session_start();
2016-04-07 11:33:03 +02:00
$providerName = '';
if (array_key_exists('provider', $_GET)) {
$providerName = $_GET['provider'];
$_SESSION['provider'] = $providerName;
} elseif (array_key_exists('provider', $_SESSION)) {
$providerName = $_SESSION['provider'];
}
if (!in_array($providerName, ['Google', 'Microsoft', 'Yahoo'])) {
exit('Only Google, Microsoft and Yahoo OAuth2 providers are currently supported in this script.');
}
2016-08-31 10:26:06 +02:00
//These details are obtained by setting up an app in the Google developer console,
//or whichever provider you're using.
$clientId = 'RANDOMCHARS-----duv1n2.apps.googleusercontent.com';
$clientSecret = 'RANDOMCHARS-----lGyjPcRtvP';
2016-08-31 10:26:06 +02:00
//If this automatic URL doesn't work, set it yourself manually to the URL of this script
2016-04-08 01:41:46 +02:00
$redirectUri = (isset($_SERVER['HTTPS']) ? 'https://' : 'http://') . $_SERVER['HTTP_HOST'] . $_SERVER['PHP_SELF'];
2016-04-07 11:33:03 +02:00
//$redirectUri = 'http://localhost/PHPMailer/redirect';
$params = [
'clientId' => $clientId,
'clientSecret' => $clientSecret,
'redirectUri' => $redirectUri,
'accessType' => 'offline'
];
$options = [];
2016-08-31 10:26:06 +02:00
$provider = null;
2016-04-07 11:33:03 +02:00
switch ($providerName) {
case 'Google':
$provider = new Google($params);
$options = [
'scope' => [
'https://mail.google.com/'
]
];
2016-04-07 11:33:03 +02:00
break;
case 'Yahoo':
$provider = new Yahoo($params);
break;
case 'Microsoft':
$provider = new Microsoft($params);
2016-04-07 11:35:44 +02:00
$options = [
'scope' => [
'wl.imap',
'wl.offline_access'
]
];
2016-04-07 11:33:03 +02:00
break;
}
2016-08-31 10:26:06 +02:00
if (is_null($provider)) {
2017-07-28 10:48:35 +02:00
exit('Provider missing');
2016-08-31 10:26:06 +02:00
}
if (!isset($_GET['code'])) {
// If we don't have an authorization code then get one
2016-04-07 11:33:03 +02:00
$authUrl = $provider->getAuthorizationUrl($options);
2015-10-23 13:32:43 +02:00
$_SESSION['oauth2state'] = $provider->getState();
header('Location: ' . $authUrl);
exit;
// Check given state against previously stored one to mitigate CSRF attack
} elseif (empty($_GET['state']) || ($_GET['state'] !== $_SESSION['oauth2state'])) {
unset($_SESSION['oauth2state']);
2016-04-07 11:33:03 +02:00
unset($_SESSION['provider']);
exit('Invalid state');
} else {
2016-04-07 11:33:03 +02:00
unset($_SESSION['provider']);
// Try to get an access token (using the authorization code grant)
$token = $provider->getAccessToken(
'authorization_code',
2015-11-10 13:45:13 +01:00
[
'code' => $_GET['code']
2015-11-10 13:45:13 +01:00
]
);
2016-04-07 11:33:03 +02:00
// Use this to interact with an API on the users behalf
// Use this to get a new access token if the old one expires
2017-07-28 10:54:10 +02:00
echo 'Refresh Token: ', $token->getRefreshToken();
}