contract

package
v0.5.2 Latest Latest
Warning

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

Go to latest
Published: Jan 13, 2022 License: Apache-2.0 Imports: 18 Imported by: 6

README

Contracts

Tgrade smart contracts. See https://github.com/confio/tgrade-contracts for source code and details.

Arch with Gov Architecture

Developers

Test strategy

Contract interactions (query/ updates) should be covered by integration tests that talk to the real contract(s) We need to ensure that things work as expected but also to provide "consumer driven contracts" in code that couple both worlds to be stable. Though there are use cases that would also be covered by system tests like create-validator or end block callback. In this case we have enough confidence.

Pure Go code should be unit tested only

Download new artifacts

Requires a github access token

Example to download contract for tag v0.1.3

./download_releases.sh v0.1.3
OSX
Preparation
  1. Create access token on github with access to private repos!
Store key in OS keychain
  1. Copy token to clipboard
  2. Add to your OS keychain
security add-generic-password -a "$USER" -s 'github_api_key' -w "$(pbpaste)"

The script will read the token from the OS keychain

Others

Set your api key via environment GITHUB_API_TOKEN variable before running the download script

Documentation

Index

Constants

This section is empty.

Variables

This section is empty.

Functions

func BondDelegation

func BondDelegation(ctx sdk.Context, contractAddr sdk.AccAddress, operatorAddress sdk.AccAddress, amount sdk.Coins, k types.Executor) error

BondDelegation sends given amount to the staking contract to increase the bonded amount for the validator operator

func CallEndBlockWithValidatorUpdate

func CallEndBlockWithValidatorUpdate(ctx sdk.Context, contractAddr sdk.AccAddress, k types.Sudoer) ([]abci.ValidatorUpdate, error)

CallEndBlockWithValidatorUpdate calls valset contract for a validator diff

func DecimalFromPercentage

func DecimalFromPercentage(percent sdk.Dec) *sdk.Dec

func DecimalFromProMille

func DecimalFromProMille(promille int64) *sdk.Dec

func QueryTG4Admin

func QueryTG4Admin(ctx sdk.Context, k types.SmartQuerier, tg4Addr sdk.AccAddress) (sdk.AccAddress, error)

QueryTG4Admin returns admin of this contract, if any. Will return nil, err if no admin

func QueryTG4Member

func QueryTG4Member(ctx sdk.Context, k types.SmartQuerier, tg4Addr sdk.AccAddress, member sdk.AccAddress) (*int, error)

QueryTG4Member returns the weight of this member. (nil, nil) means not present, (&0, nil) means member with no votes

func QueryTG4TotalWeight

func QueryTG4TotalWeight(ctx sdk.Context, k types.SmartQuerier, tg4Addr sdk.AccAddress) (int, error)

QueryTG4TotalWeight returns the weight of this member. (nil, nil) means not present

func RegisterValidator

func RegisterValidator(ctx sdk.Context, contractAddr sdk.AccAddress, pk cryptotypes.PubKey, operatorAddress sdk.AccAddress, description stakingtypes.Description, k types.Executor) error

RegisterValidator calls valset contract to register a new validator key and address

func SetEngagementPoints

func SetEngagementPoints(ctx sdk.Context, contractAddr sdk.AccAddress, k types.Sudoer, opAddr sdk.AccAddress, points uint64) error

SetEngagementPoints set engagement points If the member already exists, its weight will be reset to the weight sent here

func UnbondDelegation

func UnbondDelegation(ctx sdk.Context, contractAddr sdk.AccAddress, operatorAddress sdk.AccAddress, amount sdk.Coin, k types.Executor) error

UnbondDelegation unbond the given amount from the operators self delegation Amount must be in bonding token denom

func UpdateValidator

func UpdateValidator(ctx sdk.Context, contractAddr sdk.AccAddress, operatorAddress sdk.AccAddress, description stakingtypes.Description, k types.Executor) error

UpdateValidator calls valset contract to change validator's metadata

Types

type AlgebraicSigmoid

type AlgebraicSigmoid struct {
	MaxRewards uint64  `json:"max_rewards,string"`
	A          sdk.Dec `json:"a"`
	P          sdk.Dec `json:"p"`
	S          sdk.Dec `json:"s"`
}

type ChainUpgrade

type ChainUpgrade struct {
	Name   string `json:"name"`
	Height uint64 `json:"height"`
	Info   string `json:"info"`
}

ChainUpgrade defines a subset of attributes for testing only

type CommunityPoolInitMsg

type CommunityPoolInitMsg struct {
	VotingRules  VotingRules `json:"rules"`
	GroupAddress string      `json:"group_addr"`
}

type ContractAdapter

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

ContractAdapter is the base contract adapter type that contains common methods to interact with the contract

func NewContractAdapter

func NewContractAdapter(contractAddr sdk.AccAddress, twasmKeeper types.TWasmKeeper, addressLookupErr error) ContractAdapter

NewContractAdapter constructor

type DistributionContract

type DistributionContract struct {
	Address string `json:"contract"`
	// Ratio of total reward tokens for an epoch to be sent to that contract for further distribution.
	// Range 0 - 1
	Ratio sdk.Dec `json:"ratio"`
}

type DistributionContractAdapter

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

func NewDistributionContractAdapter

func NewDistributionContractAdapter(contractAddr sdk.AccAddress, contractQuerier types.SmartQuerier, addressLookupErr error) *DistributionContractAdapter

NewDistributionContractAdapter constructor

func (DistributionContractAdapter) ValidatorOutstandingReward

func (d DistributionContractAdapter) ValidatorOutstandingReward(ctx sdk.Context, addr sdk.AccAddress) (sdk.Coin, error)

type DistributionQuery

type DistributionQuery struct {
	WithdrawableFunds *WithdrawableFundsQuery `json:"withdrawable_funds,omitempty"`
}

type EndWithValidatorUpdateResponse

type EndWithValidatorUpdateResponse struct {
	Diffs []ValidatorUpdate `json:"diffs"`
}

EndWithValidatorUpdateResponse is the response to an `EndWithValidatorUpdate` sudo call.

type EngagementContractAdapter

type EngagementContractAdapter struct {
	ContractAdapter
}

func NewEngagementContractAdapter

func NewEngagementContractAdapter(contractAddr sdk.AccAddress, twasmKeeper types.TWasmKeeper, addressLookupErr error) *EngagementContractAdapter

NewEngagementContractAdapter constructor

func (EngagementContractAdapter) UpdateAdmin

func (a EngagementContractAdapter) UpdateAdmin(ctx sdk.Context, newAdmin, sender sdk.AccAddress) error

type FundsResponse

type FundsResponse struct {
	Funds sdk.Coin
}

type GrantEngagementProposal

type GrantEngagementProposal struct {
	Member string `json:"member"`
	Points uint64 `json:"points"`
}

type JailMsg

type JailMsg struct {
	Operator string `json:"operator"`
	// Duration for how long validator is jailed (in seconds)
	Duration JailingDuration `json:"duration"`
}

type JailingDuration added in v0.5.2

type JailingDuration struct {
	Duration uint64 `json:"duration,omitempty"`
	Forever  bool   `json:"forever,omitempty"`
}

func (JailingDuration) MarshalJSON added in v0.5.2

func (j JailingDuration) MarshalJSON() ([]byte, error)

type JailingPeriod added in v0.5.2

type JailingPeriod struct {
	Forever bool      `json:"forever,omitempty"`
	Until   time.Time `json:"until,omitempty"`
}

func (*JailingPeriod) UnmarshalJSON added in v0.5.2

func (j *JailingPeriod) UnmarshalJSON(data []byte) error

type ListActiveValidatorsResponse

type ListActiveValidatorsResponse struct {
	Validators []ValidatorInfo `json:"validators"`
}

type ListClaimsQuery

type ListClaimsQuery struct {
	Address string `json:"address"`
	// Limit for pagination
	Limit uint32 `json:"limit,omitempty"`
	// StartAfter is used for pagination. Take last `claim.ReleaseAt` from last query
	StartAfter uint64 `json:"start_after,string,omitempty"`
}

type ListMembersByWeightQuery

type ListMembersByWeightQuery struct {
	StartAfter *TG4Member `json:"start_after,omitempty"`
	Limit      int        `json:"limit,omitempty"`
}

type ListMembersQuery

type ListMembersQuery struct {
	StartAfter string `json:"start_after,omitempty"`
	Limit      int    `json:"limit,omitempty"`
}

type ListProposalQuery

type ListProposalQuery struct {
	StartAfter uint64 `json:"start_after,omitempty"`
	Limit      uint32 `json:"limit,omitempty"`
}

type ListValidatorSlashingResponse

type ListValidatorSlashingResponse struct {
	Operator    string              `json:"operator"`
	StartHeight uint64              `json:"start_height"`
	Slashing    []ValidatorSlashing `json:"slashing"`
}

type ListValidatorsQuery

type ListValidatorsQuery struct {
	StartAfter string `json:"start_after,omitempty"`
	Limit      int    `json:"limit,omitempty"`
}

type ListValidatorsResponse

type ListValidatorsResponse struct {
	Validators []OperatorResponse `json:"validators"`
}

type ListVotersQuery

type ListVotersQuery struct {
	StartAfter string `json:"start_after,omitempty"`
	Limit      uint32 `json:"limit,omitempty"`
}

type ListVotesQuery

type ListVotesQuery struct {
	ProposalID uint64 `json:"proposal_id"`
	StartAfter string `json:"start_after,omitempty"`
	Limit      uint32 `json:"limit,omitempty"`
}

type MemberQuery

type MemberQuery struct {
	Addr     string `json:"addr"`
	AtHeight int    `json:"at_height,omitempty"`
}

type MixerFunction

type MixerFunction struct {
	GeometricMean    *struct{}         `json:"geometric_mean,omitempty"`
	Sigmoid          *Sigmoid          `json:"sigmoid,omitempty"`
	SigmoidSqrt      *SigmoidSqrt      `json:"sigmoid_sqrt,omitempty"`
	AlgebraicSigmoid *AlgebraicSigmoid `json:"algebaic_sigmoid,omitempty"`
}

type OCProposalListResponse

type OCProposalListResponse struct {
	Proposals []OCProposalResponse `json:"proposals"`
}

