blockchain_go/block.go

74 lines
1.5 KiB
Go
Raw Normal View History

package main
import (
"bytes"
"encoding/gob"
"log"
"time"
)
// Block represents a block in the blockchain
type Block struct {
Timestamp int64
Transactions []*Transaction
PrevBlockHash []byte
Hash []byte
2017-08-21 05:50:41 -05:00
Nonce int
2017-09-30 23:02:38 -05:00
Height int
}
// NewBlock creates and returns Block
2017-09-30 23:02:38 -05:00
func NewBlock(transactions []*Transaction, prevBlockHash []byte, height int) *Block {
block := &Block{time.Now().Unix(), transactions, prevBlockHash, []byte{}, 0, height}
2017-08-21 09:06:52 -05:00
pow := NewProofOfWork(block)
nonce, hash := pow.Run()
block.Hash = hash[:]
block.Nonce = nonce
return block
}
// NewGenesisBlock creates and returns genesis Block
func NewGenesisBlock(coinbase *Transaction) *Block {
2017-09-30 23:02:38 -05:00
return NewBlock([]*Transaction{coinbase}, []byte{}, 0)
}
// HashTransactions returns a hash of the transactions in the block
func (b *Block) HashTransactions() []byte {
2017-09-18 01:01:43 -05:00
var transactions [][]byte
for _, tx := range b.Transactions {
2017-09-18 01:01:43 -05:00
transactions = append(transactions, tx.Serialize())
}
2017-09-18 01:01:43 -05:00
mTree := NewMerkleTree(transactions)
2017-09-18 01:01:43 -05:00
return mTree.RootNode.Data
}
// Serialize serializes the block
func (b *Block) Serialize() []byte {
var result bytes.Buffer
encoder := gob.NewEncoder(&result)
err := encoder.Encode(b)
if err != nil {
log.Panic(err)
}
return result.Bytes()
}
// DeserializeBlock deserializes a block
func DeserializeBlock(d []byte) *Block {
var block Block
decoder := gob.NewDecoder(bytes.NewReader(d))
err := decoder.Decode(&block)
if err != nil {
log.Panic(err)
}
return &block
}