Skip to content

Commit

Permalink
WIP Integrate ActionMailbox
Browse files Browse the repository at this point in the history
Integrate ActionMailbox into `RequestMailer.receive` for inbound email
handling. This maintains existing functionality but lays the groundwork
for future enhancements.

Added an `origin` column to the ActionMailbox::InboundEmail table. This
change was necessary to preserve the functionality of checking the mail
`source`, avoiding a naming clash with the `source` method.

Benefits of using ActionMailbox include:

1. Enhanced email routing capabilities, enabling specialized
   processing like the Excel hidden data spreadsheet analyzer.
2. Refactoring opportunities for `RequestMailer#receive`, particularly
   for spam detection, duplicate email handling, and initial request
   assessment.
3. Clear separation of concerns between Mailers (for sending) and
   Mailboxes (for receiving).
4. Improved email processing efficiency through ActionMailbox,
   facilitating background job handling and potential simplification
   of mail ingress.
5. Provides a solution for re-users to receive emails without needing
   their own mail server setup.

WIP
  • Loading branch information
gbp committed Oct 15, 2024
1 parent a7e161e commit f0c3f2e
Show file tree
Hide file tree
Showing 10 changed files with 75 additions and 3 deletions.
3 changes: 3 additions & 0 deletions app/mailboxes/application_mailbox.rb
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
class ApplicationMailbox < ActionMailbox::Base

Check warning on line 1 in app/mailboxes/application_mailbox.rb

View workflow job for this annotation

GitHub Actions / build

[rubocop] reported by reviewdog 🐶 Missing top-level documentation comment for `class ApplicationMailbox`. Raw Output: app/mailboxes/application_mailbox.rb:1:1: C: Style/Documentation: Missing top-level documentation comment for `class ApplicationMailbox`.
routing all: :request
end
11 changes: 11 additions & 0 deletions app/mailboxes/request_mailbox.rb
Original file line number Diff line number Diff line change
@@ -0,0 +1,11 @@
class RequestMailbox < ApplicationMailbox

Check warning on line 1 in app/mailboxes/request_mailbox.rb

View workflow job for this annotation

GitHub Actions / build

[rubocop] reported by reviewdog 🐶 Missing top-level documentation comment for `class RequestMailbox`. Raw Output: app/mailboxes/request_mailbox.rb:1:1: C: Style/Documentation: Missing top-level documentation comment for `class RequestMailbox`.
def process
mail = MailHandler.mail_from_raw_email(inbound_email.source)

RequestMailer.new.receive(
mail,
inbound_email.source,
inbound_email.origin&.to_sym
)
end
end
6 changes: 4 additions & 2 deletions app/mailers/request_mailer.rb
Original file line number Diff line number Diff line change
Expand Up @@ -210,8 +210,10 @@ def self.receive(raw_email, source = :mailin)
unless logger.nil?
logger.debug "Received mail from #{source}:\n #{raw_email}"
end
mail = MailHandler.mail_from_raw_email(raw_email)
new.receive(mail, raw_email, source)

ActionMailbox::InboundEmail.create_and_extract_message_id!(
raw_email, origin: source
)
end

# Find which info requests the email is for
Expand Down
4 changes: 3 additions & 1 deletion config/application.rb
Original file line number Diff line number Diff line change
Expand Up @@ -8,7 +8,7 @@
require "active_storage/engine"
require "action_controller/railtie"
require "action_mailer/railtie"
# require "action_mailbox/engine"
require "action_mailbox/engine"
require "action_text/engine"
require "action_view/railtie"
# require "action_cable/engine"
Expand Down Expand Up @@ -101,5 +101,7 @@ class Application < Rails::Application

# Allow the generation of full URLs in emails
config.action_mailer.default_url_options = { host: AlaveteliConfiguration.domain }

config.action_mailbox.storage_service = :inbound_emails
end
end
2 changes: 2 additions & 0 deletions config/sidekiq.yml-example
Original file line number Diff line number Diff line change
Expand Up @@ -8,6 +8,8 @@ production:
- default
- xapian
- low
- action_mailbox_routing
- action_mailbox_incineration

