Addons

Amazon CloudFront

Updated: December 17, 2024

The CloudFrontBinaryManager is a Nuxeo Binary Manager that lets you store Nuxeo's binaries in an Amazon S3 bucket and lets you download them from an Amazon CloudFront CDN using signed URLs.

Before You Start

You should be familiar with:

Distribution Configuration

Serving S3 Content

Follow Using CloudFront with Amazon S3 documentation page to create a web distribution bound to S3.

Mandatory settings:

  • Restrict Bucket Access: true. Must be enabled to serve private content and sign URLs.

  • Query String Forwarding and Caching: whitelist.

    response-content-type
    response-content-disposition
    

To get correct response content-type and content-disposition headers.

  • Restrict Viewer Access: Yes. Requires signed URLs to access objects in the bucket.

Recommended settings in order to ease configuration:

  • Restrict Bucket Access: Yes. Restricts Bucket access to only CloudFront origin.

  • Origin Access Identity: Create a New Identity. Creates a dedicated Identity between the distribution and S3.

  • Grant Read Permissions on Bucket: Yes, Update Bucket Policy. Grants read permission to the selected Identity.

Nuxeo Configuration

In order to configure the package, you will need to provide values for the configuration parameters that define your S3 credentials bucket.

Assuming that you already have a bucket nuxeo_bucket with minimal configuration:

nuxeo.aws.accessKeyId=your_AWS_ACCESS_KEY_ID
nuxeo.aws.secretKey=your_AWS_SECRET_ACCESS_KEY

nuxeo.s3storage.bucket=nuxeo_bucket

# Required prior to 9.3
nuxeo.s3storage.directdownload=true

You don't need to specify nuxeo.aws.accessKeyId and nuxeo.aws.secretKey if you're using IAM instance roles. If you want to go further, please read the Nuxeo S3 Binary Manager page.

Specifying Your Amazon CloudFront Parameters

In nuxeo.conf, add the following lines:

# Use CloudFrontBinaryManager
nuxeo.core.binarymanager=org.nuxeo.ecm.core.storage.sql.CloudFrontBinaryManager

# CloudFront private key in .pem or .der format
nuxeo.s3storage.cloudfront.privKey=/local/path/cf/private/key
nuxeo.s3storage.cloudfront.privKeyId=your_CF_PRIV_KEY_ID
nuxeo.s3storage.cloudfront.distribDomain=your_DISTRIBUTION_DOMAIN

# Fix a query parameter encoding issue - Amazon has to fix it...
nuxeo.s3storage.cloudfront.fix.encoding=true