/// <summary> /// Deprecated Method for adding a new object to the MovilizacionTimelines EntitySet. Consider using the .Add method of the associated ObjectSet<T> property instead. /// </summary> public void AddToMovilizacionTimelines(MovilizacionTimeline movilizacionTimeline) { base.AddObject("MovilizacionTimelines", movilizacionTimeline); }
public string AlertaMovilizacion(MovilizacionContact contacto, int valor, string mensaje) { var db = new edayRoomEntities(); var centro = db.Centroes.Single(c => c.id == contacto.IdCentro); var user = db.users.Single(u => u.username == User.Identity.Name); #region Registro la alerta var alerta = new MovilizacionAlerta { activa = true, fecha = DateTime.Now, id_centro = contacto.IdCentro, id_movilizador = contacto.IdTestigo, id_alerta = valor, id_usuario = user.id }; db.MovilizacionAlertas.AddObject(alerta); var messages = new List<MovilizacionAlertaMessage>(); if (!string.IsNullOrWhiteSpace(mensaje)) { var alertMessage = new MovilizacionAlertaMessage { fecha = DateTime.Now, mensaje = mensaje, id_usuario = user.id }; alerta.MovilizacionAlertaMessages.Add(alertMessage); messages.Add(alertMessage); } #endregion #region Retraso de Timeline Alerta objetoAlerta = db.Alertas.Single(a => a.id == valor); if (objetoAlerta.blocking){ centro.alertBlocked = true; centro.blockingAlertId = objetoAlerta.id; } if (objetoAlerta.regresivo) { //MovilizacionTimeline oldTimeline = // (from pt in db.MovilizacionTimelines where // pt.id == contacto.MovilizacionTimelineId select pt). // Single(); //oldTimeline.activa = false; //Cancelo todos los timelines activos y resolvemos este peo var oldTimelines = (from pt in db.MovilizacionTimelines where pt.activa && pt.id_centro == contacto.IdCentro //pt.id == contacto.MovilizacionTimelineId select pt); foreach (var oldTimeline in oldTimelines) { oldTimeline.activa = false; } DateTime newDate = DateTime.Now.AddMinutes(objetoAlerta.tiempo); var newTimeline = new MovilizacionTimeline { id_centro = contacto.IdCentro, fecha = newDate, activa = true }; db.MovilizacionTimelines.AddObject(newTimeline); } #endregion db.SaveChanges(); // VERIFICAR SI HAY QUE HACER TRIGGER DE ALGUNA ALERTA IQueryable<MovilizacionAlerta> existingAlerts = from a in db.MovilizacionAlertas where a.id_centro == contacto.IdCentro && a.id_alerta == valor && a.activa select a; var alertCount = existingAlerts.Count(); var maxRepeats = existingAlerts.First().Alerta.maxRepeats ?? 0; if (maxRepeats != 0) { if (alertCount == maxRepeats) { //LLEGUE AL LIMITE, hago el trigger de la alerta var newAlerta = existingAlerts.First().Alerta.AlertaAsociada; var alertaAuto = new MovilizacionAlerta { activa = true, fecha = DateTime.Now, id_centro = contacto.IdCentro, id_movilizador = contacto.IdTestigo, id_alerta = newAlerta.id, id_usuario = user.id }; db.MovilizacionAlertas.AddObject(alertaAuto); if (newAlerta.blocking){ centro.alertBlocked = true; centro.blockingAlertId = newAlerta.id; } var alertMessage = new MovilizacionAlertaMessage { fecha = DateTime.Now, mensaje = "Alerta generada por sistema", id_usuario=user.id }; alertaAuto.MovilizacionAlertaMessages.Add(alertMessage); } } db.SaveChanges(); return new JavaScriptSerializer().Serialize(""); }
/// <summary> /// Create a new MovilizacionTimeline object. /// </summary> /// <param name="id">Initial value of the id property.</param> /// <param name="id_centro">Initial value of the id_centro property.</param> /// <param name="fecha">Initial value of the fecha property.</param> /// <param name="activa">Initial value of the activa property.</param> public static MovilizacionTimeline CreateMovilizacionTimeline(global::System.Int32 id, global::System.Int32 id_centro, global::System.DateTime fecha, global::System.Boolean activa) { MovilizacionTimeline movilizacionTimeline = new MovilizacionTimeline(); movilizacionTimeline.id = id; movilizacionTimeline.id_centro = id_centro; movilizacionTimeline.fecha = fecha; movilizacionTimeline.activa = activa; return movilizacionTimeline; }
public string UpdateMovilizacion(MovilizacionContact contacto, int valor, int cola = 0) { var db = new edayRoomEntities(); var user = db.users.Single(u => u.username == User.Identity.Name); //Reseteo los timelines activos var oldTimelines = (from pt in db.MovilizacionTimelines where pt.activa && pt.id_centro == contacto.IdCentro select pt); foreach (var oldTimeline in oldTimelines) { oldTimeline.activa = false; } var newDate = contacto.QuickCountActive ? DateTime.Now.AddMinutes(45) : DateTime.Now.AddMinutes(60); //Actualizo los timelines var newTimeline = new MovilizacionTimeline { id_centro = contacto.IdCentro, fecha = newDate, activa = true }; db.MovilizacionTimelines.AddObject(newTimeline); var newMovilizacion = new Movilizacion { fecha = DateTime.Now, hora = DateTime.Now.Hour, min10 = DateTime.Now.Minute / 10, min30 = DateTime.Now.Minute / 30, conteo = valor, id_centro = contacto.IdCentro, id_movilizador = contacto.IdTestigo, active = true, id_parent = contacto.LastMovilizacionId, id_user = user.id }; //Actualizo los datos a nivel de centro var centro = db.Centroes.Single(c => c.id == contacto.IdCentro); centro.movilizacionCount = valor; centro.lastMovilizacionContact = DateTime.Now; centro.nextMovilizacionContact = newDate; Movilizacion oldMovilizacion = db.Movilizacions.Single(p => p.id == contacto.LastMovilizacionId); oldMovilizacion.active = false; db.Movilizacions.AddObject(newMovilizacion); //Desactivo las alertas que esten pendientes en el centro var alertas = from a in db.MovilizacionAlertas where a.activa && !a.Alerta.blocking && a.id_centro == contacto.IdCentro select a; foreach (var a in alertas) { a.activa = false; } db.SaveChanges(); return new JavaScriptSerializer().Serialize(""); }