Skip to content

⏳ Core smart contracts of the Sablier V2 token distribution protocol

License

Unknown, GPL-3.0 licenses found

Licenses found

Unknown
LICENSE.md
GPL-3.0
LICENSE-GPL.md
Notifications You must be signed in to change notification settings

sablier-labs/v2-core

Repository files navigation

Sablier V2 Core Github Actions Coverage Foundry

This repository contains the core smart contracts of the Sablier V2 Protocol. For higher-level logic, see the sablierhq/v2-periphery repository.

In-depth documentation is available at docs.sablier.com.

Background

Sablier is a smart contract protocol that enables trustless streaming of ERC-20 assets. In the context of Sablier, 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.

Install

Foundry

First, run the install step:

forge install sablierhq/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/sablierhq/v2-core"

Finally, add this to your remappings.txt file:

@sablier/v2-core/=lib/v2-core/src/
src/=src/

Hardhat

Sablier V2 Core is available as a Node.js package:

pnpm add @sablier/v2-core

Usage

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 {
    // ...
  }
}

Security

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.

Licensing

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/ and src/types may also be licensed under GPL-3.0-or-later (as indicated in their SPDX headers), see LICENSE-GPL.md.
  • Several files in src/abstracts/ and src/libraries/ may also be licensed under GPL-3.0-or-later (as indicated in their SPDX headers), see LICENSE-GPL.md.

Other Exceptions

  • All files in test/ remain unlicensed (as indicated in their SPDX headers).