mirror of
https://github.com/boldsuck/haveno.git
synced 2025-01-05 07:39:22 +00:00
prefer local price provider, preserve provider when banned nodes applied
This commit is contained in:
parent
0d82f8827f
commit
8f5e56b9dc
1 changed files with 24 additions and 10 deletions
|
@ -37,6 +37,7 @@ package haveno.core.provider;
|
||||||
import com.google.inject.Inject;
|
import com.google.inject.Inject;
|
||||||
import com.google.inject.name.Named;
|
import com.google.inject.name.Named;
|
||||||
import haveno.common.config.Config;
|
import haveno.common.config.Config;
|
||||||
|
import java.util.ArrayList;
|
||||||
import java.util.Arrays;
|
import java.util.Arrays;
|
||||||
import java.util.Collections;
|
import java.util.Collections;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
@ -47,6 +48,8 @@ import lombok.extern.slf4j.Slf4j;
|
||||||
|
|
||||||
@Slf4j
|
@Slf4j
|
||||||
public class ProvidersRepository {
|
public class ProvidersRepository {
|
||||||
|
|
||||||
|
private static final String DEFAULT_LOCAL_NODE = "http://localhost:8078/";
|
||||||
private static final List<String> DEFAULT_NODES = Arrays.asList(
|
private static final List<String> DEFAULT_NODES = Arrays.asList(
|
||||||
"http://elaxlgigphpicy5q7pi5wkz2ko2vgjbq4576vic7febmx4xcxvk6deqd.onion/", // Haveno
|
"http://elaxlgigphpicy5q7pi5wkz2ko2vgjbq4576vic7febmx4xcxvk6deqd.onion/", // Haveno
|
||||||
"http://lrrgpezvdrbpoqvkavzobmj7dr2otxc5x6wgktrw337bk6mxsvfp5yid.onion/" // Cake
|
"http://lrrgpezvdrbpoqvkavzobmj7dr2otxc5x6wgktrw337bk6mxsvfp5yid.onion/" // Cake
|
||||||
|
@ -78,19 +81,22 @@ public class ProvidersRepository {
|
||||||
this.providersFromProgramArgs = providers;
|
this.providersFromProgramArgs = providers;
|
||||||
this.useLocalhostForP2P = useLocalhostForP2P;
|
this.useLocalhostForP2P = useLocalhostForP2P;
|
||||||
|
|
||||||
Collections.shuffle(DEFAULT_NODES);
|
Collections.shuffle(DEFAULT_NODES); // randomize order of default nodes
|
||||||
|
|
||||||
applyBannedNodes(config.bannedPriceRelayNodes);
|
applyBannedNodes(config.bannedPriceRelayNodes);
|
||||||
}
|
}
|
||||||
|
|
||||||
public void applyBannedNodes(@Nullable List<String> bannedNodes) {
|
public void applyBannedNodes(@Nullable List<String> bannedNodes) {
|
||||||
this.bannedNodes = bannedNodes;
|
this.bannedNodes = bannedNodes;
|
||||||
|
|
||||||
|
// fill provider list
|
||||||
fillProviderList();
|
fillProviderList();
|
||||||
selectNextProviderBaseUrl();
|
|
||||||
|
// select next provider if current provider is null or banned
|
||||||
|
if (baseUrl == null || isBanned(baseUrl)) selectNextProviderBaseUrl();
|
||||||
|
|
||||||
if (bannedNodes != null && !bannedNodes.isEmpty()) {
|
if (bannedNodes != null && !bannedNodes.isEmpty()) {
|
||||||
log.info("Excluded provider nodes from filter: nodes={}, selected provider baseUrl={}, providerList={}",
|
log.info("Excluded provider nodes from filter: nodes={}, selected provider baseUrl={}, providerList={}", bannedNodes, baseUrl, providerList);
|
||||||
bannedNodes, baseUrl, providerList);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -129,22 +135,30 @@ public class ProvidersRepository {
|
||||||
// If we run in localhost mode we don't have the tor node running, so we need a clearnet host
|
// If we run in localhost mode we don't have the tor node running, so we need a clearnet host
|
||||||
// Use localhost for using a locally running provider
|
// Use localhost for using a locally running provider
|
||||||
providers = List.of(
|
providers = List.of(
|
||||||
"http://localhost:8078/",
|
DEFAULT_LOCAL_NODE,
|
||||||
"https://price.haveno.network/",
|
"https://price.haveno.network/",
|
||||||
"http://173.230.142.36:8078/");
|
"http://173.230.142.36:8078/");
|
||||||
} else {
|
} else {
|
||||||
providers = DEFAULT_NODES;
|
providers = new ArrayList<String>();
|
||||||
|
providers.add(DEFAULT_LOCAL_NODE); // try local provider first
|
||||||
|
providers.addAll(DEFAULT_NODES);
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
providers = providersFromProgramArgs;
|
providers = providersFromProgramArgs;
|
||||||
}
|
}
|
||||||
providerList = providers.stream()
|
providerList = providers.stream()
|
||||||
.filter(e -> bannedNodes == null ||
|
.filter(e -> !isBanned(e))
|
||||||
!bannedNodes.contains(e.replace("http://", "")
|
|
||||||
.replace("/", "")
|
|
||||||
.replace(".onion", "")))
|
|
||||||
.map(e -> e.endsWith("/") ? e : e + "/")
|
.map(e -> e.endsWith("/") ? e : e + "/")
|
||||||
.map(e -> e.startsWith("http") ? e : "http://" + e)
|
.map(e -> e.startsWith("http") ? e : "http://" + e)
|
||||||
.collect(Collectors.toList());
|
.collect(Collectors.toList());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private boolean isBanned(String provider) {
|
||||||
|
if (bannedNodes == null) return false;
|
||||||
|
return bannedNodes.stream()
|
||||||
|
.anyMatch(e -> provider.replace("http://", "")
|
||||||
|
.replace("/", "")
|
||||||
|
.replace(".onion", "")
|
||||||
|
.equals(e));
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue