Search in sources :

Example 1 with ReturnTaskDisplayVO

use of com.dtstack.taier.develop.vo.schedule.ReturnTaskDisplayVO in project Taier by DTStack.

the class TaskTaskService method displayAllFlowSubTasks.

/**
 * 查询所有工作流节点
 *
 * @param taskShade 工作流任务
 * @return
 */
private ReturnTaskDisplayVO displayAllFlowSubTasks(ScheduleTaskShade taskShade) {
    ReturnTaskDisplayVO vo = new ReturnTaskDisplayVO();
    // 头节点
    TaskNodeVO root = new TaskNodeVO();
    setNode(taskShade, root);
    vo.setRootTaskNode(root);
    // 查询出所有工作流任务
    List<ScheduleTaskShade> taskShadeList = taskService.findAllFlowTasks(taskShade.getTaskId());
    if (CollectionUtils.isEmpty(taskShadeList)) {
        return vo;
    }
    // 查询出这些工作流的关系数据
    Map<Long, ScheduleTaskShade> taskMaps = taskShadeList.stream().collect(Collectors.toMap(ScheduleTaskShade::getTaskId, g -> (g)));
    Set<Long> taskSet = Sets.newHashSet(taskMaps.keySet());
    taskSet.add(taskShade.getTaskId());
    List<ScheduleTaskTaskShade> taskTaskShades = this.lambdaQuery().in(ScheduleTaskTaskShade::getTaskId, taskSet).eq(ScheduleTaskTaskShade::getIsDeleted, Deleted.NORMAL.getStatus()).list();
    if (CollectionUtils.isEmpty(taskTaskShades)) {
        return vo;
    }
    // 递归工作流任务的关系
    Map<Long, List<ScheduleTaskTaskShade>> taskTaskMap = taskTaskShades.stream().collect(Collectors.groupingBy(ScheduleTaskTaskShade::getParentTaskId));
    root.setChildNode(findChildNode(root, taskMaps, taskTaskMap));
    return vo;
}
Also used : ReturnTaskDisplayVO(com.dtstack.taier.develop.vo.schedule.ReturnTaskDisplayVO) ServiceImpl(com.baomidou.mybatisplus.extension.service.impl.ServiceImpl) QueryTaskDisplayDTO(com.dtstack.taier.scheduler.dto.schedule.QueryTaskDisplayDTO) ScheduleTaskShade(com.dtstack.taier.dao.domain.ScheduleTaskShade) UserService(com.dtstack.taier.develop.service.user.UserService) ReturnTaskDisplayVO(com.dtstack.taier.develop.vo.schedule.ReturnTaskDisplayVO) TaskNodeVO(com.dtstack.taier.develop.vo.schedule.TaskNodeVO) EnvironmentContext(com.dtstack.taier.common.env.EnvironmentContext) TenantService(com.dtstack.taier.develop.service.console.TenantService) Autowired(org.springframework.beans.factory.annotation.Autowired) Set(java.util.Set) Collectors(java.util.stream.Collectors) ScheduleTaskTaskShadeMapper(com.dtstack.taier.dao.mapper.ScheduleTaskTaskShadeMapper) Sets(com.google.common.collect.Sets) DisplayDirect(com.dtstack.taier.common.enums.DisplayDirect) ScheduleTaskTaskShade(com.dtstack.taier.dao.domain.ScheduleTaskTaskShade) List(java.util.List) Tenant(com.dtstack.taier.dao.domain.Tenant) Lists(com.google.common.collect.Lists) CollectionUtils(org.apache.commons.collections.CollectionUtils) Service(org.springframework.stereotype.Service) Map(java.util.Map) JobUtils(com.dtstack.taier.develop.utils.JobUtils) EScheduleJobType(com.dtstack.taier.common.enums.EScheduleJobType) Deleted(com.dtstack.taier.common.enums.Deleted) List(java.util.List) TaskNodeVO(com.dtstack.taier.develop.vo.schedule.TaskNodeVO) ScheduleTaskShade(com.dtstack.taier.dao.domain.ScheduleTaskShade) ScheduleTaskTaskShade(com.dtstack.taier.dao.domain.ScheduleTaskTaskShade)

