##// END OF EJS Templates
Only notify users that can see news (#16134)....
Jean-Philippe Lang -
r12639:98e299857bc4
parent child
Show More
@@ -1,85 +1,85
1 # Redmine - project management software
1 # Redmine - project management software
2 # Copyright (C) 2006-2014 Jean-Philippe Lang
2 # Copyright (C) 2006-2014 Jean-Philippe Lang
3 #
3 #
4 # This program is free software; you can redistribute it and/or
4 # This program is free software; you can redistribute it and/or
5 # modify it under the terms of the GNU General Public License
5 # modify it under the terms of the GNU General Public License
6 # as published by the Free Software Foundation; either version 2
6 # as published by the Free Software Foundation; either version 2
7 # of the License, or (at your option) any later version.
7 # of the License, or (at your option) any later version.
8 #
8 #
9 # This program is distributed in the hope that it will be useful,
9 # This program is distributed in the hope that it will be useful,
10 # but WITHOUT ANY WARRANTY; without even the implied warranty of
10 # but WITHOUT ANY WARRANTY; without even the implied warranty of
11 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
11 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12 # GNU General Public License for more details.
12 # GNU General Public License for more details.
13 #
13 #
14 # You should have received a copy of the GNU General Public License
14 # You should have received a copy of the GNU General Public License
15 # along with this program; if not, write to the Free Software
15 # along with this program; if not, write to the Free Software
16 # Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
16 # Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
17
17
18 class News < ActiveRecord::Base
18 class News < ActiveRecord::Base
19 include Redmine::SafeAttributes
19 include Redmine::SafeAttributes
20 belongs_to :project
20 belongs_to :project
21 belongs_to :author, :class_name => 'User', :foreign_key => 'author_id'
21 belongs_to :author, :class_name => 'User', :foreign_key => 'author_id'
22 has_many :comments, :as => :commented, :dependent => :delete_all, :order => "created_on"
22 has_many :comments, :as => :commented, :dependent => :delete_all, :order => "created_on"
23
23
24 validates_presence_of :title, :description
24 validates_presence_of :title, :description
25 validates_length_of :title, :maximum => 60
25 validates_length_of :title, :maximum => 60
26 validates_length_of :summary, :maximum => 255
26 validates_length_of :summary, :maximum => 255
27
27
28 acts_as_attachable :delete_permission => :manage_news
28 acts_as_attachable :delete_permission => :manage_news
29 acts_as_searchable :columns => ['title', 'summary', "#{table_name}.description"], :include => :project
29 acts_as_searchable :columns => ['title', 'summary', "#{table_name}.description"], :include => :project
30 acts_as_event :url => Proc.new {|o| {:controller => 'news', :action => 'show', :id => o.id}}
30 acts_as_event :url => Proc.new {|o| {:controller => 'news', :action => 'show', :id => o.id}}
31 acts_as_activity_provider :find_options => {:include => [:project, :author]},
31 acts_as_activity_provider :find_options => {:include => [:project, :author]},
32 :author_key => :author_id
32 :author_key => :author_id
33 acts_as_watchable
33 acts_as_watchable
34
34
35 after_create :add_author_as_watcher
35 after_create :add_author_as_watcher
36 after_create :send_notification
36 after_create :send_notification
37
37
38 scope :visible, lambda {|*args|
38 scope :visible, lambda {|*args|
39 includes(:project).where(Project.allowed_to_condition(args.shift || User.current, :view_news, *args))
39 includes(:project).where(Project.allowed_to_condition(args.shift || User.current, :view_news, *args))
40 }
40 }
41
41
42 safe_attributes 'title', 'summary', 'description'
42 safe_attributes 'title', 'summary', 'description'
43
43
44 def visible?(user=User.current)
44 def visible?(user=User.current)
45 !user.nil? && user.allowed_to?(:view_news, project)
45 !user.nil? && user.allowed_to?(:view_news, project)
46 end
46 end
47
47
48 # Returns true if the news can be commented by user
48 # Returns true if the news can be commented by user
49 def commentable?(user=User.current)
49 def commentable?(user=User.current)
50 user.allowed_to?(:comment_news, project)
50 user.allowed_to?(:comment_news, project)
51 end
51 end
52
52
53 def recipients
53 def recipients
54 project.users.select {|user| user.notify_about?(self)}.map(&:mail)
54 project.users.select {|user| user.notify_about?(self) && user.allowed_to?(:view_news, project)}.map(&:mail)
55 end
55 end
56
56
57 # Returns the email addresses that should be cc'd when a new news is added
57 # Returns the email addresses that should be cc'd when a new news is added
58 def cc_for_added_news
58 def cc_for_added_news
59 cc = []
59 cc = []
60 if m = project.enabled_module('news')
60 if m = project.enabled_module('news')
61 cc = m.notified_watchers
61 cc = m.notified_watchers
62 unless project.is_public?
62 unless project.is_public?
63 cc = cc.select {|user| project.users.include?(user)}
63 cc = cc.select {|user| project.users.include?(user)}
64 end
64 end
65 end
65 end
66 cc.map(&:mail)
66 cc.map(&:mail)
67 end
67 end
68
68
69 # returns latest news for projects visible by user
69 # returns latest news for projects visible by user
70 def self.latest(user = User.current, count = 5)
70 def self.latest(user = User.current, count = 5)
71 visible(user).includes([:author, :project]).order("#{News.table_name}.created_on DESC").limit(count).all
71 visible(user).includes([:author, :project]).order("#{News.table_name}.created_on DESC").limit(count).all
72 end
72 end
73
73
74 private
74 private
75
75
76 def add_author_as_watcher
76 def add_author_as_watcher
77 Watcher.create(:watchable => self, :user => author)
77 Watcher.create(:watchable => self, :user => author)
78 end
78 end
79
79
80 def send_notification
80 def send_notification
81 if Setting.notified_events.include?('news_added')
81 if Setting.notified_events.include?('news_added')
82 Mailer.news_added(self).deliver
82 Mailer.news_added(self).deliver
83 end
83 end
84 end
84 end
85 end
85 end
General Comments 0
You need to be logged in to leave comments. Login now