UserCreateService: check if we're from web before setting flash message #195
Also return an error message to console if mail send failed
This commit is contained in:
@ -7,6 +7,7 @@
|
|||||||
- Enh: Changed `View::render()` calls in views to use absolute paths (ajmedway)
|
- Enh: Changed `View::render()` calls in views to use absolute paths (ajmedway)
|
||||||
- Fix #169: Fix bug in ReCaptchaComponent (BuTaMuH)
|
- Fix #169: Fix bug in ReCaptchaComponent (BuTaMuH)
|
||||||
- Fix #168: Fix spelling in russian language (EvgenyOrekhov)
|
- Fix #168: Fix spelling in russian language (EvgenyOrekhov)
|
||||||
|
- Fix #195: UserCreateService: check if we're from web before setting flash message (maxxer)
|
||||||
|
|
||||||
## 1.1.4 - February 19, 2018
|
## 1.1.4 - February 19, 2018
|
||||||
- Enh: Check enableEmailConfirmation on registration (faenir)
|
- Enh: Check enableEmailConfirmation on registration (faenir)
|
||||||
|
|||||||
@ -16,6 +16,7 @@ use Da\User\Event\UserEvent;
|
|||||||
use Da\User\Helper\SecurityHelper;
|
use Da\User\Helper\SecurityHelper;
|
||||||
use Da\User\Model\User;
|
use Da\User\Model\User;
|
||||||
use Da\User\Traits\MailAwareTrait;
|
use Da\User\Traits\MailAwareTrait;
|
||||||
|
use Da\User\Traits\ModuleAwareTrait;
|
||||||
use Exception;
|
use Exception;
|
||||||
use Yii;
|
use Yii;
|
||||||
use yii\base\InvalidCallException;
|
use yii\base\InvalidCallException;
|
||||||
@ -23,6 +24,7 @@ use yii\base\InvalidCallException;
|
|||||||
class UserCreateService implements ServiceInterface
|
class UserCreateService implements ServiceInterface
|
||||||
{
|
{
|
||||||
use MailAwareTrait;
|
use MailAwareTrait;
|
||||||
|
use ModuleAwareTrait;
|
||||||
|
|
||||||
protected $model;
|
protected $model;
|
||||||
protected $securityHelper;
|
protected $securityHelper;
|
||||||
@ -67,14 +69,22 @@ class UserCreateService implements ServiceInterface
|
|||||||
|
|
||||||
$model->trigger(UserEvent::EVENT_AFTER_CREATE, $event);
|
$model->trigger(UserEvent::EVENT_AFTER_CREATE, $event);
|
||||||
if (!$this->sendMail($model)) {
|
if (!$this->sendMail($model)) {
|
||||||
Yii::$app->session->setFlash(
|
$error_msg = Yii::t(
|
||||||
'warning',
|
'usuario',
|
||||||
Yii::t(
|
'Error sending welcome message to "{email}". Please try again later.',
|
||||||
'usuario',
|
['email' => $model->email]
|
||||||
'Error sending welcome message to "{email}". Please try again later.',
|
|
||||||
['email' => $model->email]
|
|
||||||
)
|
|
||||||
);
|
);
|
||||||
|
// from web display a flash message (if enabled)
|
||||||
|
if($this->getModule()->enableFlashMessages == TRUE && is_a(Yii::$app, yii\web\Application::class)) {
|
||||||
|
Yii::$app->session->setFlash(
|
||||||
|
'warning',
|
||||||
|
$error_msg
|
||||||
|
);
|
||||||
|
}
|
||||||
|
// if we're from console add an error to the model in order to return an error message
|
||||||
|
if(is_a(Yii::$app, yii\console\Application::class)) {
|
||||||
|
$model->addError("username", $error_msg);
|
||||||
|
}
|
||||||
$transaction->rollBack();
|
$transaction->rollBack();
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user