jwt 2.10.2 → 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/CHANGELOG.md +104 -41
- data/CODE_OF_CONDUCT.md +14 -14
- data/CONTRIBUTING.md +11 -12
- data/README.md +190 -221
- data/UPGRADING.md +47 -0
- data/lib/jwt/base64.rb +1 -10
- data/lib/jwt/claims/numeric.rb +0 -32
- data/lib/jwt/claims.rb +0 -7
- data/lib/jwt/configuration/container.rb +0 -1
- data/lib/jwt/configuration/decode_configuration.rb +7 -2
- data/lib/jwt/decode.rb +25 -16
- data/lib/jwt/encoded_token/claims_context.rb +23 -0
- data/lib/jwt/encoded_token.rb +97 -14
- data/lib/jwt/error.rb +0 -3
- data/lib/jwt/jwa/ecdsa.rb +25 -4
- data/lib/jwt/jwa/hmac.rb +28 -10
- data/lib/jwt/jwa/ps.rb +1 -0
- data/lib/jwt/jwa/rsa.rb +1 -0
- data/lib/jwt/jwa/signer_context.rb +19 -0
- data/lib/jwt/jwa/signing_algorithm.rb +0 -1
- data/lib/jwt/jwa/verifier_context.rb +21 -0
- data/lib/jwt/jwa.rb +43 -26
- data/lib/jwt/jwk/ec.rb +52 -62
- data/lib/jwt/jwk/hmac.rb +3 -3
- data/lib/jwt/jwk/key_base.rb +15 -1
- data/lib/jwt/jwk/key_finder.rb +35 -9
- data/lib/jwt/jwk/rsa.rb +6 -2
- data/lib/jwt/jwk.rb +0 -1
- data/lib/jwt/token.rb +26 -7
- data/lib/jwt/version.rb +4 -28
- data/lib/jwt/x5c_key_finder.rb +1 -1
- data/lib/jwt.rb +1 -7
- data/ruby-jwt.gemspec +1 -0
- metadata +21 -13
- data/lib/jwt/claims/verification_methods.rb +0 -20
- data/lib/jwt/claims_validator.rb +0 -18
- data/lib/jwt/deprecations.rb +0 -49
- data/lib/jwt/jwa/compat.rb +0 -32
- data/lib/jwt/jwa/eddsa.rb +0 -35
- data/lib/jwt/jwa/hmac_rbnacl.rb +0 -50
- data/lib/jwt/jwa/hmac_rbnacl_fixed.rb +0 -47
- data/lib/jwt/jwa/wrapper.rb +0 -44
- data/lib/jwt/jwk/okp_rbnacl.rb +0 -109
- data/lib/jwt/verify.rb +0 -40
checksums.yaml
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
---
|
|
2
2
|
SHA256:
|
|
3
|
-
metadata.gz:
|
|
4
|
-
data.tar.gz:
|
|
3
|
+
metadata.gz: 0bb396cd444a952a2c732720675f053ce5c4557978acf54acc0753a98b81f402
|
|
4
|
+
data.tar.gz: deeb4ea2635a1620f8dab94b4b7b2d6b7a01087ea0f45b9f79b408c9a7b23c25
|
|
5
5
|
SHA512:
|
|
6
|
-
metadata.gz:
|
|
7
|
-
data.tar.gz:
|
|
6
|
+
metadata.gz: d9913bf66785a88c127148c5a4a3fd6dcd9a28820f53c20635ab5469cebdfb159366566ba8b198154c9a541927224c11e75ced5c9f5b69c1d32a9e01764ca0dd
|
|
7
|
+
data.tar.gz: e2d4765fa99b67229f3204b917aea480a1d4027c23a216f307f92d6ffa8acd049b72071377d7e0c4c8fcba5eb845f9751c944dbc87e9a597020665859edd40c1
|
data/CHANGELOG.md
CHANGED
|
@@ -1,12 +1,76 @@
|
|
|
1
1
|
# Changelog
|
|
2
2
|
|
|
3
|
-
## [
|
|
3
|
+
## [v3.2.0](https://github.com/jwt/ruby-jwt/tree/v3.2.0) (2026-05-13)
|
|
4
4
|
|
|
5
|
-
[Full Changelog](https://github.com/jwt/ruby-jwt/compare/
|
|
5
|
+
[Full Changelog](https://github.com/jwt/ruby-jwt/compare/v3.1.2...v3.2.0)
|
|
6
|
+
|
|
7
|
+
**Features:**
|
|
8
|
+
|
|
9
|
+
- Add `enforce_hmac_key_length` configuration option [#716](https://github.com/jwt/ruby-jwt/pull/716) - ([@304](https://github.com/304))
|
|
10
|
+
|
|
11
|
+
**Fixes and enhancements:**
|
|
12
|
+
|
|
13
|
+
- Reject `nil` and empty HMAC keys when signing and verifying ([CVE-2026-45363](https://www.cve.org/CVERecord?id=CVE-2026-45363) / [GHSA-c32j-vqhx-rx3x](https://github.com/jwt/ruby-jwt/security/advisories/GHSA-c32j-vqhx-rx3x))
|
|
14
|
+
- Fix compatibility with the openssl 4.0 gem [#706](https://github.com/jwt/ruby-jwt/pull/706)
|
|
15
|
+
- Test against Ruby 4.0 on CI [#707](https://github.com/jwt/ruby-jwt/pull/707)
|
|
16
|
+
- Fix type error when header is not a JSON object [#715](https://github.com/jwt/ruby-jwt/pull/715) - ([@304](https://github.com/304))
|
|
17
|
+
|
|
18
|
+
## [v3.1.2](https://github.com/jwt/ruby-jwt/tree/v3.1.2) (2025-06-28)
|
|
19
|
+
|
|
20
|
+
[Full Changelog](https://github.com/jwt/ruby-jwt/compare/v3.1.1...v3.1.2)
|
|
6
21
|
|
|
7
22
|
**Fixes and enhancements:**
|
|
8
23
|
|
|
9
24
|
- Avoid using the same digest across calls in JWT::JWA::Ecdsa and JWT::JWA::Rsa [#697](https://github.com/jwt/ruby-jwt/pull/697)
|
|
25
|
+
- Fix signing with a EC JWK [#699](https://github.com/jwt/ruby-jwt/pull/699) ([@anakinj](https://github.com/anakinj))
|
|
26
|
+
|
|
27
|
+
## [v3.1.1](https://github.com/jwt/ruby-jwt/tree/v3.1.1) (2025-06-24)
|
|
28
|
+
|
|
29
|
+
[Full Changelog](https://github.com/jwt/ruby-jwt/compare/v3.1.0...v3.1.1)
|
|
30
|
+
|
|
31
|
+
**Fixes and enhancements:**
|
|
32
|
+
|
|
33
|
+
- Require the algorithm to be provided when signing and verifying tokens using JWKs [#695](https://github.com/jwt/ruby-jwt/pull/695) ([@anakinj](https://github.com/anakinj))
|
|
34
|
+
|
|
35
|
+
## [v3.1.0](https://github.com/jwt/ruby-jwt/tree/v3.1.0) (2025-06-23)
|
|
36
|
+
|
|
37
|
+
[Full Changelog](https://github.com/jwt/ruby-jwt/compare/v3.0.0...v3.1.0)
|
|
38
|
+
|
|
39
|
+
**Features:**
|
|
40
|
+
|
|
41
|
+
- Add support for x5t header parameter for X.509 certificate thumbprint verification [#669](https://github.com/jwt/ruby-jwt/pull/669) ([@hieuk09](https://github.com/hieuk09))
|
|
42
|
+
- Raise an error if the ECDSA signing or verification key is not an instance of `OpenSSL::PKey::EC` [#688](https://github.com/jwt/ruby-jwt/pull/688) ([@anakinj](https://github.com/anakinj))
|
|
43
|
+
- Allow `OpenSSL::PKey::EC::Point` to be used as the verification key in ECDSA [#689](https://github.com/jwt/ruby-jwt/pull/689) ([@anakinj](https://github.com/anakinj))
|
|
44
|
+
- Require claims to have been verified before accessing the `JWT::EncodedToken#payload` [#690](https://github.com/jwt/ruby-jwt/pull/690) ([@anakinj](https://github.com/anakinj))
|
|
45
|
+
- Support signing and verifying tokens using a JWK [#692](https://github.com/jwt/ruby-jwt/pull/692) ([@anakinj](https://github.com/anakinj))
|
|
46
|
+
|
|
47
|
+
## [v3.0.0](https://github.com/jwt/ruby-jwt/tree/v3.0.0) (2025-06-14)
|
|
48
|
+
|
|
49
|
+
[Full Changelog](https://github.com/jwt/ruby-jwt/compare/v2.10.1...v3.0.0)
|
|
50
|
+
|
|
51
|
+
**Breaking changes:**
|
|
52
|
+
|
|
53
|
+
- Require token signature to be verified before accessing payload [#648](https://github.com/jwt/ruby-jwt/pull/648) ([@anakinj](https://github.com/anakinj))
|
|
54
|
+
- Drop support for the HS512256 algorithm [#650](https://github.com/jwt/ruby-jwt/pull/650) ([@anakinj](https://github.com/anakinj))
|
|
55
|
+
- Remove deprecated claim verification methods [#654](https://github.com/jwt/ruby-jwt/pull/654) ([@anakinj](https://github.com/anakinj))
|
|
56
|
+
- Remove dependency to rbnacl [#655](https://github.com/jwt/ruby-jwt/pull/655) ([@anakinj](https://github.com/anakinj))
|
|
57
|
+
- Support only stricter base64 decoding (RFC 4648) [#658](https://github.com/jwt/ruby-jwt/pull/658) ([@anakinj](https://github.com/anakinj))
|
|
58
|
+
- Custom algorithms are required to include `JWT::JWA::SigningAlgorithm` [#660](https://github.com/jwt/ruby-jwt/pull/660) ([@anakinj](https://github.com/anakinj))
|
|
59
|
+
- Require RSA keys to be at least 2048 bits [#661](https://github.com/jwt/ruby-jwt/pull/661) ([@anakinj](https://github.com/anakinj))
|
|
60
|
+
- Base64 encode and decode the k value for HMAC JWKs [#662](https://github.com/jwt/ruby-jwt/pull/662) ([@anakinj](https://github.com/anakinj))
|
|
61
|
+
|
|
62
|
+
Take a look at the [upgrade guide](UPGRADING.md) for more details.
|
|
63
|
+
|
|
64
|
+
**Features:**
|
|
65
|
+
|
|
66
|
+
- JWT::EncodedToken#verify! method that bundles signature and claim validation [#647](https://github.com/jwt/ruby-jwt/pull/647) ([@anakinj](https://github.com/anakinj))
|
|
67
|
+
- Do not override the alg header if already given [#659](https://github.com/jwt/ruby-jwt/pull/659) ([@anakinj](https://github.com/anakinj))
|
|
68
|
+
- Make `JWK::KeyFinder` compatible with `JWT::EncodedToken` [#663](https://github.com/jwt/ruby-jwt/pull/663) ([@anakinj](https://github.com/anakinj))
|
|
69
|
+
|
|
70
|
+
**Fixes and enhancements:**
|
|
71
|
+
|
|
72
|
+
- Ruby 3.4 to CI matrix [#649](https://github.com/jwt/ruby-jwt/pull/649) ([@anakinj](https://github.com/anakinj))
|
|
73
|
+
- Add logger as development dependency [#670](https://github.com/jwt/ruby-jwt/pull/670) ([@hieuk09](https://github.com/hieuk09))
|
|
10
74
|
|
|
11
75
|
## [v2.10.1](https://github.com/jwt/ruby-jwt/tree/v2.10.1) (2024-12-26)
|
|
12
76
|
|
|
@@ -14,7 +78,7 @@
|
|
|
14
78
|
|
|
15
79
|
**Fixes and enhancements:**
|
|
16
80
|
|
|
17
|
-
- Make version constants public again [#646](https://github.com/jwt/ruby-jwt/pull/646) ([@anakinj]
|
|
81
|
+
- Make version constants public again [#646](https://github.com/jwt/ruby-jwt/pull/646) ([@anakinj](https://github.com/anakinj))
|
|
18
82
|
|
|
19
83
|
## [v2.10.0](https://github.com/jwt/ruby-jwt/tree/v2.10.0) (2024-12-25)
|
|
20
84
|
|
|
@@ -25,7 +89,7 @@
|
|
|
25
89
|
- JWT::Token and JWT::EncodedToken for signing and verifying tokens [#621](https://github.com/jwt/ruby-jwt/pull/621) ([@anakinj](https://github.com/anakinj))
|
|
26
90
|
- Detached payload support for JWT::Token and JWT::EncodedToken [#630](https://github.com/jwt/ruby-jwt/pull/630) ([@anakinj](https://github.com/anakinj))
|
|
27
91
|
- Skip decoding payload if b64 header is present and false [#631](https://github.com/jwt/ruby-jwt/pull/631) ([@anakinj](https://github.com/anakinj))
|
|
28
|
-
- Remove a few custom
|
|
92
|
+
- Remove a few custom RuboCop configs [#638](https://github.com/jwt/ruby-jwt/pull/638) ([@anakinj](https://github.com/anakinj))
|
|
29
93
|
|
|
30
94
|
**Fixes and enhancements:**
|
|
31
95
|
|
|
@@ -170,6 +234,7 @@
|
|
|
170
234
|
- Support OpenSSL >= 3.0 [#496](https://github.com/jwt/ruby-jwt/pull/496) ([@anakinj](https://github.com/anakinj))
|
|
171
235
|
|
|
172
236
|
**Fixes and enhancements:**
|
|
237
|
+
|
|
173
238
|
- Bring back the old Base64 (RFC2045) deocode mechanisms [#488](https://github.com/jwt/ruby-jwt/pull/488) ([@anakinj](https://github.com/anakinj))
|
|
174
239
|
- Rescue RbNaCl exception for EdDSA wrong key [#491](https://github.com/jwt/ruby-jwt/pull/491) ([@n-studio](https://github.com/n-studio))
|
|
175
240
|
- New parameter name for cases when kid is not found using JWK key loader proc [#501](https://github.com/jwt/ruby-jwt/pull/501) ([@anakinj](https://github.com/anakinj))
|
|
@@ -180,6 +245,7 @@
|
|
|
180
245
|
[Full Changelog](https://github.com/jwt/ruby-jwt/compare/v2.4.0...v2.4.1)
|
|
181
246
|
|
|
182
247
|
**Fixes and enhancements:**
|
|
248
|
+
|
|
183
249
|
- Raise JWT::DecodeError on invalid signature [\#484](https://github.com/jwt/ruby-jwt/pull/484) ([@freakyfelt!](https://github.com/freakyfelt!))
|
|
184
250
|
|
|
185
251
|
## [v2.4.0](https://github.com/jwt/ruby-jwt/tree/v2.4.0) (2022-06-06)
|
|
@@ -197,11 +263,12 @@
|
|
|
197
263
|
- Add Support to be able to verify from multiple keys [\#425](https://github.com/jwt/ruby-jwt/pull/425) ([ritikesh](https://github.com/ritikesh))
|
|
198
264
|
|
|
199
265
|
**Fixes and enhancements:**
|
|
266
|
+
|
|
200
267
|
- Readme: Typo fix re MissingRequiredClaim [\#451](https://github.com/jwt/ruby-jwt/pull/451) ([antonmorant](https://github.com/antonmorant))
|
|
201
268
|
- Fix RuboCop TODOs [\#476](https://github.com/jwt/ruby-jwt/pull/476) ([typhoon2099](https://github.com/typhoon2099))
|
|
202
269
|
- Make specific algorithms in README linkable [\#472](https://github.com/jwt/ruby-jwt/pull/472) ([milieu](https://github.com/milieu))
|
|
203
270
|
- Update note about supported JWK types [\#475](https://github.com/jwt/ruby-jwt/pull/475) ([dpashkevich](https://github.com/dpashkevich))
|
|
204
|
-
- Create
|
|
271
|
+
- Create CODE_OF_CONDUCT.md [\#449](https://github.com/jwt/ruby-jwt/pull/449) ([loic5](https://github.com/loic5))
|
|
205
272
|
|
|
206
273
|
## [v2.3.0](https://github.com/jwt/ruby-jwt/tree/v2.3.0) (2021-10-03)
|
|
207
274
|
|
|
@@ -222,19 +289,19 @@
|
|
|
222
289
|
- Release 2.3.0 [\#448](https://github.com/jwt/ruby-jwt/pull/448) ([excpt](https://github.com/excpt))
|
|
223
290
|
- Fix Style/MultilineIfModifier issues [\#447](https://github.com/jwt/ruby-jwt/pull/447) ([anakinj](https://github.com/anakinj))
|
|
224
291
|
- feat\(EdDSA\): Accept EdDSA as algorithm header [\#446](https://github.com/jwt/ruby-jwt/pull/446) ([Pierre-Michard](https://github.com/Pierre-Michard))
|
|
225
|
-
- Pass kid param through JWT::JWK.
|
|
292
|
+
- Pass kid param through JWT::JWK.create_from [\#445](https://github.com/jwt/ruby-jwt/pull/445) ([shaun-guth-allscripts](https://github.com/shaun-guth-allscripts))
|
|
226
293
|
- fix document about passing JWKs as a simple Hash [\#443](https://github.com/jwt/ruby-jwt/pull/443) ([takayamaki](https://github.com/takayamaki))
|
|
227
294
|
- Tests for mixing JWK keys with mismatching algorithms [\#441](https://github.com/jwt/ruby-jwt/pull/441) ([anakinj](https://github.com/anakinj))
|
|
228
|
-
-
|
|
295
|
+
- verify_claims test shouldnt be within the verify_sub test [\#431](https://github.com/jwt/ruby-jwt/pull/431) ([andyjdavis](https://github.com/andyjdavis))
|
|
229
296
|
- Allow decode options to specify required claims [\#430](https://github.com/jwt/ruby-jwt/pull/430) ([andyjdavis](https://github.com/andyjdavis))
|
|
230
|
-
- Fix OpenSSL::PKey::EC
|
|
231
|
-
- Add documentation for
|
|
297
|
+
- Fix OpenSSL::PKey::EC public_key handing in tests [\#427](https://github.com/jwt/ruby-jwt/pull/427) ([anakinj](https://github.com/anakinj))
|
|
298
|
+
- Add documentation for find_key [\#426](https://github.com/jwt/ruby-jwt/pull/426) ([ritikesh](https://github.com/ritikesh))
|
|
232
299
|
- Give ruby 3.0 as a string to avoid number formatting issues [\#424](https://github.com/jwt/ruby-jwt/pull/424) ([anakinj](https://github.com/anakinj))
|
|
233
300
|
- Tests for iat verification behaviour [\#423](https://github.com/jwt/ruby-jwt/pull/423) ([anakinj](https://github.com/anakinj))
|
|
234
301
|
- Remove HMAC with nil secret from documentation [\#422](https://github.com/jwt/ruby-jwt/pull/422) ([boardfish](https://github.com/boardfish))
|
|
235
302
|
- Update broken link in README [\#420](https://github.com/jwt/ruby-jwt/pull/420) ([severin](https://github.com/severin))
|
|
236
303
|
- Add metadata for RubyGems [\#418](https://github.com/jwt/ruby-jwt/pull/418) ([nickhammond](https://github.com/nickhammond))
|
|
237
|
-
- Fixed a typo about class name
|
|
304
|
+
- Fixed a typo about class name [\#417](https://github.com/jwt/ruby-jwt/pull/417) ([mai-f](https://github.com/mai-f))
|
|
238
305
|
- Fix references for v2.2.3 on CHANGELOG [\#416](https://github.com/jwt/ruby-jwt/pull/416) ([vyper](https://github.com/vyper))
|
|
239
306
|
- Raise IncorrectAlgorithm if token has no alg header [\#411](https://github.com/jwt/ruby-jwt/pull/411) ([bouk](https://github.com/bouk))
|
|
240
307
|
|
|
@@ -244,9 +311,9 @@
|
|
|
244
311
|
|
|
245
312
|
**Implemented enhancements:**
|
|
246
313
|
|
|
247
|
-
- Verify algorithm before evaluating keyfinder
|
|
314
|
+
- Verify algorithm before evaluating keyfinder [\#343](https://github.com/jwt/ruby-jwt/issues/343)
|
|
248
315
|
- Why jwt depends on json \< 2.0 ? [\#179](https://github.com/jwt/ruby-jwt/issues/179)
|
|
249
|
-
- Support for JWK in-lieu of
|
|
316
|
+
- Support for JWK in-lieu of rsa_public [\#158](https://github.com/jwt/ruby-jwt/issues/158)
|
|
250
317
|
- Fix rspec `raise_error` warning [\#413](https://github.com/jwt/ruby-jwt/pull/413) ([excpt](https://github.com/excpt))
|
|
251
318
|
- Add support for JWKs with HMAC key type. [\#372](https://github.com/jwt/ruby-jwt/pull/372) ([phlegx](https://github.com/phlegx))
|
|
252
319
|
- Improve 'none' algorithm handling [\#365](https://github.com/jwt/ruby-jwt/pull/365) ([danleyden](https://github.com/danleyden))
|
|
@@ -274,7 +341,7 @@
|
|
|
274
341
|
- Add forwardable dependency [\#408](https://github.com/jwt/ruby-jwt/pull/408) ([anakinj](https://github.com/anakinj))
|
|
275
342
|
- Ignore casing of algorithm [\#405](https://github.com/jwt/ruby-jwt/pull/405) ([johnnyshields](https://github.com/johnnyshields))
|
|
276
343
|
- Document function and add tests for verify claims method [\#404](https://github.com/jwt/ruby-jwt/pull/404) ([yasonk](https://github.com/yasonk))
|
|
277
|
-
- documenting calling
|
|
344
|
+
- documenting calling verify_jti callback with 2 arguments in the readme [\#402](https://github.com/jwt/ruby-jwt/pull/402) ([HoneyryderChuck](https://github.com/HoneyryderChuck))
|
|
278
345
|
- Target the master branch on the build status badge [\#399](https://github.com/jwt/ruby-jwt/pull/399) ([anakinj](https://github.com/anakinj))
|
|
279
346
|
- Improving the local development experience [\#397](https://github.com/jwt/ruby-jwt/pull/397) ([anakinj](https://github.com/anakinj))
|
|
280
347
|
- Fix sourcelevel broken links [\#395](https://github.com/jwt/ruby-jwt/pull/395) ([anakinj](https://github.com/anakinj))
|
|
@@ -300,7 +367,7 @@
|
|
|
300
367
|
**Implemented enhancements:**
|
|
301
368
|
|
|
302
369
|
- JWK does not decode. [\#332](https://github.com/jwt/ruby-jwt/issues/332)
|
|
303
|
-
- Inconsistent use of symbol and string keys in args \(exp and
|
|
370
|
+
- Inconsistent use of symbol and string keys in args \(exp and algorithm\). [\#331](https://github.com/jwt/ruby-jwt/issues/331)
|
|
304
371
|
- Pin simplecov to \< 0.18 [\#356](https://github.com/jwt/ruby-jwt/pull/356) ([anakinj](https://github.com/anakinj))
|
|
305
372
|
- verifies algorithm before evaluating keyfinder [\#346](https://github.com/jwt/ruby-jwt/pull/346) ([jb08](https://github.com/jb08))
|
|
306
373
|
- Update Rails 6 appraisal to use actual release version [\#336](https://github.com/jwt/ruby-jwt/pull/336) ([smudge](https://github.com/smudge))
|
|
@@ -322,7 +389,7 @@
|
|
|
322
389
|
- Decode any token [\#360](https://github.com/jwt/ruby-jwt/issues/360)
|
|
323
390
|
- \[question\] example of using a pub/priv keys for signing? [\#351](https://github.com/jwt/ruby-jwt/issues/351)
|
|
324
391
|
- JWT::ExpiredSignature raised for non-JSON payloads [\#350](https://github.com/jwt/ruby-jwt/issues/350)
|
|
325
|
-
-
|
|
392
|
+
- verify_aud only verifies that at least one aud is expected [\#345](https://github.com/jwt/ruby-jwt/issues/345)
|
|
326
393
|
- Sinatra 4.90s TTFB [\#344](https://github.com/jwt/ruby-jwt/issues/344)
|
|
327
394
|
- How to Logout [\#342](https://github.com/jwt/ruby-jwt/issues/342)
|
|
328
395
|
- jwt token decoding even when wrong token is provided for some letters [\#337](https://github.com/jwt/ruby-jwt/issues/337)
|
|
@@ -374,9 +441,9 @@
|
|
|
374
441
|
|
|
375
442
|
**Implemented enhancements:**
|
|
376
443
|
|
|
377
|
-
- Use
|
|
444
|
+
- Use iat_leeway option [\#273](https://github.com/jwt/ruby-jwt/issues/273)
|
|
378
445
|
- Use of global state in latest version breaks thread safety of JWT.decode [\#268](https://github.com/jwt/ruby-jwt/issues/268)
|
|
379
|
-
- JSON support
|
|
446
|
+
- JSON support [\#246](https://github.com/jwt/ruby-jwt/issues/246)
|
|
380
447
|
- Change the Github homepage URL to https [\#301](https://github.com/jwt/ruby-jwt/pull/301) ([ekohl](https://github.com/ekohl))
|
|
381
448
|
- Fix Salt length for conformance with PS family specification. [\#300](https://github.com/jwt/ruby-jwt/pull/300) ([tobypinder](https://github.com/tobypinder))
|
|
382
449
|
- Add support for Ruby 2.6 [\#299](https://github.com/jwt/ruby-jwt/pull/299) ([bustikiller](https://github.com/bustikiller))
|
|
@@ -389,7 +456,7 @@
|
|
|
389
456
|
- Add note about using a hard coded algorithm in README [\#280](https://github.com/jwt/ruby-jwt/pull/280) ([revodoge](https://github.com/revodoge))
|
|
390
457
|
- Add Appraisal support [\#278](https://github.com/jwt/ruby-jwt/pull/278) ([olbrich](https://github.com/olbrich))
|
|
391
458
|
- Fix decode threading issue [\#269](https://github.com/jwt/ruby-jwt/pull/269) ([ab320012](https://github.com/ab320012))
|
|
392
|
-
- Removed leeway from
|
|
459
|
+
- Removed leeway from verify_iat [\#257](https://github.com/jwt/ruby-jwt/pull/257) ([ab320012](https://github.com/ab320012))
|
|
393
460
|
|
|
394
461
|
**Fixed bugs:**
|
|
395
462
|
|
|
@@ -415,11 +482,11 @@
|
|
|
415
482
|
- 'DecodeError'will replace 'ExpiredSignature' [\#260](https://github.com/jwt/ruby-jwt/issues/260)
|
|
416
483
|
- TypeError: no implicit conversion of OpenSSL::PKey::RSA into String [\#259](https://github.com/jwt/ruby-jwt/issues/259)
|
|
417
484
|
- NameError: uninitialized constant JWT::Algos::Eddsa::RbNaCl [\#258](https://github.com/jwt/ruby-jwt/issues/258)
|
|
418
|
-
- Get new token if
|
|
485
|
+
- Get new token if current token expired [\#256](https://github.com/jwt/ruby-jwt/issues/256)
|
|
419
486
|
- Infer algorithm from header [\#254](https://github.com/jwt/ruby-jwt/issues/254)
|
|
420
487
|
- Why is the result of decode is an array? [\#252](https://github.com/jwt/ruby-jwt/issues/252)
|
|
421
488
|
- Add support for headless token [\#251](https://github.com/jwt/ruby-jwt/issues/251)
|
|
422
|
-
- Leeway or
|
|
489
|
+
- Leeway or exp_leeway [\#215](https://github.com/jwt/ruby-jwt/issues/215)
|
|
423
490
|
- Could you describe purpose of cert fixtures and their cryptokey lengths. [\#185](https://github.com/jwt/ruby-jwt/issues/185)
|
|
424
491
|
|
|
425
492
|
**Merged pull requests:**
|
|
@@ -430,7 +497,7 @@
|
|
|
430
497
|
- Drop Ruby 2.2 from test matrix [\#290](https://github.com/jwt/ruby-jwt/pull/290) ([anakinj](https://github.com/anakinj))
|
|
431
498
|
- Remove broken reek config [\#283](https://github.com/jwt/ruby-jwt/pull/283) ([excpt](https://github.com/excpt))
|
|
432
499
|
- Add missing test, Update common files [\#275](https://github.com/jwt/ruby-jwt/pull/275) ([excpt](https://github.com/excpt))
|
|
433
|
-
- Remove
|
|
500
|
+
- Remove iat_leeway option [\#274](https://github.com/jwt/ruby-jwt/pull/274) ([wohlgejm](https://github.com/wohlgejm))
|
|
434
501
|
- improving code quality of jwt module [\#266](https://github.com/jwt/ruby-jwt/pull/266) ([ab320012](https://github.com/ab320012))
|
|
435
502
|
- fixed ECDSA supported versions const [\#263](https://github.com/jwt/ruby-jwt/pull/263) ([starbeast](https://github.com/starbeast))
|
|
436
503
|
- Added my name to contributor list [\#262](https://github.com/jwt/ruby-jwt/pull/262) ([ab320012](https://github.com/ab320012))
|
|
@@ -520,14 +587,14 @@
|
|
|
520
587
|
- Move signature logic to its own module [\#195](https://github.com/jwt/ruby-jwt/pull/195) ([EmilioCristalli](https://github.com/EmilioCristalli))
|
|
521
588
|
- Add options for claim-specific leeway [\#187](https://github.com/jwt/ruby-jwt/pull/187) ([EmilioCristalli](https://github.com/EmilioCristalli))
|
|
522
589
|
- Add user friendly encode error if private key is a String, \#171 [\#176](https://github.com/jwt/ruby-jwt/pull/176) ([ogonki-vetochki](https://github.com/ogonki-vetochki))
|
|
523
|
-
- Return empty string if signature less than
|
|
590
|
+
- Return empty string if signature less than byte_size \#155 [\#175](https://github.com/jwt/ruby-jwt/pull/175) ([ogonki-vetochki](https://github.com/ogonki-vetochki))
|
|
524
591
|
- Remove 'typ' optional parameter [\#174](https://github.com/jwt/ruby-jwt/pull/174) ([ogonki-vetochki](https://github.com/ogonki-vetochki))
|
|
525
592
|
- Pass payload to keyfinder [\#172](https://github.com/jwt/ruby-jwt/pull/172) ([CodeMonkeySteve](https://github.com/CodeMonkeySteve))
|
|
526
593
|
- Use RbNaCl for HMAC if available with fallback to OpenSSL [\#149](https://github.com/jwt/ruby-jwt/pull/149) ([mwpastore](https://github.com/mwpastore))
|
|
527
594
|
|
|
528
595
|
**Fixed bugs:**
|
|
529
596
|
|
|
530
|
-
- ruby-jwt::
|
|
597
|
+
- ruby-jwt::raw_to_asn1: Fails for signatures less than byte_size [\#155](https://github.com/jwt/ruby-jwt/issues/155)
|
|
531
598
|
- The leeway parameter is applies to all time based verifications [\#129](https://github.com/jwt/ruby-jwt/issues/129)
|
|
532
599
|
- Make algorithm option required to verify signature [\#184](https://github.com/jwt/ruby-jwt/pull/184) ([EmilioCristalli](https://github.com/EmilioCristalli))
|
|
533
600
|
- Validate audience when payload is a scalar and options is an array [\#183](https://github.com/jwt/ruby-jwt/pull/183) ([steti](https://github.com/steti))
|
|
@@ -539,7 +606,7 @@
|
|
|
539
606
|
- Include custom headers with password [\#189](https://github.com/jwt/ruby-jwt/issues/189)
|
|
540
607
|
- can't create token - 'NotImplementedError: Unsupported signing method' [\#186](https://github.com/jwt/ruby-jwt/issues/186)
|
|
541
608
|
- Cannot verify JWT at all?? [\#177](https://github.com/jwt/ruby-jwt/issues/177)
|
|
542
|
-
-
|
|
609
|
+
- verify_iss: true is raising JWT::DecodeError instead of JWT::InvalidIssuerError [\#170](https://github.com/jwt/ruby-jwt/issues/170)
|
|
543
610
|
|
|
544
611
|
**Merged pull requests:**
|
|
545
612
|
|
|
@@ -610,7 +677,7 @@
|
|
|
610
677
|
- Added test execution to Rakefile [\#147](https://github.com/jwt/ruby-jwt/pull/147) ([jabbrwcky](https://github.com/jabbrwcky))
|
|
611
678
|
- Bump version [\#145](https://github.com/jwt/ruby-jwt/pull/145) ([excpt](https://github.com/excpt))
|
|
612
679
|
- Add a changelog file [\#142](https://github.com/jwt/ruby-jwt/pull/142) ([excpt](https://github.com/excpt))
|
|
613
|
-
- Return
|
|
680
|
+
- Return decoded_segments [\#139](https://github.com/jwt/ruby-jwt/pull/139) ([akostrikov](https://github.com/akostrikov))
|
|
614
681
|
|
|
615
682
|
## [v1.5.4](https://github.com/jwt/ruby-jwt/tree/v1.5.4) (2016-03-24)
|
|
616
683
|
|
|
@@ -618,12 +685,12 @@
|
|
|
618
685
|
|
|
619
686
|
**Closed issues:**
|
|
620
687
|
|
|
621
|
-
- 404 at https://rubygems.global.ssl.fastly.net/gems/jwt-1.5.3.gem [\#137](https://github.com/jwt/ruby-jwt/issues/137)
|
|
688
|
+
- 404 at [https://rubygems.global.ssl.fastly.net/gems/jwt-1.5.3.gem](https://rubygems.global.ssl.fastly.net/gems/jwt-1.5.3.gem) [\#137](https://github.com/jwt/ruby-jwt/issues/137)
|
|
622
689
|
|
|
623
690
|
**Merged pull requests:**
|
|
624
691
|
|
|
625
692
|
- Update README.md [\#138](https://github.com/jwt/ruby-jwt/pull/138) ([excpt](https://github.com/excpt))
|
|
626
|
-
- Fix
|
|
693
|
+
- Fix base64url_decode [\#136](https://github.com/jwt/ruby-jwt/pull/136) ([excpt](https://github.com/excpt))
|
|
627
694
|
- Fix ruby 1.9.3 compatibility [\#135](https://github.com/jwt/ruby-jwt/pull/135) ([excpt](https://github.com/excpt))
|
|
628
695
|
- iat can be a float value [\#134](https://github.com/jwt/ruby-jwt/pull/134) ([llimllib](https://github.com/llimllib))
|
|
629
696
|
|
|
@@ -634,8 +701,8 @@
|
|
|
634
701
|
**Implemented enhancements:**
|
|
635
702
|
|
|
636
703
|
- Refactor obsolete code for ruby 1.8 support [\#120](https://github.com/jwt/ruby-jwt/issues/120)
|
|
637
|
-
- Fix "
|
|
638
|
-
- Fix "
|
|
704
|
+
- Fix "RuboCop/Metrics/CyclomaticComplexity" issue in lib/jwt.rb [\#106](https://github.com/jwt/ruby-jwt/issues/106)
|
|
705
|
+
- Fix "RuboCop/Metrics/CyclomaticComplexity" issue in lib/jwt.rb [\#105](https://github.com/jwt/ruby-jwt/issues/105)
|
|
639
706
|
- Allow a proc to be passed for JTI verification [\#126](https://github.com/jwt/ruby-jwt/pull/126) ([yahooguntu](https://github.com/yahooguntu))
|
|
640
707
|
- Relax restrictions on "jti" claim verification [\#113](https://github.com/jwt/ruby-jwt/pull/113) ([lwe](https://github.com/lwe))
|
|
641
708
|
|
|
@@ -644,7 +711,7 @@
|
|
|
644
711
|
- Verifications not functioning in latest release [\#128](https://github.com/jwt/ruby-jwt/issues/128)
|
|
645
712
|
- Base64 is generating invalid length base64 strings - cross language interop [\#127](https://github.com/jwt/ruby-jwt/issues/127)
|
|
646
713
|
- Digest::Digest is deprecated; use Digest [\#119](https://github.com/jwt/ruby-jwt/issues/119)
|
|
647
|
-
-
|
|
714
|
+
- verify_rsa no method 'verify' for class String [\#115](https://github.com/jwt/ruby-jwt/issues/115)
|
|
648
715
|
- Add a changelog [\#111](https://github.com/jwt/ruby-jwt/issues/111)
|
|
649
716
|
|
|
650
717
|
**Merged pull requests:**
|
|
@@ -762,14 +829,14 @@
|
|
|
762
829
|
|
|
763
830
|
**Closed issues:**
|
|
764
831
|
|
|
765
|
-
- The behavior using 'json' differs from '
|
|
832
|
+
- The behavior using 'json' differs from 'multi_json' [\#41](https://github.com/jwt/ruby-jwt/issues/41)
|
|
766
833
|
|
|
767
834
|
**Merged pull requests:**
|
|
768
835
|
|
|
769
836
|
- Release 1.4.0 [\#64](https://github.com/jwt/ruby-jwt/pull/64) ([excpt](https://github.com/excpt))
|
|
770
837
|
- Update README.md and remove dead code [\#63](https://github.com/jwt/ruby-jwt/pull/63) ([excpt](https://github.com/excpt))
|
|
771
|
-
- Add
|
|
772
|
-
- Add
|
|
838
|
+
- Add 'iat/ aud/ sub/ jti' support for ruby-jwt [\#62](https://github.com/jwt/ruby-jwt/pull/62) ([ZhangHanDong](https://github.com/ZhangHanDong))
|
|
839
|
+
- Add 'iss' support for ruby-jwt [\#61](https://github.com/jwt/ruby-jwt/pull/61) ([ZhangHanDong](https://github.com/ZhangHanDong))
|
|
773
840
|
- Clarify .encode API in README [\#60](https://github.com/jwt/ruby-jwt/pull/60) ([jbodah](https://github.com/jbodah))
|
|
774
841
|
|
|
775
842
|
## [jwt-1.3.0](https://github.com/jwt/ruby-jwt/tree/jwt-1.3.0) (2015-02-24)
|
|
@@ -781,13 +848,13 @@
|
|
|
781
848
|
- Signature Verification to Return Verification Error rather than decode error [\#57](https://github.com/jwt/ruby-jwt/issues/57)
|
|
782
849
|
- Incorrect readme for leeway [\#55](https://github.com/jwt/ruby-jwt/issues/55)
|
|
783
850
|
- What is the reason behind stripping the = in base64 encoding? [\#54](https://github.com/jwt/ruby-jwt/issues/54)
|
|
784
|
-
-
|
|
851
|
+
- Preparations for version 2.x [\#50](https://github.com/jwt/ruby-jwt/issues/50)
|
|
785
852
|
- Release a new version [\#47](https://github.com/jwt/ruby-jwt/issues/47)
|
|
786
853
|
- Catch up for ActiveWhatever 4.1.1 series [\#40](https://github.com/jwt/ruby-jwt/issues/40)
|
|
787
854
|
|
|
788
855
|
**Merged pull requests:**
|
|
789
856
|
|
|
790
|
-
- raise verification error for
|
|
857
|
+
- raise verification error for signature verification [\#58](https://github.com/jwt/ruby-jwt/pull/58) ([punkle](https://github.com/punkle))
|
|
791
858
|
- Added support for not before claim verification [\#56](https://github.com/jwt/ruby-jwt/pull/56) ([punkle](https://github.com/punkle))
|
|
792
859
|
|
|
793
860
|
## [jwt-1.2.1](https://github.com/jwt/ruby-jwt/tree/jwt-1.2.1) (2015-01-22)
|
|
@@ -832,7 +899,7 @@
|
|
|
832
899
|
|
|
833
900
|
**Closed issues:**
|
|
834
901
|
|
|
835
|
-
- API request - JWT::
|
|
902
|
+
- API request - JWT::decoded_header\(\) [\#26](https://github.com/jwt/ruby-jwt/issues/26)
|
|
836
903
|
|
|
837
904
|
**Merged pull requests:**
|
|
838
905
|
|
|
@@ -935,9 +1002,5 @@
|
|
|
935
1002
|
|
|
936
1003
|
**Merged pull requests:**
|
|
937
1004
|
|
|
938
|
-
- Bumped a version and added a .gemspec using rake
|
|
1005
|
+
- Bumped a version and added a .gemspec using rake build_gemspec [\#3](https://github.com/jwt/ruby-jwt/pull/3) ([zhitomirskiyi](https://github.com/zhitomirskiyi))
|
|
939
1006
|
- Added RSA support [\#2](https://github.com/jwt/ruby-jwt/pull/2) ([zhitomirskiyi](https://github.com/zhitomirskiyi))
|
|
940
|
-
|
|
941
|
-
|
|
942
|
-
|
|
943
|
-
\* *This Changelog was automatically generated by [github_changelog_generator](https://github.com/github-changelog-generator/github-changelog-generator)*
|
data/CODE_OF_CONDUCT.md
CHANGED
|
@@ -10,21 +10,21 @@ We pledge to act and interact in ways that contribute to an open, welcoming, div
|
|
|
10
10
|
|
|
11
11
|
Examples of behavior that contributes to a positive environment for our community include:
|
|
12
12
|
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
13
|
+
- Demonstrating empathy and kindness toward other people
|
|
14
|
+
- Being respectful of differing opinions, viewpoints, and experiences
|
|
15
|
+
- Giving and gracefully accepting constructive feedback
|
|
16
|
+
- Accepting responsibility and apologizing to those affected by our mistakes, and learning from the experience
|
|
17
|
+
- Focusing on what is best not just for us as individuals, but for the overall community
|
|
18
18
|
|
|
19
19
|
Examples of unacceptable behavior include:
|
|
20
20
|
|
|
21
|
-
|
|
21
|
+
- The use of sexualized language or imagery, and sexual attention or
|
|
22
22
|
advances of any kind
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
23
|
+
- Trolling, insulting or derogatory comments, and personal or political attacks
|
|
24
|
+
- Public or private harassment
|
|
25
|
+
- Publishing others' private information, such as a physical or email
|
|
26
26
|
address, without their explicit permission
|
|
27
|
-
|
|
27
|
+
- Other conduct which could reasonably be considered inappropriate in a
|
|
28
28
|
professional setting
|
|
29
29
|
|
|
30
30
|
## Enforcement Responsibilities
|
|
@@ -39,7 +39,7 @@ This Code of Conduct applies within all community spaces, and also applies when
|
|
|
39
39
|
|
|
40
40
|
## Enforcement
|
|
41
41
|
|
|
42
|
-
Instances of abusive, harassing, or otherwise unacceptable behavior may be reported to the community leaders responsible for enforcement at antmanj@gmail.com
|
|
42
|
+
Instances of abusive, harassing, or otherwise unacceptable behavior may be reported to the community leaders responsible for enforcement at <antmanj@gmail.com>. All complaints will be reviewed and investigated promptly and fairly.
|
|
43
43
|
|
|
44
44
|
All community leaders are obligated to respect the privacy and security of the reporter of any incident.
|
|
45
45
|
|
|
@@ -67,18 +67,18 @@ Community leaders will follow these Community Impact Guidelines in determining t
|
|
|
67
67
|
|
|
68
68
|
### 4. Permanent Ban
|
|
69
69
|
|
|
70
|
-
**Community Impact**: Demonstrating a pattern of violation of community standards, including sustained inappropriate behavior,
|
|
70
|
+
**Community Impact**: Demonstrating a pattern of violation of community standards, including sustained inappropriate behavior, harassment of an individual, or aggression toward or disparagement of classes of individuals.
|
|
71
71
|
|
|
72
72
|
**Consequence**: A permanent ban from any sort of public interaction within the community.
|
|
73
73
|
|
|
74
74
|
## Attribution
|
|
75
75
|
|
|
76
76
|
This Code of Conduct is adapted from the [Contributor Covenant][homepage], version 2.0,
|
|
77
|
-
available at https://www.contributor-covenant.org/version/2/0/code_of_conduct.html.
|
|
77
|
+
available at [https://www.contributor-covenant.org/version/2/0/code_of_conduct.html](https://www.contributor-covenant.org/version/2/0/code_of_conduct.html).
|
|
78
78
|
|
|
79
79
|
Community Impact Guidelines were inspired by [Mozilla's code of conduct enforcement ladder](https://github.com/mozilla/diversity).
|
|
80
80
|
|
|
81
81
|
[homepage]: https://www.contributor-covenant.org
|
|
82
82
|
|
|
83
83
|
For answers to common questions about this code of conduct, see the FAQ at
|
|
84
|
-
https://www.contributor-covenant.org/faq. Translations are available at https://www.contributor-covenant.org/translations.
|
|
84
|
+
[https://www.contributor-covenant.org/faq](https://www.contributor-covenant.org/faq). Translations are available at [https://www.contributor-covenant.org/translations](https://www.contributor-covenant.org/translations).
|
data/CONTRIBUTING.md
CHANGED
|
@@ -2,9 +2,9 @@
|
|
|
2
2
|
|
|
3
3
|
## Forking the project
|
|
4
4
|
|
|
5
|
-
Fork the project on GitHub and clone your own fork.
|
|
5
|
+
Fork the project on GitHub and clone your own fork. Instructions on forking can be found from the [GitHub Docs](https://docs.github.com/en/get-started/quickstart/fork-a-repo)
|
|
6
6
|
|
|
7
|
-
```
|
|
7
|
+
```bash
|
|
8
8
|
git clone git@github.com:you/ruby-jwt.git
|
|
9
9
|
cd ruby-jwt
|
|
10
10
|
git remote add upstream https://github.com/jwt/ruby-jwt
|
|
@@ -14,7 +14,7 @@ git remote add upstream https://github.com/jwt/ruby-jwt
|
|
|
14
14
|
|
|
15
15
|
Make sure you have the latest upstream main branch of the project.
|
|
16
16
|
|
|
17
|
-
```
|
|
17
|
+
```bash
|
|
18
18
|
git fetch --all
|
|
19
19
|
git checkout main
|
|
20
20
|
git rebase upstream/main
|
|
@@ -28,7 +28,7 @@ Before you start with your implementation make sure you are able to get a succes
|
|
|
28
28
|
|
|
29
29
|
The tests are written with rspec and [Appraisal](https://github.com/thoughtbot/appraisal) is used to ensure compatibility with 3rd party dependencies providing cryptographic features.
|
|
30
30
|
|
|
31
|
-
[
|
|
31
|
+
[RuboCop](https://github.com/rubocop/rubocop) is used to enforce the Ruby style.
|
|
32
32
|
|
|
33
33
|
To run the complete set of tests and linter run the following
|
|
34
34
|
|
|
@@ -44,7 +44,8 @@ Implement tests and your change. Don't be shy adding a little something in the [
|
|
|
44
44
|
Add a short description of the change in either the `Features` or `Fixes` section in the [CHANGELOG](CHANGELOG.md) file.
|
|
45
45
|
|
|
46
46
|
The form of the row (You need to return to the row when you know the pull request id)
|
|
47
|
-
|
|
47
|
+
|
|
48
|
+
```markdown
|
|
48
49
|
- Fix a little problem [#123](https://github.com/jwt/ruby-jwt/pull/123) - [@you](https://github.com/you).
|
|
49
50
|
```
|
|
50
51
|
|
|
@@ -52,7 +53,7 @@ The form of the row (You need to return to the row when you know the pull reques
|
|
|
52
53
|
|
|
53
54
|
Before pushing make sure the tests pass and RuboCop is happy.
|
|
54
55
|
|
|
55
|
-
```
|
|
56
|
+
```bash
|
|
56
57
|
bundle exec appraisal rake test
|
|
57
58
|
bundle exec rubocop
|
|
58
59
|
git push origin fix-a-little-problem
|
|
@@ -64,9 +65,9 @@ Make a new pull request on the [ruby-jwt project](https://github.com/jwt/ruby-jw
|
|
|
64
65
|
|
|
65
66
|
Update the [CHANGELOG](CHANGELOG.md) with the pull request id from the previous step.
|
|
66
67
|
|
|
67
|
-
You can
|
|
68
|
+
You can amend the previous commit with the updated changelog change and force push your branch. The PR will get automatically updated.
|
|
68
69
|
|
|
69
|
-
```
|
|
70
|
+
```bash
|
|
70
71
|
git add CHANGELOG.md
|
|
71
72
|
git commit --amend --no-edit
|
|
72
73
|
git push origin fix-a-little-problem -f
|
|
@@ -80,14 +81,14 @@ A maintainer will review and probably merge you changes when time allows, be pat
|
|
|
80
81
|
|
|
81
82
|
It's recommended that you keep your branch up-to-date by rebasing to the upstream main.
|
|
82
83
|
|
|
83
|
-
```
|
|
84
|
+
```bash
|
|
84
85
|
git fetch upstream
|
|
85
86
|
git checkout fix-a-little-problem
|
|
86
87
|
git rebase upstream/main
|
|
87
88
|
git push origin fix-a-little-problem -f
|
|
88
89
|
```
|
|
89
90
|
|
|
90
|
-
|
|
91
|
+
## Releasing a new version
|
|
91
92
|
|
|
92
93
|
The version is using the [Semantic Versioning](http://semver.org/) and the version is located in the [version.rb](lib/jwt/version.rb) file.
|
|
93
94
|
Also update the [CHANGELOG](CHANGELOG.md) to reflect the upcoming version release.
|
|
@@ -95,5 +96,3 @@ Also update the [CHANGELOG](CHANGELOG.md) to reflect the upcoming version releas
|
|
|
95
96
|
```bash
|
|
96
97
|
rake release
|
|
97
98
|
```
|
|
98
|
-
|
|
99
|
-
**If you want a release cut with your PR, please include a version bump according to **
|