Changelog#

JCL 1.3.1#

Released: 2025-01-14

Updates#

  • The latest version of the Inrupt Access Grants JSON-LD context (namely v2) is now sent when calling the legacy AccessGrantClient::query(AccessCredentialQuery<T>) and AccessGrantClient::query(URI, URI, …), ensuring that all Access Credentials (both using the v1 and the v2 context) are returned.

Dependency updates#

  • Apache Commons Text 1.13.0

  • Guava 33.4.0

  • Quarkus 3.17.5

  • Spring Security 6.4.2

  • Okio 3.10.2

JCL 1.3#

Released: 2024-12-13

Additions#

  • Introduce the Access Credential filter API for querying for Access Grants and Access Requests via AccessGrantClient::query(CredentialFilter<T>). This allows developers to perform more sophisticated queries on the ESS Access Grant service. The response from this method is a paged response that can be navigated forwards and backwards.

  • Connect Access Grants to their corresponding Access Request via the AccessGrantClient::grantAccess(AccessRequest) method.

Deprecations#

  • With the introduction of the AccessGrantClient::query(CredentialFilter<T>) method, the existing ::query(AccessCredentialQuery<T>) and ::query(URI, URI, ...) methods have been deprecated. Developers are advised to migrate to use the new formulation.

Dependency updates#

  • Apache Jena 5.2.0

  • Apache Commons IO 2.18.0

  • Guava 33.3.1

  • Jackson 2.18.2

  • Quarkus 3.17.3

  • Spring Security 6.4.1

JCL 1.2#

Released: 2024-09-20

