From db0b7644a9a5a62ac2da3cf571fee41bb8b6974f Mon Sep 17 00:00:00 2001
From: Pu Zhibing <393733352@qq.com>
Date: 星期四, 25 九月 2025 15:54:15 +0800
Subject: [PATCH] 添加E路通推送数据功能

---
 ruoyi-service/ruoyi-chargingPile/src/main/java/com/ruoyi/chargingPile/controller/TChargingPileController.java |   81 ++++++++++++++++++++++++++++++++++++++--
 1 files changed, 77 insertions(+), 4 deletions(-)

diff --git a/ruoyi-service/ruoyi-chargingPile/src/main/java/com/ruoyi/chargingPile/controller/TChargingPileController.java b/ruoyi-service/ruoyi-chargingPile/src/main/java/com/ruoyi/chargingPile/controller/TChargingPileController.java
index 52fb479..2df41df 100644
--- a/ruoyi-service/ruoyi-chargingPile/src/main/java/com/ruoyi/chargingPile/controller/TChargingPileController.java
+++ b/ruoyi-service/ruoyi-chargingPile/src/main/java/com/ruoyi/chargingPile/controller/TChargingPileController.java
@@ -3,9 +3,7 @@
 
 import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
 import com.baomidou.mybatisplus.core.toolkit.Wrappers;
-import com.ruoyi.chargingPile.api.model.TChargingGun;
-import com.ruoyi.chargingPile.api.model.TChargingPile;
-import com.ruoyi.chargingPile.api.model.TFaultMessage;
+import com.ruoyi.chargingPile.api.model.*;
 import com.ruoyi.chargingPile.api.query.TChargingGunQuery;
 import com.ruoyi.chargingPile.api.vo.TChargingGunVO;
 import com.ruoyi.chargingPile.api.vo.UpdateChargingPileStatusVo;
@@ -15,6 +13,7 @@
 import com.ruoyi.chargingPile.dto.GetChargingGunMonitoring;
 import com.ruoyi.chargingPile.service.*;
 import com.ruoyi.common.core.domain.R;
+import com.ruoyi.common.core.utils.StringUtils;
 import com.ruoyi.common.core.web.domain.AjaxResult;
 import com.ruoyi.common.core.web.page.PageInfo;
 import com.ruoyi.chargingPile.api.dto.PageChargingPileListDTO;
@@ -30,6 +29,11 @@
 import com.ruoyi.common.redis.service.RedisService;
 import com.ruoyi.common.security.annotation.Logical;
 import com.ruoyi.common.security.annotation.RequiresPermissions;
+import com.ruoyi.integration.api.elutong.model.ConnectorStatusInfo;
+import com.ruoyi.integration.api.elutong.model.ConnectorStatusReq;
+import com.ruoyi.integration.api.elutong.model.StationStausInfo;
+import com.ruoyi.integration.api.elutong.model.StationsStatusReq;
+import com.ruoyi.integration.api.feignClient.ELuTongClient;
 import com.ruoyi.integration.api.feignClient.TCECClient;
 import com.ruoyi.order.api.feignClient.ChargingOrderClient;
 import com.ruoyi.order.api.model.TChargingOrder;
@@ -39,6 +43,7 @@
 import io.swagger.annotations.ApiImplicitParam;
 import io.swagger.annotations.ApiImplicitParams;
 import io.swagger.annotations.ApiOperation;
+import lombok.extern.slf4j.Slf4j;
 import org.springframework.data.redis.core.RedisTemplate;
 import org.springframework.web.bind.annotation.*;
 
@@ -60,6 +65,7 @@
  * @author xiaochen
  * @since 2024-08-06
  */
+@Slf4j
 @Api(tags = "充电桩")
 @RestController
 @RequestMapping("/t-charging-pile")
@@ -79,6 +85,14 @@
 	
 	@Resource
 	private TCECClient tcecClient;
+
+	@Resource
+	private ELuTongClient eLuTongClient;
+
+	@Resource
+	private ISiteService siteService;
+
+
 
 
     @Autowired
@@ -249,7 +263,7 @@
 		Integer status = vo.getStatus();
 		Long time = (Long) redisTemplate.opsForHash().get("charging_gun_online", (pile_code + gun_code));
 		//小于1分钟才处理数据,防止频繁查询数据
-		if(null != time && (System.currentTimeMillis() - time) < 60000){
+		if(null != time && (System.currentTimeMillis() - time) < 30000){
 			return;
 		}
 		TChargingGun tChargingGun = chargingGunService.getOne(new LambdaQueryWrapper<TChargingGun>().eq(TChargingGun::getFullNumber, (pile_code + gun_code)).eq(TChargingGun::getDelFlag, 0));
@@ -268,6 +282,7 @@
 					public void run() {
 						//推送状态给三方平台
 						tcecClient.pushChargingGunStatus(tChargingGun.getFullNumber(), tChargingGun1.getStatus());
+						pushConnectorStatus(tChargingGun);
 					}
 				}).start();
 				
@@ -296,6 +311,7 @@
 					public void run() {
 						//推送状态给三方平台
 						tcecClient.pushChargingGunStatus(tChargingGun.getFullNumber(), tChargingGun1.getStatus());
+						pushConnectorStatus(tChargingGun);
 					}
 				}).start();
 				
@@ -349,6 +365,7 @@
 						public void run() {
 							//推送状态给三方平台
 							tcecClient.pushChargingGunStatus(tChargingGun.getFullNumber(), tChargingGun1.getStatus());
+							pushConnectorStatus(tChargingGun);
 						}
 					}).start();
 				}else{
@@ -361,6 +378,7 @@
 						public void run() {
 							//推送状态给三方平台
 							tcecClient.pushChargingGunStatus(tChargingGun.getFullNumber(), tChargingGun1.getStatus());
+							pushConnectorStatus(tChargingGun);
 						}
 					}).start();
 				}
@@ -374,5 +392,60 @@
 			}
 		}
 	}
+
+
+	/**
+	 * 推送设备接口状态信息
+	 * @param chargingGun
+	 */
+	private void pushConnectorStatus(TChargingGun chargingGun){
+		Site site = siteService.getById(chargingGun.getSiteId());
+		if(StringUtils.isNotEmpty(site.getSerAreaCode())){
+			ConnectorStatusReq connectorStatusReq = new ConnectorStatusReq();
+			connectorStatusReq.setOperatorId("91510903906171535D");
+			connectorStatusReq.setSerAreaCode(site.getSerAreaCode());
+			connectorStatusReq.setStationId(site.getId().toString());
+			List<ConnectorStatusInfo> connectorStatusInfos = new ArrayList<>();
+			connectorStatusInfos.add(buildConnectorStatus(chargingGun));
+			connectorStatusReq.setItemSize(connectorStatusInfos.size());
+			connectorStatusReq.setConnectorStatusInfos(connectorStatusInfos);
+			R r = eLuTongClient.pushConnectorStatus(connectorStatusReq);
+			if(200 != r.getCode()){
+				log.error(r.getMsg());
+			}
+		}
+	}
+
+
+	private ConnectorStatusInfo buildConnectorStatus(TChargingGun chargingGun){
+		ConnectorStatusInfo connectorStatusInfo = new ConnectorStatusInfo();
+		connectorStatusInfo.setConnectorId(chargingGun.getId().toString());
+		switch (chargingGun.getStatus()){
+			case 1:
+				connectorStatusInfo.setStatus(0);
+				break;
+			case 2:
+				connectorStatusInfo.setStatus(1);
+				break;
+			case 3:
+				connectorStatusInfo.setStatus(2);
+				break;
+			case 4:
+				connectorStatusInfo.setStatus(3);
+				break;
+			case 5:
+				connectorStatusInfo.setStatus(3);
+				break;
+			case 6:
+				connectorStatusInfo.setStatus(4);
+				break;
+			case 7:
+				connectorStatusInfo.setStatus(255);
+				break;
+		}
+		connectorStatusInfo.setSoc(0D);
+		connectorStatusInfo.setRemainingTime(0);
+		return connectorStatusInfo;
+	}
 }
 

--
Gitblit v1.7.1