mediaInformationService = $mediaInformationService; $this->streamerFactory = $streamerFactory; $this->artistRepository = $artistRepository; $this->albumRepository = $albumRepository; } /** * Play a song * * The GET request to play/stream a song. By default Koel will serve the file as-is, unless it's a FLAC. * If the value of `transcode` is truthy, Koel will attempt to transcode the file into `bitRate`kbps using ffmpeg. * * @response {} * * @queryParam jwt-token required The JWT token. * * @see https://github.com/phanan/koel/wiki#streaming-music * * @param bool|null $transcode Whether to force transcoding the song. * If this is omitted, by default Koel will transcode FLAC. * @param int|null $bitRate The target bit rate to transcode, defaults to OUTPUT_BIT_RATE. * Only taken into account if $transcode is truthy. * * @return RedirectResponse|Redirector */ public function play(SongPlayRequest $request, Song $song, ?bool $transcode = null, ?int $bitRate = null) { return $this->streamerFactory ->createStreamer($song, $transcode, $bitRate, floatval($request->time)) ->stream(); } /** * Update song information * * @bodyParam songs array required An array of song IDs to be updated. * @bodyParam data object required The new data, with these supported fields: `title`, `artistName`, `albumName`, and `lyrics`. * * @group 5. Media information * * @return JsonResponse */ public function update(SongUpdateRequest $request) { $updatedSongs = Song::updateInfo($request->songs, $request->data); return response()->json([ 'artists' => $this->artistRepository->getByIds($updatedSongs->pluck('artist_id')->all()), 'albums' => $this->albumRepository->getByIds($updatedSongs->pluck('album_id')->all()), 'songs' => $updatedSongs, ]); } }