-
Notifications
You must be signed in to change notification settings - Fork 170
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-0083: Add additional event properties to ease DDO transition #964
FIP-0083: Add additional event properties to ease DDO transition #964
Conversation
Peer: other than hearing the feedback from various ecosystem partners, i also felt the pain points myself when working on integration docs, for getting simple data 📊 like “how much data is stored in filecoin” I believe these additional events fields are necessary for toolings like starboard dashboards, http://filplus.d.interplanetary.one/, filecoin.tool, https://filecoin-tracker.com/ and so on to build systems that can continue providing CORRECT and more real-time visibility of the network: how much data are onboarded and currently stored; what data is stored; how long the data is stored. To only make the minimal change here is needed to not delay the network upgrade, whether built in actors should include more info or not and a more complete tradeoff analysis via another FIP. One more piece I think is missing, is a visible event that can make f05 deal onboarded via ProveCommitSectors observable. Today the event is triggered in cron which is not observable from the clients atm, (1) message receipts don't include implicit messages (2) internal traces only has call traces, and dont Enable events viability in cron is a much bigger change that shouldn’t happen in this late of development phase. Without this information, tooling developers will need to add event indexing while keeping the current heavy state inspection, and dedup entries that are captured twice. I wonder, is there anywhere else, outside of the cron we can safely trigger this event? |
@rvagg There is some data wrangling we need to do to get the claim info available in all the Sector events. I'd like to avoid that. The Claim event in the VerifReg Actor now already has the (miner ID, sector number, piece cid, piece size, claim ID) info on it and that will be sufficient for clients to track allocation claims by SPs and also correlate them with the sectors/pieces being claimed. |
Actually, we already have the provider in the claim event. Given that we now have (provider ID, sector number, piece cid and piece size) in the Claim event, I don't think we need to add the claim ID to any of the Miner Actor events. |
@jennijuju Unfortunately, that is tricky because the proofs submitted via 'ProveCommitSectors' are validated in a cron job and unless those proofs are validated, we don't know if the deals have been successfully "onboarded"/"activated". So we can't just emit this info/event when the SP calls 'ProveCommitSectors'. We can only emit this after those proofs have been validated but the proofs are validated in a cron job. |
Hrm you get the claim ID right? I think the expiration here meant sector expiration not claim expiration, and sector expiration is already in the sector info and shouldn’t be hard to get. |
If we add notification actor ID to sector activated event that may solve the problem as well. |
@jennijuju @rvagg Just to be clear
This is the epoch after which the SP stops getting QA power for the claimed sector
|
Summarizing my objections from the call: I'm going to object to this pretty strongly. We're asking the user to infer that, because the market actor was notified, the deal necessarily "belongs" to the market actor. The SP can choose to notify any actor and and any number of actors and who they notify won't necessarily be the "storage market" that owns the deal (and I really don't want users to start assuming this). E.g., the SP could choose to notify f05 even if the deal isn't related to the market. Proposal from the call:
NOTE: It doesn't matter which piece we ignore from the sector activation event, we don't have IDs anyways. |
Proposal from a followup conversation with @aarshkshah1992: We don't actually need to add anything to the deal activation event. Instead, we can:
This will let us get away with adding nothing to our events. |
@Stebalien, like I said, I won't insist on this if there is a solution for the builder that's simple enough to build. BUT last bikeshedding. The original comment called it the notification actor ID, not the storage market ID, for a reason. So, I am not convinced by your "I read builders mind" statement here. A more productive thing would be defining and aligning standards with the builders/ecosystem. I am also unconvinced that "the SP could choose to notify f05 even if the deal isn't related to the market." What is the incentive/use case for any client/SP to ever DO that? Who would anyone send any notification if they don't want to have their data deal to participate in some storage market/marketplace or leverage some on-chain payment mechanism? It would be great if you could follow up on #fip-direct-data-onboarding cuz I'm now concerned about why we are not aligned on why we should have this notification design in the protocol and why it is useful. |
@aarshkshah1992 @Stebalien, what's your plan to check this? Where do you get the pieces from and what information other than piece CID will you be using, and the key pairs for checking in the deal DB? |
A reminder to you all that most of this discussion belongs in the discussion thread #754, where it has the context of prior discussion, can support a level of threading, and will persist and be discoverable after this PR is closed. |
* remove expiration from sector-* events
This looks good to me at the moment with the exception of the verifier-balance event discussed here. Note I don't object to adding more simple fields (piece id, size, sector) to market events. I don't think we should attempt to do anything special for the unobservable events from legacy prove commit sector though. |
Predicting how an API might be misused is an important part of API design (and UX, in general). In this case, my concern is that users may try to use this information the same way you are, but with more severe consequences if something goes wrong (and therefore more incentive for SPs to send bad notifications).
We don't need the piece CIDs for deduplication, just the deal IDs from the deal activation events (and later, the deal IDs in the market state). The key difference between our two proposals is which information we keep:
This actually means less work in the future. When we drop support for the old (and yeah, we should have had this discussion in a threaded forum) |
Every solution we've discussed involves diffing the market state to detect deals from ProveCommit. The goal here is to avoid double counting. I'd actually prefer the last solution I proposed for the reason I stated in my previous comment. |
Removed Updated original post to detail just the changes here now. |
* Remove "client" from verifier-balance event, for consideration separately
37011fb
to
5b85d00
Compare
move "sector" to the end of claim events to match implementation
@anorth @Stebalien 👍 I hear you and I agree we have other alternatives thats better. |
Editor: thanks all for the user feedback and peer reviews! These changes LGTM, other than the verifreg expiration fields which I believe was suggested to be replaced. If that's changed, @rvagg @aarshkshah1992 can you link us the latest thread where alignment was made? |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I took the editorial liberty of fixing the typos.
Discussion inline at: #964 (comment)
|
I'm happy to add |
Added |
…coin-project#964 "client" in verifier-balance was merge-resolved out Closes: filecoin-project#971
The current proposal here, after discussion, negotiation and splitting out the slightly more difficult pieces comes down to the following, which is all focused on augmenting existing verified registry events with easily accessible information that can be used to match up to sector activations and/or market state data.
"
(to make it easier to grep and awk) and table alignment and other minor formatting issues that GitHub diff does a good job of highlighting.allocation
"piece-cid"
and"piece-size"
"term-max"
and"term-min"
"expiration"
allocation-removed
"piece-cid"
and"piece-size"
"term-max"
and"term-min"
"expiration"
claim
"piece-cid"
and"piece-size"
"sector"
(ID)"term-max"
and"term-min"
claim-updated
"piece-cid"
and"piece-size"
"sector"
(ID)"term-max"
and"term-min"
claim-removed
"piece-cid"
and"piece-size"
"sector"
(ID)"term-max"
and"term-min"
Click to expand original post
This is a revisit of #955, a proposal to add additional information to built-in actor events, but adds more information across more events than #955 did. That PR was discussed further in this thread: #754 (comment), where it was pointed out regarding the costs of these events:
After receiving additional feedback on the information currently available in events, including from a raised awareness of the implications of DDO in network version 22 on observability concerns, we're coming back with this new proposal that we're hoping to get approved and shipped with network version 22.
Given the tight time constraints and concerns about stability, we've attempted to craft a line between "near-to-hand" information (i.e. low-risk, minimal code changes) and "maximally useful" when considering the requirements we are hearing from parties concerned about a DDO world.
A lot of the feedback we have received is related to the verified registry and the difficulties in tracking claims, pieces, SPs and clients and their relationships. The events, as they are currently structured, require reactive state inspection to provide enough context to make sense of them, such as the example of claims outlined #955.
The diff here also includes some formatting changes, so it's a bit noisier than just the pure event changes, sorry. The changes proposed here are summarised as follows:
Verified registry events
verifier-balance
Add"prev-balance"
(zero forAddVerifier
, whereas"balance"
is zero forRemoveVerifier
)"client"
(ID) as optional (only used forAddVerifiedClient
)allocation
"piece-cid"
and"piece-size"
"term-max"
and"term-min"
"expiration"
allocation-removed
"piece-cid"
and"piece-size"
"term-max"
and"term-min"
"expiration"
claim
"piece-cid"
and"piece-size"
"sector"
(ID)"term-max"
and"term-min"
Add"expiration"
claim-updated
"piece-cid"
and"piece-size"
"sector"
(ID)"term-max"
and"term-min"
Add"prev-term-max"
Add"expiration"
claim-removed
"piece-cid"
and"piece-size"
"sector"
(ID)"term-max"
and"term-min"
Add"expiration"
Market actor events
No changes, these are complicated because there's so much information possible to include (e.g. all
DealProposal
could be included on all of these events) and can be revisited in a future FIP according to feedback. Hopefully many existing workflows will be sufficient where the market actor is involved.Miner actor events
sector-activated
Add"expiration-epoch"
Add"claim"
(ID) to couple with each"piece-cid"
&"piece-size"
pair where a claim is madesector-updated
Add"expiration-epoch"
Add"claim"
(ID) to couple with each"piece-cid"
&"piece-size"
pair where a claim is madeDiscussion: #754 (comment)