public static function createUser()
 {
     $params = $_POST;
     $sign_up_form = new SignUpForm(array('first_name' => $params['first_name'], 'last_name' => $params['last_name'], 'email' => $params['email'], 'password' => $params['password'], 'password_confirmation' => $params['password_confirmation']));
     if ($sign_up_form->validate()) {
         $user = new User((array) $sign_up_form);
         $user->save();
         $_SESSION['user'] = $user->id;
         Redirect::to('/units', array('message' => 'Welcome ' . $user->first_name . "!"));
     } else {
         $errors = array_values($sign_up_form->errors());
         Redirect::to('/', array('errors' => $errors, 'input' => $params));
     }
 }
예제 #2
0
 public function actionSignup()
 {
     $model = new SignUpForm();
     if (isset($_POST['SignUpForm'])) {
         $model->attributes = $_POST['SignUpForm'];
         if ($model->validate()) {
             $user = new FrontendUser();
             $user->username = $model->email;
             $user->email = $model->email;
             $user->password = $model->password;
             $isExist = FrontendUser::model()->find(array('condition' => 'email = :email OR username = :username', 'params' => array(':email' => $user->email, ':username' => $user->email)));
             if ($isExist) {
                 echo json_encode(array('status' => 'error', 'error' => 'Пользователь с указанным e-mail уже зарегистрирован на сайте'));
             } elseif ($user->save()) {
                 EmailManager::sendUserInfo($user, $model->password);
                 echo '{"status" : "ok"}';
             } else {
                 echo json_encode(array('status' => 'error', 'error' => CHtml::errorSummary($user)));
             }
         } else {
             echo json_encode(array('status' => 'error', 'error' => CHtml::errorSummary($model)));
         }
     }
 }