The following information is intended for our partners who are looking to configure your app for use with a Custom Domain url and want to use Amazon CloudFront.
Step 1 - Add Custom Domain in IoT Console
In this step we will let myDevices know that your App can be accessed from a Custom Domain URL. This is done by adding the URL to use in the IoT Console.
Log into the IoT Console using your credentials.
Navigate to the White Label Settings tab.
On the Product Info tab that appears, enter the custom domain you are using into the Custom Domain field.
💡 This helps us to know which domain your customers will use when accessing your app, along with making sure that email communications point back to your domain.
Don’t forget to click Save in the console after making this change.
Step 2 - Configure an SSL cert in AWS ACM
Configure an SSL cert for the custom domain in AWS ACM.
You are configuring an SSL cert for the custom domain you want to use (E.g. app.mycustomdomain.com), not the *.mydevices.com URL that we provide to you.
The cert can either be requested for free in AWS ACM, or a commercial SSL cert from GoDaddy or other SSL cert provider can be purchased and imported to ACM. We recommend using ACM free certs because it's free and it handles renewals automatically.
➡️ The SSL Cert must be ready in ACM before Step 3 can be completed.
How to request free SSL cert in AWS ACM
If you want to follow the optional step of creating a free cert in AWS ACM, the following information will help guide you through this.
AWS docs on requesting free SSL cert in ACM: https://docs.aws.amazon.com/acm/latest/userguide/gs-acm-request-public.htm
FQDN pictured in our example will be app.mycustomdomain.com
Step 1: Go to ACM and click Request certificate, then select Request a public certificate
Step 2:
Step 3: SSL cert request appears on the list of certificates and it needs to be validated:
Open the request, and add the required DNS records to complete validation.
If you host your domain in AWS too, then ACM can automatically add those records by clicking the appropriate button. If the domain is hosted elsewhere, those validation records must be added manually.
Once DNS records are ready, wait for CloudFront to change status for the SSL cert to Issued
.
➡️ Only when the SSL Cert shows Issued should you proceed to Step 3 to create CloudFront distribution.
Step 3 - Create CloudFront distribution
Default settings generally work, but below is a screenshot with the fields that we found need to be set / change from their default values. Everything else can stay unchanged.
One note about the last highlighted field in the screenshot (Custom SSL certificate) - this is where the SSL cert for the custom domain appears if it was properly configured in ACM in Step 2. Although we have not selected anything in the screenshot (because we do not have SSL cert for our example domain), this field cannot be left empty - it must be set.
Step 4 - Disable Caching (Optional, Troubleshooting)
There are two additional extra fields that can be set to disable CDN caching and forward all browser requests to the myDevices servers. By default, CloudFront uses aggressive caching and it might get in the way. Although we are not currently aware of any related issues, if any issues are observed, these two additional settings are the first actions to take to see if it improves anything.
Step 5 - Notify Us
As a final step, please Notify Us and include your details (your White label name, Custom URL being used) and let us know that you are done following the configuration guide. We will then verify things are working and apply any final steps needed on our side to ensure your custom domain URL will work.
Failure to do this step may result in problems such as Google Map API errors seen when your users use the dashboard.