Beispiel #1
0
        private void OpenAuthPage(object sender, RoutedEventArgs e)
        {
            AuthPage authPage = new AuthPage();

            this.Visibility = Visibility.Hidden; //Скрывает текущее окно
            authPage.Show();
        }
Beispiel #2
0
        private void DisconnectButton_Click(object sender, RoutedEventArgs e)
        {
            File.Delete(@"Token.json");
            AuthPage authPage = new AuthPage();

            this.Visibility = Visibility.Hidden; //Скрывает текущее окно
            authPage.Show();
        }
Beispiel #3
0
        private void RegButton_Clicked(object sender, RoutedEventArgs e)
        {
            string _name        = textboxName.Text.Trim();            //Trim() - Удаление лишних символов
            string _Email       = textboxEmail.Text.Trim().ToLower(); //ToLower() - Перевод всех символов строки в нижний регистр
            string _password1   = passwordbox_1.Password.Trim();
            string _password2   = passwordbox_2.Password.Trim();
            bool   nameCorrect  = false;
            bool   emailCorrect = false;
            bool   ispassEqual  = false;

            //Логика регистрации
            if (_name.Length < 3)
            {
                textboxName.ToolTip     = "Имя слишком короткое.\n(Минимальная длина - 3 символа)";
                textboxName.BorderBrush = Brushes.Red;
            }
            else //Имя верно
            {
                textboxName.ToolTip     = _name;
                textboxName.BorderBrush = Brushes.Gray;
                nameCorrect             = true;
            }
            if (_Email.Length < 5)
            {
                textboxEmail.ToolTip     = "Логин слишком короткий.\n(Минимальная длина - 5 символов)";
                textboxEmail.BorderBrush = Brushes.Red;
            }
            else if (!_Email.Contains("@") || (!_Email.Contains(".")))
            {
                textboxEmail.ToolTip     = "Введены некорректные данные.\n(Возможно отсутствует символ \"@\" или символ \".\")";
                textboxEmail.BorderBrush = Brushes.Red;
            }
            else //Почта верна
            {
                textboxEmail.ToolTip     = _Email;
                textboxEmail.BorderBrush = Brushes.Gray;
                emailCorrect             = true;
            }
            if (_password1 != _password2 || (_password1 == "" && _password2 == ""))
            {
                passwordbox_1.ToolTip     = "Пароли не совпадают.";
                passwordbox_1.BorderBrush = Brushes.Red;
                passwordbox_2.ToolTip     = "Пароли не совпадают.";
                passwordbox_2.BorderBrush = Brushes.Red;
            }
            else if (_password1.Length < 8 || _password2.Length < 8)
            {
                passwordbox_1.ToolTip     = "Пароль слишком короткий.\nМинимальная длина пароля - 8 символов.";
                passwordbox_1.BorderBrush = Brushes.Red;
                passwordbox_2.ToolTip     = "Пароль слишком короткий.\nМинимальная длина пароля - 8 символов.";
                passwordbox_2.BorderBrush = Brushes.Red;
            }
            else //Пароли совпадают
            {
                passwordbox_1.ToolTip     = "Пароли совпадают";
                passwordbox_1.BorderBrush = Brushes.Gray;
                passwordbox_2.ToolTip     = "Пароли совпадают";
                passwordbox_2.BorderBrush = Brushes.Gray;
                ispassEqual = true;
            }
            if (nameCorrect == true && emailCorrect == true && ispassEqual == true)
            {
                if (MessageBox.Show(this, "Создать аккаунт с этими данными?\n\nИмя - " + textboxName.Text + "\nEmail - " + textboxEmail.Text, "Подтверждение", MessageBoxButton.YesNo) != MessageBoxResult.Yes)
                {
                    //pass
                }
                else
                {
                    try
                    {
                        var client = new RestClient("http://testingwebrtc.herokuapp.com/signup");
                        client.Timeout = -1;
                        var request = new RestRequest(Method.POST);
                        request.AddHeader("Content-Type", "application/x-www-form-urlencoded");
                        request.AddParameter("nickname", _name.ToString());
                        request.AddParameter("email", _Email.ToString());
                        request.AddParameter("password", _password1.ToString());
                        IRestResponse response = client.Execute(request);

                        string responseData = response.Content.ToString();

                        JSONauth tempUser = JsonConvert.DeserializeObject <JSONauth>(responseData);

                        UserInfo.Email = tempUser.Data.Email;
                        //UserInfo.ID = tempUser.ID;
                        UserInfo.Role  = tempUser.Data.Role;
                        UserInfo.Token = tempUser.Token;
                        MessageBox.Show("Регистрация прошла успешно", "Выполнено", MessageBoxButton.OK, MessageBoxImage.Information);
                        AuthPage authPage = new AuthPage();
                        this.Visibility = Visibility.Hidden; //Скрывает текущее окно
                        authPage.Show();
                    }
                    catch
                    {
                        textboxEmail.ToolTip     = "Пользователь с таким E-Mail-ом уже существует";
                        textboxEmail.BorderBrush = Brushes.Red;
                        //MessageBox.Show("Возможно пользователь с таким E-Mail-ом уже существует", "Что-то пошло не так", MessageBoxButton.OK, MessageBoxImage.Information);
                    }
                }
            }
        }