Уведомление Laravel не отправляется по почте

я использую уведомления в первый раз и застрял на проблеме. Реализовано «Добро пожаловать» уведомление через «почту» и «базу данных». С "базой данных" все в порядке и работает хорошо. Проблема в "почтовой" части. При запуске уведомления через «мастера-мастера» все в порядке, и почта отправляется (настроено с помощью «журнала», чтобы записать его в «laravel.log»). При использовании той же строки кода, что и в Laravel, строка db записывается, но почта не отправляется.

Одно слово тинкеру: запись в журнале НЕ записывается в тот момент, когда я отправляю свой код в командную строку, она записывается в журнал, когда я говорю «выйти» в тинкере.

Есть мысли, что пошло не так???

Вот мое уведомление (Welcome.php):

<?php

namespace App\Notifications;

use App\Model\Account;
use App\Model\ClientSettings;
use App\Model\Mailserver;
use App\Model\Mailtemplate;
use Illuminate\Bus\Queueable;
use Illuminate\Contracts\Queue\ShouldQueue;
use Illuminate\Notifications\Notification;
use Illuminate\Notifications\Messages\MailMessage;

class Welcome extends Notification implements ShouldQueue
{
    use Queueable;

    private $user;
    private $mailserver;
    private $mailmessage;
    private $template;

    /**
     * Create a new notification instance.
     *
     * @param \App\Model\Account    $user
     * @param \App\Model\Mailserver $mailserver
     */
    public function __construct(Account $user, Mailserver $mailserver, Mailtemplate $mailtemplate)
    {
        $this->user = $user;
        $this->mailserver = $mailserver;
        $this->mailmessage = null;
        $this->template = $mailtemplate;
    }

    /**
     * Get the notification's delivery channels.
     *
     * @param  mixed $notifiable
     * @return array
     */
    public function via($notifiable)
    {
        return ['mail', 'database'];
    }

    /**
     * Get the mail representation of the notification.
     *
     * @param  mixed $notifiable
     * @return \Illuminate\Notifications\Messages\MailMessage
     */
    public function toMail($notifiable)
    {
        $clientsettings = ClientSettings::first();
        $maillogo = '';

        if ($clientsettings !== null) {
            $maillogo = $clientsettings->getMaillogo();
        }
       return (new MailMessage)
           ->subject($this->template->subject)
           ->greeting('Very nice Greeting ;)')
           ->salutation($maillogo)
           ->line('Willkommen bei X!')
           ->action('Anmelden', url(config('app.url')))
           ->line('have fun!');
    }

    /**
     * Get the array representation of the notification.
     *
     * @param  mixed $notifiable
     * @return array
     */
    public function toArray($notifiable)
    {
        return [
            'id' => $notifiable->getAttributes()['ac_id'],
            'email' => $notifiable->ac_email,
            'user' => $this->user,
            'mailserver' => $this->mailserver,
            'mailmessage' => ($this->mailmessage !== null) ?: $this->toMail($notifiable),
        ];
    }
}

Команда тинкера:

Notification::send(App\User::find(1), new App\Notifications\Welcome(App\Model\Account::first(), App\Model\Mailserver::first(), App\Model\Mailtemplate::first()));

Это запуск кода (очень быстрый и грязный)

    public function sendWelcomeNotification(Request $request): JsonResponse
    {
        $this->validator = WelcomeStoreRequest::class;
        $inputData = $request->validate(app($this->validator)->rules());
        $user = Account::findOrFail($inputData['user_id']);
        $server = array_key_exists('server_id', $inputData) ? Mailserver::findOrFail($inputData['server_id']) : Mailserver::first();
        $template = Mailtemplate::where('type', '=', 'WELCOME')->first();
//        $user->notify(new Welcome($user, $server, $template));
        Notification::send($user, new Welcome($user, $server, $template));
        return new JsonResponse([
            'status' => 'ok'
        ]);
    }

Ни один из двух способов уведомления не работает :(


person Paladin    schedule 20.09.2018    source источник
comment
Можете ли вы опубликовать свой код, пожалуйста?   -  person Jonathon    schedule 20.09.2018
comment
Конечно, но я не уверен, какой код вам нужен. Уведомление? Конфигурация?   -  person Paladin    schedule 20.09.2018
comment
В идеале, ваш класс уведомлений, код, который его запускает, и то, что вы сделали в tinker, чтобы он работал. Конфигурация тоже может быть полезна. В общем, все, что может иметь значение :)   -  person Jonathon    schedule 20.09.2018
comment
Хорошо, добавил немного кода, есть ли что-нибудь, указывающее на то, что я сделал что-то не так?   -  person Paladin    schedule 20.09.2018
comment
Я ничего не вижу сразу. Единственное, что я заметил, это то, что вы делаете $request->validate(...); и ожидаете, что это вернет массив. Насколько я знаю, объект Request не имеет метода validate, и большинство методов validate в фреймворке, как правило, не возвращают массивы. Это то, что вы сделали сами? В классе FormRequest есть метод проверки, введенный трейтом ValidatesWhenResolved, но он ничего не возвращает.   -  person Jonathon    schedule 20.09.2018
comment
@Jonathon Нет, это встроенная функция laravel для ручной проверки с помощью класса Validator. И это работает хорошо, в $inputData у меня есть только проверенные данные без чего-либо, что не должно быть там.   -  person Paladin    schedule 20.09.2018
comment
Не могли бы вы поместить dd(get_class($request), $inputData); перед строкой, начинающейся с $user = Account::findOrFail(...), и отредактировать свой вопрос, чтобы включить его вывод, пожалуйста? (Редактировать: извините, я напутал, обновил свой комментарий)   -  person Jonathon    schedule 20.09.2018
comment
@Jonathon, ты здесь: picload.org/view/dlwawwca/image.png.html , сделал dd($request, $inputData);   -  person Paladin    schedule 20.09.2018


Ответы (1)


Хорошо, нашел сам, мне понадобилось несколько минут, чтобы закончить мой фейспалм, извините.

Причина заключалась в «дизайне» базы данных, поскольку в таблице учетных записей была запись с «ac_email», а laravel искал «email». Итак, добавив это в мой файл модели

public function routeNotificationForMail($notification)
{
    return $this->ac_email;
}

Сделано трюк, и электронные письма теперь отправляются. Всем спасибо за помощь ;)

person Paladin    schedule 20.09.2018