macaroons: convert to use new kvdb abstraction
This commit is contained in:
parent
557b930c5f
commit
852b2380a9
@ -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)
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user