-
Notifications
You must be signed in to change notification settings - Fork 10
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
* feat: add transferable documentation feat: add parameters tables in Types section refactor: update core accordingly to 2.1 changes perf: overall improve hyperlinks fix: use release branch to cite from github * feat: add Merkle Streamer documentation in periphery feat: remove proxy documentation in periphery * feat: add LOCKUP * feat: include in sender in the withdraw multiple acces control * feat: remove sender hook guides * feat: add batch create streams section feat: remove proxy architecture section feat: add more snippets refactor: remove ERC20Spets snippet refactor: use constants in guides * refactor: update overview to not reference proxy system feat: add note in Flash Loans * feat: add a new page for older deployments feat: reference the old deployment page in the latest version * perf: improve wording in older deployments page * feat: reference examples in stream types section feat: remove outdated contracts and interfaces refactor: use yarn to install sablier Node.js packages chore: correct typos * feat: remove sender hook in protocol concepts * fix: correct reference hyperlinks perf: mention ISablierV2MerkleStreamer documentation chore: remove unnecessary word * feat: add airstream campaigns page in concepts feat: remove flashloans page in concepts feat: add diagram for airstream campaign * feat: add diagram image * chore: polish airstream campaign page * refactor: update sender/recipient permissions * refactor: update airstream concept page * perf: polish airstream concept page perf: improve airstream diagram refactore: remove png diagram from technical reference * refactor: update SablierV2NFTDescriptor contract * refactor: segregate v2.0 and v2.1 deployments feat: add v2.1 deployment addresses for Sepolia * feat: add v2.1 deployments * refactor: older deployments * feat: add Mainnet Periphery * fix: use correct hyperlink for aribtrum sepolia contracts * refactor: remove Avalanche addresses * refactor: update v2.1 deployment addresses * fix: correct comptroller address on arbitrum sepolia * refactor: move isWarm and isCold to SablierV2Lockup * refactor: use yarn instead of pnpm in local-environment * refactor: use new deployed addresses in guides * refactor: reference blob/release instead of tree/release * fix: correct arbitrum one dynamic address * refactor: remove proxy and permit paragraphs from frontend guide page --------- Co-authored-by: Paul Razvan Berg <[email protected]> Co-authored-by: maxdesalle <[email protected]>
- Loading branch information
1 parent
d2c1e90
commit ed052d2
Showing
80 changed files
with
2,093 additions
and
2,965 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,79 @@ | ||
--- | ||
id: "airstreams" | ||
sidebar_position: 7 | ||
title: "Airstreams" | ||
--- | ||
|
||
:::note | ||
|
||
Please refer to the [airdrop section](/concepts/use-cases#airdrops) of our use-cases page for an explanation regarding | ||
why streaming an airdrop makes sense. | ||
|
||
::: | ||
|
||
## Why Airstreams? | ||
|
||
The gist of Airstreams is that instead of airdropping the entirety of the tokens all at once, airdrop recipients receive | ||
a fraction of the tokens every second through a token stream. | ||
|
||
The beauty of it is that airdrop recipients are forced to think long-term and keep the project’s future as their first | ||
and foremost priority. They are forced to, because instead of receiving all the tokens at once, they receive them over | ||
time in the gorgeous Airstreams [interface](app.sablier.com/airstreams). | ||
|
||
:::info | ||
|
||
An airstream can have claim period of a few days, months, years or even no expiration, you get to chose. You could, for | ||
example, configure the airdrop of your new token to vest over years, but the recipients will receive the streaming | ||
tokens only if a claim is made in the interval set. | ||
|
||
::: | ||
|
||
Airstreams not only create the right incentives for token holders, but also prevents them from dumping their tokens on | ||
day one, as has been the case for many airdrops in the past. | ||
|
||
With Airstreams, airdrop recipients only receive a fraction of the tokens every second, only after they claim a stream | ||
and have to withdraw the tokens which are getting streamed. | ||
|
||
## How It Works | ||
|
||
Thanks to our battle-tested token streaming and distribution protocol, you can quickly create Airstreams for thousands | ||
of recipients in a few clicks using our interface. Recipients and their respective airdrop allocations can be added by | ||
uploading a simple CSV spreadsheet to the [interface](app.sablier.com/airstreams). | ||
|
||
Our spreadsheet feature is the perfect fit for airstreams: it allows you to upload a CSV file with tens of thousands of | ||
recipients and the interface will automatically create a new airstream for each of these recipients. | ||
|
||
Another great advantage, is that creating an Airstream campaign with thousands of recipients won't ruin you in terms of | ||
gas fees, on the contrary. When launching a campaign, a contract is deployed, and Airstreams are only created when they | ||
are claimed by the Airstream recipients. This is made possible by a system called _Merkle Distributor_, which is backed | ||
by a Merkle Tree, a data structure used for efficiently summarizing and verifying the integrity of large sets of data. | ||
|
||
:::note | ||
|
||
The contract that implements an Airstream Campaign is called `MerkleStreamer`. For those interested in the technical | ||
part, [click here](/contracts/v2/reference/periphery/contract.SablierV2MerkleStreamerLL). | ||
|
||
::: | ||
|
||
When you create an Airstream campaign, all you are really doing is deploying a contract that allows for the recipients | ||
you put in to prove that they are eligible, and create a stream if they are. That's all it is. | ||
|
||
Additionally, you don't have to immediately fund the Airstream contract. You can first create the contract, and at a | ||
later date fund it with the tokens to be streamed over. | ||
|
||
**This has three great implications:** | ||
|
||
- **Recipients pay for the gas fees themselves to create the stream**, when they claim (the claim action creates the | ||
stream). Creating a campaign with thousands of recipients would be incredibly costly if the campaign creator had to | ||
pay for all the gas fees. | ||
- **You keep full control over unclaimed Airstream token allocations**. If a recipient doesn't claim their Airstream, | ||
it's not created, and you remain in full control over that token allocation. | ||
- This is the case only if the campaign itself has an expiration date. If the campaign has no expiration date, the | ||
recipients can claim their Airstreams at any time in the future. | ||
- **You don't have to fund the campaign directly in order to deploy it**. You can deploy the campaign contract now, and | ||
fund it at a later date when you feel comfortable doing so. There is no rush. | ||
|
||
Once the Airstream campaign is launched, recipients who have claimed can withdraw the tokens which have already been | ||
streamed at any time using our interface. The deployment page, the last step when launching an Airstream campaign. | ||
|
||
data:image/s3,"s3://crabby-images/bf190/bf1907f9b4118d46cafe9bad3b1bc0a2ba040395" alt="" |
This file was deleted.
Oops, something went wrong.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.