##// END OF EJS Templates
Merged r9129 from trunk....
Jean-Philippe Lang -
r9026:5141f1e4741d
parent child
Show More
@@ -1,36 +1,37
1 1 class CommentsController < ApplicationController
2 2 default_search_scope :news
3 3 model_object News
4 4 before_filter :find_model_object
5 5 before_filter :find_project_from_association
6 6 before_filter :authorize
7 7
8 8 verify :method => :post, :only => :create, :render => {:nothing => true, :status => :method_not_allowed }
9 9 def create
10 @comment = Comment.new(params[:comment])
10 @comment = Comment.new
11 @comment.safe_attributes = params[:comment]
11 12 @comment.author = User.current
12 13 if @news.comments << @comment
13 14 flash[:notice] = l(:label_comment_added)
14 15 end
15 16
16 17 redirect_to :controller => 'news', :action => 'show', :id => @news
17 18 end
18 19
19 20 verify :method => :delete, :only => :destroy, :render => {:nothing => true, :status => :method_not_allowed }
20 21 def destroy
21 22 @news.comments.find(params[:comment_id]).destroy
22 23 redirect_to :controller => 'news', :action => 'show', :id => @news
23 24 end
24 25
25 26 private
26 27
27 28 # ApplicationController's find_model_object sets it based on the controller
28 29 # name so it needs to be overriden and set to @news instead
29 30 def find_model_object
30 31 super
31 32 @news = @object
32 33 @comment = nil
33 34 @news
34 35 end
35 36
36 37 end
@@ -1,23 +1,26
1 1 # Redmine - project management software
2 2 # Copyright (C) 2006-2011 Jean-Philippe Lang
3 3 #
4 4 # This program is free software; you can redistribute it and/or
5 5 # modify it under the terms of the GNU General Public License
6 6 # as published by the Free Software Foundation; either version 2
7 7 # of the License, or (at your option) any later version.
8 8 #
9 9 # This program is distributed in the hope that it will be useful,
10 10 # but WITHOUT ANY WARRANTY; without even the implied warranty of
11 11 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12 12 # GNU General Public License for more details.
13 13 #
14 14 # You should have received a copy of the GNU General Public License
15 15 # along with this program; if not, write to the Free Software
16 16 # Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
17 17
18 18 class Comment < ActiveRecord::Base
19 include Redmine::SafeAttributes
19 20 belongs_to :commented, :polymorphic => true, :counter_cache => true
20 21 belongs_to :author, :class_name => 'User', :foreign_key => 'author_id'
21 22
22 23 validates_presence_of :commented, :author, :comments
24
25 safe_attributes 'comments'
23 26 end
General Comments 0
You need to be logged in to leave comments. Login now