aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--app/jobs/action_mailroom/inbound_email/incineration_job.rb11
-rw-r--r--app/models/action_mailroom/inbound_email.rb2
-rw-r--r--app/models/action_mailroom/inbound_email/incineratable.rb31
-rw-r--r--app/models/action_mailroom/inbound_email/incineratable/incineration.rb18
-rw-r--r--test/unit/inbound_email/incineration_test.rb14
5 files changed, 76 insertions, 0 deletions
diff --git a/app/jobs/action_mailroom/inbound_email/incineration_job.rb b/app/jobs/action_mailroom/inbound_email/incineration_job.rb
new file mode 100644
index 0000000000..fa1d346008
--- /dev/null
+++ b/app/jobs/action_mailroom/inbound_email/incineration_job.rb
@@ -0,0 +1,11 @@
+class ActionMailroom::InboundEmail::IncinerationJob < ApplicationJob
+ queue_as :action_mailroom_incineration
+
+ def self.schedule(inbound_email)
+ set(wait: ActionMailroom::InboundEmail::Incineratable::INCINERATABLE_AFTER).perform_later(inbound_email)
+ end
+
+ def perform(inbound_email)
+ inbound_email.incinerate
+ end
+end
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
diff --git a/test/unit/inbound_email/incineration_test.rb b/test/unit/inbound_email/incineration_test.rb
new file mode 100644
index 0000000000..10a6e564f8
--- /dev/null
+++ b/test/unit/inbound_email/incineration_test.rb
@@ -0,0 +1,14 @@
+require_relative '../../test_helper'
+
+class ActionMailroom::InboundEmail::IncinerationTest < ActiveSupport::TestCase
+ include ActiveJob::TestHelper
+
+ test "incinerate emails 30 days after they have been processed" do
+ freeze_time
+
+ assert_enqueued_with job: ActionMailroom::InboundEmail::IncinerationJob, at: 30.days.from_now do
+ inbound_email = create_inbound_email("welcome.eml")
+ inbound_email.delivered!
+ end
+ end
+end