All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.netflix.server.context.DirectionAwareContextSerializer Maven / Gradle / Ivy

/*
 * Copyright 2014 Netflix, Inc.
 *
 * 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.netflix.server.context;

/**
 * A replacement for {@link ContextSerializer} for {@link BiDirectional} contexts that requires information about the
 * direction of flow (i.e. request or response). For legacy reasons, this class extends {@link ContextSerializer}, the
 * easier way to implement a direction aware serializer will be to extend {@link DirectionAwareSerializerAdapter} which
 * provides a default implementation of the methods in {@link ContextSerializer} 
* *

Directions

* * Directions carry different meanings when associated with serialization type. Infact its usually the opposite for * serialization and de-serialization. Following is the definition: * *

{@link Direction#Inbound}

* Serialization: Serializing for adding to the response. * De-serialization: De-serializing for reading the request. * *

{@link Direction#Outbound}

* Serialization: Serializing for adding to the request. * De-serialization: De-serializing for reading the response. * * @author Nitesh Kant */ public interface DirectionAwareContextSerializer extends ContextSerializer { /** * Directions defined by this interface. See {@link DirectionAwareContextSerializer} for definitions. */ enum Direction { // Direction when an app receives the context. Inbound, Outbound } /** * Serializes the passed object {@code toSerialize} * * @param toSerialize The object to serialize. This object will never be {@code null} * @param direction Direction of message flow. See {@link DirectionAwareContextSerializer} for definitions. * * @return The serialized string. The serialization will be deemed failed if the returned object is {@code null} * and hence the callee will throw a {@link ContextSerializationException} upon receiving a {@code null} * * @throws ContextSerializationException If the serialization failed. * * @see DirectionAwareContextSerializer */ String serialize(T toSerialize, Direction direction) throws ContextSerializationException; /** * De-serializes the passed object {@code serialized}. * * @param serialized The serialized object to de-serialize. This string will never be {@code null} * @param version The version of the serializer as returned by {@link ContextSerializer#getVersion()} used to * serialize the passed string. * @param direction Direction of message flow. See {@link DirectionAwareContextSerializer} for definitions. * * @return The de-serialized object. The de-serialization will be deemed failed if the returned object is {@code null} * and hence the callee will throw a {@link ContextSerializationException} upon receiving a {@code null} * * @throws ContextSerializationException If the de-serialization failed. * * @see DirectionAwareContextSerializer */ T deserialize(String serialized, Direction direction, int version) throws ContextSerializationException; }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy