There are two options for building the IoT Edge Security Daemon.
-
Build the OS packages. If you just want to build something that you can install on your device, and are not making frequent changes to the daemon's source code, you probably want this option.
-
Build the daemon binaries. If you want to make frequent changes to the daemon's source code and run it without installing it, you probably want this option.
Linux packages are built using the edgelet/build/linux/package.sh
script. Set the following environment variables, then invoke the script:
-
PACKAGE_OS
: This is the OS on which the resulting packages will be installed. It should be one ofcentos7
,debian9
,debian10
,debian11
,ubuntu18.04
, orubuntu20.04
-
PACKAGE_ARCH
: This is the architecture of the OS on which the resulting packages will be installed. It should be one ofamd64
,arm32v7
oraarch64
.
For example:
git clone --recurse-submodules 'https://github.com/Azure/iotedge'
cd iotedge/
PACKAGE_OS='debian10' PACKAGE_ARCH='arm32v7' ./edgelet/build/linux/package.sh
The packages are built inside a Docker container, so no build dependencies are installed on the device running the script. However the user running the script does need to have permissions to invoke the docker
command.
Note that the script must be run on an amd64
device. The PACKAGE_ARCH=arm32v7
and PACKAGE_ARCH=aarch64
builds are done using a cross-compiler.
Once the packages are built, they will be found somewhere under the edgelet/target/
directory. (The exact path under that directory depends on the combination of PACKAGE_OS
and PACKAGE_ARCH
. See builds/misc/packages.yaml
and builds/misc/packages.slow.yaml
for the exact paths.)
If you want to run another build for a different combination of PACKAGE_OS
and PACKAGE_ARCH
, make sure to clean the repository first with sudo git clean -xffd
so that artifacts from the previous build don't get reused for the next one.
Note: For the following targets, qemu-user-static
must be installed on the host and registered with binfmt
:
PACKAGE_OS=centos7 PACKAGE_ARCH=arm32v7
PACKAGE_OS=centos7 PACKAGE_ARCH=aarch64
If that has not been done, package.sh
prints an error message explaining how to do that.
This is because these targets do not have functional cross-compilers, so their builds are done as native builds emulated using qemu. Be aware that these builds are much slower - where a native build might take 15m, a qemu build might take 2h30m.
See "Building daemon binaries" below.
The daemon is written in Rust, so you will need an installation of the Rust compiler. It is recommended to use rustup
to install a Rust toolchain. For Linux, some distributions have their own packages for rustc
and cargo
, but these might not match the toolchain used by our code and may fail to build it.
After installing rustup
, or if you already have it installed, install the toolchain that will be used to build the daemon binaries.
rustup self update # Update rustup itself to the latest version
git clone --recurse-submodules 'https://github.com/Azure/iotedge'
cd iotedge/edgelet/
rustup update # Install / update the toolchain used to build the daemon binaries.
# This is controlled by the rust-toolchain file in this directory.
# For the master branch, this is the latest "stable" toolchain.
# For release branches, this is a pinned Rust release.
In addition, building the daemon binaries also requires these dependencies to be installed:
yum update
yum install \
cmake curl git make rpm-build \
gcc gcc-c++ \
libcurl-devel libuuid-devel openssl-devel
apt-get update
apt-get install \
binutils build-essential ca-certificates curl cmake debhelper file git make \
gcc g++ pkg-config \
libcurl4-openssl-dev libssl-dev uuid-dev
apt-get update
apt-get install \
binutils build-essential ca-certificates curl cmake debhelper dh-systemd file git make \
gcc g++ pkg-config \
libcurl4-openssl-dev libssl-dev uuid-dev
-
Install the dependencies using Homebrew package manager
brew update brew install cmake openssl
-
Set the
OPENSSL_DIR
andOPENSSL_ROOT_DIR
environment variables to point to the local openssl installation.export OPENSSL_DIR=/usr/local/opt/openssl export OPENSSL_ROOT_DIR=/usr/local/opt/openssl
-
Install Visual Studio 2017 / 2019, or the Build Tools for Visual Studio 2017 / 2019. Ensure the components for building C / C++ are installed.
-
Install
cmake
from https://cmake.org/ or withchoco
orscoop
. Ensurecmake
is inPATH
after installation. -
Install
vcpkg
git clone https://github.com/Microsoft/vcpkg cd vcpkg .\bootstrap-vcpkg.bat
-
Install openssl
.\vcpkg install openssl:x64-windows
-
Set the
OPENSSL_DIR
andOPENSSL_ROOT_DIR
environment variables to point to the local openssl installation.# $PWD is the root of the vcpkg repository $env:OPENSSL_DIR = "$PWD\installed\x64-windows" $env:OPENSSL_ROOT_DIR = "$PWD\installed\x64-windows"
To build the project, use:
cd edgelet/
cargo build -p aziot-edged -p iotedge
This will create aziot-edged
and iotedge
binaries under edgelet/target/debug
To run aziot-edged
locally:
-
Create a directory that it will use as its home directory, such as
~/iotedge
-
Linux / macOS
export IOTEDGE_HOMEDIR=~/iotedge mkdir -p "$IOTEDGE_HOMEDIR"
-
Windows
$env:IOTEDGE_HOMEDIR = Resolve-Path ~/iotedge New-Item -Type Directory -Force $env:IOTEDGE_HOMEDIR
-
-
Create a
config.yaml
. It's okay to create this under theIOTEDGE_HOMEDIR
directory. -
Run the daemon with the
IOTEDGE_HOMEDIR
environment variable set and with the path to theconfig.yaml
cargo run -p aziot-edged -- -c /absolute/path/to/config.yaml
cargo test --all
In order to run Code Coverage Checks locally do the following
#Run From the Edgelet Directory
cd edgelet
#One Time Setup Only.
cargo install cargo-tarpaulin
#Run Unit Test with Code Coverage
cargo tarpaulin --out Xml --output-dir .
You should see an output like this
.
.
.
|| support-bundle/src/error.rs: 0/9
|| support-bundle/src/runtime_util.rs: 0/18
|| support-bundle/src/shell_util.rs: 0/117
|| support-bundle/src/support_bundle.rs: 0/50
||
46.28% coverage, 2993/6467 lines covered
Additionally, You can also view a HTML Report highlighting code sections covered using the following
#One Time Setup Only.
pip install pycobertura
#Create an HTML Report for viewing using pycobertura
pycobertura show --format html --output coverage.html cobertura.xml
-
rustfmt
This tool automatically formats the Rust source code. Our checkin gates assert that the code is correctly formatted.
Install it with:
cd edgelet/ rustup component add rustfmt
To format the source code, run:
cargo fmt --all
To verify the source code is already correctly formatted, run:
cargo fmt --all -- --check
-
clippy
This is a Rust linter. It provides suggestions for more idiomatic Rust code and detects some common mistakes. Our checkin gates assert that clippy raises no warnings or errors when run against the code.
Install it with:
cd edgelet/ rustup component add clippy
Run it with:
cargo clippy --all cargo clippy --all --tests cargo clippy --all --examples
-
Swagger
Some of our source code is generated from swagger definitions stored as YAML.
You can edit the definitions in VS code, but https://editor.swagger.io is also an invaluable tool for validation, converting YAML -> JSON for code-gen, etc.
We use a modified version of
swagger-codegen
to generate code from the swagger definitions. To build the tool:git clone -b support-rust-uds https://github.com/avranju/swagger-codegen.git cd swagger-codegen mvn clean package
To run the tool, for example to update our workload API:
java -jar swagger-codegen-cli.jar generate -i api/workload.yaml -l rust -o {root}/edgelet/workload
Note that we've manually fixed up the generated code so that it satisfies rustfmt and clippy. As such, if you ever need to run
swagger-codegen-cli
against new definitions, or need to regenerate existing ones, you will want to perform the same fixups manually. Make sure to run clippy and rustfmt against the new code yourself, and inspect the diffs of modified files before checking in.For more details, please visit How to build Management API using Swagger-Codegen
-
IDE
VS Code has good support for Rust. Consider installing the following extensions:
- Rust (rls) - Syntax highlighting and Intellisense support
- Better TOML - Syntax highlighting for
Cargo.toml
- C/C++ - Native debugger support
- Vim - For a more sophisticated editor experience :)
Alternatively, IntelliJ IDEA Community Edition with the Rust plugin provides a full IDE experience for programming in Rust.
If you would like to know how to test IoT Edge daemon API endpoints on dev machine, please read from here.
-
Rust API Guidelines - Guidelines on naming conventions, organization, function semantics, etc.