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.
		
		
		
		
		
			
		
			
				
					
					
						
							145 lines
						
					
					
						
							3.3 KiB
						
					
					
				
			
		
		
	
	
							145 lines
						
					
					
						
							3.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; | |
|  | |
| 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('success', 'Thank you for contacting us. We will respond to you as soon as possible.'); | |
| 			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 actionRequestPasswordReset() | |
| 	{ | |
| 		$model = new User(); | |
| 		$model->scenario = 'requestPasswordResetToken'; | |
| 		if ($model->load($_POST) && $model->validate()) { | |
| 			if ($this->sendPasswordResetEmail($email)) { | |
| 				Yii::$app->getSession()->setFlash('success', 'Check your email for further instructions.'); | |
| 				$this->redirect('index'); | |
| 			} else { | |
| 				Yii::$app->getSession()->setFlash('error', 'There was an error sending email.'); | |
| 			} | |
| 		} | |
| 		$this->render('requestPasswordResetToken', array( | |
| 			'model' => $model, | |
| 		)); | |
| 	} | |
|  | |
| 	public function actionResetPassword($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()) { | |
| 			Yii::$app->getSession()->setFlash('success', 'New password was saved.'); | |
| 			$this->redirect('index'); | |
| 		} | |
|  | |
| 		$this->render('resetPassword', array( | |
| 			'model' => $model, | |
| 		)); | |
| 	} | |
|  | |
| 	private function sendPasswordResetEmail($email) | |
| 	{ | |
| 		$user = User::find(array( | |
| 			'status' => User::STATUS_ACTIVE, | |
| 			'email' => $email, | |
| 		)); | |
|  | |
| 		if (!$user) { | |
| 			return false; | |
| 		} | |
|  | |
| 		$user->password_reset_token = Security::generateRandomKey(); | |
| 		if ($user->save(false)) { | |
| 			$fromEmail = \Yii::$app->params['supportEmail']; | |
| 			$name = '=?UTF-8?B?' . base64_encode(\Yii::$app->name . ' robot') . '?='; | |
| 			$subject = '=?UTF-8?B?' . base64_encode('Password reset for ' . \Yii::$app->name) . '?='; | |
| 			$body = $this->renderPartial('/emails/passwordResetToken', array( | |
| 				'user' => $this, | |
| 			)); | |
| 			$headers = "From: $name <{$fromEmail}>\r\n" . | |
| 				"MIME-Version: 1.0\r\n" . | |
| 				"Content-type: text/plain; charset=UTF-8"; | |
| 			return mail($fromEmail, $subject, $body, $headers); | |
| 		} | |
|  | |
| 		return false; | |
| 	} | |
| }
 | |
| 
 |