Class: Cabal::API::UserService
- Inherits:
-
Object
- Object
- Cabal::API::UserService
- Defined in:
- lib/cabal/api/user_service.rb
Instance Attribute Summary collapse
-
#access_keys ⇒ Object
readonly
Returns the value of attribute access_keys.
-
#secret_keys ⇒ Object
readonly
Returns the value of attribute secret_keys.
-
#users ⇒ Object
readonly
Returns the value of attribute users.
Instance Method Summary collapse
- #by_access_key(access_key) ⇒ Object
- #by_email(email) ⇒ Object
- #create(email) ⇒ Object
-
#initialize(user_warehouse: STORAGE[:users], access_key_warehouse: STORAGE[:access_keys], secret_key_warehouse: STORAGE[:secret_keys]) ⇒ UserService
constructor
A new instance of UserService.
- #list ⇒ Object
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_keys ⇒ Object (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_keys ⇒ Object (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 |
#users ⇒ Object (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 |
#list ⇒ Object
48 49 50 |
# File 'lib/cabal/api/user_service.rb', line 48 def list users.ids.sort end |