Documentation ¶
Index ¶
- Variables
- func BadTxForBan(keyID int64)
- func BannedTill(keyID int64) string
- func GetBlockDataFromBlockChain(blockID int64) (*utils.BlockData, error)
- func GetDataFromFirstBlock() (data *consts.FirstBlock, ok bool)
- func GetRollbacksHash(transaction *model.DbTransaction, blockID int64) ([]byte, error)
- func InsertBlockWOForks(data []byte, genBlock, firstBlock bool) error
- func InsertIntoBlockchain(transaction *model.DbTransaction, block *Block) error
- func IsKeyBanned(keyID int64) bool
- func MarshallBlock(header *utils.BlockData, trData [][]byte, prev *utils.BlockData, key string) ([]byte, error)
- func UpdBlockInfo(dbTransaction *model.DbTransaction, block *Block) error
- type Block
- type Limiter
- type Limits
Constants ¶
This section is empty.
Variables ¶
View Source
var ( ErrIncorrectRollbackHash = errors.New("Rollback hash doesn't match") ErrEmptyBlock = errors.New("Block doesn't contain transactions") )
View Source
var ( ErrMaxBlockSize = utils.WithBan(errors.New("Block size exceeds maximum limit")) ErrZeroBlockSize = utils.WithBan(errors.New("Block size is zero")) ErrUnmarshallBlock = utils.WithBan(errors.New("Unmarshall block")) )
View Source
var ( // ErrLimitSkip returns when tx should be skipped during generating block ErrLimitSkip = errors.New(`skip tx`) // ErrLimitStop returns when the generation of the block should be stopped ErrLimitStop = errors.New(`stop generating block`) // ErrLimitTime returns when the time limit exceeded ErrLimitTime = errors.New(`Time limit exceeded`) )
View Source
var (
ErrIcorrectBlockTime = utils.WithBan(errors.New("Incorrect block time"))
)
Functions ¶
func BannedTill ¶
BannedTill returns the time that the user has been banned till
func GetBlockDataFromBlockChain ¶
GetBlockDataFromBlockChain is retrieving block data from blockchain
func GetDataFromFirstBlock ¶
func GetDataFromFirstBlock() (data *consts.FirstBlock, ok bool)
GetDataFromFirstBlock returns data of first block
func GetRollbacksHash ¶
func GetRollbacksHash(transaction *model.DbTransaction, blockID int64) ([]byte, error)
func InsertBlockWOForks ¶
InsertBlockWOForks is inserting blocks
func InsertIntoBlockchain ¶
func InsertIntoBlockchain(transaction *model.DbTransaction, block *Block) error
InsertIntoBlockchain inserts a block into the blockchain
func IsKeyBanned ¶
IsBanned returns true if the key has been banned
func MarshallBlock ¶
func MarshallBlock(header *utils.BlockData, trData [][]byte, prev *utils.BlockData, key string) ([]byte, error)
MarshallBlock is marshalling block
func UpdBlockInfo ¶
func UpdBlockInfo(dbTransaction *model.DbTransaction, block *Block) error
UpdBlockInfo updates info_block table
Types ¶
type Block ¶
type Block struct { Header utils.BlockData PrevHeader *utils.BlockData PrevRollbacksHash []byte MrklRoot []byte BinData []byte Transactions []*transaction.Transaction SysUpdate bool GenBlock bool // it equals true when we are generating a new block Notifications []types.Notifications }
Block is storing block data
func ProcessBlockWherePrevFromBlockchainTable ¶
ProcessBlockWherePrevFromBlockchainTable is processing block with in table previous block
func UnmarshallBlock ¶
type Limiter ¶
type Limiter interface {
// contains filtered or unexported methods
}
Limiter describes interface functions for limits
type Limits ¶
type Limits struct { Mode int Block *Block // it equals nil if checking before generatin block Limiters []Limiter // the list of limiters }
Limits is used for saving current limit information
func (*Limits) CheckLimit ¶
func (limits *Limits) CheckLimit(t *transaction.Transaction) error
CheckLimit calls each limiter
Click to show internal directories.
Click to hide internal directories.