DeviceRegisterServiceImpl.java 16 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347
  1. package com.xy.service;
  2. import com.alibaba.excel.EasyExcel;
  3. import com.alibaba.excel.context.AnalysisContext;
  4. import com.alibaba.excel.read.listener.ReadListener;
  5. import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
  6. import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
  7. import com.baomidou.mybatisplus.core.conditions.update.LambdaUpdateWrapper;
  8. import com.baomidou.mybatisplus.core.metadata.IPage;
  9. import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
  10. import com.xy.annotation.Lock;
  11. import com.xy.collections.list.JArrayList;
  12. import com.xy.collections.list.JList;
  13. import com.xy.collections.map.JMap;
  14. import com.xy.config.DeviceThreadPoolConfig;
  15. import com.xy.dto.DeviceCreateIdsDto;
  16. import com.xy.dto.DeviceQualityDto;
  17. import com.xy.dto.DeviceRegisterDto;
  18. import com.xy.dto.MqttUserDto;
  19. import com.xy.entity.*;
  20. import com.xy.mapper.*;
  21. import com.xy.utils.*;
  22. import com.xy.utils.consts.CommConsts;
  23. import io.swagger.annotations.Api;
  24. import io.swagger.annotations.ApiModelProperty;
  25. import io.swagger.annotations.ApiOperation;
  26. import lombok.AllArgsConstructor;
  27. import lombok.Data;
  28. import lombok.RequiredArgsConstructor;
  29. import lombok.extern.slf4j.Slf4j;
  30. import org.springframework.stereotype.Service;
  31. import org.springframework.transaction.annotation.Transactional;
  32. import org.springframework.validation.annotation.Validated;
  33. import org.springframework.web.bind.annotation.PostMapping;
  34. import org.springframework.web.bind.annotation.RequestBody;
  35. import org.springframework.web.bind.annotation.RequestParam;
  36. import org.springframework.web.multipart.MultipartFile;
  37. import javax.validation.constraints.NotBlank;
  38. import java.io.IOException;
  39. import java.time.LocalDateTime;
  40. import java.util.ArrayList;
  41. import java.util.List;
  42. import static com.xy.utils.PlusBeans.*;
  43. /**
  44. * <p>
  45. * 设备-注册登记 服务实现类
  46. * </p>
  47. *
  48. * @author lijin
  49. * @since 2022-12-29
  50. */
  51. @Service
  52. @Api(tags = "设备-注册登记")
  53. @AllArgsConstructor
  54. public class DeviceRegisterServiceImpl extends ServiceImpl<DeviceRegisterMapper, DeviceRegister> implements DeviceRegisterService {
  55. private DeviceCreateIdsMapper deviceCreateIdsMapper;
  56. private DeviceInfoMapper deviceInfoMapper;
  57. private DeviceSysinfoMapper deviceSysinfoMapper;
  58. private DeviceStatusMapper deviceStatusMapper;
  59. private DeviceQualityServiceImpl deviceQualityService;
  60. private MqttUserServiceImpl mqttUserService;
  61. private DeviceSysinfoServiceImpl deviceSysinfoService;
  62. private DeviceCreateIdsServiceImpl deviceCreateIdsService;
  63. @PostMapping("save")
  64. @ApiOperation("添加")
  65. @Transactional(rollbackFor = Exception.class)
  66. @Lock(value = "save.deviceId", prefix = "device_register_")
  67. public R save(@RequestBody @Validated DeviceRegisterDto.Save save) {
  68. //重复校验
  69. DeviceRegister deviceRegister = copy(DeviceRegister.class, save);
  70. DeviceCreateIds deviceCreateIds = deviceCreateIdsMapper.selectById(deviceRegister.getDeviceId());
  71. if (deviceCreateIds == null) {
  72. return R.fail("设备ID不存在");
  73. }
  74. if (deviceCreateIds.getBindState()) {
  75. return R.fail("设备ID已被绑定");
  76. }
  77. long count = count(new LambdaQueryWrapper<DeviceRegister>().eq(DeviceRegister::getDeviceSn, save.getDeviceSn()));
  78. if (count > 0) {
  79. return R.fail("设备SN已被绑定");
  80. }
  81. deviceRegister.setDeviceType(deviceCreateIds.getDeviceType())
  82. .setCreateUser(AuthorizeUtils.getLoginId(Long.class))
  83. .setCreateTime(LocalDateTime.now());
  84. //操作注册序号
  85. String property = LambdaUtils.getProperty(DeviceRegister::getRegisterNum);
  86. QueryWrapper<DeviceRegister> queryWrapper = new QueryWrapper<DeviceRegister>()
  87. .select(String.format("max(%s) as %s", StringTools.humpToLine(property), property))
  88. .eq(StringTools.humpToLine(LambdaUtils.getProperty(DeviceRegister::getCreateUser)), AuthorizeUtils.getLoginId(Long.class));
  89. DeviceRegister one = getOne(queryWrapper);
  90. Integer registerNum = one == null || one.getRegisterNum() == null ? 0 : one.getRegisterNum();
  91. deviceRegister.setRegisterNum(registerNum + 1);
  92. //修改设备-机器ID号生成为已绑定
  93. deviceCreateIdsMapper.updateById(new DeviceCreateIds()
  94. .setDeviceId(deviceRegister.getDeviceId())
  95. .setBindState(true)
  96. .setBindTime(deviceRegister.getCreateTime())
  97. );
  98. DeviceInfo deviceInfo = new DeviceInfo()
  99. .setDeviceId(deviceRegister.getDeviceId())
  100. .setDeviceType(deviceRegister.getDeviceType())
  101. .setMercDeviceCode(deviceRegister.getAssetNo())
  102. .setCreateTime(deviceRegister.getCreateTime());
  103. DeviceSysinfo deviceSysinfo = new DeviceSysinfo()
  104. .setDeviceId(deviceRegister.getDeviceId())
  105. .setDeviceSn(deviceRegister.getDeviceSn())
  106. .setCreateTime(deviceRegister.getCreateTime());
  107. DeviceStatus deviceStatus = new DeviceStatus().setDeviceId(deviceRegister.getDeviceId());
  108. DeviceRegister deviceRegisterById = getById(deviceRegister.getDeviceId());
  109. //新增
  110. if (deviceRegisterById == null) {
  111. //设备-注册登记
  112. save(deviceRegister);
  113. //设备信息
  114. deviceInfoMapper.insert(deviceInfo);
  115. //设备-系统信息
  116. deviceSysinfoMapper.insert(deviceSysinfo);
  117. //设备-状态
  118. deviceStatusMapper.insert(deviceStatus);
  119. //mqtt认证信息
  120. String deviceId = deviceRegister.getDeviceId().toString();
  121. MqttUserDto.Save mqttUserInfo = new MqttUserDto.Save();
  122. mqttUserInfo.setUsername(deviceId);
  123. mqttUserInfo.setPasswordHash(deviceId);
  124. mqttUserInfo.setCreated(LocalDateTime.now());
  125. mqttUserInfo.setTopic(deviceId + CommConsts.DEVICE_MQTT_TOPIC_SUFFIX);
  126. mqttUserInfo.setSn(deviceRegister.getDeviceSn());
  127. mqttUserInfo.setDeviceId(deviceRegister.getDeviceId());
  128. mqttUserService.save(mqttUserInfo);
  129. } else {
  130. updateById(deviceRegister);
  131. deviceSysinfoMapper.updateById(deviceSysinfo);
  132. mqttUserService.update(new LambdaUpdateWrapper<MqttUser>()
  133. .set(MqttUser::getSn, deviceRegister.getDeviceSn())
  134. .eq(MqttUser::getDeviceId, deviceRegister.getDeviceId())
  135. );
  136. }
  137. return R.ok();
  138. }
  139. @PostMapping("page")
  140. @ApiOperation("分页查询")
  141. public R<PageBean<DeviceRegisterDto.Vo>> page(@RequestBody DeviceRegisterDto.Page page) {
  142. PageBean pageBean = page.getPage();
  143. LambdaQueryWrapper<DeviceRegister> lambdaQueryWrapper = new MybatisPlusQuery().eqWrapper(page, DeviceRegister.class)
  144. .ge(DeviceRegister::getCreateTime, page.getBeginCreateTime())
  145. .le(DeviceRegister::getCreateTime, page.getEndCreateTime())
  146. .likeRight(DeviceRegister::getDeviceSn)
  147. .build()
  148. .and(page.getIsBind() != null && page.getIsBind(), deviceRegisterLambdaQueryWrapper -> deviceRegisterLambdaQueryWrapper
  149. .isNotNull(DeviceRegister::getDeviceSn)
  150. .ne(DeviceRegister::getDeviceSn, "")
  151. )
  152. .and(page.getIsBind() != null && !page.getIsBind(), deviceRegisterLambdaQueryWrapper -> deviceRegisterLambdaQueryWrapper
  153. .isNull(DeviceRegister::getDeviceSn)
  154. .or()
  155. .eq(DeviceRegister::getDeviceSn, "")
  156. )
  157. .orderByDesc(!Emptys.check(pageBean.getOrders()), DeviceRegister::getCreateTime);
  158. IPage<DeviceRegister> iPage = page(toIPage(pageBean), lambdaQueryWrapper);
  159. PageBean<DeviceRegisterDto.Vo> voPageBean = toPageBean(DeviceRegisterDto.Vo.class, iPage);
  160. List<DeviceRegisterDto.Vo> deviceRegisters = voPageBean.getRecords();
  161. if (deviceRegisters.size() > 0) {
  162. JList<Long> deviceIds = new JArrayList<>(deviceRegisters).getProperty(DeviceRegisterDto.Vo::getDeviceId);
  163. List<DeviceQualityDto.Vo> vos = deviceQualityService.list(new DeviceQualityDto.SelectList().setDeviceIds(deviceIds)
  164. .setShowStatus(true)
  165. ).getData();
  166. JMap<Long, DeviceQualityDto.Vo> map = new JArrayList<>(vos).toMap(DeviceQualityDto.Vo::getDeviceId).cover();
  167. for (DeviceRegisterDto.Vo deviceRegister : deviceRegisters) {
  168. DeviceQualityDto.Vo vo = map.get(deviceRegister.getDeviceId());
  169. if (vo != null) {
  170. deviceRegister.setFactoryState(vo.getFactoryState()).setQualityState(vo.getQualityState());
  171. }
  172. }
  173. }
  174. return R.ok(voPageBean);
  175. }
  176. @PostMapping("obj")
  177. @ApiOperation("对象查询")
  178. public R<DeviceRegisterDto.Vo> obj(@RequestBody DeviceRegisterDto.Vo vo) {
  179. LambdaQueryWrapper<DeviceRegister> lambdaQueryWrapper = new MybatisPlusQuery().eqWrapper(vo, DeviceRegister.class).build();
  180. List<DeviceRegister> list = list(lambdaQueryWrapper);
  181. if (!Emptys.check(list)) {
  182. return R.ok();
  183. }
  184. DeviceRegisterDto.Vo deviceRegister = copy(DeviceRegisterDto.Vo.class, list.get(0));
  185. DeviceQualityDto.Vo deviceQuality = deviceQualityService.obj(new DeviceQualityDto.Obj()
  186. .setDeviceId(deviceRegister.getDeviceId())
  187. .setShowStatus(true)
  188. ).getData();
  189. if (deviceQuality != null) {
  190. deviceRegister.setFactoryState(deviceQuality.getFactoryState()).setQualityState(deviceQuality.getQualityState());
  191. }
  192. return R.ok(deviceRegister);
  193. }
  194. @PostMapping("list")
  195. @ApiOperation("集合查询")
  196. public R<List<DeviceRegisterDto.Vo>> list(@RequestBody DeviceRegisterDto.SelectList selectList) {
  197. LambdaQueryWrapper<DeviceRegister> lambdaQueryWrapper = new MybatisPlusQuery().eqWrapper(selectList, DeviceRegister.class)
  198. .in(DeviceRegister::getDeviceId, selectList.getDeviceIds())
  199. .in(DeviceRegister::getDeviceSn, selectList.getDeviceSns())
  200. .in(DeviceRegister::getDeviceType, selectList.getDeviceTypes())
  201. .in(DeviceRegister::getDevicePc, selectList.getDevicePcs())
  202. .in(DeviceRegister::getAssetNo, selectList.getAssetNos())
  203. .build();
  204. List<DeviceRegister> list = list(lambdaQueryWrapper);
  205. return R.ok(copy(DeviceRegisterDto.Vo.class, list));
  206. }
  207. @ApiOperation("修改sn")
  208. @PostMapping("updateSn")
  209. @Transactional(rollbackFor = Exception.class)
  210. public R updateSn(@RequestBody @Validated DeviceRegisterDto.UpdateSn updateSn) {
  211. //校验
  212. String deviceSn = updateSn.getDeviceSn();
  213. Long deviceId = updateSn.getDeviceId();
  214. if (Emptys.check(deviceSn)) {
  215. DeviceRegister deviceRegister = getById(deviceId);
  216. if (!deviceSn.equals(deviceRegister.getDeviceSn())) {
  217. long count = count(new LambdaQueryWrapper<DeviceRegister>().eq(DeviceRegister::getDeviceSn, deviceSn));
  218. if (count > 0) {
  219. return R.fail("sn号已被绑定");
  220. }
  221. }
  222. }
  223. //修改注册等级
  224. update(new LambdaUpdateWrapper<DeviceRegister>()
  225. .set(DeviceRegister::getDeviceSn, updateSn.getDeviceSn())
  226. .eq(DeviceRegister::getDeviceId, deviceId));
  227. //修改系统信息
  228. deviceSysinfoService.update(new LambdaUpdateWrapper<DeviceSysinfo>()
  229. .set(DeviceSysinfo::getDeviceSn, updateSn.getDeviceSn())
  230. .eq(DeviceSysinfo::getDeviceId, deviceId));
  231. //修改mqtt认证
  232. mqttUserService.update(new LambdaUpdateWrapper<MqttUser>()
  233. .set(MqttUser::getSn, deviceSn)
  234. .eq(MqttUser::getDeviceId, deviceId));
  235. //机器ID号生成清除绑定
  236. if (!Emptys.check(deviceSn)) {
  237. deviceCreateIdsService.update(new LambdaUpdateWrapper<DeviceCreateIds>()
  238. .set(DeviceCreateIds::getBindState, false)
  239. .set(DeviceCreateIds::getBindTime, null)
  240. .eq(DeviceCreateIds::getDeviceId, deviceId)
  241. );
  242. }
  243. return R.ok();
  244. }
  245. @ApiOperation("上传sn注册设备")
  246. @PostMapping("uploadSaveBySn")
  247. public R uploadSaveBySn(@RequestParam("file") MultipartFile file, @RequestParam("deviceType") Integer deviceType, @RequestParam("devicePc") String devicePc, @RequestParam("assetNo") String assetNo) {
  248. ThreadPoolUtils.excPoll(DeviceThreadPoolConfig.DEVICE_COMMON_POLL, 1)
  249. .execute(() -> {
  250. try {
  251. EasyExcel.read(file.getInputStream(), UploadSaveBySn.class, new UploadSaveBySnListener(deviceCreateIdsService, this, deviceType, devicePc, assetNo)).sheet().doRead();
  252. } catch (IOException e) {
  253. log.error("", e);
  254. }
  255. });
  256. return R.ok();
  257. }
  258. @Slf4j
  259. @RequiredArgsConstructor
  260. public static class UploadSaveBySnListener implements ReadListener<UploadSaveBySn> {
  261. private final DeviceCreateIdsServiceImpl deviceCreateIdsService;
  262. private final DeviceRegisterServiceImpl deviceRegisterService;
  263. private final Integer deviceType;
  264. private final String devicePc;
  265. private final String assetNo;
  266. private List<UploadSaveBySn> sns = new ArrayList<>();
  267. /**
  268. * 这个每一条数据解析都会来调用
  269. *
  270. * @param data one row value. Is is same as {@link AnalysisContext#readRowHolder()}
  271. * @param context
  272. */
  273. @Override
  274. public void invoke(UploadSaveBySn data, AnalysisContext context) {
  275. sns.add(data);
  276. }
  277. /**
  278. * 所有数据解析完成了 都会来调用
  279. *
  280. * @param context
  281. */
  282. @Override
  283. public void doAfterAllAnalysed(AnalysisContext context) {
  284. log.info("上传sn注册设备文件解析完毕,总数量:{},批次:{}", sns.size(), devicePc);
  285. //生成设备号
  286. JList<DeviceCreateIds> deviceCreateIds = deviceCreateIdsService.save(new DeviceCreateIdsDto.Save()
  287. .setDeviceType(deviceType)
  288. .setDoorType("1")
  289. .setCreatePc(devicePc)
  290. .setNum(sns.size())
  291. ).getData();
  292. JList<Long> deviceIds = deviceCreateIds.getProperty(DeviceCreateIds::getDeviceId);
  293. //注册设备
  294. ThreadPoolUtils.Execute execute = ThreadPoolUtils.excPoll(DeviceThreadPoolConfig.DEVICE_COMMON_POLL, sns.size());
  295. for (int i = 0; i < sns.size(); i++) {
  296. UploadSaveBySn sn = sns.get(i);
  297. Long deviceId = deviceIds.get(i);
  298. execute.execute(() -> {
  299. DeviceRegisterDto.Save save = new DeviceRegisterDto.Save()
  300. .setDeviceId(deviceId)
  301. .setDeviceSn(sn.getSn())
  302. .setDevicePc(devicePc)
  303. .setAssetNo(assetNo);
  304. R r = deviceRegisterService.save(save);
  305. if (r.getCode() == R.Enum.FAIL.getCode()) {
  306. log.error("{},{}", sn.getSn(), r.getMsg());
  307. }
  308. });
  309. }
  310. execute.end();
  311. log.info("上传sn注册设备注册完毕,批次:{}", devicePc);
  312. }
  313. }
  314. @Data
  315. public static class UploadSaveBySn {
  316. private String sn;
  317. }
  318. }