devise-jwt 0.5.2 → 0.5.3

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: 6ae27be60b14e728a0f86baaef42c0dc4bf04813
4
- data.tar.gz: b671e8223fcc31bfbae9e020ef3c363b600e63e0
3
+ metadata.gz: 513c35a60d789e0dd80233c4d9bdfa7ae35701bc
4
+ data.tar.gz: 9b5898453832eefb55490b14044efd82b68322ef
5
5
  SHA512:
6
- metadata.gz: b78d89e4b8ef89e96a07b7ea49417b52aa04672ae585056c335d74a1fbb9c0f4e8ee7f7442df44753f20de04ebe7607af48250395451fd944595bfcf99229b23
7
- data.tar.gz: 232d88e6253117a24b34909c253fb4cd9ae81f147a2bd4e85b79e48c9d18d04cacc42c6d4f881b5ff6be805bf0903262fcedb357a3228e9b1854fb44daae9666
6
+ metadata.gz: bfa429578e3a4014f1f7d839a05a7a49ac010374c416bea67af442a4f20fbcc6ead7d2883c25c5b378ddf01f112885c0c653c3b7a50e3a87dc1e342fdd1e15f6
7
+ data.tar.gz: fbd7dffa673dee31069d347d27682041221c195aa24eff667862ad2262a8bb0fb9a5673d8df94f4f615b92705c9b4437cbad6a589d23c0a5b914426eb5f048ed
@@ -12,3 +12,5 @@ RSpec/ContextWording:
12
12
  Metrics/BlockLength:
13
13
  Exclude:
14
14
  - "spec/**/*.rb"
15
+ Style/SafeNavigation:
16
+ Enabled: false
@@ -4,6 +4,13 @@ All notable changes to this project will be documented in this file.
4
4
  The format is based on [Keep a Changelog](http://keepachangelog.com/)
5
5
  and this project adheres to [Semantic Versioning](http://semver.org/).
6
6
 
7
+ ## [0.5.3] - 2017-12-31
8
+ ### Fixed
9
+ - Do not crash for consecutive revocations of same token in blacklist &
10
+ whitelist strategies
11
+ - Update `warden-jwt_auth` dependency to allow a JWT scope to be fetched from
12
+ session in a html request
13
+
7
14
  ## [0.5.2] - 2017-12-23
8
15
  ### Added
9
16
  - Added a test helper to authenticate request headers
data/README.md CHANGED
@@ -26,7 +26,7 @@ You can read about which security concerns this library takes into account and a
26
26
  Add this line to your application's Gemfile:
27
27
 
28
28
  ```ruby
29
- gem 'devise-jwt', '~> 0.5.2'
29
+ gem 'devise-jwt', '~> 0.5.3'
30
30
  ```
31
31
 
32
32
  And then execute:
@@ -22,7 +22,7 @@ Gem::Specification.new do |spec|
22
22
  spec.require_paths = ["lib"]
23
23
 
24
24
  spec.add_dependency 'devise', '~> 4.0'
25
- spec.add_dependency 'warden-jwt_auth', '~> 0.3.2'
25
+ spec.add_dependency 'warden-jwt_auth', '~> 0.3.3'
26
26
 
27
27
  spec.add_development_dependency "bundler", "~> 1.12"
28
28
  spec.add_development_dependency "rake", "~> 10.0"
@@ -21,8 +21,8 @@ module Devise
21
21
 
22
22
  # @see Warden::JWTAuth::Interfaces::RevocationStrategy#revoke_jwt
23
23
  def self.revoke_jwt(payload, _user)
24
- create(jti: payload['jti'],
25
- exp: Time.at(payload['exp'].to_i))
24
+ find_or_create_by!(jti: payload['jti'],
25
+ exp: Time.at(payload['exp'].to_i))
26
26
  end
27
27
  end
28
28
  end
@@ -32,7 +32,8 @@ module Devise
32
32
 
33
33
  # @see Warden::JWTAuth::Interfaces::RevocationStrategy#revoke_jwt
34
34
  def self.revoke_jwt(payload, user)
35
- user.whitelisted_jwts.find_by(payload.slice('jti', 'aud')).destroy!
35
+ jwt = user.whitelisted_jwts.find_by(payload.slice('jti', 'aud'))
36
+ jwt.destroy! if jwt
36
37
  end
37
38
  end
38
39
 
@@ -2,6 +2,6 @@
2
2
 
3
3
  module Devise
4
4
  module JWT
5
- VERSION = '0.5.2'
5
+ VERSION = '0.5.3'
6
6
  end
7
7
  end
metadata CHANGED
@@ -1,14 +1,14 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: devise-jwt
3
3
  version: !ruby/object:Gem::Version
4
- version: 0.5.2
4
+ version: 0.5.3
5
5
  platform: ruby
6
6
  authors:
7
7
  - Marc Busqué
8
8
  autorequire:
9
9
  bindir: exe
10
10
  cert_chain: []
11
- date: 2017-12-23 00:00:00.000000000 Z
11
+ date: 2017-12-31 00:00:00.000000000 Z
12
12
  dependencies:
13
13
  - !ruby/object:Gem::Dependency
14
14
  name: devise
@@ -30,14 +30,14 @@ dependencies:
30
30
  requirements:
31
31
  - - "~>"
32
32
  - !ruby/object:Gem::Version
33
- version: 0.3.2
33
+ version: 0.3.3
34
34
  type: :runtime
35
35
  prerelease: false
36
36
  version_requirements: !ruby/object:Gem::Requirement
37
37
  requirements:
38
38
  - - "~>"
39
39
  - !ruby/object:Gem::Version
40
- version: 0.3.2
40
+ version: 0.3.3
41
41
  - !ruby/object:Gem::Dependency
42
42
  name: bundler
43
43
  requirement: !ruby/object:Gem::Requirement