|  |  | 
 |  |  | import com.dy.pipIrrGlobal.voSe.VoUnlock; | 
 |  |  | import com.dy.pipIrrSell.clientCard.ClientCardSv; | 
 |  |  | import com.dy.pipIrrSell.clientCard.LastOperateENUM; | 
 |  |  | import com.dy.pipIrrSell.result.SellResultCode; | 
 |  |  | import io.swagger.v3.oas.annotations.Operation; | 
 |  |  | import io.swagger.v3.oas.annotations.Parameter; | 
 |  |  | import io.swagger.v3.oas.annotations.media.Content; | 
 |  |  | import io.swagger.v3.oas.annotations.media.Schema; | 
 |  |  | import io.swagger.v3.oas.annotations.responses.ApiResponse; | 
 |  |  | 
 |  |  | import org.springframework.web.bind.annotation.*; | 
 |  |  |  | 
 |  |  | import java.time.format.DateTimeFormatter; | 
 |  |  | import java.util.Date; | 
 |  |  | import java.util.List; | 
 |  |  | import java.util.Objects; | 
 |  |  | import java.util.Optional; | 
 |  |  | import java.util.*; | 
 |  |  |  | 
 |  |  | /** | 
 |  |  |  * @author ZhuBaoMin | 
 |  |  | 
 |  |  |                             schema = @Schema(implementation = VoUnlock.class))} | 
 |  |  |             ) | 
 |  |  |     }) | 
 |  |  |     @GetMapping(path = "/getUnlocks", consumes = MediaType.APPLICATION_JSON_VALUE) | 
 |  |  |     @SsoAop("-1") | 
 |  |  |     public BaseResponse<QueryResultVo<List<VoUnlock>>> getUnlocks(@RequestBody @Parameter(description = "查询form表单json数据", required = true) QueryVo vo){ | 
 |  |  |     @GetMapping(path = "/getUnlocks") | 
 |  |  |     @SsoAop() | 
 |  |  |     public BaseResponse<QueryResultVo<List<VoUnlock>>> getUnlocks(QueryVo vo){ | 
 |  |  |         try { | 
 |  |  |             QueryResultVo<List<VoUnlock>> res = unlockSv.getUnlocks(vo); | 
 |  |  |             return BaseResponseUtils.buildSuccess(res); | 
 |  |  | 
 |  |  |     }) | 
 |  |  |     @PostMapping(path = "add", consumes = MediaType.APPLICATION_JSON_VALUE) | 
 |  |  |     @Transactional(rollbackFor = Exception.class) | 
 |  |  |     @SsoAop("-1")//@SsoAop(power = "-1") | 
 |  |  |     public BaseResponse<Boolean> add(@RequestBody @Parameter(description = "form表单json数据", required = true) @Valid DtoUnlock po, @Parameter(hidden = true) BindingResult bindingResult){ | 
 |  |  |     @SsoAop() | 
 |  |  |     public BaseResponse<Boolean> add(@RequestBody @Valid DtoUnlock po, BindingResult bindingResult){ | 
 |  |  |         DateTimeFormatter dtf = DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm:ss"); | 
 |  |  |         if(bindingResult != null && bindingResult.hasErrors()){ | 
 |  |  |             return BaseResponseUtils.buildFail(Objects.requireNonNull(bindingResult.getFieldError()).getDefaultMessage()); | 
 |  |  |         } | 
 |  |  |  | 
 |  |  |         /** | 
 |  |  |          * cardId           水卡编号(非传入参数,由cardAddr反查) | 
 |  |  |          * cardAddr         水卡地址 | 
 |  |  |          * clientId         农户编号 | 
 |  |  |          * cardId           水卡编号(非传入参数,由cardAddr反查,修改农户卡使用) | 
 |  |  |          * clientId         农户编号(非传入参数,由cardNum反查) | 
 |  |  |          * cardNum          水卡地址 | 
 |  |  |          * money            余额 | 
 |  |  |          * remarks          备注 | 
 |  |  |          * operator         操作人编号 | 
 |  |  |          * unlockTime       解锁时间 | 
 |  |  |          */ | 
 |  |  |         Long cardId = 0L; | 
 |  |  |         String cardAddr = po.getCardAddr(); | 
 |  |  |         Long clientId = po.getClientId(); | 
 |  |  |         Long cardNum = po.getCardNum(); | 
 |  |  |         Long clientId = 0L; | 
 |  |  |         Float money = po.getMoney(); | 
 |  |  |         String remarks = po.getRemarks(); | 
 |  |  |         Long operator = po.getOperator(); | 
 |  |  |         Date unlockTime = new Date(); | 
 |  |  |  | 
 |  |  |         /** | 
 |  |  |          * 依据水卡地址获取水卡编号(主键) | 
 |  |  |          * 依据水卡编号获取水卡表主键及农户编号 | 
 |  |  |          */ | 
 |  |  |         cardId = Optional.ofNullable(clientCardSv.getCardIdByAddr(cardAddr)).orElse(0L); | 
 |  |  |         if(cardId == 0) { | 
 |  |  |             return BaseResponseUtils.buildFail("卡号错误,该卡不存在"); | 
 |  |  |         Map map = Optional.ofNullable(clientCardSv.getCardIdAndClientNum(cardNum)).orElse(new HashMap()); | 
 |  |  |         if(map == null || map.size() <= 0) { | 
 |  |  |             return BaseResponseUtils.buildFail(SellResultCode.CARD_NUMBER_MISTAKE.getMessage()); | 
 |  |  |         } | 
 |  |  |         cardId = Long.parseLong(map.get("cardId").toString()); | 
 |  |  |         clientId = Long.parseLong(map.get("clientId").toString()); | 
 |  |  |  | 
 |  |  |         /** | 
 |  |  |          * 修改农户卡信息: | 
 |  |  | 
 |  |  |         SeClientCard seClientCard = new SeClientCard(); | 
 |  |  |         seClientCard.setId(cardId); | 
 |  |  |         seClientCard.setUnlockdt(unlockTime); | 
 |  |  |         seClientCard.setMoney(money); | 
 |  |  |         seClientCard.setLastoper(LastOperateENUM.UNLOCK.getCode()); | 
 |  |  |         Integer rec_updateClientCard = Optional.ofNullable(clientCardSv.UpdateClientCard(seClientCard)).orElse(0); | 
 |  |  |         if(rec_updateClientCard == 0) { | 
 |  |  |             return BaseResponseUtils.buildFail("解锁失败-农户卡解锁异常"); | 
 |  |  |             return BaseResponseUtils.buildFail(SellResultCode.UNLOCK_FAIL_WRITE_CLIENT_CARD_ERROR.getMessage()); | 
 |  |  |         } | 
 |  |  |  | 
 |  |  |         /** | 
 |  |  |          * 添加解锁记录 | 
 |  |  |          */ | 
 |  |  |         SeUnlock seUnlock = new SeUnlock(); | 
 |  |  |         //seUnlock.setCardnum(cardNum); | 
 |  |  |         //seUnlock.setClientnum(clientNum); | 
 |  |  |         seUnlock.setCardid(cardId); | 
 |  |  |         seUnlock.setClientid(clientId); | 
 |  |  |         seUnlock.setMoney(money); | 
 |  |  | 
 |  |  |         seUnlock.setOperatedt(unlockTime); | 
 |  |  |         Long rec = Optional.ofNullable(unlockSv.add(seUnlock)).orElse(0L); | 
 |  |  |         if(rec == 0) { | 
 |  |  |             return BaseResponseUtils.buildFail("解锁失败-解锁记录写入异常"); | 
 |  |  |             return BaseResponseUtils.buildFail(SellResultCode.UNLOCK_FAIL_WRITE_UNLOCK_ERROR.getMessage()); | 
 |  |  |         } | 
 |  |  |  | 
 |  |  |         return BaseResponseUtils.buildSuccess(true) ; |