103 lines
2.6 KiB
Ruby
103 lines
2.6 KiB
Ruby
class JamRuby::JamTrackTrack
|
|
|
|
# add a custom validation
|
|
|
|
attr_accessor :preview_generate_error
|
|
|
|
validate :preview
|
|
|
|
def preview
|
|
if preview_generate_error
|
|
errors.add(:preview_start_time, preview_generate_error)
|
|
end
|
|
end
|
|
|
|
|
|
|
|
# this is used by active admin/jam-admin
|
|
def preview_start_time_raw
|
|
if self.preview_start_time.nil? || self.preview_start_time.nil?
|
|
''
|
|
else
|
|
seconds = self.preview_start_time.to_f/1000
|
|
time = Time.at(seconds)
|
|
time.strftime("%M:%S:#{(self.preview_start_time % 1000).to_s.rjust(3, '0')}")
|
|
end
|
|
end
|
|
|
|
# this is used by active admin/jam-admin
|
|
def preview_start_time_raw=(new_value)
|
|
|
|
value = nil
|
|
if new_value == nil || new_value == ''
|
|
value = nil
|
|
else
|
|
if new_value && new_value.kind_of?(String) && new_value.include?(':')
|
|
bits = new_value.split(':')
|
|
if bits.length != 3
|
|
raise "format of preview start time must be MM:SS:MLS"
|
|
end
|
|
|
|
value = (bits[0].to_i * 60000) + (bits[1].to_i * 1000) + (bits[2].to_i)
|
|
|
|
else
|
|
raise "format of preview start time must be MM:SS:MLS"
|
|
end
|
|
end
|
|
|
|
if !value.nil? && value != self.preview_start_time
|
|
self.preview_start_time = value
|
|
generate_preview
|
|
else
|
|
self.preview_start_time = value
|
|
end
|
|
end
|
|
|
|
def generate_preview
|
|
|
|
begin
|
|
Dir.mktmpdir do |tmp_dir|
|
|
|
|
input = File.join(tmp_dir, 'in.ogg')
|
|
output = File.join(tmp_dir, 'out.ogg')
|
|
|
|
start = self.preview_start_time.to_f / 1000
|
|
stop = start + 20
|
|
|
|
raise 'no track' unless self["url_44"]
|
|
|
|
s3_manager.download(self.url_by_sample_rate(44), input)
|
|
|
|
command = "sox \"#{input}\" \"#{output}\" trim #{start} #{stop}"
|
|
|
|
@@log.debug("trimming using: " + command)
|
|
|
|
sox_output = `#{command}`
|
|
|
|
result_code = $?.to_i
|
|
|
|
if result_code != 0
|
|
@@log.debug("fail #{result_code}")
|
|
@preview_generate_error = "unable to execute cut command #{sox_output}"
|
|
else
|
|
@@log.debug("uploading preview to #{self.preview_filename}")
|
|
|
|
s3_manager.upload(self.preview_filename, output)
|
|
|
|
self.skip_uploader = true
|
|
# and finally update the JamTrackTrack with the new info
|
|
self["preview_url"] = self.preview_filename
|
|
self["preview_md5"] = ::Digest::MD5.file(output).hexdigest
|
|
self["preview_length"] = File.new(output).size
|
|
self.save!
|
|
end
|
|
end
|
|
rescue Exception => e
|
|
@@log.error("error in sox command #{e.to_s}")
|
|
@preview_generate_error = e.to_s
|
|
end
|
|
|
|
end
|
|
|
|
end
|