public static void Import_Doctors_from_xls(string connectionString, SessionSecurityTicket securityTicket) { string folder = Directory.GetParent(Directory.GetCurrentDirectory()).Parent.FullName; string filePath = Path.Combine(folder, "Excel\\doctors.xlsx"); bool hasHeader = true; bool flagValid = true; System.Data.DataTable excelData = ExcelUtils.getDataFromExcelFileMM(filePath, hasHeader); try { excelData = ExcelUtils.getDataFromExcelFileMM(filePath, hasHeader); filePath = Path.Combine(folder, "Excel\\doctors.xls"); } catch (Exception ex) { } List <Doctor_model_from_xlsx> DoctorL = new List <Doctor_model_from_xlsx>(); DO_GAPR_1112[] PracticeData = new DO_GAPR_1112[] { }; DbConnection Connection = null; DbTransaction Transaction = null; bool cleanupConnection = Connection == null; bool cleanupTransaction = Transaction == null; if (cleanupConnection == true) { Connection = CSV2Core_MySQL.Support.DBSQLSupport.CreateConnection(connectionString); Connection.Open(); } if (cleanupTransaction == true) { Transaction = Connection.BeginTransaction(); } try { PracticeData = cls_Get_all_Practices.Invoke(Connection, Transaction, securityTicket).Result; //Commit the transaction if (cleanupTransaction == true) { Transaction.Commit(); } //Close the connection if (cleanupConnection == true) { Connection.Close(); } } catch (Exception ex) { try { if (cleanupTransaction == true && Transaction != null) { Transaction.Rollback(); } } catch { } try { if (cleanupConnection == true && Connection != null) { Connection.Close(); } } catch { } throw ex; } List <string> LoginMailUnique = new List <string>(); Dictionary <string, string> LANRUnique = new Dictionary <string, string>(); IEnumerable <DataRow> doctors = excelData.Rows.Cast <DataRow>(); foreach (System.Data.DataRow item in excelData.Rows) { Doctor_model_from_xlsx doctor = new Doctor_model_from_xlsx(); doctor.ValidationErrors = ""; // doctor.Salutation = item.ItemArray[0].ToString(); doctor.Salutation = ""; doctor.Title = item.ItemArray[1].ToString(); doctor.FirstName = item.ItemArray[2].ToString(); if (doctor.FirstName == "") { flagValid = false; doctor.ValidationErrors = "First name empty"; } doctor.LastNAme = item.ItemArray[3].ToString(); if (doctor.LastNAme == "") { doctor.ValidationErrors = doctor.ValidationErrors + ", " + "Last name empty"; } doctor.Email = item.ItemArray[4].ToString(); if (doctor.Email != "") { if (!ValidationMethods.IsMailValid(doctor.Email)) { flagValid = false; doctor.ValidationErrors = doctor.ValidationErrors + ", " + "Email not valid"; } } doctor.Phone = item.ItemArray[5].ToString(); if (doctor.Phone == "") { flagValid = false; doctor.ValidationErrors = doctor.ValidationErrors + ", " + "Phone empty"; } doctor.LANR = item.ItemArray[6].ToString(); if (doctor.LANR == "") { flagValid = false; doctor.ValidationErrors = doctor.ValidationErrors + ", " + "LANR empty"; } else if (doctor.LANR.Length != 9) { flagValid = false; doctor.ValidationErrors = doctor.ValidationErrors + ", " + "LANR length not valid"; } else if (!ValidationMethods.IsDigitsOnly(doctor.LANR)) { flagValid = false; doctor.ValidationErrors = doctor.ValidationErrors + ", " + "LANR not number"; } else if (!ValidationMethods.LANRValidation(doctor.LANR)) { flagValid = false; doctor.ValidationErrors = doctor.ValidationErrors + ", " + "LANR not valid"; } doctor.BSNR = item.ItemArray[7].ToString(); if (doctors.Count(doc => doc.ItemArray[6] == doctor.LANR && doc.ItemArray[7] == doctor.BSNR) > 1) { flagValid = false; doctor.ValidationErrors = doctor.ValidationErrors + ", " + "LANR already exists in practice: " + item.ItemArray[8].ToString() + ", (BSNR: " + doctor.BSNR + ")"; } if (doctor.BSNR == "") { flagValid = false; doctor.ValidationErrors = doctor.ValidationErrors + ", " + "BSNR empty"; } doctor.PracticeName = item.ItemArray[8].ToString(); if (doctor.PracticeName == "") { flagValid = false; doctor.ValidationErrors = doctor.ValidationErrors + ", " + "Practice name empty"; } var PracticeForDoctor = PracticeData.Where(pr => pr.CompanyInfo_EstablishmentNumber == doctor.BSNR && pr.DisplayName == doctor.PracticeName).SingleOrDefault(); if (PracticeForDoctor == null) { flagValid = false; doctor.ValidationErrors = doctor.ValidationErrors + ", " + "Practice with given name and BSNR do not exists"; } else { doctor.PracticeID = PracticeForDoctor.HEC_MedicalPractiseID; } try { doctor.IsUsePracticeBank = int.Parse(item.ItemArray[9].ToString()) == 1 ? true : false; } catch (Exception ex) { doctor.IsUsePracticeBank = bool.Parse(item.ItemArray[9].ToString()); } doctor.AccountHolder = item.ItemArray[10].ToString(); doctor.Bic = item.ItemArray[11].ToString(); if (doctor.Bic != "") { if (!doctor.IsUsePracticeBank && !ValidationMethods.isValidBic(doctor.Bic)) { flagValid = false; doctor.ValidationErrors = doctor.ValidationErrors + ", " + "Bic invalid"; } } doctor.IBAN = item.ItemArray[12].ToString(); if (doctor.IBAN != "") { IBAN.IbanValidator validateIban = new IbanValidator(); if (doctor.IBAN != "") { try { bool isValidIban = validateIban.ValidateIban(doctor.IBAN); } catch { flagValid = false; doctor.ValidationErrors = doctor.ValidationErrors + ", " + "Iban not valid"; } } } doctor.Bank = item.ItemArray[13].ToString(); if (!doctor.IsUsePracticeBank && doctor.Bic != "" && doctor.Bank == "") { flagValid = false; doctor.ValidationErrors = doctor.ValidationErrors + ", " + "Bic entered, bank empty"; } doctor.LoginEmail = item.ItemArray[14].ToString(); if (doctor.LoginEmail == "") { flagValid = false; doctor.ValidationErrors = doctor.ValidationErrors + ", " + "Login mail empty"; } else if (!ValidationMethods.IsMailValid(doctor.LoginEmail)) { flagValid = false; doctor.ValidationErrors = doctor.ValidationErrors + ", " + "Login mail not valid"; } foreach (var lg in LoginMailUnique) { if (lg == doctor.LoginEmail) { flagValid = false; doctor.ValidationErrors = doctor.ValidationErrors + ", " + "Login email already exists"; } } LoginMailUnique.Add(doctor.LoginEmail); doctor.inPassword = item.ItemArray[15].ToString(); if (doctor.inPassword != "" && !ValidationMethods.isValidPass(doctor.inPassword)) { flagValid = false; doctor.ValidationErrors = doctor.ValidationErrors + ", " + "Password not valid"; } else if (doctor.inPassword == "") { doctor.inPassword = ValidationMethods.CreatePassword(8); } if (doctor.ValidationErrors != "") { doctor.ValidationErrors = doctor.ValidationErrors.Substring(1); } doctor.isValid = flagValid; DoctorL.Add(doctor); } string file = ExportDoctorsBeforeUpload.ExportDoctorBeforeUploadToDB(DoctorL); MemoryStream ms = new MemoryStream(File.ReadAllBytes(file)); Console.WriteLine("----- XLS created."); if (!DoctorL.Any(vl => vl.isValid == false)) { foreach (var doctor in DoctorL) { if (doctor.LoginEmail != "") { doctor.account_id = Create_Accounts.Save_accounts_to_DBPerson(doctor, connectionString, securityTicket); } } foreach (var doctor in DoctorL) { if (doctor.LoginEmail != "") { Save_Doctors.Save_Doctors_to_DB(doctor, connectionString, securityTicket); } } Console.WriteLine("Doctors imported"); } else { Console.WriteLine("Data not valid,won't be saved "); } }
public static void import_Practice_from_xls(string connectionString, SessionSecurityTicket securityTicket) { string folder = Directory.GetParent(Directory.GetCurrentDirectory()).Parent.FullName; string filePath = Path.Combine(folder, "Excel\\practices.xlsx"); bool hasHeader = true; bool flagValid = true; System.Data.DataTable excelData = ExcelUtils.getDataFromExcelFileMM(filePath, hasHeader); try { excelData = ExcelUtils.getDataFromExcelFileMM(filePath, hasHeader); } catch (Exception ex) { filePath = Path.Combine(folder, "Excel\\practices.xls"); } excelData = ExcelUtils.getDataFromExcelFileMM(filePath, hasHeader); List <Practice_Model_from_xlsx> PracticeL = new List <Practice_Model_from_xlsx>(); List <string> BSNRUnique = new List <string>(); List <string> LoginMailUnique = new List <string>(); foreach (System.Data.DataRow item in excelData.Rows) { Practice_Model_from_xlsx practice = new Practice_Model_from_xlsx(); practice.PracticeName = item.ItemArray[0].ToString(); practice.ValidationErrors = ""; if (practice.PracticeName == "") { flagValid = false; practice.ValidationErrors = "Practice name empty"; } practice.BSNR = item.ItemArray[1].ToString(); foreach (var bs in BSNRUnique) { if (bs == practice.BSNR) { flagValid = false; practice.ValidationErrors = practice.ValidationErrors + ", " + "BSNR already exists"; } } BSNRUnique.Add(practice.BSNR); if (practice.BSNR == "") { flagValid = false; practice.ValidationErrors = practice.ValidationErrors + ", " + "BSNR name empty"; } if (!ValidationMethods.IsDigitsOnly(practice.BSNR)) { flagValid = false; practice.ValidationErrors = practice.ValidationErrors + ", " + "BSNR doesn't have only digits"; } if (practice.BSNR.Length != 9) { flagValid = false; practice.ValidationErrors = practice.ValidationErrors + ", " + "BSNR doesn't have 9 digits"; } practice.Street = item.ItemArray[2].ToString(); if (practice.Street == "") { flagValid = false; practice.ValidationErrors = practice.ValidationErrors + ", " + "Street name empty"; } practice.No = item.ItemArray[3].ToString(); if (practice.No == "") { flagValid = false; practice.ValidationErrors = practice.ValidationErrors + ", " + "Street number empty"; } practice.Zip = item.ItemArray[4].ToString(); if (practice.Zip == "") { flagValid = false; practice.ValidationErrors = practice.ValidationErrors + ", " + "ZIP code empty"; } practice.City = item.ItemArray[5].ToString(); if (practice.City == "") { flagValid = false; practice.ValidationErrors = practice.ValidationErrors + ", " + "City name empty"; } practice.MainEmail = item.ItemArray[6].ToString(); if (practice.MainEmail != "") { if (!ValidationMethods.IsMailValid(practice.MainEmail)) { flagValid = false; practice.ValidationErrors = practice.ValidationErrors + ", " + "Main email not valid"; } } practice.MainPhone = item.ItemArray[7].ToString(); //if (practice.MainPhone == "") //{ // flagValid = false; // practice.ValidationErrors = practice.ValidationErrors + ", " + "Main phone empty"; //} practice.Fax = item.ItemArray[8].ToString(); practice.ContactPerson = item.ItemArray[9].ToString(); practice.Email = item.ItemArray[10].ToString(); if (practice.Email != "") { if (!ValidationMethods.IsMailValid(practice.Email)) { flagValid = false; practice.ValidationErrors = practice.ValidationErrors + ", " + "Email not valid"; } } practice.Phone = item.ItemArray[11].ToString(); practice.AccountHolder = item.ItemArray[12].ToString(); practice.Bic = item.ItemArray[13].ToString(); if (!String.IsNullOrEmpty(practice.Bic)) { if (!ValidationMethods.isValidBic(practice.Bic.ToString())) { flagValid = false; practice.ValidationErrors = practice.ValidationErrors + ", " + "BIC not valid"; } } practice.IBAN = item.ItemArray[14].ToString(); practice.Bank = item.ItemArray[15].ToString(); if (practice.Bic != "" && practice.Bank == "") { flagValid = false; practice.ValidationErrors = practice.ValidationErrors + ", " + "Bic not empty but bank is empty"; } practice.LoginEmail = item.ItemArray[16].ToString(); if (practice.LoginEmail == "") { flagValid = false; practice.ValidationErrors = practice.ValidationErrors + ", " + "Login email empty"; } if (!ValidationMethods.IsMailValid(practice.LoginEmail)) { flagValid = false; practice.ValidationErrors = practice.ValidationErrors + ", " + "Login email not valid"; } foreach (var lg in LoginMailUnique) { if (lg == practice.LoginEmail) { flagValid = false; practice.ValidationErrors = practice.ValidationErrors + ", " + "Login email already exists"; } } LoginMailUnique.Add(practice.LoginEmail); practice.inPassword = item.ItemArray[17].ToString(); if (practice.inPassword != "") { if (!ValidationMethods.isValidPass(practice.inPassword)) { flagValid = false; practice.ValidationErrors = practice.ValidationErrors + ", " + "Password not valid"; } } else { practice.inPassword = ValidationMethods.CreatePassword(8); } practice.IsSurgeryPractice = int.Parse(item.ItemArray[18].ToString()) == 1 ? true : false; practice.IsOrderDrugs = int.Parse(item.ItemArray[19].ToString()) == 1 ? true : false; practice.DefaultShippingDateOffset = item.ItemArray[20].ToString(); if (practice.DefaultShippingDateOffset == "") { practice.ValidationErrors = practice.ValidationErrors + ", " + "Default shipping date offset empty"; flagValid = false; } practice.IsOnlyLabelRequired = int.Parse(item.ItemArray[21].ToString()) == 1 ? true : false; practice.isWaiveServiceFee = int.Parse(item.ItemArray[22].ToString()) == 1 ? true : false; practice.isValid = flagValid; if (practice.ValidationErrors != "") { practice.ValidationErrors = practice.ValidationErrors.Substring(1); } PracticeL.Add(practice); } string file = ExportPracticesBeforeUpload.ExportPracticesBeforeUploadToDB(PracticeL); MemoryStream ms = new MemoryStream(File.ReadAllBytes(file)); Console.WriteLine("----- XLS created."); if (!PracticeL.Any(vl => vl.isValid == false)) { foreach (var practice in PracticeL) { if (practice.LoginEmail != "") { Create_Accounts.Save_accounts_to_DBCompany(practice, connectionString, securityTicket); } } foreach (var practice in PracticeL) { if (practice.LoginEmail != "") { Save_practices.Save_practices_to_DB(practice, connectionString, securityTicket); } } Console.WriteLine("Practices imported"); } else { Console.WriteLine("Data invalid, won't be saved!"); } }