public void OnSavePassChangesButtonClick() { if (view.OldPassTextBoxText == string.Empty || view.NewPassTextBoxText == string.Empty || view.NewPassAgainTextBoxText == string.Empty) { view.Message("Моля, попълнате всички полета.", "Внимание", Views.MessageIcon.Warning); return; } Utilities.IPasswordHash passHasher = new Utilities.PasswordHash(); if (!passHasher.Verify(view.OldPassTextBoxText, user.Password)) { view.Message("Въвели сте грешна парола. Моля, опитайте отново.", "Внимание", Views.MessageIcon.Warning); return; } if (view.NewPassAgainTextBoxText != view.NewPassTextBoxText) { view.Message("Новата парола се различава от нейното потвърждение. Моля, опитайте отново.", "Внимание", Views.MessageIcon.Warning); return; } if (view.NewPassTextBoxText == view.OldPassTextBoxText) { view.Message("Новата парола не може да е същата като старата. Моля, опитайте отново.", "Внимание", Views.MessageIcon.Warning); return; } if (!Regex.IsMatch(view.NewPassTextBoxText, @"^.{8,25}$")) { view.Message("Новата парола трябва да е с дължина между 8 и 25 символа.", "Внимание", Views.MessageIcon.Warning); return; } user.Password = passHasher.Generate(view.NewPassAgainTextBoxText); try { data.SaveChanges(); view.Message("Паролата беше променена успешно.", "Успех", Views.MessageIcon.Information); } catch (Exception) { view.Message("В момента изпитваме технически затруднения. Възможно е вашите промени да не са запазени. Моля, опитайте отново по-късно. Съжаляваме за причененото неудобство.", "Грешка", Views.MessageIcon.Error); } view.DisplayMainScreen(); }
public void OnLoginButtonClick() { // Check if the user input is valid, display info if not. if (view.Username == string.Empty) { view.Message("Моля, въведете вашето потребителско име.", "Внимание", Views.MessageIcon.Warning); return; } if (view.Pass == string.Empty) { view.Message("Моля, въведете вашата парола.", "Внимание", Views.MessageIcon.Warning); return; } // Check if the username is in the database Model.IUser currentUser = null; //string typeOfUser = view.TypeOfUser; try { currentUser = (data.Teachers.Where(x => x.username == view.Username).SingleOrDefault() as Model.IUser) ?? (data.Parents.Where(x => x.username == view.Username).SingleOrDefault() as Model.IUser) ?? data.Admins.Where(x => x.admin_username == view.Username).SingleOrDefault(); } catch (System.Data.Entity.Core.EntityException) { view.Message("Неуспешна връзка с базата данни. Моля, опитайте отново по-късно. Съжаляваме за причиненото неудобство.", "Грешка", Views.MessageIcon.Error); return; } // Display error message if there is no such user. if (currentUser == null) { view.Message("Грешно потребителско име и/или парола. Моля, опитайте отново. Ако продължавате да изпитвате затруднения, свържете се с училищния администратор.", "Грешка", Views.MessageIcon.Error); return; } // Instantiate a new password hashing/checking class and use it to check if the user password is correct. Utilities.IPasswordHash passHashChecker = new Utilities.PasswordHash(); var isPasswordCorrect = passHashChecker.Verify(view.Pass, currentUser.Password); // Disaply error if password is not correct if (!isPasswordCorrect) { view.Message("Грешно потребителско име и/или парола. Моля, опитайте отново.", "Грешка", Views.MessageIcon.Error); return; } // If everything is fine, hide this view and start the appropriate one. (Not implemented) view.Hide(); //view.Close(); switch (currentUser.UserType) { case Model.UserType.Teacher: Views.ITeacherView teacherView = view.CreateTeacherView(); ITeacherPresenter teacherPresenter = PresenterFactory.GetTeacherPresenter(teacherView, data, currentUser, this); teacherPresenter.Start(); break; case Model.UserType.Parent: Views.IParentView parentView = view.CreateParentView(); IParentPresenter parentPresenter = PresenterFactory.GetParentPresenter(parentView, data, currentUser, this); parentPresenter.Start(); break; case Model.UserType.Admin: Views.IAdminView adminView = view.CreateAdminView(); IAdminPresenter adminPresenter = PresenterFactory.GetAdminPresenter(adminView, data, currentUser, this); adminPresenter.Start(); break; } }
public void OnSaveClick() { string typeOfProfile = view.typeOfProfile; var regexString = new Regex("^[А-я]+$"); var regexInt = new Regex("^[0-9]+$"); var regexPassword = new Regex("^.{8,25}$"); var regexUserName = new Regex("^[A-Za-z0-9_]+$"); Random random = new Random(); int randomNum = random.Next(); switch (typeOfProfile) { case "Учител": if (view.UserNameTextBox != string.Empty && view.TextBoxSubject != string.Empty && view.FirstNTextBox != string.Empty && view.LastNTextBox != string.Empty && view.Password != string.Empty && regexString.IsMatch(view.FirstNTextBox) && regexString.IsMatch(view.LastNTextBox) && regexString.IsMatch(view.TextBoxSubject) && regexUserName.IsMatch(view.UserNameTextBox)) { var existingTeacher = data.Teachers.Where(x => x.username == view.UserNameTextBox).SingleOrDefault(); if (existingTeacher != null) { view.Message("Това потребителско име вече е заето. Моля, изберете друго.", "Внимание", Views.MessageIcon.Warning); return; } if (!regexPassword.IsMatch(view.Password)) { view.Message("Паролата трябва да е с дължина между 8 и 25 символа.", "Внимание", Views.MessageIcon.Warning); return; } Utilities.IPasswordHash passHasher = new Utilities.PasswordHash(); var passHash = passHasher.Generate(view.PasswordTextBox.ToString()); var teacher = new Model.Teacher() { username = view.UserNameTextBox, teacher_firstN = view.FirstNTextBox, teacher_lastN = view.LastNTextBox, password_hash = passHash }; data.Teachers.Add(teacher); var teacherid = teacher.teacher_id; var subject = new Model.Subject() { subject_name = view.TextBoxSubject, teacher_id = teacherid }; data.Subjects.Add(subject); } else { view.Message("Моля попълнете всички полета коректно.", "Грешка", Views.MessageIcon.Error); return; } break; case "Ученик": if (view.ComboBoxGrade != null && view.FirstNTextBox != string.Empty && view.LastNTextBox != string.Empty && view.PINTextBox != string.Empty && regexInt.IsMatch(view.PINTextBox) && regexString.IsMatch(view.FirstNTextBox) && regexString.IsMatch(view.LastNTextBox)) { var student = new Model.Student() { student_firstN = view.FirstNTextBox, student_lastN = view.LastNTextBox, grade = view.ComboBoxGrade, student_PIN = view.PINTextBox, code = randomNum.ToString() }; data.Students.Add(student); } else { view.Message("Моля попълнете всички полета коректно.", "Грешка", Views.MessageIcon.Error); return; } break; } try { data.SaveChanges(); if (typeOfProfile == "Учител") { view.Message("Успешно направен профил на учител!", "Успех", Views.MessageIcon.Information); } else { view.Message(String.Format("Успешно направен профил на ученик с код: {0}", randomNum.ToString()), "Успех", Views.MessageIcon.Information); string path = "StudentsProfiles.txt"; string studentInfo = String.Concat(view.PINTextBox + " ", view.FirstNTextBox + " ", view.LastNTextBox + " ", randomNum.ToString(), "\n"); File.AppendAllText(path, studentInfo); } view.ClearText(); } catch (Exception) { view.Message("В момента изпитваме технически затруднения. Възможно е вашите промени да не са запазени. Моля, опитайте отново по-късно. Съжаляваме за причененото неудобство.", "Грешка", Views.MessageIcon.Error); return; } }
public void OnCreateButtonClick() { if (view.Username == string.Empty) { view.Message("Моля, въведете потребителско име.", "Внимание", Views.MessageIcon.Warning); return; } if (view.Pass == string.Empty) { view.Message("Моля, въведете парола.", "Внимание", Views.MessageIcon.Warning); return; } if (view.FirstName == string.Empty || view.Surname == string.Empty) { view.Message("Моля, въведете вашето лично име и фамилия.", "Внимание", Views.MessageIcon.Warning); return; } if (!Regex.IsMatch(view.FirstName, @"^[А-я]+$") || !Regex.IsMatch(view.Surname, @"^[А-я]+$")) { view.Message("Моля, използвайте само букви от българската азбука за вашето собствено име и фамилия.", "Внимание", Views.MessageIcon.Warning); return; } if (!Regex.IsMatch(view.Username, @"^[A-Za-z0-9_]+$")) { view.Message("Моля, въведете валидно потребтилеско име (разрешени са буквите от английската азбука, цифрите 0-9 и долна черта).", "Внимание", Views.MessageIcon.Warning); return; } var existingParent = data.Parents.Where(x => x.username == view.Username).SingleOrDefault(); var existingTeacher = data.Teachers.Where(x => x.username == view.Username).SingleOrDefault(); var existingAdmin = data.Admins.Where(x => x.admin_username == view.Username).SingleOrDefault(); if (existingParent != null || existingTeacher != null || existingAdmin != null) { view.Message("Това потребителско име вече е заето. Моля, изберете друго.", "Внимание", Views.MessageIcon.Warning); return; } if (!Regex.IsMatch(view.Pass, @"^.{8,25}$")) { view.Message("Моля, въведете парола с дължина между 8 и 25 символа.", "Внимание", Views.MessageIcon.Warning); return; } Utilities.IPasswordHash passHasher = new Utilities.PasswordHash(); var passHash = passHasher.Generate(view.Pass); var newParent = new Model.Parent() { parent_firstN = view.FirstName, parent_lastN = view.Surname, username = view.Username, password_hash = passHash }; data.Parents.Add(newParent); try { data.SaveChanges(); } catch (Exception) { view.Message("В момента изпитваме технически затруднения. Моля, опитайте отново по-късно. Съжаляваме за причененото неудобство.", "Грешка", Views.MessageIcon.Error); return; } view.Message("Вашият профил беше създаден успешно. Можете да го използвате.", "Успех", Views.MessageIcon.Information); view.Close(); loginPresenter.ShowLoginView(); }