Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

FIP-0045 First draft of FIP for decoupling FIL+ from markets #432

Merged
merged 7 commits into from
Aug 30, 2022

Conversation

anorth
Copy link
Member

@anorth anorth commented Aug 14, 2022

This is a first draft of the FIP for the proposal discussed in #313

FIPS/fip-filplus.md Outdated Show resolved Hide resolved
FIPS/fip-filplus.md Outdated Show resolved Hide resolved
FIPS/fip-filplus.md Outdated Show resolved Hide resolved
FIPS/fip-filplus.md Outdated Show resolved Hide resolved
FIPS/fip-filplus.md Outdated Show resolved Hide resolved
FIPS/fip-filplus.md Outdated Show resolved Hide resolved
FIPS/fip-filplus.md Outdated Show resolved Hide resolved
FIPS/fip-filplus.md Outdated Show resolved Hide resolved
FIPS/fip-filplus.md Outdated Show resolved Hide resolved
@anorth anorth changed the title First draft of FIP for decoupling FIL from markets First draft of FIP for decoupling FIL+ from markets Aug 16, 2022
FIPS/fip-0045.md Outdated Show resolved Hide resolved
FIPS/fip-0045.md Outdated Show resolved Hide resolved
FIPS/fip-0045.md Outdated Show resolved Hide resolved
FIPS/fip-0045.md Outdated Show resolved Hide resolved
the initial pledge for the new sector is calculated using the network conditions at the time.
The pledge requirement for the old sector is not decreased,
but any subsequent penalty is calculated using the current (reduced) power.

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I think this point is very important to fully clarify. I would expect that an additional piece of collateral needs to be placed at the time when SP starts earning 10X, when the claim is sealed. But this is not really specified here.

If QAP can change throughout the lifetime of a sector then I would imagine the collateral also changes, increases when the QAP increases?

If collateral will work in this "not smeared over sector lifetime" way, this has a potentially very large economic impact to the network that we would need to evaluate.

The idea is economically, collateral from sectors can be viewed as a "loan" to the network, freeze these funds, which is good for the rest of the network, for a period of time. The point is that the terms of these loans are changing (and perhaps maybe rightfully so, this may be right thing to do) but it strictly resuts in a "bad deal" for the rest of the network. If you loan me 10 dollars that I have to pay back in one year, it is not the same as if you loan me 5 dollars that I have to pay you back in 2 years. The second loan is a more valuable one for which I should pay you back more interest.

Currently collateral works in the second "smeared way", which economically speaking is "better for the network" than the new version.

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I would expect that an additional piece of collateral needs to be placed at the time when SP starts earning 10X

I meant to imply this with "the initial pledge for the new sector is calculated using the network conditions at the time". The new sector pledge accounts for its FIL+ contents. I can clarify in the body.

the terms of these loans are changing

They can only change in a way that is "good for the network". The amount can only increase, and the term can only be extended. Could you state a concrete scenario that you're worried about?

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I meant to imply this with "the initial pledge for the new sector is calculated using the network conditions at the time". The new sector pledge accounts for its FIL+ contents. I can clarify in the body.

Ok yes I think this can be more explicitly specified. Let's say I seal a 1 year sector, and I make a 6 month claim on it, which starts on the second half. So I place 1X pledge at the beginning of the sector, then when the claim starts halfway through the sector, I need to deposit the remaining 9X of the pledge (roughly but not exactly because this would be based on current network conditions, different from 6 months ago) before I start earning 10X reward. Is this how it works?

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

They can only change in a way that is "good for the network". The amount can only increase, and the term can only be extended. Could you state a concrete scenario that you're worried about?

Let's take the same example, 1 year sector, with 6 month claim on its second half. Currently the network would have 5.5X locked for 1 year duration. With this proposal the network would have 1X locked for 6 months, and 10X locked for 6 months. Financially the first loan is "better".

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Another possible issue I am thinking is the maximum term mechanism can introduce an incentive for sealing shorter sectors. If a client offers an SP an allocation with 6 month max term, and the SP now has to put it in a sector. Currently the SP can seal that in a new sector and might as well seal it in a longer 1 year sector or whatever. Specially if Duration multiplier passes, they would seal it in the longest sector they can, so they can multiply their multipliers together and earn more.

