34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
|
# File 'app/models/dhatu/price.rb', line 34
def self.save_row_data(hsh)
error_object = Kuppayam::Importer::ErrorHash.new
return error_object if hsh[:title].to_s.strip.blank?
price = Dhatu::Price.find_by_title(hsh[:title].to_s.strip) || Dhatu::Price.new
price.title = hsh[:title].to_s.strip
price.sub_title = hsh[:sub_title].to_s.strip
price.price = hsh[:price].to_s.strip
price.category = Dhatu::Category.find_by_name(hsh[:category].to_s.strip)
price.status = hsh[:status].to_s.strip || PUBLISHED
price.featured = hsh[:featured].to_s.strip == "true"
price.priority = hsh[:priority].to_s.strip || 1
if price.valid?
begin
price.save!
rescue Exception => e
summary = "uncaught #{e} exception while handling connection: #{e.message}"
details = "Stack trace: #{e.backtrace.map {|l| " #{l}\n"}.join}"
error_object.errors << { summary: summary, details: details }
end
else
summary = "Error while saving price: #{price.title}"
details = "Error! #{price.errors.full_messages.to_sentence}"
error_object.errors << { summary: summary, details: details }
end
return error_object
end
|