public async Task <GetCardHolder_DTO> ObtenerPersona(string idBadge) { GetCardHolder_DTO persona = new GetCardHolder_DTO(); ManagementObjectSearcher cardHolder = new ManagementObjectSearcher(); string idPersona = await _badge_REP_LOCAL.ConsultarPersonaBadge(idBadge); if (idPersona == "NA") { throw new Exception("No hay una persona relacionada a este codigo de tarjeta"); } cardHolder = await _cardHolder_REP.GetCardHolderByID(idPersona, _path, _user, _pass); try { foreach (ManagementObject queryObj in cardHolder.Get()) { persona.id = int.Parse(queryObj["ID"].ToString()); try { persona.apellidos = queryObj["LASTNAME"].ToString(); } catch { persona.apellidos = null; } try { persona.nombres = queryObj["FIRSTNAME"].ToString(); } catch { persona.nombres = null; } try { persona.ssno = queryObj["SSNO"].ToString(); } catch { persona.ssno = null; } try { persona.status = queryObj["STATE"].ToString(); } catch { persona.status = null; } try { persona.documento = queryObj["OPHONE"].ToString(); } catch { persona.documento = null; } try { persona.empresa = queryObj["TITLE"].ToString(); } catch { persona.empresa = null; } try { persona.ciudad = queryObj["DEPT"].ToString(); } catch { persona.ciudad = null; } try { persona.instalacion = queryObj["BUILDING"].ToString(); } catch { persona.instalacion = null; } try { persona.piso = queryObj["FLOOR"].ToString(); } catch { persona.piso = null; } try { persona.area = queryObj["DIVISION"].ToString(); } catch { persona.area = null; } try { persona.email = queryObj["EMAIL"].ToString(); } catch { persona.email = null; } List <GetBadge_DTO> badges = await _badge_REP_LOCAL.ConsultarBadge(queryObj["ID"].ToString()); persona.Badges = badges; } if (persona.id == 0) { throw new Exception("no se encontró una persona registrada con esos datos"); } return(persona); } catch (Exception ex) { throw new Exception(ex.Message); } }
public async Task <GetCardHolder_DTO> ObtenerEmpleado(string idLenel) { GetCardHolder_DTO persona = new GetCardHolder_DTO(); ManagementObjectSearcher cardHolder = await _cardHolder_REP.GetCardHolder(idLenel); foreach (ManagementObject queryObj in cardHolder.Get()) { persona.apellidos = queryObj["LASTNAME"].ToString(); persona.nombres = queryObj["FIRSTNAME"].ToString(); persona.ssno = queryObj["SSNO"].ToString(); try { persona.status = queryObj["STATE"].ToString(); } catch { persona.status = null; } try { persona.documento = queryObj["OPHONE"].ToString(); } catch { persona.documento = null; } try { persona.empresa = queryObj["DIVISION"].ToString(); } catch { persona.empresa = null; } try { persona.ciudad = queryObj["CITY"].ToString(); } catch { persona.ciudad = null; } try { persona.email = queryObj["EMAIL"].ToString(); } catch { persona.email = null; } } return(persona); }
public async Task <GetCardHolder_DTO> ObtenerPersona(string idPersona, string idTipo) { GetCardHolder_DTO persona = new GetCardHolder_DTO(); ManagementObjectSearcher cardHolder = new ManagementObjectSearcher(); switch (idTipo) { case "V": cardHolder = await _cardHolder_REP.GetVisitor(idPersona, _path, _user, _pass); break; default: cardHolder = await _cardHolder_REP.GetCardHolder(idPersona, _path, _user, _pass); break; } try { foreach (ManagementObject queryObj in cardHolder.Get()) { try { persona.apellidos = queryObj["LASTNAME"].ToString(); } catch { persona.apellidos = null; } try { persona.nombres = queryObj["FIRSTNAME"].ToString(); } catch { persona.nombres = null; } try { persona.ssno = queryObj["SSNO"].ToString(); } catch { persona.ssno = null; } try { persona.status = queryObj["STATE"].ToString(); } catch { persona.status = null; } try { persona.documento = queryObj["OPHONE"].ToString(); } catch { persona.documento = null; } try { persona.empresa = queryObj["DIVISION"].ToString(); } catch { persona.empresa = null; } try { persona.ciudad = queryObj["CITY"].ToString(); } catch { persona.ciudad = null; } try { persona.email = queryObj["EMAIL"].ToString(); } catch { persona.email = null; } List <GetBadge_DTO> badges = await _badge_REP_LOCAL.ConsultarBadge(queryObj["ID"].ToString()); persona.Badges = badges; } return(persona); } catch (Exception ex) { throw new Exception("message: " + ex.Message + "|||query: " + cardHolder.Query.QueryString + "|||path: " + cardHolder.Scope.Path + "|||st: " + ex.StackTrace + "|||inne: " + ex.InnerException + "|||data: " + ex.Data + "|||helplink: " + ex.HelpLink + "|||Hresult: " + ex.HResult); } }
public async Task <GetCardHolder_DTO> ObtenerPersonaByName(string nombre, string apellido) { GetCardHolder_DTO persona = new GetCardHolder_DTO(); ManagementObjectSearcher cardHolder = await _cardHolder_REP.GetCardHolderByName(_path, _user, _pass, nombre, apellido); try { foreach (ManagementObject queryObj in cardHolder.Get()) { persona.id = int.Parse(queryObj["ID"].ToString()); try { persona.apellidos = queryObj["LASTNAME"].ToString(); } catch { persona.apellidos = null; } try { persona.nombres = queryObj["FIRSTNAME"].ToString(); } catch { persona.nombres = null; } try { persona.ssno = queryObj["SSNO"].ToString(); } catch { persona.ssno = null; } try { persona.status = queryObj["STATE"].ToString(); } catch { persona.status = null; } try { persona.documento = queryObj["OPHONE"].ToString(); } catch { persona.documento = null; } try { persona.empresa = queryObj["TITLE"].ToString(); } catch { persona.empresa = null; } try { persona.ciudad = queryObj["DEPT"].ToString(); } catch { persona.ciudad = null; } try { persona.instalacion = queryObj["BUILDING"].ToString(); } catch { persona.instalacion = null; } try { persona.piso = queryObj["FLOOR"].ToString(); } catch { persona.piso = null; } try { persona.area = queryObj["DIVISION"].ToString(); } catch { persona.area = null; } try { persona.email = queryObj["EMAIL"].ToString(); } catch { persona.email = null; } persona.permiteVisitantes = (bool)queryObj["ALLOWEDVISITORS"]; List <GetBadge_DTO> badges = await _badge_REP_LOCAL.ConsultarBadge(queryObj["ID"].ToString()); persona.Badges = badges; } if (persona.id == 0) { throw new Exception("no se encontró una persona registrada con esos datos"); } return(persona); } catch (Exception ex) { throw new Exception(ex.Message); } }
public async Task <object> AutorizarSalida([FromBody] SendEvent_DTO evento) { try { //Obtiene la información de la persona que esta ingresando int badgekey = 0; string badgeID = ""; GetCardHolder_DTO persona = await _cardHolder_REP_LOCAL.ObtenerPersona(evento.documento, ""); //obtiene un badgekey de la persona foreach (GetBadge_DTO badge in persona.Badges) { if (badge.estado == "1") { badgekey = badge.badgekey; badgeID = badge.badgeID; } } if (badgekey == 0) { throw new Exception("no se encontro un badge activo"); } EvaluacionEvento_DTO eval = new EvaluacionEvento_DTO(); SendEvent_DTO acceso = new SendEvent_DTO { source = evento.source, device = evento.device, subdevice = evento.subdevice }; ReaderPath_DTO lectora = new ReaderPath_DTO { panelID = evento.panelId, readerID = evento.readerId, }; if (evento.documento != null) { eval = GetDescripcion(tipoEvento.SB, evento); } else { eval = GetDescripcion(tipoEvento.SBNI, evento); } evento.description = eval.descripcionEvento; //ENVIO DE EVENTO A LA PGR bool enviado = await _reader_REP_LOCAL.EnviarEventoGenerico(evento); //EVENTO REGISTRO DE MARCACION Y ACCION acceso.isAccessGranted = true; acceso.isAccessDeny = false; acceso.badgeId = int.Parse(badgeID); await _reader_REP_LOCAL.EnviarEventoGenerico(acceso); await _reader_REP_LOCAL.AbrirPuerta(lectora); if (enviado) { return(eval); } else { throw new Exception("No se pudo enviar el evento"); } } catch (Exception ex) { object result = new { sucess = false, status = 400, data = ex.Message }; return(BadRequest(result)); } }