##// END OF EJS Templates
Merged r9129 from trunk....
Jean-Philippe Lang -
r9026:5141f1e4741d
parent child
Show More
@@ -1,36 +1,37
1 class CommentsController < ApplicationController
1 class CommentsController < ApplicationController
2 default_search_scope :news
2 default_search_scope :news
3 model_object News
3 model_object News
4 before_filter :find_model_object
4 before_filter :find_model_object
5 before_filter :find_project_from_association
5 before_filter :find_project_from_association
6 before_filter :authorize
6 before_filter :authorize
7
7
8 verify :method => :post, :only => :create, :render => {:nothing => true, :status => :method_not_allowed }
8 verify :method => :post, :only => :create, :render => {:nothing => true, :status => :method_not_allowed }
9 def create
9 def create
10 @comment = Comment.new(params[:comment])
10 @comment = Comment.new
11 @comment.safe_attributes = params[:comment]
11 @comment.author = User.current
12 @comment.author = User.current
12 if @news.comments << @comment
13 if @news.comments << @comment
13 flash[:notice] = l(:label_comment_added)
14 flash[:notice] = l(:label_comment_added)
14 end
15 end
15
16
16 redirect_to :controller => 'news', :action => 'show', :id => @news
17 redirect_to :controller => 'news', :action => 'show', :id => @news
17 end
18 end
18
19
19 verify :method => :delete, :only => :destroy, :render => {:nothing => true, :status => :method_not_allowed }
20 verify :method => :delete, :only => :destroy, :render => {:nothing => true, :status => :method_not_allowed }
20 def destroy
21 def destroy
21 @news.comments.find(params[:comment_id]).destroy
22 @news.comments.find(params[:comment_id]).destroy
22 redirect_to :controller => 'news', :action => 'show', :id => @news
23 redirect_to :controller => 'news', :action => 'show', :id => @news
23 end
24 end
24
25
25 private
26 private
26
27
27 # ApplicationController's find_model_object sets it based on the controller
28 # ApplicationController's find_model_object sets it based on the controller
28 # name so it needs to be overriden and set to @news instead
29 # name so it needs to be overriden and set to @news instead
29 def find_model_object
30 def find_model_object
30 super
31 super
31 @news = @object
32 @news = @object
32 @comment = nil
33 @comment = nil
33 @news
34 @news
34 end
35 end
35
36
36 end
37 end
@@ -1,23 +1,26
1 # Redmine - project management software
1 # Redmine - project management software
2 # Copyright (C) 2006-2011 Jean-Philippe Lang
2 # Copyright (C) 2006-2011 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 Comment < ActiveRecord::Base
18 class Comment < ActiveRecord::Base
19 include Redmine::SafeAttributes
19 belongs_to :commented, :polymorphic => true, :counter_cache => true
20 belongs_to :commented, :polymorphic => true, :counter_cache => true
20 belongs_to :author, :class_name => 'User', :foreign_key => 'author_id'
21 belongs_to :author, :class_name => 'User', :foreign_key => 'author_id'
21
22
22 validates_presence_of :commented, :author, :comments
23 validates_presence_of :commented, :author, :comments
24
25 safe_attributes 'comments'
23 end
26 end
General Comments 0
You need to be logged in to leave comments. Login now