Superfluid & Gelato for Stream Scheduling
🚀 Learn how to automate Start/Stop Superfluid streams in Super Apps
One of the most extraordinary things about web3 is that we are still at an early stage and as we speak, the web3 ecosystem is growing with new protocols, toolings, etc., and regardless of our level of expertise, we can contribute to helping others as we are learning. This blog aims to help devs to use the gelato network with smart contracts and specifically for using Gelato automation with Superfluid Super Apps.
Superfluid Protocol among other features allows users to stream money/tokens to users/contracts with only one transaction and minimal capital lockup. The caveat is that you have to remember to stop the stream, if not the stream will continue endlessly. Please visit Superfluid website for further info https://www.superfluid.finance/home
Gelato Network allows you to execute tasks at a future point in time (for ex-web2 would be similar to a kind of scheduler). The main use case is for repeated tasks. For Superfluid streams we will only need one execution (start or stop) therefore we will have to deploy the task and at the same time the “cancel Task”. Please visit Gelato website for further info https://www.gelato.network/
This project showcases general-purpose examples of automating smart contracts with gelato as well as the application for superfluid streams presenting a very simple 3+3 Step guide to create programmable cash flows
In order to do that we have deployed a showcase dapp at https://gelato-superapp.web.app. we will interact with two main verified and deployed on mumbai contracts :
- Party App Contract (view on scan)
- Gelato Super App Contract (view on scan)
The code can be found in the below repository
3+3 Steps Guide to Gelatofy a Smart Contract
Here you will find 3 + 3 easiest steps to add the gelato infrastructure and very easily automate your smart contract tasks:
1) Wire Gelato infrastructure
2) Gelato Funding Strategy
3) Gelato Business Logic
3.1) Task Creation
3.2) Checker Condition
3.3) Executable Function
Step 1: Wire Gelato infrastructure
In order to interact with the gelato network, we will need to interact with the Gelato contracts (addresses can be found here). We will interact with three contracts:
Ops Contract: The main contract for creating, canceling, getting transaction Fees, transfer fees, etc. We will inherit the contract OpsReady.sol
, we will pass in the constructor the gelato ops and gelato treasury addresses and we are good to go!.
Gelato Treasury Contract: We will require to interact with the gelato treasury contract for fund/withdrawal depending on our funding strategy (see step 2)
Gelato Network: We will interact with this contract in our tests… more on Bonus Track #2
The OpsReady.sol contract, as well as the interfaces, can be found in gelato-files within the repository. You can just copy them and it works!
Step 2: Gelato Funding Strategy
Gelato executes transactions at a future point in time, therefore we need to choose a way of funding the transactions that Gelato is going to execute on our behalf.
There are two alternatives to do that:
1) Fund the Gelato Treasury Contract: as long as you have a positive balance in the treasury contract, the future transactions will be executed. If we choose this alternative we need to interact with the Gelato Treasury Contract funding it.
2) Fund every transaction: Our smart contract will transfer in every future transaction the amount requested to pay the fees. In this case, we won’t need to interact with the Gelato Treasury Contract but we must maintain a positive balance in our contract.
Step 3: Gelato Business Logic
There are three main parts/steps that we have to define within the business logic:
3.1) Create the Task: We will have to define a task to tell Gelato what we want to be executed.
3.2) Checker Condition: In order to execute a future transaction, we will have to provide Gelato with the condition to check whether Gelato can execute or not
3.3) Executable Function: Function that will be executed when conditions and/or time are met.
Party App demo!
Our First Gelato App is going to be very simple. It checks whether our gelato party has started or not. The party will always start if we don’t have a “headache” from the previous party.
We can set manually when our “headache” is over and then the Gelato network will be able to execute the start party, setting a new start party timestamp and setting our “headache to true”
Our screen is divided into two parts depending on our funding strategy.
This contract allows three uses cases:
1) Create a simple task funded with treasury: Details can be seen above
Once the task is created we can go to the gelato ops website and we will see our task waiting for execution
And after successful execution, the ops dashboard will show us something like this.
2) Create a simple task funded with treasury and cancel after the first execution (we are going to use this pattern later on with our Superfluid streams).
3) Create a simple task paying each transaction (not treasury funding)
Gelato Super App Demo
Our Gelato super App will help us make superfluid streams programmable by automating the stop or the start of a stream.
We will implement the gelato Infrastructure (Step 1) like in the party app and we choose Treasury funding as a Funding Strategy (Step 2)
We will demo stopping a stream after some predefined minutes. Our Business Logic will look like this:
Now if you have funded the treasury, have started a stream and the gelato has already been executed stopping the stream you have unlocked your Bonus!!
Bonus Track #1: Go to Sleep and the Stream will Start.
So far we have achieved to stop a stream automatically, but following the same logic, I may want to start streaming to a new employee exactly at 00:00 AM on the first day of work and I don’t want to stay awake every day because hopefully, we are going to hire a lot of employes!
.. then CFA ACL to the rescue…
… with a simple call to the CFA constant agreement either from the SDK or directly to the contract you may want to allow our Super App to start a stream on your behalf when a certain time is elapsed and a “Gelato Task” is executed.
In this use case, we are concatenating two tasks, when the first one is executed, the stream will be started, the task canceled and another task to stop the stream will be created.
Bonus Track#2: Master Hardhat Fork and Sky Rocket your Development Speed
One of the pleasant experiences in blockchain development is the ability to one-click creation of…..
As our dapps grow in complexity we will require to interact with existing on-chain contracts and if we want to remain local we will have to mock/deploy protocols. In some cases that can be cumbersome and we will spend precious development time. The best alternative to overcome this issue is to work with a fork, with a very simple configuration within our hardhat.config.ts
(thks Sam Flamini and Hilmar X for pointing out the right direction).
and then with the npx hardhat node --network "hardhat"
we will be able to create a “virtual” copy of the blockchain we are targeting. The blocks we create from now on will be stored locally and for the older ones we will query the “real” blockchain with our RPC provider (above we are using alchemy)
In our example, we are working with mumbai, the Superfluid contracts (Host, ConstanFlowAgreeent, Supertoken…), as well as the Gelato contracts (Network, OPS, and Treasury), exist with the state they had at the block number of the fork allowing us to interact with them as we would interact with the “real” blockchain.
Now, you have your local “mumbai” with the additional helper methods to truly master the chain:
In our Dapp we are working with Gelato contracts. The “Executors” will take care to automate our tasks, but in our local “virtual” chain there are no executors… who will execute our tasks?. And the answer to that is very simple, we are going to execute the task ourselves. We can do that because we master our local blockchain, we can be whoever we want to be and we choose to be the executor. Hardhat provides us with the fantastic method hardhat_impersonateAcount
and we will use it to become locally “the executor”.
Here we can see the details of the implementation for executing gelato tasks impersonating the Gelato NetWork contra
We will need to build the params to be able to execute the task, if we look in Ops interface we see that we need the following params
Using one of our examples in the party app we will have:
The implementation in our dapp tests can be seen in the code. We use this technique in our contract tests.
Conclusion
As we have seen, it is relatively simple to wire the gelato network into our smart contracts and unlock the full potential of automation. Specifically for Superfluid streams gelato can allow Super Apps to do stream-scheduling.
Hope this article can help other devs to quickly get up and running with gelato and apply it to Superfluid streams.
You can connect with me on Twitter @donoso_eth
Further Reading and Watching
Super Apps in-depth
Gelato Network Architecture
Gelato Ops