@@ -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 |
|
|
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