@ascension/koa-ip
TypeScript icon, indicating that this package has built-in type declarations

2.1.4 • Public • Published

koa-ip

KoaJs Slack

koa-ip is a ip filter middleware for koa, support whitelist and blacklist.

What is Trafficfilter.io?

Trafficfilter.io is a fast, simple, Base-on IP address Invalid Traffic Filtration and IP-Geo Service.

Trafficfilter.io can easily integrating your websites, applications,company's tools .

Scenarios:

  • Evaluation of traffic sources
  • Filtering non-real traffic
  • Blocking spiders and malicious traffic visits

(In most cases, trafficfilter.io is more accurate than most "Cloak" tools)

Install

$ npm i koa-ip --save

Usage

ip(String|RegExp)
ip(Array{String|RegExp})
ip({
  whitelist: Array{String|RegExp},
  blacklist: Array{String|RegExp},
  handler: async (ctx, next) => {} // handle blacklist ip
})

Examples

const Koa = require('koa')
const ip = require('koa-ip')

const app = new Koa()

app.use(ip('192.168.0.*')) // whitelist
// app.use(ip(['192.168.0.*', '8.8.8.[0-3]'])) // whitelist
// app.use(ip({
//   whitelist: ['192.168.0.*', '8.8.8.[0-3]'],
//   blacklist: ['144.144.*']
// }))

app.listen(3000)

blacklist handler

const app = new Koa()
app.use((ctx, next) => {
  ctx.request.ip = '127.0.0.1'
  return next()
})
app.use(ip({
  blacklist: ['127.0.0.*'],
  handler: async (ctx, next) => {
    ctx.status = 403
  }
}))

app.use((ctx, next) => {
  ctx.status = 200
})

app.listen(3000)

NB: If missing blacklist handler, default ctx.status = 403.

More examples see test.

Test

$ npm test (coverage 100%)

License

MIT

Package Sidebar

Install

npm i @ascension/koa-ip

Weekly Downloads

0

Version

2.1.4

License

MIT

Unpacked Size

8.78 kB

Total Files

7

Last publish

Collaborators

  • ascension