1 class DiaryCommentsController < ApplicationController
 
   4   before_action :authorize_web
 
   5   before_action :set_locale
 
   6   before_action :check_database_readable
 
  10   before_action :check_database_writable
 
  12   allow_thirdparty_images :only => :create
 
  15     @diary_entry = DiaryEntry.find(params[:id])
 
  16     @comments = @diary_entry.visible_comments
 
  17     @diary_comment = @diary_entry.comments.build(comment_params)
 
  18     @diary_comment.user = current_user
 
  19     if @diary_comment.save
 
  21       # Notify current subscribers of the new comment
 
  22       @diary_entry.subscribers.visible.each do |user|
 
  23         UserMailer.diary_comment_notification(@diary_comment, user).deliver_later if current_user != user
 
  26       # Add the commenter to the subscribers if necessary
 
  27       @diary_entry.subscriptions.create(:user => current_user) unless @diary_entry.subscribers.exists?(current_user.id)
 
  29       redirect_to diary_entry_path(@diary_entry.user, @diary_entry, :anchor => "comment#{@diary_comment.id}")
 
  31       render :action => "new"
 
  33   rescue ActiveRecord::RecordNotFound
 
  34     render "diary_entries/no_such_entry", :status => :not_found
 
  38     comment = DiaryComment.find(params[:comment])
 
  39     comment.update(:visible => false)
 
  40     redirect_to diary_entry_path(comment.diary_entry.user, comment.diary_entry)
 
  44     comment = DiaryComment.find(params[:comment])
 
  45     comment.update(:visible => true)
 
  46     redirect_to diary_entry_path(comment.diary_entry.user, comment.diary_entry)
 
  52   # return permitted diary comment parameters
 
  54     params.expect(:diary_comment => [:body])