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:

  1. on Nucleo-F429ZI open SB121 and close SB122
  2. on X-Nucleo-IDB05A1 move R4 to R6

The BLE client searches for and connects to a MotEnv node.

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?

UserRevisionLine numberNew 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__