This repository contains the core smart contracts of the Sablier V2 Protocol. For higher-level logic, see the sablier-labs/v2-periphery repository.
In-depth documentation is available at docs.sablier.com.
Sablier is a smart contract protocol that enables trustless streaming of ERC-20 assets. In this context, streaming means the ability to make payments by the second.
The protocol features a type of stream called a lockup stream, in which the sender locks up a specified amount of ERC-20 assets in a contract. Subsequently, the contract progressively allocates these assets to the designated recipient, who can access them as they become available. The streaming rate is influenced by various factors, including the start and end times, as well as the total amount of assets locked up.
First, run the install step:
forge install sablier-labs/v2-core
Your .gitmodules
file should now contain the following entry:
[submodule "lib/v2-core"]
branch = "main"
path = "lib/v2-core"
url = "https://github.com/sablier-labs/v2-core"
Finally, add this to your remappings.txt
file:
@sablier/v2-core/=lib/v2-core/src/
Sablier V2 Core is available as a Node.js package:
pnpm add @sablier/v2-core
This is just a glimpse of Sablier V2 Core. For more guides and examples, see the documentation.
import { ISablierV2LockupLinear } from "@sablier/v2-core/interfaces/ISablierV2LockupLinear.sol";
contract MyContract {
ISablierV2LockupLinear sablier;
function buildSomethingWithSablier() external {
// ...
}
}
See the Deployments wiki for guidance on the deployment scripts. The list of all deployments addresses can be found here.
It is worth noting that not every file in this repository is included in each deployment. For instance, the
SablierV2FlashLoan
abstract is not inherited by any contract on the main
branch, but we have kept it in version
control because we may decide to use it in the future.
Please refer to the SECURITY policy for any security-related concerns. This repository is subject to a bug bounty program per the terms outlined in the aforementioned policy.
The primary license for Sablier V2 Core is the Business Source License 1.1 (BUSL-1.1
), see
LICENSE.md
. However, some files are dual-licensed under GPL-3.0-or-later
:
- All files in
src/interfaces/
andsrc/types
may also be licensed underGPL-3.0-or-later
(as indicated in their SPDX headers), seeLICENSE-GPL.md
. - Several files in
src/abstracts/
,src/libraries/
,script
, andtest
may also be licensed underGPL-3.0-or-later
(as indicated in their SPDX headers), seeLICENSE-GPL.md
. - All other files in
test/
remain unlicensed (as indicated in their SPDX headers).