VerifyController.java 10.9 KB
package com.huaheng.tool.controller;

import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
import com.baomidou.mybatisplus.core.toolkit.Wrappers;
import com.huaheng.common.core.exception.BaseException;
import com.huaheng.common.core.web.domain.AjaxResult;
import com.huaheng.config.api.RemoteLocationService;
import com.huaheng.config.api.domain.Location;
import com.huaheng.task.api.RemoteTaskService;
import com.huaheng.task.api.domain.TaskHeader;
import com.huaheng.tool.domain.LocationVerify;
import com.huaheng.tool.domain.TaskVerify;
import com.huaheng.tool.domain.ContrastLocation;
import com.huaheng.tool.domain.ContrastTask;
import com.huaheng.tool.service.WcslocationService;
import com.huaheng.tool.service.WcstaskService;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;

import javax.annotation.Resource;
import java.util.ArrayList;
import java.util.List;

@RestController
@RequestMapping("/verify")
public class VerifyController {

    @Resource
    private WcslocationService wcslocationService;
    @Resource
    private WcstaskService wcstaskService;
    @Resource
    private RemoteLocationService locationService;
    @Resource
    private RemoteTaskService taskService;


    @GetMapping("/locationStatusList")
    public AjaxResult locationStatusList() {
        LambdaQueryWrapper<ContrastLocation> wcsWrapper = Wrappers.lambdaQuery();

        wcsWrapper.eq(ContrastLocation::getStatus, "lock");

        List<Location> locations = locationService.remoteList("status");
        if (locations==null){
            throw new BaseException("调用库位服务失败");
        }
        if (locations.size()==0){
            return AjaxResult.success("本地锁定状态库位为空");
        }
        List<ContrastLocation> contrastLocations = wcslocationService.list(wcsWrapper);
        if (contrastLocations.size()==0){
            return AjaxResult.success("对照数据库锁定状态库位为空");
        }

        ArrayList<LocationVerify> verifyLocations = new ArrayList<>();
        ArrayList<Location> removeWmsLocation = new ArrayList<>();
        ArrayList<ContrastLocation> removeWcsLocation = new ArrayList<>();

        for (Location location : locations) {
            for (ContrastLocation contrastLocation : contrastLocations) {
                if (location.getCode().equals(contrastLocation.getCode())) {
                    removeWmsLocation.add(location);
                    removeWcsLocation.add(contrastLocation);
                }
            }
        }
        if (removeWcsLocation.size() == contrastLocations.size() && removeWmsLocation.size() == locations.size()) {
            return AjaxResult.success("校验通过,数据匹配");
        } else {
            locations.removeAll(removeWmsLocation);
            contrastLocations.removeAll(removeWcsLocation);
            if (locations.size() != 0) {
                for (Location location : locations) {
                    LocationVerify locationVerify = new LocationVerify();
                    locationVerify.setLocalContain(location.getContainerCode());
                    locationVerify.setLocalLocation(location.getCode());
                    locationVerify.setLocalLocationStatus(location.getStatus());
                    locationVerify.setContrastLocationStatus("empty");
                    verifyLocations.add(locationVerify);
                }
                if (contrastLocations.size() != 0) {
                    for (ContrastLocation contrastLocation : contrastLocations) {
                        LocationVerify locationVerify = new LocationVerify();
                        locationVerify.setLocalContain(contrastLocation.getContainerCode());
                        locationVerify.setLocalLocation(contrastLocation.getCode());
                        locationVerify.setLocalLocationStatus("empty");
                        locationVerify.setContrastLocationStatus("lock");
                        verifyLocations.add(locationVerify);
                    }
                }
            }
//            if (verifyLocations.size()>1000){
//                return AjaxResult.success("校验不通过,不符的数据大于1000条,暂时不支持大数据量差的结果显示");
//            }
            return AjaxResult.success("校验不通过,有"+verifyLocations.size()+"条数据不符",verifyLocations);
        }
    }

