mirror of
https://github.com/aljazceru/btcpayserver.git
synced 2025-12-19 06:54:19 +01:00
Triggering optional confirmation update only on Invoice details page
This commit is contained in:
committed by
Nicolas Dorier
parent
be844978c1
commit
9a2e1d43ea
@@ -84,6 +84,29 @@ namespace BTCPayServer.Controllers
|
|||||||
Current = !h.UnAssigned.HasValue
|
Current = !h.UnAssigned.HasValue
|
||||||
}).ToArray();
|
}).ToArray();
|
||||||
|
|
||||||
|
var updateConfirmationCountIfNeeded = invoice
|
||||||
|
.GetPayments()
|
||||||
|
.Select<PaymentEntity, Task>(async payment =>
|
||||||
|
{
|
||||||
|
var paymentNetwork = _NetworkProvider.GetNetwork(payment.GetCryptoCode());
|
||||||
|
var paymentData = payment.GetCryptoPaymentData();
|
||||||
|
if (paymentData is Payments.Bitcoin.BitcoinLikePaymentData onChainPaymentData)
|
||||||
|
{
|
||||||
|
int confirmationCount = 0;
|
||||||
|
if ((onChainPaymentData.ConfirmationCount < paymentNetwork.MaxTrackedConfirmation && payment.Accounted)
|
||||||
|
&& (onChainPaymentData.Legacy || invoice.MonitoringExpiration < DateTimeOffset.UtcNow))
|
||||||
|
// The confirmation count in the paymentData is not up to date
|
||||||
|
{
|
||||||
|
confirmationCount = (await ((ExplorerClientProvider)_ServiceProvider.GetService(typeof(ExplorerClientProvider))).GetExplorerClient(payment.GetCryptoCode())?.GetTransactionAsync(onChainPaymentData.Outpoint.Hash))?.Confirmations ?? 0;
|
||||||
|
onChainPaymentData.ConfirmationCount = confirmationCount;
|
||||||
|
payment.SetCryptoPaymentData(onChainPaymentData);
|
||||||
|
await _InvoiceRepository.UpdatePayments(new List<PaymentEntity> { payment });
|
||||||
|
}
|
||||||
|
}
|
||||||
|
})
|
||||||
|
.ToArray();
|
||||||
|
await Task.WhenAll(updateConfirmationCountIfNeeded);
|
||||||
|
|
||||||
var details = await InvoicePopulatePayments(invoice);
|
var details = await InvoicePopulatePayments(invoice);
|
||||||
model.CryptoPayments = details.CryptoPayments;
|
model.CryptoPayments = details.CryptoPayments;
|
||||||
model.OnChainPayments = details.OnChainPayments;
|
model.OnChainPayments = details.OnChainPayments;
|
||||||
@@ -127,19 +150,7 @@ namespace BTCPayServer.Controllers
|
|||||||
m.Crypto = payment.GetPaymentMethodId().CryptoCode;
|
m.Crypto = payment.GetPaymentMethodId().CryptoCode;
|
||||||
m.DepositAddress = onChainPaymentData.GetDestination(paymentNetwork);
|
m.DepositAddress = onChainPaymentData.GetDestination(paymentNetwork);
|
||||||
|
|
||||||
int confirmationCount = 0;
|
int confirmationCount = onChainPaymentData.ConfirmationCount;
|
||||||
if ((onChainPaymentData.ConfirmationCount < paymentNetwork.MaxTrackedConfirmation && payment.Accounted)
|
|
||||||
&& (onChainPaymentData.Legacy || invoice.MonitoringExpiration < DateTimeOffset.UtcNow)) // The confirmation count in the paymentData is not up to date
|
|
||||||
{
|
|
||||||
confirmationCount = (await ((ExplorerClientProvider)_ServiceProvider.GetService(typeof(ExplorerClientProvider))).GetExplorerClient(payment.GetCryptoCode())?.GetTransactionAsync(onChainPaymentData.Outpoint.Hash))?.Confirmations ?? 0;
|
|
||||||
onChainPaymentData.ConfirmationCount = confirmationCount;
|
|
||||||
payment.SetCryptoPaymentData(onChainPaymentData);
|
|
||||||
await _InvoiceRepository.UpdatePayments(new List<PaymentEntity> { payment });
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
confirmationCount = onChainPaymentData.ConfirmationCount;
|
|
||||||
}
|
|
||||||
if (confirmationCount >= paymentNetwork.MaxTrackedConfirmation)
|
if (confirmationCount >= paymentNetwork.MaxTrackedConfirmation)
|
||||||
{
|
{
|
||||||
m.Confirmations = "At least " + (paymentNetwork.MaxTrackedConfirmation);
|
m.Confirmations = "At least " + (paymentNetwork.MaxTrackedConfirmation);
|
||||||
@@ -157,7 +168,7 @@ namespace BTCPayServer.Controllers
|
|||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
var lightningPaymentData = (Payments.Lightning.LightningLikePaymentData)paymentData;
|
var lightningPaymentData = (LightningLikePaymentData)paymentData;
|
||||||
return new InvoiceDetailsModel.OffChainPayment()
|
return new InvoiceDetailsModel.OffChainPayment()
|
||||||
{
|
{
|
||||||
Crypto = paymentNetwork.CryptoCode,
|
Crypto = paymentNetwork.CryptoCode,
|
||||||
|
|||||||
Reference in New Issue
Block a user