SablierFlowBase
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
Name | Type | Description |
---|---|---|
initialAdmin | address | The address of the initial contract admin. |
initialNFTDescriptor | IFlowNFTDescriptor | The 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
Name | Type | Description |
---|---|---|
streamId | uint256 | The 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
Name | Type | Description |
---|---|---|
streamId | uint256 | The 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
Name | Type | Description |
---|---|---|
streamId | uint256 | The 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
Name | Type | Description |
---|---|---|
streamId | uint256 | The 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
Name | Type | Description |
---|---|---|
streamId | uint256 | The 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
Name | Type | Description |
---|---|---|
streamId | uint256 | The 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
Name | Type | Description |
---|---|---|
streamId | uint256 | The 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
Name | Type | Description |
---|---|---|
streamId | uint256 | The 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
Name | Type | Description |
---|---|---|
streamId | uint256 | The 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
Name | Type | Description |
---|---|---|
streamId | uint256 | The 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
Name | Type | Description |
---|---|---|
streamId | uint256 | The 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
Name | Type | Description |
---|---|---|
streamId | uint256 | The 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
Name | Type | Description |
---|---|---|
streamId | uint256 | The 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
Name | Type | Description |
---|---|---|
token | IERC20 | The contract address of the ERC-20 token for which to claim protocol revenue. |
to | address | The 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
Name | Type | Description |
---|---|---|
token | IERC20 | The contract address of the ERC-20 token to recover for. |
to | address | The 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
Name | Type | Description |
---|---|---|
newNFTDescriptor | IFlowNFTDescriptor | The 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 thanMAX_FEE
.
function setProtocolFee(IERC20 token, UD60x18 newProtocolFee) external override onlyAdmin;
Parameters
Name | Type | Description |
---|---|---|
token | IERC20 | The contract address of the ERC-20 token to update the fee for. |
newProtocolFee | UD60x18 | The 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
Name | Type | Description |
---|---|---|
streamId | uint256 | The 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
Name | Type | Description |
---|---|---|
to | address | The address of the new recipient of the stream. |
streamId | uint256 | ID of the stream to update. |
auth | address | Optional 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
Name | Type | Description |
---|---|---|
<none> | address | The original recipient of the streamId before the update. |