io.hyscale.controller.validator.impl.ClusterValidator Maven / Gradle / Ivy
/**
* Copyright 2019 Pramati Prism, Inc.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package io.hyscale.controller.validator.impl;
import io.hyscale.commons.exception.CommonErrorCode;
import io.hyscale.commons.io.StructuredOutputHandler;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Component;
import io.hyscale.commons.exception.HyscaleException;
import io.hyscale.commons.logger.LoggerTags;
import io.hyscale.commons.logger.WorkflowLogger;
import io.hyscale.commons.models.AuthConfig;
import io.hyscale.commons.validator.Validator;
import io.hyscale.controller.activity.ValidatorActivity;
import io.hyscale.controller.model.WorkflowContext;
import io.hyscale.deployer.services.deployer.Deployer;
import javax.annotation.PostConstruct;
import java.util.HashMap;
import java.util.Map;
/**
* Validate cluster information using {@link AuthConfig}
* provided by {@link WorkflowContext}
* Checks if access to cluster is allowed.
*/
@Component
public class ClusterValidator implements Validator {
private static final Logger logger = LoggerFactory.getLogger(ClusterValidator.class);
@Autowired
private Deployer deployer;
@Autowired
private StructuredOutputHandler outputHandler;
private Map clusterValidationMap;
@PostConstruct
public void init() {
clusterValidationMap = new HashMap<>();
}
@Override
public boolean validate(WorkflowContext context) throws HyscaleException {
if (clusterValidationMap.containsKey(context.getAuthConfig())) {
return clusterValidationMap.get(context.getAuthConfig());
}
long startTime = System.currentTimeMillis();
boolean isClusterValid = false;
logger.debug("Starting K8s cluster validation");
try {
isClusterValid = deployer.authenticate(context.getAuthConfig());
clusterValidationMap.put(context.getAuthConfig(), isClusterValid);
} catch (HyscaleException ex) {
logger.error("Error while validating cluster", ex);
clusterValidationMap.put(context.getAuthConfig(), false);
throw ex;
} finally {
if (!isClusterValid) {
WorkflowLogger.persist(ValidatorActivity.CLUSTER_AUTHENTICATION_FAILED, LoggerTags.ERROR);
if(WorkflowLogger.isDisabled()){
outputHandler.addErrorMessage(CommonErrorCode.FAILED_TO_CONNECT_TO_CLUSTER.getMessage());
}
}
}
logger.debug("Is K8s cluster valid: {}. Time taken: {}", isClusterValid, System.currentTimeMillis() - startTime);
return isClusterValid;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy