macaroons: convert to use new kvdb abstraction

This commit is contained in:
Olaoluwa Osuntokun 2020-01-09 18:45:26 -08:00
parent 557b930c5f
commit 852b2380a9
No known key found for this signature in database
GPG Key ID: BC13F65E2DC84465
4 changed files with 28 additions and 25 deletions

@ -7,7 +7,7 @@ import (
"os" "os"
"path" "path"
"github.com/coreos/bbolt" "github.com/lightningnetwork/lnd/channeldb/kvdb"
"google.golang.org/grpc" "google.golang.org/grpc"
"google.golang.org/grpc/metadata" "google.golang.org/grpc/metadata"
@ -48,8 +48,8 @@ func NewService(dir string, checks ...Checker) (*Service, error) {
// Open the database that we'll use to store the primary macaroon key, // Open the database that we'll use to store the primary macaroon key,
// and all generated macaroons+caveats. // and all generated macaroons+caveats.
macaroonDB, err := bbolt.Open( macaroonDB, err := kvdb.Create(
path.Join(dir, DBFilename), 0600, bbolt.DefaultOptions, kvdb.BoltBackendName, path.Join(dir, DBFilename), true,
) )
if err != nil { if err != nil {
return nil, err return nil, err

@ -8,7 +8,7 @@ import (
"path" "path"
"testing" "testing"
"github.com/coreos/bbolt" "github.com/lightningnetwork/lnd/channeldb/kvdb"
"github.com/lightningnetwork/lnd/macaroons" "github.com/lightningnetwork/lnd/macaroons"
"google.golang.org/grpc/metadata" "google.golang.org/grpc/metadata"
"gopkg.in/macaroon-bakery.v2/bakery" "gopkg.in/macaroon-bakery.v2/bakery"
@ -33,8 +33,9 @@ func setupTestRootKeyStorage(t *testing.T) string {
if err != nil { if err != nil {
t.Fatalf("Error creating temp dir: %v", err) t.Fatalf("Error creating temp dir: %v", err)
} }
db, err := bbolt.Open(path.Join(tempDir, "macaroons.db"), 0600, db, err := kvdb.Create(
bbolt.DefaultOptions) kvdb.BoltBackendName, path.Join(tempDir, "macaroons.db"), true,
)
if err != nil { if err != nil {
t.Fatalf("Error opening store DB: %v", err) t.Fatalf("Error opening store DB: %v", err)
} }

@ -7,7 +7,7 @@ import (
"io" "io"
"sync" "sync"
"github.com/coreos/bbolt" "github.com/lightningnetwork/lnd/channeldb/kvdb"
"github.com/btcsuite/btcwallet/snacl" "github.com/btcsuite/btcwallet/snacl"
) )
@ -46,7 +46,7 @@ var (
// RootKeyStorage implements the bakery.RootKeyStorage interface. // RootKeyStorage implements the bakery.RootKeyStorage interface.
type RootKeyStorage struct { type RootKeyStorage struct {
*bbolt.DB kvdb.Backend
encKeyMtx sync.RWMutex encKeyMtx sync.RWMutex
encKey *snacl.SecretKey encKey *snacl.SecretKey
@ -54,10 +54,10 @@ type RootKeyStorage struct {
// NewRootKeyStorage creates a RootKeyStorage instance. // NewRootKeyStorage creates a RootKeyStorage instance.
// TODO(aakselrod): Add support for encryption of data with passphrase. // TODO(aakselrod): Add support for encryption of data with passphrase.
func NewRootKeyStorage(db *bbolt.DB) (*RootKeyStorage, error) { func NewRootKeyStorage(db kvdb.Backend) (*RootKeyStorage, error) {
// If the store's bucket doesn't exist, create it. // If the store's bucket doesn't exist, create it.
err := db.Update(func(tx *bbolt.Tx) error { err := kvdb.Update(db, func(tx kvdb.RwTx) error {
_, err := tx.CreateBucketIfNotExists(rootKeyBucketName) _, err := tx.CreateTopLevelBucket(rootKeyBucketName)
return err return err
}) })
if err != nil { if err != nil {
@ -65,7 +65,7 @@ func NewRootKeyStorage(db *bbolt.DB) (*RootKeyStorage, error) {
} }
// Return the DB wrapped in a RootKeyStorage object. // Return the DB wrapped in a RootKeyStorage object.
return &RootKeyStorage{DB: db, encKey: nil}, nil return &RootKeyStorage{Backend: db, encKey: nil}, nil
} }
// CreateUnlock sets an encryption key if one is not already set, otherwise it // CreateUnlock sets an encryption key if one is not already set, otherwise it
@ -84,8 +84,8 @@ func (r *RootKeyStorage) CreateUnlock(password *[]byte) error {
return ErrPasswordRequired return ErrPasswordRequired
} }
return r.Update(func(tx *bbolt.Tx) error { return kvdb.Update(r, func(tx kvdb.RwTx) error {
bucket := tx.Bucket(rootKeyBucketName) bucket := tx.ReadWriteBucket(rootKeyBucketName)
dbKey := bucket.Get(encryptedKeyID) dbKey := bucket.Get(encryptedKeyID)
if len(dbKey) > 0 { if len(dbKey) > 0 {
// We've already stored a key, so try to unlock with // We've already stored a key, so try to unlock with
@ -131,8 +131,8 @@ func (r *RootKeyStorage) Get(_ context.Context, id []byte) ([]byte, error) {
return nil, ErrStoreLocked return nil, ErrStoreLocked
} }
var rootKey []byte var rootKey []byte
err := r.View(func(tx *bbolt.Tx) error { err := kvdb.View(r, func(tx kvdb.ReadTx) error {
dbKey := tx.Bucket(rootKeyBucketName).Get(id) dbKey := tx.ReadBucket(rootKeyBucketName).Get(id)
if len(dbKey) == 0 { if len(dbKey) == 0 {
return fmt.Errorf("root key with id %s doesn't exist", return fmt.Errorf("root key with id %s doesn't exist",
string(id)) string(id))
@ -166,8 +166,8 @@ func (r *RootKeyStorage) RootKey(_ context.Context) ([]byte, []byte, error) {
} }
var rootKey []byte var rootKey []byte
id := defaultRootKeyID id := defaultRootKeyID
err := r.Update(func(tx *bbolt.Tx) error { err := kvdb.Update(r, func(tx kvdb.RwTx) error {
ns := tx.Bucket(rootKeyBucketName) ns := tx.ReadWriteBucket(rootKeyBucketName)
dbKey := ns.Get(id) dbKey := ns.Get(id)
// If there's a root key stored in the bucket, decrypt it and // If there's a root key stored in the bucket, decrypt it and
@ -212,5 +212,5 @@ func (r *RootKeyStorage) Close() error {
if r.encKey != nil { if r.encKey != nil {
r.encKey.Zero() r.encKey.Zero()
} }
return r.DB.Close() return r.Backend.Close()
} }

@ -8,8 +8,7 @@ import (
"path" "path"
"testing" "testing"
"github.com/coreos/bbolt" "github.com/lightningnetwork/lnd/channeldb/kvdb"
"github.com/lightningnetwork/lnd/macaroons" "github.com/lightningnetwork/lnd/macaroons"
"github.com/btcsuite/btcwallet/snacl" "github.com/btcsuite/btcwallet/snacl"
@ -22,8 +21,9 @@ func TestStore(t *testing.T) {
} }
defer os.RemoveAll(tempDir) defer os.RemoveAll(tempDir)
db, err := bbolt.Open(path.Join(tempDir, "weks.db"), 0600, db, err := kvdb.Create(
bbolt.DefaultOptions) kvdb.BoltBackendName, path.Join(tempDir, "weks.db"), true,
)
if err != nil { if err != nil {
t.Fatalf("Error opening store DB: %v", err) t.Fatalf("Error opening store DB: %v", err)
} }
@ -73,11 +73,13 @@ func TestStore(t *testing.T) {
} }
store.Close() store.Close()
// Between here and the re-opening of the store, it's possible to get // Between here and the re-opening of the store, it's possible to get
// a double-close, but that's not such a big deal since the tests will // a double-close, but that's not such a big deal since the tests will
// fail anyway in that case. // fail anyway in that case.
db, err = bbolt.Open(path.Join(tempDir, "weks.db"), 0600, db, err = kvdb.Create(
bbolt.DefaultOptions) kvdb.BoltBackendName, path.Join(tempDir, "weks.db"), true,
)
if err != nil { if err != nil {
t.Fatalf("Error opening store DB: %v", err) t.Fatalf("Error opening store DB: %v", err)
} }