77 lines
		
	
	
		
			2.0 KiB
		
	
	
	
		
			Ruby
		
	
	
	
			
		
		
	
	
			77 lines
		
	
	
		
			2.0 KiB
		
	
	
	
		
			Ruby
		
	
	
	
| # frozen_string_literal: true
 | |
| 
 | |
| # == Schema Information
 | |
| #
 | |
| # Table name: session_activations
 | |
| #
 | |
| #  id                       :bigint(8)        not null, primary key
 | |
| #  session_id               :string           not null
 | |
| #  created_at               :datetime         not null
 | |
| #  updated_at               :datetime         not null
 | |
| #  user_agent               :string           default(""), not null
 | |
| #  ip                       :inet
 | |
| #  access_token_id          :bigint(8)
 | |
| #  user_id                  :bigint(8)        not null
 | |
| #  web_push_subscription_id :bigint(8)
 | |
| #
 | |
| 
 | |
| class SessionActivation < ApplicationRecord
 | |
|   include BrowserDetection
 | |
| 
 | |
|   belongs_to :user, inverse_of: :session_activations
 | |
|   belongs_to :access_token, class_name: 'Doorkeeper::AccessToken', dependent: :destroy, optional: true
 | |
|   belongs_to :web_push_subscription, class_name: 'Web::PushSubscription', dependent: :destroy, optional: true
 | |
| 
 | |
|   delegate :token,
 | |
|            to: :access_token,
 | |
|            allow_nil: true
 | |
| 
 | |
|   before_create :assign_access_token
 | |
| 
 | |
|   DEFAULT_SCOPES = %w(read write follow).freeze
 | |
| 
 | |
|   scope :latest, -> { order(id: :desc) }
 | |
| 
 | |
|   class << self
 | |
|     def active?(id)
 | |
|       id && exists?(session_id: id)
 | |
|     end
 | |
| 
 | |
|     def activate(**)
 | |
|       activation = create!(**)
 | |
|       purge_old
 | |
|       activation
 | |
|     end
 | |
| 
 | |
|     def deactivate(id)
 | |
|       return unless id
 | |
| 
 | |
|       where(session_id: id).destroy_all
 | |
|     end
 | |
| 
 | |
|     def purge_old
 | |
|       latest.offset(Rails.configuration.x.max_session_activations).destroy_all
 | |
|     end
 | |
| 
 | |
|     def exclusive(id)
 | |
|       where.not(session_id: id).destroy_all
 | |
|     end
 | |
|   end
 | |
| 
 | |
|   private
 | |
| 
 | |
|   def assign_access_token
 | |
|     self.access_token = Doorkeeper::AccessToken.create!(access_token_attributes)
 | |
|   end
 | |
| 
 | |
|   def access_token_attributes
 | |
|     {
 | |
|       application_id: Doorkeeper::Application.find_by(superapp: true)&.id,
 | |
|       resource_owner_id: user_id,
 | |
|       scopes: DEFAULT_SCOPES.join(' '),
 | |
|       expires_in: Doorkeeper.configuration.access_token_expires_in,
 | |
|       use_refresh_token: Doorkeeper.configuration.refresh_token_enabled?,
 | |
|     }
 | |
|   end
 | |
| end
 |