/** * @param $username * @return string */ public function actionEditInfo() { $model = $this->user; $rr = new RequestResponse(); if ($rr->isRequestOnValidateAjaxForm()) { return $rr->ajaxValidateForm($model); } if ($rr->isRequestAjaxPost()) { if ($model->load(\Yii::$app->request->post()) && $model->save()) { $rr->success = true; $rr->message = 'Данные успешно сохранены'; } else { $rr->message = 'Не получилось сохранить данные'; } return $rr; } return $this->render($this->action->id); }
public function actionSubmit() { $rr = new RequestResponse(); $model = new Comments2Message(); if ($rr->isRequestOnValidateAjaxForm()) { return $rr->ajaxValidateForm($model); } if ($rr->isRequestAjaxPost()) { $model->scenario = Comments2Message::SCENARIO_SITE_INSERT; $model->page_url = \Yii::$app->request->referrer; if ($model->load(\Yii::$app->request->post())) { //Проверка на максимальное количество комментариев к одному посту от одного пользователя. $messagesFind = Comments2Message::find(); if (\Yii::$app->user->isGuest) { $messagesFind->andWhere(['ip' => Request::getRealUserIp()]); } else { $messagesFind->andWhere(['created_by' => \Yii::$app->user->identity->id]); } $messagesFind2 = clone $messagesFind; $messagesFind->andWhere(['status' => Comments2Message::STATUS_ALLOWED])->andWhere(['element_id' => $model->element_id]); if (\Yii::$app->comments2->maxCountMessagesForUser != 0) { if ($messagesFind->count() >= \Yii::$app->comments2->maxCountMessagesForUser) { $rr->success = false; $rr->message = \skeeks\cms\comments2\Module::t('app', 'You have already added a comment on this post before.'); return $rr; } } //Проверка частоты добавления комментариев if (\Yii::$app->comments2->securityEnabledRateLimit == Cms::BOOL_Y) { $messagesFind2 = Comments2Message::find(); if (\Yii::$app->user->isGuest) { $messagesFind2->andWhere(['ip' => Request::getRealUserIp()]); } else { $messagesFind2->andWhere(['created_by' => \Yii::$app->user->identity->id]); } $lastTime = \Yii::$app->formatter->asTimestamp(time()) - (int) \Yii::$app->comments2->securityRateLimitTime; $messagesFind2->andWhere(['>=', 'created_at', $lastTime]); //print_r($messagesFind2->createCommand()->rawSql);die; if ($messagesFind2->count() >= \Yii::$app->comments2->securityRateLimitRequests) { $rr->success = false; $rr->message = \skeeks\cms\comments2\Module::t('app', 'You too often add comments.'); return $rr; } } if ($model->save()) { $rr->success = true; if (\Yii::$app->comments2->enabledBeforeApproval == Cms::BOOL_Y) { $rr->message = \Yii::$app->comments2->messageSuccessBeforeApproval; } else { $rr->message = \Yii::$app->comments2->messageSuccess; //Отключена предмодерация, сразу публикуем $model->status = Comments2Message::STATUS_ALLOWED; $model->scenario = ActiveRecord::SCENARIO_DEFAULT; $model->save(); } $model->notifyCreate(); } else { $rr->success = false; $rr->message = \skeeks\cms\comments2\Module::t('app', 'You comments not added') . ": " . implode(",", $model->getFirstErrors()); } } else { $rr->success = false; $rr->message = \skeeks\cms\comments2\Module::t('app', 'You comments not added') . ": " . implode(",", $model->getFirstErrors()); } } return $rr; }
public function actionAuth() { $this->view->title = \Yii::t('app', 'Authorization'); $this->layout = '@skeeks/cms/modules/admin/views/layouts/unauthorized.php'; $goUrl = ""; $loginModel = new LoginFormUsernameOrEmail(); $passwordResetModel = new PasswordResetRequestFormEmailOrLogin(); if ($ref = UrlHelper::getCurrent()->getRef()) { $goUrl = $ref; } $rr = new RequestResponse(); if (!\Yii::$app->user->isGuest) { return $goUrl ? $this->redirect($goUrl) : $this->goHome(); } //Авторизация if (\Yii::$app->request->post('do') == 'login') { if ($rr->isRequestOnValidateAjaxForm()) { return $rr->ajaxValidateForm($loginModel); } if ($rr->isRequestAjaxPost()) { if ($loginModel->load(\Yii::$app->request->post()) && $loginModel->login()) { if (!$goUrl) { $goUrl = Yii::$app->getUser()->getReturnUrl($defaultUrl); } $rr->redirect = $goUrl; $rr->success = true; $rr->message = ""; $rr->message = ""; return (array) $rr; } else { $rr->success = false; $rr->message = \Yii::t('app', "Unsuccessful attempt authorization"); return (array) $rr; } } } //Запрос на сброс пароля if (\Yii::$app->request->post('do') == 'password-reset') { if ($rr->isRequestOnValidateAjaxForm()) { return $rr->ajaxValidateForm($passwordResetModel); } if ($rr->isRequestAjaxPost()) { if ($passwordResetModel->load(\Yii::$app->request->post()) && $passwordResetModel->sendEmail()) { $rr->success = true; $rr->message = \Yii::t('app', "Check your email address"); return (array) $rr; } else { $rr->success = false; $rr->message = \Yii::t('app', "Failed send email"); return (array) $rr; } } } return $this->render('auth', ['loginModel' => $loginModel, 'passwordResetModel' => $passwordResetModel, 'goUrl' => $goUrl]); }
/** * Восстановлеине пароля * @return string|Response */ public function actionRegisterByEmail() { if (!\Yii::$app->user->isGuest) { return $this->goHome(); } $rr = new RequestResponse(); $model = new SignupForm(); $model->scenario = SignupForm::SCENARION_ONLYEMAIL; //Запрос на валидацию ajax формы if ($rr->isRequestOnValidateAjaxForm()) { return $rr->ajaxValidateForm($model); } //Запрос ajax post if ($rr->isRequestAjaxPost()) { if ($model->load(\Yii::$app->request->post()) && ($registeredUser = $model->signup())) { $rr->success = true; $rr->message = 'Для дальнейших действий, проверьте вашу почту.'; return $rr; } else { $rr->message = 'Не удалось зарегистрироваться'; } return (array) $rr; } return $this->render('register', ['model' => $model]); }
public function actionSubmit() { $rr = new RequestResponse(); $model = new Reviews2Message(); if ($rr->isRequestOnValidateAjaxForm()) { return $rr->ajaxValidateForm($model); } if ($rr->isRequestAjaxPost()) { $model->scenario = Reviews2Message::SCENARIO_SITE_INSERT; $model->page_url = \Yii::$app->request->referrer; if ($model->load(\Yii::$app->request->post())) { //Проверка на максимальное количество отзывов к одному посту от одного пользователя. $messagesFind = Reviews2Message::find(); if (\Yii::$app->user->isGuest) { $messagesFind->andWhere(['ip' => \Yii::$app->request->userIP])->andWhere(['or', ['created_by' => null], ['created_by' => '']]); } else { $messagesFind->andWhere(['created_by' => \Yii::$app->user->identity->id]); } $messagesFind2 = clone $messagesFind; $messagesFind->andWhere(['status' => Reviews2Message::STATUS_ALLOWED])->andWhere(['element_id' => $model->element_id]); if (\Yii::$app->reviews2->maxCountMessagesForUser != 0) { if ($messagesFind->count() >= \Yii::$app->reviews2->maxCountMessagesForUser) { $rr->success = false; $rr->message = \Yii::t('skeeks/reviews2', "You have already added a review for this post earlier."); return $rr; } } //Проверка частоты добавления отзывов if (\Yii::$app->reviews2->securityEnabledRateLimit == Cms::BOOL_Y) { $messagesFind2 = Reviews2Message::find(); if (\Yii::$app->user->isGuest) { $messagesFind2->andWhere(['ip' => \Yii::$app->request->userIP]); } else { $messagesFind2->andWhere(['created_by' => \Yii::$app->user->identity->id]); } $lastTime = \Yii::$app->formatter->asTimestamp(time()) - (int) \Yii::$app->reviews2->securityRateLimitTime; $messagesFind2->andWhere(['>=', 'created_at', $lastTime]); //print_r($messagesFind2->createCommand()->rawSql);die; if ($messagesFind2->count() >= \Yii::$app->reviews2->securityRateLimitRequests) { $rr->success = false; $rr->message = \Yii::t('skeeks/reviews2', "You too often add reviews."); return $rr; } } if ($model->save()) { $rr->success = true; if (\Yii::$app->reviews2->enabledBeforeApproval == Cms::BOOL_Y) { $rr->message = \Yii::$app->reviews2->messageSuccessBeforeApproval; } else { $rr->message = \Yii::$app->reviews2->messageSuccess; //Отключена предмодерация, сразу публикуем $model->status = Reviews2Message::STATUS_ALLOWED; $model->save(); } $model->notifyCreate(); } else { $rr->success = false; $rr->message = \Yii::t('skeeks/reviews2', "Review not added") . ": " . implode(",", $model->getFirstErrors()); } } else { $rr->success = false; $rr->message = \Yii::t('skeeks/reviews2', "Review not added") . ": " . implode(",", $model->getFirstErrors()); } } return $rr; }