*
*/
public ActionForward execute(ActionMapping mapping, ActionForm form,
HttpServletRequest request, HttpServletResponse response)
throws Exception {
final Category log = Category.getInstance(ResponderMsgAction.class
.getName());
DynaActionForm _form = (DynaActionForm) form;
ActionMessages errorMsgs = new ActionMessages();
// Recupera parámetros da requisição
String lsTitulo = _form.getString("txtTitulo");
String lsResp = _form.getString("txtResposta");
String lidAcion = _form.getString("idAcionamento");
String lsAcao = _form.getString("txtAcao");
String lidRemetenteRedirec = _form.getString("idRemetenteRedirec");
String stSolucao = _form.getString("idSolucao");
Long idSolucao=null;
if (stSolucao!=null && !stSolucao.trim().equals("")){
idSolucao=(new Long(stSolucao));
}
// Responde ao acionamento
try {
AcionamentoCtrl ctrlAcion = new AcionamentoCtrl(getDaoFactory());
// Recupera o acionamento a partir do id
Acionamento acionamento = ctrlAcion.get(new Long(lidAcion));
if (acionamento == null) {
errorMsgs.add(ActionMessages.GLOBAL_MESSAGE, new ActionMessage(
"error.mensagem.notFound"));
saveMessages(request, errorMsgs);
} else if (lidRemetenteRedirec != null
&& !lidRemetenteRedirec.equals("")) {
// retorna ao ouvidor que redirecionou a msg ao especialista
// consultor
RedirecionarMensagemCtrl redirecionarMensagemCtrl = new RedirecionarMensagemCtrl(
getDaoFactory());
Funcionario ouvidor = null;
ouvidor = redirecionarMensagemCtrl.obterOuvidor(new Long(lidRemetenteRedirec));
if (ouvidor != null) {
acionamento.setFuncionario(ouvidor);
}
Timestamp hoje = new Timestamp(System.currentTimeMillis());
// Finaliza resposta ao acionamento
acionamento.finalizarRespostaConsultor(lsTitulo, lsResp, hoje, idSolucao);
redirecionarMensagemCtrl.salvarAcionamento(acionamento);
ctrlAcion.save(acionamento);
// Repassa os parámetros para a tela de mensagem de sucesso
request.setAttribute("idAcionamento", lidAcion);
request.setAttribute("txtAcao", lsAcao);
} else {
Timestamp hoje = new Timestamp(System.currentTimeMillis());
// Finaliza resposta ao acionamento
acionamento
.finalizarRespostaAcionamento(lsTitulo, lsResp, hoje, idSolucao);
// acionamento.setEstadoAcionamento(EstadoAcionamento.RESPONDIDO);
ctrlAcion.save(acionamento);
// Verifica se a opção de recebimento da resposta for email.
if (acionamento.getAcionador().getMeioEnvioRespostaOrgao()
.getMeioEnvioResposta().getId().longValue() == MeioEnvioResposta.EMAIL
.getId().longValue()) {
EnviarEmailCtrl envioEmail = new EnviarEmailCtrl(
getDaoFactory());
Orgao orgao = getOrgao(request);
String lsEnderecoUrl = "";
try {
int tamanho = request.getRequestURL().length();
lsEnderecoUrl = request.getRequestURL().substring(0,
(tamanho - 32));
log.info("endereco: " + lsEnderecoUrl);
String enc = Utilitario.encrypt(Constants.DES_KEY,
orgao.getId().toString());
Integer numProtocolo = acionamento.getNumeroProtocolo();
String codigoAcesso = "";
if (this.getOrgao(request).getConfiguracoes().getPossuiCodigoAcesso()
.booleanValue()) {
codigoAcesso = acionamento.getAcionador().getInformacoesConsultaAcionamento().getCodigoAcesso();
codigoAcesso = "&codigoAcesso="+codigoAcesso+"&osessionid=".concat(enc);
}
lsEnderecoUrl=lsEnderecoUrl+"andamento/ExibirResposta.do?action=consultar&numeroProtocolo="+numProtocolo;
lsEnderecoUrl=lsEnderecoUrl+codigoAcesso;
lsEnderecoUrl=lsEnderecoUrl+"&osessionid=".concat(enc);
log.info("endereco: " + lsEnderecoUrl);
} catch (Exception e) {
log.info("ERRO:::" + e.getMessage());
log.info("ERRO:::" + e.getCause());
log.info("ERRO:::" + e.getStackTrace());
return (mapping.findForward("failure"));
}
boolean emailOK = envioEmail.enviarEmail(acionamento,
orgao, lsEnderecoUrl);