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.
171 lines
4.5 KiB
171 lines
4.5 KiB
<?php |
|
namespace frontend\controllers; |
|
|
|
use common\models\LoginForm; |
|
use frontend\models\PasswordResetRequestForm; |
|
use frontend\models\ResetPasswordForm; |
|
use frontend\models\SignupForm; |
|
use frontend\models\ContactForm; |
|
use yii\base\InvalidParamException; |
|
use yii\web\BadRequestHttpException; |
|
use yii\web\Controller; |
|
use Yii; |
|
use yii\web\VerbFilter; |
|
|
|
/** |
|
* Site controller |
|
*/ |
|
class SiteController extends Controller |
|
{ |
|
/** |
|
* @inheritdoc |
|
*/ |
|
public function behaviors() |
|
{ |
|
return [ |
|
'access' => [ |
|
'class' => \yii\web\AccessControl::className(), |
|
'only' => ['logout', 'signup'], |
|
'rules' => [ |
|
[ |
|
'actions' => ['signup'], |
|
'allow' => true, |
|
'roles' => ['?'], |
|
], |
|
[ |
|
'actions' => ['logout'], |
|
'allow' => true, |
|
'roles' => ['@'], |
|
], |
|
], |
|
], |
|
'verbs' => [ |
|
'class' => VerbFilter::className(), |
|
'actions' => [ |
|
'logout' => ['post'], |
|
], |
|
], |
|
]; |
|
} |
|
|
|
/** |
|
* @inheritdoc |
|
*/ |
|
public function actions() |
|
{ |
|
return [ |
|
'error' => [ |
|
'class' => 'yii\web\ErrorAction', |
|
], |
|
'captcha' => [ |
|
'class' => 'yii\captcha\CaptchaAction', |
|
'fixedVerifyCode' => YII_ENV_TEST ? 'testme' : null, |
|
], |
|
]; |
|
} |
|
|
|
public function actionIndex() |
|
{ |
|
return $this->render('index'); |
|
} |
|
|
|
public function actionLogin() |
|
{ |
|
if (!\Yii::$app->user->isGuest) { |
|
return $this->goHome(); |
|
} |
|
|
|
$model = new LoginForm(); |
|
if ($model->load(Yii::$app->request->post()) && $model->login()) { |
|
return $this->goBack(); |
|
} else { |
|
return $this->render('login', [ |
|
'model' => $model, |
|
]); |
|
} |
|
} |
|
|
|
public function actionLogout() |
|
{ |
|
Yii::$app->user->logout(); |
|
|
|
return $this->goHome(); |
|
} |
|
|
|
public function actionContact() |
|
{ |
|
$model = new ContactForm(); |
|
if ($model->load(Yii::$app->request->post()) && $model->validate()) { |
|
if ($model->sendEmail(Yii::$app->params['adminEmail'])) { |
|
Yii::$app->session->setFlash('success', 'Thank you for contacting us. We will respond to you as soon as possible.'); |
|
} else { |
|
Yii::$app->session->setFlash('error', 'There was an error sending email.'); |
|
} |
|
|
|
return $this->refresh(); |
|
} else { |
|
return $this->render('contact', [ |
|
'model' => $model, |
|
]); |
|
} |
|
} |
|
|
|
public function actionAbout() |
|
{ |
|
return $this->render('about'); |
|
} |
|
|
|
public function actionSignup() |
|
{ |
|
$model = new SignupForm(); |
|
if ($model->load(Yii::$app->request->post())) { |
|
$user = $model->signup(); |
|
if ($user) { |
|
if (Yii::$app->getUser()->login($user)) { |
|
return $this->goHome(); |
|
} |
|
} |
|
} |
|
|
|
return $this->render('signup', [ |
|
'model' => $model, |
|
]); |
|
} |
|
|
|
public function actionRequestPasswordReset() |
|
{ |
|
$model = new PasswordResetRequestForm(); |
|
if ($model->load(Yii::$app->request->post()) && $model->validate()) { |
|
if ($model->sendEmail()) { |
|
Yii::$app->getSession()->setFlash('success', 'Check your email for further instructions.'); |
|
|
|
return $this->goHome(); |
|
} else { |
|
Yii::$app->getSession()->setFlash('error', 'Sorry, we are unable to reset password for email provided.'); |
|
} |
|
} |
|
|
|
return $this->render('requestPasswordResetToken', [ |
|
'model' => $model, |
|
]); |
|
} |
|
|
|
public function actionResetPassword($token) |
|
{ |
|
try { |
|
$model = new ResetPasswordForm($token); |
|
} catch (InvalidParamException $e) { |
|
throw new BadRequestHttpException($e->getMessage()); |
|
} |
|
|
|
if ($model->load(Yii::$app->request->post()) && $model->validate() && $model->resetPassword()) { |
|
Yii::$app->getSession()->setFlash('success', 'New password was saved.'); |
|
|
|
return $this->goHome(); |
|
} |
|
|
|
return $this->render('resetPassword', [ |
|
'model' => $model, |
|
]); |
|
} |
|
}
|
|
|