package com.ld.igds.sh.service; import com.alibaba.fastjson.JSONObject; import com.ld.igds.log.service.InteStatusLogService; import com.ld.igds.models.InteStatusLog; import com.ld.igds.models.Pest; import com.ld.igds.sh.dto.ApiResponse; import com.ld.igds.sh.dto.Dto1405; 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 ApiShServiceImpl1405 implements ApiShService { @Autowired private HApiShServiceImpl hApiShServiceImpl; @Autowired private InteStatusLogService inteStatusLogService; @Autowired private RedisUtil redisUtil; @Override public String getInterfaceId() { return ApiShConst.API_SH_1405; } @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.listPest(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<>(); Dto1405 dto; InteStatusLog log; InteStatusLog addLog; //封装数据信息 for (Pest data : dataList) { dto = new Dto1405(); dto.setHcjcdh(data.getBatchId()); dto.setJcsj(DateFormatUtils.format(data.getReceiveDate(),"yyyy-MM-dd HH:mm:ss")); dto.setHwdm(ApiShUtil.getGbDepotId(data.getDepotId()) + "01"); dto.setJchcff(StringUtils.isEmpty(data.getMethod())?"0":data.getMethod()); dto.setFsbw(StringUtils.isEmpty(data.getPosition())?"0":data.getPosition()); dto.setHczl(StringUtils.isEmpty(data.getPestType())?"0":data.getPestType()); dto.setCkmdzjh(StringUtils.isEmpty(data.getPoints())?"0":data.getPoints()); dto.setCldjpd(StringUtils.isEmpty(data.getPestLevel())?"0":data.getPestLevel()); dto.setHckyxfx(StringUtils.isEmpty(data.getPestAnalysis())?"0":data.getPestAnalysis()); dto.setZhgxsj(DateFormatUtils.format(new Date(), "yyyy-MM-dd HH:mm:ss")); //查询日志状态表,设置操作标志 log = inteStatusLogService.getLogByBizId(companyId, ApiShConst.API_SH_1405 + "_" + data.getCompanyId() + data.getBatchId()); if(null == log){ addLog = new InteStatusLog(); addLog.setBizId(ApiShConst.API_SH_1405 + "_" + data.getCompanyId() + data.getBatchId()); addLog.setCompanyId(companyId); addLog.setBizType(ApiShConst.API_SH_TYPE_TASK); addLog.setInterfaceId(ApiShConst.API_SH_1405); 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); } }