Skip to content

Commit

Permalink
Add updateNowPlaying for Last.fm
Browse files Browse the repository at this point in the history
  • Loading branch information
An Phan committed Dec 23, 2015
1 parent 5e79a27 commit a083696
Show file tree
Hide file tree
Showing 8 changed files with 151 additions and 3 deletions.
45 changes: 45 additions & 0 deletions app/Events/SongStartedPlaying.php
Original file line number Diff line number Diff line change
@@ -0,0 +1,45 @@
<?php

namespace App\Events;

use App\Models\Song;
use App\Models\User;
use Illuminate\Queue\SerializesModels;

class SongStartedPlaying extends Event
{
use SerializesModels;

/**
* The now playing song.
*
* @var Song
*/
public $song;

/**
* The user listening.
*
* @var User
*/
public $user;

/**
* Create a new event instance.
*/
public function __construct(Song $song, User $user)
{
$this->song = $song;
$this->user = $user;
}

/**
* Get the channels the event should be broadcast on.
*
* @return array
*/
public function broadcastOn()
{
return [];
}
}
7 changes: 6 additions & 1 deletion app/Http/Controllers/API/InteractionController.php
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,7 @@

namespace App\Http\Controllers\API;

use App\Events\SongStartedPlaying;
use App\Http\Requests\API\BatchInteractionRequest;
use App\Models\Interaction;
use Illuminate\Http\Request;
Expand All @@ -17,7 +18,11 @@ class InteractionController extends Controller
*/
public function play(Request $request)
{
return response()->json(Interaction::increasePlayCount($request->input('id'), $request->user()));
if ($interaction = Interaction::increasePlayCount($request->input('id'), $request->user())) {
event(new SongStartedPlaying($interaction->song, $interaction->user));
}

return response()->json($interaction);
}

/**
Expand Down
48 changes: 48 additions & 0 deletions app/Listeners/UpdateLastfmNowPlaying.php
Original file line number Diff line number Diff line change
@@ -0,0 +1,48 @@
<?php

namespace App\Listeners;

use App\Events\SongStartedPlaying;
use App\Models\Album;
use App\Services\Lastfm;

class UpdateLastfmNowPlaying
{
/**
* The Last.fm service instance.
*
* @var Lastfm
*/
protected $lastfm;

/**
* Create the event listener.
*/
public function __construct(Lastfm $lastfm)
{
$this->lastfm = $lastfm;
}

/**
* Handle the event.
*
* @param SongStartedPlaying $event
*/
public function handle(SongStartedPlaying $event)
{
if (!$this->lastfm->enabled() ||
!($sessionKey = $event->user->getLastfmSessionKey()) ||
$event->song->album->artist->isUnknown()
) {
return;
}

$this->lastfm->updateNowPlaying(
$event->song->album->artist->name,
$event->song->title,
$event->song->album->name === Album::UNKNOWN_NAME ? null : $event->song->album->name,
$event->song->length,
$sessionKey
);
}
}
3 changes: 3 additions & 0 deletions app/Providers/EventServiceProvider.php
Original file line number Diff line number Diff line change
Expand Up @@ -19,6 +19,9 @@ class EventServiceProvider extends ServiceProvider
'App\Events\SongLikeToggled' => [
'App\Listeners\LoveTrackOnLastfm',
],
'App\Events\SongStartedPlaying' => [
'App\Listeners\UpdateLastfmNowPlaying',
],
];

/**
Expand Down
29 changes: 29 additions & 0 deletions app/Services/Lastfm.php
Original file line number Diff line number Diff line change
Expand Up @@ -233,6 +233,35 @@ public function toggleLoveTrack($track, $artist, $sk, $love = true)
}
}

/**
* Update a track's "now playing" on Last.fm.
*
* @param string $artist Name of the artist
* @param string $track Name of the track
* @param string $album Name of the album
* @param int|float $duration Duration of the track, in seconds
* @param string $sk The session key
*
* @return bool
*/
public function updateNowPlaying($artist, $track, $album, $duration, $sk)
{
$params = compact('artist', 'track', 'duration', 'sk');
$params['method'] = 'track.updateNowPlaying';

if ($album) {
$params['album'] = $album;
}

try {
return (bool) $this->post('/', $this->buildAuthCallParams($params), false);
} catch (\Exception $e) {
Log::error($e);

return false;
}
}

/**
* Build the parameters to use for _authenticated_ Last.fm API calls.
* Such calls require:
Expand Down
2 changes: 1 addition & 1 deletion resources/assets/js/services/playback.js
Original file line number Diff line number Diff line change
Expand Up @@ -93,7 +93,7 @@ export default {
this.player.source(`/api/${song.id}/play`);
this.player.play();

// Register the play count to the server
// Register the play to the server
songStore.registerPlay(song);

// Show the notification if we're allowed to
Expand Down
1 change: 1 addition & 0 deletions tests/InteractionTest.php
Original file line number Diff line number Diff line change
Expand Up @@ -20,6 +20,7 @@ public function setUp()

public function testPlayCountRegister()
{
$this->withoutEvents();
$user = factory(User::class)->create();

$song = Song::orderBy('id')->first();
Expand Down
19 changes: 18 additions & 1 deletion tests/LastfmTest.php
Original file line number Diff line number Diff line change
@@ -1,8 +1,10 @@
<?php

use App\Events\SongLikeToggled;
use App\Events\SongStartedPlaying;
use App\Http\Controllers\API\LastfmController;
use App\Listeners\LoveTrackOnLastfm;
use App\Listeners\UpdateLastfmNowPlaying;
use App\Models\Interaction;
use App\Models\Song;
use App\Models\User;
Expand Down Expand Up @@ -170,8 +172,23 @@ public function testLoveTrack()

$lastfm = m::mock(Lastfm::class, ['enabled' => true]);
$lastfm->shouldReceive('toggleLoveTrack')
->withArgs([$interaction->song->title, $interaction->song->album->artist->name, 'bar', false]);
->with($interaction->song->title, $interaction->song->album->artist->name, 'bar', false);

(new LoveTrackOnLastfm($lastfm))->handle(new SongLikeToggled($interaction, $user));
}

public function testUpdateNowPlaying()
{
$this->withoutEvents();
$this->createSampleMediaSet();

$user = factory(User::class)->create(['preferences' => ['lastfm_session_key' => 'bar']]);
$song = Song::first();

$lastfm = m::mock(Lastfm::class, ['enabled' => true]);
$lastfm->shouldReceive('updateNowPlaying')
->with($song->album->artist->name, $song->title, $song->album->name, $song->length, 'bar');

(new UpdateLastfmNowPlaying($lastfm))->handle(new SongStartedPlaying($song, $user));
}
}

0 comments on commit a083696

Please sign in to comment.