. */ namespace App\Commands; use App\Models\Playlist; use App\Models\Track; use Illuminate\Support\Facades\Auth; use Illuminate\Support\Facades\DB; use Illuminate\Support\Facades\Validator; class AddTrackToPlaylistCommand extends CommandBase { /** @var Track */ private $_track; /** @var Playlist */ private $_playlist; public function __construct($playlistId, $trackId) { $this->_playlist = Playlist::find($playlistId); $this->_track = Track::find($trackId); } /** * @return bool */ public function authorize() { $user = Auth::user(); return $user != null && $this->_playlist && $this->_track && $this->_playlist->user_id == $user->id; } /** * @throws \Exception * @return CommandResponse */ public function execute() { // check if this track is already in the playlist $validator = Validator::make( ['track_id' => $this->_track->id], ['track_id' => "unique:playlist_track,track_id,null,id,playlist_id,{$this->_playlist->id}"] ); if ($validator->fails()) { return CommandResponse::fail($validator); } $songIndex = $this->_playlist->trackCount() + 1; $this->_playlist->tracks()->attach($this->_track, ['position' => $songIndex]); $this->_playlist->touch(); Playlist::where('id', $this->_playlist->id)->update([ 'track_count' => DB::raw('(SELECT COUNT(id) FROM playlist_track WHERE playlist_id = '.$this->_playlist->id.')'), ]); return CommandResponse::succeed(['message' => 'Track added!']); } }