All notable changes to this project will be documented in this file.
The format is based on Keep a Changelog.
1.0.4 2025.01.17
- Added support for multiple OpenID Connect Identity Providers.
- Updated dependencies.
1.0.3 2024.06.19
- Added additional debugging details for unknown connection errors.
1.0.2 2024.03.21
- Fixed the spec for the
aud
claim, to reject bad values.
1.0.1 2024.01.10
- Some types of token corruption/manipulation throwed
java.lang.Error
derived exceptions, that the library didn't catch (it only catched java.lang.Exception
derived ones). Now the library catches java.lang.Throwable
to cover all the bases.
1.0.0 2023.12.08
- Added new configuration setting,
:well-known-url
. It can be used, instead of the :jwks-uri
configuration setting, to specify where to get the JWKS token signing keys from. It should contain the URL of the OpenID Provider's Configuration Document (also known as the "well-known openid-configuration").
- Made
test-validate-token*
unit test be strict about not accepting symmetric encryption keys. Previously we didn't include the symmetric key in the set of keys to use for validation. Hence any token signed with the symmetric key was considered invalid. - Fixed all clj-kondo warnings (especially by adding docstrings to vars that we expect to be public, and making the rest private).
- Upgraded clj-kondo version.
- Tweaked the clj-kondo configuration to deal with the newer
unresolved-var
linter. - Let git ignore all third party libraries clj-kondo configuration files.
- Added JVM options to let AWS SDK call some JAVA 9+ internal methods (development only).
- Remove unused vars in the test namespace.
- Upgraded depedency versions.
- Moved all implemenation functions that are not part of the public API to the
impl
namespace. We keep those functions public to be able to test them from the tests namespace. But they are not considered part of the public API of the library, and should not be used by external parties (as they may change without notice, and without maintaining backwards compatibility).
0.10.6 - 2023-02-19
- Internal implementation details. Merged validate-single-key into validate-token* and changed the way the pubkeys from JWKS are stored in the cache. It avoids looping over pubkeys that, while valid, will not unsign the token (because it has been signed by another valid key from the same key set). And logging their corresponding failures.
0.10.5 - 2023-02-13
- Making
create-token
and now-in-secs
test functions public - Split args in
create-token
test function to separate claims and key signing details - Bumped dependencies
0.10.4 - 2022-05-25
- Moving the repository to gethop-dev organization
- CI/CD solution switch from TravisCI to GitHub Actions
lein
, cljfmt
and eastwood
dependencies bump- More
clj-kondo
linters config - update this changelog's releases tags links
0.10.3 - 2021-05-07
- Use our own forked versin of per item TTL cache. It fixes a nasty bug that was making evicted entries look like they were alive in the cache, but returning a nil value when looked up.
0.10.2 - 2021-03-31
- More debugging information, for other corner cases.
0.10.1 - 2021-03-30
- Lots of additional debugging information to be able to diagnose corner cases.
0.10.0 - 2020-10-29
- [BREAKING CHANGE] Upgraded http-kit dependency to 2.5.0. This change bumps the minimum JVM version from 1.6 to 1.7!
0.9.0 - 2020-08-24
- Upgraded http-kit dependency to 2.4.0. This fixes issue #1.
0.8.6 - 2020-07-01
- Explicitly prevent verifying tokens with the 'none' algorithm (instead of relying on the behaviour of the underlying JWT library).
0.8.5 - 2020-03-19
- Emergency fix for last minute non-tested change that breaks the build.
0.8.4 - 2020-03-19
- You can now provide two additional configuration keys for JWKS retrieval connection policy.
:jwks-retrieval-timeout
specifies the connection timeout (in milli-seconds) and :jwks-retrieval-retries
specifies the number of additional retries in case of connection failure.
0.8.3 - 2020-03-02
- Bumped Amazonica dependency version (devel profile only)
- Removed CIDER dependency (devel profile only)
- Bumped mininum Leiningen version to 2.9.0.
- Reorganized dev profile definition to allow to override some settings via profiles.clj file inside project's directory.
- Increased timeout to 500s with 3 max retries (from 250ms with 5 max retries)
- Made a couple of caching related unit test more thorough, to make sure we do the right thing.
0.7.0 - 2019-09-06
- 'aud' claim can now be either a single string value or a collection of them. The aud claim of the token is checked against all of them.
0.6.0 - 2019-06-18
- Fixed installation instructions in README.md
- This CHANGELOG
- Implemented JWKS keys retrieval retries with diehard
- You can now provide a configuration key that implements the
duct.logger/Logger
protocol and the the library will log any relevant issues that may prevent tokens from being validated (e.g., inability to get the JWKS URL, getting invalid keys in the JWKS body, etc.)
0.5.0 - 2019-02-21
- Added composed cache to set token storage limit. This was previously disabled (even if it was documented as working in the README), as composition with
ttlcache
didn't seem to work. - Bumped CIDER version dependency (devel profile only)
0.4.0 - 2019-01-29
- Updated Clojure version to 1.10.0
- Added deploy config
0.3.0 - 2019-01-28
- Initial commit (previous versions were not publicly released)
Can you improve this documentation? These fine people already did:
Iñaki Arenaza, szymonPietras, spietras, usasigain, Bingen Galartza Iparragirre & Kamil HryniewiczEdit on GitHub