Documentation ¶
Overview ¶
Package common contains various helper functions.
Index ¶
- Constants
- Variables
- func Bytes2Hex(d []byte) string
- func CopyBytes(b []byte) (copiedBytes []byte)
- func FromHex(s string) []byte
- func Hex2Bytes(str string) []byte
- func Hex2BytesFixed(str string, flen int) []byte
- func IsCheckPointHeight(height uint64) bool
- func IsHexAddress(s string) bool
- func LeftPadBytes(slice []byte, l int) []byte
- func Parallel(tasks ...func())
- func RightPadBytes(slice []byte, l int) []byte
- func ToHex(b []byte) stringdeprecated
- func WriteFileAtomic(filePath string, newBytes []byte, mode os.FileMode) error
- func WriteInitialConfig(filePath string) error
- type Address
- func (a Address) Big() *big.Int
- func (a Address) Bytes() []byte
- func (a Address) Hash() Hash
- func (a Address) Hex() string
- func (a Address) IsEmpty() bool
- func (a Address) MarshalText() ([]byte, error)
- func (a *Address) Scan(src interface{}) error
- func (a *Address) SetBytes(b []byte)
- func (a Address) String() string
- func (a *Address) UnmarshalJSON(input []byte) error
- func (a *Address) UnmarshalText(input []byte) error
- func (a Address) Value() (driver.Value, error)
- type Bytes
- type ChannelIDEnum
- type Hash
- func (h Hash) Big() *big.Int
- func (h Hash) Bytes() []byte
- func (h Hash) Format(s fmt.State, c rune)
- func (h Hash) Generate(rand *rand.Rand, size int) reflect.Value
- func (h Hash) Hex() string
- func (h Hash) IsEmpty() bool
- func (h Hash) MarshalText() ([]byte, error)
- func (h *Hash) Scan(src interface{}) error
- func (h *Hash) SetBytes(b []byte)
- func (h Hash) String() string
- func (h Hash) TerminalString() string
- func (h *Hash) UnmarshalJSON(input []byte) error
- func (h *Hash) UnmarshalText(input []byte) error
- func (h Hash) Value() (driver.Value, error)
- type JSONBig
- type JSONUint64
- type MixedcaseAddress
- func (ma *MixedcaseAddress) Address() Address
- func (ma *MixedcaseAddress) MarshalJSON() ([]byte, error)
- func (ma *MixedcaseAddress) Original() string
- func (ma *MixedcaseAddress) String() string
- func (ma *MixedcaseAddress) UnmarshalJSON(input []byte) error
- func (ma *MixedcaseAddress) ValidChecksum() bool
- type UnprefixedAddress
- type UnprefixedHash
Constants ¶
const ( // CfgGenesisHash defines the hash of the genesis block CfgGenesisHash = "genesis.hash" // CfgGenesisChainID defines the chainID. CfgGenesisChainID = "genesis.chainID" // CfgConsensusMaxEpochLength defines the maxium length of an epoch. CfgConsensusMaxEpochLength = "consensus.maxEpochLength" // CfgConsensusMinProposalWait defines the minimal interval between proposals. CfgConsensusMinProposalWait = "consensus.minProposalWait" // CfgConsensusMessageQueueSize defines the capacity of consensus message queue. CfgConsensusMessageQueueSize = "consensus.messageQueueSize" // CfgStorageStatePruningEnabled indicates whether state pruning is enabled CfgStorageStatePruningEnabled = "storage.statePruningEnabled" // CfgStorageStatePruningInterval indicates the purning interval (in terms of blocks) CfgStorageStatePruningInterval = "storage.statePruningInterval" // CfgStorageStatePruningRetainedBlocks indicates the number of blocks prior to the latest finalized block to be retained CfgStorageStatePruningRetainedBlocks = "storage.statePruningRetainedBlocks" // CfgSyncMessageQueueSize defines the capacity of Sync Manager message queue. CfgSyncMessageQueueSize = "sync.messageQueueSize" // CfgSyncDownloadByHash indicates whether should download blocks using hash. CfgSyncDownloadByHash = "sync.downloadByHash" // CfgSyncDownloadByHeader indicates whether should download blocks using header. CfgSyncDownloadByHeader = "sync.downloadByHeader" // CfgP2PName sets the ID of local node in P2P network. CfgP2PName = "p2p.name" // CfgP2PPort sets the port used by P2P network. CfgP2PPort = "p2p.port" // CfgP2PSeeds sets the boostrap peers. CfgP2PSeeds = "p2p.seeds" // CfgP2PMessageQueueSize sets the message queue size for network interface. CfgP2PMessageQueueSize = "p2p.messageQueueSize" // CfgP2PSeedPeerOnlyOutbound decides whether only the seed peers can be outbound peers. CfgP2PSeedPeerOnlyOutbound = "p2p.seedPeerOnlyOutbound" // CfgP2PSeedPeerOnly decides whether the node will connect to peers other than the seeds. CfgP2PSeedPeerOnly = "p2p.seedPeerOnly" // CfgSyncInboundResponseWhitelist filters inbound messages based on peer ID. CfgSyncInboundResponseWhitelist = "sync.inboundResponseWhitelist" // CfgRPCEnabled sets whether to run RPC service. CfgRPCEnabled = "rpc.enabled" // CfgRPCAddress sets the binding address of RPC service. CfgRPCAddress = "rpc.address" // CfgRPCPort sets the port of RPC service. CfgRPCPort = "rpc.port" // CfgRPCMaxConnections limits concurrent connections accepted by RPC server. CfgRPCMaxConnections = "rpc.maxConnections" // CfgLogLevels sets the log level. CfgLogLevels = "log.levels" // CfgLogPrintSelfID determines whether to print node's ID in log (Useful in simulation when // there are more than one node running). CfgLogPrintSelfID = "log.printSelfID" )
const ( // HashLength is the expected length of the hash HashLength = 32 // AddressLength is the expected length of the adddress AddressLength = 20 )
Lengths of hashes and addresses in bytes.
const CheckpointInterval = int64(100)
CheckpointInterval defines the interval between checkpoints.
const HeightEnableValidatorReward uint64 = 4164982 // approximate time: 2pm January 14th, 2020
HeightEnableValidatorReward specifies the minimal block height to enable the validtor TFUEL reward
const InitialConfig = `# Theta configuration
p2p:
port: 5000
seeds: 127.0.0.1:6000,127.0.0.1:7000
`
InitialConfig is the default configuration produced by init command.
Variables ¶
var ( Big1 = big.NewInt(1) Big2 = big.NewInt(2) Big3 = big.NewInt(3) Big0 = big.NewInt(0) Big32 = big.NewInt(32) Big256 = big.NewInt(256) Big257 = big.NewInt(257) BigMaxUint16 = new(big.Int).SetUint64(1<<16 - 1) BigMaxUint32 = new(big.Int).SetUint64(1<<32 - 1) BigMaxUint64 = new(big.Int).SetUint64(1<<64 - 1) )
Common big integers often used
Functions ¶
func FromHex ¶
FromHex returns the bytes represented by the hexadecimal string s. s may be prefixed with "0x".
func Hex2BytesFixed ¶
Hex2BytesFixed returns bytes of a specified fixed length flen.
func IsCheckPointHeight ¶ added in v1.1.0
IsCheckPointHeight returns if a block height is a checkpoint.
func IsHexAddress ¶
IsHexAddress verifies whether a string can represent a valid hex-encoded Ethereum address or not.
func LeftPadBytes ¶
LeftPadBytes zero-pads slice to the left up to length l.
func RightPadBytes ¶
RightPadBytes zero-pads slice to the right up to length l.
func WriteFileAtomic ¶
WriteFileAtomic writes to newBytes to filePath. Guaranteed not to lose *both* oldBytes and newBytes, (assuming that the OS is perfect)
func WriteInitialConfig ¶
WriteInitialConfig writes initial config file to file system.
Types ¶
type Address ¶
type Address [AddressLength]byte
Address represents the 20 byte address of an Ethereum account.
func BigToAddress ¶
BigToAddress returns Address with byte values of b. If b is larger than len(h), b will be cropped from the left.
func BytesToAddress ¶
BytesToAddress returns Address with value b. If b is larger than len(h), b will be cropped from the left.
func HexToAddress ¶
HexToAddress returns Address with byte values of s. If s is larger than len(h), s will be cropped from the left.
func (Address) MarshalText ¶
MarshalText returns the hex representation of a.
func (*Address) SetBytes ¶
SetBytes sets the address to the value of b. If b is larger than len(a) it will panic.
func (*Address) UnmarshalJSON ¶
UnmarshalJSON parses a hash in hex syntax.
func (*Address) UnmarshalText ¶
UnmarshalText parses a hash in hex syntax.
type ChannelIDEnum ¶
type ChannelIDEnum byte
ChannelIDEnum defines the channelID for different type of data for synchronization among blockchain nodes
const ( // ChannelIDInvalid indicates an invalid channel ChannelIDInvalid ChannelIDEnum = iota // ChannelIDCheckpoint indicates the channel for Checkpoint ChannelIDCheckpoint // ChannelIDHeader indicates the channel for Header ChannelIDHeader // ChannelIDBlock indicates the channel for Block ChannelIDBlock // ChannelIDProposal indicates the channel for Proposal ChannelIDProposal // ChannelIDCC indicates the channel for Commit Certificate ChannelIDCC // ChannelIDVote indicates the channel for Vote ChannelIDVote // ChannelIDTransaction indicates the channel for Transaction ChannelIDTransaction // ChannelIDPeerDiscovery indicates the channel for Peer Discovery information exchange ChannelIDPeerDiscovery // ChannelIDPing indicates the channel for Ping/Pong messages between peers ChannelIDPing )
type Hash ¶
type Hash [HashLength]byte
Hash represents the 32 byte Keccak256 hash of arbitrary data.
func BigToHash ¶
BigToHash sets byte representation of b to hash. If b is larger than len(h), b will be cropped from the left.
func BytesToHash ¶
BytesToHash sets b to hash. If b is larger than len(h), b will be cropped from the left.
func HexToHash ¶
HexToHash sets byte representation of s to hash. If b is larger than len(h), b will be cropped from the left.
func (Hash) Format ¶
Format implements fmt.Formatter, forcing the byte slice to be formatted as is, without going through the stringer interface used for logging.
func (Hash) MarshalText ¶
MarshalText returns the hex representation of h.
func (*Hash) SetBytes ¶
SetBytes sets the hash to the value of b. If b is larger than len(h), b will be cropped from the left.
func (Hash) String ¶
String implements the stringer interface and is used also by the logger when doing full logging into a file.
func (Hash) TerminalString ¶
TerminalString implements log.TerminalStringer, formatting a string for console output during logging.
func (*Hash) UnmarshalJSON ¶
UnmarshalJSON parses a hash in hex syntax.
func (*Hash) UnmarshalText ¶
UnmarshalText parses a hash in hex syntax.
type JSONBig ¶
func (JSONBig) MarshalText ¶
MarshalText implements encoding.TextMarshaler
func (*JSONBig) UnmarshalJSON ¶
UnmarshalJSON implements json.Unmarshaler.
func (*JSONBig) UnmarshalText ¶
UnmarshalText implements encoding.TextUnmarshaler
type JSONUint64 ¶
type JSONUint64 uint64
func (JSONUint64) MarshalText ¶
func (b JSONUint64) MarshalText() ([]byte, error)
MarshalText implements encoding.TextMarshaler.
func (*JSONUint64) UnmarshalJSON ¶
func (b *JSONUint64) UnmarshalJSON(input []byte) error
UnmarshalJSON implements json.Unmarshaler.
func (*JSONUint64) UnmarshalText ¶
func (b *JSONUint64) UnmarshalText(raw []byte) error
UnmarshalText implements encoding.TextUnmarshaler
type MixedcaseAddress ¶
type MixedcaseAddress struct {
// contains filtered or unexported fields
}
MixedcaseAddress retains the original string, which may or may not be correctly checksummed
func NewMixedcaseAddress ¶
func NewMixedcaseAddress(addr Address) MixedcaseAddress
NewMixedcaseAddress constructor (mainly for testing)
func NewMixedcaseAddressFromString ¶
func NewMixedcaseAddressFromString(hexaddr string) (*MixedcaseAddress, error)
NewMixedcaseAddressFromString is mainly meant for unit-testing
func (*MixedcaseAddress) Address ¶
func (ma *MixedcaseAddress) Address() Address
Address returns the address
func (*MixedcaseAddress) MarshalJSON ¶
func (ma *MixedcaseAddress) MarshalJSON() ([]byte, error)
MarshalJSON marshals the original value
func (*MixedcaseAddress) Original ¶
func (ma *MixedcaseAddress) Original() string
Original returns the mixed-case input string
func (*MixedcaseAddress) String ¶
func (ma *MixedcaseAddress) String() string
String implements fmt.Stringer
func (*MixedcaseAddress) UnmarshalJSON ¶
func (ma *MixedcaseAddress) UnmarshalJSON(input []byte) error
UnmarshalJSON parses MixedcaseAddress
func (*MixedcaseAddress) ValidChecksum ¶
func (ma *MixedcaseAddress) ValidChecksum() bool
ValidChecksum returns true if the address has valid checksum
type UnprefixedAddress ¶
type UnprefixedAddress Address
UnprefixedAddress allows marshaling an Address without 0x prefix.
func (UnprefixedAddress) MarshalText ¶
func (a UnprefixedAddress) MarshalText() ([]byte, error)
MarshalText encodes the address as hex.
func (*UnprefixedAddress) UnmarshalText ¶
func (a *UnprefixedAddress) UnmarshalText(input []byte) error
UnmarshalText decodes the address from hex. The 0x prefix is optional.
type UnprefixedHash ¶
type UnprefixedHash Hash
UnprefixedHash allows marshaling a Hash without 0x prefix.
func (UnprefixedHash) MarshalText ¶
func (h UnprefixedHash) MarshalText() ([]byte, error)
MarshalText encodes the hash as hex.
func (*UnprefixedHash) UnmarshalText ¶
func (h *UnprefixedHash) UnmarshalText(input []byte) error
UnmarshalText decodes the hash from hex. The 0x prefix is optional.
Source Files ¶
Directories ¶
Path | Synopsis |
---|---|
Package hexutil implements hex encoding with 0x prefix.
|
Package hexutil implements hex encoding with 0x prefix. |
Package math provides integer math utilities.
|
Package math provides integer math utilities. |
Go port of Coda Hale's Metrics library <https://github.com/rcrowley/go-metrics> Coda Hale's original work: <https://github.com/codahale/metrics>
|
Go port of Coda Hale's Metrics library <https://github.com/rcrowley/go-metrics> Coda Hale's original work: <https://github.com/codahale/metrics> |
exp
Hook go-metrics into expvar on any /debug/metrics request, load all vars from the registry into expvar, and execute regular expvar handler
|
Hook go-metrics into expvar on any /debug/metrics request, load all vars from the registry into expvar, and execute regular expvar handler |