summaryrefslogtreecommitdiffstats
path: root/app
diff options
context:
space:
mode:
authorJean-Philippe Lang <jp_lang@yahoo.fr>2012-02-11 17:14:56 +0000
committerJean-Philippe Lang <jp_lang@yahoo.fr>2012-02-11 17:14:56 +0000
commit8ddcc4caf51c3ae911f7789ad21dcb456ebcf193 (patch)
treea39169476ba2de37a9753bb373baffc1424bf467 /app
parent9678e335a46da29ff567a750edf3b6480ca6f844 (diff)
downloadredmine-8ddcc4caf51c3ae911f7789ad21dcb456ebcf193.tar.gz
redmine-8ddcc4caf51c3ae911f7789ad21dcb456ebcf193.zip
Adds a News#commentable? method to easily specific additional rules.
git-svn-id: svn+ssh://rubyforge.org/var/svn/redmine/trunk@8854 e93f8b46-1217-0410-a6f0-8f06a7374b81
Diffstat (limited to 'app')
-rw-r--r--app/controllers/comments_controller.rb20
-rw-r--r--app/models/news.rb5
-rw-r--r--app/views/news/show.html.erb2
3 files changed, 25 insertions, 2 deletions
diff --git a/app/controllers/comments_controller.rb b/app/controllers/comments_controller.rb
index 230af5caf..e6cfab798 100644
--- a/app/controllers/comments_controller.rb
+++ b/app/controllers/comments_controller.rb
@@ -1,3 +1,20 @@
+# Redmine - project management software
+# Copyright (C) 2006-2012 Jean-Philippe Lang
+#
+# This program is free software; you can redistribute it and/or
+# modify it under the terms of the GNU General Public License
+# as published by the Free Software Foundation; either version 2
+# of the License, or (at your option) any later version.
+#
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+# GNU General Public License for more details.
+#
+# You should have received a copy of the GNU General Public License
+# along with this program; if not, write to the Free Software
+# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
+
class CommentsController < ApplicationController
default_search_scope :news
model_object News
@@ -7,6 +24,8 @@ class CommentsController < ApplicationController
verify :method => :post, :only => :create, :render => {:nothing => true, :status => :method_not_allowed }
def create
+ raise Unauthorized unless @news.commentable?
+
@comment = Comment.new(params[:comment])
@comment.author = User.current
if @news.comments << @comment
@@ -32,5 +51,4 @@ class CommentsController < ApplicationController
@comment = nil
@news
end
-
end
diff --git a/app/models/news.rb b/app/models/news.rb
index 78dcc0c8c..eed17945e 100644
--- a/app/models/news.rb
+++ b/app/models/news.rb
@@ -42,6 +42,11 @@ class News < ActiveRecord::Base
!user.nil? && user.allowed_to?(:view_news, project)
end
+ # Returns true if the news can be commented by user
+ def commentable?(user=User.current)
+ user.allowed_to?(:comment_news, project)
+ end
+
# returns latest news for projects visible by user
def self.latest(user = User.current, count = 5)
find(:all, :limit => count,
diff --git a/app/views/news/show.html.erb b/app/views/news/show.html.erb
index 72c18d9a6..b0b5f023e 100644
--- a/app/views/news/show.html.erb
+++ b/app/views/news/show.html.erb
@@ -53,7 +53,7 @@
<% end if @comments.any? %>
</div>
-<% if authorize_for 'comments', 'create' %>
+<% if @news.commentable? %>
<p><%= toggle_link l(:label_comment_add), "add_comment_form", :focus => "comment_comments" %></p>
<% form_tag({:controller => 'comments', :action => 'create', :id => @news}, :id => "add_comment_form", :style => "display:none;") do %>
<div class="box">