Skip to content

Releases: vapor/jwt-kit

4.13.3 - Fix RSA memory leak

15 Apr 08:17
ee06dd4
Compare
Choose a tag to compare

What's Changed

Deinitialise correct pointer by @ptoffy in #158

This aims to fix the memory leak reported in #157

This patch was released by @ptoffy

Full Changelog: 4.13.2...4.13.3

5.0.0 Beta 2

15 Mar 21:57
295a5e5
Compare
Choose a tag to compare
5.0.0 Beta 2 Pre-release
Pre-release

What's Changed

Full Changelog: 5.0.0-beta.1...5.0.0-beta.2

5.0.0 Beta 1

21 Feb 18:16
12391f9
Compare
Choose a tag to compare
5.0.0 Beta 1 Pre-release
Pre-release

First beta release of major version 5.

For all changes check out #107

4.13.2 - Update BoringSSL

21 Feb 12:11
e05513b
Compare
Choose a tag to compare

What's Changed

Update BoringSSL by @0xTim in #134

Updates BoringSSL to revision 58a318edc892a595a5b043359a5d441869158699

This is the final non-security release of JWTKit v4

This patch was released by @ptoffy

Full Changelog: 4.13.1...4.13.2

4.13.1 - Increase permitted range for crypto-kit dependency

04 Oct 09:34
cd0fe3a
Compare
Choose a tag to compare

What's Changed

Increase permitted range for crypto-kit dependency by @AndyHeardApps in #98

Currently the crypto-kit package has a permitted version range of 2.0.0 ..< 3.0.0. With the release of crypto-kit 3.0.0, this range is preventing Vapor apps from making use of the latest versions. Increasing the range to 2.0.0 ..< 4.0.0 allows apps to use the latest release without forcing an update.

This patch was released by @0xTim

Full Changelog: 4.13.0...4.13.1

4.13.0 - Add customizable JSON encoders and decoders

18 Jul 00:46
9e929d9
Compare
Choose a tag to compare

Add new, fully source-compatible APIs to JWTSigners and JWTSigner which allow specifying custom JSON encoders and decoders. Also provides the JWTJSONEncoder and JWTJSONDecoder protocols, which allow using alternative JSON implementations.

Custom coders specified for a single JWTSigner affect token parsing and signing performed only by that signer. Custom coders specified on a JWTSigners object will become the default coders for all signers added to that object, unless a given signer already specifies its own custom coders.

The default encoding and decoding implementation provided for JWTUnixEpochClaim (of which ExpirationClaim (exp), IssuedAtClaim (iat), and NotBeforeClaim (nbf) are examples) has been adjusted to encode and decode its Date value directly, rather than performing the explicit conversion to and from a Double. This allows these claims to take advantage of the dateEncodingStrategy and dateDecodingStrategy specified on custom JSON coders. (It also gives a bit of the lie to the name JWTUnixEpochClaim, but it's public API, so I left it alone.)

The default coders in use remain the same: An encoder and decoder which use the .secondsSince1970 date encoding/decoding strategy. As such, neither the new support nor the change to Date-based claims affects how tokens are signed or verified unless custom coders with different strategies are specified (that being, after all, the original need which inspired these changes).

Finally, an .integerSecondsSince1970 date encoding and decoding strategy has been added to the public API for the benefit of interoperation with JWT implementations - such as that used by GitHub - which require the aforementioned date-based claims to specify values as an integer number of seconds. (As GitHub proves, while this is in violation of the definition of NumericDate given by RFC 7519 § 2, which explicitly permits floating-point values, it nonetheless appears in the wild.)

This is a semver-minor release, as it adds new public API (although it has been careful to fully retain source compatibility, at the cost of a goodly amount of silly-looking repetition in the implementation - please, do not ask me if I know what default parameter values are! 😂).

AppleIdentityToken: Adds `real_user_status` claim

05 Jul 14:15
dd3fe31
Compare
Choose a tag to compare
This patch was authored by @qalandarov and released by @0xTim.

Adds the missing real_user_status claim which helps detecting if the user is likely a real person. Closes #88

Improve JWKS `find(identifier:type:)`

05 Jul 13:12
78b292d
Compare
Choose a tag to compare
This patch was authored by @nnsnodnb and released by @0xTim.

Update JWKS find(identifier:type:) to use better Swift algorithms for matching

Add optional org_id field to AppleIdentityToken

15 Jun 18:28
8b3a69c
Compare
Choose a tag to compare
This patch was authored by @RanLearns and released by @gwynne.

Motivation and Reasoning

When working with Managed Apple IDs (schools and business) there can be a need to decode an additional field of a user's org_id when they sign in.

Update the vendored BoringSSL

02 Jun 18:14
268cdf5
Compare
Choose a tag to compare
This patch was authored and released by @gwynne.

Update the vendored BoringSSL to the latest. This also brings in the latest updates to the vendoring scripts themselves from upstream, updates CI (what? In a PR from Gwynne? Say it ain't so!), and bumps the minimum Swift version to 5.6 to be in line with Vapor.