summaryrefslogtreecommitdiff
path: root/example/models/user.rb
blob: daea62157eb5019894a3501446f09c8882d68448 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
class User

  def self.current
    # p "getting #{@current ? @current.login : 'nil'}"
    @current ||= User.new
  end

  attr_accessor :login
  attr_accessor :salt
  attr_accessor :verifier
  attr_accessor :active
  attr_accessor :srp

  def signup!(params)
    self.login = params.delete('login')
    self.salt = params.delete('salt').to_i
    self.verifier = params.delete('verifier').to_i
    self.active = false
  end

  def initialize_auth(params)
    srp = SRP::Server.new(self.salt, self.verifier)
    bb, u = srp.initialize_auth(params.delete('aa').to_i)
    return {:bb => bb, :u => u}
  end

  def login!(params)
    self.active = valid_login?(params[:login], params[:password])
  end

  def valid_login?(login, password)
    (self.login == login) and (self.password == password)
  end
end