Commit 87617f3cc4196d8253d5599d031e4a1f93e1a940
Exists in
captcha_serpro_plugin
Merge branch 'login-captcha' into captcha_serpro_core_changes_with_eugenio_changes
* login-captcha: Added the missing session store
Showing
2 changed files
with
100 additions
and
0 deletions
Show diff stats
| ... | ... | @@ -0,0 +1,53 @@ |
| 1 | +## A session store for the API. It can store | |
| 2 | +## generic data on the Rails Cache to simulate | |
| 3 | +## a stateful session for API methods | |
| 4 | +class Noosfero::API::SessionStore | |
| 5 | + | |
| 6 | + ## A generic data value to allow storing any | |
| 7 | + ## value within this SessionStore | |
| 8 | + attr_accessor :data | |
| 9 | + ## The user private_token associated with this SessionStore | |
| 10 | + attr_reader :private_token | |
| 11 | + ## The key for this SessionStore in the Rails Cache | |
| 12 | + attr_reader :key | |
| 13 | + | |
| 14 | + ## Call this method to create and store a SessionStore | |
| 15 | + ## in Rails Cache. The SessionStore is returned. The | |
| 16 | + ## client_key parameter, if used, will uniquely identify | |
| 17 | + ## this SessionStore in Rails Cache, along with the user | |
| 18 | + ## private_token in the form: client_key#private_token | |
| 19 | + def self.create(client_key = nil) | |
| 20 | + private_token = SecureRandom.hex | |
| 21 | + store = Noosfero::API::SessionStore.new(client_key, private_token) | |
| 22 | + Rails.cache.write(store.key, store, expires_in: 300) | |
| 23 | + return store | |
| 24 | + end | |
| 25 | + | |
| 26 | + ## Creates a new SessionStore. Do not use directly in cliente code. | |
| 27 | + ## Please use the self.create method instead | |
| 28 | + def initialize(client_key, private_token) | |
| 29 | + ## Creates the key to store this object in Rails Cache | |
| 30 | + key = "#{client_key}#" if client_key | |
| 31 | + key = "#{key}#{private_token}" | |
| 32 | + @key = key | |
| 33 | + @private_token = private_token | |
| 34 | + end | |
| 35 | + | |
| 36 | + ## Returns the SessionStore in Rails Cache associated | |
| 37 | + ## with the given key | |
| 38 | + def self.get(key) | |
| 39 | + Rails.cache.fetch(key) | |
| 40 | + end | |
| 41 | + | |
| 42 | + ## Stores this SessionStore in Rails Cache using the | |
| 43 | + ## key attribute as the unique identifier | |
| 44 | + def store | |
| 45 | + Rails.cache.write(@key, self) | |
| 46 | + end | |
| 47 | + | |
| 48 | + ## Remove this session store from Rails Cache | |
| 49 | + def destroy | |
| 50 | + Rails.cache.delete(@key) | |
| 51 | + end | |
| 52 | + | |
| 53 | +end | ... | ... |
| ... | ... | @@ -0,0 +1,47 @@ |
| 1 | +require File.dirname(__FILE__) + '/test_helper' | |
| 2 | + | |
| 3 | +class SessionStoreTest < ActiveSupport::TestCase | |
| 4 | + | |
| 5 | + should 'create a session store without client key' do | |
| 6 | + store = Noosfero::API::SessionStore.create | |
| 7 | + assert_not_nil store | |
| 8 | + private_token = store.private_token | |
| 9 | + assert_not_nil private_token | |
| 10 | + key = store.key | |
| 11 | + assert_not_nil key | |
| 12 | + assert_equal key, private_token | |
| 13 | + end | |
| 14 | + | |
| 15 | + should 'create a session store with client key' do | |
| 16 | + store = Noosfero::API::SessionStore.create("mykey") | |
| 17 | + assert_not_nil store | |
| 18 | + private_token = store.private_token | |
| 19 | + assert_not_nil private_token | |
| 20 | + key = store.key | |
| 21 | + assert_not_nil key | |
| 22 | + assert_equal key, "mykey##{private_token}" | |
| 23 | + end | |
| 24 | + | |
| 25 | + should 'get a session store with client key' do | |
| 26 | + store = Noosfero::API::SessionStore.create("mykey") | |
| 27 | + retrieved = Noosfero::API::SessionStore.get(store.key) | |
| 28 | + assert_not_nil retrieved | |
| 29 | + end | |
| 30 | + | |
| 31 | + should 'not get a destroyed session store with client key' do | |
| 32 | + store = Noosfero::API::SessionStore.create("mykey") | |
| 33 | + store.destroy | |
| 34 | + retrieved = Noosfero::API::SessionStore.get(store.key) | |
| 35 | + assert_nil retrieved | |
| 36 | + end | |
| 37 | + | |
| 38 | + should 'store data in session store' do | |
| 39 | + store = Noosfero::API::SessionStore.create("mykey") | |
| 40 | + store.data = [1, 2] | |
| 41 | + ## Put it back in cache | |
| 42 | + store.store | |
| 43 | + retrieved = Noosfero::API::SessionStore.get(store.key) | |
| 44 | + assert_equal [1,2], retrieved.data | |
| 45 | + end | |
| 46 | + | |
| 47 | +end | |
| 0 | 48 | \ No newline at end of file | ... | ... |