diff options
author | David Heinemeier Hansson <david@loudthinking.com> | 2018-09-27 16:45:59 -0700 |
---|---|---|
committer | David Heinemeier Hansson <david@loudthinking.com> | 2018-09-27 16:45:59 -0700 |
commit | b1e08b468b7041ef5df179213f686722b0ead358 (patch) | |
tree | fee5085088a1b24f323f5e67f6dd2534dbb49d5e | |
parent | 4f0d6c87b15d96a4dba252be833b367bcd675e2b (diff) | |
download | rails-b1e08b468b7041ef5df179213f686722b0ead358.tar.gz rails-b1e08b468b7041ef5df179213f686722b0ead358.tar.bz2 rails-b1e08b468b7041ef5df179213f686722b0ead358.zip |
Provide a basic admin interface
BEHOLD THE CONDUCTOR!
-rw-r--r-- | app/controllers/action_mailroom/inbound_emails_controller.rb | 27 | ||||
-rw-r--r-- | app/views/action_mailroom/inbound_emails/index.html.erb | 15 | ||||
-rw-r--r-- | app/views/action_mailroom/inbound_emails/new.html.erb | 8 | ||||
-rw-r--r-- | app/views/action_mailroom/inbound_emails/show.html.erb | 8 | ||||
-rw-r--r-- | app/views/layouts/action_mailroom.html.erb | 7 | ||||
-rw-r--r-- | config/routes.rb | 4 |
6 files changed, 65 insertions, 4 deletions
diff --git a/app/controllers/action_mailroom/inbound_emails_controller.rb b/app/controllers/action_mailroom/inbound_emails_controller.rb index cf44367b7b..b8fa6cde49 100644 --- a/app/controllers/action_mailroom/inbound_emails_controller.rb +++ b/app/controllers/action_mailroom/inbound_emails_controller.rb @@ -2,15 +2,38 @@ # TODO: Spam/malware catching? # TODO: Specific bounces for SMTP good citizenship: 200/404/400 class ActionMailroom::InboundEmailsController < ActionController::Base + layout "action_mailroom" + skip_forgery_protection - before_action :require_rfc822_message + before_action :ensure_development_env, except: :create + before_action :require_rfc822_message, only: :create + + def index + @inbound_emails = ActionMailroom::InboundEmail.order(created_at: :desc) + end + + def new + end + + def show + @inbound_email = ActionMailroom::InboundEmail.find(params[:id]) + end def create ActionMailroom::InboundEmail.create_from_raw_email!(params[:message]) - head :created + + respond_to do |format| + format.html { redirect_to main_app.rails_new_inbound_email_url } + format.any { head :created } + end end private + # TODO: Should probably separate the admin interface and do more to ensure that it isn't exposed to the web + def ensure_development_env + head :forbidden unless Rails.env.development? + end + def require_rfc822_message head :unsupported_media_type unless params.require(:message).content_type == 'message/rfc822' end diff --git a/app/views/action_mailroom/inbound_emails/index.html.erb b/app/views/action_mailroom/inbound_emails/index.html.erb new file mode 100644 index 0000000000..6636e351be --- /dev/null +++ b/app/views/action_mailroom/inbound_emails/index.html.erb @@ -0,0 +1,15 @@ +<% provide :title, "Deliver new inbound email" %> + +<h1>All inbound emails</h1> + +<table> + <tr><th>Message ID</th><th>Status</th></tr> + <% @inbound_emails.each do |inbound_email| %> + <tr> + <td><%= link_to inbound_email.message_id, main_app.rails_inbound_email_path(inbound_email) %></td> + <td><%= inbound_email.status %></td> + </tr> + <% end %> +</table> + +<%= link_to "Deliver new inbound email", main_app.new_rails_inbound_email_path %>
\ No newline at end of file diff --git a/app/views/action_mailroom/inbound_emails/new.html.erb b/app/views/action_mailroom/inbound_emails/new.html.erb new file mode 100644 index 0000000000..dfd0bd7ea5 --- /dev/null +++ b/app/views/action_mailroom/inbound_emails/new.html.erb @@ -0,0 +1,8 @@ +<% provide :title, "Deliver new inbound email" %> + +<h1>Deliver new inbound email</h1> + +<%= form_with(url: main_app.rails_inbound_emails_url, remote: false) do |form| %> + <%= form.file_field :message, size: "150x50", autofocus: true %><br> + <%= form.submit "Deliver inbound email" %> +<% end %> diff --git a/app/views/action_mailroom/inbound_emails/show.html.erb b/app/views/action_mailroom/inbound_emails/show.html.erb new file mode 100644 index 0000000000..bc443775e4 --- /dev/null +++ b/app/views/action_mailroom/inbound_emails/show.html.erb @@ -0,0 +1,8 @@ +<% provide :title, @inbound_email.message_id %> + +<h1><%= @inbound_email.message_id %>: <%= @inbound_email.status %></h1> + +<ul> + <li>Retry</li> + <li>Incinerate</li> +</ul> diff --git a/app/views/layouts/action_mailroom.html.erb b/app/views/layouts/action_mailroom.html.erb new file mode 100644 index 0000000000..3efa8c3989 --- /dev/null +++ b/app/views/layouts/action_mailroom.html.erb @@ -0,0 +1,7 @@ +<html> +<head> + <title><%= yield :title %></title> +</head> +<body> +<%= yield %> +</html> diff --git a/config/routes.rb b/config/routes.rb index a24d5054cf..e19c641a68 100644 --- a/config/routes.rb +++ b/config/routes.rb @@ -1,7 +1,7 @@ # frozen_string_literal: true Rails.application.routes.draw do - scope "rails/action_mailroom" do - post "/inbound_emails" => "action_mailroom/inbound_emails#create", as: :rails_inbound_emails + scope 'rails/action_mailroom', module: 'action_mailroom' do + resources :inbound_emails, as: :rails_inbound_emails end end |