CakePHP OAuth2 Server Plugin
This is a plugin for implementing an OAuth Server/Provider in CakePHP, built on quizlets oauth2-php library
- A lovely OAuth component that allows cakey access to the oauth library
- The required models with super safe automatic beforeSave token hashing
- AuthComponent'ish interface for action allow/deny's
- Convenience functions for retrieving the current user and adding clients
- An example controller with authorize and token end points
A clone of oauth2-php in your Vendors folder
First grab the tables.sql and get your tables going.
Then clone this repo into a "OAuth" folder in your Plugins folder:
$ git clone git://github.com/seddonmedia/cakephp-oauth-server.git Plugin/OAuth
And include the component in your controller:
$components = array('OAuth.OAuth');
This plugin makes it easy to implement an OAuth2 provider/server. However, before you even think about using it you should make sure you are fully aware of how the OAuth "protocol" actually works. Good documentation explaining various OAuth2 flows is provided by Google, Facebook and in the official spec. For reference, this plugin currently supports the following grant types:
- Authorization Code Grant
- Refresh Token Grant
- Resource Owner Password Credentials Grant (requires setup, see below)
If you need any others please build them into the base oauth2-php library and let me know :)
It should be noted that most methods support both GET and POST, so you can test your setup straight from the browser.
To use the "Resource Owner Password Credentials Grant" you need to configure the plugin so it knows where to look for your users username/password combinations. By default it will try a "Users" model with "username" and "password" fields, you can change this in your controllers beforeFilter like so:
$this->OAuth->authenticate = array( 'userModel' => 'Members', 'fields' => array( 'username' => 'email' ) );
You can control what actions can be accessed using an OAuth access token in the same way you control access with the AuthComponent, so for eaxmple placing this in a controller's beforeFilter:
Would allow access to the "userinfo" and "example" actions.
Adding OAuth Clients
A client is an application that can access resources on behalf of resource owner, i.e. someone who can use your API.
This plugin ships with all required models, including the "Clients" model for adding and accessing OAuth clients. You may wish to add clients manually, see the tables.sql for the schema, or you can use the convenience method included in the model, like so:
$client = $this->OAuth->Clients->add('http://www.return_url.com')
Which will generate then client_id and client_secret and return something like:
Array( [client_id] => NGYcZDRjODcxYzFkY2Rk [client_secret] => 8e7ff3208eed06d101bf3da2473fc92ac1c6d2e7 [redirect_uri] => http://www.return_url.com )
The method includes various schemes for generating client id's, pick your favourite.
NOTE: This convenience will generate a random client secret and hash it before storage, for security. It will make sure the actual client secret it returned when using the method, but the as it is stored hashed, it is not possible to ever retrieve the actual client secret that should be used. This means that if the client forgets it, a new client secret will have to be issued.
This plugin ships with an example controller that provides the necessary endpoints to generate access tokens. Routes are also included to give you sexy URL's like: "/oauth/token", you can fire them up by placing this in your bootstrap.php:
CakePlugin::loadAll(array( 'OAuth' => array('routes' => true) ));
As an example, once you have registered a client, you could then use the Authorization Code Grant like so:
- Get an Authorization code
- (note the URL encoding on the redirect_uri)
- Swap code for access token
- Use access token
There is quite a bit of documentation through the code, so dive in, get your hands dirty and submit any issues here!