| | |
| | | package org.springblade.mdm.machinefile.service; |
| | | |
| | | import com.alibaba.excel.util.StringUtils; |
| | | import lombok.extern.slf4j.Slf4j; |
| | | import org.apache.commons.codec.digest.DigestUtils; |
| | | import org.springblade.core.log.exception.ServiceException; |
| | | import org.springblade.mdm.basesetting.machine.service.MachineService; |
| | | import org.springblade.mdm.basesetting.machine.entity.Machine; |
| | | import org.springblade.mdm.commons.service.MachineDirTranslator; |
| | | import org.springblade.mdm.commons.service.ParamService; |
| | | import org.springblade.mdm.gkw.programnode.vo.ProgramNameVO; |
| | | import org.springblade.mdm.machinefile.entity.MachineFile; |
| | | import org.springblade.mdm.machinefile.mapper.MachineFileMapper; |
| | | import org.springblade.mdm.program.service.ProgramAnnotationService; |
| | | import org.springblade.mdm.program.service.programannotation.*; |
| | | import org.springblade.mdm.utils.FileContentUtil; |
| | | import org.springblade.mdm.utils.ProgramFileNameParser; |
| | | import org.springblade.system.pojo.entity.DictBiz; |
| | | import org.springframework.beans.factory.annotation.Autowired; |
| | | import org.springframework.scheduling.annotation.Async; |
| | | import org.springframework.stereotype.Component; |
| | | |
| | | import java.io.BufferedInputStream; |
| | |
| | | @Autowired |
| | | private MachineService machineService; |
| | | @Autowired |
| | | private ParamService paramService; |
| | | private AnnotationProcessorHelper annotationProcessorHelper; |
| | | @Autowired |
| | | private ProgramAnnotationService programAnnotationService; |
| | | |
| | | |
| | | /** |
| | | * 扫描所有机床的配置目录 |
| | | */ |
| | | private MachineDirTranslator machineDirTranslator; |
| | | @Autowired |
| | | private MachineFileMapper machineFileMapper; |
| | | @Async |
| | | public void scanMachineFile() { |
| | | List<Machine> machines = machineService.getEnableMachines(); |
| | | for (Machine machine : machines) { |
| | |
| | | } |
| | | } |
| | | |
| | | machineFileMapper.deleteNotUseRecords(); |
| | | } |
| | | |
| | | |
| | | /** |
| | | * 扫描目录 |
| | | * @param machine 机床信息 |
| | | * @param dirType 目录类型 |
| | | * @throws IOException |
| | | * @throws IOException 文件操作可能导致的异常 |
| | | */ |
| | | public void scanDir(Machine machine,String dirType) throws IOException { |
| | | String basePath = MachineFileService.getBasePath(machine,dirType); |
| | | String basePath = machineDirTranslator.trans(MachineFileService.getBasePath(machine,dirType)); |
| | | if(basePath == null) { |
| | | log.warn("目录类型不匹配:{}",dirType); |
| | | return; |
| | |
| | | List<Path> files = Files.list(dirPath) |
| | | .filter(Files::isRegularFile).toList(); |
| | | |
| | | byte[] buffer = new byte[2048]; |
| | | |
| | | //MachineFile existFileInDb; |
| | | List<DictBiz> annotatiionList = programAnnotationService.getAnnotionDictList(); |
| | | //byte[] buffer = new byte[2048]; |
| | | //List<DictBiz> annotatiionList = programAnnotationService.getAnnotionDictList(); |
| | | //boolean exists;//文件是否存在于数据库中 |
| | | for (Path filePath : files) { |
| | | //existFileInDb = null; |
| | | //exists = false; |
| | | |
| | | /*MachineFile mf = new MachineFile(); |
| | | mf.setTenantId("000000"); |
| | | mf.setName(filePath.toFile().getName()); |
| | | mf.setDirType(dirType); |
| | | mf.setMachineCode(machine.getCode());*/ |
| | | |
| | | try { |
| | | //读取内容,确定程序状态 |
| | | /*int pstatus = readProgramStatus(filePath,machine.getMachineGroupCode(),annotatiionList); |
| | | mf.setProgramStatus(pstatus); |
| | | BasicFileAttributes attrs = Files.readAttributes( |
| | | filePath, |
| | | BasicFileAttributes.class |
| | | ); |
| | | |
| | | FileTime creationTime = attrs.creationTime(); |
| | | Date creationDate = new Date(creationTime.toMillis()); |
| | | mf.setFileCreateTime(creationDate); |
| | | |
| | | FileTime modifyTime = attrs.lastModifiedTime(); |
| | | mf.setFileModifyTime(new Date(modifyTime.toMillis())); |
| | | mf.setFileSize(Files.size(filePath)); |
| | | try (InputStream inputStream = Files.newInputStream(filePath)) { |
| | | // 使用输入流读取文件内容 |
| | | int bytesRead = inputStream.read(buffer); |
| | | mf.setMd5(DigestUtils.md5Hex(buffer)); |
| | | } catch (IOException e) { |
| | | log.error("读取文件md5失败",e); |
| | | continue;//有错误,掠过 |
| | | }*/ |
| | | |
| | | MachineFile mf = readFileToMachineFile(filePath,machine,dirType,annotatiionList); |
| | | MachineFile mf = readFileToMachineFile(filePath,machine,dirType); |
| | | |
| | | machineFileService.refreshFileData(mf); |
| | | /* |
| | | existFileInDb = machineFileService.getExistsFile(mf.getName(),dirType,machine.getCode()); |
| | | System.out.println("文件创建时间: " + mf.getFileCreateTime()); |
| | | |
| | | if(existFileInDb == null) { |
| | | machineFileService.save(mf); |
| | | }else{ |
| | | log.info("文件已存在:{}",filePath.getFileName()); |
| | | |
| | | existFileInDb.setFileSize(mf.getFileSize()); |
| | | existFileInDb.setProgramStatus(mf.getProgramStatus()); |
| | | existFileInDb.setFileCreateTime(mf.getFileCreateTime()); |
| | | existFileInDb.setFileModifyTime(mf.getFileModifyTime()); |
| | | if(!StringUtils.equals(existFileInDb.getMd5(),mf.getMd5())){ |
| | | //文件内容发生变化了,设置状态为初始状态 |
| | | existFileInDb.setStatus(MachineFile.STATUS_NORMAL); |
| | | } |
| | | existFileInDb.setMd5(mf.getMd5()); |
| | | |
| | | machineFileService.updateById(existFileInDb); |
| | | |
| | | }*/ |
| | | } catch (IOException e) { |
| | | log.error("读取文件信息失败",e); |
| | | } |
| | |
| | | * @param filePath 文件路径 |
| | | * @param machine 机器 |
| | | * @param dirType 目录类型 |
| | | * @param annotatiionList 注解配置字典 用于读取程序状态 |
| | | * @return MachineFile 实例 |
| | | * @throws IOException |
| | | */ |
| | | public MachineFile readFileToMachineFile(Path filePath,Machine machine,String dirType,List<DictBiz> annotatiionList) throws IOException { |
| | | public MachineFile readFileToMachineFile(Path filePath,Machine machine,String dirType) throws IOException { |
| | | MachineFile mf = new MachineFile(); |
| | | |
| | | mf.setTenantId("000000"); |
| | | mf.setName(filePath.toFile().getName()); |
| | | mf.setDirType(dirType); |
| | | mf.setMachineCode(machine.getCode()); |
| | | mf.setProgramStatus(readProgramStatus(filePath,machine.getMachineGroupCode(),annotatiionList)); |
| | | |
| | | BasicFileAttributes attrs = Files.readAttributes( |
| | | filePath, |
| | |
| | | log.error("读取文件md5失败",e); |
| | | throw new ServiceException("读取文件md5失败"+e.getMessage()); |
| | | } |
| | | try (InputStream inputStream = Files.newInputStream(filePath)) { |
| | | AnnotationProcessor annoProcessor = annotationProcessorHelper.getProcessor(machine.getMachineGroupCode()); |
| | | AnnotationData annoData = annoProcessor.readAnnotationData(inputStream); |
| | | mf.setProgramStatus(annoData.getProgramStatus()); |
| | | |
| | | return mf; |
| | | } |
| | | /** |
| | | * 读取文件中的程序状态 |
| | | * @param filePath 文件路径 |
| | | * @param machineGroupCode |
| | | * @param annotatiionList 注释配置字典 |
| | | * @return 状态的整数之和 |
| | | * @throws IOException |
| | | */ |
| | | int readProgramStatus(Path filePath,String machineGroupCode,List<DictBiz> annotatiionList) throws IOException { |
| | | int programStatus = MachineFile.PROGRAM_STATUS_UNKNOWN; |
| | | try(InputStream ins = Files.newInputStream(filePath); |
| | | BufferedInputStream bis = new BufferedInputStream(ins)){ |
| | | |
| | | boolean isText= FileContentUtil.isTextFile(bis); |
| | | if(!isText){ |
| | | return MachineFile.PROGRAM_STATUS_UNKNOWN; |
| | | } |
| | | bis.reset(); |
| | | String statusLine = FileContentUtil.readLineAt(ins,ProgramAnnotationService.STATUS_LINE_INDEX); |
| | | if(programAnnotationService.isAnnotation(statusLine,machineGroupCode,annotatiionList)){ |
| | | String progStatusTxt = programAnnotationService.removeAnnotation(machineGroupCode,statusLine,annotatiionList); |
| | | if(ProgramAnnotationService.SQ.equals(progStatusTxt)){ |
| | | programStatus = MachineFile.PROGRAM_STATUS_TRY; |
| | | }else if(ProgramAnnotationService.GH.equals(progStatusTxt)){ |
| | | programStatus = MachineFile.PROGRAM_STATUS_CURED; |
| | | }else if(ProgramAnnotationService.PL.equals(progStatusTxt)){ |
| | | programStatus = MachineFile.PROGRAM_STATUS_DIVIASTION; |
| | | } |
| | | ProgramNameVO progVO = ProgramFileNameParser.parseProgramName(mf.getName()); |
| | | if(StringUtils.isNotBlank(progVO.getLgPart())) { |
| | | mf.setDeviation(annoData.getDeviation()); |
| | | } |
| | | } |
| | | |
| | | return programStatus; |
| | | return mf; |
| | | } |
| | | |
| | | /** |
| | | * 清理已经删除了文件的记录 |
| | | * @param machine |
| | | * @param dirType |
| | | * @param machine 机床 |
| | | * @param dirType 目录类型 |
| | | * @throws IOException |
| | | */ |
| | | void clearDeletedRecords(Machine machine,String dirType) throws IOException { |
| | | List<MachineFile> machineFiles = this.machineFileService.lambdaQuery().eq(MachineFile::getDirType,dirType) |
| | | .eq(MachineFile::getMachineCode,machine.getCode()).list(); |
| | | |
| | | String basePath = MachineFileService.getBasePath(machine,dirType); |
| | | String basePath = machineDirTranslator.trans(MachineFileService.getBasePath(machine,dirType)); |
| | | if(basePath == null) { |
| | | log.warn("目录类型不匹配:{}",dirType); |
| | | return; |