|
@ -528,7 +528,7 @@ public class ElectrumServer { |
|
|
|
|
|
|
|
|
Map<Integer, Double> targetBlocksFeeRatesSats = new TreeMap<>(); |
|
|
Map<Integer, Double> targetBlocksFeeRatesSats = new TreeMap<>(); |
|
|
for(Integer target : targetBlocksFeeRatesBtcKb.keySet()) { |
|
|
for(Integer target : targetBlocksFeeRatesBtcKb.keySet()) { |
|
|
targetBlocksFeeRatesSats.put(target, targetBlocksFeeRatesBtcKb.get(target) * Transaction.SATOSHIS_PER_BITCOIN / 1024); |
|
|
targetBlocksFeeRatesSats.put(target, targetBlocksFeeRatesBtcKb.get(target) * Transaction.SATOSHIS_PER_BITCOIN / 1000); |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
return targetBlocksFeeRatesSats; |
|
|
return targetBlocksFeeRatesSats; |
|
@ -537,6 +537,16 @@ public class ElectrumServer { |
|
|
} |
|
|
} |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
public Double getMinimumRelayFee() throws ServerException { |
|
|
|
|
|
Double minFeeRateBtcKb = electrumServerRpc.getMinimumRelayFee(getTransport()); |
|
|
|
|
|
if(minFeeRateBtcKb != null) { |
|
|
|
|
|
long minFeeRateSatsKb = (long)(minFeeRateBtcKb * Transaction.SATOSHIS_PER_BITCOIN); |
|
|
|
|
|
return minFeeRateSatsKb / 1000d; |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
return Transaction.DEFAULT_MIN_RELAY_FEE; |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
public Sha256Hash broadcastTransaction(Transaction transaction) throws ServerException { |
|
|
public Sha256Hash broadcastTransaction(Transaction transaction) throws ServerException { |
|
|
byte[] rawtxBytes = transaction.bitcoinSerialize(); |
|
|
byte[] rawtxBytes = transaction.bitcoinSerialize(); |
|
|
String rawtxHex = Utils.bytesToHex(rawtxBytes); |
|
|
String rawtxHex = Utils.bytesToHex(rawtxBytes); |
|
@ -667,7 +677,12 @@ public class ElectrumServer { |
|
|
Map<Integer, Double> blockTargetFeeRates = electrumServer.getFeeEstimates(SendController.TARGET_BLOCKS_RANGE); |
|
|
Map<Integer, Double> blockTargetFeeRates = electrumServer.getFeeEstimates(SendController.TARGET_BLOCKS_RANGE); |
|
|
feeRatesRetrievedAt = System.currentTimeMillis(); |
|
|
feeRatesRetrievedAt = System.currentTimeMillis(); |
|
|
|
|
|
|
|
|
return new ConnectionEvent(serverVersion, banner, tip.height, tip.getBlockHeader(), blockTargetFeeRates); |
|
|
Double minimumRelayFeeRate = electrumServer.getMinimumRelayFee(); |
|
|
|
|
|
for(Integer blockTarget : blockTargetFeeRates.keySet()) { |
|
|
|
|
|
blockTargetFeeRates.computeIfPresent(blockTarget, (blocks, feeRate) -> feeRate < minimumRelayFeeRate ? minimumRelayFeeRate : feeRate); |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
return new ConnectionEvent(serverVersion, banner, tip.height, tip.getBlockHeader(), blockTargetFeeRates, minimumRelayFeeRate); |
|
|
} else { |
|
|
} else { |
|
|
if(reader.isAlive()) { |
|
|
if(reader.isAlive()) { |
|
|
electrumServer.ping(); |
|
|
electrumServer.ping(); |
|
|