X.509 Bootstrap (XBoot) for Azure Device Provisioning Service

X.509 Bootstrap (XBoot) for Azure Device Provisioning Service

X.509 Bootstrap (aka XBoot) is a reference application that allows IoT device builders to have a generic firmware loaded onto their devices at time of manufacturing and avoid the cost of "touching" each device to install individual x.509 certificates, during or post-manufacturing.

For IoT device builders wanting to use x.509 certificates to authenticate their devices with IoT Hub, the Azure Device Provisioning Service (DPS) provisioning process assumes you already have a process to install the certificates on the devices. This is where XBoot comes in!

With XBoot, when the IoT device starts up, the device generates an x.509 certificate signing request (CSR) using the (optional) XBoot.Client .NET SDK, sends the CSR to the XBoot.Server REST endpoint, and receives a signed x.509 certificate back. At this point, the XBoot process is complete. The certificate can now be used by the device as part of the standard Azure DPS attestation process and to authenticate with Azure IoT Hub.

I developed XBoot after seeing several partners struggle with developing a process and tooling to generate and install individual x.509 certificates on IoT devices, at scale, with few (or no) changes to their existing manufacturing processes.

XBoot is open source and available at khilscher/xboot: X.509 Bootstrap (github.com). The GitHub repo also has instructions for generating your own signing certificates. It was developed as a reference application for you to develop your own solution. It is not an end-to-end solution for you to use in production.

I look forward to your feedback.


Richard Reukema

Digital Architect Specializing in AI | Strategic Consulting | Cloud Solutions Architect | App Migration

1y

Exactly what I'm struggling with, as we ramp up high enough and get manufacturing involved yet.

Like
Reply
Jon Mikel Inza

CTO | Digital transformation - value creation with IoT and Cloud Solutions | Architect | Microsoft IoT MVP & Microsoft Azure MVP

4y

Sounds very interesting.Have to try it 😊. Well done.The IoT simulator (DPS version) with CA X509 will be released soon😉.Being documented...

To view or add a comment, sign in

More articles by Kevin Hilscher

  • Step-by-step guide to installing OPC Publisher on Azure IoT Edge

    You just received your shiny, new "Edge Certified" gateway device that you ordered from the Azure IoT Device Catalog…

    15 Comments
  • IoT: Detecting bad data at the Edge

    A while back I wrote an article on methods for connecting Industrial Control Systems (ICS) with Azure and why you would…

    1 Comment
  • Automatically Deploy Visual Studio Team Services Agent to Ubuntu

    Recently I needed to deploy a Ubuntu 16.04 VM as part of a CI/CD (Continuous Integration/Continuous Deployment) process…

  • OPC UA and Azure

    Recently we have been encountering more and more customers wanting to integrate their SCADA Historians (e.g.

    4 Comments

Insights from the community

Explore topics