From 513e5442723f501525bf9ca6210b16561e5d3a2b Mon Sep 17 00:00:00 2001
From: zyy <zyy@email.com>
Date: Tue, 24 Mar 2026 11:41:07 +0800
Subject: [PATCH] 1
---
trading-order-service/src/main/java/com/yami/trading/service/item/ItemService.java | 53 ++++++++++++++++++++++++++++++++++++++++++++++++++---
1 files changed, 50 insertions(+), 3 deletions(-)
diff --git a/trading-order-service/src/main/java/com/yami/trading/service/item/ItemService.java b/trading-order-service/src/main/java/com/yami/trading/service/item/ItemService.java
index 577f5c6..50d8aef 100644
--- a/trading-order-service/src/main/java/com/yami/trading/service/item/ItemService.java
+++ b/trading-order-service/src/main/java/com/yami/trading/service/item/ItemService.java
@@ -16,12 +16,14 @@
import com.yami.trading.bean.item.domain.Item;
import com.yami.trading.bean.item.dto.ItemDTO;
import com.yami.trading.bean.item.dto.ItemLeverageDTO;
+import com.yami.trading.bean.robot.domain.Robot;
import com.yami.trading.common.util.ApplicationContextUtils;
import com.yami.trading.common.util.MarketOpenChecker;
import com.yami.trading.common.util.StringUtils;
import com.yami.trading.dao.item.ItemMapper;
import lombok.extern.slf4j.Slf4j;
import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.cache.annotation.CacheEvict;
import org.springframework.stereotype.Service;
import org.springframework.transaction.annotation.Transactional;
@@ -48,7 +50,6 @@
private ItemLeverageService itemLeverageService;
private Map<String, Integer> symbolDecimal = Maps.newHashMap();
-
@Autowired
private CacheManager cacheManager;
@@ -128,6 +129,13 @@
return super.baseMapper.selectOne(queryWrapper);
}
+ public Item findCurrBySymbol(String symbol) {
+ LambdaQueryWrapper<Item> queryWrapper = new LambdaQueryWrapper<Item>()
+ .eq(Item::getSymbol, symbol)
+ .last("LIMIT 1");
+ return super.baseMapper.selectOne(queryWrapper);
+ }
+
/**
* 根据id查询
@@ -162,7 +170,7 @@
@Cached(name = ITEM_CACHE, key = "'all'", expire = 3600)
@Override
public List<Item> list() {
- List<Item> list = super.list();
+ List<Item> list = super.list(new LambdaQueryWrapper<>(Item.class).eq(Item::getType,Item.cryptos));
symbolDecimal = list.stream()
.collect(Collectors.toMap(Item::getSymbol, Item::getDecimals, (s1, s2) -> s2));
return list;
@@ -180,6 +188,9 @@
return super.removeById(id);
}
+ public void reloadListAndCache() {
+ init();
+ }
/**
* 获取品种精度
@@ -203,7 +214,7 @@
}
public List<Item> cacheGetAll() {
- return ApplicationContextUtils.getApplicationContext().getBean(ItemService.class).list();
+ return ApplicationContextUtils.getApplicationContext().getBean(ItemService.class).list(new LambdaQueryWrapper<>(Item.class).eq(Item::getType,Item.cryptos));
}
@@ -229,4 +240,40 @@
Item bySymbol = findBySymbol(symbol);
return MarketOpenChecker.isMarketOpenByItemCloseType(bySymbol.getOpenCloseType());
}
+
+ /**
+ * 是否开放合约
+ * @param item
+ * @return
+ */
+ public boolean isContractTrading(Item item) {
+ item = findBySymbol(item.getSymbol());
+ //虚拟币新币才判断
+ if (item.getType().equals(Item.cryptos) && (item.getCurrencyType() != null && item.getCurrencyType() == 1)) {
+ if (item.getTradeType() != null && item.getTradeType().equals("0")) {
+ return false;
+ }
+ }
+ return true;
+ }
+
+ /**
+ * 是否停牌状态
+ * @return
+ */
+ public boolean isSuspended(String symbol) {
+ //Item item = findBySymbol(symbol);
+ Item item = getOne(new LambdaQueryWrapper<Item>().eq(Item::getSymbol, symbol));
+ if (item != null) {
+ //虚拟币新币才判断
+ if (item.getType().equals(Item.cryptos) /*&& (item.getCurrencyType() != null && item.getCurrencyType() == 1)*/) {
+ //item = getById(item.getUuid());
+ if (item.getStatus() != null && item.getStatus() == 0) {
+ return true;
+ }
+ }
+ }
+ return false;
+ }
+
}
--
Gitblit v1.9.3