@libp2p/mplex
Version:
JavaScript implementation of https://github.com/libp2p/mplex
92 lines • 3.12 kB
TypeScript
/**
* @packageDocumentation
*
* This is a [simple stream multiplexer(https://docs.libp2p.io/concepts/multiplex/mplex/) that has been deprecated.
*
* Please use [@chainsafe/libp2p-yamux](https://www.npmjs.com/package/@chainsafe/libp2p-yamux) instead.
*
* @example
*
* ```TypeScript
* import { mplex } from '@libp2p/mplex'
* import { pipe } from 'it-pipe'
*
* const factory = mplex()
*
* const muxer = factory.createStreamMuxer(components, {
* onStream: stream => { // Receive a duplex stream from the remote
* // ...receive data from the remote and optionally send data back
* },
* onStreamEnd: stream => {
* // ...handle any tracking you may need of stream closures
* }
* })
*
* pipe(conn, muxer, conn) // conn is duplex connection to another peer
*
* const stream = muxer.newStream() // Create a new duplex stream to the remote
*
* // Use the duplex stream to send some data to the remote...
* pipe([1, 2, 3], stream)
* ```
*/
import { type MplexComponents } from './mplex.js';
import type { StreamMuxerFactory } from '@libp2p/interface';
export type { MplexComponents };
export interface MplexInit {
/**
* The maximum size of message that can be sent in one go in bytes.
* Messages larger than this will be split into multiple smaller
* messages. If we receive a message larger than this an error will
* be thrown and the connection closed.
*
* @default 1048576
*/
maxMsgSize?: number;
/**
* Constrains the size of the unprocessed message queue buffer.
* Before messages are deserialized, the raw bytes are buffered to ensure
* we have the complete message to deserialized. If the queue gets longer
* than this value an error will be thrown and the connection closed.
*
* @default 4194304
*/
maxUnprocessedMessageQueueSize?: number;
/**
* The maximum number of multiplexed streams that can be open at any
* one time. A request to open more than this will have a stream
* reset message sent immediately as a response for the newly opened
* stream id
*
* @default 1024
*/
maxInboundStreams?: number;
/**
* The maximum number of multiplexed streams that can be open at any
* one time. An attempt to open more than this will throw
*
* @default 1024
*/
maxOutboundStreams?: number;
/**
* Incoming stream messages are buffered until processed by the stream
* handler. If the buffer reaches this size in bytes the stream will
* be reset
*
* @default 4194304
*/
maxStreamBufferSize?: number;
/**
* When `maxInboundStreams` is hit, if the remote continues try to open
* more than this many new multiplexed streams per second the connection
* will be closed
*
* @default 5
*/
disconnectThreshold?: number;
}
/**
* @deprecated mplex is deprecated as it has no flow control. Please use yamux instead.
*/
export declare function mplex(init?: MplexInit): (components: MplexComponents) => StreamMuxerFactory;
//# sourceMappingURL=index.d.ts.map