Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/brunocarvalhodearaujo/js-oauth2

OAuth2 authentication module written in vanilla ES6
https://github.com/brunocarvalhodearaujo/js-oauth2

angular browserify javascript nodejs oauth2 react react-native webpack

Last synced: 2 months ago
JSON representation

OAuth2 authentication module written in vanilla ES6

Awesome Lists containing this project

README

        

js-oauth2
=========

[![npm version](https://badge.fury.io/js/js-oauth2.svg)](http://badge.fury.io/js/js-oauth2)
[![License](https://img.shields.io/npm/l/js-oauth2.svg)](https://www.npmjs.com/package/js-oauth2)
[![Dependency Status](https://david-dm.org/brunocarvalhodearaujo/js-oauth2.svg?style=flat-square)](https://david-dm.org/brunocarvalhodearaujo/js-oauth2)
[![devDependency Status](https://david-dm.org/brunocarvalhodearaujo/js-oauth2/dev-status.svg?style=flat-square)](https://david-dm.org/brunocarvalhodearaujo/js-oauth2#info=devDependencies)
[![npm](https://img.shields.io/npm/dt/js-oauth2.svg)](https://www.npmjs.com/package/js-oauth2)
[![coverage report](https://gitlab.com/brunocarvalho/js-oauth2/badges/2.x/coverage.svg)](https://gitlab.com/brunocarvalho/js-oauth2/commits/2.x)

This library is a port of angular-oauth2 to vanilla JS and fetch. Currently, this library only uses the password
credential grant, i.e, using a combination (username, password), we'll request an access
token (using `grant_type=password`) wich, in case of success, will return a response such as:

````json
{
"access_token": "foobar",
"token_type": "Bearer",
"expires_in": 3600,
"refresh_token": "foobiz"
}
````

Internally we'll automatically store it as a cookie and it will be used in every request adding an
Authorization header: Authorization: 'Bearer foobar'.

### Instalation

choose your preferred method:

- npm: `npm install --save js-oauth2`
- yarn: `yarn add js-oauth2`

### Usage

initialize library:

````js
import { AuthenticationService, AbstractKeychain, httpRequestInterceptor } from 'js-oauth2'
import cookie from 'js-cookie'

class Keychain extends AbstractKeychain {
/**
* @param {Token} value
* @returns {Promise}
*/
setToken (value) {
return new Promise((resolve) => {
resolve(cookie.set('token', value))
})
}

/**
* @returns {Promise}
*/
getToken () {
return new Promise((resolve) => {
resolve(cookie.getJSON('token') || {})
})
}

/**
* @returns {Promise}
*/
removeToken () {
return new Promise((resolve) => {
resolve(cookie.remove('token'))
})
}
}

const oauth = new AuthenticationService({
baseUrl: '/api',
clientId: 'b921b25ebe3ee70c6b1',
clientSecret: '8f4d45d9a363d922b2eb7',
keychain: new Keychain()
})

httpRequestInterceptor(oauth) // only if you need http request interception
````

#### API

Check authentication status:

```js
/**
* Verifies if the `user` is authenticated or not based on the `token`
* cookie.
* @return {Promise}
*/
oauth.isAuthenticated()
```

Get an access token:

```js
/**
* Retrieves the `access_token` and stores the `response.data` on cookies
* using the `OAuthToken`.
* @param {object} user - Object with `username` and `password` properties.
* @param {object} config - Optional configuration object sent to `POST`.
* @return {Promise} A response promise.
*/

oauth.getAccessToken(user, options)
```

Refresh access token:

```js
/**
* Retrieves the `refresh_token` and stores the `response.data` on cookies
* using the `OAuthToken`.
* @return {Promise} A response promise.
*/

oauth.getRefreshToken()
```

Revoke access token:

```js
/**
* Revokes the `token` and removes the stored `token` from cookies
* using the `OAuthToken`.
* @return {Promise} A response promise.
*/

oauth.revokeToken()
```

Catch OAuth errors and do something with them (optional):

````js
/**
* @param {Response} response
*/

async function onError (response) {
const data = await response.clone().json()
if (data.error === 'invalid_grant') {
return
}
// Refresh token when a `invalid_token` error occurs.
if (data.error === 'invalid_token') {
return oauth.getRefreshToken()
}
// Redirect to `/login` with the `error_reason`.
return window.location(`/login?error_reason=${data.error}`)
}

auth.onError(onError)
````

**NOTE**: An *event* `oauth:error` will be sent everytime a `onError` is emitted:

* `{ status: 400, data: { error: 'invalid_request' } }`
* `{ status: 400, data: { error: 'invalid_grant' } }`
* `{ status: 401, data: { error: 'invalid_token' } }`
* `{ status: 401, headers: { 'www-authenticate': 'Bearer realm="example"' } }`

## References to create project
- [angular-oauth2](https://www.npmjs.com/package/angular-oauth2)
- [Resouce Owner Password Credential Grant](https://tools.ietf.org/html/rfc6749#section-4.3)