You're Invited:Meet the Socket Team at BlackHat and DEF CON in Las Vegas, Aug 4-6.RSVP
Socket
Book a DemoInstallSign in
Socket

run-middleware

Package Overview
Dependencies
Maintainers
1
Versions
18
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

run-middleware

NodeJS module to execute your Express endpoints (middlewares) from your code. This module will let you laucnch manually all your middleware. It is simulate a client calling to your rest API's. It is not using a network connections

0.9.10
latest
Source
npmnpm
Version published
Weekly downloads
1.5K
61.87%
Maintainers
1
Weekly downloads
 
Created
Source
  • NodeJS run-middleware
  • Why?
  • Installation
  • Support & Contributions
  • Change request paramaters
  • Auto pass cookies
  • Redirecting
  • Changelog
  • Examples
  • License

NodeJS module to execute your Express endpoints (middlewares) from your code. This module will let you manually launch all your middleware. It is simulating a client calling your rest APIs, without using a network connection (your server does not even need to listen on a port).

#NodeJS run-middleware

npm npm version Join the chat at https://gitter.im/node-run-middleware/Lobby Build Status

Why?

Many times, your server and your client, need to execute the same functions. For example here is an endpoint to get user details:

app.get('/get-user/:id',function(req,res){
	mysql.query('select * from users where id=?',[req.params.id],function(err,rows){
		res.send({user:rows[0]})
	})
})

Now you want to get the user details from your code. What should you do?

app.runMiddleware('/get-user/20',function(code,body,headers){
	console.log('User Details:',body)
})

Installation

npm i -S run-middleware

var express=require('express')
var app=express();
require('run-middleware')(app)

Support & Contributions

  • Pull requests, issues, and English proofreading are welcome on Github.
  • Question & support on StackOverflow using run-middlewaretag.

Change request paramaters

As options you can pass the query, body, method, cookies parameters.

app.runMiddleware('/handler',{
		method:'post',
		query:{token:'tk-12345'},
		body:{"action":"list","path":"/"}
	},function(code,data){
		console.log(code,data)
		process.exit()
	})

Auto pass cookies

When you can runMiddleware from another middleware, you can autopass all the parameters of the current middleware, by using the express request object.

app.get('/middleware1',function(req,res){
	// We use res.runMiddleware instead of app.runMiddleware. All the cookies & other data (like socket.io session) will be pass to the second middleware
	res.runMidleware(...)
})

Redirecting

If the middleware you execute will redirect, you will be notified about it, by reading the code and the headers.location

app.runMiddleware('/this-middleware-will-response-as-redirect',function(code,body,headers){
	if(code==301 || code=302) {// Redirect HTTP codes
		console.log('Redirect to:',headers.location)
	}
})

Changelog

  • v1.0.0 (25 June 2018) -
  • v0.6.1 (9 Sep 2016) - Supports response.redirect
  • v0.6.2 (10 Sep 2016) - Supports passing cookies and other variables to runMiddleware
  • v0.6.3 (11 Sep 2016) - Supports running middleware from others middleware, for automatically passing cookies and headers between middlewares.
  • v0.6.4 (13 Sep 2016) - Better documentation and examples

Examples

See the tests

License

ISC License Copyright (c) 2016, Aminadav Glickshtein

Permission to use, copy, modify, and/or distribute this software for any purpose with or without fee is hereby granted, provided that the above copyright notice and this permission notice appear in all copies.

THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.

FAQs

Package last updated on 16 Jul 2018

Did you know?

Socket

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