into a base class.
--- /dev/null
+class GeoRecord < ActiveRecord::Base
+ before_save :update_tile
+
+ def self.find_by_area(minlat, minlon, maxlat, maxlon, options)
+ self.with_scope(:find => {:conditions => OSM.sql_for_area(minlat, minlon, maxlat, maxlon)}) do
+ return self.find(:all, options)
+ end
+ end
+
+ def update_tile
+ self.tile = QuadTile.tile_for_point(lat, lon)
+ end
+
+ def lat=(l)
+ self.latitude = (l * 10000000).round
+ end
+
+ def lon=(l)
+ self.longitude = (l * 10000000).round
+ end
+
+ def lat
+ return self.latitude.to_f / 10000000
+ end
+
+ def lon
+ return self.longitude.to_f / 10000000
+ end
+end
-class Node < ActiveRecord::Base
+class Node < GeoRecord
require 'xml/libxml'
+
set_table_name 'current_nodes'
validates_presence_of :user_id, :timestamp
has_many :old_nodes, :foreign_key => :id
belongs_to :user
- before_save :update_tile
-
- def self.find_by_area(minlat, minlon, maxlat, maxlon, options)
- self.with_scope(:find => {:conditions => OSM.sql_for_area(minlat, minlon, maxlat, maxlon)}) do
- return self.find(:all, options)
- end
- end
-
- def update_tile
- self.tile = QuadTile.tile_for_point(lat, lon)
- end
-
- def lat=(l)
- self.latitude = (l * 10000000).round
- end
-
- def lon=(l)
- self.longitude = (l * 10000000).round
- end
-
- def lat
- return self.latitude.to_f / 10000000
- end
-
- def lon
- return self.longitude.to_f / 10000000
- end
-
def validate_position
errors.add_to_base("Node is not in the world") unless in_world?
end
-class OldNode < ActiveRecord::Base
+class OldNode < GeoRecord
set_table_name 'nodes'
validates_presence_of :user_id, :timestamp
belongs_to :user
- before_save :update_tile
-
- def self.find_by_area(minlat, minlon, maxlat, maxlon, options)
- self.with_scope(:find => {:conditions => OSM.sql_for_area(minlat, minlon, maxlat, maxlon)}) do
- return self.find(:all, options)
- end
- end
-
- def update_tile
- self.tile = QuadTile.tile_for_point(lat, lon)
- end
-
- def lat=(l)
- self.latitude = (l * 10000000).round
- end
-
- def lon=(l)
- self.longitude = (l * 10000000).round
- end
-
- def lat
- return self.latitude.to_f / 10000000
- end
-
- def lon
- return self.longitude.to_f / 10000000
- end
-
def validate_position
errors.add_to_base("Node is not in the world") unless in_world?
end
-class Tracepoint < ActiveRecord::Base
+class Tracepoint < GeoRecord
set_table_name 'gps_points'
validates_numericality_of :trackid, :only_integer => true
validates_presence_of :timestamp
belongs_to :trace, :foreign_key => 'gpx_id'
-
- before_save :update_tile
-
- def self.find_by_area(minlat, minlon, maxlat, maxlon, options)
- self.with_scope(:find => {:conditions => OSM.sql_for_area(minlat, minlon, maxlat, maxlon)}) do
- return self.find(:all, options)
- end
- end
-
- def update_tile
- self.tile = QuadTile.tile_for_point(lat, lon)
- end
-
- def lat=(l)
- self.latitude = (l * 10000000).round
- end
-
- def lon=(l)
- self.longitude = (l * 10000000).round
- end
-
- def lat
- return self.latitude.to_f / 10000000
- end
-
- def lon
- return self.longitude.to_f / 10000000
- end
def to_xml_node
el1 = XML::Node.new 'trkpt'