You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
113 lines
2.3 KiB
113 lines
2.3 KiB
<?php |
|
|
|
namespace frontend\controllers; |
|
|
|
use Yii; |
|
use yii\web\Controller; |
|
use common\models\LoginForm; |
|
use frontend\models\ContactForm; |
|
use common\models\User; |
|
use yii\web\HttpException; |
|
use frontend\models\SendPasswordResetTokenForm; |
|
|
|
class SiteController extends Controller |
|
{ |
|
public function actions() |
|
{ |
|
return array( |
|
'captcha' => array( |
|
'class' => 'yii\web\CaptchaAction', |
|
), |
|
); |
|
} |
|
|
|
public function actionIndex() |
|
{ |
|
return $this->render('index'); |
|
} |
|
|
|
public function actionLogin() |
|
{ |
|
$model = new LoginForm(); |
|
if ($model->load($_POST) && $model->login()) { |
|
return $this->redirect(array('site/index')); |
|
} else { |
|
return $this->render('login', array( |
|
'model' => $model, |
|
)); |
|
} |
|
} |
|
|
|
public function actionLogout() |
|
{ |
|
Yii::$app->user->logout(); |
|
return $this->redirect(array('site/index')); |
|
} |
|
|
|
public function actionContact() |
|
{ |
|
$model = new ContactForm; |
|
if ($model->load($_POST) && $model->contact(Yii::$app->params['adminEmail'])) { |
|
Yii::$app->session->setFlash('contactFormSubmitted'); |
|
return $this->refresh(); |
|
} else { |
|
return $this->render('contact', array( |
|
'model' => $model, |
|
)); |
|
} |
|
} |
|
|
|
public function actionAbout() |
|
{ |
|
return $this->render('about'); |
|
} |
|
|
|
public function actionSignup() |
|
{ |
|
$model = new User(); |
|
$model->setScenario('signup'); |
|
if ($model->load($_POST) && $model->save()) { |
|
if (Yii::$app->getUser()->login($model)) { |
|
$this->redirect('index'); |
|
} |
|
} |
|
|
|
return $this->render('signup', array( |
|
'model' => $model, |
|
)); |
|
} |
|
|
|
public function actionResetPassword($token = null) |
|
{ |
|
if ($token) { |
|
$model = User::find(array( |
|
'password_reset_token' => $token, |
|
'status' => User::STATUS_ACTIVE, |
|
)); |
|
|
|
if (!$model) { |
|
throw new HttpException(400, 'Wrong password reset token.'); |
|
} |
|
|
|
$model->scenario = 'resetPassword'; |
|
if ($model->load($_POST) && $model->save()) { |
|
// TODO: confirm that password was successfully saved |
|
$this->redirect('index'); |
|
} |
|
|
|
$this->render('resetPassword', array( |
|
'model' => $model, |
|
)); |
|
} |
|
else { |
|
$model = new SendPasswordResetTokenForm(); |
|
if ($model->load($_POST) && $model->sendEmail()) { |
|
// TODO: confirm that password reset token was sent |
|
$this->redirect('index'); |
|
} |
|
$this->render('sendPasswordResetTokenForm', array( |
|
'model' => $model, |
|
)); |
|
} |
|
} |
|
}
|
|
|