Sha256: 3979f4b5a590213a5f118ae5478e06696e4c348fa45ad9c77802a4cefd9451f2

Contents?: true

Size: 1.99 KB

Versions: 21

Compression:

Stored size: 1.99 KB

Contents

# frozen_string_literal: true

require "mail"

module ActionMailbox
  # The +InboundEmail+ is an Active Record that keeps a reference to the raw email stored in Active Storage
  # and tracks the status of processing. By default, incoming emails will go through the following lifecycle:
  #
  # * Pending: Just received by one of the ingress controllers and scheduled for routing.
  # * Processing: During active processing, while a specific mailbox is running its #process method.
  # * Delivered: Successfully processed by the specific mailbox.
  # * Failed: An exception was raised during the specific mailbox's execution of the +#process+ method.
  # * Bounced: Rejected processing by the specific mailbox and bounced to sender.
  #
  # Once the +InboundEmail+ has reached the status of being either +delivered+, +failed+, or +bounced+,
  # it'll count as having been +#processed?+. Once processed, the +InboundEmail+ will be scheduled for
  # automatic incineration at a later point.
  #
  # When working with an +InboundEmail+, you'll usually interact with the parsed version of the source,
  # which is available as a +Mail+ object from +#mail+. But you can also access the raw source directly
  # using the +#source+ method.
  #
  # Examples:
  #
  #   inbound_email.mail.from # => 'david@loudthinking.com'
  #   inbound_email.source # Returns the full rfc822 source of the email as text
  class InboundEmail < Record
    include Incineratable, MessageId, Routable

    has_one_attached :raw_email, service: ActionMailbox.storage_service
    enum :status, %i[ pending processing delivered failed bounced ]

    def mail
      @mail ||= Mail.from_source(source)
    end

    def source
      @source ||= raw_email.download
    end

    def processed?
      delivered? || failed? || bounced?
    end

    def instrumentation_payload # :nodoc:
      {
        id: id,
        message_id: message_id,
        status: status
      }
    end
  end
end

ActiveSupport.run_load_hooks :action_mailbox_inbound_email, ActionMailbox::InboundEmail

Version data entries

21 entries across 21 versions & 2 rubygems

Version Path
actionmailbox-8.0.1 app/models/action_mailbox/inbound_email.rb
actionmailbox-8.0.0.1 app/models/action_mailbox/inbound_email.rb
actionmailbox-7.2.2.1 app/models/action_mailbox/inbound_email.rb
actionmailbox-8.0.0 app/models/action_mailbox/inbound_email.rb
actionmailbox-7.2.2 app/models/action_mailbox/inbound_email.rb
actionmailbox-8.0.0.rc2 app/models/action_mailbox/inbound_email.rb
actionmailbox-7.2.1.2 app/models/action_mailbox/inbound_email.rb
actionmailbox-8.0.0.rc1 app/models/action_mailbox/inbound_email.rb
actionmailbox-7.2.1.1 app/models/action_mailbox/inbound_email.rb
actionmailbox-8.0.0.beta1 app/models/action_mailbox/inbound_email.rb
omg-actionmailbox-8.0.0.alpha9 app/models/action_mailbox/inbound_email.rb
omg-actionmailbox-8.0.0.alpha8 app/models/action_mailbox/inbound_email.rb
omg-actionmailbox-8.0.0.alpha7 app/models/action_mailbox/inbound_email.rb
omg-actionmailbox-8.0.0.alpha4 app/models/action_mailbox/inbound_email.rb
omg-actionmailbox-8.0.0.alpha3 app/models/action_mailbox/inbound_email.rb
actionmailbox-7.2.1 app/models/action_mailbox/inbound_email.rb
actionmailbox-7.2.0 app/models/action_mailbox/inbound_email.rb
actionmailbox-7.2.0.rc1 app/models/action_mailbox/inbound_email.rb
actionmailbox-7.2.0.beta3 app/models/action_mailbox/inbound_email.rb
actionmailbox-7.2.0.beta2 app/models/action_mailbox/inbound_email.rb