chain

package
v1.21.0 Latest Latest
Warning

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

Go to latest
Published: Feb 1, 2024 License: MIT Imports: 5 Imported by: 7

Documentation

Index

Constants

View Source
const MaxOperatorID = math.MaxUint32

MaxOperatorID is the maximum allowed value for OperatorID supported by Sortition Pool contract.

Variables

This section is empty.

Functions

This section is empty.

Types

type Address added in v1.21.0

type Address string

Address is a chain-agnostic representation of a chain address.

func (Address) String added in v1.21.0

func (a Address) String() string

type Addresses added in v1.21.0

type Addresses []Address

Addresses is a list of Address.

func (Addresses) Set added in v1.21.0

func (a Addresses) Set() map[Address]bool

Set transform Addresses into a set of unique items.

func (Addresses) String added in v1.21.0

func (a Addresses) String() string

String converts Addresses into a string with elements indexed from 1. This allows to print the list of addresses as a group members with member indexes starting from 1.

type BlockCounter

type BlockCounter interface {
	// WaitForBlockHeight blocks at the caller until the given block height is
	// reached. If the number of blocks is zero or negative or if the given
	// block height has been already reached, it returns immediately.
	WaitForBlockHeight(blockNumber uint64) error

	// BlockHeightWaiter returns a channel that will emit the block number after
	// the given block height is reached and then immediately close.
	// Reading from the returned channel immediately will effectively behave the
	// same way as calling WaitForBlockHeight.
	BlockHeightWaiter(blockNumber uint64) (<-chan uint64, error)

	// CurrentBlock returns the current block height.
	CurrentBlock() (uint64, error)

	// WatchBlocks returns a channel that will emit new block numbers as they
	// are mined. When the context provided as the parameter ends, new blocks
	// are no longer pushed to the channel and the channel is closed. If there
	// is no reader for the channel or reader is too slow, block updates can be
	// dropped.
	WatchBlocks(ctx context.Context) <-chan uint64
}

BlockCounter is an interface that provides the ability to wait for a certain number of abstract blocks or watch as they are mined. Block height is expected to increase monotonically, though the time between blocks depends on the underlying implementation.

type OperatorID added in v1.21.0

type OperatorID = uint32

OperatorID is a unique identifier of an operator assigned by the Sortition Pool when the operator enters the pool for the first time. ID is never changing for the given operator address.

type OperatorIDs added in v1.21.0

type OperatorIDs []OperatorID

OperatorIDs is a list of OperatorID values.

type Signing

type Signing interface {
	// Address returns operator's address.
	Address() Address

	// PublicKey returns operator's public key in a serialized format.
	// The returned public key is used to Sign messages and can be later used
	// for verification.
	PublicKey() []byte

	// Sign the provided message with operator's private key. Returns the
	// signature or error in case signing failed.
	Sign(message []byte) ([]byte, error)

	// Verify the provided message against the signature using operator's
	// public key. Returns true if signature is valid and false otherwise.
	// If signature verification failed for some reason, an error is returned.
	Verify(message []byte, signature []byte) (bool, error)

	// VerifyWithPublicKey verifies the provided message against the signature
	// using the provided operator's public key. Returns true if signature is
	// valid and false otherwise. If signature verification failed for some
	// reason, an error is returned.
	VerifyWithPublicKey(
		message []byte,
		signature []byte,
		publicKey []byte,
	) (bool, error)

	// PublicKeyToAddress converts operator's public key to an address
	// associated with the chain.
	PublicKeyToAddress(publicKey *operator.PublicKey) (Address, error)

	// PublicKeyBytesToAddress converts operator's public key bytes to an address
	// associated with the chain.
	PublicKeyBytesToAddress(publicKey []byte) Address
}

Signing is an interface that provides ability to sign and verify signatures using operator's key associated with the chain.

Jump to

Keyboard shortcuts

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