From 61d730abf9208408847c48c929f4eedce0bd2119 Mon Sep 17 00:00:00 2001 From: Jelle Besseling Date: Tue, 25 Aug 2020 20:16:52 +0200 Subject: [PATCH] Add Tether token support via ERC20 and Omni --- .../bisq/asset/LiquidBitcoinAddressValidator.java | 12 ++++++++++++ .../main/java/bisq/asset/coins/LiquidBitcoin.java | 3 ++- .../main/java/bisq/asset/coins/TetherUSDLiquid.java | 12 ++++++++++++ .../main/java/bisq/asset/coins/TetherUSDOmni.java | 12 ++++++++++++ .../main/java/bisq/asset/tokens/TetherUSDERC20.java | 11 +++++++++++ .../resources/META-INF/services/bisq.asset.Asset | 3 +++ .../java/bisq/core/provider/price/PriceProvider.java | 11 ++++++++++- .../src/main/java/bisq/desktop/main/MainView.java | 3 +-- 8 files changed, 63 insertions(+), 4 deletions(-) create mode 100644 assets/src/main/java/bisq/asset/LiquidBitcoinAddressValidator.java create mode 100644 assets/src/main/java/bisq/asset/coins/TetherUSDLiquid.java create mode 100644 assets/src/main/java/bisq/asset/coins/TetherUSDOmni.java create mode 100644 assets/src/main/java/bisq/asset/tokens/TetherUSDERC20.java diff --git a/assets/src/main/java/bisq/asset/LiquidBitcoinAddressValidator.java b/assets/src/main/java/bisq/asset/LiquidBitcoinAddressValidator.java new file mode 100644 index 00000000000..b8861bb1084 --- /dev/null +++ b/assets/src/main/java/bisq/asset/LiquidBitcoinAddressValidator.java @@ -0,0 +1,12 @@ +package bisq.asset; + +public class LiquidBitcoinAddressValidator extends RegexAddressValidator { + static private final String REGEX = "^([a-km-zA-HJ-NP-Z1-9]{26,35}|[a-km-zA-HJ-NP-Z1-9]{80}|[a-z]{2,5}1[ac-hj-np-z02-9]{8,87}|[A-Z]{2,5}1[AC-HJ-NP-Z02-9]{8,87})$"; + public LiquidBitcoinAddressValidator() { + super(REGEX); + } + + public LiquidBitcoinAddressValidator(String regex, String errorMessageI18nKey) { + super(REGEX, "validation.altcoin.liquidBitcoin.invalidAddress"); + } +} diff --git a/assets/src/main/java/bisq/asset/coins/LiquidBitcoin.java b/assets/src/main/java/bisq/asset/coins/LiquidBitcoin.java index 6d773509949..3c0be367b06 100644 --- a/assets/src/main/java/bisq/asset/coins/LiquidBitcoin.java +++ b/assets/src/main/java/bisq/asset/coins/LiquidBitcoin.java @@ -19,12 +19,13 @@ import bisq.asset.AltCoinAccountDisclaimer; import bisq.asset.Coin; +import bisq.asset.LiquidBitcoinAddressValidator; import bisq.asset.RegexAddressValidator; @AltCoinAccountDisclaimer("account.altcoin.popup.liquidbitcoin.msg") public class LiquidBitcoin extends Coin { public LiquidBitcoin() { - super("Liquid Bitcoin", "L-BTC", new RegexAddressValidator("^([a-km-zA-HJ-NP-Z1-9]{26,35}|[a-km-zA-HJ-NP-Z1-9]{80}|[a-z]{2,5}1[ac-hj-np-z02-9]{8,87}|[A-Z]{2,5}1[AC-HJ-NP-Z02-9]{8,87})$", "validation.altcoin.liquidBitcoin.invalidAddress")); + super("Liquid Bitcoin", "L-BTC", new LiquidBitcoinAddressValidator()); } } diff --git a/assets/src/main/java/bisq/asset/coins/TetherUSDLiquid.java b/assets/src/main/java/bisq/asset/coins/TetherUSDLiquid.java new file mode 100644 index 00000000000..b5b50a8ad14 --- /dev/null +++ b/assets/src/main/java/bisq/asset/coins/TetherUSDLiquid.java @@ -0,0 +1,12 @@ +package bisq.asset.coins; + +import bisq.asset.Coin; +import bisq.asset.LiquidBitcoinAddressValidator; + +public class TetherUSDLiquid extends Coin { + public TetherUSDLiquid() { + // If you add a new USDT variant or want to change this ticker symbol you should also look here: + // core/src/main/java/bisq/core/provider/price/PriceProvider.java:getAll() + super("Tether USD (Liquid Bitcoin)", "L-USDT", new LiquidBitcoinAddressValidator()); + } +} diff --git a/assets/src/main/java/bisq/asset/coins/TetherUSDOmni.java b/assets/src/main/java/bisq/asset/coins/TetherUSDOmni.java new file mode 100644 index 00000000000..b0ab624d713 --- /dev/null +++ b/assets/src/main/java/bisq/asset/coins/TetherUSDOmni.java @@ -0,0 +1,12 @@ +package bisq.asset.coins; + +import bisq.asset.Base58BitcoinAddressValidator; +import bisq.asset.Coin; + +public class TetherUSDOmni extends Coin { + public TetherUSDOmni() { + // If you add a new USDT variant or want to change this ticker symbol you should also look here: + // core/src/main/java/bisq/core/provider/price/PriceProvider.java:getAll() + super("Tether USD (Omni)", "USDT-O", new Base58BitcoinAddressValidator()); + } +} diff --git a/assets/src/main/java/bisq/asset/tokens/TetherUSDERC20.java b/assets/src/main/java/bisq/asset/tokens/TetherUSDERC20.java new file mode 100644 index 00000000000..cb57361a1f4 --- /dev/null +++ b/assets/src/main/java/bisq/asset/tokens/TetherUSDERC20.java @@ -0,0 +1,11 @@ +package bisq.asset.tokens; + +import bisq.asset.Erc20Token; + +public class TetherUSDERC20 extends Erc20Token { + public TetherUSDERC20() { + // If you add a new USDT variant or want to change this ticker symbol you should also look here: + // core/src/main/java/bisq/core/provider/price/PriceProvider.java:getAll() + super("Tether USD (ERC20)", "USDT-E"); + } +} diff --git a/assets/src/main/resources/META-INF/services/bisq.asset.Asset b/assets/src/main/resources/META-INF/services/bisq.asset.Asset index 80a6168463b..a2f77816d66 100644 --- a/assets/src/main/resources/META-INF/services/bisq.asset.Asset +++ b/assets/src/main/resources/META-INF/services/bisq.asset.Asset @@ -104,6 +104,8 @@ bisq.asset.coins.Spectrecoin bisq.asset.coins.Starwels bisq.asset.coins.SUB1X bisq.asset.coins.TEO +bisq.asset.coins.TetherUSDLiquid +bisq.asset.coins.TetherUSDOmni bisq.asset.coins.TurtleCoin bisq.asset.coins.UnitedCommunityCoin bisq.asset.coins.Unobtanium @@ -123,6 +125,7 @@ bisq.asset.coins.ZeroClassic bisq.asset.tokens.AugmintEuro bisq.asset.tokens.DaiStablecoin bisq.asset.tokens.EtherStone +bisq.asset.tokens.TetherUSDERC20 bisq.asset.tokens.TrueUSD bisq.asset.tokens.USDCoin bisq.asset.tokens.VectorspaceAI diff --git a/core/src/main/java/bisq/core/provider/price/PriceProvider.java b/core/src/main/java/bisq/core/provider/price/PriceProvider.java index d0ac27c2d72..184be90435f 100644 --- a/core/src/main/java/bisq/core/provider/price/PriceProvider.java +++ b/core/src/main/java/bisq/core/provider/price/PriceProvider.java @@ -70,7 +70,12 @@ public Tuple2, Map> getAll() throws IOExc final double price = (Double) treeMap.get("price"); // json uses double for our timestampSec long value... final long timestampSec = MathUtils.doubleToLong((Double) treeMap.get("timestampSec")); - marketPriceMap.put(currencyCode, new MarketPrice(currencyCode, price, timestampSec, true)); + if (currencyCode.equals("USDT")) { + addPrice(marketPriceMap, "USDT-O", price, timestampSec); + addPrice(marketPriceMap, "USDT-E", price, timestampSec); + addPrice(marketPriceMap, "L-USDT", price, timestampSec); + } + addPrice(marketPriceMap, currencyCode, price, timestampSec); } catch (Throwable t) { log.error(t.toString()); t.printStackTrace(); @@ -80,6 +85,10 @@ public Tuple2, Map> getAll() throws IOExc return new Tuple2<>(tsMap, marketPriceMap); } + private void addPrice(Map marketPriceMap, String currencyCode, double price, long timestampSec) { + marketPriceMap.put(currencyCode, new MarketPrice(currencyCode, price, timestampSec, true)); + } + public String getBaseUrl() { return httpClient.getBaseUrl(); } diff --git a/desktop/src/main/java/bisq/desktop/main/MainView.java b/desktop/src/main/java/bisq/desktop/main/MainView.java index 981c819ea28..cca1f6c1642 100644 --- a/desktop/src/main/java/bisq/desktop/main/MainView.java +++ b/desktop/src/main/java/bisq/desktop/main/MainView.java @@ -534,11 +534,10 @@ private String getPriceProviderTooltipString() { String selectedCurrencyCode = model.getPriceFeedService().getCurrencyCode(); MarketPrice selectedMarketPrice = model.getPriceFeedService().getMarketPrice(selectedCurrencyCode); - return Res.get("mainView.marketPrice.tooltip", "Bisq Price Index for " + selectedCurrencyCode, "", - DisplayUtils.formatTime(new Date(selectedMarketPrice.getTimestampSec())), + selectedMarketPrice != null ? DisplayUtils.formatTime(new Date(selectedMarketPrice.getTimestampSec())) : Res.get("shared.na"), model.getPriceFeedService().getProviderNodeAddress()); }