    @GetMapping("locationWithContainerList")
    public AjaxResult locationWithContainerList() {
        LambdaQueryWrapper<ContrastLocation> wcsWrapper = Wrappers.lambdaQuery();
        wcsWrapper.isNotNull(ContrastLocation::getContainerCode);
        List<Location> locations = locationService.remoteList("container");
        if (locations.size()==0){
            return AjaxResult.success("本地库位为空");
        }
        List<ContrastLocation> contrastLocations = wcslocationService.list(wcsWrapper);
        if (contrastLocations.size()==0){
            return AjaxResult.success("对照数据库库位为空");
        }

        ArrayList<LocationVerify> verifyLocations = new ArrayList<>();
        ArrayList<Location> removeWmsLocation = new ArrayList<>();
        ArrayList<ContrastLocation> removeWcsLocation = new ArrayList<>();

        for (Location location : locations) {
            for (ContrastLocation contrastLocation : contrastLocations) {
                if (location.getCode().equals(contrastLocation.getCode())) {
                    if (!location.getContainerCode().equals(contrastLocation.getContainerCode())) {
                        LocationVerify locationVerify = new LocationVerify();
                        locationVerify.setLocalLocation(location.getCode());
                        locationVerify.setContrastLocation(contrastLocation.getCode());
                        locationVerify.setLocalContain(location.getContainerCode());
                        locationVerify.setContrastLocation(location.getContainerCode());
                        verifyLocations.add(locationVerify);
                    }
                    removeWmsLocation.add(location);
                    removeWcsLocation.add(contrastLocation);
                }
            }
        }
        if (removeWcsLocation.size() == contrastLocations.size() && removeWmsLocation.size() == locations.size() &&
                verifyLocations.size() == 0) {
            return AjaxResult.success("校验通过,数据匹配");
        } else {
            locations.removeAll(removeWmsLocation);
            contrastLocations.removeAll(removeWcsLocation);
            if (locations.size() != 0) {
                for (Location location : locations) {
                    LocationVerify locationVerify = new LocationVerify();
                    locationVerify.setLocalContain(location.getContainerCode());
                    locationVerify.setLocalLocation(location.getCode());
                    locationVerify.setContrastLocation(location.getCode());
                    locationVerify.setContrastContain("");
                    verifyLocations.add(locationVerify);
                }
                if (contrastLocations.size() != 0) {
                    for (ContrastLocation contrastLocation : contrastLocations) {
                        LocationVerify locationVerify = new LocationVerify();
                        locationVerify.setLocalContain("");
                        locationVerify.setLocalLocation(contrastLocation.getCode());
                        locationVerify.setContrastContain(contrastLocation.getContainerCode());
                        locationVerify.setContrastLocation(contrastLocation.getCode());
                        verifyLocations.add(locationVerify);
                    }
                }
            }
//            if (verifyLocations.size()>1000){
//                return AjaxResult.success("校验不通过,不符的数据大于1000条,暂时不支持大数据量差的结果显示");
//            }
            return AjaxResult.success("校验不通过,有"+verifyLocations.size()+"条数据不符",verifyLocations);
        }
    }

    @GetMapping("/taskStatuslist")
    public AjaxResult taskStatuslist(){
        LambdaQueryWrapper<TaskHeader> localTaskWrapper = Wrappers.lambdaQuery();
        LambdaQueryWrapper<ContrastTask> wcsTaskWrapper = Wrappers.lambdaQuery();
        localTaskWrapper.gt(TaskHeader::getStatus,10)
                .lt(TaskHeader::getStatus,100);
        wcsTaskWrapper.lt(ContrastTask::getTaskStatus,100);
        List<TaskHeader> taskHeaders = taskService.remoteList(localTaskWrapper);
        List<ContrastTask> contrastTasks = wcstaskService.list(wcsTaskWrapper);

        ArrayList<TaskVerify> verifyTasks = new ArrayList<>();
        ArrayList<TaskHeader> removeWmsTask = new ArrayList<>();
        ArrayList<ContrastTask> removeWcsTask = new ArrayList<>();

        for (TaskHeader taskHeader : taskHeaders) {
            for (ContrastTask contrastTask : contrastTasks) {
                if (taskHeader.getId().equals(Integer.valueOf(contrastTask.getRemoteTaskNo()))) {
                    removeWmsTask.add(taskHeader);
                    removeWcsTask.add(contrastTask);
                }
            }
        }
        if (removeWcsTask.size() == contrastTasks.size() && removeWmsTask.size() == taskHeaders.size()) {
            return AjaxResult.success("校验通过,数据匹配");
        } else {
            taskHeaders.removeAll(removeWmsTask);
            contrastTasks.removeAll(removeWcsTask);
            if (taskHeaders.size() != 0) {
                for (TaskHeader taskHeader : taskHeaders) {
                    TaskVerify taskVerify = new TaskVerify();
                    taskVerify.setLocalId(taskHeader.getId());
                    taskVerify.setLocalContainerCode(taskHeader.getContainerCode());
                    taskVerify.setLocalTaskStatus(taskHeader.getStatus());
                    taskVerify.setContrastTaskStatus(100);
                    verifyTasks.add(taskVerify);
                }
                if (contrastTasks.size() != 0) {
                    for (ContrastTask contrastTask : contrastTasks) {
                        TaskVerify taskVerify = new TaskVerify();
                        taskVerify.setLocalId(Integer.valueOf(contrastTask.getRemoteTaskNo()));
                        taskVerify.setLocalContainerCode(contrastTask.getContainerCode());
                        taskVerify.setLocalTaskStatus(100);
                        taskVerify.setContrastTaskStatus((int) contrastTask.getTaskStatus());
                        verifyTasks.add(taskVerify);
                    }
                }
            }
//            if (verifyTasks.size()>1000){
//                return AjaxResult.success("校验不通过,不符的数据大于1000条,暂时不支持大数据量差的结果显示");
//            }
            return AjaxResult.success("校验不通过,有"+verifyTasks.size()+"条数据不符",verifyTasks);
        }
    }
}