/*
* 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.action;
import java.security.cert.X509Certificate;
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.ActionMessage;
import org.apache.struts.action.ActionMessages;
import br.gov.serpro.ouvidoria.controller.CertificadoDigitalCtrl;
import br.gov.serpro.ouvidoria.controller.gerencial.administracao.FuncionarioCtrl;
import br.gov.serpro.ouvidoria.model.Funcionario;
import br.gov.serpro.ouvidoria.struts.ActionSupport;
import br.gov.serpro.ouvidoria.util.Constants;
import br.gov.serpro.ouvidoria.util.Utilitario;
/**
* Objetivo: Efeturar o Login do Funcionario no Site com Certificado Digital
*
* @author SERPRO
* @version $Revision: 1.1.2.4 $, $Date: 2011/10/20 15:30:36 $
* @version 0.1, 2005/04/01
*/
public class CertificadoDigitalAction extends ActionSupport {
public ActionForward execute(ActionMapping mapping, ActionForm form,
HttpServletRequest request, HttpServletResponse response)
throws Exception {
//imprimir informações de DEBUG
if (Constants.DEBUG) {
X509Certificate[] certs = (X509Certificate[]) request
.getAttribute("javax.servlet.request.X509Certificate");
if (certs != null) {
for (int i = 0; i < certs.length; i++) {
X509Certificate cert = certs[i];
request.getSession().setAttribute(
"javax.servlet.request.X509Certificate", cert);
String nm = cert.getSubjectDN().getName();
String[] nms = nm.split(",");
for (int j = 0; j < nms.length; j++) {
System.out.println(nms[j]);
}
}
} else {
System.out.println("Certs returned NULL");
}
}
ActionMessages errors = new ActionMessages();
X509Certificate[] certs = (X509Certificate[]) request
.getAttribute("javax.servlet.request.X509Certificate");
if (certs == null) {
errors.add(ActionMessages.GLOBAL_MESSAGE, new ActionMessage(
"certificadoDigital.error"));
saveErrors(request, errors);
return mapping.findForward("error");
}
String login = CertificadoDigitalCtrl.getLogin(certs);
if (login == null || !Utilitario.validaCpf(login)) {
errors.add(ActionMessages.GLOBAL_MESSAGE, new ActionMessage(
"certificadoDigital.invalido.error"));
saveErrors(request, errors);
return mapping.findForward("error");
}
FuncionarioCtrl funcCtrl = new FuncionarioCtrl(getDaoFactory());
Funcionario funcionario = funcCtrl.getByLogin(getOrgao(request), login);
if (funcionario == null) {
errors.add(ActionMessages.GLOBAL_MESSAGE, new ActionMessage(
"certificadoDigital.recuperarFuncionario.error", "\""
+ login + "\""));
saveErrors(request, errors);
return mapping.findForward("error");
}
request.getSession(true).setAttribute(Constants.PA_FUNCIONARIO,
funcionario.getId());
geraHistorico(request);
return mapping.findForward("success");
}
}