mirror of
https://gitlab.com/pulsechaincom/prysm-pulse.git
synced 2025-01-14 22:18:20 +00:00
b06876d698
* add node server * stub implementations * node server impl * gaz * only missing genesis info now * fmt imports * all tests pass * fmt * revert change * punctuation * use internal err code * view permission * using real reflection * spacing * lint
56 lines
1.6 KiB
Go
56 lines
1.6 KiB
Go
package db
|
|
|
|
import (
|
|
"bytes"
|
|
"context"
|
|
"fmt"
|
|
|
|
"github.com/boltdb/bolt"
|
|
"github.com/ethereum/go-ethereum/common"
|
|
"go.opencensus.io/trace"
|
|
)
|
|
|
|
var depositContractAddressKey = []byte("deposit-contract")
|
|
|
|
// DepositContractAddress returns contract address is the address of
|
|
// the deposit contract on the proof of work chain.
|
|
func (db *BeaconDB) DepositContractAddress(ctx context.Context) ([]byte, error) {
|
|
ctx, span := trace.StartSpan(ctx, "BeaconDB.DepositContractAddress")
|
|
defer span.End()
|
|
|
|
var addr []byte
|
|
err := db.view(func(tx *bolt.Tx) error {
|
|
chainInfo := tx.Bucket(chainInfoBucket)
|
|
addr = chainInfo.Get(depositContractAddressKey)
|
|
return nil
|
|
})
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
return addr, nil
|
|
}
|
|
|
|
// VerifyContractAddress that represents the data in this database. The
|
|
// contract address is the address of the deposit contract on the proof of work
|
|
// Ethereum chain. This value will never change or all of the data in the
|
|
// database would be made invalid.
|
|
func (db *BeaconDB) VerifyContractAddress(ctx context.Context, addr common.Address) error {
|
|
ctx, span := trace.StartSpan(ctx, "BeaconDB.VerifyContractAddress")
|
|
defer span.End()
|
|
|
|
return db.update(func(tx *bolt.Tx) error {
|
|
chainInfo := tx.Bucket(chainInfoBucket)
|
|
|
|
expectedAddress := chainInfo.Get(depositContractAddressKey)
|
|
if expectedAddress == nil {
|
|
return chainInfo.Put(depositContractAddressKey, addr.Bytes())
|
|
}
|
|
|
|
if !bytes.Equal(expectedAddress, addr.Bytes()) {
|
|
return fmt.Errorf("invalid deposit contract address, expected %#x - try running with --clear-db", expectedAddress)
|
|
}
|
|
|
|
return nil
|
|
})
|
|
}
|