randomize completed trade info, fixes #1099
Some checks are pending
CI / build (macos-13) (push) Waiting to run
CI / build (ubuntu-latest) (push) Waiting to run
CI / build (windows-latest) (push) Waiting to run
Codacy Coverage Reporter / Publish coverage (push) Waiting to run
CodeQL / Analyze (java) (push) Waiting to run

This commit is contained in:
fa2a5qj3 2024-07-09 16:58:05 -04:00 committed by woodser
parent 8e3e91c7cc
commit db6cb237bf

View file

@ -54,6 +54,8 @@ import java.util.Date;
import java.util.HashMap;
import java.util.Map;
import java.util.Optional;
import java.util.concurrent.ThreadLocalRandom;
import java.util.concurrent.TimeUnit;
import static com.google.common.base.Preconditions.checkNotNull;
@ -88,13 +90,27 @@ public final class TradeStatistics3 implements ProcessOncePersistableNetworkPayl
Offer offer = checkNotNull(trade.getOffer());
return new TradeStatistics3(offer.getCurrencyCode(),
trade.getPrice().getValue(),
trade.getAmount().longValueExact(),
fuzzTradeAmount(trade.getAmount().longValueExact()),
offer.getPaymentMethod().getId(),
trade.getTakeOfferDate().getTime(),
fuzzTradeDate(trade.getTakeOfferDate().getTime()),
truncatedArbitratorNodeAddress,
extraDataMap);
}
private static long fuzzTradeAmount(long exactAmount) { // randomize completed trade info #1099
long adjustedAmount = (long) ThreadLocalRandom.current().nextDouble(
exactAmount * 0.95, exactAmount * 1.05);
log.info("fuzzed trade amount from {} to {}", exactAmount, adjustedAmount);
return adjustedAmount;
}
private static long fuzzTradeDate(long originalTimestamp) { // randomize completed trade info #1099
long adjustedTimestamp = ThreadLocalRandom.current().nextLong(
originalTimestamp-TimeUnit.HOURS.toMillis(24), originalTimestamp);
log.info("fuzzed trade datestamp from {} to {}", new Date(originalTimestamp), new Date(adjustedTimestamp));
return adjustedTimestamp;
}
// This enum must not change the order as we use the ordinal for storage to reduce data size.
// The payment method string can be quite long and would consume 15% more space.
// When we get a new payment method we can add it to the enum at the end. Old users would add it as string if not