Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/edcs/oauth2-mondo
Mondo Provider for @thephpleague's OAuth 2.0 Client
https://github.com/edcs/oauth2-mondo
Last synced: 2 months ago
JSON representation
Mondo Provider for @thephpleague's OAuth 2.0 Client
- Host: GitHub
- URL: https://github.com/edcs/oauth2-mondo
- Owner: edcs
- License: mit
- Archived: true
- Created: 2016-03-05T14:24:47.000Z (almost 9 years ago)
- Default Branch: master
- Last Pushed: 2016-10-26T04:31:29.000Z (about 8 years ago)
- Last Synced: 2024-10-03T09:23:43.024Z (3 months ago)
- Language: PHP
- Homepage:
- Size: 17.6 KB
- Stars: 6
- Watchers: 2
- Forks: 1
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- Contributing: CONTRIBUTING.md
- License: LICENSE
Awesome Lists containing this project
- awesome-monzo - oauth-mondo - A Mondo provider for the PHP League OAuth 2.0 Client (Code & Client Libraries)
README
# Mondo Provider for OAuth 2.0 Client
[![Codeship Status for edcs/oauth-mondo](https://codeship.com/projects/ceb79fd0-c50d-0133-0fd4-62b97b21679d/status?branch=master)](https://codeship.com/projects/138484)
[![Coverage Status](https://coveralls.io/repos/github/edcs/oauth-mondo/badge.svg?branch=master)](https://coveralls.io/github/edcs/oauth-mondo?branch=master)
[![StyleCI](https://styleci.io/repos/53205114/shield)](https://styleci.io/repos/53205114)
[![SensioLabsInsight](https://insight.sensiolabs.com/projects/41068e01-e186-4178-ac5f-f31b38beac28/mini.png)](https://insight.sensiolabs.com/projects/41068e01-e186-4178-ac5f-f31b38beac28)This package provides Mondo OAuth 2.0 support for the PHP League's
[OAuth 2.0 Client](https://github.com/thephpleague/oauth2-client).## Installation
To install, use composer:
```bash
composer require edcs/oauth2-mondo
```### Authorization Code Flow
```php
$provider = new Edcs\OAuth2\Client\Provider\Mondo([
'clientId' => '{your-client-id}',
'clientSecret' => '{your-client-secret}',
'redirectUri' => 'http://localhost:8000/',
]);if (!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;// Check given state against previously stored one to mitigate CSRF attack
} elseif (empty($_GET['state']) || ($_GET['state'] !== $_SESSION['oauth2state'])) {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']
]);
// Now you can do something useful with the access token.
var_dump($token);// Optional: Store the token in the session so we can refresh the page while we're testing
$_SESSION['access_token'] = [
'access_token' => $token->getToken(),
'expires' => $token->getExpires(),
'refresh_token' => $token->getRefreshToken(),
'resource_owner_id' => $token->getResourceOwnerId()
];// Optional: Now you have a token you can look up a users profile data
echo 'Now visit this page.';
}
```## Testing
``` bash
$ ./vendor/bin/phpunit
```## Contributing
Please see [CONTRIBUTING](https://github.com/edcs/oauth2-mondo/blob/master/CONTRIBUTING.md) for details.
## License
The MIT License (MIT). Please see [License File](https://github.com/edcs/oauth2-mondo/blob/master/LICENSE) for
more information.