Skip to content

Sample code to deploy a website and a "public files" S3 bucket which can be loaded with any files an administrator wishes to publish publicly online.

License

Notifications You must be signed in to change notification settings

aws-samples/public-file-browser-for-amazon-s3

Public File Browser for Amazon S3

AWS Storage Blog: Creating a simple public file repository on Amazon S3

This AWS Samples code allows customers to create a simple PUBLIC file repository using Amazon S3 and Amazon CloudFront. This sample code deploys a website and a public files S3 bucket which can be loaded with any files they wish to publish publicly online.

Example Interface Screenshot

Architecture

Overall Architecture Diagram

  1. User accesses static website via CloudFront CDN (contents of S3 "Website" Bucket)
  2. Static website loads and browser obtains temporary credentials from Cognito
  3. Cognito credentials are used to list files in the public S3 "Files" Bucket
  4. Directory and file tree is rendered in the browser
  5. User clicks any file to download via CloudFront CDN (contents of S3 "Files" Bucket)

Deployment Instructions

The solution is packaged as an automated deployment via the AWS Serverless Application Model (SAM) CLI.

Prerequisites

For this walkthrough, you need to have the following prerequisites:

  • An AWS account
  • AWS SAM CLI installed and set up with credentials
  • Python 3.11 Installed and in your PATH variable
  • Choose a region where the required services below are supported. Most AWS commercial regions are supported, but consult the AWS Services by Region page for details.
    • Amazon CloudFront (including Standard Log support)
    • Amazon S3
    • Amazon Cognito
    • AWS CloudFormation
    • AWS Lambda
    • As of March 2024, these are the supported regions:
      • US East (N. Virginia)
      • US East (Ohio)
      • US West (N. California)
      • US West (Oregon)
      • Canada (Central)
      • Europe (Frankfurt)
      • Europe (Ireland)
      • Europe (London)
      • Europe (Paris)
      • Europe (Stockholm)
      • Asia Pacific (Mumbai)
      • Asia Pacific (Osaka)
      • Asia Pacific (Seoul)
      • Asia Pacific (Singapore)
      • Asia Pacific (Sydney)
      • Asia Pacific (Tokyo)
      • South America (São Paulo)

Build and Deploy

Download the source code and extract locally: AWS Samples - Public File Browser for Amazon S3

  1. In a terminal, navigate to the ./sam/ directory
  2. Run the following command to build and package the project for deployment:
    sam build
  3. Deploy the SAM template to your account. The wizard will guide you through the process of deploying the SAM AWS CloudFormation. Details on this process are found in the sam build documentation.
    1. Run the following command:
      sam deploy --guided --capabilities CAPABILITY_NAMED_IAM
    2. Select the supported AWS Region you chose in the prerequisites section.
    3. Enter values for the deployment parameters
      1. Stack Name - Choose a unique CloudFormation stack name. End users do not see this.
      2. AWS Region - The supported AWS Region you chose in the Prerequisites section.
      3. SiteName - Publicly visible title for the site, shown on the top of the page and in the title bar.
      4. FilesOpenTabMode - How do you want the browser to react when a user selects a file in the following interface values. In New Tab is recommended over In Same Tab.
      5. VisibleStorageClasses - Comma delimited list of storage classes to show. Recommend keeping this default.
      6. CrossOriginRestriction - Browser security setting, set to * for first deployment, then see Step 6.
    4. Select the default inputs for the remaining items with the last prompt before deployment being:
      Deploy this changeset?
  4. Wait for the deployment to complete. This process takes approximately five minutes with a final prompt stating:
    Successfully created/updated stack - [STACK-NAME] in [REGION]
  5. Once the deployment completes, note the following entries in the Outputs section.
    1. FileBrowserURL - This URL is for the public web interface. Needed in Step 6.
    2. PublicFilesBucket - The name of the S3 bucket for storing PUBLICLY ACCESSIBLE files that display in the user browser.
    3. WebInterfaceAppBucket - The name of the S3 bucket that stores the code that runs the file browser web interface.
  6. IMPORTANT: Complete Steps 3 and 4 again, keeping all values the same except for the CrossOriginRestriction parameter, and input the value from the FileBrowserURL output in Step 5. For example:
    Parameter CrossOriginRestriction [*]: https://d111111abcdef8.cloudfront.net

