Exemple #1
0
        public static int GetAndUpdateCurrentEvenID()
        {
            SSHMC01Entities1 db = new SSHMC01Entities1();

               db.tblSiteEventMaintain.First().SEVENT_ID += 1;
               db.SaveChanges();
              return db.tblSiteEventMaintain.First().SEVENT_ID;
        }
Exemple #2
0
        void info_OnDegreeChanged(Sensor.SensorBase snr, int degree)
        {
            ////  //  SensorInfo snrinfo = snrList.Where(n => n.SENSOR_ID == info.SENSOR_ID).FirstOrDefault();
            ////    int maxDegree = snrList.Max(n => n.CURRENT_DEGREE);
            ////    // Controll flow here!
            SSHMC01Entities1 db = new SSHMC01Entities1();
               //   Sen snrinfo = snrList.Where(n => n.SENSOR_ID == info.SENSOR_ID).FirstOrDefault();
            int maxDegree = snrList.Max(n => n.CurrentDegree);
            tblSite site = db.tblSite.Where(n => n.SITE_ID == snr.Site_ID).FirstOrDefault();
            Console.Write("sitrid:" + this.SITE_ID + ",degree:" + maxDegree);
               //  Controll flow here!

            if (maxDegree > 0)
            {
                if (CURRENT_DEGREE == 0) // new evenr
                {
                    int evtid = Global.GetAndUpdateCurrentEvenID();

                    if (site != null)
                    {
                          this.STATUS=   site.STATUS = "A";  //waiting confirm
                           site.CURRENT_DEGREE =  this.CURRENT_DEGREE= maxDegree;
                           site.SEVENT_ID = this.SEVENT_ID= evtid;
                            site.REF_SENDSOR_ID =this.REF_SENSOR_ID= snr.SensorID;
                            site.HappenTimeStamp=this.HappenTimeStamp=DateTime.Now;
                            site.ConfirmTimes = this.ConfirmTimes = 0;
                            db.SaveChanges();

                            //string subject = site.SITE_NAME + (4 - maxDegree) + "級事件發生確認通知";
                            //string body = ComposeBody(site, snr, maxDegree);
                            //Global.SendMailToUser("*****@*****.**", subject, body);

                        // mail to  waiting confirm
                    }

                }
                else if (CURRENT_DEGREE > 0)
                {
                    if (site.STATUS == "E")  //Execute  upgrade
                    {
                        if (maxDegree > CURRENT_DEGREE)
                        {
                            //mail notify

                            site.HappenTimeStamp = this.HappenTimeStamp = System.DateTime.Now;
                            site.REF_SENDSOR_ID = this.REF_SENSOR_ID = snr.SensorID;
                            site.CURRENT_DEGREE = this.CURRENT_DEGREE = maxDegree;
                            db.SaveChanges();
                            string subject = ((DateTime)this.HappenTimeStamp).ToString() + "," + site.SITE_NAME + (4 - maxDegree) + "級升級事件通知";
                            string body = ComposeBody(site, snr, maxDegree);
                            string mailto = (from n in db.OMEMP where n.EMPNO == site.ENGINEER select n.MAIL).FirstOrDefault();
                            if (mailto != null)
                            {
                                try
                                {
                                    Global.SendMailToUser(mailto, subject, body);
                                }
                                catch (Exception ex)
                                {
                                    Console.WriteLine(ex.Message + "," + ex.StackTrace);
                                }
                            }
                          //  throw new NotImplementedException();
                        }
                        else   if(maxDegree <CURRENT_DEGREE)  // downgrade
                        {
                            site.HappenTimeStamp = this.HappenTimeStamp = System.DateTime.Now;
                            site.REF_SENDSOR_ID = this.REF_SENSOR_ID = snr.SensorID;
                            site.CURRENT_DEGREE = this.CURRENT_DEGREE = maxDegree;
                            db.SaveChanges();

                            string subject = ((DateTime)this.HappenTimeStamp).ToString() + "," + site.SITE_NAME + (4 - maxDegree) + "級降級級事件通知";
                            string body = ComposeBody(site, snr, maxDegree);
                            string mailto = (from n in db.OMEMP where n.EMPNO == site.ENGINEER select n.MAIL).FirstOrDefault();
                            if (mailto != null)
                            {
                                try
                                {
                                    Global.SendMailToUser(mailto, subject, body);
                                }
                                catch (Exception ex)
                                {
                                    Console.WriteLine(ex.Message + "," + ex.StackTrace);
                                }
                            }

                          //  throw new NotImplementedException();
                        }

                    }
                    else if (site.STATUS == "S" || site.STATUS == "C"  ||  site.STATUS=="A")
                    {
                        if (maxDegree > CURRENT_DEGREE)  //upgrade
                        {
                            //mail notify

                         //   if (site.STATUS == "S")
                                        this.STATUS = site.STATUS ="A";

                            site.CURRENT_DEGREE = this.CURRENT_DEGREE = maxDegree;

                            site.REF_SENDSOR_ID = this.REF_SENSOR_ID = snr.SensorID;
                            site.HappenTimeStamp = this.HappenTimeStamp = DateTime.Now;
                            site.ConfirmTimes = this.ConfirmTimes = 0;
                            db.SaveChanges();
                            if (site.STATUS != "A")
                            {

                                string subject = site.SITE_NAME + (4 - maxDegree) + "級升級事件確認";
                                string body = ComposeBody(site, snr, maxDegree);
                                string mailto = (from n in db.OMEMP where n.EMPNO == site.ENGINEER select n.MAIL).FirstOrDefault();
                                if (mailto != null)
                                {
                                    try
                                    {
                                        Global.SendMailToUser(mailto, subject, body);
                                    }
                                    catch (Exception ex)
                                    {
                                        Console.WriteLine(ex.Message + "," + ex.StackTrace);
                                    }
                                }
                                // Global.SendMailToUser(mailto, subject, body);
                            }
                          //  throw new NotImplementedException();
                        }
                        else if (maxDegree < CURRENT_DEGREE)  // downgrade
                        {
                            site.CURRENT_DEGREE = this.CURRENT_DEGREE = maxDegree;

                            site.REF_SENDSOR_ID = this.REF_SENSOR_ID = snr.SensorID;
                            site.HappenTimeStamp = this.HappenTimeStamp = DateTime.Now;
                           // site.ConfirmTimes = this.ConfirmTimes = 0;
                            db.SaveChanges();
                            if (site.STATUS != "A")
                            {
                                string subject = ((DateTime)this.HappenTimeStamp).ToString() + "," + site.SITE_NAME + (4 - maxDegree) + "級降級級事件通知";
                                string body = ComposeBody(site, snr, maxDegree);
                                string mailto = (from n in db.OMEMP where n.EMPNO == site.ENGINEER select n.MAIL).FirstOrDefault();
                                if (mailto != null)
                                {
                                    try
                                    {
                                        Global.SendMailToUser(mailto, subject, body);
                                    }
                                    catch (Exception ex)
                                    {
                                        Console.WriteLine(ex.Message + "," + ex.StackTrace);
                                    }
                                }
                            }
                           // throw new NotImplementedException();
                        }

                    }

                }

            }
            else if(maxDegree==0||maxDegree==-1)  //判斷是否事件該結束
            {
                if(CURRENT_DEGREE>0)
                {
                    string LastStatus = site.STATUS;
                    this.STATUS = site.STATUS = null;  //waiting confirm
                    site.CURRENT_DEGREE = this.CURRENT_DEGREE = maxDegree;
                    this.SEVENT_ID = null;
                    site.SEVENT_ID  = null;
                    site.REF_SENDSOR_ID = null;
                    this.REF_SENSOR_ID = -1;
                    site.HappenTimeStamp = this.HappenTimeStamp = null;
                    site.ConfirmTimes = this.ConfirmTimes = null;
                    db.SaveChanges();
                    if (LastStatus != "A")
                    {
                        string subject = (DateTime.Now).ToString() + "," + site.SITE_NAME + "事件結束通知";
                        string body = ComposeBody(site, snr, maxDegree);
                        string mailto = (from n in db.OMEMP where n.EMPNO == site.ENGINEER select n.MAIL).FirstOrDefault();
                        if (mailto != null)
                        {
                            try
                            {
                                Global.SendMailToUser(mailto, subject, body);
                            }
                            catch (Exception ex)
                            {
                                Console.WriteLine(ex.Message + "," + ex.StackTrace);
                            }
                        }
                    }
                    // send mail to notify event has end
                }
            }

            //if(CURRENT_DEGREE!=maxDegree)
            //          CURRENT_DEGREE = maxDegree;
        }
