|
|
package common
import ( "encoding/binary" "fmt" "math/big"
ethCommon "github.com/ethereum/go-ethereum/common" )
// Batch is a struct that represents Hermez network batch
type Batch struct { BatchNum BatchNum SlotNum SlotNum // Slot in which the batch is forged
EthTxHash ethCommon.Hash EthBlockNum uint64 // Ethereum block in which the batch is forged
ExitRoot Hash OldStateRoot Hash NewStateRoot Hash OldNumAccounts int NewNumAccounts int ToForgeL1TxsNum uint32 // optional, Only when the batch forges L1 txs. Identifier that corresponds to the group of L1 txs forged in the current batch.
ToForgeL1TxsHash ethCommon.Hash // optional, Only when the batch forges L1 txs. Frozen from pendingL1TxsHash (which are the group of L1UserTxs), to be forged in ToForgeL1TxsNum + 1.
ForgedL1TxsHash ethCommon.Hash // optional, Only when the batch forges L1 txs. This will be the Hash of the group of L1 txs (L1UserTxs + L1CoordinatorTx) forged in the current batch.
CollectedFees map[TokenID]*big.Int ForgerAddr ethCommon.Address // TODO: Should this be retrieved via slot reference?
}
// BatchNum identifies a batch
type BatchNum uint32
// Bytes returns a byte array of length 4 representing the BatchNum
func (bn BatchNum) Bytes() []byte { var batchNumBytes [4]byte binary.LittleEndian.PutUint32(batchNumBytes[:], uint32(bn)) return batchNumBytes[:] }
// BatchNumFromBytes returns BatchNum from a []byte
func BatchNumFromBytes(b []byte) (BatchNum, error) { if len(b) != 4 { return 0, fmt.Errorf("can not parse BatchNumFromBytes, bytes len %d, expected 4", len(b)) } batchNum := binary.LittleEndian.Uint32(b[:4]) return BatchNum(batchNum), nil }
|