Ejemplo n.º 1
0
        public TelemetryList GetTelemetry(string companyname, int usertype = 3, string username = "******", int count = 1)
        {
            TelemetryList telemetryList = null;

            telemetryList = _telemetryService.GetTelemetry(companyname, usertype, username, count);
            return(telemetryList);
        }
        private void GetDataByTerminalId(int terminalId)
        {
            try
            {
                var request = (HttpWebRequest)WebRequest.Create($"http://localhost:8084/client/getdata/{terminalId}");
                using (var response = (HttpWebResponse)request.GetResponse())
                {
                    _logger.Info($"Connection to server StatusCode: {response.StatusCode}.");

                    TelemetryCollection telemetryData =
                        _serializer.Deserialize <TelemetryCollection>(GetResponseBody(response));

                    TelemetryList.Clear();
                    foreach (var data in telemetryData.Collection)
                    {
                        TelemetryList.Add(data);
                    }

                    InitialDateSelected = telemetryData.Collection.Min(i => i.Time);
                    FinalDateSelected   = telemetryData.Collection.Max(f => f.Time);

                    response.Close();
                }
            }
            catch (Exception ex)
            {
                _logger.Error(ex);
                MessageBox.Show(ex.Message, "Ошибка при получении данных", MessageBoxButton.OK, MessageBoxImage.Warning);
            }
        }
Ejemplo n.º 3
0
        private static TelemetryList TransformTelemetry(IDataReader rdr)
        {
            var telemetryList = new TelemetryList();

            while (rdr.Read())
            {
                var telemetry = new UserTelemetry();

                telemetry.deviceid  = rdr[0].ToString().Trim();
                telemetry.longitude = (double)rdr[1];
                telemetry.latitude  = (double)rdr[2];
                telemetry.timestamp = Convert.ToDateTime(rdr[3].ToString());

                telemetry.User.userid      = rdr[4].ToString().Trim();
                telemetry.User.companyname = rdr[5].ToString().Trim();
                telemetry.User.imageurl    = rdr[6].ToString().Trim();
                telemetry.User.firstname   = rdr[7].ToString().Trim();
                telemetry.User.lastname    = rdr[8].ToString().Trim();
                telemetry.User.username    = rdr[9].ToString().Trim();
                telemetry.User.type        = rdr[10].ToString().Trim();
                telemetry.User.phone       = rdr[11].ToString().Trim();
                telemetry.User.email       = rdr[12].ToString().Trim();
                telemetry.User.gender      = rdr[13].ToString().Trim();
                telemetry.User.race        = rdr[14].ToString().Trim();

                telemetry.Readings.age                  = (double)rdr[15];
                telemetry.Readings.height               = (double)rdr[16];
                telemetry.Readings.weight               = (double)rdr[17];
                telemetry.Readings.heartRateBPM         = (double)rdr[18];
                telemetry.Readings.heartRateRedZone     = (double)rdr[19];
                telemetry.Readings.heartrateVariability = (double)rdr[20];
                telemetry.Readings.temperature          = (double)rdr[21];
                telemetry.Readings.steps                = (double)rdr[22];
                telemetry.Readings.velocity             = (double)rdr[23];
                telemetry.Readings.altitude             = (double)rdr[24];
                telemetry.Readings.ventilization        = (double)rdr[25];
                telemetry.Readings.activity             = (double)rdr[26];
                telemetry.Readings.cadence              = (double)rdr[27];
                telemetry.Readings.speed                = (double)rdr[28];

                telemetryList.list.Add(telemetry);
            }

            rdr.Close();

            return(telemetryList);
        }
Ejemplo n.º 4
0
        public TelemetryList GetTelemetry(string companyname, int usertype, string username, int count)
        {
            // type == 2 means a manager is requesting data for their employees so restriction is based on companyname
            // type == 3 means an employee is requsting their data s the query is restricted by companyname and their username

            string whereClause;

            switch (usertype)
            {
            case 2:
                whereClause = $"where type='3' and companyname='{companyname}'";
                break;

            case 3:
                whereClause = $"where type='3' and companyname='{companyname}' and username='******'";
                break;

            default:
                throw new Exception("Error: User Type not specified");
            }

            var topClause = (count > 0) ? "top " + count.ToString() : "";

            Open();

            var query = "select " + topClause +
                        " [DeviceId],[Longitude],[Latitude],[Timestamp],[UserId],[companyname],[imageUrl],[firstname],[lastname],[username],[type],[phone],[email],[gender],[race],[Age],[Height],[Weight],[HeartRateBPM],[BreathingRate],[HeartRateRedZone],[HeartrateVariability],[Temperature],[Steps],[Velocity],[Altitude],[Ventilization],[Activity],[Cadence],[Speed],[HIB] from IoTHubSensorReadings " +
                        whereClause + " order by timestamp desc";

            var cmd = new SqlCommand(query, _conn);

            var rdr = cmd.ExecuteReader();

            TelemetryList tempTelemetryList = null;

            if (rdr.HasRows)
            {
                tempTelemetryList = TransformTelemetry(rdr);
            }

            Close();

            return(tempTelemetryList);
        }