/*
* Copyright 2017 LinkedIn Corp. All rights reserved.
*
* 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.
*/
package com.github.ambry.clustermap;
import org.apache.helix.HelixManager;
import org.apache.helix.HelixManagerFactory;
import org.apache.helix.InstanceType;
/**
* A factory class to construct and get a reference to a {@link HelixManager}
*/
public class HelixFactory {
/**
* Get a reference to a {@link HelixManager}
* @param clusterName the name of the cluster for which the manager is to be gotten.
* @param instanceName the name of the instance on whose behalf the manager is to be gotten.
* @param instanceType the {@link InstanceType} of the requester.
* @param zkAddr the address identifying the zk service to which this request is to be made.
* @return the constructed {@link HelixManager}.
*/
HelixManager getZKHelixManager(String clusterName, String instanceName, InstanceType instanceType,
String zkAddr) {
return HelixManagerFactory.getZKHelixManager(clusterName, instanceName, instanceType, zkAddr);
}
}