Socket
Socket
Sign inDemoInstall

action-chainer

Package Overview
Dependencies
0
Maintainers
1
Versions
1
Alerts
File Explorer

Advanced tools

Install Socket

Detect and block malicious and high-risk dependencies

Install

    action-chainer

Chain async actions one after another. Makes it easy to do async actions when they depend on each other.


Version published
Maintainers
1
Install size
109 kB
Created

Readme

Source

Action Chainer

Chain async actions one after another. Makes it easy to do async actions when they depend on each other.


Build Status Test Coverage npm version

Dependency Status devDependency Status Greenkeeper badge

Installation

npm install action-chainer

Example: API calls that need to pass headers from one to other

This example will take the x-value header from the previous call, and set it for the next one:

const Chainer = require('action-chainer');
const chainer = new Chainer({

  // Sets the state after a successful action
  reducer: function(res) {
    var state = {
      headers: {
        'x-value': res ? res.headers.get('x-value') : null
      }
    };
    return state;
  },

  // Prepares the action arguments based on the given arguments and state
  argsTransformer: function([input, init], state) {
    return [input, state];
  }
});

// Wraps around the fetch API
const chainableFetch = (input, init) => chain(window.fetch, [input, init], window);

Promise.all([
  chainableFetch('/foo'),
  chainableFetch('/bar'),
  chainableFetch('/baz')
]).then((responses) => {
  // Handle the responses
  // Fetch calls were done one after another and the `x-value` header was passed from one to another
});

Docs

Constructor

The constructor accepts an options object that can contain two methods:

reducer(result)

The reducer method receives the action result, and should return a new state

argsTransformer(functionArgs, state)

The argsTransformer receives a list of arguments given to the chained function (as an array) and the state returned by the reducer of the previous action. It should return an array of arguments that should be passed to the original wrapped action function

chain(func, args, ctx)

The chainer instance has only one method - chain. It receives the function we want to call, an array of arguments we want to pass to it and the context we want to use (optional). Chain can be used for one time chained calls, but it can also be used to wrap functions for multiple uses (like in the example above)

License

The MIT License

Credits

action-chainer is maintained and sponsored by Infinum.

FAQs

Last updated on 17 Sep 2017

Did you know?

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc