* Shows confirmed status in list.
* Adds ability to confirm users in admin UI.
* Added new english translations.
* Addresses feedback from #2245.
* More feedback.
--- /dev/null
+# frozen_string_literal: true
+
+module Admin
+ class ConfirmationsController < BaseController
+ before_action :set_account
+
+ def create
+ @account.user.confirm
+ redirect_to admin_accounts_path
+ end
+
+ private
+
+ def set_account
+ @account = Account.find(params[:account_id])
+ end
+ end
+end
scope :admins, -> { where(admin: true) }
scope :confirmed, -> { where.not(confirmed_at: nil) }
+ def confirmed?
+ confirmed_at.present?
+ end
+
def send_devise_notification(notification, *args)
devise_mailer.send(notification, self, *args).deliver_later
end
%tr
%th= t('admin.accounts.username')
%th= t('admin.accounts.domain')
+ %th= t('admin.accounts.confirmed')
%th= fa_icon 'paper-plane-o'
%th
%tbody
%td
- unless account.local?
= link_to account.domain, admin_accounts_path(by_domain: account.domain)
+ %td
+ - if account.local?
+ - if account.user.present? && account.user.confirmed?
+ %i.fa.fa-check
+ - else
+ %i.fa.fa-times
%td
- if account.local?
= t('admin.accounts.location.local')
- else
= link_to t('admin.accounts.silence'), admin_account_silence_path(@account.id), method: :post, class: 'button'
+ - unless @account.user.confirmed?
+ = link_to t('admin.accounts.confirm'), admin_account_confirmation_path(@account.id), method: :post, class: 'button'
+
- if @account.suspended?
= link_to t('admin.accounts.undo_suspension'), admin_account_suspension_path(@account.id), method: :delete, class: 'button'
- else
admin:
accounts:
are_you_sure: Are you sure?
+ confirm: Confirm
+ confirmed: Confirmed
display_name: Display name
domain: Domain
edit: Edit
resource :reset, only: [:create]
resource :silence, only: [:create, :destroy]
resource :suspension, only: [:create, :destroy]
+ resource :confirmation, only: [:create]
end
end
end
end
+ describe '#confirmed?' do
+ it 'returns true when a confirmed_at is set' do
+ user = Fabricate.build(:user, confirmed_at: Time.now.utc)
+ expect(user.confirmed?).to be true
+ end
+
+ it 'returns false if a confirmed_at is nil' do
+ user = Fabricate.build(:user, confirmed_at: nil)
+ expect(user.confirmed?).to be false
+ end
+ end
+
describe 'whitelist' do
around(:each) do |example|
old_whitelist = Rails.configuration.x.email_whitelist