mirror of
https://github.com/boldsuck/haveno.git
synced 2025-01-09 09:39:23 +00:00
synchronize closed and failed trade managers
This commit is contained in:
parent
28c07e966b
commit
86511b4e21
2 changed files with 67 additions and 37 deletions
|
@ -109,53 +109,68 @@ public class ClosedTradableManager implements PersistedDataHost {
|
||||||
}
|
}
|
||||||
|
|
||||||
public void add(Tradable tradable) {
|
public void add(Tradable tradable) {
|
||||||
|
synchronized (closedTradables) {
|
||||||
if (closedTradables.add(tradable)) {
|
if (closedTradables.add(tradable)) {
|
||||||
maybeClearSensitiveData();
|
maybeClearSensitiveData();
|
||||||
requestPersistence();
|
requestPersistence();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
public void remove(Tradable tradable) {
|
public void remove(Tradable tradable) {
|
||||||
|
synchronized (closedTradables) {
|
||||||
if (closedTradables.remove(tradable)) {
|
if (closedTradables.remove(tradable)) {
|
||||||
requestPersistence();
|
requestPersistence();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
public boolean wasMyOffer(Offer offer) {
|
public boolean wasMyOffer(Offer offer) {
|
||||||
return offer.isMyOffer(keyRing);
|
return offer.isMyOffer(keyRing);
|
||||||
}
|
}
|
||||||
|
|
||||||
public ObservableList<Tradable> getObservableList() {
|
public ObservableList<Tradable> getObservableList() {
|
||||||
|
synchronized (closedTradables) {
|
||||||
return closedTradables.getObservableList();
|
return closedTradables.getObservableList();
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
public List<Tradable> getTradableList() {
|
public List<Tradable> getTradableList() {
|
||||||
return ImmutableList.copyOf(new ArrayList<>(getObservableList()));
|
return ImmutableList.copyOf(new ArrayList<>(getObservableList()));
|
||||||
}
|
}
|
||||||
|
|
||||||
public List<Trade> getClosedTrades() {
|
public List<Trade> getClosedTrades() {
|
||||||
|
synchronized (closedTradables) {
|
||||||
return ImmutableList.copyOf(getObservableList().stream()
|
return ImmutableList.copyOf(getObservableList().stream()
|
||||||
.filter(e -> e instanceof Trade)
|
.filter(e -> e instanceof Trade)
|
||||||
.map(e -> (Trade) e)
|
.map(e -> (Trade) e)
|
||||||
.collect(Collectors.toList()));
|
.collect(Collectors.toList()));
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
public List<OpenOffer> getCanceledOpenOffers() {
|
public List<OpenOffer> getCanceledOpenOffers() {
|
||||||
|
synchronized (closedTradables) {
|
||||||
return ImmutableList.copyOf(getObservableList().stream()
|
return ImmutableList.copyOf(getObservableList().stream()
|
||||||
.filter(e -> (e instanceof OpenOffer) && ((OpenOffer) e).getState().equals(CANCELED))
|
.filter(e -> (e instanceof OpenOffer) && ((OpenOffer) e).getState().equals(CANCELED))
|
||||||
.map(e -> (OpenOffer) e)
|
.map(e -> (OpenOffer) e)
|
||||||
.collect(Collectors.toList()));
|
.collect(Collectors.toList()));
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
public Optional<Tradable> getTradableById(String id) {
|
public Optional<Tradable> getTradableById(String id) {
|
||||||
|
synchronized (closedTradables) {
|
||||||
return closedTradables.stream().filter(e -> e.getId().equals(id)).findFirst();
|
return closedTradables.stream().filter(e -> e.getId().equals(id)).findFirst();
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
public Optional<Tradable> getTradeById(String id) {
|
public Optional<Tradable> getTradeById(String id) {
|
||||||
|
synchronized (closedTradables) {
|
||||||
return closedTradables.stream().filter(e -> e instanceof Trade && e.getId().equals(id)).findFirst();
|
return closedTradables.stream().filter(e -> e instanceof Trade && e.getId().equals(id)).findFirst();
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
public void maybeClearSensitiveData() {
|
public void maybeClearSensitiveData() {
|
||||||
|
synchronized (closedTradables) {
|
||||||
log.info("checking closed trades eligibility for having sensitive data cleared");
|
log.info("checking closed trades eligibility for having sensitive data cleared");
|
||||||
closedTradables.stream()
|
closedTradables.stream()
|
||||||
.filter(e -> e instanceof Trade)
|
.filter(e -> e instanceof Trade)
|
||||||
|
@ -164,14 +179,17 @@ public class ClosedTradableManager implements PersistedDataHost {
|
||||||
.forEach(Trade::maybeClearSensitiveData);
|
.forEach(Trade::maybeClearSensitiveData);
|
||||||
requestPersistence();
|
requestPersistence();
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
public boolean canTradeHaveSensitiveDataCleared(String tradeId) {
|
public boolean canTradeHaveSensitiveDataCleared(String tradeId) {
|
||||||
Instant safeDate = getSafeDateForSensitiveDataClearing();
|
Instant safeDate = getSafeDateForSensitiveDataClearing();
|
||||||
|
synchronized (closedTradables) {
|
||||||
return closedTradables.stream()
|
return closedTradables.stream()
|
||||||
.filter(e -> e.getId().equals(tradeId))
|
.filter(e -> e.getId().equals(tradeId))
|
||||||
.filter(e -> e.getDate().toInstant().isBefore(safeDate))
|
.filter(e -> e.getDate().toInstant().isBefore(safeDate))
|
||||||
.count() > 0;
|
.count() > 0;
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
public Instant getSafeDateForSensitiveDataClearing() {
|
public Instant getSafeDateForSensitiveDataClearing() {
|
||||||
return Instant.ofEpochSecond(Instant.now().getEpochSecond()
|
return Instant.ofEpochSecond(Instant.now().getEpochSecond()
|
||||||
|
|
|
@ -88,35 +88,46 @@ public class FailedTradesManager implements PersistedDataHost {
|
||||||
}
|
}
|
||||||
|
|
||||||
public void add(Trade trade) {
|
public void add(Trade trade) {
|
||||||
|
synchronized (failedTrades) {
|
||||||
if (failedTrades.add(trade)) {
|
if (failedTrades.add(trade)) {
|
||||||
requestPersistence();
|
requestPersistence();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
public void removeTrade(Trade trade) {
|
public void removeTrade(Trade trade) {
|
||||||
|
synchronized (failedTrades) {
|
||||||
if (failedTrades.remove(trade)) {
|
if (failedTrades.remove(trade)) {
|
||||||
requestPersistence();
|
requestPersistence();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
public boolean wasMyOffer(Offer offer) {
|
public boolean wasMyOffer(Offer offer) {
|
||||||
return offer.isMyOffer(keyRing);
|
return offer.isMyOffer(keyRing);
|
||||||
}
|
}
|
||||||
|
|
||||||
public ObservableList<Trade> getObservableList() {
|
public ObservableList<Trade> getObservableList() {
|
||||||
|
synchronized (failedTrades) {
|
||||||
return failedTrades.getObservableList();
|
return failedTrades.getObservableList();
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
public Optional<Trade> getTradeById(String id) {
|
public Optional<Trade> getTradeById(String id) {
|
||||||
|
synchronized (failedTrades) {
|
||||||
return failedTrades.stream().filter(e -> e.getId().equals(id)).findFirst();
|
return failedTrades.stream().filter(e -> e.getId().equals(id)).findFirst();
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
public Stream<Trade> getTradesStreamWithFundsLockedIn() {
|
public Stream<Trade> getTradesStreamWithFundsLockedIn() {
|
||||||
|
synchronized (failedTrades) {
|
||||||
return failedTrades.stream()
|
return failedTrades.stream()
|
||||||
.filter(Trade::isFundsLockedIn);
|
.filter(Trade::isFundsLockedIn);
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
public void unFailTrade(Trade trade) {
|
public void unFailTrade(Trade trade) {
|
||||||
|
synchronized (failedTrades) {
|
||||||
if (unFailTradeCallback == null)
|
if (unFailTradeCallback == null)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
|
@ -127,6 +138,7 @@ public class FailedTradesManager implements PersistedDataHost {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
public String checkUnFail(Trade trade) {
|
public String checkUnFail(Trade trade) {
|
||||||
var addresses = tradeUtil.getTradeAddresses(trade);
|
var addresses = tradeUtil.getTradeAddresses(trade);
|
||||||
|
|
Loading…
Reference in a new issue