labels

package
v0.14.2-beta.rc3 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Jun 22, 2022 License: MIT Imports: 3 Imported by: 0

Documentation

Overview

Package labels contains labels used to label transactions broadcast by lnd. These labels are used across packages, so they are declared in a separate package to avoid dependency issues.

Labels for transactions broadcast by lnd have two set fields followed by an optional set labelled data values, all separated by colons.

  • Label version: an integer that indicates the version lnd used
  • Label type: the type of transaction we are labelling
  • {field name}-{value}: a named field followed by its value, these items are optional, and there may be more than field present.

For version 0 we have the following optional data fields defined:

  • shortchanid: the short channel ID that a transaction is associated with, with its value set to the uint64 short channel id.

Index

Constants

View Source
const External = "external"

External labels a transaction as user initiated via the api. This label is only used when a custom user provided label is not given.

Variables

This section is empty.

Functions

func MakeLabel

func MakeLabel(labelType LabelType, channelID *lnwire.ShortChannelID) string

MakeLabel creates a label with the provided type and short channel id. If our short channel ID is not known, we simply return version:label_type. If we do have a short channel ID set, the label will also contain its value: shortchanid-{int64 chan ID}.

func ValidateAPI

func ValidateAPI(label string) (string, error)

ValidateAPI returns the generic api label if the label provided is empty. This allows us to label all transactions published by the api, even if no label is provided. If a label is provided, it is validated against the known restrictions.

Types

type LabelField

type LabelField string

LabelField is used to tag a value within a label.

const (
	// ShortChanID is used to tag short channel id values in our labels.
	ShortChanID LabelField = "shortchanid"
)

type LabelType

type LabelType string

LabelType indicates the type of label we are creating. It is a string rather than an int for easy string matching and human-readability.

const (
	// LabelTypeChannelOpen is used to label channel opens.
	LabelTypeChannelOpen LabelType = "openchannel"

	// LabelTypeChannelClose is used to label channel closes.
	LabelTypeChannelClose LabelType = "closechannel"

	// LabelTypeJusticeTransaction is used to label justice transactions.
	LabelTypeJusticeTransaction LabelType = "justicetx"

	// LabelTypeSweepTransaction is used to label sweeps.
	LabelTypeSweepTransaction LabelType = "sweep"
)

type LabelVersion

type LabelVersion uint8

LabelVersion versions our labels so they can be easily update to contain new data while still easily string matched.

const LabelVersionZero LabelVersion = iota

LabelVersionZero is the label version for labels that contain label type and channel ID (where available).

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL