Class: Cabal::API::UserService

Inherits:
Object
  • Object
show all
Defined in:
lib/cabal/api/user_service.rb

Instance Attribute Summary collapse

Instance Method Summary collapse

Constructor Details

#initialize(user_warehouse: STORAGE[:users], access_key_warehouse: STORAGE[:access_keys], secret_key_warehouse: STORAGE[:secret_keys]) ⇒ UserService

Returns a new instance of UserService.



13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
# File 'lib/cabal/api/user_service.rb', line 13

def initialize(user_warehouse: STORAGE[:users], access_key_warehouse: STORAGE[:access_keys], secret_key_warehouse: STORAGE[:secret_keys])
  passthrough = Sekrat::Crypter::Passthrough.new

  @users = Sekrat.manager(
    warehouse: user_warehouse,
    crypter: passthrough
  )

  @access_keys = Sekrat.manager(
    warehouse: access_key_warehouse,
    crypter: passthrough
  )

  @secret_keys = Sekrat.manager(
    warehouse: secret_key_warehouse,
    crypter: Sekrat::Crypter::Aes
  )
end

Instance Attribute Details

#access_keysObject (readonly)

Returns the value of attribute access_keys.



11
12
13
# File 'lib/cabal/api/user_service.rb', line 11

def access_keys
  @access_keys
end

#secret_keysObject (readonly)

Returns the value of attribute secret_keys.



11
12
13
# File 'lib/cabal/api/user_service.rb', line 11

def secret_keys
  @secret_keys
end

#usersObject (readonly)

Returns the value of attribute users.



11
12
13
# File 'lib/cabal/api/user_service.rb', line 11

def users
  @users
end

Instance Method Details

#by_access_key(access_key) ⇒ Object



68
69
70
71
72
73
74
75
76
# File 'lib/cabal/api/user_service.rb', line 68

def by_access_key(access_key)
  email = begin
            access_keys.get(access_key, access_key)
          rescue
            return nil
          end

  by_email(email)
end

#by_email(email) ⇒ Object



52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
# File 'lib/cabal/api/user_service.rb', line 52

def by_email(email)
  user = begin
           User.new(JSON.load(users.get(email, email)))
         rescue
           return nil
         end

  crypted_secret_key = begin
                         secret_keys.get(user.access_key, user.crypto_key)
                       rescue
                         return nil
                       end

  user.new(crypted_secret_key: crypted_secret_key)
end

#create(email) ⇒ Object



32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
# File 'lib/cabal/api/user_service.rb', line 32

def create(email)
  secret_key = SecureRandom.hex(32)

  User.new(
    email: email,
    access_key: SecureRandom.hex(16),
    secret_key: secret_key,
    crypted_secret_key: BCrypt::Password.create(secret_key).to_s,
    created_at: Time.now.utc
  ).tap do |user|
    return nil unless write_user(user) &&
      write_access_key(user) &&
      write_secret_key(user)
  end
end

#listObject



48
49
50
# File 'lib/cabal/api/user_service.rb', line 48

def list
  users.ids.sort
end