python-boto3/docs/source/guide/s3-example-configuring-buckets.rst
2022-05-25 16:13:54 -07:00

80 lines
2.7 KiB
ReStructuredText

.. Copyright 2010-2019 Amazon.com, Inc. or its affiliates. All Rights Reserved.
This work is licensed under a Creative Commons Attribution-NonCommercial-ShareAlike 4.0
International License (the "License"). You may not use this file except in compliance with the
License. A copy of the License is located at http://creativecommons.org/licenses/by-nc-sa/4.0/.
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.
#########################
Bucket CORS configuration
#########################
Cross Origin Resource Sharing (CORS) enables client web applications in one
domain to access resources in another domain. An S3 bucket can be configured
to enable cross-origin requests. The configuration defines rules that specify
the allowed origins, HTTP methods (GET, PUT, etc.), and other elements.
Retrieve a bucket CORS configuration
====================================
Retrieve a bucket's CORS configuration by calling the AWS SDK for Python
``get_bucket_cors`` method.
.. code-block:: python
import logging
import boto3
from botocore.exceptions import ClientError
def get_bucket_cors(bucket_name):
"""Retrieve the CORS configuration rules of an Amazon S3 bucket
:param bucket_name: string
:return: List of the bucket's CORS configuration rules. If no CORS
configuration exists, return empty list. If error, return None.
"""
# Retrieve the CORS configuration
s3 = boto3.client('s3')
try:
response = s3.get_bucket_cors(Bucket=bucket_name)
except ClientError as e:
if e.response['Error']['Code'] == 'NoSuchCORSConfiguration':
return []
else:
# AllAccessDisabled error == bucket not found
logging.error(e)
return None
return response['CORSRules']
Set a bucket CORS configuration
===============================
A bucket's CORS configuration can be set by calling the ``put_bucket_cors``
method.
.. code-block:: python
# Define the configuration rules
cors_configuration = {
'CORSRules': [{
'AllowedHeaders': ['Authorization'],
'AllowedMethods': ['GET', 'PUT'],
'AllowedOrigins': ['*'],
'ExposeHeaders': ['ETag', 'x-amz-request-id'],
'MaxAgeSeconds': 3000
}]
}
# Set the CORS configuration
s3 = boto3.client('s3')
s3.put_bucket_cors(Bucket='BUCKET_NAME',
CORSConfiguration=cors_configuration)