mirror of
https://gitlab.com/pulsechaincom/prysm-pulse.git
synced 2025-01-15 06:28:20 +00:00
5569a68452
* Value assigned to a variable is never read before being overwritten * The result of append is not used anywhere * Suspicious assignment of range-loop vars detected * Unused method receiver detected * Revert "Auxiliary commit to revert individual files from 54edcb445484a2e5d79612e19af8e949b8861253" This reverts commit bbd1e1beabf7b0c5cfc4f514dcc820062ad6c063. * Method modifies receiver * Fix test * Duplicate imports detected * Incorrectly formatted error string * Types of function parameters can be combined * One more "Unused method receiver detected" * Unused parameter detected in function
42 lines
1.3 KiB
Go
42 lines
1.3 KiB
Go
package kv
|
|
|
|
import (
|
|
"context"
|
|
"fmt"
|
|
|
|
"github.com/ethereum/go-ethereum/common"
|
|
bolt "go.etcd.io/bbolt"
|
|
"go.opencensus.io/trace"
|
|
)
|
|
|
|
// DepositContractAddress returns contract address is the address of
|
|
// the deposit contract on the proof of work chain.
|
|
func (s *Store) DepositContractAddress(ctx context.Context) ([]byte, error) {
|
|
_, span := trace.StartSpan(ctx, "BeaconDB.DepositContractAddress")
|
|
defer span.End()
|
|
var addr []byte
|
|
if err := s.db.View(func(tx *bolt.Tx) error {
|
|
chainInfo := tx.Bucket(chainMetadataBucket)
|
|
addr = chainInfo.Get(depositContractAddressKey)
|
|
return nil
|
|
}); err != nil { // This view never returns an error, but we'll handle anyway for sanity.
|
|
panic(err)
|
|
}
|
|
return addr, nil
|
|
}
|
|
|
|
// SaveDepositContractAddress to the db. It returns an error if an address has been previously saved.
|
|
func (s *Store) SaveDepositContractAddress(ctx context.Context, addr common.Address) error {
|
|
_, span := trace.StartSpan(ctx, "BeaconDB.VerifyContractAddress")
|
|
defer span.End()
|
|
|
|
return s.db.Update(func(tx *bolt.Tx) error {
|
|
chainInfo := tx.Bucket(chainMetadataBucket)
|
|
expectedAddress := chainInfo.Get(depositContractAddressKey)
|
|
if expectedAddress != nil {
|
|
return fmt.Errorf("cannot override deposit contract address: %v", expectedAddress)
|
|
}
|
|
return chainInfo.Put(depositContractAddressKey, addr.Bytes())
|
|
})
|
|
}
|