MouldEquipmentServiceImpl.java 22 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447
  1. package com.hssx.cloudmodel.service.impl;
  2. import com.alibaba.fastjson.JSON;
  3. import com.alibaba.fastjson.JSONObject;
  4. import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
  5. import com.github.pagehelper.PageHelper;
  6. import com.github.pagehelper.PageInfo;
  7. import com.hssx.cloudmodel.constant.Constant;
  8. import com.hssx.cloudmodel.entity.*;
  9. import com.hssx.cloudmodel.entity.vo.MouldEquipmentVO;
  10. import com.hssx.cloudmodel.entity.vo.UserVO;
  11. import com.hssx.cloudmodel.mapper.*;
  12. import com.hssx.cloudmodel.service.MouldEquipmentService;
  13. import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
  14. import com.hssx.cloudmodel.util.*;
  15. import org.apache.commons.lang3.StringEscapeUtils;
  16. import org.apache.poi.ss.usermodel.Cell;
  17. import org.apache.poi.xssf.usermodel.XSSFCell;
  18. import org.apache.poi.xssf.usermodel.XSSFRow;
  19. import org.apache.poi.xssf.usermodel.XSSFSheet;
  20. import org.apache.poi.xssf.usermodel.XSSFWorkbook;
  21. import org.springframework.stereotype.Service;
  22. import org.springframework.web.bind.annotation.RequestParam;
  23. import org.springframework.web.multipart.MultipartFile;
  24. import javax.annotation.Resource;
  25. import java.io.*;
  26. import java.security.KeyManagementException;
  27. import java.security.NoSuchAlgorithmException;
  28. import java.security.NoSuchProviderException;
  29. import java.text.SimpleDateFormat;
  30. import java.time.LocalDateTime;
  31. import java.time.LocalTime;
  32. import java.util.*;
  33. import java.util.stream.Collectors;
  34. /**
  35. * <p>
  36. * 服务实现类
  37. * </p>
  38. *
  39. * @author 吴涛涛
  40. * @since 2019-08-02
  41. */
  42. @Service
  43. public class MouldEquipmentServiceImpl extends ServiceImpl<MouldEquipmentMapper, MouldEquipment> implements MouldEquipmentService {
  44. @Resource
  45. MouldEquipmentMapper mouldEquipmentMapper;
  46. @Resource
  47. MouldMapper mouldMapper;
  48. @Resource
  49. UserMapper userMapper;
  50. @Resource
  51. NewsNoticeMapper newsNoticeMapper;
  52. @Resource
  53. NewsNoticeUserMapper newsNoticeUserMapper;
  54. @Resource
  55. PowerMapper powerMapper;
  56. @Resource
  57. ProjectMapper projectMapper;
  58. @Resource
  59. ProjectApproveMapper projectApproveMapper;
  60. @Resource
  61. MouldDownPacketMapper mouldDownPacketMapper;
  62. @Resource
  63. ProjectUserMapper projectUserMapper;
  64. @Override
  65. public HttpRespMsg addAndUpdateMouldEquipment(MouldEquipment mouldEquipment, User user) {
  66. HttpRespMsg msg = new HttpRespMsg();
  67. if (user.getParentId() == 0) {
  68. if (mouldEquipment.getId() == null) {
  69. //添加设备
  70. //查询当前设备编号的模具是否存在
  71. Integer count = mouldEquipmentMapper.selectCount(new QueryWrapper<MouldEquipment>().eq("equipment_no", mouldEquipment.getEquipmentNo()));
  72. if (count > 0) {
  73. msg.setError("当前设备编号已存在,请重新输入其他模具编号");
  74. } else {
  75. mouldEquipmentMapper.insert(mouldEquipment);
  76. }
  77. } else {
  78. //修改设备
  79. MouldEquipment mouldEqu = mouldEquipmentMapper.selectById(mouldEquipment.getId());
  80. MouldEquipment m = mouldEquipmentMapper.selectOne(new QueryWrapper<MouldEquipment>().eq("equipment_no", mouldEquipment.getEquipmentNo()));
  81. if (mouldEqu.getEquipmentNo().equals(mouldEquipment.getEquipmentNo()) || m==null) {
  82. mouldEquipmentMapper.updateById(mouldEquipment);
  83. } else{
  84. msg.setError("当前设备编号已存在,请重新输入其他模具编号");
  85. }
  86. }
  87. } else {
  88. msg.setError("对不起,您不是管理员,不具备设备创建或修改的权限");
  89. }
  90. return msg;
  91. }
  92. @Override
  93. public HttpRespMsg isUse(MouldEquipmentVO mouldEquipment, User user) {
  94. HttpRespMsg msg = new HttpRespMsg();
  95. //16进制的转化
  96. String lowPowerLimitStr = Integer.toHexString(mouldEquipment.getLowPowerLimit());
  97. String hotAlarmLimitStr = Integer.toHexString(mouldEquipment.getHotAlarmLimit());
  98. String isUseStr = "0"+Integer.toHexString(mouldEquipment.getIsUse());
  99. //判断是不是超级管理员,是才可操作
  100. if (user.getParentId() == 0) {
  101. //修改设备
  102. String[] split = mouldEquipment.getEquipmentNo().split(",");
  103. MouldDownPacket packet = null;
  104. String setPacketMessage = "";
  105. for (String str : split) {
  106. packet = mouldDownPacketMapper.selectOne(new QueryWrapper<MouldDownPacket>().eq("equipment_no", str));
  107. MouldEquipment equipment = new MouldEquipment();
  108. equipment.setIsUse(mouldEquipment.getIsUse());
  109. equipment.setEquipmentNo(mouldEquipment.getEquipmentNo());
  110. equipment.setHillNumber(mouldEquipment.getLowPowerLimit()+"");
  111. equipment.setTemperature(mouldEquipment.getHotAlarmLimit());
  112. mouldEquipmentMapper.update(equipment,new QueryWrapper<MouldEquipment>().eq("equipment_no",str));
  113. if(packet != null){
  114. //已经存在更新下发数据包
  115. MouldDownPacket mouldDownPacket = new MouldDownPacket();
  116. mouldDownPacket.setId(packet.getId());
  117. setPacketMessage = downProcessMsg(lowPowerLimitStr,hotAlarmLimitStr,isUseStr); mouldDownPacket.setPacketStr(setPacketMessage);
  118. mouldDownPacket.setPacketStr(setPacketMessage);
  119. mouldDownPacket.setIsUse(mouldEquipment.getIsUse());
  120. mouldDownPacketMapper.updateById(mouldDownPacket);
  121. }else{
  122. MouldDownPacket mouldDownPacket = new MouldDownPacket();
  123. setPacketMessage = downProcessMsg(lowPowerLimitStr,hotAlarmLimitStr,isUseStr); mouldDownPacket.setPacketStr(setPacketMessage);
  124. mouldDownPacket.setPacketStr(setPacketMessage);
  125. mouldDownPacket.setIsUse(mouldEquipment.getIsUse());
  126. mouldDownPacketMapper.insert(mouldDownPacket);
  127. }
  128. }
  129. } else {
  130. msg.setError("对不起,您不是超级管理员,不具备启用设备的权限");
  131. return msg;
  132. }
  133. return msg;
  134. }
  135. @Override
  136. public HttpRespMsg getList(User user, PageUtil page, Integer companyId, String keyName) {
  137. HttpRespMsg msg = new HttpRespMsg();
  138. if (user != null) {
  139. if (Constant.SYS_PARENT_ID.equals(user.getParentId())) {
  140. PageHelper.startPage(page.getPageNum(), page.getPageSize());
  141. List<MouldEquipmentVO> mouldEquipments = mouldEquipmentMapper.getList(companyId, keyName);
  142. PageInfo<MouldEquipmentVO> pageInfo = new PageInfo<>(mouldEquipments);
  143. msg.data = pageInfo;
  144. } else {
  145. msg.setError("对不起,您不含有查看该列表的权利");
  146. }
  147. }
  148. return msg;
  149. }
  150. @Override
  151. public HttpRespMsg getListByCompanyId(MouldEquipmentVO mouldEquipmentVO) {
  152. HttpRespMsg msg = new HttpRespMsg();
  153. List<Integer> mouldsEquipmentIds = mouldMapper.selectList(new QueryWrapper<Mould>().eq("company_id", mouldEquipmentVO.getBelongCompanyId()).isNotNull("equipment_id")).stream().map(Mould::getEquipmentId).collect(Collectors.toList());
  154. mouldsEquipmentIds.add(-1);
  155. List<Integer> equipmentIds = mouldEquipmentMapper.selectList(new QueryWrapper<MouldEquipment>().eq("belong_company_id", mouldEquipmentVO.getBelongCompanyId()).eq("stage", 0)).stream().map(MouldEquipment::getId).collect(Collectors.toList());
  156. equipmentIds.removeAll(mouldsEquipmentIds);//把已经使用的设备剔除
  157. equipmentIds.add(-1);
  158. List<MouldEquipmentVO> list = mouldEquipmentMapper.getListByCompanyId(mouldEquipmentVO.getBelongCompanyId(), equipmentIds);
  159. msg.data = list;
  160. return msg;
  161. }
  162. @Override
  163. public HttpRespMsg MouldEquipmentAlarm() {
  164. HttpRespMsg msg = new HttpRespMsg();
  165. String token = GainTokenUtil.getToken();
  166. List<MouldEquipment> mouldEquipments = mouldEquipmentMapper.selectList(new QueryWrapper<MouldEquipment>().eq("is_use", 1));
  167. for (MouldEquipment mouldEquipment : mouldEquipments) {
  168. Mould mould = mouldMapper.selectOne(new QueryWrapper<Mould>().eq("equipment_id", mouldEquipment.getId()));
  169. Project project = projectMapper.selectById(mould.getProjectId());
  170. List<Integer> uids = projectUserMapper.selectList(new QueryWrapper<ProjectUser>().eq("project_id", project.getId())).stream().map(ProjectUser::getUserId).collect(Collectors.toList());
  171. uids.add(project.getManagerId());
  172. uids.add(project.getCreatorId());
  173. uids.add(-1);
  174. List<User> userList = userMapper.selectList(new QueryWrapper<User>().in("id", uids).isNotNull("openid").eq("is_disable", 1));
  175. if (Constant.ELECTRICITY_THRESHOLD >= Double.parseDouble(mouldEquipment.getHillNumber())) {
  176. if (0 == mouldEquipment.getStage()) {
  177. mouldEquipment.setStage(2);
  178. } else {
  179. mouldEquipment.setStage(3);
  180. }
  181. mouldEquipmentMapper.updateById(mouldEquipment);
  182. //公众号的推送to do
  183. userList.forEach(u -> {
  184. try {
  185. WechatTemplateUtil.sendEmergencyTemplateMessage(u.getOpenid(), mouldEquipment.getEquipmentName(), Constant.ELECTRICITY_TYPE, Constant.ELECTRICITY_CONTENT, token);
  186. } catch (Exception e) {
  187. e.printStackTrace();
  188. }
  189. });
  190. //查询到参与该项目的人
  191. List<Integer> userIds = new ArrayList<>();
  192. userIds.add(-1);
  193. userIds.add(project.getCreatorId());
  194. userIds.add(project.getManagerId());
  195. List<ProjectUser> projectUsers = projectUserMapper.selectList(new QueryWrapper<ProjectUser>().eq("project_id", project.getId()));
  196. for (ProjectUser projectUser : projectUsers) {
  197. userIds.add(projectUser.getUserId());
  198. }
  199. List<ProjectApprove> projectApproves = projectApproveMapper.selectList(new QueryWrapper<ProjectApprove>().eq("project_id", project.getId()));
  200. for (ProjectApprove projectApprove : projectApproves) {
  201. userIds.add(projectApprove.getApproverId());
  202. }
  203. List<User> users = userMapper.selectList(new QueryWrapper<User>().in("id", userIds));
  204. //查询到之前模具保养的消息
  205. NewsNotice oldNews = newsNoticeMapper.selectOne(new QueryWrapper<NewsNotice>().eq("ref_id", mould.getId()).eq("notice_type", 2));
  206. NewsNotice newsNotice = new NewsNotice();
  207. if (oldNews != null) {
  208. NewsNotice newNews = new NewsNotice();
  209. newNews.setId(oldNews.getId());
  210. oldNews.setIndate(LocalDateTime.now());
  211. newsNoticeMapper.updateById(oldNews);
  212. newsNoticeUserMapper.updateNewsNoticeUserByNewsNoticeId(oldNews.getId());
  213. // for (User u : users) {
  214. // //添加通知的消息
  215. // NewsNoticeUser newsNoticeUser = new NewsNoticeUser();
  216. // newsNoticeUser.setNewsId(oldNews.getId());
  217. // newsNoticeUser.setUserId(u.getId());
  218. // newsNoticeUser.setIsRead(0);
  219. // newsNoticeUserMapper.updateById(newsNoticeUser);
  220. // }
  221. } else {
  222. newsNotice.setNoticeType(Constant.EMERGENCY_TYPE);
  223. newsNotice.setProjectId(project.getId());
  224. newsNotice.setProjectName(project.getProjectName() + "-" + mould.getModelName());
  225. // newsNotice.setRefId(mould.getId());
  226. newsNotice.setContent(mouldEquipment.getEquipmentNo() + "-" + Constant.EMERGENCY_ELECTRICITY_NOTICE);
  227. newsNoticeMapper.insert(newsNotice);
  228. for (User u : users) {
  229. //添加通知的消息
  230. NewsNoticeUser newsNoticeUser = new NewsNoticeUser();
  231. newsNoticeUser.setNewsId(newsNotice.getId());
  232. newsNoticeUser.setUserId(u.getId());
  233. newsNoticeUserMapper.insert(newsNoticeUser);
  234. }
  235. }
  236. }
  237. if (Constant.TEMPERATURE_THRESHOLD <= mouldEquipment.getTemperature()) {
  238. if (0 == mouldEquipment.getStage()) {
  239. mouldEquipment.setStage(1);
  240. } else {
  241. mouldEquipment.setStage(3);
  242. }
  243. mouldEquipmentMapper.updateById(mouldEquipment);
  244. //公众号的推送to do
  245. userList.forEach(u -> {
  246. try {
  247. WechatTemplateUtil.sendEmergencyTemplateMessage(u.getOpenid(), mouldEquipment.getEquipmentName(), Constant.TEMPERATURE_TYPE, Constant.TEMPERATURE_CONTENT, token);
  248. } catch (Exception e) {
  249. e.printStackTrace();
  250. }
  251. });
  252. //查询到参与该项目的人
  253. List<Integer> userIds = new ArrayList<>();
  254. userIds.add(-1);
  255. userIds.add(project.getCreatorId());
  256. userIds.add(project.getManagerId());
  257. List<ProjectUser> projectUsers = projectUserMapper.selectList(new QueryWrapper<ProjectUser>().eq("project_id", project.getId()));
  258. for (ProjectUser projectUser : projectUsers) {
  259. userIds.add(projectUser.getUserId());
  260. }
  261. List<ProjectApprove> projectApproves = projectApproveMapper.selectList(new QueryWrapper<ProjectApprove>().eq("project_id", project.getId()));
  262. for (ProjectApprove projectApprove : projectApproves) {
  263. userIds.add(projectApprove.getApproverId());
  264. }
  265. List<User> users = userMapper.selectList(new QueryWrapper<User>().in("id", userIds));
  266. //查询到之前模具保养的消息
  267. NewsNotice oldNews = newsNoticeMapper.selectOne(new QueryWrapper<NewsNotice>().eq("ref_id", mould.getId()).eq("notice_type", 2));
  268. NewsNotice newsNotice = new NewsNotice();
  269. if (oldNews != null) {
  270. NewsNotice newNews = new NewsNotice();
  271. newNews.setId(oldNews.getId());
  272. oldNews.setIndate(LocalDateTime.now());
  273. newsNoticeMapper.updateById(oldNews);
  274. newsNoticeUserMapper.updateNewsNoticeUserByNewsNoticeId(oldNews.getId());
  275. // for (User u : users) {
  276. // //添加通知的消息
  277. // NewsNoticeUser newsNoticeUser = new NewsNoticeUser();
  278. // newsNoticeUser.setNewsId(oldNews.getId());
  279. // newsNoticeUser.setUserId(u.getId());
  280. // newsNoticeUser.setIsRead(0);
  281. // newsNoticeUserMapper.updateById(newsNoticeUser);
  282. // }
  283. } else {
  284. newsNotice.setNoticeType(Constant.EMERGENCY_TYPE);
  285. newsNotice.setProjectId(project.getId());
  286. newsNotice.setProjectName(project.getProjectName() + "-" + mould.getModelName());
  287. // newsNotice.setRefId(mould.getId());
  288. newsNotice.setContent(mouldEquipment.getEquipmentNo() + "-" + Constant.EMERGENCY_TEMPERATURE_NOTICE);
  289. newsNoticeMapper.insert(newsNotice);
  290. for (User u : users) {
  291. //添加通知的消息
  292. NewsNoticeUser newsNoticeUser = new NewsNoticeUser();
  293. newsNoticeUser.setNewsId(newsNotice.getId());
  294. newsNoticeUser.setUserId(u.getId());
  295. newsNoticeUserMapper.insert(newsNoticeUser);
  296. }
  297. }
  298. }
  299. }
  300. return msg;
  301. }
  302. @Override
  303. public HttpRespMsg importMouldEquipmentExcel(MultipartFile file, UserVO userVO) {
  304. HttpRespMsg msg = new HttpRespMsg();
  305. User user = userMapper.selectOne(new QueryWrapper<User>().eq("head_imgurl", userVO.getToken()));
  306. if (user != null) {
  307. List<MouldEquipment> mouldEquipments = mouldEquipmentMapper.selectList(new QueryWrapper<MouldEquipment>());
  308. try {
  309. File f = null;
  310. if ("".equals(file) || file.getSize() <= 0) {
  311. file = null;
  312. } else {
  313. //获取输入流
  314. InputStream ins = file.getInputStream();
  315. //新建一个文件
  316. f = new File(file.getOriginalFilename());
  317. //输入流转file
  318. inputStreamToFile(ins, f);
  319. }
  320. //根据文件创建工作簿
  321. XSSFWorkbook wookbook = new XSSFWorkbook(f);
  322. XSSFSheet sheet = wookbook.getSheetAt(0);
  323. int s = sheet.getLastRowNum();
  324. // 遍历当前sheet中的所有行,第一行是数据对应的字段,不是数据,
  325. // 故从第二行开始遍历拿数据(如果有标题的话,则从第三行开始拿数据)
  326. for (int j = 1; j < sheet.getLastRowNum() + 1; j++) {
  327. XSSFRow row = sheet.getRow(j);
  328. //新建云模盒对象
  329. MouldEquipment mouldEquipment = new MouldEquipment();
  330. // 遍历所有的列,下面的10是excle表格里共有10列即对应了10个字段
  331. for (int y = 0; y < 3; y++) {
  332. XSSFCell cell = row.getCell(y);
  333. cell.setCellType(Cell.CELL_TYPE_STRING);
  334. //取出当前列的值
  335. String value = cell.getStringCellValue();
  336. //判断第几列插入数据,后面就是从列中取数据往对象里放,然后插入到数据库里
  337. if (value == null && "".equals(value)) {
  338. log.error("数据不可为空");
  339. msg.setError("数据不可为空");
  340. return msg;
  341. } else if (y == 0) {
  342. //云模编号
  343. for (MouldEquipment p : mouldEquipments) {
  344. if (value.equals(p.getEquipmentNo())) {
  345. // msg.setError("第" + j + "行的云模盒编号:" + value + "已被占用,请修改后重新上传");
  346. msg.setError("云模盒编号已被占用,请修改后重新上传");
  347. return msg;
  348. }
  349. }
  350. mouldEquipment.setEquipmentNo(value);
  351. } else if (y == 1) {
  352. //使用年限
  353. mouldEquipment.setUseLife(Integer.parseInt(value));
  354. } else if (y == 2) {
  355. //代理商
  356. mouldEquipment.setAgent(value);
  357. }
  358. }
  359. mouldEquipmentMapper.insert(mouldEquipment);
  360. }
  361. //用完后删除临时文件
  362. if (!f.isDirectory()) {
  363. f.delete();
  364. }
  365. } catch (Exception e) {
  366. log.error(e.getMessage(), e);
  367. msg.setError(e.getMessage());
  368. return msg;
  369. }
  370. } else {
  371. msg.setError("用户不存在或者未登录");
  372. }
  373. return msg;
  374. }
  375. @Override
  376. public HttpRespMsg getEquipmentListByOldMouldAndUser(UserVO userVO) {
  377. HttpRespMsg msg = new HttpRespMsg();
  378. User user = userMapper.selectOne(new QueryWrapper<User>().eq("head_imgurl", userVO.getToken()));
  379. if (user == null) {
  380. msg.setError("用户不存在或者未登录");
  381. } else {
  382. Mould mould = mouldMapper.selectById(userVO.getMouldId());
  383. User admin = userMapper.selectById(projectMapper.selectById(mould.getProjectId()).getCreatorId());
  384. List<Integer> mouldsEquipmentIds = mouldMapper.selectList(new QueryWrapper<Mould>().eq("company_id", admin.getCompanyId()).isNotNull("equipment_id")).stream().map(Mould::getEquipmentId).collect(Collectors.toList());
  385. mouldsEquipmentIds.add(-1);
  386. List<Integer> equipmentIds = mouldEquipmentMapper.selectList(new QueryWrapper<MouldEquipment>().eq("belong_company_id", admin.getCompanyId()).eq("stage", 0)).stream().map(MouldEquipment::getId).collect(Collectors.toList());
  387. equipmentIds.removeAll(mouldsEquipmentIds);//把已经使用的设备剔除
  388. equipmentIds.add(-1);
  389. List<MouldEquipmentVO> list = mouldEquipmentMapper.getListByCompanyId(admin.getCompanyId(), equipmentIds);
  390. msg.data = list;
  391. }
  392. return msg;
  393. }
  394. /**
  395. * 输入流转file
  396. *
  397. * @param ins
  398. * @param file
  399. */
  400. public static void inputStreamToFile(InputStream ins, File file) {
  401. try {
  402. OutputStream os = new FileOutputStream(file);
  403. int bytesRead = 0;
  404. byte[] buffer = new byte[8192];
  405. while ((bytesRead = ins.read(buffer, 0, 8192)) != -1) {
  406. os.write(buffer, 0, bytesRead);
  407. }
  408. os.close();
  409. ins.close();
  410. } catch (Exception e) {
  411. e.printStackTrace();
  412. }
  413. }
  414. // 下行配置数据包
  415. private String downProcessMsg(String lowPowerLimit,String hotAlarmLimit,String isUse) {
  416. //"23"不解析
  417. if("23".equals(lowPowerLimit)){
  418. lowPowerLimit="24";
  419. }
  420. if("23".equals(hotAlarmLimit)){
  421. hotAlarmLimit="24";
  422. }
  423. if("23".equals(isUse)){
  424. isUse="24";
  425. }
  426. String ret = "FA AF 00 07 "+isUse+" 1e 78 "+lowPowerLimit+" "+hotAlarmLimit+" 00 3C";
  427. ret = ret.replaceAll(" ", "");
  428. String crcCode = CRC16Util.getCRC(ret);
  429. System.out.println("ret===>"+ret);
  430. String lastPart = (ret + crcCode).replaceAll("23", "24").replaceAll(" ", "");
  431. System.out.println("lastPart===>"+lastPart);
  432. return lastPart;
  433. }
  434. }