2017-07-03 01:32:46 +02:00
|
|
|
/**
|
2021-03-11 15:12:27 +01:00
|
|
|
* @defgroup pkg_wakaama LwM2M - Lightweight Machine to Machine
|
2017-07-03 01:32:46 +02:00
|
|
|
* @ingroup pkg
|
2017-07-03 11:18:47 +02:00
|
|
|
* @ingroup net
|
2021-03-11 15:12:27 +01:00
|
|
|
* @brief LwM2M implementation based on the Wakaama package
|
2021-03-12 19:07:39 +01:00
|
|
|
*
|
|
|
|
* Lightweight Machine to Machine is a device management protocol designed for sensor networks,
|
|
|
|
* designed for remote management of M2M devices and related service enablement. It defines an
|
|
|
|
* extensible resource and data model and builds top of CoAP. LwM2M has been specified by the
|
|
|
|
* OMA SpecWorks Device Management Working Group. The specification is freely available
|
|
|
|
* [here](http://openmobilealliance.org/wp/index.html).
|
2021-03-11 15:12:27 +01:00
|
|
|
*
|
|
|
|
* For a list of the supported objects see @ref lwm2m_objects.
|
2021-03-12 19:07:39 +01:00
|
|
|
* The client implementation is based on the Eclipse
|
|
|
|
* [Wakaama project](https://github.com/eclipse/wakaama)
|
|
|
|
*
|
|
|
|
*
|
|
|
|
* ## Usage
|
|
|
|
* A LwM2M Client organizes resources as object instances. The LwM2M engine is independent of the
|
|
|
|
* objects that the client exposes, but it needs at least 3 mandatory ones:
|
|
|
|
* @ref lwm2m_objects_device "Device object", @ref lwm2m_objects_security "Security object" and a
|
|
|
|
* Server object.
|
|
|
|
*
|
|
|
|
* ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ {.c}
|
|
|
|
* #include "lwm2m_client.h"
|
|
|
|
* #include "lwm2m_client_objects.h"
|
|
|
|
* #include "objects/security.h"
|
|
|
|
* #include "objects/device.h"
|
|
|
|
* #include "net/credman.h"
|
|
|
|
*
|
|
|
|
* // hold references to object handles
|
|
|
|
* lwm2m_object_t *obj_list[3];
|
|
|
|
*
|
|
|
|
* // LwM2M Client instance
|
|
|
|
* lwm2m_client_data_t client_data;
|
|
|
|
*
|
|
|
|
* // short ID for internal reference of the server
|
|
|
|
* #define CONFIG_LWM2M_SERVER_SHORT_ID 1
|
|
|
|
*
|
|
|
|
* int main(void)
|
|
|
|
* {
|
|
|
|
*
|
|
|
|
* // initiate the LwM2M Client
|
|
|
|
* lwm2m_client_init(&client_data);
|
|
|
|
*
|
|
|
|
* // arguments for instantiating a security object
|
|
|
|
* lwm2m_obj_security_args_t args = {
|
|
|
|
* .server_id = CONFIG_LWM2M_SERVER_SHORT_ID,
|
|
|
|
* .server_uri = "coap://[fd00:dead:beef::1]:5683",
|
|
|
|
* .security_mode = LWM2M_SECURITY_MODE_NONE,
|
|
|
|
* .is_bootstrap = false,
|
|
|
|
* .client_hold_off_time = 5,
|
|
|
|
* .bootstrap_account_timeout = 0
|
|
|
|
* };
|
|
|
|
*
|
|
|
|
* // get the Security object handle
|
|
|
|
* obj_list[0] = lwm2m_object_security_init(&client_data);
|
|
|
|
*
|
|
|
|
* // create a new Security object instance
|
|
|
|
* int res = lwm2m_object_security_instance_create(&args, 1);
|
|
|
|
* if (res < 0) {
|
|
|
|
* puts("Could not instantiate the security object");
|
|
|
|
* return;
|
|
|
|
* }
|
|
|
|
*
|
|
|
|
* // get the Server object handle (only single instance for now)
|
|
|
|
* obj_list[1] = lwm2m_client_get_server_object(&client_data, CONFIG_LWM2M_SERVER_SHORT_ID);
|
|
|
|
*
|
|
|
|
* // device object has a single instance. All the information for now is defined at compile-time
|
|
|
|
* obj_list[2] = lwm2m_object_device_get();
|
|
|
|
*
|
|
|
|
* // run the LwM2M client
|
|
|
|
* lwm2m_client_run(&client_data, obj_list, ARRAY_SIZE(obj_list);
|
|
|
|
* }
|
|
|
|
* ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
|
|
*
|
|
|
|
* The LwM2M Client will connect to the specified LwM2M server and register itself. After that, the
|
|
|
|
* server will be able to perform Read, Write, Create, Delete, Execute and Observe operations on the
|
|
|
|
* resources.
|
|
|
|
*
|
|
|
|
* ### DTLS support
|
|
|
|
* With the configuration above plain CoAP is used. To secure the connection with the LwM2M Server,
|
|
|
|
* a credential is needed in the Security object instance. To enable DTLS support add the module
|
|
|
|
* `wakaama_client_dtls`. This uses the @ref net_sock_dtls, so you will need to select an
|
|
|
|
* implementation of it (e.g. `USEPKG += tinydtls`). Currently Pre-Shared Key (PSK) and Raw Public
|
|
|
|
* Key (RPK) modes are supported.
|
|
|
|
*
|
|
|
|
* To see how to use DTLS credentials, go to the usage section of @ref lwm2m_objects_security.
|
|
|
|
*
|
|
|
|
* ### Using a LwM2M Bootstrap Server
|
|
|
|
* A bootstrap server gives a LwM2M deployment more flexibility. Information on how to connect to the
|
|
|
|
* LwM2M bootstrap server is defined at compile-time in the client (including URI and potentially
|
|
|
|
* needed credentials). The client connects to the bootstrap server on boot, which installs on the
|
|
|
|
* node the information needed to connect to the LwM2M servers.
|
|
|
|
*
|
|
|
|
* To enable bootstrap support, set the `LWM2M_BOOTSTRAP` option on Kconfig or set the CFLAG
|
|
|
|
* `CONFIG_LWM2M_BOOTSTRAP=1`. You will also need to specify during the security object instantiation
|
|
|
|
* that the information corresponds to a bootstrap server. DTLS is also supported for the bootstrap
|
|
|
|
* server:
|
|
|
|
*
|
|
|
|
* ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ {.c}
|
|
|
|
* lwm2m_obj_security_args_t args = {
|
|
|
|
* .server_id = 1,
|
|
|
|
* .server_uri = "coaps://[fd00:dead:beef::1]:5684",
|
|
|
|
* .security_mode = LWM2M_SECURITY_MODE_PRE_SHARED_KEY,
|
|
|
|
* .pub_key_or_id = psk_id,
|
|
|
|
* .pub_key_or_id_len = sizeof(psk_id) - 1,
|
|
|
|
* .secret_key = psk_key,
|
|
|
|
* .secret_key_len = sizeof(psk_key) - 1,
|
|
|
|
* .is_bootstrap = true,
|
|
|
|
* .client_hold_off_time = 5,
|
|
|
|
* .bootstrap_account_timeout = 0
|
|
|
|
* };
|
|
|
|
* ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
|
|
*
|
|
|
|
* Keep into account, that some Sock DTLS implementations may need some extra configuration to handle
|
|
|
|
* multiple connections. See the `example/wakaama` Makefile.
|
|
|
|
*
|
2021-03-11 15:12:27 +01:00
|
|
|
*/
|