mirror of
https://github.com/btcpayserver/btcpayserver.git
synced 2025-02-24 06:47:50 +01:00
* Dashboard: Load Lightning balance async, display default currency * Simplify approach, improve views and scripts * Async tiles Async tiles * Add period for app sales * Fix missing keypad view sales * Fix after rebase * Fix awaited call * Fix build Co-authored-by: Nicolas Dorier <nicolas.dorier@gmail.com>
76 lines
3.1 KiB
C#
76 lines
3.1 KiB
C#
using System;
|
|
using Dapper;
|
|
using System.Globalization;
|
|
using System.Linq;
|
|
using System.Threading.Tasks;
|
|
using BTCPayServer.Client.Models;
|
|
using BTCPayServer.Components.StoreRecentTransactions;
|
|
using BTCPayServer.Data;
|
|
using BTCPayServer.Services;
|
|
using BTCPayServer.Services.Stores;
|
|
using BTCPayServer.Services.Wallets;
|
|
using Microsoft.AspNetCore.Identity;
|
|
using Microsoft.AspNetCore.Mvc;
|
|
using Microsoft.EntityFrameworkCore;
|
|
using Npgsql;
|
|
using StoreData = BTCPayServer.Data.StoreData;
|
|
|
|
namespace BTCPayServer.Components.StoreNumbers;
|
|
|
|
public class StoreNumbers : ViewComponent
|
|
{
|
|
private readonly StoreRepository _storeRepo;
|
|
private readonly ApplicationDbContextFactory _dbContextFactory;
|
|
private readonly BTCPayWalletProvider _walletProvider;
|
|
private readonly NBXplorerConnectionFactory _nbxConnectionFactory;
|
|
private readonly BTCPayNetworkProvider _networkProvider;
|
|
|
|
public StoreNumbers(
|
|
StoreRepository storeRepo,
|
|
ApplicationDbContextFactory dbContextFactory,
|
|
BTCPayNetworkProvider networkProvider,
|
|
BTCPayWalletProvider walletProvider,
|
|
NBXplorerConnectionFactory nbxConnectionFactory)
|
|
{
|
|
_storeRepo = storeRepo;
|
|
_walletProvider = walletProvider;
|
|
_nbxConnectionFactory = nbxConnectionFactory;
|
|
_networkProvider = networkProvider;
|
|
_dbContextFactory = dbContextFactory;
|
|
}
|
|
|
|
public async Task<IViewComponentResult> InvokeAsync(StoreNumbersViewModel vm)
|
|
{
|
|
if (vm.Store == null) throw new ArgumentNullException(nameof(vm.Store));
|
|
if (vm.CryptoCode == null) throw new ArgumentNullException(nameof(vm.CryptoCode));
|
|
|
|
vm.WalletId = new WalletId(vm.Store.Id, vm.CryptoCode);
|
|
|
|
if (vm.InitialRendering) return View(vm);
|
|
|
|
await using var ctx = _dbContextFactory.CreateContext();
|
|
var payoutsCount = await ctx.Payouts
|
|
.Where(p => p.PullPaymentData.StoreId == vm.Store.Id && !p.PullPaymentData.Archived && p.State == PayoutState.AwaitingApproval)
|
|
.CountAsync();
|
|
var refundsCount = await ctx.Invoices
|
|
.Where(i => i.StoreData.Id == vm.Store.Id && !i.Archived && i.CurrentRefundId != null)
|
|
.CountAsync();
|
|
|
|
var derivation = vm.Store.GetDerivationSchemeSettings(_networkProvider, vm.CryptoCode);
|
|
int? transactionsCount = null;
|
|
if (derivation != null && _nbxConnectionFactory.Available)
|
|
{
|
|
await using var conn = await _nbxConnectionFactory.OpenConnection();
|
|
var wid = NBXplorer.Client.DBUtils.nbxv1_get_wallet_id(derivation.Network.CryptoCode, derivation.AccountDerivation.ToString());
|
|
var afterDate = DateTimeOffset.UtcNow - TimeSpan.FromDays(vm.TransactionDays);
|
|
var count = await conn.ExecuteScalarAsync<long>("SELECT COUNT(*) FROM wallets_history WHERE code=@code AND wallet_id=@wid AND seen_at > @afterDate", new { code = derivation.Network.CryptoCode, wid, afterDate });
|
|
transactionsCount = (int)count;
|
|
}
|
|
|
|
vm.PayoutsPending = payoutsCount;
|
|
vm.Transactions = transactionsCount;
|
|
vm.RefundsIssued = refundsCount;
|
|
|
|
return View(vm);
|
|
}
|
|
}
|