with this proposed version, they only have the options of a) add it to a sector they have that only has 6months or less left, or b) seal a new 6 month sector.

All FIL+ will be added to sectors that are exactly the right size, while otherwise SP's could have sealed longer sectors (which aligns more with the sectors as containers idea).

I appreciate the point, I think this is an elegant solution to simplifying the QAP calculation, and I generally prefer this current proposal to some of the previous iterations like FIL+ forever. Just figuring out still what may be the compromises and if they are worth it.

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Let's take the same example, 1 year sector, with 6 month claim on its second half. Currently the network would have 5.5X locked for 1 year duration. With this proposal the network would have 1X locked for 6 months, and 10X locked for 6 months. Financially the first loan is "better".

Thanks for the example. I understand the point but think the example is not representative of real behaviour. Given a deal that doesn't start until six months in the future, the network doesn't get to choose between these cases even today. An SP would just wait and put the 6-month deal is a 6-month sector when it was actually due to start. (I'm ignoring the idea of "storage futures", which would be better implemented higher level than concrete sectors).

the maximum term mechanism can introduce an incentive for sealing shorter sectors. If a client offers an SP an allocation with 6 month max term, and the SP now has to put it in a sector. Currently the SP can seal that in a new sector and might as well seal it in a longer 1 year sector or whatever

I concur that there is potential incentive for some sectors to have short commitments, up to the client demand for low term maximums (i.e. clients that want their data unincentivised after some period, for some reason). An SP doesn't have to take such a deal though – if they can get better return on a long commitment sans-deal, they should take it. So I'm actually a little more worried that short deals will find a scarce supply and have to pay, because SDM pays miners to prefer long ones.

Note that the incentive to short sector already exists because of the spread-out QA power. Up to sealing costs, a rational SP picks the shortest sector duration for their deals so their payout and risk of penalty is as short as possible. So all up I don't think this will exert any significant pressure on sector commitment duration.

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

FIPS/fip-0045.md Outdated Show resolved Hide resolved

The `UseBytes` method is removed.
To create an allocation, a verified client transfers data cap tokens to the verified registry actor.
The transfer must be accompanied by one or more `Allocation` records which specify
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

when an allocation is claimed - does the token get to be transferred from the verifreg -> datacap token contract under the miner actor's balance?

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

No, it's burnt

FIPS/fip-0045.md Outdated Show resolved Hide resolved
FIPS/fip-0045.md Outdated Show resolved Hide resolved
FIPS/fip-0045.md Outdated Show resolved Hide resolved
FIPS/fip-0045.md Outdated Show resolved Hide resolved
FIPS/fip-0045.md Outdated Show resolved Hide resolved
FIPS/fip-0045.md Outdated
- Discuss how market delegate means no external API changes
- Discuss mechanisms for conditional allocations, negatively priced deals
- Market method for fetching allocation ids for deals (needed?)
- Spec hook/method for a different client extending the claim by spending data cap (needed?).
Copy link
Member

@jennijuju jennijuju Aug 19, 2022

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This seems nice and can be something that DP folks like @dkkapur would be interested for programs like EG.
however, is there any soon-to-land use case exists to support this feature to a high priority that must land in nv17? If not, I’d suggest add it to future enhancement and defer to a later fip.

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

The SDM proposal could cause a high priority need for it.

FIPS/fip-0045.md Outdated Show resolved Hide resolved
minimum and maximum. An allocation's minimum term must be at least as large as its maximum term.

Due to the implementation of term enforcement (details below), clients should leave a large buffer
between the minimum and maximum term to make the allocation practical for a provider.

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

What should be the buffer? Should it be enforced in the logic?

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Clients can pick. I guess we could chose a minimum but it would only be for practicality, not correctness.

FIPS/fip-0045.md Show resolved Hide resolved
FIPS/fip-0045.md Show resolved Hide resolved
FIPS/fip-0045.md Outdated
Each sector hosting a range of an allocation gains power individually.
All ranges from a single allocation must be claimed by the same provider.
If a sector hosting one range of an allocation is lost,
the provider will pay the usual termination penalty but can re-seal the range into a new sector

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I am not sure what this means. As an example, let's imagine that we have claim for storing a deal for 2 years. The sector is sealed and the SP starts getting rewards. After one year, the sector is terminated and the termination fee is paid. What happens to the claim? Can the SP seal another 2-year sector with the same claim? Or do we consider that one year of data cap was already spent?

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

When it was first sealed, the claim got a TermStart epoch. It's valid only until TermStart + TermMaximum. So the new sector must have a scheduled expiration before that. So yes, we basically consider that one year of the allocation was already used.


The record of a claim may be removed by the provider after it has been completed.

The maximum term for a claim may be increased by the client which originally made the allocation,

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Is this possible for a claim related to data already sealed in a sector? If yes, does the SP need to change the list of sectors of this claim?

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

No (we lack the technique today to prove inclusion of some data in an already-sealed sector).

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

If I understand this correctly, does this mean that sectors with deals sealed before this FIP is introduced won't be able to extend?

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Sorry, I misread your original question.

Yes, the term for a claim may be extended – all claims are already sealed in a sector. But this doesn't imply any change to the sector.

FIPS/fip-0045.md Show resolved Hide resolved

The actual term for a claim ends the epoch that the sector containing the data expires,
or that data is replaced.
The term cannot end during a sector's lifetime, except by explicit replacement of data.

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

To clarify, does this mean that a claim with a max term of 1 year cannot be stored in a 2-year sector?

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Also, if we have a claim with a min term of 1 year, we cannot store it in a 6 months sector, right?

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Yes and yes.

@anorth anorth marked this pull request as ready for review August 24, 2022 04:31
@anorth anorth requested a review from jennijuju August 24, 2022 04:31
@anorth
Copy link
Member Author

anorth commented Aug 24, 2022

@jennijuju I've added a lot of the missing content here. While not final, I think this PR is now ready to merge as a draft. @ZenGround0 and I can then collaborate on improvements as implementation progresses.

Copy link
Contributor

@arajasek arajasek left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Thank you for the detailed and well-written FIP. This is a complex change, and understanding it is a lot easier thanks to the FIP.

I do worry that certain aspects of this are overengineered, but I don't yet have anything in mind that I'd suggest simplifying. For now, some notes and questions.

FIPS/fip-0045.md Outdated Show resolved Hide resolved
FIPS/fip-0045.md Outdated Show resolved Hide resolved
FIPS/fip-0045.md Outdated
The new sector’s committed lifespan is still constrained to fit within the claim’s term.

#### Sector extension
A provider cannot extend the scheduled expiration for a sector past the maximum term
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I'm having a hard time understanding this paragraph. We say that a provider cannot extend the scheduled expiration for a sector past the maximum term of any piece of verified data that it holds, but it sounds like a provider can do so (under the circumstances listed in the subsequent paragraph), but will automatically lose the power boost for the extended period if they do so.

Is that correct?

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Well, yes, because it stops holding (kinda, once we can resnap) that piece of data. I'll try to reword.

FIPS/fip-0045.md Outdated Show resolved Hide resolved
// The verified client which allocated the data cap.
Client: Address
// The provider (miner actor) which may claim the allocation.
Provider: Address
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

So this is interesting, and a non-trivial deviation from the FilPlus process today. Today the "verification" process is:

  1. Steps are taken for verifiers (notaries) to be authorized -- irrelevant / unchanged by this proposal
  2. Notaries give some DataCap to Verified Clients, who can spend it on any data, with any SP as they see fit.
  3. VCs negotiate deals with SPs. SPs validate the deal offer by checking that the VC has enough DataCap for the deal.
  4. Data is transferred to the SP.
  5. The DataCap gets "used" when the SP publishes the storage deal*. Note that the SP could get misled by a VC whose DataCap changes between the validation of the offer in Step 2, and the actual publication of the deal in Step 4.

With this FIP, the process becomes:

  1. Steps are taken for verifiers (notaries) to be authorized -- irrelevant / unchanged by this proposal
  2. Notaries give some DataCap (tokens) to Verified Clients, who can spend it on any data, with any SP as they see fit.
  3. VCs negotiate deals with SPs. SPs validate the deal offer by checking that the VC has enough DataCap for the deal.
    3?) VC publishes the Claim, with the matching SP. The SP waits for this publication
    4?) Data is transferred to the SP.
    5?) The DataCap gets "used" when the SP publishes the storage deal*.

