Skip to content
This repository has been archived by the owner on Apr 5, 2023. It is now read-only.

Latest commit

 

History

History
106 lines (77 loc) · 5.77 KB

setup.md

File metadata and controls

106 lines (77 loc) · 5.77 KB

Secure Device Onboard (SDO) Compilation Setup

1. Intel safestringlib

SDO client-sdk uses safestringlib for string and memory operations to prevent serious security vulnerabilities (For example, buffer overflows).

  1. For Linux*/ Arm Mbed* OS/ Arm Mbed Linux OS builds, download safestring from intel-safestringlib.

2. Setting the Manufacturer Network Address

To set the manufacturer network address(domain name or IP) that SDO Linux device uses during Device Initialization (DI) protocol:

# To set the manufacturer DNS
$ cd <path-to-sdo-client-sdk>
$ echo -n <manufacturer domain-name> > data/manufacturer_dn.bin

or

# To set the manufacturer IP
$ cd <path-to-sdo-client-sdk>
$ echo -n <manufacturer server-ip> > data/manufacturer_ip.bin

The default manufacturer port is 8039. If required, it can be configured by following instructions:

# For setting manufacturer port
$ cd <path-to-sdo-client-sdk>
$ echo -n <manufacturer server-port> > data/manufacturer_port.bin

Note: By default, manufacturer_dn.bin is configured with "localhost". If both IP and domain name are set, the IP takes precedence over domain name.

3. Elliptic Curve Digital Signature Algorithm (ECDSA) Private Key File Generation

The following are steps to generate the private key file for ECDSA-based devices, only EC Curve P-256 and P-384 are supported.

  • Generate EC private key (optional, if not already generated):

    $ openssl ecparam -name prime256v1 -genkey -noout -out key.pem #For P-256

    or

    $ openssl ecparam -name secp384r1 -genkey -noout -out key.pem #For P-384
  • Option1 (default): To generate the binary private key data file

  1. To parse the Privacy-Enhanced Mail (PEM)-formatted EC private key to generate the private key in binary format:

    $ openssl asn1parse < key.pem

    Note: An example of output from the preceding command:
    ......
    ......
    .. [HEX DUMP]:A253014C61B6AEB5FA867B5417CD4A87D45BD6A505E81060D064529D0540CD36
    ......
    ......

  2. Use the [HEX DUMP] information from the above to generate the respective EC key (.dat) file (ecdsa256privkey.dat for EC curve P-256 and ecdsa384privkey.dat for EC curve P-384): For example,

    $ echo 'A253014C61B6AEB5FA867B5417CD4A87D45BD6A505E81060D064529D0540CD36' | xxd -r -p > ecdsaXXXprivkey.dat

    The respective ecdsaXXXprivkey.dat file will be used by the SDO target binary (Linux* or Arm* Mbed* OS) while ECDSA sign operation.

  • Option2: To use the private key in PEM format, rename key.pem to ecdsaXXXprivkey.pem (ecdsa256privkey.pem for EC curve P-256 and ecdsa384privkey.pem for EC curve P-384). Use the compilation flag DA_FILE=pem during binary creation.

4. SDO Credentials REUSE Protocol

The SDO credentials REUSE feature allows SDO devices to reuse their ownership credentials across multiple device onboardings. This feature only gets enabled if the owner sends down the same rendezvous info, device GUID information, and public key at the end of the Transfer of Ownership, Step 2 (TO2) protocol.

Specifically, if TO2.SetupDevice.r3, TO2.SetupDevice.g3, and TO2.SetupDevice.pk match the corresponding values held by the device, the device will not generate a Hash-based Message Authentication Code (HMAC), which then allows the original ownership voucher (OV) to be used for another (and subsequent) onboarding(s) by reusing the same device credentials multiple times.

However, device client binary must be generated using -DREUSE=true flag:

$ cmake -DREUSE=true

Activating the device credentials will in turn, activate the SDO device and configure the SDO device to run multiple onboarding(s). This can be useful in several test and development environments, where multiple onboardings are common.

Note: To run SDO Client-SDK binaries in REUSE mode, the following configuration need to be taken care of while launching SDO servers:

  • “TO2_CREDENTIAL_REUSE_ENABLED=true” should be set in ocs.env file in Owner server (iot-platform-sdk).

5. HTTP-proxy configuration (optional)

If the device is located behind a proxy server, the proxy server details must be provided to the device. For the same purpose, there are three files (each for the manufacturer, rendezvous, and owner servers) in which the proxy server details should be specified in the required format, before connecting to the respective server. These files can be created or removed as required.

Each proxy file is located in the data/ directory and named as follows:

  • mfg_proxy.dat - holds the proxy server network address between the device and manufacturer.
  • rv_proxy.dat - holding the proxy server network address between the device and the rendezvous server.
  • owner_proxy.dat - holds the proxy server network address between the device and owner.

The following is the format for proxy server network address:

<Proxy Server IP>:<proxy Server Port>  e.g. 255.255.255.255:65535

Note: The files rv_proxy.dat,mfg_proxy.dat, and owner_proxy.dat must not contain any other information beyond the information mentioned above.

The proxy server network address is optional if the device connects to an access point that connects the device through the proxy server.

Note : SDO clients that run on the Linux* OS also support network proxy discovery using the environment variable or the Web Proxy Auto-Discovery (WPAD) protocol based on the libproxy library. To use wpad protocol, use export http_proxy=’wpad:’.