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> ObtenerPersona(string documento, string ssno) { GetCardHolder_DTO persona = new GetCardHolder_DTO(); ManagementObjectSearcher cardHolder = await _cardHolder_REP.GetCardHolder(documento, ssno, _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; } 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> LastEvent(string documento, int gap, int intentos, int timeout) { bool salir = false; DateTime tiempoEvento = new DateTime(); int personaId = 0; string resultado = "OK"; List <LastLocation_DTO> listLocations = new List <LastLocation_DTO>(); ManagementObjectSearcher cardHolder = await _cardHolder_REP.GetCardHolder(documento, "", _path, _user, _pass); try { foreach (ManagementObject queryObj in cardHolder.Get()) { personaId = int.Parse(queryObj["ID"].ToString()); } if (personaId == 0) { throw new Exception("no se encontró una persona registrada con esos datos"); } else { int intento = 1; do { ManagementObjectSearcher LastLocation = await _badge_REP.GetLastLocation(personaId, _path, _user, _pass); listLocations.Clear(); foreach (ManagementObject queryObj in LastLocation.Get()) { LastLocation_DTO lastLocation = new LastLocation_DTO(); try { lastLocation.badgeId = queryObj["BADGEID"].ToString(); } catch { lastLocation.badgeId = "0"; } try { lastLocation.eventTime = queryObj["EVENTTIME"].ToString(); } catch { lastLocation.eventTime = null; } try { lastLocation.panelId = (int)queryObj["PANELID"]; } catch { lastLocation.panelId = 0; } try { lastLocation.readerId = (int)queryObj["READERID"]; } catch { lastLocation.readerId = 0; } listLocations.Add(lastLocation); } foreach (LastLocation_DTO location in listLocations) { if (string.IsNullOrEmpty(location.eventTime)) { throw new Exception("no se encontró un evento asociado"); } else { tiempoEvento = DateTime.ParseExact(location.eventTime.Substring(0, 14), "yyyyMMddHHmmss", null); TimeSpan difTime = tiempoEvento - DateTime.Now; if (difTime.Duration() < new TimeSpan(0, 0, gap)) { salir = true; break; } } } if (intento == intentos && salir != true) { resultado = "No se presento un evento en la ventana de tiempo requerida"; salir = true; } else { System.Threading.Thread.Sleep(timeout); intento++; } } while (salir == false); } object result = new { locations = listLocations, result = resultado }; return(result); } catch (Exception ex) { throw new Exception(ex.Message); } }