From ca72da809fdf68f2d6833ed77ad92c9aadc0663d Mon Sep 17 00:00:00 2001
From: fengxiang <110431245@qq.com>
Date: Tue, 22 May 2018 09:30:20 +0800
Subject: [PATCH] 地图 增加 监控点入口

---
 src/main/java/com/moral/service/impl/DeviceServiceImpl.java |  419 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++---
 1 files changed, 392 insertions(+), 27 deletions(-)

diff --git a/src/main/java/com/moral/service/impl/DeviceServiceImpl.java b/src/main/java/com/moral/service/impl/DeviceServiceImpl.java
index b21b0af..a3c9565 100644
--- a/src/main/java/com/moral/service/impl/DeviceServiceImpl.java
+++ b/src/main/java/com/moral/service/impl/DeviceServiceImpl.java
@@ -1,36 +1,65 @@
 package com.moral.service.impl;
 
-import java.util.Date;
-import java.util.HashMap;
-import java.util.List;
-import java.util.Map;
+import java.util.*;
+import java.util.stream.Collectors;
 
 import javax.annotation.Resource;
 
+import com.alibaba.fastjson.TypeReference;
+import com.github.pagehelper.Page;
+import com.moral.common.bean.Constants;
+import com.moral.common.bean.PageBean;
+import com.moral.common.bean.PageResult;
+import com.moral.common.exception.BusinessException;
+import com.moral.common.util.ExampleUtil;
+import com.moral.common.util.RedisUtils;
+import com.moral.mapper.MonitorPointMapper;
+import org.apache.commons.collections.MapUtils;
+import org.apache.commons.lang3.BooleanUtils;
+import org.apache.commons.lang3.StringUtils;
+import org.apache.log4j.Logger;
 import org.springframework.stereotype.Service;
+import org.springframework.transaction.annotation.Transactional;
 import org.springframework.util.ObjectUtils;
 
 import com.github.pagehelper.PageHelper;
-import com.moral.common.exception.BusinessException;
 import com.moral.common.util.ValidateUtil;
 import com.moral.entity.Device;
 import com.moral.mapper.DeviceMapper;
 import com.moral.service.AccountService;
 import com.moral.service.DeviceService;
