feat(p2p): protocol check and support responce p2p connection

This commit is contained in:
Alexey Kasyanchuk
2018-03-03 01:43:56 +03:00
parent 2595d389b8
commit 2779bfe49d

View File

@ -13,7 +13,9 @@ class p2p {
this.send = send
this.tcpServer = net.createServer();
this.tcpServer.on('connection', (socket) => {
//console.log('p2p server connection', socket.remoteAddress)
// try to setup back connection
this.add(socket.address())
socket = new JsonSocket(socket);
socket.on('error', (err) => {})
socket.on('message', (message) => {
@ -28,6 +30,15 @@ class p2p {
}
});
})
// check protocol
this.on('protocol', (data, callback) => {
if(!data || data.protocol != 'rats')
return
callback({
protocol: 'rats'
})
})
}
listen() {
@ -64,13 +75,9 @@ class p2p {
connect(address)
{
this.peers.push(address)
const socket = new JsonSocket(new net.Socket()); //Decorate a standard net.Socket with JsonSocket
const rawSocket = new net.Socket();
const socket = new JsonSocket(rawSocket); //Decorate a standard net.Socket with JsonSocket
socket.on('connect', () => { //Don't send until we're connected
// add to peers
this.size++;
this.send('peer', this.size)
console.log('new peer', address)
const callbacks = {}
socket.on('message', (message) => {
if(message.id && callbacks[message.id])
@ -90,7 +97,21 @@ class p2p {
data
});
}
address.emit = emit
// check protocol
const protocolTimeout = setTimeout(() => rawSocket.destroy(), 7000)
emit('protocol', {protocol: 'rats'}, (data) => {
if(!data || data.protocol != 'rats')
return
// success
clearTimeout(protocolTimeout)
// add to peers
address.emit = emit
this.size++;
this.send('peer', this.size)
console.log('new peer', address)
})
});
socket.on('close', () => {