micro/plugin-oauth2-client

Micro Framework: OAuth2 client based on "league/oauth2-client"

2.0.0-alpha 2024-07-06 12:41 UTC

This package is auto-updated.

Last update: 2024-11-06 21:31:11 UTC


README

Micro Framework: OAuth2 client based on "league/oauth2-client"

Installation

Install plugin with composer

$ composer require micro/plugin-oauth2-client

And install a specific provider(s).

Available providers: micro/plugin-oauth2-client-keycloak

Аnd then add plugin to the list of plugins (etc/plugins.php)

$pluginsCommon = [
    //....OTHER PLUGINS ....
    Micro\Plugin\OAuth2\Client\OAuth2ClientPlugin::class,
    Micro\Plugin\OAuth2\Client\Keycloak\OAuth2KeycloakProviderPlugin::class,
];

Configure your oauth2 providers

The adapter configuration template usually looks like this MICRO_OAUTH2_<PROVIDER_NAME>_<PROVIDER_SETTING>

Default adapter name "default"

MICRO_OAUTH2_DEFAULT_TYPE=keycloak
MICRO_OAUTH2_DEFAULT_CLIENT_ID=<my-client-id>
MICRO_OAUTH2_DEFAULT_CLIENT_SECRET=<client-secret-key>
MICRO_OAUTH2_DEFAULT_CLIENT_URL_AUTHORIZATION=<auth url>
MICRO_OAUTH2_DEFAULT_CLIENT_URL_REDIRECT=<redirect url>

Usage/Examples

Index document

use use Micro\Plugin\OAuth2\Client\Facade\Oauth2ClientFacadeInterface;

/** Unauthorized user */ 
$client = $container->get(Oauth2ClientFacadeInterface::class);
$provider = $client->getProvider('default');

$provider->getAuthorizationUrl(); This method will return the full path to the server for user authorization.


/*** Response from the authorization server with a code */
$accessToken    = $provider->getAccessToken('authorization_code', [
    'code'  => $_GET['code'],
]);

$owner = $provider->getResourceOwner($accessToken);

$id = $owner->getId();
$ownerData = $owner->toArray(); //Associated data with the user.

Support

For support, email head.trackingsoft@gmail.com.

Authors

License

MIT