This package provides WordPress.com OAuth 2.0 support for the PHP League's OAuth 2.0 Client., (*1)
Requirements
This package uses WordPress.com Connect to authenticate users with WordPress.com accounts., (*2)
Requirements to use this package:
- PHP >= 5.6
- a WordPress client ID and client secret, referred to as {wordpress-client-id} and {wordpress-client-secret}. Follow the WordPress Apps instructions to create the required credentials, (*3)
Installation
Use composer to install:, (*4)
composer require layered/oauth2-wordpress-com
Usage
Usage is the same as The League's Abstract OAuth client, using \Layered\OAuth2\Client\Provider\WordPressCom as the provider., (*5)
Authorization Code Flow
use Layered\OAuth2\Client\Provider\WordPressCom;
$provider = new WordPressCom([
    'clientId'      =>  '{wordpresscom-client-id}',
    'clientSecret'  =>  '{wordpresscom-client-secret}',
    'redirectUri'   =>  'https://example.com/callback-url',
    'blog'          =>  'https://example.com'       // optional - request auth for a specific blog
]);
if (isset($_GET['error'])) {    // Got an error, probably user denied access
    exit('Error: ' . htmlspecialchars($_GET['error_description'] . ' (' . $_GET['error_description'] . ')', ENT_QUOTES, 'UTF-8'));
} elseif (!isset($_GET['code'])) {  // If we don't have an authorization code then get one
    $authUrl = $provider->getAuthorizationUrl();
    $_SESSION['oauth2state'] = $provider->getState();
    header('Location: '. $authUrl);
    exit;
} elseif (empty($_GET['state']) || ($_GET['state'] !== $_SESSION['oauth2state'])) { // Check given state against previously stored one to mitigate CSRF attack
    unset($_SESSION['oauth2state']);
    exit('Invalid state');
} else {
    // Try to get an access token (using the authorization code grant)
    $token = $provider->getAccessToken('authorization_code', [
        'code' => $_GET['code']
    ]);
    // If auth was for a single site or global access, token contains extra blog info
    $tokenValues = $token->getValues();
    echo 'Blog ID: ' . $tokenValues['blog_id'] . '<br>';
    echo 'Blog URL: ' . $tokenValues['blog_url'] . '<br>';
    // Get user profile data
    try {
        // We got an access token, let's now get the user's details
        $user = $provider->getResourceOwner($token);
        // Use these details to create a new profile
        printf('Hello %s!', $user->getName());
    } catch (\Exception $e) {
        // Failed to get user details
        exit('Something went wrong: ' . $e->getMessage());
    }
    // Use this to interact with an API on the users behalf
    echo $token->getToken();
}
Available Options
The WordPressCom provider has the following options:, (*6)
- 
blogcan be a blog URL or blog ID for a WordPress.com blog or Jetpack site
- 
scopeto request access to additional data
Scopes
When creating the authorization URL, specify the scope your application may authorize. Available scopes for WordPress.com:, (*7)
- 
authfor authentication only, grants access to /me endpoints
- 
globalaccess to all user's sites and data
- '' (empty) access to a single blog, specified in request or chosen by user
Get access to user profile
$provider->getAuthorizationUrl([
    'scope' =>  'auth'
]);
Get access to user profile & a single blog
$provider->getAuthorizationUrl([
    'scope' =>  ''
]);
Testing
composer test
Credits
License
The MIT License (MIT). Please see License File for more information., (*8)