'string', 'length' => 'float', ]; public function album() { return $this->belongsTo(Album::class); } public function playlists() { return $this->belongsToMany(Playlist::class); } /** * Scrobble the song using Last.fm service. * * @param string $timestamp The UNIX timestamp in which the song started playing. * * @return mixed */ public function scrobble($timestamp) { // Don't scrobble the unknown guys. No one knows them. if ($this->album->artist->isUnknown()) { return false; } // If the current user hasn't connected to Last.fm, don't do shit. if (!$sessionKey = auth()->user()->getLastfmSessionKey()) { return false; } return Lastfm::scrobble( $this->album->artist->name, $this->title, $timestamp, $this->album->name === Album::UNKNOWN_NAME ? '' : $this->album->name, $sessionKey ); } /** * Sometimes the tags extracted from getID3 are HTML entity encoded. * This makes sure they are always sane. * * @param $value */ public function setTitleAttribute($value) { $this->attributes['title'] = html_entity_decode($value); } /** * Some songs don't have a title. * Fall back to the file name (without extension) for such. * * @param $value * * @return string */ public function getTitleAttribute($value) { return $value ?: pathinfo($this->path, PATHINFO_FILENAME); } /** * Prepare the lyrics for displaying. * * @param $value * * @return string */ public function getLyricsAttribute($value) { return nl2br($value); } }