module DeviseTokenAuth::Concerns::ResourceFinder

def database_adapter

def database_adapter
  @database_adapter ||= begin
    rails_version = [Rails::VERSION::MAJOR, Rails::VERSION::MINOR].join(".")
    adapter =
      if rails_version >= "6.1"
        resource_class.try(:connection_db_config)&.try(:adapter)
      else
        resource_class.try(:connection_config)&.try(:[], :adapter)
      end
  end
end

def find_resource(field, value)

def find_resource(field, value)
  @resource = if database_adapter&.include?('mysql')
                # fix for mysql default case insensitivity
                resource_class.where("BINARY #{field} = ? AND provider= ?", value, provider).first
              else
                resource_class.dta_find_by(field => value, 'provider' => provider)
              end
end

def get_case_insensitive_field_from_resource_params(field)

def get_case_insensitive_field_from_resource_params(field)
  # honor Devise configuration for case_insensitive keys
  q_value = resource_params[field.to_sym]
  if resource_class.case_insensitive_keys.include?(field.to_sym)
    q_value.downcase!
  end
  if resource_class.strip_whitespace_keys.include?(field.to_sym)
    q_value.strip!
  end
  q_value
end

def provider

def provider
  'email'
end

def resource_class(m = nil)

def resource_class(m = nil)
  mapping = if m
              Devise.mappings[m]
            else
              Devise.mappings[resource_name] || Devise.mappings.values.first
            end
  mapping.to
end