/* * Sistema de Ouvidoria: um canal através do qual os usuários * podem encaminhar suas reclamações, elogios e sugestões. * * Copyright (C) 2011 SERPRO * * Este programa é software livre; você pode redistribuí-lo e/ou * modificá-lo sob os termos da Licença Pública Geral GNU, conforme * publicada pela Free Software Foundation; tanto a versão 2 da * Licença como (a seu critério) qualquer versão mais nova. * * Este programa é distribuído na expectativa de ser útil, mas SEM * QUALQUER GARANTIA; sem mesmo a garantia implícita de * COMERCIALIZAÇÃO ou de ADEQUAÇÃO A QUALQUER PROPÓSITO EM * PARTICULAR. Consulte a Licença Pública Geral GNU para obter mais * detalhes. * * Você deve ter recebido uma cópia da Licença Pública Geral GNU, * sob o título "LICENCA.txt", junto com esse programa. Se não, * acesse o Portal do Software Público Brasileiro no endereço * http://www.softwarepublico.gov.br/ ou escreva para a Fundação do * Software Livre (FSF) Inc., 51 Franklin St, Fifth Floor, Boston, * MA 02111-1301, USA. * * Contatos através do seguinte endereço internet: * http://www.serpro.gov.br/sistemaouvidoria/ */ package br.gov.serpro.ouvidoria.struts; import java.text.SimpleDateFormat; import java.util.ArrayList; import java.util.Date; import java.util.List; import javax.servlet.ServletException; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import org.apache.struts.action.ActionForm; import org.apache.struts.action.ActionForward; import org.apache.struts.action.ActionMapping; import org.apache.struts.action.ExceptionHandler; import org.apache.struts.config.ExceptionConfig; import org.apache.commons.logging.Log; import org.apache.commons.logging.LogFactory; /** * Objetivo: Extender as funcionalidades básicas de um Action * * @author SERPRO * @version $Revision: 1.1.2.3 $, $Date: 2011/10/20 15:30:34 $ * @version 0.1, Date: 11/11/2004 */ public class CustomExceptionHandler extends ExceptionHandler { /** Logger for this class and subclasses */ protected final Log logger = LogFactory.getLog(getClass()); public ActionForward execute(Exception exception, ExceptionConfig exceptionConfig, ActionMapping mapping, ActionForm form, HttpServletRequest request, HttpServletResponse response) throws ServletException { try { List errors = new ArrayList(); String ne = String.valueOf(System.currentTimeMillis()); String dt = new SimpleDateFormat("dd/MM/yyyy HH:mm:ss") .format(new Date(System.currentTimeMillis())); String id = "[" + dt + " ERRO-" + ne.substring(9) + "] "; if (exception.getCause() != null) { exception.getCause().printStackTrace(System.out); } logger.error(id, exception); errors .add(id + " Ocorreu um erro inesperado, por favor entre em contato com o suporte."); request.setAttribute("exception", errors); return (mapping.findForward("exception")); } catch (Exception e) { this.logException(e); throw new ServletException(e); } } }