Skip to content

Commit

Permalink
add contributing, devnotes, update readme
Browse files Browse the repository at this point in the history
  • Loading branch information
kiragpg committed Dec 4, 2023
1 parent 9afaca6 commit 70d3317
Show file tree
Hide file tree
Showing 3 changed files with 288 additions and 154 deletions.
88 changes: 88 additions & 0 deletions CONTRIBUTING.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,88 @@
# Contributing

- [Contributing](#contributing)
- [Overview](#overview)
- [Kira Improvement Proposal (KIP)](#kira-improvement-proposal-kip)
- [Testing](#testing)
- [Pull Requests](#pull-requests)
- [Requesting Reviews](#requesting-reviews)
- [Changelog](#changelog)
- [Dependencies](#dependencies)
- [Protobuf](#protobuf)
- [Branching Model and Release](#branching-model-and-release)

## Overview

Contributing to this repo can mean many things such as participating in
discussion or proposing code changes.
Following the processes outlined in this document will lead to the best
chance of getting changes merged into the codebase.

## Kira Improvement Proposal (KIP)

When proposing an architecture decision for Gaia, please start by opening an [issue](https://github.com/cosmos/gaia/issues/new/choose) or a [discussion](https://github.com/cosmos/gaia/discussions/new) with a summary of the proposal. Once the proposal has been discussed and there is rough alignment on a high-level approach to the design, you may either start development, or write an ADR.

If your architecture decision is a simple change, you may contribute directly without writing an ADR. However, if you are proposing a significant change, please include a corresponding ADR.

To create an ADR, follow the [template](./docs/architecture/adr-template.md) and [doc](./docs/architecture/README.md). If you would like to see examples of how these are written, please refer to the current [ADRs](https://github.com/cosmos/gaia/tree/main/docs/architecture).

### Testing

Tests can be executed by running `make test` at the top level of the Sekai repository.

### Pull Requests

Before submitting a pull request:

- synchronize your branch with the latest `master` branch and resolve any arising conflicts, `git fetch origin/master && git merge origin/master`
- run `make install`, `make test`, to ensure that all checks and tests pass.

### Requesting Reviews

In order to accommodate the review process, the author of the PR should be in contact with Sekai repo maintainers.

### Changelog

Changelog keeps the changes made as part of releases. The logs are kept on [CHANGELOG](./CHANGELOG.md).

## Dependencies

We use [Go Modules](https://github.com/golang/go/wiki/Modules) to manage
dependency versions.

The main branch of every Cosmos repository should just build with `go get`,
which means they should be kept up-to-date with their dependencies so we can
get away with telling people they can just `go get` our software.

When dependencies in Sekai's `go.mod` are changed, it is generally accepted practice
to delete `go.sum` and then run `go mod tidy`.

Since some dependencies are not under our control, a third party may break our
build, in which case we can fall back on `go mod tidy -v`.

## Protobuf

We use [Protocol Buffers](https://developers.google.com/protocol-buffers) along with [gogoproto](https://github.com/cosmos/gogoproto) to generate code for use in sekai.

For deterministic behavior around Protobuf tooling, everything is containerized using Docker. Make sure to have Docker installed on your machine, or head to [Docker's website](https://docs.docker.com/get-docker/) to install it.

To generate the protobuf stubs, you can run `make proto-gen`.

## Branching Model and Release

Sekai branches should be one of `feature/{feature-description}` or `bugfix/{bugfix-description}` to join CI/CD process.

Sekai follows [semantic versioning](https://semver.org).

To release a new version

- Set a new sekai version on [`types/constants.go`](types/constants.go)
- Add relevant information on [`RELEASE.md`](RELEASE.md)
- Push the code to the branch
- The bot automatically creates release branch `release/vx.x.x` as configured in [`types/constants.go`](types/constants.go) and raise the PR from working branch to release branch automatically
- Check CI/CD pass on the PR
- Get manual review
- Get the PR merged into release branch
- New PR into master is raised after release branch PR merge
- Check CI/CD pass on the PR
- Merge into master
172 changes: 172 additions & 0 deletions DEVNOTES.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,172 @@
## Install bash-utils

Bash-utils is a KIRA tool that helps to simplify shell scripts and various bash commands that you might need to run

```
# Install bash-utils.sh KIRA tool to make downloads faster and easier
TOOLS_VERSION="v0.0.12.4" && mkdir -p /usr/keys && FILE_NAME="bash-utils.sh" && \
if [ -z "$KIRA_COSIGN_PUB" ] ; then KIRA_COSIGN_PUB=/usr/keys/kira-cosign.pub ; fi && \
echo -e "-----BEGIN PUBLIC KEY-----\nMFkwEwYHKoZIzj0CAQYIKoZIzj0DAQcDQgAE/IrzBQYeMwvKa44/DF/HB7XDpnE+\nf+mU9F/Qbfq25bBWV2+NlYMJv3KvKHNtu3Jknt6yizZjUV4b8WGfKBzFYw==\n-----END PUBLIC KEY-----" > $KIRA_COSIGN_PUB && \
wget "https://github.com/KiraCore/tools/releases/download/$TOOLS_VERSION/${FILE_NAME}" -O ./$FILE_NAME && \
wget "https://github.com/KiraCore/tools/releases/download/$TOOLS_VERSION/${FILE_NAME}.sig" -O ./${FILE_NAME}.sig && \
cosign verify-blob --key="$KIRA_COSIGN_PUB" --signature=./${FILE_NAME}.sig ./$FILE_NAME && \
chmod -v 555 ./$FILE_NAME && ./$FILE_NAME bashUtilsSetup "/var/kiraglob" && . /etc/profile && \
echoInfo "Installed bash-utils $(bash-utils bashUtilsVersion)"
```

## Quick setup from Releases

```bash
# TBD
```

## Set environment variables

```sh
sh env.sh
```

# Get version info

[scripts/commands/version.sh](scripts/commands/version.sh)

# Adding more validators

[scripts/commands/adding-validators.sh](scripts/commands/adding-validators.sh)

## Set ChangeTxFee permission

[scripts/commands/set-permission.sh](scripts/commands/set-permission.sh)

## Set network properties

[scripts/commands/set-network-properties.sh](scripts/commands/set-network-properties.sh)

## Set Execution Fee

[scripts/commands/set-execution-fee.sh](scripts/commands/set-execution-fee.sh)

## Upsert token rates

[scripts/commands/upsert-token-rates.sh](scripts/commands/upsert-token-rates.sh)

## Upsert token alias

[scripts/commands/upsert-token-alias.sh](scripts/commands/upsert-token-alias.sh)

# Fee payment in foreign currency

[scripts/commands/foreign-fee-payments.sh](scripts/commands/foreign-fee-payments.sh)

# Fee payment in foreign currency returning failure - execution fee in foreign currency

[scripts/commands/foreign-fee-payments-failure-return.sh](scripts/commands/foreign-fee-payments-failure-return.sh)

## Query permission of an address

[scripts/commands/query-permission.sh](scripts/commands/query-permission.sh)

## Query network properties

[scripts/commands/query-network-properties.sh](scripts/commands/query-network-properties.sh)

## Query execution fee

[scripts/commands/query-execution-fee.sh](scripts/commands/query-execution-fee.sh)

# Query token alias

[scripts/commands/query-token-alias.sh](scripts/commands/query-token-alias.sh)

# Query token rate

[scripts/commands/query-token-rate.sh](scripts/commands/query-token-rate.sh)

# Query validator account

[scripts/commands/query-validator.sh](scripts/commands/query-validator.sh)

# Query for current frozen / unfronzen tokens

**Notes**: these values are valid only when specific network property is enabled
[scripts/commands/query-frozen-token.sh](scripts/commands/query-frozen-token.sh)

# Query poor network messages

[scripts/commands/query-poor-network-messages.sh](scripts/commands/query-poor-network-messages.sh)

# Query signing infos per validator's consensus address

[scripts/commands/query-signing-infos.sh](scripts/commands/query-signing-infos.sh)

# Common commands for governance process

[scripts/commands/governance/common.sh](scripts/commands/governance/common.sh)

### Set permission via governance process

[scripts/commands/governance/assign-permission.sh](scripts/commands/governance/assign-permission.sh)

## Upsert token alias via governance process

[scripts/commands/governance/upsert-token-alias.sh](scripts/commands/governance/upsert-token-alias.sh)

## Upsert token rates via governance process

[scripts/commands/governance/upsert-token-rates.sh](scripts/commands/governance/upsert-token-rates.sh)

# Commands for poor network management via governance process

[scripts/commands/governance/poor-network-messages.sh](scripts/commands/governance/poor-network-messages.sh)

# Freeze / unfreeze tokens via governance process

[scripts/commands/governance/token-freeze.sh](scripts/commands/governance/token-freeze.sh)

# Set network property proposal via governance process

[scripts/commands/governance/set-network-property.sh](scripts/commands/governance/set-network-property.sh)

# Set application upgrade proposal via governance process

[scripts/commands/governance/upgrade-plan.sh](scripts/commands/governance/upgrade-plan.sh)

Export the status of chain before halt (should kill the daemon process at the time of genesis export)
[scripts/commands/export-state.sh](scripts/commands/export-state.sh)

The script for creating new chain from exported state should be written or manual edition process is required.
`ChainId` should be modified in this process.

For now, upgrade process requires manual conversion from old genesis to new genesis.
At each time of upgrade, genesis upgrade command will be built and infra could run the command like `sekaid genesis-migrate`

Note: state export command is not exporting the upgrade plan and if all validators run with exported genesis with the previous binary, consensus failure won't happen.

# Identity registrar

[scripts/commands/identity-registrar.sh](scripts/commands/identity-registrar.sh)

# Unjail via governance process

Modify genesis json to have jailed validator for Unjail testing
Add jailed validator key to kms.

```sh
sekaid keys add jailed_validator --keyring-backend=test --home=$HOME/.sekaid --recover
"dish rather zoo connect cross inhale security utility occur spell price cute one catalog coconut sort shuffle palm crop surface label foster slender inherit"
```

[scripts/commands/governance/unjail-validator.sh](scripts/commands/governance/unjail-validator.sh)

# New genesis file generation process from exported version

In order to manually generate new genesis file when the hard fork is activated, following steps should be taken:

1. Export current genesis, e.g: sekaid export --home=<path>
2. Change chain-id to new_chain_id as indicated by the upgrade plan
3. Replace current upgrade plan in the app_state.upgrade with next plan and set next plan to null

Using a command it can be done in this way.

1. sekaid export > exported-genesis.json
2. sekaid new-genesis-from-exported exported-genesis.json new-genesis.json --json-minimize=true
Loading

0 comments on commit 70d3317

Please sign in to comment.