simple-authorisation 0.0.4 → 0.0.5

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -39,9 +39,12 @@ module Simple
39
39
 
40
40
  anonymous_user_class = options.fetch(:anonymous_user_class, NilClass)
41
41
 
42
- return true if allow.index('?')
43
- return false if deny.index('?') and user.is_a? anonymous_user_class
44
- return true if allow.index('*') and not user.is_a? anonymous_user_class
42
+ return true if allow.index('?')
43
+ return false if deny.index('?') and user.is_a? anonymous_user_class
44
+ return true if allow.index('*') and not user.is_a? anonymous_user_class
45
+ allow.each do | allowed |
46
+ return true if user.actions.include?(allowed)
47
+ end if user.respond_to? :actions
45
48
 
46
49
  false
47
50
  end
@@ -10,7 +10,11 @@ module Sinatra
10
10
  app.before do
11
11
  route_name = request.path
12
12
  user = send(options.authorisation_current_user)
13
- unless Simple::Authorisation.is_allowed?(route_name, :user => user, :anonymous_user_class => options.authorisation_anonymous_user_class, :method => request.request_method.downcase.to_sym)
13
+ unless Simple::Authorisation.is_allowed?(
14
+ route_name,
15
+ :user => user,
16
+ :anonymous_user_class => options.authorisation_anonymous_user_class,
17
+ :method => request.request_method.downcase.to_sym)
14
18
  session[:return_to] = request.fullpath unless request.fullpath.include?('favicon.ico')
15
19
  redirect options.authorisation_login
16
20
  return false
@@ -3,7 +3,7 @@ $LOAD_PATH.unshift File.expand_path("../lib", __FILE__)
3
3
 
4
4
  Gem::Specification.new do |s|
5
5
  s.name = 'simple-authorisation'
6
- s.version = '0.0.4'
6
+ s.version = '0.0.5'
7
7
  s.authors = ["Derek Ekins"]
8
8
  s.description = 'Handles authorisation only'
9
9
  s.summary = "simple-authorisation-#{s.version}"
@@ -54,5 +54,28 @@ module Simple
54
54
  it "should raise an exception when checking is_allowed for a route with no rules" do
55
55
  lambda {Simple::Authorisation.is_allowed?('/test', :method => :get, :user => nil)}.should raise_error(Simple::Authorisation::NoSettingsForRoute)
56
56
  end
57
+
58
+ it "should be pass if we ask the user object if the user is allowed to perform the action when they are" do
59
+ user = Object.new
60
+ user.stub!(:actions).and_return(['test-action'])
61
+
62
+ Simple::Authorisation.route '/test', :allow => ['test-action']
63
+ Simple::Authorisation.is_allowed?('/test', :method => :get, :user => user).should be_true
64
+ end
65
+
66
+ it "should be fail if we ask the user object if the user is allowed to perform the action and they are not" do
67
+ user = Object.new
68
+ user.stub!(:actions).and_return(['wrong-action'])
69
+
70
+ Simple::Authorisation.route '/test', :allow => ['test-action']
71
+ Simple::Authorisation.is_allowed?('/test', :method => :get, :user => user).should be_false
72
+ end
73
+
74
+ it "should not call the actions method if it does not exist" do
75
+ user = Object.new
76
+
77
+ Simple::Authorisation.route '/test', :allow => ['test-action']
78
+ lambda{ Simple::Authorisation.is_allowed?('/test', :method => :get, :user => user)}.should_not raise_error
79
+ end
57
80
  end
58
81
  end
metadata CHANGED
@@ -1,7 +1,7 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: simple-authorisation
3
3
  version: !ruby/object:Gem::Version
4
- version: 0.0.4
4
+ version: 0.0.5
5
5
  prerelease:
6
6
  platform: ruby
7
7
  authors:
@@ -9,11 +9,11 @@ authors:
9
9
  autorequire:
10
10
  bindir: bin
11
11
  cert_chain: []
12
- date: 2011-07-28 00:00:00.000000000Z
12
+ date: 2011-08-03 00:00:00.000000000Z
13
13
  dependencies:
14
14
  - !ruby/object:Gem::Dependency
15
15
  name: sinatra
16
- requirement: &15242400 !ruby/object:Gem::Requirement
16
+ requirement: &11355540 !ruby/object:Gem::Requirement
17
17
  none: false
18
18
  requirements:
19
19
  - - ~>
@@ -21,10 +21,10 @@ dependencies:
21
21
  version: 1.2.6
22
22
  type: :runtime
23
23
  prerelease: false
24
- version_requirements: *15242400
24
+ version_requirements: *11355540
25
25
  - !ruby/object:Gem::Dependency
26
26
  name: rake
27
- requirement: &15241800 !ruby/object:Gem::Requirement
27
+ requirement: &11355060 !ruby/object:Gem::Requirement
28
28
  none: false
29
29
  requirements:
30
30
  - - ! '>='
@@ -32,10 +32,10 @@ dependencies:
32
32
  version: 0.9.2
33
33
  type: :development
34
34
  prerelease: false
35
- version_requirements: *15241800
35
+ version_requirements: *11355060
36
36
  - !ruby/object:Gem::Dependency
37
37
  name: rspec
38
- requirement: &15241240 !ruby/object:Gem::Requirement
38
+ requirement: &11354600 !ruby/object:Gem::Requirement
39
39
  none: false
40
40
  requirements:
41
41
  - - ! '>='
@@ -43,10 +43,10 @@ dependencies:
43
43
  version: 2.6.0
44
44
  type: :development
45
45
  prerelease: false
46
- version_requirements: *15241240
46
+ version_requirements: *11354600
47
47
  - !ruby/object:Gem::Dependency
48
48
  name: sinatra
49
- requirement: &15240680 !ruby/object:Gem::Requirement
49
+ requirement: &11354140 !ruby/object:Gem::Requirement
50
50
  none: false
51
51
  requirements:
52
52
  - - ! '>='
@@ -54,10 +54,10 @@ dependencies:
54
54
  version: 1.2.6
55
55
  type: :development
56
56
  prerelease: false
57
- version_requirements: *15240680
57
+ version_requirements: *11354140
58
58
  - !ruby/object:Gem::Dependency
59
59
  name: rack-test
60
- requirement: &15240120 !ruby/object:Gem::Requirement
60
+ requirement: &11353680 !ruby/object:Gem::Requirement
61
61
  none: false
62
62
  requirements:
63
63
  - - ! '>='
@@ -65,7 +65,7 @@ dependencies:
65
65
  version: 0.6.0
66
66
  type: :development
67
67
  prerelease: false
68
- version_requirements: *15240120
68
+ version_requirements: *11353680
69
69
  description: Handles authorisation only
70
70
  email: derek@spathi.com
71
71
  executables: []
@@ -117,7 +117,7 @@ rubyforge_project:
117
117
  rubygems_version: 1.8.6
118
118
  signing_key:
119
119
  specification_version: 3
120
- summary: simple-authorisation-0.0.4
120
+ summary: simple-authorisation-0.0.5
121
121
  test_files:
122
122
  - spec/simple-authorisation/authorisation_spec.rb
123
123
  - spec/simple-authorisation/sinatra_integration_spec.rb