]> git.openstreetmap.org Git - rails.git/commitdiff
Use Activerecord '#or' method for queries
authorAndy Allan <git@gravitystorm.co.uk>
Wed, 30 Aug 2023 16:17:15 +0000 (17:17 +0100)
committerAndy Allan <git@gravitystorm.co.uk>
Wed, 30 Aug 2023 16:17:15 +0000 (17:17 +0100)
That let's us use relation names (like `sender`) and avoid dealing
directly with ids.

app/controllers/messages_controller.rb

index e0b5b05d31900dca9032e070df3ea127fa45cd18..adb53b43ba3842d8cd0b3faf5aaa898abde4b213 100644 (file)
@@ -57,7 +57,7 @@ class MessagesController < ApplicationController
 
   # 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 = Message.where(:recipient => current_user).or(Message.where(:sender => 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?
@@ -109,7 +109,7 @@ class MessagesController < ApplicationController
 
   # Set the message as being read or unread.
   def mark
-    @message = Message.where("to_user_id = ? OR from_user_id = ?", current_user.id, current_user.id).find(params[:message_id])
+    @message = Message.where(:recipient => current_user).or(Message.where(:sender => current_user)).find(params[:message_id])
     if params[:mark] == "unread"
       message_read = false
       notice = t ".as_unread"