21 lines
630 B
Ruby
21 lines
630 B
Ruby
# frozen_string_literal: true
|
|
|
|
class Profiles::ActiveSessionsController < Profiles::ApplicationController
|
|
feature_category :users
|
|
|
|
def index
|
|
@sessions = ActiveSession.list(current_user).reject(&:is_impersonated)
|
|
end
|
|
|
|
def destroy
|
|
# params[:id] can be either an Rack::Session::SessionId#private_id
|
|
# or an encrypted Rack::Session::SessionId#public_id
|
|
ActiveSession.destroy_with_deprecated_encryption(current_user, params[:id])
|
|
current_user.forget_me!
|
|
|
|
respond_to do |format|
|
|
format.html { redirect_to profile_active_sessions_url, status: :found }
|
|
format.js { head :ok }
|
|
end
|
|
end
|
|
end
|