[ '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 [ 'error' => [ 'class' => 'yii\web\ErrorAction', ], 'captcha' => [ 'class' => 'yii\captcha\CaptchaAction', 'fixedVerifyCode' => YII_ENV_TEST ? 'testme' : null, ], ]; } public function actionIndex() { // redirection de l'utilisateur vers le tableau de bord s'il est connecté if (!Yii::$app->user->isGuest) { return $this->redirect(['commande/index']); } // produits $produits = Produit::find()->orderBy('order ASC')->all(); // contact $model = new ContactForm(); if ($model->load(Yii::$app->request->post()) && $model->validate()) { if ($model->sendEmail('matthieu@lechatdesnoisettes.com')) { Yii::$app->session->setFlash('success', "Votre message a bien été envoyé, j'y répondrai dès que possible."); } else { Yii::$app->session->setFlash('error', 'There was an error sending email.'); } return $this->refresh(); } // map $center = new LatLng(['lat' => '46,9991224', 'lng' => '6,0582595']); $tileLayer = new TileLayer([ 'map' => 'test1', 'urlTemplate' => 'http://{s}.tile.osm.org/{z}/{x}/{y}.png', 'clientOptions' => [ 'attribution' => 'Tiles Courtesy of MapQuest ' . ', ' . 'Map data © OpenStreetMap contributors, CC-BY-SA', ] ]); $map = new LeafLet([ 'tileLayer' => $tileLayer, 'center' => $center ]); $point = new LatLng(['lat' => '46,9991224', 'lng' => '6,0582595']); $marker = new Marker(['latLng' => $point, 'popupContent' => Html::encode('Le Chat des Noisettes')]); $map->addLayer($marker); return $this->render('index', [ 'page_principale' => true, 'produits' => $produits, 'model' => $model, 'map' => $map ]); } public function actionMentions() { return $this->render('mentions'); } public function actionCommander() { if (Yii::$app->user->isGuest) { $this->redirect(Yii::$app->urlManager->createUrl('site/login')); } } 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 $this->goBack(['commande/index']); } else { return $this->render('@frontend/views/site/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', '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, ]); } } public function actionAbout() { return $this->render('about'); } 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, ]); } 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, ]); } 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, ]); } public function actionCgv() { return $this->render('cgv'); } public function actionCreditpain() { return $this->render('creditpain'); } public function actionEtablissement($id_etablissement) { $model_login = new LoginForm(); $model_signup = new SignupForm(); $etablissement = Etablissement::findOne($id_etablissement); if (Yii::$app->user->isGuest) { if ($model_login->load(Yii::$app->request->post()) && $model_login->login()) { // ajout de l'établissement en favoris si ce n'est pas encore le cas $user_etablissement_exist = UserEtablissement::find() ->where([ 'id_user' => Yii::$app->user->id, 'id_etablissement' => $id_etablissement ])->one(); if (!$user_etablissement_exist) { $etab_user = new UserEtablissement; $etab_user->id_etablissement = $id_etablissement; $etab_user->id_user = Yii::$app->user->id; $etab_user->credit = 0; $etab_user->actif = 1; $etab_user->save(); } else { if (!$user_etablissement_exist->actif) { $user_etablissement_exist->actif = 1; $user_etablissement_exist->save(); } } $this->redirect(['commande/index']); } if ($model_signup->load(Yii::$app->request->post())) { $model_signup->id_etablissement = $id_etablissement; $model_signup->option_client_boulanger = 'client'; if ($user = $model_signup->signup()) { if (Yii::$app->getUser()->login($user)) { $this->redirect(['commande/index']); } } } } else { $this->redirect(['commande/create', 'id_etablissement' => $id_etablissement]); } return $this->render('etablissement', [ 'model_login' => $model_login, 'model_signup' => $model_signup, 'etablissement' => $etablissement, ]); } }