0

カスタム受信トレイシステムに取り組んでいます。メッセージを削除しようとすると、メッセージが削除されたというメッセージが点滅します。ただし、受信トレイから URL を入力してメッセージを表示することはできます。メッセージが実際に完全に削除されるか、少なくとも削除フォルダー (まだ作成していないフォルダー) 内に配置されるように、アクションをセットアップするにはどうすればよいですか?

メッセージ モデル:

class Message < ActiveRecord::Base
    attr_accessible :subject, :body, :sender_id, :recepient_id, :read_at,:sender_deleted,:recepient_deleted
    validates_presence_of :subject, :message => "Please enter message title"

    belongs_to :sender,
    :class_name => 'User',
    :foreign_key => 'sender_id'
    belongs_to :recepient,
    :class_name => 'User',
    :foreign_key => 'recepient_id'

    # marks a message as deleted by either the sender or the recepient, which ever the user that was passed is.
    # When both sender and recepient marks it deleted, it is destroyed.
    def mark_message_deleted(id,user_id)
        self.sender_deleted = true if self.sender_id == user_id and self.id=id
        self.recepient_deleted = true if self.recepient_id == user_id and self.id=id
        self.sender_deleted && self.recepient_deleted ? self.destroy : save!
    end

    # Read message and if it is read by recepient then mark it is read
    def self.readingmessage(id, reader)
        message = find(id, :conditions => ["sender_id = ? OR recepient_id = ?", reader, reader])
        if message.read_at.nil? && (message.recepient.user_id==reader)
            message.read_at = Time.now
            message.save!
        end
        message
    end

    # Based on if a message has been read by it's recepient returns true or false.
    def read?
        self.read_at.nil? ? false : true
    end

    def self.received_by(user)
       where(:recepient_id => user.id)
     end

     def self.not_recepient_deleted
       where("recepient_deleted = ?", false)
     end

end

メッセージ コントローラ:

class MessagesController < ApplicationController

  before_filter :set_user

  def index
    if params[:mailbox] == "sent"
      @messages = @user.sent_messages
    elsif params[:mailbox] == "inbox"
      @messages = @user.received_messages
    #elsif params[:mailbox] == "archieved"
     # @messages = @user.archived_messages
    end
  end

  def new
    @message = Message.new
    if params[:reply_to]
      @reply_to = User.find_by_user_id(params[:reply_to])
      unless @reply_to.nil?
        @message.recepient_id = @reply_to.user_id
      end
    end
  end

  def create
    @message = Message.new(params[:message])
    @message.sender_id = @user_id
    if @message.save
      flash[:notice] = "Message has been sent"
      redirect_to user_messages_path(current_user, :mailbox=>:inbox)
    else
      render :action => :new
    end
  end

  def show
    @message = Message.find(params[:id])
  end

  def delete_multiple
      if params[:delete]
        params[:delete].each { |id|
          @message = Message.find(id)
          @message.mark_message_deleted(@message.id,@user_id) unless @message.nil?
        }
        flash[:notice] = "Messages deleted"
      end
      redirect_to user_messages_path(@user, @messages)
  end

  private
    def set_user
      @user = current_user
    end
end

受信トレイ ビュー:

<h2>Your Inbox</h2>
<% if @messages.size == 0 %>
No messages in your Inbox
<% end %>
<% else %>
        <%= form_tag delete_multiple_user_messages_path, :method=>:post do %>
            <table  class="table table-bordered">
                    <tr>
                    <th>Delete?</th>
                    <th>Sent</th>
                    <th>Sender</th>
                    <th>Sent</th>
                </tr>
                    <% for message in @messages %>
                        <tr>
                            <td><%= check_box_tag "delete[]", message.id %></td>
                            <td>
                                <% if message.read? %>
                                  <%= link_to h(message.subject), user_message_path(@user, message) %>
                                <% else %>
                                  <%= link_to "#{h(message.subject)} (unread)", user_message_path(@user, message) %>
                                <% end %>
                            </td>

                            <td><%=h message.created_at.to_s(:long) %></td>
                        </tr>
            <% end %>
            </table>
        <%= submit_tag "Delete selected" %> |
        <% end %>
<%= link_to "Compose New Message", new_user_message_path(@user)%> | 
<%= link_to "View Sent Messages", user_messages_path(current_user, :mailbox => :sent)%>
4

1 に答える 1

1

どうぞ...

1 つの方法は、メッセージをデータベースから完全に削除することです。これにより、特定の URL にアクセスできたとしても、メッセージがそれ以上利用できなくなります。

または、データベースからメッセージを完全に削除するのではなく、メッセージを論理的に削除する場合は、メソッドに条件を 1 つ追加してshow、メッセージが論理的に削除された場合にページングする必要がありindexます。

だからあなたのshow方法は

デフショー
  @message = Message.where(:id => params[:id], :deleted => false).first
  @message.present でない限り、redirect_to messages_path?
終わり

上記のクエリでdeletedは、天気予報を削除したかどうかを伝えるために使用できるフィールドであると想定しました。上記のクエリは、それdeletedが false の場合にのみメッセージを返します。

アップデート:

mark_message_deletedモデルでメソッドを確認した後、メソッドを次のように変更します

def mark_message_deleted(id,user_id)
    self.sender_deleted = true if self.sender_id == user_id
    self.recepient_deleted = true if self.recepient_id == user_id
    (self.sender_deleted && self.recepient_deleted) ? self.destroy : self.save!
end

これだけで十分です。

于 2013-03-28T18:06:57.867 に答える