This repository has been archived by the owner on Feb 26, 2021. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 12
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
feat(spdy): migration to pull-streams
- Loading branch information
1 parent
830d170
commit fed8198
Showing
14 changed files
with
397 additions
and
287 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,26 +1,24 @@ | ||
'use strict' | ||
|
||
const tcp = require('net') | ||
const pull = require('pull-stream') | ||
const toPull = require('stream-to-pull-stream') | ||
const libp2pSPDY = require('../src') | ||
|
||
const socket = tcp.connect(9999) | ||
const muxer = libp2pSPDY(socket, false) | ||
const muxer = libp2pSPDY.dial(toPull(socket)) | ||
|
||
muxer.on('stream', (stream) => { | ||
console.log('-> got new muxed stream') | ||
stream.on('data', (data) => { | ||
console.log('do I ever get data?', data) | ||
}) | ||
stream.pipe(stream) | ||
pull(stream, pull.log, stream) | ||
}) | ||
|
||
console.log('-> opening a stream from my side') | ||
muxer.newStream((err, stream) => { | ||
if (err) { | ||
throw err | ||
} | ||
|
||
console.log('-> opened the stream') | ||
stream.write('hey, how is it going. I am dialer') | ||
stream.end() | ||
const stream = muxer.newStream((err) => { | ||
if (err) throw err | ||
}) | ||
|
||
pull( | ||
pull.values(['hey, how is it going. I am dialer']), | ||
stream | ||
) |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,70 +1,31 @@ | ||
'use strict' | ||
|
||
const spdy = require('spdy-transport') | ||
const Connection = require('interface-connection').Connection | ||
const EE = require('events').EventEmitter | ||
const toStream = require('pull-stream-to-stream') | ||
|
||
exports = module.exports = function (conn, isListener) { | ||
const muxer = spdy.connection.create(conn, { | ||
protocol: 'spdy', | ||
isServer: isListener | ||
}) | ||
|
||
const proxyMuxer = new EE() | ||
|
||
muxer.start(3.1) | ||
|
||
// method added to enable pure stream muxer feeling | ||
proxyMuxer.newStream = (callback) => { | ||
if (!callback) { | ||
callback = noop | ||
} | ||
|
||
const muxedConn = new Connection(muxer.request({ | ||
method: 'POST', | ||
path: '/', | ||
headers: {} | ||
}, callback)) | ||
const Muxer = require('./muxer') | ||
const SPDY_CODEC = require('./spdy-codec') | ||
|
||
if (conn.getObservedAddrs) { | ||
muxedConn.getObservedAddrs = conn.getObservedAddrs.bind(conn) | ||
muxedConn.getPeerInfo = conn.getPeerInfo.bind(conn) | ||
muxedConn.setPeerInfo = conn.setPeerInfo.bind(conn) | ||
} | ||
function create (rawConn, isListener) { | ||
const conn = toStream(rawConn) | ||
// Let it flow, let it flooow | ||
conn.resume() | ||
|
||
return muxedConn | ||
} | ||
|
||
// The rest of the API comes by default with SPDY | ||
muxer.on('close', () => { | ||
proxyMuxer.emit('close') | ||
}) | ||
|
||
muxer.on('error', (err) => { | ||
proxyMuxer.emit('error', err) | ||
conn.on('end', () => { | ||
// Cleanup and destroy the connection when it ends | ||
// as the converted stream doesn't emit 'close' | ||
// but .destroy will trigger a 'close' event. | ||
conn.destroy() | ||
}) | ||
|
||
proxyMuxer.end = (cb) => { | ||
muxer.end(cb) | ||
} | ||
|
||
// needed by other spdy impl that need the response headers | ||
// in order to confirm the stream can be open | ||
muxer.on('stream', (stream) => { | ||
stream.respond(200, {}) | ||
const muxedConn = new Connection(stream) | ||
if (conn.getObservedAddrs) { | ||
muxedConn.getObservedAddrs = conn.getObservedAddrs.bind(conn) | ||
muxedConn.getPeerInfo = conn.getPeerInfo.bind(conn) | ||
muxedConn.setPeerInfo = conn.setPeerInfo.bind(conn) | ||
} | ||
proxyMuxer.emit('stream', muxedConn) | ||
const spdyMuxer = spdy.connection.create(conn, { | ||
protocol: 'spdy', | ||
isServer: isListener | ||
}) | ||
|
||
proxyMuxer.multicodec = exports.multicodec | ||
return proxyMuxer | ||
return new Muxer(rawConn, spdyMuxer) | ||
} | ||
|
||
exports.multicodec = '/spdy/3.1.0' | ||
|
||
function noop () {} | ||
exports.multicodec = SPDY_CODEC | ||
exports.dial = (conn) => create(conn, false) | ||
exports.listen = (conn) => create(conn, true) |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,61 @@ | ||
'use strict' | ||
|
||
const EventEmitter = require('events').EventEmitter | ||
const noop = require('lodash.noop') | ||
const Connection = require('interface-connection').Connection | ||
const toPull = require('stream-to-pull-stream') | ||
|
||
const SPDY_CODEC = require('./spdy-codec') | ||
|
||
module.exports = class Muxer extends EventEmitter { | ||
constructor (conn, spdy) { | ||
super() | ||
|
||
this.spdy = spdy | ||
this.conn = conn | ||
this.multicodec = SPDY_CODEC | ||
|
||
spdy.start(3.1) | ||
|
||
// The rest of the API comes by default with SPDY | ||
spdy.on('close', () => { | ||
this.emit('close') | ||
}) | ||
|
||
spdy.on('error', (err) => { | ||
this.emit('error', err) | ||
}) | ||
|
||
// needed by other spdy impl that need the response headers | ||
// in order to confirm the stream can be open | ||
spdy.on('stream', (stream) => { | ||
stream.respond(200, {}) | ||
const muxedConn = new Connection(toPull.duplex(stream), this.conn) | ||
this.emit('stream', muxedConn) | ||
}) | ||
} | ||
|
||
// method added to enable pure stream muxer feeling | ||
newStream (callback) { | ||
if (!callback) { | ||
callback = noop | ||
} | ||
const conn = new Connection(null, this.conn) | ||
|
||
this.spdy.request({ | ||
method: 'POST', | ||
path: '/', | ||
headers: {} | ||
}, (err, stream) => { | ||
conn.setInnerConn(toPull.duplex(stream), this.conn) | ||
|
||
callback(err, conn) | ||
}) | ||
|
||
return conn | ||
} | ||
|
||
end (cb) { | ||
this.spdy.end(cb) | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,3 @@ | ||
'use strict' | ||
|
||
module.exports = '/spdy/3.1.0' |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file was deleted.
Oops, something went wrong.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,16 @@ | ||
/* eslint-env mocha */ | ||
'use strict' | ||
|
||
const tests = require('interface-stream-muxer') | ||
const spdy = require('../src') | ||
|
||
describe('compliance', () => { | ||
tests({ | ||
setup (cb) { | ||
cb(null, spdy) | ||
}, | ||
teardown (cb) { | ||
cb() | ||
} | ||
}) | ||
}) |
Oops, something went wrong.