-
Notifications
You must be signed in to change notification settings - Fork 3.7k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request #8444 from cosmos/release/v0.40.x
Release v0.41.0
- Loading branch information
Showing
17 changed files
with
608 additions
and
119 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,45 +1,30 @@ | ||
# Cosmos SDK v0.40.1 "Stargate" Release Notes | ||
# Cosmos SDK v0.41.0 "Stargate" Release Notes | ||
|
||
This is a bug fix release to the *Cosmos SDK 0.40* "Stargate" release series. No breaking changes are introduced, thus no migration should be needed. | ||
Among the various bugfixes, this release introduces important security patches. | ||
This release includes two breaking changes, and a few minor bugfixes. | ||
|
||
See the [Cosmos SDK v0.40.1 milestone](https://github.com/cosmos/cosmos-sdk/milestone/36?closed=1) on our issue tracker for details. | ||
See the [Cosmos SDK v0.41.0 milestone](https://github.com/cosmos/cosmos-sdk/milestone/37?closed=1) on our issue tracker for details. | ||
|
||
### Gogo protobuf security release | ||
### Support Amino JSON for IBC MsgTransfer | ||
|
||
[Gogoprotobuf](https://github.com/gogo/protobuf) released a bugfix addressing [CVE-2021-3121](https://nvd.nist.gov/vuln/detail/CVE-2021-3121). Cosmos SDK respective dependency has been updated and protobuf generated files were regenerated. | ||
This change **breaks state backward compatibility**. | ||
|
||
### Tendermint security patches | ||
At the moment hardware wallets are [unable to sign messages using `SIGN_MODE_DIRECT` because the cosmos ledger app does not support proto encoding and`SIGN_MODE_TEXTUAL` is not available yet](https://https://github.com/cosmos/cosmos-sdk/issues/8266). | ||
|
||
This release comes with a newer release of Tendermint that, other than fixing various bugs it also addresses a high-severity security vulnerability. | ||
For the comprehensive list of changes introduced by Tendermint since Cosmos SDK v0.40.0, please refer to [Tendermint's v0.34.3 release notes](https://github.com/tendermint/tendermint/blob/v0.34.3/CHANGELOG.md#v0.34.3). | ||
In order to enable hardware wallets users to interact with IBC, amino JSON support was added to `MsgTransfer` only. | ||
|
||
### Fix zero time checks | ||
### Counterparty.ChannelID not available in OnChanOpenAck callback implementation. | ||
|
||
In Cosmos SDK applications, it is recommended to use `Time.Unix() <= 0` instead of `Time.IsZero()`, which may lead to unexpected results. | ||
See [\#8085](https://github.com/cosmos/cosmos-sdk/pull/8058) for more information. | ||
This change **breaks state backward compatibility**. | ||
|
||
### Querying upgrade plans panics when no plan exists | ||
In a previous version the `Counterparty.ChannelID` was available for an `OnChanOpenAck` callback implementation (read via `channelKeeper.GetChannel()`. Due to a regression, the channelID is currently empty. | ||
|
||
The `x/upgrade` module command and REST endpoints for querying upgrade plans would panic when no plan existed. This is now resolved. | ||
The issue has been fixed by reordering IBC `ChanOpenAck` and `ChanOpenConfirm` to execute the core handlers logic first, followed by application callbacks. | ||
|
||
### Fix account sequence | ||
It breaks state backward compatibility because the current change consumes more gas, which means that in an updated node a TX might fail because it ran out of gas whilst in older versions it would be successful. | ||
|
||
In Cosmos SDK v0.40.0 a new structure (`SignatureV2`) for handling message signatures was introduced. | ||
Although the `tx sign --signature-only` command was still capable of generating correct signatures, it was not returning the account's correct sequence number. | ||
### Bug Fixes | ||
|
||
### Reproducible builds | ||
Now `x/bank` correctly verifies balances and metadata at init genesis stage. | ||
|
||
Our automatic builds were not working correctly due to small gaps in file paths. Fixed in [\8300](https://github.com/cosmos/cosmos-sdk/pull/8300) and [\8301](https://github.com/cosmos/cosmos-sdk/pull/8301). | ||
`simapp` correctly adds the coins of genesis accounts to supply. | ||
|
||
### Wrapper errors were not reflective | ||
|
||
Cosmos SDK errors typically support the `Is()` method. The `Go` `errors.Is()` function compares an error to a value and should always return `true` when the receiver is passed as an argument to its own method, e.g. `err.Is(err)`. This was not a case for the error types provided by the `types/errors` package. | ||
|
||
### Fix latest consensus state | ||
|
||
Errors occur when using the client to send IBC transactions without flag `--absolute-timeouts`, e.g: | ||
|
||
gaiad tx ibc-transfer transfer | ||
|
||
The issue was caused by incorrect interface decoding and unpacking of `Any` values and is now fixed. |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,93 @@ | ||
package types | ||
|
||
import ( | ||
"bytes" | ||
"encoding/json" | ||
fmt "fmt" | ||
"sort" | ||
|
||
"github.com/cosmos/cosmos-sdk/codec" | ||
sdk "github.com/cosmos/cosmos-sdk/types" | ||
"github.com/cosmos/cosmos-sdk/x/bank/exported" | ||
) | ||
|
||
var _ exported.GenesisBalance = (*Balance)(nil) | ||
|
||
// GetAddress returns the account address of the Balance object. | ||
func (b Balance) GetAddress() sdk.AccAddress { | ||
addr, _ := sdk.AccAddressFromBech32(b.Address) | ||
return addr | ||
} | ||
|
||
// GetCoins returns the account coins of the Balance object. | ||
func (b Balance) GetCoins() sdk.Coins { | ||
return b.Coins | ||
} | ||
|
||
// Validate checks for address and coins correctness. | ||
func (b Balance) Validate() error { | ||
_, err := sdk.AccAddressFromBech32(b.Address) | ||
if err != nil { | ||
return err | ||
} | ||
|
||
if len(b.Coins) == 0 { | ||
return fmt.Errorf("empty or nil coins for address %s", b.Address) | ||
} | ||
|
||
seenDenoms := make(map[string]bool) | ||
|
||
// NOTE: we perform a custom validation since the coins.Validate function | ||
// errors on zero balance coins | ||
for _, coin := range b.Coins { | ||
if seenDenoms[coin.Denom] { | ||
return fmt.Errorf("duplicate denomination %s", coin.Denom) | ||
} | ||
|
||
if err := sdk.ValidateDenom(coin.Denom); err != nil { | ||
return err | ||
} | ||
|
||
if coin.IsNegative() { | ||
return fmt.Errorf("coin %s amount is cannot be negative", coin.Denom) | ||
} | ||
|
||
seenDenoms[coin.Denom] = true | ||
} | ||
|
||
// sort the coins post validation | ||
b.Coins = b.Coins.Sort() | ||
|
||
return nil | ||
} | ||
|
||
// SanitizeGenesisBalances sorts addresses and coin sets. | ||
func SanitizeGenesisBalances(balances []Balance) []Balance { | ||
sort.Slice(balances, func(i, j int) bool { | ||
addr1, _ := sdk.AccAddressFromBech32(balances[i].Address) | ||
addr2, _ := sdk.AccAddressFromBech32(balances[j].Address) | ||
return bytes.Compare(addr1.Bytes(), addr2.Bytes()) < 0 | ||
}) | ||
|
||
for _, balance := range balances { | ||
balance.Coins = balance.Coins.Sort() | ||
} | ||
|
||
return balances | ||
} | ||
|
||
// GenesisBalancesIterator implements genesis account iteration. | ||
type GenesisBalancesIterator struct{} | ||
|
||
// IterateGenesisBalances iterates over all the genesis balances found in | ||
// appGenesis and invokes a callback on each genesis account. If any call | ||
// returns true, iteration stops. | ||
func (GenesisBalancesIterator) IterateGenesisBalances( | ||
cdc codec.JSONMarshaler, appState map[string]json.RawMessage, cb func(exported.GenesisBalance) (stop bool), | ||
) { | ||
for _, balance := range GetGenesisStateFromAppState(cdc, appState).Balances { | ||
if cb(balance) { | ||
break | ||
} | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,80 @@ | ||
package types | ||
|
||
import ( | ||
"testing" | ||
|
||
"github.com/stretchr/testify/require" | ||
|
||
sdk "github.com/cosmos/cosmos-sdk/types" | ||
) | ||
|
||
func TestBalanceValidate(t *testing.T) { | ||
|
||
testCases := []struct { | ||
name string | ||
balance Balance | ||
expErr bool | ||
}{ | ||
{ | ||
"valid balance", | ||
Balance{ | ||
Address: "cosmos1yq8lgssgxlx9smjhes6ryjasmqmd3ts2559g0t", | ||
Coins: sdk.Coins{sdk.NewInt64Coin("uatom", 1)}, | ||
}, | ||
false, | ||
}, | ||
{"empty balance", Balance{}, true}, | ||
{ | ||
"nil balance coins", | ||
Balance{ | ||
Address: "cosmos1yq8lgssgxlx9smjhes6ryjasmqmd3ts2559g0t", | ||
}, | ||
true, | ||
}, | ||
{ | ||
"dup coins", | ||
Balance{ | ||
Address: "cosmos1yq8lgssgxlx9smjhes6ryjasmqmd3ts2559g0t", | ||
Coins: sdk.Coins{ | ||
sdk.NewInt64Coin("uatom", 1), | ||
sdk.NewInt64Coin("uatom", 1), | ||
}, | ||
}, | ||
true, | ||
}, | ||
{ | ||
"invalid coin denom", | ||
Balance{ | ||
Address: "cosmos1yq8lgssgxlx9smjhes6ryjasmqmd3ts2559g0t", | ||
Coins: sdk.Coins{ | ||
sdk.Coin{Denom: "", Amount: sdk.OneInt()}, | ||
}, | ||
}, | ||
true, | ||
}, | ||
{ | ||
"negative coin", | ||
Balance{ | ||
Address: "cosmos1yq8lgssgxlx9smjhes6ryjasmqmd3ts2559g0t", | ||
Coins: sdk.Coins{ | ||
sdk.Coin{Denom: "uatom", Amount: sdk.NewInt(-1)}, | ||
}, | ||
}, | ||
true, | ||
}, | ||
} | ||
|
||
for _, tc := range testCases { | ||
tc := tc | ||
t.Run(tc.name, func(t *testing.T) { | ||
|
||
err := tc.balance.Validate() | ||
|
||
if tc.expErr { | ||
require.Error(t, err) | ||
} else { | ||
require.NoError(t, err) | ||
} | ||
}) | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.