2013-06-11 03:33:37 +08:00
|
|
|
require_dependency 'email/renderer'
|
2013-06-04 04:12:24 +08:00
|
|
|
|
|
|
|
class Admin::EmailController < Admin::AdminController
|
|
|
|
|
|
|
|
def index
|
2014-02-15 07:50:08 +08:00
|
|
|
data = { delivery_method: delivery_method, settings: delivery_settings }
|
|
|
|
render_json_dump(data)
|
2013-06-04 04:12:24 +08:00
|
|
|
end
|
|
|
|
|
|
|
|
def test
|
|
|
|
params.require(:email_address)
|
2014-11-19 23:49:12 +08:00
|
|
|
begin
|
|
|
|
Jobs::TestEmail.new.execute(to_address: params[:email_address])
|
|
|
|
render nothing: true
|
|
|
|
rescue => e
|
|
|
|
render json: {errors: [e.message]}, status: 422
|
|
|
|
end
|
2013-06-04 04:12:24 +08:00
|
|
|
end
|
|
|
|
|
2014-02-15 07:50:08 +08:00
|
|
|
def sent
|
|
|
|
email_logs = filter_email_logs(EmailLog.sent, params)
|
|
|
|
render_serialized(email_logs, EmailLogSerializer)
|
2014-02-15 02:06:21 +08:00
|
|
|
end
|
|
|
|
|
|
|
|
def skipped
|
2014-02-15 07:50:08 +08:00
|
|
|
email_logs = filter_email_logs(EmailLog.skipped, params)
|
|
|
|
render_serialized(email_logs, EmailLogSerializer)
|
2013-06-04 04:12:24 +08:00
|
|
|
end
|
|
|
|
|
2016-05-03 05:15:32 +08:00
|
|
|
def bounced
|
|
|
|
email_logs = filter_email_logs(EmailLog.bounced, params)
|
|
|
|
render_serialized(email_logs, EmailLogSerializer)
|
|
|
|
end
|
|
|
|
|
2016-01-19 07:57:55 +08:00
|
|
|
def received
|
|
|
|
incoming_emails = filter_incoming_emails(IncomingEmail, params)
|
|
|
|
render_serialized(incoming_emails, IncomingEmailSerializer)
|
|
|
|
end
|
|
|
|
|
|
|
|
def rejected
|
|
|
|
incoming_emails = filter_incoming_emails(IncomingEmail.errored, params)
|
|
|
|
render_serialized(incoming_emails, IncomingEmailSerializer)
|
|
|
|
end
|
|
|
|
|
2013-06-04 04:12:24 +08:00
|
|
|
def preview_digest
|
|
|
|
params.require(:last_seen_at)
|
2015-10-31 02:05:54 +08:00
|
|
|
params.require(:username)
|
|
|
|
user = User.find_by_username(params[:username])
|
|
|
|
renderer = Email::Renderer.new(UserNotifications.digest(user, since: params[:last_seen_at]))
|
2013-06-04 04:12:24 +08:00
|
|
|
render json: MultiJson.dump(html_content: renderer.html, text_content: renderer.text)
|
|
|
|
end
|
|
|
|
|
2016-11-24 06:46:57 +08:00
|
|
|
def send_digest
|
|
|
|
params.require(:last_seen_at)
|
|
|
|
params.require(:username)
|
|
|
|
params.require(:email)
|
|
|
|
user = User.find_by_username(params[:username])
|
|
|
|
message, skip_reason = UserNotifications.send(:digest, user, {since: params[:last_seen_at]})
|
|
|
|
if message
|
|
|
|
message.to = params[:email]
|
|
|
|
begin
|
|
|
|
Email::Sender.new(message, :digest).send
|
2016-11-25 04:05:33 +08:00
|
|
|
render json: success_json
|
2016-11-24 06:46:57 +08:00
|
|
|
rescue => e
|
|
|
|
render json: {errors: [e.message]}, status: 422
|
|
|
|
end
|
|
|
|
else
|
|
|
|
render json: {errors: skip_reason}
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2017-04-05 14:32:50 +08:00
|
|
|
def smtp_should_reject
|
|
|
|
params.require(:from)
|
|
|
|
params.require(:to)
|
|
|
|
# These strings aren't localized; they are sent to an anonymous SMTP user.
|
2017-04-06 00:46:56 +08:00
|
|
|
if !User.exists?(email: Email.downcase(params[:from])) && !SiteSetting.enable_staged_users
|
2017-04-05 14:32:50 +08:00
|
|
|
render json: { reject: true, reason: "Mail from your address is not accepted. Do you have an account here?" }
|
2017-04-06 00:45:58 +08:00
|
|
|
elsif Email::Receiver.check_address(Email.downcase(params[:to])).nil?
|
2017-04-05 14:32:50 +08:00
|
|
|
render json: { reject: true, reason: "Mail to this address is not accepted. Check the address and try to send again?" }
|
|
|
|
else
|
|
|
|
render json: { reject: false }
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2015-10-19 05:33:24 +08:00
|
|
|
def handle_mail
|
|
|
|
params.require(:email)
|
2016-06-22 21:50:49 +08:00
|
|
|
Email::Processor.process!(params[:email])
|
2015-10-19 05:33:24 +08:00
|
|
|
render text: "email was processed"
|
|
|
|
end
|
|
|
|
|
2016-02-02 04:41:49 +08:00
|
|
|
def raw_email
|
|
|
|
params.require(:id)
|
|
|
|
incoming_email = IncomingEmail.find(params[:id].to_i)
|
2017-03-09 06:15:42 +08:00
|
|
|
text, html = Email.extract_parts(incoming_email.raw)
|
|
|
|
render json: { raw_email: incoming_email.raw, text_part: text, html_part: html }
|
2016-02-02 04:41:49 +08:00
|
|
|
end
|
|
|
|
|
2016-02-11 05:00:27 +08:00
|
|
|
def incoming
|
|
|
|
params.require(:id)
|
|
|
|
incoming_email = IncomingEmail.find(params[:id].to_i)
|
|
|
|
serializer = IncomingEmailDetailsSerializer.new(incoming_email, root: false)
|
|
|
|
render_json_dump(serializer)
|
|
|
|
end
|
|
|
|
|
2017-02-23 01:51:33 +08:00
|
|
|
def incoming_from_bounced
|
|
|
|
params.require(:id)
|
|
|
|
|
2017-03-03 07:37:28 +08:00
|
|
|
begin
|
|
|
|
bounced = EmailLog.find_by(id: params[:id].to_i)
|
|
|
|
raise Discourse::InvalidParameters if bounced.nil?
|
2017-02-23 01:51:33 +08:00
|
|
|
|
2017-03-03 07:37:28 +08:00
|
|
|
email_local_part, email_domain = SiteSetting.notification_email.split('@')
|
|
|
|
bounced_to_address = "#{email_local_part}+verp-#{bounced.bounce_key}@#{email_domain}"
|
|
|
|
|
|
|
|
incoming_email = IncomingEmail.find_by(to_addresses: bounced_to_address)
|
|
|
|
raise Discourse::NotFound if incoming_email.nil?
|
|
|
|
|
|
|
|
serializer = IncomingEmailDetailsSerializer.new(incoming_email, root: false)
|
|
|
|
render_json_dump(serializer)
|
|
|
|
rescue => e
|
|
|
|
render json: {errors: [e.message]}, status: 404
|
|
|
|
end
|
2017-02-23 01:51:33 +08:00
|
|
|
end
|
|
|
|
|
2013-06-12 07:00:13 +08:00
|
|
|
private
|
|
|
|
|
2014-02-15 07:50:08 +08:00
|
|
|
def filter_email_logs(email_logs, params)
|
2016-02-16 23:35:57 +08:00
|
|
|
email_logs = email_logs.includes(:user, { post: :topic })
|
2016-01-19 07:57:55 +08:00
|
|
|
.references(:user)
|
|
|
|
.order(created_at: :desc)
|
|
|
|
.offset(params[:offset] || 0)
|
|
|
|
.limit(50)
|
|
|
|
|
|
|
|
email_logs = email_logs.where("users.username ILIKE ?", "%#{params[:user]}%") if params[:user].present?
|
|
|
|
email_logs = email_logs.where("email_logs.to_address ILIKE ?", "%#{params[:address]}%") if params[:address].present?
|
|
|
|
email_logs = email_logs.where("email_logs.email_type ILIKE ?", "%#{params[:type]}%") if params[:type].present?
|
|
|
|
email_logs = email_logs.where("email_logs.reply_key ILIKE ?", "%#{params[:reply_key]}%") if params[:reply_key].present?
|
|
|
|
email_logs = email_logs.where("email_logs.skipped_reason ILIKE ?", "%#{params[:skipped_reason]}%") if params[:skipped_reason].present?
|
|
|
|
|
|
|
|
email_logs
|
|
|
|
end
|
|
|
|
|
|
|
|
def filter_incoming_emails(incoming_emails, params)
|
|
|
|
incoming_emails = incoming_emails.includes(:user, { post: :topic })
|
|
|
|
.order(created_at: :desc)
|
|
|
|
.offset(params[:offset] || 0)
|
|
|
|
.limit(50)
|
|
|
|
|
|
|
|
incoming_emails = incoming_emails.where("from_address ILIKE ?", "%#{params[:from]}%") if params[:from].present?
|
2016-07-14 04:43:25 +08:00
|
|
|
incoming_emails = incoming_emails.where("to_addresses ILIKE :to OR cc_addresses ILIKE :to", to: "%#{params[:to]}%") if params[:to].present?
|
2016-01-19 07:57:55 +08:00
|
|
|
incoming_emails = incoming_emails.where("subject ILIKE ?", "%#{params[:subject]}%") if params[:subject].present?
|
|
|
|
incoming_emails = incoming_emails.where("error ILIKE ?", "%#{params[:error]}%") if params[:error].present?
|
|
|
|
|
|
|
|
incoming_emails
|
2014-02-15 07:50:08 +08:00
|
|
|
end
|
|
|
|
|
2013-06-12 07:00:13 +08:00
|
|
|
def delivery_settings
|
|
|
|
action_mailer_settings
|
2014-08-15 05:54:55 +08:00
|
|
|
.reject { |k, _| k == :password }
|
2013-06-12 07:00:13 +08:00
|
|
|
.map { |k, v| { name: k, value: v }}
|
|
|
|
end
|
|
|
|
|
|
|
|
def delivery_method
|
|
|
|
ActionMailer::Base.delivery_method
|
|
|
|
end
|
|
|
|
|
|
|
|
def action_mailer_settings
|
|
|
|
ActionMailer::Base.public_send "#{delivery_method}_settings"
|
|
|
|
end
|
2013-06-04 04:12:24 +08:00
|
|
|
end
|