X-Git-Url: https://git.openstreetmap.org./rails.git/blobdiff_plain/d781f42016767132eea7c7463549640d943c2910..28e9a84da2d035fb5396e3a3deb80f416ab12706:/app/models/trace.rb diff --git a/app/models/trace.rb b/app/models/trace.rb index 2d4e9ef8a..c189c035e 100644 --- a/app/models/trace.rb +++ b/app/models/trace.rb @@ -73,7 +73,54 @@ class Trace < ActiveRecord::Base end def mime_type - return `file -bi #{trace_name}`.chomp + filetype = `/usr/bin/file -bz #{trace_name}`.chomp + gzipped = filetype =~ /gzip compressed/ + bzipped = filetype =~ /bzip2 compressed/ + zipped = filetype =~ /Zip archive/ + + if gzipped then + mimetype = "application/x-gzip" + elsif bzipped then + mimetype = "application/x-bzip2" + elsif zipped + mimetype = "application/x-zip" + else + mimetype = "text/xml" + end + + return mimetype + end + + def extension_name + filetype = `/usr/bin/file -bz #{trace_name}`.chomp + gzipped = filetype =~ /gzip compressed/ + bzipped = filetype =~ /bzip2 compressed/ + zipped = filetype =~ /Zip archive/ + tarred = filetype =~ /tar archive/ + + if tarred and gzipped then + extension = ".tar.gz" + elsif tarred and bzipped then + extension = ".tar.bz2" + elsif tarred + extension = ".tar" + elsif gzipped + extension = ".gpx.gz" + elsif bzipped + extension = ".gpx.bz2" + elsif zipped + extension = ".zip" + else + extension = ".gpx" + end + + return extension + end + + def to_xml + doc = OSM::API.new.get_xml_doc + doc.root << to_xml_node() + return doc end def to_xml_node @@ -94,7 +141,7 @@ class Trace < ActiveRecord::Base logger.info("GPX Import importing #{name} (#{id}) from #{user.email}") # TODO *nix specific, could do to work on windows... would be functionally inferior though - check for '.gz' - filetype = `file -bz #{trace_name}`.chomp + filetype = `/usr/bin/file -bz #{trace_name}`.chomp gzipped = filetype =~ /gzip compressed/ bzipped = filetype =~ /bzip2 compressed/ zipped = filetype =~ /Zip archive/ @@ -141,7 +188,6 @@ class Trace < ActiveRecord::Base tp.lng = point['longitude'].to_f tp.altitude = point['altitude'].to_f tp.timestamp = point['timestamp'] - tp.user_id = user.id tp.gpx_id = id tp.trackid = point['segment'].to_i tp.save! @@ -164,7 +210,7 @@ class Trace < ActiveRecord::Base self.icon_picture = gpx.get_icon(min_lat, min_lon, max_lat, max_lon) self.size = gpx.actual_points self.inserted = true - self.save + self.save! end logger.info "done trace #{id}"