
Security News
Vite+ Joins the Push to Consolidate JavaScript Tooling
Evan You announces Vite+, a commercial, Rust-powered toolchain built on the Vite ecosystem to unify JavaScript development and fund open source.
@sablier/lockup
Advanced tools
In-depth documentation is available at docs.sablier.com.
Sablier Lockup is a token distribution protocol that enables onchain vesting and airdrops. Our flagship model is the linear stream, which distributes tokens on a continuous, by-the-second basis.
The way it works is that the sender of a payment stream first deposits a specific amount of ERC-20 tokens in a contract. Then, the contract progressively allocates the funds to the recipient, who can access them as they become available over time. The payment rate is influenced by various factors, including the start and end times, as well as the total amount of tokens deposited.
This is the recommended approach.
Install Lockup using your favorite package manager, e.g., with Bun:
bun add @sablier/lockup
Then, if you are using Foundry, you need to add these to your remappings.txt
file:
@sablier/lockup/=node_modules/@sablier/lockup/
@openzeppelin/contracts/=node_modules/@openzeppelin/contracts/
@prb/math/=node_modules/@prb/math/
This installation method is not recommended, but it is available for those who prefer it.
First, install the submodule using Forge:
forge install --no-commit sablier-labs/lockup
Second, install the project's dependencies:
forge install --no-commit OpenZeppelin/openzeppelin-contracts@v5.0.2 PaulRBerg/prb-math@v4.1.0
Finally, add these to your remappings.txt
file:
@sablier/lockup/=lib/lockup/
@openzeppelin/contracts/=lib/openzeppelin-contracts/contracts/
@prb/math/=lib/prb-math/
This is just a glimpse of Sablier Lockup. For more guides and examples, see the documentation.
import { ISablierLockup } from "@sablier/lockup/src/interfaces/ISablierLockup.sol";
contract MyContract {
ISablierLockup lockup;
function buildSomethingWithSablier() external {
// ...
}
}
Lockup uses a singleton-style architecture, where all streams are managed in the SablierLockup
contract. That is,
Sablier does not deploy a new contract for each distribution model or stream. It bundles all streams into a single
contract, which is more gas-efficient and easier to maintain.
For more information, see the Technical Overview in our docs, as well as these diagrams.
You may notice that some test files are accompanied by .tree
files. This is called the Branching Tree Technique, and
it is explained in depth here.
The list of all deployment addresses can be found here. For guidance on the deploy scripts, see the Deployments wiki.
The codebase has undergone rigorous audits by leading security experts from Cantina, as well as independent auditors. For a comprehensive list of all audits conducted, please click here.
For any security-related concerns, please refer to the SECURITY policy. This repository is subject to a bug bounty program per the terms outlined in the aforementioned policy.
Feel free to dive in! Open an issue, start a discussion or submit a PR. For any informal concerns or feedback, please join our Discord server.
For guidance on how to create PRs, see the CONTRIBUTING guide.
The primary license for Sablier Lockup is the Business Source License 1.1 (BUSL-1.1
), see
LICENSE.md
. However, there are exceptions:
src/interfaces/
and src/types
are licensed under GPL-3.0-or-later
, see
LICENSE-GPL.md
.src
, script
, and tests
are licensed under GPL-3.0-or-later
, see
LICENSE-GPL.md
.tests/
remain unlicensed (as indicated in their SPDX headers).FAQs
EVM smart contracts of the Sablier Lockup token distribution protocol
The npm package @sablier/lockup receives a total of 124 weekly downloads. As such, @sablier/lockup popularity was classified as not popular.
We found that @sablier/lockup demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 5 open source maintainers collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
Evan You announces Vite+, a commercial, Rust-powered toolchain built on the Vite ecosystem to unify JavaScript development and fund open source.
Security News
Ruby Central’s incident report on the RubyGems.org access dispute sparks backlash from former maintainers and renewed debate over project governance.
Research
/Security News
Socket researchers uncover how threat actors weaponize Discord across the npm, PyPI, and RubyGems ecosystems to exfiltrate sensitive data.