access_token_agent 3.1.1 → 3.2.0
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.
- checksums.yaml +4 -4
- data/.rspec +1 -0
- data/CHANGELOG.md +15 -0
- data/README.md +6 -3
- data/access_token_agent.gemspec +5 -1
- data/bin/console +11 -0
- data/lib/access_token_agent.rb +1 -0
- data/lib/access_token_agent/connector.rb +25 -9
- data/lib/access_token_agent/error.rb +3 -1
- data/lib/access_token_agent/missing_access_token.rb +7 -0
- data/lib/access_token_agent/token.rb +15 -4
- data/lib/access_token_agent/unsupported_token_type_error.rb +7 -0
- data/lib/access_token_agent/version.rb +3 -0
- metadata +6 -2
- data/lib/access_token_agent/invalid_token_type_error.rb +0 -5
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA1:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: b05e9bb8df48a419db6aa15bf18bca718638a4e8
|
4
|
+
data.tar.gz: 405ed7dfca477e3763e8acd6fc12b394813e0ffb
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: 19b6c44ddedcfdd3a7dc8a7c67dc0ab73d81c7cf11129c6bb2ccc2bf897d0cd15dee6400bf82fae597cbb49cb6b602a39ed5f56064a929ff1970e253231f7fcf
|
7
|
+
data.tar.gz: 90dab0e2595761e707ca502ec1b0b3489cbf8e7d96fdf21a6ca8952715856db351acfd29235b281567aa298d786eefc105fe751555042d77990bca76f5e3899b
|
data/.rspec
ADDED
@@ -0,0 +1 @@
|
|
1
|
+
--color
|
data/CHANGELOG.md
CHANGED
@@ -1,3 +1,18 @@
|
|
1
|
+
## master
|
2
|
+
|
3
|
+
*no unreleased changes*
|
4
|
+
|
5
|
+
## 3.2.0
|
6
|
+
|
7
|
+
- Add `http_auth_header` method to the connector, since this is the most
|
8
|
+
common use case
|
9
|
+
- Deprecate the `authenticate` method in favor of the new `token` method
|
10
|
+
- Allow to configure from which path to get the access token
|
11
|
+
- Put all errors into the AccessTokenAgent namespace
|
12
|
+
- Actually return a token when faking auth
|
13
|
+
- Rename error raised for unsupported token types
|
14
|
+
- Ensure that access token response carries an access token
|
15
|
+
|
1
16
|
## 3.1.1
|
2
17
|
|
3
18
|
- Fix broken gem release (missing files)
|
data/README.md
CHANGED
@@ -19,21 +19,24 @@ And then execute:
|
|
19
19
|
|
20
20
|
$ bundle
|
21
21
|
|
22
|
-
## Configuration
|
22
|
+
## Basic Configuration
|
23
23
|
|
24
24
|
Create an instance of AccessTokenAgent::Connector with the desired
|
25
25
|
configuration and use that instance to authenticate.
|
26
26
|
|
27
|
-
Needs the following parameters:
|
27
|
+
Needs the following parameters to instantiate:
|
28
28
|
|
29
29
|
* `host` - the server address where the auth provider is running.
|
30
30
|
* `client_id` - the client_id of the application using this gem.
|
31
31
|
* `client_secret` - the client_secret of the application using this gem.
|
32
|
+
* `access_token_path` - Allows to customize the HTTP path where the
|
33
|
+
access token needs to be requested.
|
34
|
+
**Default:** `/oauth/token`
|
32
35
|
|
33
36
|
Optional parameters:
|
34
37
|
|
35
38
|
* `fake_auth` - if true, do not connect to the auth service and return
|
36
|
-
|
39
|
+
a faked access token.
|
37
40
|
|
38
41
|
### Example
|
39
42
|
|
data/access_token_agent.gemspec
CHANGED
@@ -1,8 +1,12 @@
|
|
1
1
|
# coding: utf-8
|
2
2
|
|
3
|
+
lib = File.expand_path('../lib', __FILE__)
|
4
|
+
$LOAD_PATH.unshift(lib) unless $LOAD_PATH.include?(lib)
|
5
|
+
require 'access_token_agent/version'
|
6
|
+
|
3
7
|
Gem::Specification.new do |s|
|
4
8
|
s.name = 'access_token_agent'
|
5
|
-
s.version =
|
9
|
+
s.version = AccessTokenAgent::VERSION
|
6
10
|
s.date = '2016-04-08'
|
7
11
|
s.summary = 'Handles authentication against an OAuth2 provider'
|
8
12
|
s.homepage = 'https://github.com/kaeuferportal/access_token_agent'
|
data/bin/console
ADDED
@@ -0,0 +1,11 @@
|
|
1
|
+
#!/usr/bin/env ruby
|
2
|
+
|
3
|
+
require 'bundler/setup'
|
4
|
+
require 'access_token_agent'
|
5
|
+
|
6
|
+
# You can add fixtures and/or initialization code here to make experimenting
|
7
|
+
# with your gem easier. You can also use a different console, if you like.
|
8
|
+
|
9
|
+
# (If you use this, don't forget to add pry to your Gemfile!)
|
10
|
+
require 'pry'
|
11
|
+
Pry.start
|
data/lib/access_token_agent.rb
CHANGED
@@ -2,28 +2,44 @@ require 'net/http'
|
|
2
2
|
|
3
3
|
module AccessTokenAgent
|
4
4
|
class Connector
|
5
|
+
FAKE_TOKEN = 'FakeAuthToken'.freeze
|
6
|
+
|
5
7
|
def initialize(host:,
|
6
8
|
client_id:,
|
7
9
|
client_secret:,
|
8
|
-
fake_auth: false
|
10
|
+
fake_auth: false,
|
11
|
+
access_token_path: '/oauth/token')
|
9
12
|
@host = host
|
10
13
|
@client_id = client_id
|
11
14
|
@client_secret = client_secret
|
12
15
|
@fake_auth = fake_auth
|
16
|
+
@access_token_path = access_token_path
|
13
17
|
end
|
14
18
|
|
15
|
-
def
|
16
|
-
|
17
|
-
|
19
|
+
def http_auth_header
|
20
|
+
{ Authorization: "Bearer #{token}" }
|
21
|
+
end
|
22
|
+
|
23
|
+
def token
|
24
|
+
return FAKE_TOKEN if @fake_auth
|
25
|
+
@known_token = fetch_token unless @known_token && @known_token.valid?
|
26
|
+
|
18
27
|
@known_token.value
|
19
28
|
end
|
20
29
|
|
30
|
+
def authenticate
|
31
|
+
warn '[DEPRECATION] `authenticate` is deprecated. Use `token` instead.'
|
32
|
+
token
|
33
|
+
end
|
34
|
+
|
35
|
+
private
|
36
|
+
|
21
37
|
def fetch_token
|
22
|
-
|
38
|
+
Token.new(fetch_token_hash)
|
23
39
|
end
|
24
40
|
|
25
|
-
def
|
26
|
-
response =
|
41
|
+
def fetch_token_hash
|
42
|
+
response = perform_request
|
27
43
|
case response.code
|
28
44
|
when '200' then JSON.parse(response.body)
|
29
45
|
when '401' then raise UnauthorizedError
|
@@ -34,7 +50,7 @@ module AccessTokenAgent
|
|
34
50
|
raise ConnectionError
|
35
51
|
end
|
36
52
|
|
37
|
-
def
|
53
|
+
def perform_request
|
38
54
|
request = Net::HTTP::Post.new(auth_uri)
|
39
55
|
request.basic_auth @client_id, @client_secret
|
40
56
|
request.form_data = { 'grant_type' => 'client_credentials' }
|
@@ -47,7 +63,7 @@ module AccessTokenAgent
|
|
47
63
|
end
|
48
64
|
|
49
65
|
def auth_uri
|
50
|
-
@auth_uri ||= URI("#{@host}
|
66
|
+
@auth_uri ||= URI("#{@host}#{@access_token_path}")
|
51
67
|
end
|
52
68
|
end
|
53
69
|
end
|
@@ -1,4 +1,5 @@
|
|
1
|
-
require 'access_token_agent/
|
1
|
+
require 'access_token_agent/missing_access_token'
|
2
|
+
require 'access_token_agent/unsupported_token_type_error'
|
2
3
|
|
3
4
|
module AccessTokenAgent
|
4
5
|
class Token
|
@@ -7,9 +8,8 @@ module AccessTokenAgent
|
|
7
8
|
EXPIRY_MARGIN = 60 # seconds
|
8
9
|
|
9
10
|
def initialize(auth_response)
|
10
|
-
|
11
|
-
|
12
|
-
end
|
11
|
+
validate_response(auth_response)
|
12
|
+
|
13
13
|
@value = auth_response['access_token']
|
14
14
|
@expires_at = Time.now + auth_response['expires_in']
|
15
15
|
end
|
@@ -17,5 +17,16 @@ module AccessTokenAgent
|
|
17
17
|
def valid?
|
18
18
|
@expires_at - EXPIRY_MARGIN > Time.now
|
19
19
|
end
|
20
|
+
|
21
|
+
private
|
22
|
+
|
23
|
+
def validate_response(auth_response)
|
24
|
+
unless auth_response['token_type'] == 'bearer'
|
25
|
+
raise UnsupportedTokenTypeError, auth_response['token_type']
|
26
|
+
end
|
27
|
+
|
28
|
+
token = auth_response['access_token']
|
29
|
+
raise MissingAccessToken if token.nil? || token.empty?
|
30
|
+
end
|
20
31
|
end
|
21
32
|
end
|
metadata
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: access_token_agent
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 3.
|
4
|
+
version: 3.2.0
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- Beko Käuferportal GmbH
|
@@ -115,6 +115,7 @@ extensions: []
|
|
115
115
|
extra_rdoc_files: []
|
116
116
|
files:
|
117
117
|
- ".gitignore"
|
118
|
+
- ".rspec"
|
118
119
|
- ".rubocop.yml"
|
119
120
|
- ".ruby-version"
|
120
121
|
- ".travis.yml"
|
@@ -123,13 +124,16 @@ files:
|
|
123
124
|
- LICENSE.md
|
124
125
|
- README.md
|
125
126
|
- access_token_agent.gemspec
|
127
|
+
- bin/console
|
126
128
|
- lib/access_token_agent.rb
|
127
129
|
- lib/access_token_agent/connection_error.rb
|
128
130
|
- lib/access_token_agent/connector.rb
|
129
131
|
- lib/access_token_agent/error.rb
|
130
|
-
- lib/access_token_agent/
|
132
|
+
- lib/access_token_agent/missing_access_token.rb
|
131
133
|
- lib/access_token_agent/token.rb
|
132
134
|
- lib/access_token_agent/unauthorized_error.rb
|
135
|
+
- lib/access_token_agent/unsupported_token_type_error.rb
|
136
|
+
- lib/access_token_agent/version.rb
|
133
137
|
homepage: https://github.com/kaeuferportal/access_token_agent
|
134
138
|
licenses:
|
135
139
|
- MIT
|