Class: RailsJwtAuth::Session

Inherits:
Object
  • Object
show all
Defined in:
lib/rails_jwt_auth/session.rb

Defined Under Namespace

Classes: Errors

Instance Attribute Summary collapse

Instance Method Summary collapse

Constructor Details

#initialize(params = {}) ⇒ Session

Returns a new instance of Session.



7
8
9
10
11
12
13
# File 'lib/rails_jwt_auth/session.rb', line 7

def initialize(params={})
  @auth_field_value = (params[RailsJwtAuth.auth_field_name] || '').strip
  @auth_field_value.downcase! if RailsJwtAuth.downcase_auth_field
  @password = params[:password]

  find_user if @auth_field_value.present?
end

Instance Attribute Details

#errorsObject (readonly)

Returns the value of attribute errors.



3
4
5
# File 'lib/rails_jwt_auth/session.rb', line 3

def errors
  @errors
end

#jwtObject (readonly)

Returns the value of attribute jwt.



3
4
5
# File 'lib/rails_jwt_auth/session.rb', line 3

def jwt
  @jwt
end

#userObject (readonly)

Returns the value of attribute user.



3
4
5
# File 'lib/rails_jwt_auth/session.rb', line 3

def user
  @user
end

Instance Method Details

#generate!(request) ⇒ Object



21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
# File 'lib/rails_jwt_auth/session.rb', line 21

def generate!(request)
  if valid?
    user.clean_reset_password if recoverable?
    user.clean_lock if lockable?
    user.track_session_info(request) if trackable?
    user.load_auth_token

    unless user.save
      add_error(RailsJwtAuth.model_name.underscore, :invalid)

      return false
    end

    generate_jwt(request)

    true
  else
    user.failed_attempt if lockable?

    false
  end
end

#valid?Boolean

Returns:

  • (Boolean)


15
16
17
18
19
# File 'lib/rails_jwt_auth/session.rb', line 15

def valid?
  validate!

  !errors?
end