]> git.openstreetmap.org Git - rails.git/blob - app/models/node.rb
get new slippy map in rails
[rails.git] / app / models / node.rb
1 class Node < ActiveRecord::Base
2   require 'xml/libxml'
3   set_table_name 'current_nodes'
4
5   validates_numericality_of :latitude
6   validates_numericality_of :longitude
7   # FIXME validate lat and lon within the world
8
9   has_many :old_nodes, :foreign_key => :id
10   belongs_to :user
11
12
13   def self.from_xml(xml, create=false)
14     p = XML::Parser.new
15     p.string = xml
16     doc = p.parse
17
18     node = Node.new
19
20     doc.find('//osm/node').each do |pt|
21
22
23       node.latitude = pt['lat'].to_f
24       node.longitude = pt['lon'].to_f
25
26       if node.latitude > 90 or node.latitude < -90 or node.longitude > 180 or node.longitude < -180
27         return nil
28       end
29
30       if pt['id'] != '0'
31         node.id = pt['id'].to_i
32       end
33
34       node.visible = pt['visible'] and pt['visible'] == 'true'
35
36       if create
37         node.timestamp = Time.now
38       else
39         if pt['timestamp']
40           node.timestamp = Time.parse(pt['timestamp'])
41         end
42       end
43
44       tags = []
45
46       pt.find('tag').each do |tag|
47         tags << [tag['k'],tag['v']]
48       end
49
50       tags = tags.collect { |k,v| "#{k}=#{v}" }.join(';')
51       tags = '' if tags.nil?
52
53       node.tags = tags
54
55     end
56     return node
57   end
58
59   def save_with_history
60     begin
61       Node.transaction do
62         self.save
63         old_node = OldNode.from_node(self)
64         old_node.save
65       end
66       return true
67     rescue Exception => ex
68       return nil
69     end
70   end
71
72   def to_xml
73     doc = XML::Document.new
74     doc.encoding = 'UTF-8' 
75     root = XML::Node.new 'osm'
76     root['version'] = '0.4'
77     root['generator'] = 'OpenStreetMap server'
78     doc.root = root
79     el1 = XML::Node.new 'node'
80     el1['id'] = self.id.to_s
81     el1['lat'] = self.latitude.to_s
82     el1['lon'] = self.longitude.to_s
83     Node.split_tags(el1, self.tags)
84     el1['visible'] = self.visible.to_s
85     el1['timestamp'] = self.timestamp.xmlschema
86     root << el1
87     return doc
88   end
89
90   def self.split_tags(el, tags)
91     tags.split(';').each do |tag|
92       parts = tag.split('=')
93       key = ''
94       val = ''
95       key = parts[0].strip unless parts[0].nil?
96       val = parts[1].strip unless parts[1].nil?
97       if key != '' && val != ''
98         el2 = Node.new('tag')
99         el2['k'] = key.to_s
100         el2['v'] = val.to_s
101         el << el2
102       end
103     end
104   end
105
106 end