/* * (C) Copyright 2006-2008 Nuxeo SAS (http://nuxeo.com/) and contributors. * * All rights reserved. This program and the accompanying materials * are made available under the terms of the GNU Lesser General Public License * (LGPL) version 2.1 which accompanies this distribution, and is available at * http://www.gnu.org/licenses/lgpl.html * * This library is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU * Lesser General Public License for more details. * * Contributors: * bstefanescu * * $Id$ */ package org.nuxeo.ecm.webengine.model.io; import java.io.File; import java.io.FileInputStream; import java.io.IOException; import java.io.OutputStream; import java.lang.annotation.Annotation; import java.lang.reflect.Type; import javax.ws.rs.Produces; 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 org.apache.commons.logging.Log; import org.apache.commons.logging.LogFactory; import org.nuxeo.common.utils.FileUtils; import org.nuxeo.ecm.platform.web.common.exceptionhandling.ExceptionHelper; import org.nuxeo.ecm.webengine.WebException; /** * text/plain is needed otherwise resteasy will use its default text plain * (@see DefaultTextPlain) writer to write text/plain objects and the file is * not written correctly. * * @author <a href="mailto:bs@nuxeo.com">Bogdan Stefanescu</a> */ @Provider @Produces( { "*/*", "text/plain" }) public class FileWriter implements MessageBodyWriter<File> { private static final Log log = LogFactory.getLog(FileWriter.class); public void writeTo(File t, Class<?> type, Type genericType, Annotation[] annotations, MediaType mediaType, MultivaluedMap<String, Object> httpHeaders, OutputStream entityStream) throws IOException { FileInputStream in = null; try { in = new FileInputStream(t); FileUtils.copy(in, entityStream); entityStream.flush(); } catch (Throwable e) { Throwable unwrappedError = ExceptionHelper.unwrapException(e); if (ExceptionHelper.isClientAbortError(unwrappedError)) { // ignore but log as warn log.warn(unwrappedError.getMessage()); } else if (unwrappedError instanceof IOException) { // can be a broken pipe => do not display the whole stack trace log.error(unwrappedError.getMessage()); } else { throw WebException.wrap("Failed to render resource", e); } } finally { if (in != null) { in.close(); } } } public long getSize(File arg0, Class<?> arg1, Type arg2, Annotation[] arg3, MediaType arg4) { long n = arg0.length(); return n <= 0 ? -1 : n; } public boolean isWriteable(Class<?> arg0, Type type, Annotation[] arg2, MediaType arg3) { return File.class.isAssignableFrom(arg0); } }