GithubHelp home page GithubHelp logo

redux-fetch-apptoken's Introduction

Redux fetch app token

Redux middleware that wraps fetch calls with a http header that bears and app token.

Useful for non-full fledged HTTP bearer token OAuth2 implementations, like for microservice architecture that have a central authorization microservice that grants temporary app tokens to other microservices.

Usage

npm install --save @bongione/redux-fetch-apptoken

When setting up your redux store

let {createStore, applyMiddleware} = require('redux')
import {fetchWithAppTokenMiddleware} from '@bongione/redux-fetch-apptoken'

const options = {
    tokenFetchRequest: (url, scopes) => { ... },
    tokenFetchUrl: '/auth/users/app_token',
    httpAppTokenHeader: 'SENECA-APP-TOKEN'
}

const store = createStore(testApp, applyMiddleware(
        fetchWithAppTokenMiddleware(options)
    ))

The options object attributes are:

  • tokenFetchRequest a function with signature (url = '', scope = []) to retrieve the app tokens once the user has been authenticated
  • tokenFetchUrl the url used to retrieve the tokens
  • httpAppTokenHeader The HTTP header name to use where the token is attached to.

The middleware expects the token provider to return a json object of the format

{
    token: 'TOKENSTRING',
    expires_is_s: 3600
}

When you would usually call a fetch statement from an action

import {fetchWithAppToken} from '@bongione/redux-fetch-apptoken'

function testPostFetchAction (fetch, dispatch) {
    fetch
        .then(response => response.json())
        .then(json => {
            dispatch(saveData(json))
        })
        .catch(err => {
            console.log(err)
        })
}


store.dispatch(fetchWithAppToken('test_url', {}, 'TEST', testPostFetchAction))

fetchWithAppToken (url, fetch_options, scope, action) takes the following parameters:

  • url url to fetch from
  • fetch_options options you would use for your fetch called, like method, credentials, body...
  • scope The scope of the API you are calling. We expect the backend to be served by multiple microservices
  • action the action to perform after the fetch. Action should be a function with the following signature:
action(fetchPromise, dispatch)

The middleware will queue fetch requests until a valid token has been retrieved from the backend.

redux-fetch-apptoken's People

Contributors

bongione avatar

Watchers

 avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.