channeldb: add method for fetching channels waiting for closing tx

This commit adds a new method FetchWaitingCloseChannels to the database,
used for fetching OpenChannels that have a ChanStatus != Default. These
are channels that are borked, or have had a commitment broadcasted, and
is now waiting for it to confirm.

The fetchChannels method is rewritten to return channels exclusively
based on wheter they are pending or waitingClose.
This commit is contained in:
Johan T. Halseth 2018-04-12 12:49:19 +02:00
parent b2949bd728
commit 0735b8e0b7
No known key found for this signature in database
GPG Key ID: 15BAADA29DA20D26

@ -312,23 +312,60 @@ func (d *DB) fetchNodeChannels(chainBucket *bolt.Bucket) ([]*OpenChannel, error)
} }
// FetchAllChannels attempts to retrieve all open channels currently stored // FetchAllChannels attempts to retrieve all open channels currently stored
// within the database. // within the database, including pending open, fully open and channels waiting
// for a closing transaction to confirm.
func (d *DB) FetchAllChannels() ([]*OpenChannel, error) { func (d *DB) FetchAllChannels() ([]*OpenChannel, error) {
return fetchChannels(d, false) var channels []*OpenChannel
// TODO(halseth): fetch all in one db tx.
openChannels, err := d.FetchAllOpenChannels()
if err != nil {
return nil, err
}
channels = append(channels, openChannels...)
pendingChannels, err := d.FetchPendingChannels()
if err != nil {
return nil, err
}
channels = append(channels, pendingChannels...)
waitingClose, err := d.FetchWaitingCloseChannels()
if err != nil {
return nil, err
}
channels = append(channels, waitingClose...)
return channels, nil
}
// FetchAllOpenChannels will return all channels that have the funding
// transaction confirmed, and is not waiting for a closing transaction to be
// confirmed.
func (d *DB) FetchAllOpenChannels() ([]*OpenChannel, error) {
return fetchChannels(d, false, false)
} }
// FetchPendingChannels will return channels that have completed the process of // FetchPendingChannels will return channels that have completed the process of
// generating and broadcasting funding transactions, but whose funding // generating and broadcasting funding transactions, but whose funding
// transactions have yet to be confirmed on the blockchain. // transactions have yet to be confirmed on the blockchain.
func (d *DB) FetchPendingChannels() ([]*OpenChannel, error) { func (d *DB) FetchPendingChannels() ([]*OpenChannel, error) {
return fetchChannels(d, true) return fetchChannels(d, true, false)
}
// FetchWaitingCloseChannels will return all channels that have been opened,
// but now is waiting for a closing transaction to be confirmed.
func (d *DB) FetchWaitingCloseChannels() ([]*OpenChannel, error) {
return fetchChannels(d, false, true)
} }
// fetchChannels attempts to retrieve channels currently stored in the // fetchChannels attempts to retrieve channels currently stored in the
// database. The pendingOnly parameter determines whether only pending channels // database. The pending parameter determines whether only pending channels
// will be returned. If no active channels exist within the network, then // will be returned, or only open channels will be returned. The waitingClose
// ErrNoActiveChannels is returned. // parameter determines wheter only channels waiting for a closing transaction
func fetchChannels(d *DB, pendingOnly bool) ([]*OpenChannel, error) { // to be confirmed should be returned. If no active channels exist within the
// network, then ErrNoActiveChannels is returned.
func fetchChannels(d *DB, pending, waitingClose bool) ([]*OpenChannel, error) {
var channels []*OpenChannel var channels []*OpenChannel
err := d.View(func(tx *bolt.Tx) error { err := d.View(func(tx *bolt.Tx) error {
@ -377,23 +414,36 @@ func fetchChannels(d *DB, pendingOnly bool) ([]*OpenChannel, error) {
"channel for chain_hash=%x, "+ "channel for chain_hash=%x, "+
"node_key=%x: %v", chainHash[:], k, err) "node_key=%x: %v", chainHash[:], k, err)
} }
// TODO(roasbeef): simplify
if pendingOnly {
for _, channel := range nodeChans { for _, channel := range nodeChans {
if channel.IsPending { if channel.IsPending != pending {
continue
}
// If the channel is in any other state
// than Default, then it means it is
// waiting to be closed.
channelWaitingClose :=
channel.ChanStatus != Default
// Only include it if we requested
// channels with the same waitingClose
// status.
if channelWaitingClose != waitingClose {
continue
}
channels = append(channels, channel) channels = append(channels, channel)
} }
}
} else {
channels = append(channels, nodeChans...)
}
return nil return nil
}) })
}) })
}) })
if err != nil {
return nil, err
}
return channels, err return channels, nil
} }
// FetchClosedChannels attempts to fetch all closed channels from the database. // FetchClosedChannels attempts to fetch all closed channels from the database.