Sha256: de0588a70861cb8e08f3cf6a3354e94cfb3cdb46fae720b800905bfbb0a2f6c7

Contents?: true

Size: 1.93 KB

Versions: 3

Compression:

Stored size: 1.93 KB

Contents

module ThecoreAuthCommonsUserConcern
  extend ActiveSupport::Concern

  included do            
    before_validation on: :create do
      # If the generated uuid is not already present, then create the user with the proposed uuid
      # Otherwise, try to generate another one
      begin
          self.access_token = SecureRandom.uuid #urlsafe_base64(32)
      end while ::User.exists?(access_token: self.access_token)
    end
    # REFERENCES
    has_many :role_users, dependent: :destroy, inverse_of: :user
    has_many :roles, through: :role_users, inverse_of: :users
    # VALIDATIONS
    validates :email, uniqueness: { case_sensitive: false }, presence: true, format: { with: /\A([^@\s]+)@((?:[-a-z0-9]+\.)+[a-z]{2,})\Z/i }
    validates :password, presence: true, on: :create
    validates :password_confirmation, presence: true, on: :create
    validate :check_password_and_confirmation_equal
    validates :access_token, uniqueness: true
    validates_each :admin do |record, attr, value|
      # Don't want admin == false if the current user is the only admin
      record.errors.add(attr, I18n.t("validation.errors.cannot_unadmin_last_admin")) if record.admin_changed? && record.admin_was == true && User.where(admin: true).count == 1
    end
    validates_each :locked do |record, attr, value|
      # Don't want locked == true if the current user is the only admin
      record.errors.add(attr, I18n.t("validation.errors.cannot_lock_last_admin")) if record.locked_changed? && record.locked_was == false && User.where(locked: false).count == 1
    end
    
    def display_name
      email
    end
    
    def has_role? role
      roles.include? role.to_s
    end
    
    def authenticate password
      self&.valid_password?(password) ? self : nil
    end
    
    def check_password_and_confirmation_equal
      errors.add(:password, I18n.t("validation.errors.password_and_confirm_must_be_the_same")) unless password == password_confirmation
    end
  end
end

Version data entries

3 entries across 3 versions & 1 rubygems

Version Path
thecore_auth_commons-3.0.7 config/initializers/concern_user.rb
thecore_auth_commons-3.0.6 config/initializers/concern_user.rb
thecore_auth_commons-3.0.5 config/initializers/concern_user.rb