|
| 1 | +# frozen_string_literal: true |
| 2 | + |
| 3 | +class Admin::UsersController < Admin::BaseController |
| 4 | + before_action :set_user, only: [:toggle_admin, :new_email, :confirm_email, :add_email] |
| 5 | + |
| 6 | + def active_admin_section |
| 7 | + :users |
| 8 | + end |
| 9 | + |
| 10 | + def index |
| 11 | + @users = User.active |
| 12 | + .includes(person: [:default_alias, :aliases]) |
| 13 | + .order(created_at: :desc) |
| 14 | + .limit(params.fetch(:limit, 50).to_i) |
| 15 | + .offset(params.fetch(:offset, 0).to_i) |
| 16 | + end |
| 17 | + |
| 18 | + def toggle_admin |
| 19 | + if @user == current_user |
| 20 | + return redirect_to admin_users_path, alert: "You cannot change your own admin status." |
| 21 | + end |
| 22 | + |
| 23 | + @user.update!(admin: !@user.admin?) |
| 24 | + redirect_to admin_users_path, notice: "#{@user.username || 'User'} is #{@user.admin? ? 'now' : 'no longer'} an admin." |
| 25 | + end |
| 26 | + |
| 27 | + def new_email |
| 28 | + end |
| 29 | + |
| 30 | + def confirm_email |
| 31 | + @email = params[:email].to_s.strip.downcase |
| 32 | + if @email.blank? |
| 33 | + return redirect_to new_email_admin_user_path(@user), alert: "Email address is required." |
| 34 | + end |
| 35 | + |
| 36 | + @existing_aliases = Alias.by_email(@email) |
| 37 | + @owned_by_other = @existing_aliases.where.not(user_id: [nil, @user.id]).exists? |
| 38 | + end |
| 39 | + |
| 40 | + def add_email |
| 41 | + email = params[:email].to_s.strip.downcase |
| 42 | + if email.blank? |
| 43 | + return redirect_to admin_users_path, alert: "Email address is required." |
| 44 | + end |
| 45 | + |
| 46 | + person = @user.person || Person.create! |
| 47 | + @user.update!(person_id: person.id) if @user.person_id.nil? |
| 48 | + |
| 49 | + aliases = Alias.by_email(email) |
| 50 | + |
| 51 | + if aliases.where.not(user_id: [nil, @user.id]).exists? |
| 52 | + return redirect_to admin_users_path, alert: "Email is linked to another account. Cannot associate." |
| 53 | + end |
| 54 | + |
| 55 | + if aliases.exists? |
| 56 | + aliases.find_each do |al| |
| 57 | + person.attach_alias!(al, user: @user) |
| 58 | + al.update_columns(verified_at: Time.current) |
| 59 | + end |
| 60 | + |
| 61 | + AdminEmailChange.create!( |
| 62 | + performed_by: current_user, |
| 63 | + target_user: @user, |
| 64 | + email: email, |
| 65 | + aliases_attached: aliases.count, |
| 66 | + created_new_alias: false |
| 67 | + ) |
| 68 | + else |
| 69 | + al = Alias.create!(person: person, user: @user, name: email, email: email, verified_at: Time.current) |
| 70 | + person.update!(default_alias_id: al.id) if person.default_alias_id.nil? |
| 71 | + |
| 72 | + AdminEmailChange.create!( |
| 73 | + performed_by: current_user, |
| 74 | + target_user: @user, |
| 75 | + email: email, |
| 76 | + aliases_attached: 0, |
| 77 | + created_new_alias: true |
| 78 | + ) |
| 79 | + end |
| 80 | + |
| 81 | + redirect_to admin_users_path, notice: "Email #{email} has been associated with #{@user.username || 'the user'}." |
| 82 | + end |
| 83 | + |
| 84 | + private |
| 85 | + |
| 86 | + def set_user |
| 87 | + @user = User.find(params[:id]) |
| 88 | + end |
| 89 | +end |
0 commit comments