package com.ld.igds.sh.service; import com.alibaba.fastjson.JSONObject; import com.ld.igds.log.service.InteStatusLogService; import com.ld.igds.models.DrugLog; import com.ld.igds.models.InteStatusLog; import com.ld.igds.sh.dto.ApiResponse; import com.ld.igds.sh.dto.Dto1404; import com.ld.igds.sh.param.ApiRequest; import com.ld.igds.sh.param.BaseParam; import com.ld.igds.sh.service.impl.HApiShServiceImpl; import com.ld.igds.sh.util.ApiShConst; import com.ld.igds.sh.util.ApiShUtil; import com.ld.igds.sh.util.RespCodeEnum; import com.ld.igds.sh.util.RespUtil; import com.ld.igds.util.ContextUtil; import com.ld.igds.util.RedisUtil; import lombok.extern.slf4j.Slf4j; import org.apache.commons.lang3.StringUtils; import org.apache.commons.lang3.time.DateFormatUtils; import org.apache.commons.lang3.time.DateUtils; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Service; import java.util.ArrayList; import java.util.Date; import java.util.List; /** * 熏蒸作业接口 * * @author chen */ @Slf4j @Service public class ApiShServiceImpl1404 implements ApiShService { @Autowired private HApiShServiceImpl hApiShServiceImpl; @Autowired private InteStatusLogService inteStatusLogService; @Autowired private RedisUtil redisUtil; @Override public String getInterfaceId() { return ApiShConst.API_SH_1404; } @SuppressWarnings("unchecked") @Override public ApiResponse execute(ApiRequest request) { //获取参数信息 String deptId = request.getDeptId(); BaseParam param = JSONObject.parseObject(JSONObject.toJSONString(request.getData()), BaseParam.class); String companyId = ContextUtil.getDefaultCompanyId(); // String key = RedisConst.buildKey(companyId, ApiShConst.API_SH_1112); // Date startTime = (Date) redisUtil.get(key); // if(null == startTime){ // startTime = DateUtils.addDays(param.getEndTime(), -30); // } // redisUtil.set(key, param.getEndTime()); if(null == param.getStartTime()){ param.setStartTime(DateUtils.addDays(param.getEndTime(), -1)); } //查询熏蒸作业信息 List dataList = hApiShServiceImpl.listDrugLog(companyId, param.getDepotId(), param.getStartTime(), param.getEndTime()); //响应数据为空则直接返回响应码2000 if (dataList == null || dataList.isEmpty()) { return RespUtil.error(RespCodeEnum.CODE_2000.getCode(), request); } List list = new ArrayList<>(); Dto1404 dto; InteStatusLog log; InteStatusLog addLog; //封装数据信息 for (DrugLog data : dataList) { dto = new Dto1404(); dto.setXzzybm(ApiShUtil.getGbDepotId(data.getDepotId()).substring(0, 25) + data.getId()); dto.setCfdm(ApiShUtil.getGbDepotId(data.getDepotId()).substring(0, 25)); dto.setXzkssj(DateFormatUtils.format(data.getStart()==null?(new Date()):data.getStart(),"yyyy-MM-dd")); dto.setXzjssj(DateFormatUtils.format(data.getEnd()==null?(new Date()):data.getEnd(),"yyyy-MM-dd")); dto.setHcjcdh(StringUtils.isEmpty(data.getPestBatchId())?"0":data.getPestBatchId()); dto.setDjcxz(data.getNum()==null?"0":data.getNum() + ""); dto.setCgxzfs(StringUtils.isEmpty(data.getMode())?"0":data.getMode()); dto.setHlxzfs(StringUtils.isEmpty(data.getRecirMode())?"0":data.getRecirMode()); dto.setYjmc(StringUtils.isEmpty(data.getDrugName())?"0":data.getDrugName()); dto.setNd(data.getConcentration()==null?"0":data.getConcentration() + ""); dto.setLddwyyl(data.getGrainDose()==null?"0":data.getGrainDose()+""); dto.setKjdwyyl(data.getSpaceDose()==null?"0":data.getSpaceDose()+""); dto.setZyyl(data.getDose()==null?"0":data.getDose()+""); dto.setSqrq(DateFormatUtils.format(data.getVentilateTime()==null?(new Date()):data.getVentilateTime(),"yyyy-MM-dd")); dto.setSqff(StringUtils.isEmpty(data.getVentilateMethod())?"0":data.getVentilateMethod()); dto.setSqjsslhqnd(data.getAfterPh3()==null?"0.0":data.getAfterPh3() + ""); dto.setXzxgpj(StringUtils.isEmpty(data.getEvaluate())?"0":data.getEvaluate()); dto.setCzsjff(StringUtils.isEmpty(data.getCzsjff())?"0":data.getCzsjff()); dto.setCzclcs(StringUtils.isEmpty(data.getCzclcs())?"0":data.getCzclcs()); dto.setXzzyry(StringUtils.isEmpty(data.getUser())?"0":data.getUser()); dto.setZhgxsj(DateFormatUtils.format(new Date(), "yyyy-MM-dd HH:mm:ss")); //查询日志状态表,设置操作标志 log = inteStatusLogService.getLogByBizId(companyId, ApiShConst.API_SH_1404 + "_" + data.getId()); if(null == log){ addLog = new InteStatusLog(); addLog.setBizId(ApiShConst.API_SH_1404 + "_" + data.getId()); addLog.setCompanyId(companyId); addLog.setBizType(ApiShConst.API_SH_TYPE_TASK); addLog.setInterfaceId(ApiShConst.API_SH_1404); addLog.setInterfaceType(ApiShConst.API_SH_TYPE_TASK); addLog.setStatus(ApiShConst.API_SH_STATUS_SUCCESS); inteStatusLogService.addInteStatusLog(addLog); }else { dto.setCzbz(ApiShConst.API_SH_U); } list.add(dto); } //响应数据为空则直接返回响应码2000 if (list.isEmpty()) { return RespUtil.error(RespCodeEnum.CODE_2000.getCode(), request); } return RespUtil.success(list, request); } }