Compare commits

...

10 Commits

Author SHA1 Message Date
c7eac39012 chore: release version v0.7.4
License: MIT
Signed-off-by: Jacob Heun <jacobheun@gmail.com>
2019-01-04 09:27:29 -07:00
9d5f2a35ae chore: update contributors 2019-01-04 09:27:29 -07:00
7477c5c4a4 chore: update dependencies 2019-01-04 09:24:19 -07:00
ba275558bb chore: release version v0.7.3
License: MIT
Signed-off-by: Jacob Heun <jacobheun@gmail.com>
2018-11-26 14:38:08 +01:00
9b32d25de9 chore: update contributors 2018-11-26 14:38:07 +01:00
3c16dbe93e chore: upgrade dependencies 2018-11-26 14:26:27 +01:00
2dbcc4b126 chore: release version v0.7.2
License: MIT
Signed-off-by: Jacob Heun <jacobheun@gmail.com>
2018-07-23 14:16:02 +02:00
27481e7edc chore: update contributors 2018-07-23 14:16:01 +02:00
aa199362c2 fix: add the ability to verify expected peer data
chore: remove non jenkins ci
chore: remove appveyor
chore: update deps
fix: linting
2018-07-23 14:14:57 +02:00
3694e02eaa chore: add lead maintainer (#45)
* chore: add lead maintainer

License: MIT
Signed-off-by: Jacob Heun <jacobheun@gmail.com>

* Update package.json
2018-06-26 17:57:21 +02:00
9 changed files with 81 additions and 90 deletions

View File

@ -1,32 +0,0 @@
# Warning: This file is automatically synced from https://github.com/ipfs/ci-sync so if you want to change it, please change it there and ask someone to sync all repositories.
sudo: false
language: node_js
matrix:
include:
- node_js: 6
env: CXX=g++-4.8
- node_js: 8
env: CXX=g++-4.8
# - node_js: stable
# env: CXX=g++-4.8
script:
- npm run lint
- npm run test
- npm run coverage
before_script:
- export DISPLAY=:99.0
- sh -e /etc/init.d/xvfb start
after_success:
- npm run coverage-publish
addons:
firefox: 'latest'
apt:
sources:
- ubuntu-toolchain-r-test
packages:
- g++-4.8

View File

@ -1,3 +1,23 @@
<a name="0.7.4"></a>
## [0.7.4](https://github.com/libp2p/js-libp2p-identify/compare/v0.7.3...v0.7.4) (2019-01-04)
<a name="0.7.3"></a>
## [0.7.3](https://github.com/libp2p/js-libp2p-identify/compare/v0.7.2...v0.7.3) (2018-11-26)
<a name="0.7.2"></a>
## [0.7.2](https://github.com/libp2p/js-libp2p-identify/compare/v0.7.1...v0.7.2) (2018-07-23)
### Bug Fixes
* add the ability to verify expected peer data ([aa19936](https://github.com/libp2p/js-libp2p-identify/commit/aa19936))
<a name="0.7.1"></a>
## [0.7.1](https://github.com/libp2p/js-libp2p-identify/compare/v0.7.0...v0.7.1) (2018-04-30)

View File

@ -13,9 +13,13 @@
> libp2p Identify Protocol
## Lead Maintainer
[Jacob Heun](https://github.com/jacobheun)
## Description
Identify is a STUN protocol, used by libp2p-swarmin order to broadcast and learn about the `ip:port` pairs a specific peer is available through and to know when a new stream muxer is established, so a conn can be reused.
Identify is a STUN protocol, used by libp2p-swarm in order to broadcast and learn about the `ip:port` pairs a specific peer is available through and to know when a new stream muxer is established, so a conn can be reused.
## How does it work

View File

@ -1,29 +0,0 @@
# Warning: This file is automatically synced from https://github.com/ipfs/ci-sync so if you want to change it, please change it there and ask someone to sync all repositories.
version: "{build}"
environment:
matrix:
- nodejs_version: "6"
- nodejs_version: "8"
matrix:
fast_finish: true
install:
# Install Node.js
- ps: Install-Product node $env:nodejs_version
# Upgrade npm
- npm install -g npm
# Output our current versions for debugging
- node --version
- npm --version
# Install our package dependencies
- npm install
test_script:
- npm run test:node
build: off

View File

@ -1,15 +0,0 @@
# Warning: This file is automatically synced from https://github.com/ipfs/ci-sync so if you want to change it, please change it there and ask someone to sync all repositories.
machine:
node:
version: stable
dependencies:
pre:
- google-chrome --version
- curl -L -o google-chrome.deb https://dl.google.com/linux/direct/google-chrome-stable_current_amd64.deb
- sudo dpkg -i google-chrome.deb || true
- sudo apt-get update
- sudo apt-get install -f
- sudo apt-get install --only-upgrade lsb-base
- sudo dpkg -i google-chrome.deb
- google-chrome --version

View File

@ -1,7 +1,8 @@
{
"name": "libp2p-identify",
"version": "0.7.1",
"version": "0.7.4",
"description": "libp2p Identify Protocol",
"leadMaintainer": "Jacob Heun <jacobheun@gmail.com>",
"main": "src/index.js",
"scripts": {
"lint": "aegir lint",
@ -14,7 +15,7 @@
"release-major": "aegir release --type major",
"coverage": "aegir coverage"
},
"pre-commit": [
"pre-push": [
"lint",
"test"
],
@ -30,33 +31,34 @@
"IPFS",
"libp2p"
],
"author": "David Dias <daviddias@ipfs.io>",
"license": "MIT",
"bugs": {
"url": "https://github.com/libp2p/js-libp2p-identify/issues"
},
"homepage": "https://github.com/libp2p/js-libp2p-identify#readme",
"devDependencies": {
"aegir": "^13.1.0",
"chai": "^4.1.2",
"aegir": "^18.0.2",
"chai": "^4.2.0",
"dirty-chai": "^2.0.1",
"pre-commit": "^1.2.2",
"pull-pair": "^1.1.0"
},
"dependencies": {
"multiaddr": "^5.0.0",
"peer-id": "~0.10.7",
"peer-info": "~0.14.1",
"multiaddr": "^6.0.2",
"peer-id": "~0.12.1",
"peer-info": "~0.15.0",
"protons": "^1.0.1",
"pull-length-prefixed": "^1.3.0",
"pull-stream": "^3.6.7"
"pull-length-prefixed": "^1.3.1",
"pull-stream": "^3.6.9"
},
"contributors": [
"David Dias <daviddias.p@gmail.com>",
"Friedel Ziegelmayer <dignifiedquire@gmail.com>",
"Greenkeeper <support@greenkeeper.io>",
"Jacob Heun <jacobheun@gmail.com>",
"Jacob Heun <jake@andyet.net>",
"Maciej Krüger <mkg20001@gmail.com>",
"Richard Littauer <richard.littauer@gmail.com>",
"Vasco Santos <vasco.santos@moxy.studio>",
"ᴠɪᴄᴛᴏʀ ʙᴊᴇʟᴋʜᴏʟᴍ <victorbjelkholm@gmail.com>"
]
}

View File

@ -7,7 +7,13 @@ const lp = require('pull-length-prefixed')
const msg = require('./message')
module.exports = (conn, callback) => {
module.exports = (conn, expectedPeerInfo, callback) => {
if (typeof expectedPeerInfo === 'function') {
callback = expectedPeerInfo
expectedPeerInfo = null
console.warn('WARNING: no expected peer info was given, identify will not be able to verify peer integrity')
}
pull(
conn,
lp.decode(),
@ -30,6 +36,10 @@ module.exports = (conn, callback) => {
}
const peerInfo = new PeerInfo(id)
if (expectedPeerInfo && expectedPeerInfo.id.toB58String() !== id.toB58String()) {
return callback(new Error('invalid peer'))
}
try {
input.listenAddrs
.map(multiaddr)
@ -59,7 +69,7 @@ function getObservedAddrs (input) {
let addrs = input.observedAddr
if (!Array.isArray(input.observedAddr)) {
if (!Array.isArray(addrs)) {
addrs = [addrs]
}

View File

@ -4,3 +4,4 @@ exports = module.exports
exports.multicodec = '/ipfs/id/1.0.0'
exports.listener = require('./listener')
exports.dialer = require('./dialer')
exports.message = require('./message')

View File

@ -108,4 +108,34 @@ describe('identify.dialer', () => {
done()
})
})
it('should return an error with mismatched peerInfo data', (done) => {
const p = pair()
original.multiaddrs.add(multiaddr('/ip4/127.0.0.1/tcp/5002'))
const input = msg.encode({
protocolVersion: 'ipfs/0.1.0',
agentVersion: 'na',
publicKey: original.id.pubKey.bytes,
listenAddrs: [multiaddr('/ip4/127.0.0.1/tcp/5002').buffer],
observedAddr: multiaddr('/ip4/127.0.0.1/tcp/5001').buffer
})
PeerInfo.create((err, info) => {
if (err) {
return done(err)
}
pull(
pull.values([input]),
lp.encode(),
p[0]
)
identify.dialer(p[1], info, (err, peerInfo) => {
expect(err).to.exist()
expect(peerInfo).to.not.exist()
done()
})
})
})
})