This concludes the deployment of the Public File Browser for Amazon S3 web application. AWS SAM CLI uses AWS CloudFormation to orchestrate the deployment of the front-end static website and public file storage bucket. The entire application is deployed.

Usage

To add files to the public interface simply move files into the S3 Bucket indicated in the PublicFilesBucket output from the above SAM Deploy command. The bucket name should start with public-file-browser-files- followed by a random string.

Note that this solution has Amazon S3 Versioning enabled for all data, which could result in deleted data being retained and incurring costs. See the Security section below for details.

Frequently Asked Questions

How much does this solution cost to operate?

This is an entirely serverless solution. Therefore, costs are directly related to usage, both in data storage and data retrieval by end users. Reference below and consult the S3 and CloudFront pricing pages.

  • Static Costs
    • A few cents monthly to store the website source code in S3 Standard
    • S3 data storage costs for the public files and logging buckets
      • Free Tier: 5GB Per Month for First 12 Months
  • Costs for End User Access
    • CloudFront data transfer
      • Free Tier: 1TB Per Month
    • S3 LIST/GET request costs
      • Free Tier: 2,000 Page Views and 20,000 Downloads for First 12 Months
      • Note: There is NO CHARGE for S3 Data Transfer to CloudFront

How are objects listed in the interface?

S3 object/prefix lists are ordered lexicographically (UTF-8 byte order). For this to make sense in most use cases the solution automatically switches between two modes:

  • Less than or equal to 1000 Objects/Prefixes
    • Sort how most filesystems do (lexicographically with folders always on top)
    • This makes the system make intuitive sense for 99% of listings and views
  • Greater than 1000 Objects
    • Strictly lexicographically so folders may be interspersed
    • While this is less intuitive it is consistent without listing the entire bucket. Listing the entire bucket would inflate costs and load times unnecessarily. The alternative would be to take each page and treat it as above but this leads to odd ordering that almost seems random since the top of one page is not always the next object of the previous page (it is all the next folders lexicographically).

How do I move files into the public-file-browser-files-[...] quickly in bulk?

Sync from a local system:

For large uploads:

If your files are already in a different Amazon S3 bucket:

How do I use this solution with my own DNS domain name (such as publicfiles.example.com) instead of the CloudFront name?

See How can I configure CloudFront to serve my content using an alternate domain name over HTTPS?

How do I modify the public user interface, such as to add text, change the style, or add my logo?

The public website files are located in the public-file-browser-website-[...] bucket. These files can be downloaded, modified, and re-uploaded containing customizations. Note that CloudFront caches these files, so you must create an invalidation to clear the cache when a file is updated. See How do I remove a cached file from CloudFront?

If you choose to update the files in the ./website/ directory of the source code repository for future deployments, then you must update the ./sam/seed_s3_data/website.zip by following the instructions in the repository’s README.md file.

Security

As a best practice, the solution enables the following features:

See CONTRIBUTING for more information.

Development

Run the following from the website directory using local-web-server:

> ws -r '/ -> index.html' '/pfb_for_s3/(.*) -> /$1' --log.format dev

Automatic Deployment Note

The file ./sam/seed_s3_data/website.zip contains a statically zipped copy of the ./website/ directory. This zip file is used to automatically load the public-file-browser-website-[...] bucket with the actual website code during deployment. Before re-deploying you will need to re-create ./sam/seed_s3_data/website.zip using the command below from the root of the repository. You may then follow the DEPLOYMENT guide.

> zip -FS -x "*.DS_Store" -r ./sam/seed_s3_data/website.zip website

License

This library is licensed under the MIT-0 License. See the LICENSE file.

About

Sample code to deploy a website and a "public files" S3 bucket which can be loaded with any files an administrator wishes to publish publicly online.

Resources

License

Code of conduct

Security policy

Stars

Watchers

Forks