Skip to content

Latest commit

 

History

History
95 lines (73 loc) · 2.72 KB

README.md

File metadata and controls

95 lines (73 loc) · 2.72 KB

Build Status Coverage Status codecov Code Climate

jigawatt

Influential's Functional, Promise-based Express Middleware

Installation

npm install jigawatt

Middleware Structure

Properties

Jigawatt Middleware must consist of at least one of three properties:

  • awesomize: (Validator -> AwesomizeSpec) -> Request -> Object a

  • io: Request, Data -> Object a

    • returns an object that is merged into req.data
  • transform: Request, Data -> Object a

    • returns an object to become the new req.data value

Example Middleware

const _         = require('ramda')
const Bluebird  = require('bluebird')

const Order = require('../domain/order.js')

const getById = {
  awesomize: (v) => ({
    order_id: {
      read: _.path(['params', 'orderId'])
    , validation: [ v.required ]
    }
  })

  io: (req, data) => {
    return Bluebird.props({
      order : Order.getById(data.order_id)
    })
  }
};

const uniteDetails = {
  transform: (req, data) => {
    return {
      order     : data.order
    , customer  : data.customer
    , product   : data.product
    , shipping  : data.shipping  
    }
  }
}

module.exports = {
  getById
, uniteDetails
}

Example Usage

const router     = require('express').Router()
const JW         = require('jigawatt')

// MIDDLEWARE
const Order      = require('../middleware/order.js')
const Customer   = require('../middleware/customer.js')
const Product    = require('../middleware/product.js')
const Shipping   = require('../middleware/shipping.js')


// ROUTES
router.get('order/:orderId', JW(Order.getById));

router.get('order/:orderId/detail', JW(

  [ Order.getById             // call all of these promise
  , Customer.getByOrderId     // functions at the same time
  , Product.getByOrderId      // and merge request.data when
  , Shipping.getByOrderId     // all are complete
  ]

, Order.uniteDetails          // transform-only middleware
                              // to aggregate details and
                              // present to user
))