Upgrade XChange 5.0.13, remove BitBay CoinPaprika add CoinbasePro.

This commit is contained in:
jmacxx 2022-05-30 21:38:28 -05:00
parent ad15fcd5c4
commit 1c9aff0f21
No known key found for this signature in database
GPG Key ID: 155297BABFE94A1B
5 changed files with 16 additions and 149 deletions

View File

@ -62,7 +62,7 @@ configure(subprojects) {
junitVersion = '4.12' junitVersion = '4.12'
jupiterVersion = '5.7.0' jupiterVersion = '5.7.0'
kotlinVersion = '1.3.41' kotlinVersion = '1.3.41'
knowmXchangeVersion = '4.4.2' knowmXchangeVersion = '5.0.13'
langVersion = '3.11' langVersion = '3.11'
logbackVersion = '1.1.11' logbackVersion = '1.1.11'
loggingVersion = '1.2' loggingVersion = '1.2'
@ -606,6 +606,7 @@ configure(project(':pricenode')) {
implementation("org.knowm.xchange:xchange-bitstamp:$knowmXchangeVersion") implementation("org.knowm.xchange:xchange-bitstamp:$knowmXchangeVersion")
implementation("org.knowm.xchange:xchange-btcmarkets:$knowmXchangeVersion") implementation("org.knowm.xchange:xchange-btcmarkets:$knowmXchangeVersion")
implementation("org.knowm.xchange:xchange-cexio:$knowmXchangeVersion") implementation("org.knowm.xchange:xchange-cexio:$knowmXchangeVersion")
implementation("org.knowm.xchange:xchange-coinbasepro:$knowmXchangeVersion")
implementation("org.knowm.xchange:xchange-coinmarketcap:$knowmXchangeVersion") implementation("org.knowm.xchange:xchange-coinmarketcap:$knowmXchangeVersion")
implementation("org.knowm.xchange:xchange-coinmate:$knowmXchangeVersion") implementation("org.knowm.xchange:xchange-coinmate:$knowmXchangeVersion")
implementation("org.knowm.xchange:xchange-coinone:$knowmXchangeVersion") implementation("org.knowm.xchange:xchange-coinone:$knowmXchangeVersion")

View File

@ -14,13 +14,12 @@
* You should have received a copy of the GNU Affero General Public License * You should have received a copy of the GNU Affero General Public License
* along with Bisq. If not, see <http://www.gnu.org/licenses/>. * along with Bisq. If not, see <http://www.gnu.org/licenses/>.
*/ */
package bisq.price.spot.providers; package bisq.price.spot.providers;
import bisq.price.spot.ExchangeRate; import bisq.price.spot.ExchangeRate;
import bisq.price.spot.ExchangeRateProvider; import bisq.price.spot.ExchangeRateProvider;
import org.knowm.xchange.bitbay.BitbayExchange; import org.knowm.xchange.coinbasepro.CoinbaseProExchange;
import org.springframework.core.env.Environment; import org.springframework.core.env.Environment;
import org.springframework.stereotype.Component; import org.springframework.stereotype.Component;
@ -30,16 +29,21 @@ import java.time.Duration;
import java.util.Set; import java.util.Set;
@Component @Component
class Bitbay extends ExchangeRateProvider { class CoinbasePro extends ExchangeRateProvider {
public Bitbay(Environment env) { public CoinbasePro(Environment env) {
super(env, "BITBAY", "bitbay", Duration.ofMinutes(1)); super(env, "COINBASEPRO", "coinbasepro", Duration.ofMinutes(1));
} }
@Override @Override
public Set<ExchangeRate> doGet() { public Set<ExchangeRate> doGet() {
// Supported fiat: EUR, GBP, PLN, USD // Supported fiat: EUR, USD, GBP
// Supported alts: DASH, ETH, LTC // Supported alts: DASH, DOGE, ETC, ETH, LTC, ZEC, ZEN
return doGet(BitbayExchange.class); return doGet(CoinbaseProExchange.class);
}
@Override
protected boolean requiresFilterDuringBulkTickerRetrieval() {
return true;
} }
} }

View File

@ -1,102 +0,0 @@
/*
* This file is part of Bisq.
*
* Bisq is free software: you can redistribute it and/or modify it
* under the terms of the GNU Affero General Public License as published by
* the Free Software Foundation, either version 3 of the License, or (at
* your option) any later version.
*
* Bisq is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU Affero General Public
* License for more details.
*
* You should have received a copy of the GNU Affero General Public License
* along with Bisq. If not, see <http://www.gnu.org/licenses/>.
*/
package bisq.price.spot.providers;
import bisq.price.spot.ExchangeRate;
import bisq.price.spot.ExchangeRateProvider;
import bisq.price.util.coinpaprika.CoinpaprikaMarketData;
import org.springframework.core.ParameterizedTypeReference;
import org.springframework.core.env.Environment;
import org.springframework.http.RequestEntity;
import org.springframework.stereotype.Component;
import org.springframework.web.client.RestTemplate;
import org.springframework.web.util.UriComponentsBuilder;
import java.time.Duration;
import java.util.Date;
import java.util.HashSet;
import java.util.Map;
import java.util.Set;
import java.util.function.Predicate;
import java.util.stream.Collectors;
@Component
class Coinpaprika extends ExchangeRateProvider {
private final RestTemplate restTemplate = new RestTemplate();
/**
* Used to determine the currencies in which the BTC price can be quoted. There seems
* to be no programatic way to retrieve it, so we get the value from the API
* documentation (see "quotes" param decsribed at
* https://api.coinpaprika.com/#operation/getTickersById ). The hardcoded value below
* is the list of allowed values as per the API documentation, but without BTC and ETH
* as it makes no sense to quote the BTC price in them.
*/
private final static String SUPPORTED_CURRENCIES =
("USD, EUR, PLN, KRW, GBP, CAD, JPY, RUB, TRY, NZD, AUD, CHF, UAH, HKD, " +
"SGD, NGN, PHP, MXN, BRL, THB, CLP, CNY, CZK, DKK, HUF, IDR, ILS," +
"INR, MYR, NOK, PKR, SEK, TWD, ZAR, VND, BOB, COP, PEN, ARS, ISK")
.replace(" ", ""); // Strip any spaces
public Coinpaprika(Environment env) {
super(env, "COINPAPRIKA", "coinpaprika", Duration.ofMinutes(1));
}
@Override
public Set<ExchangeRate> doGet() {
// Single IP address can send less than 10 requests per second
// We make only 1 API call per provider poll, so we're not at risk of reaching it
Set<ExchangeRate> result = new HashSet<ExchangeRate>();
Predicate<Map.Entry> isDesiredFiatPair = t -> getSupportedFiatCurrencies().contains(t.getKey());
getMarketData().getQuotes().entrySet().stream()
.filter(isDesiredFiatPair)
.collect(Collectors.toMap(Map.Entry::getKey, Map.Entry::getValue))
.forEach((key, ticker) -> {
result.add(new ExchangeRate(
key,
ticker.getPrice(),
new Date(),
this.getName()
));
});
return result;
}
private CoinpaprikaMarketData getMarketData() {
return restTemplate.exchange(
RequestEntity
.get(UriComponentsBuilder
.fromUriString(
"https://api.coinpaprika.com/v1/tickers/btc-bitcoin?quotes=" +
SUPPORTED_CURRENCIES).build()
.toUri())
.build(),
new ParameterizedTypeReference<CoinpaprikaMarketData>() {
}
).getBody();
}
}

View File

@ -1,36 +0,0 @@
/*
* This file is part of Bisq.
*
* Bisq is free software: you can redistribute it and/or modify it
* under the terms of the GNU Affero General Public License as published by
* the Free Software Foundation, either version 3 of the License, or (at
* your option) any later version.
*
* Bisq is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU Affero General Public
* License for more details.
*
* You should have received a copy of the GNU Affero General Public License
* along with Bisq. If not, see <http://www.gnu.org/licenses/>.
*/
package bisq.price.spot.providers;
import bisq.price.AbstractExchangeRateProviderTest;
import org.springframework.core.env.StandardEnvironment;
import lombok.extern.slf4j.Slf4j;
import org.junit.jupiter.api.Test;
@Slf4j
public class BitbayTest extends AbstractExchangeRateProviderTest {
@Test
public void doGet_successfulCall() {
doGet_successfulCall(new Bitbay(new StandardEnvironment()));
}
}

View File

@ -26,11 +26,11 @@ import lombok.extern.slf4j.Slf4j;
import org.junit.jupiter.api.Test; import org.junit.jupiter.api.Test;
@Slf4j @Slf4j
public class CoinpaprikaTest extends AbstractExchangeRateProviderTest { public class CoinbaseProTest extends AbstractExchangeRateProviderTest {
@Test @Test
public void doGet_successfulCall() { public void doGet_successfulCall() {
doGet_successfulCall(new Coinpaprika(new StandardEnvironment())); doGet_successfulCall(new CoinbasePro(new StandardEnvironment()));
} }
} }