oauth2_token 0.1.3 → 0.1.4

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 CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA1:
3
- metadata.gz: 7eedf89c84a83cab6b3b86c5054a9791f4acac20
4
- data.tar.gz: a605feb556d3df932bd4106881b4afdd32dc780b
3
+ metadata.gz: 421ec95d0448ebaba9477495d82c38271fae0c3e
4
+ data.tar.gz: a683c9bb9f62d1f1cd69db595c47af0728b3f4f1
5
5
  SHA512:
6
- metadata.gz: f94d62db05a86715f0d52cba0a125cec36c389631a0edb6b8226fa7770a9acb4aadb793ab7f27adaf79aec740d82fd70577ee8a1f09fa10ec72a2beb3647c33f
7
- data.tar.gz: 58bebcc6dd50aa475900a8478754c93a882d9b735bd2681d3f92d6cf6338ebfbf5177b07794b9b9219324ad550deea1a34a74260781a205eee6566de3f1e7400
6
+ metadata.gz: 9b82b103134d2e549ef3db4becfa6c275639b029e9faa4da47e9c0629ec625231faab460ec185d907a6ec84b306cb076ef112201533a323d30a2295380a4173a
7
+ data.tar.gz: 934478c6496b45314879e1b16bb246790ba6a2e09a560ae676307ba594ed14ba9ffb722e5499fa7470b8afec1ea4b6040b3ba8e5492d25d230c4aa6b572f6056
data/README.md CHANGED
@@ -23,7 +23,7 @@ Or install it yourself as:
23
23
  __authenticate and validate__
24
24
 
25
25
  # options object
26
- opts = { "uri" => "https://id.corp.aol.com/identity", "realm" => "<your realm>", "scope" => "<comma separated list of scopes>" }
26
+ opts = { "uri" => "https://<oauth2 provider url>", "realm" => "<your realm>", "scope" => "<comma separated list of scopes>" }
27
27
 
28
28
  # generate a token
29
29
  token = Oauth2Token.get_token('client_id','client_secret', opts)
data/lib/oauth2_token.rb CHANGED
@@ -1,5 +1,6 @@
1
1
  require "oauth2_token/version"
2
2
  require "httparty"
3
+ require "jwt"
3
4
 
4
5
  module Oauth2Token
5
6
 
@@ -8,12 +9,13 @@ module Oauth2Token
8
9
  def get_token(client_id, client_secret, options={})
9
10
  begin
10
11
  endpoint = get_endpoint(options['uri'], "create")
12
+ jwt = create_jwt(client_id, client_secret, endpoint, options['realm'])
11
13
  body = {
12
- "grant_type" => "client_credentials",
13
- "scope" => options['scope'],
14
- "realm" => options['realm'],
15
- "client_id" => client_id,
16
- "client_secret" => client_secret
14
+ "grant_type" => "client_credentials",
15
+ "scope" => options['scope'],
16
+ "realm" => options['realm'],
17
+ "client_assertion_type" => "urn:ietf:params:oauth:client-assertion-type:jwt-bearer",
18
+ "client_assertion" => jwt
17
19
  }
18
20
  response = wrap(HTTParty.post(endpoint, http_options.merge(:body => body)))
19
21
  response['access_token']
@@ -42,6 +44,19 @@ module Oauth2Token
42
44
 
43
45
  private
44
46
 
47
+ def create_jwt(client_id, client_secret, endpoint, realm)
48
+ iat = Time.now.to_i
49
+ exp = iat+600
50
+ payload = {
51
+ :iss => client_id,
52
+ :sub => client_id,
53
+ :aud => endpoint + '?realm=' + realm,
54
+ :iat => iat,
55
+ :exp => exp
56
+ }
57
+ JWT.encode payload, client_secret, 'HS256'
58
+ end
59
+
45
60
  def get_endpoint(uri, action)
46
61
  case action
47
62
  when "create"
@@ -1,3 +1,3 @@
1
1
  module Oauth2Token
2
- VERSION = "0.1.3"
2
+ VERSION = "0.1.4"
3
3
  end
data/oauth2_token.gemspec CHANGED
@@ -31,6 +31,7 @@ Gem::Specification.new do |spec|
31
31
  spec.require_paths = ["lib"]
32
32
 
33
33
  spec.add_dependency "httparty"
34
+ spec.add_dependency "jwt"
34
35
 
35
36
  spec.add_development_dependency "bundler", "~> 1.13"
36
37
  spec.add_development_dependency "rake", "~> 10.0"
metadata CHANGED
@@ -1,14 +1,14 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: oauth2_token
3
3
  version: !ruby/object:Gem::Version
4
- version: 0.1.3
4
+ version: 0.1.4
5
5
  platform: ruby
6
6
  authors:
7
7
  - Sandeep Malalur
8
8
  autorequire:
9
9
  bindir: exe
10
10
  cert_chain: []
11
- date: 2017-03-03 00:00:00.000000000 Z
11
+ date: 2017-08-16 00:00:00.000000000 Z
12
12
  dependencies:
13
13
  - !ruby/object:Gem::Dependency
14
14
  name: httparty
@@ -24,6 +24,20 @@ dependencies:
24
24
  - - ">="
25
25
  - !ruby/object:Gem::Version
26
26
  version: '0'
27
+ - !ruby/object:Gem::Dependency
28
+ name: jwt
29
+ requirement: !ruby/object:Gem::Requirement
30
+ requirements:
31
+ - - ">="
32
+ - !ruby/object:Gem::Version
33
+ version: '0'
34
+ type: :runtime
35
+ prerelease: false
36
+ version_requirements: !ruby/object:Gem::Requirement
37
+ requirements:
38
+ - - ">="
39
+ - !ruby/object:Gem::Version
40
+ version: '0'
27
41
  - !ruby/object:Gem::Dependency
28
42
  name: bundler
29
43
  requirement: !ruby/object:Gem::Requirement