All notable changes to this project will be documented in this file. This project adheres to Semantic Versioning.
- Using continue pagination and remove mechanism to iterate based in
next
- Remove
continue
flag to support navigation to next page - Remove
page
param to support navigation to a give page
- Fixing bug deserializing Resource Maps with floats.
- Fixing bug deserializing URL query string when the value contains the character
=
.
- Removing auth header when requests to the registry/services endpoint.
- Update HttpClientAccessCredentialProvider to use registry in order to extract identity service location per owner to get tokens. To avoid making requests to registry continuously, a cache has also been implemented to store identity hosts per owner name. Values in the cache will expire after 10 minutes, so that, if any change is done in registry, it will be reflected in the client in 10 minutes as much.
- Release minor version
- Add
continue
flag to support navigation to next page
- Upgrade google http client version. This fixes some bugs related to not being able to do a browse using a Map<String, String> with certain headers as
accept
orcontent-type
- Headers
accept
andcontent-type
with valueapplication/json
added to GET operations
- Fix NPE when some of the linked resources in an array have the field
statusCode
and some others don't
- New serializer for
MetadataType
to avoid building the jsonObject when it's empty. It is empty on these cases:
"metadata": {}
"metadata": {
"fields": {}
}
"metadata": {
"fields": {
"locks": {},
"locking": {}
}
}
- The headers are kept in the possible pagination requests
- Added the option to pass headers parameter to the endpoint
-
Add capability to call services for owners different from the owner which the client was first instantiated.
client.service("myService", "myOwner")
will use registry service to look for a service namedmyService
among all services for ownermyOwner
. -
Extend current functionality to add the owner query param to the url when creating the resourceful endpoint even if the user does not add when calling the method.
client.service("myService", "myOwner").resourcefulEndpoint("myService", MyClass.class)
will generate a URL kind of:
http://myHost:ports/myPath/myService?owner=myOwner
-
RequestClient moved to interface, and added the capability to define at configuration which implementation to be used when creating the client. So this means that the implementation of Http requests can be now delegated to the user. Regarding the old implementation it´s being hold in the distribution as the default RequestClient implementation, using Google Http libraries.
- Add
@Key
annotation toResource#title
field
- Removed dependencies for:
- WiremockHelper
- Sequoia Annotation
- The client won't paginate by default to the next page if there isn't any content even though there are pagination links.
- Resource common fields added to
Resource
class:- title
- createdBy
- deletedAt
- deletedBy
- metadata
- reapAt
- scores
- The field
metadata
is retrieved only when the resource is got directly using its reference, for instance:
ResourceResponse<Content> content = endpoint.read(Reference.fromReference("owner:xxxxxxxxxxxx"));
Be careful if you have some classes using any of the above fields, that might cause issues.
- The exception
RequestExecutionException
has more details in the message: http verb and URL. - New possibility of adding an HTTP Interceptor to the client so you can hook your actions to every response, such as logging. Check README file to get more information about how to use it. For more info see PROCESSING-2464
- When any exception other then HttpResponseException will occur while executeRequest process then RequestClient rise
RequestExecutionException
with this exception in cause parameter
- Expose initializeRequest method in RequestClient so that it can be overriden from classes which are extending it, for more info see PROCESSING-2392
- Credentials are optional instead of mandatory in ClientConfiguration to create SequoiaClient, this allows to call services which don't require authentication using SequoiaClient, for more info see PROCESSING-2399
- Fix NPE when linked resources don't contain ref to join with main resources because this reference is not properly requested in the query, WARN message is logged when this situation happens. For more info see PROCESSING-2386
- Performance improvements deserializing and mapping resources.
- Removed usage of JsonPath. For more info see PROCESSING-2365
- Added support for filtering included resources, for more info see PROCESSING-2370
- Performance improvements using caching to avoid deserializing same entities more than once
- Avoid usage of PathNotFoundException, for more info see PROCESSING-2345
- Performance improvement handling LinkedResourceIterable, for more info see PROCESSING-2309
- Adapt pagination to 5 pages returned by metadata services, for more info see FOUNDATION-2620
- Pagination over linked resources supported
- Added support for intersect https://productdocs.piksel.com/components/foundations/concepts/aggregate-resources.html
- Added support for active and available filters in criteria
- Bug fixed when 0 resources are returned in the page NoSuchElementException is not thrown.
- correlationId logged and held in field in RequestExecutionException.
- Improved method equals in ClientConfiguration.
- reset method added to LifeCycle interface. This will allow reinitialisation of the SequoiaClient in case of failure and it will be automatically called when awaitInitialised fails.
- SequoiaClientInitalisationException is thrown when an error occurs during initialization
- Apply toString method in RequestClient logs
- Using http://www.mojohaus.org/flatten-maven-plugin/usage.html in order to remove dependencies with the parent.
- Ignore missing references when
linked.[relationship]
is returning a 404 rather than throwing IncludeResourceException. - Fix NPE when the returned linked resources don't include ref
- Performance improvement on parsing when response contains linked resources
- Added support for using multiple query parameters if filtering lists
- Added support for setting RecoveryStrategy: back off and number of retries, when 5xx errors occur
- Related Document Sort and Fields as query parameters passed to the secondary query as prefixes with the relationship
- Support the ServiceFactoryProvider extension point to allow for the customization of service and endpoint creation by usercode.
- Number support in ResourceList to manage all the numbers as Number instead of as long.
- Allow User-Agent header to be configured through ClientConfiguration
- Fix a bug whereby if the 'next' page returned an empty result, an index out of bounds exception was triggered
- Specify UTF-8 as the desired JSON encoding rather than relying on the platform default charset
- Fix the resources management with endpoints with hyphen "-" in the url.
- Add a shaded jar as part of the release for users needing to control the dependency (especially Guava)
- All fields (except derived) settable on the Resource.
- Usage of Wiremock Helper
- Added support for faceted counts
- Added support for non-Optional collections for @DirectRelationships and @IndirectRelationships
First release of the Client SDK including:
- Transparent acquisition and refreshing of access tokens
- Transparent acquisition and management of registered services
- Support for both business and resourceful endpoints
- A fluent criteria-based API for selecting, filtering, expanding/including, paging and searching resourceful resources
- Automatically mapped linked resources into Java models
- Pluggable JSON serialization and HTTP transports
- Transparent and lazy pagination of resources
- Built-in validation support via Hibernate Validator