Example 2 with ReturnTaskDisplayVO

use of com.dtstack.taier.develop.vo.schedule.ReturnTaskDisplayVO in project Taier by DTStack.

the class TaskTaskService method displayOffSpring.

/**
 * 展开任务上下游
 * @return 上下游规则
 */
public ReturnTaskDisplayVO displayOffSpring(QueryTaskDisplayDTO dto) {
    // 查询的最长层级不能超过 max.jobJob.level
    dto.setLevel(JobUtils.checkLevel(dto.getLevel(), context.getMaxLevel()));
    // 查询任务
    ScheduleTaskShade taskShade = taskService.lambdaQuery().eq(ScheduleTaskShade::getTaskId, dto.getTaskId()).eq(ScheduleTaskShade::getIsDeleted, Deleted.NORMAL.getStatus()).one();
    if (taskShade == null) {
        return null;
    }
    // 创建节点
    TaskNodeVO rootNode = new TaskNodeVO();
    setNode(taskShade, rootNode);
    Tenant tenant = tenantService.getTenantById(taskShade.getTenantId());
    if (null != tenant) {
        rootNode.setTenantName(tenant.getTenantName());
        rootNode.setTenantId(tenant.getId());
    }
    String userName = userService.getUserName(taskShade.getCreateUserId());
    rootNode.setOperatorId(taskShade.getCreateUserId());
    rootNode.setOperatorName(userName);
    if (DisplayDirect.CHILD.getType().equals(dto.getDirectType())) {
        rootNode.setChildNode(displayLevelNode(taskShade, dto.getLevel(), dto.getDirectType()));
    } else {
        rootNode.setParentNode(displayLevelNode(taskShade, dto.getLevel(), dto.getDirectType()));
    }
    ReturnTaskDisplayVO vo = new ReturnTaskDisplayVO();
    vo.setDirectType(dto.getDirectType());
    vo.setRootTaskNode(rootNode);
    return vo;
}
Also used : ReturnTaskDisplayVO(com.dtstack.taier.develop.vo.schedule.ReturnTaskDisplayVO) Tenant(com.dtstack.taier.dao.domain.Tenant) ScheduleTaskShade(com.dtstack.taier.dao.domain.ScheduleTaskShade) TaskNodeVO(com.dtstack.taier.develop.vo.schedule.TaskNodeVO)

Aggregations

ScheduleTaskShade (com.dtstack.taier.dao.domain.ScheduleTaskShade)2 Tenant (com.dtstack.taier.dao.domain.Tenant)2 ReturnTaskDisplayVO (com.dtstack.taier.develop.vo.schedule.ReturnTaskDisplayVO)2 TaskNodeVO (com.dtstack.taier.develop.vo.schedule.TaskNodeVO)2 ServiceImpl (com.baomidou.mybatisplus.extension.service.impl.ServiceImpl)1 Deleted (com.dtstack.taier.common.enums.Deleted)1 DisplayDirect (com.dtstack.taier.common.enums.DisplayDirect)1 EScheduleJobType (com.dtstack.taier.common.enums.EScheduleJobType)1 EnvironmentContext (com.dtstack.taier.common.env.EnvironmentContext)1 ScheduleTaskTaskShade (com.dtstack.taier.dao.domain.ScheduleTaskTaskShade)1 ScheduleTaskTaskShadeMapper (com.dtstack.taier.dao.mapper.ScheduleTaskTaskShadeMapper)1 TenantService (com.dtstack.taier.develop.service.console.TenantService)1 UserService (com.dtstack.taier.develop.service.user.UserService)1 JobUtils (com.dtstack.taier.develop.utils.JobUtils)1 QueryTaskDisplayDTO (com.dtstack.taier.scheduler.dto.schedule.QueryTaskDisplayDTO)1 Lists (com.google.common.collect.Lists)1 Sets (com.google.common.collect.Sets)1 List (java.util.List)1 Map (java.util.Map)1 Set (java.util.Set)1