type OCProposalResponse

type OCProposalResponse struct {
	ID          uint64            `json:"id"`
	Title       string            `json:"title"`
	Description string            `json:"description"`
	Proposal    OversightProposal `json:"proposal"`
	Status      ProposalStatus    `json:"status"`
	// TODO: clarify this format
	// Expires     EXP               `json:"expires"`
	Rules       VotingRules `json:"rules"`
	TotalWeight uint64      `json:"total_weight"`
	Votes       Votes       `json:"votes"`
}

type OCProposalsContractAdapter

type OCProposalsContractAdapter struct {
	VotingContractAdapter
}

func NewOCProposalsContractAdapter

func NewOCProposalsContractAdapter(contractAddr sdk.AccAddress, twasmKeeper types.TWasmKeeper, addressLookupErr error) *OCProposalsContractAdapter

NewOCProposalsContractAdapter constructor

func (OCProposalsContractAdapter) ProposeGrant

func (v OCProposalsContractAdapter) ProposeGrant(ctx sdk.Context, grantee sdk.AccAddress, points uint64, sender sdk.AccAddress) error

ProposeGrant creates a proposal to grant engagement to this account Use LatestProposal after to get the ProposalID

func (OCProposalsContractAdapter) ProposeSlash

func (v OCProposalsContractAdapter) ProposeSlash(ctx sdk.Context, member sdk.AccAddress, portion sdk.Dec, sender sdk.AccAddress) error

ProposeSlash creates a proposal to slash this account Use LatestProposal after to get the ProposalID

type OCProposalsExecuteMsg

type OCProposalsExecuteMsg struct {
	Propose *ProposalMsg `json:"propose,omitempty"`
	Vote    *VoteMsg     `json:"vote,omitempty"`
	Execute *ProposalID  `json:"execute,omitempty"`
	Close   *ProposalID  `json:"close,omitempty"`
}

type OCProposalsInitMsg

type OCProposalsInitMsg struct {
	VotingRules VotingRules `json:"rules"`
	// GroupContractAddress is the group contract that contains the member list
	GroupContractAddress string `json:"group_addr"`
	// EngagementContractAddress is the engagement contract that contains list for engagement rewards
	EngagementContractAddress string `json:"engagement_addr"`
	// ValsetContractAddress is the valset contract that we execute slashing on
	ValsetContractAddress string `json:"valset_addr"`
}

OCProposalsInitMsg instantiation message

type OperatorResponse

type OperatorResponse struct {
	Operator    string            `json:"operator"`
	Pubkey      ValidatorPubkey   `json:"pubkey"`
	Metadata    ValidatorMetadata `json:"metadata"`
	JailedUntil *JailingPeriod    `json:"jailed_until,omitempty"`
}

func (OperatorResponse) ToValidator

func (v OperatorResponse) ToValidator() (stakingtypes.Validator, error)

type OversightProposal

type OversightProposal struct {
	GrantEngagement *GrantEngagementProposal `json:"grant_engagement,omitempty"`
	Slash           *SlashProposal           `json:"punish,omitempty"`
}

type ProposalID

type ProposalID struct {
	ProposalID uint64 `json:"proposal_id"`
}

type ProposalMsg

type ProposalMsg struct {
	Title       string            `json:"title"`
	Description string            `json:"description"`
	Proposal    OversightProposal `json:"proposal"`
}

type ProposalStatus

type ProposalStatus string
const (
	ProposalStatusPending  ProposalStatus = "pending"
	ProposalStatusOpen     ProposalStatus = "open"
	ProposalStatusRejected ProposalStatus = "rejected"
	ProposalStatusPassed   ProposalStatus = "passed"
	ProposalStatusExecuted ProposalStatus = "executed"
)

type ProposalsQuery

type ProposalsQuery struct {
	// Returns VotingRules
	Rules *struct{} `json:"rules,omitempty"`
	// Returns OCProposalResponse
	Proposal *ProposalID `json:"proposal,omitempty"`
	// Returns OCProposalListResponse
	ListProposals *ListProposalQuery `json:"list_proposals,omitempty"`
	// Returns OCProposalListResponse
	ReverseProposals *ListProposalQuery `json:"reverse_proposals,omitempty"`
	// Returns VoteResponse
	Vote *VoteQuery `json:"vote,omitempty"`
	// Returns VoteListResponse
	ListVotes *ListVotesQuery `json:"list_votes,omitempty"`
	// Returns VoterResponse
	Voter *VoterQuery `json:"voter,omitempty"`
	// Returns VoterListResponse
	ListVoters *ListVotersQuery `json:"list_voters,omitempty"`
}

type RegisterValidatorKey

type RegisterValidatorKey struct {
	PubKey   ValidatorPubkey   `json:"pubkey"`
	Metadata ValidatorMetadata `json:"metadata"`
}

type Sigmoid

type Sigmoid struct {
	MaxRewards uint64  `json:"max_rewards,string"`
	P          sdk.Dec `json:"p"`
	S          sdk.Dec `json:"s"`
}

type SigmoidSqrt

type SigmoidSqrt struct {
	MaxRewards uint64  `json:"max_rewards,string"`
	S          sdk.Dec `json:"s"`
}

