Skip to content

Commit

Permalink
feat(rpc): runtime addcurrency for lnd & connext
Browse files Browse the repository at this point in the history
This PR allows for adding Connext and Lnd currencies via the
`AddCurrency` rpc call and have them available for trading immediately
without requiring a restart of xud.

In the case of Connext it merely registers the tokenaddress and currency
symbol for the new currency with the existing ConnextClient, as we had
previously done with Raiden.

In the case of Lnd, we read from the configuration and use that to
instantiate and initialize a new `LndClient` for the specified currency.

Closes #1111.
  • Loading branch information
sangaman committed Jul 24, 2020
1 parent 86ed586 commit 3dd595e
Show file tree
Hide file tree
Showing 2 changed files with 33 additions and 19 deletions.
11 changes: 6 additions & 5 deletions lib/orderbook/OrderBook.ts
Original file line number Diff line number Diff line change
Expand Up @@ -18,7 +18,7 @@ import OrderBookRepository from './OrderBookRepository';
import TradingPair from './TradingPair';
import {
IncomingOrder, isOwnOrder, Order, OrderBookThresholds, OrderIdentifier, OrderPortion, OutgoingOrder, OwnLimitOrder, OwnMarketOrder,
OwnOrder, Pair, PeerOrder, PlaceOrderEvent, PlaceOrderEventType, PlaceOrderResult,
OwnOrder, Pair, PeerOrder, PlaceOrderEvent, PlaceOrderEventType, PlaceOrderResult
} from './types';

interface OrderBook {
Expand Down Expand Up @@ -290,12 +290,13 @@ class OrderBook extends EventEmitter {
if (this.currencyInstances.has(currency.id)) {
throw errors.CURRENCY_ALREADY_EXISTS(currency.id);
}
if (currency.swapClient === SwapClientType.Raiden && !currency.tokenAddress) {
if ((currency.swapClient === SwapClientType.Raiden || currency.swapClient === SwapClientType.Connext)
&& !currency.tokenAddress) {
throw errors.CURRENCY_MISSING_ETHEREUM_CONTRACT_ADDRESS(currency.id);
}
const currencyInstance = await this.repository.addCurrency({ ...currency, decimalPlaces: currency.decimalPlaces || 8 });
this.currencyInstances.set(currencyInstance.id, currencyInstance);
this.swaps.swapClientManager.add(currencyInstance);
await this.swaps.swapClientManager.add(currencyInstance);
}

public removeCurrency = async (currencyId: string) => {
Expand Down Expand Up @@ -968,8 +969,8 @@ class OrderBook extends EventEmitter {
try {
const removeResult = this.removePeerOrder(oi.id, oi.pairId, peerPubKey, oi.quantity);
this.emit('peerOrder.invalidation', removeResult.order);
} catch {
this.logger.error(`failed to remove order (${oi.id}) of peer ${peerPubKey} (${pubKeyToAlias(peerPubKey)})`);
} catch (err) {
this.logger.error(`failed to remove order (${oi.id}) of peer ${peerPubKey} (${pubKeyToAlias(peerPubKey)})`, err);
// TODO: Penalize peer
}
}
Expand Down
41 changes: 27 additions & 14 deletions lib/swaps/SwapClientManager.ts
Original file line number Diff line number Diff line change
Expand Up @@ -330,25 +330,38 @@ class SwapClientManager extends EventEmitter {
* @param currency a currency that should be linked with a swap client.
* @returns Nothing upon success, throws otherwise.
*/
public add = (currency: Currency): void => {
if (currency.swapClient === SwapClientType.Raiden && currency.tokenAddress && this.raidenClient) {
this.swapClients.set(currency.id, this.raidenClient);
this.raidenClient.tokenAddresses.set(currency.id, currency.tokenAddress);
this.emit('raidenUpdate', this.raidenClient.tokenAddresses, this.raidenClient.address);
public add = async (currency: Currency) => {
if (currency.tokenAddress) {
if (currency.swapClient === SwapClientType.Connext) {
if (!this.connextClient) {
throw errors.SWAP_CLIENT_NOT_CONFIGURED(currency.id);
}
this.swapClients.set(currency.id, this.connextClient);
this.connextClient.tokenAddresses.set(currency.id, currency.tokenAddress);
this.emit('connextUpdate', this.connextClient.tokenAddresses, this.connextClient.address);
} else if (currency.swapClient === SwapClientType.Raiden) {
if (!this.raidenClient) {
throw errors.SWAP_CLIENT_NOT_CONFIGURED(currency.id);
}
this.swapClients.set(currency.id, this.raidenClient);
this.raidenClient.tokenAddresses.set(currency.id, currency.tokenAddress);
this.emit('raidenUpdate', this.raidenClient.tokenAddresses, this.raidenClient.address);
}
} else if (currency.swapClient === SwapClientType.Lnd) {
// in case of lnd we check if the configuration includes swap client
// for the specified currency
let isCurrencyConfigured = false;
for (const lndCurrency in this.config.lnd) {
if (lndCurrency === currency.id) {
isCurrencyConfigured = true;
break;
}
}
// adding a new lnd client at runtime is currently not supported
if (!isCurrencyConfigured) {
const config = this.config.lnd[currency.id];
if (!config) {
throw errors.SWAP_CLIENT_NOT_CONFIGURED(currency.id);
}

const lndClient = new LndClient({
config,
logger: this.loggers.lnd.createSubLogger(currency.id),
currency: currency.id,
});
this.swapClients.set(currency.id, lndClient);
await lndClient.init();
}
}

Expand Down

0 comments on commit 3dd595e

Please sign in to comment.