]> git.openstreetmap.org Git - rails.git/blob - app/models/old_relation.rb
Exclude files in the vendor directory from erb-lint rubocop checks
[rails.git] / app / models / old_relation.rb
1 # == Schema Information
2 #
3 # Table name: relations
4 #
5 #  relation_id  :integer          default(0), not null, primary key
6 #  changeset_id :integer          not null
7 #  timestamp    :datetime         not null
8 #  version      :integer          not null, primary key
9 #  visible      :boolean          default(TRUE), not null
10 #  redaction_id :integer
11 #
12 # Indexes
13 #
14 #  relations_changeset_id_idx  (changeset_id)
15 #  relations_timestamp_idx     (timestamp)
16 #
17 # Foreign Keys
18 #
19 #  relations_changeset_id_fkey  (changeset_id => changesets.id)
20 #  relations_redaction_id_fkey  (redaction_id => redactions.id)
21 #
22
23 class OldRelation < ActiveRecord::Base
24   include ConsistencyValidations
25   include ObjectMetadata
26
27   self.table_name = "relations"
28   self.primary_keys = "relation_id", "version"
29
30   # note this needs to be included after the table name changes, or
31   # the queries generated by Redactable will use the wrong table name.
32   include Redactable
33
34   belongs_to :changeset
35   belongs_to :redaction
36   belongs_to :current_relation, :class_name => "Relation", :foreign_key => "relation_id"
37
38   has_many :old_members, -> { order(:sequence_id) }, :class_name => "OldRelationMember", :foreign_key => [:relation_id, :version]
39   has_many :old_tags, :class_name => "OldRelationTag", :foreign_key => [:relation_id, :version]
40
41   validates :changeset, :presence => true, :associated => true
42   validates :timestamp, :presence => true
43   validates :visible, :inclusion => [true, false]
44
45   def self.from_relation(relation)
46     old_relation = OldRelation.new
47     old_relation.visible = relation.visible
48     old_relation.changeset_id = relation.changeset_id
49     old_relation.timestamp = relation.timestamp
50     old_relation.relation_id = relation.id
51     old_relation.version = relation.version
52     old_relation.members = relation.members
53     old_relation.tags = relation.tags
54     old_relation
55   end
56
57   def save_with_dependencies!
58     save!
59
60     tags.each do |k, v|
61       tag = OldRelationTag.new
62       tag.k = k
63       tag.v = v
64       tag.relation_id = relation_id
65       tag.version = version
66       tag.save!
67     end
68
69     members.each_with_index do |m, i|
70       member = OldRelationMember.new
71       member.id = [relation_id, version, i]
72       member.member_type = m[0].classify
73       member.member_id = m[1]
74       member.member_role = m[2]
75       member.save!
76     end
77   end
78
79   def members
80     @members ||= old_members.collect do |member|
81       [member.member_type, member.member_id, member.member_role]
82     end
83   end
84
85   def tags
86     @tags ||= Hash[old_tags.collect { |t| [t.k, t.v] }]
87   end
88
89   attr_writer :members
90
91   attr_writer :tags
92
93   def to_xml
94     doc = OSM::API.new.get_xml_doc
95     doc.root << to_xml_node
96     doc
97   end
98
99   def to_xml_node(changeset_cache = {}, user_display_name_cache = {})
100     el = XML::Node.new "relation"
101     el["id"] = relation_id.to_s
102
103     add_metadata_to_xml_node(el, self, changeset_cache, user_display_name_cache)
104
105     old_members.each do |member|
106       member_el = XML::Node.new "member"
107       member_el["type"] = member.member_type.to_s.downcase
108       member_el["ref"] = member.member_id.to_s # "id" is considered uncool here as it should be unique in XML
109       member_el["role"] = member.member_role.to_s
110       el << member_el
111     end
112
113     add_tags_to_xml_node(el, old_tags)
114
115     el
116   end
117
118   # Temporary method to match interface to relations
119   def relation_members
120     old_members
121   end
122
123   # Pretend we're not in any relations
124   def containing_relation_members
125     []
126   end
127
128   # check whether this element is the latest version - that is,
129   # has the same version as its "current" counterpart.
130   def is_latest_version?
131     current_relation.version == version
132   end
133 end