package com.fp.viaticos.mail; import java.util.ArrayList; import java.util.HashMap; import java.util.List; import java.util.Map; import javax.persistence.NoResultException; import javax.persistence.Query; import com.fp.persistence.commondb.PersistenceHelper; import com.fp.persistence.pviaticos.hra.Empleado; import com.fp.persistence.pviaticos.hra.EmpleadoJpql; import com.fp.persistence.pviaticos.param.ViaCiudadUsuario; import com.fp.persistence.pviaticos.solicitud.ViaSolicitud; import com.fp.persistence.pviaticos.solicitud.ViaSolicitudKey; import com.fp.simple.maia.MailRecipient; import com.fp.viaticos.rules.exception.ViaticosException; /** * Clase que se encarga de objener el email de un usuario asociado a talento humano. * * @version 2.1 */ public class TalentoHumano extends MailRecipient { /* * (non-Javadoc) * * @see com.fp.simple.maia.MailRecipient#getEmailAddress(java.lang.Object) */ @SuppressWarnings("unchecked") @Override public Map getEmailAddress(Object pParam) throws Exception { List lemail = new ArrayList(); Map mresp = new HashMap(); HashMap m = (HashMap) pParam; Map mrequest = (Map) m.get("request"); if (mrequest.get("csolicitud") == null) { return mresp; } String solicitud = (String) mrequest.get("csolicitud"); ViaSolicitud vsol = ViaSolicitud.find(PersistenceHelper.getEntityManager(), new ViaSolicitudKey(solicitud, "S")); EmpleadoJpql ejpql = new EmpleadoJpql(); Empleado e = ejpql.find(vsol.getCod_empleado()); String usuario = this.getUsuario(e.getCodigoLocalidad(), "TALENTOHUMANO"); // adiciona email del empleado. lemail.add(ejpql.findPorUsuarioWeb(usuario.toLowerCase()).getEmail()); mresp.put("lemail", lemail); return mresp; } /** * Busca en la tabla ViaCiudadUsuario, el codigo de usuario asociado a una localidad a la que pertence un * funcionario de la SBS. * * @param ciudad Codigo de ciudad a obtener el usuario. * @return String * @throws Exception */ private String getUsuario(String ciudad, String actividad) throws Exception { Query qry = PersistenceHelper.getEntityManager().createQuery( "from ViaCiudadUsuario t where t.pk.cod_actividad_catalog = :actividad and t.pk.cod_ciudad_catalog = :ciudad "); qry.setParameter("ciudad", ciudad); qry.setParameter("actividad", actividad); ViaCiudadUsuario obj = null; try { obj = (ViaCiudadUsuario) qry.getSingleResult(); } catch (NoResultException e) { throw new ViaticosException("VIA-0002", "USUARIO NO DEFINIDO EN VIA_CIUDAD_USUARIO CIUDAD: {0} ACTIVIDAD: {1} ", ciudad, actividad); } return obj.getCod_usuario(); } }