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

[PVM] Add the functionality of multisig alias definition removal in MultisigAliasTx #356

Merged
merged 1 commit into from
Jul 25, 2024
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
14 changes: 10 additions & 4 deletions vms/components/multisig/camino_multisig.go
Original file line number Diff line number Diff line change
Expand Up @@ -17,16 +17,19 @@ import (
// MaxMemoSize is the maximum number of bytes in the memo field
const MaxMemoSize = 256

var errMemoIsToBig = errors.New("msig alias memo is to big")

var (
_ snow.ContextInitializable = (*Alias)(nil)
_ verify.Verifiable = (*Alias)(nil)

errMemoIsTooBig = errors.New("msig alias memo is too big")
errEmptyAlias = errors.New("alias id and alias owners cannot be empty both at the same time")
)

type Owners interface {
snow.ContextInitializable
verify.Verifiable

IsZero() bool
}

type Alias struct {
Expand All @@ -49,8 +52,11 @@ func (ma *Alias) InitCtx(ctx *snow.Context) {
}

func (ma *Alias) Verify() error {
if len(ma.Memo) > MaxMemoSize {
return fmt.Errorf("%w: expected not greater than %d bytes, got %d bytes", errMemoIsToBig, MaxMemoSize, len(ma.Memo))
switch {
case len(ma.Memo) > MaxMemoSize:
return fmt.Errorf("%w: expected not greater than %d bytes, got %d bytes", errMemoIsTooBig, MaxMemoSize, len(ma.Memo))
case ma.Owners.IsZero() && ma.ID == ids.ShortEmpty:
return errEmptyAlias
}

return ma.Owners.Verify()
Expand Down
24 changes: 19 additions & 5 deletions vms/components/multisig/camino_multisig_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -13,20 +13,34 @@ import (
"github.com/ava-labs/avalanchego/vms/components/avax"
)

var _ Owners = (*testOwners)(nil)

type testOwners struct {
avax.TestState
isEmpty bool
}

func (o testOwners) IsZero() bool { return o.isEmpty }

func TestVerify(t *testing.T) {
tests := map[string]struct {
alias Alias
message string
expectedErr error
}{
"MemoSizeShouldBeLowerThanMaxMemoSize": {
"Memo size should be lower than maxMemoSize": {
alias: Alias{
Owners: &avax.TestState{},
Owners: &testOwners{},
Memo: make([]byte, avax.MaxMemoSize+1),
ID: hashing.ComputeHash160Array(ids.Empty[:]),
},
message: "memo size should be lower than max memo size",
expectedErr: errMemoIsToBig,
expectedErr: errMemoIsTooBig,
},
"Zero owners": {
alias: Alias{
ID: ids.ShortEmpty,
Owners: &testOwners{isEmpty: true},
},
expectedErr: errEmptyAlias,
},
}
for name, tt := range tests {
Expand Down
4 changes: 2 additions & 2 deletions vms/platformvm/dac/camino_add_member_proposal_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -39,7 +39,7 @@ func TestAddMemberProposalVerify(t *testing.T) {
},
expectedErr: errEndNotAfterStart,
},
"To small duration": {
"Too small duration": {
proposal: &AddMemberProposal{
Start: 100,
End: 100 + AddMemberProposalDuration - 1,
Expand All @@ -50,7 +50,7 @@ func TestAddMemberProposalVerify(t *testing.T) {
},
expectedErr: errWrongDuration,
},
"To big duration": {
"Too big duration": {
proposal: &AddMemberProposal{
Start: 100,
End: 100 + AddMemberProposalDuration + 1,
Expand Down
4 changes: 2 additions & 2 deletions vms/platformvm/dac/camino_exclude_member_proposal_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -39,7 +39,7 @@ func TestExcludeMemberProposalVerify(t *testing.T) {
},
expectedErr: errEndNotAfterStart,
},
"To small duration": {
"Too small duration": {
proposal: &ExcludeMemberProposal{
Start: 100,
End: 100 + ExcludeMemberProposalMinDuration - 1,
Expand All @@ -50,7 +50,7 @@ func TestExcludeMemberProposalVerify(t *testing.T) {
},
expectedErr: errWrongDuration,
},
"To big duration": {
"Too big duration": {
proposal: &ExcludeMemberProposal{
Start: 100,
End: 100 + ExcludeMemberProposalMaxDuration + 1,
Expand Down
6 changes: 3 additions & 3 deletions vms/platformvm/dac/camino_general_proposal.go
Original file line number Diff line number Diff line change
Expand Up @@ -28,8 +28,8 @@ var (
_ Proposal = (*GeneralProposal)(nil)
_ ProposalState = (*GeneralProposalState)(nil)

errGeneralProposalOptionIsToBig = errors.New("option size is to big")
errNotImplemented = errors.New("not implemented, should never be called")
errGeneralProposalOptionIsTooBig = errors.New("option size is too big")
errNotImplemented = errors.New("not implemented, should never be called")
)

type GeneralProposal struct {
Expand Down Expand Up @@ -84,7 +84,7 @@ func (p *GeneralProposal) Verify() error {
for i := 0; i < len(p.Options); i++ {
if len(p.Options[i]) > generalProposalMaxOptionSize {
return fmt.Errorf("%w (expected: no more than %d, actual: %d, option index: %d)",
errGeneralProposalOptionIsToBig, generalProposalMaxOptionSize, len(p.Options[i]), i)
errGeneralProposalOptionIsTooBig, generalProposalMaxOptionSize, len(p.Options[i]), i)
}
for j := i + 1; j < len(p.Options); j++ {
if bytes.Equal(p.Options[i], p.Options[j]) {
Expand Down
6 changes: 3 additions & 3 deletions vms/platformvm/dac/camino_general_proposal_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -69,7 +69,7 @@ func TestGeneralProposalVerify(t *testing.T) {
},
expectedErr: errEndNotAfterStart,
},
"To small duration": {
"Too small duration": {
proposal: &GeneralProposal{
Start: 100,
End: 100 + GeneralProposalMinDuration - 1,
Expand All @@ -82,7 +82,7 @@ func TestGeneralProposalVerify(t *testing.T) {
},
expectedErr: errWrongDuration,
},
"To big duration": {
"Too big duration": {
proposal: &GeneralProposal{
Start: 100,
End: 100 + generalProposalMaxDuration + 1,
Expand All @@ -106,7 +106,7 @@ func TestGeneralProposalVerify(t *testing.T) {
End: 100 + GeneralProposalMinDuration,
Options: [][]byte{make([]byte, generalProposalMaxOptionSize+1)},
},
expectedErr: errGeneralProposalOptionIsToBig,
expectedErr: errGeneralProposalOptionIsTooBig,
},
"Not unique option": {
proposal: &GeneralProposal{
Expand Down
4 changes: 2 additions & 2 deletions vms/platformvm/state/camino.go
Original file line number Diff line number Diff line change
Expand Up @@ -108,7 +108,7 @@ type CaminoDiff interface {
// Multisig Owners

GetMultisigAlias(ids.ShortID) (*multisig.AliasWithNonce, error)
SetMultisigAlias(*multisig.AliasWithNonce)
SetMultisigAlias(ids.ShortID, *multisig.AliasWithNonce)

// ShortIDsLink

Expand Down Expand Up @@ -425,7 +425,7 @@ func (cs *caminoState) syncGenesis(s *state, g *genesis.Genesis) error {
// adding msig aliases

for _, multisigAlias := range g.Camino.MultisigAliases {
cs.SetMultisigAlias(&multisig.AliasWithNonce{Alias: *multisigAlias})
cs.SetMultisigAlias(multisigAlias.ID, &multisig.AliasWithNonce{Alias: *multisigAlias})
}

// adding blocks (validators and deposits)
Expand Down
2 changes: 1 addition & 1 deletion vms/platformvm/state/camino_address_state.go
Original file line number Diff line number Diff line change
Expand Up @@ -44,7 +44,7 @@ func (cs *caminoState) GetAddressStates(address ids.ShortID) (as.AddressState, e
func (cs *caminoState) writeAddressStates() error {
for key, val := range cs.modifiedAddressStates {
delete(cs.modifiedAddressStates, key)
if val == 0 {
if val == as.AddressStateEmpty {
if err := cs.addressStateDB.Delete(key[:]); err != nil {
return err
}
Expand Down
8 changes: 4 additions & 4 deletions vms/platformvm/state/camino_diff.go
Original file line number Diff line number Diff line change
Expand Up @@ -273,8 +273,8 @@ func (d *diff) GetNextToUnlockDepositIDsAndTime(removedDepositIDs set.Set[ids.ID
return nextDepositIDs, nextUnlockTime, nil
}

func (d *diff) SetMultisigAlias(alias *multisig.AliasWithNonce) {
d.caminoDiff.modifiedMultisigAliases[alias.ID] = alias
func (d *diff) SetMultisigAlias(id ids.ShortID, alias *multisig.AliasWithNonce) {
d.caminoDiff.modifiedMultisigAliases[id] = alias
}

func (d *diff) GetMultisigAlias(alias ids.ShortID) (*multisig.AliasWithNonce, error) {
Expand Down Expand Up @@ -682,8 +682,8 @@ func (d *diff) ApplyCaminoState(baseState State) error {
}
}

for _, v := range d.caminoDiff.modifiedMultisigAliases {
baseState.SetMultisigAlias(v)
for multisigAliasID, multisigAlias := range d.caminoDiff.modifiedMultisigAliases {
baseState.SetMultisigAlias(multisigAliasID, multisigAlias)
}

for fullKey, link := range d.caminoDiff.modifiedShortLinks {
Expand Down
6 changes: 3 additions & 3 deletions vms/platformvm/state/camino_diff_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -2375,7 +2375,7 @@ func TestDiffSetMultisigAlias(t *testing.T) {
}
for name, tt := range tests {
t.Run(name, func(t *testing.T) {
tt.diff.SetMultisigAlias(tt.alias)
tt.diff.SetMultisigAlias(tt.alias.ID, tt.alias)
require.Equal(t, tt.expectedDiff, tt.diff)
})
}
Expand Down Expand Up @@ -5166,8 +5166,8 @@ func TestDiffApplyCaminoState(t *testing.T) {
s.EXPECT().ModifyDeposit(depositTxID, depositDiff.Deposit)
}
}
for _, v := range d.caminoDiff.modifiedMultisigAliases {
s.EXPECT().SetMultisigAlias(v)
for multisigAliasID, multisigAlias := range d.caminoDiff.modifiedMultisigAliases {
s.EXPECT().SetMultisigAlias(multisigAliasID, multisigAlias)
}
for fullKey, link := range d.caminoDiff.modifiedShortLinks {
id, key := fromShortLinkKey(fullKey)
Expand Down
6 changes: 3 additions & 3 deletions vms/platformvm/state/camino_multisig_alias.go
Original file line number Diff line number Diff line change
Expand Up @@ -19,9 +19,9 @@ type msigAlias struct {
Nonce uint64 `serialize:"true"`
}

func (cs *caminoState) SetMultisigAlias(ma *multisig.AliasWithNonce) {
cs.modifiedMultisigAliases[ma.ID] = ma
cs.multisigAliasesCache.Evict(ma.ID)
func (cs *caminoState) SetMultisigAlias(id ids.ShortID, ma *multisig.AliasWithNonce) {
cs.modifiedMultisigAliases[id] = ma
cs.multisigAliasesCache.Evict(id)
}

func (cs *caminoState) GetMultisigAlias(id ids.ShortID) (*multisig.AliasWithNonce, error) {
Expand Down
2 changes: 1 addition & 1 deletion vms/platformvm/state/camino_multisig_alias_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -223,7 +223,7 @@ func TestSetMultisigAlias(t *testing.T) {
for name, tt := range tests {
t.Run(name, func(t *testing.T) {
caminoState := tt.caminoState(gomock.NewController(t))
caminoState.SetMultisigAlias(tt.multisigAlias)
caminoState.SetMultisigAlias(tt.multisigAlias.ID, tt.multisigAlias)
require.Equal(t, tt.expectedCaminoState(caminoState), caminoState)
})
}
Expand Down
4 changes: 2 additions & 2 deletions vms/platformvm/state/camino_state.go
Original file line number Diff line number Diff line change
Expand Up @@ -94,8 +94,8 @@ func (s *state) GetNextToUnlockDepositIDsAndTime(removedDepositIDs set.Set[ids.I
return s.caminoState.GetNextToUnlockDepositIDsAndTime(removedDepositIDs)
}

func (s *state) SetMultisigAlias(owner *multisig.AliasWithNonce) {
s.caminoState.SetMultisigAlias(owner)
func (s *state) SetMultisigAlias(id ids.ShortID, owner *multisig.AliasWithNonce) {
s.caminoState.SetMultisigAlias(id, owner)
}

func (s *state) GetMultisigAlias(alias ids.ShortID) (*multisig.AliasWithNonce, error) {
Expand Down
8 changes: 4 additions & 4 deletions vms/platformvm/state/mock_chain.go

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

8 changes: 4 additions & 4 deletions vms/platformvm/state/mock_diff.go

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

8 changes: 4 additions & 4 deletions vms/platformvm/state/mock_state.go

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

2 changes: 1 addition & 1 deletion vms/platformvm/txs/camino_deposit_tx.go
Original file line number Diff line number Diff line change
Expand Up @@ -19,7 +19,7 @@ import (
var (
_ UnsignedTx = (*DepositTx)(nil)

errTooBigDeposit = errors.New("to big deposit")
errTooBigDeposit = errors.New("too big deposit")
errInvalidRewardOwner = errors.New("invalid reward owner")
errBadOfferOwnerAuth = errors.New("bad offer owner auth")
errBadDepositCreatorAuth = errors.New("bad deposit creator auth")
Expand Down
2 changes: 1 addition & 1 deletion vms/platformvm/txs/camino_deposit_tx_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -38,7 +38,7 @@ func TestDepositTxSyntacticVerify(t *testing.T) {
},
expectedErr: errInvalidRewardOwner,
},
"To big total deposit amount": {
"Too big total deposit amount": {
tx: &DepositTx{
BaseTx: BaseTx{BaseTx: avax.BaseTx{
NetworkID: ctx.NetworkID,
Expand Down
5 changes: 3 additions & 2 deletions vms/platformvm/txs/camino_multisig_alias_tx.go
Original file line number Diff line number Diff line change
Expand Up @@ -14,8 +14,9 @@ import (
)

var (
_ UnsignedTx = (*MultisigAliasTx)(nil)
errFailedToVerifyAliasOrAuth = errors.New("failed to verify alias or auth")
_ UnsignedTx = (*MultisigAliasTx)(nil)

errFailedToVerifyAliasOrAuth = errors.New("failed to verify alias or auth")
)

// MultisigAliasTx is an unsigned multisig alias tx
Expand Down
Loading
Loading