/**
* Copyright (c) 2009-2011 VMware, Inc. 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.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package com.springsource.insight.plugin.cassandra;
import java.util.ArrayList;
import java.util.Collection;
import java.util.Collections;
import java.util.List;
import com.springsource.insight.intercept.operation.Operation;
import com.springsource.insight.intercept.operation.OperationType;
import com.springsource.insight.intercept.topology.AbstractExternalResourceAnalyzer;
import com.springsource.insight.intercept.topology.ExternalResourceDescriptor;
import com.springsource.insight.intercept.topology.ExternalResourceType;
import com.springsource.insight.intercept.topology.MD5NameGenerator;
import com.springsource.insight.intercept.trace.Frame;
import com.springsource.insight.intercept.trace.Trace;
import com.springsource.insight.util.ListUtil;
public abstract class AbsCassandraExternalResourceAnalyzer extends AbstractExternalResourceAnalyzer {
public AbsCassandraExternalResourceAnalyzer(OperationType type) {
super(type);
}
public Collection<ExternalResourceDescriptor> locateExternalResourceName(Trace trace, Collection<Frame> frames) {
if (ListUtil.size(frames) <= 0) {
return Collections.emptyList();
}
List<ExternalResourceDescriptor> queueDescriptors = new ArrayList<ExternalResourceDescriptor>(frames.size());
for (Frame cacheFrame : frames) {
Operation op = cacheFrame.getOperation();
String server = op.get("server", String.class, "");
int port = 0;
String host = server;
int indx = server.lastIndexOf(":");
if (indx > 0) {
host = server.substring(0, indx);
try {
port = Integer.parseInt(server.substring(indx + 1));
} catch (Exception e) {
// invalid port
}
}
String hashString = MD5NameGenerator.getName(server);
String color = colorManager.getColor(op);
ExternalResourceDescriptor descriptor =
new ExternalResourceDescriptor(cacheFrame, "server:" + hashString, server,
ExternalResourceType.DATABASE.name(), "Cassandra",
host, port, color, false);
queueDescriptors.add(descriptor);
}
return queueDescriptors;
}
}