notes to self
* CAS vs locks * Daemon storage redundancy+error-detection * Proper bucket indexing
This commit is contained in:
parent
41065a4538
commit
6bb5febe9e
@ -212,10 +212,13 @@ func NewLightningWallet(privWalletPass, pubWalletPass, hdSeed []byte, dataDir st
|
|||||||
// TODO(roasbeef): logging
|
// TODO(roasbeef): logging
|
||||||
|
|
||||||
return &LightningWallet{
|
return &LightningWallet{
|
||||||
db: db,
|
db: db,
|
||||||
wallet: wallet,
|
wallet: wallet,
|
||||||
lnNamespace: lnNamespace,
|
lnNamespace: lnNamespace,
|
||||||
msgChan: make(chan interface{}, msgBufferSize),
|
msgChan: make(chan interface{}, msgBufferSize),
|
||||||
|
// TODO(roasbeef): make this atomic.Uint32 instead? Which is
|
||||||
|
// faster, locks or CAS? I'm guessing CAS because assembly:
|
||||||
|
// * https://golang.org/src/sync/atomic/asm_amd64.s
|
||||||
nextFundingID: 0,
|
nextFundingID: 0,
|
||||||
fundingLimbo: make(map[uint64]*ChannelReservation),
|
fundingLimbo: make(map[uint64]*ChannelReservation),
|
||||||
quit: make(chan struct{}),
|
quit: make(chan struct{}),
|
||||||
@ -632,6 +635,7 @@ func (l *LightningWallet) handleFundingCounterPartySigs(msg *addCounterPartySigs
|
|||||||
writeErr := l.lnNamespace.Update(func(tx walletdb.Tx) error {
|
writeErr := l.lnNamespace.Update(func(tx walletdb.Tx) error {
|
||||||
// Get the bucket dedicated to storing the meta-data for open
|
// Get the bucket dedicated to storing the meta-data for open
|
||||||
// channels.
|
// channels.
|
||||||
|
// TODO(roasbeef): CHECKSUMS, REDUNDANCY, etc etc.
|
||||||
rootBucket := tx.RootBucket()
|
rootBucket := tx.RootBucket()
|
||||||
openChanBucket, err := rootBucket.CreateBucketIfNotExists(openChannelBucket)
|
openChanBucket, err := rootBucket.CreateBucketIfNotExists(openChannelBucket)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
@ -640,7 +644,7 @@ func (l *LightningWallet) handleFundingCounterPartySigs(msg *addCounterPartySigs
|
|||||||
|
|
||||||
// Create a new sub-bucket within the open channel bucket
|
// Create a new sub-bucket within the open channel bucket
|
||||||
// specifically for this channel.
|
// specifically for this channel.
|
||||||
// TODO(roasbeef): should def be indexed by LNID
|
// TODO(roasbeef): should def be indexed by LNID, cuz mal etc.
|
||||||
chanBucket, err := openChanBucket.CreateBucketIfNotExists(txID.Bytes())
|
chanBucket, err := openChanBucket.CreateBucketIfNotExists(txID.Bytes())
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
|
Loading…
Reference in New Issue
Block a user