com.couchbase.client.java.diagnostics.PingOptions Maven / Gradle / Ivy
Show all versions of java-client Show documentation
/*
* Copyright (c) 2019 Couchbase, Inc.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package com.couchbase.client.java.diagnostics;
import com.couchbase.client.core.annotation.Stability;
import com.couchbase.client.core.retry.RetryStrategy;
import com.couchbase.client.core.service.ServiceType;
import java.time.Duration;
import java.util.Arrays;
import java.util.EnumSet;
import java.util.Optional;
import java.util.Set;
import static com.couchbase.client.core.util.Validators.notNull;
import static com.couchbase.client.core.util.Validators.notNullOrEmpty;
/**
* Allows to customize a cluster or bucket level ping operation.
*/
public class PingOptions {
/**
* Holds a custom report id.
*/
private Optional reportId = Optional.empty();
/**
* The service types to limit this diagnostics request to.
*/
private Set serviceTypes;
/**
* The timeout for the operation, if set.
*/
private Optional timeout = Optional.empty();
/**
* The custom retry strategy, if set.
*/
private Optional retryStrategy = Optional.empty();
/**
* Creates a new set of {@link PingOptions}.
*
* @return options to customize.
*/
public static PingOptions pingOptions() {
return new PingOptions();
}
private PingOptions() {}
/**
* Sets a custom report ID that will be used in the report.
*
* If no report ID is provided, the client will generate a unique one.
*
* @param reportId the report ID that should be used for this report.
* @return the {@link PingOptions} to allow method chaining.
*/
public PingOptions reportId(final String reportId) {
this.reportId = Optional.of(reportId);
return this;
}
/**
* Allows to customize the set of services to ping.
*
* If this method is not called, all available services are included in the ping.
*
* @param serviceTypes the service types that should be pinged.
* @return the {@link PingOptions} to allow method chaining.
*/
public PingOptions serviceTypes(final Set serviceTypes) {
this.serviceTypes = notNullOrEmpty(serviceTypes, "ServiceTypes");
return this;
}
/**
* Allows to customize the set of services to ping.
*
* If this method is not called, all available services are included in the ping.
*
* @param serviceTypes the service types that should be pinged.
* @return the {@link PingOptions} to allow method chaining.
*/
public PingOptions serviceTypes(final ServiceType... serviceTypes) {
EnumSet set = EnumSet.noneOf(ServiceType.class);
set.addAll(Arrays.asList(notNull(serviceTypes, "ServiceTypes")));
return serviceTypes(set);
}
/**
* Specifies a custom per-operation timeout.
*
* Note: if a custom timeout is provided through this builder, it will override the default set
* on the environment.
*
* @param timeout the timeout to use for this operation.
* @return this options builder for chaining purposes.
*/
public PingOptions timeout(final Duration timeout) {
this.timeout = Optional.ofNullable(timeout);
return this;
}
/**
* Specifies a custom {@link RetryStrategy} for this operation.
*
* Note: if a custom strategy is provided through this builder, it will override the default set
* on the environment.
*
* @param retryStrategy the retry strategy to use for this operation.
* @return this options builder for chaining purposes.
*/
public PingOptions retryStrategy(final RetryStrategy retryStrategy) {
this.retryStrategy = Optional.ofNullable(retryStrategy);
return this;
}
@Stability.Internal
public Built build() {
return new Built();
}
@Stability.Internal
public class Built {
Built() { }
public Optional reportId() {
return reportId;
}
/**
* Returns the custom timeout if provided.
*/
public Optional timeout() {
return timeout;
}
public Set serviceTypes() {
return serviceTypes;
}
/**
* Returns the custom retry strategy if provided.
*/
public Optional retryStrategy() {
return retryStrategy;
}
}
}