
@solana/rpc-subscriptions
This package contains types that implement RPC subscriptions as required by the Solana RPC. Additionally, it incorporates some useful defaults that make working with subscriptions easier, more performant, and more reliable. It can be used standalone, but it is also exported as part of the Solana JavaScript SDK @solana/web3.js@rc
.
Functions
getChannelPoolingChannelCreator(createChannel, { maxSubscriptionsPerChannel, minChannels })
Given a channel creator, will return a new channel creator with the following behavior.
- When called, returns an
RpcSubscriptionsChannel
. Adds that channel to a pool. - When called again, creates and returns new
RpcSubscriptionChannels
up to the number specified by minChannels
. - When
minChannels
channels have been created, subsequent calls vend whichever existing channel from the pool has the fewest subscribers, or the next one in rotation in the event of a tie. - Once all channels carry the number of subscribers specified by the number
maxSubscriptionsPerChannel
, new channels in excess of minChannel
will be created, returned, and added to the pool. - A channel will be destroyed once all of its subscribers' abort signals fire.
getRpcSubscriptionsChannelWithJSONSerialization(channel)
Given an RpcSubscriptionsChannel
, will return a new channel that parses data published to the 'message'
channel as JSON, and JSON-stringifies messages sent via the send(message)
method.
getRpcSubscriptionsChannelWithAutoping(channel)
Given an RpcSubscriptionsChannel
, will return a new channel that sends a ping message to the inner channel if a message has not been sent or received in the last intervalMs
. In web browsers, this implementation sends no ping when the network is down, and sends a ping immediately upon the network coming back up.