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:
parent
b2949bd728
commit
0735b8e0b7
@ -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
|
for _, channel := range nodeChans {
|
||||||
if pendingOnly {
|
if channel.IsPending != pending {
|
||||||
for _, channel := range nodeChans {
|
continue
|
||||||
if channel.IsPending {
|
|
||||||
channels = append(channels, channel)
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
} else {
|
|
||||||
channels = append(channels, nodeChans...)
|
// 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)
|
||||||
}
|
}
|
||||||
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.
|
||||||
|
Loading…
Reference in New Issue
Block a user