. */ namespace App\Jobs; use App\Models\ShowSong; use App\Models\Track; use Auth; use DB; use Illuminate\Contracts\Queue\ShouldQueue; use Illuminate\Queue\InteractsWithQueue; use SerializesModels; class DeleteShowSong extends Job implements ShouldQueue { use InteractsWithQueue, SerializesModels; protected $executingUser; protected $songToDelete; protected $destinationSong; /** * Create a new job instance. * * @param ShowSong $songToDelete * @param ShowSong $destinationSong */ public function __construct(ShowSong $songToDelete, ShowSong $destinationSong) { $this->executingUser = Auth::user(); $this->songToDelete = $songToDelete; $this->destinationSong = $destinationSong; } /** * Execute the job. * * @return void */ public function handle() { $this->beforeHandle(); // The user who kicked off this job is used when generating revision log entries. Auth::login($this->executingUser); // This is done instead of a single UPDATE query in order to // generate revision logs for the change. $this->songToDelete->tracks()->chunk(200, function ($tracks) { foreach ($tracks as $track) { /** @var Track $track */ $oldSongs = $track->showSongs; $newSongs = []; foreach ($oldSongs as $key => $showSong) { if ($showSong->id == $this->songToDelete->id) { $newSongs[$key] = $this->destinationSong->id; } else { $newSongs[$key] = $showSong->id; } } $track->showSongs()->sync($newSongs); $track->save(); $track->updateTags(); } }); $this->songToDelete->delete(); } }