At the very least, this leads to changes in the validation processes on the SP side. Additionally, it's not clear to me in what order these steps "should" be performed -- that's not consenus-critical, but I'm interested in whether the FIP authors have an idea in their minds.

I'm concerned about the various ways both VCs and SPs could get misled by this. Is the idea for VCs to only publish claims with very short Expirations, so that they don't have their DataCap locked for a long period by an uncooperative SP? Is the idea for SPs to receive all the data before the VC actually publishes the Claim, leaving them vulnerable to having their time and resources wasted by malicious VCs who have no intent of actually publishing a Claim?

I suspect time and discussion has already gone into these questions, so feel free to point me to the appropriate place.

*I might be wrong about the precise details of this.

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

as discussed offline, 3&4 happen within 5!

FIPS/fip-0045.md Outdated Show resolved Hide resolved
FIPS/fip-0045.md Outdated Show resolved Hide resolved
FIPS/fip-0045.md Outdated Show resolved Hide resolved
FIPS/fip-0045.md Outdated Show resolved Hide resolved
FIPS/fip-0045.md Outdated Show resolved Hide resolved
FIPS/fip-0045.md Outdated Show resolved Hide resolved
FIPS/fip-0045.md Outdated Show resolved Hide resolved
FIPS/fip-0045.md Outdated Show resolved Hide resolved
FIPS/fip-0045.md Outdated Show resolved Hide resolved
@jennijuju
Copy link
Member