type SimulateActiveValidatorsResponse

type SimulateActiveValidatorsResponse = ListActiveValidatorsResponse

type SlashProposal

type SlashProposal struct {
	Member  string  `json:"member"`
	Portion sdk.Dec `json:"portion"`
}

type StakeContractAdapter

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

func NewStakeContractAdapter

func NewStakeContractAdapter(contractAddr sdk.AccAddress, contractQuerier types.SmartQuerier, addressLookupErr error) *StakeContractAdapter

NewStakeContractAdapter constructor

func (StakeContractAdapter) QueryStakedAmount

func (v StakeContractAdapter) QueryStakedAmount(ctx sdk.Context, opAddr sdk.AccAddress) (*sdk.Int, error)

func (StakeContractAdapter) QueryStakingUnbonding

func (v StakeContractAdapter) QueryStakingUnbonding(ctx sdk.Context, opAddr sdk.AccAddress) ([]stakingtypes.UnbondingDelegationEntry, error)

QueryStakingUnbonding query PoE staking contract for unbonded self delegations TODO: add pagination support here!

func (StakeContractAdapter) QueryStakingUnbondingPeriod

func (v StakeContractAdapter) QueryStakingUnbondingPeriod(ctx sdk.Context) (time.Duration, error)

QueryStakingUnbondingPeriod query the unbonding period from PoE staking contract

type StakedQuery

type StakedQuery struct {
	Address string `json:"address"`
}

type TG4AdminResponse

type TG4AdminResponse struct {
	Admin string `json:"admin,omitempty"`
}

type TG4EngagementExecute

type TG4EngagementExecute struct {
	UpdateMembers *UpdateMembersMsg  `json:"update_members,omitempty"`
	UpdateAdmin   *TG4UpdateAdminMsg `json:"update_admin,omitempty"`
}

TG4EngagementExecute execute message See https://github.com/confio/tgrade-contracts/blob/v0.5.0-alpha/contracts/tg4-engagement/src/msg.rs

type TG4EngagementInitMsg

type TG4EngagementInitMsg struct {
	Admin            string      `json:"admin,omitempty"`
	Members          []TG4Member `json:"members"`
	PreAuthsHooks    uint64      `json:"preauths_hooks,omitempty"`
	PreAuthsSlashing uint64      `json:"preauths_slashing,omitempty"`
	// Halflife is measured in seconds
	Halflife uint64 `json:"halflife,omitempty"`
	// Denom of tokens which may be distributed by this contract.
	Denom string `json:"denom"`
}

TG4EngagementInitMsg contract init message See https://github.com/confio/tgrade-contracts/blob/v0.5.0-alpha/contracts/tg4-engagement/src/msg.rs

type TG4EngagementSudoMsg

type TG4EngagementSudoMsg struct {
	UpdateMember *TG4Member `json:"update_member,omitempty"`
}

TG4EngagementSudoMsg TG4 group sudo message See https://github.com/confio/tgrade-contracts/blob/v0.5.0-alpha/contracts/tg4-engagement/src/msg.rs

type TG4Member

type TG4Member struct {
	Addr   string `json:"addr"`
	Weight uint64 `json:"weight"`
}

func QueryTG4Members

func QueryTG4Members(ctx sdk.Context, k types.SmartQuerier, tg4Addr sdk.AccAddress, pagination *types.Paginator) ([]TG4Member, error)

func QueryTG4MembersByWeight

func QueryTG4MembersByWeight(ctx sdk.Context, k types.SmartQuerier, tg4Addr sdk.AccAddress, pagination *types.Paginator) ([]TG4Member, error)

func SortByWeightDesc

func SortByWeightDesc(s []TG4Member) []TG4Member

type TG4MemberListResponse

type TG4MemberListResponse struct {
	Members []TG4Member `json:"members"`
}

TG4MemberListResponse response to a list members query.

type TG4MemberResponse

type TG4MemberResponse struct {
	// Weight nil means not a member, 0 means member with no voting power... this can be a very important distinction
	Weight *int `json:"weight"`
}

type TG4MixerInitMsg

type TG4MixerInitMsg struct {
	LeftGroup        string        `json:"left_group"`
	RightGroup       string        `json:"right_group"`
	PreAuthsHooks    uint64        `json:"preauths_hooks,omitempty"`
	PreAuthsSlashing uint64        `json:"preauths_slashing,omitempty"`
	FunctionType     MixerFunction `json:"function_type"`
}

TG4MixerInitMsg contract init message See https://github.com/confio/tgrade-contracts/blob/main/contracts/tg4-mixer/schema/instantiate_msg.json

type TG4Query

type TG4Query struct {
	Admin               *struct{}                 `json:"admin,omitempty"`
	TotalWeight         *struct{}                 `json:"total_weight,omitempty"`
	ListMembers         *ListMembersQuery         `json:"list_members,omitempty"`
	ListMembersByWeight *ListMembersByWeightQuery `json:"list_members_by_weight,omitempty"`
	Member              *MemberQuery              `json:"member,omitempty"`
}

TG4Query applies to all tg4 types - stake, group, and mixer

type TG4StakeClaim

