
com.amazonaws.client.builder.AwsAsyncClientBuilder Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of aws-java-sdk-osgi Show documentation
Show all versions of aws-java-sdk-osgi Show documentation
The AWS SDK for Java with support for OSGi. The AWS SDK for Java provides Java APIs for building software on AWS' cost-effective, scalable, and reliable infrastructure products. The AWS Java SDK allows developers to code against APIs for all of Amazon's infrastructure web services (Amazon S3, Amazon EC2, Amazon SQS, Amazon Relational Database Service, Amazon AutoScaling, etc).
/*
* Copyright 2011-2016 Amazon.com, Inc. or its affiliates. All Rights Reserved.
*
* Licensed under the Apache License, Version 2.0 (the "License").
* You may not use this file except in compliance with the License.
* A copy of the License is located at
*
* http://aws.amazon.com/apache2.0
*
* or in the "license" file accompanying this file. This file 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.amazonaws.client.builder;
import com.amazonaws.ClientConfigurationFactory;
import com.amazonaws.annotation.NotThreadSafe;
import com.amazonaws.annotation.SdkProtectedApi;
import com.amazonaws.annotation.SdkTestInternalApi;
import com.amazonaws.client.AwsAsyncClientParams;
import com.amazonaws.regions.AwsRegionProvider;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
/**
* Base class for all service specific async client builders.
*
* @param Concrete builder type, used for better fluent methods.
*/
@NotThreadSafe
@SdkProtectedApi
public abstract class AwsAsyncClientBuilder extends
AwsClientBuilder {
private ExecutorFactory executorFactory;
protected AwsAsyncClientBuilder(ClientConfigurationFactory clientConfigFactory) {
super(clientConfigFactory);
}
@SdkTestInternalApi
protected AwsAsyncClientBuilder(ClientConfigurationFactory clientConfigFactory,
AwsRegionProvider regionProvider) {
super(clientConfigFactory, regionProvider);
}
/**
* @return The {@link ExecutorFactory} currently configured by the client.
*/
public final ExecutorFactory getExecutorFactory() {
return executorFactory;
}
/**
* Sets a custom executor service factory to use for the async clients. The factory will be
* called for each async client created through the builder.
*
* @param executorFactory Factory supplying new instances of {@link ExecutorService}
*/
public final void setExecutorFactory(ExecutorFactory executorFactory) {
this.executorFactory = executorFactory;
}
/**
* Sets a custom executor service factory to use for the async clients. The factory will be
* called for each async client created through the builder.
*
* @param executorFactory Factory supplying new instances of {@link ExecutorService}
* @return This object for method chaining.
*/
public final Subclass withExecutorFactory(ExecutorFactory executorFactory) {
setExecutorFactory(executorFactory);
return getSubclass();
}
@Override
public final TypeToBuild build() {
return configureMutableProperties(build(getAsyncClientParams()));
}
protected abstract TypeToBuild build(AwsAsyncClientParams asyncClientParams);
/**
* @return An instance of AwsAsyncClientParams that has all params to be used in the async
* client constructor.
*/
protected final AwsAsyncClientParams getAsyncClientParams() {
return new AsyncBuilderParams(executorFactory);
}
/**
* Presents a view of the builder to be used in the async client constructor.
*/
protected class AsyncBuilderParams extends SyncBuilderParams {
private final ExecutorService _executorService;
protected AsyncBuilderParams(ExecutorFactory executorFactory) {
this._executorService =
(executorFactory == null) ? defaultExecutor() : executorFactory.newExecutor();
}
@Override
public ExecutorService getExecutor() {
return this._executorService;
}
/**
* @return Default async Executor to use if none is explicitly provided by user.
*/
private ExecutorService defaultExecutor() {
return Executors.newFixedThreadPool(getClientConfiguration().getMaxConnections());
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy