mirror of
https://github.com/haveno-dex/haveno.git
synced 2025-01-23 21:21:06 -05:00
enforce trade limit over grpc
This commit is contained in:
parent
31dfdd7710
commit
f11c816cda
@ -96,6 +96,10 @@ class CorePaymentAccountsService {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
PaymentAccount getPaymentAccount(String paymentAccountId) {
|
||||||
|
return user.getPaymentAccount(paymentAccountId);
|
||||||
|
}
|
||||||
|
|
||||||
Set<PaymentAccount> getPaymentAccounts() {
|
Set<PaymentAccount> getPaymentAccounts() {
|
||||||
return user.getPaymentAccounts();
|
return user.getPaymentAccounts();
|
||||||
}
|
}
|
||||||
|
@ -17,6 +17,7 @@
|
|||||||
|
|
||||||
package bisq.core.offer;
|
package bisq.core.offer;
|
||||||
|
|
||||||
|
import bisq.core.account.witness.AccountAgeWitnessService;
|
||||||
import bisq.core.api.CoreContext;
|
import bisq.core.api.CoreContext;
|
||||||
import bisq.core.api.CoreMoneroConnectionsService;
|
import bisq.core.api.CoreMoneroConnectionsService;
|
||||||
import bisq.core.btc.wallet.BtcWalletService;
|
import bisq.core.btc.wallet.BtcWalletService;
|
||||||
@ -136,6 +137,8 @@ public class OpenOfferManager implements PeerManager.Listener, DecryptedDirectMe
|
|||||||
private Timer periodicRepublishOffersTimer, periodicRefreshOffersTimer, retryRepublishOffersTimer;
|
private Timer periodicRepublishOffersTimer, periodicRefreshOffersTimer, retryRepublishOffersTimer;
|
||||||
@Getter
|
@Getter
|
||||||
private final ObservableList<Tuple2<OpenOffer, String>> invalidOffers = FXCollections.observableArrayList();
|
private final ObservableList<Tuple2<OpenOffer, String>> invalidOffers = FXCollections.observableArrayList();
|
||||||
|
@Getter
|
||||||
|
private final AccountAgeWitnessService accountAgeWitnessService;
|
||||||
|
|
||||||
|
|
||||||
///////////////////////////////////////////////////////////////////////////////////////////
|
///////////////////////////////////////////////////////////////////////////////////////////
|
||||||
@ -161,7 +164,8 @@ public class OpenOfferManager implements PeerManager.Listener, DecryptedDirectMe
|
|||||||
FilterManager filterManager,
|
FilterManager filterManager,
|
||||||
Broadcaster broadcaster,
|
Broadcaster broadcaster,
|
||||||
PersistenceManager<TradableList<OpenOffer>> persistenceManager,
|
PersistenceManager<TradableList<OpenOffer>> persistenceManager,
|
||||||
PersistenceManager<SignedOfferList> signedOfferPersistenceManager) {
|
PersistenceManager<SignedOfferList> signedOfferPersistenceManager,
|
||||||
|
AccountAgeWitnessService accountAgeWitnessService) {
|
||||||
this.coreContext = coreContext;
|
this.coreContext = coreContext;
|
||||||
this.keyRing = keyRing;
|
this.keyRing = keyRing;
|
||||||
this.user = user;
|
this.user = user;
|
||||||
@ -181,6 +185,7 @@ public class OpenOfferManager implements PeerManager.Listener, DecryptedDirectMe
|
|||||||
this.broadcaster = broadcaster;
|
this.broadcaster = broadcaster;
|
||||||
this.persistenceManager = persistenceManager;
|
this.persistenceManager = persistenceManager;
|
||||||
this.signedOfferPersistenceManager = signedOfferPersistenceManager;
|
this.signedOfferPersistenceManager = signedOfferPersistenceManager;
|
||||||
|
this.accountAgeWitnessService = accountAgeWitnessService;
|
||||||
|
|
||||||
this.persistenceManager.initialize(openOffers, "OpenOffers", PersistenceManager.Source.PRIVATE);
|
this.persistenceManager.initialize(openOffers, "OpenOffers", PersistenceManager.Source.PRIVATE);
|
||||||
this.signedOfferPersistenceManager.initialize(signedOffers, "SignedOffers", PersistenceManager.Source.PRIVATE); // arbitrator stores reserve tx for signed offers
|
this.signedOfferPersistenceManager.initialize(signedOffers, "SignedOffers", PersistenceManager.Source.PRIVATE); // arbitrator stores reserve tx for signed offers
|
||||||
@ -741,7 +746,7 @@ public class OpenOfferManager implements PeerManager.Listener, DecryptedDirectMe
|
|||||||
}
|
}
|
||||||
|
|
||||||
private void signAndPostOffer(OpenOffer openOffer,
|
private void signAndPostOffer(OpenOffer openOffer,
|
||||||
Coin offerReserveAmount, // TODO: switch to BigInteger
|
Coin offerReserveAmount,
|
||||||
boolean useSavingsWallet, // TODO: remove this
|
boolean useSavingsWallet, // TODO: remove this
|
||||||
TransactionResultHandler resultHandler, ErrorMessageHandler errorMessageHandler) {
|
TransactionResultHandler resultHandler, ErrorMessageHandler errorMessageHandler) {
|
||||||
log.info("Signing and posting offer " + openOffer.getId());
|
log.info("Signing and posting offer " + openOffer.getId());
|
||||||
@ -760,7 +765,8 @@ public class OpenOfferManager implements PeerManager.Listener, DecryptedDirectMe
|
|||||||
tradeStatisticsManager,
|
tradeStatisticsManager,
|
||||||
user,
|
user,
|
||||||
keyRing,
|
keyRing,
|
||||||
filterManager);
|
filterManager,
|
||||||
|
accountAgeWitnessService);
|
||||||
|
|
||||||
// create protocol
|
// create protocol
|
||||||
PlaceOfferProtocol placeOfferProtocol = new PlaceOfferProtocol(model,
|
PlaceOfferProtocol placeOfferProtocol = new PlaceOfferProtocol(model,
|
||||||
|
@ -17,6 +17,7 @@
|
|||||||
|
|
||||||
package bisq.core.offer.placeoffer;
|
package bisq.core.offer.placeoffer;
|
||||||
|
|
||||||
|
import bisq.core.account.witness.AccountAgeWitnessService;
|
||||||
import bisq.core.btc.wallet.BtcWalletService;
|
import bisq.core.btc.wallet.BtcWalletService;
|
||||||
import bisq.core.btc.wallet.TradeWalletService;
|
import bisq.core.btc.wallet.TradeWalletService;
|
||||||
import bisq.core.btc.wallet.XmrWalletService;
|
import bisq.core.btc.wallet.XmrWalletService;
|
||||||
@ -63,6 +64,8 @@ public class PlaceOfferModel implements Model {
|
|||||||
private final KeyRing keyRing;
|
private final KeyRing keyRing;
|
||||||
@Getter
|
@Getter
|
||||||
private final FilterManager filterManager;
|
private final FilterManager filterManager;
|
||||||
|
@Getter
|
||||||
|
private final AccountAgeWitnessService accountAgeWitnessService;
|
||||||
|
|
||||||
// Mutable
|
// Mutable
|
||||||
@Setter
|
@Setter
|
||||||
@ -87,7 +90,8 @@ public class PlaceOfferModel implements Model {
|
|||||||
TradeStatisticsManager tradeStatisticsManager,
|
TradeStatisticsManager tradeStatisticsManager,
|
||||||
User user,
|
User user,
|
||||||
KeyRing keyRing,
|
KeyRing keyRing,
|
||||||
FilterManager filterManager) {
|
FilterManager filterManager,
|
||||||
|
AccountAgeWitnessService accountAgeWitnessService) {
|
||||||
this.offer = offer;
|
this.offer = offer;
|
||||||
this.reservedFundsForOffer = reservedFundsForOffer;
|
this.reservedFundsForOffer = reservedFundsForOffer;
|
||||||
this.useSavingsWallet = useSavingsWallet;
|
this.useSavingsWallet = useSavingsWallet;
|
||||||
@ -102,6 +106,7 @@ public class PlaceOfferModel implements Model {
|
|||||||
this.user = user;
|
this.user = user;
|
||||||
this.keyRing = keyRing;
|
this.keyRing = keyRing;
|
||||||
this.filterManager = filterManager;
|
this.filterManager = filterManager;
|
||||||
|
this.accountAgeWitnessService = accountAgeWitnessService;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -19,6 +19,7 @@ package bisq.core.offer.placeoffer.tasks;
|
|||||||
|
|
||||||
import bisq.core.offer.Offer;
|
import bisq.core.offer.Offer;
|
||||||
import bisq.core.offer.placeoffer.PlaceOfferModel;
|
import bisq.core.offer.placeoffer.PlaceOfferModel;
|
||||||
|
import bisq.core.trade.HavenoUtils;
|
||||||
import bisq.core.trade.messages.TradeMessage;
|
import bisq.core.trade.messages.TradeMessage;
|
||||||
|
|
||||||
import bisq.common.taskrunner.Task;
|
import bisq.common.taskrunner.Task;
|
||||||
@ -65,8 +66,9 @@ public class ValidateOffer extends Task<PlaceOfferModel> {
|
|||||||
/*checkArgument(offer.getMinAmount().compareTo(ProposalConsensus.getMinTradeAmount()) >= 0,
|
/*checkArgument(offer.getMinAmount().compareTo(ProposalConsensus.getMinTradeAmount()) >= 0,
|
||||||
"MinAmount is less than " + ProposalConsensus.getMinTradeAmount().toFriendlyString());*/
|
"MinAmount is less than " + ProposalConsensus.getMinTradeAmount().toFriendlyString());*/
|
||||||
|
|
||||||
checkArgument(offer.getAmount().compareTo(offer.getPaymentMethod().getMaxTradeLimitAsCoin(offer.getCurrencyCode())) <= 0,
|
long maxAmount = model.getAccountAgeWitnessService().getMyTradeLimit(model.getUser().getPaymentAccount(offer.getMakerPaymentAccountId()), offer.getCurrencyCode(), offer.getDirection());
|
||||||
"Amount is larger than " + offer.getPaymentMethod().getMaxTradeLimitAsCoin(offer.getCurrencyCode()).toFriendlyString());
|
checkArgument(offer.getAmount().longValue() <= maxAmount,
|
||||||
|
"Amount is larger than " + HavenoUtils.coinToXmr(offer.getPaymentMethod().getMaxTradeLimitAsCoin(offer.getCurrencyCode())) + " XMR");
|
||||||
checkArgument(offer.getAmount().compareTo(offer.getMinAmount()) >= 0, "MinAmount is larger than Amount");
|
checkArgument(offer.getAmount().compareTo(offer.getMinAmount()) >= 0, "MinAmount is larger than Amount");
|
||||||
|
|
||||||
checkNotNull(offer.getPrice(), "Price is null");
|
checkNotNull(offer.getPrice(), "Price is null");
|
||||||
@ -89,7 +91,6 @@ public class ValidateOffer extends Task<PlaceOfferModel> {
|
|||||||
"maxTradePeriod must be positive. maxTradePeriod=" + offer.getMaxTradePeriod());
|
"maxTradePeriod must be positive. maxTradePeriod=" + offer.getMaxTradePeriod());
|
||||||
// TODO check upper and lower bounds for fiat
|
// TODO check upper and lower bounds for fiat
|
||||||
// TODO check rest of new parameters
|
// TODO check rest of new parameters
|
||||||
// TODO check for account age witness base tradeLimit is missing
|
|
||||||
|
|
||||||
complete();
|
complete();
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
|
@ -38,7 +38,6 @@ import bisq.core.trade.protocol.TradeListener;
|
|||||||
import bisq.core.trade.protocol.TradeProtocol;
|
import bisq.core.trade.protocol.TradeProtocol;
|
||||||
import bisq.core.trade.protocol.TradingPeer;
|
import bisq.core.trade.protocol.TradingPeer;
|
||||||
import bisq.core.trade.txproof.AssetTxProofResult;
|
import bisq.core.trade.txproof.AssetTxProofResult;
|
||||||
import bisq.core.util.ParsingUtils;
|
|
||||||
import bisq.core.util.VolumeUtil;
|
import bisq.core.util.VolumeUtil;
|
||||||
import bisq.network.p2p.AckMessage;
|
import bisq.network.p2p.AckMessage;
|
||||||
import bisq.network.p2p.NodeAddress;
|
import bisq.network.p2p.NodeAddress;
|
||||||
@ -701,7 +700,6 @@ public abstract class Trade implements Tradable, Model {
|
|||||||
public MoneroTxWallet createPayoutTx() {
|
public MoneroTxWallet createPayoutTx() {
|
||||||
|
|
||||||
// gather info
|
// gather info
|
||||||
XmrWalletService walletService = processModel.getProvider().getXmrWalletService();
|
|
||||||
MoneroWallet multisigWallet = getWallet();
|
MoneroWallet multisigWallet = getWallet();
|
||||||
if (multisigWallet.isMultisigImportNeeded()) throw new RuntimeException("Cannot create payout tx because multisig import is needed");
|
if (multisigWallet.isMultisigImportNeeded()) throw new RuntimeException("Cannot create payout tx because multisig import is needed");
|
||||||
String sellerPayoutAddress = this.getSeller().getPayoutAddressString();
|
String sellerPayoutAddress = this.getSeller().getPayoutAddressString();
|
||||||
|
@ -73,7 +73,8 @@ public class OpenOfferManagerTest {
|
|||||||
null,
|
null,
|
||||||
null,
|
null,
|
||||||
persistenceManager,
|
persistenceManager,
|
||||||
signedOfferPersistenceManager);
|
signedOfferPersistenceManager,
|
||||||
|
null);
|
||||||
|
|
||||||
AtomicBoolean startEditOfferSuccessful = new AtomicBoolean(false);
|
AtomicBoolean startEditOfferSuccessful = new AtomicBoolean(false);
|
||||||
|
|
||||||
@ -119,7 +120,8 @@ public class OpenOfferManagerTest {
|
|||||||
null,
|
null,
|
||||||
null,
|
null,
|
||||||
persistenceManager,
|
persistenceManager,
|
||||||
signedOfferPersistenceManager);
|
signedOfferPersistenceManager,
|
||||||
|
null);
|
||||||
|
|
||||||
AtomicBoolean startEditOfferSuccessful = new AtomicBoolean(false);
|
AtomicBoolean startEditOfferSuccessful = new AtomicBoolean(false);
|
||||||
|
|
||||||
@ -159,7 +161,8 @@ public class OpenOfferManagerTest {
|
|||||||
null,
|
null,
|
||||||
null,
|
null,
|
||||||
persistenceManager,
|
persistenceManager,
|
||||||
signedOfferPersistenceManager);
|
signedOfferPersistenceManager,
|
||||||
|
null);
|
||||||
|
|
||||||
AtomicBoolean startEditOfferSuccessful = new AtomicBoolean(false);
|
AtomicBoolean startEditOfferSuccessful = new AtomicBoolean(false);
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user