io.sphere.sdk.client.SphereClientFactory Maven / Gradle / Ivy
package io.sphere.sdk.client;
import io.sphere.sdk.http.HttpClient;
import io.sphere.sdk.http.HttpRequest;
import io.sphere.sdk.http.HttpResponse;
import io.sphere.sdk.models.Base;
import io.sphere.sdk.models.SphereException;
import java.lang.reflect.InvocationTargetException;
import java.lang.reflect.Method;
import java.util.concurrent.CompletionStage;
import java.util.function.Function;
import java.util.function.Supplier;
import static io.sphere.sdk.utils.CompletableFutureUtils.successful;
/**
* A factory to instantiate SPHERE.IO Java clients which use {@link CompletionStage} as future implementation.
*
* {@include.example example.JavaClientInstantiationExample}
*/
public class SphereClientFactory extends Base {
private final Supplier httpClientSupplier;
private SphereClientFactory(final Supplier httpClientSupplier) {
this.httpClientSupplier = httpClientSupplier;
}
public static SphereClientFactory of(final Supplier httpClientSupplier) {
return new SphereClientFactory(httpClientSupplier);
}
public static SphereClientFactory of() {
try {
Class> clazz;
try {
clazz = Class.forName("io.sphere.sdk.client.SphereAsyncHttpClientFactory");
} catch (final ClassNotFoundException e) {
clazz = Class.forName("io.sphere.sdk.client.SphereApacheHttpClientFactory");
}
final Method create = clazz.getMethod("create");
final Supplier supplier = () -> {
try {
return (HttpClient) create.invoke(null);
} catch (IllegalAccessException | InvocationTargetException e) {
throw new SphereException(e);
}
};
return of(supplier);
} catch (ClassNotFoundException | NoSuchMethodException e) {
throw new SphereException(e);
}
}
public HttpClient createHttpClient() {
return httpClientSupplier.get();
}
/**
* Creates a standard client with configurable service URLs. Intended for commercetools staff
* developing with a custom SPHERE.IO instance.
*
* @param config configuration for the client
* @return client
*/
public SphereClient createClient(final SphereClientConfig config) {
final HttpClient httpClient = createHttpClient();
final SphereAccessTokenSupplier tokenSupplier = SphereAccessTokenSupplier.ofAutoRefresh(config, httpClient, false);
return SphereClient.of(config, httpClient, tokenSupplier);
}
/**
* Creates a client with a custom service to provide access tokens.
* @param config the configuration to use the API
* @param tokenSupplier a service which provides tokens
* @return client
*/
public SphereClient createClient(final SphereApiConfig config, final SphereAccessTokenSupplier tokenSupplier) {
return SphereClient.of(config, createHttpClient(), tokenSupplier);
}
/**
* Creates a standard client suitable for online shops.
*
* For the credentials consult the Merchant Center.
* @param projectKey the project identifier
* @param clientId username
* @param clientSecret password
* @return sphere client
*/
public SphereClient createClient(final String projectKey, final String clientId, final String clientSecret) {
return createClient(SphereClientConfig.of(projectKey, clientId, clientSecret));
}
/**
* Creates a client which relies on an access token and does not refresh it, it reuses an existing http client.
*
* A possible use case is keeping the clientSecret secret and/or instantiate a client which is used for few requests for a limited time.
* The underlying http client does not get closed by closing the client
*
* @param config the configuration to use the API
* @param accessToken the token belonging to the project in {@code config}
* @param httpClient the http client used for performing requests
* @return client
*/
public SphereClient createClientOfApiConfigAndAccessToken(final SphereApiConfig config, final String accessToken, final HttpClient httpClient) {
final HttpClient uncloseableHttpClient = new HttpClient() {
@Override
public CompletionStage execute(final HttpRequest httpRequest) {
return httpClient.execute(httpRequest);
}
@Override
public void close() {
}
};
return SphereClient.of(config, uncloseableHttpClient, SphereAccessTokenSupplier.ofConstantToken(accessToken));
}
/**
* Creates a client which relies on an access token and does not refresh it.
*
* A possible use case is keeping the clientSecret secret and/or instantiate a client which is used for few requests for a limited time.
*
* @param config the configuration to use the API
* @param accessToken the token belonging to the project in {@code config}
* @return client
*/
public SphereClient createClientOfApiConfigAndAccessToken(final SphereApiConfig config, final String accessToken) {
return SphereClient.of(config, createHttpClient(), SphereAccessTokenSupplier.ofConstantToken(accessToken));
}
/**
* deprecated
* @deprecated use {@link TestDoubleSphereClientFactory#createHttpTestDouble(Function)}
* @param function mapping from intent to http response
* @return test double
*/
@Deprecated
public static SphereClient createHttpTestDouble(final Function function) {
return TestDoubleSphereClientFactory.createHttpTestDouble(function);
}
/**
* deprecated
* @deprecated use {@link TestDoubleSphereClientFactory#createObjectTestDouble(Function)}
* @param function a function which returns a matching http request for a SPHERE.IO request.
* @return sphere client test double
*/
@Deprecated
@SuppressWarnings("unchecked")
public static SphereClient createObjectTestDouble(final Function function) {
return new SphereClient() {
@Override
public CompletionStage execute(final SphereRequest sphereRequest) {
final T result = (T) function.apply(sphereRequest.httpRequestIntent());
return successful(result);
}
@Override
public void close() {
}
@Override
public String toString() {
return "SphereClientObjectTestDouble";
}
};
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy