Gem to make interacting with http://api.dirble.com/ amazingly easy. Using familiar Rails syntax. It uses Faraday and Typhoeus as adapter.
- Ruby 1.9.3 and 2
- Rubinius
Add this line to your application's Gemfile:
gem 'dirble'
And then execute:
$ bundle
Or install it yourself as:
$ gem install dirble
In Rails: Put this quick configuration block in environment file. Beyond Rails: Put this in initialization or config file.
Dirble.configure do |config|
config.api_key = "valid_api_key_from_dirble"
end
Now you are ready to go.
-
Fetch all categories with
Dirble::Category.all
-
Fetch primary categories with
Dirble::Category.primary
orDirble::PrimaryCategory.all
-
Find category by id
Dirble::Category.find(2)
-
Get first category
Dirble::Category.first
-
Find children of primary category
primary_category = Dirble::PrimaryCategory.first
children = primary_category.children
-
Find stations of category
category.stations
-
Category details
category.id
category.name
category.description
-
Search stations
Dirble::Station.search('pop')
-
Stations by continent
Dirble::Station.by_continent('Asia')
-
Stations by country using iso code
Dirble::Station.by_country('us')
-
Stations by country name
Dirbel::Station.by_country_name('United States')
-
Find station by id
Dirble::Station.find(100)
-
Get similar stations
Dirble::Station.similar(100)
-
Station details
station.name
station.website
station.bitrate
station.directory
station.description
station.stream_url
station.status
-
Accessing song history by station, information available only after
Dirble::Station.find(id)
station.song_history
Songs in song history have many interesting informations.
-
Name and title
song.name
song.title
-
Spotify url
song.spotify_url
-
When last played on particular station
song.played_on
- Add parallel connections with Typhoeus
- Fork it ( https://github.com/[my-github-username]/dirble/fork )
- Create your feature branch (
git checkout -b my-new-feature
) - Commit your changes (
git commit -am 'Add some feature'
) - Push to the branch (
git push origin my-new-feature
) - Create a new Pull Request