codezero / oauth
Social authentication without the headaches.
Requires
- php: >=5.4.0
- and/oauth: ~0.6
Requires (Dev)
- henrikbjorn/phpspec-code-coverage: ~1.0
- phpspec/phpspec: ~2.0
This package is auto-updated.
Last update: 2024-11-11 14:40:11 UTC
README
Social authentication without the headaches!
This package is a wrapper around logical-and/php-oauth and aims to make it even easier to authenticate users via third party providers. Supports vanilla PHP and Laravel 5.
Installation
Install this package through Composer:
composer require codezero/oauth
Register Apps
You will need to create an App with each of the providers that you wish to support. They will give you an App ID (or key) and an App secret.
Vanilla PHP Implementation
Create a Configuration File
Create a providers.php
configuration file and store your keys in it:
<?php
return [
'facebook' => [
'key' => '123',
'secret' => '456',
],
'google' => [
'key' => '123',
'secret' => '456',
],
// ...
];
Create a Script
Create a .php
file and autoload the vendor classes:
require_once 'vendor/autoload.php'; // Path may vary
Next, import and new up the classes:
use CodeZero\OAuth\Authenticator;
use CodeZero\OAuth\ProviderFactory;
$credentials = include __DIR__.'/path/to/providers.php';
$providerFactory = new ProviderFactory($credentials);
$auth = new Authenticator($providerFactory);
Now you have $auth
to work with. Jump to #usage to see how easy it is... ;)
Laravel 5 Implementation
Add the ServiceProvider to the providers array in config/app.php
:
'providers' => [
'CodeZero\OAuth\Laravel5\OAuthServiceProvider'
]
Create oauth-providers.php
to the config
folder and add your configuration array, or simply publish and edit it:
php artisan config:publish codezero/oauth
Then you can "make" (or inject) a Authenticator
instance anywhere in your app:
$auth = \App::make('CodeZero\OAuth\Contracts\Authenticator');
Now you have $auth
to work with. Jump to #usage to see how easy it is... ;)
Usage
Redirect... Enjoy the ride!
With the Authenticator
instance ($auth
) you can call... Facebook (or Google, or...):
$details = $auth->request('facebook'); //=> Lower case!
When you run $auth->request('provider')
you will first be redirected to the provider. You will need to grant or deny access to your personal information and then you will be redirected back to the page where you came from.
IMPORTANT: You need to set your page as a valid callback URL in your App!
Also note that this script will always append
?run=1
to the URL when you are redirected back. Depending on the provider, they are touchy about this. At least for Google this is very important, so make sure you include it in the callback URL in your App settings if needed!
Check the response...
Now you can handle the $details
that were returned by the provider:
if ($details) {
$email = $details->getEmail();
$firstName = $details->getFirstName();
$lastName = $details->getLastName();
// ...
} else {
// User canceled!
}
If the user declines, $details
will be false
and you can do whatever is needed.
If access is granted, $details
will be an instance of ExtractorInterface
from the logical-and/php-oauth package, which has several handy methods to fetch specific user data. Please refer to https://github.com/logical-and/php-oauth#userdata for more information on this or take a look at the interface
.
Redirect the users...
When you get redirected back to your site after a successful request, you will notice that there is a token in the URL. This token can't be used twice, so if you would refresh the page an exception would be thrown...
Therefor, it might be wise to redirect your users somewhere after you're done.
Available Providers
logical-and/php-oauth
supports ALOT of different services.
Each of those can work with this package, as long as you add the nescessary keys to your configuration and there is a Provider class available.
Create a Provider
If I didn't include a supported provider yet, you can make one yourself:
use CodeZero\OAuth\BaseProvider;
class ExampleProvider extends BaseProvider
{
/**
* Internal Provider Handle
*
* @var string
*/
protected $handle = 'example';
/**
* Default Scope
*
* @var array
*/
protected $defaultScope = [ 'example.scope' ];
/**
* Default Request Uri
*
* @var string
*/
protected $defaultRequest = 'example/uri';
}
The handle needs to match the ones that are used in php-oauth's examples. Also the basic scope and request URI can be found there.
Just save your class somewhere, make sure it's being (auto)loaded and then reference it in your configuration array like so:
'example' => [
'key' => '123',
'secret' => '456',
'scope' => [], // Optional: overrule default
'request_uri' => '', // Optional: overrule default
'callback_url' => '', // Optional: overrule default
'provider_class' => 'ExampleProvider', //=> Your custom provider
],
Examples
Take a look at examples.
ToDo
- Add tests...
- Add more providers...
- Create storage driver for Laravel's Session...
- Fix bugs (maybe... probably...) :)
Testing
$ vendor/bin/phpspec run
Security
If you discover any security related issues, please e-mail me instead of using the issue tracker.
License
The MIT License (MIT). Please see License File for more information.