Skip to content

Latest commit

 

History

History
378 lines (252 loc) · 15.3 KB

devbox_setup.md

File metadata and controls

378 lines (252 loc) · 15.3 KB

Prepare your development environment

This document describes how to prepare your development environment to use the Microsoft Azure IoT device SDK for C. It describes preparing a development environment in Windows using Visual Studio and in Linux.

Set up a Windows development environment

  • Install Visual Studio 2015. You can use the Visual Studio Community Free download if you meet the licensing requirements.

Be sure to include Visual C++ and NuGet Package Manager.

  • Install git. Confirm git is in your PATH by typing git version from a command prompt.

  • Install CMake. Make sure it is in your PATH by typing cmake -version from a command prompt. CMake will be used to create Visual Studio projects to build libraries and samples.

  • Locate the tag name for the latest release of the SDK.

Our release tag names are date values in yyyy-mm-dd format.

  • Clone the latest release of SDK to your local machine using the tag name you found:
git clone -b <yyyy-mm-dd> --recursive https://github.com/Azure/azure-iot-sdk-c.git

The --recursive argument instructs git to clone other GitHub repos this SDK depends on. Dependencies are listed here.

Build a sample application without building the SDK

To quickly build one of our sample applications, open the corresponding solution file (.sln) in Visual Studio. For example, to build our MQTT sample, open iothub_client\samples\iothub_client_sample_mqtt\windows\iothub_client_sample_mqtt.sln.

In the sample's main source file, find the line similar to this:

static const char* connectionString = "[device connection string]";

...and replace [device connection string] with a valid device connection string for a device registered with your IoT Hub. For more information, see the samples section below.

Build the sample project. As part of the build, NuGet Package Manager will download packages for dependencies so you don't have to build the entire SDK. See windows\packages.config for the list of packages that will be downloaded.

Build the C SDK in Windows

In some cases, you may want to build the SDK locally for development and testing purposes. First, take the following steps to generate project files:

  • Open a "Developer Command Prompt for VS2015".

  • Run the following CMake commands from the root of the repository:

cd azure-iot-sdk-c
mkdir cmake
cd cmake
cmake -G "Visual Studio 14 2015" ..

This builds x86 libraries. To build for x64, modify the cmake generator argument: cmake .. -G "Visual Studio 14 2015 Win64"

If project generation completes successfully, you should see a Visual Studio solution file (.sln) under the cmake folder. To build the SDK, do one of the following:

  • Open cmake\azure_iot_sdks.sln in Visual Studio and build it, OR
  • Run the following command in the command prompt you used to generate the project files:
cmake --build . -- /m /p:Configuration=Release

To build Debug binaries, use the corresponding MSBuild argument: cmake --build . -- /m /p:Configuration=Debug There are many CMake configuration options available for building the SDK. For example, you can disable one of the available protocol stacks by adding an argument to the CMake project generation command:

cmake -G "Visual Studio 14 2015" -Duse_amqp=OFF ..

Also, you can build and run unit tests:

cmake -G "Visual Studio 14 2015" -Drun_unittests=ON ..
cmake --build . -- /m /p:Configuration=Debug
ctest -C "debug" -V

Build a sample that uses WebSocket

By default the C-SDK will have web sockets enabled for AMQP and MQTT. The samples that show examples for this are iothub_client_sample_amqp_websockets and iothub_client_sample_mqtt_websockets.

Using OpenSSL in the SDK

For TLS operations the C-SDK will use Schannel on the Windows Platforms. To enable OpenSSL to be used on Windows, you will need to execute the following instructions:

OpenSSL binaries that the C-SDK depends on are ssleay32 and libeay32. You need to build and install these libraries and DLLs before you build the sample that uses them.

