feat: 异步查询最近连接主机.
This commit is contained in:
@@ -1,6 +1,8 @@
|
|||||||
package com.orion.ops.module.asset.controller;
|
package com.orion.ops.module.asset.controller;
|
||||||
|
|
||||||
import com.alibaba.fastjson.JSONArray;
|
import com.alibaba.fastjson.JSONArray;
|
||||||
|
import com.orion.ops.framework.log.core.annotation.IgnoreLog;
|
||||||
|
import com.orion.ops.framework.log.core.enums.IgnoreLogMode;
|
||||||
import com.orion.ops.framework.web.core.annotation.RestWrapper;
|
import com.orion.ops.framework.web.core.annotation.RestWrapper;
|
||||||
import com.orion.ops.module.asset.service.HostTerminalService;
|
import com.orion.ops.module.asset.service.HostTerminalService;
|
||||||
import io.swagger.v3.oas.annotations.Operation;
|
import io.swagger.v3.oas.annotations.Operation;
|
||||||
@@ -33,6 +35,7 @@ public class HostTerminalController {
|
|||||||
@Resource
|
@Resource
|
||||||
private HostTerminalService hostTerminalService;
|
private HostTerminalService hostTerminalService;
|
||||||
|
|
||||||
|
@IgnoreLog(IgnoreLogMode.ALL)
|
||||||
@GetMapping("/themes")
|
@GetMapping("/themes")
|
||||||
@Operation(summary = "获取主机终端主题")
|
@Operation(summary = "获取主机终端主题")
|
||||||
public JSONArray getTerminalThemes() {
|
public JSONArray getTerminalThemes() {
|
||||||
|
|||||||
@@ -30,7 +30,10 @@ public class AuthorizedHostWrapperVO {
|
|||||||
@Schema(description = "授权的主机列表")
|
@Schema(description = "授权的主机列表")
|
||||||
private List<HostVO> hostList;
|
private List<HostVO> hostList;
|
||||||
|
|
||||||
@Schema(description = "分组树节点映射 'groupId':hostIdList")
|
@Schema(description = "分组树节点映射 groupId:hostIdList")
|
||||||
private Map<String, Set<Long>> treeNodes;
|
private Map<String, Set<Long>> treeNodes;
|
||||||
|
|
||||||
|
@Schema(description = "最近访问的主机")
|
||||||
|
private List<Long> latestHosts;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -8,6 +8,7 @@ import com.orion.ops.module.asset.enums.HostConnectStatusEnum;
|
|||||||
import com.orion.ops.module.asset.enums.HostConnectTypeEnum;
|
import com.orion.ops.module.asset.enums.HostConnectTypeEnum;
|
||||||
|
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
import java.util.concurrent.Future;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 主机连接日志 服务类
|
* 主机连接日志 服务类
|
||||||
@@ -50,4 +51,13 @@ public interface HostConnectLogService {
|
|||||||
*/
|
*/
|
||||||
List<Long> getLatestConnectHostId(HostConnectLogQueryRequest request);
|
List<Long> getLatestConnectHostId(HostConnectLogQueryRequest request);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 查询用户最近连接的主机
|
||||||
|
*
|
||||||
|
* @param type type
|
||||||
|
* @param userId userId
|
||||||
|
* @return hostId
|
||||||
|
*/
|
||||||
|
Future<List<Long>> getLatestConnectHostIdAsync(HostConnectTypeEnum type, Long userId);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -9,10 +9,8 @@ import com.orion.ops.framework.common.utils.Valid;
|
|||||||
import com.orion.ops.module.asset.convert.HostGroupConvert;
|
import com.orion.ops.module.asset.convert.HostGroupConvert;
|
||||||
import com.orion.ops.module.asset.entity.request.asset.AssetAuthorizedDataQueryRequest;
|
import com.orion.ops.module.asset.entity.request.asset.AssetAuthorizedDataQueryRequest;
|
||||||
import com.orion.ops.module.asset.entity.vo.*;
|
import com.orion.ops.module.asset.entity.vo.*;
|
||||||
import com.orion.ops.module.asset.service.AssetAuthorizedDataService;
|
import com.orion.ops.module.asset.enums.HostConnectTypeEnum;
|
||||||
import com.orion.ops.module.asset.service.HostIdentityService;
|
import com.orion.ops.module.asset.service.*;
|
||||||
import com.orion.ops.module.asset.service.HostKeyService;
|
|
||||||
import com.orion.ops.module.asset.service.HostService;
|
|
||||||
import com.orion.ops.module.infra.api.*;
|
import com.orion.ops.module.infra.api.*;
|
||||||
import com.orion.ops.module.infra.entity.dto.data.DataGroupDTO;
|
import com.orion.ops.module.infra.entity.dto.data.DataGroupDTO;
|
||||||
import com.orion.ops.module.infra.entity.dto.tag.TagDTO;
|
import com.orion.ops.module.infra.entity.dto.tag.TagDTO;
|
||||||
@@ -59,6 +57,9 @@ public class AssetAuthorizedDataServiceImpl implements AssetAuthorizedDataServic
|
|||||||
@Resource
|
@Resource
|
||||||
private HostIdentityService hostIdentityService;
|
private HostIdentityService hostIdentityService;
|
||||||
|
|
||||||
|
@Resource
|
||||||
|
private HostConnectLogService hostConnectLogService;
|
||||||
|
|
||||||
@Resource
|
@Resource
|
||||||
private FavoriteApi favoriteApi;
|
private FavoriteApi favoriteApi;
|
||||||
|
|
||||||
@@ -176,6 +177,8 @@ public class AssetAuthorizedDataServiceImpl implements AssetAuthorizedDataServic
|
|||||||
AuthorizedHostWrapperVO wrapper = new AuthorizedHostWrapperVO();
|
AuthorizedHostWrapperVO wrapper = new AuthorizedHostWrapperVO();
|
||||||
// 查询我的收藏
|
// 查询我的收藏
|
||||||
Future<List<Long>> favoriteResult = favoriteApi.getFavoriteRelIdListAsync(FavoriteTypeEnum.HOST, userId);
|
Future<List<Long>> favoriteResult = favoriteApi.getFavoriteRelIdListAsync(FavoriteTypeEnum.HOST, userId);
|
||||||
|
// 查询最近连接的主机
|
||||||
|
Future<List<Long>> latestConnectHostIdList = hostConnectLogService.getLatestConnectHostIdAsync(HostConnectTypeEnum.SSH, userId);
|
||||||
// 查询数据别名
|
// 查询数据别名
|
||||||
Future<Map<Long, String>> dataAliasResult = dataAliasApi.getDataAliasAsync(userId, DataExtraTypeEnum.HOST);
|
Future<Map<Long, String>> dataAliasResult = dataAliasApi.getDataAliasAsync(userId, DataExtraTypeEnum.HOST);
|
||||||
// 查询分组
|
// 查询分组
|
||||||
@@ -205,6 +208,8 @@ public class AssetAuthorizedDataServiceImpl implements AssetAuthorizedDataServic
|
|||||||
this.getAuthorizedHostExtra(wrapper.getHostList(),
|
this.getAuthorizedHostExtra(wrapper.getHostList(),
|
||||||
favoriteResult.get(),
|
favoriteResult.get(),
|
||||||
dataAliasResult.get());
|
dataAliasResult.get());
|
||||||
|
// 设置最近连接的主机
|
||||||
|
wrapper.setLatestHosts(latestConnectHostIdList.get());
|
||||||
return wrapper;
|
return wrapper;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -2,6 +2,7 @@ package com.orion.ops.module.asset.service.impl;
|
|||||||
|
|
||||||
import com.alibaba.fastjson.JSON;
|
import com.alibaba.fastjson.JSON;
|
||||||
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
|
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
|
||||||
|
import com.orion.lang.constant.Const;
|
||||||
import com.orion.lang.define.wrapper.DataGrid;
|
import com.orion.lang.define.wrapper.DataGrid;
|
||||||
import com.orion.lang.utils.Arrays1;
|
import com.orion.lang.utils.Arrays1;
|
||||||
import com.orion.ops.framework.mybatis.core.query.Conditions;
|
import com.orion.ops.framework.mybatis.core.query.Conditions;
|
||||||
@@ -16,11 +17,14 @@ import com.orion.ops.module.asset.enums.HostConnectStatusEnum;
|
|||||||
import com.orion.ops.module.asset.enums.HostConnectTypeEnum;
|
import com.orion.ops.module.asset.enums.HostConnectTypeEnum;
|
||||||
import com.orion.ops.module.asset.service.HostConnectLogService;
|
import com.orion.ops.module.asset.service.HostConnectLogService;
|
||||||
import lombok.extern.slf4j.Slf4j;
|
import lombok.extern.slf4j.Slf4j;
|
||||||
|
import org.springframework.scheduling.annotation.Async;
|
||||||
import org.springframework.stereotype.Service;
|
import org.springframework.stereotype.Service;
|
||||||
|
|
||||||
import javax.annotation.Resource;
|
import javax.annotation.Resource;
|
||||||
import java.util.Date;
|
import java.util.Date;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
import java.util.concurrent.CompletableFuture;
|
||||||
|
import java.util.concurrent.Future;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 主机连接日志 服务实现类
|
* 主机连接日志 服务实现类
|
||||||
@@ -75,6 +79,13 @@ public class HostConnectLogServiceImpl implements HostConnectLogService {
|
|||||||
return hostConnectLogDAO.selectLatestConnectHostId(SecurityUtils.getLoginUserId(), request.getType(), request.getLimit());
|
return hostConnectLogDAO.selectLatestConnectHostId(SecurityUtils.getLoginUserId(), request.getType(), request.getLimit());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
@Async("asyncExecutor")
|
||||||
|
public Future<List<Long>> getLatestConnectHostIdAsync(HostConnectTypeEnum type, Long userId) {
|
||||||
|
List<Long> hostIdList = hostConnectLogDAO.selectLatestConnectHostId(userId, type.name(), Const.N_10);
|
||||||
|
return CompletableFuture.completedFuture(hostIdList);
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 构建查询 wrapper
|
* 构建查询 wrapper
|
||||||
*
|
*
|
||||||
|
|||||||
@@ -36,6 +36,7 @@ import com.orion.ops.module.infra.enums.TagTypeEnum;
|
|||||||
import com.orion.spring.SpringHolder;
|
import com.orion.spring.SpringHolder;
|
||||||
import lombok.SneakyThrows;
|
import lombok.SneakyThrows;
|
||||||
import lombok.extern.slf4j.Slf4j;
|
import lombok.extern.slf4j.Slf4j;
|
||||||
|
import org.springframework.scheduling.annotation.Async;
|
||||||
import org.springframework.stereotype.Service;
|
import org.springframework.stereotype.Service;
|
||||||
|
|
||||||
import javax.annotation.Resource;
|
import javax.annotation.Resource;
|
||||||
@@ -211,6 +212,7 @@ public class HostServiceImpl implements HostService {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@Async("asyncExecutor")
|
||||||
public void deleteHostRelByIdAsync(Long id) {
|
public void deleteHostRelByIdAsync(Long id) {
|
||||||
// 删除配置
|
// 删除配置
|
||||||
hostConfigDAO.deleteByHostId(id);
|
hostConfigDAO.deleteByHostId(id);
|
||||||
|
|||||||
@@ -7,6 +7,7 @@ import com.orion.ops.module.infra.entity.request.data.DataAliasUpdateRequest;
|
|||||||
import com.orion.ops.module.infra.enums.DataExtraTypeEnum;
|
import com.orion.ops.module.infra.enums.DataExtraTypeEnum;
|
||||||
import com.orion.ops.module.infra.service.DataAliasService;
|
import com.orion.ops.module.infra.service.DataAliasService;
|
||||||
import lombok.extern.slf4j.Slf4j;
|
import lombok.extern.slf4j.Slf4j;
|
||||||
|
import org.springframework.scheduling.annotation.Async;
|
||||||
import org.springframework.stereotype.Service;
|
import org.springframework.stereotype.Service;
|
||||||
|
|
||||||
import javax.annotation.Resource;
|
import javax.annotation.Resource;
|
||||||
@@ -53,6 +54,7 @@ public class DataAliasApiImpl implements DataAliasApi {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@Async("asyncExecutor")
|
||||||
public Future<Map<Long, String>> getDataAliasAsync(Long userId, DataExtraTypeEnum type) {
|
public Future<Map<Long, String>> getDataAliasAsync(Long userId, DataExtraTypeEnum type) {
|
||||||
Valid.notNull(userId);
|
Valid.notNull(userId);
|
||||||
return CompletableFuture.completedFuture(dataAliasService.getDataAlias(userId, type.name()));
|
return CompletableFuture.completedFuture(dataAliasService.getDataAlias(userId, type.name()));
|
||||||
|
|||||||
Reference in New Issue
Block a user