cfeminter

package
v1.1.0-rc0 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Jan 3, 2023 License: Apache-2.0 Imports: 26 Imported by: 0

README

Chain4Energy minter module - cfeminter

Abstract

Chain4Energy minter module provides functionality of controlled token emissions. Tokens are emited according to configuration.

Contents

  1. Concept
  2. Params
  3. State
  4. Events
  5. Queries
  6. Genesis validations

Concepts

The purpose of cfeminter module is to provide token emission mechanism.

Token emission mechanism

Token emission mechanism mints calculated amount of tokens per each block. Token amount is calculated according to cfeminter module configuration params. Tokens minting process is divided into separate minters where each minter has different minting rules. Those minting rules are defined within cfeminter module configuration params. Simply, mintining process configuration is a list of ordered minters, where each minter has its own start and end time (end time for last minter is not required, in that case last minter works infinitely).

Minters

Ordered list of minters defines whole token emission process. End time of one minter is a start time of the next minter on the minters list. Each minter has its own type assigned. Last minter on the list must be defined to work indefinitely (cannot have end time).

Minting type

Minting type defines general rules of token emission. Each minter has its specific minting type. Currently, cfeminter module supports following minting types:

  • no miniting
  • linear minting
  • exponential step minting

Each minting type has its own specific set of parameters modifying token emission

No minitng

No minting is a simple minting type that mints nothing. This minting type has no parameters.

Linear minting

Linear minting is block time based minting type. It mints configured amount of tokens within minter linearly. This minting type requires minter with end time since given amount of token needs to be minted in finite time period. So this minting type cannot be configured as a type of last period.

Minter type parameters:

  • amount - amount of tokens to mint within minter period
Exponential step minting

Exponential step minting is block time based minting type. It mints configured amount of tokens within minter, where it divides this minter into smaller subminters of equal lenght. Then within subminter expected amount is minted, lineary. Expected amount of subminter minted tokens is equal to tokens minted by previous subminter multiplied by configured factor. For example initial minter amount is 40 million, multiplying factor set to 0.5 and step duration is four years, then:

  • 1st subminter (1st year) mints 40 millions linearly
  • 2nd subminter (2nd year) mints 20 millions linearly
  • 3rd subminter (3rd year) mints 10 millions linearly
  • 4th subminter (4th year) mints 5 millions linearly and so on.

This minter can mint infinitely.

Minter type parameters:

  • step duration - period of time mint amount is emitted
  • amount - amount to mint for the first period
  • amount multiplier - amount multiplying factor

Examples

Four years halving minting that starts with 40 million tokens and step duration set at 4 years

Minter configuration:

  • minting start: now
  • Amount of minter Minters: 1
  • Minter period 1:
    • end time: null
    • type: exponential step minting
    • exponential step minting parameters:
      • step_duration: 4 years
      • amount: 40 millions
      • amount_multiplier: 0.5

Result:

  • 1st 4 years mints 40 millions
  • 2nd 4 years mints 20 millions
  • 3rd 4 years mints 10 millions and so on
Linear minting of 100 million of token during period of 10 years, next no emission

Minter configration:

  • minting start: now
  • Amount of minter Minters: 2
  • Minter period 1:
    • end time: 10 years from now
    • type: linear minting
    • linear minting parameters:
      • amount: 100 millions
  • Minter period 2:
    • end time: null
    • type: no minting

Result:

  • 10 millions yearly for 10 years

Parameters

The Chain4Energy minter module contains the following configurations parameters:

Key Type Description
mint_denom string Denom of minting token
minter_config MinterConfig Token emission configuration
MinterConfig type
Param Type Description
start_time Time Token emission start time
minters List of Minters list of minters
Minter type
Param Type Description
sequence_id uint32 Minter ordering id
end_time Time Minter end time
type Enum string Minter period type. Allowed values:
- NO_MINTING
- LINEAR_MINTING
- EXPONENTIAL_STEP_MINTING;
linear_minting LinearMinting Linear minting configuration
exponential_step_minting ExponentialStepMinting Exponential step minting configuration
LinearMinting type
Param Type Description
amount sdk.Int An amount to mint lieary during the period
ExponentialStepMinting type
Param Type Description
step_duration uint32 period of time of token emission
amount sdk.Int amount to mint during "stepDuration"
amount_multiplier sdk.Dec amount multiplying factor
Example params
  1. Four years halving minting that starts with 40 million tokens and step duration set at 4 years
{
  "params": {
    "mint_denom": "uc4e",
    "minter_config": {
      "start_time": "2022-07-05T00:00:00Z",
      "minters": [
        {
          "SequenceId": 1,
          "end_time": null,
          "type": "EXPONENTIAL_STEP_MINTING",
          "linear_minting": null,
          "exponential_step_minting": {
            "step_duration": "126144000s",
            "amount": 40000000000000,
            "amount_multiplier": "0.500000000000000000"
          }
        }
      ]
    }
  }
}
  1. Linear minting of 100 million of token during period of 10 years, next no emission
{
  "params": {
    "mint_denom": "uc4e",
    "minter_config": {
      "start_time": "2022-07-05T00:00:00Z",
      "minters": [
        {
          "SequenceId": 1,
          "end_time": "2023-07-05T00:00:00Z",
          "type": "LINEAR_MINTING",
          "linear_minting": {
            "amount": 100000000000000
          },
          "exponential_step_minting": null
        },
        {
          "SequenceId": 2,
          "end_time": null,
          "type": "NO_MINTING",
          "linear_minting": null,
          "exponential_step_minting": null
        }
      ]
    }
  }
}

