2013-03-26 12:09:49 +00:00
|
|
|
A Quick Introduction to the Erbium (Er) REST Engine
|
|
|
|
===================================================
|
|
|
|
|
|
|
|
EXAMPLE FILES
|
|
|
|
-------------
|
|
|
|
|
2017-09-01 15:45:50 +00:00
|
|
|
- coap-example-server.c: A RESTful server example showing how to use the REST
|
2013-03-26 12:09:49 +00:00
|
|
|
layer to develop server-side applications (at the moment only CoAP is
|
|
|
|
implemented for the REST Engine).
|
2017-09-01 15:45:50 +00:00
|
|
|
- coap-example-client.c: A CoAP client that polls the /actuators/toggle resource
|
2013-03-26 12:09:49 +00:00
|
|
|
every 10 seconds and cycles through 4 resources on button press (target
|
|
|
|
address is hard-coded).
|
2017-09-01 15:45:50 +00:00
|
|
|
- plugtest-server.c: The server used for draft compliance testing at ETSI
|
2013-06-19 12:53:21 +00:00
|
|
|
IoT CoAP Plugtests. Erbium (Er) participated in Paris, France, March 2012 and
|
|
|
|
Sophia-Antipolis, France, November 2012 (configured for minimal-net).
|
2013-03-26 12:09:49 +00:00
|
|
|
|
|
|
|
PRELIMINARIES
|
|
|
|
-------------
|
|
|
|
|
|
|
|
- Make sure rpl-border-router has the same stack and fits into mote memory:
|
|
|
|
You can disable RDC in border-router project-conf.h (not really required as BR keeps radio turned on).
|
|
|
|
#define NETSTACK_CONF_RDC nullrdc_driver
|
2014-05-15 11:12:22 +00:00
|
|
|
- Alternatively, you can use the native-border-router together with the slip-radio.
|
2013-03-26 12:09:49 +00:00
|
|
|
- For convenience, define the Cooja addresses in /etc/hosts
|
2015-09-30 14:06:58 +00:00
|
|
|
fd00::0212:7401:0001:0101 cooja1
|
|
|
|
fd00::0212:7402:0002:0202 cooja2
|
2013-03-26 12:09:49 +00:00
|
|
|
...
|
|
|
|
- Get the Copper (Cu) CoAP user-agent from
|
|
|
|
[https://addons.mozilla.org/en-US/firefox/addon/copper-270430](https://addons.mozilla.org/en-US/firefox/addon/copper-270430)
|
|
|
|
- Optional: Save your target as default target
|
|
|
|
make TARGET=sky savetarget
|
|
|
|
|
|
|
|
COOJA HOWTO
|
|
|
|
-----------
|
|
|
|
|
|
|
|
###Server only:
|
|
|
|
|
|
|
|
make TARGET=cooja server-only.csc
|
|
|
|
|
|
|
|
Open new terminal
|
|
|
|
|
|
|
|
make connect-router-cooja
|
|
|
|
|
|
|
|
- Start Copper and discover resources at coap://cooja2:5683/
|
|
|
|
- Choose "Click button on Sky 2" from the context menu of mote 2 (server) after
|
|
|
|
requesting /test/separate
|
|
|
|
- Do the same when observing /test/event
|
|
|
|
|
|
|
|
###With client:
|
|
|
|
|
|
|
|
make TARGET=cooja server-client.csc
|
|
|
|
|
|
|
|
Open new terminal
|
|
|
|
|
|
|
|
make connect-router-cooja
|
|
|
|
|
|
|
|
- Wait until red LED toggles on mote 2 (server)
|
|
|
|
- Choose "Click button on Sky 3" from the context menu of mote 3 (client) and
|
|
|
|
watch serial output
|
|
|
|
|
|
|
|
TMOTES HOWTO
|
|
|
|
------------
|
|
|
|
|
|
|
|
###Server:
|
|
|
|
|
|
|
|
1. Connect two Tmote Skys (check with $ make TARGET=sky sky-motelist)
|
|
|
|
|
2017-09-01 15:45:50 +00:00
|
|
|
make TARGET=sky coap-example-server.upload MOTE=2
|
2013-03-26 12:09:49 +00:00
|
|
|
make TARGET=sky login MOTE=2
|
|
|
|
|
|
|
|
2. Press reset button, get address, abort with Ctrl+C:
|
|
|
|
Line: "Tentative link-local IPv6 address fe80:0000:0000:0000:____:____:____:____"
|
|
|
|
|
2017-10-28 22:48:46 +00:00
|
|
|
cd ../rpl-border-router/
|
2013-03-26 12:09:49 +00:00
|
|
|
make TARGET=sky border-router.upload MOTE=1
|
|
|
|
make connect-router
|
|
|
|
|
|
|
|
For a BR tty other than USB0:
|
|
|
|
|
|
|
|
make connect-router-port PORT=X
|
|
|
|
|
|
|
|
3. Start Copper and discover resources at:
|
|
|
|
|
2015-09-30 14:06:58 +00:00
|
|
|
coap://[fd00::____:____:____:____]:5683/
|
2013-03-26 12:09:49 +00:00
|
|
|
|
|
|
|
### Add a client:
|
|
|
|
|
2017-09-01 15:45:50 +00:00
|
|
|
1. Change the hard-coded server address in coap-example-client.c to fd00::____:____:____:____
|
2013-03-26 12:09:49 +00:00
|
|
|
2. Connect a third Tmote Sky
|
|
|
|
|
2017-09-01 15:45:50 +00:00
|
|
|
make TARGET=sky coap-example-client.upload MOTE=3
|
2013-03-26 12:09:49 +00:00
|
|
|
|
|
|
|
MINIMAL-NET HOWTO
|
|
|
|
-----------------
|
|
|
|
|
|
|
|
With the target minimal-net you can test your CoAP applications without
|
|
|
|
constraints, i.e., with large buffers, debug output, memory protection, etc.
|
2017-09-01 15:45:50 +00:00
|
|
|
The plugtest-server is thought for the minimal-net platform, as it requires
|
2013-03-26 12:09:49 +00:00
|
|
|
an 1280-byte IP buffer and 1024-byte blocks.
|
|
|
|
|
2017-09-01 15:45:50 +00:00
|
|
|
make TARGET=minimal-net plugtest-server
|
|
|
|
sudo ./plugtest-server.minimal-net
|
2013-03-26 12:09:49 +00:00
|
|
|
|
|
|
|
Open new terminal
|
|
|
|
|
|
|
|
make connect-minimal
|
|
|
|
|
|
|
|
- Start Copper and discover resources at coap://[fdfd::ff:fe00:10]:5683/
|
|
|
|
- You can enable the ETSI Plugtest menu in Copper's preferences
|
|
|
|
|
|
|
|
Under Windows/Cygwin, WPCAP might need a patch in
|
|
|
|
<cygwin>\usr\include\w32api\in6addr.h:
|
|
|
|
|
|
|
|
21,23c21
|
|
|
|
< #ifdef __INSIDE_CYGWIN__
|
|
|
|
< uint32_t __s6_addr32[4];
|
|
|
|
< #endif
|
|
|
|
---
|
|
|
|
> u_int __s6_addr32[4];
|
|
|
|
36d33
|
|
|
|
< #ifdef __INSIDE_CYGWIN__
|
|
|
|
39d35
|
|
|
|
< #endif
|
|
|
|
|
|
|
|
DETAILS
|
|
|
|
-------
|
|
|
|
|
2014-05-15 11:12:22 +00:00
|
|
|
Erbium implements the Proposed Standard of CoAP. Central features are commented
|
2017-09-01 15:45:50 +00:00
|
|
|
in coap-example-server.c. In general, coap supports:
|
2013-03-26 12:09:49 +00:00
|
|
|
|
2014-05-15 11:12:22 +00:00
|
|
|
- All draft-18 header options
|
2013-03-26 12:09:49 +00:00
|
|
|
- CON Retransmissions (note COAP_MAX_OPEN_TRANSACTIONS)
|
2017-09-01 15:45:50 +00:00
|
|
|
- Blockwise Transfers (note REST_MAX_CHUNK_SIZE, see plugtest-server.c for
|
2013-03-26 12:09:49 +00:00
|
|
|
Block1 uploads)
|
|
|
|
- Separate Responses (no rest_set_pre_handler() required anymore, note
|
|
|
|
coap_separate_accept(), _reject(), and _resume())
|
|
|
|
- Resource Discovery
|
|
|
|
- Observing Resources (see EVENT_ and PRERIODIC_RESOURCE, note
|
|
|
|
COAP_MAX_OBSERVERS)
|
|
|
|
|
|
|
|
TODOs
|
|
|
|
-----
|
|
|
|
|
|
|
|
- Dedicated Observe buffers
|
|
|
|
- Optimize message struct variable access (directly access struct without copying)
|
|
|
|
- Observe client
|
|
|
|
- Multiple If-Match ETags
|
|
|
|
- (Message deduplication)
|