:limits:
xapian: 1
Expand Down
19 changes: 19 additions & 0 deletions config/storage.yml-example
Original file line number Diff line number Diff line change
Expand Up @@ -20,6 +20,25 @@
# project: ''
# bucket: ''

## Inbound Emails ##

inbound_emails_disk: &inbound_emails_disk
service: Disk
root: <%= Rails.root.join('storage/inbound_emails') %>

inbound_emails_production: &inbound_emails_production
<<: *inbound_emails_disk

inbound_emails_development: &inbound_emails_development
<<: *inbound_emails_disk

inbound_emails_test: &inbound_emails_test
service: Disk
root: <%= Rails.root.join('tmp/storage/inbound_emails') %>

inbound_emails:
<<: *inbound_emails_<%= Rails.env %>

## Raw Emails ##

raw_emails_disk: &raw_emails_disk
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,14 @@
# This migration comes from action_mailbox (originally 20180917164000)
class CreateActionMailboxTables < ActiveRecord::Migration[6.0]
def change
create_table :action_mailbox_inbound_emails do |t|
t.integer :status, default: 0, null: false
t.string :message_id, null: false
t.string :message_checksum, null: false

t.timestamps

t.index [ :message_id, :message_checksum ], name: "index_action_mailbox_inbound_emails_uniqueness", unique: true

Check warning on line 11 in db/migrate/20231214125336_create_action_mailbox_tables.action_mailbox.rb

View workflow job for this annotation

GitHub Actions / build

[rubocop] reported by reviewdog 🐶 Do not use space inside array brackets. Raw Output: db/migrate/20231214125336_create_action_mailbox_tables.action_mailbox.rb:11:16: C: Layout/SpaceInsideArrayLiteralBrackets: Do not use space inside array brackets.

Check warning on line 11 in db/migrate/20231214125336_create_action_mailbox_tables.action_mailbox.rb

View workflow job for this annotation

GitHub Actions / build

[rubocop] reported by reviewdog 🐶 Do not use space inside array brackets. Raw Output: db/migrate/20231214125336_create_action_mailbox_tables.action_mailbox.rb:11:47: C: Layout/SpaceInsideArrayLiteralBrackets: Do not use space inside array brackets.

Check warning on line 11 in db/migrate/20231214125336_create_action_mailbox_tables.action_mailbox.rb

View workflow job for this annotation

GitHub Actions / build

[rubocop] reported by reviewdog 🐶 Line is too long. [118/80] (https://rubystyle.guide#max-line-length) Raw Output: db/migrate/20231214125336_create_action_mailbox_tables.action_mailbox.rb:11:81: C: Layout/LineLength: Line is too long. [118/80] (https://rubystyle.guide#max-line-length)
end
end
end
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
class AddOriginToActionMailboxInboundEmails < ActiveRecord::Migration[7.0]
def change
add_column :action_mailbox_inbound_emails, :origin, :string
end
end
9 changes: 9 additions & 0 deletions doc/CHANGES.md
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,7 @@

## Highlighted Features

* Integrate ActionMailbox for better inbound email processing (Graeme Porteous)
* Add basic Citation searching in admin UI (Gareth Rees)
* Improve citations admin to allow title and description updates (Graeme
Porteous)
Expand Down Expand Up @@ -109,6 +110,14 @@
DAEMON=puma.service`. For detailed instructions, refer to [the
documentation](https://alaveteli.org/docs/installing/cron_and_daemons/#puma).

* _Required:_ Please update your `config/storage.yml` file to include a
production configuration for `inbound_emails`. See
`config/storage.yml-example` as an example.

* _Required:_ Please update your `config/sidekiq.yml` file to include the
`action_mailbox_routing` and `action_mailbox_incineration` queues. See
`config/sidekiq.yml-example` as an example.

* _Optional:_ Bodies with not many requests will automatically get tagged
`not_many_requests` as they are updated. If you want to automatically tag them
all in one go, run the following from the app root directory:
Expand Down
5 changes: 5 additions & 0 deletions spec/mailboxes/request_mailbox_spec.rb
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
require 'rails_helper'

RSpec.describe RequestMailbox, type: :mailbox do
pending "add some examples to (or delete) #{__FILE__}"
end

0 comments on commit f0c3f2e

Please sign in to comment.