A simple customizable OAuth 2.0 provider (server) for node.js.
Switch branches/tags
Nothing to show
Pull request Compare This branch is 31 commits behind ammmir:master.
Latest commit 7acc5ed Jul 6, 2012 @ammmir ammmir Add save_access_token event to allow saving the access token.
For some reason, people might want to save the generated access token in
a database, so the save_access_token event is now emitted. It is

Closes #10
Failed to load latest commit information.
examples Add save_access_token event to allow saving the access token. Jul 6, 2012
LICENSE Add MIT license. Apr 13, 2012
README.md Update example authorize URLs. Jul 6, 2012
index.js Add save_access_token event to allow saving the access token. Jul 6, 2012


OAuth 2 Provider for Connect & Express

This is a node.js module for implementing OAuth2 servers (providers) that support server-side (code) and client-side (token) OAuth flows.

It's very customizable, so you can (and currently, must) take care of OAuth token storage and client lists. In the future, a Mongo or Redis backed abstraction will be provided so you don't need to care about any kind of storage at all.

Using it with npm

If you're using this module via npm, please be sure the bracket the version in your app's package.json file. Major versions may have an incompatible API that's not backwards-compatible, so use a safe version range under dependencies (eg. for version 1.x):

"oauth2-provider": ">=1.0.0 <2.0.0"

Quick Start

Install via npm:

npm install oauth2-provider

You can add it to your Connect or Express application as another middleware. Be sure to enable the bodyParser and query middleware.

The OAuth2Provider instance providers two middleware:

  • oauth(): OAuth flow entry and access token generation
  • login(): Access control for protected resources

The most importand event emitted by OAuth2Provider is access_token, which lets you set up the request as if it were authenticated. For example, to support both cookie-authenticated and OAuth access to protected URLs, you could populate req.session.user so that individual URLs don't need to care about which type of authentication was used.


In the root directory, run npm install express and then run:

node examples/simple.js

Visit http://localhost:8081/login to gain access to http://localhost:8081/secret or use OAuth to obtain an access token as a code (default) or a token (in the URL hash):