class Admin::IdentitiesController < Admin::ApplicationController before_action :user before_action :identity, except: [:index, :new, :create] def new @identity = Identity.new end def create @identity = Identity.new(identity_params) @identity.user_id = user.id if @identity.save redirect_to admin_user_identities_path(@user), notice: 'User identity was successfully created.' else render :new end end def index @identities = @user.identities end def edit end def update if @identity.update_attributes(identity_params) RepairLdapBlockedUserService.new(@user).execute redirect_to admin_user_identities_path(@user), notice: 'User identity was successfully updated.' else render :edit end end def destroy if @identity.destroy RepairLdapBlockedUserService.new(@user).execute redirect_to admin_user_identities_path(@user), status: 302, notice: 'User identity was successfully removed.' else redirect_to admin_user_identities_path(@user), status: 302, alert: 'Failed to remove user identity.' end end protected def user @user ||= User.find_by!(username: params[:user_id]) end def identity @identity ||= user.identities.find(params[:id]) end def identity_params params.require(:identity).permit(:provider, :extern_uid) end end