type TG4StakeClaim struct {
	// Addr A human readable address
	Addr string `json:"addr"`
	// Amount of tokens in claim
	Amount sdk.Int `json:"amount"`
	// CreationHeight Height of a blockchain in a moment of creation of this claim
	CreationHeight uint64 `json:"creation_height"`
	// ReleaseAt is the release time of the claim as timestamp in nanoseconds
	ReleaseAt uint64 `json:"release_at,string,omitempty"`
}

type TG4StakeClaimsResponse

type TG4StakeClaimsResponse struct {
	Claims []TG4StakeClaim `json:"claims"`
}

type TG4StakeExecute

type TG4StakeExecute struct {
	Bond   *struct{} `json:"bond,omitempty"`
	Unbond *Unbond   `json:"unbond,omitempty"`
	Claim  *struct{} `json:"claim,omitempty"`
}

TG4StakeExecute staking contract execute messages See https://github.com/confio/tgrade-contracts/blob/v0.5.0-alpha/contracts/tg4-stake/src/msg.rs

type TG4StakeInitMsg

type TG4StakeInitMsg struct {
	Admin           string `json:"admin,omitempty"`
	Denom           string `json:"denom"`
	MinBond         uint64 `json:"min_bond,string"`
	TokensPerWeight uint64 `json:"tokens_per_weight,string"`
	// UnbondingPeriod unbonding period in seconds
	UnbondingPeriod uint64 `json:"unbonding_period"`
	// AutoReturnLimit limits how much claims would be automatically returned at end of block, 20 by default. Setting this to 0 disables auto returning claims.
	AutoReturnLimit  *uint64 `json:"auto_return_limit,omitempty"`
	PreAuthsHooks    uint64  `json:"preauths_hooks,omitempty"`
	PreAuthsSlashing uint64  `json:"preauths_slashing,omitempty"`
}

TG4StakeInitMsg instantiation message See https://github.com/confio/tgrade-contracts/blob/v0.5.0-alpha/contracts/tg4-stake/src/msg.rs

type TG4StakeQuery

type TG4StakeQuery struct {
	UnbondingPeriod *struct{}        `json:"unbonding_period,omitempty"`
	Claims          *ListClaimsQuery `json:"claims,omitempty"`
	Staked          *StakedQuery     `json:"staked,omitempty"`
}

TG4StakeQuery contains some custom queries for the tg4-stake contract. You can also make any generic TG4Query on it. See https://github.com/confio/tgrade-contracts/blob/v0.5.0-alpha/contracts/tg4-stake/src/msg.rs

type TG4StakedAmountsResponse

type TG4StakedAmountsResponse struct {
	Stake wasmvmtypes.Coin `json:"stake"`
}

func QueryStakedAmount

func QueryStakedAmount(ctx sdk.Context, k types.SmartQuerier, stakeAddr sdk.AccAddress, opAddr sdk.AccAddress) (TG4StakedAmountsResponse, error)

QueryStakedAmount query PoE staking contract for bonded self delegation amount

type TG4TotalWeightResponse

type TG4TotalWeightResponse struct {
	Weight int `json:"weight"`
}

type TG4UpdateAdminMsg

type TG4UpdateAdminMsg struct {
	NewAdmin *string `json:"admin,omitempty"`
}

TG4UpdateAdminMsg update admin message

type TG4ValsetExecute

type TG4ValsetExecute struct {
	RegisterValidatorKey *RegisterValidatorKey `json:"register_validator_key,omitempty"`
	UpdateMetadata       *ValidatorMetadata    `json:"update_metadata,omitempty"`
	// Jails validator. Can be executed only by the admin.
	Jail *JailMsg `json:"jail,omitempty"`
	// Unjails validator. Admin can unjail anyone anytime, others can unjail only themselves and
	// only if the jail period passed.
	Unjail *UnjailMsg `json:"unjail,omitempty"`
	// UpdateAdmin set a new admin address
	UpdateAdmin *TG4UpdateAdminMsg `json:"update_admin,omitempty"`
}

TG4ValsetExecute Valset contract validator key registration See https://github.com/confio/tgrade-contracts/tree/v0.5.0-alpha/contracts/tgrade-valset/src/msg.rs

type TrustedCircleInitMsg

type TrustedCircleInitMsg struct {
	// Name of trusted circle
	Name string `json:"name"`
	// EscrowAmount The required escrow amount, in the default denom (utgd)
	EscrowAmount sdk.Int `json:"escrow_amount"`
	// VotingPeriod Voting period in days
	VotingPeriod uint32 `json:"voting_period"`
	// Quorum voting quorum (0.0-1.0)
	Quorum sdk.Dec `json:"quorum"`
	// Threshold voting threshold (0.0-1.0)
	Threshold sdk.Dec `json:"threshold"`
	// AllowEndEarly If true, and absolute threshold and quorum are met, we can end before voting period finished.
	// (Recommended value: true, unless you have special needs)
	AllowEndEarly bool `json:"allow_end_early"`
	// InitialMembers is a list of non-voting members to be added to the TRUSTED_CIRCLE upon creation
	InitialMembers []string `json:"initial_members"`
	// DenyList is an optional cw4 contract with list of addresses denied to be part of TrustedCircle
	DenyList string `json:"deny_list,omitempty"`
	// EditTrustedCircleDisabled If true, no further adjustments may happen.
	EditTrustedCircleDisabled bool `json:"edit_trusted_circle_disabled"`
}

type Unbond

type Unbond struct {
	// Tokens are the amount to unbond
	Tokens wasmvmtypes.Coin `json:"tokens"`
}

Unbond will start the unbonding process for the given number of tokens. The sender immediately loses weight from these tokens, and can claim them back to his wallet after `unbonding_period`",

type UnbondingPeriodResponse

type UnbondingPeriodResponse struct {
	// Time is the number of seconds that must pass
	UnbondingPeriod uint64 `json:"unbonding_period"`
}

type UnjailMsg

type UnjailMsg struct {
	// Address to unjail. Optional, as if not provided it is assumed to be the sender of the
	// message (for convenience when unjailing self after the jail period).
	Operator string `json:"operator,omitempty"`
}

type UpdateMembersMsg

type UpdateMembersMsg struct {
	Add    []TG4Member `json:"add"`
	Remove []string    `json:"remove"`
}

UpdateMembersMsg contract execute message to update members See https://github.com/confio/tgrade-contracts/blob/v0.5.0-alpha/contracts/tg4-engagement/src/msg.rs

func (*UpdateMembersMsg) Json

func (m *UpdateMembersMsg) Json(t *testing.T) string

type Validator

type Validator struct {
	Operator        string          `json:"operator"`
	ValidatorPubkey ValidatorPubkey `json:"validator_pubkey"`
}

type ValidatorInfo

type ValidatorInfo struct {
	Operator        string          `json:"operator"`
	ValidatorPubkey ValidatorPubkey `json:"validator_pubkey"`
	Power           uint64          `json:"power"`
}

func ListActiveValidators

func ListActiveValidators(ctx sdk.Context, k types.SmartQuerier, valset sdk.AccAddress) ([]ValidatorInfo, error)

func SimulateActiveValidators

func SimulateActiveValidators(ctx sdk.Context, k types.SmartQuerier, valset sdk.AccAddress) ([]ValidatorInfo, error)

type ValidatorMetadata

type ValidatorMetadata struct {
	// moniker defines a human-readable name for the validator.
	Moniker string `json:"moniker"`
	// identity defines an optional identity signature (ex. UPort or Keybase).
	Identity string `json:"identity,omitempty"`
	// website defines an optional website link.
	Website string `json:"website,omitempty"`
	// security_contact defines an optional email for security contact.
	SecurityContact string `json:"security_contact,omitempty"`
	// details define other optional details.
	Details string `json:"details,omitempty"`
}

func MetadataFromDescription

func MetadataFromDescription(description stakingtypes.Description) ValidatorMetadata

func (ValidatorMetadata) ToDescription

func (m ValidatorMetadata) ToDescription() stakingtypes.Description

type ValidatorProposal

type ValidatorProposal struct {
	// PinCodes that should be pinned in cache for high performance
	PinCodes        []uint64      `json:"pin_codes,omitempty"`
	RegisterUpgrade *ChainUpgrade `json:"register_upgrade,omitempty"`
}

ValidatorProposal proposal options. Incomplete list as this is used for testing only within tgrade. Clients may use all options defined in the contract.

type ValidatorPubkey

type ValidatorPubkey struct {
	Ed25519   []byte `json:"ed25519,omitempty"`
	Secp256k1 []byte `json:"secp256k1,omitempty"`
	Sr25519   []byte `json:"sr25519,omitempty"`
}

func NewValidatorPubkey

func NewValidatorPubkey(pk cryptotypes.PubKey) (ValidatorPubkey, error)

type ValidatorQuery

type ValidatorQuery struct {
	Operator string `json:"operator"`
}

type ValidatorResponse

type ValidatorResponse struct {
	Validator *OperatorResponse `json:"validator"`
}

type ValidatorSlashing

type ValidatorSlashing struct {
	Height  uint64  `json:"slash_height"`
	Portion sdk.Dec `json:"portion"`
}

type ValidatorUpdate

type ValidatorUpdate struct {
	// PubKey is the ed25519 pubkey used in Tendermint consensus
	PubKey ValidatorPubkey `json:"pubkey"`
	// Power is the new voting power in the consensus rounds
	Power uint64 `json:"power"`
}

ValidatorUpdate is used to update the validator set See https://github.com/tendermint/tendermint/blob/v0.34.8/proto/tendermint/abci/types.proto#L343-L346

type ValidatorUpdateSudoMsg

type ValidatorUpdateSudoMsg struct {
	/// This will be delivered after everything.
	/// The data in the Response is (JSON?) encoded diff to the validator set
	EndWithValidatorUpdate *struct{} `json:"end_with_validator_update,omitempty"`
}

ValidatorUpdateSudoMsg callback message sent to a contract. See https://github.com/confio/tgrade-contracts/blob/main/packages/bindings/src/sudo.rs

type ValidatorVotingExecuteMsg

type ValidatorVotingExecuteMsg struct {
	Propose *ValidatorVotingPropose `json:"propose,omitempty"`
	Vote    *struct{}               `json:"vote,omitempty"`
	Execute *struct{}               `json:"execute,omitempty"`
}

ValidatorVotingExecuteMsg executable contract message

type ValidatorVotingInitMsg

type ValidatorVotingInitMsg struct {
	VotingRules  VotingRules `json:"rules"`
	GroupAddress string      `json:"group_addr"`
}

ValidatorVotingInitMsg setup contract on instantiation

type ValidatorVotingPropose

type ValidatorVotingPropose struct {
	Title       string            `json:"title"`
	Description string            `json:"description"`
	Proposal    ValidatorProposal `json:"proposal"`
}

ValidatorVotingPropose submit a new gov proposal

type ValsetConfigResponse

type ValsetConfigResponse struct {
	Membership    string   `json:"membership"`
	MinWeight     uint64   `json:"min_weight"`
	MaxValidators uint32   `json:"max_validators"`
	Scaling       uint32   `json:"scaling,omitempty"`
	EpochReward   sdk.Coin `json:"epoch_reward"`
	// Percentage of total accumulated fees which is subtracted from tokens minted as a rewards. A fixed-point decimal value with 18 fractional digits, i.e. Decimal(1_000_000_000_000_000_000) == 1.0
	FeePercentage         sdk.Dec                `json:"fee_percentage"`
	DistributionContracts []DistributionContract `json:"distribution_contracts,omitempty"`
	RewardsContract       string                 `json:"rewards_contract"`
	AutoUnjail            bool                   `json:"auto_unjail"`
}

ValsetConfigResponse Response to `config` query

type ValsetContractAdapter

type ValsetContractAdapter struct {
	ContractAdapter
}

func NewValsetContractAdapter

func NewValsetContractAdapter(contractAddr sdk.AccAddress, twasmKeeper types.TWasmKeeper, addressLookupErr error) *ValsetContractAdapter

NewValsetContractAdapter constructor

func (ValsetContractAdapter) JailValidator added in v0.5.2

func (v ValsetContractAdapter) JailValidator(ctx sdk.Context, nodeOperator sdk.AccAddress, duration time.Duration, forever bool, sender sdk.AccAddress) error

JailValidator is for testing propose only. On a chain the OC does this

func (ValsetContractAdapter) ListValidatorSlashing

func (v ValsetContractAdapter) ListValidatorSlashing(ctx sdk.Context, opAddr sdk.AccAddress) ([]ValidatorSlashing, error)

func (ValsetContractAdapter) ListValidators

func (v ValsetContractAdapter) ListValidators(ctx sdk.Context, pagination *types.Paginator) ([]stakingtypes.Validator, error)

ListValidators query all validators

func (ValsetContractAdapter) QueryConfig

QueryConfig query contract configuration

func (ValsetContractAdapter) QueryRawValidator added in v0.5.2

func (v ValsetContractAdapter) QueryRawValidator(ctx sdk.Context, opAddr sdk.AccAddress) (ValidatorResponse, error)

QueryRawValidator query a single validator as the contract returns it. returns nil when not found

func (ValsetContractAdapter) QueryValidator

func (v ValsetContractAdapter) QueryValidator(ctx sdk.Context, opAddr sdk.AccAddress) (*stakingtypes.Validator, error)

QueryValidator query a single validator and map to the sdk type. returns nil when not found

func (ValsetContractAdapter) UnjailValidator added in v0.5.2

func (v ValsetContractAdapter) UnjailValidator(ctx sdk.Context, sender sdk.AccAddress) error

func (ValsetContractAdapter) UpdateAdmin

func (v ValsetContractAdapter) UpdateAdmin(ctx sdk.Context, newAdmin sdk.AccAddress, sender sdk.AccAddress) error

UpdateAdmin sets a new admin address

type ValsetEpochResponse

type ValsetEpochResponse struct {
	// Number of seconds in one epoch. We update the Tendermint validator set only once per epoch.
	EpochLength uint64 `json:"epoch_length"`
	// The current epoch # (block.time/epoch_length, rounding down)
	CurrentEpoch uint64 `json:"current_epoch"`
	// The last time we updated the validator set - block time (in seconds)
	LastUpdateTime uint64 `json:"last_update_time"`
	// The last time we updated the validator set - block height
	LastUpdateHeight uint64 `json:"last_update_height"`
}

ValsetEpochQueryResponse Response to `config` query

func QueryValsetEpoch

func QueryValsetEpoch(ctx sdk.Context, k types.SmartQuerier, valset sdk.AccAddress) (*ValsetEpochResponse, error)

type ValsetInitMsg

