active_session 0.0.6 → 0.1.0

Sign up to get free protection for your applications and to get access to all the features.
@@ -1,3 +1,3 @@
1
1
  module ActiveSession
2
- VERSION = "0.0.6"
2
+ VERSION = "0.1.0"
3
3
  end
@@ -4,7 +4,43 @@ require "active_session/attribute_methods"
4
4
  require "active_session/errors"
5
5
 
6
6
  module ActiveSession
7
+ # Adds a simple session mechanism for a given model.
8
+ #
9
+ # <tt>authenticates :user</tt> adds <tt>user</tt> and
10
+ # <tt>user=(new_user)</tt> methods.
11
+ #
12
+ # Options are:
13
+ # * <tt>:class_name</tt> - Specifies the class name of the
14
+ # association. Use it only if that name can't be inferred from the
15
+ # name. So <tt>authenticates :user</tt> will by default be linked
16
+ # to the User class, but if the real class name is Admin, you'll
17
+ # have to specify it using this option.
18
+ # * <tt>:foreign_key</tt> - Specifies the foreign key of the
19
+ # association. Use it only if the key can't be inferred from the
20
+ # name. So <tt>authenticates :user</tt> will by default add
21
+ # <tt>user_id</tt> and <tt>user_id=(new_user_id)</tt> methods.
22
+ # * <tt>:primary_key</tt> - Specifies the primary key of the
23
+ # association. Use it only if the key is different than <tt>id</tt>.
24
+ # * <tt>:finder_method</tt> - Specifies the finder_method for the
25
+ # association. Uses <tt>find_for_authentication</tt> method by
26
+ # default.
27
+ # * <tt>:persists</tt> - Specifies if the session model is
28
+ # persistable in the store. If set to <tt>true</tt> (default)
29
+ # <tt>foreign_key</tt> will be used to store session. So
30
+ # <tt>authenticates :user</tt> will by default store the session
31
+ # using <tt>:user_id</tt> key in the store, and use
32
+ # <tt>user_id</tt> method to fetch the stored value. You can
33
+ # change it to <tt>:email</tt> if you want to use <tt>:email</tt>
34
+ # key and <tt>email</tt> method to store the session. You can also
35
+ # turn the persistence off by passing <tt>false</tt>. Adds
36
+ # <tt>save</tt>, <tt>destroy</tt>, <tt>persisted?</tt> and a class
37
+ # method <tt>find</tt> when turned on. When turned off adds only
38
+ # <tt>persisted?</tt> method that returns false to comply with
39
+ # <tt>ActiveModel::Lint</tt>.
40
+
7
41
  def authenticates(name, options = {})
42
+ options.assert_valid_keys(:class_name, :foreign_key, :primary_key, :finder_method, :persists)
43
+
8
44
  klass = options.fetch(:class_name, name.to_s.classify)
9
45
  foreign_key = options.fetch(:foreign_key, "#{name}_id").to_sym
10
46
  primary_key = options.fetch(:primary_key, "id").to_sym
metadata CHANGED
@@ -1,7 +1,7 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: active_session
3
3
  version: !ruby/object:Gem::Version
4
- version: 0.0.6
4
+ version: 0.1.0
5
5
  prerelease:
6
6
  platform: ruby
7
7
  authors:
@@ -14,7 +14,7 @@ date: 2011-10-19 00:00:00.000000000Z
14
14
  dependencies:
15
15
  - !ruby/object:Gem::Dependency
16
16
  name: activemodel
17
- requirement: &17538940 !ruby/object:Gem::Requirement
17
+ requirement: &11440600 !ruby/object:Gem::Requirement
18
18
  none: false
19
19
  requirements:
20
20
  - - ~>
@@ -22,10 +22,10 @@ dependencies:
22
22
  version: 3.1.1
23
23
  type: :runtime
24
24
  prerelease: false
25
- version_requirements: *17538940
25
+ version_requirements: *11440600
26
26
  - !ruby/object:Gem::Dependency
27
27
  name: activesupport
28
- requirement: &17538440 !ruby/object:Gem::Requirement
28
+ requirement: &11440080 !ruby/object:Gem::Requirement
29
29
  none: false
30
30
  requirements:
31
31
  - - ~>
@@ -33,7 +33,7 @@ dependencies:
33
33
  version: 3.1.1
34
34
  type: :runtime
35
35
  prerelease: false
36
- version_requirements: *17538440
36
+ version_requirements: *11440080
37
37
  description: ActiveModel session
38
38
  email:
39
39
  - qoobaa@gmail.com