AgileVentures/LocalSupport

View on GitHub
app/controllers/users_controller.rb

Summary

Maintainability
A
0 mins
Test Coverage
class UsersController < ApplicationController

  def edit
    @user = User.find_by_id UserParams.build(params).fetch(:id)
  end

  # we should allow logged in users to update their pending_organisation_id
  # and only superadmins should be allowed to update organisation_id
  # makes me think of a attributes permissions matrix
  def update
    org = Organisation.friendly.find(params[:pending_organisation_id])
    usr = User.find_by_id UserParams.build(params).fetch(:id)
    UserOrganisationClaimer.new(self, usr, usr).call(org.id)
  end

  def update_message_for_admin_status
    org = Organisation.friendly.find(params[:pending_organisation_id])
    flash[:notice] = "You have requested admin status for #{org.name}"
    send_email_to_superadmin_about_request_for_admin_of org   # could be moved to an hook on the user model?
    redirect_to organisation_path(org)
  end

  class UserParams
    def self.build params
      params.permit(
          :id,
          :email,
          :password,
          :password_confirmation,
          :remember_me,
          :pending_organisation_id
      )
    end
  end
end