An mbed BLE-to-Cloud Gateway using Nucleo-F429ZI+X-Nucleo-IDB05A1 or Nucleo-L476RG+X-Nucleo-IDB05A1+X-Nucleo-IDW01M1.
Information
Nucleo- F429ZI configuration requires two hardware patches:
- on Nucleo-F429ZI open SB121 and close SB122
- on X-Nucleo-IDB05A1 move R4 to R6
The BLE client searches for and connects to a MotEnv node.
simpleclient.h@4:d5f5559b48f7, 2017-10-20 (annotated)
- Committer:
- nikapov
- Date:
- Fri Oct 20 19:04:58 2017 +0200
- Revision:
- 4:d5f5559b48f7
- Parent:
- 0:c7083010ae49
Add support to Nucleo_F429ZI and ethernet.
Who changed what in which revision?
User | Revision | Line number | New contents of line |
---|---|---|---|
nikapov | 0:c7083010ae49 | 1 | /* |
nikapov | 0:c7083010ae49 | 2 | * Copyright (c) 2015 ARM Limited. All rights reserved. |
nikapov | 0:c7083010ae49 | 3 | * SPDX-License-Identifier: Apache-2.0 |
nikapov | 0:c7083010ae49 | 4 | * Licensed under the Apache License, Version 2.0 (the License); you may |
nikapov | 0:c7083010ae49 | 5 | * not use this file except in compliance with the License. |
nikapov | 0:c7083010ae49 | 6 | * You may obtain a copy of the License at |
nikapov | 0:c7083010ae49 | 7 | * |
nikapov | 0:c7083010ae49 | 8 | * http://www.apache.org/licenses/LICENSE-2.0 |
nikapov | 0:c7083010ae49 | 9 | * |
nikapov | 0:c7083010ae49 | 10 | * Unless required by applicable law or agreed to in writing, software |
nikapov | 0:c7083010ae49 | 11 | * distributed under the License is distributed on an AS IS BASIS, WITHOUT |
nikapov | 0:c7083010ae49 | 12 | * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
nikapov | 0:c7083010ae49 | 13 | * See the License for the specific language governing permissions and |
nikapov | 0:c7083010ae49 | 14 | * limitations under the License. |
nikapov | 0:c7083010ae49 | 15 | */ |
nikapov | 0:c7083010ae49 | 16 | |
nikapov | 0:c7083010ae49 | 17 | #ifndef __SIMPLECLIENT_H__ |
nikapov | 0:c7083010ae49 | 18 | #define __SIMPLECLIENT_H__ |
nikapov | 0:c7083010ae49 | 19 | |
nikapov | 0:c7083010ae49 | 20 | #include "mbed-client/m2minterfacefactory.h" |
nikapov | 0:c7083010ae49 | 21 | #include "mbed-client/m2mdevice.h" |
nikapov | 0:c7083010ae49 | 22 | #include "mbed-client/m2minterfaceobserver.h" |
nikapov | 0:c7083010ae49 | 23 | #include "mbed-client/m2minterface.h" |
nikapov | 0:c7083010ae49 | 24 | #include "mbed-client/m2mobject.h" |
nikapov | 0:c7083010ae49 | 25 | #include "mbed-client/m2mobjectinstance.h" |
nikapov | 0:c7083010ae49 | 26 | #include "mbed-client/m2mresource.h" |
nikapov | 0:c7083010ae49 | 27 | #include "mbed-client/m2mconfig.h" |
nikapov | 0:c7083010ae49 | 28 | #include "mbed-client/m2mblockmessage.h" |
nikapov | 0:c7083010ae49 | 29 | #include "security.h" |
nikapov | 0:c7083010ae49 | 30 | #include "mbed.h" |
nikapov | 0:c7083010ae49 | 31 | |
nikapov | 0:c7083010ae49 | 32 | #define ETHERNET 1 |
nikapov | 0:c7083010ae49 | 33 | #define WIFI 2 |
nikapov | 0:c7083010ae49 | 34 | #define MESH_LOWPAN_ND 3 |
nikapov | 0:c7083010ae49 | 35 | #define MESH_THREAD 4 |
nikapov | 0:c7083010ae49 | 36 | #define ATMEL 5 |
nikapov | 0:c7083010ae49 | 37 | #define MCR20 6 |
nikapov | 0:c7083010ae49 | 38 | #define SPIRIT1 7 |
nikapov | 0:c7083010ae49 | 39 | #define EFR32 8 |
nikapov | 0:c7083010ae49 | 40 | |
nikapov | 0:c7083010ae49 | 41 | #define STRINGIFY(s) #s |
nikapov | 0:c7083010ae49 | 42 | |
nikapov | 0:c7083010ae49 | 43 | // Check if using mesh networking, define helper |
nikapov | 0:c7083010ae49 | 44 | #if MBED_CONF_APP_NETWORK_INTERFACE == MESH_LOWPAN_ND |
nikapov | 0:c7083010ae49 | 45 | #define MESH |
nikapov | 0:c7083010ae49 | 46 | #elif MBED_CONF_APP_NETWORK_INTERFACE == MESH_THREAD |
nikapov | 0:c7083010ae49 | 47 | #define MESH |
nikapov | 0:c7083010ae49 | 48 | #endif |
nikapov | 0:c7083010ae49 | 49 | |
nikapov | 0:c7083010ae49 | 50 | #if defined (MESH) || (MBED_CONF_LWIP_IPV6_ENABLED==true) |
nikapov | 0:c7083010ae49 | 51 | // Mesh is always IPV6 - also WiFi and ETH can be IPV6 if IPV6 is enabled |
nikapov | 0:c7083010ae49 | 52 | M2MInterface::NetworkStack NETWORK_STACK = M2MInterface::LwIP_IPv6; |
nikapov | 0:c7083010ae49 | 53 | #else |
nikapov | 0:c7083010ae49 | 54 | // Everything else - we assume it's IPv4 |
nikapov | 0:c7083010ae49 | 55 | M2MInterface::NetworkStack NETWORK_STACK = M2MInterface::LwIP_IPv4; |
nikapov | 0:c7083010ae49 | 56 | #endif |
nikapov | 0:c7083010ae49 | 57 | |
nikapov | 0:c7083010ae49 | 58 | //Select binding mode: UDP or TCP -- note - Mesh networking is IPv6 UDP ONLY |
nikapov | 0:c7083010ae49 | 59 | #ifdef MESH |
nikapov | 0:c7083010ae49 | 60 | M2MInterface::BindingMode SOCKET_MODE = M2MInterface::UDP; |
nikapov | 0:c7083010ae49 | 61 | #else |
nikapov | 0:c7083010ae49 | 62 | // WiFi or Ethernet supports both - TCP by default to avoid |
nikapov | 0:c7083010ae49 | 63 | // NAT problems, but UDP will also work - IF you configure |
nikapov | 0:c7083010ae49 | 64 | // your network right. |
nikapov | 0:c7083010ae49 | 65 | M2MInterface::BindingMode SOCKET_MODE = M2MInterface::TCP; |
nikapov | 0:c7083010ae49 | 66 | #endif |
nikapov | 0:c7083010ae49 | 67 | |
nikapov | 0:c7083010ae49 | 68 | |
nikapov | 0:c7083010ae49 | 69 | // MBED_DOMAIN and MBED_ENDPOINT_NAME come |
nikapov | 0:c7083010ae49 | 70 | // from the security.h file copied from connector.mbed.com |
nikapov | 0:c7083010ae49 | 71 | |
nikapov | 0:c7083010ae49 | 72 | struct MbedClientDevice { |
nikapov | 0:c7083010ae49 | 73 | const char* Manufacturer; |
nikapov | 0:c7083010ae49 | 74 | const char* Type; |
nikapov | 0:c7083010ae49 | 75 | const char* ModelNumber; |
nikapov | 0:c7083010ae49 | 76 | const char* SerialNumber; |
nikapov | 0:c7083010ae49 | 77 | }; |
nikapov | 0:c7083010ae49 | 78 | |
nikapov | 0:c7083010ae49 | 79 | /* |
nikapov | 0:c7083010ae49 | 80 | * Wrapper for mbed client stack that handles all callbacks, error handling, and |
nikapov | 0:c7083010ae49 | 81 | * other shenanigans to make the mbed client stack easier to use. |
nikapov | 0:c7083010ae49 | 82 | * |
nikapov | 0:c7083010ae49 | 83 | * The end user should only have to care about configuring the parameters at the |
nikapov | 0:c7083010ae49 | 84 | * top of this file and making sure they add the security.h file correctly. |
nikapov | 0:c7083010ae49 | 85 | * To add resources you can copy the _TODO__ function and add as many instances as |
nikapov | 0:c7083010ae49 | 86 | * you want. |
nikapov | 0:c7083010ae49 | 87 | * |
nikapov | 0:c7083010ae49 | 88 | */ |
nikapov | 0:c7083010ae49 | 89 | class MbedClient: public M2MInterfaceObserver { |
nikapov | 0:c7083010ae49 | 90 | public: |
nikapov | 0:c7083010ae49 | 91 | |
nikapov | 0:c7083010ae49 | 92 | // constructor for MbedClient object, initialize private variables |
nikapov | 0:c7083010ae49 | 93 | MbedClient(struct MbedClientDevice device) { |
nikapov | 0:c7083010ae49 | 94 | _interface = NULL; |
nikapov | 0:c7083010ae49 | 95 | _bootstrapped = false; |
nikapov | 0:c7083010ae49 | 96 | _error = false; |
nikapov | 0:c7083010ae49 | 97 | _registered = false; |
nikapov | 0:c7083010ae49 | 98 | _unregistered = false; |
nikapov | 0:c7083010ae49 | 99 | _register_security = NULL; |
nikapov | 0:c7083010ae49 | 100 | _value = 0; |
nikapov | 0:c7083010ae49 | 101 | _object = NULL; |
nikapov | 0:c7083010ae49 | 102 | _device = device; |
nikapov | 0:c7083010ae49 | 103 | } |
nikapov | 0:c7083010ae49 | 104 | |
nikapov | 0:c7083010ae49 | 105 | // de-constructor for MbedClient object, you can ignore this |
nikapov | 0:c7083010ae49 | 106 | ~MbedClient() { |
nikapov | 0:c7083010ae49 | 107 | if(_interface) { |
nikapov | 0:c7083010ae49 | 108 | delete _interface; |
nikapov | 0:c7083010ae49 | 109 | } |
nikapov | 0:c7083010ae49 | 110 | if(_register_security){ |
nikapov | 0:c7083010ae49 | 111 | delete _register_security; |
nikapov | 0:c7083010ae49 | 112 | } |
nikapov | 0:c7083010ae49 | 113 | } |
nikapov | 0:c7083010ae49 | 114 | |
nikapov | 0:c7083010ae49 | 115 | // debug printf function |
nikapov | 0:c7083010ae49 | 116 | void trace_printer(const char* str) { |
nikapov | 0:c7083010ae49 | 117 | printf("\r\n%s\r\n", str); |
nikapov | 0:c7083010ae49 | 118 | } |
nikapov | 0:c7083010ae49 | 119 | |
nikapov | 0:c7083010ae49 | 120 | /* |
nikapov | 0:c7083010ae49 | 121 | * Creates M2MInterface using which endpoint can |
nikapov | 0:c7083010ae49 | 122 | * setup its name, resource type, life time, connection mode, |
nikapov | 0:c7083010ae49 | 123 | * Currently only LwIPv4 is supported. |
nikapov | 0:c7083010ae49 | 124 | */ |
nikapov | 0:c7083010ae49 | 125 | void create_interface(const char *server_address, |
nikapov | 0:c7083010ae49 | 126 | void *handler=NULL) { |
nikapov | 0:c7083010ae49 | 127 | // Randomizing listening port for Certificate mode connectivity |
nikapov | 0:c7083010ae49 | 128 | _server_address = server_address; |
nikapov | 0:c7083010ae49 | 129 | uint16_t port = 0; // Network interface will randomize with port 0 |
nikapov | 0:c7083010ae49 | 130 | |
nikapov | 0:c7083010ae49 | 131 | // create mDS interface object, this is the base object everything else attaches to |
nikapov | 0:c7083010ae49 | 132 | _interface = M2MInterfaceFactory::create_interface(*this, |
nikapov | 0:c7083010ae49 | 133 | MBED_ENDPOINT_NAME, // endpoint name string |
nikapov | 0:c7083010ae49 | 134 | "test", // endpoint type string |
nikapov | 0:c7083010ae49 | 135 | 100, // lifetime |
nikapov | 0:c7083010ae49 | 136 | port, // listen port |
nikapov | 0:c7083010ae49 | 137 | MBED_DOMAIN, // domain string |
nikapov | 0:c7083010ae49 | 138 | SOCKET_MODE, // binding mode |
nikapov | 0:c7083010ae49 | 139 | NETWORK_STACK, // network stack |
nikapov | 0:c7083010ae49 | 140 | ""); // context address string |
nikapov | 0:c7083010ae49 | 141 | const char *binding_mode = (SOCKET_MODE == M2MInterface::UDP) ? "UDP" : "TCP"; |
nikapov | 0:c7083010ae49 | 142 | printf("\r\nSOCKET_MODE : %s\r\n", binding_mode); |
nikapov | 0:c7083010ae49 | 143 | printf("Connecting to %s\r\n", server_address); |
nikapov | 0:c7083010ae49 | 144 | |
nikapov | 0:c7083010ae49 | 145 | if(_interface) { |
nikapov | 0:c7083010ae49 | 146 | _interface->set_platform_network_handler(handler); |
nikapov | 0:c7083010ae49 | 147 | } |
nikapov | 0:c7083010ae49 | 148 | |
nikapov | 0:c7083010ae49 | 149 | } |
nikapov | 0:c7083010ae49 | 150 | |
nikapov | 0:c7083010ae49 | 151 | /* |
nikapov | 0:c7083010ae49 | 152 | * check private variable to see if the registration was sucessful or not |
nikapov | 0:c7083010ae49 | 153 | */ |
nikapov | 0:c7083010ae49 | 154 | bool register_successful() { |
nikapov | 0:c7083010ae49 | 155 | return _registered; |
nikapov | 0:c7083010ae49 | 156 | } |
nikapov | 0:c7083010ae49 | 157 | |
nikapov | 0:c7083010ae49 | 158 | /* |
nikapov | 0:c7083010ae49 | 159 | * check private variable to see if un-registration was sucessful or not |
nikapov | 0:c7083010ae49 | 160 | */ |
nikapov | 0:c7083010ae49 | 161 | bool unregister_successful() { |
nikapov | 0:c7083010ae49 | 162 | return _unregistered; |
nikapov | 0:c7083010ae49 | 163 | } |
nikapov | 0:c7083010ae49 | 164 | |
nikapov | 0:c7083010ae49 | 165 | /* |
nikapov | 0:c7083010ae49 | 166 | * Creates register server object with mbed device server address and other parameters |
nikapov | 0:c7083010ae49 | 167 | * required for client to connect to mbed device server. |
nikapov | 0:c7083010ae49 | 168 | */ |
nikapov | 0:c7083010ae49 | 169 | M2MSecurity* create_register_object() { |
nikapov | 0:c7083010ae49 | 170 | // create security object using the interface factory. |
nikapov | 0:c7083010ae49 | 171 | // this will generate a security ObjectID and ObjectInstance |
nikapov | 0:c7083010ae49 | 172 | M2MSecurity *security = M2MInterfaceFactory::create_security(M2MSecurity::M2MServer); |
nikapov | 0:c7083010ae49 | 173 | |
nikapov | 0:c7083010ae49 | 174 | // make sure security ObjectID/ObjectInstance was created successfully |
nikapov | 0:c7083010ae49 | 175 | if(security) { |
nikapov | 0:c7083010ae49 | 176 | // Add ResourceID's and values to the security ObjectID/ObjectInstance |
nikapov | 0:c7083010ae49 | 177 | security->set_resource_value(M2MSecurity::M2MServerUri, _server_address); |
nikapov | 0:c7083010ae49 | 178 | security->set_resource_value(M2MSecurity::SecurityMode, M2MSecurity::Certificate); |
nikapov | 0:c7083010ae49 | 179 | security->set_resource_value(M2MSecurity::ServerPublicKey, SERVER_CERT, sizeof(SERVER_CERT) - 1); |
nikapov | 0:c7083010ae49 | 180 | security->set_resource_value(M2MSecurity::PublicKey, CERT, sizeof(CERT) - 1); |
nikapov | 0:c7083010ae49 | 181 | security->set_resource_value(M2MSecurity::Secretkey, KEY, sizeof(KEY) - 1); |
nikapov | 0:c7083010ae49 | 182 | } |
nikapov | 0:c7083010ae49 | 183 | return security; |
nikapov | 0:c7083010ae49 | 184 | } |
nikapov | 0:c7083010ae49 | 185 | |
nikapov | 0:c7083010ae49 | 186 | /* |
nikapov | 0:c7083010ae49 | 187 | * Creates device object which contains mandatory resources linked with |
nikapov | 0:c7083010ae49 | 188 | * device endpoint. |
nikapov | 0:c7083010ae49 | 189 | */ |
nikapov | 0:c7083010ae49 | 190 | M2MDevice* create_device_object() { |
nikapov | 0:c7083010ae49 | 191 | // create device objectID/ObjectInstance |
nikapov | 0:c7083010ae49 | 192 | M2MDevice *device = M2MInterfaceFactory::create_device(); |
nikapov | 0:c7083010ae49 | 193 | // make sure device object was created successfully |
nikapov | 0:c7083010ae49 | 194 | if(device) { |
nikapov | 0:c7083010ae49 | 195 | // add resourceID's to device objectID/ObjectInstance |
nikapov | 0:c7083010ae49 | 196 | device->create_resource(M2MDevice::Manufacturer, _device.Manufacturer); |
nikapov | 0:c7083010ae49 | 197 | device->create_resource(M2MDevice::DeviceType, _device.Type); |
nikapov | 0:c7083010ae49 | 198 | device->create_resource(M2MDevice::ModelNumber, _device.ModelNumber); |
nikapov | 0:c7083010ae49 | 199 | device->create_resource(M2MDevice::SerialNumber, _device.SerialNumber); |
nikapov | 0:c7083010ae49 | 200 | } |
nikapov | 0:c7083010ae49 | 201 | return device; |
nikapov | 0:c7083010ae49 | 202 | } |
nikapov | 0:c7083010ae49 | 203 | |
nikapov | 0:c7083010ae49 | 204 | /* |
nikapov | 0:c7083010ae49 | 205 | * register an object |
nikapov | 0:c7083010ae49 | 206 | */ |
nikapov | 0:c7083010ae49 | 207 | void test_register(M2MSecurity *register_object, M2MObjectList object_list){ |
nikapov | 0:c7083010ae49 | 208 | if(_interface) { |
nikapov | 0:c7083010ae49 | 209 | // Register function |
nikapov | 0:c7083010ae49 | 210 | _interface->register_object(register_object, object_list); |
nikapov | 0:c7083010ae49 | 211 | } |
nikapov | 0:c7083010ae49 | 212 | } |
nikapov | 0:c7083010ae49 | 213 | |
nikapov | 0:c7083010ae49 | 214 | /* |
nikapov | 0:c7083010ae49 | 215 | * unregister all objects |
nikapov | 0:c7083010ae49 | 216 | */ |
nikapov | 0:c7083010ae49 | 217 | void test_unregister() { |
nikapov | 0:c7083010ae49 | 218 | if(_interface) { |
nikapov | 0:c7083010ae49 | 219 | // Unregister function |
nikapov | 0:c7083010ae49 | 220 | _interface->unregister_object(NULL); // NULL will unregister all objects |
nikapov | 0:c7083010ae49 | 221 | } |
nikapov | 0:c7083010ae49 | 222 | } |
nikapov | 0:c7083010ae49 | 223 | |
nikapov | 0:c7083010ae49 | 224 | //Callback from mbed client stack when the bootstrap |
nikapov | 0:c7083010ae49 | 225 | // is successful, it returns the mbed Device Server object |
nikapov | 0:c7083010ae49 | 226 | // which will be used for registering the resources to |
nikapov | 0:c7083010ae49 | 227 | // mbed Device server. |
nikapov | 0:c7083010ae49 | 228 | void bootstrap_done(M2MSecurity *server_object){ |
nikapov | 0:c7083010ae49 | 229 | if(server_object) { |
nikapov | 0:c7083010ae49 | 230 | _bootstrapped = true; |
nikapov | 0:c7083010ae49 | 231 | _error = false; |
nikapov | 0:c7083010ae49 | 232 | trace_printer("Bootstrapped"); |
nikapov | 0:c7083010ae49 | 233 | } |
nikapov | 0:c7083010ae49 | 234 | } |
nikapov | 0:c7083010ae49 | 235 | |
nikapov | 0:c7083010ae49 | 236 | //Callback from mbed client stack when the registration |
nikapov | 0:c7083010ae49 | 237 | // is successful, it returns the mbed Device Server object |
nikapov | 0:c7083010ae49 | 238 | // to which the resources are registered and registered objects. |
nikapov | 0:c7083010ae49 | 239 | void object_registered(M2MSecurity */*security_object*/, const M2MServer &/*server_object*/){ |
nikapov | 0:c7083010ae49 | 240 | _registered = true; |
nikapov | 0:c7083010ae49 | 241 | _unregistered = false; |
nikapov | 0:c7083010ae49 | 242 | trace_printer("Registered object successfully!"); |
nikapov | 0:c7083010ae49 | 243 | } |
nikapov | 0:c7083010ae49 | 244 | |
nikapov | 0:c7083010ae49 | 245 | //Callback from mbed client stack when the unregistration |
nikapov | 0:c7083010ae49 | 246 | // is successful, it returns the mbed Device Server object |
nikapov | 0:c7083010ae49 | 247 | // to which the resources were unregistered. |
nikapov | 0:c7083010ae49 | 248 | void object_unregistered(M2MSecurity */*server_object*/){ |
nikapov | 0:c7083010ae49 | 249 | trace_printer("Unregistered Object Successfully"); |
nikapov | 0:c7083010ae49 | 250 | _unregistered = true; |
nikapov | 0:c7083010ae49 | 251 | _registered = false; |
nikapov | 0:c7083010ae49 | 252 | } |
nikapov | 0:c7083010ae49 | 253 | |
nikapov | 0:c7083010ae49 | 254 | /* |
nikapov | 0:c7083010ae49 | 255 | * Callback from mbed client stack when registration is updated |
nikapov | 0:c7083010ae49 | 256 | */ |
nikapov | 0:c7083010ae49 | 257 | void registration_updated(M2MSecurity */*security_object*/, const M2MServer & /*server_object*/){ |
nikapov | 0:c7083010ae49 | 258 | /* The registration is updated automatically and frequently by the |
nikapov | 0:c7083010ae49 | 259 | * mbed client stack. This print statement is turned off because it |
nikapov | 0:c7083010ae49 | 260 | * tends to happen alot. |
nikapov | 0:c7083010ae49 | 261 | */ |
nikapov | 0:c7083010ae49 | 262 | //trace_printer("\r\nRegistration Updated\r\n"); |
nikapov | 0:c7083010ae49 | 263 | } |
nikapov | 0:c7083010ae49 | 264 | |
nikapov | 0:c7083010ae49 | 265 | // Callback from mbed client stack if any error is encountered |
nikapov | 0:c7083010ae49 | 266 | // during any of the LWM2M operations. Error type is passed in |
nikapov | 0:c7083010ae49 | 267 | // the callback. |
nikapov | 0:c7083010ae49 | 268 | void error(M2MInterface::Error error){ |
nikapov | 0:c7083010ae49 | 269 | _error = true; |
nikapov | 0:c7083010ae49 | 270 | switch(error){ |
nikapov | 0:c7083010ae49 | 271 | case M2MInterface::AlreadyExists: |
nikapov | 0:c7083010ae49 | 272 | trace_printer("[ERROR:] M2MInterface::AlreadyExist"); |
nikapov | 0:c7083010ae49 | 273 | break; |
nikapov | 0:c7083010ae49 | 274 | case M2MInterface::BootstrapFailed: |
nikapov | 0:c7083010ae49 | 275 | trace_printer("[ERROR:] M2MInterface::BootstrapFailed"); |
nikapov | 0:c7083010ae49 | 276 | break; |
nikapov | 0:c7083010ae49 | 277 | case M2MInterface::InvalidParameters: |
nikapov | 0:c7083010ae49 | 278 | trace_printer("[ERROR:] M2MInterface::InvalidParameters"); |
nikapov | 0:c7083010ae49 | 279 | break; |
nikapov | 0:c7083010ae49 | 280 | case M2MInterface::NotRegistered: |
nikapov | 0:c7083010ae49 | 281 | trace_printer("[ERROR:] M2MInterface::NotRegistered"); |
nikapov | 0:c7083010ae49 | 282 | break; |
nikapov | 0:c7083010ae49 | 283 | case M2MInterface::Timeout: |
nikapov | 0:c7083010ae49 | 284 | trace_printer("[ERROR:] M2MInterface::Timeout"); |
nikapov | 0:c7083010ae49 | 285 | break; |
nikapov | 0:c7083010ae49 | 286 | case M2MInterface::NetworkError: |
nikapov | 0:c7083010ae49 | 287 | trace_printer("[ERROR:] M2MInterface::NetworkError"); |
nikapov | 0:c7083010ae49 | 288 | break; |
nikapov | 0:c7083010ae49 | 289 | case M2MInterface::ResponseParseFailed: |
nikapov | 0:c7083010ae49 | 290 | trace_printer("[ERROR:] M2MInterface::ResponseParseFailed"); |
nikapov | 0:c7083010ae49 | 291 | break; |
nikapov | 0:c7083010ae49 | 292 | case M2MInterface::UnknownError: |
nikapov | 0:c7083010ae49 | 293 | trace_printer("[ERROR:] M2MInterface::UnknownError"); |
nikapov | 0:c7083010ae49 | 294 | break; |
nikapov | 0:c7083010ae49 | 295 | case M2MInterface::MemoryFail: |
nikapov | 0:c7083010ae49 | 296 | trace_printer("[ERROR:] M2MInterface::MemoryFail"); |
nikapov | 0:c7083010ae49 | 297 | break; |
nikapov | 0:c7083010ae49 | 298 | case M2MInterface::NotAllowed: |
nikapov | 0:c7083010ae49 | 299 | trace_printer("[ERROR:] M2MInterface::NotAllowed"); |
nikapov | 0:c7083010ae49 | 300 | break; |
nikapov | 0:c7083010ae49 | 301 | case M2MInterface::SecureConnectionFailed: |
nikapov | 0:c7083010ae49 | 302 | trace_printer("[ERROR:] M2MInterface::SecureConnectionFailed"); |
nikapov | 0:c7083010ae49 | 303 | break; |
nikapov | 0:c7083010ae49 | 304 | case M2MInterface::DnsResolvingFailed: |
nikapov | 0:c7083010ae49 | 305 | trace_printer("[ERROR:] M2MInterface::DnsResolvingFailed"); |
nikapov | 0:c7083010ae49 | 306 | break; |
nikapov | 0:c7083010ae49 | 307 | |
nikapov | 0:c7083010ae49 | 308 | default: |
nikapov | 0:c7083010ae49 | 309 | break; |
nikapov | 0:c7083010ae49 | 310 | } |
nikapov | 0:c7083010ae49 | 311 | } |
nikapov | 0:c7083010ae49 | 312 | |
nikapov | 0:c7083010ae49 | 313 | /* Callback from mbed client stack if any value has changed |
nikapov | 0:c7083010ae49 | 314 | * during PUT operation. Object and its type is passed in |
nikapov | 0:c7083010ae49 | 315 | * the callback. |
nikapov | 0:c7083010ae49 | 316 | * BaseType enum from m2mbase.h |
nikapov | 0:c7083010ae49 | 317 | * Object = 0x0, Resource = 0x1, ObjectInstance = 0x2, ResourceInstance = 0x3 |
nikapov | 0:c7083010ae49 | 318 | */ |
nikapov | 0:c7083010ae49 | 319 | void value_updated(M2MBase *base, M2MBase::BaseType type) { |
nikapov | 0:c7083010ae49 | 320 | printf("\r\nPUT Request Received!"); |
nikapov | 0:c7083010ae49 | 321 | printf("\r\nName :'%s', \r\nPath : '%s', \r\nType : '%d' (0 for Object, 1 for Resource), \r\nType : '%s'\r\n", |
nikapov | 0:c7083010ae49 | 322 | base->name(), |
nikapov | 0:c7083010ae49 | 323 | base->uri_path(), |
nikapov | 0:c7083010ae49 | 324 | type, |
nikapov | 0:c7083010ae49 | 325 | base->resource_type() |
nikapov | 0:c7083010ae49 | 326 | ); |
nikapov | 0:c7083010ae49 | 327 | } |
nikapov | 0:c7083010ae49 | 328 | |
nikapov | 0:c7083010ae49 | 329 | /* |
nikapov | 0:c7083010ae49 | 330 | * update the registration period |
nikapov | 0:c7083010ae49 | 331 | */ |
nikapov | 0:c7083010ae49 | 332 | void test_update_register() { |
nikapov | 0:c7083010ae49 | 333 | if (_registered) { |
nikapov | 0:c7083010ae49 | 334 | _interface->update_registration(_register_security, 100); |
nikapov | 0:c7083010ae49 | 335 | } |
nikapov | 0:c7083010ae49 | 336 | } |
nikapov | 0:c7083010ae49 | 337 | |
nikapov | 0:c7083010ae49 | 338 | /* |
nikapov | 0:c7083010ae49 | 339 | * manually configure the security object private variable |
nikapov | 0:c7083010ae49 | 340 | */ |
nikapov | 0:c7083010ae49 | 341 | void set_register_object(M2MSecurity *register_object) { |
nikapov | 0:c7083010ae49 | 342 | if (_register_security == NULL) { |
nikapov | 0:c7083010ae49 | 343 | _register_security = register_object; |
nikapov | 0:c7083010ae49 | 344 | } |
nikapov | 0:c7083010ae49 | 345 | } |
nikapov | 0:c7083010ae49 | 346 | |
nikapov | 0:c7083010ae49 | 347 | private: |
nikapov | 0:c7083010ae49 | 348 | |
nikapov | 0:c7083010ae49 | 349 | /* |
nikapov | 0:c7083010ae49 | 350 | * Private variables used in class |
nikapov | 0:c7083010ae49 | 351 | */ |
nikapov | 0:c7083010ae49 | 352 | M2MInterface *_interface; |
nikapov | 0:c7083010ae49 | 353 | M2MSecurity *_register_security; |
nikapov | 0:c7083010ae49 | 354 | M2MObject *_object; |
nikapov | 0:c7083010ae49 | 355 | volatile bool _bootstrapped; |
nikapov | 0:c7083010ae49 | 356 | volatile bool _error; |
nikapov | 0:c7083010ae49 | 357 | volatile bool _registered; |
nikapov | 0:c7083010ae49 | 358 | volatile bool _unregistered; |
nikapov | 0:c7083010ae49 | 359 | int _value; |
nikapov | 0:c7083010ae49 | 360 | struct MbedClientDevice _device; |
nikapov | 0:c7083010ae49 | 361 | String _server_address; |
nikapov | 0:c7083010ae49 | 362 | }; |
nikapov | 0:c7083010ae49 | 363 | |
nikapov | 0:c7083010ae49 | 364 | #endif // __SIMPLECLIENT_H__ |