001/* 002 * (C) Copyright 2015 Nuxeo SA (http://nuxeo.com/) and others. 003 * 004 * Licensed under the Apache License, Version 2.0 (the "License"); 005 * you may not use this file except in compliance with the License. 006 * You may obtain a copy of the License at 007 * 008 * http://www.apache.org/licenses/LICENSE-2.0 009 * 010 * Unless required by applicable law or agreed to in writing, software 011 * distributed under the License is distributed on an "AS IS" BASIS, 012 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 013 * See the License for the specific language governing permissions and 014 * limitations under the License. 015 * 016 * Contributors: 017 * Nicolas Chapurlat <nchapurlat@nuxeo.com> 018 */ 019 020package org.nuxeo.ecm.core.io.registry; 021 022import java.io.IOException; 023import java.io.InputStream; 024import java.lang.reflect.Type; 025 026import javax.ws.rs.core.MediaType; 027 028/** 029 * Interface of mimetype to Java type converter. 030 * <p> 031 * see {@link Marshaller} for more details. 032 * </p> 033 * 034 * @param <EntityType> The managed Java type. 035 * @since 7.2 036 */ 037public interface Reader<EntityType> extends Marshaller<EntityType> { 038 039 /** 040 * Read the entity from in {@link InputStream} using mediatype format. 041 * <p> 042 * This method implementation can use injected properties. 043 * </p> 044 * 045 * @param clazz The requested marshalled class. 046 * @param genericType The requested marshalled generic type. 047 * @param mediatype The input mediatype. 048 * @param in The input of this marshaller. 049 * @throws IOException If some error append while reading entity from in. 050 * @since 7.2 051 */ 052 EntityType read(Class<?> clazz, Type genericType, MediaType mediaType, InputStream in) throws IOException; 053 054}