DeviceRegisterServiceImpl.java 16 KB

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