// Copyright (C) 2011 Splunk Inc.
//
// Splunk Inc. licenses this file
// to you 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 com.splunk.shuttl.archiver.clustering;
import java.net.URI;
import javax.management.InstanceNotFoundException;
import com.splunk.ClusterPeers;
import com.splunk.Service;
import com.splunk.shuttl.server.mbeans.JMXSplunk;
import com.splunk.shuttl.server.mbeans.JMXSplunkMBean;
/**
* Creates ClusterPeers by after getting a master uri.
*/
public class ClusterPeersProvider {
private final JMXSplunkMBean mBeanProxy;
/**
* @param mBeanProxy
*/
public ClusterPeersProvider(JMXSplunkMBean mBeanProxy) {
this.mBeanProxy = mBeanProxy;
}
public ClusterPeers getClusterPeers(URI masterUri) {
Service service = new Service(masterUri.getHost(), masterUri.getPort());
service.login(mBeanProxy.getUsername(), mBeanProxy.getPassword());
return new ClusterPeers(service);
}
public static ClusterPeersProvider create() {
try {
return new ClusterPeersProvider(JMXSplunk.getMBeanProxy());
} catch (InstanceNotFoundException e) {
throw new RuntimeException(e);
}
}
}