1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950 |
- # frozen_string_literal: true
- class Oauth::AuthorizedApplicationsController < Doorkeeper::AuthorizedApplicationsController
- skip_before_action :authenticate_resource_owner!
- before_action :store_current_location
- before_action :authenticate_resource_owner!
- before_action :require_not_suspended!, only: :destroy
- before_action :set_body_classes
- before_action :set_cache_headers
- before_action :set_last_used_at_by_app, only: :index, unless: -> { request.format == :json }
- skip_before_action :require_functional!
- include Localized
- def destroy
- Web::PushSubscription.unsubscribe_for(params[:id], current_resource_owner)
- super
- end
- private
- def set_body_classes
- @body_classes = 'admin'
- end
- def store_current_location
- store_location_for(:user, request.url)
- end
- def require_not_suspended!
- forbidden if current_account.unavailable?
- end
- def set_cache_headers
- response.cache_control.replace(private: true, no_store: true)
- end
- def set_last_used_at_by_app
- @last_used_at_by_app = Doorkeeper::AccessToken
- .select('DISTINCT ON (application_id) application_id, last_used_at')
- .where(resource_owner_id: current_resource_owner.id)
- .where.not(last_used_at: nil)
- .order(application_id: :desc, last_used_at: :desc)
- .pluck(:application_id, :last_used_at)
- .to_h
- end
- end
|