# gpx_files_user_id_fkey (user_id => users.id)
#
-class Trace < ActiveRecord::Base
+class Trace < ApplicationRecord
+ require "open3"
+
self.table_name = "gpx_files"
belongs_to :user, :counter_cache => true
end
def mime_type
- filetype = `/usr/bin/file -Lbz #{trace_name}`.chomp
+ filetype = Open3.capture2("/usr/bin/file", "-Lbz", trace_name).first.chomp
gzipped = filetype =~ /gzip compressed/
bzipped = filetype =~ /bzip2 compressed/
zipped = filetype =~ /Zip archive/
end
def extension_name
- filetype = `/usr/bin/file -Lbz #{trace_name}`.chomp
+ filetype = Open3.capture2("/usr/bin/file", "-Lbz", trace_name).first.chomp
gzipped = filetype =~ /gzip compressed/
bzipped = filetype =~ /bzip2 compressed/
zipped = filetype =~ /Zip archive/
end
def xml_file
- # TODO: *nix specific, could do to work on windows... would be functionally inferior though - check for '.gz'
- filetype = `/usr/bin/file -Lbz #{trace_name}`.chomp
+ filetype = Open3.capture2("/usr/bin/file", "-Lbz", trace_name).first.chomp
gzipped = filetype =~ /gzip compressed/
bzipped = filetype =~ /bzip2 compressed/
zipped = filetype =~ /Zip archive/
tarred = filetype =~ /tar archive/
if gzipped || bzipped || zipped || tarred
- tmpfile = Tempfile.new("trace.#{id}")
+ file = Tempfile.new("trace.#{id}")
if tarred && gzipped
- system("tar -zxOf #{trace_name} > #{tmpfile.path}")
+ system("tar -zxOf #{trace_name} > #{file.path}")
elsif tarred && bzipped
- system("tar -jxOf #{trace_name} > #{tmpfile.path}")
+ system("tar -jxOf #{trace_name} > #{file.path}")
elsif tarred
- system("tar -xOf #{trace_name} > #{tmpfile.path}")
+ system("tar -xOf #{trace_name} > #{file.path}")
elsif gzipped
- system("gunzip -c #{trace_name} > #{tmpfile.path}")
+ system("gunzip -c #{trace_name} > #{file.path}")
elsif bzipped
- system("bunzip2 -c #{trace_name} > #{tmpfile.path}")
+ system("bunzip2 -c #{trace_name} > #{file.path}")
elsif zipped
- system("unzip -p #{trace_name} -x '__MACOSX/*' > #{tmpfile.path} 2> /dev/null")
+ system("unzip -p #{trace_name} -x '__MACOSX/*' > #{file.path} 2> /dev/null")
end
- tmpfile.unlink
-
- file = tmpfile.file
+ file.unlink
else
file = File.open(trace_name)
end
def import
logger.info("GPX Import importing #{name} (#{id}) from #{user.email}")
- gpx = ::GPX::File.new(trace_name)
+ gpx = GPX::File.new(trace_name)
f_lat = 0
f_lon = 0