Sha256: ae662fb59b2cbe9ba08b7feec13ce6df653b833a7ce998fee57795b1d3c551a3

Contents?: true

Size: 1.68 KB

Versions: 39

Compression:

Stored size: 1.68 KB

Contents

# frozen_string_literal: true

# The +Message-ID+ as specified by rfc822 is supposed to be a unique identifier for that individual email.
# That makes it an ideal tracking token for debugging and forensics, just like +X-Request-Id+ does for
# web request.
#
# If an inbound email does not, against the rfc822 mandate, specify a Message-ID, one will be generated
# using the approach from <tt>Mail::MessageIdField</tt>.
module ActionMailbox::InboundEmail::MessageId
  extend ActiveSupport::Concern

  class_methods do
    # Create a new +InboundEmail+ from the raw +source+ of the email, which be uploaded as a Active Storage
    # attachment called +raw_email+. Before the upload, extract the Message-ID from the +source+ and set
    # it as an attribute on the new +InboundEmail+.
    def create_and_extract_message_id!(source, **options)
      message_checksum = Digest::SHA1.hexdigest(source)
      message_id = extract_message_id(source) || generate_missing_message_id(message_checksum)

      create! options.merge(message_id: message_id, message_checksum: message_checksum) do |inbound_email|
        inbound_email.raw_email.attach io: StringIO.new(source), filename: "message.eml", content_type: "message/rfc822"
      end
    rescue ActiveRecord::RecordNotUnique
      nil
    end

    private
      def extract_message_id(source)
        Mail.from_source(source).message_id rescue nil
      end

      def generate_missing_message_id(message_checksum)
        Mail::MessageIdField.new("<#{message_checksum}@#{::Socket.gethostname}.mail>").message_id.tap do |message_id|
          logger.warn "Message-ID couldn't be parsed or is missing. Generated a new Message-ID: #{message_id}"
        end
      end
  end
end

Version data entries

39 entries across 39 versions & 4 rubygems

Version Path
actionmailbox-6.0.6.1 app/models/action_mailbox/inbound_email/message_id.rb
actionmailbox-6.0.6 app/models/action_mailbox/inbound_email/message_id.rb
actionmailbox-6.0.5.1 app/models/action_mailbox/inbound_email/message_id.rb
actionmailbox-6.0.5 app/models/action_mailbox/inbound_email/message_id.rb
actionmailbox-6.0.4.8 app/models/action_mailbox/inbound_email/message_id.rb
actionmailbox-6.0.4.7 app/models/action_mailbox/inbound_email/message_id.rb
actionmailbox-6.0.4.6 app/models/action_mailbox/inbound_email/message_id.rb
actionmailbox-6.0.4.5 app/models/action_mailbox/inbound_email/message_id.rb
actionmailbox-6.0.4.4 app/models/action_mailbox/inbound_email/message_id.rb
actionmailbox-6.0.4.3 app/models/action_mailbox/inbound_email/message_id.rb
actionmailbox-6.0.4.2 app/models/action_mailbox/inbound_email/message_id.rb
actionmailbox-6.0.4.1 app/models/action_mailbox/inbound_email/message_id.rb
actionmailbox-6.0.4 app/models/action_mailbox/inbound_email/message_id.rb
actionmailbox-6.0.3.7 app/models/action_mailbox/inbound_email/message_id.rb
actionmailbox-6.0.3.6 app/models/action_mailbox/inbound_email/message_id.rb
actionmailbox-6.0.3.5 app/models/action_mailbox/inbound_email/message_id.rb
actionmailbox-6.0.3.4 app/models/action_mailbox/inbound_email/message_id.rb
actionmailbox-6.0.3.3 app/models/action_mailbox/inbound_email/message_id.rb
actionmailbox-6.0.3.2 app/models/action_mailbox/inbound_email/message_id.rb
actionmailbox-6.0.3.1 app/models/action_mailbox/inbound_email/message_id.rb