package org.jboss.resteasy.test.cdi.basic.resource; import org.jboss.logging.Logger; import org.jboss.resteasy.spi.ResteasyProviderFactory; import org.jboss.resteasy.test.cdi.util.Constants; import javax.enterprise.event.Event; import javax.enterprise.event.Observes; import javax.inject.Inject; 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; import java.util.ArrayList; @Provider @Consumes(Constants.MEDIA_TYPE_TEST_XML) public class EventsBookReader implements MessageBodyReader<EJBBook> { private static Logger log = Logger.getLogger(EventsBookReader.class); private static MessageBodyReader<EJBBook> delegate; @Inject @EventsRead(context = "reader") Event<String> readEvent; private ArrayList<Object> eventList = new ArrayList<Object>(); static { log.info("In BookReader static {}"); ResteasyProviderFactory factory = ResteasyProviderFactory.getInstance(); delegate = factory.getMessageBodyReader(EJBBook.class, null, null, Constants.MEDIA_TYPE_TEST_XML_TYPE); log.info("In BookReader static {}"); } public boolean isReadable(Class<?> type, Type genericType, Annotation[] annotations, MediaType mediaType) { log.info("entering BookReader.isReadable()"); boolean b = EJBBook.class.equals(type); log.info("leaving BookReader.isReadable()"); return b; } public EJBBook readFrom(Class<EJBBook> type, Type genericType, Annotation[] annotations, MediaType mediaType, MultivaluedMap<String, String> httpHeaders, InputStream entityStream) throws IOException, WebApplicationException { log.info("entering BookReader.readFrom()"); EJBBook book = EJBBook.class.cast(delegate.readFrom(EJBBook.class, genericType, annotations, mediaType, httpHeaders, entityStream)); log.info("BookReader firing readEvent"); readEvent.fire("readEvent"); log.info("BookReader.readFrom() read " + book); log.info("leaving BookReader.readFrom()"); return book; } public void readIntercept(@Observes @EventsReadIntercept String event) { eventList.add(event); log.info("BookReader.readIntercept() got " + event); } public void read(@Observes @EventsRead(context = "reader") String event) { eventList.add(event); log.info("BookReader.read() got " + event); } public void writeIntercept(@Observes @EventsWriteIntercept String event) { eventList.add(event); log.info("BookReader.writeIntercept() got " + event); } public void write(@Observes @EventsWrite(context = "writer") String event) { eventList.add(event); log.info("BookReader.write() got " + event); } public void process(@Observes @EventsProcess String event) { eventList.add(event); log.info("BookReader.process() got " + event); } public void processRead(@Observes @EventsProcess @EventsRead(context = "resource") String event) { eventList.add(event); log.info("BookReader.processRead() got " + event); } public void processWrite(@Observes @EventsProcess @EventsWrite(context = "resource") String event) { eventList.add(event); log.info("BookReader.processWrite() got " + event); } public void unused(@Observes @EventsRead(context = "unused") @EventsWrite(context = "unused") EventsUnused event) { eventList.add(event); log.info("BookReader.unused() got " + event); throw new RuntimeException("BookReader.unused() got " + event); } public ArrayList<Object> getEventList() { return new ArrayList<Object>(eventList); } }