Skip to content
This repository has been archived by the owner on Nov 28, 2018. It is now read-only.

Move default getClientIp to use proxy-addr, just like express does. #62

Open
pdefreitas opened this issue Aug 28, 2018 · 0 comments
Open

Comments

@pdefreitas
Copy link

pdefreitas commented Aug 28, 2018

express/express does offer application-wide settings to handle proxied request by setting 'trust proxy' option:

app.set('trust proxy', 'loopback') // specify a single subnet
app.set('trust proxy', 'loopback, 123.123.123.123') // specify a subnet and an address
app.set('trust proxy', 'loopback, linklocal, uniquelocal') // specify multiple subnets as CSV
app.set('trust proxy', ['loopback', 'linklocal', 'uniquelocal']) // specify multiple subnets as an array

The default value is false. Full documentation: http://expressjs.com/en/guide/behind-proxies.html

My suggestion is to integrate jshttp/proxy-addr into this project and drop the current solution of getClientIp, to work just like express works with proxied requests. People needing to control other headers could still append their getClientIp function into this module and enforce their desired headers. This way we could just append the same setting we use application-wide and it would work as expected out of the box, like it works in express.

I am implementing such a paradigm shift, in my fork of this project, if someone is interested in it as well take a look at it.

https://github.com/pdefreitas/express-ipfilter/

Thanks,
Pedro

Sign up for free to subscribe to this conversation on GitHub. Already have an account? Sign in.
Labels
None yet
Projects
None yet
Development

No branches or pull requests

1 participant