mirror of
https://github.com/lightningnetwork/lnd.git
synced 2025-07-07 22:10:27 +02:00
graph/db+sqldb: implement various zombie index methods
Here we implement the SQLStore methods: - MarkEdgeZombie - MarkEdgeLive - IsZombieEdge - NumZombies These will be tested in the next commit as one more method implementation is required.
This commit is contained in:
@ -26,6 +26,19 @@ func (q *Queries) AddSourceNode(ctx context.Context, nodeID int64) error {
|
||||
return err
|
||||
}
|
||||
|
||||
const countZombieChannels = `-- name: CountZombieChannels :one
|
||||
SELECT COUNT(*)
|
||||
FROM zombie_channels
|
||||
WHERE version = $1
|
||||
`
|
||||
|
||||
func (q *Queries) CountZombieChannels(ctx context.Context, version int16) (int64, error) {
|
||||
row := q.db.QueryRowContext(ctx, countZombieChannels, version)
|
||||
var count int64
|
||||
err := row.Scan(&count)
|
||||
return count, err
|
||||
}
|
||||
|
||||
const createChannel = `-- name: CreateChannel :one
|
||||
/* ─────────────────────────────────────────────
|
||||
channels table queries
|
||||
@ -168,6 +181,21 @@ func (q *Queries) DeleteNodeFeature(ctx context.Context, arg DeleteNodeFeaturePa
|
||||
return err
|
||||
}
|
||||
|
||||
const deleteZombieChannel = `-- name: DeleteZombieChannel :execresult
|
||||
DELETE FROM zombie_channels
|
||||
WHERE scid = $1
|
||||
AND version = $2
|
||||
`
|
||||
|
||||
type DeleteZombieChannelParams struct {
|
||||
Scid []byte
|
||||
Version int16
|
||||
}
|
||||
|
||||
func (q *Queries) DeleteZombieChannel(ctx context.Context, arg DeleteZombieChannelParams) (sql.Result, error) {
|
||||
return q.db.ExecContext(ctx, deleteZombieChannel, arg.Scid, arg.Version)
|
||||
}
|
||||
|
||||
const getChannelAndNodesBySCID = `-- name: GetChannelAndNodesBySCID :one
|
||||
SELECT
|
||||
c.id, c.version, c.scid, c.node_id_1, c.node_id_2, c.outpoint, c.capacity, c.bitcoin_key_1, c.bitcoin_key_2, c.node_1_signature, c.node_2_signature, c.bitcoin_1_signature, c.bitcoin_2_signature,
|
||||
@ -888,6 +916,30 @@ func (q *Queries) GetSourceNodesByVersion(ctx context.Context, version int16) ([
|
||||
return items, nil
|
||||
}
|
||||
|
||||
const getZombieChannel = `-- name: GetZombieChannel :one
|
||||
SELECT scid, version, node_key_1, node_key_2
|
||||
FROM zombie_channels
|
||||
WHERE scid = $1
|
||||
AND version = $2
|
||||
`
|
||||
|
||||
type GetZombieChannelParams struct {
|
||||
Scid []byte
|
||||
Version int16
|
||||
}
|
||||
|
||||
func (q *Queries) GetZombieChannel(ctx context.Context, arg GetZombieChannelParams) (ZombieChannel, error) {
|
||||
row := q.db.QueryRowContext(ctx, getZombieChannel, arg.Scid, arg.Version)
|
||||
var i ZombieChannel
|
||||
err := row.Scan(
|
||||
&i.Scid,
|
||||
&i.Version,
|
||||
&i.NodeKey1,
|
||||
&i.NodeKey2,
|
||||
)
|
||||
return i, err
|
||||
}
|
||||
|
||||
const highestSCID = `-- name: HighestSCID :one
|
||||
SELECT scid
|
||||
FROM channels
|
||||
@ -1538,3 +1590,36 @@ func (q *Queries) UpsertNodeExtraType(ctx context.Context, arg UpsertNodeExtraTy
|
||||
_, err := q.db.ExecContext(ctx, upsertNodeExtraType, arg.NodeID, arg.Type, arg.Value)
|
||||
return err
|
||||
}
|
||||
|
||||
const upsertZombieChannel = `-- name: UpsertZombieChannel :exec
|
||||
/* ─────────────────────────────────────────────
|
||||
zombie_channels table queries
|
||||
─────────────────────────────────────────────
|
||||
*/
|
||||
|
||||
INSERT INTO zombie_channels (scid, version, node_key_1, node_key_2)
|
||||
VALUES ($1, $2, $3, $4)
|
||||
ON CONFLICT (scid, version)
|
||||
DO UPDATE SET
|
||||
-- If a conflict exists for the SCID and version pair, then we
|
||||
-- update the node keys.
|
||||
node_key_1 = COALESCE(EXCLUDED.node_key_1, zombie_channels.node_key_1),
|
||||
node_key_2 = COALESCE(EXCLUDED.node_key_2, zombie_channels.node_key_2)
|
||||
`
|
||||
|
||||
type UpsertZombieChannelParams struct {
|
||||
Scid []byte
|
||||
Version int16
|
||||
NodeKey1 []byte
|
||||
NodeKey2 []byte
|
||||
}
|
||||
|
||||
func (q *Queries) UpsertZombieChannel(ctx context.Context, arg UpsertZombieChannelParams) error {
|
||||
_, err := q.db.ExecContext(ctx, upsertZombieChannel,
|
||||
arg.Scid,
|
||||
arg.Version,
|
||||
arg.NodeKey1,
|
||||
arg.NodeKey2,
|
||||
)
|
||||
return err
|
||||
}
|
||||
|
@ -13,6 +13,7 @@ import (
|
||||
type Querier interface {
|
||||
AddSourceNode(ctx context.Context, nodeID int64) error
|
||||
ClearKVInvoiceHashIndex(ctx context.Context) error
|
||||
CountZombieChannels(ctx context.Context, version int16) (int64, error)
|
||||
CreateChannel(ctx context.Context, arg CreateChannelParams) (int64, error)
|
||||
CreateChannelExtraType(ctx context.Context, arg CreateChannelExtraTypeParams) error
|
||||
DeleteCanceledInvoices(ctx context.Context) (sql.Result, error)
|
||||
@ -22,6 +23,7 @@ type Querier interface {
|
||||
DeleteNodeAddresses(ctx context.Context, nodeID int64) error
|
||||
DeleteNodeByPubKey(ctx context.Context, arg DeleteNodeByPubKeyParams) (sql.Result, error)
|
||||
DeleteNodeFeature(ctx context.Context, arg DeleteNodeFeatureParams) error
|
||||
DeleteZombieChannel(ctx context.Context, arg DeleteZombieChannelParams) (sql.Result, error)
|
||||
FetchAMPSubInvoiceHTLCs(ctx context.Context, arg FetchAMPSubInvoiceHTLCsParams) ([]FetchAMPSubInvoiceHTLCsRow, error)
|
||||
FetchAMPSubInvoices(ctx context.Context, arg FetchAMPSubInvoicesParams) ([]AmpSubInvoice, error)
|
||||
FetchSettledAMPSubInvoices(ctx context.Context, arg FetchSettledAMPSubInvoicesParams) ([]FetchSettledAMPSubInvoicesRow, error)
|
||||
@ -54,6 +56,7 @@ type Querier interface {
|
||||
GetNodesByLastUpdateRange(ctx context.Context, arg GetNodesByLastUpdateRangeParams) ([]Node, error)
|
||||
GetPublicV1ChannelsBySCID(ctx context.Context, arg GetPublicV1ChannelsBySCIDParams) ([]Channel, error)
|
||||
GetSourceNodesByVersion(ctx context.Context, version int16) ([]GetSourceNodesByVersionRow, error)
|
||||
GetZombieChannel(ctx context.Context, arg GetZombieChannelParams) (ZombieChannel, error)
|
||||
HighestSCID(ctx context.Context, version int16) ([]byte, error)
|
||||
InsertAMPSubInvoice(ctx context.Context, arg InsertAMPSubInvoiceParams) error
|
||||
InsertAMPSubInvoiceHTLC(ctx context.Context, arg InsertAMPSubInvoiceHTLCParams) error
|
||||
@ -90,6 +93,7 @@ type Querier interface {
|
||||
UpsertEdgePolicy(ctx context.Context, arg UpsertEdgePolicyParams) (int64, error)
|
||||
UpsertNode(ctx context.Context, arg UpsertNodeParams) (int64, error)
|
||||
UpsertNodeExtraType(ctx context.Context, arg UpsertNodeExtraTypeParams) error
|
||||
UpsertZombieChannel(ctx context.Context, arg UpsertZombieChannelParams) error
|
||||
}
|
||||
|
||||
var _ Querier = (*Queries)(nil)
|
||||
|
@ -460,3 +460,34 @@ WHERE cp.id = $1 OR cp.id = $2;
|
||||
-- name: DeleteChannelPolicyExtraTypes :exec
|
||||
DELETE FROM channel_policy_extra_types
|
||||
WHERE channel_policy_id = $1;
|
||||
|
||||
/* ─────────────────────────────────────────────
|
||||
zombie_channels table queries
|
||||
─────────────────────────────────────────────
|
||||
*/
|
||||
|
||||
-- name: UpsertZombieChannel :exec
|
||||
INSERT INTO zombie_channels (scid, version, node_key_1, node_key_2)
|
||||
VALUES ($1, $2, $3, $4)
|
||||
ON CONFLICT (scid, version)
|
||||
DO UPDATE SET
|
||||
-- If a conflict exists for the SCID and version pair, then we
|
||||
-- update the node keys.
|
||||
node_key_1 = COALESCE(EXCLUDED.node_key_1, zombie_channels.node_key_1),
|
||||
node_key_2 = COALESCE(EXCLUDED.node_key_2, zombie_channels.node_key_2);
|
||||
|
||||
-- name: DeleteZombieChannel :execresult
|
||||
DELETE FROM zombie_channels
|
||||
WHERE scid = $1
|
||||
AND version = $2;
|
||||
|
||||
-- name: CountZombieChannels :one
|
||||
SELECT COUNT(*)
|
||||
FROM zombie_channels
|
||||
WHERE version = $1;
|
||||
|
||||
-- name: GetZombieChannel :one
|
||||
SELECT *
|
||||
FROM zombie_channels
|
||||
WHERE scid = $1
|
||||
AND version = $2;
|
||||
|
Reference in New Issue
Block a user