echonest_resource 0.0.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- data/.gitignore +4 -0
- data/Gemfile +4 -0
- data/README.md +72 -0
- data/Rakefile +1 -0
- data/echonest_resource.gemspec +25 -0
- data/lib/echonest_resource/base.rb +75 -0
- data/lib/echonest_resource/version.rb +3 -0
- data/lib/echonest_resource.rb +19 -0
- metadata +75 -0
data/.gitignore
ADDED
data/Gemfile
ADDED
data/README.md
ADDED
@@ -0,0 +1,72 @@
|
|
1
|
+
# Echonest gem
|
2
|
+
|
3
|
+
## Installation
|
4
|
+
|
5
|
+
Add the gem to your Gemfile
|
6
|
+
|
7
|
+
``` ruby
|
8
|
+
gem "echonest_resource"
|
9
|
+
```
|
10
|
+
|
11
|
+
Obtain an API key from echonest and create a file called 'echonest.yml' in your /config directory
|
12
|
+
|
13
|
+
``` ruby
|
14
|
+
api_key = "YOUR_API_KEY"
|
15
|
+
```
|
16
|
+
|
17
|
+
## Usage
|
18
|
+
|
19
|
+
Right now the gem supports two Echonest resources: Artist and Song
|
20
|
+
|
21
|
+
### Artist
|
22
|
+
|
23
|
+
``` ruby
|
24
|
+
class Artist < ActiveResource::Base
|
25
|
+
include EchonestResource::Base
|
26
|
+
echonest_resource :artist
|
27
|
+
end
|
28
|
+
```
|
29
|
+
|
30
|
+
``` ruby
|
31
|
+
class Artist < ActiveResource::Base
|
32
|
+
include EchonestResource::Base
|
33
|
+
echonest_resource :song
|
34
|
+
end
|
35
|
+
```
|
36
|
+
|
37
|
+
Now you can search for an artist:
|
38
|
+
|
39
|
+
``` ruby
|
40
|
+
artists = Artist.search("Macklemore")
|
41
|
+
```
|
42
|
+
|
43
|
+
The search method also accepts an options hash where you can specify things like: results, bucket, sort
|
44
|
+
|
45
|
+
|
46
|
+
``` ruby
|
47
|
+
artists = Artist.search("Macklemore", {:results => 20, :sort => "hotttnesss-desc"})
|
48
|
+
```
|
49
|
+
|
50
|
+
### Song
|
51
|
+
|
52
|
+
You can search for songs for an artist name
|
53
|
+
|
54
|
+
``` ruby
|
55
|
+
songs = Song.find_by_artist_name("Macklemore")
|
56
|
+
```
|
57
|
+
|
58
|
+
The find_by_artist_name method also accepts an options hash
|
59
|
+
|
60
|
+
``` ruby
|
61
|
+
songs = Song.find_by_artist_name("Macklemore", :sort => "song_hotttnesss")
|
62
|
+
```
|
63
|
+
|
64
|
+
You can retrieve additional information by specifying a bucket like so:
|
65
|
+
|
66
|
+
``` ruby
|
67
|
+
songs = Song.find_by_artist_name("Macklemore", :sort => "duration-desc", :bucket => "audio_summary")
|
68
|
+
```
|
69
|
+
|
70
|
+
|
71
|
+
All the attributes on the songs use the same name as the Echonest API (http://developer.echonest.com/docs/v4)
|
72
|
+
|
data/Rakefile
ADDED
@@ -0,0 +1 @@
|
|
1
|
+
require "bundler/gem_tasks"
|
@@ -0,0 +1,25 @@
|
|
1
|
+
# -*- encoding: utf-8 -*-
|
2
|
+
$:.push File.expand_path("../lib", __FILE__)
|
3
|
+
require "echonest_resource/version"
|
4
|
+
|
5
|
+
Gem::Specification.new do |s|
|
6
|
+
s.name = "echonest_resource"
|
7
|
+
s.version = EchonestResource::VERSION
|
8
|
+
s.authors = ["tzumby"]
|
9
|
+
s.email = ["tzumby@gmail.com"]
|
10
|
+
s.homepage = ""
|
11
|
+
s.summary = %q{Echonest API Wrapper}
|
12
|
+
s.description = %q{Use this gem to search the Echonest API for Artists and Songs}
|
13
|
+
|
14
|
+
s.rubyforge_project = "echonest_resource"
|
15
|
+
|
16
|
+
s.files = `git ls-files`.split("\n")
|
17
|
+
s.test_files = `git ls-files -- {test,spec,features}/*`.split("\n")
|
18
|
+
s.executables = `git ls-files -- bin/*`.split("\n").map{ |f| File.basename(f) }
|
19
|
+
s.require_paths = ["lib"]
|
20
|
+
|
21
|
+
# specify any dependencies here; for example:
|
22
|
+
# s.add_development_dependency "rspec"
|
23
|
+
s.add_runtime_dependency "httparty"
|
24
|
+
s.add_runtime_dependency "hashie"
|
25
|
+
end
|
@@ -0,0 +1,75 @@
|
|
1
|
+
module EchonestResource
|
2
|
+
module Base
|
3
|
+
|
4
|
+
def self.included(base)
|
5
|
+
base.extend(ClassMethods)
|
6
|
+
end
|
7
|
+
|
8
|
+
module ClassMethods
|
9
|
+
|
10
|
+
def request_params
|
11
|
+
{
|
12
|
+
:api_key => EchonestResource.api_key,
|
13
|
+
:results => 1
|
14
|
+
}
|
15
|
+
end
|
16
|
+
|
17
|
+
def echonest_resource(resource)
|
18
|
+
raise StandardError if resource.blank?
|
19
|
+
|
20
|
+
include HTTParty
|
21
|
+
base_uri 'http://developer.echonest.com/api/v4'
|
22
|
+
format :json
|
23
|
+
|
24
|
+
case resource
|
25
|
+
when :artist
|
26
|
+
instance_eval <<-EOV
|
27
|
+
def search(name, options={})
|
28
|
+
raise StandardError if name.blank?
|
29
|
+
|
30
|
+
results = Hashie::Mash.new(self.get('/artist/search', :query =>
|
31
|
+
request_params.merge({:name => name}).merge(options)
|
32
|
+
))
|
33
|
+
if results.response && results.response.artists; results.response.artists; end;
|
34
|
+
end
|
35
|
+
EOV
|
36
|
+
when :song
|
37
|
+
instance_eval <<-EOV
|
38
|
+
|
39
|
+
def find_by_artist_id(id, options={})
|
40
|
+
raise StandardError if id.blank?
|
41
|
+
|
42
|
+
results = Hashie::Mash.new(self.get('/song/search', :query =>
|
43
|
+
request_params.merge(options).merge({
|
44
|
+
:artist_id => id
|
45
|
+
})
|
46
|
+
))
|
47
|
+
if results.response && results.response.songs; results.response.songs; end;
|
48
|
+
end
|
49
|
+
|
50
|
+
def find_by_artist_name(name, options={})
|
51
|
+
raise StandardError if name.blank?
|
52
|
+
|
53
|
+
if artist = Artist.search(:name => name)
|
54
|
+
Song.find_by_id(artist.first.id, options)
|
55
|
+
end
|
56
|
+
end
|
57
|
+
|
58
|
+
def search(title, options={})
|
59
|
+
raise StandardError if title.blank?
|
60
|
+
|
61
|
+
results = Hashie::Mash.new(self.get('/song/search', :query =>
|
62
|
+
request_params.merge({:title => title}).merge(options)
|
63
|
+
))
|
64
|
+
results
|
65
|
+
end
|
66
|
+
|
67
|
+
|
68
|
+
EOV
|
69
|
+
end
|
70
|
+
|
71
|
+
end
|
72
|
+
end
|
73
|
+
|
74
|
+
end
|
75
|
+
end
|
@@ -0,0 +1,19 @@
|
|
1
|
+
require "echonest_resource/version"
|
2
|
+
require 'active_support'
|
3
|
+
require 'httparty'
|
4
|
+
require 'hashie'
|
5
|
+
|
6
|
+
class APIKeyMissing < StandardError; end
|
7
|
+
class MissingConfigFile < StandardError; end
|
8
|
+
|
9
|
+
module EchonestResource
|
10
|
+
def self.api_key
|
11
|
+
echonest_config = YAML.load_file("#{Rails.root}/config/echonest.yml")
|
12
|
+
raise MissingConfigFile if echonest_config.blank?
|
13
|
+
echonest_config["api_key"]
|
14
|
+
end
|
15
|
+
end
|
16
|
+
|
17
|
+
directory = File.expand_path(File.dirname(__FILE__))
|
18
|
+
|
19
|
+
require File.join(directory, 'echonest_resource', 'base')
|
metadata
ADDED
@@ -0,0 +1,75 @@
|
|
1
|
+
--- !ruby/object:Gem::Specification
|
2
|
+
name: echonest_resource
|
3
|
+
version: !ruby/object:Gem::Version
|
4
|
+
version: 0.0.1
|
5
|
+
prerelease:
|
6
|
+
platform: ruby
|
7
|
+
authors:
|
8
|
+
- tzumby
|
9
|
+
autorequire:
|
10
|
+
bindir: bin
|
11
|
+
cert_chain: []
|
12
|
+
date: 2012-02-27 00:00:00.000000000 Z
|
13
|
+
dependencies:
|
14
|
+
- !ruby/object:Gem::Dependency
|
15
|
+
name: httparty
|
16
|
+
requirement: &70308245661760 !ruby/object:Gem::Requirement
|
17
|
+
none: false
|
18
|
+
requirements:
|
19
|
+
- - ! '>='
|
20
|
+
- !ruby/object:Gem::Version
|
21
|
+
version: '0'
|
22
|
+
type: :runtime
|
23
|
+
prerelease: false
|
24
|
+
version_requirements: *70308245661760
|
25
|
+
- !ruby/object:Gem::Dependency
|
26
|
+
name: hashie
|
27
|
+
requirement: &70308245660520 !ruby/object:Gem::Requirement
|
28
|
+
none: false
|
29
|
+
requirements:
|
30
|
+
- - ! '>='
|
31
|
+
- !ruby/object:Gem::Version
|
32
|
+
version: '0'
|
33
|
+
type: :runtime
|
34
|
+
prerelease: false
|
35
|
+
version_requirements: *70308245660520
|
36
|
+
description: Use this gem to search the Echonest API for Artists and Songs
|
37
|
+
email:
|
38
|
+
- tzumby@gmail.com
|
39
|
+
executables: []
|
40
|
+
extensions: []
|
41
|
+
extra_rdoc_files: []
|
42
|
+
files:
|
43
|
+
- .gitignore
|
44
|
+
- Gemfile
|
45
|
+
- README.md
|
46
|
+
- Rakefile
|
47
|
+
- echonest_resource.gemspec
|
48
|
+
- lib/echonest_resource.rb
|
49
|
+
- lib/echonest_resource/base.rb
|
50
|
+
- lib/echonest_resource/version.rb
|
51
|
+
homepage: ''
|
52
|
+
licenses: []
|
53
|
+
post_install_message:
|
54
|
+
rdoc_options: []
|
55
|
+
require_paths:
|
56
|
+
- lib
|
57
|
+
required_ruby_version: !ruby/object:Gem::Requirement
|
58
|
+
none: false
|
59
|
+
requirements:
|
60
|
+
- - ! '>='
|
61
|
+
- !ruby/object:Gem::Version
|
62
|
+
version: '0'
|
63
|
+
required_rubygems_version: !ruby/object:Gem::Requirement
|
64
|
+
none: false
|
65
|
+
requirements:
|
66
|
+
- - ! '>='
|
67
|
+
- !ruby/object:Gem::Version
|
68
|
+
version: '0'
|
69
|
+
requirements: []
|
70
|
+
rubyforge_project: echonest_resource
|
71
|
+
rubygems_version: 1.8.11
|
72
|
+
signing_key:
|
73
|
+
specification_version: 3
|
74
|
+
summary: Echonest API Wrapper
|
75
|
+
test_files: []
|