/** * Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved. * SPDX-License-Identifier: Apache-2.0. */ #pragma once #include #include #include namespace Aws { namespace Utils { namespace Xml { class XmlNode; } // namespace Xml } // namespace Utils namespace CloudFront { namespace Model { /** *

A complex type that contains information about the Amazon S3 bucket from * which you want CloudFront to get your media files for * distribution.

See Also:

AWS * API Reference

*/ class S3Origin { public: AWS_CLOUDFRONT_API S3Origin(); AWS_CLOUDFRONT_API S3Origin(const Aws::Utils::Xml::XmlNode& xmlNode); AWS_CLOUDFRONT_API S3Origin& operator=(const Aws::Utils::Xml::XmlNode& xmlNode); AWS_CLOUDFRONT_API void AddToNode(Aws::Utils::Xml::XmlNode& parentNode) const; /** *

The DNS name of the Amazon S3 origin.

*/ inline const Aws::String& GetDomainName() const{ return m_domainName; } /** *

The DNS name of the Amazon S3 origin.

*/ inline bool DomainNameHasBeenSet() const { return m_domainNameHasBeenSet; } /** *

The DNS name of the Amazon S3 origin.

*/ inline void SetDomainName(const Aws::String& value) { m_domainNameHasBeenSet = true; m_domainName = value; } /** *

The DNS name of the Amazon S3 origin.

*/ inline void SetDomainName(Aws::String&& value) { m_domainNameHasBeenSet = true; m_domainName = std::move(value); } /** *

The DNS name of the Amazon S3 origin.

*/ inline void SetDomainName(const char* value) { m_domainNameHasBeenSet = true; m_domainName.assign(value); } /** *

The DNS name of the Amazon S3 origin.

*/ inline S3Origin& WithDomainName(const Aws::String& value) { SetDomainName(value); return *this;} /** *

The DNS name of the Amazon S3 origin.

*/ inline S3Origin& WithDomainName(Aws::String&& value) { SetDomainName(std::move(value)); return *this;} /** *

The DNS name of the Amazon S3 origin.

*/ inline S3Origin& WithDomainName(const char* value) { SetDomainName(value); return *this;} /** *

The CloudFront origin access identity to associate with the distribution. Use * an origin access identity to configure the distribution so that end users can * only access objects in an Amazon S3 bucket through CloudFront.

If you * want end users to be able to access objects using either the CloudFront URL or * the Amazon S3 URL, specify an empty OriginAccessIdentity * element.

To delete the origin access identity from an existing * distribution, update the distribution configuration and include an empty * OriginAccessIdentity element.

To replace the origin access * identity, update the distribution configuration and specify the new origin * access identity.

For more information, see Using * an Origin Access Identity to Restrict Access to Your Amazon S3 Content in * the Amazon CloudFront Developer Guide.

*/ inline const Aws::String& GetOriginAccessIdentity() const{ return m_originAccessIdentity; } /** *

The CloudFront origin access identity to associate with the distribution. Use * an origin access identity to configure the distribution so that end users can * only access objects in an Amazon S3 bucket through CloudFront.

If you * want end users to be able to access objects using either the CloudFront URL or * the Amazon S3 URL, specify an empty OriginAccessIdentity * element.

To delete the origin access identity from an existing * distribution, update the distribution configuration and include an empty * OriginAccessIdentity element.

To replace the origin access * identity, update the distribution configuration and specify the new origin * access identity.

For more information, see Using * an Origin Access Identity to Restrict Access to Your Amazon S3 Content in * the Amazon CloudFront Developer Guide.

*/ inline bool OriginAccessIdentityHasBeenSet() const { return m_originAccessIdentityHasBeenSet; } /** *

The CloudFront origin access identity to associate with the distribution. Use * an origin access identity to configure the distribution so that end users can * only access objects in an Amazon S3 bucket through CloudFront.

If you * want end users to be able to access objects using either the CloudFront URL or * the Amazon S3 URL, specify an empty OriginAccessIdentity * element.

To delete the origin access identity from an existing * distribution, update the distribution configuration and include an empty * OriginAccessIdentity element.

To replace the origin access * identity, update the distribution configuration and specify the new origin * access identity.

For more information, see Using * an Origin Access Identity to Restrict Access to Your Amazon S3 Content in * the Amazon CloudFront Developer Guide.

*/ inline void SetOriginAccessIdentity(const Aws::String& value) { m_originAccessIdentityHasBeenSet = true; m_originAccessIdentity = value; } /** *

The CloudFront origin access identity to associate with the distribution. Use * an origin access identity to configure the distribution so that end users can * only access objects in an Amazon S3 bucket through CloudFront.

If you * want end users to be able to access objects using either the CloudFront URL or * the Amazon S3 URL, specify an empty OriginAccessIdentity * element.

To delete the origin access identity from an existing * distribution, update the distribution configuration and include an empty * OriginAccessIdentity element.

To replace the origin access * identity, update the distribution configuration and specify the new origin * access identity.

For more information, see Using * an Origin Access Identity to Restrict Access to Your Amazon S3 Content in * the Amazon CloudFront Developer Guide.

*/ inline void SetOriginAccessIdentity(Aws::String&& value) { m_originAccessIdentityHasBeenSet = true; m_originAccessIdentity = std::move(value); } /** *

The CloudFront origin access identity to associate with the distribution. Use * an origin access identity to configure the distribution so that end users can * only access objects in an Amazon S3 bucket through CloudFront.

If you * want end users to be able to access objects using either the CloudFront URL or * the Amazon S3 URL, specify an empty OriginAccessIdentity * element.

To delete the origin access identity from an existing * distribution, update the distribution configuration and include an empty * OriginAccessIdentity element.

To replace the origin access * identity, update the distribution configuration and specify the new origin * access identity.

For more information, see Using * an Origin Access Identity to Restrict Access to Your Amazon S3 Content in * the Amazon CloudFront Developer Guide.

*/ inline void SetOriginAccessIdentity(const char* value) { m_originAccessIdentityHasBeenSet = true; m_originAccessIdentity.assign(value); } /** *

The CloudFront origin access identity to associate with the distribution. Use * an origin access identity to configure the distribution so that end users can * only access objects in an Amazon S3 bucket through CloudFront.

If you * want end users to be able to access objects using either the CloudFront URL or * the Amazon S3 URL, specify an empty OriginAccessIdentity * element.

To delete the origin access identity from an existing * distribution, update the distribution configuration and include an empty * OriginAccessIdentity element.

To replace the origin access * identity, update the distribution configuration and specify the new origin * access identity.

For more information, see Using * an Origin Access Identity to Restrict Access to Your Amazon S3 Content in * the Amazon CloudFront Developer Guide.

*/ inline S3Origin& WithOriginAccessIdentity(const Aws::String& value) { SetOriginAccessIdentity(value); return *this;} /** *

The CloudFront origin access identity to associate with the distribution. Use * an origin access identity to configure the distribution so that end users can * only access objects in an Amazon S3 bucket through CloudFront.

If you * want end users to be able to access objects using either the CloudFront URL or * the Amazon S3 URL, specify an empty OriginAccessIdentity * element.

To delete the origin access identity from an existing * distribution, update the distribution configuration and include an empty * OriginAccessIdentity element.

To replace the origin access * identity, update the distribution configuration and specify the new origin * access identity.

For more information, see Using * an Origin Access Identity to Restrict Access to Your Amazon S3 Content in * the Amazon CloudFront Developer Guide.

*/ inline S3Origin& WithOriginAccessIdentity(Aws::String&& value) { SetOriginAccessIdentity(std::move(value)); return *this;} /** *

The CloudFront origin access identity to associate with the distribution. Use * an origin access identity to configure the distribution so that end users can * only access objects in an Amazon S3 bucket through CloudFront.

If you * want end users to be able to access objects using either the CloudFront URL or * the Amazon S3 URL, specify an empty OriginAccessIdentity * element.

To delete the origin access identity from an existing * distribution, update the distribution configuration and include an empty * OriginAccessIdentity element.

To replace the origin access * identity, update the distribution configuration and specify the new origin * access identity.

For more information, see Using * an Origin Access Identity to Restrict Access to Your Amazon S3 Content in * the Amazon CloudFront Developer Guide.

*/ inline S3Origin& WithOriginAccessIdentity(const char* value) { SetOriginAccessIdentity(value); return *this;} private: Aws::String m_domainName; bool m_domainNameHasBeenSet = false; Aws::String m_originAccessIdentity; bool m_originAccessIdentityHasBeenSet = false; }; } // namespace Model } // namespace CloudFront } // namespace Aws