From e29655ec7a1909d869215a4a2313d6f9d3520e1e Mon Sep 17 00:00:00 2001 From: Peter John Bushnell Date: Sat, 2 Nov 2024 01:02:53 +0000 Subject: [PATCH] Add ICX Taker Fee logging (#3108) * Add ICX Taker Fee logging * Rename keys --- src/dfi/consensus/icxorders.cpp | 38 +++++++++++++++++++++++++++------ src/dfi/consensus/icxorders.h | 4 +++- src/dfi/icxorder.cpp | 11 ++++++++-- src/dfi/icxorder.h | 1 + 4 files changed, 44 insertions(+), 10 deletions(-) diff --git a/src/dfi/consensus/icxorders.cpp b/src/dfi/consensus/icxorders.cpp index 6ce5724e33a..f50be7b5ed9 100644 --- a/src/dfi/consensus/icxorders.cpp +++ b/src/dfi/consensus/icxorders.cpp @@ -31,14 +31,29 @@ static CAmount GetDFIperBTC(const CPoolPair &BTCDFIPoolPair) { return DivideAmounts(BTCDFIPoolPair.reserveB, BTCDFIPoolPair.reserveA); } -CAmount CICXOrdersConsensus::CalculateTakerFee(CAmount amount) const { +CAmount CICXOrdersConsensus::CalculateTakerFee(const CAmount amount, + const std::string &txType, + const std::string &txid) const { auto &mnview = blockCtx.GetView(); auto tokenBTC = mnview.GetToken(CICXOrder::TOKEN_BTC); assert(tokenBTC); auto pair = mnview.GetPoolPair(tokenBTC->first, DCT_ID{0}); assert(pair); - return (arith_uint256(amount) * mnview.ICXGetTakerFeePerBTC() / COIN * GetDFIperBTC(pair->second) / COIN) - .GetLow64(); + auto takerFee = + (arith_uint256(amount) * mnview.ICXGetTakerFeePerBTC() / COIN * GetDFIperBTC(pair->second) / COIN).GetLow64(); + if (LogAcceptCategory(BCLog::ICXBUG)) { + UniValue result(UniValue::VOBJ); + result.pushKV("calc_type", txType); + result.pushKV("calc_tx", txid); + result.pushKV("calc_start_amount", GetDecimalString(amount)); + result.pushKV("calc_fee_per_btc", GetDecimalString(mnview.ICXGetTakerFeePerBTC())); + result.pushKV("calc_pool_dfi_per_btc", GetDecimalString(GetDFIperBTC(pair->second))); + result.pushKV("calc_taker_fee_in_btc", + GetDecimalString(((arith_uint256(amount) * mnview.ICXGetTakerFeePerBTC() / COIN).GetLow64()))); + result.pushKV("calc_taker_fee_in_dfi", GetDecimalString(takerFee)); + LogPrint(BCLog::ICXBUG, "%s\n", result.write(0)); + } + return takerFee; } DCT_ID CICXOrdersConsensus::FindTokenByPartialSymbolName(const std::string &symbol) const { @@ -140,7 +155,7 @@ Res CICXOrdersConsensus::operator()(const CICXMakeOfferMessage &obj) const { if (order->orderType == CICXOrder::TYPE_INTERNAL) { // calculating takerFee - makeoffer.takerFee = CalculateTakerFee(makeoffer.amount); + makeoffer.takerFee = CalculateTakerFee(makeoffer.amount, "CICXMakeOfferMessage", tx.GetHash().ToString()); } else if (order->orderType == CICXOrder::TYPE_EXTERNAL) { if (!makeoffer.receivePubkey.IsFullyValid()) { return Res::Err("receivePubkey must be valid pubkey"); @@ -149,7 +164,7 @@ Res CICXOrdersConsensus::operator()(const CICXMakeOfferMessage &obj) const { // calculating takerFee CAmount BTCAmount(static_cast( (arith_uint256(makeoffer.amount) * arith_uint256(COIN) / arith_uint256(order->orderPrice)).GetLow64())); - makeoffer.takerFee = CalculateTakerFee(BTCAmount); + makeoffer.takerFee = CalculateTakerFee(BTCAmount, "CICXMakeOfferMessage", tx.GetHash().ToString()); } // locking takerFee in offer txidaddr @@ -237,7 +252,7 @@ Res CICXOrdersConsensus::operator()(const CICXSubmitDFCHTLCMessage &obj) const { } } else { auto BTCAmount = MultiplyAmounts(submitdfchtlc.amount, order->orderPrice); - takerFee = CalculateTakerFee(BTCAmount); + takerFee = CalculateTakerFee(BTCAmount, "CICXSubmitDFCHTLCMessage", tx.GetHash().ToString()); } // refund the rest of locked takerFee if there is difference @@ -426,7 +441,7 @@ Res CICXOrdersConsensus::operator()(const CICXSubmitEXTHTLCMessage &obj) const { takerFee = (arith_uint256(submitexthtlc.amount) * offer->takerFee / BTCAmount).GetLow64(); } } else { - takerFee = CalculateTakerFee(submitexthtlc.amount); + takerFee = CalculateTakerFee(submitexthtlc.amount, "CICXSubmitEXTHTLCMessage", tx.GetHash().ToString()); } // refund the rest of locked takerFee if there is difference @@ -564,8 +579,17 @@ Res CICXOrdersConsensus::operator()(const CICXClaimDFCHTLCMessage &obj) const { if (ExtractDestination(order->ownerAddress, dest)) { UniValue result(UniValue::VOBJ); result.pushKV("order_tx", order->creationTx.ToString()); + result.pushKV("order_pubkey", HexStr(order->receivePubkey)); result.pushKV("offer_tx", dfchtlc->offerTx.ToString()); + result.pushKV("offer_pubkey", HexStr(offer->receivePubkey)); result.pushKV("dfchtlc_tx", dfchtlc->creationTx.ToString()); + if (exthtlc) { + if (auto extTx = mnview.GetICXSubmitEXTHTLCTXID(dfchtlc->offerTx)) { + result.pushKV("ext_htlc_tx", extTx->ToString()); + } + result.pushKV("ext_htlc_address", exthtlc->htlcscriptAddress); + result.pushKV("ext_htlc_pubkey", HexStr(exthtlc->ownerPubkey)); + } result.pushKV("claim_tx", tx.GetHash().ToString()); result.pushKV("address", EncodeDestination(dest)); result.pushKV("amount", GetDecimalString(offer->takerFee * 50 / 100)); diff --git a/src/dfi/consensus/icxorders.h b/src/dfi/consensus/icxorders.h index 30cb68b65b3..328eb35140c 100644 --- a/src/dfi/consensus/icxorders.h +++ b/src/dfi/consensus/icxorders.h @@ -16,7 +16,9 @@ struct CICXCloseOrderMessage; struct CICXCloseOfferMessage; class CICXOrdersConsensus : public CCustomTxVisitor { - [[nodiscard]] CAmount CalculateTakerFee(CAmount amount) const; + [[nodiscard]] CAmount CalculateTakerFee(const CAmount amount, + const std::string &txType, + const std::string &txid) const; [[nodiscard]] DCT_ID FindTokenByPartialSymbolName(const std::string &symbol) const; public: diff --git a/src/dfi/icxorder.cpp b/src/dfi/icxorder.cpp index f533dd43387..a139558f522 100644 --- a/src/dfi/icxorder.cpp +++ b/src/dfi/icxorder.cpp @@ -373,10 +373,17 @@ void CICXOrderView::ForEachICXSubmitEXTHTLCExpire(std::function(callback, StatusKey{height, {}}); } -std::unique_ptr CICXOrderView::HasICXSubmitEXTHTLCOpen(const uint256 &offertxid) { +std::optional CICXOrderView::GetICXSubmitEXTHTLCTXID(const uint256 &offertxid) { auto it = LowerBound(TxidPairKey{offertxid, {}}); if (it.Valid() && it.Key().first == offertxid) { - return GetICXSubmitEXTHTLCByCreationTx(it.Key().second); + return it.Key().second; + } + return {}; +} + +std::unique_ptr CICXOrderView::HasICXSubmitEXTHTLCOpen(const uint256 &offertxid) { + if (const auto extTx = GetICXSubmitEXTHTLCTXID(offertxid)) { + return GetICXSubmitEXTHTLCByCreationTx(*extTx); } return {}; } diff --git a/src/dfi/icxorder.h b/src/dfi/icxorder.h index e91d91e45e2..ee1fffd2899 100644 --- a/src/dfi/icxorder.h +++ b/src/dfi/icxorder.h @@ -404,6 +404,7 @@ class CICXOrderView : public virtual CStorageView { void ForEachICXMakeOfferExpire(std::function callback, const uint32_t &height = 0); std::unique_ptr HasICXMakeOfferOpen(const uint256 &ordertxid, const uint256 &offertxid); + std::optional GetICXSubmitEXTHTLCTXID(const uint256 &offertxid); // SubmitDFCHTLC std::unique_ptr GetICXSubmitDFCHTLCByCreationTx(const uint256 &txid) const;