. */ namespace Poniverse\Ponyfm\Http\Controllers\Api\Web; use Poniverse\Ponyfm\Models\Genre; use Poniverse\Ponyfm\Http\Controllers\ApiControllerBase; use Poniverse\Ponyfm\Models\License; use Poniverse\Ponyfm\Models\ShowSong; use Poniverse\Ponyfm\Models\TrackType; use DB; class TaxonomiesController extends ApiControllerBase { public function getAll() { return \Response::json([ 'licenses' => License::all()->toArray(), 'genres' => Genre::with('trackCountRelation') ->orderBy('name') ->get() ->toArray(), 'track_types' => TrackType::select( 'track_types.*', DB::raw('(SELECT COUNT(id) FROM tracks WHERE tracks.track_type_id = track_types.id AND tracks.published_at IS NOT NULL) AS track_count') ) ->where('id', '!=', TrackType::UNCLASSIFIED_TRACK) ->get()->toArray(), 'show_songs' => ShowSong::select( 'title', 'id', 'slug', DB::raw('(SELECT COUNT(tracks.id) FROM show_song_track INNER JOIN tracks ON tracks.id = show_song_track.track_id WHERE show_song_track.show_song_id = show_songs.id AND tracks.published_at IS NOT NULL) AS track_count') )->orderBy('title')->get()->toArray() ], 200); } }