CfnBucketPolicyPropsMixin
- class aws_cdk.mixins_preview.aws_s3.mixins.CfnBucketPolicyPropsMixin(props, *, strategy=None)
Bases:
MixinApplies an Amazon S3 bucket policy to an Amazon S3 bucket.
If you are using an identity other than the root user of the AWS account that owns the bucket, the calling identity must have the
PutBucketPolicypermissions on the specified bucket and belong to the bucket owner’s account in order to use this operation.If you don’t have
PutBucketPolicypermissions, Amazon S3 returns a403 Access Deniederror. If you have the correct permissions, but you’re not using an identity that belongs to the bucket owner’s account, Amazon S3 returns a405 Method Not Allowederror. .. epigraph:As a security precaution, the root user of the AWS account that owns a bucket can always use this operation, even if the policy explicitly denies the root user the ability to perform this action.
When using the
AWS::S3::BucketPolicyresource, you can create, update, and delete bucket policies for S3 buckets located in Regions that are different from the stack’s Region. However, the CloudFormation stacks should be deployed in the US East (N. Virginia) orus-east-1Region. This cross-region bucket policy modification functionality is supported for backward compatibility with existing workflows. .. epigraph:If the `DeletionPolicy attribute <https://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-attribute-deletionpolicy.html>`_ is not specified or set to ``Delete`` , the bucket policy will be removed when the stack is deleted. If set to ``Retain`` , the bucket policy will be preserved even after the stack is deleted.
For example, a CloudFormation stack in
us-east-1can use theAWS::S3::BucketPolicyresource to manage the bucket policy for an S3 bucket inus-west-2. The retention or removal of the bucket policy during the stack deletion is determined by theDeletionPolicyattribute specified in the stack template.For more information, see Bucket policy examples .
The following operations are related to
PutBucketPolicy:- See:
http://docs.aws.amazon.com/AWSCloudFormation/latest/UserGuide/aws-resource-s3-bucketpolicy.html
- CloudformationResource:
AWS::S3::BucketPolicy
- Mixin:
true
- ExampleMetadata:
fixture=_generated
Example:
# The code below shows an example of how to instantiate this type. # The values are placeholders you should change. from aws_cdk.mixins_preview import mixins from aws_cdk.mixins_preview.aws_s3 import mixins as s3_mixins # policy_document: Any cfn_bucket_policy_props_mixin = s3_mixins.CfnBucketPolicyPropsMixin(s3_mixins.CfnBucketPolicyMixinProps( bucket="bucket", policy_document=policy_document ), strategy=mixins.PropertyMergeStrategy.OVERRIDE )
Create a mixin to apply properties to
AWS::S3::BucketPolicy.- Parameters:
props (
Union[CfnBucketPolicyMixinProps,Dict[str,Any]]) – L1 properties to apply.strategy (
Optional[PropertyMergeStrategy]) – (experimental) Strategy for merging nested properties. Default: - PropertyMergeStrategy.MERGE
Methods
- apply_to(construct)
Apply the mixin properties to the construct.
- Parameters:
construct (
IConstruct)- Return type:
- supports(construct)
Check if this mixin supports the given construct.
- Parameters:
construct (
IConstruct)- Return type:
bool
Attributes
- CFN_PROPERTY_KEYS = ['bucket', 'policyDocument']
Static Methods
- classmethod is_mixin(x)
(experimental) Checks if
xis a Mixin.- Parameters:
x (
Any) – Any object.- Return type:
bool- Returns:
true if
xis an object created from a class which extendsMixin.- Stability:
experimental