mirror of
https://github.com/RIOT-OS/RIOT.git
synced 2025-01-16 14:52:45 +01:00
114 lines
4.4 KiB
Markdown
114 lines
4.4 KiB
Markdown
# Wakaama LwM2M example client
|
|
|
|
This application starts a
|
|
[LwM2M](https://wiki.openmobilealliance.org/display/TOOL/What+is+LwM2M) client
|
|
on the node with instances of the following objects:
|
|
- [Security object](http://www.openmobilealliance.org/tech/profiles/LWM2M_Security-v1_0.xml)
|
|
- [Server object](http://www.openmobilealliance.org/tech/profiles/LWM2M_Server-v1_0.xml)
|
|
- [Device object](http://www.openmobilealliance.org/tech/profiles/LWM2M_Device-v1_0_3.xml)
|
|
|
|
The application is based on the Eclipse Wakaama
|
|
[example client](https://github.com/eclipse/wakaama/tree/master/examples/client)
|
|
.
|
|
|
|
## Usage
|
|
|
|
### Setting up a LwM2M Test Server
|
|
To test the client a LwM2M server where to register is needed.
|
|
[Eclipse Leshan](https://github.com/eclipse/leshan) demo is a good option for
|
|
running one locally.
|
|
|
|
To run the demo server:
|
|
```shell
|
|
wget https://hudson.eclipse.org/leshan/job/leshan/lastSuccessfulBuild/artifact/leshan-server-demo.jar
|
|
|
|
java -jar ./leshan-server-demo.jar
|
|
```
|
|
It will output the addresses where it is listening:
|
|
```
|
|
INFO LeshanServer - LWM2M server started at coap://0.0.0.0/0.0.0.0:5683 coaps://0.0.0.0/0.0.0.0:5684
|
|
INFO LeshanServerDemo - Web server started at http://0.0.0.0:8080/.
|
|
```
|
|
|
|
Additionally, you can specify a binding address for the Leshan server, using
|
|
the `-lh` option. For instance, if you are connecting from a node via a Border
|
|
Router, you might want to specify:
|
|
|
|
```shell
|
|
java -jar ./leshan-server-demo.jar -lh fd00:dead:beef::1
|
|
```
|
|
|
|
#### Bootstrap server
|
|
LwM2M provides a bootstrapping mechanism to provide the clients with information
|
|
to register to one or more servers. To test this mechanism both the previous server and a bootstrap server should be running. Eclipse Leshan also provides a bootstrap server demo.
|
|
|
|
By default the bootstrap server option is disabled, it can be enabled by defining
|
|
`CONFIG_LWM2M_BOOTSTRAP` as 1 (see the Makefile in this application).
|
|
|
|
To run the bootstrap server, make sure that the ports it uses are different
|
|
from the ones of previous server (default are 5683 for CoAP, 5684 for CoAPs,
|
|
and 8080 for the webserver), and that it corresponds to the one set in
|
|
`lwm2m.h` as `CONFIG_LWM2M_BSSERVER_PORT`:
|
|
```shell
|
|
# download demo
|
|
wget https://hudson.eclipse.org/leshan/job/leshan/lastSuccessfulBuild/artifact/leshan-bsserver-demo.jar
|
|
|
|
# set CoAP, CoAPs and webserver ports for bootstrap server
|
|
BS_COAPPORT=5685
|
|
BS_COAPSPORT=5686
|
|
BS_WEBPORT=8888
|
|
|
|
# run the server
|
|
java -jar ./leshan-bsserver-demo.jar --coapport ${BS_COAPPORT} \
|
|
--coapsport ${BS_COAPSPORT} --webport ${BS_WEBPORT}
|
|
```
|
|
|
|
To set up the configuration of the node and the server:
|
|
1. Click the `Add new client bootstrap configuration` button.
|
|
2. Fill in the name of the device, it **should** match the one set in
|
|
`lwm2m.h` as `CONFIG_LWM2M_DEVICE_NAME`.
|
|
3. Using the `LWM2M Server` tab enter the address where the LwM2M server is
|
|
listening. For now only `No security` mode can be used.
|
|
|
|
### Running the client
|
|
The address set as `CONFIG_LWM2M_SERVER_URI` (in `lwm2m.h` or via `menuconfig`)
|
|
should be reachable from the node, e.g. either running on native with a tap
|
|
interface or as a mote connected to a
|
|
[border router](https://github.com/RIOT-OS/RIOT/tree/master/examples/gnrc_border_router).
|
|
|
|
Also, if a bootstrap server is being used the macro `CONFIG_LWM2M_BOOTSTRAP` should be
|
|
defined as 1.
|
|
|
|
The server URI for the example is being defined using the variable `SERVER_URI`
|
|
in the Makefile, and can be changed when compiling.
|
|
|
|
#### Configure, compile and run
|
|
|
|
The Wakaama package can be configured via Kconfig. Its options are placed
|
|
under `Packages > Configure Wakaama LwM2M`. To access the configuration
|
|
interface you can run:
|
|
```
|
|
make menuconfig
|
|
```
|
|
|
|
For debugging purposes there are two types of messages that can be enabled:
|
|
- The lwm2m client adaptation debug can be enabled by setting `ENABLE_DEBUG` in
|
|
`lwm2m_client.c` and `lwm2m_client_connection.c` to 1
|
|
- The wakaama internal logging can be enabled by setting
|
|
`CONFIG_LWM2M_WITH_LOGS`, either on `menuconfig` or by adding it to CFLAGS
|
|
(`CFLAGS += -DCONFIG_LWM2M_WITH_LOGS`).
|
|
|
|
For memory allocation the TLSF package is being used, with a private heap. If
|
|
memory usage has to be tweaked the heap size can be modified via the option
|
|
`CONFIG_LWM2M_TLSF_BUFFER`.
|
|
|
|
To compile run:
|
|
|
|
```shell
|
|
BOARD=<board> make clean all flash term
|
|
```
|
|
|
|
#### Shell commands
|
|
- `lwm2m start`: Starts the LwM2M by configuring the module and registering to
|
|
the server.
|