From 4784ba9b5fe0d2c9ada694834ac6b0d0b7474b89 Mon Sep 17 00:00:00 2001
From: lizijie <lzjiiie@163.com>
Date: Thu, 12 Aug 2021 15:52:23 +0800
Subject: [PATCH] special_device、special_device_history相关文件,special_device查询接口

---
 screen-manage/src/main/java/com/moral/api/entity/SpecialDeviceHistory.java                  |   84 +++++++++
 screen-manage/src/main/java/com/moral/api/service/SpecialDeviceService.java                 |   20 ++
 screen-manage/src/main/java/com/moral/api/service/impl/SpecialDeviceHistoryServiceImpl.java |   20 ++
 screen-manage/src/main/resources/mapper/SpecialDeviceMapper.xml                             |   19 ++
 screen-manage/src/main/java/com/moral/api/mapper/SpecialDeviceMapper.java                   |   16 +
 screen-manage/src/main/resources/mapper/SpecialDeviceHistoryMapper.xml                      |   19 ++
 screen-manage/src/main/java/com/moral/api/entity/SpecialDevice.java                         |   84 +++++++++
 screen-manage/src/main/java/com/moral/api/mapper/SpecialDeviceHistoryMapper.java            |   16 +
 screen-manage/src/main/java/com/moral/api/service/impl/SpecialDeviceServiceImpl.java        |  178 +++++++++++++++++++
 screen-manage/src/main/java/com/moral/api/service/SpecialDeviceHistoryService.java          |   16 +
 screen-manage/src/main/java/com/moral/api/controller/SpecialDeviceController.java           |   36 ++++
 11 files changed, 508 insertions(+), 0 deletions(-)

diff --git a/screen-manage/src/main/java/com/moral/api/controller/SpecialDeviceController.java b/screen-manage/src/main/java/com/moral/api/controller/SpecialDeviceController.java
new file mode 100644
index 0000000..d8dad90
--- /dev/null
+++ b/screen-manage/src/main/java/com/moral/api/controller/SpecialDeviceController.java
@@ -0,0 +1,36 @@
+package com.moral.api.controller;
+
+import com.moral.api.service.SpecialDeviceService;
+import com.moral.constant.ResultMessage;
+import com.moral.util.WebUtils;
+import io.swagger.annotations.Api;
+import lombok.extern.slf4j.Slf4j;
+import org.springframework.web.bind.annotation.RequestMapping;
+import org.springframework.web.bind.annotation.RequestMethod;
+import org.springframework.web.bind.annotation.ResponseBody;
+import org.springframework.web.bind.annotation.RestController;
+
+import javax.annotation.Resource;
+import javax.servlet.http.HttpServletRequest;
+import java.util.Map;
+
+@Slf4j
+@Api(tags = {"������������"})
+@RestController
+@RequestMapping("/specialDevice")
+public class SpecialDeviceController {
+
+    @Resource
+    private SpecialDeviceService specialDeviceService;
+
+    @RequestMapping(value = "getSpecialDeviceByCondition", method = RequestMethod.GET)
+    @ResponseBody
+    public ResultMessage getSpecialDeviceByCondition(HttpServletRequest request) {
+        Map<String,Object> parameters = WebUtils.getParametersStartingWith(request,null);
+        Map<String,Object> resultMap = specialDeviceService.getDataByCondition(parameters);
+        if (!resultMap.containsKey("code")){
+            return ResultMessage.ok(resultMap);
+        }
+        return ResultMessage.fail(Integer.parseInt(resultMap.get("code").toString()),resultMap.get("msg").toString());
+    }
+}
diff --git a/screen-manage/src/main/java/com/moral/api/entity/SpecialDevice.java b/screen-manage/src/main/java/com/moral/api/entity/SpecialDevice.java
new file mode 100644
index 0000000..ef614d2
--- /dev/null
+++ b/screen-manage/src/main/java/com/moral/api/entity/SpecialDevice.java
@@ -0,0 +1,84 @@
+package com.moral.api.entity;
+
+import com.baomidou.mybatisplus.annotation.IdType;
+import com.baomidou.mybatisplus.extension.activerecord.Model;
+import com.baomidou.mybatisplus.annotation.TableId;
+import java.time.LocalDateTime;
+import java.io.Serializable;
+import java.util.Date;
+
+import lombok.Data;
+import lombok.EqualsAndHashCode;
+
+/**
+ * <p>
+ * 
+ * </p>
+ *
+ * @author moral
+ * @since 2021-08-11
+ */
+@Data
+@EqualsAndHashCode(callSuper = false)
+public class SpecialDevice extends Model<SpecialDevice> {
+
+    private static final long serialVersionUID = 1L;
+
+    /**
+     * id
+     */
+    @TableId(value = "id", type = IdType.AUTO)
+    private Integer id;
+
+    /**
+     * ������������
+     */
+    private String name;
+
+    /**
+     * mac���
+     */
+    private String mac;
+
+    /**
+     * ���������id���������������������������������manage_account
+     */
+    private String operateIds;
+
+    /**
+     * ������������������id
+     */
+    private Integer organizationId;
+
+    /**
+     * ������������������id
+     */
+    private Integer deviceVersionId;
+
+    /**
+     * ���������������������������������������
+     */
+    private String specialType;
+
+    /**
+     * ������������
+     */
+    private Date createTime;
+
+    /**
+     * ������������
+     */
+    private Date updateTime;
+
+    /**
+     * ������������,0���������������1���������
+     */
+    private String isDelete;
+
+
+    @Override
+    protected Serializable pkVal() {
+        return this.id;
+    }
+
+}
diff --git a/screen-manage/src/main/java/com/moral/api/entity/SpecialDeviceHistory.java b/screen-manage/src/main/java/com/moral/api/entity/SpecialDeviceHistory.java
new file mode 100644
index 0000000..00d1962
--- /dev/null
+++ b/screen-manage/src/main/java/com/moral/api/entity/SpecialDeviceHistory.java
@@ -0,0 +1,84 @@
+package com.moral.api.entity;
+
+import com.baomidou.mybatisplus.annotation.IdType;
+import com.baomidou.mybatisplus.extension.activerecord.Model;
+import com.baomidou.mybatisplus.annotation.TableId;
+import java.time.LocalDateTime;
+import java.io.Serializable;
+import java.util.Date;
+
+import lombok.Data;
+import lombok.EqualsAndHashCode;
+
+/**
+ * <p>
+ * 
+ * </p>
+ *
+ * @author moral
+ * @since 2021-08-11
+ */
+@Data
+@EqualsAndHashCode(callSuper = false)
+public class SpecialDeviceHistory extends Model<SpecialDeviceHistory> {
+
+    private static final long serialVersionUID = 1L;
+
+    /**
+     * id
+     */
+    @TableId(value = "id", type = IdType.AUTO)
+    private Integer id;
+
+    /**
+     * ������������
+     */
+    private String name;
+
+    /**
+     * ������mac���
+     */
+    private String mac;
+
+    /**
+     * ���������id���������������������������������manage_account
+     */
+    private String operateIds;
+
+    /**
+     * ������������id
+     */
+    private Integer organizationId;
+
+    /**
+     * ������������id
+     */
+    private Integer deviceVersionId;
+
+    /**
+     * ���������������������������������������
+     */
+    private String specialType;
+
+    /**
+     * ������������
+     */
+    private Date createTime;
+
+    /**
+     * ������������
+     */
+    private Date updateTime;
+
+    /**
+     * ������������,0���������������1���������
+     */
+    private String isDelete;
+
+
+    @Override
+    protected Serializable pkVal() {
+        return this.id;
+    }
+
+}
diff --git a/screen-manage/src/main/java/com/moral/api/mapper/SpecialDeviceHistoryMapper.java b/screen-manage/src/main/java/com/moral/api/mapper/SpecialDeviceHistoryMapper.java
new file mode 100644
index 0000000..6dfa59e
--- /dev/null
+++ b/screen-manage/src/main/java/com/moral/api/mapper/SpecialDeviceHistoryMapper.java
@@ -0,0 +1,16 @@
+package com.moral.api.mapper;
+
+import com.moral.api.entity.SpecialDeviceHistory;
+import com.baomidou.mybatisplus.core.mapper.BaseMapper;
+
+/**
+ * <p>
+ *  Mapper ������
+ * </p>
+ *
+ * @author moral
+ * @since 2021-08-11
+ */
+public interface SpecialDeviceHistoryMapper extends BaseMapper<SpecialDeviceHistory> {
+
+}
diff --git a/screen-manage/src/main/java/com/moral/api/mapper/SpecialDeviceMapper.java b/screen-manage/src/main/java/com/moral/api/mapper/SpecialDeviceMapper.java
new file mode 100644
index 0000000..c5c44bb
--- /dev/null
+++ b/screen-manage/src/main/java/com/moral/api/mapper/SpecialDeviceMapper.java
@@ -0,0 +1,16 @@
+package com.moral.api.mapper;
+
+import com.moral.api.entity.SpecialDevice;
+import com.baomidou.mybatisplus.core.mapper.BaseMapper;
+
+/**
+ * <p>
+ *  Mapper ������
+ * </p>
+ *
+ * @author moral
+ * @since 2021-08-11
+ */
+public interface SpecialDeviceMapper extends BaseMapper<SpecialDevice> {
+
+}
diff --git a/screen-manage/src/main/java/com/moral/api/service/SpecialDeviceHistoryService.java b/screen-manage/src/main/java/com/moral/api/service/SpecialDeviceHistoryService.java
new file mode 100644
index 0000000..2aef4f1
--- /dev/null
+++ b/screen-manage/src/main/java/com/moral/api/service/SpecialDeviceHistoryService.java
@@ -0,0 +1,16 @@
+package com.moral.api.service;
+
+import com.moral.api.entity.SpecialDeviceHistory;
+import com.baomidou.mybatisplus.extension.service.IService;
+
+/**
+ * <p>
+ *  ���������
+ * </p>
+ *
+ * @author moral
+ * @since 2021-08-11
+ */
+public interface SpecialDeviceHistoryService extends IService<SpecialDeviceHistory> {
+
+}
diff --git a/screen-manage/src/main/java/com/moral/api/service/SpecialDeviceService.java b/screen-manage/src/main/java/com/moral/api/service/SpecialDeviceService.java
new file mode 100644
index 0000000..f52d7c9
--- /dev/null
+++ b/screen-manage/src/main/java/com/moral/api/service/SpecialDeviceService.java
@@ -0,0 +1,20 @@
+package com.moral.api.service;
+
+import com.moral.api.entity.SpecialDevice;
+import com.baomidou.mybatisplus.extension.service.IService;
+
+import java.util.List;
+import java.util.Map;
+
+/**
+ * <p>
+ *  ���������
+ * </p>
+ *
+ * @author moral
+ * @since 2021-08-11
+ */
+public interface SpecialDeviceService extends IService<SpecialDevice> {
+
+    Map<String,Object> getDataByCondition(Map map);
+}
diff --git a/screen-manage/src/main/java/com/moral/api/service/impl/SpecialDeviceHistoryServiceImpl.java b/screen-manage/src/main/java/com/moral/api/service/impl/SpecialDeviceHistoryServiceImpl.java
new file mode 100644
index 0000000..cd44849
--- /dev/null
+++ b/screen-manage/src/main/java/com/moral/api/service/impl/SpecialDeviceHistoryServiceImpl.java
@@ -0,0 +1,20 @@
+package com.moral.api.service.impl;
+
+import com.moral.api.entity.SpecialDeviceHistory;
+import com.moral.api.mapper.SpecialDeviceHistoryMapper;
+import com.moral.api.service.SpecialDeviceHistoryService;
+import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
+import org.springframework.stereotype.Service;
+
+/**
+ * <p>
+ *  ���������������
+ * </p>
+ *
+ * @author moral
+ * @since 2021-08-11
+ */
+@Service
+public class SpecialDeviceHistoryServiceImpl extends ServiceImpl<SpecialDeviceHistoryMapper, SpecialDeviceHistory> implements SpecialDeviceHistoryService {
+
+}
diff --git a/screen-manage/src/main/java/com/moral/api/service/impl/SpecialDeviceServiceImpl.java b/screen-manage/src/main/java/com/moral/api/service/impl/SpecialDeviceServiceImpl.java
new file mode 100644
index 0000000..5038125
--- /dev/null
+++ b/screen-manage/src/main/java/com/moral/api/service/impl/SpecialDeviceServiceImpl.java
@@ -0,0 +1,178 @@
+package com.moral.api.service.impl;
+
+import com.alibaba.fastjson.JSON;
+import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
+import com.baomidou.mybatisplus.core.toolkit.ObjectUtils;
+import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
+import com.moral.api.entity.*;
+import com.moral.api.mapper.*;
+import com.moral.api.service.SpecialDeviceService;
+import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
+import com.moral.constant.Constants;
+import com.moral.constant.ResponseCodeEnum;
+import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.stereotype.Service;
+
+import java.text.SimpleDateFormat;
+import java.util.ArrayList;
+import java.util.HashMap;
+import java.util.List;
+import java.util.Map;
+
+/**
+ * <p>
+ *  ���������������
+ * </p>
+ *
+ * @author moral
+ * @since 2021-08-11
+ */
+@Service
+public class SpecialDeviceServiceImpl extends ServiceImpl<SpecialDeviceMapper, SpecialDevice> implements SpecialDeviceService {
+
+    @Autowired(required = false)
+    private SpecialDeviceMapper specialDeviceMapper;
+
+    @Autowired(required = false)
+    private ManageAccountMapper manageAccountMapper;
+
+    @Autowired(required = false)
+    private VersionMapper versionMapper;
+
+    @Autowired(required = false)
+    private SysDictDataMapper sysDictDataMapper;
+
+    @Autowired(required = false)
+    private SpecialDeviceHistoryMapper specialDeviceHistoryMapper;
+
+    @Autowired(required = false)
+    private OrganizationMapper organizationMapper;
+
+    @Override
+    public Map<String, Object> getDataByCondition(Map map) {
+        Map<String,Object> resultMap = new HashMap<>();
+        if (!map.containsKey("current")||!map.containsKey("size")){
+            resultMap.put("code",ResponseCodeEnum.PARAMETERS_IS_MISSING.getCode());
+            resultMap.put("msg",ResponseCodeEnum.PARAMETERS_IS_MISSING.getMsg());
+            return resultMap;
+        }
+        int current = Integer.parseInt(map.get("current").toString());
+        int size = Integer.parseInt(map.get("size").toString());
+        Page<SpecialDevice> page = new Page<>(current,size);
+        QueryWrapper<SpecialDevice> wrapper_Condition = new QueryWrapper<>();
+        wrapper_Condition.eq("is_delete",Constants.NOT_DELETE);
+        if (!ObjectUtils.isEmpty(map.get("organization_id"))){
+            wrapper_Condition.like("organization_id",map.get("organization_id").toString());
+        }
+        if (!ObjectUtils.isEmpty(map.get("keyword"))){
+            wrapper_Condition.like("name",map.get("keyword").toString()).or().like("mac",map.get("keyword").toString());
+        }
+        wrapper_Condition.orderByDesc("create_time");
+        Page resultPage = specialDeviceMapper.selectPage(page,wrapper_Condition);
+        List<SpecialDevice> specialDevices = resultPage.getRecords();
+        SimpleDateFormat SDF = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
+        List<Map<String,Object>> specialDeviceList = new ArrayList<>();
+        for (SpecialDevice specialDevice:specialDevices) {
+            Map specialDeviceMap = JSON.parseObject(JSON.toJSONString(specialDevice),Map.class);
+            String createTime = SDF.format(specialDevice.getCreateTime());
+            String updateTime = SDF.format(specialDevice.getUpdateTime());
+            specialDeviceMap.put("createTime",createTime);
+            specialDeviceMap.put("updateTime",updateTime);
+            List<Map<String,Object>> operateList = new ArrayList<>();
+            if (!ObjectUtils.isEmpty(specialDevice.getOperateIds()) && specialDevice.getOperateIds()!=null){
+                String operateIds = specialDevice.getOperateIds();
+                String[] operateIdArr = operateIds.split(",");
+                if (operateIdArr.length>0){
+                    List<Integer> operateIdList = new ArrayList<>();
+                    for (int i = 0; i < operateIdArr.length; i++){
+                        operateIdList.add(Integer.parseInt(operateIdArr[i]));
+                    }
+                    QueryWrapper<ManageAccount> wapper_manageAccount = new QueryWrapper<>();
+                    wapper_manageAccount.eq("is_delete",Constants.NOT_DELETE);
+                    wapper_manageAccount.in("id",operateIdList);
+                    List<ManageAccount> manageAccounts = manageAccountMapper.selectList(wapper_manageAccount);
+                    for (ManageAccount manageAccount:manageAccounts) {
+                        Map<String,Object> operateMap = new HashMap<>();
+                        operateMap.put("id",manageAccount.getId());
+                        operateMap.put("name",manageAccount.getUserName());
+                        operateList.add(operateMap);
+                    }
+                }
+            }
+            specialDeviceMap.put("operates",operateList);
+            Map<String,Object> deviceVersionMap = new HashMap<>();
+            if (!ObjectUtils.isEmpty(specialDevice.getDeviceVersionId()) && specialDevice.getDeviceVersionId()!=null && !"".equals(specialDevice.getDeviceVersionId())){
+                int versionId = Integer.parseInt(specialDevice.getDeviceVersionId().toString());
+                QueryWrapper<Version> wapper_version = new QueryWrapper<>();
+                wapper_version.eq("is_delete",Constants.NOT_DELETE);
+                wapper_version.eq("id",versionId);
+                Version version = versionMapper.selectOne(wapper_version);
+                if (!ObjectUtils.isEmpty(version)){
+                    deviceVersionMap.put("id",version.getId());
+                    deviceVersionMap.put("name",version.getName());
+                }
+            }
+            specialDeviceMap.put("deviceVersion",deviceVersionMap);
+            Map<String,Object> specialTypeMap = new HashMap<>();
+            if (!ObjectUtils.isEmpty(specialDevice.getSpecialType()) && specialDevice.getSpecialType()!=null && !"".equals(specialDevice.getSpecialType())){
+                int specialTypeId = Integer.parseInt(specialDevice.getSpecialType().toString());
+                QueryWrapper<SysDictData> wapper_sysDictData = new QueryWrapper<>();
+                wapper_sysDictData.eq("is_delete",Constants.NOT_DELETE);
+                wapper_sysDictData.eq("dict_type_id",27);
+                wapper_sysDictData.eq("dataKey",specialTypeId);
+                SysDictData sysDictData = sysDictDataMapper.selectOne(wapper_sysDictData);
+                if (!ObjectUtils.isEmpty(sysDictData)){
+                    specialTypeMap.put("id",sysDictData.getId());
+                    specialTypeMap.put("name",sysDictData.getDataValue());
+                }
+            }
+            specialDeviceMap.put("specialType",specialTypeMap);
+            Map<String,Object> organizationMap = new HashMap<>();
+            if (!ObjectUtils.isEmpty(specialDevice.getOrganizationId()) && specialDevice.getOrganizationId()!=null && !"".equals(specialDevice.getOrganizationId())){
+                int organizationId = Integer.parseInt(specialDevice.getOrganizationId().toString());
+                QueryWrapper<Organization> wapper_organization = new QueryWrapper<>();
+                wapper_organization.eq("is_delete",Constants.NOT_DELETE);
+                wapper_organization.eq("id",organizationId);
+                Organization organization = organizationMapper.selectOne(wapper_organization);
+                if (!ObjectUtils.isEmpty(organization)){
+                    organizationMap.put("id",organization.getId());
+                    organizationMap.put("name",organization.getName());
+                }
+            }
+            specialDeviceMap.put("organazation",organizationMap);
+            List<Map<String,Object>> organizationList = new ArrayList<>();
+            QueryWrapper<SpecialDeviceHistory> wapper_specialDeviceHistory = new QueryWrapper<>();
+            wapper_specialDeviceHistory.eq("is_delete",Constants.NOT_DELETE);
+            wapper_specialDeviceHistory.eq("mac",specialDevice.getMac());
+            List<SpecialDeviceHistory> specialDeviceHistories = specialDeviceHistoryMapper.selectList(wapper_specialDeviceHistory);
+            if (!ObjectUtils.isEmpty(specialDeviceHistories)){
+                List organizationIdList = new ArrayList();
+                for (SpecialDeviceHistory specialDeviceHistory:specialDeviceHistories) {
+                    organizationIdList.add(specialDeviceHistory.getOrganizationId());
+                }
+                QueryWrapper<Organization> wapper_organizationHistory = new QueryWrapper<>();
+                wapper_organizationHistory.eq("is_delete",Constants.NOT_DELETE);
+                wapper_organizationHistory.in("id",organizationIdList);
+                List<Organization> organizations = organizationMapper.selectList(wapper_organizationHistory);
+                for (Organization organization:organizations) {
+                    Map<String,Object> organizationHistoryMap = new HashMap<>();
+                    organizationHistoryMap.put("id",organization.getId());
+                    organizationHistoryMap.put("name",organization.getName());
+                    organizationList.add(organizationHistoryMap);
+                }
+            }
+            specialDeviceMap.put("organizations",organizationList);
+            specialDeviceList.add(specialDeviceMap);
+        }
+        resultMap.put("specialDevices",specialDeviceList);
+        int totalNumber = specialDevices.size();
+        resultMap.put("totalNumber",totalNumber);
+        resultMap.put("current",current);
+        int totalPageNumber = totalNumber/size;
+        if(totalNumber%size != 0){
+            totalPageNumber += 1;
+        }
+        resultMap.put("totalPageNumber",totalPageNumber);
+        return resultMap;
+    }
+}
diff --git a/screen-manage/src/main/resources/mapper/SpecialDeviceHistoryMapper.xml b/screen-manage/src/main/resources/mapper/SpecialDeviceHistoryMapper.xml
new file mode 100644
index 0000000..cf343c3
--- /dev/null
+++ b/screen-manage/src/main/resources/mapper/SpecialDeviceHistoryMapper.xml
@@ -0,0 +1,19 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
+<mapper namespace="com.moral.api.mapper.SpecialDeviceHistoryMapper">
+
+        <!-- ������������������������ -->
+        <resultMap id="BaseResultMap" type="com.moral.api.entity.SpecialDeviceHistory">
+                    <id column="id" property="id" />
+                    <result column="name" property="name" />
+                    <result column="mac" property="mac" />
+                    <result column="operate_ids" property="operateIds" />
+                    <result column="organization_id" property="organizationId" />
+                    <result column="device_version_id" property="deviceVersionId" />
+                    <result column="special_type" property="specialType" />
+                    <result column="create_time" property="createTime" />
+                    <result column="update_time" property="updateTime" />
+                    <result column="is_delete" property="isDelete" />
+        </resultMap>
+
+</mapper>
\ No newline at end of file
diff --git a/screen-manage/src/main/resources/mapper/SpecialDeviceMapper.xml b/screen-manage/src/main/resources/mapper/SpecialDeviceMapper.xml
new file mode 100644
index 0000000..db8b4e6
--- /dev/null
+++ b/screen-manage/src/main/resources/mapper/SpecialDeviceMapper.xml
@@ -0,0 +1,19 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
+<mapper namespace="com.moral.api.mapper.SpecialDeviceMapper">
+
+        <!-- ������������������������ -->
+        <resultMap id="BaseResultMap" type="com.moral.api.entity.SpecialDevice">
+                    <id column="id" property="id" />
+                    <result column="name" property="name" />
+                    <result column="mac" property="mac" />
+                    <result column="operate_ids" property="operateIds" />
+                    <result column="organization_id" property="organizationId" />
+                    <result column="device_version_id" property="deviceVersionId" />
+                    <result column="special_type" property="specialType" />
+                    <result column="create_time" property="createTime" />
+                    <result column="update_time" property="updateTime" />
+                    <result column="is_delete" property="isDelete" />
+        </resultMap>
+
+</mapper>
\ No newline at end of file

--
Gitblit v1.8.0