Merge PR #3683: spec-spec update, spec file reorg, TOC updates
* spec reorg * ... * PENDING.md * @alexanderbez comments
This commit is contained in:
parent
cf2cdabe6b
commit
a07b235f67
|
@ -45,6 +45,7 @@
|
|||
|
||||
### SDK
|
||||
|
||||
* [\#3300] Update the spec-spec, spec file reorg, and TOC updates.
|
||||
* [\#3665] Overhaul sdk.Uint type in preparation for Coins's Int -> Uint migration.
|
||||
|
||||
### Tendermint
|
||||
|
|
|
@ -7,20 +7,35 @@ this directory.
|
|||
|
||||
For consistency, specs should be written in passive present tense.
|
||||
|
||||
## Pseudo-Code
|
||||
|
||||
Generally, pseudo-code should be minimized throughout the spec. Often, simple
|
||||
bulleted-lists which describe a function's operations are sufficient and should
|
||||
be considered preferable. In certain instances, due to the complex nature of
|
||||
the functionality being described pseudo-code may the most suitable form of
|
||||
specification. In these cases use of pseudo-code is permissible, but should be
|
||||
presented in a concise manner, ideally restricted to only the complex
|
||||
element as a part of a larger description.
|
||||
|
||||
## Common Layout
|
||||
|
||||
The following generalized structure should be used to breakdown specifications
|
||||
for modules. Note that not all files may be required depending on the modules
|
||||
function
|
||||
The following generalized file structure should be used to breakdown
|
||||
specifications for modules. With the exception of README.md, `XX` at the
|
||||
beginning of the file name should be replaced with a number to indicate
|
||||
document flow (ex. read `01_state.md` before `02_state_transitions.md`). The
|
||||
following list is nonbinding and all files are optional.
|
||||
|
||||
- `overview.md` - describe module
|
||||
- `state.md` - specify and describe structures expected to marshalled into the store, and their keys
|
||||
- `state_transitions.md` - standard state transition operations triggered by hooks, messages, etc.
|
||||
- `end_block.md` - specify any end-block operations
|
||||
- `begin_block.md` - specify any begin-block operations
|
||||
- `messages.md` - specify message structure and expected state machine behaviour
|
||||
- `hooks.md` - describe available hooks to be called by/from this module
|
||||
- `tags.md` - list and describe event tags used
|
||||
- `README.md` - overview of the module
|
||||
- `XX_concepts.md` - describe specialized concepts and definitions used throughout the spec
|
||||
- `XX_state.md` - specify and describe structures expected to marshalled into the store, and their keys
|
||||
- `XX_state_transitions.md` - standard state transition operations triggered by hooks, messages, etc.
|
||||
- `XX_messages.md` - specify message structure(s) and expected state machine behaviour(s)
|
||||
- `XX_begin_block.md` - specify any begin-block operations
|
||||
- `XX_end_block.md` - specify any end-block operations
|
||||
- `XX_hooks.md` - describe available hooks to be called by/from this module
|
||||
- `XX_tags.md` - list and describe event tags used
|
||||
- `XX_future_improvements.md` - describe future improvements of this module
|
||||
- `XX_appendix.md` - supplementary details referenced elsewhere within the spec
|
||||
|
||||
### Notation for key-value mapping
|
||||
|
||||
|
|
|
@ -1,4 +1,6 @@
|
|||
# Gas & Fees
|
||||
# Concepts
|
||||
|
||||
## Gas & Fees
|
||||
|
||||
Fees serve two purposes for an operator of the network.
|
||||
|
|
@ -1,6 +1,6 @@
|
|||
## State
|
||||
# State
|
||||
|
||||
### Accounts
|
||||
## Accounts
|
||||
|
||||
Accounts contain authentication information for a uniquely identified external user of an SDK blockchain,
|
||||
including public key, address, and account number / sequence number for replay protection. For efficiency,
|
||||
|
@ -13,7 +13,7 @@ account types may do so.
|
|||
|
||||
- `0x01 | Address -> amino(account)`
|
||||
|
||||
#### Account Interface
|
||||
### Account Interface
|
||||
|
||||
The account interface exposes methods to read and write standard account information.
|
||||
Note that all of these methods operate on an account struct confirming to the interface
|
||||
|
@ -53,6 +53,6 @@ type BaseAccount struct {
|
|||
}
|
||||
```
|
||||
|
||||
#### Vesting Account
|
||||
### Vesting Account
|
||||
|
||||
See [Vesting](vesting.md).
|
|
@ -1,3 +1,7 @@
|
|||
# Messages
|
||||
|
||||
TODO make this file conform to typical messages spec
|
||||
|
||||
## Handlers
|
||||
|
||||
The auth module presently has no transaction handlers of its own, but does expose
|
|
@ -1,4 +1,4 @@
|
|||
## Types
|
||||
# Types
|
||||
|
||||
Besides accounts (specified in [State](state.md)), the types exposed by the auth module
|
||||
are `StdFee`, the combination of an amount and gas limit, `StdSignature`, the combination
|
||||
|
@ -6,7 +6,7 @@ of an optional public key and a cryptographic signature as a byte array, `StdTx`
|
|||
a struct which implements the `sdk.Tx` interface using `StdFee` and `StdSignature`, and
|
||||
`StdSignDoc`, a replay-prevention structure for `StdTx` which transaction senders must sign over.
|
||||
|
||||
### StdFee
|
||||
## StdFee
|
||||
|
||||
A `StdFee` is simply the combination of a fee amount, in any number of denominations,
|
||||
and a gas limit (where dividing the amount by the gas limit gives a "gas price").
|
||||
|
@ -18,7 +18,7 @@ type StdFee struct {
|
|||
}
|
||||
```
|
||||
|
||||
### StdSignature
|
||||
## StdSignature
|
||||
|
||||
A `StdSignature` is the combination of an optional public key and a cryptographic signature
|
||||
as a byte array. The SDK is agnostic to particular key or signature formats and supports any
|
||||
|
@ -31,7 +31,7 @@ type StdSignature struct {
|
|||
}
|
||||
```
|
||||
|
||||
### StdTx
|
||||
## StdTx
|
||||
|
||||
A `StdTx` is a struct which implements the `sdk.Tx` interface, and is likely to be generic
|
||||
enough to serve the purposes of many Cosmos SDK blockchains.
|
||||
|
@ -45,7 +45,7 @@ type StdTx struct {
|
|||
}
|
||||
```
|
||||
|
||||
### StdSignDoc
|
||||
## StdSignDoc
|
||||
|
||||
A `StdSignDoc` is a replay-prevention structure to be signed over, which ensures that
|
||||
any submitted transaction (which is simply a signature over a particular bytestring)
|
|
@ -1,8 +1,8 @@
|
|||
## Keepers
|
||||
# Keepers
|
||||
|
||||
The auth module only exposes one keeper, the account keeper, which can be used to read and write accounts.
|
||||
|
||||
### Account Keeper
|
||||
## Account Keeper
|
||||
|
||||
Presently only one fully-permissioned account keeper is exposed, which has the ability to both read and write
|
||||
all fields of all accounts, and to iterate over all stored accounts.
|
|
@ -13,18 +13,24 @@ This module will be used in the Cosmos Hub.
|
|||
|
||||
## Contents
|
||||
|
||||
1. **[State](state.md)**
|
||||
1. [Accounts](state.md#accounts)
|
||||
1. [Account Interface](state.md#account-interface)
|
||||
2. [Base Account](state.md#baseaccount)
|
||||
3. [Vesting Account](state.md#vestingaccount)
|
||||
1. **[Types](types.md)**
|
||||
1. [StdFee](types.md#stdfee)
|
||||
2. [StdSignature](types.md#stdsignature)
|
||||
3. [StdTx](types.md#stdtx)
|
||||
4. [StdSignDoc](types.md#stdsigndoc)
|
||||
1. **[Keepers](keepers.md)**
|
||||
1. [AccountKeeper](keepers.md#account-keeper)
|
||||
1. **[Handlers](handlers.md)**
|
||||
1. [Ante Handler](handlers.md#ante-handler)
|
||||
1. **[Gas & Fees](gas_fees.md)**
|
||||
1. **[Concepts](01_concepts.md)**
|
||||
- [Gas & Fees](01_concepts.md#gas-&-fees)
|
||||
2. **[State](02_state.md)**
|
||||
- [Accounts](02_state.md#accounts)
|
||||
3. **[Messages](03_messages.md)**
|
||||
- [Handlers](03_messages.md#handlers)
|
||||
4. **[Types](03_types.md)**
|
||||
- [StdFee](03_types.md#stdfee)
|
||||
- [StdSignature](03_types.md#stdsignature)
|
||||
- [StdTx](03_types.md#stdtx)
|
||||
- [StdSignDoc](03_types.md#stdsigndoc)
|
||||
5. **[Keepers](04_keepers.md)**
|
||||
- [Account Keeper](04_keepers.md#account-keeper)
|
||||
6. **[Vesting](05_vesting.md)**
|
||||
- [Intro and Requirements](05_vesting.md#intro-and-requirements)
|
||||
- [Vesting Account Types](05_vesting.md#vesting-account-types)
|
||||
- [Vesting Account Specification](05_vesting.md#vesting-account-specification)
|
||||
- [Keepers & Handlers](05_vesting.md#keepers-&-handlers)
|
||||
- [Genesis Initialization](05_vesting.md#genesis-initialization)
|
||||
- [Examples](05_vesting.md#examples)
|
||||
- [Glossary](05_vesting.md#glossary)
|
||||
|
|
|
@ -1,4 +1,4 @@
|
|||
## State
|
||||
# State
|
||||
|
||||
Presently, the bank module has no inherent state — it simply reads and writes accounts using the `AccountKeeper` from the `auth` module.
|
||||
|
|
@ -1,12 +1,12 @@
|
|||
## Keepers
|
||||
# Keepers
|
||||
|
||||
The bank module provides three different exported keeper interfaces which can be passed to other modules which need to read or update account balances. Modules should use the least-permissive interface which provides the functionality they require.
|
||||
|
||||
Note that you should always review the `bank` module code to ensure that permissions are limited in the way that you expect.
|
||||
|
||||
### Common Types
|
||||
## Common Types
|
||||
|
||||
#### Input
|
||||
### Input
|
||||
|
||||
An input of a multiparty transfer
|
||||
|
||||
|
@ -17,7 +17,7 @@ type Input struct {
|
|||
}
|
||||
```
|
||||
|
||||
#### Output
|
||||
### Output
|
||||
|
||||
An output of a multiparty transfer.
|
||||
|
||||
|
@ -28,7 +28,7 @@ type Output struct {
|
|||
}
|
||||
```
|
||||
|
||||
### BaseKeeper
|
||||
## BaseKeeper
|
||||
|
||||
The base keeper provides full-permission access: the ability to arbitrary modify any account's balance and mint or burn coins.
|
||||
|
||||
|
@ -82,7 +82,7 @@ inputOutputCoins(inputs []Input, outputs []Output)
|
|||
addCoins(output.Address, output.Coins)
|
||||
```
|
||||
|
||||
### SendKeeper
|
||||
## SendKeeper
|
||||
|
||||
The send keeper provides access to account balances and the ability to transfer coins between accounts, but not to alter the total supply (mint or burn coins).
|
||||
|
||||
|
@ -100,7 +100,7 @@ sendCoins(from AccAddress, to AccAddress, amt Coins)
|
|||
addCoins(to, amt)
|
||||
```
|
||||
|
||||
### ViewKeeper
|
||||
## ViewKeeper
|
||||
|
||||
The view keeper provides read-only access to account balances but no balance alteration functionality. All balance lookups are `O(1)`.
|
||||
|
|
@ -1,6 +1,6 @@
|
|||
## Messages
|
||||
# Messages
|
||||
|
||||
### MsgSend
|
||||
## MsgSend
|
||||
|
||||
```golang
|
||||
type MsgSend struct {
|
|
@ -14,13 +14,13 @@ This module will be used in the Cosmos Hub.
|
|||
|
||||
## Contents
|
||||
|
||||
1. **[State](state.md)**
|
||||
1. **[Keepers](keepers.md)**
|
||||
1. [Common Types](keepers.md#common-types)
|
||||
1. [Input](keepers.md#input)
|
||||
1. [Output](keepers.md#output)
|
||||
1. [BaseKeeper](keepers.md#basekeeper)
|
||||
1. [SendKeeper](keepers.md#sendkeeper)
|
||||
1. [ViewKeeper](keepers.md#viewkeeper)
|
||||
1. **[Transactions](transactions.md)**
|
||||
1. [MsgSend](transactions.md#msgsend)
|
||||
1. **[State](01_state.md)**
|
||||
2. **[Keepers](02_keepers.md)**
|
||||
- [Common Types](02_keepers.md#common-types)
|
||||
- [BaseKeeper](02_keepers.md#basekeeper)
|
||||
- [SendKeeper](02_keepers.md#sendkeeper)
|
||||
- [ViewKeeper](02_keepers.md#viewkeeper)
|
||||
3. **[Messages](03_messages.md)**
|
||||
- [MsgSend](03_messages.md#msgsend)
|
||||
4. **[Tags](04_tags.md)**
|
||||
- [Handlers](04_tags.md#handlers)
|
||||
|
|
|
@ -1,3 +1,5 @@
|
|||
# Concepts
|
||||
|
||||
## Reference Counting in F1 Fee Distribution
|
||||
|
||||
In F1 fee distribution, in order to calculate the rewards a delegator ought to receive when they
|
|
@ -74,3 +74,22 @@ In conclusion, we can only have Atom commission and unbonded atoms
|
|||
provisions or bonded atom provisions with no Atom commission, and we elect to
|
||||
implement the former. Stakeholders wishing to rebond their provisions may elect
|
||||
to set up a script to periodically withdraw and rebond rewards.
|
||||
|
||||
## Contents
|
||||
|
||||
1. **[Concepts](01_concepts.md)**
|
||||
- [Reference Counting in F1 Fee Distribution](01_concepts.md#reference-counting-in-f1-fee-distribution)
|
||||
2. **[02_state.md](02_state.md)**
|
||||
- [State](02_state.md#state)
|
||||
3. **[End Block](03_end_block.md)**
|
||||
4. **[Messages](04_messages.md)**
|
||||
- [MsgWithdrawDelegationRewardsAll](04_messages.md#msgwithdrawdelegationrewardsall)
|
||||
- [MsgWithdrawDelegationReward](04_messages.md#msgwithdrawdelegationreward)
|
||||
- [MsgWithdrawValidatorRewardsAll](04_messages.md#msgwithdrawvalidatorrewardsall)
|
||||
- [Common calculations ](04_messages.md#common-calculations-)
|
||||
5. **[Hooks](05_hooks.md)**
|
||||
- [Create or modify delegation distribution](05_hooks.md#create-or-modify-delegation-distribution)
|
||||
- [Commission rate change](05_hooks.md#commission-rate-change)
|
||||
- [Change in Validator State](05_hooks.md#change-in-validator-state)
|
||||
6. **[Tags](06_tags.md)**
|
||||
- [Handlers](06_tags.md#handlers)
|
||||
|
|
|
@ -1,4 +1,4 @@
|
|||
# Design Overview
|
||||
# Concepts
|
||||
|
||||
*Disclaimer: This is work in progress. Mechanisms are susceptible to change.*
|
||||
|
|
@ -1,8 +1,6 @@
|
|||
# Implementation (1/2)
|
||||
# State
|
||||
|
||||
## State
|
||||
|
||||
### Parameters and base types
|
||||
## Parameters and base types
|
||||
|
||||
`Parameters` define the rules according to which votes are run. There can only
|
||||
be one active parameter set at any given time. If governance wants to change a
|
||||
|
@ -65,7 +63,7 @@ const (
|
|||
)
|
||||
```
|
||||
|
||||
### Deposit
|
||||
## Deposit
|
||||
|
||||
```go
|
||||
type Deposit struct {
|
||||
|
@ -74,7 +72,7 @@ const (
|
|||
}
|
||||
```
|
||||
|
||||
### ValidatorGovInfo
|
||||
## ValidatorGovInfo
|
||||
|
||||
This type is used in a temp map when tallying
|
||||
|
||||
|
@ -85,7 +83,7 @@ This type is used in a temp map when tallying
|
|||
}
|
||||
```
|
||||
|
||||
### Proposals
|
||||
## Proposals
|
||||
|
||||
`Proposals` are an item to be voted on.
|
||||
|
||||
|
@ -117,7 +115,7 @@ We also mention a method to update the tally for a given proposal:
|
|||
func (proposal Proposal) updateTally(vote byte, amount sdk.Dec)
|
||||
```
|
||||
|
||||
### Stores
|
||||
## Stores
|
||||
|
||||
*Stores are KVStores in the multistore. The key to find the store is the first parameter in the list*`
|
||||
|
||||
|
@ -132,7 +130,7 @@ For pseudocode purposes, here are the two function we will use to read or write
|
|||
* `load(StoreKey, Key)`: Retrieve item stored at key `Key` in store found at key `StoreKey` in the multistore
|
||||
* `store(StoreKey, Key, value)`: Write value `Value` at key `Key` in store found at key `StoreKey` in the multistore
|
||||
|
||||
### Proposal Processing Queue
|
||||
## Proposal Processing Queue
|
||||
|
||||
**Store:**
|
||||
* `ProposalProcessingQueue`: A queue `queue[proposalID]` containing all the
|
|
@ -1,8 +1,6 @@
|
|||
# Implementation (2/2)
|
||||
# Messages
|
||||
|
||||
## Messages
|
||||
|
||||
### Proposal Submission
|
||||
## Proposal Submission
|
||||
|
||||
Proposals can be submitted by any Atom holder via a `TxGovSubmitProposal`
|
||||
transaction.
|
||||
|
@ -69,7 +67,7 @@ upon receiving txGovSubmitProposal from sender do
|
|||
return proposalID
|
||||
```
|
||||
|
||||
### Deposit
|
||||
## Deposit
|
||||
|
||||
Once a proposal is submitted, if
|
||||
`Proposal.TotalDeposit < ActiveParam.MinDeposit`, Atom holders can send
|
||||
|
@ -138,7 +136,7 @@ upon receiving txGovDeposit from sender do
|
|||
store(Proposals, <txGovVote.ProposalID|'proposal'>, proposal)
|
||||
```
|
||||
|
||||
### Vote
|
||||
## Vote
|
||||
|
||||
Once `ActiveParam.MinDeposit` is reached, voting period starts. From there,
|
||||
bonded Atom holders are able to send `TxGovVote` transactions to cast their
|
|
@ -1,4 +1,4 @@
|
|||
# Future improvements (not in scope for MVP)
|
||||
# Future Improvements
|
||||
|
||||
The current documentation only describes the minimum viable product for the
|
||||
governance module. Future improvements may include:
|
|
@ -21,15 +21,22 @@ This module will be used in the Cosmos Hub, the first Hub in the Cosmos network.
|
|||
|
||||
The following specification uses *Atom* as the native staking token. The module can be adapted to any Proof-Of-Stake blockchain by replacing *Atom* with the native staking token of the chain.
|
||||
|
||||
1. **[Design overview](overview.md)**
|
||||
2. **Implementation**
|
||||
1. **[State](state.md)**
|
||||
1. Parameters
|
||||
2. Proposals
|
||||
3. Proposal Processing Queue
|
||||
2. **[Transactions](transactions.md)**
|
||||
1. Proposal Submission
|
||||
2. Deposit
|
||||
3. Claim Deposit
|
||||
4. Vote
|
||||
3. **[Future improvements](future_improvements.md)**
|
||||
1. **[Concepts](01_concepts.md)**
|
||||
- [Proposal submission](01_concepts.md#proposal-submission)
|
||||
- [Vote](01_concepts.md#vote)
|
||||
- [Software Upgrade](01_concepts.md#software-upgrade)
|
||||
2. **[State](02_state.md)**
|
||||
- [Parameters and base types](02_state.md#parameters-and-base-types)
|
||||
- [Deposit](02_state.md#deposit)
|
||||
- [ValidatorGovInfo](02_state.md#validatorgovinfo)
|
||||
- [Proposals](02_state.md#proposals)
|
||||
- [Stores](02_state.md#stores)
|
||||
- [Proposal Processing Queue](02_state.md#proposal-processing-queue)
|
||||
3. **[Messages](03_messages.md)**
|
||||
- [Proposal Submission](03_messages.md#proposal-submission)
|
||||
- [Deposit](03_messages.md#deposit)
|
||||
- [Vote](03_messages.md#vote)
|
||||
4. **[Tags](04_tags.md)**
|
||||
- [EndBlocker](04_tags.md#endblocker)
|
||||
- [Handlers](04_tags.md#handlers)
|
||||
5. **[Future Improvements](05_future_improvements.md)**
|
||||
|
|
|
@ -1,6 +1,6 @@
|
|||
## State
|
||||
# State
|
||||
|
||||
### Minter
|
||||
## Minter
|
||||
|
||||
The minter is a space for holding current inflation information.
|
||||
|
||||
|
@ -13,7 +13,7 @@ type Minter struct {
|
|||
}
|
||||
```
|
||||
|
||||
### Params
|
||||
## Params
|
||||
|
||||
Minting params are held in the global params store.
|
||||
|
|
@ -1,4 +1,11 @@
|
|||
# Mint Specification
|
||||
|
||||
- [State](./state.md)
|
||||
- [Begin Block](./begin_block.md)
|
||||
## Contents
|
||||
|
||||
1. **[State](01_state.md)**
|
||||
- [Minter](01_state.md#minter)
|
||||
- [Params](01_state.md#params)
|
||||
2. **[Begin-Block](02_begin_block.md)**
|
||||
- [NextInflationRate](02_begin_block.md#nextinflationrate)
|
||||
- [NextAnnualProvisions](02_begin_block.md#nextannualprovisions)
|
||||
- [BlockProvision](02_begin_block.md#blockprovision)
|
||||
|
|
|
@ -16,5 +16,8 @@ The following contents explains how to use params module for master and user mod
|
|||
|
||||
## Contents
|
||||
|
||||
1. [Keeper](keeper.md)
|
||||
1. [Subspace](subspace.md)
|
||||
1. **[Keeper](01_keeper.md)**
|
||||
2. **[Subspace](02_subspace.md)**
|
||||
- [Key](02_subspace.md#key)
|
||||
- [KeyTable](02_subspace.md#keytable)
|
||||
- [ParamSet](02_subspace.md#paramset)
|
||||
|
|
|
@ -1,12 +1,12 @@
|
|||
## Conceptual overview
|
||||
# Concepts
|
||||
|
||||
### States
|
||||
## States
|
||||
|
||||
At any given time, there are any number of validators registered in the state machine.
|
||||
Each block, the top `n = MaximumBondedValidators` validators who are not jailed become *bonded*, meaning that they may propose and vote on blocks.
|
||||
Validators who are *bonded* are *at stake*, meaning that part or all of their stake and their delegators' stake is at risk if they commit a protocol fault.
|
||||
|
||||
### Tombstone Caps
|
||||
## Tombstone Caps
|
||||
|
||||
In order to mitigate the impact of initially likely categories of non-malicious protocol faults, the Cosmos Hub implements for each validator
|
||||
a *tombstone* cap, which only allows a validator to be slashed once for a double sign fault. For example, if you misconfigure your HSM and double-sign
|
||||
|
@ -15,7 +15,7 @@ to avoid, but tombstone caps somewhat blunt the economic impact of unintentional
|
|||
|
||||
Liveness faults do not have caps, as they can't stack upon each other. Liveness bugs are "detected" as soon as the infraction occurs, and the validators are immediately put in jail, so it is not possible for them to commit multiple liveness faults without unjailing in between.
|
||||
|
||||
#### ASCII timelines
|
||||
## ASCII timelines
|
||||
|
||||
*Code*
|
||||
|
|
@ -1,8 +1,8 @@
|
|||
## Messages
|
||||
# Messages
|
||||
|
||||
In this section we describe the processing of messages for the `slashing` module.
|
||||
|
||||
### Unjail
|
||||
## Unjail
|
||||
|
||||
If a validator was automatically unbonded due to downtime and wishes to come back online &
|
||||
possibly rejoin the bonded set, it must send `TxUnjail`:
|
|
@ -16,15 +16,20 @@ This module will be used by the Cosmos Hub, the first hub in the Cosmos ecosyste
|
|||
|
||||
## Contents
|
||||
|
||||
1. **[Overview](overview.md)**
|
||||
1. **[State](state.md)**
|
||||
1. [SigningInfo](state.md#signing-info)
|
||||
2. **[Transactions](transactions.md)**
|
||||
1. [Unjail](transactions.md#unjail)
|
||||
3. **[Hooks](hooks.md)**
|
||||
1. [Validator Bonded](hooks.md#validator-bonded)
|
||||
4. **[Begin Block](begin-block.md)**
|
||||
1. [Evidence handling](begin-block.md#evidence-handling)
|
||||
2. [Uptime tracking](begin-block.md#uptime-tracking)
|
||||
5. **[Future Improvements](future-improvements.md)**
|
||||
1. [State cleanup](future-improvements.md#state-cleanup)
|
||||
1. **[Concepts](01_concepts.md)**
|
||||
- [States](01_concepts.md#states)
|
||||
- [Tombstone Caps](01_concepts.md#tombstone-caps)
|
||||
- [ASCII timelines](01_concepts.md#ascii-timelines)
|
||||
2. **[State](02_state.md)**
|
||||
- [Signing Info](02_state.md#signing-info)
|
||||
3. **[Messages](03_messages.md)**
|
||||
- [Unjail](03_messages.md#unjail)
|
||||
4. **[Begin-Block](04_begin_block.md)**
|
||||
- [Evidence handling](04_begin_block.md#evidence-handling)
|
||||
- [Uptime tracking](04_begin_block.md#uptime-tracking)
|
||||
5. **[05_hooks.md](05_hooks.md)**
|
||||
- [Hooks](05_hooks.md#hooks)
|
||||
6. **[Tags](06_tags.md)**
|
||||
- [Handlers](06_tags.md#handlers)
|
||||
7. **[Staking Tombstone](07_tombstone.md)**
|
||||
- [Abstract](07_tombstone.md#abstract)
|
||||
|
|
|
@ -117,7 +117,7 @@ with the `ValidatorAddr` Delegators are indexed in the store as follows:
|
|||
|
||||
- Delegation: ` 0x31 | DelegatorAddr | ValidatorAddr -> amino(delegation)`
|
||||
|
||||
Atom holders may delegate coins to validators; under this circumstance their
|
||||
Stake holders may delegate coins to validators; under this circumstance their
|
||||
funds are held in a `Delegation` data structure. It is owned by one
|
||||
delegator, and is associated with the shares for one validator. The sender of
|
||||
the transaction is the owner of the bond.
|
|
@ -16,34 +16,29 @@ network.
|
|||
|
||||
## Contents
|
||||
|
||||
The following specification uses *Atom* as the native staking token. The module
|
||||
can be adapted to any Proof-Of-Stake blockchain by replacing *Atom* with the
|
||||
native staking token of the chain.
|
||||
|
||||
1. **[State](state.md)**
|
||||
- Pool
|
||||
- Params
|
||||
- Validator
|
||||
- Delegation
|
||||
- UnbondingDelegation
|
||||
- Redelegation
|
||||
- Queues
|
||||
2. **[State Transistions](state_transitions.md)**
|
||||
- Validator
|
||||
- Delegation
|
||||
- Slashing
|
||||
3. **[Messages](messages.md)**
|
||||
- MsgCreateValidator
|
||||
- MsgEditValidator
|
||||
- MsgDelegate
|
||||
- MsgBeginUnbonding
|
||||
- MsgBeginRedelegate
|
||||
4. **[End-Block](end_block.md)**
|
||||
- Validator Set Changes
|
||||
- Queues
|
||||
- Unbonding Validators
|
||||
- Unbonding Delegations
|
||||
- Redelegations
|
||||
5. **[Hooks](hooks.md)**
|
||||
6. **[Tags](tags.md)**
|
||||
|
||||
1. **[State](01_state.md)**
|
||||
- [Pool](01_state.md#pool)
|
||||
- [LastTotalPower](01_state.md#lasttotalpower)
|
||||
- [Params](01_state.md#params)
|
||||
- [Validator](01_state.md#validator)
|
||||
- [Delegation](01_state.md#delegation)
|
||||
- [UnbondingDelegation](01_state.md#unbondingdelegation)
|
||||
- [Redelegation](01_state.md#redelegation)
|
||||
- [Queues](01_state.md#queues)
|
||||
2. **[State Transitions](02_state_transitions.md)**
|
||||
- [Validators](02_state_transitions.md#validators)
|
||||
- [Delegations](02_state_transitions.md#delegations)
|
||||
- [Slashing](02_state_transitions.md#slashing)
|
||||
3. **[Messages](03_messages.md)**
|
||||
- [MsgCreateValidator](03_messages.md#msgcreatevalidator)
|
||||
- [MsgEditValidator](03_messages.md#msgeditvalidator)
|
||||
- [MsgDelegate](03_messages.md#msgdelegate)
|
||||
- [MsgBeginUnbonding](03_messages.md#msgbeginunbonding)
|
||||
- [MsgBeginRedelegate](03_messages.md#msgbeginredelegate)
|
||||
4. **[End-Block ](04_end_block.md)**
|
||||
- [Validator Set Changes](04_end_block.md#validator-set-changes)
|
||||
- [Queues ](04_end_block.md#queues-)
|
||||
5. **[Hooks](05_hooks.md)**
|
||||
6. **[Tags](06_tags.md)**
|
||||
- [EndBlocker](06_tags.md#endblocker)
|
||||
- [Handlers](06_tags.md#handlers)
|
||||
|
|
Loading…
Reference in New Issue