Generic Pelion Device Management example for various U-blox-based boards.

Dependencies:   ublox-at-cellular-interface ublox-cellular-base

DEPRECATED

This example application is not maintained and not recommended. It uses an old version of Mbed OS, Pelion DM, and Arm toolchain. It doesn't work with Mbed Studio.

Please use: https://os.mbed.com/teams/mbed-os-examples/code/mbed-os-example-pelion/

This example is known to work great on the following platforms:

For Odin-W2 please go to Repository link

Follow the Quick-Start instructions: https://cloud.mbed.com/quick-start

UBLOX_C030_U201

UBLOX_C030_R412M

Example functionality

This example showcases the following device functionality:

  • On user button click, increment Pelion LWM2M button resource.
  • Allow the user to change the state of the board LED from Pelion LWM2M led_state resource and PUT request.
  • (currently disabled) Read ADC temperature and ADC vref, and report them as Pelion LWM2M resources.

Use this example with Mbed CLI

1. Import the application into your desktop:

mbed import https://os.mbed.com/teams/ublox/code/pelion-example-common

cd pelion-example-common

2. Install the CLOUD_SDK_API_KEY

mbed config -G CLOUD_SDK_API_KEY <PELION_DM_API_KEY>

For instructions on how to generate your API key, please see the documentation.

3. Initialize firmware credentials (done once per repository). You can use the following command:

mbed dm init -d "<your company name in Pelion DM>" --model-name "<product model identifier>" -q --force

If above command do not work for your Mbed CLI, please consider upgrading Mbed CLI to version 1.8.x or above.

4. Compile and program:

mbed compile -t <toolchain> -m <TARGET_BOARD>

(supported toolchains : GCC_ARM / ARM / IAR)

Committer:
screamer
Date:
Wed Mar 27 18:57:20 2019 +0000
Revision:
7:230af466efc4
Parent:
6:2fb5057c0e42
Imporve inline documentation
Update to Mbed OS 5.11.5 and PDMC 2.2.1

Who changed what in which revision?

UserRevisionLine numberNew contents of line
screamer 0:a076a1bbe630 1 /*
screamer 0:a076a1bbe630 2 * Copyright (c) 2017 ARM Limited. All rights reserved.
screamer 0:a076a1bbe630 3 * SPDX-License-Identifier: Apache-2.0
screamer 0:a076a1bbe630 4 * Licensed under the Apache License, Version 2.0 (the License); you may
screamer 0:a076a1bbe630 5 * not use this file except in compliance with the License.
screamer 0:a076a1bbe630 6 * You may obtain a copy of the License at
screamer 0:a076a1bbe630 7 *
screamer 0:a076a1bbe630 8 * http://www.apache.org/licenses/LICENSE-2.0
screamer 0:a076a1bbe630 9 *
screamer 0:a076a1bbe630 10 * Unless required by applicable law or agreed to in writing, software
screamer 0:a076a1bbe630 11 * distributed under the License is distributed on an AS IS BASIS, WITHOUT
screamer 0:a076a1bbe630 12 * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
screamer 0:a076a1bbe630 13 * See the License for the specific language governing permissions and
screamer 0:a076a1bbe630 14 * limitations under the License.
screamer 0:a076a1bbe630 15 */
screamer 0:a076a1bbe630 16 #ifndef __MBED_CLOUD_DEV_CREDENTIALS_H__
screamer 0:a076a1bbe630 17 #define __MBED_CLOUD_DEV_CREDENTIALS_H__
screamer 0:a076a1bbe630 18
screamer 6:2fb5057c0e42 19 #if MBED_CONF_DEVICE_MANAGEMENT_DEVELOPER_MODE == 1
screamer 0:a076a1bbe630 20 #error "Replace mbed_cloud_dev_credentials.c with your own developer cert."
screamer 0:a076a1bbe630 21 #endif
screamer 0:a076a1bbe630 22
screamer 0:a076a1bbe630 23 #include <inttypes.h>
screamer 0:a076a1bbe630 24
screamer 0:a076a1bbe630 25 const char MBED_CLOUD_DEV_BOOTSTRAP_ENDPOINT_NAME[] = "";
screamer 0:a076a1bbe630 26 const char MBED_CLOUD_DEV_ACCOUNT_ID[] = "";
screamer 0:a076a1bbe630 27 const char MBED_CLOUD_DEV_BOOTSTRAP_SERVER_URI[] = "";
screamer 0:a076a1bbe630 28
screamer 0:a076a1bbe630 29 const uint8_t MBED_CLOUD_DEV_BOOTSTRAP_DEVICE_CERTIFICATE[] =
screamer 0:a076a1bbe630 30 { 0x0 };
screamer 0:a076a1bbe630 31
screamer 0:a076a1bbe630 32 const uint8_t MBED_CLOUD_DEV_BOOTSTRAP_SERVER_ROOT_CA_CERTIFICATE[] =
screamer 0:a076a1bbe630 33 { 0x0 };
screamer 0:a076a1bbe630 34
screamer 0:a076a1bbe630 35 const uint8_t MBED_CLOUD_DEV_BOOTSTRAP_DEVICE_PRIVATE_KEY[] =
screamer 0:a076a1bbe630 36 { 0x0 };
screamer 0:a076a1bbe630 37
screamer 0:a076a1bbe630 38 const char MBED_CLOUD_DEV_MANUFACTURER[] = "dev_manufacturer";
screamer 0:a076a1bbe630 39
screamer 0:a076a1bbe630 40 const char MBED_CLOUD_DEV_MODEL_NUMBER[] = "dev_model_num";
screamer 0:a076a1bbe630 41
screamer 0:a076a1bbe630 42 const char MBED_CLOUD_DEV_SERIAL_NUMBER[] = "0";
screamer 0:a076a1bbe630 43
screamer 0:a076a1bbe630 44 const char MBED_CLOUD_DEV_DEVICE_TYPE[] = "dev_device_type";
screamer 0:a076a1bbe630 45
screamer 0:a076a1bbe630 46 const char MBED_CLOUD_DEV_HARDWARE_VERSION[] = "dev_hardware_version";
screamer 0:a076a1bbe630 47
screamer 0:a076a1bbe630 48 const uint32_t MBED_CLOUD_DEV_MEMORY_TOTAL_KB = 0;
screamer 0:a076a1bbe630 49 const uint32_t MBED_CLOUD_DEV_BOOTSTRAP_DEVICE_CERTIFICATE_SIZE = sizeof(MBED_CLOUD_DEV_BOOTSTRAP_DEVICE_CERTIFICATE);
screamer 0:a076a1bbe630 50 const uint32_t MBED_CLOUD_DEV_BOOTSTRAP_SERVER_ROOT_CA_CERTIFICATE_SIZE = sizeof(MBED_CLOUD_DEV_BOOTSTRAP_SERVER_ROOT_CA_CERTIFICATE);
screamer 0:a076a1bbe630 51 const uint32_t MBED_CLOUD_DEV_BOOTSTRAP_DEVICE_PRIVATE_KEY_SIZE = sizeof(MBED_CLOUD_DEV_BOOTSTRAP_DEVICE_PRIVATE_KEY);
screamer 0:a076a1bbe630 52
screamer 0:a076a1bbe630 53 #endif //__MBED_CLOUD_DEV_CREDENTIALS_H__