X-Git-Url: https://git.openstreetmap.org./rails.git/blobdiff_plain/df31fe13a535a9b36206c035a48f1e4cdec913f4..98d49ed14497e3af8367d8f42af9d9b760dcaba7:/app/models/old_node.rb diff --git a/app/models/old_node.rb b/app/models/old_node.rb index c63738fc4..76eab8427 100644 --- a/app/models/old_node.rb +++ b/app/models/old_node.rb @@ -1,4 +1,6 @@ class OldNode < ActiveRecord::Base + include GeoRecord + set_table_name 'nodes' validates_presence_of :user_id, :timestamp @@ -8,34 +10,6 @@ class OldNode < ActiveRecord::Base 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 @@ -64,9 +38,34 @@ class OldNode < ActiveRecord::Base el1['lat'] = self.lat.to_s el1['lon'] = self.lon.to_s el1['user'] = self.user.display_name if self.user.data_public? - Node.split_tags(el1, self.tags) + + Tags.split(self.tags) do |k,v| + el2 = XML::Node.new('tag') + el2['k'] = k.to_s + el2['v'] = v.to_s + el1 << el2 + end + el1['visible'] = self.visible.to_s el1['timestamp'] = self.timestamp.xmlschema return el1 end + + def tags_as_hash + hash = {} + Tags.split(self.tags) do |k,v| + hash[k] = v + end + hash + end + + # Pretend we're not in any ways + def ways + return [] + end + + # Pretend we're not in any relations + def containing_relation_members + return [] + end end