Intent Source Contract
The IntentSource
contract lives on the origin chain and is responsible for the management of intent origination, custody of funds and filler fulfillment. Each chain supported by the Eco Protocol has one.
Intent Contract Design
The IntentSource
contract contains two primary functions: createIntent
and withdrawRewards
, which are explained below. All code snippets in this section reference this specific commit.
Intent Creation
Intent creation is managed through the createIntent
function on the IntentSource
contract. When a user goes to post a transfer request on chain, they call this function and supply data specifying the:
Destination Chain
Inbox Contract Address
Array of Contracts to Call
Array of Calldata for those Functions
Reward Tokens and Amounts
Expiration Time
Prover Contract
After running a few sanity checks, the contract takes the inputs and calculates a unique hash for the intent request. The addition of a nonce ensures no collisions occur for intent creations with identical parameters. The hash is used by both the Inbox
and Prover
contracts to uniquely identify the intent throughout the fulfillment process.
Finally, the contract transfers the specified reward tokens to itself and emits an intent creation event.
Reward Withdrawal
Intent creation is managed through the withdrawRewards
function on the IntentSource
contract. This function is called by users who are withdrawing unsolved intents, and fillers who have solved intents and are going to claim their rewards.
The intent rewards being claimed are identified by their hash, created during the origination of the intent. The contract then checks to ensure that the Prover
contract shows that intent as proved, and loads the claimant
address from the prover contract. The claimant
is the address entitled to claim the funds.
If the intent has been proven by the Prover
contract, the funds are withdrawn to the claimant
If not, then then the contract checks if the intent is past the expiry time, and withdraws the funds to the intent creator.
Design Discussion
Intent Parameters
The createIntent
function requires the intent creator to specify many parameters as part of intent creation.
Destination Chain — This specifies the ID of the destination chain where the intent fufillment will be fulfilled on the
Inbox
contract.Inbox Contract Address — This specifies the address of the
Inbox
contract on the destination chain.Array of Contracts to Call — This specifies the list of contracts that the intent creator is requesting a filler to call on the destination chain.
Array of Calldata for those Functions — This specifies the list of corresponding function signatures and calldata that pair with the contracts to call.
Reward Tokens and Amounts — This specifies the ERC20 tokens and amounts that the filler is entitled to for fufilling the intent.
Expiration Time — This specifies the expiration blocktime after which the intent will be considered expired. If the intent fulfillment is not proven by this time, the intent originator can claw back their funds. This expiration time must be appropriately set to the proving method chosen by the intent creator.
Prover Contract — This specifies the proving contract that will validate if the intent has been fulfilled.
The amount of parameterization is part of the design philosophy of the system. It makes the contracts extremely extensible and it gives maximum flexibility to intent creators and fillers to specify whatever logic they want to use, and to make their own decisions about tradeoffs between decentralization and cost.
For example, the ability to specify the prover at intent creation makes it easy to use alternative proof methods that might be cheaper for intent creators and fillers, at the cost of centralization.
The choice for maximum flexibility, however, does come with a downside. Given that intent creators can specify whatever function calls and whatever contracts they want, fillers must carefully simulate and vet each intent to ensure they are not malicious. We believe this downside is worth it — but does require the development of extensive guardrails in filler software.
User and Filler Matching
Unlike other intent base protocols, the Eco Protocol does not rely on an RFQ system or off-chain matching system before intent creation. Instead, the Eco Protocol is optimized for application developers that intend to run, or will contract out, the settlement of intents on behalf of their customers.
Applications and users will negotiate what fees are appropriate for cross chain actions on the application level, and applications (or their contracted fillers) will be incentivized to fufill these intents to retain their customers. In the case where an application fails to fulfill an intent a user posts on chain, the user will experience a lockup of their funds for a given period, but does not risk total loss of their funds.
We decided to design this system this way because it was the best possible design consideration for our needs with Bend. We do intend to add matching systems and onchain incentives for fillers to fill intents, which you can read about in the next section.
Future Directions
Future versions of the Eco Protocol will introduce significant flexibility around the filler / user matching process. The system is highly optimized for applications who provide services to their users, but significant improvements are needed to make it appropriate for other decentralized use cases. Below are some possible future improvements, which are also discussed in more detail in Future Directions.
Bonded Exclusivity — this would involve adding a feature to the
IntentSource
contract that would allow fillers to submit user intents, with the exclusive right to solve them. In order to make exclusive claim to these intents, they would be required to post collateral.ERC-7683 Compliance — compliance with ERC-7683 would open the protocol to many different filler pools and increase the compatibility of the system with general purpose intent protocols.
TEE Matching Mechanism — the use of TEE systems, and other offchain trustless execution environments, could allow for trustless matching of users and fillers. This might also allow for deterministic execution of actions on both rollups, removing the need for any cross chain proving at all.
Batch Claims — this will allow fillers to submit an array of intents that have been proven by the prover contract, and claim each relevant reward token with a single transfer.
Last updated