software.amazon.awssdk.services.codecatalyst.endpoints.internal.DefaultCodeCatalystEndpointProvider Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of codecatalyst Show documentation
Show all versions of codecatalyst Show documentation
The AWS Java SDK for Code Catalyst module holds the client classes that are used for
communicating with Code Catalyst.
/*
* Copyright 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 software.amazon.awssdk.services.codecatalyst.endpoints.internal;
import java.net.URI;
import java.util.concurrent.CompletableFuture;
import software.amazon.awssdk.annotations.Generated;
import software.amazon.awssdk.annotations.SdkInternalApi;
import software.amazon.awssdk.core.exception.SdkClientException;
import software.amazon.awssdk.endpoints.Endpoint;
import software.amazon.awssdk.regions.Region;
import software.amazon.awssdk.services.codecatalyst.endpoints.CodeCatalystEndpointParams;
import software.amazon.awssdk.services.codecatalyst.endpoints.CodeCatalystEndpointProvider;
import software.amazon.awssdk.utils.CompletableFutureUtils;
import software.amazon.awssdk.utils.Validate;
@Generated("software.amazon.awssdk:codegen")
@SdkInternalApi
public final class DefaultCodeCatalystEndpointProvider implements CodeCatalystEndpointProvider {
@Override
public CompletableFuture resolveEndpoint(CodeCatalystEndpointParams params) {
Validate.notNull(params.useFips(), "Parameter 'UseFIPS' must not be null");
try {
RuleResult result = endpointRule0(params, new LocalState(params.region()));
if (result.canContinue()) {
throw SdkClientException.create("Rule engine did not reach an error or endpoint result");
}
if (result.isError()) {
String errorMsg = result.error();
if (errorMsg.contains("Invalid ARN") && errorMsg.contains(":s3:::")) {
errorMsg += ". Use the bucket name instead of simple bucket ARNs in GetBucketLocationRequest.";
}
throw SdkClientException.create(errorMsg);
}
return CompletableFuture.completedFuture(result.endpoint());
} catch (Exception error) {
return CompletableFutureUtils.failedFuture(error);
}
}
private static RuleResult endpointRule0(CodeCatalystEndpointParams params, LocalState locals) {
RuleResult result = endpointRule1(params, locals);
if (result.isResolved()) {
return result;
}
result = endpointRule2(params, locals);
if (result.isResolved()) {
return result;
}
return endpointRule7(params, locals);
}
private static RuleResult endpointRule1(CodeCatalystEndpointParams params, LocalState locals) {
if (params.endpoint() != null) {
return RuleResult.endpoint(Endpoint.builder().url(URI.create(params.endpoint())).build());
}
return RuleResult.carryOn();
}
private static RuleResult endpointRule2(CodeCatalystEndpointParams params, LocalState locals) {
if (locals.region() == null) {
RulePartition partitionResult = null;
if ((partitionResult = RulesFunctions.awsPartition("us-west-2")) != null) {
locals = locals.toBuilder().partitionResult(partitionResult).build();
RuleResult result = endpointRule3(params, locals);
if (result.isResolved()) {
return result;
}
return endpointRule6(params, locals);
}
}
return RuleResult.carryOn();
}
private static RuleResult endpointRule3(CodeCatalystEndpointParams params, LocalState locals) {
if (params.useFips()) {
RuleResult result = endpointRule4(params, locals);
if (result.isResolved()) {
return result;
}
return endpointRule5(params, locals);
}
return RuleResult.carryOn();
}
private static RuleResult endpointRule4(CodeCatalystEndpointParams params, LocalState locals) {
if (!locals.partitionResult().supportsFIPS()) {
return RuleResult.error("Partition does not support FIPS.");
}
return RuleResult.carryOn();
}
private static RuleResult endpointRule5(CodeCatalystEndpointParams params, LocalState locals) {
return RuleResult.endpoint(Endpoint.builder()
.url(URI.create("https://codecatalyst-fips.global." + locals.partitionResult().dualStackDnsSuffix())).build());
}
private static RuleResult endpointRule6(CodeCatalystEndpointParams params, LocalState locals) {
return RuleResult.endpoint(Endpoint.builder()
.url(URI.create("https://codecatalyst.global." + locals.partitionResult().dualStackDnsSuffix())).build());
}
private static RuleResult endpointRule7(CodeCatalystEndpointParams params, LocalState locals) {
if (locals.region() != null) {
RulePartition partitionResult = null;
if ((partitionResult = RulesFunctions.awsPartition(locals.region())) != null) {
locals = locals.toBuilder().partitionResult(partitionResult).build();
RuleResult result = endpointRule8(params, locals);
if (result.isResolved()) {
return result;
}
return endpointRule11(params, locals);
}
}
return RuleResult.carryOn();
}
private static RuleResult endpointRule8(CodeCatalystEndpointParams params, LocalState locals) {
if (params.useFips()) {
RuleResult result = endpointRule9(params, locals);
if (result.isResolved()) {
return result;
}
return endpointRule10(params, locals);
}
return RuleResult.carryOn();
}
private static RuleResult endpointRule9(CodeCatalystEndpointParams params, LocalState locals) {
if (!locals.partitionResult().supportsFIPS()) {
return RuleResult.error("Partition does not support FIPS.");
}
return RuleResult.carryOn();
}
private static RuleResult endpointRule10(CodeCatalystEndpointParams params, LocalState locals) {
return RuleResult.endpoint(Endpoint.builder()
.url(URI.create("https://codecatalyst-fips.global." + locals.partitionResult().dualStackDnsSuffix())).build());
}
private static RuleResult endpointRule11(CodeCatalystEndpointParams params, LocalState locals) {
return RuleResult.endpoint(Endpoint.builder()
.url(URI.create("https://codecatalyst.global." + locals.partitionResult().dualStackDnsSuffix())).build());
}
@Override
public boolean equals(Object rhs) {
return rhs != null && getClass().equals(rhs.getClass());
}
@Override
public int hashCode() {
return getClass().hashCode();
}
private static final class LocalState {
private final String region;
private final RulePartition partitionResult;
LocalState() {
this.region = null;
this.partitionResult = null;
}
LocalState(Region region) {
if (region != null) {
this.region = region.id();
} else {
this.region = null;
}
this.partitionResult = null;
}
LocalState(LocalStateBuilder builder) {
this.region = builder.region;
this.partitionResult = builder.partitionResult;
}
public String region() {
return this.region;
}
public RulePartition partitionResult() {
return this.partitionResult;
}
public LocalStateBuilder toBuilder() {
return new LocalStateBuilder(this);
}
}
private static final class LocalStateBuilder {
private String region;
private RulePartition partitionResult;
LocalStateBuilder() {
this.region = null;
this.partitionResult = null;
}
LocalStateBuilder(LocalState locals) {
this.region = locals.region;
this.partitionResult = locals.partitionResult;
}
public LocalStateBuilder region(String value) {
this.region = value;
return this;
}
public LocalStateBuilder partitionResult(RulePartition value) {
this.partitionResult = value;
return this;
}
LocalState build() {
return new LocalState(this);
}
}
}