Additions#

  • Support for RFC 9457: Problem Details in HTTP responses is now available. In the high-level SolidClient, any HTTP errors that throw exceptions now give developers access to problem detail data from an RFC 9457-conforming server. This change introduces the SolidClientException::getProblemDetails method along with a com.inrupt.client.ProblemDetails interface.

  • The OpenIdProvider::authorize method now supports scope, state and nonce values.

  • Support for qualified type names has been added to the Access Grant client so that names with the vc: prefix are now supported across the various Access Grant types. This is an addition to the current support of localname (e.g. SolidAccessGrant, SolidAccessRequest, SolidAccessDenial) and fully qualified names (e.g. http://www.w3.org/ns/solid/vc#SolidAccessGrant).

  • The OpenIdProvider class includes better support for RFC 9207 OAuth 2.0 Authorization Server Issuer Identification during the authorization_code flow in a browser-based interaction.

Bugs Fixed#

  • The SolidContainer class now has better support for the getHeaders() method, making it possible for clients using this class to access response headers from remote Web resources.

Dependency updates#

  • Apache Commons Codec 1.17.1

  • Apache Commons IO 2.17.0

  • Guava 33.3.0

  • Jackson 2.17.2

  • Quarkus 3.14.0

  • Spring Security 6.3.3

JCL 1.1.1#

Released: 2024-06-26

Bugs fixed#

  • The SolidContainer class now has better support for the getHeaders() method, making it possible for clients using this class to access response headers from remote Web resources.

  • The OpenIdProvider.authorize() method had previously ignored scope, nonce and state values. If a client supplies these values, they will now be included in the resulting redirection URL.

Dependency updates#

  • Apache Commons Codec 1.17.0

  • Apache Commons IO 2.16.1

  • Guava 33.2.1

  • Jackson 2.17.1

  • Jose4j 0.9.6

  • Quarkus 3.12.0

  • Spring Security 6.3.1

JCL 1.1#

Released: 2023-11-29

Additions#

  • The Resource interface now includes a getHeaders() method, making it possible for clients to access all response headers from remote Web resources. This method is available on all subtypes, including RDFSource, NonRDSource, SolidRDFSource, SolidNonRDFSource and any derived user-defined type.

  • Standard URI normalization is now performed automatically for all resource identifiers, so it is now unnecessary to call URI::normalize in user code before interacting with SolidClient API methods.

  • An inrupt-client-spring module is available to make it easier to integrate Spring applications with the Inrupt Solid Client Libraries. At present, this integration layer includes an asSession(OAuth2User) method to convert a Spring user object into a Session object that can be used with these libraries.

  • An inrupt-client-quarkus module is available to make it easier to integrate Quarkus applications with the Inrupt Solid Client Libraries. As with the Spring integration, this module includes an asSession(JsonWebToken) utility method to convert a Microprofile user object into a Session object.

Dependency updates#

  • Guava 32.1.3

  • Jackson 2.16.0

  • Jena 4.10.0

  • OkHttp 4.12.0

  • Quarkus 3.6.0

  • RDF4J 4.3.8

  • Spring Boot 3.2.0

JCL 1.0.1#

Released: 2023-08-31

Bugs fixed#

  • The SolidContainer class method getResources() is now more strict in validating containment triples: it now excludes containment triples that include fragment and query components.

JCL 1.0#

Released: 2023-07-17

Additions#

  • To support Android development, the library uses RDF Module with Java8 support

  • Added NonRDFSource class to handle non-rdf resources.

  • The Session interface has added a new method authenticate(Authenticator auth, Request req, Set<String> algs) and deprecates authenticate(Request req, Set<String> algs) . This change makes use of the ClientCache<K, V> mechanism to speed up the use of session credential objects.

  • The AccessGrantClient now includes a verify(AccessCredential) method, returning an AccessCredentialVerification object.

  • When the high-level Solid Client encounters an HTTP error (e.g. 404 Not Found or 409 Conflict), rather than throwing the generic SolidClientException, it throws specializations, such as NotFoundException or ConflictException.

  • Added SolidContainer::getResources method which returns a Set and deprecated SolidContainer::getContainedResources which returns a Stream.

  • The Java Client libraries now publish an inrupt-client-runtime artifact that includes all of the modules that are commonly used by application developers.

  • The AccessGrantClient now includes a grantAccess(AccessRequest) method for approving access requests.

  • The WebIdProfile and AccessGrant classes use consistent naming for getters such that methods that return collections have pluralized names (e.g., .getStorages()). Existing (non-plural) getter methods are now deprecated.

  • The antlr dependency used by the inrupt-client-parser module is now listed in the provided Maven BOM, making it easier for users of the Java Client Libraries to have a consistent runtime version of antlr.

  • The Session interface now includes a reset() method that can be used to clear the internal state of the session.

  • The AccessGrantClient now includes a denyAccess(AccessRequest) method for issuing access denials.

  • The Metadata class in the Solid package now has an Optional<URI> getAcl() method, returning the location of an ACL document, if one is available.

  • To enable Access Grant usage, added AccessGrantUtils to update Access Control Resource(s).

  • The AccessGrantClient.query method now accepts a Set<URL> parameter for purpose arguments.

  • The AccessCredential classes (AccessGrant, AccessRequest, AccessDenial) now include a method to retrieve the date at which the credential was issued: getIssuedAt()

  • To specify multiple query values for multiple purpose and access mode values, introduces an AccessCredentialQuery class (with a .builder) that can be used with the AccessGrantClient.query method.

  • The AccessGrantClient.requestAccess method now accepts an AccessRequest.RequestParameters object so that the access request can be constructed via a builder pattern. This also adds support for issuance dates in the future.

  • The SolidContainer and SolidNonRDFSource objects can now be created without the need for explicitly providing a Metadata parameter

  • The SolidContainer class now includes an implementation of the RDFSource::validate() method so that, in the high-level client, during data mapping, a resource with the wrong shape (e.g. invalid ldp:contains triples, missing trailing slash) will throw a DataMappingException. This makes the handling of containment triples much safer for applications, as a malicious server cannot trick a client into processing unexpected resources. Strictly speaking, this change is superfluous when interacting with ESS, as the server already validates the shape of a container in this regard. This is relevant specifically for servers that maliciously or inadvertently do not conform to the Solid protocol

Updates#

  • The java client libraries now use the groupId: com.inrupt.client

  • The UmaSession class is now deprecated. A developer should use either the OpenIdSession or AccessGrantSession instead.

  • Upgrade JSON-B module to use JakartaEE 10+.

  • Developers may write custom plugins for supporting different authentication mechanisms in Solid. For known insecure mechanisms, however, the reactive authorization mechanism explicitly excludes the auth schemes: Basic and Digest

  • This change introduces a new parameter to the AccessGrantClient.query method such that developers can filter access credential queries on creator and/or recipient (instead of the more ambiguous “agent”)

  • The internal session caches are based on request URI, but those caches unnecessarily consider query parameters and fragment URIs. Those elements are now removed from the internal cache keys if they are present.

  • Ensure that the PKCE verifier code always produces strings that correspond to the specification requirements.

Removals#

  • All deprecated methods and classes from the Beta series of releases have been removed for 1.0 GA

Bugs fixed#

  • No longer send Accept: text/turtle when handling Non-RDF resources.

  • Improved support for concurrent OpenId session refresh flows.

  • Bugfix preventing runtime exceptions thrown when processing an OkHttp response to bubble up and not be caught instead of being gracefully handled.