mirror of
https://github.com/fluencelabs/js-libp2p
synced 2025-04-21 16:42:14 +00:00
* refactor: add js-libp2p-connection-manager to repo Co-authored-by: David Dias <daviddias.p@gmail.com> Co-authored-by: Jacob Heun <jacobheun@gmail.com> Co-authored-by: Pedro Teixeira <i@pgte.me> Co-authored-by: Vasco Santos <vasco.santos@ua.pt> * test(conn-mgr): only run in node * refactor: add js-libp2p-identify to repo Co-authored-by: David Dias <daviddias.p@gmail.com> Co-authored-by: Friedel Ziegelmayer <dignifiedquire@gmail.com> Co-authored-by: Hugo Dias <hugomrdias@gmail.com> Co-authored-by: Jacob Heun <jacobheun@gmail.com> Co-authored-by: Maciej Krüger <mkg20001@gmail.com> Co-authored-by: Richard Littauer <richard.littauer@gmail.com> Co-authored-by: Vasco Santos <vasco.santos@moxy.studio> Co-authored-by: Yusef Napora <yusef@protocol.ai> Co-authored-by: ᴠɪᴄᴛᴏʀ ʙᴊᴇʟᴋʜᴏʟᴍ <victorbjelkholm@gmail.com> * refactor: add libp2p-pnet to repo Co-authored-by: Jacob Heun <jacobheun@gmail.com> Co-authored-by: Vasco Santos <vasco.santos@moxy.studio> * refactor: add libp2p-ping to repo Co-authored-by: David Dias <daviddias.p@gmail.com> Co-authored-by: Francisco Baio Dias <xicombd@gmail.com> Co-authored-by: Friedel Ziegelmayer <dignifiedquire@gmail.com> Co-authored-by: Hugo Dias <mail@hugodias.me> Co-authored-by: Jacob Heun <jacobheun@gmail.com> Co-authored-by: João Antunes <j.goncalo.antunes@gmail.com> Co-authored-by: Richard Littauer <richard.littauer@gmail.com> Co-authored-by: Vasco Santos <vasco.santos@moxy.studio> Co-authored-by: Vasco Santos <vasco.santos@ua.pt> Co-authored-by: ᴠɪᴄᴛᴏʀ ʙᴊᴇʟᴋʜᴏʟᴍ <victorbjelkholm@gmail.com> * refactor: add libp2p-circuit to repo Co-authored-by: David Dias <daviddias.p@gmail.com> Co-authored-by: Dmitriy Ryajov <dryajov@gmail.com> Co-authored-by: Friedel Ziegelmayer <dignifiedquire@gmail.com> Co-authored-by: Hugo Dias <mail@hugodias.me> Co-authored-by: Jacob Heun <jacobheun@gmail.com> Co-authored-by: Maciej Krüger <mkg20001@gmail.com> Co-authored-by: Oli Evans <oli@tableflip.io> Co-authored-by: Pedro Teixeira <i@pgte.me> Co-authored-by: Vasco Santos <vasco.santos@ua.pt> Co-authored-by: Victor Bjelkholm <victorbjelkholm@gmail.com> Co-authored-by: Yusef Napora <yusef@napora.org> Co-authored-by: dirkmc <dirk@mccormick.cx> * test(switch): avoid using instanceof * chore(switch): update bignumber dep * refactor(circuit): clean up tests * refactor(switch): consolidate get peer utils * test(identify): do deep checks of addresses * test(identify): bump timeout for identify test * test(switch): tidy up limit dialer test * refactor(switch): remove redundant circuit tests * chore: add coverage script * refactor(circuit): consolidate get peer info * docs: reference original repositories in each sub readme * docs: fix comment * refactor: clean up sub package.json files and readmes
71 lines
2.0 KiB
JavaScript
71 lines
2.0 KiB
JavaScript
'use strict'
|
|
|
|
const pull = require('pull-stream')
|
|
const Connection = require('interface-connection').Connection
|
|
const assert = require('assert')
|
|
|
|
const Errors = require('./errors')
|
|
const State = require('./state')
|
|
const decodeV1PSK = require('./crypto').decodeV1PSK
|
|
const debug = require('debug')
|
|
const log = debug('libp2p:pnet')
|
|
log.err = debug('libp2p:pnet:err')
|
|
|
|
/**
|
|
* Takes a Private Shared Key (psk) and provides a `protect` method
|
|
* for wrapping existing connections in a private encryption stream
|
|
*/
|
|
class Protector {
|
|
/**
|
|
* @param {Buffer} keyBuffer The private shared key buffer
|
|
* @constructor
|
|
*/
|
|
constructor (keyBuffer) {
|
|
const decodedPSK = decodeV1PSK(keyBuffer)
|
|
this.psk = decodedPSK.psk
|
|
this.tag = decodedPSK.tag
|
|
}
|
|
|
|
/**
|
|
* Takes a given Connection and creates a privaste encryption stream
|
|
* between its two peers from the PSK the Protector instance was
|
|
* created with.
|
|
*
|
|
* @param {Connection} connection The connection to protect
|
|
* @param {function(Error)} callback
|
|
* @returns {Connection} The protected connection
|
|
*/
|
|
protect (connection, callback) {
|
|
assert(connection, Errors.NO_HANDSHAKE_CONNECTION)
|
|
|
|
const protectedConnection = new Connection(undefined, connection)
|
|
const state = new State(this.psk)
|
|
|
|
log('protecting the connection')
|
|
|
|
// Run the connection through an encryptor
|
|
pull(
|
|
connection,
|
|
state.encrypt((err, encryptedOuterStream) => {
|
|
if (err) {
|
|
log.err('There was an error attempting to protect the connection', err)
|
|
return callback(err)
|
|
}
|
|
|
|
connection.getPeerInfo(() => {
|
|
protectedConnection.setInnerConn(new Connection(encryptedOuterStream, connection))
|
|
log('the connection has been successfully wrapped by the protector')
|
|
callback()
|
|
})
|
|
}),
|
|
connection
|
|
)
|
|
|
|
return protectedConnection
|
|
}
|
|
}
|
|
|
|
module.exports = Protector
|
|
module.exports.errors = Errors
|
|
module.exports.generate = require('./key-generator')
|