ISablierV2LockupLinear
Inherits: ISablierV2Lockup
Creates and manages lockup streams with a linear streaming function.
Functions
getCliffTime
Retrieves the stream's cliff time, which is a Unix timestamp.
Reverts if streamId references a null stream.
function getCliffTime(uint256 streamId) external view returns (uint40 cliffTime);
Parameters
| Name | Type | Description |
|---|---|---|
streamId | uint256 | The stream id for the query. |
getRange
Retrieves the range of the stream, a struct containing (i) the stream's start time, (ii) cliff time, and (iii) end time, all as Unix timestamps.
Reverts if streamId references a null stream.
function getRange(uint256 streamId) external view returns (LockupLinear.Range memory range);
Parameters
| Name | Type | Description |
|---|---|---|
streamId | uint256 | The stream id for the query. |
getStream
Retrieves the stream entity.
Reverts if streamId references a null stream.
function getStream(uint256 streamId) external view returns (LockupLinear.Stream memory stream);
Parameters
| Name | Type | Description |
|---|---|---|
streamId | uint256 | The stream id for the query. |
streamedAmountOf
Calculates the amount streamed to the recipient, denoted in units of the asset's decimals. When the stream is warm, the streaming function is:
Where:
- is the elapsed time divided by the stream's total duration.
- is the deposited amount.
- is the cliff amount. Upon cancellation of the stream, the amount streamed is calculated as the difference between the deposited amount and the refunded amount. Ultimately, when the stream becomes depleted, the streamed amount is equivalent to the total amount withdrawn.
Reverts if streamId references a null stream.
function streamedAmountOf(uint256 streamId) external view returns (uint128 streamedAmount);
Parameters
| Name | Type | Description |
|---|---|---|
streamId | uint256 | The stream id for the query. |
createWithDurations
Creates a stream by setting the start time to block.timestamp, and the end time to the sum of block.timestamp and
params.durations.total. The stream is funded by msg.sender` and is wrapped in an ERC-721 NFT.
Emits a {CreateLockupLinearStream} and a {Transfer} event. Requirements:
- All requirements in {createWithRange} must be met for the calculated parameters.
function createWithDurations(LockupLinear.CreateWithDurations calldata params) external returns (uint256 streamId);
Parameters
| Name | Type | Description |
|---|---|---|
params | LockupLinear.CreateWithDurations | Struct encapsulating the function parameters, which are documented in {DataTypes}. |
Returns
| Name | Type | Description |
|---|---|---|
streamId | uint256 | The id of the newly created stream. |
createWithRange
Creates a stream with the provided start time and end time as the range. The stream is funded by msg.sender and is
wrapped in an ERC-721 NFT.
Emits a {CreateLockupLinearStream} and a {Transfer} event. Notes:
- As long as the times are ordered, it is not an error for the start or the cliff time to be in the past. Requirements:
- Must not be delegate called.
params.totalAmountmust be greater than zero.- If set,
params.broker.feemust not be greater thanMAX_FEE. params.range.startmust be less than or equal toparams.range.cliff.params.range.cliffmust be less thanparams.range.end.params.range.endmust be in the future.params.recipientmust not be the zero address.msg.sendermust have allowed this contract to spend at leastparams.totalAmountassets.
function createWithRange(LockupLinear.CreateWithRange calldata params) external returns (uint256 streamId);
Parameters
| Name | Type | Description |
|---|---|---|
params | LockupLinear.CreateWithRange | Struct encapsulating the function parameters, which are documented in {DataTypes}. |
Returns
| Name | Type | Description |
|---|---|---|
streamId | uint256 | The id of the newly created stream. |
Events
CreateLockupLinearStream
Emitted when a stream is created.
event CreateLockupLinearStream(
uint256 streamId,
address indexed funder,
address indexed sender,
address indexed recipient,
Lockup.CreateAmounts amounts,
IERC20 asset,
bool cancelable,
LockupLinear.Range range,
address broker
);