|  |  |  | 
|---|
|  |  |  | package com.zy.asrs.controller; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | import com.alibaba.fastjson.JSON; | 
|---|
|  |  |  | import com.alibaba.fastjson.JSONObject; | 
|---|
|  |  |  | import com.baomidou.mybatisplus.mapper.EntityWrapper; | 
|---|
|  |  |  | import com.core.annotations.ManagerAuth; | 
|---|
|  |  |  | import com.core.common.Arith; | 
|---|
|  |  |  | import com.core.common.Cools; | 
|---|
|  |  |  | import com.core.common.DateUtils; | 
|---|
|  |  |  | import com.core.common.R; | 
|---|
|  |  |  | import com.zy.asrs.domain.enums.CrnStatusType; | 
|---|
|  |  |  | import com.zy.asrs.domain.enums.SiteStatusType; | 
|---|
|  |  |  | import com.zy.asrs.domain.param.SystemSwitchParam; | 
|---|
|  |  |  | import com.zy.asrs.domain.vo.*; | 
|---|
|  |  |  | import com.zy.asrs.entity.BasCrnError; | 
|---|
|  |  |  | import com.zy.asrs.entity.BasDevp; | 
|---|
|  |  |  | import com.zy.asrs.entity.BasRgv; | 
|---|
|  |  |  | import com.zy.asrs.entity.WrkMast; | 
|---|
|  |  |  | import com.zy.asrs.mapper.BasCrnErrorMapper; | 
|---|
|  |  |  | import com.zy.asrs.mapper.LocMastMapper; | 
|---|
|  |  |  | import com.zy.asrs.service.BasDevpService; | 
|---|
|  |  |  | import com.zy.asrs.service.BasRgvService; | 
|---|
|  |  |  | import com.zy.asrs.service.WrkMastService; | 
|---|
|  |  |  | import com.zy.common.CodeRes; | 
|---|
|  |  |  | import com.zy.core.CrnThread; | 
|---|
|  |  |  | import com.zy.core.DevpThread; | 
|---|
|  |  |  | import com.zy.core.RgvThread2; | 
|---|
|  |  |  | import com.zy.core.Slave; | 
|---|
|  |  |  | import com.zy.core.cache.OutputQueue; | 
|---|
|  |  |  | import com.zy.core.cache.SlaveConnection; | 
|---|
|  |  |  | import com.zy.core.enums.CrnModeType; | 
|---|
|  |  |  | import com.zy.core.enums.SlaveType; | 
|---|
|  |  |  | import com.zy.core.model.CrnSlave; | 
|---|
|  |  |  | import com.zy.core.model.DevpSlave; | 
|---|
|  |  |  | import com.zy.core.model.RgvSlave; | 
|---|
|  |  |  | import com.zy.core.model.protocol.CrnProtocol; | 
|---|
|  |  |  | import com.zy.core.model.protocol.RgvProtocol; | 
|---|
|  |  |  | import com.zy.core.model.protocol.StaProtocol; | 
|---|
|  |  |  | import com.zy.core.properties.SlaveProperties; | 
|---|
|  |  |  | import com.zy.core.properties.SystemProperties; | 
|---|
|  |  |  | import com.zy.core.thread.DevpThread; | 
|---|
|  |  |  | import com.zy.core.thread.*; | 
|---|
|  |  |  | import lombok.extern.slf4j.Slf4j; | 
|---|
|  |  |  | import org.springframework.beans.factory.annotation.Autowired; | 
|---|
|  |  |  | import org.springframework.web.bind.annotation.PostMapping; | 
|---|
|  |  |  | import org.springframework.web.bind.annotation.RequestMapping; | 
|---|
|  |  |  | import org.springframework.web.bind.annotation.RequestParam; | 
|---|
|  |  |  | import org.springframework.web.bind.annotation.RestController; | 
|---|
|  |  |  | import org.springframework.web.bind.annotation.*; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | import java.util.*; | 
|---|
|  |  |  | import java.util.concurrent.atomic.AtomicInteger; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * 主控图接口 | 
|---|
|  |  |  | * Created by vincent on 2020-06-01 | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | @Slf4j | 
|---|
|  |  |  | @RestController | 
|---|
|  |  |  | @RequestMapping("/console") | 
|---|
|  |  |  | public class ConsoleController { | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | private SlaveProperties slaveProperties; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | public static AtomicInteger integer = new AtomicInteger(); | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | private WrkMastService wrkMastService; | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | private BasDevpService basDevpService; | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | private LocMastMapper locMastMapper; | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | private BasCrnErrorMapper basCrnErrorMapper; | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | private BasRgvService basRgvService; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @PostMapping("/system/running/status") | 
|---|
|  |  |  | @ManagerAuth(memo = "系统运行状态") | 
|---|
|  |  |  | 
|---|
|  |  |  | return R.error("口令错误"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | Thread.sleep(2000L); | 
|---|
|  |  |  | Thread.sleep(200L); | 
|---|
|  |  |  | SystemProperties.WCS_RUNNING_STATUS.set(param.getOperatorType()==1?Boolean.TRUE:Boolean.FALSE); | 
|---|
|  |  |  | return R.ok().add(Cools.add("status", SystemProperties.WCS_RUNNING_STATUS.get())); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @PostMapping("/site/detail") | 
|---|
|  |  |  | @ManagerAuth(memo = "输送设备数据详情") | 
|---|
|  |  |  | public R siteDetail(@RequestParam String siteId){ | 
|---|
|  |  |  | if (Cools.isEmpty(siteId)){ | 
|---|
|  |  |  | return R.parse(CodeRes.EMPTY); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | SiteDetailVo vo = new SiteDetailVo(); | 
|---|
|  |  |  | vo.setDevpNo(siteId); | 
|---|
|  |  |  | vo.setWorkNo("9998"); | 
|---|
|  |  |  | vo.setWorkStatus("2.设备上移动"); | 
|---|
|  |  |  | vo.setAutoing("Y"); | 
|---|
|  |  |  | vo.setLoading("Y"); | 
|---|
|  |  |  | vo.setCanining("N"); | 
|---|
|  |  |  | vo.setCanouting("Y"); | 
|---|
|  |  |  | vo.setIoType("1.入库"); | 
|---|
|  |  |  | vo.setSourceStaNo("2303"); | 
|---|
|  |  |  | vo.setStaNo("2410"); | 
|---|
|  |  |  | vo.setSourceStock(""); | 
|---|
|  |  |  | vo.setStock(""); | 
|---|
|  |  |  | return R.ok().add(vo); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @PostMapping("/crn/detail") | 
|---|
|  |  |  | @ManagerAuth(memo = "堆垛机设备数据详情") | 
|---|
|  |  |  | public R crnDetail(@RequestParam String crnNo){ | 
|---|
|  |  |  | if (Cools.isEmpty(crnNo)){ | 
|---|
|  |  |  | return R.parse(CodeRes.EMPTY); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | CrnDetailVo vo = new CrnDetailVo(); | 
|---|
|  |  |  | vo.setCrnNo(crnNo); | 
|---|
|  |  |  | vo.setWorkNo("3387"); | 
|---|
|  |  |  | vo.setSourceStaNo("2303"); | 
|---|
|  |  |  | vo.setStaNo("2410"); | 
|---|
|  |  |  | vo.setWorkStatus("3.吊车入库中"); | 
|---|
|  |  |  | vo.setIoType("1.入库"); | 
|---|
|  |  |  | vo.setSourceStock(""); | 
|---|
|  |  |  | vo.setStock("05050040"); | 
|---|
|  |  |  | vo.setCrnStatus("取货中"); | 
|---|
|  |  |  | vo.setError("0"); | 
|---|
|  |  |  | return R.ok().add(vo); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Deprecated | 
|---|
|  |  |  | @PostMapping("/site/update") | 
|---|
|  |  |  | @ManagerAuth(memo = "输送设备数据修改") | 
|---|
|  |  |  | public R updateSite(){ | 
|---|
|  |  |  | return R.ok(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Deprecated | 
|---|
|  |  |  | @PostMapping("/crn/update") | 
|---|
|  |  |  | @ManagerAuth(memo = "堆垛机数据修改") | 
|---|
|  |  |  | public R updateCrn(){ | 
|---|
|  |  |  | return R.ok(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /****************************************************************/ | 
|---|
|  |  |  | 
|---|
|  |  |  | stations.putAll(devpThread.getStation()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | List<BasRgv> basRgvs = basRgvService.selectList(new EntityWrapper<BasRgv>()); | 
|---|
|  |  |  | for (Map.Entry<Integer, StaProtocol> entry : stations.entrySet()) { | 
|---|
|  |  |  | SiteLatestDataVo vo = new SiteLatestDataVo(); | 
|---|
|  |  |  | StaProtocol staProtocol = entry.getValue(); | 
|---|
|  |  |  | vo.setSiteId(String.valueOf(entry.getKey())); // 站点编号 | 
|---|
|  |  |  | for (BasRgv basRgv: basRgvs){ | 
|---|
|  |  |  | if (basRgv.getRgvNo().equals(entry.getKey()) ){ | 
|---|
|  |  |  | staProtocol.setWorkNo(basRgv.getWrkNo1()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | vo.setWorkNo(staProtocol.getWorkNo()); // 工作号 | 
|---|
|  |  |  | vo.setSiteStatus(SiteStatusType.process(staProtocol));  // 状态 | 
|---|
|  |  |  | vo.setNearbySta(staProtocol.getNearbySta()); | 
|---|
|  |  |  | vos.add(vo); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | return R.ok().add(vos); | 
|---|
|  |  |  | 
|---|
|  |  |  | @ManagerAuth(memo = "堆垛机实时数据") | 
|---|
|  |  |  | public R crnLatestData(){ | 
|---|
|  |  |  | List<CrnLatestDataVo> vos = new ArrayList<>(); | 
|---|
|  |  |  | for (int i =1; i<=2; i++){ | 
|---|
|  |  |  | for (CrnSlave crn : slaveProperties.getCrn()) { | 
|---|
|  |  |  | // 获取堆垛机信息 | 
|---|
|  |  |  | CrnThread crnThread = (CrnThread) SlaveConnection.get(SlaveType.Crn, crn.getId()); | 
|---|
|  |  |  | if (crnThread == null) { | 
|---|
|  |  |  | continue; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | CrnProtocol crnProtocol = crnThread.getCrnProtocol(); | 
|---|
|  |  |  | if (crnProtocol == null) { | 
|---|
|  |  |  | continue; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | CrnLatestDataVo vo = new CrnLatestDataVo(); | 
|---|
|  |  |  | vo.setCrnId(i); | 
|---|
|  |  |  | vo.setOffset((double) new Random().nextInt(560)); | 
|---|
|  |  |  | vo.setCrnId(crn.getId());   //  堆垛机编号 | 
|---|
|  |  |  |  | 
|---|
|  |  |  | //            Short totalBay = locMastMapper.selectTotalBay(); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | vo.setOffset((double) new Random().nextInt(560));     //  堆垛机偏移量 | 
|---|
|  |  |  | vo.setBay((short) (crnProtocol.getBay() - crn.getOffset()));    //  当前列 | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * 堆垛机状态判断 | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | if (crnProtocol.getAlarm() > 0) { | 
|---|
|  |  |  | vo.setCrnStatus(CrnStatusType.MACHINE_ERROR); | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | if (crnProtocol.getTaskNo()>0) { | 
|---|
|  |  |  | WrkMast wrkMast = wrkMastService.selectById(crnProtocol.getTaskNo()); | 
|---|
|  |  |  | if (wrkMast != null) { | 
|---|
|  |  |  | vo.setCrnStatus(CrnStatusType.process(wrkMast.getIoType())); | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | vo.setCrnStatus(crnProtocol.modeType.equals(CrnModeType.AUTO)? CrnStatusType.MACHINE_AUTO: CrnStatusType.MACHINE_UN_AUTO); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | vo.setCrnStatus(crnProtocol.modeType.equals(CrnModeType.AUTO)? CrnStatusType.MACHINE_AUTO: CrnStatusType.MACHINE_UN_AUTO); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | vos.add(vo); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  | return R.ok().add(vos); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | 
|---|
|  |  |  | @PostMapping("/latest/data/barcode") | 
|---|
|  |  |  | @ManagerAuth(memo = "条码扫描仪实时数据") | 
|---|
|  |  |  | public R barcodeLatestData(){ | 
|---|
|  |  |  | integer.getAndIncrement(); | 
|---|
|  |  |  | List<BarcodeDataVo> list = new ArrayList<>(); | 
|---|
|  |  |  | for (int i=1;i<=1;i++){ | 
|---|
|  |  |  | BarcodeDataVo vo = new BarcodeDataVo(); | 
|---|
|  |  |  | vo.setBarcodeId("1"); | 
|---|
|  |  |  | if (integer.get()%5 != 0) { | 
|---|
|  |  |  | vo.setCodeValue("0"); | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | vo.setCodeValue(String.valueOf(new Random().nextInt(5000))); | 
|---|
|  |  |  | for (Slave barcode : slaveProperties.getBarcode()) { | 
|---|
|  |  |  | BarcodeThread barcodeThread = (BarcodeThread) SlaveConnection.get(SlaveType.Barcode, barcode.getId()); | 
|---|
|  |  |  | if (null == barcodeThread) { | 
|---|
|  |  |  | continue; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | BarcodeDataVo vo = new BarcodeDataVo(); | 
|---|
|  |  |  | vo.setBarcodeId(barcode.getId()); | 
|---|
|  |  |  | vo.setCodeValue(barcodeThread.getBarcode()); | 
|---|
|  |  |  | list.add(vo); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | return R.ok().add(list); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @PostMapping("/latest/data/scale") | 
|---|
|  |  |  | @ManagerAuth(memo = "磅秤实时数据") | 
|---|
|  |  |  | public R scaleLatestData(){ | 
|---|
|  |  |  | List<ScaleDataVo> list = new ArrayList<>(); | 
|---|
|  |  |  | for (Slave scale : slaveProperties.getScale()) { | 
|---|
|  |  |  | ScaleThread scaleThread = (ScaleThread) SlaveConnection.get(SlaveType.Scale, scale.getId()); | 
|---|
|  |  |  | if (null == scaleThread) { | 
|---|
|  |  |  | continue; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | ScaleDataVo vo = new ScaleDataVo(); | 
|---|
|  |  |  | vo.setScaleId(scale.getId()); | 
|---|
|  |  |  | vo.setValue(String.valueOf(Arith.multiplys(1, scaleThread.getScale(), 1))); | 
|---|
|  |  |  | list.add(vo); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | return R.ok().add(list); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /****************************************************************/ | 
|---|
|  |  |  | /************************** 详情操作 ******************************/ | 
|---|
|  |  |  | /****************************************************************/ | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @PostMapping("/site/detail") | 
|---|
|  |  |  | @ManagerAuth(memo = "输送设备数据详情") | 
|---|
|  |  |  | public R siteDetail(@RequestParam Integer siteId){ | 
|---|
|  |  |  | if (Cools.isEmpty(siteId)){ | 
|---|
|  |  |  | return R.parse(CodeRes.EMPTY); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | SiteDetailVo vo = new SiteDetailVo(); | 
|---|
|  |  |  | for (DevpSlave devp : slaveProperties.getDevp()) { | 
|---|
|  |  |  | DevpThread devpThread = (DevpThread) SlaveConnection.get(SlaveType.Devp, devp.getId()); | 
|---|
|  |  |  | if (null != devpThread) { | 
|---|
|  |  |  | StaProtocol staProtocol = devpThread.getStation().get(siteId); | 
|---|
|  |  |  | if (staProtocol != null) { | 
|---|
|  |  |  | BasDevp basDevp = basDevpService.selectById(siteId); | 
|---|
|  |  |  | if (basDevp == null) { | 
|---|
|  |  |  | return R.error("数据库维护异常"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | vo.setSiteId(siteId);   // 站点编号 | 
|---|
|  |  |  | vo.setWorkNo(staProtocol.getWorkNo());   // 工作号 | 
|---|
|  |  |  |  | 
|---|
|  |  |  | if (staProtocol.getWorkNo() > 0) { | 
|---|
|  |  |  | WrkMast wrkMast = wrkMastService.selectById(staProtocol.getWorkNo()); | 
|---|
|  |  |  | if (wrkMast != null) { | 
|---|
|  |  |  | vo.setWrkSts(wrkMast.getWrkSts$());   // 工作状态 | 
|---|
|  |  |  | vo.setIoType(wrkMast.getIoType$());   //  入出库类型 | 
|---|
|  |  |  | vo.setSourceStaNo(wrkMast.getSourceStaNo$()); | 
|---|
|  |  |  | vo.setStaNo(wrkMast.getStaNo$()); | 
|---|
|  |  |  | vo.setSourceLocNo(wrkMast.getSourceLocNo$()); | 
|---|
|  |  |  | vo.setLocNo(wrkMast.getLocNo$()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | vo.setAutoing(staProtocol.isAutoing()?"Y":"N"); //  自动 | 
|---|
|  |  |  | vo.setLoading(staProtocol.isLoading()?"Y":"N"); //  有物 | 
|---|
|  |  |  |  | 
|---|
|  |  |  | vo.setCanining(basDevp.getCanining());  //  能入 | 
|---|
|  |  |  | vo.setCanouting(basDevp.getCanouting());    //  能出 | 
|---|
|  |  |  |  | 
|---|
|  |  |  | return R.ok().add(vo); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | return R.error(); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @PostMapping("/crn/detail") | 
|---|
|  |  |  | @ManagerAuth(memo = "堆垛机设备数据详情") | 
|---|
|  |  |  | public R crnDetail(@RequestParam Integer crnNo){ | 
|---|
|  |  |  | if (Cools.isEmpty(crnNo)){ | 
|---|
|  |  |  | return R.parse(CodeRes.EMPTY); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | CrnDetailVo vo = new CrnDetailVo(); | 
|---|
|  |  |  | for (CrnSlave crnSlave : slaveProperties.getCrn()) { | 
|---|
|  |  |  | if (crnSlave.getId().equals(crnNo)) { | 
|---|
|  |  |  | SiemensCrnThread crnThread = (SiemensCrnThread) SlaveConnection.get(SlaveType.Crn, crnSlave.getId()); | 
|---|
|  |  |  | CrnProtocol crnProtocol = crnThread.getCrnProtocol(); | 
|---|
|  |  |  | vo.setCrnNo(crnNo); | 
|---|
|  |  |  | vo.setWorkNo(crnProtocol.getTaskNo()); | 
|---|
|  |  |  | vo.setCrnStatus(crnProtocol.getStatusType().desc); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | if (crnProtocol.getAlarm() > 0) { | 
|---|
|  |  |  | BasCrnError crnError = basCrnErrorMapper.selectById(crnProtocol.getAlarm()); | 
|---|
|  |  |  | vo.setError(crnError == null ? "未知异常" : crnError.getErrName()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | if (crnProtocol.getTaskNo() > 0) { | 
|---|
|  |  |  | WrkMast wrkMast = wrkMastService.selectById(crnProtocol.getTaskNo()); | 
|---|
|  |  |  | if (wrkMast != null) { | 
|---|
|  |  |  | vo.setSourceStaNo(wrkMast.getSourceStaNo$()); | 
|---|
|  |  |  | vo.setStaNo(wrkMast.getStaNo$()); | 
|---|
|  |  |  | vo.setWrkSts(wrkMast.getWrkSts$());   // 工作状态 | 
|---|
|  |  |  | vo.setIoType(wrkMast.getIoType$());   //  入出库类型 | 
|---|
|  |  |  | vo.setSourceLocNo(wrkMast.getSourceLocNo$()); | 
|---|
|  |  |  | vo.setLocNo(wrkMast.getLocNo$()); | 
|---|
|  |  |  | vo.setCrnStatus(crnProtocol.getStatusType().desc); | 
|---|
|  |  |  | vo.setError("");    // todo | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | return R.ok().add(vo); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | return R.error(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Deprecated | 
|---|
|  |  |  | @PostMapping("/site/update") | 
|---|
|  |  |  | @ManagerAuth(memo = "输送设备数据修改") | 
|---|
|  |  |  | public R updateSite(){ | 
|---|
|  |  |  | return R.ok(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Deprecated | 
|---|
|  |  |  | @PostMapping("/crn/update") | 
|---|
|  |  |  | @ManagerAuth(memo = "堆垛机数据修改") | 
|---|
|  |  |  | public R updateCrn(){ | 
|---|
|  |  |  | return R.ok(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @GetMapping("/barcode/output/site") | 
|---|
|  |  |  | public R crnOutput(){ | 
|---|
|  |  |  | ArrayList<JSONObject> jsonObjects = new ArrayList<>(OutputQueue.BARCODE); | 
|---|
|  |  |  | jsonObjects.sort(new Comparator<JSONObject>() { | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | public int compare(JSONObject o1, JSONObject o2) { | 
|---|
|  |  |  | Date o1Time = DateUtils.convert(o1.getString("time"), DateUtils.yyyyMMddHHmmss_F); | 
|---|
|  |  |  | Date o2Time = DateUtils.convert(o2.getString("time"), DateUtils.yyyyMMddHHmmss_F); | 
|---|
|  |  |  | return (int) (o2Time.getTime() - o1Time.getTime()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | }); | 
|---|
|  |  |  | return R.ok().add(JSON.toJSONString(jsonObjects)); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | } | 
|---|