lib/doorkeeper/orm/active_record/application.rb
module Doorkeeper class Application < ActiveRecord::Base include ApplicationMixin self.table_name = "#{table_name_prefix}oauth_applications#{table_name_suffix}".to_sym if ActiveRecord::VERSION::MAJOR >= 4 has_many :authorized_tokens, -> { where(revoked_at: nil) }, class_name: 'AccessToken' else has_many :authorized_tokens, class_name: 'AccessToken', conditions: { revoked_at: nil } end has_many :authorized_applications, through: :authorized_tokens, source: :application def self.column_names_with_table self.column_names.map { |c| "#{table_name}.#{c}" } end def self.authorized_for(resource_owner) joins(:authorized_applications). where(AccessToken.table_name => { resource_owner_id: resource_owner.id, revoked_at: nil }). group(column_names_with_table.join(',')) end end end