mirror of
https://0xacab.org/sutty/sutty
synced 2024-11-24 12:46:22 +00:00
81 lines
2.3 KiB
Ruby
81 lines
2.3 KiB
Ruby
# frozen_string_literal: true
|
|
|
|
# Usuarie de la plataforma
|
|
class Usuarie < ApplicationRecord
|
|
include Usuarie::Consent
|
|
|
|
devise :invitable, :database_authenticatable,
|
|
:recoverable, :rememberable, :validatable,
|
|
:confirmable, :lockable, :registerable
|
|
|
|
validates_uniqueness_of :email
|
|
validates_with EmailAddress::ActiveRecordValidator, field: :email
|
|
|
|
before_create :lang_from_locale!
|
|
before_update :remove_confirmation_invitation_inconsistencies!
|
|
before_update :accept_invitation_after_confirmation!
|
|
|
|
has_many :roles
|
|
has_many :sites, through: :roles
|
|
has_many :blazer_audits, foreign_key: 'user_id', class_name: 'Blazer::Audit'
|
|
has_many :blazer_queries, foreign_key: 'creator_id', class_name: 'Blazer::Query'
|
|
|
|
def name
|
|
email.split('@', 2).first
|
|
end
|
|
|
|
# Encuentra el rol que tiene le usuarie en el sitio
|
|
def rol_for_site(site)
|
|
roles.find_by(site: site)
|
|
end
|
|
|
|
# XXX: Ver increment_and_lock
|
|
def can_sign_in?(password)
|
|
active_for_authentication? && valid_password?(password)
|
|
end
|
|
|
|
# XXX: Estamos duplicando la forma en que Devise bloquea acceso
|
|
# por intentos fallidos porque no tenemos forma de correr
|
|
# validate() desde la estrategia DatabaseAuthenticatable sin
|
|
# generar una redirección.
|
|
#
|
|
# lib/devise/models/lockable.rb
|
|
def increment_and_lock!
|
|
increment_failed_attempts
|
|
lock_access! if attempts_exceeded? && !access_locked?
|
|
end
|
|
|
|
def send_devise_notification(notification, *args)
|
|
I18n.with_locale(lang) do
|
|
devise_mailer.send(notification, self, *args).deliver_later
|
|
end
|
|
end
|
|
|
|
# Les usuaries necesitan link de invitación si no tenían cuenta
|
|
# y todavía no aceptaron la invitación anterior.
|
|
def needs_invitation_link?
|
|
created_by_invite? && !invitation_accepted?
|
|
end
|
|
|
|
private
|
|
|
|
def lang_from_locale!
|
|
self.lang = I18n.locale.to_s
|
|
end
|
|
|
|
# El invitation_token solo es necesario cuando fue creade por otre
|
|
# usuarie. De lo contrario lo que queremos es un proceso de
|
|
# confirmación.
|
|
def remove_confirmation_invitation_inconsistencies!
|
|
self.invitation_token = nil unless created_by_invite?
|
|
end
|
|
|
|
# Si le usuarie (re)confirma su cuenta con una invitación pendiente,
|
|
# considerarla aceptada también.
|
|
def accept_invitation_after_confirmation!
|
|
if confirmed?
|
|
self.invitation_token = nil
|
|
self.invitation_accepted_at ||= Time.now.utc
|
|
end
|
|
end
|
|
end
|