]> git.openstreetmap.org Git - rails.git/blob - app/models/map_bug.rb
Merge branch 'master' into openstreetbugs
[rails.git] / app / models / map_bug.rb
1 class MapBug < ActiveRecord::Base
2   include GeoRecord
3
4   set_table_name 'map_bugs'
5
6   validates_presence_of :id, :on => :update
7   validates_uniqueness_of :id
8   validates_numericality_of :latitude, :only_integer => true
9   validates_numericality_of :longitude, :only_integer => true
10   validates_presence_of :date_created
11   validates_presence_of :last_changed
12   validates_prensence_of :date_closed if :status == "closed"
13   validates_inclusion_of :status, :in => [ "open", "closed", "hidden" ]
14
15   has_many :map_bug_comment, :foreign_key => :bug_id, :order => :date_created, :conditions => "visible = true and comment is not null"
16
17
18   def self.create_bug(lat, lon)
19         bug = MapBug.new(:lat => lat, :lon => lon);
20         raise OSM::APIBadUserInput.new("The node is outside this world") unless bug.in_world?
21         bug.date_created = Time.now.getutc
22         bug.last_changed = Time.now.getutc
23         bug.status = "open";
24         return bug;
25   end
26
27   def close_bug
28         self.status = "closed"
29         close_time = Time.now.getutc
30         self.last_changed = close_time
31         self.date_closed = close_time
32
33         self.save;
34   end
35
36   def flatten_comment ( separator_char, upto_timestamp = :nil)
37         resp = ""
38         comment_no = 1
39         self.map_bug_comment.each do |comment|
40           next if upto_timestamp != :nil and comment.date_created > upto_timestamp
41         resp += (comment_no == 1 ? "" : separator_char)
42                 resp += comment.comment if comment.comment
43                 resp += " [ " 
44                 resp += comment.commenter_name if comment.commenter_name
45                 resp += " " + comment.date_created.to_s + " ]"
46                 comment_no += 1
47         end
48
49         return resp
50
51   end
52
53   def visible
54         return status != "hidden"
55   end
56
57 end