Admin mailer parameterization (#25759)
This commit is contained in:
		
							parent
							
								
									41a505513f
								
							
						
					
					
						commit
						cf33028f35
					
				
					 10 changed files with 40 additions and 36 deletions
				
			
		|  | @ -6,45 +6,52 @@ class AdminMailer < ApplicationMailer | ||||||
|   helper :accounts |   helper :accounts | ||||||
|   helper :languages |   helper :languages | ||||||
| 
 | 
 | ||||||
|   def new_report(recipient, report) |   before_action :process_params | ||||||
|  |   before_action :set_instance | ||||||
|  | 
 | ||||||
|  |   default to: -> { @me.user_email } | ||||||
|  | 
 | ||||||
|  |   def new_report(report) | ||||||
|     @report = report |     @report = report | ||||||
|     @me       = recipient |  | ||||||
|     @instance = Rails.configuration.x.local_domain |  | ||||||
| 
 | 
 | ||||||
|     locale_for_account(@me) do |     locale_for_account(@me) do | ||||||
|       mail to: @me.user_email, subject: I18n.t('admin_mailer.new_report.subject', instance: @instance, id: @report.id) |       mail subject: default_i18n_subject(instance: @instance, id: @report.id) | ||||||
|     end |     end | ||||||
|   end |   end | ||||||
| 
 | 
 | ||||||
|   def new_appeal(recipient, appeal) |   def new_appeal(appeal) | ||||||
|     @appeal = appeal |     @appeal = appeal | ||||||
|     @me       = recipient |  | ||||||
|     @instance = Rails.configuration.x.local_domain |  | ||||||
| 
 | 
 | ||||||
|     locale_for_account(@me) do |     locale_for_account(@me) do | ||||||
|       mail to: @me.user_email, subject: I18n.t('admin_mailer.new_appeal.subject', instance: @instance, username: @appeal.account.username) |       mail subject: default_i18n_subject(instance: @instance, username: @appeal.account.username) | ||||||
|     end |     end | ||||||
|   end |   end | ||||||
| 
 | 
 | ||||||
|   def new_pending_account(recipient, user) |   def new_pending_account(user) | ||||||
|     @account = user.account |     @account = user.account | ||||||
|     @me       = recipient |  | ||||||
|     @instance = Rails.configuration.x.local_domain |  | ||||||
| 
 | 
 | ||||||
|     locale_for_account(@me) do |     locale_for_account(@me) do | ||||||
|       mail to: @me.user_email, subject: I18n.t('admin_mailer.new_pending_account.subject', instance: @instance, username: @account.username) |       mail subject: default_i18n_subject(instance: @instance, username: @account.username) | ||||||
|     end |     end | ||||||
|   end |   end | ||||||
| 
 | 
 | ||||||
|   def new_trends(recipient, links, tags, statuses) |   def new_trends(links, tags, statuses) | ||||||
|     @links                  = links |     @links                  = links | ||||||
|     @tags                   = tags |     @tags                   = tags | ||||||
|     @statuses               = statuses |     @statuses               = statuses | ||||||
|     @me                     = recipient |  | ||||||
|     @instance               = Rails.configuration.x.local_domain |  | ||||||
| 
 | 
 | ||||||
|     locale_for_account(@me) do |     locale_for_account(@me) do | ||||||
|       mail to: @me.user_email, subject: I18n.t('admin_mailer.new_trends.subject', instance: @instance) |       mail subject: default_i18n_subject(instance: @instance) | ||||||
|     end |     end | ||||||
|   end |   end | ||||||
|  | 
 | ||||||
|  |   private | ||||||
|  | 
 | ||||||
|  |   def process_params | ||||||
|  |     @me = params[:recipient] | ||||||
|  |   end | ||||||
|  | 
 | ||||||
|  |   def set_instance | ||||||
|  |     @instance = Rails.configuration.x.local_domain | ||||||
|  |   end | ||||||
| end | end | ||||||
|  |  | ||||||
|  | @ -35,7 +35,7 @@ module Trends | ||||||
|     return if links_requiring_review.empty? && tags_requiring_review.empty? && statuses_requiring_review.empty? |     return if links_requiring_review.empty? && tags_requiring_review.empty? && statuses_requiring_review.empty? | ||||||
| 
 | 
 | ||||||
|     User.those_who_can(:manage_taxonomies).includes(:account).find_each do |user| |     User.those_who_can(:manage_taxonomies).includes(:account).find_each do |user| | ||||||
|       AdminMailer.new_trends(user.account, links_requiring_review, tags_requiring_review, statuses_requiring_review).deliver_later! if user.allows_trends_review_emails? |       AdminMailer.with(recipient: user.account).new_trends(links_requiring_review, tags_requiring_review, statuses_requiring_review).deliver_later! if user.allows_trends_review_emails? | ||||||
|     end |     end | ||||||
|   end |   end | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -475,7 +475,7 @@ class User < ApplicationRecord | ||||||
|     User.those_who_can(:manage_users).includes(:account).find_each do |u| |     User.those_who_can(:manage_users).includes(:account).find_each do |u| | ||||||
|       next unless u.allows_pending_account_emails? |       next unless u.allows_pending_account_emails? | ||||||
| 
 | 
 | ||||||
|       AdminMailer.new_pending_account(u.account, self).deliver_later |       AdminMailer.with(recipient: u.account).new_pending_account(self).deliver_later | ||||||
|     end |     end | ||||||
|   end |   end | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -23,7 +23,7 @@ class AppealService < BaseService | ||||||
| 
 | 
 | ||||||
|   def notify_staff! |   def notify_staff! | ||||||
|     User.those_who_can(:manage_appeals).includes(:account).each do |u| |     User.those_who_can(:manage_appeals).includes(:account).each do |u| | ||||||
|       AdminMailer.new_appeal(u.account, @appeal).deliver_later if u.allows_appeal_emails? |       AdminMailer.with(recipient: u.account).new_appeal(@appeal).deliver_later if u.allows_appeal_emails? | ||||||
|     end |     end | ||||||
|   end |   end | ||||||
| end | end | ||||||
|  |  | ||||||
|  | @ -40,7 +40,7 @@ class ReportService < BaseService | ||||||
| 
 | 
 | ||||||
|     User.those_who_can(:manage_reports).includes(:account).each do |u| |     User.those_who_can(:manage_reports).includes(:account).each do |u| | ||||||
|       LocalNotificationWorker.perform_async(u.account_id, @report.id, 'Report', 'admin.report') |       LocalNotificationWorker.perform_async(u.account_id, @report.id, 'Report', 'admin.report') | ||||||
|       AdminMailer.new_report(u.account, @report).deliver_later if u.allows_report_emails? |       AdminMailer.with(recipient: u.account).new_report(@report).deliver_later if u.allows_report_emails? | ||||||
|     end |     end | ||||||
|   end |   end | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -63,6 +63,7 @@ ignore_unused: | ||||||
|   - 'admin_mailer.new_appeal.actions.*' |   - 'admin_mailer.new_appeal.actions.*' | ||||||
|   - 'statuses.attached.*' |   - 'statuses.attached.*' | ||||||
|   - 'move_handler.carry_{mutes,blocks}_over_text' |   - 'move_handler.carry_{mutes,blocks}_over_text' | ||||||
|  |   - 'admin_mailer.*.subject' | ||||||
|   - 'notification_mailer.*' |   - 'notification_mailer.*' | ||||||
|   - 'imports.overwrite_preambles.{following,blocking,muting,domain_blocking,bookmarks}_html' |   - 'imports.overwrite_preambles.{following,blocking,muting,domain_blocking,bookmarks}_html' | ||||||
|   - 'imports.preambles.{following,blocking,muting,domain_blocking,bookmarks}_html' |   - 'imports.preambles.{following,blocking,muting,domain_blocking,bookmarks}_html' | ||||||
|  |  | ||||||
|  | @ -23,8 +23,6 @@ RSpec.describe Api::V1::ReportsController do | ||||||
|     let(:rule_ids) { nil } |     let(:rule_ids) { nil } | ||||||
| 
 | 
 | ||||||
|     before do |     before do | ||||||
|       allow(AdminMailer).to receive(:new_report) |  | ||||||
|         .and_return(instance_double(ActionMailer::MessageDelivery, deliver_later: nil)) |  | ||||||
|       post :create, params: { status_ids: [status.id], account_id: target_account.id, comment: 'reasons', category: category, rule_ids: rule_ids, forward: forward } |       post :create, params: { status_ids: [status.id], account_id: target_account.id, comment: 'reasons', category: category, rule_ids: rule_ids, forward: forward } | ||||||
|     end |     end | ||||||
| 
 | 
 | ||||||
|  | @ -41,7 +39,7 @@ RSpec.describe Api::V1::ReportsController do | ||||||
|     end |     end | ||||||
| 
 | 
 | ||||||
|     it 'sends e-mails to admins' do |     it 'sends e-mails to admins' do | ||||||
|       expect(AdminMailer).to have_received(:new_report).with(admin.account, Report) |       expect(ActionMailer::Base.deliveries.first.to).to eq([admin.email]) | ||||||
|     end |     end | ||||||
| 
 | 
 | ||||||
|     context 'when a status does not belong to the reported account' do |     context 'when a status does not belong to the reported account' do | ||||||
|  |  | ||||||
|  | @ -14,13 +14,11 @@ RSpec.describe Disputes::AppealsController do | ||||||
|     let(:strike) { Fabricate(:account_warning, target_account: current_user.account) } |     let(:strike) { Fabricate(:account_warning, target_account: current_user.account) } | ||||||
| 
 | 
 | ||||||
|     before do |     before do | ||||||
|       allow(AdminMailer).to receive(:new_appeal) |  | ||||||
|         .and_return(instance_double(ActionMailer::MessageDelivery, deliver_later: nil)) |  | ||||||
|       post :create, params: { strike_id: strike.id, appeal: { text: 'Foo' } } |       post :create, params: { strike_id: strike.id, appeal: { text: 'Foo' } } | ||||||
|     end |     end | ||||||
| 
 | 
 | ||||||
|     it 'notifies staff about new appeal' do |     it 'notifies staff about new appeal' do | ||||||
|       expect(AdminMailer).to have_received(:new_appeal).with(admin.account, Appeal.last) |       expect(ActionMailer::Base.deliveries.first.to).to eq([admin.email]) | ||||||
|     end |     end | ||||||
| 
 | 
 | ||||||
|     it 'redirects back to the strike page' do |     it 'redirects back to the strike page' do | ||||||
|  |  | ||||||
|  | @ -7,7 +7,7 @@ RSpec.describe AdminMailer do | ||||||
|     let(:sender)    { Fabricate(:account, username: 'John') } |     let(:sender)    { Fabricate(:account, username: 'John') } | ||||||
|     let(:recipient) { Fabricate(:account, username: 'Mike') } |     let(:recipient) { Fabricate(:account, username: 'Mike') } | ||||||
|     let(:report)    { Fabricate(:report, account: sender, target_account: recipient) } |     let(:report)    { Fabricate(:report, account: sender, target_account: recipient) } | ||||||
|     let(:mail)      { described_class.new_report(recipient, report) } |     let(:mail)      { described_class.with(recipient: recipient).new_report(report) } | ||||||
| 
 | 
 | ||||||
|     before do |     before do | ||||||
|       recipient.user.update(locale: :en) |       recipient.user.update(locale: :en) | ||||||
|  | @ -27,7 +27,7 @@ RSpec.describe AdminMailer do | ||||||
|   describe '.new_appeal' do |   describe '.new_appeal' do | ||||||
|     let(:appeal) { Fabricate(:appeal) } |     let(:appeal) { Fabricate(:appeal) } | ||||||
|     let(:recipient) { Fabricate(:account, username: 'Kurt') } |     let(:recipient) { Fabricate(:account, username: 'Kurt') } | ||||||
|     let(:mail)      { described_class.new_appeal(recipient, appeal) } |     let(:mail)      { described_class.with(recipient: recipient).new_appeal(appeal) } | ||||||
| 
 | 
 | ||||||
|     before do |     before do | ||||||
|       recipient.user.update(locale: :en) |       recipient.user.update(locale: :en) | ||||||
|  | @ -47,7 +47,7 @@ RSpec.describe AdminMailer do | ||||||
|   describe '.new_pending_account' do |   describe '.new_pending_account' do | ||||||
|     let(:recipient) { Fabricate(:account, username: 'Barklums') } |     let(:recipient) { Fabricate(:account, username: 'Barklums') } | ||||||
|     let(:user) { Fabricate(:user) } |     let(:user) { Fabricate(:user) } | ||||||
|     let(:mail) { described_class.new_pending_account(recipient, user) } |     let(:mail) { described_class.with(recipient: recipient).new_pending_account(user) } | ||||||
| 
 | 
 | ||||||
|     before do |     before do | ||||||
|       recipient.user.update(locale: :en) |       recipient.user.update(locale: :en) | ||||||
|  | @ -69,7 +69,7 @@ RSpec.describe AdminMailer do | ||||||
|     let(:links) { [] } |     let(:links) { [] } | ||||||
|     let(:statuses) { [] } |     let(:statuses) { [] } | ||||||
|     let(:tags) { [] } |     let(:tags) { [] } | ||||||
|     let(:mail) { described_class.new_trends(recipient, links, tags, statuses) } |     let(:mail) { described_class.with(recipient: recipient).new_trends(links, tags, statuses) } | ||||||
| 
 | 
 | ||||||
|     before do |     before do | ||||||
|       recipient.user.update(locale: :en) |       recipient.user.update(locale: :en) | ||||||
|  |  | ||||||
|  | @ -5,16 +5,16 @@ | ||||||
| class AdminMailerPreview < ActionMailer::Preview | class AdminMailerPreview < ActionMailer::Preview | ||||||
|   # Preview this email at http://localhost:3000/rails/mailers/admin_mailer/new_pending_account |   # Preview this email at http://localhost:3000/rails/mailers/admin_mailer/new_pending_account | ||||||
|   def new_pending_account |   def new_pending_account | ||||||
|     AdminMailer.new_pending_account(Account.first, User.pending.first) |     AdminMailer.with(recipient: Account.first).new_pending_account(User.pending.first) | ||||||
|   end |   end | ||||||
| 
 | 
 | ||||||
|   # Preview this email at http://localhost:3000/rails/mailers/admin_mailer/new_trends |   # Preview this email at http://localhost:3000/rails/mailers/admin_mailer/new_trends | ||||||
|   def new_trends |   def new_trends | ||||||
|     AdminMailer.new_trends(Account.first, PreviewCard.joins(:trend).limit(3), Tag.limit(3), Status.joins(:trend).where(reblog_of_id: nil).limit(3)) |     AdminMailer.with(recipient: Account.first).new_trends(PreviewCard.joins(:trend).limit(3), Tag.limit(3), Status.joins(:trend).where(reblog_of_id: nil).limit(3)) | ||||||
|   end |   end | ||||||
| 
 | 
 | ||||||
|   # Preview this email at http://localhost:3000/rails/mailers/admin_mailer/new_appeal |   # Preview this email at http://localhost:3000/rails/mailers/admin_mailer/new_appeal | ||||||
|   def new_appeal |   def new_appeal | ||||||
|     AdminMailer.new_appeal(Account.first, Appeal.first) |     AdminMailer.with(recipient: Account.first).new_appeal(Appeal.first) | ||||||
|   end |   end | ||||||
| end | end | ||||||
|  |  | ||||||
		Loading…
	
		Reference in a new issue