mirror of
https://github.com/fluencelabs/js-libp2p-utils
synced 2025-05-28 05:51:36 +00:00
61 lines
1.5 KiB
JavaScript
61 lines
1.5 KiB
JavaScript
'use strict'
|
|
|
|
const abortable = require('abortable-iterator')
|
|
const log = require('debug')('libp2p:stream:converter')
|
|
|
|
/**
|
|
* Convert a duplex iterable into a MultiaddrConnection.
|
|
* https://github.com/libp2p/interface-transport#multiaddrconnection
|
|
*
|
|
* @param {object} streamProperties
|
|
* @param {DuplexStream} streamProperties.stream
|
|
* @param {Multiaddr} streamProperties.remoteAddr
|
|
* @param {Multiaddr} streamProperties.localAddr
|
|
* @param {object} [options]
|
|
* @param {AbortSignal} [options.signal]
|
|
*/
|
|
function streamToMaConnection ({ stream, remoteAddr, localAddr }, options = {}) {
|
|
const { sink, source } = stream
|
|
const maConn = {
|
|
async sink (source) {
|
|
if (options.signal) {
|
|
source = abortable(source, options.signal)
|
|
}
|
|
|
|
try {
|
|
await sink(source)
|
|
} catch (err) {
|
|
// If aborted we can safely ignore
|
|
if (err.type !== 'aborted') {
|
|
// If the source errored the socket will already have been destroyed by
|
|
// toIterable.duplex(). If the socket errored it will already be
|
|
// destroyed. There's nothing to do here except log the error & return.
|
|
log(err)
|
|
}
|
|
}
|
|
close()
|
|
},
|
|
|
|
source: options.signal ? abortable(source, options.signal) : source,
|
|
conn: stream,
|
|
localAddr,
|
|
remoteAddr,
|
|
timeline: { open: Date.now() },
|
|
|
|
close () {
|
|
sink([])
|
|
close()
|
|
}
|
|
}
|
|
|
|
function close () {
|
|
if (!maConn.timeline.close) {
|
|
maConn.timeline.close = Date.now()
|
|
}
|
|
}
|
|
|
|
return maConn
|
|
}
|
|
|
|
module.exports = streamToMaConnection
|