/*
* 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.
*/
/*
* Do not modify this file. This file is generated from the s3control-2018-08-20.normal.json service model.
*/
using System;
using System.Collections.Generic;
using Amazon.Runtime;
using Amazon.Runtime.Endpoints;
using static Amazon.Runtime.Internal.Endpoints.StandardLibrary.Fn;
namespace Amazon.S3Control.Internal
{
///
/// Amazon S3Control endpoint provider.
/// Resolves endpoint for given set of S3ControlEndpointParameters.
/// Can throw AmazonClientException if endpoint resolution is unsuccessful.
///
public class AmazonS3ControlEndpointProvider : IEndpointProvider
{
///
/// Resolve endpoint for S3ControlEndpointParameters
///
public Endpoint ResolveEndpoint(EndpointParameters parameters)
{
if (parameters == null)
throw new ArgumentNullException("parameters");
if (parameters["UseFIPS"] == null)
throw new AmazonClientException("UseFIPS parameter must be set for endpoint resolution");
if (parameters["UseDualStack"] == null)
throw new AmazonClientException("UseDualStack parameter must be set for endpoint resolution");
var refs = new Dictionary()
{
["Region"] = parameters["Region"],
["UseFIPS"] = parameters["UseFIPS"],
["UseDualStack"] = parameters["UseDualStack"],
["Endpoint"] = parameters["Endpoint"],
["AccountId"] = parameters["AccountId"],
["RequiresAccountId"] = parameters["RequiresAccountId"],
["OutpostId"] = parameters["OutpostId"],
["Bucket"] = parameters["Bucket"],
["AccessPointName"] = parameters["AccessPointName"],
["UseArnRegion"] = parameters["UseArnRegion"],
};
if (IsSet(refs["Region"]))
{
if (Equals(refs["Region"], "snow") && IsSet(refs["Endpoint"]) && (refs["url"] = ParseURL((string)refs["Endpoint"])) != null)
{
if ((refs["partitionResult"] = Partition((string)refs["Region"])) != null)
{
if (Equals(refs["UseDualStack"], true))
{
throw new AmazonClientException("S3 Snow does not support Dual-stack");
}
if (Equals(refs["UseFIPS"], true))
{
throw new AmazonClientException("S3 Snow does not support FIPS");
}
return new Endpoint(Interpolate(@"{url#scheme}://{url#authority}", refs), InterpolateJson(@"{""authSchemes"":[{""disableDoubleEncoding"":true,""name"":""sigv4"",""signingName"":""s3"",""signingRegion"":""{Region}""}]}", refs), InterpolateJson(@"", refs));
}
throw new AmazonClientException("A valid partition could not be determined");
}
if (IsSet(refs["OutpostId"]))
{
if ((refs["partitionResult"] = Partition((string)refs["Region"])) != null)
{
if (Equals(refs["UseFIPS"], true) && Equals(GetAttr(refs["partitionResult"], "name"), "aws-cn"))
{
throw new AmazonClientException("Partition does not support FIPS");
}
if (IsSet(refs["RequiresAccountId"]) && Equals(refs["RequiresAccountId"], true) && !IsSet(refs["AccountId"]))
{
throw new AmazonClientException("AccountId is required but not set");
}
if (IsSet(refs["AccountId"]) && !IsValidHostLabel((string)refs["AccountId"], false))
{
throw new AmazonClientException("AccountId must only contain a-z, A-Z, 0-9 and `-`.");
}
if (!IsValidHostLabel((string)refs["OutpostId"], false))
{
throw new AmazonClientException("OutpostId must only contain a-z, A-Z, 0-9 and `-`.");
}
if (IsValidHostLabel((string)refs["Region"], true))
{
if (Equals(refs["UseDualStack"], true))
{
throw new AmazonClientException("Invalid configuration: Outposts do not support dual-stack");
}
if (IsSet(refs["Endpoint"]) && (refs["url"] = ParseURL((string)refs["Endpoint"])) != null)
{
return new Endpoint(Interpolate(@"{url#scheme}://{url#authority}{url#path}", refs), InterpolateJson(@"{""authSchemes"":[{""disableDoubleEncoding"":true,""name"":""sigv4"",""signingName"":""s3-outposts"",""signingRegion"":""{Region}""}]}", refs), InterpolateJson(@"", refs));
}
if (Equals(refs["UseFIPS"], true))
{
return new Endpoint(Interpolate(@"https://s3-outposts-fips.{Region}.{partitionResult#dnsSuffix}", refs), InterpolateJson(@"{""authSchemes"":[{""disableDoubleEncoding"":true,""name"":""sigv4"",""signingName"":""s3-outposts"",""signingRegion"":""{Region}""}]}", refs), InterpolateJson(@"", refs));
}
return new Endpoint(Interpolate(@"https://s3-outposts.{Region}.{partitionResult#dnsSuffix}", refs), InterpolateJson(@"{""authSchemes"":[{""disableDoubleEncoding"":true,""name"":""sigv4"",""signingName"":""s3-outposts"",""signingRegion"":""{Region}""}]}", refs), InterpolateJson(@"", refs));
}
throw new AmazonClientException("Invalid region: region was not a valid DNS name.");
}
throw new AmazonClientException("A valid partition could not be determined");
}
if (IsSet(refs["AccessPointName"]) && (refs["accessPointArn"] = ParseArn((string)refs["AccessPointName"])) != null)
{
if ((refs["arnType"] = GetAttr(refs["accessPointArn"], "resourceId[0]")) != null && !Equals(refs["arnType"], ""))
{
if (Equals(GetAttr(refs["accessPointArn"], "service"), "s3-outposts"))
{
if (Equals(refs["UseDualStack"], true))
{
throw new AmazonClientException("Invalid configuration: Outpost Access Points do not support dual-stack");
}
if ((refs["outpostId"] = GetAttr(refs["accessPointArn"], "resourceId[1]")) != null)
{
if (IsValidHostLabel((string)refs["outpostId"], false))
{
if (IsSet(refs["UseArnRegion"]) && Equals(refs["UseArnRegion"], false) && !Equals(GetAttr(refs["accessPointArn"], "region"), Interpolate(@"{Region}", refs)))
{
throw new AmazonClientException(Interpolate(@"Invalid configuration: region from ARN `{accessPointArn#region}` does not match client region `{Region}` and UseArnRegion is `false`", refs));
}
if ((refs["partitionResult"] = Partition((string)refs["Region"])) != null)
{
if ((refs["arnPartition"] = Partition((string)GetAttr(refs["accessPointArn"], "region"))) != null)
{
if (Equals(GetAttr(refs["arnPartition"], "name"), GetAttr(refs["partitionResult"], "name")))
{
if (IsValidHostLabel((string)GetAttr(refs["accessPointArn"], "region"), true))
{
if (!Equals(GetAttr(refs["accessPointArn"], "accountId"), ""))
{
if (IsValidHostLabel((string)GetAttr(refs["accessPointArn"], "accountId"), false))
{
if (IsSet(refs["AccountId"]) && !Equals(refs["AccountId"], Interpolate(@"{accessPointArn#accountId}", refs)))
{
throw new AmazonClientException(Interpolate(@"Invalid ARN: the accountId specified in the ARN (`{accessPointArn#accountId}`) does not match the parameter (`{AccountId}`)", refs));
}
if ((refs["outpostType"] = GetAttr(refs["accessPointArn"], "resourceId[2]")) != null)
{
if ((refs["accessPointName"] = GetAttr(refs["accessPointArn"], "resourceId[3]")) != null)
{
if (Equals(refs["outpostType"], "accesspoint"))
{
if (Equals(refs["UseFIPS"], true))
{
return new Endpoint(Interpolate(@"https://s3-outposts-fips.{accessPointArn#region}.{arnPartition#dnsSuffix}", refs), InterpolateJson(@"{""authSchemes"":[{""disableDoubleEncoding"":true,""name"":""sigv4"",""signingName"":""s3-outposts"",""signingRegion"":""{accessPointArn#region}""}]}", refs), InterpolateJson(@"{""x-amz-account-id"":[""{accessPointArn#accountId}""],""x-amz-outpost-id"":[""{outpostId}""]}", refs));
}
if (IsSet(refs["Endpoint"]) && (refs["url"] = ParseURL((string)refs["Endpoint"])) != null)
{
return new Endpoint(Interpolate(@"{url#scheme}://{url#authority}{url#path}", refs), InterpolateJson(@"{""authSchemes"":[{""disableDoubleEncoding"":true,""name"":""sigv4"",""signingName"":""s3-outposts"",""signingRegion"":""{accessPointArn#region}""}]}", refs), InterpolateJson(@"{""x-amz-account-id"":[""{accessPointArn#accountId}""],""x-amz-outpost-id"":[""{outpostId}""]}", refs));
}
return new Endpoint(Interpolate(@"https://s3-outposts.{accessPointArn#region}.{arnPartition#dnsSuffix}", refs), InterpolateJson(@"{""authSchemes"":[{""disableDoubleEncoding"":true,""name"":""sigv4"",""signingName"":""s3-outposts"",""signingRegion"":""{accessPointArn#region}""}]}", refs), InterpolateJson(@"{""x-amz-account-id"":[""{accessPointArn#accountId}""],""x-amz-outpost-id"":[""{outpostId}""]}", refs));
}
throw new AmazonClientException(Interpolate(@"Expected an outpost type `accesspoint`, found `{outpostType}`", refs));
}
throw new AmazonClientException("Invalid ARN: expected an access point name");
}
throw new AmazonClientException("Invalid ARN: Expected a 4-component resource");
}
throw new AmazonClientException(Interpolate(@"Invalid ARN: The account id may only contain a-z, A-Z, 0-9 and `-`. Found: `{accessPointArn#accountId}`", refs));
}
throw new AmazonClientException("Invalid ARN: missing account ID");
}
throw new AmazonClientException(Interpolate(@"Invalid region in ARN: `{accessPointArn#region}` (invalid DNS name)", refs));
}
throw new AmazonClientException(Interpolate(@"Client was configured for partition `{partitionResult#name}` but ARN has `{arnPartition#name}`", refs));
}
throw new AmazonClientException(Interpolate(@"Could not load partition for ARN region `{accessPointArn#region}`", refs));
}
throw new AmazonClientException("A valid partition could not be determined");
}
throw new AmazonClientException(Interpolate(@"Invalid ARN: The outpost Id must only contain a-z, A-Z, 0-9 and `-`., found: `{outpostId}`", refs));
}
throw new AmazonClientException("Invalid ARN: The Outpost Id was not set");
}
}
throw new AmazonClientException("Invalid ARN: No ARN type specified");
}
if (IsSet(refs["Bucket"]) && (refs["bucketArn"] = ParseArn((string)refs["Bucket"])) != null)
{
if ((refs["arnType"] = GetAttr(refs["bucketArn"], "resourceId[0]")) != null && !Equals(refs["arnType"], ""))
{
if (Equals(GetAttr(refs["bucketArn"], "service"), "s3-outposts"))
{
if (Equals(refs["UseDualStack"], true))
{
throw new AmazonClientException("Invalid configuration: Outpost buckets do not support dual-stack");
}
if ((refs["outpostId"] = GetAttr(refs["bucketArn"], "resourceId[1]")) != null)
{
if (IsValidHostLabel((string)refs["outpostId"], false))
{
if (IsSet(refs["UseArnRegion"]) && Equals(refs["UseArnRegion"], false) && !Equals(GetAttr(refs["bucketArn"], "region"), Interpolate(@"{Region}", refs)))
{
throw new AmazonClientException(Interpolate(@"Invalid configuration: region from ARN `{bucketArn#region}` does not match client region `{Region}` and UseArnRegion is `false`", refs));
}
if ((refs["arnPartition"] = Partition((string)GetAttr(refs["bucketArn"], "region"))) != null)
{
if ((refs["partitionResult"] = Partition((string)refs["Region"])) != null)
{
if (Equals(GetAttr(refs["arnPartition"], "name"), GetAttr(refs["partitionResult"], "name")))
{
if (IsValidHostLabel((string)GetAttr(refs["bucketArn"], "region"), true))
{
if (!Equals(GetAttr(refs["bucketArn"], "accountId"), ""))
{
if (IsValidHostLabel((string)GetAttr(refs["bucketArn"], "accountId"), false))
{
if (IsSet(refs["AccountId"]) && !Equals(refs["AccountId"], Interpolate(@"{bucketArn#accountId}", refs)))
{
throw new AmazonClientException(Interpolate(@"Invalid ARN: the accountId specified in the ARN (`{bucketArn#accountId}`) does not match the parameter (`{AccountId}`)", refs));
}
if ((refs["outpostType"] = GetAttr(refs["bucketArn"], "resourceId[2]")) != null)
{
if ((refs["bucketName"] = GetAttr(refs["bucketArn"], "resourceId[3]")) != null)
{
if (Equals(refs["outpostType"], "bucket"))
{
if (Equals(refs["UseFIPS"], true))
{
return new Endpoint(Interpolate(@"https://s3-outposts-fips.{bucketArn#region}.{arnPartition#dnsSuffix}", refs), InterpolateJson(@"{""authSchemes"":[{""disableDoubleEncoding"":true,""name"":""sigv4"",""signingName"":""s3-outposts"",""signingRegion"":""{bucketArn#region}""}]}", refs), InterpolateJson(@"{""x-amz-account-id"":[""{bucketArn#accountId}""],""x-amz-outpost-id"":[""{outpostId}""]}", refs));
}
if (IsSet(refs["Endpoint"]) && (refs["url"] = ParseURL((string)refs["Endpoint"])) != null)
{
return new Endpoint(Interpolate(@"{url#scheme}://{url#authority}{url#path}", refs), InterpolateJson(@"{""authSchemes"":[{""disableDoubleEncoding"":true,""name"":""sigv4"",""signingName"":""s3-outposts"",""signingRegion"":""{bucketArn#region}""}]}", refs), InterpolateJson(@"{""x-amz-account-id"":[""{bucketArn#accountId}""],""x-amz-outpost-id"":[""{outpostId}""]}", refs));
}
return new Endpoint(Interpolate(@"https://s3-outposts.{bucketArn#region}.{arnPartition#dnsSuffix}", refs), InterpolateJson(@"{""authSchemes"":[{""disableDoubleEncoding"":true,""name"":""sigv4"",""signingName"":""s3-outposts"",""signingRegion"":""{bucketArn#region}""}]}", refs), InterpolateJson(@"{""x-amz-account-id"":[""{bucketArn#accountId}""],""x-amz-outpost-id"":[""{outpostId}""]}", refs));
}
throw new AmazonClientException(Interpolate(@"Invalid ARN: Expected an outpost type `bucket`, found `{outpostType}`", refs));
}
throw new AmazonClientException("Invalid ARN: expected a bucket name");
}
throw new AmazonClientException("Invalid ARN: Expected a 4-component resource");
}
throw new AmazonClientException(Interpolate(@"Invalid ARN: The account id may only contain a-z, A-Z, 0-9 and `-`. Found: `{bucketArn#accountId}`", refs));
}
throw new AmazonClientException("Invalid ARN: missing account ID");
}
throw new AmazonClientException(Interpolate(@"Invalid region in ARN: `{bucketArn#region}` (invalid DNS name)", refs));
}
throw new AmazonClientException(Interpolate(@"Client was configured for partition `{partitionResult#name}` but ARN has `{arnPartition#name}`", refs));
}
throw new AmazonClientException("A valid partition could not be determined");
}
throw new AmazonClientException(Interpolate(@"Could not load partition for ARN region `{bucketArn#region}`", refs));
}
throw new AmazonClientException(Interpolate(@"Invalid ARN: The outpost Id must only contain a-z, A-Z, 0-9 and `-`., found: `{outpostId}`", refs));
}
throw new AmazonClientException("Invalid ARN: The Outpost Id was not set");
}
}
throw new AmazonClientException("Invalid ARN: No ARN type specified");
}
if ((refs["partitionResult"] = Partition((string)refs["Region"])) != null)
{
if (IsValidHostLabel((string)refs["Region"], true))
{
if (Equals(refs["UseFIPS"], true) && Equals(GetAttr(refs["partitionResult"], "name"), "aws-cn"))
{
throw new AmazonClientException("Partition does not support FIPS");
}
if (IsSet(refs["RequiresAccountId"]) && Equals(refs["RequiresAccountId"], true) && !IsSet(refs["AccountId"]))
{
throw new AmazonClientException("AccountId is required but not set");
}
if (IsSet(refs["AccountId"]) && !IsValidHostLabel((string)refs["AccountId"], false))
{
throw new AmazonClientException("AccountId must only contain a-z, A-Z, 0-9 and `-`.");
}
if (IsSet(refs["Endpoint"]) && (refs["url"] = ParseURL((string)refs["Endpoint"])) != null)
{
if (Equals(refs["UseDualStack"], true))
{
throw new AmazonClientException("Invalid Configuration: Dualstack and custom endpoint are not supported");
}
if (IsSet(refs["RequiresAccountId"]) && Equals(refs["RequiresAccountId"], true) && IsSet(refs["AccountId"]))
{
return new Endpoint(Interpolate(@"{url#scheme}://{AccountId}.{url#authority}{url#path}", refs), InterpolateJson(@"{""authSchemes"":[{""disableDoubleEncoding"":true,""name"":""sigv4"",""signingName"":""s3"",""signingRegion"":""{Region}""}]}", refs), InterpolateJson(@"", refs));
}
return new Endpoint(Interpolate(@"{url#scheme}://{url#authority}{url#path}", refs), InterpolateJson(@"{""authSchemes"":[{""disableDoubleEncoding"":true,""name"":""sigv4"",""signingName"":""s3"",""signingRegion"":""{Region}""}]}", refs), InterpolateJson(@"", refs));
}
if (Equals(refs["UseFIPS"], true) && Equals(refs["UseDualStack"], true) && IsSet(refs["RequiresAccountId"]) && Equals(refs["RequiresAccountId"], true) && IsSet(refs["AccountId"]))
{
return new Endpoint(Interpolate(@"https://{AccountId}.s3-control-fips.dualstack.{Region}.{partitionResult#dnsSuffix}", refs), InterpolateJson(@"{""authSchemes"":[{""disableDoubleEncoding"":true,""name"":""sigv4"",""signingName"":""s3"",""signingRegion"":""{Region}""}]}", refs), InterpolateJson(@"", refs));
}
if (Equals(refs["UseFIPS"], true) && Equals(refs["UseDualStack"], true))
{
return new Endpoint(Interpolate(@"https://s3-control-fips.dualstack.{Region}.{partitionResult#dnsSuffix}", refs), InterpolateJson(@"{""authSchemes"":[{""disableDoubleEncoding"":true,""name"":""sigv4"",""signingName"":""s3"",""signingRegion"":""{Region}""}]}", refs), InterpolateJson(@"", refs));
}
if (Equals(refs["UseFIPS"], true) && Equals(refs["UseDualStack"], false) && IsSet(refs["RequiresAccountId"]) && Equals(refs["RequiresAccountId"], true) && IsSet(refs["AccountId"]))
{
return new Endpoint(Interpolate(@"https://{AccountId}.s3-control-fips.{Region}.{partitionResult#dnsSuffix}", refs), InterpolateJson(@"{""authSchemes"":[{""disableDoubleEncoding"":true,""name"":""sigv4"",""signingName"":""s3"",""signingRegion"":""{Region}""}]}", refs), InterpolateJson(@"", refs));
}
if (Equals(refs["UseFIPS"], true) && Equals(refs["UseDualStack"], false))
{
return new Endpoint(Interpolate(@"https://s3-control-fips.{Region}.{partitionResult#dnsSuffix}", refs), InterpolateJson(@"{""authSchemes"":[{""disableDoubleEncoding"":true,""name"":""sigv4"",""signingName"":""s3"",""signingRegion"":""{Region}""}]}", refs), InterpolateJson(@"", refs));
}
if (Equals(refs["UseFIPS"], false) && Equals(refs["UseDualStack"], true) && IsSet(refs["RequiresAccountId"]) && Equals(refs["RequiresAccountId"], true) && IsSet(refs["AccountId"]))
{
return new Endpoint(Interpolate(@"https://{AccountId}.s3-control.dualstack.{Region}.{partitionResult#dnsSuffix}", refs), InterpolateJson(@"{""authSchemes"":[{""disableDoubleEncoding"":true,""name"":""sigv4"",""signingName"":""s3"",""signingRegion"":""{Region}""}]}", refs), InterpolateJson(@"", refs));
}
if (Equals(refs["UseFIPS"], false) && Equals(refs["UseDualStack"], true))
{
return new Endpoint(Interpolate(@"https://s3-control.dualstack.{Region}.{partitionResult#dnsSuffix}", refs), InterpolateJson(@"{""authSchemes"":[{""disableDoubleEncoding"":true,""name"":""sigv4"",""signingName"":""s3"",""signingRegion"":""{Region}""}]}", refs), InterpolateJson(@"", refs));
}
if (Equals(refs["UseFIPS"], false) && Equals(refs["UseDualStack"], false) && IsSet(refs["RequiresAccountId"]) && Equals(refs["RequiresAccountId"], true) && IsSet(refs["AccountId"]))
{
return new Endpoint(Interpolate(@"https://{AccountId}.s3-control.{Region}.{partitionResult#dnsSuffix}", refs), InterpolateJson(@"{""authSchemes"":[{""disableDoubleEncoding"":true,""name"":""sigv4"",""signingName"":""s3"",""signingRegion"":""{Region}""}]}", refs), InterpolateJson(@"", refs));
}
if (Equals(refs["UseFIPS"], false) && Equals(refs["UseDualStack"], false))
{
return new Endpoint(Interpolate(@"https://s3-control.{Region}.{partitionResult#dnsSuffix}", refs), InterpolateJson(@"{""authSchemes"":[{""disableDoubleEncoding"":true,""name"":""sigv4"",""signingName"":""s3"",""signingRegion"":""{Region}""}]}", refs), InterpolateJson(@"", refs));
}
}
throw new AmazonClientException("Invalid region: region was not a valid DNS name.");
}
throw new AmazonClientException("A valid partition could not be determined");
}
throw new AmazonClientException("Region must be set");
throw new AmazonClientException("Cannot resolve endpoint");
}
}
}