+ def create
+ @message = Message.new(message_params)
+ @message.recipient = @user
+ @message.sender = current_user
+ @message.sent_on = Time.now.utc
+
+ if current_user.sent_messages.where("sent_on >= ?", Time.now.utc - 1.hour).count >= current_user.max_messages_per_hour
+ flash.now[:error] = t ".limit_exceeded"
+ render :action => "new"
+ elsif @message.save
+ flash[:notice] = t ".message_sent"
+ UserMailer.message_notification(@message).deliver_later
+ redirect_to :action => :inbox
+ else
+ @title = t "messages.new.title"
+ render :action => "new"
+ end
+ end
+
+ # Destroy the message.
+ def destroy
+ @message = Message.where("to_user_id = ? OR from_user_id = ?", current_user.id, current_user.id).find(params[:id])
+ @message.from_user_visible = false if @message.sender == current_user
+ @message.to_user_visible = false if @message.recipient == current_user
+ if @message.save && !request.xhr?
+ flash[:notice] = t ".destroyed"
+
+ referer = safe_referer(params[:referer]) if params[:referer]
+
+ redirect_to referer || { :action => :inbox }
+ end
+ rescue ActiveRecord::RecordNotFound
+ @title = t "messages.no_such_message.title"
+ render :action => "no_such_message", :status => :not_found
+ end
+