WWW::TheEchoNest::TasteProfile - Wrapper for The Echo Nest API of music intelligence Taste Profiles
version 1.1
my $api_key = $ENV{EN_API_KEY} || 'YOUR EN API KEY';
my $tasteprofile = WWW::TheEchoNest::TasteProfile->new( api_key => $api_key );
# don't do this in the real world! each taste profile name has to be unique # so create something to ensure you can locate them in the future
my $cat_name = "WWWTheEchoNestTest_$$" . rand(1000);
# create an artist tasteprofile
$tasteprofile->create( type => 'artist' , name => $cat_name );
my $tasteprofile_id = $tasteprofile->get( 'id' );
Allows for interacting with The Echo Nest Taste Profile (/tasteprofile) calls
The taste profile calls rely on json that is passed in to perform certain actions so you should have a good JSON checker handy. This module provides a crude good or bad method you can use to check the JSON before sending. See the synopsis below.
All modules use Moose so 'use strict' will be auto loaded with in your script so beaware of how you scope your variables if you are new to Perl.
WWW::TheEchoNest::TasteProfile
Ban a particular taste profile item. This can also be done through the update method, but this method only allows for one item at a time.
$tasteprofile->ban( id => 'CAxxxxxxxxxxxxxxxx', item => 'theItemName' );
$tasteprofile->create();
$tasteprofile->delete();
$tasteprofile->favorite();
$tasteprofile->feed();
$tasteprofile->keyvalues();
$tasteprofile->list();
$tasteprofile->play();
$tasteprofile->predict();
$tasteprofile->profile( id => 'CAxxxxxxxxxxxxxxxx' ); # if tasteprofile exists my $tickets = $tasteprofile->get( 'tasteprofile.pending_tickets' ); # the above will return an array ref that contains the list of # of pending tickts if any. my ($total,$resolved) = $tasteprofile->get( 'tasteprofile.total', 'tasteprofile.resolved' ); print "There are $total items in 'CAxxxxxxxxxxxxxxxx' and $resolved of them have been resolved\n";
Allows you to rate a particular taste profile item.
$tasteprofile->rate( id => 'CAxxxxxxxxxxxxxxxx', item => 'theItemName' ); # defaults to 5 you can also pass in 0 - 10 $tasteprofile->rate( 'CAxxxxxxxxxxxxxxxx', item => 'theItemName', rating => 9 );
$tasteprofile->read();
$tasteprofile->similar();
$tasteprofile->skip();
Get the status of an update that has been sent. You must have a ticket to reference. A ticket is a md5 checksum that is returned with the update call.
$tasteprofile->status( ticket => 'abcdeabcdeabcdeabcdeabcdeabcdeab' );
Send in a block of JSON that contains a properly formatted list of items you would like to update.
my $keyvalue_json = qq~[ { "action": "update", "item": { "item_id": "kfw", "item_keyvalues": { "class" : ["Primary", "Gold", "Deep Track"], "sound" : ["female", "disco", "pop"], "mood" : "upbeat", "rating" : 10, "tempo" : ["fast", "fast"] } } } ]~; $tasteprofile->update( id => 'CAxxxxxxxxxxxxxxxx', data => $keyvalue_json );
This method can also be used to update the taste profile (not the items) with key value pairs. The Echo Nest documentation contain more specifics on what is allowed.
my $tasteprofile_kv_json = qq~[ { "action":"update", "tasteprofile_keyvalues": { "type": "user", "gender": "male", "yob": "1959", "zipcode": "03101" } } ]~; $tasteprofile->update( id => 'CAxxxxxxxxxxxxxxxx', data => $tasteprofile_kv_json );
Reminder that "tasteprofile_keyvalues" is for the *tasteprofile* not the individual items.
Aaron Johnson <aaronjjohnson@gmail.com>
This software is copyright (c) 2014 by Aaron Johnson.
This is free software; you can redistribute it and/or modify it under the same terms as the Perl 5 programming language system itself.
To install WWW::TheEchoNest, copy and paste the appropriate command in to your terminal.
cpanm
cpanm WWW::TheEchoNest
CPAN shell
perl -MCPAN -e shell install WWW::TheEchoNest
For more information on module installation, please visit the detailed CPAN module installation guide.