A Java Client or SDK that allows you to interact with the Microcks API. It has minimal dependencies and is easy to use.
Latest released version is 0.0.3
.
Current development version is 0.0.4-SNAPSHOT
.
- Documentation
- Microcks Community and community meeting
- Join us on Discord, on GitHub Discussions or CNCF Slack #microcks channel
To get involved with our community, please make sure you are familiar with the project's Code of Conduct.
Java Client | Microcks Version |
---|---|
0.0.2 |
1.10.0 and + |
0.0.3 |
1.10.0 and + |
If you're using Maven:
<dependency>
<groupId>io.github.microcks</groupId>
<artifactId>microcks-java-client</artifactId>
<version>0.0.3</version>
</dependency>
or if you're using Gradle:
dependencies {
implementation 'io.github.microcks:microcks-java-client:0.0.3'
}
The API endpoints available on Microcks backend are split in different classes in the io.github.microcks.client
package.
Each class represents a different part of the API but needs a common client configuration that is named ApiClient
.
Here's the basic usage of the client where you configure the base URI of the Microcks API:
ApiClient apiClient = new ApiClient();
apiClient.updateBaseUri("http://localhost:8585/api");
You can then easily use the client to interact with the different part of the API:
ConfigApi configApi = new ConfigApi(apiClient);
KeycloakConfig config = configApi.getKeycloakConfig();
Check the Microcks' OpenAPI reference for comprehensive list of available endpoints and their parameters.
If your Microcks backend instance has enabled AuthN and AUthZ and if you need to access authenticated endpoints,
we provide a KeycloakClient
to first retrieve an oAuth token to use in following requests. You'll additionally need
the service account name and credentials to retrieve the token (see our documentation on
how Microcks is using Service Accounts).
The flow is as follows:
KeycloakConfig keycloak = configApi.getKeycloakConfig();
// If Keycloak is enabled on target backend.
if (config.isEnabled()) {
// Build the OAuth token endpoint - here using Keycloak public url but it could be another private one.
String tokenEndpoint = keycloak.getAuthServerUrl() + "/realms/" + keycloak.getRealm() + "/protocol/openid-connect/token";
final String oauthToken = KeycloakClient.connectAndGetOAuthToken("<service-account>", "<service-account-credentials>", tokenEndpoint);
// Set a new interceptor to add the Authorization header with the OAuth token.
apiClient.setRequestInterceptor(request -> request.header("Authorization", "Bearer " + oauthToken));
}
// Now you can use the client to create a protected resource.
JobApi jobApi = new JobApi(apiClient);
ImportJob importJob = new ImportJob();
importJob.setName("Hello Soap Service");
importJob.setRepositoryUrl("https://raw.githubusercontent.com/microcks/microcks/master/samples/HelloService-soapui-project.xml");
ImportJob result = jobApi.createImportJob(importJob);