package org.jboss.resteasy.test.cdi.interceptors.resource;
import org.jboss.logging.Logger;
import org.jboss.resteasy.spi.ResteasyProviderFactory;
import org.jboss.resteasy.test.cdi.util.Constants;
import javax.interceptor.Interceptors;
import javax.ws.rs.Produces;
import javax.ws.rs.WebApplicationException;
import javax.ws.rs.core.MediaType;
import javax.ws.rs.core.MultivaluedMap;
import javax.ws.rs.ext.MessageBodyWriter;
import javax.ws.rs.ext.Provider;
import java.io.IOException;
import java.io.OutputStream;
import java.lang.annotation.Annotation;
import java.lang.reflect.Type;
@Provider
@Produces(Constants.MEDIA_TYPE_TEST_XML)
@Interceptors({InterceptorOne.class})
@InterceptorClassBinding
public class InterceptorBookWriter implements MessageBodyWriter<InterceptorBook> {
private static Logger logger = Logger.getLogger(InterceptorBookReader.class);
private static MessageBodyWriter<InterceptorBook> delegate;
static {
logger.info("In InterceptorBookWriter static {}");
ResteasyProviderFactory factory = ResteasyProviderFactory.getInstance();
delegate = factory.getMessageBodyWriter(InterceptorBook.class, null, null, Constants.MEDIA_TYPE_TEST_XML_TYPE);
}
public boolean isWriteable(Class<?> type, Type genericType, Annotation[] annotations, MediaType mediaType) {
logger.info("entering InterceptorBookWriter.isWriteable()");
boolean b = InterceptorBook.class.equals(type);
logger.info("leaving InterceptorBookWriter.isWriteable()");
return b;
}
public long getSize(InterceptorBook t, Class<?> type, Type genericType, Annotation[] annotations, MediaType mediaType) {
logger.info("entering InterceptorBookWriter.getSize()");
logger.info("leaving InterceptorBookWriter.getSize()");
return -1;
}
@Override
@Interceptors({InterceptorTwo.class})
@InterceptorMethodBinding
public void writeTo(InterceptorBook t, Class<?> type, Type genericType,
Annotation[] annotations, MediaType mediaType,
MultivaluedMap<String, Object> httpHeaders, OutputStream entityStream)
throws IOException, WebApplicationException {
logger.info("entering InterceptorBookWriter.writeTo()");
logger.info("InterceptorBookWriter.writeTo() writing " + t);
delegate.writeTo(t, type, genericType, annotations, mediaType, httpHeaders, entityStream);
logger.info("leaving InterceptorBookWriter.writeTo()");
}
}