Outline
External Data Structures
↑ Back to Outline This section describes external data structures used by the CCV module. The CCV module uses the ABCIValidatorUpdate data structure, which consists of a validator and its power (for more details, take a look at the ABCI specification), i.e.,
ValidatorUpdates, containing an entry for every validator that had its power updated.
The data structures required for creating clients (i.e., ClientState, ConsensusState) are defined in ICS 2.
In the context of CCV, every chain is uniquely defined by their chain ID and the validator set.
Thus, CCV requires the ClientState to contain the chain ID and the ConsensusState for a particular height to contain the validator set at that height.
In addition, the ClientState should contain the UnbondingPeriod.
For an example, take a look at the ClientState and ConsensusState defined in ICS 7.
CCV Data Structures
↑ Back to Outline The CCV module is initialized through theInitGenesis method when the chain is first started. The initialization is done from a genesis state. This is the case for both provider and consumer chains:
-
On the provider chain, the genesis state is described by the following interface:
with
ConsumerStatedefined as -
On the consumer chain, the genesis state is described by the following interface:
preCCVis a flag indicating whether the consumer CCV module starts in pre-CCV state. In pre-CCV state the consumer CCV module MUST NOT pass validator updates to the underlying consensus engine. IfpreCCV == true, thenconnIdmust be set.unbondingPeriodis the unbonding period on the consumer chain.connIdis the ID of the connection end on the consumer chain on top of which the CCV channel will be established. IfconnId == "", a new client of the provider chain and a new connection on top of this client are created.providerClientStateis the client state used to create a new client of the provider chain (as defined in ICS 2). IfconnId != "", thenproviderClientStateis ignored.providerConsensusStateis the consensus state used to create a new client of the provider chain (as defined in ICS 2). IfconnId != "", thenproviderConsensusStateis ignored.counterpartyClientIdis the ID of the client of the consumer chain on the provider chain. Note thatcounterpartyClientIdis only needed to allow the consumer CCV module to initiate the connection opening handshake. IfconnId != "", thencounterpartyClientIdis ignored.initialValSetis the first validator set that will start validating on this consumer chain.transferChannelIdis the ID of a token transfer channel (as defined in ICS 20) used for the Reward Distribution sub-protocol. IftransferChannelId == "", a new token transfer channel is created on top of the same connection as the CCV channel.
Proposal interface in the Governance module documentation of Cosmos SDK),
this specification expects the following fields to be part of the proposals to add new consumer chains (i.e., ConsumerAdditionProposal) and to remove existing ones (i.e., ConsumerRemovalProposal):
-
chainIdis the proposed chain ID of the new consumer chain. It must be different from all other consumer chain IDs of the executing provider chain. -
spawnTimeis the time on the provider chain at which the consumer chain genesis is finalized and all validators are responsible to start their consumer chain validator node. -
connIdis the ID of the connection end on the provider chain on top of which the CCV channel will be established. IfconnId == "", a new client of the consumer chain and a new connection on top of this client are created. Note that a sovereign chain can transition to a consumer chain while maintaining existing IBC channels to other chains by providing a validconnId. -
unbondingPeriodis the unbonding period on the consumer chain. -
transferChannelIdis the ID of a token transfer channel (as defined in ICS 20) used for the Reward Distribution sub-protocol. IftransferChannelId == "", a new token transfer channel is created on top of the same connection as the CCV channel. Note thattransferChannelIdis the ID of the channel end on the consumer chain. -
lockUnbondingOnTimeoutis a boolean value that indicates whether the funds corresponding to the outstanding unbonding operations are to be released in case of a timeout. IflockUnbondingOnTimeout == true, a governance proposal to stop the timed out consumer chain would be necessary to release the locked funds. -
chainIdis the chain ID of the consumer chain to be removed. It must be the ID of an existing consumer chain of the executing provider chain. -
stopTimeis the time on the provider chain at which all validators are responsible to stop their consumer chain validator node.
GetDistributionAccountAddress() method. For an example, take a look at the auth module of Cosmos SDK.
CCV Packets
↑ Back to Outline The structure of the packets sent through the CCV channel is defined by thePacket interface in ICS 4.
The following packet data types are required by the CCV module:
-
VSCPacketDatacontains a list of validator updates, i.e., -
VSCMaturedPacketDatacontains the ID of the VSC that reached maturity, i.e., -
SlashPacketDatacontains a request to slash a validator, i.e.,
Note that for brevity we use e.g.,Packets are acknowledged by the remote side by sending back anVSCPacketto refer to a packet withVSCPacketDataas its data.
Acknowledgement that contains either a result (in case of success) or an error (as defined in ICS 4).
The following acknowledgement types are required by the CCV module:
CCV State
↑ Back to Outline This section describes the internal state of the CCV module. For simplicity, the state is described by a set of variables; for each variable, both the type and a brief description is provided. In practice, all the state (except for hardcoded constants, e.g.,ProviderPortId) is stored in a key/value store (KVS). The host state machine provides a KVS interface with three functions, i.e., get(), set(), and delete() (as defined in ICS 24).
ccvVersion = "ccv-1"is the CCV expected version. Both the provider and the consumer chains need to agree on this version.zeroTimeoutHeight = {0,0}is thetimeoutHeight(as defined in ICS 4) used by CCV for sending packets. Note that CCV usesccvTimeoutTimestampfor sending CCV packets andtransferTimeoutTimestampfor transferring tokens.ccvTimeoutTimestamp: uint64is thetimeoutTimestamp(as defined in ICS 4) for sending CCV packets. The CCV protocol is responsible of settingccvTimeoutTimestampsuch that the Correct Relayer assumption is feasible.transferTimeoutTimestamp: uint64is thetimeoutTimestamp(as defined in ICS 4) for transferring tokens.
State on Provider Chain
↑ Back to OutlineProviderPortId = "provider"is the port ID the provider CCV module is expected to bind to.initTimeout: uint64is the maximum time duration the Channel Initialization subprotocol may execute, i.e., for any consumer chain, if the CCV channel is not established withininitTimeoutsince the consumer chain was registered, then the consumer chain is removed.vscTimeout: uint64is the maximum time duration between sending anyVSCPacketto any consumer chain and receiving the correspondingVSCMaturedPacket, without timing out the consumer chain and consequently removing it.pendingConsumerAdditionProposals: [ConsumerAdditionProposal]is a list of pending governance proposals to add new consumer chains.pendingConsumerRemovalProposals: [ConsumerRemovalProposal]is a list of pending governance proposals to remove existing consumer chains. Both lists of pending governance proposals expose the following interface:
-
lockUnbondingOnTimeout: Map<string, Bool>is a mapping from consumer chain IDs to the boolean values indicating whether the funds corresponding to the in progress unbonding operations are to be released in case of a timeout. -
chainToClient: Map<string, Identifier>is a mapping from consumer chain IDs to the associated client IDs. -
chainToConnection: Map<string, Identifier>is a mapping from consumer chain IDs to the associated connection IDs. -
chainToChannel: Map<string, Identifier>is a mapping from consumer chain IDs to the CCV channel IDs. -
channelToChain: Map<Identifier, string>is a mapping from CCV channel IDs to consumer chain IDs. -
initTimeoutTimestamps: Map<string, uint64>is a mapping from consumer chain IDs to init timeout timestamps, seeinitTimeout. -
pendingVSCPackets: Map<string, [VSCPacketData]>is a mapping from consumer chain IDs to a list of pendingVSCPacketDatas that must be sent to the consumer chain once the CCV channel is established. The map exposes the following interface: -
vscId: uint64is a monotonic strictly increasing and positive ID that is used to uniquely identify the VSCs sent to the consumer chains. Note that0is used as a special ID for the mapping from consumer heights to provider heights. -
vscSendTimestamps: Map<(string, uint64), uint64>is a mapping from(chainId, vscId)tuples to the timestamps of sendingVSCPackets. -
initialHeights: Map<string, Height>is a mapping from consumer chain IDs to the heights on the provider chain. For every consumer chain, the mapping stores the height when the CCV channel to that consumer chain is established. Note that the provider validator set at this height matches the validator set at the height when the first VSC is provided to that consumer chain. It enables the mapping from consumer heights to provider heights. -
VSCtoH: Map<uint64, Height>is a mapping from VSC IDs to heights on the provider chain. It enables the mapping from consumer heights to provider heights, i.e., the voting power at heightVSCtoH[id]on the provider chain was last updated by the validator updates contained in the VSC with IDid. -
unbondingOps: Map<uint64, UnbondingOperation>is a mapping that enables accessing for every unbonding operation the list of consumer chains that are still unbonding. When unbonding operations are initiated, the Staking module calls theAfterUnbondingInitiated()hook); this leads to the creation of a newUnbondingOperation, which is defined as -
vscToUnbondingOps: Map<(string, uint64), [uint64]>is a mapping from(chainId, vscId)tuples to a list of unbonding operation IDs. It enables the provider CCV module to match aVSCMaturedPacket{vscId}, received from a consumer chain withchainId, with the corresponding unbonding operations. As a result,chainIdcan be removed from the list of consumer chains that are still unbonding these operations. For more details see how receivedVSCMaturedPackets are handled. -
maturedUnbondingOps: [uint64]is a list of IDs of matured unbonding operations (from the perspective of the consumer chains), for which notifications can be sent to the Staking module (seestakingKeeper.UnbondingCanComplete). Note thatmaturedUnbondingOpsis emptied at the end of each block. -
downtimeSlashRequests: Map<string, [string]>is a mapping fromchainIds to lists of validator addresses, i.e.,downtimeSlashRequests[chainId]contains all the validator addresses for which the provider chain received slash requests for downtime from the consumer chain withchainId.
State on Consumer Chain
↑ Back to Outline-
ConsumerPortId = "consumer"is the port ID the consumer CCV module is expected to bind to. -
ConsumerUnbondingPeriod: Durationis the unbonding period on the consumer chain. -
preCCV: Boolis a flag indicating whether the consumer CCV module starts in pre-CCV state. In pre-CCV state, the consumer CCV module MUST NOT pass validator updates to the underlying consensus engine. -
providerClientId: Identifieridentifies the client of the provider chain (on the consumer chain) that the CCV channel is build upon. -
providerChannel: Identifieridentifies the consumer’s channel end of the CCV channel. -
ccvValidatorSet: <string, ValidatorUpdate>is a mapping that stores the validators in the validator set of the consumer chain. -
receivedVSCs: [VSCPacketData]is a list of data items (i.e.,VSCPacketData) received inVSCPackets that are not yet applied. -
HtoVSC: Map<Height, uint64>is a mapping from consumer chain heights to VSC IDs. It enables the mapping from consumer heights to provider heights., i.e.,- if
HtoVSC[h] == 0, then the voting power on the consumer chain at heighthwas setup at genesis during Channel Initialization; - otherwise, the voting power on the consumer chain at height
hwas updated by the VSC with IDHtoVSC[h].
- if
-
maturingVSCs: [(uint64, uint64)]is a list of(id, ts)tuples, whereidis the ID of a VSC received via aVSCPacketandtsis the timestamp at which the VSC reaches maturity on the consumer chain. The list is used to keep track of when unbonding operations are matured on the consumer chain. It exposes the following interface: -
pendingSlashRequests: [SlashRequest]is a list of pendingSlashRequests that must be sent to the provider chain once the CCV channel is established. ASlashRequestconsist of aSlashPacketDataand a flag indicating whether the request is for downtime slashing. The list exposes the following interface: -
outstandingDowntime: <string, Bool>is a mapping from validator addresses to boolean values.outstandingDowntime[valAddr] == TRUEentails that the consumer chain sent a request to slash for downtime the validator with addressvalAddr.outstandingDowntime[valAddr]is set to false once the consumer chain receives a confirmation that the downtime slash request was received by the provider chain, i.e., aVSCPacketthat containsvalAddrindowntimeSlashAcks. The mapping enables the consumer CCV module to avoid sending to the provider chain multiple slashing requests for the same downtime infraction. -
providerDistributionAccount: stringis the address of the distribution module account on the provider chain. It enables the consumer chain to transfer rewards to the provider chain. -
distributionChannelId: Identifieris the ID of the distribution token transfer channel used for sending rewards to the provider chain. -
BlocksPerDistributionTransfer: int64is the interval (in number of blocks) between two distribution token transfers. -
lastDistributionTransferHeight: Heightis the block height of the last distribution token transfer. -
ccvAccount: stringis the address of the CCV module account where a fraction of the consumer chain rewards are collected before being transferred to the provider chain.