. */ namespace App\Http\Controllers; use Illuminate\Support\Facades\App; use App\Models\ResourceLogItem; use App\Models\Track; use App\Models\TrackFile; use Illuminate\Support\Facades\Auth; use Illuminate\Support\Facades\Config; use Illuminate\Http\Request; use Illuminate\Support\Facades\Redirect; use Illuminate\Support\Facades\Response; use Illuminate\Support\Facades\View; class TracksController extends Controller { public function getIndex() { return view('tracks.index'); } public function getEmbed($id) { $track = Track ::whereId($id) ->published() ->userDetails() ->with( 'user', 'user.avatar', 'genre' )->first(); if (! $track || ! $track->canView(Auth::user())) { abort(404); } $userData = [ 'stats' => [ 'views' => 0, 'plays' => 0, 'downloads' => 0, ], 'is_favourited' => false, ]; if ($track->users->count()) { $userRow = $track->users[0]; $userData = [ 'stats' => [ 'views' => $userRow->view_count, 'plays' => $userRow->play_count, 'downloads' => $userRow->download_count, ], 'is_favourited' => $userRow->is_favourited, ]; } return view('tracks.embed', ['track' => $track, 'user' => $userData]); } public function getOembed(Request $request) { if (! $request->filled('url')) { abort(404); } $parsedUrl = parse_url($request->input('url')); $id = explode('-', explode('/', $parsedUrl['path'])[2])[0]; $track = Track ::whereId($id) ->published() ->userDetails() ->first(); if (! $track || ! $track->canView(Auth::user())) { abort(404); } $output = [ 'version' => '1.0', 'type' => 'rich', 'provider_name' => 'Pony.fm', 'provider_url' => 'https://pony.fm', 'width' => 480, 'height' => 130, 'title' => $track->title, 'author_name' => $track->user->display_name, 'author_url' => $track->user->url, 'html' => '', ]; return response()->json($output); } public function getTrack($id, $slug) { $track = Track::find($id); if (! $track || ! $track->canView(Auth::user())) { abort(404); } if ($track->slug != $slug) { return Redirect::action('TracksController@getTrack', [$id, $track->slug]); } return view('tracks.show', ['track' => $track]); } public function getEdit($id, $slug) { return $this->getTrack($id, $slug); } public function getShortlink($id) { $track = Track::find($id); if (! $track || ! $track->canView(Auth::user())) { abort(404); } return Redirect::action('TracksController@getTrack', [$id, $track->slug]); } public function getStream($id, $extension) { $track = Track::find($id); if (! $track || ! $track->canView(Auth::user())) { abort(404); } $trackFile = TrackFile::findOrFailByExtension($track->id, $extension); $response = response('', 200); $filename = $trackFile->getFile(); if (! file_exists($filename)) { abort(418); } ResourceLogItem::logItem('track', $id, ResourceLogItem::PLAY, $trackFile->getFormat()['index']); if (config('app.sendfile')) { $response->header('X-Sendfile', $filename); } else { $response->header('X-Accel-Redirect', $filename); } $time = gmdate(filemtime($filename)); if (isset($_SERVER['HTTP_IF_MODIFIED_SINCE']) && $time == $_SERVER['HTTP_IF_MODIFIED_SINCE']) { header('HTTP/1.0 304 Not Modified'); exit(); } $response->header('Last-Modified', $time); $response->header('Content-Type', $trackFile->getFormat()['mime_type']); return $response; } public function getDownload($id, $extension) { $track = Track::find($id); if (! $track || ! $track->canView(Auth::user())) { abort(404); } $trackFile = TrackFile::findOrFailByExtension($track->id, $extension); ResourceLogItem::logItem('track', $id, ResourceLogItem::DOWNLOAD, $trackFile->getFormat()['index']); $response = response('', 200); $filename = $trackFile->getFile(); if (config('app.sendfile')) { $response->header('X-Sendfile', $filename); $response->header( 'Content-Disposition', 'attachment; filename="'.$trackFile->getDownloadFilename().'"' ); } else { $response->header('X-Accel-Redirect', $filename); $response->header( 'Content-Disposition', 'attachment; filename="'.$trackFile->getDownloadFilename().'"' ); } $time = gmdate(filemtime($filename)); if (isset($_SERVER['HTTP_IF_MODIFIED_SINCE']) && $time == $_SERVER['HTTP_IF_MODIFIED_SINCE']) { header('HTTP/1.0 304 Not Modified'); exit(); } $response->header('Last-Modified', $time); $response->header('Content-Type', $trackFile->getFormat()['mime_type']); return $response; } }