aboutsummaryrefslogtreecommitdiffstats
path: root/app/controllers/comment_controller.rb
blob: 890e9faaa3a8547e8d03feaf137f219e6934b8c1 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
# app/controllers/comment_controller.rb:
# Show annotations upon a request or other object.
#
# Copyright (c) 2008 UK Citizens Online Democracy. All rights reserved.
# Email: hello@mysociety.org; WWW: http://www.mysociety.org/

class CommentController < ApplicationController
    before_filter :check_read_only, :only => [ :new ]
    before_filter :find_info_request, :only => [ :new ]
    before_filter :create_track_thing, :only => [ :new ]
    before_filter :reject_unless_comments_allowed, :only => [ :new ]
    before_filter :reject_if_user_banned, :only => [ :new ]

    def new
        if params[:comment]
            @comment = Comment.new(params[:comment].merge({
                :comment_type => 'request',
                :user => @user
            }))
        end

        if params[:comment]
            # TODO: this check should theoretically be a validation rule in the model
            @existing_comment = Comment.find_existing(@info_request.id, params[:comment][:body])
        else
            # Default to subscribing to request when first viewing form
            params[:subscribe_to_request] = true
        end

        # See if values were valid or not
        if !params[:comment] || !@existing_comment.nil? || !@comment.valid? || params[:reedit]
            render :action => 'new'
            return
        end

        # Show preview page, if it is a preview
        if params[:preview].to_i == 1
            render :action => 'preview'
            return
        end

        if authenticated?(
                :web => _("To post your annotation"),
                :email => _("Then your annotation to {{info_request_title}} will be posted.",:info_request_title=>@info_request.title),
                :email_subject => _("Confirm your annotation to {{info_request_title}}",:info_request_title=>@info_request.title)
            )

            # Also subscribe to track for this request, so they get updates
            # (do this first, so definitely don't send alert)
            flash[:notice] = _("Thank you for making an annotation!")

            if params[:subscribe_to_request]
                @track_thing = TrackThing.create_track_for_request(@info_request)
                @existing_track = TrackThing.find_existing(@user, @track_thing)
                if @user && @info_request.user == @user
                    # don't subscribe to own request!
                elsif !@existing_track
                    @track_thing.track_medium = 'email_daily'
                    @track_thing.tracking_user_id = @user.id
                    @track_thing.save!
                    flash[:notice] += _(" You will also be emailed updates about the request.")
                else
                    flash[:notice] += _(" You are already being emailed updates about the request.")
                end
            end

            # This automatically saves dependent objects in the same transaction
            @comment = @info_request.add_comment(params[:comment][:body], authenticated_user)
            @info_request.save!

            # we don't use comment_url here, as then you don't see the flash at top of page
            redirect_to request_url(@info_request)
        else
            # do nothing - as "authenticated?" has done the redirect to signin page for us
        end
    end

    private

    def find_info_request
        if params[:type] == 'request'
            @info_request = InfoRequest.find_by_url_title!(params[:url_title])
        else
            raise "Unknown type #{ params[:type] }"
        end
    end

    def create_track_thing
        @track_thing = TrackThing.create_track_for_request(@info_request)
    end

    # Are comments disabled on this request?
    #
    # There is no “add comment” link when comments are disabled, so users should
    # not usually hit this unless they are explicitly attempting to avoid the comment block
    def reject_unless_comments_allowed
        unless @info_request.comments_allowed?
            redirect_to request_url(@info_request), :notice => "Comments are not allowed on this request"
        end
    end

    # Banned from adding comments?
    def reject_if_user_banned
        if authenticated_user && !authenticated_user.can_make_comments?
            @details = authenticated_user.can_fail_html
            render :template => 'user/banned'
        end
    end

end