org.hpccsystems.ws.client.platform.Cluster Maven / Gradle / Ivy
/*******************************************************************************
* Copyright (c) 2011 HPCC Systems. All rights reserved. This program and the accompanying materials are made available
* under the terms of the Eclipse Public License v1.0 which accompanies this distribution, and is available at
* http://www.eclipse.org/legal/epl-v10.html
*
* Contributors: HPCC Systems - initial API and implementation
******************************************************************************/
package org.hpccsystems.ws.client.platform;
import java.util.HashMap;
import java.util.Map;
import org.hpccsystems.ws.client.HPCCWsTopologyClient;
import org.hpccsystems.ws.client.gen.axis2.wstopology.v1_28.TpClusterInfoResponse;
import org.hpccsystems.ws.client.gen.axis2.wstopology.v1_28.TpTargetCluster;
import org.hpccsystems.ws.client.utils.DataSingleton;
import org.hpccsystems.ws.client.utils.EqualsUtil;
import org.hpccsystems.ws.client.utils.HashCodeUtil;
import org.hpccsystems.ws.client.wrappers.ArrayOfEspExceptionWrapper;
import org.hpccsystems.ws.client.wrappers.gen.wstopology.TpClusterInfoResponseWrapper;
public class Cluster extends DataSingleton
{
private static Map Clusters = new HashMap();
public static synchronized Cluster get(Platform platform, String name)
{
Cluster cluster = new Cluster(platform, name);
if (Clusters.containsKey(cluster.hashCode()))
{
return Clusters.get(cluster.hashCode());
}
else
{
Clusters.put(cluster.hashCode(), cluster);
}
return cluster;
}
private Platform platform;
private TpTargetCluster info;
private TpClusterInfoResponse info2;
Cluster(Platform platform, String name)
{
this.platform = platform;
info = new TpTargetCluster();
info.setName(name);
info2 = new TpClusterInfoResponse();
info2.setName(name);
}
public String getName()
{
return info.getName();
}
@Override
protected boolean isComplete()
{
return true;
}
@Override
protected void fastRefresh()
{
fullRefresh();
}
@Override
protected void fullRefresh()
{
try
{
HPCCWsTopologyClient wsTopologyClient = platform.getWsClient().getWsTopologyClient();
TpClusterInfoResponseWrapper respsone = wsTopologyClient.getClusterInfo(info.getName());
Update(respsone);
}
catch (Exception e)
{
e.printStackTrace();
}
}
private void Update(TpClusterInfoResponseWrapper ci)
{
if (info2.getName().equals(ci.getName()))
{
info2 = ci.getRaw();
setChanged();
}
}
public void Update(TpTargetCluster tc)
{
if (info.getName().equals(tc.getName()))
{
info = tc;
setChanged();
}
}
void Update(TpClusterInfoResponse ci)
{
if (info2.getName().equals(ci.getName()))
{
info2 = ci;
setChanged();
}
}
@Override
public boolean equals(Object aThat)
{
if (this == aThat)
{
return true;
}
if (!(aThat instanceof Cluster))
{
return false;
}
Cluster that = (Cluster) aThat;
// now a proper field-by-field evaluation can be made
return EqualsUtil.areEqual(platform, that.platform) && EqualsUtil.areEqual(info.getName(), that.info.getName());
}
@Override
public int hashCode()
{
int result = HashCodeUtil.SEED;
result = HashCodeUtil.hash(result, platform);
result = HashCodeUtil.hash(result, info.getName());
return result;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy