demarches-normaliennes/app/models/france_connect_information.rb

45 lines
1.6 KiB
Ruby
Raw Normal View History

2020-08-06 16:35:45 +02:00
# == Schema Information
#
# Table name: france_connect_informations
#
# id :integer not null, primary key
# birthdate :date
# birthplace :string
# data :jsonb
2020-08-06 16:35:45 +02:00
# email_france_connect :string
# family_name :string
# gender :string
# given_name :string
# created_at :datetime not null
# updated_at :datetime not null
2020-08-06 16:35:45 +02:00
# france_connect_particulier_id :string
# user_id :integer not null
2020-08-06 16:35:45 +02:00
#
2018-03-06 13:44:29 +01:00
class FranceConnectInformation < ApplicationRecord
belongs_to :user, optional: true
validates :france_connect_particulier_id, presence: true, allow_blank: false, allow_nil: false
def associate_user!
user = User.find_by(email: email_france_connect.downcase)
if user.nil?
begin
user = User.create!(
email: email_france_connect.downcase,
password: Devise.friendly_token[0, 20],
confirmed_at: Time.zone.now
)
rescue ActiveRecord::RecordNotUnique
# ignore this exception because we check before is user is nil.
# exception can be raised in race conditions, when FranceConnect calls callback 2 times.
# At the 2nd call, user is nil but exception is raised at the creation of the user
# because the first call has already created a user
end
end
update_attribute('user_id', user.id)
2021-04-26 16:26:09 +02:00
touch # needed to update updated_at column
end
2017-04-04 15:27:04 +02:00
end