From 5c427a35595e2deb2c1a025ff9a4c164d498e01d Mon Sep 17 00:00:00 2001
From: jinpengyong <jpy123456>
Date: Fri, 24 Dec 2021 11:00:44 +0800
Subject: [PATCH] 行业贡献率:行业列表,传感器列表接口
---
screen-api/src/main/java/com/moral/api/service/ProfessionService.java | 13 ++++
screen-api/src/main/java/com/moral/api/service/impl/ProfessionServiceImpl.java | 86 ++++++++++++++++++++++++++++
screen-api/src/main/java/com/moral/api/controller/ProfessionController.java | 56 ++++++++++++++++++
3 files changed, 155 insertions(+), 0 deletions(-)
diff --git a/screen-api/src/main/java/com/moral/api/controller/ProfessionController.java b/screen-api/src/main/java/com/moral/api/controller/ProfessionController.java
new file mode 100644
index 0000000..33c95c7
--- /dev/null
+++ b/screen-api/src/main/java/com/moral/api/controller/ProfessionController.java
@@ -0,0 +1,56 @@
+package com.moral.api.controller;
+
+import io.swagger.annotations.Api;
+import io.swagger.annotations.ApiOperation;
+import lombok.extern.slf4j.Slf4j;
+import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.web.bind.annotation.CrossOrigin;
+import org.springframework.web.bind.annotation.GetMapping;
+import org.springframework.web.bind.annotation.RequestMapping;
+import org.springframework.web.bind.annotation.RestController;
+
+import java.util.List;
+import java.util.Map;
+import java.util.Set;
+
+import javax.servlet.http.HttpServletRequest;
+
+import com.baomidou.mybatisplus.core.toolkit.ObjectUtils;
+import com.moral.api.service.ProfessionService;
+import com.moral.constant.ResponseCodeEnum;
+import com.moral.constant.ResultMessage;
+import com.moral.util.WebUtils;
+
+@Slf4j
+@Api(tags = {"���������������������"})
+@RestController
+@CrossOrigin(origins = "*", maxAge = 3600)
+@RequestMapping("/profession")
+public class ProfessionController {
+
+ @Autowired
+ private ProfessionService professionService;
+
+ @ApiOperation(value = "������������id������������������������������", notes = "������������id������������������������������")
+ @GetMapping("getProfessionsByOrganizationId")
+ public ResultMessage getProfessions(Integer organizationId) {
+ if (ObjectUtils.isEmpty(organizationId)) {
+ return ResultMessage.fail(ResponseCodeEnum.PARAMETERS_IS_MISSING.getCode(),
+ ResponseCodeEnum.PARAMETERS_IS_MISSING.getMsg());
+ }
+ Set<Map<String, Object>> response = professionService.getProfessionsByOrganizationId(organizationId);
+ return ResultMessage.ok(response);
+ }
+
+ @ApiOperation(value = "���������������������������������������������", notes = "���������������������������������������������")
+ @GetMapping("getSensorByProfessions")
+ public ResultMessage getProfessions(HttpServletRequest request) {
+ Map<String, Object> params = WebUtils.getParametersStartingWith(request, null);
+ if (ObjectUtils.isEmpty(params.get("organizationId")) || ObjectUtils.isEmpty(params.get("professions"))) {
+ return ResultMessage.fail(ResponseCodeEnum.PARAMETERS_IS_MISSING.getCode(),
+ ResponseCodeEnum.PARAMETERS_IS_MISSING.getMsg());
+ }
+ Set<Map<String, Object>> response = professionService.getSensorByProfessionsAndOrganizationId(params);
+ return ResultMessage.ok(response);
+ }
+}
diff --git a/screen-api/src/main/java/com/moral/api/service/ProfessionService.java b/screen-api/src/main/java/com/moral/api/service/ProfessionService.java
new file mode 100644
index 0000000..ba24c92
--- /dev/null
+++ b/screen-api/src/main/java/com/moral/api/service/ProfessionService.java
@@ -0,0 +1,13 @@
+package com.moral.api.service;
+
+import java.util.Map;
+import java.util.Set;
+
+public interface ProfessionService {
+
+ //������������id���������������������������������������������
+ Set<Map<String, Object>> getProfessionsByOrganizationId(Integer organizationId);
+
+ //������������������������������������������
+ Set<Map<String, Object>> getSensorByProfessionsAndOrganizationId(Map<String, Object> params);
+}
diff --git a/screen-api/src/main/java/com/moral/api/service/impl/ProfessionServiceImpl.java b/screen-api/src/main/java/com/moral/api/service/impl/ProfessionServiceImpl.java
new file mode 100644
index 0000000..d67599f
--- /dev/null
+++ b/screen-api/src/main/java/com/moral/api/service/impl/ProfessionServiceImpl.java
@@ -0,0 +1,86 @@
+package com.moral.api.service.impl;
+
+import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.data.redis.core.RedisTemplate;
+import org.springframework.stereotype.Service;
+
+import java.util.Arrays;
+import java.util.HashMap;
+import java.util.HashSet;
+import java.util.List;
+import java.util.Map;
+import java.util.Set;
+import java.util.stream.Collectors;
+
+import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
+import com.moral.api.entity.Device;
+import com.moral.api.entity.Sensor;
+import com.moral.api.service.DeviceService;
+import com.moral.api.service.ProfessionService;
+import com.moral.constant.Constants;
+import com.moral.constant.RedisConstants;
+
+/**
+ * <p>
+ * ���������������������������
+ * </p>
+ *
+ * @author moral
+ * @since 2021-12-23
+ */
+@Service
+public class ProfessionServiceImpl implements ProfessionService {
+
+ @Autowired
+ private DeviceService deviceService;
+
+ @Autowired
+ private RedisTemplate redisTemplate;
+
+ @Override
+ public Set<Map<String, Object>> getProfessionsByOrganizationId(Integer organizationId) {
+ //������������������������������
+ List<Map<String, Object>> devices = deviceService.getDevicesByOrganizationId(organizationId);
+ Set<Map<String, Object>> result = new HashSet<>();
+ for (Map<String, Object> device : devices) {
+ List<Map<String, Object>> professions = (List<Map<String, Object>>) device.get("professions");
+ result.addAll(professions);
+ }
+ return result;
+ }
+
+ @Override
+ public Set<Map<String, Object>> getSensorByProfessionsAndOrganizationId(Map<String, Object> params) {
+ Set<Map<String, Object>> result = new HashSet<>();
+ //���������������������������������
+ Integer orgId = Integer.parseInt(params.get("organizationId").toString());
+ List<String> professions = Arrays.asList(params.get("professions").toString().split(","));
+ QueryWrapper<Device> queryWrapper = new QueryWrapper<>();
+ queryWrapper.select("mac", "profession")
+ .eq("organization_id", orgId)
+ .eq("is_delete", Constants.NOT_DELETE);
+ List<Device> devices = deviceService.list(queryWrapper);
+ devices = devices.stream().filter(device -> {
+ String[] list = device.getProfession().split(",");
+ for (String s : list) {
+ if (professions.contains(s)) {
+ return true;
+ }
+ }
+ return false;
+ }).collect(Collectors.toList());
+
+ //���redis������������������������
+ for (Device device : devices) {
+ device = (Device) redisTemplate.opsForHash().get(RedisConstants.DEVICE_INFO, device.getMac());
+ List<Sensor> sensors = device.getVersion().getSensors();
+ for (Sensor sensor : sensors) {
+ Map<String, Object> sensorMap = new HashMap<>();
+ sensorMap.put("sensorCode", sensor.getCode());
+ sensorMap.put("sensorName", sensor.getName());
+ result.add(sensorMap);
+ }
+ }
+ return result;
+ }
+}
--
Gitblit v1.8.0