Exemple #3
0
        void LoadDB()
        {
            SSHMC01Entities1 db = new SSHMC01Entities1();
               var q = from n in db.tblSite select new SiteInfo() { SITE_ID = n.SITE_ID, CURRENT_DEGREE = n.CURRENT_DEGREE??0, REF_SENSOR_ID = n.REF_SENDSOR_ID??0, SEVENT_ID = n.SEVENT_ID??0, STATUS = n.STATUS };
               foreach (SiteInfo info in q)
               {
               dictSiteInfos.Add(info.SITE_ID, info);
               }

              //  var  q1 = from n in  select n;

              foreach (Sensor.SensorBase info in snrmgr.getAllDeviceEnum())
              {
              dictSnrInfo.Add(info.SensorID, info);
              this.dictSiteInfos[info.Site_ID].AddSiteSensorInfo(info);

              }
        }
Exemple #4
0
        public void SuspendEvent(string siteid)
        {
            if (!this.dictSiteInfos.ContainsKey(siteid))
               return;
               SSHMC01Entities1 db = new SSHMC01Entities1();
               SiteInfo siteinfo = dictSiteInfos[siteid];
               tblSite site = (from n in db.tblSite where n.SITE_ID == siteid select n).FirstOrDefault();

               if (site == null)
               return;

               site.STATUS = "S";  //waiting confirm
               site.CURRENT_DEGREE = siteinfo.CURRENT_DEGREE;
               //  site.SEVENT_ID = this.SEVENT_ID = evtid;
               site.REF_SENDSOR_ID = siteinfo.REF_SENSOR_ID;
               site.HappenTimeStamp = DateTime.Now;
               site.ConfirmTimes = 0;
               db.SaveChanges();
               //  throw new NotImplementedException();
        }
Exemple #5
0
        //public  void SetSensorCurrentLevel(int snrid,int level)
        //{
        //}
        public void NotifySponsor(string siteid, string mailaddress, string mailtitle, string mailbody)
        {
            if (!this.dictSiteInfos.ContainsKey(siteid))
               return;
               SSHMC01Entities1 db = new SSHMC01Entities1();
               SiteInfo siteinfo = dictSiteInfos[siteid];
               tblSite site = (from n in db.tblSite where n.SITE_ID == siteid select n).FirstOrDefault();

               if (site == null)
               return;

            site.STATUS = "C";  //waiting confirm
            site.CURRENT_DEGREE = siteinfo.CURRENT_DEGREE;
             //  site.SEVENT_ID = this.SEVENT_ID = evtid;
            site.REF_SENDSOR_ID = siteinfo.REF_SENSOR_ID;
               site.HappenTimeStamp =DateTime.Now;
               //site.ConfirmTimes =   0;
               db.SaveChanges();

               Global.SendMailToUser(mailaddress, mailtitle, mailbody);
        }