use of com.huawei.esight.exception.EsightException in project Server_Management_Plugin_vRealize by Huawei.
the class ESightAdapter method onCollect.
/**
* This method is called for each collection cycle. By default, this value
* is 5 minutes unless user changes it
*
* @param adapterInstResource ResourceConfig
* @param monitoringResources Collection<ResourceConfig>
*/
@Override
public void onCollect(ResourceConfig adapterInstResource, Collection<ResourceConfig> monitoringResources) {
if (logger.isInfoEnabled()) {
logger.info("Inside onCollect method of ESightAdapter class");
}
final IdentifierCredentialProperties prop = new IdentifierCredentialProperties(adapterLoggerFactory, adapterInstResource);
String hostIp = prop.getIdentifier(Constant.KEY_SERVER_IP_ADDRESS, "").trim();
setHost(hostIp);
int hostPort = prop.getIntIdentifier(Constant.KEY_ESIGHT_SERVER_PORT, Constant.DEFAULT_ESIGHT_SERVER_PORT);
String username = prop.getCredential(Constant.KEY_ESIGHT_ACCOUNT);
String eSightCode = prop.getCredential(Constant.KEY_ESIGHT_CODE);
String openid = null;
try {
openid = service.login(hostIp, hostPort, username, eSightCode);
} catch (EsightException e) {
logger.error(e.getMessage() + ": eSight server (" + hostIp + ") authentication failed.", e);
}
if (openid == null || openid.isEmpty()) {
configEsight(hostIp);
return;
}
final Long startTime = System.nanoTime();
DiscoveryResult discoveryResult = collectResult.getDiscoveryResult(true);
List<ResourceKey> resources = collectResourceDataFromESight(hostIp);
// 注销会话 openid
service.logout(openid);
if (resources.size() == 0) {
logger.error("No resources collected from server with IP " + hostIp);
} else {
logger.error(resources.size() + " resources collected from server with IP " + hostIp);
}
for (ResourceKey resourceKey : resources) {
useResourceKey(discoveryResult, resourceKey);
}
Long seconds = TimeUnit.SECONDS.convert(System.nanoTime() - startTime, TimeUnit.NANOSECONDS);
logger.error("Collected resource from esight elapsed time is " + seconds + " seconds.");
if (seconds > Constant.DEFAULT_COLLECT_INTERVAL * 60) {
logger.error("PLEASE UPDATE THE COLLECT INTERVAL GREATER THAN " + seconds + " SECONDS.");
}
}
use of com.huawei.esight.exception.EsightException in project Server_Management_Plugin_vRealize by Huawei.
the class ESightAdapter method onTest.
/**
* This method is called when presses "Test" button while
* creating/editing an adapter instance.
*
* @param testParam TestParam
* @return boolean
*/
@Override
public boolean onTest(TestParam testParam) {
ResourceConfig adapterInstanceResource = testParam.getAdapterConfig().getAdapterInstResource();
final IdentifierCredentialProperties prop = new IdentifierCredentialProperties(adapterLoggerFactory, adapterInstanceResource);
if (logger.isInfoEnabled()) {
logger.info("Inside onTest method of ESightAdapter class");
}
String empty = "";
String hostIp = prop.getIdentifier(Constant.KEY_SERVER_IP_ADDRESS, empty).trim();
int serverPort = prop.getIntIdentifier(Constant.KEY_ESIGHT_SERVER_PORT, Constant.DEFAULT_ESIGHT_SERVER_PORT);
String username = prop.getCredential(Constant.KEY_ESIGHT_ACCOUNT);
String password = prop.getCredential(Constant.KEY_ESIGHT_CODE);
try {
if (!isValidUrl(hostIp, serverPort)) {
throw new EsightException("invalid host ip");
}
ESightService serviceImpl = new ESightServiceImpl();
String openid = serviceImpl.login(hostIp, serverPort, username, password);
if (openid == null || openid.isEmpty()) {
return false;
}
serviceImpl.logout(openid);
} catch (EsightException e) {
logger.error("Test eSight login failed.", e);
return false;
}
return true;
}
Aggregations