type ValsetInitMsg struct {
	Admin         string      `json:"admin,omitempty"`
	Membership    string      `json:"membership"`
	MinWeight     uint64      `json:"min_weight"`
	MaxValidators uint32      `json:"max_validators"`
	EpochLength   uint64      `json:"epoch_length"`
	EpochReward   sdk.Coin    `json:"epoch_reward"`
	InitialKeys   []Validator `json:"initial_keys"`
	Scaling       uint32      `json:"scaling,omitempty"`
	// Percentage of total accumulated fees which is subtracted from tokens minted as a rewards. A fixed-point decimal value with 18 fractional digits, i.e. Decimal(1_000_000_000_000_000_000) == 1.0
	FeePercentage *sdk.Dec `json:"fee_percentage,omitempty"`
	// If set to true, we will auto-unjail any validator after their jailtime is over.
	AutoUnjail bool `json:"auto_unjail"`
	// This contract receives the rewards that don't go to the validator (set ot tg4-engagement)
	DistributionContracts []DistributionContract `json:"distribution_contracts,omitempty"`
	// This is the code-id of the cw2222-compliant contract used to handle rewards for the validators
	// Generally should the the tg4-engagement code id
	RewardsCodeID uint64 `json:"rewards_code_id"`
}

ValsetInitMsg Valset contract init message See https://github.com/confio/tgrade-contracts/tree/v0.5.0-alpha/contracts/tgrade-valset/src/msg.rs

type ValsetQuery

type ValsetQuery struct {
	Config                   *struct{}            `json:"configuration,omitempty"`
	Epoch                    *struct{}            `json:"epoch,omitempty"`
	Validator                *ValidatorQuery      `json:"validator,omitempty"`
	ListValidators           *ListValidatorsQuery `json:"list_validators,omitempty"`
	ListActiveValidators     *struct{}            `json:"list_active_validators,omitempty"`
	SimulateActiveValidators *struct{}            `json:"simulate_active_validators,omitempty"`
	ListValidatorSlashing    *ValidatorQuery      `json:"list_validator_slashing,omitempty"`
}

ValsetQuery will create many queries for the valset contract See https://github.com/confio/tgrade-contracts/tree/v0.5.0-alpha/contracts/tgrade-valset/src/msg.rs

type Vote

type Vote string
const (
	YES_VOTE     Vote = "yes"
	NO_VOTE      Vote = "no"
	ABSTAIN_VOTE Vote = "abstain"
	VETO_VOTE    Vote = "veto"
)

type VoteInfo

type VoteInfo struct {
	Voter  string `json:"voter"`
	Vote   Vote   `json:"vote"`
	Weight uint64 `json:"weight"`
}

type VoteListResponse

type VoteListResponse struct {
	Votes []VoteInfo `json:"votes"`
}

type VoteMsg

type VoteMsg struct {
	Vote       Vote   `json:"vote"`
	ProposalID uint64 `json:"proposal_id"`
}

type VoteQuery

type VoteQuery struct {
	ProposalID uint64 `json:"proposal_id"`
	Voter      string `json:"voter"`
}

type VoteResponse

type VoteResponse struct {
	Vote *VoteInfo `json:"vote,omitempty"`
}

type VoterDetail

type VoterDetail struct {
	Addr   string `json:"addr"`
	Weight uint64 `json:"weight"`
}

type VoterListResponse

type VoterListResponse struct {
	Voters []VoterDetail `json:"voters"`
}

type VoterQuery

type VoterQuery struct {
	Address string `json:"address"`
}

type VoterResponse

type VoterResponse struct {
	Weight *uint64 `json:"weight"`
}

type Votes

type Votes struct {
	Yes     uint64 `json:"yes"`
	No      uint64 `json:"no"`
	Abstain uint64 `json:"abstain"`
	Veto    uint64 `json:"veto"`
}

type VotingContractAdapter

type VotingContractAdapter struct {
	ContractAdapter
}

func NewVotingContractAdapter

func NewVotingContractAdapter(contractAddr sdk.AccAddress, twasmKeeper types.TWasmKeeper, addressLookupErr error) VotingContractAdapter

NewVotingContractAdapter constructor

func (VotingContractAdapter) ExecuteProposal

func (v VotingContractAdapter) ExecuteProposal(ctx sdk.Context, proposalID uint64, sender sdk.AccAddress) error

ExecuteProposal executes a previously passed proposal

func (VotingContractAdapter) LatestProposal

func (v VotingContractAdapter) LatestProposal(ctx sdk.Context) (*OCProposalResponse, error)

LatestProposal gets info on the last proposal made, easy way to get the ProposalID

func (VotingContractAdapter) QueryProposal

func (v VotingContractAdapter) QueryProposal(ctx sdk.Context, id uint64) (*OCProposalResponse, error)

QueryProposal query a proposal by id

func (VotingContractAdapter) VoteProposal

func (v VotingContractAdapter) VoteProposal(ctx sdk.Context, proposalID uint64, vote Vote, sender sdk.AccAddress) error

VoteProposal votes on a proposal

type VotingRules

type VotingRules struct {
	// VotingPeriod Voting period in days
	VotingPeriod uint32 `json:"voting_period"`
	// Quorum voting quorum (0.0-1.0)
	Quorum sdk.Dec `json:"quorum"`
	// Threshold voting threshold (0.5-1.0)
	Threshold sdk.Dec `json:"threshold"`
	// AllowEndEarly If true, and absolute threshold and quorum are met, we can end before voting period finished.
	// (Recommended value: true, unless you have special needs)
	AllowEndEarly bool `json:"allow_end_early"`
}

VotingRules voting rules

type WithdrawableFundsQuery

type WithdrawableFundsQuery struct {
	Owner string `json:"owner"`
}

Jump to

Keyboard shortcuts

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