2015-08-31 16:30:02 +02:00
|
|
|
<?php
|
|
|
|
|
2015-10-24 03:22:14 +02:00
|
|
|
namespace Poniverse\Ponyfm\Http\Controllers\Api\Web;
|
2015-08-31 16:30:02 +02:00
|
|
|
|
2015-10-24 03:22:14 +02:00
|
|
|
use Poniverse\Ponyfm\Album;
|
|
|
|
use Poniverse\Ponyfm\Commands\ToggleFavouriteCommand;
|
|
|
|
use Poniverse\Ponyfm\Favourite;
|
|
|
|
use Poniverse\Ponyfm\Http\Controllers\ApiControllerBase;
|
|
|
|
use Poniverse\Ponyfm\Playlist;
|
|
|
|
use Poniverse\Ponyfm\Track;
|
2015-08-31 16:30:02 +02:00
|
|
|
use Illuminate\Support\Facades\Auth;
|
|
|
|
use Illuminate\Support\Facades\Input;
|
|
|
|
use Illuminate\Support\Facades\Response;
|
|
|
|
|
2015-09-06 19:21:11 +02:00
|
|
|
class FavouritesController extends ApiControllerBase
|
2015-08-31 16:30:02 +02:00
|
|
|
{
|
|
|
|
public function postToggle()
|
|
|
|
{
|
|
|
|
return $this->execute(new ToggleFavouriteCommand(Input::get('type'), Input::get('id')));
|
|
|
|
}
|
|
|
|
|
|
|
|
public function getTracks()
|
|
|
|
{
|
|
|
|
$query = Favourite
|
|
|
|
::whereUserId(Auth::user()->id)
|
|
|
|
->whereNotNull('track_id')
|
|
|
|
->with([
|
|
|
|
'track' => function ($query) {
|
|
|
|
$query
|
|
|
|
->userDetails()
|
|
|
|
->published();
|
|
|
|
},
|
|
|
|
'track.user',
|
|
|
|
'track.genre',
|
|
|
|
'track.cover',
|
|
|
|
'track.album',
|
|
|
|
'track.album.user'
|
|
|
|
]);
|
|
|
|
|
|
|
|
$tracks = [];
|
|
|
|
|
|
|
|
foreach ($query->get() as $fav) {
|
|
|
|
if ($fav->track == null) // deleted track
|
|
|
|
{
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
|
|
|
|
$tracks[] = Track::mapPublicTrackSummary($fav->track);
|
|
|
|
}
|
|
|
|
|
|
|
|
return Response::json(["tracks" => $tracks], 200);
|
|
|
|
}
|
|
|
|
|
|
|
|
public function getAlbums()
|
|
|
|
{
|
|
|
|
$query = Favourite
|
|
|
|
::whereUserId(Auth::user()->id)
|
|
|
|
->whereNotNull('album_id')
|
|
|
|
->with([
|
|
|
|
'album' => function ($query) {
|
|
|
|
$query->userDetails();
|
|
|
|
},
|
|
|
|
'album.user',
|
|
|
|
'album.user.avatar',
|
|
|
|
'album.cover'
|
|
|
|
]);
|
|
|
|
|
|
|
|
$albums = [];
|
|
|
|
|
|
|
|
foreach ($query->get() as $fav) {
|
|
|
|
if ($fav->album == null) // deleted album
|
|
|
|
{
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
|
|
|
|
$albums[] = Album::mapPublicAlbumSummary($fav->album);
|
|
|
|
}
|
|
|
|
|
|
|
|
return Response::json(["albums" => $albums], 200);
|
|
|
|
}
|
|
|
|
|
|
|
|
public function getPlaylists()
|
|
|
|
{
|
|
|
|
$query = Favourite
|
|
|
|
::whereUserId(Auth::user()->id)
|
|
|
|
->whereNotNull('playlist_id')
|
|
|
|
->with([
|
|
|
|
'playlist' => function ($query) {
|
|
|
|
$query->userDetails();
|
|
|
|
},
|
|
|
|
'playlist.user',
|
|
|
|
'playlist.user.avatar',
|
|
|
|
'playlist.tracks',
|
|
|
|
'playlist.tracks.cover'
|
|
|
|
]);
|
|
|
|
|
|
|
|
$playlists = [];
|
|
|
|
|
|
|
|
foreach ($query->get() as $fav) {
|
|
|
|
if ($fav->playlist == null) // deleted playlist
|
|
|
|
{
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
|
|
|
|
$playlists[] = Playlist::mapPublicPlaylistSummary($fav->playlist);
|
|
|
|
}
|
|
|
|
|
|
|
|
return Response::json(["playlists" => $playlists], 200);
|
|
|
|
}
|
|
|
|
}
|