devise_auth_proxy 0.1.19 → 0.2.2
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/Gemfile.lock +1 -1
- data/README.md +4 -1
- data/lib/devise_auth_proxy.rb +4 -1
- data/lib/devise_auth_proxy/helper.rb +24 -0
- data/lib/devise_auth_proxy/strategy.rb +2 -1
- data/lib/devise_auth_proxy/version.rb +1 -1
- data/lib/service/foss_identity.rb +13 -0
- metadata +3 -2
- data/lib/devise_auth_proxy/controller.rb +0 -17
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA256:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: 6685eda6d5e050116a63de08210c1c2dccea5ae08df98bd0651e56e0992a6626
|
4
|
+
data.tar.gz: 46eac5cd37ebc5af22748c6bd9596ab1b82fb81ef1c732f010868ca5d46b94a3
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: f18939adddd8937c114e803945dd69ada09d72b892fcf2d3616be8fbd14b46d4961d5900beecbf15fff50d2ae9a8512d6794ec4a1b4d7b5b75e0c7638f6b6e7a
|
7
|
+
data.tar.gz: 9f1573f0481cd88971b3c7aeab6d71e1e6bffcf649d09fd9d694fae4ac9fb214332056ba86be45ad5dd35eed1edcaef03c20fb117d3b2f7b15d818bb19935c28
|
data/Gemfile.lock
CHANGED
data/README.md
CHANGED
@@ -24,12 +24,14 @@ Or install it yourself as:
|
|
24
24
|
|
25
25
|
Invoke hook
|
26
26
|
* Add `:auth_proxy_authenticatable` symbol to `devise` statement in User model, before other authentication strategies (e.g., `:database_authenticatable`).
|
27
|
+
* Add `include DeviseAuthProxy::Helper` to ApplicationController to override `after_sign_out_path_for` of devise if you want to modify the redirect url after sign out.
|
27
28
|
|
28
|
-
|
29
|
+
Configuration options:
|
29
30
|
* `env_key` - String (default: 'AUTH_PROXY'). Request environment key for the proxy user id.
|
30
31
|
* `attribute_map` - Hash (default: {}). Map of User model attributes to request environment keys for updating the local user when auto-creation is enabled.
|
31
32
|
* `auto_create` - Boolean (default: false). Whether to auto-create a local user from the proxy user attributes. Note: Also requires adding the Warden callbacks as shown below.
|
32
33
|
* `auto_update` - Boolean (default: false). Whether to auto-update authenticated user attributes from proxy user attributes.
|
34
|
+
* `default_role` - List (default: []). A list of role default for new user. If your application integrate with CanCan of something like that.
|
33
35
|
* `logout_url` - String (default: '/'). For redirecting to a proxy user logout URL after signing out of the Rails application. Include DeviseAuthProxy::ControllerBehavior in your application controller to enable (by overriding Devise's after_sign_out_path_for).
|
34
36
|
|
35
37
|
|
@@ -43,6 +45,7 @@ DeviseAuthProxy.configure do |config|
|
|
43
45
|
config.auto_create = true
|
44
46
|
config.auto_update = true
|
45
47
|
config.attribute_map = { email: 'mail' }
|
48
|
+
config.default_role = ['role_name / role_id']
|
46
49
|
config.logout_url = "http://localhost:3000/logout"
|
47
50
|
end
|
48
51
|
```
|
data/lib/devise_auth_proxy.rb
CHANGED
@@ -3,7 +3,7 @@ require 'devise_auth_proxy/version'
|
|
3
3
|
|
4
4
|
module DeviseAuthProxy
|
5
5
|
class << self
|
6
|
-
attr_accessor :env_key, :auto_create, :auto_update, :auth_key, :attribute_map, :default_role, :logout_url
|
6
|
+
attr_accessor :env_key, :auto_create, :auto_update, :auth_key, :attribute_map, :default_role, :logout_service, :logout_url
|
7
7
|
end
|
8
8
|
|
9
9
|
# request.env key for remote user name
|
@@ -26,6 +26,9 @@ module DeviseAuthProxy
|
|
26
26
|
# Set default role for new user.
|
27
27
|
self.default_role = []
|
28
28
|
|
29
|
+
# Set the service using to logout.
|
30
|
+
self.logout_service = nil
|
31
|
+
|
29
32
|
# Settings for redirecting to the remote user logout URL
|
30
33
|
# Enable by including DeviseAuthProxy::Controllers::Helpers in ApplicationController
|
31
34
|
# (it overrides Devise's after_sign_out_path_for method).
|
@@ -0,0 +1,24 @@
|
|
1
|
+
require 'service/foss_identity'
|
2
|
+
|
3
|
+
module DeviseAuthProxy
|
4
|
+
module Helper
|
5
|
+
|
6
|
+
# Modify session controller after user log out.
|
7
|
+
# To redirect user to a custom url.
|
8
|
+
def after_sign_out_path_for(resource_or_scope)
|
9
|
+
unless DeviseAuthProxy.logout_service.nil?
|
10
|
+
case DeviseAuthProxy.logout_service
|
11
|
+
when 'foss_identity'
|
12
|
+
Service::FossIdentity.logout(DeviseAuthProxy.logout_url, session[:http_cookie])
|
13
|
+
else
|
14
|
+
# do nothing
|
15
|
+
end
|
16
|
+
end
|
17
|
+
|
18
|
+
session.delete(:http_cookie)
|
19
|
+
|
20
|
+
return DeviseAuthProxy.logout_url if DeviseAuthProxy.logout_url
|
21
|
+
super
|
22
|
+
end
|
23
|
+
end
|
24
|
+
end
|
metadata
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: devise_auth_proxy
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 0.
|
4
|
+
version: 0.2.2
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- QuangTK
|
@@ -44,11 +44,12 @@ files:
|
|
44
44
|
- bin/setup
|
45
45
|
- devise_auth_proxy.gemspec
|
46
46
|
- lib/devise_auth_proxy.rb
|
47
|
-
- lib/devise_auth_proxy/
|
47
|
+
- lib/devise_auth_proxy/helper.rb
|
48
48
|
- lib/devise_auth_proxy/manager.rb
|
49
49
|
- lib/devise_auth_proxy/model.rb
|
50
50
|
- lib/devise_auth_proxy/strategy.rb
|
51
51
|
- lib/devise_auth_proxy/version.rb
|
52
|
+
- lib/service/foss_identity.rb
|
52
53
|
homepage: https://github.com/me0den/devise_auth_proxy
|
53
54
|
licenses:
|
54
55
|
- MIT
|
@@ -1,17 +0,0 @@
|
|
1
|
-
module DeviseAuthProxy
|
2
|
-
module Controller
|
3
|
-
|
4
|
-
# Modify session controller after user log out.
|
5
|
-
# To redirect user to a custom url.
|
6
|
-
def after_sign_out_path_for(resource_or_scope)
|
7
|
-
DeviseAuthProxy.logout_url if proxy_user_authenticated? and DeviseAuthProxy.logout_url
|
8
|
-
super
|
9
|
-
end
|
10
|
-
|
11
|
-
private
|
12
|
-
|
13
|
-
def proxy_user_authenticated?
|
14
|
-
DeviseAuthProxy.proxy_user_id(request.env).present?
|
15
|
-
end
|
16
|
-
end
|
17
|
-
end
|