X.509 Provisioning and Connection
Overview
This section explains how to provision a gateway and how to connect to the Azure IoT Services using X.509 certificates. This connection method can be used with IoT Hub DPS Individual Enrollment, IoT Hub DPS Enrollment Group, IoT Central Individual Enrollment, or IoT Central Enrollment Group.
ESF Cloud Connector for Azure IoT, Version 2.0.0 and Above Only
These instructions apply to the ESF Cloud Connector for Azure IoT, Version 2.0.0 and above. See Legacy v2 Azure IoT Connection if you are using any version under 2.0.0.
Testing Use Only
These instructions are for testing and development only. The certificates generated in this guide are not suitable for deployment!
Always follow the correct procedures for generating secure certificates!
Prerequisites
A terminal application and the OpenSSL package are required. These are often pre-installed with operating systems.
Create a X.509 Self-Signed CA Certificate (Root Certificate) and Key
Create a PEM formatted X.509 self-signed CA certificate (also known as a Root Certificate) and key by running the following command:
Unencrypted Private Key File
The command below will generate a private key file that is unencrypted. If you prefer to encrypt the private key file, remove the "-nodes" argument from the command.
openssl req -x509 -newkey rsa:2048 -keyout root-private-key.pem -nodes -out root-cert.pem
Enter the following information when prompted. The values you enter into the fields other than Common Name can be anything and do not matter. Make sure to note what you entered in the Common Name field as it will be used later in the provisioning process.
Certificate Detail Fields
You must enter a value into at least one of the configuration fields other than Common Name. If all fields other than Common Name are blank, the certificate generation will succeed but the Azure authentication will fail.
Common Name Format
The Common Name field must be alphanumeric (a-z, 0-9) characters only and all lower case. If the Common Name field is not all lower case or includes any non-alphanumeric characters, the certificate generation will succeed but the Azure authentication will fail.
Note the Common Name
Make sure you keep a copy of the Common Name. It will be required later in the provisioning process and must be an exact match to the Common Name used in this certificate.
Configuration Fields:
- Country Name: Enter any 2 letter code. Enter a period for blank. At least one of these fields must be filled in.
- State or Province Name: Enter anything. Enter a period for blank. At least one of these fields must be filled in.
- Locality Name: Enter anything. Enter a period for blank. At least one of these fields must be filled in.
- Organization Name: Enter anything. Enter a period for blank. At least one of these fields must be filled in.
- Organization Unit Name: Enter anything. Enter a period for blank. At least one of these fields must be filled in.
- Common Name: This is required. Must be all lower case. Make sure you note this value as it will be used later in the provisioning status. At least one other field must be filled in as well.
- Email Address: Enter anything. Enter a period for blank. At least one of these fields must be filled in.
Provisioning
X.509 Provisioning can be accomplished in five ways:
- Start at Provision Device Using IoT Hub DPS Individual Enrollment for IoT Hub DPS Individual Enrollment
- Start at Provision Device Using IoT Hub DPS Enrollment Group for IoT Hub DPS Enrollment Group
- Start at Provision Device Using IoT Central Individual Enrollment for IoT Central Individual Enrollment
- Start at Provision Device Using IoT Central Enrollment Group for IoT Central Enrollment Group
Provision Device Using IoT Hub DPS Individual Enrollment
Go to the Manage Enrollments page of your DPS in your Azure Portal and Click + Add individual enrollment.
data:image/s3,"s3://crabby-images/721a7/721a76ffc04c00e9faf2d08b83984b5f92934d3c" alt="x509-new-ind-enrollment.png 2724"
On the Add Enrollment page, enter the following information:
- Mechanism: X.509
- Primary Certificate: Upload the root-cert.pem you generated above
- IoT Hub Device ID: Enter the name you gave the certificate in the Common Name field here. This must be all lower case (you must generate a new certificate if it is not all lower case).
- All other fields: Leave at the default values
Click Save.
data:image/s3,"s3://crabby-images/85cbb/85cbb34a45ce91ccb1fe251adbc4ff5b06c2f437" alt="x509-add-enrollment.png 1733"
The Azure Portal will return you to the Manage Enrollments page. Navigate to the Manage Enrollments page if you are not automatically returned to it.
Continue At Create a X.509 cloud connection.
Provision Device Using IoT Hub DPS Enrollment Group
Add Certificate to DPS
Go to the Certificates page of your DPS in your Azure Portal and click + Add.
data:image/s3,"s3://crabby-images/c2535/c2535a70bd9b4df2e73036118761f2f6e39719f0" alt="x509-certificates.png 3618"
Enter a certificate name and upload the root-cert.pem you created above. Click Save.
data:image/s3,"s3://crabby-images/0c25d/0c25db05216a6c618a58d7801049f8dfc5ca987b" alt="x509-upload-cert.png 3636"
The certificate will be added to the list of certificates and will have Unverified in the Status column. Click on the certificate name to bring up the Certificate Details panel.
data:image/s3,"s3://crabby-images/6775f/6775f1148ff1721e61071c80ef896c0dcf33d1af" alt="x509-unverified-cert.png 3630"
Click Generate Verification Code. This will populate the Verification Code field with the verification code.
data:image/s3,"s3://crabby-images/07ccf/07ccf7fecf2a8a90e306a1bbfd7d57b92f592b67" alt="x509-generate-verification-code.png 3633"
Copy the verification code. Open the Verification Certificates section of Creating Additional Types of Certificates for Azure IoT in a new window and follow the instructions to create a verification certificate. Continue with these instructions once you have created the verification certificate.
Upload the verification certificate you just created and click Verify.
data:image/s3,"s3://crabby-images/0ab94/0ab94f7a5f8dc599d39fa72ddc748858bc6106a0" alt="x509-upload-verification.png 3628"
The certificate should now show Verified with a green checkmark in the Status column.
data:image/s3,"s3://crabby-images/d82c0/d82c0b9563fd9b71678ee3fc538fad27475e3d58" alt="x509-cert-verified.png 3627"
Create Enrollment Group
Go to the Manage Enrollments page of your DPS. Click + Add Enrollment Group.
data:image/s3,"s3://crabby-images/e3102/e310214837a9bd46a44dd71516408799801bc678" alt="x509-add-new-enrollment-group.png 2724"
On the Add Enrollment Group page, enter the following information:
- Group Name: Any unique designator.
- Attestation Type: Certificate
- Primary Certificate: Select the certificate you uploaded and verified above.
- All other fields: Leave at the default values
Click Save.
data:image/s3,"s3://crabby-images/50ee8/50ee83243acdf7d986b993a223286f9acc4b5e87" alt="x509-add-enrollment-group.png 1713"
Continue At Create a X.509 cloud connection.
Provision Device Using IoT Central Individual Enrollment
Prerequisites
Create an Application
In order to provision your device with X.509 credentials using IoT Central Applications, you must first create an application. Instructions on how to create your own IoT Central application can be found here.
Create a Device
You must Create your device in your Azure IoT Central Application before provisioning using X.509 credentials.
Device ID Must Match Certificate Common Name
When you create a device in your Azure IoT Central Application, the Device ID must match the Common Name that you used when creating the root certificate (in the Prerequisites section at the start of this document).
Connect device
Click on your device from the Devices page and click Connect.
data:image/s3,"s3://crabby-images/540b6/540b6e07900a7f7a5f97a407b92a46c8fb5c0285" alt="x509-device-connect.png 1574"
Set the Authentication Type to "Individual Enrollment" and the Authentication Method to "Certificates (X.509)".
Click the button to upload your root certificate for both Primary and Secondary. You should use the same certificate for both.
Click Save.
data:image/s3,"s3://crabby-images/7289a/7289ae8c60f15faaf57a2d3eb3015098adf9d06b" alt="x509-cert-connection-settings.png 1272"
Leave this window open. It will be used in the next section.
Continue At Create a X.509 cloud connection.
Provision Device Using IoT Central Enrollment Group
Prerequisites
Create an Application
In order to provision your device with X.509 credentials using IoT Central Applications, you must first create an application. Instructions on how to create your own IoT Central application can be found here.
Navigate to the Device connection section of the Administration page in your IoT Central Application. Click + Create enrollment group.
data:image/s3,"s3://crabby-images/9bd00/9bd00c423d489bd56c9bccc1d7aa4df5358f06eb" alt="x509-device-connection.png 3386"
The Name must be set to a unique enrollment group name. Set the Attestation type to "Certificates (X.509)". Leave all other fields at default values and click Save.
data:image/s3,"s3://crabby-images/51137/511373d297855058a8cf46252fc76445614a4d92" alt="x509-create-new-group.png 3625"
Once the Enrollment Group is saved, new options will appear under Certificates (X.509). Click + Manage Primary.
data:image/s3,"s3://crabby-images/bbc7f/bbc7f34dd7cf439fa12b1f97f9623319fb79050e" alt="x509-manage-primary.png 3609"
Upload the root certificate to Primary. You should see a warning in red that says Needs verification just under the Primary field.
Click Generate verification code. This will generate a verification code.
data:image/s3,"s3://crabby-images/1a194/1a1941fe354d7f8a57082e70dd08666d3aec85ce" alt="x509-upload-primary-cert.png 3620"
Copy the verification code. Open the Verification Certificates section of Creating Additional Types of Certificates for Azure IoT in a new window and follow the instructions to create a verification certificate. Continue with these instructions once you have created the verification certificate.
Click Verify and upload your verification certificate. The message below Primary will change to a green "Verified".
data:image/s3,"s3://crabby-images/6ab01/6ab01b61bf1f7efd5958273d30ee87b48ba682b6" alt="x509-primary-cert-verified.png 3629"
Click Close, then click Save.
data:image/s3,"s3://crabby-images/0e8ed/0e8ed8612ebe158ef2cc1be4274c14a29028f2bd" alt="x509-save-group.png 3617"
Continue At Create a X.509 cloud connection.
Create a X.509 cloud connection
In the ESF Web interface, go to the Cloud Connection section and click New Connection.
On the New Cloud Connection dialog, enter the following information:
- Cloud Connection Factory PID: AzureDpsX509
- Cloud Connection Service PID: AzureDpsX509 or other valid Cloud Connection Service PID
Click Apply.
data:image/s3,"s3://crabby-images/71b57/71b57c26eecf814e08f9850d750b2fa5110b6e3a" alt="x509-create-cloud-connection.png 1192"
Select the new connection and go to the X509MqttDataTransport tab.
data:image/s3,"s3://crabby-images/4dd81/4dd8111f202d765d20d23ce1710e7edf2f512a39" alt="x509_data_transport.png 2676"
Select the appropriate Device Model ID from the list of options. If a device model does not need to be specified your application, leave the default 'None' field'. Set the 'Device Model ID Version' to the appropriate version of the Device Model ID.
Connecting to Azure IoT Portal can be accomplished in five ways:
- Start at Configure connection using IoT Hub DPS Individual Enrollment for IoT Hub DPS Individual Enrollment
- Start at Configure connection using IoT Hub DPS Enrollment Group for IoT Hub DPS Enrollment Group
- Start at Configure connection using IoT Central Individual Enrollment for IoT Central Individual Enrollment
- Start at Configure connection using IoT Central Enrollment Group for IoT Central Enrollment Group
Configure connection using IoT Hub DPS Individual Enrollment
Navigate to the Overview page of the Azure DPS. Copy/paste the Global device endpoint and ID Scope into the Global Endpoint and Scope ID in ESF.
data:image/s3,"s3://crabby-images/94b44/94b4480c0be402654b3b6493933f1262f78658ef" alt="x509-global-endpoint.png 2717"
Run the following command to get the certificate.
cat root-cert.pem
The output of that command will start with "-----BEGIN CERTIFICATE-----", then have a large block of random looking text, and end with "-----END CERTIFICATE-----".
data:image/s3,"s3://crabby-images/6add3/6add327f1128ff0542877ebecf557bf0da5e2e18" alt="x509-get-cert.png 1090"
The large block of random looking text is blacked out in this image.
Copy and paste the entire output starting with "-----BEGIN" and ending with "CERTIFICATE-----". Paste this into the Device Certificate textbox in ESF.
Whitespace Warning
Be careful not to copy/paste any extra whitespace characters after the last dash. If extra whitespace characters are included the connection will fail.
Run the following command to get the private key.
cat root-private-key.pem
The output of that command will start with "-----BEGIN PRIVATE KEY-----", then have a large block of random looking text, and end with "-----END PRIVATE KEY-----".
data:image/s3,"s3://crabby-images/2b4f0/2b4f02a988afad9f94e9642d71b0a76cb0f1d1fc" alt="x509-get-private-key.png 1179"
The large block of random looking text is blacked out in this image.
Copy and paste the entire output starting with "-----BEGIN" and ending with "CERTIFICATE-----". Paste this into the Device Private Key textbox in ESF.
Whitespace Warning
Be careful not to copy/paste any extra whitespace characters after the last dash. If extra whitespace characters are included the connection will fail.
Click Apply.
Click the Connect/Disconnect button. The Status should change to Connected. The connection process may take up to two minutes.
When the AzureDpsX509 is connected, navigate to the device in DPS (via Manage Enrollments/Individual Enrollments). Select your device to go to the Enrollment Details page.
In the Registration Status section, confirm that the Status is "assigned." If the Status is still "unassigned" try refreshing the page in your browser (not the Azure Portal "refresh" button).
data:image/s3,"s3://crabby-images/86442/86442b13919bccd9ad4e38dd40204bd07bc38adf" alt="x509-confirm-connection.png 3640"
When the gateway connects for the first time, a Device will be created in the IoT Hub. Navigate to your IoT Hub in the Azure Portal. Go to the IoT Devices page and confirm the device is listed. The gateway will be listed under the Device ID you entered earlier.
data:image/s3,"s3://crabby-images/61497/614977b0c56f2adfc8eb36d7235c4396d1fcf47f" alt="x509-iot-hub-device.png 2715"
The device is now connected.
Configure connection using IoT Hub DPS Enrollment Group
Open the Device Certificates section of Creating Additional Types of Certificates for Azure IoT in a new window and follow the instructions to create device certificates to use on the gateway. Continue with these instructions once you have created the device certificates.
Navigate to the Overview page of the Azure DPS. Copy/paste the Global device endpoint and ID Scope into the Global Endpoint and Scope ID in ESF.
data:image/s3,"s3://crabby-images/5cc00/5cc00bdcb93e8d6fd6f81939a094fc411fc3cb0f" alt="x509-global-endpoint.png 2717"
Run the following command to get the certificate.
cat device.crt
Note: This command uses a different filename than the screenshot below, but the output should be the same.
The output of that command will start with "-----BEGIN CERTIFICATE-----", then have a large block of random looking text, and end with "-----END CERTIFICATE-----".
data:image/s3,"s3://crabby-images/e56b8/e56b86733ace16f5e6f5b761a0852474553d81f8" alt="x509-get-cert.png 1090"
The large block of random looking text is blacked out in this image.
Copy and paste the entire output starting with "-----BEGIN" and ending with "CERTIFICATE-----". Paste this into the Device Certificate textbox in ESF.
Whitespace Warning
Be careful not to copy/paste any extra whitespace characters after the last dash. If extra whitespace characters are included the connection will fail.
Run the following command to get the private key.
cat device-private-key.pem
Note: This command uses a different filename than the screenshot below, but the output should be the same.
The output of that command will start with "-----BEGIN PRIVATE KEY-----", then have a large block of random looking text, and end with "-----END PRIVATE KEY-----".
data:image/s3,"s3://crabby-images/b1fb2/b1fb24b2d0ccd556ab317e808e84a59636186352" alt="x509-get-private-key.png 1179"
The large block of random looking text is blacked out in this image.
Copy and paste the entire output starting with "-----BEGIN" and ending with "CERTIFICATE-----". Paste this into the Device Private Key textbox in ESF.
Whitespace Warning
Be careful not to copy/paste any extra whitespace characters after the last dash. If extra whitespace characters are included the connection will fail.
Click Apply.
Click the Connect/Disconnect button. The Status should change to Connected. The connection process may take up to two minutes.
When the AzureDpsX509 is connected, navigate to the Enrollment Group Details page in DPS (via Manage Enrollments/Enrollment Groups and click your Enrollment Group). Select the Registration Records tab.
data:image/s3,"s3://crabby-images/ad3bd/ad3bd46b3a0ff82676a971ad3318a4d74b59097e" alt="x509-reg-records.png 2730"
Click your device to go to the Device Registration page. In the Registration Status section, confirm that the Status is "assigned." If the Status is still "unassigned" try refreshing the page in your browser (not the Azure Portal "refresh" button).
data:image/s3,"s3://crabby-images/bc624/bc624832dc5ed5b17845cdae8c744dc40f279e09" alt="x509-confirm-device-assigned.png 2723"
When the gateway connects for the first time, a Device will be created in the IoT Hub. Navigate to your IoT Hub in the Azure Portal. Go to the IoT Devices page and confirm the device is listed.
data:image/s3,"s3://crabby-images/bdfd4/bdfd40ba8d23d83dacf56fa80f0b9191ae1773a7" alt="x509-iot-hub-device.png 2715"
The device is now connected.
Configure connection using IoT Central Individual Enrollment
The Device Connection details page should still be open in your IoT Central Application. If not, open it by navigating to Devices/[Device Name]/Connect. Copy the ID scope into the Scope ID in ESF.
data:image/s3,"s3://crabby-images/6ef0a/6ef0a0275e24b4d7f9d6ad4c87dd5dabc1cc30ca" alt="x509-get-id-scope.png 1275"
The Global Endpoint can be found in the DPS in the Azure Portal by navigating to the Overview page of your Azure DPS.
Copy/paste the Global device endpoint to the Global Endpoint in ESF.
data:image/s3,"s3://crabby-images/0488d/0488d7f7c7ca1733c597b6e501ebd6f93ab1a38f" alt="x509-global-device-endpoint.png 3361"
Run the following command to get the certificate.
cat root-cert.pem
The output of that command will start with "-----BEGIN CERTIFICATE-----", then have a large block of random looking text, and end with "-----END CERTIFICATE-----".
data:image/s3,"s3://crabby-images/a11ff/a11ff19b25c23b9c59282f130ec8549bc7dad392" alt="x509-get-cert.png 1090"
The large block of random looking text is blacked out in this image.
Copy and paste the entire output starting with "-----BEGIN" and ending with "CERTIFICATE-----". Paste this into the Device Certificate textbox in ESF.
Whitespace Warning
Be careful not to copy/paste any extra whitespace characters after the last dash. If extra whitespace characters are included the connection will fail.
Run the following command to get the private key.
cat root-private-key.pem
The output of that command will start with "-----BEGIN PRIVATE KEY-----", then have a large block of random looking text, and end with "-----END PRIVATE KEY-----".
data:image/s3,"s3://crabby-images/50f32/50f324783e4593c87b7a8e52652d244c26fa9160" alt="x509-get-private-key.png 1179"
The large block of random looking text is blacked out in this image.
Copy and paste the entire output starting with "-----BEGIN" and ending with "CERTIFICATE-----". Paste this into the Device Private Key textbox in ESF.
Whitespace Warning
Be careful not to copy/paste any extra whitespace characters after the last dash. If extra whitespace characters are included the connection will fail.
Click Apply.
Click the Connect/Disconnect button. The Status should change to Connected. The connection process may take up to two minutes.
When the AzureDpsX509 is connected, navigate to the Devices page in your IoT Central Application. Confirm the Device status is Provisioned.
data:image/s3,"s3://crabby-images/eaf57/eaf57c14b81af419a0986b6c3d0e62b91f27c472" alt="x509-device-provisioned.png 3356"
The device is now connected.
Configure connection using IoT Central Enrollment Group
Navigate to the Device connection section of the Administration page in your IoT Central Application. Copy the ID Scope and paste it in the Scope ID in ESF.
data:image/s3,"s3://crabby-images/ababa/ababa5b165fe81fc2e8a96e4562a40185b110a7f" alt="x509-group-scope-id.png 3360"
Navigate to the Overview page of the Azure DPS. Copy/paste the Global device endpoint into the Global Endpoint in ESF.
data:image/s3,"s3://crabby-images/03427/034277fe7668739f22597905a205c982ec45ff37" alt="x509-global-device-endpoint.png 3361"
Open the Device Certificates section of Creating Additional Types of Certificates for Azure IoT in a new window and follow the instructions to create device certificates to use on the gateway. Continue with these instructions once you have created the device certificates.
Run the following command to get the certificate.
cat device.crt
Note: This command uses a different filename than the screenshot below, but the output should be the same.
The output of that command will start with "-----BEGIN CERTIFICATE-----", then have a large block of random looking text, and end with "-----END CERTIFICATE-----".
data:image/s3,"s3://crabby-images/f9080/f908043734ecbf12202b1093f9e77f571140d556" alt="x509-get-cert.png 1090"
The large block of random looking text is blacked out in this image.
Copy and paste the entire output starting with "-----BEGIN" and ending with "CERTIFICATE-----". Paste this into the Device Certificate textbox in ESF.
Whitespace Warning
Be careful not to copy/paste any extra whitespace characters after the last dash. If extra whitespace characters are included the connection will fail.
Run the following command to get the private key.
cat device-private-key.pem
Note: This command uses a different filename than the screenshot below, but the output should be the same.
The output of that command will start with "-----BEGIN PRIVATE KEY-----", then have a large block of random looking text, and end with "-----END PRIVATE KEY-----".
data:image/s3,"s3://crabby-images/387c7/387c799792723667c496c00e657b87aad15191c4" alt="x509-get-private-key.png 1179"
The large block of random looking text is blacked out in this image.
Copy and paste the entire output starting with "-----BEGIN" and ending with "CERTIFICATE-----". Paste this into the Device Private Key textbox in ESF.
Whitespace Warning
Be careful not to copy/paste any extra whitespace characters after the last dash. If extra whitespace characters are included the connection will fail.
Click Apply.
Click the Connect/Disconnect button. The Status should change to Connected. The connection process may take up to two minutes.
When the AzureDpsX509 is connected, navigate to the Devices page in your IoT Central Application. Confirm the device is listed, and that Device status is Provisioned. If the device does not show up, refresh the page in your browser.
data:image/s3,"s3://crabby-images/f8ab6/f8ab6dadb7addef219774978b86d9fbfc777f3ef" alt="x509-device-provisioned.png 3356"
The device is now connected.
Updated about 3 years ago