Skip to main content

SablierFlowBase

Git Source

Inherits: Adminable, ISablierFlowBase, ERC721

See the documentation in ISablierFlowBase.

State Variables

MAX_FEE

Retrieves the maximum fee that can be charged by the broker and the protocol, denoted as a fixed-point percentage where 1e18 is 100%.

This value is hard coded as a constant.

UD60x18 public constant override MAX_FEE = UD60x18.wrap(0.1e18);

aggregateBalance

Retrieves the sum of balances of all streams.

mapping(IERC20 token => uint256 amount) public override aggregateBalance;

nextStreamId

Counter for stream ids.

uint256 public override nextStreamId;

nftDescriptor

Contract that generates the non-fungible token URI.

IFlowNFTDescriptor public override nftDescriptor;

protocolFee

Protocol fee for the provided ERC-20 token, denoted as a fixed-point percentage where 1e18 is 100%.

mapping(IERC20 token => UD60x18 fee) public override protocolFee;

protocolRevenue

Protocol revenue accrued for the provided ERC-20 token, denoted in token's decimals.

mapping(IERC20 token => uint128 revenue) public override protocolRevenue;

_streams

Sablier Flow streams mapped by unsigned integers.

mapping(uint256 id => Flow.Stream stream) internal _streams;

Functions

constructor

Emits {TransferAdmin} event.

constructor(address initialAdmin, IFlowNFTDescriptor initialNFTDescriptor);

Parameters

NameTypeDescription
initialAdminaddressThe address of the initial contract admin.
initialNFTDescriptorIFlowNFTDescriptorThe address of the initial NFT descriptor.

notNull

Checks that streamId does not reference a null stream.

modifier notNull(uint256 streamId);

notPaused

Checks that streamId does not reference a paused stream.

modifier notPaused(uint256 streamId);

notVoided

Checks that streamId does not reference a voided stream.

modifier notVoided(uint256 streamId);

onlySender

Checks the msg.sender is the stream's sender.

modifier onlySender(uint256 streamId);

updateMetadata

Emits an ERC-4906 event to trigger an update of the NFT metadata.

modifier updateMetadata(uint256 streamId);

getBalance

Retrieves the balance of the stream, i.e. the total deposited amounts subtracted by the total withdrawn amounts, denoted in token's decimals.

Reverts if streamId references a null stream.

function getBalance(uint256 streamId) external view override notNull(streamId) returns (uint128 balance);

Parameters

NameTypeDescription
streamIduint256The stream ID for the query.

getRatePerSecond

Retrieves the rate per second of the stream, denoted as a fixed-point number where 1e18 is 1 token per second.

Reverts if streamId references a null stream.

function getRatePerSecond(uint256 streamId) external view override notNull(streamId) returns (UD21x18 ratePerSecond);

Parameters

NameTypeDescription
streamIduint256The ID of the stream to make the query for.

getRecipient

Retrieves the stream's recipient.

Reverts if streamId references a null stream.

function getRecipient(uint256 streamId) external view override notNull(streamId) returns (address recipient);

Parameters

NameTypeDescription
streamIduint256The stream ID for the query.

getSender

Retrieves the stream's sender.

Reverts if streamId references a null stream.

function getSender(uint256 streamId) external view override notNull(streamId) returns (address sender);

Parameters

NameTypeDescription
streamIduint256The stream ID for the query.

getSnapshotDebtScaled

Retrieves the snapshot debt of the stream, denoted as a fixed-point number where 1e18 is 1 token.

Reverts if streamId references a null stream.

function getSnapshotDebtScaled(uint256 streamId)
external
view
override
notNull(streamId)
returns (uint256 snapshotDebtScaled);

Parameters

NameTypeDescription
streamIduint256The stream ID for the query.

getSnapshotTime

Retrieves the snapshot time of the stream, which is a Unix timestamp.

Reverts if streamId references a null stream.

function getSnapshotTime(uint256 streamId) external view override notNull(streamId) returns (uint40 snapshotTime);

Parameters

NameTypeDescription
streamIduint256The ID of the stream to make the query for.

getStream

Retrieves the stream entity.

Reverts if streamId references a null stream.

function getStream(uint256 streamId) external view override notNull(streamId) returns (Flow.Stream memory stream);

Parameters

NameTypeDescription
streamIduint256The stream ID for the query.

getToken

Retrieves the token of the stream.

Reverts if streamId references a null stream.

function getToken(uint256 streamId) external view override notNull(streamId) returns (IERC20 token);

Parameters

NameTypeDescription
streamIduint256The ID of the stream to make the query for.

getTokenDecimals

Retrieves the token decimals of the stream.

Reverts if streamId references a null stream.

