mirror of
https://github.com/0glabs/0g-chain.git
synced 2025-01-27 15:35:17 +00:00
apply various PR comments
This commit is contained in:
parent
c17de631d2
commit
631b87eaf0
@ -78,7 +78,6 @@ func (k Keeper) AddVote(ctx sdk.Context, proposalID uint64, voter sdk.AccAddress
|
|||||||
}
|
}
|
||||||
|
|
||||||
// GetProposalResult calculates if a proposal currently has enough votes to pass.
|
// GetProposalResult calculates if a proposal currently has enough votes to pass.
|
||||||
// TODO rename GetProposalTally?
|
|
||||||
func (k Keeper) GetProposalResult(ctx sdk.Context, proposalID uint64) (bool, sdk.Error) {
|
func (k Keeper) GetProposalResult(ctx sdk.Context, proposalID uint64) (bool, sdk.Error) {
|
||||||
pr, found := k.GetProposal(ctx, proposalID)
|
pr, found := k.GetProposal(ctx, proposalID)
|
||||||
if !found {
|
if !found {
|
||||||
@ -123,23 +122,23 @@ func (k Keeper) EnactProposal(ctx sdk.Context, proposalID uint64) sdk.Error {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// CloseExpiredProposals removes proposals (and associated votes) that have past their deadline.
|
// CloseExpiredProposals removes proposals (and associated votes) that have past their deadline.
|
||||||
// TODO rename to RemoveExpiredProposals?
|
|
||||||
func (k Keeper) CloseExpiredProposals(ctx sdk.Context) {
|
func (k Keeper) CloseExpiredProposals(ctx sdk.Context) {
|
||||||
|
|
||||||
k.IterateProposals(ctx, func(proposal types.Proposal) bool {
|
k.IterateProposals(ctx, func(proposal types.Proposal) bool {
|
||||||
if proposal.HasExpiredBy(ctx.BlockTime()) {
|
if !proposal.HasExpiredBy(ctx.BlockTime()) {
|
||||||
|
return false
|
||||||
k.DeleteProposalAndVotes(ctx, proposal.ID)
|
|
||||||
|
|
||||||
ctx.EventManager().EmitEvent(
|
|
||||||
sdk.NewEvent(
|
|
||||||
types.EventTypeProposalClose,
|
|
||||||
sdk.NewAttribute(types.AttributeKeyCommitteeID, fmt.Sprintf("%d", proposal.CommitteeID)),
|
|
||||||
sdk.NewAttribute(types.AttributeKeyProposalID, fmt.Sprintf("%d", proposal.ID)),
|
|
||||||
sdk.NewAttribute(types.AttributeKeyProposalCloseStatus, types.AttributeValueProposalTimeout),
|
|
||||||
),
|
|
||||||
)
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
k.DeleteProposalAndVotes(ctx, proposal.ID)
|
||||||
|
|
||||||
|
ctx.EventManager().EmitEvent(
|
||||||
|
sdk.NewEvent(
|
||||||
|
types.EventTypeProposalClose,
|
||||||
|
sdk.NewAttribute(types.AttributeKeyCommitteeID, fmt.Sprintf("%d", proposal.CommitteeID)),
|
||||||
|
sdk.NewAttribute(types.AttributeKeyProposalID, fmt.Sprintf("%d", proposal.ID)),
|
||||||
|
sdk.NewAttribute(types.AttributeKeyProposalCloseStatus, types.AttributeValueProposalTimeout),
|
||||||
|
),
|
||||||
|
)
|
||||||
return false
|
return false
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
@ -29,9 +29,10 @@ func handleCommitteeChangeProposal(ctx sdk.Context, k Keeper, committeeProposal
|
|||||||
|
|
||||||
// Remove all committee's ongoing proposals
|
// Remove all committee's ongoing proposals
|
||||||
k.IterateProposals(ctx, func(p Proposal) bool {
|
k.IterateProposals(ctx, func(p Proposal) bool {
|
||||||
if p.CommitteeID == committeeProposal.NewCommittee.ID {
|
if p.CommitteeID != committeeProposal.NewCommittee.ID {
|
||||||
k.DeleteProposalAndVotes(ctx, p.ID)
|
return false
|
||||||
}
|
}
|
||||||
|
k.DeleteProposalAndVotes(ctx, p.ID)
|
||||||
return false
|
return false
|
||||||
})
|
})
|
||||||
|
|
||||||
@ -47,9 +48,10 @@ func handleCommitteeDeleteProposal(ctx sdk.Context, k Keeper, committeeProposal
|
|||||||
|
|
||||||
// Remove all committee's ongoing proposals
|
// Remove all committee's ongoing proposals
|
||||||
k.IterateProposals(ctx, func(p Proposal) bool {
|
k.IterateProposals(ctx, func(p Proposal) bool {
|
||||||
if p.CommitteeID == committeeProposal.CommitteeID {
|
if p.CommitteeID != committeeProposal.CommitteeID {
|
||||||
k.DeleteProposalAndVotes(ctx, p.ID)
|
return false
|
||||||
}
|
}
|
||||||
|
k.DeleteProposalAndVotes(ctx, p.ID)
|
||||||
return false
|
return false
|
||||||
})
|
})
|
||||||
|
|
||||||
|
@ -21,8 +21,8 @@ type Committee struct {
|
|||||||
Description string `json:"description" yaml:"description"`
|
Description string `json:"description" yaml:"description"`
|
||||||
Members []sdk.AccAddress `json:"members" yaml:"members"`
|
Members []sdk.AccAddress `json:"members" yaml:"members"`
|
||||||
Permissions []Permission `json:"permissions" yaml:"permissions"`
|
Permissions []Permission `json:"permissions" yaml:"permissions"`
|
||||||
VoteThreshold sdk.Dec `json:"vote_threshold" yaml:"vote_threshold"`
|
VoteThreshold sdk.Dec `json:"vote_threshold" yaml:"vote_threshold"` // Smallest percentage of members that must vote for a proposal to pass.
|
||||||
ProposalDuration time.Duration `json:"proposal_duration" yaml:"proposal_duration"`
|
ProposalDuration time.Duration `json:"proposal_duration" yaml:"proposal_duration"` // The length of time a proposal remains active for. Proposals will close earlier if they get enough votes.
|
||||||
}
|
}
|
||||||
|
|
||||||
func NewCommittee(id uint64, description string, members []sdk.AccAddress, permissions []Permission, threshold sdk.Dec, duration time.Duration) Committee {
|
func NewCommittee(id uint64, description string, members []sdk.AccAddress, permissions []Permission, threshold sdk.Dec, duration time.Duration) Committee {
|
||||||
@ -80,22 +80,18 @@ func (c Committee) Validate() error {
|
|||||||
return fmt.Errorf("invalid description")
|
return fmt.Errorf("invalid description")
|
||||||
}
|
}
|
||||||
|
|
||||||
if c.VoteThreshold.IsNil() || c.VoteThreshold.IsNegative() || c.VoteThreshold.GT(sdk.NewDec(1)) {
|
// threshold must be in the range (0,1]
|
||||||
|
if c.VoteThreshold.IsNil() || c.VoteThreshold.LTE(sdk.ZeroDec()) || c.VoteThreshold.GT(sdk.NewDec(1)) {
|
||||||
return fmt.Errorf("invalid threshold")
|
return fmt.Errorf("invalid threshold")
|
||||||
}
|
}
|
||||||
|
|
||||||
if c.ProposalDuration < 0 {
|
if c.ProposalDuration < 0 {
|
||||||
return fmt.Errorf("invalid time")
|
return fmt.Errorf("invalid proposal duration")
|
||||||
}
|
}
|
||||||
|
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
// Permission is anything with a method that validates whether a proposal is allowed by it or not.
|
|
||||||
type Permission interface {
|
|
||||||
Allows(PubProposal) bool
|
|
||||||
}
|
|
||||||
|
|
||||||
// ------------------------------------------
|
// ------------------------------------------
|
||||||
// Proposals
|
// Proposals
|
||||||
// ------------------------------------------
|
// ------------------------------------------
|
||||||
|
@ -13,6 +13,15 @@ func init() {
|
|||||||
gov.RegisterProposalTypeCodec(ParamChangePermission{}, "kava/ParamChangePermission")
|
gov.RegisterProposalTypeCodec(ParamChangePermission{}, "kava/ParamChangePermission")
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Permission is anything with a method that validates whether a proposal is allowed by it or not.
|
||||||
|
type Permission interface {
|
||||||
|
Allows(PubProposal) bool
|
||||||
|
}
|
||||||
|
|
||||||
|
// ------------------------------------------
|
||||||
|
// GodPermission
|
||||||
|
// ------------------------------------------
|
||||||
|
|
||||||
// GodPermission allows any governance proposal. It is used mainly for testing.
|
// GodPermission allows any governance proposal. It is used mainly for testing.
|
||||||
type GodPermission struct{}
|
type GodPermission struct{}
|
||||||
|
|
||||||
@ -29,6 +38,10 @@ func (GodPermission) MarshalYAML() (interface{}, error) {
|
|||||||
return valueToMarshal, nil
|
return valueToMarshal, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// ------------------------------------------
|
||||||
|
// ParamChangePermission
|
||||||
|
// ------------------------------------------
|
||||||
|
|
||||||
// ParamChangeProposal only allows changes to certain params
|
// ParamChangeProposal only allows changes to certain params
|
||||||
type ParamChangePermission struct {
|
type ParamChangePermission struct {
|
||||||
AllowedParams AllowedParams `json:"allowed_params" yaml:"allowed_params"`
|
AllowedParams AllowedParams `json:"allowed_params" yaml:"allowed_params"`
|
||||||
@ -76,6 +89,10 @@ func (allowed AllowedParams) Contains(paramChange params.ParamChange) bool {
|
|||||||
return false
|
return false
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// ------------------------------------------
|
||||||
|
// TextPermission
|
||||||
|
// ------------------------------------------
|
||||||
|
|
||||||
// TextPermission allows any text governance proposal.
|
// TextPermission allows any text governance proposal.
|
||||||
type TextPermission struct{}
|
type TextPermission struct{}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user