This post will be about a Lambda routing fix for Cloudfront, which is caused by the way that Cloudfront deals with routes for sub folders.
Unlike S3, Cloudfront does not allow the index file within a subfolder to be automatically displayed, this is behaviour that needs to be programmed with a Lambda function.
Step 1

Step 2

Step 3

I’ve posted the Lambda function below (with comments) so you can use this Lambda routing fix for Cloudfront! I’ve also written a similar post to this on how to trigger a code pipeline to deploy to an S3 bucket via a lambda function, that you may find helpful! Enjoy 🙂
Lambda function
'use strict';
exports.handler = (event, context, callback) => {
    // Extract the request from the CloudFront event that is sent to Lambda@Edge 
    var request = event.Records[0].cf.request;
    // Extract the URI from the request
    var olduri = request.uri;
    // Replace the received URI with the URI that includes the index page
    request.uri = updateUri(olduri);
    // Return to CloudFront
    return callback(null, request);
};
function updateUri(olduri) {
    // if url ends with file name all it to pass through to site
    if (olduri.match(/\.[0-9a-z]+$/i)) {
        return olduri;
    }
    // else (if it ends with "/" folder path) then add "/index.html"
    else if (olduri.endsWith('/')) {
        return `${olduri}index.html`;
    }
    // else return the previous url with "/index.html ad"
    return `${olduri}/index.html`;
}
Lambda permission role’s trust relationship
{
  "Version": "2012-10-17",
  "Statement": [
    {
      "Effect": "Allow",
      "Principal": {
        "Service": [
          "lambda.amazonaws.com",
          "edgelambda.amazonaws.com"
        ]
      },
      "Action": "sts:AssumeRole"
    }
  ]
}
 
				