Beispiel #1
0
        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();
        }
Beispiel #2
0
        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;
            }
        }
Beispiel #3
0
        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;
            }
        }
Beispiel #4
0
        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();
        }