-
Notifications
You must be signed in to change notification settings - Fork 212
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
feat: Reputation: CNS-1004 - QoS excellence epoch score aggregation #1612
base: CNS-1003-reputation-proto-definitions
Are you sure you want to change the base?
Changes from 19 commits
54a0136
e3f0183
4471779
d1a4117
841e0e8
32a544c
1a599a0
5e56157
2ff09f5
994e762
13deb57
31f5ddd
21e2819
8a34d74
b7c747f
e374c8b
c7e2a57
5ad9aae
ee2cf55
2262838
600464d
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -170,6 +170,22 @@ func (k msgServer) RelayPayment(goCtx context.Context, msg *types.MsgRelayPaymen | |
k.handleBadgeCu(ctx, badgeData, relay.Provider, relay.CuSum, newBadgeTimerExpiry) | ||
} | ||
|
||
// update the reputation's epoch QoS score | ||
// the excellece QoS report can be nil when the provider and consumer geolocations are not equal | ||
if relay.QosExcellenceReport != nil { | ||
err = k.updateReputationEpochQosScore(ctx, project.Subscription, relay) | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. change the name of the method since we have another one with the same name There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. done. see 600464d |
||
if err != nil { | ||
return nil, utils.LavaFormatWarning("RelayPayment: could not update reputation epoch QoS score", err, | ||
utils.LogAttr("consumer", project.Subscription), | ||
utils.LogAttr("project", project.Index), | ||
utils.LogAttr("chain", relay.SpecId), | ||
utils.LogAttr("provider", relay.Provider), | ||
utils.LogAttr("qos_excellence_report", relay.QosExcellenceReport.String()), | ||
utils.LogAttr("sync_factor", k.ReputationLatencyOverSyncFactor(ctx).String()), | ||
) | ||
} | ||
} | ||
|
||
// TODO: add support for spec changes | ||
spec, found := k.specKeeper.GetSpec(ctx, relay.SpecId) | ||
if !found || !spec.Enabled { | ||
|
@@ -473,3 +489,40 @@ func (k Keeper) handleBadgeCu(ctx sdk.Context, badgeData BadgeData, provider str | |
badgeUsedCuMapEntry.UsedCu += relayCuSum | ||
k.SetBadgeUsedCu(ctx, badgeUsedCuMapEntry) | ||
} | ||
|
||
func (k Keeper) updateReputationEpochQosScore(ctx sdk.Context, subscription string, relay *types.RelaySession) error { | ||
sub, found := k.subscriptionKeeper.GetSubscription(ctx, subscription) | ||
if !found { | ||
return utils.LavaFormatError("RelayPayment: could not get cluster for reputation score update", fmt.Errorf("relay consumer's subscription not found"), | ||
utils.LogAttr("subscription", subscription), | ||
utils.LogAttr("chain", relay.SpecId), | ||
utils.LogAttr("provider", relay.Provider), | ||
) | ||
} | ||
|
||
syncFactor := k.ReputationLatencyOverSyncFactor(ctx) | ||
score, err := relay.QosExcellenceReport.ComputeQosExcellenceForReputation(syncFactor) | ||
if err != nil { | ||
return utils.LavaFormatWarning("RelayPayment: could not compute qos excellence score", err, | ||
utils.LogAttr("consumer", subscription), | ||
utils.LogAttr("chain", relay.SpecId), | ||
utils.LogAttr("provider", relay.Provider), | ||
utils.LogAttr("qos_excellence_report", relay.QosExcellenceReport.String()), | ||
utils.LogAttr("sync_factor", syncFactor.String()), | ||
) | ||
} | ||
|
||
stakeEntry, found := k.epochStorageKeeper.GetStakeEntryCurrent(ctx, relay.SpecId, relay.Provider) | ||
if !found { | ||
return utils.LavaFormatWarning("RelayPayment: could not get stake entry for reputation", fmt.Errorf("stake entry not found"), | ||
utils.LogAttr("consumer", subscription), | ||
utils.LogAttr("chain", relay.SpecId), | ||
utils.LogAttr("provider", relay.Provider), | ||
) | ||
} | ||
effectiveStake := sdk.NewCoin(stakeEntry.Stake.Denom, stakeEntry.TotalStake()) | ||
|
||
// note the current weight used is by relay num. In the future, it might change | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. can you explain why this is? afaik this is just an incrementing number to count sessions (?) There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. The goal was to give more weight to relay payments with lots of relays. I also remember is the counter, will fix later There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. done. see 600464d |
||
k.UpdateReputationEpochQosScore(ctx, relay.SpecId, sub.Cluster, relay.Provider, score, utils.SafeUint64ToInt64Convert(relay.RelayNum), effectiveStake) | ||
return nil | ||
} |
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -97,6 +97,32 @@ func (k Keeper) GetAllReputation(ctx sdk.Context) []types.ReputationGenesis { | |
return entries | ||
} | ||
|
||
// UpdateReputationEpochQosScore updates the epoch QoS score of the provider's reputation using the score from the relay | ||
// payment's QoS excellence report | ||
func (k Keeper) UpdateReputationEpochQosScore(ctx sdk.Context, chainID string, cluster string, provider string, score math.LegacyDec, weight int64, stake sdk.Coin) { | ||
// get current reputation and get parameters for the epoch score update | ||
r, found := k.GetReputation(ctx, chainID, cluster, provider) | ||
truncate := false | ||
if found { | ||
stabilizationPeriod := k.ReputationVarianceStabilizationPeriod(ctx) | ||
if r.ShouldTruncate(stabilizationPeriod, ctx.BlockTime().UTC().Unix()) { | ||
truncate = true | ||
} | ||
} else { | ||
// new reputation score is not truncated and its decay factor is equal to 1 | ||
r = types.NewReputation(ctx) | ||
} | ||
|
||
// calculate the updated QoS epoch score | ||
updatedEpochScore := r.EpochScore.Update(score, truncate, weight) | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. can we make this in place method? There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. done. see 600464d |
||
|
||
// update the reputation and set | ||
r.EpochScore = updatedEpochScore | ||
r.TimeLastUpdated = ctx.BlockTime().UTC().Unix() | ||
r.Stake = stake | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. why is the stake needed? There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. from the comment in the proto:
You'll see it in the next parts |
||
k.SetReputation(ctx, chainID, cluster, provider, r) | ||
} | ||
|
||
// GetReputationScore returns the current reputation pairing score | ||
func (k Keeper) GetReputationScore(ctx sdk.Context, chainID string, cluster string, provider string) (val math.LegacyDec, found bool) { | ||
block := uint64(ctx.BlockHeight()) | ||
|
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.
better in a function for readability
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.
done. see 5ad9aae