Intel vPro Detector

A program to detect the presence of Intel vPro and the status of Intel AMT

Sep 03, 2020

1 minute


Built with

Electron
Next.js
Tailwind CSS
Intel
Golang

This tool was produced to detect the presence of Intel vPro and the status of Intel AMT. Intel vPro is a collection of security features included in Intel processors. One of these features is Intel AMT, this allows for remote access from the BIOS level, meaning it can be recovered from more serious failures.

I initially wrote this tool in Golang as a proof of concept. This was functional, but suffered from two major problems.

  1. I was using a separate executable to find the raw statuses, and this would have to be downloaded separately to the tool I was creating
  2. It was difficult to add a good GUI

For these reasons I decided to look into alternate ways of creating desktop applications. One that stood out to me was Electron as I am already very familiar with web development and it had a range of bundling options that help solve my first issue.

For the exact implementation of Electron, I chose nextron as I was recently learning Next.js and wanted to get more experience in it, and it provides lots of boilerplate code to get me started.

To solve the first problem, I used the extraFiles key from electron-builder, this allows you to include a file that the program will see in it’s root directory, perfect for what I need.

To run the file I used sudo-prompt, which allows me to run a command using administrator privileges, which the executable needed as it reads from the registry. I then processed the output of that using the built in XML parser in JavaScript to get the values I need.

These values were then inserted into the user interface in the following way