Мой слушатель не сохраняет данные в таблицу - PullRequest
0 голосов
/ 30 апреля 2019

Я создал обработчик событий, который перед обновлением таблицы team_members должен сохранить строку в таблице team_members_log. На данный момент ничего не происходит, без ошибок, без вставок Я не уверен, что event уволят вообще.

Моя модель, я отправляю событие из:

<?php

namespace App\Models;

use App\Events\TeamMemberUpdating;
use Illuminate\Notifications\Notifiable;
use Illuminate\Database\Eloquent\Model;

class TeamMember extends Model
{
    use Notifiable; 

    protected $table = 'team_members';

    protected $fillable = ['project_request_id'];

    protected $dispatchesEvents = [
        'updating' => TeamMemberUpdating::class,
    ];
}

Само событие:

<?php

namespace App\Events;

use Illuminate\Broadcasting\Channel;
use Illuminate\Queue\SerializesModels;
use Illuminate\Broadcasting\PrivateChannel;
use Illuminate\Broadcasting\PresenceChannel;
use Illuminate\Foundation\Events\Dispatchable;
use Illuminate\Broadcasting\InteractsWithSockets;
use Illuminate\Contracts\Broadcasting\ShouldBroadcast;
use App\Models\TeamMember;

class TeamMemberUpdating extends Event
{
    use Dispatchable, InteractsWithSockets, SerializesModels;

    public $teamMember;

    /**
     * Create a new event instance.
     *
     * @return void
     */
    public function __construct(TeamMember $teamMember)
    {
        $this->teamMember = $teamMember;
    }

    /**
     * Get the channels the event should broadcast on.
     *
     * @return \Illuminate\Broadcasting\Channel|array
     */
    /*public function broadcastOn()
    {
        return new PrivateChannel('channel-name');
    }*/
}

Слушатель:

<?php

namespace App\Listeners;

use App\Models\TeamMemberLog;
use App\Events\TeamMemberUpdating;
use Illuminate\Queue\InteractsWithQueue;
use Illuminate\Contracts\Queue\ShouldQueue;

class LogTeamMemberWithProjectRequest
{
    /**
     * Create the event listener.
     *
     * @return void
     */
    public function __construct()
    {
        //
    }

    /**
     * Handle the event.
     *
     * @param  TeamMemberUpdating  $event
     * @return void
     */
    public function handle(TeamMemberUpdating $event)
    {   
        TeamMemberLog::create(['name' => $event->teamMember->name, 'title'=> $event->teamMember->title, 'picture' => $event->teamMember->picture, 'email' => $event->teamMember->email, 'phone_number' => $event->teamMember->phonenumber, 'background-information' => $event->teamMemmber->background_information ]);
    }
}

регистрируя их:

 protected $listen = [
        Registered::class => [
            SendEmailVerificationNotification::class,
        ],
        'App\Events\TeamMemberUpdating' => [
            'App\Listeners\LogTeamMemberWithProjectRequest',
        ],
    ];
...