/* * Copyright 2014 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.thrift.util; import org.apache.thrift.TBase; import org.apache.thrift.TException; import org.slf4j.Logger; import org.slf4j.LoggerFactory; import com.navercorp.pinpoint.thrift.io.DeserializerFactory; import com.navercorp.pinpoint.thrift.io.HeaderTBaseDeserializer; import com.navercorp.pinpoint.thrift.io.HeaderTBaseSerializer; import com.navercorp.pinpoint.thrift.io.SerializerFactory; public final class SerializationUtils { private static final Logger LOGGER = LoggerFactory.getLogger(SerializationUtils.class); private SerializationUtils() { } public static byte[] serialize(TBase object, SerializerFactory<HeaderTBaseSerializer> factory) throws TException { assertNotNull(factory, "SerializerFactory may note be null."); return serialize(object, factory.createSerializer()); } public static byte[] serialize(TBase object, HeaderTBaseSerializer serializer) throws TException { assertNotNull(object, "TBase may note be null."); assertNotNull(serializer, "Serializer may note be null."); return serializer.serialize(object); } public static byte[] serialize(TBase object, SerializerFactory<HeaderTBaseSerializer> factory, byte[] defaultValue) { try { return serialize(object, factory); } catch (Exception e) { if (LOGGER.isWarnEnabled()) { LOGGER.warn("Serialize " + object + " failed. Error:" + e.getMessage(), e); } } return defaultValue; } public static byte[] serialize(TBase object, HeaderTBaseSerializer serializer, byte[] defaultValue) { try { return serialize(object, serializer); } catch (Exception e) { if (LOGGER.isWarnEnabled()) { LOGGER.warn("Serialize " + object + " failed. Error:" + e.getMessage(), e); } } return defaultValue; } public static TBase deserialize(byte[] objectData, DeserializerFactory<HeaderTBaseDeserializer> factory) throws TException { assertNotNull(factory, "DeserializerFactory may note be null."); return deserialize(objectData, factory.createDeserializer()); } public static TBase deserialize(byte[] objectData, HeaderTBaseDeserializer deserializer) throws TException { assertNotNull(objectData, "TBase may note be null."); assertNotNull(deserializer, "Deserializer may note be null."); return deserializer.deserialize(objectData); } public static TBase deserialize(byte[] objectData, DeserializerFactory<HeaderTBaseDeserializer> factory, TBase defaultValue) { try { return deserialize(objectData, factory); } catch (Exception e) { if (LOGGER.isWarnEnabled()) { LOGGER.warn("Deserialize failed. Error:" + e.getMessage(), e); } } return defaultValue; } public static TBase deserialize(byte[] objectData, HeaderTBaseDeserializer deserializer, TBase defaultValue) { try { return deserialize(objectData, deserializer); } catch (Exception e) { if (LOGGER.isWarnEnabled()) { LOGGER.warn("Deserialize failed. Error:" + e.getMessage(), e); } } return defaultValue; } private static void assertNotNull(Object object, String message) { if (object == null) { throw new NullPointerException(message); } } }