feat: is multiaddr private and loopback (#10)

This commit is contained in:
Vasco Santos 2020-10-07 17:02:08 +02:00 committed by GitHub
parent 03e272cd24
commit d7fa562d91
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
7 changed files with 210 additions and 4 deletions

View File

@ -38,6 +38,60 @@ const ipAndPortToMultiaddr = require('libp2p-utils/src/ip-port-to-multiaddr')
const ma = ipAndPortToMultiaddr('127.0.0.1', 9000)
```
## API
### multiaddr `.isLoopback(ma)`
Check if a given multiaddr is a loopback address.
#### Parameters
| Name | Type | Description |
|------|------|-------------|
| ma | `Multiaddr` | multiaddr to verify |
#### Returns
| Type | Description |
|------|-------------|
| `boolean` | returns true if multiaddr is a loopback address, false otherwise |
#### Example
```js
const multiaddr = require('multiaddr')
const isLoopback = require('libp2p-utils/src/multiaddr/is-loopback')
const ma = multiaddr('/ip4/127.0.0.1/tcp/1000')
isMultiaddrLoopbackAddrs = isLoopback(ma)
```
### multiaddr `.isPrivate(ma)`
Check if a given multiaddr has a private address.
#### Parameters
| Name | Type | Description |
|------|------|-------------|
| ma | `Multiaddr` | multiaddr to verify |
#### Returns
| Type | Description |
|------|-------------|
| `boolean` | returns true if multiaddr is a private address, false otherwise |
#### Example
```js
const multiaddr = require('multiaddr')
const isPrivate = require('libp2p-utils/src/multiaddr/is-private')
const ma = multiaddr('/ip4/10.0.0.1/tcp/1000')
isMultiaddrPrivateAddrs = isPrivate(ma)
```
## Contribute
Contributions welcome. Please check out [the issues](https://github.com/libp2p/js-libp2p-utils/issues).

View File

@ -29,17 +29,19 @@
},
"homepage": "https://github.com/libp2p/js-libp2p-utils#readme",
"devDependencies": {
"aegir": "^25.0.0",
"aegir": "^27.0.0",
"it-pair": "^1.0.0",
"it-pipe": "^1.1.0",
"streaming-iterables": "^5.0.2"
"streaming-iterables": "^5.0.3"
},
"dependencies": {
"abortable-iterator": "^3.0.0",
"debug": "^4.1.1",
"debug": "^4.2.0",
"err-code": "^2.0.3",
"ip-address": "^6.1.0",
"multiaddr": "^8.0.0"
"is-loopback-addr": "^1.0.0",
"multiaddr": "^8.0.0",
"private-ip": "^1.0.5"
},
"contributors": [
"Vasco Santos <vasco.santos@moxy.studio>",

View File

@ -3,6 +3,7 @@
/**
* Verify if two arrays of non primitive types with the "equals" function are equal.
* Compatible with multiaddr, peer-id and Buffer.
*
* @param {Array<*>} a
* @param {Array<*>} b
* @returns {boolean}

View File

@ -0,0 +1,17 @@
'use strict'
const isLoopbackAddr = require('is-loopback-addr')
/**
* Check if a given multiaddr is a loopback address.
*
* @param {Multiaddr} ma
* @returns {boolean}
*/
function isLoopback (ma) {
const { address } = ma.nodeAddress()
return isLoopbackAddr(address)
}
module.exports = isLoopback

View File

@ -0,0 +1,17 @@
'use strict'
const isIpPrivate = require('private-ip')
/**
* Check if a given multiaddr has a private address.
*
* @param {Multiaddr} ma
* @returns {boolean}
*/
function isPrivate (ma) {
const { address } = ma.nodeAddress()
return isIpPrivate(address)
}
module.exports = isPrivate

View File

@ -0,0 +1,57 @@
/* eslint-env mocha */
'use strict'
const { expect } = require('aegir/utils/chai')
const multiaddr = require('multiaddr')
const isLoopback = require('../../src/multiaddr/is-loopback')
describe('multiaddr isLoopback', () => {
it('identifies loopback ip4 multiaddrs', () => {
[
multiaddr('/ip4/127.0.0.1/tcp/1000'),
multiaddr('/ip4/127.0.1.1/tcp/1000'),
multiaddr('/ip4/127.1.1.1/tcp/1000'),
multiaddr('/ip4/127.255.255.255/tcp/1000')
].forEach(ma => {
expect(isLoopback(ma)).to.eql(true)
})
})
it('identifies non loopback ip4 multiaddrs', () => {
[
multiaddr('/ip4/101.0.26.90/tcp/1000'),
multiaddr('/ip4/10.0.0.1/tcp/1000'),
multiaddr('/ip4/192.168.0.1/tcp/1000'),
multiaddr('/ip4/172.16.0.1/tcp/1000')
].forEach(ma => {
expect(isLoopback(ma)).to.eql(false)
})
})
it('identifies loopback ip6 multiaddrs', () => {
[
multiaddr('/ip6/::1/tcp/1000')
].forEach(ma => {
expect(isLoopback(ma)).to.eql(true)
})
})
it('identifies non loopback ip6 multiaddrs', () => {
[
multiaddr('/ip6/2001:8a0:7ac5:4201:3ac9:86ff:fe31:7095/tcp/1000'),
multiaddr('/ip6/::/tcp/1000')
].forEach(ma => {
expect(isLoopback(ma)).to.eql(false)
})
})
it('identifies other multiaddrs as not loopback addresses', () => {
[
multiaddr('/dns4/wss0.bootstrap.libp2p.io/tcp/443'),
multiaddr('/dns6/wss0.bootstrap.libp2p.io/tcp/443')
].forEach(ma => {
expect(isLoopback(ma)).to.eql(false)
})
})
})

View File

@ -0,0 +1,58 @@
/* eslint-env mocha */
'use strict'
const { expect } = require('aegir/utils/chai')
const multiaddr = require('multiaddr')
const isPrivate = require('../../src/multiaddr/is-private')
describe('multiaddr isPrivate', () => {
it('identifies private ip4 multiaddrs', () => {
[
multiaddr('/ip4/127.0.0.1/tcp/1000'),
multiaddr('/ip4/10.0.0.1/tcp/1000'),
multiaddr('/ip4/192.168.0.1/tcp/1000'),
multiaddr('/ip4/172.16.0.1/tcp/1000')
].forEach(ma => {
expect(isPrivate(ma)).to.eql(true)
})
})
it('identifies public ip4 multiaddrs', () => {
[
multiaddr('/ip4/101.0.26.90/tcp/1000'),
multiaddr('/ip4/40.1.20.9/tcp/1000'),
multiaddr('/ip4/92.168.0.1/tcp/1000'),
multiaddr('/ip4/2.16.0.1/tcp/1000')
].forEach(ma => {
expect(isPrivate(ma)).to.eql(false)
})
})
it('identifies private ip6 multiaddrs', () => {
[
multiaddr('/ip6/fd52:8342:fc46:6c91:3ac9:86ff:fe31:7095/tcp/1000'),
multiaddr('/ip6/fd52:8342:fc46:6c91:3ac9:86ff:fe31:1/tcp/1000')
].forEach(ma => {
expect(isPrivate(ma)).to.eql(true)
})
})
it('identifies public ip6 multiaddrs', () => {
[
multiaddr('/ip6/2001:8a0:7ac5:4201:3ac9:86ff:fe31:7095/tcp/1000'),
multiaddr('/ip6/2000:8a0:7ac5:4201:3ac9:86ff:fe31:7095/tcp/1000')
].forEach(ma => {
expect(isPrivate(ma)).to.eql(false)
})
})
it('identifies other multiaddrs as not private addresses', () => {
[
multiaddr('/dns4/wss0.bootstrap.libp2p.io/tcp/443'),
multiaddr('/dns6/wss0.bootstrap.libp2p.io/tcp/443')
].forEach(ma => {
expect(isPrivate(ma)).to.eql(false)
})
})
})