The client wanted to create a file server for training documents including MP4, PDF, PPT, WMV, etc. that was accessible through different sub domains. DNS managed through Cloudflare.
In Amazon's S3 dashboard, create a bucket that matches the subdomain you want to use.
data:image/s3,"s3://crabby-images/8279b/8279bb8176df06ffda801516441abc0c5b485292" alt="2018-08-24_09h04_23"
For example, videos.domain.com sub domain would need a matching bucket, videos.domain.com. Make sure the created bucket is set to PUBLIC.
data:image/s3,"s3://crabby-images/4a7ee/4a7ee2973c920144a26a04d9a1c6bbf53017483c" alt="2018-08-24_09h18_40-1"
Left click on the bucket to open it. Go to Permissions and CORS configuration.
data:image/s3,"s3://crabby-images/5d1af/5d1afc600c81652e21c7826ad93f324e9cf480df" alt="2018-08-24_09h07_57"
Inside CORS configuration, you will need to add this information configured for your subdomain:
<?xml version="1.0" encoding="UTF-8"?>
<CORSConfiguration xmlns="http://s3.amazonaws.com/doc/2006-03-01/">
<CORSRule>
<AllowedOrigin>http://videos.domain.com</AllowedOrigin>
<AllowedMethod>PUT</AllowedMethod>
<AllowedMethod>POST</AllowedMethod>
<AllowedMethod>DELETE</AllowedMethod>
<MaxAgeSeconds>3000</MaxAgeSeconds>
<ExposeHeader>x-amz-server-side-encryption</ExposeHeader>
<ExposeHeader>x-amz-request-id</ExposeHeader>
<ExposeHeader>x-amz-id-2</ExposeHeader>
<AllowedHeader>*</AllowedHeader>
</CORSRule>
</CORSConfiguration>
Cloudflare Configuration
You will need to create a CNAME record. Set the name as the subdomain, in our example, this is video.
The Value would be: video.domain.com.s3.amazonaws.com
data:image/s3,"s3://crabby-images/2db39/2db3911496407184ddf536be28df8a5c5c3afe0c" alt="2018-08-24_09h13_12-1"