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

ch.mimo.netty.handler.codec.icap.IcapMessage Maven / Gradle / Ivy

/*******************************************************************************
 * Copyright (c) 2011 Michael Mimo Moratti.
 *
 * Michael Mimo Moratti licenses this file to you 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 ch.mimo.netty.handler.codec.icap;

import java.util.List;
import java.util.Map;
import java.util.Set;

import org.jboss.netty.handler.codec.http.HttpRequest;
import org.jboss.netty.handler.codec.http.HttpResponse;

/**
 * An ICAP message that contains common operations for @see {@link IcapRequest} and @see {@link IcapResponse}.
 * 
 * @author Michael Mimo Moratti ([email protected])
 *
 */
public interface IcapMessage {

    /**
     * Returns the header value with the specified header name.  If there are
     * more than one header value for the specified header name, the first
     * value is returned.
     *
     * @return the header value or {@code null} if there is no such header
     *
     */
    String getHeader(String name);

    /**
     * Returns the header values with the specified header name.
     *
     * @return the {@link List} of header values.  An empty list if there is no
     *         such header.
     */
    Set getHeaders(String name);

    /**
     * Returns the all header names and values that this message contains.
     *
     * @return the {@link List} of the header name-value pairs.  An empty list
     *         if there is no header in this message.
     */
    Set> getHeaders();

    /**
     * @param name header name
     * @return {@code true} if and only if there is a header with the specified
     * header name.
     */
    boolean containsHeader(String name);

    /**
     * @return {@link Set} of all header names that this message contains.
     */
    Set getHeaderNames();
    
    /**
     * Adds a new header with the specified name and value.
     * @param name header name
     * @param value for the given name
     * @return self in order to chain the method calls
     */
    IcapMessage addHeader(String name, Object value);

    /**
     * Sets a new header with the specified name and value.  If there is an
     * existing header with the same name, the existing header is removed.
     * @param name header name
     * @param value for the given name
     * @return self in order to chain the method calls
     */
    IcapMessage setHeader(String name, Object value);

    /**
     * Sets a new header with the specified name and values.  If there is an
     * existing header with the same name, the existing header is removed.
     * @param name header name
     * @param values for the given name
     * @return self in order to chain the method calls
     */
    IcapMessage setHeader(String name, Iterable values);

    /**
     * Removes the header with the specified name.
     * @return self in order to chain the method calls
     */
    IcapMessage removeHeader(String name);
    
    /**
     * @return the @see {@link Integer} preview header value.
     */
    int getPreviewAmount();

    /**
     * Removes all headers from this message.
     * @return self in order to chain the method calls
     */
    IcapMessage clearHeaders();
    
    /**
     * @return the protocol version of this message.
     */
    IcapVersion getProtocolVersion();

    /**
     * Sets the protocol version of this message.
     * @param version @see {@link IcapVersion}
     * @return self in order to chain the method calls
     */
    IcapMessage setProtocolVersion(IcapVersion version);
    
    /**
     * @return whether this message is a preview of the actual message.
     */
    boolean isPreviewMessage();
	
    /**
     * @return true if a http request was delivered.
     */
    boolean containsHttpRequest();
    
    /**
     * @return the actual http request instance @see {@link HttpRequest}
     */
	HttpRequest getHttpRequest();
	
	/**
	 * @param httpRequest
	 * @return self in order to chain the method calls
	 */
	IcapMessage setHttpRequest(HttpRequest httpRequest);
	
	/**
	 * @return true if a http response was delivered.
	 */
	boolean containsHttpResponse();
	
	/**
	 * @return the actual http response instance @see {@link HttpResponse}
	 */
	HttpResponse getHttpResponse();
	
	/**
	 * Adds a @see {@link HttpResponse} to the Icap message.
	 * 
	 * @param response the @see {@link HttpResponse}
	 * @return self in order to chain the method calls
	 */
	IcapMessage setHttpResponse(HttpResponse response);
	
	/**
	 * Sets the @see {@link Encapsulated} Encapsulation header for this message
	 * @param encapsulated @see {@link Encapsulated} instance
	 * @return self in order to chain the method calls
	 */
	IcapMessage setEncapsulatedHeader(Encapsulated encapsulated);
	
	/**
	 * @return @see {@link Encapsulated} Encapsulated header value
	 */
	Encapsulated getEncapsulatedHeader();

	/**
	 * Sets the indication that this icap message contains a body of some kind.
	 * @param body @see {@link IcapMessageElementEnum}
	 * @return self in order to chain the method calls
	 */
	IcapMessage setBody(IcapMessageElementEnum body);

	/**
	 * @return @see {@link IcapMessageElementEnum} message body indicator.
	 */
	IcapMessageElementEnum getBodyType();
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy