mirror of
https://github.com/aljazceru/BTCPayServerPlugins.git
synced 2025-12-17 07:34:24 +01:00
upd wb
This commit is contained in:
@@ -53,8 +53,7 @@ SmartCoin[] FilterCoinsMore(IEnumerable<SmartCoin> coins)
|
||||
.Where(coin => roundParameters.AllowedInputAmounts.Contains(coin.Amount))
|
||||
.Where(coin =>
|
||||
{
|
||||
var effV = coin.EffectiveValue(roundParameters.MiningFeeRate,
|
||||
roundParameters.CoordinationFeeRate);
|
||||
var effV = coin.EffectiveValue(roundParameters.MiningFeeRate);
|
||||
var percentageLeft = (effV.ToDecimal(MoneyUnit.BTC) / coin.Amount.ToDecimal(MoneyUnit.BTC));
|
||||
// filter out low value coins where 50% of the value would be eaten up by fees
|
||||
return effV > Money.Zero && percentageLeft >= 0.5m;
|
||||
@@ -283,8 +282,7 @@ SmartCoin[] FilterCoinsMore(IEnumerable<SmartCoin> coins)
|
||||
//attempt to shift coins that comes from the same tx AND also attempt to shift coins based on percentage probability
|
||||
var remainingCoins = SlightlyShiftOrder(RandomizeCoins(
|
||||
coins.OrderBy(coin => coin.CoinColor(_wallet)).ThenByDescending(x =>
|
||||
x.EffectiveValue(utxoSelectionParameters.MiningFeeRate,
|
||||
utxoSelectionParameters.CoordinationFeeRate))
|
||||
x.EffectiveValue(utxoSelectionParameters.MiningFeeRate))
|
||||
.ToList(), liquidityClue), 10);
|
||||
var remainingPendingPayments = new List<PendingPayment>(pendingPayments);
|
||||
var solution = new SubsetSolution(remainingPendingPayments.Count, _wallet,
|
||||
@@ -487,8 +485,7 @@ public class SubsetSolution
|
||||
public List<SmartCoin> Coins { get; set; } = new();
|
||||
public List<PendingPayment> HandledPayments { get; set; } = new();
|
||||
|
||||
public decimal TotalValue => Coins.Sum(coin =>
|
||||
coin.EffectiveValue(_utxoSelectionParameters.MiningFeeRate, _utxoSelectionParameters.CoordinationFeeRate)
|
||||
public decimal TotalValue => Coins.Sum(coin => coin.EffectiveValue(_utxoSelectionParameters.MiningFeeRate)
|
||||
.ToDecimal(MoneyUnit.BTC));
|
||||
|
||||
public Dictionary<AnonsetType, SmartCoin[]> SortedCoins =>
|
||||
|
||||
@@ -13,7 +13,7 @@
|
||||
<PropertyGroup>
|
||||
<Product>Coinjoin</Product>
|
||||
<Description>Allows you to integrate your btcpayserver store with coinjoins.</Description>
|
||||
<Version>1.0.92</Version>
|
||||
<Version>1.0.93</Version>
|
||||
<CopyLocalLockFileAssemblies>true</CopyLocalLockFileAssemblies>
|
||||
</PropertyGroup>
|
||||
|
||||
|
||||
@@ -4,6 +4,7 @@ using System.IO;
|
||||
using System.Threading.Tasks;
|
||||
using BTCPayServer.Services;
|
||||
using Microsoft.Extensions.Logging;
|
||||
using NBitcoin;
|
||||
using Newtonsoft.Json;
|
||||
using NLog;
|
||||
using WalletWasabi.WabiSabi.Client.Banning;
|
||||
@@ -17,7 +18,8 @@ public class SettingsCoinPrison : CoinPrison
|
||||
private readonly SettingsRepository _settingsRepository;
|
||||
private readonly string _coordinatorName;
|
||||
|
||||
public SettingsCoinPrison(SettingsRepository settingsRepository, string coordinatorName) : base(null)
|
||||
public SettingsCoinPrison(SettingsRepository settingsRepository, string coordinatorName,
|
||||
Dictionary<OutPoint, PrisonedCoinRecord> bannedCoins) : base(null, bannedCoins)
|
||||
{
|
||||
_settingsRepository = settingsRepository;
|
||||
_coordinatorName = coordinatorName;
|
||||
@@ -25,29 +27,30 @@ public class SettingsCoinPrison : CoinPrison
|
||||
|
||||
protected override void ToFile()
|
||||
{
|
||||
var json = JsonConvert.SerializeObject(BannedCoins, Formatting.Indented);
|
||||
var json = JsonConvert.SerializeObject(_bannedCoins, Formatting.Indented);
|
||||
_settingsRepository.UpdateSetting(json, "wabisabi_" + _coordinatorName + "_bannedcoins").GetAwaiter().GetResult();
|
||||
}
|
||||
|
||||
public static async Task<SettingsCoinPrison> CreateFromCoordinatorName(SettingsRepository settingsRepository,
|
||||
string coordinatorName, ILogger logger)
|
||||
{
|
||||
HashSet<PrisonedCoinRecord> prisonedCoinRecords = new();
|
||||
Dictionary<OutPoint, PrisonedCoinRecord> prisonedCoinRecords = new();
|
||||
try
|
||||
{
|
||||
var data = await settingsRepository.GetSettingAsync<string>("wabisabi_" + coordinatorName + "_bannedcoins");
|
||||
if (string.IsNullOrWhiteSpace(data))
|
||||
{
|
||||
logger.LogDebug("Prisoned coins file is empty.");
|
||||
return new(settingsRepository, coordinatorName);
|
||||
return new(settingsRepository, coordinatorName, new());
|
||||
}
|
||||
prisonedCoinRecords = JsonConvert.DeserializeObject<HashSet<PrisonedCoinRecord>>(data)
|
||||
prisonedCoinRecords = JsonConvert.DeserializeObject<Dictionary<OutPoint, PrisonedCoinRecord>>(data)
|
||||
?? throw new InvalidDataException("Prisoned coins file is corrupted.");
|
||||
}
|
||||
catch (Exception exc)
|
||||
{
|
||||
logger.LogError($"There was an error during loading {nameof(SettingsCoinPrison)}. Ignoring corrupt data.", exc);
|
||||
}
|
||||
return new(settingsRepository, coordinatorName){ BannedCoins = prisonedCoinRecords };
|
||||
|
||||
return new(settingsRepository, coordinatorName, prisonedCoinRecords);
|
||||
}
|
||||
}
|
||||
@@ -416,7 +416,7 @@ updateInProgressAnimation(myChart);
|
||||
@{
|
||||
if (coordinator.CoinPrison is not null)
|
||||
{
|
||||
var bannedCoins = coins.Where(coin => coordinator.CoinPrison.TryGetOrRemoveBannedCoin(coin, out _));
|
||||
var bannedCoins = coins.Where(coin => coordinator.CoinPrison.IsBanned(coin.Outpoint)).ToArray();
|
||||
@if (bannedCoins.Any())
|
||||
{
|
||||
<div class="text-muted">@bannedCoins.Count() banned coins(for disrupting rounds)</div>
|
||||
|
||||
@@ -1,11 +1,5 @@
|
||||
@using BTCPayServer.Plugins.Wabisabi
|
||||
@using BTCPayServer.Abstractions.Extensions
|
||||
@using BTCPayServer.Abstractions.Contracts
|
||||
@using BTCPayServer.Security
|
||||
@using NBitcoin
|
||||
@using System.Security.Claims
|
||||
@using BTCPayServer
|
||||
@using BTCPayServer.Common
|
||||
@model WabisabiStoreController.SpendViewModel
|
||||
@inject IScopeProvider _scopeProvider
|
||||
@inject WalletProvider WalletProvider
|
||||
|
||||
Reference in New Issue
Block a user