/**
* Abiquo community edition
* cloud management application for hybrid clouds
* Copyright (C) 2008-2010 - Abiquo Holdings S.L.
*
* This application is free software; you can redistribute it and/or
* modify it under the terms of the GNU LESSER GENERAL PUBLIC
* LICENSE as published by the Free Software Foundation under
* version 3 of the License
*
* This software 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 v.3 for more details.
*
* You should have received a copy of the GNU Lesser General Public
* License along with this library; if not, write to the
* Free Software Foundation, Inc., 59 Temple Place - Suite 330,
* Boston, MA 02111-1307, USA.
*/
package com.abiquo.api.exceptions.mapper;
import java.net.SocketTimeoutException;
import javax.ws.rs.core.Response;
import javax.ws.rs.core.Response.ResponseBuilder;
import javax.ws.rs.core.Response.Status;
import javax.ws.rs.ext.ExceptionMapper;
import javax.ws.rs.ext.Provider;
import org.apache.wink.common.internal.ResponseImpl.ResponseBuilderImpl;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import com.abiquo.api.exceptions.APIError;
import com.abiquo.model.transport.error.ErrorDto;
import com.abiquo.model.transport.error.ErrorsDto;
@Provider
public class SocketTimeoutExceptionMapper implements ExceptionMapper<SocketTimeoutException>
{
private static final Logger LOGGER = LoggerFactory
.getLogger(SocketTimeoutExceptionMapper.class);
@Override
public Response toResponse(final SocketTimeoutException exception)
{
return buildErrorResponse(Status.INTERNAL_SERVER_ERROR, APIError.INTERNAL_SERVER_ERROR);
}
private Response buildErrorResponse(final Status status, final APIError error)
{
ErrorsDto errorsDto = new ErrorsDto();
ErrorDto errorDto = new ErrorDto();
ResponseBuilder builder = new ResponseBuilderImpl();
errorDto.setCode(error.getCode());
errorDto.setMessage(error.getMessage());
errorsDto.getCollection().add(errorDto);
builder.status(status);
builder.entity(errorsDto);
builder.type(ErrorsDto.MEDIA_TYPE);
LOGGER.debug("SocketTimeoutException: " + errorDto.toString());
LOGGER.info("Connection with API closed, caused by SocketTimeout");
return builder.build();
}
}