You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

56 lines
1.6 KiB

package blockchain
// thhis file implements code which controls output indexes
// rewrites them during chain reorganisation
import "fmt"
import "encoding/binary"
import "github.com/deroproject/derosuite/crypto"
//import "github.com/deroproject/derosuite/crypto/ringct"
type Output_index struct {
Key crypto.Hash // stealth address key
Commitment crypto.Hash // commitment public key
Height uint64 // height to which this belongs
}
func (o *Output_index) Serialize() (result []byte) {
result = append(o.Key[:], o.Commitment[:]...)
result = append(result, itob(o.Height)...)
return
}
func (o *Output_index) Deserialize(buf []byte) (err error) {
if len(buf) != ( 32 + 32 + 8){
return fmt.Errorf("Output index needs to be 72 bytes in size but found to be %d bytes", len(buf))
}
copy(o.Key[:],buf[:32])
copy(o.Commitment[:],buf[32:64])
o.Height = binary.BigEndian.Uint64(buf[64:])
return
}
// this function writes or overwrites the data related to outputs
// the following data is collected from each output
// the secret key,
// the commitment ( for miner tx the commitment is created from scratch
// 8 bytes blockheight to which this output belongs
// this function should always succeed or panic showing something is not correct
// NOTE: this function should only be called after all the tx and the block has been stored to DB
func (chain *Blockchain)write_output_index(block_id crypto.Hash){
// load the block
bl, err := chain.Load_BL_FROM_ID(block_id)
if err != nil {
panic(fmt.Sprintf("No such block %x\n", block_id))
}
_ = bl
}