diff options
Diffstat (limited to 'app/models')
3 files changed, 51 insertions, 0 deletions
diff --git a/app/models/action_mailroom/inbound_email.rb b/app/models/action_mailroom/inbound_email.rb index 92f80f26e3..5c351b74b8 100644 --- a/app/models/action_mailroom/inbound_email.rb +++ b/app/models/action_mailroom/inbound_email.rb @@ -1,6 +1,8 @@ require "mail" class ActionMailroom::InboundEmail < ActiveRecord::Base + include Incineratable + self.table_name = "action_mailroom_inbound_emails" has_one_attached :raw_email diff --git a/app/models/action_mailroom/inbound_email/incineratable.rb b/app/models/action_mailroom/inbound_email/incineratable.rb new file mode 100644 index 0000000000..83ccec89ba --- /dev/null +++ b/app/models/action_mailroom/inbound_email/incineratable.rb @@ -0,0 +1,31 @@ +module ActionMailroom::InboundEmail::Incineratable + extend ActiveSupport::Concern + + # TODO: Extract into framework configuration + INCINERATABLE_AFTER = 30.days + + included do + before_update :remember_to_incinerate_later + after_update_commit :incinerate_later, if: :need_to_incinerate_later? + end + + def incinerate + Incineration.new(self).run + end + + private + # TODO: Use enum change tracking once merged into Active Support + def remember_to_incinerate_later + if status_changed? && (delivered? || failed?) + @incinerate_later = true + end + end + + def need_to_incinerate_later? + @incinerate_later + end + + def incinerate_later + ActionMailroom::InboundEmail::IncinerationJob.schedule(self) + end +end diff --git a/app/models/action_mailroom/inbound_email/incineratable/incineration.rb b/app/models/action_mailroom/inbound_email/incineratable/incineration.rb new file mode 100644 index 0000000000..8b88c1fc5b --- /dev/null +++ b/app/models/action_mailroom/inbound_email/incineratable/incineration.rb @@ -0,0 +1,18 @@ +class ActionMailroom::InboundEmail::Incineratable::Incineration + def initialize(inbound_email) + @inbound_email = inbound_email + end + + def run + @inbound_email.destroy if due? && processed? + end + + private + def due? + @inbound_email.updated_at < ActionMailroom::InboundEmail::Incineratable::INCINERATABLE_AFTER.ago.end_of_day + end + + def processed? + @inbound_email.delivered? || @inbound_email.failed? + end +end |