Module: Kingsman::Models::Recoverable::ClassMethods

Defined in:
lib/kingsman/models/recoverable.rb

Instance Method Summary collapse

Instance Method Details

#reset_password_by_token(attributes = {}) ⇒ Object

Attempt to find a user by its reset_password_token to reset its password. If a user is found and token is still valid, reset its password and automatically try saving the record. If not user is found, returns a new user containing an error in reset_password_token attribute. Attributes must contain reset_password_token, password and confirmation



134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
# File 'lib/kingsman/models/recoverable.rb', line 134

def reset_password_by_token(attributes = {})
  original_token       = attributes[:reset_password_token]
  reset_password_token = Kingsman.token_generator.digest(self, :reset_password_token, original_token)

  recoverable = find_or_initialize_with_error_by(:reset_password_token, reset_password_token)

  if recoverable.persisted?
    if recoverable.reset_password_period_valid?
      recoverable.reset_password(attributes[:password], attributes[:password_confirmation])
    else
      recoverable.errors.add(:reset_password_token, :expired)
    end
  end

  recoverable.reset_password_token = original_token if recoverable.reset_password_token.present?
  recoverable
end

#send_reset_password_instructions(attributes = {}) ⇒ Object

Attempt to find a user by its email. If a record is found, send new password instructions to it. If user is not found, returns a new user with an email not found error. Attributes must contain the user’s email



123
124
125
126
127
# File 'lib/kingsman/models/recoverable.rb', line 123

def send_reset_password_instructions(attributes = {})
  recoverable = find_or_initialize_with_errors(reset_password_keys, attributes, :not_found)
  recoverable.send_reset_password_instructions if recoverable.persisted?
  recoverable
end

#with_reset_password_token(token) ⇒ Object

Attempt to find a user by password reset token. If a user is found, return it If a user is not found, return nil



114
115
116
117
# File 'lib/kingsman/models/recoverable.rb', line 114

def with_reset_password_token(token)
  reset_password_token = Kingsman.token_generator.digest(self, :reset_password_token, token)
  to_adapter.find_first(reset_password_token: reset_password_token)
end