State

Chain4Energy minter module state contains informations used by current minting period. Module state contains followng data:

Key Type Description
minter_state MinterState current minting period state
state_history List of MinterState previuos minting Minters final states
MinterState
Key Type Description
sequence_id uint32 current minting period SequenceId
amount_minted sdk.Int amount minted by current minting period
remainder_to_mint sdk.Dec decimal remainder - decimal amount that should be minted but was not Int.
last_mint_block_time sdk.Time Time of last mint
remainder_from_previous_period sdk.Dec decimal remainder left by previous minting period
Example state
{
  "minter_state": {
    "sequence_id": 1,
    "amount_minted": "13766330043442",
    "remainder_to_mint": "0.415017757483510908",
    "last_mint_block_time": "2022-11-07T14:49:34.606250Z",
    "remainder_from_previous_period": "0.000000000000000000"
  },
  "state_history": []
}

Events

Chain4Energy minter module emits the following events:

BeginBlockers
Mint
Type Attribute Key Attribute Value
bonded_ratio Dec
inflation sdk.Dec Minting block inflation level
amount sdk.Int Amount minted in block

TODO remove bonded_ratio TODO add minter period id

Queries

Params query

Queries the module params.

See example reponse:

{
  "params": {
    "mint_denom": "uc4e",
    "minter_config": {
      "start_time": "2022-07-05T00:00:00Z",
      "minters": [
        {
          "sequence_id": 1,
          "end_time": null,
          "type": "EXPONENTIAL_STEP_MINTING",
          "linear_minting": null,
          "exponential_step_minting": {
            "step_duration": "31536000s",
            "amount": "40000000000000",
            "amount_multiplier": "0.500000000000000000"
          }
        }
      ]
    }
  }
}
State query

Queries the module state.

See example reponse:

{
  "minter_state": {
    "sequence_id": 1,
    "amount_minted": "13766330043442",
    "remainder_to_mint": "0.415017757483510908",
    "last_mint_block_time": "2022-11-07T14:49:34.606250Z",
    "remainder_from_previous_period": "0.000000000000000000"
  },
  "state_history": []
}
Inflation query

Queries current inflation.

See example reponse:

{
  "inflation": "0.102489480201216908"
}

Genesis validations

TODO

Documentation

Index

Constants

View Source
const SecondsInYear = int32(3600 * 24 * 365)

Variables

This section is empty.

Functions

func BeginBlocker

func BeginBlocker(ctx sdk.Context, k keeper.Keeper)

BeginBlocker mints new tokens for the previous block.

func ExportGenesis

func ExportGenesis(ctx sdk.Context, k keeper.Keeper) *types.GenesisState

ExportGenesis returns the capability module's exported genesis.

func InitGenesis

func InitGenesis(ctx sdk.Context, k keeper.Keeper, ak types.AccountKeeper, genState types.GenesisState)

InitGenesis initializes the capability module's state from a provided genesis state.

func NewHandler

func NewHandler(k keeper.Keeper) sdk.Handler

NewHandler ...

Types

type AppModule

type AppModule struct {
	AppModuleBasic
	// contains filtered or unexported fields
}

AppModule implements the AppModule interface for the capability module.

func NewAppModule

func NewAppModule(
	cdc codec.Codec,
	keeper keeper.Keeper,
	accountKeeper types.AccountKeeper,
	bankKeeper types.BankKeeper,
) AppModule

func (AppModule) BeginBlock

func (am AppModule) BeginBlock(ctx sdk.Context, _ abci.RequestBeginBlock)

BeginBlock executes all ABCI BeginBlock logic respective to the capability module.

func (AppModule) ConsensusVersion

func (AppModule) ConsensusVersion() uint64

ConsensusVersion implements ConsensusVersion.

func (AppModule) EndBlock

