X-Git-Url: https://git.openstreetmap.org./rails.git/blobdiff_plain/b527d27674f0ad4ad66075def914bde695d4d88e..07c1cd6b983d5138c1a217a716248b9a1010b9e3:/app/models/node.rb diff --git a/app/models/node.rb b/app/models/node.rb index 4393f2526..af88a117d 100644 --- a/app/models/node.rb +++ b/app/models/node.rb @@ -1,8 +1,8 @@ -# The node model represents a current existing node, that is, the latest version. Use OldNode for historical nodes. - -class Node < GeoRecord +class Node < ActiveRecord::Base require 'xml/libxml' + include GeoRecord + set_table_name 'current_nodes' validates_presence_of :user_id, :timestamp @@ -17,8 +17,11 @@ class Node < GeoRecord has_many :way_nodes has_many :ways, :through => :way_nodes - has_many :containing_relation_members, :as => :member - has_many :containing_relations, :through => :containing_relation_members + has_many :old_way_nodes + has_many :ways_via_history, :class_name=> "Way", :through => :old_way_nodes, :source => :way + + has_many :containing_relation_members, :class_name => "RelationMember", :as => :member + has_many :containing_relations, :class_name => "Relation", :through => :containing_relation_members, :source => :relation, :extend => ObjectFinder # Sanity check the latitude and longitude and add an error if it's broken def validate_position @@ -54,8 +57,7 @@ class Node < GeoRecord # Read in xml as text and return it's Node object representation def self.from_xml(xml, create=false) begin - p = XML::Parser.new - p.string = xml + p = XML::Parser.string(xml) doc = p.parse node = Node.new