package com.fzzy.otherview.sh2023.pr; import com.alibaba.fastjson.JSON; import com.alibaba.fastjson.JSONObject; import com.bstek.dorado.annotation.DataProvider; import com.bstek.dorado.annotation.DataResolver; import com.bstek.dorado.annotation.Expose; import com.bstek.dorado.data.provider.Page; import com.fzzy.api.Constant; import com.fzzy.api.data.ApiParam; import com.fzzy.api.dto.ResponseDto; import com.fzzy.api.entity.ApiConfs; import com.fzzy.api.entity.ApiInfoData; import com.fzzy.api.service.ApiCommonService; import com.fzzy.api.service.ApiPushManager; import com.fzzy.api.service.ApiRemoteService; import com.fzzy.api.utils.ContextUtil; import com.fzzy.api.view.repository.ApiInfoDataRep; import com.fzzy.push.sh2023.SH2023Constant; import com.fzzy.push.sh2023.dto.SH2023Api2102; import org.apache.commons.lang.StringUtils; import org.apache.commons.lang.time.DateFormatUtils; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.data.domain.PageRequest; import org.springframework.data.domain.Pageable; import org.springframework.data.domain.Sort; import org.springframework.data.jpa.domain.Specification; import org.springframework.stereotype.Component; import javax.persistence.criteria.CriteriaBuilder; import javax.persistence.criteria.CriteriaQuery; import javax.persistence.criteria.Predicate; import javax.persistence.criteria.Root; import java.util.ArrayList; import java.util.Date; import java.util.List; /** * 上海市接口-2102 倒仓倒入 * * @author czt * @date 2023/8/17 */ @Component(value = "sHApi2102PR") public class SHApi2102PR { @Autowired private ApiInfoDataRep apiInfoDataRep; @Autowired private ApiCommonService apiCommonService; @Autowired private ApiPushManager apiPushManager; /** * 获取信息 * sHApi2102PR#listData * * @return */ @DataProvider public void listData(Page page, ApiParam param) { Pageable pageable = PageRequest.of(page.getPageNo() - 1, page.getPageSize(), Sort.Direction.DESC, "updateTime"); Specification specification = new Specification() { private static final long serialVersionUID = 1L; @Override public Predicate toPredicate(Root root, CriteriaQuery criteriaQuery, CriteriaBuilder criteriaBuilder) { List predicates = new ArrayList<>(); //所有的断言 Predicate predicate = criteriaBuilder.equal(root.get("inteId"), SH2023Constant.SH_2023_API_CODE_2102); predicates.add(predicate); if (null != param) { if (StringUtils.isNotBlank(param.getKqdm())) { Predicate predicate1 = criteriaBuilder.equal(root.get("kqdm"), param.getKqdm()); predicates.add(predicate1); } if (StringUtils.isNotBlank(param.getCzbz())) { Predicate predicate2 = criteriaBuilder.equal(root.get("czbz"), param.getCzbz()); predicates.add(predicate2); } if (null != param.getStart()) { Predicate predicate3 = criteriaBuilder.greaterThan(root.get("updateTime"), ContextUtil.getCurZero(param.getStart())); predicates.add(predicate3); } if (null != param.getEnd()) { Predicate predicate4 = criteriaBuilder.lessThan(root.get("updateTime"), ContextUtil.getNextZero(param.getEnd())); predicates.add(predicate4); } } return criteriaBuilder.and(predicates.toArray(new Predicate[0])); } }; org.springframework.data.domain.Page japPage = apiInfoDataRep.findAll(specification, pageable); page.setEntityCount((int) japPage.getTotalElements()); List list = new ArrayList<>(); SH2023Api2102 sh2023Api2102; for (ApiInfoData infoData : japPage.getContent()) { sh2023Api2102 = JSONObject.parseObject(infoData.getData(), SH2023Api2102.class); list.add(sh2023Api2102); } page.setEntities(list); } /** * sHApi2102PR#saveData */ @DataResolver public void saveData(SH2023Api2102 data) { if (null == data.getPch() || data.getPch() == "") { data.setPch(data.getDrhwdm() + DateFormatUtils.format(data.getDcrq(), "yyyy")); } ApiInfoData infoData = new ApiInfoData(); infoData.setId(data.getDrdh()); infoData.setKqdm(data.getDrhwdm().substring(0, 21)); infoData.setInteId(SH2023Constant.SH_2023_API_CODE_2102); infoData.setUpdateTime(new Date()); infoData.setDataId(data.getDrdh()); infoData.setData(JSON.toJSONString(data)); infoData.setCzbz(data.getCzbz()); infoData.setRemarks("备注信息"); apiInfoDataRep.save(infoData); } /** * sHApi2102PR#delData */ @Expose public void delData(SH2023Api2102 data) { apiInfoDataRep.deleteById(data.getDrdh()); } /** * sHApi2102PR#delUpdate */ @Expose public String delUpdate(SH2023Api2102 entity) { if (null == entity) { return "无数据执行"; } entity.setCzbz(Constant.CZBZ_D); apiInfoDataRep.updateStatus(entity.getDrdh(), JSON.toJSONString(entity), Constant.CZBZ_D); return null; } @Expose public String pushData(List items) { String result = ""; String kqdm = items.get(0).getDrhwdm().substring(0, 21); ApiConfs apiConf = apiCommonService.getConf(kqdm); if (null == apiConf) { return "系统没有获取到当前库区配置信息,执行失败"; } //封装参数 ApiParam param = new ApiParam(apiConf, "90", Constant.API_CODE_9103); //获取实现接口 ApiRemoteService apiService = apiPushManager.getApiRemoteService(param.getPushProtocol()); if (null == apiService) { return "系统没有当前推送协议配置,执行失败"; } ResponseDto responseDto; ApiInfoData infoData; for (SH2023Api2102 data : items) { //推送,数据为集合形式 responseDto = apiService.pushData(param, apiConf, data); if (responseDto.getSuccess() == 0) { //推送成功,更新数据上传状态 if (Constant.CZBZ_I.equals(data.getCzbz())) { List apiInfoList = apiInfoDataRep.getDataByInteAndData(SH2023Constant.SH_2023_API_CODE_2102, data.getDrdh(), data.getDrdw()); data.setCzbz(Constant.CZBZ_U); infoData = apiInfoList.get(0); infoData.setUpdateTime(new Date()); infoData.setCzbz(Constant.CZBZ_U); infoData.setData(JSON.toJSONString(data)); apiInfoDataRep.save(infoData); } } result += responseDto.toString(); } return result; } }