/*
* 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 org.apache.ambari.server.topology.validators;
import org.apache.ambari.server.topology.ClusterTopology;
import org.apache.ambari.server.topology.Configuration;
import org.apache.ambari.server.topology.InvalidTopologyException;
import org.apache.ambari.server.topology.TopologyValidator;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
/**
* Validates hive service related setup before provisioning the cluster.
*/
public class HiveServiceValidator implements TopologyValidator {
private static final Logger LOGGER = LoggerFactory.getLogger(HiveServiceValidator.class);
private static final String HIVE_ENV = "hive-env";
private static final String HIVE_DB_DEFAULT = "New MySQL Database";
private static final String HIVE_DB_PROPERTY = "hive_database";
private static final String MYSQL_SERVER_COMPONENT = "MYSQL_SERVER";
public static final String HIVE_SERVICE = "HIVE";
@Override
public void validate(ClusterTopology topology) throws InvalidTopologyException {
// there is no hive configured in the blueprint, nothing to do (does the validator apply?)
if (!topology.getBlueprint().getServices().contains(HIVE_SERVICE)) {
LOGGER.info(" [{}] service is not listed in the blueprint, skipping hive service validation.", HIVE_SERVICE);
return;
}
Configuration clusterConfiguration = topology.getConfiguration();
// hive database settings are missing (this should never be the case, defaults come from the stack def.)
if (!clusterConfiguration.getAllConfigTypes().contains(HIVE_ENV)) {
String errorMessage = String.format(" [ %s ] config type is missing from the service [ %s ]. HIVE service validation failed.", HIVE_ENV, HIVE_SERVICE);
LOGGER.error(errorMessage);
throw new InvalidTopologyException(errorMessage);
}
// hive database has custom configuration, skipping validation
if (!HIVE_DB_DEFAULT.equals(clusterConfiguration.getPropertyValue(HIVE_ENV, HIVE_DB_PROPERTY))) {
LOGGER.info("Custom hive database settings detected. HIVE service validation succeeded.");
return;
}
// hive database settings need the mysql-server component in the blueprint
if (!topology.getBlueprint().getComponents(HIVE_SERVICE).contains(MYSQL_SERVER_COMPONENT)) {
String errorMessage = String.format("Component [%s] must explicitly be set in the blueprint when hive database " +
"is configured with the current settings. HIVE service validation failed.", MYSQL_SERVER_COMPONENT);
LOGGER.error(errorMessage);
throw new InvalidTopologyException(errorMessage);
}
}
}