-
 import tk.mybatis.mapper.entity.Example;
 
 @Service
 public class DeviceServiceImpl implements DeviceService {
-
+	Logger log = Logger.getLogger(DeviceServiceImpl.class);
+	//-----------------------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
+    private MonitorPointMapper monitorPointMapper;
 	@Resource
 	private AccountService accountService;
-
+    private Class ENTITY_CLASS = Device.class;
+	@Resource
+	RedisUtils redisUtils;
 	@Override
 	public Map<String, Object> getDeviceStatesByAccount(Map<String, Object> parameters) {
+		ValidateUtil.notNull(parameters.get("accountId"), "param.is.null");
 		Map<String, Object> result = new HashMap<String, Object>();
 		accountService.setOrgIdsByAccount(parameters);
 		List<Map<String, Object>> list = deviceMapper.getDeviceStatesByAccount(parameters);
@@ -57,38 +86,374 @@
 	}
 	
 	@Override
-	public List<Map<String, Object>> getSensorsByDevice(String mac) {
-		return deviceMapper.getSensorsByDevice(mac);
-	}
-
-	@Override
+	@Transactional
 	public void saveOrUpdateDevice(Device device) {
-		ValidateUtil.notNull(device, "������������������");
-		ValidateUtil.notEmpty(device.getMac(), "������������������");
-		Example example = new Example(Device.class);
-		example.or().andEqualTo("mac",device.getMac());
-		List<Device> devices = deviceMapper.selectByExample(example);
+		ValidateUtil.notNull(device, "param.is.null");
+		ValidateUtil.notEmpty(device.getMac(), "param.is.null");
+		Device queryDevice = new Device();
+		queryDevice.setMac(device.getMac());
+		queryDevice = deviceMapper.selectOne(queryDevice);
 		Date operateDate = new Date();
 		device.setInstallTime(operateDate);
-		if (ObjectUtils.isEmpty(devices)) {
+		if (ObjectUtils.isEmpty(queryDevice)) {
 			device.setCreateTime(operateDate);
 			device.setState("4");
+			device.setIsDelete(Constants.IS_DELETE_FALSE);
 			deviceMapper.insertSelective(device);
-		}else if (devices.size() > 1) {
-			throw new BusinessException("���������������������������������������");
 		}else {
-			device.setId(devices.get(0).getId());
+			device.setId(queryDevice.getId());
 			deviceMapper.updateByPrimaryKeySelective(device);
 		}
+		//������redis������������
+		refreshDeviceInRedis(device.getMac());
 	}
 
 	@Override
 	public List<Device> getInstallDevicesByOperateUser(Integer uid, Integer pageIndex, Integer pageSize) {
-		Example example = new Example(Device.class);
-		example.or().andEqualTo("operateUserId",uid);
-		PageHelper.startPage(pageIndex, pageSize);
-		List<Device> devices = deviceMapper.selectByExample(example);
+		ValidateUtil.notNull(uid, "param.is.null");
+		Device device = new Device();
+		device.setOperateUserId(uid);
+		PageHelper.startPage(pageIndex, pageSize,false);
+		List<Device> devices = deviceMapper.select(device);
 		return devices;
 	}
 
+	/**
+	 *
+	 * @param mac
+	 * @param fromCache
+	 * @return ������������������
+	 */
+    @Override
+    public  Device getDeviceByMac (String mac ,boolean fromCache){
+	    if(fromCache){
+            Device device = getDeviceFromRedis(mac);
+            if(device==null) {
+                device = deviceMapper.selectWithOrgIdsByMac(mac);
+                if(device!=null){
+                    setDeviceToRedis(mac,device);
+                }
+            }
+            return  device;
+        }else {
+            return  deviceMapper.selectWithOrgIdsByMac(mac);
+        }
+
+    }
+
+    /**
+     * ���������������������
+     * @param mac
+     * @return
+     */
+	@Override
+	public Device getDeviceByMac(String mac) {
+
+		return getDeviceByMac(mac,true);
+	}
+	/*
+	 * ���������������������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);
+	}
+
+	/**
+	 *
+	 * @param map
+	 * map��� ������ ������id���4������������
+	 * @return ������������������������
+	 */
+	@Override
+	public List<Device> query(Map<String, Object> map) {
+		List <Device> list = deviceMapper.selectByMap(map);
+		loadDeviceState(list);
+		return list;
+	}
+
+	/**
+	 *  ������������id��������������� ������������������
+	 * @param orgId
+	 * @param deviceName
+	 * @param pageSize
+	 * @param pageNo
+	 * @return ���������������������
+	 */
+	@Override
+	public PageResult query(Integer orgId, String deviceName, Integer pageSize, Integer pageNo) {
+		if(!ObjectUtils.isEmpty(pageSize)&&!ObjectUtils.isEmpty(pageNo)){
+			PageHelper.startPage(pageNo,pageSize);
+		}
+		String state = null;
+		switch (deviceName){
+			case "������":
+				state = "0";
+				deviceName = null;break;
+				case "������":
+				state = "1";
+				deviceName = null;break;
+			case "������":
+				state = "2";
+				deviceName = null;break;
+			case "������":
+				state = "3";
+				deviceName = null;break;
+			case "������":
+				state = "4";
+				deviceName = null;break;
+		}
+		List<Device> list = deviceMapper.selectByOrgIdAndDevName(orgId,state,deviceName);
+		//���redis������������
+		loadDeviceState(list);
+		if(list instanceof Page){
+			return new PageResult(((Page) list).getTotal(),list);
+		}
+		return new PageResult(null,list);
+	}
+
+	/**
+	 * ������������id������������id ������������������
+	 * @param orgId
+	 * @param mpId
+	 * @param pageSize
+	 * @param pageNo
+	 * @return ���������������������
+	 */
+	@Override
+	public PageResult query(Integer orgId, Integer mpId, Integer pageSize, Integer pageNo) {
+		if(!ObjectUtils.isEmpty(pageSize)&&!ObjectUtils.isEmpty(pageNo)){
+			PageHelper.startPage(pageNo,pageSize);
+		}
+		List<Device> list = deviceMapper.selectByOrgIdAndMpId(orgId,mpId);
+		//���redis������������
+		loadDeviceState(list);
+		if(list instanceof Page){
+			return new PageResult(((Page) list).getTotal(),list);
+		}
+		return new PageResult(null,list);
+	}
+	private void loadDeviceState(List<Device> list){
+		//���redis������������
+		list.stream().map( device -> {
+			String mac = device.getMac();
+			if(!StringUtils.isBlank(mac)){
+				String state = getSateFromRedis(device.getMonitorPointId(),mac.toLowerCase());
+				device.setState(state);
+			}else{
+				device.setState(Constants.DEVICE_STATE_OFFLINE);
+			}
+			return device;
+		}).count();
+	}
+	private String getSateFromRedis(Integer mpId,String mac){
+
+		Map<String,String> stateMap  = getStateMapFromRedis(mpId,mac);
+		String state = null;
+		if(stateMap != null){
+			state  = stateMap.get("state");
+		}
+		state = state == null ?Constants.DEVICE_STATE_OFFLINE:state;
+		return  state;
+	}
+	public Map<String,String> getStateMapFromRedis(Integer mpId,String mac){
+		StringBuilder key = new StringBuilder();
+		//������key
+		key.append("state_").append(mpId).append("_").append(mac);
+		return   redisUtils.get(key.toString(),new TypeReference<Map<String,String>>(){});
+	}
+	private Device getDeviceWithOrgIdsByMac(String mac) {
+		String key = "device_"+mac;
+		Device device = redisUtils.get(key,Device.class);
+		if(device==null) {
+			device = deviceMapper.selectWithOrgIdsByMac(mac);
+			if(device!=null){
+				redisUtils.set(key,device);
+			}
+		}
+		return device;
+	}
+
+	/**
+	 * ������������������������������
+	 * ������ redis ���������������
+	 * @param mac
+	 */
+	private void refreshDeviceInRedis(String mac){
+	     if(!StringUtils.isBlank(mac)){
+	     	 Device devQuery = new Device();
+	     	 devQuery.setMac(mac);
+	     	 Device device = deviceMapper.selectOne(devQuery);
+	     	 if(device.getMonitorPointId()!=null){
+	     	 	List<Integer> orgIds = monitorPointMapper.selectOrganizationIds(device.getMonitorPointId());
+	     	 	device.setOrganizationIds(orgIds);
+			 }
+             String key = "device_"+mac;
+             redisUtils.set(key,device);
+         }else
+		 {
+		 	log.warn("param mac is null in method [refreshDeviceInRedis]");
+		 }
+	}
+	@Override
+	public int countByExample(PageBean pageBean){
+		Example example = ExampleUtil.generateExample(ENTITY_CLASS,pageBean);
+		addDeletesToExample(example);
+        return deviceMapper.selectCountByExample(example);
+	}
+
+	/**
+	 * ������������������������
+	 * @param example
+	 */
+	private void addDeletesToExample(Example example){
+		List<Example.Criteria> criteriaList = example.getOredCriteria();
+		if(criteriaList!=null&&criteriaList.size()>0){
+			for(Example.Criteria cri : criteriaList){
+				cri.andNotEqualTo("isDelete", Constants.IS_DELETE_TRUE);
+			}
+		}else {
+			example.or().andNotEqualTo("isDelete",Constants.IS_DELETE_TRUE);
+		}
+	}
+	@Override
+	public PageBean queryByPageBean(PageBean pageBean) {
+		Example example = ExampleUtil.generateExample(ENTITY_CLASS,pageBean);
+		addDeletesToExample(example);
+		if(pageBean.getPageSize()>0){
+			PageHelper.startPage(pageBean.getPageIndex(),pageBean.getPageSize());
+		}
+		List<Device> organizationList = deviceMapper.selectWithRelationData(example);
+		return new PageBean(organizationList);
+	}
+
+	@Override
+	public void deleteByIds(Integer[] ids) {
+		Device device = new Device();
+		device.setIsDelete(Constants.IS_DELETE_TRUE);
+		if(ids!=null&&ids.length>0){
+			Example example = new Example(ENTITY_CLASS);
+			example.or().andIn("id", Arrays.asList(ids));
+			if(ids.length==1){
+				device.setId(ids[0]);
+				deviceMapper.updateByPrimaryKeySelective(device);
+			}else{
+				deviceMapper.updateByExampleSelective(device,example);
+			}
+			List<Device> deviceList = deviceMapper.selectByExample(example);
+			List<String> adjustAndDeviceKeys = deviceList.stream().collect(
+					ArrayList<String>::new,
+					(list,dev) -> {
+						if(!StringUtils.isBlank(dev.getMac())){
+							list.add("device_"+dev.getMac());
+							list.add("adjust_"+dev.getMac());
+						}
+					},
+					(oList,nList)-> {
+						oList.addAll(nList);
+					}
+			);
+			redisUtils.remove(adjustAndDeviceKeys.toArray(new String [adjustAndDeviceKeys.size()]));
+		}
+	}
+
+	@Override
+	public void addOrModify(Device device){
+		try{
+			//mac ���������
+			if(!StringUtils.isBlank(device.getMac())){
+				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{
+				deviceMapper.updateByPrimaryKeySelective(device);
+			}
+			//������redis���������������
+			refreshDeviceInRedis(device.getMac());
+		}
+		catch (Exception ex){
+			throw  ex;
+		}
+	}
+	@Override
+	public List<Map> countByTimes(Date start,Date end,String format){
+		if(start==null||end==null||StringUtils.isBlank(format)){
+			log.error("some  params is null");
+			throw new BusinessException("some  params is null");
+		}
+		return  deviceMapper.countByTimes(start, end, format);
+	}
+	@Override
+	public List<Device> getDevicesByMonitorPointId(Integer monitorPointId) {
+		Device device = new Device();
+		device.setMonitorPointId(monitorPointId);
+		device.setIsDelete(Constants.IS_DELETE_FALSE);
+		return deviceMapper.select(device);
+	}
+
+	/**
+	 *  ������map{mac������state���}
+	 * @param macList
+	 * @return
+	 */
+	@Override
+	public List<Map<String,String>> queryDevicesState(List<String> macList,Boolean withData) {
+		List<Map<String,String>> list = macList.stream().map(mac->{
+			Map<String,String> resultMap = new HashMap<>();
+			if(!StringUtils.isBlank(mac)){
+				mac = mac.toLowerCase();
+				Device device = getDeviceWithOrgIdsByMac(mac);
+				Map<String,String> stateMap = getStateMapFromRedis(device.getMonitorPointId(),mac);
+				if(!MapUtils.isEmpty(stateMap)){
+					resultMap.putAll(stateMap);
+				}else{
+					resultMap.put("state",Constants.DEVICE_STATE_OFFLINE);
+					resultMap.put("mac",mac);
+				}
+				//������data
+				if(BooleanUtils.isTrue(withData)){
+					String dataKey = "data_"+mac;
+					Map<String,String> dataMap = redisUtils.get(dataKey,new TypeReference<Map<String,String>>(){});
+					if(!MapUtils.isEmpty(dataMap)){
+						resultMap.putAll(dataMap);
+					}
+				}
+			}
+			return  resultMap;
+		}).collect(Collectors.toList());
+		return list;
+	}
+
+	@Override
+	public Device queryById(Integer id) {
+		return deviceMapper.selectByPrimaryKey(id);
+	}
+
+	@Override
+	public List<Device> getDevicesByProfessionId(Map<String, Object> parameters) {
+		
+		return deviceMapper.getDevicesByProfession(parameters);
+	}
+
 }

--
Gitblit v1.8.0