All Downloads are FREE. Search and download functionalities are using the official Maven repository.

io.sphere.sdk.client.SphereClientConfig Maven / Gradle / Ivy

There is a newer version: 1.0.0-M26
Show newest version
package io.sphere.sdk.client;

import io.sphere.sdk.models.Base;

import java.util.Properties;

import static io.sphere.sdk.client.ClientPackage.API_URL;
import static io.sphere.sdk.client.ClientPackage.AUTH_URL;
import static io.sphere.sdk.client.ClientPackage.requireNonBlank;

/**
 * The full configuration for a SPHERE.IO client.
 *
 */
public class SphereClientConfig extends Base implements SphereAuthConfig, SphereApiConfig {
    public static final String ENVIRONMENT_VARIABLE_API_URL_SUFFIX = "API_URL";
    public static final String ENVIRONMENT_VARIABLE_AUTH_URL_SUFFIX = "AUTH_URL";
    public static final String ENVIRONMENT_VARIABLE_PROJECT_KEY_SUFFIX = "PROJECT_KEY";
    public static final String ENVIRONMENT_VARIABLE_CLIENT_ID_SUFFIX = "CLIENT_ID";
    public static final String ENVIRONMENT_VARIABLE_CLIENT_SECRET_SUFFIX = "CLIENT_SECRET";

    public static final String PROPERTIES_KEY_API_URL_SUFFIX = "apiUrl";
    public static final String PROPERTIES_KEY_AUTH_URL_SUFFIX = "authUrl";
    public static final String PROPERTIES_KEY_PROJECT_KEY_SUFFIX = "projectKey";
    public static final String PROPERTIES_KEY_CLIENT_ID_SUFFIX = "clientId";
    public static final String PROPERTIES_KEY_CLIENT_SECRET_SUFFIX = "clientSecret";

    private final String projectKey;
    private final String clientId;
    private final String clientSecret;
    private final String authUrl;
    private final String apiUrl;

    private SphereClientConfig(final String projectKey, final String clientId, final String clientSecret, final String authUrl, final String apiUrl) {
        this.apiUrl = requireNonBlank(apiUrl, "apiUrl");
        this.projectKey = requireNonBlank(projectKey, "projectKey");
        this.clientId = requireNonBlank(clientId, "clientId");
        this.clientSecret = requireNonBlank(clientSecret, "clientSecret");
        this.authUrl = requireNonBlank(authUrl, "authUrl");
    }

    public static SphereClientConfig of(final String projectKey, final String clientId, final String clientSecret) {
        return of(projectKey, clientId, clientSecret, AUTH_URL, API_URL);
    }

    public static SphereClientConfig of(final String projectKey, final String clientId, final String clientSecret, final String authUrl, final String apiUrl) {
        return new SphereClientConfig(projectKey, clientId, clientSecret, authUrl, apiUrl);
    }

    @Override
    public String getApiUrl() {
        return apiUrl;
    }

    @Override
    public String getAuthUrl() {
        return authUrl;
    }

    @Override
    public String getClientId() {
        return clientId;
    }

    @Override
    public String getClientSecret() {
        return clientSecret;
    }

    @Override
    public String getProjectKey() {
        return projectKey;
    }

    public SphereClientConfig withApiUrl(final String apiUrl) {
        return of(getProjectKey(), getClientId(), getClientSecret(), getAuthUrl(), apiUrl);
    }
    
    public SphereClientConfig withAuthUrl(final String authUrl) {
        return of(getProjectKey(), getClientId(), getClientSecret(), authUrl, getApiUrl());
    }

    /**
    Creates a {@link SphereClientConfig} out of environment variables using {@code prefix} as namespace parameter.

    An example environment variable initialization with "EXAMPLE" as {@code prefix}:
    
{@code
    export EXAMPLE_PROJECT_KEY="YOUR project key"
    export EXAMPLE_CLIENT_ID="YOUR client id"
    export EXAMPLE_CLIENT_SECRET="YOUR client secret"
    export EXAMPLE_AUTH_URL="https://auth.sphere.io"
    export EXAMPLE_API_URL="https://api.sphere.io"
    }
The possible suffixes are {@value #ENVIRONMENT_VARIABLE_PROJECT_KEY_SUFFIX}, {@value #ENVIRONMENT_VARIABLE_CLIENT_ID_SUFFIX}, {@value #ENVIRONMENT_VARIABLE_CLIENT_SECRET_SUFFIX}, {@value #ENVIRONMENT_VARIABLE_AUTH_URL_SUFFIX} and {@value #ENVIRONMENT_VARIABLE_API_URL_SUFFIX}. @param prefix prefix of the environment variables @return a new {@link SphereClientConfig} containing the values of the environment variables. */ public static SphereClientConfig ofEnvironmentVariables(final String prefix) { return SphereClientConfigUtils.ofEnvironmentVariables(prefix, System::getenv); } /** Creates a {@link SphereClientConfig} using {@link Properties} using {@code prefix} as namespace parameter. An example properties file with "commercetools." (including the dot) as {@code prefix}:
{@code
    commercetools.projectKey=YOUR project key without quotes
    commercetools.clientId=YOUR client id without quotes
    commercetools.clientSecret=YOUR client secret without quotes
    commercetools.authUrl=https://auth.sphere.io
    commercetools.apiUrl=https://api.sphere.io
    }
The possible suffixes are {@value #PROPERTIES_KEY_PROJECT_KEY_SUFFIX}, {@value #PROPERTIES_KEY_CLIENT_ID_SUFFIX}, {@value #PROPERTIES_KEY_CLIENT_SECRET_SUFFIX}, {@value #PROPERTIES_KEY_AUTH_URL_SUFFIX} and {@value #PROPERTIES_KEY_API_URL_SUFFIX}. @param properties properties containing the commercetools platform credentials @param prefix prefix of the property keys @return a new {@link SphereClientConfig} containing the values of the properties. */ public static SphereClientConfig ofProperties(final Properties properties, final String prefix) { return SphereClientConfigUtils.ofProperties(properties, prefix); } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy