From b98924dab9f433d152944f189e0a28edb09ed7e7 Mon Sep 17 00:00:00 2001
From: 沈斌 <bluelazysb@hotmail.com>
Date: Thu, 26 Apr 2018 16:40:43 +0800
Subject: [PATCH] 修改ftp服务器

---
 src/main/java/com/moral/service/impl/DeviceServiceImpl.java |   64 +++++++++++++++++++++++++++----
 1 files changed, 55 insertions(+), 9 deletions(-)

diff --git a/src/main/java/com/moral/service/impl/DeviceServiceImpl.java b/src/main/java/com/moral/service/impl/DeviceServiceImpl.java
index 74b3571..a3c7ea1 100644
--- a/src/main/java/com/moral/service/impl/DeviceServiceImpl.java
+++ b/src/main/java/com/moral/service/impl/DeviceServiceImpl.java
@@ -30,7 +30,21 @@
 
 @Service
 public class DeviceServiceImpl implements DeviceService {
-
+	//-----------------------redis key������-������---------------------------------
+	private static String AlARM = "alarm";//������������������key������
+	private static String ADJUST="adjust";//���������������key������
+	private static String DEVICE = "device";//������������������key������
+	private static String STATE = "state";//������������������key������
+	private static String DATA = "data";//������������������key������
+	//-----------------------redis key������-������---------------------------------
+	private String keysConnect(String... keys) {
+		StringBuilder key = new StringBuilder(keys[0]);
+		for(int i=1;i<keys.length;i++) {
+			key.append("_");
+			key.append(keys[i]);
+		}
+		return key.toString().toLowerCase();
+	}
 	@Resource
 	private DeviceMapper deviceMapper;
     @Resource
@@ -101,11 +115,39 @@
 
 	@Override
 	public Device getDeviceByMac(String mac) {
-		ValidateUtil.notEmpty(mac, "param.is.null");
-		Device device = new Device();
-		device.setMac(mac);
-		device = deviceMapper.selectOne(device);
+		Device device = getDeviceFromRedis(mac);
+		if(device==null) {
+			device = deviceMapper.selectWithOrgIdsByMac(mac);
+			if(device!=null){
+				setDeviceToRedis(mac,device);
+			}
+		}
 		return device;
+	}
+	/*
+	 * ���������������������redis������key
+	 */
+	private String getDeviceKey(String mac) {
+		return keysConnect(DEVICE,mac);
+	}
+	/*
+	 * ������������������redis��������� ������
+	 */
+	private void setDeviceToRedis(String mac,Device device){
+		String key = getDeviceKey(mac);
+		Device simpleDevice = new Device();
+		simpleDevice.setId(device.getId());// id
+		simpleDevice.setName(device.getName());// name
+		simpleDevice.setAddress(device.getAddress());// address
+		simpleDevice.setDeviceVersionId(device.getDeviceVersionId());// version
+		simpleDevice.setMac(device.getMac()); // mac
+		simpleDevice.setMonitorPointId(device.getMonitorPointId());// ���������id
+		simpleDevice.setOrganizationIds(device.getOrganizationIds());// ������������
+		redisUtils.set(key,simpleDevice);
+	}
+	private Device getDeviceFromRedis(String mac) {
+		String key = getDeviceKey(mac);
+		return redisUtils.get(key,Device.class);
 	}
 
 	/**
@@ -210,10 +252,13 @@
 	private void refreshDeviceInRedis(Device device){
 	     if(!StringUtils.isBlank(device.getMac())){
              Device simpleDevice = new Device();
-             simpleDevice.setId(device.getId());
-             simpleDevice.setDeviceVersion(device.getDeviceVersion());
-             simpleDevice.setMac(device.getMac());
-             simpleDevice.setMonitorPointId(device.getMonitorPointId());
+			 simpleDevice.setId(device.getId());// id
+			 simpleDevice.setName(device.getName());// name
+			 simpleDevice.setAddress(device.getAddress());// address
+			 simpleDevice.setDeviceVersionId(device.getDeviceVersionId());// version
+			 simpleDevice.setMac(device.getMac()); // mac
+			 simpleDevice.setMonitorPointId(device.getMonitorPointId());// ���������id
+			 simpleDevice.setOrganizationIds(device.getOrganizationIds());// ������������
              if(device.getMonitorPointId()!=null){
                  List<Integer> orgIds = monitorPointMapper.selectOrganizationIds(device.getMonitorPointId());
                  simpleDevice.setOrganizationIds(orgIds);
@@ -265,6 +310,7 @@
 				device.setMac(device.getMac().toLowerCase());
 			}
 			if(device.getId()==null){
+				device.setState(Constants.DEVICE_STATE_OFFLINE);
 				device.setIsDelete(Constants.IS_DELETE_FALSE);
 				deviceMapper.insertSelective(device);
 			}else{

--
Gitblit v1.8.0