예제 #1
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);
            }
        }
예제 #2
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);
            }
        }