mirror of
https://github.com/lightningnetwork/lnd.git
synced 2024-11-19 18:10:34 +01:00
ce43e4bab7
This commit adds a new expected field, `min_relay_feerate`, in the response body returned from the API source, allowing the API to specify a min relay feerate to be used instead of the FeePerKwFloor. This change is backwards compatible as for an old API source which doesn't specify the `min_relay_feerate`, it will be interpreted as zero.
94 lines
3.0 KiB
Go
94 lines
3.0 KiB
Go
package chainfee
|
|
|
|
import (
|
|
"fmt"
|
|
|
|
"github.com/btcsuite/btcd/blockchain"
|
|
"github.com/btcsuite/btcd/btcutil"
|
|
"github.com/lightningnetwork/lnd/lntypes"
|
|
)
|
|
|
|
const (
|
|
// FeePerKwFloor is the lowest fee rate in sat/kw that we should use for
|
|
// estimating transaction fees before signing.
|
|
FeePerKwFloor SatPerKWeight = 253
|
|
|
|
// AbsoluteFeePerKwFloor is the lowest fee rate in sat/kw of a
|
|
// transaction that we should ever _create_. This is the equivalent
|
|
// of 1 sat/byte in sat/kw.
|
|
AbsoluteFeePerKwFloor SatPerKWeight = 250
|
|
)
|
|
|
|
// SatPerVByte represents a fee rate in sat/vbyte.
|
|
type SatPerVByte btcutil.Amount
|
|
|
|
// FeePerKWeight converts the current fee rate from sat/vb to sat/kw.
|
|
func (s SatPerVByte) FeePerKWeight() SatPerKWeight {
|
|
return SatPerKWeight(s * 1000 / blockchain.WitnessScaleFactor)
|
|
}
|
|
|
|
// FeePerKVByte converts the current fee rate from sat/vb to sat/kvb.
|
|
func (s SatPerVByte) FeePerKVByte() SatPerKVByte {
|
|
return SatPerKVByte(s * 1000)
|
|
}
|
|
|
|
// String returns a human-readable string of the fee rate.
|
|
func (s SatPerVByte) String() string {
|
|
return fmt.Sprintf("%v sat/vb", int64(s))
|
|
}
|
|
|
|
// SatPerKVByte represents a fee rate in sat/kb.
|
|
type SatPerKVByte btcutil.Amount
|
|
|
|
// FeeForVSize calculates the fee resulting from this fee rate and the given
|
|
// vsize in vbytes.
|
|
func (s SatPerKVByte) FeeForVSize(vbytes lntypes.VByte) btcutil.Amount {
|
|
return btcutil.Amount(s) * btcutil.Amount(vbytes) / 1000
|
|
}
|
|
|
|
// FeePerKWeight converts the current fee rate from sat/kb to sat/kw.
|
|
func (s SatPerKVByte) FeePerKWeight() SatPerKWeight {
|
|
return SatPerKWeight(s / blockchain.WitnessScaleFactor)
|
|
}
|
|
|
|
// String returns a human-readable string of the fee rate.
|
|
func (s SatPerKVByte) String() string {
|
|
return fmt.Sprintf("%v sat/kvb", int64(s))
|
|
}
|
|
|
|
// SatPerKWeight represents a fee rate in sat/kw.
|
|
type SatPerKWeight btcutil.Amount
|
|
|
|
// NewSatPerKWeight creates a new fee rate in sat/kw.
|
|
func NewSatPerKWeight(fee btcutil.Amount, wu lntypes.WeightUnit) SatPerKWeight {
|
|
return SatPerKWeight(fee.MulF64(1000 / float64(wu)))
|
|
}
|
|
|
|
// FeeForWeight calculates the fee resulting from this fee rate and the given
|
|
// weight in weight units (wu).
|
|
func (s SatPerKWeight) FeeForWeight(wu lntypes.WeightUnit) btcutil.Amount {
|
|
// The resulting fee is rounded down, as specified in BOLT#03.
|
|
return btcutil.Amount(s) * btcutil.Amount(wu) / 1000
|
|
}
|
|
|
|
// FeeForVByte calculates the fee resulting from this fee rate and the given
|
|
// size in vbytes (vb).
|
|
func (s SatPerKWeight) FeeForVByte(vb lntypes.VByte) btcutil.Amount {
|
|
return s.FeePerKVByte().FeeForVSize(vb)
|
|
}
|
|
|
|
// FeePerKVByte converts the current fee rate from sat/kw to sat/kb.
|
|
func (s SatPerKWeight) FeePerKVByte() SatPerKVByte {
|
|
return SatPerKVByte(s * blockchain.WitnessScaleFactor)
|
|
}
|
|
|
|
// FeePerVByte converts the current fee rate from sat/kw to sat/vb.
|
|
func (s SatPerKWeight) FeePerVByte() SatPerVByte {
|
|
return SatPerVByte(s * blockchain.WitnessScaleFactor / 1000)
|
|
}
|
|
|
|
// String returns a human-readable string of the fee rate.
|
|
func (s SatPerKWeight) String() string {
|
|
return fmt.Sprintf("%v sat/kw", int64(s))
|
|
}
|