[ 'class' => AccessControl::className(), 'only' => ['logout', 'signup'], 'rules' => [ [ 'actions' => ['signup'], 'allow' => true, 'roles' => ['?'], ], [ 'actions' => ['logout'], 'allow' => true, 'roles' => ['@'], ], ], ], 'verbs' => [ 'class' => VerbFilter::className(), 'actions' => [ 'logout' => ['get'], ], ], ]; } /** * @inheritdoc */ public function actions() { return [ 'captcha' => [ 'class' => 'yii\captcha\CaptchaAction', 'fixedVerifyCode' => YII_ENV_TEST ? 'testme' : null, ], ]; } /** * Affiche la page d'erreur. * * @return mixed */ public function actionError() { $exception = Yii::$app->errorHandler->exception; if($exception->getMessage() == 'Établissement introuvable' || Yii::$app->getRequest()->getQueryParam('producer_not_found')) { return $this->render('error-404-producer', ['exception' => $exception]); } if ($exception !== null) { return $this->render('error', ['exception' => $exception]); } } /** * Affiche la page d'accueil. * * @return mixed */ public function actionIndex() { return $this->render('index'); } /** * Liste les producteurs utilisant la plateforme. * * @return mixed */ public function actionProducers() { $data_provider_producers = new ActiveDataProvider([ 'query' => Etablissement::find() ->where([ 'actif' => true, ]) ->orderBy('nom ASC'), 'pagination' => [ 'pageSize' => 100, ], ]); return $this->render('producers',[ 'data_provider_producers' => $data_provider_producers ]); } /** * Affiche les mentions légales. * * @return mixed */ public function actionMentions() { return $this->render('mentions'); } /** * Affiche la page de connexion et traite le formulaire de connexion. * * @return mixed */ public function actionLogin() { if (!\Yii::$app->user->isGuest) { return Yii::$app->getResponse()->redirect(['commande/index']); } $model = new LoginForm(); if ($model->load(Yii::$app->request->post()) && $model->login()) { $return_url = Yii::$app->request->get('return_url'); if($return_url){ return $this->redirect($return_url); } else { return $this->goBack(); } } else { return $this->render('@frontend/views/site/login', [ 'model' => $model, ]); } } /** * Déconnecte l'utilisateur. * * @return mixed */ public function actionLogout() { Yii::$app->user->logout(); return $this->goHome(); } /** * Affiche la page de contact et traite le formulaire s'il est soumis. * * @return mixed */ 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', 'Votre message a bien été envoyé. Nous vous répondrons dès que possible.'); } else { Yii::$app->session->setFlash('error', 'Il y a eu une erreur lors de l\'envoi de votre message.'); } return $this->refresh(); } else { return $this->render('contact', [ 'model' => $model, ]); } } /** * Affiche la page d'inscription et traite son formulaire. * * @return mixed */ public function actionSignup() { $model = new SignupForm(); if ($model->load(Yii::$app->request->post())) { if ($user = $model->signup()) { if (Yii::$app->getUser()->login($user)) { $this->redirect(['commande/index']); } } } // liste des établissements disponibles $etablissements = Etablissement::getEtablissementsPopulateDropdown(); $data_etablissements_dispos = $etablissements['data']; $options_etablissements_dispos = $etablissements['options']; return $this->render('signup', [ 'model' => $model, 'data_etablissements_dispos' => $data_etablissements_dispos, 'options_etablissements_dispos' => $options_etablissements_dispos, ]); } /** * Affiche la page de demande de nouveau mot de passe. * Traitement du formulaire. * * @return mixed */ public function actionRequestPasswordReset() { $model = new PasswordResetRequestForm(); if ($model->load(Yii::$app->request->post()) && $model->validate()) { if ($model->sendEmail()) { Yii::$app->getSession()->setFlash('success', 'Un lien vous permettant de réinitialiser votre mot de passe vient d\'être envoyé sur votre boîte mail.'); 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, ]); } /** * Met à jour le mot de passe de l'utilisateur. * * @param string $token * @return mixed * @throws BadRequestHttpException */ 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', 'Votre nouveau mot de passe vient d\'être sauvegardé.'); return $this->goHome(); } return $this->render('resetPassword', [ 'model' => $model, ]); } /** * Affiche les conditions générale de service. * * @return mixed */ public function actionCgv() { return $this->render('cgv'); } /** * Affiche les précisions concernant l'utilisation du crédit pain. * @return type */ public function actionCreditpain() { return $this->render('creditpain'); } /** * Affiche le formulaire de demande de code pour accéder à certains * producteurs. * * @param integer $id * @return mixed * @throws \yii\web\HttpException */ public function actionProducerCode($id) { $producer = Etablissement::findOne($id); if(!$producer) throw new \yii\web\HttpException(404, 'Établissement introuvable'); $model_producer_code = new ProducerCodeForm ; $model_producer_code->id_producer = $id ; if($model_producer_code->load(Yii::$app->request->post()) && $model_producer_code->validate()) { Etablissement::addUser(Yii::$app->user->id, $id) ; $this->redirect(Yii::$app->urlManagerProducer->createAbsoluteUrl(['site/index','slug_producer' => $producer->slug])); } return $this->render('producer_code',[ 'producer' => $producer, 'model_producer_code' => $model_producer_code, ]) ; } /** * Affiche la page de connexion / inscription pour accéder notamment au * formulaire de commande des producteirs. * * @param integer $id * @return mixed */ public function actionProducer($id) { $model_login = new LoginForm(); $model_signup = new SignupForm(); $etablissement = Etablissement::findOne($id); $model_login->id_etablissement = $id; $model_signup->id_etablissement = $id; $model_signup->option_client_boulanger = 'client'; $return_url = Yii::$app->request->get('return_url', Yii::$app->urlManagerProducer->createAbsoluteUrl(['site/index','slug_producer' => $etablissement->slug])); if (Yii::$app->user->isGuest) { if ($model_login->load(Yii::$app->request->post()) && $model_login->login()) { Etablissement::addUser(Yii::$app->user->id, $id) ; $this->redirect($return_url); } if ($model_signup->load(Yii::$app->request->post())) { if ($user = $model_signup->signup()) { if (Yii::$app->getUser()->login($user)) { $this->redirect($return_url); } } } } else { $this->redirect($return_url); } return $this->render('producer', [ 'model_login' => $model_login, 'model_signup' => $model_signup, 'etablissement' => $etablissement, ]); } }