All Downloads are FREE. Search and download functionalities are using the official Maven repository.
Please wait. This can take some minutes ...
Many resources are needed to download a project. Please understand that we have to compensate our server costs. Thank you in advance.
Project price only 1 $
You can buy this project and download/modify it how often you want.
org.jboss.resteasy.specimpl.AbstractBuiltResponse Maven / Gradle / Ivy
package org.jboss.resteasy.specimpl;
import org.jboss.resteasy.core.Headers;
import org.jboss.resteasy.plugins.delegates.LocaleDelegate;
import org.jboss.resteasy.resteasy_jaxrs.i18n.Messages;
import org.jboss.resteasy.spi.HeaderValueProcessor;
import org.jboss.resteasy.spi.ResteasyProviderFactory;
import org.jboss.resteasy.util.CaseInsensitiveMap;
import org.jboss.resteasy.util.DateUtil;
import org.jboss.resteasy.util.HttpResponseCodes;
import javax.ws.rs.core.EntityTag;
import javax.ws.rs.core.GenericEntity;
import javax.ws.rs.core.GenericType;
import javax.ws.rs.core.HttpHeaders;
import javax.ws.rs.core.Link;
import javax.ws.rs.core.MediaType;
import javax.ws.rs.core.MultivaluedMap;
import javax.ws.rs.core.NewCookie;
import javax.ws.rs.core.Response;
import java.io.FilterInputStream;
import java.io.IOException;
import java.io.InputStream;
import java.lang.annotation.Annotation;
import java.lang.reflect.Type;
import java.net.URI;
import java.util.ArrayList;
import java.util.Date;
import java.util.HashMap;
import java.util.HashSet;
import java.util.List;
import java.util.Locale;
import java.util.Map;
import java.util.Set;
/**
* A response object not attached to a client or server invocation.
*
* @author Bill Burke
* @version $Revision: 1 $
*/
@SuppressWarnings("rawtypes")
public abstract class AbstractBuiltResponse extends Response
{
protected Object entity;
protected int status = HttpResponseCodes.SC_OK;
protected String reason = "Unknown Code";
protected Headers metadata = new Headers();
protected Annotation[] annotations;
protected Class entityClass;
protected Type genericType;
protected HeaderValueProcessor processor;
protected volatile boolean isClosed;
protected InputStream is;
protected byte[] bufferedEntity;
protected volatile boolean streamRead;
protected volatile boolean streamFullyRead;
public AbstractBuiltResponse()
{
}
public AbstractBuiltResponse(final int status, final String reason,
final Headers metadata, final Object entity,
final Annotation[] entityAnnotations)
{
setEntity(entity);
this.status = status;
this.metadata = metadata;
this.annotations = entityAnnotations;
if (reason != null) {
this.reason = reason;
}
}
protected abstract InputStream getInputStream();
protected abstract void setInputStream(InputStream is);
protected abstract InputStream getEntityStream();
/**
* Release underlying connection but do not close.
*
* @throws IOException if I/O error occurred
*/
public abstract void releaseConnection() throws IOException;
/**
* Release underlying connection but do not close.
*
* @param consumeInputStream boolean to indicate either the underlying input stream must be fully read before releasing the connection or not.
*
* For most HTTP connection implementations, consuming the underlying input stream before releasing the connection will help to ensure connection reusability with respect of Keep-Alive policy.
*
* @throws IOException if I/O error occured
*/
public abstract void releaseConnection(boolean consumeInputStream) throws IOException;
public Class getEntityClass()
{
return entityClass;
}
public void setEntityClass(Class entityClass)
{
this.entityClass = entityClass;
}
protected HeaderValueProcessor getHeaderValueProcessor()
{
if (processor != null) return processor;
return ResteasyProviderFactory.getInstance();
}
@Override
public Object getEntity()
{
abortIfClosed();
return entity;
}
@Override
public int getStatus()
{
return status;
}
public String getReasonPhrase()
{
return reason;
}
@Override
public StatusType getStatusInfo()
{
StatusType statusType = Status.fromStatusCode(status);
if (statusType == null)
{
statusType = new StatusType()
{
@Override
public int getStatusCode()
{
return status;
}
@Override
public Status.Family getFamily()
{
return Status.Family.familyOf(status);
}
@Override
public String getReasonPhrase()
{
return reason;
}
};
}
return statusType;
}
@Override
public MultivaluedMap getMetadata()
{
return metadata;
}
public void setEntity(Object entity)
{
if (entity == null)
{
this.entity = null;
this.genericType = null;
this.entityClass = null;
}
else if (entity instanceof GenericEntity)
{
GenericEntity ge = (GenericEntity) entity;
this.entity = ge.getEntity();
this.genericType = ge.getType();
this.entityClass = ge.getRawType();
}
else
{
this.entity = entity;
this.entityClass = entity.getClass();
this.genericType = null;
}
}
public void setStatus(int status)
{
this.status = status;
}
public void setReasonPhrase(String reason)
{
this.reason = reason;
}
public void setMetadata(MultivaluedMap metadata)
{
this.metadata = new Headers();
this.metadata.putAll(metadata);
}
public Annotation[] getAnnotations()
{
return annotations;
}
public void addMethodAnnotations(Annotation[] methodAnnotations)
{
List ann = new ArrayList();
if (annotations != null)
{
for (Annotation annotation : annotations)
{
ann.add(annotation);
}
}
for (Annotation annotation : methodAnnotations)
{
ann.add(annotation);
}
annotations = ann.toArray(new Annotation[ann.size()]);
}
public void setAnnotations(Annotation[] annotations)
{
this.annotations = annotations;
}
public Type getGenericType()
{
return genericType;
}
public void setGenericType(Type genericType)
{
this.genericType = genericType;
}
@Override
public T readEntity(Class type, Annotation[] annotations)
{
return readEntity(type, null, annotations);
}
@SuppressWarnings(value = "unchecked")
@Override
public T readEntity(GenericType entityType, Annotation[] annotations)
{
return readEntity((Class) entityType.getRawType(), entityType.getType(), annotations);
}
@Override
public T readEntity(Class type)
{
return readEntity(type, null, null);
}
@SuppressWarnings(value = "unchecked")
@Override
public T readEntity(GenericType entityType)
{
return readEntity((Class) entityType.getRawType(), entityType.getType(), null);
}
public abstract T readEntity(Class type, Type genericType, Annotation[] anns);
protected void resetEntity()
{
entity = null;
bufferedEntity = null;
streamFullyRead = false;
streamRead = false;
}
public void setStreamRead(Boolean b)
{
streamRead = b;
}
public void setStreamFullyRead(Boolean b)
{
streamFullyRead = b;
}
@Override
public boolean hasEntity()
{
abortIfClosed();
return entity != null;
}
public boolean isClosed()
{
return isClosed;
}
public void abortIfClosed()
{
if (bufferedEntity == null) {
if (isClosed()) throw new IllegalStateException(Messages.MESSAGES.responseIsClosed());
}
}
@Override
public void close()
{
isClosed = true;
}
@Override
public Locale getLanguage()
{
Object obj = metadata.getFirst(HttpHeaders.CONTENT_LANGUAGE);
if (obj == null) return null;
if (obj instanceof Locale) return (Locale) obj;
return new LocaleDelegate().fromString(toHeaderString(obj));
}
@Override
public int getLength()
{
Object obj = metadata.getFirst(HttpHeaders.CONTENT_LENGTH);
if (obj == null) return -1;
if (obj instanceof Integer) return (Integer) obj;
return Integer.valueOf(toHeaderString(obj));
}
@Override
public MediaType getMediaType()
{
Object obj = metadata.getFirst(HttpHeaders.CONTENT_TYPE);
if (obj instanceof MediaType) return (MediaType) obj;
if (obj == null) return null;
return MediaType.valueOf(toHeaderString(obj));
}
@Override
public Map getCookies()
{
Map cookies = new HashMap();
List list = metadata.get(HttpHeaders.SET_COOKIE);
if (list == null) return cookies;
for (Object obj : list)
{
if (obj instanceof NewCookie)
{
NewCookie cookie = (NewCookie)obj;
cookies.put(cookie.getName(), cookie);
}
else
{
String str = toHeaderString(obj);
NewCookie cookie = NewCookie.valueOf(str);
cookies.put(cookie.getName(), cookie);
}
}
return cookies;
}
@Override
public EntityTag getEntityTag()
{
Object d = metadata.getFirst(HttpHeaders.ETAG);
if (d == null) return null;
if (d instanceof EntityTag) return (EntityTag) d;
return EntityTag.valueOf(toHeaderString(d));
}
@Override
public Date getDate()
{
Object d = metadata.getFirst(HttpHeaders.DATE);
if (d == null) return null;
if (d instanceof Date) return (Date) d;
return DateUtil.parseDate(d.toString());
}
@Override
public Date getLastModified()
{
Object d = metadata.getFirst(HttpHeaders.LAST_MODIFIED);
if (d == null) return null;
if (d instanceof Date) return (Date) d;
return DateUtil.parseDate(d.toString());
}
@Override
public Set getAllowedMethods()
{
Set allowedMethods = new HashSet();
List allowed = metadata.get("Allow");
if (allowed == null) return allowedMethods;
for (Object header : allowed)
{
if (header != null && header instanceof String)
{
String[] list = ((String)header).split(",");
for (String str : list)
{
if (!"".equals(str.trim()))
{
allowedMethods.add(str.trim().toUpperCase());
}
}
}
else
{
allowedMethods.add(toHeaderString(header).toUpperCase());
}
}
return allowedMethods;
}
protected String toHeaderString(Object header)
{
if (header instanceof String) return (String)header;
return getHeaderValueProcessor().toHeaderString(header);
}
@Override
public MultivaluedMap getStringHeaders()
{
CaseInsensitiveMap map = new CaseInsensitiveMap();
for (Map.Entry> entry : metadata.entrySet())
{
for (Object obj : entry.getValue())
{
map.add(entry.getKey(), toHeaderString(obj));
}
}
return map;
}
@Override
public String getHeaderString(String name)
{
List vals = metadata.get(name);
if (vals == null) return null;
StringBuilder builder = new StringBuilder();
boolean first = true;
for (Object val : vals)
{
if (first) first = false;
else builder.append(",");
if (val == null) val = "";
val = toHeaderString(val);
if (val == null) val = "";
builder.append(val);
}
return builder.toString();
}
@Override
public URI getLocation()
{
Object uri = metadata.getFirst(HttpHeaders.LOCATION);
if (uri == null) return null;
if (uri instanceof URI) return (URI)uri;
String str = null;
if (uri instanceof String) str = (String)uri;
else str = toHeaderString(uri);
return URI.create(str);
}
@Override
public Set getLinks()
{
LinkHeaders linkHeaders = getLinkHeaders();
Set links = new HashSet ();
links.addAll(linkHeaders.getLinks());
return links;
}
private LinkHeaders getLinkHeaders()
{
LinkHeaders linkHeaders = new LinkHeaders();
linkHeaders.addLinkObjects(metadata, getHeaderValueProcessor());
return linkHeaders;
}
@Override
public boolean hasLink(String relation)
{
return getLinkHeaders().getLinkByRelationship(relation) != null;
}
@Override
public Link getLink(String relation)
{
return getLinkHeaders().getLinkByRelationship(relation);
}
@Override
public Link.Builder getLinkBuilder(String relation)
{
Link link = getLinkHeaders().getLinkByRelationship(relation);
if (link == null) return null;
return Link.fromLink(link);
}
private final class LinkHeaders
{
private Map linksByRelationship = new HashMap();
private List links = new ArrayList ();
public LinkHeaders addLinkObjects(MultivaluedMap headers, HeaderValueProcessor factory)
{
List values = headers.get("Link");
if (values == null) return this;
for (Object val : values)
{
if (val instanceof Link) addLink((Link)val);
else
{
String str = factory.toHeaderString(val);
addLink(Link.valueOf(str));
}
}
return this;
}
public LinkHeaders addLink(final Link link)
{
links.add(link);
for (String rel : link.getRels())
{
linksByRelationship.put(rel, link);
}
return this;
}
public Link getLinkByRelationship(String rel)
{
return linksByRelationship.get(rel);
}
/**
* All the links defined.
*
* @return links
*/
public List getLinks()
{
return links;
}
}
protected static class InputStreamWrapper
extends FilterInputStream
{
private T response;
public InputStreamWrapper(final InputStream in, final T response) {
super(in);
this.response = response;
}
public int read() throws IOException
{
return checkEOF(super.read());
}
public int read(byte[] b) throws IOException
{
return checkEOF(super.read(b));
}
public int read(byte[] b, int off, int len) throws IOException
{
return checkEOF(super.read(b, off, len));
}
private int checkEOF(int v)
{
this.response.setStreamRead(true);
if (v < 0)
{
this.response.setStreamFullyRead(true);
}
return v;
}
@Override
public void close() throws IOException {
super.close();
this.response.close();
}
}
}