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

javax.ws.rs.core.Response Maven / Gradle / Ivy

/*
 * The contents of this file are subject to the terms
 * of the Common Development and Distribution License
 * (the "License").  You may not use this file except
 * in compliance with the License.
 *
 * You can obtain a copy of the license at
 * http://www.opensource.org/licenses/cddl1.php
 * See the License for the specific language governing
 * permissions and limitations under the License.
 */

/*
 * Response.java
 *
 * Created on April 18, 2007, 9:00 AM
 *
 */

package javax.ws.rs.core;

import java.net.URI;
import java.util.Date;
import javax.ws.rs.ext.Contract;
import javax.ws.rs.ext.ProviderFactory;

/**
 * Defines the contract between a returned instance and the runtime when
 * an application needs to provide metadata to the runtime. An application
 * class can implement this interface directly or can use the nested Builder
 * class to create an instance.
 * 
 * @see Response.Builder
 */
public interface Response {
    
    /**
     * Return the entity for the response. The response will be serialized using an
     * EntityProvider for the class of the entity.
     * @return an object instance or null if there is no entity
     * @see javax.ws.rs.ext.EntityProvider
     */
    Object getEntity();
    
    /**
     * Get the status code associated with the response.
     * @return the response status code or -1 if the status was not set
     */
    int getStatus();

    /**
     * Write any metadata associated with the response to the supplied map. Values
     * will be serialized using a HeaderProvider for the class of the value. Multivalued
     * entries will be serialized as separate headers.
     * @param metadata a map to write the metadata to
     * @see javax.ws.rs.ext.HeaderProvider
     */
    void addMetadata(MultivaluedMap metadata);
    
    /**
     * A class used to build Response instances that contain metadata instead of or in addition
     * to an entity. Static methods are provided to obtain an initial instance,
     * instance methods provide the ability to set metadata. E.g. to create a response
     * that indicates the creation of a new resource:
     * 
@HttpMethod
     * Response addWidget(...) {
     *   Widget w = ...
     *   URI widgetId = ...
     *   return Builder.created(w, widgetId).build();
     * }
*/ @Contract public static abstract class Builder { /** * Create a new builder instance. * @return a new Builder */ protected static synchronized Builder newInstance() { Builder b = ProviderFactory.getInstance().createInstance(Builder.class); if (b==null) throw new UnsupportedOperationException("No Builder implementation found"); return b; } /** * Create a Response instance from the current Builder. The builder * is reset to a blank state equivalent to calling the ok method. * @return a Response instance */ public abstract Response build(); /** * Create a new Builder that contains a representation. * @param entity the representation entity data * @return a new Builder */ public static Builder representation(Object entity) { Builder b = newInstance(); b.status(200).entity(entity); return b; } /** * Create a new Builder that contains a representation. * @param entity the representation entity data * @param type the media type of the entity * @return a new Builder */ public static Builder representation(Object entity, MediaType type) { Builder b = representation(entity); b.type(type); return b; } /** * Create a new Builder that contains a representation. * @param entity the representation entity data * @param type the media type of the entity * @return a new Builder */ public static Builder representation(Object entity, String type) { Builder b = representation(entity); b.type(type); return b; } /** * Create a new Builder with an OK status. * @return a new Builder */ public static Builder ok() { Builder b = newInstance(); b.status(200); return b; } /** * Create a new Builder with an OK status. * @param entity the representation entity data * @return a new Builder */ public static Builder ok(Object entity) { Builder b = ok(); b.entity(entity); return b; } /** * Create a new Builder with an server error status. * @return a new Builder */ public static Builder serverError() { Builder b = newInstance(); b.status(500); return b; } /** * Create a new Builder for a created resource. * @param entity the representation of the new resource * @param location the URI of the new resource * @return a new Builder */ public static Builder created(Object entity, URI location) { Builder b = created(location); b.entity(entity); return b; } /** * Create a new Builder for a created resource. * @param location the URI of the new resource * @return a new Builder */ public static Builder created(URI location) { Builder b = newInstance(); b.status(201).location(location); return b; } /** * Create a new Builder for an empty response. * @return a new Builder */ public static Builder noContent() { Builder b = newInstance(); b.status(204); return b; } /** * Create a new Builder with a not-modified status. * @return a new Builder */ public static Builder notModified() { Builder b = newInstance(); b.status(304); return b; } /** * Create a new Builder with a not-modified status. * @param tag a tag for the unmodified entity * @return a new Builder */ public static Builder notModified(EntityTag tag) { Builder b = notModified(); b.tag(tag); return b; } /** * Create a new Builder with a not-modified status. * @param tag a tag for the unmodified entity * @return a new Builder */ public static Builder notModified(String tag) { Builder b = notModified(); b.tag(tag); return b; } /** * Create a new Builder for a temporary redirection. * @param location the redirection URI * @return a new Builder */ public static Builder temporaryRedirect(URI location) { Builder b = newInstance(); b.status(307).location(location); return b; } /** * Set the status on the Builder. * @param status the response status * @return the updated Builder */ public abstract Builder status(int status); /** * Set the entity on the Builder. * * @return the updated Builder * @param entity the response entity */ public abstract Builder entity(Object entity); /** * Set the type on the Builder. * * @return the updated Builder * @param type the media type of the response entity */ public abstract Builder type(MediaType type); /** * Set the type on the Builder. * * @return the updated Builder * @param type the media type of the response entity */ public abstract Builder type(String type); /** * Set the language on the Builder. * * @return the updated Builder * @param language the language of the response entity */ public abstract Builder language(String language); /** * Set the location on the Builder. * * @return the updated Builder * @param location the location */ public abstract Builder location(URI location); /** * Set the content location on the Builder. * * @return the updated Builder * @param location the content location */ public abstract Builder contentLocation(URI location); /** * Set the entity tag on the Builder. * * @return the updated Builder * @param tag the entity tag */ public abstract Builder tag(EntityTag tag); /** * Set the entity tag on the Builder. * * @return the updated Builder * @param tag the entity tag */ public abstract Builder tag(String tag); /** * Set the last modified date on the Builder. * * @return the updated Builder * @param lastModified the last modified date */ public abstract Builder lastModified(Date lastModified); /** * Set the cache control data on the Builder. * * @return the updated Builder * @param cacheControl the cache control directives */ public abstract Builder cacheControl(CacheControl cacheControl); /** * Set the value of a specific header on the Builder. * @param name the name of the header * @param value the value of the header, the header will be serialized * using a HeaderProvider for the class of the value * @see javax.ws.rs.ext.HeaderProvider * @return the updated Builder */ public abstract Builder header(String name, Object value); /** * Set a new cookie on the Builder. * * @return the updated Builder * @param cookie the new cookie that will accompany the response. */ public abstract Builder cookie(NewCookie cookie); } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy