Esempio n. 1
0
 public IHttpActionResult GetRFIDOfDB()
 {
     try
     {
         List <int> list = this.ef_rfid.Database.SqlQuery <int>("SELECT max([id]) as id FROM [dbo].[OPC_RFID] group by [num_trk],[side]").ToList();
         if (list == null)
         {
             return(NotFound());
         }
         List <RFID> result_list = new List <RFID>();
         foreach (int id in list)
         {
             OPC_RFID rfid = this.ef_rfid.GetOPC_RFID(id);
             if (rfid != null)
             {
                 result_list.Add(new RFID {
                     num_trk = rfid.num_trk, side = rfid.side ? 1 : 0, card = GetCardsOfNum(rfid.id_hi, rfid.id_lo), hi = (uint?)rfid.id_hi, lo = (uint?)rfid.id_lo
                 });
             }
         }
         if (result_list == null)
         {
             return(NotFound());
         }
         return(Ok(result_list));
     }
     catch (Exception e)
     {
         return(NotFound());
     }
 }
Esempio n. 2
0
 public OPC_RFID GetOPC_RFID(int id)
 {
     try
     {
         return(OPC_RFID.Where(c => c.id == id).FirstOrDefault());
     }
     catch (Exception e)
     {
         String.Format("Ошибка выполнения метода GetOPC_RFID(id={0})", id).SaveError(e);
         return(null);
     }
 }
Esempio n. 3
0
        public void Test_ClientTRK_ReadTagsOPSOfRFIDSaveDB()
        {
            try
            {
                ClientTRK  client      = new ClientTRK();
                EFOPC_RFID ef_opc_rfid = new EFOPC_RFID();

                List <RFID> list = client.ReadTagsOPSOfRFID(true);

                if (list != null)
                {
                    foreach (RFID rfid in list)
                    {
                        Console.WriteLine("rfid.num_trk - {0}", rfid.num_trk);
                        Console.WriteLine("rfid.side - {0}", rfid.side);
                        Console.WriteLine("rfid.lo - {0}", rfid.lo);
                        Console.WriteLine("rfid.hi - {0}", rfid.hi);

                        if (rfid.hi != null && rfid.lo != null && rfid.hi > 0 && rfid.lo > 0)
                        {
                            String.Format("Сервис TRKServices - Считана RFID-Карта ТРК={0}, сторона={1}, id_card={2}, hi={3}, lo={4}", rfid.num_trk, rfid.side, rfid.card != null ? (int?)rfid.card.Id : null, rfid.hi, rfid.lo).SaveInformation();
                            bool     side     = rfid.side == 0 ? false : true;
                            OPC_RFID rfid_old = ef_opc_rfid.OPC_RFID.Where(o => o.id_hi == (int)rfid.hi && o.id_lo == rfid.lo && o.side == side).OrderByDescending(o => o.id).FirstOrDefault();
                            if (rfid_old == null)
                            {
                                int res = ef_opc_rfid.AddOPC_RFID(rfid.num_trk, rfid.side == 0 ? false : true, rfid.card != null ? (int?)rfid.card.Id : null, (int)rfid.hi, (int)rfid.lo);
                                String.Format("Сервис TRKServices - добавлена новая RFID-Карта ТРК={0}, сторона={1}, id_card={2}, hi={3}, lo={4} - id строки - {5}", rfid.num_trk, rfid.side, rfid.card != null ? (int?)rfid.card.Id : null, rfid.hi, rfid.lo, res).SaveInformation();
                            }
                        }
                    }
                }
                else
                {
                    String.Format("Список считаных RFID-карт = null").SaveWarning();
                }
            }
            catch (Exception e)
            {
                Console.WriteLine(e);
            }
        }
