Models moved into module, safe loading, v0.2.0

This commit is contained in:
Gregory Eremin
2011-09-13 14:06:52 +04:00
parent dadf0de159
commit 6a2720e637
13 changed files with 177 additions and 146 deletions
+26
View File
@@ -0,0 +1,26 @@
module MusicBrainz
@@last_query_time = 0
def self.last_query_time
@@last_query_time
end
def self.last_query_time= time
@@last_query_time = time
end
def self.load url
sleep 1.1 - (Time.now.to_f - self.last_query_time) if Time.now.to_f - self.last_query_time < 1.1
response = nil
5.times do
begin
response = open(url, "User-Agent" => "gem musicbrainz (https://github.com/magnolia-fan/musicbrainz) @ " + Socket.gethostname)
rescue => e
p "MusicBrainz: 503"
end
break unless response.nil?
end
self.last_query_time = Time.now.to_f
response
end
end
+31
View File
@@ -0,0 +1,31 @@
module MusicBrainz
class Artist
attr_accessor :id, :type, :name, :country, :date_begin, :date_end
@release_groups
def release_groups
if @release_groups.nil? and not self.id.nil?
@release_groups = []
Nokogiri::XML(MusicBrainz.load('http://musicbrainz.org/ws/2/release-group/?artist=' + self.id)).css('release-group').each do |rg|
@release_groups << MusicBrainz::ReleaseGroup.parse_xml(rg)
end
end
@release_groups
end
def self.find mbid
@artist = self.parse_xml(Nokogiri::XML(MusicBrainz.load('http://musicbrainz.org/ws/2/artist/' + mbid)))
end
def self.parse_xml xml
@artist = MusicBrainz::Artist.new
@artist.id = xml.css('artist').attr('id').value
@artist.type = xml.css('artist').attr('type').value
@artist.name = xml.css('artist > name').text
@artist.country = xml.css('artist > country').text || nil
@artist.date_begin = xml.css('artist > life-span > begin').text || nil
@artist.date_end = xml.css('artist > life-span > end').text || nil
@artist
end
end
end
+40
View File
@@ -0,0 +1,40 @@
module MusicBrainz
class Release
attr_accessor :id, :title, :status, :date, :country
@tracks
def tracks
if @tracks.nil? and not self.id.nil?
@tracks = []
Nokogiri::XML(MusicBrainz.load('http://musicbrainz.org/ws/2/release/' + self.id + '?inc=recordings')).css('medium-list > medium > track-list > track').each do |r|
@tracks << MusicBrainz::Track.parse_xml(r)
end
end
@tracks
end
def self.find mbid
xml = Nokogiri::XML(MusicBrainz.load('http://musicbrainz.org/ws/2/release/' + mbid)).css('release').first
self.parse_xml(xml) unless xml.nil?
end
def self.parse_xml xml
@release = MusicBrainz::Release.new
@release.id = xml.attr('id')
@release.title = xml.css('title').text
@release.status = xml.css('status').text
date = xml.css('date').text
unless date.nil? or date.empty?
if date.length == 4
date += '-01-01'
elsif date.length == 7
date += '-01'
end
date = Time.parse(date)
end
@release.date = date
@release.country = xml.css('country').text
@release
end
end
end
+39
View File
@@ -0,0 +1,39 @@
module MusicBrainz
class ReleaseGroup
attr_accessor :id, :type, :title, :first_release_date
@releases
def releases
if @releases.nil? and not self.id.nil?
@releases = []
Nokogiri::XML(MusicBrainz.load('http://musicbrainz.org/ws/2/release/?release-group=' + self.id)).css('release').each do |r|
@releases << MusicBrainz::Release.parse_xml(r)
end
end
@releases
end
def self.find mbid
xml = Nokogiri::XML(MusicBrainz.load('http://musicbrainz.org/ws/2/release-group/' + mbid)).css('release-group').first
self.parse_xml(xml) unless xml.nil?
end
def self.parse_xml xml
@release_group = MusicBrainz::ReleaseGroup.new
@release_group.id = xml.attr('id')
@release_group.type = xml.attr('type')
@release_group.title = xml.css('title').text
date = xml.css('first-release-date').text
unless date.nil? or date.empty?
if date.length == 4
date += '-01-01'
elsif date.length == 7
date += '-01'
end
date = Time.parse(date)
end
@release_group.first_release_date = date
@release_group
end
end
end
+19
View File
@@ -0,0 +1,19 @@
module MusicBrainz
class Track
attr_accessor :position, :recording_id, :title, :length
def self.find mbid
xml = Nokogiri::XML(MusicBrainz.load('http://musicbrainz.org/ws/2/recording/' + mbid))
self.parse_xml(xml) unless xml.nil?
end
def self.parse_xml xml
@track = MusicBrainz::Track.new
@track.position = xml.css('position').text.to_i || nil
@track.recording_id = xml.css('recording').attr('id').value
@track.title = xml.css('recording > title').text
@track.length = xml.css('length').first.text.to_i || 0
@track
end
end
end
-30
View File
@@ -1,30 +0,0 @@
class MusicBrainzArtist
attr_accessor :id, :type, :name, :country, :date_begin, :date_end
@release_groups
def release_groups
if @release_groups.nil? and not self.id.nil?
@release_groups = []
Nokogiri::XML(open('http://musicbrainz.org/ws/2/release-group/?artist=' + self.id)).css('release-group').each do |rg|
@release_groups << MusicBrainzReleaseGroup.parse_xml(rg)
end
end
@release_groups
end
def self.find mbid
@artist = self.parse_xml(Nokogiri::XML(open('http://musicbrainz.org/ws/2/artist/' + mbid)))
end
def self.parse_xml xml
@artist = MusicBrainzArtist.new
@artist.id = xml.css('artist').attr('id').value
@artist.type = xml.css('artist').attr('type').value
@artist.name = xml.css('artist > name').text
@artist.country = xml.css('artist > country').text || nil
@artist.date_begin = xml.css('artist > life-span > begin').text || nil
@artist.date_end = xml.css('artist > life-span > end').text || nil
@artist
end
end
-38
View File
@@ -1,38 +0,0 @@
class MusicBrainzRelease
attr_accessor :id, :title, :status, :date, :country
@tracks
def tracks
if @tracks.nil? and not self.id.nil?
@tracks = []
Nokogiri::XML(open('http://musicbrainz.org/ws/2/release/' + self.id + '?inc=recordings')).css('medium-list > medium > track-list > track').each do |r|
@tracks << MusicBrainzTrack.parse_xml(r)
end
end
@tracks
end
def self.find mbid
xml = Nokogiri::XML(open('http://musicbrainz.org/ws/2/release/' + mbid)).css('release').first
self.parse_xml(xml) unless xml.nil?
end
def self.parse_xml xml
@release = MusicBrainzRelease.new
@release.id = xml.attr('id')
@release.title = xml.css('title').text
@release.status = xml.css('status').text
date = xml.css('date').text
unless date.nil? or date.empty?
if date.length == 4
date += '-01-01'
elsif date.length == 7
date += '-01'
end
date = Time.parse(date)
end
@release.date = date
@release.country = xml.css('country').text
@release
end
end
-37
View File
@@ -1,37 +0,0 @@
class MusicBrainzReleaseGroup
attr_accessor :id, :type, :title, :first_release_date
@releases
def releases
if @releases.nil? and not self.id.nil?
@releases = []
Nokogiri::XML(open('http://musicbrainz.org/ws/2/release/?release-group=' + self.id)).css('release').each do |r|
@releases << MusicBrainzRelease.parse_xml(r)
end
end
@releases
end
def self.find mbid
xml = Nokogiri::XML(open('http://musicbrainz.org/ws/2/release-group/' + mbid)).css('release-group').first
self.parse_xml(xml) unless xml.nil?
end
def self.parse_xml xml
@release_group = MusicBrainzReleaseGroup.new
@release_group.id = xml.attr('id')
@release_group.type = xml.attr('type')
@release_group.title = xml.css('title').text
date = xml.css('first-release-date').text
unless date.nil? or date.empty?
if date.length == 4
date += '-01-01'
elsif date.length == 7
date += '-01'
end
date = Time.parse(date)
end
@release_group.first_release_date = date
@release_group
end
end
-17
View File
@@ -1,17 +0,0 @@
class MusicBrainzTrack
attr_accessor :position, :recording_id, :title, :length
def self.find mbid
xml = Nokogiri::XML(open('http://musicbrainz.org/ws/2/recording/' + mbid))
self.parse_xml(xml) unless xml.nil?
end
def self.parse_xml xml
@track = MusicBrainzTrack.new
@track.position = xml.css('position').text.to_i || nil
@track.recording_id = xml.css('recording').attr('id').value
@track.title = xml.css('recording > title').text
@track.length = xml.css('length').first.text.to_i || 0
@track
end
end
+6 -4
View File
@@ -1,7 +1,9 @@
require "open-uri"
require "socket"
require "nokogiri"
require "models/music_brainz_artist"
require "models/music_brainz_release_group"
require "models/music_brainz_release"
require "models/music_brainz_track"
require "models/music_brainz"
require "models/music_brainz/artist"
require "models/music_brainz/release_group"
require "models/music_brainz/release"
require "models/music_brainz/track"