/*
* Copyright 2017 NAVER Corp.
*
* 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.navercorp.pinpoint.web.cluster;
import com.navercorp.pinpoint.thrift.dto.command.TCommandTransferResponse;
import com.navercorp.pinpoint.thrift.dto.command.TRouteResult;
import com.navercorp.pinpoint.thrift.io.DeserializerFactory;
import com.navercorp.pinpoint.thrift.io.HeaderTBaseDeserializer;
import com.navercorp.pinpoint.thrift.util.SerializationUtils;
import org.apache.commons.lang3.ArrayUtils;
import org.apache.thrift.TBase;
/**
* @Author Taejin Koo
*/
public class DefaultPinpointRouteResponse implements PinpointRouteResponse {
private final byte[] payload;
private TRouteResult routeResult;
private TBase response;
private boolean isParsed;
public DefaultPinpointRouteResponse(byte[] payload) {
this.payload = payload;
}
public void parse(DeserializerFactory<HeaderTBaseDeserializer> commandDeserializerFactory) {
if (!isParsed) {
if (ArrayUtils.isEmpty(payload)) {
routeResult = TRouteResult.EMPTY_RESPONSE;
return;
}
TBase object = deserialize(commandDeserializerFactory, payload, null);
if (object == null) {
routeResult = TRouteResult.NOT_SUPPORTED_RESPONSE;
} else if (object instanceof TCommandTransferResponse) {
TCommandTransferResponse commandResponse = (TCommandTransferResponse) object;
TRouteResult routeResult = commandResponse.getRouteResult();
if (routeResult == null) {
this.routeResult = TRouteResult.UNKNOWN;
} else {
this.routeResult = routeResult;
}
response = deserialize(commandDeserializerFactory, commandResponse.getPayload(), null);
} else {
routeResult = TRouteResult.UNKNOWN;
response = object;
}
isParsed = true;
}
}
@Override
public TRouteResult getRouteResult() {
assertParsed();
return routeResult;
}
@Override
public TBase getResponse() {
assertParsed();
return response;
}
@Override
public <R extends TBase> R getResponse(Class<R> clazz) {
TBase response = getResponse();
if (clazz.isInstance(response)) {
return (R) response;
}
throw new ClassCastException("Not expected " + clazz + " type.");
}
@Override
public <R extends TBase> R getResponse(Class<R> clazz, R defaultValue) {
TBase response = getResponse();
if (clazz.isInstance(response)) {
return (R) response;
}
return defaultValue;
}
private void assertParsed() {
if (!isParsed) {
throw new IllegalStateException("not yet parsed.");
}
}
private TBase deserialize(DeserializerFactory<HeaderTBaseDeserializer> commandDeserializerFactory, byte[] objectData, TBase defaultValue) {
return SerializationUtils.deserialize(objectData, commandDeserializerFactory, defaultValue);
}
}