com.stripe.net.RequestOptions Maven / Gradle / Ivy
package com.stripe.net;
import com.stripe.Stripe;
import java.net.PasswordAuthentication;
import java.net.Proxy;
import java.util.Map;
import lombok.EqualsAndHashCode;
@EqualsAndHashCode(callSuper = false)
public class RequestOptions {
// When adding setting here keep them in sync with settings in StripeClientOptions and
// in the RequestOptions.merge method
private final Authenticator authenticator;
private final String clientId;
private final String stripeContext;
private final String idempotencyKey;
private final String stripeAccount;
private final String baseUrl;
/** Stripe version always set at {@link Stripe#API_VERSION}. */
private final String stripeVersion = Stripe.API_VERSION;
/**
* Stripe version override when made on behalf of others. This can be used when the returned
* response will not be deserialized into the current classes pinned to {@link Stripe#VERSION}.
*/
private final String stripeVersionOverride;
private final Integer connectTimeout;
private final Integer readTimeout;
private final Integer maxNetworkRetries;
private final Proxy connectionProxy;
private final PasswordAuthentication proxyCredential;
public static RequestOptions getDefault() {
return new RequestOptions(
null, null, null, null, null, null, null, null, null, null, null, null);
}
protected RequestOptions(
Authenticator authenticator,
String clientId,
String idempotencyKey,
String stripeContext,
String stripeAccount,
String stripeVersionOverride,
String baseUrl,
Integer connectTimeout,
Integer readTimeout,
Integer maxNetworkRetries,
Proxy connectionProxy,
PasswordAuthentication proxyCredential) {
this.authenticator = authenticator;
this.clientId = clientId;
this.idempotencyKey = idempotencyKey;
this.stripeContext = stripeContext;
this.stripeAccount = stripeAccount;
this.stripeVersionOverride = stripeVersionOverride;
this.baseUrl = baseUrl;
this.connectTimeout = connectTimeout;
this.readTimeout = readTimeout;
this.maxNetworkRetries = maxNetworkRetries;
this.connectionProxy = connectionProxy;
this.proxyCredential = proxyCredential;
}
public Authenticator getAuthenticator() {
return this.authenticator;
}
public String getApiKey() {
if (authenticator instanceof BearerTokenAuthenticator) {
return ((BearerTokenAuthenticator) authenticator).getApiKey();
}
return null;
}
public String getClientId() {
return clientId;
}
public String getStripeContext() {
return stripeContext;
}
public String getIdempotencyKey() {
return idempotencyKey;
}
public String getStripeAccount() {
return stripeAccount;
}
public String getStripeVersion() {
return stripeVersion;
}
public static String unsafeGetStripeVersionOverride(RequestOptions options) {
return options.stripeVersionOverride;
}
public Integer getReadTimeout() {
return readTimeout;
}
public Integer getConnectTimeout() {
return connectTimeout;
}
public Integer getMaxNetworkRetries() {
return maxNetworkRetries;
}
public Proxy getConnectionProxy() {
return connectionProxy;
}
public PasswordAuthentication getProxyCredential() {
return proxyCredential;
}
public String getBaseUrl() {
return baseUrl;
}
public static RequestOptionsBuilder builder() {
return new RequestOptionsBuilder();
}
/**
* Convert request options to builder, retaining invariant values for the integration.
*
* @deprecated prefer {@link toBuilderFullCopy} which fully copies the request options instead of
* a subset of its options.
* @return option builder.
*/
@Deprecated
public RequestOptionsBuilder toBuilder() {
return new RequestOptionsBuilder()
.setAuthenticator(this.authenticator)
.setStripeAccount(this.stripeAccount);
}
/**
* Convert request options to builder, copying all options.
*
* @return option builder.
*/
public RequestOptionsBuilder toBuilderFullCopy() {
return RequestOptionsBuilder.unsafeSetStripeVersionOverride(
new RequestOptionsBuilder()
.setAuthenticator(this.authenticator)
.setBaseUrl(this.baseUrl)
.setClientId(this.clientId)
.setIdempotencyKey(this.idempotencyKey)
.setStripeAccount(this.stripeAccount)
.setConnectTimeout(this.connectTimeout)
.setReadTimeout(this.readTimeout)
.setMaxNetworkRetries(this.maxNetworkRetries)
.setConnectionProxy(this.connectionProxy)
.setProxyCredential(this.proxyCredential),
stripeVersionOverride);
}
public static class RequestOptionsBuilder {
protected Authenticator authenticator;
protected String clientId;
protected String idempotencyKey;
protected String stripeContext;
protected String stripeAccount;
protected String stripeVersionOverride;
protected Integer connectTimeout;
protected Integer readTimeout;
protected Integer maxNetworkRetries;
protected Proxy connectionProxy;
protected PasswordAuthentication proxyCredential;
protected String baseUrl;
/**
* Constructs a request options builder with the global parameters (API key and client ID) as
* default values.
*/
public RequestOptionsBuilder() {}
public Authenticator getAuthenticator() {
return this.authenticator;
}
public RequestOptionsBuilder setAuthenticator(Authenticator authenticator) {
this.authenticator = authenticator;
return this;
}
public String getApiKey() {
if (authenticator instanceof BearerTokenAuthenticator) {
return ((BearerTokenAuthenticator) authenticator).getApiKey();
}
return null;
}
public RequestOptionsBuilder setApiKey(String apiKey) {
if (apiKey == null) {
this.authenticator = null;
} else {
this.authenticator = new BearerTokenAuthenticator(normalizeApiKey(apiKey));
}
return this;
}
public RequestOptionsBuilder clearApiKey() {
this.authenticator = null;
return this;
}
public String getClientId() {
return clientId;
}
public RequestOptionsBuilder setClientId(String clientId) {
this.clientId = normalizeClientId(clientId);
return this;
}
public RequestOptionsBuilder clearClientId() {
this.clientId = null;
return this;
}
public String getStripeContext() {
return stripeContext;
}
public RequestOptionsBuilder setStripeContext(String context) {
this.stripeContext = context;
return this;
}
public RequestOptionsBuilder clearStripeContext() {
this.stripeContext = null;
return this;
}
public RequestOptionsBuilder setIdempotencyKey(String idempotencyKey) {
this.idempotencyKey = idempotencyKey;
return this;
}
public Integer getConnectTimeout() {
return connectTimeout;
}
/**
* Sets the timeout value that will be used for making new connections to the Stripe API (in
* milliseconds).
*
* @param timeout timeout value in milliseconds
*/
public RequestOptionsBuilder setConnectTimeout(Integer timeout) {
this.connectTimeout = timeout;
return this;
}
public Integer getReadTimeout() {
return readTimeout;
}
/**
* Sets the timeout value that will be used when reading data from an established connection to
* the Stripe API (in milliseconds).
*
* Note that this value should be set conservatively because some API requests can take time
* and a short timeout increases the likelihood of causing a problem in the backend.
*
* @param timeout timeout value in milliseconds
*/
public RequestOptionsBuilder setReadTimeout(Integer timeout) {
this.readTimeout = timeout;
return this;
}
public Integer getMaxNetworkRetries() {
return maxNetworkRetries;
}
/**
* Sets the maximum number of times the request will be retried in the event of a failure.
*
* @param maxNetworkRetries the number of times to retry the request
*/
public RequestOptionsBuilder setMaxNetworkRetries(Integer maxNetworkRetries) {
this.maxNetworkRetries = maxNetworkRetries;
return this;
}
public Proxy getConnectionProxy() {
return connectionProxy;
}
public RequestOptionsBuilder setConnectionProxy(Proxy connectionProxy) {
this.connectionProxy = connectionProxy;
return this;
}
public PasswordAuthentication getProxyCredential() {
return proxyCredential;
}
public RequestOptionsBuilder setProxyCredential(PasswordAuthentication proxyCredential) {
this.proxyCredential = proxyCredential;
return this;
}
public RequestOptionsBuilder clearIdempotencyKey() {
this.idempotencyKey = null;
return this;
}
public String getIdempotencyKey() {
return this.idempotencyKey;
}
public String getStripeAccount() {
return this.stripeAccount;
}
public RequestOptionsBuilder setStripeAccount(String stripeAccount) {
this.stripeAccount = stripeAccount;
return this;
}
public RequestOptionsBuilder clearStripeAccount() {
return setStripeAccount(null);
}
/**
* This is for internal use only. See {@link com.stripe.model.EphemeralKey#create(Map,
* RequestOptions)}. Setting this yourself will result in a version mismatch between your
* request and this library's types, which can result in missing data and deserialization
* errors.
*
*
Static, so that it doesn't appear in IDE auto-completion alongside the other setters.
*
* @return option builder
*/
public static RequestOptionsBuilder unsafeSetStripeVersionOverride(
RequestOptionsBuilder builder, String stripeVersionOverride) {
builder.stripeVersionOverride = normalizeStripeVersion(stripeVersionOverride);
return builder;
}
public RequestOptionsBuilder setBaseUrl(final String baseUrl) {
this.baseUrl = baseUrl;
return this;
}
/** Constructs a {@link RequestOptions} with the specified values. */
public RequestOptions build() {
return new RequestOptions(
this.authenticator,
normalizeClientId(this.clientId),
normalizeIdempotencyKey(this.idempotencyKey),
stripeContext,
normalizeStripeAccount(this.stripeAccount),
normalizeStripeVersion(this.stripeVersionOverride),
normalizeBaseUrl(this.baseUrl),
connectTimeout,
readTimeout,
maxNetworkRetries,
connectionProxy,
proxyCredential);
}
}
protected static String normalizeApiKey(String apiKey) {
// null apiKeys are considered "valid"
if (apiKey == null) {
return null;
}
return apiKey.trim();
}
protected static String normalizeClientId(String clientId) {
// null client_ids are considered "valid"
if (clientId == null) {
return null;
}
String normalized = clientId.trim();
if (normalized.isEmpty()) {
throw new InvalidRequestOptionsException("Empty client_id specified!");
}
return normalized;
}
protected static String normalizeStripeVersion(String stripeVersion) {
// null stripeVersions are considered "valid" and use Stripe.apiVersion
if (stripeVersion == null) {
return null;
}
String normalized = stripeVersion.trim();
if (normalized.isEmpty()) {
throw new InvalidRequestOptionsException("Empty Stripe version specified!");
}
return normalized;
}
protected static String normalizeBaseUrl(String baseUrl) {
// null baseUrl is valid, and will fall back to e.g. Stripe.apiBase or Stripe.connectBase
// (depending on the method)
if (baseUrl == null) {
return null;
}
String normalized = baseUrl.trim();
if (normalized.isEmpty()) {
throw new InvalidRequestOptionsException("Empty baseUrl specified!");
}
return normalized;
}
protected static String normalizeIdempotencyKey(String idempotencyKey) {
if (idempotencyKey == null) {
return null;
}
String normalized = idempotencyKey.trim();
if (normalized.isEmpty()) {
throw new InvalidRequestOptionsException("Empty Idempotency Key Specified!");
}
if (normalized.length() > 255) {
throw new InvalidRequestOptionsException(
String.format(
"Idempotency Key length was %d, which is larger than the 255 character " + "maximum!",
normalized.length()));
}
return normalized;
}
protected static String normalizeStripeContext(String stripContext) {
if (stripContext == null) {
return null;
}
String normalized = stripContext.trim();
if (normalized.isEmpty()) {
throw new InvalidRequestOptionsException("Empty stripe context specified!");
}
return normalized;
}
protected static String normalizeStripeAccount(String stripeAccount) {
if (stripeAccount == null) {
return null;
}
String normalized = stripeAccount.trim();
if (normalized.isEmpty()) {
throw new InvalidRequestOptionsException("Empty stripe account specified!");
}
return normalized;
}
static RequestOptions merge(StripeResponseGetterOptions clientOptions, RequestOptions options) {
if (options == null) {
return new RequestOptions(
clientOptions.getAuthenticator(), // authenticator
clientOptions.getClientId(), // clientId
null, // idempotencyKey
clientOptions.getStripeContext(), // stripeContext
null, // stripeAccount
null, // stripeVersionOverride
null, // baseUrl
clientOptions.getConnectTimeout(), // connectTimeout
clientOptions.getReadTimeout(), // readTimeout
clientOptions.getMaxNetworkRetries(), // maxNetworkRetries
clientOptions.getConnectionProxy(), // connectionProxy
clientOptions.getProxyCredential() // proxyCredential
);
}
return new RequestOptions(
options.getAuthenticator() != null
? options.getAuthenticator()
: clientOptions.getAuthenticator(),
options.getClientId() != null ? options.getClientId() : clientOptions.getClientId(),
options.getIdempotencyKey(),
options.getStripeContext() != null
? options.getStripeContext()
: clientOptions.getStripeContext(),
options.getStripeAccount(),
RequestOptions.unsafeGetStripeVersionOverride(options),
options.getBaseUrl(),
options.getConnectTimeout() != null
? options.getConnectTimeout()
: clientOptions.getConnectTimeout(),
options.getReadTimeout() != null
? options.getReadTimeout()
: clientOptions.getReadTimeout(),
options.getMaxNetworkRetries() != null
? options.getMaxNetworkRetries()
: clientOptions.getMaxNetworkRetries(),
options.getConnectionProxy() != null
? options.getConnectionProxy()
: clientOptions.getConnectionProxy(),
options.getProxyCredential() != null
? options.getProxyCredential()
: clientOptions.getProxyCredential());
}
public static class InvalidRequestOptionsException extends RuntimeException {
private static final long serialVersionUID = 1L;
public InvalidRequestOptionsException(String message) {
super(message);
}
}
}