package org.jboss.resteasy.test.cdi.basic.resource;
import javax.decorator.Decorator;
import javax.decorator.Delegate;
import javax.inject.Inject;
import javax.ws.rs.WebApplicationException;
import javax.ws.rs.core.MediaType;
import javax.ws.rs.core.MultivaluedMap;
import javax.ws.rs.ext.MessageBodyReader;
import java.io.IOException;
import java.io.InputStream;
import java.lang.annotation.Annotation;
import java.lang.reflect.Type;
import java.util.logging.Logger;
@Decorator
public abstract class DecoratorsBookReaderDecorator implements MessageBodyReader<EJBBook> {
@Inject
private Logger log;
@Inject
@Delegate
private MessageBodyReader<EJBBook> reader;
@Override
public EJBBook readFrom(Class<EJBBook> type, Type genericType,
Annotation[] annotations, MediaType mediaType,
MultivaluedMap<String, String> httpHeaders, InputStream entityStream)
throws IOException, WebApplicationException {
log.info("entering DecoratorsBookReaderDecorator.readFrom()");
DecoratorsVisitList.add(DecoratorsVisitList.READER_DECORATOR_ENTER);
EJBBook b = reader.readFrom(type, genericType, annotations, mediaType, httpHeaders, entityStream);
DecoratorsVisitList.add(DecoratorsVisitList.READER_DECORATOR_LEAVE);
log.info("leaving DecoratorsBookReaderDecorator.readFrom()");
return b;
}
}