@anorth could you please specify, what happens when the sector is early terminated?

  • faulty >42 days
  • manually terminated

did the claimed got removed then datacap got burned?

@anorth
Copy link
Member Author

anorth commented Aug 25, 2022

please specify, what happens when the sector is early terminated

There is no change from behaviour today. Datacap was already burned. The claim is not removed until the provider does so explicitly.


The verified registry can support re-commitment of the same data
(even though the built-in storage market actor does not support resumption of a terminated deal).
If a claim’s maximum term has not been reached when a sector terminates,
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I don't understand how this would work. Is the verified registry notified when a sector fulfilling a claim expires? Or is the idea that a Claim can be re-claimed if the Sector in the original Claim has expired?

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

No the registry is not notified when a sector expires. The miner actor is still trusted to enforce the appropriate penalties etc.

But a claim can be re-claimed if the original sector has expired. Here again the miner actor will be trusted to only do this when the original sector has gone. It's quite likely that the user-facing method to do this won't be landed as part of this nv17, but it's automatically encompassed in the follow-on designs.

@jennijuju
Copy link
Member

please specify, what happens when the sector is early terminated

There is no change from behaviour today. Datacap was already burned. The claim is not removed until the provider does so explicitly.

maybe i missed it - but i cant seem to find when the token is burned in this fip yet. Upon a claim?

- Spec methods for sector migration on miner, market, and verifreg actors
- Spec change to SectorOnChainInfo to distinguish migrated sectors
- Confirm policy for built-in market actor's default term maximum
- Market method for fetching allocation/claim ids for deals (needed?)
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

ah.. we will need this for client implementation, when extend a sector, we need to be able to get the term max of all data in the deals of that sector

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

You can do state inspection. This method will eventually be needed for operators to migrate off that though.

@jennijuju
Copy link
Member

@anorth i believe two things are missing

  • upon upgrade, we should migrate the existing verified clients datacap balance to the token contract, under the clients address. I’m not sure if we need to migrate verifiers or not, iiuc we are keeping the verifier datacap state in verifreg, if so we don’t need to do anything.
  • upon upgrade, we should migrate and add allocations for pending deals (deals that’s has been onchain via PSD), so that, when SP provecommit those deal sectors, they won’t fail the claim due to allocation not found.

@anorth
Copy link
Member Author

anorth commented Aug 29, 2022

Thanks I've added notes about the upgrade migration, including datacap balances. I'm not yet confident about the best way to handle pending deals, so have added TODO.

@jennijuju
Copy link
Member

I think this FIP still needs a couple of iterations before it can be considered last call ready. However, it has enough information for the first draft of an FIP and has enough community interest to consider the idea for filecoin network.
That being said, I am merging this PR now - more discussion of the FIP evolvement at #313. FIP authors shall ensure that the unaddressed comments in this PR are either captured in the discussion or tracked elsewhere and will be addressed in the upcoming iterations.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

9 participants