From 4696a0be1e0235e4a9e5077c3f42e038da8c6809 Mon Sep 17 00:00:00 2001 From: zhang <zc857179121@qq.com> Date: 星期四, 14 八月 2025 16:30:37 +0800 Subject: [PATCH] 1 --- zy-acs-manager/src/main/java/com/zy/acs/manager/manager/controller/OpenController.java | 120 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++---- 1 files changed, 112 insertions(+), 8 deletions(-) diff --git a/zy-acs-manager/src/main/java/com/zy/acs/manager/manager/controller/OpenController.java b/zy-acs-manager/src/main/java/com/zy/acs/manager/manager/controller/OpenController.java index fba286a..a55eee0 100644 --- a/zy-acs-manager/src/main/java/com/zy/acs/manager/manager/controller/OpenController.java +++ b/zy-acs-manager/src/main/java/com/zy/acs/manager/manager/controller/OpenController.java @@ -1,22 +1,36 @@ package com.zy.acs.manager.manager.controller; -import com.zy.acs.manager.common.annotation.OperationLog; +import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; +import com.zy.acs.framework.common.Cools; import com.zy.acs.framework.common.R; -import com.zy.acs.manager.system.controller.BaseController; +import com.zy.acs.manager.common.annotation.OperationLog; +import com.zy.acs.manager.common.domain.BaseParam; +import com.zy.acs.manager.common.domain.PageParam; +import com.zy.acs.manager.core.constant.LocGroupConstant; import com.zy.acs.manager.core.service.MainService; import com.zy.acs.manager.manager.controller.param.OpenBusSubmitParam; +import com.zy.acs.manager.manager.entity.Loc; +import com.zy.acs.manager.manager.entity.Sta; +import com.zy.acs.manager.manager.enums.StaStsType; +import com.zy.acs.manager.manager.service.LocService; +import com.zy.acs.manager.manager.service.StaService; +import com.zy.acs.manager.system.controller.BaseController; +import com.zy.acs.manager.system.service.ConfigService; import io.swagger.annotations.Api; import org.springframework.beans.factory.annotation.Autowired; -import org.springframework.security.access.prepost.PreAuthorize; import org.springframework.web.bind.annotation.PostMapping; import org.springframework.web.bind.annotation.RequestBody; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RestController; +import java.util.Collections; +import java.util.List; +import java.util.Map; + /** * Created by vincent on 2023/6/12 */ -@Api(tags = "寮�鏀惧钩鍙�") +@Api(tags = "Open Api") @RestController @RequestMapping("/api/open") public class OpenController extends BaseController { @@ -24,12 +38,102 @@ @Autowired private MainService mainService; - @PreAuthorize("hasAuthority('open:bus:submit')") + @Autowired + private LocService locService; + + @Autowired + private StaService staService; + + @Autowired + private ConfigService configService; + + //@PreAuthorize("hasAuthority('open:bus:submit')") @PostMapping("/bus/submit") - @OperationLog("浠诲姟涓嬪彂") + @OperationLog("generate task from open api") public R save(@RequestBody OpenBusSubmitParam param) { - mainService.generateBusAndTask(param, null); - return R.ok("淇濆瓨鎴愬姛"); + if (!configService.getVal("TaskAssignMode", Boolean.class)) { + if (configService.getVal("InAndOutMode", Boolean.class, false)) { + mainService.generateBusAndTask(param, null); + return R.ok("generate tasks success"); + } + } + return R.error("generate tasks error"); + } + + @PostMapping("/sta/update") + @OperationLog("sync sta") + public R updateLoc(@RequestBody Map<String, Object> map) { + if (!configService.getVal("TaskAssignMode", Boolean.class)) { + if (configService.getVal("InAndOutMode", Boolean.class, false)) { + String staNo = map.get("staNo").toString(); + Sta loc = staService.selectByStaNo(staNo); + if (staNo.equals("1001")) { + if (loc.getStaSts() == StaStsType.STOCK.val()) { + loc.setStaSts(Long.parseLong(map.get("sts").toString())); + return staService.updateById(loc) ? R.ok() : R.error("update loc fail"); + } + } else if (staNo.equals("1007")) { + if (loc.getStaSts() == StaStsType.IDLE.val()) { + loc.setStaSts(Long.parseLong(map.get("sts").toString())); + return staService.updateById(loc) ? R.ok() : R.error("update loc fail"); + } + } + } + } + return R.error("update loc fail"); + } + + //@PreAuthorize("hasAuthority('open:bus:submit')") + @PostMapping("/loc/sync") + @OperationLog("sync loc") + public R loc(@RequestBody Map<String, Object> map) { + BaseParam baseParam = buildParam(map, BaseParam.class); + PageParam<Loc, BaseParam> pageParam = new PageParam<>(baseParam, Loc.class); + return R.ok().add(locService.page(pageParam, pageParam.buildWrapper(true))); + } + + @PostMapping("/loc/one") + @OperationLog("one loc") + public R emptyLoc(@RequestBody Map<String, Object> map) { + if (!configService.getVal("TaskAssignMode", Boolean.class)) { + if (configService.getVal("InAndOutMode", Boolean.class, false)) { + String staNo = map.get("staNo").toString(); + Integer startRow = null; + Integer endRow = null; + if (staNo.equals("101-2") || staNo.equals("101-3") || staNo.equals("102-2") || staNo.equals("102-3")) { + startRow = Collections.min(LocGroupConstant.FAR_RIGHT_LOC_ROW_LIST); + endRow = Collections.max(LocGroupConstant.FAR_RIGHT_LOC_ROW_LIST); + } else if (staNo.equals("103-2") || staNo.equals("103-3") || staNo.equals("104-2") || staNo.equals("104-3")) { + startRow = Collections.min(LocGroupConstant.RIGHT_LOC_ROW_LIST); + endRow = Collections.max(LocGroupConstant.RIGHT_LOC_ROW_LIST); + } else if (staNo.equals("105-2") || staNo.equals("105-3") || staNo.equals("106-2") || staNo.equals("106-3")) { + startRow = Collections.min(LocGroupConstant.MIDDLE_LOC_ROW_LIST); + endRow = Collections.max(LocGroupConstant.MIDDLE_LOC_ROW_LIST); + } else if (staNo.equals("107-2") || staNo.equals("107-3") || staNo.equals("108-2") || staNo.equals("108-3")) { + startRow = Collections.min(LocGroupConstant.LEFT_LOC_ROW_LIST); + endRow = Collections.max(LocGroupConstant.LEFT_LOC_ROW_LIST); + } else if (staNo.equals("1007") || staNo.equals("1001")) { + startRow = Collections.min(LocGroupConstant.FAR_LEFT_LOC_ROW_LIST); + endRow = Collections.max(LocGroupConstant.FAR_LEFT_LOC_ROW_LIST); + } else { + return R.error("staNo is not support"); + } + LambdaQueryWrapper<Loc> idleWrapper = new LambdaQueryWrapper<Loc>().eq(Loc::getLocSts, Long.parseLong(map.get("sts").toString())); + if (null != startRow) { + idleWrapper.ge(Loc::getRow, startRow); + } + if (null != endRow) { + idleWrapper.le(Loc::getRow, endRow); + } + List<Loc> idleList = locService.list(idleWrapper); + if (Cools.isEmpty(idleList)) { + return R.error("娌$┖搴撲綅"); + } + Collections.shuffle(idleList); + return R.ok().add(idleList.get(0)); + } + } + return R.error("鏈紑鍚妯″紡"); } } -- Gitblit v1.9.1