function getTokenDecimals(uint256 streamId) external view override notNull(streamId) returns (uint8 tokenDecimals);

Parameters

NameTypeDescription
streamIduint256The ID of the stream to make the query for.

isPaused

Returns whether a stream is paused.

Reverts if streamId references a null stream.

function isPaused(uint256 streamId) external view override notNull(streamId) returns (bool result);

Parameters

NameTypeDescription
streamIduint256The stream ID for the query.

isStream

Retrieves a flag indicating whether the stream exists.

Does not revert if streamId references a null stream.

function isStream(uint256 streamId) external view override returns (bool result);

Parameters

NameTypeDescription
streamIduint256The stream ID for the query.

isTransferable

Retrieves a flag indicating whether the stream NFT is transferable.

Reverts if streamId references a null stream.

function isTransferable(uint256 streamId) external view override notNull(streamId) returns (bool result);

Parameters

NameTypeDescription
streamIduint256The stream ID for the query.

isVoided

Retrieves a flag indicating whether the stream is voided.

Reverts if streamId references a null stream.

function isVoided(uint256 streamId) external view override notNull(streamId) returns (bool result);

Parameters

NameTypeDescription
streamIduint256The stream ID for the query.

tokenURI

See {IERC721Metadata-tokenURI}.

function tokenURI(uint256 streamId) public view override(IERC721Metadata, ERC721) returns (string memory uri);

collectProtocolRevenue

Collect the protocol revenue accrued for the provided ERC-20 token.

Emits {CollectProtocolRevenue} event. Requirements:

  • msg.sender must be the contract admin.
  • The accrued protocol revenue must be greater than zero.
function collectProtocolRevenue(IERC20 token, address to) external override onlyAdmin;

Parameters

NameTypeDescription
tokenIERC20The contract address of the ERC-20 token for which to claim protocol revenue.
toaddressThe address to send the protocol revenue.

recover

Recover the surplus amount of tokens.

Emits {Recover} event. Notes:

  • The surplus amount is defined as the difference between the total balance of the contract for the provided ERC-20 token and the sum of balances of all streams created using the same ERC-20 token. Requirements:
  • msg.sender must be the contract admin.
  • The surplus amount must be greater than zero.
function recover(IERC20 token, address to) external override onlyAdmin;

Parameters

NameTypeDescription
tokenIERC20The contract address of the ERC-20 token to recover for.
toaddressThe address to send the surplus amount.

setNFTDescriptor

Sets a new NFT descriptor contract, which produces the URI describing the Sablier stream NFTs.

Emits {SetNFTDescriptor} and {BatchMetadataUpdate} events. Notes:

  • Does not revert if the NFT descriptor is the same. Requirements:
  • msg.sender must be the contract admin.
function setNFTDescriptor(IFlowNFTDescriptor newNFTDescriptor) external override onlyAdmin;

Parameters

NameTypeDescription
newNFTDescriptorIFlowNFTDescriptorThe address of the new NFT descriptor contract.

setProtocolFee

Sets a new protocol fee that will be charged on all the withdrawals from streams created with the provided ERC-20 token.

Emits {SetProtocolFee} and {BatchMetadataUpdate} events. Notes:

  • Does not revert if the fee is the same.
  • It can be zero. Requirements:
  • msg.sender must be the contract admin.
  • newProtocolFee must not be greater than MAX_FEE.
function setProtocolFee(IERC20 token, UD60x18 newProtocolFee) external override onlyAdmin;

Parameters

NameTypeDescription
tokenIERC20The contract address of the ERC-20 token to update the fee for.
newProtocolFeeUD60x18The new protocol fee, denoted as a fixed-point percentage where 1e18 is 100%.

supportsInterface

See {IERC165-supportsInterface}.

function supportsInterface(bytes4 interfaceId) public view override(IERC165, ERC721) returns (bool);

_isCallerStreamRecipientOrApproved

Checks whether msg.sender is the stream's recipient or an approved third party.

function _isCallerStreamRecipientOrApproved(uint256 streamId) internal view returns (bool);

Parameters

NameTypeDescription
streamIduint256The stream ID for the query.

_update

Overrides the {ERC-721._update} function to check that the stream is transferable.

The transferable flag is ignored if the current owner is 0, as the update in this case is a mint and is allowed. Transfers to the zero address are not allowed, preventing accidental burns.

function _update(
address to,
uint256 streamId,
address auth
)
internal
override
updateMetadata(streamId)
returns (address);

Parameters

NameTypeDescription
toaddressThe address of the new recipient of the stream.
streamIduint256ID of the stream to update.
authaddressOptional parameter. If the value is not zero, the overridden implementation will check that auth is either the recipient of the stream, or an approved third party.

Returns

NameTypeDescription
<none>addressThe original recipient of the streamId before the update.