2015-08-31 16:30:02 +02:00
|
|
|
<?php
|
|
|
|
|
2015-10-25 06:17:45 +01:00
|
|
|
/**
|
|
|
|
* Pony.fm - A community for pony fan music.
|
2021-02-14 03:39:15 +01:00
|
|
|
* Copyright (C) 2015-2017 Feld0.
|
2015-10-25 06:17:45 +01:00
|
|
|
*
|
|
|
|
* This program is free software: you can redistribute it and/or modify
|
|
|
|
* it under the terms of the GNU Affero General Public License as published by
|
|
|
|
* the Free Software Foundation, either version 3 of the License, or
|
|
|
|
* (at your option) any later version.
|
|
|
|
*
|
|
|
|
* This program is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
* GNU Affero General Public License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU Affero General Public License
|
|
|
|
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
*/
|
|
|
|
|
2021-02-14 03:34:58 +01:00
|
|
|
namespace App\Http\Controllers\Api\V1;
|
2015-08-31 16:30:02 +02:00
|
|
|
|
2021-02-14 03:34:58 +01:00
|
|
|
use App\Commands\UploadTrackCommand;
|
|
|
|
use App\Http\Controllers\ApiControllerBase;
|
|
|
|
use App\Models\Image;
|
|
|
|
use App\Models\Track;
|
2021-02-14 20:45:51 +01:00
|
|
|
use Illuminate\Support\Facades\Response;
|
2015-08-31 16:30:02 +02:00
|
|
|
|
2015-11-09 20:35:30 +01:00
|
|
|
class TracksController extends ApiControllerBase
|
2015-08-31 16:30:02 +02:00
|
|
|
{
|
2016-09-30 00:26:31 +02:00
|
|
|
public function postUploadTrack()
|
|
|
|
{
|
2015-11-09 20:35:30 +01:00
|
|
|
session_write_close();
|
|
|
|
|
2015-12-26 12:40:47 +01:00
|
|
|
$response = $this->execute(new UploadTrackCommand(true, true, session('api_client_id'), true));
|
2015-11-09 20:35:30 +01:00
|
|
|
$commandData = $response->getData(true);
|
|
|
|
|
|
|
|
if (200 !== $response->getStatusCode()) {
|
|
|
|
return $response;
|
|
|
|
}
|
|
|
|
|
|
|
|
$data = [
|
2015-12-26 12:40:47 +01:00
|
|
|
'id' => (string) $commandData['id'],
|
2015-11-09 20:35:30 +01:00
|
|
|
'status_url' => action('Api\V1\TracksController@getUploadStatus', ['id' => $commandData['id']]),
|
2015-12-26 12:40:47 +01:00
|
|
|
'track_url' => action('TracksController@getTrack', ['id' => $commandData['id'], 'slug' => $commandData['slug']]),
|
|
|
|
'message' => $commandData['autoPublish']
|
2021-02-14 03:39:15 +01:00
|
|
|
? 'This track has been accepted for processing! Poll the status_url to know when it has been published. It will be published at the track_url.'
|
2015-12-26 12:40:47 +01:00
|
|
|
: "This track has been accepted for processing! Poll the status_url to know when it's ready to publish. It will be published at the track_url.",
|
2015-11-09 20:35:30 +01:00
|
|
|
];
|
|
|
|
|
|
|
|
$response->setData($data);
|
|
|
|
$response->setStatusCode(202);
|
2021-02-14 03:39:15 +01:00
|
|
|
|
2015-11-09 20:35:30 +01:00
|
|
|
return $response;
|
|
|
|
}
|
|
|
|
|
2016-09-30 00:26:31 +02:00
|
|
|
public function getUploadStatus($trackId)
|
|
|
|
{
|
2015-11-09 20:35:30 +01:00
|
|
|
$track = Track::findOrFail($trackId);
|
|
|
|
$this->authorize('edit', $track);
|
|
|
|
|
|
|
|
if ($track->status === Track::STATUS_PROCESSING) {
|
|
|
|
return Response::json(['message' => 'Processing...'], 202);
|
|
|
|
} elseif ($track->status === Track::STATUS_COMPLETE) {
|
|
|
|
return Response::json([
|
2015-12-26 12:40:47 +01:00
|
|
|
'message' => $track->published_at
|
|
|
|
? 'Processing complete! The track is live at the track_url. The artist can edit the track by visiting its edit_url.'
|
|
|
|
: 'Processing complete! The artist must publish the track by visiting its edit_url.',
|
|
|
|
'edit_url' => action('ContentController@getTracks', ['id' => $trackId]),
|
2021-02-14 03:39:15 +01:00
|
|
|
'track_url' => $track->url,
|
2015-11-09 20:35:30 +01:00
|
|
|
], 201);
|
|
|
|
} else {
|
|
|
|
// something went wrong
|
2016-09-21 02:32:30 +02:00
|
|
|
return Response::json(['error' => 'Processing failed! Please contact logic@pony.fm to figure out what went wrong.'], 500);
|
2015-11-09 20:35:30 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-10-29 01:44:08 +02:00
|
|
|
/**
|
|
|
|
* Returns a stable representation of a track for the API. This is very
|
|
|
|
* similar to the radio representation below but finds tracks by ID and is
|
|
|
|
* expected to be more stable.
|
|
|
|
*
|
|
|
|
* @param int $id track ID
|
|
|
|
* @return \Illuminate\Http\JsonResponse
|
|
|
|
*/
|
2021-02-14 03:39:15 +01:00
|
|
|
public function getTrackDetails($id)
|
|
|
|
{
|
2017-10-29 01:44:08 +02:00
|
|
|
/** @var Track|null $track */
|
|
|
|
$track = Track
|
|
|
|
::with('user', 'album', 'user.avatar', 'cover', 'genre')
|
|
|
|
->published()
|
|
|
|
->where('id', $id)->first();
|
|
|
|
|
2021-02-14 03:39:15 +01:00
|
|
|
if (! $track) {
|
2017-10-29 01:44:08 +02:00
|
|
|
return Response::json(['message' => 'Track not found.'], 404);
|
|
|
|
}
|
2015-11-09 20:35:30 +01:00
|
|
|
|
2017-10-29 01:50:15 +02:00
|
|
|
return Response::json(self::trackToJson($track, false, true), 200);
|
2017-10-29 01:44:08 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Returns a serialized version of a track for use by radios.
|
|
|
|
*
|
|
|
|
* @deprecated in favour of getTrackDetails
|
|
|
|
* @param $hash
|
|
|
|
* @return \Illuminate\Http\JsonResponse
|
|
|
|
*/
|
2015-08-31 16:30:02 +02:00
|
|
|
public function getTrackRadioDetails($hash)
|
|
|
|
{
|
2017-10-29 01:44:08 +02:00
|
|
|
/** @var Track|null $track */
|
2015-08-31 16:30:02 +02:00
|
|
|
$track = Track
|
|
|
|
::with('user', 'album', 'user.avatar', 'cover', 'comments', 'genre')
|
|
|
|
->published()
|
2017-10-29 01:44:08 +02:00
|
|
|
->where('hash', $hash)->first();
|
2015-08-31 16:30:02 +02:00
|
|
|
|
2021-02-14 03:39:15 +01:00
|
|
|
if (! $track) {
|
2015-08-31 16:30:02 +02:00
|
|
|
return Response::json(['message' => 'Track not found.'], 403);
|
|
|
|
}
|
|
|
|
|
2017-10-29 01:50:15 +02:00
|
|
|
return Response::json(self::trackToJson($track, true, false), 200);
|
2017-10-29 01:44:08 +02:00
|
|
|
}
|
2015-08-31 16:30:02 +02:00
|
|
|
|
2017-10-29 01:44:08 +02:00
|
|
|
/**
|
|
|
|
* Helper method to form the serialized version of a track for the V1 API.
|
|
|
|
*
|
|
|
|
* @param Track $track
|
|
|
|
* @param bool $includeComments if true, includes the track's comments in the serialization
|
|
|
|
* @return array serialized track
|
|
|
|
*/
|
2021-02-14 03:39:15 +01:00
|
|
|
private static function trackToJson(Track $track, bool $includeComments, bool $includeStreamUrl)
|
|
|
|
{
|
2017-10-29 01:44:08 +02:00
|
|
|
$trackResponse = [
|
2015-08-31 16:30:02 +02:00
|
|
|
'id' => $track->id,
|
|
|
|
'title' => $track->title,
|
|
|
|
'description' => $track->description,
|
|
|
|
'lyrics' => $track->lyrics,
|
|
|
|
'user' => [
|
|
|
|
'id' => $track->user->id,
|
|
|
|
'name' => $track->user->display_name,
|
|
|
|
'url' => $track->user->url,
|
|
|
|
'avatars' => [
|
|
|
|
'thumbnail' => $track->user->getAvatarUrl(Image::THUMBNAIL),
|
|
|
|
'small' => $track->user->getAvatarUrl(Image::SMALL),
|
2021-02-14 03:39:15 +01:00
|
|
|
'normal' => $track->user->getAvatarUrl(Image::NORMAL),
|
|
|
|
],
|
2015-08-31 16:30:02 +02:00
|
|
|
],
|
|
|
|
'stats' => [
|
|
|
|
'views' => $track->view_count,
|
|
|
|
'plays' => $track->play_count,
|
|
|
|
'downloads' => $track->download_count,
|
|
|
|
'comments' => $track->comment_count,
|
2021-02-14 03:39:15 +01:00
|
|
|
'favourites' => $track->favourite_count,
|
2015-08-31 16:30:02 +02:00
|
|
|
],
|
|
|
|
'url' => $track->url,
|
2021-02-14 03:39:15 +01:00
|
|
|
'is_vocal' => (bool) $track->is_vocal,
|
|
|
|
'is_explicit' => (bool) $track->is_explicit,
|
|
|
|
'is_downloadable' => (bool) $track->is_downloadable,
|
2015-08-31 16:30:02 +02:00
|
|
|
'published_at' => $track->published_at,
|
|
|
|
'duration' => $track->duration,
|
|
|
|
'genre' => $track->genre != null
|
|
|
|
?
|
|
|
|
[
|
|
|
|
'id' => $track->genre->id,
|
2021-02-14 03:39:15 +01:00
|
|
|
'name' => $track->genre->name,
|
2015-08-31 16:30:02 +02:00
|
|
|
] : null,
|
|
|
|
'type' => [
|
2017-10-29 01:44:08 +02:00
|
|
|
'id' => $track->trackType->id,
|
2021-02-14 03:39:15 +01:00
|
|
|
'name' => $track->trackType->title,
|
2015-08-31 16:30:02 +02:00
|
|
|
],
|
|
|
|
'covers' => [
|
|
|
|
'thumbnail' => $track->getCoverUrl(Image::THUMBNAIL),
|
|
|
|
'small' => $track->getCoverUrl(Image::SMALL),
|
2021-02-14 03:39:15 +01:00
|
|
|
'normal' => $track->getCoverUrl(Image::NORMAL),
|
2015-08-31 16:30:02 +02:00
|
|
|
],
|
2015-10-28 08:05:37 +01:00
|
|
|
|
2017-10-29 01:44:08 +02:00
|
|
|
// As of 2017-10-28, this should be expected to produce
|
2017-10-29 01:50:15 +02:00
|
|
|
// "direct_upload", "mlpma", "ponify", or "eqbeats" for all tracks.
|
2021-02-14 03:39:15 +01:00
|
|
|
'source' => $track->source,
|
2017-10-29 01:44:08 +02:00
|
|
|
];
|
|
|
|
|
|
|
|
if ($includeComments) {
|
|
|
|
$comments = [];
|
|
|
|
foreach ($track->comments as $comment) {
|
|
|
|
$comments[] = [
|
|
|
|
'id' => $comment->id,
|
|
|
|
'created_at' => $comment->created_at,
|
|
|
|
'content' => $comment->content,
|
|
|
|
'user' => [
|
|
|
|
'name' => $comment->user->display_name,
|
|
|
|
'id' => $comment->user->id,
|
|
|
|
'url' => $comment->user->url,
|
|
|
|
'avatars' => [
|
|
|
|
'normal' => $comment->user->getAvatarUrl(Image::NORMAL),
|
|
|
|
'thumbnail' => $comment->user->getAvatarUrl(Image::THUMBNAIL),
|
|
|
|
'small' => $comment->user->getAvatarUrl(Image::SMALL),
|
2021-02-14 03:39:15 +01:00
|
|
|
],
|
|
|
|
],
|
2017-10-29 01:44:08 +02:00
|
|
|
];
|
|
|
|
}
|
|
|
|
|
|
|
|
$trackResponse['comments'] = $comments;
|
|
|
|
}
|
|
|
|
|
|
|
|
if ($includeStreamUrl) {
|
|
|
|
$trackResponse['streams'] = [
|
|
|
|
'mp3' => [
|
|
|
|
'url' => $track->getStreamUrl('MP3', session('api_client_id')),
|
|
|
|
'mime_type' => Track::$Formats['MP3']['mime_type'],
|
2021-02-14 03:39:15 +01:00
|
|
|
],
|
2017-10-29 01:44:08 +02:00
|
|
|
];
|
|
|
|
}
|
|
|
|
|
|
|
|
return $trackResponse;
|
2015-08-31 16:30:02 +02:00
|
|
|
}
|
2015-10-25 06:17:45 +01:00
|
|
|
}
|