26f21fd5a0
* Cas authentication feature * Config * Remove class_eval + Omniauth initializer * Codeclimate review * Codeclimate review 2 * Codeclimate review 3 * Remove uid/email reconciliation * SAML authentication * Clean up code * Improve login form * Fix code style issues * Add locales
22 lines
638 B
Ruby
22 lines
638 B
Ruby
# frozen_string_literal: true
|
|
# == Schema Information
|
|
#
|
|
# Table name: identities
|
|
#
|
|
# id :integer not null, primary key
|
|
# user_id :integer
|
|
# provider :string default(""), not null
|
|
# uid :string default(""), not null
|
|
# created_at :datetime not null
|
|
# updated_at :datetime not null
|
|
#
|
|
|
|
class Identity < ApplicationRecord
|
|
belongs_to :user, dependent: :destroy
|
|
validates :uid, presence: true, uniqueness: { scope: :provider }
|
|
validates :provider, presence: true
|
|
|
|
def self.find_for_oauth(auth)
|
|
find_or_create_by(uid: auth.uid, provider: auth.provider)
|
|
end
|
|
end
|