From ed8c7a5effd0d423ce1118b680ecdca6fe732609 Mon Sep 17 00:00:00 2001 From: 13693261870 <252740454@qq.com> Date: 星期三, 02 七月 2025 16:43:13 +0800 Subject: [PATCH] Merge branch 'master' of http://192.168.11.205:9000/r/P2022036_Service --- src/main/java/com/lf/server/controller/show/ApplyController.java | 260 ++++++++++++++++++++++++++++++++++++++++------------ 1 files changed, 200 insertions(+), 60 deletions(-) diff --git a/src/main/java/com/lf/server/controller/show/ApplyController.java b/src/main/java/com/lf/server/controller/show/ApplyController.java index 3bcb0f2..3d6f7c2 100644 --- a/src/main/java/com/lf/server/controller/show/ApplyController.java +++ b/src/main/java/com/lf/server/controller/show/ApplyController.java @@ -2,15 +2,23 @@ import com.lf.server.annotation.SysLog; import com.lf.server.controller.all.BaseController; +import com.lf.server.entity.all.HttpStatus; import com.lf.server.entity.all.ResponseMsg; +import com.lf.server.entity.all.StaticData; import com.lf.server.entity.ctrl.DownloadReqEntity; +import com.lf.server.entity.data.DownloadEntity; import com.lf.server.entity.show.ApplyEntity; +import com.lf.server.entity.show.FlowEntity; import com.lf.server.entity.sys.UserEntity; import com.lf.server.helper.AesHelper; import com.lf.server.helper.StringHelper; +import com.lf.server.helper.WebHelper; import com.lf.server.service.data.DownloadService; import com.lf.server.service.show.ApplyService; +import com.lf.server.service.show.FlowService; +import com.lf.server.service.sys.DownlogService; import com.lf.server.service.sys.TokenService; +import com.lf.server.service.sys.UserService; import io.swagger.annotations.Api; import io.swagger.annotations.ApiImplicitParam; import io.swagger.annotations.ApiImplicitParams; @@ -19,13 +27,15 @@ import org.springframework.web.bind.annotation.*; import javax.servlet.http.HttpServletRequest; +import javax.servlet.http.HttpServletResponse; +import java.sql.Timestamp; import java.util.List; /** * 鏁版嵁鐢宠 * @author WWW */ -@Api(tags = "杩愮淮绠$悊\\鏁版嵁鐢宠") +@Api(tags = "缁煎悎灞曠ず\\鏁版嵁鐢宠") @RestController @RequestMapping("/apply") public class ApplyController extends BaseController { @@ -33,133 +43,263 @@ ApplyService applyService; @Autowired + FlowService flowService; + + @Autowired TokenService tokenService; + + @Autowired + UserService userService; + + @Autowired + DownlogService downlogService; + + @Autowired + DownloadService downloadService; @SysLog() @ApiOperation(value = "鎻掑叆鏁版嵁鐢宠") @ApiImplicitParams({ - @ApiImplicitParam(name = "reqEntity", value = "璇锋眰涓嬭浇瀹炰綋", dataType = "DownloadReqEntity", paramType = "body") + @ApiImplicitParam(name = "dr", value = "璇锋眰涓嬭浇瀹炰綋", dataType = "DownloadReqEntity", paramType = "body") }) @ResponseBody @PostMapping(value = "/insertApply") - public ResponseMsg<Object> insertApply(@RequestBody DownloadReqEntity reqEntity, HttpServletRequest req) { + public ResponseMsg<Object> insertApply(@RequestBody DownloadReqEntity dr, HttpServletRequest req) { try { - if (null == reqEntity || StringHelper.isEmpty(reqEntity.getPwd())) { - return fail("瀵嗙爜涓嶈兘涓虹┖"); - } - if (null == reqEntity.getTabs() || null == reqEntity.getEntities() || reqEntity.getTabs().size() != reqEntity.getEntities().size()) { + if (null == dr || null == dr.getEntities() || dr.getEntities().isEmpty()) { return fail("璇烽�夋嫨瑕佷笅杞界殑瀹炰綋鍚�"); } - if (null == reqEntity.getIds() || reqEntity.getIds().isEmpty()) { - return fail("璇烽�夋嫨鍗曚綅ID"); + if (StringHelper.isEmpty(dr.getPwd())) { + return fail("瀵嗙爜涓嶈兘涓虹┖"); } - reqEntity.setWkt(AesHelper.decrypt(reqEntity.getWkt())); - if (StringHelper.isEmpty(reqEntity.getWkt())) { - return fail("璇烽�夋嫨瑕佷笅杞界殑WKT鑼冨洿"); - } - if (!DownloadService.decryptPwd(reqEntity)) { - return fail("瀵嗙爜瑙e瘑澶辫触", null); - } - if (!StringHelper.checkPwdValid(reqEntity.getPwd())) { + dr.setPwd(AesHelper.decrypt(dr.getPwd())); + if (StringHelper.isPwdInvalid(dr.getPwd())) { return fail("瀵嗙爜涓嶇鍚堣姹�"); + } + if (!StringHelper.isEmpty(dr.getWkt())) { + dr.setWkt(AesHelper.decrypt(dr.getWkt())); + } + if (null == dr.getTabs() || dr.getTabs().isEmpty()) { + return fail("璇烽�夋嫨瑕佷笅杞界殑琛ㄥ悕"); + } + if (null == dr.getDepcodes() || dr.getDepcodes().isEmpty()) { + return fail("璇烽�夋嫨寰呯敵璇风殑鍗曚綅缂栫爜(澶氫釜浠ラ�楀彿闅斿紑)"); } UserEntity ue = tokenService.getCurrentUser(req); - int rows = applyService.insertApply(ue, reqEntity); + int rows = applyService.insertApply(ue, dr); return success(rows); } catch (Exception ex) { - return fail(ex.getMessage(), null); + return fail(ex, null); } } @SysLog() - @ApiOperation(value = "鍒嗛〉鏌ヨ骞惰繑鍥炶褰曟暟") + @ApiOperation(value = "鍒嗛〉鏌ヨ鐢宠") @ApiImplicitParams({ - @ApiImplicitParam(name = "userid", value = "鐢ㄦ埛ID", dataType = "Integer", paramType = "query", example = ""), + @ApiImplicitParam(name = "uname", value = "鐢ㄦ埛鍚�", dataType = "String", paramType = "query", example = "鍛�"), + @ApiImplicitParam(name = "status", value = "鐘舵��", dataType = "Integer", paramType = "query", example = "0"), + @ApiImplicitParam(name = "start", value = "寮�濮嬫椂闂�", dataType = "Timestamp", paramType = "query", example = "2022-12-09 09:00:00"), + @ApiImplicitParam(name = "end", value = "缁撴潫鏃堕棿", dataType = "Timestamp", paramType = "query", example = "2022-12-31 23:00:00"), @ApiImplicitParam(name = "pageSize", value = "姣忛〉鏉℃暟", dataType = "Integer", paramType = "query", example = "10"), @ApiImplicitParam(name = "pageIndex", value = "鍒嗛〉鏁帮紙浠�1寮�濮嬶級", dataType = "Integer", paramType = "query", example = "1") }) - @GetMapping(value = "/selectByPageAndCount") - public ResponseMsg<List<ApplyEntity>> selectByPageAndCount(Integer userid, Integer pageSize, Integer pageIndex) { + @GetMapping(value = "/selectByPage") + public ResponseMsg<Object> selectByPage(String uname, Integer status, Timestamp start, Timestamp end, Integer pageSize, Integer pageIndex, HttpServletRequest req) { try { if (pageSize < 1 || pageIndex < 1) { return fail("姣忛〉椤垫暟鎴栧垎椤垫暟灏忎簬1", null); } - int count = applyService.selectCount(userid); + int count = applyService.selectCount(uname, status, start, end); if (count == 0) { return success(0, null); } - List<ApplyEntity> rs = applyService.selectByPage(userid, pageSize, pageSize * (pageIndex - 1)); + UserEntity ue = tokenService.getCurrentUser(req); + List<ApplyEntity> rs = applyService.selectByPage(ue.getId(), uname, status, start, end, pageSize, pageSize * (pageIndex - 1)); return success(count, rs); } catch (Exception ex) { - return fail(ex.getMessage(), null); + return fail(ex, null); } } @SysLog() - @ApiOperation(value = "鎻掑叆涓�鏉�") - @ApiImplicitParams({ - @ApiImplicitParam(name = "entity", value = "瀹炰綋绫�", dataType = "ApplyEntity", paramType = "body") - }) - @PostMapping(value = "/insert", produces = "application/json; charset=UTF-8") - public ResponseMsg<Integer> insert(@RequestBody ApplyEntity entity, HttpServletRequest req) { + @ApiOperation(value = "鏌ヨ寰呭鏍告暟") + @GetMapping(value = "/selectSubmits") + public ResponseMsg<Object> selectSubmits(HttpServletRequest req) { try { UserEntity ue = tokenService.getCurrentUser(req); - if (ue != null) { - entity.setCreateUser(ue.getId()); - } + int rows = applyService.selectSubmits(ue.getId()); - int count = applyService.insert(entity); - - return success(count); + return success(rows); } catch (Exception ex) { - return fail(ex.getMessage(), -1); + return fail(ex, null); } } @SysLog() - @ApiOperation(value = "鍒犻櫎澶氭潯") + @ApiOperation(value = "鏌ヨ娴佺▼") @ApiImplicitParams({ - @ApiImplicitParam(name = "ids", value = "ID鏁扮粍", dataType = "Integer", paramType = "query", example = "1,2") + @ApiImplicitParam(name = "applyid", value = "鏁版嵁鐢宠ID", dataType = "Integer", paramType = "query", example = "1") }) - @GetMapping(value = "/deletes") - public ResponseMsg<Integer> deletes(@RequestParam List<Integer> ids) { + @GetMapping(value = "/selectFlows") + public ResponseMsg<Object> selectFlows(Integer applyid) { try { - if (ids == null || ids.isEmpty()) { - return fail("id鏁扮粍涓嶈兘涓虹┖", -1); - } + List<FlowEntity> rs = applyService.selectFlows(applyid); - int count = applyService.deletes(ids); - - return success(count); + return success(rs); } catch (Exception ex) { - return fail(ex.getMessage(), -1); + return fail(ex, null); } } @SysLog() - @ApiOperation(value = "鏇存柊涓�鏉�") + @ApiOperation(value = "搴熷純鐢宠") @ApiImplicitParams({ - @ApiImplicitParam(name = "entity", value = "瀹炰綋绫�", dataType = "ApplyEntity", paramType = "body") + @ApiImplicitParam(name = "applyid", value = "鏁版嵁鐢宠ID", dataType = "Integer", paramType = "query", example = "1") + }) + @GetMapping(value = "/updateForDiscard") + public ResponseMsg<Object> updateForDiscard(Integer applyid, HttpServletRequest req) { + try { + ApplyEntity applyEntity = applyService.selectById(applyid); + if (null == applyEntity) { + return fail("鎵句笉鍒版暟鎹敵璇�"); + } + if (!(applyEntity.getStatus() >= -1 && applyEntity.getStatus() <= StaticData.NINE)) { + return fail("璇ユ暟鎹敵璇锋棤娉曞簾寮�"); + } + + UserEntity ue = tokenService.getCurrentUser(req); + int rows = applyService.updateForDiscard(ue.getId(), applyid); + + return success(rows); + } catch (Exception ex) { + return fail(ex, null); + } + } + + @SysLog() + @ApiOperation(value = "閲嶆柊鎻愪氦") + @ApiImplicitParams({ + @ApiImplicitParam(name = "applyid", value = "鏁版嵁鐢宠ID", dataType = "Integer", paramType = "query", example = "1") + }) + @GetMapping(value = "/updateForResubmit") + public ResponseMsg<Object> updateForResubmit(Integer applyid, HttpServletRequest req) { + try { + ApplyEntity applyEntity = applyService.selectById(applyid); + if (null == applyEntity) { + return fail("鎵句笉鍒版暟鎹敵璇�"); + } + if (-1 != applyEntity.getStatus()) { + return fail("璇ユ暟鎹敵璇锋棤闇�閲嶆柊鎻愪氦"); + } + + UserEntity ue = tokenService.getCurrentUser(req); + int rows = applyService.updateForResubmit(ue.getId(), applyid); + + return success(rows); + } catch (Exception ex) { + return fail(ex, null); + } + } + + @SysLog() + @ApiOperation(value = "鎻愪氦娴佺▼") + @ApiImplicitParams({ + @ApiImplicitParam(name = "flowId", value = "鐢宠娴佺▼ID", dataType = "Integer", paramType = "query", example = "1") + }) + @GetMapping(value = "/updateForSubmit") + public ResponseMsg<Object> updateForSubmit(Integer flowId, HttpServletRequest req) { + try { + FlowEntity flowEntity = flowService.selectById(flowId); + if (null == flowEntity) { + return fail("鎵句笉鍒扮敵璇锋祦绋�"); + } + if (flowEntity.getStatus() != 0) { + return fail("璇ョ敵璇锋祦绋嬫棤闇�鎻愪氦"); + } + + ApplyEntity applyEntity = applyService.selectById(flowEntity.getApplyid()); + if (null == applyEntity) { + return fail("鎵句笉鍒版暟鎹敵璇�"); + } + if (!(applyEntity.getStatus() >= 0 && applyEntity.getStatus() <= StaticData.NINE)) { + return fail("璇ユ暟鎹敵璇锋棤闇�鎵撳洖"); + } + + UserEntity ue = tokenService.getCurrentUser(req); + int rows = applyService.updateForSubmit(ue.getId(), applyEntity.getId(), flowEntity.getId()); + + applyEntity = applyService.selectById(applyEntity.getId()); + if (StaticData.I10 == applyEntity.getStatus()) { + UserEntity user = userService.selectUser(applyEntity.getUserid()); + applyService.zipDbData(user, applyEntity); + } + + return success(rows); + } catch (Exception ex) { + return fail(ex, null); + } + } + + @SysLog() + @ApiOperation(value = "鎵撳洖娴佺▼") + @ApiImplicitParams({ + @ApiImplicitParam(name = "flowId", value = "鐢宠娴佺▼ID", dataType = "Integer", paramType = "query", example = "1") + }) + @GetMapping(value = "/updateForReject") + public ResponseMsg<Object> updateForReject(Integer flowId, HttpServletRequest req) { + try { + FlowEntity flowEntity = flowService.selectById(flowId); + if (null == flowEntity) { + return fail("鎵句笉鍒扮敵璇锋祦绋�"); + } + if (flowEntity.getStatus() != 0) { + return fail("璇ョ敵璇锋祦绋嬫棤闇�鎵撳洖"); + } + + ApplyEntity applyEntity = applyService.selectById(flowEntity.getApplyid()); + if (null == applyEntity) { + return fail("鎵句笉鍒版暟鎹敵璇�"); + } + if (!(applyEntity.getStatus() >= 0 && applyEntity.getStatus() <= StaticData.NINE)) { + return fail("璇ユ暟鎹敵璇锋棤闇�鎵撳洖"); + } + + UserEntity ue = tokenService.getCurrentUser(req); + Integer rows = applyService.updateForReject(ue.getId(), applyEntity.getId(), flowEntity.getId()); + + return success(rows); + } catch (Exception ex) { + return fail(ex, null); + } + } + + @SysLog() + @ApiOperation(value = "涓嬭浇鏂囦欢") + @ApiImplicitParams({ + @ApiImplicitParam(name = "guid", value = "鏂囦欢GUID", dataType = "String", paramType = "query") }) @ResponseBody - @PostMapping(value = "/update", produces = "application/json; charset=UTF-8") - public ResponseMsg<Integer> update(@RequestBody ApplyEntity entity, HttpServletRequest req) { + @GetMapping(value = "/downloadFile") + public void downloadFile(String guid, HttpServletRequest req, HttpServletResponse res) { try { - UserEntity ue = tokenService.getCurrentUser(req); - if (ue != null) { - entity.setUpdateUser(ue.getId()); + DownloadEntity de = downloadService.selectByGuid(guid); + if (null == de) { + WebHelper.writeInfo(HttpStatus.NOT_FOUND, "鏂囦欢涓嶅瓨鍦�", res); + return; } - int count = applyService.update(entity); + UserEntity ue = tokenService.getCurrentUser(req); + downlogService.updateInfos(ue, de, req); - return success(count); + String filePath = downloadService.getDownloadFilePath(de); + WebHelper.download(filePath, de.getName(), res); } catch (Exception ex) { - return fail(ex.getMessage(), -1); + WebHelper.writeInfo(HttpStatus.ERROR, ex.getMessage(), res); } } } -- Gitblit v1.9.3