Module: Zaikio::OAuthClient
- Defined in:
- lib/zaikio/oauth_client.rb,
lib/zaikio/oauth_client/error.rb,
lib/zaikio/oauth_client/engine.rb,
lib/zaikio/oauth_client/version.rb,
lib/zaikio/oauth_client/test_helper.rb,
lib/zaikio/oauth_client/configuration.rb,
lib/zaikio/oauth_client/authenticatable.rb,
lib/zaikio/oauth_client/system_test_helper.rb,
lib/zaikio/oauth_client/client_configuration.rb,
app/controllers/zaikio/oauth_client/sessions_controller.rb,
app/controllers/zaikio/oauth_client/connections_controller.rb,
app/controllers/zaikio/oauth_client/subscriptions_controller.rb
Overview
rubocop:disable Metrics/ModuleLength
Defined Under Namespace
Modules: Authenticatable, SystemTestHelper, TestHelper
Classes: ClientConfiguration, Configuration, ConnectionsController, Engine, InvalidScopesError, SessionsController, SubscriptionsController
Constant Summary
collapse
- VERSION =
"0.21.2".freeze
Class Method Summary
collapse
-
.client_name ⇒ Object
-
.client_name=(new_value) ⇒ Object
-
.configuration ⇒ Object
-
.configure {|configuration| ... } ⇒ Object
-
.fetch_new_token(client_config:, bearer_type:, bearer_id:, scopes:) ⇒ Object
-
.find_active_access_token(id, valid_for: 30.seconds) ⇒ Object
This method can be used to find an active access token by id.
-
.find_usable_access_token(client_name:, bearer_type:, bearer_id:, requested_scopes:, valid_for: 30.seconds) ⇒ Object
Finds active access token with matching criteria for bearer and scopes.
-
.for(client_name = nil) ⇒ Object
-
.get_access_token(bearer_id:, client_name: nil, bearer_type: "Person", scopes: nil, valid_for: 30.seconds) ⇒ Object
Finds active access token, using the DB or Client Credentials flow * It searches in the DB for an active access token * If the token does not exist, we’ll get a new one using the client_credentials flow.
-
.get_plain_scopes(scopes) ⇒ Object
-
.oauth_scheme ⇒ Object
-
.with_auth(options_or_access_token, &block) ⇒ Object
-
.with_client(new_client_name) ⇒ Object
-
.with_oauth_scheme(scheme = :request_body) ⇒ Object
Class Method Details
.client_name ⇒ Object
20
21
22
|
# File 'lib/zaikio/oauth_client.rb', line 20
def client_name
Thread.current[:zaikio_oauth_client_name]
end
|
.client_name=(new_value) ⇒ Object
24
25
26
|
# File 'lib/zaikio/oauth_client.rb', line 24
def client_name=(new_value)
Thread.current[:zaikio_oauth_client_name] = new_value
end
|
.configuration ⇒ Object
16
17
18
|
# File 'lib/zaikio/oauth_client.rb', line 16
def configuration
@configuration ||= Configuration.new
end
|
11
12
13
14
|
# File 'lib/zaikio/oauth_client.rb', line 11
def configure
@configuration ||= Configuration.new
yield(configuration)
end
|
.fetch_new_token(client_config:, bearer_type:, bearer_id:, scopes:) ⇒ Object
132
133
134
135
136
137
138
139
140
141
142
143
144
|
# File 'lib/zaikio/oauth_client.rb', line 132
def fetch_new_token(client_config:, bearer_type:, bearer_id:, scopes:)
Zaikio::AccessToken.build_from_access_token(
client_config.token_by_client_credentials(
bearer_type: bearer_type,
bearer_id: bearer_id,
scopes: scopes
),
requested_scopes: scopes,
include_refresh_token: false
).tap(&:save!)
end
|
.find_active_access_token(id, valid_for: 30.seconds) ⇒ Object
This method can be used to find an active access token by id. It might refresh the access token to get an active one.
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
|
# File 'lib/zaikio/oauth_client.rb', line 91
def find_active_access_token(id, valid_for: 30.seconds)
return unless id
if Rails.env.test?
access_token = TestHelper.find_active_access_token(id)
return access_token if access_token
end
access_token = Zaikio::AccessToken.valid(valid_for.from_now).or(
Zaikio::AccessToken.valid_refresh(valid_for.from_now)
).find_by(id: id)
access_token = access_token.refresh! if access_token&.expired?
access_token
end
|
.find_usable_access_token(client_name:, bearer_type:, bearer_id:, requested_scopes:, valid_for: 30.seconds) ⇒ Object
Finds active access token with matching criteria for bearer and scopes.
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
|
# File 'lib/zaikio/oauth_client.rb', line 108
def find_usable_access_token(client_name:, bearer_type:, bearer_id:, requested_scopes:, valid_for: 30.seconds) configuration.logger.debug "Try to fetch token for client_name: #{client_name}, " \
"bearer #{bearer_type}/#{bearer_id}, requested_scopes: #{requested_scopes}"
fetch_access_token = lambda {
Zaikio::AccessToken
.where(audience: client_name)
.by_bearer(
bearer_type: bearer_type,
bearer_id: bearer_id,
requested_scopes: requested_scopes
)
.valid(valid_for.from_now)
.order(created_at: :desc)
.first
}
if configuration.logger.respond_to?(:silence)
configuration.logger.silence { fetch_access_token.call }
else
fetch_access_token.call
end
end
|
.for(client_name = nil) ⇒ Object
28
29
30
|
# File 'lib/zaikio/oauth_client.rb', line 28
def for(client_name = nil)
client_config_for(client_name).oauth_client
end
|
.get_access_token(bearer_id:, client_name: nil, bearer_type: "Person", scopes: nil, valid_for: 30.seconds) ⇒ Object
Finds active access token, using the DB or Client Credentials flow
* It searches in the DB for an active access token
* If the token does not exist, we'll get a new one using the client_credentials flow
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
|
# File 'lib/zaikio/oauth_client.rb', line 72
def get_access_token(bearer_id:, client_name: nil, bearer_type: "Person", scopes: nil, valid_for: 30.seconds)
client_config = client_config_for(client_name || self.client_name)
scopes ||= client_config.default_scopes_for(bearer_type)
token = find_usable_access_token(client_name: client_config.client_name,
bearer_type: bearer_type,
bearer_id: bearer_id,
requested_scopes: scopes,
valid_for: valid_for)
token ||= fetch_new_token(client_config: client_config,
bearer_type: bearer_type,
bearer_id: bearer_id,
scopes: scopes)
token
end
|
.get_plain_scopes(scopes) ⇒ Object
146
147
148
149
150
151
|
# File 'lib/zaikio/oauth_client.rb', line 146
def get_plain_scopes(scopes)
regex = /^((Org|Per)\.)?(.*)$/
scopes.filter_map do |scope|
(regex.match(scope) || [])[3]
end
end
|
.oauth_scheme ⇒ Object
32
33
34
|
# File 'lib/zaikio/oauth_client.rb', line 32
def oauth_scheme
@oauth_scheme ||= :request_body
end
|
.with_auth(options_or_access_token, &block) ⇒ Object
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
|
# File 'lib/zaikio/oauth_client.rb', line 53
def with_auth(options_or_access_token, &block)
access_token = if options_or_access_token.is_a?(Zaikio::AccessToken)
options_or_access_token
else
get_access_token(**options_or_access_token)
end
return unless block
if configuration.around_auth_block
configuration.around_auth_block.call(access_token, block)
else
yield(access_token)
end
end
|
.with_client(new_client_name) ⇒ Object
43
44
45
46
47
48
49
50
51
|
# File 'lib/zaikio/oauth_client.rb', line 43
def with_client(new_client_name)
original_client_name = client_name
self.client_name = new_client_name
yield
ensure
self.client_name = original_client_name
end
|
.with_oauth_scheme(scheme = :request_body) ⇒ Object
36
37
38
39
40
41
|
# File 'lib/zaikio/oauth_client.rb', line 36
def with_oauth_scheme(scheme = :request_body)
@oauth_scheme = scheme
yield
ensure
@oauth_scheme = :request_body
end
|