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.Consumes; import javax.ws.rs.WebApplicationException; import javax.ws.rs.core.MediaType; import javax.ws.rs.core.MultivaluedMap; import javax.ws.rs.ext.MessageBodyReader; import javax.ws.rs.ext.Provider; import java.io.IOException; import java.io.InputStream; import java.lang.annotation.Annotation; import java.lang.reflect.Type; @Provider @Consumes(Constants.MEDIA_TYPE_TEST_XML) @Interceptors({InterceptorOne.class}) @InterceptorClassBinding public class InterceptorBookReader implements MessageBodyReader<InterceptorBook> { private static Logger logger = Logger.getLogger(InterceptorBookReader.class); private static MessageBodyReader<InterceptorBook> delegate; static { logger.info("In InterceptorBookReader static {}"); ResteasyProviderFactory factory = ResteasyProviderFactory.getInstance(); delegate = factory.getMessageBodyReader(InterceptorBook.class, null, null, Constants.MEDIA_TYPE_TEST_XML_TYPE); logger.info("In InterceptorBookReader static {}"); } public boolean isReadable(Class<?> type, Type genericType, Annotation[] annotations, MediaType mediaType) { logger.info("entering InterceptorBookReader.isReadable()"); boolean b = InterceptorBook.class.equals(type); logger.info("leaving InterceptorBookReader.isReadable()"); return b; } @Interceptors({InterceptorTwo.class}) @InterceptorMethodBinding public InterceptorBook readFrom(Class<InterceptorBook> type, Type genericType, Annotation[] annotations, MediaType mediaType, MultivaluedMap<String, String> httpHeaders, InputStream entityStream) throws IOException, WebApplicationException { logger.info("entering InterceptorBookReader.readFrom()"); InterceptorBook book = InterceptorBook.class.cast(delegate.readFrom(InterceptorBook.class, genericType, annotations, mediaType, httpHeaders, entityStream)); logger.info("InterceptorBookReader.readFrom() read " + book); logger.info("leaving InterceptorBookReader.readFrom()"); return book; } }