X-Git-Url: https://git.openstreetmap.org./rails.git/blobdiff_plain/6efdcaa9930bd2e392294304095ae31a91b8c4ab..24ee5618ce06105fc8dd7baf641af08d96365c41:/app/models/trace.rb diff --git a/app/models/trace.rb b/app/models/trace.rb index de9bda661..4f21c8b25 100644 --- a/app/models/trace.rb +++ b/app/models/trace.rb @@ -6,8 +6,13 @@ class Trace < ActiveRecord::Base validates_inclusion_of :inserted, :in => [ true, false] belongs_to :user - has_many :tags, :class_name => 'Tracetag', :foreign_key => 'gpx_id', :dependent => :destroy - has_many :points, :class_name => 'Tracepoint', :foreign_key => 'gpx_id', :dependent => :destroy + has_many :tags, :class_name => 'Tracetag', :foreign_key => 'gpx_id', :dependent => :delete_all + has_many :points, :class_name => 'Tracepoint', :foreign_key => 'gpx_id', :dependent => :delete_all + + def destroy + super + FileUtils.rm_f(trace_name, icon_picture_name, large_picture_name) + end def tagstring=(s) self.tags = s.split().collect {|tag| @@ -135,21 +140,11 @@ class Trace < ActiveRecord::Base self.size = gpx.actual_points self.inserted = true self.save - - Notifier::deliver_gpx_success(self, gpx.possible_points) - else - FileUtils.rm_f("/home/osm/gpx/#{id}.gpx") - self.destroy - Notifier::deliver_gpx_failure(self, '0 points parsed ok. Do they all have lat,lng,alt,timestamp?') end logger.info "done trace #{id}" - rescue Exception => ex - logger.info ex - ex.backtrace.each {|l| logger.info l } - FileUtils.rm_f("/home/osm/gpx/#{id}.gpx") - self.destroy - Notifier::deliver_gpx_failure(self, ex.to_s + ex.backtrace.join("\n") ) + + return gpx ensure FileUtils.rm_f(tempfile) if tempfile end