mirror of
https://github.com/btcpayserver/btcpayserver.git
synced 2025-02-23 14:40:36 +01:00
* Make Invoice Create Faster And Fix Gap Limit Issue This make address reserve only when user "activate" paymet method in ui. optional setting in store checkout ui. * Fix swagger documentation around Lazy payment methods * fix changed code signature * Add missing GreenField API for activate feature * Fix checkout experience styling for activate feature * Fix issue with Checkout activate button * Make lightning also work with activation * Make sure PreparePaymentModel is still called on payment handlers even when unactivated * Make payment link return empty if not activated * Add activate payment method method to client and add test * remove debugger * add e2e test * Rearranging lazy payments position in UI to be near dependent Unified QR code * fix rebase conflicts * Make lazy payment method mode activate on UI load. Co-authored-by: Kukks <evilkukka@gmail.com> Co-authored-by: rockstardev <rockstardev@users.noreply.github.com> Co-authored-by: Andrew Camilleri <kukks@btcpayserver.org>
68 lines
2.3 KiB
C#
68 lines
2.3 KiB
C#
using System;
|
|
using System.Linq;
|
|
using BTCPayServer.Client.Models;
|
|
using NBitcoin;
|
|
using Newtonsoft.Json;
|
|
|
|
namespace BTCPayServer.Payments.Bitcoin
|
|
{
|
|
public class BitcoinLikeOnChainPaymentMethod : IPaymentMethodDetails
|
|
{
|
|
public PaymentType GetPaymentType() => PaymentTypes.BTCLike;
|
|
|
|
public string GetPaymentDestination()
|
|
{
|
|
return DepositAddress;
|
|
}
|
|
|
|
public decimal GetNextNetworkFee()
|
|
{
|
|
// NextNetworkFee is sometimes not initialized properly, so we return 0 in that case
|
|
return NextNetworkFee?.ToDecimal(MoneyUnit.BTC) ?? 0;
|
|
}
|
|
|
|
public decimal GetFeeRate()
|
|
{
|
|
return FeeRate?.SatoshiPerByte ?? 0;
|
|
}
|
|
|
|
public void SetPaymentDetails(IPaymentMethodDetails newPaymentMethodDetails)
|
|
{
|
|
DepositAddress = newPaymentMethodDetails.GetPaymentDestination();
|
|
KeyPath = (newPaymentMethodDetails as BitcoinLikeOnChainPaymentMethod)?.KeyPath;
|
|
}
|
|
public bool Activated { get; set; } = true;
|
|
public NetworkFeeMode NetworkFeeMode { get; set; }
|
|
|
|
FeeRate _NetworkFeeRate;
|
|
[JsonConverter(typeof(NBitcoin.JsonConverters.FeeRateJsonConverter))]
|
|
public FeeRate NetworkFeeRate
|
|
{
|
|
get
|
|
{
|
|
// Some old invoices don't have this field set, so we fallback on FeeRate
|
|
return _NetworkFeeRate ?? FeeRate;
|
|
}
|
|
set
|
|
{
|
|
_NetworkFeeRate = value;
|
|
}
|
|
}
|
|
public bool PayjoinEnabled { get; set; }
|
|
// Those properties are JsonIgnore because their data is inside CryptoData class for legacy reason
|
|
[JsonIgnore]
|
|
public FeeRate FeeRate { get; set; }
|
|
[JsonIgnore]
|
|
public Money NextNetworkFee { get; set; }
|
|
[JsonIgnore]
|
|
public String DepositAddress { get; set; }
|
|
[JsonConverter(typeof(NBitcoin.JsonConverters.KeyPathJsonConverter))]
|
|
public KeyPath KeyPath { get; set; }
|
|
|
|
public BitcoinAddress GetDepositAddress(Network network)
|
|
{
|
|
return string.IsNullOrEmpty(DepositAddress) ? null : BitcoinAddress.Create(DepositAddress, network);
|
|
}
|
|
///////////////////////////////////////////////////////////////////////////////////////
|
|
}
|
|
}
|