Ejemplo n.º 1
0
        private void LoginButton_Click(object sender, EventArgs e)
        {
            //Hash password input so the raw password isn't stored in the database
            var hashPassword = StaticAccessor.HashString(Password);

            var User = StaticAccessor.DB.GetUser(0, Username);

            //Check User exists in db and compare hashed passwords
            if (User.Username == null || !User.Password.Equals(hashPassword))
            {
                UserFound = false;
            }
            else
            {
                UserFound = true;
            }
            if (UserFound)
            {
                Interceptor interceptor = new ConcreteLoginInterceptor();
                var         dispatcher  = new Dispatcher();
                dispatcher.RegisterInterceptor(interceptor);
                if (User.SystemAdmin)
                {
                    Hide();
                    var SAA = new SysAdminAuthentication(User.Id);
                    SAA.ShowDialog();
                }
                else
                {
                    if (User.RestaurantAdmin && User.RestaurantId == 0)
                    {
                        MessageBox.Show("Login Failed");
                        ErrorMessageLabel.Text    = "Error Message: Admin not assigned to a restaurant";
                        ErrorMessageLabel.Visible = true;
                        PasswordTextbox.Text      = "";
                    }
                    else
                    {
                        dispatcher.DispatchLoginInterceptor(interceptor, this);
                        Hide();
                        User.login();
                    }
                }
            }
            else
            {
                MessageBox.Show("Login Failed");
                ErrorMessageLabel.Text    = "Error Message: Incorrect Username or Password";
                ErrorMessageLabel.Visible = true;
                PasswordTextbox.Text      = "";
            }
        }
        private void SaveChangesButton_Click(object sender, EventArgs e)
        {
            if (CorrectEmailFormat && CorrectNameFormat && CorrectUsernameFormat &&
                CorrectPasswordFormat /* && CorrectRestaurantFormat*/)
            {
                //Hash password input so the raw password isn't stored in the database
                var hashPassword = StaticAccessor.HashString(Password);

                if (newAccount)
                {
                    var user = new UserFactory().GetUser(0, Username, hashPassword, FirstName, LastName, Email,
                                                         Membership,
                                                         "User");
                    StaticAccessor.DB.InsertUser(user);
                    MessageBox.Show(@"Account Created");
                    Hide();
                    new LoginMenuV2();
                }
                else
                {
                    var user = StaticAccessor.DB.GetUser(UserId);
                    user.FirstName  = FirstName;
                    user.LastName   = LastName;
                    user.Username   = Username;
                    user.Password   = hashPassword;
                    user.Email      = Email;
                    user.Membership = Membership;
                    StaticAccessor.DB.UpdateUser(user);
                    MessageBox.Show(@"Changes Saved");
                    Hide();
                    var UMM = new UserMainMenu(UserId);
                    UMM.ShowDialog();
                }
            }
            else
            {
                ErrorMessageLabel.Text    = "Error Message: Please Fix Any Issues with your details";
                ErrorMessageLabel.Visible = true;
            }
        }
Ejemplo n.º 3
0
        private void SaveChangesButton_Click(object sender, EventArgs e)
        {
            if (CorrectEmailFormat && CorrectNameFormat && CorrectUsernameFormat &&
                CorrectPasswordFormat /* && CorrectRestaurantFormat*/)
            {
                var UsernameExists = false;
                var EmailExists    = false;
                //Boolean RestaurantExists = false;
                var Admin  = StaticAccessor.DB.GetUser(0, AdminUsername);
                var Admin2 = StaticAccessor.DB.GetUser(0, "", AdminEmail);
                //Restaurant.Restaurant Rest = DatabaseHandler.GetRestaurant(AdminRestaurant);

                if (newAdmin)
                {
                    if (Admin.Username == null)
                    {
                    }
                    else
                    {
                        UsernameExists = true;
                        ErrorMessage   = "Error: Username Already Exists.";
                    }
                    if (Admin2.Username == null)
                    {
                    }
                    else
                    {
                        EmailExists  = true;
                        ErrorMessage = "Error: Email Already Exists.";
                    }
                }

                if (!UsernameExists && !EmailExists)
                {
                    //check if admin already exists
                    var RestaurantAdminExists = StaticAccessor.DB.GetUser(0, "", "", 0, AdminRestaurant);
                    //AbstractUser IsCurrentAdmin = DatabaseHandler.CheckIfAdmin(AdminUsername);
                    var CurrentAdmin = StaticAccessor.DB.GetUser(0, AdminUsername);

                    //Hash password input so the raw password isn't stored in the database
                    string hashPassword;
                    if (sysAdmin && !newAdmin)
                    {
                        hashPassword = StaticAccessor.DB.GetUser(CurrentAdmin.Id).Password;
                    }
                    else
                    {
                        hashPassword = StaticAccessor.HashString(AdminPassword);
                    }

                    if (RestaurantAdminExists.Username == null)
                    {
                        if (newAdmin)
                        {
                            var restaurantId = StaticAccessor.DB.GetRestaurant(0, AdminRestaurant).Id;
                            var user         = new UserFactory().GetUser(CurrentAdmin.Id, AdminUsername, hashPassword,
                                                                         AdminFirstName, AdminLastName, AdminEmail, 0, "RestAdmin", restaurantId, true);
                            StaticAccessor.DB.InsertUser(user);
                            MessageBox.Show("New Admin Created");

                            Hide();
                            var SAAM = new SysAdminAdminsMenu(AdminId);
                            SAAM.ShowDialog();
                        }
                    }
                    else
                    {
                        if (CurrentAdmin.RestaurantAdmin) //admin of that restaurant
                        {
                            var restaurantId = StaticAccessor.DB.GetRestaurant(0, AdminRestaurant).Id;
                            var user         = new UserFactory().GetUser(CurrentAdmin.Id, AdminUsername, hashPassword,
                                                                         AdminFirstName, AdminLastName, AdminEmail, 0, "RestAdmin", restaurantId, true);
                            StaticAccessor.DB.UpdateUser(user);
                            MessageBox.Show("Admin Details Updated");

                            if (sysAdmin)
                            {
                                Hide();
                                var SAAM = new SysAdminAdminsMenu(AdminId);
                                SAAM.ShowDialog();
                            }
                            else
                            {
                                Hide();
                                var RAM = new RestAdminMainMenu(AdminId, RestaurantId);
                                RAM.ShowDialog();
                            }
                            MessageBox.Show("Admin Details Updated");

                            if (sysAdmin)
                            {
                                Hide();
                                var SAAM = new SysAdminAdminsMenu(AdminId);
                                SAAM.ShowDialog();
                            }
                            else
                            {
                                Hide();
                                var RAM = new RestAdminMainMenu(AdminId, RestaurantId);
                                RAM.ShowDialog();
                            }
                        }
                        else
                        {
                            UsernameExists = true;
                            MessageBox.Show("Error: An Admin Already exists for that restaurant");
                        }
                    }
                }
                else
                {
                    ErrorMessageLabel.Visible = true;
                    ErrorMessageLabel.Text    = "Error Message: " + ErrorMessage;
                }
            }
            else
            {
                ErrorMessageLabel.Text    = "Error Message: Please Fix Any Issues with the Admin's details";
                ErrorMessageLabel.Visible = true;
            }
        }