From 07206a0ac38c9639afea06a893d82c23cc36902c Mon Sep 17 00:00:00 2001 From: reality Date: Fri, 25 Oct 2013 15:36:53 +0000 Subject: [PATCH] artists --- modules/lastfm/lastfm.js | 25 +++++++++++++++++++++++++ modules/lastfm/strings.json | 3 +++ 2 files changed, 28 insertions(+) diff --git a/modules/lastfm/lastfm.js b/modules/lastfm/lastfm.js index e13eb63..4b773c6 100644 --- a/modules/lastfm/lastfm.js +++ b/modules/lastfm/lastfm.js @@ -224,9 +224,34 @@ var lastfm = function(dbot) { } } }); + }, + + '~artists': function(event) { + var u1 = event.rUser, + lfm1 = event.rProfile.lastfm, + u2 = event.res[0].user, + lfm2 = event.res[0].lfm; + + this.api.tasteCompare(event.rProfile.lastfm, lfm2, function(err, comp) { + if(!err) { + var artists = _.pluck(comp.artists.artist, 'name').join(', '); + event.reply(dbot.t('common_artists', { + 'user1': event.user, + 'user2': u2.currentNick, + 'common': artists + })); + } else { + if(err == 'no_user') { + event.reply('Unknown Last.FM user.'); + } else { + event.reply('Well something went wrong and I don\'t know what it means'); + } + } + }); } }; this.commands['~taste'].regex = [/^~taste ([\d\w[\]{}^|\\`_-]+?)/, 2]; + this.commands['~artists'].regex = [/^~artists ([\d\w[\]{}^|\\`_-]+?)/, 2]; _.each(this.commands, function(command) { command.resolver = function(event, callback) { diff --git a/modules/lastfm/strings.json b/modules/lastfm/strings.json index dda2848..f1aba18 100644 --- a/modules/lastfm/strings.json +++ b/modules/lastfm/strings.json @@ -11,6 +11,9 @@ "taste_compat": { "en": "{user1} and {user2} are {score}% musically compatible!" }, + "common_artists": { + "en": "Artists {user1} and {user2} have in common: {common}" + }, "lfm_suggestion": { "en": "{user}: Try listening to {name} by {artist}" }