internal static void ProccessTablesDataGroupedByTimeStamp(IGrouping <DateTime, TurbineInfo> turbineGroupedByTimeStamp, DateTime endDate, VestasTurbinesData turbinaDataCollector)
        {
            long counterPackage = 0;

            for (DateTime i = turbineGroupedByTimeStamp.Key; i < endDate; i = i.AddMinutes(10))
            {
                turbineGroupedByTimeStamp = ChangeCurrentTimeStamp(turbineGroupedByTimeStamp, i);

                if (counterPackage % 1000 == 0)
                {
                    turbinaDataCollector.CloseConnection();
                    turbinaDataCollector.OpenConnection();
                }
                //Get the data
                //if (counterPackage % 200 == 0)
                Console.WriteLine("//////////////////////");
                Stopwatch st = new Stopwatch();
                st.Start();

                var turbineData = turbinaDataCollector.GetDataFromTurbines(turbineGroupedByTimeStamp);

                if (!turbineData.Any())// && counterPackage%200 == 0)
                {
                    Console.WriteLine("No data available for: " + i.ToString());
                    continue;
                }

                st.Stop();

                var tableNames = GetTableNames(turbineGroupedByTimeStamp);
                //if (counterPackage % 200 == 0)
                //{
                Console.WriteLine("Obtaining Data for " + tableNames);
                Console.WriteLine("Timestam: " + i.ToString() + ", Time Elapsed: = " + st.ElapsedMilliseconds);
                //}

                //send to serializator
                var serializedData = DataTransformator.SerializeData(turbineData);
                // var package = DataTransformator.PreaparePackage(serializedData, PackageManager.PackageBuilder.EncryptionAlgorithmType.AES, PackageManager.PackageBuilder.PayloadDataType.Data10Minutes, i);

                IEncryptor encryptor = new AESEncryptor();
                st.Reset();
                st.Start();
                var securedData = encryptor.EncryptData(serializedData);
                st.Stop();
                //if (counterPackage % 200 == 0)
                Console.WriteLine("Encrypting data took: " + st.ElapsedMilliseconds);

                counterPackage++;
                //if(counterPackage%200 == 0)
                Console.WriteLine("Counter = " + counterPackage);

                var package = DataTransformator.PreaparePackage(securedData.Data, PackageManager.PackageBuilder.EncryptionAlgorithmType.AES, PackageManager.PackageBuilder.PayloadDataType.Data10Minutes, i);
                package.EncryptedKey = securedData.Key;
                package.EncryptedIV  = securedData.Vector;
                var binaryPackage = DataTransformator.GetBinary(package);

                // send to data relay

                try
                {
                    DataRelayService.DataRelayServiceClient client = new DataRelayService.DataRelayServiceClient();
                    var result = client.Send(binaryPackage);
                    _serviceCounter++;

                    // client.KnockKnock(binaryPackage);
                }
                catch (EndpointNotFoundException)
                {
                    Console.WriteLine("Couldn't connect to Data Relay using configured endpoint");
                    continue;
                }
                catch (Exception ex)
                {
                    Console.WriteLine(ex.Message);
                    throw;
                }

                turbinaDataCollector.SetTimeStampsForTables(turbineGroupedByTimeStamp);
            }

            Console.WriteLine("Service was called: " + _serviceCounter);
        }