EndBlock executes all ABCI EndBlock logic respective to the capability module. It returns no validator updates.

func (AppModule) ExportGenesis

func (am AppModule) ExportGenesis(ctx sdk.Context, cdc codec.JSONCodec) json.RawMessage

ExportGenesis returns the capability module's exported genesis state as raw JSON bytes.

func (AppModule) GenerateGenesisState

func (AppModule) GenerateGenesisState(simState *module.SimulationState)

GenerateGenesisState creates a randomized GenState of the module

func (AppModule) InitGenesis

func (am AppModule) InitGenesis(ctx sdk.Context, cdc codec.JSONCodec, gs json.RawMessage) []abci.ValidatorUpdate

InitGenesis performs the capability module's genesis initialization It returns no validator updates.

func (AppModule) LegacyQuerierHandler

func (am AppModule) LegacyQuerierHandler(legacyQuerierCdc *codec.LegacyAmino) sdk.Querier

LegacyQuerierHandler returns the capability module's Querier.

func (AppModule) Name

func (am AppModule) Name() string

Name returns the capability module's name.

func (AppModule) ProposalContents

ProposalContents doesn't return any content functions for governance proposals

func (AppModule) QuerierRoute

func (AppModule) QuerierRoute() string

QuerierRoute returns the capability module's query routing key.

func (AppModule) RandomizedParams

func (am AppModule) RandomizedParams(_ *rand.Rand) []simtypes.ParamChange

RandomizedParams creates randomized param changes for the simulator

func (AppModule) RegisterInvariants

func (am AppModule) RegisterInvariants(_ sdk.InvariantRegistry)

RegisterInvariants registers the capability module's invariants.

func (AppModule) RegisterServices

func (am AppModule) RegisterServices(cfg module.Configurator)

RegisterServices registers a GRPC query service to respond to the module-specific GRPC queries.

func (AppModule) RegisterStoreDecoder

func (am AppModule) RegisterStoreDecoder(_ sdk.StoreDecoderRegistry)

RegisterStoreDecoder registers a decoder

func (AppModule) Route

func (am AppModule) Route() sdk.Route

Route returns the capability module's message routing key.

func (AppModule) WeightedOperations

func (am AppModule) WeightedOperations(simState module.SimulationState) []simtypes.WeightedOperation

WeightedOperations returns the all the gov module operations with their respective weights.

type AppModuleBasic

type AppModuleBasic struct {
	// contains filtered or unexported fields
}

AppModuleBasic implements the AppModuleBasic interface for the capability module.

func NewAppModuleBasic

func NewAppModuleBasic(cdc codec.BinaryCodec) AppModuleBasic

func (AppModuleBasic) DefaultGenesis

func (AppModuleBasic) DefaultGenesis(cdc codec.JSONCodec) json.RawMessage

DefaultGenesis returns the capability module's default genesis state.

func (AppModuleBasic) GetQueryCmd

func (AppModuleBasic) GetQueryCmd() *cobra.Command

GetQueryCmd returns the capability module's root query command.

func (AppModuleBasic) GetTxCmd

func (a AppModuleBasic) GetTxCmd() *cobra.Command

GetTxCmd returns the capability module's root tx command.

func (AppModuleBasic) Name

func (AppModuleBasic) Name() string

Name returns the capability module's name.

func (AppModuleBasic) RegisterCodec

func (AppModuleBasic) RegisterCodec(cdc *codec.LegacyAmino)

func (AppModuleBasic) RegisterGRPCGatewayRoutes

func (AppModuleBasic) RegisterGRPCGatewayRoutes(clientCtx client.Context, mux *runtime.ServeMux)

RegisterGRPCGatewayRoutes registers the gRPC Gateway routes for the module.

func (AppModuleBasic) RegisterInterfaces

func (a AppModuleBasic) RegisterInterfaces(reg cdctypes.InterfaceRegistry)

RegisterInterfaces registers the module's interface types

func (AppModuleBasic) RegisterLegacyAminoCodec

func (AppModuleBasic) RegisterLegacyAminoCodec(cdc *codec.LegacyAmino)

func (AppModuleBasic) RegisterRESTRoutes

func (AppModuleBasic) RegisterRESTRoutes(clientCtx client.Context, rtr *mux.Router)

RegisterRESTRoutes registers the capability module's REST service handlers.

func (AppModuleBasic) ValidateGenesis

func (AppModuleBasic) ValidateGenesis(cdc codec.JSONCodec, config client.TxEncodingConfig, bz json.RawMessage) error

ValidateGenesis performs genesis state validation for the capability module.

Directories

Path Synopsis
client
cli
migrations
Package types is a reverse proxy.
Package types is a reverse proxy.

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL