From 6a1b28591ebe95ed9f26810fbf9677da5c87692d Mon Sep 17 00:00:00 2001
From: xufenglei <xufenglei>
Date: Mon, 12 Mar 2018 09:24:36 +0800
Subject: [PATCH] 大屏 报表接口

---
 src/main/java/com/moral/service/impl/MonitorPointServiceImpl.java |   58 ++++++++++++++++++++++++++++++++++++++++++++++++++++++----
 1 files changed, 54 insertions(+), 4 deletions(-)

diff --git a/src/main/java/com/moral/service/impl/MonitorPointServiceImpl.java b/src/main/java/com/moral/service/impl/MonitorPointServiceImpl.java
index e979b68..6e8c2c3 100644
--- a/src/main/java/com/moral/service/impl/MonitorPointServiceImpl.java
+++ b/src/main/java/com/moral/service/impl/MonitorPointServiceImpl.java
@@ -8,15 +8,22 @@
 
 import javax.annotation.Resource;
 
+import org.apache.commons.collections.CollectionUtils;
+import org.springframework.stereotype.Service;
+
 import com.github.pagehelper.PageHelper;
 import com.moral.common.bean.Constants;
 import com.moral.common.bean.PageBean;
-import com.moral.common.util.*;
-import org.springframework.stereotype.Service;
-
+import com.moral.common.util.ExampleUtil;
+import com.moral.common.util.RedisUtils;
+import com.moral.common.util.StringUtils;
+import com.moral.common.util.ValidateUtil;
+import com.moral.entity.Device;
 import com.moral.entity.MonitorPoint;
+import com.moral.mapper.DeviceMapper;
 import com.moral.mapper.MonitorPointMapper;
 import com.moral.service.MonitorPointService;
+
 import tk.mybatis.mapper.entity.Example;
 import tk.mybatis.mapper.entity.Example.Criteria;
 
@@ -24,6 +31,8 @@
 public class MonitorPointServiceImpl implements MonitorPointService {
     @Resource
     private MonitorPointMapper monitorPointMapper;
+    @Resource
+    private DeviceMapper deviceMapper;
     @Resource
     RedisUtils redisUtils;
     private static Class ENTITY_CLASS = MonitorPoint.class;
@@ -84,15 +93,43 @@
                 monitorPoint.setIsDelete(Constants.IS_DELETE_FALSE);
                 monitorPointMapper.insertSelective(monitorPoint);
             }else{
-                // TODO ������������id������������������redis���������������
                 monitorPointMapper.updateByPrimaryKeySelective(monitorPoint);
+                // ������������������������������ ���redis���������������
+                refreshDevicesInRedis(monitorPoint.getId());
             }
         }
         catch (Exception ex){
             throw  ex;
         }
     }
+    /*
+      ������������������������������ ���redis���������������
+     */
+    private void  refreshDevicesInRedis(int monitorPointId){
+        Device device = new Device();
+        device.setMonitorPointId(monitorPointId);
+        List<Device> deviceList = deviceMapper.select(device);
+        if (!CollectionUtils.isEmpty(deviceList)){
+            List<Integer> orgIds = monitorPointMapper.selectOrganizationIds(monitorPointId);
+            if (!CollectionUtils.isEmpty(orgIds)){
+                deviceList.stream().forEach(dev ->{
+                    if(!StringUtils.isNullOrEmpty(dev.getMac())){
+                        String key = "device_"+dev.getMac();
+                        // ��������������������� ������������redis
+                        Device simpleDevice = new Device();
+                        simpleDevice.setId(dev.getId());
+                        simpleDevice.setDeviceVersion(dev.getDeviceVersion());
+                        simpleDevice.setMac(dev.getMac());
+                        simpleDevice.setMonitorPointId(dev.getMonitorPointId());
+                        // ������������������������������������������������������������������
+                        simpleDevice.setOrganizationIds(orgIds);
+                        redisUtils.set(key,simpleDevice);
+                    }
+                });
+            }
+        }
 
+    }
     @Override
     public void deleteByIds(Integer... ids) {
         MonitorPoint monitorPoint = new MonitorPoint();
@@ -138,4 +175,17 @@
         }).collect(Collectors.toList());
         return list;
     }
+
+    @Override
+	public List<MonitorPoint> getMonitorPointsByOrganizationId(Integer orgId) {
+		Example example = new Example(MonitorPoint.class);
+		Criteria criteria = example.createCriteria();
+		
+		criteria.andEqualTo("isDelete", Constants.IS_DELETE_FALSE);
+		if (Constants.isNotSpecialOrgId(orgId)) {
+			criteria.andEqualTo("organizationId", orgId);
+		}
+		example.orderBy("name").asc();
+		return monitorPointMapper.selectByExample(example);
+	}
 }

--
Gitblit v1.8.0