|
package org.springblade.mdm.program.service;
|
|
import com.alibaba.fastjson.JSONArray;
|
import com.alibaba.fastjson.JSONObject;
|
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
|
import com.baomidou.mybatisplus.core.metadata.IPage;
|
import lombok.AllArgsConstructor;
|
import lombok.extern.slf4j.Slf4j;
|
import org.apache.commons.compress.archivers.zip.ZipArchiveEntry;
|
import org.apache.commons.compress.archivers.zip.ZipFile;
|
import org.apache.commons.compress.utils.SeekableInMemoryByteChannel;
|
import org.apache.commons.lang3.StringUtils;
|
import org.springblade.core.mp.base.BizEntity;
|
import org.springblade.core.mp.base.BizServiceImpl;
|
import org.springblade.core.mp.support.Condition;
|
import org.springblade.core.mp.support.Query;
|
import org.springblade.core.oss.OssTemplate;
|
import org.springblade.core.tool.utils.FileUtil;
|
import org.springblade.core.tool.utils.Func;
|
import org.springblade.mdm.flow.entity.ApproveRecord;
|
import org.springblade.mdm.flow.service.ApproveRecordService;
|
import org.springblade.mdm.program.entity.NcNode;
|
import org.springblade.mdm.program.entity.NcProgram;
|
import org.springblade.mdm.program.entity.NcProgramApproved;
|
import org.springblade.mdm.program.entity.NcProgramExchange;
|
import org.springblade.mdm.program.mapper.NcProgramExchangeMapper;
|
import org.springblade.mdm.program.vo.DncSendBackData;
|
import org.springframework.stereotype.Service;
|
import org.springframework.web.multipart.MultipartFile;
|
|
import java.io.*;
|
import java.nio.charset.StandardCharsets;
|
import java.util.ArrayList;
|
import java.util.Enumeration;
|
import java.util.List;
|
import java.util.zip.ZipEntry;
|
import java.util.zip.ZipOutputStream;
|
|
/**
|
* 下发/回传程序统计
|
*
|
* @author yangys
|
*/
|
@Slf4j
|
@Service
|
@AllArgsConstructor
|
public class NcProgramExportDNCService extends BizServiceImpl<NcProgramExchangeMapper, NcProgramExchange> {
|
private final NcProgramService progService;
|
private final NcProgramApprovedService approvedService;
|
private final ApproveRecordService approveRecordService;
|
private final NcNodeService ncNodeService;
|
private final OssTemplate ossTemplate;
|
|
public static final String PROGRAM_JSON_FILE = "exp_mdm_nc_program.json";
|
/**
|
* 分页查询
|
* @param query 查询参数
|
* @return
|
*/
|
public IPage<DncSendBackData> dncSendBackPageQuery(Query query) {
|
|
IPage<DncSendBackData> page = this.getBaseMapper().dncSendBackpageQuery(Condition.getPage(query),query);
|
|
return page;
|
|
}
|
|
|
/**
|
* 导出dnc压缩包
|
* @param approvedIdArr 待导出审批表id数组
|
*/
|
public void exportDnc(Long[] approvedIdArr, OutputStream os) throws IOException {
|
//FileOutputStream fos = new FileOutputStream("d:/exportDnc.zip");
|
try (ZipOutputStream zipOut = new ZipOutputStream(os);) {//os
|
|
ArrayList<Long> programIdList = new ArrayList<Long>();
|
|
for (Long approvedId : approvedIdArr) {
|
NcProgramApproved approved = approvedService.getById(approvedId);
|
programIdList.add(approved.getNcProgramId());
|
|
NcProgram prog = progService.getById(approved.getNcProgramId());
|
|
String filename = prog.getOssName();
|
InputStream inputStream = ossTemplate.statFileStream(filename);
|
|
addInputStreamToZip(zipOut, inputStream, prog.getName());
|
|
}
|
addDataJson(zipOut, programIdList);
|
}
|
|
}
|
|
|
/**
|
* 导入数据文件
|
* @param zipOut
|
*/
|
void addDataJson(ZipOutputStream zipOut, List<Long> programIdList) throws IOException {
|
addProgramDataJson(zipOut, programIdList);
|
addApproveRecordDataJson(zipOut, programIdList);
|
|
addNcNodeDataJson(zipOut, programIdList);
|
}
|
|
/**
|
* 导入程序记录
|
* @param zipOut
|
* @param programIdList
|
*/
|
void addProgramDataJson(ZipOutputStream zipOut, List<Long> programIdList) throws IOException {
|
LambdaQueryWrapper<NcProgram> queryWrapper = new LambdaQueryWrapper<>();
|
queryWrapper.in(NcProgram::getId, programIdList);
|
List<NcProgram> programList = progService.list(queryWrapper);
|
JSONArray jsonArray = new JSONArray();
|
for(NcProgram program : programList){
|
JSONObject recObj = new JSONObject();
|
recObj.put("id", program.getId());
|
recObj.put("code", program.getCode());
|
recObj.put("ossName",program.getOssName());
|
recObj.put("isTextFile",program.getIsTextFile());
|
recObj.put("category",program.getCategory());
|
recObj.put("description",program.getDescription());
|
recObj.put("name",program.getName());
|
recObj.put("partNo",program.getPartNo());
|
recObj.put("ncNodeId",program.getNcNodeId());
|
recObj.put("bindNcNodeId",program.getBindNcNodeId());
|
recObj.put("url",program.getUrl());
|
recObj.put("isCured",program.getIsCured());
|
recObj.put("isLocked",program.getIsLocked());
|
recObj.put("isTest",program.getIsTest());
|
recObj.put("machineCode",program.getMachineCode());
|
recObj.put("processEdition",program.getProcessEdition());
|
recObj.put("taskAssignTime",program.getTaskAssignTime());
|
|
addSuperProperties(recObj,program);
|
|
jsonArray.add(recObj);
|
}
|
addInputStreamToZip(zipOut,new ByteArrayInputStream(jsonArray.toJSONString().getBytes(StandardCharsets.UTF_8)),PROGRAM_JSON_FILE);
|
|
}
|
|
/**
|
* 导入审批记录
|
* @param zipOut
|
* @param programIdList
|
*/
|
void addApproveRecordDataJson(ZipOutputStream zipOut, List<Long> programIdList) throws IOException {
|
LambdaQueryWrapper<ApproveRecord> queryWrapper = new LambdaQueryWrapper<>();
|
queryWrapper.in(ApproveRecord::getNcProgramId, programIdList);
|
List<ApproveRecord> records = approveRecordService.list(queryWrapper);
|
JSONArray jsonArray = new JSONArray();
|
for(ApproveRecord record : records){
|
JSONObject recObj = new JSONObject();
|
recObj.put("id", record.getId());
|
recObj.put("comment", record.getComment());
|
recObj.put("userId",record.getUserId());
|
recObj.put("userNickname",record.getUserNickname());
|
recObj.put("operateTime",record.getOperateTime());
|
recObj.put("operateResult",record.getOperateResult());
|
recObj.put("taskName",record.getTaskName());
|
recObj.put("ncProgramId",record.getNcProgramId());
|
recObj.put("processInstanceId",record.getProcessInstanceId());
|
|
addSuperProperties(recObj,record);
|
|
jsonArray.add(recObj);
|
}
|
addInputStreamToZip(zipOut,new ByteArrayInputStream(jsonArray.toJSONString().getBytes(StandardCharsets.UTF_8)),"exp_mdm_approve_record.json");
|
|
}
|
|
/**
|
* 导入节点
|
* @param zipOut
|
* @param programIdList
|
*/
|
void addNcNodeDataJson(ZipOutputStream zipOut, List<Long> programIdList) throws IOException {
|
LambdaQueryWrapper<NcProgram> queryWrapper = new LambdaQueryWrapper<>();
|
queryWrapper.in(NcProgram::getId, programIdList);
|
|
List<NcProgram> programs = progService.list(queryWrapper);
|
JSONArray jsonArray = new JSONArray();
|
|
ArrayList<Long> exportNodeIdList = new ArrayList<>();
|
for(NcProgram program : programs){
|
JSONObject recObj = new JSONObject();
|
if(!exportNodeIdList.contains(program.getNcNodeId())){
|
exportNodeIdList.add(program.getNcNodeId());
|
}
|
NcNode ncNode = ncNodeService.getById(program.getNcNodeId());
|
|
if(StringUtils.isNotEmpty(ncNode.getParentIds())){
|
List<Long> pids = Func.toLongList(ncNode.getParentIds());
|
for(Long nodeId : pids){
|
if(!exportNodeIdList.contains(nodeId)){
|
exportNodeIdList.add(nodeId);
|
}
|
}
|
|
}
|
|
}
|
|
LambdaQueryWrapper<NcNode> nodeQueryWrapper = new LambdaQueryWrapper<>();
|
nodeQueryWrapper.in(NcNode::getId, exportNodeIdList);
|
List<NcNode> nodeList =ncNodeService.list(nodeQueryWrapper);
|
for(NcNode node : nodeList){
|
JSONObject recObj = new JSONObject();
|
|
recObj.put("id", node.getId());
|
recObj.put("nodeType", node.getNodeType());
|
recObj.put("machineCode",node.getMachineCode());
|
recObj.put("parentId",node.getParentId());
|
recObj.put("description",node.getDescription());
|
recObj.put("name",node.getName());
|
recObj.put("remark",node.getRemark());
|
recObj.put("partNo",node.getPartNo());
|
recObj.put("parentIds",node.getParentIds());
|
recObj.put("processName",node.getProcessName());
|
|
addSuperProperties(recObj,node);
|
|
jsonArray.add(recObj);
|
}
|
addInputStreamToZip(zipOut,new ByteArrayInputStream(jsonArray.toJSONString().getBytes(StandardCharsets.UTF_8)),"exp_mdm_nc_node.json");
|
}
|
|
void addSuperProperties(JSONObject recObj, BizEntity entity){
|
recObj.put("tenantId",entity.getTenantId());
|
recObj.put("createTime",entity.getCreateTime());
|
recObj.put("updateTime",entity.getUpdateTime());
|
recObj.put("createUser",entity.getCreateUser());
|
recObj.put("updateUser",entity.getUpdateUser());
|
recObj.put("status",entity.getStatus());
|
recObj.put("createDept",entity.getCreateDept());
|
}
|
|
public void addInputStreamToZip(ZipOutputStream zipOut, InputStream inputStream, String entryName)
|
throws IOException {
|
// 创建新的 ZIP 条目
|
ZipEntry zipEntry = new ZipEntry(entryName);
|
zipOut.putNextEntry(zipEntry);
|
|
// 将输入流写入 ZIP 输出流
|
byte[] buffer = new byte[1024];
|
int length;
|
while ((length = inputStream.read(buffer)) >= 0) {
|
zipOut.write(buffer, 0, length);
|
}
|
|
// 关闭当前条目
|
zipOut.closeEntry();
|
}
|
}
|