-
Notifications
You must be signed in to change notification settings - Fork 3.8k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
Showing
10 changed files
with
295 additions
and
68 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 |
---|---|---|
@@ -0,0 +1,20 @@ | ||
# Params module specification | ||
|
||
## Abstract | ||
|
||
Package params provides a globally available parameter store. | ||
|
||
There are two main types, Keeper and Subspace. Subspace is an isolated namespace for a | ||
paramstore, where keys are prefixed by preconfigured spacename. Keeper has a | ||
permission to access all existing spaces. | ||
|
||
Subspace can be used by the individual keepers, who needs a private parameter store | ||
that the other keeper cannot modify. Keeper can be used by the Governance keeper, | ||
who need to modify any parameter in case of the proposal passes. | ||
|
||
The following contents explains how to use params module for master and user modules. | ||
|
||
## Contents | ||
|
||
1. [Keeper](keeper.md) | ||
1. [Subspace](subspace.md) |
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,17 @@ | ||
# Keeper | ||
|
||
In the app initialization stage, `Keeper.Subspace(Paramspace)` is passed to the user modules, and the subspaces are stored in `Keeper.spaces`. Later it can be retrieved with `Keeper.GetSubspace`, so the keepers holding `Keeper` can access to any subspace. For example, Gov module can take `Keeper` as its argument and modify parameter of any subspace when a `ParameterChangeProposal` is accepted. | ||
|
||
```go | ||
type MasterKeeper struct { | ||
pk params.Keeper | ||
} | ||
|
||
func (k MasterKeeper) SetParam(ctx sdk.Context, space string, key string, param interface{}) { | ||
space, ok := k.ps.GetSubspace(space) | ||
if !ok { | ||
return | ||
} | ||
space.Set(ctx, key, param) | ||
} | ||
``` |
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,76 @@ | ||
# Subspace | ||
|
||
## Basic Usage | ||
|
||
First, declare parameter space and parameter keys for the module. Then include params.Subspace in the keeper. Since we prefix the keys with the spacename, it is recommended to use the same name with the module's. | ||
|
||
```go | ||
const ( | ||
DefaultParamspace = "mymodule" | ||
) | ||
|
||
const ( | ||
KeyParameter1 = "myparameter1" | ||
KeyParameter2 = "myparameter2" | ||
) | ||
|
||
type Keeper struct { | ||
cdc *wire.Codec | ||
key sdk.StoreKey | ||
|
||
ps params.Subspace | ||
} | ||
``` | ||
|
||
Pass a params.Subspace to NewKeeper with DefaultParamSubspace (or another) | ||
|
||
```go | ||
app.myKeeper = mymodule.NewKeeper(cdc, key, app.paramStore.SubStore(mymodule.DefaultParamspace)) | ||
``` | ||
|
||
`NewKeeper` should register a `TypeTable`, which defines a map from parameter keys from types. | ||
|
||
```go | ||
func NewKeeper(cdc *codec.Codec, key sdk.StoreKey, space params.Subspace) Keeper { | ||
return Keeper { | ||
cdc: cdc, | ||
key: key, | ||
ps: space.WithTypeTable(ParamTypeTable()), | ||
} | ||
} | ||
``` | ||
|
||
Now we can access to the paramstore using Paramstore Keys | ||
|
||
```go | ||
var param MyStruct | ||
k.ps.Get(KeyParameter1, ¶m) | ||
k.ps.Set(KeyParameter2, param) | ||
``` | ||
|
||
# Genesis Usage | ||
|
||
Declare a struct for parameters and make it implement params.ParamSet. It will then be able to be passed to SetParamSet. | ||
|
||
```go | ||
type MyParams struct { | ||
Parameter1 uint64 | ||
Parameter2 string | ||
} | ||
|
||
// Implements params.ParamSet | ||
// KeyValuePairs must return the list of (ParamKey, PointerToTheField) | ||
func (p *MyParams) KeyValuePairs() params.KeyValuePairs { | ||
return params.KeyFieldPairs { | ||
{KeyParameter1, &p.Parameter1}, | ||
{KeyParameter2, &p.Parameter2}, | ||
} | ||
} | ||
|
||
func InitGenesis(ctx sdk.Context, k Keeper, data GenesisState) { | ||
k.ps.SetParamSet(ctx, &data.params) | ||
} | ||
``` | ||
|
||
The method is pointer receiver because there could be a case that we read from the store and set the result to the struct. | ||
|
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
Oops, something went wrong.