Go to file
Federico Kunze Küllmer 5b02bf459f
feat: `ScheduleUpgradeNoHeightValidation` for automated upgrades w/o gov proposal (#11551)
## Description



Implements a `ScheduleUpgradeNoHeightValidation` function for chains to schedule an automated upgrade (using the `x/upgrade` module) without having to go through a governance proposal.

This is beneficial to coordinate upgrades without having to manually download the new version, do the migration and restart the chain.

This is the procedure Evmos used for its automated upgrade.

---

### Author Checklist

*All items are required. Please add a note to the item if the item is not applicable and
please add links to any relevant follow up issues.*

I have...

- [ ] included the correct [type prefix](https://github.com/commitizen/conventional-commit-types/blob/v3.0.0/index.json) in the PR title
- [ ] added `!` to the type prefix if API or client breaking change
- [ ] targeted the correct branch (see [PR Targeting](https://github.com/cosmos/cosmos-sdk/blob/master/CONTRIBUTING.md#pr-targeting))
- [ ] provided a link to the relevant issue or specification
- [ ] followed the guidelines for [building modules](https://github.com/cosmos/cosmos-sdk/blob/master/docs/building-modules)
- [ ] included the necessary unit and integration [tests](https://github.com/cosmos/cosmos-sdk/blob/master/CONTRIBUTING.md#testing)
- [ ] added a changelog entry to `CHANGELOG.md`
- [ ] included comments for [documenting Go code](https://blog.golang.org/godoc)
- [ ] updated the relevant documentation or specification
- [ ] reviewed "Files changed" and left comments if necessary
- [ ] confirmed all CI checks have passed

### Reviewers Checklist

*All items are required. Please add a note if the item is not applicable and please add
your handle next to the items reviewed if you only reviewed selected items.*

I have...

- [ ] confirmed the correct [type prefix](https://github.com/commitizen/conventional-commit-types/blob/v3.0.0/index.json) in the PR title
- [ ] confirmed `!` in the type prefix if API or client breaking change
- [ ] confirmed all author checklist items have been addressed 
- [ ] reviewed state machine logic
- [ ] reviewed API design and naming
- [ ] reviewed documentation is accurate
- [ ] reviewed tests and test coverage
- [ ] manually tested (if applicable)
2022-04-07 17:00:00 +00:00
.github build(deps): Bump codecov/codecov-action from 2.1.0 to 3 (#11549) 2022-04-05 18:19:54 +02:00
api refactor(group): API naming audit (#11515) 2022-04-06 11:16:23 +00:00
baseapp fix: RegisterLegacyAminoCodec should error if Msg name is >39 chars (#11349) 2022-03-16 13:21:00 +00:00
client feat: EIP191 sign mode (#11533) 2022-04-05 08:43:59 +00:00
codec fix: RegisterLegacyAminoCodec should error if Msg name is >39 chars (#11349) 2022-03-16 13:21:00 +00:00
container build(deps): Bump github.com/stretchr/testify in /container (#11400) 2022-03-19 11:47:11 +01:00
contrib chore: use canonical name for dockerfile (#11485) 2022-03-29 17:55:34 +00:00
cosmovisor build(deps): Bump github.com/cosmos/cosmos-sdk in /cosmovisor (#11553) 2022-04-05 19:04:18 +02:00
crypto fix(cli): Group SubmitProposal CLI not working properly (#11521) 2022-04-04 10:11:02 +00:00
db build(deps): Bump github.com/stretchr/testify from 1.7.0 to 1.7.1 in /db (#11397) 2022-03-19 23:09:41 +00:00
docs ci: fix gh docs action (#11547) 2022-04-05 15:04:15 +02:00
errors fix(errors): support wrapped errors with gRPC codes (#11385) 2022-03-16 13:59:49 +00:00
internal feat: ADR-040: Add `RootStore` implementation (#10430) 2021-12-16 13:09:57 +00:00
orm fix(orm): add additional checks on invalid tables (#11387) 2022-04-05 19:48:58 +00:00
proto refactor(group): API naming audit (#11515) 2022-04-06 11:16:23 +00:00
scripts fix: Protobuf docker (#11472) 2022-03-26 23:38:32 +01:00
server feat: add tm inspect cmd (#11548) 2022-04-05 19:13:25 +00:00
simapp feat: Cancel unbonding delegation entry (#10885) 2022-04-05 10:01:13 +00:00
snapshots feat: ADR-040: add state sync for v2 store (#10794) 2022-03-04 06:05:23 +00:00
std fix: register evidence regression (#10595) 2021-12-14 14:25:31 +00:00
store feat: state migration from IAVL to SMT (ADR-040) (#10962) 2022-03-20 03:17:23 +00:00
telemetry refactor!: Keyring migration (#9695) 2021-09-20 12:02:15 +00:00
tests feat: ADR-040: Add `RootStore` implementation (#10430) 2021-12-16 13:09:57 +00:00
testutil refactor(x/auth/middleware)!: tx middleware to support pluggable feemarket module (#11413) 2022-03-29 14:46:56 +00:00
third_party/proto feat: full api module building alongside gogo proto files with buf schema registry support (#10669) 2022-01-06 14:57:55 -05:00
types feat: EIP191 sign mode (#11533) 2022-04-05 08:43:59 +00:00
version refactor: Implementing sigs.k8s.io YAML to remove .proto yaml annotations (#9780) 2021-09-24 14:37:34 +00:00
x feat: `ScheduleUpgradeNoHeightValidation` for automated upgrades w/o gov proposal (#11551) 2022-04-07 17:00:00 +00:00
.build.sh fix library file path (#8301) 2021-01-12 10:08:42 +00:00
.clang-format Fix clang-format to specific version (#7350) 2020-10-27 10:04:34 +00:00
.codecov.yml CI: Fix codecov flag project config (#7994) 2020-11-20 09:13:25 -05:00
.deepsource.toml chore: refactor code quality issues (#8932) 2021-03-22 09:30:27 +00:00
.dockerignore Add basic Dockerfile to build all binaries and export gaiad 2018-04-10 12:39:47 +02:00
.gitattributes Merge PR #6426: Migrate API Server 2020-06-15 13:39:09 -04:00
.gitignore ci: fix gh docs action (#11547) 2022-04-05 15:04:15 +02:00
.golangci.yml chore: bump TM to v0.35.0 release candidate (#10210) 2021-11-16 11:24:38 -08:00
.goreleaser.yml ci: automate release post tag push (#6230) 2020-05-25 20:02:08 +02:00
.markdownlint.json docs: Code blocks in SDK docs are broken (#11189) 2022-02-14 23:39:35 +01:00
.markdownlintignore docs: Improve markdownlint configuration (#11104) 2022-02-10 12:07:01 +00:00
.mergify.yml chore: Add mergify backport to v0.46.x (#11501) 2022-03-30 14:49:57 +02:00
CHANGELOG.md feat: `ScheduleUpgradeNoHeightValidation` for automated upgrades w/o gov proposal (#11551) 2022-04-07 17:00:00 +00:00
CODE_OF_CONDUCT.md Update CODE_OF_CONDUCT.md (#7381) 2020-09-28 11:28:30 +02:00
CODING_GUIDELINES.md docs: Improve markdownlint configuration (#11104) 2022-02-10 12:07:01 +00:00
CONTRIBUTING.md docs: Code blocks in SDK docs are broken (#11189) 2022-02-14 23:39:35 +01:00
Dockerfile build: Update Dockerfile (#9839) 2021-08-03 09:46:16 -04:00
LICENSE docs: 10180 Fix SDK (#10237) 2021-09-28 19:33:58 +02:00
Makefile ci: fix gh docs action (#11547) 2022-04-05 15:04:15 +02:00
README.md docs: Fix the broken links in the documents (#11477) 2022-03-30 07:29:35 +00:00
RELEASE_PROCESS.md docs: Improve markdownlint configuration (#11104) 2022-02-10 12:07:01 +00:00
SECURITY.md fix: Broken HackerOne program link #11481 2022-03-28 17:24:25 -04:00
buf.work.yaml feat: full api module building alongside gogo proto files with buf schema registry support (#10669) 2022-01-06 14:57:55 -05:00
docker-compose.yml build: add remote debugging with delve (#10587) 2021-12-01 12:44:54 +00:00
go.mod build(deps): Bump github.com/coinbase/rosetta-sdk-go from 0.7.6 to 0.7.7 (#11535) 2022-04-06 09:57:16 +02:00
go.sum build(deps): Bump github.com/coinbase/rosetta-sdk-go from 0.7.6 to 0.7.7 (#11535) 2022-04-06 09:57:16 +02:00

README.md

Cosmos SDK

banner

The Cosmos SDK is a framework for building blockchain applications. Tendermint Core (BFT Consensus) and the Cosmos SDK are written in the Golang programming language. Cosmos SDK is used to build Gaia, the first implementation of the Cosmos Hub.

WARNING: The Cosmos SDK has mostly stabilized, but we are still making some breaking changes.

Note: Requires Go 1.17+

Quick Start

To learn how the Cosmos SDK works from a high-level perspective, see the Cosmos SDK High-Level Intro.

If you want to get started quickly and learn how to build on top of Cosmos SDK, visit Cosmos SDK Tutorials. You can also fork the tutorial's repository to get started building your own Cosmos SDK application.

For more information, see the Cosmos SDK Documentation.

Contributing

See CONTRIBUTING.md for details how to contribute and participate in our dev calls. If you want to follow the updates or learn more about the latest design then join our Discord.

Tools and Frameworks

The Cosmos ecosystem is vast. We will only make a few notable mentions here.

  • Tools: notable frameworks and modules.
  • CosmJS: the Swiss Army knife to power JavaScript based client solutions.

Cosmos Hub Mainnet

The Cosmos Hub application, gaia, has moved to its own cosmos/gaia repository. Go there to join the Cosmos Hub mainnet and more.

Inter-Blockchain Communication (IBC)

The IBC module for the Cosmos SDK has moved to its own cosmos/ibc-go repository. Go there to build and integrate with the IBC module.

Starport

Starport is the all-in-one platform to build, launch, and maintain any crypto application on a sovereign and secured blockchain. If you are building a new app or a new module, use Starport to get started and speed up development.

Disambiguation

This Cosmos SDK project is not related to the React-Cosmos project (yet). Many thanks to Evan Coury and Ovidiu (@skidding) for this Github organization name. As per our agreement, this disambiguation notice will stay here.