Esempio n. 4
0
 /// <summary>
 /// Добавить карту
 /// </summary>
 /// <param name="num_trk"></param>
 /// <param name="side"></param>
 /// <param name="id_card"></param>
 /// <param name="id_hi"></param>
 /// <param name="id_lo"></param>
 /// <returns></returns>
 public int AddOPC_RFID(int num_trk, bool side, int?id_card, int id_hi, int id_lo)
 {
     try
     {
         OPC_RFID new_opc_rfid = new OPC_RFID()
         {
             id       = 0,
             datetime = DateTime.Now,
             num_trk  = num_trk,
             side     = side,
             id_card  = id_card,
             id_hi    = id_hi,
             id_lo    = id_lo
         };
         context.OPC_RFID.Add(new_opc_rfid);
         context.SaveChanges();
         return(new_opc_rfid.id);
     }
     catch (Exception e)
     {
         String.Format("Ошибка выполнения метода AddOPC_RFID(num_trk={0}, side={1}, id_card={2}, id_hi={3}, id_lo={4})", num_trk, side, id_card, id_hi, id_lo).SaveError(e);
         return(-1);
     }
 }
Esempio n. 5
0
        public void OnTimerServices(object sender, System.Timers.ElapsedEventArgs args)
        {
            try
            {
                //String.Format("Сервис TRKServices - чтение RFID").SaveInformation();
                ClientTRK client  = new ClientTRK();
                EFTRKLogs trk_log = new EFTRKLogs();


                EFOPC_RFID ef_opc_rfid = new EFOPC_RFID();


                List <RFID> list = client.ReadTagsOPSOfRFID(true);
                List <Gun>  guns = client.ReadTagOPCOfGun();

                string log_mes;

                // Сравним масив с памятью (выставим сообщения
                foreach (Gun gn in guns)
                {
                    int num = gn.num_trk > 9 ? gn.num_gun + 29 : gn.num_gun;
                    if (gn.taken != null && gn.taken != guns_taken[num])
                    {
                        if (gn.num_trk > 9)
                        {
                            log_mes = String.Format("Наливной стояк № {0} заземлен : {1}", gn.num_gun, gn.taken);
                        }
                        else
                        {
                            log_mes = String.Format("Пистолет № {0} снят : {1}", gn.num_gun, gn.taken);
                        }
                        log_mes.SaveWarning(); // Запишим в лог
                        // Пистолет подняли
                        trk_log.AddTRKLogs(new TRKLogs()
                        {
                            ID       = 0,
                            DateTime = DateTime.Now,
                            Level    = 4,
                            UserName = "******",
                            Log      = log_mes
                        });
                        // Отобразим световую индикацию
                        if (gn.num_trk <= 9)
                        {
                            if (gn.taken == true && trk_rfid[gn.num_trk, gn.side] == false)
                            {
                                // Блымкнем
                                client.WritePulseTagsRFID(gn.num_trk, gn.side == 0 ? 1 : 2, 99, 1);
                                trk_rfid[gn.num_trk, gn.side] = true;
                            }
                            //else
                            //{
                            //    // Перестаним блымкать
                            //    client.WritePulseTagsRFID(gn.num_trk, gn.side == 0 ? 1 : 2, 0, 1);
                            //}
                        }
                        guns_taken[num] = (bool)gn.taken;
                    }
                }
                // Проверим на выключение
                if (guns_taken[1] == false && trk_rfid[1, 0] == true)
                {
                    client.WritePulseTagsRFID(1, 1, 0, 1);
                    trk_rfid[1, 0] = false;
                }
                if (guns_taken[2] == false && trk_rfid[1, 1] == true)
                {
                    client.WritePulseTagsRFID(1, 2, 0, 1);
                    trk_rfid[1, 1] = false;
                }
                if (guns_taken[3] == false && trk_rfid[2, 0] == true)
                {
                    client.WritePulseTagsRFID(2, 1, 0, 1);
                    trk_rfid[2, 0] = false;
                }
                if (guns_taken[4] == false && trk_rfid[2, 1] == true)
                {
                    client.WritePulseTagsRFID(2, 2, 0, 1);
                    trk_rfid[2, 1] = false;
                }
                if (guns_taken[5] == false && trk_rfid[3, 0] == true)
                {
                    client.WritePulseTagsRFID(3, 1, 0, 1);
                    trk_rfid[3, 0] = false;
                }
                if (guns_taken[6] == false && trk_rfid[3, 1] == true)
                {
                    client.WritePulseTagsRFID(3, 2, 0, 1);
                    trk_rfid[3, 1] = false;
                }
                if (guns_taken[7] == false && trk_rfid[4, 0] == true)
                {
                    client.WritePulseTagsRFID(4, 1, 0, 1);
                    trk_rfid[4, 0] = false;
                }
                if (guns_taken[8] == false && trk_rfid[4, 1] == true)
                {
                    client.WritePulseTagsRFID(4, 2, 0, 1);
                    trk_rfid[4, 1] = false;
                }
                if (guns_taken[9] == false && trk_rfid[5, 0] == true)
                {
                    client.WritePulseTagsRFID(5, 1, 0, 1);
                    trk_rfid[5, 0] = false;
                }
                if (guns_taken[10] == false && trk_rfid[5, 1] == true)
                {
                    client.WritePulseTagsRFID(5, 2, 0, 1);
                    trk_rfid[5, 1] = false;
                }
                if (guns_taken[11] == false && trk_rfid[6, 0] == true)
                {
                    client.WritePulseTagsRFID(6, 1, 0, 1);
                    trk_rfid[6, 0] = false;
                }
                if (guns_taken[12] == false && trk_rfid[6, 1] == true)
                {
                    client.WritePulseTagsRFID(6, 2, 0, 1);
                    trk_rfid[6, 1] = false;
                }
                if (guns_taken[13] == false && guns_taken[14] == false && guns_taken[15] == false && guns_taken[16] == false && trk_rfid[7, 0] == true)
                {
                    client.WritePulseTagsRFID(7, 1, 0, 1);
                    trk_rfid[7, 0] = false;
                }
                if (guns_taken[17] == false && guns_taken[18] == false && guns_taken[19] == false && guns_taken[20] == false && trk_rfid[7, 1] == true)
                {
                    client.WritePulseTagsRFID(7, 2, 0, 1);
                    trk_rfid[7, 1] = false;
                }
                if (guns_taken[21] == false && guns_taken[22] == false && guns_taken[23] == false && guns_taken[24] == false && trk_rfid[8, 0] == true)
                {
                    client.WritePulseTagsRFID(8, 1, 0, 1);
                    trk_rfid[8, 0] = false;
                }
                if (guns_taken[25] == false && guns_taken[26] == false && guns_taken[27] == false && guns_taken[28] == false && trk_rfid[8, 1] == true)
                {
                    client.WritePulseTagsRFID(8, 2, 0, 1);
                    trk_rfid[8, 1] = false;
                }
                if (guns_taken[29] == false && trk_rfid[9, 0] == true)
                {
                    client.WritePulseTagsRFID(9, 1, 0, 1);
                    trk_rfid[9, 0] = false;
                }
                // Можно добавить НС
                if (list != null && guns != null)
                {
                    // String.Format("Список считаных RFID-карт = {0}",list.Count()).SaveWarning();
                    // Проверим RFID
                    foreach (RFID rfid in list)
                    {
                        // Определим сторону
                        bool side = rfid.side == 0 ? false : true;
                        // Получим список пистолетов относящихся к RFID
                        List <Gun> guns_trk = guns.Where(g => g.num_trk == rfid.num_trk && g.side == rfid.side).ToList();
                        // Если все пистолеты опущены и это колонка - тогда удалим карточку
                        if ((guns_trk == null || !IsTaken(guns_trk)) && rfid.num_trk < 10)
                        {
                            SqlParameter trk   = new SqlParameter("@trk", rfid.num_trk);
                            SqlParameter bside = new SqlParameter("@side", side);
                            int          res   = ef_opc_rfid.Database.ExecuteSqlCommand("DELETE FROM [dbo].[OPC_RFID] where [num_trk]=@trk and [side]=@side", trk, bside);
                        }
                        //// Пистолет поднят
                        //if (guns_trk != null && IsTaken(guns_trk))
                        //{
                        //    // Блымкнем
                        //    client.WritePulseTagsRFID(rfid.num_trk, side == false ? 1 : 2, 99, 1);
                        //    //String.Format("Пистолет поднят RFID-карту TRK={0}, сторона {1}, результат={2}", rfid.num_trk, side == false ? 1 : 2, res).SaveWarning();
                        //}
                        //else {
                        //    if (rfid.num_trk < 10)
                        //    {
                        //        SqlParameter trk = new SqlParameter("@trk", rfid.num_trk);
                        //        SqlParameter bside = new SqlParameter("@side", side);
                        //        int res = ef_opc_rfid.Database.ExecuteSqlCommand("DELETE FROM [dbo].[OPC_RFID] where [num_trk]=@trk and [side]=@side", trk, bside);
                        //        client.WritePulseTagsRFID(rfid.num_trk, side == false ? 1 : 2, 0, 1);
                        //        //String.Format("Сбросим RFID-карту TRK={0}, сторона {1}, результат={2}", rfid.num_trk, side == false ? 1 : 2, res).SaveWarning();
                        //    }
                        //}
                        // Проверим RFID поднесена
                        if (rfid.hi != null && rfid.lo != null && rfid.hi >= 0 && rfid.lo > 0)
                        {
                            // Да, поднесена
                            String.Format("Сервис TRKServices - Считана RFID-Карта ТРК={0}, сторона={1}, id_card={2}, hi={3}, lo={4}", rfid.num_trk, rfid.side, rfid.card != null ? (int?)rfid.card.Id : null, rfid.hi, rfid.lo).SaveInformation();
                            // Проверим эта карта есть в базе
                            OPC_RFID rfid_old = ef_opc_rfid.OPC_RFID.Where(o => o.id_hi == (int)rfid.hi && o.id_lo == rfid.lo && o.side == side).OrderByDescending(o => o.id).FirstOrDefault();
                            // Карты в базе нет?
                            if (rfid_old == null)
                            {
                                // проверим по колонке есть снятый пистолет
                                if (guns_trk != null && ((rfid.num_trk < 10 && IsTaken(guns_trk)) || (rfid.num_trk >= 10 && rfid.num_trk <= 12)))
                                {
                                    int res = ef_opc_rfid.AddOPC_RFID(rfid.num_trk, rfid.side == 0 ? false : true, rfid.card != null ? (int?)rfid.card.Id : null, (int)rfid.hi, (int)rfid.lo);

                                    if (rfid.num_trk > 9)
                                    {
                                        log_mes = String.Format("Наливной стояк № {0} считана RFID-карта : {1} Код записи в БД - {2}", rfid.num_trk - 10, rfid.card != null ? (int?)rfid.card.Id : null, res);
                                    }
                                    else
                                    {
                                        log_mes = String.Format("ТРК № {0}, сторона {1}, считана RFID-карта : {2} Код записи в БД - {3}", rfid.num_trk, rfid.side, rfid.card != null ? (int?)rfid.card.Id : null, res);
                                    }
                                    log_mes.SaveWarning(); // Запишим в лог
                                    trk_log.AddTRKLogs(new TRKLogs()
                                    {
                                        ID       = 0,
                                        DateTime = DateTime.Now,
                                        Level    = 4,
                                        UserName = "******",
                                        Log      = log_mes
                                    });
                                }
                            }
                        }
                    }
                }
                else
                {
                    String.Format("Список считаных RFID-карт = null").SaveWarning();
                }
            }
            catch (Exception e)
            {
                String.Format("OnTimerServices(sender={0}, args={1})", sender, args.ToString()).SaveError(e);
            }
        }