mirror of
https://github.com/lightningnetwork/lnd.git
synced 2025-09-19 20:15:18 +02:00
sqldb: add channel data batch queries
Also add the calling logic for these queries. This logic is not yet used.
This commit is contained in:
@@ -701,6 +701,49 @@ func (q *Queries) GetChannelBySCIDWithPolicies(ctx context.Context, arg GetChann
|
||||
return i, err
|
||||
}
|
||||
|
||||
const getChannelExtrasBatch = `-- name: GetChannelExtrasBatch :many
|
||||
SELECT
|
||||
channel_id,
|
||||
type,
|
||||
value
|
||||
FROM graph_channel_extra_types
|
||||
WHERE channel_id IN (/*SLICE:chan_ids*/?)
|
||||
ORDER BY channel_id, type
|
||||
`
|
||||
|
||||
func (q *Queries) GetChannelExtrasBatch(ctx context.Context, chanIds []int64) ([]GraphChannelExtraType, error) {
|
||||
query := getChannelExtrasBatch
|
||||
var queryParams []interface{}
|
||||
if len(chanIds) > 0 {
|
||||
for _, v := range chanIds {
|
||||
queryParams = append(queryParams, v)
|
||||
}
|
||||
query = strings.Replace(query, "/*SLICE:chan_ids*/?", makeQueryParams(len(queryParams), len(chanIds)), 1)
|
||||
} else {
|
||||
query = strings.Replace(query, "/*SLICE:chan_ids*/?", "NULL", 1)
|
||||
}
|
||||
rows, err := q.db.QueryContext(ctx, query, queryParams...)
|
||||
if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
defer rows.Close()
|
||||
var items []GraphChannelExtraType
|
||||
for rows.Next() {
|
||||
var i GraphChannelExtraType
|
||||
if err := rows.Scan(&i.ChannelID, &i.Type, &i.Value); err != nil {
|
||||
return nil, err
|
||||
}
|
||||
items = append(items, i)
|
||||
}
|
||||
if err := rows.Close(); err != nil {
|
||||
return nil, err
|
||||
}
|
||||
if err := rows.Err(); err != nil {
|
||||
return nil, err
|
||||
}
|
||||
return items, nil
|
||||
}
|
||||
|
||||
const getChannelFeaturesAndExtras = `-- name: GetChannelFeaturesAndExtras :many
|
||||
SELECT
|
||||
cf.channel_id,
|
||||
@@ -760,6 +803,48 @@ func (q *Queries) GetChannelFeaturesAndExtras(ctx context.Context, channelID int
|
||||
return items, nil
|
||||
}
|
||||
|
||||
const getChannelFeaturesBatch = `-- name: GetChannelFeaturesBatch :many
|
||||
SELECT
|
||||
channel_id,
|
||||
feature_bit
|
||||
FROM graph_channel_features
|
||||
WHERE channel_id IN (/*SLICE:chan_ids*/?)
|
||||
ORDER BY channel_id, feature_bit
|
||||
`
|
||||
|
||||
func (q *Queries) GetChannelFeaturesBatch(ctx context.Context, chanIds []int64) ([]GraphChannelFeature, error) {
|
||||
query := getChannelFeaturesBatch
|
||||
var queryParams []interface{}
|
||||
if len(chanIds) > 0 {
|
||||
for _, v := range chanIds {
|
||||
queryParams = append(queryParams, v)
|
||||
}
|
||||
query = strings.Replace(query, "/*SLICE:chan_ids*/?", makeQueryParams(len(queryParams), len(chanIds)), 1)
|
||||
} else {
|
||||
query = strings.Replace(query, "/*SLICE:chan_ids*/?", "NULL", 1)
|
||||
}
|
||||
rows, err := q.db.QueryContext(ctx, query, queryParams...)
|
||||
if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
defer rows.Close()
|
||||
var items []GraphChannelFeature
|
||||
for rows.Next() {
|
||||
var i GraphChannelFeature
|
||||
if err := rows.Scan(&i.ChannelID, &i.FeatureBit); err != nil {
|
||||
return nil, err
|
||||
}
|
||||
items = append(items, i)
|
||||
}
|
||||
if err := rows.Close(); err != nil {
|
||||
return nil, err
|
||||
}
|
||||
if err := rows.Err(); err != nil {
|
||||
return nil, err
|
||||
}
|
||||
return items, nil
|
||||
}
|
||||
|
||||
const getChannelPolicyByChannelAndNode = `-- name: GetChannelPolicyByChannelAndNode :one
|
||||
SELECT id, version, channel_id, node_id, timelock, fee_ppm, base_fee_msat, min_htlc_msat, max_htlc_msat, last_update, disabled, inbound_base_fee_msat, inbound_fee_rate_milli_msat, message_flags, channel_flags, signature
|
||||
FROM graph_channel_policies
|
||||
@@ -853,6 +938,55 @@ func (q *Queries) GetChannelPolicyExtraTypes(ctx context.Context, arg GetChannel
|
||||
return items, nil
|
||||
}
|
||||
|
||||
const getChannelPolicyExtraTypesBatch = `-- name: GetChannelPolicyExtraTypesBatch :many
|
||||
SELECT
|
||||
channel_policy_id as policy_id,
|
||||
type,
|
||||
value
|
||||
FROM graph_channel_policy_extra_types
|
||||
WHERE channel_policy_id IN (/*SLICE:policy_ids*/?)
|
||||
ORDER BY channel_policy_id, type
|
||||
`
|
||||
|
||||
type GetChannelPolicyExtraTypesBatchRow struct {
|
||||
PolicyID int64
|
||||
Type int64
|
||||
Value []byte
|
||||
}
|
||||
|
||||
func (q *Queries) GetChannelPolicyExtraTypesBatch(ctx context.Context, policyIds []int64) ([]GetChannelPolicyExtraTypesBatchRow, error) {
|
||||
query := getChannelPolicyExtraTypesBatch
|
||||
var queryParams []interface{}
|
||||
if len(policyIds) > 0 {
|
||||
for _, v := range policyIds {
|
||||
queryParams = append(queryParams, v)
|
||||
}
|
||||
query = strings.Replace(query, "/*SLICE:policy_ids*/?", makeQueryParams(len(queryParams), len(policyIds)), 1)
|
||||
} else {
|
||||
query = strings.Replace(query, "/*SLICE:policy_ids*/?", "NULL", 1)
|
||||
}
|
||||
rows, err := q.db.QueryContext(ctx, query, queryParams...)
|
||||
if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
defer rows.Close()
|
||||
var items []GetChannelPolicyExtraTypesBatchRow
|
||||
for rows.Next() {
|
||||
var i GetChannelPolicyExtraTypesBatchRow
|
||||
if err := rows.Scan(&i.PolicyID, &i.Type, &i.Value); err != nil {
|
||||
return nil, err
|
||||
}
|
||||
items = append(items, i)
|
||||
}
|
||||
if err := rows.Close(); err != nil {
|
||||
return nil, err
|
||||
}
|
||||
if err := rows.Err(); err != nil {
|
||||
return nil, err
|
||||
}
|
||||
return items, nil
|
||||
}
|
||||
|
||||
const getChannelsByOutpoints = `-- name: GetChannelsByOutpoints :many
|
||||
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,
|
||||
|
@@ -38,9 +38,12 @@ type Querier interface {
|
||||
GetChannelByOutpointWithPolicies(ctx context.Context, arg GetChannelByOutpointWithPoliciesParams) (GetChannelByOutpointWithPoliciesRow, error)
|
||||
GetChannelBySCID(ctx context.Context, arg GetChannelBySCIDParams) (GraphChannel, error)
|
||||
GetChannelBySCIDWithPolicies(ctx context.Context, arg GetChannelBySCIDWithPoliciesParams) (GetChannelBySCIDWithPoliciesRow, error)
|
||||
GetChannelExtrasBatch(ctx context.Context, chanIds []int64) ([]GraphChannelExtraType, error)
|
||||
GetChannelFeaturesAndExtras(ctx context.Context, channelID int64) ([]GetChannelFeaturesAndExtrasRow, error)
|
||||
GetChannelFeaturesBatch(ctx context.Context, chanIds []int64) ([]GraphChannelFeature, error)
|
||||
GetChannelPolicyByChannelAndNode(ctx context.Context, arg GetChannelPolicyByChannelAndNodeParams) (GraphChannelPolicy, error)
|
||||
GetChannelPolicyExtraTypes(ctx context.Context, arg GetChannelPolicyExtraTypesParams) ([]GetChannelPolicyExtraTypesRow, error)
|
||||
GetChannelPolicyExtraTypesBatch(ctx context.Context, policyIds []int64) ([]GetChannelPolicyExtraTypesBatchRow, error)
|
||||
GetChannelsByOutpoints(ctx context.Context, outpoints []string) ([]GetChannelsByOutpointsRow, error)
|
||||
GetChannelsByPolicyLastUpdateRange(ctx context.Context, arg GetChannelsByPolicyLastUpdateRangeParams) ([]GetChannelsByPolicyLastUpdateRangeRow, error)
|
||||
GetChannelsBySCIDRange(ctx context.Context, arg GetChannelsBySCIDRangeParams) ([]GetChannelsBySCIDRangeRow, error)
|
||||
|
@@ -647,6 +647,14 @@ INSERT INTO graph_channel_features (
|
||||
$1, $2
|
||||
);
|
||||
|
||||
-- name: GetChannelFeaturesBatch :many
|
||||
SELECT
|
||||
channel_id,
|
||||
feature_bit
|
||||
FROM graph_channel_features
|
||||
WHERE channel_id IN (sqlc.slice('chan_ids')/*SLICE:chan_ids*/)
|
||||
ORDER BY channel_id, feature_bit;
|
||||
|
||||
/* ─────────────────────────────────────────────
|
||||
graph_channel_extra_types table queries
|
||||
─────────────────────────────────────────────
|
||||
@@ -658,6 +666,15 @@ INSERT INTO graph_channel_extra_types (
|
||||
)
|
||||
VALUES ($1, $2, $3);
|
||||
|
||||
-- name: GetChannelExtrasBatch :many
|
||||
SELECT
|
||||
channel_id,
|
||||
type,
|
||||
value
|
||||
FROM graph_channel_extra_types
|
||||
WHERE channel_id IN (sqlc.slice('chan_ids')/*SLICE:chan_ids*/)
|
||||
ORDER BY channel_id, type;
|
||||
|
||||
/* ─────────────────────────────────────────────
|
||||
graph_channel_policies table queries
|
||||
─────────────────────────────────────────────
|
||||
@@ -760,6 +777,15 @@ INSERT INTO graph_channel_policy_extra_types (
|
||||
)
|
||||
VALUES ($1, $2, $3);
|
||||
|
||||
-- name: GetChannelPolicyExtraTypesBatch :many
|
||||
SELECT
|
||||
channel_policy_id as policy_id,
|
||||
type,
|
||||
value
|
||||
FROM graph_channel_policy_extra_types
|
||||
WHERE channel_policy_id IN (sqlc.slice('policy_ids')/*SLICE:policy_ids*/)
|
||||
ORDER BY channel_policy_id, type;
|
||||
|
||||
-- name: GetChannelPolicyExtraTypes :many
|
||||
SELECT
|
||||
cp.id AS policy_id,
|
||||
|
Reference in New Issue
Block a user