Below are steps to build and install OpenSSL libraries and corresponding DLLs. These steps were tested with openssl-1.0.2k.

  • Go to the [OpenSSL Github Repository] and clone the release [git clone https://github.com/openssl/openssl.git -b OpenSSL_1_0_2k]

  • For more details on supported configurations, prerequisites, and build steps read OpenSSL Installation and Compilation and Installation.

  • For x86 configuration, open "VS2015 x86 Native Tools Command Prompt" and follow the commands in the INSTALL.W32 file.

  • For x64 configuration, open "VS2015 x64 Native Tools Command Prompt" and following commands in the INSTALL.W64 file.

After completing the above steps make sure OpenSSL libraries and DLLs are in your OpenSSL install location.

Follow these steps to build the sample:

  • Open a Developer Command Prompt and change to the build_all\windows directory

  • Set OpenSSLDir and OPENSSL_ROOT_DIR environment variables to the OpenSSL install location. For example, if your OpenSSL install location is C:\usr\local\ssl, you will set following:

    set OpenSSLDir=C:\usr\local\ssl
    set OPENSSL_ROOT_DIR=C:\usr\local\ssl
  • Build the SDK to include OpenSSL:

    cd azure-iot-sdk-c
    mkdir cmake
    cd cmake
    cmake -Duse_openssl:BOOL=ON ..
    cmake --build . -- /m /p:Configuration=Release

This will build the C SDK libraries and use openssl as your TLS library.

Set up a Linux development environment

This section describes how to set up a development environment for the C SDK on Ubuntu. CMake will create makefiles and make will use them to compile the C SDK source code using the gcc compiler.

  • Make sure all dependencies are installed before building the SDK. For Ubuntu, you can use apt-get to install the right packages:

    sudo apt-get update
    sudo apt-get install -y git cmake build-essential curl libcurl4-openssl-dev libssl-dev uuid-dev
  • Verify that CMake is at least version 2.8.12:

    cmake --version

    For information about how to upgrade your version of CMake to 3.x on Ubuntu 14.04, read How to install CMake 3.2 on Ubuntu 14.04?.

  • Verify that gcc is at least version 4.4.7:

    gcc --version

    For information about how to upgrade your version of gcc on Ubuntu 14.04, read How do I use the latest GCC 4.9 on Ubuntu 14.04?.

  • Locate the tag name for the latest release of the SDK.

    Our release tag names are date values in yyyy-mm-dd format.

  • Clone the latest release of SDK to your local machine using the tag name you found:

    git clone -b <yyyy-mm-dd> --recursive https://github.com/Azure/azure-iot-sdk-c.git

    The --recursive argument instructs git to clone other GitHub repos this SDK depends on. Dependencies are listed here.

Build the C SDK in Linux

To build the SDK:

cd azure-iot-sdk-c
mkdir cmake
cd cmake
cmake ..
cmake --build .  # append '-- -j <n>' to run <n> jobs in parallel

To build Debug binaries, add the corresponding CMake option to the project generation command above, e.g.:

cmake -DCMAKE_BUILD_TYPE=Debug ..

There are many CMake configuration options available for building the SDK. For example, you can disable one of the available protocol stacks by adding an argument to the CMake project generation command:

cmake -Duse_amqp=OFF ..

Also, you can build and run unit tests:

cmake -Drun_unittests=ON ..
cmake --build .
ctest -C "debug" -V

Note: Any samples you built will not work until you configure them with a valid IoT Hub device connection string. For more information, see the samples section below.

Set up a macOS (Mac OS X) development environment

This section describes how to set up a development environment for the C SDK on macOS. CMake will create makefiles and make will use them to compile the C SDK source code using clang. clang is included with XCode.

We've tested the device SDK for C on macOS Sierra, with XCode version 8.

  • Make sure all dependencies are installed before building the SDK. For macOS, you can use Homebrew to install the right packages:

    brew update
    brew install git cmake pkgconfig openssl ossp-uuid
  • Verify that CMake is at least version 2.8.12:

    cmake --version
  • Locate the tag name for the latest release of the SDK.

    Our release tag names are date values in yyyy-mm-dd format.

  • Clone the latest release of SDK to your local machine using the tag name you found:

    git clone -b <yyyy-mm-dd> --recursive https://github.com/Azure/azure-iot-sdk-c.git

    The --recursive argument instructs git to clone other GitHub repos this SDK depends on. Dependencies are listed here.

Build the C SDK

To build the SDK:

cd azure-iot-sdk-c
mkdir cmake
cd cmake
cmake -DOPENSSL_ROOT_DIR:PATH=/usr/local/opt/openssl ..
cmake --build .  # append '-- -j <n>' to run <n> jobs in parallel

To build Debug binaries, add the corresponding CMake option to the project generation command above, e.g.:

cmake -DOPENSSL_ROOT_DIR:PATH=/usr/local/opt/openssl -DCMAKE_BUILD_TYPE=Debug ..

There are many CMake configuration options available for building the SDK. For example, you can disable one of the available protocol stacks by adding an argument to the CMake project generation command:

cmake -Duse_amqp=OFF ..

Also, you can build and run unit tests:

cmake -Drun_unittests=ON ..
cmake --build .
ctest -C "debug" -V

Note: Any samples you built will not work until you configure them with a valid IoT Hub device connection string. For more information, see the samples section below.

Set up a Windows Embedded Compact 2013 development environment

  • Install Visual Studio 2015. You can use the Visual Studio Community Free download if you meet the licensing requirements.

    Be sure to include Visual C++ and NuGet Package Manager.

  • Install Application Builder for Windows Embedded Compact 2013 for Visual Studio 2015

  • Install Toradex Windows Embedded Compact 2013 SDK or your own SDK.

  • Install git. Confirm git is in your PATH by typing git version from a command prompt.

  • Install CMake. Make sure it is in your PATH by typing cmake -version from a command prompt. CMake will be used to create Visual Studio projects to build libraries and samples.

  • Locate the tag name for the latest release of the SDK.

    Our release tag names are date values in yyyy-mm-dd format.

  • Clone the latest release of SDK to your local machine using the tag name you found:

    git clone -b <yyyy-mm-dd> --recursive https://github.com/Azure/azure-iot-sdk-c.git

    The --recursive argument instructs git to clone other GitHub repos this SDK depends on. Dependencies are listed here.

If you installed a different SDK please check azure-iot-sdk-c\build_all\windowsce\build.cmd and replace:

set SDKNAME=TORADEX_CE800
set PROCESSOR=arm

with a reference to the name of the SDK and the processor architecture (arm/x86) you plan to use.

Verify your environment

You can build the Windows samples to verify that your environment is set up correctly.

  • Open a "Developer Command Prompt for VS2015".
  • Navigate to the build_all\windowsce folder in your local copy of the repository.
  • Run the following command:
build

This script uses CMake to create a folder called "cmake_ce8" in your home directory and generates in that folder a Visual Studio solution called azure_iot_sdks.sln. The script will then proceed to build the HTTP sample.

Note: you will not be able to run the samples until you configure them with a valid IoT hub device connection string. For more information, see running a C sample application on Windows Embedded Compact 2013 on a Toradex module.

To view the projects and examine the source code, open the azure_iot_sdks.sln solution file in Visual Studio.

You can use one of the sample applications as a template to get started when you are creating your own client applications.

Sample applications

This repository contains various C sample applications that illustrate how to use the Azure IoT device SDK for C:

-Simple samples for the device SDK

-Samples using the serializer library

Once the SDK is building successfully you can run any of the available samples using the following (example given for a linux system):

-Edit the sample file entering the proper connection string from the Azure Portal:

static const char* connectionString = "[device connection string]";

-Navigate to the directory of the sample that was edited, build the sample with the new changes and execute the sample:

cd ./azure-iot-sdk-c/cmake/iothub_client/samples/iothub_client_sample_amqp
make
./iothub_client_sample_amqp