From 59300d512ae107bd1baf7feff8207594ad4ee6ec Mon Sep 17 00:00:00 2001 From: jennijuju Date: Fri, 12 Jul 2024 17:18:02 +0200 Subject: [PATCH 1/4] create fip draft for discussion #1034 --- FIPS/fip-tbd.md | 106 ++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 106 insertions(+) create mode 100644 FIPS/fip-tbd.md diff --git a/FIPS/fip-tbd.md b/FIPS/fip-tbd.md new file mode 100644 index 00000000..5f224f72 --- /dev/null +++ b/FIPS/fip-tbd.md @@ -0,0 +1,106 @@ +--- +fip: "tbd" +title: More API between user-programmed actors and built-in miner actor for building decentralized staking protocol +author: @Schwartz10, @jennijuju +discussions-to: +status: Draft +type: https://github.com/filecoin-project/FIPs/discussions/1034 +category (*only required for Standard Track): +created: 2024-07-12 +--- + + +# FIP-TBD: More API between user-programmed actors and built-in miner actors for building decentralized staking protocol + +## Simple Summary + +Export additional built-in miner actor methods for invocation by user actors, so to enable more decentralized DeFi protocol for Storage Provider (SP) services. + +## Abstract + +Upon the FEVM launch, [FIP-0050](https://github.com/filecoin-project/FIPs/blob/master/FIPS/fip-0050.md) was also introduced with a list of the builtin actor methods that are exposed as callables from user actors. Since then, we’ve seen a number of protocols build lending or leasing applications around Miner Actors collateral & rewards. As common practice in DeFi, protocols often introduce a “liquidation” procedure that liquidates a borrower’s collateral to derisk the liquidity providers from losing lent out funds. In the process of Filecoin leasing applications, a liquidation means termination of a miner’s active sectors, facing a penalty, but recovering pledged collateral to return to liquidity providers. Economic security of applications being built on the FEVM is important for developing trust and attracting outside capital / liquidity / investors, and understanding precise collateral values for any given miner actor is critical for a DeFi protocol’s economic security. + +This FIP aims to introduce more exported APIs in miner actor for supporting onchain liquidation procedure for decentralized staking protocol. + +## Change Motivation + + +As DeFi protocols on Filecoin gain traction and lock larger amounts of value, they will be targets for more attacks. As an ecosystem, we should create the necessary primitives to build secure economic applications that use miner actors as collateral. + +There are a few motivations to this change: + +Trustless DeFi - it’s important that users of a DeFi protocol can trust code and not humans to protect their assets. When humans are in the loop, there is necessarily a “judgment call zone”, which violates all aspects of DeFi, it also creates personal safety issues for individuals who are known to process liquidations with no plausible deniability. +Liability concern - from the DeFi protocol creator’s perspective, being an external third party that has to process liquidations off chain (rather than creating a keeper network of liquidators) introduces liability and regulatory concern to the protocol, making it harder to operate in certain jurisdictions +Incentive design - by designing their own rulesets for liquidations, application developers can incentivize keepers to protect their protocol in a decentralized manner + + +This FIPs propose builtin actors APIs that can provide information/functionalities that staking protocols often need to build offchain logics/oracles for: +- triggering sector termination. +- compute collateral/reward values (significantly bloating the surface area of attack vectors for any lending / leasing protocol). + +## Specification + +Following the FIP-0050 specification for exported builin actor methods in, we add a set of additional methods. + +### Operation + +**TerminateSectors** In Miner Actor + +Export the existing TerminateSectors method with the following change: + +```rust +pub struct TerminateSectorsParams { + pub terminations: Vec, +} +``` + +`Vec` can be nullable. When it is null, flush/terminate the sectors that are queued up in the cron for termination. + +To prevent the same sectors to be added to the termination queue in the cron and consume block space maliciously, calling this method will immediately terminate the sectors in early_terminations queue first, then execute termination of the sectors submitted in TerminationDeclaration. + + +```rust +pub struct TerminateSectorsReturn { + pub done_sectors: BitField, + pub pending_sectors: BitField, +} +``` + +Update the return value of the method to include sector numbers that are successfully terminated or still pending in the queue.. + +### Read only methods in miner actor + +- GetAvailableBalance +- GetLockedReward +- GetLockedInitialPledge +- GetExpectedRewards + + + +## Backwards Compatibility + +This FIP introduces new builtin actor methods, therefore needs a new actors version shipped in a network upgrade. No breaking changes to existing methods, however. + +## Test Cases + +- User actors can call all exported methods +- Newly introduced methods are correct + + +## Security Considerations + +No new method is being introduced that can be used to attack the network, and bugs in the implementation will only lead to incorrect behavior being observed by user actors. + +## Product and Incentive Considerations + +This FIP enables more trustless and decentralized staking and DeFi protocol for token holders to partipate in. Staking and Defi protocol can drive Filecoin onchain activities, improve FIL utilities and enabling more (1) storage providers to get liquidity to join the network and prvoide storage services & secure the network consensus (2) token holders to put their FIL into use and improve Filecoin GDP. + + +## Implementation + +TODO + +## Copyright +Copyright and related rights waived via [CC0](https://creativecommons.org/publicdomain/zero/1.0/). + + From 12300d016caf3e6c6e36768111c8633a179f412f Mon Sep 17 00:00:00 2001 From: jennijuju Date: Mon, 22 Jul 2024 18:19:19 -0400 Subject: [PATCH 2/4] update the FIP - address editors initial feedback - update the spec for the new terminating sectors method - remove other apis and will introduce in a separate fip --- FIPS/fip-tbd.md | 90 ++++++++++++++++++++++++++----------------------- 1 file changed, 48 insertions(+), 42 deletions(-) diff --git a/FIPS/fip-tbd.md b/FIPS/fip-tbd.md index 5f224f72..22a37efc 100644 --- a/FIPS/fip-tbd.md +++ b/FIPS/fip-tbd.md @@ -1,99 +1,105 @@ --- fip: "tbd" -title: More API between user-programmed actors and built-in miner actor for building decentralized staking protocol -author: @Schwartz10, @jennijuju -discussions-to: +title: Export sector termination method from miner actor +author: @jennijuju, @stebalien, @anorth, @Schwartz10, +discussions-to: https://github.com/filecoin-project/FIPs/discussions/1034 status: Draft -type: https://github.com/filecoin-project/FIPs/discussions/1034 +type: Technical category (*only required for Standard Track): created: 2024-07-12 --- -# FIP-TBD: More API between user-programmed actors and built-in miner actors for building decentralized staking protocol +# FIP-TBD: Export sector termination method from miner actor ## Simple Summary -Export additional built-in miner actor methods for invocation by user actors, so to enable more decentralized DeFi protocol for Storage Provider (SP) services. +Adds a new `TerminateSectors2` (method 37) that allows callers to submit sectors for termination and define the maximum amount of sectors to be terminated immediately. + +Expose `TerminateSectors2` method for invocation by user actors, so to enable more decentralized DeFi protocol for Storage Provider (SP) services. ## Abstract Upon the FEVM launch, [FIP-0050](https://github.com/filecoin-project/FIPs/blob/master/FIPS/fip-0050.md) was also introduced with a list of the builtin actor methods that are exposed as callables from user actors. Since then, we’ve seen a number of protocols build lending or leasing applications around Miner Actors collateral & rewards. As common practice in DeFi, protocols often introduce a “liquidation” procedure that liquidates a borrower’s collateral to derisk the liquidity providers from losing lent out funds. In the process of Filecoin leasing applications, a liquidation means termination of a miner’s active sectors, facing a penalty, but recovering pledged collateral to return to liquidity providers. Economic security of applications being built on the FEVM is important for developing trust and attracting outside capital / liquidity / investors, and understanding precise collateral values for any given miner actor is critical for a DeFi protocol’s economic security. -This FIP aims to introduce more exported APIs in miner actor for supporting onchain liquidation procedure for decentralized staking protocol. +This FIP aims to introduce an exported sector termination method in miner actor for supporting onchain liquidation procedures for decentralized staking protocol. ## Change Motivation - As DeFi protocols on Filecoin gain traction and lock larger amounts of value, they will be targets for more attacks. As an ecosystem, we should create the necessary primitives to build secure economic applications that use miner actors as collateral. There are a few motivations to this change: -Trustless DeFi - it’s important that users of a DeFi protocol can trust code and not humans to protect their assets. When humans are in the loop, there is necessarily a “judgment call zone”, which violates all aspects of DeFi, it also creates personal safety issues for individuals who are known to process liquidations with no plausible deniability. -Liability concern - from the DeFi protocol creator’s perspective, being an external third party that has to process liquidations off chain (rather than creating a keeper network of liquidators) introduces liability and regulatory concern to the protocol, making it harder to operate in certain jurisdictions -Incentive design - by designing their own rulesets for liquidations, application developers can incentivize keepers to protect their protocol in a decentralized manner +- Trustless DeFi - it’s important that users of a DeFi protocol can trust code and not humans to protect their assets. When humans are in the loop, there is necessarily a “judgment call zone”, which violates all aspects of DeFi, it also creates personal safety issues for individuals who are known to process liquidations with no plausible deniability. +- Liability concern - from the DeFi protocol creator’s perspective, being an external third party that has to process liquidations off chain (rather than creating a keeper network of liquidators) introduces liability and regulatory concern to the protocol, making it harder to operate in certain jurisdictions +- Incentive design - by designing their own rulesets for liquidations, application developers can incentivize keepers to protect their protocol in a decentralized manner - -This FIPs propose builtin actors APIs that can provide information/functionalities that staking protocols often need to build offchain logics/oracles for: -- triggering sector termination. -- compute collateral/reward values (significantly bloating the surface area of attack vectors for any lending / leasing protocol). +This FIPs propose a builtin actors APIs that can trigger sector termination in smart contracts that staking protocols often need to build offchain logics/oracles for currently. ## Specification -Following the FIP-0050 specification for exported builin actor methods in, we add a set of additional methods. +Expose the following APIs, following the FIP-0050 specification for exported builtin actor methods. -### Operation +**TerminateSectors2** In Miner Actor -**TerminateSectors** In Miner Actor +To allow caller (storage providers, stake pools and etc) to have more precise control over the amount of the sectors to be terminated based on their operational needs, this FIP introduces a new `TerminateSector2` method. This method follows most of the behaviour of the existing `TerminateSectors` method (method 9), notably: +- Only a control address of the miner actor can call this method. +- Attempt to terminate sectors that is in the current or the next proving deadline will fail with `USR_ILLEGAL_ARGUMENT`. +- The method will always process the sector(s) that are already in the `early_termination` queue before processing newly submitted sectors. -Export the existing TerminateSectors method with the following change: +This FIP proposes the following behaviour changes: +- Currently, `TerminateSectors` allows callers to submit early termination for at most 3000 sectors in one message. `TerminateSectors2` will remove this hardcoded upper bound. Instead, `TerminateSectors2` takes a `max_termination` parameter for caller to specify the maximum number of sectors to be terminated. +- `TerminateSectors2` will always first terminate the sectors that are already in the `early_termination` queue (either added through cron or through `TerminateSectors(2)` messages), then process the new sectors submitted in the message. This prevents the same sectors to be added to the termination queue in the cron and consume block space maliciously. + - A newly submitted sector will be skipped if it was already in the `early_termination` queue and got executed first, so that the sector will not be terminated twice. +- `TerminateSectors2` will only terminate sectors up to the number caller specified in the `max_termination` parameter. If there are more sectors in `early_termination` queue and the new sectors submitted in the message than the `max_termination` amount, the message will fail with `USR_ILLEGAL_ARGUMENT`. + - Caller can query the `early_termination` queue size ahead of submitting the message to determine the maximum number of sectors and/or new sectors it can terminate in one message. + - That said, `TerminateSectors2` will not add sectors to the termination queue. +- `TerminateSectors2` will fail with `SYS_OUT_OF_GAS` and abort the all execution if the caller doesn't have enough gas to execute the termination and/or the message itself run out of gas. -```rust -pub struct TerminateSectorsParams { - pub terminations: Vec, -} -``` +The `TerminateSectors2Params` follows the existing `TerminateSectorsParams` structure, with an additional `max_termination` parameter. `Vec` can be nullable. When it is null, flush/terminate the sectors that are queued up in the cron for termination. -To prevent the same sectors to be added to the termination queue in the cron and consume block space maliciously, calling this method will immediately terminate the sectors in early_terminations queue first, then execute termination of the sectors submitted in TerminationDeclaration. - - ```rust -pub struct TerminateSectorsReturn { - pub done_sectors: BitField, - pub pending_sectors: BitField, +pub struct TerminateSectors2Params { + pub terminations: Option>, + pub max_termination: u64, } -``` -Update the return value of the method to include sector numbers that are successfully terminated or still pending in the queue.. +pub struct TerminateSectors2Return { + // Set to true if all early termination work and new sectors termination work have been completed. Set to false otherwise. + pub done: bool, +} +``` -### Read only methods in miner actor +**TerminateSectors2Exported** In Miner Actor -- GetAvailableBalance -- GetLockedReward -- GetLockedInitialPledge -- GetExpectedRewards - +Add `TerminateSectors2Exported` method to Miner builtin actor. The method ID is `2777360141`. ## Backwards Compatibility -This FIP introduces new builtin actor methods, therefore needs a new actors version shipped in a network upgrade. No breaking changes to existing methods, however. +This FIP introduces new builtin actor methods, therefore needs a new actors version shipped in a network upgrade. No breaking changes to existing methods, however, existing methods may be deprecated in future network upgrades. + +This FIP does not require a state migration. ## Test Cases -- User actors can call all exported methods -- Newly introduced methods are correct +- TODO ## Security Considerations No new method is being introduced that can be used to attack the network, and bugs in the implementation will only lead to incorrect behavior being observed by user actors. + +To prevents the same sectors to be added to the termination queue in the cron and consume block space maliciously with programmatic smart contracts, `TerminateSectors2` will not add any sectors to the cron queue and it will always terminate the sectors that are already in the `early_termination` queue first, then process the new sectors submitted in the message and skip the sectors that are already in the `early_termination` queue. + +While the newly introduced `TerminateSectors2` method allows a smart contract to terminate a sector on SPs behalf, it still requires the SP to add the smart contract as a control address first. When SPs signs and send the message to add smart contract as a control address, this should be considered as a high trust action, as the SP is authorizing the control right to the smart contract. + ## Product and Incentive Considerations -This FIP enables more trustless and decentralized staking and DeFi protocol for token holders to partipate in. Staking and Defi protocol can drive Filecoin onchain activities, improve FIL utilities and enabling more (1) storage providers to get liquidity to join the network and prvoide storage services & secure the network consensus (2) token holders to put their FIL into use and improve Filecoin GDP. +This FIP enables more trustless and decentralized staking and DeFi protocol for token holders to participate in. Staking and Defi protocol can drive Filecoin onchain activities, improve FIL utilities and enabling more (1) storage providers to get liquidity to join the network and provide storage services & secure the network consensus (2) token holders to put their FIL into use and improve Filecoin GDP. ## Implementation From 93ecebd1d1ca7b1ad7dfd11829f45c25d0c0c75d Mon Sep 17 00:00:00 2001 From: Jiaying Wang <42981373+jennijuju@users.noreply.github.com> Date: Wed, 18 Sep 2024 17:41:12 -0400 Subject: [PATCH 3/4] Apply suggestions from code review Co-authored-by: Kaitlin Beegle <46908964+kaitlin-beegle@users.noreply.github.com> --- FIPS/fip-tbd.md | 7 +++++-- 1 file changed, 5 insertions(+), 2 deletions(-) diff --git a/FIPS/fip-tbd.md b/FIPS/fip-tbd.md index 22a37efc..dc43efcd 100644 --- a/FIPS/fip-tbd.md +++ b/FIPS/fip-tbd.md @@ -20,9 +20,12 @@ Expose `TerminateSectors2` method for invocation by user actors, so to enable mo ## Abstract -Upon the FEVM launch, [FIP-0050](https://github.com/filecoin-project/FIPs/blob/master/FIPS/fip-0050.md) was also introduced with a list of the builtin actor methods that are exposed as callables from user actors. Since then, we’ve seen a number of protocols build lending or leasing applications around Miner Actors collateral & rewards. As common practice in DeFi, protocols often introduce a “liquidation” procedure that liquidates a borrower’s collateral to derisk the liquidity providers from losing lent out funds. In the process of Filecoin leasing applications, a liquidation means termination of a miner’s active sectors, facing a penalty, but recovering pledged collateral to return to liquidity providers. Economic security of applications being built on the FEVM is important for developing trust and attracting outside capital / liquidity / investors, and understanding precise collateral values for any given miner actor is critical for a DeFi protocol’s economic security. +Following FEVM launch, [FIP-0050](https://github.com/filecoin-project/FIPs/blob/master/FIPS/fip-0050.md) introduced a list of builtin actor methods that are exposed as callables from user actors. Since then, we have seen a number of protocols use miner actor collateral and/or rewards to build lending and leasing applications. -This FIP aims to introduce an exported sector termination method in miner actor for supporting onchain liquidation procedures for decentralized staking protocol. +It is a common practice in DeFi applications to manage risk for liquidity providers (i.e., those lending money) by "liquidating" collateral supplied by borrowers. In the Filecoin ecosystem, 'liquidation' is achieved when Storage Providers terminate a miner's active sectors, pay the required penalty, recover their pledged collateral, and repay liquidity providers. This process is a critical part of FEVM economic security, as is understanding the precise value of existing collateral. + + +This FIP aims to introduce an exported sector termination method in miner actor to support on-chain liquidation procedures. ## Change Motivation From f2ff0bdc029058a9b1dd75c2b8bae0253d6eb443 Mon Sep 17 00:00:00 2001 From: Jiaying Wang <42981373+jennijuju@users.noreply.github.com> Date: Wed, 18 Sep 2024 17:41:25 -0400 Subject: [PATCH 4/4] Update FIPS/fip-tbd.md Co-authored-by: Kaitlin Beegle <46908964+kaitlin-beegle@users.noreply.github.com> --- FIPS/fip-tbd.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/FIPS/fip-tbd.md b/FIPS/fip-tbd.md index dc43efcd..a8f2529c 100644 --- a/FIPS/fip-tbd.md +++ b/FIPS/fip-tbd.md @@ -47,7 +47,7 @@ Expose the following APIs, following the FIP-0050 specification for exported bui To allow caller (storage providers, stake pools and etc) to have more precise control over the amount of the sectors to be terminated based on their operational needs, this FIP introduces a new `TerminateSector2` method. This method follows most of the behaviour of the existing `TerminateSectors` method (method 9), notably: - Only a control address of the miner actor can call this method. -- Attempt to terminate sectors that is in the current or the next proving deadline will fail with `USR_ILLEGAL_ARGUMENT`. +- Attempt to terminate sectors that are in the current or the next proving deadline will fail with `USR_ILLEGAL_ARGUMENT`. - The method will always process the sector(s) that are already in the `early_termination` queue before processing newly submitted sectors. This FIP proposes the following behaviour changes: