Documentation ¶
Index ¶
Constants ¶
View Source
const ( Addr_Length uint8 = 4 Data_Length uint8 = 4 Process_Length uint32 = 2000 )
Variables ¶
This section is empty.
Functions ¶
func Deserilization ¶
func Deserilization(tx TransactionType) (uint32, []byte)
Types ¶
type BlockchainState ¶
func NewBlockchainState ¶
func NewBlockchainState(name string, dir string) *BlockchainState
type ShardCrosslinkMsg ¶
type TransactionType ¶
type TransactionType struct { From_shard uint8 // the sender's shard To_shard uint8 // the receiver's shard Tx_type uint8 From []byte To []byte Value uint32 Data []byte Nonce uint32 // TODO: enable contineous tx requests by setting vary nonce TX_id uint32 }
func ResolveTx ¶
func ResolveTx(_tx []byte) (uint32, TransactionType)
func Serilization ¶
func Serilization(tx []byte) (uint32, TransactionType)
type ValidatorInterface ¶
type ValidatorInterface struct { BCState *BlockchainState Shard_id uint8 Leader bool Tx_set [Process_Length]uint8 Byzantine uint8 // 0: honest; 1: byzantine Attack_shard uint8 // the attacker's shard Node_id uint8 // used to construct different front-running tx // contains filtered or unexported fields }
func NewValidatorInterface ¶
func NewValidatorInterface(bcstate *BlockchainState, shard_num uint8, shard_id uint8, leader bool, in_addr hctypes.HaechiAddress, out_addrs []hctypes.HaechiAddress, attacks ...uint8) *ValidatorInterface
func (*ValidatorInterface) DeliverAttackTx ¶
func (nw *ValidatorInterface) DeliverAttackTx(tx []byte, shardid uint8)
func (*ValidatorInterface) DeliverCommitTx ¶
func (nw *ValidatorInterface) DeliverCommitTx(tx []byte)
func (*ValidatorInterface) DeliverExecutionTx ¶
func (nw *ValidatorInterface) DeliverExecutionTx(tx []byte, shardid uint8)
Click to show internal directories.
Click to hide internal directories.