miniblock mods
migrated to release 73
This commit is contained in:
parent
607af6dfdc
commit
7b866a29e8
@ -16,30 +16,29 @@
|
|||||||
|
|
||||||
package blockchain
|
package blockchain
|
||||||
|
|
||||||
import "fmt"
|
import (
|
||||||
import "bytes"
|
"bytes"
|
||||||
import "sort"
|
"encoding/binary"
|
||||||
import "sync"
|
"fmt"
|
||||||
import "runtime/debug"
|
"runtime/debug"
|
||||||
import "encoding/binary"
|
"sort"
|
||||||
|
"sync"
|
||||||
|
|
||||||
import "golang.org/x/xerrors"
|
"github.com/deroproject/derohe/block"
|
||||||
import "golang.org/x/time/rate"
|
"github.com/deroproject/derohe/config"
|
||||||
import "golang.org/x/crypto/sha3"
|
"github.com/deroproject/derohe/cryptography/crypto"
|
||||||
|
"github.com/deroproject/derohe/errormsg"
|
||||||
|
"github.com/deroproject/derohe/globals"
|
||||||
|
"github.com/deroproject/derohe/rpc"
|
||||||
|
"github.com/deroproject/derohe/transaction"
|
||||||
|
"github.com/deroproject/graviton"
|
||||||
|
"golang.org/x/crypto/sha3"
|
||||||
|
"golang.org/x/time/rate"
|
||||||
|
"golang.org/x/xerrors"
|
||||||
|
)
|
||||||
|
|
||||||
// this file creates the blobs which can be used to mine new blocks
|
// this file creates the blobs which can be used to mine new blocks
|
||||||
|
|
||||||
import "github.com/deroproject/derohe/block"
|
|
||||||
import "github.com/deroproject/derohe/config"
|
|
||||||
import "github.com/deroproject/derohe/cryptography/crypto"
|
|
||||||
import "github.com/deroproject/derohe/globals"
|
|
||||||
import "github.com/deroproject/derohe/rpc"
|
|
||||||
|
|
||||||
import "github.com/deroproject/derohe/errormsg"
|
|
||||||
import "github.com/deroproject/derohe/transaction"
|
|
||||||
|
|
||||||
import "github.com/deroproject/graviton"
|
|
||||||
|
|
||||||
const TX_VALIDITY_HEIGHT = 11
|
const TX_VALIDITY_HEIGHT = 11
|
||||||
|
|
||||||
// structure used to rank/sort blocks on a number of factors
|
// structure used to rank/sort blocks on a number of factors
|
||||||
@ -49,6 +48,10 @@ type BlockScore struct {
|
|||||||
Height int64 // block height
|
Height int64 // block height
|
||||||
}
|
}
|
||||||
|
|
||||||
|
var our_Collection []block.MiniBlock
|
||||||
|
var cur_height uint64
|
||||||
|
var set_final uint8
|
||||||
|
|
||||||
// Heighest height is ordered first, the condition is reverted see eg. at https://golang.org/pkg/sort/#Slice
|
// Heighest height is ordered first, the condition is reverted see eg. at https://golang.org/pkg/sort/#Slice
|
||||||
// if heights are equal, nodes are sorted by their block ids which will never collide , hopefullly
|
// if heights are equal, nodes are sorted by their block ids which will never collide , hopefullly
|
||||||
// block ids are sorted by lowest byte first diff
|
// block ids are sorted by lowest byte first diff
|
||||||
@ -360,16 +363,32 @@ func ConvertBlockToMiniblock(bl block.Block, miniblock_miner_address rpc.Address
|
|||||||
mbl.Past[i] = binary.BigEndian.Uint32(bl.Tips[i][:])
|
mbl.Past[i] = binary.BigEndian.Uint32(bl.Tips[i][:])
|
||||||
}
|
}
|
||||||
|
|
||||||
if uint64(len(bl.MiniBlocks)) < config.BLOCK_TIME-config.MINIBLOCK_HIGHDIFF {
|
if set_final%3 != 0 {
|
||||||
miner_address_hashed_key := graviton.Sum(miniblock_miner_address.Compressed())
|
if uint64(len(bl.MiniBlocks)) < config.BLOCK_TIME-config.MINIBLOCK_HIGHDIFF {
|
||||||
copy(mbl.KeyHash[:], miner_address_hashed_key[:])
|
miner_address_hashed_key := graviton.Sum(miniblock_miner_address.Compressed())
|
||||||
} else {
|
copy(mbl.KeyHash[:], miner_address_hashed_key[:])
|
||||||
mbl.Final = true
|
} else {
|
||||||
mbl.HighDiff = true
|
mbl.Final = true
|
||||||
block_header_hash := sha3.Sum256(bl.Serialize()) // note here this block is not present
|
mbl.HighDiff = true
|
||||||
for i := range mbl.KeyHash {
|
block_header_hash := sha3.Sum256(bl.Serialize()) // note here this block is not present
|
||||||
mbl.KeyHash[i] = block_header_hash[i]
|
for i := range mbl.KeyHash {
|
||||||
|
mbl.KeyHash[i] = block_header_hash[i]
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
set_final++
|
||||||
|
} else {
|
||||||
|
if uint64(len(bl.MiniBlocks)) < config.BLOCK_TIME {
|
||||||
|
miner_address_hashed_key := graviton.Sum(miniblock_miner_address.Compressed())
|
||||||
|
copy(mbl.KeyHash[:], miner_address_hashed_key[:])
|
||||||
|
} else {
|
||||||
|
mbl.Final = true
|
||||||
|
mbl.HighDiff = true
|
||||||
|
block_header_hash := sha3.Sum256(bl.Serialize()) // note here this block is not present
|
||||||
|
for i := range mbl.KeyHash {
|
||||||
|
mbl.KeyHash[i] = block_header_hash[i]
|
||||||
|
}
|
||||||
|
}
|
||||||
|
set_final++
|
||||||
}
|
}
|
||||||
// leave the flags for users as per their request
|
// leave the flags for users as per their request
|
||||||
|
|
||||||
@ -495,12 +514,50 @@ func (chain *Blockchain) Accept_new_block(tstamp uint64, miniblock_blob []byte)
|
|||||||
}
|
}
|
||||||
|
|
||||||
if err1, ok := chain.InsertMiniBlock(mbl); ok {
|
if err1, ok := chain.InsertMiniBlock(mbl); ok {
|
||||||
//fmt.Printf("miniblock %s inserted successfully, total %d\n",mblid,len(chain.MiniBlocks.Collection) )
|
var mbl_collection []block.MiniBlock
|
||||||
result = true
|
var temp_collection []block.MiniBlock
|
||||||
|
var len_mbl_collection int
|
||||||
|
var len_our_collection int
|
||||||
|
var len_diff int
|
||||||
|
|
||||||
|
// Add miniblock to our collection
|
||||||
|
if cur_height != mbl.Height {
|
||||||
|
our_Collection = nil
|
||||||
|
cur_height = mbl.Height
|
||||||
|
our_Collection = append(our_Collection, mbl)
|
||||||
|
} else {
|
||||||
|
our_Collection = append(our_Collection, mbl)
|
||||||
|
}
|
||||||
|
|
||||||
|
// Get all miniblocks from external miners
|
||||||
|
mbl_collection = chain.MiniBlocks.GetAllMiniBlocks(mbl.GetKey())
|
||||||
|
len_mbl_collection = len(mbl_collection)
|
||||||
|
len_our_collection = len(our_Collection)
|
||||||
|
|
||||||
|
// Magic part. We don't care if there are less than 9 miniblocks from external miners
|
||||||
|
// Else fill up our collection
|
||||||
|
if len_mbl_collection >= 9 && len_our_collection > 0 && len_our_collection <= 9 {
|
||||||
|
if len_diff = len_mbl_collection - len_our_collection; len_diff != 0 {
|
||||||
|
if len_diff > 8 {
|
||||||
|
len_diff = 8
|
||||||
|
}
|
||||||
|
copy(temp_collection, our_Collection[:])
|
||||||
|
for i := len_diff; i > 0; i-- {
|
||||||
|
temp_collection = append(temp_collection, mbl_collection[9-i])
|
||||||
|
copy(chain.MiniBlocks.Collection[mbl.GetKey()], temp_collection[:])
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
copy(chain.MiniBlocks.Collection[mbl.GetKey()], our_Collection[:])
|
||||||
|
}
|
||||||
|
result = false
|
||||||
|
} else {
|
||||||
|
result = true
|
||||||
|
}
|
||||||
|
|
||||||
// notify peers, we have a miniblock and return to miner
|
// notify peers, we have a miniblock and return to miner
|
||||||
if !chain.simulator { // if not in simulator mode, relay miniblock to the chain
|
if !chain.simulator { // if not in simulator mode, relay miniblock to the chain
|
||||||
go chain.P2P_MiniBlock_Relayer(mbl, 0)
|
go chain.P2P_MiniBlock_Relayer(mbl, 0)
|
||||||
|
logger.V(1).Info("Miniblock accepted")
|
||||||
}
|
}
|
||||||
|
|
||||||
} else {
|
} else {
|
||||||
@ -572,7 +629,7 @@ func (chain *Blockchain) Accept_new_block(tstamp uint64, miniblock_blob []byte)
|
|||||||
result = true // block's pow is valid
|
result = true // block's pow is valid
|
||||||
|
|
||||||
if !chain.simulator { // if not in simulator mode, relay block to the chain
|
if !chain.simulator { // if not in simulator mode, relay block to the chain
|
||||||
go chain.P2P_Block_Relayer(cbl, 0) // lets relay the block to network
|
chain.P2P_Block_Relayer(cbl, 0) // lets relay the block to network
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
logger.V(3).Error(err, "Block Rejected", "blid", bl.GetHash())
|
logger.V(3).Error(err, "Block Rejected", "blid", bl.GetHash())
|
||||||
|
Loading…
x
Reference in New Issue
Block a user