diff options
author | George Claghorn <george@basecamp.com> | 2018-12-26 16:18:42 -0500 |
---|---|---|
committer | George Claghorn <george@basecamp.com> | 2018-12-26 16:18:42 -0500 |
commit | 6c168aaffb37c62dee6c895a22e240e5552be669 (patch) | |
tree | b081b79a1088d9bc2bad0ee9f85fd4d7e5cc3638 /actionmailbox/app/models/action_mailbox/inbound_email/incineratable | |
parent | 11a8ba12723c919397c8ccc0b4cf2e9f50da99ed (diff) | |
download | rails-6c168aaffb37c62dee6c895a22e240e5552be669.tar.gz rails-6c168aaffb37c62dee6c895a22e240e5552be669.tar.bz2 rails-6c168aaffb37c62dee6c895a22e240e5552be669.zip |
Nest Action Mailbox classes in the API docs
Diffstat (limited to 'actionmailbox/app/models/action_mailbox/inbound_email/incineratable')
-rw-r--r-- | actionmailbox/app/models/action_mailbox/inbound_email/incineratable/incineration.rb | 38 |
1 files changed, 20 insertions, 18 deletions
diff --git a/actionmailbox/app/models/action_mailbox/inbound_email/incineratable/incineration.rb b/actionmailbox/app/models/action_mailbox/inbound_email/incineratable/incineration.rb index 4656f359bf..685f7fceb6 100644 --- a/actionmailbox/app/models/action_mailbox/inbound_email/incineratable/incineration.rb +++ b/actionmailbox/app/models/action_mailbox/inbound_email/incineratable/incineration.rb @@ -1,24 +1,26 @@ # frozen_string_literal: true -# Command class for carrying out the actual incineration of the `InboundMail` that's been scheduled -# for removal. Before the incineration – which really is just a call to `#destroy!` – is run, we verify -# that it's both eligible (by virtue of having already been processed) and time to do so (that is, -# the `InboundEmail` was processed after the `incinerate_after` time). -class ActionMailbox::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 < ActionMailbox.incinerate_after.ago.end_of_day +module ActionMailbox + # Command class for carrying out the actual incineration of the `InboundMail` that's been scheduled + # for removal. Before the incineration – which really is just a call to `#destroy!` – is run, we verify + # that it's both eligible (by virtue of having already been processed) and time to do so (that is, + # the `InboundEmail` was processed after the `incinerate_after` time). + class InboundEmail::Incineratable::Incineration + def initialize(inbound_email) + @inbound_email = inbound_email end - def processed? - @inbound_email.processed? + def run + @inbound_email.destroy! if due? && processed? end + + private + def due? + @inbound_email.updated_at < ActionMailbox.incinerate_after.ago.end_of_day + end + + def processed? + @inbound_email.processed? + end + end end |